ProcessActiveQueues
This commit is contained in:
parent
a04d8f24be
commit
113abec6fa
@ -103,21 +103,22 @@ char &g_nMissionAudioPlayingStatus = *(char *)0x60ED88;
|
|||||||
void
|
void
|
||||||
cAudioManager::AddDetailsToRequestedOrderList(uint8 sample)
|
cAudioManager::AddDetailsToRequestedOrderList(uint8 sample)
|
||||||
{
|
{
|
||||||
int32 offset;
|
|
||||||
uint32 i = 0;
|
uint32 i = 0;
|
||||||
if(sample != 0) {
|
if(sample != 0) {
|
||||||
for(; i < sample; i++) {
|
for(; i < sample; i++) {
|
||||||
offset = 27 * m_bActiveSampleQueue;
|
if(m_asSamples[m_bActiveSampleQueue]
|
||||||
if(m_asSamples[offset + m_abSampleQueueIndexTable[i + offset]]
|
[m_abSampleQueueIndexTable[m_bActiveSampleQueue][i]]
|
||||||
.calculatedVolume > m_asSamples[offset + sample].calculatedVolume)
|
.calculatedVolume >
|
||||||
|
m_asSamples[m_bActiveSampleQueue][sample].calculatedVolume)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if(i < sample) {
|
if(i < sample) {
|
||||||
memmove(&m_abSampleQueueIndexTable[offset + 1 + i],
|
memmove(&m_abSampleQueueIndexTable[m_bActiveSampleQueue][i + 1],
|
||||||
&m_abSampleQueueIndexTable[offset + i], m_bActiveSamples - i - 1);
|
&m_abSampleQueueIndexTable[m_bActiveSampleQueue][i],
|
||||||
|
m_bActiveSamples - i - 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
m_abSampleQueueIndexTable[27 * m_bActiveSampleQueue + i] = sample;
|
m_abSampleQueueIndexTable[m_bActiveSampleQueue][i] = sample;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -193,7 +194,7 @@ cAudioManager::AddReflectionsToRequestedQueue()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#if 0
|
#if 1
|
||||||
WRAPPER void
|
WRAPPER void
|
||||||
cAudioManager::AddReleasingSounds()
|
cAudioManager::AddReleasingSounds()
|
||||||
{
|
{
|
||||||
@ -271,17 +272,17 @@ cAudioManager::AddSampleToRequestedQueue()
|
|||||||
{
|
{
|
||||||
int32 calculatedVolume;
|
int32 calculatedVolume;
|
||||||
tActiveSample *sample;
|
tActiveSample *sample;
|
||||||
int32 unknown1;
|
uint8 sampleIndex;
|
||||||
uint8 unknown2;
|
|
||||||
bool bReflections;
|
bool bReflections;
|
||||||
|
|
||||||
if(m_sQueueSample.m_nSampleIndex < TOTAL_AUDIO_SAMPLES) {
|
if(m_sQueueSample.m_nSampleIndex < TOTAL_AUDIO_SAMPLES) {
|
||||||
calculatedVolume = m_sQueueSample.field_16 * (maxVolume - m_sQueueSample.m_bVolume);
|
calculatedVolume = m_sQueueSample.field_16 * (maxVolume - m_sQueueSample.m_bVolume);
|
||||||
unknown2 = m_bSampleRequestQueuesStatus[m_bActiveSampleQueue];
|
sampleIndex = m_bSampleRequestQueuesStatus[m_bActiveSampleQueue];
|
||||||
if(unknown2 >= m_bActiveSamples) {
|
if(sampleIndex >= m_bActiveSamples) {
|
||||||
unknown1 = 27 * m_bActiveSampleQueue;
|
sampleIndex = *(&m_asSamples[1][26].field_91 + m_bActiveSamples +
|
||||||
unknown2 = *(&m_asSamples[53].field_91 + m_bActiveSamples + unknown1);
|
27 * m_bActiveSampleQueue);
|
||||||
if(m_asSamples[unknown1 + unknown2].calculatedVolume <= calculatedVolume)
|
if(m_asSamples[m_bActiveSampleQueue][sampleIndex].calculatedVolume <=
|
||||||
|
calculatedVolume)
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
++m_bSampleRequestQueuesStatus[m_bActiveSampleQueue];
|
++m_bSampleRequestQueuesStatus[m_bActiveSampleQueue];
|
||||||
@ -302,7 +303,7 @@ cAudioManager::AddSampleToRequestedQueue()
|
|||||||
|
|
||||||
if(!m_bDynamicAcousticModelingStatus) m_sQueueSample.m_bReverbFlag = 0;
|
if(!m_bDynamicAcousticModelingStatus) m_sQueueSample.m_bReverbFlag = 0;
|
||||||
|
|
||||||
sample = &m_asSamples[27 * m_bActiveSampleQueue + unknown2];
|
sample = &m_asSamples[m_bActiveSampleQueue][sampleIndex];
|
||||||
sample->m_nEntityIndex = m_sQueueSample.m_nEntityIndex;
|
sample->m_nEntityIndex = m_sQueueSample.m_nEntityIndex;
|
||||||
sample->field_4 = m_sQueueSample.field_4;
|
sample->field_4 = m_sQueueSample.field_4;
|
||||||
sample->m_nSampleIndex = m_sQueueSample.m_nSampleIndex;
|
sample->m_nSampleIndex = m_sQueueSample.m_nSampleIndex;
|
||||||
@ -330,7 +331,7 @@ cAudioManager::AddSampleToRequestedQueue()
|
|||||||
sample->calculatedVolume = m_sQueueSample.calculatedVolume;
|
sample->calculatedVolume = m_sQueueSample.calculatedVolume;
|
||||||
sample->field_88 = m_sQueueSample.field_88;
|
sample->field_88 = m_sQueueSample.field_88;
|
||||||
|
|
||||||
AddDetailsToRequestedOrderList(unknown2);
|
AddDetailsToRequestedOrderList(sampleIndex);
|
||||||
if(bReflections) AddReflectionsToRequestedQueue();
|
if(bReflections) AddReflectionsToRequestedQueue();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -383,7 +384,7 @@ void
|
|||||||
cAudioManager::ClearRequestedQueue()
|
cAudioManager::ClearRequestedQueue()
|
||||||
{
|
{
|
||||||
for(int32 i = 0; i < m_bActiveSamples; i++) {
|
for(int32 i = 0; i < m_bActiveSamples; i++) {
|
||||||
m_abSampleQueueIndexTable[i + 27 * m_bActiveSampleQueue] = m_bActiveSamples;
|
m_abSampleQueueIndexTable[m_bActiveSampleQueue][i] = m_bActiveSamples;
|
||||||
}
|
}
|
||||||
m_bSampleRequestQueuesStatus[m_bActiveSampleQueue] = 0;
|
m_bSampleRequestQueuesStatus[m_bActiveSampleQueue] = 0;
|
||||||
}
|
}
|
||||||
@ -554,6 +555,21 @@ cAudioManager::GetDistanceSquared(CVector *v)
|
|||||||
return sq(v->x - c.x) + sq(v->y - c.y) + sq((v->z - c.z) * 0.2f);
|
return sq(v->x - c.x) + sq(v->y - c.y) + sq((v->z - c.z) * 0.2f);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
cAudioManager::TranslateEntity(CVector *v1, CVector *v2)
|
||||||
|
{
|
||||||
|
const RwMatrix &cM = TheCamera.GetMatrix().m_matrix;
|
||||||
|
const CVector &cV = TheCamera.GetPosition();
|
||||||
|
|
||||||
|
float a = v1->z - cV.z;
|
||||||
|
float b = v1->y - cV.y;
|
||||||
|
float c = v1->x - cV.x;
|
||||||
|
|
||||||
|
v2->x = cM.right.y * b + cM.right.x * c + cM.right.z * a;
|
||||||
|
v2->y = cM.up.y * b + cM.up.x * c + cM.up.z * a;
|
||||||
|
v2->z = cM.at.y * b + cM.at.x * c + cM.at.z * a;
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
cAudioManager::Initialise()
|
cAudioManager::Initialise()
|
||||||
{
|
{
|
||||||
@ -3118,6 +3134,8 @@ cAudioManager::GetGenericFemaleTalkSfx(int16 sound)
|
|||||||
return sfx;
|
return sfx;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if 1
|
||||||
|
|
||||||
WRAPPER
|
WRAPPER
|
||||||
void
|
void
|
||||||
cAudioManager::ProcessActiveQueues()
|
cAudioManager::ProcessActiveQueues()
|
||||||
@ -3125,6 +3143,320 @@ cAudioManager::ProcessActiveQueues()
|
|||||||
EAXJMP(0x57BA60);
|
EAXJMP(0x57BA60);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
void
|
||||||
|
cAudioManager::ProcessActiveQueues()
|
||||||
|
{
|
||||||
|
int v3; // ecx
|
||||||
|
cAudioManager *v4; // edx
|
||||||
|
tActiveSample *v5; // ebx
|
||||||
|
cAudioManager *v6; // edi
|
||||||
|
tActiveSample *v7; // esi
|
||||||
|
char v8; // al
|
||||||
|
unsigned __int8 v9; // dl
|
||||||
|
double v10; // st7
|
||||||
|
double v11; // st6
|
||||||
|
float a4; // ST08_4
|
||||||
|
float a3; // ST04_4
|
||||||
|
int activeSampleFreq; // ecx
|
||||||
|
int freq; // edi
|
||||||
|
int newFreq; // ecx
|
||||||
|
int v17; // eax
|
||||||
|
char v18; // al
|
||||||
|
unsigned __int8 v19; // al
|
||||||
|
float v20; // ST0C_4
|
||||||
|
int v21; // edx
|
||||||
|
unsigned __int8 v22; // bl
|
||||||
|
cAudioManager *v23; // ebp
|
||||||
|
int v24; // ecx
|
||||||
|
cAudioManager *v25; // edx
|
||||||
|
tActiveSample *v26; // ebx
|
||||||
|
cAudioManager *v27; // ebp
|
||||||
|
unsigned int v28; // edi
|
||||||
|
unsigned int v29; // eax
|
||||||
|
unsigned __int8 v30; // cl
|
||||||
|
double v31; // st4
|
||||||
|
double v32; // st7
|
||||||
|
double v33; // st6
|
||||||
|
double v34; // st5
|
||||||
|
float v35; // ST0C_4
|
||||||
|
float v36; // ST08_4
|
||||||
|
float v37; // ST04_4
|
||||||
|
float v38; // ST0C_4
|
||||||
|
int v39; // edx
|
||||||
|
int v40; // [esp+Ch] [ebp-58h]
|
||||||
|
int v41; // [esp+Ch] [ebp-58h]
|
||||||
|
unsigned int v42; // [esp+10h] [ebp-54h]
|
||||||
|
int v43; // [esp+10h] [ebp-54h]
|
||||||
|
char v44; // [esp+14h] [ebp-50h]
|
||||||
|
unsigned __int8 v45; // [esp+14h] [ebp-50h]
|
||||||
|
unsigned __int8 l; // [esp+24h] [ebp-40h]
|
||||||
|
unsigned __int8 j; // [esp+28h] [ebp-3Ch]
|
||||||
|
unsigned __int8 k; // [esp+34h] [ebp-30h]
|
||||||
|
unsigned __int8 i; // [esp+38h] [ebp-2Ch]
|
||||||
|
CVector a2; // [esp+48h] [ebp-1Ch]
|
||||||
|
|
||||||
|
for(uint32 i = 0; i < m_bActiveSamples; i++) {
|
||||||
|
m_asSamples[m_bActiveSampleQueue][i].m_bIsProcessed = 0;
|
||||||
|
m_asActiveSamples[i].m_bIsProcessed = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
for(i = 0;; ++i) {
|
||||||
|
v21 = m_bActiveSampleQueue;
|
||||||
|
if(i >= m_bSampleRequestQueuesStatus[v21]) break;
|
||||||
|
v3 = i + 27 * v21;
|
||||||
|
v4 = (this + 2484 * v21);
|
||||||
|
v5 = &v4->m_asSamples[m_abSampleQueueIndexTable[v3]];
|
||||||
|
if(v4->m_asSamples[m_abSampleQueueIndexTable[v3]].m_nSampleIndex != NO_SAMPLE) {
|
||||||
|
v6 = this;
|
||||||
|
for(j = 0;; ++j) {
|
||||||
|
if(j >= m_bActiveSamples) goto LABEL_58;
|
||||||
|
v7 = m_asActiveSamples;
|
||||||
|
if(v5->m_nEntityIndex == m_asActiveSamples[0].m_nEntityIndex &&
|
||||||
|
v5->field_4 == m_asActiveSamples[0].field_4 &&
|
||||||
|
v5->m_nSampleIndex == m_asActiveSamples[0].m_nSampleIndex) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
LABEL_56:
|
||||||
|
v6 = (v6 + 92);
|
||||||
|
}
|
||||||
|
if(v5->m_nLoopCount) {
|
||||||
|
if(m_nTimeOfRecentCrime & 1) {
|
||||||
|
if(!(j & 1)) {
|
||||||
|
v8 = 0;
|
||||||
|
goto LABEL_17;
|
||||||
|
}
|
||||||
|
LABEL_16:
|
||||||
|
v8 = 1;
|
||||||
|
} else {
|
||||||
|
if(!(j & 1)) goto LABEL_16;
|
||||||
|
v8 = 0;
|
||||||
|
}
|
||||||
|
LABEL_17:
|
||||||
|
if(v8 && !cSampleManager.GetChannelUsedFlag(j)) {
|
||||||
|
v5->m_bLoopEnded = 1;
|
||||||
|
m_asActiveSamples[0].m_bLoopEnded = 1;
|
||||||
|
m_asActiveSamples[0].m_nSampleIndex = NO_SAMPLE;
|
||||||
|
v7->m_nEntityIndex = -5;
|
||||||
|
goto LABEL_56;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
v5->m_bIsProcessed = 1;
|
||||||
|
m_asActiveSamples[0].m_bIsProcessed = 1;
|
||||||
|
v5->field_88 = -1;
|
||||||
|
if(!v5->field_56) {
|
||||||
|
if(v5->m_bIsDistant) {
|
||||||
|
if(field_4) {
|
||||||
|
v9 = v5->m_bEmittingVolume;
|
||||||
|
if(v9 >= 63u)
|
||||||
|
v42 = 63;
|
||||||
|
else
|
||||||
|
v42 = v9;
|
||||||
|
v43 = 2 * v42;
|
||||||
|
} else {
|
||||||
|
v43 = v5->m_bEmittingVolume;
|
||||||
|
}
|
||||||
|
cSampleManager.SetChannelFrequency(j, v5->m_nFrequency);
|
||||||
|
cSampleManager.SetChannelEmittingVolume(j, v43);
|
||||||
|
} else {
|
||||||
|
v10 = m_asActiveSamples[0].m_fDistance;
|
||||||
|
v11 = v5->m_fDistance;
|
||||||
|
m_asActiveSamples[0].m_fDistance = v5->m_fDistance;
|
||||||
|
a4 = v11;
|
||||||
|
a3 = v10;
|
||||||
|
v5->m_nFrequency = ComputeDopplerEffectedFrequency(
|
||||||
|
v5->m_nFrequency, a3, a4, v5->field_48);
|
||||||
|
activeSampleFreq = m_asActiveSamples[0].m_nFrequency;
|
||||||
|
freq = v5->m_nFrequency;
|
||||||
|
if(freq != activeSampleFreq) {
|
||||||
|
if(freq <= activeSampleFreq) {
|
||||||
|
if(activeSampleFreq - 6000 > freq)
|
||||||
|
freq = activeSampleFreq - 6000;
|
||||||
|
newFreq = freq;
|
||||||
|
} else if(activeSampleFreq + 6000 >= freq) {
|
||||||
|
newFreq = v5->m_nFrequency;
|
||||||
|
} else {
|
||||||
|
newFreq = activeSampleFreq + 6000;
|
||||||
|
}
|
||||||
|
v7->m_nFrequency = newFreq;
|
||||||
|
cSampleManager.SetChannelFrequency(j, newFreq);
|
||||||
|
}
|
||||||
|
v40 = v7->m_bEmittingVolume;
|
||||||
|
v17 = v5->m_bEmittingVolume;
|
||||||
|
if(v17 != v40) {
|
||||||
|
if(v17 <= v40) {
|
||||||
|
if(v40 - 10 > v17) v17 = v40 - 10;
|
||||||
|
v41 = v17;
|
||||||
|
} else if(v40 + 10 >= v17) {
|
||||||
|
v41 = v5->m_bEmittingVolume;
|
||||||
|
} else {
|
||||||
|
v41 = v40 + 10;
|
||||||
|
}
|
||||||
|
if(field_4) {
|
||||||
|
if(v41 >= 63)
|
||||||
|
v18 = 63;
|
||||||
|
else
|
||||||
|
v18 = v41;
|
||||||
|
v19 = 2 * v18;
|
||||||
|
} else {
|
||||||
|
v19 = v41;
|
||||||
|
}
|
||||||
|
cSampleManager.SetChannelEmittingVolume(j, v19);
|
||||||
|
v7->m_bEmittingVolume = v41;
|
||||||
|
}
|
||||||
|
TranslateEntity(&v5->m_vecPos, &a2);
|
||||||
|
cSampleManager.SetChannel3DPosition(j, a2.x, a2.y, a2.z);
|
||||||
|
v20 = 0.25f * v5->m_fSoundIntensity;
|
||||||
|
cSampleManager.SetChannel3DDistances(
|
||||||
|
j, v5->m_fSoundIntensity, v20);
|
||||||
|
}
|
||||||
|
cSampleManager.SetChannelReverbFlag(j, v5->m_bReverbFlag);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
v5->m_bIsProcessed = 0;
|
||||||
|
m_asActiveSamples[0].m_bIsProcessed = 0;
|
||||||
|
goto LABEL_56;
|
||||||
|
}
|
||||||
|
LABEL_58:;
|
||||||
|
}
|
||||||
|
v22 = 0;
|
||||||
|
v23 = this;
|
||||||
|
for(uint32 i = 0; v22 < m_bActiveSamples; i++) {
|
||||||
|
if(v23->m_asActiveSamples[0].m_nSampleIndex != NO_SAMPLE &&
|
||||||
|
!v23->m_asActiveSamples[0].m_bIsProcessed) {
|
||||||
|
cSampleManager.StopChannel(i);
|
||||||
|
v23->m_asActiveSamples[0].m_nSampleIndex = NO_SAMPLE;
|
||||||
|
v23->m_asActiveSamples[0].m_nEntityIndex = -5;
|
||||||
|
}
|
||||||
|
v23 = (v23 + 92);
|
||||||
|
}
|
||||||
|
for(k = 0; k < m_bSampleRequestQueuesStatus[m_bActiveSampleQueue]; ++k) {
|
||||||
|
v24 = k + 27 * v39;
|
||||||
|
v25 = (this + 2484 * v39);
|
||||||
|
v26 = &v25->m_asSamples[m_abSampleQueueIndexTable[v24]];
|
||||||
|
if(!v25->m_asSamples[m_abSampleQueueIndexTable[v24]].m_bIsProcessed &&
|
||||||
|
!v25->m_asSamples[m_abSampleQueueIndexTable[v24]].m_bLoopEnded &&
|
||||||
|
m_asAudioEntities[v26->m_nEntityIndex].m_bIsUsed &&
|
||||||
|
v25->m_asSamples[m_abSampleQueueIndexTable[v24]].m_nSampleIndex < NO_SAMPLE) {
|
||||||
|
if(v25->m_asSamples[m_abSampleQueueIndexTable[v24]].field_4 > 255u &&
|
||||||
|
v25->m_asSamples[m_abSampleQueueIndexTable[v24]].m_nLoopCount &&
|
||||||
|
v25->m_asSamples[m_abSampleQueueIndexTable[v24]].m_bLoopsRemaining) {
|
||||||
|
--v25->m_asSamples[m_abSampleQueueIndexTable[v24]]
|
||||||
|
.m_bLoopsRemaining;
|
||||||
|
v26->field_76 = 1;
|
||||||
|
} else {
|
||||||
|
v27 = this;
|
||||||
|
for(l = 0; l < m_bActiveSamples; ++l) {
|
||||||
|
if(!v27->m_asActiveSamples[0].m_bIsProcessed) {
|
||||||
|
if(!v26->m_nLoopCount) goto LABEL_80;
|
||||||
|
v28 = v26->m_nFrequency / field_19192;
|
||||||
|
v29 = v26->m_nLoopCount *
|
||||||
|
cSampleManager.GetSampleLength(
|
||||||
|
v26->m_nSampleIndex);
|
||||||
|
if(v28) {
|
||||||
|
v26->field_76 = v29 / v28 + 1;
|
||||||
|
LABEL_80:
|
||||||
|
memcpy(v27->m_asActiveSamples, v26, 92);
|
||||||
|
if(!v27->m_asActiveSamples[0].m_bIsDistant)
|
||||||
|
TranslateEntity(
|
||||||
|
&v27->m_asActiveSamples[0]
|
||||||
|
.m_vecPos,
|
||||||
|
&a2);
|
||||||
|
if(field_4) {
|
||||||
|
if(v27->m_asActiveSamples[0]
|
||||||
|
.m_bEmittingVolume >= 63u)
|
||||||
|
v44 = 63;
|
||||||
|
else
|
||||||
|
v44 =
|
||||||
|
v27
|
||||||
|
->m_asActiveSamples
|
||||||
|
[0]
|
||||||
|
.m_bEmittingVolume;
|
||||||
|
v45 = 2 * v44;
|
||||||
|
} else {
|
||||||
|
v45 = v27->m_asActiveSamples[0]
|
||||||
|
.m_bEmittingVolume;
|
||||||
|
}
|
||||||
|
if(cSampleManager.InitialiseChannel(
|
||||||
|
l,
|
||||||
|
v27->m_asActiveSamples[0]
|
||||||
|
.m_nSampleIndex,
|
||||||
|
v27->m_asActiveSamples[0]
|
||||||
|
.m_bBankIndex)) {
|
||||||
|
cSampleManager.SetChannelFrequency(
|
||||||
|
l, v27->m_asActiveSamples[0]
|
||||||
|
.m_nFrequency);
|
||||||
|
cSampleManager
|
||||||
|
.SetChannelEmittingVolume(l,
|
||||||
|
v45);
|
||||||
|
cSampleManager.SetChannelLoopPoints(
|
||||||
|
l,
|
||||||
|
v27->m_asActiveSamples[0]
|
||||||
|
.m_nLoopStart,
|
||||||
|
v27->m_asActiveSamples[0]
|
||||||
|
.m_nLoopEnd);
|
||||||
|
cSampleManager.SetChannelLoopCount(
|
||||||
|
l, v27->m_asActiveSamples[0]
|
||||||
|
.m_nLoopCount);
|
||||||
|
cSampleManager.SetChannelReverbFlag(
|
||||||
|
l, v27->m_asActiveSamples[0]
|
||||||
|
.m_bReverbFlag);
|
||||||
|
if(v27->m_asActiveSamples[0]
|
||||||
|
.m_bIsDistant) {
|
||||||
|
v30 = v27->m_asActiveSamples
|
||||||
|
[0]
|
||||||
|
.m_bOffset;
|
||||||
|
if(v30 == 63) {
|
||||||
|
v31 = 0.0f;
|
||||||
|
} else if(v30 >= 63u) {
|
||||||
|
v31 = (v30 - 63) *
|
||||||
|
15.873f;
|
||||||
|
} else {
|
||||||
|
v31 = -((63 - v30) *
|
||||||
|
15.873f);
|
||||||
|
}
|
||||||
|
v32 = v31;
|
||||||
|
v33 = 0.0f;
|
||||||
|
v34 = 0.0f;
|
||||||
|
v27->m_asActiveSamples[0]
|
||||||
|
.m_fSoundIntensity =
|
||||||
|
100000.0f;
|
||||||
|
} else {
|
||||||
|
v32 = a2.x;
|
||||||
|
v33 = a2.y;
|
||||||
|
v34 = a2.z;
|
||||||
|
}
|
||||||
|
v35 = v34;
|
||||||
|
v36 = v33;
|
||||||
|
v37 = v32;
|
||||||
|
cSampleManager.SetChannel3DPosition(
|
||||||
|
l, v37, v36, v35);
|
||||||
|
v38 = 0.25f *
|
||||||
|
v27->m_asActiveSamples[0]
|
||||||
|
.m_fSoundIntensity;
|
||||||
|
cSampleManager
|
||||||
|
.SetChannel3DDistances(
|
||||||
|
l,
|
||||||
|
v27->m_asActiveSamples[0]
|
||||||
|
.m_fSoundIntensity,
|
||||||
|
v38);
|
||||||
|
cSampleManager.StartChannel(l);
|
||||||
|
}
|
||||||
|
v27->m_asActiveSamples[0].m_bIsProcessed =
|
||||||
|
1;
|
||||||
|
v26->m_bIsProcessed = 1;
|
||||||
|
v26->field_88 = -1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
v27 = (v27 + 92);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#if 1
|
#if 1
|
||||||
bool
|
bool
|
||||||
cAudioManager::ProcessAirBrakes(cVehicleParams *params)
|
cAudioManager::ProcessAirBrakes(cVehicleParams *params)
|
||||||
@ -3733,9 +4065,9 @@ cAudioManager::ProcessGarages()
|
|||||||
EAXJMP(0x578C20);
|
EAXJMP(0x578C20);
|
||||||
}
|
}
|
||||||
|
|
||||||
void cAudioManager::ProcessHomeScriptObject(uint8 sound)
|
void
|
||||||
|
cAudioManager::ProcessHomeScriptObject(uint8 sound)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -3820,7 +4152,7 @@ STARTPATCHES
|
|||||||
InjectHook(0x57B210, &cAudioManager::AddDetailsToRequestedOrderList, PATCH_JUMP);
|
InjectHook(0x57B210, &cAudioManager::AddDetailsToRequestedOrderList, PATCH_JUMP);
|
||||||
InjectHook(0x56AD30, &cAudioManager::AddPlayerCarSample, PATCH_JUMP);
|
InjectHook(0x56AD30, &cAudioManager::AddPlayerCarSample, PATCH_JUMP);
|
||||||
InjectHook(0x57B300, &cAudioManager::AddReflectionsToRequestedQueue, PATCH_JUMP);
|
InjectHook(0x57B300, &cAudioManager::AddReflectionsToRequestedQueue, PATCH_JUMP);
|
||||||
InjectHook(0x57B8D0, &cAudioManager::AddReleasingSounds, PATCH_JUMP);
|
// InjectHook(0x57B8D0, &cAudioManager::AddReleasingSounds, PATCH_JUMP);
|
||||||
InjectHook(0x57B070, &cAudioManager::AddSampleToRequestedQueue, PATCH_JUMP);
|
InjectHook(0x57B070, &cAudioManager::AddSampleToRequestedQueue, PATCH_JUMP);
|
||||||
InjectHook(0x57A8F0, &cAudioManager::AutoDetect3DProviders, PATCH_JUMP);
|
InjectHook(0x57A8F0, &cAudioManager::AutoDetect3DProviders, PATCH_JUMP);
|
||||||
// InjectHook(0x580AF0, &cAudioManager::AgeCrimes, PATCH_JUMP);
|
// InjectHook(0x580AF0, &cAudioManager::AgeCrimes, PATCH_JUMP);
|
||||||
@ -3977,6 +4309,7 @@ InjectHook(0x575460, &cAudioManager::GetGenericMaleTalkSfx, PATCH_JUMP);
|
|||||||
InjectHook(0x575510, &cAudioManager::GetGenericFemaleTalkSfx, PATCH_JUMP);
|
InjectHook(0x575510, &cAudioManager::GetGenericFemaleTalkSfx, PATCH_JUMP);
|
||||||
|
|
||||||
// Process stuff
|
// Process stuff
|
||||||
|
// InjectHook(0x57BA60, &cAudioManager::ProcessActiveQueues, PATCH_JUMP);
|
||||||
InjectHook(0x577B30, &cAudioManager::ProcessAirportScriptObject, PATCH_JUMP);
|
InjectHook(0x577B30, &cAudioManager::ProcessAirportScriptObject, PATCH_JUMP);
|
||||||
InjectHook(0x579250, &cAudioManager::ProcessBridgeMotor, PATCH_JUMP);
|
InjectHook(0x579250, &cAudioManager::ProcessBridgeMotor, PATCH_JUMP);
|
||||||
InjectHook(0x579170, &cAudioManager::ProcessBridgeWarning, PATCH_JUMP);
|
InjectHook(0x579170, &cAudioManager::ProcessBridgeWarning, PATCH_JUMP);
|
||||||
|
@ -7,48 +7,48 @@
|
|||||||
class tActiveSample
|
class tActiveSample
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
int m_nEntityIndex;
|
int32 m_nEntityIndex;
|
||||||
int field_4;
|
int32 field_4;
|
||||||
int m_nSampleIndex;
|
int32 m_nSampleIndex;
|
||||||
char m_bBankIndex;
|
uint8 m_bBankIndex;
|
||||||
char m_bIsDistant;
|
uint8 m_bIsDistant;
|
||||||
char field_14;
|
uint8 field_14;
|
||||||
char field_15;
|
uint8 field_15;
|
||||||
int field_16;
|
int32 field_16;
|
||||||
int m_nFrequency;
|
int32 m_nFrequency;
|
||||||
uint8 m_bVolume;
|
uint8 m_bVolume;
|
||||||
char field_25;
|
uint8 field_25;
|
||||||
char field_26;
|
uint8 field_26;
|
||||||
char field_27;
|
uint8 field_27;
|
||||||
float m_fDistance;
|
float m_fDistance;
|
||||||
int m_nLoopCount;
|
int32 m_nLoopCount;
|
||||||
int m_nLoopStart;
|
int32 m_nLoopStart;
|
||||||
int m_nLoopEnd;
|
int32 m_nLoopEnd;
|
||||||
uint8 m_bEmittingVolume;
|
uint8 m_bEmittingVolume;
|
||||||
char field_45;
|
uint8 field_45;
|
||||||
char field_46;
|
uint8 field_46;
|
||||||
char field_47;
|
uint8 field_47;
|
||||||
float field_48;
|
float field_48;
|
||||||
float m_fSoundIntensity;
|
float m_fSoundIntensity;
|
||||||
char field_56;
|
uint8 field_56;
|
||||||
char field_57;
|
uint8 field_57;
|
||||||
char field_58;
|
uint8 field_58;
|
||||||
char field_59;
|
uint8 field_59;
|
||||||
CVector m_vecPos;
|
CVector m_vecPos;
|
||||||
char m_bReverbFlag;
|
uint8 m_bReverbFlag;
|
||||||
char m_bLoopsRemaining;
|
uint8 m_bLoopsRemaining;
|
||||||
char m_bRequireReflection;
|
uint8 m_bRequireReflection;
|
||||||
uint8 m_bOffset;
|
uint8 m_bOffset;
|
||||||
int field_76;
|
int32 field_76;
|
||||||
char m_bIsProcessed;
|
uint8 m_bIsProcessed;
|
||||||
char m_bLoopEnded;
|
uint8 m_bLoopEnded;
|
||||||
char field_82;
|
uint8 field_82;
|
||||||
char field_83;
|
uint8 field_83;
|
||||||
int calculatedVolume;
|
int32 calculatedVolume;
|
||||||
char field_88;
|
uint8 field_88;
|
||||||
char field_89;
|
uint8 field_89;
|
||||||
char field_90;
|
uint8 field_90;
|
||||||
char field_91;
|
uint8 field_91;
|
||||||
};
|
};
|
||||||
|
|
||||||
static_assert(sizeof(tActiveSample) == 0x5c, "tActiveSample: error");
|
static_assert(sizeof(tActiveSample) == 0x5c, "tActiveSample: error");
|
||||||
@ -79,12 +79,12 @@ public:
|
|||||||
eAudioType m_nType;
|
eAudioType m_nType;
|
||||||
CPhysical *m_pEntity;
|
CPhysical *m_pEntity;
|
||||||
bool m_bIsUsed;
|
bool m_bIsUsed;
|
||||||
char m_bStatus;
|
uint8 m_bStatus;
|
||||||
int16 m_awAudioEvent[4];
|
int16 m_awAudioEvent[4];
|
||||||
char gap_18[2];
|
uint8 gap_18[2];
|
||||||
float m_afVolume[4];
|
float m_afVolume[4];
|
||||||
char field_24;
|
uint8 field_24;
|
||||||
char field_25[3];
|
uint8 field_25[3];
|
||||||
};
|
};
|
||||||
|
|
||||||
static_assert(sizeof(tAudioEntity) == 0x28, "tAudioEntity: error");
|
static_assert(sizeof(tAudioEntity) == 0x28, "tAudioEntity: error");
|
||||||
@ -96,9 +96,9 @@ public:
|
|||||||
int field_4;
|
int field_4;
|
||||||
CVector m_vecPos;
|
CVector m_vecPos;
|
||||||
float m_fDistance;
|
float m_fDistance;
|
||||||
char m_bVolume;
|
uint8 m_bVolume;
|
||||||
char field_25;
|
uint8 field_25;
|
||||||
char gap_26[2];
|
uint8 gap_26[2];
|
||||||
};
|
};
|
||||||
|
|
||||||
static_assert(sizeof(tPedComment) == 0x1c, "tPedComment: error");
|
static_assert(sizeof(tPedComment) == 0x1c, "tPedComment: error");
|
||||||
@ -107,10 +107,10 @@ class cPedComments
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
tPedComment m_asPedComments[40];
|
tPedComment m_asPedComments[40];
|
||||||
char field_1120[40];
|
uint8 field_1120[40];
|
||||||
char field_1160[2];
|
uint8 field_1160[2];
|
||||||
char field_1162;
|
uint8 field_1162;
|
||||||
char gap_1163[1];
|
uint8 gap_1163[1];
|
||||||
};
|
};
|
||||||
|
|
||||||
static_assert(sizeof(cPedComments) == 0x48c, "cPedComments: error");
|
static_assert(sizeof(cPedComments) == 0x48c, "cPedComments: error");
|
||||||
@ -122,15 +122,15 @@ class cAudioCollision
|
|||||||
public:
|
public:
|
||||||
CEntity *m_pEntity1;
|
CEntity *m_pEntity1;
|
||||||
CEntity *m_pEntity2;
|
CEntity *m_pEntity2;
|
||||||
char m_bSurface1;
|
uint8 m_bSurface1;
|
||||||
char m_bSurface2;
|
uint8 m_bSurface2;
|
||||||
char field_10;
|
uint8 field_10;
|
||||||
char field_11;
|
uint8 field_11;
|
||||||
float m_fIntensity1;
|
float m_fIntensity1;
|
||||||
float m_fIntensity2;
|
float m_fIntensity2;
|
||||||
CVector m_vecPosition;
|
CVector m_vecPosition;
|
||||||
float m_fDistance;
|
float m_fDistance;
|
||||||
int m_nBaseVolume;
|
int32 m_nBaseVolume;
|
||||||
};
|
};
|
||||||
|
|
||||||
static_assert(sizeof(cAudioCollision) == 0x28, "cAudioCollision: error");
|
static_assert(sizeof(cAudioCollision) == 0x28, "cAudioCollision: error");
|
||||||
@ -140,9 +140,9 @@ class cAudioCollisionManager
|
|||||||
public:
|
public:
|
||||||
cAudioCollision m_asCollisions1[10];
|
cAudioCollision m_asCollisions1[10];
|
||||||
cAudioCollision m_asCollisions2[10];
|
cAudioCollision m_asCollisions2[10];
|
||||||
char m_bIndicesTable[10];
|
uint8 m_bIndicesTable[10];
|
||||||
char m_bCollisionsInQueue;
|
uint8 m_bCollisionsInQueue;
|
||||||
char gap_811;
|
uint8 gap_811;
|
||||||
cAudioCollision m_sQueue;
|
cAudioCollision m_sQueue;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -152,18 +152,18 @@ class cMissionAudio
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CVector m_vecPos;
|
CVector m_vecPos;
|
||||||
char field_12;
|
uint8 field_12;
|
||||||
char gap_13[3];
|
uint8 gap_13[3];
|
||||||
int m_nSampleIndex;
|
int m_nSampleIndex;
|
||||||
char m_bLoadingStatus;
|
uint8 m_bLoadingStatus;
|
||||||
char m_bPlayStatus;
|
uint8 m_bPlayStatus;
|
||||||
char field_22;
|
uint8 field_22;
|
||||||
char field_23;
|
uint8 field_23;
|
||||||
int field_24;
|
int field_24;
|
||||||
bool m_bIsPlayed;
|
bool m_bIsPlayed;
|
||||||
char field_29;
|
uint8 field_29;
|
||||||
char field_30;
|
uint8 field_30;
|
||||||
char field_31;
|
uint8 field_31;
|
||||||
};
|
};
|
||||||
|
|
||||||
class cVehicleParams;
|
class cVehicleParams;
|
||||||
@ -174,50 +174,50 @@ class cAudioManager
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
bool m_bIsInitialised;
|
bool m_bIsInitialised;
|
||||||
char field_1;
|
uint8 field_1;
|
||||||
char field_2;
|
uint8 field_2;
|
||||||
char m_bActiveSamples;
|
uint8 m_bActiveSamples;
|
||||||
char field_4;
|
uint8 field_4;
|
||||||
bool m_bDynamicAcousticModelingStatus;
|
bool m_bDynamicAcousticModelingStatus;
|
||||||
char field_6;
|
uint8 field_6;
|
||||||
char field_7;
|
uint8 field_7;
|
||||||
float speedOfSound;
|
float speedOfSound;
|
||||||
bool m_bTimerJustReset;
|
bool m_bTimerJustReset;
|
||||||
char field_13;
|
uint8 field_13;
|
||||||
char field_14;
|
uint8 field_14;
|
||||||
char field_15;
|
uint8 field_15;
|
||||||
int m_nTimer;
|
int32 m_nTimer;
|
||||||
tActiveSample m_sQueueSample;
|
tActiveSample m_sQueueSample;
|
||||||
uint8 m_bActiveSampleQueue;
|
uint8 m_bActiveSampleQueue;
|
||||||
char gap_109[3];
|
uint8 gap_109[3];
|
||||||
tActiveSample m_asSamples[54];
|
tActiveSample m_asSamples[2][27];
|
||||||
char m_abSampleQueueIndexTable[54];
|
uint8 m_abSampleQueueIndexTable[2][27];
|
||||||
char m_bSampleRequestQueuesStatus[2];
|
uint8 m_bSampleRequestQueuesStatus[2];
|
||||||
tActiveSample m_asActiveSamples[27];
|
tActiveSample m_asActiveSamples[27];
|
||||||
tAudioEntity m_asAudioEntities[200];
|
tAudioEntity m_asAudioEntities[200];
|
||||||
int m_anAudioEntityIndices[200];
|
int32 m_anAudioEntityIndices[200];
|
||||||
int m_nAudioEntitiesTotal;
|
int32 m_nAudioEntitiesTotal;
|
||||||
CVector m_avecReflectionsPos[5];
|
CVector m_avecReflectionsPos[5];
|
||||||
float m_afReflectionsDistances[5];
|
float m_afReflectionsDistances[5];
|
||||||
int m_anScriptObjectEntityIndices[40];
|
int32 m_anScriptObjectEntityIndices[40];
|
||||||
int m_nScriptObjectEntityTotal;
|
int32 m_nScriptObjectEntityTotal;
|
||||||
cPedComments m_sPedComments;
|
cPedComments m_sPedComments;
|
||||||
int m_nFireAudioEntity;
|
int32 m_nFireAudioEntity;
|
||||||
int m_nWaterCannonEntity;
|
int32 m_nWaterCannonEntity;
|
||||||
int m_nPoliceChannelEntity;
|
int32 m_nPoliceChannelEntity;
|
||||||
char gap45B8[444];
|
uint8 gap45B8[444];
|
||||||
int m_nFrontEndEntity;
|
int32 m_nFrontEndEntity;
|
||||||
int m_nCollisionEntity;
|
int32 m_nCollisionEntity;
|
||||||
cAudioCollisionManager m_sCollisionManager;
|
cAudioCollisionManager m_sCollisionManager;
|
||||||
int m_nProjectileEntity;
|
int32 m_nProjectileEntity;
|
||||||
int m_nBridgeEntity;
|
int32 m_nBridgeEntity;
|
||||||
cMissionAudio m_sMissionAudio;
|
cMissionAudio m_sMissionAudio;
|
||||||
int m_anRandomTable[5];
|
int32 m_anRandomTable[5];
|
||||||
char field_19192;
|
uint8 field_19192;
|
||||||
char m_bUserPause;
|
uint8 m_bUserPause;
|
||||||
char m_bPreviousUserPause;
|
uint8 m_bPreviousUserPause;
|
||||||
char field_19195;
|
uint8 field_19195;
|
||||||
int m_nTimeOfRecentCrime;
|
int32 m_nTimeOfRecentCrime;
|
||||||
|
|
||||||
void AddDetailsToRequestedOrderList(uint8 sample);
|
void AddDetailsToRequestedOrderList(uint8 sample);
|
||||||
void AddPlayerCarSample(uint8 emittingVolume, int32 freq, uint32 sample, uint8 unk1,
|
void AddPlayerCarSample(uint8 emittingVolume, int32 freq, uint32 sample, uint8 unk1,
|
||||||
@ -248,6 +248,8 @@ public:
|
|||||||
|
|
||||||
// done
|
// done
|
||||||
|
|
||||||
|
void TranslateEntity(CVector *v1, CVector *v2); // todo hook
|
||||||
|
|
||||||
void Initialise();
|
void Initialise();
|
||||||
void PostInitialiseGameSpecificSetup();
|
void PostInitialiseGameSpecificSetup();
|
||||||
void InitialisePoliceRadioZones(); // todo
|
void InitialisePoliceRadioZones(); // todo
|
||||||
|
@ -14,6 +14,37 @@ CSampleManager::IsMP3RadioChannelAvailable()
|
|||||||
return nNumOfMp3Files != 0;
|
return nNumOfMp3Files != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
WRAPPER
|
||||||
|
void CSampleManager::SetChannelFrequency(int32, int32) { EAXJMP(0x5679D0); }
|
||||||
|
|
||||||
|
WRAPPER
|
||||||
|
void CSampleManager::SetChannelEmittingVolume(int32, uint32) { EAXJMP(0x567820); }
|
||||||
|
|
||||||
|
WRAPPER
|
||||||
|
void
|
||||||
|
CSampleManager::SetChannel3DPosition(int32, float, float, float)
|
||||||
|
{
|
||||||
|
EAXJMP(0x567890);
|
||||||
|
}
|
||||||
|
|
||||||
|
WRAPPER
|
||||||
|
void CSampleManager::SetChannelLoopCount(int32, int32) { EAXJMP(0x567AA0); }
|
||||||
|
|
||||||
|
WRAPPER
|
||||||
|
void CSampleManager::SetChannel3DDistances(int32, int32, int32) { EAXJMP(0x5678D0); }
|
||||||
|
|
||||||
|
WRAPPER
|
||||||
|
void CSampleManager::SetChannelReverbFlag(int32, uint8) { EAXJMP(0x567630); }
|
||||||
|
|
||||||
|
WRAPPER
|
||||||
|
int32 CSampleManager::GetSampleLength(int32) { EAXJMP(0x567300); }
|
||||||
|
|
||||||
|
WRAPPER
|
||||||
|
bool CSampleManager::InitialiseChannel(int32, int32, uint32, uint32) { EAXJMP(0x5676A0); }
|
||||||
|
|
||||||
|
WRAPPER
|
||||||
|
void CSampleManager::SetChannelLoopPoints(int32, int32, int32) { EAXJMP(0x567A30); }
|
||||||
|
|
||||||
WRAPPER
|
WRAPPER
|
||||||
bool
|
bool
|
||||||
CSampleManager::CheckForAnAudioFileOnCD()
|
CSampleManager::CheckForAnAudioFileOnCD()
|
||||||
@ -126,6 +157,13 @@ CSampleManager::GetChannelUsedFlag(int32 id)
|
|||||||
EAXJMP(0x567B00);
|
EAXJMP(0x567B00);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
WRAPPER
|
||||||
|
void
|
||||||
|
CSampleManager::StartChannel(int32 id)
|
||||||
|
{
|
||||||
|
EAXJMP(0x567B80);
|
||||||
|
}
|
||||||
|
|
||||||
WRAPPER
|
WRAPPER
|
||||||
void
|
void
|
||||||
CSampleManager::StopChannel(int32 id)
|
CSampleManager::StopChannel(int32 id)
|
||||||
|
@ -13,6 +13,20 @@ struct tSample {
|
|||||||
class CSampleManager
|
class CSampleManager
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
void SetChannelFrequency(int32, int32);
|
||||||
|
void SetChannelEmittingVolume(int32, uint32);
|
||||||
|
void SetChannel3DPosition(int32, float, float, float);
|
||||||
|
void SetChannelLoopCount(int32, int32);
|
||||||
|
|
||||||
|
void SetChannel3DDistances(int32, int32, int32);
|
||||||
|
void SetChannelReverbFlag(int32, uint8);
|
||||||
|
|
||||||
|
int32 GetSampleLength(int32);
|
||||||
|
|
||||||
|
bool InitialiseChannel(int32, int32, uint32, uint32 something = 0);
|
||||||
|
|
||||||
|
void SetChannelLoopPoints(int32, int32, int32);
|
||||||
|
|
||||||
bool CheckForAnAudioFileOnCD();
|
bool CheckForAnAudioFileOnCD();
|
||||||
|
|
||||||
int32 GetSampleBaseFrequency(int32);
|
int32 GetSampleBaseFrequency(int32);
|
||||||
@ -40,6 +54,8 @@ public:
|
|||||||
void SetSpeakerConfig(uint32 config);
|
void SetSpeakerConfig(uint32 config);
|
||||||
|
|
||||||
bool GetChannelUsedFlag(int32 id);
|
bool GetChannelUsedFlag(int32 id);
|
||||||
|
|
||||||
|
void StartChannel(int32 id);
|
||||||
void StopChannel(int32 id);
|
void StopChannel(int32 id);
|
||||||
|
|
||||||
static bool IsMP3RadioChannelAvailable();
|
static bool IsMP3RadioChannelAvailable();
|
||||||
@ -47,6 +63,6 @@ public:
|
|||||||
|
|
||||||
extern uint32 &nNumOfMp3Files;
|
extern uint32 &nNumOfMp3Files;
|
||||||
extern uint8 &num3DProvidersAvailable;
|
extern uint8 &num3DProvidersAvailable;
|
||||||
extern uint32* asName3DProviders;
|
extern uint32 *asName3DProviders;
|
||||||
|
|
||||||
extern CSampleManager &cSampleManager;
|
extern CSampleManager &cSampleManager;
|
Loading…
Reference in New Issue
Block a user