mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-11 18:50:46 +00:00
Fix annoying bug with ambient creature sound timer
This commit is contained in:
parent
4e21cf5cbf
commit
6f9cdaccfc
4 changed files with 27 additions and 19 deletions
|
@ -2092,6 +2092,8 @@ static void GameMove(void)
|
|||
bobangle &= kAngleMask;
|
||||
}
|
||||
|
||||
UpdateCreepySounds();
|
||||
|
||||
// loc_120E9:
|
||||
totalmoves++;
|
||||
moveframes--;
|
||||
|
|
|
@ -345,7 +345,7 @@ void InitFX(void)
|
|||
|
||||
nTotalSoundBytes = 0;
|
||||
nSoundCount = 0;
|
||||
nCreepyTimer = 450;
|
||||
nCreepyTimer = kCreepyCount;
|
||||
|
||||
#if 0
|
||||
int status = FX_Init(FXDevice, NumVoices, NumChannels, NumBits, MixRate);
|
||||
|
@ -817,29 +817,32 @@ void UpdateSounds()
|
|||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (!nFreeze && levelnum != 20)
|
||||
void UpdateCreepySounds()
|
||||
{
|
||||
if (levelnum == 20)
|
||||
return;
|
||||
spritetype *pSprite = &sprite[PlayerList[nLocalPlayer].nSprite];
|
||||
nCreepyTimer--;
|
||||
if (nCreepyTimer <= 0)
|
||||
{
|
||||
nCreepyTimer--;
|
||||
if (nCreepyTimer <= 0)
|
||||
if (nCreaturesLeft > 0 && !(SectFlag[nPlayerViewSect[nLocalPlayer]]&0x2000))
|
||||
{
|
||||
if (nCreaturesLeft > 0 && !(SectFlag[nPlayerViewSect[nLocalPlayer]]&0x2000))
|
||||
int vsi = seq_GetFrameSound(SeqOffsets[kSeqCreepy], totalmoves%SeqSize[SeqOffsets[kSeqCreepy]]);
|
||||
if (vsi >= 0 && (vsi&0x1ff) < kMaxSounds)
|
||||
{
|
||||
int vsi = seq_GetFrameSound(SeqOffsets[kSeqCreepy], totalmoves%SeqSize[SeqOffsets[kSeqCreepy]]);
|
||||
if (vsi >= 0 && (vsi&0x1ff) < kMaxSounds)
|
||||
{
|
||||
int vdx = (totalmoves+32)&31;
|
||||
if (totalmoves & 1)
|
||||
vdx = -vdx;
|
||||
int vax = (totalmoves+32)&63;
|
||||
if (totalmoves & 2)
|
||||
vax = -vax;
|
||||
int vdx = (totalmoves+32)&31;
|
||||
if (totalmoves & 1)
|
||||
vdx = -vdx;
|
||||
int vax = (totalmoves+32)&63;
|
||||
if (totalmoves & 2)
|
||||
vax = -vax;
|
||||
|
||||
PlayFXAtXYZ(vsi, pSprite->x+vdx, pSprite->y+vax, pSprite->z, pSprite->sectnum);
|
||||
}
|
||||
PlayFXAtXYZ(vsi, pSprite->x+vdx, pSprite->y+vax, pSprite->z, pSprite->sectnum);
|
||||
}
|
||||
nCreepyTimer = 450;
|
||||
}
|
||||
nCreepyTimer = kCreepyCount;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1153,7 +1156,7 @@ short PlayFX2(unsigned short nSound, short nSprite)
|
|||
|
||||
// Nuke: added nSprite >= 0 check
|
||||
if (nSprite != nLocalSpr && nSprite >= 0 && (sprite[nSprite].cstat&257))
|
||||
nCreepyTimer = 450;
|
||||
nCreepyTimer = kCreepyCount;
|
||||
|
||||
return v14;
|
||||
}
|
||||
|
|
|
@ -7,6 +7,8 @@
|
|||
#define kMaxSoundNameLen 8
|
||||
#define kMaxActiveSounds 8
|
||||
|
||||
#define kCreepyCount 150
|
||||
|
||||
enum {
|
||||
kSound0 = 0,
|
||||
kSound1,
|
||||
|
@ -91,6 +93,7 @@ extern short StaticSound[];
|
|||
|
||||
|
||||
void UpdateSounds();
|
||||
void UpdateCreepySounds();
|
||||
|
||||
void InitFX();
|
||||
void UnInitFX();
|
||||
|
|
|
@ -213,7 +213,7 @@ static void analyzesprites()
|
|||
{
|
||||
spritetype *pTarget = &sprite[besttarget];
|
||||
|
||||
nCreepyTimer = 450;
|
||||
nCreepyTimer = kCreepyCount;
|
||||
|
||||
if (!cansee(x, y, z, nSector, pTarget->x, pTarget->y, pTarget->z - GetSpriteHeight(besttarget), pTarget->sectnum))
|
||||
{
|
||||
|
|
Loading…
Reference in a new issue