mirror of
https://github.com/isledecomp/isle.git
synced 2025-10-23 00:14:22 +00:00
Reorganize sources and files (#414)
* Reorganize sources * Refactor * Remove relative paths * Renames * Fix gitignore * Remove stuff * Try fixing format script * Fix format * Fix format * Fix naming script * Test format * Fix format
This commit is contained in:

committed by
GitHub

parent
6a85e62406
commit
c47206617d
97
LEGO1/omni/include/mxpresenter.h
Normal file
97
LEGO1/omni/include/mxpresenter.h
Normal file
@@ -0,0 +1,97 @@
|
||||
#ifndef MXPRESENTER_H
|
||||
#define MXPRESENTER_H
|
||||
|
||||
#include "decomp.h"
|
||||
#include "mxcore.h"
|
||||
#include "mxcriticalsection.h"
|
||||
#include "mxdsaction.h"
|
||||
#include "mxomni.h"
|
||||
#include "mxpoint32.h"
|
||||
|
||||
class MxCompositePresenter;
|
||||
class MxStreamController;
|
||||
class MxEntity;
|
||||
|
||||
// VTABLE: LEGO1 0x100d4d38
|
||||
// SIZE 0x40
|
||||
class MxPresenter : public MxCore {
|
||||
public:
|
||||
enum TickleState {
|
||||
TickleState_Idle = 0,
|
||||
TickleState_Ready,
|
||||
TickleState_Starting,
|
||||
TickleState_Streaming,
|
||||
TickleState_Repeating,
|
||||
TickleState_unk5,
|
||||
TickleState_Done,
|
||||
};
|
||||
|
||||
MxPresenter() { Init(); }
|
||||
|
||||
__declspec(dllexport) virtual ~MxPresenter(); // vtable+0x0
|
||||
__declspec(dllexport) virtual MxResult Tickle() override; // vtable+0x8
|
||||
|
||||
// FUNCTION: LEGO1 0x1000bfe0
|
||||
inline virtual const char* ClassName() const override // vtable+0xc
|
||||
{
|
||||
// STRING: LEGO1 0x100f0740
|
||||
return "MxPresenter";
|
||||
}
|
||||
|
||||
// FUNCTION: LEGO1 0x1000bff0
|
||||
inline virtual MxBool IsA(const char* p_name) const override // vtable+0x10
|
||||
{
|
||||
return !strcmp(p_name, MxPresenter::ClassName()) || MxCore::IsA(p_name);
|
||||
}
|
||||
|
||||
virtual void VTable0x14(); // vtable+0x14
|
||||
virtual void ReadyTickle(); // vtable+0x18
|
||||
virtual void StartingTickle(); // vtable+0x1c
|
||||
virtual void StreamingTickle(); // vtable+0x20
|
||||
virtual void RepeatingTickle(); // vtable+0x24
|
||||
virtual void Unk5Tickle(); // vtable+0x28
|
||||
|
||||
protected:
|
||||
__declspec(dllexport) virtual void DoneTickle(); // vtable+0x2c
|
||||
__declspec(dllexport) virtual void ParseExtra(); // vtable+0x30
|
||||
|
||||
public:
|
||||
virtual MxResult AddToManager(); // vtable+0x34
|
||||
virtual void Destroy(); // vtable+0x38
|
||||
__declspec(dllexport) virtual MxResult StartAction(MxStreamController*, MxDSAction*); // vtable+0x3c
|
||||
__declspec(dllexport) virtual void EndAction(); // vtable+0x40
|
||||
virtual void SetTickleState(TickleState p_tickleState); // vtable+0x44
|
||||
virtual MxBool HasTickleStatePassed(TickleState p_tickleState); // vtable+0x48
|
||||
virtual MxResult PutData(); // vtable+0x4c
|
||||
virtual MxBool IsHit(MxS32 p_x, MxS32 p_y); // vtable+0x50
|
||||
__declspec(dllexport) virtual void Enable(MxBool p_enable); // vtable+0x54
|
||||
|
||||
MxEntity* CreateEntityBackend(const char* p_name);
|
||||
MxBool IsEnabled();
|
||||
|
||||
inline MxS32 GetCurrentTickleState() const { return this->m_currentTickleState; }
|
||||
inline MxPoint32 GetLocation() const { return this->m_location; }
|
||||
inline MxS32 GetDisplayZ() const { return this->m_displayZ; }
|
||||
inline MxDSAction* GetAction() const { return this->m_action; }
|
||||
|
||||
inline void SetCompositePresenter(MxCompositePresenter* p_compositePresenter)
|
||||
{
|
||||
m_compositePresenter = p_compositePresenter;
|
||||
}
|
||||
|
||||
protected:
|
||||
__declspec(dllexport) void Init();
|
||||
void SendToCompositePresenter(MxOmni*);
|
||||
|
||||
TickleState m_currentTickleState; // 0x8
|
||||
MxU32 m_previousTickleStates; // 0x0c
|
||||
MxPoint32 m_location; // 0x10
|
||||
MxS32 m_displayZ; // 0x18
|
||||
MxDSAction* m_action; // 0x1c
|
||||
MxCriticalSection m_criticalSection; // 0x20
|
||||
MxCompositePresenter* m_compositePresenter; // 0x3c
|
||||
};
|
||||
|
||||
const char* PresenterNameDispatch(const MxDSAction&);
|
||||
|
||||
#endif // MXPRESENTER_H
|
Reference in New Issue
Block a user