Files
dusklight/src/d/actor/d_a_npc_zra.cpp
T
2026-03-18 01:56:47 -04:00

2358 lines
72 KiB
C++

/**
* d_a_npc_zra.cpp
* NPC - Zora
*/
#include "d/dolzel_rel.h" // IWYU pragma: keep
#include "d/actor/d_a_npc_zra.h"
#include "SSystem/SComponent/c_math.h"
#include "JSystem/JKernel/JKRHeap.h"
#include "JSystem/J3DGraphBase/J3DMaterial.h"
#include "Z2AudioLib/Z2Instances.h"
#include "f_op/f_op_actor_mng.h"
#include "f_op/f_op_kankyo_mng.h"
#include "d/d_com_inf_game.h"
#include "d/d_meter2_info.h"
#include "f_pc/f_pc_name.h"
#include "d/actor/d_a_canoe.h"
#include "d/actor/d_a_npc_hoz.h"
#include "d/actor/d_a_obj_zraMark.h"
#include <cstring>
static NPC_ZRA_HIO_CLASS l_HIO;
daNpc_zrA_HIOParam const daNpc_zrA_Param_c::m = {
230.0f, // mAttnOffsetY
-3.0f, // mGravity
1.0f, // mScale
800.0f, // mShadowDepth
255.0f, // mCcWeight
230.0f, // mCylH
0.0f, // mWallH
40.0f, // mWallR
30.0f, // mBodyUpAngle
-20.0f, // mBodyDownAngle
30.0f, // mBodyLeftAngle
-30.0f, // mBodyRightAngle
15.0f, // mHeadUpAngle
0.0f, // mHeadDownAngle
0.0f, // mHeadLeftAngle
0.0f, // mHeadRightAngle
0.6f, // mNeckAngleScl
12.0f, // mMorfFrames
3, // mSpeakDistIdx
6, // mSpeakAngleIdx
5, // mTalkDistIdx
6, // mTalkAngleIdx
80.0f, // mAttnFovY
500.0f, // mAttnRadius
300.0f, // mAttnUpperY
-300.0f, // mAttnLowerY
60,
8, // mDamageTimer
0, // mTestExpression
0, // mTestMotion
0, // mTestLookMode
false, // mTest
false,
20.0f, // mSwimSpeed
0.5f, // mMinSwimSpeedScale
0x580, // mSwimAngleSpeed
15.0f, // mSwimAnmRate
0.0f,
0.0f,
1.5f, // mMaxScaleFactor
150.0f, // mMinDepth
100.0f,
20.0f,
4.0f, // mWalkSpeed
0x800, // mWalkAngleSpeed
2, // mWalkAngleScale
6.0f, // mWalkAnmRate
140.0f,
350.0f,
5000.0f,
3000.0f,
};
BOOL daNpc_zrA_Path_c::getDstPosDst2(cXyz i_pos, cXyz& o_pnt) {
BOOL ret = false;
o_pnt = getPntPos(getIdx());
if (chkPassedDst(i_pos)) {
ret = true;
if (!setNextIdx()) {
o_pnt = getPntPos(getIdx());
mPosDst = (i_pos - o_pnt).abs();
mPosition = i_pos;
}
}
return ret;
}
void daNpc_zrA_Path_c::setNextIdxDst(cXyz param_0) {
if (!setNextIdx()) {
mPosDst = (param_0 - getPntPos(getIdx())).abs();
mPosition = param_0;
}
}
BOOL daNpc_zrA_Path_c::chkPassedDstXZ(cXyz i_pos) {
return mPosDst + field_0x10 <= (mPosition - i_pos).absXZ();
}
BOOL daNpc_zrA_Path_c::getDstPosDstXZ(cXyz i_pos, cXyz& o_pnt) {
BOOL ret = false;
o_pnt = getPntPos(getIdx());
if (chkPassedDstXZ(i_pos)) {
if (setNextIdx()) {
ret = true;
} else {
o_pnt = getPntPos(getIdx());
mPosDst = (i_pos - o_pnt).absXZ();
mPosition = i_pos;
}
}
return ret;
}
BOOL daNpc_zrA_Path_c::chkPassedChase(u16 i_idx, cXyz i_pos) {
return daNpcF_chkPassed(i_pos, (dPnt*)mPathInfo->m_points, i_idx,
mPathInfo->m_num, mIsClosed, mIsReversed);
}
int daNpc_zrA_Path_c::getDstPosChase(u16 i_idx, cXyz i_pos, cXyz& o_pnt) {
BOOL done = false;
while (!done) {
o_pnt = getPntPos(i_idx);
if (!chkPassedChase(i_idx, i_pos)) {
break;
}
if (mIsReversed) {
if (i_idx == 0) {
done = true;
} else {
i_idx--;
}
} else {
if (i_idx == getEndIdx()) {
done = true;
} else {
i_idx++;
}
}
}
return i_idx;
}
f32 daNpc_zrA_Path_c::chkPassDst(u16 i_idx, cXyz i_pos) {
u16 prev_idx, next_idx;
dPnt* points = mPathInfo->m_points;
u16 idx = mIdx;
u8 reversed = mIsReversed;
mIdx = i_idx;
mIsReversed = false;
next_idx = getNextIdx();
mIdx = i_idx;
prev_idx = getBeforeIdx();
mIdx = idx;
mIsReversed = reversed;
cXyz prev_pos, cur_pos, next_pos, pos;
prev_pos.set(points[prev_idx].m_position.x,
points[prev_idx].m_position.y,
points[prev_idx].m_position.z);
cur_pos.set(points[i_idx].m_position.x,
points[i_idx].m_position.y,
points[i_idx].m_position.z);
next_pos.set(points[next_idx].m_position.x,
points[next_idx].m_position.y,
points[next_idx].m_position.z);
f32 dist;
s16 angle;
if (prev_idx != i_idx || next_idx != i_idx) {
if (prev_idx < i_idx && i_idx < next_idx) {
dist = (next_pos - prev_pos).absXZ();
angle = cM_atan2s(next_pos.x - prev_pos.x, next_pos.z - prev_pos.z);
pos = prev_pos;
prev_pos.x = pos.x + dist * -1.0f * cM_ssin(angle);
prev_pos.z = pos.z + dist * -1.0f * cM_scos(angle);
next_pos.x = pos.x + dist * 2.0f * cM_ssin(angle);
next_pos.z = pos.z + dist * 2.0f * cM_scos(angle);
} else if (prev_idx < i_idx) {
dist = (cur_pos - prev_pos).absXZ();
angle = cM_atan2s(cur_pos.x - prev_pos.x, cur_pos.z - prev_pos.z);
pos = cur_pos;
prev_pos.x = pos.x + dist * -2.0f * cM_ssin(angle);
prev_pos.z = pos.z + dist * -2.0f * cM_scos(angle);
next_pos.x = pos.x + dist * 2.0f * cM_ssin(angle);
next_pos.z = pos.z + dist * 2.0f * cM_scos(angle);
} else if (i_idx < next_idx) {
dist = (next_pos - cur_pos).absXZ();
angle = cM_atan2s(next_pos.x - cur_pos.x, next_pos.z - cur_pos.z);
pos = cur_pos;
prev_pos.x = pos.x + dist * -2.0f * cM_ssin(angle);
prev_pos.z = pos.z + dist * -2.0f * cM_scos(angle);
next_pos.x = pos.x + dist * 2.0f * cM_ssin(angle);
next_pos.z = pos.z + dist * 2.0f * cM_scos(angle);
}
f32 proj_x, proj_z, proj2_x, proj2_z;
daNpcF_pntVsLineSegmentLengthSquare2D(i_pos.x, i_pos.z, prev_pos.x, prev_pos.z,
next_pos.x, next_pos.z, &proj_x, &proj_z, &dist);
if (cM3d_IsZero(dist)) {
return -G_CM3D_F_INF;
} else {
daNpcF_pntVsLineSegmentLengthSquare2D(cur_pos.x, cur_pos.z, prev_pos.x, prev_pos.z,
next_pos.x, next_pos.z, &proj2_x, &proj2_z, &dist);
s16 angle2;
if (mIsReversed) {
angle2 = cM_atan2s(prev_pos.x - next_pos.x, prev_pos.z - next_pos.z);
} else {
angle2 = cM_atan2s(next_pos.x - prev_pos.x, next_pos.z - prev_pos.z);
}
s16 angle_diff = angle2 - cM_atan2s(proj2_x - proj_x, proj2_z - proj_z);
dist = JMAFastSqrt((proj2_x - proj_x) * (proj2_x - proj_x)
+ (proj2_z - proj_z) * (proj2_z - proj_z));
if ((u16)abs(angle_diff) > 0x4000) {
return dist;
} else {
return -dist;
}
}
} else {
return -G_CM3D_F_INF;
}
}
static daNpc_GetParam1 l_bmdGetParamList[6] = {
{3, 4}, // zra
{13, 5}, // zra_tw
{3, 7}, // zra_met
{4, 7}, // zra_sp
{3, 10}, // zra_met_tw
{4, 10}, // zra_sp_tw
};
static daNpc_GetParam1 l_bckGetParamList[63] = {
{-1, 0},
{8, 0}, // zra_f_talk_a
{9, 0}, // zra_f_talk_a_sp
{11, 0}, // zra_f_wait_swim
{10, 0}, // zra_f_talk_nomal
{13, 0}, // zra_fh_talk_nomal
{5, 5}, // zra_fh_sadsit_a
{4, 6}, // zra_fh_sadsit_b
{5, 6}, // zra_fh_sadsit_c
{6, 5}, // zra_fh_sadsit_d
{7, 5}, // zra_fh_sadsit_e
{5, 3}, // zra_f_looking_sp
{8, 3}, // zra_fh_looking_sp
{4, 9}, // zra_f_lookup
{7, 9}, // zra_fh_lookup
{7, 3}, // zra_f_talk_swim_sp
{6, 3}, // zra_f_talk_b_sp
{5, 9}, // zra_f_spa_talk_a
{8, 9}, // zra_fh_spa_wait_a
{6, 9}, // zra_f_spa_talk_b
{9, 9}, // zra_fh_spa_wait_b
{17, 0}, // zra_swim_turn
{14, 0}, // zra_still
{12, 0}, // zra_fallswim
{16, 0}, // zra_swim_talk
{8, 5}, // zra_sadsit_a
{6, 6}, // zra_sadsit_b
{7, 6}, // zra_sadsit_c
{9, 5}, // zra_sadsit_d
{10, 5}, // zra_sadsit_e
{4, 8}, // zra_tobikomi_s
{5, 8}, // zra_tobikomi_t
{3, 8}, // zra_tobikomi_e
{11, 3}, // zra_looking_sp
{17, 3}, // zra_talk_swim_sp
{16, 3}, // zra_talk_b_sp
{10, 9}, // zra_lookup
{14, 9}, // zra_spa_wait_b
{12, 9}, // zra_spa_talk_b
{13, 9}, // zra_spa_wait_a
{11, 9}, // zra_spa_talk_a
{5, 2}, // zra_wait_a
{10, 1}, // zra_walk_a
{4, 2}, // zra_talk_a
{7, 1}, // zra_swim_a
{8, 1}, // zra_swim_b
{9, 1}, // zra_wait_swim
{3, 1}, // zra_dive
{4, 1}, // zra_dive_b
{5, 1}, // zra_float
{6, 1}, // zra_float_b
{3, 2}, // zra_step
{18, 3}, // zra_wait_sp
{20, 3}, // zra_walk_a_sp
{15, 3}, // zra_talk_a_sp
{13, 3}, // zra_swim_a_sp
{14, 3}, // zra_swim_b_sp
{19, 3}, // zra_wait_swim_sp
{4, 3}, // zra_dive_sp
{3, 3}, // zra_dive_b_sp
{10, 3}, // zra_float_sp
{9, 3}, // zra_float_b_sp
{12, 3}, // zra_step_sp
};
static daNpc_GetParam1 l_btpGetParamList[8] = {
{34, 0}, // zra
{16, 5}, // zra_fh_sadsit_a
{10, 6}, // zra_fh_sadsit_b
{11, 6}, // zra_fh_sadsit_c
{17, 5}, // zra_fh_sadsit_d
{18, 5}, // zra_fh_sadsit_e
{17, 9}, // zra_f_spa_talk_b
{18, 9}, // zra_fh_spa_wait_b
};
static daNpc_GetParam1 l_btkGetParamList[4] = {
{28, 0}, // zra
{31, 0}, // zra_water02
{29, 0}, // zra_reset
{30, 0}, // zra_w_eyeball
};
static daNpc_GetParam1 l_brkGetParamList[2] = {
{24, 0}, // zra
{25, 0}, // zra_water02
};
static daNpc_GetParam1 l_bpkGetParamList[2] = {
{20, 0}, // zra
{21, 0}, // zra_water02
};
static daNpc_GetParam1 l_evtGetParamList[13] = {
{0, 0},
{1, 0},
{2, 0},
{3, 0},
{4, 0},
{5, 0},
{6, 0},
{7, 0},
{8, 0},
{9, 0},
{10, 0},
{11, 0},
{12, 0},
};
static char* l_evtNames[13] = {
NULL,
"TALK_SWIM",
"BEFORE_BLAST_ZRR",
"AFTER_BLAST_ZRR",
"THANKS_BLAST",
"RESULT_ANNOUNCE",
"CARRY_WATERFALL",
"CARRY_WATERFALL_NIGHT",
"CARRY_WATERFALL_SKIP",
"CARRY_WATERFALL_NIGHT_SKIP",
"SEARCH_PRINCE",
"TALK_MULTI",
"TALK_MULTI2",
};
static int l_loadObj_list[3][3] = {
{2, 3, -1},
{2, -1, -1},
{-1, -1, -1},
};
static int l_loadObj_listTW[3][3] = {
{4, 5, -1},
{4, -1, -1},
{-1, -1, -1},
};
static int l_loadRes_ZRAa[8] = {0, 1, 2, 4, 6, -1, -1, -1};
static int l_loadRes_Swim[8] = {0, 1, 2, 4, -1, -1, -1, -1};
static int l_loadRes_Tobi[8] = {0, 1, 2, 4, 8, -1, -1, -1};
static int l_loadRes_Spa[8] = {0, 2, 4, 9, -1, -1, -1, -1};
static int l_loadRes_ZRA0[8] = {0, 1, 2, 4, -1, -1, -1, -1};
static int* l_loadRes_list[8] = {
l_loadRes_ZRAa, l_loadRes_Swim, l_loadRes_Swim, l_loadRes_Swim,
l_loadRes_Tobi, l_loadRes_Tobi, l_loadRes_Spa, l_loadRes_ZRA0,
};
static char* l_resNames[11] = {
"zrA",
"zrA_nml",
"zrA_nml2",
"zrA_sp",
"zrA_MDL",
"zrA_TW",
"zrA_sad",
"zrA_obj",
"zrA_tobi",
"zrA2",
"zrA_objTW",
};
static char* l_myName[4] = {
"zrA",
"zrA_talk",
"zrR",
"zrWF",
};
char* daNpc_zrA_c::mEvtCutNameList[11] = {
"",
"TALK_SWIM",
"BEFORE_BLAST_ZRR",
"AFTER_BLAST_ZRR",
"THANKS_BLAST",
"RESULT_ANNOUNCE",
"CARRY_WATERFALL",
"CARRY_WATERFALL_SKIP",
"SEARCH_PRINCE1",
"SEARCH_PRINCE2",
"TALK_MULTI",
};
daNpc_zrA_c::EventFn daNpc_zrA_c::mEvtCutList[11] = {
NULL,
&daNpc_zrA_c::ECut_talkSwim,
&daNpc_zrA_c::ECut_beforeBlastzrR,
&daNpc_zrA_c::ECut_afterBlastzrR,
&daNpc_zrA_c::ECut_thanksBlast,
&daNpc_zrA_c::ECut_resultAnnounce,
&daNpc_zrA_c::ECut_carryWaterfall,
&daNpc_zrA_c::ECut_carryWaterfallSkip,
&daNpc_zrA_c::ECut_searchPrince1,
&daNpc_zrA_c::ECut_searchPrince2,
&daNpc_zrA_c::ECut_talkMulti,
};
#if DEBUG
daNpc_zrA_HIO_c::daNpc_zrA_HIO_c() {
m = daNpc_zrA_Param_c::m;
}
void daNpc_zrA_HIO_c::listenPropertyEvent(const JORPropertyEvent* event) {
// NONMATCHING
}
void daNpc_zrA_HIO_c::genMessage(JORMContext* ctx) {
// NONMATCHING
}
#endif
daNpc_zrA_c::daNpc_zrA_c() {}
daNpc_zrA_c::~daNpc_zrA_c() {
int i;
for (i = 0; l_loadRes_list[mType][i] >= 0; i++) {
int res_no = l_loadRes_list[mType][i];
if (res_no == 4) {
if (mTwilight) {
res_no = 5;
}
} else if (res_no == 1) {
if (mSoldierType == SOLDIER_SPEAR) {
res_no = 3;
}
}
dComIfG_resDelete(&mPhase[i], l_resNames[res_no]);
}
if (mSoldierType != SOLDIER_NONE) {
if (mTwilight) {
dComIfG_resDelete(&mPhase[i], l_resNames[10]);
} else {
dComIfG_resDelete(&mPhase[i], l_resNames[7]);
}
}
if (heap != NULL) {
mAnm_p->stopZelAnime();
}
#if DEBUG
if (mpHIO != NULL) {
mpHIO->removeHIO();
}
#endif
}
cPhs_Step daNpc_zrA_c::create() {
fopAcM_ct(this, daNpc_zrA_c);
mType = getTypeFromArgument();
// !@bug home.angle.x is promoted to a 32-bit signed integer prior
// to being compared, so the compared value can never exceed
// SHORT_MAX and the condition always passes.
if (home.angle.x != 0xffff) {
mFlowID = home.angle.x;
} else {
mFlowID = -1;
}
mSoldierType = getSoldierTypeFromParam();
mGameMode = getGameModeFromParam();
mSwitch1 = (u8)home.angle.z;
mSwitch2 = (u8)((u16)home.angle.z >> 8);
mTwilight = dKy_darkworld_check();
if (isDelete()) {
return cPhs_ERROR_e;
}
int res_count = 0;
cPhs_Step step;
int i;
for (i = 0; l_loadRes_list[mType][i] >= 0; i++) {
int res_no = l_loadRes_list[mType][i];
if (res_no == 4) {
if (mTwilight) {
res_no = 5;
}
} else if (res_no == 1) {
if (mSoldierType == SOLDIER_SPEAR) {
res_no = 3;
}
}
step = dComIfG_resLoad(&mPhase[i], l_resNames[res_no]);
if (step == cPhs_ERROR_e || step == cPhs_UNK3_e) {
return cPhs_ERROR_e;
}
if (step == cPhs_COMPLEATE_e) {
res_count++;
}
}
if (mSoldierType != SOLDIER_NONE) {
if (mTwilight) {
step = dComIfG_resLoad(&mPhase[i], l_resNames[10]);
} else {
step = dComIfG_resLoad(&mPhase[i], l_resNames[7]);
}
if (step == cPhs_ERROR_e || step == cPhs_UNK3_e) {
return cPhs_ERROR_e;
}
if (step == cPhs_COMPLEATE_e) {
res_count++;
}
i++;
}
if (res_count == i) {
if (!fopAcM_entrySolidHeap(this, createHeapCallBack, 0x80007280)) {
return cPhs_ERROR_e;
}
fopAcM_SetMtx(this, mAnm_p->getModel()->getBaseTRMtx());
fopAcM_setCullSizeBox(this, -300.0f, -50.0f, -300.0f, 300.0f, 450.0f, 300.0f);
mCreatureSound.init(&current.pos, &eyePos, 3, 1);
#if DEBUG
mpHIO = &l_HIO;
mpHIO->entryHIO("ゾ-ラ");
#endif
mAcchCir.SetWall(mpHIO->m.common.width, mpHIO->m.common.knee_length);
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));
mPaPo.init(&mAcch, mpHIO->m.common.height, mpHIO->m.common.height);
mCcStts.Init(mpHIO->m.common.weight, 0, this);
mCcCyl.Set(mCcDCyl);
mCcCyl.SetStts(&mCcStts);
mCcCyl.SetTgHitCallback(tgHitCallBack);
mAcch.SetWtrChkMode(2);
mAcch.CrrPos(dComIfG_Bgsp());
mGndChk = mAcch.m_gnd;
mGroundH = mAcch.GetGroundH();
setEnvTevColor();
setRoomNo();
reset();
Execute();
return cPhs_COMPLEATE_e;
}
return cPhs_INIT_e;
}
int daNpc_zrA_c::CreateHeap() {
J3DModelData* model_data = NULL;
u32 model_flag;
if (mTwilight) {
if (l_bmdGetParamList[1].fileIdx >= 0) {
model_data = static_cast<J3DModelData*>(
dComIfG_getObjectRes(l_resNames[l_bmdGetParamList[1].arcIdx],
l_bmdGetParamList[1].fileIdx));
}
model_flag = 0x80000;
} else {
if (l_bmdGetParamList[0].fileIdx >= 0) {
model_data = static_cast<J3DModelData*>(
dComIfG_getObjectRes(l_resNames[l_bmdGetParamList[0].arcIdx],
l_bmdGetParamList[0].fileIdx));
}
model_flag = 0;
}
mAnm_p = JKR_NEW mDoExt_McaMorfSO(model_data, NULL, NULL, NULL, -1, 1.0f, 0, -1,
&mCreatureSound, model_flag, 0x11020285);
if (mAnm_p != NULL && mAnm_p->getModel() == NULL) {
mAnm_p->stopZelAnime();
mAnm_p = NULL;
}
if (mAnm_p == NULL) {
return 0;
}
J3DModel* model = mAnm_p->getModel();
for (u16 i = 0; i < model_data->getJointNum(); i++) {
switch (i) {
case 0:
case 1:
case 3:
case 4:
case 5:
case 14:
case 29:
model_data->getJointNodePointer(i)->setCallBack(ctrlJointCallBack);
break;
default:
model_data->getJointNodePointer(i)->setCallBack(NULL);
}
}
model->setUserArea((uintptr_t)this);
mpMatAnm = JKR_NEW daNpcF_MatAnm_c();
if (mpMatAnm == NULL) {
return 0;
}
setMotionWaterAnm(1);
if (!setExpressionAnm(ANM_F_TALK_A, false)) {
return 0;
}
setMotionAnm(ANM_WAIT_A, 0.0f);
if (mSoldierType != SOLDIER_NONE) {
for (int i = 0; i < 3; i++) {
int index;
if (mTwilight) {
index = l_loadObj_listTW[mSoldierType][i];
} else {
index = l_loadObj_list[mSoldierType][i];
}
if (index > 0) {
model_data = static_cast<J3DModelData*>(
dComIfG_getObjectRes(l_resNames[l_bmdGetParamList[index].arcIdx],
l_bmdGetParamList[index].fileIdx));
if (model_data != NULL) {
mpObjectModel[i] = mDoExt_J3DModel__create(model_data, 0x80000, 0x11000084);
if (mpObjectModel[i] == NULL) {
return 0;
}
} else {
return 0;
}
} else {
mpObjectModel[i] = NULL;
}
}
}
return 1;
}
int daNpc_zrA_c::Delete() {
this->~daNpc_zrA_c();
return 1;
}
int daNpc_zrA_c::Execute() {
return execute();
}
int daNpc_zrA_c::Draw() {
BOOL bvar2 = false;
J3DModel* model = mAnm_p->getModel();
J3DModelData* model_data = model->getModelData();
model_data->getMaterialNodePointer(1)->setMaterialAnm(mpMatAnm);
if (!mHide) {
if (mTwilight) {
bvar2 = false;
} else {
bvar2 = true;
}
}
if (!checkHide()) {
if (mTwilight) {
g_env_light.settingTevStruct(4, &current.pos, &tevStr);
} else {
g_env_light.settingTevStruct(0, &current.pos, &tevStr);
}
g_env_light.setLightTevColorType_MAJI(model, &tevStr);
if (!drawDbgInfo()) {
if (mWaterAnmFlags & ANM_PLAY_BTK) {
mWaterBtkAnm.entry(model_data);
}
if (mWaterAnmFlags & ANM_PLAY_BPK) {
mWaterBpkAnm.entry(model_data);
}
if (mAnmFlags & ANM_PLAY_BTP) {
mBtpAnm.entry(model_data);
}
if (mAnmFlags & ANM_PLAY_BTK) {
mBtkAnm.entry(model_data);
}
if (mAnmFlags & ANM_PLAY_BRK) {
mBrkAnm.entry(model_data);
}
if (bvar2) {
fopAcM_setEffectMtx(this, model_data);
}
if (mTwilight) {
dComIfGd_setListDark();
mAnm_p->entryDL();
dComIfGd_setList();
} else {
mAnm_p->entryDL();
}
if (mAnmFlags & ANM_PLAY_BTP) {
mBtpAnm.remove(model_data);
}
if (mAnmFlags & ANM_PLAY_BTK) {
mBtkAnm.remove(model_data);
}
if (mAnmFlags & ANM_PLAY_BRK) {
mBrkAnm.remove(model_data);
}
if (mWaterAnmFlags & ANM_PLAY_BPK) {
mWaterBpkAnm.remove(model_data);
}
if (mWaterAnmFlags & ANM_PLAY_BTK) {
mWaterBtkAnm.remove(model_data);
}
mShadowKey = dComIfGd_setShadow(mShadowKey, 1, model, &current.pos,
mpHIO->m.common.real_shadow_size, 20.0f,
current.pos.y, mGroundH, mGndChk, &tevStr,
0, 1.0f, dDlst_shadowControl_c::getSimpleTex());
drawOtherMdls();
}
}
return 1;
}
int daNpc_zrA_c::ctrlJoint(J3DJoint* i_joint, J3DModel* i_model) {
int jnt_no = i_joint->getJntNo();
Mtx mtx1, mtx2;
cXyz pos;
if (mSwimMode != SWIM_WAIT) {
mDoMtx_stack_c::copy(i_model->getAnmMtx(jnt_no));
switch (jnt_no) {
case 29:
calcWaistAngle();
MTXCopy(mDoMtx_stack_c::get(), mtx1);
pos.set(mtx1[0][3], mtx1[1][3], mtx1[2][3]);
mtx1[0][3] = mtx1[1][3] = mtx1[2][3] = 0.0f;
mDoMtx_stack_c::ZXYrotS(mCurAngle);
mDoMtx_stack_c::inverse();
MTXCopy(mDoMtx_stack_c::get(), mtx2);
mDoMtx_stack_c::transS(pos);
mDoMtx_stack_c::ZXYrotM(mCurAngle);
mDoMtx_stack_c::ZXYrotM(mWaistAngle);
mDoMtx_stack_c::concat(mtx2);
mDoMtx_stack_c::concat(mtx1);
break;
}
i_model->setAnmMtx(jnt_no, mDoMtx_stack_c::get());
MTXCopy(mDoMtx_stack_c::get(), J3DSys::mCurrentMtx);
return 1;
}
int lookat_joints[3] = {1, 3, 4};
if (jnt_no == 0) {
mDoMtx_stack_c::copy(mAnm_p->getModel()->getAnmMtx(1));
mDoMtx_stack_c::multVecZero(&mLookatPos[0]);
mDoMtx_stack_c::copy(mAnm_p->getModel()->getAnmMtx(3));
mDoMtx_stack_c::multVecZero(&mLookatPos[1]);
mDoMtx_stack_c::copy(mAnm_p->getModel()->getAnmMtx(4));
mDoMtx_stack_c::multVecZero(&mLookatPos[2]);
}
mDoMtx_stack_c::copy(i_model->getAnmMtx(jnt_no));
switch (jnt_no) {
case 1:
case 3:
case 4:
setLookatMtx(jnt_no, lookat_joints, mpHIO->m.common.neck_rotation_ratio);
break;
}
if (jnt_no == 1) {
mDoMtx_stack_c::YrotM(field_0x908[0].z);
mDoMtx_stack_c::ZrotM(-field_0x908[0].x);
} else if (jnt_no == 4) {
mDoMtx_stack_c::YrotM(field_0x908[2].z);
mDoMtx_stack_c::ZrotM(field_0x908[2].x);
}
i_model->setAnmMtx(jnt_no, mDoMtx_stack_c::get());
MTXCopy(mDoMtx_stack_c::get(), J3DSys::mCurrentMtx);
if ((jnt_no == 4 || jnt_no == 14) && (mAnmFlags & ANM_PLAY_BCK)) {
J3DAnmTransform* bck_anm = mBckAnm.getBckAnm();
mBckAnm.changeBckOnly(mAnm_p->getAnm());
mAnm_p->changeAnm(bck_anm);
}
return 1;
}
int daNpc_zrA_c::createHeapCallBack(fopAc_ac_c* i_this) {
return static_cast<daNpc_zrA_c*>(i_this)->CreateHeap();
}
int daNpc_zrA_c::ctrlJointCallBack(J3DJoint* i_joint, int param_1) {
if (param_1 == 0) {
J3DModel* model = j3dSys.getModel();
daNpc_zrA_c* _this = (daNpc_zrA_c*)model->getUserArea();
if (_this != NULL) {
_this->ctrlJoint(i_joint, model);
}
}
return 1;
}
void daNpc_zrA_c::setParam() {
u32 attn_flags = (fopAc_AttnFlag_SPEAK_e | fopAc_AttnFlag_TALK_e);
BOOL in_water = mAcch.ChkWaterIn();
if (mTwilight) {
attn_flags = (fopAc_AttnFlag_UNK_0x800000 | fopAc_AttnFlag_SPEAK_e | fopAc_AttnFlag_TALK_e);
}
selectAction();
if (!mTwilight && daPy_py_c::checkNowWolf()) {
attn_flags = 0;
}
if (field_0x1521) {
field_0x14d0 = 0;
field_0x14d4 = 0;
attn_flags = fopAc_AttnFlag_TALK_e;
if (daPy_getPlayerActorClass()->checkSwimUp()) {
attn_flags = 0;
}
if (field_0x153c == true || mSwimMode == SWIM_TURN) {
attn_flags = 0;
}
attention_info.distances[fopAc_attn_LOCK_e] = 64;
attention_info.distances[fopAc_attn_TALK_e] = attention_info.distances[fopAc_attn_LOCK_e];
attention_info.distances[fopAc_attn_SPEAK_e] = 63;
} else {
if (mType != TYPE_WAIT && mType != TYPE_SPA && mType != TYPE_SEARCH
&& (mType != TYPE_WATERFALL || mActionSelect != 0))
{
attn_flags = 0;
}
field_0x14d0 = 0;
field_0x14d4 = 0;
attention_info.distances[fopAc_attn_LOCK_e] = getDistTableIdx(5, 6);
attention_info.distances[fopAc_attn_TALK_e] = attention_info.distances[fopAc_attn_LOCK_e];
attention_info.distances[fopAc_attn_SPEAK_e] = getDistTableIdx(3, 6);
}
attention_info.flags = attn_flags;
scale.set(mpHIO->m.common.scale,
mpHIO->m.common.scale,
mpHIO->m.common.scale);
if (mSwimMode != SWIM_WAIT) {
scale *= mScaleFactor;
}
mAcchCir.SetWallR(mpHIO->m.common.width);
mAcchCir.SetWallH(mpHIO->m.common.knee_length);
if ((mType == TYPE_WAIT && !in_water) || mType == TYPE_SPA) {
gravity = mpHIO->m.common.gravity;
}
}
BOOL daNpc_zrA_c::main() {
if (!doEvent()) {
mOrderEvtNo = EVT_NONE;
if (mpNextActionFn != NULL) {
if (mpActionFn == mpNextActionFn) {
(this->*mpActionFn)(NULL);
} else {
setAction(mpNextActionFn);
}
}
}
if (checkHide()) {
attention_info.flags = 0;
}
if (!mpHIO->m.common.debug_mode_ON
&& (!dComIfGp_event_runCheck() || (mOrderNewEvt && dComIfGp_getEvent()->isOrderOK())))
{
if (mOrderEvtNo != EVT_NONE) {
eventInfo.setArchiveName(l_resNames[l_evtGetParamList[mOrderEvtNo].arcIdx]);
}
orderEvent(mOrderSpeakEvt, l_evtNames[l_evtGetParamList[mOrderEvtNo].fileIdx],
0xffff, 4, 0xff, 2);
if (!mTwilight && mType == TYPE_WAIT && !field_0x1550) {
eventInfo.onCondition(dEvtCnd_CANTALKITEM_e);
}
}
if (field_0x9ee) {
mExpressionMorfOverride = 0.0f;
mMotionMorfOverride = 0.0f;
field_0x9ee = false;
}
playExpression();
playMotion();
if (mAcch.ChkWaterIn()) {
setMotionWaterAnm(1);
} else {
setMotionWaterAnm(0);
}
if (mWaterAnmFlags & ANM_PLAY_BTK) {
f32 speed = mWaterBtkAnm.getPlaySpeed();
if (mWaterAnmFlags & ANM_PAUSE_BTK) {
mWaterBtkAnm.setPlaySpeed(0.0f);
}
mWaterBtkAnm.play();
mWaterBtkAnm.setPlaySpeed(speed);
}
if (mWaterAnmFlags & ANM_PLAY_BPK) {
f32 speed = mWaterBpkAnm.getPlaySpeed();
if (mWaterAnmFlags & ANM_PAUSE_BPK) {
mWaterBpkAnm.setPlaySpeed(0.0f);
}
mWaterBpkAnm.play();
mWaterBpkAnm.setPlaySpeed(speed);
}
mWaterAnmFlags &= ~(ANM_PAUSE_ALL | ANM_PAUSE_BPK);
return true;
}
BOOL daNpc_zrA_c::ctrlBtk() {
if (mpMatAnm != NULL) {
J3DAnmTextureSRTKey* btk_anm = NULL;
if (l_btkGetParamList[mBtkID].fileIdx >= 0) {
btk_anm = getTexSRTKeyAnmP(l_resNames[l_btkGetParamList[mBtkID].arcIdx],
l_btkGetParamList[mBtkID].fileIdx);
}
if (btk_anm == mBtkAnm.getBtkAnm()) {
if (mBtkID == 0) {
mpMatAnm->setNowOffsetX(cM_ssin(mEyeAngle.y) * 0.2f * -1.0f);
} else {
mpMatAnm->setNowOffsetX(cM_ssin(mEyeAngle.y) * 0.2f);
}
mpMatAnm->setNowOffsetY(cM_ssin(mEyeAngle.x) * 0.12f);
mpMatAnm->onEyeMoveFlag();
return true;
}
mpMatAnm->offEyeMoveFlag();
}
return false;
}
void daNpc_zrA_c::setAttnPos() {
static cXyz eyeOffset(-20.0f, 10.0f, 0.0f);
f32 offset = mpHIO->m.common.attention_offset;
cXyz center, vec2, vec3, vec4, vec5;
mDoMtx_stack_c::YrotS(field_0x990);
cLib_addCalc2(&field_0x984[0], 0.0f, 0.1f, 125.0f);
cLib_addCalc2(&field_0x984[2], 0.0f, 0.1f, 125.0f);
for (int i = 0; i < 3; i++) {
vec3.set(0.0f, 0.0f, field_0x984[i] * cM_ssin(field_0x992));
mDoMtx_stack_c::multVec(&vec3, &vec4);
field_0x908[i].x = -vec4.z;
field_0x908[i].z = -vec4.x;
}
cLib_chaseS(&field_0x992, 0, 0x555);
if (mLookMode == LOOK_RESET) {
for (int i = 0; i < 3; i++) {
mLookatAngle[i].setall(0);
}
}
J3DModelData* model_data = mAnm_p->getModel()->getModelData();
for (u16 i = 0; i < model_data->getJointNum(); i++) {
switch (i) {
case 0:
case 1:
case 3:
case 4:
case 5:
case 14:
case 29:
model_data->getJointNodePointer(i)->setCallBack(ctrlJointCallBack);
break;
default:
model_data->getJointNodePointer(i)->setCallBack(NULL);
break;
}
}
setMtx();
lookat();
setPrtcl();
mDoMtx_stack_c::copy(mAnm_p->getModel()->getAnmMtx(4));
mDoMtx_stack_c::multVecZero(&mHeadPos);
mDoMtx_stack_c::multVec(&eyeOffset, &eyePos);
eyeOffset.y = 0.0f;
mDoMtx_stack_c::multVec(&eyeOffset, &vec3);
mHeadAngle.x = cLib_targetAngleX(&mHeadPos, &vec3);
mHeadAngle.y = cLib_targetAngleY(&mHeadPos, &vec3);
cXyz* attn_pos = mLookat.getAttnPos();
if (attn_pos != NULL) {
vec2 = *attn_pos - eyePos;
mEyeAngle.y = -(mLookatAngle[2].y + mCurAngle.y);
mEyeAngle.y += cM_atan2s(vec2.x, vec2.z);
mEyeAngle.x = -cM_atan2s(vec2.y, vec2.absXZ());
mEyeAngle.x += mHeadAngle.x;
} else {
mEyeAngle.x = mEyeAngle.y = 0;
}
f32 extra_height = 0.0f;
f32 extra_radius = 0.0f;
vec2.set(0.0f, 0.0f, 0.0f);
if ((mType == TYPE_WAIT || mType == TYPE_SPA) && mActionType != ACT_TYPE_0) {
if (mType == TYPE_SPA || (mType == TYPE_WAIT
&& (mActionType == ACT_TYPE_1
|| mActionType == ACT_TYPE_2
|| mActionType == ACT_TYPE_3)))
{
mDoMtx_stack_c::copy(mAnm_p->getModel()->getAnmMtx(29));
mDoMtx_stack_c::multVecZero(&center);
center.y = current.pos.y;
extra_radius = 70.0f;
} else {
center = current.pos;
}
mDoMtx_stack_c::copy(mAnm_p->getModel()->getAnmMtx(4));
mDoMtx_stack_c::multVecZero(&vec5);
attention_info.position.set(vec5.x, vec5.y + 40.0f, vec5.z);
} else {
if (mType == TYPE_TOBIKOMI) {
extra_height = 700.0f;
extra_radius = 800.0f;
} else if (mType == TYPE_SWIM && mPath.getPathInfo() != NULL) {
extra_height = -150.0f;
}
center = current.pos;
attention_info.position.set(center.x, center.y + offset, center.z);
}
if (!mHide) {
if (mDamageTimer == 0) {
if (mType == TYPE_TOBIKOMI) {
mCcCyl.SetTgType(0x2020);
mCcCyl.SetTgSPrm(0x3f);
mCcCyl.OnTgNoHitMark();
} else {
mCcCyl.SetTgType(0xd8fbfdff);
mCcCyl.SetTgSPrm(0x1f);
mCcCyl.OnTgNoHitMark();
}
} else {
mCcCyl.SetTgType(0);
mCcCyl.SetTgSPrm(0);
}
if (mType == TYPE_TOBIKOMI) {
mCcCyl.SetCoSPrm(0x379);
} else {
switch (mOrderEvtNo) {
case EVT_CARRY_WATERFALL:
case EVT_CARRY_WATERFALL_NIGHT:
mCcCyl.SetCoSPrm(0x179);
break;
default:
mCcCyl.SetCoSPrm(0x79);
break;
}
}
mCcCyl.SetC(center);
mCcCyl.SetH(mpHIO->m.common.height + extra_height);
mCcCyl.SetR(mpHIO->m.common.width + extra_radius);
dComIfG_Ccsp()->Set(&mCcCyl);
}
mCcCyl.ClrAtHit();
mCcCyl.ClrTgHit();
mCcCyl.ClrCoHit();
}
void daNpc_zrA_c::setMtx() {
J3DModel* model = mAnm_p->getModel();
cXyz pos = current.pos;
pos += mModulationOffset;
mDoMtx_stack_c::transS(pos);
mDoMtx_stack_c::ZXYrotM(mCurAngle);
mDoMtx_stack_c::scaleM(scale);
model->setBaseTRMtx(mDoMtx_stack_c::get());
model->setUserArea((uintptr_t)this);
if (mAnmFlags & ANM_PLAY_BCK) {
mBckAnm.getBckAnm()->setFrame(mBckAnm.getFrame());
mAnm_p->modelCalc();
} else {
mAnm_p->modelCalc();
}
}
bool daNpc_zrA_c::setExpressionAnm(int i_idx, bool i_modify) {
J3DAnmTransform* bck_anm = NULL;
int attr = J3DFrameCtrl::EMode_NONE;
mAnmFlags &= ~ANM_EXPRESSION_FLAGS;
if (l_bckGetParamList[i_idx].fileIdx >= 0) {
bck_anm = getTrnsfrmKeyAnmP(l_resNames[l_bckGetParamList[i_idx].arcIdx],
l_bckGetParamList[i_idx].fileIdx);
}
bool res = false;
switch (i_idx) {
case ANM_NONE:
res = setExpressionBtp(0);
break;
case ANM_F_TALK_A:
res = setExpressionBtp(0);
break;
case ANM_F_TALK_A_SP:
res = setExpressionBtp(0);
break;
case ANM_F_WAIT_SWIM:
res = setExpressionBtp(0);
break;
case ANM_F_TALK_NOMAL:
res = setExpressionBtp(0);
break;
case ANM_FH_TALK_NOMAL:
res = setExpressionBtp(0);
attr = J3DFrameCtrl::EMode_LOOP;
break;
case ANM_FH_SADSIT_A:
res = setExpressionBtp(1);
attr = J3DFrameCtrl::EMode_LOOP;
break;
case ANM_FH_SADSIT_B:
res = setExpressionBtp(2);
attr = J3DFrameCtrl::EMode_LOOP;
break;
case ANM_FH_SADSIT_C:
res = setExpressionBtp(3);
attr = J3DFrameCtrl::EMode_LOOP;
break;
case ANM_FH_SADSIT_D:
res = setExpressionBtp(4);
attr = J3DFrameCtrl::EMode_LOOP;
break;
case ANM_FH_SADSIT_E:
res = setExpressionBtp(5);
attr = J3DFrameCtrl::EMode_LOOP;
break;
case ANM_F_LOOKING_SP:
res = setExpressionBtp(0);
break;
case ANM_FH_LOOKING_SP:
res = setExpressionBtp(0);
attr = J3DFrameCtrl::EMode_LOOP;
break;
case ANM_F_LOOKUP:
res = setExpressionBtp(0);
break;
case ANM_FH_LOOKUP:
res = setExpressionBtp(0);
attr = J3DFrameCtrl::EMode_LOOP;
break;
case ANM_F_TALK_SWIM_SP:
res = setExpressionBtp(0);
break;
case ANM_F_TALK_B_SP:
res = setExpressionBtp(0);
break;
case ANM_F_SPA_TALK_A:
res = setExpressionBtp(0);
break;
case ANM_FH_SPA_WAIT_A:
res = setExpressionBtp(0);
attr = J3DFrameCtrl::EMode_LOOP;
break;
case ANM_F_SPA_TALK_B:
res = setExpressionBtp(6);
break;
case ANM_FH_SPA_WAIT_B:
res = setExpressionBtp(7);
attr = J3DFrameCtrl::EMode_LOOP;
break;
default:
bck_anm = NULL;
break;
}
if (!res) {
return false;
}
if (bck_anm == NULL) {
return true;
}
if (setBckAnm(bck_anm, 1.0f, attr, 0, -1, i_modify)) {
mAnmFlags |= ANM_PLAY_BCK | ANM_PAUSE_BCK;
mExpressionLoops = 0;
return true;
}
return false;
}
bool daNpc_zrA_c::setExpressionBtp(int i_idx) {
J3DAnmTexPattern* btp_anm = NULL;
int attr = J3DFrameCtrl::EMode_NONE;
mAnmFlags &= ~(ANM_PLAY_BTP | ANM_PAUSE_BTP | ANM_FLAG_800);
if (l_btpGetParamList[i_idx].fileIdx >= 0) {
btp_anm = getTexPtrnAnmP(l_resNames[l_btpGetParamList[i_idx].arcIdx],
l_btpGetParamList[i_idx].fileIdx);
}
switch (i_idx) {
case 0:
case 1:
case 2:
case 3:
case 4:
case 5:
case 7:
attr = J3DFrameCtrl::EMode_LOOP;
break;
case 6:
break;
default:
btp_anm = NULL;
break;
}
if (btp_anm == NULL) {
return true;
}
if (setBtpAnm(btp_anm, mAnm_p->getModel()->getModelData(), 1.0f, attr)) {
mAnmFlags |= ANM_PLAY_BTP | ANM_PAUSE_BTP;
if (i_idx == 0) {
mAnmFlags |= ANM_FLAG_800;
}
return true;
}
return false;
}
void daNpc_zrA_c::setExpression(int i_expression, f32 i_morf) {
if (i_expression >= 0 && i_expression < 0x15) {
mExpression = i_expression;
mExpressionMorfOverride = i_morf;
mExpressionPrevPhase = -1;
mExpressionPhase = 0;
}
}
void daNpc_zrA_c::setMotionAnm(int i_idx, f32 i_morf) {
J3DAnmTransformKey* bck_anm = NULL;
J3DAnmTextureSRTKey* btk_anm = NULL;
int btk_idx = 0;
int attr = J3DFrameCtrl::EMode_LOOP;
mBaseMotionAnm = i_idx;
if (mAcch.ChkWaterIn()) {
btk_idx = 3;
}
if (mSoldierType == SOLDIER_SPEAR && mBaseMotionAnm >= 0x29 && mBaseMotionAnm <= 0x33) {
i_idx += 0xb;
}
mAnmFlags &= ~(ANM_PLAY_MORF | ANM_PLAY_BTK | ANM_PAUSE_MORF | ANM_PAUSE_BTK);
if (l_bckGetParamList[i_idx].fileIdx >= 0) {
bck_anm = getTrnsfrmKeyAnmP(l_resNames[l_bckGetParamList[i_idx].arcIdx],
l_bckGetParamList[i_idx].fileIdx);
}
switch (i_idx) {
case ANM_SWIM_TURN:
case ANM_STILL:
case ANM_SWIM_TALK:
case ANM_TOBIKOMI_S:
case ANM_TOBIKOMI_E:
case ANM_SPA_TALK_B:
case ANM_SPA_TALK_A:
case ANM_TALK_A:
case ANM_DIVE:
case ANM_DIVE_B:
case ANM_FLOAT:
case ANM_FLOAT_B:
case ANM_STEP:
case ANM_TALK_A_SP:
case ANM_DIVE_SP:
case ANM_DIVE_B_SP:
case ANM_FLOAT_SP:
case ANM_FLOAT_B_SP:
case ANM_STEP_SP:
attr = J3DFrameCtrl::EMode_NONE;
break;
case ANM_FALLSWIM:
case ANM_SADSIT_A:
case ANM_SADSIT_B:
case ANM_SADSIT_C:
case ANM_SADSIT_D:
case ANM_SADSIT_E:
case ANM_TOBIKOMI_T:
case ANM_LOOKING_SP:
case ANM_TALK_SWIM_SP:
case ANM_TALK_B_SP:
case ANM_LOOKUP:
case ANM_SPA_WAIT_B:
case ANM_SPA_WAIT_A:
case ANM_WAIT_A:
case ANM_WALK_A:
case ANM_SWIM_A:
case ANM_SWIM_B:
case ANM_WAIT_SWIM:
case ANM_WAIT_SP:
case ANM_WALK_A_SP:
case ANM_SWIM_A_SP:
case ANM_SWIM_B_SP:
case ANM_WAIT_SWIM_SP:
break;
default:
bck_anm = NULL;
btk_anm = NULL;
break;
}
if (l_btkGetParamList[btk_idx].fileIdx >= 0) {
btk_anm = getTexSRTKeyAnmP(l_resNames[l_btkGetParamList[btk_idx].arcIdx],
l_btkGetParamList[btk_idx].fileIdx);
}
if (btk_anm != NULL && setBtkAnm(btk_anm, mAnm_p->getModel()->getModelData(), 1.0f, 2)) {
mAnmFlags |= ANM_PLAY_BTK | ANM_PAUSE_BTK;
}
mBtkID = btk_idx;
if (bck_anm != NULL && setMcaMorfAnm(bck_anm, 1.0f, i_morf, attr, 0, -1)) {
mAnmFlags |= ANM_PLAY_MORF | ANM_PAUSE_MORF;
mMotionLoops = 0;
}
}
void daNpc_zrA_c::setMotionWaterAnm(int i_idx) {
J3DAnmTevRegKey* brk_anm = NULL;
J3DAnmTextureSRTKey* btk_anm = NULL;
J3DAnmColor* bpk_anm = NULL;
int btk_idx = 0;
int bpk_idx = 0;
mAnmFlags &= ~(ANM_PLAY_BRK | ANM_PAUSE_BRK);
mWaterAnmFlags &= ~(ANM_PLAY_BTK | ANM_PAUSE_BTK | ANM_PLAY_BPK | ANM_PAUSE_BPK);
if (!mTwilight) {
if (l_brkGetParamList[i_idx].fileIdx >= 0) {
brk_anm = getTevRegKeyAnmP(l_resNames[l_brkGetParamList[i_idx].arcIdx],
l_brkGetParamList[i_idx].fileIdx);
}
}
switch (i_idx) {
case 0:
btk_idx = 2;
bpk_idx = i_idx;
break;
case 1:
btk_idx = i_idx;
bpk_idx = i_idx;
break;
default:
brk_anm = NULL;
}
mBpkID = bpk_idx;
if (brk_anm != NULL) {
if (mBrkAnm.getBrkAnm() == brk_anm) {
mAnmFlags |= ANM_PLAY_BRK;
} else if (setBrkAnm(brk_anm, mAnm_p->getModel()->getModelData(), 1.0f, 2)) {
mAnmFlags |= ANM_PLAY_BRK | ANM_PAUSE_BRK;
}
}
if (!mTwilight) {
if (l_btkGetParamList[btk_idx].fileIdx >= 0) {
btk_anm = getTexSRTKeyAnmP(l_resNames[l_btkGetParamList[btk_idx].arcIdx],
l_btkGetParamList[btk_idx].fileIdx);
}
}
if (btk_anm != NULL) {
if (mWaterBtkAnm.getBtkAnm() == btk_anm) {
mWaterAnmFlags |= ANM_PLAY_BTK;
} else if (mWaterBtkAnm.init(mAnm_p->getModel()->getModelData(),
btk_anm, 1, 2, 1.0f, 0, -1)) {
mWaterAnmFlags |= ANM_PLAY_BTK | ANM_PAUSE_BTK;
}
}
if (l_bpkGetParamList[bpk_idx].fileIdx >= 0) {
bpk_anm = static_cast<J3DAnmColor*>(
dComIfG_getObjectRes(l_resNames[l_bpkGetParamList[bpk_idx].arcIdx],
l_bpkGetParamList[bpk_idx].fileIdx));
}
if (bpk_anm != NULL) {
if (mWaterBpkAnm.getBpkAnm() == bpk_anm) {
mWaterAnmFlags |= ANM_PLAY_BPK;
} else if (mWaterBpkAnm.init(mAnm_p->getModel()->getModelData(),
bpk_anm, 1, 2, 1.0f, 0, -1)) {
mWaterAnmFlags |= ANM_PLAY_BPK | ANM_PAUSE_BPK;
}
}
}
void daNpc_zrA_c::setMotion(int i_motion, f32 i_morf, BOOL i_restart) {
s16 motion = i_motion;
if (i_restart || mMotion != motion) {
if (i_motion >= 0 && i_motion < 0x24) {
mMotion = motion;
mMotionMorfOverride = i_morf;
mMotionPrevPhase = -1;
mMotionPhase = 0;
}
}
}
BOOL daNpc_zrA_c::drawDbgInfo() {
return false;
}
void daNpc_zrA_c::drawOtherMdls() {
static int const l_jntNumTbl[3][3] = {
{4, 25, -1},
{4, -1, -1},
{-1, -1, -1},
};
if (mSoldierType != SOLDIER_NONE) {
for (int i = 0; i < 3; i++) {
int jnt_no = l_jntNumTbl[mSoldierType][i];
J3DModel* model = mpObjectModel[i];
if (model != NULL && jnt_no >= 0) {
g_env_light.setLightTevColorType_MAJI(model, &tevStr);
mDoMtx_stack_c::copy(mAnm_p->getModel()->getAnmMtx(jnt_no));
mDoMtx_stack_c::scaleM(scale);
model->setBaseTRMtx(mDoMtx_stack_c::get());
mDoExt_modelUpdateDL(model);
dComIfGd_addRealShadow(mShadowKey, model);
}
}
}
}
daNpc_zrA_c::Type daNpc_zrA_c::getTypeFromArgument() {
switch (argument) {
case 0:
return TYPE_WAIT;
case 1:
return TYPE_SWIM;
case 2:
return TYPE_WATERFALL;
case 3:
return TYPE_RIVER;
case 4:
return TYPE_TOBIKOMI;
case 5:
return TYPE_SEARCH;
case 6:
return TYPE_SPA;
default:
return TYPE_WAIT;
}
}
daNpc_zrA_c::SoldierType daNpc_zrA_c::getSoldierTypeFromParam() {
if (mType == TYPE_WATERFALL || mType == TYPE_SEARCH) {
return SOLDIER_NOSPEAR;
}
if (mType == TYPE_TOBIKOMI) {
return SOLDIER_NONE;
}
switch (fopAcM_GetParam(this) & 0xff) {
case 0:
return SOLDIER_SPEAR;
default:
return SOLDIER_NONE;
}
}
daNpc_zrA_c::GameMode daNpc_zrA_c::getGameModeFromParam() {
switch ((fopAcM_GetParam(this) >> 0x14) & 0xf) {
case 1:
return GAME_MODE_3;
default:
return GAME_MODE_0;
}
}
daNpc_zrA_c::ActionType daNpc_zrA_c::getActionTypeFromParam() {
u8 param = (fopAcM_GetParam(this) >> 0x10) & 0xf;
if (mType == TYPE_WAIT) {
switch (param) {
case 1:
return ACT_TYPE_1;
case 2:
return ACT_TYPE_2;
case 3:
return ACT_TYPE_3;
case 4:
return ACT_TYPE_4;
case 5:
return ACT_TYPE_5;
case 6:
return ACT_TYPE_6;
default:
return ACT_TYPE_0;
}
} else if (mType == TYPE_SPA) {
switch (param) {
case 1:
return ACT_TYPE_2;
case 2:
return ACT_TYPE_3;
default:
return ACT_TYPE_0;
}
} else {
return (ActionType)param;
}
}
u8 daNpc_zrA_c::getMultiModeFromParam() {
u8 param = (fopAcM_GetParam(this) >> 0x14) & 0xf;
if (mType != 0) {
return 0;
}
if (param == 0xf) {
param = 0;
}
return param;
}
u8 daNpc_zrA_c::getMultiNoFromParam() {
u8 param = (fopAcM_GetParam(this) >> 0x18) & 0xf;
if (mType != 0) {
return 0;
}
return param == 0xf ? (u8)0 : param;
}
BOOL daNpc_zrA_c::isDelete() {
if ((mType == TYPE_SEARCH && dComIfGs_isSwitch(mSwitch1, fopAcM_GetRoomNo(this)))
|| (mType == TYPE_SPA && !daNpcF_chkEvtBit(0x10a))
|| (mType == TYPE_RIVER && mGameMode == GAME_MODE_3
&& (strcmp(dComIfGp_getStartStageName(), "F_SP115") || fopAcM_GetRoomNo(this) != 0
|| dComIfGs_getStartPoint() != 2)))
{
return true;
}
return false;
}
void daNpc_zrA_c::reset() {
initialize();
mpMatAnm->initialize();
mPath.initialize();
if (mType != TYPE_TOBIKOMI
&& mPath.setPathInfo(getPathNoFromParam(), fopAcM_GetRoomNo(this), 0))
{
mPath.setRange(100.0f);
}
mLookat.initialize();
for (int i = 0; i < 3; i++) {
mActorMngr[i].initialize();
}
mpNextActionFn = NULL;
mpActionFn = NULL;
field_0x14d0 = 0;
field_0x14d4 = 0;
mSwimTurnTimer = 0;
field_0x14dc = 0;
mLookMode = -1;
mMode = 0;
mHide = false;
mItemID = -1;
current.pos = home.pos;
old.pos = current.pos;
current.angle.set(0, home.angle.y, 0);
old.angle = current.angle;
shape_angle = current.angle;
mCurAngle = current.angle;
mOldAngle = mCurAngle;
speedF = 0.0f;
speed.setall(0.0f);
if ((mType == TYPE_SWIM && mPath.getPathInfo() != NULL) || mType == TYPE_WATERFALL) {
fopAcM_OnStatus(this, fopAcStts_UNK_0x8000000_e);
}
mBtkID = 0;
field_0x1510 = 0;
if (mType == TYPE_RIVER) {
mStaffName = l_myName[2];
} else if (mType == TYPE_WATERFALL) {
mStaffName = l_myName[3];
} else {
mStaffName = l_myName[0];
}
mSpinAngle = 0;
mSpinTimer = 0;
mSwimSpeedScale = 1.0f;
mSwimSpeedF = mSwimSpeedScale * mpHIO->m.mSwimSpeed;
mSwimMode = SWIM_WAIT;
field_0x1521 = false;
mWaistAngle.set(0, 0, 0);
mSwimAngleCalc = current.angle;
field_0x153c = false;
field_0x153d = false;
field_0x153e = false;
mSwimFastTurnTimer = 0;
mSwimSpeed.set(0.0f, 0.0f, 0.0f);
mEvasionTimer = 0;
mCheckSwimTurnTimer = 0;
mCheckSwimTurn = false;
mResetWaistAngle = false;
field_0x1550 = false;
field_0x1554 = 0;
mModulationOffset.set(0.0f, 0.0f, 0.0f);
mModulationParam = 210;
mActionType = getActionTypeFromParam();
mIsAboveWater = false;
mIsTurning = false;
mActionSelect = 0;
mMeterCount = 0;
mRiverPathIdx = 0;
field_0x15c0 = 0;
mBlastFlag = false;
mWaterAnmFlags = 0;
if (mType == TYPE_SEARCH) {
if (getNoFromParam() == 0) {
eventInfo.setIdx(1);
} else {
eventInfo.setIdx(2);
}
} else if (mType == TYPE_WAIT && getMultiModeFromParam() != 0) {
eventInfo.setIdx(getMultiNoFromParam());
}
field_0x9ee = 1;
}
void daNpc_zrA_c::playExpression() {
daNpcF_anmPlayData dat0a = {ANM_F_TALK_NOMAL, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat0b = {ANM_FH_TALK_NOMAL, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat0[2] = {&dat0a, &dat0b};
daNpcF_anmPlayData dat1 = {ANM_FH_SADSIT_A, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat1[1] = {&dat1};
daNpcF_anmPlayData dat2 = {ANM_FH_SADSIT_B, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat2[1] = {&dat2};
daNpcF_anmPlayData dat3 = {ANM_FH_SADSIT_C, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat3[1] = {&dat3};
daNpcF_anmPlayData dat4 = {ANM_FH_SADSIT_D, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat4[1] = {&dat4};
daNpcF_anmPlayData dat5 = {ANM_FH_SADSIT_E, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat5[1] = {&dat5};
daNpcF_anmPlayData dat6a = {ANM_F_LOOKING_SP, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat6b = {ANM_FH_LOOKING_SP, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat6[2] = {&dat6a, &dat6b};
daNpcF_anmPlayData dat7a = {ANM_F_LOOKUP, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat7b = {ANM_FH_LOOKUP, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat7[2] = {&dat7a, &dat7b};
daNpcF_anmPlayData dat8a = {ANM_F_SPA_TALK_A, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat8b = {ANM_FH_SPA_WAIT_A, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat8[2] = {&dat8a, &dat8b};
daNpcF_anmPlayData dat9a = {ANM_F_SPA_TALK_B, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat9b = {ANM_FH_SPA_WAIT_B, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat9[2] = {&dat9a, &dat9b};
daNpcF_anmPlayData dat10a = {ANM_F_TALK_SWIM_SP, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat10b = {ANM_NONE, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat10[2] = {&dat10a, &dat10b};
daNpcF_anmPlayData dat11a = {ANM_F_TALK_B_SP, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat11b = {ANM_NONE, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat11[2] = {&dat11a, &dat11b};
daNpcF_anmPlayData dat12a = {ANM_F_TALK_A, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat12b = {ANM_NONE, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat12[2] = {&dat12a, &dat12b};
daNpcF_anmPlayData dat13a = {ANM_F_WAIT_SWIM, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat13b = {ANM_NONE, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat13[2] = {&dat13a, &dat13b};
daNpcF_anmPlayData dat14a = {ANM_F_TALK_A_SP, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat14b = {ANM_NONE, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat14[2] = {&dat14a, &dat14b};
daNpcF_anmPlayData dat15 = {ANM_FH_TALK_NOMAL, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat15[1] = {&dat15};
daNpcF_anmPlayData dat16 = {ANM_FH_LOOKING_SP, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat16[1] = {&dat16};
daNpcF_anmPlayData dat17 = {ANM_FH_LOOKUP, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat17[1] = {&dat17};
daNpcF_anmPlayData dat18 = {ANM_FH_SPA_WAIT_A, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat18[1] = {&dat18};
daNpcF_anmPlayData dat19 = {ANM_FH_SPA_WAIT_B, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat19[1] = {&dat19};
daNpcF_anmPlayData dat20 = {ANM_NONE, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat20[1] = {&dat20};
daNpcF_anmPlayData** ppDat[21] = {
pDat0, pDat1, pDat2, pDat3, pDat4, pDat5, pDat6, pDat7, pDat8, pDat9, pDat10, pDat11,
pDat12, pDat13, pDat14, pDat15, pDat16, pDat17, pDat18, pDat19, pDat20,
};
if (mExpression >= 0 && mExpression < 0x15) {
playExpressionAnm(ppDat);
}
}
void daNpc_zrA_c::playMotion() {
daNpcF_anmPlayData dat0 = {ANM_WAIT_A, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat0[1] = {&dat0};
daNpcF_anmPlayData dat1 = {ANM_WAIT_SWIM, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat1[1] = {&dat1};
daNpcF_anmPlayData dat2a = {ANM_SWIM_TALK, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat2b = {ANM_WAIT_SWIM, 0.0f, 0};
daNpcF_anmPlayData* pDat2[2] = {&dat2a, &dat2b};
daNpcF_anmPlayData dat3 = {ANM_WAIT_A, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat3[1] = {&dat3};
daNpcF_anmPlayData dat4 = {ANM_WAIT_SWIM, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat4[1] = {&dat4};
daNpcF_anmPlayData dat5a = {ANM_TALK_A, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat5b = {ANM_WAIT_A, 0.0f, 0};
daNpcF_anmPlayData* pDat5[2] = {&dat5a, &dat5b};
daNpcF_anmPlayData dat6 = {ANM_SADSIT_A, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat6[1] = {&dat6};
daNpcF_anmPlayData dat7 = {ANM_SADSIT_B, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat7[1] = {&dat7};
daNpcF_anmPlayData dat8 = {ANM_SADSIT_C, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat8[1] = {&dat8};
daNpcF_anmPlayData dat9 = {ANM_SADSIT_D, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat9[1] = {&dat9};
daNpcF_anmPlayData dat10 = {ANM_SADSIT_E, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat10[1] = {&dat10};
daNpcF_anmPlayData dat11 = {ANM_LOOKING_SP, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat11[1] = {&dat11};
daNpcF_anmPlayData dat12 = {ANM_LOOKUP, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat12[1] = {&dat12};
daNpcF_anmPlayData dat13a = {ANM_SPA_TALK_A, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat13b = {ANM_SPA_WAIT_A, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat13[2] = {&dat13a, &dat13b};
daNpcF_anmPlayData dat14a = {ANM_SPA_TALK_B, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat14b = {ANM_SPA_WAIT_B, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat14[2] = {&dat14a, &dat14b};
daNpcF_anmPlayData dat15a = {ANM_TALK_SWIM_SP, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat15b = {ANM_WAIT_SWIM_SP, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat15[2] = {&dat15a, &dat15b};
daNpcF_anmPlayData dat16a = {ANM_TALK_B_SP, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat16b = {ANM_WAIT_SP, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat16[2] = {&dat16a, &dat16b};
daNpcF_anmPlayData dat17a = {ANM_TALK_A, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat17b = {ANM_WAIT_A, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat17[2] = {&dat17a, &dat17b};
daNpcF_anmPlayData dat18 = {ANM_SPA_WAIT_A, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat18[1] = {&dat18};
daNpcF_anmPlayData dat19 = {ANM_SPA_WAIT_B, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat19[1] = {&dat19};
daNpcF_anmPlayData dat20 = {ANM_WALK_A, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat20[1] = {&dat20};
daNpcF_anmPlayData dat22 = {ANM_SWIM_A, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat22[1] = {&dat22};
daNpcF_anmPlayData dat23 = {ANM_SWIM_B, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat23[1] = {&dat23};
daNpcF_anmPlayData dat24a = {ANM_DIVE, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat24b = {ANM_SWIM_A, 0.0f, 0};
daNpcF_anmPlayData* pDat24[2] = {&dat24a, &dat24b};
daNpcF_anmPlayData dat25a = {ANM_DIVE_B, 3.0f, 1};
daNpcF_anmPlayData dat25b = {ANM_SWIM_A, 0.0f, 0};
daNpcF_anmPlayData* pDat25[2] = {&dat25a, &dat25b};
daNpcF_anmPlayData dat26a = {ANM_DIVE, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat26b = {ANM_SWIM_B, mpHIO->m.common.morf_frame / 2.0f, 0};
daNpcF_anmPlayData* pDat26[2] = {&dat26a, &dat26b};
daNpcF_anmPlayData dat27a = {ANM_DIVE_B, 3.0f, 1};
daNpcF_anmPlayData dat27b = {ANM_SWIM_B, mpHIO->m.common.morf_frame / 2.0f, 0};
daNpcF_anmPlayData* pDat27[2] = {&dat27a, &dat27b};
daNpcF_anmPlayData dat28 = {ANM_STEP, 2.0f, 0};
daNpcF_anmPlayData* pDat28[1] = {&dat28};
daNpcF_anmPlayData dat29a = {ANM_FLOAT, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat29b = {ANM_WAIT_SWIM, 2.0f, 0};
daNpcF_anmPlayData* pDat29[2] = {&dat29a, &dat29b};
daNpcF_anmPlayData dat30a = {ANM_FLOAT_B, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat30b = {ANM_WAIT_SWIM, 2.0f, 0};
daNpcF_anmPlayData* pDat30[2] = {&dat30a, &dat30b};
daNpcF_anmPlayData dat31a = {ANM_SWIM_TURN, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat31b = {ANM_STILL, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat31[2] = {&dat31a, &dat31b};
daNpcF_anmPlayData dat32 = {ANM_TOBIKOMI_S, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat32[1] = {&dat32};
daNpcF_anmPlayData dat33 = {ANM_TOBIKOMI_T, 0.0f, 0};
daNpcF_anmPlayData* pDat33[1] = {&dat33};
daNpcF_anmPlayData dat34a = {ANM_TOBIKOMI_E, mpHIO->m.common.morf_frame, 1};
daNpcF_anmPlayData dat34b = {ANM_SWIM_A, 0.0f, 0};
daNpcF_anmPlayData* pDat34[2] = {&dat34a, &dat34b};
daNpcF_anmPlayData dat35 = {ANM_FALLSWIM, mpHIO->m.common.morf_frame, 0};
daNpcF_anmPlayData* pDat35[1] = {&dat35};
daNpcF_anmPlayData** ppDat[36] = {
pDat0, pDat1, pDat2, pDat3, pDat4, pDat5, pDat6, pDat7, pDat8, pDat9, pDat10, pDat11,
pDat12, pDat13, pDat14, pDat15, pDat16, pDat17, pDat18, pDat19, pDat20, NULL, pDat22,
pDat23, pDat24, pDat25, pDat26, pDat27, pDat28, pDat29, pDat30, pDat31, pDat32,
pDat33, pDat34, pDat35,
};
if (mMotion >= 0 && mMotion < 0x24) {
playMotionAnm(ppDat);
}
}
BOOL daNpc_zrA_c::chkAction(ActionFn i_action) {
return mpActionFn == i_action;
}
bool daNpc_zrA_c::setAction(ActionFn i_action) {
mMode = 3;
if (mpActionFn != NULL) {
(this->*mpActionFn)(NULL);
}
mMode = 0;
mpActionFn = i_action;
if (mpActionFn != NULL) {
(this->*mpActionFn)(NULL);
}
return true;
}
bool daNpc_zrA_c::selectAction() {
mpNextActionFn = NULL;
if (mpHIO->m.common.debug_mode_ON) {
mpNextActionFn = &daNpc_zrA_c::test;
} else {
switch (mType) {
case TYPE_SWIM:
mpNextActionFn = &daNpc_zrA_c::swim;
break;
case TYPE_WATERFALL:
switch (mActionSelect) {
case 0:
mpNextActionFn = &daNpc_zrA_c::waitWaterfall;
break;
case 1:
mpNextActionFn = &daNpc_zrA_c::swimWaterfall;
break;
case 2:
break;
case 3:
mpNextActionFn = &daNpc_zrA_c::diveWaterfall;
break;
}
break;
case TYPE_RIVER:
switch (mActionSelect) {
case 0:
mpNextActionFn = &daNpc_zrA_c::waitRiverDescend;
break;
case 1:
mpNextActionFn = &daNpc_zrA_c::swimRiverDescend;
break;
case 6:
mpNextActionFn = &daNpc_zrA_c::swimRiverDescend2;
break;
case 3:
mpNextActionFn = &daNpc_zrA_c::diveRiverDescend;
break;
case 4:
mpNextActionFn = &daNpc_zrA_c::swimGoalRiverDescend;
break;
default:
mpNextActionFn = &daNpc_zrA_c::returnRiverDescend;
break;
}
break;
case TYPE_TOBIKOMI:
switch (mActionSelect) {
case 0:
mpNextActionFn = &daNpc_zrA_c::tobiSearch;
break;
case 1:
mpNextActionFn = &daNpc_zrA_c::tobiWait;
break;
case 2:
mpNextActionFn = &daNpc_zrA_c::tobikomi1;
break;
case 3:
mpNextActionFn = &daNpc_zrA_c::tobikomi2;
break;
case 4:
mpNextActionFn = &daNpc_zrA_c::tobikomi3;
break;
case 5:
mpNextActionFn = &daNpc_zrA_c::tobiJump;
break;
case 6:
mpNextActionFn = &daNpc_zrA_c::tobiEnd;
break;
}
break;
case TYPE_SEARCH:
switch (mActionSelect) {
case 0:
mpNextActionFn = &daNpc_zrA_c::waitSearch;
break;
}
break;
case TYPE_SPA:
mpNextActionFn = &daNpc_zrA_c::waitSpa;
break;
case TYPE_WAIT:
if (mActionType == ACT_TYPE_6) {
mpNextActionFn = &daNpc_zrA_c::waitLake;
} else {
mpNextActionFn = &daNpc_zrA_c::wait;
}
break;
default:
mpNextActionFn = &daNpc_zrA_c::wait;
break;
}
}
return true;
}
BOOL daNpc_zrA_c::doEvent() {
dEvent_manager_c* event_manager = NULL;
BOOL ret = false;
int staff_id;
if (dComIfGp_event_runCheck()) {
event_manager = &dComIfGp_getEventManager();
if (eventInfo.checkCommandTalk() || eventInfo.checkCommandDemoAccrpt()) {
mOrderNewEvt = false;
}
if (eventInfo.checkCommandTalk()) {
if (field_0x1521 == true && mType == TYPE_SWIM) {
mOrderEvtNo = EVT_TALK_SWIM;
changeEvent(l_resNames[l_evtGetParamList[mOrderEvtNo].arcIdx],
l_evtNames[l_evtGetParamList[mOrderEvtNo].fileIdx], 1, 0xffff);
mStaffName = l_myName[1];
} else if (mType == TYPE_WATERFALL) {
if (chkAction(&daNpc_zrA_c::talkSwim)) {
(this->*mpActionFn)(NULL);
} else if (dComIfGp_event_chkTalkXY() == false || dComIfGp_evmng_ChkPresentEnd()) {
setAction(&daNpc_zrA_c::talkSwim);
}
} else if (mType == TYPE_SEARCH) {
mOrderEvtNo = EVT_SEARCH_PRINCE;
changeEvent(l_resNames[l_evtGetParamList[mOrderEvtNo].arcIdx],
l_evtNames[l_evtGetParamList[mOrderEvtNo].fileIdx], 1, 0xffff);
} else if (mType == TYPE_WAIT && getMultiModeFromParam() != 0) {
if (getMultiModeFromParam() == 1) {
mOrderEvtNo = EVT_TALK_MULTI;
} else {
mOrderEvtNo = EVT_TALK_MULTI2;
}
changeEvent(l_resNames[l_evtGetParamList[mOrderEvtNo].arcIdx],
l_evtNames[l_evtGetParamList[mOrderEvtNo].fileIdx], 1, 0xffff);
} else if (chkAction(&daNpc_zrA_c::talk)) {
(this->*mpActionFn)(NULL);
} else if (dComIfGp_event_chkTalkXY()) {
if (dComIfGp_evmng_ChkPresentEnd()) {
if (dComIfGp_event_getPreItemNo() == 0x91) {
if (mSoldierType != SOLDIER_NONE) {
if (home.angle.x == 0x6d) {
mFlowID = 4;
} else {
mFlowID = 5;
}
} else {
mFlowID = 6;
}
setAction(&daNpc_zrA_c::talk);
} else {
s16 event_idx =
dComIfGp_getEventManager().getEventIdx(this, "NO_RESPONSE", 0xff);
dComIfGp_getEvent()->reset(this);
fopAcM_orderChangeEventId(this, event_idx, 1, 0xffff);
field_0x9ec = true;
}
}
} else {
setAction(&daNpc_zrA_c::talk);
}
ret = true;
} else {
if (mItemID != -1) {
dComIfGp_event_setItemPartnerId(mItemID);
mItemID = -1;
}
staff_id = event_manager->getMyStaffId(mStaffName, this, 0);
if (staff_id != -1) {
mStaffID = staff_id;
int act_idx = event_manager->getMyActIdx(staff_id, mEvtCutNameList,
ARRAY_SIZEU(mEvtCutNameList), 0, 0);
JUT_ASSERT(0xf0e, act_idx >= 0 && act_idx < 11);
JUT_ASSERT(0xf0f, mEvtCutList[act_idx] != NULL);
if ((this->*mEvtCutList[act_idx])(staff_id)) {
event_manager->cutEnd(staff_id);
}
ret = true;
}
if (eventInfo.checkCommandDemoAccrpt()) {
if (mEventIdx != -1 && event_manager->endCheck(mEventIdx)) {
switch (mOrderEvtNo) {
case EVT_TALK_SWIM:
dComIfGp_event_reset();
setAction(&daNpc_zrA_c::swim);
mOrderEvtNo = 0;
mEventIdx = -1;
mStaffName = l_myName[0];
break;
case EVT_THANKS_BLAST:
case EVT_RESULT_ANNOUNCE:
dComIfGp_event_reset();
mActionSelect = 5;
setAction(&daNpc_zrA_c::returnRiverDescend);
mOrderEvtNo = 0;
mEventIdx = -1;
dComIfGs_offSwitch(mSwitch1, fopAcM_GetRoomNo(this));
dComIfGs_offSwitch(mSwitch2, fopAcM_GetRoomNo(this));
break;
case EVT_CARRY_WATERFALL:
case EVT_CARRY_WATERFALL_NIGHT:
dComIfGp_event_reset();
mActionSelect = 3;
setAction(&daNpc_zrA_c::diveWaterfall);
mOrderEvtNo = 0;
mEventIdx = -1;
break;
default:
dComIfGp_event_reset();
mOrderEvtNo = 0;
mEventIdx = -1;
break;
}
} else {
switch (mOrderEvtNo) {
case EVT_CARRY_WATERFALL:
setSkipZev(EVT_CARRY_WATERFALL, EVT_CARRY_WATERFALL_SKIP);
break;
case EVT_CARRY_WATERFALL_NIGHT:
setSkipZev(EVT_CARRY_WATERFALL_NIGHT, EVT_CARRY_WATERFALL_NIGHT_SKIP);
break;
}
}
}
}
int expression, motion;
int prev_msg_timer = mMsgTimer;
if (ctrlMsgAnm(expression, motion, this, false)) {
if (!field_0x9eb) {
setExpression(expression, -1.0f);
setMotion(motion, -1.0f, false);
}
} else if (!field_0x9eb && prev_msg_timer != 0 && mMsgTimer == 0) {
setExpressionTalkAfter();
}
}
if (!ret) {
if (mStaffID != -1) {
mpActionFn = NULL;
mStaffID = -1;
}
mMsgTimer = 0;
}
return ret;
}
BOOL daNpc_zrA_c::setSkipZev(int i_idx1, int i_idx2) {
if (!strcmp(dComIfGp_getEventManager().getRunEventName(), l_evtNames[i_idx1])) {
dComIfGp_getEvent()->setSkipZev(this, l_evtNames[i_idx2]);
return true;
}
return false;
}
void daNpc_zrA_c::setLookMode(int i_lookMode) {
if (i_lookMode >= 0 && i_lookMode < 6 && i_lookMode != mLookMode) {
mLookMode = i_lookMode;
}
}
void daNpc_zrA_c::lookat() {
fopAc_ac_c* attn_actor = NULL;
J3DModel* model = mAnm_p->getModel();
BOOL snap = false;
f32 body_down_angle = mpHIO->m.common.body_angleX_min;
f32 body_up_angle = mpHIO->m.common.body_angleX_max;
f32 body_right_angle = mpHIO->m.common.body_angleY_min;
f32 body_left_angle = mpHIO->m.common.body_angleY_max;
f32 head_down_angle = mpHIO->m.common.head_angleX_min;
f32 head_up_angle = mpHIO->m.common.head_angleX_max;
f32 head_right_angle = mpHIO->m.common.head_angleY_min;
f32 head_left_angle = mpHIO->m.common.head_angleY_max;
s16 angle_delta = mCurAngle.y - mOldAngle.y;
cXyz lookat_pos[3] = {mLookatPos[0], mLookatPos[1], mLookatPos[2]};
csXyz* lookat_angle[3] = {&mLookatAngle[0], &mLookatAngle[1], &mLookatAngle[2]};
switch (mLookMode) {
case LOOK_RESET:
snap = true;
break;
case LOOK_PLAYER:
case LOOK_PLAYER_TALK:
attn_actor = daPy_getPlayerActorClass();
if (mLookMode == LOOK_PLAYER_TALK) {
head_right_angle = -80.0f;
head_left_angle = 80.0f;
}
break;
case LOOK_ACTOR:
attn_actor = mActorMngr[2].getActorP();
break;
case LOOK_ATTN:
attn_actor = mActorMngr[1].getActorP();
break;
}
if (attn_actor != NULL) {
mLookPos = attn_actor->attention_info.position;
if (mLookMode != LOOK_PLAYER && mLookMode != LOOK_PLAYER_TALK && mLookMode != LOOK_ATTN) {
mLookPos.y -= 40.0f;
}
mLookat.setAttnPos(&mLookPos);
if (mBaseMotionAnm != ANM_WAIT_SWIM && mBaseMotionAnm != ANM_SWIM_TALK
&& mBaseMotionAnm != ANM_TALK_SWIM_SP && mBaseMotionAnm != ANM_WAIT_SWIM_SP)
{
body_up_angle = body_down_angle = 0.0f;
}
} else {
mLookat.setAttnPos(NULL);
}
mLookat.setParam(body_down_angle, body_up_angle, body_right_angle, body_left_angle,
0.0f, 0.0f, 0.0f, 0.0f,
head_down_angle, head_up_angle, head_right_angle, head_left_angle,
mCurAngle.y, lookat_pos);
mLookat.calc(this, model->getBaseTRMtx(), lookat_angle, snap, angle_delta, false);
}
BOOL daNpc_zrA_c::chkFindPlayer() {
BOOL check;
if (mActorMngr[0].getActorP() == NULL) {
check = chkPlayerInSpeakArea(this);
} else {
check = chkPlayerInTalkArea(this);
}
if (check) {
mActorMngr[0].entry(daPy_getPlayerActorClass());
} else {
mActorMngr[0].remove();
}
return check;
}
void daNpc_zrA_c::setExpressionTalkAfter() {
switch (mExpression) {
case EXPR_TALK_NOMAL:
setExpression(EXPR_TALK_NOMAL_2, -1.0f);
break;
case EXPR_LOOKING_SP:
setExpression(EXPR_LOOKING_SP_2, -1.0f);
break;
case EXPR_LOOKUP:
setExpression(EXPR_LOOKUP_2, -1.0f);
break;
case EXPR_SPA_TALK_A:
setExpression(EXPR_SPA_WAIT_A, -1.0f);
break;
case EXPR_SPA_TALK_B:
setExpression(EXPR_SPA_WAIT_B, -1.0f);
break;
default:
setExpression(EXPR_NONE, -1.0f);
break;
}
}
// fakematch to get the clib_calctimer functions to appear in the correct order.
// Perhaps clever inline keyword usage can fix the problem, but this is easier.
int dummy_clib_u8(u8* arg) {
return cLib_calcTimer<u8>(arg);
}
void daNpc_zrA_c::setPrtcl() {
u32 flags = 0x40002;
cXyz ptcl_scale(1.5f, 1.5f, 1.5f);
if (field_0x1550) {
if (cLib_calcTimer(&field_0x1554) != 0) {
flags |= 0x20000;
} else {
field_0x1554 = 10;
}
}
mPaPo.setEffectCenter(&tevStr, &current.pos, 1, flags, NULL, NULL, &ptcl_scale,
fopAcM_GetRoomNo(this), 1.0f, speedF);
}
BOOL daNpc_zrA_c::test(void* param_0) {
switch (mMode) {
case 0:
speedF = 0.0f;
speed.setall(0.0f);
mMode = 2;
// fallthrough
case 2:
if (mpHIO->m.common.face_expression != mExpression) {
setExpression(mpHIO->m.common.face_expression, mpHIO->m.common.morf_frame);
}
setMotion(mpHIO->m.common.motion, mpHIO->m.common.morf_frame, false);
setLookMode(mpHIO->m.common.look_mode);
mOrderEvtNo = EVT_NONE;
attention_info.flags = 0;
break;
case 3:
break;
}
return true;
}
static cPhs_Step daNpc_zrA_Create(void* i_this) {
return static_cast<daNpc_zrA_c*>(i_this)->create();
}
static int daNpc_zrA_Delete(void* i_this) {
return static_cast<daNpc_zrA_c*>(i_this)->Delete();
}
static int daNpc_zrA_Execute(void* i_this) {
return static_cast<daNpc_zrA_c*>(i_this)->Execute();
}
static int daNpc_zrA_Draw(void* i_this) {
return static_cast<daNpc_zrA_c*>(i_this)->Draw();
}
static int daNpc_zrA_IsDelete(void* i_this) {
return 1;
}
#include "d/actor/d_a_npc_zra.inc"
AUDIO_INSTANCES
static actor_method_class daNpc_zrA_MethodTable = {
(process_method_func)daNpc_zrA_Create,
(process_method_func)daNpc_zrA_Delete,
(process_method_func)daNpc_zrA_Execute,
(process_method_func)daNpc_zrA_IsDelete,
(process_method_func)daNpc_zrA_Draw,
};
actor_process_profile_definition g_profile_NPC_ZRA = {
/* Layer ID */ fpcLy_CURRENT_e,
/* List ID */ 3,
/* List Prio */ fpcPi_CURRENT_e,
/* Proc Name */ fpcNm_NPC_ZRA_e,
/* Proc SubMtd */ &g_fpcLf_Method.base,
/* Size */ sizeof(daNpc_zrA_c),
/* Size Other */ 0,
/* Parameters */ 0,
/* Leaf SubMtd */ &g_fopAc_Method.base,
/* Draw Prio */ fpcDwPi_NPC_ZRA_e,
/* Actor SubMtd */ &daNpc_zrA_MethodTable,
/* Status */ fopAcStts_UNK_0x40000_e | fopAcStts_UNK_0x4000_e | fopAcStts_CULL_e,
/* Group */ fopAc_NPC_e,
/* Cull Type */ fopAc_CULLBOX_CUSTOM_e,
};