Merge branch 'Rainchus:main' into main

This commit is contained in:
CreateSource 2024-05-12 18:07:33 -04:00 committed by GitHub
commit bc6ce69f6c
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
85 changed files with 13335 additions and 1465 deletions

View file

@ -0,0 +1,501 @@
#include "ext_math.h"
#include "game/gamework_data.h"
#include "game/hsfman.h"
#include "game/init.h"
#include "game/objsub.h"
#include "game/sprite.h"
#include "game/window.h"
#include "rel_sqrt_consts.h"
#include "REL/E3SetupDLL.h"
static s16 mgDefault;
static omObjData *mgInterfaceObj;
static omObjData *mgSelectObj;
static omObjData *mgPicObj;
s32 lbl_2_bss_14;
s16 lbl_2_bss_10;
s16 lbl_2_bss_E;
s16 lbl_2_bss_C;
s16 lbl_2_bss_A;
static s16 lbl_2_bss_0[5];
float lbl_2_data_0[] = { 0, 12000, 0, 0, 0, 0, 0, 0, -1 };
static void StartMGSelect(omObjData *object);
static void UpdatePad(omObjData *object);
static void CreateMGSelect(omObjData *object);
static void CreateMGPic(omObjData *object);
static void UpdateMGInterface(omObjData *object);
static void CreateMGInterface(omObjData *object);
void E3MGSelectInit()
{
s32 var_r29;
s32 var_r30;
Process *var_r31;
for (var_r29 = 0, var_r30 = 0; var_r29 < 4; var_r29++) {
if (HuPadStatGet(var_r29) == 0) {
var_r30++;
}
}
e3ConfigPlayerCnt = var_r30;
if (var_r30 <= 0) {
OSReport("No pad detected\n");
var_r30++;
}
mgDefault = 0;
HuSysVWaitSet(1);
var_r31 = omInitObjMan(0x50, 0x2000);
HuWinInit(1);
CRot.x = -4.0f;
CRot.y = 0.0f;
CRot.z = 0.0f;
Center.x = 0.0f;
Center.y = 160.0f;
Center.z = 0.0f;
CZoom = 1960.0;
e3CameraFov = 40.0f;
Hu3DCameraCreate(1);
Hu3DCameraPerspectiveSet(1, e3CameraFov, 100.0f, 25000.0f, 4.0f / 3.0f);
e3ViewObj = omAddObjEx(var_r31, 32730, 0, 0, -1, omOutView);
e3OvlWatchObj = omAddObjEx(var_r31, 200, 0, 0, -1, E3OvlWatchInit);
e3MenuMainObj = omAddObjEx(var_r31, 10, 0, 0, -1, StartMGSelect);
e3BGObj = omAddObjEx(var_r31, 0x14, 0, 0, -1, E3BGCreate);
mgInterfaceObj = omAddObjEx(var_r31, 20, 0, 0, -1, CreateMGInterface);
mgSelectObj = omAddObjEx(var_r31, 30, 0, 0, -1, CreateMGSelect);
mgPicObj = omAddObjEx(var_r31, 31, 0, 0, -1, CreateMGPic);
mgPicObj->work[0] = mgDefault;
E3LightInit();
WipeCreate(1, 0, -1);
}
s16 lbl_2_data_36[] = { 0x0023, 0x0026, 0x0029, 0x002C };
static s16 mgOvlTbl[] = {
11,
12,
15,
18,
20,
23,
26,
27,
33,
34,
39,
44,
46,
};
static s16 mgIdTbl[] = { 403, 404, 407, 410, 412, 415, 418, 419, 425, 426, 431, 436, 438, 0 };
static s32 mgNameTbl[] = {
0x00170003,
0x00170004,
0x00170007,
0x0017000A,
0x0017000C,
0x0017000F,
0x00170012,
0x00170013,
0x00170019,
0x0017001A,
0x0017001F,
0x00170024,
0x00170026,
};
char lbl_2_data_A8[] = "\013TEST MINIGAME NAME01\n test";
char lbl_2_data_C9[] = "\013TEST MINIGAME NAME02";
char lbl_2_data_DF[] = "\013TEST MINIGAME NAME03";
char lbl_2_data_F5[] = "\013TEST MINIGAME NAME04";
char lbl_2_data_10B[] = "\013TEST NAME05";
char lbl_2_data_118[] = "\013TEST MINIGAME NAME06";
char lbl_2_data_12E[] = "\013TEST NAME07";
char lbl_2_data_13B[] = "\013TEST MINIGAME NAME08";
char lbl_2_data_151[] = "\013TEST MINIGAME NAME09";
char lbl_2_data_167[] = "\013TEST MINIGAME NAME10";
char lbl_2_data_17D[] = "\013TEST MINIGAME NAME11";
char lbl_2_data_193[] = "\013TEST MINIGAME NAME12";
char lbl_2_data_1A9[] = "\013TEST MINIGAME NAME13";
static char *mgNameTestTbl[] = {
lbl_2_data_A8,
lbl_2_data_C9,
lbl_2_data_DF,
lbl_2_data_F5,
lbl_2_data_10B,
lbl_2_data_118,
lbl_2_data_12E,
lbl_2_data_13B,
lbl_2_data_151,
lbl_2_data_167,
lbl_2_data_17D,
lbl_2_data_193,
lbl_2_data_1A9,
};
static float cursorYOfsTbl[] = { -100.0f, -50.0f, 0.0f, 50.0f, 100.0f };
static s32 mgPicTbl[] = { 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52 };
static char startText[] = "\013\016\r PRESS START";
static void StartMGSelect(omObjData *object)
{
HuAudSeqPlay(0x2B);
lbl_2_bss_14 = 0;
lbl_2_bss_10 = -1;
lbl_2_bss_C = 0x1E;
lbl_2_bss_A = 0;
object->func = UpdatePad;
worstVcount = 0;
object->work[0] = 0;
object->work[1] = 0;
}
static void UpdatePad(omObjData *object)
{
s32 i;
s32 players;
if (e3ExitEnableF == 0) {
for (i = 0, players = 0; i < 4; i++) {
E3PadUpdate(i, &e3PadData[i]);
if (!e3PadData[i].enable) {
players++;
}
}
e3ConfigPlayerCnt = players;
}
}
static void UpdateMGSelect(omObjData *object)
{
mgSelect *var_r31;
s32 var_r30;
u32 var_r28;
s16 var_r27;
s16 var_r26;
s16 var_r25;
s16 var_r24;
u16 var_r23;
s16 var_r22;
s32 var_r21;
float sp8[2];
var_r31 = object->data;
var_r23 = e3PadData[e3PadCtrl].btnDown;
if (object->work[3] != 0) {
if ((var_r23 & 0x1100) != 0) {
HuAudFXPlay(1);
mgDefault = var_r31->unk_44;
var_r21 = mgIdTbl[var_r31->unk_44];
GWMGAvailSet(var_r21);
GWSystem.mg_next = var_r21 - 401;
e3NextOvl = 3;
e3NextEvent = 0;
e3ExitMode = 2;
e3ExitEnableF = 1;
var_r28 = mgOvlTbl[var_r31->unk_44];
for (var_r30 = 0; var_r30 < 50; var_r30++) {
if (var_r28 == mgInfoTbl[var_r30].ovl) {
break;
}
}
if (var_r30 >= 50) {
e3ExitMode = 0;
e3NextOvl = 0;
};
switch (mgInfoTbl[var_r30].type) {
case 0:
case 3:
case 4:
case 5:
case 6:
for (var_r30 = 0; var_r30 < 4; var_r30++) {
GWPlayerCfg[var_r30].group = var_r30;
}
break;
case 1:
var_r28 = frand();
var_r28 &= 3;
for (var_r30 = 0; var_r30 < 4; var_r30++) {
if (var_r28 == var_r30) {
GWPlayerCfg[var_r30].group = 0;
} else {
GWPlayerCfg[var_r30].group = 1;
}
}
break;
case 2:
for (var_r30 = 0; var_r30 < 2; var_r30++) {
GWPlayerCfg[var_r30].group = 0;
}
for (var_r30 = 2; var_r30 < 4; var_r30++) {
GWPlayerCfg[var_r30].group = 1;
}
break;
}
object->work[3] = 0;
return;
}
if ((var_r23 & 0x200) != 0) {
HuAudFXPlay(3);
e3ExitMode = 0;
e3NextOvl = 0;
e3NextEvent = 0;
e3ExitEnableF = 1;
object->work[3] = 0;
return;
}
if (object->work[3] != 0) {
if ((var_r23 & 8) != 0) {
HuAudFXPlay(0);
var_r31->unk_44--;
if (var_r31->unk_44 < 0) {
var_r31->unk_44 = 0xC;
}
} else if ((var_r23 & 4) != 0) {
HuAudFXPlay(0);
var_r31->unk_44++;
if (var_r31->unk_44 >= 13) {
var_r31->unk_44 = 0;
}
}
if (var_r31->unk_46 != var_r31->unk_44) {
mgPicObj->work[0] = var_r31->unk_44;
var_r27 = var_r31->unk_44 - var_r31->unk_46;
if ((var_r27 > 1) || (var_r27 < -1)) {
if (var_r27 < 0) {
var_r27 = 1;
} else {
var_r27 = -1;
}
}
var_r25 = var_r31->unk_42 + var_r27;
if ((var_r25 < 0) || (var_r25 >= 5)) {
for (var_r30 = 0; var_r30 < 5; var_r30++) {
var_r22 = var_r31->unk_2E[var_r30];
var_r26 = var_r31->unk_38[var_r30];
var_r24 = var_r26 - var_r27;
if ((var_r24 < 0) || (var_r24 >= 5)) {
var_r28 = mgNameTbl[var_r31->unk_44];
HuWinMesSizeCancelCRSet(1);
HuWinMesMaxSizeGet(1, sp8, var_r28);
HuWinCenterPosSet(var_r22, (296.0f - sp8[0]) / -2.0f, (68.0f - sp8[1]) / -2.0f);
HuWinMesSet(var_r22, var_r28);
if (var_r24 < 0) {
var_r26 = 4;
} else {
var_r26 = 0;
}
} else {
var_r26 = var_r24;
}
HuWinPosSet(var_r22, 36.0f, 237.0f + cursorYOfsTbl[var_r26]);
var_r31->unk_38[var_r30] = var_r26;
}
} else {
var_r31->unk_42 = var_r25;
HuSprPosSet(var_r31->unk_1C, 1, 0.0f, cursorYOfsTbl[var_r25]);
}
var_r31->unk_46 = var_r31->unk_44;
}
}
}
}
static void CreateMGSelect(omObjData *object)
{
mgSelect *temp_r31;
s16 temp_r30;
s16 temp_r29;
s32 var_r28;
s16 var_r26;
s16 index2;
u32 temp_r22;
s32 temp_r21;
AnimData *temp_r25;
AnimData *temp_r23;
float sp8[2];
omSetStatBit(object, OM_STAT_MODEL_PAUSED);
object->data = HuMemDirectMallocNum(HEAP_SYSTEM, 0x48, MEMORY_DEFAULT_NUM);
temp_r31 = object->data;
index2 = 0;
temp_r30 = HuSprGrpCreate(3);
temp_r31->unk_1C = temp_r30;
HuSprGrpPosSet(temp_r30, 174.0f, 271.0f);
temp_r25 = HuSprAnimRead(HuDataReadNum(0x21, MEMORY_DEFAULT_NUM));
temp_r31->unk_00[index2] = temp_r25;
temp_r29 = HuSprCreate(temp_r25, 0x7540, 0);
HuSprGrpMemberSet(temp_r30, index2, temp_r29);
index2++;
temp_r25 = HuSprAnimRead(HuDataReadNum(0x27, MEMORY_DEFAULT_NUM));
temp_r31->unk_00[index2] = temp_r25;
temp_r29 = HuSprCreate(temp_r25, 0x64, 0);
HuSprGrpMemberSet(temp_r30, index2, temp_r29);
HuSprScaleSet(temp_r30, index2, 1.1f, 1.0f);
HuSprTPLvlSet(temp_r30, index2, 0.5f);
temp_r31->unk_42 = 0;
HuSprPosSet(temp_r30, index2, 0.0f, cursorYOfsTbl[temp_r31->unk_42]);
index2++;
temp_r25 = HuSprAnimRead(HuDataReadNum(0x35, MEMORY_DEFAULT_NUM));
temp_r31->unk_00[index2++] = temp_r25;
temp_r23 = HuSprAnimRead(HuDataReadNum(0x36, MEMORY_DEFAULT_NUM));
temp_r31->unk_00[index2++] = temp_r23;
temp_r30 = HuSprGrpCreate(2);
temp_r31->unk_1E = temp_r30;
HuSprGrpPosSet(temp_r30, 174.0f, 128.0f);
temp_r29 = HuSprCreate(temp_r25, 4, 0);
HuSprGrpMemberSet(temp_r30, 0, temp_r29);
temp_r29 = HuSprCreate(temp_r23, 6, 0);
HuSprGrpMemberSet(temp_r30, 1, temp_r29);
HuSprTPLvlSet(temp_r30, 1, 0.7f);
HuSprPosSet(temp_r30, 1, 0.0f, -4.0f);
temp_r30 = HuSprGrpCreate(2);
temp_r31->unk_20 = temp_r30;
HuSprGrpPosSet(temp_r30, 174.0f, 414.0f);
temp_r29 = HuSprCreate(temp_r25, 4, 1);
HuSprGrpMemberSet(temp_r30, 0, temp_r29);
temp_r29 = HuSprCreate(temp_r23, 6, 1);
HuSprGrpMemberSet(temp_r30, 1, temp_r29);
HuSprTPLvlSet(temp_r30, 1, 0.7f);
HuSprPosSet(temp_r30, 1, 0.0f, -4.0f);
temp_r21 = GWSystem.mg_next + 401;
var_r26 = temp_r21;
for (var_r28 = 0; var_r28 < 13;) {
if (var_r26 != mgIdTbl[var_r28]) {
var_r28++;
} else {
break;
}
}
if (var_r28 >= 13) {
var_r28 = 0;
}
mgDefault = var_r28;
var_r26 = mgDefault;
mgPicObj->work[0] = var_r26;
temp_r31->unk_44 = var_r26;
temp_r31->unk_46 = var_r26;
for (var_r28 = 0; var_r28 < 5;) {
if (var_r26 >= 13) {
var_r26 = 0;
}
temp_r29 = HuWinCreate(36.0f, 237.0f + cursorYOfsTbl[var_r28], 0x128, 0x44, 0x4E20);
temp_r31->unk_2E[var_r28] = temp_r29;
temp_r31->unk_38[var_r28] = var_r28;
HuWinBGTPLvlSet(temp_r29, 0.0f);
HuWinMesSpeedSet(temp_r29, 0);
temp_r22 = mgNameTbl[var_r26];
HuWinAttrSet(temp_r29, 0x100);
HuWinMesSizeCancelCRSet(1);
HuWinMesMaxSizeGet(1, sp8, temp_r22);
HuWinCenterPosSet(temp_r29, (296.0f - sp8[0]) / -2.0f, (68.0f - sp8[1]) / -2.0f);
HuWinMesSet(temp_r29, temp_r22);
var_r28++;
var_r26++;
}
object->work[3] = 1;
object->func = UpdateMGSelect;
}
static void UpdateMGPic(omObjData *object)
{
mgPic *temp_r30 = (mgPic *)object->data;
s16 temp_r29;
if (object->work[1] != object->work[0]) {
temp_r29 = temp_r30->unk_40;
HuSprAttrSet(temp_r29, object->work[1], 4);
HuSprAttrReset(temp_r29, object->work[0], 4);
object->work[1] = object->work[0];
}
}
static void CreateMGPic(omObjData *object)
{
mgPic *temp_r28;
AnimData *temp_r3_2;
s16 temp_r3;
s32 var_r30;
s32 index;
s16 index2;
s16 group;
omSetStatBit(object, OM_STAT_MODEL_PAUSED);
object->data = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(mgPic), MEMORY_DEFAULT_NUM);
temp_r28 = object->data;
index2 = 0;
temp_r3 = HuSprGrpCreate(14);
temp_r28->unk_40 = temp_r3;
HuSprGrpPosSet(temp_r3, 444.0f, 228.0f);
for (var_r30 = 0; var_r30 < 13; var_r30++) {
temp_r3_2 = HuSprAnimRead(HuDataReadNum(mgPicTbl[var_r30], MEMORY_DEFAULT_NUM));
temp_r28->unk_00[var_r30] = temp_r3_2;
group = HuSprCreate(temp_r3_2, 0x2710, 0);
HuSprGrpMemberSet(temp_r3, var_r30, group);
HuSprScaleSet(temp_r3, var_r30, 0.6f, 0.6f);
HuSprAttrSet(temp_r3, var_r30, 4);
}
index2 = var_r30;
temp_r3_2 = HuSprAnimRead(HuDataReadNum(0x22, MEMORY_DEFAULT_NUM));
temp_r28->unk_00[index2] = temp_r3_2;
group = HuSprCreate(temp_r3_2, 0x7540, 0);
HuSprGrpMemberSet(temp_r3, index2, group);
HuSprTPLvlSet(temp_r3, index2, 0.7f);
index2++;
object->work[1] = object->work[0];
HuSprAttrReset(temp_r3, object->work[1], 4);
object->func = UpdateMGPic;
}
static void UpdateMGInterface(omObjData *object) { void *sp8 = object->data; }
static void CreateMGInterface(omObjData *object)
{
mgInterface *unkStruct;
s16 index;
s16 group;
s16 index2;
AnimData *temp_r3_2;
float sp8[2];
omSetStatBit(object, OM_STAT_MODEL_PAUSED);
object->data = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(mgInterface), MEMORY_DEFAULT_NUM);
unkStruct = object->data;
index2 = 0;
group = HuSprGrpCreate(1);
unkStruct->group = group;
HuSprGrpPosSet(group, 288.0f, 64.0f);
temp_r3_2 = HuSprAnimRead(HuDataReadNum(0x24, MEMORY_DEFAULT_NUM));
unkStruct->unk_00[index2] = temp_r3_2;
index = HuSprCreate(temp_r3_2, 0x2710, 0);
HuSprGrpMemberSet(group, 0, index);
index2++;
group = HuSprGrpCreate(1);
unkStruct->group2 = group;
HuSprGrpPosSet(group, 444.0f, 384.0f);
temp_r3_2 = HuSprAnimRead(HuDataReadNum(0x23, MEMORY_DEFAULT_NUM));
unkStruct->unk_00[index2] = temp_r3_2;
index = HuSprCreate(temp_r3_2, 0x271A, 0);
HuSprGrpMemberSet(group, 0, index);
index2++;
HuWinMesMaxSizeGet(1, sp8, &startText);
index = HuWinCreate(340.0f, 362.0f, sp8[0], sp8[1], 0);
unkStruct->unk_2C = index;
HuWinMesColSet(index, 0);
HuWinBGTPLvlSet(index, 0.0f);
HuWinMesSpeedSet(index, 0);
HuWinMesSet(index, MAKE_MESSID_PTR(startText));
object->func = UpdateMGInterface;
}

View file

