Files
tww/src/d/actor/d_a_himo3.cpp
T
2026-05-18 00:10:32 -04:00

877 lines
30 KiB
C++

/**
* d_a_himo3.cpp
* Object - Rope (Pirate Ship rope minigame, Forsaken Fortress)
*/
#include "d/dolzel_rel.h" // IWYU pragma: keep
#include "d/actor/d_a_himo3.h"
#include "d/actor/d_a_player.h"
#include "d/res/res_always.h"
#if VERSION > VERSION_DEMO
#include "d/res/res_bgn.h"
#endif
#include "d/res/res_link.h"
#include "d/res/res_himo3.h"
#include "d/d_s_play.h"
#include "d/d_procname.h"
#include "d/d_priority.h"
#include "d/d_com_inf_game.h"
#include "d/d_kankyo_wether.h"
#include "f_op/f_op_actor_mng.h"
class himo3HIO_c : public JORReflexible {
public:
himo3HIO_c() {
m06 = 0;
m08 = 0.75f;
m0C = 0.5f;
m10 = 0xEB;
m12 = 0x7D;
m14 = 0;
m18 = 5.0f;
}
virtual ~himo3HIO_c() {}
void genMessage(JORMContext* ctx) {}
public:
/* 0x04 */ s8 mNo;
/* 0x06 */ s16 m06;
/* 0x08 */ f32 m08;
/* 0x0C */ f32 m0C;
/* 0x10 */ s16 m10;
/* 0x10 */ s16 m12;
/* 0x10 */ s16 m14;
/* 0x18 */ f32 m18;
}; // size = 0x1C
static f32 HIMO3_SCALE;
static bool hio_set;
static himo3HIO_c l_HIO;
/* 000000EC-00000C58 .text himo3_control__FP11himo3_classP7himo3_s */
void himo3_control(himo3_class* i_this, himo3_s* r31) {
/* Nonmatching - regalloc */
fopAc_ac_c* actor = &i_this->actor;
daPy_py_c* player = (daPy_py_c*)dComIfGp_getPlayer(0);
int i = 1;
cXyz spAC;
cXyz spA0;
cXyz sp94;
f32 tmp200;
f32 tmpReg;
f32 f28;
f32 f27;
r31 += 1;
if (i_this->m02BE != 0) {
s16 target;
if (i_this->m02BE == 1) {
if (player->getRopeGrabRightHand()) {
spAC = player->getRightHandPos();
} else {
spAC = player->getLeftHandPos();
}
target = player->shape_angle.y;
} else {
spAC = i_this->m21F4;
target = i_this->m2200;
}
if (i_this->m15C4.y == -23535.0f) {
i_this->m15C4 = spAC;
}
cXyz sp88 = spAC - actor->current.pos;
f32 sqrt = sp88.abs();
int iVar8 = sqrt / HIMO3_SCALE;
f28 = sqrt / HIMO3_SCALE - iVar8;
if (iVar8 >= i_this->m15C0 - 1) {
iVar8 = i_this->m15C0 - 1;
}
if (iVar8 > 1) {
for (i = 1; i < iVar8; i++, r31++) {
f32 fVar12 = (f32)i / (iVar8 - 1);
r31->m00.x = actor->current.pos.x + sp88.x * fVar12;
r31->m00.y = actor->current.pos.y + sp88.y * fVar12;
r31->m00.z = actor->current.pos.z + sp88.z * fVar12;
}
}
cLib_addCalcAngleS2(&actor->current.angle.y, target, 2, 0x2000);
spA0 = spAC - i_this->m15C4;
cMtx_YrotS(*calc_mtx, -target);
MtxPosition(&spA0, &sp94);
f32 tmp1 = sp94.z * DEMO_SELECT(REG0_F(5) + -10.0f, -10.0f);
f32 tmp2 = DEMO_SELECT(REG0_F(6) + 10.0f, 10.0f);
cLib_addCalc2(&i_this->m15D0, tmp1, 0.1f, tmp2 * i_this->m15E4);
f32 f1 = sp94.x * DEMO_SELECT(REG0_F(5) + -10.0f, -10.0f);
tmp2 = DEMO_SELECT(REG0_F(6) + 10.0f, 10.0f);
cLib_addCalc2(&i_this->m15D8, f1, 0.1f, tmp2 * i_this->m15E4);
// TODO: fakematch
f32 fake1 = tmp1;
f32 fake2 = f1;
if (std::fabsf(sp94.z) > 1.0f || std::fabsf(sp94.x) > 1.0f) {
cLib_addCalc2(&i_this->m15E4, 1.0f, 1.0f, 0.05f);
} else {
cLib_addCalc2(&i_this->m15E4, 0.1f, 1.0f, 0.05f);
}
if (fopAcM_GetParam(i_this) == 3) {
i_this->m02BE = 0;
i_this->m02BC = 0x1e;
i_this->m15E0 = 0.0f;
}
i_this->m15C4 = spAC;
} else {
i_this->m15D0 += i_this->m15D4;
f32 tmp = i_this->m15D0 * DEMO_SELECT(REG0_F(7) + -0.003f, -0.003f);
i_this->m15D4 += tmp;
cLib_addCalc0(&i_this->m15D0, 0.05f, DEMO_SELECT(REG0_F(9) + 1.0f, 1.0f));
i_this->m15D8 += i_this->m15DC;
tmp = i_this->m15D8 * DEMO_SELECT(REG0_F(7) + -0.003f, -0.003f);
i_this->m15DC += tmp;
cLib_addCalc0(&i_this->m15D8, 0.05f, DEMO_SELECT(REG0_F(9) + 1.0f, 1.0f));
if (fopAcM_GetParam(i_this) == 1) {
i_this->m02BE = 1;
i_this->m15E0 = 1.0f;
if (strcmp(dComIfGp_getStartStageName(), "majroom") == 0 || strcmp(dComIfGp_getStartStageName(), "Majroom") == 0 ||
strcmp(dComIfGp_getStartStageName(), "MajyuE") == 0)
{
dComIfGs_onEventBit(dSv_event_flag_c::UNK_0402);
}
} else if (fopAcM_GetParam(i_this) == 2) {
i_this->m02BE = 2;
i_this->m15E0 = 1.0f;
}
i_this->m15C4.y = -23535.0f;
}
cMtx_YrotS(*calc_mtx, actor->current.angle.y);
spA0.x = i_this->m15D8;
spA0.y = 0.0f;
spA0.z = i_this->m15D0;
cXyz sp7C;
MtxPosition(&spA0, &sp7C);
cXyz* pcVar7 = dKyw_get_wind_vec();
s16 iVar8 = cM_atan2s(pcVar7->x, pcVar7->z);
f32* pfVar9 = dKyw_get_wind_power();
if (i_this->m02BE != 0) {
cLib_addCalc2(&i_this->m15E8, *pfVar9 * 0.5f, 1.0f, 0.05f);
} else {
cLib_addCalc2(&i_this->m15E8, *pfVar9, 1.0f, 0.001f);
}
if (i_this->m15F0 > 0.01f) {
i_this->m15FA++;
} else {
i_this->m15FA = 0;
}
cLib_addCalc2(&i_this->m15F0, i_this->m15F4, 0.2f, DEMO_SELECT(REG0_F(2) + 0.05f, 0.05f));
cLib_addCalc0(&i_this->m15F4, 1.0f, DEMO_SELECT(REG0_F(3) + 0.005f, 0.005f));
cMtx_YrotS(*calc_mtx, i_this->m15F8);
spA0.x = 0.0f;
spA0.y = 0.0f;
spA0.z = cM_ssin(i_this->m15FA * DEMO_SELECT(REG0_S(5) + 500, 500)) * DEMO_SELECT(REG0_F(4) + 100.0f, 100.0f) * i_this->m15F0;
cXyz sp70;
MtxPosition(&spA0, &sp70);
cMtx_YrotS(*calc_mtx, iVar8);
spA0.x = 0.0f;
spA0.y = 0.0f;
spA0.z = cM_ssin(i_this->m02BA * DEMO_SELECT(REG0_S(5) + 500, 500)) * DEMO_SELECT(REG0_F(4) + 100.0f, 100.0f) * i_this->m15E8;
cXyz sp64;
MtxPosition(&spA0, &sp64);
sp64 += sp70;
tmpReg = DEMO_SELECT(REG0_F(1), 0.0f);
spA0.x = 0.0f;
spA0.y = 0.0f;
tmp200 = DEMO_SELECT(REG0_F(8) + -200.0f, -200.0f);
int j = 0;
if ((i_this->m02BE == 0) && (i_this->m02BC == 0)) {
f27 = DEMO_SELECT(REG0_F(2) + 30.0f + 20.0f - 20.0f, 30.0f);
} else {
f27 = -200.0f;
}
s16 unaff_r24;
s16 unaff_r23;
u8 bVar4 = 0;
for (; i < i_this->m15C0; i++, r31++) {
cXyz sp60;
sp60.z = 0.0f;
sp60.y = 0.0f;
sp60.x = 0.0f;
Vec f29_f26_f25;
f29_f26_f25.x = r31->m00.x - r31[-1].m00.x + r31->m0C.x + sp7C.x + sp64.x + sp60.x;
f29_f26_f25.y = r31->m00.y - r31[-1].m00.y + tmp200 + r31->m0C.y + sp60.y;
f29_f26_f25.z = r31->m00.z - r31[-1].m00.z + r31->m0C.z + sp7C.z + sp64.z + sp60.z;
unaff_r24 = -cM_atan2s(f29_f26_f25.y, f29_f26_f25.z);
unaff_r23 = (s16)cM_atan2s(f29_f26_f25.x + 0.0f, std::sqrtf(SQUARE(f29_f26_f25.y) + SQUARE(f29_f26_f25.z)));
cMtx_XrotS(*calc_mtx, unaff_r24);
cMtx_YrotM(*calc_mtx, unaff_r23);
spA0.z = HIMO3_SCALE;
if (bVar4 == 0) {
spA0.z -= f28 * HIMO3_SCALE;
bVar4++;
}
MtxPosition(&spA0, &sp94);
r31->m0C = r31->m00;
r31->m00 = r31[-1].m00 + sp94;
r31->m0C.x = (r31->m00.x - r31->m0C.x) * tmpReg;
r31->m0C.y = (r31->m00.y - r31->m0C.y) * tmpReg;
r31->m0C.z = (r31->m00.z - r31->m0C.z) * tmpReg;
if ((i_this->m0298 == 0xf) && (i == i_this->m15C0 - 1)) {
if (i_this->m02BE == 0) {
i_this->mCyl.SetC(r31->m00);
} else {
cXyz sp4C(-10000.0f, -10000.0f, 0.0f);
i_this->mCyl.SetC(sp4C);
}
dComIfG_Ccsp()->Set(&i_this->mCyl);
} else if (((i + i_this->m02BA * 3 & 0xf) == 0) && (j < 5)) {
i_this->mSphs[j].SetR(f27);
i_this->mSphs[j].SetC(r31->m00);
dComIfG_Ccsp()->Set(&i_this->mSphs[j]);
j++;
}
}
cXyz* pcVar10 = i_this->mLineMat.getPos(0);
himo3_s* phVar11 = i_this->m02C0;
for (int i = 0; i < i_this->m15C0; i++, phVar11++, pcVar10++) {
if (i_this->m15E0 >= 0.999f) {
*pcVar10 = phVar11->m00;
} else {
cLib_addCalc2(&pcVar10->x, phVar11->m00.x, 1.0f, i_this->m15E0 * 100.0f);
cLib_addCalc2(&pcVar10->y, phVar11->m00.y, 1.0f, i_this->m15E0 * 100.0f);
cLib_addCalc2(&pcVar10->z, phVar11->m00.z, 1.0f, i_this->m15E0 * 100.0f);
}
if ((i_this->m0298 != 0xf) && (i == i_this->m15C0 - 1)) {
MtxTrans(pcVar10->x, pcVar10->y, pcVar10->z, 0);
cMtx_XrotM(*calc_mtx, unaff_r24);
cMtx_YrotM(*calc_mtx, unaff_r23);
f32 fVar14 = l_HIO.m08;
if (i_this->m0298 != 1) {
cMtx_XrotM(*calc_mtx, -0x4000);
fVar14 = l_HIO.m0C;
}
MtxScale(fVar14, fVar14, fVar14, true);
i_this->mpModel->setBaseTRMtx(*calc_mtx);
}
}
cLib_addCalc2(&i_this->m15E0, 1.0f, 1.0f, DEMO_SELECT(REG0_F(3) + 0.05f, 0.05f));
}
/* 00000C58-00000D1C .text ga_draw__FP11himo3_class */
void ga_draw(himo3_class* i_this) {
h3_ga_s* ga = &i_this->m2114[0];
for (int i = 0; i < ARRAY_SSIZE(i_this->m2114); i++, ga++) {
if (ga->m2E == 1) {
MtxTrans(ga->mPos.x, ga->mPos.y, ga->mPos.z, 0);
cMtx_YrotM(*calc_mtx, ga->m1E);
cMtx_XrotM(*calc_mtx, ga->m1C);
MtxScale(ga->m24, ga->m24 * ga->m28, ga->m24, true);
MtxTrans(0.0f, -18.0f, 0.0f, 1);
ga->mpModel->setBaseTRMtx(*calc_mtx);
mDoExt_modelUpdateDL(ga->mpModel);
}
}
}
/* 00000D1C-00000EF8 .text daHimo3_Draw__FP11himo3_class */
static BOOL daHimo3_Draw(himo3_class* i_this) {
fopAc_ac_c* actor = &i_this->actor;
g_env_light.settingTevStruct(TEV_TYPE_BG0, &actor->current.pos, &actor->tevStr);
f32 fVar1;
if (i_this->m0298 == 0xf) {
fVar1 = DEMO_SELECT(REG0_F(0) + 4.625f, 4.625f);
} else {
fVar1 = DEMO_SELECT(REG0_F(0) + 3.75f, 3.75f);
}
#ifdef __MWERKS__
i_this->mLineMat.update(i_this->m15C0, fVar1, (GXColor){200, 150, 50, 255}, 0, &actor->tevStr);
#else
GXColor color = (GXColor){200, 150, 50, 255};
i_this->mLineMat.update(i_this->m15C0, fVar1, color, 0, &actor->tevStr);
#endif
dComIfGd_set3DlineMat(&i_this->mLineMat);
if (i_this->m0298 != 0xf) {
J3DModel* model = i_this->mpModel;
g_env_light.setLightTevColorType(model, &actor->tevStr);
mDoExt_modelUpdateDL(model);
if (i_this->m0298 == 0) {
if (l_HIO.m06 == 2) {
dComIfGd_setSpotModel(dDlst_alphaModel_c::TYPE_TWO_SPHERES, i_this->m1840, 0x20);
} else {
GXColor color;
color.r = l_HIO.m10;
color.g = l_HIO.m12;
color.b = l_HIO.m14;
color.a = 0;
dComIfGd_setAlphaModelColor(color);
if (l_HIO.m06 == 0) {
dComIfGd_setAlphaModel(dDlst_alphaModel_c::TYPE_SPHERE, i_this->m1840, i_this->m1878);
} else {
dComIfGd_setAlphaModel(dDlst_alphaModel_c::TYPE_TWO_SPHERES, i_this->m1840, i_this->m1878);
}
}
dComIfGd_setSimpleShadow2(&i_this->m1624, i_this->mAcch.GetGroundH(), i_this->m20F8, i_this->mAcch.m_gnd);
ga_draw(i_this);
}
}
return TRUE;
}
/* 00000EF8-00001108 .text ga_move__FP11himo3_class */
void ga_move(himo3_class* i_this) {
cXyz sp30(0.0f, 0.0f, 10.0f);
cXyz sp24;
if (i_this->m2114[0].m2E) {
if (i_this->m2114[0].m2F != 0) {
i_this->m2114[0].m2F--;
} else {
i_this->m2114[0].m2F = cM_rndF(10.0f);
i_this->m2114[0].m10.x = i_this->m1624.x + cM_rndFX(150.0f);
i_this->m2114[0].m10.y = i_this->m1624.y + cM_rndFX(100.0f);
i_this->m2114[0].m10.z = i_this->m1624.z + cM_rndFX(150.0f);
}
cXyz sp0C = i_this->m2114[0].m10 - i_this->m2114[0].mPos;
cLib_addCalcAngleS2(&i_this->m2114[0].m1E, cM_atan2s(sp0C.x, sp0C.z), 2, 0x1000);
cLib_addCalcAngleS2(&i_this->m2114[0].m1C, -cM_atan2s(sp0C.y, std::sqrtf(SQUARE(sp0C.x) + SQUARE(sp0C.z))), 2, 0x1000);
cMtx_YrotS(*calc_mtx, i_this->m2114[0].m1E);
cMtx_XrotM(*calc_mtx, i_this->m2114[0].m1C);
MtxPosition(&sp30, &sp24);
i_this->m2114[0].mPos += sp24;
i_this->m2114[0].m28 = cM_ssin(i_this->m2114[0].m2C);
i_this->m2114[0].m2C += 0x3E00;
}
}
/* 00001108-00001128 .text setActorHang__11himo3_classF4cXyzs */
void himo3_class::setActorHang(cXyz arg1, short arg2) {
m21F4 = arg1;
m2200 = arg2;
}
/* 00001128-000014F8 .text path_move__FP11himo3_class */
void path_move(himo3_class* i_this) {
fopAc_ac_c* actor = &i_this->actor;
cXyz sp28;
cXyz sp10;
dPnt* pnt;
switch (i_this->m02A4) {
case 0:
i_this->m029C += i_this->m029D;
if (i_this->m029C >= (s8)i_this->ppd->m_num) {
if (dPath_ChkClose(i_this->ppd)) {
i_this->m029C = 0;
} else {
i_this->m029D = -1;
i_this->m029C = i_this->ppd->m_num - 2;
}
if ((int)i_this->ppd->m_nextID != 0xFFFF) {
i_this->ppd = dPath_GetRoomPath(i_this->ppd->m_nextID, fopAcM_GetRoomNo(actor));
JUT_ASSERT(DEMO_SELECT(890, 891), i_this->ppd != NULL);
}
} else if (i_this->m029C < 0) {
i_this->m029D = 1;
i_this->m029C = 1;
}
i_this->m02A4 = 1;
pnt = &i_this->ppd->m_points[i_this->m029C];
i_this->m02A8 = pnt->m_position;
case 1:
sp10 = i_this->m02A8 - actor->current.pos;
if (i_this->m02BE == 0) {
u8 uStack_14 = i_this->ppd->m_points[i_this->m029C].mArg3;
if (uStack_14 != 0 && uStack_14 != 0xff) {
cLib_addCalc2(&actor->speedF, uStack_14, 1.0f, uStack_14 * 0.1f);
} else {
uStack_14 = i_this->m0299;
cLib_addCalc2(&actor->speedF, uStack_14, 1.0f, uStack_14 * 0.1f);
}
} else {
cLib_addCalc0(&actor->speedF, 1.0f, 1.0f);
}
sp28.x = 0.0f;
sp28.y = 0.0f;
sp28.z = actor->speedF;
cMtx_YrotS(*calc_mtx, cM_atan2s(sp10.x, sp10.z));
f32 fVar8 = std::sqrtf(SQUARE(sp10.x) + SQUARE(sp10.z));
cMtx_XrotM(*calc_mtx, -cM_atan2s(sp10.y, fVar8));
MtxPosition(&sp28, &actor->speed);
actor->current.pos += actor->speed;
if (sp10.abs() < actor->speedF * 2.0f) {
i_this->m02A4 = 0;
}
break;
}
}
/* 000014F8-00001A3C .text daHimo3_Execute__FP11himo3_class */
static BOOL daHimo3_Execute(himo3_class* i_this) {
fopAc_ac_c* actor = &i_this->actor;
fopAc_ac_c* player = dComIfGp_getPlayer(0);
if (i_this->m02BC != 0) {
i_this->m02BC--;
}
if (i_this->m029B != 0) {
path_move(i_this);
}
i_this->m02BA++;
i_this->m02C0[0].m00 = actor->current.pos;
himo3_control(i_this, i_this->m02C0);
if (i_this->m0298 != 0xf) {
if (i_this->mSph.ChkTgHit()) {
cCcD_Obj* pcVar5 = i_this->mSph.GetTgHitObj();
if (pcVar5 != NULL && pcVar5->ChkAtType(AT_TYPE_WIND)) {
i_this->m15F8 = player->shape_angle.y;
i_this->m15F4 = DEMO_SELECT(REG0_F(0) + 1.0f, 1.0f);
}
}
i_this->mAcch.CrrPos(*dComIfG_Bgsp());
i_this->m1870 = l_HIO.m18;
cMtx_copy(i_this->mpModel->getBaseTRMtx(), *calc_mtx);
if (i_this->m0298 == 0) {
MtxTrans(DEMO_SELECT(REG0_F(6) + 10.0f, 10.0f), DEMO_SELECT(REG0_F(7) + -140.0f, -140.0f), DEMO_SELECT(REG0_F(8) + -15.0f, -15.0f), 1);
} else {
MtxTrans(DEMO_SELECT(REG0_F(6), 0.0f), DEMO_SELECT(REG0_F(7), 0.0f), DEMO_SELECT(REG0_F(8) + 35.0f, 35.0f), 1);
}
MtxScale(i_this->m1870, i_this->m1870, i_this->m1870, true);
MTXCopy(*calc_mtx, i_this->m1840);
cXyz sp28;
sp28.z = 0.0f;
sp28.y = 0.0f;
sp28.x = 0.0f;
MtxPosition(&sp28, &i_this->m1624);
i_this->mSph.SetC(i_this->m1624);
dComIfG_Ccsp()->Set(&i_this->mSph);
if (i_this->m0298 == 0) {
for (int i = 0; i < ARRAY_SSIZE(i_this->m02B4); i++) {
if (i_this->m02B4[i]) {
i_this->m02B4[i]--;
}
}
if (i_this->m02B4[0] == 0) {
i_this->m02B4[0] = cM_rndF(DEMO_SELECT(REG0_F(2) + 10.0f, 10.0f)) + 5.0f + DEMO_SELECT(REG0_F(3), 0.0f);
i_this->m187C = cM_rndF(DEMO_SELECT(REG0_F(6) + 16.0f, 16.0f)) + 4.0f + DEMO_SELECT(REG0_F(7), 0.0f);
}
if (i_this->m02B4[1] == 0) {
i_this->m02B4[1] = cM_rndF(6.0f) + 3.0f;
}
cLib_addCalc2(&i_this->m1878, i_this->m187C, 1.0f, DEMO_SELECT(REG0_F(4) + 0.1f, 0.1f));
#if VERSION == VERSION_DEMO
if (!i_this->m2110) {
#else
if (i_this->m20FC.getEmitter() == NULL) {
#endif
static cXyz fire_scale(0.7f, 0.7f, 0.7f);
#if VERSION == VERSION_DEMO
i_this->demo_m20FC =
#endif
dComIfGp_particle_set(dPa_name::ID_AK_JN_TORCH, &i_this->m1624, NULL, &fire_scale, 0xff, &i_this->m20FC);
#if VERSION == VERSION_DEMO
i_this->m2110 = 1;
#endif
i_this->m1620 = 1.0f;
}
#if VERSION == VERSION_DEMO
JPABaseEmitter* pJVar6 = i_this->demo_m20FC;
#else
JPABaseEmitter* pJVar6 = i_this->m20FC.getEmitter();
#endif
if (pJVar6 != NULL) {
Vec vec1;
f32 f3;
f3 = DEMO_SELECT(REG0_F(3) + -0.03f, -0.03f);
vec1.x = f3 * (i_this->m1624.x - i_this->m1630.x);
if (vec1.x > 1.0f) {
vec1.x = 1.0f;
} else if (vec1.x < -1.0f) {
vec1.x = -1.0f;
}
vec1.z = f3 * (i_this->m1624.z - i_this->m1630.z);
if (vec1.z > 1.0f) {
vec1.z = 1.0f;
} else if (vec1.z < -1.0f) {
vec1.z = -1.0f;
}
JGeometry::TVec3<f32> dir;
dir.x = vec1.x;
dir.y = 0.1f;
dir.z = vec1.z;
pJVar6->setDirection(dir);
Vec vec2;
vec2.x = 1.0f;
vec2.y = 1.0f + std::sqrtf(SQUARE(vec1.x) + SQUARE(vec1.z)) * DEMO_SELECT(REG0_F(12) + 2.0f, 2.0f);
f32 f0 = DEMO_SELECT(REG0_F(13) + 4.0f, 4.0f);
if (vec2.y > f0) {
vec2.y = f0;
}
JGeometry::TVec3<f32> scale;
scale.x = vec2.x;
scale.y = vec2.y;
scale.z = vec2.x;
#if VERSION == VERSION_DEMO
pJVar6 = i_this->demo_m20FC;
#endif
pJVar6->setGlobalParticleScale(scale);
cLib_addCalc2(&i_this->m1620, cM_rndF(0.2f) + 1.0f, 0.5f, 0.02f);
} else {
i_this->m1620 = 0.0f;
}
cXyz sp1C(i_this->m1624.x, DEMO_SELECT(i_this->m1624.y + REG0_F(7), i_this->m1624.y) + 20.0f, i_this->m1624.z);
dComIfGp_particle_setSimple(dPa_name::ID_AK_JP_O_KAGEROU00, &sp1C);
i_this->m1600.mPos = i_this->m1624;
i_this->m1600.mColor.r = 600;
i_this->m1600.mColor.g = 400;
i_this->m1600.mColor.b = 0x78;
i_this->m1600.mPower = (s16)(i_this->m1620 * 150.0f);
i_this->m1600.mFluctuation = 250.0f;
ga_move(i_this);
}
}
i_this->m1630 = i_this->m1624;
return TRUE;
}
/* 00001A3C-00001A44 .text daHimo3_IsDelete__FP11himo3_class */
static BOOL daHimo3_IsDelete(himo3_class* i_this) {
#if VERSION == VERSION_DEMO
if (i_this->demo_m20FC != 0) {
i_this->m20FC.remove();
}
#endif
return TRUE;
}
/* 00001A44-00001AE0 .text daHimo3_Delete__FP11himo3_class */
static BOOL daHimo3_Delete(himo3_class* i_this) {
dComIfG_resDeleteDemo(&i_this->mPhase, "Himo3");
if (i_this->m0298 == 0) {
dKy_plight_cut(&i_this->m1600);
}
if (DEMO_SELECT(i_this->m2111, i_this->m2110) != 0) {
hio_set = false;
mDoHIO_deleteChild(l_HIO.mNo);
}
#if VERSION > VERSION_DEMO
i_this->m20FC.remove();
#endif
return TRUE;
}
/* 00001AE0-00001DD4 .text useHeapInit__FP11himo3_class */
cPhs_State useHeapInit(himo3_class* i_this) {
fopAc_ac_c* actor = &i_this->actor;
static int hook_bmd[] = {HIMO3_BMD_SLAMP_00, LINK_BDL_ROPEEND, HIMO3_BMD_SLAMP_00, HIMO3_BMD_SLAMP_00, HIMO3_BMD_SLAMP_00};
#if VERSION == VERSION_DEMO
if (!i_this->mLineMat.init(1, 200, (ResTIMG*)dComIfG_getObjectRes("Always", i_this->m0298 == 0xf ? ALWAYS_BTI_TXM_ROPE1 : ALWAYS_BTI_ROPE), 0)) {
return cPhs_ERROR_e;
}
#else
if (i_this->m0298 == 0xf) {
if (!i_this->mLineMat.init(1, 200, (ResTIMG*)dComIfG_getObjectRes("Bgn", BGN_BTI_NOT_CUT1), 0)) {
return cPhs_ERROR_e;
}
} else if (!i_this->mLineMat.init(1, 200, (ResTIMG*)dComIfG_getObjectRes("Always", ALWAYS_BTI_ROPE), 0)) {
return cPhs_ERROR_e;
}
#endif
J3DModelData* modelData = NULL;
if (i_this->m0298 != 0xf) {
if (i_this->m0298 == 1) {
modelData = (J3DModelData*)dComIfG_getObjectRes("Link", hook_bmd[i_this->m0298]);
} else if (i_this->m0298 <= 4) {
modelData = (J3DModelData*)dComIfG_getObjectRes("Himo3", hook_bmd[i_this->m0298]);
}
JUT_ASSERT(DEMO_SELECT(1250, 1284), modelData != NULL);
i_this->mpModel = mDoExt_J3DModel__create(modelData, 0, 0x11020203);
if (i_this->mpModel == NULL) {
return cPhs_ERROR_e;
}
}
if (i_this->m0298 == 0) {
modelData = (J3DModelData*)dComIfG_getObjectRes("Himo3", HIMO3_BMD_H3_GA);
JUT_ASSERT(DEMO_SELECT(1264, 1298), modelData != NULL);
s32 tmp = 0;
for (int i = 0; i < ARRAY_SSIZE(i_this->m2114); i++) {
i_this->m2114[i].mpModel = mDoExt_J3DModel__create(modelData, 0, 0x11020203);
if (i_this->m2114[i].mpModel == NULL) {
return cPhs_INIT_e;
}
if (tmp == 0 || cM_rndF(1.0f) < 0.5f) {
i_this->m2114[i].m2E = true;
i_this->m2114[i].mPos = actor->current.pos;
i_this->m2114[i].m24 = cM_rndF(0.3f) + 0.3f;
i_this->m2114[i].m2C = cM_rndF(30000.0f);
}
}
}
return cPhs_COMPLEATE_e;
}
/* 00001DD4-00002128 .text daHimo3_Create__FP10fopAc_ac_c */
static cPhs_State daHimo3_Create(fopAc_ac_c* a_this) {
static dCcD_SrcCyl cc_cyl_src = {
// dCcD_SrcGObjInf
{
/* Flags */ 0,
/* SrcObjAt Type */ 0,
/* SrcObjAt Atp */ 0,
/* SrcObjAt SPrm */ 0,
/* SrcObjTg Type */ AT_TYPE_ALL & ~AT_TYPE_BOOMERANG & ~AT_TYPE_WATER & ~AT_TYPE_UNK20000 & ~AT_TYPE_UNK400000 & ~AT_TYPE_LIGHT,
/* SrcObjTg SPrm */ cCcD_TgSPrm_Set_e | cCcD_TgSPrm_IsEnemy_e,
/* SrcObjCo SPrm */ cCcD_CoSPrm_Set_e | cCcD_CoSPrm_IsPlayer_e | cCcD_CoSPrm_VsGrpAll_e,
/* SrcGObjAt Se */ 0,
/* SrcGObjAt HitMark */ dCcG_AtHitMark_None_e,
/* SrcGObjAt Spl */ dCcG_At_Spl_UNK0,
/* SrcGObjAt Mtrl */ 0,
/* SrcGObjAt SPrm */ 0,
/* SrcGObjTg Se */ 0,
/* SrcGObjTg HitMark */ 0,
/* SrcGObjTg Spl */ dCcG_Tg_Spl_UNK0,
/* SrcGObjTg Mtrl */ 0,
/* SrcGObjTg SPrm */ dCcG_TgSPrm_NoConHit_e,
/* SrcGObjCo SPrm */ 0,
},
// cM3dGCylS
{{
/* Center */ {0.0f, 0.0f, 0.0f},
/* Radius */ 50.0f,
/* Height */ 4000.0f,
}},
};
static dCcD_SrcSph sph_src = {
// dCcD_SrcGObjInf
{
/* Flags */ 0,
/* SrcObjAt Type */ 0,
/* SrcObjAt Atp */ 1,
/* SrcObjAt SPrm */ 0,
/* SrcObjTg Type */ AT_TYPE_ALL & ~AT_TYPE_BOOMERANG & ~AT_TYPE_WATER & ~AT_TYPE_UNK20000 & ~AT_TYPE_WIND & ~AT_TYPE_UNK400000 & ~AT_TYPE_LIGHT,
/* SrcObjTg SPrm */ cCcD_TgSPrm_Set_e | cCcD_TgSPrm_IsEnemy_e,
/* SrcObjCo SPrm */ cCcD_CoSPrm_Set_e | cCcD_CoSPrm_IsPlayer_e | cCcD_CoSPrm_VsGrpAll_e,
/* SrcGObjAt Se */ 0,
/* SrcGObjAt HitMark */ dCcG_AtHitMark_None_e,
/* SrcGObjAt Spl */ dCcG_At_Spl_UNK0,
/* SrcGObjAt Mtrl */ 0,
/* SrcGObjAt SPrm */ 0,
/* SrcGObjTg Se */ 0,
/* SrcGObjTg HitMark */ 0,
/* SrcGObjTg Spl */ dCcG_Tg_Spl_UNK0,
/* SrcGObjTg Mtrl */ 0,
/* SrcGObjTg SPrm */ 0,
/* SrcGObjCo SPrm */ 0,
},
// cM3dGSphS
{{
/* Center */ {0.0f, 0.0f, 0.0f},
/* Radius */ 50.0f,
}},
};
static dCcD_SrcSph sph2_src = {
// dCcD_SrcGObjInf
{
/* Flags */ 0,
/* SrcObjAt Type */ 0,
/* SrcObjAt Atp */ 1,
/* SrcObjAt SPrm */ 0,
/* SrcObjTg Type */ AT_TYPE_ALL & ~AT_TYPE_BOOMERANG & ~AT_TYPE_WATER & ~AT_TYPE_UNK20000 & ~AT_TYPE_UNK400000 & ~AT_TYPE_LIGHT,
/* SrcObjTg SPrm */ cCcD_TgSPrm_Set_e | cCcD_TgSPrm_IsEnemy_e,
/* SrcObjCo SPrm */ cCcD_CoSPrm_Set_e | cCcD_CoSPrm_IsPlayer_e | cCcD_CoSPrm_VsGrpAll_e,
/* SrcGObjAt Se */ 0,
/* SrcGObjAt HitMark */ dCcG_AtHitMark_None_e,
/* SrcGObjAt Spl */ dCcG_At_Spl_UNK0,
/* SrcGObjAt Mtrl */ 0,
/* SrcGObjAt SPrm */ 0,
/* SrcGObjTg Se */ 0,
/* SrcGObjTg HitMark */ dCcg_TgHitMark_Purple_e,
/* SrcGObjTg Spl */ dCcG_Tg_Spl_UNK0,
/* SrcGObjTg Mtrl */ 0,
/* SrcGObjTg SPrm */ dCcG_TgSPrm_Shield_e,
/* SrcGObjCo SPrm */ 0,
},
// cM3dGSphS
{{
/* Center */ {0.0f, 0.0f, 0.0f},
/* Radius */ 80.0f,
}},
};
himo3_class* i_this = (himo3_class*)a_this;
fopAcM_ct(a_this, himo3_class);
cPhs_State PVar1 = dComIfG_resLoad(&i_this->mPhase, "Himo3");
if (PVar1 == cPhs_COMPLEATE_e) {
i_this->m0298 = (fopAcM_GetParam(a_this) >> 0) & 0xFF;
i_this->m0299 = (fopAcM_GetParam(a_this) >> 16) & 0xFF;
i_this->m029A = (fopAcM_GetParam(a_this) >> 24) & 0xFF;
if (i_this->m0298 == 0xff) {
i_this->m0298 = 0;
}
if (fopAcM_createHeap(a_this, 0xa220, 0) == 0) {
return cPhs_ERROR_e;
}
PVar1 = useHeapInit(i_this);
fopAcM_adjustHeap(a_this);
if (PVar1 == cPhs_ERROR_e) {
return cPhs_ERROR_e;
}
i_this->m15C0 = (fopAcM_GetParam(a_this) >> 8) & 0xFF;
if (i_this->m0298 == 0xf) {
HIMO3_SCALE = DEMO_SELECT(REG0_F(4) + 22.0f, 22.0f);
i_this->m15C0 = DEMO_SELECT(REG0_S(0) + 200, 200);
i_this->m029A = 0xff;
} else {
HIMO3_SCALE = 20.0f;
}
i_this->m15FC = i_this->m15C0 * HIMO3_SCALE - 50.0f;
if (i_this->m0298 == 0) {
i_this->m15FC -= 50.0f;
}
if (i_this->m15C0 > 0xc8) {
return cPhs_ERROR_e;
}
if (i_this->m029A != 0xff) {
i_this->ppd = dPath_GetRoomPath(i_this->m029A, fopAcM_GetRoomNo(a_this));
if (i_this->ppd == NULL) {
return cPhs_ERROR_e;
}
i_this->m029B = i_this->m029A + 1;
i_this->m029D = 1;
}
i_this->m15E0 = 1.0f;
i_this->mStts.Init(0xff, 0xff, a_this);
if (i_this->m0298 == 0xf) {
i_this->mCyl.Set(cc_cyl_src);
i_this->mCyl.SetStts(&i_this->mStts);
} else {
for (int i = 0; i < ARRAY_SSIZE(i_this->mSphs); i++) {
i_this->mSphs[i].Set(sph_src);
i_this->mSphs[i].SetStts(&i_this->mStts);
}
i_this->mSph.Set(sph2_src);
i_this->mSph.SetStts(&i_this->mStts);
i_this->mAcch.Set(&i_this->m1624, &i_this->m1630, a_this, 1, &i_this->mAcchCir, fopAcM_GetSpeed_p(a_this));
if (i_this->m0298 == 0) {
i_this->mAcchCir.SetWall(40.0f, 50.0f);
i_this->m20F8 = 20.0f;
dKy_plight_set(&i_this->m1600);
} else if (i_this->m0298 == 1) {
i_this->mAcchCir.SetWall(20.0f, 20.0f);
i_this->mSph.SetR(20.0f);
i_this->m20F8 = 10.0f;
}
}
if (!hio_set) {
hio_set = true;
DEMO_SELECT(i_this->m2111, i_this->m2110) = 0;
l_HIO.mNo = mDoHIO_createChild("ぶら下がりロープ", &l_HIO);
}
for (int i = 0; i < 10; i++) {
daHimo3_Execute(i_this);
}
}
return PVar1;
}
static actor_method_class l_daHimo3_Method = {
(process_method_func)daHimo3_Create,
(process_method_func)daHimo3_Delete,
(process_method_func)daHimo3_Execute,
(process_method_func)daHimo3_IsDelete,
(process_method_func)daHimo3_Draw,
};
actor_process_profile_definition g_profile_HIMO3 = {
/* LayerID */ fpcLy_CURRENT_e,
/* ListID */ 0x0008,
/* ListPrio */ fpcPi_CURRENT_e,
/* ProcName */ PROC_HIMO3,
/* Proc SubMtd */ &g_fpcLf_Method.base,
/* Size */ sizeof(himo3_class),
/* SizeOther */ 0,
/* Parameters */ 0,
/* Leaf SubMtd */ &g_fopAc_Method.base,
/* Priority */ PRIO_HIMO3,
/* Actor SubMtd */ &l_daHimo3_Method,
/* Status */ fopAcStts_UNK4000_e | fopAcStts_UNK40000_e,
/* Group */ fopAc_ACTOR_e,
/* CullType */ fopAc_CULLBOX_0_e,
};