mirror of
https://github.com/ZDoom/gzdoom.git
synced 2025-01-18 15:42:34 +00:00
- The options menu no longer scales up so quickly, so it can fit wider text
onscreen. In addition, it now uses the whole height available to it. Also, at lower resolutions, items on the compatibility options menu now cut off the beginning of the option label rather than the option setting, making this menu useable where previously it was not. SVN r2044 (trunk)
This commit is contained in:
parent
9eb5fdd276
commit
b3986a0235
8 changed files with 166 additions and 86 deletions
|
@ -1,4 +1,9 @@
|
||||||
December 24, 2009
|
December 24, 2009
|
||||||
|
- The options menu no longer scales up so quickly, so it can fit wider text
|
||||||
|
onscreen. In addition, it now uses the whole height available to it. Also,
|
||||||
|
at lower resolutions, items on the compatibility options menu now cut off
|
||||||
|
the beginning of the option label rather than the option setting, making
|
||||||
|
this menu useable where previously it was not.
|
||||||
- Added a channel parameter to the sector overload of SN_StopSequence() so
|
- Added a channel parameter to the sector overload of SN_StopSequence() so
|
||||||
it can be properly paired with calls to SN_StartSequence().
|
it can be properly paired with calls to SN_StartSequence().
|
||||||
- Fixed: P_CheckPlayerSprites() ignored the MF4_NOSKIN flag. It now also sets
|
- Fixed: P_CheckPlayerSprites() ignored the MF4_NOSKIN flag. It now also sets
|
||||||
|
|
|
@ -2120,6 +2120,26 @@ static void M_PlayerSetupTicker (void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void M_DrawPlayerSlider (int x, int y, int cur)
|
||||||
|
{
|
||||||
|
const int range = 255;
|
||||||
|
|
||||||
|
x = (x - 160) * CleanXfac + screen->GetWidth() / 2;
|
||||||
|
y = (y - 100) * CleanYfac + screen->GetHeight() / 2;
|
||||||
|
|
||||||
|
screen->DrawText (ConFont, CR_WHITE, x, y,
|
||||||
|
"\x10\x11\x11\x11\x11\x11\x11\x11\x11\x11\x11\x12",
|
||||||
|
DTA_CellX, 8 * CleanXfac,
|
||||||
|
DTA_CellY, 8 * CleanYfac,
|
||||||
|
TAG_DONE);
|
||||||
|
screen->DrawText (ConFont, CR_ORANGE, x + (5 + (int)((cur * 78) / range)) * CleanXfac, y,
|
||||||
|
"\x13",
|
||||||
|
DTA_CellX, 8 * CleanXfac,
|
||||||
|
DTA_CellY, 8 * CleanYfac,
|
||||||
|
TAG_DONE);
|
||||||
|
}
|
||||||
|
|
||||||
static void M_PlayerSetupDrawer ()
|
static void M_PlayerSetupDrawer ()
|
||||||
{
|
{
|
||||||
int x, xo, yo;
|
int x, xo, yo;
|
||||||
|
@ -2251,9 +2271,9 @@ static void M_PlayerSetupDrawer ()
|
||||||
x = SmallFont->StringWidth ("Green") + 8 + PSetupDef.x;
|
x = SmallFont->StringWidth ("Green") + 8 + PSetupDef.x;
|
||||||
color = players[consoleplayer].userinfo.color;
|
color = players[consoleplayer].userinfo.color;
|
||||||
|
|
||||||
M_DrawSlider (x, PSetupDef.y + LINEHEIGHT*2+yo, 0.0f, 255.0f, float(RPART(color)), -1);
|
M_DrawPlayerSlider (x, PSetupDef.y + LINEHEIGHT*2+yo, RPART(color));
|
||||||
M_DrawSlider (x, PSetupDef.y + LINEHEIGHT*3+yo, 0.0f, 255.0f, float(GPART(color)), -1);
|
M_DrawPlayerSlider (x, PSetupDef.y + LINEHEIGHT*3+yo, GPART(color));
|
||||||
M_DrawSlider (x, PSetupDef.y + LINEHEIGHT*4+yo, 0.0f, 255.0f, float(BPART(color)), -1);
|
M_DrawPlayerSlider (x, PSetupDef.y + LINEHEIGHT*4+yo, BPART(color));
|
||||||
|
|
||||||
// [GRB] Draw class setting
|
// [GRB] Draw class setting
|
||||||
int pclass = players[consoleplayer].userinfo.PlayerClass;
|
int pclass = players[consoleplayer].userinfo.PlayerClass;
|
||||||
|
@ -3443,7 +3463,13 @@ void M_Drawer ()
|
||||||
screen->DrawText(SmallFont, CR_UNTRANSLATED, 160, y + fontheight + 1, GStrings["TXT_NO"], DTA_Clean, true, TAG_DONE);
|
screen->DrawText(SmallFont, CR_UNTRANSLATED, 160, y + fontheight + 1, GStrings["TXT_NO"], DTA_Clean, true, TAG_DONE);
|
||||||
if (skullAnimCounter < 6)
|
if (skullAnimCounter < 6)
|
||||||
{
|
{
|
||||||
M_DrawConText(CR_RED, 150, y + (fontheight + 1) * messageSelection, "\xd");
|
screen->DrawText(ConFont, CR_RED,
|
||||||
|
(150 - 160) * CleanXfac + screen->GetWidth() / 2,
|
||||||
|
(y + (fontheight + 1) * messageSelection - 100) * CleanYfac + screen->GetHeight() / 2,
|
||||||
|
"\xd",
|
||||||
|
DTA_CellX, 8 * CleanXfac,
|
||||||
|
DTA_CellY, 8 * CleanYfac,
|
||||||
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -84,9 +84,6 @@ void M_DeactivateMenuInput ();
|
||||||
|
|
||||||
void M_NotifyNewSave (const char *file, const char *title, bool okForQuicksave);
|
void M_NotifyNewSave (const char *file, const char *title, bool okForQuicksave);
|
||||||
|
|
||||||
// Draw a slider. Set fracdigits negative to not display the current value numerically.
|
|
||||||
void M_DrawSlider (int x, int y, double min, double max, double cur, int fracdigits=1);
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// MENU TYPEDEFS
|
// MENU TYPEDEFS
|
||||||
//
|
//
|
||||||
|
|
|
@ -1494,11 +1494,9 @@ void M_DrawConText (int color, int x, int y, const char *str)
|
||||||
{
|
{
|
||||||
int len = (int)strlen(str);
|
int len = (int)strlen(str);
|
||||||
|
|
||||||
x = (x - 160) * CleanXfac + screen->GetWidth() / 2;
|
|
||||||
y = (y - 100) * CleanYfac + screen->GetHeight() / 2;
|
|
||||||
screen->DrawText (ConFont, color, x, y, str,
|
screen->DrawText (ConFont, color, x, y, str,
|
||||||
DTA_CellX, 8 * CleanXfac,
|
DTA_CellX, 8 * CleanXfac_1,
|
||||||
DTA_CellY, 8 * CleanYfac,
|
DTA_CellY, 8 * CleanYfac_1,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1558,7 +1556,8 @@ bool M_StartOptionsMenu (void)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void M_DrawSlider (int x, int y, double min, double max, double cur,int fracdigits)
|
// Draw a slider. Set fracdigits negative to not display the current value numerically.
|
||||||
|
static void M_DrawSlider (int x, int y, double min, double max, double cur,int fracdigits)
|
||||||
{
|
{
|
||||||
double range;
|
double range;
|
||||||
|
|
||||||
|
@ -1572,7 +1571,7 @@ void M_DrawSlider (int x, int y, double min, double max, double cur,int fracdigi
|
||||||
{
|
{
|
||||||
char textbuf[16];
|
char textbuf[16];
|
||||||
mysnprintf(textbuf, countof(textbuf), "%.*f", fracdigits, cur);
|
mysnprintf(textbuf, countof(textbuf), "%.*f", fracdigits, cur);
|
||||||
screen->DrawText(SmallFont, CR_DARKGRAY, x + 12*8 + 4, y, textbuf, DTA_Clean, true, TAG_DONE);
|
screen->DrawText(SmallFont, CR_DARKGRAY, x + (12*8 + 4) * CleanXfac_1, y, textbuf, DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1643,6 +1642,7 @@ void M_OptDrawer ()
|
||||||
DWORD overlay;
|
DWORD overlay;
|
||||||
int labelofs;
|
int labelofs;
|
||||||
int indent;
|
int indent;
|
||||||
|
int cursorspace;
|
||||||
|
|
||||||
if (!CurrentMenu->DontDim)
|
if (!CurrentMenu->DontDim)
|
||||||
{
|
{
|
||||||
|
@ -1663,9 +1663,9 @@ void M_OptDrawer ()
|
||||||
if (BigFont && CurrentMenu->texttitle)
|
if (BigFont && CurrentMenu->texttitle)
|
||||||
{
|
{
|
||||||
screen->DrawText (BigFont, gameinfo.gametype & GAME_DoomChex ? CR_RED : CR_UNTRANSLATED,
|
screen->DrawText (BigFont, gameinfo.gametype & GAME_DoomChex ? CR_RED : CR_UNTRANSLATED,
|
||||||
160-BigFont->StringWidth (CurrentMenu->texttitle)/2, 10,
|
(screen->GetWidth() - BigFont->StringWidth(CurrentMenu->texttitle) * CleanXfac_1) / 2, 10*CleanYfac_1,
|
||||||
CurrentMenu->texttitle, DTA_Clean, true, TAG_DONE);
|
CurrentMenu->texttitle, DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
y = 15 + BigFont->GetHeight ();
|
y = 15 + BigFont->GetHeight();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -1674,7 +1674,7 @@ void M_OptDrawer ()
|
||||||
}
|
}
|
||||||
if (gameinfo.gametype & GAME_Raven)
|
if (gameinfo.gametype & GAME_Raven)
|
||||||
{
|
{
|
||||||
labelofs = 2;
|
labelofs = 2 * CleanXfac_1;
|
||||||
y -= 2;
|
y -= 2;
|
||||||
fontheight = 9;
|
fontheight = 9;
|
||||||
}
|
}
|
||||||
|
@ -1683,9 +1683,13 @@ void M_OptDrawer ()
|
||||||
labelofs = 0;
|
labelofs = 0;
|
||||||
fontheight = 8;
|
fontheight = 8;
|
||||||
}
|
}
|
||||||
ytop = y + CurrentMenu->scrolltop * 8;
|
cursorspace = 14 * CleanXfac_1;
|
||||||
|
y *= CleanYfac_1;
|
||||||
|
fontheight *= CleanYfac_1;
|
||||||
|
ytop = y + CurrentMenu->scrolltop * 8 * CleanYfac_1;
|
||||||
|
int lastrow = screen->GetHeight() - SmallFont->GetHeight() * CleanYfac_1;
|
||||||
|
|
||||||
for (i = 0; i < CurrentMenu->numitems && y <= 200 - SmallFont->GetHeight(); i++, y += fontheight)
|
for (i = 0; i < CurrentMenu->numitems && y <= lastrow; i++, y += fontheight)
|
||||||
{
|
{
|
||||||
if (i == CurrentMenu->scrolltop)
|
if (i == CurrentMenu->scrolltop)
|
||||||
{
|
{
|
||||||
|
@ -1696,15 +1700,30 @@ void M_OptDrawer ()
|
||||||
overlay = 0;
|
overlay = 0;
|
||||||
if (item->type == discrete && item->c.discretecenter == 1)
|
if (item->type == discrete && item->c.discretecenter == 1)
|
||||||
{
|
{
|
||||||
indent = 160;
|
indent = screen->GetWidth() / 2;
|
||||||
}
|
}
|
||||||
else if (item->type == joymore)
|
else if (item->type == joymore)
|
||||||
{
|
{
|
||||||
indent = 4;
|
indent = 4 * CleanXfac_1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
indent = CurrentMenu->indent;
|
indent = CurrentMenu->indent;
|
||||||
|
if (indent > 280)
|
||||||
|
{ // kludge for the compatibility options with their extremely long labels
|
||||||
|
if (indent + 40 <= CleanWidth_1)
|
||||||
|
{
|
||||||
|
indent = (screen->GetWidth() - ((indent + 40) * CleanXfac_1)) / 2 + indent * CleanXfac_1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
indent = screen->GetWidth() - 40 * CleanXfac_1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
indent = (indent - 160) * CleanXfac_1 + screen->GetWidth() / 2;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (item->type != screenres)
|
if (item->type != screenres)
|
||||||
|
@ -1727,7 +1746,7 @@ void M_OptDrawer ()
|
||||||
label = somestring;
|
label = somestring;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
width = SmallFont->StringWidth(label);
|
width = SmallFont->StringWidth(label) * CleanXfac_1;
|
||||||
switch (item->type)
|
switch (item->type)
|
||||||
{
|
{
|
||||||
case more:
|
case more:
|
||||||
|
@ -1737,34 +1756,34 @@ void M_OptDrawer ()
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case joymore:
|
case joymore:
|
||||||
x = 20;
|
x = 20 * CleanXfac_1;
|
||||||
color = MoreColor;
|
color = MoreColor;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case numberedmore:
|
case numberedmore:
|
||||||
case rsafemore:
|
case rsafemore:
|
||||||
case rightmore:
|
case rightmore:
|
||||||
x = indent + 14;
|
x = indent + cursorspace;
|
||||||
color = item->type != rightmore ? CR_GREEN : MoreColor;
|
color = item->type != rightmore ? CR_GREEN : MoreColor;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case redtext:
|
case redtext:
|
||||||
x = 160 - width / 2;
|
x = screen->GetWidth() / 2 - width / 2;
|
||||||
color = LabelColor;
|
color = LabelColor;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case whitetext:
|
case whitetext:
|
||||||
x = 160 - width / 2;
|
x = screen->GetWidth() / 2 - width / 2;
|
||||||
color = CR_GOLD;//ValueColor;
|
color = CR_GOLD;//ValueColor;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case listelement:
|
case listelement:
|
||||||
x = indent + 14;
|
x = indent + cursorspace;
|
||||||
color = LabelColor;
|
color = LabelColor;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case colorpicker:
|
case colorpicker:
|
||||||
x = indent + 14;
|
x = indent + cursorspace;
|
||||||
color = MoreColor;
|
color = MoreColor;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -1781,7 +1800,7 @@ void M_OptDrawer ()
|
||||||
? CR_YELLOW : LabelColor;
|
? CR_YELLOW : LabelColor;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
screen->DrawText (SmallFont, color, x, y, label, DTA_Clean, true, DTA_ColorOverlay, overlay, TAG_DONE);
|
screen->DrawText (SmallFont, color, x, y, label, DTA_CleanNoMove_1, true, DTA_ColorOverlay, overlay, TAG_DONE);
|
||||||
|
|
||||||
switch (item->type)
|
switch (item->type)
|
||||||
{
|
{
|
||||||
|
@ -1791,8 +1810,8 @@ void M_OptDrawer ()
|
||||||
char tbuf[16];
|
char tbuf[16];
|
||||||
|
|
||||||
mysnprintf (tbuf, countof(tbuf), "%d.", item->b.position);
|
mysnprintf (tbuf, countof(tbuf), "%d.", item->b.position);
|
||||||
x = indent - SmallFont->StringWidth (tbuf);
|
x = indent - SmallFont->StringWidth (tbuf) * CleanXfac_1;
|
||||||
screen->DrawText (SmallFont, CR_GREY, x, y, tbuf, DTA_Clean, true, TAG_DONE);
|
screen->DrawText (SmallFont, CR_GREY, x, y, tbuf, DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -1808,14 +1827,14 @@ void M_OptDrawer ()
|
||||||
|
|
||||||
if (v == vals)
|
if (v == vals)
|
||||||
{
|
{
|
||||||
screen->DrawText (SmallFont, ValueColor, indent + 14, y, "Unknown",
|
screen->DrawText (SmallFont, ValueColor, indent + cursorspace, y, "Unknown",
|
||||||
DTA_Clean, true, TAG_DONE);
|
DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
screen->DrawText (SmallFont, item->type == cdiscrete ? v : ValueColor,
|
screen->DrawText (SmallFont, item->type == cdiscrete ? v : ValueColor,
|
||||||
indent + 14, y, item->e.values[v].name,
|
indent + cursorspace, y, item->e.values[v].name,
|
||||||
DTA_Clean, true, TAG_DONE);
|
DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1865,15 +1884,15 @@ void M_OptDrawer ()
|
||||||
|
|
||||||
if (v == vals)
|
if (v == vals)
|
||||||
{
|
{
|
||||||
screen->DrawText (SmallFont, ValueColor, indent + 14, y, "Unknown",
|
screen->DrawText (SmallFont, ValueColor, indent + cursorspace, y, "Unknown",
|
||||||
DTA_Clean, true, DTA_ColorOverlay, overlay, TAG_DONE);
|
DTA_CleanNoMove_1, true, DTA_ColorOverlay, overlay, TAG_DONE);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
screen->DrawText (SmallFont, item->type == cdiscrete ? v : ValueColor,
|
screen->DrawText (SmallFont, item->type == cdiscrete ? v : ValueColor,
|
||||||
indent + 14, y,
|
indent + cursorspace, y,
|
||||||
item->type != discretes ? item->e.values[v].name : item->e.valuestrings[v].name.GetChars(),
|
item->type != discretes ? item->e.values[v].name : item->e.valuestrings[v].name.GetChars(),
|
||||||
DTA_Clean, true, DTA_ColorOverlay, overlay, TAG_DONE);
|
DTA_CleanNoMove_1, true, DTA_ColorOverlay, overlay, TAG_DONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1885,18 +1904,18 @@ void M_OptDrawer ()
|
||||||
|
|
||||||
value = item->a.cvar->GetGenericRep (CVAR_String);
|
value = item->a.cvar->GetGenericRep (CVAR_String);
|
||||||
v = M_FindCurVal(value.String, item->e.enumvalues, (int)item->b.numvalues);
|
v = M_FindCurVal(value.String, item->e.enumvalues, (int)item->b.numvalues);
|
||||||
screen->DrawText(SmallFont, ValueColor, indent + 14, y, v, DTA_Clean, true, TAG_DONE);
|
screen->DrawText(SmallFont, ValueColor, indent + cursorspace, y, v, DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case nochoice:
|
case nochoice:
|
||||||
screen->DrawText (SmallFont, CR_GOLD, indent + 14, y,
|
screen->DrawText (SmallFont, CR_GOLD, indent + cursorspace, y,
|
||||||
(item->e.values[(int)item->b.min]).name, DTA_Clean, true, TAG_DONE);
|
(item->e.values[(int)item->b.min]).name, DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case joy_sens:
|
case joy_sens:
|
||||||
value.Float = SELECTED_JOYSTICK->GetSensitivity();
|
value.Float = SELECTED_JOYSTICK->GetSensitivity();
|
||||||
M_DrawSlider (indent + 14, y + labelofs, item->b.min, item->c.max, value.Float, 1);
|
M_DrawSlider (indent + cursorspace, y + labelofs, item->b.min, item->c.max, value.Float, 1);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case joy_slider:
|
case joy_slider:
|
||||||
|
@ -1909,29 +1928,29 @@ void M_OptDrawer ()
|
||||||
assert(item->e.joyslidernum == 1);
|
assert(item->e.joyslidernum == 1);
|
||||||
value.Float = SELECTED_JOYSTICK->GetAxisDeadZone(item->a.joyselection);
|
value.Float = SELECTED_JOYSTICK->GetAxisDeadZone(item->a.joyselection);
|
||||||
}
|
}
|
||||||
M_DrawSlider (indent + 14, y + labelofs, item->b.min, item->c.max, fabs(value.Float), 3);
|
M_DrawSlider (indent + cursorspace, y + labelofs, item->b.min, item->c.max, fabs(value.Float), 3);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case joy_inverter:
|
case joy_inverter:
|
||||||
assert(item->e.joyslidernum == 0);
|
assert(item->e.joyslidernum == 0);
|
||||||
value.Float = SELECTED_JOYSTICK->GetAxisScale(item->a.joyselection);
|
value.Float = SELECTED_JOYSTICK->GetAxisScale(item->a.joyselection);
|
||||||
screen->DrawText(SmallFont, ValueColor, indent + 14, y,
|
screen->DrawText(SmallFont, ValueColor, indent + cursorspace, y,
|
||||||
(value.Float < 0) ? "Yes" : "No",
|
(value.Float < 0) ? "Yes" : "No",
|
||||||
DTA_Clean, true, TAG_DONE);
|
DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case slider:
|
case slider:
|
||||||
value = item->a.cvar->GetGenericRep (CVAR_Float);
|
value = item->a.cvar->GetGenericRep (CVAR_Float);
|
||||||
M_DrawSlider (indent + 14, y + labelofs, item->b.min, item->c.max, value.Float, 1);
|
M_DrawSlider (indent + cursorspace, y + labelofs, item->b.min, item->c.max, value.Float, 1);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case absslider:
|
case absslider:
|
||||||
value = item->a.cvar->GetGenericRep (CVAR_Float);
|
value = item->a.cvar->GetGenericRep (CVAR_Float);
|
||||||
M_DrawSlider (indent + 14, y + labelofs, item->b.min, item->c.max, fabs(value.Float), 1);
|
M_DrawSlider (indent + cursorspace, y + labelofs, item->b.min, item->c.max, fabs(value.Float), 1);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case intslider:
|
case intslider:
|
||||||
M_DrawSlider (indent + 14, y + labelofs, item->b.min, item->c.max, item->a.fval, 0);
|
M_DrawSlider (indent + cursorspace, y + labelofs, item->b.min, item->c.max, item->a.fval, 0);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case control:
|
case control:
|
||||||
|
@ -1941,12 +1960,12 @@ void M_OptDrawer ()
|
||||||
C_NameKeys (description, item->b.key1, item->c.key2);
|
C_NameKeys (description, item->b.key1, item->c.key2);
|
||||||
if (description[0])
|
if (description[0])
|
||||||
{
|
{
|
||||||
M_DrawConText(CR_WHITE, indent + 14, y-1+labelofs, description);
|
M_DrawConText(CR_WHITE, indent + cursorspace, y-1+labelofs, description);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
screen->DrawText(SmallFont, CR_BLACK, indent + 14, y + labelofs, "---",
|
screen->DrawText(SmallFont, CR_BLACK, indent + cursorspace, y + labelofs, "---",
|
||||||
DTA_Clean, true, TAG_DONE);
|
DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -1954,9 +1973,9 @@ void M_OptDrawer ()
|
||||||
case colorpicker:
|
case colorpicker:
|
||||||
{
|
{
|
||||||
int box_x, box_y;
|
int box_x, box_y;
|
||||||
box_x = (indent - 35 - 160) * CleanXfac + screen->GetWidth()/2;
|
box_x = indent - 35 * CleanXfac_1;
|
||||||
box_y = (y - ((gameinfo.gametype & GAME_Raven) ? 99 : 100)) * CleanYfac + screen->GetHeight()/2;
|
box_y = (gameinfo.gametype & GAME_Raven) ? y - CleanYfac_1 : y;
|
||||||
screen->Clear (box_x, box_y, box_x + 32*CleanXfac, box_y + (fontheight-1)*CleanYfac,
|
screen->Clear (box_x, box_y, box_x + 32*CleanXfac_1, box_y + fontheight-CleanYfac_1,
|
||||||
item->a.colorcvar->GetIndex(), 0);
|
item->a.colorcvar->GetIndex(), 0);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -1965,12 +1984,12 @@ void M_OptDrawer ()
|
||||||
{
|
{
|
||||||
int box_x, box_y;
|
int box_x, box_y;
|
||||||
int x1, p;
|
int x1, p;
|
||||||
const int w = fontheight*CleanXfac;
|
const int w = fontheight;
|
||||||
const int h = fontheight*CleanYfac;
|
const int h = fontheight;
|
||||||
|
|
||||||
box_y = (y - 98) * CleanYfac + screen->GetHeight()/2;
|
box_y = y - 2 * CleanYfac_1;
|
||||||
p = 0;
|
p = 0;
|
||||||
box_x = (indent - 32 - 160) * CleanXfac + screen->GetWidth()/2;
|
box_x = indent - 32 * CleanXfac_1;
|
||||||
for (x1 = 0, p = int(item->b.min * 16); x1 < 16; ++p, ++x1)
|
for (x1 = 0, p = int(item->b.min * 16); x1 < 16; ++p, ++x1)
|
||||||
{
|
{
|
||||||
screen->Clear (box_x, box_y, box_x + w, box_y + h, p, 0);
|
screen->Clear (box_x, box_y, box_x + w, box_y + h, p, 0);
|
||||||
|
@ -2025,7 +2044,7 @@ void M_OptDrawer ()
|
||||||
}
|
}
|
||||||
|
|
||||||
screen->DrawText (SmallFont, ValueColor,
|
screen->DrawText (SmallFont, ValueColor,
|
||||||
indent + 14, y, str, DTA_Clean, true, TAG_DONE);
|
indent + cursorspace, y, str, DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -2037,12 +2056,13 @@ void M_OptDrawer ()
|
||||||
i == CurrentItem &&
|
i == CurrentItem &&
|
||||||
(skullAnimCounter < 6 || menuactive == MENU_WaitKey))
|
(skullAnimCounter < 6 || menuactive == MENU_WaitKey))
|
||||||
{
|
{
|
||||||
M_DrawConText(CR_RED, indent + 3, y-1+labelofs, "\xd");
|
M_DrawConText(CR_RED, indent + 3 * CleanXfac_1, y-CleanYfac_1+labelofs, "\xd");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
char *str = NULL;
|
char *str = NULL;
|
||||||
|
int colwidth = screen->GetWidth() / 3;
|
||||||
|
|
||||||
for (x = 0; x < 3; x++)
|
for (x = 0; x < 3; x++)
|
||||||
{
|
{
|
||||||
|
@ -2059,13 +2079,13 @@ void M_OptDrawer ()
|
||||||
else
|
else
|
||||||
color = CR_BRICK; //LabelColor;
|
color = CR_BRICK; //LabelColor;
|
||||||
|
|
||||||
screen->DrawText (SmallFont, color, 104 * x + 20, y, str, DTA_Clean, true, TAG_DONE);
|
screen->DrawText (SmallFont, color, colwidth * x + 20 * CleanXfac_1, y, str, DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (i == CurrentItem && ((item->a.selmode != -1 && (skullAnimCounter < 6 || menuactive == MENU_WaitKey)) || testingmode))
|
if (i == CurrentItem && ((item->a.selmode != -1 && (skullAnimCounter < 6 || menuactive == MENU_WaitKey)) || testingmode))
|
||||||
{
|
{
|
||||||
M_DrawConText(CR_RED, item->a.selmode * 104 + 8, y-1 + labelofs, "\xd");
|
M_DrawConText(CR_RED, item->a.selmode * colwidth + 8 * CleanXfac_1, y - CleanYfac_1 + labelofs, "\xd");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2076,11 +2096,11 @@ void M_OptDrawer ()
|
||||||
|
|
||||||
if (CanScrollUp)
|
if (CanScrollUp)
|
||||||
{
|
{
|
||||||
M_DrawConText(CR_ORANGE, 3, ytop + labelofs, "\x1a");
|
M_DrawConText(CR_ORANGE, 3 * CleanXfac_1, ytop + labelofs, "\x1a");
|
||||||
}
|
}
|
||||||
if (CanScrollDown)
|
if (CanScrollDown)
|
||||||
{
|
{
|
||||||
M_DrawConText(CR_ORANGE, 3, y - 8 + labelofs, "\x1b");
|
M_DrawConText(CR_ORANGE, 3 * CleanXfac_1, y - 8*CleanYfac_1 + labelofs, "\x1b");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flagsvar)
|
if (flagsvar)
|
||||||
|
@ -2103,8 +2123,8 @@ void M_OptDrawer ()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
screen->DrawText (SmallFont, ValueColor,
|
screen->DrawText (SmallFont, ValueColor,
|
||||||
160 - (SmallFont->StringWidth (flagsblah) >> 1), 0, flagsblah,
|
(screen->GetWidth() - SmallFont->StringWidth (flagsblah) * CleanXfac_1) / 2, 0, flagsblah,
|
||||||
DTA_Clean, true, TAG_DONE);
|
DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2257,31 +2277,33 @@ void M_OptButtonHandler(EMenuKey key, bool repeat)
|
||||||
}
|
}
|
||||||
if (CurrentItem < 0)
|
if (CurrentItem < 0)
|
||||||
{
|
{
|
||||||
int maxitems, rowheight;
|
int ytop, maxitems, rowheight;
|
||||||
|
|
||||||
// Figure out how many lines of text fit on the menu
|
// Figure out how many lines of text fit on the menu
|
||||||
if (CurrentMenu->y != 0)
|
if (CurrentMenu->y != 0)
|
||||||
{
|
{
|
||||||
maxitems = CurrentMenu->y;
|
ytop = CurrentMenu->y;
|
||||||
}
|
}
|
||||||
else if (BigFont && CurrentMenu->texttitle)
|
else if (BigFont && CurrentMenu->texttitle)
|
||||||
{
|
{
|
||||||
maxitems = 15 + BigFont->GetHeight ();
|
ytop = 15 + BigFont->GetHeight ();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
maxitems = 15;
|
ytop = 15;
|
||||||
}
|
}
|
||||||
if (!(gameinfo.gametype & GAME_DoomChex))
|
if (!(gameinfo.gametype & GAME_DoomChex))
|
||||||
{
|
{
|
||||||
maxitems -= 2;
|
ytop -= 2;
|
||||||
rowheight = 9;
|
rowheight = 9;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
rowheight = 8;
|
rowheight = 8;
|
||||||
}
|
}
|
||||||
maxitems = (200 - SmallFont->GetHeight () - maxitems) / rowheight + 1;
|
ytop *= CleanYfac_1;
|
||||||
|
rowheight *= CleanYfac_1;
|
||||||
|
maxitems = (screen->GetHeight() - SmallFont->GetHeight() - ytop) / rowheight + 1;
|
||||||
|
|
||||||
CurrentMenu->scrollpos = MAX (0,CurrentMenu->numitems - maxitems + CurrentMenu->scrolltop);
|
CurrentMenu->scrollpos = MAX (0,CurrentMenu->numitems - maxitems + CurrentMenu->scrolltop);
|
||||||
CurrentItem = CurrentMenu->numitems - 1;
|
CurrentItem = CurrentMenu->numitems - 1;
|
||||||
|
@ -2989,16 +3011,16 @@ static void ColorPickerDrawer ()
|
||||||
DWORD oldColor = DWORD(*ColorPickerItems[0].a.colorcvar) | 0xFF000000;
|
DWORD oldColor = DWORD(*ColorPickerItems[0].a.colorcvar) | 0xFF000000;
|
||||||
|
|
||||||
int x = screen->GetWidth()*2/3;
|
int x = screen->GetWidth()*2/3;
|
||||||
int y = (15 + BigFont->GetHeight() + SmallFont->GetHeight()*5 - 90) * CleanYfac + screen->GetHeight()/2;
|
int y = (15 + BigFont->GetHeight() + SmallFont->GetHeight()*5 - 10) * CleanYfac_1;
|
||||||
|
|
||||||
screen->Clear (x, y, x + 48*CleanXfac, y + 48*CleanYfac, -1, oldColor);
|
screen->Clear (x, y, x + 48*CleanXfac_1, y + 48*CleanYfac_1, -1, oldColor);
|
||||||
screen->Clear (x + 48*CleanXfac, y, x + 48*2*CleanXfac, y + 48*CleanYfac, -1, newColor);
|
screen->Clear (x + 48*CleanXfac_1, y, x + 48*2*CleanXfac_1, y + 48*CleanYfac_1, -1, newColor);
|
||||||
|
|
||||||
y += 49*CleanYfac;
|
y += 49*CleanYfac_1;
|
||||||
screen->DrawText (SmallFont, CR_GRAY, x+(24-SmallFont->StringWidth("Old")/2)*CleanXfac, y,
|
screen->DrawText (SmallFont, CR_GRAY, x+(24-SmallFont->StringWidth("Old")/2)*CleanXfac_1, y,
|
||||||
"Old", DTA_CleanNoMove, true, TAG_DONE);
|
"Old", DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
screen->DrawText (SmallFont, CR_WHITE, x+(48+24-SmallFont->StringWidth("New")/2)*CleanXfac, y,
|
screen->DrawText (SmallFont, CR_WHITE, x+(48+24-SmallFont->StringWidth("New")/2)*CleanXfac_1, y,
|
||||||
"New", DTA_CleanNoMove, true, TAG_DONE);
|
"New", DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void SetColorPickerSliders ()
|
static void SetColorPickerSliders ()
|
||||||
|
@ -3099,11 +3121,12 @@ static void DrawJoystickConfigMenuHeader()
|
||||||
{
|
{
|
||||||
FString joyname = SELECTED_JOYSTICK->GetName();
|
FString joyname = SELECTED_JOYSTICK->GetName();
|
||||||
screen->DrawText(BigFont, gameinfo.gametype & GAME_DoomChex ? CR_RED : CR_UNTRANSLATED,
|
screen->DrawText(BigFont, gameinfo.gametype & GAME_DoomChex ? CR_RED : CR_UNTRANSLATED,
|
||||||
160-BigFont->StringWidth(CurrentMenu->texttitle)/2, 5,
|
(screen->GetWidth() - BigFont->StringWidth(CurrentMenu->texttitle) * CleanXfac_1) / 2,
|
||||||
CurrentMenu->texttitle, DTA_Clean, true, TAG_DONE);
|
5 * CleanYfac_1,
|
||||||
|
CurrentMenu->texttitle, DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
screen->DrawText(SmallFont, gameinfo.gametype & GAME_DoomChex ? CR_RED : CR_UNTRANSLATED,
|
screen->DrawText(SmallFont, gameinfo.gametype & GAME_DoomChex ? CR_RED : CR_UNTRANSLATED,
|
||||||
160-SmallFont->StringWidth(joyname)/2, 8 + BigFont->GetHeight(),
|
(screen->GetWidth() - SmallFont->StringWidth(joyname) * CleanXfac_1) / 2, (8 + BigFont->GetHeight()) * CleanYfac_1,
|
||||||
joyname, DTA_Clean, true, TAG_DONE);
|
joyname, DTA_CleanNoMove_1, true, TAG_DONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void UpdateJoystickConfigMenu(IJoystickConfig *joy)
|
static void UpdateJoystickConfigMenu(IJoystickConfig *joy)
|
||||||
|
|
|
@ -59,6 +59,9 @@ int CleanXfac, CleanYfac;
|
||||||
// [RH] Effective screen sizes that the above scale values give you
|
// [RH] Effective screen sizes that the above scale values give you
|
||||||
int CleanWidth, CleanHeight;
|
int CleanWidth, CleanHeight;
|
||||||
|
|
||||||
|
// Above minus 1 (or 1, if they are already 1)
|
||||||
|
int CleanXfac_1, CleanYfac_1, CleanWidth_1, CleanHeight_1;
|
||||||
|
|
||||||
CVAR (Bool, hud_scale, false, CVAR_ARCHIVE);
|
CVAR (Bool, hud_scale, false, CVAR_ARCHIVE);
|
||||||
|
|
||||||
// For routines that take RGB colors, cache the previous lookup in case there
|
// For routines that take RGB colors, cache the previous lookup in case there
|
||||||
|
@ -425,6 +428,15 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case DTA_CleanNoMove_1:
|
||||||
|
boolval = va_arg(tags, INTBOOL);
|
||||||
|
if (boolval)
|
||||||
|
{
|
||||||
|
parms->destwidth = parms->texwidth * CleanXfac_1;
|
||||||
|
parms->destheight = parms->texheight * CleanYfac_1;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case DTA_320x200:
|
case DTA_320x200:
|
||||||
boolval = va_arg(tags, INTBOOL);
|
boolval = va_arg(tags, INTBOOL);
|
||||||
if (boolval)
|
if (boolval)
|
||||||
|
|
|
@ -156,13 +156,23 @@ void STACK_ARGS DCanvas::DrawText (FFont *font, int normalcolor, int x, int y, c
|
||||||
ptrval = va_arg (tags, void*);
|
ptrval = va_arg (tags, void*);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case DTA_CleanNoMove_1:
|
||||||
|
boolval = va_arg (tags, INTBOOL);
|
||||||
|
if (boolval)
|
||||||
|
{
|
||||||
|
scalex = CleanXfac_1;
|
||||||
|
scaley = CleanYfac_1;
|
||||||
|
maxwidth = Width - (Width % scalex);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case DTA_CleanNoMove:
|
case DTA_CleanNoMove:
|
||||||
boolval = va_arg (tags, INTBOOL);
|
boolval = va_arg (tags, INTBOOL);
|
||||||
if (boolval)
|
if (boolval)
|
||||||
{
|
{
|
||||||
scalex = CleanXfac;
|
scalex = CleanXfac;
|
||||||
scaley = CleanYfac;
|
scaley = CleanYfac;
|
||||||
maxwidth = Width - (Width % CleanYfac);
|
maxwidth = Width - (Width % scalex);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -1398,6 +1398,11 @@ bool V_DoModeSetup (int width, int height, int bits)
|
||||||
assert(CleanWidth >= 320);
|
assert(CleanWidth >= 320);
|
||||||
assert(CleanHeight >= 200);
|
assert(CleanHeight >= 200);
|
||||||
|
|
||||||
|
CleanXfac_1 = MAX(CleanXfac - 1, 1);
|
||||||
|
CleanYfac_1 = MAX(CleanYfac - 1, 1);
|
||||||
|
CleanWidth_1 = width / CleanXfac_1;
|
||||||
|
CleanHeight_1 = height / CleanYfac_1;
|
||||||
|
|
||||||
DisplayWidth = width;
|
DisplayWidth = width;
|
||||||
DisplayHeight = height;
|
DisplayHeight = height;
|
||||||
DisplayBits = bits;
|
DisplayBits = bits;
|
||||||
|
|
|
@ -42,6 +42,7 @@
|
||||||
#include "c_cvars.h"
|
#include "c_cvars.h"
|
||||||
|
|
||||||
extern int CleanWidth, CleanHeight, CleanXfac, CleanYfac;
|
extern int CleanWidth, CleanHeight, CleanXfac, CleanYfac;
|
||||||
|
extern int CleanWidth_1, CleanHeight_1, CleanXfac_1, CleanYfac_1;
|
||||||
extern int DisplayWidth, DisplayHeight, DisplayBits;
|
extern int DisplayWidth, DisplayHeight, DisplayBits;
|
||||||
|
|
||||||
bool V_DoModeSetup (int width, int height, int bits);
|
bool V_DoModeSetup (int width, int height, int bits);
|
||||||
|
@ -79,6 +80,7 @@ enum
|
||||||
DTA_320x200, // bool: scale texture size and position to fit on a virtual 320x200 screen
|
DTA_320x200, // bool: scale texture size and position to fit on a virtual 320x200 screen
|
||||||
DTA_Bottom320x200, // bool: same as DTA_320x200 but centers virtual screen on bottom for 1280x1024 targets
|
DTA_Bottom320x200, // bool: same as DTA_320x200 but centers virtual screen on bottom for 1280x1024 targets
|
||||||
DTA_CleanNoMove, // bool: like DTA_Clean but does not reposition output position
|
DTA_CleanNoMove, // bool: like DTA_Clean but does not reposition output position
|
||||||
|
DTA_CleanNoMove_1, // bool: like DTA_CleanNoMove, but uses Clean[XY]fac_1 instead
|
||||||
DTA_FlipX, // bool: flip image horizontally //FIXME: Does not work with DTA_Window(Left|Right)
|
DTA_FlipX, // bool: flip image horizontally //FIXME: Does not work with DTA_Window(Left|Right)
|
||||||
DTA_ShadowColor, // color of shadow
|
DTA_ShadowColor, // color of shadow
|
||||||
DTA_ShadowAlpha, // alpha of shadow
|
DTA_ShadowAlpha, // alpha of shadow
|
||||||
|
|
Loading…
Reference in a new issue