@ -5,7 +5,7 @@ static void InitBoard(void) {
BoardCommonInit(BoardCreate, BoardDestroy);
}
int _prolog(void) {
s32 _prolog(void) {
const VoidFunc* ctors = _ctors;
while (*ctors != 0) {
(**ctors)();

View file

@ -13,6 +13,8 @@
#include "game/thpmain.h"
#include "game/msm.h"
#include "math.h"
#include "ext_math.h"
#include "rel_sqrt_consts.h"
#include "data_num/title.h"
@ -375,15 +377,15 @@ void fn_1_1178(void)
y = lbl_1_bss_3C[i].y;
z = lbl_1_bss_3C[i].z;
pos.x = (((sin((M_PI*y)/180.0)*cos((M_PI*x)/180.0))*lbl_1_bss_1C[i])+lbl_1_bss_24[i].x);
pos.y = (-sin((M_PI*x)/180.0)*lbl_1_bss_1C[i])+lbl_1_bss_24[i].y;
pos.z = ((cos((M_PI*y)/180.0)*cos((M_PI*x)/180.0))*lbl_1_bss_1C[i])+lbl_1_bss_24[i].z;
pos.x = (((sind(y)*cosd(x))*lbl_1_bss_1C[i])+lbl_1_bss_24[i].x);
pos.y = (-sind(x)*lbl_1_bss_1C[i])+lbl_1_bss_24[i].y;
pos.z = ((cosd(y)*cosd(x))*lbl_1_bss_1C[i])+lbl_1_bss_24[i].z;
target.x = lbl_1_bss_24[i].x;
target.y = lbl_1_bss_24[i].y;
target.z = lbl_1_bss_24[i].z;
up.x = sin((M_PI*y)/180.0)*sin((M_PI*x)/180.0);
up.y = cos((M_PI*x)/180.0);
up.z = cos((M_PI*y)/180.0)*sin((M_PI*x)/180.0);
up.x = sind(y)*sind(x);
up.y = cosd(x);
up.z = cosd(y)*sind(x);
Hu3DCameraPosSet(lbl_1_data_58[i], pos.x, pos.y, pos.z, up.x, up.y, up.z, target.x, target.y, target.z);
}
}
@ -408,27 +410,27 @@ void fn_1_152C(void) {
if (lbl_1_bss_1C[0] < 100.0f) {
lbl_1_bss_1C[0] = 100.0f;
}
pos.x = lbl_1_bss_24[0].x + (lbl_1_bss_1C[0] * (sin((M_PI * lbl_1_bss_3C[0].y) / 180.0) * cos((M_PI * lbl_1_bss_3C[0].x) / 180.0)));
pos.y = (lbl_1_bss_24[0].y + (lbl_1_bss_1C[0] * -sin((M_PI * lbl_1_bss_3C[0].x) / 180.0)));
pos.z = (lbl_1_bss_24[0].z + (lbl_1_bss_1C[0] * (cos((M_PI * lbl_1_bss_3C[0].y) / 180.0) * cos((M_PI * lbl_1_bss_3C[0].x) / 180.0))));
pos.x = lbl_1_bss_24[0].x + (lbl_1_bss_1C[0] * (sind(lbl_1_bss_3C[0].y) * cosd(lbl_1_bss_3C[0].x)));
pos.y = (lbl_1_bss_24[0].y + (lbl_1_bss_1C[0] * -sind(lbl_1_bss_3C[0].x)));
pos.z = (lbl_1_bss_24[0].z + (lbl_1_bss_1C[0] * (cosd(lbl_1_bss_3C[0].y) * cosd(lbl_1_bss_3C[0].x))));
offset.x = lbl_1_bss_24[0].x - pos.x;
offset.y = lbl_1_bss_24[0].y - pos.y;
offset.z = lbl_1_bss_24[0].z - pos.z;
dir.x = (sin((M_PI * lbl_1_bss_3C[0].y) / 180.0) * sin((M_PI * lbl_1_bss_3C[0].x) / 180.0));
dir.y = cos((M_PI * lbl_1_bss_3C[0].x) / 180.0);
dir.z = (cos((M_PI * lbl_1_bss_3C[0].y) / 180.0) * sin((M_PI * lbl_1_bss_3C[0].x) / 180.0));
dir.x = (sind(lbl_1_bss_3C[0].y) * sind(lbl_1_bss_3C[0].x));
dir.y = cosd(lbl_1_bss_3C[0].x);
dir.z = (cosd(lbl_1_bss_3C[0].y) * sind(lbl_1_bss_3C[0].x));
z_rot = lbl_1_bss_3C[0].z;
y_offset.x = dir.x * (offset.x * offset.x + (1.0f - offset.x * offset.x) * cos((M_PI * z_rot) / 180.0))
+ dir.y * (offset.x * offset.y * (1.0f - cos((M_PI * z_rot) / 180.0)) - offset.z * sin((M_PI * z_rot) / 180.0))
+ dir.z * (offset.x * offset.z * (1.0f - cos((M_PI * z_rot) / 180.0)) + offset.y * sin((M_PI * z_rot) / 180.0));
y_offset.x = dir.x * (offset.x * offset.x + (1.0f - offset.x * offset.x) * cosd(z_rot))
+ dir.y * (offset.x * offset.y * (1.0f - cosd(z_rot)) - offset.z * sind(z_rot))
+ dir.z * (offset.x * offset.z * (1.0f - cosd(z_rot)) + offset.y * sind(z_rot));
y_offset.y = dir.y * (offset.y * offset.y + (1.0f - offset.y * offset.y) * cos((M_PI * z_rot) / 180.0))
+ dir.x * (offset.x * offset.y * (1.0f - cos((M_PI * z_rot) / 180.0)) + offset.z * sin((M_PI * z_rot) / 180.0))
+ dir.z * (offset.y * offset.z * (1.0f - cos((M_PI * z_rot) / 180.0)) - offset.x * sin((M_PI * z_rot) / 180.0));
y_offset.y = dir.y * (offset.y * offset.y + (1.0f - offset.y * offset.y) * cosd(z_rot))
+ dir.x * (offset.x * offset.y * (1.0f - cosd(z_rot)) + offset.z * sind(z_rot))
+ dir.z * (offset.y * offset.z * (1.0f - cosd(z_rot)) - offset.x * sind(z_rot));
y_offset.z = dir.z * (offset.z * offset.z + (1.0f - offset.z * offset.z) * cos((M_PI * z_rot) / 180.0))
+ (dir.x * (offset.x * offset.z * (1.0 - cos((M_PI * z_rot) / 180.0)) - offset.y * sin((M_PI * z_rot) / 180.0))
+ dir.y * (offset.y * offset.z * (1.0 - cos((M_PI * z_rot) / 180.0)) + offset.x * sin((M_PI * z_rot) / 180.0)));
y_offset.z = dir.z * (offset.z * offset.z + (1.0f - offset.z * offset.z) * cosd(z_rot))
+ (dir.x * (offset.x * offset.z * (1.0 - cosd(z_rot)) - offset.y * sind(z_rot))
+ dir.y * (offset.y * offset.z * (1.0 - cosd(z_rot)) + offset.x * sind(z_rot)));
PSVECCrossProduct(&dir, &offset, &offset);
PSVECNormalize(&offset, &offset);
@ -507,7 +509,7 @@ static BOOL TitleProc(void)
}
HuSprAttrReset(titleGroup, 3, HUSPR_ATTR_DISPOFF);
for(i=1; i<=50; i++) {
scale = (cos((i*1.8)*M_PI/180.0)*10.0)+1.0;
scale = (cosd(i*1.8)*10.0)+1.0;
HuSprScaleSet(titleGroup, 3, scale, scale);
HuSprTPLvlSet(titleGroup, 3, i/50.0);
HuPrcVSleep();
@ -525,7 +527,7 @@ static BOOL TitleProc(void)
HuSprAttrSet(titleGroup, 2, HUSPR_ATTR_DISPOFF);
return 1;
}
scale = (sin((i*scale_time)*M_PI/180.0)*0.1)+0.9;
scale = (sind(i*scale_time)*0.1)+0.9;
scale_time += 0.05;
if(scale_time > 5) {
scale_time = 5;
@ -548,4 +550,3 @@ static BOOL TitleProc(void)
return 0;
}
char data_pad[] = "\0\0\0\0\0\0\0";

View file

@ -1,6 +1,6 @@
#include "REL/executor.h"
int _prolog(void) {
s32 _prolog(void) {
const VoidFunc* ctors = _ctors;
while (*ctors != 0) {
(**ctors)();

View file

@ -19,6 +19,7 @@
#include "game/chrman.h"
#include "math.h"
#include "ext_math.h"
#include "rel_sqrt_consts.h"
@ -260,7 +261,7 @@ static void fn_1_994(void)
}
pos_z = -500.0f;
for(i=0; i<=50; i++) {
Hu3DModelPosSet(model, 0.0f, 2500.0*cos(M_PI*(i*1.8f)/180.0)-200.0, pos_z);
Hu3DModelPosSet(model, 0.0f, 2500.0*cosd(i*1.8f)-200.0, pos_z);
Hu3DModelRotSet(model, 0, 0, 45.0f*(1.0f-(i/50.0f)));
pos_z += 50.0/7.0;
Hu3DShadowTPLvlSet(0.5*(i/50.0f));
@ -269,8 +270,8 @@ static void fn_1_994(void)
HuAudFXPlay(1211);
Hu3DModelAttrReset(model, 0x40000002);
for(i=1; i<=20; i++) {
Hu3DModelPosSet(model, 0.0f, (200.0*(sin(M_PI*(i*2.25f)/180.0)*(1.0/sin(M_PI/4))))-200.0, pos_z);
rot_x = (20-i)*cos(M_PI*(i*13.5f)/180.0);
Hu3DModelPosSet(model, 0.0f, (200.0*(sind(i*2.25f)*(1.0/sind(45))))-200.0, pos_z);
rot_x = (20-i)*cosd(i*13.5f);
Hu3DModelRotSet(model, rot_x, 0.0f, 0.0f);
pos_z += 50.0/7.0;
HuPrcVSleep();
@ -546,7 +547,7 @@ static void fn_1_17E4(void)
CharModelMotionSet(char_tbl[j], mot_tbl[j][1]);
}
if(time <= 30) {
Hu3DModelPosSet(player_mdl[j], player_pos[j].x, player_pos[j].y+(300.0*sin(M_PI*(time*9.0f)/180.0)), player_pos[j].z-(time*20));
Hu3DModelPosSet(player_mdl[j], player_pos[j].x, player_pos[j].y+(300.0*sind(time*9.0f)), player_pos[j].z-(time*20));
if(time <= 10) {
tplvl = 1-(0.1*time);
Hu3DModelTPLvlSet(platform_mdl[j], 0.5*tplvl);
@ -624,11 +625,11 @@ static void fn_1_220C(void)
Hu3DMotionTimeSet(model, 40);
HuAudFXPlay(lbl_1_data_10C[lbl_1_bss_12*2]);
for(i=0; i<=20; i++) {
Hu3DModelPosSet(model, -153.0f-(100.0f-(100.0f*(i/20.0f))), (100.0*sin(M_PI*(i*9.0f)/180.0)) + -150.0 + ofs_x, 356.0f);
Hu3DModelPosSet(model, -153.0f-(100.0f-(100.0f*(i/20.0f))), (100.0*sind(i*9.0f)) + -150.0 + ofs_x, 356.0f);
HuPrcVSleep();
}
for(i=0; i<=10; i++) {
Hu3DModelPosSet(model, -153.0f, (15.0*sin(M_PI*(i*18.0f)/180.0)) + -150.f + ofs_x, 356.0f);
Hu3DModelPosSet(model, -153.0f, (15.0*sind(i*18.0f)) + -150.f + ofs_x, 356.0f);
Hu3DModelRotSet(model, 0.0f, 90-((i/10.0f)*70), 0);
HuPrcVSleep();
}
@ -645,7 +646,7 @@ static void fn_1_220C(void)
HuPrcSleep(20);
HuAudFXPlay(lbl_1_data_10C[(lbl_1_bss_12*2)+1]);
for(i=0; i<=30; i++) {
Hu3DModelPosSet(model, (i*5)-153, (50.0*sin(M_PI*(i*9.0f)/180.0)) + -150.0 + ofs_x, (i*20)+356);
Hu3DModelPosSet(model, (i*5)-153, (50.0*sind(i*9.0f)) + -150.0 + ofs_x, (i*20)+356);
HuPrcVSleep();
}
HuPrcEnd();
@ -698,7 +699,7 @@ static void fn_1_2804(void)
}
HuPrcSleep(40);
for(i=0; i<=20; i++) {
pos_x = 500.0*cos(M_PI*(i*4.5f)/180.0)+142.0;
pos_x = 500.0*cosd(i*4.5f)+142.0;
HuWinPosSet(window, pos_x, 320);
HuPrcVSleep();
}
@ -725,7 +726,7 @@ static void fn_1_2804(void)
HuWinMesPalSet(window, 7, 0, 0, 192);
HuWinPosSet(window_other, 142.0f, 320.0f);
for(i=0; i<=10; i++) {
HuWinPosSet(window_other, 30.0*sin(M_PI*(i*9.0f)/180.0)+142.0, 160.0*(1.0-cos(M_PI*(i*9.0f)/180.0))+320.0);
HuWinPosSet(window_other, 30.0*sind(i*9.0f)+142.0, 160.0*(1.0-cosd(i*9.0f))+320.0);
HuPrcVSleep();
}
HuPrcSleep(5);
@ -734,7 +735,7 @@ static void fn_1_2804(void)
HuPrcVSleep();
}
for(i=0; i<=20; i++) {
pos_x = 500.0*(1.0-cos(M_PI*(i*4.5f)/180.0))+142.0;
pos_x = 500.0*(1.0-cosd(i*4.5f))+142.0;
HuWinPosSet(window, pos_x, 320);
HuPrcVSleep();
}
@ -870,9 +871,9 @@ static void fn_1_2FA0(void)
for(temp_r31=0; temp_r31<36; temp_r31++) {
temp_f30 = temp_r31;
if(temp_f30 <= 20.0f) {
temp_f31 = 300.0*cos(M_PI*(4.5f*temp_f30)/180.0)+temp_f29;
temp_f31 = 300.0*cosd(4.5f*temp_f30)+temp_f29;
HuSprGrpPosSet(temp_r25, temp_f31, temp_f28);
temp_f31 = 300.0*cos(M_PI*(4.5f*temp_f30)/180.0)+(576.0f-(temp_r22/2)-24.0f);
temp_f31 = 300.0*cosd(4.5f*temp_f30)+(576.0f-(temp_r22/2)-24.0f);
for(temp_r30=0; temp_r30<temp_r26; temp_r30++) {
HuSprGrpPosSet(work.spr_grp[temp_r30], temp_f31, (temp_r30*28)+70);
}
@ -880,25 +881,25 @@ static void fn_1_2FA0(void)
temp_f30 = temp_r31-3;
if(temp_f30 > 0.0f) {
if(temp_f30 <= 20.0f) {
temp_f31 = 300.0*cos(M_PI*(4.5f*temp_f30)/180.0)+lbl_1_data_124[2];
temp_f31 = 300.0*cosd(4.5f*temp_f30)+lbl_1_data_124[2];
HuSprGrpPosSet(temp_r24, temp_f31, 186.0f);
temp_f31 = 300.0*cos(M_PI*(4.5f*temp_f30)/180.0)+(lbl_1_data_124[2]-88.0f);
temp_f31 = 300.0*cosd(4.5f*temp_f30)+(lbl_1_data_124[2]-88.0f);
HuWinPosSet(sp10[0], 16.0f+temp_f31, 168.0f);
}
}
temp_f30 = temp_r31-6;
if(temp_f30 > 0.0f) {
if(temp_f30 <= 20.0f) {
temp_f31 = 300.0*cos(M_PI*(4.5f*temp_f30)/180.0)+lbl_1_data_124[4];
temp_f31 = 300.0*cosd(4.5f*temp_f30)+lbl_1_data_124[4];
HuSprGrpPosSet(temp_r23, temp_f31, 242.0f);
temp_f31 = 300.0*cos(M_PI*(4.5f*temp_f30)/180.0)+(lbl_1_data_124[4]-100.0f);
temp_f31 = 300.0*cosd(4.5f*temp_f30)+(lbl_1_data_124[4]-100.0f);
HuWinPosSet(sp10[1], 16.0f+temp_f31, 224.0f);
}
}
temp_f30 = temp_r31-9;
if(temp_f30 > 0.0f) {
if(temp_f30 <= 20.0f) {
temp_f31 = 300.0*cos(M_PI*(4.5f*temp_f30)/180.0)+(lbl_1_data_124[6]-217.0f);
temp_f31 = 300.0*cosd(4.5f*temp_f30)+(lbl_1_data_124[6]-217.0f);
HuWinPosSet(sp10[2], 16.0f+temp_f31, 274.0f);
}
}
@ -919,14 +920,14 @@ static void fn_1_2FA0(void)
HuWinMesSet(sp10[2], 0x240002+lbl_1_bss_10+lbl_1_bss_6);
}
for(temp_r31=0; temp_r31<=10; temp_r31++) {
HuWinPosSet(temp_r27, 30.0*sin(M_PI*(temp_r31*9.0f)/180.0)+temp_f31, 200.0*(1.0-cos(M_PI*(temp_r31*9.0f)/180.0))+274.0);
HuWinPosSet(temp_r27, 30.0*sind(temp_r31*9.0f)+temp_f31, 200.0*(1.0-cosd(temp_r31*9.0f))+274.0);
HuPrcVSleep();
}
}
HuPrcVSleep();
}
for(temp_r31=0; temp_r31<20; temp_r31++) {
temp_f30 = 1.0-cos(M_PI*(temp_r31*4.5f)/180.0);
temp_f30 = 1.0-cosd(temp_r31*4.5f);
temp_f31 = temp_f29+(500.0f*temp_f30);
HuSprGrpPosSet(temp_r25, temp_f31, temp_f28);
temp_f31 = ((576.0f-(work.alt_word_len/2))-24.0f)+(500.0f*temp_f30);
@ -968,15 +969,15 @@ static void fn_1_4174(omObjData *object)
y = lbl_1_bss_40[i].y;
z = lbl_1_bss_40[i].z;
pos.x = (((sin((M_PI*y)/180.0)*cos((M_PI*x)/180.0))*lbl_1_bss_20[i])+lbl_1_bss_28[i].x);
pos.y = (-sin((M_PI*x)/180.0)*lbl_1_bss_20[i])+lbl_1_bss_28[i].y;
pos.z = ((cos((M_PI*y)/180.0)*cos((M_PI*x)/180.0))*lbl_1_bss_20[i])+lbl_1_bss_28[i].z;
pos.x = (((sind(y)*cosd(x))*lbl_1_bss_20[i])+lbl_1_bss_28[i].x);
pos.y = (-sind(x)*lbl_1_bss_20[i])+lbl_1_bss_28[i].y;
pos.z = ((cosd(y)*cosd(x))*lbl_1_bss_20[i])+lbl_1_bss_28[i].z;
target.x = lbl_1_bss_28[i].x;
target.y = lbl_1_bss_28[i].y;
target.z = lbl_1_bss_28[i].z;
up.x = sin((M_PI*y)/180.0)*sin((M_PI*x)/180.0);
up.y = cos((M_PI*x)/180.0);
up.z = cos((M_PI*y)/180.0)*sin((M_PI*x)/180.0);
up.x = sind(y)*sind(x);
up.y = cosd(x);
up.z = cosd(y)*sind(x);
Hu3DCameraPosSet(lbl_1_data_144[i], pos.x, pos.y, pos.z, up.x, up.y, up.z, target.x, target.y, target.z);
}
}
@ -1000,27 +1001,27 @@ static void fn_1_4528(omObjData *object)
if (lbl_1_bss_20[0] < 100.0f) {
lbl_1_bss_20[0] = 100.0f;
}
pos.x = lbl_1_bss_28[0].x + (lbl_1_bss_20[0] * (sin((M_PI * lbl_1_bss_40[0].y) / 180.0) * cos((M_PI * lbl_1_bss_40[0].x) / 180.0)));
pos.y = (lbl_1_bss_28[0].y + (lbl_1_bss_20[0] * -sin((M_PI * lbl_1_bss_40[0].x) / 180.0)));
pos.z = (lbl_1_bss_28[0].z + (lbl_1_bss_20[0] * (cos((M_PI * lbl_1_bss_40[0].y) / 180.0) * cos((M_PI * lbl_1_bss_40[0].x) / 180.0))));
pos.x = lbl_1_bss_28[0].x + (lbl_1_bss_20[0] * (sind(lbl_1_bss_40[0].y) * cosd(lbl_1_bss_40[0].x)));
pos.y = (lbl_1_bss_28[0].y + (lbl_1_bss_20[0] * -sind(lbl_1_bss_40[0].x)));
pos.z = (lbl_1_bss_28[0].z + (lbl_1_bss_20[0] * (cosd(lbl_1_bss_40[0].y) * cosd(lbl_1_bss_40[0].x))));
offset.x = lbl_1_bss_28[0].x - pos.x;
offset.y = lbl_1_bss_28[0].y - pos.y;
offset.z = lbl_1_bss_28[0].z - pos.z;
dir.x = (sin((M_PI * lbl_1_bss_40[0].y) / 180.0) * sin((M_PI * lbl_1_bss_40[0].x) / 180.0));
dir.y = cos((M_PI * lbl_1_bss_40[0].x) / 180.0);
dir.z = (cos((M_PI * lbl_1_bss_40[0].y) / 180.0) * sin((M_PI * lbl_1_bss_40[0].x) / 180.0));
dir.x = (sind(lbl_1_bss_40[0].y) * sind(lbl_1_bss_40[0].x));
dir.y = cosd(lbl_1_bss_40[0].x);
dir.z = (cosd(lbl_1_bss_40[0].y) * sind(lbl_1_bss_40[0].x));
z_rot = lbl_1_bss_40[0].z;
y_offset.x = dir.x * (offset.x * offset.x + (1.0f - offset.x * offset.x) * cos((M_PI * z_rot) / 180.0))
+ dir.y * (offset.x * offset.y * (1.0f - cos((M_PI * z_rot) / 180.0)) - offset.z * sin((M_PI * z_rot) / 180.0))
+ dir.z * (offset.x * offset.z * (1.0f - cos((M_PI * z_rot) / 180.0)) + offset.y * sin((M_PI * z_rot) / 180.0));
y_offset.x = dir.x * (offset.x * offset.x + (1.0f - offset.x * offset.x) * cosd(z_rot))
+ dir.y * (offset.x * offset.y * (1.0f - cosd(z_rot)) - offset.z * sind(z_rot))
+ dir.z * (offset.x * offset.z * (1.0f - cosd(z_rot)) + offset.y * sind(z_rot));
y_offset.y = dir.y * (offset.y * offset.y + (1.0f - offset.y * offset.y) * cos((M_PI * z_rot) / 180.0))
+ dir.x * (offset.x * offset.y * (1.0f - cos((M_PI * z_rot) / 180.0)) + offset.z * sin((M_PI * z_rot) / 180.0))
+ dir.z * (offset.y * offset.z * (1.0f - cos((M_PI * z_rot) / 180.0)) - offset.x * sin((M_PI * z_rot) / 180.0));
y_offset.y = dir.y * (offset.y * offset.y + (1.0f - offset.y * offset.y) * cosd(z_rot))
+ dir.x * (offset.x * offset.y * (1.0f - cosd(z_rot)) + offset.z * sind(z_rot))
+ dir.z * (offset.y * offset.z * (1.0f - cosd(z_rot)) - offset.x * sind(z_rot));
y_offset.z = dir.z * (offset.z * offset.z + (1.0f - offset.z * offset.z) * cos((M_PI * z_rot) / 180.0))
+ (dir.x * (offset.x * offset.z * (1.0 - cos((M_PI * z_rot) / 180.0)) - offset.y * sin((M_PI * z_rot) / 180.0))
+ dir.y * (offset.y * offset.z * (1.0 - cos((M_PI * z_rot) / 180.0)) + offset.x * sin((M_PI * z_rot) / 180.0)));
y_offset.z = dir.z * (offset.z * offset.z + (1.0f - offset.z * offset.z) * cosd(z_rot))
+ (dir.x * (offset.x * offset.z * (1.0 - cosd(z_rot)) - offset.y * sind(z_rot))
+ dir.y * (offset.y * offset.z * (1.0 - cosd(z_rot)) + offset.x * sind(z_rot)));
PSVECCrossProduct(&dir, &offset, &offset);
PSVECNormalize(&offset, &offset);
@ -1070,14 +1071,14 @@ static void fn_1_50B0(ModelData *model, Mtx mtx)
GXSetVtxDesc(GX_VA_NRM, GX_DIRECT);
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_NRM, GX_NRM_XYZ, GX_F32, 0);
target.x = target.z = 0.0f;
target.x = lbl_1_data_14C*sin(M_PI*lbl_1_bss_40[0].y/180.0);
target.z = lbl_1_data_14C*cos(M_PI*lbl_1_bss_40[0].y/180.0);
target.x = lbl_1_data_14C*sind(lbl_1_bss_40[0].y);
target.z = lbl_1_data_14C*cosd(lbl_1_bss_40[0].y);
target.y = 415.0f;
pos.x = (sin(M_PI*lbl_1_bss_40[0].y/180.0)*cos(M_PI*lbl_1_bss_40[0].x/180.0)*lbl_1_bss_20[0])+lbl_1_bss_28[0].x;
pos.y = (-sin(M_PI*lbl_1_bss_40[0].x/180.0)*lbl_1_bss_20[0])+lbl_1_bss_28[0].y;
pos.z = (cos(M_PI*lbl_1_bss_40[0].y/180.0)*cos(M_PI*lbl_1_bss_40[0].x/180.0)*lbl_1_bss_20[0])+lbl_1_bss_28[0].z;
up.x = -sin(M_PI*lbl_1_bss_40[0].y/180.0);
up.z = -cos(M_PI*lbl_1_bss_40[0].y/180.0);
pos.x = (sind(lbl_1_bss_40[0].y)*cosd(lbl_1_bss_40[0].x)*lbl_1_bss_20[0])+lbl_1_bss_28[0].x;
pos.y = (-sind(lbl_1_bss_40[0].x)*lbl_1_bss_20[0])+lbl_1_bss_28[0].y;
pos.z = (cos(M_PI*lbl_1_bss_40[0].y/180.0)*cosd(lbl_1_bss_40[0].x)*lbl_1_bss_20[0])+lbl_1_bss_28[0].z;
up.x = -sind(lbl_1_bss_40[0].y);
up.z = -cosd(lbl_1_bss_40[0].y);
up.y = 0;
MTXLookAt(lookat, &pos, &up, &target);
MTXLightPerspective(light, lbl_1_bss_C, 1.2f, 0.5f, -0.5f, 0.5f, 0.5f);

File diff suppressed because it is too large Load diff

1949
src/REL/m402Dll/main.c Executable file

File diff suppressed because it is too large Load diff

1592
src/REL/m403Dll/main.c Executable file

File diff suppressed because it is too large Load diff

1024
src/REL/m403Dll/scene.c Executable file

File diff suppressed because it is too large Load diff

1446
src/REL/m404Dll/main.c Normal file

File diff suppressed because it is too large Load diff

View file

@ -8,7 +8,7 @@
#include "game/wipe.h"
#include "dolphin.h"
#include "math.h"
#include "ext_math.h"
#include "rel_sqrt_consts.h"
extern s32 sprintf(char*, const char*, s32);
@ -68,25 +68,25 @@ static void fn_1_300(omObjData *arg0) {
CRot.y += HuPadSubStkX[0] / 20;
CZoom += HuPadTrigL[0] / 2;
CZoom -= HuPadTrigR[0] / 2;
sp2C.x = Center.x + CZoom * (sin(CRot.y * M_PI / 180.0) * cos(CRot.x * M_PI / 180.0));
sp2C.y = Center.y + CZoom * -sin(CRot.x * M_PI / 180.0);
sp2C.z = Center.z + CZoom * (cos(CRot.y * M_PI / 180.0) * cos(CRot.x * M_PI / 180.0));
sp2C.x = Center.x + CZoom * (sind(CRot.y) * cosd(CRot.x));
sp2C.y = Center.y + CZoom * -sind(CRot.x);
sp2C.z = Center.z + CZoom * (cosd(CRot.y) * cosd(CRot.x));
sp20.x = Center.x - sp2C.x;
sp20.y = Center.y - sp2C.y;
sp20.z = Center.z - sp2C.z;
sp14.x = sin(CRot.y * M_PI / 180.0) * sin(CRot.x * M_PI / 180.0);
sp14.y = cos(CRot.x * M_PI / 180.0);
sp14.z = cos(CRot.y * M_PI / 180.0) * sin(CRot.x * M_PI / 180.0);
sp14.x = sind(CRot.y) * sind(CRot.x);
sp14.y = cosd(CRot.x);
sp14.z = cosd(CRot.y) * sind(CRot.x);
temp_f31 = CRot.z;
sp8.x = sp14.x * (sp20.x * sp20.x + (1.0f - sp20.x * sp20.x) * cos(temp_f31 * M_PI / 180.0))
+ sp14.y * (sp20.x * sp20.y * (1.0 - cos(temp_f31 * M_PI / 180.0)) - sp20.z * sin(temp_f31 * M_PI / 180.0))
+ sp14.z * (sp20.x * sp20.z * (1.0 - cos(temp_f31 * M_PI / 180.0)) + sp20.y * sin(temp_f31 * M_PI / 180.0));
sp8.y = sp14.x * (sp20.x * sp20.y * (1.0 - cos(temp_f31 * M_PI / 180.0)) + sp20.z * sin(temp_f31 * M_PI / 180.0))
+ sp14.y * (sp20.y * sp20.y + (1.0f - sp20.y * sp20.y) * cos(temp_f31 * M_PI / 180.0))
+ sp14.z * (sp20.y * sp20.z * (1.0 - cos(temp_f31 * M_PI / 180.0)) - sp20.x * sin(temp_f31 * M_PI / 180.0));
sp8.z = sp14.x * (sp20.x * sp20.z * (1.0 - cos(temp_f31 * M_PI / 180.0)) - sp20.y * sin(temp_f31 * M_PI / 180.0))
+ sp14.y * (sp20.y * sp20.z * (1.0 - cos(temp_f31 * M_PI / 180.0)) + sp20.x * sin(temp_f31 * M_PI / 180.0))
+ sp14.z * (sp20.z * sp20.z + (1.0f - sp20.z * sp20.z) * cos(temp_f31 * M_PI / 180.0));
sp8.x = sp14.x * (sp20.x * sp20.x + (1.0f - sp20.x * sp20.x) * cosd(temp_f31))
+ sp14.y * (sp20.x * sp20.y * (1.0 - cosd(temp_f31)) - sp20.z * sind(temp_f31))
+ sp14.z * (sp20.x * sp20.z * (1.0 - cosd(temp_f31)) + sp20.y * sind(temp_f31));
sp8.y = sp14.x * (sp20.x * sp20.y * (1.0 - cosd(temp_f31)) + sp20.z * sind(temp_f31))
+ sp14.y * (sp20.y * sp20.y + (1.0f - sp20.y * sp20.y) * cosd(temp_f31))
+ sp14.z * (sp20.y * sp20.z * (1.0 - cosd(temp_f31)) - sp20.x * sind(temp_f31));
sp8.z = sp14.x * (sp20.x * sp20.z * (1.0 - cosd(temp_f31)) - sp20.y * sind(temp_f31))
+ sp14.y * (sp20.y * sp20.z * (1.0 - cosd(temp_f31)) + sp20.x * sind(temp_f31))
+ sp14.z * (sp20.z * sp20.z + (1.0f - sp20.z * sp20.z) * cosd(temp_f31));
PSVECCrossProduct(&sp14, &sp20, &sp20);
PSVECNormalize(&sp20, &sp20);
temp_r31 = HuPadSubStkX[0] & 0xF8;

View file

@ -0,0 +1,261 @@
#define HUWIN_USE_OLD_DEFS
#include "game/object.h"
#include "game/gamework_data.h"
#include "game/audio.h"
#include "game/wipe.h"
#include "game/window.h"
#include "game/object.h"
#include "game/process.h"
#include "game/hsfman.h"
#include "game/pad.h"
#include "game/hsfanim.h"
#include "ext_math.h"
#include "REL/modeseldll.h"
s16 lbl_1_data_80[] = {
16, 17, 18,
19, 20, 21
};
s32 lbl_1_data_8C[] = {
0x630030,
0x630032,
0x630034,
0x630036,
0x630038,
0x63003A
};
s32 lbl_1_data_A4[] = {
0x630031,
0x630033,
0x630035,
0x630037,
0x630039,
0x63003B
};
u32 lbl_1_data_BC[] = {
0x110001,
0x110002,
0x110003,
0x110004,
0x110005,
0x110006
};
s16 lbl_1_bss_82;
s16 lbl_1_bss_80;
void fn_1_3668(void);
//Scratch is at https://decomp.me/scratch/iirXp
//Register allocation issues at line 180 with load of 1.0 double constant
s32 fn_1_2490(void)
{
float sp10[2];
float sp8[2];
float temp_f31;
float temp_f30;
s16 temp_r31;
s16 temp_r30;
s16 temp_r29;
s16 temp_r28;
s16 temp_r27;
s16 temp_r26;
s32 temp_r25;
WindowData *temp_r24;
AnimData *temp_r23;
AnimData *temp_r22;
s16 temp_r21;
fn_1_3668();
fn_1_1EC0(1);
temp_r25 = HuAudFXPlay(2094);
if(omovlevtno) {
WipeCreate(WIPE_MODE_IN, WIPE_TYPE_NORMAL, 30);
}
for(temp_r31=0; temp_r31<=20; temp_r31++) {
temp_f31 = 1.0-sind(90.0*(temp_r31/20.0));
Hu3DModelPosSet(lbl_1_bss_19A[14], 0, -50.0f+(200.0f*temp_f31), 0);
Hu3DModelPosSet(lbl_1_bss_19A[15], 0, -50.0f+(200.0f*temp_f31), 0);
HuPrcVSleep();
}
HuPrcSleep(20);
Hu3DModelAttrReset(lbl_1_bss_19A[14], 0x40000002);
Hu3DModelAttrReset(lbl_1_bss_19A[15], 0x40000002);
HuAudFXPlay(2093);
HuPrcSleep(120);
HuAudFXPlay(2095);
for(temp_r31=0; temp_r31<=30; temp_r31++) {
temp_f31 = temp_r31/30.0;
Hu3DModelPosSet(lbl_1_bss_19A[14], 0, -50.0f-(20.0f*temp_f31), 0);
HuPrcVSleep();
}
HuWinMesMaxSizeBetGet(sp10, 0x110000, 0x110006);
lbl_1_bss_82 = HuWinExCreateStyled(-10000, 432-sp10[1], sp10[0], sp10[1], -1, 0);
HuWinMesSpeedSet(lbl_1_bss_82, 0);
temp_r24 = &winData[lbl_1_bss_82];
temp_r24->active_pad = 1;
HuWinExAnimIn(lbl_1_bss_82);
HuWinMesSet(lbl_1_bss_82, 0x110000);
HuWinMesMaxSizeGet(1, sp8, 0x1A0020);
temp_r29 = HuWinCreate(-10000, 8+(432-sp10[1]-sp8[1]), sp8[0], sp8[1], 0);
HuWinMesSpeedSet(temp_r29, 0);
HuWinBGTPLvlSet(temp_r29, 0);
HuWinMesSet(temp_r29, 0x1A0020);
HuWinDispOff(temp_r29);
while(!Hu3DMotionEndCheck(lbl_1_bss_19A[15])) {
HuPrcVSleep();
}
Hu3DModelAttrSet(lbl_1_bss_19A[15], 1);
for(temp_r31=0; temp_r31<6; temp_r31++) {
Hu3DModelAttrReset(lbl_1_bss_19A[lbl_1_data_80[temp_r31]], 1);
Hu3DModelAttrSet(lbl_1_bss_19A[lbl_1_data_80[temp_r31]], 0x40000002);
Hu3DMotionTimeSet(lbl_1_bss_19A[lbl_1_data_80[temp_r31]], 0);
Hu3DModelPosSet(lbl_1_bss_19A[lbl_1_data_80[temp_r31]], 0, -50, 0);
}
HuWinMesWait(lbl_1_bss_82);
temp_r26 = 0;
lbl_1_bss_80 = temp_r26;
espAttrReset(lbl_1_bss_152[10], HUSPR_ATTR_DISPOFF);
espBankSet(lbl_1_bss_152[10], 0);
for(temp_r31=0; temp_r31<=10; temp_r31++) {
temp_f31 = temp_r31/10.0f;
Hu3DModelPosSet(lbl_1_bss_19A[lbl_1_data_80[lbl_1_bss_80]], 0, -50, 50.0*sind(90.0f*temp_f31));
espPosSet(lbl_1_bss_152[10], 288.0, -50.0+(106.0*sind(90.0f*temp_f31)));
HuPrcVSleep();
}
HuWinMesSet(lbl_1_bss_82, lbl_1_data_BC[lbl_1_bss_80]);
HuWinDispOn(temp_r29);
while(1) {
temp_r30 = 0;
if(HuPadDStkRep[0] & PAD_BUTTON_LEFT) {
temp_r30 = -1;
} else if(HuPadDStkRep[0] & PAD_BUTTON_RIGHT) {
temp_r30 = 1;
}
if(temp_r30) {
if(lbl_1_bss_80+temp_r30 < 0) {
lbl_1_bss_80 = 0;
} else if(lbl_1_bss_80+temp_r30 >= 6) {
lbl_1_bss_80 = 5;
} else {
lbl_1_bss_80 += temp_r30;
}
if(temp_r26 != lbl_1_bss_80) {
HuAudFXPlay(0);
for(temp_r31=0; temp_r31<=10; temp_r31++) {
temp_f31 = temp_r31/10.0f;
Hu3DModelPosSet(lbl_1_bss_19A[lbl_1_data_80[temp_r26]], 0, -50, 50.0*cosd(90.0f*temp_f31));
Hu3DModelPosSet(lbl_1_bss_19A[lbl_1_data_80[lbl_1_bss_80]], 0, -50, 50.0*sind(90.0f*temp_f31));
espPosSet(lbl_1_bss_152[10], 288.0, -50.0+(106.0*(1.0-sind(180.0f*temp_f31))));
if(temp_r31 == 5) {
espBankSet(lbl_1_bss_152[10], lbl_1_bss_80);
}
HuPrcVSleep();
}
temp_r26 = lbl_1_bss_80;
HuWinMesSet(lbl_1_bss_82, lbl_1_data_BC[lbl_1_bss_80]);
}
}
if(HuPadBtnDown[0] & PAD_BUTTON_A) {
HuAudFXPlay(2);
break;
} else if(HuPadBtnDown[0] & PAD_BUTTON_B) {
HuAudFXPlay(3);
HuAudFXStop(temp_r25);
return -1;
} else {
HuPrcVSleep();
continue;
}
}
Hu3DModelAttrReset(lbl_1_bss_19A[lbl_1_data_80[lbl_1_bss_80]], 0x40000002);
HuAudSeqAllFadeOut(1000);
for(temp_r31=0; temp_r31<=20; temp_r31++) {
temp_f31 = temp_r31/20.0f;
for(temp_r28=0; temp_r28<6; temp_r28++) {
if(temp_r28 != lbl_1_bss_80) {
Hu3DModelPosSet(lbl_1_bss_19A[lbl_1_data_80[temp_r28]], 0, -50-(300.0*(1.0-cosd(90.0f*temp_f31))), 0);
espPosSet(lbl_1_bss_152[10], 288.0, -50.0+(106.0*(cosd(90.0f*temp_f31))));
}
}
HuPrcVSleep();
}
HuWinKill(temp_r29);
HuWinExAnimOut(lbl_1_bss_82);
HuAudFXStop(temp_r25);
temp_r27 = HuSprGrpCreate(1);
temp_r21 = HuTHPSprCreateVol("movie/opmov_c00.thp", 0, 3000, 90.0);
HuSprGrpMemberSet(temp_r27, 0, temp_r21);
HuSprPosSet(temp_r27, 0, 288.0f, 240.0f);
HuSprDrawNoSet(temp_r27, 0, 127);
HuPrcSleep(2);
espAttrSet(lbl_1_bss_152[9], HUSPR_ATTR_DISPOFF);
for(temp_r31=0; temp_r31<=10; temp_r31++) {
temp_f31 = temp_r31/10.0;
Hu3DModelPosSet(lbl_1_bss_19A[14], 0, -70.0f-(100.0f*temp_f31), 0);
HuPrcVSleep();
}
temp_r23 = HuSprAnimRead(HuDataReadNum(lbl_1_data_8C[lbl_1_bss_80], MEMORY_DEFAULT_NUM));
temp_r22 = HuSprAnimRead(HuDataReadNum(lbl_1_data_A4[lbl_1_bss_80], MEMORY_DEFAULT_NUM));
Hu3DAnimCreate(temp_r23, lbl_1_bss_19A[22], "ys002_a1");
Hu3DAnimCreate(temp_r22, lbl_1_bss_19A[22], "ys002_a2");
Hu3DModelAttrSet(lbl_1_bss_19A[lbl_1_data_80[lbl_1_bss_80]], 1);
Hu3DMotionTimeSet(lbl_1_bss_19A[22], 0);
Hu3DModelAttrReset(lbl_1_bss_19A[22], 1);
Hu3DModelAttrSet(lbl_1_bss_19A[22], 0x40000002);
Hu3DModelPosSet(lbl_1_bss_19A[22], 0, 27, 50);
Hu3DModelScaleSet(lbl_1_bss_19A[22], 1.0f, 1.063f, 1.0f);
for(temp_r31=1; temp_r31<=20; temp_r31++) {
temp_f31 = temp_r31/20.0;
Hu3DModelPosSet(lbl_1_bss_19A[22], 0, 27.0-(60.0*sind(90.0f*temp_f31)), 50);
HuPrcVSleep();
}
HuPrcSleep(90);
Hu3DFogSet(3000, 8000, 255, 255, 255);
Hu3DModelAttrReset(lbl_1_bss_19A[22], 0x40000002);
HuPrcSleep(60);
temp_f31 =0;
temp_f30 = 5;
while(!HuTHPEndCheck()) {
Hu3DModelPosSet(lbl_1_bss_19A[22], 0, -33.0f+(temp_f31/30.0f), 50.0f-temp_f31);
temp_f31 += temp_f30;
temp_f30 += 5.0f;
HuPrcVSleep();
}
_ClearFlag(0x1000B);
WipeColorSet(255, 255, 255);
WipeCreate(WIPE_MODE_OUT, WIPE_TYPE_NORMAL, 10);
while(WipeStatGet()) {
HuPrcVSleep();
}
HuTHPClose();
HuSprGrpKill(temp_r27);
return lbl_1_bss_80;
}
void fn_1_3668(void)
{
Vec sp20;
Vec sp14;
Vec sp8;
Hu3DShadowCreate(20, 100, 5000);
Hu3DShadowTPLvlSet(0.3f);
Hu3DShadowSizeSet(192);
sp14.x = sp14.y = sp14.z = 0;
sp20.x = 0;
sp20.z = 300;
sp20.y = 400;
sp8.x = 0;
sp8.y = 1;
sp8.z = 0;
Hu3DShadowPosSet(&sp20, &sp8, &sp14);
Hu3DModelAttrReset(lbl_1_bss_19A[15], 1);
Hu3DModelAttrSet(lbl_1_bss_19A[15], 0x40000002);
Hu3DMotionTimeSet(lbl_1_bss_19A[15], 0);
Hu3DModelAttrReset(lbl_1_bss_19A[14], 1);
Hu3DModelAttrSet(lbl_1_bss_19A[14], 0x40000002);
Hu3DMotionTimeSet(lbl_1_bss_19A[14], 0);
}

View file

@ -453,7 +453,7 @@ void fn_1_EC(void)
}
}
int _prolog(void) {
s32 _prolog(void) {
const VoidFunc* ctors = _ctors;
while (*ctors != 0) {
(**ctors)();

View file

@ -129,13 +129,13 @@ static void fn_1_32F0(omObjData *arg0) {
fn_1_39E0(temp_r31->unk00, 1, 1);
temp_r31->unk20 = 1;
temp_r31->unk28 = 0;
GWRumbleSet(1);
GWRumbleSet(1);
arg0->unk10 = 3;
} else if (fn_1_584(4) != 0 && temp_r31->unk20 != 0) {
fn_1_39E0(temp_r31->unk00, 0, 1);
temp_r31->unk20 = 0;
temp_r31->unk28 = 0;
GWRumbleSet(0);
GWRumbleSet(0);
arg0->unk10 = 3;
}
}

235
src/REL/present/camera.c Normal file
View file

@ -0,0 +1,235 @@
#include "ext_math.h"
#include "game/hsfman.h"
#include "game/pad.h"
#include "game/printfunc.h"
#include "REL/present.h"
void fn_1_C20(omObjData *object);
omObjData *fn_1_6B4(void)
{
omObjData *var_r30;
UnkPresentCameraStruct *var_r31;
var_r30 = omAddObjEx(lbl_1_bss_4, 1001, 0, 0, 3, fn_1_BF8);
var_r31 = HuMemDirectMallocNum(HEAP_SYSTEM, 156, MEMORY_DEFAULT_NUM);
var_r30->data = var_r31;
var_r31->pos.x = 0.0f;
var_r31->pos.y = 0.0f;
var_r31->pos.z = 0.0f;
var_r31->target.x = 0.0f;
var_r31->target.y = 0.0f;
var_r31->target.z = 0.0f;
var_r31->up.x = 0.0f;
var_r31->up.y = 1.0f;
var_r31->up.z = 0.0f;
var_r31->unk_24 = 0.0f;
var_r31->unk_28 = 0.0f;
var_r31->unk_8C = 1.0f;
var_r31->unk_84 = 1.0f;
var_r31->unk_94 = 1.0f;
Hu3DCameraViewportSet(1, 0.0f, 0.0f, 640.0f, 480.0f, 0.0f, 1.0f);
Hu3DCameraPerspectiveSet(1, 42.0f, 10.0f, 8000.0f, 1.2f);
fn_1_9A4(var_r30, 0.0f, 0.0f, -600.0f, 1);
fn_1_920(var_r30, 0.0f, 220.0f, 250.0f, 1);
return var_r30;
}
void fn_1_8F0(omObjData *object)
{
HuMemDirectFree(object->data);
}
void fn_1_920(omObjData *object, float arg8, float arg9, float argA, s32 arg1)
{
UnkPresentCameraStruct *var_r31;
var_r31 = object->data;
var_r31->unk_58.x = arg8;
var_r31->unk_58.y = arg9;
var_r31->unk_58.z = argA;
var_r31->unk_2C = var_r31->pos;
var_r31->unk_84 = 0.0f;
var_r31->unk_88 = 1.0f / arg1;
}
void fn_1_9A4(omObjData *object, float arg8, float arg9, float argA, s32 arg1)
{
UnkPresentCameraStruct *var_r31;
var_r31 = object->data;
var_r31->unk_64.x = arg8;
var_r31->unk_64.y = arg9;
var_r31->unk_64.z = argA;
var_r31->unk_38 = var_r31->target;
var_r31->unk_8C = 0.0f;
var_r31->unk_90 = 1.0f / arg1;
}
void fn_1_A28(omObjData *object, s32 arg1, float arg8, float arg9, float argA)
{
UnkPresentCameraStruct *var_r31;
var_r31 = object->data;
var_r31->unk_64.y = argA;
var_r31->unk_7C = arg8;
var_r31->unk_80 = arg9;
var_r31->unk_38.y = var_r31->target.y;
var_r31->unk_50 = var_r31->unk_24;
var_r31->unk_54 = var_r31->unk_28;
var_r31->unk_94 = 0.0f;
var_r31->unk_98 = 1.0f / arg1;
}
float fn_1_AAC(omObjData *object)
{
UnkPresentCameraStruct *var_r31;
float var_f31;
var_r31 = object->data;
var_f31 = var_r31->unk_24;
return var_f31;
}
float fn_1_ADC(omObjData *object)
{
UnkPresentCameraStruct *var_r31;
float var_f31;
var_r31 = object->data;
var_f31 = var_r31->unk_28;
return var_f31;
}
void fn_1_B0C(omObjData *object, float *arg1, float *arg2, float *arg3)
{
UnkPresentCameraStruct *var_r31;
var_r31 = object->data;
*arg1 = var_r31->pos.x;
*arg2 = var_r31->pos.y;
*arg3 = var_r31->pos.z;
}
void fn_1_B3C(omObjData *object, float *arg1, float *arg2, float *arg3)
{
UnkPresentCameraStruct *var_r31;
var_r31 = object->data;
*arg1 = var_r31->target.x;
*arg2 = var_r31->target.y;
*arg3 = var_r31->target.z;
}
s32 fn_1_B6C(omObjData *object)
{
UnkPresentCameraStruct *var_r31;
s32 var_r30;
s32 var_r29;
var_r31 = object->data;
var_r30 = 1;
var_r29 = 1;
if (!(var_r31->unk_8C < 1.0f) && !(var_r31->unk_94 < 1.0f)) {
var_r29 = 0;
}
if (!var_r29 && !(var_r31->unk_84 < 1.0f)) {
var_r30 = 0;
}
return var_r30;
}
void fn_1_BF8(omObjData *object)
{
fn_1_C20(object);
}
void fn_1_C20(omObjData *object)
{
UnkPresentCameraStruct *var_r31;
float var_f31;
float var_f30;
float var_f29;
float var_f28;
float var_f27;
var_r31 = object->data;
if (var_r31->unk_84 < 1.0f) {
var_f28 = sind(90.0f * var_r31->unk_84);
var_r31->pos.x = var_r31->unk_2C.x + var_f28 * (var_r31->unk_58.x - var_r31->unk_2C.x);
var_r31->pos.y = var_r31->unk_2C.y + var_f28 * (var_r31->unk_58.y - var_r31->unk_2C.y);
var_r31->pos.z = var_r31->unk_2C.z + var_f28 * (var_r31->unk_58.z - var_r31->unk_2C.z);
if ((var_r31->unk_84 += var_r31->unk_88) >= 1.0f) {
var_r31->pos = var_r31->unk_58;
}
}
if (var_r31->unk_8C < 1.0f) {
var_f28 = sind(90.0f * var_r31->unk_8C);
var_r31->target.x = var_r31->unk_38.x + var_f28 * (var_r31->unk_64.x - var_r31->unk_38.x);
var_r31->target.y = var_r31->unk_38.y + var_f28 * (var_r31->unk_64.y - var_r31->unk_38.y);
var_r31->target.z = var_r31->unk_38.z + var_f28 * (var_r31->unk_64.z - var_r31->unk_38.z);
if ((var_r31->unk_8C += var_r31->unk_90) >= 1.0f) {
var_r31->target = var_r31->unk_64;
}
}
if (var_r31->unk_94 < 1.0f) {
var_f28 = sind(90.0f * var_r31->unk_94);
var_r31->target.y = var_r31->unk_38.y + (var_f28 * (var_r31->unk_64.y - var_r31->unk_38.y));
var_r31->unk_24 = var_r31->unk_50 + (var_f28 * (var_r31->unk_7C - var_r31->unk_50));
var_r31->unk_28 = var_r31->unk_54 + (var_f28 * (var_r31->unk_80 - var_r31->unk_54));
if ((var_r31->unk_94 += var_r31->unk_98) >= 1.0f) {
var_r31->target.y = var_r31->unk_64.y;
var_r31->unk_24 = var_r31->unk_7C;
var_r31->unk_28 = var_r31->unk_80;
}
var_r31->target.x = var_r31->unk_24 * -sind(var_r31->unk_28);
var_r31->target.z = var_r31->unk_24 * cosd(var_r31->unk_28);
}
var_f31 = var_r31->target.x - var_r31->pos.x;
var_f30 = var_r31->target.z - var_r31->pos.z;
var_r31->unk_24 = sqrtf(var_f31 * var_f31 + var_f30 * var_f30);
var_r31->unk_28 = fmod(-atan2d(var_f31, var_f30), 360.0);
if (var_r31->unk_28 < 0.0f) {
var_r31->unk_28 += 360.0f;
}
Hu3DCameraPosSet(1, var_r31->pos.x, var_r31->pos.y, var_r31->pos.z, var_r31->up.x, var_r31->up.y, var_r31->up.z, var_r31->target.x,
var_r31->target.y, var_r31->target.z);
}
void fn_1_1198(omObjData *object)
{
UnkPresentCameraStruct *var_r31;
if (HuPadBtn[0] & PAD_BUTTON_B) {
var_r31 = object->data;
var_r31->target.x = var_r31->target.x + (0.5f * HuPadStkX[0]);
var_r31->target.y = var_r31->target.y + (0.5f * HuPadStkY[0]);
var_r31->pos.z = var_r31->pos.z + (0.5f * HuPadTrigL[0]);
var_r31->pos.z = var_r31->pos.z - (0.5f * HuPadTrigR[0]);
var_r31->pos.x = var_r31->pos.x + (0.5f * HuPadSubStkY[0]);
var_r31->pos.y = var_r31->pos.y + (0.5f * HuPadSubStkX[0]);
}
}
void fn_1_1398(omObjData *object)
{
UnkPresentCameraStruct *var_r31;
var_r31 = object->data;
print8(32, 64, 1.5f, "AT : x=%.2f y=%.2f z=%.2f", var_r31->target.x, var_r31->target.y, var_r31->target.z);
print8(32, 80, 1.5f, "EYE : x=%.2f y=%.2f z=%.2f", var_r31->pos.x, var_r31->pos.y, var_r31->pos.z);
print8(32, 96, 1.5f, "R : %.2f DEG: %.2f", var_r31->unk_24, var_r31->unk_28);
}

227
src/REL/present/common.c Normal file
View file

@ -0,0 +1,227 @@
#include "ext_math.h"
#include "game/chrman.h"
#include "game/data.h"
#include "game/hsfman.h"
#include "game/hsfmotion.h"
#include "REL/present.h"
void fn_1_4620(omObjData *arg0);
void fn_1_4880(omObjData *arg0);
omObjFunc lbl_1_data_1A0[] = { NULL, fn_1_4620, fn_1_4880 };
static const s32 lbl_1_rodata_BD8[] = { 0x006E0089, 0x006E008A, 0x006E008B };
void fn_1_4A04(omObjData *object);
float fn_1_4CEC(float arg8, float arg9, float argA);
omObjData *fn_1_42F4(void)
{
omObjData *var_r31;
s32 var_lr;
s32 var_r29;
UnkPresentStruct5 *var_r30;
var_r31 = omAddObjEx(lbl_1_bss_4, 1002, 1, 3, 2, NULL);
var_r30 = HuMemDirectMallocNum(HEAP_SYSTEM, 88, MEMORY_DEFAULT_NUM);
var_r31->data = var_r30;
var_r30->x = 0.0f;
var_r30->z = 0.0f;
var_r30->y = 0.0f;
var_r30->unk_20 = 0.0f;
var_r30->unk_24 = 0.0f;
var_r30->unk_28 = 0.0f;
var_r30->unk_2C = 0.0f;
var_r30->unk_34 = 0.0f;
var_r30->unk_30 = 0.0f;
var_r31->model[0] = Hu3DModelCreate(HuDataReadNum(0x6E0088, MEMORY_DEFAULT_NUM));
Hu3DModelLayerSet(var_r31->model[0], 1);
for (var_r29 = 0; var_r29 < 3; var_r29++) {
var_r31->motion[var_r29] = Hu3DJointMotion(var_r31->model[0], HuDataSelHeapReadNum(lbl_1_rodata_BD8[var_r29], MEMORY_DEFAULT_NUM, HEAP_DATA));
}
Hu3DMotionShiftSet(var_r31->model[0], var_r31->motion[var_r30->unk_04 = 0], 0.0f, 8.0f, 0x40000001);
var_r30->unk_50 = CharModelEffectNpcInit(var_r31->model[0], var_r31->motion[2], 1, 10);
var_r30->unk_54 = CharModelEffectNpcInit(var_r31->model[0], var_r31->motion[1], 0, 10);
CharModelLayerSetAll(1);
Hu3DModelShadowSet(var_r31->model[0]);
fn_1_45C0(var_r31, 0);
fn_1_4A04(var_r31);
Hu3DModelAttrSet(var_r31->model[0], 1);
return var_r31;
}
void fn_1_4534(omObjData *object)
{
s32 var_r31;
void *var_r29;
void *var_r30;
var_r29 = object->data;
for (var_r31 = 0; var_r31 < 1; var_r31++) {
Hu3DModelKill(object->model[var_r31]);
}
for (var_r31 = 0; var_r31 < 3; var_r31++) {
Hu3DMotionKill(object->motion[var_r31]);
}
HuMemDirectFree(var_r29);
}
void fn_1_45C0(omObjData *object, s32 arg1)
{
UnkPresentStruct5 *var_r31;
var_r31 = object->data;
var_r31->unk_00 = arg1;
object->func = lbl_1_data_1A0[arg1];
object->unk10 = 0;
object->unk10 = 0;
}
s32 fn_1_4604(omObjData *object)
{
s32 *var_r31;
var_r31 = object->data;
return *var_r31;
}
void fn_1_4620(omObjData *object)
{
float var_f31;
omObjData *var_r30;
void *var_r29;
UnkPresentStruct5 *var_r31;
var_r31 = object->data;
switch (object->unk10) {
case 0:
Hu3DModelAttrReset(object->model[0], 1);
var_r31->x = -300.0f;
var_r31->z = -180.0f;
var_r31->unk_48 = 0.0f;
var_r31->unk_4C = 0.025f;
object->unk10 = 1;
case 1:
var_f31 = sind(90.0f * var_r31->unk_48);
var_f31 *= var_f31;
var_r31->unk_14 = -300.0f + (300.0f * var_f31);
var_r31->unk_2C = var_r31->unk_14 - var_r31->x;
if ((var_r31->unk_48 = var_r31->unk_48 + var_r31->unk_4C) < 1.0f) {
break;
}
var_r31->x = 0.0f;
var_r31->unk_48 = 0.0f;
var_r31->unk_4C = 0.05f;
object->unk10 = 2;
case 2:
var_r31->unk_2C = 0.0f;
var_r31->unk_34 = 0.01f;
if ((var_r31->unk_48 = var_r31->unk_48 + var_r31->unk_4C) < 1.0f) {
break;
}
var_r31->unk_24 = 0.0f;
var_r31->unk_2C = 0.0f;
var_r31->unk_30 = 0.0f;
var_r31->unk_34 = 0.0f;
object->unk10 = 3;
case 3:
fn_1_45C0(object, 0);
break;
default:
break;
}
fn_1_4A04(object);
}
void fn_1_4880(omObjData *object)
{
float var_f31;
UnkPresentStruct5 *var_r30;
void *var_r29;
var_r30 = object->data;
switch (object->unk10) {
case 0:
var_r30->unk_48 = 0.0f;
var_r30->unk_4C = 0.025f;
Hu3DModelAttrReset(object->model[0], 1);
object->unk10 = 1;
case 1:
var_f31 = sind(90.0f * var_r30->unk_48);
var_f31 *= var_f31;
var_r30->unk_14 = -(300.0f * var_f31);
var_r30->unk_2C = var_r30->unk_14 - var_r30->x;
if ((var_r30->unk_48 = var_r30->unk_48 + var_r30->unk_4C) < 1.0f) {
break;
}
object->unk10 = 2;
case 2:
Hu3DModelAttrSet(object->model[0], 1);
fn_1_45C0(object, 0);
break;
default:
break;
}
fn_1_4A04(object);
(void)object;
}
void fn_1_4A04(omObjData *object)
{
float var_f29;
float var_f30;
s16 var_r29;
UnkPresentStruct5 *var_r31;
var_r31 = object->data;
var_r29 = 0;
var_f30 = var_r31->unk_2C * var_r31->unk_2C + var_r31->unk_34 * var_r31->unk_34;
var_r31->unk_38 = sqrtf(var_f30);
if (0.001f <= var_r31->unk_38) {
if (12.0f <= var_r31->unk_38) {
var_r31->unk_2C = var_r31->unk_2C / var_r31->unk_38;
var_r31->unk_34 = var_r31->unk_34 / var_r31->unk_38;
var_r31->unk_38 = 12.0f;
var_r31->unk_2C = 12.0f * var_r31->unk_2C;
var_r31->unk_34 = 12.0f * var_r31->unk_34;
}
var_r31->unk_24 = fn_1_4CEC(var_r31->unk_24, atan2d(var_r31->unk_2C, var_r31->unk_34), 0.4f);
if (8.0f <= var_r31->unk_38) {
var_r29 = 2;
} else {
var_r29 = 1;
}
}
var_r31->x = var_r31->x + var_r31->unk_2C;
var_r31->z = var_r31->z + var_r31->unk_34;
if (var_r31->unk_04 != var_r29) {
Hu3DMotionShiftSet(object->model[0], object->motion[var_r31->unk_04 = var_r29], 0.0f, 8.0f, 0x40000001); // or 0x41000000
}
omSetTra(object, var_r31->x, var_r31->y, var_r31->z);
omSetRot(object, var_r31->unk_20, var_r31->unk_24, var_r31->unk_28);
}
float fn_1_4CEC(float arg8, float arg9, float argA)
{
float var_f30;
float var_f31;
var_f31 = fmod(arg9 - arg8, 360.0f);
if (0.0f > var_f31) {
var_f31 += 360.0f;
}
if (180.0f < var_f31) {
var_f31 -= 360.0f;
}
var_f30 = fmod(arg8 + (var_f31 * argA), 360.0f);
if (0.0f > var_f30) {
var_f30 += 360.0f;
}
return var_f30;
}

176
src/REL/present/init.c Normal file
View file

@ -0,0 +1,176 @@
#include "game/audio.h"
#include "game/esprite.h"
#include "game/objsub.h"
#include "game/pad.h"
#include "game/process.h"
#include "game/wipe.h"
#include "rel_sqrt_consts.h"
#include "REL/present.h"
omObjData *lbl_1_bss_18;
omObjData *lbl_1_bss_14;
omObjData *lbl_1_bss_10;
omObjData *lbl_1_bss_C;
omObjData *lbl_1_bss_8;
Process *lbl_1_bss_4;
omObjData *lbl_1_bss_0;
void fn_1_254(void);
void fn_1_45C(void);
void fn_1_5EC(omObjData *object);
void ModuleProlog(void)
{
lbl_1_bss_4 = omInitObjMan(150, 8192);
omGameSysInit(lbl_1_bss_4);
HuWinInit(1);
lbl_1_bss_0 = omAddObjEx(lbl_1_bss_4, 1000, 0, 0, 0, fn_1_5EC);
lbl_1_bss_0->unk10 = 0;
lbl_1_bss_18 = fn_1_39A8();
}
void fn_1_144(s16 arg0, s32 arg1, s32 arg2)
{
Process *var_r30;
UnkPresentStruct6 *var_r31;
var_r31 = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(UnkPresentStruct6), MEMORY_DEFAULT_NUM);
var_r31->unk_00 = arg0;
var_r31->unk_08 = 1.0f / arg2;
if (arg1) {
var_r31->unk_08 = var_r31->unk_08;
var_r31->unk_04 = 0.0f;
} else {
var_r31->unk_08 = -var_r31->unk_08;
var_r31->unk_04 = 1.0f;
}
espDispOn(var_r31->unk_00);
espTPLvlSet(var_r31->unk_00, var_r31->unk_04);
var_r30 = HuPrcChildCreate(fn_1_254, 100, 5376, 0, HuPrcCurrentGet());
var_r30->user_data = var_r31;
}
void fn_1_254(void)
{
UnkPresentStruct6 *var_r31;
var_r31 = HuPrcCurrentGet()->user_data;
while (TRUE) {
var_r31->unk_04 = var_r31->unk_04 + var_r31->unk_08;
if (var_r31->unk_04 > 1.0f) {
var_r31->unk_04 = 1.0f;
break;
} else if (var_r31->unk_04 < 0.0f) {
var_r31->unk_04 = 0.0f;
break;
} else {
espTPLvlSet(var_r31->unk_00, var_r31->unk_04);
HuPrcVSleep();
}
}
espTPLvlSet(var_r31->unk_00, var_r31->unk_04);
if (var_r31->unk_08 < 0.0f) {
espDispOff(var_r31->unk_00);
}
HuMemDirectFree(var_r31);
HuPrcEnd();
}
void fn_1_334(s16 arg0, s32 arg1, float arg8, s32 arg2)
{
Process *var_r30;
UnkPresentStruct6Weird *var_r31; // TODO correct type? why are only 12 bytes allocated?
var_r31 = HuMemDirectMallocNum(HEAP_SYSTEM, 12, MEMORY_DEFAULT_NUM);
var_r31->unk_00 = arg0;
var_r31->unk_0C = 1.0f / arg2;
var_r31->unk_04 = arg8;
if (arg1) {
var_r31->unk_0C = var_r31->unk_0C;
var_r31->unk_08 = 0.0f;
} else {
var_r31->unk_0C = -var_r31->unk_0C;
var_r31->unk_08 = 1.0f;
}
Hu3DModelTPLvlSet(var_r31->unk_00, var_r31->unk_08 * var_r31->unk_04);
Hu3DModelAttrReset(var_r31->unk_00, 1);
var_r30 = HuPrcChildCreate(fn_1_45C, 100, 5376, 0, HuPrcCurrentGet());
var_r30->user_data = var_r31;
}
void fn_1_45C(void)
{
UnkPresentStruct6Weird *var_r31; // TODO correct type? how is 0C possible?
var_r31 = HuPrcCurrentGet()->user_data;
while (TRUE) {
var_r31->unk_08 = var_r31->unk_08 + var_r31->unk_0C;
if (var_r31->unk_08 > 1.0f) {
var_r31->unk_08 = 1.0f;
break;
} else if (var_r31->unk_08 < 0.0f) {
var_r31->unk_08 = 0.0f;
break;
} else {
Hu3DModelTPLvlSet(var_r31->unk_00, var_r31->unk_08 * var_r31->unk_04);
HuPrcVSleep();
}
}
Hu3DModelTPLvlSet(var_r31->unk_00, var_r31->unk_08 * var_r31->unk_04);
if (var_r31->unk_0C < 0.0f) {
Hu3DModelAttrSet(var_r31->unk_00, 1);
}
HuMemDirectFree(var_r31);
HuPrcEnd();
}
u32 fn_1_550(u16 arg0)
{
u32 var_r31;
var_r31 = HuPadBtnDown[0] & arg0;
return var_r31 != 0;
}
u32 fn_1_584(u16 arg0)
{
u32 var_r31;
var_r31 = HuPadDStkRep[0] & arg0;
return var_r31 != 0;
}
u32 fn_1_5B8(u16 arg0)
{
u32 var_r31;
var_r31 = HuPadDStk[0] & arg0;
return var_r31 != 0;
}
void fn_1_5EC(omObjData *object)
{
switch (object->unk10) {
case 0:
object->unk10 = 1;
case 1:
if (!omSysExitReq) {
break;
}
object->unk10 = 2;
case 2:
WipeCreate(2, 0, 60);
HuAudFadeOut(1000);
object->unk10 = 3;
break;
case 3:
if (!WipeStatGet()) {
fn_1_3B18(lbl_1_bss_18);
omOvlReturnEx(1, 1);
}
break;
default:
break;
}
}

311
src/REL/present/main.c Normal file
View file

@ -0,0 +1,311 @@
#include "game/audio.h"
#include "game/hsfman.h"
#include "game/object.h"
#include "game/sprite.h"
#include "game/window.h"
#include "game/wipe.h"
#include "REL/present.h"
omObjData *lbl_1_bss_20;
UnkPresentStruct4 lbl_1_data_F0 = { { 0.0f, 3000.0f, 1.0f }, { 0.0f, 1.0f, 0.0f }, { 0.0f, 0.0f, 0.0f } };
void fn_1_3B8C(omObjData *object);
void fn_1_3DB8(omObjData *object);
void fn_1_4040(UnkWindowDataStruct *arg0);
void fn_1_4190(UnkWindowDataStruct *arg0);
void fn_1_41E0(void);
void fn_1_41BC(UnkWindowDataStruct *arg0, s32 arg1);
omObjData *fn_1_39A8(void)
{
omObjData *object;
UnkPresentStruct *var_r30;
object = omAddObjEx(lbl_1_bss_4, 1000, 0, 0, 4, NULL);
var_r30 = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(UnkPresentStruct), MEMORY_DEFAULT_NUM);
object->data = var_r30;
var_r30->unk_04 = 0;
lbl_1_bss_8 = fn_1_6B4();
lbl_1_bss_10 = fn_1_1458();
lbl_1_bss_20 = fn_1_42F4();
var_r30->unk_00 = fn_1_3EA4(0);
Hu3DShadowCreate(30.0f, 20.0f, 5000.0f);
Hu3DShadowTPLvlSet(0.45f);
Hu3DShadowPosSet(&lbl_1_data_F0.unk_00, &lbl_1_data_F0.unk_0C, &lbl_1_data_F0.unk_18);
if (omovlevtno > 0) {
OSReport("*** PRESENTROOM ( PRESENT GET MODE ) ***\n");
object->func = fn_1_3DB8;
object->unk10 = 0;
} else {
OSReport("*** PRESENTROOM ( PRESENT VIEW MODE ) ***\n");
object->func = fn_1_3B8C;
object->unk10 = 0;
}
return object;
}
void fn_1_3B18(omObjData *object)
{
UnkWindowDataStruct **var_r31;
var_r31 = object->data;
fn_1_8F0(lbl_1_bss_8);
fn_1_1784(lbl_1_bss_10);
fn_1_4534(lbl_1_bss_20);
fn_1_4040(*var_r31);
HuMemDirectFree(var_r31);
}
void fn_1_3B8C(omObjData *object)
{
UnkPresentStruct *var_r30;
var_r30 = object->data;
switch (object->unk10) {
case 0:
WipeCreate(WIPE_MODE_IN, WIPE_TYPE_NORMAL, 60);
object->unk10 = 1;
case 1:
if (WipeStatGet()) {
return;
}
object->unk10 = 2;
case 2:
fn_1_180C(lbl_1_bss_10, 1);
object->unk10 = 3;
case 3:
if (fn_1_1850(lbl_1_bss_10)) {
return;
}
object->unk10 = 4;
case 4:
fn_1_45C0(lbl_1_bss_20, 1);
object->unk10 = 5;
case 5:
if (fn_1_4604(lbl_1_bss_20)) {
return;
}
object->unk10 = 6;
case 6:
HuAudFXPlay(66);
fn_1_4080(var_r30->unk_00);
fn_1_40B0(var_r30->unk_00, 0x320002);
object->unk10 = 7;
case 7:
if (var_r30->unk_00->unk_20) {
return;
}
fn_1_41BC(var_r30->unk_00, 1);
object->unk10 = 8;
case 8:
if (var_r30->unk_00->unk_20) {
return;
}
fn_1_4098(var_r30->unk_00);
if (!var_r30->unk_00->choice) {
var_r30->unk_04 = 0;
object->unk10 = 11;
return;
} else {
object->unk10 = 9;
return;
}
case 9:
fn_1_45C0(lbl_1_bss_20, 2);
object->unk10 = 10;
return;
case 10:
if (fn_1_4604(lbl_1_bss_20)) {
return;
}
object->unk10 = 2;
return;
case 11:
object->unk10 = 12;
var_r30->unk_04 = 0;
case 12:
if (var_r30->unk_00->unk_20) {
return;
}
if (var_r30->unk_04++ >= 60) {
omSysExitReq = 1;
object->func = NULL;
object->unk10 = 0;
}
default:
break;
}
}
void fn_1_3DB8(omObjData *arg0)
{
void *sp8;
sp8 = arg0->data;
switch (arg0->unk10) {
case 0:
fn_1_186C(lbl_1_bss_10, omovlevtno - 1);
arg0->unk10 = 1;
case 1:
fn_1_180C(lbl_1_bss_10, 3);
arg0->unk10 = 2;
case 2:
if (!fn_1_1850(lbl_1_bss_10)) {
arg0->unk10 = 3;
} else {
break;
}
case 3:
arg0->unk10 = 4;
case 4:
omSysExitReq = 1;
arg0->func = NULL;
arg0->unk10 = 0;
break;
default:
break;
}
}
UnkWindowDataStruct *fn_1_3EA4(s32 arg0)
{
UnkWindowDataStruct *var_r31;
var_r31 = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(UnkWindowDataStruct), MEMORY_DEFAULT_NUM);
var_r31->unk18 = 0;
var_r31->unk10 = 0;
var_r31->unk14 = 0;
var_r31->unk_20 = 0;
var_r31->process = HuPrcChildCreate(fn_1_41E0, 1000, 8192, 0, lbl_1_bss_4);
var_r31->process->user_data = var_r31;
var_r31->unk08 = arg0;
switch (arg0) {
case 0:
var_r31->window = HuWinExCreateStyled(-10000.0f, 360.0f, 480, 80, -1, 1);
HuWinBGTPLvlSet(var_r31->window, 0.8f);
HuWinMesSpeedSet(var_r31->window, 0);
HuWinMesPalSet(var_r31->window, 7, 0, 0, 0);
break;
case 1:
var_r31->window = HuWinExCreateStyled(-10000.0f, 326.0f, 500, 40, -1, 0);
HuWinAttrSet(var_r31->window, 2048);
HuWinBGTPLvlSet(var_r31->window, 0.0f);
HuWinMesSpeedSet(var_r31->window, 0);
break;
}
HuWinDrawNoSet(var_r31->window, 63);
fn_1_4190(var_r31);
HuSprExecLayerSet(63, 2);
return var_r31;
}
void fn_1_4040(UnkWindowDataStruct *windowData)
{
HuWinExCleanup(windowData->window);
HuPrcKill(windowData->process);
HuMemDirectFree(windowData);
}
void fn_1_4080(UnkWindowDataStruct *windowData)
{
if (!windowData->unk0C) {
windowData->unk_20 = 1;
}
}
void fn_1_4098(UnkWindowDataStruct *windowData)
{
if (windowData->unk0C) {
windowData->unk_20 = 2;
}
}
void fn_1_40B0(UnkWindowDataStruct *windowData, u32 mess)
{
if (!windowData->unk_20) {
HuWinMesSet(windowData->window, mess);
return;
}
windowData->unk18 = mess;
}
void fn_1_4104(UnkWindowDataStruct *windowData, u32 mess, s16 index)
{
HuWinInsertMesSet(windowData->window, mess, index);
}
void fn_1_4144(UnkWindowDataStruct *windowData, float x, float y)
{
HuWinPosSet(windowData->window, x, y);
}
void fn_1_4184(UnkWindowDataStruct *windowData)
{
windowData->unk0C = 1;
}
void fn_1_4190(UnkWindowDataStruct *windowData)
{
windowData->unk0C = 0;
}
void fn_1_419C(UnkWindowDataStruct *windowData)
{
if (!windowData->unk_20) {
windowData->unk_20 = 3;
}
windowData->unk10 = 1;
}
void fn_1_41BC(UnkWindowDataStruct *windowData, s32 arg1)
{
if (!windowData->unk_20) {
windowData->unk_20 = 4;
}
windowData->unk14 = 1;
windowData->choice = arg1;
}
void fn_1_41E0(void)
{
UnkWindowDataStruct *windowData;
windowData = HuPrcCurrentGet()->user_data;
while (TRUE) {
switch (windowData->unk_20) {
case 1:
windowData->unk0C = 1;
HuWinExAnimIn(windowData->window);
break;
case 2:
HuWinExAnimOut(windowData->window);
windowData->unk0C = 0;
break;
case 3:
winData[windowData->window].active_pad = 1;
HuWinMesWait(windowData->window);
windowData->unk10 = 0;
break;
case 4:
windowData->choice = HuWinChoiceGet(windowData->window, windowData->choice);
windowData->unk14 = 0;
break;
}
if (windowData->unk18 != 0) {
HuWinMesSet(windowData->window, windowData->unk18);
windowData->unk18 = 0;
}
windowData->unk_20 = 0;
if (windowData->unk10 != 0) {
windowData->unk_20 = 3;
}
if (windowData->unk14 != 0) {
windowData->unk_20 = 4;
}
HuPrcVSleep();
}
}

