- added generic font support to the dialogue system.

This commit is contained in:
Christoph Oelckers 2019-04-11 18:55:35 +02:00
parent aeb63321ad
commit 1090c4b345

View file

@ -83,6 +83,13 @@ class ConversationMenu : Menu
int mSelection; int mSelection;
int ConversationPauseTic; int ConversationPauseTic;
int LineHeight; int LineHeight;
int ReplyLineHeight;
Font displayFont;
int displayWidth;
int displayHeight;
int fontScale;
int refwidth;
int refheight;
int SpeechWidth; int SpeechWidth;
int ReplyWidth; int ReplyWidth;
@ -105,10 +112,32 @@ class ConversationMenu : Menu
mShowGold = false; mShowGold = false;
ConversationPauseTic = gametic + 20; ConversationPauseTic = gametic + 20;
DontDim = true; DontDim = true;
if (!generic_ui)
{
displayFont = SmallFont;
displayWidth = CleanWidth;
displayHeight = CleanHeight;
fontScale = CleanXfac;
refwidth = 320;
refheight = 200;
ReplyWidth = 320-50-10;
SpeechWidth = screen.GetWidth()/CleanXfac - 24*2;
ReplyLineHeight = LineHeight = displayFont.GetHeight();
}
else
{
displayFont = NewSmallFont;
fontScale = (CleanXfac+1) / 2;
displayWidth = screen.GetWidth() / fontScale;
displayHeight = screen.GetHeight() / fontScale;
refwidth = 640;
refheight = 400;
ReplyWidth = 640-100-20;
SpeechWidth = screen.GetWidth()/fontScale - (24*2 * CleanXfac / fontScale);
LineHeight = displayFont.GetHeight() + 2;
ReplyLineHeight = LineHeight * fontScale / CleanYfac;
}
ReplyWidth = 320-50-10;
SpeechWidth = screen.GetWidth()/CleanXfac - 24*2;
LineHeight = SmallFont.GetHeight();
FormatSpeakerMessage(); FormatSpeakerMessage();
return FormatReplies(activereply); return FormatReplies(activereply);
@ -145,7 +174,7 @@ class ConversationMenu : Menu
let amount = String.Format("%u", reply.PrintAmount); let amount = String.Format("%u", reply.PrintAmount);
ReplyText.Replace("%u", amount); ReplyText.Replace("%u", amount);
} }
let ReplyLines = SmallFont.BreakLines (ReplyText, ReplyWidth); let ReplyLines = displayFont.BreakLines (ReplyText, ReplyWidth);
mResponses.Push(mResponseLines.Size()); mResponses.Push(mResponseLines.Size());
for (j = 0; j < ReplyLines.Count(); ++j) for (j = 0; j < ReplyLines.Count(); ++j)
@ -175,8 +204,8 @@ class ConversationMenu : Menu
mResponseLines.Push(goodbyestr); mResponseLines.Push(goodbyestr);
// Determine where the top of the reply list should be positioned. // Determine where the top of the reply list should be positioned.
mYpos = MIN (140, 192 - mResponseLines.Size() * LineHeight); mYpos = MIN (140, 192 - mResponseLines.Size() * ReplyLineHeight);
i = 44 + mResponseLines.Size() * LineHeight; i = 44 + mResponseLines.Size() * ReplyLineHeight;
if (mYpos - 100 < i - screen.GetHeight() / CleanYfac / 2) if (mYpos - 100 < i - screen.GetHeight() / CleanYfac / 2)
{ {
mYpos = i - screen.GetHeight() / CleanYfac / 2 + 100; mYpos = i - screen.GetHeight() / CleanYfac / 2 + 100;
@ -214,7 +243,7 @@ class ConversationMenu : Menu
{ {
toSay = "."; toSay = ".";
} }
mDialogueLines = SmallFont.BreakLines(toSay, SpeechWidth); mDialogueLines = displayFont.BreakLines(toSay, SpeechWidth);
} }
//============================================================================= //=============================================================================
@ -309,10 +338,10 @@ class ConversationMenu : Menu
int fh = LineHeight; int fh = LineHeight;
// convert x/y from screen to virtual coordinates, according to CleanX/Yfac use in DrawTexture // convert x/y from screen to virtual coordinates, according to CleanX/Yfac use in DrawTexture
x = ((x - (screen.GetWidth() / 2)) / CleanXfac) + 160; x = ((x - (screen.GetWidth() / 2)) / fontScale) + refWidth/2;
y = ((y - (screen.GetHeight() / 2)) / CleanYfac) + 100; y = ((y - (screen.GetHeight() / 2)) / fontScale) + refHeight/2;
if (x >= 24 && x <= 320-24 && y >= mYpos && y < mYpos + fh * mResponseLines.Size()) if (x >= 24 && x <= refWidth-24 && y >= mYpos && y < mYpos + fh * mResponseLines.Size())
{ {
sel = (y - mYpos) / fh; sel = (y - mYpos) / fh;
for(int i = 0; i < mResponses.Size(); i++) for(int i = 0; i < mResponses.Size(); i++)
@ -383,7 +412,7 @@ class ConversationMenu : Menu
virtual void DrawSpeakerText(bool dimbg) virtual void DrawSpeakerText(bool dimbg)
{ {
String speakerName; String speakerName;
int linesize = LineHeight * CleanYfac; int linesize = LineHeight * fontScale;
int cnt = mDialogueLines.Count(); int cnt = mDialogueLines.Count();
// Who is talking to you? // Who is talking to you?
@ -413,13 +442,13 @@ class ConversationMenu : Menu
if (speakerName.Length() > 0) if (speakerName.Length() > 0)
{ {
screen.DrawText(SmallFont, Font.CR_WHITE, x, y, speakerName, DTA_CleanNoMove, true); screen.DrawText(displayFont, Font.CR_WHITE, x / fontScale, y / fontScale, speakerName, DTA_KeepRatio, true, DTA_VirtualWidth, displayWidth, DTA_VirtualHeight, displayHeight);
y += linesize * 3 / 2; y += linesize * 3 / 2;
} }
x = 24 * screen.GetWidth() / 320; x = 24 * screen.GetWidth() / 320;
for (int i = 0; i < cnt; ++i) for (int i = 0; i < cnt; ++i)
{ {
screen.DrawText(SmallFont, Font.CR_UNTRANSLATED, x, y, mDialogueLines.StringAt(i), DTA_CleanNoMove, true); screen.DrawText(displayFont, Font.CR_UNTRANSLATED, x / fontScale, y / fontScale, mDialogueLines.StringAt(i), DTA_KeepRatio, true, DTA_VirtualWidth, displayWidth, DTA_VirtualHeight, displayHeight);
y += linesize; y += linesize;
} }
} }
@ -435,18 +464,22 @@ class ConversationMenu : Menu
{ {
// Dim the screen behind the PC's choices. // Dim the screen behind the PC's choices.
screen.Dim(0, 0.45, (24 - 160) * CleanXfac + screen.GetWidth() / 2, (mYpos - 2 - 100) * CleanYfac + screen.GetHeight() / 2, screen.Dim(0, 0.45, (24 - 160) * CleanXfac + screen.GetWidth() / 2, (mYpos - 2 - 100) * CleanYfac + screen.GetHeight() / 2,
272 * CleanXfac, MIN(mResponseLines.Size() * LineHeight + 4, 200 - mYpos) * CleanYfac); 272 * CleanXfac, MIN(mResponseLines.Size() * ReplyLineHeight + 4, 200 - mYpos) * CleanYfac);
int y = mYpos; int y = mYpos;
int fontheight = LineHeight;
int response = 0; int response = 0;
for (int i = 0; i < mResponseLines.Size(); i++) for (int i = 0; i < mResponseLines.Size(); i++)
{ {
int width = SmallFont.StringWidth(mResponseLines[i]); int width = displayFont.StringWidth(mResponseLines[i]);
int x = 64; int x = 64;
screen.DrawText(SmallFont, Font.CR_GREEN, x, y, mResponseLines[i], DTA_Clean, true); double sx = (x - 160.0) * CleanXfac + (screen.GetWidth() * 0.5);
double sy = (y - 100.0) * CleanYfac + (screen.GetHeight() * 0.5);
screen.DrawText(displayFont, Font.CR_GREEN, sx / fontScale, sy / fontScale, mResponseLines[i], DTA_KeepRatio, true, DTA_VirtualWidth, displayWidth, DTA_VirtualHeight, displayHeight);
if (i == mResponses[response]) if (i == mResponses[response])
{ {
@ -454,19 +487,20 @@ class ConversationMenu : Menu
response++; response++;
tbuf = String.Format("%d.", response); tbuf = String.Format("%d.", response);
x = 50 - SmallFont.StringWidth(tbuf); x = 50 - displayFont.StringWidth(tbuf);
screen.DrawText(SmallFont, Font.CR_GREY, x, y, tbuf, DTA_Clean, true); sx = (x - 160.0) * CleanXfac + (screen.GetWidth() * 0.5);
screen.DrawText(displayFont, Font.CR_GREY, sx / fontScale, sy / fontScale, tbuf, DTA_KeepRatio, true, DTA_VirtualWidth, displayWidth, DTA_VirtualHeight, displayHeight);
if (response == mSelection + 1) if (response == mSelection + 1)
{ {
int colr = ((MenuTime() % 8) < 4) || GetCurrentMenu() != self ? Font.CR_RED : Font.CR_GREY; int colr = ((MenuTime() % 8) < 4) || GetCurrentMenu() != self ? Font.CR_RED : Font.CR_GREY;
x = (50 + 3 - 160) * CleanXfac + screen.GetWidth() / 2; x = (50 + 3 - 160) * CleanXfac + screen.GetWidth() / 2;
int yy = (y + fontheight / 2 - 5 - 100) * CleanYfac + screen.GetHeight() / 2; int yy = (y + ReplyLineHeight / 2 - 5 - 100) * CleanYfac + screen.GetHeight() / 2;
screen.DrawText(ConFont, colr, x, yy, "\xd", DTA_CellX, 8 * CleanXfac, DTA_CellY, 8 * CleanYfac); screen.DrawText(ConFont, colr, x, yy, "\xd", DTA_CellX, 8 * CleanXfac, DTA_CellY, 8 * CleanYfac);
} }
} }
y += fontheight; y += ReplyLineHeight;
} }
} }