/** * @file d_a_obj_lv6SwGate.cpp * */ #include "d/dolzel_rel.h" // IWYU pragma: keep #include "d/d_s_play.h" #include "d/actor/d_a_obj_lv6SwGate.h" daLv6SwGate_HIO_c::daLv6SwGate_HIO_c() { mSpeed = 15.0f; mMaximumSpeed = 30.0f; mAcceleration = 15.0f; mMovementAmount = 275.0f; unk18 = 3; } #if DEBUG void daLv6SwGate_HIO_c::genMessage(JORMContext* context) { context->genLabel("--- 開く ---", 0); context->genSlider("速度", &this->mSpeed, 0.1f, 100.0f); context->genLabel("\n--- 閉まる ---", 0); context->genSlider("最大速度", &this->mMaximumSpeed, 0.1f, 100.0f); context->genSlider("加速度", &this->mAcceleration, 0.1f, 100.0f); context->genLabel("\n------", 0); context->genSlider("移動量", &this->mMovementAmount, 0.1f, 100.0f); } #endif static daLv6SwGate_HIO_c l_HIO; const dCcD_SrcGObjInf daLv6SwGate_c::mCcDObjInfo = { {0, {{0, 0, 0}, {0x400, 0x11}, {0x79}}}, {1, 0, 0, 0, 0}, {0xA, 0, 0, 0, 0}, {0} }; dCcD_SrcCyl daLv6SwGate_c::mCcDCyl = { mCcDObjInfo, { { {0.0f, 0.0f, 0.0f}, // mCenter 0.0f, // mRadius 0.0f // mHeight } // mCyl } // mCylAttr }; static cull_box l_cull_box = {-1200.0f, -300.0f, -100.0f, 1200.0f, 300.0f, 100.0f}; void daLv6SwGate_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::transM(-150.0f - mMovementAmount, 0.0f, 0.0f); mModel1->setBaseScale(scale); mModel1->setBaseTRMtx(mDoMtx_stack_c::get()); MTXCopy(mDoMtx_stack_c::get(), mBgMtx); mDoMtx_stack_c::transS(current.pos.x, current.pos.y, current.pos.z); mDoMtx_stack_c::ZXYrotM(shape_angle.x, shape_angle.y + 0x8000, shape_angle.z); mDoMtx_stack_c::transM(-150.0f - mMovementAmount, 0.0f, 0.0f); mModel2->setBaseScale(scale); mModel2->setBaseTRMtx(mDoMtx_stack_c::get()); MTXCopy(mDoMtx_stack_c::get(), mMtx); } int daLv6SwGate_c::CreateHeap() { J3DModelData* modelData = (J3DModelData*)dComIfG_getObjectRes("L6SwGate", 4); JUT_ASSERT(273, modelData != NULL); mModel1 = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084); if (mModel1 == NULL) { return FALSE; } modelData = (J3DModelData*)dComIfG_getObjectRes("L6SwGate", 4); JUT_ASSERT(284, modelData != NULL); mModel2 = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084); if (mModel2 == NULL) { return FALSE; } mpBgW = new dBgW(); if (mpBgW != NULL && !mpBgW->Set((cBgD_t*)dComIfG_getObjectRes("L6SwGate", 7), 0x1, &mMtx)) { mpBgW->SetCrrFunc(dBgS_MoveBGProc_TypicalRotY); } else { mpBgW = NULL; return FALSE; } return TRUE; } int daLv6SwGate_c::create() { fopAcM_ct(this, daLv6SwGate_c); if (getSw2() != 0xff && fopAcM_isSwitch(this, getSw2())) { return cPhs_ERROR_e; } int phase = dComIfG_resLoad(&mPhase, "L6SwGate"); if (phase == cPhs_COMPLEATE_e) { if (MoveBGCreate("L6SwGate", 7, dBgS_MoveBGProc_TypicalRotY, 0x1700, NULL) == cPhs_ERROR_e) { return cPhs_ERROR_e; } fopAcM_SetMtx(this, mModel1->getBaseTRMtx()); // copy-paste error? l_cull_box.max.y twice fopAcM_setCullSizeBox(this, l_cull_box.min.x, l_cull_box.min.y, l_cull_box.min.z, l_cull_box.max.x, l_cull_box.max.y, l_cull_box.max.y); mCcStts.Init(0xff, 0xff, this); for (int i = 0; i < 12; i++) { mCcDCyls[i].Set(mCcDCyl); mCcDCyls[i].SetStts(&mCcStts); } if (mpBgW != NULL) { dComIfG_Bgsp().Regist(mpBgW, this); mpBgW->Move(); } mUnderlyingSwitchState = getSwState(); if (mUnderlyingSwitchState == 0xf) { mUnderlyingSwitchState = 0; } mUnderylingSwitch = getSw(); mIsSwitch = isSwitch(); mMovementAmount = 0.0f; if (mIsSwitch) { mMovementAmount = l_HIO.mMovementAmount; } init_modeWait(); setBaseMtx(); #if DEBUG l_HIO.entryHIO("スイッチゲート(Lv6)"); #endif } return phase; } u8 daLv6SwGate_c::isSwitch() { return fopAcM_isSwitch(this, mUnderylingSwitch) ^ mUnderlyingSwitchState; } int daLv6SwGate_c::Execute(Mtx** i_pMTx) { moveGate(); for (int i = 0; i < 12; i++) { if (mCcDCyls[i].ChkTgHit()) { dCcD_GObjInf* o = mCcDCyls[i].GetTgHitGObj(); if (o->GetAtType() & 0x400) { init_modeBreak(); break; } } } for (int i = 0; i < 6; i++) { cXyz p(-150.0f - mMovementAmount + 120.0f - i * (55.0f + oREG_F(2)), 0.0f, 0.0f); mDoMtx_stack_c::ZXYrotS(shape_angle.x, shape_angle.y, shape_angle.z); mDoMtx_stack_c::multVec(&p, &p); p += current.pos; mCcDCyls[i].SetR(30.0f + oREG_F(0)); mCcDCyls[i].SetH(300.0f + oREG_F(1)); mCcDCyls[i].SetC(p); dComIfG_Ccsp()->Set(&mCcDCyls[i]); } for (int i = 0; i < 6; i++) { cXyz p(-150.0f - mMovementAmount + 120.0f - i * (55.0f + oREG_F(3)), 0.0f, 0.0f); mDoMtx_stack_c::ZXYrotS(shape_angle.x, shape_angle.y + 0x8000, shape_angle.z); mDoMtx_stack_c::multVec(&p, &p); p += current.pos; mCcDCyls[i + 6].SetR(30.0f + oREG_F(0)); mCcDCyls[i + 6].SetH(300.0f + oREG_F(1)); mCcDCyls[i + 6].SetC(p); dComIfG_Ccsp()->Set(&mCcDCyls[i + 6]); } *i_pMTx = &mModel1->getBaseTRMtx(); setBaseMtx(); if (mpBgW != NULL) { mpBgW->Move(); } return TRUE; } enum DALV6SWGATE_C_MODE { DALV6SWGATE_C_MODE_WAIT, DALV6SWGATE_C_MODE_OPEN, DALV6SWGATE_C_MODE_CLOSE, DALV6SWGATE_C_MODE_BREAK, }; void daLv6SwGate_c::moveGate() { typedef void (daLv6SwGate_c::*func_call)(); const static func_call mode_proc[] = { /* DALV6SWGATE_C_MODE_WAIT */ &daLv6SwGate_c::modeWait, /* DALV6SWGATE_C_MODE_OPEN */ &daLv6SwGate_c::modeOpen, /* DALV6SWGATE_C_MODE_CLOSE */ &daLv6SwGate_c::modeClose, /* DALV6SWGATE_C_MODE_BREAK */ &daLv6SwGate_c::modeBreak, }; u8 oldIsSwitch = mIsSwitch; mIsSwitch = isSwitch(); if (mIsSwitch != oldIsSwitch) { if (mIsSwitch) { init_modeOpen(); } else { init_modeClose(); } } (this->*mode_proc[mMode])(); } void daLv6SwGate_c::init_modeWait() { mMode = DALV6SWGATE_C_MODE_WAIT; } void daLv6SwGate_c::modeWait() { return; } void daLv6SwGate_c::init_modeOpen() { mMode = DALV6SWGATE_C_MODE_OPEN; } void daLv6SwGate_c::modeOpen() { f32 calc = cLib_addCalc(&mMovementAmount, l_HIO.mMovementAmount, 0.1f, l_HIO.mSpeed, 5.0f); mDoAud_seStartLevel(Z2SE_OBJ_L6_SW_GATE_OP_MV, ¤t.pos, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this))); if (calc == 0.0f) { mDoAud_seStart(Z2SE_OBJ_L6_SW_GATE_OP_ST, ¤t.pos, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this))); init_modeWait(); } } void daLv6SwGate_c::init_modeClose() { fopAcM_SetSpeedF(this, 0.0f); mMode = DALV6SWGATE_C_MODE_CLOSE; } void daLv6SwGate_c::modeClose() { int unused = cLib_chaseF(&speedF, l_HIO.mMaximumSpeed, l_HIO.mAcceleration); f32 calc = cLib_addCalc(&mMovementAmount, 0.0f, 1.0f, fopAcM_GetSpeedF(this), 5.0f); mDoAud_seStartLevel(Z2SE_OBJ_L6_SW_GATE_CL_MV, ¤t.pos, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this))); if (calc == 0.0f) { mDoAud_seStart(Z2SE_OBJ_L6_SW_GATE_CL_ST, ¤t.pos, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this))); init_modeWait(); } } void daLv6SwGate_c::init_modeBreak() { OS_REPORT("== break! ==\n"); mDoAud_seStart(Z2SE_OBJ_TRAP_BREAK, ¤t.pos, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this))); mMode = DALV6SWGATE_C_MODE_BREAK; } void daLv6SwGate_c::modeBreak() { cXyz p(-150.0f - mMovementAmount, 0.0f, 0.0f); mDoMtx_stack_c::ZXYrotS(shape_angle.x, shape_angle.y, shape_angle.z); mDoMtx_stack_c::multVec(&p, &p); p += current.pos; dComIfGp_particle_set(0x8B79, &p, &shape_angle, 0); dComIfGp_particle_set(0x8B7A, &p, &shape_angle, 0); dComIfGp_particle_set(0x8B7B, &p, &shape_angle, 0); dComIfGp_particle_set(0x8B7C, &p, &shape_angle, 0); dComIfGp_particle_set(0x8B7D, &p, &shape_angle, 0); p.set(-150.0f - mMovementAmount, 0.0f, 0.0f); csXyz shapeAngle(shape_angle); shapeAngle.y += 0x8000; mDoMtx_stack_c::ZXYrotS(shapeAngle.x, shapeAngle.y, shapeAngle.z); mDoMtx_stack_c::multVec(&p, &p); p += current.pos; dComIfGp_particle_set(0x8B79, &p, &shapeAngle, 0); dComIfGp_particle_set(0x8B7A, &p, &shapeAngle, 0); dComIfGp_particle_set(0x8B7B, &p, &shapeAngle, 0); dComIfGp_particle_set(0x8B7C, &p, &shapeAngle, 0); dComIfGp_particle_set(0x8B7D, &p, &shapeAngle, 0); if (getSw2() != 0xff) { fopAcM_onSwitch(this, getSw2()); } fopAcM_delete(this); } int daLv6SwGate_c::Draw() { g_env_light.settingTevStruct(0x10, ¤t.pos, &tevStr); g_env_light.setLightTevColorType_MAJI(mModel1, &tevStr); dComIfGd_setListBG(); mDoExt_modelUpdateDL(mModel1); mDoExt_modelUpdateDL(mModel2); dComIfGd_setList(); return TRUE; } int daLv6SwGate_c::Delete() { dComIfG_resDelete(&mPhase, "L6SwGate"); if (mpBgW != NULL && mpBgW->ChkUsed()) { dComIfG_Bgsp().Release(mpBgW); } #if DEBUG l_HIO.removeHIO(this); #endif return TRUE; } static int daLv6SwGate_Draw(daLv6SwGate_c* i_this) { return i_this->MoveBGDraw(); } static int daLv6SwGate_Execute(daLv6SwGate_c* i_this) { return i_this->MoveBGExecute(); } static int daLv6SwGate_Delete(daLv6SwGate_c* i_this) { fpc_ProcID id = fopAcM_GetID(i_this); return i_this->MoveBGDelete(); } static int daLv6SwGate_Create(fopAc_ac_c* i_this) { daLv6SwGate_c* this_gate = (daLv6SwGate_c*)i_this; fpc_ProcID id = fopAcM_GetID(i_this); return this_gate->create(); } static actor_method_class l_daLv6SwGate_Method = { (process_method_func)daLv6SwGate_Create, (process_method_func)daLv6SwGate_Delete, (process_method_func)daLv6SwGate_Execute, NULL, (process_method_func)daLv6SwGate_Draw, }; actor_process_profile_definition g_profile_Obj_Lv6SwGate = { fpcLy_CURRENT_e, // mLayerID 3, // mListID fpcPi_CURRENT_e, // mListPrio PROC_Obj_Lv6SwGate, // mProcName &g_fpcLf_Method.base, // sub_method sizeof(daLv6SwGate_c), // mSize 0, // mSizeOther 0, // mParameters &g_fopAc_Method.base, // sub_method 624, // mPriority &l_daLv6SwGate_Method, // sub_method 0x00040000, // mStatus fopAc_ACTOR_e, // mActorType fopAc_CULLBOX_CUSTOM_e, // cullType };