mirror of
https://github.com/isledecomp/isle.git
synced 2025-10-24 08:54:15 +00:00
Add Act3Ammo
, match Act3::Act3
(#1196)
* Implement `Act3Ammo`, match `Act3::Act3` * Move * Fix match
This commit is contained in:

committed by
GitHub

parent
5be00e1799
commit
97fb6e4f15
@@ -1,10 +1,31 @@
|
||||
#ifndef ACT3_H
|
||||
#define ACT3_H
|
||||
|
||||
#include "act3ammo.h"
|
||||
#include "legogamestate.h"
|
||||
#include "legostate.h"
|
||||
#include "legoworld.h"
|
||||
|
||||
class Helicopter;
|
||||
|
||||
// SIZE 0x0c
|
||||
struct Act3ListElement {
|
||||
undefined4 m_unk0x00[3]; // 0x00
|
||||
|
||||
int operator==(Act3ListElement) const { return 0; }
|
||||
int operator<(Act3ListElement) const { return 0; }
|
||||
};
|
||||
|
||||
// SIZE 0x10
|
||||
class Act3List {
|
||||
public:
|
||||
Act3List() { m_unk0x04 = 0; }
|
||||
|
||||
private:
|
||||
list<Act3ListElement> m_unk0x00; // 0x00
|
||||
undefined4 m_unk0x04; // 0x0c
|
||||
};
|
||||
|
||||
// VTABLE: LEGO1 0x100d4fc8
|
||||
// SIZE 0x0c
|
||||
class Act3State : public LegoState {
|
||||
@@ -42,8 +63,7 @@ public:
|
||||
class Act3 : public LegoWorld {
|
||||
public:
|
||||
Act3();
|
||||
|
||||
~Act3() override; // vtable+00
|
||||
~Act3() override;
|
||||
|
||||
MxLong Notify(MxParam& p_param) override; // vtable+0x04
|
||||
MxResult Tickle() override; // vtable+0x08
|
||||
@@ -69,7 +89,7 @@ public:
|
||||
MxBool Escape() override; // vtable+0x64
|
||||
void Enable(MxBool p_enable) override; // vtable+0x68
|
||||
|
||||
void SetUnknown420c(MxEntity* p_entity) { m_unk0x420c = p_entity; }
|
||||
void SetHelicopter(Helicopter* p_helicopter) { m_helicopter = p_helicopter; }
|
||||
void SetDestLocation(LegoGameState::Area p_destLocation) { m_destLocation = p_destLocation; }
|
||||
|
||||
// SYNTHETIC: LEGO1 0x10072630
|
||||
@@ -81,10 +101,33 @@ public:
|
||||
void FUN_10073430();
|
||||
|
||||
protected:
|
||||
undefined m_unk0xf8[0x4114]; // 0xf8
|
||||
MxEntity* m_unk0x420c; // 0x420c
|
||||
undefined m_unk0x4210[0x60]; // 0x4210
|
||||
undefined4 m_unk0xf8; // 0xf8
|
||||
Act3Ammo m_unk0xfc[20]; // 0xfc
|
||||
Act3Ammo m_unk0x217c[20]; // 0x217c
|
||||
undefined m_unk0x41fc; // 0x41fc
|
||||
undefined4 m_unk0x4200; // 0x4200
|
||||
undefined4 m_unk0x4204; // 0x4204
|
||||
undefined4 m_unk0x4208; // 0x4208
|
||||
Helicopter* m_helicopter; // 0x420c
|
||||
undefined4 m_unk0x4210; // 0x4210
|
||||
MxFloat m_unk0x4214; // 0x4214
|
||||
undefined4 m_unk0x4218; // 0x4218
|
||||
undefined m_unk0x421c; // 0x421c
|
||||
undefined m_unk0x421d; // 0x421d
|
||||
undefined m_unk0x421e; // 0x421e
|
||||
Act3List m_unk0x4220; // 0x4220
|
||||
undefined4 m_unk0x4230[15]; // 0x4230
|
||||
undefined4 m_unk0x426c; // 0x426c
|
||||
LegoGameState::Area m_destLocation; // 0x4270
|
||||
};
|
||||
|
||||
// TEMPLATE: LEGO1 0x10072440
|
||||
// list<Act3ListElement,allocator<Act3ListElement> >::~list<Act3ListElement,allocator<Act3ListElement> >
|
||||
|
||||
// TEMPLATE: LEGO1 0x100724b0
|
||||
// List<Act3ListElement>::~List<Act3ListElement>
|
||||
|
||||
// FUNCTION: LEGO1 0x10072650
|
||||
// Act3List::~Act3List
|
||||
|
||||
#endif // ACT3_H
|
||||
|
28
LEGO1/lego/legoomni/include/act3ammo.h
Normal file
28
LEGO1/lego/legoomni/include/act3ammo.h
Normal file
@@ -0,0 +1,28 @@
|
||||
#ifndef ACT3AMMO_H
|
||||
#define ACT3AMMO_H
|
||||
|
||||
#include "legopathactor.h"
|
||||
#include "mxgeometry/mxgeometry3d.h"
|
||||
|
||||
// VTABLE: LEGO1 0x100d8460
|
||||
// SIZE 0x1a0
|
||||
class Act3Ammo : public LegoPathActor {
|
||||
public:
|
||||
Act3Ammo();
|
||||
~Act3Ammo() override;
|
||||
|
||||
void Destroy(MxBool p_fromDestructor) override; // vtable+0x1c
|
||||
void VTable0x70(float p_time) override; // vtable+0x70
|
||||
|
||||
// SYNTHETIC: LEGO1 0x10053880
|
||||
// Act3Ammo::`scalar deleting destructor'
|
||||
|
||||
private:
|
||||
undefined2 m_unk0x154; // 0x154
|
||||
undefined4 m_unk0x158; // 0x158
|
||||
undefined4 m_unk0x15c; // 0x15c
|
||||
Mx3DPointFloat m_unk0x160[3]; // 0x160
|
||||
undefined4 m_unk0x19c; // 0x19c
|
||||
};
|
||||
|
||||
#endif // ACT3AMMO_H
|
@@ -91,11 +91,23 @@ public:
|
||||
MxFloat GetLinearVel() { return m_linearVel; }
|
||||
MxFloat GetRotationalVel() { return m_rotationalVel; }
|
||||
MxFloat GetMaxLinearVel() { return m_maxLinearVel; }
|
||||
MxFloat GetMaxLinearAccel() { return m_maxLinearAccel; }
|
||||
MxFloat GetMaxLinearDeccel() { return m_maxLinearDeccel; }
|
||||
void ResetMaxLinearVel(MxFloat p_maxLinearVel)
|
||||
{
|
||||
m_maxLinearVel = p_maxLinearVel;
|
||||
m_trackDefault = 0;
|
||||
}
|
||||
void ResetMaxLinearAccel(MxFloat p_maxLinearAccel)
|
||||
{
|
||||
m_maxLinearAccel = p_maxLinearAccel;
|
||||
m_trackDefault = 0;
|
||||
}
|
||||
void ResetMaxLinearDeccel(MxFloat p_maxLinearDeccel)
|
||||
{
|
||||
m_maxLinearDeccel = p_maxLinearDeccel;
|
||||
m_trackDefault = 0;
|
||||
}
|
||||
|
||||
// FUNCTION: BETA10 0x100c9a10
|
||||
int GetDefaultDeadZone() { return g_defdeadZone; }
|
||||
|
Reference in New Issue
Block a user