mirror of
https://github.com/zeldaret/tp
synced 2026-05-23 06:54:28 -04:00
918 lines
28 KiB
C++
918 lines
28 KiB
C++
/**
|
|
* @file d_a_obj_kuwagata.cpp
|
|
*
|
|
*/
|
|
|
|
#include "d/dolzel_rel.h" // IWYU pragma: keep
|
|
|
|
#include "f_op/f_op_camera_mng.h"
|
|
#include "d/actor/d_a_obj_kuwagata.h"
|
|
#include "d/actor/d_a_player.h"
|
|
#include "d/d_cc_d.h"
|
|
#include "d/d_menu_insect.h"
|
|
#include "f_pc/f_pc_name.h"
|
|
|
|
class daObj_KuwHIO_c : public JORReflexible{
|
|
public:
|
|
daObj_KuwHIO_c();
|
|
virtual ~daObj_KuwHIO_c() {}
|
|
|
|
void genMessage(JORMContext* ctx);
|
|
|
|
/* 0x04 */ s8 mId;
|
|
/* 0x08 */ f32 mFemaleModelScale;
|
|
/* 0x0C */ f32 mMaleModelScale;
|
|
};
|
|
|
|
daObj_KuwHIO_c::daObj_KuwHIO_c() {
|
|
mId = -1;
|
|
mMaleModelScale = 1.5f;
|
|
mFemaleModelScale = 1.2f;
|
|
}
|
|
|
|
#if DEBUG
|
|
void daObj_KuwHIO_c::genMessage(JORMContext* ctx) {
|
|
ctx->genLabel("黄金蟲(カブト)", 0x80000001);
|
|
ctx->genSlider("モデルスケール(オス)", &mMaleModelScale, 0.1f, 4.0f);
|
|
ctx->genSlider("モデルスケール(メス)", &mFemaleModelScale, 0.1f, 4.0f);
|
|
}
|
|
#endif
|
|
|
|
void daObjKUW_c::InitCcSph() {
|
|
const static dCcD_SrcSph ccSphSrc = {
|
|
{
|
|
{0x0, {{0x0, 0x0, 0x0}, {0x14002, 0x11}, 0x0}}, // mObj
|
|
{dCcD_SE_STONE, 0x0, 0x0, 0x0, 0x0}, // mGObjAt
|
|
{dCcD_SE_NONE, 0x0, 0x0, 0x0, 0x0}, // mGObjTg
|
|
{0x0}, // mGObjCo
|
|
}, // mObjInf
|
|
{
|
|
{{0.0f, 0.0f, 0.0f}, 40.0f} // mSph
|
|
} // mSphAttr
|
|
};
|
|
|
|
mStts.Init(1, 0, this);
|
|
mSph.Set(ccSphSrc);
|
|
mSph.SetStts(&mStts);
|
|
mSph.SetC(current.pos);
|
|
mSph.OnTgNoHitMark();
|
|
}
|
|
|
|
void daObjKUW_c::SetCcSph() {
|
|
mSph.SetC(current.pos);
|
|
mSph.SetR(20.0f);
|
|
dComIfG_Ccsp()->Set(&mSph);
|
|
}
|
|
|
|
static int useHeapInit(fopAc_ac_c* a_this) {
|
|
daObjKUW_c* i_this = (daObjKUW_c*)a_this;
|
|
return i_this->CreateHeap();
|
|
}
|
|
|
|
int daObjKUW_c::CreateHeap() {
|
|
J3DModelData* modelData;
|
|
|
|
if (mSex == SEX_FEMALE) {
|
|
modelData = (J3DModelData*)dComIfG_getObjectRes("I_Kuw", 10);
|
|
JUT_ASSERT(255, modelData != NULL);
|
|
} else {
|
|
modelData = (J3DModelData*)dComIfG_getObjectRes("I_Kuw", 11);
|
|
JUT_ASSERT(259, modelData != NULL);
|
|
}
|
|
|
|
mpMorf = new mDoExt_McaMorfSO(modelData, NULL, NULL, (J3DAnmTransform*)dComIfG_getObjectRes("I_Kuw", 7), 2, 1.0f, 0, -1, &mSound, 0, 0x11000284);
|
|
|
|
if (mpMorf == NULL || mpMorf->getModel() == NULL) {
|
|
return 0;
|
|
}
|
|
|
|
J3DModel* model = mpMorf->getModel();
|
|
mpBrkAnm = new mDoExt_brkAnm();
|
|
if (mpBrkAnm == NULL) {
|
|
return 0;
|
|
}
|
|
|
|
J3DAnmTevRegKey* brkRes;
|
|
if (mSex == SEX_FEMALE) {
|
|
brkRes = (J3DAnmTevRegKey*)dComIfG_getObjectRes("I_Kuw", 14);
|
|
if (!mpBrkAnm->init(model->getModelData(), brkRes, TRUE, J3DFrameCtrl::EMode_LOOP, 1.0f, 0, -1)) {
|
|
return 0;
|
|
}
|
|
} else {
|
|
brkRes = (J3DAnmTevRegKey*)dComIfG_getObjectRes("I_Kuw", 0xf);
|
|
if (!mpBrkAnm->init(model->getModelData(), brkRes, TRUE, J3DFrameCtrl::EMode_LOOP, 1.0f, 0, -1)) {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
mpBtkAnm = new mDoExt_btkAnm();
|
|
if (mpBtkAnm == NULL) {
|
|
return 0;
|
|
}
|
|
|
|
J3DAnmTextureSRTKey* btkRes;
|
|
if (mSex == SEX_FEMALE) {
|
|
btkRes = (J3DAnmTextureSRTKey*)dComIfG_getObjectRes("I_Kuw", 18);
|
|
if (!mpBtkAnm->init(model->getModelData(), btkRes, TRUE, J3DFrameCtrl::EMode_LOOP, 1.0f, 0, -1)) {
|
|
return 0;
|
|
}
|
|
} else {
|
|
btkRes = (J3DAnmTextureSRTKey*)dComIfG_getObjectRes("I_Kuw", 19);
|
|
if (!mpBtkAnm->init(model->getModelData(), btkRes, TRUE, J3DFrameCtrl::EMode_LOOP, 1.0f, 0, -1)) {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
return 1;
|
|
}
|
|
|
|
static int daObjKUW_Create(fopAc_ac_c* i_this) {
|
|
daObjKUW_c* a_this = (daObjKUW_c*)i_this;
|
|
fopAcM_RegisterCreateID(i_this, "Obj_Kuw");
|
|
return a_this->create();
|
|
}
|
|
|
|
static int daObjKUW_Delete(daObjKUW_c* i_this) {
|
|
fopAcM_RegisterDeleteID(i_this, "Obj_Kuw");
|
|
i_this->Delete();
|
|
return 1;
|
|
}
|
|
|
|
void daObjKUW_c::ShopWaitAction() {
|
|
switch (mSubAction) {
|
|
case 0:
|
|
speedF = 0.0f;
|
|
mpMorf->setAnm((J3DAnmTransform*)dComIfG_getObjectRes("I_Kuw", 7), 2, 5.0f, 0.0f, 0.0f, -1.0f);
|
|
mSubAction++;
|
|
mTimers[0] = cM_rndF(50.0f) + 50.0f;
|
|
break;
|
|
case 1:
|
|
mTimers[0]--;
|
|
if (mTimers[0] <= 0) {
|
|
mTimers[0] = 0;
|
|
}
|
|
|
|
if (mTimers[0] == 0) {
|
|
int randVal = cM_rndF(100.0f);
|
|
if (randVal < 40) {
|
|
mAction = ACTION_WALK;
|
|
mSubAction = 0;
|
|
} else if (randVal < 70) {
|
|
mAction = ACTION_MOVE;
|
|
mSubAction = 0;
|
|
} else {
|
|
mTimers[0] = cM_rndF(50.0f) + 50.0f;
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
void daObjKUW_c::WaitAction() {
|
|
switch (mSubAction) {
|
|
case 0:
|
|
speedF = 0.0f;
|
|
mpMorf->setAnm((J3DAnmTransform*)dComIfG_getObjectRes("I_Kuw", 7), 2, 5.0f, 0.0f, 0.0f, -1.0f);
|
|
mSubAction++;
|
|
mTimers[0] = cM_rndF(50.0f) + 50.0f;
|
|
break;
|
|
case 1:
|
|
if (fopAcM_searchPlayerDistance(this) < 1500.0f) {
|
|
mTimers[0]--;
|
|
if (mTimers[0] <= 0) {
|
|
mTimers[0] = 0;
|
|
}
|
|
|
|
if (mTimers[0] == 0) {
|
|
int randVal = cM_rndF(100.0f);
|
|
if (randVal < 40) {
|
|
mAction = ACTION_WALK;
|
|
mSubAction = 0;
|
|
} else if (randVal < 70) {
|
|
mAction = ACTION_MOVE;
|
|
mSubAction = 0;
|
|
} else {
|
|
mTimers[0] = cM_rndF(50.0f) + 50.0f;
|
|
}
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
BOOL daObjKUW_c::WallCheck() {
|
|
dBgS_LinChk linChk;
|
|
linChk.SetObj();
|
|
|
|
linChk.Set(&old.pos, ¤t.pos, NULL);
|
|
|
|
if (dComIfG_Bgsp().LineCross(&linChk)) {
|
|
cM3dGPla plane;
|
|
dComIfG_Bgsp().GetTriPla(linChk, &plane);
|
|
cXyz* normal = plane.GetNP();
|
|
current.pos = linChk.GetCross();
|
|
|
|
cXyz temp1(0.0f, 0.0f, 0.0f);
|
|
cXyz temp2(0.0f, normal->y, normal->z);
|
|
field_0x99a.z = -cM_atan2s(normal->x, temp1.abs(temp2));
|
|
field_0x99a.x = cM_atan2s(normal->z, normal->y);
|
|
field_0x9a2 = cM_atan2s(normal->x, normal->z);
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
void daObjKUW_c::SpeedSet() {
|
|
speed.y += gravity;
|
|
cXyz cStack_1c(0.0f, speed.y, speedF);
|
|
cXyz local_28(0.0f, 0.0f, 0.0f);
|
|
|
|
mDoMtx_stack_c::ZXYrotS(field_0x99a);
|
|
mDoMtx_stack_c::YrotM(current.angle.y);
|
|
mDoMtx_stack_c::multVec(&cStack_1c, &local_28);
|
|
|
|
current.pos.x += local_28.x;
|
|
current.pos.y += local_28.y;
|
|
current.pos.z += local_28.z;
|
|
|
|
cLib_addCalc2(&speedF, mSpeedFTarget, 0.4f, 10.0f);
|
|
cLib_addCalc2(&speed.y, mSpeedYTarget, 0.1f, 0.5f);
|
|
cLib_addCalcAngleS2(¤t.angle.y, mAngleTarget, 0x10, 0x100);
|
|
shape_angle.y = current.angle.y;
|
|
}
|
|
|
|
void daObjKUW_c::WallWalk() {
|
|
cXyz cStack_13c(0.0f, -100.0f, 3.0f * speedF);
|
|
cXyz cStack_148(0.0f, 40.0f, 0.0f);
|
|
cXyz cStack_154(0.0f, 20.0f, 100.0f);
|
|
cXyz cStack_160;
|
|
|
|
dBgS_LinChk linChk;
|
|
dBgS_LinChk linChk2;
|
|
|
|
linChk.SetObj();
|
|
linChk2.SetObj();
|
|
|
|
mDoMtx_stack_c::transS(current.pos);
|
|
mDoMtx_stack_c::ZXYrotM(field_0x99a);
|
|
mDoMtx_stack_c::YrotM(current.angle.y);
|
|
mDoMtx_stack_c::multVec(&cStack_13c, &cStack_13c);
|
|
mDoMtx_stack_c::multVec(&cStack_148, &cStack_148);
|
|
|
|
linChk.Set(&cStack_148, &cStack_13c, NULL);
|
|
|
|
if (dComIfG_Bgsp().LineCross(&linChk)) {
|
|
speedF = 0.3f;
|
|
|
|
cM3dGPla plane;
|
|
dComIfG_Bgsp().GetTriPla(linChk, &plane);
|
|
cXyz* normal = plane.GetNP();
|
|
|
|
s16 angleZ = cM_atan2s(normal->x, normal->z);
|
|
|
|
cXyz temp1(0.0f, 0.0f, 0.0f);
|
|
cXyz temp2(0.0f, normal->y, normal->z);
|
|
f32 normalLen = temp1.abs(temp2);
|
|
|
|
cStack_160 = linChk.GetCross();
|
|
|
|
int angleDiff = angleZ - field_0x9a2;
|
|
|
|
if (angleDiff < 0x1000 && angleDiff > -0x1000 && cStack_160.abs(old.pos) < speedF * 3.0f) {
|
|
current.pos = cStack_160;
|
|
field_0x9a2 = angleZ;
|
|
field_0x99a.z = -cM_atan2s(normal->x, normalLen);
|
|
field_0x99a.x = cM_atan2s(normal->z, normal->y);
|
|
} else {
|
|
mAngleTarget += 0x100;
|
|
}
|
|
} else {
|
|
mAngleTarget += 0x100;
|
|
}
|
|
|
|
cLib_addCalcAngleS2(¤t.angle.y, mAngleTarget, 0x10, 0x50);
|
|
shape_angle.y = current.angle.y;
|
|
}
|
|
|
|
void daObjKUW_c::WalkAction() {
|
|
for (int i = 0; i < 3; i++) {
|
|
mTimers[i]--;
|
|
if (mTimers[i] <= 0) {
|
|
mTimers[i] = 0;
|
|
}
|
|
}
|
|
|
|
switch (mSubAction) {
|
|
case 0:
|
|
mpMorf->setAnm((J3DAnmTransform*)dComIfG_getObjectRes("I_Kuw", 7), 2, 5.0f, 1.0f, 0.0f, -1.0f);
|
|
mSpeedFTarget = 0.5f;
|
|
speed.y = 0.0f;
|
|
mSpeedYTarget = 0.0f;
|
|
mSubAction++;
|
|
mTimers[1] = cM_rndF(50.0f) + 50.0f;
|
|
break;
|
|
case 1:
|
|
if (mTimers[0] == 0) {
|
|
cXyz targetDir(cM_rndFX(100.0f), 0.0f, cM_rndFX(100.0f));
|
|
mAngleTarget = cM_atan2s(targetDir.x, targetDir.z);
|
|
mTimers[0] = cM_rndF(50.0f) + 50.0f;
|
|
}
|
|
|
|
if (mTimers[1] == 0) {
|
|
int randVal = cM_rndF(100.0f);
|
|
|
|
if (randVal < 30) {
|
|
mAction = ACTION_MOVE;
|
|
mSubAction = 0;
|
|
} else if (randVal < 60) {
|
|
mAction = ACTION_WAIT;
|
|
mSubAction = 0;
|
|
} else {
|
|
mTimers[1] = cM_rndF(50.0f) + 50.0f;
|
|
}
|
|
}
|
|
}
|
|
|
|
WallWalk();
|
|
}
|
|
|
|
void daObjKUW_c::MoveAction() {
|
|
for (int i = 0; i < 3; i++) {
|
|
mTimers[i]--;
|
|
if (mTimers[i] <= 0) {
|
|
mTimers[i] = 0;
|
|
}
|
|
}
|
|
|
|
cXyz cStack_ac;
|
|
cXyz cStack_b8(0.0f, 1.0f, 0.0f);
|
|
dBgS_LinChk linChk;
|
|
daPy_py_c* playerActor = daPy_getPlayerActorClass();
|
|
linChk.SetObj();
|
|
cXyz local_c4;
|
|
cXyz cStack_d0;
|
|
|
|
switch (mSubAction) {
|
|
case 0:
|
|
mpMorf->setAnm((J3DAnmTransform*)dComIfG_getObjectRes("I_Kuw", 6), 2, 5.0f, 0.0f, 0.0f, -1.0f);
|
|
mSubAction++;
|
|
mTimers[0] = 20;
|
|
break;
|
|
case 1:
|
|
if (mTimers[0] == 10) {
|
|
mpMorf->setPlaySpeed(1.0f);
|
|
}
|
|
if (mTimers[0] == 0) {
|
|
mSubAction++;
|
|
mDoMtx_stack_c::ZXYrotS(field_0x99a);
|
|
mDoMtx_stack_c::multVec(&cStack_b8, &cStack_b8);
|
|
mTimers[0] = cM_rndF(30.0f) + 10.0f;
|
|
|
|
if (field_0x9c0 == 0) {
|
|
mTimers[1] = cM_rndF(80.0f) + 80.0f;
|
|
} else {
|
|
mTimers[1] = cM_rndF(50.0f) + 50.0f;
|
|
}
|
|
|
|
mSpeedFTarget = cM_rndF(5.0f) + 8.0f;
|
|
mAngleTarget = field_0x9a2;
|
|
mSpeedYTarget = 3.0f;
|
|
speed.y = 5.0f;
|
|
}
|
|
break;
|
|
case 2:
|
|
cXyz* flamePos = playerActor->getKandelaarFlamePos();
|
|
if (flamePos != NULL) {
|
|
mAngleTarget = cLib_targetAngleY(¤t.pos, flamePos);
|
|
|
|
if (flamePos->abs(current.pos) < 200.0f && speed.y < 0.0f) {
|
|
cLib_addCalcAngleS2(¤t.angle.y, mAngleTarget, 2, 0x500);
|
|
} else {
|
|
cLib_addCalcAngleS2(¤t.angle.y, mAngleTarget, 0x10, 0x200);
|
|
}
|
|
|
|
if (flamePos->abs(current.pos) < 11.0f && fopAcM_GetSpeedF(playerActor) < 1.0f) {
|
|
local_c4.set(0.0f, 0.0f, 10.0f);
|
|
if (field_0x9c2 == 0) {
|
|
field_0x9a2 = cLib_targetAngleY(¤t.pos, flamePos);
|
|
}
|
|
|
|
cLib_offsetPos(&cStack_d0, flamePos, field_0x9a2, &local_c4);
|
|
current.pos = cStack_d0;
|
|
shape_angle.x = 0x4000;
|
|
shape_angle.y = field_0x9a2;
|
|
speedF = 0.0f;
|
|
mSpeedFTarget = 0.0f;
|
|
speed.y = 0.0f;
|
|
mSpeedYTarget = 0.0f;
|
|
mpMorf->setPlaySpeed(0.0f);
|
|
mAngleTarget = 0;
|
|
current.angle.y = field_0x9a2;
|
|
field_0x9c2 = 1;
|
|
mpMorf->setAnm((J3DAnmTransform*)dComIfG_getObjectRes("I_Kuw", 7), 2, 5.0f, 1.0f, 0.0f, -1.0f);
|
|
} else {
|
|
if (field_0x9c2 != 0) {
|
|
field_0x9c2 = 0;
|
|
mSpeedYTarget = 3.0f;
|
|
speed.y = 3.0f;
|
|
speedF = 8.0f;
|
|
mSpeedFTarget = 8.0f;
|
|
mpMorf->setPlaySpeed(1.0f);
|
|
field_0x9a2 = 0;
|
|
mpMorf->setAnm((J3DAnmTransform*)dComIfG_getObjectRes("I_Kuw", 6), 2, 5.0f, 1.0f, 0.0f, -1.0f);
|
|
}
|
|
}
|
|
}
|
|
|
|
if (mTimers[0] == 0) {
|
|
if (flamePos == NULL) {
|
|
local_c4 = home.pos - current.pos;
|
|
local_c4.x += cM_rndFX(1050.0f);
|
|
local_c4.z += cM_rndFX(1050.0f);
|
|
mAngleTarget = cM_atan2s(local_c4.x, local_c4.z);
|
|
}
|
|
mTimers[0] = cM_rndF(20.0f) + 20.0f;
|
|
mSpeedFTarget = cM_rndF(5.0f) + 8.0f;
|
|
}
|
|
|
|
if (mTimers[1] == 0) {
|
|
mSpeedYTarget = -cM_rndF(3.0f);
|
|
mTimers[1] = cM_rndF(20.0f) + 20.0f;
|
|
}
|
|
|
|
mpMorf->getFrame();
|
|
SpeedSet();
|
|
|
|
if (field_0x9c0 == 0) {
|
|
cLib_addCalcAngleS2(&field_0x99a.x, 0, 0x10, 0x1000);
|
|
cLib_addCalcAngleS2(&field_0x99a.z, 0, 0x10, 0x1000);
|
|
} else {
|
|
cLib_addCalcAngleS2(&field_0x99a.x, 0, 0x10, 0x100);
|
|
cLib_addCalcAngleS2(&field_0x99a.z, 0, 0x10, 0x100);
|
|
}
|
|
|
|
if (WallCheck()) {
|
|
mAction = ACTION_WAIT;
|
|
mSubAction = 0;
|
|
speedF = 0.0f;
|
|
speed.y = 0.0f;
|
|
shape_angle.x = 0;
|
|
shape_angle.z = 0;
|
|
}
|
|
|
|
if (field_0x9c0 == 1) {
|
|
cLib_addCalcAngleS2(¤t.angle.y, mAngleTarget, 0x10, 0x100);
|
|
}
|
|
|
|
if (field_0x9c2 == 0) {
|
|
cLib_chaseAngleS(&shape_angle.x, 0, 0x400);
|
|
}
|
|
break;
|
|
}
|
|
|
|
if (mpMorf->getPlaySpeed() == 1.0f) {
|
|
mSound.startCreatureSoundLevel(Z2SE_INSCT_BTBT, 0, -1);
|
|
}
|
|
}
|
|
|
|
void daObjKUW_c::Action() {
|
|
switch (mAction) {
|
|
case ACTION_WAIT:
|
|
WaitAction();
|
|
break;
|
|
case ACTION_WALK:
|
|
WalkAction();
|
|
mSound.startCreatureSoundLevel(Z2SE_INSCT_KSKS, 0, -1);
|
|
break;
|
|
case ACTION_MOVE:
|
|
MoveAction();
|
|
break;
|
|
}
|
|
Insect_GetDemoMain();
|
|
mSound.startCreatureSoundLevel(Z2SE_INSCT_KIRA, 0, -1);
|
|
}
|
|
|
|
void daObjKUW_c::ShopAction() {
|
|
switch (mAction) {
|
|
case ACTION_WAIT:
|
|
ShopWaitAction();
|
|
break;
|
|
case ACTION_WALK:
|
|
WalkAction();
|
|
mSound.startCreatureSoundLevel(Z2SE_INSCT_KSKS, 0, -1);
|
|
break;
|
|
case ACTION_MOVE:
|
|
MoveAction();
|
|
break;
|
|
}
|
|
mSound.startCreatureSoundLevel(Z2SE_INSCT_KIRA, 0, -1);
|
|
}
|
|
|
|
void daObjKUW_c::Insect_Release() {
|
|
field_0x56c = 1;
|
|
mSubAction = 0;
|
|
mAction = ACTION_MOVE;
|
|
}
|
|
|
|
static u8 const l_kuw_itemno[2] = {
|
|
fpcNm_ITEM_M_STAG_BEETLE, fpcNm_ITEM_F_STAG_BEETLE,
|
|
};
|
|
|
|
static f32 dummyFloat() { return -9.0f; }
|
|
|
|
void daObjKUW_c::Z_BufferChk() {
|
|
cXyz local_5c;
|
|
cXyz cStack_68;
|
|
|
|
cStack_68 = current.pos;
|
|
cStack_68.y += 20.0f;
|
|
mDoLib_project(&cStack_68, &local_5c);
|
|
|
|
camera_class* cc = dComIfGp_getCamera(0);
|
|
f32 trimHeight;
|
|
if (cc != NULL) {
|
|
trimHeight = cc->mCamera.TrimHeight();
|
|
} else {
|
|
trimHeight = 0.0f;
|
|
}
|
|
|
|
if (local_5c.x > 0.0f && local_5c.x < FB_WIDTH &&
|
|
local_5c.y > trimHeight && local_5c.y < FB_HEIGHT - trimHeight) {
|
|
dComIfGd_peekZ(local_5c.x, local_5c.y, &field_0x9bc);
|
|
}
|
|
|
|
view_class* view = dComIfGd_getView();
|
|
f32 nearPlane = view->near;
|
|
f32 farPlane = view->far;
|
|
|
|
mDoLib_pos2camera(&cStack_68, &local_5c);
|
|
local_5c.z += 50.0f;
|
|
if (local_5c.z > 0.0f) {
|
|
local_5c.z = 0.0f;
|
|
}
|
|
|
|
field_0x9b8 = ((nearPlane + ((farPlane * nearPlane) / local_5c.z)) / (farPlane - nearPlane) + 1.0f) * 16777215.0f;
|
|
}
|
|
|
|
void daObjKUW_c::ParticleSet() {
|
|
if (field_0x9b8 > (f32)field_0x9bc) {
|
|
cLib_addCalc2(&mParticleScale, 0.0f, 1.0f, 1.0f);
|
|
} else {
|
|
cLib_addCalc2(&mParticleScale, mParticleScaleTarget, 1.0f, 1.0f);
|
|
}
|
|
|
|
mParticleKey1 = dComIfGp_particle_set(mParticleKey1, 0xa1b, ¤t.pos, &tevStr, &shape_angle,
|
|
0, 0xff, 0, -1, 0, 0, 0);
|
|
|
|
f32 emitterScale = mParticleScale;
|
|
JPABaseEmitter* emitter = dComIfGp_particle_getEmitter(mParticleKey1);
|
|
if (emitter != NULL) {
|
|
emitter->setGlobalParticleScale(emitterScale, emitterScale);
|
|
}
|
|
}
|
|
|
|
void daObjKUW_c::BoomChk() {
|
|
if (field_0x9c1 != 0) {
|
|
daPy_py_c* playerActor = daPy_getPlayerActorClass();
|
|
cXyz* playerPos = fopAcM_GetPosition_p(playerActor);
|
|
home.pos = current.pos;
|
|
cXyz targetPos = *playerPos;
|
|
targetPos.y += 100.0f;
|
|
|
|
if (mBoomerangMove.posMove(¤t.pos, &shape_angle.y, NULL, 0x1c00)) {
|
|
mBoomerangMove.bgCheckAfterOffset(¤t.pos);
|
|
current.pos.y += 0.5f;
|
|
} else {
|
|
dBgS_LinChk linChk;
|
|
linChk.SetObj();
|
|
linChk.Set(&targetPos, ¤t.pos, NULL);
|
|
|
|
if (dComIfG_Bgsp().LineCross(&linChk)) {
|
|
cM3dGPla plane;
|
|
dComIfG_Bgsp().GetTriPla(linChk, &plane);
|
|
current.pos = old.pos = linChk.GetCross();
|
|
mAction = ACTION_WAIT;
|
|
mSubAction = 0;
|
|
cXyz* normal = plane.GetNP();
|
|
current.pos = linChk.GetCross();
|
|
cXyz temp1(0.0f, 0.0f, 0.0f);
|
|
cXyz temp2(0.0f, normal->y, normal->z);
|
|
field_0x99a.z = -cM_atan2s(normal->x, temp1.abs(temp2));
|
|
field_0x99a.x = cM_atan2s(normal->z, normal->y);
|
|
field_0x9a2 = cM_atan2s(normal->x, normal->z);
|
|
} else {
|
|
mAction = ACTION_MOVE;
|
|
mSubAction = 2;
|
|
J3DAnmTransform* anm = (J3DAnmTransform*)dComIfG_getObjectRes("I_Kuw", 6);
|
|
mpMorf->setAnm(anm, 2, 5.0f, 1.0f, 0.0f, -1.0f);
|
|
speedF = 8.0f;
|
|
mSpeedFTarget = cM_rndF(5.0f) + 8.0f;
|
|
home.pos = current.pos;
|
|
mSpeedYTarget = 5.0f;
|
|
speed.y = 5.0f;
|
|
mTimers[0] = 50;
|
|
current.pos.y += 50.0f;
|
|
mTimers[1] = cM_rndF(5.0f) + 5.0f;
|
|
current.pos.y = old.pos.y = playerPos->y + 100.0f;
|
|
}
|
|
|
|
field_0x9c1 = 0;
|
|
}
|
|
}
|
|
}
|
|
|
|
void daObjKUW_c::ObjHit() {
|
|
if (mSph.ChkTgHit()) {
|
|
cCcD_ObjHitInf* hitObj = mSph.GetTgHitObj();
|
|
if (hitObj->ChkAtType(AT_TYPE_BOOMERANG)) {
|
|
if (field_0x9c1 == 0) {
|
|
field_0x9c1 = 1;
|
|
mBoomerangMove.initOffset(¤t.pos, mSph.GetTgHitGObj());
|
|
}
|
|
} else if (!hitObj->ChkAtType(AT_TYPE_NORMAL_SWORD) && hitObj->ChkAtType(AT_TYPE_HOOKSHOT)) {
|
|
cXyz catchPos(0.0f, 0.0f, 0.0f);
|
|
daPy_py_c* playerActor = daPy_getPlayerActorClass();
|
|
u32 actorId = fopAcM_GetID(this);
|
|
playerActor->setHookshotCarryOffset(actorId, &catchPos);
|
|
mAction = ACTION_MOVE;
|
|
mSubAction = 2;
|
|
field_0x9c1 = 0;
|
|
mpMorf->setAnm((J3DAnmTransform*)dComIfG_getObjectRes("I_Kuw", 6), 2, 5.0f, 1.0f, 0.0f, -1.0f);
|
|
speedF = 8.0f;
|
|
mSpeedFTarget = cM_rndF(5.0f) + 8.0f;
|
|
mTimers[1] = cM_rndF(5.0f) + 5.0f;
|
|
}
|
|
|
|
mSph.ClrTgHit();
|
|
}
|
|
}
|
|
|
|
int daObjKUW_c::Execute() {
|
|
if (ChkGetDemo()) {
|
|
field_0x9b8 = field_0x9bc + 10000.0f;
|
|
mSound.startCreatureSoundLevel(Z2SE_INSCT_KIRA, 0, -1);
|
|
Insect_GetDemoMain();
|
|
ParticleSet();
|
|
return 1;
|
|
}
|
|
|
|
daPy_getPlayerActorClass();
|
|
attention_info.position = current.pos;
|
|
eyePos = current.pos;
|
|
eyePos.y += 10.0f;
|
|
|
|
switch (field_0x9c0) {
|
|
case 0:
|
|
if (!fopAcM_checkHookCarryNow(this)) {
|
|
Action();
|
|
} else {
|
|
home.pos = current.pos;
|
|
}
|
|
|
|
mParticleKey2 = dComIfGp_particle_set(mParticleKey2, 0xa1c, ¤t.pos, &tevStr, &shape_angle, 0, 0xff, 0, -1, 0, 0, 0);
|
|
SetCcSph();
|
|
ObjHit();
|
|
BoomChk();
|
|
eyePos = current.pos;
|
|
eyePos.y += 10.0f;
|
|
attention_info.position = eyePos;
|
|
attention_info.position.y += 10.0f;
|
|
ParticleSet();
|
|
break;
|
|
case 1:
|
|
ShopAction();
|
|
break;
|
|
}
|
|
|
|
if (mAction == ACTION_MOVE && mSubAction == 2 && speed.y < 0.0f) {
|
|
mAcch.CrrPos(dComIfG_Bgsp());
|
|
}
|
|
|
|
mpBrkAnm->play();
|
|
mpBtkAnm->play();
|
|
mpMorf->play(0, dComIfGp_getReverb(fopAcM_GetRoomNo(this)));
|
|
setBaseMtx();
|
|
return 1;
|
|
}
|
|
|
|
static bool hio_set;
|
|
|
|
static daObj_KuwHIO_c l_HIO;
|
|
|
|
int daObjKUW_c::Delete() {
|
|
dComIfG_resDelete(&mPhase, "I_Kuw");
|
|
if (mIsHIOOwner) {
|
|
hio_set = false;
|
|
mDoHIO_DELETE_CHILD(l_HIO.mId);
|
|
}
|
|
|
|
if (heap != NULL) {
|
|
mpMorf->stopZelAnime();
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
void daObjKUW_c::setBaseMtx() {
|
|
mDoMtx_stack_c::transS(current.pos);
|
|
mDoMtx_stack_c::ZXYrotM(field_0x99a);
|
|
mDoMtx_stack_c::ZXYrotM(shape_angle);
|
|
mDoMtx_stack_c::scaleM(scale);
|
|
mpMorf->getModel()->setBaseTRMtx( mDoMtx_stack_c::get());
|
|
mpMorf->modelCalc();
|
|
}
|
|
|
|
int daObjKUW_c::Draw() {
|
|
if (mDraw) {
|
|
Z_BufferChk();
|
|
J3DModel* model = mpMorf->getModel();
|
|
g_env_light.settingTevStruct(0x10, ¤t.pos, &tevStr);
|
|
g_env_light.setLightTevColorType_MAJI(model, &tevStr);
|
|
mpBtkAnm->entry(model->getModelData());
|
|
mpBrkAnm->entry(model->getModelData());
|
|
mpMorf->entryDL();
|
|
if (field_0x9c0 == 0) {
|
|
dComIfGd_setSimpleShadow(¤t.pos, mAcch.GetGroundH(), 15.0f, mAcch.m_gnd, 0, -0.6f, dDlst_shadowControl_c::getSimpleTex());
|
|
}
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
static int daObjKUW_Draw(daObjKUW_c* i_this) {
|
|
return i_this->Draw();
|
|
}
|
|
|
|
static int daObjKUW_Execute(daObjKUW_c* i_this) {
|
|
return i_this->Execute();
|
|
}
|
|
|
|
static u16 const l_musiya_num[2] = { 0x195, 0x196 };
|
|
|
|
bool daObjKUW_c::CreateChk() {
|
|
u8 type = (fopAcM_GetParam(this) & 0xf00) >> 8;
|
|
if (type == 0xf) {
|
|
type = 0;
|
|
}
|
|
|
|
if (field_0x9c0 != 2) {
|
|
if (type != 0) {
|
|
if (!dComIfGs_isEventBit(dSv_event_flag_c::saveBitLabels[l_musiya_num[0]]) || !dComIfGs_isEventBit(dSv_event_flag_c::saveBitLabels[l_musiya_num[1]])) {
|
|
return false;
|
|
}
|
|
} else {
|
|
if (strcmp("R_SP160", dComIfGp_getStartStageName()) == 0 && dComIfGp_getStartStageRoomNo() == 3) {
|
|
if (dMenu_Insect_c::isCatchNotGiveInsect(l_kuw_itemno[mSex])) {
|
|
return false;
|
|
}
|
|
|
|
if ((mSex == SEX_MALE && !dComIfGs_isEventBit(dSv_event_flag_c::saveBitLabels[l_musiya_num[mSex]])) ||
|
|
(mSex == SEX_FEMALE && !dComIfGs_isEventBit(dSv_event_flag_c::saveBitLabels[l_musiya_num[mSex]]))) {
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
int daObjKUW_c::create() {
|
|
fopAcM_ct(this, daObjKUW_c);
|
|
int rv = dComIfG_resLoad(&mPhase, "I_Kuw");
|
|
if (rv == cPhs_COMPLEATE_e) {
|
|
OS_REPORT("KUW PARAM %x\n", fopAcM_GetParam(this));
|
|
field_0x9c0 = fopAcM_GetParam(this) & 0xf;
|
|
if (field_0x9c0 == 2) {
|
|
field_0x56c = 0;
|
|
shape_angle.x -= 0x2000;
|
|
fopAcM_OnStatus(this, fopAcM_STATUS_UNK_0x4000);
|
|
} else {
|
|
mDraw = 1;
|
|
}
|
|
|
|
attention_info.distances[fopAc_attn_CARRY_e] = 93;
|
|
mSex = (fopAcM_GetParam(this) & 0x10) >> 4;
|
|
setItemNo(l_kuw_itemno[mSex]);
|
|
setSaveBitNo(l_musiya_num[mSex]);
|
|
if (mSex == SEX_FEMALE) {
|
|
scale.set(l_HIO.mFemaleModelScale, l_HIO.mFemaleModelScale, l_HIO.mFemaleModelScale);
|
|
mParticleScaleTarget = 1.0f;
|
|
} else if (mSex == SEX_MALE) {
|
|
scale.set(l_HIO.mMaleModelScale, l_HIO.mMaleModelScale, l_HIO.mMaleModelScale);
|
|
mParticleScaleTarget = 1.1f;
|
|
}
|
|
|
|
if (!CreateChk()) {
|
|
return cPhs_ERROR_e;
|
|
}
|
|
|
|
if (!fopAcM_entrySolidHeap(this, useHeapInit, 0xb50)) {
|
|
return cPhs_ERROR_e;
|
|
}
|
|
|
|
if (!hio_set) {
|
|
hio_set = true;
|
|
mIsHIOOwner = true;
|
|
l_HIO.mId = mDoHIO_CREATE_CHILD("黄金蟲(クワガタ)", &l_HIO);
|
|
}
|
|
|
|
mAction = ACTION_WAIT;
|
|
mSubAction = 1;
|
|
gravity = 0.0f;
|
|
bool bVar4 = false;
|
|
cXyz cStack_ec(0.0f, 0.0f, 500.0f);
|
|
cXyz cStack_f8(0.0f, 0.0f, -200.0f);
|
|
cXyz cStack_104;
|
|
cXyz cStack_110;
|
|
dBgS_LinChk linChk;
|
|
linChk.SetObj();
|
|
|
|
for (int i = 0; i < 4; i++) {
|
|
cLib_offsetPos(&cStack_104, ¤t.pos, shape_angle.y + (i << 14), &cStack_ec);
|
|
cLib_offsetPos(&cStack_110, ¤t.pos, shape_angle.y + (i << 14), &cStack_f8);
|
|
linChk.Set(&cStack_110, &cStack_104, NULL);
|
|
linChk.SetObj();
|
|
if (dComIfG_Bgsp().LineCross(&linChk)) {
|
|
cM3dGPla plane;
|
|
dComIfG_Bgsp().GetTriPla(linChk, &plane);
|
|
cXyz* normal = plane.GetNP();
|
|
current.pos = linChk.GetCross();
|
|
cXyz cStack_11c(0.0f, 0.0f, 0.0f);
|
|
cXyz cStack_128(0.0f, normal->y, normal->z);
|
|
field_0x99a.z = -cM_atan2s(normal->x, cStack_11c.abs(cStack_128));
|
|
field_0x99a.x = cM_atan2s(normal->z, normal->y);
|
|
field_0x9a2 = cM_atan2s(normal->x, normal->z);
|
|
bVar4 = true;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (!bVar4) {
|
|
cStack_ec.set(0.0f, 500.0f, 0.0f);
|
|
cStack_104.set(0.0f, -1000.0f, 0.0f);
|
|
linChk.Set(&cStack_ec, &cStack_104, NULL);
|
|
linChk.SetObj();
|
|
if (dComIfG_Bgsp().LineCross(&linChk)) {
|
|
cM3dGPla plane;
|
|
dComIfG_Bgsp().GetTriPla(linChk, &plane);
|
|
cXyz* normal = plane.GetNP();
|
|
current.pos = linChk.GetCross();
|
|
cXyz cStack_134(0.0f, 0.0f, 0.0f);
|
|
cXyz cStack_140(0.0f, normal->y, normal->z);
|
|
field_0x99a.z = -cM_atan2s(normal->x, cStack_134.abs(cStack_140));
|
|
field_0x99a.x = cM_atan2s(normal->z, normal->y);
|
|
field_0x9a2 = cM_atan2s(normal->x, normal->z);
|
|
}
|
|
}
|
|
|
|
if (field_0x9c0 == 0) {
|
|
InitCcSph();
|
|
}
|
|
|
|
if (field_0x9c0 == 2) {
|
|
if (strcmp("R_SP160", dComIfGp_getStartStageName()) != 0 ||
|
|
dComIfGp_getStartStageRoomNo() != 3)
|
|
{
|
|
InitCcSph();
|
|
}
|
|
}
|
|
|
|
mAcch.Set(fopAcM_GetPosition_p(this), fopAcM_GetOldPosition_p(this), this, 1, &mAcchCir,
|
|
fopAcM_GetSpeed_p(this), NULL, NULL);
|
|
fopAcM_SetMtx(this, mpMorf->getModel()->getBaseTRMtx());
|
|
fopAcM_SetMin(this, -50.0f, -50.0f, -50.0f);
|
|
fopAcM_SetMax(this, 50.0f, 50.0f, 50.0f);
|
|
mSound.init(¤t.pos, &eyePos, 3, 1);
|
|
daObjKUW_Execute(this);
|
|
}
|
|
return rv;
|
|
}
|
|
|
|
static int daObjKUW_IsDelete(daObjKUW_c* param_0) {
|
|
return 1;
|
|
}
|
|
|
|
static actor_method_class l_daObjKUW_Method = {
|
|
(process_method_func)daObjKUW_Create,
|
|
(process_method_func)daObjKUW_Delete,
|
|
(process_method_func)daObjKUW_Execute,
|
|
(process_method_func)daObjKUW_IsDelete,
|
|
(process_method_func)daObjKUW_Draw,
|
|
};
|
|
|
|
actor_process_profile_definition g_profile_Obj_Kuw = {
|
|
fpcLy_CURRENT_e, // mLayerID
|
|
7, // mListID
|
|
fpcPi_CURRENT_e, // mListPrio
|
|
PROC_Obj_Kuw, // mProcName
|
|
&g_fpcLf_Method.base, // sub_method
|
|
sizeof(daObjKUW_c), // mSize
|
|
0, // mSizeOther
|
|
0, // mParameters
|
|
&g_fopAc_Method.base, // sub_method
|
|
479, // mPriority
|
|
&l_daObjKUW_Method, // sub_method
|
|
0x000C0100, // mStatus
|
|
fopAc_ENV_e, // mActorType
|
|
fopAc_CULLBOX_CUSTOM_e, // cullType
|
|
};
|