Files
tp/src/d/actor/d_a_obj_cblock.cpp
T
LagoLunatic 559d389e3d Fix dPnt struct (#2361)
* Fix dPnt struct

* Fix Vec warning
2025-03-30 15:45:59 -07:00

512 lines
16 KiB
C++

/**
* @file d_a_obj_cblock.cpp
*
*/
#include "d/actor/d_a_obj_cblock.h"
#include "d/d_cc_d.h"
#include "Z2AudioLib/Z2Instances.h"
#include "d/d_com_inf_game.h"
#include "d/d_path.h"
#include "d/actor/d_a_player.h"
#include "dol2asm.h"
/* 80BC5A0C-80BC5A48 0000EC 003C+00 1/1 0/0 0/0 .text initBaseMtx__11daObjCBlk_cFv */
void daObjCBlk_c::initBaseMtx() {
model1->setBaseScale(scale);
setBaseMtx();
}
/* 80BC5A48-80BC5ABC 000128 0074+00 1/1 0/0 0/0 .text setBaseMtx__11daObjCBlk_cFv */
void daObjCBlk_c::setBaseMtx() {
mDoMtx_stack_c::transS(current.pos.x, current.pos.y,current.pos.z);
mDoMtx_stack_c::YrotM(shape_angle.y);
model1->setBaseTRMtx(mDoMtx_stack_c::get());
MTXCopy(mDoMtx_stack_c::get(), mBgMtx);
}
/* ############################################################################################## */
/* 80BC6A38-80BC6A50 000000 0018+00 5/5 0/0 0/0 .rodata l_cull_box */
static Vec const l_cull_box[2] = {
{-250.0f, 0.0f, -450.0f},
{250.0f, 250.0f, 400.0f},
};
UNK_REL_DATA
/* 80BC6AF4-80BC6AF8 -00001 0004+00 3/3 0/0 0/0 .data l_arcName */
static char* l_arcName = "P_Cblock";
/* 80BC6AF8-80BC6B28 000024 0030+00 0/0 0/0 0/0 .data l_side_co_offset */
static f32 l_side_co_offset[12] = {
-255.0f, 0.0f, -30.0f, -135.0f,
0.0f, -30.0f, 135, 0.0f,
-30.0f, 255.0f, 0.0f, -30.0f,
};
/* 80BC6B28-80BC6B6C 000054 0044+00 1/1 0/0 0/0 .data l_cyl_src */
static dCcD_SrcCyl l_cyl_src = {
{
{0x0, {{0x0, 0x0, 0x0}, {0x0, 0x0}, 0x19}}, // mObj
{dCcD_SE_NONE, 0x0, 0x0, 0x0, 0x0}, // mGObjAt
{dCcD_SE_NONE, 0x0, 0x0, 0x0, 0x6}, // mGObjTg
{0x0}, // mGObjCo
}, // mObjInf
{
{0.0f, 0.0f, 0.0f}, // mCenter
60.0f, // mRadius
300.0f // mHeight
} // mCyl
};
/* 80BC5ABC-80BC5CBC 00019C 0200+00 1/0 0/0 0/0 .text Create__11daObjCBlk_cFv */
int daObjCBlk_c::Create() {
u8 pathId = getPathID();
roomPath = dPath_GetRoomPath(pathId, fopAcM_GetHomeRoomNo(this));
swNo = getSwNo();
arg0 = getArg0();
if (pathId != 0xff) {
u8 pnt_index;
if (fopAcM_isSwitch(this, swNo)) {
pnt_index = 1;
} else {
pnt_index = 0;
}
dPnt* pnt = dPath_GetPnt(roomPath, pnt_index);
JUT_ASSERT(284, pnt != 0)
current.pos = pnt->m_position;
}
initBaseMtx();
fopAcM_SetMtx(this, model1->getBaseTRMtx());
stts.Init(0xff, 0xff, this);
for (int i = 0; i < 4; i++) {
cyls[i].Set(l_cyl_src);
cyls[i].SetStts(&stts);
}
fopAcM_setCullSizeBox(this, l_cull_box[0].x, l_cull_box[0].y, l_cull_box[0].z, l_cull_box[1].x,
l_cull_box[1].y, l_cull_box[1].z);
cXyz acStack_40(0.0f, 0.0f, 50.0f);
mDoMtx_stack_c::YrotS(current.angle.y);
mDoMtx_stack_c::multVec(&acStack_40, &acStack_40);
chain_s* pChain = chains;
cXyz* pos = field_0xc24;
getChainBasePos(&pChain->position);
cXyz cStack_4c(pChain->position);
for (int i = 0; i < 7; i++) {
*pos = cStack_4c + acStack_40;
cStack_4c = *pos;
pos++;
}
initWait();
return 1;
}
/* 80BC5CF8-80BC5E58 0003D8 0160+00 1/0 0/0 0/0 .text CreateHeap__11daObjCBlk_cFv */
int daObjCBlk_c::CreateHeap() {
J3DModelData* modelData = (J3DModelData*)dComIfG_getObjectRes(l_arcName, 4);
JUT_ASSERT(350, modelData != 0);
model1 = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084);
if (model1 == NULL) {
return 0;
}
chains = new chain_s[6];
if (chains == NULL) {
return 0;
}
modelData = (J3DModelData*)dComIfG_getObjectRes(l_arcName, 5);
JUT_ASSERT(369, modelData != 0);
chain_s* pChain = chains;
for (int i = 0; i < 6; i++) {
pChain->model = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084);
if (pChain->model == NULL) {
return 0;
}
pChain++;
}
modelData = (J3DModelData*)dComIfG_getObjectRes(l_arcName, 6);
JUT_ASSERT(386, modelData != 0);
model2 = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084);
if (model2 == NULL) {
return 0;
}
return 1;
}
/* 80BC5E58-80BC5E94 000538 003C+00 1/1 0/0 0/0 .text __dt__Q211daObjCBlk_c7chain_sFv */
daObjCBlk_c::chain_s::~chain_s() {
}
/* 80BC5E94-80BC5E98 000574 0004+00 1/1 0/0 0/0 .text __ct__Q211daObjCBlk_c7chain_sFv */
daObjCBlk_c::chain_s::chain_s() {
}
static inline void dummylfunc() {
static daObjCBlk_c::modeFunc l_func[2] = {
&daObjCBlk_c::modeWait,
&daObjCBlk_c::modeWalk,
};
}
/* 80BC5E98-80BC6020 000578 0188+00 1/1 0/0 0/0 .text create__11daObjCBlk_cFv */
int daObjCBlk_c::create() {
fopAcM_SetupActor(this, daObjCBlk_c);
int rv = dComIfG_resLoad(&phase, l_arcName);
if (rv == cPhs_COMPLEATE_e) {
rv = MoveBGCreate(l_arcName, 9, dBgS_MoveBGProc_TypicalRotY, 0x1000, NULL);
if (rv == cPhs_ERROR_e) {
return rv;
}
OS_REPORT("CHAIN BLOCK:%x\n", fopAcM_GetParam(this));
}
return rv;
}
/* 80BC6260-80BC6270 000940 0010+00 1/0 0/0 0/0 .text Execute__11daObjCBlk_cFPPA3_A4_f */
int daObjCBlk_c::Execute(f32 (**mtx)[3][4]) {
*mtx = &mBgMtx;
return 1;
}
/* 80BC6270-80BC627C 000950 000C+00 2/2 0/0 0/0 .text initWait__11daObjCBlk_cFv */
void daObjCBlk_c::initWait() {
field_0xc1f = 0;
}
/* 80BC627C-80BC6414 00095C 0198+00 1/0 0/0 0/0 .text modeWait__11daObjCBlk_cFv */
void daObjCBlk_c::modeWait() {
daPy_py_c* player = daPy_getPlayerActorClass();
bool bVar1 = false;
cXyz cStack_2c;
cXyz cStack_38;
cXyz cStack_44(0.0f, 0.0f, 1.0f);
getChainBasePos(&cStack_2c);
cStack_38 = cStack_2c - chains[5].position;
mDoMtx_stack_c::YrotS(shape_angle.y);
mDoMtx_stack_c::multVec(&cStack_44, &cStack_44);
cStack_38.normalizeZP();
cStack_44.normalizeZP();
f32 dVar7 = fabs(cStack_38.inprod(cStack_44));
if (dVar7 > 0.95000005f) {
bVar1 = true;
}
if (field_0xc1c != 0 && field_0xc1e != 0) {
setPower(power);
if (bVar1) {
field_0xca3++;
if (!checkWall() && player->getBaseAnimeFrame() > 6.0f && player->getBaseAnimeFrame() < 8.0f &&
field_0xca3 > 8)
{
initWalk();
}
}
} else {
field_0xca3 = 0;
}
}
/* 80BC6414-80BC6430 000AF4 001C+00 1/1 0/0 0/0 .text initWalk__11daObjCBlk_cFv */
void daObjCBlk_c::initWalk() {
walkTimer = 13;
field_0xca6 = 2520;
field_0xc1f = 1;
}
/* 80BC6430-80BC65CC 000B10 019C+00 1/0 0/0 0/0 .text modeWalk__11daObjCBlk_cFv */
void daObjCBlk_c::modeWalk() {
cLib_calcTimer(&walkTimer);
f32 dVar5 = cM_scos(field_0xca6 * (13 - walkTimer));
dVar5 = (1.0f - dVar5) * 0.5f;
cXyz local_58(0.0f, 0.0f, 1.0f);
mDoMtx_stack_c::YrotS(home.angle.y);
mDoMtx_stack_c::multVec(&local_58, &local_58);
current.pos.x = home.pos.x + local_58.x * (50.0f * (field_0xca2 + dVar5));
current.pos.z = home.pos.z + local_58.z * (50.0f * (field_0xca2 + dVar5));
setPower(power);
fopAcM_seStartLevel(this, Z2SE_OBJ_CBLOCK_SLIDEMOVE, 0);
if (walkTimer == 0) {
initWait();
field_0xca2++;
}
}
/* 80BC6C54-80BC6C58 00000C 0001+03 0/0 0/0 0/0 .bss @1107 */
#pragma push
#pragma force_active on
static u8 lit_1107[1 + 3 /* padding */];
#pragma pop
/* 80BC6C58-80BC6C5C 000010 0001+03 0/0 0/0 0/0 .bss @1105 */
#pragma push
#pragma force_active on
static u8 lit_1105[1 + 3 /* padding */];
#pragma pop
/* 80BC6C5C-80BC6C60 000014 0001+03 0/0 0/0 0/0 .bss @1104 */
#pragma push
#pragma force_active on
static u8 lit_1104[1 + 3 /* padding */];
#pragma pop
/* 80BC6C60-80BC6C64 000018 0001+03 0/0 0/0 0/0 .bss @1099 */
#pragma push
#pragma force_active on
static u8 lit_1099[1 + 3 /* padding */];
#pragma pop
/* 80BC6C64-80BC6C68 00001C 0001+03 0/0 0/0 0/0 .bss @1097 */
#pragma push
#pragma force_active on
static u8 lit_1097[1 + 3 /* padding */];
#pragma pop
/* 80BC6C68-80BC6C6C 000020 0001+03 0/0 0/0 0/0 .bss @1095 */
#pragma push
#pragma force_active on
static u8 lit_1095[1 + 3 /* padding */];
#pragma pop
/* 80BC6C6C-80BC6C70 000024 0001+03 0/0 0/0 0/0 .bss @1094 */
#pragma push
#pragma force_active on
static u8 lit_1094[1 + 3 /* padding */];
#pragma pop
/* 80BC6C70-80BC6C74 000028 0001+03 0/0 0/0 0/0 .bss @1057 */
#pragma push
#pragma force_active on
static u8 lit_1057[1 + 3 /* padding */];
#pragma pop
/* 80BC6C74-80BC6C78 00002C 0001+03 0/0 0/0 0/0 .bss @1055 */
#pragma push
#pragma force_active on
static u8 lit_1055[1 + 3 /* padding */];
#pragma pop
/* 80BC6C78-80BC6C7C 000030 0001+03 0/0 0/0 0/0 .bss @1053 */
#pragma push
#pragma force_active on
static u8 lit_1053[1 + 3 /* padding */];
#pragma pop
/* 80BC6C7C-80BC6C80 000034 0001+03 0/0 0/0 0/0 .bss @1052 */
#pragma push
#pragma force_active on
static u8 lit_1052[1 + 3 /* padding */];
#pragma pop
/* 80BC6C80-80BC6C84 000038 0001+03 0/0 0/0 0/0 .bss @1014 */
#pragma push
#pragma force_active on
static u8 lit_1014[1 + 3 /* padding */];
#pragma pop
/* 80BC6C84-80BC6C88 00003C 0001+03 0/0 0/0 0/0 .bss @1012 */
#pragma push
#pragma force_active on
static u8 lit_1012[1 + 3 /* padding */];
#pragma pop
/* 80BC6C88-80BC6C8C 000040 0001+03 0/0 0/0 0/0 .bss @1010 */
#pragma push
#pragma force_active on
static u8 lit_1010[1 + 3 /* padding */];
#pragma pop
/* 80BC6C8C-80BC6C90 000044 0001+03 0/0 0/0 0/0 .bss @1009 */
#pragma push
#pragma force_active on
static u8 lit_1009[1 + 3 /* padding */];
#pragma pop
/* 80BC6C9C-80BC6CA8 000054 000C+00 1/2 0/0 0/0 .bss l_chainOffset */
static cXyz l_chainOffset(0.0f, 105.0f, 30.0f);
/* 80BC65CC-80BC6648 000CAC 007C+00 2/2 0/0 0/0 .text getChainBasePos__11daObjCBlk_cFP4cXyz */
void daObjCBlk_c::getChainBasePos(cXyz* pPos) {
*pPos = l_chainOffset;
mDoMtx_stack_c::transS(current.pos);
mDoMtx_stack_c::YrotM(current.angle.y);
mDoMtx_stack_c::multVec(pPos, pPos);
}
/* 80BC6648-80BC66DC 000D28 0094+00 2/2 0/0 0/0 .text setPower__11daObjCBlk_cFf */
void daObjCBlk_c::setPower(f32 power) {
daPy_py_c* player = daPy_getPlayerActorClass();
chain_s* pChain = chains;
cXyz local_28;
local_28 = pChain[4].position - pChain[5].position;
s16 angle = cM_atan2s(local_28.x, local_28.z);
player->setOutPower(power, angle, 0);
}
/* ############################################################################################## */
/* 80BC6A78-80BC6A7C 000040 0004+00 0/0 0/0 0/0 .rodata @4103 */
#pragma push
#pragma force_active on
SECTION_RODATA static f32 const lit_4103 = -6.0f;
COMPILER_STRIP_GATE(0x80BC6A78, &lit_4103);
#pragma pop
/* 80BC6A7C-80BC6A80 000044 0004+00 0/0 0/0 0/0 .rodata @4104 */
#pragma push
#pragma force_active on
SECTION_RODATA static f32 const lit_4104 = 3.0f / 40.0f;
COMPILER_STRIP_GATE(0x80BC6A7C, &lit_4104);
#pragma pop
/* 80BC6A80-80BC6A84 000048 0004+00 0/0 0/0 0/0 .rodata @4105 */
#pragma push
#pragma force_active on
SECTION_RODATA static f32 const lit_4105 = 100.0f;
COMPILER_STRIP_GATE(0x80BC6A80, &lit_4105);
#pragma pop
/* 80BC6A84-80BC6A88 00004C 0004+00 0/0 0/0 0/0 .rodata @4106 */
#pragma push
#pragma force_active on
SECTION_RODATA static f32 const lit_4106 = 15.0f;
COMPILER_STRIP_GATE(0x80BC6A84, &lit_4106);
#pragma pop
/* 80BC6A88-80BC6A90 000050 0004+04 0/0 0/0 0/0 .rodata @4107 */
#pragma push
#pragma force_active on
SECTION_RODATA static f32 const lit_4107[1 + 1 /* padding */] = {
35.0f,
/* padding */
0.0f,
};
COMPILER_STRIP_GATE(0x80BC6A88, &lit_4107);
#pragma pop
/* 80BC6A90-80BC6A98 000058 0008+00 0/0 0/0 0/0 .rodata @4310 */
#pragma push
#pragma force_active on
SECTION_RODATA static u8 const lit_4310[8] = {
0x3F, 0xE0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
};
COMPILER_STRIP_GATE(0x80BC6A90, &lit_4310);
#pragma pop
/* 80BC6A98-80BC6AA0 000060 0008+00 0/0 0/0 0/0 .rodata @4311 */
#pragma push
#pragma force_active on
SECTION_RODATA static u8 const lit_4311[8] = {
0x40, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
};
COMPILER_STRIP_GATE(0x80BC6A98, &lit_4311);
#pragma pop
/* 80BC6AA0-80BC6AA8 000068 0008+00 0/0 0/0 0/0 .rodata @4312 */
#pragma push
#pragma force_active on
SECTION_RODATA static u8 const lit_4312[8] = {
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
};
COMPILER_STRIP_GATE(0x80BC6AA0, &lit_4312);
#pragma pop
/* 80BC6AA8-80BC6AAC 000070 0004+00 0/0 0/0 0/0 .rodata @4313 */
#pragma push
#pragma force_active on
SECTION_RODATA static f32 const lit_4313 = 195.0f;
COMPILER_STRIP_GATE(0x80BC6AA8, &lit_4313);
#pragma pop
/* 80BC6AAC-80BC6AB0 000074 0004+00 0/0 0/0 0/0 .rodata @4314 */
#pragma push
#pragma force_active on
SECTION_RODATA static f32 const lit_4314 = 210.0f;
COMPILER_STRIP_GATE(0x80BC6AAC, &lit_4314);
#pragma pop
/* 80BC66DC-80BC6868 000DBC 018C+00 1/1 0/0 0/0 .text checkWall__11daObjCBlk_cFv */
BOOL daObjCBlk_c::checkWall() {
cXyz acStack_30[2] = {cXyz(-95.0f, 5.0f, 1.0f), cXyz(95.0f, 5.0f, 1.0f)};
cXyz cStack_40(0.0f, 0.0f, 1.0f);
cStack_40.z = 50.0f;
BOOL rv = FALSE;
for (int i = 0; i < 2; i++) {
cXyz cStack_4c(acStack_30[i]);
cXyz cStack_58(cStack_40);
mDoMtx_stack_c::YrotS(current.angle.y);
mDoMtx_stack_c::multVec(&cStack_4c, &cStack_4c);
cStack_4c += current.pos;
mDoMtx_stack_c::multVec(&cStack_58, &cStack_58);
cStack_58 += cStack_4c;
if (fopAcM_lc_c::lineCheck(&cStack_4c, &cStack_58, this)) {
rv = TRUE;
}
}
return rv;
}
/* 80BC6868-80BC6870 000F48 0008+00 1/0 0/0 0/0 .text Draw__11daObjCBlk_cFv */
int daObjCBlk_c::Draw() {
return 1;
}
/* 80BC6870-80BC68A4 000F50 0034+00 1/0 0/0 0/0 .text Delete__11daObjCBlk_cFv */
int daObjCBlk_c::Delete() {
dComIfG_resDelete(&phase, l_arcName);
return 1;
}
/* 80BC68A4-80BC68D0 000F84 002C+00 1/0 0/0 0/0 .text daObjCBlk_Draw__FP11daObjCBlk_c */
static int daObjCBlk_Draw(daObjCBlk_c* i_this) {
return i_this->MoveBGDraw();
}
/* 80BC68D0-80BC68F0 000FB0 0020+00 1/0 0/0 0/0 .text daObjCBlk_Execute__FP11daObjCBlk_c
*/
static int daObjCBlk_Execute(daObjCBlk_c* i_this) {
return i_this->MoveBGExecute();
}
/* 80BC68F0-80BC6910 000FD0 0020+00 1/0 0/0 0/0 .text daObjCBlk_Delete__FP11daObjCBlk_c
*/
static int daObjCBlk_Delete(daObjCBlk_c* i_this) {
return i_this->MoveBGDelete();
}
/* 80BC6910-80BC6930 000FF0 0020+00 1/0 0/0 0/0 .text daObjCBlk_Create__FP10fopAc_ac_c */
static int daObjCBlk_Create(fopAc_ac_c* i_this) {
fopAcM_GetID(i_this);
return static_cast<daObjCBlk_c*>(i_this)->create();
}
/* 80BC6CB4-80BC6CC4 00006C 000C+04 0/1 0/0 0/0 .bss l_smokeSetOffset */
static cXyz l_smokeSetOffset(0.0f, 0.0f, -200.0f);
AUDIO_INSTANCES;
/* 80BC6B9C-80BC6BBC -00001 0020+00 1/0 0/0 0/0 .data l_daObjCBlk_Method */
static actor_method_class l_daObjCBlk_Method = {
(process_method_func)daObjCBlk_Create,
(process_method_func)daObjCBlk_Delete,
(process_method_func)daObjCBlk_Execute,
NULL,
(process_method_func)daObjCBlk_Draw,
};
/* 80BC6BBC-80BC6BEC -00001 0030+00 0/0 0/0 1/0 .data g_profile_Obj_ChainBlock */
extern actor_process_profile_definition g_profile_Obj_ChainBlock = {
fpcLy_CURRENT_e, // mLayerID
3, // mListID
fpcPi_CURRENT_e, // mListPrio
PROC_Obj_ChainBlock, // mProcName
&g_fpcLf_Method.base, // sub_method
sizeof(daObjCBlk_c), // mSize
0, // mSizeOther
0, // mParameters
&g_fopAc_Method.base, // sub_method
597, // mPriority
&l_daObjCBlk_Method, // sub_method
0x00040000, // mStatus
fopAc_ACTOR_e, // mActorType
fopAc_CULLBOX_CUSTOM_e, // cullType
};
/* 80BC6AC8-80BC6AC8 000090 0000+00 0/0 0/0 0/0 .rodata @stringBase0 */