mirror of
https://github.com/TwilitRealm/dusklight
synced 2026-06-08 19:49:32 -04:00
56890c32e8
* Consolidate fopAcM_STATUS into fopAc_Status_e * Add _e suffix to fopAcStts enums * Prepare for profile enumeration * Correct typo in scene_process_profile_definition * Manually handle g_profile_Obj_DamCps (inline preprocessing) * Correct g_profile_TAG_LV5SOUP procname to enum * Create d_priority.h * Update process profile definitions * Moved inline comments to the left * Add missing fopAcStts enums * Add d_priority.h include in f_pc_leaf.h * Manually update d_a_obj_damCps profile * Replace fopAcStts enums replacing and anticipatory profile size correction * Changed profile size from literal to sizeof() in anticipation of PR #3116 * Provided putative names to staff-related status enums * Replaced appropriate literals with fopAcStts enums * Fix borked merge * Rename item number enums and move to d_item_data.h * Rename process profile name & draw priority enums * Move process profile name & draw priority enums to appropriate files * Moved fpcNm_ enums from d/d_procname.h to f_pc/f_pc_name.h * Moved fpcDwPi_ enums from d/d_priority.h to f_pc/f_pc_draw_priority.h * ACTUALLY (whoops) stage merge * Correct item mistranslation Co-authored-by: LagoLunatic <LagoLunatic@users.noreply.github.com> --------- Co-authored-by: LagoLunatic <LagoLunatic@users.noreply.github.com>
220 lines
6.3 KiB
C++
220 lines
6.3 KiB
C++
/**
|
|
* @file d_a_obj_rfHole.cpp
|
|
*
|
|
*/
|
|
|
|
#include "d/dolzel_rel.h" // IWYU pragma: keep
|
|
|
|
#include "d/actor/d_a_obj_rfHole.h"
|
|
#include "d/d_com_inf_game.h"
|
|
#include "d/d_bg_w.h"
|
|
|
|
daRfHole_HIO_c::daRfHole_HIO_c() {
|
|
field_0x04 = 130.0f;
|
|
field_0x08 = 200.0f;
|
|
field_0x10 = 0.0f;
|
|
field_0x0c = 200.0f;
|
|
field_0x14 = 10;
|
|
field_0x15 = 4;
|
|
}
|
|
|
|
void daRfHole_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);
|
|
mModel->setBaseScale(scale);
|
|
mModel->setBaseTRMtx(mDoMtx_stack_c::get());
|
|
}
|
|
|
|
int daRfHole_c::CreateHeap() {
|
|
J3DModelData* modelData = (J3DModelData*)dComIfG_getObjectRes("Otosiana", 4);
|
|
JUT_ASSERT(167, modelData!=NULL);
|
|
mModel = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084);
|
|
return mModel != NULL ? 1 : 0;
|
|
}
|
|
|
|
int daRfHole_c::create() {
|
|
fopAcM_ct(this, daRfHole_c);
|
|
int rv = dComIfG_resLoad(&mPhase, "Otosiana");
|
|
if (rv == cPhs_COMPLEATE_e) {
|
|
if (MoveBGCreate("Otosiana", 7, dBgS_MoveBGProc_TypicalRotY, 0xb40, NULL) == cPhs_ERROR_e) {
|
|
return cPhs_ERROR_e;
|
|
}
|
|
fopAcM_SetMtx(this, mModel->getBaseTRMtx());
|
|
fopAcM_setCullSizeBox2(this, mModel->getModelData());
|
|
if (fopAcM_isSwitch(this, (u8)fopAcM_GetParam(this))) {
|
|
init_modeEnd();
|
|
} else {
|
|
field_0x5ad = (fopAcM_GetParam(this) >> 8) & 0xff;
|
|
if (field_0x5ad != 1) {
|
|
mpBgW->SetRideCallback(rideCallBack);
|
|
init_modeWait();
|
|
} else {
|
|
init_modeBreakEff();
|
|
}
|
|
}
|
|
field_0x5ae = 0;
|
|
mRoofSoundOn = 0;
|
|
setBaseMtx();
|
|
}
|
|
return rv;
|
|
}
|
|
|
|
void daRfHole_c::rideCallBack(dBgW* param_1, fopAc_ac_c* param_2, fopAc_ac_c* param_3) {
|
|
if (fopAcM_GetName(param_3) == fpcNm_ALINK_e && static_cast<daRfHole_c*>(param_2)->playerAreaCheck()) {
|
|
static_cast<daRfHole_c*>(param_2)->field_0x5ae = 1;
|
|
}
|
|
}
|
|
|
|
static daRfHole_HIO_c l_HIO;
|
|
|
|
int daRfHole_c::playerAreaCheck() {
|
|
fopAc_ac_c* player = dComIfGp_getPlayer(0);
|
|
cXyz cStack_30(l_HIO.field_0x0c, 0.0f, 0.0f);
|
|
mDoMtx_stack_c::ZXYrotS(shape_angle.x, shape_angle.y, shape_angle.z);
|
|
mDoMtx_stack_c::multVec(&cStack_30, &cStack_30);
|
|
cXyz cStack_3c = current.pos + cStack_30;
|
|
cXyz cStack_48 = cStack_3c - player->current.pos;
|
|
f32 dVar8 = cStack_48.absXZ();
|
|
int rv = 0;
|
|
if (dVar8 <= l_HIO.field_0x04) {
|
|
rv = 1;
|
|
}
|
|
u8 soundOn = 0;
|
|
if (dVar8 <= l_HIO.field_0x08) {
|
|
soundOn = 1;
|
|
if (mRoofSoundOn != 1) {
|
|
mDoAud_seStart(Z2SE_OBJ_ROOF_ANA, &cStack_3c, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this)));
|
|
}
|
|
}
|
|
mRoofSoundOn = soundOn;
|
|
return rv;
|
|
}
|
|
|
|
int daRfHole_c::Execute(Mtx** i_mtx) {
|
|
holeProc();
|
|
*i_mtx = &mModel->getBaseTRMtx();
|
|
setBaseMtx();
|
|
field_0x5ae = 0;
|
|
return 1;
|
|
}
|
|
|
|
void daRfHole_c::holeProc() {
|
|
static ModeFunc mode_proc[] = {&daRfHole_c::modeWait, &daRfHole_c::modeBreak,
|
|
&daRfHole_c::modeBreakEff, &daRfHole_c::modeEnd};
|
|
(this->*(mode_proc[mMode]))();
|
|
}
|
|
|
|
void daRfHole_c::init_modeWait() {
|
|
mMode = MODE_WAIT;
|
|
}
|
|
|
|
void daRfHole_c::modeWait() {
|
|
if (field_0x5ae != 0) {
|
|
init_modeBreak();
|
|
}
|
|
}
|
|
|
|
void daRfHole_c::init_modeBreak() {
|
|
setBreakEffect();
|
|
dComIfGp_getVibration().StartShock(l_HIO.field_0x15, 15, cXyz(0.0f, 1.0f, 0.0f));
|
|
cXyz acStack_20(l_HIO.field_0x0c, 0.0f, 0.0f);
|
|
mDoMtx_stack_c::ZXYrotS(shape_angle.x, shape_angle.y, shape_angle.z);
|
|
mDoMtx_stack_c::multVec(&acStack_20, &acStack_20);
|
|
cXyz cStack_2c = current.pos + acStack_20;
|
|
mDoAud_seStart(Z2SE_OBJ_WOODROOF_BREAK, &cStack_2c, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this)));
|
|
fopAcM_onSwitch(this, (u8)fopAcM_GetParam(this));
|
|
mMode = MODE_BREAK;
|
|
}
|
|
|
|
void daRfHole_c::modeBreak() {
|
|
fopAcM_delete(this);
|
|
}
|
|
|
|
void daRfHole_c::init_modeBreakEff() {
|
|
setBreakEffect();
|
|
fopAcM_onSwitch(this, (u8)fopAcM_GetParam(this));
|
|
mMode = MODE_BREAK_EFF;
|
|
}
|
|
|
|
void daRfHole_c::modeBreakEff() {
|
|
fopAcM_delete(this);
|
|
}
|
|
|
|
void daRfHole_c::init_modeEnd() {
|
|
mMode = MODE_END;
|
|
}
|
|
|
|
void daRfHole_c::modeEnd() {
|
|
fopAcM_delete(this);
|
|
}
|
|
|
|
void daRfHole_c::setBreakEffect() {
|
|
static u16 const particle_id[5] = {
|
|
0x83B0, 0x83B1, 0x83B2, 0x83B3, 0x83B4,
|
|
};
|
|
cXyz acStack_24(l_HIO.field_0x0c, 0.0f, 0.0f);
|
|
mDoMtx_stack_c::ZXYrotS(shape_angle.x, shape_angle.y, shape_angle.z);
|
|
mDoMtx_stack_c::multVec(&acStack_24, &acStack_24);
|
|
cXyz cStack_30 = current.pos + acStack_24;
|
|
for (int i = 0; i < 5; i++) {
|
|
dComIfGp_particle_set(particle_id[i], &cStack_30, NULL, &scale, 0xff, 0, -1, NULL,
|
|
NULL, NULL);
|
|
}
|
|
}
|
|
|
|
int daRfHole_c::Draw() {
|
|
g_env_light.settingTevStruct(0x10, ¤t.pos, &tevStr);
|
|
g_env_light.setLightTevColorType_MAJI(mModel, &tevStr);
|
|
dComIfGd_setListBG();
|
|
mDoExt_modelUpdateDL(mModel);
|
|
dComIfGd_setList();
|
|
return 1;
|
|
}
|
|
|
|
int daRfHole_c::Delete() {
|
|
dComIfG_resDelete(&mPhase, "Otosiana");
|
|
return 1;
|
|
}
|
|
|
|
static int daRfHole_Draw(daRfHole_c* i_this) {
|
|
return i_this->MoveBGDraw();
|
|
}
|
|
|
|
static int daRfHole_Execute(daRfHole_c* i_this) {
|
|
return i_this->MoveBGExecute();
|
|
}
|
|
|
|
static int daRfHole_Delete(daRfHole_c* i_this) {
|
|
return i_this->MoveBGDelete();
|
|
}
|
|
|
|
static int daRfHole_Create(fopAc_ac_c* i_this) {
|
|
fopAcM_GetID(i_this);
|
|
return static_cast<daRfHole_c*>(i_this)->create();
|
|
}
|
|
|
|
static actor_method_class l_daRfHole_Method = {
|
|
(process_method_func)daRfHole_Create,
|
|
(process_method_func)daRfHole_Delete,
|
|
(process_method_func)daRfHole_Execute,
|
|
NULL,
|
|
(process_method_func)daRfHole_Draw,
|
|
};
|
|
|
|
actor_process_profile_definition g_profile_Obj_RfHole = {
|
|
/* Layer ID */ fpcLy_CURRENT_e,
|
|
/* List ID */ 3,
|
|
/* List Prio */ fpcPi_CURRENT_e,
|
|
/* Proc Name */ fpcNm_Obj_RfHole_e,
|
|
/* Proc SubMtd */ &g_fpcLf_Method.base,
|
|
/* Size */ sizeof(daRfHole_c),
|
|
/* Size Other */ 0,
|
|
/* Parameters */ 0,
|
|
/* Leaf SubMtd */ &g_fopAc_Method.base,
|
|
/* Draw Prio */ fpcDwPi_Obj_RfHole_e,
|
|
/* Actor SubMtd */ &l_daRfHole_Method,
|
|
/* Status */ fopAcStts_UNK_0x40000_e | fopAcStts_CULL_e,
|
|
/* Group */ fopAc_ACTOR_e,
|
|
/* Cull Type */ fopAc_CULLBOX_CUSTOM_e,
|
|
};
|