Minor refactor: Handle *sep entirely within S_AdjustSoundParams, instead of having a component partly outside.

This commit is contained in:
toaster 2022-04-18 17:13:27 +01:00
parent 64189da28f
commit 91a424a034

View file

@ -580,11 +580,6 @@ void S_StartSoundAtVolume(const void *origin_p, sfxenum_t sfx_id, INT32 volume)
if (listenmobj[i])
{
audible = S_AdjustSoundParams(listenmobj[i], origin, &volume, &sep, &pitch, sfx);
if (origin->x == listener[i].x && origin->y == listener[i].y)
{
sep = NORM_SEP;
}
}
if (!audible)
@ -895,11 +890,6 @@ void S_UpdateSounds(void)
&volume, &sep, &pitch,
c->sfxinfo
);
if (origin->x == listener[i].x && origin->y == listener[i].y)
{
sep = NORM_SEP;
}
}
if (audible)
@ -1009,7 +999,6 @@ boolean S_AdjustSoundParams(const mobj_t *listener, const mobj_t *source, INT32
const boolean reverse = (stereoreverse.value ^ encoremode);
fixed_t approx_dist;
angle_t angle;
listener_t listensource;
INT32 i;
@ -1087,8 +1076,14 @@ boolean S_AdjustSoundParams(const mobj_t *listener, const mobj_t *source, INT32
if (approx_dist > S_CLIPPING_DIST)
return false;
if (source->x == listensource.x && source->y == listensource.y)
{
*sep = NORM_SEP;
}
else
{
// angle of source to listener
angle = R_PointToAngle2(listensource.x, listensource.y, source->x, source->y);
angle_t angle = R_PointToAngle2(listensource.x, listensource.y, source->x, source->y);
if (angle > listensource.angle)
angle = angle - listensource.angle;
@ -1110,6 +1105,7 @@ boolean S_AdjustSoundParams(const mobj_t *listener, const mobj_t *source, INT32
// stereo separation
*sep = 128 - (FixedMul(S_STEREO_SWING, FINESINE(angle))>>FRACBITS);
}
}
// volume calculation
/* not sure if it should be > (no =), but this matches the old behavior */