Files
dusklight/src/d/actor/d_a_obj_kznkarm.cpp
T
hatal175 e82806047b d_a_obj_kznkarm OK (#2678)
* d_a_obj_kznkarm OK

* d_a_title GZ2P01 Matching

* More GZ2P01 Matches

* d_s_name matching for PAL

* d_msg_scrn_light Matching for PAL

* d_menu_fishing Matches on PAL

* d_file_sel_info Matches on PAL

* d_a_npc_cd Matching on PAL

* d_error_msg Matches on PAL

* d_cam_param matches as is on PAL

* Fix PAL JSystem and Z2AudioLib splits/symbols

* Aligning the rest of TUs to compile on all GC versions
2025-09-21 13:26:34 -06:00

502 lines
17 KiB
C++

/**
* @file d_a_obj_kznkarm.cpp
*
*/
#include "d/dolzel_rel.h"
#include "d/actor/d_a_player.h"
#include "d/actor/d_a_obj_kznkarm.h"
#include "d/actor/d_a_obj_kazeneko.h"
#include "d/d_a_obj.h"
#if DEBUG
class daObjKznkarm_Hio_c : public JORReflexible {
public:
daObjKznkarm_Hio_c();
void genMessage(JORMContext* ctx);
void default_set();
void ct();
void dt();
/* 0x04 */ int mCount;
/* 0x04 */ daObjKznkarm_Attr_c mAttr;
};
static daObjKznkarm_Hio_c M_hio;
daObjKznkarm_Hio_c::daObjKznkarm_Hio_c() {
mCount = 0;
default_set();
}
void daObjKznkarm_Hio_c::default_set() {
mAttr = daObjKznkarm_c::M_attr;
}
void daObjKznkarm_Hio_c::ct() {
if (mCount++ == 0) {
daObj::HioVarious_c::init(this, "風見ネコの風受け");
}
}
void daObjKznkarm_Hio_c::dt() {
if (--mCount == 0) {
daObj::HioVarious_c::clean(this);
}
}
void daObjKznkarm_Hio_c::genMessage(JORMContext* ctx) {
ctx->genLabel("§ 風見ネコの風受けパラメータ設定 §\n", 0, 0, NULL, 0xffff, 0xffff, 0x200,
0x18);
ctx->genSlider("重力", &mAttr.gravity, -50.0f, 0.0f, 0,
NULL, 0xffff, 0xffff, 0x200, 0x18);
ctx->genSlider("最高落下速度", &mAttr.maximum_falling_speed, -200.0f, 0.0f, 0,
NULL, 0xffff, 0xffff, 0x200, 0x18);
ctx->genSlider("水抵抗", &mAttr.water_drag, 0.0f, 1.0f, 0,
NULL, 0xffff, 0xffff, 0x200, 0x18);
ctx->genSlider("跳ね返り係数", &mAttr.bounce_coeff, 0.0f, 1.0f, 0,
NULL, 0xffff, 0xffff, 0x200, 0x18);
ctx->genSlider("回転角速度X", &mAttr.angular_speed.x, -0x4000,
0x3fff, 0, NULL, 0xffff, 0xffff, 0x200, 0x18);
ctx->genSlider("回転角速度Y", &mAttr.angular_speed.y, -0x4000,
0x3fff, 0, NULL, 0xffff, 0xffff, 0x200, 0x18);
ctx->genSlider("回転角速度Z", &mAttr.angular_speed.z, -0x4000,
0x3fff, 0, NULL, 0xffff, 0xffff, 0x200, 0x18);
ctx->genSlider("置き位置X", &mAttr.position.x, -200.0f,
200.0f, 0, NULL, 0xffff, 0xffff, 0x200, 0x18);
ctx->genSlider("置き位置Y", &mAttr.position.y, -200.0f,
200.0f, 0, NULL, 0xffff, 0xffff, 0x200, 0x18);
ctx->genSlider("置き位置Z", &mAttr.position.z, -200.0f,
200.0f, 0, NULL, 0xffff, 0xffff, 0x200, 0x18);
ctx->genSlider("初期投げ力", &mAttr.initial_throwing_force, 0.0f, 300.0f,
0, NULL, 0xffff, 0xffff, 0x200, 0x18);
ctx->genSlider("初期投げ上げ力", &mAttr.initial_throwing_upward_force, 0.0f, 300.0f,
0, NULL, 0xffff, 0xffff, 0x200, 0x18);
ctx->genSlider("投げ回転角速度", &mAttr.throw_angular_speed, -0x8000,
0x7fff, 0, NULL, 0xffff, 0xffff, 0x200, 0x18);
}
#endif
/* 80C50D08-80C50D40 000000 0038+00 8/8 0/0 0/0 .rodata M_attr__14daObjKznkarm_c */
daObjKznkarm_Attr_c const daObjKznkarm_c::M_attr = {
-5.0f, -30.0f, 0.6f, 0.94f,
40.0f, 40.0f, -60.0f,
-6.0f, -6.0f, -60.0f, 0.0f,
12.0f, 0, 0x1000, 0, 0xE000,
};
/* 80C50DC4-80C50DC8 -00001 0004+00 3/3 0/0 0/0 .data l_arcName */
static char* l_arcName = "J_Kazami";
/* 80C50E28-80C50E88 000084 0060+00 1/2 0/0 0/0 .data ActionTable__14daObjKznkarm_c */
daObjKznkarm_c::actionFunc daObjKznkarm_c::ActionTable[4][2] = {
&daObjKznkarm_c::initBroken,
&daObjKznkarm_c::executeBroken,
&daObjKznkarm_c::initCarry,
&daObjKznkarm_c::executeCarry,
&daObjKznkarm_c::initThrow,
&daObjKznkarm_c::executeThrow,
&daObjKznkarm_c::initStay,
&daObjKznkarm_c::executeStay,
};
/* 80C4F858-80C4F88C 000078 0034+00 5/5 0/0 0/0 .text
* setAction__14daObjKznkarm_cFQ214daObjKznkarm_c6Mode_e */
void daObjKznkarm_c::setAction(daObjKznkarm_c::Mode_e i_action) {
JUT_ASSERT(209, i_action < MODE_MAX_e);
mAction = ActionTable[i_action];
callInit();
}
/* 80C4F88C-80C4F8B4 0000AC 0028+00 1/1 0/0 0/0 .text callInit__14daObjKznkarm_cFv */
void daObjKznkarm_c::callInit() {
JUT_ASSERT(225, mAction != 0);
(this->*mAction[0])();
}
/* 80C4F8B4-80C4F8E0 0000D4 002C+00 1/1 0/0 0/0 .text callExecute__14daObjKznkarm_cFv */
void daObjKznkarm_c::callExecute() {
JUT_ASSERT(238, mAction != 0);
(this->*mAction[1])();
}
inline daObjKznkarm_Attr_c* daObjKznkarm_c::attr() const {
#if DEBUG
return &M_hio.mAttr;
#else
return (daObjKznkarm_Attr_c*)&M_attr;
#endif
}
/* 80C4F8E0-80C4F960 000100 0080+00 1/0 0/0 0/0 .text initBroken__14daObjKznkarm_cFv */
void daObjKznkarm_c::initBroken() {
mMode = MODE_BROKEN_e;
fopAcM_OffStatus(this, fopAcM_STATUS_UNK_0x80);
daObjKazeNeko_c* kazeNeko = (daObjKazeNeko_c*)fpcM_SearchByID(parentActorID);
if (kazeNeko != NULL) {
kazeNeko->getFirstVec(&speed, fopAcM_GetParam(this));
}
field_0x7a8 = attr()->angular_speed.x;
field_0x7aa = attr()->angular_speed.y;
field_0x7ac = attr()->angular_speed.z;
field_0x7b0 = 10;
}
/* 80C4F960-80C4FBBC 000180 025C+00 1/0 0/0 0/0 .text executeBroken__14daObjKznkarm_cFv
*/
void daObjKznkarm_c::executeBroken() {
speed.y += gravity;
if (speed.y < maxFallSpeed) {
speed.y = maxFallSpeed;
}
current.pos += speed;
if (field_0x7b0 != 0) {
field_0x7b0--;
}
if (field_0x7b0 == 0) {
f32 gndH = mAcch.GetGroundH();
if (current.pos.y < gndH) {
speed.y *= -1.0f;
speed *= attr()->bounce_coeff;
current.pos.y = gndH;
}
if (speed.abs() < fabsf(gravity)) {
speed.zero();
field_0x7a8 = 0;
field_0x7aa = 0;
field_0x7ac = 0;
shape_angle.x = 0x4000;
shape_angle.z = 0;
current.pos.y = gndH;
setAction(MODE_STAY_e);
}
}
shape_angle.x = shape_angle.x + field_0x7a8;
shape_angle.y = shape_angle.y + field_0x7aa;
shape_angle.z = shape_angle.z + field_0x7ac;
setBaseMtx();
mAcch.CrrPos(dComIfG_Bgsp());
}
/* 80C4FBBC-80C4FBEC 0003DC 0030+00 1/0 0/0 0/0 .text initCarry__14daObjKznkarm_cFv */
void daObjKznkarm_c::initCarry() {
mMode = MODE_CARRY_e;
fopAcM_OffStatus(this, fopAcM_STATUS_UNK_0x80);
cLib_offBit<u32>(attention_info.flags, fopAc_AttnFlag_CARRY_e);
field_0x7ae = 0;
field_0x7af = 0;
}
/* 80C4FBEC-80C4FD18 00040C 012C+00 1/0 0/0 0/0 .text executeCarry__14daObjKznkarm_cFv */
void daObjKznkarm_c::executeCarry() {
eyePos = attention_info.position = current.pos;
daPy_py_c* player = daPy_getPlayerActorClass();
if (player->getGrabUpStart()) {
field_0x7af = 1;
}
if (!fopAcM_checkCarryNow(this)) {
fopAcM_carryOffRevise(this);
setAction(MODE_THROW_e);
}
mDoMtx_stack_c::transS(current.pos);
if (field_0x7af != 0) {
mDoMtx_stack_c::ZXYrotM(shape_angle);
mDoMtx_stack_c::transM(attr()->field_0x18.x, attr()->field_0x18.y, attr()->field_0x18.z);
} else {
mDoMtx_stack_c::YrotM(shape_angle.y);
mDoMtx_stack_c::ZrotM(shape_angle.z);
mDoMtx_stack_c::XrotM(shape_angle.x);
mDoMtx_stack_c::transM(attr()->position.x, attr()->position.y, attr()->position.z);
}
mpModel->setBaseTRMtx(mDoMtx_stack_c::get());
}
/* 80C4FD18-80C4FDB4 000538 009C+00 1/0 0/0 0/0 .text initThrow__14daObjKznkarm_cFv */
void daObjKznkarm_c::initThrow() {
mMode = MODE_THROW_e;
fopAcM_OffStatus(this, fopAcM_STATUS_UNK_0x80);
speed.zero();
if (speedF > 1.0f) {
daPy_py_c* player = daPy_getPlayerActorClass();
f32 dVar9 = player->speedF + attr()->initial_throwing_force;
speed.set((dVar9 * cM_ssin(player->shape_angle.y)), attr()->initial_throwing_upward_force,
dVar9 * cM_scos(player->shape_angle.y));
}
field_0x7ac = attr()->throw_angular_speed;
}
/* 80C4FDB4-80C50440 0005D4 068C+00 1/0 0/0 0/0 .text executeThrow__14daObjKznkarm_cFv */
void daObjKznkarm_c::executeThrow() {
if (field_0x7ae != 0) {
speed.y += gravity * 0.2f;
if (speed.y < maxFallSpeed * 0.2f) {
speed.y = maxFallSpeed * 0.2f;
}
} else {
speed.y += gravity;
if (speed.y < maxFallSpeed) {
speed.y = maxFallSpeed;
}
}
f32 savedSpeedY = speed.y;
fopAcM_posMove(this, 0);
mAcch.CrrPos(dComIfG_Bgsp());
speed.y = savedSpeedY;
if (mAcch.ChkGroundLanding()) {
f32 speedAbs = speed.abs();
cM3dGPla groundPla;
bool hit = dComIfG_Bgsp().GetTriPla(mAcch.m_gnd, &groundPla);
cXyz* normal = groundPla.GetNP();
if (normal != NULL) {
VECReflect(&speed, normal, &speed);
speed *= speedAbs * attr()->bounce_coeff;
} else {
speed.y *= -attr()->bounce_coeff;
}
current.pos.y = mAcch.GetGroundH();
} else if (mAcch.ChkGroundHit()) {
speed.zero();
setAction(MODE_STAY_e);
}
if (mAcch.ChkWallHit()) {
f32 speedAbs = speed.abs();
cM3dGPla wallPla;
bool hit = dComIfG_Bgsp().GetTriPla(mAcchCir, &wallPla);
cXyz* normal = wallPla.GetNP();
if (normal != NULL) {
VECReflect(&speed, normal, &speed);
speed *= speedAbs * attr()->bounce_coeff;
} else {
speed.x *= -attr()->bounce_coeff;
speed.z *= -attr()->bounce_coeff;
}
field_0x7ac *= -1;
}
if (field_0x7ae == 0) {
if (mAcch.ChkWaterIn()) {
cXyz effectPos = current.pos;
effectPos.y = mAcch.m_wtr.GetHeight();
for (int i = 0; i < 4; i++) {
static u16 w_eff_id[4] = {
ID_ZI_J_DOWNWTRA_A, ID_ZI_J_DOWNWTRA_B, ID_ZI_J_DOWNWTRA_C, ID_ZI_J_DOWNWTRA_D,
};
field_0x798[i] = dComIfGp_particle_set(field_0x798[i], w_eff_id[i], &effectPos, &tevStr);
}
Z2GetAudioMgr()->seStart(Z2SE_CM_BODYFALL_WATER_S, &effectPos, 0, false, 1.0f, 1.0f, -1.0f, -1.0f, false);
field_0x7ae = 1;
}
}
if (field_0x7ae != 0) {
speed.x *= attr()->water_drag;
speed.z *= attr()->water_drag;
}
f32 fVar1 = (speed.absXZ() / attr()->initial_throwing_force);
int angleOffset = (f32)field_0x7ac * fVar1;
shape_angle.z += angleOffset;
setBaseMtx();
}
/* 80C50488-80C50504 000CA8 007C+00 1/0 0/0 0/0 .text initStay__14daObjKznkarm_cFv */
void daObjKznkarm_c::initStay() {
mMode = MODE_STAY_e;
fopAcM_OnStatus(this, fopAcM_STATUS_UNK_0x80);
cLib_onBit<u32>(attention_info.flags, fopAc_AttnFlag_CARRY_e);
speedF = 0.0f;
field_0x7a8 = getGroundSlope(shape_angle.y) - 0x4000;
shape_angle.z = (s16)getGroundSlope(shape_angle.y - 0x4000);
}
/* 80C50504-80C505F8 000D24 00F4+00 1/0 0/0 0/0 .text executeStay__14daObjKznkarm_cFv */
void daObjKznkarm_c::executeStay() {
if (shape_angle.x != field_0x7a8) {
eyePos = attention_info.position = current.pos;
cLib_chaseAngleS(&shape_angle.x, field_0x7a8, 0xc00);
mDoMtx_stack_c::transS(current.pos);
mDoMtx_stack_c::YrotM(shape_angle.y);
mDoMtx_stack_c::ZrotM(shape_angle.z);
mDoMtx_stack_c::XrotM(shape_angle.x);
mDoMtx_stack_c::transM(attr()->position.x, attr()->position.y, attr()->position.z);
mpModel->setBaseTRMtx(mDoMtx_stack_c::get());
}
if (fopAcM_checkCarryNow(this)) {
setAction(MODE_CARRY_e);
}
}
/* 80C505F8-80C506DC 000E18 00E4+00 1/1 0/0 0/0 .text create_init__14daObjKznkarm_cFv */
void daObjKznkarm_c::create_init() {
fopAcM_setCullSizeBox(this, -10.0f, -15.0f, -15.0f, 120.0f, 40.0f, 15.0f);
fopAcM_OnCarryType(this, fopAcM_CARRY_UNK_30);
attention_info.distances[fopAc_attn_CARRY_e] = 0xd;
gravity = attr()->gravity;
maxFallSpeed = attr()->maximum_falling_speed;
setAction(MODE_BROKEN_e);
initBaseMtx();
mAcchCir.SetWall(0.0f, 50.0f);
mAcch.Set(fopAcM_GetPosition_p(this), fopAcM_GetOldPosition_p(this), this, 1, &mAcchCir, fopAcM_GetSpeed_p(this), fopAcM_GetAngle_p(this), fopAcM_GetShapeAngle_p(this));
mAcch.SetRoofNone();
mAcch.OffClrSpeedY();
#if DEBUG
M_hio.ct();
#endif
}
/* 80C506DC-80C50708 000EFC 002C+00 1/1 0/0 0/0 .text initBaseMtx__14daObjKznkarm_cFv */
void daObjKznkarm_c::initBaseMtx() {
fopAcM_SetMtx(this, mpModel->getBaseTRMtx());
setBaseMtx();
}
/* 80C50708-80C5076C 000F28 0064+00 3/3 0/0 0/0 .text setBaseMtx__14daObjKznkarm_cFv */
void daObjKznkarm_c::setBaseMtx() {
mDoMtx_stack_c::transS(current.pos);
mDoMtx_stack_c::ZXYrotM(shape_angle);
mDoMtx_stack_c::transM(-60.0f, 0.0f, 0.0f);
mpModel->setBaseTRMtx(mDoMtx_stack_c::get());
}
/* 80C5076C-80C507F8 000F8C 008C+00 1/1 0/0 0/0 .text getGroundSlope__14daObjKznkarm_cFs
*/
s16 daObjKznkarm_c::getGroundSlope(s16 param_0) {
cM3dGPla groundPla;
bool hit = dComIfG_Bgsp().GetTriPla(mAcch.m_gnd, &groundPla);
if (hit) {
return fopAcM_getPolygonAngle(&groundPla, param_0);
}
return shape_angle.z;
}
inline int daObjKznkarm_c::createHeap() {
J3DModelData* modelData = (J3DModelData*)dComIfG_getObjectRes(l_arcName, "arm.bmd");
JUT_ASSERT(593, modelData != 0);
mpModel = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084);
if (mpModel == NULL) {
return FALSE;
}
return TRUE;
}
/* 80C507F8-80C50870 001018 0078+00 1/1 0/0 0/0 .text createSolidHeap__FP10fopAc_ac_c */
static int createSolidHeap(fopAc_ac_c* a_this) {
daObjKznkarm_c* i_this = ((daObjKznkarm_c*)a_this);
return i_this->createHeap();
}
inline int daObjKznkarm_c::draw() {
g_env_light.settingTevStruct(0x10, &current.pos, &tevStr);
g_env_light.setLightTevColorType_MAJI(mpModel, &tevStr);
dComIfGd_setListBG();
mDoExt_modelUpdateDL(mpModel);
dComIfGd_setList();
cXyz shadowPos = cXyz(current.pos.x, current.pos.y + 50.0f, current.pos.z);
mShadowId = dComIfGd_setShadow(mShadowId, 1, mpModel, &shadowPos, 600.0f, 0.0f,
current.pos.y, mAcch.GetGroundH(), mAcch.m_gnd, &tevStr, 0, 1.0f, dDlst_shadowControl_c::getSimpleTex());
return 1;
}
/* 80C50870-80C50984 001090 0114+00 1/0 0/0 0/0 .text daObjKznkarm_Draw__FP14daObjKznkarm_c */
static int daObjKznkarm_Draw(daObjKznkarm_c* i_this) {
return i_this->draw();
}
inline int daObjKznkarm_c::execute() {
#if DEBUG
gravity = attr()->gravity;
maxFallSpeed = attr()->maximum_falling_speed;
#endif
callExecute();
return 1;
}
/* 80C50984-80C509A8 0011A4 0024+00 1/0 0/0 0/0 .text daObjKznkarm_Execute__FP14daObjKznkarm_c */
static int daObjKznkarm_Execute(daObjKznkarm_c* i_this) {
return i_this->execute();
}
/* 80C509A8-80C509B0 0011C8 0008+00 1/0 0/0 0/0 .text daObjKznkarm_IsDelete__FP14daObjKznkarm_c */
static int daObjKznkarm_IsDelete(daObjKznkarm_c* i_this) {
return 1;
}
inline daObjKznkarm_c::~daObjKznkarm_c() {
#if DEBUG
M_hio.dt();
#endif
dComIfG_resDelete(&mPhase, l_arcName);
}
/* 80C509B0-80C50A5C 0011D0 00AC+00 1/0 0/0 0/0 .text daObjKznkarm_Delete__FP14daObjKznkarm_c */
static int daObjKznkarm_Delete(daObjKznkarm_c* i_this) {
fopAcM_RegisterDeleteID(i_this, "KznkArm");
i_this->~daObjKznkarm_c();
return 1;
}
inline int daObjKznkarm_c::create() {
fopAcM_SetupActor(this, daObjKznkarm_c);
int rv = dComIfG_resLoad(&mPhase, l_arcName);
if (rv == cPhs_COMPLEATE_e) {
if (!fopAcM_entrySolidHeap(this, createSolidHeap, 0x4000)) {
return cPhs_ERROR_e;
}
create_init();
}
return rv;
}
/* 80C50A5C-80C50B3C 00127C 00E0+00 1/0 0/0 0/0 .text daObjKznkarm_Create__FP10fopAc_ac_c
*/
static int daObjKznkarm_Create(fopAc_ac_c* i_this) {
fopAcM_RegisterCreateID(daObjKznkarm_c, i_this, "KznkArm");
return a_this->create();
}
/* 80C50E90-80C50EB0 -00001 0020+00 1/0 0/0 0/0 .data l_daObjKznkarm_Method */
static actor_method_class l_daObjKznkarm_Method = {
(process_method_func)daObjKznkarm_Create,
(process_method_func)daObjKznkarm_Delete,
(process_method_func)daObjKznkarm_Execute,
(process_method_func)daObjKznkarm_IsDelete,
(process_method_func)daObjKznkarm_Draw,
};
/* 80C50EB0-80C50EE0 -00001 0030+00 0/0 0/0 1/0 .data g_profile_Obj_KznkArm */
extern actor_process_profile_definition g_profile_Obj_KznkArm = {
fpcLy_CURRENT_e, // mLayerID
7, // mListID
fpcPi_CURRENT_e, // mListPrio
PROC_Obj_KznkArm, // mProcName
&g_fpcLf_Method.base, // sub_method
sizeof(daObjKznkarm_c), // mSize
0, // mSizeOther
0, // mParameters
&g_fopAc_Method.base, // sub_method
31, // mPriority
&l_daObjKznkarm_Method, // sub_method
0x00044100, // mStatus
fopAc_ACTOR_e, // mActorType
fopAc_CULLBOX_CUSTOM_e, // cullType
};
/* 80C50D90-80C50D90 000088 0000+00 0/0 0/0 0/0 .rodata @stringBase0 */