Implement/match rest of MxCompositeMediaPresenter (#331)

* Implement/match rest of MxCompositeMediaPresenter

* Fix annotation
This commit is contained in:
Christian Semmler 2023-12-16 10:59:01 -05:00 committed by GitHub
parent 76b4edaa9e
commit 412dda3e99
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 85 additions and 16 deletions

View File

@ -5,6 +5,7 @@
#include "legovideomanager.h" #include "legovideomanager.h"
#include "mxautolocker.h" #include "mxautolocker.h"
#include "mxdsmultiaction.h" #include "mxdsmultiaction.h"
#include "mxmediapresenter.h"
#include "mxobjectfactory.h" #include "mxobjectfactory.h"
#include "mxtimer.h" #include "mxtimer.h"
@ -14,7 +15,7 @@ DECOMP_SIZE_ASSERT(MxCompositeMediaPresenter, 0x50)
MxCompositeMediaPresenter::MxCompositeMediaPresenter() MxCompositeMediaPresenter::MxCompositeMediaPresenter()
{ {
m_unk0x4c = 0; m_unk0x4c = 0;
m_unk0x4e = 0; m_unk0x4e = FALSE;
VideoManager()->AddPresenter(*this); VideoManager()->AddPresenter(*this);
} }
@ -85,22 +86,87 @@ MxResult MxCompositeMediaPresenter::StartAction(MxStreamController* p_controller
return result; return result;
} }
// STUB: LEGO1 0x100742e0 // FUNCTION: LEGO1 0x100742e0
void MxCompositeMediaPresenter::StartingTickle() void MxCompositeMediaPresenter::StartingTickle()
{ {
// TODO MxAutoLocker lock(&m_criticalSection);
if (!m_unk0x4e) {
for (MxCompositePresenterList::iterator it = m_list.begin(); it != m_list.end(); it++) {
if ((*it)->GetCurrentTickleState() < TickleState_Streaming) {
(*it)->Tickle();
if ((*it)->GetCurrentTickleState() == TickleState_Streaming ||
((*it)->GetAction() && (*it)->GetAction()->GetStartTime()))
m_unk0x4c++;
}
}
if (m_list.size() == m_unk0x4c) {
m_unk0x4e = TRUE;
m_unk0x4c = 0;
for (MxCompositePresenterList::iterator it = m_list.begin(); it != m_list.end(); it++) {
if (!(*it)->GetAction()->GetStartTime())
m_unk0x4c++;
}
}
}
else {
for (MxCompositePresenterList::iterator it = m_list.begin(); it != m_list.end(); it++) {
if (!(*it)->GetAction()->GetStartTime() && ((MxMediaPresenter*) *it)->FUN_100b5650() &&
!((*it)->GetAction()->GetFlags() & MxDSAction::Flag_Bit9)) {
(*it)->Tickle();
(*it)->GetAction()->SetFlags((*it)->GetAction()->GetFlags() | MxDSAction::Flag_Bit9);
m_unk0x4c--;
}
}
if (!m_unk0x4c) {
m_previousTickleStates |= 1 << (unsigned char) m_currentTickleState;
m_currentTickleState = TickleState_Streaming;
MxLong time = Timer()->GetTime();
m_action->SetUnknown90(time);
}
}
} }
// STUB: LEGO1 0x10074470 // FUNCTION: LEGO1 0x10074470
MxResult MxCompositeMediaPresenter::Tickle() MxResult MxCompositeMediaPresenter::Tickle()
{ {
// TODO MxAutoLocker lock(&m_criticalSection);
switch (m_currentTickleState) {
case TickleState_Ready:
m_previousTickleStates |= 1 << (unsigned char) m_currentTickleState;
m_currentTickleState = TickleState_Starting;
case TickleState_Starting:
StartingTickle();
break;
case TickleState_Streaming:
case TickleState_Repeating:
case TickleState_unk5:
case TickleState_Done: {
for (MxCompositePresenterList::iterator it = m_list.begin(); it != m_list.end(); it++)
(*it)->Tickle();
break;
}
default:
break;
}
return SUCCESS; return SUCCESS;
} }
// STUB: LEGO1 0x10074540 // FUNCTION: LEGO1 0x10074540
MxResult MxCompositeMediaPresenter::PutData() MxResult MxCompositeMediaPresenter::PutData()
{ {
// TODO MxAutoLocker lock(&m_criticalSection);
if (m_currentTickleState >= TickleState_Streaming && m_currentTickleState <= TickleState_Done) {
for (MxCompositePresenterList::iterator it = m_list.begin(); it != m_list.end(); it++)
(*it)->PutData();
}
return SUCCESS; return SUCCESS;
} }

