From aed8a450fd7e6a8e5fcecbc4f2bb5b5284322b89 Mon Sep 17 00:00:00 2001 From: Christoph Oelckers Date: Sun, 8 Nov 2020 10:12:12 +0100 Subject: [PATCH] - SW: fixed episode menu display. The subtitle needs to use the game specific drawer, not the generic one. Fixes #162 --- source/core/menu/razemenu.cpp | 3 ++- wadsrc/static/zscript/games/sw/ui/menu.zs | 14 +++++++++----- 2 files changed, 11 insertions(+), 6 deletions(-) diff --git a/source/core/menu/razemenu.cpp b/source/core/menu/razemenu.cpp index 7e306ff03..438747305 100644 --- a/source/core/menu/razemenu.cpp +++ b/source/core/menu/razemenu.cpp @@ -398,7 +398,8 @@ static void BuildEpisodeMenu() addedVolumes++; if (gVolumeSubtitles[i].IsNotEmpty()) { - auto it = CreateListMenuItemStaticText(ld->mXpos, y, gVolumeSubtitles[i], SmallFont, CR_GRAY, false); + auto it = CreateCustomListMenuItemText(ld->mXpos, y, ld->mLinespacing * 6 / 10, 1, + gVolumeSubtitles[i], SmallFont, CR_GRAY, false, NAME_None, i); y += ld->mLinespacing * 6 / 10; ld->mItems.Push(it); } diff --git a/wadsrc/static/zscript/games/sw/ui/menu.zs b/wadsrc/static/zscript/games/sw/ui/menu.zs index 0793c04c8..7d3684fd7 100644 --- a/wadsrc/static/zscript/games/sw/ui/menu.zs +++ b/wadsrc/static/zscript/games/sw/ui/menu.zs @@ -88,6 +88,11 @@ class ListMenuItemSWTextItem : ListMenuItemTextItem if (child == 'none') mEnabled = -1; } + override bool Selectable() + { + return super.Selectable() && mFont == BigFont; + } + void InitDirect(double x, double y, int height, String hotkey, String text, Font font, int color, int color2, Name child, int param = 0) { Super.InitDirect(x, y, height, hotkey, text, font, color, color2, child, param); @@ -95,10 +100,9 @@ class ListMenuItemSWTextItem : ListMenuItemTextItem override void Draw(bool selected, ListMenuDescriptor desc) { - let gamefont = generic_ui ? NewSmallFont : BigFont; - int cr = generic_ui? Font.CR_RED : Font.CR_UNDEFINED; - double scalex = 1.; - + let gamefont = generic_ui ? NewSmallFont : mFont; + int cr = mColor != Font.CR_UNDEFINED? mColor : generic_ui? Font.CR_RED : Font.CR_UNDEFINED; + double scalex = generic_ui && mFont == SmallFont? 0.5 : 1.; // The font here is very bulky and may cause problems with localized content. Account for that by squashing the text if needed. int length = gamefont.StringWidth(mText); @@ -107,7 +111,7 @@ class ListMenuItemSWTextItem : ListMenuItemTextItem scalex = (315. - mXpos) / length; } - Screen.DrawText(BigFont, cr, mXpos, mYpos, mText, DTA_FullscreenScale, FSMode_Fit320x200, DTA_Color, !Selectable()? 0xff505050 : 0xffffffff, DTA_ScaleX, scalex); + Screen.DrawText(gamefont, cr, mXpos, mYpos, mText, DTA_FullscreenScale, FSMode_Fit320x200, DTA_Color, !super.Selectable()? 0xff505050 : 0xffffffff, DTA_ScaleX, scalex); } }