/** * @file d_a_obj_bubblePilar.cpp * */ #include "d/dolzel_rel.h" // IWYU pragma: keep #include "d/actor/d_a_obj_bubblePilar.h" #include "d/d_com_inf_game.h" #include "d/d_bg_w.h" static daBubbPilar_HIO_c l_HIO; const dCcD_SrcGObjInf daBubbPilar_c::mCcDObjInfo = { {0, {{0, 0, 0}, {0x20, 0x11}, {0}}}, {dCcD_SE_NONE, 0, 1, 0, 0}, {dCcD_SE_NONE, 0, 0, 0, 2}, {0}, }; dCcD_SrcCyl daBubbPilar_c::mCcDCyl = { daBubbPilar_c::mCcDObjInfo, { {{0.0f, 0.0f, 0.0f}, 0.0f, 0.0f} } }; daBubbPilar_HIO_c::daBubbPilar_HIO_c() { field_0x4 = 20; field_0x5 = 0; } void daBubbPilar_c::setBaseMtx() { mDoMtx_stack_c::transS(current.pos.x, current.pos.y, current.pos.z); mDoMtx_stack_c::ZXYrotM(shape_angle.x, shape_angle.y, shape_angle.z); mDoMtx_stack_c::scaleM(scale.x, scale.y, scale.z); cXyz baseScale(1.0f, 1.0f, 1.0f); mModels[mModelMode]->setBaseScale(baseScale); mModels[mModelMode]->setBaseTRMtx(mDoMtx_stack_c::get()); } int daBubbPilar_c::CreateHeap() { J3DModelData* modelData = (J3DModelData*)dComIfG_getObjectRes("M_Crack", 4); JUT_ASSERT(226, modelData != NULL); mModels[MODE_WAIT] = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084); if (mModels[MODE_WAIT] == NULL) { return 0; } modelData = (J3DModelData*)dComIfG_getObjectRes("M_Crack", 5); JUT_ASSERT(237, modelData != NULL); mModels[MODE_EFF_ON] = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084); if (mModels[MODE_EFF_ON] == NULL) { return 0; } return 1; } int daBubbPilar_c::create() { fopAcM_ct(this, daBubbPilar_c); int rv = dComIfG_resLoad(&mPhase, "M_Crack"); switch (rv) { case cPhs_COMPLEATE_e: if (MoveBGCreate("M_Crack", 8, dBgS_MoveBGProc_Typical, 0x1900, NULL) == cPhs_ERROR_e) { return cPhs_ERROR_e; } mStts.Init(200, 0xff, this); mCyl.Set(mCcDCyl); mCyl.SetStts(&mStts); mArg0 = getArg0(); mSw = getSw(); if (mArg0 != 0) { if (mpBgW != NULL) { dComIfG_Bgsp().Release(mpBgW); } mCyl.OffTgSetBit(); } if (mSw == 0xff) { initModeEffOn(); mModelMode = MODE_EFF_ON; } else { mIsSw = fopAcM_isSwitch(this, mSw); if (mIsSw != 0) { initModeEffOn(); mModelMode = MODE_EFF_ON; } else { initModeWait(); mModelMode = MODE_WAIT; } } fopAcM_SetMtx(this, mModels[mModelMode]->getBaseTRMtx()); fopAcM_setCullSizeBox2(this, mModels[mModelMode]->getModelData()); setBaseMtx(); for (int i = 0; i < 4; i++) { mEmitters[i] = NULL; } rv = cPhs_COMPLEATE_e; break; } return rv; } int daBubbPilar_c::Execute(Mtx** param_1) { static daBubbPilar_c::modeProc const mode_proc[2] = { &daBubbPilar_c::modeWait, &daBubbPilar_c::modeEffOn, }; if (mSw != 0xff) { u8 prevIsSw = mIsSw; mIsSw = fopAcM_isSwitch(this, mSw); if (prevIsSw != mIsSw) { if (mIsSw != 0) { initModeEffOn(); } else { initModeWait(); } } } (this->*(mode_proc[mMode]))(); if (dKy_camera_water_in_status_check()) { for (int i = 0; i < 4; i++) { if (mEmitters[i] != NULL) { mEmitters[i]->setGlobalAlpha(0xff); } } } else { for (int i = 0; i < 4; i++) { if (mEmitters[i] != NULL) { mEmitters[i]->setGlobalAlpha(0x20); } } } *param_1 = &mModels[mModelMode]->getBaseTRMtx(); setBaseMtx(); return 1; } void daBubbPilar_c::initModeWait() { mMode = 0; } void daBubbPilar_c::modeWait() { if (mArg0 == 0) { s8 reverb = dComIfGp_getReverb(fopAcM_GetRoomNo(this)); mDoAud_seStartLevel(Z2SE_OBJ_WTR_STREAM_S, ¤t.pos, 0, reverb); mEmitterId = dComIfGp_particle_set(mEmitterId, 0x88bd, ¤t.pos, &shape_angle, &scale); mEmitters[3] = (JPABaseEmitter*)dComIfGp_particle_getEmitter(mEmitterId); if (mCyl.ChkTgHit()) { if ((mCyl.GetTgHitGObj()->GetAtType() & AT_TYPE_BOMB) != 0) { mModelMode = MODE_EFF_ON; fopAcM_SetMtx(this, mModels[mModelMode]->getBaseTRMtx()); fopAcM_setCullSizeBox2(this, mModels[mModelMode]->getModelData()); fopAcM_onSwitch(this, mSw); } } mCyl.SetR(100.0f); mCyl.SetH(100.0f); mCyl.SetC(current.pos); dComIfG_Ccsp()->Set(&mCyl); } } void daBubbPilar_c::initModeEffOn() { if (mArg0 == 0) { mCyl.OffTgSetBit(); } mMode = 1; } static u16 const particle_id[3] = { 0x88BE, 0x88BF, 0x88C0, }; void daBubbPilar_c::modeEffOn() { s8 reverb = dComIfGp_getReverb(fopAcM_GetRoomNo(this)); mDoAud_seStartLevel(Z2SE_OBJ_WTR_STREAM, ¤t.pos, 0, reverb); for (int i = 0; i < 3; i = i + 1) { mEmitterIds[i] = dComIfGp_particle_set( mEmitterIds[i], particle_id[i], ¤t.pos, &shape_angle, &scale); mEmitters[i] = dComIfGp_particle_getEmitter(mEmitterIds[i]); } } int daBubbPilar_c::Draw() { if (mArg0 == 0) { g_env_light.settingTevStruct(0x10, ¤t.pos, &tevStr); g_env_light.setLightTevColorType_MAJI(mModels[mModelMode], &tevStr); dKy_bg_MAxx_proc(mModels[mModelMode]); dComIfGd_setListBG(); mDoExt_modelUpdateDL(mModels[mModelMode]); dComIfGd_setList(); } return 1; } int daBubbPilar_c::Delete() { dComIfG_resDelete(&mPhase, "M_Crack"); return 1; } static int daBubbPilar_Draw(daBubbPilar_c* i_this) { return i_this->MoveBGDraw(); } static int daBubbPilar_Execute(daBubbPilar_c* i_this) { return i_this->MoveBGExecute(); } static int daBubbPilar_Delete(daBubbPilar_c* i_this) { return i_this->MoveBGDelete(); } static int daBubbPilar_Create(fopAc_ac_c* i_this) { return static_cast(i_this)->create(); } static actor_method_class l_daBubbPilar_Method = { (process_method_func)daBubbPilar_Create, (process_method_func)daBubbPilar_Delete, (process_method_func)daBubbPilar_Execute, NULL, (process_method_func)daBubbPilar_Draw, }; actor_process_profile_definition g_profile_Obj_awaPlar = { /* Layer ID */ fpcLy_CURRENT_e, /* List ID */ 7, /* List Prio */ fpcPi_CURRENT_e, /* Proc Name */ fpcNm_Obj_awaPlar_e, /* Proc SubMtd */ &g_fpcLf_Method.base, /* Size */ sizeof(daBubbPilar_c), /* Size Other */ 0, /* Parameters */ 0, /* Leaf SubMtd */ &g_fopAc_Method.base, /* Draw Prio */ fpcDwPi_Obj_awaPlar_e, /* Actor SubMtd */ &l_daBubbPilar_Method, /* Status */ fopAcStts_UNK_0x40000_e | fopAcStts_UNK_0x4000_e, /* Group */ fopAc_ACTOR_e, /* Cull Type */ fopAc_CULLBOX_CUSTOM_e, };