868
src/REL/present/present.c Normal file
View file

@ -0,0 +1,868 @@
#include "ext_math.h"
#include "game/esprite.h"
#include "game/gamework_data.h"
#include "game/hsfdraw.h"
#include "game/hsfex.h"
#include "game/hsfman.h"
#include "game/wipe.h"
#include "REL/present.h"
void fn_1_180C(omObjData *object, s32 arg1);
void fn_1_1928(omObjData *arg0);
void fn_1_1FA8(omObjData *object, s32 arg1);
void fn_1_20E8(omObjData *arg0);
void fn_1_268C(omObjData *object, float *arg1, float *arg2, float *arg3);
void fn_1_2708(omObjData *arg0, float arg8, s32 arg1);
void fn_1_2774(omObjData *arg0);
s32 fn_1_28F0(omObjData *object);
void fn_1_2924(omObjData *object);
s32 fn_1_2B84(omObjData *arg0, s32 arg1, s32 arg2);
s32 fn_1_2BCC(omObjData *object, s32 arg1);
s32 fn_1_2C5C(omObjData *object, s32 arg1);
s32 fn_1_3394(s32 arg0);
void fn_1_33AC(omObjData *arg0);
s32 fn_1_393C(s32 arg0, s32 arg1);
UnkPresentStruct3 lbl_1_data_50 = { { 0.0f, 400.0f, 0.0f }, { 0.0f, -400.0f, -500.0f }, { 255, 255, 255, 255 } };
omObjFunc lbl_1_data_6C[] = { NULL, fn_1_1928, fn_1_20E8, fn_1_33AC };
static const s32 lbl_1_rodata_A0[] = { 0x006E006C, 0x006E006B, 0x006E0000, 0x006E0001, 0x006E0002, 0x006E0003, 0x006E0004, 0x006E0005, 0x006E0006,
0x006E0007, 0x006E0008, 0x006E0009, 0x006E000A, 0x006E000B, 0x006E000C, 0x006E000D, 0x006E000E, 0x006E000F, 0x006E0010, 0x006E0011, 0x006E0012,
0x006E0013, 0x006E0014, 0x006E0015, 0x006E0016, 0x006E0017, 0x006E0018, 0x006E0019, 0x006E001A, 0x006E001B, 0x006E001C, 0x006E001D, 0x006E001E,
0x006E001F, 0x006E0020, 0x006E0021, 0x006E0022, 0x006E0023, 0x006E0024, 0x006E0025, 0x006E0026, 0x006E0027, 0x006E0028, 0x006E0029, 0x006E002A,
0x006E002B, 0x006E002C, 0x006E002D, 0x006E002E, 0x006E002F, 0x006E0030, 0x006E0031, 0x006E0032, 0x006E0033, 0x006E0034, 0x006E0035, 0x006E0036,
0x006E0037, 0x006E0038, 0x006E0039, 0x006E003A, 0x006E003B, 0x006E003C, 0x006E003D, 0x006E003E, 0x006E003F, 0x006E0040, 0x006E0041, 0x006E0042,
0x006E0043, 0x006E0044, 0x006E0045, 0x006E0046, 0x006E0047, 0x006E0048, 0x006E0049, 0x006E004A, 0x006E004B, 0x006E004C, 0x006E004D, 0x006E004E,
0x006E004F, 0x006E0050, 0x006E0051, 0x006E0052, 0x006E0053, 0x006E0054, 0x006E0055, 0x006E0056, 0x006E0057, 0x006E0058, 0x006E0059, 0x006E005A,
0x006E005B, 0x006E005C, 0x006E005D, 0x006E005E, 0x006E005F, 0x006E0060, 0x006E0061, 0x006E0062, 0x006E0063, 0x006E0064, 0x006E0065, 0x006E0066,
0x006E0067, 0x006E0068, 0x006E0069, 0x006E006A, 0x006E006D, 0x006E006F, 0x006E0071, 0x006E0073, 0x006E0075, 0x006E0077, 0x006E0079, 0x006E007B,
0x006E007D, 0x006E006E, 0x006E0070, 0x006E0072, 0x006E0074, 0x006E0076, 0x006E0078, 0x006E007A, 0x006E007C, 0x006E007F, 0x006E0080, 0x006E0081,
0x006E0082, 0x006E0083, 0x006E0084, 0x006E0085, 0x006E0086 };
static const UnkPresentNestedOuterStruct lbl_1_rodata_2B8[] = {
{ 0x00000006, { { 0x00000002, 0x00000008, 0x00320006, 0x00320042 }, { 0x00000003, 0x00000009, 0x00320007, 0x00320043 },
{ 0x00000004, 0x0000000A, 0x00320008, 0x00320044 }, { 0x00000005, 0x0000000B, 0x00320009, 0x00320045 },
{ 0x00000006, 0x0000000C, 0x0032000A, 0x00320046 }, { 0x00000007, 0x0000000D, 0x0032000B, 0x00320047 },
},
},
{ 0x00000006, { { 0x0000000E, 0x00000014, 0x0032000C, 0x00320048 }, { 0x0000000F, 0x00000015, 0x0032000D, 0x00320049 },
{ 0x00000010, 0x00000016, 0x0032000E, 0x0032004A }, { 0x00000011, 0x00000017, 0x0032000F, 0x0032004B },
{ 0x00000012, 0x00000018, 0x00320010, 0x0032004C }, { 0x00000013, 0x00000019, 0x00320011, 0x0032004D },
},
},
{ 0x00000006, { { 0x0000001A, 0x00000020, 0x00320012, 0x0032004E }, { 0x0000001B, 0x00000021, 0x00320013, 0x0032004F },
{ 0x0000001C, 0x00000022, 0x00320014, 0x00320050 }, { 0x0000001D, 0x00000023, 0x00320015, 0x00320051 },
{ 0x0000001E, 0x00000024, 0x00320016, 0x00320052 }, { 0x0000001F, 0x00000025, 0x00320017, 0x00320053 },
},
},
{ 0x00000006, { { 0x00000026, 0x0000002C, 0x00320018, 0x00320054 }, { 0x00000027, 0x0000002D, 0x00320019, 0x00320055 },
{ 0x00000028, 0x0000002E, 0x0032001A, 0x00320056 }, { 0x00000029, 0x0000002F, 0x0032001B, 0x00320057 },
{ 0x0000002A, 0x00000030, 0x0032001C, 0x00320058 }, { 0x0000002B, 0x00000031, 0x0032001D, 0x00320059 },
},
},
{ 0x00000006, { { 0x00000032, 0x00000038, 0x0032001E, 0x0032005A }, { 0x00000033, 0x00000039, 0x0032001F, 0x0032005B },
{ 0x00000034, 0x0000003A, 0x00320020, 0x0032005C }, { 0x00000035, 0x0000003B, 0x00320021, 0x0032005D },
{ 0x00000036, 0x0000003C, 0x00320022, 0x0032005E }, { 0x00000037, 0x0000003D, 0x00320023, 0x0032005F },
},
},
{ 0x00000001, { { 0x00000001, 0xFFFFFFFF, 0x00320041, 0x00320041 } } },
{ 0x00000006, { { 0x0000003E, 0x00000044, 0x00320024, 0x00320060 }, { 0x0000003F, 0x00000045, 0x00320025, 0x00320061 },
{ 0x00000040, 0x00000046, 0x00320026, 0x00320062 }, { 0x00000041, 0x00000047, 0x00320027, 0x00320063 },
{ 0x00000042, 0x00000048, 0x00320028, 0x00320064 }, { 0x00000043, 0x00000049, 0x00320029, 0x00320065 },
},
},
{ 0x00000006, { { 0x0000004A, 0x00000050, 0x0032002A, 0x00320066 }, { 0x0000004B, 0x00000051, 0x0032002B, 0x00320067 },
{ 0x0000004C, 0x00000052, 0x0032002C, 0x00320068 }, { 0x0000004D, 0x00000053, 0x0032002D, 0x00320069 },
{ 0x0000004E, 0x00000054, 0x0032002E, 0x0032006A }, { 0x0000004F, 0x00000055, 0x0032002F, 0x0032006B },
},
},
{ 0x00000006, { { 0x00000056, 0x0000005C, 0x00320030, 0x0032006C }, { 0x00000057, 0x0000005D, 0x00320031, 0x0032006D },
{ 0x00000058, 0x0000005E, 0x00320032, 0x0032006E }, { 0x00000059, 0x0000005F, 0x00320033, 0x0032006F },
{ 0x0000005A, 0x00000060, 0x00320034, 0x00320070 }, { 0x0000005B, 0x00000061, 0x00320035, 0x00320071 },
},
},
{ 0x0000000B, { { 0x00000062, 0xFFFFFFFF, 0x00320036, 0x00320072 }, { 0x00000063, 0xFFFFFFFF, 0x00320037, 0x00320073 },
{ 0x00000064, 0xFFFFFFFF, 0x00320038, 0x00320074 }, { 0x00000065, 0xFFFFFFFF, 0x00320039, 0x00320075 },
{ 0x00000066, 0xFFFFFFFF, 0x0032003A, 0x00320076 }, { 0x00000067, 0xFFFFFFFF, 0x0032003B, 0x00320077 },
{ 0x00000068, 0xFFFFFFFF, 0x0032003C, 0x00320078 }, { 0x00000069, 0xFFFFFFFF, 0x0032003D, 0x00320079 },
{ 0x0000006A, 0xFFFFFFFF, 0x0032003E, 0x0032007A }, { 0x0000006B, 0xFFFFFFFF, 0x0032003F, 0x0032007B },
{ 0x0000006C, 0xFFFFFFFF, 0x00320040, 0x0032007C }
},
},
};
omObjData *fn_1_1458(void)
{
UnkPresentStruct2 *var_r31;
s32 var_r30;
omObjData *var_r29;
s32 var_r28;
s16 var_r27;
LightData *var_r26;
var_r29 = omAddObjEx(lbl_1_bss_4, 1003, 0, 0, 1, NULL);
var_r31 = HuMemDirectMallocNum(HEAP_SYSTEM, 868, MEMORY_DEFAULT_NUM);
var_r29->data = var_r31;
var_r31->unk_234 = 0;
var_r31->unk_238 = 0;
var_r31->unk_23C = 0.0f;
var_r31->unk_248 = 1.0f;
var_r31->unk_250 = 0.0f;
for (var_r30 = 0; var_r30 < 60; var_r30++) {
var_r31->unk_270[var_r30] = GWGameStat.present[var_r30];
}
for (var_r30 = 0; var_r30 < 59; var_r30++) {
if (!var_r31->unk_270[var_r30]) {
break;
}
}
if (var_r30 == 59) {
var_r31->unk_270[59] = 1;
}
Hu3DLighInit();
var_r27 = Hu3DGLightCreateV(&lbl_1_data_50.unk_00, &lbl_1_data_50.unk_0C, &lbl_1_data_50.unk_18);
Hu3DGLightInfinitytSet(var_r27);
Hu3DGLightStaticSet(var_r27, 1);
var_r26 = &Hu3DGlobalLight[var_r27];
var_r26->unk_00 = var_r26->unk_00 | 0x8000;
for (var_r30 = 0; var_r30 < 134; var_r30++) {
var_r31->unk_10[var_r30] = omAddObjEx(lbl_1_bss_4, 1003, 1, 0, 1, NULL);
var_r31->unk_10[var_r30]->model[0] = Hu3DModelCreate(HuDataSelHeapReadNum(lbl_1_rodata_A0[var_r30], MEMORY_DEFAULT_NUM, HEAP_DATA));
Hu3DModelLayerSet(var_r31->unk_10[var_r30]->model[0], 0);
Hu3DModelAttrSet(var_r31->unk_10[var_r30]->model[0], 1);
}
for (var_r28 = 0; var_r28 < 8; var_r28++) {
for (var_r30 = 0; var_r30 < 6; var_r30++) {
Hu3DModelLayerSet(var_r31->unk_10[var_r30 + 2 + var_r28 * 6 * 2]->model[0], 1);
}
}
Hu3DModelShadowMapSet(var_r31->unk_10[0]->model[0]);
fn_1_2924(var_r29);
var_r31->sprite = espEntry(7209095, 0, 0);
espDispOff(var_r31->sprite);
var_r31->unk_228 = fn_1_3EA4(0);
var_r31->unk_22C = fn_1_3EA4(1);
fn_1_2708(var_r29, var_r31->unk_234 * 36.0f, 1);
fn_1_2774(var_r29);
fn_1_180C(var_r29, 0);
(void)var_r27;
return var_r29;
}
void fn_1_1784(omObjData *object)
{
UnkPresentStruct2 *var_r31;
s32 var_r30;
void *var_r29;
var_r31 = object->data;
fn_1_4040(var_r31->unk_228);
fn_1_4040(var_r31->unk_22C);
for (var_r30 = 0; var_r30 < 134; var_r30++) {
Hu3DModelKill(var_r31->unk_10[var_r30]->model[0]);
}
espKill(var_r31->sprite);
HuMemDirectFree(var_r31);
}
void fn_1_180C(omObjData *object, s32 arg1)
{
UnkPresentStruct2 *var_r31;
var_r31 = object->data;
var_r31->unk_0C = arg1;
object->func = lbl_1_data_6C[arg1];
object->unk10 = 0;
object->unk10 = 0;
}
s32 fn_1_1850(omObjData *object)
{
UnkPresentStruct2 *var_r31;
var_r31 = object->data;
return var_r31->unk_0C;
}
static const s32 lbl_1_rodata_9D8[] = { 0, 1, 2, 3, 4, 6, 7, 8 };
static const s32 lbl_1_rodata_9F8[] = { 0, 1, 2, 3, 4, 0, 5, 6, 7, 0 };
void fn_1_186C(omObjData *object, s32 arg1)
{
UnkPresentStruct2 *var_r31;
var_r31 = object->data;
if (arg1 < 48) {
var_r31->unk_234 = lbl_1_rodata_9D8[arg1 / 6];
var_r31->unk_238 = arg1 % 6;
return;
}
if (arg1 < 59) {
var_r31->unk_234 = 9;
var_r31->unk_238 = (arg1 - 48) % 11;
return;
}
var_r31->unk_234 = 5;
var_r31->unk_238 = 0;
}
void fn_1_1928(omObjData *object)
{
Vec sp8;
UnkPresentStruct2 *var_r31;
s32 var_r29;
UnkPresentStruct2 *var_r28;
var_r31 = object->data;
switch (object->unk10) {
case 0:
var_r31->unk_00 = 0;
var_r31->unk_08 = 0;
object->unk10 = 1;
case 1:
if (var_r31->unk_08) {
fn_1_920(lbl_1_bss_8, 0.0f, 220.0f, 250.0f, 30);
fn_1_9A4(lbl_1_bss_8, 0.0f, 420.0f, -600.0f, 30);
} else {
fn_1_920(lbl_1_bss_8, 0.0f, 220.0f, 250.0f, 30);
fn_1_9A4(lbl_1_bss_8, 0.0f, 0.0f, -600.0f, 30);
}
object->unk10 = 2;
case 2:
if (!fn_1_B6C(lbl_1_bss_8) && !var_r31->unk_228->unk_20 && !fn_1_28F0(object)) {
fn_1_4080(var_r31->unk_228);
fn_1_4080(var_r31->unk_22C);
if (var_r31->unk_08) {
var_r29 = 0x320080;
} else if (var_r31->unk_234 == 5) {
var_r29 = 0x320085;
} else {
var_r29 = 0x32007e;
}
fn_1_40B0(var_r31->unk_22C, var_r29);
switch (var_r31->unk_234) {
case 0:
case 1:
case 2:
case 3:
case 4:
case 6:
case 7:
case 8:
if (var_r31->unk_08) {
if (fn_1_2B84(object, var_r31->unk_234, 5)) {
var_r29 = 0x320005;
} else {
var_r29 = 0x320082;
}
} else if (fn_1_2BCC(object, var_r31->unk_234) > 0) {
var_r29 = 0x320001;
} else {
var_r29 = 0x320081;
}
fn_1_40B0(var_r31->unk_228, var_r29);
fn_1_4104(var_r31->unk_228, lbl_1_rodata_9F8[var_r31->unk_234], 0);
break;
case 5:
if (fn_1_2B84(object, 5, 0)) {
var_r29 = 0x320041;
} else {
var_r29 = 0x320084;
}
fn_1_40B0(var_r31->unk_228, var_r29);
break;
case 9:
if (fn_1_2BCC(object, 9) > 0) {
var_r29 = 0x320083;
} else {
var_r29 = 0x320081;
}
fn_1_40B0(var_r31->unk_228, var_r29);
break;
default:
break;
}
if (var_r31->unk_08) {
sp8.x = 0.0f;
sp8.y = 600.0f;
sp8.z = -500.0f;
} else {
sp8.x = 0.0f;
sp8.y = 210.0f;
sp8.z = -500.0f;
}
Hu3D3Dto2D(&sp8, 1, &sp8);
sp8.y -= 15.0f;
sp8.x -= 20.0f;
espPosSet(var_r31->sprite, sp8.x, sp8.y);
if (!var_r31->unk_00) {
fn_1_144(var_r31->sprite, 1, 5);
var_r31->unk_00 = 1;
}
object->unk10 = 3;
}
break;
case 3:
if (!var_r31->unk_228->unk_20) {
if (fn_1_550(512) && !var_r31->unk_08) {
fn_1_144(var_r31->sprite, 0, 5);
var_r31->unk_00 = 0;
fn_1_4098(var_r31->unk_228);
fn_1_4098(var_r31->unk_22C);
HuAudFXPlay(3);
object->unk10 = 4;
} else if (fn_1_550(256) && !var_r31->unk_08) {
if (var_r31->unk_234 != 5) {
fn_1_144(var_r31->sprite, 0, 5);
var_r31->unk_00 = 0;
fn_1_4098(var_r31->unk_228);
fn_1_4098(var_r31->unk_22C);
HuAudFXPlay(2);
fn_1_180C(object, 2);
}
} else if (fn_1_584(8) && !var_r31->unk_08) {
if ((var_r31->unk_234 != 5) && (var_r31->unk_234 != 9)) {
var_r31->unk_08 = 1;
fn_1_144(var_r31->sprite, 0, 5);
var_r31->unk_00 = 0;
fn_1_4098(var_r31->unk_228);
fn_1_4098(var_r31->unk_22C);
HuAudFXPlay(0);
object->unk10 = 1;
}
} else if (fn_1_584(4) && var_r31->unk_08) {
var_r31->unk_08 = 0;
fn_1_144(var_r31->sprite, 0, 5);
var_r31->unk_00 = 0;
fn_1_4098(var_r31->unk_228);
fn_1_4098(var_r31->unk_22C);
HuAudFXPlay(0);
object->unk10 = 1;
} else if (fn_1_584(1)) {
fn_1_1FA8(object, 1);
HuAudFXPlay(0);
object->unk10 = 2;
} else if (fn_1_584(2)) {
fn_1_1FA8(object, 2);
HuAudFXPlay(0);
object->unk10 = 2;
}
}
break;
case 4:
fn_1_180C(object, 0);
break;
}
fn_1_2774(object);
}
void fn_1_1FA8(omObjData *object, s32 arg1)
{
UnkPresentStruct2 *var_r31;
s32 var_r30;
s32 var_r29;
s32 var_r28;
float var_f30;
float var_f31;
float var_f29;
var_r31 = object->data;
for (var_r30 = 0, var_f31 = 0.0f;; var_r30++) {
var_f31 += 36.0f;
if (arg1 == 1) {
var_r29 = -1;
} else {
var_r29 = 1;
}
var_r31->unk_234 = var_r31->unk_234 + var_r29;
if (var_r31->unk_234 < 0) {
var_r31->unk_234 = 9;
} else if (var_r31->unk_234 >= 10) {
var_r31->unk_234 = 0;
}
if (!((var_r31->unk_08) && ((var_r31->unk_234 == 5) || (var_r31->unk_234 == 9)))) {
break;
}
}
if (arg1 == 1) {
var_f30 = -var_f31;
} else {
var_f30 = var_f31;
}
var_f29 = var_r31->unk_23C + var_f30;
if (!var_r30) {
var_r28 = 30;
} else {
var_r28 = 45;
}
fn_1_2708(object, var_f29, var_r28);
}
void fn_1_20E8(omObjData *object)
{
Vec sp8;
UnkPresentStruct2 *var_r31;
s32 var_r29;
s32 var_r28;
s32 var_r27;
s32 var_r25;
float var_f31;
float var_f30;
var_r31 = object->data;
var_r29 = var_r31->unk_238;
var_r27 = var_r31->unk_234;
switch (object->unk10) {
case 0:
fn_1_920(lbl_1_bss_8, 0.0f, 220.0f, -120.0f, 30);
fn_1_9A4(lbl_1_bss_8, 0.0f, 0.0f, -600.0f, 30);
var_r31->unk_04 = fn_1_2BCC(object, var_r27) > 0;
var_r31->unk_00 = 0;
var_r31->unk_238 = 0;
if (var_r31->unk_04) {
var_r25 = fn_1_3394(var_r31->unk_234);
for (var_r28 = 0; var_r28 < var_r25; var_r28++) {
if (fn_1_2B84(object, var_r27, var_r28)) {
var_r31->unk_238 = var_r28;
break;
}
}
}
object->unk10 = 1;
case 1:
if (fn_1_B6C(lbl_1_bss_8)) {
break;
}
fn_1_4080(var_r31->unk_228);
fn_1_4080(var_r31->unk_22C);
fn_1_40B0(var_r31->unk_22C, 0x32007F);
if (var_r31->unk_04) {
fn_1_40B0(var_r31->unk_228, lbl_1_rodata_2B8[var_r27].unk_04[var_r29].unk_0C);
} else {
fn_1_40B0(var_r31->unk_228, 0x320003);
}
var_r31->unk_258 = 0.0f;
var_r31->unk_25C = 5.0f / 30.0f;
if (var_r31->unk_04) {
fn_1_268C(var_r31->unk_10[lbl_1_rodata_2B8[var_r27].unk_04[var_r29].unk_00], &sp8.x, &sp8.y, &sp8.z);
Hu3D3Dto2D(&sp8, 1, &sp8);
sp8.y -= 15.0f;
sp8.x -= 20.0f;
if (!var_r31->unk_00) {
fn_1_144(var_r31->sprite, 1, 5);
var_r31->unk_00 = 1;
var_r31->unk_260 = sp8.x;
var_r31->unk_264 = sp8.y;
} else {
var_r31->unk_260 = var_r31->unk_268;
var_r31->unk_264 = var_r31->unk_26C;
}
var_r31->unk_268 = sp8.x;
var_r31->unk_26C = sp8.y;
object->unk10 = 2;
} else {
object->unk10 = 3;
break;
}
case 2:
var_f31 = var_r31->unk_260 + (var_r31->unk_258 * (var_r31->unk_268 - var_r31->unk_260));
var_f30 = var_r31->unk_264 + (var_r31->unk_258 * (var_r31->unk_26C - var_r31->unk_264));
espPosSet(var_r31->sprite, var_f31, var_f30);
if ((var_r31->unk_258 = var_r31->unk_258 + var_r31->unk_25C) < 1.0f) {
break;
}
espPosSet(var_r31->sprite, var_r31->unk_268, var_r31->unk_26C);
object->unk10 = 3;
case 3:
if (fn_1_550(512)) {
fn_1_4098(var_r31->unk_228);
fn_1_4098(var_r31->unk_22C);
HuAudFXPlay(3);
object->unk10 = 4;
} else if (var_r31->unk_04) {
if (fn_1_584(1) && fn_1_5B8(8)) {
var_r29 = fn_1_2C5C(object, 5);
} else if (fn_1_584(1) && fn_1_5B8(4)) {
var_r29 = fn_1_2C5C(object, 9);
} else if (fn_1_584(2) && fn_1_5B8(8)) {
var_r29 = fn_1_2C5C(object, 6);
} else if (fn_1_584(2) && fn_1_5B8(4)) {
var_r29 = fn_1_2C5C(object, 10);
} else if (fn_1_584(1)) {
var_r29 = fn_1_2C5C(object, 1);
} else if (fn_1_584(2)) {
var_r29 = fn_1_2C5C(object, 2);
} else if (fn_1_584(8)) {
var_r29 = fn_1_2C5C(object, 4);
} else if (fn_1_584(4)) {
var_r29 = fn_1_2C5C(object, 8);
}
} else {
break;
}
if (var_r29 == -1) {
var_r29 = var_r31->unk_238;
}
if (var_r29 != var_r31->unk_238) {
var_r31->unk_238 = var_r29;
object->unk10 = 1;
HuAudFXPlay(0);
}
break;
case 4:
if (var_r31->unk_00) {
fn_1_144(var_r31->sprite, 0, 5);
}
fn_1_180C(object, 1);
break;
default:
break;
}
}
void fn_1_268C(omObjData *object, float *arg1, float *arg2, float *arg3)
{
Mtx sp8;
Hu3DModelObjMtxGet(object->model[0], "cursor", sp8);
*arg1 = sp8[0][3];
*arg2 = sp8[1][3];
*arg3 = sp8[2][3];
}
void fn_1_2708(omObjData *arg0, float arg8, s32 arg1)
{
UnkPresentStruct2 *var_r31;
var_r31 = arg0->data;
var_r31->unk_244 = arg8;
var_r31->unk_240 = var_r31->unk_23C;
var_r31->unk_248 = 0.0f;
var_r31->unk_250 = 1.0f / arg1;
}
void fn_1_2774(omObjData *object)
{
UnkPresentStruct2 *var_r31;
float var_f31;
s32 var_r30;
var_r31 = object->data;
if (var_r31->unk_248 < 1.0f) {
var_f31 = sin(90.0f * var_r31->unk_248 * M_PI / 180.0f);
var_f31 *= var_f31;
var_r31->unk_23C = var_r31->unk_240 + (var_f31 * (var_r31->unk_244 - var_r31->unk_240));
if ((var_r31->unk_248 = var_r31->unk_248 + var_r31->unk_250) >= 1.0f) {
var_r31->unk_23C = var_r31->unk_244;
}
}
var_r31->unk_23C = fmod(var_r31->unk_23C, 360.0);
if (var_r31->unk_23C < 0.0f) {
var_r31->unk_23C += 360.0f;
}
for (var_r30 = 0; var_r30 < 134; var_r30++) {
omSetRot(var_r31->unk_10[var_r30], 0.0f, var_r31->unk_23C, 0.0f);
}
}
s32 fn_1_28F0(omObjData *object)
{
UnkPresentStruct2 *var_r31;
var_r31 = object->data;
return var_r31->unk_248 < 1.0f;
}
s32 lbl_1_data_84[] = { 0, 1, 2, 3, 4, 6, 7, 8 };
void fn_1_2924(omObjData *object)
{
UnkPresentStruct2 *var_r31;
s32 var_r30;
s32 var_r27;
s32 var_r29;
var_r31 = object->data;
Hu3DModelAttrReset(var_r31->unk_10[0]->model[0], 1);
for (var_r29 = 0; var_r29 < 8; var_r29++) {
if (fn_1_2BCC(object, lbl_1_data_84[var_r29]) > 0) {
Hu3DModelAttrReset(var_r31->unk_10[var_r29 + 109]->model[0], 1);
}
for (var_r27 = 0, var_r30 = 0; var_r30 < 6; var_r30++) {
if (fn_1_2B84(object, lbl_1_data_84[var_r29], var_r30)) {
Hu3DModelAttrReset(var_r31->unk_10[var_r29 * 6 * 2 + 2 + var_r30]->model[0], 1);
Hu3DModelAttrReset(var_r31->unk_10[var_r29 * 6 * 2 + 8 + var_r30]->model[0], 1);
var_r27++;
}
}
if (var_r27 >= 6) {
Hu3DModelAttrReset(var_r31->unk_10[var_r29 + 118]->model[0], 1);
}
}
if (fn_1_2BCC(object, 9) > 0) {
Hu3DModelAttrReset(var_r31->unk_10[117]->model[0], 1);
}
for (var_r30 = 0; var_r30 < 11; var_r30++) {
if (fn_1_2B84(object, 9, var_r30)) {
Hu3DModelAttrReset(var_r31->unk_10[var_r30 + 98]->model[0], 1);
}
}
if (fn_1_2B84(object, 5, 0)) {
Hu3DModelAttrReset(var_r31->unk_10[1]->model[0], 1);
}
for (var_r30 = 0; var_r30 < 8; var_r30++) {
if (fn_1_2B84(object, lbl_1_data_84[var_r30], 5)) {
Hu3DModelAttrReset(var_r31->unk_10[var_r30 + 126]->model[0], 1);
}
}
}
static const s32 lbl_1_rodata_A74[] = { 0, 6, 12, 18, 24, 59, 30, 36, 42, 48 };
s32 fn_1_2B84(omObjData *arg0, s32 arg1, s32 arg2)
{
UnkPresentStruct2 *var_r31;
var_r31 = arg0->data;
return var_r31->unk_270[arg2 + lbl_1_rodata_A74[arg1]] != 0;
}
s32 fn_1_2BCC(omObjData *object, s32 arg1)
{
s32 var_r31;
s32 var_r30;
UnkPresentStruct2 *var_r29;
s32 var_r28;
var_r28 = fn_1_3394(arg1);
for (var_r30 = 0, var_r31 = 0; var_r31 < var_r28; var_r31++) {
if (fn_1_2B84(object, arg1, var_r31)) {
var_r30++;
}
}
return var_r30;
}
s32 fn_1_2C5C(omObjData *object, s32 arg1)
{
UnkPresentStruct7 spA4[10];
Vec sp38;
Vec sp2C;
UnkPresentStruct7 sp24;
float var_f31;
float var_f30;
float var_f29;
UnkPresentStruct2 *var_r31;
s32 var_r30;
s32 var_r28;
s32 var_r26;
s32 var_r23;
s32 var_r22;
omObjData *var_r21;
omObjData *var_r19;
s32 var_r18;
s32 var_r17;
var_r31 = object->data;
var_r22 = fn_1_3394(var_r31->unk_234);
var_r18 = fn_1_2BCC(object, var_r31->unk_234);
if (var_r18 == 1) {
return var_r31->unk_238;
}
fn_1_268C(var_r31->unk_10[lbl_1_rodata_2B8[var_r31->unk_234].unk_04[var_r31->unk_238].unk_00], &sp38.x, &sp38.y, &sp38.z);
Hu3D3Dto2D(&sp38, 1, &sp38);
for (var_r28 = 0, var_r26 = 0; !var_r28 && (var_r26 < 1); var_r26++) {
for (var_r28 = 0, var_r30 = 0; var_r30 < var_r22; var_r30++) {
if (var_r30 == var_r31->unk_238) {
continue;
}
if (!fn_1_2B84(object, var_r31->unk_234, var_r30)) {
continue;
}
fn_1_268C(var_r31->unk_10[lbl_1_rodata_2B8[var_r31->unk_234].unk_04[var_r30].unk_00], &sp2C.x, &sp2C.y, &sp2C.z);
Hu3D3Dto2D(&sp2C, 1, &sp2C);
var_f30 = sp38.x - sp2C.x;
var_f29 = sp38.y - sp2C.y;
var_f31 = fmod(atan2d(var_f30, var_f29), 360.0);
if (var_f31 < 0.0f) {
var_f31 += 360.0f;
}
if ((arg1 == 1 && var_f31 >= 45.0f && var_f31 < 135.0f) || (arg1 == 2 && var_f31 >= 225.0f && var_f31 < 315.0f)
|| (arg1 == 8 && var_f31 >= 135.0f && var_f31 < 225.0f)
|| (arg1 == 4 && (var_f31 >= 0.0f && var_f31 < 45.0f || var_f31 >= 315.0f && var_f31 < 360.0f))
|| (arg1 == 5 && var_f31 >= 0.0f && var_f31 < 90.0f) || (arg1 == 9 && var_f31 >= 90.0f && var_f31 < 180.0f)
|| (arg1 == 6 && var_f31 >= 270.0f && var_f31 < 360.0f) || (arg1 == 10 && var_f31 >= 180.0f && var_f31 < 270.0f)) {
spA4[var_r28].unk_00 = var_r30;
spA4[var_r28].unk_04 = sqrtf(var_f30 * var_f30 + var_f29 * var_f29);
var_r28++;
}
}
if (var_r28) {
continue;
}
switch (arg1) {
case 0:
break;
case 1:
L_00003218:
arg1 = 2;
break;
case 2:
L_00003220:
arg1 = 1;
break;
case 3:
break;
case 4:
L_00003228:
arg1 = 8;
break;
case 7:
break;
case 8:
L_00003230:
arg1 = 4;
break;
case 5:
L_00003238:
arg1 = 10;
break;
case 9:
L_00003240:
arg1 = 6;
break;
case 6:
L_00003248:
arg1 = 9;
break;
case 10:
L_00003250:
arg1 = 5;
break;
default:
break;
}
// L_00003254:
}
if (!var_r28) {
return var_r31->unk_238;
}
do {
for (var_r23 = 0, var_r30 = 0; var_r30 < (var_r28 - 1); var_r30++) {
if (spA4[var_r30].unk_04 > spA4[var_r30 + 1].unk_04) {
sp24 = spA4[var_r30 + 1];
spA4[var_r30 + 1] = spA4[var_r30];
spA4[var_r30] = sp24;
var_r23 = 1;
}
}
} while (var_r23);
return spA4[(var_r26 <= 1) ? 0 : var_r28 - 1].unk_00;
}
static const s32 lbl_1_rodata_AC8[] = { 6, 6, 6, 6, 6, 1, 6, 6, 6, 11 };
s32 fn_1_3394(s32 arg0)
{
return lbl_1_rodata_AC8[arg0];
}
static const s32 lbl_1_rodata_AF0[] = { 2, 14, 26, 38, 50, 0, 62, 74, 86, 0 };
static const s32 lbl_1_rodata_B18[] = { 8, 20, 32, 44, 56, 0, 68, 80, 92, 0 };
static const s32 lbl_1_rodata_B40[] = { 126, 127, 128, 129, 130, 0, 131, 132, 133, 0 };
static const s32 lbl_1_rodata_B68[] = { 118, 119, 120, 121, 122, 0, 123, 124, 125, 0 };
void fn_1_33AC(omObjData *object)
{
f32 var_f29;
f32 var_f30;
f32 var_f31;
UnkPresentStruct2 *var_r31;
UnkPresentStruct2 *var_r30;
UnkPresentStruct2 *var_r28;
s32 var_r27;
var_r31 = object->data;
switch (object->unk10) {
case 0:
var_f29 = 36.0f * var_r31->unk_234;
fn_1_2708(object, var_f29, 1);
fn_1_2774(object);
Hu3DModelAttrSet(var_r31->unk_10[var_r31->unk_238 + lbl_1_rodata_B18[var_r31->unk_234]]->model[0], 1);
Hu3DModelAttrSet(var_r31->unk_10[lbl_1_rodata_B68[var_r31->unk_234]]->model[0], 1);
Hu3DModelAttrSet(var_r31->unk_10[lbl_1_rodata_B40[var_r31->unk_234]]->model[0], 1);
var_r31->unk_24C = 0.0f;
var_r31->unk_254 = 1.0f / 360.0f;
object->unk10 = 1;
case 1:
WipeCreate(1, 0, 120);
object->unk10 = 2;
case 2:
var_f31 = sind(90.0f * var_r31->unk_24C);
var_f31 *= var_f31;
fn_1_920(lbl_1_bss_8, 0.0f, 820.0f - (600.0f * var_f31), -120.0f, 1);
fn_1_9A4(lbl_1_bss_8, 0.0f, 680.0f - (680.0f * var_f31), -600.0f, 1);
omSetTra(var_r31->unk_10[var_r31->unk_238 + lbl_1_rodata_AF0[var_r31->unk_234]], 0.0f, 840.0f - (840.0f * var_f31), 0.0f);
if ((var_r31->unk_24C = var_r31->unk_24C + var_r31->unk_254) < 1.0f) {
return;
}
if (fn_1_393C(var_r31->unk_234, var_r31->unk_238)) {
fn_1_334(var_r31->unk_10[var_r31->unk_238 + lbl_1_rodata_B18[var_r31->unk_234]]->model[0], 1, 0.4f, 30);
}
object->unk10 = 3;
case 3:
fn_1_4080(var_r31->unk_228);
fn_1_4104(var_r31->unk_228, lbl_1_rodata_2B8[var_r31->unk_234].unk_04[var_r31->unk_238].unk08, 0);
fn_1_40B0(var_r31->unk_228, 0x320004);
fn_1_419C(var_r31->unk_228);
object->unk10 = 4;
case 4:
if (var_r31->unk_228->unk_20) {
break;
}
object->unk10 = 5;
case 5:
fn_1_4098(var_r31->unk_228);
object->unk10 = 6;
case 6:
if (!var_r31->unk_228->unk_20) {
fn_1_180C(object, 0);
}
break;
}
}
static const s32 lbl_1_rodata_BA4[][2] = { { 7, 1 } };
s32 fn_1_393C(s32 arg0, s32 arg1)
{
s32 var_r31;
for (var_r31 = 0; var_r31 < 1; var_r31++) {
if (arg0 == lbl_1_rodata_BA4[var_r31][0] && arg1 == lbl_1_rodata_BA4[var_r31][1]) {
return 0;
}
}
return 1;
}

