227 lines
7.0 KiB
C
227 lines
7.0 KiB
C
#include <ultra64.h>
|
|
#include "functions.h"
|
|
#include "variables.h"
|
|
|
|
extern bool func_8028F170(f32, f32);
|
|
extern void viewport_getPosition_vec3f(f32[3]);
|
|
|
|
typedef struct {
|
|
f32 unk0;
|
|
s32 unk4[4];
|
|
f32 unk14;
|
|
}Struct_core2_C97F0_2;
|
|
|
|
typedef struct {
|
|
u8 unk0;
|
|
// u8 pad1[3];
|
|
Struct_core2_C97F0_2 unk4[15];
|
|
}Struct_core2_C97F0_1;
|
|
|
|
typedef struct {
|
|
s16 unk0;
|
|
f32 unk4[3];
|
|
u8 unk10;
|
|
}Struct_core2_C97F0_0;
|
|
|
|
/* .data */
|
|
Struct_core2_C97F0_1 D_803720B0[] = {
|
|
{1, {
|
|
{0.01f, {0xFF, 0xFF, 0xFF, 0x80}, 1.0f,},
|
|
{0.25f, {0xFF, 0x00, 0x00, 0x80}, 0.75f},
|
|
{0.5f, {0x00, 0xFF, 0x00, 0x80}, 0.5f},
|
|
{0.75f, {0x00, 0x00, 0xFF, 0x80}, 0.25f},
|
|
{1.0f, {0xFF, 0x00, 0xFF, 0x80}, 0.1f},
|
|
0
|
|
}},
|
|
{0, {
|
|
{0.15f, {0xFF, 0xFF, 0xFF, 0x80}, 0.2f},
|
|
{0.25f, {0xDC, 0xD2, 0xDC, 0xD2}, 0.35f},
|
|
{0.32f, {0xFF, 0xFF, 0xFF, 0x5A}, 0.7f},
|
|
{0.45f, {0xD2, 0xFF, 0xD7, 0x78}, 0.3f},
|
|
{0.56f, {0xC8, 0xFF, 0xFF, 0x96}, 0.9f},
|
|
{0.69f, {0xFF, 0xD2, 0xFF, 0x6E}, 0.45f},
|
|
{0.78f, {0xDC, 0xFF, 0xFF, 0x73}, 0.28f},
|
|
{0.84f, {0xFF, 0xE6, 0xFF, 0xC8}, 0.55f},
|
|
{1.05f, {0xC8, 0xFF, 0xFF, 0x64}, 0.4f},
|
|
{1.15f, {0xFF, 0xC8, 0xFF, 0x96}, 0.22f},
|
|
0
|
|
}},
|
|
{2, {
|
|
{0.15f, {0xFF, 0x00, 0x00, 0xC8}, 0.2f},
|
|
{0.25f, {0xDC, 0xD2, 0xDC, 0xD2}, 0.35f},
|
|
{0.32f, {0xFF, 0xFF, 0xFF, 0xA0}, 0.7f},
|
|
{0.45f, {0xD2, 0xF0, 0xBE, 0xDC}, 0.3f},
|
|
{0.56f, {0xC8, 0xFF, 0xFF, 0xBE}, 0.9f},
|
|
{0.69f, {0xFF, 0xD2, 0xFF, 0xA0}, 0.45f},
|
|
{0.78f, {0xDC, 0xFF, 0xFF, 0x8C}, 0.28f},
|
|
{0.84f, {0xFF, 0xE6, 0xFF, 0xFF}, 0.55f},
|
|
{1.05f, {0xC8, 0xFF, 0xFF, 0xBE}, 0.4f},
|
|
{1.15f, {0xFF, 0xC8, 0xFF, 0x96}, 0.22f},
|
|
0
|
|
}}
|
|
};
|
|
|
|
Struct_core2_C97F0_0 D_803724F4[] = {
|
|
{0x95, { 48.0f, 10.0f, -51.0f}, 0},
|
|
{0x20, { 48.0f, 10.0f, -51.0f}, 0},
|
|
{0x96, { 48.0f, 10.0f, -51.0f}, 0},
|
|
{0x97, { 48.0f, 10.0f, -51.0f}, 0},
|
|
{0x07, { 52.0f, 24.0f, -21.0f}, 0},
|
|
{0x12, {-358.74f, 90.8f, 306.8f}, 0},
|
|
{0x1F, { -61.8f, -3.64f, -42.921f}, 2},
|
|
{0x04, { 0.0f, 24.0f, -21.0f}, 1},
|
|
0
|
|
};
|
|
|
|
s32 D_803725A8[4] = {0, 0, 0, 0};
|
|
|
|
/* .bss */
|
|
struct{
|
|
Struct_core2_C97F0_1 *unk0;
|
|
Struct_core2_C97F0_0 *unk4;
|
|
void *unk8;
|
|
} D_80386170;
|
|
struct {
|
|
u8 unk0;
|
|
u8 unk1;
|
|
}D_8038617C;
|
|
|
|
/* .code */
|
|
Struct_core2_C97F0_1 *func_80350780(s32 arg0) {
|
|
Struct_core2_C97F0_1 *i_ptr;
|
|
|
|
for(i_ptr = D_803720B0; i_ptr->unk0 != 0; i_ptr++){
|
|
if(arg0 == i_ptr->unk0){
|
|
return i_ptr;
|
|
}
|
|
}
|
|
return i_ptr;
|
|
}
|
|
|
|
Struct_core2_C97F0_0 *func_803507CC(enum map_e map_id) {
|
|
Struct_core2_C97F0_0 *i_ptr;
|
|
|
|
for(i_ptr = D_803724F4; i_ptr->unk0 != 0; i_ptr++){
|
|
if(map_id == i_ptr->unk0){
|
|
return i_ptr;
|
|
}
|
|
}
|
|
return NULL;
|
|
}
|
|
|
|
void func_80350818(Gfx **gfx, Mtx **mtx, Vtx **vtx) {
|
|
f32 spDC[3];
|
|
f32 spD0[3];
|
|
f32 spC4[3];
|
|
f32 spB8[3];
|
|
Struct_core2_C97F0_0 *temp_s1;
|
|
Struct_core2_C97F0_1 *temp_s2;
|
|
f32 var_f22;
|
|
s32 i;
|
|
f32 sp9C[3];
|
|
f32 sp90[3];
|
|
s32 sp80[4];
|
|
|
|
temp_s2 = D_80386170.unk0;
|
|
if(temp_s2 != NULL){
|
|
|
|
}
|
|
|
|
temp_s1 = D_80386170.unk4;
|
|
if (( temp_s1 != NULL) && D_8038617C.unk0) {
|
|
viewport_getPosition_vec3f(spDC);
|
|
viewport_getRotation_vec3f(spD0);
|
|
sp9C[0] = temp_s1->unk4[0];
|
|
sp9C[1] = temp_s1->unk4[1];
|
|
sp9C[2] = temp_s1->unk4[2];
|
|
ml_vec3f_yaw_rotate_copy(sp9C, sp9C, -spD0[1]);
|
|
ml_vec3f_pitch_rotate_copy(sp9C, sp9C, -spD0[0]);
|
|
if (!(((1.2 * (f32)framebuffer_width) / 2) < sp9C[0]) && !(sp9C[0] < ((-1.2 * (f32)framebuffer_width) / 2))) {
|
|
if (!(((1.2 * (f32)framebuffer_height) / 2) < sp9C[1]) && !(sp9C[1] < ((-1.2 * (f32)framebuffer_height) / 2))) {
|
|
sp90[0] = -sp9C[0];
|
|
sp90[1] = -sp9C[1];
|
|
sp90[2] = sp9C[2];
|
|
ml_vec3f_pitch_rotate_copy(sp90, sp90, spD0[0]);
|
|
ml_vec3f_yaw_rotate_copy(sp90, sp90, spD0[1]);
|
|
var_f22 = 1.0f - (((sp9C[0] * sp9C[0]) + (sp9C[1] * sp9C[1])) / ((f32)framebuffer_height * (f32)framebuffer_height));
|
|
if (var_f22 < 0.0f) {
|
|
var_f22 = 0.0f;
|
|
}
|
|
if (var_f22 > 1.0f) {
|
|
var_f22 = 1.0f;
|
|
}
|
|
spC4[0] = sp90[0] - temp_s1->unk4[0];
|
|
spC4[1] = sp90[1] - temp_s1->unk4[1];
|
|
spC4[2] = sp90[2] - temp_s1->unk4[2];
|
|
for(i = 0; temp_s2->unk4[i].unk0 != 0.0f; i++){
|
|
spB8[0] = (spDC[0] + temp_s1->unk4[0]) + (temp_s2->unk4[i].unk0 * spC4[0]);
|
|
spB8[1] = (spDC[1] + temp_s1->unk4[1]) + (temp_s2->unk4[i].unk0 * spC4[1]);
|
|
spB8[2] = (spDC[2] + temp_s1->unk4[2]) + (temp_s2->unk4[i].unk0 * spC4[2]);
|
|
sp80[0] = temp_s2->unk4[i].unk4[0];
|
|
sp80[1] = temp_s2->unk4[i].unk4[1];
|
|
sp80[2] = temp_s2->unk4[i].unk4[2];
|
|
sp80[3] = temp_s2->unk4[i].unk4[3];
|
|
sp80[3] *= var_f22;
|
|
modelRender_setPrimAndEnvColors(sp80, D_803725A8);
|
|
modelRender_draw(gfx, mtx, spB8, spD0, temp_s2->unk4[i].unk14*0.25, NULL, D_80386170.unk8);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
void func_80350BC8(void){
|
|
if(D_80386170.unk4 != NULL){
|
|
assetcache_release(D_80386170.unk8);
|
|
}
|
|
}
|
|
|
|
void func_80350BFC(void) {
|
|
D_80386170.unk4 = func_803507CC(map_get());
|
|
if (D_80386170.unk4 != NULL) {
|
|
D_80386170.unk0 = func_80350780(D_80386170.unk4->unk10);
|
|
D_80386170.unk8 = assetcache_get(0x882);
|
|
ml_vec3f_set_length(D_80386170.unk4->unk4, (2*(f32)framebuffer_width) / 2);
|
|
D_8038617C.unk0 = 1;
|
|
D_8038617C.unk1 = 0;
|
|
}
|
|
}
|
|
|
|
void func_80350CA4(void) {
|
|
f32 sp54[3];
|
|
f32 sp48[3];
|
|
f32 sp3C[3];
|
|
f32 sp30[3];
|
|
f32 sp24[3];
|
|
s32 var_v0;
|
|
|
|
if (D_80386170.unk4 != NULL) {
|
|
viewport_getPosition_vec3f(sp54);
|
|
sp48[0] = D_80386170.unk4->unk4[0];
|
|
sp48[1] = D_80386170.unk4->unk4[1];
|
|
sp48[2] = D_80386170.unk4->unk4[2];
|
|
ml_vec3f_set_length(sp48, 1000.0f);
|
|
sp30[0] = sp54[0] + (sp48[0] * D_8038617C.unk1);
|
|
sp30[1] = sp54[1] + (sp48[1] * D_8038617C.unk1);
|
|
sp30[2] = sp54[2] + (sp48[2] * D_8038617C.unk1);
|
|
sp24[0] = sp30[0] + sp48[0];
|
|
sp24[1] = sp30[1] + sp48[1];
|
|
sp24[2] = sp30[2] + sp48[2];
|
|
if (func_8028F170(sp48[1], sp48[2])) {
|
|
var_v0 = func_80320B98(&sp30, &sp24, &sp3C, 0x01000000);
|
|
} else {
|
|
var_v0 = func_80309B48(&sp30, &sp24, &sp3C, 0x01000000);
|
|
}
|
|
if (var_v0 != 0) {
|
|
D_8038617C.unk0 = 0;
|
|
D_8038617C.unk1 = 0;
|
|
} else {
|
|
D_8038617C.unk1++;
|
|
if (D_8038617C.unk1 >= 0xB) {
|
|
D_8038617C.unk0 = 1;
|
|
D_8038617C.unk1 = 0;
|
|
}
|
|
}
|
|
}
|
|
}
|