mirror of
https://github.com/zeldaret/tww.git
synced 2026-05-23 06:54:16 -04:00
d_a_toge (#619)
* Started implementing d_a_toge * daToge update * daToge WIP * Implemented daToge_c::_create * Implemented toge_seStart * Implemented daToge_c::_draw * Implemented daToge_c::set_collision * Fixed daToge setCullSizeBox call * Added g_profile_TOGE * Refactored daToge_c:._delete * Fixed local float in daToge_c::set_collision * daToge_c::toge_move * Removed commented-out code * Modified Irregular switch in daToge_c::toge_move * Cleaned up daToge_c::search_wind * Implemented daToge_c::_execute * daToge code-cleanup * daToge additional code-cleanup * Removed redundant type cast * Update src/d/actor/d_a_toge.cpp Co-authored-by: LagoLunatic <LagoLunatic@users.noreply.github.com> * Fixed PR suggestions * Updated configure.py * Minor fixes --------- Co-authored-by: LagoLunatic <LagoLunatic@users.noreply.github.com>
This commit is contained in:
+1
-1
@@ -1612,7 +1612,7 @@ config.libs = [
|
||||
ActorRel(Matching, "d_a_tag_volcano"),
|
||||
ActorRel(NonMatching, "d_a_title"),
|
||||
ActorRel(NonMatching, "d_a_tn"),
|
||||
ActorRel(NonMatching, "d_a_toge"),
|
||||
ActorRel(Matching, "d_a_toge", extra_cflags=['-pragma "nosyminline on"']),
|
||||
ActorRel(NonMatching, "d_a_tori_flag"),
|
||||
ActorRel(Matching, "d_a_wall", extra_cflags=['-pragma "nosyminline on"']),
|
||||
ActorRel(Matching, "d_a_warpfout"),
|
||||
|
||||
@@ -1,25 +1,58 @@
|
||||
#ifndef D_A_TOGE_H
|
||||
#define D_A_TOGE_H
|
||||
|
||||
#include "d/d_cc_d.h"
|
||||
#include "d/d_stage.h"
|
||||
#include "f_op/f_op_actor.h"
|
||||
|
||||
class daToge_c : public fopAc_ac_c {
|
||||
public:
|
||||
void set_mtx(); // weak but not inlined?
|
||||
void set_mtx(); // weak but not inlined?
|
||||
|
||||
BOOL _delete();
|
||||
void CreateHeap();
|
||||
s32 Create();
|
||||
BOOL CreateHeap();
|
||||
BOOL Create();
|
||||
s32 _create();
|
||||
BOOL _execute();
|
||||
void set_collision();
|
||||
void search_wind();
|
||||
void toge_move();
|
||||
void toge_seStart(unsigned long);
|
||||
void toge_seStart(u32 i_seNum);
|
||||
BOOL _draw();
|
||||
|
||||
static const char m_arcname[];
|
||||
static const s16 m_bdlidx;
|
||||
static const s16 m_dzbidx;
|
||||
static const u32 m_heapsize;
|
||||
static const f32 m_y_min;
|
||||
|
||||
public:
|
||||
/* Place member variables here */
|
||||
/* 0x290 */ request_of_phase_process_class m_Phs;
|
||||
/* 0x298 */ J3DModel* mpModel;
|
||||
/* 0x29C */ dCcD_Stts mStts;
|
||||
/* 0x2D8 */ dCcD_Cyl mCyl;
|
||||
/* 0x408 */ dBgW* mpBgW1;
|
||||
/* 0x40C */ Mtx mtx1;
|
||||
/* 0x43C */ dBgW* mpBgW2;
|
||||
/* 0x440 */ Mtx mtx2;
|
||||
/* 0x470 */ f32 unk470;
|
||||
/* 0x474 */ f32 unk474;
|
||||
/* 0x478 */ s32 mSwitchNo;
|
||||
/* 0x47C */ char pad47C[4];
|
||||
/* 0x480 */ s32 mWindTagId;
|
||||
/* 0x484 */ u8 mEventState;
|
||||
/* 0x485 */ u8 unk485;
|
||||
/* 0x486 */ u8 unk486;
|
||||
};
|
||||
|
||||
namespace daToge_prm {
|
||||
inline u8 getSwitchNo(daToge_c* ac) {
|
||||
return (fopAcM_GetParam(ac) >> 0) & 0xFF;
|
||||
}
|
||||
|
||||
inline u8 getSeEnabled(daToge_c* ac) {
|
||||
return (fopAcM_GetParam(ac) >> 8) & 0xF;
|
||||
}
|
||||
}; // namespace daToge_prm
|
||||
|
||||
#endif /* D_A_TOGE_H */
|
||||
|
||||
@@ -30,7 +30,9 @@ namespace daWindTag {
|
||||
|
||||
public:
|
||||
/* Place member variables here */
|
||||
};
|
||||
/* 0x290 */ char pad290[0x208]; /* Placeholder padding */
|
||||
/* 0x498 */ f32 unk498;
|
||||
};
|
||||
}; // namespace daWindTag
|
||||
|
||||
#endif /* D_A_WIND_TAG_H */
|
||||
|
||||
+257
-32
@@ -4,104 +4,329 @@
|
||||
//
|
||||
|
||||
#include "d/actor/d_a_toge.h"
|
||||
#include "m_Do/m_Do_ext.h"
|
||||
#include "d/actor/d_a_wind_tag.h"
|
||||
#include "d/d_com_inf_game.h"
|
||||
#include "d/d_procname.h"
|
||||
#include "m_Do/m_Do_ext.h"
|
||||
|
||||
const char daToge_c::m_arcname[] = "Htoge1";
|
||||
const s16 daToge_c::m_bdlidx = 0x07;
|
||||
const s16 daToge_c::m_dzbidx = 0x04;
|
||||
const u32 daToge_c::m_heapsize = 0x5000;
|
||||
const f32 daToge_c::m_y_min = -150.0f;
|
||||
|
||||
static dCcD_SrcCyl l_cyl_src = {
|
||||
// dCcD_SrcGObjInf
|
||||
{
|
||||
/* Flags */ 0,
|
||||
/* SrcObjAt Type */ AT_TYPE_UNK800,
|
||||
/* SrcObjAt Atp */ 0x1,
|
||||
/* SrcObjAt SPrm */ AT_SPRM_SET | AT_SPRM_VS_PLAYER,
|
||||
/* SrcObjTg Type */ AT_TYPE_ALL,
|
||||
/* SrcObjTg SPrm */ 0,
|
||||
/* SrcObjCo SPrm */ CO_SPRM_SET | CO_SPRM_IS_UNK8 | CO_SPRM_VS_UNK2 | CO_SPRM_VS_UNK4 |
|
||||
CO_SPRM_VS_UNK8,
|
||||
/* SrcGObjAt Se */ 0,
|
||||
/* SrcGObjAt HitMark */ 0,
|
||||
/* SrcGObjAt Spl */ dCcG_At_Spl_UNK1,
|
||||
/* SrcGObjAt Mtrl */ 0,
|
||||
/* SrcGObjAt SPrm */ 0,
|
||||
/* SrcGObjTg Se */ 0,
|
||||
/* SrcGObjTg HitMark */ 0,
|
||||
/* SrcGObjTg Spl */ 0,
|
||||
/* SrcGObjTg Mtrl */ 0,
|
||||
/* SrcGObjTg SPrm */ G_TG_SPRM_NO_HIT_MARK,
|
||||
/* SrcGObjCo SPrm */ 0,
|
||||
},
|
||||
|
||||
// cCcD_SrcCylAttr
|
||||
{
|
||||
/* Center */ 0.0f,
|
||||
0.0f,
|
||||
0.0f,
|
||||
/* Radius */ 55.0f,
|
||||
/* Height */ 150.0f,
|
||||
}};
|
||||
|
||||
/* 00000078-0000013C .text _delete__8daToge_cFv */
|
||||
BOOL daToge_c::_delete() {
|
||||
/* Nonmatching */
|
||||
dComIfG_resDelete(&m_Phs, m_arcname);
|
||||
|
||||
if (mpBgW1 != NULL && mpBgW1->ChkUsed()) {
|
||||
dComIfG_Bgsp()->Release(mpBgW1);
|
||||
}
|
||||
|
||||
if (mpBgW2 != NULL && mpBgW2->ChkUsed()) {
|
||||
dComIfG_Bgsp()->Release(mpBgW2);
|
||||
}
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
/* 0000013C-0000015C .text CheckCreateHeap__FP10fopAc_ac_c */
|
||||
static BOOL CheckCreateHeap(fopAc_ac_c*) {
|
||||
/* Nonmatching */
|
||||
static BOOL CheckCreateHeap(fopAc_ac_c* i_this) {
|
||||
return static_cast<daToge_c*>(i_this)->CreateHeap();
|
||||
}
|
||||
|
||||
/* 0000015C-00000290 .text CreateHeap__8daToge_cFv */
|
||||
void daToge_c::CreateHeap() {
|
||||
/* Nonmatching */
|
||||
BOOL daToge_c::CreateHeap() {
|
||||
J3DModelData* modelData = (J3DModelData*)dComIfG_getObjectRes(m_arcname, 0x4);
|
||||
JUT_ASSERT(0x11A, modelData != 0);
|
||||
|
||||
mpModel = mDoExt_J3DModel__create(modelData, 0x80000U, 0x11000002U);
|
||||
|
||||
if (!mpModel) {
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
mpModel->setUserArea((u32)this);
|
||||
|
||||
mpBgW1 = dBgW_NewSet((cBgD_t*)dComIfG_getObjectRes(m_arcname, 7), cBgW::MOVE_BG_e, &mtx1);
|
||||
mpBgW2 = dBgW_NewSet((cBgD_t*)dComIfG_getObjectRes(m_arcname, 8), cBgW::MOVE_BG_e, &mtx2);
|
||||
|
||||
if (mpBgW1 == NULL || mpBgW2 == NULL) {
|
||||
return FALSE;
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
/* 00000290-00000348 .text nodeCallBack__FP7J3DNodei */
|
||||
static BOOL nodeCallBack(J3DNode*, int) {
|
||||
/* Nonmatching */
|
||||
static BOOL nodeCallBack(J3DNode* node, int timing) {
|
||||
if (timing == 0) {
|
||||
J3DJoint* joint = (J3DJoint*)node;
|
||||
u32 jntNo = joint->getJntNo();
|
||||
J3DModel* model = j3dSys.getModel();
|
||||
daToge_c* i_this = (daToge_c*)model->getUserArea();
|
||||
if (i_this != NULL) {
|
||||
mDoMtx_stack_c::copy(model->getAnmMtx(jntNo));
|
||||
mDoMtx_stack_c::transM(0.0f, i_this->unk470, 0.0f);
|
||||
model->setAnmMtx(jntNo, mDoMtx_stack_c::get());
|
||||
|
||||
mDoMtx_copy(mDoMtx_stack_c::get(), j3dSys.mCurrentMtx);
|
||||
mDoMtx_copy(mDoMtx_stack_c::get(), i_this->mtx2);
|
||||
}
|
||||
}
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
/* 00000348-000004F4 .text Create__8daToge_cFv */
|
||||
s32 daToge_c::Create() {
|
||||
/* Nonmatching */
|
||||
BOOL daToge_c::Create() {
|
||||
fopAcM_SetMtx(this, mpModel->getBaseTRMtx());
|
||||
|
||||
fopAcM_setCullSizeBox(this, -80.0f, 0.0f, -80.0f, 80.0f, 120.0f, 80.0f);
|
||||
mStts.Init(0xFF, 0xFF, this);
|
||||
|
||||
mCyl.Set(l_cyl_src);
|
||||
mCyl.SetStts(&mStts);
|
||||
|
||||
mSwitchNo = daToge_prm::getSwitchNo(this);
|
||||
|
||||
if (dComIfGs_isSwitch(mSwitchNo, fopAcM_GetHomeRoomNo(this))) {
|
||||
unk470 = m_y_min;
|
||||
mEventState = 2;
|
||||
}
|
||||
|
||||
set_mtx();
|
||||
cMtx_copy(mtx1, mtx2);
|
||||
|
||||
JUTNameTab* jointName = mpModel->getModelData()->getJointName();
|
||||
for (u16 i = 0; i < mpModel->getModelData()->getJointNum(); i++) {
|
||||
if (strcmp("toge", jointName->getName(i)) == 0) {
|
||||
mpModel->getModelData()->getJointNodePointer(i)->setCallBack(nodeCallBack);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
mpModel->calc();
|
||||
|
||||
dComIfG_Bgsp()->Regist(mpBgW1, this);
|
||||
dComIfG_Bgsp()->Regist(mpBgW2, this);
|
||||
|
||||
mpBgW1->Move();
|
||||
mpBgW2->Move();
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
/* 000004F4-00000620 .text _create__8daToge_cFv */
|
||||
s32 daToge_c::_create() {
|
||||
/* Nonmatching */
|
||||
fopAcM_SetupActor(this, daToge_c);
|
||||
|
||||
s32 ret = dComIfG_resLoad(&m_Phs, m_arcname);
|
||||
|
||||
if (ret == cPhs_COMPLEATE_e) {
|
||||
if (!fopAcM_entrySolidHeap(this, CheckCreateHeap, 0x1400)) {
|
||||
return cPhs_ERROR_e;
|
||||
}
|
||||
|
||||
Create();
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
/* 000007D8-00000868 .text set_mtx__8daToge_cFv */
|
||||
void daToge_c::set_mtx() {
|
||||
/* Nonmatching */
|
||||
mpModel->setBaseScale(scale);
|
||||
mDoMtx_stack_c::transS(current.pos.x, current.pos.y, current.pos.z);
|
||||
mDoMtx_stack_c::YrotM(current.angle.y);
|
||||
|
||||
mpModel->setBaseTRMtx(mDoMtx_stack_c::get());
|
||||
mDoMtx_copy(mDoMtx_stack_c::get(), mtx1);
|
||||
}
|
||||
|
||||
/* 00000868-000009F4 .text _execute__8daToge_cFv */
|
||||
BOOL daToge_c::_execute() {
|
||||
/* Nonmatching */
|
||||
if (mSwitchNo != 0xFF) {
|
||||
if (fopAcM_isSwitch(this, mSwitchNo) != 0) {
|
||||
if (mEventState != 1) {
|
||||
unk485 = 1;
|
||||
}
|
||||
} else if (fopAcM_isSwitch(this, mSwitchNo) == 0 && mEventState != 4) {
|
||||
mEventState = 3;
|
||||
}
|
||||
} else if (mSwitchNo == 0xFF) { // Redundant condition (necessary for matching)
|
||||
search_wind();
|
||||
|
||||
daWindTag::daWindTag_c* pActor = (daWindTag::daWindTag_c*)fopAcM_SearchByID(mWindTagId);
|
||||
|
||||
if (pActor != NULL) {
|
||||
if (pActor->unk498 > 0.0f) {
|
||||
if (mEventState != 4) {
|
||||
mEventState = 3;
|
||||
}
|
||||
} else if (mEventState != 1) {
|
||||
unk485 = 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
toge_move();
|
||||
|
||||
mpModel->setBaseScale(scale);
|
||||
mDoMtx_stack_c::transS(current.pos);
|
||||
mDoMtx_stack_c::YrotM(current.angle.y);
|
||||
mpModel->setBaseTRMtx(mDoMtx_stack_c::get());
|
||||
mDoMtx_copy(mDoMtx_stack_c::get(), mtx1);
|
||||
|
||||
mpBgW2->Move();
|
||||
|
||||
set_collision();
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
/* 000009F4-00000A78 .text set_collision__8daToge_cFv */
|
||||
void daToge_c::set_collision() {
|
||||
/* Nonmatching */
|
||||
if (mEventState != 2) {
|
||||
cXyz center = current.pos;
|
||||
|
||||
center.y += (unk470 - 10.0f);
|
||||
|
||||
mCyl.SetC(center);
|
||||
dComIfG_Ccsp()->Set(&mCyl);
|
||||
}
|
||||
}
|
||||
|
||||
/* 00000A78-00000AE0 .text search_wind__8daToge_cFv */
|
||||
void daToge_c::search_wind() {
|
||||
/* Nonmatching */
|
||||
fopAc_ac_c* pActor = fopAcM_SearchByName(PROC_WindTag);
|
||||
|
||||
if (pActor != NULL) {
|
||||
mWindTagId = fopAcM_GetID(pActor);
|
||||
} else {
|
||||
mWindTagId = fpcM_ERROR_PROCESS_ID_e;
|
||||
}
|
||||
}
|
||||
|
||||
/* 00000AE0-00000C1C .text toge_move__8daToge_cFv */
|
||||
void daToge_c::toge_move() {
|
||||
/* Nonmatching */
|
||||
u8 r30 = 1;
|
||||
switch (mEventState) {
|
||||
case 1:
|
||||
if (cLib_calcTimer(&unk486) != 0)
|
||||
break;
|
||||
toge_seStart(JA_SE_OBJ_TOGETOGE_IN);
|
||||
mEventState = 2;
|
||||
// Fallthrough
|
||||
case 2:
|
||||
// m_y_min is also -150.0f, so that might be related
|
||||
cLib_addCalc(&unk470, -150.0f, 0.1f, 30.0f, 15);
|
||||
break;
|
||||
case 0:
|
||||
// ...
|
||||
break;
|
||||
case 3:
|
||||
toge_seStart(JA_SE_OBJ_TOGETOGE_OUT);
|
||||
mEventState = 4;
|
||||
r30 = 0;
|
||||
case 4:
|
||||
if (cLib_addCalc(&unk470, unk474, 0.1f, 30.0f, 15.0f) == 0) {
|
||||
if (unk470 < 0) {
|
||||
unk474 = 0;
|
||||
} else if (unk485 != 0) {
|
||||
unk486 = 0xA;
|
||||
mEventState = 1;
|
||||
unk485 = 0;
|
||||
} else {
|
||||
if (r30 != 0) {
|
||||
toge_seStart(JA_SE_OBJ_TOGETOGE_MOVE);
|
||||
}
|
||||
unk474 = -60.0f;
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/* 00000C1C-00000CA4 .text toge_seStart__8daToge_cFUl */
|
||||
void daToge_c::toge_seStart(unsigned long) {
|
||||
/* Nonmatching */
|
||||
void daToge_c::toge_seStart(u32 i_seNum) {
|
||||
if (daToge_prm::getSeEnabled(this)) {
|
||||
fopAcM_seStart(this, i_seNum, 0);
|
||||
}
|
||||
}
|
||||
|
||||
/* 00000CA4-00000D44 .text _draw__8daToge_cFv */
|
||||
BOOL daToge_c::_draw() {
|
||||
/* Nonmatching */
|
||||
g_env_light.settingTevStruct(TEV_TYPE_BG0, ¤t.pos, &tevStr);
|
||||
g_env_light.setLightTevColorType(mpModel, &tevStr);
|
||||
|
||||
dComIfGd_setListBG();
|
||||
mDoExt_modelUpdateDL(mpModel);
|
||||
dComIfGd_setList();
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
/* 00000D44-00000D64 .text daToge_Create__FPv */
|
||||
static s32 daToge_Create(void*) {
|
||||
/* Nonmatching */
|
||||
static BOOL daToge_Create(void* i_this) {
|
||||
return static_cast<daToge_c*>(i_this)->_create();
|
||||
}
|
||||
|
||||
/* 00000D64-00000D84 .text daToge_Delete__FPv */
|
||||
static BOOL daToge_Delete(void*) {
|
||||
/* Nonmatching */
|
||||
static BOOL daToge_Delete(void* i_this) {
|
||||
return static_cast<daToge_c*>(i_this)->_delete();
|
||||
}
|
||||
|
||||
/* 00000D84-00000DA4 .text daToge_Draw__FPv */
|
||||
static BOOL daToge_Draw(void*) {
|
||||
/* Nonmatching */
|
||||
static BOOL daToge_Draw(void* i_this) {
|
||||
return static_cast<daToge_c*>(i_this)->_draw();
|
||||
}
|
||||
|
||||
/* 00000DA4-00000DC4 .text daToge_Execute__FPv */
|
||||
static BOOL daToge_Execute(void*) {
|
||||
/* Nonmatching */
|
||||
static BOOL daToge_Execute(void* i_this) {
|
||||
return static_cast<daToge_c*>(i_this)->_execute();
|
||||
}
|
||||
|
||||
/* 00000DC4-00000DCC .text daToge_IsDelete__FPv */
|
||||
static BOOL daToge_IsDelete(void*) {
|
||||
/* Nonmatching */
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
static actor_method_class daTogeMethodTable = {
|
||||
(process_method_func)daToge_Create,
|
||||
(process_method_func)daToge_Delete,
|
||||
(process_method_func)daToge_Execute,
|
||||
(process_method_func)daToge_IsDelete,
|
||||
(process_method_func)daToge_Create, (process_method_func)daToge_Delete,
|
||||
(process_method_func)daToge_Execute, (process_method_func)daToge_IsDelete,
|
||||
(process_method_func)daToge_Draw,
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user