597
src/REL/staffDll/main.c Normal file
View file

@ -0,0 +1,597 @@
#include "game/animdata.h"
#include "game/audio.h"
#include "game/hsfman.h"
#include "game/object.h"
#include "game/objsub.h"
#include "game/pad.h"
#include "game/process.h"
#include "game/sprite.h"
#include "game/window.h"
#include "game/wipe.h"
#include "REL/staffDll.h"
#include "rel_sqrt_consts.h"
static s16 imgGroup[26];
static s16 staffLogoGroup[3];
static s16 thpGroup;
static s16 thpCoverGroup;
static s32 staffSide;
static s32 currImg;
static omObjData *multiViewObj;
static UnkStaffDllStruct staffData[] = {
{ 0x00340001, 0, 0.0f, 0, 0, 0 },
{ 0x00350000, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 72.0f, 0, 0, 0 },
{ 0x00340002, 0, 0.0f, 0, 0, 0 },
{ 0x00350001, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340003, 0, 0.0f, 0, 0, 0 },
{ 0x00350002, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340004, 0, 0.0f, 0, 0, 0 },
{ 0x00350003, 2, 0.0f, 0, 0, 0 },
{ 0x00350004, 2, 0.0f, 0, 0, 0 },
{ 0x00350005, 2, 0.0f, 0, 0, 0 },
{ 0x00350006, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x00350007, 2, 0.0f, 0, 0, 0 },
{ 0x00350008, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340005, 0, 0.0f, 0, 0, 0 },
{ 0x00350009, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340006, 0, 0.0f, 0, 0, 0 },
{ 0x0035000A, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340007, 0, 0.0f, 0, 0, 0 },
{ 0x0034001C, 1, 0.0f, 0, 0, 0 },
{ 0x0035000B, 2, 0.0f, 0, 0, 0 },
{ 0x0035000C, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x0034001D, 1, 0.0f, 0, 0, 0 },
{ 0x0035000D, 2, 0.0f, 0, 0, 0 },
{ 0x0035000E, 2, 0.0f, 0, 0, 0 },
{ 0x0035000F, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x00350010, 2, 0.0f, 0, 0, 0 },
{ 0x00350011, 2, 0.0f, 0, 0, 0 },
{ 0x00350012, 2, 0.0f, 0, 0, 0 },
{ 0x00350013, 2, 0.0f, 0, 0, 0 },
{ 0x00350014, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x0034001E, 1, 0.0f, 0, 0, 0 },
{ 0x00350015, 2, 0.0f, 0, 0, 0 },
{ 0x00350016, 2, 0.0f, 0, 0, 0 },
{ 0x00350017, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340008, 0, 0.0f, 0, 0, 0 },
{ 0x00350018, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340009, 0, 0.0f, 0, 0, 0 },
{ 0x00350019, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x0034000A, 0, 0.0f, 0, 0, 0 },
{ 0x0034001C, 1, 0.0f, 0, 0, 0 },
{ 0x0035001A, 2, 0.0f, 0, 0, 0 },
{ 0x0035001B, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x0034001D, 1, 0.0f, 0, 0, 0 },
{ 0x0035001C, 2, 0.0f, 0, 0, 0 },
{ 0x0035001D, 2, 0.0f, 0, 0, 0 },
{ 0x0035001E, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x0034001E, 1, 0.0f, 0, 0, 0 },
{ 0x0035001F, 2, 0.0f, 0, 0, 0 },
{ 0x00350020, 2, 0.0f, 0, 0, 0 },
{ 0x00350021, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x0034000B, 0, 0.0f, 0, 0, 0 },
{ 0x0034001F, 1, 0.0f, 0, 0, 0 },
{ 0x00350022, 2, 0.0f, 0, 0, 0 },
{ 0x00350023, 2, 0.0f, 0, 0, 0 },
{ 0x00350024, 2, 0.0f, 0, 0, 0 },
{ 0x00350025, 2, 0.0f, 0, 0, 0 },
{ 0x00350026, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x00350027, 2, 0.0f, 0, 0, 0 },
{ 0x00350028, 2, 0.0f, 0, 0, 0 },
{ 0x00350029, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x0034001C, 1, 0.0f, 0, 0, 0 },
{ 0x0035002A, 2, 0.0f, 0, 0, 0 },
{ 0x0035002B, 2, 0.0f, 0, 0, 0 },
{ 0x0035002C, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x0034001D, 1, 0.0f, 0, 0, 0 },
{ 0x0035002D, 2, 0.0f, 0, 0, 0 },
{ 0x0035002E, 2, 0.0f, 0, 0, 0 },
{ 0x0035002F, 2, 0.0f, 0, 0, 0 },
{ 0x00350030, 2, 0.0f, 0, 0, 0 },
{ 0x00350031, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x00350032, 2, 0.0f, 0, 0, 0 },
{ 0x00350033, 2, 0.0f, 0, 0, 0 },
{ 0x00350034, 2, 0.0f, 0, 0, 0 },
{ 0x00350035, 2, 0.0f, 0, 0, 0 },
{ 0x00350036, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x0034000C, 0, 0.0f, 0, 0, 0 },
{ 0x00350037, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x0034000D, 0, 0.0f, 0, 0, 0 },
{ 0x00350038, 2, 0.0f, 0, 0, 0 },
{ 0x00350039, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x0034000E, 0, 0.0f, 0, 0, 0 },
{ 0x0035003A, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x0034000F, 0, 0.0f, 0, 0, 0 },
{ 0x0035003B, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340010, 0, 0.0f, 0, 0, 0 },
{ 0x0035003C, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x00340011, 0, 0.0f, 0, 0, 0 },
{ 0x0035003B, 2, 0.0f, 0, 0, 0 },
{ 0x0035003C, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x00340012, 0, 0.0f, 0, 0, 0 },
{ 0x0035003D, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x00340013, 0, 0.0f, 0, 0, 0 },
{ 0x0035003E, 2, 0.0f, 0, 0, 0 },
{ 0x0035003F, 2, 0.0f, 0, 0, 0 },
{ 0x00350040, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340014, 0, 0.0f, 0, 0, 0 },
{ 0x00350041, 2, 0.0f, 0, 0, 0 },
{ 0x00350042, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340015, 0, 0.0f, 0, 0, 0 },
{ 0x00350043, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340022, 0, 0.0f, 0, 0, 0 },
{ 0x00340024, 1, 0.0f, 0, 0, 0 },
{ 0x00350056, 2, 0.0f, 0, 0, 0 },
{ 0x00350057, 2, 0.0f, 0, 0, 0 },
{ 0x00350058, 2, 0.0f, 0, 0, 0 },
{ 0x00350059, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x00340025, 1, 0.0f, 0, 0, 0 },
{ 0x0035005A, 2, 0.0f, 0, 0, 0 },
{ 0x0035005B, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340023, 0, 0.0f, 0, 0, 0 },
{ 0x0035005C, 2, 0.0f, 0, 0, 0 },
{ 0x0035005D, 2, 0.0f, 0, 0, 0 },
{ 0x0035005E, 2, 0.0f, 0, 0, 0 },
{ 0x0035005F, 2, 0.0f, 0, 0, 0 },
{ 0x00350060, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340016, 0, 0.0f, 0, 0, 0 },
{ 0x00350044, 2, 0.0f, 0, 0, 0 },
{ 0x00350045, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x00350046, 2, 0.0f, 0, 0, 0 },
{ 0x00350047, 2, 0.0f, 0, 0, 0 },
{ 0x00350048, 2, 0.0f, 0, 0, 0 },
{ 0x00350049, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 24.0f, 0, 0, 0 },
{ 0x0035004A, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x0035004B, 2, 0.0f, 0, 0, 0 },
{ 0x0035004C, 2, 0.0f, 0, 0, 0 },
{ 0x0035004D, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340017, 0, 0.0f, 0, 0, 0 },
{ 0x0035004E, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 48.0f, 0, 0, 0 },
{ 0x00340018, 0, 0.0f, 0, 0, 0 },
{ 0x0035004F, 2, 0.0f, 0, 0, 0 },
{ 0x00350050, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 72.0f, 0, 0, 0 },
{ 0x00340019, 0, 0.0f, 0, 0, 0 },
{ 0x00350038, 2, 0.0f, 0, 0, 0 },
{ 0x00350051, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 72.0f, 0, 0, 0 },
{ 0x0034001A, 0, 0.0f, 0, 0, 0 },
{ 0x00350052, 2, 0.0f, 0, 0, 0 },
{ 0x00350053, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 72.0f, 0, 0, 0 },
{ 0x0034001B, 0, 0.0f, 0, 0, 0 },
{ 0x00350054, 2, 0.0f, 0, 0, 0 },
{ 0x00350055, 2, 0.0f, 0, 0, 0 },
{ -3, 0, 74.0f, 0, 0, 0 },
{ -2, 0, 0.0f, 0, 0, 0 },
{ -1, 0, 0.0f, 0, 0, 0 },
};
static float staffLogoPosTbl[] = { 460.0f, 293.0f, 293.0f };
static void MainProc(void);
static void CreateStaff(void);
static void ShowPicture(void);
void ModuleProlog(void)
{
Process *var_r31;
s32 var_lr;
var_r31 = omInitObjMan(0x32, 0x2000);
omGameSysInit(var_r31);
HuWinInit(1);
Hu3DCameraCreate(1);
Hu3DCameraPerspectiveSet(1, 20.0f, 20.0f, 10000.0f, 1.2f);
Hu3DCameraViewportSet(1, 0.0f, 0.0f, 640.0f, 480.0f, 0.0f, 1.0f);
Hu3DCameraScissorSet(1, 0, 0, 640, 480);
multiViewObj = omAddObjEx(var_r31, 0x7FDA, 0, 0, -1, omOutViewMulti);
multiViewObj->work[0] = 1;
CRotM[0].x = -35.0f;
CRotM[0].y = 0.0f;
CRotM[0].z = 0.0f;
CenterM[0].x = 0.0f;
CenterM[0].y = 0.0f;
CenterM[0].z = -250.0f;
CZoomM[0] = 4820.0f;
Hu3DBGColorSet(0, 0, 0);
CreateStaff();
HuPrcChildCreate(MainProc, 0x1000, 0x2000, 0, HuPrcCurrentGet());
WipeCreate(WIPE_MODE_IN, WIPE_TYPE_NORMAL, 60);
}
static void ExitProc(void)
{
while (TRUE) {
if (omSysExitReq == 1) {
WipeCreate(WIPE_MODE_OUT, WIPE_TYPE_NORMAL, 60);
HuAudFadeOut(1000);
HuPrcSleep(60);
MGSeqKillAll();
omOvlReturnEx(1, 1);
while (TRUE) {
HuPrcVSleep();
}
}
HuPrcVSleep();
}
while (!omSysExitReq) {
HuPrcVSleep();
}
WipeCreate(WIPE_MODE_OUT, WIPE_TYPE_NORMAL, 60);
HuAudFadeOut(1000);
HuPrcSleep(60);
MGSeqKillAll();
omOvlReturnEx(1, 1);
while (TRUE) {
HuPrcVSleep();
}
}
static void CreateStaff(void)
{
void *var_r29;
AnimData *var_r28;
s16 var_r30;
s32 var_r31;
staffSide = 0;
currImg = 0;
for (var_r31 = 0; var_r31 < 26; var_r31++) {
var_r29 = HuDataSelHeapReadNum(var_r31 + 0x730000, MEMORY_DEFAULT_NUM, HEAP_DATA);
var_r28 = HuSprAnimRead(var_r29);
var_r30 = HuSprCreate(var_r28, 16386, 0);
imgGroup[var_r31] = HuSprGrpCreate(1);
HuSprGrpMemberSet(imgGroup[var_r31], 0, var_r30);
if (staffSide != 0) {
HuSprGrpPosSet(imgGroup[var_r31], 380.0f, 240.0f);
} else {
HuSprGrpPosSet(imgGroup[var_r31], 200.0f, 240.0f);
}
HuSprAttrSet(imgGroup[var_r31], 0, HUSPR_ATTR_DISPOFF);
}
for (var_r31 = 0; var_r31 < 3; var_r31++) {
var_r29 = HuDataSelHeapReadNum(var_r31 + 0x73001A, MEMORY_DEFAULT_NUM, HEAP_DATA);
var_r28 = HuSprAnimRead(var_r29);
var_r30 = HuSprCreate(var_r28, 256, 0);
staffLogoGroup[var_r31] = HuSprGrpCreate(1);
HuSprGrpMemberSet(staffLogoGroup[var_r31], 0, var_r30);
HuSprAttrSet(staffLogoGroup[var_r31], 0, HUSPR_ATTR_DISPOFF);
}
thpGroup = HuSprGrpCreate(1);
var_r30 = HuTHPSprCreate("movie/stmov_a00.thp", 0, 16386);
HuSprGrpMemberSet(thpGroup, 0, var_r30);
HuSprGrpScaleSet(thpGroup, 0.65f, 0.65f);
HuSprGrpPosSet(thpGroup, 280.0f, 200.0f);
HuSprAttrSet(thpGroup, 0, HUSPR_ATTR_DISPOFF);
HuTHPStop();
var_r29 = HuDataSelHeapReadNum(0x73001D, MEMORY_DEFAULT_NUM, HEAP_DATA);
var_r28 = HuSprAnimRead(var_r29);
var_r30 = HuSprCreate(var_r28, 16385, 0);
thpCoverGroup = HuSprGrpCreate(1);
HuSprGrpMemberSet(thpCoverGroup, 0, var_r30);
HuSprGrpScaleSet(thpCoverGroup, 40.0f, 40.0f);
HuSprGrpPosSet(thpCoverGroup, 280.0f, 200.0f);
HuSprAttrSet(thpCoverGroup, 0, HUSPR_ATTR_DISPOFF);
HuPrcChildCreate(ShowPicture, 4096, 8192, 0, HuPrcCurrentGet());
HuPrcChildCreate(ExitProc, 4096, 4096, 0, HuPrcCurrentGet());
}
static void MoveStaff(void)
{
float sp8[2];
Process *temp_ret;
float var_f30;
float var_f31;
s16 var_r30;
u32 var_r29;
UnkStaffDllStruct *var_r31;
var_r31 = HuPrcCurrentGet()->user_data;
var_r31->unk_14 = 0;
switch (var_r31->unk_00) {
case -2:
HuSprAttrReset(staffLogoGroup[var_r31->unk_10], 0, HUSPR_ATTR_DISPOFF);
var_f31 = staffLogoPosTbl[var_r31->unk_10];
var_f30 = 576.0f;
break;
default:
HuWinMesMaxSizeGet(1, sp8, var_r31->unk_00);
var_r29 = 0;
switch (var_r31->unk_04) {
case 3:
var_f31 = 320.0f - (0.75f * sp8[0]) / 2;
break;
case 0:
var_f31 = 10.0f;
if (!staffSide) {
var_f31 += 240.0f;
}
break;
case 1:
var_f31 = 30.0f;
if (!staffSide) {
var_f31 += 240.0f;
}
break;
case 2:
var_f31 = 550.0f - (0.75f * sp8[0]);
if (staffSide) {
var_f31 -= 240.0f;
}
var_r29 = 0x1000;
break;
}
var_f30 = 476.0f;
var_r30 = HuWinCreate(var_f31, var_f30, sp8[0], sp8[1], 1);
HuWinAttrSet(var_r30, var_r29);
HuWinPriSet(var_r30, 256);
HuWinBGTPLvlSet(var_r30, 0.0f);
HuWinMesSpeedSet(var_r30, 0);
HuWinMesSet(var_r30, var_r31->unk_00);
HuWinScaleSet(var_r30, 0.75f, 0.75f);
switch (var_r31->unk_04) {
case 0:
case 1:
HuWinMesPalSet(var_r30, 7, 96, 240, 255);
break;
default:
HuWinMesPalSet(var_r30, 7, 255, 255, 255);
break;
}
break;
}
while (TRUE) {
var_f30 -= 0.4f;
if (var_r31->unk_00 == -2) {
if (var_f30 < -114.0f) {
break;
}
} else if (var_f30 < -24.0f) {
break;
}
if (var_r31->unk_00 == -2) {
HuSprGrpPosSet(staffLogoGroup[var_r31->unk_10], var_f31, var_f30);
} else {
HuWinPosSet(var_r30, var_f31, var_f30);
}
HuPrcVSleep();
}
var_r31->unk_14 = 1;
if (var_r31->unk_00 == -2) {
HuSprAttrSet(staffLogoGroup[var_r31->unk_10], 0, HUSPR_ATTR_DISPOFF);
} else {
HuWinKill(var_r30);
}
HuPrcVSleep();
HuPrcKill(HuPrcCurrentGet());
while (TRUE) {
HuPrcVSleep();
}
}
static void HidePicture(void)
{
s32 prevImg;
prevImg = currImg;
currImg++;
if (staffSide != 0) {
HuSprGrpPosSet(imgGroup[currImg], 380.0f, 240.0f);
} else {
HuSprGrpPosSet(imgGroup[currImg], 200.0f, 240.0f);
}
HuSprAttrSet(imgGroup[prevImg], 0, HUSPR_ATTR_DISPOFF);
HuPrcSleep(20);
HuSprAttrReset(imgGroup[currImg], 0, HUSPR_ATTR_DISPOFF);
HuPrcKill(HuPrcCurrentGet());
while (TRUE) {
HuPrcVSleep();
}
}
static void ShowPicture(void)
{
float var_f31;
s32 var_r31;
HuPrcSleep(360);
HuSprAttrReset(imgGroup[currImg], 0, HUSPR_ATTR_DISPOFF);
for (var_r31 = 0, var_f31 = 0.0f; var_r31 < 30; var_r31++, var_f31 += 1.0f / 30.0f) {
HuSprTPLvlSet(imgGroup[currImg], 0, var_f31);
HuPrcVSleep();
}
HuSprTPLvlSet(imgGroup[currImg], 0, 1.0f);
while (TRUE) {
if (currImg >= 24) {
HuPrcSleep(430);
} else {
HuPrcSleep(550);
}
if (currImg >= 25) {
break;
}
HuPrcChildCreate(HidePicture, 0x1000, 0x2000, 0, HuPrcCurrentGet());
}
for (var_r31 = 0, var_f31 = 1.0f; var_r31 < 30; var_r31++, var_f31 -= 1.0f / 30.0f) {
HuSprTPLvlSet(imgGroup[25], 0, var_f31);
HuPrcVSleep();
}
HuSprAttrSet(imgGroup[25], 0, HUSPR_ATTR_DISPOFF);
HuSprAttrSet(imgGroup[25], 0, HUSPR_ATTR_DISPOFF);
while (TRUE) {
HuPrcVSleep();
}
}
static void MainProc(void)
{
s32 var_r31;
UnkStaffDllStruct *var_r30;
s32 var_r29;
Process *var_r28;
s32 var_r27;
float var_f29;
float var_f30;
float var_f31;
HuPrcSleep(60);
var_r27 = HuAudSStreamPlay(22);
for (var_r31 = 0;; var_r31++) {
var_r30 = &staffData[var_r31];
if (var_r30->unk_00 == -1) {
break;
}
switch (var_r30->unk_00) {
case -3:
HuPrcSleep(var_r30->unk_08 / 0.4f);
break;
default:
var_r28 = HuPrcChildCreate(MoveStaff, 0x1000, 0x2000, 0, HuPrcCurrentGet());
var_r28->user_data = var_r30;
if (var_r30->unk_0C == 1) {
staffSide++;
staffSide &= 1;
HuPrcChildCreate(HidePicture, 0x1000, 0x2000, 0, HuPrcCurrentGet());
} else {
HuPrcSleep(60);
}
break;
}
}
var_r30 = &staffData[var_r31 - 1];
while (var_r30->unk_14 == 0) {
HuPrcVSleep();
}
HuPrcSleep(60);
HuSprAttrReset(staffLogoGroup[1], 0, HUSPR_ATTR_DISPOFF);
var_f29 = staffLogoPosTbl[1];
var_f30 = 526.0f;
var_r29 = 0;
while (TRUE) {
var_f30 -= 0.4f;
if (var_f30 < 400.0f) {
break;
}
if ((var_r29 == 0) && (var_f30 < 506.0f)) {
var_r29 = 1;
HuAudSStreamFadeOut(var_r27, 6000);
}
HuSprGrpPosSet(staffLogoGroup[1], var_f29, var_f30);
HuPrcVSleep();
}
HuSprGrpPosSet(staffLogoGroup[1], var_f29, 400.0f);
HuPrcSleep(240);
HuSprAttrReset(thpGroup, 0, HUSPR_ATTR_DISPOFF);
HuSprAttrReset(thpCoverGroup, 0, HUSPR_ATTR_DISPOFF);
HuTHPRestart();
for (var_r31 = 0, var_f31 = 1.0f; var_r31 < 90; var_r31++, var_f31 -= 0.1f / 9.0f) {
HuSprTPLvlSet(thpCoverGroup, 0, var_f31);
HuPrcVSleep();
}
HuSprAttrSet(thpCoverGroup, 0, HUSPR_ATTR_DISPOFF);
while (HuTHPFrameGet() < 450) {
HuPrcVSleep();
}
HuSprAttrReset(thpCoverGroup, 0, HUSPR_ATTR_DISPOFF);
for (var_r31 = 0, var_f31 = 0.0f; var_r31 < 120; var_r31++, var_f31 += 0.05f / 6.0f) {
HuSprTPLvlSet(thpCoverGroup, 0, var_f31);
HuPrcVSleep();
}
HuSprTPLvlSet(thpCoverGroup, 0, 1.0f);
HuSprAttrSet(thpGroup, 0, HUSPR_ATTR_DISPOFF);
HuTHPClose();
for (var_r31 = 0, var_f31 = 1.0f; var_r31 < 30; var_r31++, var_f31 -= 1.0f / 30.0f) {
HuSprTPLvlSet(staffLogoGroup[1], 0, var_f31);
HuPrcVSleep();
}
HuSprAttrSet(staffLogoGroup[1], 0, HUSPR_ATTR_DISPOFF);
HuPrcSleep(120);
HuSprAttrReset(staffLogoGroup[2], 0, HUSPR_ATTR_DISPOFF);
HuSprGrpPosSet(staffLogoGroup[2], 280.0f, 240.0f);
for (var_r31 = 0, var_f31 = 0.0f; var_r31 < 30; var_r31++, var_f31 += 1.0f / 30.0f) {
HuSprTPLvlSet(staffLogoGroup[2], 0, var_f31);
HuPrcVSleep();
}
HuPrcSleep(600);
while (TRUE) {
for (var_r31 = 0; var_r31 < 4; var_r31++) {
if (HuPadBtn[var_r31] & PAD_BUTTON_START) {
break;
}
}
if (var_r31 < 4) {
break;
}
HuPrcVSleep();
}
WipeCreate(WIPE_MODE_OUT, WIPE_TYPE_NORMAL, 60);
HuAudFadeOut(1000);
HuPrcSleep(60);
MGSeqKillAll();
omOvlReturnEx(1, 1);
while (TRUE) {
HuPrcVSleep();
}
}

