d_a_obj_rcloud (#849)

* d_a_obj_rcloud

* Refactor daObjRcloud_c and update resource usage

Renamed enum values and return types in daObjRcloud_c for clarity and consistency. Updated resource indices to use named constants from res_bvkumo.h. Replaced magic numbers and variable names for improved readability. Removed an obsolete comment in J3DTexture.h.

* Rename variable o_phase to phase in _create method

Refactored the variable name from o_phase to phase in the daObjRcloud_c::_create() method for clarity and consistency.

* Set configure.py to matching.
This commit is contained in:
Kristopher Early
2025-08-14 21:26:54 +01:00
committed by GitHub
parent 2eaf012e4f
commit 396599cd7a
4 changed files with 205 additions and 32 deletions
+1 -1
View File
@@ -1422,7 +1422,7 @@ config.libs = [
ActorRel(MatchingFor("GZLJ01", "GZLE01", "GZLP01"), "d_a_obj_pbco"),
ActorRel(Equivalent, "d_a_obj_pirateship", extra_cflags=['-pragma "nosyminline on"']), # weak func order
ActorRel(MatchingFor("GZLJ01", "GZLE01", "GZLP01"), "d_a_obj_quake"),
ActorRel(NonMatching, "d_a_obj_rcloud"),
ActorRel(Matching, "d_a_obj_rcloud", extra_cflags=['-pragma "nosyminline on"']),
ActorRel(Matching, "d_a_obj_roten", extra_cflags=['-pragma "nosyminline on"']),
ActorRel(MatchingFor("GZLJ01", "GZLE01", "GZLP01"), "d_a_obj_shelf"),
ActorRel(MatchingFor("GZLJ01", "GZLE01", "GZLP01"), "d_a_obj_shmrgrd", extra_cflags=["-sym off"]),
+1 -2
View File
@@ -74,8 +74,7 @@ public:
void setViewMtx(const Mtx viewMtx) { MTXCopy(viewMtx, mViewMtx); }
void setTranslationX(f32 translationX){ mTexMtxInfo.mSRT.mTranslationX = translationX; } // Fakematch
// TODO
void getTextureSRT() {}
J3DTextureSRTInfo& getTextureSRT() { return mTexMtxInfo.mSRT;}
private:
/* 0x00 */ J3DTexMtxInfo mTexMtxInfo;
+17 -10
View File
@@ -2,16 +2,24 @@
#define D_A_OBJ_RCLOUD_H
#include "f_op/f_op_actor.h"
#include "d/d_a_obj.h"
#include "m_Do/m_Do_ext.h"
#include "SSystem/SComponent/c_phase.h"
class daObjRcloud_c : public fopAc_ac_c {
public:
void param_get_arg() const {}
typedef void (daObjRcloud_c::*ProcFunc)();
enum Param_e {
PRM_ARG_W = 1,
PRM_ARG_S = 0,
};
int param_get_arg() const { return daObj::PrmAbstract(this, PRM_ARG_W, PRM_ARG_S); }
void init_mtx();
void solidHeapCB(fopAc_ac_c*);
void create_heap();
static BOOL solidHeapCB(fopAc_ac_c*);
bool create_heap();
cPhs_State _create();
bool _delete();
void wait_act_proc();
@@ -23,15 +31,14 @@ public:
bool _draw();
public:
/* 0x290 */ request_of_phase_process_class mPhsBVkumo;
/* 0x290 */ request_of_phase_process_class mPhase;
/* 0x298 */ J3DModel* mpModel;
/* 0x29C */ mDoExt_btkAnm mBtkAnm;
/* 0x2B0 */ u8 m2B0[0x2BC - 0x2B0];
/* 0x2B0 */ ProcFunc mCurrentActProc;
/* 0x2BC */ int m2BC;
/* 0x2C0 */ int m2C0;
/* 0x2C4 */ u8 m2C4;
/* 0x2C0 */ int mDemoNameIndex;
/* 0x2C4 */ u8 mResourceLoadedFlag;
/* 0x2C5 */ u8 m2C5[0x2C8 - 0x2C5];
/* 0x2C8 */ f32 m2C8;
/* 0x2C8 */ f32 mCloudAnimProgress;
};
#endif /* D_A_OBJ_RCLOUD_H */
+186 -19
View File
@@ -4,87 +4,250 @@
*/
#include "d/actor/d_a_obj_rcloud.h"
#include "d/d_com_inf_game.h"
#include "d/d_procname.h"
#include "d/d_priority.h"
#include "m_Do/m_Do_hostIO.h"
#include "d/res/res_bvkumo.h"
#include "weak_data_1811.h" // IWYU pragma: keep
namespace {
const char l_arcname[] = "BVkumo";
const char l_demo41_name[] = "demo41";
const char l_dummy_name[] = "demo41";
const char* l_demo_name[] = {l_demo41_name, l_dummy_name};
const f32 maxDemoFrame = 428.0f;
const f32 endCloudAnimProgress = -1.0f;
} // namespace
#if VERSION == VERSION_DEMO
class daObjRcloud_HIO_c : public JORReflexible {
public:
daObjRcloud_HIO_c();
virtual ~daObjRcloud_HIO_c() {}
void genMessage(JORMContext*);
public:
/* 0x04 */ s8 mNo;
/* 0x08 */ f32 m08;
/* 0x0C */ u8 m0C;
};
daObjRcloud_HIO_c::daObjRcloud_HIO_c() {
mNo = -1;
m08 = -0.008928572f;
m0C = 0;
}
static daObjRcloud_HIO_c l_HIO;
#else
namespace L_HIO {
static const f32 m08 = -0.008928572f;
};
#endif
/* 00000078-000000E8 .text init_mtx__13daObjRcloud_cFv */
void daObjRcloud_c::init_mtx() {
/* Nonmatching */
mpModel->setBaseScale(scale);
mDoMtx_stack_c::transS(current.pos);
mpModel->setBaseTRMtx(mDoMtx_stack_c::get());
}
/* 000000E8-0000010C .text solidHeapCB__13daObjRcloud_cFP10fopAc_ac_c */
void daObjRcloud_c::solidHeapCB(fopAc_ac_c*) {
/* Nonmatching */
BOOL daObjRcloud_c::solidHeapCB(fopAc_ac_c* i_this) {
return static_cast<daObjRcloud_c*>(i_this)->create_heap();
}
/* 0000010C-00000238 .text create_heap__13daObjRcloud_cFv */
void daObjRcloud_c::create_heap() {
/* Nonmatching */
bool daObjRcloud_c::create_heap() {
bool result = true;;
J3DModelData* modelData = static_cast<J3DModelData*>(dComIfG_getObjectRes(l_arcname, BVKUMO_BDL_BVKUMO));
J3DAnmTextureSRTKey* pAnm = static_cast<J3DAnmTextureSRTKey*>(dComIfG_getObjectRes(l_arcname, BVKUMO_BTK_BVKUMO));
if (modelData == NULL || pAnm == FALSE) {
JUT_ASSERT(DEMO_SELECT(216, 220), FALSE);
result = 0;
} else {
mpModel = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000222);
s32 btkRet = mBtkAnm.init(modelData, pAnm, TRUE, J3DFrameCtrl::EMode_LOOP, 1.0f, 0, -1.0f, FALSE, 0);
if (mpModel == NULL || btkRet == 0) {
result = 0;
}
}
return result;
}
/* 00000238-000003B4 .text _create__13daObjRcloud_cFv */
cPhs_State daObjRcloud_c::_create() {
/* Nonmatching */
#if VERSION == VERSION_DEMO
cPhs_State phase = cPhs_ERROR_e;
fopAcM_SetupActor(this, daObjRcloud_c);
#else
fopAcM_SetupActor(this, daObjRcloud_c);
cPhs_State phase = cPhs_ERROR_e;
#endif
if (fopAcM_IsFirstCreating(this)) {
mDemoNameIndex = param_get_arg();
}
switch (mDemoNameIndex) {
case 0:
if (dComIfGs_isEventBit(0x3908) == 0) {
phase = dComIfG_resLoad(&mPhase, l_arcname);
mResourceLoadedFlag = 1;
}
break;
case 1:
if (dComIfGs_isSymbol(0) == 0) {
phase = dComIfG_resLoad(&mPhase, l_arcname);
mResourceLoadedFlag = 1;
}
break;
deafult:
break;
}
if (phase == cPhs_COMPLEATE_e) {
if (fopAcM_entrySolidHeap(this, solidHeapCB, 0x5a0)) {
fopAcM_SetMtx(this, mpModel->getBaseTRMtx());
init_mtx();
setup_action(0);
} else {
phase = cPhs_ERROR_e;
}
}
#if VERSION == VERSION_DEMO
if (l_HIO.mNo < 0) {
l_HIO.mNo = mDoHIO_createChild("竜の山の雲", &l_HIO);
}
#endif
return phase;
}
/* 00000458-00000494 .text _delete__13daObjRcloud_cFv */
bool daObjRcloud_c::_delete() {
/* Nonmatching */
if (mResourceLoadedFlag == 1) {
dComIfG_resDelete(&mPhase, l_arcname);
}
#if VERSION == VERSION_DEMO
if (l_HIO.mNo >= 0) {
mDoHIO_deleteChild(l_HIO.mNo);
l_HIO.mNo = -1;
}
#endif
return true;
}
/* 00000494-00000500 .text wait_act_proc__13daObjRcloud_cFv */
void daObjRcloud_c::wait_act_proc() {
/* Nonmatching */
if (dComIfGp_event_getMode() != 0 && dComIfGp_evmng_startCheck(l_demo_name[mDemoNameIndex]) != 0) {
setup_action(1);
}
#if VERSION == VERSION_DEMO
if (l_HIO.m0C == 1) {
setup_action(2);
}
#endif
}
/* 00000500-00000568 .text clouds_lift_start_wait_act_proc__13daObjRcloud_cFv */
void daObjRcloud_c::clouds_lift_start_wait_act_proc() {
/* Nonmatching */
dDemo_manager_c* demo = dComIfGp_demo_get();
if (demo != NULL) {
if ((u32)demo->getFrame() > maxDemoFrame) {
setup_action(2);
}
}
}
/* 00000568-000005DC .text clouds_lift_act_proc__13daObjRcloud_cFv */
void daObjRcloud_c::clouds_lift_act_proc() {
/* Nonmatching */
mCloudAnimProgress += HIO(m08);
if (mCloudAnimProgress < endCloudAnimProgress) {
mCloudAnimProgress = -1.0f;
dComIfGs_onEventBit(0x3908);
fopAcM_delete(this);
}
}
/* 000005DC-00000678 .text setup_action__13daObjRcloud_cFi */
void daObjRcloud_c::setup_action(int) {
/* Nonmatching */
void daObjRcloud_c::setup_action(int i_actionIndex) {
static ProcFunc act_proc[] = {&daObjRcloud_c::wait_act_proc, &daObjRcloud_c::clouds_lift_start_wait_act_proc, &daObjRcloud_c::clouds_lift_act_proc};
mCurrentActProc = act_proc[i_actionIndex];
m2BC = i_actionIndex;
}
/* 00000678-000006BC .text _execute__13daObjRcloud_cFv */
bool daObjRcloud_c::_execute() {
/* Nonmatching */
mBtkAnm.play();
(this->*mCurrentActProc)();
return TRUE;
}
/* 000006BC-00000778 .text setTexMtx__13daObjRcloud_cFv */
void daObjRcloud_c::setTexMtx() {
/* Nonmatching */
const J3DModelData* modelData = mpModel->getModelData();
for (u16 i = 0; i < modelData->getMaterialNum(); i++) {
J3DMaterial* material = modelData->getMaterialNodePointer(i);
for (u32 texMtxID = 0; texMtxID < 8; texMtxID++) {
J3DTexGenBlock* texGenBlock = material->getTexGenBlock();
J3DTexMtx* pTexMtx = texGenBlock->getTexMtx(texMtxID);
if (pTexMtx != NULL) {
pTexMtx->getMtx()[0][3] += pTexMtx->getTextureSRT().mTranslationX;
if (m2BC == 2) {
pTexMtx->getMtx()[1][3] += mCloudAnimProgress;
}
}
}
}
}
/* 00000778-00000848 .text _draw__13daObjRcloud_cFv */
bool daObjRcloud_c::_draw() {
/* Nonmatching */
g_env_light.settingTevStruct(TEV_TYPE_BG0, &current.pos, &tevStr);
g_env_light.setLightTevColorType(mpModel, &tevStr);
J3DModelData* modelData = mpModel->getModelData();
mBtkAnm.entry(modelData, mBtkAnm.getFrame());
mpModel->calc();
mpModel->calcMaterial();
setTexMtx();
mpModel->diff();
mpModel->entry();
mpModel->viewCalc();
return TRUE;
}
/* 00000848-00000868 .text daObjRcloud_Create__FP10fopAc_ac_c */
static cPhs_State daObjRcloud_Create(fopAc_ac_c* i_this) {
return ((daObjRcloud_c*)i_this)->_create();
return static_cast<daObjRcloud_c*>(i_this)->_create();
}
/* 00000868-0000088C .text daObjRcloud_Delete__FP13daObjRcloud_c */
static BOOL daObjRcloud_Delete(daObjRcloud_c* i_this) {
return ((daObjRcloud_c*)i_this)->_delete();
return i_this->_delete();
}
/* 0000088C-000008B0 .text daObjRcloud_Execute__FP13daObjRcloud_c */
static BOOL daObjRcloud_Execute(daObjRcloud_c* i_this) {
return ((daObjRcloud_c*)i_this)->_execute();
return i_this->_execute();
}
/* 000008B0-000008D4 .text daObjRcloud_Draw__FP13daObjRcloud_c */
static BOOL daObjRcloud_Draw(daObjRcloud_c* i_this) {
return ((daObjRcloud_c*)i_this)->_draw();
return i_this->_draw();
}
/* 000008D4-000008DC .text daObjRcloud_IsDelete__FP13daObjRcloud_c */
@@ -112,7 +275,11 @@ actor_process_profile_definition g_profile_Obj_Rcloud = {
/* Leaf SubMtd */ &g_fopAc_Method.base,
/* Priority */ PRIO_Obj_Rcloud,
/* Actor SubMtd */ &l_daObjRcloud_Method,
#if VERSION == VERSION_DEMO
/* Status */ fopAcStts_UNK40000_e,
#else
/* Status */ fopAcStts_UNK4000_e | fopAcStts_UNK40000_e,
#endif
/* Group */ fopAc_ACTOR_e,
/* CullType */ fopAc_CULLBOX_CUSTOM_e,
};