#include "global.h" char D_800CF970[] = "$Id: fox_edisplay.c,v 1.196 1997/05/08 08:31:50 morita Exp $"; void func_800596C0(void) { Matrix_RotateZ(gGfxMatrix, D_80177DB0 * 13.0f * M_DTOR, 1); Matrix_Scale(gGfxMatrix, 1.02f, 0.98f, 1.0f, 1); Matrix_RotateZ(gGfxMatrix, -(f32) D_80177DB0 * 13.0f * M_DTOR, 1); Matrix_Scale(gGfxMatrix, 1.02f, 0.98f, 1.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); } void func_800597C0(s32 arg0) { if (arg0 < 0) { gSPSetGeometryMode(gMasterDisp++, G_CULL_FRONT); gSPClearGeometryMode(gMasterDisp++, G_CULL_BACK); } } void func_8005980C(f32 arg0) { Matrix_Scale(gGfxMatrix, arg0, arg0, arg0, 1); Matrix_SetGfxMtx(&gMasterDisp); } void func_80059850(Object_4C* arg0) { func_800B8DD0(&gMasterDisp, 0x40); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 255, 255, 60); func_800B9B38(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); } void func_800598DC(s32 arg0) { } void func_800598E8(Object_2F4* arg0) { func_800B9B38(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); gSPDisplayList(gMasterDisp++, D_6025B50); func_800BA1D0(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); } void func_800599A4(s32 arg0, Vec3f* arg1, s32* arg2) { Vec3f sp24; Vec3f sp18; if (arg0 == 1) { sp24.x = 0.0f; sp24.y = 0.0f; sp24.z = 0.0f; Matrix_MultVec3f(gCalcMatrix, &sp24, &sp18); D_80163FE0[*arg2].unk_114 = sp18.y; } } f32 D_800CF9B0[] = { -12.32422638f, -12.00849533f, -11.08310699f, -9.561470032f, -7.440753937f, -4.713317871f, -1.393303037f, 2.485869884f, 6.872662067f, 11.66899109f, 16.7521019f, 21.98126984f, 27.19302368f, 32.21533966f, 36.87569427f, 41.0078125f, 44.46230316f, 47.09422302f, 48.7610054f, 49.34596634f, 47.64530182f, 42.98818588f, 36.06262207f, 27.66272163f, 18.64647293f, 9.883304596f, 2.113918066f, -4.157948017f, -8.673706055f, -11.39522171f, -12.32422638f, }; f32 D_800CFA2C[] = { 1.0f, 1.0f, 0.95f, 0.9f, 0.85f, 0.8f, 0.75f, 0.7f, 0.65f, 0.6f, }; void func_80059A24(Object_2F4* arg0) { Vec3f sp30[30]; f32 temp = D_800CF9B0[arg0->unk_0B6] - 114.0f; Matrix_Translate(gGfxMatrix, 0.f, -temp, 0.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); Animation_GetFrameData(&D_601E8C4, arg0->unk_0B6, sp30); Animation_DrawSkeleton(1, &D_601E9D0, sp30, NULL, func_800599A4, &arg0->unk_040, &gIdentityMatrix); } void func_80059AEC(Object_80* arg0) { gSPDisplayList(gMasterDisp++, D_601AE40); } void func_80059B20(Object_80* arg0) { if (arg0->obj.id == 29) { gSPDisplayList(gMasterDisp++, D_7007350); } else { func_8005980C(D_800CF9B0[arg0->obj.id + 2]); gSPDisplayList(gMasterDisp++, D_700BB10); } } void func_80059BB0(void* arg0) { } void func_80059BBC(Object_80* arg0) { gSPDisplayList(gMasterDisp++, D_6023AC0); } void func_80059BF0(Object_2F4* arg0) { if (arg0->unk_0B6 != 0) { gSPDisplayList(gMasterDisp++, D_6032BC0); } } void func_80059C28(void* arg0) { } void func_80059C34(Object_4C* arg0) { } void func_80059C40(Object_4C* arg0) { func_800B9C50(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 255, 255, 180); switch (arg0->unk_45) { case 0x0: Matrix_Scale(gGfxMatrix, 2.0f, 1.0f, 0.7f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_6034B90); break; case 0x15: Matrix_Scale(gGfxMatrix, 1.0f, 1.0f, 0.7f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_6034B90); break; case 0x6: case 0x7: Matrix_Scale(gGfxMatrix, 1.0f, 1.0f, 10.55f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_Gfx_800DAC20); break; case 0x38: Matrix_Scale(gGfxMatrix, 1.6f, 1.0f, 1.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_6034B90); break; case 0x14: Matrix_Scale(gGfxMatrix, 1.2f, 1.0f, 1.3f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_6034B90); break; case 0x16: Matrix_Scale(gGfxMatrix, 2.2f, 1.0f, 1.4f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_6034B90); break; } func_800B9B38(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); } void func_80059F68(Object_6C* arg0) { Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, -95.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_602DA20); } void func_80059FDC(Object_6C* arg0) { gSPDisplayList(gMasterDisp++, D_6035DA0); } void func_8005A010(Object_4C* arg0) { if (arg0->unk_48 == 0) { Matrix_RotateY(gGfxMatrix, M_PI / 2.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_60361F0); } } void func_8005A07C(void* arg0) { } void func_8005A088(void* arg0) { } Gfx* D_800CFA54[] = { 0x06027960, 0x060273A0, 0x060183B0, 0x060121E0, 0x0602A2E0, 0x0602A720, 0x0602B8F0, 0x0602A8C0, 0x06028E70, 0x0602E0A0, 0x0602DE70, 0x0602DC40, 0x0602D830, 0x0602D340, 0x06031280, 0x06031130, 0x06030850, 0x06030FD0, 0x0602DD40, 0x06033AF0, 0x060186E0, 0x06024160, 0x06033290, 0x06017F10, 0x060074E0, 0x06007590, 0x06007730, 0x06005CC0, }; Gfx* D_800CFAC4[] = { 0x060176D0, 0x06017810, 0x06017770, 0x06016D90, 0x06016E30, 0x060178B0, }; Gfx* D_800CFADC[] = { 0x06023690, 0x06021BB0, 0x06021C50, 0x06021CE0, 0x06021D80, 0x06016350, 0x06021E20, 0x060222A0, 0x06022BE0, 0x06022D70, 0x06022F00, }; Gfx* D_800CFB08[] = { 0x06020F10, 0x06021100, 0x060214B0, }; Gfx* D_800CFB14[] = { 0x060163E0, 0x060165D0, 0x06016880, 0x06016B50, 0x06000C40, }; Gfx* D_800CFB28[] = { 0x06018E80, 0x0601F620, 0x0601F420, 0x06018C80, 0x0601F940, 0x0601F260, }; Gfx* D_800CFB40[] = { 0x06014DB0, 0x060146D0, 0x06014B80, 0x06014470, 0x06014930, 0x060138A0, 0x060151A0, 0x0600F750, 0x06015810, }; Gfx* D_800CFB64[] = { 0x0600D4A0, 0x0600D720, 0x0600D810, 0x0600CFF0, 0x0600BD20, 0x0600D390, 0x0600E150, 0x06007160, 0x0600D900, }; Gfx* D_800CFB88[] = { 0x0600A8E0, 0x0600A840, 0x0600A480, 0x0600A720, 0x0600A970, 0x06007D70, 0x0600A520, 0x06009990, }; Gfx* D_800CFBA8[] = { 0x06026460, 0x060266B0, 0x06026950, 0x060276F0, 0x06027810, 0x06027330, 0x060273C0, 0x06026E30, 0x06026EC0, 0x06026DA0, 0x06026D10, 0x06026C80, 0x06026BF0, 0x06027460, 0x06026F60, }; Gfx* D_800CFBE4[] = { 0x060040F0, 0x06027C90, 0x06027FA0, 0x06003350, 0x06028240, 0x06028550, 0x06004DB0, 0x06027930, 0x0600F030, 0x060050F0, }; Gfx* D_800CFC0C[] = { 0x060294A0, 0x060291B0, 0x060287F0, 0x06029330, 0x06029240, 0x06029790, 0x06029900, 0x06028F50, 0x060290C0, 0x06029530, 0x060296A0, 0x06028A80, 0x06028910, }; Gfx* D_800CFC40[] = { 0x06014FD0, 0x06014FD0, 0x06014FD0, 0x06014FD0, }; Gfx* D_800CFC50[] = { 0x0601EDE0, 0x0601F2F0, 0x0601F830, 0x0601FD70, 0x0601D110, }; Gfx* D_800CFC64[] = { 0x06023940, 0x06023D70, 0x060249C0, 0x06023EB0, 0x060249C0, 0x06023B80, }; Gfx* D_800CFC7C[] = { 0x0601B570, 0x0601B710, 0x060209B0, 0x06020B70, 0x06020D50, 0x0601B8F0, 0x0601B3B0, 0x0601B1C0, 0x06011660, }; void func_8005A094(Object_2F4* arg0) { switch (arg0->unk_0B8) { case 0: Matrix_Translate(gGfxMatrix, 18.0f, 15.0f, -15.0f, 1); Matrix_RotateY(gGfxMatrix, M_PI, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_3016660); break; case 1: Matrix_Translate(gGfxMatrix, -18.0f, 15.0f, -15.0f, 1); Matrix_RotateY(gGfxMatrix, M_PI, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_3015D80); break; case 2: func_8005980C(arg0->unk_110); gSPDisplayList(gMasterDisp++, D_30155E0); break; case 3: gSPDisplayList(gMasterDisp++, D_3011720); break; case 4: func_8005980C(arg0->unk_110); if (arg0->unk_040 & 1) { gSPDisplayList(gMasterDisp++, D_10194C0); } else { gSPDisplayList(gMasterDisp++, D_1024290); } break; case 0x27: gSPClearGeometryMode(gMasterDisp++, G_CULL_BACK); gSPDisplayList(gMasterDisp++, D_800CFAC4[arg0->unk_048]); break; case 0x28: gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 255, 255, 255); switch (arg0->unk_048) { case 0: break; case 1: func_800B8DD0(&gMasterDisp, 0x3D); gSPClearGeometryMode(gMasterDisp++, G_CULL_BACK); break; case 2: func_800B8DD0(&gMasterDisp, 0x39); gSPClearGeometryMode(gMasterDisp++, G_CULL_BACK); break; case 3: func_800B8DD0(&gMasterDisp, 0x21); break; } if (D_80178234 != 7) { gSPDisplayList(gMasterDisp++, D_E6A810_801B769C[arg0->unk_046]); } else { if (D_8016F110[0].unk_0E4 < 4800.0f) { func_800B8DD0(&gMasterDisp, 0x1E); gDPSetFogColor(gMasterDisp++, 0x40, 0x20, 0x20, D_80178338); gSPFogPosition(gMasterDisp++, D_801783D8, D_801783DC); } else { func_800B8DD0(&gMasterDisp, 0x1E); gDPSetFogColor(gMasterDisp++, 0x10, 0x10, 0x10, D_80178338); gSPFogPosition(gMasterDisp++, D_801783D8, D_801783DC); } func_8005980C(arg0->unk_110); gSPDisplayList(gMasterDisp++, D_800CFB40[arg0->unk_046]); } break; case 0x29: func_8005980C(arg0->unk_110); gSPDisplayList(gMasterDisp++, D_800CFADC[arg0->unk_048]); break; case 0x2A: func_8005980C(arg0->unk_110); gSPDisplayList(gMasterDisp++, D_800CFB08[arg0->unk_048]); break; case 0x2B: func_8005980C(arg0->unk_110); gSPDisplayList(gMasterDisp++, D_800CFB14[arg0->unk_048]); break; case 0x2C: func_8005980C(arg0->unk_110); gSPDisplayList(gMasterDisp++, D_800CFB28[arg0->unk_048]); break; case 0x2D: gSPDisplayList(gMasterDisp++, D_40018A0); break; case 0x2E: if ((arg0->unk_048 == 2) || (arg0->unk_048 == 3) || (arg0->unk_048 == 4)) { func_800B8DD0(&gMasterDisp, 0x21); } gSPClearGeometryMode(gMasterDisp++, G_CULL_BACK); gSPDisplayList(gMasterDisp++, D_E6A810_801B7584[arg0->unk_048]); break; case 0x2F: gSPDisplayList(gMasterDisp++, D_E6A810_801B7608[arg0->unk_048]); break; case 0x30: func_8005980C(arg0->unk_110); gSPDisplayList(gMasterDisp++, D_800CFB64[arg0->unk_048]); break; case 0x31: func_8005980C(arg0->unk_110); gSPDisplayList(gMasterDisp++, D_800CFB88[arg0->unk_048]); break; case 0x32: func_8005980C(0.7f); if (arg0->unk_054 == 1) { func_800B8DD0(&gMasterDisp, 0x1E); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 0, 0, 255); } else if (arg0->unk_054 == 2) { func_800B8DD0(&gMasterDisp, 0x1E); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 0, 0, 255); func_8005980C(0.7f); } switch (arg0->unk_050) { case 0: gSPDisplayList(gMasterDisp++, D_90234D0); break; case 1: gSPDisplayList(gMasterDisp++, D_9023290); break; case 2: gSPDisplayList(gMasterDisp++, D_900D180); break; case 3: gSPDisplayList(gMasterDisp++, D_9010FD0); break; } if (arg0->unk_054 != 0) { func_800B8DD0(&gMasterDisp, 0x1D); func_8005980C(0.7f); } break; case 0x33: func_8005980C(arg0->unk_110); gSPDisplayList(gMasterDisp++, D_800CFBA8[arg0->unk_048]); break; case 0x34: func_8005980C(arg0->unk_110); gSPDisplayList(gMasterDisp++, D_800CFBE4[arg0->unk_048]); break; case 0x35: func_8005980C(arg0->unk_110); gSPDisplayList(gMasterDisp++, D_800CFC0C[arg0->unk_048]); break; case 0x36: func_8005980C(arg0->unk_110); gSPDisplayList(gMasterDisp++, D_800CFC40[arg0->unk_048]); break; case 0x37: func_8005980C(arg0->unk_110); gSPDisplayList(gMasterDisp++, D_800CFC50[arg0->unk_048]); break; case 0x38: func_8005980C(arg0->unk_110); func_800B8DD0(&gMasterDisp, 0x29); Matrix_SetGfxMtx(&gMasterDisp); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 191, 255, 223, 255); gSPDisplayList(gMasterDisp++, D_800CFC64[arg0->unk_048]); break; case 0x3A: func_8005980C(arg0->unk_110); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_60148B0); break; case 0x3B: func_8005980C(arg0->unk_110); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_800CFC7C[arg0->unk_048]); break; case 0x46: gSPDisplayList(gMasterDisp++, D_10177C0); break; case 0x39: gSPDisplayList(gMasterDisp++, D_DF4260_8019A008[arg0->unk_048]); break; default: if (arg0->unk_0B8 > 9) { // part of switch tree somehow? if (arg0->unk_0B8 == 0x24) { gSPClearGeometryMode(gMasterDisp++, G_CULL_BACK); } gSPDisplayList(gMasterDisp++, D_800CFA54[arg0->unk_0B8 - 10]); } break; } } void func_8005ADAC(Object_2F4* arg0) { f32 sp5C; f32 temp1; f32 sp54; s32 pad[5]; // fake? seems like a lot of padding if ((arg0->unk_07C != 0) && (arg0->obj.status == 2)) { temp1 = 0.65250003f; if (arg0->unk_07C >= 2) { temp1 = 1.3050001f; } Math_SmoothStepToF(&arg0->unk_188, temp1, 0.3f, 5.0f, 0.0f); sp5C = arg0->unk_188; if (D_80177DB0 & 1) { sp5C *= 1.111f; } Matrix_Push(&gGfxMatrix); Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, -60.0f, 1); Matrix_Scale(gGfxMatrix, sp5C, sp5C * 0.7f, sp5C, 1); Matrix_RotateZ(gGfxMatrix, -arg0->obj.rot.z * M_DTOR, 1U); Matrix_RotateX(gGfxMatrix, -arg0->obj.rot.x * M_DTOR, 1U); Matrix_RotateY(gGfxMatrix, -arg0->obj.rot.y * M_DTOR, 1U); Matrix_RotateY(gGfxMatrix, -D_80178280[D_801778A0].unk_058, 1U); Matrix_RotateX(gGfxMatrix, D_80178280[D_801778A0].unk_05C, 1U); Matrix_SetGfxMtx(&gMasterDisp); func_8005465C(D_80177C98); Matrix_Pop(&gGfxMatrix); } sp5C = arg0->unk_168; if ((sp5C != 0.0f) && (D_80177C98 == 0)) { sp54 = 0.0f; if (D_80177DB0 & 1) { sp54 = 180.0f; } func_800BA170(); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 255, 255, 100); Matrix_Push(&gGfxMatrix); Matrix_Translate(gGfxMatrix, 70.0f, -10.0f, -100.0f, 1); Matrix_Scale(gGfxMatrix, sp5C, 1.0f, 50.0f, 1); Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, -17.5f, 1); Matrix_RotateX(gGfxMatrix, M_PI / 2.0f, 1); Matrix_RotateY(gGfxMatrix, M_DTOR * sp54, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_102A8A0); Matrix_Pop(&gGfxMatrix); Matrix_Push(&gGfxMatrix); Matrix_Translate(gGfxMatrix, -70.0f, -10.0f, -100.0f, 1); Matrix_Scale(gGfxMatrix, sp5C, 1.0f, 50.0f, 1); Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, -17.5f, 1); Matrix_RotateX(gGfxMatrix, M_PI / 2.0f, 1); Matrix_RotateY(gGfxMatrix, M_DTOR * sp54, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_102A8A0); Matrix_Pop(&gGfxMatrix); } } f32 D_800CFCA0[] = { 1.7f, 1.8f, 2.0f, 3.0f, 3.0f, 3.0f, 3.0f, 3.0f, }; void func_8005B1E8(Object_2F4* arg0, s32 arg1) { f32 var_fv0; if ((arg0->unk_07C != 0) && (arg0->obj.status == 2)) { var_fv0 = 0.63f; if (arg0->unk_07C >= 2) { var_fv0 = D_800CFCA0[arg0->unk_07C - 2] * 0.45f; } if (D_80177DB0 & 1) { var_fv0 *= 1.2f; } Matrix_Push(&gGfxMatrix); Matrix_Scale(gGfxMatrix, var_fv0, var_fv0, var_fv0, 1); Matrix_RotateZ(gGfxMatrix, -arg0->obj.rot.z * M_DTOR, 1); Matrix_RotateX(gGfxMatrix, -arg0->obj.rot.x * M_DTOR, 1); Matrix_RotateY(gGfxMatrix, -arg0->obj.rot.y * M_DTOR, 1); Matrix_RotateY(gGfxMatrix, -D_80178280[D_801778A0].unk_058, 1); Matrix_SetGfxMtx(&gMasterDisp); func_8005465C(arg1); Matrix_Pop(&gGfxMatrix); } } void func_8005B388(Object_2F4* arg0) { Vec3f sp3C = { 0.0f, 0.0f, 0.0f }; Vec3f sp30; Matrix_MultVec3f(gGfxMatrix, &sp3C, &sp30); if ((((fabsf(sp30.z) < 3000.0f) && (fabsf(sp30.x) < 3000.0f) && (D_80178284 == 0)) || (D_80178280[0].unk_1C8 == 0) || (D_80178234 == 9) || (D_80178234 == 0x13) || (D_80178280[0].unk_1C8 == 7)) && (D_80178234 != 0xB) && (D_80178234 != 0xC)) { if (arg0->obj.id == 0xC3) { if (((D_80178234 == 0x13) && (D_80178280[0].unk_1C8 == 7) && (arg0->unk_040 == 0xA)) || ((D_80178280[0].unk_1C8 == 7) && (D_80178280[0].unk_1D0 >= 0x64) && (D_80178234 == 0x10) && (arg0->unk_040 == 1)) || ((D_80178234 == 5) && (D_80178280[0].unk_1C8 == 0) && (arg0->unk_0B8 == 5))) { D_80161630.unk_00 = D_80178280[0].unk_49C; D_80161630.unk_01 = D_80178280[0].unk_49D; } else { D_80161630.unk_00 = D_80161630.unk_01 = 2; } } else { D_80161630.unk_00 = D_80161630.unk_01 = 2; } D_80161630.unk_04 = arg0->unk_150; D_80161630.unk_0C = arg0->unk_154; D_80161630.unk_08 = arg0->unk_17C; D_80161630.unk_10 = arg0->unk_180; D_80161630.unk_14 = D_80161630.unk_18 = D_80161630.unk_1C = D_80161630.unk_20 = D_80161630.unk_38 = D_80161630.unk_24 = 0.0f; D_80161630.unk_28 = arg0->unk_158; D_80161630.unk_2C = arg0->unk_88; D_80161630.unk_30 = arg0->unk_164; D_80161630.unk_34 = arg0->unk_160; if (D_80177C98 == 1) { D_80161630.unk_04 = D_80161630.unk_08 = D_80161630.unk_0C = D_80161630.unk_10 = 0.0f; } func_80053658(&D_80161630); } else if (D_80177C98 == 0) { gSPDisplayList(gMasterDisp++, D_40018A0); } else if (D_80178280[0].unk_204 == 2) { gSPDisplayList(gMasterDisp++, D_4003BD0); } else { gSPDisplayList(gMasterDisp++, D_4007870); } func_8005ADAC(arg0); } void func_8005B6A4(Object_2F4* arg0) { Matrix_Scale(gGfxMatrix, 1.0f, 1.0f, 1.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_6024B60); } void func_8005B71C(Object_2F4* arg0) { func_800BA1D0(arg0->unk_046, D_80178328, D_80178330, D_80178338, arg0->unk_048, D_801783DC); Matrix_Scale(gGfxMatrix, 0.5f, 0.5f, 0.5f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_6018C00); } void func_8005B7CC(Object_2F4* arg0) { func_800BA1D0(arg0->unk_046, D_80178328, D_80178330, D_80178338, arg0->unk_048, D_801783DC); gSPDisplayList(gMasterDisp++, D_6022920); } void func_8005B848(Object_2F4* arg0) { f32 var_fv0; switch (arg0->unk_0B4) { case 0: gSPDisplayList(gMasterDisp++, D_1028230); break; case 1: if (D_80178234 == 3) { gSPDisplayList(gMasterDisp++, D_400B390); } else { gSPDisplayList(gMasterDisp++, D_4007AF0); } break; } var_fv0 = 2.0f; if (D_80177DB0 & 1) { var_fv0 = 1.7f; } Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, -60.0f, 1); arg0->unk_07C = 1; Matrix_Scale(gGfxMatrix, var_fv0, var_fv0, var_fv0, 1); func_8005B1E8(arg0, 2); } void func_8005B9A4(Object_2F4* arg0) { Matrix_Translate(gGfxMatrix, 0.0f, -124.0f, 0.0f, 1); Animation_GetFrameData(&D_6029528, arg0->unk_0B6, &arg0->unk_18C); Animation_DrawSkeleton(1, D_6029674, &arg0->unk_18C, NULL, NULL, (s32*) arg0, &gIdentityMatrix); } void func_8005BA30(Object_2F4* arg0) { if (arg0->unk_0BC != 0) { func_800BA400(); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 0, 0, 255); } gSPDisplayList(gMasterDisp++, D_6020B40); } void func_8005BAAC(void) { } f32 D_800CFCCC[] = { 0.0f, 0.05f, 0.03f, 0.02f, 0.01f, 0.05f, 0.0f, 0.02f, }; void func_8005BAB4(s32 arg0, s32 arg1) { f32 temp_fv0; f32 temp1; f32 temp2; switch (arg0) { case 0x176: if (D_80170130[arg1].unk_4E == 0) { Matrix_Scale(gGfxMatrix, 1.2f, 0.0f, 1.2f, 1); Matrix_RotateX(gGfxMatrix, M_PI / 2.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_102A8A0); } func_800B8DD0(&gMasterDisp, 0x40); break; case 0xC3: case 0xC6: case 0xC8: switch (D_80163FE0[arg1].unk_0B4) { case 0x3: Matrix_Scale(gGfxMatrix, 2.3f, 0.0f, 2.3f, 1); Matrix_RotateX(gGfxMatrix, M_PI / 2.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_102A010); break; case 0x51: func_800B8DD0(&gMasterDisp, 0x30); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 0, 0, 0, 255); gDPSetEnvColor(gMasterDisp++, 0, 0, 0, 255); temp_fv0 = D_80163FE0[arg1].unk_150 * 3.0f; Matrix_Scale(gGfxMatrix, temp_fv0, temp_fv0, temp_fv0, 1); Matrix_RotateX(gGfxMatrix, -M_PI / 2.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_1024AC0); break; default: temp1 = D_800CFCCC[D_80177DB0 % 8U]; temp2 = D_800CFCCC[(D_80177DB0 + 4) % 8U]; Matrix_Scale(gGfxMatrix, 1.4f + temp1, 0.0f, 1.4f + temp2, 1); Matrix_RotateY(gGfxMatrix, M_PI, 1); Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, 30.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPSetGeometryMode(gMasterDisp++, G_CULL_BACK); gSPDisplayList(gMasterDisp++, D_1032780); break; } break; case 0x124: gSPDisplayList(gMasterDisp++, D_6034B90); break; case 0x13C: if (D_80178280[0].unk_1C8 == 0) { func_800B8DD0(&gMasterDisp, 0x40); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 0, 0, 0, 200); } Matrix_RotateX(gGfxMatrix, M_PI / 2.0f, 1); func_8005980C(150.0f); gSPDisplayList(gMasterDisp++, D_102A8A0); break; case 0x125: case 0x126: case 0x127: case 0x128: __cosf(D_8016F110[arg1].obj.rot.z * M_DTOR); if (D_80161A88 == 2) { gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 255, 255, 90); } else { gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 255, 255, 150); } switch (arg0) { case 0x125: gSPDisplayList(gMasterDisp++, D_6036840); break; case 0x126: gSPDisplayList(gMasterDisp++, D_6036CD0); break; case 0x127: case 0x128: gSPDisplayList(gMasterDisp++, D_60363B0); break; } break; case 0xC0: gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 255, 255, 150); Matrix_Scale(gGfxMatrix, 0.4f, 0.4f, D_80163FE0[arg1].unk_110, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_6034B90); break; case 0xE6: func_800BA550(); func_800B8DD0(&gMasterDisp, 0x45); gSPSetGeometryMode(gMasterDisp++, G_CULL_BACK); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 0, 0, 0, 255); gDPSetEnvColor(gMasterDisp++, 0, 0, 0, 0); Matrix_RotateX(gGfxMatrix, D_80163FE0[arg1].unk_114, 1); Matrix_RotateZ(gGfxMatrix, D_80163FE0[arg1].unk_11C, 1); Matrix_Scale(gGfxMatrix, D_80163FE0[arg1].unk_110, 1.0f, D_80163FE0[arg1].unk_110, 1); Matrix_RotateX(gGfxMatrix, -M_PI / 2.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_1024AC0); break; case 0xE5: func_800B8DD0(&gMasterDisp, 0x44); gSPSetGeometryMode(gMasterDisp++, G_CULL_BACK); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 0, 0, 0, 255); gDPSetEnvColor(gMasterDisp++, 0, 0, 0, 0); Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, 120.0f, 1); Matrix_RotateX(gGfxMatrix, D_80163FE0[arg1].unk_118 * M_DTOR, 1); Matrix_RotateZ(gGfxMatrix, D_80163FE0[arg1].unk_11C * M_DTOR, 1); Matrix_RotateY(gGfxMatrix, D_80163FE0[arg1].obj.rot.y * M_DTOR, 1); Matrix_Scale(gGfxMatrix, 6.0f, 1.0f, 7.5f, 1); Matrix_RotateX(gGfxMatrix, -M_PI / 2.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_1024AC0); break; case 0xE7: func_800B8DD0(&gMasterDisp, 0x45); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 0, 0, 0, 255); gDPSetEnvColor(gMasterDisp++, 0, 0, 0, 0); Matrix_RotateX(gGfxMatrix, D_80163FE0[arg1].unk_118, 1); Matrix_RotateZ(gGfxMatrix, D_80163FE0[arg1].unk_11C, 1); Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, 0.0f, 1); Matrix_Scale(gGfxMatrix, 1.2f, 1.0f, 1.2f, 1); Matrix_RotateX(gGfxMatrix, -M_PI / 2.0f, 1U); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_1024AC0); break; case 0xD7: func_800BA550(); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 0, 0, 0, 255); gDPSetEnvColor(gMasterDisp++, 0, 0, 0, 255); Matrix_Scale(gGfxMatrix, 4.0f, 4.0f, 4.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_1024AC0); break; case 0x13F: func_DF4260_80198310(&D_8016F110[arg1]); break; } } void func_8005C5F0(Object_6C* arg0) { s32 i; if ((D_80177DB0 & 0x18) && (arg0->unk_46 == 0)) { Matrix_Push(&gGfxMatrix); func_800B8DD0(&gMasterDisp, 0x40); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 255, 0, 255); Matrix_Scale(gGfxMatrix, 3.2f, 3.2f, 3.2f, 1); Matrix_SetGfxMtx(&gMasterDisp); gDPSetTextureFilter(gMasterDisp++, G_TF_POINT); gSPDisplayList(gMasterDisp++, D_1023C80); gDPSetTextureFilter(gMasterDisp++, G_TF_BILERP); Matrix_Pop(&gGfxMatrix); } func_800B8DD0(&gMasterDisp, 0x1D); gSPTexture(gMasterDisp++, 2000, 2000, 0, G_TX_RENDERTILE, G_ON); gSPSetGeometryMode(gMasterDisp++, G_TEXTURE_GEN); Matrix_RotateZ(gGfxMatrix, arg0->unk_58 * M_DTOR, 1); for (i = 0; i < 8; i++) { Matrix_Push(&gGfxMatrix); Matrix_RotateZ(gGfxMatrix, i * 45.0f * M_DTOR, 1); Matrix_Translate(gGfxMatrix, 2.0f * arg0->unk_68, 0.0f, 0.0f, 1); Matrix_RotateZ(gGfxMatrix, (D_80177DB0 + (i * 110.0f)) * M_DTOR * 7.2f * arg0->unk_54, 1); func_8005980C(2.0f * arg0->unk_50); gSPDisplayList(gMasterDisp++, D_101CAE0); Matrix_Pop(&gGfxMatrix); } gSPClearGeometryMode(gMasterDisp++, G_TEXTURE_GEN); } void func_8005C900(Object_6C* arg0) { func_800B8DD0(&gMasterDisp, 0x1D); gSPTexture(gMasterDisp++, 3000, 0, 0, G_TX_RENDERTILE, G_ON); gSPSetGeometryMode(gMasterDisp++, G_TEXTURE_GEN | G_TEXTURE_GEN_LINEAR); func_8005980C(arg0->unk_68); gSPDisplayList(gMasterDisp++, D_101A570); gSPClearGeometryMode(gMasterDisp++, G_TEXTURE_GEN | G_TEXTURE_GEN_LINEAR); } void func_8005C9C0(Object_6C* arg0) { func_800B8DD0(&gMasterDisp, 0x1D); gSPTexture(gMasterDisp++, 3000, 0, 0, G_TX_RENDERTILE, G_ON); gSPSetGeometryMode(gMasterDisp++, G_TEXTURE_GEN | G_TEXTURE_GEN_LINEAR); func_8005980C(arg0->unk_68); gSPDisplayList(gMasterDisp++, D_1019CA0); gSPClearGeometryMode(gMasterDisp++, G_TEXTURE_GEN | G_TEXTURE_GEN_LINEAR); } void func_8005CA80(Object_6C* arg0) { func_800B8DD0(&gMasterDisp, 0x1D); gSPTexture(gMasterDisp++, 1900, 1700, 0, G_TX_RENDERTILE, G_ON); gSPSetGeometryMode(gMasterDisp++, G_TEXTURE_GEN | G_TEXTURE_GEN_LINEAR); func_8005980C(arg0->unk_68); gSPDisplayList(gMasterDisp++, D_1016870); gSPClearGeometryMode(gMasterDisp++, G_TEXTURE_GEN | G_TEXTURE_GEN_LINEAR); } void func_8005CB44(Object_6C* arg0) { if (D_80178234 == 0xD) { func_8005980C(arg0->unk_68); gSPDisplayList(gMasterDisp++, D_3005980); } else { func_8005980C(arg0->unk_68 * 0.1f); func_800B8DD0(&gMasterDisp, 0x1D); gSPTexture(gMasterDisp++, 2000, 2000, 0, G_TX_RENDERTILE, G_ON); gSPSetGeometryMode(gMasterDisp++, G_TEXTURE_GEN); gSPDisplayList(gMasterDisp++, D_10231A0); gSPClearGeometryMode(gMasterDisp++, G_TEXTURE_GEN); func_800B8DD0(&gMasterDisp, 0x1B); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 255, 255, 255); gSPDisplayList(gMasterDisp++, D_1022E80); } } void func_8005CC9C(Object_6C* arg0) { func_8005980C(arg0->unk_68 * 0.1f); func_800B8DD0(&gMasterDisp, 0x1D); gSPTexture(gMasterDisp++, 2000, 2000, 0, G_TX_RENDERTILE, G_ON); gSPSetGeometryMode(gMasterDisp++, G_TEXTURE_GEN); gSPDisplayList(gMasterDisp++, D_1019820); gSPClearGeometryMode(gMasterDisp++, G_TEXTURE_GEN); func_800B8DD0(&gMasterDisp, 0x1B); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 255, 255, 255); gSPDisplayList(gMasterDisp++, D_101A8E0); } void func_8005CDA8(Object_6C* arg0) { s32 i; arg0->obj.rot.y = (Math_Atan2F(D_80178280[D_801778A0].unk_040.x - arg0->obj.pos.x, D_80178280[D_801778A0].unk_040.z - (arg0->obj.pos.z + D_80177D20)) * 180.0f) / M_PI; if (arg0->unk_46 != 0) { func_800B8DD0(&gMasterDisp, 0x29); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 255, 255, arg0->unk_44); } else { func_800B9B38(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); } gSPClearGeometryMode(gMasterDisp++, G_CULL_BACK | G_LIGHTING); // wrong order? for (i = 0; i < 7; i++) { Matrix_Push(&gGfxMatrix); Matrix_RotateZ(gGfxMatrix, (i * 360.0f / 7.0f) * M_DTOR, 1); Matrix_Translate(gGfxMatrix, 0.0f, arg0->unk_68, 0.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_102FE80); Matrix_Pop(&gGfxMatrix); } gSPSetGeometryMode(gMasterDisp++, G_CULL_BACK | G_LIGHTING); } void func_8005D008(Object* arg0, s32 arg1) { if (arg1 == 2) { Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, D_80177D20, 1); Matrix_Translate(gCalcMatrix, arg0->pos.x, arg0->pos.y, arg0->pos.z, 0); Matrix_Push(&gGfxMatrix); Matrix_Mult(gGfxMatrix, gCalcMatrix, 1); Matrix_Copy(&D_801615F0, gGfxMatrix); Matrix_Pop(&gGfxMatrix); Matrix_RotateY(gCalcMatrix, arg0->rot.y * M_DTOR, 1); Matrix_RotateX(gCalcMatrix, arg0->rot.x * M_DTOR, 1); Matrix_RotateZ(gCalcMatrix, arg0->rot.z * M_DTOR, 1); } else { Matrix_Translate(gGfxMatrix, arg0->pos.x, arg0->pos.y, arg0->pos.z + D_80177D20, 1); Matrix_Copy(&D_801615F0, gGfxMatrix); Matrix_RotateY(gGfxMatrix, arg0->rot.y * M_DTOR, 1); Matrix_RotateX(gGfxMatrix, arg0->rot.x * M_DTOR, 1); Matrix_RotateZ(gGfxMatrix, arg0->rot.z * M_DTOR, 1); Matrix_SetGfxMtx(&gMasterDisp); } } void func_8005D1F0(Object* arg0, s32 arg1) { if (arg1 == 2) { Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, D_80177D20, 1); Matrix_Translate(gCalcMatrix, arg0->pos.x, arg0->pos.y, arg0->pos.z, 0); Matrix_Push(&gGfxMatrix); Matrix_Mult(gGfxMatrix, gCalcMatrix, 1); Matrix_Copy(&D_801615F0, gGfxMatrix); Matrix_Pop(&gGfxMatrix); Matrix_RotateY(gCalcMatrix, arg0->rot.y * M_DTOR, 1); Matrix_RotateX(gCalcMatrix, arg0->rot.x * M_DTOR, 1); Matrix_RotateZ(gCalcMatrix, arg0->rot.z * M_DTOR, 1); } else { Matrix_Translate(gGfxMatrix, arg0->pos.x, arg0->pos.y, arg0->pos.z + D_80177D20, 1); Matrix_Copy(&D_801615F0, gGfxMatrix); Matrix_RotateY(gGfxMatrix, arg0->rot.y * M_DTOR, 1); Matrix_RotateX(gGfxMatrix, arg0->rot.x * M_DTOR, 1); Matrix_RotateZ(gGfxMatrix, arg0->rot.z * M_DTOR, 1); } } void func_8005D3CC(Object* arg0, f32 arg1, f32 arg2, f32 arg3, s32 arg4) { if (arg4 == 2) { Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, D_80177D20, 1); Matrix_Translate(gCalcMatrix, arg0->pos.x, arg0->pos.y, arg0->pos.z, 0); Matrix_Push(&gGfxMatrix); Matrix_Mult(gGfxMatrix, gCalcMatrix, 1); Matrix_Copy(&D_801615F0, gGfxMatrix); Matrix_Pop(&gGfxMatrix); Matrix_RotateY(gCalcMatrix, M_DTOR * arg2, 1); Matrix_RotateX(gCalcMatrix, M_DTOR * arg1, 1); Matrix_RotateZ(gCalcMatrix, M_DTOR * arg3, 1); Matrix_RotateY(gCalcMatrix, arg0->rot.y * M_DTOR, 1); Matrix_RotateX(gCalcMatrix, arg0->rot.x * M_DTOR, 1); Matrix_RotateZ(gCalcMatrix, arg0->rot.z * M_DTOR, 1); } else { Matrix_Translate(gGfxMatrix, arg0->pos.x, arg0->pos.y, arg0->pos.z + D_80177D20, 1); Matrix_Copy(&D_801615F0, gGfxMatrix); Matrix_RotateY(gGfxMatrix, M_DTOR * arg2, 1); Matrix_RotateX(gGfxMatrix, M_DTOR * arg1, 1); Matrix_RotateZ(gGfxMatrix, M_DTOR * arg3, 1); Matrix_RotateY(gGfxMatrix, arg0->rot.y * M_DTOR, 1); Matrix_RotateX(gGfxMatrix, arg0->rot.x * M_DTOR, 1); Matrix_RotateZ(gGfxMatrix, arg0->rot.z * M_DTOR, 1); Matrix_SetGfxMtx(&gMasterDisp); } } void func_8005D654(Object_80* arg0, s32 arg1) { arg0->obj.pos.y += D_8017847C; func_8005D008(&arg0->obj, arg0->unk_1C.unk_04); arg0->obj.pos.y -= D_8017847C; if (arg0->unk_1C.unk_04 == 0) { if ((arg0->obj.id == 0x13) || (arg0->obj.id == 0x37) || (arg0->obj.id == 9) || (arg0->obj.id == 0x32)) { func_800B9EB0(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); gSPClearGeometryMode(gMasterDisp++, G_CULL_BACK); if (arg1 < 0) { func_800596C0(); } gSPDisplayList(gMasterDisp++, arg0->unk_1C.unk_00); func_800BA1D0(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); } else { if (arg0->obj.id == 8) { if (arg1 < 0) { return; // weird control flow } func_800B9B38(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); } func_800597C0(arg1); if (arg1 < 0) { func_800596C0(); } gSPDisplayList(gMasterDisp++, arg0->unk_1C.unk_00); if (arg0->obj.id == 8) { func_800BA1D0(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); } } } else if (arg0->unk_1C.unk_00 != NULL) { func_800597C0(arg1); arg0->unk_1C.unk_00(&arg0->obj); } } void func_8005D8B8(Object_4C* arg0, s32 arg1) { if (arg1 >= 0) { arg0->obj.pos.y += D_8017847C; func_8005D008(&arg0->obj, 0); arg0->obj.pos.y -= D_8017847C; if (arg0->unk_1C.unk_04 == 0) { gSPDisplayList(gMasterDisp++, arg0->unk_1C.unk_00); } else if (arg0->unk_1C.unk_00 != NULL) { arg0->unk_1C.unk_00(&arg0->obj); } } } void func_8005D954(Object_2F4* arg0) { Vec3f sp34 = { 0.0f, 0.0f, 0.0f }; if (arg0->unk_01C.unk_00 != NULL) { switch (arg0->obj.id) { case 0xC2: func_8006B74C(arg0); return; case 0xEC: func_E16C50_80190F08(arg0); return; } if ((arg0->obj.id == 0xC8) && (arg0->unk_0B4 == 200)) { func_8006B74C(arg0); } else { if (arg0->unk_01C.unk_19 != 0) { arg0->obj.pos.y += D_8017847C; func_8005D008(&arg0->obj, arg0->unk_01C.unk_04); arg0->obj.pos.y -= D_8017847C; } else if ((arg0->obj.id == 0xC8) && (arg0->unk_0B4 != 0x1F)) { func_8005D3CC(&arg0->obj, arg0->unk_2E8.x, arg0->unk_2E8.y, arg0->unk_2E8.z + arg0->unk_0FC, arg0->unk_01C.unk_04); } else { func_8005D008(&arg0->obj, arg0->unk_01C.unk_04); } if (arg0->unk_01C.unk_04 == 0) { gSPDisplayList(gMasterDisp++, arg0->unk_01C.unk_00); func_8005F1EC(&arg0->unk_100); } else { arg0->unk_01C.unk_00(&arg0->obj); func_8005F1EC(&arg0->unk_100); if (((arg0->obj.id == 0xC6) || ((arg0->obj.id == 0xCB) && (arg0->unk_0B6 > 0))) && (D_80161410 > 0)) { Matrix_MultVec3f(gGfxMatrix, &sp34, &D_80177E98[arg0->unk_0E4]); } } if ((arg0->unk_0CA[0] != 0) && (D_80161410 > 0)) { sp34.y += arg0->unk_01C.unk_1C; Matrix_MultVec3f(gGfxMatrix, &sp34, &D_80161578[0]); if (D_80161578[0].z > -200.0f) { arg0->unk_0CA[0] = 0; } } } } } #ifdef NON_MATCHING void func_8005DBC0(Object_2F4* arg0) { s32 var_v1; Vec3f sp50 = { 0.0f, 0.0f, 0.0f }; f32 var_fa1; f32 var_ft5; f32 var_fv0; f32 var_fv1; D_801615EC = 0; if (arg0->unk_01C.unk_04 == 2) { Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, D_80177D20, 1); Matrix_Translate(gCalcMatrix, arg0->obj.pos.x, arg0->obj.pos.y, arg0->obj.pos.z, 0); Matrix_Push(&gGfxMatrix); Matrix_Mult(gGfxMatrix, gCalcMatrix, 1); Matrix_MultVec3f(gGfxMatrix, &sp50, &D_801615E0); Matrix_Pop(&gGfxMatrix); var_fv0 = 0.0f; var_fv1 = -12000.0f; if ((arg0->obj.id == 197) && (arg0->unk_0E4 >= 100)) { var_fv0 = 1000.0f; var_fv1 = -25000.0f; } if (((var_fv0 > D_801615E0.z) && (D_801615E0.z > var_fv1)) && ((fabsf(D_801615E0.x) < (fabsf(D_801615E0.z * 0.5f) + 500.0f)) && (fabsf(D_801615E0.y) < (fabsf(D_801615E0.z * 0.5f) + 500.0f)))) { Matrix_RotateY(gCalcMatrix, arg0->obj.rot.y * M_DTOR, 1); Matrix_RotateX(gCalcMatrix, arg0->obj.rot.x * M_DTOR, 1); Matrix_RotateZ(gCalcMatrix, arg0->obj.rot.z * M_DTOR, 1); arg0->unk_01C.unk_00(&arg0->obj); D_801615EC = 1; if ((D_80178280->unk_1C8 == 3) && (arg0->obj.id == 0xC5) && (arg0->unk_0E4 == 0xC8)) { D_80177E98[0] = D_801615E0; } } } else { Matrix_Translate(gGfxMatrix, arg0->obj.pos.x, arg0->obj.pos.y, arg0->obj.pos.z, 1); Matrix_MultVec3f(gGfxMatrix, &sp50, &D_801615E0); if ((D_80178280->unk_1C8 == 2) || (D_80178280->unk_1C8 == 0) || ((arg0->obj.id == 0xC5) && (arg0->unk_0E4 >= 0x64)) || ((arg0->obj.id == 0xC3) && (arg0->unk_01C.unk_20 != 0))) { var_ft5 = var_fv0 = 3000.0f; var_fv1 = -29000.0f; var_fa1 = 0.7f; } else { var_ft5 = 500.0f; var_fv0 = 0.0f; var_fv1 = -20000.0f; var_fa1 = 0.5f; } if (((D_801615E0.z < var_fv0) && (var_fv1 < D_801615E0.z)) && ((fabsf(D_801615E0.x) < (fabsf(D_801615E0.z * var_fa1) + var_ft5)) && (fabsf(D_801615E0.y) < (fabsf(D_801615E0.z * var_fa1) + var_ft5)) && (arg0->unk_01C.unk_00 != NULL))) { Matrix_RotateY(gGfxMatrix, arg0->obj.rot.y * M_DTOR, 1); Matrix_RotateX(gGfxMatrix, arg0->obj.rot.x * M_DTOR, 1); Matrix_RotateZ(gGfxMatrix, arg0->obj.rot.z * M_DTOR, 1); Matrix_SetGfxMtx(&gMasterDisp); arg0->unk_01C.unk_00(&arg0->obj); D_801615EC = 1; if ((D_80178280->unk_1C8 == 3) && (((arg0->obj.id == 0xC5) && ((arg0->unk_0E4 < 4) || (arg0->unk_0E4 == 8) || (arg0->unk_0E4 == 9))) || (arg0->obj.id == 0xC6))) { D_80177E98[arg0->unk_0E4] = D_801615E0; } } } if (D_801615EC == 0) { arg0->unk_0CA[D_801778A0] = 0; if ((arg0->obj.id == 0xBD) || (arg0->obj.id == 0x11E)) { func_80060FBC(&arg0->obj, &arg0->unk_100); } } for (var_v1 = 0; var_v1 < D_801778A8; var_v1++) { if (arg0->unk_0CA[var_v1] != 0) { D_80161578[var_v1] = D_801615E0; D_80161578[var_v1].y += arg0->unk_01C.unk_1C; if ((var_v1 == D_801778A0) && (D_80161578[var_v1].z > -300.0f)) { arg0->unk_0CA[var_v1] = 0; } } } func_8005F290(&arg0->unk_100, &D_801615E0); arg0->unk_0B0 = D_801615EC; } #else Vec3f D_800CFCF8 = { 0.0f, 0.0f, 0.0f }; void func_8005DBC0(Object_2F4* arg0); #pragma GLOBAL_ASM("asm/us/nonmatchings/main/fox_edisplay/func_8005DBC0.s") #endif #ifdef NON_MATCHING void func_8005E1B8(Object_408* arg0, s32 arg1) { f32 var_fa1; f32 var_ft5; f32 var_fv0; f32 var_fv1; f32 sp3C; Vec3f sp30 = { 0.0f, 0.0f, 0.0f }; if (arg0->unk_01C.unk_19 != 0) { arg0->obj.pos.y += arg0->unk_068 + D_8017847C; func_8005D1F0(&arg0->obj, arg0->unk_01C.unk_04); arg0->obj.pos.y -= arg0->unk_068 + D_8017847C; } else { func_8005D1F0(&arg0->obj, arg0->unk_01C.unk_04); } Matrix_MultVec3f(&D_801615F0, &sp30, &D_801615D0); func_8005F290(&arg0->unk_3FC, &D_801615D0); if ((arg0->obj.id == 0x13C) || (arg0->obj.id == 0x13D)) { var_fa1 = 6000.0f; var_fv0 = 6000.0f; var_ft5 = 0.9f; var_fv1 = -20000.0f; } else if (arg0->obj.id == 0x139) { var_fv1 = -25000.0f; var_ft5 = 0.7f; var_fa1 = 3000.0f; var_fv0 = 2000.0f; } else { var_ft5 = 0.5f; var_fa1 = 2000.0f; var_fv0 = 1000.0f; var_fv1 = -15000.0f; } sp3C = -1.0f; if (((D_801615D0.z < var_fv0) && (var_fv1 < D_801615D0.z)) && ((fabsf(D_801615D0.x) < (fabsf(D_801615D0.z * var_ft5) + var_fa1)) && (fabsf(D_801615D0.y) < (fabsf(D_801615D0.z * var_ft5) + var_fa1)))) { sp3C = 1.0f; if (arg0->obj.id != 0x135) { if (arg0->obj.id != 0x13C) { func_8005F670(&arg0->obj.pos); } if (arg0->unk_01C.unk_04 != 2) { Matrix_SetGfxMtx(&gMasterDisp); } if (arg1 < 0) { func_800596C0(); } arg0->unk_01C.unk_00(&arg0->obj); } } D_801615D0.y = sp3C; if (arg0->obj.id == 0x135) { arg0->unk_308 = D_801615D0; func_8005F670(&arg0->obj.pos); Matrix_SetGfxMtx(&gMasterDisp); arg0->unk_01C.unk_00(&arg0->obj); } } #else Vec3f D_800CFD04 = { 0.0f, 0.0f, 0.0f }; void func_8005E1B8(Object_408* arg0, s32 arg1); #pragma GLOBAL_ASM("asm/us/nonmatchings/main/fox_edisplay/func_8005E1B8.s") #endif void func_8005E454(Object_8C* arg0, s32 arg1) { if ((arg1 < 0) && (arg0->obj.pos.y < 7.0f)) { return; } if ((arg0->obj.id == 0x161) || (arg0->obj.id == 0x171)) { func_8005D3CC(&arg0->obj, arg0->unk_60.x, arg0->unk_60.y, arg0->unk_60.z, 0); } else if (arg0->unk_1C.unk_14 == -1) { arg0->obj.pos.y += D_8017847C; func_8005D008(&arg0->obj, 0); arg0->obj.pos.y -= D_8017847C; } else { func_8005D008(&arg0->obj, 0); } if (arg0->unk_1C.unk_00 != NULL) { arg0->unk_1C.unk_00(&arg0->obj); } } #ifdef NON_MATCHING void func_8005E538(Object_8C* arg0) { Vec3f sp4C = { 0.0f, 0.0f, 0.0f }; Vec3f sp40; f32 var_fv0; u8 sp3B = 0; if (arg0->unk_1C.unk_14 == -1) { Matrix_Translate(gGfxMatrix, arg0->obj.pos.x, arg0->obj.pos.y + D_8017847C, arg0->obj.pos.z + D_80177D20, 1); } else { Matrix_Translate(gGfxMatrix, arg0->obj.pos.x, arg0->obj.pos.y, arg0->obj.pos.z + D_80177D20, 1); } Matrix_MultVec3f(gGfxMatrix, &sp4C, &sp40); if ((D_80178234 == 0x12) || (D_80178234 == 0x11)) { var_fv0 = -20000.0f; } else { var_fv0 = -10000.0f; } if ((sp40.z < 0.0f) && (var_fv0 < sp40.z) && (fabsf(sp40.x) < (fabsf(sp40.z * 0.5f) + 500.0f)) && (fabsf(sp40.y) < (fabsf(sp40.z * 0.5f) + 500.0f))) { if (arg0->unk_1C.unk_00 != NULL) { Matrix_RotateY(gGfxMatrix, arg0->obj.rot.y * M_DTOR, 1); Matrix_RotateX(gGfxMatrix, arg0->obj.rot.x * M_DTOR, 1); Matrix_RotateZ(gGfxMatrix, arg0->obj.rot.z * M_DTOR, 1); Matrix_SetGfxMtx(&gMasterDisp); arg0->unk_1C.unk_00(&arg0->obj); } sp3B = 1; } func_8005F290(&arg0->unk_80, &sp40); if ((sp3B == 0) && (arg0->obj.id != 0x160) && (arg0->obj.id != 0x175) && (D_801778E8 == 0)) { func_80060FBC(&arg0->obj, &arg0->unk_80); } } #else Vec3f D_800CFD10 = { 0.0f, 0.0f, 0.0f }; void func_8005E538(Object_8C* arg0); #pragma GLOBAL_ASM("asm/us/nonmatchings/main/fox_edisplay/func_8005E538.s") #endif #ifdef NON_MATCHING void func_8005E7B8(Object_6C* arg0, s32 arg1) { Vec3f sp44 = { 0.0f, 0.0f, 0.0f }; Vec3f sp38; u8 var_v0; Matrix_Translate(gGfxMatrix, arg0->obj.pos.x, arg0->obj.pos.y, arg0->obj.pos.z + D_80177D20, 1); Matrix_MultVec3f(gGfxMatrix, &sp44, &sp38); var_v0 = 0; if ((sp38.z < 0.0f) && (sp38.z > -12000.0f) && (fabsf(sp38.x) < (fabsf(sp38.z * 0.5f) + 500.0f)) && (fabsf(sp38.y) < (fabsf(sp38.z * 0.5f) + 500.0f))) { if (arg0->unk_1C.unk_00 != NULL) { Matrix_RotateY(gGfxMatrix, arg0->obj.rot.y * M_DTOR, 1); Matrix_RotateX(gGfxMatrix, arg0->obj.rot.x * M_DTOR, 1); Matrix_RotateZ(gGfxMatrix, arg0->obj.rot.z * M_DTOR, 1); Matrix_SetGfxMtx(&gMasterDisp); if (arg0->unk_1C.unk_04 == 0) { gSPDisplayList(gMasterDisp++, arg0->unk_1C.unk_00); } else { arg0->unk_1C.unk_00(&arg0->obj); } } var_v0 = 1; } func_8005F290(&arg0->unk_5C, &sp38); if ((var_v0 == 0) && (D_80177880 == 1) && (D_801778A8 == 1) && (arg0->obj.id < 0x150) && (D_80178234 != 9)) { func_80060FBC(&arg0->obj, &arg0->unk_5C); } } #else Vec3f D_800CFD1C = { 0.0f, 0.0f, 0.0f }; void func_8005E7B8(Object_6C* arg0, s32 arg1); #pragma GLOBAL_ASM("asm/us/nonmatchings/main/fox_edisplay/func_8005E7B8.s") #endif void func_8005EA24(Object_2F4* arg0) { Matrix_Translate(gGfxMatrix, arg0->obj.pos.x, arg0->unk_178 + 3.0f, arg0->obj.pos.z, 1); if (D_80178234 == 0xE) { Matrix_RotateY(gGfxMatrix, arg0->unk_180, 1); Matrix_RotateX(gGfxMatrix, arg0->unk_17C, 1); Matrix_RotateZ(gGfxMatrix, arg0->unk_184, 1); Matrix_RotateY(gGfxMatrix, -arg0->unk_180, 1); } Matrix_Scale(gGfxMatrix, 1.4f, 0.0f, 1.4f, 1); Matrix_RotateY(gGfxMatrix, (arg0->obj.rot.y + 180.0f) * M_DTOR, 1); Matrix_RotateZ(gGfxMatrix, arg0->obj.rot.z * M_DTOR, 1); Matrix_SetGfxMtx(&gMasterDisp); if (arg0->unk_0E4 < 4) { Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, 30.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_1032780); } else if (D_80178234 == 0x10) { if ((arg0->unk_0B6 == 1) || (arg0->unk_0B6 == 2)) { gSPDisplayList(gMasterDisp++, D_600D730); } else { gSPDisplayList(gMasterDisp++, D_600DBC0); } } else if ((arg0->unk_0E4 < 8) || (D_80178234 != 0xE)) { gSPDisplayList(gMasterDisp++, D_F014310); } else if (D_80178234 == 0xE) { gSPDisplayList(gMasterDisp++, D_6009F90); } else { gSPDisplayList(gMasterDisp++, D_F014310); } } void func_8005ECD8(s32 arg0, Object* arg1) { func_800B8DD0(&gMasterDisp, 0x42); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 0, 0, 0, 180); if (arg1->id == 0xC5) { func_8005EA24(&D_80163FE0[arg0]); } else { switch (arg1->id) { case 0xE6: Matrix_Translate(gGfxMatrix, arg1->pos.x, D_80177940 + 2.0f + D_80163FE0[arg0].unk_118, arg1->pos.z + D_80177D20, 1); break; case 0xE5: case 0xE7: Matrix_Translate(gGfxMatrix, arg1->pos.x, D_80177940 + 2.0f + D_80163FE0[arg0].unk_114, arg1->pos.z + D_80177D20, 1); break; case 0x13C: Matrix_Translate(gGfxMatrix, arg1->pos.x, D_80177940 + 2.0f + D_8017847C, arg1->pos.z, 1); break; default: Matrix_Translate(gGfxMatrix, arg1->pos.x, D_80177940 + 2.0f, arg1->pos.z + D_80177D20, 1); break; } if ((D_801784AC != 4) || (arg1->id == 0xC8) || (arg1->id == 0xC3) || (arg1->id == 0xC6)) { Matrix_Scale(gGfxMatrix, 1.0f, 0.0f, 1.0f, 1); Matrix_RotateY(gGfxMatrix, arg1->rot.y * M_DTOR, 1); } if ((arg1->id < 0x124) && (arg1->id != 0xE6) && (arg1->id != 0xE5) && (arg1->id != 0xE7)) { Matrix_RotateX(gGfxMatrix, arg1->rot.x * M_DTOR, 1); Matrix_RotateZ(gGfxMatrix, arg1->rot.z * M_DTOR, 1); } Matrix_SetGfxMtx(&gMasterDisp); func_8005BAB4(arg1->id, arg0); } } void func_8005F030(Vec3f* arg0) { if (arg0->x > 5000.0f) { arg0->x = 5000.0f; } if (arg0->x < -5000.0f) { arg0->x = -5000.0f; } if (arg0->y > 2000.0f) { arg0->y = 2000.0f; } if (arg0->y < -2000.0f) { arg0->y = -2000.0f; } if (arg0->z > 5000.0f) { arg0->z = 5000.0f; } if (arg0->z < -5000.0f) { arg0->z = -5000.0f; } } void func_8005F0E8(Vec3f* arg0, Vec3f* arg1) { Vec3f sp2C; Vec3f sp20; if (D_801778A8 != 1) { arg0->x = arg0->y = arg0->z = 0.0f; } else { Matrix_RotateY(gCalcMatrix, D_80178280->unk_058, 0); Matrix_RotateX(gCalcMatrix, D_80178280->unk_05C, 1); sp2C.x = arg1->x - D_801779D8.x; sp2C.y = arg1->y - D_801779D8.y; sp2C.z = arg1->z + D_80177D20 - D_801779D8.z; Matrix_MultVec3f(gCalcMatrix, &sp2C, &sp20); arg0->x = sp20.x; arg0->y = sp20.y; arg0->z = sp20.z; } func_8005F030(arg0); } void func_8005F1EC(Vec3f* arg0) { Vec3f sp2C = { 0.0f, 0.0f, 0.0f }; Vec3f sp20; s32 pad; if (D_801778A8 != 1) { arg0->z = 0.0f; arg0->y = 0.0f; arg0->x = 0.0f; } else { Matrix_MultVec3f(&D_801615F0, &sp2C, &sp20); arg0->x = sp20.x; arg0->y = sp20.y; arg0->z = sp20.z; } func_8005F030(arg0); } void func_8005F290(Vec3f* arg0, Vec3f* arg1) { if (D_801778A8 != 1) { arg0->z = 0.0f; arg0->y = 0.0f; arg0->x = 0.0f; } else { arg0->x = arg1->x; arg0->y = arg1->y; arg0->z = arg1->z; } func_8005F030(arg0); } #ifdef NON_MATCHING void func_8005F2F4(Object_58* arg0) { Vec3f sp54 = { 0.0f, 0.0f, 0.0f }; Vec3f sp48; f32 sp44 = 1000.0f; f32 sp40 = -12000.0f; f32 sp3C = 2000.0f; f32 sp38 = 0.5f; if (arg0->obj.id == 0x9C) { sp44 = 4000.0f; sp40 = -13000.0f; sp3C = 4500.0f; } else if (D_80178234 == 9) { sp40 = -20000.0f; sp38 = 0.4f; } else if (arg0->obj.id == 0x8F) { sp44 = 6000.0f; sp40 = -20000.0f; sp3C = 6000.0f; sp38 = 0.9f; } if ((D_80177C98 == 0) || (D_80178234 == 0x11)) { Matrix_Translate(gGfxMatrix, arg0->obj.pos.x, arg0->obj.pos.y + D_8017847C, arg0->obj.pos.z, 1); } else { Matrix_Translate(gGfxMatrix, arg0->obj.pos.x, arg0->obj.pos.y, arg0->obj.pos.z, 1); } Matrix_MultVec3f(gGfxMatrix, &sp54, &sp48); if ((sp48.z < sp44) && (sp40 < sp48.z) && (fabsf(sp48.y) < (fabsf(sp48.z * sp38) + sp3C)) && (fabsf(sp48.x) < (fabsf(sp48.z * sp38) + sp3C))) { func_8005F670(&arg0->obj.pos); if (arg0->obj.id == 0x83) { Matrix_RotateY(gGfxMatrix, arg0->obj.rot.y * M_DTOR, 1); Matrix_RotateX(gGfxMatrix, arg0->obj.rot.x * M_DTOR, 1); Matrix_RotateZ(gGfxMatrix, arg0->obj.rot.z * M_DTOR, 1); Matrix_RotateY(gGfxMatrix, M_PI / 2.0f, 1); Matrix_Translate(gGfxMatrix, -551.0f, 0.0f, 0.0f, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_6007650); } else { Matrix_RotateY(gGfxMatrix, arg0->obj.rot.y * M_DTOR, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, arg0->unk_1C.unk_00); } } } #else Vec3f D_800CFD34 = { 0.0f, 0.0f, 0.0f }; void func_8005F2F4(Object_58*); #pragma GLOBAL_ASM("asm/us/nonmatchings/main/fox_edisplay/func_8005F2F4.s") #endif void func_8005F670(Vec3f* arg0) { Vec3f sp9C; f32 sp98; f32 sp94; f32 temp_fv0; Vec3f sp84; f32 temp1; f32 temp2; f32 var_fs0; Vec3f sp6C; f32 temp3; f32 pad; if (D_8017836C > 0.01f) { sp9C.x = arg0->x - D_80178370; sp9C.y = arg0->y - D_80178374; sp9C.z = arg0->z - D_80178378; temp_fv0 = sqrtf(VEC3F_SQ(sp9C)); if (D_80178280->unk_1C8 == 2) { var_fs0 = 700.0f / temp_fv0; } else { var_fs0 = 200.0f / temp_fv0; } if (var_fs0 > 1.0f) { var_fs0 = 1.0f; } if (D_8017812C == 2) { var_fs0 = 1.0f; } sp94 = Math_Atan2F(sp9C.x, sp9C.z); sp98 = -Math_Atan2F(sp9C.y, sqrtf(SQ(sp9C.x) + SQ(sp9C.z))); Matrix_Push(&gCalcMatrix); Matrix_RotateZ(gCalcMatrix, D_80178280[D_801778A0].unk_034 * D_80177950 * M_DTOR, 0); Matrix_RotateX(gCalcMatrix, -D_80178280[D_801778A0].unk_05C, 1); Matrix_RotateY(gCalcMatrix, D_80178280[D_801778A0].unk_058 + sp94, 1); Matrix_RotateX(gCalcMatrix, sp98, 1); sp6C.x = 0.0f; sp6C.y = 0.0f; sp6C.z = -100.0f; Matrix_MultVec3fNoTranslate(gCalcMatrix, &sp6C, &sp84); Matrix_Pop(&gCalcMatrix); temp1 = D_80178360 * D_8017836C * var_fs0; temp2 = D_80178364 * D_8017836C * var_fs0; temp3 = D_80178368 * D_8017836C * var_fs0; Lights_SetTwoLights(&gMasterDisp, D_801784DC, D_801784E0, D_801784E4, sp84.x, sp84.y, sp84.z, D_80178548, D_8017854C, D_80178550, temp1, temp2, temp3, D_80178554, D_80178558, D_8017855C); } } #ifdef NON_MATCHING s32 func_8005F9DC(Vec3f* arg0) { Vec3f sp2C; Vec3f sp20; Matrix_RotateY(gCalcMatrix, D_80178280[D_801778A0].unk_058, 0); Matrix_RotateX(gCalcMatrix, D_80178280[D_801778A0].unk_05C, 1); sp2C.x = arg0->x - D_80178280[D_801778A0].unk_040.x; sp2C.y = arg0->y - D_80178280[D_801778A0].unk_040.y; sp2C.z = arg0->z - D_80178280[D_801778A0].unk_040.z; Matrix_MultVec3fNoTranslate(gCalcMatrix, &sp2C, &sp20); if ((sp20.z < 1000.0f) && (sp20.z > -13000.0f) && (fabsf(sp20.x) < (fabsf(sp20.z * 0.4f) + 2000.0f)) && (fabsf(sp20.y) < (fabsf(sp20.y * 0.4f) + 2000.0f))) { return 1; } return 0; } #else #pragma GLOBAL_ASM("asm/us/nonmatchings/main/fox_edisplay/func_8005F9DC.s") #endif void func_8005FB70(s32 arg0) { Vec3f spAC; s32 i; s32 pad[5]; // probably separate iterators for each loop Object_2F4* var_s0_5; Object_408* var_s0_3; Object_4C* var_s0_4; Object_58* var_s0; Object_6C* var_s0_6; Object_80* var_s0_2; if ((D_80177880 == 1) && (D_80178234 != 0x10)) { func_800BA1D0(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); if (D_80177AB0 == 5) { gSPClearGeometryMode(gMasterDisp++, G_CULL_BACK); } for (i = 0, var_s0 = D_801782A8; i < 200; i++, var_s0++) { if ((var_s0->obj.status == 2) && (var_s0->obj.id != 0x93)) { if (D_80178234 == 0x11) { spAC.x = var_s0->unk_48.x; spAC.y = var_s0->unk_48.y; spAC.z = var_s0->unk_48.z; Matrix_MultVec3fNoTranslate(&D_E51970_8019EE80, &spAC, &var_s0->obj.pos); var_s0->obj.rot.y = var_s0->unk_54 + D_8016F110->obj.rot.y; } Matrix_Push(&gGfxMatrix); func_8005F2F4(var_s0); Matrix_Pop(&gGfxMatrix); } } } else { func_800BA1D0(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); for (i = 0, var_s0_2 = D_80161B00; i < ARRAY_COUNT(D_80161B00); i++, var_s0_2++) { if (var_s0_2->obj.status >= 2) { if (arg0 > 0) { func_8005F670(&var_s0_2->obj.pos); } Matrix_Push(&gGfxMatrix); func_8005D654(var_s0_2, arg0); Matrix_Pop(&gGfxMatrix); func_8005F1EC(&var_s0_2->unk_70); } } } for (i = 0, var_s0_3 = D_8016F110; i < ARRAY_COUNT(D_8016F110); i++, var_s0_3++) { if ((var_s0_3->obj.status >= 2) && (var_s0_3->obj.id != 0x136)) { if (!(var_s0_3->unk_05C & 1)) { func_800BA1D0(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); } else { func_800BA400(); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 64, 64, 255, 255); } func_800597C0(arg0); Matrix_Push(&gGfxMatrix); func_8005E1B8(var_s0_3, arg0); Matrix_Pop(&gGfxMatrix); if ((var_s0_3->unk_05E != 0) && (D_801615D0.y > 0.0f)) { Matrix_Push(&gGfxMatrix); func_8005ECD8(i, &var_s0_3->obj); Matrix_Pop(&gGfxMatrix); } } } Lights_SetOneLight(&gMasterDisp, D_801784DC, D_801784E0, D_801784E4, D_80178548, D_8017854C, D_80178550, D_80178554, D_80178558, D_8017855C); for (i = 0, var_s0_4 = D_80163400; i < ARRAY_COUNT(D_80163400); i++, var_s0_4++) { if ((var_s0_4->obj.status >= 2) && (func_80060FE4(&var_s0_4->obj.pos, -12000.0f) != 0)) { Matrix_Push(&gGfxMatrix); if ((var_s0_4->obj.id == 0xA5) || (var_s0_4->obj.id == 0xA6)) { func_800B9EB0(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); } else { func_800B9B38(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); } func_8005D8B8(var_s0_4, arg0); Matrix_Pop(&gGfxMatrix); } } for (i = 0, var_s0_5 = D_80163FE0; i < ARRAY_COUNT(D_80163FE0); i++, var_s0_5++) { if (var_s0_5->obj.status >= 2) { if (!(var_s0_5->unk_0C6 & 1)) { if (D_80178234 == 0xF) { func_800BA1A0(); } else { func_800BA1D0(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); } } else { func_800BA400(); if (var_s0_5->unk_110 >= 0.0f) { gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 0, 0, 255); } else { gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 64, 64, 255, 255); } } switch (D_80177880) { case 0: case 2: Matrix_Push(&gGfxMatrix); if ((D_80178280->unk_1C8 == 2) || (D_80178280->unk_1C8 == 7) || (D_80178234 == 0xD)) { func_8005F670(&var_s0_5->obj.pos); } func_800597C0(arg0); func_8005D954(var_s0_5); Matrix_Pop(&gGfxMatrix); if (var_s0_5->unk_0C9 != 0) { Matrix_Push(&gGfxMatrix); func_8005ECD8(i, &var_s0_5->obj); Matrix_Pop(&gGfxMatrix); } break; case 1: Matrix_Push(&gGfxMatrix); func_8005DBC0(var_s0_5); Matrix_Pop(&gGfxMatrix); if ((var_s0_5->unk_0C9 != 0) && (D_801615EC != 0) && ((D_801615E0.z > -4000.0f) || (D_80178234 != 0x10))) { Matrix_Push(&gGfxMatrix); func_8005ECD8(i, &var_s0_5->obj); Matrix_Pop(&gGfxMatrix); } break; } } } gDPSetFogColor(gMasterDisp++, D_80178320, D_80178328, D_80178330, D_80178338); gSPFogPosition(gMasterDisp++, D_801783D8, D_801783DC); Lights_SetOneLight(&gMasterDisp, -0x3C, -0x3C, 0x3C, 0x96, 0x96, 0x96, 0x14, 0x14, 0x14); for (i = 0, var_s0_6 = D_801737E0; i < ARRAY_COUNT(D_801737E0); i++, var_s0_6++) { if (var_s0_6->obj.status >= 2) { Matrix_Push(&gGfxMatrix); func_800B8DD0(&gMasterDisp, 0x1D); func_800597C0(arg0); func_8005E7B8(var_s0_6, arg0); Matrix_Pop(&gGfxMatrix); } } Lights_SetOneLight(&gMasterDisp, D_801784DC, D_801784E0, D_801784E4, D_80178548, D_8017854C, D_80178550, D_80178554, D_80178558, D_8017855C); } void func_8006046C(s32 arg0) { s32 i; Object_408* var_s0_2; Object_8C* var_s0; func_800B8DD0(&gMasterDisp, 0x40); for (i = 0, var_s0 = D_80170130; i < ARRAY_COUNT(D_80170130); i++, var_s0++) { if (var_s0->obj.status >= 2) { if (var_s0->unk_1C.unk_14 == 1) { var_s0->obj.rot.y = (-D_80178280[D_801778A0].unk_058 * 180.0f) / M_PI; var_s0->obj.rot.x = (D_80178280[D_801778A0].unk_05C * 180.0f) / M_PI; } if (D_80177880 == 1) { Matrix_Push(&gGfxMatrix); func_8005E538(var_s0); Matrix_Pop(&gGfxMatrix); } else { Matrix_Push(&gGfxMatrix); func_8005E454(var_s0, arg0); Matrix_Pop(&gGfxMatrix); func_8005F1EC(&var_s0->unk_80); if (var_s0->obj.id == 0x176) { Matrix_Push(&gGfxMatrix); func_8005ECD8(i, &var_s0->obj); Matrix_Pop(&gGfxMatrix); } } } } for (i = 0, var_s0_2 = D_8016F110; i < ARRAY_COUNT(D_8016F110); i++, var_s0_2++) { if ((var_s0_2->obj.status >= 2) && (var_s0_2->obj.id == 0x136)) { if (!(var_s0_2->unk_05C & 1)) { func_800BA1D0(D_80178320, D_80178328, D_80178330, D_80178338, D_801783D8, D_801783DC); } else { func_800BA400(); gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 64, 64, 255, 255); } Matrix_Push(&gGfxMatrix); func_8005E1B8(var_s0_2, arg0); Matrix_Pop(&gGfxMatrix); } } } void func_80060714(s32 arg0) { D_80161410 = 1; func_8005FB70(1); if ((D_80161A88 == 2) && (D_80178280[0].unk_1C8 != 2)) { D_80161410 = -1; Lights_SetOneLight(&gMasterDisp, D_801784DC, -1 * D_801784E0, D_801784E4, D_80178548, D_8017854C, D_80178550, D_80178554, D_80178558, D_8017855C); Matrix_Push(&gGfxMatrix); Matrix_Scale(gGfxMatrix, 1.0f, -1.0f, 1.0f, 1); func_8005FB70(-1); Matrix_Pop(&gGfxMatrix); Lights_SetOneLight(&gMasterDisp, D_801784DC, D_801784E0, D_801784E4, D_80178548, D_8017854C, D_80178550, D_80178554, D_80178558, D_8017855C); } } void func_8006089C(u8 arg0) { if (arg0 == 0) { D_80161410 = 1; func_8006046C(1); } else if ((D_80161A88 == 2) && (D_80178280->unk_1C8 != 2)) { D_80161410 = -1; Matrix_Push(&gGfxMatrix); Matrix_Scale(gGfxMatrix, 1.0f, -1.0f, 1.0f, 1); func_8006046C(-1); Matrix_Pop(&gGfxMatrix); } D_80161410 = 1; } Vtx D_800CFD40[] = { VTX(1, 0, 0, 0, 0, 255, 255, 255, 255), VTX(-1, 0, 0, 0, 0, 255, 255, 255, 255), VTX(-1, 0, -1, 0, 0, 255, 255, 255, 255), VTX(1, 0, -1, 0, 0, 255, 255, 255, 255), }; Gfx D_800CFD80[] = { gsSPVertex(D_800CFD40, 4, 0), gsSP1Quadrangle(1, 2, 3, 0, 0), gsSPEndDisplayList(), }; #ifdef NON_MATCHING void func_80060968(void) { s32 i; s32 var_a1; if (D_80178234 == 0xB) { func_800B8DD0(&gMasterDisp, 0x21); gSPClearGeometryMode(gMasterDisp++, G_CULL_BACK); } else if ((D_80178234 == 0xD) || (D_80178234 == 9)) { func_800B8DD0(&gMasterDisp, 0x29); } else { func_800B92F8(); } for (i = 0; i < ARRAY_COUNT(D_80174750); i++) { if (D_80174750[i].unk_00 != 0) { Matrix_Push(&gGfxMatrix); Matrix_Translate(gGfxMatrix, D_80174750[i].unk_04, D_80174750[i].unk_08, D_80174750[i].unk_0C + D_80177D20, 1); Matrix_RotateY(gGfxMatrix, D_80174750[i].unk_20, 1); Matrix_RotateX(gGfxMatrix, D_80174750[i].unk_1C, 1); Matrix_RotateZ(gGfxMatrix, D_80174750[i].unk_20, 1); Matrix_Scale(gGfxMatrix, D_80174750[i].unk_28, D_80174750[i].unk_28, D_80174750[i].unk_24, 1); if ((D_80178234 == 0xD) || (D_80178234 == 9)) { var_a1 = (D_80177DB0 & 1) ? 180 : 50; gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, 255, 255, 255, var_a1); if (D_80178234 == 0xD) { Matrix_Scale(gGfxMatrix, 0.01f, 0.3f, 0.0025f, 1); Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, -200.0f, 1); Matrix_RotateZ(gGfxMatrix, D_80177DB0 * 5.0f * M_DTOR, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_60119A0); } else if (D_80178234 == 9) { Matrix_Scale(gGfxMatrix, 1.0f, 1.0f, 0.0025f, 1); Matrix_Translate(gGfxMatrix, 0.0f, 0.0f, -200.0f, 1); Matrix_RotateZ(gGfxMatrix, D_80177DB0 * 25.0f * M_DTOR, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPDisplayList(gMasterDisp++, D_C017440); } } else { Matrix_SetGfxMtx(&gMasterDisp); if (D_80178234 == 0xB) { gSPDisplayList(gMasterDisp++, D_6012C00); } else { gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, D_80174750[i].unk_2C, D_80174750[i].unk_2D, D_80174750[i].unk_2E, D_80174750[i].unk_2F); gSPDisplayList(gMasterDisp++, D_800CFD80); } } Matrix_Pop(&gGfxMatrix); } } } #else void func_80060968(void); #pragma GLOBAL_ASM("asm/us/nonmatchings/main/fox_edisplay/func_80060968.s") #endif void func_80060D94(s32 arg0) { UnkStruct_D_80174750* temp_s0 = &D_80174750[arg0]; if (temp_s0->unk_2F == 0xFF) { func_800B8DD0(&gMasterDisp, 5); } else { func_800B8DD0(&gMasterDisp, 0xE); } gDPSetPrimColor(gMasterDisp++, 0x00, 0x00, temp_s0->unk_2C, temp_s0->unk_2D, temp_s0->unk_2E, temp_s0->unk_2F); Matrix_Push(&gGfxMatrix); Matrix_Translate(gGfxMatrix, temp_s0->unk_04, temp_s0->unk_08, temp_s0->unk_0C, 1); Matrix_RotateY(gGfxMatrix, temp_s0->unk_20, 1); Matrix_RotateX(gGfxMatrix, temp_s0->unk_1C, 1); Matrix_RotateZ(gGfxMatrix, temp_s0->unk_1C, 1); Matrix_Scale(gGfxMatrix, temp_s0->unk_28, 1.0f, temp_s0->unk_24, 1); Matrix_SetGfxMtx(&gMasterDisp); gSPClearGeometryMode(gMasterDisp++, G_CULL_BACK); gSPDisplayList(gMasterDisp++, D_800CFD80); gSPSetGeometryMode(gMasterDisp++, G_CULL_BACK); Matrix_Pop(&gGfxMatrix); }