View file

@ -1114,7 +1114,7 @@ static void fn_1_3624(void) {
}
temp_r19 = HuAudFXPlay(0x40C);
fn_1_4774();
WipeCreate(1, 0, -1);
WipeCreate(WIPE_MODE_IN, WIPE_TYPE_NORMAL, -1);
lbl_1_bss_6B0 = 1;
HuAudFXPlay(0x413);
while (TRUE) {
@ -1163,7 +1163,7 @@ static void fn_1_3624(void) {
lbl_1_bss_660.x = lbl_1_bss_660.z = 0.0f;
BoardAudSeqFadeOut(1, 1000);
WipeColorSet(0, 0, 0);
WipeCreate(2, 0, -1);
WipeCreate(WIPE_MODE_OUT, WIPE_TYPE_NORMAL, -1);
HuAudFXPlay(0x401);
temp_f28 = (-lbl_1_bss_63C - lbl_1_bss_660.y) / 30.0f;
for (i = 0; i < 30; i++) {
@ -1213,7 +1213,7 @@ static void fn_1_45F4(void) {
BoardAudSeqPause(0, 0, 1000);
BoardCameraMoveSet(1);
BoardCameraMotionWait();
WipeCreate(1, 0, 21);
WipeCreate(WIPE_MODE_IN, WIPE_TYPE_NORMAL, 21);
while (WipeStatGet() != 0) {
HuPrcVSleep();
}
@ -1316,7 +1316,7 @@ static s32 fn_1_48B4(void) {
HuAudFXPlay(0x402);
BoardStatusShowSetAll(0);
WipeColorSet(0, 0, 0);
WipeCreate(2, 0, 21);
WipeCreate(WIPE_MODE_OUT, WIPE_TYPE_NORMAL, 21);
while (WipeStatGet() != 0) {
HuPrcVSleep();
}
@ -1930,7 +1930,7 @@ static void fn_1_77EC(s32 arg0, s32 arg1) {
static void fn_1_7894(void) {
lbl_1_bss_6B1 = 1;
WipeColorSet(0, 0, 0);
WipeCreate(2, 0, 21);
WipeCreate(WIPE_MODE_OUT, WIPE_TYPE_NORMAL, 21);
while (WipeStatGet() != 0) {
HuPrcVSleep();
}
@ -1987,7 +1987,7 @@ static void fn_1_7A64(void) {
fn_1_852C();
BoardModelMotionSpeedSet(lbl_1_bss_6AE, lbl_1_bss_670);
BoardCameraMotionWait();
WipeCreate(1, 0, -1);
WipeCreate(WIPE_MODE_IN, WIPE_TYPE_NORMAL, -1);
lbl_1_bss_6B0 = 1;
temp_r19 = HuAudFXPlay(0x412);
while (TRUE) {
@ -2005,13 +2005,13 @@ static void fn_1_7A64(void) {
if (lbl_1_bss_0->unk00_field0 == 0) {
if (BoardModelMotionTimeGet(lbl_1_bss_6AE) <= 20.0f && var_r28 == 0) {
WipeColorSet(0, 0, 0);
WipeCreate(2, 0, -1);
WipeCreate(WIPE_MODE_OUT, WIPE_TYPE_NORMAL, -1);
var_r28 = 1;
}
} else {
if (BoardModelMotionTimeGet(lbl_1_bss_6AE) >= lbl_1_bss_644 - 20.0f && var_r28 == 0) {
WipeColorSet(0, 0, 0);
WipeCreate(2, 0, -1);
WipeCreate(WIPE_MODE_OUT, WIPE_TYPE_NORMAL, -1);
var_r28 = 1;
}
}

View file

@ -301,7 +301,7 @@ static void fn_1_68D8(void) {
HuPrcVSleep();
}
BoardModelAlphaSet(lbl_1_bss_274, 0);
WipeCreate(2, 0, 60);
WipeCreate(WIPE_MODE_OUT, WIPE_TYPE_NORMAL, 60);
WipeColorSet(0, 0, 0);
while (WipeStatGet() != 0) {
HuPrcVSleep();
@ -384,7 +384,7 @@ static void fn_1_6CF8(void) {
BoardCameraXRotZoomSet(1600.0f, -5.0f);
lbl_1_bss_104 = HuPrcChildCreate(fn_1_75D8, 0x2003, 0x1000, 0, boardMainProc);
HuPrcDestructorSet2(lbl_1_bss_104, fn_1_757C);
WipeCreate(1, 0, 60);
WipeCreate(WIPE_MODE_IN, WIPE_TYPE_NORMAL, 60);
while (WipeStatGet() != 0) {
HuPrcVSleep();
}
@ -417,7 +417,7 @@ static void fn_1_7300(void) {
s32 i;
s32 j;
WipeCreate(2, 0, 30);
WipeCreate(WIPE_MODE_OUT, WIPE_TYPE_NORMAL, 30);
while (WipeStatGet() != 0) {
HuPrcVSleep();
}
@ -453,7 +453,7 @@ static void fn_1_7300(void) {
sp8.x = sp8.y = sp8.z = 3.0f;
BoardModelScaleSetV(lbl_1_bss_274, &sp8);
BoardModelPosSetV(lbl_1_bss_274, &lbl_1_bss_108);
WipeCreate(1, 0, 30);
WipeCreate(WIPE_MODE_IN, WIPE_TYPE_NORMAL, 30);
while (WipeStatGet() != 0) {
HuPrcVSleep();
}

View file

@ -317,7 +317,7 @@ static void fn_1_95AC(s32 arg0) {
HuPrcVSleep();
}
WipeColorSet(0xFF, 0xFF, 0xFF);
WipeCreate(2, 1, 1);
WipeCreate(WIPE_MODE_OUT, WIPE_TYPE_CROSS, 1);
HuPrcSleep(2);
BoardCameraMoveSet(0);
BoardModelVisibilitySet(BoardPlayerModelGet(arg0), 0);
@ -334,7 +334,7 @@ static void fn_1_95AC(s32 arg0) {
sp38.z = sp2C.z;
BoardPlayerPosSetV(arg0, &sp38);
BoardModelVisibilitySet(BoardPlayerModelGet(arg0), 1);
WipeCreate(1, 1, 30);
WipeCreate(WIPE_MODE_IN, WIPE_TYPE_CROSS, 30);
while (WipeStatGet() != 0) {
HuPrcVSleep();
}
@ -553,7 +553,7 @@ static void fn_1_A408(s32 arg0) {
_SetFlag(FLAG_ID_MAKE(1, 28));
_SetFlag(FLAG_ID_MAKE(1, 14));
WipeColorSet(0xFF, 0xFF, 0xFF);
WipeCreate(2, 0, -1);
WipeCreate(WIPE_MODE_OUT, WIPE_TYPE_NORMAL, -1);
while (WipeStatGet() != 0) {
HuPrcVSleep();
}
@ -669,7 +669,7 @@ static void fn_1_AB4C(s32 arg0, s32 arg1) {
BoardCameraMotionStartEx(lbl_1_data_49A, &spC, &sp18, 2000.0f, -1.0f, 2);
BoardCameraMotionWait();
BoardCameraTargetModelSet(-1);
WipeCreate(1, 0, 21);
WipeCreate(WIPE_MODE_IN, WIPE_TYPE_NORMAL, 21);
while (WipeStatGet() != 0) {
HuPrcVSleep();
}
@ -1048,7 +1048,7 @@ static void fn_1_C40C(void) {
sp20.y += 250.0f;
BoardModelPosSetV(lbl_1_data_4A0, &sp20);
BoardModelScaleSet(lbl_1_data_4A0, 10.0f, 10.0f, 10.0f);
WipeCreate(1, 0, 21);
WipeCreate(WIPE_MODE_IN, WIPE_TYPE_NORMAL, 21);
while (WipeStatGet() != 0) {
HuPrcVSleep();
}
@ -1083,7 +1083,7 @@ static void fn_1_C40C(void) {
BoardWinKill();
BoardAudSeqFadeOut(1, 1000);
WipeColorSet(0, 0, 0);
WipeCreate(2, 0, 21);
WipeCreate(WIPE_MODE_OUT, WIPE_TYPE_NORMAL, 21);
while (WipeStatGet() != 0) {
HuPrcVSleep();
}

154
src/REL/w20Dll/main.c Normal file
View file

@ -0,0 +1,154 @@
#include "game/board/model.h"
#include "game/data.h"
#include "game/gamework_data.h"
#include "math.h"
#include "REL/w20Dll.h"
s16 lbl_1_bss_C;
s32 lbl_1_bss_8;
s32 lbl_1_bss_4;
UnkW20BoardData *lbl_1_bss_0;
s16 lbl_1_data_0 = 0xFFFF;
s16 lbl_1_data_2 = 0xFFFF;
s16 lbl_1_data_4 = 0xFFFF;
s16 lbl_1_data_6 = 0xFFFF;
s16 lbl_1_data_8 = 0xFFFF;
s16 lbl_1_data_A = 0xFFFF;
s32 lbl_1_data_C[] = {
0x005F0000,
0x001A0000,
0x006D0000,
0x008A0000,
0x00850000,
0x00110000,
0x000D0000,
0x00810000,
};
s32 unkMotTbl[] = { DATA_MAKE_NUM(DATADIR_BGUEST, 42), -1 };
void fn_1_44C(void);
void fn_1_490(void);
void fn_1_494(void);
s32 fn_1_498(void);
void fn_1_4A0(void);
void fn_1_4A4(void);
void fn_1_4A8(void);
s32 fn_1_4AC(s16 arg0, float arg8, float arg9);
void BoardCreate(void)
{
s32 sp8;
s32 var_r31;
var_r31 = GWSystem.board;
sp8 = var_r31;
lbl_1_bss_0 = (UnkW20BoardData *)GWSystem.board_data;
lbl_1_bss_0->unk_00 = 0;
lbl_1_bss_0->unk_04 = 0;
lbl_1_bss_0->unk_06 = 0;
BoardSpaceInit(DATA_MAKE_NUM(DATADIR_W20, 0));
lbl_1_data_0 = BoardModelCreate(0x7C0001, NULL, 0);
fn_8006DDE8(lbl_1_data_0, -1.0f);
BoardModelPosSet(lbl_1_data_0, 0.0f, 0.0f, 0.0f);
BoardModelMotionStart(lbl_1_data_0, 0, 0x40000001);
BoardModelMotionSpeedSet(lbl_1_data_0, 1.0f);
lbl_1_data_2 = BoardModelCreate(0x7C0002, NULL, 0);
fn_8006DDE8(lbl_1_data_2, -1.0f);
BoardModelPosSet(lbl_1_data_2, 0.0f, 0.0f, 0.0f);
BoardModelMotionStart(lbl_1_data_2, 0, 0x40000001);
lbl_1_data_6 = BoardModelCreate(0x20029, unkMotTbl, 0);
BoardModelMotionStart(lbl_1_data_6, 1, 0x40000001);
lbl_1_data_8 = BoardModelCreate(0x20029, unkMotTbl, 0);
BoardModelMotionStart(lbl_1_data_8, 1, 0x40000001);
BoardLightHookSet(fn_1_44C, fn_1_490);
BoardSpaceWalkEventFuncSet(fn_1_498);
BoardSpaceWalkMiniEventFuncSet(fn_1_4A8);
BoardSpaceLandEventFuncSet(fn_1_494);
BoardShopHostSet(lbl_1_data_6);
BoardLotteryHostSet(lbl_1_data_8);
BoardStarHostSet(lbl_1_data_6);
}
void BoardDestroy(void)
{
if (lbl_1_data_6 != -1) {
BoardModelKill(lbl_1_data_6);
lbl_1_data_6 = -1;
}
if (lbl_1_data_0 != -1) {
BoardModelKill(lbl_1_data_0);
lbl_1_data_0 = -1;
}
if (lbl_1_data_2 != -1) {
BoardModelKill(lbl_1_data_2);
lbl_1_data_2 = -1;
}
BoardSpaceDestroy();
}
void fn_1_44C(void)
{
s16 var_r31;
var_r31 = BoardModelIDGet(lbl_1_data_0);
Hu3DModelLightInfoSet(var_r31, 1);
}
void fn_1_490(void) { }
void fn_1_494(void) { }
s32 fn_1_498(void) { return 0; }
void fn_1_4A0(void) { }
void fn_1_4A4(void) { }
void fn_1_4A8(void) { }
s32 fn_1_4AC(s16 arg0, float arg8, float arg9)
{
float var_f29;
float var_f31;
s32 var_r31;
var_r31 = 0;
var_f31 = BoardModelRotYGet(arg0);
arg8 = fmod(arg8, 360.0f);
if (var_f31 < 0.0f) {
var_f31 += 360.0f;
}
if (arg8 < 0.0f) {
arg8 += 360.0f;
}
if (var_f31 != arg8) {
var_f29 = arg8 - var_f31;
if (var_f29 < 0.0f) {
var_f29 += 360.0f;
}
if (var_f29 < 180.0f) {
if (var_f29 > arg9) {
var_f31 += arg9;
} else {
var_f31 = arg8;
}
} else if ((360.0f - var_f29) > arg9) {
var_f31 -= arg9;
} else {
var_f31 = arg8;
}
if (var_f31 < 0.0f) {
var_f31 += 360.0f;
}
if (var_f31 >= 360.0f) {
var_f31 -= 360.0f;
}
BoardModelRotYSet(arg0, var_f31);
} else {
var_r31 = 1;
}
return var_r31;
}