mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 08:50:55 +00:00
Sound cleanups
git-svn-id: https://svn.eduke32.com/eduke32@7915 1a8010ca-5511-0410-912e-c29ae57300e0 # Conflicts: # source/duke3d/src/sounds.h
This commit is contained in:
parent
48f9edf743
commit
b7f349cd92
2 changed files with 62 additions and 57 deletions
|
@ -30,17 +30,18 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#define DQSIZE 256
|
#define DQSIZE 256
|
||||||
|
|
||||||
int32_t g_numEnvSoundsPlaying, g_highestSoundIdx = 0;
|
int32_t g_numEnvSoundsPlaying, g_highestSoundIdx;
|
||||||
|
|
||||||
static int32_t MusicIsWaveform = 0;
|
static char *MusicPtr;
|
||||||
static char *MusicPtr = NULL;
|
|
||||||
|
static int32_t MusicIsWaveform;
|
||||||
static int32_t MusicVoice = -1;
|
static int32_t MusicVoice = -1;
|
||||||
static bool MusicPaused = false;
|
|
||||||
static bool SoundPaused = false;
|
|
||||||
|
|
||||||
std::atomic<uint32_t> dnum;
|
static bool MusicPaused;
|
||||||
uint32_t dq[DQSIZE];
|
static bool SoundPaused;
|
||||||
static mutex_t m_callback;
|
|
||||||
|
std::atomic<uint32_t> dnum, dq[DQSIZE];
|
||||||
|
// static mutex_t m_callback;
|
||||||
|
|
||||||
static inline void S_SetProperties(assvoice_t *snd, int const owner, int const voice, int const dist, int const clock)
|
static inline void S_SetProperties(assvoice_t *snd, int const owner, int const voice, int const dist, int const clock)
|
||||||
{
|
{
|
||||||
|
@ -88,7 +89,7 @@ void S_SoundStartup(void)
|
||||||
S_MusicVolume(ud.config.MusicVolume);
|
S_MusicVolume(ud.config.MusicVolume);
|
||||||
|
|
||||||
FX_SetReverseStereo(ud.config.ReverseStereo);
|
FX_SetReverseStereo(ud.config.ReverseStereo);
|
||||||
mutex_init(&m_callback);
|
// mutex_init(&m_callback);
|
||||||
FX_SetCallBack(S_Callback);
|
FX_SetCallBack(S_Callback);
|
||||||
FX_SetPrintf(OSD_Printf);
|
FX_SetPrintf(OSD_Printf);
|
||||||
}
|
}
|
||||||
|
@ -387,7 +388,7 @@ void S_StopMusic(void)
|
||||||
|
|
||||||
void S_Cleanup(void)
|
void S_Cleanup(void)
|
||||||
{
|
{
|
||||||
static uint32_t ldnum;
|
static uint32_t ldnum = 0;
|
||||||
|
|
||||||
while (ldnum < dnum)
|
while (ldnum < dnum)
|
||||||
{
|
{
|
||||||
|
@ -396,8 +397,10 @@ void S_Cleanup(void)
|
||||||
// negative index is RTS playback
|
// negative index is RTS playback
|
||||||
if ((int32_t)num < 0)
|
if ((int32_t)num < 0)
|
||||||
{
|
{
|
||||||
if (rts_lumplockbyte[-(int32_t)num] >= 200)
|
int const rtsindex = klabs((int32_t)num);
|
||||||
rts_lumplockbyte[-(int32_t)num]--;
|
|
||||||
|
if (rts_lumplockbyte[rtsindex] >= 200)
|
||||||
|
--rts_lumplockbyte[rtsindex];
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -411,19 +414,18 @@ void S_Cleanup(void)
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
int const vidx = num & (MAXSOUNDINSTANCES - 1);
|
int const voiceindex = num & (MAXSOUNDINSTANCES - 1);
|
||||||
|
|
||||||
num = (num - vidx) / MAXSOUNDINSTANCES;
|
num = (num - voiceindex) / MAXSOUNDINSTANCES;
|
||||||
|
|
||||||
auto &snd = g_sounds[num];
|
auto &snd = g_sounds[num];
|
||||||
auto &voice = g_sounds[num].voices[vidx];
|
auto &voice = snd.voices[voiceindex];
|
||||||
|
|
||||||
int const spriteNum = voice.owner;
|
int const spriteNum = voice.owner;
|
||||||
|
|
||||||
if (EDUKE32_PREDICT_FALSE(snd.num > MAXSOUNDINSTANCES))
|
if (EDUKE32_PREDICT_FALSE(snd.num > MAXSOUNDINSTANCES))
|
||||||
OSD_Printf(OSD_ERROR "S_Cleanup(): num exceeds MAXSOUNDINSTANCES! g_sounds[%d].num %d wtf?\n", num, snd.num);
|
OSD_Printf(OSD_ERROR "S_Cleanup(): num exceeds MAXSOUNDINSTANCES! g_sounds[%d].num %d wtf?\n", num, snd.num);
|
||||||
|
else if (snd.num > 0)
|
||||||
if (snd.num > 0)
|
|
||||||
--snd.num;
|
--snd.num;
|
||||||
|
|
||||||
// MUSICANDSFX uses t_data[0] to control restarting the sound
|
// MUSICANDSFX uses t_data[0] to control restarting the sound
|
||||||
|
@ -467,7 +469,8 @@ int32_t S_LoadSound(int num)
|
||||||
|
|
||||||
void cacheAllSounds(void)
|
void cacheAllSounds(void)
|
||||||
{
|
{
|
||||||
for (int32_t i = 0, j = 0; i <= g_highestSoundIdx; ++i)
|
for (int i=0, j=0; i <= g_highestSoundIdx; ++i)
|
||||||
|
{
|
||||||
if (g_sounds[i].ptr == 0)
|
if (g_sounds[i].ptr == 0)
|
||||||
{
|
{
|
||||||
j++;
|
j++;
|
||||||
|
@ -476,6 +479,7 @@ void cacheAllSounds(void)
|
||||||
|
|
||||||
S_LoadSound(i);
|
S_LoadSound(i);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int S_GetPitch(int num)
|
static inline int S_GetPitch(int num)
|
||||||
|
@ -540,12 +544,10 @@ static inline int S_GetAngle(int ang, const vec3_t *cam, const vec3_t *pos)
|
||||||
return (2048 + ang - getangle(cam->x - pos->x, cam->y - pos->y)) & 2047;
|
return (2048 + ang - getangle(cam->x - pos->x, cam->y - pos->y)) & 2047;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool S_CalcDistAndAng(int32_t spriteNum, int32_t soundNum, int32_t sectNum, int32_t angle,
|
static int S_CalcDistAndAng(int spriteNum, int soundNum, int sectNum, int angle,
|
||||||
const vec3_t *cam, const vec3_t *pos,
|
const vec3_t *cam, const vec3_t *pos, int *distPtr, int *angPtr)
|
||||||
int32_t *distPtr, int32_t *angPtr)
|
|
||||||
{
|
{
|
||||||
int32_t sndang = 0, sndist = 0;
|
int sndang = 0, sndist = 0, explosion = 0;
|
||||||
bool explosion = false;
|
|
||||||
|
|
||||||
if (PN(spriteNum) == APLAYER && P_Get(spriteNum) == screenpeek)
|
if (PN(spriteNum) == APLAYER && P_Get(spriteNum) == screenpeek)
|
||||||
goto sound_further_processing;
|
goto sound_further_processing;
|
||||||
|
@ -590,13 +592,19 @@ sound_further_processing:
|
||||||
if (sndist < 0)
|
if (sndist < 0)
|
||||||
sndist = 0;
|
sndist = 0;
|
||||||
|
|
||||||
if (sectNum > -1 && sndist && PN(spriteNum) != MUSICANDSFX
|
#ifndef EDUKE32_STANDALONE
|
||||||
|
if (!FURY && sectNum > -1 && sndist && PN(spriteNum) != MUSICANDSFX
|
||||||
&& !cansee(cam->x, cam->y, cam->z - (24 << 8), sectNum, SX(spriteNum), SY(spriteNum), SZ(spriteNum) - (24 << 8), SECT(spriteNum)))
|
&& !cansee(cam->x, cam->y, cam->z - (24 << 8), sectNum, SX(spriteNum), SY(spriteNum), SZ(spriteNum) - (24 << 8), SECT(spriteNum)))
|
||||||
sndist += sndist>>5;
|
sndist += sndist>>5;
|
||||||
|
#else
|
||||||
|
UNREFERENCED_PARAMETER(sectNum);
|
||||||
|
#endif
|
||||||
|
|
||||||
if ((g_sounds[soundNum].m & (SF_GLOBAL|SF_DTAG)) == (SF_GLOBAL|SF_DTAG))
|
if ((g_sounds[soundNum].m & (SF_GLOBAL|SF_DTAG)) == (SF_GLOBAL|SF_DTAG))
|
||||||
{
|
{
|
||||||
|
#ifndef EDUKE32_STANDALONE
|
||||||
boost:
|
boost:
|
||||||
|
#endif
|
||||||
explosion = true;
|
explosion = true;
|
||||||
if (sndist > 6144)
|
if (sndist > 6144)
|
||||||
sndist = 6144;
|
sndist = 6144;
|
||||||
|
@ -815,17 +823,15 @@ int S_PlaySound(int num)
|
||||||
}
|
}
|
||||||
|
|
||||||
snd.num++;
|
snd.num++;
|
||||||
snd.voices[sndnum].owner = -1;
|
S_SetProperties(&snd.voices[sndnum], -1, voice, 255-LOUDESTVOLUME, 0);
|
||||||
snd.voices[sndnum].id = voice;
|
|
||||||
snd.voices[sndnum].dist = 255 - LOUDESTVOLUME;
|
|
||||||
snd.voices[sndnum].clock = 0;
|
|
||||||
|
|
||||||
return voice;
|
return voice;
|
||||||
}
|
}
|
||||||
|
|
||||||
int A_PlaySound(int soundNum, int spriteNum)
|
int A_PlaySound(int soundNum, int spriteNum)
|
||||||
{
|
{
|
||||||
if (EDUKE32_PREDICT_FALSE((unsigned)soundNum > (unsigned)g_highestSoundIdx)) return -1;
|
if (EDUKE32_PREDICT_FALSE((unsigned)soundNum > (unsigned)g_highestSoundIdx))
|
||||||
|
return -1;
|
||||||
|
|
||||||
return (unsigned)spriteNum >= MAXSPRITES ? S_PlaySound(soundNum) :
|
return (unsigned)spriteNum >= MAXSPRITES ? S_PlaySound(soundNum) :
|
||||||
S_PlaySound3D(soundNum, spriteNum, (vec3_t *)&sprite[spriteNum]);
|
S_PlaySound3D(soundNum, spriteNum, (vec3_t *)&sprite[spriteNum]);
|
||||||
|
@ -833,34 +839,35 @@ int A_PlaySound(int soundNum, int spriteNum)
|
||||||
|
|
||||||
void S_StopEnvSound(int32_t num, int32_t i)
|
void S_StopEnvSound(int32_t num, int32_t i)
|
||||||
{
|
{
|
||||||
if (EDUKE32_PREDICT_FALSE((unsigned)num > (unsigned)g_highestSoundIdx) || g_sounds[num].num <= 0)
|
if (EDUKE32_PREDICT_FALSE((unsigned)num > (unsigned)g_highestSoundIdx)
|
||||||
|
|| g_sounds[num].num <= 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
int32_t j;
|
S_Cleanup();
|
||||||
|
|
||||||
do
|
for (int j=0; j<MAXSOUNDINSTANCES; ++j)
|
||||||
{
|
{
|
||||||
for (j=0; j<MAXSOUNDINSTANCES; ++j)
|
auto &voice = g_sounds[num].voices[j];
|
||||||
{
|
|
||||||
S_Cleanup();
|
|
||||||
|
|
||||||
if ((i == -1 && g_sounds[num].voices[j].id > FX_Ok) || (i != -1 && g_sounds[num].voices[j].owner == i))
|
if ((i == -1 && voice.id > FX_Ok) || (i != -1 && voice.owner == i))
|
||||||
{
|
{
|
||||||
#ifdef DEBUGGINGAIDS
|
#ifdef DEBUGGINGAIDS
|
||||||
if (EDUKE32_PREDICT_FALSE(i >= 0 && g_sounds[num].voices[j].id <= FX_Ok))
|
if (EDUKE32_PREDICT_FALSE(i >= 0 && voice.id <= FX_Ok))
|
||||||
initprintf(OSD_ERROR "S_StopEnvSound(): bad voice %d for sound ID %d index %d!\n", g_sounds[num].voices[j].id, num, j);
|
initprintf(OSD_ERROR "S_StopEnvSound(): bad voice %d for sound ID %d index %d!\n", voice.id, num, j);
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
if (g_sounds[num].voices[j].id > FX_Ok)
|
if (voice.id > FX_Ok)
|
||||||
|
{
|
||||||
|
if (FX_SoundActive(voice.id))
|
||||||
{
|
{
|
||||||
if (FX_SoundActive(g_sounds[num].voices[j].id))
|
FX_StopSound(voice.id);
|
||||||
FX_StopSound(g_sounds[num].voices[j].id);
|
S_Cleanup();
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
j = 0;
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
while (j < MAXSOUNDINSTANCES);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Do not remove this or make it inline.
|
// Do not remove this or make it inline.
|
||||||
|
@ -937,7 +944,7 @@ void S_Update(void)
|
||||||
if ((unsigned)spriteNum >= MAXSPRITES || voice.id <= FX_Ok || !FX_SoundActive(voice.id))
|
if ((unsigned)spriteNum >= MAXSPRITES || voice.id <= FX_Ok || !FX_SoundActive(voice.id))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
int32_t sndist, sndang;
|
int sndist, sndang;
|
||||||
|
|
||||||
S_CalcDistAndAng(spriteNum, sndnum, cs, ca, c, (const vec3_t *)&sprite[spriteNum], &sndist, &sndang);
|
S_CalcDistAndAng(spriteNum, sndnum, cs, ca, c, (const vec3_t *)&sprite[spriteNum], &sndist, &sndang);
|
||||||
|
|
||||||
|
@ -959,11 +966,9 @@ void S_Callback(intptr_t num)
|
||||||
if (num == MUSIC_ID)
|
if (num == MUSIC_ID)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
mutex_lock(&m_callback);
|
// mutex_lock(&m_callback);
|
||||||
int const ldnum = dnum;
|
dq[dnum++ & (DQSIZE - 1)] = num;
|
||||||
dq[ldnum & (DQSIZE - 1)] = num;
|
// mutex_unlock(&m_callback);
|
||||||
dnum++;
|
|
||||||
mutex_unlock(&m_callback);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void S_ClearSoundLocks(void)
|
void S_ClearSoundLocks(void)
|
||||||
|
@ -984,7 +989,7 @@ void S_ClearSoundLocks(void)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
bool A_CheckSoundPlaying(int spriteNum, int soundNum)
|
int A_CheckSoundPlaying(int spriteNum, int soundNum)
|
||||||
{
|
{
|
||||||
if (EDUKE32_PREDICT_FALSE((unsigned)soundNum > (unsigned)g_highestSoundIdx)) return 0;
|
if (EDUKE32_PREDICT_FALSE((unsigned)soundNum > (unsigned)g_highestSoundIdx)) return 0;
|
||||||
|
|
||||||
|
@ -999,7 +1004,7 @@ bool A_CheckSoundPlaying(int spriteNum, int soundNum)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check if actor <i> is playing any sound.
|
// Check if actor <i> is playing any sound.
|
||||||
bool A_CheckAnySoundPlaying(int spriteNum)
|
int A_CheckAnySoundPlaying(int spriteNum)
|
||||||
{
|
{
|
||||||
int const msp = g_highestSoundIdx;
|
int const msp = g_highestSoundIdx;
|
||||||
|
|
||||||
|
@ -1013,7 +1018,7 @@ bool A_CheckAnySoundPlaying(int spriteNum)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool S_CheckSoundPlaying(int soundNum)
|
int S_CheckSoundPlaying(int soundNum)
|
||||||
{
|
{
|
||||||
if (EDUKE32_PREDICT_FALSE((unsigned)soundNum > (unsigned)g_highestSoundIdx)) return false;
|
if (EDUKE32_PREDICT_FALSE((unsigned)soundNum > (unsigned)g_highestSoundIdx)) return false;
|
||||||
return (g_sounds[soundNum].num != 0);
|
return (g_sounds[soundNum].num != 0);
|
||||||
|
|
|
@ -63,11 +63,11 @@ extern char g_soundlocks[MAXSOUNDS];
|
||||||
extern sound_t g_sounds[MAXSOUNDS];
|
extern sound_t g_sounds[MAXSOUNDS];
|
||||||
extern int32_t g_numEnvSoundsPlaying,g_highestSoundIdx;
|
extern int32_t g_numEnvSoundsPlaying,g_highestSoundIdx;
|
||||||
|
|
||||||
bool A_CheckSoundPlaying(int spriteNum,int soundNum);
|
int A_CheckSoundPlaying(int spriteNum,int soundNum);
|
||||||
int A_PlaySound(int soundNum, int spriteNum);
|
int A_PlaySound(int soundNum, int spriteNum);
|
||||||
void S_Callback(intptr_t num);
|
void S_Callback(intptr_t num);
|
||||||
bool A_CheckAnySoundPlaying(int spriteNum);
|
int A_CheckAnySoundPlaying(int spriteNum);
|
||||||
bool S_CheckSoundPlaying(int soundNum);
|
int S_CheckSoundPlaying(int soundNum);
|
||||||
void S_Cleanup(void);
|
void S_Cleanup(void);
|
||||||
void S_ClearSoundLocks(void);
|
void S_ClearSoundLocks(void);
|
||||||
int32_t S_LoadSound(uint32_t num);
|
int32_t S_LoadSound(uint32_t num);
|
||||||
|
|
Loading…
Reference in a new issue