mirror of
https://github.com/isledecomp/isle-portable.git
synced 2024-11-22 23:48:12 -05:00
Prepare MxMidiPresenter vtable and refactoring (#278)
This commit is contained in:
parent
e86d6f0cc7
commit
c626f18b03
9 changed files with 91 additions and 37 deletions
|
@ -5,13 +5,13 @@
|
|||
DECOMP_SIZE_ASSERT(MxAudioPresenter, 0x54);
|
||||
|
||||
// OFFSET: LEGO1 0x1000d260
|
||||
undefined4 MxAudioPresenter::vtable5c()
|
||||
MxU32 MxAudioPresenter::GetVolume()
|
||||
{
|
||||
return this->m_unk50;
|
||||
return m_volume;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x1000d270
|
||||
void MxAudioPresenter::vtable60(undefined4 p_unk50)
|
||||
void MxAudioPresenter::SetVolume(MxU32 p_volume)
|
||||
{
|
||||
this->m_unk50 = p_unk50;
|
||||
m_volume = p_volume;
|
||||
}
|
||||
|
|
|
@ -5,9 +5,10 @@
|
|||
#include "mxmediapresenter.h"
|
||||
|
||||
// VTABLE 0x100d4c70
|
||||
// SIZE 0x54
|
||||
class MxAudioPresenter : public MxMediaPresenter {
|
||||
public:
|
||||
MxAudioPresenter() { m_unk50 = 100; }
|
||||
MxAudioPresenter() { m_volume = 100; }
|
||||
|
||||
// OFFSET: LEGO1 0x1000d280
|
||||
inline virtual const char* ClassName() const override // vtable+0x0c
|
||||
|
@ -22,10 +23,11 @@ class MxAudioPresenter : public MxMediaPresenter {
|
|||
return !strcmp(name, MxAudioPresenter::ClassName()) || MxMediaPresenter::IsA(name);
|
||||
}
|
||||
|
||||
virtual undefined4 vtable5c();
|
||||
virtual void vtable60(undefined4);
|
||||
virtual MxU32 GetVolume(); // vtable+0x5c
|
||||
virtual void SetVolume(MxU32 p_volume); // vtable+0x60
|
||||
|
||||
undefined4 m_unk50;
|
||||
private:
|
||||
MxU32 m_volume;
|
||||
};
|
||||
|
||||
#endif // MXAUDIOPRESENTER_H
|
||||
|
|
|
@ -159,7 +159,7 @@ void MxBackgroundAudioManager::StartAction(MxParam& p)
|
|||
m_action2.SetAtomId(m_unk138->GetAction()->GetAtomId());
|
||||
m_action2.SetObjectId(m_unk138->GetAction()->GetObjectId());
|
||||
m_targetVolume = ((MxDSSound*) (m_unk138->GetAction()))->GetVolume();
|
||||
m_unk138->vtable60(0);
|
||||
m_unk138->SetVolume(0);
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x1007f200
|
||||
|
@ -257,15 +257,15 @@ void MxBackgroundAudioManager::FUN_1007ef40()
|
|||
if (m_unk148 == 0) {
|
||||
compare = m_unk148;
|
||||
}
|
||||
volume = m_unk138->vtable5c();
|
||||
volume = m_unk138->GetVolume();
|
||||
if (volume < compare) {
|
||||
if (m_unk140 + m_unk138->vtable5c() <= compare) {
|
||||
if (m_unk140 + m_unk138->GetVolume() <= compare) {
|
||||
compare = m_unk140 + compare;
|
||||
}
|
||||
m_unk138->vtable60(compare);
|
||||
m_unk138->SetVolume(compare);
|
||||
}
|
||||
else {
|
||||
m_unk138->vtable60(compare);
|
||||
m_unk138->SetVolume(compare);
|
||||
m_unka0 = m_unk138;
|
||||
m_action1 = m_action2;
|
||||
m_unk138 = NULL;
|
||||
|
@ -276,16 +276,16 @@ void MxBackgroundAudioManager::FUN_1007ef40()
|
|||
}
|
||||
}
|
||||
else if (m_unka0->GetAction() != NULL) {
|
||||
if (m_unka0->vtable5c() == 0) {
|
||||
if (m_unka0->GetVolume() == 0) {
|
||||
DeleteObject(*m_unka0->GetAction());
|
||||
}
|
||||
else {
|
||||
compare = m_unka0->vtable5c();
|
||||
compare = m_unka0->GetVolume();
|
||||
volume = 0;
|
||||
if (compare != m_unk140 && -1 < compare - m_unk140) {
|
||||
volume = m_unka0->vtable5c() - m_unk140;
|
||||
volume = m_unka0->GetVolume() - m_unk140;
|
||||
}
|
||||
m_unk138->vtable60(volume);
|
||||
m_unk138->SetVolume(volume);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -295,7 +295,7 @@ void MxBackgroundAudioManager::FadeInOrFadeOut()
|
|||
{
|
||||
// This function probably is the fade in/out routine
|
||||
if (m_unka0 != NULL) {
|
||||
undefined4 volume = m_unka0->vtable5c();
|
||||
undefined4 volume = m_unka0->GetVolume();
|
||||
MxU32 compare = 30;
|
||||
if (m_unk148 == 0) {
|
||||
compare = m_targetVolume;
|
||||
|
@ -306,17 +306,17 @@ void MxBackgroundAudioManager::FadeInOrFadeOut()
|
|||
if (compare <= volume) {
|
||||
volume = compare;
|
||||
}
|
||||
m_unka0->vtable60(volume);
|
||||
m_unka0->SetVolume(volume);
|
||||
}
|
||||
else if (compare < volume) {
|
||||
volume = volume - m_unk140;
|
||||
if (volume <= compare) {
|
||||
volume = compare;
|
||||
}
|
||||
m_unka0->vtable60(volume);
|
||||
m_unka0->SetVolume(volume);
|
||||
}
|
||||
else {
|
||||
m_unka0->vtable60(volume);
|
||||
m_unka0->SetVolume(volume);
|
||||
m_unk13c = 0;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -6,6 +6,13 @@
|
|||
|
||||
DECOMP_SIZE_ASSERT(MxMIDIPresenter, 0x58);
|
||||
|
||||
// OFFSET: LEGO1 0x100c25a0 STUB
|
||||
MxResult MxMIDIPresenter::AddToManager()
|
||||
{
|
||||
// TODO
|
||||
return SUCCESS;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100c25e0
|
||||
MxMIDIPresenter::MxMIDIPresenter()
|
||||
{
|
||||
|
@ -30,10 +37,46 @@ void MxMIDIPresenter::Destroy(MxBool p_fromDestructor)
|
|||
// TODO
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100c2890 STUB
|
||||
void MxMIDIPresenter::ReadyTickle()
|
||||
{
|
||||
// TODO
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100c28d0 STUB
|
||||
void MxMIDIPresenter::StartingTickle()
|
||||
{
|
||||
// TODO
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100c2910 STUB
|
||||
void MxMIDIPresenter::StreamingTickle()
|
||||
{
|
||||
// TODO
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100c2940
|
||||
void MxMIDIPresenter::DoneTickle()
|
||||
{
|
||||
if (!MusicManager()->GetMIDIInitialized()) {
|
||||
this->EndAction();
|
||||
}
|
||||
if (!MusicManager()->GetMIDIInitialized())
|
||||
EndAction();
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100c2960 STUB
|
||||
void MxMIDIPresenter::Destroy()
|
||||
{
|
||||
// TODO
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100c2970 STUB
|
||||
undefined4 MxMIDIPresenter::PutData()
|
||||
{
|
||||
// TODO
|
||||
return 0;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100c29e0 STUB
|
||||
void MxMIDIPresenter::EndAction()
|
||||
{
|
||||
// TODO
|
||||
}
|
||||
|
|
|
@ -4,6 +4,7 @@
|
|||
#include "mxmusicpresenter.h"
|
||||
|
||||
// VTABLE 0x100dca20
|
||||
// SIZE 0x58
|
||||
class MxMIDIPresenter : public MxMusicPresenter {
|
||||
public:
|
||||
MxMIDIPresenter();
|
||||
|
@ -22,11 +23,18 @@ class MxMIDIPresenter : public MxMusicPresenter {
|
|||
return !strcmp(name, MxMIDIPresenter::ClassName()) || MxMusicPresenter::IsA(name);
|
||||
}
|
||||
|
||||
virtual void DoneTickle() override; // vtable+0x2c
|
||||
virtual void ReadyTickle() override; // vtable+0x18
|
||||
virtual void StartingTickle() override; // vtable+0x1c
|
||||
virtual void StreamingTickle() override; // vtable+0x20
|
||||
virtual void DoneTickle() override; // vtable+0x2c
|
||||
virtual MxResult AddToManager() override; // vtable+0x34
|
||||
virtual void Destroy() override; // vtable+0x38
|
||||
virtual void EndAction() override; // vtable+0x40
|
||||
virtual undefined4 PutData() override; // vtable+0x4c
|
||||
|
||||
private:
|
||||
void Init();
|
||||
void Destroy(MxBool);
|
||||
void Destroy(MxBool p_fromDestructor);
|
||||
|
||||
undefined4 m_unk54;
|
||||
};
|
||||
|
|
|
@ -7,6 +7,9 @@
|
|||
// SIZE 0x54
|
||||
class MxMusicPresenter : public MxAudioPresenter {
|
||||
public:
|
||||
MxMusicPresenter();
|
||||
virtual ~MxMusicPresenter() override;
|
||||
|
||||
// OFFSET: LEGO1 0x100c23a0
|
||||
inline virtual const char* ClassName() const override // vtable+0xc
|
||||
{
|
||||
|
@ -20,9 +23,6 @@ class MxMusicPresenter : public MxAudioPresenter {
|
|||
return !strcmp(name, MxMusicPresenter::ClassName()) || MxAudioPresenter::IsA(name);
|
||||
}
|
||||
|
||||
MxMusicPresenter();
|
||||
virtual ~MxMusicPresenter() override;
|
||||
|
||||
virtual MxResult AddToManager() override; // vtable+0x34
|
||||
virtual void Destroy() override; // vtable+0x38
|
||||
|
||||
|
|
|
@ -145,7 +145,7 @@ void MxSoundManager::SetVolume(MxS32 p_volume)
|
|||
MxPresenterListCursor cursor(m_presenters);
|
||||
|
||||
while (cursor.Next(presenter))
|
||||
((MxAudioPresenter*) presenter)->vtable60(((MxAudioPresenter*) presenter)->vtable5c());
|
||||
((MxAudioPresenter*) presenter)->SetVolume(((MxAudioPresenter*) presenter)->GetVolume());
|
||||
|
||||
m_criticalSection.Leave();
|
||||
}
|
||||
|
|
|
@ -11,6 +11,12 @@ MxSoundPresenter::~MxSoundPresenter()
|
|||
Destroy(TRUE);
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x1000d490
|
||||
void MxSoundPresenter::Destroy()
|
||||
{
|
||||
Destroy(FALSE);
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100b1a50
|
||||
void MxSoundPresenter::Destroy(MxBool p_fromDestructor)
|
||||
{
|
||||
|
@ -37,9 +43,3 @@ MxResult MxSoundPresenter::AddToManager()
|
|||
|
||||
return ret;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x1000d490
|
||||
void MxSoundPresenter::Destroy()
|
||||
{
|
||||
Destroy(FALSE);
|
||||
}
|
||||
|
|
|
@ -5,6 +5,7 @@
|
|||
#include "mxomni.h"
|
||||
|
||||
// VTABLE 0x100d4b08
|
||||
// SIZE 0x54
|
||||
class MxSoundPresenter : public MxAudioPresenter {
|
||||
public:
|
||||
virtual ~MxSoundPresenter() override;
|
||||
|
@ -26,7 +27,7 @@ class MxSoundPresenter : public MxAudioPresenter {
|
|||
virtual void Destroy() override; // vtable+0x38
|
||||
|
||||
private:
|
||||
void Destroy(MxBool);
|
||||
void Destroy(MxBool p_fromDestructor);
|
||||
};
|
||||
|
||||
#endif // MXSOUNDPRESENTER_H
|
||||
|
|
Loading…
Reference in a new issue