mirror of
https://github.com/zeldaret/tww.git
synced 2026-06-27 18:12:58 -04:00
+32
-16
@@ -25,19 +25,19 @@ public:
|
||||
void WorkCo(fopAc_ac_c*, u32, int);
|
||||
void WorkAt_NoCutAnim(fopAc_ac_c*, u32, int, dCcMassS_HitInf*, cCcD_Obj*);
|
||||
void WorkAt(fopAc_ac_c*, u32, int, dCcMassS_HitInf*);
|
||||
void hitCheck(fopAc_ac_c*, int);
|
||||
BOOL hitCheck(fopAc_ac_c*, int);
|
||||
void animation(int);
|
||||
|
||||
/* 0x000 */ u8 field_0x000;
|
||||
/* 0x000 */ u8 mState;
|
||||
/* 0x001 */ u8 field_0x001;
|
||||
/* 0x002 */ u8 mAnimIdx;
|
||||
/* 0x003 */ s8 field_0x003;
|
||||
/* 0x002 */ s8 mAnimIdx;
|
||||
/* 0x003 */ u8 field_0x003;
|
||||
/* 0x004 */ cXyz mPos;
|
||||
/* 0x010 */ Mtx field_0x010;
|
||||
/* 0x040 */ Mtx field_0x040;
|
||||
/* 0x070 */ Mtx field_0x070;
|
||||
/* 0x0A0 */ Mtx mShadowMtx;
|
||||
/* 0x0D0 */ u8 field_0x0D0[0x100 - 0x0D0];
|
||||
/* 0x0D0 */ Mtx field_0x0d0;
|
||||
/* 0x100 */ dTree_data_c* mpNext;
|
||||
|
||||
static dPa_smokeEcallBack mSmokeEcallback;
|
||||
@@ -48,10 +48,10 @@ public:
|
||||
~dTree_anm_c();
|
||||
dTree_anm_c();
|
||||
|
||||
/* 0x00 */ u8 field_0x00[0x02 - 0x00];
|
||||
/* 0x00 */ u8 mState;
|
||||
/* 0x02 */ s16 field_0x02;
|
||||
/* 0x04 */ s16 field_0x04;
|
||||
/* 0x06 */ u8 field_0x06[0x08 - 0x06];
|
||||
/* 0x06 */ s16 field_0x06;
|
||||
/* 0x08 */ s16 field_0x08;
|
||||
/* 0x0A */ s16 field_0x0a;
|
||||
/* 0x0C */ f32 mAnimTimer;
|
||||
@@ -61,7 +61,7 @@ public:
|
||||
/* 0x1C */ f32 field_0x1c;
|
||||
/* 0x20 */ f32 field_0x20;
|
||||
/* 0x24 */ Mtx field_0x24;
|
||||
/* 0x54 */ u8 field_0x54[0x84 - 0x54];
|
||||
/* 0x54 */ Mtx field_0x54;
|
||||
};
|
||||
|
||||
class dTree_room_c {
|
||||
@@ -71,7 +71,9 @@ public:
|
||||
void newData(dTree_data_c*);
|
||||
void deleteData();
|
||||
|
||||
/* 0x0 */ dTree_data_c* mpHead;
|
||||
dTree_data_c* getData() { return mpData; }
|
||||
|
||||
/* 0x0 */ dTree_data_c* mpData;
|
||||
};
|
||||
|
||||
class dTree_packet_c : public J3DPacket {
|
||||
@@ -81,22 +83,36 @@ public:
|
||||
void calc();
|
||||
void update();
|
||||
void setData(dTree_data_c*, int, cXyz&, u8, int);
|
||||
void newData(cXyz&, u8, int);
|
||||
void newAnm(s16);
|
||||
dTree_data_c* newData(cXyz&, u8, int);
|
||||
s32 newAnm(s16);
|
||||
void setAnm(int, s16);
|
||||
void deleteRoom(s32 roomNo) { mRoom[roomNo].deleteData(); }
|
||||
void deleteAnm(int idx) { mAnm[idx].mState = 0; }
|
||||
|
||||
dTree_anm_c* getAnm() { return mAnm; }
|
||||
dTree_anm_c& getAnm(int idx) { return mAnm[idx]; }
|
||||
dTree_data_c* getData() { return mData; }
|
||||
|
||||
void setPlayerCutFlg(int i_flg) { mPlayerCutFlg = i_flg; }
|
||||
void setPlayerSwordTop(cXyz& i_pos) { mPlayerSwordTop = i_pos; }
|
||||
void setPlayerSwordMoveAngY(s16 i_ang) { mPlayerSwordMoveAngY = i_ang; }
|
||||
cXyz& getPlayerSwordTop() { return mPlayerSwordTop; }
|
||||
void setPlayerSwordAngY(s16 i_ang) { mPlayerSwordAngY = i_ang;}
|
||||
s16 getPlayerSwordMoveAngY() { return mPlayerSwordMoveAngY; }
|
||||
|
||||
int getNum() {}
|
||||
|
||||
virtual void draw();
|
||||
virtual ~dTree_packet_c();
|
||||
|
||||
/* 0x0010 */ s16 field_0x0010;
|
||||
/* 0x0010 */ u16 mNextIdx;
|
||||
/* 0x0014 */ dTree_data_c mData[64];
|
||||
/* 0x4114 */ dTree_anm_c mAnm[72];
|
||||
/* 0x6634 */ dTree_room_c mRoom[64];
|
||||
/* 0x6734 */ u8 field_0x6734;
|
||||
/* 0x6736 */ s16 field_0x6736;
|
||||
/* 0x6738 */ s16 field_0x6738;
|
||||
/* 0x673C */ cXyz field_0x673c;
|
||||
/* 0x6734 */ u8 mPlayerCutFlg;
|
||||
/* 0x6736 */ s16 mPlayerSwordAngY;
|
||||
/* 0x6738 */ s16 mPlayerSwordMoveAngY;
|
||||
/* 0x673C */ cXyz mPlayerSwordTop;
|
||||
};
|
||||
|
||||
#endif /* D_TREE_H */
|
||||
|
||||
+536
-37
@@ -1,12 +1,10 @@
|
||||
//
|
||||
// Generated by dtk
|
||||
// Translation Unit: d_tree.cpp
|
||||
//
|
||||
|
||||
#include "d/dolzel.h" // IWYU pragma: keep
|
||||
#include "d/d_tree.h"
|
||||
#include "dolphin/types.h"
|
||||
|
||||
#include "d/actor/d_a_player.h"
|
||||
#include "dolphin/gf/GF.h"
|
||||
#include "SSystem/SComponent/c_counter.h"
|
||||
#include "m_Do/m_Do_lib.h"
|
||||
#include "f_op/f_op_overlap_mng.h"
|
||||
|
||||
#include "assets/l_Txa_swood_aTEX.h"
|
||||
const u16 l_Txa_swood_aTEX__width = 64;
|
||||
@@ -163,61 +161,299 @@ g_dTree_shadowMatDL(l_Txa_kage_32TEX);
|
||||
const u32 g_dTree_Oba_kage_32DL_SIZE = sizeof(g_dTree_Oba_kage_32DL);
|
||||
const u32 g_dTree_shadowMatDL_SIZE = sizeof(g_dTree_shadowMatDL);
|
||||
|
||||
dPa_smokeEcallBack dTree_data_c::mSmokeEcallback(1, 1, 0, 1);
|
||||
static bool l_CutSoundFlag;
|
||||
|
||||
/* 800787BC-80078960 .text WorkCo__12dTree_data_cFP10fopAc_ac_cUli */
|
||||
void dTree_data_c::WorkCo(fopAc_ac_c*, u32, int) {
|
||||
/* Nonmatching */
|
||||
// NONMATCHING - small float regalloc
|
||||
void dTree_data_c::WorkCo(fopAc_ac_c* i_actor, u32, int) {
|
||||
if (field_0x001) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (mAnimIdx < 8) {
|
||||
dTree_anm_c& anm = dComIfGp_getTree()->getAnm(mAnimIdx);
|
||||
s32 newAnm = dComIfGp_getTree()->newAnm(anm.field_0x02);
|
||||
if (newAnm < 0) {
|
||||
return;
|
||||
}
|
||||
mAnimIdx = newAnm;
|
||||
}
|
||||
|
||||
cXyz vel;
|
||||
vel.x = mPos.x - i_actor->current.pos.x;
|
||||
vel.y = mPos.y - i_actor->current.pos.y;
|
||||
vel.z = mPos.z - i_actor->current.pos.z;
|
||||
vel.abs2XZ();
|
||||
|
||||
dTree_anm_c& anm = dComIfGp_getTree()->getAnm(mAnimIdx);
|
||||
|
||||
s16 angle = cM_atan2s(vel.x, vel.z);
|
||||
f32 cos = cM_scos(i_actor->current.angle.y - angle);
|
||||
if (cos > 0.9f && fopAcM_GetName(i_actor) == fpcNm_PLAYER_e) {
|
||||
((daPy_py_c*)i_actor)->onFrollCrashFlg(7);
|
||||
}
|
||||
|
||||
f32 var_f1 = cLib_maxLimit(std::abs(i_actor->speedF * 50.0f), 4000.0f);
|
||||
if (std::fabsf(anm.mAnimTimer) < std::fabsf(var_f1 * cos)) {
|
||||
anm.mAnimTimer = var_f1 * cos;
|
||||
anm.field_0x0a = angle;
|
||||
}
|
||||
}
|
||||
|
||||
/* 80078960-80078CC0 .text WorkAt_NoCutAnim__12dTree_data_cFP10fopAc_ac_cUliP15dCcMassS_HitInfP8cCcD_Obj */
|
||||
void dTree_data_c::WorkAt_NoCutAnim(fopAc_ac_c*, u32, int, dCcMassS_HitInf*, cCcD_Obj*) {
|
||||
/* Nonmatching */
|
||||
void dTree_data_c::WorkAt_NoCutAnim(fopAc_ac_c* i_actor, u32, int i_roomNo, dCcMassS_HitInf* i_hitInf, cCcD_Obj* i_hitObj) {
|
||||
if (field_0x001) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (mAnimIdx < 8) {
|
||||
dTree_anm_c& anm = dComIfGp_getTree()->getAnm(mAnimIdx);
|
||||
s32 newAnm = dComIfGp_getTree()->newAnm(anm.field_0x02);
|
||||
if (newAnm < 0) {
|
||||
return;
|
||||
}
|
||||
mAnimIdx = newAnm;
|
||||
}
|
||||
|
||||
dCcD_GObjInf* hitObjInf = dCcD_GetGObjInf(i_hitObj);
|
||||
cXyz vel = *hitObjInf->GetAtVecP();
|
||||
f32 mag = vel.absXZ();
|
||||
|
||||
if (cM3d_IsZero(mag)) {
|
||||
if (fopAcM_GetName(i_actor) == fpcNm_PLAYER_e) {
|
||||
vel.x = mPos.x - i_actor->current.pos.x;
|
||||
vel.y = mPos.y - i_actor->current.pos.y;
|
||||
vel.z = mPos.z - i_actor->current.pos.z;
|
||||
mag = vel.absXZ();
|
||||
} else if (fopAcM_GetName(i_actor) == fpcNm_BOMB_e || fopAcM_GetName(i_actor) == fpcNm_Bomb2_e) {
|
||||
vel.x = mPos.x - i_actor->current.pos.x;
|
||||
vel.y = mPos.y - i_actor->current.pos.y;
|
||||
vel.z = mPos.z - i_actor->current.pos.z;
|
||||
mag = 200.0f - vel.absXZ();
|
||||
if (mag < 0.0f) {
|
||||
mag = 0.0f;
|
||||
}
|
||||
|
||||
VECNormalize(&vel, &vel);
|
||||
VECScale(&vel, &vel, mag);
|
||||
}
|
||||
}
|
||||
|
||||
dTree_anm_c& anm = dComIfGp_getTree()->getAnm(mAnimIdx);
|
||||
|
||||
s16 var_r30 = cM_atan2s(vel.x, vel.z);
|
||||
f32 var_f0 = mag * 50.0f;
|
||||
f32 anm_timer = var_f0 > 4000.0f ? 4000.0f : var_f0;
|
||||
if (std::fabsf(anm.mAnimTimer) < std::fabsf(anm_timer)) {
|
||||
anm.mAnimTimer = anm_timer;
|
||||
anm.field_0x0a = var_r30;
|
||||
}
|
||||
}
|
||||
|
||||
/* 80078CC0-80078ED4 .text WorkAt__12dTree_data_cFP10fopAc_ac_cUliP15dCcMassS_HitInf */
|
||||
void dTree_data_c::WorkAt(fopAc_ac_c*, u32, int, dCcMassS_HitInf*) {
|
||||
/* Nonmatching */
|
||||
void dTree_data_c::WorkAt(fopAc_ac_c* i_actor, u32 param_1, int i_roomNo, dCcMassS_HitInf* i_hitInf) {
|
||||
cCcD_Obj* hitObj = i_hitInf->GetAtHitObj();
|
||||
if (hitObj != NULL && (hitObj->ChkAtType(AT_TYPE_WIND) ||
|
||||
hitObj->ChkAtType(AT_TYPE_BOMB) ||
|
||||
hitObj->ChkAtType(AT_TYPE_FIRE) ||
|
||||
hitObj->ChkAtType(AT_TYPE_NORMAL_ARROW) ||
|
||||
hitObj->ChkAtType(AT_TYPE_FIRE_ARROW) ||
|
||||
hitObj->ChkAtType(AT_TYPE_ICE_ARROW) ||
|
||||
hitObj->ChkAtType(AT_TYPE_LIGHT_ARROW) ||
|
||||
hitObj->ChkAtType(AT_TYPE_HOOKSHOT)))
|
||||
{
|
||||
WorkAt_NoCutAnim(i_actor, param_1, i_roomNo, i_hitInf, hitObj);
|
||||
} else {
|
||||
cXyz vel;
|
||||
vel.x = mPos.x - i_actor->current.pos.x;
|
||||
vel.y = mPos.y - i_actor->current.pos.y;
|
||||
vel.z = mPos.z - i_actor->current.pos.z;
|
||||
vel.abs2XZ();
|
||||
|
||||
s16 var_r30 = cM_atan2s(vel.x, vel.z);
|
||||
|
||||
if (field_0x001) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (mAnimIdx < 8) {
|
||||
dTree_anm_c& anm = dComIfGp_getTree()->getAnm(mAnimIdx);
|
||||
s32 newAnm = dComIfGp_getTree()->newAnm(anm.field_0x02);
|
||||
if (newAnm < 0) {
|
||||
return;
|
||||
}
|
||||
mAnimIdx = newAnm;
|
||||
}
|
||||
|
||||
field_0x001 = 1;
|
||||
dTree_packet_c* tree = dComIfGp_getTree();
|
||||
dTree_anm_c& anm = tree->getAnm(mAnimIdx);
|
||||
anm.field_0x0a = tree->mPlayerSwordMoveAngY;
|
||||
anm.mAnimTimer = 0.0f;
|
||||
anm.field_0x10 = -2.0f;
|
||||
anm.field_0x14 = 12.0f;
|
||||
|
||||
Mtx m;
|
||||
MTXScale(m, 0.4f, 1.0f, 0.4f);
|
||||
MTXConcat(mShadowMtx, m, mShadowMtx);
|
||||
|
||||
if (!l_CutSoundFlag) {
|
||||
l_CutSoundFlag = true;
|
||||
mDoAud_seStart(JA_SE_OBJ_CUT_TREE_DOWN, &mPos, 0, dComIfGp_getReverb(i_roomNo));
|
||||
}
|
||||
|
||||
dComIfGp_getVibration().StartShock(4, -0x21, cXyz(0.0f, 1.0f, 0.0f));
|
||||
}
|
||||
}
|
||||
|
||||
/* 80078ED4-80078FA8 .text hitCheck__12dTree_data_cFP10fopAc_ac_ci */
|
||||
void dTree_data_c::hitCheck(fopAc_ac_c*, int) {
|
||||
/* Nonmatching */
|
||||
BOOL dTree_data_c::hitCheck(fopAc_ac_c*, int i_roomNo) {
|
||||
fopAc_ac_c* actor = NULL;
|
||||
dCcMassS_HitInf hitInf;
|
||||
u32 ret = dComIfG_Ccsp()->ChkMass(&mPos, &actor, &hitInf);
|
||||
|
||||
if (ret == 0 || actor == NULL) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (ret & 2)
|
||||
WorkCo(actor, ret, i_roomNo);
|
||||
if (ret & 1)
|
||||
WorkAt(actor, ret, i_roomNo, &hitInf);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* 80078FA8-8007945C .text animation__12dTree_data_cFi */
|
||||
void dTree_data_c::animation(int) {
|
||||
/* Nonmatching */
|
||||
// NONMATCHING - small float math issues
|
||||
void dTree_data_c::animation(int i_roomNo) {
|
||||
dTree_anm_c& anm = dComIfGp_getTree()->getAnm(mAnimIdx);
|
||||
|
||||
if (!field_0x001) {
|
||||
anm.mAnimTimer += anm.field_0x08 * -1.0f;
|
||||
anm.mAnimTimer *= 0.9f;
|
||||
anm.field_0x08 += (s16)anm.mAnimTimer;
|
||||
|
||||
if (anm.field_0x08 * anm.mAnimTimer >= 0.0f) {
|
||||
f32 var_f0 = std::fabsf(anm.mAnimTimer);
|
||||
if (var_f0 < 40.0f) {
|
||||
anm.field_0x08 = 0;
|
||||
anm.mAnimTimer = 0.0f;
|
||||
|
||||
int idx = (anm.field_0x02 >> 13) & 7;
|
||||
dTree_anm_c& anm2 = dComIfGp_getTree()->getAnm(idx);
|
||||
if (cLib_chaseAngleS(&anm.field_0x04, anm2.field_0x04, 800)
|
||||
&& cLib_chaseAngleS(&anm.field_0x06, anm2.field_0x06, 800))
|
||||
{
|
||||
dComIfGp_getTree()->deleteAnm(mAnimIdx);
|
||||
mAnimIdx = idx;
|
||||
}
|
||||
} else if (var_f0 > 400.0f) {
|
||||
cXyz pos(mPos.x, mPos.y + 203.0f, mPos.z);
|
||||
dComIfGp_particle_setSimple(dPa_name::ID_IT_JN_O_HAPPA01, &pos);
|
||||
mDoAud_seStart(JA_SE_OBJ_TREE_SWING, &mPos, 0, dComIfGp_getReverb(i_roomNo));
|
||||
}
|
||||
}
|
||||
|
||||
anm.field_0x04 = anm.field_0x08;
|
||||
} else {
|
||||
f32 var_f0 = anm.field_0x10 * cM_ssin(anm.field_0x0a);
|
||||
f32 var_f0_2 = anm.field_0x10 * cM_scos(anm.field_0x0a);
|
||||
|
||||
anm.field_0x14 += -2.0f;
|
||||
if (anm.field_0x14 < -40.0f) {
|
||||
anm.field_0x14 = -40.0f;
|
||||
}
|
||||
|
||||
anm.field_0x18 += var_f0;
|
||||
anm.field_0x20 += var_f0_2;
|
||||
anm.field_0x1c += anm.field_0x14;
|
||||
|
||||
if (anm.field_0x1c < -5.0f) {
|
||||
anm.field_0x1c = -5.0f;
|
||||
anm.field_0x10 = 0.0f;
|
||||
}
|
||||
|
||||
cLib_chaseF(&anm.mAnimTimer, 1500.0f, 40.0f);
|
||||
|
||||
if (anm.field_0x04 != 13600) {
|
||||
if (cLib_chaseAngleS(&anm.field_0x04, 13600, anm.mAnimTimer)) {
|
||||
static cXyz l_particleOffset(0.0f, 150.0f, 0.0f);
|
||||
static cXyz l_scale(1.6f, 1.6f, 1.6f);
|
||||
|
||||
cXyz sp18;
|
||||
MTXMultVec(anm.field_0x24, &l_particleOffset, &sp18);
|
||||
|
||||
JPABaseEmitter* emitter = dComIfGp_particle_setToon(0x2022, &sp18, NULL, &l_scale, 0xAA, &mSmokeEcallback, i_roomNo, NULL, NULL, NULL);
|
||||
if (emitter != NULL) {
|
||||
emitter->setRate(20.0f);
|
||||
emitter->setSpread(1.0f);
|
||||
emitter->setDirectionalSpeed(15.0f);
|
||||
emitter->setLifeTime(60);
|
||||
emitter->setMaxFrame(1);
|
||||
}
|
||||
|
||||
sp18.y -= 50.0f;
|
||||
dComIfGp_particle_set(0x3df, &sp18);
|
||||
}
|
||||
} else if (anm.field_0x10 == 0.0f) {
|
||||
mState |= 8;
|
||||
MTXCopy(anm.field_0x24, field_0x070);
|
||||
field_0x070[0][3] = mPos.x + anm.field_0x18;
|
||||
field_0x070[1][3] = mPos.y + anm.field_0x1c;
|
||||
field_0x070[2][3] = mPos.z + anm.field_0x20;
|
||||
|
||||
dComIfGp_getTree()->deleteAnm(mAnimIdx);
|
||||
mAnimIdx = (anm.field_0x02 >> 13) & 7;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/* 8007945C-8007946C .text newData__12dTree_room_cFP12dTree_data_c */
|
||||
void dTree_room_c::newData(dTree_data_c*) {
|
||||
/* Nonmatching */
|
||||
void dTree_room_c::newData(dTree_data_c* i_data) {
|
||||
i_data->mpNext = mpData;
|
||||
mpData = i_data;
|
||||
}
|
||||
|
||||
/* 8007946C-800794D0 .text deleteData__12dTree_room_cFv */
|
||||
void dTree_room_c::deleteData() {
|
||||
/* Nonmatching */
|
||||
while (mpData != NULL) {
|
||||
mpData->mState = 0;
|
||||
mDoAud_seDeleteObject(&mpData->mPos);
|
||||
mpData = mpData->mpNext;
|
||||
}
|
||||
}
|
||||
|
||||
/* 800794D0-800795E8 .text __ct__14dTree_packet_cFv */
|
||||
dTree_packet_c::dTree_packet_c() {
|
||||
/* Nonmatching */
|
||||
dTree_data_c* data = getData();
|
||||
for (s32 i = 0; i < ARRAY_SIZE(mData); i++, data++)
|
||||
data->mState = 0;
|
||||
|
||||
dTree_anm_c* anm = getAnm();
|
||||
for (s32 i = 0; i < ARRAY_SIZE(mAnm); i++, anm++)
|
||||
anm->mState = 0;
|
||||
|
||||
s16 angle = 0;
|
||||
for (s32 i = 0; i < 8; i++, angle += 0x2000)
|
||||
setAnm(i, angle);
|
||||
}
|
||||
|
||||
dPa_smokeEcallBack dTree_data_c::mSmokeEcallback(1, 1, 0, 1);
|
||||
|
||||
/* 800795E8-800795F4 .text __ct__12dTree_room_cFv */
|
||||
dTree_room_c::dTree_room_c() {
|
||||
/* Nonmatching */
|
||||
mpData = NULL;
|
||||
}
|
||||
|
||||
/* 800795F4-80079600 .text __ct__11dTree_anm_cFv */
|
||||
dTree_anm_c::dTree_anm_c() {
|
||||
/* Nonmatching */
|
||||
mState = 0;
|
||||
}
|
||||
|
||||
/* 80079600-8007960C .text __ct__12dTree_data_cFv */
|
||||
dTree_data_c::dTree_data_c() {
|
||||
/* Nonmatching */
|
||||
mState = 0;
|
||||
}
|
||||
|
||||
/* 8007960C-80079898 .text draw__14dTree_packet_cFv */
|
||||
@@ -255,39 +491,302 @@ void dTree_packet_c::draw() {
|
||||
{&l_Oba_swood_a_cuttDL, 0xA0},
|
||||
{&l_Oba_swood_a_cutuDL, 0x60},
|
||||
};
|
||||
|
||||
static GXColor l_shadowColor = {0x00, 0x00, 0x00, 0x64};
|
||||
|
||||
static u8 l_modelStatus[2][3] = {0, 1, 2, 3, 1, 4};
|
||||
|
||||
j3dSys.reinitGX();
|
||||
GXSetNumIndStages(0);
|
||||
GFSetVtxDescv(l_shadowVtxDescList);
|
||||
GFSetVtxAttrFmtv(GX_VTXFMT0, l_shadowVtxAttrFmtList);
|
||||
GFSetArray(GX_VA_POS, g_dTree_shadowPos, 3);
|
||||
GFSetArray(GX_VA_TEX0, g_dTree_shadowTexCoord, 2);
|
||||
GXCallDisplayList(g_dTree_shadowMatDL, 0x80);
|
||||
GFSetTevColor(GX_TEVREG0, l_shadowColor);
|
||||
|
||||
dTree_room_c* room = &mRoom[0];
|
||||
for (s32 i = 0; i < (s32)ARRAY_SIZE(mRoom); room++, i++) {
|
||||
dKy_tevstr_c* tevstr = dComIfGp_roomControl_getTevStr(i);
|
||||
dKy_GfFog_tevstr_set(tevstr);
|
||||
for (dTree_data_c* data = room->mpData; data != NULL; data = data->mpNext) {
|
||||
if (!cLib_checkBit<u8>(data->mState, 0x04)) {
|
||||
GFLoadPosMtxImm(data->field_0x0d0, GX_PNMTX0);
|
||||
GXCallDisplayList(g_dTree_Oba_kage_32DL, 0x20);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
GFSetVtxDescv(l_vtxDescList);
|
||||
GFSetVtxAttrFmtv(GX_VTXFMT0, l_vtxAttrFmtList);
|
||||
GFSetArray(GX_VA_POS, l_pos, sizeof(cXyz));
|
||||
GFSetArray(GX_VA_CLR0, l_color, sizeof(GXColor));
|
||||
GFSetArray(GX_VA_TEX0, l_texCoord, sizeof(cXy));
|
||||
GXCallDisplayList(l_matDL, 0xA0);
|
||||
|
||||
room = &mRoom[0];
|
||||
for (s32 i = 0; i < (s32)ARRAY_SIZE(mRoom); room++, i++) {
|
||||
dKy_tevstr_c* tevstr = dComIfGp_roomControl_getTevStr(i);
|
||||
GFSetTevColorS10(GX_TEVREG0, tevstr->mColorC0);
|
||||
GFSetTevColor(GX_TEVREG1, tevstr->mColorK0);
|
||||
dKy_GfFog_tevstr_set(tevstr);
|
||||
for (dTree_data_c* data = room->mpData; data != NULL; data = data->mpNext) {
|
||||
if (!cLib_checkBit<u8>(data->mState, 0x04)) {
|
||||
u8* var_r25 = l_modelStatus[data->field_0x001];
|
||||
if (data->field_0x003 != 0) {
|
||||
GXColor sp;
|
||||
sp.a = data->field_0x003;
|
||||
GFSetTevColor(GX_TEVREG2, sp);
|
||||
GFLoadPosMtxImm(data->field_0x010, GX_PNMTX0);
|
||||
GXCallDisplayList(l_modelDataStatus[var_r25[0]].list,
|
||||
l_modelDataStatus[var_r25[0]].nbytes);
|
||||
GXCallDisplayList(l_modelDataStatus[var_r25[1]].list,
|
||||
l_modelDataStatus[var_r25[1]].nbytes);
|
||||
}
|
||||
|
||||
GFLoadPosMtxImm(data->field_0x040, GX_PNMTX0);
|
||||
GXCallDisplayList(l_modelDataStatus[var_r25[2]].list,
|
||||
l_modelDataStatus[var_r25[2]].nbytes);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
J3DShape::resetVcdVatCache();
|
||||
}
|
||||
|
||||
/* 80079898-80079B24 .text calc__14dTree_packet_cFv */
|
||||
// NONMATCHING - some regalloc
|
||||
void dTree_packet_c::calc() {
|
||||
/* Nonmatching */
|
||||
dTree_anm_c* anm = getAnm();
|
||||
|
||||
int var_r3 = 0;
|
||||
for (s32 i = 0; i < 8; anm++, var_r3 += 250, i++) {
|
||||
anm->field_0x06 = anm->field_0x02 + 100.0f + cM_scos((g_Counter.mTimer + var_r3) * 4000.0f) * 100.0f;
|
||||
anm->field_0x04 = 100.0f + cM_scos((g_Counter.mTimer + var_r3) * 1000.0f) * 100.0f;
|
||||
}
|
||||
|
||||
int roomNo = dComIfGp_roomControl_getStayNo();
|
||||
dTree_data_c* data = mRoom[roomNo].getData();
|
||||
if (data != NULL) {
|
||||
daPy_py_c* player = daPy_getPlayerActorClass();
|
||||
mPlayerCutFlg = player->checkNoResetFlg0(daPy_py_c::daPyFlg0_CUT_AT_FLG) != 0;
|
||||
|
||||
cXyz sp38;
|
||||
cXyz sp2C;
|
||||
sp38 = player->getSwordTopPos();
|
||||
|
||||
sp2C = sp38 - player->current.pos;
|
||||
mPlayerSwordAngY = cM_atan2s(sp2C.x, sp2C.z);
|
||||
|
||||
sp2C = mPlayerSwordTop - sp38;
|
||||
mPlayerSwordMoveAngY = cM_atan2s(sp2C.x, sp2C.z);
|
||||
|
||||
mPlayerSwordTop = sp38;
|
||||
|
||||
l_CutSoundFlag = false;
|
||||
dComIfG_Ccsp()->SetMassAttr(40.0f, 200.0f, 19, 1);
|
||||
|
||||
while (true) {
|
||||
if (!cLib_checkBit<u8>(data->mState, 0x08))
|
||||
data->hitCheck(player, roomNo);
|
||||
|
||||
if (data->mAnimIdx >= 8)
|
||||
data->animation(roomNo);
|
||||
|
||||
data = data->mpNext;
|
||||
if (data == NULL)
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/* 80079B24-80079E6C .text checkGroundY__FP12dTree_data_cR4cXyz */
|
||||
void checkGroundY(dTree_data_c*, cXyz&) {
|
||||
/* Nonmatching */
|
||||
f32 checkGroundY(dTree_data_c* i_data, cXyz& i_pos) {
|
||||
dBgS_GndChk chk;
|
||||
i_pos.y += 50.0f;
|
||||
chk.SetPos(&i_pos);
|
||||
f32 y = dComIfG_Bgsp()->GroundCross(&chk);
|
||||
i_pos.y -= 50.0f;
|
||||
|
||||
cXyz norm;
|
||||
if (y <= -G_CM3D_F_INF) {
|
||||
y = i_pos.y;
|
||||
norm.set(0.0f, 1.0f, 0.0f);
|
||||
} else {
|
||||
norm = *dComIfG_Bgsp()->GetTriPla(chk)->GetNP();
|
||||
}
|
||||
|
||||
f32 var_f4 = std::sqrtf(1.0f - (norm.x * norm.x));
|
||||
f32 var_f2;
|
||||
f32 var_f3;
|
||||
if (var_f4 != 0.0f) {
|
||||
var_f2 = norm.y * var_f4;
|
||||
var_f3 = -norm.z * var_f4;
|
||||
} else {
|
||||
var_f2 = 0.0f;
|
||||
var_f3 = 0.0f;
|
||||
}
|
||||
|
||||
i_data->mShadowMtx[0][0] = var_f4;
|
||||
i_data->mShadowMtx[0][1] = norm.x;
|
||||
i_data->mShadowMtx[0][2] = 0.0f;
|
||||
i_data->mShadowMtx[0][3] = i_pos.x;
|
||||
|
||||
i_data->mShadowMtx[1][0] = -norm.x * var_f2;
|
||||
i_data->mShadowMtx[1][1] = norm.y;
|
||||
i_data->mShadowMtx[1][2] = var_f3;
|
||||
i_data->mShadowMtx[1][3] = y + 1.0f;
|
||||
|
||||
i_data->mShadowMtx[2][0] = norm.x * var_f3;
|
||||
i_data->mShadowMtx[2][1] = norm.z;
|
||||
i_data->mShadowMtx[2][2] = var_f2;
|
||||
i_data->mShadowMtx[2][3] = i_pos.z;
|
||||
|
||||
return y;
|
||||
}
|
||||
|
||||
/* 80079E6C-8007A14C .text update__14dTree_packet_cFv */
|
||||
void dTree_packet_c::update() {
|
||||
/* Nonmatching */
|
||||
dTree_anm_c* anm = getAnm();
|
||||
for (int i = 0; i < (s32)ARRAY_SIZE(mAnm); i++, anm++) {
|
||||
mDoMtx_stack_c::YrotS(anm->field_0x0a);
|
||||
mDoMtx_stack_c::XrotM(anm->field_0x04);
|
||||
mDoMtx_stack_c::YrotM(anm->field_0x06 - anm->field_0x0a);
|
||||
mDoMtx_copy(mDoMtx_stack_c::get(), anm->field_0x24);
|
||||
|
||||
mDoMtx_stack_c::YrotS(anm->field_0x0a);
|
||||
mDoMtx_stack_c::XrotM(anm->field_0x08);
|
||||
mDoMtx_stack_c::YrotM(anm->field_0x02 - anm->field_0x0a);
|
||||
mDoMtx_copy(mDoMtx_stack_c::get(), anm->field_0x54);
|
||||
}
|
||||
|
||||
dTree_data_c* data = getData();
|
||||
anm = getAnm();
|
||||
|
||||
s32 numPerFrame = 0;
|
||||
mDoLib_clipper::changeFar(mDoLib_clipper::getFar() * 1.8181819f);
|
||||
|
||||
for (int i = 0; i < (s32)ARRAY_SIZE(mData); i++) {
|
||||
if (data->mState & 2) {
|
||||
if ((data->mState & 0x10) && numPerFrame < 4) {
|
||||
data->mPos.y = checkGroundY(data, data->mPos);
|
||||
data->mState &= ~0x10;
|
||||
numPerFrame++;
|
||||
}
|
||||
|
||||
cXyz pos(data->mPos.x, data->mPos.y + 260.0f, data->mPos.z);
|
||||
if (mDoLib_clipper::clip(j3dSys.getViewMtx(), pos, 260.0f)) {
|
||||
cLib_onBit<u8>(data->mState, 0x04);
|
||||
} else {
|
||||
cLib_offBit<u8>(data->mState, 0x04);
|
||||
|
||||
dTree_anm_c* var_r22 = &anm[data->mAnimIdx];
|
||||
if (data->mState & 8) {
|
||||
mDoMtx_concat(j3dSys.getViewMtx(), data->field_0x070, data->field_0x010);
|
||||
cLib_chaseUC(&data->field_0x003, 0, 8);
|
||||
} else {
|
||||
var_r22->field_0x24[0][3] = data->mPos.x + var_r22->field_0x18;
|
||||
var_r22->field_0x24[1][3] = data->mPos.y + var_r22->field_0x1c;
|
||||
var_r22->field_0x24[2][3] = data->mPos.z + var_r22->field_0x20;
|
||||
mDoMtx_concat(j3dSys.getViewMtx(), var_r22->field_0x24, data->field_0x010);
|
||||
}
|
||||
|
||||
var_r22->field_0x54[0][3] = data->mPos.x;
|
||||
var_r22->field_0x54[1][3] = data->mPos.y;
|
||||
var_r22->field_0x54[2][3] = data->mPos.z;
|
||||
|
||||
mDoMtx_concat(j3dSys.getViewMtx(), var_r22->field_0x54, data->field_0x040);
|
||||
mDoMtx_concat(j3dSys.getViewMtx(), data->mShadowMtx, data->field_0x0d0);
|
||||
}
|
||||
}
|
||||
data++;
|
||||
}
|
||||
|
||||
mDoLib_clipper::resetFar();
|
||||
dComIfGd_setXluListBG();
|
||||
j3dSys.getDrawBuffer(1)->entryImm(this, 0);
|
||||
dComIfGd_setXluList();
|
||||
}
|
||||
|
||||
/* 8007A14C-8007A238 .text setData__14dTree_packet_cFP12dTree_data_ciR4cXyzUci */
|
||||
void dTree_packet_c::setData(dTree_data_c*, int, cXyz&, u8, int) {
|
||||
/* Nonmatching */
|
||||
void dTree_packet_c::setData(dTree_data_c* i_data, int i_nextIdx, cXyz& i_pos, u8 param_3, int i_roomNo) {
|
||||
f32 y;
|
||||
if (fopOvlpM_IsPeek()) {
|
||||
y = checkGroundY(i_data, i_pos);
|
||||
i_data->mState = 6;
|
||||
} else {
|
||||
y = i_pos.y;
|
||||
i_data->mState = 22;
|
||||
}
|
||||
|
||||
i_data->field_0x001 = param_3;
|
||||
i_data->field_0x003 = param_3 == 1 ? 0 : 0xFF;
|
||||
i_data->mAnimIdx = (u8)cM_rndF(7.0f);
|
||||
i_data->mPos.set(i_pos.x, y, i_pos.z);
|
||||
mRoom[i_roomNo].newData(i_data);
|
||||
mNextIdx = i_nextIdx;
|
||||
}
|
||||
|
||||
/* 8007A238-8007A36C .text newData__14dTree_packet_cFR4cXyzUci */
|
||||
void dTree_packet_c::newData(cXyz&, u8, int) {
|
||||
/* Nonmatching */
|
||||
dTree_data_c* dTree_packet_c::newData(cXyz& i_pos, u8 param_1, int i_roomNo) {
|
||||
JUT_ASSERT(1608, 0 <= i_roomNo && i_roomNo < 64);
|
||||
|
||||
dTree_data_c* data = &mData[mNextIdx];
|
||||
s32 i = mNextIdx;
|
||||
for (; i < (s32)ARRAY_SIZE(mData); data++, i++) {
|
||||
if (!(data->mState & 2)) {
|
||||
setData(data, i, i_pos, param_1, i_roomNo);
|
||||
return data;
|
||||
}
|
||||
}
|
||||
|
||||
data = getData();
|
||||
for (i = 0; i < mNextIdx; data++, i++) {
|
||||
if (!(data->mState & 2)) {
|
||||
setData(data, i, i_pos, param_1, i_roomNo);
|
||||
return data;
|
||||
}
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* 8007A36C-8007A3DC .text newAnm__14dTree_packet_cFs */
|
||||
void dTree_packet_c::newAnm(s16) {
|
||||
/* Nonmatching */
|
||||
s32 dTree_packet_c::newAnm(s16 param_0) {
|
||||
dTree_anm_c* anm = &getAnm(8);
|
||||
for (s32 i = 8; i < 64 + 8; anm++, i++) {
|
||||
if (anm->mState == 0) {
|
||||
anm->mState = 1;
|
||||
anm->field_0x02 = param_0;
|
||||
anm->field_0x06 = param_0;
|
||||
anm->field_0x04 = 0;
|
||||
anm->field_0x08 = 0;
|
||||
anm->field_0x0a = 0;
|
||||
anm->mAnimTimer = 0;
|
||||
anm->field_0x10 = 0;
|
||||
anm->field_0x14 = 0;
|
||||
anm->field_0x18 = 0;
|
||||
anm->field_0x1c = 0;
|
||||
anm->field_0x20 = 0;
|
||||
return i;
|
||||
}
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
/* 8007A3DC-8007A428 .text setAnm__14dTree_packet_cFis */
|
||||
void dTree_packet_c::setAnm(int, s16) {
|
||||
/* Nonmatching */
|
||||
void dTree_packet_c::setAnm(int i_no, s16 param_1) {
|
||||
dTree_anm_c& anm = getAnm(i_no);
|
||||
anm.mState = 1;
|
||||
anm.field_0x02 = param_1;
|
||||
anm.field_0x06 = param_1;
|
||||
anm.field_0x04 = 0;
|
||||
anm.field_0x08 = 0;
|
||||
anm.field_0x0a = 0;
|
||||
anm.mAnimTimer = 0;
|
||||
anm.field_0x10 = 0;
|
||||
anm.field_0x14 = 0;
|
||||
anm.field_0x18 = 0;
|
||||
anm.field_0x1c = 0;
|
||||
anm.field_0x20 = 0;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user