Files
tww/src/d/actor/d_a_dk.cpp
T
2026-05-07 15:59:23 -04:00

429 lines
13 KiB
C++

/**
* d_a_dk.cpp
* NPC - Helmaroc King (Forsaken Fortress 1 tower, Outset Island)
*/
#include "d/dolzel_rel.h" // IWYU pragma: keep
#include "d/actor/d_a_dk.h"
#include "d/res/res_dk.h"
#include "d/d_com_inf_game.h"
#include "d/d_s_play.h"
#include "m_Do/m_Do_ext.h"
#include "d/d_procname.h"
#include "d/d_priority.h"
#include "f_op/f_op_actor_mng.h"
static void dummy() {
// string-ordering fix.
OSReport("Dk");
}
daDk_HIO_c l_HIO;
/* 000000EC-00000130 .text __ct__10daDk_HIO_cFv */
daDk_HIO_c::daDk_HIO_c() {
mNo = -1;
field_0x05 = 0;
field_0x08 = 1.0f;
field_0x0C = 4.0f;
field_0x10 = 1.5f;
field_0x14 = 0;
}
/* 00000130-000001EC .text nodeCallBack__FP7J3DNodei */
static BOOL nodeCallBack(J3DNode* node, int calcTiming) {
/* Nonmatching */
if (calcTiming == J3DNodeCBCalcTiming_In) {
J3DJoint* joint = (J3DJoint*)node;
s32 jnt_no = joint->getJntNo();
J3DModel* model = j3dSys.getModel();
dk_class* a_this = (dk_class*)model->getUserArea();
if (a_this != NULL) {
MTXCopy(model->getAnmMtx(jnt_no), *calc_mtx);
s32 tail_idx = ((jnt_no - 58) / 2);
cXyz pos_vec;
pos_vec.x = pos_vec.y = pos_vec.z = 0.0f;
MtxPosition(&pos_vec, &a_this->tails[tail_idx].field_0x150[1]);
pos_vec.x = -10.0f;
MtxPosition(&pos_vec, &a_this->tails[tail_idx].field_0x150[0]);
}
}
return TRUE;
}
/* 00000228-00000720 .text tail_control__FP8dk_classP6tail_s */
static void tail_control(dk_class* a_this, tail_s* tail) {
/* Nonmatching */
s32 i;
cXyz vec = tail->field_0x150[1] - tail->field_0x150[0];
tail->field_0x168.y = cM_atan2s(vec.x, vec.z);
f32 xz_dist = std::sqrtf(vec.x * vec.x + vec.z * vec.z);
tail->field_0x168.x = -cM_atan2s(vec.y, xz_dist);
vec.x = 0.0f;
vec.y = 0.0f;
vec.z = REG0_F(5) + 25.0f + 5.0f;
cMtx_YrotS(*calc_mtx, tail->field_0x168.y);
cMtx_XrotM(*calc_mtx, tail->field_0x168.x);
MtxPosition(&vec, &tail->field_0x170);
tail->field_0x024[0] = tail->field_0x150[1];
cXyz* field_24_ptr = &tail->field_0x024[1];
csXyz* field_9C_ptr = &tail->field_0x09C[1];
cXyz* field_D8_ptr = &tail->field_0x0D8[1];
f32 unk = REG0_F(2) + 0.77000004f;
f32 unk2;
if (a_this->field_0x2B4 >= 2) {
unk2 = -G_CM3D_F_INF;
} else {
unk2 = a_this->field_0x900.GetGroundH() + 5.0f;
}
for (i = 1; i < 10; i++) {
cXyz* field_24_ptr_prev = field_24_ptr - 1;
cXyz pos_vec;
f32 multiplier = 1.0f - (i - 1) * (REG0_F(4) + 0.1f);
cXyz new_vec;
new_vec.x = field_D8_ptr->x + tail->field_0x170.x * multiplier;
new_vec.y = field_D8_ptr->y + tail->field_0x170.y * multiplier;
new_vec.z = field_D8_ptr->z + tail->field_0x170.z * multiplier;
f32 y_base = field_24_ptr->y + new_vec.y;
if (y_base < unk2) {
y_base = unk2;
}
f32 y_2 = y_base - field_24_ptr_prev->y;
f32 x_2 = new_vec.x + (field_24_ptr->x - field_24_ptr_prev->x);
f32 z_2 = new_vec.z + (field_24_ptr->z - field_24_ptr_prev->z);
s16 new_x_angle;
s32 new_y_angle = cM_atan2s(x_2, z_2);
f32 xz_dist = std::sqrtf(x_2 * x_2 + z_2 * z_2);
new_x_angle = -cM_atan2s(y_2, xz_dist);
(field_9C_ptr - 1)->y = new_y_angle;
(field_9C_ptr - 1)->x = new_x_angle;
vec.x = 0.0f;
vec.y = 0.0f;
f32 temp = l_HIO.field_0x10 * ((i * 0.03f) + 0.25f) * 20.0f;
vec.z = temp * (2.0f * l_HIO.field_0x0C);
cMtx_YrotS(*calc_mtx, new_y_angle);
cMtx_XrotM(*calc_mtx, new_x_angle);
MtxPosition(&vec, &pos_vec);
*field_D8_ptr = *field_24_ptr;
field_24_ptr->x = field_24_ptr_prev->x + pos_vec.x;
field_24_ptr->y = field_24_ptr_prev->y + pos_vec.y;
field_24_ptr->z = field_24_ptr_prev->z + pos_vec.z;
field_D8_ptr->x = unk * (field_24_ptr->x - field_D8_ptr->x);
field_D8_ptr->y = unk * (field_24_ptr->y - field_D8_ptr->y);
field_D8_ptr->z = unk * (field_24_ptr->z - field_D8_ptr->z);
field_24_ptr++;
field_9C_ptr++;
field_D8_ptr++;
}
}
static f32 tial_scale[] = {
0.25f, 0.275f, 0.2875f, 0.3f, 0.325f, 0.375f, 0.4625f, 0.575f, 0.8f,
};
/* 00000720-00000820 .text tail_draw__FP8dk_classP6tail_s */
static void tail_draw(dk_class* a_this, tail_s* tail) {
cXyz* trans = &tail->field_0x024[0];
csXyz* rot = &tail->field_0x09C[0];
for (int i = 0; i < 9; i++) {
f32 scale = l_HIO.field_0x0C * tial_scale[i];
MtxTrans(trans->x, trans->y, trans->z, false);
MtxScale(scale, scale, scale, true);
cMtx_YrotM(*calc_mtx, rot->y);
cMtx_XrotM(*calc_mtx, rot->x);
J3DModel* model = tail->models[i];
model->setBaseTRMtx(*calc_mtx);
g_env_light.setLightTevColorType(model, &a_this->tevStr);
mDoExt_modelUpdate(model);
trans++;
rot++;
}
}
/* 00000820-00000938 .text kamen_draw__FP8dk_class */
static void kamen_draw(dk_class* a_this) {
J3DModel* model = a_this->mpModelKamen;
MTXCopy(a_this->field_0x2B8->getModel()->getAnmMtx(24), *calc_mtx);
cMtx_YrotM(*calc_mtx, 0x4000);
cMtx_ZrotM(*calc_mtx, -0x4000);
MtxTrans(REG0_F(0) * 0.01f,
(REG0_F(1) * 0.01f) + 50.0f - 10.0f,
(REG0_F(2) * 0.01f) + 140.0f - 15.0f,
true);
model->setBaseTRMtx(*calc_mtx);
g_env_light.settingTevStruct(TEV_TYPE_ACTOR, &a_this->current.pos, &a_this->tevStr);
g_env_light.setLightTevColorType(model, &a_this->tevStr);
mDoExt_modelUpdateDL(model);
}
/* 00000938-00000A18 .text daDk_Draw__FP8dk_class */
static BOOL daDk_Draw(dk_class* a_this) {
if ((l_HIO.field_0x14 == 0 && a_this->field_0xAEE != 0)) {
return TRUE;
}
if (l_HIO.field_0x14 != 0 || a_this->field_0xAC5 > 2) {
J3DModel* model = a_this->field_0x2B8->getModel();
g_env_light.settingTevStruct(TEV_TYPE_ACTOR, &a_this->current.pos, &a_this->tevStr);
g_env_light.setLightTevColorType(model, &a_this->tevStr);
a_this->field_0x2B8->entryDL();
kamen_draw(a_this);
for (s32 i = 0; i < 4; i++) {
tail_draw(a_this, &a_this->tails[i]);
}
}
return TRUE;
}
/* 00000A18-00000A1C .text move__FP8dk_class */
static void move(dk_class*) {
}
/* 00000A1C-00000A20 .text daDk_demoProc__FP8dk_class */
static void daDk_demoProc(dk_class*) {
}
/* 00000A20-00000A60 .text daDk_delete_Bdk__Fv */
static void daDk_delete_Bdk() {
fopAc_ac_c* actor = fopAcM_searchFromName("Bdk", 0, 0);
if (actor != NULL) {
fopAcM_delete(actor);
}
}
/* 00000A60-00000D08 .text daDk_Execute__FP8dk_class */
static BOOL daDk_Execute(dk_class* a_this) {
a_this->field_0x2BC++;
for (s32 i = 0; i < 5; i++) {
if (a_this->field_0x2C0[i] != 0) {
a_this->field_0x2C0[i]--;
}
}
if (l_HIO.field_0x05 == 0) {
move(a_this);
a_this->eyePos = a_this->current.pos;
a_this->eyePos.y += 100.0f;
BOOL demo_set = dDemo_setDemoData(
a_this,
dDemo_actor_c::ENABLE_TRANS_e | dDemo_actor_c::ENABLE_ROTATE_e | dDemo_actor_c::ENABLE_ANM_e | dDemo_actor_c::ENABLE_ANM_FRAME_e,
a_this->field_0x2B8,
"Dk"
);
if (demo_set) {
daDk_demoProc(a_this);
a_this->field_0xAEE = 0;
daDk_delete_Bdk();
} else {
a_this->field_0x2B8->play(&a_this->eyePos, 0, 0);
a_this->field_0xAEE = 1;
}
switch (a_this->field_0xAC5) {
case 0:
if (dComIfGs_isEventBit(dSv_event_flag_c::UNK_0310)) {
a_this->field_0xAC5 = 2;
}
break;
case 2:
if (dComIfGp_evmng_startCheck("zelda_fly")) {
a_this->field_0xAC5 = 3;
}
// fallthrough
case 3:
if (dComIfGs_isEventBit(dSv_event_flag_c::UNK_0001)) {
a_this->field_0xAC5 = -1;
}
break;
case 10:
default:
break;
}
}
if (a_this->field_0x2B4 < 2) {
a_this->field_0x900.CrrPos(*dComIfG_Bgsp());
}
a_this->scale.x = a_this->scale.y = a_this->scale.z = l_HIO.field_0x08;
J3DModel* model = a_this->field_0x2B8->getModel();
model->setBaseScale(a_this->scale);
mDoMtx_stack_c::transS(a_this->current.pos);
mDoMtx_stack_c::YrotM(a_this->current.angle.y);
mDoMtx_stack_c::XrotM(a_this->current.angle.x);
mDoMtx_stack_c::ZrotM(a_this->current.angle.z);
model->setBaseTRMtx(mDoMtx_stack_c::get());
a_this->field_0x2B8->calc();
for (s32 i = 0; i < 4; i++) {
tail_control(a_this, &a_this->tails[i]);
}
return TRUE;
}
/* 00000D08-00000D10 .text daDk_IsDelete__FP8dk_class */
static BOOL daDk_IsDelete(dk_class*) {
return TRUE;
}
/* 00000D10-00000D7C .text daDk_Delete__FP8dk_class */
static BOOL daDk_Delete(dk_class* a_this) {
dComIfG_resDelete(&a_this->mPhs, "Dk");
a_this->field_0xACC.remove();
mDoHIO_deleteChild(l_HIO.mNo);
return TRUE;
}
/* 00000D7C-00000FFC .text useHeapInit__FP10fopAc_ac_c */
static BOOL useHeapInit(fopAc_ac_c* i_this) {
dk_class* a_this = (dk_class*)i_this;
mDoExt_McaMorf* morf = new mDoExt_McaMorf(
(J3DModelData*)dComIfG_getObjectIDRes("Dk", DK_BDL_DK),
NULL,
NULL,
(J3DAnmTransform*)dComIfG_getObjectIDRes("Dk", DK_BCK_FLY1),
J3DFrameCtrl::EMode_LOOP,
1.0f,
0,
-1,
1,
NULL,
0x80000,
0x11020002
);
a_this->field_0x2B8 = morf;
if (a_this->field_0x2B8 == NULL || a_this->field_0x2B8->getModel() == NULL) {
return FALSE;
}
for (u16 i = 0; i < a_this->field_0x2B8->getModel()->getModelData()->getJointNum(); i++) {
if (i == 58 || i == 60 || i == 62 || i == 64) {
a_this->field_0x2B8->getModel()->getModelData()->getJointNodePointer(i)->setCallBack(nodeCallBack);
}
}
a_this->field_0x2B8->getModel()->setUserArea((u32) a_this);
J3DModelData* modelData = (J3DModelData*) dComIfG_getObjectIDRes("Dk", DK_BDL_DK_KAMEN);
a_this->mpModelKamen = mDoExt_J3DModel__create(modelData, 0x80000, 0x11020002);
#if VERSION > VERSION_DEMO
if (a_this->mpModelKamen == NULL) {
return FALSE;
}
#endif
modelData = (J3DModelData*) dComIfG_getObjectIDRes("Dk", DK_BDL_DK_TAIL);
JUT_ASSERT(DEMO_SELECT(817, 819), modelData != NULL);
for (s32 i = 0; i < 4; i++) {
for (s32 j = 0; j < 9; j++) {
a_this->tails[i].models[j] = mDoExt_J3DModel__create(modelData, 0x80000, 0x11020002);
#if VERSION > VERSION_DEMO
if (a_this->tails[i].models[j] == NULL) {
return FALSE;
}
#endif
}
}
return TRUE;
}
/* 00000FFC-000011EC .text daDk_Create__FP10fopAc_ac_c */
static cPhs_State daDk_Create(fopAc_ac_c* i_this) {
dk_class* a_this = (dk_class*)i_this;
fopAcM_ct(i_this, dk_class);
cPhs_State res = dComIfG_resLoad(&a_this->mPhs, "Dk");
if (res == cPhs_COMPLEATE_e) {
a_this->field_0x2B4 = fopAcM_GetParam(a_this);
if (!fopAcM_entrySolidHeap(i_this, useHeapInit, 0x1BD80)) {
return cPhs_ERROR_e;
}
fopAcM_SetMtx(i_this, a_this->field_0x2B8->getModel()->getBaseTRMtx());
fopAcM_SetMin(i_this, -1000.0f, -1000.0f, -1000.0f);
fopAcM_SetMax(i_this, 1000.0f, 1000.0f, 1000.0f);
l_HIO.mNo = mDoHIO_createChild("大怪鳥", &l_HIO);
if (a_this->field_0x2B4 < 2) {
a_this->field_0x900.Set(
fopAcM_GetPosition_p(a_this), fopAcM_GetOldPosition_p(a_this),
a_this, 1, &a_this->field_0x8C0, fopAcM_GetSpeed_p(a_this), NULL, NULL);
}
a_this->field_0x8C0.SetWall(0.0f, 300.0f);
if (a_this->field_0x2B4 == 1) {
a_this->field_0xAC5 = 0;
} else {
a_this->field_0xAC5 = 10;
}
a_this->field_0xAC8 = 0;
}
return res;
}
static actor_method_class l_daDk_Method = {
(process_method_func)daDk_Create,
(process_method_func)daDk_Delete,
(process_method_func)daDk_Execute,
(process_method_func)daDk_IsDelete,
(process_method_func)daDk_Draw,
};
actor_process_profile_definition g_profile_DK = {
/* LayerID */ fpcLy_CURRENT_e,
/* ListID */ 0x0007,
/* ListPrio */ fpcPi_CURRENT_e,
/* ProcName */ PROC_DK,
/* Proc SubMtd */ &g_fpcLf_Method.base,
/* Size */ sizeof(dk_class),
/* SizeOther */ 0,
/* Parameters */ 0,
/* Leaf SubMtd */ &g_fopAc_Method.base,
/* Priority */ PRIO_DK,
/* Actor SubMtd */ &l_daDk_Method,
/* Status */ fopAcStts_CULL_e | fopAcStts_UNK40000_e,
/* Group */ fopAc_ACTOR_e,
/* CullType */ fopAc_CULLBOX_CUSTOM_e,
};