mirror of https://github.com/zeldaret/tp.git
2059 lines
67 KiB
C++
2059 lines
67 KiB
C++
/**
|
|
* @file d_a_obj_brg.cpp
|
|
*
|
|
*/
|
|
|
|
#include "d/actor/d_a_obj_brg.h"
|
|
#include "d/d_com_inf_game.h"
|
|
#include "d/d_s_play.h"
|
|
#include "SSystem/SComponent/c_math.h"
|
|
#include "d/d_cc_uty.h"
|
|
#include "d/actor/d_a_player.h"
|
|
#include "d/d_path.h"
|
|
#include "Z2AudioLib/Z2Instances.h"
|
|
|
|
/* 80BBC90C-80BBCCFC 0000EC 03F0+00 1/1 0/0 0/0 .text
|
|
* ride_call_back__FP4dBgWP10fopAc_ac_cP10fopAc_ac_c */
|
|
static void ride_call_back(dBgW* i_bgw, fopAc_ac_c* i_bgActor, fopAc_ac_c* i_rideActor) {
|
|
obj_brg_class* a_this = (obj_brg_class*)i_bgActor;
|
|
|
|
cXyz sp74 = a_this->mBr[0].field_0x0bc - i_rideActor->current.pos;
|
|
int var_r27 = JMAFastSqrt(sp74.x * sp74.x + sp74.z * sp74.z) / (a_this->field_0xaedc * 51.0f) - -0.5f;
|
|
|
|
if (var_r27 > a_this->field_0xb1ea - 1) {
|
|
var_r27 = a_this->field_0xb1ea - 1;
|
|
} else if (var_r27 < 0) {
|
|
var_r27 = 0;
|
|
}
|
|
|
|
br_s* br_p = &a_this->mBr[var_r27];
|
|
cXyz sp80;
|
|
cXyz sp8C;
|
|
cXyz sp98;
|
|
|
|
f32 var_f30;
|
|
if (a_this->mType & 5) {
|
|
var_f30 = 0.85f;
|
|
} else if (a_this->field_0xb1ed == 2) {
|
|
var_f30 = KREG_F(7) + 0.1f;
|
|
} else {
|
|
var_f30 = 1.0f;
|
|
}
|
|
|
|
cMtx_YrotS(*calc_mtx, -br_p->field_0x0d4.y);
|
|
|
|
sp80 = i_rideActor->current.pos - br_p->field_0x0bc;
|
|
MtxPosition(&sp80, &sp8C);
|
|
|
|
sp80 = i_rideActor->old.pos - br_p->field_0x0bc;
|
|
MtxPosition(&sp80, &sp98);
|
|
|
|
i_rideActor->speed.y = -5.0f;
|
|
|
|
f32 var_f29;
|
|
if (fopAcM_GetName(i_rideActor) == PROC_ALINK) {
|
|
var_f29 = 100.0f;
|
|
br_p->field_0x0e4 = -31.0f;
|
|
a_this->field_0xb1ef = 5;
|
|
} else if (fopAcM_GetName(i_rideActor) == PROC_NPC_KS) {
|
|
var_f29 = 70.0f;
|
|
br_p->field_0x0e4 = -20.0f;
|
|
i_rideActor->speed.y = -20.0f;
|
|
} else {
|
|
var_f29 = 50.0f;
|
|
br_p->field_0x0e4 = -10.0f;
|
|
}
|
|
|
|
var_f29 *= var_f30;
|
|
|
|
br_p->field_0x0e4 *= var_f30;
|
|
br_p->field_0x0e4 += var_f29 * ((a_this->field_0xaef0 * cM_ssin(a_this->field_0xaf1e)) * 0.03f);
|
|
|
|
br_p->field_0x0f2 = -sp8C.x * var_f29;
|
|
br_p->field_0x706 = 2;
|
|
|
|
sp74 = sp8C - sp98;
|
|
|
|
f32 var_f31 = var_f30 * (sp74.abs() * 0.3f);
|
|
if (var_f31 > 20.0f) {
|
|
var_f31 = 20.0f;
|
|
}
|
|
|
|
if (a_this->field_0xaee0 <= var_f31) {
|
|
a_this->field_0xaee0 = var_f31;
|
|
}
|
|
|
|
var_f31 = var_f30 * fabsf(sp74.x);
|
|
if (var_f31 > 50.0f) {
|
|
var_f31 = 50.0f;
|
|
}
|
|
|
|
if (a_this->field_0xaee4 <= var_f31) {
|
|
a_this->field_0xaee4 += 0.5f;
|
|
}
|
|
}
|
|
|
|
/* 80BBCD38-80BBD740 000518 0A08+00 1/0 0/0 0/0 .text daObj_Brg_Draw__FP13obj_brg_class
|
|
*/
|
|
static int daObj_Brg_Draw(obj_brg_class* i_this) {
|
|
fopAc_ac_c* a_this = (fopAc_ac_c*)i_this;
|
|
g_env_light.settingTevStruct(0x10, &a_this->current.pos, &a_this->tevStr);
|
|
|
|
if (i_this->field_0xb1f0) {
|
|
return 1;
|
|
}
|
|
|
|
br_s* br_p = i_this->mBr;
|
|
|
|
for (int i = 0; i < i_this->field_0xb1ea; i++, br_p++) {
|
|
g_env_light.setLightTevColorType_MAJI(br_p->mpBridgeModel, &a_this->tevStr);
|
|
|
|
dComIfGd_setListBG();
|
|
mDoExt_modelUpdateDL(br_p->mpBridgeModel);
|
|
dComIfGd_setList();
|
|
|
|
if (i_this->mType & 8) {
|
|
for (int j = 0; j < 2; j++) {
|
|
g_env_light.setLightTevColorType_MAJI(br_p->mpKnotModels[j], &a_this->tevStr);
|
|
mDoExt_modelUpdateDL(br_p->mpKnotModels[j]);
|
|
}
|
|
}
|
|
|
|
if (!(i_this->mType & 4) && (br_p->field_0x708 & 4)) {
|
|
cXyz sp74;
|
|
cXyz sp80;
|
|
cXyz sp8C;
|
|
cXyz sp98;
|
|
|
|
cMtx_YrotS(*calc_mtx, i_this->field_0xaf1e);
|
|
|
|
sp74.x = 0.0f;
|
|
sp74.y = 0.0f;
|
|
sp74.z = 1.0f;
|
|
MtxPosition(&sp74, &sp80);
|
|
|
|
sp8C = br_p->field_0x074[0] - br_p->field_0x074[1];
|
|
sp98 = br_p->field_0x050[0] - br_p->field_0x050[1];
|
|
|
|
if (!(i_this->mType & 1)) {
|
|
f32 var_f30;
|
|
if (i_this->mType & 8) {
|
|
var_f30 = 5.0f;
|
|
} else {
|
|
var_f30 = 3.0f;
|
|
}
|
|
|
|
f32* spFC = br_p->field_0x014.getSize(0);
|
|
f32* sp100 = br_p->field_0x014.getSize(2);
|
|
|
|
if (!(br_p->field_0x708 & 1)) {
|
|
for (int j = 0; j < 5; j++) {
|
|
*sp100 = var_f30;
|
|
*spFC = var_f30;
|
|
spFC++;
|
|
sp100++;
|
|
}
|
|
} else {
|
|
cXyz* spF4 = br_p->field_0x014.getPos(0);
|
|
cXyz* spF8 = br_p->field_0x014.getPos(2);
|
|
sp8C.x *= 0.25f;
|
|
sp8C.y *= 0.25f;
|
|
sp8C.z *= 0.25f;
|
|
|
|
f32 var_f29 = br_p->field_0x0fe[0] * cM_ssin(i_this->field_0xaf1e * 5);
|
|
for (int j = 0; j < 5; j++) {
|
|
*spFC = var_f30;
|
|
|
|
f32 var_f31;
|
|
if (j == 2) {
|
|
var_f31 = 1.0f;
|
|
|
|
if (br_p->field_0x704 <= 1) {
|
|
*spFC = 0.0f;
|
|
} else if (br_p->field_0x704 == 2) {
|
|
*spFC = 1.0f;
|
|
}
|
|
|
|
br_p->field_0x098[0] = *spF4;
|
|
} else if (j == 1 || j == 3) {
|
|
var_f31 = 0.7f;
|
|
} else {
|
|
var_f31 = 0.0f;
|
|
}
|
|
|
|
sp74.x = (sp8C.x * j) + var_f29 * (var_f31 * sp80.x);
|
|
sp74.y = (sp8C.y * j);
|
|
sp74.z = (sp8C.z * j) + var_f29 * (var_f31 * sp80.z);
|
|
|
|
*spF4 = br_p->field_0x074[1] + sp74;
|
|
*spF8 = br_p->field_0x074[0];
|
|
*sp100 = 0.0f;
|
|
|
|
spF4++;
|
|
spF8++;
|
|
spFC++;
|
|
sp100++;
|
|
}
|
|
}
|
|
|
|
spFC = br_p->field_0x014.getSize(1);
|
|
sp100 = br_p->field_0x014.getSize(3);
|
|
|
|
if (!(br_p->field_0x708 & 2)) {
|
|
for (int j = 0; j < 5; j++) {
|
|
*sp100 = var_f30;
|
|
*spFC = var_f30;
|
|
spFC++;
|
|
sp100++;
|
|
}
|
|
} else {
|
|
cXyz* spF4 = br_p->field_0x014.getPos(1);
|
|
cXyz* spF8 = br_p->field_0x014.getPos(3);
|
|
sp98.x *= 0.25f;
|
|
sp98.y *= 0.25f;
|
|
sp98.z *= 0.25f;
|
|
|
|
f32 var_f29 = br_p->field_0x0fe[1] * cM_ssin(i_this->field_0xaf1e * 5);
|
|
for (int j = 0; j < 5; j++) {
|
|
*spFC = var_f30;
|
|
|
|
f32 var_f31;
|
|
if (j == 2) {
|
|
var_f31 = 1.0f;
|
|
|
|
if (br_p->field_0x705 <= 1) {
|
|
*spFC = 0.0f;
|
|
} else if (br_p->field_0x705 == 2) {
|
|
*spFC = 1.0f;
|
|
}
|
|
|
|
br_p->field_0x098[1] = *spF4;
|
|
} else if (j == 1 || j == 3) {
|
|
var_f31 = 0.7f;
|
|
} else {
|
|
var_f31 = 0.0f;
|
|
}
|
|
|
|
sp74.x = (sp98.x * j) + var_f29 * (var_f31 * sp80.x);
|
|
sp74.y = (sp98.y * j);
|
|
sp74.z = (sp98.z * j) + var_f29 * (var_f31 * sp80.z);
|
|
|
|
*spF4 = br_p->field_0x050[1] + sp74;
|
|
*spF8 = br_p->field_0x050[0];
|
|
*sp100 = 0.0f;
|
|
|
|
spF4++;
|
|
spF8++;
|
|
spFC++;
|
|
sp100++;
|
|
}
|
|
}
|
|
|
|
static GXColor l_color = {0x96, 0x96, 0x96, 0xFF};
|
|
br_p->field_0x014.update(5, l_color, &a_this->tevStr);
|
|
dComIfGd_set3DlineMat(&br_p->field_0x014);
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!(i_this->mType & 4) && !(i_this->mType & 5)) {
|
|
cXyz spA4;
|
|
cXyz spB0;
|
|
|
|
if (i_this->field_0xb1ed == 1) {
|
|
spA4.x = WREG_F(9) + -150.0f;
|
|
spA4.y = WREG_F(10) + 430.0f;
|
|
spA4.z = WREG_F(11) + -300.0f + 50.0f;
|
|
} else if (i_this->field_0xb1ed == 2) {
|
|
spA4.x = (WREG_F(9) + -150.0f) - 500.0f;
|
|
spA4.y = WREG_F(10) + 430.0f + 900.0f;
|
|
spA4.z = (WREG_F(11) + -300.0f + 50.0f) - 700.0f;
|
|
} else {
|
|
spA4.x = WREG_F(9) + -120.0f;
|
|
spA4.y = WREG_F(10) + 350.0f;
|
|
spA4.z = WREG_F(11) + -80.0f;
|
|
}
|
|
|
|
cMtx_YrotS(*calc_mtx, a_this->home.angle.y);
|
|
MtxPosition(&spA4, &spB0);
|
|
|
|
cXyz* sp114 = i_this->field_0xae90.getPos(0);
|
|
sp114->x = a_this->home.pos.x + spB0.x;
|
|
sp114->y = a_this->home.pos.y + spB0.y;
|
|
sp114->z = a_this->home.pos.z + spB0.z;
|
|
|
|
if (i_this->field_0xb1ed == 1) {
|
|
spA4.y = WREG_F(10) + 430.0f + 20.0f;
|
|
spA4.z = -(WREG_F(11) + -300.0f - 50.0f);
|
|
} else if (i_this->field_0xb1ed == 2) {
|
|
spA4.y = WREG_F(10) + 430.0f + 20.0f + 900.0f;
|
|
spA4.z = -(WREG_F(11) + -300.0f - 50.0f - 700.0f);
|
|
} else {
|
|
spA4.z = -(WREG_F(19) + -80.0f + 50.0f - 80.0f);
|
|
spA4.y = WREG_F(18) + 350.0f + 20.0f;
|
|
}
|
|
|
|
sp114 = &i_this->field_0xae90.getPos(0)[i_this->field_0xaed8] + 1;
|
|
MtxPosition(&spA4, &spB0);
|
|
|
|
sp114->x = i_this->mEndPos.x + spB0.x;
|
|
sp114->y = i_this->mEndPos.y + spB0.y;
|
|
sp114->z = i_this->mEndPos.z + spB0.z;
|
|
|
|
spA4.x *= -1.0f;
|
|
|
|
if (i_this->field_0xb1ed == 1) {
|
|
spA4.y = WREG_F(10) + 430.0f;
|
|
spA4.z = WREG_F(11) + -300.0f + 50.0f;
|
|
} else if (i_this->field_0xb1ed == 2) {
|
|
spA4.y = WREG_F(10) + 430.0f + 900.0f;
|
|
spA4.z = (WREG_F(11) + -300.0f + 50.0f) - 700.0f;
|
|
} else {
|
|
spA4.z = WREG_F(11) + -80.0f;
|
|
spA4.y = WREG_F(10) + 350.0f;
|
|
}
|
|
|
|
MtxPosition(&spA4, &spB0);
|
|
|
|
sp114 = i_this->field_0xae90.getPos(1);
|
|
sp114->x = a_this->home.pos.x + spB0.x;
|
|
sp114->y = a_this->home.pos.y + spB0.y;
|
|
sp114->z = a_this->home.pos.z + spB0.z;
|
|
|
|
if (i_this->field_0xb1ed == 1) {
|
|
spA4.y = WREG_F(10) + 430.0f + 20.0f;
|
|
spA4.z = -(WREG_F(11) + -300.0f - 50.0f);
|
|
} else if (i_this->field_0xb1ed == 2) {
|
|
spA4.y = WREG_F(10) + 430.0f + 20.0f + 900.0f;
|
|
spA4.z = -(WREG_F(11) + -300.0f - 50.0f - 700.0f);
|
|
} else {
|
|
spA4.z = -(WREG_F(19) + -80.0f + 50.0f - 80.0f);
|
|
spA4.y = WREG_F(18) + 350.0f + 20.0f;
|
|
}
|
|
|
|
sp114 = &i_this->field_0xae90.getPos(1)[i_this->field_0xaed8] + 1;
|
|
MtxPosition(&spA4, &spB0);
|
|
|
|
sp114->x = i_this->mEndPos.x + spB0.x;
|
|
sp114->y = i_this->mEndPos.y + spB0.y;
|
|
sp114->z = i_this->mEndPos.z + spB0.z;
|
|
|
|
f32 var_f28;
|
|
if (i_this->mType & 8) {
|
|
var_f28 = 10.0f;
|
|
} else if (i_this->field_0xb1ed == 1) {
|
|
var_f28 = WREG_F(4) + 6.5f;
|
|
} else if (i_this->field_0xb1ed == 2) {
|
|
var_f28 = WREG_F(5) + 10.0f;
|
|
} else {
|
|
var_f28 = 5.0f;
|
|
}
|
|
|
|
static GXColor l_color = {0x96, 0x96, 0x96, 0xFF};
|
|
i_this->field_0xae90.update((u16)(i_this->field_0xaed8 + VREG_S(2) + 2), var_f28, l_color, 0, &a_this->tevStr);
|
|
dComIfGd_set3DlineMat(&i_this->field_0xae90);
|
|
}
|
|
|
|
return 1;
|
|
}
|
|
|
|
/* 80BC24E8-80BC24EC 000008 0001+03 1/1 0/0 0/0 .bss @1109 */
|
|
static u8 lit_1109[1 + 3 /* padding */];
|
|
|
|
/* 80BC24EC-80BC24F0 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
|
|
|
|
/* 80BC24F0-80BC24F4 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
|
|
|
|
/* 80BC24F4-80BC24F8 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
|
|
|
|
/* 80BC24F8-80BC24FC 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
|
|
|
|
/* 80BC24FC-80BC2500 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
|
|
|
|
/* 80BC2500-80BC2504 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
|
|
|
|
/* 80BC2504-80BC2508 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
|
|
|
|
/* 80BC2508-80BC250C 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
|
|
|
|
/* 80BC250C-80BC2510 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
|
|
|
|
/* 80BC2510-80BC2514 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
|
|
|
|
/* 80BC2514-80BC2518 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
|
|
|
|
/* 80BC2518-80BC251C 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
|
|
|
|
/* 80BC251C-80BC2520 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
|
|
|
|
/* 80BC2520-80BC2524 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
|
|
|
|
/* 80BC2524-80BC2528 -00001 0004+00 5/5 0/0 0/0 .bss None */
|
|
/* 80BC2524 0001+01 data_80BC2524 @1009 */
|
|
|
|
static u8 struct_80BC2524[2];
|
|
|
|
/* 80BC2526 0002+00 data_80BC2526 wy */
|
|
static s16 wy;
|
|
|
|
/* 80BBD740-80BBDA64 000F20 0324+00 1/1 0/0 0/0 .text control1__FP13obj_brg_classP4br_s
|
|
*/
|
|
static void control1(obj_brg_class* i_this, br_s* i_part) {
|
|
cXyz sp84;
|
|
cXyz sp90;
|
|
cXyz sp9C;
|
|
|
|
i_part++;
|
|
|
|
i_this->field_0xaf22 += i_this->field_0xaf26;
|
|
i_this->field_0xaf24 += i_this->field_0xaf28;
|
|
|
|
s16 var_r27;
|
|
if (i_this->field_0xb1ea > 10) {
|
|
var_r27 = 4000;
|
|
} else {
|
|
var_r27 = 8000;
|
|
}
|
|
|
|
cXyz spA8;
|
|
cXyz spB4;
|
|
|
|
sp84.x = i_this->field_0xaeec * cM_scos(i_this->field_0xaf22);
|
|
sp84.y = 0.0f;
|
|
sp84.z = 0.0f;
|
|
|
|
cMtx_YrotS(*calc_mtx, i_this->home.angle.y);
|
|
MtxPosition(&sp84, &spA8);
|
|
|
|
sp84.x = 1.0f;
|
|
MtxPosition(&sp84, &spB4);
|
|
|
|
cXyz spC0;
|
|
|
|
sp84.x = 0.0f;
|
|
sp84.z = i_this->field_0xaf30 * 5.0f;
|
|
|
|
cMtx_YrotS(*calc_mtx, wy);
|
|
MtxPosition(&sp84, &spC0);
|
|
|
|
sp84.x = 0.0f;
|
|
sp84.z = i_this->field_0xaedc * 50.0f;
|
|
|
|
for (int i = 1; i < i_this->field_0xb1ea; i++, i_part++) {
|
|
f32 var_f27 = (i_part->field_0x0e8 * 0.5f) + (((i_part->field_0x0ec * i_part->field_0x0e0) * 0.5f) + i_part->field_0x0b0.y);
|
|
f32 var_f29 = (i_this->field_0xaee8 * cM_ssin(i_this->field_0xaf22 + (i * var_r27))) * i_part->field_0x0e0;
|
|
f32 var_f26 = (i_this->field_0xaef0 * cM_ssin(i_this->field_0xaf24 + (i * (var_r27 + 1000)))) * i_part->field_0x0e0;
|
|
|
|
f32 var_f31 = spC0.x + ((spA8.x * i_part->field_0x0e0) + ((i_part->field_0x0b0.x - i_part[-1].field_0x0b0.x) + (var_f29 * spB4.x)));
|
|
f32 var_f28 = var_f26 + (var_f27 - i_part[-1].field_0x0b0.y);
|
|
f32 var_f30 = spC0.z + ((spA8.z * i_part->field_0x0e0) + ((i_part->field_0x0b0.z - i_part[-1].field_0x0b0.z) + (var_f29 * spB4.z)));
|
|
|
|
s16 spC6, spC8;
|
|
spC8 = (s16)cM_atan2s(var_f31, var_f30);
|
|
spC6 = -cM_atan2s(var_f28, JMAFastSqrt(var_f31 * var_f31 + var_f30 * var_f30));
|
|
|
|
cMtx_YrotS(*calc_mtx, spC8);
|
|
cMtx_XrotM(*calc_mtx, spC6);
|
|
MtxPosition(&sp84, &sp9C);
|
|
|
|
i_part->field_0x0b0.x = i_part[-1].field_0x0b0.x + sp9C.x;
|
|
i_part->field_0x0b0.y = i_part[-1].field_0x0b0.y + sp9C.y;
|
|
i_part->field_0x0b0.z = i_part[-1].field_0x0b0.z + sp9C.z;
|
|
}
|
|
}
|
|
|
|
/* 80BBDA64-80BBDC28 001244 01C4+00 1/1 0/0 0/0 .text control2__FP13obj_brg_classP4br_s
|
|
*/
|
|
static void control2(obj_brg_class* i_this, br_s* i_part) {
|
|
cXyz sp68;
|
|
cXyz sp74;
|
|
|
|
i_part += i_this->field_0xb1ea - 2;
|
|
|
|
sp68.x = 0.0f;
|
|
sp68.y = 0.0f;
|
|
sp68.z = i_this->field_0xaedc * 50.0f;
|
|
|
|
for (int i = 0; i < i_this->field_0xb1ea - 1; i++, i_part--) {
|
|
f32 var_f28 = (i_part->field_0x0e8 * 0.5f) + (((i_part->field_0x0ec * i_part->field_0x0e0) * 0.5f) + i_part->field_0x0b0.y);
|
|
f32 var_f29 = var_f28 - i_part[1].field_0x0b0.y;
|
|
f32 var_f31 = i_part->field_0x0b0.x - i_part[1].field_0x0b0.x;
|
|
f32 var_f30 = i_part->field_0x0b0.z - i_part[1].field_0x0b0.z;
|
|
|
|
s16 spC6, spC8;
|
|
spC8 = (s16)cM_atan2s(var_f31, var_f30);
|
|
spC6 = -cM_atan2s(var_f29, JMAFastSqrt(var_f31 * var_f31 + var_f30 * var_f30));
|
|
|
|
i_part[1].field_0x0d4.y = spC8;
|
|
i_part[1].field_0x0d4.x = spC6;
|
|
|
|
cMtx_YrotS(*calc_mtx, spC8);
|
|
cMtx_XrotM(*calc_mtx, spC6);
|
|
MtxPosition(&sp68, &sp74);
|
|
|
|
i_part->field_0x0b0.x = i_part[1].field_0x0b0.x + sp74.x;
|
|
i_part->field_0x0b0.y = i_part[1].field_0x0b0.y + sp74.y;
|
|
i_part->field_0x0b0.z = i_part[1].field_0x0b0.z + sp74.z;
|
|
}
|
|
}
|
|
|
|
/* 80BBDC28-80BBDCE8 001408 00C0+00 1/1 0/0 0/0 .text control3__FP13obj_brg_classP4br_s
|
|
*/
|
|
static void control3(obj_brg_class* i_this, br_s* i_part) {
|
|
f32 var_f31 = i_part->field_0x0b0.x - i_part[1].field_0x0b0.x;
|
|
f32 var_f29 = i_part->field_0x0b0.y - i_part[1].field_0x0b0.y;
|
|
f32 var_f30 = i_part->field_0x0b0.z - i_part[1].field_0x0b0.z;
|
|
|
|
i_part->field_0x0d4.y = cM_atan2s(var_f31, var_f30);
|
|
i_part->field_0x0d4.x = -cM_atan2s(var_f29, JMAFastSqrt(var_f31 * var_f31 + var_f30 * var_f30));
|
|
}
|
|
|
|
/* 80BBDCE8-80BBE008 0014C8 0320+00 1/1 0/0 0/0 .text cut_control1__FP13obj_brg_classP4br_s */
|
|
static void cut_control1(obj_brg_class* i_this, br_s* i_part) {
|
|
cXyz sp7C;
|
|
cXyz sp88;
|
|
|
|
i_part++;
|
|
|
|
cXyz sp94;
|
|
|
|
cMtx_YrotS(*calc_mtx, i_this->home.angle.y);
|
|
|
|
sp7C.x = 0.0f;
|
|
sp7C.y = 0.0f;
|
|
sp7C.z = 1.0f;
|
|
MtxPosition(&sp7C, &sp94);
|
|
|
|
cXyz spA0(0.0f, 0.0f, 0.0f);
|
|
|
|
if (fopAcM_GetRoomNo(i_this) == 4 && !dComIfGp_event_runCheck()) {
|
|
cMtx_YrotS(*calc_mtx, wy);
|
|
sp7C.x = 0.0f;
|
|
sp7C.y = 0.0f;
|
|
sp7C.z = i_this->field_0xaf30 * ((cM_ssin(i_this->field_0xaf1e) * 0.1f) + (TREG_F(7) + 0.05f));
|
|
MtxPosition(&sp7C, &spA0);
|
|
|
|
i_this->field_0xaef4 = i_this->field_0xaf30 * 3000.0f;
|
|
}
|
|
|
|
sp7C.z = i_this->field_0xaedc * 50.0f;
|
|
|
|
for (int i = 1; i < i_this->field_0xaed0; i++, i_part++) {
|
|
f32 var_f29 = i_part->field_0x0b0.y + i_part->field_0x0ec;
|
|
if (var_f29 < i_part->field_0x0dc + 30.0f) {
|
|
var_f29 = i_part->field_0x0dc + 30.0f;
|
|
i_part->field_0x707++;
|
|
}
|
|
|
|
f32 var_f28 = var_f29 - i_part[-1].field_0x0b0.y;
|
|
f32 var_f31 = (sp94.x + (i_part->field_0x0b0.x - i_part[-1].field_0x0b0.x)) + (spA0.x * (f32)(i - 1));
|
|
f32 var_f30 = (sp94.z + (i_part->field_0x0b0.z - i_part[-1].field_0x0b0.z)) + (spA0.z * (f32)(i - 1));
|
|
|
|
s16 var_r26 = (s16)cM_atan2s(var_f31, var_f30);
|
|
s16 var_r27 = -cM_atan2s(var_f28, JMAFastSqrt(var_f31 * var_f31 + var_f30 * var_f30));
|
|
|
|
i_part[-1].field_0x0d4.y = var_r26 + 0x8000;
|
|
i_part[-1].field_0x0d4.x = -var_r27;
|
|
|
|
if (i == i_this->field_0xaed0 - 1) {
|
|
i_part->field_0x0d4.y = var_r26 + 0x8000;
|
|
i_part->field_0x0d4.x = var_r27;
|
|
}
|
|
|
|
cMtx_YrotS(*calc_mtx, var_r26);
|
|
cMtx_XrotM(*calc_mtx, var_r27);
|
|
MtxPosition(&sp7C, &sp88);
|
|
|
|
i_part->field_0x0b0.x = i_part[-1].field_0x0b0.x + sp88.x;
|
|
i_part->field_0x0b0.y = i_part[-1].field_0x0b0.y + sp88.y;
|
|
i_part->field_0x0b0.z = i_part[-1].field_0x0b0.z + sp88.z;
|
|
}
|
|
}
|
|
|
|
/* 80BBE008-80BBE338 0017E8 0330+00 1/1 0/0 0/0 .text cut_control2__FP13obj_brg_classP4br_s */
|
|
static void cut_control2(obj_brg_class* i_this, br_s* i_part) {
|
|
cXyz sp7C;
|
|
cXyz sp88;
|
|
|
|
i_part += i_this->field_0xb1ea - 2;
|
|
|
|
cXyz sp94;
|
|
|
|
cMtx_YrotS(*calc_mtx, i_this->home.angle.y);
|
|
|
|
sp7C.x = 0.0f;
|
|
sp7C.y = 0.0f;
|
|
sp7C.z = 1.0f;
|
|
MtxPosition(&sp7C, &sp94);
|
|
|
|
cXyz spA0(0.0f, 0.0f, 0.0f);
|
|
|
|
if (fopAcM_GetRoomNo(i_this) == 4 && !dComIfGp_event_runCheck()) {
|
|
cMtx_YrotS(*calc_mtx, wy);
|
|
sp7C.x = 0.0f;
|
|
sp7C.y = 0.0f;
|
|
sp7C.z = i_this->field_0xaf30 * ((cM_ssin(i_this->field_0xaf1e) * 0.1f) + (TREG_F(7) + 0.05f));
|
|
MtxPosition(&sp7C, &spA0);
|
|
}
|
|
|
|
sp7C.z = i_this->field_0xaedc * 50.0f;
|
|
|
|
for (int i = 0; i < (i_this->field_0xb1ea - 1) - i_this->field_0xaed0; i++, i_part--) {
|
|
f32 var_f29 = i_part->field_0x0b0.y + i_part->field_0x0ec;
|
|
if (var_f29 < i_part->field_0x0dc + 30.0f) {
|
|
var_f29 = i_part->field_0x0dc + 30.0f;
|
|
i_part->field_0x707++;
|
|
}
|
|
|
|
f32 var_f28 = var_f29 - i_part[1].field_0x0b0.y;
|
|
f32 var_f31 = (sp94.x + (i_part->field_0x0b0.x - i_part[1].field_0x0b0.x)) + (spA0.x * (f32)i);
|
|
f32 var_f30 = (sp94.z + (i_part->field_0x0b0.z - i_part[1].field_0x0b0.z)) + (spA0.z * (f32)i);
|
|
|
|
s16 var_r27, var_r26;
|
|
var_r26 = (s16)cM_atan2s(var_f31, var_f30);
|
|
var_r27 = -cM_atan2s(var_f28, JMAFastSqrt(var_f31 * var_f31 + var_f30 * var_f30));
|
|
|
|
i_part[1].field_0x0d4.y = var_r26;
|
|
i_part[1].field_0x0d4.x = var_r27;
|
|
|
|
if (i == (i_this->field_0xb1ea - 2) - i_this->field_0xaed0) {
|
|
i_part->field_0x0d4.y = var_r26;
|
|
i_part->field_0x0d4.x = var_r27 + 0x8000;
|
|
}
|
|
|
|
cMtx_YrotS(*calc_mtx, var_r26);
|
|
cMtx_XrotM(*calc_mtx, var_r27);
|
|
MtxPosition(&sp7C, &sp88);
|
|
|
|
i_part->field_0x0b0.x = i_part[1].field_0x0b0.x + sp88.x;
|
|
i_part->field_0x0b0.y = i_part[1].field_0x0b0.y + sp88.y;
|
|
i_part->field_0x0b0.z = i_part[1].field_0x0b0.z + sp88.z;
|
|
}
|
|
}
|
|
|
|
/* 80BBE338-80BBE578 001B18 0240+00 1/1 0/0 0/0 .text himo_cut_control1__FP13obj_brg_classP4cXyzf
|
|
*/
|
|
static void himo_cut_control1(obj_brg_class* i_this, cXyz* param_1, f32 param_2) {
|
|
cXyz sp74;
|
|
cXyz sp80;
|
|
cXyz sp8C;
|
|
|
|
sp74.x = 0.0f;
|
|
sp74.y = 0.0f;
|
|
sp74.z = i_this->field_0xaf30 * 3.0f;
|
|
cMtx_YrotS(*calc_mtx, wy);
|
|
MtxPosition(&sp74, &sp8C);
|
|
|
|
sp74.x = 0.0f;
|
|
sp74.y = 0.0f;
|
|
sp74.z = param_2;
|
|
|
|
cXyz* var_r28 = param_1 + 1;
|
|
cXyz* temp_r27 = var_r28;
|
|
|
|
for (int i = 1; i < 5; i++, var_r28++) {
|
|
f32 var_f28 = (i_this->field_0xaf30 * cM_ssin((i_this->field_0xaf20 * 6000) + ((NREG_S(3) - 10000) * ((int)temp_r27 + i))) ) * (NREG_F(11) + 7.0f);
|
|
f32 var_f27 = (i_this->field_0xaf30 * cM_ssin((i_this->field_0xaf20 * 6000) + ((NREG_S(4) - 12000) * ((int)temp_r27 + i))) ) * (NREG_F(11) + 7.0f);
|
|
|
|
f32 var_f31 = var_f28 + (sp8C.x + (var_r28->x - var_r28[-1].x));
|
|
f32 var_f29 = (var_r28->y - var_r28[-1].y) - 10.0f;
|
|
f32 var_f30 = var_f27 + (sp8C.z + (var_r28->z - var_r28[-1].z));
|
|
|
|
s16 sp94 = (s16)cM_atan2s(var_f31, var_f30);
|
|
s16 sp92 = -cM_atan2s(var_f29, JMAFastSqrt(var_f31 * var_f31 + var_f30 * var_f30));
|
|
|
|
cMtx_YrotS(*calc_mtx, sp94);
|
|
cMtx_XrotM(*calc_mtx, sp92);
|
|
MtxPosition(&sp74, &sp80);
|
|
|
|
var_r28->x = var_r28[-1].x + sp80.x;
|
|
var_r28->y = var_r28[-1].y + sp80.y;
|
|
var_r28->z = var_r28[-1].z + sp80.z;
|
|
}
|
|
}
|
|
|
|
/* 80BC23AC-80BC23D8 000008 002C+00 1/1 0/0 0/0 .data ita_z_p */
|
|
static f32 ita_z_p[] = {
|
|
0.1f,
|
|
0.3f,
|
|
0.5f,
|
|
0.75f,
|
|
0.89999998f,
|
|
1.0f,
|
|
0.89999998f,
|
|
0.75f,
|
|
0.5f,
|
|
0.3f,
|
|
0.1f,
|
|
};
|
|
|
|
/* 80BBE578-80BBF21C 001D58 0CA4+00 1/1 0/0 0/0 .text obj_brg_move__FP13obj_brg_class */
|
|
static void obj_brg_move(obj_brg_class* i_this) {
|
|
fopAc_ac_c* a_this = (fopAc_ac_c*)i_this;
|
|
fopAc_ac_c* player = dComIfGp_getPlayer(0);
|
|
|
|
cXyz spD0;
|
|
cXyz spDC;
|
|
cXyz spE8;
|
|
|
|
br_s* part = i_this->mBr;
|
|
|
|
switch (i_this->field_0xaf1c) {
|
|
case 0:
|
|
i_this->field_0xb1e9 = 0;
|
|
i_this->field_0xaf1c = 2;
|
|
/* fallthrough */
|
|
case 2:
|
|
for (int i = 0; i < i_this->field_0xb1ea; i++) {
|
|
if ((i_this->mType & 1) == 1) {
|
|
i_this->mBr[i].field_0x0e0 = 1.0f;
|
|
} else {
|
|
i_this->mBr[i].field_0x0e0 = fabsf(sinf((i / (i_this->field_0xb1ea - 1)) * M_PI));
|
|
}
|
|
|
|
i_this->mBr[i].field_0x705 = 3;
|
|
i_this->mBr[i].field_0x704 = 3;
|
|
}
|
|
|
|
i_this->field_0xaf1c = 3;
|
|
/* fallthrough */
|
|
case 3:
|
|
i_this->field_0xaf1e += 3000;
|
|
part->field_0x0b0 = a_this->home.pos;
|
|
|
|
if ((i_this->mType & 1) == 1) {
|
|
cMtx_YrotS(*calc_mtx, i_this->home.angle.y);
|
|
spD0.x = (i_this->field_0xaeec * cM_scos(i_this->field_0xaf22)) * -2.0f;
|
|
spD0.y = 0.0f;
|
|
spD0.z = 0.0f;
|
|
MtxPosition(&spD0, &spDC);
|
|
|
|
part->field_0x0b0 += spDC;
|
|
}
|
|
|
|
control1(i_this, part);
|
|
part[i_this->field_0xb1ea - 1].field_0x0b0 = i_this->mEndPos;
|
|
|
|
if ((i_this->mType & 1) == 1) {
|
|
part[i_this->field_0xb1ea - 1].field_0x0b0 -= spDC;
|
|
}
|
|
|
|
control2(i_this, part);
|
|
control3(i_this, part);
|
|
|
|
spE8 = a_this->home.pos - part->field_0x0b0;
|
|
a_this->current.pos = part->field_0x0b0;
|
|
a_this->current.angle = part->field_0x0d4;
|
|
|
|
for (int i = 0; i < i_this->field_0xb1ea; i++, part++) {
|
|
part->field_0x0bc = part->field_0x0b0;
|
|
|
|
f32 var_f30 = ((f32)(i_this->field_0xb1ea - i) / (f32)i_this->field_0xb1ea) * 0.75f;
|
|
part->field_0x0bc.x += spE8.x * var_f30;
|
|
part->field_0x0bc.y += spE8.y * var_f30;
|
|
part->field_0x0bc.z += spE8.z * var_f30;
|
|
|
|
if (part->field_0x706) {
|
|
for (int j = -5; j < 6; j++) {
|
|
if (i + j > -1 && i + j < i_this->field_0xb1ea) {
|
|
cLib_addCalcAngleS2(&part[j].field_0x0f4, (f32)part->field_0x0f2 * ita_z_p[j + 5] * part[j].field_0x0e0, 4, 0x800);
|
|
cLib_addCalc2(&part[j].field_0x0e8, part->field_0x0e4 * ita_z_p[j + 5], 1.0f, 10.0f);
|
|
}
|
|
}
|
|
}
|
|
|
|
if (part->field_0x708 & 4 && (part->field_0x708 & 3) != 3) {
|
|
f32 var_f31 = 0.0f;
|
|
f32 var_f29 = -80.0f;
|
|
|
|
if ((part->field_0x708 & 3) == 1) {
|
|
var_f31 = 7000.0f;
|
|
var_f29 = -30.0f;
|
|
} else if ((part->field_0x708 & 3) == 2) {
|
|
var_f31 = -7000.0f;
|
|
var_f29 = -30.0f;
|
|
}
|
|
|
|
for (int j = -5; j < 6; j++) {
|
|
if (i + j > -1 && i + j < i_this->field_0xb1ea) {
|
|
cLib_addCalcAngleS2(&part[j].field_0x0f6, var_f31 * ita_z_p[j + 5] * part[j].field_0x0e0, 4, 0x800);
|
|
cLib_addCalc2(&part[j].field_0x0e8, var_f29 * ita_z_p[j + 5], 1.0f, 15.0f);
|
|
}
|
|
|
|
if ((part->field_0x708 & 3) == 0 && (i_this->mType & 4) == 0 && j > -3 && j < 3 && part[j].field_0x706 != 0) {
|
|
if (dComIfGp_event_runCheck()) {
|
|
i_this->field_0xaed4 = 0;
|
|
} else {
|
|
i_this->field_0xaed4 += 2;
|
|
}
|
|
|
|
if (i_this->field_0xaed4 > 100) {
|
|
i_this->field_0xaf1c = 4;
|
|
i_this->field_0xaed0 = i + j;
|
|
|
|
if (i_this->field_0xb1ef != 0) {
|
|
dComIfGp_getVibration().StartShock(5, 31, cXyz(0.0f, 1.0f, 0.0f));
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (part[j].field_0x0e4 < -200.0f) {
|
|
i_this->field_0xaf1c = 4;
|
|
i_this->field_0xaed0 = i + j;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
if ((part->field_0x708 & 4) != 0 && (part->field_0x0fe[0] != 0 || part->field_0x0fe[1] != 0)) {
|
|
f32 var_f26 = (f32)(part->field_0x0fe[0] | part->field_0x0fe[1]) * 150.0f;
|
|
f32 var_f31 = var_f26 * cM_ssin(i_this->field_0xaf26 * 4);
|
|
|
|
for (int j = -5; j < 6; j++) {
|
|
if (i + j > -1 && i + j < i_this->field_0xb1ea) {
|
|
part[j].field_0x0f6 += (var_f31 * ita_z_p[j + 5]) * part[j].field_0x0e0;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (part->field_0x706 != 0) {
|
|
part->field_0x706--;
|
|
}
|
|
|
|
part->field_0x0f2 = 0;
|
|
part->field_0x0d4.y = part->field_0x0f4 + part->field_0x0f6;
|
|
|
|
s16 sp138 = 0;
|
|
if (i_this->field_0xb1ec) {
|
|
if (i == 7) {
|
|
sp138 = 0x800;
|
|
} else if (i == 5) {
|
|
sp138 = -0x500;
|
|
} else if (i == 9) {
|
|
sp138 = -0x300;
|
|
}
|
|
}
|
|
|
|
cLib_addCalcAngleS2(&part->field_0x0f4, sp138, 4, 0x400);
|
|
cLib_addCalcAngleS2(&part->field_0x0f6, 0, 4, 0x400);
|
|
cLib_addCalc2(&part->field_0x0ec, -15.0f, 1.0f, 5.0f);
|
|
cLib_addCalc0(&part->field_0x0e8, 1.0f, 5.0f);
|
|
}
|
|
|
|
if (i_this->field_0xaed4 != 0) {
|
|
i_this->field_0xaed4--;
|
|
}
|
|
|
|
i_this->field_0xaef0 = i_this->field_0xaee0;
|
|
i_this->field_0xaee8 = i_this->field_0xaee0;
|
|
i_this->field_0xaeec = i_this->field_0xaee4;
|
|
i_this->field_0xaf28 = 3000;
|
|
i_this->field_0xaf26 = 1400;
|
|
|
|
f32 var_f28 = i_this->field_0xaf30 * 3.0f;
|
|
cLib_addCalc2(&i_this->field_0xaee0, var_f28, 0.1f, 0.1f);
|
|
cLib_addCalc2(&i_this->field_0xaee4, var_f28 * 0.3f, 0.1f, 0.05f);
|
|
break;
|
|
case 4:
|
|
for (int i = 0; i < i_this->field_0xb1ea; i++, part++) {
|
|
part->field_0x0ec = 0.0f;
|
|
}
|
|
|
|
i_this->field_0xaf1c = 5;
|
|
i_this->field_0xaf2c = 50;
|
|
i_this->field_0xaef4 = 4000.0f;
|
|
|
|
mDoAud_seStart(JA_SE_OBJ_BREAK_WOOD_L, NULL, 0, 0);
|
|
|
|
if (fopAcM_GetRoomNo(a_this) != 4) {
|
|
int sw = fopAcM_GetParam(a_this) >> 0x18;
|
|
if (sw != 0xFF) {
|
|
dComIfGs_onSwitch(sw, fopAcM_GetRoomNo(a_this));
|
|
}
|
|
}
|
|
/* fallthrough */
|
|
case 5:
|
|
br_s* var_r24 = i_this->mBr;
|
|
|
|
if (i_this->field_0xaf2c != 0) {
|
|
i_this->field_0xaf2c--;
|
|
}
|
|
|
|
i_this->field_0xaf1e += 4000;
|
|
var_r24->field_0x0b0 = a_this->home.pos;
|
|
|
|
cut_control1(i_this, var_r24);
|
|
var_r24[i_this->field_0xb1ea - 1].field_0x0b0 = i_this->mEndPos;
|
|
cut_control2(i_this, var_r24);
|
|
|
|
if (i_this->field_0xb1ed) {
|
|
u32 sp11C = (u32)(i_this->field_0xaf30 * 110.0f) - 10;
|
|
if (sp11C > 0x7F) {
|
|
sp11C = 0x7F;
|
|
}
|
|
|
|
Z2GetAudioMgr()->seStartLevel(Z2SE_OBJ_BROKENBRIDGE, &a_this->home.pos, sp11C, 0, 1.0f, 1.0f, -1.0f, -1.0f, 0);
|
|
Z2GetAudioMgr()->seStartLevel(Z2SE_OBJ_BROKENBRIDGE, &i_this->mEndPos, sp11C, 0, 1.0f, 1.0f, -1.0f, -1.0f, 0);
|
|
}
|
|
|
|
for (int i = 0; i < i_this->field_0xb1ea; i++, var_r24++) {
|
|
var_r24->field_0x0bc = var_r24->field_0x0b0;
|
|
cLib_addCalc2(&var_r24->field_0x0ec, -50.0f, 1.0f, 5.0f);
|
|
var_r24->field_0x0dc = -10000.0f;
|
|
|
|
if (i_this->field_0xb1f1 == 0 || (i < i_this->field_0xaed0 && i_this->field_0xb1f1 == 2) || (i >= i_this->field_0xaed0 && i_this->field_0xb1f1 == 1)) {
|
|
cLib_addCalcAngleS2(&var_r24->field_0x0d4.z, i_this->field_0xaef4 * cM_ssin(i_this->field_0xaf2e + (i * 10000)), 4, 0x800);
|
|
}
|
|
}
|
|
|
|
cLib_addCalc0(&i_this->field_0xaef4, 0.05f, 80.0f);
|
|
i_this->field_0xaf2e += 4500;
|
|
|
|
if (i_this->field_0xb1ec) {
|
|
spDC = i_this->mEndPos;
|
|
spDC.y = 3200.0f;
|
|
i_this->mCyl[0].SetC(spDC);
|
|
|
|
spDC = a_this->home.pos;
|
|
spDC.y = 3200.0f;
|
|
i_this->mCyl[1].SetC(spDC);
|
|
|
|
for (int i = 0; i < 2; i++) {
|
|
i_this->mCyl[i].SetR(60.0f);
|
|
dComIfG_Ccsp()->Set(&i_this->mCyl[i]);
|
|
|
|
if (i_this->field_0xb1f2[i] != 0) {
|
|
i_this->field_0xb1f2[i]--;
|
|
}
|
|
|
|
if (i_this->field_0xb1f2[i] == 0 && i_this->mCyl[i].ChkTgHit()) {
|
|
i_this->field_0xb1f2[i] = 10;
|
|
i_this->field_0xb1f1 = i + 1;
|
|
|
|
dCcU_AtInfo spC4;
|
|
spC4.mpCollider = i_this->mCyl[i].GetTgHitObj();
|
|
at_power_check(&spC4);
|
|
|
|
if (spC4.mAttackPower > 3) {
|
|
i_this->field_0xaef4 = 3000.0f;
|
|
} else {
|
|
i_this->field_0xaef4 = 1600.0f;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 80BBF21C-80BC0834 0029FC 1618+00 2/1 0/0 0/0 .text daObj_Brg_Execute__FP13obj_brg_class */
|
|
static int daObj_Brg_Execute(obj_brg_class* i_this) {
|
|
fopAc_ac_c* a_this = (fopAc_ac_c*)i_this;
|
|
daPy_py_c* player = (daPy_py_c*)dComIfGp_getPlayer(0);
|
|
|
|
cXyz spC4;
|
|
cXyz spD0;
|
|
cXyz spDC;
|
|
cXyz spE8;
|
|
|
|
camera_class* camera = dComIfGp_getCamera(0);
|
|
spC4 = a_this->current.pos - camera->lookat.eye;
|
|
|
|
if (i_this->field_0xb1ef != 0) {
|
|
i_this->field_0xb1ef--;
|
|
}
|
|
|
|
f32 sp1BC;
|
|
if (i_this->field_0xb1ed == 2) {
|
|
sp1BC = 5500.0f;
|
|
} else if (i_this->field_0xb1ed == 1) {
|
|
sp1BC = 4000.0f;
|
|
} else {
|
|
sp1BC = 2000.0f;
|
|
}
|
|
|
|
if (spC4.abs() > sp1BC) {
|
|
spD0 = camera->lookat.center - camera->lookat.eye;
|
|
|
|
cMtx_YrotS(*calc_mtx, -cM_atan2s(spD0.x, spD0.z));
|
|
MtxPosition(&spC4, &spD0);
|
|
|
|
if (spD0.z < 0.0f) {
|
|
i_this->field_0xb1f0 = 1;
|
|
return 1;
|
|
}
|
|
}
|
|
|
|
i_this->field_0xb1f0 = 0;
|
|
|
|
cXyz spF4;
|
|
cXyz sp100 = a_this->current.pos + ((i_this->mEndPos - a_this->current.pos) * 0.5f);
|
|
|
|
f32 sp1C0;
|
|
dKyw_get_AllWind_vec(&sp100, &spF4, &sp1C0);
|
|
|
|
if (sp1C0 > 0.6f) {
|
|
sp1C0 = 0.6f;
|
|
}
|
|
sp1C0 *= sp1C0;
|
|
|
|
cLib_addCalc2(&i_this->field_0xaf30, sp1C0, 0.1f, 0.03f);
|
|
wy = cM_atan2s(spF4.x, spF4.z);
|
|
i_this->field_0xaf20++;
|
|
|
|
obj_brg_move(i_this);
|
|
|
|
i_this->field_0xaed8 = 0;
|
|
|
|
br_s* part = i_this->mBr;
|
|
|
|
cXyz sp10C;
|
|
bool var_r25 = 0;
|
|
if (player->getBokoFlamePos(&sp10C)) {
|
|
var_r25 = 1;
|
|
}
|
|
|
|
f32 var_f26 = 0.0f;
|
|
f32 var_f29;
|
|
if (i_this->mType & 1) {
|
|
var_f29 = 1000.0f;
|
|
} else if (i_this->field_0xb1ed == 1) {
|
|
var_f29 = 250.0f;
|
|
} else if (i_this->field_0xb1ed == 2) {
|
|
var_f29 = 600.0f;
|
|
} else {
|
|
var_f29 = 200.0f;
|
|
}
|
|
|
|
for (int i = 0; i < i_this->field_0xb1ea; i++, part++) {
|
|
if (i_this->field_0xb1ed == 2) {
|
|
var_f26 = -300.0f * sinf(((f32)i / (f32)(i_this->field_0xb1ea - 1)) * M_PI);
|
|
} else if (i_this->field_0xb1ed == 1) {
|
|
var_f26 = -100.0f * sinf(((f32)i / (f32)(i_this->field_0xb1ea - 1)) * M_PI);
|
|
}
|
|
|
|
MtxTrans(part->field_0x0bc.x, part->field_0x0bc.y, part->field_0x0bc.z, 0);
|
|
cMtx_YrotM(*calc_mtx, part->field_0x0d4.y);
|
|
cMtx_XrotM(*calc_mtx, part->field_0x0d4.x);
|
|
cMtx_ZrotM(*calc_mtx, part->field_0x0d4.z);
|
|
|
|
if (i_this->field_0xaed0 != 0) {
|
|
f32 sp1CC;
|
|
if (i_this->field_0xaed0 < i) {
|
|
sp1CC = 30.0f;
|
|
} else {
|
|
sp1CC = -30.0f;
|
|
}
|
|
|
|
MtxTrans(0.0f, 0.0f, sp1CC, 1);
|
|
}
|
|
|
|
spC4.x = part->field_0x0c8.x * 99.0f;
|
|
spC4.y = 5.0f;
|
|
spC4.z = 0.0f;
|
|
MtxPosition(&spC4, &part->field_0x074[1]);
|
|
|
|
spC4.x *= -1.0f;
|
|
MtxPosition(&spC4, &part->field_0x050[1]);
|
|
|
|
spC4.y = -30.0f;
|
|
MtxPosition(&spC4, &part->field_0x050[2]);
|
|
|
|
spC4.x *= -1.0f;
|
|
MtxPosition(&spC4, &part->field_0x074[2]);
|
|
|
|
if (part->field_0x708 & 4) {
|
|
if (part->field_0x0f8 != 0) {
|
|
if (part->field_0x0f8 > 0) {
|
|
part->field_0x0f8--;
|
|
}
|
|
|
|
spC4.x = i_this->field_0xaedc * 66.0f;
|
|
spC4.y = 0.0f;
|
|
spC4.z = 0.0f;
|
|
MtxPosition(&spC4, &part->field_0x074[0]);
|
|
|
|
spC4.x *= -1.0f;
|
|
MtxPosition(&spC4, &part->field_0x050[0]);
|
|
|
|
part->field_0x074[0].y += var_f29 + var_f26;
|
|
part->field_0x050[0].y += var_f29 + var_f26;
|
|
|
|
if (i_this->mType & 8) {
|
|
MtxPush();
|
|
|
|
MtxTrans(part->field_0x074[0].x, part->field_0x074[0].y, part->field_0x074[0].z, 0);
|
|
cMtx_YrotM(*calc_mtx, a_this->current.angle.y);
|
|
MtxScale(2.0f, 2.0f, 2.0f, 1);
|
|
part->mpKnotModels[0]->setBaseTRMtx(*calc_mtx);
|
|
|
|
MtxTrans(part->field_0x050[0].x, part->field_0x050[0].y, part->field_0x050[0].z, 0);
|
|
cMtx_YrotM(*calc_mtx, a_this->current.angle.y);
|
|
MtxScale(2.0f, 2.0f, 2.0f, 1);
|
|
part->mpKnotModels[1]->setBaseTRMtx(*calc_mtx);
|
|
|
|
MtxPull();
|
|
}
|
|
|
|
if (i > 0 && i < i_this->field_0xb1ea - 2) {
|
|
f32 var_f30 = (part[1].field_0x074[0].y + part[-1].field_0x074[0].y) * 0.5f;
|
|
if (var_f30 < part->field_0x074[0].y) {
|
|
part->field_0x074[0].y = var_f30;
|
|
}
|
|
|
|
var_f30 = (part[1].field_0x050[0].y + part[-1].field_0x050[0].y) * 0.5f;
|
|
if (var_f30 < part->field_0x050[0].y) {
|
|
part->field_0x050[0].y = var_f30;
|
|
}
|
|
}
|
|
|
|
if ((i_this->mType & 2) && i == i_this->field_0xb1eb - 1) {
|
|
i_this->field_0xaf04 = part->field_0x074[0];
|
|
i_this->field_0xaf10 = part->field_0x050[0];
|
|
}
|
|
}
|
|
|
|
if (!(i_this->mType & 9)) {
|
|
dCcU_AtInfo spB8;
|
|
|
|
if (i_this->field_0xaed0 != 0) {
|
|
part->field_0x708 &= 0x1C;
|
|
}
|
|
|
|
if (part->mCyl[0].ChkTgHit() && part->field_0x0fe[0] < 10) {
|
|
part->mCyl[0].OnTgNoConHit();
|
|
part->field_0x0fe[0] = 20;
|
|
|
|
spB8.mpCollider = part->mCyl[0].GetTgHitObj();
|
|
at_power_check(&spB8);
|
|
|
|
if (!spB8.mpCollider->ChkAtType(0x10)) {
|
|
spB8.mAttackPower = 4;
|
|
}
|
|
|
|
part->field_0x704 -= spB8.mAttackPower;
|
|
if (part->field_0x704 < 1) {
|
|
part->field_0x708 &= 0x1E;
|
|
|
|
Z2GetAudioMgr()->seStartLevel(Z2SE_HIT_ROPE_CUT, &part->field_0x074[0], 0, dComIfGp_getReverb(fopAcM_GetRoomNo(a_this)), 1.0f, 1.0f, -1.0f, -1.0f, 0);
|
|
if (fopAcM_GetRoomNo(a_this) == 4) {
|
|
i_this->field_0xaf1c = 4;
|
|
i_this->field_0xaed0 = 10;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (part->mCyl[1].ChkTgHit() && part->field_0x0fe[1] < 10) {
|
|
part->mCyl[1].OnTgNoConHit();
|
|
part->field_0x0fe[1] = 20;
|
|
|
|
spB8.mpCollider = part->mCyl[1].GetTgHitObj();
|
|
at_power_check(&spB8);
|
|
|
|
if (!spB8.mpCollider->ChkAtType(0x10)) {
|
|
spB8.mAttackPower = 4;
|
|
}
|
|
|
|
part->field_0x705 -= spB8.mAttackPower;
|
|
if (part->field_0x705 < 1) {
|
|
part->field_0x708 &= 0x1D;
|
|
|
|
Z2GetAudioMgr()->seStartLevel(Z2SE_HIT_ROPE_CUT, &part->field_0x050[0], 0, dComIfGp_getReverb(fopAcM_GetRoomNo(a_this)), 1.0f, 1.0f, -1.0f, -1.0f, 0);
|
|
}
|
|
}
|
|
} else {
|
|
cXyz sp118;
|
|
sp118.z = 2.0f;
|
|
sp118.y = 2.0f;
|
|
sp118.x = 2.0f;
|
|
|
|
if (part->mCyl[0].ChkTgHit() && part->field_0x0fe[0] < 10) {
|
|
part->mCyl[0].OnTgNoConHit();
|
|
|
|
if (i_this->field_0xb1ed == 2) {
|
|
part->field_0x0fe[0] = 7;
|
|
} else {
|
|
part->field_0x0fe[0] = 15;
|
|
}
|
|
|
|
Z2GetAudioMgr()->seStartLevel(JA_SE_CM_MAGBALL_BOUND, &part->field_0x074[0], 0, dComIfGp_getReverb(fopAcM_GetRoomNo(a_this)), 1.0f, 1.0f, -1.0f, -1.0f, 0);
|
|
}
|
|
|
|
if (part->mCyl[1].ChkTgHit() && part->field_0x0fe[1] < 10) {
|
|
part->mCyl[1].OnTgNoConHit();
|
|
|
|
if (i_this->field_0xb1ed == 2) {
|
|
part->field_0x0fe[1] = 7;
|
|
} else {
|
|
part->field_0x0fe[1] = 15;
|
|
}
|
|
|
|
Z2GetAudioMgr()->seStartLevel(JA_SE_CM_MAGBALL_BOUND, &part->field_0x050[0], 0, dComIfGp_getReverb(fopAcM_GetRoomNo(a_this)), 1.0f, 1.0f, -1.0f, -1.0f, 0);
|
|
}
|
|
}
|
|
|
|
cXyz sp124(part->field_0x074[1]);
|
|
if (!(part->field_0x708 & 1)) {
|
|
sp124.y -= 10000.0f;
|
|
}
|
|
|
|
part->mCyl[0].SetC(sp124);
|
|
|
|
if (part->field_0x0fa != 0) {
|
|
part->field_0x0fa--;
|
|
|
|
if (part->field_0xc != NULL) {
|
|
mDoMtx_stack_c::transS(part->field_0x074[1].x, part->field_0x074[1].y + 100.0f, part->field_0x074[1].z);
|
|
part->field_0xc->setGlobalRTMatrix(mDoMtx_stack_c::get());
|
|
|
|
if (part->field_0x0fa == 0) {
|
|
part->field_0xc->becomeInvalidEmitter();
|
|
part->field_0xc = NULL;
|
|
}
|
|
}
|
|
|
|
if (part->field_0x0fa == 0) {
|
|
part->field_0x708 &= 0x1E;
|
|
}
|
|
} else if (var_r25) {
|
|
cXyz sp130;
|
|
|
|
if (!(i_this->mType & 9)) {
|
|
sp124.y += 100.0f;
|
|
|
|
sp130 = sp124 - sp10C;
|
|
sp130.y *= 0.4f;
|
|
|
|
if (sp130.abs() < 50.0f) {
|
|
part->field_0x0fa = 30;
|
|
}
|
|
}
|
|
}
|
|
|
|
sp124 = part->field_0x050[1];
|
|
if (!(part->field_0x708 & 2)) {
|
|
sp124.y -= 10000.0f;
|
|
}
|
|
|
|
part->mCyl[1].SetC(sp124);
|
|
|
|
if (part->field_0x0fc != 0) {
|
|
part->field_0x0fc--;
|
|
|
|
if (part->field_0x10 != NULL) {
|
|
mDoMtx_stack_c::transS(part->field_0x050[1].x, part->field_0x050[1].y + 100.0f, part->field_0x050[1].z);
|
|
part->field_0x10->setGlobalRTMatrix(mDoMtx_stack_c::get());
|
|
|
|
if (part->field_0x0fc == 0) {
|
|
part->field_0x10->becomeInvalidEmitter();
|
|
part->field_0x10 = NULL;
|
|
}
|
|
}
|
|
|
|
if (part->field_0x0fc == 0) {
|
|
part->field_0x708 &= 0x1D;
|
|
}
|
|
} else if (var_r25) {
|
|
cXyz sp13C;
|
|
|
|
if (!(i_this->mType & 9)) {
|
|
sp124.y += 100.0f;
|
|
|
|
sp13C = sp124 - sp10C;
|
|
sp13C.y *= 0.4f;
|
|
|
|
if (sp13C.abs() < 50.0f) {
|
|
part->field_0x0fc = 30;
|
|
}
|
|
}
|
|
}
|
|
|
|
dComIfG_Ccsp()->Set(&part->mCyl[0]);
|
|
dComIfG_Ccsp()->Set(&part->mCyl[1]);
|
|
}
|
|
|
|
for (int j = 0; j < 2; j++) {
|
|
if (part->field_0x0fe[j] != 0) {
|
|
part->field_0x0fe[j]--;
|
|
}
|
|
}
|
|
|
|
cMtx_YrotM(*calc_mtx, part->field_0x0f0);
|
|
|
|
if (i_this->field_0xb1eb <= i) {
|
|
part->field_0x0c8.z = 0.0f;
|
|
part->field_0x0c8.y = 0.0f;
|
|
part->field_0x0c8.x = 0.0f;
|
|
|
|
part->mpBridgeModel->setBaseScale(part->field_0x0c8);
|
|
part->field_0x708 = 0;
|
|
}
|
|
|
|
MtxTrans(0.0f, part->field_0x0c8.y * -3.0f, 0.0f, 1);
|
|
part->mpBridgeModel->setBaseTRMtx(*calc_mtx);
|
|
|
|
if (!(i_this->mType & 4) && !(i_this->mType & 1) && (part->field_0x708 & 4)) {
|
|
cXyz* sp1D4 = i_this->field_0xae90.getPos(0);
|
|
cXyz* sp1D8 = i_this->field_0xae90.getPos(1);
|
|
int sp1E4 = i_this->field_0xaed8 + 1;
|
|
|
|
cXyz sp148;
|
|
spC4.x = 0.0f;
|
|
spC4.y = 0.0f;
|
|
spC4.z = i_this->field_0xaf30;
|
|
spC4.z *= (cM_ssin((i_this->field_0xb1e9 * 1500) + (i_this->field_0xaf20 * 1400)) * 2.0f + 5.0f) * 0.15f;
|
|
|
|
cMtx_YrotS(*calc_mtx, wy);
|
|
MtxPosition(&spC4, &sp148);
|
|
|
|
if (part->field_0x708 & 1) {
|
|
sp1D4[sp1E4] = part->field_0x074[0];
|
|
} else {
|
|
cXyz sp154 = sp1D4[sp1E4 - 1] - sp1D4[sp1E4 + 1];
|
|
f32 sp1E8 = (f32)part->field_0x0fe[0] * cM_ssin(i_this->field_0xaf1e * 6);
|
|
|
|
sp1D4[sp1E4].x = sp148.x + sp154.x * 0.5f + sp1D4[sp1E4 + 1].x;
|
|
sp1D4[sp1E4].y = sp1E8 + sp154.y * 0.5f + sp1D4[sp1E4 + 1].y;
|
|
sp1D4[sp1E4].z = sp148.z + sp154.z * 0.5f + sp1D4[sp1E4 + 1].z;
|
|
|
|
cXyz* sp1DC = part->field_0x014.getPos(0);
|
|
cXyz* sp1E0 = part->field_0x014.getPos(2);
|
|
|
|
f32 var_f28;
|
|
f32 var_f27;
|
|
if (part->field_0x708 & 0x10) {
|
|
var_f28 = 0.0f;
|
|
var_f27 = i_this->field_0xaedc * 25.0f;
|
|
} else {
|
|
var_f27 = i_this->field_0xaedc * 16.0f;
|
|
var_f28 = var_f27;
|
|
}
|
|
|
|
*sp1DC = sp1D4[sp1E4];
|
|
himo_cut_control1(i_this, sp1DC, var_f28);
|
|
|
|
*sp1E0 = part->field_0x074[1];
|
|
himo_cut_control1(i_this, sp1E0, var_f27);
|
|
}
|
|
|
|
if (part->field_0x708 & 2) {
|
|
sp1D8[sp1E4] = part->field_0x050[0];
|
|
} else {
|
|
cXyz sp160 = sp1D8[sp1E4 - 1] - sp1D8[sp1E4 + 1];
|
|
f32 sp1E8 = (f32)part->field_0x0fe[1] * cM_ssin(i_this->field_0xaf1e * 6);
|
|
|
|
sp1D8[sp1E4].x = sp148.x + sp160.x * 0.5f + sp1D8[sp1E4 + 1].x;
|
|
sp1D8[sp1E4].y = sp1E8 + sp160.y * 0.5f + sp1D8[sp1E4 + 1].y;
|
|
sp1D8[sp1E4].z = sp148.z + sp160.z * 0.5f + sp1D8[sp1E4 + 1].z;
|
|
|
|
cXyz* sp1DC = part->field_0x014.getPos(1);
|
|
cXyz* sp1E0 = part->field_0x014.getPos(3);
|
|
|
|
f32 var_f28;
|
|
f32 var_f27;
|
|
if (part->field_0x708 & 0x10) {
|
|
var_f28 = 0.0f;
|
|
var_f27 = i_this->field_0xaedc * 25.0f;
|
|
} else {
|
|
var_f27 = i_this->field_0xaedc * 16.0f;
|
|
var_f28 = var_f27;
|
|
}
|
|
|
|
*sp1DC = sp1D8[sp1E4];
|
|
himo_cut_control1(i_this, sp1DC, var_f28);
|
|
|
|
*sp1E0 = part->field_0x050[1];
|
|
himo_cut_control1(i_this, sp1E0, var_f27);
|
|
}
|
|
}
|
|
}
|
|
|
|
i_this->mpBgW->CopyBackVtx();
|
|
|
|
Vec* vtx_tbl = (Vec*)i_this->mpBgW->GetVtxTbl();
|
|
|
|
int sp1F8 = 0;
|
|
for (int i = 0; i < i_this->mpBgW->GetVtxNum(); i++) {
|
|
int temp = i >> 2;
|
|
|
|
if (i < i_this->field_0xb1eb) {
|
|
switch (i & 3) {
|
|
case 0:
|
|
vtx_tbl[i] = i_this->mBr[temp].field_0x074[2];
|
|
break;
|
|
case 1:
|
|
vtx_tbl[i] = i_this->mBr[temp].field_0x050[2];
|
|
break;
|
|
case 2:
|
|
vtx_tbl[i] = i_this->mBr[temp].field_0x074[1];
|
|
break;
|
|
case 3:
|
|
vtx_tbl[i] = i_this->mBr[temp].field_0x050[1];
|
|
break;
|
|
}
|
|
|
|
if (temp == 0 || temp == i_this->field_0xb1eb - 1) {
|
|
cMtx_YrotS(*calc_mtx, i_this->mBr[temp].field_0x0d4.y);
|
|
cMtx_XrotM(*calc_mtx, i_this->mBr[temp].field_0x0d4.x);
|
|
|
|
spC4.y = 0.0f;
|
|
spC4.x = 0.0f;
|
|
|
|
if (temp == 0) {
|
|
spC4.z = 50.0f;
|
|
} else if (i_this->field_0xb1eb == i_this->field_0xb1ea) {
|
|
spC4.z = -50.0f;
|
|
} else {
|
|
spC4.z = -40.0f;
|
|
}
|
|
|
|
MtxPosition(&spC4, &spD0);
|
|
vtx_tbl[i].x += spD0.x;
|
|
vtx_tbl[i].y += spD0.y;
|
|
vtx_tbl[i].z += spD0.z;
|
|
}
|
|
sp1F8 = i;
|
|
} else {
|
|
vtx_tbl[i] = vtx_tbl[sp1F8];
|
|
}
|
|
|
|
if (i_this->field_0xaf1c > 3) {
|
|
vtx_tbl[i].y = 10000.0f;
|
|
}
|
|
}
|
|
|
|
i_this->mpBgW->Move();
|
|
return 1;
|
|
}
|
|
|
|
/* 80BC0834-80BC0854 004014 0020+00 1/0 0/0 0/0 .text daObj_Brg_IsDelete__FP13obj_brg_class */
|
|
static int daObj_Brg_IsDelete(obj_brg_class* i_this) {
|
|
br_s* part = i_this->mBr;
|
|
|
|
for (int i = 0; i < i_this->field_0xb1ea; i++, part++) {
|
|
mDoAud_seDeleteObject(&part->field_0x0b0);
|
|
}
|
|
|
|
return 1;
|
|
}
|
|
|
|
/* 80BC0854-80BC08B0 004034 005C+00 1/0 0/0 0/0 .text daObj_Brg_Delete__FP13obj_brg_class
|
|
*/
|
|
static int daObj_Brg_Delete(obj_brg_class* i_this) {
|
|
dComIfG_resDelete(&i_this->mPhase, "Obj_brg");
|
|
|
|
if (i_this->mpBgW != NULL) {
|
|
dComIfG_Bgsp().Release(i_this->mpBgW);
|
|
}
|
|
|
|
return 1;
|
|
}
|
|
|
|
/* 80BC08B0-80BC0A40 004090 0190+00 1/1 0/0 0/0 .text CreateInit__FP10fopAc_ac_c */
|
|
static void CreateInit(fopAc_ac_c* i_this) {
|
|
obj_brg_class* a_this = (obj_brg_class*)i_this;
|
|
|
|
a_this->mCcStts.Init(0xFF, 0xFF, i_this);
|
|
|
|
static dCcD_SrcCyl himo_cyl_src = {
|
|
{
|
|
{0x0, {{0x0, 0x0, 0x0}, {0xd8fbfdff, 0x3}, 0x75}}, // mObj
|
|
{dCcD_SE_NONE, 0x0, 0x0, 0x0, 0x0}, // mGObjAt
|
|
{dCcD_SE_NONE, 0xff, 0x0, 0x0, 0x1}, // mGObjTg
|
|
{0x0}, // mGObjCo
|
|
}, // mObjInf
|
|
{
|
|
{0.0f, 0.0f, 0.0f}, // mCenter
|
|
5.0f, // mRadius
|
|
1000.0f // mHeight
|
|
} // mCyl
|
|
};
|
|
|
|
static dCcD_SrcCyl wire_cyl_src = {
|
|
{
|
|
{0x0, {{0x0, 0x0, 0x0}, {0xd8fbfdff, 0x3}, 0x75}}, // mObj
|
|
{dCcD_SE_NONE, 0x0, 0x0, 0x0, 0x0}, // mGObjAt
|
|
{dCcD_SE_METAL, 0x2, 0x0, 0x0, 0x3}, // mGObjTg
|
|
{0x0}, // mGObjCo
|
|
}, // mObjInf
|
|
{
|
|
{0.0f, 0.0f, 0.0f}, // mCenter
|
|
5.0f, // mRadius
|
|
1000.0f // mHeight
|
|
} // mCyl
|
|
};
|
|
|
|
br_s* part = a_this->mBr;
|
|
for (int i = 0; i < a_this->field_0xb1ea; i++, part++) {
|
|
for (int j = 0; j < 2; j++) {
|
|
if (a_this->mType & 8) {
|
|
part->mCyl[j].Set(wire_cyl_src);
|
|
part->mCyl[j].SetStts(&a_this->mCcStts);
|
|
part->mCyl[j].SetH(400.0f);
|
|
} else {
|
|
part->mCyl[j].Set(himo_cyl_src);
|
|
part->mCyl[j].SetStts(&a_this->mCcStts);
|
|
|
|
if (!(a_this->mType & 1)) {
|
|
part->mCyl[j].SetH(200.0f);
|
|
part->mCyl[j].OffTgShield();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (a_this->field_0xb1ec != 0) {
|
|
a_this->mCyl[0].Set(himo_cyl_src);
|
|
a_this->mCyl[0].SetStts(&a_this->mCcStts);
|
|
|
|
a_this->mCyl[1].Set(himo_cyl_src);
|
|
a_this->mCyl[1].SetStts(&a_this->mCcStts);
|
|
|
|
a_this->mCyl[0].SetH(500.0f);
|
|
a_this->mCyl[1].SetH(500.0f);
|
|
|
|
a_this->mCyl[0].OffCoSetBit();
|
|
a_this->mCyl[1].OffCoSetBit();
|
|
}
|
|
}
|
|
|
|
/* 80BC0A40-80BC1050 004220 0610+00 1/1 0/0 0/0 .text CallbackCreateHeap__FP10fopAc_ac_c
|
|
*/
|
|
static int CallbackCreateHeap(fopAc_ac_c* i_this) {
|
|
obj_brg_class* a_this = (obj_brg_class*)i_this;
|
|
|
|
int sp30 = a_this->mType & 1;
|
|
if (a_this->mType == 4) {
|
|
sp30 = 1;
|
|
} else if (a_this->mType == 8) {
|
|
sp30 = 2;
|
|
}
|
|
|
|
static const int obj_brg_bmd[] = {5, 6, 7};
|
|
J3DModelData* modelData = (J3DModelData*)dComIfG_getObjectRes("Obj_brg", obj_brg_bmd[sp30]);
|
|
JUT_ASSERT(0, modelData != 0);
|
|
|
|
J3DModelData* modelData2;
|
|
if (a_this->mType == 8) {
|
|
modelData2 = (J3DModelData*)dComIfG_getObjectRes("Obj_brg", 8);
|
|
JUT_ASSERT(0, modelData2 != 0);
|
|
}
|
|
|
|
br_s* part = a_this->mBr;
|
|
|
|
for (int i = 0; i < a_this->field_0xb1ea; i++, part++) {
|
|
part->mpBridgeModel = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084);
|
|
if (part->mpBridgeModel == NULL) {
|
|
return 0;
|
|
}
|
|
|
|
if (a_this->mType == 8) {
|
|
for (int j = 0; j < 2; j++) {
|
|
part->mpKnotModels[j] = mDoExt_J3DModel__create(modelData2, 0x80000, 0x11000084);
|
|
if (part->mpKnotModels[j] == NULL) {
|
|
return 0;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!(a_this->mType & 4)) {
|
|
part->field_0x708 = 7;
|
|
|
|
if (a_this->field_0xb1ed == 1) {
|
|
part->field_0x708 |= 0x10;
|
|
|
|
if (i == 3 || i == 4 || i == 7 || i == 11 || i == 13 || i == 15 || i == 18 || i == 19) {
|
|
part->field_0x708 = 0x16;
|
|
} else if (i == 1 || i == 2 || i == 5 || i == 6 || i == 9 || i == 12 || i == 16 || i == 17) {
|
|
part->field_0x708 = 0x15;
|
|
}
|
|
}
|
|
|
|
if ((a_this->mType & 1) != 1) {
|
|
part->field_0x0f8 = -1;
|
|
|
|
BOOL sp40;
|
|
if (a_this->mType & 8) {
|
|
sp40 = part->field_0x014.init(4, 5, (ResTIMG*)dComIfG_getObjectRes("Obj_brg", 16), 1);
|
|
} else {
|
|
sp40 = part->field_0x014.init(4, 5, (ResTIMG*)dComIfG_getObjectRes("Obj_brg", 15), 1);
|
|
}
|
|
|
|
if (!sp40) {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
if (i == 0) {
|
|
BOOL sp44;
|
|
if (a_this->mType & 8) {
|
|
sp44 = a_this->field_0xae90.init(2, a_this->field_0xb1ea + 2, (ResTIMG*)dComIfG_getObjectRes("Obj_brg", 16), 0);
|
|
} else {
|
|
sp44 = a_this->field_0xae90.init(2, a_this->field_0xb1ea + 2, (ResTIMG*)dComIfG_getObjectRes("Obj_brg", 15), 0);
|
|
}
|
|
|
|
if (!sp44) {
|
|
return 0;
|
|
}
|
|
|
|
cXyz* sp48 = a_this->field_0xae90.getPos(0);
|
|
for (int j = 0; j < a_this->field_0xb1ea + 2; j++, sp48++) {
|
|
*sp48 = i_this->current.pos;
|
|
}
|
|
|
|
sp48 = a_this->field_0xae90.getPos(1);
|
|
for (int j = 0; j < a_this->field_0xb1ea + 2; j++, sp48++) {
|
|
*sp48 = i_this->current.pos;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!(a_this->mType & 1)) {
|
|
part->field_0x0c8.y = 1.0f;
|
|
part->field_0x0c8.x = cM_rndF(0.05f) + 1.0f;
|
|
} else {
|
|
part->field_0x0c8.y = 1.0f;
|
|
part->field_0x0c8.x = 1.0f;
|
|
}
|
|
|
|
if (a_this->field_0xb1ed == 1) {
|
|
part->field_0x0c8.x *= 1.5f;
|
|
part->field_0x0c8.y *= 1.5f;
|
|
} else if (a_this->field_0xb1ed == 2) {
|
|
part->field_0x0c8.x *= 2.5f;
|
|
part->field_0x0c8.y *= 2.5f;
|
|
}
|
|
|
|
part->field_0x0c8.z = a_this->field_0xaedc;
|
|
part->mpBridgeModel->setBaseScale(part->field_0x0c8);
|
|
|
|
if (cM_rndF(1.0f) < 0.5f) {
|
|
part->field_0x0f0 = 0x8000;
|
|
}
|
|
}
|
|
|
|
OS_REPORT("BGSV SET 1! \n");
|
|
|
|
a_this->mpBgW = new dBgWSv();
|
|
if (a_this->mpBgW == NULL) {
|
|
return 0;
|
|
}
|
|
|
|
if ((a_this->mType & 1) == 1) {
|
|
if (a_this->mpBgW->Set((cBgD_t*)dComIfG_getObjectRes("Obj_brg", 12), 0)) {
|
|
return 0;
|
|
}
|
|
} else {
|
|
if (a_this->mpBgW->Set((cBgD_t*)dComIfG_getObjectRes("Obj_brg", 11), 0)) {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
a_this->mpBgW->SetRideCallback(ride_call_back);
|
|
a_this->mpBgW->CopyBackVtx();
|
|
|
|
Vec* vtx_tbl = (Vec*)a_this->mpBgW->GetVtxTbl();
|
|
for (int i = 0; i < a_this->mpBgW->GetVtxNum(); i++) {
|
|
vtx_tbl[i] = i_this->current.pos;
|
|
}
|
|
|
|
a_this->mpBgW->Move();
|
|
OS_REPORT("BGSV SET 2! \n");
|
|
return 1;
|
|
}
|
|
|
|
/* 80BC2528-80BC2538 000048 000C+04 0/1 0/0 0/0 .bss @5786 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5786[12 + 4 /* padding */];
|
|
#pragma pop
|
|
|
|
/* 80BC2538-80BC2544 000058 000C+00 0/1 0/0 0/0 .bss @5789 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5789[12];
|
|
#pragma pop
|
|
|
|
/* 80BC2544-80BC2550 000064 000C+00 0/1 0/0 0/0 .bss @5790 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5790[12];
|
|
#pragma pop
|
|
|
|
/* 80BC2550-80BC255C 000070 000C+00 0/1 0/0 0/0 .bss @5791 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5791[12];
|
|
#pragma pop
|
|
|
|
/* 80BC255C-80BC2568 00007C 000C+00 0/1 0/0 0/0 .bss @5792 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5792[12];
|
|
#pragma pop
|
|
|
|
/* 80BC2568-80BC2574 000088 000C+00 0/1 0/0 0/0 .bss @5793 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5793[12];
|
|
#pragma pop
|
|
|
|
/* 80BC2574-80BC2580 000094 000C+00 0/1 0/0 0/0 .bss @5794 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5794[12];
|
|
#pragma pop
|
|
|
|
/* 80BC2580-80BC258C 0000A0 000C+00 0/1 0/0 0/0 .bss @5795 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5795[12];
|
|
#pragma pop
|
|
|
|
/* 80BC258C-80BC2598 0000AC 000C+00 0/1 0/0 0/0 .bss @5796 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5796[12];
|
|
#pragma pop
|
|
|
|
/* 80BC2598-80BC25A4 0000B8 000C+00 0/1 0/0 0/0 .bss @5797 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5797[12];
|
|
#pragma pop
|
|
|
|
/* 80BC25A4-80BC25B0 0000C4 000C+00 0/1 0/0 0/0 .bss @5798 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5798[12];
|
|
#pragma pop
|
|
|
|
/* 80BC25B0-80BC25BC 0000D0 000C+00 0/1 0/0 0/0 .bss @5799 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5799[12];
|
|
#pragma pop
|
|
|
|
/* 80BC25BC-80BC25C8 0000DC 000C+00 0/1 0/0 0/0 .bss @5800 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5800[12];
|
|
#pragma pop
|
|
|
|
/* 80BC25C8-80BC25D4 0000E8 000C+00 0/1 0/0 0/0 .bss @5801 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5801[12];
|
|
#pragma pop
|
|
|
|
/* 80BC25D4-80BC25E0 0000F4 000C+00 0/1 0/0 0/0 .bss @5802 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5802[12];
|
|
#pragma pop
|
|
|
|
/* 80BC25E0-80BC25EC 000100 000C+00 0/1 0/0 0/0 .bss @5803 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5803[12];
|
|
#pragma pop
|
|
|
|
/* 80BC25EC-80BC25F8 00010C 000C+00 0/1 0/0 0/0 .bss @5804 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5804[12];
|
|
#pragma pop
|
|
|
|
/* 80BC25F8-80BC2604 000118 000C+00 0/1 0/0 0/0 .bss @5805 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5805[12];
|
|
#pragma pop
|
|
|
|
/* 80BC2604-80BC2610 000124 000C+00 0/1 0/0 0/0 .bss @5806 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5806[12];
|
|
#pragma pop
|
|
|
|
/* 80BC2610-80BC261C 000130 000C+00 0/1 0/0 0/0 .bss @5807 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5807[12];
|
|
#pragma pop
|
|
|
|
/* 80BC261C-80BC2628 00013C 000C+00 0/1 0/0 0/0 .bss @5808 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5808[12];
|
|
#pragma pop
|
|
|
|
/* 80BC2628-80BC2634 000148 000C+00 0/1 0/0 0/0 .bss @5809 */
|
|
#pragma push
|
|
#pragma force_active on
|
|
static u8 lit_5809[12];
|
|
#pragma pop
|
|
|
|
/* 80BC1050-80BC1D74 004830 0D24+00 1/0 0/0 0/0 .text daObj_Brg_Create__FP10fopAc_ac_c */
|
|
static int daObj_Brg_Create(fopAc_ac_c* i_this) {
|
|
obj_brg_class* a_this = (obj_brg_class*)i_this;
|
|
fopAcM_SetupActor(i_this, obj_brg_class);
|
|
|
|
int phase_state = dComIfG_resLoad(&a_this->mPhase, "Obj_brg");
|
|
if (phase_state == cPhs_COMPLEATE_e) {
|
|
a_this->mType = fopAcM_GetParam(i_this);
|
|
a_this->mType = 0;
|
|
a_this->field_0xb1e9 = fopAcM_GetParam(i_this) >> 8;
|
|
|
|
OS_REPORT("OBJ_BRG SET %x\n", fopAcM_GetParam(i_this));
|
|
|
|
u8 path_id = fopAcM_GetParam(i_this) >> 0x10;
|
|
a_this->field_0xaedc = 1.5f;
|
|
|
|
if (strcmp(dComIfGp_getStartStageName(), "F_SP104") == 0) {
|
|
a_this->mType = 8;
|
|
a_this->field_0xb1ed = 2;
|
|
a_this->field_0xaedc *= 3.0f;
|
|
}
|
|
|
|
if (path_id == 0xFF) {
|
|
if (strcmp(dComIfGp_getStartStageName(), "D_MN05") == 0) {
|
|
if (fopAcM_GetRoomNo(i_this) == 2) {
|
|
a_this->mType = 4;
|
|
|
|
i_this->home.pos.set(NREG_F(0) + 10155.0f + 1586.0f,
|
|
NREG_F(1) + 3740.0f + 2.0f,
|
|
NREG_F(2) + 5015.0f + -1280.0f);
|
|
a_this->mEndPos.set(NREG_F(3) + 11070.0f + 1586.0f,
|
|
NREG_F(4) + 3730.0f + 2.0f,
|
|
NREG_F(5) + 4705.0f + -1280.0f);
|
|
|
|
a_this->field_0xb1ec = 1;
|
|
} else if (fopAcM_GetRoomNo(i_this) == 4) {
|
|
i_this->home.pos.set(0.0f, 3285.0f, 3425.0f);
|
|
a_this->mEndPos.set(0.0f, 3270.0f, 1095.0f);
|
|
|
|
a_this->field_0xaedc *= 1.5f;
|
|
a_this->field_0xb1ed = 1;
|
|
} else {
|
|
return cPhs_ERROR_e;
|
|
}
|
|
}
|
|
} else {
|
|
dPath* path = dPath_GetRoomPath(path_id, fopAcM_GetRoomNo(i_this));
|
|
if (path != NULL) {
|
|
i_this->home.pos.x = path->m_points[0].m_position.x;
|
|
i_this->home.pos.y = path->m_points[0].m_position.y;
|
|
i_this->home.pos.z = path->m_points[0].m_position.z;
|
|
|
|
a_this->mEndPos.x = path->m_points[1].m_position.x;
|
|
a_this->mEndPos.y = path->m_points[1].m_position.y;
|
|
a_this->mEndPos.z = path->m_points[1].m_position.z;
|
|
} else {
|
|
OS_REPORT("NON PATH !!!!!!!!! %d!\n", path_id);
|
|
return cPhs_ERROR_e;
|
|
}
|
|
}
|
|
|
|
cXyz sp40 = a_this->mEndPos - i_this->home.pos;
|
|
i_this->home.angle.y = cM_atan2s(sp40.x, sp40.z);
|
|
i_this->home.angle.x = -cM_atan2s(sp40.y, JMAFastSqrt(sp40.x * sp40.x + sp40.z * sp40.z));
|
|
|
|
f32 var_f31 = TREG_F(14) + 3.0f;
|
|
if (a_this->field_0xb1ed == 1) {
|
|
var_f31 = TREG_F(14) + 2.0f;
|
|
} else if (a_this->field_0xb1ed == 2) {
|
|
var_f31 = TREG_F(15);
|
|
} else if (a_this->field_0xb1ec != 0) {
|
|
var_f31 = 0.0f;
|
|
} else if (sp40.abs() > 1300.0f) {
|
|
var_f31 += TREG_F(15) + 3.0f;
|
|
} else if (fopAcM_GetRoomNo(i_this) == 1) {
|
|
var_f31 = 0.0f;
|
|
}
|
|
|
|
a_this->field_0xb1ea = (sp40.abs() / var_f31 + 47.0f) * a_this->field_0xaedc;
|
|
|
|
if (a_this->field_0xb1ea > 24) {
|
|
OS_REPORT("TOO MANY BIRIDGE !!!! %d!\n", a_this->field_0xb1ea);
|
|
return cPhs_ERROR_e;
|
|
}
|
|
|
|
OS_REPORT("BIRIDGE JOINT !!!! %d!\n", a_this->field_0xb1ea);
|
|
|
|
if (!fopAcM_entrySolidHeap(i_this, CallbackCreateHeap, 0x375E0)) {
|
|
return cPhs_ERROR_e;
|
|
}
|
|
|
|
CreateInit(a_this);
|
|
|
|
if (a_this->mpBgW != NULL) {
|
|
if (dComIfG_Bgsp().Regist(a_this->mpBgW, i_this)) {
|
|
return cPhs_ERROR_e;
|
|
}
|
|
}
|
|
|
|
if (a_this->mType & 2) {
|
|
if (a_this->field_0xb1ea >= 16) {
|
|
a_this->field_0xb1eb = 15;
|
|
} else if (a_this->field_0xb1ea >= 12) {
|
|
a_this->field_0xb1eb = 11;
|
|
} else {
|
|
a_this->field_0xb1eb = 7;
|
|
}
|
|
} else {
|
|
a_this->field_0xb1eb = a_this->field_0xb1ea;
|
|
}
|
|
|
|
OS_REPORT("OBJ_BRG SET END \n");
|
|
|
|
int sp54 = fopAcM_GetParam(i_this) >> 0x18;
|
|
bool sp78 = sp54 != 0xFF && dComIfGs_isSwitch(sp54, fopAcM_GetRoomNo(i_this));
|
|
|
|
br_s* part = a_this->mBr;
|
|
for (int i = 0; i < a_this->field_0xb1ea; i++, part++) {
|
|
part->field_0x074[0].y = i_this->home.pos.y + 350.0f;
|
|
part->field_0x050[0].y = i_this->home.pos.y + 350.0f;
|
|
}
|
|
|
|
int sp60 = 10;
|
|
if (a_this->field_0xb1ed == 2) {
|
|
sp60 = 2;
|
|
|
|
static cXyz brg_init_pos[] = {
|
|
cXyz(334.0f, 249.0f, -11868.0f),
|
|
cXyz(334.0f, 180.0f, -12082.0f),
|
|
cXyz(334.0f, 114.0f, -12297.0f),
|
|
cXyz(334.0f, 50.0f, -12512.0f),
|
|
cXyz(334.0f, -9.0f, -12729.0f),
|
|
cXyz(334.0f, -63.0f, -12948.0f),
|
|
cXyz(334.0f, -111.0f, -13168.0f),
|
|
cXyz(334.0f, -150.0f, -13389.0f),
|
|
cXyz(334.0f, -181.0f, -13612.0f),
|
|
cXyz(334.0f, -203.0f, -13836.0f),
|
|
cXyz(334.0f, -215.0f, -14061.0f),
|
|
cXyz(334.0f, -217.0f, -14286.0f),
|
|
cXyz(334.0f, -208.0f, -14511.0f),
|
|
cXyz(334.0f, -190.0f, -14735.0f),
|
|
cXyz(334.0f, -162.0f, -14958.0f),
|
|
cXyz(334.0f, -126.0f, -15180.0f),
|
|
cXyz(334.0f, -82.0f, -15401.0f),
|
|
cXyz(334.0f, -31.0f, -15620.0f),
|
|
cXyz(334.0f, 24.0f, -15838.0f),
|
|
cXyz(334.0f, 85.0f, -16054.0f),
|
|
cXyz(334.0f, 150.0f, -16270.0f),
|
|
cXyz(334.0f, 216.0f, -16485.0f),
|
|
};
|
|
|
|
for (int i = 0; i < a_this->field_0xb1ea; i++) {
|
|
a_this->mBr[i].field_0x098[2] = brg_init_pos[i];
|
|
}
|
|
}
|
|
|
|
for (int i = 0; i < sp60; i++) {
|
|
if (i == 5 && sp78) {
|
|
if (a_this->field_0xb1ec != 0) {
|
|
a_this->field_0xaf1c = 5;
|
|
a_this->field_0xaed0 = 7;
|
|
} else if (a_this->field_0xb1ec == 1) {
|
|
a_this->field_0xaf1c = 5;
|
|
a_this->field_0xaed0 = 10;
|
|
a_this->mType = 4;
|
|
} else {
|
|
a_this->field_0xaf1c = 5;
|
|
a_this->field_0xaed0 = a_this->field_0xb1ea / 2;
|
|
}
|
|
}
|
|
|
|
daObj_Brg_Execute(a_this);
|
|
}
|
|
}
|
|
|
|
return phase_state;
|
|
}
|
|
|
|
AUDIO_INSTANCES;
|
|
|
|
/* 80BC2460-80BC2480 -00001 0020+00 1/0 0/0 0/0 .data l_daObj_Brg_Method */
|
|
static actor_method_class l_daObj_Brg_Method = {
|
|
(process_method_func)daObj_Brg_Create,
|
|
(process_method_func)daObj_Brg_Delete,
|
|
(process_method_func)daObj_Brg_Execute,
|
|
(process_method_func)daObj_Brg_IsDelete,
|
|
(process_method_func)daObj_Brg_Draw,
|
|
};
|
|
|
|
/* 80BC2480-80BC24B0 -00001 0030+00 0/0 0/0 1/0 .data g_profile_OBJ_BRG */
|
|
extern actor_process_profile_definition g_profile_OBJ_BRG = {
|
|
fpcLy_CURRENT_e, // mLayerID
|
|
3, // mListID
|
|
fpcPi_CURRENT_e, // mListPrio
|
|
PROC_OBJ_BRG, // mProcName
|
|
&g_fpcLf_Method.base, // sub_method
|
|
sizeof(obj_brg_class), // mSize
|
|
0, // mSizeOther
|
|
0, // mParameters
|
|
&g_fopAc_Method.base, // sub_method
|
|
54, // mPriority
|
|
&l_daObj_Brg_Method, // sub_method
|
|
0x00044000, // mStatus
|
|
fopAc_ACTOR_e, // mActorType
|
|
fopAc_CULLBOX_CUSTOM_e, // cullType
|
|
};
|