tp/src/d/d_kankyo.cpp

7190 lines
263 KiB
C++

#include "d/d_kankyo.h"
#include <dolphin.h>
#include <dolphin/gf/GFPixel.h>
#include "SSystem/SComponent/c_counter.h"
#include "SSystem/SComponent/c_math.h"
#include "d/actor/d_a_kytag08.h"
#include "d/actor/d_a_player.h"
#include "d/d_kankyo_rain.h"
#include "d/d_kankyo_static.h"
#include "d/d_meter2_info.h"
#include "d/d_msg_object.h"
#include "f_op/f_op_kankyo.h"
#include "m_Do/m_Do_graphic.h"
#include "m_Do/m_Do_lib.h"
static void GxXFog_set();
struct sub_kankyo__class : public kankyo_class {};
// setSunpos calls these functions as inlines somehow
// these need to be moved to MSL_C once an appropriate solution is found
inline float sinf(float x) {
return sin(x);
}
inline float cosf(float x) {
return cos(x);
}
/* 8019C388-8019C3A4 196CC8 001C+00 2/2 0/0 0/0 .text dKy_WolfPowerup_AmbCol__FP11_GXColorS10 */
void dKy_WolfPowerup_AmbCol(GXColorS10* in_col_p) {
JUT_ASSERT(185, in_col_p != 0);
in_col_p->r = 40;
in_col_p->g = 52;
in_col_p->b = 49;
}
/* 8019C3A4-8019CB0C 196CE4 0768+00 2/2 0/0 0/0 .text dKy_sense_pat_get__Fv */
int dKy_sense_pat_get() {
int pat = 0;
if (dKy_Outdoor_check()) {
pat = 1;
} else {
pat = 5;
}
// Stage is Lake Hylia
if (!strcmp(dComIfGp_getStartStageName(), "F_SP115")) {
pat = 9;
// Room is Lake
if (dComIfGp_roomControl_getStayNo() == 0 && dComIfGs_isSaveSwitch(17) &&
!dComIfGs_isSaveSwitch(0x75))
{
pat = 2;
}
if (dComIfGs_sense_type_change_Get() > 0) {
pat = 13;
}
}
// Stage is Zora's Domain
else if (!strcmp(dComIfGp_getStartStageName(), "F_SP113"))
{
if (dComIfGs_sense_type_change_Get() > 0) {
pat = 13;
} else {
pat = 1;
}
}
// Stage is Faron Woods Cave
else if (!strcmp(dComIfGp_getStartStageName(), "D_SB10"))
{
pat = 1;
}
// Stage is Zora's River
else if (!strcmp(dComIfGp_getStartStageName(), "F_SP112"))
{
pat = 3;
}
// Stage is Upper Zora's River
else if (!strcmp(dComIfGp_getStartStageName(), "F_SP126"))
{
pat = 6;
}
// Stage is Snowpeak
else if (!strcmp(dComIfGp_getStartStageName(), "F_SP114"))
{
pat = 4;
}
// Stage is Forest Temple or Goron Mines or Goron Stockcave or Grotto
else if (!memcmp(dComIfGp_getStartStageName(), "D_MN05", 6) ||
!memcmp(dComIfGp_getStartStageName(), "D_MN04", 6) ||
!memcmp(dComIfGp_getStartStageName(), "D_SB04", 6) ||
!memcmp(dComIfGp_getStartStageName(), "D_SB05", 6) ||
!memcmp(dComIfGp_getStartStageName(), "D_SB06", 6) ||
!memcmp(dComIfGp_getStartStageName(), "D_SB07", 6) ||
!memcmp(dComIfGp_getStartStageName(), "D_SB08", 6) ||
!memcmp(dComIfGp_getStartStageName(), "D_SB09", 6))
{
pat = 5;
}
// Stage is Stallord arena or Argorok arena
else if (!strcmp(dComIfGp_getStartStageName(), "D_MN10A") ||
!strcmp(dComIfGp_getStartStageName(), "D_MN07A"))
{
pat = 14;
}
// Stage is Death Sword arena
else if (!strcmp(dComIfGp_getStartStageName(), "D_MN10B"))
{
pat = 15;
}
// Stage is Arbiter's Grounds
else if (!strcmp(dComIfGp_getStartStageName(), "D_MN10"))
{
pat = 8;
// Room is Central Poe room
if (dComIfGp_roomControl_getStayNo() == 2) {
pat = 14;
// Room is 2nd Poe room or 4th Poe room
} else if (dComIfGp_roomControl_getStayNo() == 3 || dComIfGp_roomControl_getStayNo() == 8) {
pat = 6;
}
}
// Stage is Blizzeta arena
else if (!strcmp(dComIfGp_getStartStageName(), "D_MN11A"))
{
pat = 4;
}
// Stage is Snowpeak Ruins or Darkhammer or Ice Puzzle cave
else if (!strcmp(dComIfGp_getStartStageName(), "D_MN11") ||
!strcmp(dComIfGp_getStartStageName(), "D_MN11B") ||
!memcmp(dComIfGp_getStartStageName(), "D_SB00", 6))
{
pat = 7;
// Stage is Snowpeak Ruins and Room is Courtyard
if (!strcmp(dComIfGp_getStartStageName(), "D_MN11") &&
dComIfGp_roomControl_getStayNo() == 4)
{
pat = 4;
}
}
// Stage is Ganondorf Field or Ganondorf Defeated or Castle Town
else if (!strcmp(dComIfGp_getStartStageName(), "D_MN09B") ||
!strcmp(dComIfGp_getStartStageName(), "D_MN09C") ||
!strcmp(dComIfGp_getStartStageName(), "F_SP116"))
{
pat = 1;
}
// Stage is Temple of Time or City in the Sky or Hyrule Castle Throne Room or
// Cave of Ordeals or Cloud Sea or Hyrule Castle cutscenes or Lakebed Temple or Deku Toad
else if (!memcmp(dComIfGp_getStartStageName(), "D_MN06", 6) ||
!strcmp(dComIfGp_getStartStageName(), "D_MN07") ||
!strcmp(dComIfGp_getStartStageName(), "D_MN09A") ||
!memcmp(dComIfGp_getStartStageName(), "D_SB01", 6) ||
!strcmp(dComIfGp_getStartStageName(), "R_SP300") ||
!strcmp(dComIfGp_getStartStageName(), "R_SP301") ||
!strcmp(dComIfGp_getStartStageName(), "D_MN01") ||
!strcmp(dComIfGp_getStartStageName(), "D_MN01B"))
{
pat = 8;
}
// Stage is Morpheel arena
else if (!strcmp(dComIfGp_getStartStageName(), "D_MN01A"))
{
pat = 14;
}
// Stage is Palace of Twilight
else if (!memcmp(dComIfGp_getStartStageName(), "D_MN08", 6))
{
pat = 9;
}
// Stage is Gorge Cave or Lake Hylia Cave
else if (!memcmp(dComIfGp_getStartStageName(), "D_SB02", 6) ||
!memcmp(dComIfGp_getStartStageName(), "D_SB03", 6))
{
pat = 10;
}
// Stage is Ordon Village Interiors or Faron Woods Interiors or
// Kakariko Graveyard or Telma's Bar or STAR game or Death Mountain or
// Hyrule Castle sewers
else if (!strcmp(dComIfGp_getStartStageName(), "R_SP01") ||
!strcmp(dComIfGp_getStartStageName(), "R_SP108") ||
!strcmp(dComIfGp_getStartStageName(), "R_SP209") ||
!strcmp(dComIfGp_getStartStageName(), "R_SP116") ||
!strcmp(dComIfGp_getStartStageName(), "R_SP161") ||
!strcmp(dComIfGp_getStartStageName(), "F_SP110") ||
!strcmp(dComIfGp_getStartStageName(), "R_SP107"))
{
pat = 11;
// Stage is Ordon Village and Room is Sera's Shop
if (!strcmp(dComIfGp_getStartStageName(), "R_SP01") &&
dComIfGp_roomControl_getStayNo() == 1)
{
pat = 12;
}
}
// Stage is Hidden Village interiors or Castle Town interiors or Fishing Pond interiors
else if (!strcmp(dComIfGp_getStartStageName(), "R_SP128") ||
!strcmp(dComIfGp_getStartStageName(), "R_SP160") ||
!strcmp(dComIfGp_getStartStageName(), "R_SP127"))
{
pat = 12;
}
// Stage is Kakariko Village interiors
else if (!strcmp(dComIfGp_getStartStageName(), "R_SP109"))
{
pat = 12;
// Room is Sanctuary or Inn
if (dComIfGp_roomControl_getStayNo() == 0 || dComIfGp_roomControl_getStayNo() == 2) {
pat = 11;
}
}
return pat;
}
/* 803BBDB8-803BBDC4 018ED8 000C+00 1/1 0/0 0/0 .data cNullVec__6Z2Calc */
static u8 cNullVec__6Z2Calc[12] = {
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
};
/* 803BBDC4-803BBEAC 018EE4 00E8+00 1/1 0/0 0/0 .data lightStatusBase */
static LightStatus lightStatusBase = {
{-36384.5f, 29096.699f, 17422.199f},
{377.0f, 5207.3999f, 1220.4f},
{0xFF, 0xFF, 0xFF, 0xFF},
0,
1.0f,
0.0f,
0.0f,
1.0f,
0.0f,
0.0f,
{0.0f, -1.0f, -1.0f},
90.0f,
GX_SP_OFF,
500.0f,
1.0f,
GX_DA_OFF,
{
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
},
320.0f,
-320.0f,
1000.0f,
160000.0f,
{
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
},
0.536479f,
2.726476f,
0.0f,
0.5f,
};
/* 803BBEAC-803BBEBC 018FCC 0010+00 4/4 0/0 0/0 .data lightMaskData */
static u16 lightMaskData[8] = {
GX_LIGHT0, GX_LIGHT1, GX_LIGHT2, GX_LIGHT3, GX_LIGHT4, GX_LIGHT5, GX_LIGHT6, GX_LIGHT7,
};
/* 8019CB0C-8019CCDC 19744C 01D0+00 3/2 0/0 0/0 .text dKy_WolfPowerup_BgAmbCol__FP11_GXColorS10 */
void dKy_WolfPowerup_BgAmbCol(GXColorS10* in_col_p) {
JUT_ASSERT(374, in_col_p != 0);
switch (dKy_sense_pat_get()) {
case 1:
in_col_p->r = 33;
in_col_p->g = 48;
in_col_p->b = 44;
break;
case 2:
in_col_p->r = 33;
in_col_p->g = 48;
in_col_p->b = 44;
break;
case 3:
in_col_p->r = 40;
in_col_p->g = 53;
in_col_p->b = 49;
break;
case 4:
in_col_p->r = 32;
in_col_p->g = 46;
in_col_p->b = 40;
break;
case 5:
in_col_p->r = 45;
in_col_p->g = 64;
in_col_p->b = 58;
break;
case 6:
in_col_p->r = 33;
in_col_p->g = 48;
in_col_p->b = 44;
break;
case 7:
in_col_p->r = 38;
in_col_p->g = 53;
in_col_p->b = 49;
break;
case 8:
in_col_p->r = 33;
in_col_p->g = 48;
in_col_p->b = 44;
break;
case 9:
in_col_p->r = 40;
in_col_p->g = 59;
in_col_p->b = 53;
break;
case 11:
case 12:
in_col_p->r = 45;
in_col_p->g = 64;
in_col_p->b = 58;
break;
case 10:
in_col_p->r = 40;
in_col_p->g = 60;
in_col_p->b = 58;
break;
case 13:
in_col_p->r = 33;
in_col_p->g = 48;
in_col_p->b = 44;
break;
case 14:
in_col_p->r = 33;
in_col_p->g = 48;
in_col_p->b = 44;
break;
case 15:
in_col_p->r = 30;
in_col_p->g = 48;
in_col_p->b = 59;
break;
}
}
/* 8019CCDC-8019CE5C 19761C 0180+00 4/3 0/0 0/0 .text dKy_WolfPowerup_FogNearFar__FPfPf
*/
void dKy_WolfPowerup_FogNearFar(f32* near_p, f32* far_p) {
JUT_ASSERT(499, near_p != 0);
JUT_ASSERT(500, far_p != 0);
switch (dKy_sense_pat_get()) {
case 1:
*near_p = 750.0f;
*far_p = 1750.0f;
break;
case 2:
*near_p = 5000.0f;
*far_p = 40000.0f;
break;
case 3:
*near_p = 4000.0f;
*far_p = 12000.0f;
break;
case 4:
*near_p = 500.0f;
*far_p = 2250.0f;
break;
case 5:
*near_p = 1000.0f;
*far_p = 1800.0f;
break;
case 6:
*near_p = 1000.0f;
*far_p = 2750.0f;
break;
case 7:
*near_p = 750.0f;
*far_p = 1750.0f;
break;
case 8:
*near_p = 750.0f;
*far_p = 1750.0f;
break;
case 9:
*near_p = 2000.0f;
*far_p = 3000.0f;
break;
case 10:
*near_p = 300.0f;
*far_p = 700.0f;
break;
case 11:
*near_p = 750.0f;
*far_p = 1500.0f;
break;
case 12:
*near_p = 500.0f;
*far_p = 1250.0f;
break;
case 13:
*near_p = 1000.0f;
*far_p = 80000.0f;
break;
case 14:
*near_p = 1250.0f;
*far_p = 3000.0f;
break;
case 15:
*near_p = 1000.0f;
*far_p = 4750.0f;
break;
}
}
/* 8019CE5C-8019CFE4 19779C 0188+00 1/1 0/0 0/0 .text dKy_pos2_get_angle__FP4cXyzP4cXyzPsPs */
void dKy_pos2_get_angle(cXyz* pos1_p, cXyz* pos2_p, s16* pitch_p, s16* yaw_p) {
cXyz vec;
vec = *pos1_p - *pos2_p;
*pitch_p = cM_atan2s(-vec.y, vec.absXZ());
*yaw_p = cM_atan2s(vec.x, vec.z);
}
/* 8042CA54-8042DD64 059774 1310+00 116/118 128/128 649/649 .bss g_env_light */
dScnKy_env_light_c g_env_light;
/* 8019CFE4-8019D1A0 197924 01BC+00 4/4 0/0 0/0 .text dKy_twi_wolflight_set__Fi */
void dKy_twi_wolflight_set(int light_id) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
camera_class* camera_p = dComIfGp_getCamera(0);
cXyz vectle;
if (camera_p == NULL) {
return;
}
s16 angle_x;
s16 angle_y;
dKy_pos2_get_angle(&camera_p->lookat.center, &camera_p->lookat.eye, &angle_x, &angle_y);
dKyr_get_vectle_calc(&camera_p->lookat.center, &camera_p->lookat.eye, &vectle);
kankyo->field_0x0c18[light_id].mPos.x = camera_p->lookat.eye.x + vectle.x * 300.0f;
kankyo->field_0x0c18[light_id].mPos.y = camera_p->lookat.eye.y + vectle.y * 300.0f;
kankyo->field_0x0c18[light_id].mPos.z = camera_p->lookat.eye.z + vectle.z * 300.0f;
switch (g_env_light.light_size) {
case LIGHT_SIZE_S:
kankyo->field_0x0c18[light_id].mPos.y += 1500.0f;
break;
case LIGHT_SIZE_M:
kankyo->field_0x0c18[light_id].mPos.y += 500.0f;
break;
case LIGHT_SIZE_L:
kankyo->field_0x0c18[light_id].mPos.y += 1000.0f;
break;
case LIGHT_SIZE_LL:
kankyo->field_0x0c18[light_id].mPos.y += 1500.0f;
break;
default:
kankyo->field_0x0c18[light_id].mPos.y += 500.0f;
break;
}
angle_x += 6000;
kankyo->field_0x0c18[light_id].mAngleX = cM_sht2d(-angle_x);
kankyo->field_0x0c18[light_id].mAngleY = cM_sht2d(-angle_y) + 90.0f;
}
/* 8019D1A0-8019D2C4 197AE0 0124+00 3/3 0/0 0/0 .text dKy_lightdir_set__FffP3Vec */
void dKy_lightdir_set(f32 angle_x, f32 angle_y, Vec* out_dir_p) {
MtxP view_mtx = j3dSys.getViewMtx();
Mtx inv;
Vec calc_dir;
cXyz dir;
f32 x_deg = RAD_TO_DEG(angle_x);
f32 y_deg = RAD_TO_DEG(angle_y);
dir.x = cM_fcos(x_deg) * cM_fcos(y_deg);
dir.y = cM_fsin(x_deg);
dir.z = cM_fcos(x_deg) * cM_fsin(y_deg);
mDoMtx_inverseTranspose(view_mtx, inv);
cMtx_multVec(inv, &dir, &calc_dir);
out_dir_p->x = calc_dir.x;
out_dir_p->y = calc_dir.y;
out_dir_p->z = calc_dir.z;
}
/* 8019D2C4-8019D44C 197C04 0188+00 3/2 0/0 0/0 .text dKy_GXInitLightSpot__FP12J3DLightInfofUc */
void dKy_GXInitLightSpot(J3DLightInfo* light_p, f32 cutoff, u8 spot_type) {
if (cutoff <= 0.0f || cutoff > 90.0f) {
spot_type = GX_SP_OFF;
}
f32 temp_f1;
f32 var_f4 = cosf((cutoff * M_PI) / 180.0f);
f32 x, y, z;
switch (spot_type) {
case GX_SP_FLAT:
x = var_f4 * -1000.0f;
y = 1000.0f;
z = 0.0f;
break;
case GX_SP_COS:
x = -var_f4 / (1.0f - var_f4);
y = 1.0f / (1.0f - var_f4);
z = 0.0f;
break;
case GX_SP_COS2:
x = 0.0f;
y = -var_f4 / (1.0f - var_f4);
z = 1.0f / (1.0f - var_f4);
break;
case GX_SP_SHARP:
temp_f1 = ((1.0f - var_f4) * (1.0f - var_f4));
x = (var_f4 * (var_f4 - 2.0f)) / temp_f1;
y = 2.0f / temp_f1;
z = -1.0f / temp_f1;
break;
case GX_SP_RING1:
temp_f1 = ((1.0f - var_f4) * (1.0f - var_f4));
x = (var_f4 * -4.0f) / temp_f1;
y = ((var_f4 + 1.0f) * 4.0f) / temp_f1;
z = -4.0f / temp_f1;
break;
case GX_SP_RING2:
temp_f1 = ((1.0f - var_f4) * (1.0f - var_f4));
x = 1.0f - (var_f4 * 2.0f * var_f4) / temp_f1;
y = (var_f4 * 4.0f) / temp_f1;
z = -2.0f / temp_f1;
break;
case GX_SP_OFF:
default:
x = 1.0f;
y = 0.0f;
z = 0.0f;
break;
}
light_p->mCosAtten.x = x;
light_p->mCosAtten.y = y;
light_p->mCosAtten.z = z;
}
/* 8019D44C-8019D520 197D8C 00D4+00 2/2 0/0 0/0 .text
* dKy_GXInitLightDistAttn__FP12J3DLightInfoffUc */
void dKy_GXInitLightDistAttn(J3DLightInfo* light_p, f32 param_1, f32 param_2, u8 distattn_type) {
f32 temp_f3;
f32 z;
f32 x;
f32 y;
if (param_1 < 0.0f) {
distattn_type = GX_DA_OFF;
}
if (param_2 <= 0.0f || param_2 >= 1.0f) {
distattn_type = GX_DA_OFF;
}
switch (distattn_type) {
case GX_DA_GENTLE:
x = 1.0f;
y = (1.0f - param_2) / (param_2 * param_1);
z = 0.0f;
break;
case GX_DA_MEDIUM:
x = 1.0f;
temp_f3 = (1.0f - param_2) * 0.5f;
y = temp_f3 / (param_2 * param_1);
z = temp_f3 / (param_1 * param_2 * param_1);
break;
case GX_DA_STEEP:
x = 1.0f;
y = 0.0f;
z = (1.0f - param_2) / (param_1 * (param_2 * param_1));
break;
default:
case GX_DA_OFF:
x = 1.0f;
y = 0.0f;
z = 0.0f;
break;
}
light_p->mDistAtten.x = x;
light_p->mDistAtten.y = y;
light_p->mDistAtten.z = z;
}
/* 8019D520-8019D56C 197E60 004C+00 1/1 0/0 0/0 .text u8_data_ratio_set__FUcUcf */
static s16 u8_data_ratio_set(u8 start, u8 end, f32 ratio) {
return start + (int)(ratio * (end - start));
}
/* 8019D56C-8019D5BC 197EAC 0050+00 1/1 0/0 0/0 .text s16_data_ratio_set__Fssf */
static s16 s16_data_ratio_set(s16 start, s16 end, f32 ratio) {
return start + (s16)(ratio * (end - start));
}
/* 8019D5BC-8019D61C 197EFC 0060+00 1/1 0/0 0/0 .text kankyo_color_ratio_calc_common__Fsf
*/
static u8 kankyo_color_ratio_calc_common(s16 color, f32 ratio) {
s16 calc = color * ratio;
if (calc < 0) {
calc = 0;
} else if (calc > 255) {
calc = 255;
}
return calc;
}
/* 8019D61C-8019D68C 197F5C 0070+00 1/1 0/0 0/0 .text
* kankyo_color_ratio_calc__FP8_GXColor11_GXColorS10f */
static void kankyo_color_ratio_calc(GXColor* out_col_p, GXColorS10 color, f32 ratio) {
GXColorS10 work_color;
work_color = color;
out_col_p->r = kankyo_color_ratio_calc_common(work_color.r, ratio);
out_col_p->g = kankyo_color_ratio_calc_common(work_color.g, ratio);
out_col_p->b = kankyo_color_ratio_calc_common(work_color.b, ratio);
}
/* 8019D68C-8019D790 197FCC 0104+00 2/2 0/0 0/0 .text kankyo_color_ratio_set__FUcUcfUcUcfsf */
static s16 kankyo_color_ratio_set(u8 color_a_start, u8 color_a_end, f32 color_ratio,
u8 color_b_start, u8 color_b_end, f32 blend_ratio, s16 add_color,
f32 scale) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
s16 a = s16_data_ratio_set(color_a_start, color_a_end, color_ratio);
s16 b = s16_data_ratio_set(color_b_start, color_b_end, color_ratio);
s16 blend_color = s16_data_ratio_set(a, b, blend_ratio);
blend_color += add_color;
s16 calc_color = kankyo->now_allcol_ratio * scale * blend_color;
if (calc_color < 0) {
calc_color = 0;
}
if (calc_color > 255) {
calc_color = 255;
}
return calc_color;
}
/* 8019D790-8019D7A0 1980D0 0010+00 1/1 0/0 0/0 .text fl_data_ratio_set__Ffff */
static f32 fl_data_ratio_set(f32 start, f32 end, f32 ratio) {
return start + ratio * (end - start);
}
/* 8019D7A0-8019D878 1980E0 00D8+00 3/3 0/0 0/0 .text float_kankyo_color_ratio_set__Fffffffff */
static f32 float_kankyo_color_ratio_set(f32 color_a_start, f32 color_a_end, f32 color_ratio,
f32 color_b_start, f32 color_b_end, f32 blend_ratio,
f32 param_6, f32 param_7) {
f32 a = fl_data_ratio_set(color_a_start, color_a_end, color_ratio);
f32 b = fl_data_ratio_set(color_b_start, color_b_end, color_ratio);
f32 calc_color = fl_data_ratio_set(a, b, blend_ratio);
calc_color += param_7 * (param_6 - calc_color);
return calc_color;
}
/* 8019D878-8019D8AC 1981B8 0034+00 3/3 0/0 0/0 .text get_parcent__Ffff */
static f32 get_parcent(f32 max, f32 min, f32 value) {
f32 range = max - min;
if (0.0f != range) {
f32 diff = max - value;
f32 parcent = 1.0f - (diff / range);
if (!(parcent >= 1.0f)) {
return parcent;
}
}
return 1.0f;
}
/* 8019D8AC-8019D8CC 1981EC 0020+00 0/0 1/1 1/1 .text dKy_get_parcent__Ffff */
f32 dKy_get_parcent(f32 max, f32 min, f32 value) {
return get_parcent(max, min, value);
}
/* 8019D8CC-8019DD4C 19820C 0480+00 1/1 0/0 0/0 .text dKy_FiveSenses_fullthrottle_dark_static1__Fv
*/
static void dKy_FiveSenses_fullthrottle_dark_static1() {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
BOOL init_mode_change = FALSE;
cXyz particle_pos;
cXyz particle_size;
particle_pos.x = 0.0f;
particle_pos.y = 0.0f;
particle_pos.z = 0.0f;
particle_size.x = 1.0f;
particle_size.y = 1.0f;
particle_size.z = 1.0f;
if (daPy_py_c::checkNowWolfPowerUp()) {
kankyo->now_senses_effect = 1;
init_mode_change = TRUE;
if (kankyo->senses_effect_strength <= 0.0f) {
dComIfGp_particle_set(0x1E3, &particle_pos, NULL, NULL, &particle_size);
}
cLib_addCalc(&kankyo->senses_effect_strength, 1.0f, 0.5f, 0.1f, 0.01f);
} else if (kankyo->senses_effect_strength > 0.0f) {
if (kankyo->senses_effect_strength >= 1.0f) {
dComIfGp_particle_set(0x46A, &particle_pos, NULL, NULL, &particle_size);
}
cLib_addCalc(&kankyo->senses_effect_strength, 0.0f, 0.5f, 0.1f, 0.01f);
init_mode_change = TRUE;
}
switch (kankyo->senses_mode) {
case 0:
if (init_mode_change != TRUE) {
break;
}
kankyo->senses_ef_emitter0 = NULL;
kankyo->senses_ef_emitter1 = NULL;
kankyo->senses_ef_emitter2 = NULL;
kankyo->senses_ef_emitter0 = dComIfGp_particle_set(0x1F2, &particle_pos, NULL, NULL);
kankyo->senses_ef_emitter1 = dComIfGp_particle_set(0x1F3, &particle_pos, NULL, NULL, &particle_size);
kankyo->senses_ef_emitter2 = dComIfGp_particle_set(0x1F4, &particle_pos, NULL, NULL, &particle_size);
kankyo->senses_mode++;
case 1:
if (init_mode_change == TRUE) {
if (kankyo->senses_ef_emitter0 != NULL) {
kankyo->senses_ef_emitter0->setGlobalTranslation(particle_pos.x, particle_pos.y,
particle_pos.z);
kankyo->senses_ef_emitter0->setGlobalAlpha(kankyo->senses_effect_strength * 255.0f);
}
if (kankyo->senses_ef_emitter1 != NULL) {
kankyo->senses_ef_emitter1->setGlobalTranslation(particle_pos.x, particle_pos.y,
particle_pos.z);
kankyo->senses_ef_emitter1->setGlobalAlpha(kankyo->senses_effect_strength * 255.0f);
}
if (kankyo->senses_ef_emitter2 != NULL) {
kankyo->senses_ef_emitter2->setGlobalTranslation(particle_pos.x, particle_pos.y,
particle_pos.z);
kankyo->senses_ef_emitter2->setGlobalEnvColor(
255.0f * (1.0f - kankyo->senses_effect_strength),
255.0f * (1.0f - kankyo->senses_effect_strength),
255.0f * (1.0f - kankyo->senses_effect_strength));
}
} else {
kankyo->senses_mode++;
}
break;
case 2:
if (kankyo->senses_ef_emitter0 != NULL) {
kankyo->senses_ef_emitter0->deleteAllParticle();
kankyo->senses_ef_emitter0->becomeInvalidEmitter();
kankyo->senses_ef_emitter0->quitImmortalEmitter();
kankyo->senses_ef_emitter0->setEmitterCallBackPtr(NULL);
kankyo->senses_ef_emitter0 = NULL;
}
if (kankyo->senses_ef_emitter1 != NULL) {
kankyo->senses_ef_emitter1->deleteAllParticle();
kankyo->senses_ef_emitter1->becomeInvalidEmitter();
kankyo->senses_ef_emitter1->quitImmortalEmitter();
kankyo->senses_ef_emitter1->setEmitterCallBackPtr(NULL);
kankyo->senses_ef_emitter1 = NULL;
}
if (kankyo->senses_ef_emitter2 != NULL) {
kankyo->senses_ef_emitter2->deleteAllParticle();
kankyo->senses_ef_emitter2->becomeInvalidEmitter();
kankyo->senses_ef_emitter2->quitImmortalEmitter();
kankyo->senses_ef_emitter2->setEmitterCallBackPtr(NULL);
kankyo->senses_ef_emitter2 = NULL;
}
kankyo->senses_mode = 0;
break;
}
}
/* 8019DD4C-8019DD6C 19868C 0020+00 0/0 1/1 0/0 .text dKy_FiveSenses_fullthrottle_dark__Fv */
void dKy_FiveSenses_fullthrottle_dark() {
dKy_FiveSenses_fullthrottle_dark_static1();
}
/* 8019DD6C-8019E13C 1986AC 03D0+00 3/3 0/0 0/0 .text dKy_light_influence_id__F4cXyzi */
int dKy_light_influence_id(cXyz position, int param_1) {
f32 closest_plight_dist = 1000000.0f;
int closest_plight_no = -1;
int var_r27 = -1;
int j;
int var_r25 = -1;
int i;
f32 var_f30 = 800.0f;
if (strcmp(dComIfGp_getStartStageName(), "D_MN09") == 0) {
var_f30 = 250.0f;
}
for (i = 0; i <= param_1; i++) {
for (j = 0; j < 100; j++) {
if (g_env_light.pointlight[j] != NULL && (i == 0 || j != closest_plight_no) &&
g_env_light.pointlight[j]->mPow > 0.01f)
{
if (closest_plight_dist > position.abs(g_env_light.pointlight[j]->mPosition)) {
if (g_env_light.pointlight[j]->mIndex & 0x8000) {
if (closest_plight_dist > var_f30) {
if (i == 0) {
closest_plight_no = j;
}
if (i != 0) {
var_r27 = j;
}
closest_plight_dist = var_f30;
}
} else {
closest_plight_dist = position.abs(g_env_light.pointlight[j]->mPosition);
if (closest_plight_dist < g_env_light.pointlight[j]->mPow) {
if (strcmp(dComIfGp_getStartStageName(), "D_MN05") == 0 &&
dComIfGp_roomControl_getStayNo() == 0)
{
if (closest_plight_dist < g_env_light.pointlight[j]->mPow * 0.5f) {
var_r25 = 99;
}
} else {
var_r25 = 99;
}
}
if (var_r25 != -2) {
if (i == 0) {
closest_plight_no = j;
} else {
var_r27 = j;
}
}
}
}
if (g_env_light.pointlight[j]->mIndex < 0 && var_r25 != 99) {
if (i == 0) {
closest_plight_no = j;
}
var_r25 = -2;
}
}
}
closest_plight_dist = 1000000.0f;
}
if (param_1 == 0) {
return closest_plight_no;
} else {
return var_r27;
}
}
/* 8019E13C-8019E404 198A7C 02C8+00 2/2 0/0 0/0 .text dKy_eflight_influence_id__F4cXyzi
*/
int dKy_eflight_influence_id(cXyz position, int param_1) {
f32 var_f31 = 1000000.0f;
int var_r28 = -1;
int var_r27 = -1;
int j, i;
for (i = 0; i <= param_1; i++) {
for (j = 0; j < 5; j++) {
if (g_env_light.efplight[j] != NULL && (i == 0 || j != var_r28)) {
if (var_f31 > position.abs(g_env_light.efplight[j]->mPosition) &&
g_env_light.efplight[j]->mPow > 0.01f)
{
var_f31 = position.abs(g_env_light.efplight[j]->mPosition);
if (i == 0) {
var_r28 = j;
} else {
var_r27 = j;
}
}
}
}
var_f31 = 1000000.0f;
}
if (param_1 == 0) {
return var_r28;
} else {
return var_r27;
}
}
/* 8019E404-8019E430 198D44 002C+00 1/1 0/0 0/0 .text dKy_light_influence_col__Fi */
GXColorS10 dKy_light_influence_col(int light_id) {
dScnKy_env_light_c* kankyo = &g_env_light;
return kankyo->pointlight[light_id >= 0 ? light_id : 0]->mColor;
}
/* 8019E430-8019E520 198D70 00F0+00 4/4 3/3 0/0 .text dKy_light_influence_col__FP8_GXColorf */
GXColor dKy_light_influence_col(GXColor* in_col_p, f32 ratio) {
GXColor out_col;
f32 r = in_col_p->r * ratio;
if (r <= 255.0f) {
out_col.r = r;
} else {
out_col.r = 255;
}
f32 g = in_col_p->g * ratio;
if (g <= 255.0f) {
out_col.g = g;
} else {
out_col.g = 255;
}
f32 b = in_col_p->b * ratio;
if (b <= 255.0f) {
out_col.b = b;
} else {
out_col.b = 255;
}
return out_col;
}
/* 8019E520-8019E548 198E60 0028+00 1/1 0/0 0/0 .text dKy_light_influence_power__Fi */
f32 dKy_light_influence_power(int light_id) {
dScnKy_env_light_c* kankyo = &g_env_light;
return kankyo->pointlight[light_id >= 0 ? light_id : 0]->mPow;
}
/* 8019E548-8019E570 198E88 0028+00 1/1 0/0 0/0 .text dKy_light_influence_yuragi__Fi */
f32 dKy_light_influence_yuragi(int light_id) {
dScnKy_env_light_c* kankyo = &g_env_light;
return kankyo->pointlight[light_id >= 0 ? light_id : 0]->mFluctuation;
}
/* 8019E570-8019E694 198EB0 0124+00 1/1 0/0 0/0 .text dKy_light_influence_distance__F4cXyzi */
f32 dKy_light_influence_distance(cXyz position, int light_id) {
return position.abs(g_env_light.pointlight[light_id >= 0 ? light_id : 0]->mPosition);
}
/* 8019E694-8019E708 198FD4 0074+00 2/2 0/0 0/0 .text plight_init__Fv */
static void plight_init() {
g_env_light.mLightInfluence[0].mPow = 99999.9f;
for (int i = 0; i < 100; i++) {
g_env_light.pointlight[i] = NULL;
}
for (int i = 0; i < 5; i++) {
g_env_light.efplight[i] = NULL;
g_env_light.unk_0x72c[i] = NULL;
}
g_env_light.mPlayerPLightIdx = -1;
g_env_light.mPlayerEfLightIdx = -1;
}
/* 8019E708-8019E734 199048 002C+00 1/1 0/0 0/0 .text darkmist_init__Fv */
static void darkmist_init() {
for (int i = 0; i < 10; i++) {
g_env_light.dalkmist_influence[i] = NULL;
}
}
/* 8019E734-8019E854 199074 0120+00 1/1 0/0 0/0 .text plight_set__Fv */
static void plight_set() {
int plight_no = 0;
stage_plight_info_class* plight_info = dComIfGp_getStagePlightInfo();
if (plight_info != NULL) {
g_env_light.stage_plight_info = plight_info;
for (int i = 0; i < dComIfGp_getStagePlightNumInfo(); i++) {
if (plight_no < 30) {
g_env_light.mLightInfluence[plight_no].mPosition = plight_info[i].position;
g_env_light.mLightInfluence[plight_no].mColor.r = plight_info[i].color.r;
g_env_light.mLightInfluence[plight_no].mColor.g = plight_info[i].color.g;
g_env_light.mLightInfluence[plight_no].mColor.b = plight_info[i].color.b;
g_env_light.mLightInfluence[plight_no].mPow = plight_info[i].power * 200.0f;
g_env_light.mLightInfluence[plight_no].mFluctuation = plight_info[i].fluctuation;
dKy_plight_set(&g_env_light.mLightInfluence[plight_no]);
plight_no++;
} else {
#ifdef DEBUG
// "\nToo many Point Lights set!!!"
OSReport_Warning("\nポイントライトマップ配置が多すぎます!!!");
#endif
}
}
}
}
/* 8019E854-8019E874 199194 0020+00 1/1 0/0 0/0 .text bgparts_activelight_init__Fv */
static void bgparts_activelight_init() {
for (int i = 0; i < 2; i++) {
g_env_light.bgparts_active_light[0].mIndex = 0;
}
}
/* 8019E874-8019EAA0 1991B4 022C+00 1/1 0/0 0/0 .text dungeonlight_init__Fv */
static void dungeonlight_init() {
static Vec test_pos_tbl[] = {
{0.0f, -99999.0f, 0.0f}, {0.0f, -99999.0f, 0.0f}, {0.0f, -99999.0f, 0.0f},
{0.0f, -99999.0f, 0.0f}, {0.0f, -99999.0f, 0.0f}, {0.0f, -99999.0f, 0.0f},
{0.0f, -99999.0f, 0.0f}, {0.0f, -99999.0f, 0.0f},
};
static color_RGB_class test_color_tbl[] = {
{0, 0, 0}, {0, 0, 0}, {0, 0, 0}, {0, 0, 0}, {0, 0, 0}, {0, 0, 0}, {0, 0, 0}, {0, 0, 0},
};
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
for (int i = 0; i < 8; i++) {
kankyo->dungeonlight[i].mPosition = cXyz(test_pos_tbl[i]);
kankyo->dungeonlight[i].mRefDistance = 1.0f;
kankyo->dungeonlight[i].field_0x14 = 0.99f;
kankyo->dungeonlight[i].mColor.r = test_color_tbl[i].r;
kankyo->dungeonlight[i].mColor.g = test_color_tbl[i].g;
kankyo->dungeonlight[i].mColor.b = test_color_tbl[i].b;
kankyo->dungeonlight[i].mColor.a = 255;
kankyo->dungeonlight[i].mInfluence.mPosition = kankyo->dungeonlight[i].mPosition;
kankyo->dungeonlight[i].mInfluence.mColor.r = kankyo->dungeonlight[i].mColor.r;
kankyo->dungeonlight[i].mInfluence.mColor.g = kankyo->dungeonlight[i].mColor.g;
kankyo->dungeonlight[i].mInfluence.mColor.b = kankyo->dungeonlight[i].mColor.b;
kankyo->dungeonlight[i].mInfluence.mPow = kankyo->dungeonlight[i].mRefDistance * 100.0f;
kankyo->dungeonlight[i].mInfluence.mFluctuation = 0.0f;
kankyo->dungeonlight[i].mCutoffAngle = 90.0f;
kankyo->dungeonlight[i].mAngleX = -90.0f;
kankyo->dungeonlight[i].mAngleY = 0.0f;
kankyo->dungeonlight[i].mAngleAttenuation = GX_SP_OFF;
kankyo->dungeonlight[i].mDistAttenuation = GX_DA_MEDIUM;
kankyo->field_0x0c18[i].mPos = cXyz(test_pos_tbl[i]);
kankyo->field_0x0c18[i].mColor.r = test_color_tbl[i].r;
kankyo->field_0x0c18[i].mColor.g = test_color_tbl[i].g;
kankyo->field_0x0c18[i].mColor.b = test_color_tbl[i].b;
kankyo->field_0x0c18[i].mColor.a = 255;
kankyo->field_0x0c18[i].mRefDistance = 0.001f;
kankyo->field_0x0c18[i].field_0x14 = 0.99f;
kankyo->field_0x0c18[i].field_0x26 = 0;
kankyo->field_0x0c18[i].mCutoffAngle = 90.0f;
kankyo->field_0x0c18[i].mAngleX = -90.0f;
kankyo->field_0x0c18[i].mAngleY = 0.0f;
kankyo->field_0x0c18[i].mAngleAttenuation = GX_SP_OFF;
kankyo->field_0x0c18[i].mDistAttenuation = GX_DA_MEDIUM;
if (i < 6) {
kankyo->field_0x0d58[i] = kankyo->field_0x0c18[i];
}
}
}
/* 8019EAA0-8019EBD0 1993E0 0130+00 1/1 0/0 0/0 .text undwater_init__Fv */
static void undwater_init() {
J3DModelData* modelData2 = (J3DModelData*)dComIfG_getObjectRes("Always", 0x1D);
JUT_ASSERT(1867, modelData2 != 0);
g_env_light.undwater_ef_heap = mDoExt_createSolidHeapFromGameToCurrent(0x600, 0x20);
if (g_env_light.undwater_ef_heap != NULL) {
g_env_light.undwater_ef_model = mDoExt_J3DModel__create(modelData2, 0x80000, 0x11020202);
if (g_env_light.undwater_ef_model != NULL) {
g_env_light.undwater_btk = new mDoExt_btkAnm();
if (g_env_light.undwater_btk != NULL) {
J3DAnmTextureSRTKey* pbtk = (J3DAnmTextureSRTKey*)dComIfG_getObjectRes("Always", 0x3C);
if (!g_env_light.undwater_btk->init(modelData2, pbtk, TRUE,
J3DFrameCtrl::EMode_LOOP, 1.0f, 0, -1))
{
JUT_ASSERT(1898, 0);
}
} else {
JUT_ASSERT(1902, 0);
}
}
mDoExt_restoreCurrentHeap();
mDoExt_adjustSolidHeap(g_env_light.undwater_ef_heap);
} else {
JUT_ASSERT(1917, 0);
}
}
/* 8019EBD0-8019EC98 199510 00C8+00 1/1 0/0 0/0 .text dKy_light_size_get__FPCc */
void dKy_light_size_get(char const* stageName) {
dKydata_lightsizeInfo_c* size_tbl = dKyd_light_size_tbl_getp();
dKydata_lightsizeInfo_c* tw_size_tbl = dKyd_light_tw_size_tbl_getp();
if (!dKy_darkworld_check()) {
for (int i = 0; i < 36; i++) {
if (!strcmp(stageName, size_tbl->stageName)) {
g_env_light.light_size = size_tbl->size;
return;
}
size_tbl++;
}
} else {
for (int i = 0; i < 9; i++) {
if (!strcmp(stageName, tw_size_tbl->stageName)) {
g_env_light.light_size = tw_size_tbl->size;
return;
}
tw_size_tbl++;
}
}
}
/* 8019EC98-8019F264 1995D8 05CC+00 1/1 0/0 0/0 .text envcolor_init__Fv */
static void envcolor_init() {
stage_palette_info_class* stage_palette_p = dComIfGp_getStagePaletteInfo();
stage_pselect_info_class* stage_psel_p = dComIfGp_getStagePselectInfo();
stage_envr_info_class* stage_envr_p = dComIfGp_getStageEnvrInfo();
stage_vrboxcol_info_class* stage_vrboxcol_p = dComIfGp_getStageVrboxcolInfo();
dKy_actor_addcol_set(0, 0, 0, 0.0f);
dKy_fog_startendz_set(0.0f, 0.0f, 0.0f);
dKy_vrbox_addcol_set(0, 0, 0, 0.0f);
g_env_light.field_0x1280 = 0;
g_env_light.light_init_timer = 1;
g_env_light.schbit = 0;
g_env_light.schbit_timer = 0;
g_env_light.hide_vrbox = false;
g_env_light.mContrastFlag = 0;
g_env_light.mFogAdjEnable = true;
g_env_light.mFogAdjTableType = 0;
g_env_light.mFogAdjCenter = 0x140;
dKyd_xfog_table_set(0);
g_env_light.now_allcol_ratio = 1.0f;
g_env_light.now_actcol_ratio = 1.0f;
g_env_light.now_bgcol_ratio = 1.0f;
g_env_light.now_fogcol_ratio = 1.0f;
g_env_light.now_vrboxsoracol_ratio = 1.0f;
g_env_light.now_vrboxkumocol_ratio = 1.0f;
g_env_light.field_0x1210 = 1.0f;
g_env_light.allcol_ratio = 1.0f;
g_env_light.actcol_ratio = 1.0f;
g_env_light.bgcol_ratio = 1.0f;
g_env_light.fogcol_ratio = 1.0f;
g_env_light.vrboxsoracol_ratio = 1.0f;
g_env_light.vrboxkumocol_ratio = 1.0f;
g_env_light.field_0x122c = 1.0f;
g_env_light.Itemgetcol_chg = 0;
g_env_light.field_0x1240 = 0.0f;
g_env_light.field_0x1230 = 0.0f;
g_env_light.field_0x1234 = 0.0f;
g_env_light.mThunderEff.mState = 0;
g_env_light.field_0x1238 = 0.0f;
g_env_light.field_0x123c = 0.0f;
g_env_light.field_0x12d6 = 0;
g_env_light.shadow_mode = 0;
g_env_light.camera_water_in_status = 0;
g_env_light.field_0x1258 = 0.0f;
g_env_light.mActorLightEffect = 100;
g_env_light.bg_light_influence = 1.0f;
g_env_light.field_0x1064.x = 0.0f;
g_env_light.field_0x1064.y = -1.0f;
g_env_light.field_0x1064.z = -1.0f;
g_env_light.mDemoAttentionPoint = 0.0f;
if (!strcmp(dComIfGp_getStartStageName(), "R_SP127")) {
g_env_light.mDemoAttentionPoint = 0.11f;
}
g_env_light.light_mask_type = 0;
g_env_light.field_0x130b = 0;
g_env_light.light_size = LIGHT_SIZE_M;
dKy_light_size_get(dComIfGp_getStartStageName());
g_env_light.grass_light_inf_rate = 1.0f;
g_env_light.field_0x12fc = -1;
g_env_light.field_0x1278 = 0.0f;
g_env_light.field_0x1264 = -255.0f;
g_env_light.field_0x1268 = 999999.9f;
g_env_light.field_0x126c = 999999.9f;
g_env_light.field_0x127c = 200.0f;
if (dStage_stagInfo_GetSTType(dComIfGp_getStage()->getStagInfo()) == ST_BOSS_ROOM) {
g_env_light.light_schedule = dKyd_schejule_boss_getp();
} else {
g_env_light.light_schedule = dKyd_schejule_getp();
}
g_env_light.PrevCol = dComIfGp_roomControl_getStayNo();
g_env_light.UseCol = dComIfGp_roomControl_getStayNo();
g_env_light.pat_ratio = 1.0f;
g_env_light.field_0x12b0 = 0;
g_env_light.mColpatWeather = 0;
g_env_light.mVrkumoStrength = 0.0f;
if (!strcmp(dComIfGp_getStartStageName(), "F_SP127") ||
!strcmp(dComIfGp_getStartStageName(), "R_SP127"))
{
if (g_env_light.field_0x12cc >= 7) {
g_env_light.mColpatWeather = 2;
} else if (g_env_light.field_0x12cc != 0) {
g_env_light.mColpatWeather = 1;
}
} else if (!strcmp(dComIfGp_getStartStageName(), "D_MN07A")) {
if (g_env_light.field_0x12cc == 1) {
g_env_light.mColpatWeather = 1;
} else if (g_env_light.field_0x12cc == 2) {
g_env_light.mColpatWeather = 2;
}
} else {
g_env_light.field_0x12cc = 0;
}
g_env_light.base_raincnt = 0;
g_env_light.field_0x12a0 = 0;
g_env_light.dice_wether_mode = 0;
g_env_light.dice_wether_change_time = dComIfGs_getTime() + (cM_rndF(g_Counter.mCounter0 & 31) * 15.0f);
if (g_env_light.dice_wether_change_time >= 360.0f) {
g_env_light.dice_wether_change_time -= 360.0f;
}
g_env_light.dice_wether_state = 0;
g_env_light.dice_wether_pat = 0;
g_env_light.dice_wether_counter = 0;
g_env_light.dice_wether_time = 0.0f;
g_env_light.wether_pat0 = g_env_light.mColpatWeather;
g_env_light.wether_pat1 = g_env_light.mColpatWeather;
g_env_light.mColpatPrevGather = 0xFF;
g_env_light.mColpatCurrGather = 0xFF;
g_env_light.mColPatBlendGather = -1.0f;
g_env_light.mColPatMode = 0;
g_env_light.mColPatModeGather = 0;
if (stage_envr_p != NULL) {
g_env_light.stage_envr_info = stage_envr_p;
} else {
g_env_light.stage_envr_info = (stage_envr_info_class*)dKyd_dmenvr_getp();
}
if (stage_palette_p != NULL) {
g_env_light.stage_palette_info = stage_palette_p;
} else {
g_env_light.stage_palette_info = (stage_palette_info_class*)dKyd_dmpalet_getp();
}
if (stage_psel_p != NULL) {
g_env_light.stage_pselect_info = stage_psel_p;
} else {
g_env_light.stage_pselect_info = (stage_pselect_info_class*)dKyd_dmpselect_getp();
}
if (stage_vrboxcol_p != NULL) {
g_env_light.stage_vrboxcol_info = stage_vrboxcol_p;
} else {
g_env_light.stage_vrboxcol_info = (stage_vrboxcol_info_class*)dKyd_dmvrbox_getp();
}
plight_init();
plight_set();
darkmist_init();
bgparts_activelight_init();
g_env_light.unk_0x11c8 = 1.0f;
g_env_light.unk_0x11cc = 1.0f;
g_env_light.unk_0x11d0 = 1.0f;
g_env_light.field_0xf2c = 0;
g_env_light.undwater_ef_model = NULL;
g_env_light.field_0xf34 = 0.0f;
g_env_light.undwater_ef_heap = NULL;
undwater_init();
dComIfGs_PolyDamageOff_Set(0);
g_env_light.player_room_no = dComIfGp_roomControl_getStayNo();
g_env_light.is_blure = 0;
g_env_light.using_time_control_tag = 0;
g_env_light.field_0x1300 = -1;
g_env_light.field_0x1302 = -1;
g_env_light.mWaterSurfaceShineRate = 1.0f;
int stage_time = dStage_stagInfo_GetTimeH(dComIfGp_getStage()->getStagInfo());
if (stage_time >= 0) {
dComIfGs_setTime(stage_time * 15.0f);
}
g_env_light.time_change_rate = 0.012f;
memset(&g_env_light.moya_se, 0, 0x10);
}
/* 8019F264-8019F2E8 199BA4 0084+00 1/1 1/1 0/0 .text dKy_clear_game_init__Fv */
void dKy_clear_game_init() {
dKy_actor_addcol_set(0, 0, 0, 0.0f);
g_env_light.sun_pos.x = 1.0f;
g_env_light.sun_pos.y = 0.0f;
g_env_light.sun_pos.z = 0.0f;
g_env_light.moon_pos.x = -1.0f;
g_env_light.moon_pos.y = 0.0f;
g_env_light.moon_pos.z = 0.0f;
g_env_light.nexttime = -1.0f;
g_env_light.old_time = -1.0f;
g_env_light.dark_daytime = 120.0f;
g_env_light.darktime_week = 0;
g_env_light.fishing_hole_season = 0;
g_env_light.field_0x130a = 0;
g_env_light.field_0x12cc = 0;
g_env_light.staffroll_next_timer = 0;
}
/* 8019F2E8-8019F400 199C28 0118+00 1/1 0/0 0/0 .text __ct__18dScnKy_env_light_cFv */
dScnKy_env_light_c::dScnKy_env_light_c() {
dKy_clear_game_init();
}
/* 8019F4FC-8019F780 199E3C 0284+00 1/1 0/0 0/0 .text setDaytime__18dScnKy_env_light_cFv
*/
// NONMATCHING - getTimePass doing s8 check instead of int check
void dScnKy_env_light_c::setDaytime() {
mDate = dComIfGs_getDate();
daytime = dComIfGs_getTime();
if (using_time_control_tag == 0) {
if (!dKy_darkworld_check()) {
if (dComIfGp_event_runCheck() == FALSE) {
msg_class* msg = dMsgObject_c::getActor();
bool temp_r29 = msg == NULL || msg->mode < 2;
if (dComIfGp_roomControl_getTimePass() && !field_0x130a && temp_r29) {
daytime += time_change_rate;
// Stage is Fishing Pond or Hena's Hut
if (!strcmp(dComIfGp_getStartStageName(), "F_SP127") ||
!strcmp(dComIfGp_getStartStageName(), "R_SP127"))
{
f32 current_time = daytime;
if (current_time >= 300.0f || current_time <= 60.0f) {
daytime += time_change_rate;
daytime += time_change_rate;
} else if (current_time >= 150.0f && current_time <= 195.0f) {
daytime = current_time + time_change_rate;
}
}
if ((u32)daytime >= 360.0f) {
daytime = 0.0f;
mDate++;
dKankyo_DayProc();
}
}
}
} else {
dark_daytime += time_change_rate;
if ((u32)dark_daytime >= 360.0f) {
darktime_week++;
dark_daytime = 0.0f;
}
daytime = 0.0f;
}
}
if (daytime >= 360.0f) {
daytime = 0.0f;
}
dComIfGs_setTime(daytime);
mDoAud_setHour(dKy_getdaytime_hour());
mDoAud_setMinute(dKy_getdaytime_minute());
mDoAud_setWeekday(dKy_get_dayofweek());
dComIfGs_setDate(mDate);
g_env_light.using_time_control_tag = 0;
}
/* 8019F788-8019FA08 19A0C8 0280+00 1/1 0/0 0/0 .text setSunpos__18dScnKy_env_light_cFv
*/
void dScnKy_env_light_c::setSunpos() {
camera_class* camera_p = dComIfGp_getCamera(0);
cXyz pos;
if (camera_p != NULL && strcmp(dComIfGp_getStartStageName(), "F_SP200") != 0) {
f32 sun_time = g_env_light.daytime;
f32 sun_angle;
f32 moon_time;
f32 moon_angle;
if (sun_time >= 90.0f && sun_time <= 270.0f) {
f32 percent = get_parcent(270.0f, 90.0f, sun_time);
sun_angle = (percent * 150.0f) + 105.0f;
} else {
if (sun_time < 90.0f) {
sun_time += 360.0f;
}
f32 percent = get_parcent(450.0f, 270.0f, sun_time);
sun_angle = (percent * 210.0f) + 255.0f;
if (sun_angle > 360.0f) {
sun_angle -= 360.0f;
}
}
moon_time = 180.0f + g_env_light.daytime;
if (moon_time >= 360.0f) {
moon_time -= 360.0f;
}
if (moon_time >= 90.0f && moon_time <= 270.0f) {
f32 percent = get_parcent(270.0f, 90.0f, moon_time);
moon_angle = (percent * 150.0f) + 105.0f;
} else {
if (moon_time < 90.0f) {
moon_time += 360.0f;
}
f32 percent = get_parcent(450.0f, 270.0f, moon_time);
moon_angle = (percent * 210.0f) + 255.0f;
if (moon_angle > 360.0f) {
moon_angle -= 360.0f;
}
}
pos.x = sinf(DEG_TO_RAD(sun_angle)) * 80000.0f;
pos.y = cosf(DEG_TO_RAD(sun_angle)) * 80000.0f;
pos.z = cosf(DEG_TO_RAD(sun_angle)) * -48000.0f;
sun_pos.x = camera_p->lookat.eye.x + pos.x;
sun_pos.y = camera_p->lookat.eye.y - pos.y;
sun_pos.z = camera_p->lookat.eye.z + pos.z;
pos.x = sinf(DEG_TO_RAD(moon_angle)) * 80000.0f;
pos.y = cosf(DEG_TO_RAD(moon_angle)) * 80000.0f;
pos.z = cosf(DEG_TO_RAD(moon_angle)) * -48000.0f;
moon_pos.x = pos.x;
moon_pos.y = -pos.y;
moon_pos.z = pos.z;
}
}
/* 8019FA08-8019FA10 19A348 0008+00 3/3 5/5 1/1 .text getDaytime__18dScnKy_env_light_cFv
*/
f32 dScnKy_env_light_c::getDaytime() {
return daytime;
}
/* 8019FA10-8019FA3C 19A350 002C+00 2/2 2/2 32/32 .text dKy_getdaytime_hour__Fv */
int dKy_getdaytime_hour() {
return dComIfGs_getTime() / 15.0f;
}
/* 8019FA3C-8019FAB8 19A37C 007C+00 1/1 1/1 26/26 .text dKy_getdaytime_minute__Fv */
int dKy_getdaytime_minute() {
f32 tmp = ((int)(dComIfGs_getTime() * 1000000.0f) % 15000000);
return tmp / 1000000.0f / 15.0f * 60.0f;
}
/* 8019FAB8-8019FAF4 19A3F8 003C+00 0/0 3/3 6/6 .text dKy_daynight_check__Fv */
BOOL dKy_daynight_check() {
int hour = dKy_getdaytime_hour();
if (hour >= 6 && hour < 19) {
return FALSE; // day time
} else {
return TRUE; // night time
}
}
/* 8019FAF4-8019FB30 19A434 003C+00 0/0 0/0 22/22 .text dKy_getDarktime_hour__Fv */
int dKy_getDarktime_hour() {
return g_env_light.getDarkDaytime() / 15.0f;
}
/* 8019FB30-8019FBBC 19A470 008C+00 0/0 0/0 19/19 .text dKy_getDarktime_minute__Fv */
int dKy_getDarktime_minute() {
f32 time = g_env_light.getDarkDaytime();
f32 temp_f30 = ((int)(time * 1000000.0f) % 15000000) / 1000000.0f;
return 60.0f * (temp_f30 / 15.0f);
}
/* 8019FBBC-8019FBCC 19A4FC 0010+00 0/0 0/0 8/8 .text dKy_getDarktime_week__Fv */
u8 dKy_getDarktime_week() {
return g_env_light.darktime_week;
}
/* 8019FBCC-8019FBD4 19A50C 0008+00 2/2 0/0 0/0 .text getDarkDaytime__18dScnKy_env_light_cFv */
f32 dScnKy_env_light_c::getDarkDaytime() {
return dark_daytime;
}
/* 8019FBD4-801A0340 19A514 076C+00 5/3 0/0 0/0 .text
* setLight_palno_get__18dScnKy_env_light_cFPUcPUcPUcPUcPUcPUcPUcPUcPfPiPiPfPUc */
/**
* Gets stage environment color palette information based on given IDs.
* This gets both previous and next palette information so that blending between
* palettes can occur. Both previous and next palette's also get a start and ending palette
* used to blend color based on time of day.
*
* @param prev_envr_id_p Index into stage ENVR info for previous palette
* @param next_envr_id_p Index into stage ENVR info for next (target) palette
* @param prev_pat_p Index of stage Pselect (Palette Select) to use for previous palette
* @param next_pat_p Index of stage Pselect (Palette Select) to use for next (target) palette
* @param prev_pal_start_id_p Start Palette ID for previous palette color
* @param prev_pal_end_id_p Ending Palette ID for previous palette color
* @param next_pal_start_id_p Start Palette ID for next (target) palette color
* @param next_pal_end_id_p Ending Palette ID for next (target) palette color
* @param color_ratio_p Ratio in-between start and ending palette to use
* @param start_pat_pal_id_p Index into stage Pselect for starting palette
* @param end_pat_pal_id_p Index into stage Pselect for ending palette
* @param pattern_ratio_p Ratio in-between previous pattern to the next
* @param init_timer_p
*/
void dScnKy_env_light_c::setLight_palno_get(u8* prev_envr_id_p, u8* next_envr_id_p, u8* prev_pat_p,
u8* next_pat_p, u8* prev_pal_start_id_p,
u8* prev_pal_end_id_p, u8* next_pal_start_id_p,
u8* next_pal_end_id_p, f32* color_ratio_p,
int* start_pat_pal_id_p, int* end_pat_pal_id_p,
f32* pattern_ratio_p, u8* init_timer_p) {
stage_envr_info_class* envr_p;
u8 psel_idx = 0;
if (*init_timer_p != 0) {
*init_timer_p += 1;
if (*init_timer_p > 20) {
*init_timer_p = 0;
}
if (g_env_light.mColPatMode == 0 && g_env_light.mColPatModeGather == 0) {
*pattern_ratio_p = g_env_light.pat_ratio;
// previous has reached next, so set previous to next
if (*pattern_ratio_p >= 1.0f) {
*prev_envr_id_p = *next_envr_id_p;
*prev_pat_p = *next_pat_p;
}
}
}
for (int i = 0; i < 11; i++) {
// if time of day is not within light schedule range, then don't calculate light color
if (!(daytime >= light_schedule[i].startTime && daytime <= light_schedule[i].endTime)) {
continue;
}
*start_pat_pal_id_p = light_schedule[i].startTimeLight;
*end_pat_pal_id_p = light_schedule[i].endTimeLight;
*color_ratio_p = get_parcent(light_schedule[i].endTime, light_schedule[i].startTime, daytime);
envr_p = &g_env_light.stage_envr_info[*prev_envr_id_p];
switch (*prev_pat_p) {
case 0:
psel_idx = envr_p->pselect_id[0];
break;
case 1:
psel_idx = envr_p->pselect_id[1];
break;
case 2:
psel_idx = envr_p->pselect_id[2];
break;
case 3:
psel_idx = envr_p->pselect_id[3];
break;
case 4:
psel_idx = envr_p->pselect_id[4];
break;
case 5:
psel_idx = envr_p->pselect_id[5];
break;
case 6:
psel_idx = envr_p->pselect_id[6];
break;
case 7:
psel_idx = envr_p->pselect_id[7];
break;
default:
if (*prev_pat_p > 7 && *prev_pat_p < 64) {
psel_idx = envr_p->pselect_id[*prev_pat_p];
}
break;
}
// use a specific palette for underwater (except during morpheel and zant fight)
if (g_env_light.camera_water_in_status &&
strcmp(dComIfGp_getStartStageName(), "D_MN08D") != 0 &&
strcmp(dComIfGp_getStartStageName(), "D_MN01A") != 0)
{
if (g_env_light.wether_pat1 == 0) {
psel_idx = envr_p->pselect_id[8];
} else {
psel_idx = envr_p->pselect_id[9];
}
}
// use a specific palette for rollgoal (camera eye gets set below 0.0)
else if (strcmp(dComIfGp_getStartStageName(), "R_SP127") == 0)
{
camera_class* camera_p = dComIfGp_getCamera(0);
if (camera_p != NULL && camera_p->lookat.eye.y < 0.0f) {
psel_idx = envr_p->pselect_id[10];
}
}
if (psel_idx > 250) {
psel_idx = 0;
}
stage_pselect_info_class* pselect_p = &g_env_light.stage_pselect_info[psel_idx];
switch (*start_pat_pal_id_p) {
case 0:
*prev_pal_start_id_p = pselect_p->palette_id[0];
break;
case 1:
*prev_pal_start_id_p = pselect_p->palette_id[1];
break;
case 2:
*prev_pal_start_id_p = pselect_p->palette_id[2];
break;
case 3:
*prev_pal_start_id_p = pselect_p->palette_id[3];
break;
case 4:
*prev_pal_start_id_p = pselect_p->palette_id[4];
break;
case 5:
*prev_pal_start_id_p = pselect_p->palette_id[5];
break;
}
switch (*end_pat_pal_id_p) {
case 0:
*prev_pal_end_id_p = pselect_p->palette_id[0];
break;
case 1:
*prev_pal_end_id_p = pselect_p->palette_id[1];
break;
case 2:
*prev_pal_end_id_p = pselect_p->palette_id[2];
break;
case 3:
*prev_pal_end_id_p = pselect_p->palette_id[3];
break;
case 4:
*prev_pal_end_id_p = pselect_p->palette_id[4];
break;
case 5:
*prev_pal_end_id_p = pselect_p->palette_id[5];
break;
}
envr_p = &g_env_light.stage_envr_info[*next_envr_id_p];
switch (*next_pat_p) {
case 0:
psel_idx = envr_p->pselect_id[0];
break;
case 1:
psel_idx = envr_p->pselect_id[1];
break;
case 2:
psel_idx = envr_p->pselect_id[2];
break;
case 3:
psel_idx = envr_p->pselect_id[3];
break;
case 4:
psel_idx = envr_p->pselect_id[4];
break;
case 5:
psel_idx = envr_p->pselect_id[5];
break;
case 6:
psel_idx = envr_p->pselect_id[6];
break;
case 7:
psel_idx = envr_p->pselect_id[7];
break;
default:
if (*next_pat_p > 7 && *next_pat_p < 64) {
psel_idx = envr_p->pselect_id[*next_pat_p];
}
break;
}
if (psel_idx > 250) {
psel_idx = 0;
}
pselect_p = &g_env_light.stage_pselect_info[psel_idx];
if (*prev_envr_id_p != *next_envr_id_p || *prev_pat_p != *next_pat_p) {
if (pselect_p->change_rate < (1.0f / 30)) {
pselect_p->change_rate = (1.0f / 30);
}
if (g_env_light.mColPatMode == 0) {
if (pselect_p->change_rate > 0.0f) {
*pattern_ratio_p += (1.0f / 30) / pselect_p->change_rate;
}
// pattern change rate is faster in hyrule field
if (strcmp(dComIfGp_getStartStageName(), "F_SP121") == 0 &&
*prev_pat_p == *next_pat_p)
{
*pattern_ratio_p += (1.0f / 15);
}
if (*pattern_ratio_p >= 1.0f) {
*prev_envr_id_p = *next_envr_id_p;
*prev_pat_p = *next_pat_p;
*pattern_ratio_p = 1.0f;
}
}
}
// use a specific palette for underwater (except during morpheel and zant fight)
if (g_env_light.camera_water_in_status &&
strcmp(dComIfGp_getStartStageName(), "D_MN08D") != 0 &&
strcmp(dComIfGp_getStartStageName(), "D_MN01A") != 0)
{
if (g_env_light.wether_pat1 == 0) {
pselect_p = &g_env_light.stage_pselect_info[envr_p->pselect_id[8]];
} else {
pselect_p = &g_env_light.stage_pselect_info[envr_p->pselect_id[9]];
}
}
// use a specific palette for rollgoal (camera eye gets set below 0.0)
else if (strcmp(dComIfGp_getStartStageName(), "R_SP127") == 0)
{
camera_class* camera_p = dComIfGp_getCamera(0);
if (camera_p != NULL && camera_p->lookat.eye.y < 0.0f) {
pselect_p = &g_env_light.stage_pselect_info[envr_p->pselect_id[10]];
}
}
switch (*start_pat_pal_id_p) {
case 0:
*next_pal_start_id_p = pselect_p->palette_id[0];
break;
case 1:
*next_pal_start_id_p = pselect_p->palette_id[1];
break;
case 2:
*next_pal_start_id_p = pselect_p->palette_id[2];
break;
case 3:
*next_pal_start_id_p = pselect_p->palette_id[3];
break;
case 4:
*next_pal_start_id_p = pselect_p->palette_id[4];
break;
case 5:
*next_pal_start_id_p = pselect_p->palette_id[5];
break;
}
switch (*end_pat_pal_id_p) {
case 0:
*next_pal_end_id_p = pselect_p->palette_id[0];
break;
case 1:
*next_pal_end_id_p = pselect_p->palette_id[1];
break;
case 2:
*next_pal_end_id_p = pselect_p->palette_id[2];
break;
case 3:
*next_pal_end_id_p = pselect_p->palette_id[3];
break;
case 4:
*next_pal_end_id_p = pselect_p->palette_id[4];
break;
case 5:
*next_pal_end_id_p = pselect_p->palette_id[5];
break;
}
break;
}
if (*prev_pal_start_id_p > 250) {
*prev_pal_start_id_p = 0;
}
if (*next_pal_start_id_p > 250) {
*next_pal_start_id_p = 0;
}
if (*prev_pal_end_id_p > 250) {
*prev_pal_end_id_p = 0;
}
if (*next_pal_end_id_p > 250) {
*next_pal_end_id_p = 0;
}
}
/* 801A0340-801A040C 19AC80 00CC+00 3/3 0/0 0/0 .text
* dKy_calc_color_set__FP11_GXColorS10P15color_RGB_classP15color_RGB_classP15color_RGB_classP15color_RGB_classff11_GXColorS10f
*/
void dKy_calc_color_set(GXColorS10* out_color_p, color_RGB_class* color_a_start_p,
color_RGB_class* color_b_start_p, color_RGB_class* color_a_end_p,
color_RGB_class* color_b_end_p, f32 color_ratio, f32 blend_ratio,
GXColorS10 add_col, f32 scale) {
out_color_p->r =
kankyo_color_ratio_set(color_a_start_p->r, color_a_end_p->r, color_ratio,
color_b_start_p->r, color_b_end_p->r, blend_ratio, add_col.r, scale);
out_color_p->g =
kankyo_color_ratio_set(color_a_start_p->g, color_a_end_p->g, color_ratio,
color_b_start_p->g, color_b_end_p->g, blend_ratio, add_col.g, scale);
out_color_p->b =
kankyo_color_ratio_set(color_a_start_p->b, color_a_end_p->b, color_ratio,
color_b_start_p->b, color_b_end_p->b, blend_ratio, add_col.b, scale);
}
inline bool checkZoraWearFlg() {
return dComIfGs_getSelectEquipClothes() == fpcNm_ITEM_WEAR_ZORA;
}
/* 801A040C-801A133C 19AD4C 0F30+00 1/1 0/0 0/0 .text setLight__18dScnKy_env_light_cFv */
void dScnKy_env_light_c::setLight() {
u8* init_timer = &g_env_light.light_init_timer;
camera_class* camera_p = dComIfGp_getCamera(0);
GXColorS10 add_col;
add_col.r = 0;
add_col.g = 0;
add_col.b = 0;
add_col.a = 0;
if (camera_p != NULL) {
if (g_env_light.camera_water_in_status) {
dBgS_CamGndChk_Wtr camchk;
cXyz chkpos;
if (checkZoraWearFlg() && !daPy_py_c::checkNowWolf()) {
dKy_WaterIn_Light_set();
}
chkpos = camera_p->lookat.eye;
chkpos.y += 100000.0f;
camchk.SetPos(&chkpos);
dComIfG_Bgsp().GroundCross(&camchk);
cLib_addCalc(&g_env_light.field_0x1258, 1.0f, 0.25f, 0.01f, 0.0000000000001f);
} else {
g_env_light.field_0x1258 = 0.0f;
}
u8 prev_pal_start_id;
u8 next_pal_start_id;
u8 prev_pal_end_id;
u8 next_pal_end_id;
f32 color_ratio;
int start_pat_pal_id;
int end_pat_pal_id;
setLight_palno_get(&g_env_light.PrevCol, &g_env_light.UseCol, &g_env_light.wether_pat0,
&g_env_light.wether_pat1, &prev_pal_start_id, &prev_pal_end_id,
&next_pal_start_id, &next_pal_end_id, &color_ratio, &start_pat_pal_id,
&end_pat_pal_id, &g_env_light.pat_ratio, init_timer);
if (prev_pal_start_id == 0xFF) {
actor_amb_col.r = 255;
actor_amb_col.g = 0;
actor_amb_col.b = 0;
for (int i = 0; i < 4; i++) {
bg_amb_col[i].r = 255;
bg_amb_col[i].g = 0;
bg_amb_col[i].b = 0;
bg_amb_col[i].a = 0;
}
} else {
stage_palette_info_class* prev_pal_start_p = &g_env_light.stage_palette_info[prev_pal_start_id];
stage_palette_info_class* prev_pal_end_p = &g_env_light.stage_palette_info[prev_pal_end_id];
stage_palette_info_class* next_pal_start_p = &g_env_light.stage_palette_info[next_pal_start_id];
stage_palette_info_class* next_pal_end_p = &g_env_light.stage_palette_info[next_pal_end_id];
dKy_calc_color_set(&actor_amb_col, &prev_pal_start_p->actor_amb_col,
&next_pal_start_p->actor_amb_col, &prev_pal_end_p->actor_amb_col,
&next_pal_end_p->actor_amb_col, color_ratio, g_env_light.pat_ratio,
add_col,
g_env_light.field_0x1210 * (g_env_light.now_actcol_ratio * g_env_light.now_actcol_ratio));
for (int i = 0; i < 4; i++) {
if (i != 3 || (strcmp(dComIfGp_getStartStageName(), "R_SP127") != 0 &&
strcmp(dComIfGp_getStartStageName(), "F_SP127") != 0))
{
dKy_calc_color_set(&bg_amb_col[i], &prev_pal_start_p->bg_amb_col[i],
&next_pal_start_p->bg_amb_col[i],
&prev_pal_end_p->bg_amb_col[i],
&next_pal_end_p->bg_amb_col[i], color_ratio,
g_env_light.pat_ratio, add_col, g_env_light.now_bgcol_ratio);
}
}
if (daPy_py_c::checkNowWolfPowerUp()) {
dKy_WolfPowerup_AmbCol(&actor_amb_col);
dKy_WolfPowerup_BgAmbCol(&bg_amb_col[0]);
}
bg_amb_col[1].a = (u8)kankyo_color_ratio_set(
prev_pal_start_p->BG1_amb_alpha, prev_pal_end_p->BG1_amb_alpha, color_ratio,
next_pal_start_p->BG1_amb_alpha, next_pal_end_p->BG1_amb_alpha,
g_env_light.pat_ratio, 0, 1.0f);
bg_amb_col[2].a = (u8)kankyo_color_ratio_set(
prev_pal_start_p->BG2_amb_alpha, prev_pal_end_p->BG2_amb_alpha, color_ratio,
next_pal_start_p->BG2_amb_alpha, next_pal_end_p->BG2_amb_alpha,
g_env_light.pat_ratio, 0, 1.0f);
bg_amb_col[3].a = (u8)kankyo_color_ratio_set(
prev_pal_start_p->BG3_amb_alpha, prev_pal_end_p->BG3_amb_alpha, color_ratio,
next_pal_start_p->BG3_amb_alpha, next_pal_end_p->BG3_amb_alpha,
g_env_light.pat_ratio, 0, 1.0f);
s16 bg_light_inf = kankyo_color_ratio_set(
prev_pal_start_p->bg_light_influence, prev_pal_end_p->bg_light_influence,
color_ratio, next_pal_start_p->bg_light_influence,
next_pal_end_p->bg_light_influence, g_env_light.pat_ratio, 0, 1.0f);
bg_light_influence = bg_light_inf * 0.01f;
if (bg_light_influence > 2.0f) {
bg_light_influence = 1.0f;
}
mFogDensity = kankyo_color_ratio_set(
prev_pal_start_p->cloud_shadow_density, prev_pal_end_p->cloud_shadow_density,
color_ratio, next_pal_start_p->cloud_shadow_density,
next_pal_end_p->cloud_shadow_density, g_env_light.pat_ratio, 0, 1.0f);
if (daPy_py_c::checkNowWolfPowerUp()) {
mFogDensity = -1;
}
for (int i = 0; i < 6; i++) {
dKy_calc_color_set(&dungeonlight_col[i], &prev_pal_start_p->plight_col[i],
&next_pal_start_p->plight_col[i], &prev_pal_end_p->plight_col[i],
&next_pal_end_p->plight_col[i], color_ratio,
g_env_light.pat_ratio, add_col, g_env_light.now_bgcol_ratio);
if (daPy_py_c::checkNowWolfPowerUp()) {
dungeonlight_col[i].r = 0;
dungeonlight_col[i].g = 0;
dungeonlight_col[i].b = 0;
}
g_env_light.dungeonlight[i].mColor.r = dungeonlight_col[i].r;
g_env_light.dungeonlight[i].mColor.g = dungeonlight_col[i].g;
g_env_light.dungeonlight[i].mColor.b = dungeonlight_col[i].b;
}
dKy_calc_color_set(&fog_col, &prev_pal_start_p->fog_col, &next_pal_start_p->fog_col,
&prev_pal_end_p->fog_col, &next_pal_end_p->fog_col, color_ratio,
g_env_light.pat_ratio, addcol_fog, g_env_light.now_fogcol_ratio);
mFogNear = float_kankyo_color_ratio_set(
prev_pal_start_p->fog_start_z, prev_pal_end_p->fog_start_z, color_ratio,
next_pal_start_p->fog_start_z, next_pal_end_p->fog_start_z, g_env_light.pat_ratio,
g_env_light.field_0x11ec, g_env_light.field_0x11f4);
mFogFar = float_kankyo_color_ratio_set(
prev_pal_start_p->fog_end_z, prev_pal_end_p->fog_end_z, color_ratio,
next_pal_start_p->fog_end_z, next_pal_end_p->fog_end_z, g_env_light.pat_ratio,
g_env_light.field_0x11f0, g_env_light.field_0x11f4);
if (daPy_py_c::checkNowWolfPowerUp()) {
fog_col.r = 0;
fog_col.g = 0;
fog_col.b = 0;
dKy_WolfPowerup_FogNearFar(&mFogNear, &mFogFar);
}
u8 prev_bloom_start_id = prev_pal_start_p->bloom_tbl_id;
u8 next_bloom_start_id = next_pal_start_p->bloom_tbl_id;
u8 prev_bloom_end_id = prev_pal_end_p->bloom_tbl_id;
u8 next_bloom_end_id = next_pal_end_p->bloom_tbl_id;
if (daPy_py_c::checkNowWolfPowerUp()) {
next_bloom_end_id = 3;
prev_bloom_end_id = 3;
next_bloom_start_id = 3;
prev_bloom_start_id = 3;
}
f32 temp_f31;
if (g_env_light.field_0x12fc >= 0) {
prev_bloom_end_id = g_env_light.field_0x12fc;
next_bloom_end_id = g_env_light.field_0x12fc;
temp_f31 = color_ratio;
color_ratio = g_env_light.field_0x1278;
}
dKydata_BloomInfo_c* bloomInf0_p;
dKydata_BloomInfo_c* bloomInf1_p;
dKydata_BloomInfo_c* bloomInf2_p;
dKydata_BloomInfo_c* bloomInf3_p;
bloomInf0_p = dKyd_BloomInf_tbl_getp(prev_bloom_start_id);
bloomInf2_p = dKyd_BloomInf_tbl_getp(next_bloom_start_id);
bloomInf1_p = dKyd_BloomInf_tbl_getp(prev_bloom_end_id);
bloomInf3_p = dKyd_BloomInf_tbl_getp(next_bloom_end_id);
u8 bloom_point = kankyo_color_ratio_set(
bloomInf0_p->mThreshold, bloomInf1_p->mThreshold, color_ratio,
bloomInf2_p->mThreshold, bloomInf3_p->mThreshold, g_env_light.pat_ratio, 0, 1.0f);
mDoGph_gInf_c::getBloom()->setPoint(bloom_point);
u8 blure_size = (u8)kankyo_color_ratio_set(
bloomInf0_p->mBlurAmount, bloomInf1_p->mBlurAmount, color_ratio,
bloomInf2_p->mBlurAmount, bloomInf3_p->mBlurAmount, g_env_light.pat_ratio, 0, 1.0f);
if (dKy_darkworld_check()) {
static s16 S_fuwan_sin;
f32 sin = cM_ssin(S_fuwan_sin);
S_fuwan_sin += (s16)cM_rndF(2000.0f) + 500;
blure_size += (u8)(sin * (0.2f * blure_size));
}
mDoGph_gInf_c::getBloom()->setBlureSize(blure_size);
mDoGph_gInf_c::getBloom()->setBlureRatio(kankyo_color_ratio_set(
bloomInf0_p->mDensity, bloomInf1_p->mDensity, color_ratio, bloomInf2_p->mDensity,
bloomInf3_p->mDensity, g_env_light.pat_ratio, 0, 1.0f));
GXColor bloom_blend_col;
bloom_blend_col.r = kankyo_color_ratio_set(
bloomInf0_p->mColorR, bloomInf1_p->mColorR, color_ratio, bloomInf2_p->mColorR,
bloomInf3_p->mColorR, g_env_light.pat_ratio, 0, 1.0f);
bloom_blend_col.g = kankyo_color_ratio_set(
bloomInf0_p->mColorG, bloomInf1_p->mColorG, color_ratio, bloomInf2_p->mColorG,
bloomInf3_p->mColorG, g_env_light.pat_ratio, 0, 1.0f);
bloom_blend_col.b = kankyo_color_ratio_set(
bloomInf0_p->mColorB, bloomInf1_p->mColorB, color_ratio, bloomInf2_p->mColorB,
bloomInf3_p->mColorB, g_env_light.pat_ratio, 0, 1.0f);
bloom_blend_col.a =
kankyo_color_ratio_set(bloomInf0_p->mOrigDensity, bloomInf1_p->mOrigDensity,
color_ratio, bloomInf2_p->mOrigDensity,
bloomInf3_p->mOrigDensity, g_env_light.pat_ratio, 0, 1.0f);
mDoGph_gInf_c::getBloom()->setBlendColor(bloom_blend_col);
if (g_env_light.field_0x12fc >= 0) {
color_ratio = temp_f31;
}
GXColor bloom_mono_col;
bloom_mono_col.r = kankyo_color_ratio_set(
bloomInf0_p->mSaturateSubtractR, bloomInf1_p->mSaturateSubtractR, color_ratio,
bloomInf2_p->mSaturateSubtractR, bloomInf3_p->mSaturateSubtractR,
g_env_light.pat_ratio, 0, 1.0f);
bloom_mono_col.g = kankyo_color_ratio_set(
bloomInf0_p->mSaturateSubtractG, bloomInf1_p->mSaturateSubtractG, color_ratio,
bloomInf2_p->mSaturateSubtractG, bloomInf3_p->mSaturateSubtractG,
g_env_light.pat_ratio, 0, 1.0f);
bloom_mono_col.b = kankyo_color_ratio_set(
bloomInf0_p->mSaturateSubtractB, bloomInf1_p->mSaturateSubtractB, color_ratio,
bloomInf2_p->mSaturateSubtractB, bloomInf3_p->mSaturateSubtractB,
g_env_light.pat_ratio, 0, 1.0f);
bloom_mono_col.a = kankyo_color_ratio_set(
bloomInf0_p->mSaturateSubtractA, bloomInf1_p->mSaturateSubtractA, color_ratio,
bloomInf2_p->mSaturateSubtractA, bloomInf3_p->mSaturateSubtractA,
g_env_light.pat_ratio, 0, 1.0f);
mDoGph_gInf_c::getBloom()->setMonoColor(bloom_mono_col);
if (bloom_point >= 0xFF) {
mDoGph_gInf_c::getBloom()->setEnable(0);
} else {
u8 mode = 0;
mDoGph_gInf_c::getBloom()->setEnable(1);
if (prev_bloom_start_id != 0 && bloomInf0_p->mType != 0) {
mode = 1;
} else if (next_bloom_start_id != 0 && bloomInf2_p->mType != 0) {
mode = 1;
} else if (prev_bloom_end_id != 0 && bloomInf1_p->mType != 0) {
mode = 1;
} else if (next_bloom_end_id != 0 && bloomInf3_p->mType != 0) {
mode = 1;
}
mDoGph_gInf_c::getBloom()->setMode(mode);
}
f32 var_f30;
if (dKy_Outdoor_check() == true) {
static f32 now_shadow_alpha[] = {0.25f, 0.35f, 0.6f, 0.6f, 0.25f, 0.35f};
f32 var_f1;
f32 var_f2;
f32 var_f4;
f32 var_f5;
if (start_pat_pal_id < 6) {
var_f1 = now_shadow_alpha[start_pat_pal_id];
} else {
var_f1 = 0.25f;
}
if (end_pat_pal_id < 6) {
var_f2 = now_shadow_alpha[end_pat_pal_id];
} else {
var_f2 = 0.25f;
}
var_f4 = 0.25f;
var_f5 = 0.25f;
if (prev_pal_start_p == next_pal_start_p) {
var_f4 = var_f1;
var_f5 = var_f2;
}
var_f30 = float_kankyo_color_ratio_set(var_f1, var_f2, color_ratio, var_f4, var_f5,
g_env_light.pat_ratio, 0.0f, 0.0f);
field_0x123c = 0.8f;
if (mColpatWeather != 0) {
var_f30 *= 0.4f;
}
} else {
var_f30 = 0.4f;
field_0x123c = 0.65f;
}
if (dKy_darkworld_check()) {
var_f30 = 0.55f;
field_0x123c = 0.55f;
}
if (g_env_light.light_init_timer != 0) {
field_0x1238 = var_f30;
} else {
cLib_addCalc(&field_0x1238, var_f30, 0.05f, 0.005f, 0.000001f);
}
stage_vrboxcol_info_class* prev_vrboxcol_start_p = &g_env_light.stage_vrboxcol_info[prev_pal_start_p->vrboxcol_id];
stage_vrboxcol_info_class* prev_vrboxcol_end_p = &g_env_light.stage_vrboxcol_info[prev_pal_end_p->vrboxcol_id];
stage_vrboxcol_info_class* next_vrboxcol_start_p = &g_env_light.stage_vrboxcol_info[next_pal_start_p->vrboxcol_id];
stage_vrboxcol_info_class* next_vrboxcol_end_p = &g_env_light.stage_vrboxcol_info[next_pal_end_p->vrboxcol_id];
vrbox_sky_col.r = kankyo_color_ratio_set(
prev_vrboxcol_start_p->sky_col.r, prev_vrboxcol_end_p->sky_col.r, color_ratio,
next_vrboxcol_start_p->sky_col.r, next_vrboxcol_end_p->sky_col.r,
g_env_light.pat_ratio, vrbox_addcol_sky0.r,
g_env_light.now_vrboxsoracol_ratio * g_env_light.unk_0x11c8);
vrbox_sky_col.g = kankyo_color_ratio_set(
prev_vrboxcol_start_p->sky_col.g, prev_vrboxcol_end_p->sky_col.g, color_ratio,
next_vrboxcol_start_p->sky_col.g, next_vrboxcol_end_p->sky_col.g,
g_env_light.pat_ratio, vrbox_addcol_sky0.g,
g_env_light.now_vrboxsoracol_ratio * g_env_light.unk_0x11cc);
vrbox_sky_col.b = kankyo_color_ratio_set(
prev_vrboxcol_start_p->sky_col.b, prev_vrboxcol_end_p->sky_col.b, color_ratio,
next_vrboxcol_start_p->sky_col.b, next_vrboxcol_end_p->sky_col.b,
g_env_light.pat_ratio, vrbox_addcol_sky0.b,
g_env_light.now_vrboxsoracol_ratio * g_env_light.unk_0x11d0);
vrbox_sky_col.a = 255;
vrbox_kumo_top_col.r = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kumo_top_col.r, prev_vrboxcol_end_p->kumo_top_col.r,
color_ratio, next_vrboxcol_start_p->kumo_top_col.r,
next_vrboxcol_end_p->kumo_top_col.r, g_env_light.pat_ratio, vrbox_addcol_sky0.r,
g_env_light.now_vrboxkumocol_ratio * g_env_light.unk_0x11c8);
vrbox_kumo_top_col.g = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kumo_top_col.g, prev_vrboxcol_end_p->kumo_top_col.g,
color_ratio, next_vrboxcol_start_p->kumo_top_col.g,
next_vrboxcol_end_p->kumo_top_col.g, g_env_light.pat_ratio, vrbox_addcol_sky0.g,
g_env_light.now_vrboxkumocol_ratio * g_env_light.unk_0x11cc);
vrbox_kumo_top_col.b = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kumo_top_col.b, prev_vrboxcol_end_p->kumo_top_col.b,
color_ratio, next_vrboxcol_start_p->kumo_top_col.b,
next_vrboxcol_end_p->kumo_top_col.b, g_env_light.pat_ratio, vrbox_addcol_sky0.b,
g_env_light.now_vrboxkumocol_ratio * g_env_light.unk_0x11d0);
vrbox_kumo_top_col.a = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kumo_shadow_col.a, prev_vrboxcol_end_p->kumo_shadow_col.a,
color_ratio, next_vrboxcol_start_p->kumo_shadow_col.a,
next_vrboxcol_end_p->kumo_shadow_col.a, g_env_light.pat_ratio, 0, 1.0f);
vrbox_kumo_bottom_col.r = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kumo_bottom_col.r, prev_vrboxcol_end_p->kumo_bottom_col.r,
color_ratio, next_vrboxcol_start_p->kumo_bottom_col.r,
next_vrboxcol_end_p->kumo_bottom_col.r, g_env_light.pat_ratio, vrbox_addcol_sky0.r,
g_env_light.now_vrboxkumocol_ratio * g_env_light.unk_0x11c8);
vrbox_kumo_bottom_col.g = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kumo_bottom_col.g, prev_vrboxcol_end_p->kumo_bottom_col.g,
color_ratio, next_vrboxcol_start_p->kumo_bottom_col.g,
next_vrboxcol_end_p->kumo_bottom_col.g, g_env_light.pat_ratio, vrbox_addcol_sky0.g,
g_env_light.now_vrboxkumocol_ratio * g_env_light.unk_0x11cc);
vrbox_kumo_bottom_col.b = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kumo_bottom_col.b, prev_vrboxcol_end_p->kumo_bottom_col.b,
color_ratio, next_vrboxcol_start_p->kumo_bottom_col.b,
next_vrboxcol_end_p->kumo_bottom_col.b, g_env_light.pat_ratio, vrbox_addcol_sky0.b,
g_env_light.now_vrboxkumocol_ratio * g_env_light.unk_0x11d0);
vrbox_kumo_shadow_col.r = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kumo_shadow_col.r, prev_vrboxcol_end_p->kumo_shadow_col.r,
color_ratio, next_vrboxcol_start_p->kumo_shadow_col.r,
next_vrboxcol_end_p->kumo_shadow_col.r, g_env_light.pat_ratio, vrbox_addcol_sky0.r,
g_env_light.now_vrboxkumocol_ratio * g_env_light.unk_0x11c8);
vrbox_kumo_shadow_col.g = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kumo_shadow_col.g, prev_vrboxcol_end_p->kumo_shadow_col.g,
color_ratio, next_vrboxcol_start_p->kumo_shadow_col.g,
next_vrboxcol_end_p->kumo_shadow_col.g, g_env_light.pat_ratio, vrbox_addcol_sky0.g,
g_env_light.now_vrboxkumocol_ratio * g_env_light.unk_0x11cc);
vrbox_kumo_shadow_col.b = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kumo_shadow_col.b, prev_vrboxcol_end_p->kumo_shadow_col.b,
color_ratio, next_vrboxcol_start_p->kumo_shadow_col.b,
next_vrboxcol_end_p->kumo_shadow_col.b, g_env_light.pat_ratio, vrbox_addcol_sky0.b,
g_env_light.now_vrboxkumocol_ratio * g_env_light.unk_0x11d0);
vrbox_kasumi_outer_col.r = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kasumi_outer_col.r, prev_vrboxcol_end_p->kasumi_outer_col.r,
color_ratio, next_vrboxcol_start_p->kasumi_outer_col.r,
next_vrboxcol_end_p->kasumi_outer_col.r, g_env_light.pat_ratio,
vrbox_addcol_kasumi.r, g_env_light.now_vrboxsoracol_ratio * g_env_light.unk_0x11c8);
vrbox_kasumi_outer_col.g = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kasumi_outer_col.g, prev_vrboxcol_end_p->kasumi_outer_col.g,
color_ratio, next_vrboxcol_start_p->kasumi_outer_col.g,
next_vrboxcol_end_p->kasumi_outer_col.g, g_env_light.pat_ratio,
vrbox_addcol_kasumi.g, g_env_light.now_vrboxsoracol_ratio * g_env_light.unk_0x11cc);
vrbox_kasumi_outer_col.b = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kasumi_outer_col.b, prev_vrboxcol_end_p->kasumi_outer_col.b,
color_ratio, next_vrboxcol_start_p->kasumi_outer_col.b,
next_vrboxcol_end_p->kasumi_outer_col.b, g_env_light.pat_ratio,
vrbox_addcol_kasumi.b, g_env_light.now_vrboxsoracol_ratio * g_env_light.unk_0x11d0);
vrbox_kasumi_outer_col.a = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kasumi_outer_col.a, prev_vrboxcol_end_p->kasumi_outer_col.a,
color_ratio, next_vrboxcol_start_p->kasumi_outer_col.a,
next_vrboxcol_end_p->kasumi_outer_col.a, g_env_light.pat_ratio, 0, 1.0f);
vrbox_kasumi_inner_col.r = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kasumi_inner_col.r, prev_vrboxcol_end_p->kasumi_inner_col.r,
color_ratio, next_vrboxcol_start_p->kasumi_inner_col.r,
next_vrboxcol_end_p->kasumi_inner_col.r, g_env_light.pat_ratio,
vrbox_addcol_kasumi.r, g_env_light.now_vrboxsoracol_ratio * g_env_light.unk_0x11c8);
vrbox_kasumi_inner_col.g = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kasumi_inner_col.g, prev_vrboxcol_end_p->kasumi_inner_col.g,
color_ratio, next_vrboxcol_start_p->kasumi_inner_col.g,
next_vrboxcol_end_p->kasumi_inner_col.g, g_env_light.pat_ratio,
vrbox_addcol_kasumi.g, g_env_light.now_vrboxsoracol_ratio * g_env_light.unk_0x11cc);
vrbox_kasumi_inner_col.b = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kasumi_inner_col.b, prev_vrboxcol_end_p->kasumi_inner_col.b,
color_ratio, next_vrboxcol_start_p->kasumi_inner_col.b,
next_vrboxcol_end_p->kasumi_inner_col.b, g_env_light.pat_ratio,
vrbox_addcol_kasumi.b, g_env_light.now_vrboxsoracol_ratio * g_env_light.unk_0x11d0);
vrbox_kasumi_inner_col.a = kankyo_color_ratio_set(
prev_vrboxcol_start_p->kasumi_inner_col.a, prev_vrboxcol_end_p->kasumi_inner_col.a,
color_ratio, next_vrboxcol_start_p->kasumi_inner_col.a,
next_vrboxcol_end_p->kasumi_inner_col.a, g_env_light.pat_ratio, 0, 1.0f);
if (daPy_py_c::checkNowWolfPowerUp()) {
vrbox_sky_col.r = 0;
vrbox_sky_col.g = 0;
vrbox_sky_col.b = 0;
vrbox_kumo_top_col.r = 0;
vrbox_kumo_top_col.g = 0;
vrbox_kumo_top_col.b = 0;
vrbox_kumo_bottom_col.r = 0;
vrbox_kumo_bottom_col.g = 0;
vrbox_kumo_bottom_col.b = 0;
vrbox_kumo_shadow_col.r = 0;
vrbox_kumo_shadow_col.g = 0;
vrbox_kumo_shadow_col.b = 0;
vrbox_kasumi_outer_col.r = 0;
vrbox_kasumi_outer_col.g = 0;
vrbox_kasumi_outer_col.b = 0;
vrbox_kasumi_inner_col.r = 0;
vrbox_kasumi_inner_col.g = 0;
vrbox_kasumi_inner_col.b = 0;
}
}
}
}
/* 801A133C-801A16C0 19BC7C 0384+00 2/2 0/0 0/0 .text
* setLight_bg__18dScnKy_env_light_cFP12dKy_tevstr_cP11_GXColorS10P11_GXColorS10PfPf */
void dScnKy_env_light_c::setLight_bg(dKy_tevstr_c* tevstr_p, GXColorS10* bg_col_p,
GXColorS10* fog_col_p, f32* fog_near_p, f32* fog_far_p) {
tevstr_p->wether_pat0 = g_env_light.wether_pat0;
tevstr_p->wether_pat1 = g_env_light.wether_pat1;
if (tevstr_p->wether_pat0 != tevstr_p->wether_pat1) {
tevstr_p->pat_ratio = g_env_light.pat_ratio;
}
u8 prev_pal_start_id;
u8 next_pal_start_id;
u8 prev_pal_end_id;
u8 next_pal_end_id;
f32 color_ratio;
int start_pat_pal_id;
int end_pat_pal_id;
int i;
setLight_palno_get(&tevstr_p->PrevCol, &tevstr_p->UseCol, &tevstr_p->wether_pat0,
&tevstr_p->wether_pat1, &prev_pal_start_id, &prev_pal_end_id,
&next_pal_start_id, &next_pal_end_id, &color_ratio, &start_pat_pal_id,
&end_pat_pal_id, &tevstr_p->pat_ratio, &tevstr_p->mInitTimer);
if (prev_pal_start_id == 0xFF) {
for (int i = 0; i < 4; i++) {
bg_col_p[i].r = 255;
bg_col_p[i].g = 0;
bg_col_p[i].b = 0;
}
} else {
stage_palette_info_class* prev_pal_start_p = &g_env_light.stage_palette_info[prev_pal_start_id];
stage_palette_info_class* prev_pal_end_p = &g_env_light.stage_palette_info[prev_pal_end_id];
stage_palette_info_class* next_pal_start_p = &g_env_light.stage_palette_info[next_pal_start_id];
stage_palette_info_class* next_pal_end_p = &g_env_light.stage_palette_info[next_pal_end_id];
for (int i = 0; i < 4; i++) {
dKy_calc_color_set(&bg_col_p[i], &prev_pal_start_p->bg_amb_col[i],
&next_pal_start_p->bg_amb_col[i], &prev_pal_end_p->bg_amb_col[i],
&next_pal_end_p->bg_amb_col[i], color_ratio, tevstr_p->pat_ratio,
bg_addcol_amb, g_env_light.now_bgcol_ratio);
}
if (daPy_py_c::checkNowWolfEyeUp()) {
dKy_WolfPowerup_BgAmbCol(bg_col_p);
}
bg_col_p[3].a = 255;
bg_col_p[2].a = 255;
bg_col_p[1].a = 255;
bg_col_p[0].a = 255;
GXColorS10 plight_colors[6];
for (i = 0; i < 6; i++) {
dKy_calc_color_set(&plight_colors[i], &prev_pal_start_p->plight_col[i],
&next_pal_start_p->plight_col[i], &prev_pal_end_p->plight_col[i],
&next_pal_end_p->plight_col[i], color_ratio, tevstr_p->pat_ratio,
bg_addcol_amb, g_env_light.now_bgcol_ratio);
if (daPy_py_c::checkNowWolfEyeUp()) {
plight_colors[i].r = 0;
plight_colors[i].g = 0;
plight_colors[i].b = 0;
}
J3DLightInfo& light_info = tevstr_p->mLights[i].getLightInfo();
GXColor light_color;
light_color.r = plight_colors[i].r;
light_color.g = plight_colors[i].g;
light_color.b = plight_colors[i].b;
light_color.a = plight_colors[i].a;
light_info.mColor = dKy_light_influence_col(&light_color, tevstr_p->field_0x374);
}
dKy_calc_color_set(fog_col_p, &prev_pal_start_p->fog_col, &next_pal_start_p->fog_col,
&prev_pal_end_p->fog_col, &next_pal_end_p->fog_col, color_ratio,
tevstr_p->pat_ratio, addcol_fog, g_env_light.now_fogcol_ratio);
*fog_near_p = float_kankyo_color_ratio_set(
prev_pal_start_p->fog_start_z, prev_pal_end_p->fog_start_z, color_ratio,
next_pal_start_p->fog_start_z, next_pal_end_p->fog_start_z, tevstr_p->pat_ratio,
g_env_light.field_0x11ec, g_env_light.field_0x11f4);
*fog_far_p = float_kankyo_color_ratio_set(
prev_pal_start_p->fog_end_z, prev_pal_end_p->fog_end_z, color_ratio,
next_pal_start_p->fog_end_z, next_pal_end_p->fog_end_z, tevstr_p->pat_ratio,
g_env_light.field_0x11f0, g_env_light.field_0x11f4);
if (daPy_py_c::checkNowWolfEyeUp()) {
fog_col_p->r = 0;
fog_col_p->g = 0;
fog_col_p->b = 0;
dKy_WolfPowerup_FogNearFar(fog_near_p, fog_far_p);
}
}
}
/* 801A16C0-801A1D64 19C000 06A4+00 1/1 0/0 0/0 .text
* setLight_actor__18dScnKy_env_light_cFP12dKy_tevstr_cP11_GXColorS10PfPf */
void dScnKy_env_light_c::setLight_actor(dKy_tevstr_c* tevstr_p, GXColorS10* fog_col_p,
f32* fog_near_p, f32* fog_far_p) {
u8 prev_pal_start_id;
u8 next_pal_start_id;
u8 prev_pal_end_id;
u8 next_pal_end_id;
f32 color_ratio;
int start_pat_pal_id;
int end_pat_pal_id;
int i;
tevstr_p->wether_pat0 = g_env_light.wether_pat0;
tevstr_p->wether_pat1 = g_env_light.wether_pat1;
if (tevstr_p->wether_pat0 != tevstr_p->wether_pat1) {
tevstr_p->pat_ratio = g_env_light.pat_ratio;
} else if (tevstr_p->PrevCol == tevstr_p->UseCol) {
tevstr_p->pat_ratio = 0.0f;
}
setLight_palno_get(&tevstr_p->PrevCol, &tevstr_p->UseCol, &tevstr_p->wether_pat0,
&tevstr_p->wether_pat1, &prev_pal_start_id, &prev_pal_end_id,
&next_pal_start_id, &next_pal_end_id, &color_ratio, &start_pat_pal_id,
&end_pat_pal_id, &tevstr_p->pat_ratio, &tevstr_p->mInitTimer);
if (prev_pal_start_id == 0xFF) {
for (i = 0; i < 4; i++) {
tevstr_p->AmbCol.r = 255;
tevstr_p->AmbCol.g = 0;
tevstr_p->AmbCol.b = 0;
}
} else {
stage_palette_info_class* prev_pal_start_p = &g_env_light.stage_palette_info[prev_pal_start_id];
stage_palette_info_class* prev_pal_end_p = &g_env_light.stage_palette_info[prev_pal_end_id];
stage_palette_info_class* next_pal_start_p = &g_env_light.stage_palette_info[next_pal_start_id];
stage_palette_info_class* next_pal_end_p = &g_env_light.stage_palette_info[next_pal_end_id];
if (tevstr_p->Type == 10 || tevstr_p->Type == 9 || tevstr_p->Material_id != 0) {
dKy_calc_color_set(&tevstr_p->AmbCol, &prev_pal_start_p->actor_amb_col,
&next_pal_start_p->actor_amb_col, &prev_pal_end_p->actor_amb_col,
&next_pal_end_p->actor_amb_col, color_ratio, tevstr_p->pat_ratio,
actor_addcol_amb,
tevstr_p->field_0x374 *
(g_env_light.now_actcol_ratio * g_env_light.now_actcol_ratio));
} else {
dKy_calc_color_set(&tevstr_p->AmbCol, &prev_pal_start_p->actor_amb_col,
&next_pal_start_p->actor_amb_col, &prev_pal_end_p->actor_amb_col,
&next_pal_end_p->actor_amb_col, color_ratio, tevstr_p->pat_ratio,
actor_addcol_amb,
tevstr_p->field_0x374 *
(g_env_light.field_0x1210 * (g_env_light.now_actcol_ratio * g_env_light.now_actcol_ratio)));
}
if (daPy_py_c::checkNowWolfPowerUp()) {
dKy_WolfPowerup_AmbCol(&tevstr_p->AmbCol);
}
GXColorS10 plight_col[6];
for (i = 0; i < 6; i++) {
J3DLightInfo* light_info = &tevstr_p->mLights[i].getLightInfo();
if (i == 0) {
if (tevstr_p->Type == 10 || tevstr_p->Type == 9 || tevstr_p->Material_id != 0) {
dKy_calc_color_set(&plight_col[i], &prev_pal_start_p->plight_col[i],
&next_pal_start_p->plight_col[i],
&prev_pal_end_p->plight_col[i],
&next_pal_end_p->plight_col[i], color_ratio,
tevstr_p->pat_ratio, actor_addcol_amb, 1.0f);
if (daPy_py_c::checkNowWolfPowerUp()) {
plight_col[i].r = 0;
plight_col[i].g = 0;
plight_col[i].b = 0;
}
light_info = &tevstr_p->mLights[i].getLightInfo();
GXColor light_col;
light_col.r = plight_col[i].r;
light_col.g = plight_col[i].g;
light_col.b = plight_col[i].b;
light_col.a = plight_col[i].a;
light_info->mColor = dKy_light_influence_col(&light_col, tevstr_p->field_0x374);
} else {
dKy_calc_color_set(
&plight_col[i], &prev_pal_start_p->plight_col[i],
&next_pal_start_p->plight_col[i], &prev_pal_end_p->plight_col[i],
&next_pal_end_p->plight_col[i], color_ratio, tevstr_p->pat_ratio,
actor_addcol_amb, g_env_light.field_0x1210);
if (daPy_py_c::checkNowWolfPowerUp()) {
plight_col[i].r = 0;
plight_col[i].g = 0;
plight_col[i].b = 0;
}
kankyo_color_ratio_calc(&light_info->mColor, plight_col[i],
field_0x1210 * tevstr_p->field_0x374);
}
} else if (tevstr_p->Type == 10 || tevstr_p->Type == 9 || tevstr_p->Material_id != 0) {
dKy_calc_color_set(&plight_col[i], &prev_pal_start_p->plight_col[i],
&next_pal_start_p->plight_col[i], &prev_pal_end_p->plight_col[i],
&next_pal_end_p->plight_col[i], color_ratio, tevstr_p->pat_ratio,
actor_addcol_amb,
g_env_light.now_actcol_ratio * g_env_light.now_actcol_ratio);
if (daPy_py_c::checkNowWolfPowerUp()) {
plight_col[i].r = 0;
plight_col[i].g = 0;
plight_col[i].b = 0;
}
GXColor light_col;
light_col.r = plight_col[i].r;
light_col.g = plight_col[i].g;
light_col.b = plight_col[i].b;
light_col.a = plight_col[i].a;
light_info->mColor = dKy_light_influence_col(&light_col, tevstr_p->field_0x374);
} else {
dKy_calc_color_set(&plight_col[i], &prev_pal_start_p->plight_col[i],
&next_pal_start_p->plight_col[i], &prev_pal_end_p->plight_col[i],
&next_pal_end_p->plight_col[i], color_ratio, tevstr_p->pat_ratio,
actor_addcol_amb,
g_env_light.field_0x1210 * (g_env_light.now_actcol_ratio *
g_env_light.now_actcol_ratio));
if (daPy_py_c::checkNowWolfPowerUp()) {
plight_col[i].r = 0;
plight_col[i].g = 0;
plight_col[i].b = 0;
}
kankyo_color_ratio_calc(&light_info->mColor, plight_col[i],
field_0x1210 * tevstr_p->field_0x374);
}
}
dKy_calc_color_set(fog_col_p, &prev_pal_start_p->fog_col, &next_pal_start_p->fog_col,
&prev_pal_end_p->fog_col, &next_pal_end_p->fog_col, color_ratio,
tevstr_p->pat_ratio, addcol_fog, g_env_light.now_fogcol_ratio);
if ((tevstr_p->Type != 10 && tevstr_p->Type != 9) || g_env_light.field_0x1210 == 1.0f) {
*fog_near_p = float_kankyo_color_ratio_set(
prev_pal_start_p->fog_start_z, prev_pal_end_p->fog_start_z, color_ratio,
next_pal_start_p->fog_start_z, next_pal_end_p->fog_start_z, tevstr_p->pat_ratio,
g_env_light.field_0x11ec, g_env_light.field_0x11f4);
*fog_far_p = float_kankyo_color_ratio_set(
prev_pal_start_p->fog_end_z, prev_pal_end_p->fog_end_z, color_ratio,
next_pal_start_p->fog_end_z, next_pal_end_p->fog_end_z, tevstr_p->pat_ratio,
g_env_light.field_0x11f0, g_env_light.field_0x11f4);
} else {
*fog_near_p = float_kankyo_color_ratio_set(
prev_pal_start_p->fog_start_z, prev_pal_end_p->fog_start_z, color_ratio,
next_pal_start_p->fog_start_z, next_pal_end_p->fog_start_z, tevstr_p->pat_ratio,
g_env_light.field_0x11ec, 0.0f);
*fog_far_p = float_kankyo_color_ratio_set(
prev_pal_start_p->fog_end_z, prev_pal_end_p->fog_end_z, color_ratio,
next_pal_start_p->fog_end_z, next_pal_end_p->fog_end_z, tevstr_p->pat_ratio,
g_env_light.field_0x11f0, 0.0f);
}
if (daPy_py_c::checkNowWolfPowerUp()) {
fog_col_p->r = 0;
fog_col_p->g = 0;
fog_col_p->b = 0;
dKy_WolfPowerup_FogNearFar(fog_near_p, fog_far_p);
}
}
}
/* 801A1D64-801A1F58 19C6A4 01F4+00 1/1 0/0 0/0 .text
* settingTevStruct_colget_actor__18dScnKy_env_light_cFP4cXyzP12dKy_tevstr_cP11_GXColorS10P11_GXColorS10PfPf
*/
void dScnKy_env_light_c::settingTevStruct_colget_actor(cXyz* unused, dKy_tevstr_c* tevstr_p,
GXColorS10* out_color_p,
GXColorS10* fog_col_p, f32* fog_near_p,
f32* fog_far_p) {
if (tevstr_p->YukaCol != 0xFF) {
f32 target = tevstr_p->YukaCol / 100.0f;
if (g_env_light.mActorLightEffect == 100) {
cLib_addCalc(&tevstr_p->field_0x374, target, 0.25f, 0.05f, 0.000001f);
}
} else if (tevstr_p->room_no >= 0) {
tevstr_p->UseCol = tevstr_p->room_no;
if (g_env_light.mActorLightEffect == 100) {
cLib_addCalc(&tevstr_p->field_0x374, 1.0f, 0.25f, 0.05f, 0.000001f);
}
} else {
tevstr_p->UseCol = 0;
}
if ((tevstr_p->Type >= 1 && tevstr_p->Type <= 7) ||
(tevstr_p->Type == 9 && dKy_darkworld_check()))
{
if ((tevstr_p->Type != 2 && tevstr_p->Type != 3) || dKy_darkworld_check()) {
tevstr_p->field_0x374 = 0.0f;
}
}
if (tevstr_p->PrevCol != tevstr_p->UseCol &&
(tevstr_p->pat_ratio >= 1.0f || tevstr_p->pat_ratio <= 0.0f))
{
tevstr_p->pat_ratio = 0.0f;
}
if (tevstr_p->Type != 8) {
setLight_actor(tevstr_p, fog_col_p, fog_near_p, fog_far_p);
out_color_p->r = tevstr_p->AmbCol.r;
out_color_p->g = tevstr_p->AmbCol.g;
out_color_p->b = tevstr_p->AmbCol.b;
out_color_p->a = tevstr_p->AmbCol.a;
} else {
GXColorS10 BG_col[4];
setLight_bg(tevstr_p, BG_col, fog_col_p, fog_near_p, fog_far_p);
out_color_p->r = BG_col[0].r;
out_color_p->g = BG_col[0].g;
out_color_p->b = BG_col[0].b;
out_color_p->a = BG_col[0].a;
}
}
/* 801A1F58-801A2090 19C898 0138+00 1/1 0/0 0/0 .text
* settingTevStruct_colget_player__18dScnKy_env_light_cFP12dKy_tevstr_c */
void dScnKy_env_light_c::settingTevStruct_colget_player(dKy_tevstr_c* tevstr_p) {
if (tevstr_p->YukaCol != 0xFF) {
f32 target = tevstr_p->YukaCol / 100.0f;
if (g_env_light.mActorLightEffect == 100) {
cLib_addCalc(&tevstr_p->field_0x374, target, 0.25f, 0.05f, 0.000001f);
}
} else if (tevstr_p->room_no >= 0) {
tevstr_p->UseCol = tevstr_p->room_no;
if (g_env_light.mActorLightEffect == 100) {
cLib_addCalc(&tevstr_p->field_0x374, 1.0f, 0.25f, 0.05f, 0.000001f);
}
}
if (g_env_light.UseCol != tevstr_p->UseCol) {
if (tevstr_p->UseCol == g_env_light.PrevCol) {
g_env_light.PrevCol = g_env_light.UseCol;
g_env_light.UseCol = tevstr_p->UseCol;
g_env_light.pat_ratio = 1.0f - g_env_light.pat_ratio;
tevstr_p->pat_ratio = 1.0f - g_env_light.pat_ratio;
} else if (g_env_light.pat_ratio >= 1.0f || g_env_light.pat_ratio <= 0.0f) {
g_env_light.UseCol = tevstr_p->UseCol;
g_env_light.pat_ratio = 0.0f;
tevstr_p->pat_ratio = 0.0f;
}
}
}
/* 801A2090-801A2128 19C9D0 0098+00 1/1 0/0 0/0 .text cLib_addCalcU8__FPUcUcss */
static void cLib_addCalcU8(u8* i_value, u8 i_target, s16 i_scale, s16 i_maxStep) {
s16 step, value;
value = *i_value;
step = i_target - value;
if (abs(step) >= i_scale) {
step /= i_scale;
}
if (step > i_maxStep) {
value += i_maxStep;
} else if (step < -i_maxStep) {
value -= i_maxStep;
} else {
value += step;
}
*i_value = value;
}
/* 801A2128-801A37C4 19CA68 169C+00 2/1 0/0 0/0 .text
* settingTevStruct_plightcol_plus__18dScnKy_env_light_cFP4cXyzP12dKy_tevstr_c11_GXColorS1011_GXColorS10Uc
*/
void dScnKy_env_light_c::settingTevStruct_plightcol_plus(cXyz* pos_p, dKy_tevstr_c* tevstr_p,
GXColorS10 param_2, GXColorS10 param_3,
u8 init_timer) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
cXyz light_pos;
Vec spDC;
MtxP view_mtx = j3dSys.getViewMtx();
f32 light_dist;
f32 light_power;
f32 light_yuragi;
int sp40 = 0;
int sp3C = 0;
int light_inf_id;
u8 sp9 = 0;
f32 sp34 = 1.0f;
daPy_py_c* player = daPy_getPlayerActorClass();
if (pos_p != NULL) {
J3DLightInfo* light_info = &tevstr_p->mLightObj.getLightInfo();
light_info->mColor.a = 0xFF;
light_inf_id = dKy_light_influence_id(*pos_p, 0);
BOOL sp44 = 0;
if (tevstr_p->Type == 7 || tevstr_p->Type == 1 ||
((tevstr_p->Type == 2 || tevstr_p->Type == 6 || tevstr_p->Type == 3) &&
dKy_darkworld_check()) ||
tevstr_p->Type == 4 || tevstr_p->Type == 5)
{
light_inf_id = -2;
} else if (tevstr_p->Type == 9 && dKy_darkworld_check()) {
light_inf_id = -2;
}
if (light_inf_id >= 0) {
light_dist = dKy_light_influence_distance(*pos_p, light_inf_id);
light_power = dKy_light_influence_power(light_inf_id);
if (light_power < 0.001f) {
light_power = 0.001f;
}
if (light_dist < 1000.0f + light_power) {
sp44 = 1;
}
}
if (sp44 == 0) {
light_pos = kankyo->base_light.mPosition;
light_dist = kankyo->base_light.mPosition.abs(*pos_p);
light_power = kankyo->base_light.mPow;
light_yuragi = kankyo->base_light.mFluctuation;
field_0x10f8.r = 0;
field_0x10f8.g = 0;
field_0x10f8.b = 0;
if ((light_inf_id <= -2 || (light_inf_id == -1 && dKy_Outdoor_check() == TRUE) ||
strcmp(dComIfGp_getStartStageName(), "D_MN09A") == 0))
{
cXyz camfwd;
camera_class* camera = (camera_class*)dComIfGp_getCamera(0);
J3DLightInfo* light0_info = &tevstr_p->mLights[0].getLightInfo();
sp9 = 1;
dKyr_get_vectle_calc(&camera->lookat.center, &camera->lookat.eye, &camfwd);
light_pos = *pos_p + (camfwd * 500.0f);
light_pos.y += 40.0f;
if (tevstr_p->Type >= 1 && tevstr_p->Type <= 9) {
dKyr_get_vectle_calc(&camera->lookat.center, &camera->lookat.eye, &camfwd);
light_pos = camera->lookat.eye + (camfwd * 180.0f);
}
field_0x10f8.r = light0_info->mColor.r;
field_0x10f8.g = light0_info->mColor.g;
field_0x10f8.b = light0_info->mColor.b;
light_yuragi = 0.0f;
light_power = 120.0f;
light_dist = 100.0f;
sp40 = 1;
sp3C = 1;
if (strcmp(dComIfGp_getStartStageName(), "D_MN09A") == 0) {
if (dComIfG_play_c::getLayerNo(0) == 0) {
if (tevstr_p->Type == 0) {
field_0x10f8.r = 0x1E;
field_0x10f8.g = 0x37;
field_0x10f8.b = 0x6E;
light_pos.y += -800.0f;
light_power = 250.0f;
}
} else if (dComIfG_play_c::getLayerNo(0) == 1 && tevstr_p->Type == 0) {
field_0x10f8.r = 0x3C;
field_0x10f8.g = 0x5F;
field_0x10f8.b = 0x64;
light_pos.y += -800.0f;
light_power = 150.0f;
}
}
if (tevstr_p != NULL && tevstr_p->mLightInf.a != 0) {
field_0x10f8.r = tevstr_p->mLightInf.r * 4;
field_0x10f8.g = tevstr_p->mLightInf.g * 4;
field_0x10f8.b = tevstr_p->mLightInf.b * 4;
}
switch (tevstr_p->Type) {
case 1:
field_0x10f8.r = 500;
field_0x10f8.g = 500;
field_0x10f8.b = 500;
light_dist = 90.0f;
light_power = 5000.0f;
break;
case 4:
field_0x10f8.r = 500;
field_0x10f8.g = 500;
field_0x10f8.b = 500;
light_dist = 90.0f;
light_power = 5000.0f;
break;
case 5:
field_0x10f8.r = 170;
field_0x10f8.g = 170;
field_0x10f8.b = 170;
light_dist = 90.0f;
light_power = 5000.0f;
break;
case 2:
if (dKy_darkworld_check()) {
field_0x10f8.r = 103;
field_0x10f8.g = 129;
field_0x10f8.b = 199;
light_dist = 90.0f;
light_power = 5000.0f;
}
break;
case 3:
if (dKy_darkworld_check()) {
field_0x10f8.r = 53;
field_0x10f8.g = 53;
field_0x10f8.b = 80;
light_dist = 90.0f;
light_power = 5000.0f;
}
break;
case 9:
if (dKy_darkworld_check()) {
field_0x10f8.r = 110;
field_0x10f8.g = 110;
field_0x10f8.b = 140;
light_dist = 90.0f;
light_power = 5000.0f;
}
break;
case 7: {
f32 sp34 = tevstr_p->TevColor.a / 255.0f;
field_0x10f8.r = 180;
field_0x10f8.g = 180;
field_0x10f8.b = 180;
light_dist = 90.0f;
light_pos.y += -120.0f;
f32 sp24 = cM_ssin(g_Counter.mCounter0 * 325);
f32 sp20 = cM_scos(g_Counter.mCounter0 * 285);
cLib_addCalcU8(&light_info->mColor.a, fabsf(sp24 * 255.0f), 2, 255);
light_info->mColor.a *= sp34;
light_pos.y += sp20 * 500.0f;
light_pos.y -= 80.0f;
light_power = 300.0f;
break;
}
case 6:
if (dKy_darkworld_check()) {
field_0x10f8.r = 255;
field_0x10f8.g = 255;
field_0x10f8.b = 255;
light_dist = 90.0f;
light_power = 5000.0f;
}
break;
}
}
} else {
light_pos = dKy_light_influence_pos(light_inf_id);
field_0x10f8 = dKy_light_influence_col(light_inf_id);
light_yuragi = dKy_light_influence_yuragi(light_inf_id);
}
f32 var_f31;
if (light_power <= 0.0f && sp3C == 0) {
var_f31 = 1.0f;
} else {
var_f31 = light_dist / light_power;
}
if (var_f31 > 1.0f) {
var_f31 = 1.0f;
}
var_f31 = (1.0f - var_f31);
var_f31 *= g_env_light.now_actcol_ratio;
if ((tevstr_p->Type != 10 && tevstr_p->Type != 9) || tevstr_p->Material_id != 0) {
field_0x10f0.r = field_0x10f8.r * (var_f31 * kankyo->field_0x1210);
field_0x10f0.g = field_0x10f8.g * (var_f31 * kankyo->field_0x1210);
field_0x10f0.b = field_0x10f8.b * (var_f31 * kankyo->field_0x1210);
} else {
field_0x10f0.r = field_0x10f8.r * var_f31;
field_0x10f0.g = field_0x10f8.g * var_f31;
field_0x10f0.b = field_0x10f8.b * var_f31;
}
if (field_0x10f0.r > 0xFF) {
field_0x10f0.r = 0xFF;
}
if (field_0x10f0.g > 0xFF) {
field_0x10f0.g = 0xFF;
}
if (field_0x10f0.b > 0xFF) {
field_0x10f0.b = 0xFF;
}
if (init_timer != 0 || var_f31 <= 0.0f || sp9 == 0) {
light_info->mColor.r = field_0x10f0.r;
light_info->mColor.g = field_0x10f0.g;
light_info->mColor.b = field_0x10f0.b;
} else {
cLib_addCalcU8(&light_info->mColor.r, field_0x10f0.r, 10, 0x80);
cLib_addCalcU8(&light_info->mColor.g, field_0x10f0.g, 10, 0x80);
cLib_addCalcU8(&light_info->mColor.b, field_0x10f0.b, 10, 0x80);
}
field_0x10f0.r = param_2.r + (int)(light_info->mColor.r * (0.1f * var_f31));
field_0x10f0.g = param_2.g + (int)(light_info->mColor.g * (0.1f * var_f31));
field_0x10f0.b = param_2.b + (int)(light_info->mColor.b * (0.1f * var_f31));
if (field_0x10f0.r > 0xFF) {
field_0x10f0.r = 0xFF;
}
if (field_0x10f0.g > 0xFF) {
field_0x10f0.g = 0xFF;
}
if (field_0x10f0.b > 0xFF) {
field_0x10f0.b = 0xFF;
}
if (init_timer != 0 || sp40 != 0 || tevstr_p->field_0x384 != 0) {
tevstr_p->field_0x32c = light_pos;
} else {
f32 sp18 = pos_p->abs(tevstr_p->field_0x32c);
f32 sp14 = sp18 / 10000.0f;
if (sp14 > 1.0f) {
sp14 = 1.0f;
}
sp14 *= sp14;
sp18 = pos_p->abs(light_pos);
f32 var_f28 = sp18 / 5000.0f;
if (var_f28 > 1.0f) {
var_f28 = 1.0f;
}
var_f28 = 1.0f - var_f28;
var_f28 *= var_f28 * var_f28;
f32 sp1C = 10.0f + (10000.0f * sp14) + (100.0f * var_f28);
cLib_addCalc(&tevstr_p->field_0x32c.x, light_pos.x, 0.5f, sp1C, 0.001f);
cLib_addCalc(&tevstr_p->field_0x32c.y, light_pos.y, 0.5f, sp1C, 0.001f);
cLib_addCalc(&tevstr_p->field_0x32c.z, light_pos.z, 0.5f, sp1C, 0.001f);
}
cXyz spC4;
cXyz spB8;
spB8 = tevstr_p->field_0x32c;
cMtx_multVec(view_mtx, &spB8, &spDC);
if (dKy_shadow_mode_check(4) == 0) {
if ((tevstr_p->Type == 9 || tevstr_p->Type == 10) &&
(player->getSinkShapeOffset() < -20.0f || player->checkSinkDead() || dKy_camera_water_in_status_check() || !player->checkSwimUp()))
{
cLib_addCalc(&tevstr_p->mLightPosWorld.x, pos_p->x, 0.5f, 5000.0f, 0.1f);
cLib_addCalc(&tevstr_p->mLightPosWorld.y, 1000.0f + pos_p->y, 0.5f, 5000.0f, 0.1f);
cLib_addCalc(&tevstr_p->mLightPosWorld.z, pos_p->z, 0.5f, 5000.0f, 0.1f);
} else if ((kankyo->shadow_mode & 1) || (kankyo->shadow_mode & 2)) {
cLib_addCalc(&tevstr_p->mLightPosWorld.x, g_env_light.field_0x10a0.x, 0.5f, 5000.0f,
0.1f);
cLib_addCalc(&tevstr_p->mLightPosWorld.y, g_env_light.field_0x10a0.y, 0.5f, 5000.0f,
0.1f);
cLib_addCalc(&tevstr_p->mLightPosWorld.z, g_env_light.field_0x10a0.z, 0.5f, 5000.0f,
0.1f);
} else if (sp9 != 0) {
if (init_timer != 0 || tevstr_p->field_0x384 != 0) {
tevstr_p->mLightPosWorld = kankyo->base_light.mPosition;
} else {
cLib_addCalc(&tevstr_p->mLightPosWorld.x, kankyo->base_light.mPosition.x, 0.25f,
1000.0f, 0.0001f);
cLib_addCalc(&tevstr_p->mLightPosWorld.y, kankyo->base_light.mPosition.y, 0.25f,
1000.0f, 0.0001f);
cLib_addCalc(&tevstr_p->mLightPosWorld.z, kankyo->base_light.mPosition.z, 0.25f,
1000.0f, 0.0001f);
}
} else {
cXyz spAC;
u8 sp8 = 0;
spAC = tevstr_p->field_0x32c;
for (int i = 0; i < 6; i++) {
if (kankyo->field_0x0c18[i].field_0x26 == 1) {
if (kankyo->field_0x0c18[i].mPos.abs(*pos_p) < spAC.abs(*pos_p) &&
kankyo->field_0x0c18[i].mPos.abs(*pos_p) < 1000.0f)
{
spAC = kankyo->field_0x0c18[i].mPos;
sp8 = i + 1;
}
}
}
if (sp8 == 0) {
if (init_timer != 0 || tevstr_p->field_0x384 != 0) {
tevstr_p->mLightPosWorld = tevstr_p->field_0x32c;
} else {
cLib_addCalc(&tevstr_p->mLightPosWorld.x, tevstr_p->field_0x32c.x, 0.25f,
1000.0f, 0.0001f);
cLib_addCalc(&tevstr_p->mLightPosWorld.y, tevstr_p->field_0x32c.y, 0.25f,
1000.0f, 0.0001f);
cLib_addCalc(&tevstr_p->mLightPosWorld.z, tevstr_p->field_0x32c.z, 0.25f,
1000.0f, 0.0001f);
}
} else {
if (init_timer != 0 || tevstr_p->field_0x384 != 0) {
tevstr_p->mLightPosWorld = kankyo->field_0x0c18[sp8 - 1].mPos;
} else {
cLib_addCalc(&tevstr_p->mLightPosWorld.x,
kankyo->field_0x0c18[sp8 - 1].mPos.x, 0.25f, 1000.0f, 0.0001f);
cLib_addCalc(&tevstr_p->mLightPosWorld.y,
kankyo->field_0x0c18[sp8 - 1].mPos.y, 0.25f, 1000.0f, 0.0001f);
cLib_addCalc(&tevstr_p->mLightPosWorld.z,
kankyo->field_0x0c18[sp8 - 1].mPos.z, 0.25f, 1000.0f, 0.0001f);
}
var_f31 = kankyo->field_0x0c18[sp8 - 1].mPos.abs(*pos_p) / 500.0f;
if (var_f31 > 1.0f) {
var_f31 = 1.0f;
}
var_f31 = 1.0f - var_f31;
}
}
if ((tevstr_p->Type == 9 || tevstr_p->Type == 10) &&
(player->checkSinkDead() || dComIfGp_checkPlayerStatus0(0, 0x02000308) ||
dComIfGp_checkPlayerStatus1(0, 0x02000000) || player->checkMagneBootsOn()))
{
cLib_addCalc(&tevstr_p->field_0x344, 0.0f, 0.75f, 0.21f, 0.0001f);
} else if (tevstr_p->Type == 9 && player->getSinkShapeOffset() < -35.0f) {
cLib_addCalc(&tevstr_p->field_0x344, 0.0f, 0.1f, 0.001f, 0.00001f);
} else if (tevstr_p->Type == 10 && player->getSinkShapeOffset() < -100.0f) {
cLib_addCalc(&tevstr_p->field_0x344, 0.0f, 0.1f, 0.001f, 0.00001f);
} else if (init_timer != 0) {
tevstr_p->field_0x344 = kankyo->field_0x1238 +
(var_f31 * (kankyo->field_0x123c - kankyo->field_0x1238));
} else {
cLib_addCalc(&tevstr_p->field_0x344,
kankyo->field_0x1238 +
(var_f31 * (kankyo->field_0x123c - kankyo->field_0x1238)),
0.75f, 0.04f, 0.000001f);
}
if (tevstr_p->field_0x344 > 1.0f) {
tevstr_p->field_0x344 = 1.0f;
}
}
light_info->mLightPosition = spDC;
light_info->mLightDirection = g_env_light.field_0x1064;
light_info->mCosAtten.x = 1.0f;
light_info->mCosAtten.y = 0.0f;
light_info->mCosAtten.z = 0.0f;
light_info->mDistAtten.x = 1.0f;
light_info->mDistAtten.y = 0.0f;
light_info->mDistAtten.z = 0.0f;
}
}
/* 8042DD70-8042E07C 05AA90 030C+00 1/2 8/8 9/9 .bss g_mEnvSeMgr */
Z2EnvSeMgr g_mEnvSeMgr;
/* 8042E07C-8042E7BC 05AD9C 0740+00 5/4 0/0 0/0 .bss lightStatusData */
static LightStatus lightStatusData[8];
/* 801A37C4-801A441C 19E104 0C58+00 2/1 14/14 515/515 .text
* settingTevStruct__18dScnKy_env_light_cFiP4cXyzP12dKy_tevstr_c */
void dScnKy_env_light_c::settingTevStruct(int tevstrType, cXyz* pos_p, dKy_tevstr_c* tevstr_p) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
u8 init_timer = tevstr_p->mInitTimer;
GXColorS10 amb_col;
GXColorS10 fog_tev_col;
f32 fog_near;
f32 fog_far;
cXyz pos;
if (tevstr_p->room_no < 0) {
tevstr_p->room_no = dComIfGp_roomControl_getStayNo();
}
if (pos_p != NULL) {
pos = *pos_p;
} else {
pos.set(0.0f, 0.0f, 0.0f);
}
if (tevstr_p != NULL && g_env_light.mActorLightEffect != 100) {
tevstr_p->field_0x374 = g_env_light.mActorLightEffect / 100.0f;
}
tevstr_p->Type = tevstrType;
if (tevstr_p->Material_use_fg != 123 && tevstr_p->Material_use_fg != 124) {
dKy_tevstr_init(tevstr_p, dComIfGp_roomControl_getStayNo(), 0xFF);
OS_REPORT_ERROR("\n\ntevstr init Non. Material_use_fg[%d] setroom=[%d]\n",
tevstr_p->Material_use_fg, dComIfGp_roomControl_getStayNo());
}
tevstr_p->Material_use_fg = 124;
actor_amb_col.a = 255;
if (tevstrType == 14) {
camera_class* camera_p = (camera_class*)dComIfGp_getCamera(0);
cXyz calc_pos;
tevstr_p->mLightMode = 0;
// @bug room_no is a signed char, so this will always evaluate to false
if (tevstr_p->room_no >= 128) {
tevstr_p->UseCol = 0;
} else {
tevstr_p->UseCol = tevstr_p->room_no;
}
if (!dKy_darkworld_check()) {
field_0x10f0.r = 24;
field_0x10f0.g = 24;
field_0x10f0.b = 24;
field_0x10f0.a = 255;
} else {
field_0x10f0.r = 55;
field_0x10f0.g = 55;
field_0x10f0.b = 77;
}
fog_tev_col.r = 255;
fog_tev_col.g = 255;
fog_tev_col.b = 255;
fog_near = 30000.0f;
fog_far = 30000.0f;
dKyr_get_vectle_calc(&pos, &camera_p->lookat.eye, &calc_pos);
for (int i = 0; i < 6; i++) {
J3DLightInfo& light_info = tevstr_p->mLights[i].getLightInfo();
if (i == 0) {
if (!dKy_darkworld_check()) {
light_info.mColor.r = 126;
light_info.mColor.g = 110;
light_info.mColor.b = 89;
} else {
light_info.mColor.r = 0;
light_info.mColor.g = 0;
light_info.mColor.b = 0;
}
} else if (i == 1) {
if (!dKy_darkworld_check()) {
light_info.mColor.r = 24;
light_info.mColor.g = 41;
light_info.mColor.b = 50;
} else {
light_info.mColor.r = 0;
light_info.mColor.g = 0;
light_info.mColor.b = 0;
}
} else {
light_info.mColor.r = 0;
light_info.mColor.g = 0;
light_info.mColor.b = 0;
}
dKy_GXInitLightSpot(&light_info, 90.0f, GX_SP_OFF);
dKy_GXInitLightDistAttn(&light_info, 100000.0f, 0.99999f, GX_DA_STEEP);
light_info.mLightPosition.x = 0.0f;
light_info.mLightPosition.y = 0.0f;
light_info.mLightPosition.z = 0.0f;
if (i == 0) {
light_info.mLightPosition.x = 500.0f;
light_info.mLightPosition.y = 500.0f;
light_info.mLightPosition.z = 500.0f;
} else {
light_info.mLightPosition.x = -500.0f;
light_info.mLightPosition.y = -500.0f;
light_info.mLightPosition.z = -500.0f;
}
dKy_lightdir_set(0.0f, 0.0f, &light_info.mLightDirection);
light_info.mLightDirection.x = -light_info.mLightDirection.x;
light_info.mLightDirection.y = -light_info.mLightDirection.y;
light_info.mLightDirection.z = -light_info.mLightDirection.z;
}
MtxP view_mtx = j3dSys.getViewMtx();
Vec sp8C;
Vec sp80;
sp80.x = camera_p->lookat.eye.x;
sp80.y = camera_p->lookat.eye.y;
sp80.z = camera_p->lookat.eye.z;
cMtx_multVec(view_mtx, &sp80, &sp8C);
J3DLightInfo& light_info = tevstr_p->mLightObj.getLightInfo();
light_info.mLightPosition = sp8C;
tevstr_p->field_0x32c = sp80;
tevstr_p->mLightPosWorld = sp80;
light_info.mLightDirection = g_env_light.field_0x1064;
light_info.mColor.r = 0;
light_info.mColor.g = 0;
light_info.mColor.b = 0;
light_info.mCosAtten.x = 1.0f;
light_info.mCosAtten.y = 0.0f;
light_info.mCosAtten.z = 0.0f;
light_info.mDistAtten.x = 1.0f;
light_info.mDistAtten.y = 0.0f;
light_info.mDistAtten.z = 0.0f;
} else if (tevstrType == 12 || tevstrType == 13) {
camera_class* camera_p = (camera_class*)dComIfGp_getCamera(0);
tevstr_p->TevColor.r = 0;
tevstr_p->TevColor.g = 0;
tevstr_p->TevColor.b = 0;
tevstr_p->TevColor.a = 0;
tevstr_p->TevKColor.r = 0;
tevstr_p->TevKColor.g = 0;
tevstr_p->TevKColor.b = 0;
tevstr_p->TevKColor.a = 0;
tevstr_p->mLightMode = 0;
if (tevstr_p->room_no >= 128) {
tevstr_p->UseCol = 0;
} else {
tevstr_p->UseCol = tevstr_p->room_no;
}
if (tevstrType == 12) {
field_0x10f0.r = 25;
field_0x10f0.g = 20;
field_0x10f0.b = 25;
} else {
field_0x10f0.r = 40;
field_0x10f0.g = 35;
field_0x10f0.b = 30;
}
field_0x10f0.a = 0xFF;
fog_tev_col.r = 255;
fog_tev_col.g = 255;
fog_tev_col.b = 255;
fog_near = 30000.0f;
fog_far = 30000.0f;
for (int i = 0; i < 6; i++) {
J3DLightInfo& temp_r31 = tevstr_p->mLights[i].getLightInfo();
if (i == 0) {
if (tevstrType == 12) {
temp_r31.mLightPosition.x = -30000.0f;
temp_r31.mLightPosition.y = 18800.0f;
temp_r31.mLightPosition.z = 29000.0f;
temp_r31.mColor.r = 120;
temp_r31.mColor.g = 110;
temp_r31.mColor.b = 100;
} else {
temp_r31.mLightPosition.x = -37000.0f;
temp_r31.mLightPosition.y = 18800.0f;
temp_r31.mLightPosition.z = 500.0f;
temp_r31.mColor.r = 85;
temp_r31.mColor.g = 90;
temp_r31.mColor.b = 100;
}
} else if (i == 1) {
if (tevstrType == 12) {
temp_r31.mLightPosition.x = 14400.0f;
temp_r31.mLightPosition.y = 7500.0f;
temp_r31.mLightPosition.z = 3900.0f;
temp_r31.mColor.r = 30;
temp_r31.mColor.g = 45;
temp_r31.mColor.b = 30;
} else {
temp_r31.mLightPosition.x = 18000.0f;
temp_r31.mLightPosition.y = -6500.0f;
temp_r31.mLightPosition.z = -10000.0f;
temp_r31.mColor.r = 100;
temp_r31.mColor.g = 65;
temp_r31.mColor.b = 40;
}
} else {
temp_r31.mColor.r = 0;
temp_r31.mColor.g = 0;
temp_r31.mColor.b = 0;
}
dKy_GXInitLightSpot(&temp_r31, 90.0f, 0);
dKy_GXInitLightDistAttn(&temp_r31, 100000.0f, 0.99999f, 3);
dKy_lightdir_set(0.0f, 0.0f, &temp_r31.mLightDirection);
temp_r31.mLightDirection.x = -temp_r31.mLightDirection.x;
temp_r31.mLightDirection.y = -temp_r31.mLightDirection.y;
temp_r31.mLightDirection.z = -temp_r31.mLightDirection.z;
}
MtxP view_mtx = j3dSys.getViewMtx();
Vec sp74;
Vec sp68;
sp68.x = camera_p->lookat.eye.x;
sp68.y = camera_p->lookat.eye.y;
sp68.z = camera_p->lookat.eye.z;
J3DLightInfo& light_info = tevstr_p->mLightObj.getLightInfo();
cMtx_multVec(view_mtx, &sp68, &sp74);
light_info.mLightPosition = sp74;
if (tevstrType == 13) {
tevstr_p->field_0x32c = sp68;
tevstr_p->mLightPosWorld = sp68;
}
light_info.mLightDirection = g_env_light.field_0x1064;
light_info.mColor.r = 0;
light_info.mColor.g = 0;
light_info.mColor.b = 0;
light_info.mCosAtten.x = 1.0f;
light_info.mCosAtten.y = 0.0f;
light_info.mCosAtten.z = 0.0f;
light_info.mDistAtten.x = 1.0f;
light_info.mDistAtten.y = 0.0f;
light_info.mDistAtten.z = 0.0f;
} else if (!(tevstrType & 0xF0)) {
tevstr_p->mLightMode = 1;
amb_col = actor_amb_col;
fog_tev_col = fog_col;
fog_near = mFogNear;
fog_far = mFogFar;
if (tevstrType == 0 || tevstrType == 0 || tevstrType == 8 || tevstrType == 7 ||
tevstrType == 1 || tevstrType == 2 || tevstrType == 3 || tevstrType == 5 ||
tevstrType == 4 || tevstrType == 11)
{
settingTevStruct_colget_actor(pos_p, tevstr_p, &amb_col, &fog_tev_col, &fog_near,
&fog_far);
} else if (tevstrType == 10 || tevstrType == 9) {
if (g_env_light.player_room_no != (u8)dComIfGp_roomControl_getStayNo()) {
g_env_light.player_room_no = dComIfGp_roomControl_getStayNo();
mDoAud_setSceneName(
dComIfGp_getStartStageName(), dComIfGp_roomControl_getStayNo(),
dComIfG_play_c::getLayerNo_common(dComIfGp_getStartStageName(),
dComIfGp_roomControl_getStayNo(),
dComIfGp_getStartStageLayer()));
if (strcmp(dComIfGp_getStartStageName(), "F_SP121") == 0) {
mDoAud_load2ndDynamicWave();
}
}
init_timer = g_env_light.light_init_timer;
settingTevStruct_colget_player(tevstr_p);
settingTevStruct_colget_actor(pos_p, tevstr_p, &amb_col, &fog_tev_col, &fog_near,
&fog_far);
}
field_0x10f0.r = amb_col.r;
field_0x10f0.g = amb_col.g;
field_0x10f0.b = amb_col.b;
field_0x10f0.a = 255;
if (tevstrType != 11) {
settingTevStruct_plightcol_plus(pos_p, tevstr_p, amb_col, amb_col, init_timer);
}
if (tevstrType == 10 || tevstrType == 9) {
g_env_light.plight_near_pos = tevstr_p->mLightPosWorld;
}
} else {
tevstr_p->mLightMode = 0;
if (tevstr_p->Type != 20) {
tevstr_p->field_0x374 = g_env_light.bg_light_influence;
} else {
switch (tevstr_p->mLightInf.r) {
case 0:
tevstr_p->field_0x374 = 0.2f;
break;
case 1:
tevstr_p->field_0x374 = 0.3f;
break;
case 2:
tevstr_p->field_0x374 = 0.4f;
break;
case 3:
tevstr_p->field_0x374 = 0.6f;
break;
case 4:
tevstr_p->field_0x374 = 0.8f;
break;
case 5:
tevstr_p->field_0x374 = 0.9f;
break;
case 6:
tevstr_p->field_0x374 = 1.0f;
break;
case 7:
tevstr_p->field_0x374 = 1.2f;
break;
default:
tevstr_p->field_0x374 = 1.0f;
break;
}
}
// @bug room_no is a signed char, so this will always evaluate to false
if (tevstr_p->room_no >= 128) {
tevstr_p->UseCol = 0;
} else {
tevstr_p->UseCol = tevstr_p->room_no;
}
GXColorS10 BG_col[4];
setLight_bg(tevstr_p, BG_col, &fog_tev_col, &fog_near, &fog_far);
field_0x10f0 = BG_col[tevstrType & 3];
MtxP view_mtx = j3dSys.getViewMtx();
Vec sp5C;
cXyz pos;
bool var_r25_3 = 0;
pos.z = 0.0f;
pos.y = 0.0f;
pos.x = 0.0f;
int light_inf_id = dKy_light_influence_id(pos, 0);
if (light_inf_id >= 0 && g_env_light.pointlight[light_inf_id]->mIndex < 0) {
var_r25_3 = 1;
}
if (var_r25_3 == 1) {
pos = g_env_light.pointlight[light_inf_id]->mPosition;
J3DLightInfo& light_info = tevstr_p->mLightObj.getLightInfo();
cMtx_multVec(view_mtx, &pos, &sp5C);
light_info.mLightPosition = sp5C;
tevstr_p->field_0x32c = pos;
light_info.mLightDirection = g_env_light.field_0x1064;
light_info.mColor.a = g_env_light.pointlight[light_inf_id]->mColor.a;
light_info.mColor.r = g_env_light.pointlight[light_inf_id]->mColor.r;
light_info.mColor.g = g_env_light.pointlight[light_inf_id]->mColor.g;
light_info.mColor.b = g_env_light.pointlight[light_inf_id]->mColor.b;
dKy_GXInitLightSpot(&light_info, 90.0f, GX_SP_OFF);
dKy_GXInitLightDistAttn(&light_info,
g_env_light.pointlight[light_inf_id]->mPow * 0.001f, 0.99999f,
GX_DA_STEEP);
} else {
MtxP view_mtx = j3dSys.getViewMtx();
J3DLightInfo& light_info = tevstr_p->mLightObj.getLightInfo();
Vec sp44;
cMtx_multVec(view_mtx, &lightStatusData[0].position, &sp44);
light_info.mLightPosition = sp44;
tevstr_p->field_0x32c = lightStatusData[0].position;
light_info.mLightDirection = g_env_light.field_0x1064;
light_info.mColor.r = 0;
light_info.mColor.g = 0;
light_info.mColor.b = 0;
light_info.mCosAtten.x = 0.0f;
light_info.mCosAtten.y = 0.0f;
light_info.mCosAtten.z = 0.0f;
light_info.mDistAtten.x = 0.0f;
light_info.mDistAtten.y = 0.0f;
light_info.mDistAtten.z = 0.0f;
}
tevstr_p->mLightPosWorld = kankyo->base_light.mPosition;
}
field_0x10f0.a = 255;
tevstr_p->AmbCol = field_0x10f0;
tevstr_p->FogCol = fog_tev_col;
tevstr_p->mFogStartZ = fog_near;
tevstr_p->mFogEndZ = fog_far;
}
/* 801A441C-801A4420 19ED5C 0004+00 0/0 0/0 2/2 .text
* setLightTevColorType__18dScnKy_env_light_cFP12J3DModelDataP12dKy_tevstr_c */
void dScnKy_env_light_c::setLightTevColorType(J3DModelData*, dKy_tevstr_c*) {}
/* 801A4420-801A4C08 19ED60 07E8+00 2/2 0/0 0/0 .text
* setLightTevColorType_MAJI_sub__FP11J3DMaterialP12dKy_tevstr_ci */
// NONMATCHING - some minor issues with dKyd_maple_col_getp
static void setLightTevColorType_MAJI_sub(J3DMaterial* material_p, dKy_tevstr_c* tevstr_p,
int lightType) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
MtxP view_mtx = j3dSys.getViewMtx();
camera_class* camera = (camera_class*)dComIfGp_getCamera(0);
if (tevstr_p != NULL) {
J3DGXColor amb_col;
amb_col.r = tevstr_p->AmbCol.r;
amb_col.g = tevstr_p->AmbCol.g;
amb_col.b = tevstr_p->AmbCol.b;
amb_col.a = tevstr_p->AmbCol.a;
if (((tevstr_p->Type >= 1 && tevstr_p->Type <= 7) || tevstr_p->Type == 5 ||
tevstr_p->Type == 15 || (tevstr_p->Type == 9 && dKy_darkworld_check())) &&
((tevstr_p->Type != 2 && tevstr_p->Type != 3) || dKy_darkworld_check()))
{
amb_col.r = 0;
amb_col.g = 0;
amb_col.b = 0;
amb_col.a = 0;
if (tevstr_p->Type == 7) {
amb_col.a = 4;
}
if (tevstr_p->Type == 3) {
amb_col.r = 12;
amb_col.g = 12;
amb_col.b = 12;
} else if (tevstr_p->Type == 6) {
f32 var_r30 = fabsf(cM_ssin(g_Counter.mCounter0 * 662));
amb_col.r = 255.0f - (185.0f * var_r30);
amb_col.g = 255.0f - (185.0f * var_r30);
amb_col.b = 255.0f - (185.0f * var_r30);
} else if (tevstr_p->Type == 2) {
amb_col.r = 0x12;
amb_col.g = 0x12;
amb_col.b = 0x12;
} else if (tevstr_p->Type == 4) {
amb_col.r = 0xFF;
amb_col.g = 0x33;
amb_col.b = 0xB;
} else if (tevstr_p->Type == 5) {
amb_col.r = 0xA;
amb_col.g = 0xA;
amb_col.b = 8;
} else if (tevstr_p->Type == 15) {
amb_col.r = 0x19;
amb_col.g = 0x1E;
amb_col.b = 0x23;
}
}
material_p->setAmbColor(0, &amb_col);
if (lightType != 0) {
material_p->setTevColor(0, (J3DGXColorS10*)&tevstr_p->TevColor);
material_p->setTevKColor(0, (J3DGXColor*)&tevstr_p->TevKColor);
}
MtxP sp10 = j3dSys.getViewMtx();
if (sp10 != NULL) {
Vec sp28;
J3DLightInfo* sp20 = &tevstr_p->mLightObj.getLightInfo();
cMtx_multVec(sp10, &tevstr_p->field_0x32c, &sp28);
sp20->mLightPosition = sp28;
}
material_p->setLight(0, &tevstr_p->mLightObj);
if (view_mtx != NULL) {
if (lightType != 2) {
for (int i = 0; i < 6; i++) {
material_p->setLight(i + 2, &tevstr_p->mLights[i]);
}
} else if (g_env_light.fishing_hole_season >= 1 && g_env_light.fishing_hole_season <= 4)
{
color_RGB_class maple_color;
maple_color.r = dKyd_maple_col_getp()[g_env_light.fishing_hole_season + 7].r;
maple_color.g = dKyd_maple_col_getp()[g_env_light.fishing_hole_season + 7].g;
maple_color.b = dKyd_maple_col_getp()[g_env_light.fishing_hole_season + 7].b;
amb_col.r = 0xA;
amb_col.g = 0xA;
amb_col.b = 0xA;
f32 var_f31;
var_f31 = (amb_col.r * g_env_light.now_bgcol_ratio) / 10.0f;
var_f31 *= var_f31;
if (var_f31 > 1.0f) {
var_f31 = 1.0f;
}
amb_col.r = g_env_light.now_bgcol_ratio * (maple_color.r * var_f31);
var_f31 = (amb_col.g * g_env_light.now_bgcol_ratio) / 10.0f;
var_f31 *= var_f31;
if (var_f31 > 1.0f) {
var_f31 = 1.0f;
}
amb_col.g = g_env_light.now_bgcol_ratio * (maple_color.g * var_f31);
var_f31 = (amb_col.b * g_env_light.now_bgcol_ratio) / 10.0f;
var_f31 *= var_f31;
if (var_f31 > 1.0f) {
var_f31 = 1.0f;
}
amb_col.b = g_env_light.now_bgcol_ratio * (maple_color.b * var_f31);
material_p->setAmbColor(0, &amb_col);
for (int i = 0; i < 6; i++) {
if (i <= 1) {
J3DLightInfo* var_r28;
if (i == 0) {
kankyo->global_maple_col_change[i].light_obj = tevstr_p->mLights[i];
J3DLightInfo* sp8 =
&kankyo->global_maple_col_change[1].light_obj.getLightInfo();
var_r28 = &kankyo->global_maple_col_change[i].light_obj.getLightInfo();
sp8->mColor = var_r28->mColor;
} else {
var_r28 = &kankyo->global_maple_col_change[i].light_obj.getLightInfo();
}
color_RGB_class maple_color;
maple_color.r =
dKyd_maple_col_getp()[(g_env_light.fishing_hole_season + (i * 4))].r;
maple_color.g =
dKyd_maple_col_getp()[(g_env_light.fishing_hole_season + (i * 4))].g;
maple_color.b =
dKyd_maple_col_getp()[(g_env_light.fishing_hole_season + (i * 4))].b;
var_f31 = var_r28->mColor.r / 95.0f;
var_f31 *= var_f31;
if (var_f31 > 1.0f) {
var_f31 = 1.0f;
}
var_r28->mColor.r = maple_color.r;
var_r28->mColor.r *= var_f31;
var_f31 = var_r28->mColor.g / 95.0f;
var_f31 *= var_f31;
if (var_f31 > 1.0f) {
var_f31 = 1.0f;
}
var_r28->mColor.g = maple_color.g;
var_r28->mColor.g *= var_f31;
var_f31 = var_r28->mColor.b / 95.0f;
var_f31 *= var_f31;
if (var_f31 > 1.0f) {
var_f31 = 1.0f;
}
var_r28->mColor.b = maple_color.b;
var_r28->mColor.b *= var_f31;
material_p->setLight(i + 2, &kankyo->global_maple_col_change[i].light_obj);
} else {
material_p->setLight(i + 2, &tevstr_p->mLights[i]);
}
}
}
}
if (material_p->getFog() != NULL) {
J3DFogInfo* fog_info = material_p->getFog()->getFogInfo();
if (fog_info->mType != 0) {
fog_info->mStartZ = tevstr_p->mFogStartZ;
fog_info->mEndZ = tevstr_p->mFogEndZ;
if (dComIfGd_getView() != NULL) {
fog_info->mNearZ = dComIfGd_getView()->near;
fog_info->mFarZ = dComIfGd_getView()->far;
}
if (fog_info->mType == 7) {
fog_info->mType = 2;
fog_info->mColor.r = 0;
fog_info->mColor.g = 0;
fog_info->mColor.b = 0;
} else if (fog_info->mType == 6) {
fog_info->mColor.r = 0xFF;
fog_info->mColor.g = 0xFF;
fog_info->mColor.b = 0xFF;
} else {
fog_info->mColor.r = tevstr_p->FogCol.r;
fog_info->mColor.g = tevstr_p->FogCol.g;
fog_info->mColor.b = tevstr_p->FogCol.b;
}
fog_info->mAdjEnable = g_env_light.mFogAdjEnable;
if (fog_info->mAdjEnable == 1) {
fog_info->mCenter = g_env_light.mFogAdjCenter;
memcpy(&fog_info->mFogAdjTable, &g_env_light.mXFogTbl, sizeof(GXFogAdjTable));
}
}
}
}
}
/* 801A4C10-801A4DA0 19F550 0190+00 1/1 0/0 0/0 .text
* dKy_cloudshadow_scroll__FP12J3DModelDataP12dKy_tevstr_ci */
void dKy_cloudshadow_scroll(J3DModelData* modelData_p, dKy_tevstr_c* tevstr_p, int param_2) {
JUTNameTab* mat_nametbl = modelData_p->getMaterialName();
for (int i = modelData_p->getMaterialNum() - 1; i >= 0; i--) {
J3DMaterial* mat_p = modelData_p->getMaterialNodePointer(i);
int lightType = param_2;
if (tevstr_p->Material_id != 0 && tevstr_p->Material_id == i) {
lightType = 2;
}
setLightTevColorType_MAJI_sub(mat_p, tevstr_p, lightType);
const char* mat_name = mat_nametbl->getName(i);
if ((mat_name[3] == 'M' && mat_name[4] == 'A' && mat_name[5] == '0' &&
(mat_name[6] == '0' || mat_name[6] == '1')) ||
(mat_name[5] == '1' && mat_name[6] == '6'))
{
if (mat_name[6] == '0') {
J3DGXColor k_color;
k_color.r = g_env_light.mFogDensity;
k_color.g = 0;
k_color.b = 0;
k_color.a = 0;
mat_p->setTevKColor(1, &k_color);
}
if (mat_p->getTexGenBlock()->getTexMtx(1) != NULL) {
J3DTexMtxInfo* tex_mtx_inf =
&mat_p->getTexGenBlock()->getTexMtx(1)->getTexMtxInfo();
if (tex_mtx_inf != NULL && g_env_light.mpVrkumoPacket != NULL) {
tex_mtx_inf->mSRT.mTranslationX = g_env_light.mpVrkumoPacket->field_0x1150;
tex_mtx_inf->mSRT.mTranslationY = g_env_light.mpVrkumoPacket->field_0x1154;
}
}
}
}
}
/* 801A4DA0-801A4E90 19F6E0 00F0+00 0/0 18/18 536/536 .text
* setLightTevColorType_MAJI__18dScnKy_env_light_cFP12J3DModelDataP12dKy_tevstr_c */
void dScnKy_env_light_c::setLightTevColorType_MAJI(J3DModelData* modelData_p,
dKy_tevstr_c* tevstr_p) {
if (tevstr_p->Material_use_fg != 124) {
OS_REPORT_ERROR("\ncoltype tevstr init Non. Material_use_fg[%d]\n",
tevstr_p->Material_use_fg);
if (tevstr_p->Material_use_fg != 123) {
dKy_tevstr_init(tevstr_p, dComIfGp_roomControl_getStayNo(), 0xFF);
}
settingTevStruct(11, NULL, tevstr_p);
}
dKy_setLight_nowroom_actor(tevstr_p);
int lightType;
if (tevstr_p->Type > 10 && tevstr_p->Type != 12 && tevstr_p->Type != 13) {
lightType = 0;
} else {
lightType = 1;
}
if (tevstr_p->Type & 0x20) {
dKy_cloudshadow_scroll(modelData_p, tevstr_p, lightType);
} else {
for (int i = modelData_p->getMaterialNum() - 1; i >= 0; i--) {
setLightTevColorType_MAJI_sub(modelData_p->getMaterialNodePointer(i), tevstr_p,
lightType);
}
}
}
/* 801A4E90-801A4F24 19F7D0 0094+00 1/1 0/0 0/0 .text CalcTevColor__18dScnKy_env_light_cFv */
void dScnKy_env_light_c::CalcTevColor() {
fopAc_ac_c* player_p = dComIfGp_getPlayer(0);
if (player_p != NULL) {
mPlayerEfLightIdx = dKy_eflight_influence_id(player_p->current.pos, 0);
mPlayerPLightIdx = dKy_light_influence_id(player_p->current.pos, 0);
}
}
/* 801A4F24-801A4F64 19F864 0040+00 1/1 0/0 0/0 .text Sndpos__18dScnKy_env_light_cFv */
void dScnKy_env_light_c::Sndpos() {
if (sound_influence.timer != 0) {
sound_influence.timer--;
if (sound_influence.timer == 0) {
dKy_Sound_init();
}
}
}
/* 801A4F64-801A516C 19F8A4 0208+00 1/1 0/0 0/0 .text Eflight_flush_proc__18dScnKy_env_light_cFv
*/
void dScnKy_env_light_c::Eflight_flush_proc() {
struct flush_info {
u8 start_frame;
u8 r;
u8 g;
u8 b;
};
f32 power;
f32 fluctuation;
flush_info* info;
if (eflight.mLightType == 0) {
static flush_info flush_col[] = {
{1, 0x00, 0x00, 0x00},
{4, 0x43, 0x73, 0x58},
{10, 0x25, 0x3E, 0x2D},
{20, 0x00, 0x00, 0x00},
};
info = flush_col;
fluctuation = 100.0f;
power = 120.0f;
} else if (eflight.mLightType == 1) {
static flush_info flush_col2[] = {
{1, 0x00, 0x00, 0x00},
{4, 0x6E, 0x5A, 0x00},
{8, 0x4B, 0x22, 0x00},
{15, 0x00, 0x00, 0x00},
};
info = flush_col2;
fluctuation = 0.0f;
power = 120.0f;
} else {
static flush_info flush_col3[] = {
{1, 0x00, 0x00, 0x00},
{4, 0x46, 0x4D, 0x43},
{15, 0x22, 0x1E, 0x00},
{20, 0x00, 0x00, 0x00},
};
info = flush_col3;
fluctuation = 100.0f;
power = 80.0f;
}
switch (eflight.mState) {
case 0:
break;
case 1:
eflight.mFrame = 0;
eflight.field_0x8.mColor.r = info[0].r;
eflight.field_0x8.mColor.g = info[0].g;
eflight.field_0x8.mColor.b = info[0].b;
eflight.field_0x8.mPow = power;
eflight.field_0x8.mFluctuation = fluctuation;
dKy_efplight_set(&eflight.field_0x8);
eflight.mState++;
break;
case 2:
for (int i = 0; i < 3; i++) {
if (eflight.mFrame >= info[i].start_frame && eflight.mFrame <= info[i + 1].start_frame)
{
f32 ratio = 1.0f - (f32)(info[i + 1].start_frame - eflight.mFrame) /
(f32)(info[i + 1].start_frame - info[i].start_frame);
eflight.field_0x8.mColor.r = u8_data_ratio_set(info[i].r, info[i + 1].r, ratio);
eflight.field_0x8.mColor.g = u8_data_ratio_set(info[i].g, info[i + 1].g, ratio);
eflight.field_0x8.mColor.b = u8_data_ratio_set(info[i].b, info[i + 1].b, ratio);
break;
}
}
if (eflight.mFrame > info[3].start_frame) {
eflight.mState++;
}
eflight.mFrame++;
break;
case 3:
dKy_efplight_cut(&eflight.field_0x8);
eflight.mState = 0;
break;
case 4:
dKy_efplight_cut(&eflight.field_0x8);
eflight.mState = 1;
break;
}
}
/* 80450700-80450704 000180 0002+02 2/2 0/0 0/0 .sdata lightMask */
static u16 lightMask = 0x0001;
/* 80450704-80450708 -00001 0004+00 3/3 0/0 0/0 .sdata lightStatusPt */
static LightStatus* lightStatusPt = lightStatusData;
/* 801A516C-801A5288 19FAAC 011C+00 1/1 0/0 0/0 .text SetBaseLight__18dScnKy_env_light_cFv */
void dScnKy_env_light_c::SetBaseLight() {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
camera_class* camera = (camera_class*)dComIfGp_getCamera(0);
if (dKy_SunMoon_Light_Check() == TRUE) {
f32 daytime = g_env_light.getDaytime();
if (daytime > 67.5f && daytime < 292.5f) {
base_light.mPosition = kankyo->sun_light_pos;
} else if (camera != NULL) {
base_light.mPosition = camera->lookat.eye + kankyo->moon_pos;
} else {
base_light.mPosition = kankyo->moon_pos;
}
} else {
base_light.mPosition = lightStatusPt[2].position;
}
base_light.mColor.r = 0xFF;
base_light.mColor.g = 0xFF;
base_light.mColor.b = 0xFF;
base_light.mColor.a = 0xFF;
base_light.mPow = 0.0f;
base_light.mFluctuation = 0.0f;
}
/* 801A5288-801A56DC 19FBC8 0454+00 1/1 0/0 0/0 .text exeKankyo__18dScnKy_env_light_cFv
*/
// NONMATCHING - single regswap
void dScnKy_env_light_c::exeKankyo() {
for (int i = 0; i < 6; i++) {
field_0x0c18[i].field_0x26 = 0;
if (field_0x0d58[i].field_0x26 != 0) {
field_0x0d58[i].field_0x26 = 0;
dKy_BossLight_set(&field_0x0d58[i].mPos, &field_0x0d58[i].mColor,
field_0x0d58[i].mRefDistance, 0);
}
}
g_env_light.mColPatMode = g_env_light.mColPatModeGather;
if (dComIfGp_event_runCheck() == false && g_env_light.mColPatModeGather != 0) {
if (g_env_light.mColPatModeGather >= 3) {
g_env_light.mColPatModeGather = 0;
} else {
g_env_light.mColPatModeGather++;
}
}
if (g_env_light.mColPatMode != 0) {
if (g_env_light.mColpatPrevGather != 0xFF) {
g_env_light.wether_pat0 = g_env_light.mColpatPrevGather;
if (g_env_light.mColPatModeGather == 0) {
g_env_light.mColpatPrevGather = 0xFF;
}
}
if (g_env_light.mColpatCurrGather != 0xFF) {
g_env_light.wether_pat1 = g_env_light.mColpatCurrGather;
if (g_env_light.mColPatModeGather == 0) {
g_env_light.mColpatCurrGather = 0xFF;
}
}
if (g_env_light.mColPatBlendGather >= 0.0f) {
g_env_light.pat_ratio = g_env_light.mColPatBlendGather;
if (g_env_light.mColPatModeGather == 0) {
g_env_light.mColPatBlendGather = -1.0f;
}
}
} else if (g_env_light.wether_pat0 == g_env_light.wether_pat1) {
if (g_env_light.mColpatPrevGather != 0xFF) {
g_env_light.wether_pat0 = g_env_light.mColpatPrevGather;
g_env_light.mColpatPrevGather = 0xFF;
}
if (g_env_light.mColpatCurrGather != 0xFF) {
g_env_light.wether_pat1 = g_env_light.mColpatCurrGather;
g_env_light.mColpatCurrGather = 0xFF;
g_env_light.mColpatWeather = g_env_light.wether_pat1;
}
if (g_env_light.mColPatBlendGather >= 0.0f) {
g_env_light.pat_ratio = g_env_light.mColPatBlendGather;
g_env_light.mColPatBlendGather = -1.0f;
}
}
g_env_light.field_0x1210 = g_env_light.field_0x122c;
cLib_addCalc(&g_env_light.now_allcol_ratio, g_env_light.allcol_ratio, 0.5f, 0.25f, 0.01f);
cLib_addCalc(&g_env_light.now_actcol_ratio, g_env_light.actcol_ratio, 0.5f, 0.25f, 0.01f);
cLib_addCalc(&g_env_light.now_bgcol_ratio, g_env_light.bgcol_ratio * g_env_light.field_0x1210,
0.5f, 0.25f, 0.01f);
cLib_addCalc(&g_env_light.now_fogcol_ratio, g_env_light.fogcol_ratio * g_env_light.field_0x1210,
0.5f, 0.25f, 0.01f);
cLib_addCalc(&g_env_light.now_vrboxsoracol_ratio,
g_env_light.vrboxsoracol_ratio * g_env_light.field_0x1210, 0.5f, 0.25f, 0.01f);
cLib_addCalc(&g_env_light.now_vrboxkumocol_ratio,
g_env_light.vrboxkumocol_ratio * g_env_light.field_0x1210, 0.5f, 0.25f, 0.01f);
g_env_light.allcol_ratio = 1.0f;
g_env_light.actcol_ratio = 1.0f;
g_env_light.bgcol_ratio = 1.0f;
g_env_light.fogcol_ratio = 1.0f;
g_env_light.vrboxsoracol_ratio = 1.0f;
g_env_light.vrboxkumocol_ratio = 1.0f;
g_env_light.field_0x122c = 1.0f;
g_env_light.field_0x126c = g_env_light.field_0x1268;
g_env_light.field_0x1268 = 999999.9f;
for (int i = 50; i < 100; i++) {
g_env_light.pointlight[i] = NULL;
}
g_env_light.field_0x130b = 0;
setDaytime();
dKyw_wether_proc();
CalcTevColor();
Sndpos();
Eflight_flush_proc();
daPy_py_c* player_p = (daPy_py_c*)dComIfGp_getPlayer(0);
if (player_p != NULL) {
cXyz* flame_pos_p = player_p->getKandelaarFlamePos();
if (flame_pos_p != NULL) {
g_env_light.field_0x10a0 = *flame_pos_p;
dKy_shadow_mode_set(2);
} else if (dKy_shadow_mode_check(2)) {
dKy_shadow_mode_reset(2);
}
}
if (strcmp(dComIfGp_getStartStageName(), "R_SP127") == 0) {
if ((dCam_getBody()->Mode() == 4 || dCam_getBody()->Mode() == 7) && dComIfGp_event_runCheck())
{
cLib_addCalc(&g_env_light.mDemoAttentionPoint, 0.0f, 0.5f, 0.1f, 1E-05f);
} else {
cLib_addCalc(&g_env_light.mDemoAttentionPoint, 0.11f, 0.5f, 0.1f, 1E-05f);
}
}
}
/* 801A56DC-801A572C 1A001C 0050+00 1/1 0/0 0/0 .text drawKankyo__18dScnKy_env_light_cFv
*/
void dScnKy_env_light_c::drawKankyo() {
setSunpos();
SetBaseLight();
setLight();
dKy_setLight_nowroom(g_env_light.PrevCol);
}
/* 801A572C-801A5B6C 1A006C 0440+00 0/0 1/1 0/0 .text dKy_undwater_filter_draw__Fv */
void dKy_undwater_filter_draw() {
camera_class* camera = (camera_class*)dComIfGp_getCamera(0);
cXyz size;
static cXyz S_old_cameye(0.0f, 0.0f, 0.0f);
static cXyz S_old_camctr(0.0f, 0.0f, 0.0f);
if (dKy_camera_water_in_status_check()) {
f32 dist_to_old = camera->lookat.eye.abs(S_old_cameye);
if (dist_to_old > 100.0f) {
dist_to_old = 100.0f;
}
if (g_env_light.field_0x1258 > 1.0f - (dist_to_old / 100.0f)) {
cLib_addCalc(&g_env_light.field_0x1258, 1.0f - (dist_to_old / 100.0f), 0.5f, 0.05f,
0.0001f);
}
dist_to_old = camera->lookat.center.abs(S_old_camctr);
if (dist_to_old > 100.0f) {
dist_to_old = 100.0f;
}
if (g_env_light.field_0x1258 > 1.0f - (dist_to_old / 100.0f)) {
cLib_addCalc(&g_env_light.field_0x1258, 1.0f - (dist_to_old / 100.0f), 0.5f, 0.05f,
0.0001f);
}
S_old_cameye = camera->lookat.eye;
S_old_camctr = camera->lookat.center;
mDoMtx_stack_c::transS(0.0f, 0.0f, 0.0f);
size.x = 0.00524f;
size.y = 0.00524f;
size.z = 0.00524f;
if (g_env_light.undwater_ef_model != NULL) {
J3DGXColor sp8;
g_env_light.undwater_ef_model->setBaseScale(size);
g_env_light.undwater_ef_model->setBaseTRMtx(mDoMtx_stack_c::get());
if (g_env_light.undwater_btk != NULL) {
g_env_light.undwater_btk->setPlaySpeed(2.0f + (35.0f * (1.0f - g_env_light.field_0x1258)));
g_env_light.undwater_btk->entry(g_env_light.undwater_ef_model->getModelData());
g_env_light.undwater_btk->play();
dComIfGd_setXluList2DScreen();
mDoExt_modelUpdateDL(g_env_light.undwater_ef_model);
dComIfGd_setList();
}
}
}
}
/* 801A5B6C-801A5B98 1A04AC 002C+00 1/0 0/0 0/0 .text dKy_Draw__FP17sub_kankyo__class */
static int dKy_Draw(sub_kankyo__class* i_this) {
g_env_light.drawKankyo();
return 1;
}
/* 801A5B98-801A5BCC 1A04D8 0034+00 1/0 0/0 0/0 .text dKy_Execute__FP17sub_kankyo__class
*/
static int dKy_Execute(sub_kankyo__class* i_this) {
g_env_light.exeKankyo();
dKyw_wind_set();
dKy_twilight_camelight_set();
return 1;
}
/* 801A5BCC-801A5BD4 1A050C 0008+00 1/0 0/0 0/0 .text dKy_IsDelete__FP17sub_kankyo__class
*/
static int dKy_IsDelete(sub_kankyo__class* i_this) {
return 1;
}
/* 801A5BD4-801A5C1C 1A0514 0048+00 1/0 0/0 0/0 .text dKy_Delete__FP17sub_kankyo__class
*/
static int dKy_Delete(sub_kankyo__class* i_this) {
plight_init();
mDoAud_mEnvse_resetScene();
if (g_env_light.undwater_ef_heap != NULL) {
mDoExt_destroySolidHeap(g_env_light.undwater_ef_heap);
}
return 1;
}
/* 801A5C1C-801A5E54 1A055C 0238+00 1/0 0/0 0/0 .text dKy_Create__FPv */
static int dKy_Create(void* i_this) {
BOOL next_time_set = false;
stage_envr_info_class* stage_envr_p = dComIfGp_getStageEnvrInfo();
if (stage_envr_p != NULL && dComIfGp_getStartStageRoomNo() != -1) {
if (stage_envr_p[dComIfGp_getStartStageRoomNo()].pselect_id[64] != 0) {
mDoGph_gInf_c::getBloom()->create();
}
}
envcolor_init();
g_env_light.field_0x12b0 = 0;
g_env_light.field_0x1254 = 1.0f;
g_env_light.plight_near_pos.x = 0.0f;
g_env_light.plight_near_pos.y = 0.0f;
g_env_light.plight_near_pos.z = 0.0f;
g_env_light.senses_mode = 0;
g_env_light.senses_effect_strength = 0.0f;
g_env_light.now_senses_effect = 0;
dKy_setLight_init();
dKy_Sound_init();
dKyw_wind_set();
dungeonlight_init();
dKy_setLight_nowroom(dComIfGp_roomControl_getStayNo());
g_env_light.pol_efftbl = (dKy_pol_efftbl_struct*)dComIfG_getStageRes("pol_efftbl.dat");
g_env_light.pol_effcol = (dKy_pol_effcol_struct*)dComIfG_getStageRes("pol_effcol.dat");
g_env_light.pol_efftbl2 = (dKy_pol_efftbl_struct*)dComIfG_getStageRes("pol_efftbl2.dat");
g_env_light.pol_effcol2 = (dKy_pol_effcol_struct*)dComIfG_getStageRes("pol_effcol2.dat");
g_env_light.pol_sound = (dKy_pol_sound_struct*)dComIfG_getStageRes("pol_sound.dat");
g_env_light.pol_arg = (dKy_pol_arg_struct*)dComIfG_getStageRes("pol_arg.dat");
g_env_light.colordata_tbl = (dKy_color_data_struct*)dComIfG_getStageRes("colordata_tbl.dat");
if (g_env_light.nexttime != -1.0f) {
next_time_set = true;
dComIfGs_setTime(g_env_light.nexttime);
}
if (dKy_darkworld_check()) {
if (g_env_light.old_time == -1.0f) {
g_env_light.old_time = dComIfGs_getTime();
}
} else if (g_env_light.old_time != -1.0f) {
if (!next_time_set) {
dComIfGs_setTime(g_env_light.old_time);
}
g_env_light.old_time = -1.0f;
}
g_env_light.nexttime = -1.0f;
return cPhs_COMPLEATE_e;
}
/* 801A5E54-801A60BC 1A0794 0268+00 1/1 1/1 0/0 .text dKy_setLight_init__Fv */
void dKy_setLight_init() {
for (int i = 0; i < 8; i++) {
lightStatusData[i] = lightStatusBase;
}
}
/* 801A60BC-801A60E0 1A09FC 0024+00 0/0 1/1 0/0 .text dKy_setLight__Fv */
void dKy_setLight() {
g_env_light.sun_light_pos = g_env_light.sun_pos;
}
/* 801A60E0-801A61F4 1A0A20 0114+00 2/2 0/0 0/0 .text dKy_GlobalLight_set__Fv */
void dKy_GlobalLight_set() {
MtxP view_mtx = j3dSys.getViewMtx();
for (int i = 0; i < 8; i++) {
LightStatus* light_status = &lightStatusData[i];
Vec light_pos;
cMtx_multVec(view_mtx, &light_status->position, &light_pos);
GXLightObj light_obj;
GXInitLightPos(&light_obj, light_pos.x, light_pos.y, light_pos.z);
GXInitLightDir(&light_obj, light_status->mLightDir.x, light_status->mLightDir.y,
light_status->mLightDir.z);
GXInitLightColor(&light_obj, light_status->color);
if (light_status->mRefDist <= 0.0f) {
light_status->mRefDist = 0.000001f;
}
GXInitLightDistAttn(&light_obj, light_status->mRefDist, light_status->mRefBrightness,
light_status->mDistFn);
GXInitLightSpot(&light_obj, light_status->mCutoff, light_status->mSpotFn);
GXLoadLightObjImm(&light_obj, (GXLightID)lightMaskData[i]);
}
}
inline u8 dLVI_getSWLight(stage_pure_lightvec_info_class* i_info) {
return i_info->flags & 0x80;
}
/* 801A61F4-801A6278 1A0B34 0084+00 3/3 0/0 0/0 .text
* dKy_lightswitch_check__FP30stage_pure_lightvec_info_classc */
BOOL dKy_lightswitch_check(stage_pure_lightvec_info_class* stage_light_info_p, char room_no) {
BOOL is_switch = TRUE;
if (stage_light_info_p->switch_no != 0xFF) {
if (!dLVI_getSWLight(stage_light_info_p)) {
if (dComIfGs_isSwitch(stage_light_info_p->switch_no, room_no)) {
is_switch = FALSE;
}
} else if (!dComIfGs_isSwitch(stage_light_info_p->switch_no, room_no)) {
is_switch = FALSE;
}
}
return is_switch;
}
/* 801A6278-801A6C20 1A0BB8 09A8+00 2/2 0/0 0/0 .text dKy_setLight_nowroom_common__Fcf */
// NONMATCHING - some issues with lightStatusPt loads
void dKy_setLight_nowroom_common(char room_no, f32 light_ratio) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
camera_class* camera = (camera_class*)dComIfGp_getCamera(0);
fopAc_ac_c* player = (fopAc_ac_c*)dComIfGp_getPlayer(0);
MtxP view_mtx = j3dSys.getViewMtx();
dKy_tevstr_c* room_tevstr = dComIfGp_roomControl_getTevStr(room_no);
if (dComIfGp_roomControl_getStatusRoomDt(room_no) != NULL) {
stage_pure_lightvec_info_class* room_light_info = dComIfGp_roomControl_getStatusRoomDt(room_no)->getLightVecInfo();
int room_light_info_num = dComIfGp_roomControl_getStatusRoomDt(room_no)->getLightVecInfoNum();
if (room_light_info_num > 6) {
room_light_info_num = 6;
}
lightMask = 0;
for (int i = 0; i < room_light_info_num; i++) {
if (room_light_info != NULL) {
lightMask |= lightMaskData[i + 2];
}
room_light_info++;
}
room_light_info = dComIfGp_roomControl_getStatusRoomDt(room_no)->getLightVecInfo();
if (dKy_SunMoon_Light_Check() == TRUE && room_light_info == NULL) {
lightMask |= lightMaskData[2];
lightMask |= lightMaskData[3];
room_light_info_num = 2;
}
if (g_env_light.bgparts_active_light[0].mIndex != 0) {
lightMask |= 1;
}
if (g_env_light.bgparts_active_light[1].mIndex != 0) {
lightMask |= 2;
}
if (camera != 0) {
int eflight_id = dKy_eflight_influence_id(camera->lookat.eye, 0);
if (eflight_id >= 0) {
dKy_bgparts_activelight_set(g_env_light.efplight[eflight_id], 1);
if (dKy_Indoor_check() == TRUE) {
g_env_light.field_0x10a0 = g_env_light.efplight[eflight_id]->mPosition;
dKy_shadow_mode_set(1);
}
} else {
dKy_bgparts_activelight_cut(1);
if (dKy_shadow_mode_check(1)) {
dKy_shadow_mode_reset(1);
}
}
}
for (int i = 0; i < 2; i++) {
if (g_env_light.bgparts_active_light[i].mIndex != 0 &&
0.0f != g_env_light.bgparts_active_light[i].mPow &&
(i != 1 || dMeter2Info_getWindowStatus() != 3))
{
lightStatusPt[i].position = g_env_light.bgparts_active_light[i].mPosition;
if (i == 0) {
lightStatusPt[i].mRefDist = g_env_light.bgparts_active_light[i].mPow * 0.01f;
} else {
lightStatusPt[i].mRefDist = g_env_light.bgparts_active_light[i].mPow * 0.01f;
}
lightStatusPt[i].mRefBrightness = 0.99999f;
lightStatusPt[i].field_0x1c = 1;
lightStatusPt[i].mDistFn = GX_DA_STEEP;
lightStatusPt[i].mSpotFn = GX_SP_OFF;
lightStatusPt[i].color.r = g_env_light.bgparts_active_light[i].mColor.r;
lightStatusPt[i].color.g = g_env_light.bgparts_active_light[i].mColor.g;
lightStatusPt[i].color.b = g_env_light.bgparts_active_light[i].mColor.b;
} else {
lightStatusPt[i].color.r = 0;
lightStatusPt[i].color.g = 0;
lightStatusPt[i].color.b = 0;
}
}
for (int i = 0; i < 6; i++) {
if (room_light_info != 0) {
if (i < room_light_info_num) {
lightStatusPt[i + 2].position.x = room_light_info[i].position.x;
lightStatusPt[i + 2].position.y = room_light_info[i].position.y;
lightStatusPt[i + 2].position.z = room_light_info[i].position.z;
if (dKy_lightswitch_check(&room_light_info[i], room_no) == TRUE) {
lightStatusPt[i + 2].mRefDist = room_light_info[i].radius;
} else {
lightStatusPt[i + 2].mRefDist = 0.000001f;
}
lightStatusPt[i + 2].mRefBrightness = 0.99999f;
lightStatusPt[i + 2].field_0x1c = 0;
lightStatusPt[i + 2].mSpotFn = (GXSpotFn)room_light_info[i].spot_type;
lightStatusPt[i + 2].mDistFn = (GXDistAttnFn)room_light_info[i].dist_atten_type;
lightStatusPt[i + 2].mCutoff = room_light_info[i].spotCutoff;
dKy_lightdir_set(room_light_info[i].directionX, room_light_info[i].directionY,
&lightStatusPt[i + 2].mLightDir);
} else {
lightStatusPt[i + 2].mRefDist = 0.0f;
lightStatusPt[i + 2].mRefBrightness = 0.99999f;
lightStatusPt[i + 2].field_0x1c = 0;
lightStatusPt[i + 2].mDistFn = GX_DA_OFF;
lightStatusPt[i + 2].mSpotFn = GX_SP_OFF;
lightStatusPt[i + 2].mCutoff = 90.0f;
}
}
if (dKy_SunMoon_Light_Check() == TRUE && i <= 1) {
lightMask |= lightMaskData[2];
lightMask |= lightMaskData[3];
if (i == 0) {
lightStatusPt[i + 2].position = kankyo->sun_pos;
} else if (camera != 0) {
lightStatusPt[i + 2].position = camera->lookat.eye + kankyo->moon_pos;
} else {
lightStatusPt[i + 2].position = kankyo->moon_pos;
}
lightStatusPt[i + 2].mRefDist = 10000.0f;
lightStatusPt[i + 2].mRefBrightness = 0.99999f;
lightStatusPt[i + 2].field_0x1c = 1;
lightStatusPt[i + 2].mDistFn = GX_DA_STEEP;
lightStatusPt[i + 2].mSpotFn = GX_SP_OFF;
}
if (lightMask & lightMaskData[i + 2]) {
if (room_tevstr == NULL) {
JUT_ASSERT(12633, 0);
}
J3DLightInfo* room_light = &room_tevstr->mLights[i].getLightInfo();
if (room_light != NULL) {
lightStatusPt[i + 2].color =
dKy_light_influence_col(&room_light->mColor, light_ratio);
} else {
lightStatusPt[i + 2].color =
dKy_light_influence_col(&g_env_light.dungeonlight[i].mColor, light_ratio);
}
if (room_no == dComIfGp_roomControl_getStayNo() && room_light_info != NULL &&
i < room_light_info_num)
{
g_env_light.dungeonlight[i].mPosition = lightStatusPt[i + 2].position;
g_env_light.dungeonlight[i].mRefDistance = lightStatusPt[i + 2].mRefDist;
g_env_light.dungeonlight[i].mCutoffAngle = lightStatusPt[i + 2].mCutoff;
g_env_light.dungeonlight[i].mAngleAttenuation = lightStatusPt[i + 2].mSpotFn;
g_env_light.dungeonlight[i].mDistAttenuation = lightStatusPt[i + 2].mDistFn;
g_env_light.dungeonlight[i].mAngleX = room_light_info[i].directionX;
g_env_light.dungeonlight[i].mAngleY = room_light_info[i].directionY;
}
} else {
lightStatusPt[i + 2].color.r = 0;
lightStatusPt[i + 2].color.g = 0;
lightStatusPt[i + 2].color.b = 0;
}
}
for (int i = 0; i < 6; i++) {
if (kankyo->field_0x0c18[i].field_0x26 == 1) {
for (int j = 0; j < 6; j++) {
if (!(lightMask & lightMaskData[j + 2])) {
lightMask |= lightMaskData[j + 2];
if (kankyo->field_0x0c18[i].mColor.a == 254 ||
kankyo->field_0x0c18[i].mColor.a == 253)
{
dKy_twi_wolflight_set(i);
}
if (room_tevstr->Type < 16) {
lightStatusPt[j + 2].position.x = kankyo->field_0x0c18[i].mPos.x;
lightStatusPt[j + 2].position.y = kankyo->field_0x0c18[i].mPos.y;
lightStatusPt[j + 2].position.z = kankyo->field_0x0c18[i].mPos.z;
} else {
lightStatusPt[j + 2].position.x = kankyo->field_0x0c18[i].mPos.x;
if (i == 0) {
lightStatusPt[j + 2].position.y =
kankyo->field_0x0c18[i].mPos.y + g_env_light.field_0x127c;
} else {
lightStatusPt[j + 2].position.y =
200.0f + kankyo->field_0x0c18[i].mPos.y;
}
lightStatusPt[j + 2].position.z = kankyo->field_0x0c18[i].mPos.z;
}
lightStatusPt[j + 2].color = dKy_light_influence_col(&kankyo->field_0x0c18[i].mColor, light_ratio);
lightStatusPt[j + 2].mRefDist = kankyo->field_0x0c18[i].mRefDistance;
lightStatusPt[j + 2].mRefBrightness = 0.99999f;
lightStatusPt[j + 2].field_0x1c = 1;
lightStatusPt[j + 2].mSpotFn = (GXSpotFn)kankyo->field_0x0c18[i].mAngleAttenuation;
lightStatusPt[j + 2].mDistFn = (GXDistAttnFn)kankyo->field_0x0c18[i].mDistAttenuation;
lightStatusPt[j + 2].mCutoff = kankyo->field_0x0c18[i].mCutoffAngle;
dKy_lightdir_set(kankyo->field_0x0c18[i].mAngleX,
kankyo->field_0x0c18[i].mAngleY,
&lightStatusPt[j + 2].mLightDir);
break;
}
}
}
}
dKy_GlobalLight_set();
}
}
/* 801A6C20-801A6C58 1A1560 0038+00 2/2 1/1 0/0 .text dKy_setLight_nowroom__Fc */
void dKy_setLight_nowroom(char room_no) {
if (dComIfGp_getCamera(0) != NULL) {
dKy_setLight_nowroom_common(room_no, 1.0f);
}
}
/* 801A6C58-801A6D4C 1A1598 00F4+00 0/0 1/1 2/2 .text dKy_setLight_nowroom_grass__Fcf */
// NONMATCHING - weird branching
void dKy_setLight_nowroom_grass(char room_no, f32 light_ratio) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
camera_class* camera = (camera_class*)dComIfGp_getCamera(0);
fopAc_ac_c* player = (fopAc_ac_c*)dComIfGp_getPlayer(0);
MtxP view_mtx = j3dSys.getViewMtx();
if (dComIfGp_roomControl_getStatusRoomDt(room_no) != NULL) {
dStage_FileList_dt_c* filelist = dComIfGp_roomControl_getStatusRoomDt(room_no)->getFileListInfo();
if (filelist == NULL) {
return;
}
int grass_light = dStage_FileList_dt_GRASSLIGHT(filelist);
f32 grass_light_ratio;
if (grass_light >= 0xFF) {
grass_light_ratio = 1.0f;
} else {
grass_light_ratio = grass_light / 100.0f;
}
if (light_ratio == 0.0f) {
dKy_setLight_nowroom_common(room_no, grass_light_ratio);
} else {
dKy_setLight_nowroom_common(room_no, light_ratio);
}
}
}
/* 801A6D4C-801A6E9C 1A168C 0150+00 1/1 1/1 0/0 .text dKy_move_room_ratio__FP12dKy_tevstr_cPSc */
f32 dKy_move_room_ratio(dKy_tevstr_c* tevstr_p, s8* room_no_p) {
f32 ratio = 1.0f;
if (memcmp(dComIfGp_getStartStageName(), "D_MN", 4) == 0 && g_env_light.mColPatMode == 0 &&
g_env_light.mColPatModeGather == 0 && tevstr_p->pat_ratio > 0.0f &&
tevstr_p->pat_ratio < 1.0f)
{
if (tevstr_p->pat_ratio < 0.5f) {
if (tevstr_p->YukaCol == 0xFF) {
*room_no_p = tevstr_p->PrevCol;
ratio = fabsf(2.0f * (0.5f - tevstr_p->pat_ratio));
} else {
*room_no_p = tevstr_p->room_no;
ratio = fabsf(2.0f * (tevstr_p->pat_ratio - 0.5f));
}
} else {
*room_no_p = tevstr_p->room_no;
ratio = fabsf(2.0f * (tevstr_p->pat_ratio - 0.5f));
}
if (ratio <= 0.0f) {
ratio = 0.000001f;
}
}
return ratio;
}
/* 801A6E9C-801A75C0 1A17DC 0724+00 1/1 1/1 0/0 .text dKy_setLight_nowroom_actor__FP12dKy_tevstr_c
*/
void dKy_setLight_nowroom_actor(dKy_tevstr_c* tevstr_p) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
Vec light_pos;
Vec sp3C;
camera_class* camera = (camera_class*)dComIfGp_getCamera(0);
fopAc_ac_c* player = dComIfGp_getPlayer(0);
MtxP view_mtx = j3dSys.getViewMtx();
s8 room_no = tevstr_p->room_no;
f32 light_ratio = 1.0f;
if (tevstr_p->Type == 9 || tevstr_p->Type == 10) {
light_ratio = dKy_move_room_ratio(tevstr_p, &room_no);
}
if (tevstr_p->Type == 14 || tevstr_p->Type == 12 || tevstr_p->Type == 13) {
return;
}
if (dComIfGp_roomControl_getStatusRoomDt(room_no) != NULL) {
J3DLightInfo* light;
stage_pure_lightvec_info_class* room_lights = dComIfGp_roomControl_getStatusRoomDt(room_no)->getLightVecInfo();
int room_light_num = dComIfGp_roomControl_getStatusRoomDt(room_no)->getLightVecInfoNum();
if (room_light_num > 6) {
room_light_num = 6;
}
lightMask = 0;
for (int i = 0; i < room_light_num; i++) {
if (room_lights != NULL) {
lightMask |= lightMaskData[i + 2];
}
room_lights++;
}
room_lights = dComIfGp_roomControl_getStatusRoomDt(room_no)->getLightVecInfo();
for (int i = 0; i < 6; i++) {
light = &tevstr_p->mLights[i].getLightInfo();
if (view_mtx != NULL) {
if (room_lights != 0 && i < room_light_num) {
sp3C.x = room_lights[i].position.x;
sp3C.y = room_lights[i].position.y;
sp3C.z = room_lights[i].position.z;
dKy_GXInitLightSpot(light, room_lights[i].spotCutoff, room_lights[i].spot_type);
f32 var_f29;
if (dKy_lightswitch_check(&room_lights[i], room_no) == TRUE) {
var_f29 = light_ratio * room_lights[i].radius;
} else {
var_f29 = 0.000001f;
}
dKy_GXInitLightDistAttn(light, var_f29, 0.99999f,
room_lights[i].dist_atten_type);
dKy_lightdir_set(room_lights[i].directionX, room_lights[i].directionY,
&light->mLightDirection);
light->mLightDirection.x = -light->mLightDirection.x;
light->mLightDirection.y = -light->mLightDirection.y;
light->mLightDirection.z = -light->mLightDirection.z;
}
if (dKy_SunMoon_Light_Check() == TRUE && i <= 1) {
lightMask |= lightMaskData[2];
lightMask |= lightMaskData[3];
if (i == 0) {
sp3C.x = kankyo->sun_pos.x;
sp3C.y = kankyo->sun_pos.y;
sp3C.z = kankyo->sun_pos.z;
} else if (camera != NULL) {
sp3C.x = camera->lookat.eye.x + kankyo->moon_pos.x;
sp3C.y = camera->lookat.eye.y + kankyo->moon_pos.y;
sp3C.z = camera->lookat.eye.z + kankyo->moon_pos.z;
} else {
sp3C.x = kankyo->moon_pos.x;
sp3C.y = kankyo->moon_pos.y;
sp3C.z = kankyo->moon_pos.z;
}
dKy_GXInitLightSpot(light, 90.0f, GX_SP_OFF);
dKy_GXInitLightDistAttn(light, 10000.0f, 0.99999f, GX_DA_STEEP);
}
cMtx_multVec(view_mtx, &sp3C, &light_pos);
light->mLightPosition = light_pos;
if (1.0f != light_ratio) {
light->mColor.r *= light_ratio;
light->mColor.g *= light_ratio;
light->mColor.b *= light_ratio;
}
}
if (!(lightMask & lightMaskData[i + 2])) {
light->mColor.r = 0;
light->mColor.g = 0;
light->mColor.b = 0;
}
light = &tevstr_p->mLightObj.getLightInfo();
if (1.0f != light_ratio) {
light->mColor.r *= light_ratio;
light->mColor.g *= light_ratio;
light->mColor.b *= light_ratio;
}
}
for (int i = 0; i < 6; i++) {
if (kankyo->field_0x0c18[i].field_0x26 == 1 && view_mtx != NULL) {
for (int j = 0; j < 6; j++) {
if (!(lightMask & lightMaskData[j + 2])) {
lightMask |= lightMaskData[j + 2];
light = &tevstr_p->mLights[j].getLightInfo();
if (kankyo->field_0x0c18[i].mColor.a == 254 ||
kankyo->field_0x0c18[i].mColor.a == 253)
{
dKy_twi_wolflight_set(i);
}
light->mColor = dKy_light_influence_col(&kankyo->field_0x0c18[i].mColor,
tevstr_p->field_0x374);
if (tevstr_p->Type < 16) {
sp3C.x = kankyo->field_0x0c18[i].mPos.x;
sp3C.y = kankyo->field_0x0c18[i].mPos.y;
sp3C.z = kankyo->field_0x0c18[i].mPos.z;
if (kankyo->field_0x0c18[i].mColor.a == 253) {
light->mColor.r = light->mColor.r * 0.65f;
light->mColor.g = light->mColor.g * 0.65f;
light->mColor.b = light->mColor.b * 0.65f;
}
} else {
sp3C.x = kankyo->field_0x0c18[i].mPos.x;
if (i == 0) {
sp3C.y = kankyo->field_0x0c18[i].mPos.y + g_env_light.field_0x127c;
} else {
sp3C.y = 200.0f + kankyo->field_0x0c18[i].mPos.y;
}
sp3C.z = kankyo->field_0x0c18[i].mPos.z;
}
dKy_GXInitLightSpot(light, kankyo->field_0x0c18[i].mCutoffAngle,
kankyo->field_0x0c18[i].mAngleAttenuation);
f32 var_f30 = kankyo->field_0x0c18[i].mRefDistance * light_ratio;
if (var_f30 <= 0.0f) {
var_f30 = 0.000001f;
}
dKy_GXInitLightDistAttn(light, var_f30, 0.99999f,
kankyo->field_0x0c18[i].mDistAttenuation);
cMtx_multVec(view_mtx, &sp3C, &light_pos);
light->mLightPosition = light_pos;
dKy_lightdir_set(kankyo->field_0x0c18[i].mAngleX,
kankyo->field_0x0c18[i].mAngleY, &light->mLightDirection);
light->mLightDirection.x = -light->mLightDirection.x;
light->mLightDirection.y = -light->mLightDirection.y;
light->mLightDirection.z = -light->mLightDirection.z;
break;
}
}
}
}
}
}
/* 801A75C0-801A75E0 1A1F00 0020+00 0/0 6/6 7/7 .text dKy_setLight_again__Fv */
void dKy_setLight_again() {
dKy_GlobalLight_set();
}
/* 801A75E0-801A76D8 1A1F20 00F8+00 0/0 3/3 5/5 .text dKy_Global_amb_set__FP12dKy_tevstr_c */
void dKy_Global_amb_set(dKy_tevstr_c* tevstr_p) {
GXColor color;
color.r = tevstr_p->AmbCol.r;
color.g = tevstr_p->AmbCol.g;
color.b = tevstr_p->AmbCol.b;
color.a = tevstr_p->AmbCol.a;
if (tevstr_p->Type == 2 || tevstr_p->Type == 3) {
if (dKy_darkworld_check()) {
if (tevstr_p->Type == 2) {
color.r = 18;
color.g = 18;
color.b = 18;
color.a = 0;
} else {
color.r = 12;
color.g = 12;
color.b = 12;
color.a = 0;
}
}
} else if ((tevstr_p->Type >= 1 && tevstr_p->Type <= 7) ||
(tevstr_p->Type == 9 && dKy_darkworld_check()))
{
color.r = 0;
color.g = 0;
color.b = 0;
color.a = 0;
}
GXSetChanAmbColor(GX_COLOR0A0, color);
}
/* 801A76D8-801A7714 1A2018 003C+00 1/1 0/0 0/0 .text dKy_light_influence_pos__Fi */
cXyz dKy_light_influence_pos(int light_id) {
if (light_id < 0) {
light_id = 0;
}
dScnKy_env_light_c* kankyo = &g_env_light;
return kankyo->pointlight[light_id]->mPosition;
}
/* 801A7714-801A7738 1A2054 0024+00 0/0 1/1 0/0 .text dKy_plight_near_pos__Fv */
cXyz dKy_plight_near_pos() {
return g_env_light.plight_near_pos;
}
/* 801A7738-801A7790 1A2078 0058+00 0/0 0/0 1/1 .text
* dKy_mock_light_every_set__FP15LIGHT_INFLUENCE */
void dKy_mock_light_every_set(LIGHT_INFLUENCE* light_inf_p) {
for (int i = 50; i < 100; i++) {
if (g_env_light.pointlight[i] == NULL) {
g_env_light.pointlight[i] = light_inf_p;
g_env_light.pointlight[i]->mIndex = i + 1;
break;
}
}
}
/* 801A7790-801A7814 1A20D0 0084+00 1/1 1/1 18/18 .text dKy_plight_set__FP15LIGHT_INFLUENCE */
void dKy_plight_set(LIGHT_INFLUENCE* light_inf_p) {
for (int i = 0; i < 100; i++) {
if (g_env_light.pointlight[i] == light_inf_p) {
return;
}
}
for (int i = 0; i < 50; i++) {
if (g_env_light.pointlight[i] == NULL) {
g_env_light.pointlight[i] = light_inf_p;
g_env_light.pointlight[i]->mIndex = i + 1;
break;
}
}
}
/* 801A7814-801A7868 1A2154 0054+00 0/0 0/0 4/4 .text dKy_dalkmist_inf_set__FP18DALKMIST_INFLUENCE
*/
void dKy_dalkmist_inf_set(DALKMIST_INFLUENCE* dalkmist_inf_p) {
for (int i = 0; i < 10; i++) {
if (g_env_light.dalkmist_influence[i] == NULL) {
g_env_light.dalkmist_influence[i] = dalkmist_inf_p;
g_env_light.dalkmist_influence[i]->mIndex = i;
break;
}
}
}
/* 801A7868-801A789C 1A21A8 0034+00 0/0 0/0 4/4 .text dKy_dalkmist_inf_cut__FP18DALKMIST_INFLUENCE
*/
void dKy_dalkmist_inf_cut(DALKMIST_INFLUENCE* dalkmist_inf_p) {
if (dalkmist_inf_p != NULL) {
if (dalkmist_inf_p->mIndex < 10) {
g_env_light.dalkmist_influence[dalkmist_inf_p->mIndex] = NULL;
}
}
}
/* 801A789C-801A792C 1A21DC 0090+00 0/0 0/0 1/1 .text dKy_plight_priority_set__FP15LIGHT_INFLUENCE
*/
void dKy_plight_priority_set(LIGHT_INFLUENCE* light_inf_p) {
int i = 0;
for (; i < 50; i++) {
if (g_env_light.pointlight[i] == NULL) {
g_env_light.pointlight[i] = light_inf_p;
g_env_light.pointlight[i]->mIndex = -(i + 1);
break;
}
}
if (i >= 50) {
OSReport_Warning("\nPOINTLIGHT COUNT OVER!!!\n");
}
}
/* 801A792C-801A797C 1A226C 0050+00 0/0 1/1 32/32 .text dKy_plight_cut__FP15LIGHT_INFLUENCE */
void dKy_plight_cut(LIGHT_INFLUENCE* light_inf_p) {
if (light_inf_p != NULL) {
if (light_inf_p->mIndex != 0) {
if (light_inf_p->mIndex < 0) {
light_inf_p->mIndex *= -1;
}
int idx = (light_inf_p->mIndex & 0xFFF) - 1;
if (idx < 50) {
g_env_light.pointlight[idx] = NULL;
}
}
}
}
/* 801A797C-801A7A00 1A22BC 0084+00 1/1 1/1 3/3 .text dKy_efplight_set__FP15LIGHT_INFLUENCE */
void dKy_efplight_set(LIGHT_INFLUENCE* light_inf_p) {
for (int i = 0; i < 5; i++) {
if (g_env_light.efplight[i] == light_inf_p) {
return;
}
}
for (int i = 0; i < 5; i++) {
if (g_env_light.efplight[i] == NULL) {
g_env_light.efplight[i] = light_inf_p;
g_env_light.efplight[i]->mIndex = i + 1;
break;
}
}
}
/* 801A7A00-801A7A40 1A2340 0040+00 1/1 1/1 3/3 .text dKy_efplight_cut__FP15LIGHT_INFLUENCE */
void dKy_efplight_cut(LIGHT_INFLUENCE* light_inf_p) {
if (light_inf_p != NULL) {
if (light_inf_p->mIndex != 0) {
int idx = light_inf_p->mIndex - 1;
if (idx >= 0 && idx < 5) {
g_env_light.efplight[idx] = NULL;
}
}
}
}
/* 801A7A40-801A7AAC 1A2380 006C+00 1/1 0/0 0/0 .text
* dKy_bgparts_activelight_set__FP15LIGHT_INFLUENCEi */
void dKy_bgparts_activelight_set(LIGHT_INFLUENCE* light_inf_p, int bgpart_id) {
if (light_inf_p != NULL) {
memcpy(&g_env_light.bgparts_active_light[bgpart_id], light_inf_p, sizeof(LIGHT_INFLUENCE));
g_env_light.bgparts_active_light[bgpart_id].mIndex = bgpart_id + 1;
}
}
/* 801A7AAC-801A7AC8 1A23EC 001C+00 1/1 0/0 0/0 .text dKy_bgparts_activelight_cut__Fi */
void dKy_bgparts_activelight_cut(int bgpart_id) {
g_env_light.bgparts_active_light[bgpart_id].mIndex = 0;
}
/* 801A7AC8-801A7B68 1A2408 00A0+00 1/1 1/1 1/1 .text dKy_actor_addcol_amb_set__Fsssf */
void dKy_actor_addcol_amb_set(s16 r, s16 g, s16 b, f32 ratio) {
g_env_light.actor_addcol_amb.r = r * ratio;
g_env_light.actor_addcol_amb.g = g * ratio;
g_env_light.actor_addcol_amb.b = b * ratio;
}
/* 801A7B68-801A7C08 1A24A8 00A0+00 1/1 1/1 1/1 .text dKy_bg_addcol_amb_set__Fsssf */
void dKy_bg_addcol_amb_set(s16 r, s16 g, s16 b, f32 ratio) {
g_env_light.bg_addcol_amb.r = r * ratio;
g_env_light.bg_addcol_amb.g = g * ratio;
g_env_light.bg_addcol_amb.b = b * ratio;
}
/* 801A7C08-801A7CA8 1A2548 00A0+00 1/1 1/1 0/0 .text dKy_bg1_addcol_amb_set__Fsssf */
void dKy_bg1_addcol_amb_set(s16 r, s16 g, s16 b, f32 ratio) {
g_env_light.bg1_addcol_amb.r = r * ratio;
g_env_light.bg1_addcol_amb.g = g * ratio;
g_env_light.bg1_addcol_amb.b = b * ratio;
}
/* 801A7CA8-801A7D48 1A25E8 00A0+00 1/1 0/0 0/0 .text dKy_bg2_addcol_amb_set__Fsssf */
void dKy_bg2_addcol_amb_set(s16 r, s16 g, s16 b, f32 ratio) {
g_env_light.bg2_addcol_amb.r = r * ratio;
g_env_light.bg2_addcol_amb.g = g * ratio;
g_env_light.bg2_addcol_amb.b = b * ratio;
}
/* 801A7D48-801A7DE8 1A2688 00A0+00 1/1 0/0 0/0 .text dKy_bg3_addcol_amb_set__Fsssf */
void dKy_bg3_addcol_amb_set(s16 r, s16 g, s16 b, f32 ratio) {
g_env_light.bg3_addcol_amb.r = r * ratio;
g_env_light.bg3_addcol_amb.g = g * ratio;
g_env_light.bg3_addcol_amb.b = b * ratio;
}
/* 801A7DE8-801A7E88 1A2728 00A0+00 1/1 1/1 0/0 .text dKy_addcol_fog_set__Fsssf */
void dKy_addcol_fog_set(s16 r, s16 g, s16 b, f32 ratio) {
g_env_light.addcol_fog.r = r * ratio;
g_env_light.addcol_fog.g = g * ratio;
g_env_light.addcol_fog.b = b * ratio;
}
/* 801A7E88-801A7F20 1A27C8 0098+00 2/2 0/0 2/2 .text dKy_actor_addcol_set__Fsssf */
void dKy_actor_addcol_set(s16 r, s16 g, s16 b, f32 ratio) {
dKy_actor_addcol_amb_set(r, g, b, ratio);
dKy_bg_addcol_amb_set(r, g, b, ratio);
dKy_bg1_addcol_amb_set(r, g, b, ratio);
dKy_bg2_addcol_amb_set(r, g, b, ratio);
dKy_bg3_addcol_amb_set(r, g, b, ratio);
}
/* 801A7F20-801A7FC0 1A2860 00A0+00 1/1 1/1 0/0 .text dKy_vrbox_addcol_sky0_set__Fsssf */
void dKy_vrbox_addcol_sky0_set(s16 r, s16 g, s16 b, f32 ratio) {
g_env_light.vrbox_addcol_sky0.r = r * ratio;
g_env_light.vrbox_addcol_sky0.g = g * ratio;
g_env_light.vrbox_addcol_sky0.b = b * ratio;
}
/* 801A7FC0-801A8060 1A2900 00A0+00 1/1 1/1 0/0 .text dKy_vrbox_addcol_kasumi_set__Fsssf
*/
void dKy_vrbox_addcol_kasumi_set(s16 r, s16 g, s16 b, f32 ratio) {
g_env_light.vrbox_addcol_kasumi.r = r * ratio;
g_env_light.vrbox_addcol_kasumi.g = g * ratio;
g_env_light.vrbox_addcol_kasumi.b = b * ratio;
}
/* 801A8060-801A80D0 1A29A0 0070+00 1/1 0/0 0/0 .text dKy_vrbox_addcol_set__Fsssf */
void dKy_vrbox_addcol_set(s16 r, s16 g, s16 b, f32 ratio) {
dKy_vrbox_addcol_sky0_set(r, g, b, ratio);
dKy_vrbox_addcol_kasumi_set(r, g, b, ratio);
dKy_addcol_fog_set(r, g, b, ratio);
}
/* 801A80D0-801A8168 1A2A10 0098+00 1/1 0/0 2/2 .text dKy_fog_startendz_set__Ffff */
void dKy_fog_startendz_set(f32 param_0, f32 param_1, f32 ratio) {
if (ratio < 0.0f || ratio > 1.0f) {
OSReport_Warning("\ndKy_fog_startendz_set ratio error!\n");
ratio = 0.0f;
}
if (ratio < 0.0000000000001f) {
ratio = 0.0f;
}
g_env_light.field_0x11ec = param_0;
g_env_light.field_0x11f0 = param_1;
g_env_light.field_0x11f4 = ratio;
}
/* 801A8168-801A8190 1A2AA8 0028+00 0/0 1/1 0/0 .text dKy_Itemgetcol_chg_on__Fv */
void dKy_Itemgetcol_chg_on() {
if (g_env_light.Itemgetcol_chg == 0 || g_env_light.Itemgetcol_chg == 6) {
g_env_light.Itemgetcol_chg = 1;
}
}
/* 801A8190-801A81C0 1A2AD0 0030+00 2/2 0/0 0/0 .text dKy_Sound_init__Fv */
void dKy_Sound_init() {
g_env_light.sound_influence.position.x = 999999.9f;
g_env_light.sound_influence.position.y = 999999.9f;
g_env_light.sound_influence.position.z = 999999.9f;
g_env_light.sound_influence.field_0xc = 0;
g_env_light.sound_influence.actor_id = fpcM_ERROR_PROCESS_ID_e;
g_env_light.sound_influence.timer = 0;
}
/* 801A81C0-801A8474 1A2B00 02B4+00 0/0 5/5 27/27 .text dKy_Sound_set__F4cXyziUii */
void dKy_Sound_set(cXyz pos, int param_1, fpc_ProcID actor_id, int timer) {
camera_class* camera_p = (camera_class*)dComIfGp_getCamera(0);
BOOL set_sound = FALSE;
f32 dist_pos_to_eye = pos.abs(camera_p->lookat.eye);
f32 dist_sndpos_to_eye = g_env_light.sound_influence.position.abs(camera_p->lookat.eye);
if (dist_pos_to_eye < dist_sndpos_to_eye) {
if (dist_sndpos_to_eye < 1500.0f) {
set_sound = TRUE;
} else if (g_env_light.sound_influence.field_0xc < param_1) {
set_sound = TRUE;
}
}
if (set_sound) {
g_env_light.sound_influence.position = pos;
g_env_light.sound_influence.field_0xc = param_1;
g_env_light.sound_influence.actor_id = actor_id;
g_env_light.sound_influence.timer = timer;
}
}
/* 801A8474-801A8484 1A2DB4 0010+00 0/0 1/1 8/8 .text dKy_Sound_get__Fv */
SND_INFLUENCE* dKy_Sound_get() {
return &g_env_light.sound_influence;
}
/* 801A8484-801A8538 1A2DC4 00B4+00 0/0 2/2 0/0 .text dKy_SordFlush_set__F4cXyzi */
void dKy_SordFlush_set(cXyz light_pos, int light_type) {
dScnKy_env_light_c* light = dKy_getEnvlight();
if (!dKy_darkworld_check() &&
(light->mThunderEff.mState >= 10 || light->mThunderEff.mFlashTimer <= 0.0f))
{
if (g_env_light.eflight.mState == 0) {
g_env_light.eflight.mState = 1;
g_env_light.eflight.mLightType = light_type;
g_env_light.eflight.field_0x8.mPosition = light_pos;
} else if (g_env_light.eflight.mState == 2) {
g_env_light.eflight.mState = 4;
}
}
}
/* 801A8538-801A85E8 1A2E78 00B0+00 1/1 0/0 0/0 .text GxFogSet_Sub__FP8_GXColor */
static void GxFogSet_Sub(GXColor* fog_col_p) {
f32 near_z = 1.0f;
f32 far_z = 160000.0f;
GXColor color;
color = *fog_col_p;
if (dComIfGd_getView() != NULL) {
if (dComIfGd_getView()->near >= 0.0f && dComIfGd_getView()->far >= 0.0f) {
if (dComIfGd_getView()->near < dComIfGd_getView()->far) {
near_z = dComIfGd_getView()->near;
far_z = dComIfGd_getView()->far;
}
}
}
GXSetFog(GX_FOG_PERSP_LIN, g_env_light.mFogNear, g_env_light.mFogFar, near_z, far_z, color);
}
/* 801A85E8-801A862C 1A2F28 0044+00 1/1 0/0 0/0 .text GxFog_set__Fv */
static void GxFog_set() {
GXColor color;
color.r = g_env_light.fog_col.r;
color.g = g_env_light.fog_col.g;
color.b = g_env_light.fog_col.b;
GxFogSet_Sub(&color);
}
/* 801A862C-801A8650 1A2F6C 0024+00 0/0 7/7 2/2 .text dKy_GxFog_set__Fv */
void dKy_GxFog_set() {
GxFog_set();
GxXFog_set();
}
/* 801A8650-801A86F8 1A2F90 00A8+00 0/0 3/3 6/6 .text dKy_GxFog_tevstr_set__FP12dKy_tevstr_c */
void dKy_GxFog_tevstr_set(dKy_tevstr_c* tevstr_p) {
f32 near_z = 1.0f;
f32 far_z = 160000.0f;
GXColor color;
color.r = tevstr_p->FogCol.r;
color.g = tevstr_p->FogCol.g;
color.b = tevstr_p->FogCol.b;
if (dComIfGd_getView() != NULL) {
if (dComIfGd_getView()->near >= 0.0f && dComIfGd_getView()->far >= 0.0f) {
if (dComIfGd_getView()->near < dComIfGd_getView()->far) {
near_z = dComIfGd_getView()->near;
far_z = dComIfGd_getView()->far;
}
}
}
GXSetFog(GX_FOG_PERSP_LIN, tevstr_p->mFogStartZ, tevstr_p->mFogEndZ, near_z, far_z, color);
GxXFog_set();
}
/* 801A86F8-801A87A0 1A3038 00A8+00 0/0 0/0 1/1 .text dKy_GfFog_tevstr_set__FP12dKy_tevstr_c */
void dKy_GfFog_tevstr_set(dKy_tevstr_c* tevstr_p) {
f32 near_z = 1.0f;
f32 far_z = 160000.0f;
GXColor color;
color.r = tevstr_p->FogCol.r;
color.g = tevstr_p->FogCol.g;
color.b = tevstr_p->FogCol.b;
if (dComIfGd_getView() != NULL) {
if (dComIfGd_getView()->near >= 0.0f && dComIfGd_getView()->far >= 0.0f) {
if (dComIfGd_getView()->near < dComIfGd_getView()->far) {
near_z = dComIfGd_getView()->near;
far_z = dComIfGd_getView()->far;
}
}
}
GFSetFog(GX_FOG_PERSP_LIN, tevstr_p->mFogStartZ, tevstr_p->mFogEndZ, near_z, far_z, color);
GxXFog_set();
}
/* 801A87A0-801A87E4 1A30E0 0044+00 3/3 0/0 0/0 .text GxXFog_set__Fv */
static void GxXFog_set() {
dKyd_xfog_table_set(g_env_light.mFogAdjTableType);
GXSetFogRangeAdj(g_env_light.mFogAdjEnable, g_env_light.mFogAdjCenter, &g_env_light.mXFogTbl);
}
/* 801A87E4-801A880C 1A3124 0028+00 0/0 0/0 52/52 .text dKy_change_colpat__FUc */
void dKy_change_colpat(u8 colpat) {
g_env_light.mColpatCurrGather = colpat;
if (g_env_light.wether_pat1 != colpat) {
g_env_light.mColPatBlendGather = 0.0f;
}
}
/* 801A880C-801A8854 1A314C 0048+00 0/0 0/0 25/25 .text dKy_custom_colset__FUcUcf */
void dKy_custom_colset(u8 prevGather, u8 curGather, f32 blend) {
if (g_env_light.light_init_timer != 1) {
if (blend < 1.0f) {
g_env_light.mColpatPrevGather = prevGather;
} else {
g_env_light.mColpatPrevGather = curGather;
}
g_env_light.mColpatCurrGather = curGather;
g_env_light.mColPatBlendGather = blend;
g_env_light.mColPatModeGather = 1;
}
}
/* 801A8854-801A88EC 1A3194 0098+00 0/0 0/0 2/2 .text dKy_setLight_mine__FP12dKy_tevstr_c
*/
void dKy_setLight_mine(dKy_tevstr_c* tevstr_p) {
GXLightObj light;
GXInitLightPos(&light, tevstr_p->mLightObj.mInfo.mLightPosition.x,
tevstr_p->mLightObj.mInfo.mLightPosition.y,
tevstr_p->mLightObj.mInfo.mLightPosition.z);
GXInitLightDir(&light, tevstr_p->mLightObj.mInfo.mLightDirection.x,
tevstr_p->mLightObj.mInfo.mLightDirection.y,
tevstr_p->mLightObj.mInfo.mLightDirection.z);
GXInitLightColor(&light, tevstr_p->mLightObj.mInfo.mColor);
GXInitLightAttn(&light, tevstr_p->mLightObj.mInfo.mCosAtten.x,
tevstr_p->mLightObj.mInfo.mCosAtten.y, tevstr_p->mLightObj.mInfo.mCosAtten.z,
tevstr_p->mLightObj.mInfo.mDistAtten.x, tevstr_p->mLightObj.mInfo.mDistAtten.y,
tevstr_p->mLightObj.mInfo.mDistAtten.z);
GXLoadLightObjImm(&light, (GXLightID)*lightMaskData);
}
/* 801A88EC-801A8A34 1A322C 0148+00 2/2 5/5 11/11 .text dKy_tevstr_init__FP12dKy_tevstr_cScUc */
void dKy_tevstr_init(dKy_tevstr_c* tevstr_p, s8 room_no, u8 floorCol) {
memset(tevstr_p, 0, sizeof(dKy_tevstr_c));
if (room_no == -1) {
tevstr_p->room_no = dComIfGp_roomControl_getStayNo();
} else {
tevstr_p->room_no = room_no;
}
tevstr_p->UseCol = tevstr_p->room_no;
tevstr_p->PrevCol = tevstr_p->room_no;
tevstr_p->YukaCol = floorCol;
tevstr_p->mInitTimer = 1;
tevstr_p->Material_use_fg = 0x7B;
tevstr_p->AmbCol.a = 0;
tevstr_p->FogCol.a = 255;
tevstr_p->Material_id = 0;
tevstr_p->field_0x374 = 1.0f;
tevstr_p->field_0x384 = 0;
tevstr_p->mLightObj.mInfo.mColor.g = 0;
tevstr_p->mLightObj.mInfo.mColor.b = 0;
tevstr_p->mLightObj.mInfo.mColor.a = 255;
tevstr_p->mLightObj.mInfo.mCosAtten.x = 1.0f;
tevstr_p->mLightObj.mInfo.mCosAtten.y = 0.0f;
tevstr_p->mLightObj.mInfo.mCosAtten.z = 0.0f;
tevstr_p->mLightObj.mInfo.mDistAtten.x = 1.0f;
tevstr_p->mLightObj.mInfo.mDistAtten.y = 0.0f;
tevstr_p->mLightObj.mInfo.mDistAtten.z = 0.0f;
for (int i = 0; i < 6; i++) {
J3DLightObj* tev_light_p = &tevstr_p->mLights[i];
LightStatus* light_data_p = &lightStatusData[i];
tev_light_p->mInfo.mLightPosition = light_data_p->position;
tev_light_p->mInfo.mColor = light_data_p->color;
tev_light_p->mInfo.mCosAtten.x = 1.0f;
tev_light_p->mInfo.mCosAtten.y = 0.0f;
tev_light_p->mInfo.mCosAtten.z = 0.0f;
tev_light_p->mInfo.mDistAtten.x = 1.0f;
tev_light_p->mInfo.mDistAtten.y = 0.0f;
tev_light_p->mInfo.mDistAtten.z = 0.0f;
}
}
/* 801A8A34-801A8A44 1A3374 0010+00 0/0 1/1 0/0 .text dKy_rain_check__Fv */
int dKy_rain_check() {
return g_env_light.raincnt;
}
/* 801A8A44-801A8A54 1A3384 0010+00 0/0 0/0 5/5 .text dKy_set_allcol_ratio__Ff */
void dKy_set_allcol_ratio(f32 ratio) {
g_env_light.allcol_ratio = ratio;
}
/* 801A8A54-801A8A64 1A3394 0010+00 0/0 1/1 1/1 .text dKy_set_actcol_ratio__Ff */
void dKy_set_actcol_ratio(f32 ratio) {
g_env_light.actcol_ratio = ratio;
}
/* 801A8A64-801A8A74 1A33A4 0010+00 0/0 1/1 1/1 .text dKy_set_bgcol_ratio__Ff */
void dKy_set_bgcol_ratio(f32 ratio) {
g_env_light.bgcol_ratio = ratio;
}
/* 801A8A74-801A8A84 1A33B4 0010+00 0/0 1/1 1/1 .text dKy_set_fogcol_ratio__Ff */
void dKy_set_fogcol_ratio(f32 ratio) {
g_env_light.fogcol_ratio = ratio;
}
/* 801A8A84-801A8AB8 1A33C4 0034+00 0/0 1/1 0/0 .text dKy_set_vrboxcol_ratio__Ff */
void dKy_set_vrboxcol_ratio(f32 ratio) {
dKy_set_vrboxsoracol_ratio(ratio);
dKy_set_vrboxkumocol_ratio(ratio);
}
/* 801A8AB8-801A8AC8 1A33F8 0010+00 1/1 0/0 0/0 .text dKy_set_vrboxsoracol_ratio__Ff */
void dKy_set_vrboxsoracol_ratio(f32 ratio) {
g_env_light.vrboxsoracol_ratio = ratio;
}
/* 801A8AC8-801A8AD8 1A3408 0010+00 1/1 0/0 0/0 .text dKy_set_vrboxkumocol_ratio__Ff */
void dKy_set_vrboxkumocol_ratio(f32 ratio) {
g_env_light.vrboxkumocol_ratio = ratio;
}
/* 801A8AD8-801A8B38 1A3418 0060+00 0/0 1/1 0/0 .text dKy_itudemo_se__Fv */
void dKy_itudemo_se() {
if (g_env_light.moya_se != 0) {
mDoAud_seStart(g_env_light.moya_se, NULL, 0, 0);
}
}
/* 801A8B38-801A8B58 1A3478 0020+00 1/1 2/2 11/11 .text dKy_get_dayofweek__Fv */
int dKy_get_dayofweek() {
return dComIfGs_getDate() % 7;
}
/* 801A8B58-801A8B68 1A3498 0010+00 0/0 3/3 0/0 .text dKy_set_nexttime__Ff */
void dKy_set_nexttime(f32 nexttime) {
g_env_light.nexttime = nexttime;
}
/* 801A8B68-801A8BC8 1A34A8 0060+00 0/0 1/1 0/0 .text dKy_instant_timechg__Ff */
void dKy_instant_timechg(f32 time) {
if (time < g_env_light.getDaytime()) {
dComIfGs_setDate(dComIfGs_getDate() + 1);
dKankyo_DayProc();
}
dComIfGs_setTime(time);
}
/* 801A8BC8-801A8C04 1A3508 003C+00 0/0 1/1 0/0 .text dKy_instant_rainchg__Fv */
void dKy_instant_rainchg() {
dKyw_rain_set(250);
g_env_light.mColpatWeather = 1;
g_env_light.wether_pat0 = 1;
g_env_light.wether_pat1 = 1;
}
/* 801A8C04-801A8E20 1A3544 021C+00 3/3 0/0 0/0 .text NewAmbColGet__FP11_GXColorS10 */
static GXColor NewAmbColGet(GXColorS10* in_col_p) {
GXColorS10 sp18, sp10;
sp18 = *in_col_p;
sp10.r = sp18.r * 4;
sp10.g = sp18.g * 4;
sp10.b = sp18.b * 4;
if (sp10.r > 0xFF) {
f32 temp_f31 = 255.0f / sp10.r;
sp10.r *= temp_f31;
sp10.g *= temp_f31;
sp10.b *= temp_f31;
}
if (sp10.g > 0xFF) {
f32 temp_f31_2 = 255.0f / sp10.g;
sp10.r *= temp_f31_2;
sp10.g *= temp_f31_2;
sp10.b *= temp_f31_2;
}
if (sp10.b > 0xFF) {
f32 temp_f31_3 = 255.0f / sp10.b;
sp10.r *= temp_f31_3;
sp10.g *= temp_f31_3;
sp10.b *= temp_f31_3;
}
GXColor amb_col;
amb_col.r = sp10.r;
amb_col.g = sp10.g;
amb_col.b = sp10.b;
amb_col.a = 0xFF;
return amb_col;
}
/* 803BC0A0-803BC0B4 -00001 0014+00 1/0 0/0 0/0 .data l_dKy_Method */
static leafdraw_method_class l_dKy_Method = {
(process_method_func)dKy_Create, (process_method_func)dKy_Delete,
(process_method_func)dKy_Execute, (process_method_func)dKy_IsDelete,
(process_method_func)dKy_Draw,
};
/* 803BC0B4-803BC0DC -00001 0028+00 0/0 0/0 1/0 .data g_profile_KANKYO */
extern kankyo_process_profile_definition g_profile_KANKYO = {
fpcLy_CURRENT_e,
1,
fpcPi_CURRENT_e,
PROC_KANKYO,
&g_fpcLf_Method.base,
sizeof(sub_kankyo__class),
0,
0,
&g_fopKy_Method,
2,
&l_dKy_Method,
};
// fixes float literal order
static f32 dummy() {
return 50.0f;
}
/* 801A8E20-801A9BE4 1A3760 0DC4+00 2/2 0/0 0/0 .text
* dKy_ParticleColor_get_base__FP4cXyzP12dKy_tevstr_cP8_GXColorP8_GXColorP8_GXColorP8_GXColorf */
void dKy_ParticleColor_get_base(cXyz* param_0, dKy_tevstr_c* param_1, GXColor* param_2,
GXColor* param_3, GXColor* param_4, GXColor* param_5, f32 param_6) {
GXColor sp70[3];
cXyz sp64;
f32 sp58[] = {100000000.0f, 100000000.0f, 100000000.0f};
int i;
u8 spD = 0;
s8 room_no;
GXColorS10 sp48;
J3DLightInfo* sp44;
GXColor sp40;
int sp3C;
int sp38;
stage_pure_lightvec_info_class* stage_light_info_p;
int sp30;
for (i = 0; i < 6; i++) {
if (param_1 != NULL) {
sp44 = &param_1->mLights[i].getLightInfo();
sp40 = sp44->mColor;
} else {
sp38 = dComIfGp_roomControl_getStayNo();
if (dKy_SunMoon_Light_Check() == TRUE && i <= 1) {
sp40 = g_env_light.dungeonlight[i].mColor;
} else if (dComIfGp_roomControl_getStatusRoomDt(sp38) != NULL) {
stage_light_info_p =
dComIfGp_roomControl_getStatusRoomDt(sp38)->getLightVecInfo();
sp30 = dComIfGp_roomControl_getStatusRoomDt(sp38)->getLightVecInfoNum();
if (i < sp30) {
sp40 = g_env_light.dungeonlight[i].mColor;
} else {
sp40.r = 0;
sp40.g = 0;
sp40.b = 0;
}
}
}
f32 var_f31;
if (dKy_SunMoon_Light_Check() == TRUE && i <= 1) {
if (g_env_light.daytime >= 90.0f && g_env_light.daytime <= 285.0f) {
if (i == 0) {
var_f31 = 1.0f;
} else {
var_f31 = 2.0f;
}
} else if (i == 0) {
var_f31 = 2.0f;
} else {
var_f31 = 1.0f;
}
if (strcmp(dComIfGp_getStartStageName(), "F_SP114") == 0) {
if (sp40.r < 15.0f) {
sp40.r = 15;
}
if (sp40.g < 17.0f) {
sp40.g = 17;
}
if (sp40.b < 20.0f) {
sp40.b = 20;
}
}
} else if (sp40.r != 0 || sp40.g != 0 || sp40.b != 0) {
stage_pure_lightvec_info_class* stage_light_info_p;
if (param_1 != NULL && param_1->room_no >= 0) {
stage_light_info_p = dComIfGp_roomControl_getStatusRoomDt(param_1->room_no)
->getLightVecInfo();
sp3C = dComIfGp_roomControl_getStatusRoomDt(param_1->room_no)
->getLightVecInfoNum();
} else {
stage_light_info_p = dComIfGp_roomControl_getStatusRoomDt(dComIfGp_roomControl_getStayNo())->getLightVecInfo();
sp3C = dComIfGp_roomControl_getStatusRoomDt(dComIfGp_roomControl_getStayNo())->getLightVecInfoNum();
}
f32 var_f27;
f32 var_f26;
if (stage_light_info_p != 0) {
if (i < sp3C) {
sp64.x = stage_light_info_p[i].position.x;
sp64.y = stage_light_info_p[i].position.y;
sp64.z = stage_light_info_p[i].position.z;
if (param_1 != NULL && param_1->room_no >= 0) {
room_no = param_1->room_no;
} else {
room_no = dComIfGp_roomControl_getStayNo();
}
if (dKy_lightswitch_check(&stage_light_info_p[i], room_no) == TRUE) {
var_f27 = 190.0f * stage_light_info_p[i].radius;
} else {
var_f27 = 0.0f;
}
} else {
sp64.x = lightStatusPt[i + 2].position.x;
sp64.y = lightStatusPt[i + 2].position.y;
sp64.z = lightStatusPt[i + 2].position.z;
var_f27 = 190.0f * lightStatusPt[i + 2].mRefDist;
}
} else {
sp64.x = 100000000.0f;
sp64.y = 100000000.0f;
sp64.z = 100000000.0f;
var_f27 = 0.0f;
}
var_f31 = param_0->abs(sp64);
if (var_f31 <= 0.0f) {
var_f31 = 0.0000000000001f;
}
if (var_f27 > 0.0f) {
var_f26 = var_f27 / var_f31;
} else {
var_f26 = 0.0f;
}
if (var_f26 < 1.0f) {
sp40.r *= var_f26;
sp40.g *= var_f26;
sp40.b *= var_f26;
} else {
var_f31 = 5.0f;
}
}
if (sp58[0] > var_f31) {
sp58[2] = sp58[1];
sp58[1] = sp58[0];
sp58[0] = var_f31;
sp70[2] = sp70[1];
sp70[1] = sp70[0];
sp70[0] = sp40;
} else if (sp58[1] > var_f31) {
sp58[2] = sp58[1];
sp58[1] = var_f31;
sp70[2] = sp70[1];
sp70[1] = sp40;
} else if (sp58[2] > var_f31) {
sp58[2] = var_f31;
sp70[2] = sp40;
}
}
sp48.r = 0;
sp48.g = 0;
sp48.b = 0;
for (int i = 0; i < 3; i++) {
if (sp58[i] < 100000000.0f) {
spD++;
}
}
static f32 parcent_tabel[][3] = {
{0.0f, 0.0f, 0.0f},
{1.0f, 0.0f, 0.0f},
{0.7f, 0.3f, 0.0f},
{0.6f, 0.3f, 0.1f},
};
if (sp58[0] < 100000000.0f) {
f32 temp_f28 = parcent_tabel[spD][0];
sp48.r = sp70[0].r * temp_f28;
sp48.g = sp70[0].g * temp_f28;
sp48.b = sp70[0].b * temp_f28;
}
for (int i = 1; i < 3; i++) {
if (sp58[i] < 100000000.0f) {
f32 temp_f28 = parcent_tabel[spD][i];
sp48.r += (s16)(sp70[i].r * temp_f28);
sp48.g += (s16)(sp70[i].g * temp_f28);
sp48.b += (s16)(sp70[i].b * temp_f28);
}
}
*param_3 = NewAmbColGet(&sp48);
sp48.r = (0.8f * param_2->r) + (1.2f * param_3->r);
sp48.g = (0.8f * param_2->g) + (1.2f * param_3->g);
sp48.b = (0.8f * param_2->b) + (1.2f * param_3->b);
if (sp48.r > 0xFF) {
f32 temp_f30 = 255.0f / sp48.r;
sp48.r *= temp_f30;
sp48.g *= temp_f30;
sp48.b *= temp_f30;
}
if (sp48.g > 0xFF) {
f32 temp_f30 = 255.0f / sp48.g;
sp48.r *= temp_f30;
sp48.g *= temp_f30;
sp48.b *= temp_f30;
}
if (sp48.b > 0xFF) {
f32 temp_f30 = 255.0f / sp48.b;
sp48.r *= temp_f30;
sp48.g *= temp_f30;
sp48.b *= temp_f30;
}
GXColorS10 sp50;
sp50.r = sp48.r & 0xFF;
sp50.g = sp48.g & 0xFF;
sp50.b = sp48.b & 0xFF;
f32 sp20 = param_4->r / 255.0f;
f32 sp1C = param_4->g / 255.0f;
f32 sp18 = param_4->b / 255.0f;
param_2->r = (sp20 * (sp50.r * (1.0f - param_6))) + (param_4->r * param_6);
param_2->g = (sp1C * (sp50.g * (1.0f - param_6))) + (param_4->g * param_6);
param_2->b = (sp18 * (sp50.b * (1.0f - param_6))) + (param_4->b * param_6);
sp20 = (param_5->r / 255.0f);
sp1C = (param_5->g / 255.0f);
sp18 = (param_5->b / 255.0f);
param_3->r = (sp20 * (sp50.r * (1.0f - param_6))) + (param_5->r * param_6);
param_3->g = (sp1C * (sp50.g * (1.0f - param_6))) + (param_5->g * param_6);
param_3->b = (sp18 * (sp50.b * (1.0f - param_6))) + (param_5->b * param_6);
}
/* 801A9BE4-801A9CBC 1A4524 00D8+00 0/0 3/3 0/0 .text
* dKy_ParticleColor_get_actor__FP4cXyzP12dKy_tevstr_cP8_GXColorP8_GXColorP8_GXColorP8_GXColorf */
void dKy_ParticleColor_get_actor(cXyz* param_0, dKy_tevstr_c* tevstr_p, GXColor* param_2,
GXColor* param_3, GXColor* param_4, GXColor* param_5,
f32 param_6) {
if (tevstr_p != NULL) {
*param_2 = NewAmbColGet(&tevstr_p->AmbCol);
} else {
*param_2 = NewAmbColGet(&g_env_light.actor_amb_col);
}
dKy_ParticleColor_get_base(param_0, tevstr_p, param_2, param_3, param_4, param_5, param_6);
}
/* 801A9CBC-801A9D60 1A45FC 00A4+00 0/0 6/6 0/0 .text
* dKy_ParticleColor_get_bg__FP4cXyzP12dKy_tevstr_cP8_GXColorP8_GXColorP8_GXColorP8_GXColorf */
void dKy_ParticleColor_get_bg(cXyz* param_0, dKy_tevstr_c* tevstr_p, GXColor* param_2,
GXColor* param_3, GXColor* param_4, GXColor* param_5, f32 param_6) {
*param_2 = NewAmbColGet(&g_env_light.bg_amb_col[0]);
dKy_ParticleColor_get_base(param_0, tevstr_p, param_2, param_3, param_4, param_5, param_6);
}
/* 801A9D60-801AA664 1A46A0 0904+00 1/1 0/0 17/17 .text dKy_BossLight_set__FP4cXyzP8_GXColorfUc */
int dKy_BossLight_set(cXyz* pos_p, GXColor* color_p, f32 ref_dist, u8 param_3) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
camera_class* camera = (camera_class*)dComIfGp_getCamera(0);
int sp10 = 0;
f32 var_f31 = 0.0f;
u8 spA = 0xFF;
int stage_light_info_num = 0;
int i;
if (strcmp(dComIfGp_getStartStageName(), "F_SP118") != 0) {
u8 room_no = dComIfGp_roomControl_getStayNo();
if (dComIfGp_roomControl_getStatusRoomDt(room_no) == NULL) {
return 0;
}
stage_light_info_num = dComIfGp_roomControl_getStatusRoomDt(room_no)->getLightVecInfoNum();
if (stage_light_info_num < 0 || stage_light_info_num > 6) {
stage_light_info_num = 6;
}
}
BOSS_LIGHT* boss_light_p;
if (param_3 == 0) {
boss_light_p = kankyo->field_0x0c18;
} else {
boss_light_p = kankyo->field_0x0d58;
}
for (i = 1; i < 6 - stage_light_info_num; i++) {
if (boss_light_p[i].field_0x26 == 1 && pos_p->x == boss_light_p[i].mPos.x &&
pos_p->y == boss_light_p[i].mPos.y && pos_p->z == boss_light_p[i].mPos.z)
{
return 0;
}
}
for (i = 1; i < 6 - stage_light_info_num; i++) {
if (boss_light_p[i].field_0x26 == 0) {
boss_light_p[i].mPos = *pos_p;
boss_light_p[i].mColor.r = color_p->r;
boss_light_p[i].mColor.g = color_p->g;
boss_light_p[i].mColor.b = color_p->b;
boss_light_p[i].mColor.a = 0xFF;
boss_light_p[i].mRefDistance = ref_dist;
boss_light_p[i].field_0x14 = 0.99f;
boss_light_p[i].mCutoffAngle = 90.0f;
boss_light_p[i].mAngleX = 0.0f;
boss_light_p[i].mAngleY = 0.0f;
boss_light_p[i].mAngleAttenuation = GX_SP_OFF;
boss_light_p[i].mDistAttenuation = GX_DA_STEEP;
boss_light_p[i].field_0x26 = 1;
sp10 = 1;
break;
}
}
for (i = 1; i < 6 - stage_light_info_num; i++) {
if (boss_light_p[i].field_0x26 != 0) {
cXyz sp1C(boss_light_p[i].mPos);
if (strcmp(dComIfGp_getStartStageName(), "D_SB03") == 0) {
sp1C.x = camera->lookat.eye.x;
sp1C.z = camera->lookat.eye.z;
if (sp1C.abs(camera->lookat.eye) > 2000.0f) {
var_f31 = 99999.9f;
spA = i;
break;
} else {
if (boss_light_p[i].mPos.abs(camera->lookat.eye) > var_f31) {
var_f31 = boss_light_p[i].mPos.abs(camera->lookat.eye);
spA = i;
}
}
} else {
if (boss_light_p[i].mPos.abs(camera->lookat.eye) > var_f31) {
var_f31 = boss_light_p[i].mPos.abs(camera->lookat.eye);
spA = i;
}
}
}
}
if (sp10 == 0 && spA != 0xFF) {
i = spA;
if (i < 6 && pos_p->abs(camera->lookat.eye) < var_f31) {
boss_light_p[i].mPos = *pos_p;
boss_light_p[i].mColor.r = color_p->r;
boss_light_p[i].mColor.g = color_p->g;
boss_light_p[i].mColor.b = color_p->b;
boss_light_p[i].mColor.a = 0xFF;
boss_light_p[i].mRefDistance = ref_dist;
boss_light_p[i].field_0x14 = 0.99f;
boss_light_p[i].mCutoffAngle = 90.0f;
boss_light_p[i].mAngleX = 0.0f;
boss_light_p[i].mAngleY = 0.0f;
boss_light_p[i].mAngleAttenuation = GX_SP_OFF;
boss_light_p[i].mDistAttenuation = GX_DA_STEEP;
boss_light_p[i].field_0x26 = 1;
sp10 = 1;
}
}
return sp10;
}
/* 801AA664-801AAC5C 1A4FA4 05F8+00 0/0 0/0 3/3 .text
* dKy_BossSpotLight_set__FP4cXyzfffP8_GXColorfUcUc */
int dKy_BossSpotLight_set(cXyz* pos_p, f32 angle_x, f32 angle_y, f32 cutoff, GXColor* color_p,
f32 ref_dist, u8 spot_type, u8 distattn_type) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
camera_class* camera = (camera_class*)dComIfGp_getCamera(0);
int spC = 0;
f32 var_f31 = 0.0f;
u8 sp8 = 0xFF;
int i;
for (i = 1; i < 6; i++) {
if (kankyo->field_0x0c18[i].field_0x26 == 0) {
kankyo->field_0x0c18[i].mPos = *pos_p;
kankyo->field_0x0c18[i].mColor.r = color_p->r;
kankyo->field_0x0c18[i].mColor.g = color_p->g;
kankyo->field_0x0c18[i].mColor.b = color_p->b;
kankyo->field_0x0c18[i].mColor.a = 0xFF;
kankyo->field_0x0c18[i].mRefDistance = ref_dist;
kankyo->field_0x0c18[i].field_0x14 = 0.99f;
kankyo->field_0x0c18[i].mCutoffAngle = cutoff;
kankyo->field_0x0c18[i].mAngleX = angle_x;
kankyo->field_0x0c18[i].mAngleY = angle_y + 90.0f;
kankyo->field_0x0c18[i].mAngleAttenuation = spot_type;
kankyo->field_0x0c18[i].mDistAttenuation = distattn_type;
kankyo->field_0x0c18[i].field_0x26 = 1;
spC = 1;
break;
}
}
if (spC == 0) {
for (i = 1; i < 6; i++) {
if (kankyo->field_0x0c18[i].field_0x26 != 0 &&
kankyo->field_0x0c18[i].mPos.abs(camera->lookat.eye) > var_f31)
{
var_f31 = kankyo->field_0x0c18[i].mPos.abs(camera->lookat.eye);
sp8 = i;
}
}
if (sp8 != 0xFF) {
i = sp8;
if (i < 6 && pos_p->abs(camera->lookat.eye) <
kankyo->field_0x0c18[i].mPos.abs(camera->lookat.eye))
{
kankyo->field_0x0c18[i].mPos = *pos_p;
kankyo->field_0x0c18[i].mColor.r = color_p->r;
kankyo->field_0x0c18[i].mColor.g = color_p->g;
kankyo->field_0x0c18[i].mColor.b = color_p->b;
kankyo->field_0x0c18[i].mColor.a = 0xFF;
kankyo->field_0x0c18[i].mRefDistance = ref_dist;
kankyo->field_0x0c18[i].field_0x14 = 0.99f;
kankyo->field_0x0c18[i].mCutoffAngle = cutoff;
kankyo->field_0x0c18[i].mAngleX = angle_x;
kankyo->field_0x0c18[i].mAngleY = angle_y + 90.0f;
kankyo->field_0x0c18[i].mAngleAttenuation = spot_type;
kankyo->field_0x0c18[i].mDistAttenuation = distattn_type;
kankyo->field_0x0c18[i].field_0x26 = 1;
spC = 1;
}
}
}
return spC;
}
/* 801AAC5C-801AAD50 1A559C 00F4+00 0/0 1/1 0/0 .text
* dKy_WolfEyeLight_set__FP4cXyzfffP8_GXColorfUcUc */
int dKy_WolfEyeLight_set(cXyz* pos_p, f32 angle_x, f32 angle_y, f32 cutoff, GXColor* color_p,
f32 ref_dist, u8 spot_type, u8 distattn_type) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
kankyo->field_0x0c18[0].mPos = *pos_p;
kankyo->field_0x0c18[0].mColor.r = color_p->r;
kankyo->field_0x0c18[0].mColor.g = color_p->g;
kankyo->field_0x0c18[0].mColor.b = color_p->b;
kankyo->field_0x0c18[0].mColor.a = 255;
kankyo->field_0x0c18[0].mRefDistance = ref_dist;
kankyo->field_0x0c18[0].field_0x14 = 0.99f;
kankyo->field_0x0c18[0].mCutoffAngle = cutoff;
kankyo->field_0x0c18[0].mAngleX = angle_x;
kankyo->field_0x0c18[0].mAngleY = angle_y + 90.0f;
kankyo->field_0x0c18[0].mAngleAttenuation = spot_type;
kankyo->field_0x0c18[0].mDistAttenuation = distattn_type;
f32 var_f31;
f32 var_f30;
f32 var_f29;
switch (kankyo->light_size) {
case LIGHT_SIZE_S:
var_f31 = 50.0f;
var_f30 = 1.0f;
var_f29 = 0.9f;
break;
case LIGHT_SIZE_M:
var_f31 = 200.0f;
var_f30 = 1.0f;
var_f29 = 1.0f;
break;
case LIGHT_SIZE_L:
var_f31 = 350.0f;
var_f30 = 1.5f;
var_f29 = 1.5f;
break;
case LIGHT_SIZE_LL:
default:
var_f31 = 1500.0f;
var_f30 = 4.0f;
var_f29 = 1.5f;
}
kankyo->field_0x127c = var_f31;
kankyo->field_0x0c18[0].mRefDistance *= var_f30;
kankyo->field_0x0c18[0].mCutoffAngle *= var_f29;
kankyo->field_0x0c18[0].field_0x26 = 1;
return 1;
}
/* 801AAD50-801AB01C 1A5690 02CC+00 1/1 0/0 0/0 .text dKy_twilight_camelight_set__Fv */
void dKy_twilight_camelight_set() {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
fopAc_ac_c* player_p = dComIfGp_getPlayer(0);
camera_class* camera_p = (camera_class*)dComIfGp_getCamera(0);
u8 sp8 = 0;
if (strcmp(dComIfGp_getStartStageName(), "R_SP107") != 0 ||
dComIfGp_roomControl_getStayNo() != 3 || dComIfGp_getStartStageLayer() != 12)
{
if (!dKy_darkworld_check() || memcmp(dComIfGp_getStartStageName(), "D_MN08", 6) == 0) {
return;
}
if (!daPy_py_c::checkNowWolfPowerUp()) {
for (int i = 0; i < 6; i++) {
if (kankyo->field_0x0c18[i].field_0x26 != 1) {
dKy_twi_wolflight_set(i);
kankyo->field_0x0c18[i].field_0x14 = 0.99f;
kankyo->field_0x0c18[i].mColor.a = 254;
f32 var_f31 = 0.0f;
if (player_p != NULL) {
f32 var_f30 = camera_p->lookat.eye.y - player_p->current.pos.y;
if (var_f30 < 0.0f) {
var_f30 = 0.0f;
}
if (var_f30 > 600.0f) {
var_f30 = 600.0f;
}
var_f31 = var_f30 / 450.0f;
}
switch (g_env_light.light_size) {
case LIGHT_SIZE_S:
kankyo->field_0x0c18[i].mColor.r = 0x19;
kankyo->field_0x0c18[i].mColor.g = 0x5A;
kankyo->field_0x0c18[i].mColor.b = 0xB7;
cLib_addCalc(&kankyo->field_0x0c18[i].mRefDistance,
1.0625f + (0.75f * var_f31), 0.2f, 10.0f, 0.0001f);
kankyo->field_0x0c18[i].mCutoffAngle = 90.0f;
break;
case LIGHT_SIZE_M:
kankyo->field_0x0c18[i].mColor.r = 0x48;
kankyo->field_0x0c18[i].mColor.g = 0x87;
kankyo->field_0x0c18[i].mColor.b = 0xCE;
cLib_addCalc(&kankyo->field_0x0c18[i].mRefDistance,
1.7f + (0.75f * var_f31), 0.2f, 10.0f, 0.0001f);
kankyo->field_0x0c18[i].mCutoffAngle = 70.0f;
break;
case LIGHT_SIZE_L:
kankyo->field_0x0c18[i].mColor.r = 0x48;
kankyo->field_0x0c18[i].mColor.g = 0x87;
kankyo->field_0x0c18[i].mColor.b = 0xCE;
cLib_addCalc(&kankyo->field_0x0c18[i].mRefDistance,
2.5500002f + (0.75f * var_f31), 0.2f, 10.0f, 0.0001f);
kankyo->field_0x0c18[i].mCutoffAngle = 70.0f;
break;
case LIGHT_SIZE_LL:
kankyo->field_0x0c18[i].mColor.r = 0x50;
kankyo->field_0x0c18[i].mColor.g = 0x87;
kankyo->field_0x0c18[i].mColor.b = 0xCE;
cLib_addCalc(&kankyo->field_0x0c18[i].mRefDistance,
3.4f + (0.75f * var_f31), 0.2f, 10.0f, 0.0001f);
kankyo->field_0x0c18[i].mCutoffAngle = 65.0f;
break;
}
kankyo->field_0x0c18[i].mAngleAttenuation = GX_SP_COS;
kankyo->field_0x0c18[i].mDistAttenuation = GX_DA_STEEP;
kankyo->field_0x0c18[i].field_0x26 = 1;
break;
}
}
}
}
}
/* 801AB01C-801AB270 1A595C 0254+00 1/1 0/0 0/0 .text dKy_WaterIn_Light_set__Fv */
// NONMATCHING - some weirdness with temp stores
void dKy_WaterIn_Light_set() {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
fopAc_ac_c* player_p = dComIfGp_getPlayer(0);
camera_class* camera = (camera_class*)dComIfGp_getCamera(0);
int sp10 = 0;
int spC = 0;
int sp8 = 1;
if (strcmp(dComIfGp_getStartStageName(), "F_SP109") == 0 ||
strcmp(dComIfGp_getStartStageName(), "F_SP115") == 0 ||
strcmp(dComIfGp_getStartStageName(), "F_SP122") == 0)
{
sp8 = 3;
}
for (int i = 0; i < 6; i++) {
if (kankyo->field_0x0c18[i].field_0x26 != 1) {
dKy_twi_wolflight_set(i);
kankyo->field_0x0c18[i].mColor.r = 0x8A;
kankyo->field_0x0c18[i].mColor.g = 0xC0;
kankyo->field_0x0c18[i].mColor.b = 0xBC;
kankyo->field_0x0c18[i].mColor.a = 0xFD;
f32 var_f26 = 0.0f;
if (player_p != NULL) {
f32 var_f31 = camera->lookat.eye.y - player_p->current.pos.y;
if (var_f31 < 0.0f) {
var_f31 = 0.0f;
}
if (var_f31 > 600.0f) {
var_f31 = 600.0f;
}
var_f26 = var_f31 / 450.0f;
}
kankyo->field_0x0c18[i].mRefDistance = 7.2250004f + (0.75f * var_f26);
kankyo->field_0x0c18[i].mCutoffAngle = 28.0f;
kankyo->field_0x0c18[i].mAngleAttenuation = 2;
kankyo->field_0x0c18[i].mDistAttenuation = 3;
f32* var_r30 = &kankyo->field_0x0c18[i].mRefDistance;
f32* var_r29 = &kankyo->field_0x0c18[i].mCutoffAngle;
if (strcmp(dComIfGp_getStartStageName(), "D_MN01A") == 0) {
dBgS_CamGndChk_Wtr sp28;
cXyz sp1C;
sp8 = 1;
*var_r29 = 60.0f;
sp1C = camera->lookat.eye;
sp1C.y += 100000.0f;
sp28.SetPos(&sp1C);
f32 var_f30 = (dComIfG_Bgsp().GroundCross(&sp28) - camera->lookat.eye.y) / 3000.0f;
if (var_f30 < 0.0f) {
var_f30 = 0.0f;
}
if (var_f30 > 1.0f) {
var_f30 = 1.0f;
}
*var_r30 *= var_f30;
}
f32 var_f29, var_f28, var_f27;
switch (sp8) {
case 0:
case 1:
var_f29 = 200.0f;
var_f28 = 1.0f;
var_f27 = 1.0f;
break;
case 2:
case 3:
case 4:
default:
var_f29 = 200.0f;
var_f28 = 2.0f;
var_f27 = 1.25f;
break;
}
kankyo->field_0x127c = var_f29;
*var_r30 *= var_f28;
*var_r29 *= var_f27;
kankyo->field_0x0c18[i].field_0x26 = 1;
sp10 = 1;
}
break;
}
}
/* 801AB270-801AB280 1A5BB0 0010+00 0/0 2/2 0/0 .text dKy_camera_water_in_status_set__FUc
*/
void dKy_camera_water_in_status_set(u8 status) {
g_env_light.camera_water_in_status = status;
}
/* 801AB280-801AB290 1A5BC0 0010+00 3/3 1/1 5/5 .text dKy_camera_water_in_status_check__Fv */
BOOL dKy_camera_water_in_status_check() {
return g_env_light.camera_water_in_status;
}
/* 801AB290-801AB3A8 1A5BD0 0118+00 0/0 5/5 0/0 .text dKy_pol_efftype_get__FPC13cBgS_PolyInfo */
u8 dKy_pol_efftype_get(const cBgS_PolyInfo* polyinfo_p) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
if (polyinfo_p == NULL || &dComIfG_Bgsp() == NULL) {
return 0xFF;
}
int z0 = dComIfG_Bgsp().GetPolyAtt0(*polyinfo_p);
if (strcmp(dComIfGp_getStartStageName(), "F_SP127") == 0 &&
g_env_light.fishing_hole_season == 4)
{
if (z0 == 4) {
z0 = 13;
}
} else if (strcmp(dComIfGp_getStartStageName(), "D_MN05A") == 0 &&
dComIfGs_isStageBossEnemy() && z0 == 11)
{
z0 = 7;
}
u8 efftype;
int z1 = dComIfG_Bgsp().GetPolyAtt1(*polyinfo_p);
if (kankyo->pol_efftbl != 0) {
efftype = kankyo->pol_efftbl[z0].data[z1];
} else {
efftype = 0xFF;
}
return efftype;
}
/* 801AB3A8-801AB4C0 1A5CE8 0118+00 0/0 2/2 0/0 .text dKy_pol_efftype2_get__FPC13cBgS_PolyInfo */
u8 dKy_pol_efftype2_get(const cBgS_PolyInfo* polyinfo_p) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
if (polyinfo_p == NULL || &dComIfG_Bgsp() == NULL) {
return 0xFF;
}
int z0 = dComIfG_Bgsp().GetPolyAtt0(*polyinfo_p);
if (strcmp(dComIfGp_getStartStageName(), "F_SP127") == 0 &&
g_env_light.fishing_hole_season == 4)
{
if (z0 == 4) {
z0 = 13;
}
} else if (strcmp(dComIfGp_getStartStageName(), "D_MN05A") == 0 &&
dComIfGs_isStageBossEnemy() && z0 == 11)
{
z0 = 7;
}
u8 efftype;
int z1 = dComIfG_Bgsp().GetPolyAtt1(*polyinfo_p);
if (kankyo->pol_efftbl2 != 0) {
efftype = kankyo->pol_efftbl2[z0].data[z1];
} else {
efftype = 0xFF;
}
return efftype;
}
/* 801AB4C0-801AB59C 1A5E00 00DC+00 0/0 9/9 21/21 .text dKy_pol_sound_get__FPC13cBgS_PolyInfo */
u8 dKy_pol_sound_get(const cBgS_PolyInfo* polyinfo_p) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
if (polyinfo_p == NULL || &dComIfG_Bgsp() == NULL) {
return 0;
}
int z0 = dComIfG_Bgsp().GetPolyAtt0(*polyinfo_p);
if (!strcmp(dComIfGp_getStartStageName(), "F_SP127") && g_env_light.fishing_hole_season == 4 &&
z0 == 4)
{
z0 = 13;
}
u8 sound;
int z1 = dComIfG_Bgsp().GetPolyAtt1(*polyinfo_p);
if (kankyo->pol_sound != NULL) {
sound = kankyo->pol_sound[z0].data[z1];
} else {
sound = 0;
}
if (sound == 0xFF) {
sound = 0;
}
return sound;
}
/* 801AB59C-801AB668 1A5EDC 00CC+00 0/0 5/5 0/0 .text dKy_pol_argument_get__FPC13cBgS_PolyInfo */
u8 dKy_pol_argument_get(const cBgS_PolyInfo* polyinfo_p) {
dScnKy_env_light_c* kankyo = &g_env_light;
if (polyinfo_p == NULL || &dComIfG_Bgsp() == NULL) {
return 0;
}
int z0 = dComIfG_Bgsp().GetPolyAtt0(*polyinfo_p);
if (!strcmp(dComIfGp_getStartStageName(), "F_SP127") && g_env_light.fishing_hole_season == 4 &&
z0 == 4)
{
z0 = 13;
}
int z1 = dComIfG_Bgsp().GetPolyAtt1(*polyinfo_p);
if (kankyo->pol_arg != NULL) {
return kankyo->pol_arg[z0].data[z1];
}
return 0;
}
/* 801AB668-801AB7D0 1A5FA8 0168+00 0/0 1/1 2/2 .text
* dKy_pol_eff_prim_get__FPC13cBgS_PolyInfoP8_GXColor */
u8 dKy_pol_eff_prim_get(const cBgS_PolyInfo* polyinfo_p, GXColor* out_color_p) {
dScnKy_env_light_c* kankyo = &g_env_light;
if (polyinfo_p == NULL || out_color_p == NULL || &dComIfG_Bgsp() == NULL) {
return 0xFF;
}
int z0 = dComIfG_Bgsp().GetPolyAtt0(*polyinfo_p);
if (strcmp(dComIfGp_getStartStageName(), "F_SP127") == 0 &&
g_env_light.fishing_hole_season == 4)
{
if (z0 == 4) {
z0 = 13;
}
} else if (strcmp(dComIfGp_getStartStageName(), "D_MN05A") == 0 &&
dComIfGs_isStageBossEnemy() && z0 == 11)
{
z0 = 7;
}
int z1 = dComIfG_Bgsp().GetPolyAtt1(*polyinfo_p);
u8 eff_id;
if (kankyo->pol_effcol != NULL) {
eff_id = kankyo->pol_effcol[z0].data[z1];
} else {
return 0xFF;
}
if (eff_id >= 100) {
return 0xFF;
}
out_color_p->r = kankyo->colordata_tbl[eff_id].data[0];
out_color_p->g = kankyo->colordata_tbl[eff_id].data[1];
out_color_p->b = kankyo->colordata_tbl[eff_id].data[2];
return eff_id;
}
/* 801AB7D0-801AB93C 1A6110 016C+00 0/0 1/1 2/2 .text
* dKy_pol_eff_env_get__FPC13cBgS_PolyInfoP8_GXColor */
u8 dKy_pol_eff_env_get(const cBgS_PolyInfo* polyinfo_p, GXColor* out_color_p) {
dScnKy_env_light_c* kankyo = &g_env_light;
if (polyinfo_p == NULL || out_color_p == NULL || &dComIfG_Bgsp() == NULL) {
return 0xFF;
}
int z0 = dComIfG_Bgsp().GetPolyAtt0(*polyinfo_p);
if (strcmp(dComIfGp_getStartStageName(), "F_SP127") == 0 &&
g_env_light.fishing_hole_season == 4)
{
if (z0 == 4) {
z0 = 13;
}
} else if (strcmp(dComIfGp_getStartStageName(), "D_MN05A") == 0 &&
dComIfGs_isStageBossEnemy() && z0 == 11)
{
z0 = 7;
}
int z1 = dComIfG_Bgsp().GetPolyAtt1(*polyinfo_p);
u8 eff_id;
if (kankyo->pol_effcol != NULL) {
eff_id = kankyo->pol_effcol[z0].data[z1];
} else {
return 0xFF;
}
if (eff_id >= 100) {
return 0xFF;
}
out_color_p->r = kankyo->colordata_tbl[eff_id].data[3];
out_color_p->g = kankyo->colordata_tbl[eff_id].data[4];
out_color_p->b = kankyo->colordata_tbl[eff_id].data[5];
return eff_id;
}
/* 801AB93C-801ABAA4 1A627C 0168+00 0/0 1/1 2/2 .text
* dKy_pol_eff2_prim_get__FPC13cBgS_PolyInfoP8_GXColor */
u8 dKy_pol_eff2_prim_get(const cBgS_PolyInfo* polyinfo_p, GXColor* out_color_p) {
dScnKy_env_light_c* kankyo = &g_env_light;
if (polyinfo_p == NULL || out_color_p == NULL || &dComIfG_Bgsp() == NULL) {
return 0xFF;
}
int z0 = dComIfG_Bgsp().GetPolyAtt0(*polyinfo_p);
if (strcmp(dComIfGp_getStartStageName(), "F_SP127") == 0 &&
g_env_light.fishing_hole_season == 4)
{
if (z0 == 4) {
z0 = 13;
}
} else if (strcmp(dComIfGp_getStartStageName(), "D_MN05A") == 0 &&
dComIfGs_isStageBossEnemy() && z0 == 11)
{
z0 = 7;
}
int z1 = dComIfG_Bgsp().GetPolyAtt1(*polyinfo_p);
u8 eff_id;
if (kankyo->pol_effcol2 != NULL) {
eff_id = kankyo->pol_effcol2[z0].data[z1];
} else {
return 0xFF;
}
if (eff_id >= 100) {
return 0xFF;
}
out_color_p->r = kankyo->colordata_tbl[eff_id].data[0];
out_color_p->g = kankyo->colordata_tbl[eff_id].data[1];
out_color_p->b = kankyo->colordata_tbl[eff_id].data[2];
return eff_id;
}
/* 801ABAA4-801ABC10 1A63E4 016C+00 0/0 1/1 2/2 .text
* dKy_pol_eff2_env_get__FPC13cBgS_PolyInfoP8_GXColor */
u8 dKy_pol_eff2_env_get(const cBgS_PolyInfo* polyinfo_p, GXColor* out_color_p) {
dScnKy_env_light_c* kankyo = &g_env_light;
if (polyinfo_p == NULL || out_color_p == NULL || &dComIfG_Bgsp() == NULL) {
return 0xFF;
}
int z0 = dComIfG_Bgsp().GetPolyAtt0(*polyinfo_p);
if (strcmp(dComIfGp_getStartStageName(), "F_SP127") == 0 &&
g_env_light.fishing_hole_season == 4)
{
if (z0 == 4) {
z0 = 13;
}
} else if (strcmp(dComIfGp_getStartStageName(), "D_MN05A") == 0 &&
dComIfGs_isStageBossEnemy() && z0 == 11)
{
z0 = 7;
}
int z1 = dComIfG_Bgsp().GetPolyAtt1(*polyinfo_p);
u8 eff_id;
if (kankyo->pol_effcol2 != NULL) {
eff_id = kankyo->pol_effcol2[z0].data[z1];
} else {
return 0xFF;
}
if (eff_id >= 100) {
return 0xFF;
}
out_color_p->r = kankyo->colordata_tbl[eff_id].data[3];
out_color_p->g = kankyo->colordata_tbl[eff_id].data[4];
out_color_p->b = kankyo->colordata_tbl[eff_id].data[5];
return eff_id;
}
/* 801ABC10-801ABD4C 1A6550 013C+00 0/0 1/1 2/2 .text dKy_pol_eff_alpha_get__FPC13cBgS_PolyInfo */
u8 dKy_pol_eff_alpha_get(const cBgS_PolyInfo* polyinfo_p) {
dScnKy_env_light_c* kankyo = &g_env_light;
if (polyinfo_p == NULL || &dComIfG_Bgsp() == NULL) {
return 0xFF;
}
int z0 = dComIfG_Bgsp().GetPolyAtt0(*polyinfo_p);
if (strcmp(dComIfGp_getStartStageName(), "F_SP127") == 0 &&
g_env_light.fishing_hole_season == 4)
{
if (z0 == 4) {
z0 = 13;
}
} else if (strcmp(dComIfGp_getStartStageName(), "D_MN05A") == 0 &&
dComIfGs_isStageBossEnemy() && z0 == 11)
{
z0 = 7;
}
int z1 = dComIfG_Bgsp().GetPolyAtt1(*polyinfo_p);
u8 eff_id;
if (kankyo->pol_effcol != NULL) {
eff_id = kankyo->pol_effcol[z0].data[z1];
} else {
return 0xFF;
}
if (eff_id >= 100) {
return 0xFF;
}
eff_id = kankyo->colordata_tbl[eff_id].data[6];
return eff_id;
}
/* 801ABD4C-801ABEA8 1A668C 015C+00 0/0 1/1 2/2 .text dKy_pol_eff_ratio_get__FPC13cBgS_PolyInfo */
f32 dKy_pol_eff_ratio_get(const cBgS_PolyInfo* polyinfo_p) {
dScnKy_env_light_c* kankyo = &g_env_light;
f32 ratio = 0.0f;
if (polyinfo_p == NULL || &dComIfG_Bgsp() == NULL) {
return 0.0f;
}
int z0 = dComIfG_Bgsp().GetPolyAtt0(*polyinfo_p);
if (strcmp(dComIfGp_getStartStageName(), "F_SP127") == 0 &&
g_env_light.fishing_hole_season == 4)
{
if (z0 == 4) {
z0 = 13;
}
} else if (strcmp(dComIfGp_getStartStageName(), "D_MN05A") == 0 &&
dComIfGs_isStageBossEnemy() && z0 == 11)
{
z0 = 7;
}
int z1 = dComIfG_Bgsp().GetPolyAtt1(*polyinfo_p);
u8 eff_id;
if (kankyo->pol_effcol != NULL) {
eff_id = kankyo->pol_effcol[z0].data[z1];
} else {
return ratio;
}
if (eff_id >= 100) {
return ratio;
}
ratio = (f32)kankyo->colordata_tbl[eff_id].data[7];
ratio = 0.01f * ratio;
return ratio;
}
/* 801ABEA8-801ABFE4 1A67E8 013C+00 0/0 1/1 2/2 .text dKy_pol_eff2_alpha_get__FPC13cBgS_PolyInfo
*/
u8 dKy_pol_eff2_alpha_get(const cBgS_PolyInfo* polyinfo_p) {
dScnKy_env_light_c* kankyo = &g_env_light;
if (polyinfo_p == NULL || &dComIfG_Bgsp() == NULL) {
return 0xFF;
}
int z0 = dComIfG_Bgsp().GetPolyAtt0(*polyinfo_p);
if (strcmp(dComIfGp_getStartStageName(), "F_SP127") == 0 &&
g_env_light.fishing_hole_season == 4)
{
if (z0 == 4) {
z0 = 13;
}
} else if (strcmp(dComIfGp_getStartStageName(), "D_MN05A") == 0 &&
dComIfGs_isStageBossEnemy() && z0 == 11)
{
z0 = 7;
}
int z1 = dComIfG_Bgsp().GetPolyAtt1(*polyinfo_p);
u8 var_r30;
if (kankyo->pol_effcol2 != NULL) {
var_r30 = kankyo->pol_effcol2[z0].data[z1];
} else {
return 0xFF;
}
if (var_r30 >= 100) {
return 0xFF;
}
var_r30 = kankyo->colordata_tbl[var_r30].data[6];
return var_r30;
}
/* 801ABFE4-801AC140 1A6924 015C+00 0/0 1/1 2/2 .text dKy_pol_eff2_ratio_get__FPC13cBgS_PolyInfo
*/
f32 dKy_pol_eff2_ratio_get(const cBgS_PolyInfo* polyinfo_p) {
dScnKy_env_light_c* kankyo = &g_env_light;
f32 ratio = 0.0f;
if (polyinfo_p == NULL || &dComIfG_Bgsp() == NULL) {
return 0.0f;
}
int z0 = dComIfG_Bgsp().GetPolyAtt0(*polyinfo_p);
if (strcmp(dComIfGp_getStartStageName(), "F_SP127") == 0 &&
g_env_light.fishing_hole_season == 4)
{
if (z0 == 4) {
z0 = 13;
}
} else if (strcmp(dComIfGp_getStartStageName(), "D_MN05A") == 0 &&
dComIfGs_isStageBossEnemy() && z0 == 11)
{
z0 = 7;
}
int z1 = dComIfG_Bgsp().GetPolyAtt1(*polyinfo_p);
u8 eff_id;
if (kankyo->pol_effcol2 != NULL) {
eff_id = kankyo->pol_effcol2[z0].data[z1];
} else {
return ratio;
}
if (eff_id >= 100) {
return ratio;
}
ratio = (f32)kankyo->colordata_tbl[eff_id].data[7];
ratio = 0.01f * ratio;
return ratio;
}
/* 801AC140-801AC168 1A6A80 0028+00 0/0 2/2 0/0 .text dKy_TeachWind_existence_chk__Fv */
BOOL dKy_TeachWind_existence_chk() {
if (g_env_light.TeachWind_existence == 0xFF) {
return -1;
}
return g_env_light.TeachWind_existence ? TRUE : FALSE;
}
/* 801AC168-801AC228 1A6AA8 00C0+00 4/4 0/0 2/2 .text dKy_SunMoon_Light_Check__Fv */
BOOL dKy_SunMoon_Light_Check() {
BOOL check = false;
if (g_env_light.mSunInitialized && !dKy_darkworld_check()) {
// stage is not City in the Sky, Hyrule Castle, or Hidden Skill area
if (memcmp(dComIfGp_getStartStageName(), "D_MN07", 6) &&
memcmp(dComIfGp_getStartStageName(), "D_MN09", 6) &&
strcmp(dComIfGp_getStartStageName(), "F_SP200"))
{
check = true;
}
}
return check;
}
/* 801AC228-801AC28C 1A6B68 0064+00 3/3 0/0 0/0 .text dKy_Outdoor_check__Fv */
BOOL dKy_Outdoor_check() {
BOOL outdoors = false;
u32 stage_type = ST_FIELD;
if (dComIfGp_getStage() != NULL) {
stage_type = dStage_stagInfo_GetSTType(dComIfGp_getStage()->getStagInfo());
}
if (stage_type == ST_FIELD) {
outdoors = true;
}
return outdoors;
}
/* 801AC28C-801AC2E0 1A6BCC 0054+00 1/1 0/0 0/0 .text dKy_Indoor_check__Fv */
BOOL dKy_Indoor_check() {
BOOL indoors = false;
if (dStage_stagInfo_GetSTType(dComIfGp_getStage()->getStagInfo()) != ST_FIELD) {
indoors = true;
}
return indoors;
}
/* 801AC2E0-801AC2E8 1A6C20 0008+00 0/0 1/1 0/0 .text dKy_withwarp_capture_check__Fv */
BOOL dKy_withwarp_capture_check() {
return false;
}
/* 801AC2E8-801AC57C 1A6C28 0294+00 0/0 1/1 0/0 .text dKy_depth_dist_set__FPv */
void dKy_depth_dist_set(void* process_p) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
camera_class* camera_p = (camera_class*)dComIfGp_getCamera(0);
cXyz sp30;
cXyz sp24;
fopAc_ac_c* actor_p = (fopAc_ac_c*)process_p;
sp24 = actor_p->eyePos;
if (dComIfGp_event_runCheck() && actor_p->tevStr.Type <= 10) {
if (fabsf(sp24.y - camera_p->lookat.eye.y) < 400.0f) {
sp24.y = camera_p->lookat.eye.y;
}
f32 var_f31 = sp24.abs(camera_p->lookat.eye);
if (var_f31 < 2000.0f && var_f31 < kankyo->field_0x1268) {
mDoLib_project(&actor_p->eyePos, &sp30);
if ((sp30.x >= 0.0f && sp30.x < 608.0f) && (sp30.y >= 0.0f && sp30.y < 600.0f)) {
cXyz sp18;
cXyz spC;
dKyr_get_vectle_calc(&camera_p->lookat.eye, &camera_p->lookat.center, &sp18);
dKyr_get_vectle_calc(&camera_p->lookat.eye, &actor_p->eyePos, &spC);
s16 temp_r27 = cM_atan2s(sp18.x, sp18.z);
s16 temp_r26 = cM_atan2s(spC.x, spC.z);
if ((s16)fabsf((f32)temp_r26 - (f32)temp_r27) > 0) {
kankyo->field_0x1268 = var_f31;
}
}
}
}
}
/* 801AC57C-801AC5BC 1A6EBC 0040+00 13/13 21/21 134/134 .text dKy_darkworld_check__Fv */
bool dKy_darkworld_check() {
bool check = false;
if (dComIfGp_world_dark_get() == TRUE) {
check = true;
}
return check;
}
/**
* @brief Returns the following info about a room: (1) if the room must not be in twilight and (2)
* which darkLv the room belongs to (Faron, Eldin, etc.).
*
* @param stageName stage name
* @param roomNo room number
* @param out_darkLv byte pointer to write darkLv to, or NULL
* @param tblIndex index in darkworld table for the stageName
* @return int Returns -1 if the given room must not be loaded in twilight, else returns 0 or 1. A
* return of 1 means darkLv should be read from out_darkLv and 0 means it should be read from the
* darkworld table.
*/
/* 801AC5BC-801AC70C 1A6EFC 0150+00 3/3 0/0 0/0 .text dKy_F_SP121Check__FPCciPUci */
int dKy_F_SP121Check(char const* stageName, int roomNo, u8* out_darkLv, int tblIndex) {
dKydata_darkworldInfo_c* darkworldTbl = dKyd_darkworld_tbl_getp();
int result = 0;
if (out_darkLv != NULL) {
*out_darkLv = KY_DARKLV_UNCLEARABLE;
}
// Stage is Hyrule Field
if (!strcmp(stageName, "F_SP121")) {
// Room is one of:
// - Eldin Field (0)
// - Kakariko Gorge (3)
// - Eldin Field / Kakariko Gorge Path North (5) and South (4)
// - Faron Field / Kakariko Gorge Path North (2)
// - Outside Hidden Village (7)
if (roomNo == 0 || (2 <= roomNo && roomNo <= 5) || roomNo == 7) {
if (out_darkLv != NULL) {
*out_darkLv = KY_DARKLV_ELDIN;
}
result = 1;
}
// Room is one of:
// - Lanayru Field (10)
// - Great Bridge of Hylia (13)
// - Lanayru Field / Great Bridge of Hylia Path North (11) and South (12)
// - Faron Field / Great Bridge of Hylia Path North (14)
// - Lanayru Field / Outside Hidden Village Path (9)
else if (roomNo >= 9 && roomNo <= 14)
{
if (out_darkLv != NULL) {
*out_darkLv = KY_DARKLV_LANAYRU;
}
result = 1;
}
// Room is one of:
// - Faron Field (6)
// - Faron Field / Kakariko Gorge Path South (1)
// - Faron Field / Great Bridge of Hylia Path South (15)
else
{
result = -1;
}
}
// Faron Spring; No twilight during Rusl cutscene at very beginning of game.
else if (!strcmp(stageName, "F_SP108") && roomNo == 1 && dComIfGp_getStartStageLayer() == 13)
{
result = -1;
}
// Prevent twilight if stage depends on Faron Twilight cleared status (Faron Woods, Coro's
// Lantern Shop, Faron Woods Cave) but haven't finished Ordon Day 2.
if (darkworldTbl[tblIndex].darkLv == KY_DARKLV_FARON && !dComIfGs_isEventBit(0x4510)) {
result = -1;
}
return result;
}
/**
* @brief Returns TRUE if (1) the room is one which can be loaded in twilight, (2) there is nothing
* currently preventing it from being loaded in twilight, and (3) the player has not cleared the
* relevant dark level (Faron Twilight, etc.). Otherwise returns FALSE.
*
* @param stageName stage name
* @param roomNo room number
* @return BOOL Returns TRUE if the room can be loaded as twilight and the player has not already
* cleared it, else FALSE.
*/
/* 801AC70C-801AC7E0 1A704C 00D4+00 0/0 2/2 0/0 .text dKy_darkworld_stage_check__FPCci */
u8 dKy_darkworld_stage_check(char const* stageName, int roomNo) {
dKydata_darkworldInfo_c* darkworldTbl = dKyd_darkworld_tbl_getp();
u8 result = FALSE;
u8 darkLv[1];
for (int i = 0; i < 34; i++) {
if (!strcmp(stageName, darkworldTbl[i].stageName)) {
if (darkworldTbl[i].darkLv != KY_DARKLV_ALWAYS) {
int fsp121CheckResult = dKy_F_SP121Check(stageName, roomNo, darkLv, i);
if (fsp121CheckResult >= 0) {
if (fsp121CheckResult == 0) {
*darkLv = darkworldTbl[i].darkLv;
}
if (!dComIfGs_isDarkClearLV(*darkLv)) {
result = TRUE;
}
break;
}
} else {
// KY_DARKLV_ALWAYS is used to force twilight (likely for testing). This will
// never normally run since it is not present in l_darkworld_tbl.
result = TRUE;
break;
}
}
}
return result;
}
/**
* @brief Returns TRUE if a given room would be loaded in twilight. This function always behaves as
* if the player has not cleared any twilights.
*
* For example, Eldin Field will always return TRUE. Faron Woods on the other hand might return TRUE
* or FALSE depending on whether or not the player has completed Ordon Day 2.
*
* @param stageName stage name
* @param roomNo room number
* @return BOOL Returns TRUE if a given room would be loaded in twilight. This function always
* behaves as if the player has not cleared any twilights.
*/
/* 801AC7E0-801AC870 1A7120 0090+00 0/0 1/1 0/0 .text dKy_darkworld_spot_check__FPCci */
BOOL dKy_darkworld_spot_check(char const* stageName, int roomNo) {
dKydata_darkworldInfo_c* darkworldTblPtr = dKyd_darkworld_tbl_getp();
BOOL result = FALSE;
for (int i = 0; i < 34; i++) {
if (!strcmp(stageName, darkworldTblPtr->stageName) &&
dKy_F_SP121Check(stageName, roomNo, NULL, i) >= 0)
{
result = TRUE;
break;
}
darkworldTblPtr++;
}
return result;
}
/* 801AC870-801AC918 1A71B0 00A8+00 0/0 1/1 0/0 .text dKy_darkworld_Area_set__FPCci */
void dKy_darkworld_Area_set(char const* stageName, int roomNo) {
dKydata_darkworldInfo_c* darkworldTblPtr = dKyd_darkworld_tbl_getp();
u8 darkLv[1];
for (int i = 0; i < 34; i++) {
if (!strcmp(stageName, darkworldTblPtr[i].stageName)) {
int fsp121CheckResult = dKy_F_SP121Check(stageName, roomNo, darkLv, i);
if (fsp121CheckResult >= 0) {
if (fsp121CheckResult == 0) {
*darkLv = darkworldTblPtr[i].darkLv;
}
dComIfGp_setStartStageDarkArea(*darkLv);
break;
}
}
}
}
/* 801AC918-801ACCDC 1A7258 03C4+00 1/1 0/0 0/0 .text dKy_murky_set__FP11J3DMaterial */
void dKy_murky_set(J3DMaterial* material_p) {
dKankyo_sunlenz_Packet* lenz_packet = g_env_light.mpSunLenzPacket;
dKankyo_sun_Packet* sun_packet = g_env_light.mpSunPacket;
camera_class* camera_p = (camera_class*)dComIfGp_getCamera(0);
cXyz sp18;
J3DGXColorS10 tev_col;
J3DGXColor tev_kcol;
JUT_ASSERT(0x43DB, material_p != 0);
tev_col.r = g_env_light.bg_amb_col[1].r;
tev_col.g = g_env_light.bg_amb_col[1].g;
tev_col.b = g_env_light.bg_amb_col[1].b;
tev_col.a = g_env_light.bg_amb_col[2].a;
tev_kcol.a = g_env_light.bg_amb_col[1].a;
f32 var_f29 = 1.0f;
if (g_env_light.field_0x1300 != -1) {
tev_kcol.a = g_env_light.field_0x1300 * var_f29;
}
if (g_env_light.field_0x1302 != -1) {
tev_col.a = (u8)(g_env_light.field_0x1302 * var_f29);
}
if (lenz_packet != NULL && sun_packet->mVisibility > 0.000001f) {
tev_col.a = (u8)(tev_col.a *
(1.0f - (sun_packet->mVisibility *
(1.0f - (lenz_packet->mDistFalloff * lenz_packet->mDistFalloff * lenz_packet->mDistFalloff)))));
}
// Diababa room handling
if (strcmp(dComIfGp_getStartStageName(), "D_MN05A") == 0) {
dScnKy_env_light_c* var_r26 = dKy_getEnvlight();
dKankyo_mud_Packet* var_r27 = var_r26->mpMudPacket;
f32 var_f31;
if (var_r27 != NULL) {
var_f31 = 1.0f - var_r27->field_0x1c3c;
}
tev_col.r = 20;
tev_col.g = 6;
tev_col.b = 15;
tev_col.r = (u8)(tev_col.r + (s16)(-(f32)tev_col.r * var_f31));
tev_col.g = (u8)(tev_col.g + (s16)((36.0f - tev_col.g) * var_f31));
tev_col.b = (u8)(tev_col.b + (s16)((29.0f - tev_col.b) * var_f31));
if (camera_p != NULL && camera_p->lookat.eye.z < 1800.0f) {
f32 var_f30;
if (camera_p->lookat.eye.z < 1550.0f) {
var_f30 = 1.0f;
} else {
var_f30 = 1.0f - ((camera_p->lookat.eye.z - 1550.0f) / 250.0f);
}
tev_col.a = (u8)(255.0f * var_f30);
} else {
tev_col.a = 0;
}
tev_col.a = (u8)(tev_col.a + (s16)(-(f32)tev_col.a * var_f31));
tev_kcol.a = 0xFF;
tev_kcol.a = (u8)(tev_kcol.a + (s16)((140.0f - tev_kcol.a) * var_f31));
}
tev_kcol.r = 0;
tev_kcol.g = 0;
tev_kcol.b = 0;
material_p->setTevColor(1, &tev_col);
material_p->setTevKColor(3, &tev_kcol);
}
/* 801ACCDC-801ACCF4 1A761C 0018+00 2/2 1/1 0/0 .text dKy_shadow_mode_set__FUc */
void dKy_shadow_mode_set(u8 mode) {
g_env_light.shadow_mode |= mode;
}
/* 801ACCF4-801ACD0C 1A7634 0018+00 2/2 1/1 0/0 .text dKy_shadow_mode_reset__FUc */
void dKy_shadow_mode_reset(u8 mode) {
g_env_light.shadow_mode &= ~mode;
}
/* 801ACD0C-801ACD24 1A764C 0018+00 3/3 0/0 1/1 .text dKy_shadow_mode_check__FUc */
u8 dKy_shadow_mode_check(u8 mode) {
return g_env_light.shadow_mode & mode;
}
/* 80450708-8045070C 000188 0004+00 1/1 0/0 0/0 .sdata l_zmodeUpEnable */
static J3DZModeInfo l_zmodeUpEnable = {1, 3, 1};
/* 8045070C-80450710 00018C 0004+00 1/1 0/0 0/0 .sdata l_zmodeUpDisable */
static J3DZModeInfo l_zmodeUpDisable = {1, 3, 0};
/* 80450710-80450718 000190 0008+00 1/1 0/0 0/0 .sdata l_alphaCompInfoOPA */
static J3DAlphaCompInfo l_alphaCompInfoOPA = {
0x07, 0x00, 0x01, 0x07, 0x00, 0x00, 0x00, 0x00,
};
/* 80450718-80450720 000198 0008+00 1/1 0/0 0/0 .sdata l_alphaCompInfo */
static J3DAlphaCompInfo l_alphaCompInfo = {
0x04, 0x80, 0x00, 0x03, 0xFF, 0x00, 0x00, 0x00,
};
/* 801ACD24-801ADBBC 1A7664 0E98+00 0/0 0/0 7/7 .text dKy_bg_MAxx_proc__FPv */
void dKy_bg_MAxx_proc(void* bg_model_p) {
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
J3DModel* model_p = (J3DModel*)bg_model_p;
dDlst_window_c* window = dComIfGp_getWindow(0);
camera_class* camera_p = (camera_class*)dComIfGp_getCamera(window->getCameraID());
fopAc_ac_c* player_p = dComIfGp_getPlayer(0);
if (model_p != NULL && player_p != NULL) {
J3DModelData* modelData = model_p->getModelData();
for (u16 i = 0; i < modelData->getMaterialNum(); i++) {
J3DGXColor sp5C;
J3DMaterial* mat_p = modelData->getMaterialNodePointer(i);
JUTNameTab* mat_nametbl = modelData->getMaterialName();
const char* mat_name = mat_nametbl->getName(i);
if (mat_name[3] == 'M' && mat_name[4] == 'A') {
if (memcmp(&mat_name[3], "MA06", 4) == 0) {
dKy_murky_set(mat_p);
}
if (memcmp(&mat_name[3], "MA03", 4) == 0 || memcmp(&mat_name[3], "MA09", 4) == 0 ||
memcmp(&mat_name[3], "MA17", 4) == 0 || memcmp(&mat_name[3], "MA19", 4) == 0)
{
if (mat_name[5] != '1') {
dComIfGd_setListDarkBG();
} else if (mat_name[6] == '9') {
dComIfGd_setListInvisisble();
}
if (mat_p->getFog() != NULL) {
J3DFogInfo* fog_info_p = mat_p->getFog()->getFogInfo();
if (fog_info_p != NULL) {
if (mat_name[5] == '0' && mat_name[6] == '9') {
fog_info_p->mType = 6;
J3DGXColor sp44;
sp44.r = 245.0f - g_env_light.mWaterSurfaceShineRate * 45.0f;
sp44.g = 245.0f - g_env_light.mWaterSurfaceShineRate * 45.0f;
sp44.b = 245.0f - g_env_light.mWaterSurfaceShineRate * 35.0f;
sp44.a = 255;
mat_p->setTevKColor(1, &sp44);
} else {
fog_info_p->mType = 7;
J3DGXColorS10 spA0;
J3DGXColor sp40;
spA0.r = g_env_light.bg_amb_col[2].r;
spA0.g = g_env_light.bg_amb_col[2].g;
spA0.b = g_env_light.bg_amb_col[2].b;
spA0.a = g_env_light.bg_amb_col[2].a;
sp40.a = g_env_light.bg_amb_col[1].a;
sp40.r = 0;
sp40.g = 0;
sp40.b = 0;
mat_p->setTevColor(1, &spA0);
mat_p->setTevKColor(3, &sp40);
}
}
}
}
if (memcmp(&mat_name[3], "MA07", 4) == 0) {
J3DGXColorS10 sp98;
dScnKy_env_light_c* kankyo = dKy_getEnvlight();
EF_THUNDER* thunder_ef = &kankyo->mThunderEff;
sp98.r = (u8)(thunder_ef->mFlashTimer * 100.0f);
sp98.g = (u8)(thunder_ef->mFlashTimer * 100.0f);
sp98.b = (u8)(thunder_ef->mFlashTimer * 100.0f);
sp98.a = 255;
mat_p->setTevColor(0, &sp98);
}
if (memcmp(&mat_name[3], "MA10", 4) == 0 || memcmp(&mat_name[3], "MA02", 4) == 0) {
dComIfGd_setListInvisisble();
if (mat_p->getTexGenBlock()->getTexMtx(0) != NULL) {
J3DTexMtxInfo* tex_mtx_inf =
&mat_p->getTexGenBlock()->getTexMtx(0)->getTexMtxInfo();
if (tex_mtx_inf != NULL) {
cXyz* sp34 = dKyw_get_wind_vec();
cXyz sp108;
Mtx sp1D8;
if (mat_name[6] == '2') {
C_MTXLightPerspective(sp1D8, dComIfGd_getView()->fovy,
camera_p->aspect, 1.0f, 1.0f, -0.01f, 0.0f);
} else {
C_MTXLightPerspective(sp1D8, dComIfGd_getView()->fovy,
camera_p->aspect, 0.49f, -0.49f, 0.5f, 0.5f);
}
tex_mtx_inf->setEffectMtx(sp1D8);
modelData->simpleCalcMaterial(0, (MtxP)j3dDefaultMtx);
}
}
}
if (memcmp(&mat_name[3], "MA00", 4) == 0 || memcmp(&mat_name[3], "MA01", 4) == 0 ||
memcmp(&mat_name[3], "MA04", 4) == 0 || memcmp(&mat_name[3], "MA16", 4) == 0)
{
sp5C.r = g_env_light.mFogDensity;
sp5C.g = 0;
sp5C.b = 0;
if (mat_name[6] == '1') {
J3DPEBlock* peblock_p = mat_p->getPEBlock();
mat_p->change();
if (dKy_camera_water_in_status_check()) {
sp5C.a = 255;
peblock_p->getAlphaComp()->setAlphaCompInfo(l_alphaCompInfo);
peblock_p->getZMode()->setZModeInfo(l_zmodeUpEnable);
} else {
sp5C.a = 0;
peblock_p->getAlphaComp()->setAlphaCompInfo(l_alphaCompInfoOPA);
peblock_p->getZMode()->setZModeInfo(l_zmodeUpDisable);
}
} else {
sp5C.a = 0;
}
mat_p->setTevKColor(1, &sp5C);
}
if (memcmp(&mat_name[3], "MA11", 4) == 0) {
J3DGXColorS10 sp90;
if (dKy_darkworld_check()) {
dComIfGd_setListDarkBG();
sp90.r = 170;
sp90.g = 160;
sp90.b = 255;
sp90.a = 255;
mat_p->setTevColor(1, &sp90);
sp90.r = 50;
sp90.g = 20;
sp90.b = 90;
sp90.a = 255;
mat_p->setTevColor(2, &sp90);
} else {
cXyz spFC;
cXyz spF0;
sp90.r = 120;
sp90.g = 90;
sp90.b = 180;
sp90.a = 255;
if (dComIfG_play_c::getLayerNo(0) == 1) {
sp90.a = 0;
}
mat_p->setTevColor(1, &sp90);
sp90.r = 40;
sp90.g = 30;
sp90.b = 65;
sp90.a = 255;
mat_p->setTevColor(2, &sp90);
if (kankyo->fog_avoid_tag != NULL) {
spF0 = kankyo->fog_avoid_tag->mAvoidPos;
f32 var_f28 =
kankyo->fog_avoid_tag->mSize.x * kankyo->fog_avoid_tag->mSizeScale;
if (var_f28 < 0.1f) {
var_f28 = 0.1f;
}
if (mat_p->getTexGenBlock()->getTexMtx(0) != NULL) {
J3DTexMtxInfo* tex_mtx_inf =
&mat_p->getTexGenBlock()->getTexMtx(0)->getTexMtxInfo();
if (tex_mtx_inf != NULL) {
Mtx sp1A8;
Mtx sp178;
C_MTXLightPerspective(sp1A8, var_f28 * 2.8f, 1.0f, 0.5f, 0.5f,
0.0f, 0.0f);
spFC.x = spF0.x;
spFC.y = 100.0f;
spFC.z = spF0.z;
cXyz spE4(spF0.x, -1000.0f, spF0.z);
mDoMtx_lookAt(sp178, &spE4, &spFC, 0);
cMtx_concat(sp1A8, sp178, sp178);
tex_mtx_inf->setEffectMtx(sp178);
}
}
}
}
} else if (memcmp(&mat_name[3], "MA20", 4) == 0) {
cXyz spD8;
cXyz spCC;
if (mat_p->getFog() != NULL) {
J3DFogInfo* fog_inf = mat_p->getFog()->getFogInfo();
if (fog_inf != NULL) {
fog_inf->mType = 7;
}
J3DGXColorS10 sp88;
sp88.r = g_env_light.bg_amb_col[3].r;
sp88.g = g_env_light.bg_amb_col[3].g;
sp88.b = g_env_light.bg_amb_col[3].b;
sp88.a = 255;
mat_p->setTevColor(1, &sp88);
if (mat_p->getTexGenBlock()->getTexMtx(2) != NULL) {
J3DTexMtxInfo* tex_mtx_inf =
&mat_p->getTexGenBlock()->getTexMtx(2)->getTexMtxInfo();
if (tex_mtx_inf != NULL) {
Mtx sp148;
Mtx sp118;
C_MTXLightPerspective(sp148, 170.0f, 1.0f, 1.5f, 1.5f, 0.0f, 0.0f);
spD8.x = player_p->current.pos.x;
spD8.y = -14770.0f;
spD8.z = player_p->current.pos.z;
cXyz spC0(player_p->current.pos.x, -14570.0f,
player_p->current.pos.z);
mDoMtx_lookAt(sp118, &spC0, &spD8, 0);
cMtx_concat(sp148, sp118, sp118);
tex_mtx_inf->setEffectMtx(sp118);
}
}
}
} else if (memcmp(&mat_name[3], "MA13", 4) == 0) {
J3DGXColorS10 sp80;
sp80.r = g_env_light.bg_amb_col[3].r;
sp80.g = g_env_light.bg_amb_col[3].g;
sp80.b = g_env_light.bg_amb_col[3].b;
sp80.a = g_env_light.bg_amb_col[3].a;
mat_p->setTevColor(1, &sp80);
} else if (memcmp(&mat_name[3], "MA14", 4) == 0) {
J3DGXColorS10 sp78;
J3DGXColor sp1C;
sp78.r = g_env_light.fog_col.r;
sp78.g = g_env_light.fog_col.g;
sp78.b = g_env_light.fog_col.b;
sp78.a = g_env_light.fog_col.a;
mat_p->setTevColor(1, &sp78);
sp1C.r = sp1C.g = sp1C.b = 0;
sp1C.a = g_env_light.bg_amb_col[3].a;
mat_p->setTevKColor(3, &sp1C);
} else if (memcmp(&mat_name[3], "MA16", 4) == 0) {
J3DGXColorS10 sp70;
J3DGXColor sp18;
sp70.r = g_env_light.bg_amb_col[1].r;
sp70.g = g_env_light.bg_amb_col[1].g;
sp70.b = g_env_light.bg_amb_col[1].b;
sp70.a = g_env_light.bg_amb_col[1].a;
mat_p->setTevColor(1, &sp70);
sp18.r = sp18.g = sp18.b = 0;
sp18.a = g_env_light.bg_amb_col[3].a;
mat_p->setTevKColor(3, &sp18);
}
}
if (memcmp(&mat_name[3], "Rainbow", 7) == 0) {
f32 temp_f29;
f32 temp_f31;
f32 time = g_env_light.getDaytime();
cXyz spB4;
camera_class* camera_p = dComIfGp_getCamera(0);
J3DGXColor sp10;
cXyz spA8;
spA8.x = -5853.0f;
spA8.y = camera_p->lookat.eye.y;
spA8.z = -879.0f;
temp_f31 = spA8.abs(camera_p->lookat.eye);
temp_f31 = -0.2f + (temp_f31 / 4500.0f);
if (temp_f31 > 1.0f) {
temp_f31 = 1.0f;
} else if (temp_f31 < 0.0f) {
temp_f31 = 0.0f;
}
sp10.b = sp10.g = sp10.r = 255;
sp10.a = 255;
temp_f29 = 0.0f;
if (time >= 270.0f) {
if (time < 285.0f) {
temp_f29 = (285.0f - time) / 15.0f;
}
} else if (time < 75.0f) {
if (time >= 60.0f) {
temp_f29 = 1.0f - ((75.0f - time) / 15.0f);
}
} else {
temp_f29 = 1.0f;
}
if (g_env_light.mColpatWeather != 0) {
temp_f29 = 0.0f;
}
sp10.b = 255;
sp10.g = 255;
sp10.r = 255;
f32 temp_f25 = 1.0f;
spA8 = camera_p->lookat.center;
spA8.y = camera_p->lookat.eye.y;
dKyr_get_vectle_calc(&camera_p->lookat.eye, &spA8, &spB4);
f32 temp_f27 = cM3d_VectorProduct2d(0.0f, 0.0f, -0.81f, 0.583f, spB4.x, spB4.z);
f32 temp_f26;
if (temp_f27 < 0.2f) {
sp10.a = 0;
} else {
if (temp_f27 > 0.6f) {
temp_f26 = 1.0f;
} else {
temp_f26 = (temp_f27 - 0.2f) / 0.4f;
}
sp10.a = temp_f25 * (temp_f31 * (115.0f * temp_f26 * temp_f29));
}
mat_p->setTevKColor(3, &sp10);
}
}
}
}