From 7bf3d5186fdabf9b5446091b242b32ad7e21c9d7 Mon Sep 17 00:00:00 2001 From: Christoph Oelckers Date: Fri, 31 Jul 2020 21:05:09 +0200 Subject: [PATCH] - Blood font refactoring. --- source/blood/src/blood.cpp | 9 +--- source/blood/src/d_menu.cpp | 47 ++++++------------ source/blood/src/endgame.cpp | 2 +- source/blood/src/map2d.cpp | 6 +-- source/blood/src/map2d.h | 4 +- source/blood/src/messages.cpp | 2 +- source/blood/src/qav.cpp | 4 +- source/blood/src/view.cpp | 94 ++++++++++++++--------------------- source/blood/src/view.h | 6 +-- 9 files changed, 65 insertions(+), 109 deletions(-) diff --git a/source/blood/src/blood.cpp b/source/blood/src/blood.cpp index 8b2718bfc..035a925a9 100644 --- a/source/blood/src/blood.cpp +++ b/source/blood/src/blood.cpp @@ -248,13 +248,6 @@ void PreloadTiles(void) int skyTile = -1; memset(gotpic,0,sizeof(gotpic)); // Fonts - for (int i = 0; i < kFontNum; i++) - { - for (int j = 0; j < 96; j++) - { - tilePrecacheTile(gFont[i].tile + j, 0); - } - } for (int i = 0; i < numsectors; i++) { tilePrecacheTile(sector[i].floorpicnum, 0); @@ -976,7 +969,7 @@ static void gameTicker() static void drawBackground() { twod->ClearScreen(); - DrawTexture(twod, tileGetTexture(2518), 0, 0, DTA_FullscreenEx, 3, TAG_DONE); + DrawTexture(twod, tileGetTexture(2518, true), 0, 0, DTA_FullscreenEx, 3, TAG_DONE); if (gQuitRequest && !gQuitGame) netBroadcastMyLogoff(gQuitRequest == 2); } diff --git a/source/blood/src/d_menu.cpp b/source/blood/src/d_menu.cpp index c270cbcb7..ce6256852 100644 --- a/source/blood/src/d_menu.cpp +++ b/source/blood/src/d_menu.cpp @@ -25,20 +25,17 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. #include "build.h" #include "compat.h" -#include "common_game.h" -#include "blood.h" -#include "globals.h" -#include "inifile.h" -#include "levels.h" -#include "qav.h" -#include "view.h" -#include "network.h" #include "mmulti.h" #include "c_bind.h" #include "menu.h" -#include "sound.h" #include "gamestate.h" +#include "blood.h" +#include "globals.h" +#include "qav.h" +#include "view.h" +#include "sound.h" + bool ShowOptionMenu(); BEGIN_BLD_NS @@ -220,19 +217,14 @@ void GameInterface::DrawNativeMenuText(int fontnum, int state, double xpos, doub int shade = (state != NIT_InactiveState) ? 32 : 48; int pal = (state != NIT_InactiveState) ? 5 : 5; if (state == NIT_SelectedState) shade = 32 - ((int)totalclock & 63); - int width, height; - int gamefont = fontnum == NIT_BigFont ? 1 : fontnum == NIT_SmallFont ? 2 : 3; - - int x = int(xpos); - int y = int(ypos); - viewGetFontInfo(gamefont, text, &width, &height); + auto gamefont = fontnum == NIT_BigFont ? BigFont : fontnum == NIT_SmallFont ? SmallFont : SmallFont2; if (flags & LMF_Centered) { - x -= width / 2; + int width = gamefont->StringWidth(text); + xpos -= width / 2; } - - viewDrawText(gamefont, text, x, y, shade, pal, 0, true); + DrawText(twod, gamefont, CR_UNDEFINED, xpos, ypos, text, DTA_TranslationIndex, TRANSLATION(Translation_Remap, pal), DTA_Color, shadeToLight(shade), TAG_DONE); } @@ -269,35 +261,28 @@ FSavegameInfo GameInterface::GetSaveSig() void GameInterface::DrawMenuCaption(const DVector2& origin, const char* text) { - int height, width; - // font #1, tile #2038. - - viewGetFontInfo(1, text, &width, &height); - double scalex = 1.; // Expand the box if the text is longer + int width = BigFont->StringWidth(text); int boxwidth = tileWidth(2038); if (boxwidth - 10 < width) scalex = double(width) / (boxwidth - 10); - DrawTexture(twod, tileGetTexture(2038), 160, 20, DTA_FullscreenScale, 3, DTA_VirtualWidth, 320, DTA_VirtualHeight, 200, DTA_CenterOffsetRel, true, DTA_ScaleX, scalex, TAG_DONE); - - viewDrawText(1, text, 160, 20 - height / 2, -128, 0, 1, false); + DrawTexture(twod, tileGetTexture(2038, true), 160, 20, DTA_FullscreenScale, 3, DTA_VirtualWidth, 320, DTA_VirtualHeight, 200, DTA_CenterOffsetRel, true, DTA_ScaleX, scalex, TAG_DONE); + DrawText(twod, BigFont, CR_UNDEFINED, 160, 29, text, TAG_DONE); } void GameInterface::DrawCenteredTextScreen(const DVector2& origin, const char* text, int position, bool bg) { if (text) { - int width, height = 0; - viewGetFontInfo(0, "T", &width, &height); + int height = SmallFont->GetHeight(); auto lines = FString(text).Split("\n"); int y = 100 - (height * lines.Size() / 2); for (auto& l : lines) { - int lheight = 0; - viewGetFontInfo(0, l, &width, &lheight); + int width = SmallFont->StringWidth(text); int x = 160 - width / 2; - viewDrawText(0, l, x, y, 0, 0, 0, false); + DrawText(twod, SmallFont, CR_UNTRANSLATED, y, y, text, TAG_DONE); y += height; } } diff --git a/source/blood/src/endgame.cpp b/source/blood/src/endgame.cpp index d46e293be..3f17e9c6b 100644 --- a/source/blood/src/endgame.cpp +++ b/source/blood/src/endgame.cpp @@ -55,7 +55,7 @@ void CEndGameMgr::Draw(void) viewLoadingScreenWide(); int nHeight; viewGetFontInfo(1, NULL, NULL, &nHeight); - DrawTexture(twod, tileGetTexture(2038), 160, 20, DTA_FullscreenScale, 3, DTA_VirtualWidth, 320, DTA_VirtualHeight, 200, DTA_CenterOffsetRel, true, TAG_DONE); + DrawTexture(twod, tileGetTexture(2038, true), 160, 20, DTA_FullscreenScale, 3, DTA_VirtualWidth, 320, DTA_VirtualHeight, 200, DTA_CenterOffsetRel, true, TAG_DONE); int nY = 20 - nHeight / 2; if (gGameOptions.nGameType == 0) { diff --git a/source/blood/src/map2d.cpp b/source/blood/src/map2d.cpp index 59cca16d9..6e9d22d0e 100644 --- a/source/blood/src/map2d.cpp +++ b/source/blood/src/map2d.cpp @@ -160,7 +160,7 @@ void sub_2541C(int x, int y, int z, short a) double x = xdim/2. + x1 / double(1<<12); double y = ydim/2. + y1 / double(1<<12); // This very likely needs fixing later - DrawTexture(twod, tileGetTexture(nTile), x, y, DTA_FullscreenScale, 3, DTA_ViewportX, windowxy1.x, DTA_ViewportY, windowxy1.y, + DrawTexture(twod, tileGetTexture(nTile, true), x, y, DTA_FullscreenScale, 3, DTA_ViewportX, windowxy1.x, DTA_ViewportY, windowxy1.y, DTA_ViewportWidth, windowxy2.x - windowxy1.x+1, DTA_ViewportHeight, windowxy2.y - windowxy1.y+1, DTA_Alpha, (pSprite->cstat&2? 0.5:1.), TAG_DONE); } } @@ -216,9 +216,9 @@ void CViewMap::sub_25C74(void) #if 0 // needs to be generalized if (gViewMap.bFollowMode) - viewDrawText(3, "MAP FOLLOW MODE", gViewX1S, nViewY+8, -128, 0, 2, 0, 256); + Printf(PRINT_NOTIFY, "MAP FOLLOW MODE\n"); else - viewDrawText(3, "MAP SCROLL MODE", gViewX1S, nViewY+8, -128, 0, 2, 0, 256); + Printf(PRINT_NOTIFY, "MAP SCROLL MODE\n"); #endif if (tm) viewResizeView(viewSize); diff --git a/source/blood/src/map2d.h b/source/blood/src/map2d.h index 29812b09a..93861fea8 100644 --- a/source/blood/src/map2d.h +++ b/source/blood/src/map2d.h @@ -21,8 +21,8 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ //------------------------------------------------------------------------- #pragma once -#include "common_game.h" -#include "db.h" +#include "build.h" +#include "fix16.h" BEGIN_BLD_NS diff --git a/source/blood/src/messages.cpp b/source/blood/src/messages.cpp index ecd7f885f..cb9903cb2 100644 --- a/source/blood/src/messages.cpp +++ b/source/blood/src/messages.cpp @@ -442,7 +442,7 @@ void CGameMessageMgr::SetMaxMessages(int nMessages) void CGameMessageMgr::SetFont(int nFont) { this->nFont = nFont; - fontHeight = gFont[nFont].ySize; + fontHeight = gFont[nFont]->GetHeight(); } void CGameMessageMgr::SetCoordinates(int x, int y) diff --git a/source/blood/src/qav.cpp b/source/blood/src/qav.cpp index d671e409c..591cf1bd8 100644 --- a/source/blood/src/qav.cpp +++ b/source/blood/src/qav.cpp @@ -67,13 +67,13 @@ void DrawFrame(F2DDrawer *twod, int x, int y, TILE_FRAME *pTile, int stat, int s if (!to3dview) { DrawTexture(twod, tex, x, y, DTA_ScaleX, scale, DTA_ScaleY, scale, DTA_Rotate, angle, DTA_LegacyRenderStyle, renderstyle, DTA_Alpha, alpha, DTA_Pin, pin, DTA_TranslationIndex, translation, - DTA_TopLeft, topleft, DTA_CenterOffsetRel, !topleft, DTA_FullscreenScale, 3, DTA_VirtualWidth, 320, DTA_VirtualHeight, 200, DTA_FlipOffsets, !topleft, DTA_Color, color, + DTA_TopLeft, topleft, DTA_CenterOffsetRel, !topleft, DTA_FullscreenScale, 3, DTA_VirtualWidth, 320, DTA_VirtualHeight, 200, DTA_FlipOffsets, true, DTA_Color, color, DTA_FlipX, xflip, DTA_FlipY, yflip, TAG_DONE); } else { DrawTexture(twod, tex, x, y, DTA_ScaleX, scale, DTA_ScaleY, scale, DTA_Rotate, angle, DTA_LegacyRenderStyle, renderstyle, DTA_Alpha, alpha, DTA_Pin, pin, DTA_TranslationIndex, translation, - DTA_TopLeft, topleft, DTA_CenterOffsetRel, !topleft, DTA_FullscreenScale, 3, DTA_VirtualWidth, 320, DTA_VirtualHeight, 200, DTA_FlipOffsets, !topleft, DTA_Color, color, + DTA_TopLeft, topleft, DTA_CenterOffsetRel, !topleft, DTA_FullscreenScale, 3, DTA_VirtualWidth, 320, DTA_VirtualHeight, 200, DTA_FlipOffsets, true, DTA_Color, color, DTA_FlipX, xflip, DTA_FlipY, yflip, DTA_ViewportX, windowxy1.x, DTA_ViewportY, windowxy1.y, DTA_ViewportWidth, windowxy2.x - windowxy1.x+1, DTA_ViewportHeight, windowxy2.y - windowxy1.y+1, TAG_DONE); } } diff --git a/source/blood/src/view.cpp b/source/blood/src/view.cpp index 51cf0cd4d..f2293e077 100644 --- a/source/blood/src/view.cpp +++ b/source/blood/src/view.cpp @@ -29,23 +29,15 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. #include "build.h" #include "pragmas.h" #include "mmulti.h" -#include "common_game.h" +#include "v_font.h" -#include "aistate.h" -#include "blood.h" -#include "choke.h" -#include "db.h" #include "endgame.h" -#include "gameutil.h" -#include "globals.h" -#include "levels.h" -#include "loadsave.h" +#include "aistate.h" #include "map2d.h" -#include "messages.h" -#include "network.h" -#include "player.h" - #include "screen.h" +#include "loadsave.h" +#include "screen.h" #include "sectorfx.h" +#include "choke.h" #include "view.h" #include "nnexts.h" #include "zstring.h" @@ -53,6 +45,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. #include "gstrings.h" #include "v_2ddrawer.h" #include "v_video.h" +#include "v_font.h" #include "glbackend/glbackend.h" CVARD(Bool, hud_powerupduration, true, CVAR_ARCHIVE/*|CVAR_FRONTEND_BLOOD*/, "enable/disable displaying the remaining seconds for power-ups") @@ -176,54 +169,47 @@ void RotateXY(int *pX, int *pY, int *pZ, int ang) *pY = dmulscale30r(oX,angSin,oY,angCos); } -FONT gFont[kFontNum]; +FFont *gFont[kFontNum]; void FontSet(int id, int tile, int space) { if (id < 0 || id >= kFontNum || tile < 0 || tile >= kMaxTiles) return; - FONT *pFont = &gFont[id]; - int xSize = 0; - int ySize = 0; - pFont->tile = tile; - for (int i = 0; i < 96; i++) + GlyphSet glyphs; + for (int i = 1; i < 96; i++) { - if (tilesiz[tile+i].x > xSize) - xSize = tilesiz[tile+i].x; - if (tilesiz[tile+i].y > ySize) - ySize = tilesiz[tile+i].y; + auto tex = tileGetTexture(tile + i); + if (tex->isValid() && tex->GetTexelWidth() > 0 && tex->GetTexelHeight() > 0) + glyphs.Insert(i + 32, tex); + } - pFont->xSize = xSize; - pFont->ySize = ySize; - pFont->space = space; + const char *names[] = { "smallfont", "bigfont", "gothfont", "smallfont2", "digifont"}; + const char *defs[] = { "defsmallfont", "defbigfont", nullptr, "defsmallfont2", nullptr}; + const bool kerning[] = { 0, 1, 1, 1, 0}; + FFont ** ptrs[] = { &SmallFont, &BigFont, nullptr, &SmallFont2, nullptr}; + gFont[id] = new ::FFont(names[id], nullptr, defs[id], 0, 0, 0, kerning[id], tileWidth(tile), false, false, &glyphs); + if (ptrs[id]) *ptrs[id] = gFont[id]; } void viewGetFontInfo(int id, const char *unk1, int *pXSize, int *pYSize) { if (id < 0 || id >= kFontNum) return; - FONT *pFont = &gFont[id]; + FFont *pFont = gFont[id]; if (!unk1) { if (pXSize) - *pXSize = pFont->xSize; + *pXSize = pFont->GetCharWidth('N'); if (pYSize) - *pYSize = pFont->ySize; + *pYSize = pFont->GetHeight(); } else { - int width = -pFont->space; - for (const char *pBuf = unk1; *pBuf != 0; pBuf++) - { - int tile = ((*pBuf-32)&127)+pFont->tile; - if (tileGetTexture(tile)->isValid()) - width += tilesiz[tile].x+pFont->space; - } if (pXSize) - *pXSize = width; + *pXSize = pFont->StringWidth(unk1); if (pYSize) - *pYSize = pFont->ySize; + *pYSize = pFont->GetHeight(); } } @@ -1015,29 +1001,25 @@ void RestoreInterpolations(void) 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) { if (nFont < 0 || nFont >= kFontNum || !pString) return; - FONT *pFont = &gFont[nFont]; + FFont *pFont = gFont[nFont]; //y += pFont->yoff; - if (position) - { - const char *s = pString; - int width = -pFont->space; - while (*s) - { - int nTile = ((*s-' ')&127)+pFont->tile; - if (tilesiz[nTile].x && tilesiz[nTile].y) - width += tilesiz[nTile].x+pFont->space; - s++; - } - if (position == 1) - width >>= 1; - x -= width; - } + if (position) x -= pFont->StringWidth(pString) / 2; + + if (shadow) + { + DrawText(twod, pFont, CR_UNDEFINED, x, y, pString, DTA_FullscreenScale, 3, DTA_VirtualWidth, 320, DTA_VirtualHeight, 200, DTA_Color, 0, DTA_Alpha, 0.5, TAG_DONE); + } + DrawText(twod, pFont, CR_UNDEFINED, x, y, pString, DTA_FullscreenScale, 3, DTA_VirtualWidth, 320, DTA_VirtualHeight, 200, DTA_TranslationIndex, TRANSLATION(Translation_Remap, nPalette), + DTA_Color, shadeToLight(nShade), TAG_DONE); + + // This is just for position comparison const char *s = pString; while (*s) { - int nTile = ((*s-' ')&127) + pFont->tile; + int nTile = 'A' - 32 + 4096 + nFont*96; + //int nTile = ((*s-' ')&127) + '; if (tilesiz[nTile].x && tilesiz[nTile].y) { if (shadow) @@ -1045,7 +1027,7 @@ void viewDrawText(int nFont, const char *pString, int x, int y, int nShade, int rotatesprite_fs_alpha((x+1)<<16, (y+1)<<16, 65536, 0, nTile, 127, nPalette, 26|nStat, alpha); } rotatesprite_fs_alpha(x<<16, y<<16, 65536, 0, nTile, nShade, nPalette, 26|nStat, alpha); - x += tilesiz[nTile].x+pFont->space; + x += pFont->GetDefaultKerning(); } s++; } diff --git a/source/blood/src/view.h b/source/blood/src/view.h index 342dc1a3f..a34c824f9 100644 --- a/source/blood/src/view.h +++ b/source/blood/src/view.h @@ -75,12 +75,8 @@ enum INTERPOLATE_TYPE { #define kFontNum 5 -struct FONT { - int tile, xSize, ySize, space; -}; - extern int gZoom; -extern FONT gFont[kFontNum]; +extern FFont *gFont[kFontNum]; extern int gViewMode; extern VIEWPOS gViewPos; extern int gViewIndex;