Implement/match Jetski class (#1061)

This commit is contained in:
Christian Semmler 2024-07-04 17:11:20 -07:00 committed by GitHub
parent bee101b1f4
commit 87a9a37b33
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
7 changed files with 159 additions and 36 deletions

View file

@ -32,12 +32,12 @@ class DuneBuggy : public IslePathActor {
void ActivateSceneActions(); void ActivateSceneActions();
static MxS32 GetColorOffset(const char* p_variable);
// SYNTHETIC: LEGO1 0x10067dc0 // SYNTHETIC: LEGO1 0x10067dc0
// DuneBuggy::`scalar deleting destructor' // DuneBuggy::`scalar deleting destructor'
private: private:
static MxS32 GetDashboardOffset(const char* p_variable);
MxS16 m_dashboard; // 0x160 MxS16 m_dashboard; // 0x160
MxFloat m_fuel; // 0x164 MxFloat m_fuel; // 0x164
MxFloat m_time; // 0x168 MxFloat m_time; // 0x168

View file

@ -26,12 +26,12 @@ class Jetski : public IslePathActor {
} }
MxResult Create(MxDSAction& p_dsAction) override; // vtable+0x18 MxResult Create(MxDSAction& p_dsAction) override; // vtable+0x18
void VTable0x70(float p_float) override; // vtable+0x70 void VTable0x70(float p_time) override; // vtable+0x70
MxLong HandleClick() override; // vtable+0xcc MxLong HandleClick() override; // vtable+0xcc
MxLong HandleControl(LegoControlManagerNotificationParam&) override; // vtable+0xd4 MxLong HandleControl(LegoControlManagerNotificationParam&) override; // vtable+0xd4
void Exit() override; // vtable+0xe4 void Exit() override; // vtable+0xe4
void FUN_1007e990(); void ActivateSceneActions();
MxS16 GetUnknown0x160() { return m_unk0x160; } MxS16 GetUnknown0x160() { return m_unk0x160; }
@ -39,9 +39,9 @@ class Jetski : public IslePathActor {
// Jetski::`scalar deleting destructor' // Jetski::`scalar deleting destructor'
private: private:
// TODO: Jetski fields void RemoveFromWorld();
MxS16 m_unk0x160; // 0x160
undefined m_unk0x162[2]; // 0x162 MxS16 m_unk0x160; // 0x160
}; };
#endif // JETSKI_H #endif // JETSKI_H

View file

@ -3,6 +3,8 @@
#include "mxvariable.h" #include "mxvariable.h"
extern const char* g_varJETSPEED;
extern const char* g_varJETFUEL;
extern const char* g_varDUNESPEED; extern const char* g_varDUNESPEED;
extern const char* g_varDUNEFUEL; extern const char* g_varDUNEFUEL;
extern const char* g_varMOTOSPEED; extern const char* g_varMOTOSPEED;

View file

@ -102,7 +102,7 @@ MxLong DuneBuggy::HandleClick()
} }
m_time = Timer()->GetTime(); m_time = Timer()->GetTime();
m_dashboard = IsleScript::c_DuneCarSpeedMeter + GetDashboardOffset(g_varDBFRFNY4); m_dashboard = IsleScript::c_DuneCarSpeedMeter + GetColorOffset(g_varDBFRFNY4);
InvokeAction(Extra::ActionType::e_start, *g_isleScript, m_dashboard, NULL); InvokeAction(Extra::ActionType::e_start, *g_isleScript, m_dashboard, NULL);
InvokeAction(Extra::ActionType::e_start, *g_isleScript, IsleScript::c_DuneCarDashboard, NULL); InvokeAction(Extra::ActionType::e_start, *g_isleScript, IsleScript::c_DuneCarDashboard, NULL);
@ -157,30 +157,30 @@ MxLong DuneBuggy::HandlePathStruct(LegoPathStructNotificationParam& p_param)
} }
// FUNCTION: LEGO1 0x10068290 // FUNCTION: LEGO1 0x10068290
MxS32 DuneBuggy::GetDashboardOffset(const char* p_variable) MxS32 DuneBuggy::GetColorOffset(const char* p_variable)
{ {
MxS32 color = 1; MxS32 offset = 1;
const char* colorName = VariableTable()->GetVariable(p_variable); const char* colorName = VariableTable()->GetVariable(p_variable);
if (strcmpi(colorName, "lego green")) { if (strcmpi(colorName, "lego green")) {
if (!strcmpi(colorName, "lego red")) { if (!strcmpi(colorName, "lego red")) {
color = 2; offset = 2;
} }
else if (!strcmpi(colorName, "lego yellow")) { else if (!strcmpi(colorName, "lego yellow")) {
color = 3; offset = 3;
} }
else if (!strcmpi(colorName, "lego black")) { else if (!strcmpi(colorName, "lego black")) {
color = 4; offset = 4;
} }
else if (!strcmpi(colorName, "lego blue")) { else if (!strcmpi(colorName, "lego blue")) {
color = 5; offset = 5;
} }
else if (!strcmpi(colorName, "lego white")) { else if (!strcmpi(colorName, "lego white")) {
color = 6; offset = 6;
} }
} }
return color; return offset;
} }
// FUNCTION: LEGO1 0x10068350 // FUNCTION: LEGO1 0x10068350

