Fixes to MusicManager
This commit is contained in:
parent
dff49e9c23
commit
ec2f4fde93
1 changed files with 42 additions and 47 deletions
|
@ -88,7 +88,7 @@ cMusicManager::ResetMusicAfterReload()
|
||||||
field_3995 = false;
|
field_3995 = false;
|
||||||
field_3996 = false;
|
field_3996 = false;
|
||||||
field_3997 = false;
|
field_3997 = false;
|
||||||
field_3998 = -1;
|
nFramesSinceCutsceneEnded = -1;
|
||||||
field_3999 = false;
|
field_3999 = false;
|
||||||
field_399A = false;
|
field_399A = false;
|
||||||
field_399C = false;
|
field_399C = false;
|
||||||
|
@ -195,7 +195,7 @@ cMusicManager::Initialise()
|
||||||
field_3995 = false;
|
field_3995 = false;
|
||||||
field_3996 = false;
|
field_3996 = false;
|
||||||
field_3997 = false;
|
field_3997 = false;
|
||||||
field_3998 = -1;
|
nFramesSinceCutsceneEnded = -1;
|
||||||
field_3999 = false;
|
field_3999 = false;
|
||||||
field_399A = false;
|
field_399A = false;
|
||||||
m_nMusicModeToBeSet = MUSICMODE_DISABLED;
|
m_nMusicModeToBeSet = MUSICMODE_DISABLED;
|
||||||
|
@ -507,7 +507,7 @@ cMusicManager::ServiceGameMode()
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!field_3996) {
|
if (!field_3996) {
|
||||||
field_3998 = -1;
|
nFramesSinceCutsceneEnded = -1;
|
||||||
gNumRetunePresses = 0;
|
gNumRetunePresses = 0;
|
||||||
gRetuneCounter = 0;
|
gRetuneCounter = 0;
|
||||||
field_2 = false;
|
field_2 = false;
|
||||||
|
@ -867,7 +867,7 @@ cMusicManager::ServiceTrack(CVehicle *veh, CPed *ped)
|
||||||
{
|
{
|
||||||
static bool bRadioStatsRecorded = false;
|
static bool bRadioStatsRecorded = false;
|
||||||
static bool bRadioStatsRecorded2 = false;
|
static bool bRadioStatsRecorded2 = false;
|
||||||
uint8 AmbienceVol;
|
uint8 volume;
|
||||||
if (!field_398F)
|
if (!field_398F)
|
||||||
m_nStreamedTrack = m_nFrontendTrack;
|
m_nStreamedTrack = m_nFrontendTrack;
|
||||||
if (gRetuneCounter != 0 || field_2) {
|
if (gRetuneCounter != 0 || field_2) {
|
||||||
|
@ -920,8 +920,8 @@ cMusicManager::ServiceTrack(CVehicle *veh, CPed *ped)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ComputeAmbienceVol(true, AmbienceVol);
|
ComputeAmbienceVol(true, volume);
|
||||||
SampleManager.SetStreamedVolumeAndPan(AmbienceVol, 63, 1, 0);
|
SampleManager.SetStreamedVolumeAndPan(volume, 63, 1, 0);
|
||||||
}
|
}
|
||||||
if (m_nStreamedTrack < STREAMED_SOUND_CITY_AMBIENT)
|
if (m_nStreamedTrack < STREAMED_SOUND_CITY_AMBIENT)
|
||||||
m_nLastTrackServiceTime = CTimer::GetTimeInMillisecondsPauseMode();
|
m_nLastTrackServiceTime = CTimer::GetTimeInMillisecondsPauseMode();
|
||||||
|
@ -952,8 +952,8 @@ cMusicManager::ServiceTrack(CVehicle *veh, CPed *ped)
|
||||||
|
|
||||||
if (m_nPlayingTrack >= STREAMED_SOUND_CITY_AMBIENT && m_nPlayingTrack <= STREAMED_SOUND_AMBSIL_AMBIENT)
|
if (m_nPlayingTrack >= STREAMED_SOUND_CITY_AMBIENT && m_nPlayingTrack <= STREAMED_SOUND_AMBSIL_AMBIENT)
|
||||||
{
|
{
|
||||||
ComputeAmbienceVol(false, AmbienceVol);
|
ComputeAmbienceVol(false, volume);
|
||||||
SampleManager.SetStreamedVolumeAndPan(AmbienceVol, 63, 1, 0);
|
SampleManager.SetStreamedVolumeAndPan(volume, 63, 1, 0);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (CTimer::GetIsSlowMotionActive())
|
if (CTimer::GetIsSlowMotionActive())
|
||||||
|
@ -967,57 +967,51 @@ cMusicManager::ServiceTrack(CVehicle *veh, CPed *ped)
|
||||||
}
|
}
|
||||||
else if (DistToTargetSq >= SQR(10.0f))
|
else if (DistToTargetSq >= SQR(10.0f))
|
||||||
{
|
{
|
||||||
AmbienceVol = (45.0f - (Sqrt(DistToTargetSq) - 10.0f)) / 45.0f * m_nCurrentVolume;
|
volume = (45.0f - (Sqrt(DistToTargetSq) - 10.0f)) / 45.0f * m_nCurrentVolume;
|
||||||
if (AudioManager.ShouldDuckMissionAudio(0) || AudioManager.ShouldDuckMissionAudio(1))
|
if (AudioManager.ShouldDuckMissionAudio(0) || AudioManager.ShouldDuckMissionAudio(1))
|
||||||
AmbienceVol /= 4;
|
volume /= 4;
|
||||||
|
|
||||||
uint8 pan = 0;
|
uint8 pan = 0;
|
||||||
if (AmbienceVol > 0)
|
if (volume > 0)
|
||||||
{
|
{
|
||||||
CVector panVec;
|
CVector panVec;
|
||||||
AudioManager.TranslateEntity(&TheCamera.pTargetEntity->GetPosition(), &panVec);
|
AudioManager.TranslateEntity(&TheCamera.pTargetEntity->GetPosition(), &panVec);
|
||||||
pan = AudioManager.ComputePan(55.0f, &panVec);
|
pan = AudioManager.ComputePan(55.0f, &panVec);
|
||||||
}
|
}
|
||||||
if (gRetuneCounter != 0)
|
if (gRetuneCounter != 0)
|
||||||
AmbienceVol = 0;
|
volume = 0;
|
||||||
SampleManager.SetStreamedVolumeAndPan(AmbienceVol, pan, 0, 0);
|
SampleManager.SetStreamedVolumeAndPan(volume, pan, 0, 0);
|
||||||
}
|
|
||||||
else if (!AudioManager.ShouldDuckMissionAudio(0) && !AudioManager.ShouldDuckMissionAudio(1))
|
|
||||||
{
|
|
||||||
if (gRetuneCounter == 0)
|
|
||||||
SampleManager.SetStreamedVolumeAndPan(m_nCurrentVolume, 63, 0, 0);
|
|
||||||
else
|
|
||||||
SampleManager.SetStreamedVolumeAndPan(0, 63, 0, 0);
|
|
||||||
}
|
}
|
||||||
|
else if (AudioManager.ShouldDuckMissionAudio(0) || AudioManager.ShouldDuckMissionAudio(1))
|
||||||
|
SampleManager.SetStreamedVolumeAndPan(m_nCurrentVolume, 63, 0, 0);
|
||||||
|
else if (gRetuneCounter != 0)
|
||||||
|
SampleManager.SetStreamedVolumeAndPan(0, 63, 0, 0);
|
||||||
else
|
else
|
||||||
SampleManager.SetStreamedVolumeAndPan(m_nCurrentVolume, 63, 0, 0);
|
SampleManager.SetStreamedVolumeAndPan(m_nCurrentVolume, 63, 0, 0);
|
||||||
}
|
}
|
||||||
}
|
} else if (AudioManager.ShouldDuckMissionAudio(0) || AudioManager.ShouldDuckMissionAudio(1)) {
|
||||||
else
|
SampleManager.SetStreamedVolumeAndPan(Min(m_nCurrentVolume, 25), 63, 0, 0);
|
||||||
{
|
} else {
|
||||||
if (!AudioManager.ShouldDuckMissionAudio(0) && !AudioManager.ShouldDuckMissionAudio(1)) {
|
if (nFramesSinceCutsceneEnded == -1)
|
||||||
if (field_3998 == -1)
|
volume = m_nCurrentVolume;
|
||||||
AmbienceVol = m_nCurrentVolume;
|
else if (nFramesSinceCutsceneEnded < 20)
|
||||||
else if (field_3998 < 20)
|
{
|
||||||
{
|
volume = Min(m_nCurrentVolume, 25);
|
||||||
AmbienceVol = Min(m_nCurrentVolume, 25);
|
nFramesSinceCutsceneEnded++;
|
||||||
field_3998++;
|
}
|
||||||
}
|
else if (nFramesSinceCutsceneEnded < 40)
|
||||||
else if (field_3998 < 40)
|
{
|
||||||
{
|
volume = Min(m_nCurrentVolume, 3 * (nFramesSinceCutsceneEnded - 20) + 25);
|
||||||
AmbienceVol = Min(m_nCurrentVolume, 3 * (field_3998 - 20) + 25);
|
nFramesSinceCutsceneEnded++;
|
||||||
field_3998++;
|
}
|
||||||
}
|
else
|
||||||
else
|
{
|
||||||
{
|
volume = m_nCurrentVolume;
|
||||||
AmbienceVol = m_nCurrentVolume;
|
nFramesSinceCutsceneEnded = -1;
|
||||||
field_3998 = -1;
|
}
|
||||||
}
|
if (gRetuneCounter != 0)
|
||||||
if (gRetuneCounter != 0)
|
volume = 0;
|
||||||
AmbienceVol = 0;
|
SampleManager.SetStreamedVolumeAndPan(volume, 63, 0, 0);
|
||||||
SampleManager.SetStreamedVolumeAndPan(AmbienceVol, 63, 0, 0);
|
|
||||||
} else
|
|
||||||
SampleManager.SetStreamedVolumeAndPan(Min(m_nCurrentVolume, 25), 63, 0, 0);
|
|
||||||
}
|
}
|
||||||
if (m_nVolumeLatency > 0)
|
if (m_nVolumeLatency > 0)
|
||||||
m_nVolumeLatency--;
|
m_nVolumeLatency--;
|
||||||
|
@ -1115,7 +1109,8 @@ cMusicManager::GetListenTimeArray()
|
||||||
return aListenTimeArray;
|
return aListenTimeArray;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32 cMusicManager::GetTrackStartPos(uint32 track)
|
uint32
|
||||||
|
cMusicManager::GetTrackStartPos(uint32 track)
|
||||||
{
|
{
|
||||||
if (!IsInitialised()) return 0;
|
if (!IsInitialised()) return 0;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue