mirror of
https://github.com/isledecomp/isle.git
synced 2025-10-24 08:54:15 +00:00
Start IslePathActor (#93)
* Start IslePathActor * Update types/add needed type in LegoPathActor for Pizza Yes, this is a recommit because last time I pushed my cmake dir * Fix types in islepathactor * Adjust variables * add size asserts --------- Co-authored-by: itsmattkc <34096995+itsmattkc@users.noreply.github.com>
This commit is contained in:
@@ -45,6 +45,7 @@ add_library(lego1 SHARED
|
||||
LEGO1/jukeboxentity.cpp
|
||||
LEGO1/jukeboxstate.cpp
|
||||
LEGO1/legoact2state.cpp
|
||||
LEGO1/legoactor.cpp
|
||||
LEGO1/legoactioncontrolpresenter.cpp
|
||||
LEGO1/legoactor.cpp
|
||||
LEGO1/legoanimactor.cpp
|
||||
|
@@ -1 +1,17 @@
|
||||
#include "islepathactor.h"
|
||||
|
||||
DECOMP_SIZE_ASSERT(IslePathActor, 0x160)
|
||||
|
||||
// OFFSET: LEGO1 0x1001a200
|
||||
IslePathActor::IslePathActor()
|
||||
{
|
||||
this->m_pLegoWorld = NULL;
|
||||
this->m_unk13c = 6.0;
|
||||
this->m_unk15c = 1.0;
|
||||
this->m_unk158 = 0;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x10002e10
|
||||
IslePathActor::~IslePathActor()
|
||||
{
|
||||
}
|
||||
|
@@ -2,12 +2,17 @@
|
||||
#define ISLEPATHACTOR_H
|
||||
|
||||
#include "legopathactor.h"
|
||||
#include "legoworld.h"
|
||||
#include "mxtypes.h"
|
||||
|
||||
// VTABLE 0x100d4398
|
||||
// SIZE >= 0x230
|
||||
// SIZE 0x160
|
||||
class IslePathActor : public LegoPathActor
|
||||
{
|
||||
public:
|
||||
public:
|
||||
IslePathActor();
|
||||
~IslePathActor();
|
||||
|
||||
// OFFSET: LEGO1 0x10002ea0
|
||||
inline virtual const char *ClassName() const override // vtable+0x0c
|
||||
{
|
||||
@@ -20,6 +25,11 @@ public:
|
||||
{
|
||||
return !strcmp(name, IslePathActor::ClassName()) || LegoPathActor::IsA(name);
|
||||
}
|
||||
|
||||
private:
|
||||
LegoWorld* m_pLegoWorld; // 0x154
|
||||
MxFloat m_unk158;
|
||||
MxFloat m_unk15c;
|
||||
};
|
||||
|
||||
#endif // ISLEPATHACTOR_H
|
||||
|
@@ -23,7 +23,7 @@ public:
|
||||
}
|
||||
|
||||
private:
|
||||
undefined unk04_[0x68];
|
||||
undefined unk68[0x10];
|
||||
|
||||
};
|
||||
|
||||
|
@@ -1,5 +1,7 @@
|
||||
#include "legoentity.h"
|
||||
|
||||
DECOMP_SIZE_ASSERT(LegoEntity, 0x68)
|
||||
|
||||
// OFFSET: LEGO1 0x1000c290
|
||||
LegoEntity::~LegoEntity()
|
||||
{
|
||||
|
@@ -4,6 +4,7 @@
|
||||
#include "mxentity.h"
|
||||
|
||||
// VTABLE 0x100d4858
|
||||
// SIZE 0x68 (probably)
|
||||
class LegoEntity : public MxEntity
|
||||
{
|
||||
public:
|
||||
|
@@ -1,5 +1,7 @@
|
||||
#include "legopathactor.h"
|
||||
|
||||
DECOMP_SIZE_ASSERT(LegoPathActor, 0x154)
|
||||
|
||||
// OFFSET: LEGO1 0x1002d700 STUB
|
||||
LegoPathActor::LegoPathActor()
|
||||
{
|
||||
|
@@ -2,6 +2,7 @@
|
||||
#define LEGOPATHACTOR_H
|
||||
|
||||
#include "legoactor.h"
|
||||
#include "mxtypes.h"
|
||||
|
||||
// VTABLE 0x100d6e28
|
||||
// SIZE 0x154 (from inlined construction at 0x1000a346)
|
||||
@@ -25,6 +26,10 @@ public:
|
||||
return !strcmp(name, LegoPathActor::ClassName()) || LegoActor::IsA(name);
|
||||
}
|
||||
|
||||
// TODO: the types. Pizza needs this as public:
|
||||
undefined unk78[0xc4];
|
||||
MxS32 m_unk13c;
|
||||
undefined unk140[0x14];
|
||||
};
|
||||
|
||||
#endif // LEGOPATHACTOR_H
|
||||
|
@@ -1,5 +1,7 @@
|
||||
#include "mxentity.h"
|
||||
|
||||
DECOMP_SIZE_ASSERT(MxEntity, 0x68)
|
||||
|
||||
// OFFSET: LEGO1 0x1001d190
|
||||
MxEntity::MxEntity()
|
||||
{
|
||||
@@ -9,4 +11,4 @@ MxEntity::MxEntity()
|
||||
// OFFSET: LEGO1 0x1000c110
|
||||
MxEntity::~MxEntity()
|
||||
{
|
||||
}
|
||||
}
|
||||
|
@@ -1,11 +1,13 @@
|
||||
#ifndef MXENTITY_H
|
||||
#define MXENTITY_H
|
||||
|
||||
#include "decomp.h"
|
||||
#include "mxatomid.h"
|
||||
#include "mxcore.h"
|
||||
#include "mxtypes.h"
|
||||
|
||||
// VTABLE 0x100d5390
|
||||
// SIZE 0x68 or less
|
||||
class MxEntity : public MxCore
|
||||
{
|
||||
public:
|
||||
@@ -27,6 +29,7 @@ public:
|
||||
private:
|
||||
MxS32 m_mxEntityId; // 0x8
|
||||
MxAtomId m_atom; // 0xc
|
||||
undefined m_unk10[0x58];
|
||||
};
|
||||
|
||||
#endif // MXENTITY_H
|
||||
|
Reference in New Issue
Block a user