/** * @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(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 };