View File

@ -30,8 +30,8 @@ public:
virtual MxResult PutData() override; // vtable+0x4c virtual MxResult PutData() override; // vtable+0x4c
private: private:
undefined2 m_unk0x4c; // 0x4c MxS16 m_unk0x4c; // 0x4c
undefined m_unk0x4e; // 0x4e MxBool m_unk0x4e; // 0x4e
}; };
// SYNTHETIC: LEGO1 0x10074000 // SYNTHETIC: LEGO1 0x10074000

View File

@ -59,6 +59,6 @@ protected:
// List<MxPresenter *>::~List<MxPresenter *> // List<MxPresenter *>::~List<MxPresenter *>
// TEMPLATE: LEGO1 0x100b6cd0 // TEMPLATE: LEGO1 0x100b6cd0
// MxList<MxDSAction *>::_DeleteEntry // MxList<MxDSAction *>::DeleteEntry
#endif // MXCOMPOSITEPRESENTER_H #endif // MXCOMPOSITEPRESENTER_H

View File

@ -19,8 +19,9 @@ public:
Flag_Enabled = 0x20, Flag_Enabled = 0x20,
Flag_Bit7 = 0x40, Flag_Bit7 = 0x40,
Flag_World = 0x80, Flag_World = 0x80,
Flag_Bit9 = 0x200, Flag_Bit9 = 0x100,
Flag_Bit10 = 0x400, Flag_Bit10 = 0x200,
Flag_Bit11 = 0x400,
}; };
__declspec(dllexport) MxDSAction(); __declspec(dllexport) MxDSAction();

View File

@ -45,6 +45,8 @@ protected:
void Init(); void Init();
void Destroy(MxBool p_fromDestructor); void Destroy(MxBool p_fromDestructor);
public:
MxStreamChunk* FUN_100b5650(); MxStreamChunk* FUN_100b5650();
MxStreamChunk* NextChunk(); MxStreamChunk* NextChunk();
}; };

View File

@ -102,7 +102,7 @@ MxResult MxTransitionManager::StartTransition(
MxDSAction* action = m_waitIndicator->GetAction(); MxDSAction* action = m_waitIndicator->GetAction();
action->SetLoopCount(10000); action->SetLoopCount(10000);
action->SetFlags(action->GetFlags() | MxDSAction::Flag_Bit9); action->SetFlags(action->GetFlags() | MxDSAction::Flag_Bit10);
} }
MxU32 time = timeGetTime(); MxU32 time = timeGetTime();

View File

@ -254,7 +254,7 @@ void MxVideoPresenter::NextFrame()
MxBool MxVideoPresenter::IsHit(MxS32 p_x, MxS32 p_y) MxBool MxVideoPresenter::IsHit(MxS32 p_x, MxS32 p_y)
{ {
MxDSAction* action = GetAction(); MxDSAction* action = GetAction();
if ((action == NULL) || (((action->GetFlags() & MxDSAction::Flag_Bit10) == 0) && !IsEnabled()) || if ((action == NULL) || (((action->GetFlags() & MxDSAction::Flag_Bit11) == 0) && !IsEnabled()) ||
(!m_bitmap && !m_alpha)) (!m_bitmap && !m_alpha))
return FALSE; return FALSE;
@ -347,7 +347,7 @@ void MxVideoPresenter::StartingTickle()
// FUNCTION: LEGO1 0x100b2fe0 // FUNCTION: LEGO1 0x100b2fe0
void MxVideoPresenter::StreamingTickle() void MxVideoPresenter::StreamingTickle()
{ {
if (m_action->GetFlags() & MxDSAction::Flag_Bit9) { if (m_action->GetFlags() & MxDSAction::Flag_Bit10) {
if (!m_currentChunk) if (!m_currentChunk)
MxMediaPresenter::StreamingTickle(); MxMediaPresenter::StreamingTickle();
@ -386,7 +386,7 @@ void MxVideoPresenter::StreamingTickle()
void MxVideoPresenter::RepeatingTickle() void MxVideoPresenter::RepeatingTickle()
{ {
if (IsEnabled()) { if (IsEnabled()) {
if (m_action->GetFlags() & MxDSAction::Flag_Bit9) { if (m_action->GetFlags() & MxDSAction::Flag_Bit10) {
if (!m_currentChunk) if (!m_currentChunk)
MxMediaPresenter::RepeatingTickle(); MxMediaPresenter::RepeatingTickle();