mirror of
https://github.com/ZDoom/Raze.git
synced 2025-01-18 22:51:50 +00:00
- removed all the intermediate variables for the status bar size.
hud_size now gets used directly by the status bar code.
This commit is contained in:
parent
8d622f9340
commit
f9d48e1f68
18 changed files with 38 additions and 104 deletions
|
@ -144,7 +144,6 @@ struct GameInterface : ::GameInterface
|
||||||
bool GenerateSavePic() override;
|
bool GenerateSavePic() override;
|
||||||
void FreeGameData() override;
|
void FreeGameData() override;
|
||||||
void set_hud_layout(int size) override;
|
void set_hud_layout(int size) override;
|
||||||
void set_hud_scale(int size) override;
|
|
||||||
FString statFPS() override;
|
FString statFPS() override;
|
||||||
FSavegameInfo GetSaveSig() override;
|
FSavegameInfo GetSaveSig() override;
|
||||||
void MenuOpened() override;
|
void MenuOpened() override;
|
||||||
|
|
|
@ -65,11 +65,6 @@ void GameInterface::set_hud_layout(int layout)
|
||||||
viewResizeView(layout);
|
viewResizeView(layout);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GameInterface::set_hud_scale(int scale)
|
|
||||||
{
|
|
||||||
// Not implemented, only needed as a placeholder. Maybe implement it after all? The hud is a bit large at its default size.
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
fix16_t gViewLook, gViewAngle;
|
fix16_t gViewLook, gViewAngle;
|
||||||
float gViewAngleAdjust;
|
float gViewAngleAdjust;
|
||||||
|
|
|
@ -159,11 +159,7 @@ CUSTOM_CVARD(Int, snd_speech, 1, CVAR_ARCHIVE|CVAR_GLOBALCONFIG, "enables/disabl
|
||||||
|
|
||||||
// HUD
|
// HUD
|
||||||
|
|
||||||
// This was particularly messy. EDuke and Rednukem had no consistent setting for this but a complex combination of 4 CVARs and lots of mod flags controlling the HUD layout
|
int hud_size_max = 11; // The maximum is different for each game
|
||||||
// NBlood had this differently with an inverted scale of 0-7 with 0 having no HUD.
|
|
||||||
// For consistency all frontends now use the same scale, with 0 being the smallest and 11 being the largest, which get converted to the internal settings by the set_hud_layout callback.
|
|
||||||
|
|
||||||
int hud_size_max = 11; // 11 is for Duke Nukem and its offspring games.
|
|
||||||
|
|
||||||
CUSTOM_CVARD(Int, hud_size, 9, CVAR_ARCHIVE | CVAR_NOINITCALL, "Defines the HUD size and style")
|
CUSTOM_CVARD(Int, hud_size, 9, CVAR_ARCHIVE | CVAR_NOINITCALL, "Defines the HUD size and style")
|
||||||
{
|
{
|
||||||
|
@ -171,35 +167,22 @@ CUSTOM_CVARD(Int, hud_size, 9, CVAR_ARCHIVE | CVAR_NOINITCALL, "Defines the HUD
|
||||||
else if (self > hud_size_max) self = hud_size_max;
|
else if (self > hud_size_max) self = hud_size_max;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (gi->validate_hud(self))
|
gi->set_hud_layout(self);
|
||||||
gi->set_hud_layout(self);
|
|
||||||
else
|
|
||||||
Printf("Hud size %d not available\n", *self);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// This is to allow flattening the overly complicated HUD configuration to one single value and keep the complexity safely inside the HUD code.
|
// This is for game code to change the size, so that the range checks remain isolated here.
|
||||||
bool G_ChangeHudLayout(int direction)
|
bool G_ChangeHudLayout(int direction)
|
||||||
{
|
{
|
||||||
if (direction < 0 && hud_size > 0)
|
if (direction < 0 && hud_size > 0)
|
||||||
{
|
{
|
||||||
int layout = hud_size - 1;
|
hud_size = hud_size - 1;
|
||||||
while (!gi->validate_hud(layout) && layout >= 0) layout--;
|
return true;
|
||||||
if (layout >= 0 && layout < hud_size && gi->validate_hud(layout))
|
|
||||||
{
|
|
||||||
hud_size = layout;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else if (direction > 0 && hud_size < 11)
|
else if (direction > 0 && hud_size < hud_size_max)
|
||||||
{
|
{
|
||||||
int layout = hud_size + 1;
|
hud_size = hud_size + 1;
|
||||||
while (!gi->validate_hud(layout) && layout <= 11) layout++;
|
return true;
|
||||||
if (layout <= 11 && layout > hud_size && gi->validate_hud(layout))
|
|
||||||
{
|
|
||||||
hud_size = layout;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -218,7 +201,7 @@ CUSTOM_CVARD(Int, hud_scale, 100, CVAR_ARCHIVE | CVAR_NOINITCALL, "changes the h
|
||||||
{
|
{
|
||||||
if (self < 36) self = 36;
|
if (self < 36) self = 36;
|
||||||
else if (self > 100) self = 100;
|
else if (self > 100) self = 100;
|
||||||
else gi->set_hud_scale(self);
|
else gi->UpdateScreenSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
CCMD(scaleup)
|
CCMD(scaleup)
|
||||||
|
@ -235,13 +218,6 @@ CCMD(scaledown)
|
||||||
if (hud_scale != oldscale) gi->PlayHudSound();
|
if (hud_scale != oldscale) gi->PlayHudSound();
|
||||||
}
|
}
|
||||||
|
|
||||||
int hud_statusbarrange; // will be set by the game's configuration setup.
|
|
||||||
CUSTOM_CVARD(Int, hud_custom, 0, CVAR_ARCHIVE|CVAR_NOINITCALL, "change the custom hud") // this has no backing implementation, it seems to be solely for scripted HUDs.
|
|
||||||
{
|
|
||||||
if (self < 0) self = 0;
|
|
||||||
else if (self > 0 && self >= hud_statusbarrange) self = hud_statusbarrange - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
CVARD(Bool, hud_stats, false, CVAR_ARCHIVE|CVAR_GLOBALCONFIG, "enable/disable level statistics display")
|
CVARD(Bool, hud_stats, false, CVAR_ARCHIVE|CVAR_GLOBALCONFIG, "enable/disable level statistics display")
|
||||||
CVARD(Bool, hud_showmapname, true, CVAR_ARCHIVE|CVAR_GLOBALCONFIG, "enable/disable map name display on load")
|
CVARD(Bool, hud_showmapname, true, CVAR_ARCHIVE|CVAR_GLOBALCONFIG, "enable/disable map name display on load")
|
||||||
CVARD(Bool, hud_position, false, CVAR_ARCHIVE, "aligns the status bar to the bottom/top")
|
CVARD(Bool, hud_position, false, CVAR_ARCHIVE, "aligns the status bar to the bottom/top")
|
||||||
|
|
|
@ -57,9 +57,7 @@ struct GameInterface
|
||||||
virtual void clearlocalinputstate() {}
|
virtual void clearlocalinputstate() {}
|
||||||
virtual void UpdateScreenSize() {}
|
virtual void UpdateScreenSize() {}
|
||||||
virtual void FreeGameData() {}
|
virtual void FreeGameData() {}
|
||||||
virtual bool validate_hud(int) { return true; }
|
|
||||||
virtual void set_hud_layout(int size) = 0;
|
virtual void set_hud_layout(int size) = 0;
|
||||||
virtual void set_hud_scale(int size) {}
|
|
||||||
virtual bool automapActive() { return false; }
|
virtual bool automapActive() { return false; }
|
||||||
virtual void PlayHudSound() {}
|
virtual void PlayHudSound() {}
|
||||||
virtual FString statFPS() { return "FPS display not available"; }
|
virtual FString statFPS() { return "FPS display not available"; }
|
||||||
|
|
|
@ -338,9 +338,7 @@ struct GameInterface : ::GameInterface
|
||||||
int app_main() override;
|
int app_main() override;
|
||||||
void UpdateScreenSize() override;
|
void UpdateScreenSize() override;
|
||||||
bool GenerateSavePic() override;
|
bool GenerateSavePic() override;
|
||||||
bool validate_hud(int) override { return true; }
|
|
||||||
void set_hud_layout(int size) override;
|
void set_hud_layout(int size) override;
|
||||||
void set_hud_scale(int size) override {}
|
|
||||||
void DrawNativeMenuText(int fontnum, int state, double xpos, double ypos, float fontscale, const char* text, int flags) override;
|
void DrawNativeMenuText(int fontnum, int state, double xpos, double ypos, float fontscale, const char* text, int flags) override;
|
||||||
void MenuOpened() override;
|
void MenuOpened() override;
|
||||||
void MenuSound(EMenuSounds snd) override;
|
void MenuSound(EMenuSounds snd) override;
|
||||||
|
|
|
@ -269,7 +269,7 @@ void Logo_d(const CompletionFunc &completion)
|
||||||
|
|
||||||
JobDesc jobs[3];
|
JobDesc jobs[3];
|
||||||
int job = 0;
|
int job = 0;
|
||||||
if (VOLUMEALL && !inputState.CheckAllInput()) jobs[job++] = { PlayVideo("logo.anm", logosound, logoframetimes), []() { S_PlaySpecialMusic(MUS_INTRO); } };
|
if (VOLUMEALL) jobs[job++] = { PlayVideo("logo.anm", logosound, logoframetimes), []() { S_PlaySpecialMusic(MUS_INTRO); } };
|
||||||
if (!isNam()) jobs[job++] = { Create<DDRealmsScreen>(), nullptr };
|
if (!isNam()) jobs[job++] = { Create<DDRealmsScreen>(), nullptr };
|
||||||
jobs[job++] = { Create<DTitleScreen>(), []() { S_PlaySound(NITEVISION_ONOFF, CHAN_AUTO, CHANF_UI); } };
|
jobs[job++] = { Create<DTitleScreen>(), []() { S_PlaySound(NITEVISION_ONOFF, CHAN_AUTO, CHANF_UI); } };
|
||||||
RunScreenJob(jobs, job, completion, true, true);
|
RunScreenJob(jobs, job, completion, true, true);
|
||||||
|
|
|
@ -38,9 +38,7 @@ struct GameInterface : ::GameInterface
|
||||||
void clearlocalinputstate() override;
|
void clearlocalinputstate() override;
|
||||||
void UpdateScreenSize() override;
|
void UpdateScreenSize() override;
|
||||||
bool GenerateSavePic() override;
|
bool GenerateSavePic() override;
|
||||||
bool validate_hud(int) override;
|
|
||||||
void set_hud_layout(int size) override;
|
void set_hud_layout(int size) override;
|
||||||
void set_hud_scale(int size) override;
|
|
||||||
void PlayHudSound() override;
|
void PlayHudSound() override;
|
||||||
bool automapActive() override;
|
bool automapActive() override;
|
||||||
FString statFPS() override;
|
FString statFPS() override;
|
||||||
|
|
|
@ -242,5 +242,6 @@ void setinterpolation(int* posptr);
|
||||||
void stopinterpolation(int* posptr);
|
void stopinterpolation(int* posptr);
|
||||||
void dointerpolations(int smoothratio);
|
void dointerpolations(int smoothratio);
|
||||||
int* animateptr(int i);
|
int* animateptr(int i);
|
||||||
|
void updateviewport(void);
|
||||||
|
|
||||||
END_DUKE_NS
|
END_DUKE_NS
|
||||||
|
|
|
@ -416,8 +416,6 @@ static void Startup(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
ud.last_level = -1;
|
ud.last_level = -1;
|
||||||
hud_size.Callback();
|
|
||||||
hud_scale.Callback();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
@ -432,6 +430,7 @@ int GameInterface::app_main()
|
||||||
Startup();
|
Startup();
|
||||||
enginePostInit();
|
enginePostInit();
|
||||||
videoInit();
|
videoInit();
|
||||||
|
updateviewport();
|
||||||
videoSetPalette(BASEPAL);
|
videoSetPalette(BASEPAL);
|
||||||
app_loop();
|
app_loop();
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -657,7 +657,7 @@ void drawoverheadmap(int cposx, int cposy, int czoom, int cang)
|
||||||
if (/*textret == 0 &&*/ ud.overhead_on == 2)
|
if (/*textret == 0 &&*/ ud.overhead_on == 2)
|
||||||
{
|
{
|
||||||
double scale = isRR() ? 0.5 : 1.;
|
double scale = isRR() ? 0.5 : 1.;
|
||||||
int top = isRR() ? 0 : ((ud.screen_size > 0) ? 147 : 179);
|
int top = isRR() ? 0 : (hud_size < 11 ? 147 : 179);
|
||||||
if (!(currentLevel->flags & MI_USERMAP))
|
if (!(currentLevel->flags & MI_USERMAP))
|
||||||
DrawText(twod, SmallFont2, CR_UNDEFINED, 5, top+6, GStrings.localize(gVolumeNames[volfromlevelnum(currentLevel->levelNumber)]),
|
DrawText(twod, SmallFont2, CR_UNDEFINED, 5, top+6, GStrings.localize(gVolumeNames[volfromlevelnum(currentLevel->levelNumber)]),
|
||||||
DTA_FullscreenScale, 3, DTA_VirtualWidth, 320, DTA_VirtualHeight, 200, DTA_ScaleX, scale, DTA_ScaleY, scale, DTA_KeepRatio, true, TAG_DONE);
|
DTA_FullscreenScale, 3, DTA_VirtualWidth, 320, DTA_VirtualHeight, 200, DTA_ScaleX, scale, DTA_ScaleY, scale, DTA_KeepRatio, true, TAG_DONE);
|
||||||
|
|
|
@ -195,14 +195,14 @@ void displaymasks_d(int snum)
|
||||||
|
|
||||||
if (ps[snum].scuba_on)
|
if (ps[snum].scuba_on)
|
||||||
{
|
{
|
||||||
if (ud.screen_size > 4)
|
if (hud_size < 9)
|
||||||
{
|
{
|
||||||
hud_drawsprite(44, (200 - 8 - tilesiz[SCUBAMASK].y), 65536, 0, SCUBAMASK, 0, p, 2 + 16);
|
hud_drawsprite(44, (200 - 8 - tilesiz[SCUBAMASK].y), 65536, 0, SCUBAMASK, 0, p, 2 + 16);
|
||||||
hud_drawsprite((320 - 43), (200 - 8 - tilesiz[SCUBAMASK].y), 65536, 1024, SCUBAMASK, 0, p, 2 + 4 + 16);
|
hud_drawsprite((320 - 43), (200 - 8 - tilesiz[SCUBAMASK].y), 65536, 1024, SCUBAMASK, 0, p, 2 + 4 + 16);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
hud_drawsprite(44 << 16, (200 - tilesiz[SCUBAMASK].y) << 16, 65536, 0, SCUBAMASK, 0, p, 2 + 16);
|
hud_drawsprite(44, (200 - tilesiz[SCUBAMASK].y), 65536, 0, SCUBAMASK, 0, p, 2 + 16);
|
||||||
hud_drawsprite((320 - 43), (200 - tilesiz[SCUBAMASK].y), 65536, 1024, SCUBAMASK, 0, p, 2 + 4 + 16);
|
hud_drawsprite((320 - 43), (200 - tilesiz[SCUBAMASK].y), 65536, 1024, SCUBAMASK, 0, p, 2 + 4 + 16);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -75,7 +75,7 @@ void nonsharedkeys(void)
|
||||||
{
|
{
|
||||||
if (G_ChangeHudLayout(1))
|
if (G_ChangeHudLayout(1))
|
||||||
{
|
{
|
||||||
S_PlaySound(isRR() ? 341 : THUD, CHAN_AUTO, CHANF_UI);
|
gi->PlayHudSound();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -92,7 +92,7 @@ void nonsharedkeys(void)
|
||||||
{
|
{
|
||||||
if (G_ChangeHudLayout(-1))
|
if (G_ChangeHudLayout(-1))
|
||||||
{
|
{
|
||||||
S_PlaySound(isRR() ? 341 : THUD, CHAN_AUTO, CHANF_UI);
|
gi->PlayHudSound();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -211,16 +211,6 @@ void nonsharedkeys(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if 0 // ESC is blocked by the menu, this function is not particularly useful anyway.
|
|
||||||
if (inputState.GetKeyStatus(sc_Escape) && ud.overhead_on && ps[myconnectindex].newowner == -1)
|
|
||||||
{
|
|
||||||
inputState.ClearKeyStatus(sc_Escape);
|
|
||||||
ud.last_overhead = ud.overhead_on;
|
|
||||||
ud.overhead_on = 0;
|
|
||||||
ud.scrollmode = 0;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (buttonMap.ButtonDown(gamefunc_Map))
|
if (buttonMap.ButtonDown(gamefunc_Map))
|
||||||
{
|
{
|
||||||
buttonMap.ClearButton(gamefunc_Map);
|
buttonMap.ClearButton(gamefunc_Map);
|
||||||
|
@ -739,7 +729,6 @@ static void processInputBits(player_struct *p, ControlInfo &info)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (gamequit) loc.bits |= SKB_GAMEQUIT;
|
if (gamequit) loc.bits |= SKB_GAMEQUIT;
|
||||||
//if (inputState.GetKeyStatus(sc_Escape)) loc.bits |= SKB_ESCAPE; fixme. This never gets here because the menu eats the escape key.
|
|
||||||
|
|
||||||
if (!onVehicle)
|
if (!onVehicle)
|
||||||
{
|
{
|
||||||
|
@ -1320,6 +1309,7 @@ void registerinputcommands()
|
||||||
C_RegisterFunction("jetpack", nullptr, [](CCmdFuncPtr)->int { BitsToSend = SKB_JETPACK; return CCMD_OK; });
|
C_RegisterFunction("jetpack", nullptr, [](CCmdFuncPtr)->int { BitsToSend = SKB_JETPACK; return CCMD_OK; });
|
||||||
C_RegisterFunction("turnaround", nullptr, [](CCmdFuncPtr)->int { BitsToSend = SKB_TURNAROUND; return CCMD_OK; });
|
C_RegisterFunction("turnaround", nullptr, [](CCmdFuncPtr)->int { BitsToSend = SKB_TURNAROUND; return CCMD_OK; });
|
||||||
C_RegisterFunction("invuse", nullptr, [](CCmdFuncPtr)->int { BitsToSend = SKB_INVENTORY; return CCMD_OK; });
|
C_RegisterFunction("invuse", nullptr, [](CCmdFuncPtr)->int { BitsToSend = SKB_INVENTORY; return CCMD_OK; });
|
||||||
|
C_RegisterFunction("backoff", nullptr, [](CCmdFuncPtr)->int { BitsToSend = SKB_ESCAPE; return CCMD_OK; });
|
||||||
}
|
}
|
||||||
|
|
||||||
// This is called from ImputState::ClearAllInput and resets all static state being used here.
|
// This is called from ImputState::ClearAllInput and resets all static state being used here.
|
||||||
|
|
|
@ -280,26 +280,29 @@ void DrawBorder()
|
||||||
|
|
||||||
void updateviewport(void)
|
void updateviewport(void)
|
||||||
{
|
{
|
||||||
ud.screen_size = clamp(ud.screen_size, 0, 64);
|
static const uint8_t size_vals[] = { 60, 54, 48, 40, 32, 24, 16, 8, 8, 4, 4, 0 };
|
||||||
int ss = std::max(ud.screen_size - 8, 0);
|
static const uint8_t size_vals_rr[] = { 56, 48, 40, 32, 24, 16, 12, 8, 8, 4, 4, 0 };
|
||||||
|
int ss = isRR() ? size_vals_rr[hud_size] : size_vals[hud_size];
|
||||||
|
|
||||||
|
ss = std::max(ss - 8, 0);
|
||||||
|
|
||||||
int x1 = scale(ss, xdim, 160);
|
int x1 = scale(ss, xdim, 160);
|
||||||
int x2 = xdim - x1;
|
int x2 = xdim - x1;
|
||||||
|
|
||||||
int y1 = scale(ss, (200 * 100) - ((tilesiz[TILE_BOTTOMSTATUSBAR].y >> (isRR() ? 1 : 0)) * ud.statusbarscale), 200 - tilesiz[TILE_BOTTOMSTATUSBAR].y);
|
int y1 = scale(ss, (200 * 100) - ((tilesiz[TILE_BOTTOMSTATUSBAR].y >> (isRR() ? 1 : 0)) * hud_scale), 200 - tilesiz[TILE_BOTTOMSTATUSBAR].y);
|
||||||
int y2 = 200 * 100 - y1;
|
int y2 = 200 * 100 - y1;
|
||||||
|
|
||||||
if (isRR() && ud.screen_size <= 12)
|
if (isRR() && hud_size > 6)
|
||||||
{
|
{
|
||||||
x1 = 0;
|
x1 = 0;
|
||||||
x2 = xdim;
|
x2 = xdim;
|
||||||
y1 = 0;
|
y1 = 0;
|
||||||
if (ud.statusbarmode)
|
if (hud_size >= 8)
|
||||||
y2 = 200 * 100;
|
y2 = 200 * 100;
|
||||||
}
|
}
|
||||||
|
|
||||||
int fbh = 0;
|
int fbh = 0;
|
||||||
if (ud.screen_size > 0 && ud.coop != 1 && ud.multimode > 1)
|
if (hud_size < 11 && ud.coop != 1 && ud.multimode > 1)
|
||||||
{
|
{
|
||||||
int j = 0;
|
int j = 0;
|
||||||
for (int i = connecthead; i >= 0; i = connectpoint2[i])
|
for (int i = connecthead; i >= 0; i = connectpoint2[i])
|
||||||
|
@ -312,8 +315,8 @@ void updateviewport(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
y1 += fbh * 100;
|
y1 += fbh * 100;
|
||||||
if (ud.screen_size >= 8 && ud.statusbarmode == 0)
|
if (hud_size <= 7)
|
||||||
y2 -= (tilesiz[TILE_BOTTOMSTATUSBAR].y >> (isRR() ? 1 : 0)) * ud.statusbarscale;
|
y2 -= (tilesiz[TILE_BOTTOMSTATUSBAR].y >> (isRR() ? 1 : 0)) * hud_scale;
|
||||||
y1 = scale(y1, ydim, 200 * 100);
|
y1 = scale(y1, ydim, 200 * 100);
|
||||||
y2 = scale(y2, ydim, 200 * 100);
|
y2 = scale(y2, ydim, 200 * 100);
|
||||||
|
|
||||||
|
@ -326,22 +329,9 @@ void updateviewport(void)
|
||||||
//
|
//
|
||||||
//==========================================================================
|
//==========================================================================
|
||||||
|
|
||||||
bool GameInterface::validate_hud(int layout)
|
|
||||||
{
|
|
||||||
return layout <= 11;
|
|
||||||
}
|
|
||||||
|
|
||||||
void GameInterface::set_hud_layout(int layout)
|
void GameInterface::set_hud_layout(int layout)
|
||||||
{
|
{
|
||||||
static const uint8_t screen_size_vals[] = { 60, 54, 48, 40, 32, 24, 16, 8, 8, 4, 4, 0 };
|
if (xdim > 0 && ydim > 0) updateviewport();
|
||||||
static const uint8_t screen_size_vals_rr[] = { 56, 48, 40, 32, 24, 16, 12, 8, 8, 4, 4, 0 };
|
|
||||||
if (validate_hud(layout))
|
|
||||||
{
|
|
||||||
ud.screen_size = isRR()? screen_size_vals_rr[layout] : screen_size_vals[layout];
|
|
||||||
ud.statusbarmode = layout >= 8;
|
|
||||||
ud.althud = layout >= 10;
|
|
||||||
if (xdim > 0 && ydim > 0) updateviewport();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void GameInterface::PlayHudSound()
|
void GameInterface::PlayHudSound()
|
||||||
|
@ -349,12 +339,6 @@ void GameInterface::PlayHudSound()
|
||||||
S_PlaySound(isRR() ? 341 : THUD, CHAN_AUTO, CHANF_UI);
|
S_PlaySound(isRR() ? 341 : THUD, CHAN_AUTO, CHANF_UI);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GameInterface::set_hud_scale(int scale)
|
|
||||||
{
|
|
||||||
ud.statusbarscale = clamp(scale, 36, 100);
|
|
||||||
if (xdim > 0 && ydim > 0) updateviewport();
|
|
||||||
}
|
|
||||||
|
|
||||||
void GameInterface::UpdateScreenSize()
|
void GameInterface::UpdateScreenSize()
|
||||||
{
|
{
|
||||||
updateviewport();
|
updateviewport();
|
||||||
|
|
|
@ -407,9 +407,9 @@ void PrintLevelName_d(double alpha);
|
||||||
void drawstatusbar_d(int snum)
|
void drawstatusbar_d(int snum)
|
||||||
{
|
{
|
||||||
DDukeStatusBar dsb;
|
DDukeStatusBar dsb;
|
||||||
if (ud.screen_size <= 4)
|
if (hud_size >= 9)
|
||||||
{
|
{
|
||||||
dsb.DrawHud(snum, ud.screen_size < 4 ? 0 : ud.althud ? 1 : 2);
|
dsb.DrawHud(snum, hud_size == 11 ? 0 : hud_size == 10 ? 1 : 2);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -290,7 +290,7 @@ public:
|
||||||
BeginStatusBar(320, 200, h, true);
|
BeginStatusBar(320, 200, h, true);
|
||||||
DrawInventory(p, 160, 154, 0);
|
DrawInventory(p, 160, 154, 0);
|
||||||
|
|
||||||
if (ud.screen_size > 8)
|
if (hud_size < 7)
|
||||||
DrawWeaponBar(p, top);
|
DrawWeaponBar(p, top);
|
||||||
|
|
||||||
DrawGraphic(tileGetTexture(BOTTOMSTATUSBAR), 0, top, DI_ITEM_LEFT_TOP, 1, -1, -1, scale, scale);
|
DrawGraphic(tileGetTexture(BOTTOMSTATUSBAR), 0, top, DI_ITEM_LEFT_TOP, 1, -1, -1, scale, scale);
|
||||||
|
@ -391,9 +391,9 @@ void PrintLevelName_r(double alpha);
|
||||||
void drawstatusbar_r(int snum)
|
void drawstatusbar_r(int snum)
|
||||||
{
|
{
|
||||||
DRedneckStatusBar dsb;
|
DRedneckStatusBar dsb;
|
||||||
if (ud.screen_size <= 4)
|
if (hud_size >= 9)
|
||||||
{
|
{
|
||||||
dsb.DrawHud(snum, ud.screen_size < 4 ? 0 : ud.althud ? 1 : 2);
|
dsb.DrawHud(snum, hud_size == 11 ? 0 : hud_size == 10 ? 1 : 2);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -55,7 +55,7 @@ struct input_t // original name was input which is too generic for a type name.
|
||||||
|
|
||||||
struct user_defs
|
struct user_defs
|
||||||
{
|
{
|
||||||
unsigned char god, cashman, eog, showallmap;
|
unsigned char god, cashman, eog;
|
||||||
unsigned char show_help, scrollmode, clipping;
|
unsigned char show_help, scrollmode, clipping;
|
||||||
char user_name[MAXPLAYERS][32];
|
char user_name[MAXPLAYERS][32];
|
||||||
unsigned char overhead_on, last_overhead, showweapons;
|
unsigned char overhead_on, last_overhead, showweapons;
|
||||||
|
@ -69,17 +69,16 @@ struct user_defs
|
||||||
int folfvel, folavel, folx, foly, fola;
|
int folfvel, folavel, folx, foly, fola;
|
||||||
int reccnt;
|
int reccnt;
|
||||||
|
|
||||||
int runkey_mode, statusbarscale, weaponswitch;
|
int runkey_mode, weaponswitch;
|
||||||
|
|
||||||
int entered_name, shadows, executions, auto_run;
|
int entered_name, shadows, executions, auto_run;
|
||||||
int coords, tickrate, levelstats, m_coop, coop, screen_size;
|
int coords, tickrate, levelstats, m_coop, coop;
|
||||||
int wchoice[MAXPLAYERS][MAX_WEAPONS], playerai;
|
int wchoice[MAXPLAYERS][MAX_WEAPONS], playerai;
|
||||||
|
|
||||||
int respawn_monsters, respawn_items, respawn_inventory, recstat, monsters_off, brightness;
|
int respawn_monsters, respawn_items, respawn_inventory, recstat, monsters_off, brightness;
|
||||||
int m_respawn_items, m_respawn_monsters, m_respawn_inventory, m_recstat, m_monsters_off, detail;
|
int m_respawn_items, m_respawn_monsters, m_respawn_inventory, m_recstat, m_monsters_off, detail;
|
||||||
int m_ffire, ffire, m_player_skill, multimode;
|
int m_ffire, ffire, m_player_skill, multimode;
|
||||||
int player_skill, marker;
|
int player_skill, marker;
|
||||||
int statusbarmode, althud;
|
|
||||||
MapRecord* nextLevel;
|
MapRecord* nextLevel;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -3806,8 +3806,6 @@ void GameInterface::set_hud_layout(int requested_size)
|
||||||
SetBorder(Player + myconnectindex, gs.BorderNum);
|
SetBorder(Player + myconnectindex, gs.BorderNum);
|
||||||
SetRedrawScreen(Player + myconnectindex);
|
SetRedrawScreen(Player + myconnectindex);
|
||||||
}
|
}
|
||||||
/*extern*/ void GameInterface::set_hud_scale(int requested_size) { }
|
|
||||||
|
|
||||||
::GameInterface* CreateInterface()
|
::GameInterface* CreateInterface()
|
||||||
{
|
{
|
||||||
return new GameInterface;
|
return new GameInterface;
|
||||||
|
|
|
@ -2538,7 +2538,6 @@ struct GameInterface : ::GameInterface
|
||||||
void FreeGameData() override;
|
void FreeGameData() override;
|
||||||
bool GenerateSavePic() override;
|
bool GenerateSavePic() override;
|
||||||
void set_hud_layout(int size) override;
|
void set_hud_layout(int size) override;
|
||||||
void set_hud_scale(int size) override;
|
|
||||||
void DrawNativeMenuText(int fontnum, int state, double xpos, double ypos, float fontscale, const char* text, int flags) override;
|
void DrawNativeMenuText(int fontnum, int state, double xpos, double ypos, float fontscale, const char* text, int flags) override;
|
||||||
void MenuOpened() override;
|
void MenuOpened() override;
|
||||||
void MenuSound(EMenuSounds snd) override;
|
void MenuSound(EMenuSounds snd) override;
|
||||||
|
|
Loading…
Reference in a new issue