-let's hope this will solve the pausing problem for good.

The checks for game pause were totally inconsistent, so now there is a utility function that tells whether the game is supposed to run or not.
pause can also take 3 values now - 0 for no pause, 1 for pause from opening the menu or console or 2 for hitting the pause button.
This commit is contained in:
Christoph Oelckers 2020-07-21 22:46:26 +02:00
parent 6227f9f7fd
commit 61f5247b71
13 changed files with 41 additions and 43 deletions

View file

@ -1103,11 +1103,12 @@ bool CheckCheatmode(bool printmsg)
void updatePauseStatus() void updatePauseStatus()
{ {
bool GUICapture = System_WantGuiCapture(); bool GUICapture = System_WantGuiCapture();
if ( GUICapture) if (M_Active() || ConsoleState != c_up)
{ {
paused = 1; paused = 1;
return;
} }
else if ((!M_Active() || !GUICapture) && !pausedWithKey) else if (!pausedWithKey)
{ {
paused = 0; paused = 0;
} }
@ -1115,7 +1116,7 @@ void updatePauseStatus()
if (inputState.GetKeyStatus(sc_Pause)) if (inputState.GetKeyStatus(sc_Pause))
{ {
inputState.ClearKeyStatus(sc_Pause); inputState.ClearKeyStatus(sc_Pause);
paused = !paused; paused = pausedWithKey ? 0 : 2;
if (paused) if (paused)
{ {
@ -1123,10 +1124,10 @@ void updatePauseStatus()
} }
else else
{ {
S_ResumeSound(paused); S_ResumeSound(!!paused);
} }
pausedWithKey = paused; pausedWithKey = !!paused;
} }
} }

View file

@ -202,6 +202,7 @@ enum
PAUSESFX_CONSOLE = 2 PAUSESFX_CONSOLE = 2
}; };
bool UIActive();
void updatePauseStatus(); void updatePauseStatus();
void updatePauseStatus(bool state, bool multiplayer); void updatePauseStatus(bool state, bool multiplayer);
extern int paused; extern int paused;

View file

