- fixed variable name clash caused by viewUpdateShake's global variables.

removed the redundant call in the Ticker, because all its results are discarded.
Use arguments instead of global variables to pass data around.
This commit is contained in:
Christoph Oelckers 2021-03-21 08:58:38 +01:00
parent d42ce0ee7e
commit 9f36ef69e6
3 changed files with 20 additions and 23 deletions

View file

@ -304,7 +304,6 @@ void GameInterface::Ticker()
viewCorrectPrediction(); viewCorrectPrediction();
ambProcess(); ambProcess();
viewUpdateDelirium(); viewUpdateDelirium();
viewUpdateShake();
gi->UpdateSounds(); gi->UpdateSounds();
if (gMe->hand == 1) if (gMe->hand == 1)
{ {

View file

@ -395,17 +395,15 @@ void viewUpdateDelirium(void)
} }
} }
int shakeHoriz, shakeAngle, shakeX, shakeY, shakeZ, shakeBobX, shakeBobY; void viewUpdateShake(int& cX, int& cY, int& cZ, binangle& cA, fixedhoriz& cH, double& pshakeX, double& pshakeY)
void viewUpdateShake(void)
{ {
shakeHoriz = 0; int shakeHoriz = 0;
shakeAngle = 0; int shakeAngle = 0;
shakeX = 0; int shakeX = 0;
shakeY = 0; int shakeY = 0;
shakeZ = 0; int shakeZ = 0;
shakeBobX = 0; int shakeBobX = 0;
shakeBobY = 0; int shakeBobY = 0;
if (gView->flickerEffect) if (gView->flickerEffect)
{ {
int nValue = ClipHigh(gView->flickerEffect * 8, 2000); int nValue = ClipHigh(gView->flickerEffect * 8, 2000);
@ -428,6 +426,14 @@ void viewUpdateShake(void)
shakeBobX += QRandom2(nValue); shakeBobX += QRandom2(nValue);
shakeBobY += QRandom2(nValue); shakeBobY += QRandom2(nValue);
} }
cH += buildhoriz(shakeHoriz);
cA += buildang(shakeAngle);
cX += shakeX;
cY += shakeY;
cZ += shakeZ;
pshakeX += shakeBobX;
pshakeY += shakeBobY;
} }
@ -452,11 +458,10 @@ static void DrawMap(spritetype* pSprite)
setViewport(hud_size); setViewport(hud_size);
} }
void SetupView(int &cX, int& cY, int& cZ, binangle& cA, fixedhoriz& cH, int& nSectnum, double& zDelta) void SetupView(int &cX, int& cY, int& cZ, binangle& cA, fixedhoriz& cH, int& nSectnum, double& zDelta, double& shakeX, double& shakeY)
{ {
int bobWidth, bobHeight; int bobWidth, bobHeight;
lookangle rotscrnang; lookangle rotscrnang;
double shakeX, shakeY;
nSectnum = gView->pSprite->sectnum; nSectnum = gView->pSprite->sectnum;
if (numplayers > 1 && gView == gMe && gPrediction && gMe->pXSprite->health > 0) if (numplayers > 1 && gView == gMe && gPrediction && gMe->pXSprite->health > 0)
{ {
@ -515,14 +520,7 @@ void SetupView(int &cX, int& cY, int& cZ, binangle& cA, fixedhoriz& cH, int& nSe
} }
} }
viewUpdateShake(); viewUpdateShake(cX, cY, cZ, cA, cH, shakeX, shakeY);
cH += buildhoriz(shakeHoriz);
cA += buildang(shakeAngle);
cX += shakeX;
cY += shakeY;
cZ += shakeZ;
shakeX += shakeBobX;
shakeY += shakeBobY;
cH += buildhoriz(MulScale(0x40000000 - Cos(gView->tiltEffect << 2), 30, 30)); cH += buildhoriz(MulScale(0x40000000 - Cos(gView->tiltEffect << 2), 30, 30));
if (gViewPos == 0) if (gViewPos == 0)
{ {
@ -686,7 +684,8 @@ void viewDrawScreen(bool sceneonly)
fixedhoriz cH; fixedhoriz cH;
int nSectnum; int nSectnum;
double zDelta; double zDelta;
SetupView(cX, cY, cZ, cA, cH, nSectnum, zDelta); double shakeX, shakeY;
SetupView(cX, cY, cZ, cA, cH, nSectnum, zDelta, shakeX, shakeY);
int tilt = interpolateang(gScreenTiltO, gScreenTilt, gInterpolate); int tilt = interpolateang(gScreenTiltO, gScreenTilt, gInterpolate);
uint8_t v14 = 0; uint8_t v14 = 0;

View file

@ -153,7 +153,6 @@ void DoLensEffect(void);
void UpdateDacs(int nPalette, bool bNoTint = false); void UpdateDacs(int nPalette, bool bNoTint = false);
void viewDrawScreen(bool sceneonly = false); void viewDrawScreen(bool sceneonly = false);
void viewUpdateDelirium(void); void viewUpdateDelirium(void);
void viewUpdateShake(void);
void viewSetSystemMessage(const char* pMessage, ...); void viewSetSystemMessage(const char* pMessage, ...);
inline void viewInterpolateSector(int nSector, sectortype *pSector) inline void viewInterpolateSector(int nSector, sectortype *pSector)