#include "global.h" #include "fox_map.h" #include "sf64level.h" typedef struct { /* 0x0 */ f32 angle; /* 0x4 */ f32 x; /* 0x8 */ f32 y; /* 0xC */ f32 scale; } ObjPosition; typedef struct { /* 0x00 */ s32 unk_00; /* 0x04 */ s32 unk_04; /* 0x08 */ s32 unk_08; /* 0x0C */ s32 unk_0C; /* 0x10 */ char pad10[0x4]; /* 0x14 */ s32 unk_14; /* 0x18 */ s32 unk_18; } UnkStruct_D_EBFBE0_801AFD18; // size = 0x1C typedef struct { /* 0x00 */ s32 id; /* 0x04 */ f32 unk_04; /* 0x08 */ f32 unk_08; /* 0x0C */ f32 zAngle; /* 0x10 */ f32 posX; /* 0x14 */ f32 posY; /* 0x18 */ f32 posZ; /* 0x1C */ f32 unk_1C; /* 0x20 */ f32 scale; /* 0x24 */ s32 alpha; /* 0x28 */ s32 unk_28; /* 0x2C */ s32 unk_2C; /* 0x30 */ s32 unk_30; /* 0x34 */ s32 unk_34; } Planet; // size = 0x38 typedef struct { /* 0x0 */ u8* addr; /* 0x4 */ s32 width; /* 0x8 */ s32 height; /* 0xC */ f32 posX; } Texture; // size = 0x10 extern Planet planet[15]; extern s32 D_EBFBE0_801AF420[2]; extern Gfx* D_EBFBE0_801AF824[4]; extern Texture D_EBFBE0_801AF834[14]; extern Texture D_EBFBE0_801AF914[14]; extern u16* D_EBFBE0_801AF428[15][2]; extern Gfx* D_EBFBE0_801AFA30[2]; extern ObjPosition D_EBFBE0_801AFA38[]; extern UnkStruct_D_EBFBE0_801AFD18 D_EBFBE0_801AFD18[24]; extern f32 D_EBFBE0_801AFFB8[]; extern f32 D_EBFBE0_801AFFF4; // yRot of something extern f32 D_EBFBE0_801AFFF8; // xRot of something extern f32 D_EBFBE0_801AFFFC; // yRot of something extern f32 D_EBFBE0_801B0000; // xRot of something extern s32 D_EBFBE0_801B0004[47]; extern s32 D_EBFBE0_801B00C0[47][96]; extern Gfx D_EBFBE0_801B4A40[]; extern void* D_EBFBE0_801B68D4[]; extern Gfx* D_EBFBE0_801B68F8[]; extern f32 D_EBFBE0_801B69D4[8]; extern f32 D_EBFBE0_801B69F4[8]; extern f32 D_EBFBE0_801B6A14[8]; extern f32* D_EBFBE0_801B6A34[2]; extern f32* D_EBFBE0_801B6A3C[2]; extern f32* D_EBFBE0_801B6A44[2]; extern f32 D_EBFBE0_801B6A78; // in-func static extern f32 D_EBFBE0_801B6A7C; extern s32 D_EBFBE0_801B6A84[]; extern s32 D_EBFBE0_801B6B24[]; // data extern f32 D_EBFBE0_801B6B30; extern f32 D_EBFBE0_801CD818[]; extern s32 D_EBFBE0_801CD83C; extern s32 D_EBFBE0_801CD840[24]; extern s32 D_EBFBE0_801CD8A0[15]; // bss extern s32 D_EBFBE0_801CD8E0[7]; extern f32 D_EBFBE0_801CD9F4; // x extern f32 D_EBFBE0_801CD9F8; // y extern f32 D_EBFBE0_801CD9FC; // z extern s32 D_EBFBE0_801CD900[15]; extern s32 D_EBFBE0_801CD93C; extern s32 D_EBFBE0_801CD940; // bss extern s32 D_EBFBE0_801CD944; // mapState // bss extern s32 D_EBFBE0_801CD948; extern s32 D_EBFBE0_801CD94C; extern s32 D_EBFBE0_801CD950; extern s32 D_EBFBE0_801CD954; extern s32 D_EBFBE0_801CD958; extern s32 D_EBFBE0_801CD95C; extern s32 D_EBFBE0_801CD960; extern s32 D_EBFBE0_801CD964; // bss extern s32 D_EBFBE0_801CD968; // bss extern s32 D_EBFBE0_801CD96C; // bss extern s32 D_EBFBE0_801CD970; extern s32 D_EBFBE0_801CD974; extern s32 D_EBFBE0_801CD978; extern s32 D_EBFBE0_801CD97C; extern s32 D_EBFBE0_801CD980; extern s32 D_EBFBE0_801CD984; extern s32 D_EBFBE0_801CD988; extern s32 D_EBFBE0_801CD98C; extern s32 D_EBFBE0_801CD990; extern s32 D_EBFBE0_801CD994; extern s32 D_EBFBE0_801CD998; extern f32 D_EBFBE0_801CD99C; extern s32 D_EBFBE0_801CD9A0; extern s32 D_EBFBE0_801CD9A4; extern s32 D_EBFBE0_801CD9A8; extern s32 D_EBFBE0_801CD9AC; extern f32 D_EBFBE0_801CD9B0; extern f32 D_EBFBE0_801CD9B4; extern s32 D_EBFBE0_801CD9B8; extern s32 D_EBFBE0_801CD9BC; extern s32 D_EBFBE0_801CD9C0; extern s32 D_EBFBE0_801CD9C4; extern s32 D_EBFBE0_801CD9C8; extern s32 D_EBFBE0_801CD9CC; extern s32 D_EBFBE0_801CD9D0; extern s32 D_EBFBE0_801CD9D4; extern f32 D_EBFBE0_801CD9DC; extern f32 D_EBFBE0_801CD9E0; extern f32 D_EBFBE0_801CD9E4; extern f32 D_EBFBE0_801CD9E8; extern f32 D_EBFBE0_801CD9EC; extern s32 D_EBFBE0_801CD9F0; extern f32 D_EBFBE0_801CDA00; // x extern f32 D_EBFBE0_801CDA04; // y extern f32 D_EBFBE0_801CDA08; // z extern f32 D_EBFBE0_801CDA0C; extern f32 D_EBFBE0_801CDA10; extern f32 D_EBFBE0_801CDA14; extern f32 D_EBFBE0_801CDA18; extern f32 D_EBFBE0_801CDA1C; extern f32 D_EBFBE0_801CDA20; extern f32 D_EBFBE0_801CDA24; extern f32 D_EBFBE0_801CDA28; extern f32 D_EBFBE0_801CDA2C; extern f32 D_EBFBE0_801CDA30; extern f32 D_EBFBE0_801CDA34; extern f32 D_EBFBE0_801CDA38; extern Vec3f D_EBFBE0_801CDA40; extern Vec3f D_EBFBE0_801CDA50; extern Matrix D_EBFBE0_801CDA60[]; extern Matrix D_EBFBE0_801CDE20[15]; // bss // planet related extern Matrix D_EBFBE0_801CE060; extern Matrix D_EBFBE0_801CE1E0[15]; extern Matrix D_EBFBE0_801CE5A0[]; extern Vec3f D_EBFBE0_801CE960[]; // pos of something extern f32 D_EBFBE0_801CEA54; extern f32 D_EBFBE0_801CEA64; extern f32 D_EBFBE0_801CEA68; extern f32 D_EBFBE0_801CEAA8; extern f32 D_EBFBE0_801CEAAC; extern f32 D_EBFBE0_801CEAB0; extern s32 D_EBFBE0_801CEAB4; extern f32 D_EBFBE0_801CEA18[]; extern f32 D_EBFBE0_801CEA58; extern f32 D_EBFBE0_801CEA5C; extern f32 D_EBFBE0_801CEA60; extern f32 D_EBFBE0_801CEA6C; extern f32 D_EBFBE0_801CEA70; extern s32 D_EBFBE0_801CEA74; extern f32 D_EBFBE0_801CEAB8[]; extern f32 D_EBFBE0_801CEAF8[]; extern s32 D_EBFBE0_801CEB34; extern s32 D_EBFBE0_801CEB38; extern f32 D_EBFBE0_801CEB3C; extern f32 D_EBFBE0_801CEB40; extern s32 D_EBFBE0_801CEB48[3]; extern s32 D_EBFBE0_801CEB58[3][10]; extern s32 D_EBFBE0_801CEBD0[3][10]; extern f32 D_EBFBE0_801CEC48[3][10]; extern f32 D_EBFBE0_801CECC0[3][10]; extern f32 D_EBFBE0_801CED38[3][10]; extern f32 D_EBFBE0_801CEDB0[3][10]; extern f32 D_EBFBE0_801CEE28[3][10]; extern s32 D_EBFBE0_801CEEA0; extern s32 D_EBFBE0_801CEEA4; extern s32 D_EBFBE0_801CEEA8; extern s32 D_EBFBE0_801CEEAC; extern Vec3f D_EBFBE0_801CEEB0; // bss extern f32 D_EBFBE0_801CEEBC; extern f32 D_EBFBE0_801CEEC0; extern s32 D_EBFBE0_801CEEC4; extern s32 D_EBFBE0_801CEEC8; extern s32 D_EBFBE0_801CEECC; extern s32 D_EBFBE0_801CEED8; extern f32 D_EBFBE0_801CEEDC; extern f32 D_EBFBE0_801CEEE0; extern Vec3f D_EBFBE0_801CEEE8[9]; extern f32 D_EBFBE0_801CEF00; extern f32 D_EBFBE0_801CEF04; extern f32 D_EBFBE0_801CEF08; extern f32 D_EBFBE0_801CEF30; extern f32 D_EBFBE0_801CEF34; extern f32 D_EBFBE0_801CEF38; extern Vec3f D_EBFBE0_801CEF58[9]; extern s32 D_EBFBE0_801CEFC4; // bss extern s32 D_EBFBE0_801CEFC8; extern s32 D_EBFBE0_801CEFD0; extern s32 D_EBFBE0_801CEFD4; extern s32 D_EBFBE0_801CEFD8; extern s32 D_EBFBE0_801CEFDC; extern f32 D_EBFBE0_801CEFE0; extern f32 D_EBFBE0_801CEFE8[3]; extern f32 D_EBFBE0_801CEFF4; extern f32 D_EBFBE0_801CEFF8; extern s32 D_EBFBE0_801CF000[]; extern s32 D_EBFBE0_801CF00C; extern s32 D_EBFBE0_801CF010; extern s32 D_EBFBE0_801CF014; extern s32 D_EBFBE0_801CF018; // bss extern f32 D_EBFBE0_801CF020[8]; extern f32 D_EBFBE0_801CF040[8]; extern f32 D_EBFBE0_801CF060[8]; extern f32 D_EBFBE0_801CF080; extern f32 D_EBFBE0_801CF088[8]; extern f32 D_EBFBE0_801CF0A8[8]; extern f32* D_EBFBE0_801CF0C8; extern f32* D_EBFBE0_801CF0CC; extern f32* D_EBFBE0_801CF0D0; extern s32 D_EBFBE0_801CF11C; extern s32 D_EBFBE0_801CF120; extern f32 D_EBFBE0_801CF124; extern u8 D_5000500[]; extern u8 D_600D590[]; extern Gfx D_601D1F0[]; extern u8 D_601DC10[]; extern u16 D_601DC90[]; extern Gfx D_601DCF0[]; extern u8 D_601DCA0[]; extern u16 D_601DCD8[]; extern u16 D_6044820[]; extern u16 D_6046AA0[]; extern u16 D_6046CD0[]; extern Gfx D_60479D0[]; extern Gfx D_6047E70[]; extern u8 D_6047F80[]; extern u8 D_6048F80[]; extern Gfx D_604C350[]; extern Gfx D_604C540[]; extern Gfx D_604CDE0[]; extern Gfx D_604D680[]; extern Gfx D_605A120[]; extern s32 D_EBFBE0_801CD810; extern f32 D_EBFBE0_801CEA78; extern f32 D_EBFBE0_801CEA7C; extern f32 D_EBFBE0_801CEA80; extern f32 D_EBFBE0_801CEA84; extern f32 D_EBFBE0_801CEA88; extern f32 D_EBFBE0_801CEA8C; extern f32 D_EBFBE0_801CEA90; extern f32 D_EBFBE0_801CEA94; extern s32 D_EBFBE0_801CEA98; extern f32 D_EBFBE0_801CEA9C; void func_EBFBE0_8019E800(void); void func_EBFBE0_8019E99C(void); void func_EBFBE0_8019F164(void); void func_EBFBE0_8019F42C(void); void func_EBFBE0_8019F600(void); void func_EBFBE0_8019F910(void); void func_EBFBE0_8019F97C(void); void func_EBFBE0_8019F83C(void); void func_EBFBE0_8019FA1C(void); void func_EBFBE0_8019FC04(void); s32 func_EBFBE0_8019FD1C(LevelId levelId, s32 arg1); void func_EBFBE0_8019FF48(void); s32 func_EBFBE0_801A05B4(void); void func_EBFBE0_801A0788(void); void func_EBFBE0_801A0954(void); void func_EBFBE0_801A0D14(void); void func_EBFBE0_801A1528(void); void func_EBFBE0_801A19A8(void); void func_EBFBE0_801A1C14(void); f32 func_EBFBE0_801A25C8(PlanetId); void func_EBFBE0_801A281C(); void func_EBFBE0_801A2B8C(void); void func_EBFBE0_801A2EB8(); void func_EBFBE0_801A3550(Vec3f*, Vec3f*, Vec3f*, f32); void func_EBFBE0_801A36A8(void); void func_EBFBE0_801A4650(void); void func_EBFBE0_801A48C0(f32 speed); void func_EBFBE0_801A4A38(f32 arg0); void func_EBFBE0_801A4AE8(void); void func_EBFBE0_801A4D0C(u32); void func_EBFBE0_801A4D7C(void); void func_EBFBE0_801A4F8C(void); void func_EBFBE0_801A4FC4(void); void func_EBFBE0_801A53C8(void); void func_EBFBE0_801A5834(void); void func_EBFBE0_801A5C90(void); s32 func_EBFBE0_801A5770(void); void func_EBFBE0_801A5E80(void); void func_EBFBE0_801A6368(void); void func_EBFBE0_801A61B4(LevelId level); bool func_EBFBE0_801A62FC(PlanetId planet); s32 func_EBFBE0_801A655C(s32 arg0, s32 arg1); void func_EBFBE0_801A6628(void); void func_EBFBE0_801A6694(void); void func_EBFBE0_801A68E4(void); void func_EBFBE0_801A6A24(void); void func_EBFBE0_801A6A98(PlanetId); s32 func_EBFBE0_801A6DAC(PlanetId planetId); void func_EBFBE0_801A6EC0(PlanetId planetId); void func_EBFBE0_801A7230(PlanetId planetId); void func_EBFBE0_801A74F4(PlanetId); void func_EBFBE0_801A7684(PlanetId planetId); void func_EBFBE0_801A77B0(PlanetId planetId); void func_EBFBE0_801A791C(PlanetId planetId); void func_EBFBE0_801A7A84(PlanetId planetId); void func_EBFBE0_801A7BEC(f32* zAngle, f32 next, f32 scale); void func_EBFBE0_801A7D3C(PlanetId planetId); void func_EBFBE0_801A7F1C(PlanetId planetId); void func_EBFBE0_801A914C(void); void func_EBFBE0_801A9EE4(void); void func_EBFBE0_801AD11C(void); void func_EBFBE0_801AD718(f32, f32, f32, f32*, f32*, f32*, f32, f32, f32); PlanetId GetPlanetId(LevelId level); void func_EBFBE0_801A809C(PlanetId planetId); void func_EBFBE0_801A8738(void); void func_EBFBE0_801A89BC(PlanetId, s32); void func_EBFBE0_801A8F40(void); void func_EBFBE0_801A9224(void); void func_EBFBE0_801A9448(void); void func_EBFBE0_801A9814(void); void func_EBFBE0_801A9910(void); void func_EBFBE0_801A9A8C(void); void func_EBFBE0_801A9DE8(void); void func_EBFBE0_801AA1CC(s32); void func_EBFBE0_801AA434(s32, f32, f32, s32); void func_EBFBE0_801AA778(s32, f32, f32, s32); void func_EBFBE0_801AB284(void); void func_EBFBE0_801AB300(void); void func_EBFBE0_801AB978(s32); void func_EBFBE0_801ABCDC(s32 arg0, s32 alpha); void func_EBFBE0_801ABF1C(void); void func_EBFBE0_801AC200(s32); void func_EBFBE0_801AC530(s32 index); s32 func_EBFBE0_801AC80C(s32); void func_EBFBE0_801AC9A0(s32); void func_EBFBE0_801ACD90(s32 index, Vec3f* src, Vec3f* dest); void func_EBFBE0_801AD048(void); void func_EBFBE0_8019E800(void) { Memory_FreeAll(); func_800A5D6C(); D_80178410 = 0; gNextGameState = 4; D_80161A34 = 5; D_80177868 = 2; gDrawMode = DRAWMODE_0; } void func_EBFBE0_8019E85C(void) { switch (D_80177868) { case 0: if (D_Timer_8017783C == 0) { D_80177868 = 1; } break; case 2: break; case 1: func_EBFBE0_8019E800(); break; } } void func_EBFBE0_8019E8C8(void) { } void func_EBFBE0_8019E8D0(void) { if (D_EBFBE0_801CD9B8 > 0) { D_EBFBE0_801CD9B8--; } if (D_EBFBE0_801CD9BC > 0) { D_EBFBE0_801CD9BC--; } if (D_EBFBE0_801CD9C0 > 0) { D_EBFBE0_801CD9C0--; } switch (D_80177B40) { case 0: if (D_Timer_8017783C == 0) { D_80177B40 = 1; } break; case 1: gDrawMode = DRAWMODE_0; func_EBFBE0_8019E99C(); break; case 2: gDrawMode = DRAW_MAP; func_EBFBE0_8019FF48(); break; } } void func_EBFBE0_8019E99C(void) { s32 i; s32 j; func_8001DC6C(0, 0x118); D_80137E78 = 2; gFrameCount = 0; func_EBFBE0_80188010(); D_EBFBE0_801CD83C = func_EBFBE0_801A05B4(); D_EBFBE0_801CD980 = 0; D_EBFBE0_801CD984 = 0; D_EBFBE0_801CD98C = 0; D_EBFBE0_801CD990 = 0; D_EBFBE0_801CD994 = 0; D_EBFBE0_801CD9CC = 0; D_EBFBE0_801CEB48[0] = 0; D_EBFBE0_801CEB48[1] = 0; D_EBFBE0_801CEB48[2] = 0; for (i = 0; i < 10; i++) { D_EBFBE0_801CEB58[1][i] = 0; D_EBFBE0_801CEB58[2][i] = 0; D_EBFBE0_801CEBD0[1][i] = 0xFF; D_EBFBE0_801CEBD0[2][i] = 0xFF; D_EBFBE0_801CEC48[1][i] = 0.0f; D_EBFBE0_801CEC48[2][i] = 0.0f; D_EBFBE0_801CECC0[1][i] = 0.5f + (Rand_ZeroOne() * 0.3f); D_EBFBE0_801CECC0[2][i] = 0.5f + (Rand_ZeroOne() * 0.3f); D_EBFBE0_801CEE28[1][i] = 1 + (s32) (Rand_ZeroOne() * 5.0f); D_EBFBE0_801CEE28[2][i] = 1 + (s32) (Rand_ZeroOne() * 5.0f); D_EBFBE0_801CED38[1][i] = 50.0f + (s32) (Rand_ZeroOne() * 30.0f); D_EBFBE0_801CED38[2][i] = 110.0f + (s32) (Rand_ZeroOne() * 30.0f); D_EBFBE0_801CEDB0[1][i] = -10.0f + (Rand_ZeroOne() * -60.0f); D_EBFBE0_801CEDB0[2][i] = -10.0f + (Rand_ZeroOne() * -60.0f); } D_EBFBE0_801CD978 = 0; D_EBFBE0_801CD97C = 0; D_EBFBE0_801CF010 = 0; D_EBFBE0_801CF014 = 0; for (j = 0; j < 15; j++) { D_EBFBE0_801CD900[j] = 0; D_EBFBE0_801CEAB8[j] = 0.0f; D_EBFBE0_801CEAF8[j] = -90.0f; } D_EBFBE0_801CDA20 = 0.0f; D_EBFBE0_801CDA24 = 1.0f; D_EBFBE0_801CDA28 = 0.0f; D_EBFBE0_801CDA00 = -150.552155f; D_EBFBE0_801CDA04 = -489.679993f; D_EBFBE0_801CDA08 = 0.0f; D_EBFBE0_801CDA0C = -42.750008f; D_EBFBE0_801CDA10 = -9.849999f; D_EBFBE0_801CDA14 = 3375.000000f; D_EBFBE0_801CDA18 = 0.0f; D_EBFBE0_801CDA1C = 0.0f; func_EBFBE0_801AD718(D_EBFBE0_801CDA00, D_EBFBE0_801CDA04, D_EBFBE0_801CDA08, &D_EBFBE0_801CD9F4, &D_EBFBE0_801CD9F8, &D_EBFBE0_801CD9FC, D_EBFBE0_801CDA14, D_EBFBE0_801CDA0C + D_EBFBE0_801CDA18, D_EBFBE0_801CDA10 + D_EBFBE0_801CDA1C); for (i = 0; i < 15; i++) { D_EBFBE0_801CD8A0[i] = i; } D_EBFBE0_801CD960 = 0; D_80178340 = 0xFF; D_80178348 = 0; D_80178350 = 0; D_80178354 = 0; D_80177D20 = 0.0f; D_EBFBE0_801CF018 = 0; gBgColor = 0; D_EBFBE0_801CEA58 = 0.0f; D_EBFBE0_801CEA5C = 0.0f; D_EBFBE0_801CEA60 = 0.0f; func_EBFBE0_801A0788(); D_EBFBE0_801B8280 = 0; D_EBFBE0_801B8284 = 0; D_EBFBE0_801CD9B8 = 0; D_EBFBE0_801CD9BC = 0; D_EBFBE0_801CD9C0 = 0; D_EBFBE0_801CD964 = 0; D_EBFBE0_801CD968 = 0; D_EBFBE0_801CD96C = 0; D_EBFBE0_801CEA6C = 0.0f; D_EBFBE0_801CEA70 = 0.002f; func_8001D444(0, 0x3C, 0, 0xFF); D_EBFBE0_801CEFC4 = 0; D_EBFBE0_801CEFC8 = 0; D_EBFBE0_801CEFD0 = 0; D_EBFBE0_801CD974 = 0; for (i = 0; i < 24; i++) { D_EBFBE0_801CD840[i] = i; D_EBFBE0_801AFD18[i].unk_14 = 0; } func_EBFBE0_801A6694(); switch (D_80161A34) { default: case 0: func_EBFBE0_8019F600(); break; case 7: func_EBFBE0_8019F164(); break; case 5: func_EBFBE0_8019F42C(); break; } func_EBFBE0_801A914C(); for (i = 0; i < 96 * 96; i++) { D_EBFBE0_801BB810[i] = 106; D_EBFBE0_801BDC10[i] = 84; D_EBFBE0_801C0010[i] = 75; D_EBFBE0_801C2410[i] = 81; D_EBFBE0_801C4810[i] = 55; D_EBFBE0_801C6C10[i] = 82; D_EBFBE0_801C9010[i] = 68; D_EBFBE0_801CB410[i] = 52; D_EBFBE0_801B9410[i] = 0; } for (i = 0; i < 9; i++) { D_EBFBE0_801CD818[i] = 0.0f; func_EBFBE0_801A07E8(D_EBFBE0_801B68B0[i], SEGMENTED_TO_VIRTUAL(D_EBFBE0_801B68D4[i]), &D_EBFBE0_801CD818[i]); } D_EBFBE0_801CD810 = 0; D_80177B40 = 2; D_EBFBE0_801CD948 = 0; D_EBFBE0_801CEEC4 = 0; D_EBFBE0_801CEEC8 = 5; D_EBFBE0_801CEFF4 = 255.0f; D_EBFBE0_801CEFF8 = 255.0f; D_EBFBE0_801CEEBC = 0.0f; D_EBFBE0_801CEEC0 = 0.0f; D_EBFBE0_801CEEA0 = 0; D_EBFBE0_801CEEA4 = 0; D_EBFBE0_801CEEA8 = 0xFF; D_EBFBE0_801CEEAC = 0xFF; D_EBFBE0_801CEB34 = -1; } void func_EBFBE0_8019F164(void) { s32 i; D_EBFBE0_801CD974 = 1; if (gLifeCount[gPlayerNum] > 99) { gLifeCount[gPlayerNum] = 99; } for (i = 0; i < 6; i++) { D_80177C38[i] = gTeamShields[i]; D_801778F0[i] = gSavedTeamShields[i]; gSavedTeamShields[i] = gTeamShields[i]; } for (i = 1; i < 4; i++) { if (D_80177C38[i] == 0) { D_80177C38[i] = 255; } } D_EBFBE0_801CD93C = D_80177930; D_EBFBE0_801CD954 = GetPlanetId(gCurrentLevel); D_EBFBE0_801CD950 = D_EBFBE0_801CD954; D_EBFBE0_801CD980 = func_EBFBE0_8019FD1C(gCurrentLevel, 0); func_EBFBE0_8019FD1C(gCurrentLevel, 2); if (D_800D3180[gCurrentLevel] == 2) { D_EBFBE0_801CD98C = 1; D_80177BB0[D_80177B48] = 1; func_EBFBE0_8019FD1C(gCurrentLevel, 1); } Save_Write(); func_EBFBE0_8019F97C(); func_EBFBE0_8019F83C(); func_EBFBE0_8019FA1C(); switch (D_EBFBE0_801CD93C) { case 0: D_EBFBE0_801CD958 = planet[D_EBFBE0_801CD954].unk_2C; break; case 1: D_EBFBE0_801CD958 = planet[D_EBFBE0_801CD954].unk_30; break; case 2: D_EBFBE0_801CD958 = planet[D_EBFBE0_801CD954].unk_34; break; } D_80177B48++; func_EBFBE0_8019FC04(); D_EBFBE0_801CEFC4 = 0; D_EBFBE0_801CEFD0 = 0; D_EBFBE0_801CEFE0 = 32.0f; D_EBFBE0_801CEFE8[0] = 255.0f; D_EBFBE0_801CEFE8[1] = 255.0f; D_EBFBE0_801CEFE8[2] = 255.0f; D_EBFBE0_801CEFD8 = 0; if (D_EBFBE0_801CD93C) { D_EBFBE0_801CEFD8 = 1; } gHitCount = 0; D_EBFBE0_801CD94C = 0; D_EBFBE0_801CD944 = 5; } void func_EBFBE0_8019F42C(void) { s32 i; D_80161714 += gHitCount; gLifeCount[gPlayerNum] = 0; D_EBFBE0_801CD974 = 1; D_EBFBE0_801CD954 = GetPlanetId(gCurrentLevel); D_80177B70[D_80177B48] = gHitCount; func_EBFBE0_8019F910(); func_EBFBE0_8019FD1C(gCurrentLevel, 0); Save_Write(); func_EBFBE0_8019F83C(); for (i = 0; i < 7; i++) { D_EBFBE0_801CD8E0[i] = 0; } if (D_80177B48 != 0) { for (i = 0; i < D_80177B48; i++) { D_EBFBE0_801CD8E0[i] = func_EBFBE0_801A655C(D_80177B90[i], D_80177B90[i + 1]); } } for (i = 0; i < 24; i++) { D_80177BD8[i] = 0; } for (i = 0; i < 15; i++) { planet[i].alpha = 0; } func_EBFBE0_8019FC04(); D_EBFBE0_801CD9AC = 0; func_8001DC6C(0, 0x19); D_EBFBE0_801CD948 = 0; D_EBFBE0_801CD94C = 0; D_EBFBE0_801CD944 = 7; } void func_EBFBE0_8019F600(void) { s32 i; s32 sp18; s32 temp_t4; D_80161714 = 0; gHitCount = 0; gTeamShields[1] = 255; gTeamShields[2] = 255; gTeamShields[3] = 255; gSavedTeamShields[1] = 255; gSavedTeamShields[2] = 255; gSavedTeamShields[3] = 255; D_80177C38[1] = 255; D_80177C38[2] = 255; D_80177C38[3] = 255; D_80177C58[1] = 255; D_80177C58[2] = 255; D_80177C58[3] = 255; D_EBFBE0_801CD950 = -1; for (i = 0; i < 15; i++) { planet[i].alpha = 0; } D_EBFBE0_801CD970 = 0; for (i = 0; i < 24; i++) { D_80177BD8[i] = 0; gUnkEntities30[i].unk_24 = 0.0f; } for (i = 0; i < 7; i++) { D_80177BB0[i] = 0; D_80177B70[i] = 0; D_80177B50[i] = 0x00FFFFFF; } D_80177B90[0] = 9; D_80177B90[1] = -1; D_80177B90[2] = -1; D_80177B90[3] = -1; D_80177B90[4] = -1; D_80177B90[5] = -1; D_80177B90[6] = 13; for (i = 0; i < 24; i++) { D_EBFBE0_801AFD18[i].unk_18 = 255; } D_80177B48 = 0; gCurrentLevel = 0; D_EBFBE0_801CD954 = 9; D_EBFBE0_801CEA9C = 0.0f; D_EBFBE0_801CD9B0 = 0.002f; D_EBFBE0_801CD9B4 = 0.01f; D_EBFBE0_801CD944 = 0; sp18 = func_EBFBE0_801A655C(D_EBFBE0_801CD954, planet[D_EBFBE0_801CD954].unk_2C); temp_t4 = func_EBFBE0_801A655C(D_EBFBE0_801CD954, planet[D_EBFBE0_801CD954].unk_30); D_80177BD8[sp18] = 1; D_80177BD8[temp_t4] = 1; } void func_EBFBE0_8019F83C(void) { s32 i; D_EBFBE0_801CD970 = 0; for (i = 0; i < 24; i++) { if ((D_80177BD8[i] == 4) || (D_80177BD8[i] == 5) || (D_80177BD8[i] == 1) || (D_80177BD8[i] == 11)) { D_80177BD8[i] = 0; } if (D_80177BD8[i] == 6) { D_EBFBE0_801AFD18[i].unk_14 = 5; } D_EBFBE0_801AFD18[i].unk_18 = 0; gUnkEntities30[i].unk_24 = 0.0f; } } void func_EBFBE0_8019F910(void) { s32 i; s32 mask = 0x00FF0000; for (i = 0; i < 3; i++) { if (gTeamShields[3 - i] <= 0) { D_80177B50[D_80177B48] ^= mask; } else { D_80177B50[D_80177B48] |= mask; } mask >>= 8; } } void func_EBFBE0_8019F97C(void) { D_EBFBE0_801CEA54 = func_EBFBE0_801A25C8(D_EBFBE0_801CD954); D_EBFBE0_801CD9F4 = D_EBFBE0_801CDA00 = planet[D_EBFBE0_801CD954].posX; D_EBFBE0_801CD9F8 = D_EBFBE0_801CDA04 = planet[D_EBFBE0_801CD954].posY; D_EBFBE0_801CDA08 = planet[D_EBFBE0_801CD954].posZ; D_EBFBE0_801CD9FC = planet[D_EBFBE0_801CD954].posZ + D_EBFBE0_801CEA54; } void func_EBFBE0_8019FA1C(void) { s32 i; for (i = 0; i < 15; i++) { if (i == D_EBFBE0_801CD954) { if ((i == 3) || (i == 4) || (i == 5)) { planet[i].alpha = 144; } else { planet[i].alpha = 255; } } else { planet[i].alpha = 0; } } } void func_EBFBE0_8019FC04(void) { s32 i; if (D_80177B48 != 0) { D_EBFBE0_801CEB48[1] = 1; D_EBFBE0_801CEB48[2] = 1; } for (i = 0; i < 7; i++) { if (D_80177B90[i] == 6) { D_EBFBE0_801CEB48[1] = 0; } if (D_80177B90[i] == 5) { D_EBFBE0_801CEB48[2] = 0; } } } bool func_EBFBE0_8019FD1C(LevelId levelId, s32 arg1) { s32 ret; s32 planetSaveSlot; switch (levelId) { case LEVEL_METEO: planetSaveSlot = PLANET_METEO; break; case LEVEL_AREA_6: planetSaveSlot = PLANET_AREA_6; break; case LEVEL_BOLSE: planetSaveSlot = PLANET_BOLSE; break; case LEVEL_SECTOR_Z: planetSaveSlot = PLANET_SECTOR_Z; break; case LEVEL_SECTOR_X: planetSaveSlot = PLANET_SECTOR_X; break; case LEVEL_SECTOR_Y: planetSaveSlot = PLANET_SECTOR_Y; break; case LEVEL_KATINA: planetSaveSlot = PLANET_KATINA; break; case LEVEL_MACBETH: planetSaveSlot = PLANET_MACBETH; break; case LEVEL_ZONESS: planetSaveSlot = PLANET_ZONESS; break; case LEVEL_CORNERIA: planetSaveSlot = PLANET_CORNERIA; break; case LEVEL_TITANIA: planetSaveSlot = PLANET_TITANIA; break; case LEVEL_AQUAS: planetSaveSlot = PLANET_AQUAS; break; case LEVEL_FORTUNA: planetSaveSlot = PLANET_FORTUNA; break; case LEVEL_SOLAR: planetSaveSlot = SAVE_SLOT_SOLAR; break; case LEVEL_VENOM_1: planetSaveSlot = SAVE_SLOT_VENOM_1; break; case LEVEL_VENOM_2: planetSaveSlot = SAVE_SLOT_VENOM_2; break; case LEVEL_VENOM_ANDROSS: if (D_8017827C == 0) { planetSaveSlot = SAVE_SLOT_VENOM_1; } else { planetSaveSlot = SAVE_SLOT_VENOM_2; } break; } ret = false; switch (arg1) { case 0: if (!(gSaveFile.save.data.planet[planetSaveSlot].played & 1)) { gSaveFile.save.data.planet[planetSaveSlot].played = 1; ret = true; } break; case 1: if (gExpertMode) { if (!(gSaveFile.save.data.planet[planetSaveSlot].expertMedal & 1)) { gSaveFile.save.data.planet[planetSaveSlot].expertMedal = 1; ret = true; } } else { if (!(gSaveFile.save.data.planet[planetSaveSlot].normalMedal & 1)) { gSaveFile.save.data.planet[planetSaveSlot].normalMedal = 1; ret = true; } } break; case 2: if (gExpertMode) { if (!(gSaveFile.save.data.planet[planetSaveSlot].expertClear & 1)) { gSaveFile.save.data.planet[planetSaveSlot].expertClear = 1; ret = true; } } else { if (!(gSaveFile.save.data.planet[planetSaveSlot].normalClear & 1)) { gSaveFile.save.data.planet[planetSaveSlot].normalClear = 1; ret = true; } } break; } return ret; } void func_EBFBE0_8019FF48(void) { func_EBFBE0_801A6694(); func_EBFBE0_801A68E4(); func_EBFBE0_801A6A24(); switch (D_EBFBE0_801CD944) { case 0: func_EBFBE0_801A0954(); D_8017842C += 0.09f; break; case 1: func_EBFBE0_801A1528(); D_EBFBE0_801CDA1C += 0.03f; break; case 3: func_EBFBE0_801AD11C(); D_EBFBE0_801CDA1C += 0.03f; break; case 2: func_EBFBE0_801A1C14(); break; case 4: func_EBFBE0_801A5E80(); break; case 5: func_EBFBE0_801A2B8C(); break; case 6: func_EBFBE0_801A4AE8(); break; case 7: func_EBFBE0_801A36A8(); break; default: break; } if ((D_EBFBE0_801CD944 == 0) || (D_EBFBE0_801CD944 == 1) || (D_EBFBE0_801CD944 == 7) || (D_EBFBE0_801CD944 == 3)) { func_EBFBE0_801AD718(D_EBFBE0_801CDA00, D_EBFBE0_801CDA04, D_EBFBE0_801CDA08, &D_EBFBE0_801CD9F4, &D_EBFBE0_801CD9F8, &D_EBFBE0_801CD9FC, D_EBFBE0_801CDA14, D_EBFBE0_801CDA0C + D_EBFBE0_801CDA18, D_EBFBE0_801CDA10 + D_EBFBE0_801CDA1C); func_800B6F50(D_EBFBE0_801CD9F4, D_EBFBE0_801CD9F8, D_EBFBE0_801CD9FC, D_EBFBE0_801CDA00, D_EBFBE0_801CDA04, D_EBFBE0_801CDA08); } gFrameCount++; } void func_EBFBE0_801A01A8(void) { s32 i; s32* ptr; Matrix_Push(&gGfxMatrix); Matrix_LookAt(gGfxMatrix, D_EBFBE0_801CD9F4, D_EBFBE0_801CD9F8, D_EBFBE0_801CD9FC, D_EBFBE0_801CDA00, D_EBFBE0_801CDA04, D_EBFBE0_801CDA08, D_EBFBE0_801CDA20, D_EBFBE0_801CDA24, D_EBFBE0_801CDA28, 1); Matrix_Translate(gGfxMatrix, D_EBFBE0_801CEA58, D_EBFBE0_801CEA5C, D_EBFBE0_801CEA60, 1); Matrix_SetGfxMtx(&gMasterDisp); if (D_EBFBE0_801CD974 && D_EBFBE0_801CD944 != 0) { for (i = 0; i < 24; i++) { if (D_80177BD8[i] == 0) { continue; } if (D_EBFBE0_801AFD18[i].unk_18 == 0) { continue; } func_EBFBE0_801AC9A0(i); if (D_EBFBE0_801AFD18[i].unk_14) { func_EBFBE0_801AC200(i); } func_80060D94(i); } } func_EBFBE0_801A8F40(); func_EBFBE0_801A9224(); func_EBFBE0_801A9448(); for (ptr = D_EBFBE0_801CD8A0, i = 0; i < 15; i++, ptr++) { func_EBFBE0_801A6A98(*ptr); } func_EBFBE0_801A8738(); Matrix_Pop(&gGfxMatrix); if (D_EBFBE0_801CD96C) { func_EBFBE0_801ABF1C(); } func_EBFBE0_801AB300(); if (D_EBFBE0_801CEFC4) { func_EBFBE0_801A5834(); } if (D_EBFBE0_801CD964) { func_EBFBE0_801A9910(); } func_EBFBE0_801A9814(); if (D_EBFBE0_801CD968) { func_EBFBE0_801A9A8C(); } func_EBFBE0_801A9DE8(); func_EBFBE0_801A5C90(); if ((D_EBFBE0_801CD944 == 7) && (D_EBFBE0_801CD948 == 1)) { func_EBFBE0_801A4650(); } if (D_EBFBE0_801CD944 == 0) { func_EBFBE0_801A0D14(); } if (D_EBFBE0_801CD944 == 1) { func_EBFBE0_801A19A8(); } if (D_EBFBE0_801CEEC8 == 0) { func_EBFBE0_801A07E8((u8*) D_EBFBE0_801B68B0[8], (u8*) SEGMENTED_TO_VIRTUAL(D_EBFBE0_801B68D4[8]), &(D_EBFBE0_801CD818[8])); D_EBFBE0_801CEEC8 = 5; } else { D_EBFBE0_801CEEC8--; } func_EBFBE0_801A07E8((u8*) D_EBFBE0_801B68B0[D_EBFBE0_801CEEC4 * 2], (u8*) SEGMENTED_TO_VIRTUAL(D_EBFBE0_801B68D4[D_EBFBE0_801CEEC4 * 2]), &(D_EBFBE0_801CD818[D_EBFBE0_801CEEC4 * 2])); func_EBFBE0_801A07E8((u8*) D_EBFBE0_801B68B0[(D_EBFBE0_801CEEC4 * 2) + 1], (u8*) SEGMENTED_TO_VIRTUAL(D_EBFBE0_801B68D4[(D_EBFBE0_801CEEC4 * 2) + 1]), &(D_EBFBE0_801CD818[(D_EBFBE0_801CEEC4 * 2) + 1])); D_EBFBE0_801CEEC4++; if (D_EBFBE0_801CEEC4 > 3) { D_EBFBE0_801CEEC4 = 0; } Texture_Mottle((u16*) D_6047F80, (u16*) D_6048F80, 5); } s32 func_EBFBE0_801A05B4(void) { s32 i; s32 j; s32 sp30[10]; s32 ret; s32 var_a3; s32 temp_a0; for (i = 0; i < 10; i++) { sp30[i] = 0; } for (i = 0; i < 10; i++) { temp_a0 = gSaveFile.save.data.unk_36[i]; for (j = 0; j < temp_a0; j++) { var_a3 = gSaveFile.save.data.unk_5E[i][j].unk_0; if (gSaveFile.save.data.unk_5E[i][j].unk_C != 0) { var_a3 += 256; } sp30[i] += var_a3; } } ret = sp30[0]; for (i = 1; i < 10; i++) { if (ret < sp30[i]) { ret = sp30[i]; } } return ret; } void func_EBFBE0_801A0788(void) { D_80178410 = 800; Memory_FreeAll(); func_800A5D6C(); D_80178420 = 320.0f; D_80178424 = 240.0f; D_8017842C = 0.0f; D_80178430 = 0.0f; } void func_EBFBE0_801A07E8(u8* arg0, u8* arg1, f32* arg2) { s32* var_v0 = D_EBFBE0_801B0004; s32 temp; s32 i; s32 j; s32 k; for (i = 1; i < 48; i++, var_v0++) { for (k = 0, j = *var_v0; j < (95 - *var_v0); j++, k++) { temp = D_EBFBE0_801B00C0[i - 1][k] + (s32) *arg2; if (temp > 95) { temp -= 95; } if (temp < 0) { temp += 95; } *(arg0 + ((i * 96) + j)) = *(arg1 + ((i * 96) + temp)); *(arg0 + ((95 - i) * 96) + j) = *(arg1 + ((95 - i) * 96) + temp); } } *arg2 -= 1.0f; if (*arg2 <= 0.0f) { *arg2 = 95.0f; } if (*arg2 > 95.0f) { *arg2 = 0.0f; } } #ifndef IMPORT_DATA extern f32 D_EBFBE0_801B6934[]; #endif void func_EBFBE0_801A0954(void) { PlanetId planetId; #ifdef IMPORT_DATA static f32 D_EBFBE0_801B6934[] = { 99.0f, 24, -90.0f, -150.0f, -208.0f, -276.0f, }; #endif switch (D_EBFBE0_801CD948) { case 100: break; case 0: D_EBFBE0_801CD9F0 = 0; D_EBFBE0_801CD9DC = 30.0f; D_EBFBE0_801CD9E0 = 230.0f; D_EBFBE0_801CD9E8 = 0; D_EBFBE0_801CD9E4 = 0; D_EBFBE0_801CD9EC = 0.29f; D_80178410 = 800; D_EBFBE0_801CD9C0 = 5; D_EBFBE0_801CD948++; break; case 1: if (D_EBFBE0_801CD9C0 != 0) { break; } if (D_80178340 != 0) { break; } if ((s32) D_EBFBE0_801CD9E0 == 205) { func_8001AD00(1000); } if (D_EBFBE0_801CD9E0 > -355.0f) { D_EBFBE0_801CD9E0 -= D_EBFBE0_801CD9EC; } if ((D_EBFBE0_801CD9E0 < 200.0f) && (D_EBFBE0_801CD9E8 != 255)) { D_EBFBE0_801CD9E8 += 8; if (D_EBFBE0_801CD9E8 > 255) { D_EBFBE0_801CD9E8 = 255; } } if (D_EBFBE0_801CD9E0 < D_EBFBE0_801B6934[D_EBFBE0_801CD9F0]) { D_EBFBE0_801CD9E4 += 8; if (D_EBFBE0_801CD9E4 > 255) { D_EBFBE0_801CD9E4 = 255; } } if (D_EBFBE0_801CD9E0 <= -355.0f) { D_EBFBE0_801CD948++; } break; case 2: D_EBFBE0_801CD9E8 -= 16; if (D_EBFBE0_801CD9E8 < 0) { D_EBFBE0_801CD9E8 = 0; D_EBFBE0_801CD948++; D_EBFBE0_801CD9C0 = 20; } break; case 3: if (D_EBFBE0_801CD9C0 != 0) { break; } D_EBFBE0_801CD948 = 0; D_EBFBE0_801CD944 = 1; break; } if (gControllerPress[gMainController].button & START_BUTTON) { func_8001D444(0, 0x3C, 0, 0xFF); Audio_PlaySfx(0x4900001FU, &D_800C5D28, 4U, &D_800C5D34, &D_800C5D34, &D_800C5D3C); for (planetId = 0; planetId < 15; planetId++) { if ((planetId == PLANET_SECTOR_Z) || (planetId == PLANET_SECTOR_X) || (planetId == PLANET_SECTOR_Y)) { planet[planetId].alpha = 144; } else { planet[planetId].alpha = 255; } D_EBFBE0_801CD900[planetId] = 255; } D_EBFBE0_801CD970 = 255; func_8001AE58(); D_EBFBE0_801CD974 = 1; D_EBFBE0_801CD97C = 1; D_EBFBE0_801CD948 = 0; D_EBFBE0_801CD944 = 3; } } #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A0D14.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A116C.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A1528.s") void func_EBFBE0_801A19A8(void) { s32 i; RCP_SetupDL(&gMasterDisp, 0x53); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, (s32) D_EBFBE0_801CEA9C); for (i = 0; i < 4; i++) { TextureRect_8bIA(&gMasterDisp, D_600D590 + (i * 168 * 4), 168, 4, 72.0f, 104.0f + (4.0f * i), 1.0f, 1.0f); } TextureRect_8bIA(&gMasterDisp, D_600D590 + (168 * 16), 168, 3, 72.0f, 104.0f + 16.0f, 1.0f, 1.0f); } void func_EBFBE0_801A1AE8(void) { f32 x; f32 y; f32 z; D_EBFBE0_801CEA64 = 0.04f; D_EBFBE0_801CEA54 = func_EBFBE0_801A25C8(D_EBFBE0_801CD954); D_EBFBE0_801CDA40.x = planet[D_EBFBE0_801CD954].posX; D_EBFBE0_801CDA40.y = planet[D_EBFBE0_801CD954].posY; D_EBFBE0_801CDA40.z = planet[D_EBFBE0_801CD954].posZ; D_EBFBE0_801CDA50.x = planet[D_EBFBE0_801CD954].posX; D_EBFBE0_801CDA50.y = planet[D_EBFBE0_801CD954].posY; D_EBFBE0_801CDA50.z = D_EBFBE0_801CDA40.z + D_EBFBE0_801CEA54; D_EBFBE0_801CDA2C = D_EBFBE0_801CDA00; D_EBFBE0_801CDA30 = D_EBFBE0_801CDA04; D_EBFBE0_801CDA34 = D_EBFBE0_801CD9F4; D_EBFBE0_801CDA38 = D_EBFBE0_801CD9F8; x = D_EBFBE0_801CDA50.x - D_EBFBE0_801CD9F4; y = D_EBFBE0_801CDA50.y - D_EBFBE0_801CD9F8; z = D_EBFBE0_801CDA50.z - D_EBFBE0_801CD9FC; D_EBFBE0_801CEA68 = sqrtf(SQ(x) + SQ(y) + SQ(z)); } #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A1C14.s") bool func_EBFBE0_801A2304(void) { s32 ret = false; f32 sp28; f32 sp24; f32 sp20; f32 temp_fv0; switch (D_EBFBE0_801CD94C) { case 0: func_8001ACDC(3); D_EBFBE0_801CEA78 += 2.9f; D_EBFBE0_801CEA80 += 2.9f; if (D_EBFBE0_801CEA78 > 5.5f) { D_EBFBE0_801CEA78 = 5.5f; D_EBFBE0_801CEA80 = 4.6f; D_EBFBE0_801CD94C += 1; D_EBFBE0_801CD9B8 = 0xD; } break; case 1: D_EBFBE0_801CEA78 -= 2.5f; D_EBFBE0_801CEA98 += 0xA; D_EBFBE0_801CEA80 -= 2.5f; if (D_EBFBE0_801CEA78 < 5.0f) { D_EBFBE0_801CEA78 = 5.0f; } if (D_EBFBE0_801CEA80 < 3.9f) { D_EBFBE0_801CEA80 = 3.9f; } D_EBFBE0_801CEA7C += 2.5f; D_EBFBE0_801CEA84 += 2.5f; if (D_EBFBE0_801CEA7C > 5.0f) { D_EBFBE0_801CEA7C = 5.0f; } if (D_EBFBE0_801CEA84 > 3.9f) { D_EBFBE0_801CEA84 = 3.9f; } if (D_EBFBE0_801CD9B8 == 0) { D_EBFBE0_801CEA98 = 0xFF; D_EBFBE0_801CD94C = 0x64; } break; case 100: sp28 = Math_SmoothStepToF(&D_EBFBE0_801CEA88, -206.0f, 0.4f, 100.0f, 1.0f); sp24 = Math_SmoothStepToF(&D_EBFBE0_801CEA8C, 51.0f, 0.4f, 100.0f, 1.0f); sp20 = Math_SmoothStepToF(&D_EBFBE0_801CEA90, -627.0f, 0.4f, 100.0f, 1.0f); temp_fv0 = Math_SmoothStepToF(&D_EBFBE0_801CEA94, 42.8f, 0.4f, 100.0f, 1.0f); if ((sp28 == 0.0f) && (sp24 == 0.0f) && (sp20 == 0.0f) && (temp_fv0 == 0.0f)) { ret = true; } break; } return ret; } f32 func_EBFBE0_801A25C8(PlanetId planetId) { f32 sp4; switch (planetId) { case PLANET_AREA_6: sp4 = 900.0f; break; case PLANET_BOLSE: sp4 = 800.0f; break; case PLANET_METEO: sp4 = 650.0f; break; case PLANET_KATINA: case PLANET_MACBETH: case PLANET_ZONESS: case PLANET_TITANIA: case PLANET_AQUAS: case PLANET_FORTUNA: sp4 = 550.0f; break; case PLANET_CORNERIA: sp4 = 1100.0f; break; case PLANET_VENOM: sp4 = 2100.0f; break; case PLANET_SOLAR: sp4 = 850.0f; break; case PLANET_SECTOR_Z: case PLANET_SECTOR_X: case PLANET_SECTOR_Y: sp4 = 650.0f; break; default: break; } return sp4; } void func_EBFBE0_801A2674(void) { s32 i; func_EBFBE0_801A48C0(D_EBFBE0_801CEA64); func_EBFBE0_801A4A38(D_EBFBE0_801CEA64); D_EBFBE0_801CEA64 *= 1.03f; for (i = 0; i < 15; i++) { D_EBFBE0_801CD900[i] -= 16; if (D_EBFBE0_801CD900[i] < 0) { D_EBFBE0_801CD900[i] = 0; } if (i == D_EBFBE0_801CD954) { continue; } planet[i].alpha -= 16; if (planet[i].alpha < 0) { planet[i].alpha = 0; } } for (i = 0; i < 24; i++) { if (D_80177BD8[i] == 0) { continue; } D_EBFBE0_801AFD18[i].unk_18 -= 16; if (D_EBFBE0_801AFD18[i].unk_18 < 0) { D_EBFBE0_801AFD18[i].unk_18 = 0; } } if (D_EBFBE0_801CD954 == 2) { Math_SmoothStepToF(&D_EBFBE0_801AFFF8, 20.0f, 0.05f, 100.0f, 0.1f); } if (D_EBFBE0_801CD954 == 1) { Math_SmoothStepToF(&D_EBFBE0_801B0000, 15.0f, 0.05f, 100.0f, 0.1f); } D_EBFBE0_801CD970 -= 16; if (D_EBFBE0_801CD970 < 0) { D_EBFBE0_801CD970 = 0; } func_800182F4(0x102D00FF); func_800182F4(0x112D00FF); } void func_EBFBE0_801A281C(void) { D_80178348 = 0; D_80178350 = 0; D_80178354 = 0; D_80178340 = 255; D_EBFBE0_801CD988 = 5; D_EBFBE0_801CEED8 = 0; D_EBFBE0_801CEEDC = 0.0f; D_EBFBE0_801CEEE0 = 0.04f; D_EBFBE0_801CEEE8[0].x = D_EBFBE0_801CEEE8[1].x = D_EBFBE0_801CD9F4; D_EBFBE0_801CEEE8[0].y = D_EBFBE0_801CEEE8[1].y = D_EBFBE0_801CD9F8; D_EBFBE0_801CEEE8[0].z = D_EBFBE0_801CEEE8[1].z = D_EBFBE0_801CD9FC; D_EBFBE0_801CEF58[0].x = D_EBFBE0_801CEF58[1].x = D_EBFBE0_801CDA00; D_EBFBE0_801CEF58[0].y = D_EBFBE0_801CEF58[1].y = D_EBFBE0_801CDA04; D_EBFBE0_801CEF58[0].z = D_EBFBE0_801CEF58[1].z = D_EBFBE0_801CDA08; D_EBFBE0_801CEF58[5].x = D_EBFBE0_801CEF58[4].x = D_EBFBE0_801CEF58[3].x = D_EBFBE0_801CEF58[2].x = planet[D_EBFBE0_801CD958].posX; D_EBFBE0_801CEF58[5].y = D_EBFBE0_801CEF58[4].y = D_EBFBE0_801CEF58[3].y = D_EBFBE0_801CEF58[2].y = planet[D_EBFBE0_801CD958].posY; D_EBFBE0_801CEF58[5].z = D_EBFBE0_801CEF58[4].z = D_EBFBE0_801CEF58[3].z = D_EBFBE0_801CEF58[2].z = planet[D_EBFBE0_801CD958].posZ; D_EBFBE0_801CDA0C = -46.5f; D_EBFBE0_801CDA10 = 0.0f; D_EBFBE0_801CDA14 = 500.0f; func_EBFBE0_801AD718(D_EBFBE0_801CEF58[2].x, D_EBFBE0_801CEF58[2].y, D_EBFBE0_801CEF58[2].z, &D_EBFBE0_801CEEE8[2].x, &D_EBFBE0_801CEEE8[2].y, &D_EBFBE0_801CEEE8[2].z, D_EBFBE0_801CDA14, D_EBFBE0_801CDA0C, D_EBFBE0_801CDA10); D_EBFBE0_801CEEE8[5].x = D_EBFBE0_801CEEE8[4].x = D_EBFBE0_801CEEE8[3].x = D_EBFBE0_801CEEE8[2].x; D_EBFBE0_801CEEE8[5].y = D_EBFBE0_801CEEE8[4].y = D_EBFBE0_801CEEE8[3].y = D_EBFBE0_801CEEE8[2].y; D_EBFBE0_801CEEE8[5].z = D_EBFBE0_801CEEE8[4].z = D_EBFBE0_801CEEE8[3].z = D_EBFBE0_801CEEE8[2].z; D_EBFBE0_801CEF58[7].x = D_EBFBE0_801CEF58[6].x = -150.552155f; D_EBFBE0_801CEF58[7].y = D_EBFBE0_801CEF58[6].y = -489.679993f; D_EBFBE0_801CEF58[7].z = D_EBFBE0_801CEF58[6].z = 0.0f; D_EBFBE0_801CDA0C = -42.750008f; D_EBFBE0_801CDA10 = -9.849999f; D_EBFBE0_801CDA14 = 3375.000000f; func_EBFBE0_801AD718(D_EBFBE0_801CEF58[6].x, D_EBFBE0_801CEF58[6].y, D_EBFBE0_801CEF58[6].z, &D_EBFBE0_801CEEE8[6].x, &D_EBFBE0_801CEEE8[6].y, &D_EBFBE0_801CEEE8[6].z, D_EBFBE0_801CDA14, D_EBFBE0_801CDA0C, D_EBFBE0_801CDA10); D_EBFBE0_801CEEE8[7].x = D_EBFBE0_801CEEE8[6].x; D_EBFBE0_801CEEE8[7].y = D_EBFBE0_801CEEE8[6].y; D_EBFBE0_801CEEE8[7].z = D_EBFBE0_801CEEE8[6].z; D_EBFBE0_801CEECC = func_EBFBE0_801A655C(D_EBFBE0_801CD954, D_EBFBE0_801CD958); if (D_EBFBE0_801CD93C == 2) { D_80177BD8[D_EBFBE0_801CEECC] = 5; D_EBFBE0_801AFD18[D_EBFBE0_801CEECC].unk_14 = 5; } else { D_80177BD8[D_EBFBE0_801CEECC] = 2; D_EBFBE0_801AFD18[D_EBFBE0_801CEECC].unk_14 = 1; } } // needs D_EBFBE0_801CD900 to be static #ifdef IMPORT_DATA void func_EBFBE0_801A2B8C(void) { s32 i; switch (D_EBFBE0_801CD94C) { case 0: func_EBFBE0_801A281C(); D_EBFBE0_801CD94C = 100; break; case 100: if (D_80178340 != 0) { D_80178340 -= 64; if (D_80178340 < 0) { D_80178340 = 0; } } else { D_EBFBE0_801CD9C0 = 30; if ((D_EBFBE0_801CD98C == 1) || (D_EBFBE0_801CD980 == 1)) { D_80178348 = 255; D_80178350 = 255; D_80178354 = 255; D_80178340 = 0; D_EBFBE0_801CD984 = 0; D_EBFBE0_801CD94C = 10; break; } D_EBFBE0_801CD9C4 = 0; D_EBFBE0_801CD94C = 1; } break; case 10: if (D_EBFBE0_801CD9C0 != 0) { break; } if ((D_EBFBE0_801CD984 == 255) && (D_80178340 == 0)) { D_EBFBE0_801CD980 = 0; D_EBFBE0_801CD9C0 = 30; D_EBFBE0_801CD94C = 20; } else if (D_EBFBE0_801CD988 != 0) { D_80178340 ^= 255; D_EBFBE0_801CD988--; } else { D_EBFBE0_801CD988 = 0; if (D_80178340 != 0) { D_80178340 -= 21; if (D_80178340 < 0) { D_80178340 = 0; } } D_EBFBE0_801CD984 += 8; if (D_EBFBE0_801CD984 > 255) { D_80178340 = 0; D_EBFBE0_801CD984 = 255; } } break; case 20: if (D_EBFBE0_801CD9C0 != 0) { break; } if ((D_EBFBE0_801CD98C == 1) || (D_EBFBE0_801CD980 == 1)) { break; } D_EBFBE0_801CD9C4 = 0; D_EBFBE0_801CD9C0 = 30; D_EBFBE0_801CD94C = 1; break; case 1: if (D_EBFBE0_801CD9C0 != 0) { break; } func_EBFBE0_801A2EB8(); break; case 2: if (D_EBFBE0_801CD9C0 != 0) { break; } for (i = 0; i < 15; i++) { D_EBFBE0_801CD900[i] = 255; } D_EBFBE0_801CD9C0 = 0; D_EBFBE0_801CD94C++; break; case 3: if (D_EBFBE0_801CD9C0 != 0) { break; } D_EBFBE0_801CEFC8 = 1; D_EBFBE0_801CD97C = 1; D_EBFBE0_801CD94C = 0; D_EBFBE0_801CD944 = 3; break; } func_800B6F50(D_EBFBE0_801CD9F4, D_EBFBE0_801CD9F8, D_EBFBE0_801CD9FC, D_EBFBE0_801CDA00, D_EBFBE0_801CDA04, D_EBFBE0_801CDA08); D_EBFBE0_801CD9C4++; } #else #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A2B8C.s") #endif #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A2EB8.s") void func_EBFBE0_801A3440(f32 arg0) { Vec3f vec[2]; if (D_EBFBE0_801CEED8 != -1) { func_EBFBE0_801A3550(vec, &D_EBFBE0_801CEEE8[D_EBFBE0_801CEED8], &D_EBFBE0_801CEF58[D_EBFBE0_801CEED8], D_EBFBE0_801CEEDC); D_EBFBE0_801CD9F4 = vec[0].x; D_EBFBE0_801CD9F8 = vec[0].y; D_EBFBE0_801CD9FC = vec[0].z; D_EBFBE0_801CDA00 = vec[1].x; D_EBFBE0_801CDA04 = vec[1].y; D_EBFBE0_801CDA08 = vec[1].z; D_EBFBE0_801CEEDC += arg0; if (D_EBFBE0_801CEEDC > 1.0f) { D_EBFBE0_801CEED8++; D_EBFBE0_801CEEDC = 0.0f; if (D_EBFBE0_801CEED8 >= 6) { D_EBFBE0_801CEED8 = -1; } } } } void func_EBFBE0_801A3550(Vec3f* arg0, Vec3f* arg1, Vec3f* arg2, f32 arg3) { f32 temp_fa1; f32 temp_fs0; f32 temp_ft5; temp_fa1 = 0.5f * ((1.0f - arg3) * (1.0f - arg3)); temp_fs0 = (-arg3 + 1.0f) * arg3 + 0.5f; temp_ft5 = SQ(arg3) * 0.5f; arg0->x = (temp_fa1 * arg1->x) + (temp_fs0 * (arg1 + 1)->x) + (temp_ft5 * (arg1 + 2)->x); arg0->y = (temp_fa1 * arg1->y) + (temp_fs0 * (arg1 + 1)->y) + (temp_ft5 * (arg1 + 2)->y); arg0->z = (temp_fa1 * arg1->z) + (temp_fs0 * (arg1 + 1)->z) + (temp_ft5 * (arg1 + 2)->z); (arg0 + 1)->x = (temp_fa1 * arg2->x) + (temp_fs0 * (arg2 + 1)->x) + (temp_ft5 * (arg2 + 2)->x); (arg0 + 1)->y = (temp_fa1 * arg2->y) + (temp_fs0 * (arg2 + 1)->y) + (temp_ft5 * (arg2 + 2)->y); (arg0 + 1)->z = (temp_fa1 * arg2->z) + (temp_fs0 * (arg2 + 1)->z) + (temp_ft5 * (arg2 + 2)->z); } #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A36A8.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A3A00.s") void func_EBFBE0_801A4394(void) { s32 i; switch (D_EBFBE0_801CD94C) { case 0: if (D_80177B48 == 0) { D_EBFBE0_801CD9C0 = 45; D_EBFBE0_801CD94C = 3; } else { D_EBFBE0_801CD94C++; } break; case 1: if (D_80177B48 == D_EBFBE0_801CD9AC) { D_EBFBE0_801CD94C = 3; D_EBFBE0_801CD9C0 = 45; break; } if ((D_EBFBE0_801AFD18[D_EBFBE0_801CD8E0[D_EBFBE0_801CD9AC]].unk_00 == 3) || (D_EBFBE0_801AFD18[D_EBFBE0_801CD8E0[D_EBFBE0_801CD9AC]].unk_00 == 4)) { D_80177BD8[D_EBFBE0_801CD8E0[D_EBFBE0_801CD9AC]] = 5; D_EBFBE0_801AFD18[D_EBFBE0_801CD8E0[D_EBFBE0_801CD9AC]].unk_14 = 5; } else { D_80177BD8[D_EBFBE0_801CD8E0[D_EBFBE0_801CD9AC]] = 2; D_EBFBE0_801AFD18[D_EBFBE0_801CD8E0[D_EBFBE0_801CD9AC]].unk_14 = 0; } D_EBFBE0_801AFD18[D_EBFBE0_801CD8E0[D_EBFBE0_801CD9AC]].unk_18 = 255; D_EBFBE0_801CEEAC = 255; D_EBFBE0_801CEEA8 = 255; D_EBFBE0_801CD94C++; break; case 2: if ((D_80177BD8[D_EBFBE0_801CD8E0[D_EBFBE0_801CD9AC]] == 3) || (D_80177BD8[D_EBFBE0_801CD8E0[D_EBFBE0_801CD9AC]] == 6)) { D_EBFBE0_801CD9AC++; D_EBFBE0_801CD94C = 1; } break; case 3: if (D_EBFBE0_801CD9C0) { break; } for (i = 0; i < 8; i++) { D_EBFBE0_801CF020[i] = D_EBFBE0_801B69D4[i]; D_EBFBE0_801CF040[i] = D_EBFBE0_801B69F4[i]; D_EBFBE0_801CF060[i] = D_EBFBE0_801B6A14[i]; } D_EBFBE0_801CD978 = 1; D_EBFBE0_801CF120 = 1; D_EBFBE0_801CF11C = 1; D_EBFBE0_801CF0C8 = D_EBFBE0_801B6A34[1]; D_EBFBE0_801CF0CC = D_EBFBE0_801B6A3C[1]; D_EBFBE0_801CF0D0 = D_EBFBE0_801B6A44[1]; D_EBFBE0_801CF080 = 1.0f; D_EBFBE0_801CD9C0 = 450; D_EBFBE0_801CD94C = 0; D_EBFBE0_801CD948 = 1; break; } } #ifndef IMPORT_DATA extern Gfx* D_EBFBE0_801B6A4C[]; // likely in-function static #endif void func_EBFBE0_801A4650(void) { s32 i; #ifdef IMPORT_DATA static Gfx* D_EBFBE0_801B6A4C[] = { (Gfx*) 0x09006AE0, (Gfx*) 0x090086F0, (Gfx*) 0x09005380, (Gfx*) 0x090075A0, (Gfx*) 0x09000570, (Gfx*) 0x09002EA0, (Gfx*) 0x090075A0, (Gfx*) 0x09004230, }; #endif Lights_SetOneLight(&gMasterDisp, 0, 0, 127, 28, 58, 105, 65, 70, 48); RCP_SetupDL(&gMasterDisp, 0x17); gSPTexture(gMasterDisp++, 2500, 200, 0, G_TX_RENDERTILE, G_ON); gSPSetGeometryMode(gMasterDisp++, G_TEXTURE_GEN); Matrix_Push(&gGfxMatrix); Matrix_LookAt(gGfxMatrix, 0.0f, 0.0f, 500.0f, 0.0f, 0.0f, -500.0f, 0.0f, 1.0f, 0.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); for (i = 0; i < 8; i++) { Matrix_Push(&gGfxMatrix); Matrix_Translate(gGfxMatrix, D_EBFBE0_801CF020[i], D_EBFBE0_801CF040[i], D_EBFBE0_801CF060[i], 1); Matrix_RotateY(gGfxMatrix, M_DTOR * D_EBFBE0_801CF0A8[i], 1); Matrix_RotateX(gGfxMatrix, M_DTOR * D_EBFBE0_801CF088[i], 1); Matrix_Scale(gGfxMatrix, D_EBFBE0_801CF080, D_EBFBE0_801CF080, D_EBFBE0_801CF080, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_EBFBE0_801B6A4C[i]); Matrix_Pop(&gGfxMatrix); } Matrix_Pop(&gGfxMatrix); } void func_EBFBE0_801A48C0(f32 speed) { f32 x; f32 y; f32 z; f32 temp; f32 angle; Math_SmoothStepToF(&D_EBFBE0_801CDA34, D_EBFBE0_801CDA50.x, speed, 100.0f, 0.1f); Math_SmoothStepToF(&D_EBFBE0_801CDA38, D_EBFBE0_801CDA50.y, speed, 100.0f, 0.1f); Math_SmoothStepToF(&D_EBFBE0_801CD9FC, D_EBFBE0_801CDA50.z, speed, 100.0f, 0.1f); x = D_EBFBE0_801CDA50.x - D_EBFBE0_801CDA34; y = D_EBFBE0_801CDA50.y - D_EBFBE0_801CDA38; z = D_EBFBE0_801CDA50.z - D_EBFBE0_801CD9FC; temp = sqrtf(SQ(x) + SQ(y) + SQ(z)); angle = M_DTOR * ((1 - (temp / D_EBFBE0_801CEA68)) * 180.0f); D_EBFBE0_801CD9F4 = D_EBFBE0_801CDA34 * (1 + __sinf(angle) * 1.1f); D_EBFBE0_801CD9F8 = D_EBFBE0_801CDA38 * (1 + __sinf(angle) * 1.3f); } void func_EBFBE0_801A4A38(f32 arg0) { Math_SmoothStepToF(&D_EBFBE0_801CDA2C, D_EBFBE0_801CDA40.x, arg0, 100.0f, 0.1f); Math_SmoothStepToF(&D_EBFBE0_801CDA30, D_EBFBE0_801CDA40.y, arg0, 100.0f, 0.1f); Math_SmoothStepToF(&D_EBFBE0_801CDA08, D_EBFBE0_801CDA40.z, arg0, 100.0f, 0.1f); D_EBFBE0_801CDA00 = D_EBFBE0_801CDA2C; D_EBFBE0_801CDA04 = D_EBFBE0_801CDA30; } void func_EBFBE0_801A4AE8(void) { s32 var_a0; s32 i; switch (D_EBFBE0_801CD94C) { case 0: func_EBFBE0_801A4D7C(); break; case 1: if (D_EBFBE0_801CF000[D_EBFBE0_801CEFDC] == 0) { if (D_EBFBE0_801CEFD0 != 0) { if (gLifeCount[gPlayerNum] != 0) { func_8001D520(); D_EBFBE0_801CD9CC = 1; D_EBFBE0_801CD9D0 = 0; D_EBFBE0_801CD9B8 = 120; } else { D_EBFBE0_801CD9D4 = 1; D_EBFBE0_801CD9B8 = 0; } } else { D_EBFBE0_801CD9B8 = 0; } D_EBFBE0_801CEFC4 = 0; D_EBFBE0_801CD94C = 2; } break; case 2: if ((D_EBFBE0_801CD9CC != 0) && (D_EBFBE0_801CD9B8 == 110)) { gLifeCount[gPlayerNum]--; } if (D_EBFBE0_801CD9B8 == 0) { D_EBFBE0_801CD9CC = 0; var_a0 = D_EBFBE0_801CEFDC; if (D_EBFBE0_801CD93C != 0) { var_a0 += 2; } func_EBFBE0_801A4D0C(var_a0); if (D_EBFBE0_801CEFDC == 0) { for (i = 0; i < 6; i++) { D_80177C58[i] = gTeamShields[i]; } D_EBFBE0_801CEFC8 = 0; D_EBFBE0_801CD948 = 0; D_EBFBE0_801CD944 = 2; } else { D_EBFBE0_801CD944 = 3; } D_EBFBE0_801CD94C = 0; } break; } } void func_EBFBE0_801A4D0C(u32 arg0) { switch (arg0) { case 1: case 4: if (D_EBFBE0_801CD9D4 != 0) { func_EBFBE0_801A4F8C(); } else { func_EBFBE0_801A4FC4(); } break; case 3: func_EBFBE0_801A53C8(); case 0: case 2: break; } } void func_EBFBE0_801A4D7C(void) { f32 temp; if (func_EBFBE0_801A5770() != 0) { D_EBFBE0_801CEFE8[D_EBFBE0_801CEFDC] = 255.0f; if (D_EBFBE0_801CD93C != 0) { if (D_EBFBE0_801CEFD4 < 0) { D_EBFBE0_801CEFDC++; if (D_EBFBE0_801CEFDC >= 3) { D_EBFBE0_801CEFDC = 0; } } else { D_EBFBE0_801CEFDC--; if (D_EBFBE0_801CEFDC < 0) { D_EBFBE0_801CEFDC = 2; } } } else { D_EBFBE0_801CEFDC ^= 1; } } temp = Math_SmoothStepToF(&D_EBFBE0_801CEFE8[D_EBFBE0_801CEFDC], D_EBFBE0_801CEFE0, 0.5f, 100.0f, 1.0f); if (temp == 0.0f) { if (D_EBFBE0_801CEFE0 == 32.0f) { D_EBFBE0_801CEFE0 = 255.0f; } else { D_EBFBE0_801CEFE0 = 32.0f; } } if (gControllerPress[gMainController].button & (B_BUTTON | START_BUTTON)) { func_8001D6DC(0); D_EBFBE0_801CEFC4 = 0; D_EBFBE0_801CD944 = 3; return; } if (gControllerPress[gMainController].button & A_BUTTON) { func_8001D6DC(0); Audio_PlaySfx(0x49000003U, &D_800C5D28, 4U, &D_800C5D34, &D_800C5D34, &D_800C5D3C); D_EBFBE0_801CF000[D_EBFBE0_801CEFDC] = 10; if (((D_EBFBE0_801CD93C != 0) && (D_EBFBE0_801CEFDC == 2)) || ((D_EBFBE0_801CD93C == 0) && (D_EBFBE0_801CEFDC == 1))) { D_EBFBE0_801CEFD0 = 1; D_EBFBE0_801CF00C = 10; } D_EBFBE0_801CD94C = 1; } } void func_EBFBE0_801A4F8C(void) { D_80178410 = 0; gGameState = 5; D_80177868 = 0; D_Timer_8017783C = 2; gDrawMode = DRAWMODE_0; } #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A4FC4.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A53C8.s") s32 func_EBFBE0_801A5770(void) { bool ret = false; s8 y = gControllerPress[gMainController].stick_y; if ((y > -40) && (y < 40)) { y = 0; } if (y != 0) { if (D_EBFBE0_801CEFD4 == 0) { ret = true; } D_EBFBE0_801CEFD4 = y; } else { D_EBFBE0_801CEFD4 = 0; } if (ret) { Audio_PlaySfx(0x49000002, &D_800C5D28, 4, &D_800C5D34, &D_800C5D34, &D_800C5D3C); } return ret; } #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A5834.s") void func_EBFBE0_801A5C90(void) { s32 pad[3]; f32 scale; if (D_EBFBE0_801CD9CC != 0) { if (gLifeCount[gPlayerNum] < 10) { scale = 0.13f; } else { scale = 0.18f; } switch (D_EBFBE0_801CD9CC) { case 1: D_EBFBE0_801CD9C0 = 2; D_EBFBE0_801CD9CC = 2; break; case 2: if (D_EBFBE0_801CD9C0 != 0) { break; } if ((D_EBFBE0_801CD9D0 + 1) > 3) { D_EBFBE0_801CD9D0 = 0; D_EBFBE0_801CD9CC = 0; } else { D_EBFBE0_801CD9D0++; D_EBFBE0_801CD9CC = 1; } break; } Matrix_Push(&gGfxMatrix); Matrix_LookAt(gGfxMatrix, 0.0f, 0.0f, 100.0f, 0.0f, 0.0f, 0.0f, 0.0f, 1.0f, 0.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); RCP_SetupDL(&gMasterDisp, 0x35); Matrix_Push(&gGfxMatrix); Matrix_Translate(gGfxMatrix, 45.0f, 32.0f, 0.01f, 1); Matrix_Scale(gGfxMatrix, scale, scale, scale, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_EBFBE0_801AF824[D_EBFBE0_801CD9D0]); Matrix_Pop(&gGfxMatrix); } } void func_EBFBE0_801A5E80(void) { switch (D_EBFBE0_801B8280) { case 0: D_EBFBE0_801B8284 = 0; D_EBFBE0_801CD9A0 = 1; func_EBFBE0_801A6368(); D_EBFBE0_801CD9A8 = func_EBFBE0_801A62FC(D_EBFBE0_801CD954); func_EBFBE0_801AB284(); D_EBFBE0_801B8280++; break; case 1: if ((gControllerPress[gMainController].button & START_BUTTON) && !(D_EBFBE0_801CD9A8)) { func_8001A838(0x4100001EU); func_8001AE58(); D_EBFBE0_801CF018 = 0; D_EBFBE0_801B8280 = 2; D_EBFBE0_801CD9B8 = 0; } if ((gControllerPress[gMainController].button & A_BUTTON) && (D_EBFBE0_801CD9A0 == 0) && !(D_EBFBE0_801CD9A8)) { func_8001AE58(); D_Timer_801782AC = 0; } if ((gControllerPress[gMainController].button & A_BUTTON) && (D_EBFBE0_801CD9A0 == 1) && !(D_EBFBE0_801CD9A8)) { D_EBFBE0_801CD9A0 = 0; } if (D_EBFBE0_801CF018 == 7) { D_EBFBE0_801CD9B8 = 5; D_EBFBE0_801B8280++; } break; case 2: if (D_EBFBE0_801CD9B8 != 0) { break; } if (D_EBFBE0_801B8284 < 120) { D_EBFBE0_801B8284 += 15; if (D_EBFBE0_801CD954 == PLANET_CORNERIA) { *D_EBFBE0_801CEB48 = 0; } } else { D_EBFBE0_801CD9B8 = 5; D_EBFBE0_801CF018 = 0; D_EBFBE0_801B8280 += 1; } break; case 3: if (D_EBFBE0_801CD9B8 == 0) { D_EBFBE0_801CD9B8 = 5; D_EBFBE0_801CD968 = 1; D_EBFBE0_801B8280 += 1; } break; case 4: if (D_EBFBE0_801CD9B8 == 0) { Audio_PlaySfx(0x49002016U, &D_800C5D28, 4U, &D_800C5D34, &D_800C5D34, &D_800C5D3C); D_EBFBE0_801CD9B8 = 75; D_EBFBE0_801B8280++; } break; case 5: if (D_EBFBE0_801CD9B8 == 0) { func_EBFBE0_801A61B4(gCurrentLevel); D_EBFBE0_801B8280 = 0; D_EBFBE0_801CD968 = 0; func_EBFBE0_801A6628(); } break; } } void func_EBFBE0_801A61B4(LevelId level) { switch (level) { case LEVEL_CORNERIA: func_8001DC6C(0, 0); break; case LEVEL_METEO: func_8001DC6C(0, 1); break; case LEVEL_TITANIA: func_8001DC6C(0, 2); break; case LEVEL_AQUAS: func_8001DC6C(0, 12); break; case LEVEL_BOLSE: func_8001DC6C(0, 10); break; case LEVEL_KATINA: func_8001DC6C(0, 11); break; case LEVEL_AREA_6: func_8001DC6C(0, 5); break; case LEVEL_SECTOR_Z: func_8001DC6C(0, 13); break; case LEVEL_FORTUNA: func_8001DC6C(0, 8); break; case LEVEL_SECTOR_X: func_8001DC6C(0, 3); break; case LEVEL_MACBETH: func_8001DC6C(0, 14); break; case LEVEL_ZONESS: func_8001DC6C(0, 4); break; case LEVEL_SECTOR_Y: func_8001DC6C(0, 7); break; case LEVEL_SOLAR: func_8001DC6C(0, 521); default: break; } } bool func_EBFBE0_801A62FC(PlanetId planet) { u32 planetSaveSlot; s32 ret = true; switch (planet) { case PLANET_METEO: case PLANET_AREA_6: case PLANET_BOLSE: case PLANET_SECTOR_Z: case PLANET_SECTOR_X: case PLANET_SECTOR_Y: case PLANET_KATINA: case PLANET_MACBETH: case PLANET_ZONESS: case PLANET_CORNERIA: case PLANET_TITANIA: case PLANET_AQUAS: case PLANET_FORTUNA: planetSaveSlot = planet; break; case PLANET_SOLAR: planetSaveSlot = SAVE_SLOT_SOLAR; break; } if (gSaveFile.save.data.planet[planetSaveSlot].played & 1) { ret = false; } return ret; } void func_EBFBE0_801A6368(void) { switch (D_EBFBE0_801CD954) { case PLANET_CORNERIA: gCurrentLevel = LEVEL_CORNERIA; break; case PLANET_METEO: gCurrentLevel = LEVEL_METEO; break; case PLANET_TITANIA: gCurrentLevel = LEVEL_TITANIA; break; case PLANET_AQUAS: gCurrentLevel = LEVEL_AQUAS; break; case PLANET_BOLSE: gCurrentLevel = LEVEL_BOLSE; break; case PLANET_KATINA: gCurrentLevel = LEVEL_KATINA; break; case PLANET_AREA_6: gCurrentLevel = LEVEL_AREA_6; break; case PLANET_SECTOR_Z: gCurrentLevel = LEVEL_SECTOR_Z; break; case PLANET_FORTUNA: gCurrentLevel = LEVEL_FORTUNA; break; case PLANET_SECTOR_X: gCurrentLevel = LEVEL_SECTOR_X; break; case PLANET_MACBETH: gCurrentLevel = LEVEL_MACBETH; break; case PLANET_ZONESS: gCurrentLevel = LEVEL_ZONESS; break; case PLANET_SECTOR_Y: gCurrentLevel = LEVEL_SECTOR_Y; break; case PLANET_VENOM: gCurrentLevel = LEVEL_VENOM_1; break; case PLANET_SOLAR: gCurrentLevel = LEVEL_SOLAR; default: break; } } PlanetId GetPlanetId(LevelId level) { PlanetId planet; switch (level) { case LEVEL_CORNERIA: planet = PLANET_CORNERIA; break; case LEVEL_METEO: planet = PLANET_METEO; break; case LEVEL_TITANIA: planet = PLANET_TITANIA; break; case LEVEL_AQUAS: planet = PLANET_AQUAS; break; case LEVEL_BOLSE: planet = PLANET_BOLSE; break; case LEVEL_KATINA: planet = PLANET_KATINA; break; case LEVEL_AREA_6: planet = PLANET_AREA_6; break; case LEVEL_SECTOR_Z: planet = PLANET_SECTOR_Z; break; case LEVEL_FORTUNA: planet = PLANET_FORTUNA; break; case LEVEL_SECTOR_X: planet = PLANET_SECTOR_X; break; case LEVEL_MACBETH: planet = PLANET_MACBETH; break; case LEVEL_ZONESS: planet = PLANET_ZONESS; break; case LEVEL_SECTOR_Y: planet = PLANET_SECTOR_Y; break; case LEVEL_VENOM_1: case LEVEL_VENOM_ANDROSS: case LEVEL_VENOM_2: planet = PLANET_VENOM; break; case LEVEL_SOLAR: planet = PLANET_SOLAR; } return planet; } s32 func_EBFBE0_801A655C(s32 arg0, s32 arg1) { s32 i; for (i = 0; i < 24; i++) { if ((D_EBFBE0_801AFD18[i].unk_04 == arg0) && (D_EBFBE0_801AFD18[i].unk_08 == arg1)) { break; } } return i; } void func_EBFBE0_801A659C(void) { func_8001A838(0x1100004C); func_8001A838(0x1100204C); if (D_EBFBE0_801CD954 != 9) { Audio_PlaySfx(0x49000003, &D_800C5D28, 4, &D_800C5D34, &D_800C5D34, &D_800C5D3C); } D_EBFBE0_801CEFC8 = 0; D_EBFBE0_801CD944 = 2; D_EBFBE0_801CD948 = 0; } void func_EBFBE0_801A6628(void) { gGameState = 7; D_Timer_8017783C = 2; D_80177854 = 0; gDrawMode = DRAWMODE_0; gHitCount = 0; func_800A5844(); D_80177CA0 = 0; D_80177CB0 = 0.0f; D_8017782C = 1; } void func_EBFBE0_801A6694(void) { s32 i; Vec3f dest; Vec3f src; src.x = 0.0f; src.y = 0.0f; src.z = 0.0f; for (i = 0; i < 15; i++) { Matrix_Push(&gGfxMatrix); Matrix_RotateY(gGfxMatrix, M_DTOR * planet[i].unk_1C, 1); Matrix_Translate(gGfxMatrix, planet[i].unk_04, planet[i].unk_08, 0.0f, 1); Matrix_RotateY(gGfxMatrix, M_DTOR * -planet[i].unk_1C, 1); func_EBFBE0_801AD048(); Matrix_SetGfxMtx(&gMasterDisp); Matrix_Copy(&D_EBFBE0_801CDA60[i], gGfxMatrix); Matrix_MultVec3f(gGfxMatrix, &src, &dest); planet[i].posX = dest.x; planet[i].posY = dest.y; planet[i].posZ = dest.z; Matrix_Pop(&gGfxMatrix); Matrix_Push(&gGfxMatrix); Matrix_LookAt(gGfxMatrix, D_EBFBE0_801CD9F4, D_EBFBE0_801CD9F8, D_EBFBE0_801CD9FC, D_EBFBE0_801CDA00, D_EBFBE0_801CDA04, D_EBFBE0_801CDA08, D_EBFBE0_801CDA20, D_EBFBE0_801CDA24, D_EBFBE0_801CDA28, 1); Matrix_Translate(gGfxMatrix, D_EBFBE0_801CEA58, D_EBFBE0_801CEA5C, D_EBFBE0_801CEA60, 1); Matrix_Mult(gGfxMatrix, &D_EBFBE0_801CDA60[i], 1); Matrix_SetGfxMtx(&gMasterDisp); Matrix_MultVec3f(gGfxMatrix, &src, &D_EBFBE0_801CE960[i]); Matrix_Pop(&gGfxMatrix); } } void func_EBFBE0_801A68E4(void) { s32 i; s32 j; s32 var_a0; for (i = 0; i < 14; i++) { for (j = i; j < 15; j++) { if (D_EBFBE0_801CE960[D_EBFBE0_801CD8A0[i]].z > D_EBFBE0_801CE960[D_EBFBE0_801CD8A0[j]].z) { var_a0 = D_EBFBE0_801CD8A0[i]; D_EBFBE0_801CD8A0[i] = D_EBFBE0_801CD8A0[j]; D_EBFBE0_801CD8A0[j] = var_a0; } } } } void func_EBFBE0_801A6A24(void) { switch (D_EBFBE0_801CD960) { case 0: if (D_80178340 != 0) { D_80178340 -= 5; } else { D_EBFBE0_801CD960 = 255; } break; case 1: if (D_80178340 != 255) { D_80178340 += 15; } else { D_EBFBE0_801CD960 = 255; } break; } } void func_EBFBE0_801A6A98(PlanetId planetId) { s32 mask; s32 temp; if ((planet[planetId].alpha == 0) && (planetId != D_EBFBE0_801CD954)) { return; } if ((planetId == D_EBFBE0_801CD954) && (D_EBFBE0_801CD944 == 2) && (D_EBFBE0_801CD95C != 0)) { mask = 0x00000001; } else { mask = 0xFFFFFFFF; } temp = func_EBFBE0_801A6DAC(planetId); func_EBFBE0_801A6EC0(planetId); func_EBFBE0_801A7D3C(planetId); Matrix_Push(&gGfxMatrix); if (gFrameCount & mask) { if (planetId == PLANET_TITANIA) { func_EBFBE0_801A791C(planetId); } if ((temp == 1) && (D_EBFBE0_801CE960[planetId].z > D_EBFBE0_801CEA18[planetId]) && (planetId != PLANET_AREA_6) && (planetId != PLANET_BOLSE)) { func_EBFBE0_801A7F1C(planetId); } func_EBFBE0_801A7230(planetId); if (planetId == PLANET_SOLAR) { func_EBFBE0_801A74F4(planetId); } if (planet[planetId].unk_28 == 4) { if (planetId != PLANET_VENOM) { if ((planetId != PLANET_AQUAS) && (planetId != PLANET_TITANIA)) { func_EBFBE0_801A7684(planetId); } func_EBFBE0_801A77B0(planetId); } if (planetId == PLANET_VENOM) { func_EBFBE0_801A7BEC(&D_EBFBE0_801CEEBC, 0.1f, 3.1f); func_EBFBE0_801A7BEC(&D_EBFBE0_801CEEC0, -0.1f, 2.9f); } } if (planetId == PLANET_TITANIA) { func_EBFBE0_801A7A84(planetId); } if (planetId == PLANET_CORNERIA && D_EBFBE0_801CEB48[0]) { func_EBFBE0_801A89BC(PLANET_CORNERIA, 0); } if (planetId == PLANET_KATINA && D_EBFBE0_801CEB48[1]) { func_EBFBE0_801A89BC(PLANET_KATINA, 1); } if (planetId == PLANET_SECTOR_Y && D_EBFBE0_801CEB48[2]) { func_EBFBE0_801A89BC(PLANET_SECTOR_Y, 2); } if ((temp == 1) && (D_EBFBE0_801CE960[planetId].z <= D_EBFBE0_801CEA18[planetId]) && (planetId != PLANET_AREA_6) && (planetId != PLANET_BOLSE)) { func_EBFBE0_801A7F1C(planetId); } if ((temp == 1) && ((planetId == PLANET_AREA_6) || (planetId == PLANET_BOLSE))) { func_EBFBE0_801A7F1C(planetId); } if (temp == 2) { func_EBFBE0_801A809C(planetId); } } Matrix_Pop(&gGfxMatrix); } s32 func_EBFBE0_801A6DAC(PlanetId planetId) { s32 ret; s32 planetSaveSlot; s32 var_v0; s32 var_a0; if (planetId == PLANET_VENOM) { if (gExpertMode) { var_v0 = gSaveFile.save.data.planet[SAVE_SLOT_VENOM_2].expertMedal & 1; var_a0 = gSaveFile.save.data.planet[SAVE_SLOT_VENOM_1].expertClear & 1 | gSaveFile.save.data.planet[SAVE_SLOT_VENOM_2].expertClear & 1; } else { var_v0 = gSaveFile.save.data.planet[SAVE_SLOT_VENOM_2].normalMedal & 1; var_a0 = gSaveFile.save.data.planet[SAVE_SLOT_VENOM_1].normalClear & 1 | gSaveFile.save.data.planet[SAVE_SLOT_VENOM_2].normalClear & 1; } } else { planetSaveSlot = planetId; if (planetId == PLANET_SOLAR) { planetSaveSlot = SAVE_SLOT_SOLAR; } if (gExpertMode) { var_v0 = gSaveFile.save.data.planet[planetSaveSlot].expertMedal & 1; var_a0 = gSaveFile.save.data.planet[planetSaveSlot].expertClear & 1; } else { var_v0 = gSaveFile.save.data.planet[planetSaveSlot].normalMedal & 1; var_a0 = gSaveFile.save.data.planet[planetSaveSlot].normalClear & 1; } } ret = 0; if (var_v0) { ret = 2; } else if (var_a0) { ret = 1; } return ret; } void func_EBFBE0_801A6EC0(PlanetId planetId) { f32 dirX; f32 dirY; f32 dirZ; Vec3f dst; Vec3f src; f32 x1; f32 y1; f32 x2; f32 y2; f32 z2; src.x = 0.0f; src.y = 0.0f; src.z = 0.0f; Matrix_Push(&gGfxMatrix); Matrix_Mult(gGfxMatrix, &D_EBFBE0_801CDA60[planetId], 1); if (planet[planetId].unk_28 == 2) { if (planetId == 2) { Matrix_RotateX(gGfxMatrix, M_DTOR * D_EBFBE0_801AFFF8, 1); Matrix_RotateY(gGfxMatrix, M_DTOR * D_EBFBE0_801AFFF4, 1); } else { Matrix_RotateX(gGfxMatrix, M_DTOR * D_EBFBE0_801B0000, 1); Matrix_RotateY(gGfxMatrix, M_DTOR * D_EBFBE0_801AFFFC, 1); } } Matrix_RotateZ(gGfxMatrix, M_DTOR * (planet[planetId].zAngle), 1); Matrix_Scale(gGfxMatrix, planet[planetId].scale, planet[planetId].scale, planet[planetId].scale, 1); Matrix_SetGfxMtx(&gMasterDisp); if (planet[planetId].unk_28 == 2) { x2 = D_EBFBE0_801CE960[14].x - D_EBFBE0_801CE960[planetId].x; y2 = D_EBFBE0_801CE960[14].y - D_EBFBE0_801CE960[planetId].y; z2 = D_EBFBE0_801CE960[14].z - D_EBFBE0_801CE960[planetId].z; x1 = Math_Atan2F(y2, sqrtf(SQ(x2) + SQ(z2))); y1 = -Math_Atan2F(x2, z2); src.x = 0.0f; src.y = 0.0f; src.z = 100.0f; Matrix_RotateY(gCalcMatrix, M_DTOR * (-D_EBFBE0_801CDA10 - y1), 0); Matrix_RotateX(gCalcMatrix, M_DTOR * (-D_EBFBE0_801CDA0C - x1), 1); Matrix_MultVec3f(gCalcMatrix, &src, &dst); dirX = dst.x; dirY = dst.y; dirZ = dst.z; Lights_SetOneLight(&gMasterDisp, dirX, dirY, dirZ, 80, 80, 60, 10, 10, 8); } Matrix_Copy(&D_EBFBE0_801CDE20[planetId], gGfxMatrix); Matrix_Pop(&gGfxMatrix); D_EBFBE0_801AFFF4 += 0.1f; D_EBFBE0_801AFFFC -= 0.09f; } void func_EBFBE0_801A7230(PlanetId planetId) { switch (planet[planetId].unk_28) { case 0: if ((D_EBFBE0_801CD944 == 3 || planetId == D_EBFBE0_801CD954 || planetId == D_EBFBE0_801CD958) && D_EBFBE0_801CD944 != 1 && D_EBFBE0_801CD944 != 7) { RCP_SetupDL(&gMasterDisp, 0x35); } else { RCP_SetupDL(&gMasterDisp, 0x29); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, planet[planetId].alpha); } break; case 2: if ((D_EBFBE0_801CD944 == 3 || planetId == D_EBFBE0_801CD954 || planetId == D_EBFBE0_801CD958) && D_EBFBE0_801CD944 != 1 && D_EBFBE0_801CD944 != 7) { RCP_SetupDL(&gMasterDisp, 0x17); } else { RCP_SetupDL(&gMasterDisp, 0x2E); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, planet[planetId].alpha); } break; case 1: case 4: RCP_SetupDL(&gMasterDisp, 0x40); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, planet[planetId].alpha); break; case 3: RCP_SetupDL(&gMasterDisp, 0x43); gDPSetPrimColor(gMasterDisp++, 0, 0, 240, 0, 0, planet[planetId].alpha); gDPSetEnvColor(gMasterDisp++, 31, 0, 0, 0); planet[planetId].zAngle += 0.1f; break; } Matrix_Push(&gGfxMatrix); Matrix_Copy(gGfxMatrix, &D_EBFBE0_801CDE20[planetId]); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_EBFBE0_801B68F8[planet[planetId].id]); Matrix_Pop(&gGfxMatrix); } #ifdef IMPORT_DATA void func_EBFBE0_801A74F4(s32 planetId) { static f32 D_EBFBE0_801B6A74 = 0.0f; s32 alpha = planet[13].alpha; if (planet[planetId].alpha > 128) alpha = 128; RCP_SetupDL(&gMasterDisp, 0x43); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, alpha); gDPSetEnvColor(gMasterDisp++, 0x1f, 0, 0, 0); Matrix_Push(&gGfxMatrix); Matrix_Copy(gGfxMatrix, &D_EBFBE0_801CDE20[planetId]); Matrix_RotateZ(gGfxMatrix, M_DTOR * D_EBFBE0_801B6A74, 1); Matrix_Scale(gGfxMatrix, 0.8f, 0.8f, 0.8f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_EBFBE0_801B68F8[planet[planetId].id]); Matrix_Pop(&gGfxMatrix); D_EBFBE0_801B6A74 -= 0.2f; } #else #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A74F4.s") #endif void func_EBFBE0_801A7684(PlanetId planetId) { s32 r; s32 g; s32 b; r = g = b = 255; if (planetId == 7) { r = g = b = 64; } RCP_SetupDL(&gMasterDisp, 0x40); gDPSetPrimColor(gMasterDisp++, 0, 0, r, g, b, planet[planetId].alpha); Matrix_Push(&gGfxMatrix); Matrix_Copy(gGfxMatrix, &D_EBFBE0_801CDE20[planetId]); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_EBFBE0_801B4A40); Matrix_Pop(&gGfxMatrix); } void func_EBFBE0_801A77B0(PlanetId planetId) { RCP_SetupDL(&gMasterDisp, 0x40); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, planet[planetId].alpha); Matrix_Push(&gGfxMatrix); Matrix_Copy(gGfxMatrix, &D_EBFBE0_801CDE20[planetId]); if ((planetId == 10) || (planetId == 7) || (planetId == 8)) { Matrix_RotateY(gGfxMatrix, M_DTOR * 180.0f, 1); } Matrix_RotateZ(gGfxMatrix, M_DTOR * planet[planetId].zAngle, 1); Matrix_Scale(gGfxMatrix, 1.6f, 1.6f, 1.6f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_605C230); Matrix_Pop(&gGfxMatrix); } void func_EBFBE0_801A791C(PlanetId planetId) { RCP_SetupDL(&gMasterDisp, 0x43); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 175, 175, planet[planetId].alpha); gDPSetEnvColor(gMasterDisp++, 73, 31, 15, 0); Matrix_Push(&gGfxMatrix); Matrix_Copy(gGfxMatrix, &D_EBFBE0_801CDE20[planetId]); Matrix_RotateZ(gGfxMatrix, M_DTOR * -planet[planetId].zAngle, 1); Matrix_RotateX(gGfxMatrix, M_DTOR * 20.0f, 1); Matrix_Scale(gGfxMatrix, 3.0f, 3.0f, 3.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_604C540); Matrix_Pop(&gGfxMatrix); } void func_EBFBE0_801A7A84(PlanetId planetId) { RCP_SetupDL(&gMasterDisp, 0x43); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 175, 175, planet[planetId].alpha); gDPSetEnvColor(gMasterDisp++, 0x49, 0x1f, 0x0f, 0); Matrix_Push(&gGfxMatrix); Matrix_Copy(gGfxMatrix, &D_EBFBE0_801CDE20[planetId]); Matrix_RotateZ(gGfxMatrix, M_DTOR * -planet[planetId].zAngle, 1); Matrix_RotateX(gGfxMatrix, M_DTOR * 20.0f, 1); Matrix_Scale(gGfxMatrix, 3.0f, 3.0f, 3.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_604CDE0); Matrix_Pop(&gGfxMatrix); } void func_EBFBE0_801A7BEC(f32* zAngle, f32 next, f32 scale) { s32 alpha = planet[13].alpha; if (planet[13].alpha > 128) { alpha = 128; } RCP_SetupDL(&gMasterDisp, 0x43); gDPSetPrimColor(gMasterDisp++, 0, 0, 63, 95, 30, alpha); gDPSetEnvColor(gMasterDisp++, 0, 0, 0, 0); Matrix_Push(&gGfxMatrix); Matrix_Copy(gGfxMatrix, &D_EBFBE0_801CDE20[13]); Matrix_RotateZ(gGfxMatrix, M_DTOR * (*zAngle), 1); Matrix_Scale(gGfxMatrix, scale, scale, scale, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_6047E70); Matrix_Pop(&gGfxMatrix); *zAngle += next; } void func_EBFBE0_801A7D3C(PlanetId planetId) { Vec3f src; Vec3f dest; f32 scale; src.x = 0.0f; src.y = 0.0f; src.z = 0.0f; scale = 7.0f + (Rand_ZeroOne() * 8.0f); Matrix_Push(&gGfxMatrix); Matrix_Mult(gGfxMatrix, &D_EBFBE0_801CDA60[planetId], 1); Matrix_RotateY(gGfxMatrix, M_DTOR * D_EBFBE0_801CEAF8[planetId], 1); Matrix_Translate(gGfxMatrix, D_EBFBE0_801AFFB8[planetId], 0.0f, 0.0f, 1); Matrix_RotateY(gGfxMatrix, M_DTOR * -D_EBFBE0_801CEAF8[planetId], 1); Matrix_SetGfxMtx(&gMasterDisp); Matrix_Copy(&D_EBFBE0_801CE5A0[planetId], gGfxMatrix); Matrix_RotateZ(gGfxMatrix, M_DTOR * D_EBFBE0_801CEAB8[planetId], 1); Matrix_Scale(gGfxMatrix, scale, scale, scale, 1); Matrix_MultVec3f(gGfxMatrix, &src, &dest); D_EBFBE0_801CEA18[planetId] = dest.z; Matrix_SetGfxMtx(&gMasterDisp); Matrix_Copy(&D_EBFBE0_801CE1E0[planetId], gGfxMatrix); Matrix_Pop(&gGfxMatrix); } void func_EBFBE0_801A7F1C(PlanetId planetId) { s32 alpha; if (D_EBFBE0_801CD980 != 1) { alpha = D_EBFBE0_801CD900[planetId]; } else { alpha = D_EBFBE0_801CD984; D_EBFBE0_801CD900[planetId] = 255; } if (alpha != 0) { RCP_SetupDL(&gMasterDisp, 0x43); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, alpha); gDPSetEnvColor(gMasterDisp++, 80, 80, 0, 0); Matrix_Push(&gGfxMatrix); Matrix_Copy(gGfxMatrix, &D_EBFBE0_801CE1E0[planetId]); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_604D680); Matrix_Pop(&gGfxMatrix); D_EBFBE0_801CEAB8[planetId] += 45.0f; if (D_EBFBE0_801CD980 == 0) { D_EBFBE0_801CEAF8[planetId] += 5.0f; } } } void func_EBFBE0_801A809C(PlanetId planetId) { #ifdef IMPORT_DATA static f32 D_EBFBE0_801B6A78 = 0.0f; #endif s32 i; s32 alpha; f32 scale; if (D_EBFBE0_801CD98C != 1) { alpha = D_EBFBE0_801CD900[planetId]; } else { alpha = D_EBFBE0_801CD984; D_EBFBE0_801CD900[planetId] = 255; } if (alpha == 0) { return; } if (D_EBFBE0_801CD98C == 1) { switch (D_EBFBE0_801CD990) { case 0: RCP_SetupDL(&gMasterDisp, 0x43); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, alpha); gDPSetEnvColor(gMasterDisp++, 80, 80, 0, 0); Matrix_Push(&gGfxMatrix); Matrix_Copy(gGfxMatrix, &D_EBFBE0_801CE1E0[planetId]); Matrix_Translate(gGfxMatrix, 0.0f, -30.0f, 0.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_604D680); Matrix_Pop(&gGfxMatrix); D_EBFBE0_801CEAB8[planetId] += 45.0f; if (alpha == 255) { D_EBFBE0_801CD9C8 = 15; D_EBFBE0_801CD998 = 0; D_EBFBE0_801CD994 = 255; D_EBFBE0_801CD99C = 0.0f; D_EBFBE0_801CD990++; } break; case 1: scale = 5.0f + (Rand_ZeroOne() * 4.0f); Math_SmoothStepToF(&D_EBFBE0_801CD99C, 150.0f, 0.09f, 100.0f, 0.1f); RCP_SetupDL(&gMasterDisp, 0x43); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, D_EBFBE0_801CD994); gDPSetEnvColor(gMasterDisp++, 80, 80, 0, 0); for (i = 0; i < 8; i++) { Matrix_Push(&gGfxMatrix); Matrix_Copy(gGfxMatrix, &D_EBFBE0_801CE5A0[planetId]); Matrix_Translate(gGfxMatrix, 0.0f, -30.0f, 0.0f, 1); Matrix_RotateZ(gGfxMatrix, M_DTOR * (i * -45.0f), 1); Matrix_Translate(gGfxMatrix, 0.0f, D_EBFBE0_801CD99C, 0.0f, 1); Matrix_RotateZ(gGfxMatrix, M_DTOR * (D_EBFBE0_801B6A78), 1); Matrix_Scale(gGfxMatrix, scale, scale, scale, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_604D680); Matrix_Pop(&gGfxMatrix); } D_EBFBE0_801B6A78 += 45.0f; D_EBFBE0_801CD994 -= 16; if (D_EBFBE0_801CD994 <= 0) { D_EBFBE0_801CD994 = 0; } RCP_SetupDL(&gMasterDisp, 0x40); gDPSetTextureFilter(gMasterDisp++, G_TF_POINT); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, D_EBFBE0_801CD998); Matrix_Push(&gGfxMatrix); Matrix_Copy(gGfxMatrix, &D_EBFBE0_801CE5A0[planetId]); Matrix_Translate(gGfxMatrix, 0.0f, -30.0f, 0.0f, 1); Matrix_Scale(gGfxMatrix, 3.0f, 3.0f, 3.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_601D1F0); Matrix_Pop(&gGfxMatrix); D_EBFBE0_801CEAF8[planetId] = -90.0f; D_EBFBE0_801CD998 += 8; if (D_EBFBE0_801CD998 == 8) { Audio_PlaySfx(0x49008030U, &D_800C5D28, 4U, &D_800C5D34, &D_800C5D34, &D_800C5D3C); } if (D_EBFBE0_801CD998 >= 255) { D_EBFBE0_801CD998 = 255; } if (D_EBFBE0_801CD998 == 255) { if (!D_EBFBE0_801CD9C8) { D_EBFBE0_801CD98C = 0; } else { D_EBFBE0_801CD9C8--; } } break; } } else { RCP_SetupDL(&gMasterDisp, 0x40); gDPSetTextureFilter(gMasterDisp++, G_TF_POINT); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, alpha); Matrix_Push(&gGfxMatrix); Matrix_Copy(gGfxMatrix, &D_EBFBE0_801CE5A0[planetId]); Matrix_Translate(gGfxMatrix, 0.0f, -30.0f, 0.0f, 1); Matrix_Scale(gGfxMatrix, 3.0f, 3.0f, 3.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_601D1F0); Matrix_Pop(&gGfxMatrix); D_EBFBE0_801CEAF8[planetId] = -90.0f; } } void func_EBFBE0_801A8738(void) { if (D_EBFBE0_801CEB34 >= 0) { RCP_SetupDL(&gMasterDisp, 0x43); gDPSetEnvColor(gMasterDisp++, 255, 0, 0, 0); switch (D_EBFBE0_801CEB34) { case 0: D_EBFBE0_801CEB3C += 0.15f; if (D_EBFBE0_801CEB3C >= 0.7f) { D_EBFBE0_801CEB3C = 0.8f; D_EBFBE0_801CEB34 = 2; D_EBFBE0_801CEB40 = 2.0f; } break; case 2: D_EBFBE0_801CEB40--; if (D_EBFBE0_801CEB40 <= 0.0f) { D_EBFBE0_801CEB34 = 3; D_EBFBE0_801CEB3C = 0.7f; } break; case 3: D_EBFBE0_801CEB38 -= 8; D_EBFBE0_801CEB3C -= 0.001f; if (D_EBFBE0_801CEB38 < 0) { D_EBFBE0_801CEB38 = 0; } if (D_EBFBE0_801CEB38 == 0) { D_EBFBE0_801CEB34 = 4; } break; } gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 200, 200, D_EBFBE0_801CEB38); Matrix_Push(&gGfxMatrix); Matrix_Copy(gGfxMatrix, &D_EBFBE0_801CE060); Matrix_RotateZ(gGfxMatrix, M_DTOR * -50.0f, 1); Matrix_Translate(gGfxMatrix, 0.0f, 25.0f, 0.0f, 1); Matrix_Scale(gGfxMatrix, D_EBFBE0_801CEB3C, D_EBFBE0_801CEB3C, D_EBFBE0_801CEB3C, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_60479D0); Matrix_Pop(&gGfxMatrix); } } #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A89BC.s") // needs in-function static #ifdef IMPORT_DATA void func_EBFBE0_801A8F40(void) { static f32 D_EBFBE0_801B6A7C = 0.0f; s32 temp; if (D_EBFBE0_801CD97C != 0) { Lights_SetOneLight(&gMasterDisp, 0, 0, 127, 80, 80, 60, 50, 50, 50); RCP_SetupDL(&gMasterDisp, 0x17); temp = Math_SmoothStepToF(&D_EBFBE0_801CEAA8, D_EBFBE0_801CEAB0, 0.1f, 100.0f, 1.0f); if (temp == 0.0f) { if (D_EBFBE0_801CEAB0 == D_EBFBE0_801CEAAC) { D_EBFBE0_801CEAA8 = D_EBFBE0_801CEAAC + 50.0f; } } Matrix_Push(&gGfxMatrix); Matrix_Mult(gGfxMatrix, &D_EBFBE0_801CDA60[D_EBFBE0_801CD954], 1); Matrix_Translate(gGfxMatrix, 0.0f, D_EBFBE0_801CEAA8, 0.0f, 1); Matrix_RotateY(gGfxMatrix, M_DTOR * D_EBFBE0_801B6A7C, 1); Matrix_Scale(gGfxMatrix, 3.0f, 3.0f, 3.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_601DCF0); Matrix_Pop(&gGfxMatrix); D_EBFBE0_801B6A7C += 6.0f; } } #else #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A8F40.s") #endif void func_EBFBE0_801A914C(void) { D_EBFBE0_801CEAA8 = 140.0f; if (D_EBFBE0_801CD954 == 9) { D_EBFBE0_801CEAA8 = 230.0f; } if (D_EBFBE0_801CD954 == 1) { D_EBFBE0_801CEAA8 = 210.0f; } if (D_EBFBE0_801CD954 == 0xE) { D_EBFBE0_801CEAA8 = 250.0f; } if (D_EBFBE0_801CD954 == 4) { D_EBFBE0_801CEAA8 = 150.0f; } if (D_EBFBE0_801CD954 == 5) { D_EBFBE0_801CEAA8 = 150.0f; } if (D_EBFBE0_801CD954 == 3) { D_EBFBE0_801CEAA8 = 150.0f; } if (D_EBFBE0_801CD954 == 0xD) { D_EBFBE0_801CEAA8 = 300.0f; } D_EBFBE0_801CEAAC = D_EBFBE0_801CEAA8; D_EBFBE0_801CEAB0 = D_EBFBE0_801CEAA8; } void func_EBFBE0_801A9224(void) { s32 i; s32 mask; if ((planet[PLANET_METEO].alpha != 0) || (D_EBFBE0_801CD954 == 0)) { if ((D_EBFBE0_801CD954 == 0) && (D_EBFBE0_801CD944 == 2) && (D_EBFBE0_801CD95C != 0)) { mask = 0x00000001; } else { mask = 0xFFFFFFFF; } if ((D_EBFBE0_801CD944 == 3) || ((D_EBFBE0_801CD954 == 0) && (D_EBFBE0_801CD944 != 7))) { RCP_SetupDL(&gMasterDisp, 0x35); } else { RCP_SetupDL(&gMasterDisp, 0x40); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, planet[PLANET_METEO].alpha); } if (gFrameCount & mask) { for (i = 0; i < 42; i++) { Matrix_Push(&gGfxMatrix); Matrix_RotateY(gGfxMatrix, M_DTOR * D_EBFBE0_801AFA38[i].angle, 1); Matrix_Translate(gGfxMatrix, D_EBFBE0_801AFA38[i].x, D_EBFBE0_801AFA38[i].y, 0.0f, 1); Matrix_RotateY(gGfxMatrix, M_DTOR * -D_EBFBE0_801AFA38[i].angle, 1); func_EBFBE0_801AD048(); Matrix_Scale(gGfxMatrix, D_EBFBE0_801AFA38[i].scale, D_EBFBE0_801AFA38[i].scale, D_EBFBE0_801AFA38[i].scale, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_EBFBE0_801B68F8[0]); Matrix_Pop(&gGfxMatrix); } } } } #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801A9448.s") void func_EBFBE0_801A9814(void) { if (D_EBFBE0_801B8280 != 0) { Matrix_Push(&gGfxMatrix); Matrix_LookAt(gGfxMatrix, D_EBFBE0_801CD9F4, D_EBFBE0_801CD9F8, D_EBFBE0_801CD9FC, D_EBFBE0_801CDA00, D_EBFBE0_801CDA04, D_EBFBE0_801CDA08, D_EBFBE0_801CDA20, D_EBFBE0_801CDA24, D_EBFBE0_801CDA28, 1); Matrix_Translate(gGfxMatrix, D_EBFBE0_801CEA58, D_EBFBE0_801CEA5C, D_EBFBE0_801CEA60, 1); Matrix_SetGfxMtx(&gMasterDisp); func_80084688(2, D_EBFBE0_801B8284); Matrix_Pop(&gGfxMatrix); } } void func_EBFBE0_801A9910(void) { s32 i; s32 var_s0; #ifdef IMPORT_DATA static s32 D_EBFBE0_801B6A84[] = { 1, 13, 12, 11, 6, 2, 4, 10, 8, 0, 9, 5, 3, 7, 7 }; #endif var_s0 = D_EBFBE0_801B6A84[D_EBFBE0_801CD954]; RCP_SetupDL(&gMasterDisp, 0x53); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, (s32) D_EBFBE0_801CEA6C); for (i = 0; i < D_EBFBE0_801AF834[var_s0].height; i++) { TextureRect_8bIA(&gMasterDisp, D_EBFBE0_801AF834[var_s0].addr + (D_EBFBE0_801AF834[var_s0].width * i), D_EBFBE0_801AF834[var_s0].width, 1, D_EBFBE0_801AF834[var_s0].posX, 20.0f + (1.0f * i), 1.0f, 1.0f); } Math_SmoothStepToF(&D_EBFBE0_801CEA6C, 255.0f, D_EBFBE0_801CEA70, 10.0f, 1.0f); D_EBFBE0_801CEA70 *= 1.08; } #ifndef IMPORT_DATA extern f32 D_EBFBE0_801B6AC0[2]; extern f32 D_EBFBE0_801B6AC8[2]; #endif void func_EBFBE0_801A9A8C(void) { s32 i; s32 sp58; u8* sp54; #ifdef IMPORT_DATA static f32 D_EBFBE0_801B6AC0[2] = { 91.0f, 207.0f }; static f32 D_EBFBE0_801B6AC8[2] = { 61.0f, 61.0f }; #endif switch (gCurrentLevel) { case LEVEL_CORNERIA: sp54 = D_500A050; sp58 = 0; break; case LEVEL_METEO: sp54 = D_500A140; sp58 = 1; break; case LEVEL_SECTOR_Y: sp54 = D_500A140; sp58 = 2; break; case LEVEL_FORTUNA: sp54 = D_500A230; sp58 = 3; break; case LEVEL_KATINA: sp54 = D_500A230; sp58 = 4; break; case LEVEL_AQUAS: sp54 = D_500A230; sp58 = 5; break; case LEVEL_SECTOR_X: sp54 = D_500A320; sp58 = 6; break; case LEVEL_SOLAR: sp54 = D_500A320; sp58 = 7; break; case LEVEL_ZONESS: sp54 = D_500A320; sp58 = 8; break; case LEVEL_TITANIA: sp54 = D_500A410; sp58 = 9; break; case LEVEL_MACBETH: sp54 = D_500A410; sp58 = 10; break; case LEVEL_SECTOR_Z: sp54 = D_500A410; sp58 = 11; break; case LEVEL_BOLSE: sp54 = D_500A500; sp58 = 12; break; case LEVEL_AREA_6: sp54 = D_500A500; sp58 = 13; break; } RCP_SetupDL(&gMasterDisp, 0x53); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, 255); TextureRect_8bIA(&gMasterDisp, &D_5000500, 112, 19, D_EBFBE0_801B6AC0[0], D_EBFBE0_801B6AC8[0], 1.0f, 1.0f); TextureRect_8bIA(&gMasterDisp, sp54, 16, 15, D_EBFBE0_801B6AC0[1], D_EBFBE0_801B6AC8[1], 1.0f, 1.0f); for (i = 0; i < D_EBFBE0_801AF834[sp58].height; i++) { TextureRect_8bIA(&gMasterDisp, D_EBFBE0_801AF834[sp58].addr + (D_EBFBE0_801AF834[sp58].width * i), D_EBFBE0_801AF834[sp58].width, 1, D_EBFBE0_801AF834[sp58].posX, 94.0f + (1.0f * i), 1.0f, 1.0f); } for (i = 0; i < D_EBFBE0_801AF914[sp58].height; i++) { TextureRect_8bIA(&gMasterDisp, D_EBFBE0_801AF914[sp58].addr + (D_EBFBE0_801AF914[sp58].width * i), D_EBFBE0_801AF914[sp58].width, 1, D_EBFBE0_801AF914[sp58].posX, 140.0f + (1.0f * i), 1.0f, 1.0f); } } void func_EBFBE0_801A9DE8(void) { s32 mask; if (!((D_EBFBE0_801CD978 != 0) || (D_EBFBE0_801CD944 == 3) || (D_EBFBE0_801CD944 == 6) || ((D_EBFBE0_801CD944 == 7) && (D_EBFBE0_801CD948 == 2)))) { return; } mask = 0xFFFFFFFF; if (D_EBFBE0_801CF00C != 0) { mask = 0x00000001; D_EBFBE0_801CF00C--; } if (gFrameCount & mask) { func_EBFBE0_801AD7EC(254, 16, gLifeCount[gPlayerNum]); } if ((D_80161A34 == 7) || (D_80161A34 == 5)) { if (D_EBFBE0_801CD83C < D_80161714) { D_EBFBE0_801CD83C = D_80161714; } func_EBFBE0_801A9EE4(); func_EBFBE0_801A9FD4(0); } } #ifndef IMPORT_DATA #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74C0.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74C4.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74C8.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74CC.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74D0.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74D4.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74D8.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74DC.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74E0.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74E4.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74E8.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74EC.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74F0.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74F4.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B74F8.s") #endif void func_EBFBE0_801A9EE4(void) { RCP_SetupDL(&gMasterDisp, 0x53); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 0, 255); Graphics_DisplaySmallText(24, 14, 1.0f, 1.0f, "TOTAL HITS"); Graphics_DisplaySmallNumber(71 - (func_8008BCBC(D_80161714) * 8), 24, D_80161714); Graphics_DisplaySmallText(143, 14, 1.0f, 1.0f, "TOP"); Graphics_DisplaySmallNumber(167 - (func_8008BCBC(D_EBFBE0_801CD83C) * 8), 24, D_EBFBE0_801CD83C); } void func_EBFBE0_801A9FD4(s32 arg0) { s32 i; s32 var_s3; f32 var_fs0, var_fs1; s32 pad[2]; f32 temp = 16.0f; if (arg0) { var_s3 = D_80177B48; } else { if ((D_80161A34 == 7) || (D_80161A34 == 8)) { var_s3 = D_80177B48; } if (D_80161A34 == 5) { var_s3 = D_EBFBE0_801CD9AC; } } func_EBFBE0_801AA1CC(var_s3); if ((D_80161A34 == 7) || (D_80161A34 == 8)) { var_s3 = 7; } if (D_80161A34 == 5) { var_s3++; } Matrix_Push(&gGfxMatrix); Matrix_LookAt(gGfxMatrix, 0.0f, 0.0f, 100.0f, 0.0f, 0.0f, 0.0f, 0.0f, 1.0f, 0.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); for (var_fs0 = 0.0f, var_fs1 = -41.5f, i = 0; i < var_s3; i++, var_fs0 += 24.0f + temp, var_fs1 += 13.8f) { if (D_80177B90[i] != -1) { func_EBFBE0_801AA434(i, 28.0f + var_fs0, 182.0f, D_80177B90[i]); func_EBFBE0_801AA778(i, var_fs1, -25.4f, D_80177B90[i]); } } Matrix_Pop(&gGfxMatrix); } void func_EBFBE0_801AA1CC(s32 arg0) { s32 i; f32 x; s32 r; s32 g; s32 b; s32 temp; f32 y = 182.0f; f32 x2 = 16.0f; s32* ptr = &D_80177B90[0]; for (x = 0.0f, i = 0; i < 7; i++, x += 24.0f + x2, ptr++) { RCP_SetupDL(&gMasterDisp, 0x53); if (i < 6) { r = g = b = 255; if (i < arg0) { temp = func_EBFBE0_801A655C(*ptr, *(ptr + 1)); switch (D_EBFBE0_801AFD18[temp].unk_00) { case 0: r = 16; g = 64; b = 255; break; case 1: case 3: r = 255; g = 175; b = 0; break; case 2: case 4: g = b = 0; break; } gDPSetPrimColor(gMasterDisp++, 0, 0, r, g, b, 255); } else { gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, 255); } TextureRect_16bRGBA(&gMasterDisp, D_60447A0, 8, 8, 28.0f + x + 24.0f, y + 11.0f, 2.0f, 0.2f); } gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, 255); TextureRect_16bRGBA(&gMasterDisp, D_6047550, 24, 24, 28.0f + x, y, 1.0f, 1.0f); } } #ifndef IMPORT_DATA extern char* D_EBFBE0_801AF9F4[15]; extern char* D_EBFBE0_801B6AD0[]; extern s32 D_EBFBE0_801B6ADC[]; extern s32 D_EBFBE0_801B6AE8[]; extern s32 D_EBFBE0_801B6AF4[]; #endif void func_EBFBE0_801AA434(s32 arg0, f32 x, f32 y, s32 pp) { s32 i; f32 x2; s32 pad; s32 mask; s32 temp; #ifdef IMPORT_DATA static char* D_EBFBE0_801B6AD0[] = { "P", "S", "F" }; static s32 D_EBFBE0_801B6ADC[] = { 255, 0, 30 }; static s32 D_EBFBE0_801B6AE8[] = { 30, 179, 30 }; static s32 D_EBFBE0_801B6AF4[] = { 0, 67, 255 }; #endif RCP_SetupDL(&gMasterDisp, 0x53); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 0, 255); Graphics_DisplaySmallText(x + 12.0f - Graphics_GetSmallTextWidth(D_EBFBE0_801AF9F4[pp]) * 0.5f, y - 8.0f, 1.0f, 1.0f, D_EBFBE0_801AF9F4[pp]); Graphics_DisplaySmallNumber(x + 15.0f - ((func_8008BCBC(D_80177B70[arg0]) - 1) * 8), y + 24.0f + 1.0f, D_80177B70[arg0]); if (D_80161A34 == 7) { temp = D_80177B48; } if ((D_80161A34 == 5) || (D_80161A34 == 8)) { temp = D_80177B48 + 1; } if (arg0 < temp) { mask = 0x00FF0000; x2 = 0.0f; for (i = 0; i < 3; i++, x2 += 9.0f) { if ((D_80177B50[arg0] & mask)) { RCP_SetupDL(&gMasterDisp, 0x53); gDPSetPrimColor(gMasterDisp++, 0, 0, D_EBFBE0_801B6ADC[i], D_EBFBE0_801B6AE8[i], D_EBFBE0_801B6AF4[i], 255); Graphics_DisplaySmallText((s32) x + x2 - 1.0f, (s32) y + 24.0f + 8.0f + 2.0f, 1.0f, 1.0f, D_EBFBE0_801B6AD0[i]); } mask >>= 8; } } } #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801AA778.s") #ifndef IMPORT_DATA extern f32 D_EBFBE0_801B6B00; // likely in-function static extern f32 D_EBFBE0_801B6B04; // likely in-function static extern f32 D_EBFBE0_801B6B08; // likely in-function static #endif void func_EBFBE0_801AB17C(f32 x, f32 y, f32 z) { #ifdef IMPORT_DATA static f32 D_EBFBE0_801B6B00 = 0.23f; // scale static f32 D_EBFBE0_801B6B04 = 4.4f; // posX static f32 D_EBFBE0_801B6B08 = 1.0f; // posY #endif RCP_SetupDL(&gMasterDisp, 0x35); gDPSetTextureFilter(gMasterDisp++, G_TF_POINT); Matrix_Push(&gGfxMatrix); Matrix_Translate(gGfxMatrix, x - D_EBFBE0_801B6B04, y + D_EBFBE0_801B6B08, z, 1); Matrix_Scale(gGfxMatrix, D_EBFBE0_801B6B00, D_EBFBE0_801B6B00, D_EBFBE0_801B6B00, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_601D1F0); Matrix_Pop(&gGfxMatrix); } void func_EBFBE0_801AB284(void) { D_EBFBE0_801CD940 = 0; D_80178308 = D_EBFBE0_801AF428[D_EBFBE0_801CD954][D_EBFBE0_801CD940]; D_80177D68 = D_EBFBE0_801AF420[D_EBFBE0_801CD940]; D_EBFBE0_801CF018 = 100; D_80178728 = 78; D_8017872C = 166; } void func_EBFBE0_801AB300(void) { if (D_Timer_801782AC > 0) { D_Timer_801782AC--; } if (D_Timer_801782B4 > 0) { D_Timer_801782B4--; } switch (D_EBFBE0_801CF018) { case 0: break; case 100: D_EBFBE0_801CEA74 = 0; D_801782A4 = 0 + D_80177D68; D_EBFBE0_801CF018 = 1; D_80177D50 = 0.0f; D_801782D8 = 0; D_EBFBE0_801CF124 = 0.0f; D_EBFBE0_801CEAB4 = 0; break; case 200: D_EBFBE0_801CF018 = 210; D_Timer_801782AC = 30; break; case 210: if (D_Timer_801782AC) { break; } D_EBFBE0_801CD940 = 1; D_80178308 = D_EBFBE0_801AF428[D_EBFBE0_801CD954][D_EBFBE0_801CD940]; func_8001ACDC(Message_IdFromPtr(D_80178308)); D_80177D68 = D_EBFBE0_801AF420[D_EBFBE0_801CD940]; D_Timer_801782AC = Message_GetCharCount(D_80178308) * 2; D_801782A4 = D_80177D68; D_EBFBE0_801CF018 = 4; D_EBFBE0_801CD9A0 = 1; break; case 1: D_EBFBE0_801CEA74 += 8; if (D_EBFBE0_801CEA74 > 255) { D_EBFBE0_801CEA74 = 255; D_80177D50 = 1.3f; Audio_PlaySfx(0x4100001EU, &D_800C5D28, 4U, &D_800C5D34, &D_800C5D34, &D_800C5D3C); func_8001ACDC(Message_IdFromPtr(D_80178308)); D_Timer_801782AC = Message_GetCharCount(D_80178308) * 2; D_EBFBE0_801CD9A4 = 0; D_EBFBE0_801CF018 = 4; } break; case 4: if (!D_Timer_801782AC && !func_8001AE78()) { D_801782A4 = D_80177D68; func_8001AE58(); if (D_EBFBE0_801CD940 == 0) { D_801782D8 = 0; D_Timer_801782AC = 30; } else { D_Timer_801782AC = 20; } D_EBFBE0_801CF018 = 41; break; } D_801782A4 = D_80177D68; if (D_Timer_801782B4 > 0) { D_801782A4 = 1 + D_80177D68; } if (D_801782D8 >= Message_GetCharCount(D_80178308)) { D_EBFBE0_801CD9A4 = 1; } if (D_EBFBE0_801CD9A0 == 1) { D_EBFBE0_801CF124 += 0.7f; D_801782D8 = D_EBFBE0_801CF124; } else { D_801782D8 += 2; } if (D_EBFBE0_801CEAB4) { if (func_8001AED4() == 1) { D_Timer_801782B4 = 2; } else { D_Timer_801782B4 = 0; } } D_EBFBE0_801CEAB4 ^= 1; break; case 41: if (D_Timer_801782AC) { break; } if (D_EBFBE0_801CD940 == 1) { D_EBFBE0_801CF018 = 5; break; } else { D_EBFBE0_801CD940 = 1; D_80178308 = D_EBFBE0_801AF428[D_EBFBE0_801CD954][D_EBFBE0_801CD940]; func_8001ACDC(Message_IdFromPtr(D_80178308)); D_80177D68 = D_EBFBE0_801AF420[D_EBFBE0_801CD940]; D_801782A4 = D_80177D68; D_801782D8 = 0; D_EBFBE0_801CF124 = 0.0f; D_Timer_801782AC = Message_GetCharCount(D_80178308) * 2; D_EBFBE0_801CD9A0 = 1; D_EBFBE0_801CD9A4 = 0; D_EBFBE0_801CF018 = 4; } break; case 5: D_Timer_801782AC = 5; D_801782A4 = D_80177D68; D_EBFBE0_801CF018++; break; case 6: if (D_Timer_801782AC == 0) { func_8001A838(0x4100001EU); func_8001ACDC(0); D_80177D50 = 0.0f; D_EBFBE0_801CF018++; D_EBFBE0_801CF018 = 7; } break; case 7: break; case 8: D_801782A4 = D_80177D68; D_80177D50 = 1.3f; D_EBFBE0_801CEA74 = 255; break; } if (D_EBFBE0_801CF018 > 0 && D_EBFBE0_801CF018 != 100) { func_EBFBE0_801AB978(D_801782A4); func_EBFBE0_801AB978(D_EBFBE0_801AF420[!D_EBFBE0_801CD940]); func_800BB388(); } } #ifndef IMPORT_DATA #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B750C.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B7510.s") #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/D_EBFBE0_801B7514.s") #endif #ifndef IMPORT_DATA extern f32 D_EBFBE0_801B6B0C[]; extern u16* D_EBFBE0_801B6B18[]; #endif void func_EBFBE0_801AB978(s32 arg0) { s32 i; f32 xPos; f32 yPos; s32 sp90[3]; #ifdef IMPORT_DATA static f32 D_EBFBE0_801B6B0C[3] = { 205.0f, 237.0f, 269.0f }; static u16* D_EBFBE0_801B6B18[3] = { (u16*) 0x06032A60, (u16*) 0x06044180, (u16*) 0x06032440, }; #endif switch (arg0) { case 10: case 11: D_EBFBE0_801CD810 = arg0 - 10; break; case 20: case 21: if (D_EBFBE0_801CEA74 != 0) { RCP_SetupDL(&gMasterDisp, 0x4C); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, D_EBFBE0_801CEA74); xPos = 205.0f; yPos = 77.0f; for (i = 0; i < 12; i++) { TextureRect_16bRGBA(&gMasterDisp, D_6044820 + (i * 92 * 4), 92, 4, xPos, yPos + (i * 4.0f), 1.0f, 1.0f); } TextureRect_16bRGBA(&gMasterDisp, D_6044820 + (92 * 12 * 4), 92, 3, xPos, yPos + 48.0f, 1.0f, 1.0f); if (arg0 == 21) { TextureRect_16bRGBA(&gMasterDisp, D_6046CD0, 32, 34, xPos + 47.0, yPos, 1.0f, 1.0f); } for (i = 0; i < 3; i++) { switch (gSavedTeamShields[3 - i]) { case -1: case -2: if (D_EBFBE0_801CEA74 > 0x20) { sp90[i] = 32; } else { sp90[i] = D_EBFBE0_801CEA74; } break; case 0: RCP_SetupDL(&gMasterDisp, 0x53); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 0, 255); if (gFrameCount & 0x10) { Graphics_DisplaySmallText(D_EBFBE0_801B6B0C[i], 131 + 28, 1.0f, 1.0f, "OK !"); } sp90[i] = D_EBFBE0_801CEA74; break; default: sp90[i] = D_EBFBE0_801CEA74; break; } RCP_SetupDL(&gMasterDisp, 0x4C); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, sp90[i]); TextureRect_16bRGBA(&gMasterDisp, D_EBFBE0_801B6B18[i], 28, 28, D_EBFBE0_801B6B0C[i], 131.0f, 1.0f, 1.0f); if ((gSavedTeamShields[3 - i] < 0) && (gSavedTeamShields[3 - i] != -2)) { func_EBFBE0_801ABCDC(i, D_EBFBE0_801CEA74); } } } } } void func_EBFBE0_801ABCDC(s32 arg0, s32 alpha) { #ifdef IMPORT_DATA static s32 D_EBFBE0_801B6B24[] = { 81.0f, 125.0f, 170.0f }; #endif Matrix_Push(&gGfxMatrix); Matrix_LookAt(gGfxMatrix, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f, -400.0f, 0.0f, 1.0f, 0.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); RCP_SetupDL(&gMasterDisp, 0x29); gDPSetTextureFilter(gMasterDisp++, G_TF_POINT); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, alpha); Matrix_Push(&gGfxMatrix); Matrix_Translate(gGfxMatrix, D_EBFBE0_801B6B24[arg0], -35.0f, -400.0f, 1); Matrix_RotateZ(gGfxMatrix, M_DTOR * -40.0f, 1); Matrix_Scale(gGfxMatrix, 0.3f, 0.3f, 1.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_500B600); Matrix_Pop(&gGfxMatrix); Matrix_Push(&gGfxMatrix); Matrix_Translate(gGfxMatrix, D_EBFBE0_801B6B24[arg0], -35.0f, -400.0f, 1); Matrix_RotateZ(gGfxMatrix, M_DTOR * 40.0f, 1); Matrix_Scale(gGfxMatrix, 0.3f, 0.3f, 1.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_500B600); Matrix_Pop(&gGfxMatrix); Matrix_Pop(&gGfxMatrix); } void func_EBFBE0_801ABF1C(void) { Matrix_Push(&gGfxMatrix); { Matrix_LookAt(gGfxMatrix, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f, -400.0f, 0.0f, 1.0f, 0.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); RCP_SetupDL(&gMasterDisp, 0x15); Matrix_Push(&gGfxMatrix); { Matrix_Translate(gGfxMatrix, D_EBFBE0_801CEA88, D_EBFBE0_801CEA8C, D_EBFBE0_801CEA90, 1); Matrix_RotateY(gGfxMatrix, M_DTOR * D_EBFBE0_801CEA94, 1); func_EBFBE0_801AD048(); Matrix_Scale(gGfxMatrix, D_EBFBE0_801CEA78, D_EBFBE0_801CEA7C, 1.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_EBFBE0_801AFA30[D_EBFBE0_801CD810]); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_605A120); } Matrix_Pop(&gGfxMatrix); RCP_SetupDL(&gMasterDisp, 0x43); gDPSetPrimColor(gMasterDisp++, 0, 0, 32, 32, 255, D_EBFBE0_801CEA98); gDPSetEnvColor(gMasterDisp++, 207, 207, 255, 0); Matrix_Push(&gGfxMatrix); { Matrix_Translate(gGfxMatrix, D_EBFBE0_801CEA88, D_EBFBE0_801CEA8C - 1.5f, D_EBFBE0_801CEA90, 1); Matrix_RotateY(gGfxMatrix, M_DTOR * D_EBFBE0_801CEA94, 1); func_EBFBE0_801AD048(); Matrix_Scale(gGfxMatrix, D_EBFBE0_801CEA80, D_EBFBE0_801CEA84, 3.3f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPClearGeometryMode(gMasterDisp++, G_CULL_BACK); gSPDisplayList(gMasterDisp++, D_604C350); gSPSetGeometryMode(gMasterDisp++, G_CULL_BACK); } Matrix_Pop(&gGfxMatrix); } Matrix_Pop(&gGfxMatrix); } void func_EBFBE0_801AC200(s32 index) { f32 x; f32 y; f32 z; f32 r; f32 r2; Vec3f vec; x = gUnkEntities30[index].unk_10.x - gUnkEntities30[index].unk_04.x; y = gUnkEntities30[index].unk_10.y - gUnkEntities30[index].unk_04.y; z = gUnkEntities30[index].unk_10.z - gUnkEntities30[index].unk_04.z; r = sqrtf(SQ(x) + SQ(y) + SQ(z)); if (r == 0.0f) { r = 1.0f; } if (D_EBFBE0_801AFD18[index].unk_14 == 2) { vec.x = (x / r) * (r / (D_EBFBE0_801AFD18[index].unk_0C - 1)); vec.y = (y / r) * (r / (D_EBFBE0_801AFD18[index].unk_0C - 1)); vec.z = (z / r) * (r / (D_EBFBE0_801AFD18[index].unk_0C - 1)); D_EBFBE0_801CEEB0.x = gUnkEntities30[index].unk_04.x + (vec.x * D_EBFBE0_801CEEA0); D_EBFBE0_801CEEB0.y = gUnkEntities30[index].unk_04.y + (vec.y * D_EBFBE0_801CEEA0); D_EBFBE0_801CEEB0.z = gUnkEntities30[index].unk_04.z + (vec.z * D_EBFBE0_801CEEA0); switch (D_EBFBE0_801CEEA4) { case 0: break; case 100: D_EBFBE0_801CD9BC = 5; D_EBFBE0_801CEEA4 = 10; break; case 10: if (D_EBFBE0_801CD9BC) { break; } D_EBFBE0_801CD9BC = 5; D_EBFBE0_801CEEA4 = 20; break; case 20: if (D_EBFBE0_801CD9BC) { break; } D_EBFBE0_801CEEA0++; if (D_EBFBE0_801CEEA0 > D_EBFBE0_801AFD18[index].unk_0C - 1) { D_EBFBE0_801CEEA0 = 0; } D_EBFBE0_801CEEA4 = 100; break; } if (D_EBFBE0_801CEEA4 != 10) { return; } } else { vec.x = (x / r) * gUnkEntities30[index].unk_24; vec.y = (y / r) * gUnkEntities30[index].unk_24; vec.z = (z / r) * gUnkEntities30[index].unk_24; D_EBFBE0_801CEEB0.x = gUnkEntities30[index].unk_04.x + vec.x; D_EBFBE0_801CEEB0.y = gUnkEntities30[index].unk_04.y + vec.y; D_EBFBE0_801CEEB0.z = gUnkEntities30[index].unk_04.z + vec.z; x = D_EBFBE0_801CEEB0.x - gUnkEntities30[index].unk_04.x; y = D_EBFBE0_801CEEB0.y - gUnkEntities30[index].unk_04.y; z = D_EBFBE0_801CEEB0.z - gUnkEntities30[index].unk_04.z; r2 = sqrtf(SQ(x) + SQ(y) + SQ(z)); if (((r / 9.0f) * 8.0f) < r2) { D_EBFBE0_801CEEAC -= 16; if (D_EBFBE0_801CEEAC < 0) { D_EBFBE0_801CEEAC = 0; } } } if (D_EBFBE0_801AFD18[index].unk_14 == 5) { func_EBFBE0_801AC80C(D_EBFBE0_801AFD18[index].unk_00); } else { func_EBFBE0_801AC530(index); } } void func_EBFBE0_801AC530(s32 index) { f32 dirX; f32 dirY; f32 dirZ; Vec3f dest; Vec3f src; f32 x1; f32 y1; f32 x; f32 y; f32 z; src.x = 0.0f; src.y = 0.0f; src.z = 0.0f; if (D_EBFBE0_801CEEA8 == 255) { RCP_SetupDL(&gMasterDisp, 0x17); } else { RCP_SetupDL(&gMasterDisp, 0x2E); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, D_EBFBE0_801CEEA8); } Matrix_Push(&gGfxMatrix); Matrix_Translate(gGfxMatrix, D_EBFBE0_801CEEB0.x, D_EBFBE0_801CEEB0.y, D_EBFBE0_801CEEB0.z, 1); Matrix_RotateY(gGfxMatrix, gUnkEntities30[index].unk_20, 1); Matrix_RotateX(gGfxMatrix, M_DTOR * -90.0f, 1); Matrix_RotateX(gGfxMatrix, gUnkEntities30[index].unk_1C, 1); Matrix_Scale(gGfxMatrix, 0.8f, 0.8f, 0.8f, 1); Matrix_SetGfxMtx(&gMasterDisp); Matrix_MultVec3f(gGfxMatrix, &src, &dest); x = D_EBFBE0_801CE960[14].x - dest.x; y = D_EBFBE0_801CE960[14].y - dest.y; z = D_EBFBE0_801CE960[14].z - dest.z; x1 = Math_Atan2F(y, sqrtf(SQ(x) + SQ(z))); y1 = -Math_Atan2F(x, z); src.x = 0.0f; src.y = 0.0f; src.z = 10.0f; Matrix_RotateY(gCalcMatrix, M_DTOR * (-D_EBFBE0_801CDA10 - y1), 0); Matrix_RotateX(gCalcMatrix, M_DTOR * (-D_EBFBE0_801CDA0C - x1), 1); Matrix_MultVec3f(gCalcMatrix, &src, &dest); dirX = dest.x; dirY = dest.y; dirZ = dest.z; Lights_SetOneLight(&gMasterDisp, dirX, dirY, dirZ, 50, 50, 40, 0, 0, 0); gSPDisplayList(gMasterDisp++, D_604A9F0); Matrix_Pop(&gGfxMatrix); } // needs in-function static #ifdef IMPORT_DATA void func_EBFBE0_801AC80C(s32 arg0) { static f32 D_EBFBE0_801B6B30 = 0.0f; s32 r; s32 g; s32 b; if (arg0 == 3) { r = 240; g = 160; b = 0; } else { r = 128; g = 0; b = 0; } RCP_SetupDL(&gMasterDisp, 0x43); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 80, D_EBFBE0_801CEEAC); gDPSetEnvColor(gMasterDisp++, r, g, b, 0); Matrix_Push(&gGfxMatrix); Matrix_Translate(gGfxMatrix, D_EBFBE0_801CEEB0.x, D_EBFBE0_801CEEB0.y, D_EBFBE0_801CEEB0.z, 1); func_EBFBE0_801AD048(); Matrix_RotateZ(gGfxMatrix, M_DTOR * D_EBFBE0_801B6B30, 1); Matrix_Scale(gGfxMatrix, 10.0f, 10.0f, 10.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_604D680); Matrix_Pop(&gGfxMatrix); D_EBFBE0_801B6B30 -= 45.0f; } #else #pragma GLOBAL_ASM("asm/us/nonmatchings/overlays/ovl_EBFBE0/ED6EC0/func_EBFBE0_801AC80C.s") #endif void func_EBFBE0_801AC9A0(s32 index) { Vec3f srcPos; Vec3f destPos; f32 x; f32 y; f32 z; f32 target; f32 temp; func_EBFBE0_801ACD90(index, &srcPos, &destPos); x = srcPos.x - destPos.x; y = srcPos.y - destPos.y; z = srcPos.z - destPos.z; target = sqrtf(SQ(x) + SQ(y) + SQ(z)); gUnkEntities30[index].mode = 4; gUnkEntities30[index].unk_04.x = srcPos.x; gUnkEntities30[index].unk_04.y = srcPos.y; gUnkEntities30[index].unk_04.z = srcPos.z; gUnkEntities30[index].unk_10.x = destPos.x; gUnkEntities30[index].unk_10.y = destPos.y; gUnkEntities30[index].unk_10.z = destPos.z; gUnkEntities30[index].unk_20 = Math_Atan2F(x, z); gUnkEntities30[index].unk_1C = -Math_Atan2F(y, sqrtf(SQ(x) + SQ(z))); switch (D_80177BD8[index]) { case 1: Audio_PlaySfx(0x1900404DU, &D_800C5D28, 4U, &D_800C5D34, &D_800C5D34, &D_800C5D3C); D_80177BD8[index] = 11; break; case 11: Math_SmoothStepToF(&gUnkEntities30[index].unk_24, target, 0.1f, 100.0f, 4.0f); gUnkEntities30[index].unk_2F = 255; if (gUnkEntities30[index].unk_24 == target) { func_8001A838(0x1900404DU); D_80177BD8[index] = 4; } break; case 5: case 6: Math_SmoothStepToF(&gUnkEntities30[index].unk_24, target, 0.1f, 100.0f, 1.0f); if (gUnkEntities30[index].unk_24 == target) { gUnkEntities30[index].unk_24 = 0.0f; D_80177BD8[index] = 6; D_EBFBE0_801CEEAC = 255; } break; case 2: temp = 0.04f; if (D_EBFBE0_801CD944 == 7) { temp = 0.25f; } Math_SmoothStepToF(&gUnkEntities30[index].unk_24, target, temp, 100.0f, 4.0f); gUnkEntities30[index].unk_2F = 255; if (gUnkEntities30[index].unk_24 == target) { D_80177BD8[index] = 3; } break; case 3: case 4: gUnkEntities30[index].unk_24 = target; gUnkEntities30[index].unk_2F = D_EBFBE0_801AFD18[index].unk_18; break; } if ((D_80177BD8[index] == 1) || (D_80177BD8[index] == 11) || (D_80177BD8[index] == 4)) { gUnkEntities30[index].unk_2C = 32; gUnkEntities30[index].unk_2D = 32; gUnkEntities30[index].unk_2E = 32; gUnkEntities30[index].unk_28 = 4.0f; } else { switch (D_EBFBE0_801AFD18[index].unk_00) { case 0: gUnkEntities30[index].unk_2C = 16; gUnkEntities30[index].unk_2D = 64; gUnkEntities30[index].unk_2E = 255; gUnkEntities30[index].unk_28 = 8.0f; break; case 1: gUnkEntities30[index].unk_2C = 255; gUnkEntities30[index].unk_2D = 175; gUnkEntities30[index].unk_2E = 0; gUnkEntities30[index].unk_28 = 8.0f; break; case 2: gUnkEntities30[index].unk_2C = 255; gUnkEntities30[index].unk_2D = 0; gUnkEntities30[index].unk_2E = 0; gUnkEntities30[index].unk_28 = 8.0f; break; case 3: case 4: gUnkEntities30[index].unk_2C = 0; gUnkEntities30[index].unk_2D = 0; gUnkEntities30[index].unk_2E = 0; gUnkEntities30[index].unk_2F = 0; gUnkEntities30[index].unk_28 = 0.1f; break; } } } void func_EBFBE0_801ACD90(s32 index, Vec3f* src, Vec3f* dest) { f32 x1; f32 y1; f32 z1; f32 x2; f32 y2; f32 z2; f32 x; f32 y; f32 z; f32 r; f32 temp1; f32 temp2; temp1 = 40.0f; if (D_EBFBE0_801AFD18[index].unk_04 == 12) { temp1 = 50.0f; } if (D_EBFBE0_801AFD18[index].unk_04 == 10) { temp1 = 60.0f; } if (D_EBFBE0_801AFD18[index].unk_04 == 14) { temp1 = 20.0f; } if (D_EBFBE0_801AFD18[index].unk_04 == 0) { temp1 = 60.0f; } if (D_EBFBE0_801AFD18[index].unk_04 == 4) { temp1 = 20.0f; } if (D_EBFBE0_801AFD18[index].unk_04 == 5) { temp1 = 20.0f; } if (D_EBFBE0_801AFD18[index].unk_04 == 3) { temp1 = 20.0f; } if (D_EBFBE0_801AFD18[index].unk_04 == 1) { temp1 = 1200.0f; } if (D_EBFBE0_801AFD18[index].unk_04 == 2) { temp1 = 1200.0f; } temp2 = 40.0f; if (D_EBFBE0_801AFD18[index].unk_08 == 10) { temp2 = 60.0f; } if (D_EBFBE0_801AFD18[index].unk_08 == 12) { temp2 = 50.0f; } if (D_EBFBE0_801AFD18[index].unk_08 == 14) { temp2 = 20.0f; } if (D_EBFBE0_801AFD18[index].unk_08 == 0) { temp2 = 60.0f; } if (D_EBFBE0_801AFD18[index].unk_08 == 4) { temp2 = 20.0f; } if (D_EBFBE0_801AFD18[index].unk_08 == 5) { temp2 = 20.0f; } if (D_EBFBE0_801AFD18[index].unk_08 == 3) { temp2 = 20.0f; } if (D_EBFBE0_801AFD18[index].unk_08 == 1) { temp2 = 1200.0f; } if (D_EBFBE0_801AFD18[index].unk_08 == 2) { temp2 = 1200.0f; } if (D_EBFBE0_801AFD18[index].unk_08 == 13) { temp2 = 30.0f; } x = planet[D_EBFBE0_801AFD18[index].unk_08].posX - planet[D_EBFBE0_801AFD18[index].unk_04].posX; y = planet[D_EBFBE0_801AFD18[index].unk_08].posY - planet[D_EBFBE0_801AFD18[index].unk_04].posY; z = planet[D_EBFBE0_801AFD18[index].unk_08].posZ - planet[D_EBFBE0_801AFD18[index].unk_04].posZ; r = sqrtf(SQ(x) + SQ(y) + SQ(z)); x1 = planet[D_EBFBE0_801AFD18[index].unk_04].posX + (temp1 * planet[D_EBFBE0_801AFD18[index].unk_04].scale * (x / r)); y1 = planet[D_EBFBE0_801AFD18[index].unk_04].posY + (temp1 * planet[D_EBFBE0_801AFD18[index].unk_04].scale * (y / r)); z1 = planet[D_EBFBE0_801AFD18[index].unk_04].posZ + (temp1 * planet[D_EBFBE0_801AFD18[index].unk_04].scale * (z / r)); x2 = planet[D_EBFBE0_801AFD18[index].unk_08].posX + (temp2 * planet[D_EBFBE0_801AFD18[index].unk_08].scale * (-x / r)); y2 = planet[D_EBFBE0_801AFD18[index].unk_08].posY + (temp2 * planet[D_EBFBE0_801AFD18[index].unk_08].scale * (-y / r)); z2 = planet[D_EBFBE0_801AFD18[index].unk_08].posZ + (temp2 * planet[D_EBFBE0_801AFD18[index].unk_08].scale * (-z / r)); src->x = x1; src->y = y1; src->z = z1; dest->x = x2; dest->y = y2; dest->z = z2; } void func_EBFBE0_801AD048(void) { f32 sp1C = Math_Atan2F(D_EBFBE0_801CD9F8 - D_EBFBE0_801CDA04, sqrtf(SQ(D_EBFBE0_801CD9F4 - D_EBFBE0_801CDA00) + SQ(D_EBFBE0_801CD9FC - D_EBFBE0_801CDA08))); f32 temp = -Math_Atan2F(D_EBFBE0_801CD9F4 - D_EBFBE0_801CDA00, D_EBFBE0_801CD9FC - D_EBFBE0_801CDA08); Matrix_RotateY(gGfxMatrix, -temp, 1); Matrix_RotateX(gGfxMatrix, -sp1C, 1); } void func_EBFBE0_801AD11C(void) { s32 i; s32 var_t0; s32 var_a3; u8 var_a1 = 0; u8 var_a2 = 0; u8 var_a0; f32 x; f32 y; var_a3 = 0; var_t0 = 0; if (gControllerPress[gMainController].button & A_BUTTON) { if ((D_80161A34 == 7) && (D_EBFBE0_801CD93C != 0) && (!D_EBFBE0_801CEFD0)) { func_8001D6DC(1); D_EBFBE0_801CEFC4 = 1; D_EBFBE0_801CEFD4 = 0; D_EBFBE0_801CEFDC = 0; D_EBFBE0_801CD944 = 6; D_EBFBE0_801CD94C = 0; } else { for (i = 0; i < 6; i++) { D_80177C58[i] = gTeamShields[i]; } func_EBFBE0_801A659C(); } return; } if (gControllerPress[gMainController].button & START_BUTTON) { if (D_EBFBE0_801CD944 == 3 && D_80161A34 == 7) { if (D_EBFBE0_801CEFD0) { Audio_PlaySfx(0x4900100AU, &D_800C5D28, 4U, &D_800C5D34, &D_800C5D34, &D_800C5D3C); } else { func_8001D6DC(1); D_EBFBE0_801CEFC4 = 1; D_EBFBE0_801CEFD4 = 0; D_EBFBE0_801CEFDC = 0; D_EBFBE0_801CD944 = 6; D_EBFBE0_801CD94C = 0; } return; } } x = gControllerPress[gMainController].stick_x; y = gControllerPress[gMainController].stick_y; if (y != 0.0f) { if (D_EBFBE0_801CDA0C - (y * 0.05f) < -80.0f) { D_EBFBE0_801CDA0C = -80.0f; y = 0.0f; } else if (D_EBFBE0_801CDA0C - (y * 0.05f) > 80.0f) { D_EBFBE0_801CDA0C = 80.0f; y = 0.0f; } else { D_EBFBE0_801CDA0C -= y * 0.05f; var_a3 = 1; var_a1 = (s32) fabsf(((y * 0.05f) / 0.27f)); } } if (x != 0.0f) { D_EBFBE0_801CDA10 += x * 0.05f; var_a2 = (s32) fabsf((x * 0.05f) / 0.27f); var_a3 = 1; } if (D_EBFBE0_801CF014 == 1) { var_a0 = var_a1; if (var_a1 < var_a2) { var_a0 = var_a2; } func_8001D15C(var_a0); } if (D_EBFBE0_801CF014 == 0 && var_a3 == 1) { func_8001D10C(&D_800C5D28, 0x1100204C); D_EBFBE0_801CF014 = 1; } if ((D_EBFBE0_801CF014 == 1) && (var_a3 == 0) && (y == 0.0f) && (x == 0.0f)) { var_a1 = 0; var_a2 = 0; func_8001A838(0x1100204CU); D_EBFBE0_801CF014 = 0; } if (gControllerHold[gMainController].button & R_TRIG) { if (D_EBFBE0_801CDA14 - 20.0f > 2475.0f) { D_EBFBE0_801CDA14 -= 20.0f; var_t0 = 1; } } if (gControllerHold[gMainController].button & Z_TRIG) { if (D_EBFBE0_801CDA14 + 20.0f < 7695.0f) { D_EBFBE0_801CDA14 += 20.0f; var_t0 = 1; } } if (gControllerHold[gMainController].button & U_CBUTTONS) { if (D_EBFBE0_801CDA04 - 10.0f >= -1200.0f) { D_EBFBE0_801CDA04 -= 10.0f; var_t0 = 1; } } if (gControllerHold[gMainController].button & D_CBUTTONS) { if (D_EBFBE0_801CDA04 + 10.0f <= 1200.0f) { D_EBFBE0_801CDA04 += 10.0f; var_t0 = 1; } } if (gControllerHold[gMainController].button & L_CBUTTONS) { if (D_EBFBE0_801CDA00 + 10.0f <= 1200.0f) { D_EBFBE0_801CDA00 += 10.0f; var_t0 = 1; } } if (gControllerHold[gMainController].button & R_CBUTTONS) { if (D_EBFBE0_801CDA00 - 10.0f >= -1200.0f) { D_EBFBE0_801CDA00 -= 10.0f; var_t0 = 1; } } if (D_EBFBE0_801CF010 == 0 && var_t0 == 1) { Audio_PlaySfx(0x1100004CU, &D_800C5D28, 4U, &D_800C5D34, &D_800C5D34, &D_800C5D3C); D_EBFBE0_801CF010 = 1; } if (D_EBFBE0_801CF010 == 1 && var_t0 == 0) { func_8001A838(0x1100004CU); D_EBFBE0_801CF010 = 0; } } void func_dummy_() { } void func_EBFBE0_801AD718(f32 arg0, f32 arg1, f32 arg2, f32* arg3, f32* arg4, f32* arg5, f32 arg6, f32 arg7, f32 arg8) { Vec3f sp2C; Vec3f sp20; sp20.x = 0.0f; sp20.y = 0.0f; sp20.z = arg6; Matrix_Translate(gCalcMatrix, arg0, arg1, arg2, 0); Matrix_RotateY(gCalcMatrix, M_DTOR * arg8, 1); Matrix_RotateX(gCalcMatrix, M_DTOR * arg7, 1); Matrix_MultVec3f(gCalcMatrix, &sp20, &sp2C); *arg3 = sp2C.x; *arg4 = sp2C.y; *arg5 = sp2C.z; } void func_EBFBE0_801AD7EC(s32 xPos, s32 yPos, s32 number) { RCP_SetupDL(&gMasterDisp, 0x55); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 255, 255); TextureRect_4bCI(&gMasterDisp, D_601DC10, D_601DC90, 16, 16, xPos, yPos, 1.0f, 1.0f); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 0, 255); TextureRect_4bCI(&gMasterDisp, D_601DCA0, D_601DCD8, 16, 7, xPos + 18.0f, yPos + 9.0f, 1.0f, 1.0f); RCP_SetupDL(&gMasterDisp, 0x53); gDPSetPrimColor(gMasterDisp++, 0, 0, 255, 255, 0, 255); if (number >= 10) { Graphics_DisplaySmallNumber(xPos + 33.0f - ((func_8008BCBC(number) - 1) * 8) + 3, yPos + 8.0f, number); } else { Graphics_DisplaySmallNumber(xPos + 33.0f, yPos + 8.0f, number); } }