@ -483,7 +483,6 @@ enum EFlamethrowerState
}; };
enum gamemode_t { enum gamemode_t {
MODE_MENU = 0x00000001,
MODE_DEMO = 0x00000002, MODE_DEMO = 0x00000002,
MODE_GAME = 0x00000004, MODE_GAME = 0x00000004,
MODE_EOL = 0x00000008, MODE_EOL = 0x00000008,

View file

@ -221,12 +221,6 @@ void GameInterface::MenuOpened()
totalclock = ototalclock; totalclock = ototalclock;
screenpeek = myconnectindex; screenpeek = myconnectindex;
} }
auto& gm = ps[myconnectindex].gm;
if (gm & MODE_GAME)
{
gm |= MODE_MENU;
}
} }
void GameInterface::MenuSound(EMenuSounds snd) void GameInterface::MenuSound(EMenuSounds snd)
@ -260,7 +254,6 @@ void GameInterface::MenuClosed()
if (gm & MODE_GAME) if (gm & MODE_GAME)
{ {
// The following lines are here so that you cannot close the menu when no game is running. // The following lines are here so that you cannot close the menu when no game is running.
gm &= ~MODE_MENU;
if (ud.multimode < 2 && ud.recstat != 2) if (ud.multimode < 2 && ud.recstat != 2)
{ {

View file

@ -40,6 +40,7 @@ Modifications for JonoF's port by Jonathon Fowler (jf@jonof.id.au)
#include "i_interface.h" #include "i_interface.h"
#include "prediction.h" #include "prediction.h"
#include "glbackend/glbackend.h" #include "glbackend/glbackend.h"
#include "gamestate.h"
BEGIN_DUKE_NS BEGIN_DUKE_NS
@ -282,7 +283,7 @@ static void ticker(void)
S_Update(); S_Update();
// we need CONTROL_GetInput in order to pick up joystick button presses // we need CONTROL_GetInput in order to pick up joystick button presses
if (!(ps[myconnectindex].gm & MODE_GAME) || (paused && !System_WantGuiCapture())) if (gamestate != GS_LEVEL || (paused && !System_WantGuiCapture()))
{ {
ControlInfo noshareinfo; ControlInfo noshareinfo;
CONTROL_GetInput(&noshareinfo); CONTROL_GetInput(&noshareinfo);

View file

@ -174,8 +174,6 @@ void FTA(int q, struct player_struct* p)
void drawbackground(void) void drawbackground(void)
{ {
if ((ps[myconnectindex].gm & MODE_GAME) == 0 && ud.recstat != 2)
{
twod->ClearScreen(); twod->ClearScreen();
auto tex = tileGetTexture(TILE_MENUSCREEN); auto tex = tileGetTexture(TILE_MENUSCREEN);
PalEntry color = 0xff808080; PalEntry color = 0xff808080;
@ -183,8 +181,6 @@ void drawbackground(void)
DrawTexture(twod, tex, 0, 0, DTA_FullscreenEx, 3, DTA_Color, color, TAG_DONE); DrawTexture(twod, tex, 0, 0, DTA_FullscreenEx, 3, DTA_Color, color, TAG_DONE);
else else
DrawTexture(twod, tex, 0, 0, DTA_VirtualWidth, twod->GetWidth(), DTA_VirtualHeight, twod->GetHeight(), DTA_KeepRatio, true, DTA_Color, color, TAG_DONE); DrawTexture(twod, tex, 0, 0, DTA_VirtualWidth, twod->GetWidth(), DTA_VirtualHeight, twod->GetHeight(), DTA_KeepRatio, true, DTA_Color, color, TAG_DONE);
return;
}
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
@ -304,7 +300,7 @@ void displayrest(int smoothratio)
if (ud.scrollmode == 0) if (ud.scrollmode == 0)
{ {
if (pp->newowner == -1 && !paused) if (pp->newowner == -1 && playrunning())
{ {
if (screenpeek == myconnectindex && numplayers > 1) if (screenpeek == myconnectindex && numplayers > 1)
{ {
@ -328,7 +324,7 @@ void displayrest(int smoothratio)
} }
else else
{ {
if (!paused) if (playrunning())
{ {
ud.fola += ud.folavel >> 3; ud.fola += ud.folavel >> 3;
ud.folx += (ud.folfvel * sintable[(512 + 2048 - ud.fola) & 2047]) >> 14; ud.folx += (ud.folfvel * sintable[(512 + 2048 - ud.fola) & 2047]) >> 14;
@ -371,7 +367,7 @@ void displayrest(int smoothratio)
} }
} }
if (paused == 1 && (ps[myconnectindex].gm & MODE_MENU) == 0) if (paused == 2)
fi.PrintPaused(); fi.PrintPaused();
} }

View file

@ -961,7 +961,6 @@ int ParseState::parse(void)
#if 0 #if 0
if( lastsavedpos >= 0 && ud.recstat != 2 ) if( lastsavedpos >= 0 && ud.recstat != 2 )
{ {
ps[g_p].gm = MODE_MENU;
KB_ClearKeyDown(sc_Space); KB_ClearKeyDown(sc_Space);
cmenu(15000); cmenu(15000);
} }

View file

@ -233,7 +233,7 @@ int domovethings()
//if(ud.recstat == 1) record(); //if(ud.recstat == 1) record();
if (paused == 0) if (playrunning())
{ {
global_random = krand(); global_random = krand();
movedummyplayers();//ST 13 movedummyplayers();//ST 13
@ -241,7 +241,7 @@ int domovethings()
for (i = connecthead; i >= 0; i = connectpoint2[i]) for (i = connecthead; i >= 0; i = connectpoint2[i])
{ {
if (paused == 0) if (playrunning())
{ {
auto p = &ps[i]; auto p = &ps[i];
if (p->pals.a > 0) if (p->pals.a > 0)
@ -253,7 +253,7 @@ int domovethings()
} }
} }
if (paused == 0) if (playrunning())
{ {
if (levelTextTime > 0) if (levelTextTime > 0)
levelTextTime--; levelTextTime--;
@ -317,12 +317,11 @@ bool GameTicker()
gameupdatetime.Reset(); gameupdatetime.Reset();
gameupdatetime.Clock(); gameupdatetime.Clock();
while ((!(ps[myconnectindex].gm & (MODE_MENU | MODE_DEMO))) && (int)(totalclock - ototalclock) >= TICSPERFRAME) while (playrunning() && (int)(totalclock - ototalclock) >= TICSPERFRAME)
{ {
ototalclock += TICSPERFRAME; ototalclock += TICSPERFRAME;
GetInput(); GetInput();
// this is where we fill the input_t struct that is actually processed by P_ProcessInput()
auto const pPlayer = &ps[myconnectindex]; auto const pPlayer = &ps[myconnectindex];
auto const q16ang = fix16_to_int(pPlayer->q16ang); auto const q16ang = fix16_to_int(pPlayer->q16ang);
auto& input = nextinput(myconnectindex); auto& input = nextinput(myconnectindex);
@ -338,12 +337,15 @@ bool GameTicker()
advancequeue(myconnectindex); advancequeue(myconnectindex);
if (((!System_WantGuiCapture() && (ps[myconnectindex].gm & MODE_MENU) != MODE_MENU) || ud.recstat == 2 || (ud.multimode > 1)) && if (playrunning())
(ps[myconnectindex].gm & MODE_GAME))
{ {
moveloop(); moveloop();
} }
} }
if (!playrunning())
{
ototalclock = totalclock - 1;
}
gameUpdate = true; gameUpdate = true;
gameupdatetime.Unclock(); gameupdatetime.Unclock();
@ -394,6 +396,7 @@ void app_loop()
while (true) while (true)
{ {
handleevents(); handleevents();
updatePauseStatus();
switch (gamestate) switch (gamestate)
{ {
default: default:

View file

@ -164,10 +164,14 @@ inline void SetPlayerPal(player_struct* p, PalEntry pe)
p->pals = pe; p->pals = pe;
} }
inline bool playrunning()
{
return (paused == 0 || (paused == 1 && (ud.recstat == 2 || ud.multimode > 1)));
}
inline int calc_smoothratio(ClockTicks totalclk, ClockTicks ototalclk) inline int calc_smoothratio(ClockTicks totalclk, ClockTicks ototalclk)
{ {
if (!((ud.multimode < 2 && ((ps[myconnectindex].gm & MODE_MENU) == 0)) || if (!playrunning())
ud.multimode > 1 || ud.recstat == 2) || paused)
{ {
return 65536; return 65536;
} }

View file

@ -1227,7 +1227,6 @@ void GetInput()
{ {
double elapsedInputTicks; double elapsedInputTicks;
auto const p = &ps[myconnectindex]; auto const p = &ps[myconnectindex];
updatePauseStatus();
auto now = I_msTimeF(); auto now = I_msTimeF();
// do not let this become too large - it would create overflows resulting in undefined behavior. The very first tic must not use the timer difference at all because the timer has not been set yet. // do not let this become too large - it would create overflows resulting in undefined behavior. The very first tic must not use the timer difference at all because the timer has not been set yet.

View file

@ -293,9 +293,9 @@ void animatecamsprite(int smoothRatio)
void setdrugmode(player_struct *p, int oyrepeat) void setdrugmode(player_struct *p, int oyrepeat)
{ {
if (!paused) if (playrunning())
{ {
if (p->DrugMode > 0 && !(p->gm & MODE_TYPE) && !paused) if (p->DrugMode > 0 && !(p->gm & MODE_TYPE))
{ {
int var_8c; int var_8c;
if (p->drug_stat[0] == 0) if (p->drug_stat[0] == 0)
@ -491,7 +491,7 @@ void displayrooms(int snum, int smoothratio)
videoSetCorrectedAspect(); videoSetCorrectedAspect();
smoothratio = min(max(smoothratio, 0), 65536); smoothratio = min(max(smoothratio, 0), 65536);
if (paused || ps[snum].on_crane > -1) smoothratio = 65536; if (!playrunning() || ps[snum].on_crane > -1) smoothratio = 65536;
sect = p->cursectnum; sect = p->cursectnum;
if (sect < 0 || sect >= MAXSECTORS) return; if (sect < 0 || sect >= MAXSECTORS) return;

View file

@ -29,6 +29,7 @@ Modifications for JonoF's port by Jonathon Fowler (jf@jonof.id.au)
#include "serializer.h" #include "serializer.h"
#include "mapinfo.h" #include "mapinfo.h"
#include "duke3d.h" #include "duke3d.h"
#include "gamestate.h"
BEGIN_DUKE_NS BEGIN_DUKE_NS
@ -483,6 +484,7 @@ void GameInterface::SerializeGameState(FSerializer& arc)
{ {
screenpeek = myconnectindex; screenpeek = myconnectindex;
ps[myconnectindex].gm = MODE_GAME; ps[myconnectindex].gm = MODE_GAME;
gamestate = GS_LEVEL;
ud.recstat = 0; ud.recstat = 0;
ud.m_player_skill = ud.player_skill; ud.m_player_skill = ud.player_skill;

View file

@ -375,7 +375,7 @@ void S_Update(void)
int S_PlaySound3D(int sndnum, int spriteNum, const vec3_t* pos, int channel, EChanFlags flags) int S_PlaySound3D(int sndnum, int spriteNum, const vec3_t* pos, int channel, EChanFlags flags)
{ {
auto const pl = &ps[myconnectindex]; auto const pl = &ps[myconnectindex];
if (!soundEngine->isValidSoundId(sndnum+1) || !SoundEnabled() || (unsigned)spriteNum >= MAXSPRITES || (pl->gm & MODE_MENU) || if (!soundEngine->isValidSoundId(sndnum+1) || !SoundEnabled() || (unsigned)spriteNum >= MAXSPRITES || !playrunning() ||
(pl->timebeforeexit > 0 && pl->timebeforeexit <= REALGAMETICSPERSEC * 3)) return -1; (pl->timebeforeexit > 0 && pl->timebeforeexit <= REALGAMETICSPERSEC * 3)) return -1;
int userflags = S_GetUserFlags(sndnum); int userflags = S_GetUserFlags(sndnum);