mirror of
https://github.com/isledecomp/isle-portable.git
synced 2025-09-27 22:54:02 -04:00
Implement/match rest of MxCompositeMediaPresenter (#331)
* Implement/match rest of MxCompositeMediaPresenter * Fix annotation
This commit is contained in:
parent
76b4edaa9e
commit
412dda3e99
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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();
|
||||||
|
@ -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();
|
||||||
};
|
};
|
||||||
|
@ -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();
|
||||||
|
@ -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();
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user