Implement/match LegoAnimationManager::Tickle (#876)

* Implement/match LegoAnimationManager::Tickle

* Resolve out of order

* Fix naming
This commit is contained in:
Christian Semmler
2024-05-02 09:22:09 -04:00
committed by GitHub
parent cd39e71597
commit 0bf39c7108
4 changed files with 202 additions and 22 deletions

View File

@@ -4,12 +4,14 @@
#include "actionsfwd.h" #include "actionsfwd.h"
#include "animstate.h" #include "animstate.h"
#include "decomp.h" #include "decomp.h"
#include "legoentity.h"
#include "legotraninfolist.h" #include "legotraninfolist.h"
#include "mxcore.h" #include "mxcore.h"
class LegoAnimPresenter; class LegoAnimPresenter;
class LegoEntity;
class LegoPathBoundary;
class LegoROIList; class LegoROIList;
class MxDSAction;
// SIZE 0x18 // SIZE 0x18
struct Character { struct Character {
@@ -36,11 +38,13 @@ struct Vehicle {
// SIZE 0x18 // SIZE 0x18
struct Unknown0x3c { struct Unknown0x3c {
LegoROI* m_roi; // 0x00 LegoROI* m_roi; // 0x00
MxS32 m_characterId; // 0x04 MxS32 m_characterId; // 0x04
undefined m_unk0x08[0x08]; // 0x08 undefined4 m_unk0x08; // 0x08
float m_unk0x10; // 0x10 undefined m_unk0x0c; // 0x0c
MxBool m_unk0x14; // 0x14 MxBool m_unk0x0d; // 0x0d
float m_unk0x10; // 0x10
MxBool m_unk0x14; // 0x14
}; };
// VTABLE: LEGO1 0x100d8c18 // VTABLE: LEGO1 0x100d8c18
@@ -119,13 +123,24 @@ private:
); );
MxResult FUN_100609f0(MxU32 p_objectId, MxMatrix* p_matrix, MxBool p_und1, MxBool p_und2); MxResult FUN_100609f0(MxU32 p_objectId, MxMatrix* p_matrix, MxBool p_und1, MxBool p_und2);
void DeleteAnimations(); void DeleteAnimations();
void FUN_10061530();
MxU16 FUN_10062110(
LegoROI* p_roi,
Vector3& p_direction,
Vector3& p_position,
LegoPathBoundary* p_boundary,
float p_speed,
MxU8 p_und,
MxBool p_unk0x14
);
MxS8 GetCharacterIndex(const char* p_name); MxS8 GetCharacterIndex(const char* p_name);
MxBool FUN_100623a0(AnimInfo& p_info); MxBool FUN_100623a0(AnimInfo& p_info);
void FUN_10062580(AnimInfo& p_info); void FUN_10062580(AnimInfo& p_info);
MxBool FUN_10062710(AnimInfo& p_info); MxBool FUN_10062710(AnimInfo& p_info);
void FUN_10063aa0(); void FUN_10063aa0();
void FUN_10063d10();
void FUN_100648f0(LegoTranInfo*, MxLong); void FUN_100648f0(LegoTranInfo*, MxLong);
void FUN_10064b50(undefined4); void FUN_10064b50(MxLong p_time);
MxS32 m_scriptIndex; // 0x08 MxS32 m_scriptIndex; // 0x08
MxU16 m_animCount; // 0x0c MxU16 m_animCount; // 0x0c
@@ -145,12 +160,12 @@ private:
Unknown0x3c m_unk0x3c[40]; // 0x3c Unknown0x3c m_unk0x3c[40]; // 0x3c
undefined4 m_unk0x3fc; // 0x3fc undefined4 m_unk0x3fc; // 0x3fc
MxBool m_unk0x400; // 0x400 MxBool m_unk0x400; // 0x400
undefined m_unk0x401; // 0x401 MxBool m_unk0x401; // 0x401
MxU8 m_unk0x402; // 0x402 MxBool m_unk0x402; // 0x402
MxLong m_unk0x404; // 0x404 MxLong m_unk0x404; // 0x404
MxLong m_unk0x408; // 0x408 MxLong m_unk0x408; // 0x408
MxLong m_unk0x40c; // 0x40c MxLong m_unk0x40c; // 0x40c
undefined4 m_unk0x410; // 0x410 MxLong m_unk0x410; // 0x410
undefined4 m_unk0x414; // 0x414 undefined4 m_unk0x414; // 0x414
undefined4 m_unk0x418; // 0x418 undefined4 m_unk0x418; // 0x418
undefined4 m_unk0x41c; // 0x41c undefined4 m_unk0x41c; // 0x41c
@@ -158,7 +173,7 @@ private:
LegoROIList* m_unk0x424; // 0x424 LegoROIList* m_unk0x424; // 0x424
MxBool m_unk0x428; // 0x428 MxBool m_unk0x428; // 0x428
MxBool m_unk0x429; // 0x429 MxBool m_unk0x429; // 0x429
undefined m_unk0x42a; // 0x42a MxBool m_unk0x42a; // 0x42a
MxBool m_suspended; // 0x42b MxBool m_suspended; // 0x42b
LegoTranInfo* m_unk0x42c; // 0x42c LegoTranInfo* m_unk0x42c; // 0x42c
MxBool m_unk0x430; // 0x430 MxBool m_unk0x430; // 0x430

View File

@@ -6,6 +6,8 @@
struct AnimInfo; struct AnimInfo;
class LegoAnimMMPresenter; class LegoAnimMMPresenter;
class LegoROI;
class MxPresenter;
// SIZE 0x78 // SIZE 0x78
struct LegoTranInfo { struct LegoTranInfo {

View File

@@ -47,6 +47,8 @@ public:
inline LegoROI* GetViewROI() { return this->m_viewROI; } inline LegoROI* GetViewROI() { return this->m_viewROI; }
inline MxDirect3D* GetDirect3D() { return this->m_direct3d; } inline MxDirect3D* GetDirect3D() { return this->m_direct3d; }
inline MxBool GetRender3D() { return this->m_render3d; } inline MxBool GetRender3D() { return this->m_render3d; }
inline double GetElapsedSeconds() { return this->m_elapsedSeconds; }
inline void SetRender3D(MxBool p_render3d) { this->m_render3d = p_render3d; } inline void SetRender3D(MxBool p_render3d) { this->m_render3d = p_render3d; }
inline void SetUnk0x554(MxBool p_unk0x554) { this->m_unk0x554 = p_unk0x554; } inline void SetUnk0x554(MxBool p_unk0x554) { this->m_unk0x554 = p_unk0x554; }

View File

@@ -22,6 +22,9 @@ DECOMP_SIZE_ASSERT(Vehicle, 0x08)
DECOMP_SIZE_ASSERT(Unknown0x3c, 0x18) DECOMP_SIZE_ASSERT(Unknown0x3c, 0x18)
DECOMP_SIZE_ASSERT(LegoTranInfo, 0x78) DECOMP_SIZE_ASSERT(LegoTranInfo, 0x78)
// GLOBAL: LEGO1 0x100d8b28
MxU8 g_unk0x100d8b28[] = {0, 1, 2, 4, 8, 16};
// GLOBAL: LEGO1 0x100f6d20 // GLOBAL: LEGO1 0x100f6d20
Vehicle g_vehicles[] = { Vehicle g_vehicles[] = {
{"bikebd", 0, FALSE}, {"bikebd", 0, FALSE},
@@ -84,9 +87,18 @@ Character g_characters[47] = {
{"jk", FALSE, -1, 0, FALSE, FALSE, TRUE, 1500, 20000, FALSE, 0, 0} {"jk", FALSE, -1, 0, FALSE, FALSE, TRUE, 1500, 20000, FALSE, 0, 0}
}; };
// GLOBAL: LEGO1 0x100f74b0
float g_unk0x100f74b0 = 10.0f;
// GLOBAL: LEGO1 0x100f74ec
float g_unk0x100f74ec = -1.0f;
// GLOBAL: LEGO1 0x100f74f8 // GLOBAL: LEGO1 0x100f74f8
MxS32 g_legoAnimationManagerConfig = 1; MxS32 g_legoAnimationManagerConfig = 1;
// GLOBAL: LEGO1 0x100f7500
float g_unk0x100f7500 = 0.1f;
// FUNCTION: LEGO1 0x1005eb50 // FUNCTION: LEGO1 0x1005eb50
void LegoAnimationManager::configureLegoAnimationManager(MxS32 p_legoAnimationManagerConfig) void LegoAnimationManager::configureLegoAnimationManager(MxS32 p_legoAnimationManagerConfig)
{ {
@@ -152,7 +164,7 @@ LegoAnimationManager::~LegoAnimationManager()
// FUNCTION: BETA10 0x1003fbc0 // FUNCTION: BETA10 0x1003fbc0
void LegoAnimationManager::Reset(MxBool p_und) void LegoAnimationManager::Reset(MxBool p_und)
{ {
m_unk0x402 = 0; m_unk0x402 = FALSE;
if (p_und && m_animState != NULL) { if (p_und && m_animState != NULL) {
m_animState->SetFlag(); m_animState->SetFlag();
@@ -196,7 +208,7 @@ void LegoAnimationManager::Suspend()
m_unk0x428 = m_unk0x3a; m_unk0x428 = m_unk0x3a;
m_unk0x429 = m_unk0x400; m_unk0x429 = m_unk0x400;
m_unk0x42a = m_unk0x402; m_unk0x42a = m_unk0x402;
m_unk0x402 = 0; m_unk0x402 = FALSE;
FUN_10061010(0); FUN_10061010(0);
@@ -239,7 +251,7 @@ void LegoAnimationManager::Suspend()
m_unk0x3a = FALSE; m_unk0x3a = FALSE;
m_unk0x400 = FALSE; m_unk0x400 = FALSE;
m_unk0x414 = 0; m_unk0x414 = 0;
m_unk0x401 = 0; m_unk0x401 = FALSE;
for (i = 0; i < (MxS32) _countof(g_characters); i++) { for (i = 0; i < (MxS32) _countof(g_characters); i++) {
g_characters[i].m_unk0x04 = FALSE; g_characters[i].m_unk0x04 = FALSE;
@@ -265,7 +277,7 @@ void LegoAnimationManager::Resume()
// FUNCTION: BETA10 0x1003ffb7 // FUNCTION: BETA10 0x1003ffb7
void LegoAnimationManager::Init() void LegoAnimationManager::Init()
{ {
m_unk0x402 = 0; m_unk0x402 = FALSE;
m_scriptIndex = -1; m_scriptIndex = -1;
m_animCount = 0; m_animCount = 0;
m_anims = NULL; m_anims = NULL;
@@ -297,7 +309,7 @@ void LegoAnimationManager::Init()
m_unk0x418 = 5; m_unk0x418 = 5;
m_unk0x0e = 0; m_unk0x0e = 0;
m_unk0x10 = 0; m_unk0x10 = 0;
m_unk0x401 = 0; m_unk0x401 = FALSE;
m_suspended = FALSE; m_suspended = FALSE;
m_unk0x430 = FALSE; m_unk0x430 = FALSE;
m_unk0x42c = NULL; m_unk0x42c = NULL;
@@ -487,15 +499,15 @@ MxResult LegoAnimationManager::LoadScriptInfo(MxS32 p_scriptIndex)
FUN_100617c0(-1, m_unk0x0e, m_unk0x10); FUN_100617c0(-1, m_unk0x0e, m_unk0x10);
result = SUCCESS; result = SUCCESS;
m_unk0x402 = 1; m_unk0x402 = TRUE;
if (m_suspended) { if (m_suspended) {
m_unk0x428 = m_unk0x3a; m_unk0x428 = m_unk0x3a;
m_unk0x429 = m_unk0x400; m_unk0x429 = m_unk0x400;
m_unk0x42a = 1; m_unk0x42a = TRUE;
m_unk0x3a = FALSE; m_unk0x3a = FALSE;
m_unk0x400 = FALSE; m_unk0x400 = FALSE;
m_unk0x402 = 0; m_unk0x402 = FALSE;
} }
if (p_scriptIndex == 0) { if (p_scriptIndex == 0) {
@@ -899,6 +911,12 @@ void LegoAnimationManager::FUN_10061010(undefined4)
// TODO // TODO
} }
// STUB: LEGO1 0x10061530
void LegoAnimationManager::FUN_10061530()
{
// TODO
}
// STUB: LEGO1 0x100617c0 // STUB: LEGO1 0x100617c0
void LegoAnimationManager::FUN_100617c0(MxS32, MxU16&, MxU16&) void LegoAnimationManager::FUN_100617c0(MxS32, MxU16&, MxU16&)
{ {
@@ -988,13 +1006,148 @@ MxLong LegoAnimationManager::Notify(MxParam& p_param)
return 0; return 0;
} }
// STUB: LEGO1 0x10061cc0 // FUNCTION: LEGO1 0x10061cc0
// FUNCTION: BETA10 0x1004293c
MxResult LegoAnimationManager::Tickle() MxResult LegoAnimationManager::Tickle()
{ {
// TODO FUN_10061530();
if (!m_unk0x402) {
return SUCCESS;
}
IslePathActor* actor = CurrentActor();
LegoROI* roi;
if (actor == NULL || (roi = actor->GetROI()) == NULL) {
return SUCCESS;
}
if (m_unk0x401) {
for (MxS32 i = 0; i < (MxS32) _countof(m_unk0x3c); i++) {
LegoROI* roi = m_unk0x3c[i].m_roi;
if (roi != NULL && m_unk0x3c[i].m_unk0x0d) {
LegoPathActor* actor = CharacterManager()->GetActor(roi->GetName());
if (actor != NULL && actor->GetController() != NULL) {
actor->GetController()->FUN_10046770(actor);
actor->ClearController();
}
CharacterManager()->FUN_10083db0(roi);
if (m_unk0x3c[i].m_unk0x14) {
m_unk0x3c[i].m_unk0x14 = FALSE;
MxS32 vehicleId = g_characters[m_unk0x3c[i].m_characterId].m_vehicleId;
if (vehicleId >= 0) {
g_vehicles[vehicleId].m_unk0x05 = FALSE;
LegoROI* roi = Lego()->FindROI(g_vehicles[vehicleId].m_name);
if (roi != NULL) {
roi->SetVisibility(FALSE);
}
}
}
m_unk0x3c[i].m_roi = NULL;
g_characters[m_unk0x3c[i].m_characterId].m_unk0x04 = FALSE;
g_characters[m_unk0x3c[i].m_characterId].m_unk0x07 = FALSE;
m_unk0x3c[i].m_characterId = -1;
m_unk0x3c[i].m_unk0x0d = FALSE;
m_unk0x414--;
}
}
m_unk0x401 = FALSE;
}
MxLong time = Timer()->GetTime();
float speed = actor->GetWorldSpeed();
FUN_10064b50(time);
if (!m_unk0x39 && time - m_unk0x404 > 10000 && speed < g_unk0x100f74b0 && speed > g_unk0x100f74ec) {
LegoPathBoundary* boundary = actor->GetBoundary();
Mx3DPointFloat position(roi->GetWorldPosition());
Mx3DPointFloat direction(roi->GetWorldDirection());
MxU8 und = 0;
MxU8 actorId = GameState()->GetActorId();
if (actorId <= 5) {
und = g_unk0x100d8b28[actorId];
}
for (MxS32 i = 0; i < (MxS32) _countof(m_unk0x3c); i++) {
LegoROI* roi = m_unk0x3c[i].m_roi;
if (roi != NULL) {
MxU16 result = FUN_10062110(roi, direction, position, boundary, speed, und, m_unk0x3c[i].m_unk0x14);
if (result) {
MxMatrix mat;
mat = roi->GetLocal2World();
if (FUN_100605e0(result & USHRT_MAX, FALSE, &mat, TRUE, roi, FALSE, TRUE, TRUE, TRUE) == SUCCESS) {
m_unk0x404 = time;
return SUCCESS;
}
}
}
}
}
if (time - m_unk0x40c > 1000) {
FUN_10063d10();
m_unk0x40c = time;
}
if (time - m_unk0x408 < m_unk0x410) {
return SUCCESS;
}
m_unk0x410 = (rand() * 10000 / SHRT_MAX) + 5000;
m_unk0x408 = time;
if (time - m_unk0x404 > 10000) {
FUN_100629b0(-1, FALSE);
}
double elapsedSeconds = VideoManager()->GetElapsedSeconds();
if (elapsedSeconds < 1.0 && elapsedSeconds > 0.01) {
g_unk0x100f7500 = (g_unk0x100f7500 * 2.0 + elapsedSeconds) / 3.0;
if (elapsedSeconds > 0.2 && m_unk0x418 > 2) {
m_unk0x418--;
}
else if (g_unk0x100f7500 < 0.16 && m_unk0x418 < m_unk0x41c) {
m_unk0x418++;
}
}
return SUCCESS; return SUCCESS;
} }
// STUB: LEGO1 0x10062110
// FUNCTION: BETA10 0x10042f41
MxU16 LegoAnimationManager::FUN_10062110(
LegoROI* p_roi,
Vector3& p_direction,
Vector3& p_position,
LegoPathBoundary* p_boundary,
float p_speed,
MxU8 p_und,
MxBool p_unk0x14
)
{
// TODO
return 0;
}
// FUNCTION: LEGO1 0x10062360 // FUNCTION: LEGO1 0x10062360
// FUNCTION: BETA10 0x100432dd // FUNCTION: BETA10 0x100432dd
MxS8 LegoAnimationManager::GetCharacterIndex(const char* p_name) MxS8 LegoAnimationManager::GetCharacterIndex(const char* p_name)
@@ -1057,6 +1210,7 @@ void LegoAnimationManager::FUN_100627d0(MxBool)
} }
// STUB: LEGO1 0x100629b0 // STUB: LEGO1 0x100629b0
// FUNCTION: BETA10 0x10043c10
void LegoAnimationManager::FUN_100629b0(MxU32, MxBool) void LegoAnimationManager::FUN_100629b0(MxU32, MxBool)
{ {
// TODO // TODO
@@ -1097,6 +1251,13 @@ void LegoAnimationManager::FUN_10063aa0()
} }
} }
// STUB: LEGO1 0x10063d10
// FUNCTION: BETA10 0x10045034
void LegoAnimationManager::FUN_10063d10()
{
// TODO
}
// STUB: LEGO1 0x10064670 // STUB: LEGO1 0x10064670
void LegoAnimationManager::FUN_10064670(Vector3*) void LegoAnimationManager::FUN_10064670(Vector3*)
{ {
@@ -1118,7 +1279,7 @@ void LegoAnimationManager::FUN_100648f0(LegoTranInfo*, MxLong)
// STUB: LEGO1 0x10064b50 // STUB: LEGO1 0x10064b50
// FUNCTION: BETA10 0x10045f14 // FUNCTION: BETA10 0x10045f14
void LegoAnimationManager::FUN_10064b50(undefined4) void LegoAnimationManager::FUN_10064b50(MxLong p_time)
{ {
// TODO // TODO
} }