- use BigUpper font for option menu captions.

This commit is contained in:
Christoph Oelckers 2019-02-28 22:19:53 +01:00
parent b48f7da43e
commit cad2f49ceb
8 changed files with 17 additions and 9 deletions

View file

@ -1453,6 +1453,10 @@ void V_InitFonts()
BigFont = new FFont("BigFont", "FONTB%02u", "defbigfont", HU_FONTSTART, HU_FONTSIZE, 1, -1); BigFont = new FFont("BigFont", "FONTB%02u", "defbigfont", HU_FONTSTART, HU_FONTSIZE, 1, -1);
} }
} }
if (!(BigUpper = V_GetFont("BigUpper")))
{
BigUpper = BigFont;
}
if (!(ConFont = V_GetFont("ConsoleFont", "CONFONT"))) if (!(ConFont = V_GetFont("ConsoleFont", "CONFONT")))
{ {
ConFont = SmallFont; ConFont = SmallFont;

View file

@ -150,7 +150,7 @@ protected:
}; };
extern FFont *SmallFont, *SmallFont2, *BigFont, *ConFont, *IntermissionFont; extern FFont *SmallFont, *SmallFont2, *BigFont, *BigUpper, *ConFont, *IntermissionFont;
void V_InitFonts(); void V_InitFonts();
void V_ClearFonts(); void V_ClearFonts();

View file

@ -248,12 +248,12 @@ void DIntermissionScreenFader::Drawer ()
void DIntermissionScreenText::Init(FIntermissionAction *desc, bool first) void DIntermissionScreenText::Init(FIntermissionAction *desc, bool first)
{ {
bool usesDefault = mTextX < 0;
Super::Init(desc, first); Super::Init(desc, first);
mText = static_cast<FIntermissionActionTextscreen*>(desc)->mText; mText = static_cast<FIntermissionActionTextscreen*>(desc)->mText;
if (mText[0] == '$') mText = GStrings(&mText[1]); if (mText[0] == '$') mText = GStrings(&mText[1]);
mTextSpeed = static_cast<FIntermissionActionTextscreen*>(desc)->mTextSpeed; mTextSpeed = static_cast<FIntermissionActionTextscreen*>(desc)->mTextSpeed;
mTextX = static_cast<FIntermissionActionTextscreen*>(desc)->mTextX; mTextX = static_cast<FIntermissionActionTextscreen*>(desc)->mTextX;
bool usesDefault = mTextX < 0;
if (mTextX < 0) mTextX =gameinfo.TextScreenX; if (mTextX < 0) mTextX =gameinfo.TextScreenX;
mTextY = static_cast<FIntermissionActionTextscreen*>(desc)->mTextY; mTextY = static_cast<FIntermissionActionTextscreen*>(desc)->mTextY;
if (mTextY < 0) mTextY =gameinfo.TextScreenY; if (mTextY < 0) mTextY =gameinfo.TextScreenY;

View file

@ -1231,6 +1231,7 @@ DEFINE_FIELD(DOptionMenuDescriptor, mScrollPos)
DEFINE_FIELD(DOptionMenuDescriptor, mIndent) DEFINE_FIELD(DOptionMenuDescriptor, mIndent)
DEFINE_FIELD(DOptionMenuDescriptor, mPosition) DEFINE_FIELD(DOptionMenuDescriptor, mPosition)
DEFINE_FIELD(DOptionMenuDescriptor, mDontDim) DEFINE_FIELD(DOptionMenuDescriptor, mDontDim)
DEFINE_FIELD(DOptionMenuDescriptor, mFont)
DEFINE_FIELD(FOptionMenuSettings, mTitleColor) DEFINE_FIELD(FOptionMenuSettings, mTitleColor)
DEFINE_FIELD(FOptionMenuSettings, mFontColor) DEFINE_FIELD(FOptionMenuSettings, mFontColor)

View file

@ -196,6 +196,7 @@ public:
int mIndent; int mIndent;
int mPosition; int mPosition;
bool mDontDim; bool mDontDim;
FFont *mFont;
void CalcIndent(); void CalcIndent();
DMenuItemBase *GetItem(FName name); DMenuItemBase *GetItem(FName name);

View file

@ -1168,6 +1168,7 @@ void M_StartupEpisodeMenu(FGameStartup *gs)
DOptionMenuDescriptor *od = Create<DOptionMenuDescriptor>(); DOptionMenuDescriptor *od = Create<DOptionMenuDescriptor>();
MenuDescriptors[NAME_Episodemenu] = od; MenuDescriptors[NAME_Episodemenu] = od;
od->mMenuName = NAME_Episodemenu; od->mMenuName = NAME_Episodemenu;
od->mFont = gameinfo.gametype == GAME_Doom ? BigUpper : BigFont;
od->mTitle = "$MNU_EPISODE"; od->mTitle = "$MNU_EPISODE";
od->mSelectedItem = 0; od->mSelectedItem = 0;
od->mScrollPos = 0; od->mScrollPos = 0;

View file

@ -145,7 +145,7 @@ public:
int DisplayWidth, DisplayHeight; int DisplayWidth, DisplayHeight;
FFont *SmallFont, *SmallFont2, *BigFont, *ConFont, *IntermissionFont; FFont *SmallFont, *SmallFont2, *BigFont, *BigUpper, *ConFont, *IntermissionFont;
uint32_t Col2RGB8[65][256]; uint32_t Col2RGB8[65][256];
uint32_t *Col2RGB8_LessPrecision[65]; uint32_t *Col2RGB8_LessPrecision[65];

View file

@ -55,6 +55,7 @@ class OptionMenuDescriptor : MenuDescriptor native
native int mIndent; native int mIndent;
native int mPosition; native int mPosition;
native bool mDontDim; native bool mDontDim;
native Font mFont;
void Reset() void Reset()
{ {
@ -224,9 +225,9 @@ class OptionMenu : Menu
if (y <= 0) if (y <= 0)
{ {
if (BigFont && mDesc.mTitle.Length() > 0) if (mDesc.mFont && mDesc.mTitle.Length() > 0)
{ {
y = -y + BigFont.GetHeight(); y = -y + mDesc.mFont.GetHeight();
} }
else else
{ {
@ -415,13 +416,13 @@ class OptionMenu : Menu
if (y <= 0) if (y <= 0)
{ {
if (BigFont && mDesc.mTitle.Length() > 0) if (mDesc.mFont && mDesc.mTitle.Length() > 0)
{ {
let tt = Stringtable.Localize(mDesc.mTitle); let tt = Stringtable.Localize(mDesc.mTitle);
screen.DrawText (BigFont, OptionMenuSettings.mTitleColor, screen.DrawText (mDesc.mFont, OptionMenuSettings.mTitleColor,
(screen.GetWidth() - BigFont.StringWidth(tt) * CleanXfac_1) / 2, 10*CleanYfac_1, (screen.GetWidth() - mDesc.mFont.StringWidth(tt) * CleanXfac_1) / 2, 10*CleanYfac_1,
tt, DTA_CleanNoMove_1, true); tt, DTA_CleanNoMove_1, true);
y = -y + BigFont.GetHeight(); y = -y + mDesc.mFont.GetHeight();
} }
else else
{ {