/** * @file d_a_obj_magLift.cpp * */ #include "d/actor/d_a_obj_magLift.h" #include "dol2asm.h" #include "d/d_path.h" /* 80C8E6DC-80C8E6E8 000000 000C+00 1/1 0/0 0/0 .data cNullVec__6Z2Calc */ SECTION_DATA static u8 cNullVec__6Z2Calc[12] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, }; /* 80C8E6E8-80C8E6FC 00000C 0004+10 0/0 0/0 0/0 .data @1787 */ #pragma push #pragma force_active on SECTION_DATA static u32 lit_1787[1 + 4 /* padding */] = { 0x02000201, /* padding */ 0x40080000, 0x00000000, 0x3FE00000, 0x00000000, }; #pragma pop static daMagLift_HIO_c l_HIO; /* 80C8DA2C-80C8DA58 0000EC 002C+00 1/1 0/0 0/0 .text __ct__15daMagLift_HIO_cFv */ daMagLift_HIO_c::daMagLift_HIO_c() { field_0x4 = 0x3c; field_0x5 = 1; } /* 80C8DAA0-80C8DB28 000160 0088+00 2/2 0/0 0/0 .text setBaseMtx__11daMagLift_cFv */ void daMagLift_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); mpModel->setBaseScale(scale); mpModel->setBaseTRMtx(mDoMtx_stack_c::get()); } /* 80C8DB28-80C8DB94 0001E8 006C+00 1/0 0/0 0/0 .text CreateHeap__11daMagLift_cFv */ int daMagLift_c::CreateHeap() { J3DModelData* modelData = (J3DModelData*)dComIfG_getObjectRes("L_maglift", 4); if (modelData == NULL) { // FIXME: For shield decomp matching, needs a JUT assert. } mpModel = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084); if (mpModel == NULL) { return 0; } return 1; } /* ############################################################################################## */ /* 80C8E65C-80C8E69C 000000 0040+00 4/4 0/0 0/0 .rodata mSpeed__11daMagLift_c */ const f32 daMagLift_c::mSpeed[16] = { 5.0f, 6.6666665f, 8.333333f, 10.0f, 11.666667f, 13.333333f, 15.0f, 16.666666f, 18.333334f, 20.0f, 21.666666f, 23.333334f, 25.0f, 26.666666f, 28.333334f, 3.3333333f, }; /* 80C8DB94-80C8DD38 000254 01A4+00 1/1 0/0 0/0 .text create__11daMagLift_cFv */ int daMagLift_c::create() { fopAcM_SetupActor(this, daMagLift_c); int phase = dComIfG_resLoad(&mPhaseReq,"L_maglift"); if (phase == cPhs_COMPLEATE_e) { if (MoveBGCreate("L_maglift", 7, dBgS_MoveBGProc_TypicalRotY, 0x4000, NULL) == cPhs_ERROR_e) { return cPhs_ERROR_e; } field_0x5ae = fopAcM_GetParam(this); dPath* path = dPath_GetRoomPath(field_0x5ae, fopAcM_GetRoomNo(this)); if (path == NULL) { return cPhs_INIT_e; } current.pos = path->m_points->m_position; field_0x5af = 1; mPoint = 0; mMoveSpeed = mSpeed[getMoveSpeed()]; fopAcM_SetSpeedF(this, 0.0f); u8 mInitMove = fopAcM_GetParam(this) >> 0xc & 0xFF; if (mInitMove == 0xff) { init_modeWaitInit(); } else { is_switch = dComIfGs_isSwitch(mInitMove, fopAcM_GetHomeRoomNo(this)); if (is_switch) { init_modeWaitInit(); } else { init_modeMoveWait(); } } fopAcM_SetMtx(this, mpModel->getBaseTRMtx()); fopAcM_setCullSizeBox2(this, mpModel->getModelData()); setBaseMtx(); } return phase; } /* 80C8DD38-80C8DD88 0003F8 0050+00 1/0 0/0 0/0 .text Execute__11daMagLift_cFPPA3_A4_f */ int daMagLift_c::Execute(Mtx** i_mtx) { moveLift(); *i_mtx = &mpModel->getBaseTRMtx(); setBaseMtx(); return 1; } /* 80C8DD88-80C8DE98 000448 0110+00 1/1 0/0 0/0 .text moveLift__11daMagLift_cFv */ void daMagLift_c::moveLift() { if (field_0x5ae != 0xff) { typedef void (daMagLift_c::*modeFunc)(); static modeFunc mode_proc[8] = {&daMagLift_c::modeAcc, &daMagLift_c::modeMove, &daMagLift_c::modeBrk, &daMagLift_c::modeWait, &daMagLift_c::modeWaitInit, &daMagLift_c::modeDead, &daMagLift_c::modeMoveWait}; (this->*mode_proc[mMode])(); } } /* 80C8DE98-80C8DF20 000558 0088+00 1/0 0/0 0/0 .text modeAcc__11daMagLift_cFv */ void daMagLift_c::modeAcc() { if (TRUE == cLib_chaseF(&speedF, mMoveSpeed, mMoveSpeed / 30.0f) || current.pos == field_0x5b4) { init_modeMove(); } cLib_addCalcPos(¤t.pos, field_0x5b4, 1.0f, fopAcM_GetSpeedF(this), 0.1f); } /* 80C8DF20-80C8DF2C 0005E0 000C+00 1/1 0/0 0/0 .text init_modeMove__11daMagLift_cFv */ void daMagLift_c::init_modeMove() { mMode = MODE_MOVE_e; } /* 80C8DF2C-80C8E1EC 0005EC 02C0+00 1/0 0/0 0/0 .text modeMove__11daMagLift_cFv */ void daMagLift_c::modeMove() { cXyz sp54(field_0x5c0); cXyz sp60(field_0x5b4); f32 magn = (sp54 - sp60).abs() * 0.3f; f32 min = 30.0f; f32 max = 300.0f; if (magn < min) { magn = min; } if (magn > max) { magn = max; } f32 o_magn = (current.pos - field_0x5b4).abs(); if (magn > o_magn) { init_modeBrk(); } cLib_addCalcPos(¤t.pos, field_0x5b4, 1.0f, fopAcM_GetSpeedF(this), 0.1f); } /* 80C8E1EC-80C8E1F8 0008AC 000C+00 1/1 0/0 0/0 .text init_modeBrk__11daMagLift_cFv */ void daMagLift_c::init_modeBrk() { mMode = MODE_BRK_e; } /* 80C8E1F8-80C8E260 0008B8 0068+00 1/0 0/0 0/0 .text modeBrk__11daMagLift_cFv */ void daMagLift_c::modeBrk() { f32 val = cLib_addCalcPos(¤t.pos, field_0x5b4, 0.1f, fopAcM_GetSpeedF(this), 0.5f); if (val == 0.0f) { fopAcM_SetSpeedF(this, 0.0f); init_modeWaitInit(); } } /* 80C8E260-80C8E26C 000920 000C+00 3/3 0/0 0/0 .text init_modeWaitInit__11daMagLift_cFv */ void daMagLift_c::init_modeWaitInit() { mMode = MODE_WAIT_INIT_e; } /* 80C8E26C-80C8E2A0 00092C 0034+00 1/0 0/0 0/0 .text modeWaitInit__11daMagLift_cFv */ void daMagLift_c::modeWaitInit() { setNextPoint(); init_modeWait(); } /* 80C8E2A0-80C8E2AC 000960 000C+00 1/1 0/0 0/0 .text init_modeWait__11daMagLift_cFv */ void daMagLift_c::init_modeWait() { mMode = MODE_WAIT_e; } /* 80C8E2AC-80C8E2B8 00096C 000C+00 1/0 0/0 0/0 .text modeWait__11daMagLift_cFv */ void daMagLift_c::modeWait() { mMode = MODE_ACC_e; } /* 80C8E2B8-80C8E2C4 000978 000C+00 1/1 0/0 0/0 .text init_modeMoveWait__11daMagLift_cFv */ void daMagLift_c::init_modeMoveWait() { mMode = MODE_MOVE_WAIT_e; } /* 80C8E2C4-80C8E318 000984 0054+00 1/0 0/0 0/0 .text modeMoveWait__11daMagLift_cFv */ void daMagLift_c::modeMoveWait() { if (fopAcM_isSwitch(this, (fopAcM_GetParam(this) & 0xff000) >> 0xc) & 0xff) { init_modeWaitInit(); } } /* 80C8E318-80C8E31C 0009D8 0004+00 1/0 0/0 0/0 .text modeDead__11daMagLift_cFv */ void daMagLift_c::modeDead() { /* empty function */ } /* 80C8E31C-80C8E450 0009DC 0134+00 1/1 0/0 0/0 .text setNextPoint__11daMagLift_cFv */ void daMagLift_c::setNextPoint() { s16 sVar1 = mPoint + field_0x5af; dPath* path = dPath_GetRoomPath(field_0x5ae, fopAcM_GetRoomNo(this)); if (dPath_ChkClose(path) != 0) { int val = path->m_num - 1; if (sVar1 > val) { sVar1 = 0; } else if (sVar1 < 0) { sVar1 = (s8) val; } } else { if (sVar1 > path->m_num - 1) { field_0x5af = 0xff; sVar1 = (s8) (path->m_num - 2); } else if (sVar1 < 0) { field_0x5af = 0x1; sVar1 = 1; } else { dStage_dPnt_c* pnt = &path->m_points[mPoint]; if (pnt->mArg0 == 0) { sVar1 = mPoint; } } } field_0x5c0 = field_0x5b4; dStage_dPnt_c* pnt = &path->m_points[sVar1]; field_0x5b4 = pnt->m_position; mPoint = sVar1; } /* 80C8E450-80C8E4F4 000B10 00A4+00 1/0 0/0 0/0 .text Draw__11daMagLift_cFv */ int daMagLift_c::Draw() { g_env_light.settingTevStruct(0x40, ¤t.pos, &tevStr); g_env_light.setLightTevColorType_MAJI(mpModel, &tevStr); dComIfGd_setListBG(); mDoExt_modelUpdateDL(mpModel); dComIfGd_setList(); return 1; } /* 80C8E4F4-80C8E524 000BB4 0030+00 1/0 0/0 0/0 .text Delete__11daMagLift_cFv */ int daMagLift_c::Delete() { dComIfG_resDelete(&mPhaseReq, "L_maglift"); return 1; } /* 80C8E524-80C8E550 000BE4 002C+00 1/0 0/0 0/0 .text daMagLift_Draw__FP11daMagLift_c */ static int daMagLift_Draw(daMagLift_c* i_this) { return i_this->Draw(); } /* 80C8E550-80C8E570 000C10 0020+00 1/0 0/0 0/0 .text daMagLift_Execute__FP11daMagLift_c */ static int daMagLift_Execute(daMagLift_c* i_this) { return i_this->MoveBGExecute(); } /* 80C8E570-80C8E590 000C30 0020+00 1/0 0/0 0/0 .text daMagLift_Delete__FP11daMagLift_c */ static int daMagLift_Delete(daMagLift_c* i_this) { return i_this->MoveBGDelete(); } /* 80C8E590-80C8E5B0 000C50 0020+00 1/0 0/0 0/0 .text daMagLift_Create__FP10fopAc_ac_c */ static int daMagLift_Create(fopAc_ac_c* i_this) { return static_cast(i_this)->create(); } /* 80C8E7B0-80C8E7D0 -00001 0020+00 1/0 0/0 0/0 .data l_daMagLift_Method */ static actor_method_class l_daMagLift_Method = { (process_method_func) daMagLift_Create, (process_method_func) daMagLift_Delete, (process_method_func) daMagLift_Execute, (process_method_func) NULL, (process_method_func) daMagLift_Draw, }; /* 80C8E7D0-80C8E800 -00001 0030+00 0/0 0/0 1/0 .data g_profile_Obj_MagLift */ extern actor_process_profile_definition g_profile_Obj_MagLift = { fpcLy_CURRENT_e, // mLayerID 3, // mListID fpcPi_CURRENT_e, // mListPrio PROC_Obj_MagLift, // mProcName &g_fpcLf_Method.base, // sub_method sizeof(daMagLift_c), // mSize 0, // mSizeOther 0, // mParameters &g_fopAc_Method.base, // sub_method 492, // mPriority &l_daMagLift_Method, // sub_method 0x00040100, // mStatus fopAc_ACTOR_e, // mActorType fopAc_CULLBOX_CUSTOM_e, // cullType };