/** * @file d_a_obj_takaraDai.cpp * */ #include "d/dolzel_rel.h" // IWYU pragma: keep #include "d/actor/d_a_obj_takaraDai.h" #include "d/d_bg_w.h" #include "d/d_com_inf_game.h" daTkraDai_HIO_c::daTkraDai_HIO_c() { field_0x04 = 12.0f; field_0x10 = 4.0f; field_0x0c = 3.0f; field_0x08 = 130.0f; field_0x14 = 0.06f; field_0x18 = 5.0f; field_0x1c = 1.0f; field_0x20 = 90.0f; field_0x24 = 30.0f; field_0x28 = 10.0f; field_0x2c = 0.01f; field_0x30 = 5.0f; field_0x34 = 0.3f; field_0x38 = 15; } void daTkraDai_c::setBaseMtx() { mDoMtx_stack_c::transS(current.pos.x, current.pos.y, current.pos.z); mDoMtx_stack_c::ZXYrotM(current.angle.x, current.angle.y, current.angle.z); mDoMtx_stack_c::ZXYrotM(field_0x5d4.x, field_0x5d4.y, field_0x5d4.z); mpBaseModel->setBaseScale(scale); mpBaseModel->setBaseTRMtx(mDoMtx_stack_c::get()); cMtx_copy(mDoMtx_stack_c::get(), mBgMtx); mDoMtx_stack_c::ZXYrotS(current.angle.x, current.angle.y, current.angle.z); mDoMtx_stack_c::ZXYrotM(field_0x5d4.x, field_0x5d4.y, field_0x5d4.z); field_0x61c.set(-1235.0f, 2050.0f, -1235.0f); mDoMtx_stack_c::multVec(&field_0x61c, &field_0x61c); mDoMtx_stack_c::transS(current.pos.x + field_0x61c.x, current.pos.y + field_0x61c.y, current.pos.z + field_0x61c.z); mDoMtx_stack_c::ZXYrotM(shape_angle.x, shape_angle.y, shape_angle.z); mpTopModel->setBaseScale(scale); mpTopModel->setBaseTRMtx(mDoMtx_stack_c::get()); cMtx_copy(mDoMtx_stack_c::get(), field_0x62c); } int daTkraDai_c::CreateHeap() { J3DModelData* modelData = (J3DModelData*)dComIfG_getObjectRes("M_TakaraD", 4); mpBaseModel = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084); if (mpBaseModel == NULL) { return 0; } modelData = (J3DModelData*)dComIfG_getObjectRes("M_TakaraD", 5); mpTopModel = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084); if (mpTopModel == NULL) { return 0; } mpBgW = new dBgW(); if (mpBgW != NULL && !mpBgW->Set((cBgD_t*)dComIfG_getObjectRes("M_TakaraD", 9), 1, &field_0x62c)) { mpBgW->SetCrrFunc(dBgS_MoveBGProc_TypicalRotY); } else { mpBgW = NULL; return 0; } return 1; } int daTkraDai_c::create() { fopAcM_ct(this, daTkraDai_c); cPhs__Step phase = static_cast(dComIfG_resLoad(&mPhase, "M_TakaraD")); if (phase == cPhs_COMPLEATE_e) { if (MoveBGCreate("M_TakaraD", 8, dBgS_MoveBGProc_Typical, 0x2e00, NULL) == cPhs_ERROR_e) { return cPhs_ERROR_e; } fopAcM_SetMtx(this, mpBaseModel->getBaseTRMtx()); J3DJoint* joint = mpBaseModel->getModelData()->getJointNodePointer(0); fopAcM_setCullSizeBox(this, scale.x * ((joint->getMin()->x - 250.0f)), scale.y * joint->getMin()->y, scale.z * (joint->getMin()->z - 250.0f), scale.x * joint->getMax()->x, scale.y * (joint->getMax()->y + 50.0f), scale.z * joint->getMax()->z); if (mpBgW) { dComIfG_Bgsp().Regist(mpBgW, this); mpBgW->Move(); } field_0x5d4.setall(0); field_0x5dc = 0; field_0x5f4 = 0.0f; field_0x5f8 = 0.0f; field_0x5fc = 0.0f; field_0x608 = 0.0f; field_0x5e4 = 0.0f; field_0x5e0 = 0.0f; field_0x5e8 = 0.0f; field_0x5ec = 0.0f; field_0x5f0 = 0.0f; field_0x600 = 0.0f; field_0x604 = 0.0f; field_0x60c = 0.0f; field_0x610 = 0.0f; field_0x614 = 0.0f; field_0x618 = 1; field_0x5d0 = 0; mDoMtx_stack_c::ZXYrotS(current.angle.x, current.angle.y, current.angle.z); field_0x61c.set(-1235.0f, 2050.0f, -1235.0f); mDoMtx_stack_c::multVec(&field_0x61c, &field_0x61c); setBaseMtx(); init_modeWait(); } return phase; } int daTkraDai_c::Execute(Mtx** param_0) { procMain(); setBaseMtx(); *param_0 = &mpBaseModel->getBaseTRMtx(); if (mpBgW != NULL) { mpBgW->Move(); } return 1; } static daTkraDai_HIO_c l_HIO; void daTkraDai_c::procMain() { typedef void (daTkraDai_c::*daTkraDai_modeFunc)(); static daTkraDai_modeFunc mode_proc[] = { &daTkraDai_c::modeWait, }; (this->*mode_proc[mMode])(); field_0x5d4.z = field_0x5dc * cM_scos(field_0x5d0 * cM_deg2s(field_0x5e4)); field_0x5d4.x = field_0x5dc * cM_ssin(field_0x5d0 * cM_deg2s(field_0x5e0)); field_0x5d0++; } void daTkraDai_c::init_modeWait() { field_0x5dc = l_HIO.field_0x08; field_0x61a = cM_deg2s(360.0f / (l_HIO.field_0x04 * 30.0f)); mMode = 0; } void daTkraDai_c::modeWait() { field_0x5dc = l_HIO.field_0x08; field_0x5e4 = l_HIO.field_0x0c; field_0x5e0 = l_HIO.field_0x10; u32 tmp = getSwBit(); if (!fopAcM_isSwitch(this, tmp)) { shape_angle.y += field_0x61a; } } int daTkraDai_c::Draw() { g_env_light.settingTevStruct(16, ¤t.pos, &tevStr); g_env_light.setLightTevColorType_MAJI(mpBaseModel, &tevStr); g_env_light.setLightTevColorType_MAJI(mpTopModel, &tevStr); dComIfGd_setListBG(); mDoExt_modelUpdateDL(mpBaseModel); mDoExt_modelUpdateDL(mpTopModel); dComIfGd_setList(); return 1; } int daTkraDai_c::Delete() { dComIfG_resDelete(&mPhase, "M_TakaraD"); if (mpBgW != NULL && mpBgW->ChkUsed()) { dComIfG_Bgsp().Release(mpBgW); } return 1; } static int daTkraDai_Draw(daTkraDai_c* i_this) { return i_this->Draw(); } static int daTkraDai_Execute(daTkraDai_c* i_this) { return i_this->MoveBGExecute(); } static int daTkraDai_Delete(daTkraDai_c* i_this) { return i_this->MoveBGDelete(); } static int daTkraDai_Create(fopAc_ac_c* i_this) { fopAcM_GetID(i_this); return static_cast(i_this)->create(); } static actor_method_class l_daTkraDai_Method = { (process_method_func)daTkraDai_Create, (process_method_func)daTkraDai_Delete, (process_method_func)daTkraDai_Execute, 0, (process_method_func)daTkraDai_Draw, }; extern actor_process_profile_definition g_profile_Obj_TakaraDai = { fpcLy_CURRENT_e, // mLayerID 3, // mListID fpcPi_CURRENT_e, // mListPrio PROC_Obj_TakaraDai, // mProcName &g_fpcLf_Method.base, // sub_method sizeof(daTkraDai_c), // mSize 0, // mSizeOther 0, // mParameters &g_fopAc_Method.base, // sub_method 654, // mPriority &l_daTkraDai_Method, // sub_method 0x00040100, // mStatus fopAc_ACTOR_e, // mActorType fopAc_CULLBOX_CUSTOM_e, // cullType };