View file

@ -1,50 +1,163 @@
#include "jetski.h" #include "jetski.h"
#include "dunebuggy.h"
#include "isle.h"
#include "isle_actions.h"
#include "jukebox_actions.h"
#include "legoanimationmanager.h"
#include "legocontrolmanager.h"
#include "legonavcontroller.h"
#include "legoutils.h"
#include "legovariables.h"
#include "legoworld.h"
#include "misc.h"
#include "mxmisc.h"
#include "mxtransitionmanager.h"
#include "mxvariabletable.h"
#include "scripts.h"
DECOMP_SIZE_ASSERT(Jetski, 0x164) DECOMP_SIZE_ASSERT(Jetski, 0x164)
// GLOBAL: LEGO1 0x100f7ab8
// STRING: LEGO1 0x100f3ce0
const char* g_varJSFRNTY5 = "c_jsfrnty5";
// GLOBAL: LEGO1 0x100f7abc
// STRING: LEGO1 0x100f3ca4
const char* g_varJSWNSHY5 = "c_jswnshy5";
// FUNCTION: LEGO1 0x1007e3b0 // FUNCTION: LEGO1 0x1007e3b0
Jetski::Jetski() Jetski::Jetski()
{ {
this->m_maxLinearVel = 25.0; m_maxLinearVel = 25.0;
this->m_unk0x150 = 2.0; m_unk0x150 = 2.0;
this->m_unk0x148 = 1; m_unk0x148 = 1;
} }
// STUB: LEGO1 0x1007e630 // FUNCTION: LEGO1 0x1007e630
MxResult Jetski::Create(MxDSAction& p_dsAction) MxResult Jetski::Create(MxDSAction& p_dsAction)
{ {
// TODO MxResult result = IslePathActor::Create(p_dsAction);
return SUCCESS; m_world = CurrentWorld();
if (m_world) {
m_world->Add(this);
}
VariableTable()->SetVariable(g_varJETFUEL, "0.8");
return result;
} }
// STUB: LEGO1 0x1007e680 // FUNCTION: LEGO1 0x1007e680
void Jetski::VTable0x70(float p_float) void Jetski::VTable0x70(float p_time)
{ {
// TODO IslePathActor::VTable0x70(p_time);
char buf[200];
float speed = abs(m_worldSpeed);
float maxLinearVel = NavController()->GetMaxLinearVel();
sprintf(buf, "%g", speed / maxLinearVel);
VariableTable()->SetVariable(g_varJETSPEED, buf);
} }
// STUB: LEGO1 0x1007e6f0 // FUNCTION: LEGO1 0x1007e6f0
void Jetski::Exit() void Jetski::Exit()
{ {
// TODO SpawnPlayer(LegoGameState::e_unk45, FALSE, c_spawnBit1 | c_playMusic | c_spawnBit3);
IslePathActor::Exit();
GameState()->m_currentArea = LegoGameState::e_jetski;
RemoveFromWorld();
EnableAnimations(TRUE);
SetIsWorldActive(TRUE);
ControlManager()->Unregister(this);
} }
// STUB: LEGO1 0x1007e750 // FUNCTION: LEGO1 0x1007e750
// FUNCTION: BETA10 0x10037621
MxLong Jetski::HandleClick() MxLong Jetski::HandleClick()
{ {
// TODO if (!FUN_1003ef60()) {
return 0; return 1;
}
FUN_10015820(TRUE, 0);
((Isle*) CurrentWorld())->SetDestLocation(LegoGameState::Area::e_jetski);
TransitionManager()->StartTransition(MxTransitionManager::e_mosaic, 50, FALSE, TRUE);
if (GameState()->GetActorId() != UserActor()->GetActorId()) {
((IslePathActor*) UserActor())->Exit();
}
// TODO: Match
m_unk0x160 = ((DuneBuggy::GetColorOffset(g_varJSWNSHY5) * 5 + 15) * 2);
m_unk0x160 += DuneBuggy::GetColorOffset(g_varJSFRNTY5);
InvokeAction(Extra::ActionType::e_start, *g_isleScript, m_unk0x160, NULL);
InvokeAction(Extra::ActionType::e_start, *g_isleScript, IsleScript::c_JetskiDashboard, NULL);
GetCurrentAction().SetObjectId(-1);
AnimationManager()->FUN_1005f6d0(FALSE);
AnimationManager()->FUN_10064670(NULL);
Enter();
ControlManager()->Register(this);
return 1;
} }
// STUB: LEGO1 0x1007e8e0 // FUNCTION: LEGO1 0x1007e880
void Jetski::RemoveFromWorld()
{
RemoveFromCurrentWorld(*g_isleScript, m_unk0x160);
RemoveFromCurrentWorld(*g_isleScript, IsleScript::c_JetskiArms_Ctl);
RemoveFromCurrentWorld(*g_isleScript, IsleScript::c_JetskiInfo_Ctl);
RemoveFromCurrentWorld(*g_isleScript, IsleScript::c_JetskiSpeedMeter);
RemoveFromCurrentWorld(*g_isleScript, IsleScript::c_JetskiFuelMeter);
}
// FUNCTION: LEGO1 0x1007e8e0
MxLong Jetski::HandleControl(LegoControlManagerNotificationParam& p_param) MxLong Jetski::HandleControl(LegoControlManagerNotificationParam& p_param)
{ {
// TODO if (p_param.GetUnknown0x28() == 1 && CurrentWorld()->IsA("Isle")) {
switch (p_param.GetClickedObjectId()) {
case IsleScript::c_JetskiArms_Ctl:
Exit();
((IslePathActor*) UserActor())
->SpawnPlayer(LegoGameState::e_jetraceExterior, TRUE, c_spawnBit1 | c_playMusic | c_spawnBit3);
GameState()->m_currentArea = LegoGameState::e_unk66;
return 1;
case IsleScript::c_JetskiInfo_Ctl:
((Isle*) CurrentWorld())->SetDestLocation(LegoGameState::e_infomain);
TransitionManager()->StartTransition(MxTransitionManager::e_mosaic, 50, FALSE, FALSE);
Exit();
return 1;
}
}
return 0; return 0;
} }
// STUB: LEGO1 0x1007e990 // FUNCTION: LEGO1 0x1007e990
void Jetski::FUN_1007e990() void Jetski::ActivateSceneActions()
{ {
// TODO PlayMusic(JukeboxScript::c_JetskiRace_Music);
Act1State* act1state = (Act1State*) GameState()->GetState("Act1State");
if (!act1state->m_unk0x018) {
if (act1state->m_unk0x022) {
PlayCamAnim(this, FALSE, 68, TRUE);
}
else {
act1state->m_unk0x022 = TRUE;
LegoPathActor* user = UserActor();
if (user != NULL) {
MxMatrix mat(user->GetROI()->GetLocal2World());
mat.TranslateBy(mat[2][0] * 2.5, mat[2][1] + 0.6, mat[2][2] * 2.5);
AnimationManager()
->FUN_10060dc0(IsleScript::c_sjs007in_RunAnim, &mat, TRUE, FALSE, NULL, FALSE, TRUE, TRUE, TRUE);
}
}
}
} }

