- add 'vid_showcurrentscaling' ccmd, expanded output for 'vid_scaletowidth' and 'vid_scaletoheight' commands

- made the vid_scaleto____ commands less hacky - after finding out I could route the calls through screen->, found the correct screen-> commands, and do scaling based on the real screen dimensions
This commit is contained in:
Rachael Alexanderson 2018-05-17 19:25:32 -04:00 committed by drfrag
parent e4110ded3c
commit 792871a380

View file

@ -188,7 +188,9 @@ bool ViewportIsScaled43()
void R_ShowCurrentScaling()
{
int x1 = screen->GetWidth(), y1 = screen->GetHeight(), x2 = x1 * vid_scalefactor, y2 = y1 * vid_scalefactor;
Printf("Current Scale: %f\n", (float)(vid_scalefactor));
Printf("Real resolution: %i x %i\nEmulated resolution: %i x %i\n", x1, y1, x2, y2);
}
bool R_CalcsShouldBeBlocked()
@ -211,13 +213,18 @@ bool R_CalcsShouldBeBlocked()
return false;
}
CCMD (vid_showcurrentscaling)
{
R_ShowCurrentScaling();
}
CCMD (vid_scaletowidth)
{
if (R_CalcsShouldBeBlocked())
return;
if (argv.argc() > 1)
vid_scalefactor = (float)((double)vid_scalefactor * (double)atof(argv[1]) / (double)DisplayWidth);
vid_scalefactor = (float)((double)atof(argv[1]) / screen->GetWidth());
R_ShowCurrentScaling();
}
@ -228,7 +235,7 @@ CCMD (vid_scaletoheight)
return;
if (argv.argc() > 1)
vid_scalefactor = (float)((double)vid_scalefactor * (double)atof(argv[1]) / (double)DisplayHeight);
vid_scalefactor = (float)((double)atof(argv[1]) / screen->GetHeight());
R_ShowCurrentScaling();
}