Starship/src/main/fox_enmy.c

2927 lines
99 KiB
C
Raw Normal View History

#include "global.h"
s32 D_80161670[4];
s32 D_80161680;
u8 D_80161684;
ObjectInit* D_800CFDA0[] = {
0x060371A4, 0x06026CC4, 0x0602A164, 0x06023F64, 0x060287A4, 0x0602E4F4, 0x06007E74,
0x0601F234, 0x06026714, 0x0C035154, 0x06006AA4, 0x06031000, 0x06006C60, 0x0602E5C8,
0x0600EAD4, NULL, 0x06011044, 0x0600FF74, 0x06006EB4, 0x06014D94, 0x0302DE3C,
};
s32 D_800CFDF4[] = {
OBJECT_0,
OBJECT_6C_SILVER_RING,
OBJECT_6C_SILVER_RING,
OBJECT_6C_SILVER_RING,
OBJECT_6C_SILVER_RING,
OBJECT_6C_BOMB,
OBJECT_6C_BOMB,
OBJECT_6C_BOMB,
OBJECT_6C_BOMB,
OBJECT_6C_LASERS,
OBJECT_6C_LASERS,
OBJECT_6C_LASERS,
OBJECT_6C_LASERS,
OBJECT_6C_1UP,
OBJECT_6C_GOLD_RING,
OBJECT_6C_GOLD_RING,
OBJECT_6C_GOLD_RING,
OBJECT_6C_GOLD_RING,
OBJECT_6C_GOLD_RING,
OBJECT_6C_LASERS,
OBJECT_6C_BOMB,
OBJECT_6C_SILVER_RING,
OBJECT_6C_SILVER_RING,
OBJECT_6C_WING_REPAIR,
OBJECT_0,
OBJECT_325,
};
f32 D_800CFE5C[] = {
0.0f, 1.0f, 0.5f, 0.33f, 0.25f, 1.0f, 0.5f, 0.33f, 0.25f, 1.0f, 0.5f, 0.33f, 0.25f,
1.0f, 1.0f, 1.0f, 1.0f, 1.0f, -1.0f, -1.0f, -1.0f, -1.0f, 0.1f, 1.0f, 1.0f, 1.0f,
};
Vec3f D_800CFEC4[6] = {
{ 0.0f, 0.0f, 50.0f }, { -50.0f, 0.0f, 0.0f }, { 50.0f, 0.0f, 0.0f },
{ 0.0f, 50.0f, 0.0f }, { 0.0f, 0.0f, -50.0f }, { 0.0f, -50.0f, 0.0f },
};
Vec3f D_800CFF0C[6] = {
{ 0.0f, 0.0f, 0.0f }, { 0.0f, -90.0f, 0.0f }, { 0.0f, 90.0f, 0.0f },
{ -90.0f, 0.0f, 0.0f }, { 0.0f, 180.0f, 0.0f }, { 90.0f, 0.0f, 0.0f },
};
u32 D_800CFF54[9] = {
0x19404038, 0x19404139, 0x1940423A, 0x1940433B, 0x1940443C, 0x1940453D, 0x1940463E, 0x1940463E, 0x1940463E,
};
void func_80060F30(Vec3f* arg0, u32 arg1, s32 arg2) {
(void) "CHIME SET \n";
(void) "BOMB SET 1\n";
(void) "BOMB SET 2\n";
(void) "center_X %f\n";
(void) "Enm->obj.pos.x %f\n";
if (D_801778E8 == 0) {
func_80019218(arg1, &D_800C5D28, 4, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
} else {
func_80019218(arg1, arg0, arg2, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
}
}
void Object_Kill(Object* arg0, Vec3f* arg1) {
arg0->status = 0;
func_8001A500(arg1);
}
s32 func_80060FE4(Vec3f* arg0, f32 arg1) {
Vec3f sp2C;
Vec3f sp20;
if ((D_80177880 != 1) && (gPlayer[0].unk_1C8 != 2)) {
return true;
}
Matrix_RotateY(gCalcMatrix, gPlayer[D_801778A0].unk_058, 0);
sp2C.x = arg0->x - gPlayer[D_801778A0].unk_040.x;
sp2C.y = 0.0f;
sp2C.z = arg0->z - gPlayer[D_801778A0].unk_040.z;
Matrix_MultVec3fNoTranslate(gCalcMatrix, &sp2C, &sp20);
if ((sp20.z < 1000.0f) && (arg1 < sp20.z) && (fabsf(sp20.x) < (fabsf(sp20.z * 0.5f) + 2000.0f))) {
return true;
}
return false;
}
s32 func_80061148(Vec3f* arg0, f32 arg1) {
Vec3f sp2C;
Vec3f sp20;
if (D_80177880 != 1) {
return true;
}
if (gPlayer[0].unk_1C8 == 7) {
return func_80060FE4(arg0, arg1);
}
Matrix_RotateY(gCalcMatrix, gPlayer[D_801778A0].unk_058, 0);
sp2C.x = arg0->x - gPlayer[D_801778A0].unk_040.x;
sp2C.y = 0.0f;
sp2C.z = arg0->z - gPlayer[D_801778A0].unk_040.z;
Matrix_MultVec3fNoTranslate(gCalcMatrix, &sp2C, &sp20);
if ((sp20.z < 0.0f) && (arg1 < sp20.z) && (fabsf(sp20.x) < (fabsf(sp20.z * 0.5f) + 500.0f))) {
return true;
}
return false;
}
void func_800612B8(ObjectStruct_1C* arg0, u32 arg1) {
*arg0 = D_800CC124[arg1];
arg0->unk_0C = SEGMENTED_TO_VIRTUAL(D_800CC124[arg1].unk_0C);
if (D_80177880 == 2) {
arg0->unk_10 += 200.0f;
}
}
void Object_80_Initialize(Object_80* arg0) {
s32 i;
u8* var_v0 = (u8*) arg0;
for (i = 0; i < sizeof(Object_80); i++, var_v0++) {
*var_v0 = 0;
}
}
void Object_4C_Initialize(Object_4C* arg0) {
s32 i;
u8* var_v0 = (u8*) arg0;
for (i = 0; i < sizeof(Object_4C); i++, var_v0++) {
*var_v0 = 0;
}
}
void Object_2F4_Initialize(Object_2F4* arg0) {
s32 i;
u8* var_v0 = (u8*) arg0;
for (i = 0; i < sizeof(Object_2F4); i++, var_v0++) {
*var_v0 = 0;
}
arg0->unk_110 = 1.0f;
}
void Object_408_Initialize(Object_408* arg0) {
s32 i;
u8* var_v0 = (u8*) arg0;
for (i = 0; i < sizeof(Object_408); i++, var_v0++) {
*var_v0 = 0;
}
arg0->unk_3F8 = 1.0f;
}
void Object_6C_Initialize(Object_6C* arg0) {
s32 i;
u8* var_v0 = (u8*) arg0;
for (i = 0; i < sizeof(Object_6C); i++, var_v0++) {
*var_v0 = 0;
}
}
void Object_8C_Initialize(Object_8C* arg0) {
s32 i;
u8* var_v0 = (u8*) arg0;
for (i = 0; i < sizeof(Object_8C); i++, var_v0++) {
*var_v0 = 0;
}
arg0->unk_70 = 1.0f;
}
void func_800614B4(Object_80* arg0, ObjectInit* arg1) {
Object_80_Initialize(arg0);
arg0->obj.status = 1;
arg0->obj.pos.z = -arg1->zPos1;
arg0->obj.pos.z += -3000.0f + arg1->zPos2;
arg0->obj.pos.x = arg1->xPos;
arg0->obj.pos.y = arg1->yPos;
arg0->obj.rot.x = arg1->unk_A;
arg0->obj.rot.y = arg1->unk_C;
arg0->obj.rot.z = arg1->unk_E;
arg0->obj.id = arg1->id;
func_800612B8(&arg0->unk_1C, arg0->obj.id);
}
void func_800615A0(Object_4C* arg0, ObjectInit* arg1) {
Object_4C_Initialize(arg0);
arg0->obj.status = 1;
arg0->obj.pos.z = -arg1->zPos1;
arg0->obj.pos.z += -3000.0f + arg1->zPos2;
arg0->obj.pos.x = arg1->xPos;
arg0->obj.pos.y = arg1->yPos;
arg0->obj.rot.y = arg1->unk_C;
arg0->obj.rot.x = arg1->unk_A;
arg0->obj.rot.z = arg1->unk_E;
arg0->obj.id = arg1->id;
func_800612B8(&arg0->unk_1C, arg0->obj.id);
}
void func_8006168C(Object_2F4* arg0, ObjectInit* arg1) {
Object_2F4_Initialize(arg0);
arg0->obj.status = 1;
arg0->obj.pos.z = -arg1->zPos1;
arg0->obj.pos.z += -3000.0f + arg1->zPos2;
arg0->obj.pos.x = arg1->xPos;
arg0->obj.pos.y = arg1->yPos;
arg0->obj.rot.y = arg1->unk_C;
arg0->obj.rot.x = arg1->unk_A;
arg0->obj.rot.z = arg1->unk_E;
arg0->obj.id = arg1->id;
func_800612B8(&arg0->unk_01C, arg0->obj.id);
}
void func_80061778(Object_408* arg0, ObjectInit* arg1) {
Object_408_Initialize(arg0);
arg0->obj.status = 1;
arg0->obj.pos.z = -arg1->zPos1;
arg0->obj.pos.z += -3000.0f + arg1->zPos2;
arg0->obj.pos.x = arg1->xPos;
arg0->obj.pos.y = arg1->yPos;
arg0->obj.rot.y = arg1->unk_C;
arg0->obj.rot.x = arg1->unk_A;
arg0->obj.rot.z = arg1->unk_E;
arg0->obj.id = arg1->id;
func_800612B8(&arg0->unk_01C, arg0->obj.id);
}
void func_80061864(Object_6C* arg0, ObjectInit* arg1) {
Object_6C_Initialize(arg0);
arg0->obj.status = 1;
arg0->obj.pos.z = -arg1->zPos1;
arg0->obj.pos.z += -3000.0f + arg1->zPos2;
arg0->obj.pos.x = arg1->xPos;
arg0->obj.pos.y = arg1->yPos;
arg0->obj.rot.y = arg1->unk_C;
arg0->obj.rot.x = arg1->unk_A;
arg0->obj.rot.z = arg1->unk_E;
arg0->obj.id = arg1->id;
arg0->unk_68 = 1.0f;
func_800612B8(&arg0->unk_1C, arg0->obj.id);
}
void func_80061958(Object_8C* arg0, f32 arg1, f32 arg2, f32 arg3) {
Object_8C_Initialize(arg0);
arg0->obj.status = 1;
arg0->obj.id = OBJECT_346;
arg0->unk_50 = 50;
arg0->unk_70 = 0.2f;
if (gCurrentLevel == LEVEL_AQUAS) {
arg0->unk_50 = 200;
arg0->unk_70 = 0.3f;
arg0->unk_6C = Rand_ZeroOne() * 255.0f;
}
arg0->obj.pos.x = arg1;
arg0->obj.pos.y = arg2;
arg0->obj.pos.z = arg3;
arg0->obj.rot.z = Rand_ZeroOne() * 360.0f;
func_800612B8(&arg0->unk_1C, arg0->obj.id);
if (gLevelType == 0) {
arg0->unk_1C.unk_10 = 100.0f;
}
}
void func_80061A4C(void) {
s32 i;
f32 sp28;
f32 sp24;
f32 sp20;
f32 sp1C;
for (i = 0; i < ARRAY_COUNT(gObjects8C); i++) {
if (gObjects8C[i].obj.status == 0) {
sp1C = (Rand_ZeroOne() - 0.5f);
sp28 = gPlayer[0].unk_074 + (sp1C * 400.0f) + (5.0f * gPlayer[0].unk_0C0.x);
sp1C = (Rand_ZeroOne() - 0.5f);
sp24 = gPlayer[0].unk_078 + (sp1C * 400.0f) + (5.0f * gPlayer[0].unk_0C0.y);
sp20 = -D_80177D20 - 500.0f;
if (D_80177D08 < 0.0f) {
sp20 = -D_80177D20 + 500.0f;
}
func_80061958(&gObjects8C[i], sp28, sp24, sp20);
break;
}
}
}
void func_80061B68(void) {
s32 i;
f32 sp28;
f32 sp24;
f32 sp20;
f32 sp1C;
for (i = 0; i < ARRAY_COUNT(gObjects8C); i++) {
if (gObjects8C[i].obj.status == 0) {
sp1C = (Rand_ZeroOne() - 0.5f);
sp28 = gPlayer[0].unk_074 + (sp1C * 2000.0f) + (5.0f * gPlayer[0].unk_0C0.x);
sp24 = 0;
while (sp24 <= D_80177940) {
sp1C = (Rand_ZeroOne() - 0.5f);
sp24 = gPlayer[0].unk_078 + (sp1C * 2000.0f) + (5.0f * gPlayer[0].unk_0C0.y);
}
sp20 = -D_80177D20 - 3000.0f;
if (D_80177D08 < 0.0f) {
sp20 = -D_80177D20 + 1000.0f;
}
func_80061958(&gObjects8C[i], sp28, sp24, sp20);
break;
}
}
}
void func_80061CD0(void) {
s32 i;
f32 sp28;
f32 sp24;
f32 sp20;
f32 sp1C;
for (i = 0; i < ARRAY_COUNT(gObjects8C); i++) {
if (gObjects8C[i].obj.status == 0) {
sp1C = (Rand_ZeroOne() - 0.5f);
sp28 = gPlayer[D_801778A0].unk_074 + (sp1C * 3000.0f) + (5.0f * gPlayer[D_801778A0].unk_0C0.x);
sp1C = (Rand_ZeroOne() - 0.5f);
sp24 = gPlayer[D_801778A0].unk_078 + 1000.0f + (sp1C * 500.0f) + (5.0f * gPlayer[D_801778A0].unk_0C0.y);
sp20 = -D_80177D20 - 2000.0f * Rand_ZeroOne();
if (D_80177D08 < 0.0f) {
sp20 = -D_80177D20 + 1000.0f;
}
func_80061958(&gObjects8C[i], sp28, sp24, sp20);
break;
}
}
}
void func_80061E48(Object_2F4* arg0, f32 arg1, f32 arg2, f32 arg3) {
Object_2F4_Initialize(arg0);
arg0->obj.status = 1;
arg0->obj.id = OBJECT_181;
if (Rand_ZeroOne() < 0.5f) {
arg0->obj.id = OBJECT_186;
}
if (Rand_ZeroOne() < 0.5f) {
arg0->obj.id = OBJECT_182;
}
arg0->obj.pos.x = arg1;
arg0->obj.pos.y = arg2;
arg0->obj.pos.z = arg3;
arg0->unk_0E8.z = 10.0f;
func_800612B8(&arg0->unk_01C, arg0->obj.id);
}
void func_80061F0C(Object_2F4* arg0, ObjectInit* arg1, s32 arg2) {
Vec3f sp24;
Object_2F4_Initialize(arg0);
arg0->obj.status = 2;
arg0->unk_040 = arg2;
arg0->obj.pos.z = -arg1->zPos1;
arg0->obj.pos.z += -3000.0f + arg1->zPos2;
arg0->obj.pos.x = arg1->xPos;
arg0->obj.pos.y = arg1->yPos;
arg0->obj.rot.y = arg0->unk_0F4.y = arg1->unk_C;
arg0->obj.rot.x = arg0->unk_0F4.x = arg1->unk_A;
arg0->unk_0F4.z = arg1->unk_E;
arg0->obj.id = OBJECT_200;
arg0->unk_0C2 = 10;
arg0->unk_0B4 = 4095;
arg0->unk_0E4 = arg1->id - OBJECT_UNK_1000;
func_800612B8(&arg0->unk_01C, arg0->obj.id);
arg0->unk_01C.unk_10 = 3000.0f;
arg0->unk_178 = 20000.0f;
arg0->unk_054 = D_80177E70;
arg0->unk_078 = gObjects2F4[D_80177E70].unk_0E4;
arg0->unk_16C = D_80161A54;
Matrix_RotateZ(gCalcMatrix, -D_80177E88.z * M_DTOR, 0);
Matrix_RotateX(gCalcMatrix, -D_80177E88.x * M_DTOR, 1);
Matrix_RotateY(gCalcMatrix, -D_80177E88.y * M_DTOR, 1);
sp24.x = arg0->obj.pos.x - D_80177F10.x;
sp24.y = arg0->obj.pos.y - D_80177F10.y;
sp24.z = arg0->obj.pos.z - D_80177F10.z;
Matrix_MultVec3fNoTranslate(gCalcMatrix, &sp24, &arg0->unk_2DC);
arg0->unk_074 = D_80177E78;
D_80177E70 = arg2;
func_80069AAC(arg0);
}
void func_80062180(ObjectInit* arg0, f32 arg1, f32 arg2, f32 arg3, f32 arg4) {
f32 temp_fv0;
s32 i;
if ((arg1 > arg0->xPos - gPlayer[0].unk_0AC) && (arg0->xPos - gPlayer[0].unk_0AC > arg2) &&
(arg3 > arg0->yPos - gPlayer[0].unk_0B0) && (arg0->yPos - gPlayer[0].unk_0B0 > arg4)) {
if (arg0->id < OBJECT_161) {
for (i = 0; i < ARRAY_COUNT(gObjects80); i++) {
if (gObjects80[i].obj.status == 0) {
func_800614B4(&gObjects80[i], arg0);
break;
}
}
}
if ((arg0->id >= OBJECT_161) && (arg0->id < OBJECT_176)) {
for (i = 0; i < ARRAY_COUNT(gObjects4C); i++) {
if (gObjects4C[i].obj.status == 0) {
func_800615A0(&gObjects4C[i], arg0);
break;
}
}
}
if ((arg0->id >= OBJECT_176) && (arg0->id < OBJECT_292)) {
if ((arg0->id == OBJECT_267) || (arg0->id == OBJECT_254)) {
for (i = ARRAY_COUNT(gObjects2F4) - 1; i >= 0; i--) {
if (gObjects2F4[i].obj.status == 0) {
func_8006168C(&gObjects2F4[i], arg0);
break;
}
}
} else if (arg0->id == OBJECT_198) {
for (i = 0; i < 3; i++) {
if (gObjects2F4[i].obj.status == 0) {
func_8006168C(&gObjects2F4[i], arg0);
break;
}
}
} else {
for (i = 4; i < ARRAY_COUNT(gObjects2F4); i++) {
if (gObjects2F4[i].obj.status == 0) {
func_8006168C(&gObjects2F4[i], arg0);
break;
}
}
}
}
if ((arg0->id >= OBJECT_292) && (arg0->id < OBJECT_6C_LASERS)) {
for (i = 0; i < ARRAY_COUNT(gObjects408); i++) {
if (gObjects408[i].obj.status == 0) {
func_80061778(&gObjects408[i], arg0);
break;
}
}
}
if ((arg0->id >= OBJECT_6C_LASERS) && (arg0->id < OBJECT_339)) {
for (i = 0; i < ARRAY_COUNT(gObjects6C); i++) {
if (gObjects6C[i].obj.status == 0) {
func_80061864(&gObjects6C[i], arg0);
break;
}
}
}
if (arg0->id >= OBJECT_339 && arg0->id <= OBJECT_UNK_406) {
switch (arg0->id) {
case OBJECT_UNK_403:
D_E6A810_801BA1E8 = 99;
break;
case OBJECT_UNK_404:
D_E6A810_801BA1E8 = 0;
break;
case OBJECT_UNK_405:
D_E6A810_801BA1E8 = 98;
break;
case OBJECT_UNK_402:
D_E9F1D0_801A7F78 = arg0->unk_E * 0.1f;
D_E9F1D0_801A7F60 = -(f32) arg0->unk_A;
break;
case OBJECT_UNK_400:
D_801782B8++;
break;
case OBJECT_UNK_401:
if (D_801782B8 > 0) {
D_801782B8--;
break;
}
break;
}
}
if (arg0->id > OBJECT_UNK_406) {
for (i = 0; i < ARRAY_COUNT(gObjects2F4); i++) {
if (gObjects2F4[i].obj.status == 0) {
func_80061F0C(&gObjects2F4[i], arg0, i);
break;
}
}
}
}
}
void func_80062568(void) {
ObjectInit* var_s1;
s32 var_s0;
s32 temp = gCurrentLevel; // seems fake
if (1) {}
D_80178310 = SEGMENTED_TO_VIRTUAL(D_800CFDA0[temp]);
var_s0 = D_80177CA0 - 40;
var_s1 = &D_80178310[var_s0];
for (; var_s0 < D_80177CA0; var_s0++, var_s1++) {
func_80062180(var_s1, 4000.0f, -4000.0f, 4000.0f, -4000.0f);
}
}
void func_80062664(void) {
ObjectInit* var_s0_2;
f32 var_fs1;
f32 var_fs2;
f32 var_fs3;
f32 var_fs4;
s32 i;
s32 j;
if ((gCurrentLevel == LEVEL_METEO) && (D_8017827C == 1)) {
D_80178310 = SEGMENTED_TO_VIRTUAL(D_602B148);
} else if ((gCurrentLevel == LEVEL_SECTOR_X) && (D_8017827C == 1)) {
D_80178310 = SEGMENTED_TO_VIRTUAL(D_602F18C);
} else if ((gCurrentLevel == LEVEL_VENOM_2) && (D_8017827C == 1)) {
D_80178310 = SEGMENTED_TO_VIRTUAL(D_C0356A4);
} else if ((gCurrentLevel == LEVEL_VENOM_1) && (D_8017827C == 1)) {
D_80178310 = SEGMENTED_TO_VIRTUAL(D_6010088);
} else {
D_80178310 = SEGMENTED_TO_VIRTUAL(D_800CFDA0[gCurrentLevel]);
}
if (D_8017812C == 0) {
for (j = 0; j < D_801782B8; j++) {
if (gCurrentLevel == LEVEL_AQUAS) {
func_80061B68();
} else {
func_80061A4C();
}
}
}
if (gCurrentLevel == LEVEL_METEO) {
var_fs3 = var_fs1 = 10000.0f;
var_fs4 = var_fs2 = -10000.0f;
} else if (gCurrentLevel == LEVEL_SECTOR_Y) {
var_fs3 = var_fs1 = 6000.0f;
var_fs4 = var_fs2 = -6000.0f;
} else if (gCurrentLevel == LEVEL_VENOM_1) {
var_fs3 = var_fs1 = 3500.0f;
var_fs4 = var_fs2 = -3500.0f;
} else {
var_fs3 = var_fs1 = 4000.0f;
var_fs4 = var_fs2 = -4000.0f;
}
if ((gPlayer[0].unk_210 != 0) && (gPlayer[0].unk_118 < 0.0f)) {
var_fs1 = 10000.0f;
}
if ((gPlayer[0].unk_210 != 0) && (gPlayer[0].unk_118 > 0.0f)) {
var_fs2 = -10000.0f;
}
D_80161680 = 0;
for (i = 0, var_s0_2 = &D_80178310[D_80177DC8]; i < 10000; i++, D_80177DC8++, var_s0_2++) {
if ((var_s0_2->id > OBJECT_INVALID) && D_80177D20 <= var_s0_2->zPos1 &&
var_s0_2->zPos1 <= D_80177D20 + 200.0f) {
if ((gCurrentLevel == LEVEL_VENOM_1) && (var_s0_2->id >= OBJECT_UNK_1000)) {
if (((var_s0_2->unk_C < 180.0f) && (var_s0_2->xPos < gPlayer[0].unk_0AC)) ||
((var_s0_2->unk_C > 180.0f) && (gPlayer[0].unk_0AC < var_s0_2->xPos))) {
func_80062180(var_s0_2, var_fs1, var_fs2, var_fs3, var_fs4);
}
} else {
func_80062180(var_s0_2, var_fs1, var_fs2, var_fs3, var_fs4);
}
} else {
break;
}
}
}
void func_80062B60(f32 arg0, f32 arg1, s32 arg2, f32 arg3) {
s32 i;
if (gLevelType == 0) {
for (i = 0; i < ARRAY_COUNT(gObjects8C); i++) {
if (gObjects8C[i].obj.status == 0) {
Object_8C_Initialize(&gObjects8C[i]);
gObjects8C[i].obj.status = 1;
gObjects8C[i].obj.id = OBJECT_348;
gObjects8C[i].obj.pos.x = arg0;
gObjects8C[i].obj.pos.y = D_80177940 + 3.0f;
gObjects8C[i].obj.pos.z = arg1;
gObjects8C[i].unk_70 = 10.0f;
gObjects8C[i].unk_6C = arg3;
gObjects8C[i].unk_44 = 80;
gObjects8C[i].unk_4E = arg2;
func_800612B8(&gObjects8C[i].unk_1C, gObjects8C[i].obj.id);
break;
}
}
}
}
void func_80062C38(f32 arg0, f32 arg1) {
s32 i;
if (gLevelType == 0) {
for (i = 0; i < ARRAY_COUNT(gObjects8C); i++) {
if (gObjects8C[i].obj.status == 0) {
Object_8C_Initialize(&gObjects8C[i]);
gObjects8C[i].obj.status = 1;
gObjects8C[i].obj.id = OBJECT_349;
gObjects8C[i].obj.pos.x = arg0;
gObjects8C[i].obj.pos.y = D_80177940 + 3.0f;
gObjects8C[i].obj.pos.z = arg1;
gObjects8C[i].unk_70 = 1.0f;
gObjects8C[i].unk_6C = 1.3f;
gObjects8C[i].unk_44 = 120;
func_800612B8(&gObjects8C[i].unk_1C, gObjects8C[i].obj.id);
break;
}
}
}
}
void func_80062D04(f32 arg0, f32 arg1) {
s32 i;
for (i = 0; i < ARRAY_COUNT(gObjects8C); i++) {
if (gObjects8C[i].obj.status == 0) {
Object_8C_Initialize(&gObjects8C[i]);
gObjects8C[i].obj.status = 1;
gObjects8C[i].obj.id = OBJECT_350;
gObjects8C[i].obj.pos.x = arg0;
gObjects8C[i].obj.pos.y = D_80177940 + 3.0f;
gObjects8C[i].obj.pos.z = arg1;
gObjects8C[i].unk_70 = 3.0f;
gObjects8C[i].unk_6C = 2.0f;
gObjects8C[i].unk_44 = 120;
func_800612B8(&gObjects8C[i].unk_1C, gObjects8C[i].obj.id);
break;
}
}
}
s32 func_80062DBC(Vec3f* arg0, f32* var_s0, Object* arg2, f32 arg3, f32 arg4, f32 arg5) {
f32 temp_fv1;
f32 var_fa0;
f32 var_fa1;
f32 var_fs1;
f32 var_fs2;
f32 var_ft4;
f32 var_ft5;
f32 var_fv0;
s32 temp_ft1;
Vec3f sp80;
Vec3f sp74;
s32 var_s4;
temp_ft1 = var_s0[0];
var_s0++;
if (temp_ft1 != 0) {
for (var_s4 = 0; var_s4 < temp_ft1; var_s4++) {
var_fv0 = 0.0f;
var_fa0 = 0.0f;
var_fs2 = 0.0f;
var_fs1 = 0.0f;
if (var_s0[0] >= 300000.0f) {
return 0;
}
if (var_s0[0] == 200000.0f) {
var_fv0 = 1.0f;
var_fs1 = var_s0[1];
var_fs2 = var_s0[2];
var_fa0 = var_s0[3];
var_s0 += 4;
}
if ((arg2->rot.y == 0.0f) && (arg2->rot.z == 0.0f) && (arg2->rot.x == 0.0f) && (var_fv0 == 0.0f)) {
var_fa1 = arg0->x;
var_ft4 = arg0->y;
var_ft5 = arg0->z;
} else {
Matrix_RotateZ(gCalcMatrix, -var_fa0 * M_DTOR, 0);
Matrix_RotateX(gCalcMatrix, -var_fs1 * M_DTOR, 1);
Matrix_RotateY(gCalcMatrix, -var_fs2 * M_DTOR, 1);
Matrix_RotateZ(gCalcMatrix, -arg2->rot.z * M_DTOR, 1);
Matrix_RotateX(gCalcMatrix, -arg2->rot.x * M_DTOR, 1);
Matrix_RotateY(gCalcMatrix, -arg2->rot.y * M_DTOR, 1);
if ((arg3 != 0.0f) || (arg4 != 0.0f) || (arg5 != 0.0f)) {
Matrix_RotateZ(gCalcMatrix, -arg5 * M_DTOR, 1);
Matrix_RotateX(gCalcMatrix, -arg3 * M_DTOR, 1);
Matrix_RotateY(gCalcMatrix, -arg4 * M_DTOR, 1);
}
sp80.x = arg0->x - arg2->pos.x;
sp80.y = arg0->y - arg2->pos.y;
sp80.z = arg0->z - arg2->pos.z;
Matrix_MultVec3fNoTranslate(gCalcMatrix, &sp80, &sp74);
var_fa1 = arg2->pos.x + sp74.x;
var_ft4 = arg2->pos.y + sp74.y;
var_ft5 = arg2->pos.z + sp74.z;
}
if ((var_s0[1] + 20.0f) > (fabsf((var_s0[0] + arg2->pos.z) - var_ft5)) &&
((var_s0[5] + 20.0f) > fabsf((var_s0[4] + arg2->pos.x) - var_fa1)) &&
((var_s0[3] + 10.0f) > fabsf((var_s0[2] + arg2->pos.y) - var_ft4))) {
return true;
}
var_s0 += 6;
}
}
return false;
}
s32 func_800631A8(Vec3f* arg0, f32* arg1, Vec3f* arg2) {
if (((s32) arg1[0] != 0) && (fabsf((arg1[1] + arg2->z) - arg0->z) < (arg1[2] + 20.0f)) &&
(fabsf((arg1[5] + arg2->x) - arg0->x) < (arg1[6] + 20.0f)) &&
(fabsf((arg1[3] + arg2->y) - arg0->y) < (arg1[4] + 20.0f))) {
return true;
}
return false;
}
s32 func_8006326C(Vec3f* arg0, Vec3f* arg1, s32 arg2, Object* arg3) {
Vec3f sp74;
Vec3f sp68;
Vec3f sp5C;
Vec3f sp50;
Vec3f sp44;
s32 var_s1;
s32 pad1[3];
f32 sp30;
s32 pad2;
sp74.x = arg0->x - arg3->pos.x;
sp74.z = arg0->z - arg3->pos.z;
if (((fabsf(sp74.x) < 1100.0f) && (fabsf(sp74.z) < 1100.0f)) || (arg2 == 0xB4)) {
sp74.y = arg0->y - arg3->pos.y;
Matrix_RotateY(gCalcMatrix, -arg3->rot.y * M_DTOR, 0);
Matrix_MultVec3fNoTranslate(gCalcMatrix, &sp74, &sp68);
sp5C.x = arg3->pos.x + sp68.x;
sp5C.y = arg3->pos.y + sp68.y;
sp5C.z = arg3->pos.z + sp68.z;
sp50.x = arg3->pos.x;
sp50.y = arg3->pos.y;
sp50.z = arg3->pos.z;
if ((arg2 == 180) || (arg2 == 149) || (arg2 == 150) || (arg2 == 308) || (arg2 == 313) || (arg2 == 312) ||
(arg2 == 309) || (arg2 == 39)) {
var_s1 = 0;
if (arg2 == 312) {
var_s1 = 9;
}
if (arg2 == 39) {
var_s1 = 1;
} else if (arg2 == 308) {
var_s1 = 4;
} else if (arg2 == 309) {
var_s1 = 7;
} else if (arg2 == 149) {
var_s1 = 5;
} else if (arg2 == 150) {
var_s1 = 6;
} else if (arg2 == 313) {
var_s1 = 8;
}
if (func_800998FC(&sp5C, &sp50, arg1, var_s1, &sp44, &sp30) > 0) {
return true;
}
} else {
var_s1 = 0;
if (arg2 == 2) {
var_s1 = 2;
}
if (arg2 == 3) {
var_s1 = 3;
}
if (arg2 == 140) {
var_s1 = 4;
}
if (arg2 == 141) {
var_s1 = 6;
}
if (arg2 == 117) {
var_s1 = 14;
} else if ((arg2 == 4) || (arg2 == 5)) {
var_s1 = 1;
}
if (func_800A3690(&sp5C, &sp50, var_s1, &sp44) != 0) {
return true;
}
}
}
return false;
}
s32 func_8006351C(s32 arg0, Vec3f* arg1, Vec3f* arg2, s32 arg3) {
Object_58* var_s0;
Object_80* var_s0_2;
Object_4C* var_s0_3;
Object_408* var_s0_4;
Object_2F4* var_s0_5;
Vec3f temp;
s32 i;
if ((D_80177880 == 1) && (gCurrentLevel != LEVEL_KATINA)) {
var_s0 = gObjects58;
for (i = 0; i < 200; i++, var_s0++) {
if (var_s0->obj.status == 2) {
if ((var_s0->obj.id == OBJECT_1) || (var_s0->obj.id == OBJECT_3) || (var_s0->obj.id == OBJECT_117) ||
(var_s0->obj.id == OBJECT_141) || (var_s0->obj.id == OBJECT_150) ||
(var_s0->obj.id == OBJECT_149) || (var_s0->obj.id == OBJECT_148) ||
(var_s0->obj.id == OBJECT_140)) {
if (func_8006326C(arg1, arg2, var_s0->obj.id, &var_s0->obj)) {
return 999;
}
} else if ((fabsf(arg1->x - var_s0->obj.pos.x) < 2000.0f) &&
(fabsf(arg1->z - var_s0->obj.pos.z) < 2000.0f)) {
if (func_80062DBC(arg1, var_s0->unk_1C.unk_0C, &var_s0->obj, 0.0f, 0.0f, 0.0f)) {
return 2;
}
}
}
}
}
var_s0_2 = gObjects80;
for (i = 0; i < ARRAY_COUNT(gObjects80) && D_80177880 == 0; i++, var_s0_2++) {
if (var_s0_2->obj.status == 2) {
if ((var_s0_2->obj.id == OBJECT_1) || (var_s0_2->obj.id == OBJECT_4) || (var_s0_2->obj.id == OBJECT_5) ||
(var_s0_2->obj.id == OBJECT_2) || (var_s0_2->obj.id == OBJECT_39) || (var_s0_2->obj.id == OBJECT_3)) {
if (func_8006326C(arg1, arg2, var_s0_2->obj.id, &var_s0_2->obj)) {
return 2;
}
} else if ((fabsf(arg1->x - var_s0_2->obj.pos.x) < 2000.0f) &&
(fabsf(arg1->z - var_s0_2->obj.pos.z) < 2000.0f)) {
if (func_80062DBC(arg1, var_s0_2->unk_1C.unk_0C, &var_s0_2->obj, 0.0f, 0.0f, 0.0f)) {
return i + 10;
}
}
}
}
var_s0_3 = gObjects4C;
for (i = 0; i < ARRAY_COUNT(gObjects4C); i++, var_s0_3++) {
if ((var_s0_3->obj.status == 2) && (fabsf(arg1->x - var_s0_3->obj.pos.x) < 500.0f) &&
(fabsf(arg1->z - var_s0_3->obj.pos.z) < 500.0f) &&
func_800631A8(arg1, var_s0_3->unk_1C.unk_0C, &var_s0_3->obj.pos)) {
if ((var_s0_3->obj.id == OBJECT_163) || (var_s0_3->obj.id == OBJECT_162) ||
(var_s0_3->obj.id == OBJECT_162)) {
var_s0_3->unk_46 = 1;
}
return 0;
}
}
if ((arg3 == 0) || (arg3 == 2) || (arg3 == 3)) {
if (arg3 != 2) {
var_s0_4 = gObjects408;
for (i = 0; i < ARRAY_COUNT(gObjects408); i++, var_s0_4++) {
if (var_s0_4->obj.status == 2) {
if ((var_s0_4->obj.id == OBJECT_308) || (var_s0_4->obj.id == OBJECT_312) ||
(var_s0_4->obj.id == OBJECT_313) || (var_s0_4->obj.id == OBJECT_309)) {
if (func_8006326C(arg1, arg2, var_s0_4->obj.id, &var_s0_4->obj)) {
return 2;
}
} else if (var_s0_4->obj.id == OBJECT_310) {
temp.x = fabsf(var_s0_4->obj.pos.x - arg1->x) * (5.0f / 6.0f);
temp.y = fabsf(var_s0_4->obj.pos.y - arg1->y) * 2;
temp.z = fabsf(var_s0_4->obj.pos.z - arg1->z) * (5.0f / 6.0f);
if (sqrtf(VEC3F_SQ(temp)) < 1500.0f) {
var_s0_4->unk_062 = 1;
return 2;
}
} else {
if (var_s0_4->obj.id == OBJECT_316) {
temp.x = fabsf(var_s0_4->obj.pos.x - arg1->x);
temp.y = fabsf(var_s0_4->obj.pos.y - 300.0f - arg1->y) * 7.42f;
temp.z = fabsf(var_s0_4->obj.pos.z - arg1->z);
if (sqrtf(VEC3F_SQ(temp)) < 2700.0f) {
return 2;
}
}
if ((fabsf(arg1->x - var_s0_4->obj.pos.x) < 2000.0f) &&
(fabsf(arg1->z - var_s0_4->obj.pos.z) < 2000.0f)) {
if (func_80062DBC(arg1, var_s0_4->unk_01C.unk_0C, &var_s0_4->obj, 0.0f, 0.0f, 0.0f)) {
return 2;
}
}
}
}
}
}
var_s0_5 = gObjects2F4;
for (i = 0; i < ARRAY_COUNT(gObjects2F4); i++, var_s0_5++) {
if ((var_s0_5->obj.status >= 2) && (fabsf(arg1->x - var_s0_5->obj.pos.x) < 1000.0f) &&
(fabsf(arg1->z - var_s0_5->obj.pos.z) < 1500.0f) && (arg0 != i) && (var_s0_5->unk_01C.unk_16 != 2) &&
((var_s0_5->obj.id != OBJECT_197) || (var_s0_5->unk_0E4 >= 4)) && (var_s0_5->unk_0C2 == 0)) {
if (var_s0_5->obj.id == OBJECT_180) {
if (func_8006326C(arg1, arg2, var_s0_5->obj.id, &var_s0_5->obj) != 0) {
return 2;
}
} else if (var_s0_5->unk_110 < 0.0f) {
if (func_80062DBC(arg1, var_s0_5->unk_01C.unk_0C, &var_s0_5->obj, var_s0_5->unk_2E8.x,
var_s0_5->unk_2E8.y, var_s0_5->unk_2E8.z + var_s0_5->unk_0F4.z)) {
var_s0_5->unk_0D0 = 1;
var_s0_5->unk_0D6 = 10;
var_s0_5->unk_0D2 = -1;
var_s0_5->unk_0D8.x = arg1->x;
var_s0_5->unk_0D8.y = arg1->y;
var_s0_5->unk_0D8.z = arg1->z;
return 2;
}
} else if ((arg3 != 2) && (arg3 != 3)) {
if (func_800631A8(arg1, var_s0_5->unk_01C.unk_0C, &var_s0_5->obj.pos)) {
var_s0_5->unk_0D0 = 1;
var_s0_5->unk_0D6 = 10;
var_s0_5->unk_0D2 = -1;
if (((var_s0_5->obj.id != OBJECT_200) || (var_s0_5->unk_080 == 0)) &&
((var_s0_5->obj.id != OBJECT_197) ||
((var_s0_5->unk_0E4 >= 10) && (var_s0_5->unk_0E4 < 100)))) {
var_s0_5->unk_0CE = 0;
}
var_s0_5->unk_0D8.x = arg1->x;
var_s0_5->unk_0D8.y = arg1->y;
var_s0_5->unk_0D8.z = arg1->z;
return 1;
}
}
}
}
}
return 0;
}
void func_80063CAC(Object_80* arg0) {
s32 i;
for (i = 0; i < ARRAY_COUNT(gObjects2F4); i++) {
if (gObjects2F4[i].obj.status == 0) {
Object_2F4_Initialize(&gObjects2F4[i]);
gObjects2F4[i].obj.status = 1;
gObjects2F4[i].obj.id = OBJECT_193;
gObjects2F4[i].obj.pos.x = arg0->obj.pos.x;
gObjects2F4[i].obj.pos.y = arg0->obj.pos.y;
gObjects2F4[i].obj.pos.z = arg0->obj.pos.z;
gObjects2F4[i].obj.rot.y = Rand_ZeroOne() * 360.0f;
func_800612B8(&gObjects2F4[i].unk_01C, gObjects2F4[i].obj.id);
break;
}
}
}
void func_80063D58(Object_80* arg0) {
s32 i;
arg0->obj.pos.y = D_80177940;
for (i = 0; i < ARRAY_COUNT(gObjects4C); i++) {
if (gObjects4C[i].obj.status == 0) {
Object_4C_Initialize(&gObjects4C[i]);
gObjects4C[i].obj.status = 1;
gObjects4C[i].obj.id = OBJECT_164;
gObjects4C[i].unk_45 = arg0->obj.id;
gObjects4C[i].obj.pos.x = arg0->obj.pos.x;
gObjects4C[i].obj.pos.y = 5.0f;
gObjects4C[i].obj.pos.z = arg0->obj.pos.z;
if ((arg0->obj.id == OBJECT_0) || (arg0->obj.id == OBJECT_6) || (arg0->obj.id == OBJECT_7) ||
(arg0->obj.id == OBJECT_56) || (arg0->obj.id == OBJECT_20) || (arg0->obj.id == OBJECT_21) ||
(arg0->obj.id == OBJECT_22)) {
gObjects4C[i].obj.rot.y = arg0->obj.rot.y;
} else {
gObjects4C[i].obj.rot.y = 44.9f;
}
func_800612B8(&gObjects4C[i].unk_1C, gObjects4C[i].obj.id);
break;
}
}
}
void func_80063E5C(Object_80* arg0, f32* arg1) {
s32 i;
Object_6C* var_v1;
for (i = 0, var_v1 = gObjects6C; i < ARRAY_COUNT(gObjects6C); i++, var_v1++) {
if (var_v1->obj.status == 0) {
Object_6C_Initialize(&gObjects6C[i]);
var_v1->obj.status = 1;
var_v1->obj.id = OBJECT_334;
var_v1->obj.pos.x = arg0->obj.pos.x;
var_v1->obj.pos.y = arg0->obj.pos.y;
var_v1->obj.pos.z = arg0->obj.pos.z;
var_v1->obj.rot.y = arg0->obj.rot.y;
func_800612B8(&var_v1->unk_1C, var_v1->obj.id);
var_v1->unk_1C.unk_0C = SEGMENTED_TO_VIRTUAL(arg1);
break;
}
}
}
void func_80063F4C(s32 arg0) {
}
void func_80063F58(Object_6C* arg0) {
arg0->unk_68 = arg0->obj.rot.z * 100.0f;
}
void func_80063F74(Object_6C* arg0) {
arg0->unk_68 = arg0->obj.rot.z * 100.0f;
}
void func_80063F90(s32 arg0, s32 objId) {
s32 var_a0;
s32 var_a2;
f32 sp54;
f32 sp50;
f32 sp4C;
f32* var_v0;
switch (objId) {
case 170:
func_8007A6F0(&gObjects4C[arg0].obj.pos, 0x11000055);
break;
case 234:
func_80019218(0x11030010, &gObjects2F4[arg0].unk_100, 0, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
break;
case 54:
func_80019218(0x11000000, &gObjects80[arg0].unk_70, 0, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
break;
case 198:
func_80092D48(&gObjects2F4[arg0]);
break;
case 235:
gObjects2F4[arg0].unk_13C = fabsf(Math_ModF(gObjects2F4[arg0].obj.pos.x, 100.0f));
break;
case 0xF7:
func_E16C50_8019D060(&gObjects2F4[arg0]);
break;
case 0x170:
if (gCurrentLevel == LEVEL_TITANIA) {
func_E6A810_801B6E20(gObjects8C[arg0].obj.pos.x, gObjects8C[arg0].obj.pos.z + D_80177D20, &sp54, &sp4C,
&sp50);
gObjects8C[arg0].obj.pos.y = sp4C + 3.0f;
gObjects8C[arg0].obj.rot.x = (sp54 * 180.0f) / M_PI;
gObjects8C[arg0].obj.rot.z = (sp50 * 180.0f) / M_PI;
} else if (gCurrentLevel == LEVEL_MACBETH) {
gObjects8C[arg0].obj.status = 0;
}
break;
case 0x1E:
func_80063E5C(&gObjects80[arg0], D_6006940);
break;
case 0x1F:
func_80063E5C(&gObjects80[arg0], D_600695C);
break;
case 0x20:
func_80063E5C(&gObjects80[arg0], D_6006978);
break;
case 0x21:
func_80063E5C(&gObjects80[arg0], D_6006994);
break;
case 0x22:
func_80063E5C(&gObjects80[arg0], D_60069B0);
break;
case 0x23:
func_80063E5C(&gObjects80[arg0], D_60069CC);
break;
case 0x24:
func_80063E5C(&gObjects80[arg0], D_60069E8);
break;
case 0x25:
func_80063E5C(&gObjects80[arg0], D_6006A04);
break;
case 0x26:
func_80063E5C(&gObjects80[arg0], D_6006A20);
break;
case 0x17:
func_80063CAC(&gObjects80[arg0]);
break;
case 0x143:
if (D_80177CA0 != 0) {
gObjects6C[arg0].obj.status = 0;
}
break;
case 0x146:
if (D_80177E80 < 0) {
gObjects6C[arg0].obj.status = 0;
}
break;
case 0x14B:
case 0x14C:
case 0x14D:
func_80063F74(&gObjects6C[arg0]);
break;
case 0x148:
case 0x149:
func_80063F58(&gObjects6C[arg0]);
break;
case 0x14A:
if (((D_80177E80 >= 7) && (gCurrentLevel == LEVEL_CORNERIA) && (D_801778B0[1] > 0)) ||
(gCurrentLevel != LEVEL_CORNERIA)) {
func_80063F58(&gObjects6C[arg0]);
} else {
gObjects6C[arg0].obj.status = 0;
}
break;
case 0x0:
func_80063E5C(&gObjects80[arg0], D_800CBF18);
/* fallthrough */
case 0x6:
case 0x7:
case 0x14:
case 0x15:
case 0x16:
case 0x38:
func_80063D58(&gObjects80[arg0]);
break;
case 0xBB:
gObjects2F4[arg0].unk_114 = gObjects2F4[arg0].obj.pos.x;
gObjects2F4[arg0].unk_118 = gObjects2F4[arg0].obj.pos.y;
gObjects2F4[arg0].obj.rot.z = gObjects2F4[arg0].obj.rot.x;
gObjects2F4[arg0].obj.rot.x = 0.0f;
break;
case 0xB6:
case 0xBA:
gObjects2F4[arg0].unk_046 = gFogRed;
gObjects2F4[arg0].unk_048 = gFogNear;
gObjects2F4[arg0].obj.rot.x = Rand_ZeroOne() * 360.0f;
gObjects2F4[arg0].obj.rot.y = Rand_ZeroOne() * 360.0f;
break;
case 0xB5:
gObjects2F4[arg0].obj.rot.x = Rand_ZeroOne() * 360.0f;
gObjects2F4[arg0].obj.rot.y = Rand_ZeroOne() * 360.0f;
gObjects2F4[arg0].unk_0CE = 200;
break;
case 0xCA:
gObjects2F4[arg0].unk_0CE = 30;
break;
case 0xFC:
if (gPlayer[0].unk_07C < gObjects2F4[arg0].obj.pos.z) {
Object_Kill(&gObjects2F4[arg0].obj, &gObjects2F4[arg0].unk_100);
}
break;
case 0xEF:
gObjects2F4[arg0].unk_050 = D_801784A4;
D_801784A4++;
break;
case 0xEC:
D_801784A4 = 0;
gObjects2F4[arg0].unk_0F4.x = gObjects2F4[arg0].obj.rot.x;
gObjects2F4[arg0].unk_0F4.y = gObjects2F4[arg0].obj.rot.y;
gObjects2F4[arg0].obj.rot.x = gObjects2F4[arg0].obj.rot.y = 0.0f;
gObjects2F4[arg0].unk_11C = gObjects2F4[arg0].obj.pos.y;
var_v0 = D_801782C4;
for (var_a0 = 0; var_a0 < 200; var_a0++, var_v0 += 6) {
var_v0[0] = gObjects2F4[arg0].obj.pos.x;
var_v0[1] = gObjects2F4[arg0].obj.pos.y;
var_v0[2] = gObjects2F4[arg0].obj.pos.z;
var_v0[3] = gObjects2F4[arg0].obj.rot.x;
var_v0[4] = gObjects2F4[arg0].obj.rot.y;
var_v0[5] = gObjects2F4[arg0].obj.rot.z;
}
break;
case 0xC2:
gObjects2F4[arg0].unk_046 = 100;
for (var_a0 = 0; var_a0 < 2; var_a0++) {
if (D_80176550[var_a0] == 0) {
D_80176550[var_a0] = 1;
gObjects2F4[arg0].unk_046 = var_a0;
for (var_a2 = 0; var_a2 < 100; var_a2++) {
D_80176878[var_a0][var_a2] = gObjects2F4[arg0].obj.pos.y;
D_80176B98[var_a0][var_a2] = gObjects2F4[arg0].obj.pos.z;
}
break;
}
}
if (gObjects2F4[arg0].unk_046 == 100) {
gObjects2F4[arg0].obj.status = 0;
}
break;
case 0xBE:
case 0xBF:
func_80019218(0x31000012, &gObjects2F4[arg0].unk_100, 4, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
break;
case 0xC0:
gObjects2F4[arg0].unk_0C9 = 1;
break;
case 0x140:
func_E9F1D0_8018D16C(&gObjects408[arg0]);
break;
case 0x13C:
func_E51970_80193CA4(&gObjects408[arg0]);
break;
case 0x13A:
func_E9F1D0_80197CC4(&gObjects408[arg0]);
break;
case 0xCD:
case 0xCE:
case 0xD0:
case 0xD1:
case 0xD2:
case 0xD3:
case 0xD4:
case 0xD5:
func_E6A810_80199F8C(&gObjects2F4[arg0]);
break;
case 0xCF:
func_E6A810_801A7D98(&gObjects2F4[arg0]);
break;
case 0xD6:
func_E6A810_801A3E70(&gObjects2F4[arg0]);
break;
case 0xD7:
func_E6A810_801A4660(&gObjects2F4[arg0]);
break;
case 0xDF:
func_E6A810_801A4AF8(&gObjects2F4[arg0]);
break;
case 0xD8:
case 0xD9:
func_E6A810_801A5E2C(&gObjects2F4[arg0]);
break;
case 0xDA:
func_E6A810_801A6134(&gObjects2F4[arg0]);
break;
case 0x41:
func_E6A810_801A65E0(&gObjects80[arg0]);
break;
case 0xB1:
case 0xB2:
func_DF4260_8018B0B4(&gObjects2F4[arg0]);
/* fallthrough */
case 0xB0:
gObjects2F4[arg0].unk_0CE = 24;
func_80019218(0x31000016, &gObjects2F4[arg0].unk_100, 4, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
break;
case 0x129:
func_E08400_80188A40(&gObjects408[arg0]);
break;
case 0x12B:
func_80042FAC(&gObjects408[arg0]);
break;
case 0x12C:
func_80042FD0(&gObjects408[arg0]);
break;
case 0x124:
func_DF4260_801878D8(&gObjects408[arg0]);
break;
case 0x125:
func_DF4260_8018BE7C(&gObjects408[arg0]);
break;
case 0x12E:
func_E16C50_80187754(&gObjects408[arg0]);
break;
case 0xE7:
func_E6A810_8018B96C(&gObjects2F4[arg0]);
break;
case 0xE8:
func_E6A810_8018ADC4(&gObjects2F4[arg0]);
break;
case 0xE9:
func_E6A810_80189B80(&gObjects2F4[arg0]);
break;
case 0xE5:
func_E6A810_8018BFB0(&gObjects2F4[arg0]);
break;
case 0xE3:
func_E6A810_8018E3CC(&gObjects2F4[arg0]);
break;
case 0xE4:
func_E6A810_8018E5E8(&gObjects2F4[arg0]);
break;
case 0xA9:
func_E6A810_8018EFF0(&gObjects4C[arg0]);
break;
case 0x132:
func_E6A810_8018FA48(&gObjects408[arg0]);
break;
case 0xF0:
func_E16C50_801915A4(&gObjects2F4[arg0]);
break;
case 0xF1:
func_E16C50_80191BB8(&gObjects2F4[arg0]);
break;
case 0x133:
func_E16C50_801932AC(&gObjects408[arg0]);
break;
case 0xFA:
func_E16C50_8019B1F0(&gObjects2F4[arg0]);
break;
case 0xFB:
func_E16C50_8019B810(&gObjects2F4[arg0]);
break;
case 0xFD:
func_E16C50_8019C200(&gObjects2F4[arg0]);
break;
case 0xFF:
func_E16C50_801AD688(&gObjects2F4[arg0]);
break;
case 0x100:
func_E16C50_801AE3AC(&gObjects2F4[arg0]);
break;
case 0x101:
func_E16C50_801AF9FC(&gObjects2F4[arg0]);
break;
case 0x13E:
func_E16C50_801B10F8(&gObjects408[arg0]);
break;
case 0x103:
func_E16C50_801B6344(&gObjects2F4[arg0]);
break;
case 0x106:
func_E16C50_801B6E54(&gObjects2F4[arg0]);
break;
case 0x104:
func_E16C50_801B7AF0(&gObjects2F4[arg0]);
break;
case 0x39:
func_E6A810_8018F0D8(&gObjects80[arg0]);
break;
case 0x13F:
func_DF4260_801935CC(&gObjects408[arg0]);
break;
case 0x118:
func_DF4260_8019250C(&gObjects2F4[arg0]);
break;
case 0x119:
case 0x11A:
func_DF4260_80192CB0(&gObjects2F4[arg0]);
break;
case 0x11B:
func_DF4260_80192EA4(&gObjects2F4[arg0]);
break;
case 0x11C:
func_DF4260_801933B4(&gObjects2F4[arg0]);
break;
case 0x109:
func_E16C50_801BA57C(&gObjects2F4[arg0]);
break;
case 0x10B:
func_E16C50_801BB26C(&gObjects2F4[arg0]);
break;
}
}
void func_800652CC(Object_80* arg0) {
f32 sp2C;
f32 sp28;
f32 sp24;
if ((D_801784AC == 4) && (arg0->unk_48 == 0)) {
func_E6A810_801B6E20(arg0->obj.pos.x, arg0->obj.pos.z + D_80177D20, &sp2C, &sp24, &sp28);
arg0->obj.pos.y = sp24 + 3.0f;
arg0->obj.rot.x = (sp2C * 180.0f) / M_PI;
arg0->obj.rot.z = (sp28 * 180.0f) / M_PI;
arg0->unk_48 += 1;
}
}
void func_80065380(Object_2F4* arg0, f32 arg1, f32 arg2, f32 arg3, f32 arg4, f32 arg5, f32 arg6) {
Object_2F4_Initialize(arg0);
arg0->obj.status = 2;
arg0->obj.id = OBJECT_182;
arg0->unk_0BC = (s32) (Rand_ZeroOne() * 10.0f) + 10;
arg0->unk_0C2 = 30;
arg0->unk_0E8.x = arg4;
arg0->unk_0E8.y = arg5;
arg0->unk_0E8.z = arg6;
arg0->obj.pos.x = arg1;
arg0->obj.pos.y = arg2;
arg0->obj.pos.z = arg3;
arg0->unk_046 = 0xFF;
arg0->unk_048 = 900;
arg0->obj.rot.z = Rand_ZeroOne() * 360.0f;
arg0->obj.rot.y = Rand_ZeroOne() * 360.0f;
func_800612B8(&arg0->unk_01C, arg0->obj.id);
}
void func_8006546C(f32 arg0, f32 arg1, f32 arg2, f32 arg3, f32 arg4, f32 arg5) {
s32 i;
for (i = 0; i < ARRAY_COUNT(gObjects2F4); i++) {
if (gObjects2F4[i].obj.status == 0) {
func_80065380(&gObjects2F4[i], arg0, arg1, arg2, arg3, arg4, arg5);
break;
}
}
}
void func_800654E4(Object* arg0) {
f32 temp_fs0;
f32 temp_fs1;
s32 var_s1;
func_8007D2C8(arg0->pos.x, arg0->pos.y, arg0->pos.z, 12.0f);
for (var_s1 = 0; var_s1 < 4; var_s1++) {
func_8006546C(arg0->pos.x, arg0->pos.y, arg0->pos.z, (Rand_ZeroOne() - 0.5f) * 40.0f,
(Rand_ZeroOne() - 0.5f) * 40.0f, Rand_ZeroOne() * -20.0f);
}
}
void func_800655C8(Object_2F4* arg0, f32 arg1, f32 arg2, f32 arg3, s32 arg4) {
Object_2F4_Initialize(arg0);
arg0->obj.status = 1;
arg0->obj.id = OBJECT_190;
arg0->obj.pos.x = arg1;
arg0->obj.pos.y = arg2;
arg0->obj.pos.z = arg3;
arg0->unk_0B4 = arg4;
arg0->unk_0BE = 50;
if (arg0->unk_0B4 == 1) {
arg0->unk_0BE = 30;
}
arg0->unk_124.y = 15.0f;
func_800612B8(&arg0->unk_01C, arg0->obj.id);
}
void func_8006566C(f32 arg0, f32 arg1, f32 arg2, s32 arg3) {
s32 i;
for (i = 0; i < ARRAY_COUNT(gObjects2F4); i++) {
if (gObjects2F4[i].obj.status == 0) {
func_800655C8(&gObjects2F4[i], arg0, arg1, arg2, arg3);
break;
}
}
}
#ifdef NON_MATCHING
void func_800656D4(Object_2F4* arg0) {
f32 spD4;
f32 spD0;
f32 spCC;
s32 spC4;
s32 spB4[3];
s32 spA8[3];
Vec3f sp98;
Vec3f sp8C;
f32 sp88;
f32 sp84;
f32 sp80;
f32 sp7C;
f32 sp78;
s32 var_ra;
f32 var_fv0;
s32 temp_a0;
s32 temp_a2;
s32 temp_t9;
s32 temp_v0;
s32 i;
s32 j;
if (D_80177880 == 1) {
var_ra = 2;
} else {
var_ra = 0;
}
if (arg0->unk_058 == 0) {
if (arg0->obj.id == OBJECT_190) {
for (i = 0, j = 1; j < 4; i++, j++) {
spA8[i] = var_ra + j;
spB4[i] = D_801778B0[j];
}
for (i = 0, j = 1; j < 3; i++, j++) {
temp_a0 = spB4[i];
temp_a2 = spB4[j];
temp_v0 = spA8[j];
if (spB4[i] < spB4[j]) {
spA8[j] = spA8[i];
spB4[j] = temp_a0;
spB4[i] = temp_a2;
spA8[i] = temp_v0;
}
}
switch (gFrameCount % 6U) {
case 0:
case 1:
case 2:
spC4 = spA8[2];
break;
case 3:
case 4:
spC4 = spA8[1];
break;
case 5:
spC4 = spA8[0];
break;
}
if (D_80177880 == 1) {
if (D_801778B0[spC4 - 1] > 0) {
arg0->unk_054 = spC4;
goto label;
} else {
arg0->unk_054 = 10000;
}
} else {
if (D_801778B0[spC4 + 1] > 0) {
arg0->unk_054 = spC4;
goto label;
} else {
arg0->unk_054 = 10000;
}
}
}
arg0->unk_054 = 10000;
label:
arg0->unk_058 = 1;
}
spC4 = arg0->unk_054;
if ((spC4 == var_ra) || ((var_ra + 1) == spC4) || ((var_ra + 2) == spC4)) {
arg0->unk_188 = gObjects2F4[spC4].obj.pos.z;
arg0->unk_184 = gObjects2F4[spC4].obj.pos.y;
arg0->unk_180 = gObjects2F4[spC4].obj.pos.x;
if ((fabsf(arg0->obj.pos.x - gObjects2F4[spC4].obj.pos.x) < 400.0f) &&
(fabsf(arg0->obj.pos.z - gObjects2F4[spC4].obj.pos.z) < 400.0f)) {
if ((Rand_ZeroOne() * (spC4 - 1)) < 0.6f) {
gObjects2F4[spC4].unk_078 = 1;
}
}
} else {
arg0->unk_188 = gPlayer[0].unk_138;
arg0->unk_184 = gPlayer[0].unk_078;
arg0->unk_180 = gPlayer[0].unk_074;
}
if (arg0->unk_0BC != 0) {
Math_SmoothStepToAngle(&arg0->obj.rot.x, 0.0f, 0.3f, 4.0f, 0.001f);
} else {
if ((arg0->unk_078 == 0) &&
((fabsf(arg0->unk_180 - arg0->obj.pos.x) > 300.0f) || (fabsf(arg0->unk_188 - arg0->obj.pos.z) > 300.0f))) {
arg0->unk_114 += 5.0f;
arg0->unk_118 += 8.0f;
sp80 = sqrtf(SQ(arg0->unk_180 - arg0->obj.pos.x) + SQ(arg0->unk_188 - arg0->obj.pos.z)) * 0.2f;
if (arg0->unk_0B4 == 1) {
sp80 = 0.1f;
}
spD0 = __sinf(arg0->unk_114 * M_DTOR) * sp80;
sp88 = __cosf(arg0->unk_118 * M_DTOR) * sp80;
spD4 = __cosf(arg0->obj.rot.y * M_DTOR) * sp88;
spCC = -__sinf(arg0->obj.rot.y * M_DTOR) * sp88;
sp88 = (arg0->unk_180 + spD4) - arg0->obj.pos.x;
sp84 = (arg0->unk_184 + spD0) - arg0->obj.pos.y;
sp80 = (arg0->unk_188 + spCC) - arg0->obj.pos.z;
sp78 = Math_RadToDeg(Math_Atan2F(sp88, sp80));
sp7C = Math_RadToDeg(-Math_Atan2F(sp84, sqrtf((sp88 * sp88) + (sp80 * sp80))));
sp84 = Math_SmoothStepToAngle(&arg0->obj.rot.y, sp78, 0.3f, 4.0f, 0.001f);
Math_SmoothStepToAngle(&arg0->obj.rot.x, sp7C, 0.3f, 4.0f, 0.001f);
}
if ((fabsf(arg0->unk_180 - arg0->obj.pos.x) < 60.0f) && (fabsf(arg0->unk_184 - arg0->obj.pos.y) < 60.0f) &&
(fabsf(arg0->unk_188 - arg0->obj.pos.z) < 60.0f) && ((spC4 == 2) || (spC4 == 3) || (spC4 == 4))) {
gObjects2F4[spC4].unk_0D0 = 1;
gObjects2F4[spC4].unk_0D6 = 20;
gObjects2F4[spC4].unk_0D4 = 2;
func_8007A6F0(&arg0->obj.pos, 0x2903A008);
func_8007D2C8(arg0->obj.pos.x, arg0->obj.pos.y, arg0->obj.pos.z, 5.0f);
Object_Kill(&arg0->obj, &arg0->unk_100);
}
}
Math_Vec3fFromAngles(&sp98, arg0->obj.rot.x, arg0->obj.rot.y, arg0->unk_124.y);
arg0->unk_0E8.x = sp98.x;
arg0->unk_0E8.y = sp98.y;
arg0->unk_0E8.z = sp98.z - D_80177D08;
if (arg0->unk_0B4 == 0) {
arg0->obj.rot.z += 5.0f;
}
if (arg0->unk_0B4 == 1) {
if (arg0->unk_0BE == 0) {
arg0->unk_0BE = 30;
Math_Vec3fFromAngles(&sp98, arg0->obj.rot.x, arg0->obj.rot.y, 120.0f);
func_8007F04C(0x161, arg0->obj.pos.x + sp98.x, arg0->obj.pos.y + sp98.y, arg0->obj.pos.z + sp98.z,
arg0->obj.rot.x, arg0->obj.rot.y, arg0->obj.rot.z, 0.0f, 0.0f, 0.0f, sp98.x, sp98.y, sp98.z,
1.0f);
}
var_fv0 = 330.0f;
if (sp84 < 0.0f) {
var_fv0 = 30.0f;
}
Math_SmoothStepToAngle(&arg0->obj.rot.z, var_fv0, 0.1f, 3.0f, 0.01f);
}
if ((D_801784AC == 4) &&
(func_E6A810_801B6AEC(arg0->obj.pos.x, arg0->obj.pos.y, arg0->obj.pos.z + D_80177D20) != 0)) {
func_8007D2C8(arg0->obj.pos.x, arg0->obj.pos.y, arg0->obj.pos.z, 5.0f);
Object_Kill(&arg0->obj, &arg0->unk_100);
}
sp8C.x = arg0->unk_0E8.x;
sp8C.y = arg0->unk_0E8.y;
sp8C.z = arg0->unk_0E8.z;
if ((func_8006351C(arg0->unk_040, &arg0->obj.pos, &sp8C, 1) != 0) || (arg0->unk_0D0 != 0) ||
(arg0->obj.pos.y < (D_80177940 + 10.0f)) || (gPlayer[0].unk_1C8 == 7)) {
func_8007D2C8(arg0->obj.pos.x, arg0->obj.pos.y, arg0->obj.pos.z, 3.0f);
Object_Kill(&arg0->obj, &arg0->unk_100);
if (arg0->unk_0D0 != 0) {
arg0->unk_044 = 2;
if ((gCurrentLevel == LEVEL_CORNERIA)) {
if (D_80177880 == 1) {
arg0->unk_044 = 2;
} else {
arg0->unk_044 = 4;
}
}
if (gCurrentLevel == LEVEL_AREA_6) {
arg0->unk_044 = 22;
}
func_80066254(arg0);
}
func_8007A6F0(&arg0->obj.pos, 0x2903A008);
}
if (D_80177880 == 0) {
if (fabsf(arg0->obj.pos.z - gPlayer[0].unk_138) < 100.0f) {
arg0->unk_078 = 1;
}
if (gPlayer[0].unk_040.z < (arg0->obj.pos.z + D_80177D20)) {
Object_Kill(&arg0->obj, &arg0->unk_100);
}
}
}
#else
#pragma GLOBAL_ASM("asm/us/nonmatchings/main/fox_enmy/func_800656D4.s")
#endif
void func_800660F0(Object_2F4* arg0) {
Object_6C* var_s0 = gObjects6C;
s32 i;
for (i = 0; i < ARRAY_COUNT(gObjects6C); i++, var_s0++) {
if (var_s0->obj.status == 0) {
Object_6C_Initialize(var_s0);
var_s0->obj.status = 1;
var_s0->obj.id = D_800CFDF4[arg0->unk_044];
var_s0->obj.pos.x = arg0->obj.pos.x;
var_s0->obj.pos.y = arg0->obj.pos.y;
var_s0->obj.pos.z = arg0->obj.pos.z;
var_s0->unk_4A = 8;
func_800612B8(&var_s0->unk_1C, var_s0->obj.id);
if ((var_s0->obj.id == OBJECT_6C_SILVER_RING) || (var_s0->obj.id == OBJECT_6C_BOMB) ||
(var_s0->obj.id == OBJECT_6C_LASERS)) {
var_s0->unk_50 = 90.0f;
}
if ((var_s0->obj.id >= OBJECT_6C_GOLD_RING) || (var_s0->obj.id == OBJECT_6C_1UP)) {
var_s0->unk_50 = 90.0f;
func_80019218(0x4900000C, &D_800C5D28, 4, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
var_s0->unk_48 = 1000;
if (var_s0->obj.id == OBJECT_6C_WING_REPAIR) {
func_80019218(0x1900302B, &var_s0->unk_5C, 0, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
}
}
break;
}
}
}
void func_80066254(Object_2F4* arg0) {
Object_2F4* var_v0;
s32 i;
if (D_801778E8 != 0) {
if ((arg0->unk_0D4 > 0) && (arg0->unk_0D4 < 5) &&
!((D_80178768[0] == 0) && (D_80178768[1] == 0) && (D_80178768[2] == 0))) {
D_80177C30[arg0->unk_0D4 - 1] += arg0->unk_01C.unk_20;
}
} else if ((arg0->obj.id != OBJECT_197) || (arg0->unk_0B6 != 1)) {
if ((arg0->unk_0D4 == 1) && (arg0->unk_01C.unk_20 != 0)) {
gHitCount += arg0->unk_01C.unk_20;
D_80177850 = 0xF;
if ((D_80177880 == 1) && (D_80161A62 != 0)) {
switch (D_80161A62) {
case 9:
if (gCurrentLevel == LEVEL_KATINA) {
func_800BA808(gMsg_ID_18031, RCID_BILL);
}
/* fallthrough */
case 4:
case 19:
case 29:
arg0->unk_044 = 14;
break;
case 14:
arg0->unk_044 = 9;
break;
}
D_80161A62 = 0;
}
if (arg0->obj.id == OBJECT_197) {
if ((arg0->unk_0E4 >= 4) && (arg0->unk_0E4 < 8)) {
func_8002E3E0(arg0);
}
}
}
if (arg0->unk_044) {
if (D_800CFE5C[arg0->unk_044] < 0.0f) {
var_v0 = gObjects2F4;
for (i = 0, var_v0 = gObjects2F4; i < ARRAY_COUNT(gObjects2F4); i++, var_v0++) {
if ((var_v0->obj.status != 0) && (var_v0->unk_040 != arg0->unk_040) &&
(arg0->unk_08C == var_v0->unk_08C)) {
return;
}
}
func_800660F0(arg0);
func_80019218(0x4900000C, &D_800C5D28, 4, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
} else if (arg0->unk_044 == 24) {
if (D_801778B0[3] > 0) {
func_800BA808(gMsg_ID_20261, RCID_PEPPY);
} else if (D_801778B0[2] > 0) {
func_800BA808(gMsg_ID_20263, RCID_SLIPPY);
} else if (D_801778B0[1] > 0) {
func_800BA808(gMsg_ID_20262, RCID_FALCO);
}
} else if (Rand_ZeroOne() <= D_800CFE5C[arg0->unk_044]) {
func_800660F0(arg0);
}
}
}
}
void func_8006654C(Object_2F4* arg0) {
arg0->unk_10C = 0.4f;
if (arg0->obj.pos.y <= D_80177940 + 130.0f) {
arg0->obj.pos.y = D_80177940 + 130.0f;
arg0->unk_0E8.y = 0.0f;
}
arg0->unk_0E8.x = __sinf(arg0->obj.rot.y * M_DTOR) * (*arg0).unk_114;
arg0->unk_0E8.z = __cosf(arg0->obj.rot.y * M_DTOR) * (*arg0).unk_114;
switch (arg0->unk_0B8) {
case 0:
if (arg0->unk_114 < 20.0f) {
arg0->unk_114 += 0.5f;
}
arg0->unk_0B6++;
if (Animation_GetFrameCount(&D_6029528) < arg0->unk_0B6) {
arg0->unk_0B6 = 0;
}
if ((arg0->obj.rot.z < 15.0f) && (arg0->unk_0B6 < 0x14)) {
arg0->obj.rot.z += 1.0f;
}
if ((arg0->obj.rot.z > -15.0f) && (arg0->unk_0B6 >= 0x15)) {
arg0->obj.rot.z -= 1.0f;
}
if ((arg0->unk_0B6 == 0x14) || (arg0->unk_0B6 == 0x28)) {
arg0->unk_0B8++;
arg0->unk_0BC = 0x14;
}
break;
case 1:
if (arg0->obj.rot.z > 0.0f) {
arg0->obj.rot.z -= 0.5f;
}
if (arg0->obj.rot.z < 0.0f) {
arg0->obj.rot.z += 0.5f;
}
if (arg0->unk_114 > 0.0f) {
arg0->unk_114 -= 0.3f;
}
if (arg0->unk_0BC == 0) {
arg0->unk_0B8 = 0;
}
break;
}
arg0->unk_110 = 0.8f;
if (arg0->unk_0D0 != 0) {
arg0->obj.status = 3;
arg0->unk_0E8.y = (Rand_ZeroOne() * 5.0f) + 6.0f;
if (arg0->unk_0D0 == 2) {
arg0->unk_0E8.y = -2.0f;
}
arg0->unk_0E8.z = -15.0f;
arg0->unk_10C = 0.5f;
func_8007D2C8(arg0->obj.pos.x, arg0->obj.pos.y + 30.0f, arg0->obj.pos.z, 13.0f);
func_80019218(0x2903A008, &arg0->unk_100, 4, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
}
}
void func_8006684C(Object_2F4* arg0) {
s32 pad;
if (arg0->unk_0BE != 0) {
arg0->unk_0E8.z = 0.0f;
arg0->unk_0E8.x = 0.0f;
arg0->unk_0E8.y = 0.0f;
if (arg0->unk_0BE == 1) {
Object_Kill(&arg0->obj, &arg0->unk_100);
arg0->unk_044 = 1;
func_80066254(arg0);
func_80019218(0x2903B009, &arg0->unk_100, 4, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
func_80077240(arg0->obj.pos.x, arg0->obj.pos.y + 250.0f, arg0->obj.pos.z, 3);
gHitCount += 3;
D_80177850 = 0xF;
}
} else {
arg0->obj.rot.x += 11.0f;
arg0->obj.rot.y += 7.0f;
if (arg0->unk_0E8.y < -3.0f) {
func_8007BFFC(arg0->obj.pos.x, arg0->obj.pos.y + 30.0f, arg0->obj.pos.z, 0.0f, 0.0f, 0.0f, 7.0f, 5);
arg0->unk_0BE = 3;
}
}
}
void func_800669A0(Object_2F4* arg0) {
if (arg0->unk_0BC != 0) {
if (arg0->unk_0BC == 1) {
Object_Kill(&arg0->obj, &arg0->unk_100);
}
} else {
arg0->obj.rot.y += 5.0f;
if (arg0->unk_0D0 != 0) {
func_8007D0E0(arg0->obj.pos.x, arg0->obj.pos.y + 130.0f, arg0->obj.pos.z, 8.0f);
func_8007BFFC(arg0->obj.pos.x, arg0->obj.pos.y + 130.0f, arg0->obj.pos.z, 0.0f, 0.0f, 0.0f, 4.0f, 5);
arg0->unk_0BC = 4;
func_8007A6F0(&arg0->obj.pos, 0x1903400F);
}
}
}
void func_80066A80(Object_2F4* arg0) {
}
void func_80066A8C(Object_80* arg0) {
Vec3f sp64;
Vec3f sp58;
f32 yf;
sp64.z = 0.0f;
sp64.x = -120.0f;
if (arg0->obj.rot.y > 90.0f) {
sp64.x = 120.0f;
}
for (yf = 0.0f; yf < 680.0f; yf += 100.0f) {
Matrix_RotateY(gCalcMatrix, arg0->obj.rot.y * M_DTOR, 0);
Matrix_RotateX(gCalcMatrix, arg0->obj.rot.x * M_DTOR, 1);
sp64.y = yf;
Matrix_MultVec3fNoTranslate(gCalcMatrix, &sp64, &sp58);
func_8007D0E0(arg0->obj.pos.x + sp58.x, arg0->obj.pos.y + sp58.y, arg0->obj.pos.z + sp58.z, 4.0f);
}
}
void func_80066C00(Object_80* arg0) {
Vec3f sp64;
Vec3f sp58;
f32 zf;
sp64.y = 30.0f;
sp64.x = -100.0f;
if (arg0->obj.rot.y > 90.0f) {
sp64.x = 100.0f;
}
Matrix_RotateY(gCalcMatrix, arg0->obj.rot.y * M_DTOR, 0);
for (zf = -180.0f; zf <= 0.0f; zf += 30.0f) {
sp64.z = zf;
Matrix_MultVec3fNoTranslate(gCalcMatrix, &sp64, &sp58);
func_8007D0E0(arg0->obj.pos.x + sp58.x, arg0->obj.pos.y + sp58.y, arg0->obj.pos.z + sp58.z,
Rand_ZeroOne() + 2.0f);
}
}
void func_80066D5C(Object_80* arg0) {
switch (arg0->unk_48) {
case 1:
func_80066C00(arg0);
arg0->unk_48++;
func_80019218(0x2900300F, &arg0->unk_70, 4, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
break;
case 2:
arg0->unk_64.x += 0.05f;
arg0->obj.rot.x += arg0->unk_64.x;
if (arg0->obj.rot.x >= 90.0f) {
arg0->obj.rot.x = 90.0f;
arg0->unk_44 = 40;
func_80066A8C(arg0);
arg0->unk_48 = 0;
D_80178480 = 25;
func_80019218(0x19130003, &arg0->unk_70, 4, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
}
break;
case 0:
break;
}
}
void func_80066E80(Object_80* arg0) {
}
void func_80066E8C(Object_4C* arg0) {
arg0->obj.rot.y += 0.2f;
}
void func_80066EA8(Object_80* arg0) {
arg0->obj.rot.y = 0.0f;
if (gPlayer[0].unk_040.x < arg0->obj.pos.x) {
arg0->obj.rot.y = 271.0f;
}
}
void func_80066EE4(Object_4C* arg0) {
}
void func_80066EF0(Object_6C* arg0) {
f32 var_fa1;
if ((gPlayer[0].unk_1C8 == 7) || (gPlayer[0].unk_1C8 == 0)) {
Object_Kill(&arg0->obj, &arg0->unk_5C);
}
if ((D_80177880 == 0) && (D_80161680 == 0)) {
var_fa1 = 900.0f;
if (gPlayer[0].unk_1CC != 0) {
var_fa1 = 600.0f;
}
if (gPlayer[0].unk_0AC + var_fa1 < arg0->obj.pos.x) {
Math_SmoothStepToF(&arg0->obj.pos.x, gPlayer[0].unk_0AC + var_fa1, 0.1f, 10.0f, 0.01f);
}
if (arg0->obj.pos.x < gPlayer[0].unk_0AC - var_fa1) {
Math_SmoothStepToF(&arg0->obj.pos.x, gPlayer[0].unk_0AC - var_fa1, 0.1f, 10.0f, 0.01f);
}
}
if (arg0->obj.pos.y > 650.0f) {
Math_SmoothStepToF(&arg0->obj.pos.y, 650.0f, 0.1f, 10.0f, 0.01f);
}
if (gLevelType == 0) {
if (arg0->obj.pos.y < D_80177940 + 70.0f) {
Math_SmoothStepToF(&arg0->obj.pos.y, D_80177940 + 70.0f, 0.1f, 5.0f, 0.01f);
}
if ((gCurrentLevel == LEVEL_AQUAS) && (D_80178284 != 0)) {
arg0->obj.pos.z += 20.0f;
}
} else if (arg0->obj.pos.y < -500.0f) {
Math_SmoothStepToF(&arg0->obj.pos.y, -500.0f, 0.1f, 5.0f, 0.01f);
}
if ((D_801778E8 != 0) && (arg0->unk_40 == 0) && (gObjects6C[1].obj.status == 2)) {
if (fabsf(arg0->obj.pos.x - gObjects6C[1].obj.pos.x) < 200.0f) {
if (fabsf(arg0->obj.pos.z - gObjects6C[1].obj.pos.z) < 200.0f) {
arg0->obj.pos.x = arg0->obj.pos.x - 5.0f;
arg0->obj.pos.z = arg0->obj.pos.z - 5.0f;
gObjects6C[1].obj.pos.x += 5.0f;
gObjects6C[1].obj.pos.z += 5.0f;
}
}
}
}
void func_800671D0(Object_6C* arg0) {
s32 var_v0;
Vec3f sp40;
Vec3f sp34;
Math_SmoothStepToF(&arg0->unk_50, 10.0f, 1.0f, 2.0f, 0.0f);
if (arg0->unk_50 > 30.0f) {
var_v0 = 0;
} else if (arg0->unk_50 > 20.0f) {
var_v0 = 1;
} else {
var_v0 = 7;
}
if (!(var_v0 & gFrameCount)) {
Matrix_RotateY(gCalcMatrix, gFrameCount * 23.0f * M_DTOR, 0);
sp40.x = 50.0f;
sp40.y = (Rand_ZeroOne() - 0.5f) * 120.0f;
sp40.z = 0.0f;
Matrix_MultVec3fNoTranslate(gCalcMatrix, &sp40, &sp34);
func_80078E50(arg0->obj.pos.x + sp34.x, arg0->obj.pos.y + sp34.y, arg0->obj.pos.z + sp34.z, 3.0f);
}
arg0->obj.rot.y += arg0->unk_50;
arg0->obj.rot.y = Math_ModF(arg0->obj.rot.y, 360.0f);
}
void func_80067348(Object_2F4* arg0, f32 arg1, f32 arg2, f32 arg3, f32 arg4, f32 arg5, f32 arg6, f32 arg7, f32 arg8) {
Object_2F4_Initialize(arg0);
arg0->obj.status = 2;
arg0->obj.id = OBJECT_189;
arg0->unk_0B8 = 70;
arg0->obj.pos.x = arg1;
arg0->obj.pos.y = arg2;
arg0->obj.pos.z = arg3;
arg0->obj.rot.x = arg4;
arg0->obj.rot.y = arg5;
arg0->unk_0E8.x = arg6;
arg0->unk_0E8.y = arg7;
arg0->unk_0E8.z = arg8;
arg0->unk_0BC = (s32) (Rand_ZeroOne() * 15.0f) + 25.0f;
arg0->unk_10C = 0.5f;
func_800612B8(&arg0->unk_01C, arg0->obj.id);
}
void func_800674B4(f32 arg0, f32 arg1, f32 arg2, f32 arg3, f32 arg4, f32 arg5, f32 arg6, f32 arg7) {
s32 i;
for (i = 59; i >= 50; i--) {
if (gObjects2F4[i].obj.status == 0) {
func_80067348(&gObjects2F4[i], arg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7);
break;
}
}
}
void func_8006753C(Object_2F4* arg0) {
Player* new_var = gPlayer; // fake?
s32 i;
arg0->obj.rot.y += 1.0f;
if (D_80177880 == 1) {
if (gCurrentLevel == LEVEL_SECTOR_Z) {
Math_SmoothStepToF(&arg0->obj.pos.x, -2000.0f, 0.05f, 60.0f, 0.01f);
Math_SmoothStepToF(&arg0->obj.pos.y, -200.0f, 0.05f, 3.0f, 0.01f);
Math_SmoothStepToF(&arg0->obj.pos.z, 0.0f, 0.05f, 0.f, 0.01f);
} else {
Math_SmoothStepToF(&arg0->obj.pos.y, 300.0f, 0.05f, 50.0f, 0.01f);
}
}
if (arg0->unk_0D0 != 0) {
arg0->unk_0D0 = 0;
arg0->unk_0CE -= arg0->unk_0D6;
if (arg0->unk_0CE <= 0) {
func_8007A6F0(&arg0->obj.pos, 0x2903A008);
func_8007D2C8(arg0->obj.pos.x, arg0->obj.pos.y, arg0->obj.pos.z, 5.0f);
if (((new_var[0].wings.rightState <= 1) || (new_var[0].wings.leftState <= 1)) &&
(new_var[0].unk_1CC != 1)) {
arg0->unk_044 = 23;
} else if (gPlayer[0].health < 0x80) {
arg0->unk_044 = 25;
} else if ((gLaserStrength[0] == 0) && (new_var[0].unk_1CC != 1)) {
arg0->unk_044 = 9;
} else {
arg0->unk_044 = 5;
}
func_80066254(arg0);
for (i = 0; i < 6; i++) {
func_800674B4(D_800CFEC4[i].x + arg0->obj.pos.x, D_800CFEC4[i].y + arg0->obj.pos.y,
D_800CFEC4[i].z + arg0->obj.pos.z, D_800CFF0C[i].y + arg0->obj.rot.y,
D_800CFF0C[i].x + arg0->obj.rot.x, (Rand_ZeroOne() - 0.5f) * 40.0f,
(Rand_ZeroOne() * 10.0f) + 10.0f, (Rand_ZeroOne() - 0.5f) * 40.0f);
func_800794CC(arg0->obj.pos.x, arg0->obj.pos.y, arg0->obj.pos.z, 0.6f);
}
Object_Kill(&arg0->obj, &arg0->unk_100);
}
}
gUnkEntities28[63].unk_00 = 1;
gUnkEntities28[63].unk_02 = 103;
gUnkEntities28[63].pos.x = arg0->obj.pos.x;
gUnkEntities28[63].pos.y = arg0->obj.pos.y;
gUnkEntities28[63].pos.z = arg0->obj.pos.z;
gUnkEntities28[63].unk_10 = 0.0f;
}
void func_80067874(Object_2F4* arg0) {
s32 i;
Lights_SetOneLight(&gMasterDisp, -60, -60, 60, 150, 150, 150, 20, 20, 20);
for (i = 0; i < 6; i++) {
Matrix_Push(&gGfxMatrix);
Matrix_Translate(gGfxMatrix, D_800CFEC4[i].x, D_800CFEC4[i].y, D_800CFEC4[i].z, 1);
Matrix_RotateY(gGfxMatrix, D_800CFF0C[i].y * M_DTOR, 1);
Matrix_RotateX(gGfxMatrix, D_800CFF0C[i].x * M_DTOR, 1);
Matrix_SetGfxMtx(&gMasterDisp);
gSPDisplayList(gMasterDisp++, D_10177C0);
Matrix_Pop(&gGfxMatrix);
}
Lights_SetOneLight(&gMasterDisp, gLight1x, gLight1y, gLight1z, gLight1R, gLight1G, gLight1B, gAmbientR, gAmbientG,
gAmbientB);
}
void func_80067A40(void) {
func_80019218(0x09008023, &gPlayer[0].unk_460, 0, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
if (gPlayer[0].wings.rightState <= 1) {
D_80177D40[0] = 1050;
gPlayer[0].wings.rightState = 2;
}
if (gPlayer[0].wings.leftState <= 1) {
D_80177D58[0] = 1050;
gPlayer[0].wings.leftState = 2;
}
if (gExpertMode) {
gRightWingHealth[0] = gLeftWingHealth[0] = 10;
} else {
gRightWingHealth[0] = gLeftWingHealth[0] = 60;
}
}
void func_80067B1C(Object_6C* arg0) {
func_80066EF0(arg0);
func_800671D0(arg0);
if (arg0->unk_4C != 0) {
Player** players;
Object_Kill(&arg0->obj, &arg0->unk_5C);
players = &gPlayer; // seems fake
func_80060F30(&(*players)[arg0->unk_4E].unk_460, 0x4900C024, arg0->unk_4E);
if (gCurrentLevel != LEVEL_TRAINING) {
gLifeCount[arg0->unk_4E]++;
}
}
if (arg0->unk_48 == 1) {
Object_Kill(&arg0->obj, &arg0->unk_5C);
}
}
void func_80067BEC(Object_6C* arg0) {
func_80066EF0(arg0);
func_800671D0(arg0);
if (arg0->unk_46 == 0) {
switch (arg0->obj.id) {
case OBJECT_6C_BOMB:
arg0->unk_68 = 18.0f;
if (arg0->unk_4C != 0) {
arg0->unk_4A = 50;
arg0->unk_46 = 1;
arg0->unk_48 = 20;
arg0->unk_50 = 60.0f;
gBombCount[arg0->unk_4E]++;
func_80060F30(gPlayer[arg0->unk_4E].unk_460_arr, 0x49002005, arg0->unk_4E);
func_80060F30(gPlayer[arg0->unk_4E].unk_460_arr, 0x49002006, arg0->unk_4E);
}
break;
case OBJECT_6C_LASERS:
arg0->unk_68 = 18.0f;
if (arg0->unk_4C != 0) {
arg0->unk_4A = 50;
arg0->unk_46 = 1;
arg0->unk_48 = 20;
arg0->unk_50 = 60.0f;
gLaserStrength[arg0->unk_4E]++;
if (gLaserStrength[arg0->unk_4E] > 2) {
gLaserStrength[arg0->unk_4E] = 2;
}
func_80060F30(gPlayer[arg0->unk_4E].unk_460_arr, 0x49002004, arg0->unk_4E);
if (gExpertMode) {
gRightWingHealth[arg0->unk_4E] = gLeftWingHealth[arg0->unk_4E] = 10;
} else {
gRightWingHealth[arg0->unk_4E] = gLeftWingHealth[arg0->unk_4E] = 60;
}
D_80177D40[arg0->unk_4E] = 1030;
D_80177D58[arg0->unk_4E] = 1030;
}
break;
}
} else {
Math_SmoothStepToF(&arg0->unk_68, 2.5f, 1.0f, 0.5f, 0.0f);
arg0->obj.pos.x += (gPlayer[arg0->unk_4E].unk_074 - arg0->obj.pos.x) * 0.5f;
if (gPlayer[arg0->unk_4E].unk_1CC == 1) {
arg0->obj.pos.y += ((gPlayer[arg0->unk_4E].unk_078 + 50.0f) - arg0->obj.pos.y) * 0.5f;
} else {
arg0->obj.pos.y += (gPlayer[arg0->unk_4E].unk_078 - arg0->obj.pos.y) * 0.5f;
}
arg0->obj.pos.z += (gPlayer[arg0->unk_4E].unk_138 - arg0->obj.pos.z) * 0.5f;
if (arg0->unk_48 == 0) {
Object_Kill(&arg0->obj, &arg0->unk_5C);
}
}
}
void func_80067F6C(Object_6C* arg0) {
if ((D_801778E8 == 0) && ((gPlayer[0].wings.leftState <= 1) || (gPlayer[0].wings.rightState <= 1))) {
arg0->obj.id = OBJECT_6C_WING_REPAIR;
func_800612B8(&arg0->unk_1C, arg0->obj.id);
arg0->unk_48 = 2000;
func_80019218(0x1900302B, &arg0->unk_5C, 0, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
} else {
func_80067BEC(arg0);
}
}
void func_80068020(Object_6C* arg0) {
Vec3f sp4C;
Vec3f sp40;
switch (arg0->unk_46) {
case 0:
Math_SmoothStepToF(&arg0->unk_68, 0.4f, 1.0f, 0.05f, 0.0f);
func_80066EF0(arg0);
func_800671D0(arg0);
if (arg0->unk_4C != 0) {
arg0->unk_46 = 1;
arg0->unk_48 = 50;
if (arg0->obj.id == OBJECT_6C_SILVER_RING) {
gPlayer[arg0->unk_4E].heal += 0x20;
func_80060F30(gPlayer[arg0->unk_4E].unk_460_arr, 0x4900200E, arg0->unk_4E);
} else if (arg0->obj.id == OBJECT_6C_GOLD_RING) {
gGoldRingCount[0]++;
if (gGoldRingCount[0] == 3) {
func_80060F30(gPlayer[arg0->unk_4E].unk_460_arr, 0x49008015, arg0->unk_4E);
} else if (gGoldRingCount[0] == 6) {
func_80060F30(gPlayer[arg0->unk_4E].unk_460_arr, 0x4900C024, arg0->unk_4E);
if (gCurrentLevel != LEVEL_TRAINING) {
gLifeCount[arg0->unk_4E]++;
}
gPlayer[arg0->unk_4E].heal += 0x20;
func_80077240(gPlayer[arg0->unk_4E].unk_074, gPlayer[arg0->unk_4E].unk_078,
gPlayer[arg0->unk_4E].unk_138, 101);
} else {
gPlayer[arg0->unk_4E].heal += 0x20;
func_80060F30(gPlayer[arg0->unk_4E].unk_460_arr, 0x49003013, arg0->unk_4E);
}
} else {
gPlayer[arg0->unk_4E].heal += 0x80;
func_80060F30(gPlayer[arg0->unk_4E].unk_460_arr, 0x4900200D, arg0->unk_4E);
}
}
if ((arg0->obj.id == OBJECT_6C_GOLD_RING) && (arg0->unk_48 == 1)) {
Object_Kill(&arg0->obj, &arg0->unk_5C);
}
break;
case 1:
if (arg0->unk_48 > 30) {
Math_SmoothStepToF(&arg0->unk_68, 1.0f, 1.0f, 0.06f, 0.0f);
} else {
Math_SmoothStepToF(&arg0->unk_68, 0.0f, 1.0f, 0.06f, 0.0f);
}
arg0->obj.pos.x += (gPlayer[arg0->unk_4E].unk_074 - arg0->obj.pos.x) * 0.5f;
if (gPlayer[arg0->unk_4E].unk_1CC == 1) {
arg0->obj.pos.y += (gPlayer[arg0->unk_4E].unk_078 + 50.0f - arg0->obj.pos.y) * 0.5f;
} else {
arg0->obj.pos.y += (gPlayer[arg0->unk_4E].unk_078 - arg0->obj.pos.y) * 0.5f;
}
if ((gPlayer[0].unk_238 != 0) && (D_80177880 == 0)) {
arg0->obj.pos.z += (gPlayer[arg0->unk_4E].unk_138 - 300.0f - arg0->obj.pos.z) * 0.3f;
} else {
arg0->obj.pos.z += (gPlayer[arg0->unk_4E].unk_138 - arg0->obj.pos.z) * 0.5f;
}
arg0->obj.rot.z += 22.0f;
Math_SmoothStepToAngle(&arg0->obj.rot.y, Math_RadToDeg(-gPlayer[arg0->unk_4E].unk_058), 0.2f, 10.0f, 0.0f);
if (arg0->unk_48 == 0) {
Object_Kill(&arg0->obj, &arg0->unk_5C);
}
if (arg0->unk_68 > 0.3f) {
Matrix_RotateY(gCalcMatrix, arg0->obj.rot.y * M_DTOR, 0);
Matrix_RotateZ(gCalcMatrix, gFrameCount * 37.0f * M_DTOR, 1);
sp4C.x = 0.0f;
sp4C.y = arg0->unk_68 * 100.0f;
sp4C.z = 0.0f;
Matrix_MultVec3fNoTranslate(gCalcMatrix, &sp4C, &sp40);
func_80078E50(arg0->obj.pos.x + sp40.x, arg0->obj.pos.y + sp40.y, arg0->obj.pos.z + sp40.z, 3.5f);
}
break;
}
}
void func_800685D8(Object_6C* arg0) {
func_80068020(arg0);
}
void func_800685F8(Object_6C* arg0) {
func_80068020(arg0);
}
void func_80068618(Object_6C* arg0) {
func_80066EF0(arg0);
func_800671D0(arg0);
if (arg0->unk_4C != 0) {
func_80067A40();
Object_Kill(&arg0->obj, &arg0->unk_5C);
}
if (arg0->unk_48 == 1) {
Object_Kill(&arg0->obj, &arg0->unk_5C);
}
}
void func_80068688(Object_6C* arg0) {
func_80066EF0(arg0);
if (arg0->unk_46 > 0) {
if (arg0->unk_46 == 1) {
arg0->obj.rot.z -= 10.0f;
arg0->obj.pos.x += (gPlayer[arg0->unk_4E].unk_074 - arg0->obj.pos.x) * 0.3f;
arg0->obj.pos.y += (gPlayer[arg0->unk_4E].unk_078 - arg0->obj.pos.y) * 0.3f;
arg0->obj.pos.z += (gPlayer[arg0->unk_4E].unk_138 - arg0->obj.pos.z) * 0.3f;
arg0->unk_68 -= 5.0f;
if (arg0->unk_68 < 0.0f) {
arg0->unk_68 = 0.0f;
}
}
arg0->unk_44 -= 10;
if (arg0->unk_44 < 0) {
Object_Kill(&arg0->obj, &arg0->unk_5C);
}
} else {
arg0->unk_68 = 100.0f;
if (D_80177E80 < 0) {
arg0->unk_46 = 2;
arg0->unk_44 = 0xFF;
} else if (arg0->unk_4C != 0) {
arg0->unk_46 = 1;
arg0->unk_44 = 0xFF;
gPlayer[arg0->unk_4E].unk_27C = 100;
func_80019218(D_800CFF54[D_80177E80], &gPlayer[0].unk_460, 0, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
if (D_80177E80 == 0) {
gPlayer[0].unk_110 = 0.0f;
}
D_80177E80++;
if (D_80177E80 >= 7) {
gPlayer[0].unk_1C8 = 8;
gPlayer[0].unk_1D0 = 0;
func_80019218(0x1900602A, &D_800C5D28, 0, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
D_80177930 = 2;
D_800D3180[gCurrentLevel] = 1;
}
}
}
}
void func_80068914(Object_6C* arg0) {
s32 i;
func_80066EF0(arg0);
arg0->unk_58 -= arg0->unk_44;
if (arg0->unk_46 > 0) {
arg0->unk_44++;
arg0->obj.pos.x += (gPlayer[arg0->unk_4E].unk_074 - arg0->obj.pos.x) * 0.3f;
if (gPlayer[arg0->unk_4E].unk_1CC == 1) {
arg0->obj.pos.y += (gPlayer[arg0->unk_4E].unk_078 + 50.0f - arg0->obj.pos.y) * 0.3f;
} else {
arg0->obj.pos.y += (gPlayer[arg0->unk_4E].unk_078 - arg0->obj.pos.y) * 0.3f;
}
if (gPlayer[0].unk_238 != 0) {
arg0->obj.pos.z += (gPlayer[arg0->unk_4E].unk_138 - 200.0f - arg0->obj.pos.z) * 0.3f;
} else {
arg0->obj.pos.z += (gPlayer[arg0->unk_4E].unk_138 - 100.0f - arg0->obj.pos.z) * 0.3f;
}
if (arg0->unk_48 == 0) {
Math_SmoothStepToF(&arg0->unk_68, 5.0f, 0.2f, 15.0f, 0.01f);
Math_SmoothStepToF(&arg0->unk_50, 0.0f, 0.1f, 0.03f, 0.0f);
Math_SmoothStepToF(&arg0->unk_54, 4.0f, 0.1f, 0.2f, 0.01f);
}
if (arg0->unk_68 <= 6.5f) {
Object_Kill(&arg0->obj, &arg0->unk_5C);
}
} else {
arg0->unk_44 = 2;
arg0->unk_50 = 1.0f;
arg0->unk_54 = 1.0f;
arg0->unk_68 = 100.0f;
if (arg0->unk_4C != 0) {
gPlayer[arg0->unk_4E].heal = 0x80;
arg0->unk_46++;
arg0->unk_48 = 15;
D_80161A8C = D_80161A88;
D_80177CB0 = -arg0->obj.pos.z;
D_80177CB0 -= 250.0f;
D_80177CA0 = D_80177DC8;
D_80161A50 = D_80161684;
D_80161A9C = gHitCount;
for (i = 1; i < 4; i++) {
D_801778D0[i] = D_801778B0[i];
}
func_80019218(0x4900400F, &D_800C5D28, 4, &D_800C5D34, &D_800C5D34, &D_800C5D3C);
}
}
}
void func_80068C48(Object_6C* arg0) {
if (arg0->unk_4C != 0) {
Object_Kill(&arg0->obj, &arg0->unk_5C);
D_80177E80++;
}
}
void func_80068C88(Object_6C* arg0) {
D_80161680 = arg0->obj.id;
if (gPlayer[0].unk_1C8 != 3) {
Object_Kill(&arg0->obj, &arg0->unk_5C);
} else if (((gCurrentLevel == LEVEL_METEO) || (gCurrentLevel == LEVEL_SECTOR_X)) && (D_8017827C == 1)) {
gPlayer[0].unk_1C8 = 7;
gPlayer[0].unk_1D0 = 0;
Object_Kill(&arg0->obj, &arg0->unk_5C);
} else if (gCurrentLevel == LEVEL_TRAINING) {
gPlayer[0].unk_1C8 = 9;
gPlayer[0].unk_1D0 = 0;
Object_Kill(&arg0->obj, &arg0->unk_5C);
} else if (arg0->unk_46 == 0) {
if (((arg0->obj.pos.z + D_80177D20) > -2700.0f) && (fabsf(arg0->obj.pos.x - gPlayer[0].unk_074) < 1000.0f)) {
switch (arg0->obj.id) {
case OBJECT_331:
case OBJECT_332:
case OBJECT_333:
break;
case OBJECT_328:
gPlayer[0].unk_228 = 0x30;
break;
case OBJECT_329:
gPlayer[0].unk_228 = 0x20;
break;
case OBJECT_330:
gPlayer[0].unk_228 = 0x10;
break;
}
}
if (arg0->unk_4C != 0) {
Object_Kill(&arg0->obj, &arg0->unk_5C);
gPlayer[0].unk_0B4 = 0.0f;
gPlayer[0].unk_210 = arg0->unk_68 * 0.05f;
switch (arg0->obj.id) {
case OBJECT_328:
if (arg0->obj.pos.x < gPlayer[0].unk_074) {
gPlayer[0].unk_118 = -30.0f;
gPlayer[0].unk_0B8 = gPlayer[0].unk_0AC + arg0->unk_68;
} else {
gPlayer[0].unk_118 = 30.0f;
gPlayer[0].unk_0B8 = gPlayer[0].unk_0AC - arg0->unk_68;
}
break;
case OBJECT_329:
gPlayer[0].unk_118 = 30.0f;
gPlayer[0].unk_0B8 = gPlayer[0].unk_0AC - arg0->unk_68;
break;
case OBJECT_330:
gPlayer[0].unk_118 = -30.0f;
gPlayer[0].unk_0B8 = gPlayer[0].unk_0AC + arg0->unk_68;
break;
case OBJECT_331:
if (arg0->obj.pos.y < gPlayer[0].unk_078) {
gPlayer[0].unk_124 = 30.0f;
gPlayer[0].unk_0BC = gPlayer[0].unk_0B0 + arg0->unk_68;
} else {
gPlayer[0].unk_124 = -30.0f;
gPlayer[0].unk_0BC = gPlayer[0].unk_0B0 - arg0->unk_68;
}
break;
case OBJECT_332:
gPlayer[0].unk_124 = 30.0f;
gPlayer[0].unk_0BC = gPlayer[0].unk_0B0 + arg0->unk_68;
break;
case OBJECT_333:
gPlayer[0].unk_124 = -30.0f;
gPlayer[0].unk_0BC = gPlayer[0].unk_0B0 - arg0->unk_68;
break;
}
}
}
}
void func_80068FE0(Object_4C* arg0) {
arg0->obj.rot.y =
(Math_Atan2F(gPlayer[0].unk_040.x - arg0->obj.pos.x, gPlayer[0].unk_040.z - (arg0->obj.pos.z + D_80177D20)) *
180.0f) /
M_PI;
if (arg0->unk_46 != 0) {
arg0->obj.status = 0;
func_8007A6F0(&arg0->obj.pos, 0x1903400F);
switch (arg0->obj.id) {
case OBJECT_161:
func_8007D074(arg0->obj.pos.x, arg0->obj.pos.y + 160.0f, arg0->obj.pos.z, 4.0f);
break;
default:
case OBJECT_169:
func_8007D074(arg0->obj.pos.x, arg0->obj.pos.y + 96.0f, arg0->obj.pos.z, 5.0f);
break;
}
}
}
void func_800690D0(s32 arg0, s32 objId) {
switch (objId) {
case OBJECT_200:
func_8007717C(&gObjects2F4[arg0]);
break;
case OBJECT_197:
if (gCurrentLevel == LEVEL_VENOM_2) {
func_E9F1D0_801888F4(&gObjects2F4[arg0]);
} else {
func_800763A4(&gObjects2F4[arg0]);
}
break;
case OBJECT_202:
func_800763A4(&gObjects2F4[arg0]);
break;
case OBJECT_194:
func_8006B0A0(&gObjects2F4[arg0]);
break;
case OBJECT_186:
func_E08400_80187B08(&gObjects2F4[arg0]);
break;
case OBJECT_181:
Object_Kill(&gObjects2F4[arg0].obj, &gObjects2F4[arg0].unk_100);
func_8007D2C8(gObjects2F4[arg0].obj.pos.x, gObjects2F4[arg0].obj.pos.y, gObjects2F4[arg0].obj.pos.z, 20.0f);
break;
case OBJECT_182:
Object_Kill(&gObjects2F4[arg0].obj, &gObjects2F4[arg0].unk_100);
func_8007D2C8(gObjects2F4[arg0].obj.pos.x, gObjects2F4[arg0].obj.pos.y, gObjects2F4[arg0].obj.pos.z, 10.0f);
func_80066254(&gObjects2F4[arg0]);
break;
case OBJECT_192:
func_8006684C(&gObjects2F4[arg0]);
break;
case OBJECT_306:
func_E6A810_801990DC(&gObjects408[arg0]);
break;
case OBJECT_232:
func_E6A810_8018B720(&gObjects2F4[arg0]);
break;
case OBJECT_319:
func_E51970_80198594(&gObjects408[arg0]);
break;
}
}
void func_800693E8(Object_2F4* arg0) {
arg0->obj.pos.x += arg0->unk_0E8.x;
arg0->obj.pos.z += arg0->unk_0E8.z;
arg0->obj.pos.y += arg0->unk_0E8.y;
arg0->unk_0E8.y -= arg0->unk_10C;
if ((D_80161AB8 != 0) && (arg0->obj.id != OBJECT_198) &&
((gCurrentLevel != LEVEL_MACBETH) || (arg0->obj.id == OBJECT_200))) {
f32 var_fv0 = 4000.0f;
if ((arg0->obj.id == OBJECT_236) || (gCurrentLevel == LEVEL_MACBETH) ||
((arg0->obj.id == OBJECT_200) && (arg0->unk_0B4 == 56))) {
var_fv0 = 8000.0f;
} else if (gPlayer[0].unk_1C8 == 8) {
var_fv0 = 100000.0f;
}
if (((gPlayer[0].unk_040.z + arg0->unk_01C.unk_10) < (arg0->obj.pos.z + D_80177D20)) ||
((arg0->obj.pos.z + D_80177D20) < -15000.0f) || (arg0->obj.pos.y < (gPlayer[0].unk_0B0 - var_fv0)) ||
((gPlayer[0].unk_0B0 + var_fv0) < arg0->obj.pos.y) || ((gPlayer[0].unk_0AC + var_fv0) < arg0->obj.pos.x) ||
(arg0->obj.pos.x < (gPlayer[0].unk_0AC - var_fv0))) {
Object_Kill(&arg0->obj, &arg0->unk_100);
switch (arg0->obj.id) {
case OBJECT_236:
D_801784A4 = 0;
break;
case OBJECT_229:
func_E6A810_8018E3B0(arg0);
break;
case OBJECT_194:
D_80176550[arg0->unk_046] = 0;
break;
case OBJECT_200:
if ((arg0->unk_0B4 >= 200) && (arg0->unk_0B4 < 300)) {
D_80176550[arg0->unk_046] = 0;
} else if ((arg0->unk_0B4 == 38) && (arg0->unk_046 != 2)) {
D_80177E80 = -1;
}
break;
case OBJECT_252:
D_80161684 = 1;
break;
}
}
}
}
void func_80069658(Object_408* arg0) {
arg0->obj.pos.x += arg0->unk_06C;
arg0->obj.pos.y += arg0->unk_070;
arg0->obj.pos.z += arg0->unk_074;
arg0->unk_070 -= arg0->unk_084;
if ((D_80161AB8 != 0) && ((arg0->obj.pos.z + D_80177D20) > (arg0->unk_01C.unk_10 - gPlayer[0].unk_040.z))) {
if (gPlayer[0].unk_040.z) {} // fake
Object_Kill(&arg0->obj, &arg0->unk_3FC);
}
}
void func_800696F8(Object_80* arg0) {
if (gPlayer[0].unk_1C8 == 2) {
arg0->obj.pos.z += arg0->unk_60;
if (arg0->unk_1C.unk_10 < arg0->obj.pos.z) {
Object_Kill(&arg0->obj, &arg0->unk_70);
}
} else if ((D_80177880 == 0) && (D_80178284 != 2)) {
f32 temp_fv0 = fabsf(arg0->obj.pos.x - gPlayer[0].unk_040.x);
f32 var_fa0 = 500.0f;
if ((arg0->obj.id == OBJECT_6) || (arg0->obj.id == OBJECT_7)) {
var_fa0 = 1000.0f;
}
temp_fv0 = ((var_fa0 > temp_fv0) ? 0.0f : (temp_fv0 - var_fa0) * 1.7f);
if ((fabsf(gPlayer[0].unk_114) > 1.0f) || (gCurrentLevel == LEVEL_MACBETH)) {
temp_fv0 = 0.0f;
}
temp_fv0 -= gPlayer[0].unk_040.z;
if ((arg0->unk_1C.unk_10 - temp_fv0) < (arg0->obj.pos.z + D_80177D20)) {
Object_Kill(&arg0->obj, &arg0->unk_70);
}
}
}
void func_80069858(Object_4C* arg0) {
if (D_80161AB8 != 0) {
f32 temp_fv0 = fabsf(arg0->obj.pos.x - gPlayer[0].unk_040.x);
f32 var_fa0 = 500.0f;
if (((arg0->obj.id == OBJECT_164) && ((arg0->unk_45 == 6) || (arg0->unk_45 == 7))) ||
(arg0->obj.id == OBJECT_8)) {
var_fa0 = 1000.0f;
}
temp_fv0 = ((var_fa0 > temp_fv0) ? 0.0f : (temp_fv0 - var_fa0) * 1.7f);
temp_fv0 -= gPlayer[0].unk_040.z;
if ((arg0->unk_1C.unk_10 - temp_fv0) < (arg0->obj.pos.z + D_80177D20)) {
arg0->obj.status = 0;
}
}
}
void func_80069924(Object_8C* arg0) {
arg0->obj.pos.x += arg0->unk_54.x;
arg0->obj.pos.y += arg0->unk_54.y;
arg0->obj.pos.z += arg0->unk_54.z;
if (D_80161AB8 != 0) {
if ((gPlayer[0].unk_040.z + arg0->unk_1C.unk_10) < (arg0->obj.pos.z + D_80177D20)) {
Object_Kill(&arg0->obj, &arg0->unk_80);
} else if ((fabsf(arg0->obj.pos.y - gPlayer[0].unk_040.y) > 25000.0f) ||
(fabsf(arg0->obj.pos.x - gPlayer[0].unk_040.x) > 25000.0f)) {
Object_Kill(&arg0->obj, &arg0->unk_80);
}
}
}
void func_80069A10(Object_6C* arg0) {
if (D_80161AB8 != 0) {
f32 temp = (0.0f - gPlayer[0].unk_040.z);
if ((arg0->unk_1C.unk_10 - temp) < (arg0->obj.pos.z + D_80177D20)) {
Object_Kill(&arg0->obj, &arg0->unk_5C);
if ((arg0->obj.id == OBJECT_326) && (arg0->unk_46 == 0)) {
D_80177E80 = -1;
}
}
}
}
void func_80069AAC(Object_2F4* arg0) {
s32 i;
if (arg0->unk_0BC != 0) {
arg0->unk_0BC--;
}
if (arg0->unk_0BE != 0) {
arg0->unk_0BE--;
}
if (arg0->unk_0C0 != 0) {
arg0->unk_0C0--;
}
if (arg0->unk_0C2 != 0) {
arg0->unk_0C2--;
}
if (arg0->unk_0C6 != 0) {
arg0->unk_0C6--;
}
if (D_801778E8 != 0) {
for (i = 0; i < gCamCount; i++) {
if (arg0->unk_0CA[i] != 0) {
if (!(gCurrentInput[i].button & A_BUTTON)) {
arg0->unk_0CA[i]--;
}
D_801779C8[i] = 0;
}
}
} else if (arg0->unk_0CA[0] != 0) {
if (!(gCurrentInput[D_80177AF8].button & A_BUTTON)) {
arg0->unk_0CA[0]--;
}
D_801779C8[0] = 0;
}
if (arg0->unk_0C4 != 0) {
arg0->unk_0C4--;
}
switch (arg0->obj.status) {
case 1:
arg0->obj.status = 2;
func_80063F90(arg0->unk_040, arg0->obj.id);
if (arg0->obj.id != OBJECT_252) {
func_800693E8(arg0);
}
break;
case 2:
func_800693E8(arg0);
if ((arg0->obj.status != 0) && (arg0->unk_01C.action != NULL)) {
arg0->unk_01C.action(&arg0->obj);
}
break;
case 3:
func_800693E8(arg0);
if (arg0->obj.status != 0) {
func_800690D0(arg0->unk_040, arg0->obj.id);
}
break;
}
}
void func_80069CBC(Object_408* arg0) {
if (arg0->unk_050 != 0) {
arg0->unk_050--;
}
if (arg0->unk_052 != 0) {
arg0->unk_052--;
}
if (arg0->unk_054 != 0) {
arg0->unk_054--;
}
if (arg0->unk_056 != 0) {
arg0->unk_056--;
}
if (arg0->unk_058 != 0) {
arg0->unk_058--;
}
if (arg0->unk_05A != 0) {
arg0->unk_05A--;
}
if (arg0->unk_05C != 0) {
arg0->unk_05C--;
}
switch (arg0->obj.status) {
case 1:
arg0->obj.status = 2;
func_80063F90(arg0->unk_040, arg0->obj.id);
func_80069658(arg0);
break;
case 2:
func_80069658(arg0);
if ((arg0->obj.status != 0) && (arg0->unk_01C.action != NULL)) {
arg0->unk_01C.action(&arg0->obj);
}
break;
case 3:
func_80069658(arg0);
if (arg0->obj.status != 0) {
func_800690D0(arg0->unk_040, arg0->obj.id);
}
break;
}
}
void func_80069DF4(Object_80* arg0) {
if (arg0->unk_4C != 0) {
arg0->unk_4C--;
}
switch (arg0->obj.status) {
case 1:
arg0->obj.status = 2;
func_80063F90(arg0->unk_40, arg0->obj.id);
func_800696F8(arg0);
break;
case 2:
func_800696F8(arg0);
if (arg0->unk_1C.action != NULL) {
arg0->unk_1C.action(&arg0->obj);
}
break;
}
}
void func_80069E88(Object_4C* arg0) {
switch (arg0->obj.status) {
case 1:
arg0->obj.status = 2;
func_80063F90(arg0->unk_40, arg0->obj.id);
func_80069858(arg0);
break;
case 2:
func_80069858(arg0);
if (arg0->unk_1C.action != NULL) {
arg0->unk_1C.action(&arg0->obj);
}
break;
case 3:
func_80069858(arg0);
func_800690D0(arg0->unk_40, arg0->obj.id);
break;
}
}
void func_80069F30(Object_6C* arg0) {
if (arg0->unk_48 != 0) {
arg0->unk_48--;
}
if (arg0->unk_4A != 0) {
arg0->unk_4A--;
}
switch (arg0->obj.status) {
case 1:
arg0->obj.status = 2;
func_80063F90(arg0->unk_40, arg0->obj.id);
func_80069A10(arg0);
break;
case 2:
func_80069A10(arg0);
if (arg0->unk_1C.action != NULL) {
arg0->unk_1C.action(&arg0->obj);
}
break;
}
}
void func_80069FD4(Object_8C* arg0) {
if (arg0->unk_50 != 0) {
arg0->unk_50--;
}
switch (arg0->obj.status) {
case 1:
arg0->obj.status = 2;
func_80063F90(arg0->unk_40, arg0->obj.id);
/* fallthrough */
case 2:
func_80069924(arg0);
if ((arg0->obj.status != 0) && (arg0->unk_1C.action != NULL)) {
arg0->unk_1C.action(&arg0->obj);
}
break;
}
}
void func_8006A06C(UnkEntity30* arg0) {
Vec3f sp44;
Vec3f sp38;
f32 sp34;
f32 sp30;
f32 sp2C;
if (arg0->timer != 0) {
arg0->timer--;
}
sp34 = arg0->unk_04.x - arg0->unk_10.x;
sp30 = arg0->unk_04.y - arg0->unk_10.y;
sp2C = arg0->unk_04.z - arg0->unk_10.z;
arg0->unk_20 = Math_Atan2F(sp34, sp2C);
arg0->unk_1C = -Math_Atan2F(sp30, sqrtf(SQ(sp34) + SQ(sp2C)));
if (arg0->mode != 4) {
arg0->unk_24 = sqrtf(SQ(sp34) + SQ(sp30) + SQ(sp2C));
}
if (gGameState == GSTATE_PLAY) {
if (((arg0->mode == 1) || (arg0->mode == 0x65) || (arg0->mode == 0x32)) && (gPlayer[0].unk_1C8 == 3) &&
(gPlayer[0].unk_1F4 == 0)) {
Matrix_RotateX(gCalcMatrix, -arg0->unk_1C, 0);
Matrix_RotateY(gCalcMatrix, -arg0->unk_20, 1);
sp44.x = gPlayer[D_801778A0].unk_074 - arg0->unk_04.x;
sp44.y = gPlayer[D_801778A0].unk_078 - arg0->unk_04.y;
sp44.z = gPlayer[D_801778A0].unk_138 - arg0->unk_04.z;
Matrix_MultVec3fNoTranslate(gCalcMatrix, &sp44, &sp38);
sp38.x += arg0->unk_04.x;
sp38.y += arg0->unk_04.y;
sp38.z += arg0->unk_04.z;
if ((fabsf(sp38.x - arg0->unk_04.x) < 30.0f) && (fabsf(sp38.y - arg0->unk_04.y) < 30.0f) &&
(sp38.z < arg0->unk_04.z) && ((arg0->unk_04.z - arg0->unk_24) < sp38.z)) {
if (gCurrentLevel == LEVEL_AQUAS) {
func_800A6CD0(&gPlayer[0], 0, 30);
} else {
func_800A6CD0(&gPlayer[0], 0, 20);
}
if (arg0->mode < 100) {
arg0->mode = 0;
}
}
}
if (((arg0->unk_04.z + D_80177D20) > 1000.0f) && (D_80177880 != 1)) {
arg0->mode = 0;
}
if (((arg0->mode == 3) || (arg0->mode == 50)) && (arg0->timer == 0)) {
arg0->mode = 0;
}
}
}
void func_8006A38C(void) {
UnkEntity30* var_s0;
s32 var_s1;
for (var_s1 = 0, var_s0 = gUnkEntities30; var_s1 < ARRAY_COUNT(gUnkEntities30); var_s1++, var_s0++) {
if (var_s0->mode != 0) {
func_8006A06C(var_s0);
}
}
}
void func_8006A3E8(void) {
s32 i;
s32 pad;
Object_58* var_v0;
Object_2F4* sp38;
Object_408* sp34;
Object_4C* sp30;
Object_80* sp2C;
Object_6C* sp28;
Object_8C* sp24;
D_80161AB8 = 0;
if ((D_80177880 == 0) && ((gPlayer[0].unk_1C8 == 1) || (gPlayer[0].unk_1C8 == 3) || (gPlayer[0].unk_1C8 == 4) ||
(gPlayer[0].unk_1C8 == 8) || (gPlayer[0].unk_1C8 == 9) || (gPlayer[0].unk_1C8 == 6))) {
D_80161AB8 = 1;
}
if (D_80177880 != 1) {
if ((D_80178488 != 0) && (gPlayer[0].unk_1C8 != 2)) {
func_80062664();
}
for (i = 0, sp2C = gObjects80; i < ARRAY_COUNT(gObjects80); i++, sp2C++) {
if (sp2C->obj.status != 0) {
sp2C->unk_40 = i;
func_80069DF4(sp2C);
}
}
} else if (D_801778E8 != 0) {
for (i = 0, var_v0 = gObjects58; i < 200; i++, var_v0++) {
if ((var_v0->obj.status != 0) && (var_v0->obj.id == OBJECT_146)) {
if (i & 1) {
var_v0->obj.rot.y += 0.5f;
} else {
var_v0->obj.rot.y -= 0.5f;
}
}
}
}
for (i = 0, sp30 = gObjects4C; i < ARRAY_COUNT(gObjects4C); i++, sp30++) {
if (sp30->obj.status != 0) {
sp30->unk_40 = i;
func_80069E88(sp30);
}
}
for (i = 0, sp34 = gObjects408; i < ARRAY_COUNT(gObjects408); i++, sp34++) {
if (sp34->obj.status != 0) {
sp34->unk_040 = i;
func_80069CBC(sp34);
}
}
for (i = 0, sp38 = gObjects2F4; i < ARRAY_COUNT(gObjects2F4); i++, sp38++) {
if (sp38->obj.status != 0) {
sp38->unk_040 = i;
func_80069AAC(sp38);
}
}
for (i = 0, sp28 = gObjects6C; i < ARRAY_COUNT(gObjects6C); i++, sp28++) {
if (sp28->obj.status != 0) {
sp28->unk_40 = i;
func_80069F30(sp28);
}
}
for (i = 0, sp24 = gObjects8C; i < ARRAY_COUNT(gObjects8C); i++, sp24++) {
if (sp24->obj.status != 0) {
sp24->unk_40 = i;
func_80069FD4(sp24);
}
}
func_8006A38C();
for (i = 0; i < ARRAY_COUNT(D_80161670); i++) {
if (D_80161670[i] != 0) {
D_80161670[i]--;
}
}
}