mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 11:10:39 +00:00
astub.c: in M32_MoveFX, use separate bit array to store "sound is playing".
Instead of sprite[].filler. git-svn-id: https://svn.eduke32.com/eduke32@4300 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
bd34885653
commit
54c74ca78e
1 changed files with 16 additions and 13 deletions
|
@ -2504,8 +2504,12 @@ static void SoundDisplay(void)
|
||||||
|
|
||||||
int32_t AmbienceToggle = 1;
|
int32_t AmbienceToggle = 1;
|
||||||
int32_t ParentalLock = 0;
|
int32_t ParentalLock = 0;
|
||||||
#undef T1
|
|
||||||
#define T1 (s->filler)
|
static uint8_t g_ambiencePlaying[MAXSPRITES>>3];
|
||||||
|
|
||||||
|
#define testbit(bitarray, i) (bitarray[(i)>>3] & (1<<((i)&7)))
|
||||||
|
#define setbit(bitarray, i) bitarray[(i)>>3] |= (1<<((i)&7))
|
||||||
|
#define clearbit(bitarray, i) bitarray[(i)>>3] &= ~(1<<((i)&7))
|
||||||
|
|
||||||
// adapted from actors.c
|
// adapted from actors.c
|
||||||
static void M32_MoveFX(void)
|
static void M32_MoveFX(void)
|
||||||
|
@ -2520,9 +2524,9 @@ static void M32_MoveFX(void)
|
||||||
|
|
||||||
if (s->picnum != MUSICANDSFX)
|
if (s->picnum != MUSICANDSFX)
|
||||||
{
|
{
|
||||||
if (T1&1)
|
if (testbit(g_ambiencePlaying, i))
|
||||||
{
|
{
|
||||||
T1 &= (~1);
|
clearbit(g_ambiencePlaying, i);
|
||||||
S_StopEnvSound(s->lotag, i);
|
S_StopEnvSound(s->lotag, i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2536,7 +2540,7 @@ static void M32_MoveFX(void)
|
||||||
if ((g_sounds[s->lotag].m & SF_MSFX))
|
if ((g_sounds[s->lotag].m & SF_MSFX))
|
||||||
{
|
{
|
||||||
x = dist((spritetype *)&pos,s);
|
x = dist((spritetype *)&pos,s);
|
||||||
if (x < ht && (T1&1) == 0 && FX_VoiceAvailable(g_sounds[s->lotag].pr-1))
|
if (x < ht && !testbit(g_ambiencePlaying, i) && FX_VoiceAvailable(g_sounds[s->lotag].pr-1))
|
||||||
{
|
{
|
||||||
char om = g_sounds[s->lotag].m;
|
char om = g_sounds[s->lotag].m;
|
||||||
if (g_numEnvSoundsPlaying == NumVoices)
|
if (g_numEnvSoundsPlaying == NumVoices)
|
||||||
|
@ -2544,7 +2548,7 @@ static void M32_MoveFX(void)
|
||||||
for (j = headspritestat[0]; j >= 0; j = nextspritestat[j])
|
for (j = headspritestat[0]; j >= 0; j = nextspritestat[j])
|
||||||
{
|
{
|
||||||
if (s->picnum == MUSICANDSFX && j != i && sprite[j].lotag < 999 &&
|
if (s->picnum == MUSICANDSFX && j != i && sprite[j].lotag < 999 &&
|
||||||
(sprite[j].filler&1) == 1 && dist(&sprite[j],(spritetype *)&pos) > x)
|
testbit(g_ambiencePlaying, j) && dist(&sprite[j],(spritetype *)&pos) > x)
|
||||||
{
|
{
|
||||||
S_StopEnvSound(sprite[j].lotag,j);
|
S_StopEnvSound(sprite[j].lotag,j);
|
||||||
break;
|
break;
|
||||||
|
@ -2556,11 +2560,11 @@ static void M32_MoveFX(void)
|
||||||
g_sounds[s->lotag].m |= SF_LOOP;
|
g_sounds[s->lotag].m |= SF_LOOP;
|
||||||
A_PlaySound(s->lotag,i);
|
A_PlaySound(s->lotag,i);
|
||||||
g_sounds[s->lotag].m = om;
|
g_sounds[s->lotag].m = om;
|
||||||
T1 |= 1;
|
setbit(g_ambiencePlaying, i);
|
||||||
}
|
}
|
||||||
if (x >= ht && (T1&1) == 1)
|
if (x >= ht && testbit(g_ambiencePlaying, i))
|
||||||
{
|
{
|
||||||
T1 &= (~1);
|
clearbit(g_ambiencePlaying, i);
|
||||||
S_StopEnvSound(s->lotag,i);
|
S_StopEnvSound(s->lotag,i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2568,7 +2572,6 @@ static void M32_MoveFX(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#undef T1
|
|
||||||
|
|
||||||
|
|
||||||
///__ShowHelpText__
|
///__ShowHelpText__
|
||||||
|
@ -5139,7 +5142,7 @@ static void Keys3d(void)
|
||||||
message("Sprite %d deleted",searchwall);
|
message("Sprite %d deleted",searchwall);
|
||||||
if (AmbienceToggle)
|
if (AmbienceToggle)
|
||||||
{
|
{
|
||||||
sprite[searchwall].filler &= (~1);
|
clearbit(g_ambiencePlaying, searchwall);
|
||||||
S_StopEnvSound(sprite[searchwall].lotag, searchwall);
|
S_StopEnvSound(sprite[searchwall].lotag, searchwall);
|
||||||
}
|
}
|
||||||
asksave = 1;
|
asksave = 1;
|
||||||
|
@ -6196,9 +6199,9 @@ static void Keys3d(void)
|
||||||
sprite[searchwall].lotag =
|
sprite[searchwall].lotag =
|
||||||
_getnumber256("Sprite lotag: ", sprite[searchwall].lotag, BTAG_MAX, 0+j, &MusicAndSFXTagText);
|
_getnumber256("Sprite lotag: ", sprite[searchwall].lotag, BTAG_MAX, 0+j, &MusicAndSFXTagText);
|
||||||
|
|
||||||
if ((sprite[searchwall].filler&1) && sprite[searchwall].lotag != oldtag)
|
if (testbit(g_ambiencePlaying, searchwall) && sprite[searchwall].lotag != oldtag)
|
||||||
{
|
{
|
||||||
sprite[searchwall].filler &= ~1;
|
clearbit(g_ambiencePlaying, searchwall);
|
||||||
S_StopEnvSound(oldtag, searchwall);
|
S_StopEnvSound(oldtag, searchwall);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue