mirror of
https://github.com/zeldaret/tp
synced 2026-06-02 10:10:35 -04:00
877889c510
* Remove NDEBUG_DEFINED fakematch, clean up getName temps * Fix ifdef * Fix bad JSystem pch ifdef breaking decomp.me * Remove Acch Chk fakematches * Private Acch fields * Fix some clangd errors in headers * Add UNUSED macro for matching debug parameters * Enable clangd unused-parameter warning * Remove extern from initializers Probably added by dol2asm? * Fix process profile definitions * Remove leftover dol2asm address comments * Remove some unnecessary double casts * Enable some more clangd warnings * Fix missing usages of fopAcM_ct * Fix wrong enum usage * Fix more fakematches
435 lines
13 KiB
C++
435 lines
13 KiB
C++
/**
|
|
* @file d_a_obj_Turara.cpp
|
|
*
|
|
*/
|
|
|
|
#include "d/dolzel_rel.h" // IWYU pragma: keep
|
|
|
|
#include "d/actor/d_a_obj_Turara.h"
|
|
#include "SSystem/SComponent/c_math.h"
|
|
|
|
class daTurara_HIO_c : public fOpAcm_HIO_entry_c {
|
|
public:
|
|
daTurara_HIO_c();
|
|
virtual ~daTurara_HIO_c() {}
|
|
|
|
void genMessage(JORMContext*);
|
|
|
|
/* 0x04 */ f32 field_0x04;
|
|
/* 0x08 */ f32 mGravity;
|
|
/* 0x0c */ f32 mMaxGravity;
|
|
/* 0x10 */ u8 mWaitTime;
|
|
/* 0x11 */ u8 mShockStrength;
|
|
/* 0x14 */ f32 field_0x14;
|
|
/* 0x18 */ f32 field_0x18;
|
|
/* 0x1c */ f32 field_0x1c;
|
|
};
|
|
|
|
STATIC_ASSERT(sizeof(daTurara_HIO_c) == 0x20);
|
|
|
|
daTurara_HIO_c::daTurara_HIO_c() {
|
|
field_0x04 = 450.f;
|
|
mGravity = 10.0f;
|
|
mMaxGravity = 200.0f;
|
|
mWaitTime = 0x1e;
|
|
field_0x14 = 5.0f;
|
|
mShockStrength = 0x4;
|
|
field_0x18 = 3.0f;
|
|
field_0x1c = 5.0f;
|
|
}
|
|
|
|
void daTurara_c::setBaseMtx() {
|
|
mDoMtx_stack_c::transS(current.pos.x, current.pos.y, current.pos.z);
|
|
mDoMtx_stack_c::ZXYrotM(0, shape_angle.y, 0);
|
|
mDoMtx_stack_c::ZXYrotM(field_0x750, field_0x752, field_0x754);
|
|
mDoMtx_stack_c::transM(field_0x758, field_0x75c, field_0x760);
|
|
mpModel[field_0x984]->setBaseScale(scale);
|
|
mpModel[field_0x984]->setBaseTRMtx(mDoMtx_stack_c::get());
|
|
MTXCopy(mDoMtx_stack_c::get(), mBgMtx);
|
|
}
|
|
|
|
static daTurara_HIO_c l_HIO;
|
|
|
|
const dCcD_SrcGObjInf daTurara_c::mCcDObjInfo = {
|
|
{0, // mFlags
|
|
{
|
|
{0x20, 0x1, 0x1f}, // mObjAt
|
|
{0xF8400022, 0x11}, // mObjTg
|
|
{0x79} // mObjCo
|
|
} // mSrcObjHitInf
|
|
}, // mObj
|
|
{1, 0, 1, 0, 0}, // mGObjAt
|
|
{0xA, 0, 0, 0, 2}, // mGObjTg
|
|
{0} // mGObjCo
|
|
};
|
|
|
|
dCcD_SrcCyl daTurara_c::mCcDCyl = {
|
|
daTurara_c::mCcDObjInfo, // mObjInf
|
|
{
|
|
{0.0f, 0.0f, 0.0f}, // mCenter
|
|
0.0f, // mRadius
|
|
0.0f // mHeight
|
|
} // mCyl
|
|
};
|
|
|
|
static u32 const l_bmdIdx[2] = {5, 8};
|
|
|
|
int daTurara_c::CreateHeap() {
|
|
J3DModelData* modelData = (J3DModelData*) dComIfG_getObjectRes("M_Turara", l_bmdIdx[field_0x98c]);
|
|
JUT_ASSERT(260, modelData != NULL);
|
|
|
|
if (field_0x98c == 0) {
|
|
mpModel[0] = mDoExt_J3DModel__create(modelData, 0, 0x11000084);
|
|
} else {
|
|
mpModel[0] = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084);
|
|
}
|
|
if (mpModel[0] == NULL) {
|
|
return 0;
|
|
}
|
|
|
|
modelData = (J3DModelData*) dComIfG_getObjectRes("M_Turara", 9);
|
|
JUT_ASSERT(279, modelData != NULL);
|
|
mpModel[1] = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084);
|
|
if (mpModel[1] == NULL) {
|
|
return 0;
|
|
}
|
|
field_0x980 = new dBgW;
|
|
if (field_0x980 == NULL || field_0x980->Set((cBgD_t *)dComIfG_getObjectRes("M_Turara", 0xd),
|
|
1, &mBgMtx) != 0) {
|
|
field_0x980 = NULL;
|
|
return 0;
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
int daTurara_c::create() {
|
|
fopAcM_ct(this, daTurara_c);
|
|
if (fopAcM_isSwitch(this, getSwBit3())) {
|
|
return cPhs_ERROR_e;
|
|
}
|
|
int phase = dComIfG_resLoad(&mPhaseReq,"M_Turara");
|
|
if (phase == cPhs_COMPLEATE_e) {
|
|
u8 r26 = 0;
|
|
field_0x98c = getState();
|
|
if (field_0x98c != 0) {
|
|
if (field_0x98c == 1) {
|
|
r26 = 1;
|
|
fopAcM_onSwitch(this, getSwBit1());
|
|
}
|
|
fopAcM_SetGroup(this,0);
|
|
field_0x98c = 1;
|
|
} else {
|
|
fopAcM_SetGroup(this,2);
|
|
}
|
|
if (MoveBGCreate("M_Turara", 0xc, dBgS_MoveBGProc_TypicalRotY, 0x2180, NULL) == cPhs_ERROR_e) {
|
|
return cPhs_ERROR_e;
|
|
}
|
|
mAcchCir.SetWall(150.0f, 150.0f);
|
|
mAcch.Set(fopAcM_GetPosition_p(this), fopAcM_GetOldPosition_p(this), this, 1, &mAcchCir,
|
|
fopAcM_GetSpeed_p(this), NULL, NULL);
|
|
mAcch.SetWaterCheckOffset(10000.0f);
|
|
field_0x748 = 0;
|
|
field_0x750 = 0;
|
|
field_0x752 = 0;
|
|
field_0x754 = 0;
|
|
field_0x758 = 0.0f;
|
|
field_0x75c = 0.0f;
|
|
field_0x760 = 0.0f;
|
|
mColliderStts.Init(0xff, 0xff, this);
|
|
mCylCollider.Set(mCcDCyl);
|
|
mCylCollider.SetStts(&mColliderStts);
|
|
mCylCollider.OffAtSetBit();
|
|
if (fopAcM_isSwitch(this, getSwBit1())) {
|
|
field_0x984 = 1;
|
|
mCylCollider.OffCoSetBit();
|
|
if (mpBgW) {
|
|
dComIfG_Bgsp().Release(mpBgW);
|
|
}
|
|
if (field_0x980) {
|
|
dComIfG_Bgsp().Regist(field_0x980, this);
|
|
field_0x980->Move();
|
|
}
|
|
if (r26) {
|
|
mMode = 3;
|
|
} else {
|
|
setFallStat();
|
|
}
|
|
} else {
|
|
field_0x984 = 0;
|
|
field_0x5c9 = getSwBit2();
|
|
init_modeWait();
|
|
}
|
|
fopAcM_SetMtx(this, mpModel[field_0x984]->getBaseTRMtx());
|
|
fopAcM_setCullSizeBox2(this, mpModel[field_0x984]->getModelData());
|
|
setBaseMtx();
|
|
field_0x994 = 1;
|
|
#if DEBUG
|
|
l_HIO.entryHIO("つらら");
|
|
#endif
|
|
}
|
|
return phase;
|
|
}
|
|
|
|
void daTurara_c::setFallStat() {
|
|
mAcch.CrrPos(dComIfG_Bgsp());
|
|
current.pos.y = mAcch.GetGroundH();
|
|
mAcch.CrrPos(dComIfG_Bgsp());
|
|
mMode = 3;
|
|
}
|
|
|
|
int daTurara_c::Execute(Mtx** i_mtx) {
|
|
eventUpdate();
|
|
move();
|
|
*i_mtx = &mpModel[field_0x984]->getBaseTRMtx();
|
|
mInWater = mAcch.ChkWaterIn();
|
|
setBaseMtx();
|
|
mColliderStts.Move();
|
|
return 1;
|
|
}
|
|
|
|
void daTurara_c::move() {
|
|
typedef void (daTurara_c::*modeFunc)();
|
|
static modeFunc mode_proc[] = {&daTurara_c::modeWait, &daTurara_c::modeDropInit,
|
|
&daTurara_c::modeDrop, &daTurara_c::modeDropEnd,
|
|
&daTurara_c::modeDropEnd2};
|
|
(this->*mode_proc[mMode])();
|
|
field_0x750 = field_0x74c * cM_scos(field_0x748 * 0x3000);
|
|
field_0x754 = field_0x74c * cM_ssin(field_0x748 * 0x3000);
|
|
cLib_addCalc0(&field_0x74c, 0.1f, 10.0f);
|
|
field_0x748 += 1;
|
|
if (field_0x984 == 0) {
|
|
mCylCollider.SetR(170.0f);
|
|
} else {
|
|
mCylCollider.SetR(130.0f);
|
|
}
|
|
mCylCollider.SetH(510.0f);
|
|
cXyz sp08(current.pos);
|
|
sp08.y -= 50.0f;
|
|
mCylCollider.SetC(sp08);
|
|
dComIfG_Ccsp()->Set(&mCylCollider);
|
|
}
|
|
|
|
void daTurara_c::init_modeWait() {
|
|
mMode = 0;
|
|
}
|
|
|
|
void daTurara_c::modeWait() {
|
|
if (field_0x5c9 != 0xff && fopAcM_isSwitch(this, field_0x5c9)) {
|
|
if (getEvetID() != 0xff) {
|
|
orderEvent(getEvetID(), 0xFF, 1);
|
|
} else {
|
|
eventStart();
|
|
}
|
|
}
|
|
if (mCylCollider.ChkTgHit()) {
|
|
dCcD_GObjInf* r29 = mCylCollider.GetTgHitGObj();
|
|
if (r29->GetAtType() == AT_TYPE_BOMB) {
|
|
if (getEvetID() != 0xff) {
|
|
orderEvent(getEvetID(), 0xFF, 1);
|
|
} else {
|
|
eventStart();
|
|
}
|
|
} else if (r29->GetAtType() == AT_TYPE_IRON_BALL) {
|
|
dComIfGp_particle_set(0x8a8f, ¤t.pos, NULL, NULL);
|
|
dComIfGp_particle_set(0x8a90, ¤t.pos, NULL, NULL);
|
|
dComIfGp_particle_set(0x8a91, ¤t.pos, NULL, NULL);
|
|
mDoAud_seStart(Z2SE_OBJ_ICICLE_BRK, ¤t.pos, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this)));
|
|
fopAcM_onSwitch(this, getSwBit3());
|
|
fopAcM_delete(this);
|
|
}
|
|
}
|
|
}
|
|
|
|
bool daTurara_c::eventStart() {
|
|
init_modeDropInit();
|
|
return true;
|
|
}
|
|
|
|
void daTurara_c::init_modeDropInit() {
|
|
if (field_0x98c == 0) {
|
|
mWaitTime = getWaitTime();
|
|
} else {
|
|
mWaitTime = l_HIO.mWaitTime;
|
|
}
|
|
field_0x74c = l_HIO.field_0x04;
|
|
mMode = 1;
|
|
}
|
|
|
|
void daTurara_c::modeDropInit() {
|
|
if (mWaitTime != 0) {
|
|
mWaitTime -= 1;
|
|
} else {
|
|
field_0x74c = 0.0f;
|
|
init_modeDrop();
|
|
}
|
|
}
|
|
|
|
void daTurara_c::init_modeDrop() {
|
|
fopAcM_SetGravity(this, -l_HIO.mGravity);
|
|
fopAcM_SetMaxFallSpeed(this, -l_HIO.mMaxGravity);
|
|
fopAcM_SetSpeedF(this, 0.0f);
|
|
fopAcM_SetMtx(this, mpModel[field_0x984]->getBaseTRMtx());
|
|
fopAcM_setCullSizeBox2(this, mpModel[field_0x984]->getModelData());
|
|
mCylCollider.OnAtSetBit();
|
|
mpBgW->OffRoofRegist();
|
|
s8 roomNo = fopAcM_GetRoomNo(this);
|
|
mDoAud_seStart(Z2SE_OBJ_ICICLE_FALL, ¤t.pos, 0, dComIfGp_getReverb(roomNo));
|
|
mMode = 2;
|
|
}
|
|
|
|
void daTurara_c::modeDrop() {
|
|
fopAcM_posMoveF(this, mColliderStts.GetCCMoveP());
|
|
mAcch.CrrPos(dComIfG_Bgsp());
|
|
bgCheck();
|
|
}
|
|
|
|
void daTurara_c::bgCheck() {
|
|
if (mAcch.ChkGroundHit() & 0xff) {
|
|
if (field_0x98c == 0) {
|
|
init_modeDropEnd2();
|
|
} else {
|
|
init_modeDropEnd();
|
|
}
|
|
}
|
|
}
|
|
|
|
void daTurara_c::init_modeDropEnd() {
|
|
if (mAcch.ChkWaterIn() == 0) {
|
|
dComIfGp_getVibration().StartShock(l_HIO.mShockStrength, 0xf, cXyz(0.0f, 1.0f, 0.0f));
|
|
}
|
|
dComIfGp_particle_set(0x8a8f, ¤t.pos, NULL, NULL);
|
|
dComIfGp_particle_set(0x8a90, ¤t.pos, NULL, NULL);
|
|
dComIfGp_particle_set(0x8a91, ¤t.pos, NULL, NULL);
|
|
dComIfGp_particle_set(0x8a92, ¤t.pos, NULL, NULL);
|
|
field_0x984 = 1;
|
|
if (mpBgW) {
|
|
dComIfG_Bgsp().Release(mpBgW);
|
|
}
|
|
if (field_0x980) {
|
|
dComIfG_Bgsp().Regist(field_0x980, this);
|
|
field_0x980->Move();
|
|
}
|
|
mCylCollider.OffCoSetBit();
|
|
mCylCollider.OffAtSetBit();
|
|
fopAcM_onSwitch(this, getSwBit1());
|
|
mDoAud_seStart(Z2SE_OBJ_ICICLE_LAND, ¤t.pos, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this)));
|
|
mMode = 3;
|
|
}
|
|
|
|
void daTurara_c::modeDropEnd() {
|
|
if (mCylCollider.ChkTgHit()) {
|
|
dCcD_GObjInf* r29 = mCylCollider.GetTgHitGObj();
|
|
if ((r29->GetAtType() & AT_TYPE_UNK) || (r29->GetAtType() & AT_TYPE_20000000)) {
|
|
if (field_0x980) {
|
|
dComIfG_Bgsp().Release(field_0x980);
|
|
field_0x980->Move();
|
|
}
|
|
csXyz sp10(0, home.angle.y, 0);
|
|
fopAcM_createItemFromTable(¤t.pos, getItemTbleNum(), -1,
|
|
fopAcM_GetHomeRoomNo(this), &sp10, 0, (cXyz*)NULL,
|
|
NULL, NULL, false);
|
|
}
|
|
dComIfGp_particle_set(0x8a8f, ¤t.pos, NULL, NULL);
|
|
dComIfGp_particle_set(0x8a90, ¤t.pos, NULL, NULL);
|
|
dComIfGp_particle_set(0x8a91, ¤t.pos, NULL, NULL);
|
|
mDoAud_seStart(Z2SE_OBJ_ICICLE_BRK, ¤t.pos, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this)));
|
|
fopAcM_onSwitch(this, getSwBit3());
|
|
fopAcM_delete(this);
|
|
}
|
|
}
|
|
|
|
void daTurara_c::init_modeDropEnd2() {
|
|
if (mAcch.ChkWaterIn() == 0) {
|
|
dComIfGp_getVibration().StartShock(l_HIO.mShockStrength, 0xf, cXyz(0.0f, 1.0f, 0.0f));
|
|
}
|
|
if (mpBgW) {
|
|
dComIfG_Bgsp().Release(mpBgW);
|
|
}
|
|
mCylCollider.OffCoSetBit();
|
|
mCylCollider.OffAtSetBit();
|
|
mDoAud_seStart(Z2SE_OBJ_ICICLE_BRK, ¤t.pos, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this)));
|
|
current.pos.y -= 100.0f;
|
|
cXyz first_vec(current.pos);
|
|
first_vec.y += 100.0f;
|
|
mEmID = fopAcM_create(PROC_E_KK, getSwBit1() << 0x10 | 3, &first_vec, fopAcM_GetRoomNo(this), 0, 0, -1);
|
|
JUT_ASSERT(770, mEmID != fpcM_ERROR_PROCESS_ID_e);
|
|
cXyz second_vec(0.7f, 0.7f, 0.7f);
|
|
dComIfGp_particle_set(0x8a8f, &first_vec, NULL, &second_vec);
|
|
dComIfGp_particle_set(0x8a90, &first_vec, NULL, &second_vec);
|
|
dComIfGp_particle_set(0x8a91, &first_vec, NULL, &second_vec);
|
|
dComIfGp_particle_set(0x8a92, &first_vec, NULL, &second_vec);
|
|
fopAcM_onSwitch(this, getSwBit3());
|
|
field_0x994 = 0;
|
|
mMode = 4;
|
|
}
|
|
|
|
void daTurara_c::modeDropEnd2() {
|
|
if (fopAcM_SearchByID(mEmID)) {
|
|
fopAcM_delete(this);
|
|
}
|
|
}
|
|
|
|
int daTurara_c::Draw() {
|
|
g_env_light.settingTevStruct(0x10, ¤t.pos, &tevStr);
|
|
g_env_light.setLightTevColorType_MAJI(mpModel[field_0x984], &tevStr);
|
|
if (field_0x98c == 0) {
|
|
fopAcM_setEffectMtx(this, mpModel[field_0x984]->getModelData());
|
|
}
|
|
|
|
dComIfGd_setListBG();
|
|
if (field_0x994) {
|
|
mDoExt_modelUpdateDL(mpModel[field_0x984]);
|
|
}
|
|
dComIfGd_setList();
|
|
return 1;
|
|
}
|
|
|
|
int daTurara_c::Delete() {
|
|
dComIfG_resDelete(&mPhaseReq, "M_Turara");
|
|
if (field_0x980 && field_0x980->ChkUsed()) {
|
|
dComIfG_Bgsp().Release(field_0x980);
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
static int daTurara_Draw(daTurara_c* i_this) {
|
|
return i_this->Draw();
|
|
}
|
|
|
|
static int daTurara_Execute(daTurara_c* i_this) {
|
|
return i_this->MoveBGExecute();
|
|
}
|
|
|
|
static int daTurara_Delete(daTurara_c* i_this) {
|
|
return i_this->MoveBGDelete();
|
|
}
|
|
|
|
static int daTurara_Create(fopAc_ac_c* i_this) {
|
|
return static_cast<daTurara_c*>(i_this)->create();
|
|
}
|
|
|
|
static actor_method_class l_daTurara_Method = {
|
|
(process_method_func)daTurara_Create,
|
|
(process_method_func)daTurara_Delete,
|
|
(process_method_func)daTurara_Execute,
|
|
0,
|
|
(process_method_func)daTurara_Draw,
|
|
};
|
|
|
|
actor_process_profile_definition g_profile_Obj_Turara = {
|
|
fpcLy_CURRENT_e, // mLayerID
|
|
3, // mListID
|
|
fpcPi_CURRENT_e, // mListPrio
|
|
PROC_Obj_Turara, // mProcName
|
|
&g_fpcLf_Method.base, // sub_method
|
|
sizeof(daTurara_c), // mSize
|
|
0, // mSizeOther
|
|
0, // mParameters
|
|
&g_fopAc_Method.base, // sub_method
|
|
545, // mPriority
|
|
&l_daTurara_Method, // sub_method
|
|
0x00044100, // mStatus
|
|
fopAc_ACTOR_e, // mActorType
|
|
fopAc_CULLBOX_CUSTOM_e, // cullType
|
|
};
|