/** * @file d_a_obj_rotTrap.cpp * */ #include "d/dolzel_rel.h" // IWYU pragma: keep #include "d/actor/d_a_obj_rotTrap.h" #include "d/d_s_play.h" daRotTrap_HIO_c::daRotTrap_HIO_c() { vibration = 3; rotate_time = 4.5f; field_0x8 = 10; AT_adjust_SW = 0; index = 0; acc = 150; } static daRotTrap_HIO_c l_HIO; dCcD_SrcGObjInf const daRotTrap_c::mCcDObjInfo = { {0, {{AT_TYPE_800, 0x1, 0x1F}, {0x0, 0x0}, {0}}}, {dCcD_SE_SWORD, 0, 1, 0, 0}, {dCcD_SE_STONE, 0, 0, 0, 0}, {0} }; dCcD_SrcCyl daRotTrap_c::mCcDCyl = { mCcDObjInfo, { {{0.0f, 0.0f, 0.0f}, 0.0f, 0.0f} } }; static Vec atPos[] = { {-37.0f, 130.0f, -200.0f}, {-37.0f, 130.0f, -300.0f}, {-37.0f, 130.0f, -400.0f}, {-37.0f, 130.0f, -500.0f}, {-37.0f, 130.0f, -600.0f}, {-37.0f, 130.0f, -700.0f}, {-37.0f, 130.0f, -800.0f}, {37.0f, 130.0f, 200.0f}, {37.0f, 130.0f, 300.0f}, {37.0f, 130.0f, 400.0f}, {37.0f, 130.0f, 500.0f}, {37.0f, 130.0f, 600.0f}, {37.0f, 130.0f, 700.0f}, {37.0f, 130.0f, 800.0f}, }; static f32 atR[] = { 50.0f, 50.0f, 50.0f, 50.0f, 50.0f, 50.0f, 50.0f, 50.0f, 50.0f, 50.0f, 50.0f, 50.0f, 50.0f, 50.0f, }; void daRotTrap_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); mpModel->setBaseScale(scale); mpModel->setBaseTRMtx(mDoMtx_stack_c::get()); MTXCopy(mDoMtx_stack_c::get(), mBgMtx); } int daRotTrap_c::CreateHeap() { J3DModelData* modelData = (J3DModelData*)dComIfG_getObjectRes("P_kama", 4); JUT_ASSERT(214, modelData != NULL); mpModel = mDoExt_J3DModel__create(modelData, J3DMdlFlag_DifferedDLBuffer, BMD_DEFAULT_DIFF_FLAGS); if (mpModel == NULL) { return 0; } mpBgW2 = JKR_NEW dBgW(); if (mpBgW2 == NULL || mpBgW2->Set((cBgD_t*)dComIfG_getObjectRes("P_kama", 8), 1, &mBgMtx)) { mpBgW2 = NULL; return 0; } return 1; } int daRotTrap_c::create() { fopAcM_ct(this, daRotTrap_c); int phase_state = dComIfG_resLoad(&mPhase, "P_kama"); if (phase_state == cPhs_COMPLEATE_e) { if (MoveBGCreate("P_kama", 7, dBgS_MoveBGProc_TypicalRotY, 0x7DF0, NULL) == cPhs_ERROR_e) { return cPhs_ERROR_e; } fopAcM_SetMtx(this, mpModel->getBaseTRMtx()); fopAcM_setCullSizeBox2(this, mpModel->getModelData()); mCcStts.Init(0xFF, 0xFF, this); for (int i = 0; i < 14; i++) { mCcCyl[i].Set(mCcDCyl); mCcCyl[i].SetStts(&mCcStts); } mSwbit = getSw(); if (mSwbit == 0xFF) { init_modeMove(); } else if (fopAcM_isSwitch(this, mSwbit)) { init_modeMove(); } else { init_modeWait(); } setBaseMtx(); } return phase_state; } int daRotTrap_c::Execute(Mtx** param_0) { procMain(); *param_0 = &mpModel->getBaseTRMtx(); setBaseMtx(); mCcStts.Move(); return 1; } void daRotTrap_c::procMain() { static void (daRotTrap_c::*mode_proc[])() = { &daRotTrap_c::modeWait, &daRotTrap_c::modeAcc, &daRotTrap_c::modeMove, }; (this->*mode_proc[mMode])(); #if DEBUG if (l_HIO.AT_adjust_SW == TRUE) { shape_angle.y = 0; } #endif for (int i = 0; i < 14; i++) { #if DEBUG if (l_HIO.AT_adjust_SW == TRUE && i == l_HIO.index) { f32 adjust_value = 1.0f; if (mDoCPd_c::getHoldR(PAD_2)) { adjust_value = 10.0f; } if (mDoCPd_c::getTrigUp(PAD_2)) { atPos[i].z -= adjust_value; } else if (mDoCPd_c::getTrigDown(PAD_2)) { atPos[i].z += adjust_value; } else if (mDoCPd_c::getTrigLeft(PAD_2)) { atPos[i].x -= adjust_value; } else if (mDoCPd_c::getTrigRight(PAD_2)) { atPos[i].x += adjust_value; } else if (mDoCPd_c::getTrigA(PAD_2)) { atPos[i].y += adjust_value; } else if (mDoCPd_c::getTrigB(PAD_2)) { atPos[i].y -= adjust_value; } else if (mDoCPd_c::getTrigX(PAD_2)) { atR[i] += adjust_value; } else if (mDoCPd_c::getTrigY(PAD_2)) { atR[i] -= adjust_value; } OS_REPORT("==%d x:%f y:%f z:%f s:%f ==\n", i, atPos[i].x, atPos[i].y, atPos[i].z, atR[i]); } #endif mDoMtx_stack_c::ZXYrotS(shape_angle.x, shape_angle.y, shape_angle.z); cXyz sp14; cXyz sp8(atPos[i]); mDoMtx_stack_c::multVec(&sp8, &sp14); sp14 += current.pos; mCcCyl[i].SetR(atR[i]); mCcCyl[i].SetH(45.0f + oREG_F(1)); mCcCyl[i].SetC(sp14); dComIfG_Ccsp()->Set(&mCcCyl[i]); } } void daRotTrap_c::init_modeWait() { if (mpBgW != NULL) { dComIfG_Bgsp().Release(mpBgW); } if (mpBgW2 != NULL) { dComIfG_Bgsp().Regist(mpBgW2, this); mpBgW2->Move(); } mMode = 0; } void daRotTrap_c::modeWait() { if (fopAcM_isSwitch(this, mSwbit)) { init_modeAcc(); } if (mpBgW2 != NULL) { mpBgW2->Move(); } } void daRotTrap_c::init_modeAcc() { if (mpBgW2 != NULL) { dComIfG_Bgsp().Release(mpBgW2); mpBgW2->Move(); } if (mpBgW != NULL) { dComIfG_Bgsp().Regist(mpBgW, this); } dComIfGp_getVibration().StartShock(l_HIO.vibration, 0xF, cXyz(0.0f, 1.0f, 0.0f)); field_0x5b0 = cM_deg2s(360.0f / (30.0f * l_HIO.rotate_time)); field_0x5b2 = 0; field_0x5ae = 0; mMode = 1; } void daRotTrap_c::modeAcc() { mDoAud_seStartLevel(Z2SE_OBJ_RL_SWD_LV, ¤t.pos, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this))); BOOL temp_r30 = cLib_chaseAngleS(&field_0x5b2, field_0x5b0, field_0x5b0 / l_HIO.acc); shape_angle.y += field_0x5b2; seSet(); if (temp_r30 == TRUE) { init_modeMove(); } } void daRotTrap_c::init_modeMove() { field_0x5ae = 0; mMode = 2; } void daRotTrap_c::modeMove() { mDoAud_seStartLevel(Z2SE_OBJ_RL_SWD_LV, ¤t.pos, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this))); field_0x5b0 = cM_deg2s(360.0f / (30.0f * l_HIO.rotate_time)); if (0.0f != l_HIO.rotate_time) { shape_angle.y += field_0x5b0; } seSet(); } void daRotTrap_c::seSet() { if (shape_angle.y & 0x8000) { if (field_0x5ae == 0) { mDoAud_seStart(Z2SE_OBJ_RL_SWD_TRG, ¤t.pos, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this))); field_0x5ae = 1; } } else if (field_0x5ae != 0) { mDoAud_seStart(Z2SE_OBJ_RL_SWD_TRG, ¤t.pos, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this))); field_0x5ae = 0; } } int daRotTrap_c::Draw() { g_env_light.settingTevStruct(16, ¤t.pos, &tevStr); g_env_light.setLightTevColorType_MAJI(mpModel, &tevStr); dComIfGd_setListBG(); mDoExt_modelUpdateDL(mpModel); dComIfGd_setList(); return 1; } int daRotTrap_c::Delete() { dComIfG_resDelete(&mPhase, "P_kama"); if (mpBgW2 != NULL && mpBgW2->ChkUsed()) { dComIfG_Bgsp().Release(mpBgW2); } return 1; } static int daRotTrap_Draw(daRotTrap_c* i_this) { return i_this->MoveBGDraw(); } static int daRotTrap_Execute(daRotTrap_c* i_this) { return i_this->MoveBGExecute(); } static int daRotTrap_Delete(daRotTrap_c* i_this) { return i_this->MoveBGDelete(); } static int daRotTrap_Create(fopAc_ac_c* i_this) { fpc_ProcID id = fopAcM_GetID(i_this); return ((daRotTrap_c*)i_this)->create(); } static actor_method_class l_daRotTrap_Method = { (process_method_func)daRotTrap_Create, (process_method_func)daRotTrap_Delete, (process_method_func)daRotTrap_Execute, (process_method_func)NULL, (process_method_func)daRotTrap_Draw, }; actor_process_profile_definition g_profile_Obj_RotTrap = { /* Layer ID */ fpcLy_CURRENT_e, /* List ID */ 3, /* List Prio */ fpcPi_CURRENT_e, /* Proc Name */ fpcNm_Obj_RotTrap_e, /* Proc SubMtd */ &g_fpcLf_Method.base, /* Size */ sizeof(daRotTrap_c), /* Size Other */ 0, /* Parameters */ 0, /* Leaf SubMtd */ &g_fopAc_Method.base, /* Draw Prio */ fpcDwPi_Obj_RotTrap_e, /* Actor SubMtd */ &l_daRotTrap_Method, /* Status */ fopAcStts_UNK_0x40000_e | fopAcStts_CULL_e, /* Group */ fopAc_ACTOR_e, /* Cull Type */ fopAc_CULLBOX_CUSTOM_e, };