- pass fonts instead of indices to Blood's viewDrawText function.

As preparation for building a proper font system.
This commit is contained in:
Christoph Oelckers 2021-05-29 15:28:47 +02:00
parent d7e1707b37
commit f97b4e830d
2 changed files with 11 additions and 13 deletions

View file

@ -57,7 +57,7 @@ double gInterpolate;
int gScreenTilt; int gScreenTilt;
FFont *gFont[kFontNum]; FFont* DigiFont;
void FontSet(int id, int tile, int space) void FontSet(int id, int tile, int space)
{ {
@ -77,10 +77,10 @@ void FontSet(int id, int tile, int space)
} }
const char *names[] = { "smallfont", "bigfont", "gothfont", "smallfont2", "digifont"}; const char *names[] = { "smallfont", "bigfont", "gothfont", "smallfont2", "digifont"};
const char *defs[] = { "defsmallfont", "defbigfont", nullptr, "defsmallfont2", nullptr}; const char *defs[] = { "defsmallfont", "defbigfont", nullptr, "defsmallfont2", nullptr};
FFont ** ptrs[] = { &SmallFont, &BigFont, nullptr, &SmallFont2, nullptr}; FFont ** ptrs[] = { &SmallFont, &BigFont, nullptr, &SmallFont2, &DigiFont};
gFont[id] = new ::FFont(names[id], nullptr, defs[id], 0, 0, 0, 0, tileWidth(tile), false, false, false, &glyphs); auto fnt = new ::FFont(names[id], nullptr, defs[id], 0, 0, 0, 0, tileWidth(tile), false, false, false, &glyphs);
gFont[id]->SetKerning(space); fnt->SetKerning(space);
if (ptrs[id]) *ptrs[id] = gFont[id]; if (ptrs[id]) *ptrs[id] = fnt;
} }
void viewBackupView(int nPlayer) void viewBackupView(int nPlayer)
@ -114,10 +114,9 @@ void viewCorrectViewOffsets(int nPlayer, vec3_t const *oldpos)
pView->viewz += pPlayer->pSprite->z-oldpos->z; pView->viewz += pPlayer->pSprite->z-oldpos->z;
} }
void viewDrawText(int nFont, const char *pString, int x, int y, int nShade, int nPalette, int position, char shadow, unsigned int nStat, uint8_t alpha) void viewDrawText(FFont* pFont, const char *pString, int x, int y, int nShade, int nPalette, int position, char shadow)
{ {
if (nFont < 0 || nFont >= kFontNum || !pString) return; if (!pString) return;
FFont *pFont = gFont[nFont];
//y += pFont->yoff; //y += pFont->yoff;
@ -130,7 +129,7 @@ void viewDrawText(int nFont, const char *pString, int x, int y, int nShade, int
DrawText(twod, pFont, CR_UNTRANSLATED, x+1, y+1, pString, DTA_FullscreenScale, FSMode_Fit320x200, DTA_Color, 0xff000000, DTA_Alpha, 0.5, TAG_DONE); DrawText(twod, pFont, CR_UNTRANSLATED, x+1, y+1, pString, DTA_FullscreenScale, FSMode_Fit320x200, DTA_Color, 0xff000000, DTA_Alpha, 0.5, TAG_DONE);
} }
DrawText(twod, pFont, CR_NATIVEPAL, x, y, pString, DTA_FullscreenScale, FSMode_Fit320x200, DTA_TranslationIndex, TRANSLATION(Translation_Remap, nPalette), DrawText(twod, pFont, CR_NATIVEPAL, x, y, pString, DTA_FullscreenScale, FSMode_Fit320x200, DTA_TranslationIndex, TRANSLATION(Translation_Remap, nPalette),
DTA_Color, shadeToLight(nShade), DTA_Alpha, alpha / 255., TAG_DONE); DTA_Color, shadeToLight(nShade), TAG_DONE);
} }
@ -153,7 +152,7 @@ void viewDrawAimedPlayerName(void)
int nPlayer = pSprite->type-kDudePlayer1; int nPlayer = pSprite->type-kDudePlayer1;
const char* szName = PlayerName(nPlayer); const char* szName = PlayerName(nPlayer);
int nPalette = (gPlayer[nPlayer].teamId&3)+11; int nPalette = (gPlayer[nPlayer].teamId&3)+11;
viewDrawText(4, szName, 160, 125, -128, nPalette, 1, 1); viewDrawText(DigiFont, szName, 160, 125, -128, nPalette, 1, 1);
} }
} }
} }
@ -789,12 +788,12 @@ void viewDrawScreen(bool sceneonly)
viewDrawAimedPlayerName(); viewDrawAimedPlayerName();
if (paused) if (paused)
{ {
viewDrawText(1, GStrings("TXTB_PAUSED"), 160, 10, 0, 0, 1, 0); viewDrawText(BigFont, GStrings("TXTB_PAUSED"), 160, 10, 0, 0, 1, 0);
} }
else if (gView != gMe) else if (gView != gMe)
{ {
FStringf gTempStr("] %s [", PlayerName(gView->nPlayer)); FStringf gTempStr("] %s [", PlayerName(gView->nPlayer));
viewDrawText(0, gTempStr, 160, 10, 0, 0, 1, 0); viewDrawText(SmallFont, gTempStr, 160, 10, 0, 0, 1, 0);
} }
if (cl_interpolate) if (cl_interpolate)
{ {

View file

@ -140,7 +140,6 @@ void viewUpdatePrediction(InputPacket *pInput);
void viewCorrectPrediction(void); void viewCorrectPrediction(void);
void viewBackupView(int nPlayer); void viewBackupView(int nPlayer);
void viewCorrectViewOffsets(int nPlayer, vec3_t const *oldpos); void viewCorrectViewOffsets(int nPlayer, vec3_t const *oldpos);
void viewDrawText(int nFont, const char *pString, int x, int y, int nShade, int nPalette, int position, char shadow, unsigned int nStat = 0, uint8_t alpha = 255);
void InitStatusBar(void); void InitStatusBar(void);
void UpdateStatusBar(); void UpdateStatusBar();
void viewInit(void); void viewInit(void);