Files
banjo-kazooie/src/core2/code_C97F0.c
2024-09-10 00:17:16 +02:00

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;
}
}
}
}