View file

@ -16,6 +16,14 @@ DECOMP_SIZE_ASSERT(CursorVariable, 0x24)
DECOMP_SIZE_ASSERT(WhoAmIVariable, 0x24) DECOMP_SIZE_ASSERT(WhoAmIVariable, 0x24)
DECOMP_SIZE_ASSERT(CustomizeAnimFileVariable, 0x24) DECOMP_SIZE_ASSERT(CustomizeAnimFileVariable, 0x24)
// GLOBAL: LEGO1 0x100f7ab0
// STRING: LEGO1 0x100f09c0
const char* g_varJETSPEED = "jetSPEED";
// GLOBAL: LEGO1 0x100f7ab4
// STRING: LEGO1 0x100f7aa8
const char* g_varJETFUEL = "jetFUEL";
// GLOBAL: LEGO1 0x100f7658 // GLOBAL: LEGO1 0x100f7658
// STRING: LEGO1 0x100f764c // STRING: LEGO1 0x100f764c
const char* g_varDUNESPEED = "duneSPEED"; const char* g_varDUNESPEED = "duneSPEED";

View file

@ -1044,7 +1044,7 @@ MxLong Isle::HandleTransitionEnd()
FUN_10032d30((IsleScript::Script) m_jetski->GetUnknown0x160(), JukeboxScript::c_MusicTheme1, NULL, TRUE); FUN_10032d30((IsleScript::Script) m_jetski->GetUnknown0x160(), JukeboxScript::c_MusicTheme1, NULL, TRUE);
if (!m_act1state->m_unk0x01f) { if (!m_act1state->m_unk0x01f) {
m_jetski->FUN_1007e990(); m_jetski->ActivateSceneActions();
} }
break; break;
default: default: