d_a_obj_damcps debug equivalent (#2904)

* d_a_obj_damcps initial

* d_a_obj_damcps guard

* d_a_obj_damcps pr comments
This commit is contained in:
Niklas Bauer 2025-12-02 21:44:39 +01:00 committed by GitHub
parent 2260191fe6
commit d2d45c58ee
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 260 additions and 19 deletions

View File

@ -1,6 +1,51 @@
#ifndef D_A_OBJ_DAMCPS_H
#define D_A_OBJ_DAMCPS_H
#include "f_op/f_op_actor_mng.h"
#include "d/d_cc_d.h"
#include "f_op/f_op_actor.h"
#include "m_Do/m_Do_hostIO.h"
/**
* @ingroup actors-objects
* @class daObjDamCps_c
* @brief Damage Cylinder
*
* @details
*
*/
class daObjDamCps_c : public fopAc_ac_c {
#ifdef DEBUG
public:
daObjDamCps_c() {};
void initBaseMtx();
void setBaseMtx();
int Create();
int create();
int execute();
int draw();
int _delete();
u8 getSwNo();
private:
/* 0x0570 */ dCcD_Stts mStts;
/* 0x05AC */ dCcD_Cps mCps;
/* 0x06F0 */ cM3dGCpsS mCapsule;
/* 0x070C */ Mtx mMtx;
/* 0x073C */ cXyz mScale;
#endif
};
class daObjDamCps_HIO_c : public mDoHIO_entry_c {
public:
daObjDamCps_HIO_c();
void genMessage(JORMContext*);
virtual ~daObjDamCps_HIO_c() {};
/* 0x08 */ f32 field_0x08;
/* 0x0C */ u8 mAdj;
/* 0x0E */ csXyz mAngle;
/* 0x14 */ cXyz mScale;
};
#endif /* D_A_OBJ_DAMCPS_H */

View File

@ -1,25 +1,221 @@
/**
* @file d_a_obj_damCps.cpp
*
*/
*
*/
#include "d/dolzel_rel.h" // IWYU pragma: keep
#include "d/dolzel_rel.h" // IWYU pragma: keep
#include "d/actor/d_a_obj_damCps.h"
extern actor_process_profile_definition g_profile_Obj_DamCps = {
fpcLy_CURRENT_e, // mLayerID
7, // mListID
fpcPi_CURRENT_e, // mListPrio
PROC_Obj_DamCps, // mProcName
&g_fpcLf_Method.base, // sub_method
sizeof(fopAc_ac_c), // mSize
0, // mSizeOther
0, // mParameters
&g_fopAc_Method.base, // sub_method
629, // mPriority
NULL, // sub_method
0x00040100, // mStatus
fopAc_ACTOR_e, // mActorType
fopAc_CULLBOX_CUSTOM_e, // cullType
#ifdef DEBUG
#include "d/d_debug_viewer.h"
static daObjDamCps_HIO_c l_HIO;
static cull_box l_cull_box = {
{-20.0f, 0.0f, -20.0f},
{20.0f, 100.0f, 20.0f},
};
static dCcD_SrcCps l_cps_src = {
{
{0x0, {{0x400, 0x0, 0x1d}, {0x0, 0x0}, 0x11}}, // mObj
{dCcD_SE_SWORD, 0x0, 0x1, 0x0, 0x0}, // mGObjAt
{dCcD_SE_NONE, 0x0, 0x0, 0x0, 0x4}, // mGObjTg
{0x0}, // mGObjCo
}, // mObjInf
{
{{0.0f, 0.0f, 0.0f}, {0.0f, 0.0f, 0.0f}, 30.0f}, // mCps
} // mCpsAttr
};
daObjDamCps_HIO_c::daObjDamCps_HIO_c() {
field_0x08 = 0.0f;
mAdj = false;
mAngle.setall(0x0);
mScale.setall(1.0f);
}
void daObjDamCps_HIO_c::genMessage(JORMContext* ctx) {
// Damage Cylinder
ctx->genLabel("ダメージ円柱", 0, 0, NULL, 0xffff, 0xffff, 0x200, 0x18);
// Adjustment
ctx->genCheckBox("調整", &mAdj, 1, 0, NULL, 0xffff, 0xffff, 0x200, 0x18);
// X Angle
ctx->genSlider("X角度", &mAngle.x, -0x7fff, 0x7fff, 0, NULL, 0xffff, 0xffff, 0x200, 0x18);
// Y Angle
ctx->genSlider("Y角度", &mAngle.y, -0x7fff, 0x7fff, 0, NULL, 0xffff, 0xffff, 0x200, 0x18);
// X Scale
ctx->genSlider("Xスケール", &mScale.x, 0.0f, 25.5f, 0, NULL, 0xffff, 0xffff, 0x200, 0x18);
// Y Scale
ctx->genSlider("Yスケール", &mScale.y, 0.0f, 25.5f, 0, NULL, 0xffff, 0xffff, 0x200, 0x18);
}
void daObjDamCps_c::initBaseMtx() {
mScale = scale;
setBaseMtx();
}
void daObjDamCps_c::setBaseMtx() {
mDoMtx_stack_c::transS(current.pos.x, current.pos.y, current.pos.z);
mDoMtx_stack_c::YrotM(shape_angle.y);
mDoMtx_stack_c::XrotM(shape_angle.x);
MTXCopy(mDoMtx_stack_c::get(), mMtx);
}
int daObjDamCps_c::Create() {
cXyz start = cXyz(0.0f, 0.0f, 0.0f);
cXyz end = cXyz(0.0f, 100.0f, 0.0f);
f32 radius = scale.x * 30.0f;
end.y *= scale.y;
mDoMtx_stack_c::transS(current.pos);
mDoMtx_stack_c::YrotM(shape_angle.y);
mDoMtx_stack_c::XrotM(shape_angle.x);
mDoMtx_stack_c::multVec(&start, &start);
mDoMtx_stack_c::multVec(&end, &end);
mCapsule.mStart = start;
mCapsule.mEnd = end;
mCapsule.mRadius = radius;
mCps.cM3dGCps::Set(mCapsule);
mCps.CalcAtVec();
initBaseMtx();
fopAcM_SetMtx(this, mMtx);
mStts.Init(0xff, 0xff, this);
mCps.Set(l_cps_src);
mCps.SetStts(&mStts);
fopAcM_setCullSizeBox(this, l_cull_box.min.x * scale.x, l_cull_box.min.y * scale.y,
l_cull_box.min.z * scale.x, l_cull_box.max.x * scale.x,
l_cull_box.max.y * scale.y, l_cull_box.max.z * scale.x);
return 1;
}
int daObjDamCps_c::create() {
fopAcM_ct(this, daObjDamCps_c);
if (!Create()) {
return cPhs_ERROR_e;
}
l_HIO.entryHIO("ダメージ円柱"); // Damage Cylinder
return cPhs_COMPLEATE_e;
}
int daObjDamCps_c::execute() {
if (l_HIO.mAdj) {
shape_angle.x = l_HIO.mAngle.x;
shape_angle.y = l_HIO.mAngle.y;
scale.x = l_HIO.mScale.x;
scale.y = l_HIO.mScale.y;
} else {
shape_angle.x = home.angle.x;
shape_angle.y = home.angle.y;
scale.x = mScale.x;
scale.y = mScale.y;
}
if (!fopAcM_isSwitch(this, getSwNo())) {
cXyz start = cXyz(0.0f, 0.0f, 0.0f);
cXyz end = cXyz(0.0f, 100.0f, 0.0f);
f32 radius = scale.x * 30.0f;
end.y *= scale.y;
mDoMtx_stack_c::transS(current.pos);
mDoMtx_stack_c::YrotM(shape_angle.y);
mDoMtx_stack_c::XrotM(shape_angle.x);
mDoMtx_stack_c::multVec(&start, &start);
mDoMtx_stack_c::multVec(&end, &end);
mCapsule.mStart = start;
mCapsule.mEnd = end;
mCapsule.mRadius = radius;
mCps.cM3dGCps::Set(mCapsule);
dComIfG_Ccsp()->Set(&mCps);
}
setBaseMtx();
return 1;
}
u8 daObjDamCps_c::getSwNo() {
return fopAcM_GetParamBit(this, 0, 8);
}
int daObjDamCps_c::draw() {
Mtx mtx;
GXColor color = (GXColor){0xff, 0x00, 0x00, 0x80};
if (fopAcM_isSwitch(this, getSwNo())) {
return 1;
}
mDoMtx_stack_c::transS(mCps.GetStart());
mDoMtx_stack_c::YrotM(shape_angle.y);
mDoMtx_stack_c::XrotM(shape_angle.x);
mDoMtx_stack_c::scaleM(scale.x * 30.0f, scale.y * 50.0f, scale.x * 30.0f);
mDoMtx_stack_c::transM(0.0f, 1.0f, 0.0f);
mDoMtx_stack_c::XrotM(0x4000);
MTXCopy(mDoMtx_stack_c::get(), mtx);
dDbVw_drawCylinderMXlu(mtx, color, 1);
return 1;
}
int daObjDamCps_c::_delete() {
l_HIO.removeHIO();
return 1;
}
static int daObjDamCps_Draw(daObjDamCps_c* i_this) {
return i_this->draw();
}
static int daObjDamCps_Execute(daObjDamCps_c* i_this) {
return i_this->execute();
}
static int daObjDamCps_Delete(daObjDamCps_c* i_this) {
fopAcM_RegisterDeleteID(i_this, "DamCps");
return i_this->_delete();
}
static int daObjDamCps_Create(fopAc_ac_c* i_this) {
fopAcM_RegisterCreateID(daObjDamCps_c, i_this, "DamCps");
return a_this->create();
}
static actor_method_class l_daObjDamCps_Method = {
(process_method_func)daObjDamCps_Create, (process_method_func)daObjDamCps_Delete,
(process_method_func)daObjDamCps_Execute, (process_method_func)NULL,
(process_method_func)daObjDamCps_Draw,
};
#endif
extern actor_process_profile_definition g_profile_Obj_DamCps = {
fpcLy_CURRENT_e, // mLayerID
7, // mListID
fpcPi_CURRENT_e, // mListPrio
PROC_Obj_DamCps, // mProcName
&g_fpcLf_Method.base, // sub_method
sizeof(daObjDamCps_c), // mSize
0, // mSizeOther
0, // mParameters
&g_fopAc_Method.base, // sub_method
629, // mPriority
#ifdef DEBUG
&l_daObjDamCps_Method, // sub_method
#else
NULL, // sub_method
#endif
0x00040100, // mStatus
fopAc_ACTOR_e, // mActorType
fopAc_CULLBOX_CUSTOM_e, // cullType
};