- use the Unicode font for the scoreboard.

This commit is contained in:
Christoph Oelckers 2019-04-10 00:15:25 +02:00
parent 5733e8c049
commit 8182c80f1e

View file

@ -130,6 +130,9 @@ void HU_SortPlayers
*/ */
bool SB_ForceActive = false; bool SB_ForceActive = false;
static FFont *displayFont;
static int FontScale;
// PRIVATE DATA DEFINITIONS ------------------------------------------------ // PRIVATE DATA DEFINITIONS ------------------------------------------------
@ -143,6 +146,9 @@ bool SB_ForceActive = false;
void HU_DrawScores (player_t *player) void HU_DrawScores (player_t *player)
{ {
displayFont = NewSmallFont;
FontScale = MAX(screen->GetHeight() / 400, 1);
if (deathmatch) if (deathmatch)
{ {
if (teamplay) if (teamplay)
@ -195,7 +201,7 @@ void HU_DrawScores (player_t *player)
void HU_GetPlayerWidths(int &maxnamewidth, int &maxscorewidth, int &maxiconheight) void HU_GetPlayerWidths(int &maxnamewidth, int &maxscorewidth, int &maxiconheight)
{ {
maxnamewidth = SmallFont->StringWidth("Name"); maxnamewidth = displayFont->StringWidth("Name");
maxscorewidth = 0; maxscorewidth = 0;
maxiconheight = 0; maxiconheight = 0;
@ -203,7 +209,7 @@ void HU_GetPlayerWidths(int &maxnamewidth, int &maxscorewidth, int &maxiconheigh
{ {
if (playeringame[i]) if (playeringame[i])
{ {
int width = SmallFont->StringWidth(players[i].userinfo.GetName()); int width = displayFont->StringWidth(players[i].userinfo.GetName());
if (width > maxnamewidth) if (width > maxnamewidth)
{ {
maxnamewidth = width; maxnamewidth = width;
@ -235,6 +241,11 @@ void HU_GetPlayerWidths(int &maxnamewidth, int &maxscorewidth, int &maxiconheigh
// //
//========================================================================== //==========================================================================
static void HU_DrawFontScaled(double x, double y, int color, const char *text)
{
screen->DrawText(displayFont, color, x / FontScale, y / FontScale, text, DTA_VirtualWidth, screen->GetWidth() / FontScale, DTA_VirtualHeight, screen->GetHeight() / FontScale, TAG_END);
}
static void HU_DoDrawScores (player_t *player, player_t *sortedplayers[MAXPLAYERS]) static void HU_DoDrawScores (player_t *player, player_t *sortedplayers[MAXPLAYERS])
{ {
int color; int color;
@ -258,7 +269,7 @@ static void HU_DoDrawScores (player_t *player, player_t *sortedplayers[MAXPLAYER
} }
HU_GetPlayerWidths(maxnamewidth, maxscorewidth, maxiconheight); HU_GetPlayerWidths(maxnamewidth, maxscorewidth, maxiconheight);
height = SmallFont->GetHeight() * CleanYfac; height = displayFont->GetHeight() * FontScale;
lineheight = MAX(height, maxiconheight * CleanYfac); lineheight = MAX(height, maxiconheight * CleanYfac);
ypadding = (lineheight - height + 1) / 2; ypadding = (lineheight - height + 1) / 2;
@ -327,23 +338,16 @@ static void HU_DoDrawScores (player_t *player, player_t *sortedplayers[MAXPLAYER
*text_name = GStrings("SCORE_NAME"), *text_name = GStrings("SCORE_NAME"),
*text_delay = GStrings("SCORE_DELAY"); *text_delay = GStrings("SCORE_DELAY");
col2 = (SmallFont->StringWidth(text_color) + 8) * CleanXfac; col2 = (displayFont->StringWidth(text_color) + 16) * FontScale;
col3 = col2 + (SmallFont->StringWidth(text_frags) + 8) * CleanXfac; col3 = col2 + (displayFont->StringWidth(text_frags) + 16) * FontScale;
col4 = col3 + maxscorewidth * CleanXfac; col4 = col3 + maxscorewidth * FontScale;
col5 = col4 + (maxnamewidth + 8) * CleanXfac; col5 = col4 + (maxnamewidth + 16) * FontScale;
x = (SCREENWIDTH >> 1) - (((SmallFont->StringWidth(text_delay) * CleanXfac) + col5) >> 1); x = (SCREENWIDTH >> 1) - (((displayFont->StringWidth(text_delay) * FontScale) + col5) >> 1);
screen->DrawText (SmallFont, color, x, y, text_color, //HU_DrawFontScaled(x, y, color, text_color);
DTA_CleanNoMove, true, TAG_DONE); HU_DrawFontScaled(x + col2, y, color, text_frags);
HU_DrawFontScaled(x + col4, y, color, text_name);
screen->DrawText (SmallFont, color, x + col2, y, text_frags, HU_DrawFontScaled(x + col5, y, color, text_delay);
DTA_CleanNoMove, true, TAG_DONE);
screen->DrawText (SmallFont, color, x + col4, y, text_name,
DTA_CleanNoMove, true, TAG_DONE);
screen->DrawText(SmallFont, color, x + col5, y, text_delay,
DTA_CleanNoMove, true, TAG_DONE);
y += height + 6 * CleanYfac; y += height + 6 * CleanYfac;
bottom -= height; bottom -= height;
@ -385,9 +389,8 @@ static void HU_DrawTimeRemaining (int y)
mysnprintf (str, countof(str), "Level ends in %d:%02d:%02d", hours, minutes, seconds); mysnprintf (str, countof(str), "Level ends in %d:%02d:%02d", hours, minutes, seconds);
else else
mysnprintf (str, countof(str), "Level ends in %d:%02d", minutes, seconds); mysnprintf (str, countof(str), "Level ends in %d:%02d", minutes, seconds);
screen->DrawText (SmallFont, CR_GREY, SCREENWIDTH/2 - SmallFont->StringWidth (str)/2*CleanXfac, HU_DrawFontScaled(SCREENWIDTH / 2 - displayFont->StringWidth(str) / 2 * FontScale, y, CR_GRAY, str);
y, str, DTA_CleanNoMove, true, TAG_DONE);
} }
} }
@ -407,7 +410,7 @@ static void HU_DrawPlayer (player_t *player, bool highlight, int col1, int col2,
// The teamplay mode uses colors to show teams, so we need some // The teamplay mode uses colors to show teams, so we need some
// other way to do highlighting. And it may as well be used for // other way to do highlighting. And it may as well be used for
// all modes for the sake of consistancy. // all modes for the sake of consistancy.
screen->Dim(MAKERGB(200,245,255), 0.125f, col1 - 12*CleanXfac, y - 1, col5 + (maxnamewidth + 24)*CleanXfac, height + 2); screen->Dim(MAKERGB(200,245,255), 0.125f, col1 - 12*FontScale, y - 1, col5 + (maxnamewidth + 24)*FontScale, height + 2);
} }
col2 += col1; col2 += col1;
@ -419,8 +422,7 @@ static void HU_DrawPlayer (player_t *player, bool highlight, int col1, int col2,
HU_DrawColorBar(col1, y, height, (int)(player - players)); HU_DrawColorBar(col1, y, height, (int)(player - players));
mysnprintf (str, countof(str), "%d", deathmatch ? player->fragcount : player->killcount); mysnprintf (str, countof(str), "%d", deathmatch ? player->fragcount : player->killcount);
screen->DrawText (SmallFont, color, col2, y + ypadding, player->playerstate == PST_DEAD && !deathmatch ? "DEAD" : str, HU_DrawFontScaled(col2, y + ypadding, color, player->playerstate == PST_DEAD && !deathmatch ? "DEAD" : str);
DTA_CleanNoMove, true, TAG_DONE);
auto icon = FSetTextureID(player->mo->IntVar(NAME_ScoreIcon)); auto icon = FSetTextureID(player->mo->IntVar(NAME_ScoreIcon));
if (icon.isValid()) if (icon.isValid())
@ -431,8 +433,7 @@ static void HU_DrawPlayer (player_t *player, bool highlight, int col1, int col2,
TAG_DONE); TAG_DONE);
} }
screen->DrawText (SmallFont, color, col4, y + ypadding, player->userinfo.GetName(), HU_DrawFontScaled(col4, y + ypadding, color, player->userinfo.GetName());
DTA_CleanNoMove, true, TAG_DONE);
int avgdelay = 0; int avgdelay = 0;
for (int i = 0; i < BACKUPTICS; i++) for (int i = 0; i < BACKUPTICS; i++)
@ -443,8 +444,7 @@ static void HU_DrawPlayer (player_t *player, bool highlight, int col1, int col2,
mysnprintf(str, countof(str), "%d", (avgdelay * ticdup) * (1000 / TICRATE)); mysnprintf(str, countof(str), "%d", (avgdelay * ticdup) * (1000 / TICRATE));
screen->DrawText(SmallFont, color, col5, y + ypadding, str, HU_DrawFontScaled(col5, y + ypadding, color, str);
DTA_CleanNoMove, true, TAG_DONE);
if (teamplay && Teams[player->userinfo.GetTeam()].GetLogo().IsNotEmpty ()) if (teamplay && Teams[player->userinfo.GetTeam()].GetLogo().IsNotEmpty ())
{ {
@ -467,7 +467,10 @@ void HU_DrawColorBar(int x, int y, int height, int playernum)
D_GetPlayerColor (playernum, &h, &s, &v, NULL); D_GetPlayerColor (playernum, &h, &s, &v, NULL);
HSVtoRGB (&r, &g, &b, h, s, v); HSVtoRGB (&r, &g, &b, h, s, v);
screen->Clear (x, y, x + 24*CleanXfac, y + height, -1, //float aspect = ActiveRatio(SCREENWIDTH, SCREENHEIGHT);
//if (!AspectTallerThanWide(aspect)) x += (screen->GetWidth() - AspectBaseWidth(aspect)) / 2;
screen->Clear (x, y, x + 24*FontScale, y + height, -1,
MAKEARGB(255,clamp(int(r*255.f),0,255), MAKEARGB(255,clamp(int(r*255.f),0,255),
clamp(int(g*255.f),0,255), clamp(int(g*255.f),0,255),
clamp(int(b*255.f),0,255))); clamp(int(b*255.f),0,255)));