d_a_obj_brakeeff debug equivalent (#2906)

* d_a_obj_brakeeff fmt

* d_a_obj_brakeeff debug equivalent
This commit is contained in:
Niklas Bauer 2025-12-03 00:33:29 +01:00 committed by GitHub
parent d2d45c58ee
commit 9a69fa38c7
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 141 additions and 131 deletions

View File

@ -1,10 +1,9 @@
#ifndef D_A_OBJ_BRAKEEFF_H
#define D_A_OBJ_BRAKEEFF_H
#include "f_op/f_op_actor_mng.h"
#include "SSystem/SComponent/c_phase.h"
#include "d/d_cc_d.h"
#include "mtx.h"
#include "f_op/f_op_actor.h"
class J3DModel;
class mDoExt_brkAnm;

View File

@ -1,100 +1,90 @@
/**
* @file d_a_obj_brakeeff.cpp
*
*/
*
*/
#include "d/dolzel_rel.h" // IWYU pragma: keep
#include "d/dolzel_rel.h" // IWYU pragma: keep
#include "d/actor/d_a_obj_brakeeff.h"
#include "d/d_kankyo.h"
#include "m_Do/m_Do_ext.h"
#include "m_Do/m_Do_mtx.h"
#include "d/d_com_inf_game.h"
#include "d/d_bg_s.h"
#include "d/d_bg_w.h"
#include "dolphin/mtx.h"
#include "d/d_com_inf_game.h"
#include "d/d_cc_uty.h"
//Particle IDS
u16 e_name[5] = {
0x00, 0x00, 0x00, 0x00, 0x00
};
//model data per effect type
u32 bef_bmd[2] = {
5,
6,
};
//J3DAnmTevRegKey per effect type
u32 bef_brk[2] = {
9,
10,
};
#include "d/d_com_inf_game.h"
#include "d/d_kankyo.h"
#include "d/d_s_play.h"
#include "m_Do/m_Do_ext.h"
#include "m_Do/m_Do_mtx.h"
int daObj_Brakeeff_Draw(obj_brakeeff_class* i_this) {
fopAc_ac_c* a_this = static_cast<fopAc_ac_c*>(i_this);
J3DModel* model = i_this->mpModel;
g_env_light.settingTevStruct(64, &i_this->current.pos, &i_this->tevStr);
g_env_light.setLightTevColorType_MAJI(model->mModelData, &i_this->tevStr);
g_env_light.settingTevStruct(64, &a_this->current.pos, &i_this->tevStr);
g_env_light.setLightTevColorType_MAJI(model, &a_this->tevStr);
i_this->mpBrk->entry(model->getModelData());
mDoExt_modelUpdateDL(model);
return 1;
}
void obj_brakeeff_1(obj_brakeeff_class* i_this) {
cXyz pos (i_this->current.pos);
cXyz misc_vector(1.0f, 1.0f, 1.0f);
// Particle IDS
u16 e_name[5] = {0x00, 0x00, 0x00, 0x00, 0x00};
if(i_this->mEffectType == 0){
pos.y += 75.0f;
}
else if(i_this->mEffectType == 1){
pos.y += 50.0f;
void obj_brakeeff_1(obj_brakeeff_class* i_this) {
fopAc_ac_c* a_this = static_cast<fopAc_ac_c*>(i_this);
cXyz pos;
cXyz misc_vector;
pos = a_this->current.pos;
misc_vector.set(1.0f, 1.0f, 1.0f);
if (i_this->mEffectType == 0) {
pos.y += TREG_F(5) + 75.0f;
} else if (i_this->mEffectType == 1) {
pos.y += TREG_F(6) + 50.0f;
misc_vector.set(0.56f, 0.56f, 0.56f);
}
switch (i_this->mMiscTimer3) {
default:
return;
case 0:
i_this->mMiscTimer3 = 1;
i_this->mMiscTimers[0] = 60;
break;
case 1:
break;
}
case 0:
i_this->mMiscTimer3 = 1;
i_this->mMiscTimers[0] = 60;
// [[fallthrough]];
case 1:
for (int i = 0; i < 2; i++) {
i_this->mRuntimeParticleIds[i] =
dComIfGp_particle_set(i_this->mRuntimeParticleIds[i], e_name[i], &pos,
&a_this->current.angle, &misc_vector);
}
for(int i = 0; i < 2; i++){
i_this->mRuntimeParticleIds[i] = dComIfGp_particle_set(i_this->mRuntimeParticleIds[i], e_name[i],&pos, &i_this->current.angle, &misc_vector);
}
if (i_this->mMiscTimers[0] == 0) {
i_this->mDCcD_Sph.SetC(pos);
dComIfG_Ccsp()->Set(&i_this->mDCcD_Sph);
if(i_this->mMiscTimers[0] == 0){
i_this->mDCcD_Sph.SetC(pos);
dComIfG_Ccsp()->Set(&i_this->mDCcD_Sph);
if (i_this->mDCcD_Sph.ChkTgHit()) {
i_this->mMiscTimer3 = 2;
if(i_this->mDCcD_Sph.ChkTgHit()){
i_this->mMiscTimer3 = 2;
dCcU_AtInfo atInfo;
dCcU_AtInfo atInfo;
atInfo.mpCollider = i_this->mDCcD_Sph.GetTgHitObj();
at_power_check(&atInfo);
atInfo.mpCollider = i_this->mDCcD_Sph.GetTgHitObj();
at_power_check(&atInfo);
cXyz result = a_this->current.pos - atInfo.mpActor->current.pos;
a_this->current.angle.y = cM_atan2s(result.x, result.z);
cXyz result = i_this->current.pos - atInfo.mpActor->current.pos;
i_this->current.angle.y = cM_atan2s(result.x, result.z);
for(int i = 2; i < 5; i++){
dComIfGp_particle_set(e_name[i], &pos, &i_this->current.angle, &misc_vector);
for (int i = 2; i < 5; i++) {
dComIfGp_particle_set(e_name[i], &pos, &a_this->current.angle, &misc_vector);
}
fopAcM_delete(a_this);
}
fopAcM_delete(i_this);
}
}
}
void action(obj_brakeeff_class* i_this) {
switch (i_this->mMiscTimer2){
fopAc_ac_c* a_this = static_cast<fopAc_ac_c*>(i_this);
cXyz stack1;
cXyz stack2;
switch (i_this->mMiscTimer2) {
case 0:
obj_brakeeff_1(i_this);
break;
@ -102,20 +92,21 @@ void action(obj_brakeeff_class* i_this) {
}
int daObj_Brakeeff_Execute(obj_brakeeff_class* i_this) {
fopAc_ac_c* a_this = static_cast<fopAc_ac_c*>(i_this);
i_this->mMiscTimer1++;
for(int i = 0; i < 2; i++) {
if(i_this->mMiscTimers[i] != 0){
for (int i = 0; i < 2; i++) {
if (i_this->mMiscTimers[i] != 0) {
i_this->mMiscTimers[i]--;
}
}
action(i_this);
mDoMtx_stack_c::transS(i_this->current.pos.x, i_this->current.pos.y, i_this->current.pos.z);
mDoMtx_stack_c::YrotM(i_this->shape_angle.y);
mDoMtx_stack_c::XrotM(i_this->shape_angle.x);
mDoMtx_stack_c::ZrotM(i_this->shape_angle.z);
mDoMtx_stack_c::transS(a_this->current.pos.x, a_this->current.pos.y, a_this->current.pos.z);
mDoMtx_stack_c::YrotM((s16)a_this->shape_angle.y);
mDoMtx_stack_c::XrotM((s16)a_this->shape_angle.x);
mDoMtx_stack_c::ZrotM(a_this->shape_angle.z);
i_this->mpModel->setBaseTRMtx(mDoMtx_stack_c::get());
MTXCopy(mDoMtx_stack_c::get(), i_this->mStoredMatrix);
@ -130,45 +121,61 @@ int daObj_Brakeeff_IsDelete(obj_brakeeff_class* i_this) {
}
int daObj_Brakeeff_Delete(obj_brakeeff_class* i_this) {
fopAc_ac_c* a_this = static_cast<fopAc_ac_c*>(i_this);
fopAcM_RegisterDeleteID(i_this, "Obj_Brakeeff");
dComIfG_resDelete(&i_this->mRequestOfPhase, "Obj_Bef");
dComIfG_Bgsp().Release(i_this->mpDBgW);
return 1;
}
// model data per effect type
u32 bef_bmd[2] = {
5,
6,
};
// J3DAnmTevRegKey per effect type
u32 bef_brk[2] = {
9,
10,
};
int useHeapInit(fopAc_ac_c* i_this) {
obj_brakeeff_class* a_this = static_cast<obj_brakeeff_class*>(i_this);
J3DModelData* modelData = static_cast<J3DModelData*>(dComIfG_getObjectRes("Obj_Bef", bef_bmd[a_this->mEffectType]));
J3DModelData* modelData =
static_cast<J3DModelData*>(dComIfG_getObjectRes("Obj_Bef", bef_bmd[a_this->mEffectType]));
a_this->mpModel = mDoExt_J3DModel__create(modelData, 0x80000,0x11000084);
JUT_ASSERT(339, modelData != 0);
a_this->mpModel = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084);
if (a_this->mpModel == NULL) {
return 0;
}
a_this->mpBrk = new mDoExt_brkAnm();
if(!a_this->mpBrk){
if (!a_this->mpBrk) {
return 0;
}
J3DAnmTevRegKey* tev_anm = static_cast<J3DAnmTevRegKey*>(dComIfG_getObjectRes("Obj_Bef", bef_brk[a_this->mEffectType]));
if (!a_this->mpBrk->init(a_this->mpModel->getModelData(), tev_anm, 1, J3DFrameCtrl::EMode_NONE, 1.0f, 0, -1)) {
if (!a_this->mpBrk->init(
a_this->mpModel->getModelData(),
(J3DAnmTevRegKey*)dComIfG_getObjectRes("Obj_Bef", bef_brk[a_this->mEffectType]), 1,
J3DFrameCtrl::EMode_NONE, 1.0f, 0, -1))
{
return 0;
}
a_this->mpDBgW = new dBgW();
if(!a_this->mpDBgW){
if (!a_this->mpDBgW) {
return 0;
}
cBgD_t* cbgd = (cBgD_t *)dComIfG_getObjectRes("Obj_Bef", 13);
u32 res = a_this->mpDBgW->Set(cbgd, 1, &a_this->mStoredMatrix);
if(res == 1){
if (a_this->mpDBgW->Set((cBgD_t*)dComIfG_getObjectRes("Obj_Bef", 13), 1,
&a_this->mStoredMatrix) == 1)
{
return 0;
}
@ -176,67 +183,71 @@ int useHeapInit(fopAc_ac_c* i_this) {
return 1;
}
int daObj_Brakeeff_Create(fopAc_ac_c* i_this) {
static dCcD_SrcSph cc_sph_src = {
{
{0x0, {{0x0, 0x0, 0x0}, {0x20, 0x11}, 0x0}}, // mObj
{dCcD_SE_NONE, 0x0, 0x0, 0x0, 0x0}, // mGObjAt
{dCcD_SE_NONE, 0x0, 0x0, 0x0, 0x2}, // mGObjTg
{0x0}, // mGObjCo
}, // mObjInf
{
{{0.0f, 0.0f, 0.0f}, 40.0f} // mSph
} // mSphAttr
};
int daObj_Brakeeff_Create(fopAc_ac_c* a_this) {
obj_brakeeff_class* i_this = static_cast<obj_brakeeff_class*>(a_this);
fopAcM_ct(i_this, obj_brakeeff_class);
obj_brakeeff_class* a_this = static_cast<obj_brakeeff_class*>(i_this);
int res_load_result = dComIfG_resLoad(&i_this->mRequestOfPhase, "Obj_Bef");
if (res_load_result == cPhs_COMPLEATE_e) {
OS_REPORT("OBJ_BRAKEEFF PARAM %x\n", fopAcM_GetParam(a_this));
fopAcM_ct(a_this, obj_brakeeff_class);
i_this->mEffectType = fopAcM_GetParam(a_this);
OS_REPORT("OBJ_BRAKEEFF//////////////OBJ_BRAKEEFF SET 1 !!\n");
int res_load_result = dComIfG_resLoad(&a_this->mRequestOfPhase, "Obj_Bef");
if (!fopAcM_entrySolidHeap(a_this, useHeapInit, 0x4b000)) {
OS_REPORT("//////////////OBJ_BRAKEEFF SET NON !!\n");
return cPhs_ERROR_e;
}
if(res_load_result == cPhs_COMPLEATE_e){
a_this->mEffectType = fopAcM_GetParam(i_this);
OS_REPORT("//////////////OBJ_BRAKEEFF SET 2 !!\n");
bool is_heap_set = fopAcM_entrySolidHeap(i_this, useHeapInit,0x4b000);
if (dComIfG_Bgsp().Regist(i_this->mpDBgW, i_this)) {
return cPhs_ERROR_e;
}
if(!is_heap_set) return cPhs_ERROR_e;
static dCcD_SrcSph cc_sph_src = {
{
{0x0, {{0x0, 0x0, 0x0}, {0x20, 0x11}, 0x0}}, // mObj
{dCcD_SE_NONE, 0x0, 0x0, 0x0, 0x0}, // mGObjAt
{dCcD_SE_NONE, 0x0, 0x0, 0x0, 0x2}, // mGObjTg
{0x0}, // mGObjCo
}, // mObjInf
{
{{0.0f, 0.0f, 0.0f}, 40.0f} // mSph
} // mSphAttr
};
bool is_registered = dComIfG_Bgsp().Regist(a_this->mpDBgW, i_this);
if(is_registered) return cPhs_ERROR_e;
fopAcM_SetMtx(a_this, i_this->mpModel->getBaseTRMtx());
i_this->mDCcD_Stts.Init(255, 0, a_this);
i_this->mDCcD_Sph.Set(cc_sph_src);
i_this->mDCcD_Sph.SetStts(&i_this->mDCcD_Stts);
fopAcM_SetMtx(i_this, a_this->mpModel->getBaseTRMtx());
a_this->mDCcD_Stts.Init(255, 0, i_this);
a_this->mDCcD_Sph.Set(cc_sph_src);
a_this->mDCcD_Sph.SetStts(&a_this->mDCcD_Stts);
daObj_Brakeeff_Execute(a_this);
daObj_Brakeeff_Execute(i_this);
}
return res_load_result;
}
actor_method_class l_daObj_Brakeeff_Method = {
(process_method_func)daObj_Brakeeff_Create,
(process_method_func)daObj_Brakeeff_Delete,
(process_method_func)daObj_Brakeeff_Execute,
(process_method_func)daObj_Brakeeff_IsDelete,
(process_method_func)daObj_Brakeeff_Create, (process_method_func)daObj_Brakeeff_Delete,
(process_method_func)daObj_Brakeeff_Execute, (process_method_func)daObj_Brakeeff_IsDelete,
(process_method_func)daObj_Brakeeff_Draw,
};
extern actor_process_profile_definition g_profile_OBJ_BEF = {
fpcLy_CURRENT_e, // mLayerID
3, // mListID
fpcPi_CURRENT_e, // mListPrio
PROC_OBJ_BEF, // mProcName
&g_fpcLf_Method.base, // sub_method
sizeof(obj_brakeeff_class), // mSize
0, // mSizeOther
0, // mParameters
&g_fopAc_Method.base, // sub_method
39, // mPriority
&l_daObj_Brakeeff_Method, // sub_method
0x00040100, // mStatus
fopAc_ACTOR_e, // mActorType
fopAc_CULLBOX_7_e, // cullType
};
fpcLy_CURRENT_e, // mLayerID
3, // mListID
fpcPi_CURRENT_e, // mListPrio
PROC_OBJ_BEF, // mProcName
&g_fpcLf_Method.base, // sub_method
sizeof(obj_brakeeff_class), // mSize
0, // mSizeOther
0, // mParameters
&g_fopAc_Method.base, // sub_method
39, // mPriority
&l_daObj_Brakeeff_Method, // sub_method
0x00040100, // mStatus
fopAc_ACTOR_e, // mActorType
fopAc_CULLBOX_7_e, // cullType
};