From d2ed4e703d402d881aee02ab68c54fd60a051850 Mon Sep 17 00:00:00 2001 From: Christoph Oelckers Date: Sat, 22 May 2021 10:06:15 +0200 Subject: [PATCH] - made Exhumed's text scroller a universal component of the cutscene system, usable by all games. --- wadsrc/static/zscript/engine/screenjob.zs | 55 +++++++++++++++++++ .../zscript/games/exhumed/ui/screens.zs | 53 +----------------- 2 files changed, 57 insertions(+), 51 deletions(-) diff --git a/wadsrc/static/zscript/engine/screenjob.zs b/wadsrc/static/zscript/engine/screenjob.zs index fcd9d07e8..fef98ffca 100644 --- a/wadsrc/static/zscript/engine/screenjob.zs +++ b/wadsrc/static/zscript/engine/screenjob.zs @@ -535,3 +535,58 @@ class ScreenJobRunner : Object Append(MoviePlayerJob.CreateWithSoundInfo(fn, sounds, 0, framerate)); } } + +//--------------------------------------------------------------------------- +// +// scrolling text, like Exhumed's story screens. +// +//--------------------------------------------------------------------------- + +class TextOverlay +{ + int nHeight; + double nCrawlY; + int palette; + int crange; + bool drawclean; + BrokenLines screentext; + + void Init(String text, int cr = Font.CR_UNTRANSLATED, int pal = 0, bool clean = false) + { + screentext = SmallFont.BreakLines(StringTable.Localize(text), 320); + nCrawlY = 199; + nHeight = screentext.Count() * 10; + palette = pal; + crange = cr; + drawclean = clean; + } + + void DisplayText() + { + if (nHeight + nCrawlY > 0) + { + double y = nCrawlY; + for (int i = 0; i < screentext.Count() && y <= 199; i++) + { + if (y >= -10) + { + int x = 160 - screenText.StringWidth(i)/2; + if (!drawclean) Screen.DrawText(SmallFont, crange, x, y, screentext.StringAt(i), DTA_FullscreenScale, FSMode_Fit320x200, DTA_TranslationIndex, palette); + else Screen.DrawText(SmallFont, crange, x, y, screentext.StringAt(i), DTA_Clean, true, DTA_TranslationIndex, palette); + } + y += 10; + } + } + } + + bool ScrollText(double clock) + { + if (nHeight + nCrawlY > 0 || musplaying.handle) + { + nCrawlY = 199 - clock / 15.; + return false; + } + return true; + } +} + diff --git a/wadsrc/static/zscript/games/exhumed/ui/screens.zs b/wadsrc/static/zscript/games/exhumed/ui/screens.zs index dbb986639..6aa76d20b 100644 --- a/wadsrc/static/zscript/games/exhumed/ui/screens.zs +++ b/wadsrc/static/zscript/games/exhumed/ui/screens.zs @@ -450,55 +450,6 @@ class MapScreen : ScreenJob } -//--------------------------------------------------------------------------- -// -// -// -//--------------------------------------------------------------------------- - -class TextOverlay -{ - int nHeight; - double nCrawlY; - int palette; - BrokenLines screentext; - - void Init(String text, int pal) - { - screentext = SmallFont.BreakLines(StringTable.Localize(text), 320); - nCrawlY = 199; - nHeight = screentext.Count() * 10; - palette = pal; - } - - void DisplayText() - { - if (nHeight + nCrawlY > 0) - { - double y = nCrawlY; - for (int i = 0; i < screentext.Count() && y <= 199; i++) - { - if (y >= -10) - { - int x = 160 - screenText.StringWidth(i)/2; - Screen.DrawText(SmallFont, Font.CR_UNDEFINED, x, y, screentext.StringAt(i), DTA_FullscreenScale, FSMode_Fit320x200, DTA_TranslationIndex, palette); - } - y += 10; - } - } - } - - bool AdvanceCinemaText(double clock) - { - if (nHeight + nCrawlY > 0 || musplaying.handle) - { - nCrawlY = 199 - clock / 15.; - return false; - } - return true; - } -} - //--------------------------------------------------------------------------- // // cinema (this has been stripped off all game logic that was still in here) @@ -520,7 +471,7 @@ class Cinema : SkippableScreenJob cinematile = TexMan.CheckForTexture(bgTexture, TexMan.Type_Any); textov = new("TextOverlay"); palette = Translation.MakeID(Translation_BasePalette, pal); - textov.Init(text, palette); + textov.Init(text, Font.CR_UNDEFINED, palette); cdtrack = cdtrk; return self; } @@ -543,7 +494,7 @@ class Cinema : SkippableScreenJob { Screen.DrawTexture(cinematile, false, 0, 0, DTA_FullscreenEx, FSMode_ScaleToFit43, DTA_TranslationIndex, palette); textov.DisplayText(); - done = textov.AdvanceCinemaText((ticks + smoothratio) * (120. / GameTicRate)); + done = textov.ScrollText((ticks + smoothratio) * (120. / GameTicRate)); } }