#include "ext_math.h" #include "game/audio.h" #include "game/gamework_data.h" #include "game/hsfdraw.h" #include "game/hsfman.h" #include "game/hsfmotion.h" #include "game/sprite.h" #include "REL/m406Dll.h" typedef struct UnkM406Struct { /* 0x00 */ u8 unk_00; /* 0x01 */ u8 unk_01; /* 0x02 */ char unk02[2]; /* 0x04 */ float unk_04; /* 0x08 */ float unk_08; /* 0x0C */ float unk_0C; /* 0x10 */ Vec unk_10; /* 0x1C */ Vec unk_1C; /* 0x28 */ float unk_28; /* 0x2C */ float unk_2C; } UnkM406Struct; /* size = 0x30 */ typedef struct UnkM406Struct3 { /* 0x00 */ s32 unk_00; /* 0x04 */ float unk_04; /* 0x08 */ s32 unk_08; /* 0x0C */ s32 unk_0C; /* 0x10 */ float unk_10; /* 0x14 */ float unk_14; /* 0x18 */ Vec unk_18; /* 0x24 */ struct UnkM406Struct5 *unk_24; } UnkM406Struct3; /* size = 0x28 */ typedef struct UnkM406Struct4 { /* 0x00 */ s32 unk_00; /* 0x04 */ s32 unk_04; /* 0x08 */ s32 unk_08; /* 0x0C */ s32 unk_0C; /* 0x10 */ float unk_10; /* 0x14 */ float unk_14; /* 0x18 */ float unk_18; /* 0x1C */ float unk_1C; /* 0x20 */ float unk_20; /* 0x24 */ float unk_24; /* 0x28 */ float unk_28; /* 0x2C */ float unk_2C; /* 0x30 */ Vec unk_30; /* 0x3C */ Vec unk_3C; } UnkM406Struct4; /* size = 0x48 */ typedef struct UnkM406Unk120Struct { /* 0x00 */ s32 unk_00; /* 0x04 */ s32 unk_04; /* 0x08 */ s32 unk_08; /* 0x0C */ float unk_0C; /* 0x10 */ float unk_10; /* 0x14 */ float unk_14; /* 0x18 */ float unk_18; /* 0x1C */ float unk_1C; /* 0x20 */ s32 unk_20; /* 0x24 */ s32 unk_24; /* 0x28 */ s32 unk_28; /* 0x2C */ UnkM406Struct3 *unk_2C; /* 0x30 */ UnkM406Struct4 *unk_30; /* 0x34 */ Vec unk_34; /* 0x40 */ Vec unk_40; /* 0x4C */ Mtx unk_4C; /* 0x7C */ s32 unk_7C; /* 0x80 */ s32 unk_80; /* 0x84 */ Vec *unk_84; /* 0x88 */ Vec *unk_88; /* 0x8C */ Vec2f *unk_8C; /* 0x90 */ GXColor *unk_90; /* 0x94 */ UnkM406Struct *unk_94; /* 0x98 */ s32 unk_98; /* 0x9C */ s16 (*unk_9C)[4]; /* 0xA0 */ u32 unk_A0; /* 0xA4 */ void *unk_A4; /* 0xA8 */ u8 *unk_A8; /* 0xAC */ s32 unk_AC; /* 0xB0 */ s32 unk_B0; /* 0xB4 */ float unk_B4; /* 0xB8 */ float unk_B8; /* 0xBC */ u8 *unk_BC; /* 0xC0 */ s32 unk_C0; /* 0xC4 */ s32 unk_C4; /* 0xC8 */ float unk_C8; /* 0xCC */ float unk_CC; } UnkM406Unk120Struct; /* size = 0xD0 */ typedef struct UnkM406Struct5 { /* 0x00 */ s16 unk_00; /* 0x02 */ s16 unk_02; /* 0x04 */ Vec unk_04; /* 0x10 */ float unk_10; /* 0x14 */ float unk_14; /* 0x18 */ float unk_18; /* 0x1C */ char unk1C[0xC]; /* 0x28 */ float unk_28; /* 0x2C */ float unk_2C; /* 0x30 */ Vec unk_30; /* 0x3C */ GXColor unk_3C; /* 0x40 */ s32 unk_40; } UnkM406Struct5; /* size = 0x44 */ // most likely UnkM426Struct8 typedef struct UnkM406Struct9 { /* 0x00 */ s16 unk00; /* 0x02 */ s16 unk_02; /* 0x04 */ s16 unk_04; /* 0x06 */ char unk06[2]; } UnkM406Struct9; /* size = 0x08 */ typedef void (*UnkM406Unk120Struct2Hook)(struct model_data *, struct UnkM406Unk120Struct2 *, Mtx); typedef struct UnkM406Unk120Struct2 { /* 0x00 */ s16 unk_00; /* 0x02 */ s16 unk_02; /* 0x04 */ char unk04[0x18]; /* 0x1C */ UnkM406Struct9 *unk_1C; /* 0x20 */ u8 unk_20; /* 0x21 */ u8 unk_21; /* 0x22 */ u8 unk_22; /* 0x23 */ char unk23; /* 0x24 */ s16 unk_24; /* 0x26 */ s16 unk_26; /* 0x28 */ s32 unk_28; /* 0x2C */ s32 unk_2C; /* 0x30 */ u32 unk_30; /* 0x34 */ u32 unk_34; /* 0x38 */ AnimData *unk_38; /* 0x3C */ UnkM406Struct5 *unk_3C; /* 0x40 */ Vec *unk_40; /* 0x44 */ Vec2f *unk_44; /* 0x48 */ void *unk_48; /* 0x4C */ UnkM406Unk120Struct2Hook unk_4C; /* 0x50 */ ModelData *unk_50; } UnkM406Unk120Struct2; /* size = 0x54 */ // strongly assumed to be a copy of UnkModelDataUnk120Struct typedef struct UnkM406Struct6 { /* 0x00 */ s32 unk_00; /* 0x04 */ s32 unk_04; } UnkM406Struct6; /* size = 0x08 */ // probably the same as UnkM426Struct13 typedef struct UnkM406Struct7 { /* 0x00 */ u8 unk_00; /* 0x01 */ u8 unk_01; /* 0x02 */ char unk02[2]; /* 0x04 */ s32 unk_04; /* 0x08 */ s32 unk_08; /* 0x0C */ float unk_0C; /* 0x10 */ float unk_10; /* 0x14 */ float unk_14; /* 0x18 */ float unk_18; /* 0x1C */ Mtx unk_1C; } UnkM406Struct7; /* size = 0x4C */ typedef struct UnkM406Struct8 { /* 0x00 */ AnimData *unk_00; /* 0x04 */ AnimData *unk_04; /* 0x08 */ AnimData *unk_08; /* 0x0C */ AnimData *unk_0C; /* 0x10 */ s32 unk_10; /* 0x14 */ s32 unk_14; /* 0x18 */ s32 unk_18; /* 0x1C */ s32 unk_1C; /* 0x20 */ s32 unk_20; /* 0x24 */ float unk_24; /* 0x28 */ float unk_28; } UnkM406Struct8; /* size = 0x2C */ typedef struct UnkM406Struct10 { /* 0x00 */ s32 unk_00; /* 0x04 */ s32 unk_04; /* 0x08 */ AnimData *unk_08; } UnkM406Struct10; /* size = 0x0C */ void fn_1_292C(omObjData *object); void fn_1_2C24(omObjData *object); void fn_1_3158(void); void fn_1_4568(void); void fn_1_45BC(ModelData *arg0, Mtx arg1); void fn_1_6304(ModelData *arg0, Mtx arg1); void fn_1_64F8(UnkM406Struct2 *arg0); s32 fn_1_66F4(float arg8, float *arg0); void fn_1_67CC(ModelData *arg0); void fn_1_6F24(void); void fn_1_6FFC(void); void fn_1_717C(void); s32 fn_1_71C4(Vec arg0, Vec arg1, float arg8, float arg9, GXColor arg2); void fn_1_7718(void); void fn_1_77F0(void); void fn_1_79B0(void); s32 fn_1_79F8(Vec arg0, Vec arg1, float arg8, float arg9, GXColor arg2); UnkM406Struct5 *fn_1_7B2C(s32 arg0); void fn_1_7B9C(void); void fn_1_7C4C(void); void fn_1_7DAC(void); s32 fn_1_7DB0(Vec arg0, Vec arg1, float arg8, GXColor arg2); void fn_1_7ED0(void); void fn_1_7F80(void); void fn_1_8100(void); s32 fn_1_8104(Vec arg0, Vec arg1, float arg8, GXColor arg2); void fn_1_8244(s32 arg0, s32 arg1, float arg8, float arg9); void fn_1_8F98(void); void fn_1_91E0(void); void fn_1_94BC(void); void fn_1_9F78(void); void fn_1_A278(void); void fn_1_A2C8(ModelData *arg0, UnkM406Unk120Struct2 *arg1, Mtx arg2); void fn_1_ADB4(ModelData *arg0, Mtx arg1); void fn_1_B1E0(float arg8); s16 fn_1_B474(AnimData *arg0, s16 arg1); void fn_1_BC18(ModelData *arg0, Mtx arg1); s16 fn_1_C4F4(s16 arg0); void fn_1_C86C(ModelData *arg0, Mtx arg1); void fn_1_CDD8(s32 arg0, float arg8, float arg9, float argA, float argB); void fn_1_CF24(s32 arg0, u8 arg1, u8 arg2, u8 arg3); s16 fn_1_D06C(ModelData *arg0, Mtx arg1, Mtx arg2, float arg8); void fn_1_D13C(LightData *arg0, s16 arg1, Mtx arg2, Mtx arg3, float arg8); void fn_1_D488(float arg8, Vec *arg0, Vec *arg1, Vec *arg2); void fn_1_D518(Mtx arg0, Vec *arg1); float fn_1_D5CC(Vec *arg0, Vec *arg1, float arg8, float arg9); extern u32 GlobalCounter; Vec lbl_1_data_F0[0x46] = { { -495.876f, 50.005f, -0.0f }, { -500.023f, -2841.226f, -5007.74f }, { -502.015f, -7170.411f, -12506.11f }, { -515.622f, -8314.231f, -14487.27f }, { -515.6f, -8761.908f, -15262.67f }, { -508.661f, -9195.703f, -16014.02f }, { -494.762f, -9629.499f, -16765.38f }, { -473.947f, -10063.294f, -17516.73f }, { -471.378f, -10495.727f, -18265.73f }, { -495.719f, -10915.74f, -18993.21f }, { -552.519f, -11337.781f, -19724.21f }, { -621.485f, -11611.703f, -20198.66f }, { -731.018f, -11887.653f, -20676.62f }, { -950.131f, -12303.607f, -21397.07f }, { -1209.766f, -12735.795f, -22145.64f }, { -1469.474f, -13170.012f, -22897.73f }, { -1627.69f, -13466.252f, -23410.83f }, { -1757.595f, -13772.641f, -23941.51f }, { -1838.731f, -14079.026f, -24472.19f }, { -1871.186f, -14393.528f, -25016.92f }, { -1834.734f, -14703.97f, -25554.62f }, { -1749.541f, -15014.414f, -26092.33f }, { -1623.78f, -15312.685f, -26608.94f }, { -1384.433f, -15761.101f, -27385.62f }, { -1124.798f, -16191.259f, -28130.68f }, { -775.859f, -16769.535f, -29132.28f }, { -568.923f, -17183.457f, -29849.22f }, { -398.537f, -17621.73f, -30608.33f }, { -187.485f, -18055.945f, -31360.41f }, { 96.491f, -18634.223f, -32362.02f }, { 254.886f, -19042.057f, -33068.41f }, { 315.738f, -19315.977f, -33542.85f }, { 331.965f, -19581.783f, -34003.24f }, { 291.397f, -19839.473f, -34449.57f }, { 189.969f, -20091.07f, -34885.35f }, { -12.871f, -20340.645f, -35317.62f }, { -325.245f, -20598.332f, -35763.96f }, { -747.265f, -20870.219f, -36234.88f }, { -1230.024f, -21152.258f, -36723.38f }, { -2276.853f, -21730.535f, -37724.99f }, { -2759.968f, -22028.799f, -38241.6f }, { -3189.989f, -22343.3f, -38786.33f }, { -3514.533f, -22669.979f, -39352.15f }, { -3620.335f, -22840.408f, -39647.35f }, { -3693.358f, -23018.965f, -39956.61f }, { -3705.528f, -23193.463f, -40258.85f }, { -3693.358f, -23367.96f, -40561.09f }, { -3551.37f, -23698.695f, -41133.94f }, { -3307.945f, -24019.275f, -41689.2f }, { -2995.571f, -24323.633f, -42216.36f }, { -2646.686f, -24621.904f, -42732.99f }, { -1920.124f, -25200.174f, -43734.58f }, { -1457.648f, -25612.07f, -44448.0f }, { -1238.474f, -25871.78f, -44897.83f }, { -1084.316f, -26137.584f, -45358.22f }, { -958.555f, -26417.594f, -45843.21f }, { -861.049f, -26697.596f, -46328.19f }, { -783.97f, -26979.635f, -46816.69f }, { -715.004f, -27261.672f, -47305.2f }, { -617.584f, -27979.957f, -48549.3f }, { -548.553f, -28700.271f, -49796.93f }, { -491.712f, -29278.535f, -50798.51f }, { -475.485f, -29856.814f, -51800.12f }, { -479.514f, -30433.059f, -52798.2f }, { -505.531f, -34619.363f, -60049.28f }, { -513.632f, -34659.062f, -60100.39f }, { -509.573f, -34721.215f, -60151.54f }, { -509.589f, -34805.496f, -60191.15f }, { -509.587f, -34970.055f, -60233.17f }, { -509.591f, -45195.266f, -61377.84f }, }; Vec lbl_1_data_438[0x46] = { { 497.979f, 49.997f, 0.0f }, { 501.235f, -2841.251f, -5007.79f }, { 497.983f, -7170.06f, -12505.5f }, { 479.876f, -8314.231f, -14487.27f }, { 479.899f, -8761.908f, -15262.67f }, { 486.837f, -9195.703f, -16014.02f }, { 500.736f, -9629.499f, -16765.38f }, { 521.552f, -10063.294f, -17516.73f }, { 524.121f, -10495.727f, -18265.73f }, { 503.13f, -10936.027f, -19028.35f }, { 446.486f, -11379.887f, -19797.14f }, { 364.665f, -11685.236f, -20326.02f }, { 245.082f, -11987.438f, -20849.45f }, { 18.48f, -12434.451f, -21623.7f }, { -252.156f, -12875.162f, -22387.03f }, { -497.617f, -13300.134f, -23123.1f }, { -655.129f, -13580.305f, -23608.37f }, { -768.419f, -13847.879f, -24071.83f }, { -843.945f, -14131.193f, -24562.54f }, { -875.687f, -14393.528f, -25016.92f }, { -850.353f, -14653.739f, -25467.62f }, { -768.533f, -14927.61f, -25941.98f }, { -642.655f, -15201.48f, -26416.33f }, { -428.664f, -15620.156f, -27141.5f }, { -170.569f, -16051.424f, -27888.48f }, { 188.182f, -16636.941f, -28902.62f }, { 408.467f, -17083.947f, -29676.86f }, { 572.186f, -17512.059f, -30418.37f }, { 786.178f, -17940.18f, -31159.9f }, { 1075.696f, -18525.695f, -32174.04f }, { 1245.631f, -18972.703f, -32948.28f }, { 1315.06f, -19274.898f, -33471.7f }, { 1327.648f, -19592.842f, -34022.39f }, { 1283.591f, -19907.637f, -34567.64f }, { 1157.714f, -20235.021f, -35134.68f }, { 887.077f, -20562.406f, -35701.73f }, { 496.857f, -20883.496f, -36257.87f }, { 31.029f, -21188.842f, -36786.75f }, { -491.693f, -21487.889f, -37304.71f }, { -1517.594f, -22057.664f, -38291.59f }, { -1958.808f, -22331.527f, -38765.94f }, { -2323.853f, -22595.953f, -39223.93f }, { -2588.195f, -22850.938f, -39665.58f }, { -2651.134f, -22964.264f, -39861.87f }, { -2695.42f, -23074.441f, -40052.7f }, { -2714.302f, -23187.768f, -40248.99f }, { -2689.126f, -23316.832f, -40472.53f }, { -2594.718f, -23552.928f, -40881.46f }, { -2393.337f, -23814.195f, -41334.0f }, { -2116.406f, -24081.771f, -41797.45f }, { -1782.831f, -24371.38f, -42299.07f }, { -1059.036f, -24941.158f, -43285.95f }, { -561.404f, -25391.299f, -44065.62f }, { -290.767f, -25709.24f, -44616.31f }, { -108.245f, -26024.033f, -45161.55f }, { 23.926f, -26323.088f, -45679.52f }, { 130.922f, -26625.29f, -46202.95f }, { 212.947f, -26918.023f, -46709.98f }, { 275.886f, -27213.93f, -47222.51f }, { 376.588f, -27941.104f, -48482.01f }, { 452.187f, -28658.824f, -49725.14f }, { 508.832f, -29241.193f, -50733.83f }, { 521.5f, -29814.105f, -51726.14f }, { 515.985f, -30433.059f, -52798.2f }, { 503.81f, -34617.785f, -60046.38f }, { 495.709f, -34657.49f, -60097.48f }, { 499.768f, -34719.64f, -60148.64f }, { 499.752f, -34803.92f, -60188.25f }, { 499.754f, -34968.48f, -60230.3f }, { 499.75f, -45193.69f, -61374.92f }, }; Vec lbl_1_data_780[3] = { { 725.7116f, -20607.168f, -35686.844f }, { -3135.352f, -23367.234f, -40490.824f }, { -282.94498f, -26285.674f, -45528.754f }, }; s16 lbl_1_data_7A4 = -1; s32 lbl_1_data_7A8[7] = { DATA_MAKE_NUM(DATADIR_M406, 35), DATA_MAKE_NUM(DATADIR_M406, 36), DATA_MAKE_NUM(DATADIR_M406, 37), DATA_MAKE_NUM(DATADIR_M406, 38), DATA_MAKE_NUM(DATADIR_M406, 39), DATA_MAKE_NUM(DATADIR_M406, 40), DATA_MAKE_NUM(DATADIR_M406, 41), }; s32 lbl_1_data_7C4[7] = { DATA_MAKE_NUM(DATADIR_M406, 48), DATA_MAKE_NUM(DATADIR_M406, 49), DATA_MAKE_NUM(DATADIR_M406, 50), DATA_MAKE_NUM(DATADIR_M406, 51), DATA_MAKE_NUM(DATADIR_M406, 52), DATA_MAKE_NUM(DATADIR_M406, 53), 0, }; s32 lbl_1_data_7E0[6] = { DATA_MAKE_NUM(DATADIR_M406, 42), DATA_MAKE_NUM(DATADIR_M406, 43), DATA_MAKE_NUM(DATADIR_M406, 44), DATA_MAKE_NUM(DATADIR_M406, 45), DATA_MAKE_NUM(DATADIR_M406, 46), DATA_MAKE_NUM(DATADIR_M406, 47), }; Vec lbl_1_data_7F8 = { 0.0f, 0.0f, 0.0f }; Vec lbl_1_data_804 = { -1.0f, -2.0f, -1.0f }; GXColor lbl_1_data_810 = { 0xFF, 0xFF, 0xFF, 0xFF }; Vec lbl_1_data_814 = { 0.0f, 2500.0f, -500.0f }; Vec lbl_1_data_820 = { 0.0f, 1.0f, 0.0f }; Vec lbl_1_data_82C = { 0.0f, 0.0f, 0.0f }; Vec lbl_1_data_838 = { 0.0f, 0.0f, 0.0f }; Vec lbl_1_data_844 = { 0.0f, 1.0f, -1.0f }; GXColor lbl_1_data_850[8] = { { 0xFF, 0xFF, 0xFF, 0xFF }, { 0xC4, 0x2F, 0, 0 }, { 0x45, 0x1C, 0x40, 0 }, { 0xC4, 0x2F, 0, 0 }, { 0, 0, 0, 0 }, { 0, 0, 0, 0 }, { 0, 0, 0, 0 }, { 0x80, 0x80, 0x80, 0xFF }, }; Process *lbl_1_bss_D4; omObjData *lbl_1_bss_D0; omObjData *lbl_1_bss_CC; omObjData *lbl_1_bss_C8; omObjData *lbl_1_bss_C4; s32 lbl_1_bss_C0; s32 lbl_1_bss_BC; UnkM406Struct2 *lbl_1_bss_B8; s32 lbl_1_bss_B4; UnkM406Struct10 *lbl_1_bss_B0; UnkM406Struct10 *lbl_1_bss_AC; UnkM406Struct6 *lbl_1_bss_A8; UnkM406Struct6 *lbl_1_bss_A4; UnkM406Struct7 *lbl_1_bss_A0; UnkM406Struct8 *lbl_1_bss_9C; s32 lbl_1_bss_98; char lbl_1_bss_8C[0xC]; UnkM406Struct5 lbl_1_bss_48; Vec lbl_1_bss_3C; s32 lbl_1_bss_30[3]; extern LightData Hu3DLocalLight[0x20]; omObjData *fn_1_2308(Process *arg0) { s32 var_r31; s32 var_r30; s32 var_r28; lbl_1_bss_D4 = arg0; lbl_1_bss_C0 = 0; lbl_1_bss_BC = 1; lbl_1_bss_98 = -1; omMakeGroupEx(arg0, 1, 1); omMakeGroupEx(arg0, 2, 1); omMakeGroupEx(arg0, 3, 1); lbl_1_bss_D0 = omAddObjEx(arg0, 127, 0, 0, -1, fn_1_292C); var_r28 = Hu3DGLightCreateV(&lbl_1_data_7F8, &lbl_1_data_804, &lbl_1_data_810); Hu3DGLightStaticSet(var_r28, 1); Hu3DGLightInfinitytSet(var_r28); lbl_1_bss_CC = omAddObjEx(arg0, 0x7E, 0x15, 0, 1, fn_1_2C24); for (var_r31 = 0; var_r31 < 7; var_r31++) { var_r30 = lbl_1_bss_CC->model[var_r31] = Hu3DModelCreateFile(lbl_1_data_7A8[var_r31]); Hu3DModelShadowMapSet(var_r30); Hu3DModelAttrSet(var_r30, 1); if (var_r31 < 6) { fn_1_CDD8(var_r30, 1.25f, 1.05f, 1.0f, 1.0f); } if (var_r31 < 6) { var_r30 = Hu3DModelCreateFile(lbl_1_data_7C4[var_r31]); lbl_1_bss_CC->model[var_r31 + 7] = var_r30; } else { var_r30 = -1; lbl_1_bss_CC->model[var_r31 + 7] = var_r30; } if (var_r30 != -1) { Hu3DModelAttrSet(var_r30, 1); Hu3DModelLayerSet(var_r30, 5); } } var_r30 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 54)); lbl_1_bss_CC->model[14] = var_r30; Hu3DModelPosSet(var_r30, 0.0f, 10.0f, 0.0f); Hu3DModelAttrSet(var_r30, 1); Hu3DModelLayerSet(var_r30, 5); lbl_1_bss_C8 = omAddObjEx(arg0, 0x7D, 6, 0, 2, NULL); for (var_r31 = 0; var_r31 < 6; var_r31++) { lbl_1_bss_C8->model[var_r31] = Hu3DModelCreateFile(lbl_1_data_7E0[var_r31]); Hu3DModelAttrSet(lbl_1_bss_C8->model[var_r31], 1); } lbl_1_bss_C4 = omAddObjEx(arg0, 0x7D, 3, 0, 3, NULL); lbl_1_bss_C4->trans.x = lbl_1_data_780->x; lbl_1_bss_C4->trans.y = lbl_1_data_780->y; lbl_1_bss_C4->trans.z = lbl_1_data_780->z; lbl_1_bss_C4->scale.x = lbl_1_bss_C4->scale.y = lbl_1_bss_C4->scale.z = 3.0f; for (var_r31 = 0; var_r31 < 3; var_r31++) { if (var_r31 == 0) { lbl_1_bss_C4->model[var_r31] = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 34)); } else { lbl_1_bss_C4->model[var_r31] = Hu3DModelLink(*lbl_1_bss_C4->model); } Hu3DModelShadowSet(lbl_1_bss_C4->model[var_r31]); Hu3DModelScaleSet(lbl_1_bss_C4->model[var_r31], lbl_1_bss_C4->scale.x, lbl_1_bss_C4->scale.y, lbl_1_bss_C4->scale.z); Hu3DModelPosSet(lbl_1_bss_C4->model[var_r31], lbl_1_data_780[var_r31].x, lbl_1_data_780[var_r31].y, lbl_1_data_780[var_r31].z); } fn_1_3158(); fn_1_6F24(); fn_1_7718(); fn_1_7B9C(); fn_1_7ED0(); fn_1_8F98(); lbl_1_bss_30[0] = 1; fn_1_9F78(); fn_1_B104(0.0f); fn_1_B1E0(0.0f); Hu3DShadowCreate(45.0f, 1000.0f, 250000.0f); Hu3DShadowTPLvlSet(0.3f); Hu3DShadowPosSet(&lbl_1_data_814, &lbl_1_data_820, &lbl_1_data_82C); return lbl_1_bss_D0; } void fn_1_292C(omObjData *object) { Vec sp24; Vec sp18; Vec spC; float sp8; float var_f31; float var_f30; float var_f29; var_f29 = 1000.0f + CZoom; var_f31 = -65.0f; var_f30 = 110.0f; sp8 = 0.0f; spC.x = Center.x; spC.y = Center.y; spC.z = Center.z; sp18.x = spC.x + (var_f29 * (sind(var_f30) * cosd(var_f31))); sp18.y = spC.y + (var_f29 * -sind(var_f31)); sp18.z = spC.z + (var_f29 * (cosd(var_f30) * cosd(var_f31))); sp24.x = sind(var_f30) * sind(var_f31); sp24.y = cosd(var_f31); sp24.z = cosd(var_f30) * sind(var_f31); Hu3DShadowPosSet(&sp18, &sp24, &spC); } void fn_1_2BEC(void) { fn_1_4568(); fn_1_717C(); fn_1_79B0(); fn_1_7DAC(); fn_1_8100(); fn_1_94BC(); fn_1_A278(); } void fn_1_2C24(omObjData *object) { float var_f31; s32 var_r30; s32 var_r29; if (!lbl_1_bss_C0) { for (var_r30 = 0; var_r30 < 6; var_r30++) { var_f31 = -(5000.0f + (10000.0f * var_r30)); if (fabs(Center.z - var_f31) > 10000.0 || !lbl_1_bss_BC) { if (object->model[var_r30] != -1) { Hu3DModelAttrSet(object->model[var_r30], 1); } var_r29 = var_r30 + 7; if (object->model[var_r29] != -1) { Hu3DModelAttrSet(object->model[var_r29], 1); } } else { if (object->model[var_r30] != -1) { Hu3DModelAttrReset(object->model[var_r30], 1); } var_r29 = var_r30 + 7; if (object->model[var_r29] != -1) { Hu3DModelAttrReset(object->model[var_r29], 1); } } } var_r29 = 14; if (object->model[var_r29] != -1) { var_f31 = 25000.0f; if (fabs(Center.z - var_f31) < 15000.0) { Hu3DModelAttrSet(object->model[var_r29], 1); } else { Hu3DModelAttrReset(object->model[var_r29], 1); } } var_r29 = 6; if (object->model[var_r29] != -1) { Hu3DModelAttrSet(object->model[var_r29], 1); } for (var_r30 = 0; var_r30 < 3; var_r30++) { if (fabs(Center.z - lbl_1_data_780[var_r30].z) > 10000.0) { Hu3DModelAttrSet(lbl_1_bss_C4->model[var_r30], 1); } else { Hu3DModelAttrReset(lbl_1_bss_C4->model[var_r30], 1); } } return; } for (var_r30 = 0; var_r30 < 6; var_r30++) { if (object->model[var_r30] != -1) { Hu3DModelAttrSet(object->model[var_r30], 1); } var_r29 = var_r30 + 7; if (object->model[var_r29] != -1) { Hu3DModelAttrSet(object->model[var_r29], 1); } } var_r29 = 6; if (object->model[var_r29] != -1) { Hu3DModelAttrReset(object->model[var_r29], 1); } for (var_r30 = 0; var_r30 < 3; var_r30++) { Hu3DModelAttrSet(lbl_1_bss_C4->model[var_r30], 1); } } void fn_1_3064(s32 arg0) { s32 var_r31; if (lbl_1_bss_C0 = arg0) { for (var_r31 = 0; var_r31 < 6; var_r31++) { if (lbl_1_bss_CC->model[var_r31] != -1) { Hu3DModelKill(lbl_1_bss_CC->model[var_r31]); } lbl_1_bss_CC->model[var_r31] = -1; } if (lbl_1_bss_CC->model[6] == -1) { lbl_1_bss_CC->model[6] = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 41)); } } } void fn_1_3158(void) { UnkM406Struct2 *sp10[2]; // TODO sp10 should probably be a void* s32 sp8[2]; float var_f31; float var_f30; float var_f29; float var_f28; UnkM406Unk120Struct *var_r31; UnkM406Struct *var_r30; s32 var_r29; UnkM406Struct4 *var_r28; UnkM406Struct3 *var_r27; ModelData *var_r26; s32 var_r25; Vec *var_r24; GXColor *var_r23; s16(*var_r22)[4]; Vec *var_r21; Vec2f *var_r20; s32 var_r19; void *var_r18; ModelData *var_r17; var_r19 = lbl_1_data_7A4 = Hu3DHookFuncCreate(fn_1_45BC); var_r26 = &Hu3DData[var_r19]; var_r31 = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Unk120Struct), var_r26->unk_48); var_r26->unk_120 = var_r31; memset(var_r31, 0, sizeof(UnkM406Unk120Struct)); sp8[0] = Hu3DHookFuncCreate(fn_1_6304); Hu3DModelLayerSet(sp8[0], 7); var_r17 = &Hu3DData[sp8[0]]; var_r17->unk_120 = var_r31; sp8[1] = Hu3DLLightCreateV(var_r19, &lbl_1_data_838, &lbl_1_data_844, lbl_1_data_850); Hu3DLLightStaticSet(var_r19, sp8[1], 1); Hu3DLLightInfinitytSet(var_r19, sp8[1]); var_r31->unk_00 = 0; var_r31->unk_04 = var_r19; var_r31->unk_08 = 0; var_r31->unk_0C = 0.0f; var_r31->unk_10 = 0.0f; var_r31->unk_14 = 2000.0f; var_r31->unk_28 = 0; var_r31->unk_A8 = HuDataReadNum(DATA_MAKE_NUM(DATADIR_M406, 61), MEMORY_DEFAULT_NUM); var_r31->unk_AC = 0x80; var_r31->unk_B0 = 0x80; var_r31->unk_B4 = 0.0f; var_r31->unk_B8 = 0.0f; var_r31->unk_BC = HuDataReadNum(DATA_MAKE_NUM(DATADIR_M406, 62), MEMORY_DEFAULT_NUM); var_r31->unk_C0 = 0x80; var_r31->unk_C4 = 0x80; var_r31->unk_C8 = 0.0f; var_r31->unk_CC = 0.0f; var_r31->unk_2C = HuMemDirectMallocNum(HEAP_DATA, 105 * sizeof(UnkM406Struct3), var_r26->unk_48); memset(var_r31->unk_2C, 0, 105 * sizeof(UnkM406Struct3)); var_r27 = var_r31->unk_2C; for (var_r29 = 0; var_r29 < 105; var_r29++, var_r27++) { var_r27->unk_00 = var_r29 / 3; var_r27->unk_04 = 0.33333334f * (var_r29 % 3); switch (var_r29 % 4) { case 0: var_r25 = var_r27->unk_08 = frand() & 0x1F; break; case 1: var_r27->unk_08 = var_r25 + 10; break; default: var_r27->unk_08 = var_r25 + 20; break; } var_r27->unk_0C = -1; var_r27->unk_10 = 0.0f; if (var_r29 == 0 || var_r29 == 104) { var_r27->unk_14 = 0.3f; } if (var_r29 == 1 || var_r29 == 103) { var_r27->unk_14 = 0.6f; } else { var_r27->unk_14 = 1.0f; } var_r27->unk_18.x = var_r27->unk_18.y = var_r27->unk_18.z = 0.0f; var_r27->unk_24 = 0; } var_r31->unk_30 = HuMemDirectMallocNum(HEAP_DATA, 12 * sizeof(UnkM406Struct4), var_r26->unk_48); memset(var_r31->unk_30, 0, 12 * sizeof(UnkM406Struct4)); var_r28 = var_r31->unk_30; for (var_r29 = 0; var_r29 < 12; var_r29++, var_r28++) { switch (var_r29) { case 0: var_r28->unk_00 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 56)); break; case 1: var_r28->unk_00 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 57)); break; case 2: var_r28->unk_00 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 58)); break; default: var_r28->unk_00 = Hu3DModelLink(var_r31->unk_30[var_r29 % 3].unk_00); break; } if (var_r29 < 3) { fn_1_CF24(var_r28->unk_00, 184, 207, 214); } var_r28->unk_04 = frand() & 1; var_r28->unk_08 = 0; var_r28->unk_0C = frand() % 60; var_r28->unk_10 = 0.2f + (0.6f * (0.007874016f * (frand() & 0x7F))); var_r28->unk_14 = var_r28->unk_18 = 0.0f; var_r28->unk_1C = 0.0f; var_r28->unk_20 = var_r28->unk_24 = 0.0f; var_r28->unk_28 = 0.0f; var_r28->unk_2C = 0.0f; var_r28->unk_3C.x = var_r28->unk_3C.y = var_r28->unk_3C.z = 0.0f; } var_r31->unk_34.x = var_r31->unk_34.y = var_r31->unk_34.z = 0.0f; var_r31->unk_40.x = var_r31->unk_40.y = var_r31->unk_40.z = 0.0f; var_r31->unk_7C = 0; var_r31->unk_80 = 1050; var_r31->unk_84 = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_80 * sizeof(Vec), var_r26->unk_48); memset(var_r31->unk_84, 0, var_r31->unk_80 * sizeof(Vec)); var_r31->unk_88 = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_80 * sizeof(Vec), var_r26->unk_48); memset(var_r31->unk_88, 0, var_r31->unk_80 * sizeof(Vec)); var_r31->unk_8C = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_80 * sizeof(Vec2f), var_r26->unk_48); memset(var_r31->unk_8C, 0, var_r31->unk_80 * sizeof(Vec2f)); var_r31->unk_90 = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_80 * sizeof(GXColor), var_r26->unk_48); memset(var_r31->unk_90, 0, var_r31->unk_80 * sizeof(GXColor)); var_r31->unk_94 = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_80 * sizeof(UnkM406Struct), var_r26->unk_48); memset(var_r31->unk_94, 0, var_r31->unk_80 * sizeof(UnkM406Struct)); var_r31->unk_98 = 986; var_r31->unk_9C = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_98 * 8, var_r26->unk_48); memset(var_r31->unk_9C, 0, var_r31->unk_98 * 8); var_r24 = var_r31->unk_84; var_r21 = var_r31->unk_88; var_r20 = var_r31->unk_8C; var_r23 = var_r31->unk_90; var_r30 = var_r31->unk_94; var_f30 = -500.0f; var_f29 = -1000.0f; var_f28 = 0.0f; for (var_r29 = 0; var_r29 < 30; var_r29++) { for (var_r25 = 0; var_r25 < 35; var_r25++) { var_r24->x = var_f30; var_r24->y = var_f28; var_r24->z = var_f29; var_f30 += 29.411764f; var_f28 = 0.0f; var_r21->x = 0.0f; var_r21->z = 0.0f; var_r21->y = 1.0f; var_r20->x = 0.0f; var_r20->y = 0.0f; var_r23->r = var_r23->g = var_r23->b = var_r23->a = 0xFF; if (var_r29 == 0) { var_r30->unk_01 = 1; if (var_r29 < 6) { var_r30->unk_08 = (6 - var_r29) / 6.0f; } else { var_r30->unk_08 = 1.0f; } } else { var_r30->unk_01 = 0; var_r30->unk_08 = 0.0f; } if (!var_r25 || var_r25 == 34 || !var_r29) { var_r30->unk_00 = 0; var_r30->unk_04 = 0.0f; } else { var_r30->unk_00 = 1; if (var_r29 < 3) { var_r30->unk_04 = 0.5f + (0.5f * (var_r29 / 3.0f)); var_r30->unk_04 = sind(90.0f * var_r30->unk_04); } else { var_r30->unk_04 = 1.0f; } } var_r30->unk_10.x = var_r24->x; var_r30->unk_10.y = var_r24->y; var_r30->unk_10.z = var_r24->z; var_r30->unk_1C.x = var_r30->unk_1C.y = var_r30->unk_1C.z = 0.0f; var_r30->unk_0C = 200.0 * sind(90.0f * (var_r29 / 29.0f)); if (var_r25 < 6) { var_f31 = var_r25 / 6.0f; var_r30->unk_04 = var_r30->unk_04 * sind(90.0f * var_f31); var_r30->unk_0C = var_r30->unk_0C * sind(90.0f * var_f31); } else if (var_r25 > 28) { var_f31 = (var_r25 - 28) / 6.0f; var_r30->unk_04 = var_r30->unk_04 * cosd(90.0f * var_f31); var_r30->unk_0C = var_r30->unk_0C * cosd(90.0f * var_f31); } var_r30->unk_28 = var_r25 / 34.0f; var_r30->unk_2C = (var_r29 * 2) / 29.0f; if (var_r30->unk_28 > 1.0f) { var_r30->unk_28 = fmod(var_r30->unk_28, 1.0); } if (var_r30->unk_2C > 1.0f) { var_r30->unk_2C = fmod(var_r30->unk_2C, 1.0); } var_r24++; var_r21++; var_r20++; var_r23++; var_r30++; } var_f30 = -500.0f; var_f29 += 68.965515f; } var_r22 = var_r31->unk_9C; for (var_r29 = 0; var_r29 < 29; var_r29++) { for (var_r25 = 0; var_r25 < 34; var_r22++, var_r25++) { (*var_r22)[0] = var_r25 + (var_r29 * 35); (*var_r22)[1] = var_r25 + 1 + (var_r29 * 35); (*var_r22)[2] = var_r25 + 1 + ((var_r29 + 1) * 35); (*var_r22)[3] = var_r25 + ((var_r29 + 1) * 35); } } var_r18 = HuMemDirectMallocNum(HEAP_DATA, 0x10000, var_r26->unk_48); sp10[0] = var_r18; DCFlushRange(var_r18, 0x10000); GXBeginDisplayList(sp10[0], 0x10000); GXBegin(GX_TRIANGLESTRIP, GX_VTXFMT0, 70); for (var_r29 = 0; var_r29 < 35; var_r29++) { // TODO fix up GXUnknownu16(var_r29 + 35); GXUnknownu16(var_r29 + 35); GXUnknownu16(var_r29 + 35); GXUnknownu16(var_r29); GXUnknownu16(var_r29); GXUnknownu16(var_r29); } var_r31->unk_A0 = GXEndDisplayList(); if (var_r31->unk_A0 >= 0x10000) { OSReport("ERROR! GList test size over! \n"); } var_r31->unk_A4 = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_A0, var_r26->unk_48); memcpy(var_r31->unk_A4, var_r18, var_r31->unk_A0); DCFlushRange(var_r31->unk_A4, var_r31->unk_A0); HuMemDirectFree(var_r18); lbl_1_bss_B4 = 70; lbl_1_bss_B8 = HuMemDirectMallocNum(HEAP_DATA, lbl_1_bss_B4 * 32, var_r26->unk_48); memset(lbl_1_bss_B8, 0, lbl_1_bss_B4 * 32); fn_1_64F8(lbl_1_bss_B8); sp10[1] = &lbl_1_bss_B8[lbl_1_bss_B4 - 1]; var_r31->unk_18 = sp10[1]->unk_04; var_r31->unk_1C = 0.0f; var_r31->unk_20 = -1; var_r31->unk_24 = 0; } GXColor lbl_1_data_88F = { 0xFF, 0xFF, 0xFF, 0xFF }; GXColor lbl_1_data_893 = { 0xB3, 0xBB, 0xC2, 0xFF }; GXColor lbl_1_data_897 = { 0xFF, 0xFF, 0xFF, 0xFF }; GXColor lbl_1_data_89B = { 0xFF, 0xFF, 0xFF, 0x40 }; GXColor lbl_1_data_89F = { 0xFF, 0xFF, 0xFF, 0xFF }; float lbl_1_data_8A4[4] = { 1000.0f, 200.0f, 600.0f, 1200.0f }; float lbl_1_data_8B4[4] = { 1.0f, 0.6f, 0.3f, 0.425f }; Vec lbl_1_data_8C4 = { 0.0f, -34700.0f, -62094.0f }; Vec lbl_1_data_8D0 = { 0.0f, 1.0f, 0.0f }; GXColor lbl_1_data_8DC = { 0xFF, 0xFF, 0xFF, 0xFF }; Vec lbl_1_data_8E0[4] = { { -0.5f, 0.5f, 0.0f }, { 0.5f, 0.5f, 0.0f }, { 0.5f, -0.5f, 0.0f }, { -0.5f, -0.5f, 0.0f }, }; Vec2f lbl_1_data_910[4] = { { 0.0f, 0.0f }, { 0.25f, 0.0f }, { 0.25f, 0.25f }, { 0.0f, 0.25f } }; Vec lbl_1_data_930[4] = { { 0.0f, 0.5f, 0.0f }, { 0.5f, 0.0f, 0.0f }, { 0.0f, -0.5f, 0.0f }, { -0.5f, 0.0f, 0.0f }, }; void fn_1_4084(void) { Vec sp28; Vec sp1C; Vec sp10; void *spC; float sp8; float var_f31; float var_f30; float var_f29; float var_f28; UnkM406Unk120Struct *var_r31; s32 var_r30; UnkM406Struct *var_r29; Vec *var_r28; s32 var_r27; s32 var_r26; ModelData *var_r25; spC = lbl_1_bss_B8; var_r25 = &Hu3DData[lbl_1_data_7A4]; var_r31 = var_r25->unk_120; if (!var_r31->unk_28) { if (++var_r31->unk_24 >= 1 && var_r31->unk_20 == -1) { sp28.x = 0.5f * (var_r31->unk_34.x + var_r31->unk_40.x); sp28.y = 0.5f * (var_r31->unk_34.y + var_r31->unk_40.y); sp28.z = 0.5f * (var_r31->unk_34.z + var_r31->unk_40.z); var_r31->unk_20 = HuAudFXEmiterPlay(1337, &sp28); } else if (var_r31->unk_20 != -1) { sp28.x = 0.5f * (var_r31->unk_34.x + var_r31->unk_40.x); sp28.y = 0.5f * (var_r31->unk_34.y + var_r31->unk_40.y); sp28.z = 0.5f * (var_r31->unk_34.z + var_r31->unk_40.z); HuAudFXEmiterUpDate(var_r31->unk_20, &sp28); } } else if (var_r31->unk_20 != -1) { HuAudFXStop(var_r31->unk_20); var_r31->unk_20 = -1; } var_r31->unk_0C = var_r31->unk_0C + var_r31->unk_10; if (var_r31->unk_0C > var_r31->unk_18) { var_r31->unk_1C = var_r31->unk_0C - var_r31->unk_18; var_r31->unk_0C = var_r31->unk_18; } else { var_r31->unk_1C = 0.0f; } var_r28 = var_r31->unk_84; var_r29 = var_r31->unk_94; var_f30 = 0.0f; var_f28 = var_r31->unk_14 / 29.0f; for (var_r27 = 0; var_r27 < 30; var_r27++) { var_r30 = fn_1_66F4(var_r31->unk_0C - var_f30, &sp8); var_f30 += var_f28; if (var_r30 < 0) { var_r30 = 0; sp1C = lbl_1_data_F0[var_r30]; sp10 = lbl_1_data_438[var_r30]; } else if (var_r30 < (lbl_1_bss_B4 - 1)) { fn_1_D488(sp8, &lbl_1_data_F0[var_r30], &lbl_1_data_F0[var_r30 + 1], &sp1C); fn_1_D488(sp8, &lbl_1_data_438[var_r30], &lbl_1_data_438[var_r30 + 1], &sp10); } else { var_r30 = lbl_1_bss_B4 - 1; sp1C = lbl_1_data_F0[var_r30]; sp10 = lbl_1_data_438[var_r30]; } if (var_r27 == 0) { var_r31->unk_34 = sp1C; var_r31->unk_40 = sp10; var_r31->unk_7C = var_r30; var_f29 = atan2d(var_r31->unk_40.x - var_r31->unk_34.x, var_r31->unk_40.z - var_r31->unk_34.z); mtxRot(var_r31->unk_4C, 0.0f, var_f29, 0.0f); } for (var_r26 = 0, var_f31 = 0.0f; var_r26 < 35; var_r28++, var_r29++, var_r26++) { fn_1_D488(var_f31, &sp1C, &sp10, var_r28); var_r29->unk_10 = *var_r28; var_f31 += 0.029411765f; var_r29->unk_1C = lbl_1_bss_B8[var_r30].unk_08; } } } void fn_1_4568(void) { UnkM406Unk120Struct *var_r31; ModelData *var_r30; var_r30 = &Hu3DData[lbl_1_data_7A4]; var_r31 = var_r30->unk_120; HuMemDirectFree(var_r31->unk_A8); } void fn_1_45BC(ModelData *arg0, Mtx arg1) { Mtx sp10; UnkM406Unk120Struct *var_r31; s16 var_r30; s16 var_r29; s16 var_r26; var_r31 = arg0->unk_120; if (!var_r31->unk_08) { fn_1_6304(arg0, arg1); } if (!var_r31->unk_28) { GXLoadPosMtxImm(arg1, 0); PSMTXInvXpose(arg1, sp10); GXLoadNrmMtxImm(sp10, 0); var_r26 = fn_1_D06C(arg0, Hu3DCameraMtx, Hu3DCameraMtxXPose, 2.0f); GXSetNumTevStages(1); GXSetNumTexGens(0); GXSetNumChans(1); GXSetTexCoordGen2(GX_TEXCOORD0, GX_TG_MTX2x4, GX_TG_NRM, 0x36, GX_FALSE, 125); GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD_NULL, GX_TEXMAP_NULL, GX_COLOR0A0); GXSetTevOp(GX_TEVSTAGE0, GX_REPLACE); GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_RASC, GX_CC_ZERO, GX_CC_ZERO, GX_CC_ZERO); GXSetTevColorOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV); GXSetTevAlphaIn(GX_TEVSTAGE0, GX_CA_RASA, GX_CA_ZERO, GX_CA_ZERO, GX_CA_ZERO); GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV); GXSetChanCtrl(GX_COLOR0A0, GX_TRUE, GX_SRC_REG, GX_SRC_REG, var_r26, GX_DF_CLAMP, GX_AF_SPEC); GXSetAlphaCompare(GX_GEQUAL, 1, GX_AOP_AND, GX_GEQUAL, 1); GXSetZMode(GX_TRUE, GX_LEQUAL, GX_TRUE); GXSetZCompLoc(GX_TRUE); GXSetBlendMode(GX_BM_BLEND, GX_BL_SRCALPHA, GX_BL_INVSRCALPHA, GX_LO_NOOP); GXSetChanAmbColor(GX_COLOR0A0, lbl_1_data_893); GXSetChanMatColor(GX_COLOR0A0, lbl_1_data_88F); DCFlushRangeNoSync(var_r31->unk_84, var_r31->unk_80 * sizeof(Vec)); DCFlushRangeNoSync(var_r31->unk_88, var_r31->unk_80 * sizeof(Vec)); DCFlushRangeNoSync(var_r31->unk_8C, var_r31->unk_80 * sizeof(Vec2f)); DCFlushRangeNoSync(var_r31->unk_90, var_r31->unk_80 * sizeof(GXColor)); PPCSync(); GXClearVtxDesc(); GXSetVtxDesc(GX_VA_POS, GX_INDEX16); GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0); GXSetArray(GX_VA_POS, var_r31->unk_84, sizeof(Vec)); GXSetVtxDesc(GX_VA_NRM, GX_INDEX16); GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_NRM, GX_NRM_XYZ, GX_F32, 0); GXSetArray(GX_VA_NRM, var_r31->unk_88, sizeof(Vec)); GXSetVtxDesc(GX_VA_CLR0, GX_INDEX16); GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_CLR0, GX_CLR_RGBA, GX_RGBA8, 0); GXSetArray(GX_VA_CLR0, var_r31->unk_90, 4); GXCallDisplayList(var_r31->unk_A4, var_r31->unk_A0); for (var_r30 = 1; var_r30 < 29; var_r30++) { var_r29 = var_r30 * 35; GXSetArray(GX_VA_POS, &var_r31->unk_84[var_r29], sizeof(Vec)); GXSetArray(GX_VA_NRM, &var_r31->unk_88[var_r29], sizeof(Vec)); GXSetArray(GX_VA_CLR0, &var_r31->unk_90[var_r29], sizeof(GXColor)); GXCallDisplayList(var_r31->unk_A4, var_r31->unk_A0); } } } void fn_1_4964(ModelData *arg0) { UnkM406Struct5 spD0; Vec spC4; Vec spB8; Vec spAC; Vec spA0; Vec2f sp50; Vec2f sp48; GXColor sp3C; float sp38; float var_f31; float var_f30; float var_f29; UnkM406Struct4 *var_r31; UnkM406Unk120Struct *var_r30; UnkM406Struct3 *var_r29; UnkM406Struct *var_r28; s32 var_r27; s32 var_r26; Vec *var_r25; s32 var_r24; s32 var_r23; s32 var_r22; Vec *var_r21; Vec2f *var_r20; GXColor *var_r19; var_r30 = arg0->unk_120; if (var_r30->unk_28) { if (!omPauseChk()) { fn_1_67CC(arg0); } return; } if (!omPauseChk()) { var_r30->unk_B4 += 0.005f; var_r30->unk_B8 += (0.007499999832361937 + (0.001 * var_r30->unk_1C)); if (fabs(var_r30->unk_B4) > 1.0) { // 1.0 or 1.0f? var_r30->unk_B4 = fmod(var_r30->unk_B4, 1.0); } if (var_r30->unk_B4 < 0.0f) { var_r30->unk_B4 += 1.0f; } if (fabs(var_r30->unk_B8) > 1.0) { var_r30->unk_B8 = fmod(var_r30->unk_B8, 1.0); } if (var_r30->unk_B8 < 0.0f) { var_r30->unk_B8 += 1.0f; } var_r30->unk_C8 += -0.005f; var_r30->unk_CC += (-0.007499999832361937 + (0.001 * var_r30->unk_1C)); if (fabs(var_r30->unk_C8) > 1.0) { var_r30->unk_C8 = fmod(var_r30->unk_C8, 1.0); } if (var_r30->unk_C8 < 0.0f) { var_r30->unk_C8 += 1.0f; } if (fabs(var_r30->unk_CC) > 1.0) { var_r30->unk_CC = fmod(var_r30->unk_CC, 1.0); } if (var_r30->unk_CC < 0.0f) { var_r30->unk_CC += 1.0f; } } var_r25 = var_r30->unk_84; var_r21 = var_r30->unk_88; var_r20 = var_r30->unk_8C; var_r19 = var_r30->unk_90; var_r28 = var_r30->unk_94; sp50.x = var_r30->unk_AC - 1; sp50.y = var_r30->unk_B0 - 1; sp48.x = var_r30->unk_C0 - 1; sp48.y = var_r30->unk_C4 - 1; for (var_r27 = 0; var_r27 < var_r30->unk_80; var_r27++) { *var_r25 = var_r28->unk_10; if (var_r28->unk_00 || var_r28->unk_01) { var_r23 = (s32)(sp50.x * (var_r28->unk_28 + var_r30->unk_B4)) & 0x7F; var_r22 = (s32)(sp50.y * (var_r28->unk_2C + var_r30->unk_B8)) & 0x7F; var_f31 = var_r30->unk_A8[(var_r22 * var_r30->unk_AC) + var_r23]; var_r23 = (s32)(sp48.x * (var_r28->unk_28 + var_r30->unk_C8)) & 0x7F; var_r22 = (s32)(sp48.y * (var_r28->unk_2C + var_r30->unk_CC)) & 0x7F; var_f31 += var_r30->unk_BC[(var_r22 * var_r30->unk_C0) + var_r23]; if (var_r28->unk_00) { var_r25->y = var_r28->unk_10.y + var_r28->unk_0C + (100.0f * (0.003921569f * (var_r28->unk_04 * var_f31))); } if (var_r28->unk_01) { var_r25->z = var_r28->unk_10.z - (50.0f * (0.003921569f * (var_r28->unk_08 * var_f31))); } (void)var_f31; (void)var_f31; (void)var_f31; (void)var_f31; } var_r25++; var_r21++; var_r20++; var_r19++; var_r28++; } if (omPauseChk()) { return; } for (var_r27 = 0; var_r27 < 5; var_r27++) { var_r26 = (u32)frand() % 34; fn_1_D488(0.007874016f * (frand() & 0x7F), &var_r30->unk_84[var_r26], &var_r30->unk_84[var_r26 + 1], &spC4); spC4.x += 10.0f * var_r30->unk_94->unk_1C.x; spC4.z += 10.0f * var_r30->unk_94->unk_1C.z; spA0.y = 5.0f + (5.0f * (0.007874016f * (frand() & 0x7F))); spA0.x = spA0.z = 0.0f; var_r26 = (frand() & 0x1F) + 0xE0; sp3C.r = 0.96f * var_r26; sp3C.g = 0.98f * var_r26; sp3C.b = (float)var_r26; sp3C.a = 0xC8; fn_1_71C4(spC4, spA0, 100.0f + (50.0f * (0.007874016f * (frand() & 0x7F))), -0.1f, sp3C); } var_r29 = var_r30->unk_2C; memset(lbl_1_bss_48, 0, sizeof(UnkM406Struct5)); for (var_r27 = 0; var_r27 < 105; var_r27++, var_r29++) { fn_1_D488(var_r29->unk_04, &var_r30->unk_84[var_r29->unk_00], &var_r30->unk_84[var_r29->unk_00 + 1], &var_r29->unk_18); if (var_r29->unk_08 >= 0) { var_r29->unk_08--; } else { var_r29->unk_24 = fn_1_7B2C(var_r29->unk_0C); if (var_r29->unk_24 == NULL) { var_r29->unk_24 = &lbl_1_bss_48; } if (var_r29->unk_24->unk_28 <= 0.0f) { spC4 = var_r29->unk_18; spA0.x = spA0.y = spA0.z = 0.0f; var_r26 = (frand() & 0x1F) + 0xE0; sp3C.r = 0.96f * var_r26; sp3C.g = 0.98f * var_r26; sp3C.b = (float)var_r26; sp3C.a = 0xFF; if (frand() & 1) { var_f31 = 0.05f; } else { var_f31 = -0.05f; } var_r29->unk_10 = 0.01f * (100.0f * (0.007874016f * (frand() & 0x7F))); var_r29->unk_0C = fn_1_79F8(spC4, spA0, 75.0f + (var_r29->unk_14 * (75.0f * (0.007874016f * (frand() & 0x7F)))), var_f31, sp3C); } else { var_r29->unk_18.y += var_r29->unk_10; var_r29->unk_24->unk_30 = var_r29->unk_18; } } } sp3C.r = sp3C.g = sp3C.b = sp3C.a = 0xFF; fn_1_D488(0.007874016f * (frand() & 0x7F), &var_r30->unk_84[0], &var_r30->unk_84[34], &spC4); if ((frand() & 3) == 0) { var_f31 = 45.0f + (30.0f * (0.007874016f * (frand() & 0x7F))); var_f29 = 0.75f + (0.75f * (0.007874016f * (frand() & 0x7F))); } else { var_f31 = -(15.0f * (0.007874016f * (frand() & 0x7F))); var_f29 = 1.75f + (0.75f * (0.007874016f * (frand() & 0x7F))); } if (var_r30->unk_10 != 0.0f) { var_f30 = 15.000001f / var_r30->unk_10; } else { var_f30 = 1.0f; } spA0.y = var_f30 * ((7.5000005f * var_f29) * sind(var_f31)); var_f30 = (0.75f * var_r30->unk_10) + (7.5000005f * var_f29) * cosd(var_f31); var_f30 = var_f30; spA0.x = var_r30->unk_94->unk_1C.x * var_f30; spA0.z = var_r30->unk_94->unk_1C.z * var_f30; fn_1_7DB0(spC4, spA0, 7.5f, sp3C); var_r31 = var_r30->unk_30; for (var_r27 = 0; var_r27 < 12; var_r27++, var_r31++) { if (var_r31->unk_08 == 0) { if (var_r31->unk_0C <= 0) { var_f30 = 0.5f + (0.75f * (0.007874016f * (frand() & 0x7F))); Hu3DModelScaleSet(var_r31->unk_00, var_f30, var_f30, var_f30); var_r31->unk_04 = frand() & 1; switch (var_r31->unk_04) { case 0: var_r31->unk_10 = 0.1f + (0.8f * (0.007874016f * (frand() & 0x7F))); var_r31->unk_14 = var_r31->unk_18 = 0.0f; var_r31->unk_20 = var_r31->unk_24 = 0.0f; var_r31->unk_08 = 0; var_r31->unk_0C = 0; var_r31->unk_1C = 100.0f * (0.5f + (0.75f * (0.007874016f * (frand() & 0x7F)))); var_r31->unk_28 = 0.0f; var_r31->unk_2C = 15.0f + (15.0f * (0.007874016f * (frand() & 0x7F))); break; case 1: var_r31->unk_10 = 0.1f + (0.8f * (0.007874016f * (frand() & 0x7F))); var_r31->unk_14 = var_r31->unk_18 = 0.0f; var_r31->unk_20 = var_r31->unk_24 = 0.0f; var_r31->unk_08 = 0; var_r31->unk_0C = 0; var_r31->unk_1C = 100.0f * (0.5f + (0.007874016f * (frand() & 0x7F))); var_r31->unk_28 = 100.0f * (0.07f + (0.03f * (0.007874016f * (frand() & 0x7F)))); var_r31->unk_2C = 15.0f + (15.0f * (0.007874016f * (frand() & 0x7F))); break; default: break; } } else { Hu3DModelAttrSet(var_r31->unk_00, 1); var_r31->unk_08 = -1; var_r31->unk_0C--; } } else if (var_r31->unk_08 >= 0) { var_r24 = fn_1_66F4(var_r30->unk_0C + var_r31->unk_18, &sp38); if (var_r24 >= 0 && var_r24 < (lbl_1_bss_B4 - 1)) { fn_1_D488(sp38, &lbl_1_data_F0[var_r24], &lbl_1_data_F0[var_r24 + 1], &spB8); fn_1_D488(sp38, &lbl_1_data_438[var_r24], &lbl_1_data_438[var_r24 + 1], &spAC); fn_1_D488(var_r31->unk_10, &spB8, &spAC, &var_r31->unk_3C); Hu3DModelAttrReset(var_r31->unk_00, 1); } else { Hu3DModelAttrSet(var_r31->unk_00, 1); var_r31->unk_08 = -1; continue; } switch (var_r31->unk_04) { case 0: var_r31->unk_18 = var_r31->unk_1C * sind(5.0f * var_r31->unk_08); var_r31->unk_20 = var_r31->unk_20 - var_r31->unk_2C; Hu3DModelPosSet(var_r31->unk_00, var_r31->unk_3C.x, var_r31->unk_3C.y, var_r31->unk_3C.z); Hu3DModelRotSet(var_r31->unk_00, var_r31->unk_20, var_r31->unk_24, 0.0f); break; case 1: var_r31->unk_18 = var_r31->unk_1C * sind((float)var_r31->unk_08); var_r31->unk_20 = var_r31->unk_20 - var_r31->unk_2C; var_r31->unk_14 = var_r31->unk_14 + var_r31->unk_28; if (var_r31->unk_14 < 0.0f) { var_f30 = 0.65 + (0.15 * (0.007874016f * (frand() & 0x7F))); var_f30 = var_f30; var_r31->unk_14 = 0.0f; var_r31->unk_28 = var_r31->unk_28 * -var_f30; } var_r31->unk_28 = var_r31->unk_28 - 0.32666668f; var_r31->unk_3C.y += var_r31->unk_14; Hu3DModelPosSet(var_r31->unk_00, var_r31->unk_3C.x, var_r31->unk_3C.y, var_r31->unk_3C.z); Hu3DModelRotSet(var_r31->unk_00, var_r31->unk_20, var_r31->unk_24, 0.0f); break; default: break; } } if (var_r31->unk_18 < (-0.1f * var_r31->unk_1C)) { var_r31->unk_08 = -1; var_r31->unk_0C = frand() & 0x1F; } var_r31->unk_08++; } var_r30->unk_00++; } void fn_1_6174(ModelData *arg0) { Vec sp20; Vec sp14; Vec sp8; UnkM406Unk120Struct *var_r31; s16(*var_r30)[4]; s32 var_r29; Vec *var_r28; var_r31 = arg0->unk_120; memset(var_r31->unk_88, 0, var_r31->unk_80 * sizeof(Vec)); for (var_r29 = 0, var_r30 = var_r31->unk_9C; var_r29 < var_r31->unk_98; var_r29++, var_r30++) { PSVECSubtract(&var_r31->unk_84[(*var_r30)[1]], &var_r31->unk_84[(*var_r30)[0]], &sp14); PSVECSubtract(&var_r31->unk_84[(*var_r30)[2]], &var_r31->unk_84[(*var_r30)[1]], &sp8); PSVECCrossProduct(&sp14, &sp8, &sp20); PSVECAdd(&var_r31->unk_88[(*var_r30)[0]], &sp20, &var_r31->unk_88[(*var_r30)[0]]); PSVECAdd(&var_r31->unk_88[(*var_r30)[1]], &sp20, &var_r31->unk_88[(*var_r30)[1]]); PSVECAdd(&var_r31->unk_88[(*var_r30)[2]], &sp20, &var_r31->unk_88[(*var_r30)[2]]); PSVECAdd(&var_r31->unk_88[(*var_r30)[3]], &sp20, &var_r31->unk_88[(*var_r30)[3]]); } for (var_r29 = 0, var_r28 = var_r31->unk_88; var_r29 < var_r31->unk_80; var_r29++) { PSVECNormalize(var_r28, var_r28); } } void fn_1_6304(ModelData *arg0, Mtx arg1) { UnkM406Unk120Struct *var_r28; ModelData *var_r27; var_r28 = arg0->unk_120; var_r27 = &Hu3DData[var_r28->unk_04]; if (!omPauseChk() && lbl_1_bss_30[0]) { fn_1_4084(); fn_1_6FFC(); fn_1_77F0(); fn_1_7C4C(); fn_1_7F80(); fn_1_91E0(); } fn_1_4964(var_r27); fn_1_6174(var_r27); var_r28->unk_08 = 1; } void fn_1_64F8(UnkM406Struct2 *arg0) { float var_f31; // ! - uninitialized UnkM406Struct2 *var_r31; s32 var_r30; UnkM406Struct2 *var_r28; for (var_r30 = 0, var_r31 = arg0; var_r30 < lbl_1_bss_B4; var_r30++, var_r31++) { var_r31->unk_14.x = 0.5f * (lbl_1_data_F0[var_r30].x + lbl_1_data_438[var_r30].x); var_r31->unk_14.y = 0.5f * (lbl_1_data_F0[var_r30].y + lbl_1_data_438[var_r30].y); var_r31->unk_14.z = 0.5f * (lbl_1_data_F0[var_r30].z + lbl_1_data_438[var_r30].z); } for (var_r30 = 0, var_r31 = arg0; var_r30 < lbl_1_bss_B4; var_r30++, var_r31++) { if (var_r30 < lbl_1_bss_B4 - 1) { var_r28 = &arg0[var_r30 + 1]; PSVECSubtract(&var_r28->unk_14, &var_r31->unk_14, &var_r31->unk_08); var_r31->unk_00 = PSVECMag(&var_r31->unk_08); PSVECNormalize(&var_r31->unk_08, &var_r31->unk_08); } else { var_r31->unk_00 = 100000.0f; var_r31->unk_08.x = 0.0f; var_r31->unk_08.y = 0.0f; var_r31->unk_08.z = -1.0f; } var_r31->unk_04 = var_f31; var_f31 += var_r31->unk_00; } } s32 fn_1_66F4(float arg8, float *arg0) { UnkM406Struct2 *var_r31; s32 var_r30; for (var_r30 = 0, var_r31 = lbl_1_bss_B8; var_r30 < lbl_1_bss_B4; var_r30++, var_r31++) { if (arg8 < (var_r31->unk_04 + var_r31->unk_00)) { *arg0 = (arg8 - var_r31->unk_04) / var_r31->unk_00; if (*arg0 < 0.0f) { *arg0 = 0.0f; } break; } } if (var_r30 >= lbl_1_bss_B4) { if (arg0) { *arg0 = 0.0f; } return -1; } return var_r30; } void fn_1_67CC(ModelData *arg0) { UnkM406Struct4 *var_r31; s32 var_r30; UnkM406Unk120Struct *var_r29; var_r29 = arg0->unk_120; var_r31 = var_r29->unk_30; for (var_r30 = 0; var_r30 < 12; var_r30++, var_r31++) { if (var_r31->unk_04 != 3 || var_r31->unk_0C > 0) { Hu3DModelAttrSet(var_r31->unk_00, 1); var_r31->unk_0C--; } else { var_r31->unk_20 = var_r31->unk_20 - var_r31->unk_2C; var_r31->unk_3C.x += var_r31->unk_30.x; var_r31->unk_3C.y += var_r31->unk_30.y; var_r31->unk_3C.z += var_r31->unk_30.z; var_r31->unk_30.y -= 0.49f; Hu3DModelPosSet(var_r31->unk_00, var_r31->unk_3C.x, var_r31->unk_3C.y, var_r31->unk_3C.z); Hu3DModelRotSet(var_r31->unk_00, var_r31->unk_20, var_r31->unk_24, 0.0f); Hu3DModelAttrReset(var_r31->unk_00, 1); if (++var_r31->unk_08 >= 600.0f) { Hu3DModelAttrSet(var_r31->unk_00, 1); var_r31->unk_04 = 0; var_r31->unk_08 = 0; } } } } void fn_1_696C(float arg8) { UnkM406Unk120Struct *var_r31; ModelData *var_r30; if (lbl_1_data_7A4 >= 0) { var_r30 = &Hu3DData[lbl_1_data_7A4]; var_r31 = var_r30->unk_120; var_r31->unk_10 = arg8; } } void fn_1_69C0(Vec *arg0) { UnkM406Unk120Struct *var_r31; ModelData *var_r30; arg0->x = arg0->y = arg0->z = 0.0f; if (lbl_1_data_7A4 >= 0) { var_r30 = &Hu3DData[lbl_1_data_7A4]; var_r31 = var_r30->unk_120; *arg0 = var_r31->unk_94[17].unk_10; } } s32 fn_1_6A44(Vec arg0) { Vec sp20; Vec sp14; Vec sp8; float var_f31; UnkM406Unk120Struct *var_r31; ModelData *var_r29; if (lbl_1_data_7A4 < 0) { return 0; } var_r29 = &Hu3DData[lbl_1_data_7A4]; var_r31 = var_r29->unk_120; PSVECAdd(&var_r31->unk_34, &var_r31->unk_40, &sp8); PSVECScale(&sp8, &sp8, 0.5f); PSVECSubtract(&var_r31->unk_34, &sp8, &sp20); PSVECSubtract(&var_r31->unk_40, &sp8, &sp14); var_f31 = fn_1_D5CC(&sp20, &sp14, arg0.x - sp8.x, arg0.z - sp8.z); if (var_f31 <= 0.0f) { return 0; } return 1; } void fn_1_6B5C(void) { UnkM406Unk120Struct *var_r31; ModelData *var_r30; if (lbl_1_data_7A4 >= 0) { var_r30 = &Hu3DData[lbl_1_data_7A4]; var_r31 = var_r30->unk_120; var_r31->unk_28 = 1; } } void fn_1_6BB4(Vec *arg0) { Vec sp30; Vec sp24; float var_f31; s32 var_r30; s32 var_r29; for (var_r30 = 0; var_r30 < 32; var_r30++) { sp30.x = arg0->x + (100.0f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); sp30.y = arg0->y; sp30.z = arg0->z - 100.0f; sp24.x = 2.0f * (0.5f - (0.007874016f * (frand() & 0x7F))); sp24.z = -2.0f * (1.0f + (1.2f * (0.007874016f * (frand() & 0x7F)))); sp24.y = 7.5000005f * (1.0f + (0.7f * (0.007874016f * (frand() & 0x7F)))); var_f31 = 5.5f + (5.5f * (0.007874016f * (frand() & 0x7F))); var_r29 = fn_1_8104(sp30, sp24, var_f31, lbl_1_data_897); fn_1_8244(var_r29, (s32)(60.0f * (0.007874016f * (frand() & 0x7F))) + 60, 0.32666668f, 0.99f); } } void fn_1_6F24(void) { s32 sp8; UnkM406Struct10 *var_r31; UnkM406Unk120Struct2 *var_r30; ModelData *var_r29; AnimData *var_r28; var_r31 = lbl_1_bss_B0 = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(UnkM406Struct10), MEMORY_DEFAULT_NUM); memset(var_r31, 0, sizeof(UnkM406Struct10)); var_r28 = HuSprAnimRead(HuDataReadNum(DATA_MAKE_NUM(DATADIR_M406, 63), MEMORY_DEFAULT_NUM)); var_r31->unk_08 = var_r28; var_r31->unk_00 = sp8 = fn_1_B474(var_r28, 0x800); Hu3DModelLayerSet(var_r31->unk_00, 2); var_r31->unk_04 = 0; var_r29 = &Hu3DData[var_r31->unk_00]; var_r30 = var_r29->unk_120; var_r30->unk_20 = 0; } void fn_1_6FFC(void) { UnkM406Struct5 *var_r31; UnkM406Struct10 *var_r30; UnkM406Unk120Struct2 *var_r29; s32 var_r28; ModelData *var_r27; var_r30 = lbl_1_bss_B0; if (var_r30->unk_04 <= 0) { Hu3DModelAttrSet(var_r30->unk_00, 1); return; } Hu3DModelAttrReset(var_r30->unk_00, 1); var_r27 = &Hu3DData[var_r30->unk_00]; var_r29 = var_r27->unk_120; var_r31 = var_r29->unk_3C; for (var_r28 = 0; var_r28 < var_r29->unk_26; var_r28++, var_r31++) { if (var_r31->unk_28 <= 0.0f) { continue; } var_r31->unk_30.x += var_r31->unk_04.x; var_r31->unk_30.y += var_r31->unk_04.y; var_r31->unk_30.z += var_r31->unk_04.z; var_r31->unk_2C += var_r31->unk_18; if (var_r31->unk_2C >= 360.0f) { var_r31->unk_2C -= 360.0f; } var_r31->unk_40 = var_r31->unk_00 >> 1; var_r31->unk_00++; if (var_r31->unk_40 >= 16) { var_r31->unk_40 = 0; var_r31->unk_00 = 0; var_r31->unk_28 = 0.0f; var_r30->unk_04--; } } } void fn_1_717C(void) { UnkM406Struct10 *var_r31; var_r31 = lbl_1_bss_B0; Hu3DModelAttrSet(var_r31->unk_00, 1); HuSprAnimKill(var_r31->unk_08); } s32 fn_1_71C4(Vec arg0, Vec arg1, float arg8, float arg9, GXColor arg2) { UnkM406Struct5 *var_r31; UnkM406Unk120Struct2 *var_r30; s32 var_r29; UnkM406Struct10 *var_r28; ModelData *var_r27; var_r28 = lbl_1_bss_B0; var_r27 = &Hu3DData[var_r28->unk_00]; var_r30 = var_r27->unk_120; var_r31 = var_r30->unk_3C; for (var_r29 = 0; var_r29 < var_r30->unk_26; var_r29++, var_r31++) { if (var_r31->unk_28 <= 0.0f) { break; } } if (var_r29 >= var_r30->unk_26) { return -1; } var_r31->unk_00 = var_r31->unk_02 = 0; var_r31->unk_30.x = arg0.x; var_r31->unk_30.y = arg0.y; var_r31->unk_30.z = arg0.z; var_r31->unk_04.x = arg1.x; var_r31->unk_04.y = arg1.y; var_r31->unk_04.z = arg1.z; var_r31->unk_18 = arg9; var_r31->unk_28 = arg8; var_r31->unk_3C.r = arg2.r; var_r31->unk_3C.g = arg2.g; var_r31->unk_3C.b = arg2.b; var_r31->unk_3C.a = arg2.a; var_r31->unk_2C = 0.0f; var_r31->unk_40 = 0; var_r31->unk_00 = 0; var_r28->unk_04++; return var_r29; } // TODO maybe pass struct by value s32 fn_1_72F8(Vec *arg0, Vec *arg1, GXColor *arg2, float arg8, float arg9, float argA) { Vec sp54; Vec sp48; s32 sp14; s32 sp10; float var_f31; sp48.x = arg1->z; sp48.z = arg1->x; sp48.y = 0.0f; var_f31 = 0.5f * argA; sp54.x = arg0->x + (sp48.x * var_f31); sp54.y = arg0->y + (sp48.y * var_f31); sp54.z = arg0->z + (sp48.z * var_f31); sp14 = fn_1_71C4(sp54, *arg1, arg8, arg9, *arg2); sp54.x = arg0->x - (sp48.x * var_f31); sp54.y = arg0->y - (sp48.y * var_f31); sp54.z = arg0->z - (sp48.z * var_f31); sp10 = fn_1_71C4(sp54, *arg1, arg8, -arg9, *arg2); return (sp14 << 16) | sp10; } UnkM406Struct5 *fn_1_76A8(s32 arg0) { UnkM406Unk120Struct2 *var_r31; UnkM406Struct10 *var_r30; ModelData *var_r29; var_r30 = lbl_1_bss_B0; var_r29 = &Hu3DData[var_r30->unk_00]; var_r31 = var_r29->unk_120; if (arg0 < 0 || arg0 >= var_r31->unk_26) { return 0; } return &var_r31->unk_3C[arg0]; } void fn_1_7718(void) { s32 sp8; UnkM406Struct10 *var_r31; UnkM406Unk120Struct2 *var_r30; ModelData *var_r29; AnimData *var_r28; var_r31 = lbl_1_bss_AC = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(UnkM406Struct10), MEMORY_DEFAULT_NUM); memset(var_r31, 0, sizeof(UnkM406Struct10)); var_r28 = HuSprAnimRead(HuDataReadNum(DATA_MAKE_NUM(DATADIR_M406, 63), MEMORY_DEFAULT_NUM)); var_r31->unk_08 = var_r28; var_r31->unk_00 = sp8 = fn_1_B474(var_r28, 105); Hu3DModelLayerSet(var_r31->unk_00, 2); var_r31->unk_04 = 0; var_r29 = &Hu3DData[var_r31->unk_00]; var_r30 = var_r29->unk_120; var_r30->unk_20 = 0; } void fn_1_77F0(void) { UnkM406Struct5 *var_r31; UnkM406Struct10 *var_r30; UnkM406Unk120Struct2 *var_r29; s32 var_r28; ModelData *var_r27; var_r30 = lbl_1_bss_AC; if (var_r30->unk_04 <= 0) { Hu3DModelAttrSet(var_r30->unk_00, 1); return; } Hu3DModelAttrReset(var_r30->unk_00, 1); var_r27 = &Hu3DData[var_r30->unk_00]; var_r29 = var_r27->unk_120; var_r31 = var_r29->unk_3C; if (fn_1_122C() < 3) { var_r29->unk_22 |= 1; } else { var_r29->unk_22 &= 0xFFFFFFFE; } for (var_r28 = 0; var_r28 < var_r29->unk_26; var_r28++, var_r31++) { if (var_r31->unk_28 <= 0.0f) { continue; } var_r31->unk_30.x += var_r31->unk_04.x; var_r31->unk_30.y += var_r31->unk_04.y; var_r31->unk_30.z += var_r31->unk_04.z; var_r31->unk_2C += var_r31->unk_18; if (var_r31->unk_2C >= 360.0f) { var_r31->unk_2C = var_r31->unk_2C - 360.0f; } var_r31->unk_40 = var_r31->unk_00 / 2; var_r31->unk_00++; if (var_r31->unk_40 >= 0x10) { var_r31->unk_40 = 0; var_r31->unk_00 = 0; var_r31->unk_02 = 0; var_r31->unk_28 = 0.0f; var_r30->unk_04--; } } } void fn_1_79B0(void) { UnkM406Struct10 *var_r31; var_r31 = lbl_1_bss_AC; Hu3DModelAttrSet(var_r31->unk_00, 1); HuSprAnimKill(var_r31->unk_08); } s32 fn_1_79F8(Vec arg0, Vec arg1, float arg8, float arg9, GXColor arg2) { UnkM406Struct5 *var_r31; UnkM406Unk120Struct2 *var_r30; s32 var_r29; UnkM406Struct10 *var_r28; ModelData *var_r27; var_r28 = lbl_1_bss_AC; var_r27 = &Hu3DData[var_r28->unk_00]; var_r30 = var_r27->unk_120; var_r31 = var_r30->unk_3C; for (var_r29 = 0; var_r29 < var_r30->unk_26; var_r29++, var_r31++) { if (var_r31->unk_28 <= 0.0f) { break; } } if (var_r29 >= var_r30->unk_26) { return -1; } var_r31->unk_00 = var_r31->unk_02 = 0; var_r31->unk_30.x = arg0.x; var_r31->unk_30.y = arg0.y; var_r31->unk_30.z = arg0.z; var_r31->unk_04.x = arg1.x; var_r31->unk_04.y = arg1.y; var_r31->unk_04.z = arg1.z; var_r31->unk_18 = arg9; var_r31->unk_28 = arg8; var_r31->unk_3C.r = arg2.r; var_r31->unk_3C.g = arg2.g; var_r31->unk_3C.b = arg2.b; var_r31->unk_3C.a = arg2.a; var_r31->unk_2C = 0.0f; var_r31->unk_40 = 0; var_r31->unk_00 = 0; var_r28->unk_04++; return var_r29; } UnkM406Struct5 *fn_1_7B2C(s32 arg0) { UnkM406Unk120Struct2 *var_r31; UnkM406Struct10 *var_r30; ModelData *var_r29; var_r30 = lbl_1_bss_AC; var_r29 = &Hu3DData[var_r30->unk_00]; var_r31 = var_r29->unk_120; if (arg0 < 0 || arg0 >= var_r31->unk_26) { return NULL; } return &var_r31->unk_3C[arg0]; } void fn_1_7B9C(void) { s32 sp8; UnkM406Struct6 *var_r31; UnkM406Unk120Struct2 *var_r30; ModelData *var_r29; var_r31 = lbl_1_bss_A8 = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(UnkM406Struct6), MEMORY_DEFAULT_NUM); memset(var_r31, 0, sizeof(UnkM406Struct6)); var_r31->unk_00 = sp8 = fn_1_C4F4(512); Hu3DModelLayerSet(var_r31->unk_00, 3); var_r31->unk_04 = 0; var_r29 = &Hu3DData[var_r31->unk_00]; var_r30 = var_r29->unk_120; var_r30->unk_20 = 0; } void fn_1_7C4C(void) { UnkM406Struct5 *var_r31; UnkM406Struct6 *var_r30; UnkM406Unk120Struct2 *var_r29; s32 var_r28; ModelData *var_r27; var_r30 = lbl_1_bss_A8; if (var_r30->unk_04 <= 0) { Hu3DModelAttrSet(var_r30->unk_00, 1); return; } Hu3DModelAttrReset(var_r30->unk_00, 1); var_r27 = &Hu3DData[var_r30->unk_00]; var_r29 = var_r27->unk_120; var_r31 = var_r29->unk_3C; for (var_r28 = 0; var_r28 < var_r29->unk_26; var_r28++, var_r31++) { if (var_r31->unk_28 <= 0.0f) { continue; } var_r31->unk_30.x += var_r31->unk_04.x; var_r31->unk_30.y += var_r31->unk_04.y; var_r31->unk_30.z += var_r31->unk_04.z; var_r31->unk_04.y -= 0.32666668f; if (++var_r31->unk_00 > 60 || var_r31->unk_30.y < var_r31->unk_14 - 200.0f) { var_r31->unk_00 = 0; var_r31->unk_28 = 0.0f; var_r30->unk_04--; } } } void fn_1_7DAC(void) { } s32 fn_1_7DB0(Vec arg0, Vec arg1, float arg8, GXColor arg2) { UnkM406Struct5 *var_r31; UnkM406Unk120Struct2 *var_r30; s32 var_r29; UnkM406Struct6 *var_r28; ModelData *var_r27; var_r28 = lbl_1_bss_A8; var_r27 = &Hu3DData[var_r28->unk_00]; var_r30 = var_r27->unk_120; var_r31 = var_r30->unk_3C; for (var_r29 = 0; var_r29 < var_r30->unk_26; var_r29++, var_r31++) { if (var_r31->unk_28 <= 0.0f) { break; } } if (var_r29 >= var_r30->unk_26) { return -1; } var_r31->unk_00 = var_r31->unk_02 = 0; var_r31->unk_30.x = arg0.x; var_r31->unk_30.y = arg0.y; var_r31->unk_30.z = arg0.z; var_r31->unk_04.x = arg1.x; var_r31->unk_04.y = arg1.y; var_r31->unk_04.z = arg1.z; var_r31->unk_14 = arg0.y; var_r31->unk_28 = arg8; var_r31->unk_3C = arg2; var_r31->unk_00 = 0; var_r28->unk_04++; return var_r29; } void fn_1_7ED0(void) { s32 sp8; UnkM406Struct6 *var_r31; UnkM406Unk120Struct2 *var_r30; ModelData *var_r29; var_r31 = lbl_1_bss_A4 = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(UnkM406Struct6), MEMORY_DEFAULT_NUM); memset(var_r31, 0, sizeof(UnkM406Struct6)); var_r31->unk_00 = sp8 = fn_1_C4F4(512); Hu3DModelLayerSet(var_r31->unk_00, 3); var_r31->unk_04 = 0; var_r29 = &Hu3DData[var_r31->unk_00]; var_r30 = var_r29->unk_120; var_r30->unk_20 = 0; } void fn_1_7F80(void) { UnkM406Struct5 *var_r31; UnkM406Struct6 *var_r30; UnkM406Unk120Struct2 *var_r29; s32 var_r28; ModelData *var_r27; var_r30 = lbl_1_bss_A4; if (var_r30->unk_04 <= 0) { Hu3DModelAttrSet(var_r30->unk_00, 1); return; } Hu3DModelAttrReset(var_r30->unk_00, 1); var_r27 = &Hu3DData[var_r30->unk_00]; var_r29 = var_r27->unk_120; var_r31 = var_r29->unk_3C; for (var_r28 = 0; var_r28 < var_r29->unk_26; var_r28++, var_r31++) { if (var_r31->unk_28 <= 0.0f) { continue; } var_r31->unk_30.x += var_r31->unk_04.x; var_r31->unk_30.y += var_r31->unk_04.y; var_r31->unk_30.z += var_r31->unk_04.z; var_r31->unk_04.y -= var_r31->unk_14; if (var_r31->unk_10 != 0.0f) { var_r31->unk_28 *= var_r31->unk_10; } if (++var_r31->unk_00 > var_r31->unk_02 || var_r31->unk_04.y <= 0.0f) { var_r31->unk_00 = 0; var_r31->unk_28 = 0.0f; var_r30->unk_04 = var_r30->unk_04 - 1; } } } void fn_1_8100(void) { } s32 fn_1_8104(Vec arg0, Vec arg1, float arg8, GXColor arg2) { UnkM406Struct5 *var_r31; UnkM406Unk120Struct2 *var_r30; UnkM406Struct6 *var_r28; s32 var_r29; ModelData *var_r27; var_r28 = lbl_1_bss_A4; var_r27 = &Hu3DData[var_r28->unk_00]; var_r30 = var_r27->unk_120; var_r31 = var_r30->unk_3C; for (var_r29 = 0; var_r29 < var_r30->unk_26; var_r29++, var_r31++) { if (var_r31->unk_28 <= 0.0f) { break; } } if (var_r29 >= var_r30->unk_26) { return -1; } var_r31->unk_00 = var_r31->unk_02 = 0; var_r31->unk_30.x = arg0.x; var_r31->unk_30.y = arg0.y; var_r31->unk_30.z = arg0.z; var_r31->unk_04.x = arg1.x; var_r31->unk_04.y = arg1.y; var_r31->unk_04.z = arg1.z; var_r31->unk_14 = 0.49f; var_r31->unk_10 = 0.0f; var_r31->unk_02 = 30; var_r31->unk_28 = arg8; var_r31->unk_3C.r = arg2.r; var_r31->unk_3C.g = arg2.g; var_r31->unk_3C.b = arg2.b; var_r31->unk_3C.a = arg2.a; var_r31->unk_00 = 0; var_r28->unk_04++; return var_r29; } void fn_1_8244(s32 arg0, s32 arg1, float arg8, float arg9) { UnkM406Struct5 *var_r31; UnkM406Unk120Struct2 *var_r30; UnkM406Struct6 *var_r29; ModelData *var_r28; var_r29 = lbl_1_bss_A4; var_r28 = &Hu3DData[var_r29->unk_00]; var_r30 = var_r28->unk_120; if (arg0 < 0 || arg0 >= var_r30->unk_26) { return; } var_r31 = &var_r30->unk_3C[arg0]; var_r31->unk_10 = arg9; var_r31->unk_14 = arg8; var_r31->unk_02 = arg1; } void fn_1_82C8(Mtx arg0, s32 arg1, float arg8) { Mtx sp8C; Vec sp80; Vec sp74; Vec sp68; Vec sp5C; Vec sp50; Vec sp44; float var_f31; float var_f30; float var_f29; s32 var_r28; sp80.x = arg0[0][3]; sp80.y = arg0[1][3]; sp80.z = arg0[2][3]; sp74.x = sp74.z = 0.0f; sp74.y = atan2d(arg0[0][0], arg0[2][0]); PSMTXCopy(arg0, sp8C); sp8C[0][3] = sp8C[1][3] = sp8C[2][3] = sp8C[3][3] = 0.0f; sp68.x = -25.0f; sp68.z = -50.0f; sp68.y = 0.0f; fn_1_D518(sp8C, &sp68); sp68.x += sp80.x; sp68.y += sp80.y; sp68.z += sp80.z; sp5C.x = -25.0f; sp5C.z = 50.0f; sp5C.y = 0.0f; fn_1_D518(sp8C, &sp5C); sp5C.x += sp80.x; sp5C.y += sp80.y; sp5C.z += sp80.z; mtxRotCat(sp8C, 0.0f, 180.0f + (90.0f - (45.0f * (0.007874016f * (frand() & 0x7F)))), 0.0f); lbl_1_data_89B.a = arg8; var_f30 = sp8C[0][2]; var_f29 = sp8C[2][2]; for (var_r28 = 0; var_r28 < (arg1 >> 1); var_r28++) { fn_1_D488(0.007874016f * (frand() & 0x7F), &sp68, &sp5C, &sp50); sp50.x += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); sp50.y += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); sp50.z += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); sp44.x = 2.0f * var_f30 * (1.0f + (0.007874016f * (frand() & 0x7F))); sp44.z = 2.0f * var_f29 * (1.0f + (0.007874016f * (frand() & 0x7F))); sp44.y = 5.0f * (1.0f + (0.7f * (0.007874016f * (frand() & 0x7F)))); var_f31 = 5.0f + (15.0f * (0.007874016f * (frand() & 0x7F))); fn_1_8104(sp50, sp44, var_f31, lbl_1_data_89B); } sp68.x = -25.0f; sp68.z = -50.0f; sp68.y = 0.0f; fn_1_D518(sp8C, &sp68); sp68.x += sp80.x; sp68.y += sp80.y; sp68.z = sp68.z + sp80.z; sp5C.x = -25.0f; sp5C.z = 50.0f; sp5C.y = 0.0f; fn_1_D518(sp8C, &sp5C); sp5C.x += sp80.x; sp5C.y += sp80.y; sp5C.z += sp80.z; for (var_r28 = 0; var_r28 < (arg1 >> 1); var_r28++) { fn_1_D488(0.007874016f * (frand() & 0x7F), &sp68, &sp5C, &sp50); sp50.x += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); sp50.y += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); sp50.z += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); sp44.x = 2.0f * var_f30 * (1.0f + (0.007874016f * (frand() & 0x7F))); sp44.z = 2.0f * var_f29 * (1.0f + (0.007874016f * (frand() & 0x7F))); sp44.y = 5.0f * (1.0f + (0.7f * (0.007874016f * (frand() & 0x7F)))); var_f31 = 5.0f + (15.0f * (0.007874016f * (frand() & 0x7F))); fn_1_8104(sp50, sp44, var_f31, lbl_1_data_89B); } } void fn_1_8F98(void) { UnkM406Struct7 *var_r31; s32 var_r30; var_r31 = lbl_1_bss_A0 = HuMemDirectMallocNum(HEAP_SYSTEM, 128 * sizeof(UnkM406Struct7), MEMORY_DEFAULT_NUM); memset(lbl_1_bss_A0, 0, 128 * sizeof(UnkM406Struct7)); for (var_r30 = 0, var_r31 = lbl_1_bss_A0; var_r30 < 64; var_r30++, var_r31++) { var_r31->unk_00 = 0; var_r31->unk_01 = 0; var_r31->unk_08 = 0; var_r31->unk_0C = 0.0f; var_r31->unk_10 = 0.0f; var_r31->unk_14 = 6.0f; var_r31->unk_18 = 1.0f; PSMTXIdentity(var_r31->unk_1C); if (var_r30 == 0) { var_r31->unk_04 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 59)); } else { var_r31->unk_04 = Hu3DModelLink(lbl_1_bss_A0->unk_04); } Hu3DModelLayerSet(var_r31->unk_04, 3); Hu3DModelAttrSet(var_r31->unk_04, 1); } for (var_r30 = 0, var_r31 = &lbl_1_bss_A0[64]; var_r30 < 64; var_r30++, var_r31++) { var_r31->unk_00 = 0; var_r31->unk_01 = 0; var_r31->unk_08 = 0; var_r31->unk_0C = 0.0f; var_r31->unk_10 = 0.0f; var_r31->unk_14 = 6.0f; var_r31->unk_18 = 1.0f; PSMTXIdentity(var_r31->unk_1C); if (var_r30 == 0) { var_r31->unk_04 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 60)); } else { var_r31->unk_04 = Hu3DModelLink(lbl_1_bss_A0[64].unk_04); } Hu3DModelLayerSet(var_r31->unk_04, 3); Hu3DModelAttrSet(var_r31->unk_04, 1); } } void fn_1_91E0(void) { Mtx sp8; float var_f31; float var_f30; UnkM406Struct7 *var_r31; ModelData *var_r30; s32 var_r29; var_r31 = lbl_1_bss_A0; for (var_r29 = 0, var_r31 = lbl_1_bss_A0; var_r29 < 64; var_r29++, var_r31++) { if (!var_r31->unk_00) { continue; } var_f30 = var_r31->unk_0C / var_r31->unk_14; var_f31 = var_r31->unk_18 * cosd((90.0f * var_f30)); var_f31 = var_f31; var_r30 = &Hu3DData[var_r31->unk_04]; PSMTXScale(sp8, var_f31, var_f31, var_f31); PSMTXConcat(var_r31->unk_1C, sp8, var_r30->unk_F0); var_r30->unk_F0[0][3] = var_r31->unk_1C[0][3]; var_r30->unk_F0[1][3] = var_r31->unk_1C[1][3]; var_r30->unk_F0[2][3] = var_r31->unk_1C[2][3]; Hu3DModelTPLvlSet(var_r31->unk_04, 1.0f - var_f30); if ((var_r31->unk_0C += var_r31->unk_10) >= var_r31->unk_14) { Hu3DModelAttrSet(var_r31->unk_04, 1); var_r31->unk_00 = 0; var_r31->unk_0C = 0.0f; } var_r31->unk_08++; } for (var_r29 = 0, var_r31 = &lbl_1_bss_A0[64]; var_r29 < 64; var_r29++, var_r31++) { if (!var_r31->unk_00) { continue; } var_f30 = var_r31->unk_0C / var_r31->unk_14; var_f31 = var_r31->unk_18 * cosd((90.0f * var_f30)); var_f31 = var_f31; var_r30 = &Hu3DData[var_r31->unk_04]; PSMTXScale(sp8, var_f31, var_f31, var_f31); PSMTXConcat(var_r31->unk_1C, sp8, var_r30->unk_F0); var_r30->unk_F0[0][3] = var_r31->unk_1C[0][3]; var_r30->unk_F0[1][3] = var_r31->unk_1C[1][3]; var_r30->unk_F0[2][3] = var_r31->unk_1C[2][3]; Hu3DModelTPLvlSet(var_r31->unk_04, 1.0f - var_f30); if ((var_r31->unk_0C += var_r31->unk_10) >= var_r31->unk_14) { Hu3DModelAttrSet(var_r31->unk_04, 1); var_r31->unk_00 = 0; var_r31->unk_0C = 0.0f; } var_r31->unk_08++; } } void fn_1_94BC(void) { } s32 fn_1_94C0(Mtx arg0, s32 arg1, s32 arg2) { Mtx spA0; Mtx sp70; Vec sp64; Vec sp58; Vec sp4C; Vec sp40; Vec sp34; Vec sp28; float var_f31; float var_f30; float var_f29; UnkM406Struct7 *var_r31; s32 var_r28; ModelData *var_r27; sp64.x = arg0[0][3]; sp64.y = arg0[1][3]; sp64.z = arg0[2][3]; sp58.x = sp58.z = 0.0f; sp58.y = atan2d(arg0[0][0], arg0[2][0]); PSMTXCopy(arg0, spA0); spA0[0][3] = spA0[1][3] = spA0[2][3] = spA0[3][3] = 0.0f; if (!arg2) { sp4C.x = 25.0f; sp4C.z = -50.0f; sp4C.y = 0.0f; fn_1_D518(spA0, &sp4C); sp4C.x += sp64.x; sp4C.y += sp64.y; sp4C.z += sp64.z; sp40.x = 25.0f; sp40.z = 50.0f; sp40.y = 0.0f; fn_1_D518(spA0, &sp40); sp40.x += sp64.x; sp40.y += sp64.y; sp40.z += sp64.z; mtxRotCat(spA0, 0.0f, 180.0f + (45.0f * (0.007874016f * (frand() & 0x7F))), 0.0f); } else { sp4C = sp64; sp4C.x = -25.0f; sp4C.z = -50.0f; sp4C.y = 0.0f; fn_1_D518(spA0, &sp4C); sp4C.x += sp64.x; sp4C.y += sp64.y; sp4C.z += sp64.z; sp40 = sp64; sp40.x = -25.0f; sp40.z = 50.0f; sp40.y = 0.0f; fn_1_D518(spA0, &sp40); sp40.x += sp64.x; sp40.y += sp64.y; sp40.z += sp64.z; mtxRotCat(spA0, 0.0f, 180.0f - (45.0f * (0.007874016f * (frand() & 0x7F))), 0.0f); } var_f30 = spA0[0][2]; var_f29 = spA0[2][2]; for (var_r28 = 0; var_r28 < arg1; var_r28++) { fn_1_D488(0.007874016f * (frand() & 0x7F), &sp4C, &sp40, &sp34); sp34.x += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); sp34.y += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); sp34.z += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); sp28.x = 2.0f * var_f30 * (1.0f + (0.007874016f * (frand() & 0x7F))); sp28.z = 2.0f * var_f29 * (1.0f + (0.007874016f * (frand() & 0x7F))); sp28.y = 5.0f * (1.0f + (0.7f * (0.007874016f * (frand() & 0x7F)))); fn_1_8104(sp34, sp28, 7.5f, lbl_1_data_89F); } var_r31 = lbl_1_bss_A0; if (!arg2) { for (var_r28 = 0, var_r31 = lbl_1_bss_A0; var_r28 < 64; var_r28++, var_r31++) { if (!var_r31->unk_00) { break; } } if (var_r28 >= 64) { return -1; } } else { for (var_r28 = 0, var_r31 = &lbl_1_bss_A0[64]; var_r28 < 64; var_r28++, var_r31++) { if (!var_r31->unk_00) { break; } } if (var_r28 >= 64) { return -1; } } var_f31 = 1.2f * (2.0f + (0.007874016f * (frand() & 0x7F))); var_r31->unk_00 = 1; var_r31->unk_08 = 0; var_r31->unk_0C = 0.0f; var_r31->unk_10 = 1.0f; var_r31->unk_14 = 6.0f; var_r31->unk_18 = var_f31; PSMTXCopy(arg0, var_r31->unk_1C); Hu3DMotionTimeSet(var_r31->unk_04, 0.0f); Hu3DMotionSpeedSet(var_r31->unk_04, 0.0f); var_r27 = &Hu3DData[var_r31->unk_04]; PSMTXScale(sp70, var_f31, var_f31, var_f31); PSMTXConcat(arg0, sp70, var_r27->unk_F0); var_r27->unk_F0[0][3] = arg0[0][3]; var_r27->unk_F0[1][3] = arg0[1][3]; var_r27->unk_F0[2][3] = arg0[2][3]; Hu3DModelPosSet(var_r31->unk_04, 0.0f, 0.0f, 0.0f); Hu3DModelRotSet(var_r31->unk_04, 0.0f, 0.0f, 0.0f); Hu3DModelScaleSet(var_r31->unk_04, 1.0f, 1.0f, 1.0f); Hu3DModelAttrReset(var_r31->unk_04, 1); (void)var_r31; return var_r28; } void fn_1_9F78(void) { UnkM406Unk120Struct2 *var_r31; UnkM406Struct8 *var_r30; ModelData *var_r29; UnkM406Struct9 *var_r28; s32 var_r27; var_r30 = lbl_1_bss_9C = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(UnkM406Struct8), MEMORY_DEFAULT_NUM); memset(var_r30, 0, sizeof(UnkM406Struct8)); var_r30->unk_00 = HuSprAnimRead(HuDataReadNum(DATA_MAKE_NUM(DATADIR_M406, 0x40), MEMORY_DEFAULT_NUM)); var_r30->unk_04 = HuSprAnimRead(HuDataReadNum(DATA_MAKE_NUM(DATADIR_M406, 0x41), MEMORY_DEFAULT_NUM)); var_r30->unk_08 = HuSprAnimRead(HuDataReadNum(DATA_MAKE_NUM(DATADIR_M406, 0x42), MEMORY_DEFAULT_NUM)); var_r30->unk_0C = HuSprAnimRead(HuDataReadNum(DATA_MAKE_NUM(DATADIR_M406, 0x43), MEMORY_DEFAULT_NUM)); var_r30->unk_24 = 0.0f; var_r30->unk_28 = 0.0f; var_r27 = fn_1_B474(var_r30->unk_00, 1); var_r30->unk_10 = var_r27; Hu3DModelLayerSet(var_r27, 6); var_r29 = &Hu3DData[var_r27]; var_r31 = var_r29->unk_120; var_r31->unk_20 = 1; var_r31->unk_22 = 2; var_r31->unk_4C = fn_1_A2C8; var_r28 = var_r31->unk_1C = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Struct9), var_r29->unk_48); memset(var_r28, 0, 8); var_r28->unk_02 = 0; var_r27 = fn_1_B474(var_r30->unk_0C, 0xA); var_r30->unk_14 = var_r27; Hu3DModelLayerSet(var_r27, 6); var_r29 = &Hu3DData[var_r27]; var_r31 = var_r29->unk_120; var_r31->unk_20 = 1; var_r31->unk_22 = 3; var_r31->unk_4C = fn_1_A2C8; var_r28 = var_r31->unk_1C = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Struct9), var_r29->unk_48); memset(var_r28, 0, 8); var_r28->unk_02 = 1; var_r27 = fn_1_B474(var_r30->unk_08, 4); var_r30->unk_18 = var_r27; Hu3DModelLayerSet(var_r27, 6); var_r29 = &Hu3DData[var_r27]; var_r31 = var_r29->unk_120; var_r31->unk_20 = 1; var_r31->unk_22 = 3; var_r31->unk_4C = fn_1_A2C8; var_r28 = var_r31->unk_1C = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Struct9), var_r29->unk_48); memset(var_r28, 0, 8); var_r28->unk_02 = 2; var_r27 = fn_1_B474(var_r30->unk_04, 6); var_r30->unk_1C = var_r27; Hu3DModelLayerSet(var_r27, 6); var_r29 = &Hu3DData[var_r27]; var_r31 = var_r29->unk_120; var_r31->unk_20 = 1; var_r31->unk_22 = 3; var_r31->unk_4C = fn_1_A2C8; var_r28 = var_r31->unk_1C = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Struct9), var_r29->unk_48); memset(var_r28, 0, 8); var_r28->unk_02 = 3; var_r30->unk_20 = Hu3DHookFuncCreate(fn_1_ADB4); Hu3DModelLayerSet(var_r30->unk_20, 7); } void fn_1_A278(void) { UnkM406Struct8 *var_r31; var_r31 = lbl_1_bss_9C; HuSprAnimKill(var_r31->unk_00); HuSprAnimKill(var_r31->unk_04); HuSprAnimKill(var_r31->unk_08); HuSprAnimKill(var_r31->unk_0C); } void fn_1_A2C8(ModelData *arg0, UnkM406Unk120Struct2 *arg1, Mtx arg2) { Vec sp3C; Vec sp30; Vec sp24; Vec sp18; void *sp14; s16 sp8; float var_f29; float var_f28; float var_f27; float var_f26; float var_f25; float var_f24; UnkM406Struct5 *var_r31; UnkM406Struct9 *var_r29; s32 var_r28; sp8 = 0; sp14 = lbl_1_bss_9C; var_r29 = arg1->unk_1C; switch (var_r29->unk_04) { case 0: var_r31 = arg1->unk_3C; if (var_r29->unk_02) { sp18.x = 10000.0f; sp18.y = -20000.0f; sp18.z = -20000.0f; var_f28 = (sp18.z * sp18.z) + ((sp18.x * sp18.x) + (sp18.y * sp18.y)); var_f29 = 1.0f / sqrtf(var_f28); sp18.x *= var_f29; sp18.y *= var_f29; sp18.z *= var_f29; var_f24 = 6500.0f / arg1->unk_26; for (var_r28 = 0; var_r28 < arg1->unk_26; var_r28++, var_r31++) { var_f26 = 500.0 + ((var_f24 * var_r28) + ((0.25f * var_f24) * (1.52587890625e-05 * (float)(frand() & 0xFFFF)))); var_f25 = var_f26 / 6500.0f; var_r31->unk_10 = var_f26; var_r31->unk_30.x = var_f26 * sp18.x; var_r31->unk_30.y = -27000.0f + (var_f26 * sp18.y); var_r31->unk_30.z = -63000.0f + (var_f26 * sp18.z); var_r31->unk_28 = (0.3f + (0.7f * (var_f25 * var_f25))) * (lbl_1_data_8A4[var_r29->unk_02] * (0.699999988079071 + (0.30000001192092896 * (1.52587890625e-05 * (float)(frand() & 0xFFFF))))); var_r31->unk_3C.r = (s32)(160.0 * (1.52587890625e-05 * (float)(frand() & 0xFFFF))) + 0x20; var_r31->unk_3C.g = (s32)(96.0 * (1.52587890625e-05 * (float)(frand() & 0xFFFF))) + 0x20; var_r31->unk_3C.b = (s32)(128.0 * (1.52587890625e-05 * (float)(frand() & 0xFFFF))) + 0x20; var_r31->unk_3C.a = ((1.0 - (0.4 * var_f25)) * (255.0f * lbl_1_data_8B4[var_r29->unk_02])) - (int)(16.0 * (1.52587890625e-05 * (float)(frand() & 0xFFFF))); } var_r29->unk_04++; } else { var_r31->unk_30.x = 0.0f; var_r31->unk_30.y = -27000.0f; var_r31->unk_30.z = -63000.0f; var_r31->unk_28 = 1000.0f; } break; case 1: sp3C.x = sind(CRot.y) * cosd(CRot.x); sp3C.y = -sind(CRot.x); sp3C.z = cosd(CRot.y) * cosd(CRot.x); sp30.x = -(Center.x + (1.25f * (sp3C.x * CZoom))); sp30.y = -27000.0f - (Center.y + (sp3C.y * CZoom)); sp30.z = -63000.0f - (Center.z + (1.25f * (sp3C.z * CZoom))); var_f27 = (sp30.z * sp30.z) + ((sp30.x * sp30.x) + (sp30.y * sp30.y)); var_f29 = 1.0f / sqrtf(var_f27); sp30.x *= var_f29; sp30.y *= var_f29; sp30.z *= var_f29; var_f29 = -((-sp30.z * -sp3C.z) + ((-sp30.x * -sp3C.x) + (-sp30.y * -sp3C.y))); sp24.x = -sp3C.x + (-2.0f * sp30.x * var_f29); sp24.y = -sp3C.y + (-2.0f * sp30.y * var_f29); sp24.z = -sp3C.z + (-2.0f * sp30.z * var_f29); var_r31 = arg1->unk_3C; for (var_r28 = 0; var_r28 < arg1->unk_26; var_r28++, var_r31++) { var_r31->unk_30.x = sp24.x * var_r31->unk_10; var_r31->unk_30.y = -27000.0f + (sp24.y * var_r31->unk_10); var_r31->unk_30.z = -63000.0f + (sp24.z * var_r31->unk_10); } break; default: break; } DCFlushRange(arg1->unk_3C, arg1->unk_26 * sizeof(UnkM406Struct5)); PPCSync(); } void fn_1_ADB4(ModelData *arg0, float (*arg1)[4]) { Mtx sp50; Mtx44 sp10; CameraData *var_r31; UnkM406Struct8 *var_r30; GXColor spC = { 0xFF, 0xFF, 0xFF, 0xFF }; var_r31 = &Hu3DCamera[0]; var_r30 = lbl_1_bss_9C; if (var_r30->unk_28 <= 0.0f) { Hu3DModelAttrSet(var_r30->unk_20, 1); return; } GXSetScissor(var_r31->scissor_x, var_r31->scissor_y, var_r31->scissor_w, var_r31->scissor_h); GXSetViewport(0.0f, 0.0f, 640.0f, 480.0f, 0.0f, 1.0f); C_MTXOrtho(sp10, 0.0f, 1.0f, 0.0f, 1.0f, 0.0f, 1.0f); GXSetProjection(sp10, GX_ORTHOGRAPHIC); spC.a = 255.0f * var_r30->unk_28; GXSetTevColor(GX_TEVREG0, spC); GXSetNumTexGens(0); GXSetNumTevStages(1); GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD_NULL, GX_TEXMAP_NULL, GX_COLOR0A0); GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_ZERO, GX_CC_ZERO, GX_CC_ZERO, GX_CC_C0); GXSetTevColorOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV); GXSetTevAlphaIn(GX_TEVSTAGE0, GX_CA_ZERO, GX_CA_ZERO, GX_CA_ZERO, GX_CA_A0); GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV); PSMTXIdentity(sp50); GXLoadPosMtxImm(sp50, 0); GXSetZMode(GX_FALSE, GX_ALWAYS, GX_TRUE); GXSetNumChans(1); GXSetChanCtrl(GX_COLOR0A0, GX_FALSE, GX_SRC_REG, GX_SRC_REG, 0, GX_DF_CLAMP, GX_AF_NONE); GXClearVtxDesc(); GXSetVtxDesc(GX_VA_POS, GX_DIRECT); GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_U8, 0); GXBegin(GX_QUADS, GX_VTXFMT0, 4); GXPosition3u8(0, 0, 0); GXPosition3u8(1, 0, 0); GXPosition3u8(1, 1, 0); GXPosition3u8(0, 1, 0); } void fn_1_B104(float arg8) { UnkM406Struct8 *var_r31; var_r31 = lbl_1_bss_9C; var_r31->unk_24 = arg8; if (var_r31->unk_24 <= 0.0f) { Hu3DModelAttrSet(var_r31->unk_10, 1); Hu3DModelAttrSet(var_r31->unk_14, 1); Hu3DModelAttrSet(var_r31->unk_18, 1); Hu3DModelAttrSet(var_r31->unk_1C, 1); return; } Hu3DModelAttrReset(var_r31->unk_10, 1); Hu3DModelAttrReset(var_r31->unk_14, 1); Hu3DModelAttrReset(var_r31->unk_18, 1); Hu3DModelAttrReset(var_r31->unk_1C, 1); } void fn_1_B1E0(float arg8) { UnkM406Struct8 *var_r31; var_r31 = lbl_1_bss_9C; var_r31->unk_28 = arg8; if (var_r31->unk_28 <= 0.0f) { Hu3DModelAttrSet(var_r31->unk_20, 1); return; } Hu3DModelAttrReset(var_r31->unk_20, 1); } void fn_1_B25C(void) { s32 var_r31; s32 var_r30; if (lbl_1_bss_98 == -1) { lbl_1_bss_98 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 68)); Hu3DModelLayerSet(lbl_1_bss_98, 0); Hu3DModelPosSet(lbl_1_bss_98, 0.0f, -26500.0f, -63000.0f); Hu3DModelRotSet(lbl_1_bss_98, 0.0f, 0.0f, 0.0f); Hu3DModelScaleSet(lbl_1_bss_98, 2.75f, 2.75f, 2.75f); var_r30 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 55)); Hu3DModelLayerSet(var_r30, 0); var_r31 = Hu3DGLightCreateV(&lbl_1_data_8C4, &lbl_1_data_8D0, &lbl_1_data_8DC); Hu3DGLightStaticSet(var_r31, 1); Hu3DGLightPointSet(var_r31, 100.0f, 1.0f, 3); lbl_1_bss_BC = 0; fn_1_2C24(lbl_1_bss_CC); } } void fn_1_B41C(void) { if (lbl_1_bss_98 != -1) { Hu3DModelKill(lbl_1_bss_98); } lbl_1_bss_98 = -1; } void fn_1_B470(void) { } s16 fn_1_B474(AnimData *arg0, s16 arg1) { UnkM406Unk120Struct2 *var_r31; s16 var_r30; Vec2f *var_r29; UnkM406Struct5 *var_r28; ModelData *var_r27; Vec *var_r25; void *var_r24; s16 var_r23; void *var_r22; var_r23 = Hu3DHookFuncCreate(fn_1_BC18); var_r27 = &Hu3DData[var_r23]; var_r31 = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Unk120Struct2), var_r27->unk_48); var_r27->unk_120 = var_r31; var_r31->unk_38 = arg0; var_r31->unk_26 = arg1; var_r31->unk_20 = 0; var_r31->unk_22 = 0; var_r31->unk_4C = 0; var_r31->unk_50 = 0; var_r31->unk_28 = 0; var_r31->unk_21 = 0; var_r31->unk_30 = 0; var_r31->unk_00 = var_r31->unk_02 = 0; var_r28 = HuMemDirectMallocNum(HEAP_DATA, arg1 * sizeof(UnkM406Struct5), var_r27->unk_48); var_r31->unk_3C = var_r28; memset(var_r28, 0, arg1 * sizeof(UnkM406Struct5)); for (var_r30 = 0; var_r30 < arg1; var_r30++, var_r28++) { var_r28->unk_28 = 0.0f; var_r28->unk_2C = 0.0f; var_r28->unk_30.x = ((frand() & 0x7F) - 0x40) * 0x14; var_r28->unk_30.y = ((frand() & 0x7F) - 0x40) * 0x1E; var_r28->unk_30.z = ((frand() & 0x7F) - 0x40) * 0x14; var_r28->unk_3C.r = var_r28->unk_3C.g = var_r28->unk_3C.b = var_r28->unk_3C.a = 0xFF; var_r28->unk_40 = 0; } var_r25 = HuMemDirectMallocNum(HEAP_DATA, arg1 * sizeof(Vec) * 4, var_r27->unk_48); var_r31->unk_40 = var_r25; for (var_r30 = 0; var_r30 < (arg1 * 4); var_r30++, var_r25++) { var_r25->x = var_r25->y = var_r25->z = 0.0f; } var_r29 = HuMemDirectMallocNum(HEAP_DATA, arg1 * sizeof(Vec2f) * 4, var_r27->unk_48); var_r31->unk_44 = var_r29; for (var_r30 = 0; var_r30 < arg1; var_r30++) { var_r29->x = 0.0f; var_r29->y = 0.0f; var_r29++; var_r29->x = 1.0f; var_r29->y = 0.0f; var_r29++; var_r29->x = 1.0f; var_r29->y = 1.0f; var_r29++; var_r29->x = 0.0f; var_r29->y = 1.0f; var_r29++; } var_r24 = HuMemDirectMallocNum(HEAP_DATA, 0x10000, var_r27->unk_48); var_r22 = var_r24; DCFlushRange(var_r24, 0x10000); GXBeginDisplayList(var_r22, 0x10000); GXBegin(GX_QUADS, GX_VTXFMT0, arg1 * 4); for (var_r30 = 0; var_r30 < arg1; var_r30++) { // TODO GXUnknownu16(var_r30 * 4); GXUnknownu16(var_r30); GXUnknownu16(var_r30 * 4); GXUnknownu16(var_r30 * 4 + 1); GXUnknownu16(var_r30); GXUnknownu16(var_r30 * 4 + 1); GXUnknownu16(var_r30 * 4 + 2); GXUnknownu16(var_r30); GXUnknownu16(var_r30 * 4 + 2); GXUnknownu16(var_r30 * 4 + 3); GXUnknownu16(var_r30); GXUnknownu16(var_r30 * 4 + 3); } var_r31->unk_34 = GXEndDisplayList(); var_r31->unk_48 = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_34, var_r27->unk_48); memcpy(var_r31->unk_48, var_r24, var_r31->unk_34); DCFlushRange(var_r31->unk_48, var_r31->unk_34); HuMemDirectFree(var_r24); (void)arg1; return var_r23; } s16 fn_1_B8FC(s16 arg0) { UnkM406Unk120Struct2 *var_r31; Vec2f *var_r30; UnkM406Struct5 *var_r29; ModelData *var_r27; s16 var_r28; UnkM406Unk120Struct2 *var_r26; Vec *var_r25; s32 var_r24; ModelData *var_r23; s16 var_r22; var_r23 = &Hu3DData[arg0]; var_r26 = var_r23->unk_120; var_r22 = Hu3DHookFuncCreate(var_r23->hook); var_r27 = &Hu3DData[var_r22]; var_r31 = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Unk120Struct2), var_r27->unk_48); var_r27->unk_120 = var_r31; var_r31->unk_38 = var_r26->unk_38; var_r31->unk_26 = var_r26->unk_26; var_r24 = var_r31->unk_26; var_r31->unk_20 = 0; var_r31->unk_22 = var_r26->unk_22; var_r31->unk_4C = 0; var_r31->unk_50 = 0; var_r31->unk_28 = 0; var_r31->unk_21 = 0; var_r31->unk_30 = 0; var_r31->unk_00 = var_r31->unk_02 = 0; var_r29 = HuMemDirectMallocNum(HEAP_DATA, var_r24 * sizeof(UnkM406Struct5), var_r27->unk_48); var_r31->unk_3C = var_r29; for (var_r28 = 0; var_r28 < var_r24; var_r28++, var_r29++) { var_r29->unk_28 = 0.0f; var_r29->unk_2C = 0.0f; var_r29->unk_30.x = ((frand() & 0x7F) - 0x40) * 0x14; var_r29->unk_30.y = ((frand() & 0x7F) - 0x40) * 0x1E; var_r29->unk_30.z = ((frand() & 0x7F) - 0x40) * 0x14; var_r29->unk_3C.r = var_r29->unk_3C.g = var_r29->unk_3C.b = var_r29->unk_3C.a = 0xFF; var_r29->unk_40 = 0; } var_r25 = HuMemDirectMallocNum(HEAP_DATA, var_r24 * sizeof(Vec) * 4, var_r27->unk_48); var_r31->unk_40 = var_r25; for (var_r28 = 0; var_r28 < (var_r24 * 4); var_r28++, var_r25++) { var_r25->x = var_r25->y = var_r25->z = 0.0f; } var_r30 = HuMemDirectMallocNum(HEAP_DATA, var_r24 * sizeof(Vec2f) * 4, var_r27->unk_48); var_r31->unk_44 = var_r30; for (var_r28 = 0; var_r28 < var_r24; var_r28++) { var_r30->x = 0.0f; var_r30->y = 0.0f; var_r30++; var_r30->x = 1.0f; var_r30->y = 0.0f; var_r30++; var_r30->x = 1.0f; var_r30->y = 1.0f; var_r30++; var_r30->x = 0.0f; var_r30->y = 1.0f; var_r30++; } var_r31->unk_34 = var_r26->unk_34; var_r31->unk_48 = var_r26->unk_48; return var_r22; } void fn_1_BC18(ModelData *arg0, float (*arg1)[4]) { Mtx sp128; Mtx spF8; Mtx spC8; Vec sp98[4]; Vec sp68[4]; Vec sp38[4]; ROMtx sp8; UnkM406Unk120Struct2 *var_r31; Vec *var_r30; UnkM406Struct5 *var_r29; Vec2f *var_r28; Vec *var_r27; s16 var_r26; s16 var_r25; Vec *var_r24; s16 var_r21; s16 var_r20; s16 var_r19; UnkM406Unk120Struct2Hook var_r18; var_r31 = arg0->unk_120; if (var_r31->unk_2C != GlobalCounter || shadowModelDrawF) { if (var_r31->unk_50 && var_r31->unk_50 != arg0) { fn_1_BC18(var_r31->unk_50, arg1); } GXLoadPosMtxImm(arg1, 0); GXSetNumTevStages(1); GXSetNumTexGens(1); GXSetTexCoordGen2(GX_TEXCOORD0, GX_TG_MTX2x4, GX_TG_TEX0, 0x3C, GX_FALSE, 0x7D); GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD0, GX_TEXMAP0, GX_COLOR0A0); if (shadowModelDrawF) { GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_ONE, GX_CC_ZERO, GX_CC_ZERO, GX_CC_ZERO); GXSetZMode(GX_FALSE, GX_LEQUAL, GX_FALSE); } else { var_r21 = var_r31->unk_38->bmp->dataFmt & 0xF; if (var_r21 == 7 || var_r21 == 8) { GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_ZERO, GX_CC_ONE, GX_CC_RASC, GX_CC_ZERO); } else { GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_ZERO, GX_CC_TEXC, GX_CC_RASC, GX_CC_ZERO); } if (var_r31->unk_22 & 1) { GXSetZMode(GX_FALSE, GX_LEQUAL, GX_FALSE); } else if (arg0->attr & 2) { GXSetZMode(GX_TRUE, GX_LEQUAL, GX_TRUE); } else { GXSetZMode(GX_TRUE, GX_LEQUAL, GX_FALSE); } } GXSetTevColorOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV); GXSetTevAlphaIn(GX_TEVSTAGE0, GX_CA_ZERO, GX_CA_TEXA, GX_CA_RASA, GX_CA_ZERO); GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV); GXSetNumChans(1); GXSetChanCtrl(GX_COLOR0A0, GX_FALSE, GX_SRC_REG, GX_SRC_VTX, 0, GX_DF_CLAMP, GX_AF_NONE); HuSprTexLoad(var_r31->unk_38, 0, 0, GX_REPEAT, GX_REPEAT, GX_LINEAR); GXSetAlphaCompare(GX_GEQUAL, 1, GX_AOP_AND, GX_GEQUAL, 1); GXSetZCompLoc(GX_FALSE); switch (var_r31->unk_20) { case 0: GXSetBlendMode(GX_BM_BLEND, GX_BL_SRCALPHA, GX_BL_INVSRCALPHA, GX_LO_NOOP); break; case 1: GXSetBlendMode(GX_BM_BLEND, GX_BL_SRCALPHA, GX_BL_ONE, GX_LO_NOOP); break; case 2: GXSetBlendMode(GX_BM_BLEND, GX_BL_ZERO, GX_BL_INVDSTCLR, GX_LO_NOOP); break; } GXClearVtxDesc(); GXSetVtxDesc(GX_VA_POS, GX_INDEX16); GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0); GXSetArray(GX_VA_POS, var_r31->unk_40, 0xC); GXSetVtxDesc(GX_VA_CLR0, GX_INDEX16); GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_CLR0, GX_CLR_RGBA, GX_RGBA8, 0); GXSetArray(GX_VA_CLR0, &var_r31->unk_3C->unk_3C, 0x44); GXSetVtxDesc(GX_VA_TEX0, GX_INDEX16); GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_TEX0, GX_TEX_ST, GX_F32, 0); GXSetArray(GX_VA_TEX0, var_r31->unk_44, 8); if (HmfInverseMtxF3X3(arg1, sp128) == 0) { PSMTXIdentity(sp128); } PSMTXReorder(sp128, sp8); if (var_r31->unk_4C) { var_r18 = var_r31->unk_4C; var_r18(arg0, var_r31, arg1); } var_r29 = var_r31->unk_3C; var_r30 = var_r31->unk_40; var_r28 = var_r31->unk_44; PSMTXROMultVecArray(sp8, lbl_1_data_8E0, &sp38[0], 4); for (var_r26 = 0; var_r26 < var_r31->unk_26; var_r26++, var_r29++) { if (!var_r29->unk_28) { var_r30->x = var_r30->y = var_r30->z = 0.0f; var_r30++; var_r30->x = var_r30->y = var_r30->z = 0.0f; var_r30++; var_r30->x = var_r30->y = var_r30->z = 0.0f; var_r30++; var_r30->x = var_r30->y = var_r30->z = 0.0f; var_r30++; } else if (!var_r29->unk_2C) { var_r27 = &sp98[0]; var_r24 = &sp38[0]; PSVECScale(var_r24++, var_r27, var_r29->unk_28); PSVECAdd(var_r27++, &var_r29->unk_30, var_r30++); PSVECScale(var_r24++, var_r27, var_r29->unk_28); PSVECAdd(var_r27++, &var_r29->unk_30, var_r30++); PSVECScale(var_r24++, var_r27, var_r29->unk_28); PSVECAdd(var_r27++, &var_r29->unk_30, var_r30++); PSVECScale(var_r24++, var_r27, var_r29->unk_28); PSVECAdd(var_r27++, &var_r29->unk_30, var_r30++); } else { PSVECScale(lbl_1_data_8E0, &sp98[0], var_r29->unk_28); PSVECScale(&lbl_1_data_8E0[1], &sp98[1], var_r29->unk_28); PSVECScale(&lbl_1_data_8E0[2], &sp98[2], var_r29->unk_28); PSVECScale(&lbl_1_data_8E0[3], &sp98[3], var_r29->unk_28); PSMTXRotRad(spC8, 90, var_r29->unk_2C); PSMTXConcat(sp128, spC8, spF8); PSMTXMultVecArray(spF8, &sp98[0], &sp68[0], 4); PSVECAdd(&sp68[0], &var_r29->unk_30, var_r30++); PSVECAdd(&sp68[1], &var_r29->unk_30, var_r30++); PSVECAdd(&sp68[2], &var_r29->unk_30, var_r30++); PSVECAdd(&sp68[3], &var_r29->unk_30, var_r30++); } } var_r29 = var_r31->unk_3C; var_r28 = var_r31->unk_44; if ((var_r31->unk_22 & 2) == 0) { for (var_r26 = 0; var_r26 < var_r31->unk_26; var_r26++, var_r29++) { var_r20 = var_r29->unk_40 & 3; var_r19 = (var_r29->unk_40 >> 2) & 3; for (var_r25 = 0; var_r25 < 4; var_r25++, var_r28++) { var_r28->x = (0.25f * var_r20) + lbl_1_data_910[var_r25].x; var_r28->y = (0.25f * var_r19) + lbl_1_data_910[var_r25].y; } } } else { for (var_r26 = 0; var_r26 < var_r31->unk_26; var_r26++, var_r29++) { for (var_r25 = 0; var_r25 < 4; var_r25++, var_r28++) { var_r28->x = 4.0f * lbl_1_data_910[var_r25].x; var_r28->y = 4.0f * lbl_1_data_910[var_r25].y; } } } DCFlushRangeNoSync(var_r31->unk_40, var_r31->unk_26 * 0xC * 4); DCFlushRangeNoSync(var_r31->unk_44, var_r31->unk_26 * 8 * 4); DCFlushRangeNoSync(var_r31->unk_3C, var_r31->unk_26 * 0x44); PPCSync(); GXCallDisplayList(var_r31->unk_48, var_r31->unk_34); if (!shadowModelDrawF) { if ((var_r31->unk_21 & 2) == 0) { var_r31->unk_28++; } if ((var_r31->unk_30 != 0) && (var_r31->unk_30 <= var_r31->unk_28)) { if (var_r31->unk_21 & 1) { var_r31->unk_28 = 0; } var_r31->unk_28 = var_r31->unk_30; } var_r31->unk_2C = GlobalCounter; } } } s16 fn_1_C4F4(s16 arg0) { Vec2f *sp8; UnkM406Unk120Struct2 *var_r31; UnkM406Struct5 *var_r30; s16 var_r29; ModelData *var_r28; Vec *var_r27; void *var_r25; s16 var_r24; void *var_r23; var_r24 = Hu3DHookFuncCreate(fn_1_C86C); var_r28 = &Hu3DData[var_r24]; var_r31 = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Unk120Struct2), var_r28->unk_48); var_r28->unk_120 = var_r31; var_r31->unk_38 = 0; var_r31->unk_26 = arg0; var_r31->unk_20 = 0; var_r31->unk_22 = 0; var_r31->unk_4C = 0; var_r31->unk_50 = 0; var_r31->unk_28 = 0; var_r31->unk_21 = 0; var_r31->unk_30 = 0; var_r31->unk_00 = var_r31->unk_02 = 0; var_r30 = HuMemDirectMallocNum(HEAP_DATA, arg0 * sizeof(UnkM406Struct5), var_r28->unk_48); var_r31->unk_3C = var_r30; memset(var_r30, 0, arg0 * sizeof(UnkM406Struct5)); for (var_r29 = 0; var_r29 < arg0; var_r29++, var_r30++) { var_r30->unk_28 = 0.0f; var_r30->unk_2C = 0.0f; var_r30->unk_30.x = ((frand() & 0x7F) - 0x40) * 0x14; var_r30->unk_30.y = ((frand() & 0x7F) - 0x40) * 0x1E; var_r30->unk_30.z = ((frand() & 0x7F) - 0x40) * 0x14; var_r30->unk_3C.r = var_r30->unk_3C.g = var_r30->unk_3C.b = var_r30->unk_3C.a = 0xFF; var_r30->unk_40 = 0; } var_r27 = HuMemDirectMallocNum(HEAP_DATA, arg0 * sizeof(Vec) * 4, var_r28->unk_48); var_r31->unk_40 = var_r27; for (var_r29 = 0; var_r29 < (arg0 * 4); var_r29++, var_r27++) { var_r27->x = var_r27->y = var_r27->z = 0.0f; } var_r31->unk_44 = sp8 = NULL; var_r25 = HuMemDirectMallocNum(HEAP_DATA, 0x10000, var_r28->unk_48); var_r23 = var_r25; DCFlushRange(var_r25, 0x10000); GXBeginDisplayList(var_r23, 0x10000); GXBegin(GX_QUADS, GX_VTXFMT0, arg0 * 4); for (var_r29 = 0; var_r29 < arg0; var_r29++) { GXUnknownu16(var_r29 * 4); GXUnknownu16(var_r29); GXUnknownu16(var_r29 * 4 + 1); GXUnknownu16(var_r29); GXUnknownu16(var_r29 * 4 + 2); GXUnknownu16(var_r29); GXUnknownu16(var_r29 * 4 + 3); GXUnknownu16(var_r29); } var_r31->unk_34 = GXEndDisplayList(); var_r31->unk_48 = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_34, var_r28->unk_48); memcpy(var_r31->unk_48, var_r25, var_r31->unk_34); DCFlushRange(var_r31->unk_48, var_r31->unk_34); HuMemDirectFree(var_r25); return var_r24; } void fn_1_C86C(ModelData *arg0, Mtx arg1) { Mtx sp9C; ROMtx sp6C; ROMtx sp3C; ROMtx spC; Vec2f *sp8; UnkM406Unk120Struct2 *var_r31; Vec *var_r30; UnkM406Struct5 *var_r29; Vec *var_r28; Vec *var_r27; s16 var_r25; UnkM406Unk120Struct2Hook var_r23; var_r31 = arg0->unk_120; if (var_r31->unk_2C != GlobalCounter || shadowModelDrawF) { if (var_r31->unk_50 && var_r31->unk_50 != arg0) { fn_1_C86C(var_r31->unk_50, arg1); } GXLoadPosMtxImm(arg1, 0); GXSetNumTevStages(1); GXSetNumTexGens(0); GXSetTexCoordGen2(GX_TEXCOORD0, GX_TG_MTX2x4, GX_TG_TEX0, 0x3C, GX_FALSE, 0x7D); GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD_NULL, GX_TEXMAP_NULL, GX_COLOR0A0); GXSetTevOp(GX_TEVSTAGE0, GX_PASSCLR); GXSetNumChans(1); GXSetChanCtrl(GX_COLOR0A0, GX_FALSE, GX_SRC_REG, GX_SRC_VTX, 0, GX_DF_CLAMP, GX_AF_NONE); GXSetAlphaCompare(GX_GEQUAL, 1, GX_AOP_AND, GX_GEQUAL, 1); GXSetZCompLoc(GX_FALSE); if (arg0->attr & 2) { GXSetZMode(GX_TRUE, GX_LEQUAL, GX_TRUE); } else { GXSetZMode(GX_TRUE, GX_LEQUAL, GX_FALSE); } switch (var_r31->unk_20) { case 0: GXSetBlendMode(GX_BM_BLEND, GX_BL_SRCALPHA, GX_BL_INVSRCALPHA, GX_LO_NOOP); break; case 1: GXSetBlendMode(GX_BM_BLEND, GX_BL_SRCALPHA, GX_BL_ONE, GX_LO_NOOP); break; case 2: GXSetBlendMode(GX_BM_BLEND, GX_BL_ZERO, GX_BL_INVDSTCLR, GX_LO_NOOP); break; } GXClearVtxDesc(); GXSetVtxDesc(GX_VA_POS, GX_INDEX16); GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0); GXSetArray(GX_VA_POS, var_r31->unk_40, sizeof(Vec)); GXSetVtxDesc(GX_VA_CLR0, GX_INDEX16); GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_CLR0, GX_CLR_RGBA, GX_RGBA8, 0); GXSetArray(GX_VA_CLR0, &var_r31->unk_3C->unk_3C, 0x44); if (HmfInverseMtxF3X3(arg1, sp9C) == 0) { PSMTXIdentity(sp9C); } PSMTXReorder(sp9C, spC); if (var_r31->unk_4C) { var_r23 = var_r31->unk_4C; var_r23(arg0, var_r31, arg1); } var_r29 = var_r31->unk_3C; var_r30 = var_r31->unk_40; sp8 = var_r31->unk_44; PSMTXROMultVecArray(spC, lbl_1_data_930, (Vec *)sp3C, 4); for (var_r25 = 0; var_r25 < var_r31->unk_26; var_r25++, var_r29++) { if (!var_r29->unk_28) { var_r30->x = var_r30->y = var_r30->z = 0.0f; var_r30++; var_r30->x = var_r30->y = var_r30->z = 0.0f; var_r30++; var_r30->x = var_r30->y = var_r30->z = 0.0f; var_r30++; var_r30->x = var_r30->y = var_r30->z = 0.0f; var_r30++; } else { var_r28 = (Vec *)&sp6C; var_r27 = (Vec *)&sp3C; PSVECScale(var_r27++, var_r28, var_r29->unk_28); PSVECAdd(var_r28++, &var_r29->unk_30, var_r30++); PSVECScale(var_r27++, var_r28, var_r29->unk_28); PSVECAdd(var_r28++, &var_r29->unk_30, var_r30++); PSVECScale(var_r27++, var_r28, var_r29->unk_28); PSVECAdd(var_r28++, &var_r29->unk_30, var_r30++); PSVECScale(var_r27++, var_r28, var_r29->unk_28); PSVECAdd(var_r28++, &var_r29->unk_30, var_r30++); } } DCFlushRangeNoSync(var_r31->unk_40, var_r31->unk_26 * 0xC * 4); DCFlushRangeNoSync(var_r31->unk_3C, var_r31->unk_26 * 0x44); PPCSync(); GXCallDisplayList(var_r31->unk_48, var_r31->unk_34); if (!shadowModelDrawF) { if ((var_r31->unk_21 & 2) == 0) { var_r31->unk_28++; } if ((var_r31->unk_30 != 0) && (var_r31->unk_30 <= var_r31->unk_28)) { if (var_r31->unk_21 & 1) { var_r31->unk_28 = 0; } var_r31->unk_28 = var_r31->unk_30; } var_r31->unk_2C = GlobalCounter; } } } s32 fn_1_CD34(s32 arg0, s32 arg1, s32 arg2) { ModelData *var_r29; ModelData *var_r30; s32 var_r31; var_r29 = &Hu3DData[arg0]; var_r30 = &Hu3DData[arg2]; for (var_r31 = 0; var_r31 < 8; var_r31++) { if (var_r30->unk_38[var_r31] == -1) { break; } } if (var_r31 == 8) { return -1; } var_r30->unk_38[var_r31] = var_r29->unk_38[arg1]; var_r30->attr |= 0x1000; return var_r31; } void fn_1_CDD8(s32 arg0, float arg8, float arg9, float argA, float argB) { HsfMaterial *var_r31; s32 var_r30; HsfData *var_r29; s32 var_r28; ModelData *var_r27; s32 var_r26; var_r27 = &Hu3DData[arg0]; var_r29 = var_r27->hsfData; var_r31 = var_r29->material; var_r26 = var_r29->materialCnt; for (var_r28 = 0; var_r28 < var_r26; var_r28++, var_r31++) { var_r31->vtxMode = 1; var_r30 = arg9 * (var_r31->litColor[0] * arg8); if (var_r30 > 0xFF) { var_r30 = 0xFF; } var_r31->litColor[0] = var_r30; var_r30 = argA * (var_r31->litColor[1] * arg8); if (var_r30 > 0xFF) { var_r30 = 0xFF; } var_r31->litColor[1] = var_r30; var_r30 = argB * (var_r31->litColor[2] * arg8); if (var_r30 > 0xFF) { var_r30 = 0xFF; } var_r31->litColor[2] = var_r30; } } void fn_1_CF24(s32 arg0, u8 arg1, u8 arg2, u8 arg3) { HsfMaterial *var_r31; HsfData *var_r30; s32 var_r29; ModelData *var_r28; s32 var_r27; var_r28 = &Hu3DData[arg0]; var_r30 = var_r28->hsfData; var_r31 = var_r30->material; var_r27 = var_r30->materialCnt; for (var_r29 = 0; var_r29 < var_r27; var_r29++, var_r31++) { var_r31->vtxMode = 1; var_r31->litColor[0] = arg1; var_r31->litColor[1] = arg2; var_r31->litColor[2] = arg3; } } void fn_1_CF98(s32 arg0, s32 arg1) { s32 var_r31; HsfData *var_r30; HsfData *var_r29; ModelData *var_r28; ModelData *var_r27; var_r28 = &Hu3DData[arg0]; var_r27 = &Hu3DData[arg1]; var_r29 = var_r28->hsfData; var_r30 = var_r27->hsfData; for (var_r31 = 0; var_r31 < var_r30->bitmapCnt; var_r31++) { memcpy(&var_r30->bitmap[var_r31], &var_r29->bitmap[var_r31], 0x20); } for (var_r31 = 0; var_r31 < var_r30->attributeCnt; var_r31++) { memcpy(&var_r30->attribute[var_r31], &var_r29->attribute[var_r31], 0x84); } } s16 fn_1_D06C(ModelData *arg0, Mtx arg1, Mtx arg2, float arg8) { s16 var_r31; s16 var_r29; s16 var_r28; LightData *var_r27; var_r28 = 0; var_r29 = 1; if (arg0->attr & 0x1000) { for (var_r31 = 0; var_r31 < 8; var_r31++) { if (arg0->unk_38[var_r31] != -1) { var_r27 = &Hu3DLocalLight[arg0->unk_38[var_r31]]; fn_1_D13C(var_r27, var_r29, arg2, arg1, arg8); var_r28 |= var_r29; var_r29 <<= 1; } } } return var_r28; } void fn_1_D13C(LightData *arg0, s16 arg1, Mtx arg2, Mtx arg3, float arg8) { GXLightObj sp30; Vec sp24; Vec sp18; switch ((u8)arg0->unk_00) { case 0: GXInitLightAttn(&sp30, 1.0f, 0.0f, 0.0f, 1.0f, 0.0f, 0.0f); GXInitLightSpot(&sp30, arg0->unk_04, arg0->unk_02); break; case 1: GXInitLightAttn(&sp30, 1.0f, 0.0f, 0.0f, 1.0f, 0.0f, 0.0f); GXInitLightSpot(&sp30, 20.0f, GX_SP_COS); GXInitLightAttnK(&sp30, 1.0f, 0.0f, 0.0f); PSVECScale(&arg0->unk_28, &arg0->unk_1C, -1000000.0f); break; case 2: GXInitLightAttn(&sp30, 1.0f, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f); GXInitLightDistAttn(&sp30, arg0->unk_04, arg0->unk_08, arg0->unk_02); break; default: break; } if (arg0->unk_00 & 0x8000) { PSMTXMultVec(arg2, &arg0->unk_28, &sp24); PSMTXMultVec(arg3, &arg0->unk_1C, &sp18); GXInitLightPos(&sp30, sp18.x, sp18.y, sp18.z); } else { GXInitLightPos(&sp30, arg0->unk_1C.x, arg0->unk_1C.y, arg0->unk_1C.z); sp24 = arg0->unk_28; } if (arg8 == 0.0f) { GXInitLightDir(&sp30, sp24.x, sp24.y, sp24.z); } else { GXInitSpecularDir(&sp30, sp24.x, sp24.y, sp24.z); GXInitLightAttn(&sp30, 0.0f, 0.0f, 1.0f, arg8 / 2, 0.0f, 1.0f - (arg8 / 2)); } GXInitLightColor(&sp30, arg0->color); GXLoadLightObjImm(&sp30, arg1); } void fn_1_D488(float arg8, Vec *arg0, Vec *arg1, Vec *arg2) { lbl_1_bss_3C.x = arg0->x + (arg8 * (arg1->x - arg0->x)); lbl_1_bss_3C.y = arg0->y + (arg8 * (arg1->y - arg0->y)); lbl_1_bss_3C.z = arg0->z + (arg8 * (arg1->z - arg0->z)); *arg2 = lbl_1_bss_3C; } void fn_1_D518(Mtx arg0, Vec *arg1) { Vec sp8; sp8.x = (arg0[0][2] * arg1->z) + ((arg0[0][0] * arg1->x) + (arg0[0][1] * arg1->y)); sp8.y = (arg0[1][2] * arg1->z) + ((arg0[1][0] * arg1->x) + (arg0[1][1] * arg1->y)); sp8.z = (arg0[2][2] * arg1->z) + ((arg0[2][0] * arg1->x) + (arg0[2][1] * arg1->y)); *arg1 = sp8; } float fn_1_D5CC(Vec *arg0, Vec *arg1, float arg8, float arg9) { float var_f31; float var_f30; float var_f29; float var_f28; float var_f27; var_f31 = arg0->x - arg8; var_f30 = arg0->z - arg9; var_f29 = arg1->x - arg8; var_f28 = arg1->z - arg9; var_f27 = -((var_f30 * var_f29) - (var_f31 * var_f28)); return var_f27; }