/** * @file d_a_npc_zelR.cpp * */ #include "d/dolzel_rel.h" // IWYU pragma: keep #include "d/actor/d_a_npc_zelR.h" enum RES_Name { /* 0x0 */ NONE, /* 0x1 */ ZELRF, }; static daNpc_GetParam1 l_bmdData[1] = { {10, 1} }; static daNpcT_evtData_c l_evtList[2] = { {"", 0}, {"NO_RESPONSE", 0} }; static char* l_resNameList[2] = { "", "zelRf" }; static s8 l_loadResPtrn0[2] = { 1, -1 }; static s8* l_loadResPtrnList[2] = { l_loadResPtrn0, l_loadResPtrn0, }; static daNpcT_faceMotionAnmData_c l_faceMotionAnmData[2] = { {-1, 0, 0, 16, 2, 1, 1}, {6, 0, 1, 16, 2, 1, 1} }; static daNpcT_motionAnmData_c l_motionAnmData = { 7, 2, 1, 13, 0, 1, 1, 0 }; static daNpcT_MotionSeqMngr_c::sequenceStepData_c l_faceMotionSequenceData[8] = { {1, -1, 1}, {-1, 0, 0}, {-1, 0, 0}, {-1, 0, 0}, {0, -1, 0}, {-1, 0, 0}, {-1, 0, 0}, {-1, 0, 0} }; static daNpcT_MotionSeqMngr_c::sequenceStepData_c l_motionSequenceData[4] = { {0, -1, 0}, {-1, 0, 0}, {-1, 0, 0}, {-1, 0, 0} }; char* daNpc_ZelR_c::mCutNameList = ""; daNpc_ZelR_c::EventFn daNpc_ZelR_c::mCutList[1] = { NULL }; daNpc_ZelR_c::~daNpc_ZelR_c() { OS_REPORT("|%06d:%x|daNpc_ZelR_c -> デストラクト\n", g_Counter.mCounter0, this); if (heap) { mpMorf[0]->stopZelAnime(); } deleteRes(l_loadResPtrnList[mType], (char const**)l_resNameList); } static daNpc_ZelR_Param_c l_HIO; daNpc_ZelR_HIOParam const daNpc_ZelR_Param_c::m = { 190.0f, -3.0f, 1.0f, 400.0f, 255.0f, 170.0f, 35.0f, 30.0f, 0.0f, 0.0f, 10.0f, -10.0f, 30.0f, -10.0f, 45.0f, -45.0f, 0.6f, 12.0f, 3, 6, 5, 6, 0.0f, 0.0f, 0.0f, 0.0f, 0x3C, 8, 0, 0, 0, false, false, 4.0f, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f, }; int daNpc_ZelR_c::create() { daNpcT_ct(this, daNpc_ZelR_c, l_faceMotionAnmData, &l_motionAnmData, l_faceMotionSequenceData, 4, l_motionSequenceData, 4, l_evtList, l_resNameList); mType = getType(); mFlowNodeNo = getFlowNodeNo(); mTwilight = false; int phaseState = loadRes(l_loadResPtrnList[mType], (const char**)l_resNameList); if (phaseState == cPhs_COMPLEATE_e) { if (!fopAcM_entrySolidHeap(this, createHeapCallBack, 0x5cd0)) { OS_REPORT("===>isDelete:TRUE\n"); return cPhs_ERROR_e; } OS_REPORT("\t(%s:%d) flowNo:%d, PathID:%02x<%08x> ", fopAcM_getProcNameString(this), mType, mFlowNodeNo, getPath(), fopAcM_GetParam(this)); if (isDelete()) { OS_REPORT("===>isDelete:TRUE\n"); return cPhs_ERROR_e; } J3DModelData* modelData = mpMorf[0]->getModel()->getModelData(); fopAcM_SetMtx(this, mpMorf[0]->getModel()->getBaseTRMtx()); fopAcM_setCullSizeBox(this, -300.0f, -50.0f, -300.0f, 300.0f, 450.0f, 300.0f); fopAcM_OnStatus(this, 0x8000000); mSound.init(¤t.pos, &eyePos, 3, 1); mAcch.Set(¤t.pos, &old.pos, this, 1, &mAcchCir, &speed, ¤t.angle, &shape_angle); mAcch.CrrPos(dComIfG_Bgsp()); mGndChk = mAcch.m_gnd; mGroundH = mAcch.GetGroundH(); setEnvTevColor(); setRoomNo(); mCcStts.Init(daNpc_ZelR_Param_c::m.common.weight, 0, this); mCyl.Set(mCcDCyl); mCyl.SetStts(&mCcStts); mCyl.SetTgHitCallback(tgHitCallBack); reset(); mCreating = true; Execute(); mCreating = false; } return phaseState; } int daNpc_ZelR_c::CreateHeap() { int bmdIdx = mTwilight == true ? NONE : NONE; J3DModelData* mdlData_p = (J3DModelData*)(dComIfG_getObjectRes( l_resNameList[l_bmdData[bmdIdx].arcIdx], l_bmdData[bmdIdx].fileIdx )); JUT_ASSERT(0x1b0, NULL != mdlData_p); mpMorf[0] = new mDoExt_McaMorfSO(mdlData_p, NULL, NULL, NULL, -1, 1.0f, 0, -1, &mSound, 0, 0x11020284); if (mpMorf[0] != NULL && mpMorf[0]->getModel() == NULL) { mpMorf[0]->stopZelAnime(); mpMorf[0] = NULL; } if (mpMorf[0] == NULL) { return 0; } J3DModel* model = mpMorf[0]->getModel(); for (u16 i = 0; i < mdlData_p->getJointNum(); i++) { mdlData_p->getJointNodePointer(i)->setCallBack(ctrlJointCallBack); } model->setUserArea((uintptr_t)this); for (int i = 0; i < 2; i++) { mpMatAnm[i] = new daNpcT_MatAnm_c(); if (mpMatAnm[i] == NULL) { return 0; } } if (setFaceMotionAnm(1, false) && setMotionAnm(0, 0.0f, 0) != 0) { return 1; } return 0; } int daNpc_ZelR_c::Delete() { fopAcM_GetID(this); this->~daNpc_ZelR_c(); return 1; } int daNpc_ZelR_c::Execute() { return execute(); } int daNpc_ZelR_c::Draw() { J3DModel* model = mpMorf[0]->getModel(); J3DModelData* modelData = model->getModelData(); if (mpMatAnm[0]) { modelData->getMaterialNodePointer(getEyeballLMaterialNo())->setMaterialAnm(mpMatAnm[0]); } if (mpMatAnm[1]) { modelData->getMaterialNodePointer(getEyeballRMaterialNo())->setMaterialAnm(mpMatAnm[1]); } return daNpcT_c::draw(0, 1, mRealShadowSize, NULL, 100.0f, 0, 0, 0); } int daNpc_ZelR_c::createHeapCallBack(fopAc_ac_c* a_this) { daNpc_ZelR_c* i_this = (daNpc_ZelR_c*)a_this; return i_this->CreateHeap(); } int daNpc_ZelR_c::ctrlJointCallBack(J3DJoint* i_joint, int param_2) { if (!param_2) { daNpc_ZelR_c* i_this = (daNpc_ZelR_c*)j3dSys.getModel()->getUserArea(); if (i_this) { i_this->ctrlJoint(i_joint, j3dSys.getModel()); } } return 1; } u8 daNpc_ZelR_c::getType() { switch (fopAcM_GetParam(this) & 0xff) { case 0: return TYPE_0; default: return TYPE_1; } } u32 daNpc_ZelR_c::getFlowNodeNo() { u16 nodeNo = home.angle.x; if (nodeNo == 0xffff) { return -1; } return nodeNo; } u8 daNpc_ZelR_c::getPath() { return (fopAcM_GetParam(this) & 0xff00) >> 8; } int daNpc_ZelR_c::isDelete() { if (mType == TYPE_1) { return 0; } switch (mType) { case TYPE_0: return daNpcT_chkEvtBit(0x2d) != 0; default: return 1; } } void daNpc_ZelR_c::reset() { initialize(); memset(&field_0xf84, 0, ((u8*)&field_0xfc4 - (u8*)&field_0xf84)); for (int i = 0; i < 2; i++) { if (mpMatAnm[i]) { mpMatAnm[i]->initialize(); } } if (getPath() != 0xff) { mPath.initialize(); mPath.setPathInfo(getPath(), fopAcM_GetRoomNo(this), 0); } setAngle(home.angle.y); } void daNpc_ZelR_c::afterJntAnm(int param_1) { if (param_1 == 1) { mDoMtx_stack_c::YrotM(mStagger.getAngleZ(1)); mDoMtx_stack_c::ZrotM(-mStagger.getAngleX(1)); } else if (param_1 == 3) { mDoMtx_stack_c::YrotM(mStagger.getAngleZ(0)); mDoMtx_stack_c::ZrotM(-mStagger.getAngleX(0)); } } BOOL daNpc_ZelR_c::ctrlBtk() { if (mpMatAnm[0] && mpMatAnm[1]) { if (field_0xe29 && mBtkAnm.getBtkAnm()) { mpMatAnm[0]->setNowOffsetX(cM_ssin(mJntAnm.getEyeAngleY()) * 0.2f * -1.0f); mpMatAnm[0]->setNowOffsetY(cM_ssin(mJntAnm.getEyeAngleX()) * 0.2f); mpMatAnm[1]->setNowOffsetX(cM_ssin(mJntAnm.getEyeAngleY()) * 0.2f); mpMatAnm[1]->setNowOffsetY(cM_ssin(mJntAnm.getEyeAngleX()) * 0.2f); mpMatAnm[0]->onEyeMoveFlag(); mpMatAnm[1]->onEyeMoveFlag(); return TRUE; } if (field_0xe2a) { mpMatAnm[0]->setMorfFrm(field_0xe2a); mpMatAnm[1]->setMorfFrm(field_0xe2a); field_0xe2a = 0; } mpMatAnm[0]->offEyeMoveFlag(); mpMatAnm[1]->offEyeMoveFlag(); } return FALSE; } void daNpc_ZelR_c::setParam() { selectAction(); srchActors(); s16 sVar1 = l_HIO.m.common.talk_distance; s16 sVar2 = l_HIO.m.common.talk_angle; s16 sVar3 = l_HIO.m.common.attention_distance; s16 sVar4 = l_HIO.m.common.attention_angle; attention_info.distances[0] = daNpcT_getDistTableIdx(sVar3, sVar4); attention_info.distances[1] = attention_info.distances[0]; attention_info.distances[3] = daNpcT_getDistTableIdx(sVar1, sVar2); attention_info.flags = fopAc_AttnFlag_SPEAK_e | fopAc_AttnFlag_TALK_e; scale.setall(l_HIO.m.common.scale); mCcStts.SetWeight(l_HIO.m.common.weight); mCylH = l_HIO.m.common.height; mWallR = l_HIO.m.common.width; mAcchCir.SetWallR(mWallR); mAcchCir.SetWallH(l_HIO.m.common.knee_length); mRealShadowSize = l_HIO.m.common.real_shadow_size; gravity = l_HIO.m.common.gravity; mExpressionMorfFrame = l_HIO.m.common.expression_morf_frame; mMorfFrames = l_HIO.m.common.morf_frame; } void daNpc_ZelR_c::setAfterTalkMotion() { mFaceMotionSeqMngr.setNo(1, -1.0f, 0, 0); } void daNpc_ZelR_c::srchActors() { /* empty function */ } BOOL daNpc_ZelR_c::evtTalk() { if (chkAction(&daNpc_ZelR_c::talk)) { (this->*field_0xf90)(NULL); } else { mPreItemNo = 0; if (dComIfGp_event_chkTalkXY()) { if (!dComIfGp_evmng_ChkPresentEnd()) { return TRUE; } else { mEvtNo = 1; evtChange(); return TRUE; } } else { setAction(&daNpc_ZelR_c::talk); } } return TRUE; } BOOL daNpc_ZelR_c::evtCutProc() { BOOL rv = FALSE; int staffId = dComIfGp_getEventManager().getMyStaffId("ZelR", this, -1); if (staffId != -1) { mStaffId = staffId; int actIdx = dComIfGp_getEventManager().getMyActIdx(mStaffId, &mCutNameList, 1, 0, 0); if ((this->*(mCutList[actIdx]))(mStaffId)) { dComIfGp_getEventManager().cutEnd(mStaffId); } rv = TRUE; } return rv; } void daNpc_ZelR_c::action() { fopAc_ac_c* hitActor = hitChk(&mCyl, 0xffffffff); if (hitActor) { mStagger.setParam(this, hitActor, mCurAngle.y); setDamage(0, 1, 0); mStagger.setPower(0.0f); mDamageTimerStart = 0; } if (mStagger.checkRebirth()) { mStagger.initialize(); mMode = 1; } if (field_0xf84) { if (field_0xf90 == field_0xf84) { (this->*field_0xf90)(NULL); } else { setAction(field_0xf84); } } } void daNpc_ZelR_c::beforeMove() { if (checkHide() || mNoDraw) { attention_info.flags = 0; } } void daNpc_ZelR_c::setAttnPos() { cXyz sp38(10.0f, -30.0f, 0.0f); mStagger.calc(FALSE); mJntAnm.setParam(this, mpMorf[0]->getModel(), &sp38, getBackboneJointNo(), getNeckJointNo(), getHeadJointNo(), l_HIO.m.common.body_angleX_min, l_HIO.m.common.body_angleX_max, l_HIO.m.common.body_angleY_min, l_HIO.m.common.body_angleY_max, l_HIO.m.common.head_angleX_min, l_HIO.m.common.head_angleX_max, l_HIO.m.common.head_angleY_min, l_HIO.m.common.head_angleY_max, l_HIO.m.common.neck_rotation_ratio, 0.0f, NULL); mJntAnm.calcJntRad(0.2f, 1.0f, cM_s2rad(mCurAngle.y - field_0xd7e.y)); setMtx(); mDoMtx_stack_c::copy(mpMorf[0]->getModel()->getAnmMtx(getHeadJointNo())); mDoMtx_stack_c::multVec(&sp38, &eyePos); mJntAnm.setEyeAngleX(eyePos, 1.0f, 0); mJntAnm.setEyeAngleY(eyePos, mCurAngle.y, 0, 1.0f, 0); attention_info.position = current.pos; attention_info.position.y += l_HIO.m.common.attention_offset; } void daNpc_ZelR_c::setCollision() { if (!mHide) { if (mTwilight == 1 && !dComIfGp_event_runCheck()) { mCyl.SetCoSPrm(0x69); } else { mCyl.SetCoSPrm(0x79); } if (mStagger.checkStagger()) { mCyl.SetTgType(0); mCyl.SetTgSPrm(0); } else { mCyl.SetTgType(0xd8fbfdff); mCyl.SetTgSPrm(0x1f); mCyl.OnTgNoHitMark(); } f32 cylH = mCylH; f32 wallR = mWallR; cXyz sp28 = current.pos; mCyl.SetH(cylH); mCyl.SetR(wallR); mCyl.SetC(sp28); dComIfG_Ccsp()->Set(&mCyl); } mCyl.ClrCoHit(); mCyl.ClrTgHit(); } int daNpc_ZelR_c::drawDbgInfo() { return 0; } int daNpc_ZelR_c::selectAction() { field_0xf84 = NULL; field_0xf84 = &daNpc_ZelR_c::wait; return 1; } int daNpc_ZelR_c::chkAction(int (daNpc_ZelR_c::*param_1)(void*)) { return field_0xf90 == param_1; } int daNpc_ZelR_c::setAction(int (daNpc_ZelR_c::*param_1)(void*)) { mMode = 3; if (field_0xf90) { (this->*field_0xf90)(NULL); } mMode = 0; field_0xf90 = param_1; if (field_0xf90) { (this->*field_0xf90)(NULL); } return 1; } int daNpc_ZelR_c::wait(void* param_1) { switch (mMode) { case 0: case 1: mFaceMotionSeqMngr.setNo(1, -1.0f, 0, 0); mMotionSeqMngr.setNo(0, -1.0f, 0, 0); mMode = 2; case 2: if (!mStagger.checkStagger()) { BOOL bVar1; if (srchPlayerActor()) { mJntAnm.lookPlayer(0); bVar1 = checkStep(); } else { mJntAnm.lookNone(0); bVar1 = home.angle.y != mCurAngle.y; } if (bVar1 && step(home.angle.y, -1, -1, 15, 0)) { mMode = 1; } } case 3: default: return 1; } } BOOL daNpc_ZelR_c::talk(void* param_1) { BOOL bVar2 = FALSE; switch (mMode) { case 0: case 1: initTalk(mFlowNodeNo, NULL); mMode = 2; case 2: if (mTwilight) { bVar2 = TRUE; } else { mJntAnm.lookPlayer(0); if (mCurAngle.y != fopAcM_searchPlayerAngleY(this)) { step(fopAcM_searchPlayerAngleY(this), -1, -1, 15, 0); } else { bVar2 = TRUE; } } if (bVar2 && talkProc(NULL, 0, NULL, 0)) { mPlayerActorMngr.entry(daPy_getPlayerActorClass()); dComIfGp_event_reset(); mMode = 3; } case 3: default: return FALSE; } } static int daNpc_ZelR_Create(void* a_this) { return static_cast(a_this)->create(); } static int daNpc_ZelR_Delete(void* a_this) { return static_cast(a_this)->Delete(); } static int daNpc_ZelR_Execute(void* a_this) { return static_cast(a_this)->Execute(); } static int daNpc_ZelR_Draw(void* a_this) { return static_cast(a_this)->Draw(); } static int daNpc_ZelR_IsDelete(void* a_this) { return 1; } static actor_method_class daNpc_ZelR_MethodTable = { (process_method_func)daNpc_ZelR_Create, (process_method_func)daNpc_ZelR_Delete, (process_method_func)daNpc_ZelR_Execute, (process_method_func)daNpc_ZelR_IsDelete, (process_method_func)daNpc_ZelR_Draw, }; extern actor_process_profile_definition g_profile_NPC_ZELR = { fpcLy_CURRENT_e, // mLayerID 7, // mListID fpcPi_CURRENT_e, // mListPrio PROC_NPC_ZELR, // mProcName &g_fpcLf_Method.base, // sub_method sizeof(daNpc_ZelR_c), // mSize 0, // mSizeOther 0, // mParameters &g_fopAc_Method.base, // sub_method 385, // mPriority &daNpc_ZelR_MethodTable, // sub_method 0x00044108, // mStatus fopAc_NPC_e, // mActorType fopAc_CULLBOX_CUSTOM_e, // cullType };