Files
dusklight/src/d/d_kankyo_wether.cpp
T
Pieter-Jan Briers b289dece80 26 02 27 pjb dev 2 (#41)
* fix kankyo UB

* Fix TEV Stage DL writing

BE issue

* BE Fixes in materials/shapes

* Move to Aurora GD impl

* JUTDataFileHeader

* j3d: load vertex and texture not through GD

* Endian swap vertex data (mostly)

* Just exit(0) when closing the game

Fix crashes :godo:

* fix fopAcM_ct_placement and remove memcpy

* J3D: track vertex arrays correctly, swap work

* fix visibility, turn off overridden new/delete when we call into aurora

* event: cut name be

* Default window improvements

Double size, allow OS to decide position

* survive TParse::parseHeader_next

* color swap fix

* swap endian/fixes oob function pointer

* Remove GXGetViewportv stub

Aurora has it now

* Set array pointers via GD again

Relies on https://github.com/encounter/aurora/pull/35

* Let Aurora decide graphics backend

* disable procbar drawing

* Fix TColor endianness conversion issues

Fixes the wrong color for the flashing logo

* cam param swap

* simplify vtx loading, mat/amb color fix

* endian swap stb/fvb data

* aurora stat changes

* fix storage buffer crash

dont unnecessarily reassign vertex buffers in a way that forces aurora to recache things

* set bgobj spec fix

* add camera debug, endian swap more stb data, d_a_bg_obj::spec_data_c swapped

* JKRExpHeap: fix bad allocator slowdown

* solid tex

* texture caching

* log level

* fix window aspect ratio, disable bloom, endian swap camera type data

camera is now actually playing opening cutscene!!!!

* add GXDestroyTexObj to a couple stack init'd GXTexObjs, remove some diag printfs

* endian swap joint weight envelope data

* move to dusk config

* verbose arg errors

* better stub logging (for now)

* less logging, more BE

* more stubbing, move logging stuff around

* move all logging to aurora logging

* fix STUB_LOG, __FUNCTION__ isn't a string literal, wasn't building as it
was.

* update aurora

* fix heap alignment mismatch and always head align for now

* prevent them from fucking up my shit

* forward jut warning to DuskLog

* remove report logging

* maybe and i must emphasize maybe fix JMessage parsing

* this was a dumb idea

* preserve negative alignment for JKRHeap

* use normal free on macos and linux

* ^

* fix JMAHermiteInterpolation c impl

* endian swap J2DScreen mColor (oops)

* swap more J3D anim data, remove weird pointer addr check in J3DMaterial getMaterialAnm

* typo fix

* Fix aligned_alloc() size issues on POSIX

aligned_alloc() requires its input size to be a multiple of alignment. This wasn't being upheld so there were allocation failures in init code that made the game fail to start outside Windows.

Also just cleaned up some of this code a bit and removed fallback cases that *shouldn't* get hit.

* _Exit instead of exit()

Seriously I don't want destructors to run. Let the OS reclaim that shit.

* Reapply "Isolate JKRHeap operator overloads" (#39)

This reverts commit 3623b27f37.

* Fix some oopsies

* Fix hardcoded pointer size in JUTCacheFont::allocArray

* More operator overload fixes

Add void template specialization for jkrDelete

Add new[] placement overload. Apparently.

* Fix delete macros on nullptr

TIL C++ allows that.

* fix delete[]

* fix new(std::nothrow) overload

* fix avoid ub

* swap remaining anim data needed for title logo

* get rid of op 7

* move aurora_end_frame to correct spot

* juttexture destroy tex

* j2d animation be

* shutdown crash

* link warp material fix

* mDoExt_3DlineMat1_c fix

* hacky keyboard controls

* endian swap J2DResReference, add kb_pad to files.cmake

* fix some missing endian swaps in J2D, remove addr alignment check

* Remove heap unsetting in aurora calls

Never worked properly and not the right solution even if it did

* Don't print in DC stubs

They're fine to never implement

* Fix alignment stuff again

* Compile GF from dolphin lib

Doesn't seem to break anything and shuts up some stub warnings

* j3dtexture tlut obj fix

* addTexMtxIndexInDL fix

* don't recreate null tex data every frame

* the actual fix i wanted to push

* its kinda fakematch city over here

* insert hte efb copy

* limited window size / viewport support

* IsDelete FIX

---------

Co-authored-by: madeline <qwertytrogi@gmail.com>
Co-authored-by: Jasper St. Pierre <jstpierre@mecheye.net>
Co-authored-by: Jeffrey Crowell <jeff@crowell.biz>
Co-authored-by: TakaRikka <takarikka@outlook.com>
Co-authored-by: CraftyBoss <talibabdulmaalik@gmail.com>
Co-authored-by: Lurs <2795933+Lurs@users.noreply.github.com>
2026-03-08 15:27:15 -07:00

1542 lines
50 KiB
C++

/**
* d_kankyo_wether.cpp
* Weather Effects
*/
#include "d/dolzel.h" // IWYU pragma: keep
#include "d/d_kankyo_wether.h"
#include "JSystem/J3DGraphBase/J3DDrawBuffer.h"
#include "SSystem/SComponent/c_math.h"
#include "d/d_com_inf_game.h"
#include "d/d_kankyo.h"
#include "d/d_kankyo_rain.h"
#include "f_op/f_op_camera_mng.h"
#include <cstring>
#include "m_Do/m_Do_audio.h"
static void dKyw_pntlight_set(WIND_INFLUENCE* pntwind);
static J3DPacket* dKyw_setDrawPacketList(J3DPacket* i_packet, int i_type) {
if (i_packet == NULL) {
return NULL;
} else {
dComIfGd_getListFilter()->entryImm(i_packet, 0);
return i_packet;
}
}
static J3DPacket* dKyw_setDrawPacketListIndScreen(J3DPacket* i_packet, int i_type) {
if (i_packet == NULL) {
return NULL;
} else {
dComIfGd_getOpaListIndScreen()->entryImm(i_packet, 0);
return i_packet;
}
}
static J3DPacket* dKyw_setDrawPacketListSky(J3DPacket* i_packet, int i_type) {
if (i_packet == NULL) {
return NULL;
} else {
dComIfGd_setListSky();
j3dSys.getDrawBuffer(i_type)->entryImm(i_packet, 0);
dComIfGd_setList();
return i_packet;
}
}
static J3DPacket* dKyw_setDrawPacketListXluBg(J3DPacket* i_packet, int i_type) {
if (i_packet == NULL) {
return NULL;
} else {
dComIfGd_setXluListBG();
j3dSys.getDrawBuffer(i_type)->entryImm(i_packet, 0);
dComIfGd_setList();
return i_packet;
}
}
void dKankyo_sun_Packet::draw() {
dKyr_drawSun(j3dSys.getViewMtx(), mPos, mColor, &mpResMoon);
}
void dKankyo_sunlenz_Packet::draw() {
dKyr_drawLenzflare(j3dSys.getViewMtx(), mPositions, mColor, &mpResBall);
}
RAIN_EFF::~RAIN_EFF() {}
RAIN_EFF::RAIN_EFF() {}
void dKankyo_rain_Packet::draw() {
dKyr_drawSibuki(j3dSys.getViewMtx(), &mpTex);
dKyr_drawRain(j3dSys.getViewMtx(), &mpTex);
}
SNOW_EFF::~SNOW_EFF() {}
SNOW_EFF::SNOW_EFF() {}
void dKankyo_snow_Packet::draw() {
dKyr_drawSnow(j3dSys.getViewMtx(), &mpTex);
}
STAR_EFF::~STAR_EFF() {}
STAR_EFF::STAR_EFF() {}
void dKankyo_star_Packet::draw() {
dKyr_drawStar(j3dSys.getViewMtx(), &mpTex);
}
CLOUD_EFF::~CLOUD_EFF() {}
CLOUD_EFF::CLOUD_EFF() {}
void dKankyo_cloud_Packet::draw() {
drawCloudShadow(j3dSys.getViewMtx(), &mpResTex);
}
HOUSI_EFF::~HOUSI_EFF() {}
HOUSI_EFF::HOUSI_EFF() {}
void dKankyo_housi_Packet::draw() {
dKyr_drawHousi(j3dSys.getViewMtx(), &mpResTex);
}
VRKUMO_EFF::~VRKUMO_EFF() {}
VRKUMO_EFF::VRKUMO_EFF() {}
void dKankyo_vrkumo_Packet::draw() {
drawVrkumo(j3dSys.getViewMtx(), mColor, &mpResCloudtx_01);
}
EF_ODOUR_EFF::~EF_ODOUR_EFF() {}
EF_ODOUR_EFF::EF_ODOUR_EFF() {}
void dKankyo_odour_Packet::draw() {
dKyr_odour_draw(j3dSys.getViewMtx(), &mpResTex);
}
EF_MUD_EFF::~EF_MUD_EFF() {}
EF_MUD_EFF::EF_MUD_EFF() {}
void dKankyo_mud_Packet::draw() {
dKyr_mud_draw(j3dSys.getViewMtx(), &mpMoyaRes);
}
EF_EVIL_EFF::~EF_EVIL_EFF() {}
EF_EVIL_EFF::EF_EVIL_EFF() {}
void dKankyo_evil_Packet::draw() {
dKyr_evil_draw(j3dSys.getViewMtx(), &mpMoyaRes);
}
static void dKyw_drawSun(int i_type) {
dKyw_setDrawPacketListSky(g_env_light.mpSunPacket, i_type);
}
static void dKyw_Sun_Draw() {
dKyw_drawSun(J3DSysDrawBuf_Xlu);
}
static void dKyw_drawSunlenz(int i_type) {
if (g_env_light.mpSunLenzPacket->mDrawLenzInSky == false) {
dKyw_setDrawPacketListIndScreen(g_env_light.mpSunLenzPacket, i_type);
} else {
dKyw_setDrawPacketListSky(g_env_light.mpSunLenzPacket, i_type);
}
}
static void dKyw_Sunlenz_Draw() {
dKyw_drawSunlenz(J3DSysDrawBuf_Xlu);
}
static void dKyw_drawRain(int i_type) {
dKyw_setDrawPacketList(g_env_light.mpRainPacket, i_type);
}
static void dKyw_Rain_Draw() {
dKyw_drawRain(J3DSysDrawBuf_Xlu);
}
static void dKyw_drawSnow(int i_type) {
dKyw_setDrawPacketList(g_env_light.mpSnowPacket, i_type);
}
static void dKyw_Snow_Draw() {
dKyw_drawSnow(J3DSysDrawBuf_Xlu);
}
static void dKyw_drawStar(int i_type) {
dKyw_setDrawPacketListSky(g_env_light.mpStarPacket, i_type);
}
static void dKyw_Star_Draw() {
dKyw_drawStar(J3DSysDrawBuf_Xlu);
}
static void dKyw_drawHousi(int i_type) {
dKyw_setDrawPacketList(g_env_light.mpHousiPacket, i_type);
}
static void dKyw_Housi_Draw() {
dKyw_drawHousi(J3DSysDrawBuf_Xlu);
}
static void dKyw_drawCloud(int i_type) {
dKyw_setDrawPacketListIndScreen(g_env_light.mpCloudPacket, i_type);
}
static void dKyw_Cloud_Draw() {
dKyw_drawCloud(J3DSysDrawBuf_Xlu);
}
static void dKyw_drawVrkumo(int i_type) {
dKyw_setDrawPacketListSky(g_env_light.mpVrkumoPacket, i_type);
}
static void dKyw_Vrkumo_Draw() {
dKyw_drawVrkumo(J3DSysDrawBuf_Xlu);
}
static void dKyw_shstar_packet(int i_type) {
dKyw_setDrawPacketListSky(g_env_light.mpShstarPacket, i_type);
}
static void dKyw_shstar_Draw() {
dKyw_shstar_packet(J3DSysDrawBuf_Xlu);
}
static void dKyw_odour_packet(int i_type) {
dKyw_setDrawPacketListIndScreen(g_env_light.mOdourData.mpOdourPacket, i_type);
}
static void dKyw_Odour_Draw() {
dKyw_odour_packet(J3DSysDrawBuf_Xlu);
}
static void dKyw_mud_packet(int i_type) {
dKyw_setDrawPacketListXluBg(g_env_light.mpMudPacket, i_type);
}
static void dKyw_mud_Draw() {
dKyw_mud_packet(J3DSysDrawBuf_Xlu);
}
static void dKyw_evil_packet(int i_type) {
dKyw_setDrawPacketListXluBg(g_env_light.mpEvilPacket, i_type);
}
static void dKyw_evil_Draw() {
dKyw_evil_packet(J3DSysDrawBuf_Xlu);
}
void dKyw_wether_init() {
g_env_light.mSunInitialized = false;
g_env_light.mThunderEff.mStatus = 0;
g_env_light.mThunderEff.mMode = 0;
g_env_light.mRainInitialized = false;
g_env_light.raincnt = 0;
g_env_light.mSnowInitialized = false;
g_env_light.field_0xe92 = 0;
g_env_light.mSnowCount = 0;
g_env_light.field_0xe90 = 0;
g_env_light.field_0xe91 = 0;
g_env_light.mStarInitialized = false;
g_env_light.mStarCount = 0;
g_env_light.mStarDensity = 0.0f;
g_env_light.mCloudInitialized = 0;
g_env_light.mMoyaCount = 0;
g_env_light.field_0xebc = 0.0f;
g_env_light.mMoyaMode = 0;
g_env_light.mHousiInitialized = false;
g_env_light.mHousiCount = 0;
g_env_light.mOdourData.mOdourPacketStatus = 0;
g_env_light.mOdourData.field_0xf24 = 0;
g_env_light.mOdourData.field_0xf21 = 0;
g_env_light.mOdourData.mpOdourPacket = NULL;
g_env_light.field_0x1038 = 0;
g_env_light.field_0x103c = 0;
g_env_light.mMudInitialized = 0;
g_env_light.field_0x1048 = 0;
g_env_light.mEvilInitialized = 0;
g_env_light.field_0x1054 = 0;
g_env_light.field_0x1051 = 0;
g_env_light.unk_0xe60 = 0.0f;
dKyw_wind_init();
dKyw_pntwind_init();
// Stage is Zora's Domain and Room is Outside Throne Room
if (!strcmp(dComIfGp_getStartStageName(), "F_SP113") && dComIfGp_roomControl_getStayNo() == 1 &&
dComIfG_play_c::getLayerNo(0) < 8)
{
cXyz tmp;
tmp.z = 0.0f;
tmp.y = 0.0f;
tmp.x = 0.0f;
dComIfGp_particle_set(0x878F, &tmp, NULL, NULL);
dComIfGp_particle_set(0x8790, &tmp, NULL, NULL);
dComIfGp_particle_set(0x8791, &tmp, NULL, NULL);
dComIfGp_particle_set(0x8792, &tmp, NULL, NULL);
dComIfGp_particle_set(0x8793, &tmp, NULL, NULL);
dComIfGp_particle_set(0x8794, &tmp, NULL, NULL);
dComIfGp_particle_set(0x8795, &tmp, NULL, NULL);
dComIfGp_particle_set(0x8796, &tmp, NULL, NULL);
dComIfGp_particle_set(0x8797, &tmp, NULL, NULL);
dComIfGp_particle_set(0x8798, &tmp, NULL, NULL);
dComIfGp_particle_set(0x8799, &tmp, NULL, NULL);
dComIfGp_particle_set(0x879A, &tmp, NULL, NULL);
dComIfGp_particle_set(0x879B, &tmp, NULL, NULL);
}
// Stage is City in the Sky
// Room is Entrance or Right Wing Outside or Left Wing Outside or Central Hub Outside
if (!strcmp(dComIfGp_getStartStageName(), "D_MN07")) {
if ((dComIfGp_roomControl_getStayNo() == 0 || dComIfGp_roomControl_getStayNo() == 3) ||
dComIfGp_roomControl_getStayNo() == 6 || dComIfGp_roomControl_getStayNo() == 13)
{
g_mEnvSeMgr.initStrongWindSe();
}
}
}
void dKyw_wether_init2() {
g_env_light.mVrkumoStatus = 0;
g_env_light.mVrkumoCount = 0;
}
void dKyw_wether_delete() {
if (g_env_light.mSunInitialized) {
JKR_DELETE(g_env_light.mpSunPacket);
JKR_DELETE(g_env_light.mpSunLenzPacket);
g_env_light.mpSunPacket = NULL;
g_env_light.mpSunLenzPacket = NULL;
}
if (g_env_light.mRainInitialized) {
JKR_DELETE(g_env_light.mpRainPacket);
g_env_light.mpRainPacket = NULL;
}
if (g_env_light.mSnowInitialized) {
JKR_DELETE(g_env_light.mpSnowPacket);
g_env_light.mpSnowPacket = NULL;
g_env_light.field_0xe90 = 0;
}
if (g_env_light.mStarInitialized) {
JKR_DELETE(g_env_light.mpStarPacket);
g_env_light.mpStarPacket = NULL;
}
if (g_env_light.mHousiInitialized) {
JKR_DELETE(g_env_light.mpHousiPacket);
g_env_light.mpHousiPacket = NULL;
}
if (g_env_light.mCloudInitialized) {
JKR_DELETE(g_env_light.mpCloudPacket);
g_env_light.mpCloudPacket = NULL;
}
if (g_env_light.mOdourData.mOdourPacketStatus) {
JKR_DELETE(g_env_light.mOdourData.mpOdourPacket);
g_env_light.mOdourData.mpOdourPacket = NULL;
}
if (g_env_light.mMudInitialized) {
JKR_DELETE(g_env_light.mpMudPacket);
g_env_light.mpMudPacket = NULL;
}
if (g_env_light.mEvilInitialized) {
JKR_DELETE(g_env_light.mpEvilPacket);
g_env_light.mpEvilPacket = NULL;
}
}
dKankyo_evil_Packet::~dKankyo_evil_Packet() {}
dKankyo_mud_Packet::~dKankyo_mud_Packet() {}
dKankyo_odour_Packet::~dKankyo_odour_Packet() {}
dKankyo_cloud_Packet::~dKankyo_cloud_Packet() {}
dKankyo_housi_Packet::~dKankyo_housi_Packet() {}
dKankyo_star_Packet::~dKankyo_star_Packet() {}
dKankyo_snow_Packet::~dKankyo_snow_Packet() {}
dKankyo_rain_Packet::~dKankyo_rain_Packet() {}
dKankyo_sunlenz_Packet::~dKankyo_sunlenz_Packet() {}
dKankyo_sun_Packet::~dKankyo_sun_Packet() {}
void dKyw_wether_delete2() {
if (g_env_light.mVrkumoStatus != 0) {
JKR_DELETE(g_env_light.mpVrkumoPacket);
g_env_light.mpVrkumoPacket = NULL;
}
}
dKankyo_vrkumo_Packet::~dKankyo_vrkumo_Packet() {}
static void wether_move_thunder() {
switch (g_env_light.mThunderEff.mStatus) {
case 0:
if (g_env_light.mThunderEff.mMode != 0) {
dKyr_thunder_init();
g_env_light.mThunderEff.mStatus = 1;
}
break;
case 1:
dKyr_thunder_move();
break;
}
}
void dKyw_wether_move() {
wether_move_thunder();
}
static void wether_move_sun() {
s32 sunVisible = false;
if (dComIfGp_checkStatus(1) && !g_env_light.hide_vrbox) {
roomRead_class* room = dComIfGp_getStageRoom();
if (room != NULL && room->num > dComIfGp_roomControl_getStayNo()) {
sunVisible = dStage_roomRead_dt_c_GetVrboxswitch(
*room->m_entries[dComIfGp_roomControl_getStayNo()]);
}
// Stage is Hero Shade arena
if (!strcmp(dComIfGp_getStartStageName(), "F_SP200")) {
sunVisible = true;
// Stage is Hyrule Castle or Castle Throne Room
} else if (!strcmp(dComIfGp_getStartStageName(), "D_MN09") ||
!strcmp(dComIfGp_getStartStageName(), "D_MN09A"))
{
sunVisible = false;
}
switch (g_env_light.mSunInitialized) {
case FALSE:
if (sunVisible && dKy_darkworld_check() != true) {
g_env_light.mpSunPacket = JKR_NEW_ARGS (0x20) dKankyo_sun_Packet();
g_env_light.mpSunLenzPacket = JKR_NEW_ARGS (0x20) dKankyo_sunlenz_Packet();
if (g_env_light.mpSunPacket != NULL && g_env_light.mpSunLenzPacket != NULL) {
g_env_light.mpSunPacket->mpResMoon = (u8*)dComIfG_getStageRes("F_moon.bti");
g_env_light.mpSunPacket->mpResMoon_A = (u8*)dComIfG_getStageRes("F_moon_A.bti");
g_env_light.mpSunPacket->mpResMoon_A_A00 =
(u8*)dComIfG_getStageRes("F_moon_A_A00.bti");
g_env_light.mpSunPacket->mpResMoon_A_A01 =
(u8*)dComIfG_getStageRes("F_moon_A_A01.bti");
g_env_light.mpSunPacket->mpResMoon_A_A02 =
(u8*)dComIfG_getStageRes("F_moon_A_A02.bti");
g_env_light.mpSunPacket->mpResMoon_A_A03 =
(u8*)dComIfG_getStageRes("F_moon_A_A03.bti");
if (g_env_light.mpSunPacket->mpResMoon == NULL) {
g_env_light.mpSunPacket->mpResMoon =
(u8*)dComIfG_getObjectRes("Always", 0x56);
g_env_light.mpSunPacket->mpResMoon_A =
(u8*)dComIfG_getObjectRes("Always", 0x56);
g_env_light.mpSunPacket->mpResMoon_A_A00 =
(u8*)dComIfG_getObjectRes("Always", 0x56);
g_env_light.mpSunPacket->mpResMoon_A_A01 =
(u8*)dComIfG_getObjectRes("Always", 0x56);
g_env_light.mpSunPacket->mpResMoon_A_A02 =
(u8*)dComIfG_getObjectRes("Always", 0x56);
g_env_light.mpSunPacket->mpResMoon_A_A03 =
(u8*)dComIfG_getObjectRes("Always", 0x56);
}
g_env_light.mpSunPacket->field_0x28 = 0;
g_env_light.mpSunPacket->field_0x29 = 0;
g_env_light.mpSunPacket->mVisibility = 0.0f;
g_env_light.mpSunPacket->mSunAlpha = 0.0f;
g_env_light.mpSunPacket->field_0x64 = 0.0f;
g_env_light.mpSunPacket->mMoonAlpha = 0.0f;
if (g_env_light.daytime < 255.0f) {
g_env_light.mpSunPacket->field_0x6c = 1.0f;
} else {
g_env_light.mpSunPacket->field_0x6c = 0.0f;
}
g_env_light.mpSunPacket->field_0x44[0] = 0;
g_env_light.mpSunPacket->field_0x44[1] = 0;
g_env_light.mpSunPacket->field_0x44[2] = 0;
g_env_light.mpSunPacket->field_0x44[3] = 0;
g_env_light.mpSunPacket->field_0x44[4] = 0;
g_env_light.mpSunPacket->field_0x58 = 0;
g_env_light.mpSunLenzPacket->mpResBall =
(u8*)dComIfG_getObjectRes("Always", 0x4A);
g_env_light.mpSunLenzPacket->mpResRing_A =
(u8*)dComIfG_getObjectRes("Always", 0x57);
g_env_light.mpSunLenzPacket->mpResLenz =
(u8*)dComIfG_getObjectRes("Always", 0x5C);
g_env_light.mpSunLenzPacket->field_0x8c = 1000000000.0f; // This is not G_CM3D_F_INF
g_env_light.mpSunLenzPacket->field_0x90 = 0.0f;
g_env_light.mpSunLenzPacket->mDistFalloff = 0.0f;
g_env_light.mpSunLenzPacket->mDrawLenzInSky = false;
dKyr_sun_move();
dKyr_lenzflare_move();
g_env_light.mSunInitialized = true;
}
}
break;
case TRUE:
if (!sunVisible) {
g_env_light.mSunInitialized = false;
JKR_DELETE(g_env_light.mpSunPacket);
JKR_DELETE(g_env_light.mpSunLenzPacket);
g_env_light.mpSunPacket = NULL;
g_env_light.mpSunLenzPacket = NULL;
} else {
dKyr_sun_move();
dKyr_lenzflare_move();
}
break;
}
}
}
static void wether_move_rain() {
switch (g_env_light.mRainInitialized) {
case FALSE:
if (g_env_light.raincnt > 3) {
g_env_light.mpRainPacket = JKR_NEW_ARGS (32) dKankyo_rain_Packet();
if (g_env_light.mpRainPacket != NULL) {
dKyr_rain_init();
dKyr_rain_move();
g_env_light.mRainInitialized = 1;
if (g_env_light.raincnt != 250) {
mDoAud_seStart(JA_SE_ATM_RAIN_START, NULL, 0, 0);
}
}
}
break;
case TRUE:
camera_process_class* cam = dComIfGp_getCamera(0);
dKyr_rain_move();
if (g_env_light.mSnowCount == 0 && cam != NULL) {
// Stage is not Fishing Pond
if (strcmp(dComIfGp_getStartStageName(), "R_SP127") || cam->view.lookat.eye.y > 0.0f) {
if (g_env_light.raincnt < 125.0f) {
mDoAud_rainPlay(FALSE);
} else {
mDoAud_rainPlay(TRUE);
}
}
}
if (g_env_light.raincnt <= 3) {
g_env_light.mRainInitialized = 0;
mDoAud_seStart(JA_SE_ATM_RAIN_END, NULL, 0, 0);
JKR_DELETE(g_env_light.mpRainPacket);
g_env_light.mpRainPacket = NULL;
}
break;
}
}
static void wether_move_snow() {
switch (g_env_light.mSnowInitialized) {
case FALSE:
if (g_env_light.mSnowCount != 0 || g_env_light.field_0xe90 != 0) {
dKyr_snow_init();
if (g_env_light.mpSnowPacket != NULL) {
dKyr_snow_move();
g_env_light.mSnowInitialized = 1;
}
}
break;
case TRUE:
dKyr_snow_move();
break;
}
}
static void wether_move_star() {
s32 starsVisible = false;
// Stage is Hyrule Castle or Castle Throne Room
if (!strcmp(dComIfGp_getStartStageName(), "D_MN09") ||
!strcmp(dComIfGp_getStartStageName(), "D_MN09A"))
{
return;
} else {
// Stage is Hero Shade arena
if ((dComIfGp_checkStatus(1) && !g_env_light.hide_vrbox) ||
!strcmp(dComIfGp_getStartStageName(), "F_SP200"))
{
roomRead_class* room = dComIfGp_getStageRoom();
if (room != NULL && room->num > dComIfGp_roomControl_getStayNo()) {
starsVisible = dStage_roomRead_dt_c_GetVrboxswitch(
*room->m_entries[dComIfGp_roomControl_getStayNo()]);
}
// Stage is Hero Shade arena
if (!strcmp(dComIfGp_getStartStageName(), "F_SP200")) {
starsVisible = true;
}
if (starsVisible && dKy_darkworld_check() != true) {
f32 density;
f32 time = g_env_light.getDaytime();
if (time >= 330.0f || time < 45.0f) {
density = 1.0f;
} else if (time > 285.0f) {
density = 1.0f - (1.0f / 45.0f) * (330.0f - time);
} else {
if (time < 75.0f) {
density = (1.0f / 30.0f) * (75.0f - time);
} else {
density = 0.0f;
}
}
if (g_env_light.mColpatWeather != 0) {
density = 0.0f;
}
if (g_env_light.wether_pat1 != 0 && g_env_light.pat_ratio > 0.5f) {
density = 0.0f;
}
// Stage is Hero Shade arena
if (!strcmp(dComIfGp_getStartStageName(), "F_SP200")) {
density = 1.0f;
}
cLib_addCalc(&g_env_light.mStarDensity, density, 0.1f, 0.01f, 0.000001f);
g_env_light.mStarCount = (s16)(1200.0f * g_env_light.mStarDensity);
// Stage is Hyrule Field or Outside Castle Town or Hidden Village
if (!strcmp(dComIfGp_getStartStageName(), "F_SP121") ||
!strcmp(dComIfGp_getStartStageName(), "F_SP122") ||
!strcmp(dComIfGp_getStartStageName(), "F_SP128"))
{
g_env_light.mStarCount = (s16)(500.0f * g_env_light.mStarDensity);
}
switch (g_env_light.mStarInitialized) {
case FALSE:
if (g_env_light.mStarCount != 0) {
dKyr_star_init();
dKyr_shstar_init();
if (g_env_light.mpStarPacket != NULL) {
dKyr_star_move();
dKyr_shstar_move();
g_env_light.mStarInitialized = true;
}
}
break;
case TRUE:
dKyr_star_move();
dKyr_shstar_move();
if (g_env_light.mStarCount == 0) {
g_env_light.mStarInitialized = false;
JKR_DELETE(g_env_light.mpStarPacket);
g_env_light.mpStarPacket = NULL;
}
break;
}
}
}
}
}
static void wether_move_housi() {
// Stage is Palace of Twilight or Zant Throne Room, or Phantom Zant arena
// Room is not Entrance or Boss Key room
if ((!strcmp(dComIfGp_getStartStageName(), "D_MN08") && dComIfGp_roomControl_getStayNo() != 0 &&
dComIfGp_roomControl_getStayNo() != 11) ||
(!strcmp(dComIfGp_getStartStageName(), "D_MN08A") ||
!strcmp(dComIfGp_getStartStageName(), "D_MN08B") ||
!strcmp(dComIfGp_getStartStageName(), "D_MN08C")))
{
return;
}
// Stage is darkworld or Stage is Lake Hylia and Room is Lanayru Spring
if (dKy_darkworld_check() == true ||
(!strcmp(dComIfGp_getStartStageName(), "F_SP115") &&
dComIfGp_roomControl_getStayNo() == 1 && dComIfGp_getStartStageLayer() == 9))
{
if (g_env_light.light_init_timer != 0) {
g_env_light.field_0xea9 = 0;
g_env_light.mHousiCount = 200;
// Stage is Faron Woods and Room is Faron Spring or
// Stage is Castle Town and Room is Castle Town Center or
// Stage is Faron Woods and Room is South Faron or
// Stage is Lake Hylia
if ((!strcmp(dComIfGp_getStartStageName(), "F_SP108") &&
dComIfGp_getStartStageRoomNo() == 1 && dComIfGp_getStartStageLayer() == 13) ||
(!strcmp(dComIfGp_getStartStageName(), "F_SP116") &&
dComIfGp_getStartStageRoomNo() == 0 && dComIfGp_getStartStageLayer() == 8) ||
(!strcmp(dComIfGp_getStartStageName(), "F_SP108") &&
dComIfGp_getStartStageRoomNo() == 0 && dComIfGp_getStartStageLayer() == 9) ||
(!strcmp(dComIfGp_getStartStageName(), "F_SP115") &&
dComIfGp_getStartStageLayer() == 9))
{
g_env_light.mHousiCount = 0;
}
}
}
switch (g_env_light.mHousiInitialized) {
case FALSE:
if (g_env_light.mHousiCount != 0) {
g_env_light.mpHousiPacket = JKR_NEW_ARGS (32) dKankyo_housi_Packet();
if (g_env_light.mpHousiPacket != NULL) {
if (dKy_darkworld_check() == true) {
g_env_light.mpHousiPacket->mpResTex = (u8*)dComIfG_getObjectRes("Always", 0x5E);
} else {
if (g_env_light.field_0xea9 == 2) {
if (g_env_light.fishing_hole_season == 3) {
g_env_light.mpHousiPacket->mpResTex =
(u8*)dComIfG_getStageRes("momiji64s3tc.bti");
} else {
g_env_light.mpHousiPacket->mpResTex =
(u8*)dComIfG_getStageRes("sakura32ia4.bti");
}
if (g_env_light.mpHousiPacket->mpResTex == NULL) {
g_env_light.mpHousiPacket->mpResTex =
(u8*)dComIfG_getObjectRes("Always", 0x55);
}
} else if (g_env_light.field_0xea9 == 0) {
g_env_light.mpHousiPacket->mpResTex =
(u8*)dComIfG_getObjectRes("Always", 0x55);
} else {
g_env_light.mpHousiPacket->mpResTex =
(u8*)dComIfG_getObjectRes("Always", 0x56);
}
}
g_env_light.mpHousiPacket->field_0x5de8 = 0.0f;
g_env_light.mpHousiPacket->field_0x10.set(0.0f, 0.0f, 0.0f);
for (int i = 0; i < 300; i++) {
g_env_light.mpHousiPacket->mHousiEff[i].mStatus = 0;
}
dKyr_housi_move();
g_env_light.mHousiInitialized = true;
}
}
break;
case TRUE:
if (g_env_light.mHousiCount == 0 &&
g_env_light.mpHousiPacket->field_0x5de8 <= 0.0f)
{
g_env_light.mHousiInitialized = false;
JKR_DELETE(g_env_light.mpHousiPacket);
g_env_light.mpHousiPacket = NULL;
} else {
dKyr_housi_move();
if (!dKy_darkworld_check()) {
g_env_light.mHousiCount = 0;
}
}
break;
}
}
static void wether_move_odour() {
switch (g_env_light.mOdourData.mOdourPacketStatus) {
case 0:
if (g_env_light.mOdourData.field_0xf21 != 0) {
g_env_light.mOdourData.mpOdourPacket = JKR_NEW_ARGS (32) dKankyo_odour_Packet();
if (g_env_light.mOdourData.mpOdourPacket != NULL) {
g_env_light.mOdourData.mpOdourPacket->mpResTex = (u8*)dComIfG_getObjectRes("Always", 0x53);
dKyr_odour_init();
dKyr_odour_move();
g_env_light.mOdourData.mOdourPacketStatus = 1;
}
}
break;
case 1:
if (g_env_light.mOdourData.field_0xf21 == 0) {
g_env_light.mOdourData.mOdourPacketStatus = 0;
if (g_env_light.mOdourData.mpOdourPacket != NULL) {
JKR_DELETE(g_env_light.mOdourData.mpOdourPacket);
g_env_light.mOdourData.mpOdourPacket = NULL;
}
} else {
dKyr_odour_move();
}
break;
case 2:
g_env_light.mOdourData.field_0xf21 = 0;
g_env_light.mOdourData.mOdourPacketStatus = 0;
JKR_DELETE(g_env_light.mOdourData.mpOdourPacket);
g_env_light.mOdourData.mpOdourPacket = NULL;
break;
}
}
static void wether_move_moya() {
switch (g_env_light.mCloudInitialized) {
case 0:
if (g_env_light.mMoyaCount != 0) {
g_env_light.mpCloudPacket = JKR_NEW_ARGS (32) dKankyo_cloud_Packet();
if (g_env_light.mpCloudPacket != NULL) {
g_env_light.mpCloudPacket->mpResTex = (u8*)dComIfG_getObjectRes("Always", 0x53);
for (int i = 0; i < 50; i++) {
g_env_light.mpCloudPacket->mCloudEff[i].mStatus = 0;
}
g_env_light.mpCloudPacket->mCount = 0;
cloud_shadow_move();
g_env_light.mCloudInitialized++;
}
}
break;
case 1:
if (g_env_light.mMoyaMode == 0) {
dKyw_get_wind_pow();
}
cloud_shadow_move();
if (g_env_light.mMoyaCount == 0 && g_env_light.mpCloudPacket->mCount == 0) {
g_env_light.mCloudInitialized = 0;
JKR_DELETE(g_env_light.mpCloudPacket);
g_env_light.mpCloudPacket = NULL;
}
break;
}
}
static void wether_move_vrkumo() {
BOOL var_r31 = false;
static cXyz r09o(-180000.0f, 750.0f, -200000.0f);
if (dComIfGp_checkStatus(1) && !g_env_light.hide_vrbox) {
g_env_light.mVrkumoCount = 6;
if (memcmp(dComIfGp_getStartStageName(), "D_MN07", 6) == 0 ||
strcmp(dComIfGp_getStartStageName(), "F_SP114") == 0 ||
(strcmp(dComIfGp_getStartStageName(), "D_MN09B") == 0 &&
(g_env_light.wether != 0 || dComIfGp_event_runCheck())))
{
cLib_addCalc(&g_env_light.mVrkumoStrength, 1.0f, 0.1f, 0.003f, 0.0000001f);
} else if (strcmp(dComIfGp_getStartStageName(), "F_SP104") == 0 &&
dComIfG_play_c::getLayerNo(0) >= 3)
{
if (g_env_light.wether_pat1 >= 4) {
cLib_addCalc(&g_env_light.mVrkumoStrength, 1.0f, 0.1f, 0.003f, 0.0000001f);
} else {
cLib_addCalc(&g_env_light.mVrkumoStrength, 0.0f, 0.08f, 0.002f, 0.00000001f);
}
} else if ((g_env_light.wether_pat1 == 1 && g_env_light.pat_ratio > 0.0f) ||
(g_env_light.wether_pat0 == 1 && g_env_light.pat_ratio < 1.0f) ||
(g_env_light.wether_pat1 == 2 && g_env_light.pat_ratio > 0.0f) ||
(g_env_light.wether_pat0 == 2 && g_env_light.pat_ratio < 1.0f))
{
cLib_addCalc(&g_env_light.mVrkumoStrength, 1.0f, 0.1f, 0.003f, 0.0000001f);
} else {
cLib_addCalc(&g_env_light.mVrkumoStrength, 0.0f, 0.08f, 0.002f, 0.00000001f);
}
g_env_light.mVrkumoCount = (s16)(g_env_light.mVrkumoStrength * 56.0f + 6.0f);
} else {
g_env_light.mVrkumoCount = 0;
}
if (dKy_darkworld_check()) {
g_env_light.mVrkumoCount = 30;
}
roomRead_class* room_p = dComIfGp_getStageRoom();
if (room_p != NULL && room_p->num > dComIfGp_roomControl_getStayNo()) {
var_r31 = dStage_roomRead_dt_c_GetVrboxswitch(
*room_p->m_entries[dComIfGp_roomControl_getStayNo()]);
}
if (strcmp(dComIfGp_getStartStageName(), "F_SP200") == 0) {
g_env_light.mVrkumoCount = 30;
} else if (var_r31 == 0) {
return;
}
switch (g_env_light.mVrkumoStatus) {
case 0:
if (g_env_light.mVrkumoCount != 0) {
g_env_light.mpVrkumoPacket = JKR_NEW_ARGS (0x20) dKankyo_vrkumo_Packet();
if (g_env_light.mpVrkumoPacket == NULL) {
return;
}
g_env_light.mpVrkumoPacket->mpResCloudtx_01 =
(u8*)dComIfG_getStageRes("cloudtx_01.bti");
g_env_light.mpVrkumoPacket->mpResCloudtx_02 =
(u8*)dComIfG_getStageRes("cloudtx_02.bti");
g_env_light.mpVrkumoPacket->mpResCloudtx_03 =
(u8*)dComIfG_getStageRes("cloudtx_03.bti");
if (g_env_light.mpVrkumoPacket->mpResCloudtx_01 == NULL ||
g_env_light.mpVrkumoPacket->mpResCloudtx_02 == NULL ||
g_env_light.mpVrkumoPacket->mpResCloudtx_03 == NULL)
{
g_env_light.mVrkumoStatus = 99;
}
for (int i = 0; i < 100; i++) {
g_env_light.mpVrkumoPacket->mVrkumoEff[i].mStatus = 0;
}
g_env_light.mpVrkumoPacket->field_0x1150 = 0.0f;
g_env_light.mpVrkumoPacket->field_0x1154 = 0.0f;
vrkumo_move();
g_env_light.mVrkumoStatus++;
}
break;
case 1:
vrkumo_move();
dKyw_get_wind_vec();
cXyz sp8;
f32 wind_vec_x = g_env_light.global_wind_influence.vec.x;
f32 wind_vec_y = g_env_light.global_wind_influence.vec.y;
f32 wind_vec_z = g_env_light.global_wind_influence.vec.z;
f32 var_f31 = g_env_light.global_wind_influence.pow;
if (strcmp(dComIfGp_getStartStageName(), "R_SP127") == 0) {
var_f31 = 0.3f;
}
f32 var_f30 = JMAFastSqrt(wind_vec_x * wind_vec_x + wind_vec_z * wind_vec_z);
f32 temp_f27_2 = cM_atan2s(wind_vec_x, wind_vec_z);
f32 temp_r4_2 = cM_atan2s(wind_vec_y, var_f30);
temp_f27_2 += 24575.0f;
sp8.x = cM_scos(temp_r4_2) * cM_ssin(temp_f27_2);
sp8.y = cM_ssin(temp_r4_2);
sp8.z = cM_scos(temp_r4_2) * cM_scos(temp_f27_2);
g_env_light.mpVrkumoPacket->field_0x1150 += (sp8.x * var_f31) * 0.0014f;
g_env_light.mpVrkumoPacket->field_0x1154 += (sp8.z * var_f31) * 0.0014f;
while (g_env_light.mpVrkumoPacket->field_0x1150 < 0.0f) {
g_env_light.mpVrkumoPacket->field_0x1150 += 1.0f;
}
while (g_env_light.mpVrkumoPacket->field_0x1150 > 1.0f) {
g_env_light.mpVrkumoPacket->field_0x1150 -= 1.0f;
}
while (g_env_light.mpVrkumoPacket->field_0x1154 < 0.0f) {
g_env_light.mpVrkumoPacket->field_0x1154 += 1.0f;
}
while (g_env_light.mpVrkumoPacket->field_0x1154 > 1.0f) {
g_env_light.mpVrkumoPacket->field_0x1154 -= 1.0f;
}
break;
}
}
static void wether_move_mud() {
switch (g_env_light.mMudInitialized) {
case 0:
if (g_env_light.field_0x1048 != 0) {
g_env_light.mpMudPacket = JKR_NEW_ARGS (32) dKankyo_mud_Packet();
if (g_env_light.mpMudPacket != NULL) {
dKyr_mud_init();
dKyr_mud_move();
g_env_light.mMudInitialized++;
}
}
break;
case 1:
dKyr_mud_move();
if (g_env_light.field_0x1048 == 0 && g_env_light.mpMudPacket->mEffectNum == 0) {
g_env_light.mMudInitialized = 0;
JKR_DELETE(g_env_light.mpMudPacket);
g_env_light.mpMudPacket = NULL;
}
break;
}
}
static void wether_move_evil() {
switch (g_env_light.mEvilInitialized & 0xF) {
case 0:
if (g_env_light.field_0x1054 != 0) {
g_env_light.mpEvilPacket = JKR_NEW_ARGS (32) dKankyo_evil_Packet();
if (g_env_light.mpEvilPacket != NULL) {
dKyr_evil_init();
dKyr_evil_move();
g_env_light.mEvilInitialized++;
}
}
break;
case 1:
dKyr_evil_move();
if (g_env_light.field_0x1054 == 0 && g_env_light.mpEvilPacket->mEffectNum == 0) {
g_env_light.mEvilInitialized = 0;
JKR_DELETE(g_env_light.mpEvilPacket);
g_env_light.mpEvilPacket = NULL;
}
break;
}
}
void dKyw_wether_move_draw() {
g_env_light.moya_se = 0;
if (strcmp(dComIfGp_getStartStageName(), "Name")) {
wether_move_sun();
wether_move_rain();
wether_move_snow();
}
wether_move_star();
if (strcmp(dComIfGp_getStartStageName(), "Name")) {
wether_move_housi();
wether_move_moya();
wether_move_mud();
wether_move_evil();
wether_move_odour();
}
}
void dKyw_wether_move_draw2() {
wether_move_vrkumo();
}
void dKyw_wether_draw() {
if (strcmp(dComIfGp_getStartStageName(), "Name") && g_env_light.mCloudInitialized != 0) {
dKyw_Cloud_Draw();
}
if (strcmp(dComIfGp_getStartStageName(), "Name") && g_env_light.mSunInitialized) {
stage_stag_info_class* stag_info = dComIfGp_getStageStagInfo();
if (dStage_stagInfo_GetArg0(stag_info) != 0) {
dKyw_Sun_Draw();
dKyw_Sunlenz_Draw();
}
}
if (g_env_light.mStarInitialized) {
dKyw_Star_Draw();
dKyw_shstar_Draw();
}
if (strcmp(dComIfGp_getStartStageName(), "Name")) {
if (g_env_light.mRainInitialized) {
dKyw_Rain_Draw();
}
if (g_env_light.mSnowInitialized) {
dKyw_Snow_Draw();
}
if (g_env_light.mHousiInitialized) {
dKyw_Housi_Draw();
}
if (g_env_light.mOdourData.mOdourPacketStatus != 0) {
dKyw_Odour_Draw();
}
if (g_env_light.mMudInitialized != 0) {
dKyw_mud_Draw();
}
if (g_env_light.mEvilInitialized != 0) {
dKyw_evil_Draw();
}
dKy_undwater_filter_draw();
}
}
void dKyw_wether_draw2() {
if (g_env_light.mVrkumoStatus != 0 && g_env_light.mVrkumoStatus < 99) {
dKyw_Vrkumo_Draw();
}
}
void dKyw_wether_proc() {
// Stage is Faron Woods or Fishing Pond or Hyrule Field
if (!strcmp(dComIfGp_getStartStageName(), "F_SP108") ||
!strcmp(dComIfGp_getStartStageName(), "F_SP127") ||
(!strcmp(dComIfGp_getStartStageName(), "F_SP121") &&
g_env_light.dice_wether_time != 0.0f))
{
if (!dKy_darkworld_check()) {
// Stage is Hyrule Field
if (!strcmp(dComIfGp_getStartStageName(), "F_SP121") ||
!(g_env_light.daytime >= 75.0f) || !(g_env_light.daytime <= 120.0f))
{
// Stage is Hyrule Field
if (!strcmp(dComIfGp_getStartStageName(), "F_SP121") &&
g_env_light.dice_wether_mode >= 1 && g_env_light.dice_wether_mode < 6)
{
dKy_get_dayofweek();
lbl1:
cLib_addCalc(&g_env_light.field_0xebc, 1.0f, 0.05f, 0.0025f, 0.000001f);
g_env_light.mMoyaMode = 7;
g_env_light.mMoyaCount = 49;
} else {
cLib_addCalc(&g_env_light.field_0xebc, 0.0f, 0.05f, 0.0025f, 0.00001f);
if (g_env_light.field_0xebc <= 0.01f && g_env_light.mMoyaCount == 49) {
g_env_light.mMoyaCount = 0;
}
}
} else {
goto lbl1; // maybe fake match
}
}
}
// Stage is Fishing Pond
if (!strcmp(dComIfGp_getStartStageName(), "F_SP127") &&
(g_env_light.fishing_hole_season == 1 || g_env_light.fishing_hole_season == 3))
{
if (g_env_light.fishing_hole_season == 1) {
g_env_light.mHousiCount = 35;
} else {
g_env_light.mHousiCount = 30;
}
g_env_light.field_0xea9 = 2;
}
squal_proc();
}
static void dKyw_wind_init() {
g_env_light.global_wind_influence.vec.x = -1.0f;
g_env_light.global_wind_influence.vec.y = 0.0f;
g_env_light.global_wind_influence.vec.z = 0.0f;
g_env_light.global_wind_influence.pow = 0.0f;
g_env_light.unk_0xe6c = 0;
g_env_light.unk_0xe64 = 0;
g_env_light.unk_0xe66 = 0;
g_env_light.global_wind_influence.vec_override = NULL;
g_env_light.custom_windpower = 0.0f;
g_env_light.evt_wind_go = 0;
g_env_light.TeachWind_existence = 0;
}
void dKyw_wind_set() {
s16 var_r30;
s16 var_r29;
int var_r28 = 0;
cXyz wind_vec;
f32 strength;
if (g_env_light.global_wind_influence.vec_override != NULL) {
wind_vec = *g_env_light.global_wind_influence.vec_override;
strength = g_env_light.custom_windpower;
cM_atan2s(wind_vec.x, wind_vec.z);
cM_atan2s(wind_vec.absXZ(), wind_vec.y);
} else {
dStage_FileList_dt_c* fili_p = NULL;
int wind_level = 0;
if (dComIfGp_roomControl_getStayNo() >= 0) {
fili_p = dComIfGp_roomControl_getStatusRoomDt(dComIfGp_roomControl_getStayNo())
->getFileListInfo();
}
var_r30 = 0;
var_r29 = 0;
if (fili_p != NULL) {
var_r28 = dStage_FileList_dt_GlobalWindDir(fili_p);
}
if (dComIfGp_roomControl_getStatusRoomDt(dComIfGp_roomControl_getStayNo()) != NULL) {
dStage_Lbnk_c* lbnk_p =
dComIfGp_roomControl_getStatusRoomDt(dComIfGp_roomControl_getStayNo())->getLbnk();
if (lbnk_p != NULL) {
dStage_Lbnk_dt_c* data_p = lbnk_p->entries;
if (dStage_lbnkWIND(&data_p[dComIfG_play_c::getLayerNo(0)]) != 7) {
var_r28 = dStage_lbnkWIND(&data_p[0]);
}
}
}
switch (var_r28) {
case 0:
case 1:
break;
case 2:
var_r30 = 0;
var_r29 = -0x4000;
break;
case 3:
var_r30 = 0;
var_r29 = 0;
break;
case 4:
var_r30 = 0;
var_r29 = 0x4000;
break;
case 5:
var_r30 = 0;
var_r29 = 0x7FFF;
break;
}
if (g_env_light.evt_wind_go != 0 && g_env_light.evt_wind_go != 0xFF) {
var_r30 = g_env_light.evt_wind_angle_x;
var_r29 = g_env_light.evt_wind_angle_y;
}
wind_vec.x = cM_scos(var_r30) * cM_ssin(var_r29);
wind_vec.y = cM_ssin(var_r30);
wind_vec.z = cM_scos(var_r30) * cM_scos(var_r29);
if (fili_p != NULL) {
wind_level = dStage_FileList_dt_GlobalWindLevel(fili_p);
}
if (dComIfGp_roomControl_getStatusRoomDt(dComIfGp_roomControl_getStayNo()) != NULL) {
dStage_Lbnk_c* lbnk_p =
dComIfGp_roomControl_getStatusRoomDt(dComIfGp_roomControl_getStayNo())->getLbnk();
if (lbnk_p != NULL) {
dStage_Lbnk_dt_c* data_p = lbnk_p->entries;
if (dStage_lbnkWlevel(&data_p[0]) != 3) {
wind_level = dStage_lbnkWlevel(&data_p[0]);
}
}
}
switch (wind_level) {
case 0:
strength = 0.3f;
break;
case 1:
strength = 0.6f;
break;
case 2:
strength = 0.9f;
break;
default:
strength = 0.0f;
break;
}
}
if (g_env_light.evt_wind_go != 0) {
strength = g_env_light.custom_windpower;
}
if (strength > 1.0f) {
strength = 1.0f;
}
if (strcmp(dComIfGp_getStartStageName(), "D_MN07") == 0 &&
(dComIfGp_roomControl_getStayNo() == 0 || dComIfGp_roomControl_getStayNo() == 3 ||
dComIfGp_roomControl_getStayNo() == 6 || dComIfGp_roomControl_getStayNo() == 13))
{
mDoAud_mEnvse_setWindDirection(&wind_vec);
if (strength <= 0.5f) {
mDoAud_mEnvse_setWindType(3);
} else {
mDoAud_mEnvse_setWindType(1);
}
s8 reverb = dComIfGp_getReverb(dComIfGp_roomControl_getStayNo());
mDoAud_mEnvse_startStrongWindSe(reverb);
}
if (g_env_light.light_init_timer != 0) {
g_env_light.global_wind_influence.vec = wind_vec;
g_env_light.global_wind_influence.pow = strength;
} else {
cLib_addCalc(&g_env_light.global_wind_influence.vec.x, wind_vec.x, 0.05f, 2.0f, 0.001f);
cLib_addCalc(&g_env_light.global_wind_influence.vec.y, wind_vec.y, 0.05f, 2.0f, 0.001f);
cLib_addCalc(&g_env_light.global_wind_influence.vec.z, wind_vec.z, 0.05f, 2.0f, 0.001f);
cLib_addCalc(&g_env_light.global_wind_influence.pow, strength, 0.05f, 1.0f, 0.005f);
}
}
cXyz* dKyw_get_wind_vec() {
return &g_env_light.global_wind_influence.vec;
}
f32 dKyw_get_wind_pow() {
return g_env_light.global_wind_influence.pow;
}
cXyz dKyw_get_wind_vecpow() {
cXyz vec = g_env_light.global_wind_influence.vec * g_env_light.global_wind_influence.pow;
return vec;
}
void dKyw_plight_collision_set(cXyz* param_0, s16 param_1, s16 param_2, f32 param_3, f32 param_4,
f32 param_5, f32 param_6, f32 param_7) {
dScnKy_env_light_c* env_light = dKy_getEnvlight();
for (int i = 0; i < 5; i++) {
if (!env_light->wind_inf_entity[i].mInUse) {
env_light->wind_inf_entity[i].mInUse = true;
env_light->wind_inf_entity[i].mMinRadius = param_4;
env_light->wind_inf_entity[i].mSpeed = param_6;
env_light->wind_inf_entity[i].mStrengthMaxVel = param_7;
WIND_INFLUENCE* wind_inf = &env_light->wind_inf_entity[i].mInfluence;
wind_inf->position = *param_0;
wind_inf->mDirection.x = cM_scos(param_1) * cM_ssin(param_2);
wind_inf->mDirection.y = cM_ssin(param_1);
wind_inf->mDirection.z = cM_scos(param_1) * cM_scos(param_2);
wind_inf->mRadius = param_3;
wind_inf->field_0x20 = wind_inf->mRadius;
wind_inf->mStrength = param_5;
dKyw_pntlight_set(wind_inf);
break;
}
}
}
static void squal_proc() {
dScnKy_env_light_c* env_light = dKy_getEnvlight();
WIND_INFLUENCE* influence;
for (int i = 0; i < 5; i++) {
influence = &env_light->wind_inf_entity[i].mInfluence;
switch (env_light->wind_inf_entity[i].mInUse) {
case 0:
break;
case 1:
influence->position.x +=
influence->mDirection.x * env_light->wind_inf_entity[i].mSpeed;
influence->position.y +=
influence->mDirection.y * env_light->wind_inf_entity[i].mSpeed;
influence->position.z +=
influence->mDirection.z * env_light->wind_inf_entity[i].mSpeed;
cLib_addCalc(&influence->mStrength, 0.0f, 0.2f,
env_light->wind_inf_entity[i].mStrengthMaxVel, 0.001f);
f32 speed = 1.0f - influence->mStrength;
f32 target = env_light->wind_inf_entity[i].mMinRadius;
cLib_addCalc(&influence->mRadius, target, speed, speed * target * 0.05f, 0.01f);
if (influence->mStrength < 0.01f) {
dKyw_pntwind_cut(influence);
env_light->wind_inf_entity[i].mInUse = false;
}
break;
}
}
}
static void dKyw_pntwind_init() {
for (int i = 0; i < 30; i++) {
g_env_light.pntwind[i] = NULL;
}
for (int i = 0; i < 5; i++) {
g_env_light.wind_inf_entity[i].mInUse = 0;
}
}
static void pntwind_set(WIND_INFLUENCE* i_pntwind) {
int i = 0;
for (; i < 30; i++) {
if (g_env_light.pntwind[i] == NULL) {
g_env_light.pntwind[i] = i_pntwind;
g_env_light.pntwind[i]->field_0x24 = i;
break;
}
}
if (i >= 30) {
i_pntwind->field_0x24 = 9999;
}
}
void dKyw_pntwind_set(WIND_INFLUENCE* i_pntwind) {
i_pntwind->mConstant = 0;
i_pntwind->field_0x29 = 0;
pntwind_set(i_pntwind);
}
static void dKyw_pntlight_set(WIND_INFLUENCE* i_pntwind) {
i_pntwind->mConstant = 0;
i_pntwind->field_0x29 = 1;
pntwind_set(i_pntwind);
}
void dKyw_pntwind_cut(WIND_INFLUENCE* i_pntwind) {
if (i_pntwind != NULL && i_pntwind->field_0x24 >= 0 && i_pntwind->field_0x24 < 30) {
g_env_light.pntwind[i_pntwind->field_0x24] = NULL;
}
}
static void pntwind_get_info(cXyz* param_0, cXyz* i_dir, f32* i_power, u8 param_3) {
i_dir->x = 0.0f;
i_dir->y = 0.0f;
i_dir->z = 0.0f;
*i_power = 0.0f;
WIND_INFLUENCE* influence;
s32 influence_count = ARRAY_SIZEU(g_env_light.pntwind);
for (int i = 0; i < influence_count; i++) {
influence = g_env_light.pntwind[i];
if (influence != NULL && influence->field_0x29 == param_3) {
f32 dist = param_0->abs(influence->position);
if (influence->mConstant == 0) {
if (dist < influence->mRadius && influence->mStrength > 0.0f && dist != 0.0f) {
f32 temp_f0;
if (influence->mRadius > 0.0f) {
f32 temp_f0_4 = (dist / influence->mRadius);
temp_f0 = 1.0f - (temp_f0_4 * temp_f0_4);
} else {
temp_f0 = 1.0f;
}
*i_power = influence->mStrength * temp_f0;
cXyz sp10;
sp10.x =
influence->position.x + -(influence->mDirection.x) * influence->mRadius;
sp10.y =
influence->position.y + -(influence->mDirection.y) * influence->mRadius;
sp10.z =
influence->position.z + -(influence->mDirection.z) * influence->mRadius;
dKyr_get_vectle_calc(&sp10, param_0, i_dir);
if (param_0->abs(sp10) < influence->mRadius) {
i_dir->x = 0.0f;
i_dir->y = 0.0f;
i_dir->z = 0.0f;
}
return;
}
} else {
if (dist < influence->mRadius && influence->mStrength > 0.0f && dist != 0.0f) {
f32 temp_f0;
if (influence->mRadius > 0.0f) {
temp_f0 = 1.0f - (dist / influence->mRadius);
} else {
temp_f0 = 1.0f;
}
i_dir->x = influence->mDirection.x;
i_dir->y = influence->mDirection.y;
i_dir->z = influence->mDirection.z;
*i_power = influence->mStrength * temp_f0;
return;
}
}
}
}
}
static void dKyw_pntwind_get_info(cXyz* param_0, cXyz* param_1, f32* param_2) {
pntwind_get_info(param_0, param_1, param_2, 0);
}
void dKyw_pntlight_collision_get_info(cXyz* param_0, cXyz* param_1, f32* param_2) {
pntwind_get_info(param_0, param_1, param_2, 1);
}
cXyz dKyw_pntwind_get_vecpow(cXyz* param_0) {
cXyz direction;
f32 power;
dKyw_pntwind_get_info(param_0, &direction, &power);
direction = direction * power;
return direction;
}
void dKyw_get_AllWind_vec(cXyz* i_position, cXyz* i_direction, f32* i_power) {
dScnKy_env_light_c* env_light = dKy_getEnvlight();
dKyw_pntwind_get_info(i_position, i_direction, i_power);
cXyz sp54;
cXyz sp30;
cXyz sp24;
sp30 = env_light->global_wind_influence.vec * (env_light->global_wind_influence.pow * (1.0f - *i_power));
sp24 = *i_direction * (*i_power * 5.0f);
sp54 = sp30 + sp24;
*i_power = sp54.abs();
sp54 = sp54.normZP();
if (sp54 != cXyz::Zero) {
i_direction->x = sp54.x;
i_direction->y = sp54.y;
i_direction->z = sp54.z;
} else {
i_direction->x = env_light->global_wind_influence.vec.x;
i_direction->y = env_light->global_wind_influence.vec.y;
i_direction->z = env_light->global_wind_influence.vec.z;
}
}
cXyz dKyw_get_AllWind_vecpow(cXyz* param_0) {
f32 sp8;
cXyz spC;
cXyz sp18;
cXyz sp24;
cXyz sp30;
dKyw_pntwind_get_info(param_0, &sp30, &sp8);
sp18 = g_env_light.global_wind_influence.vec * (g_env_light.global_wind_influence.pow * (1.0f - sp8));
sp24 = sp30 * (5.0f * sp8);
spC = sp18 + sp24;
return spC;
}
void dKyw_custom_windpower(f32 pow) {
g_env_light.custom_windpower = pow;
}
void dKyw_evt_wind_set(s16 angleX, s16 angleY) {
g_env_light.evt_wind_go = 1;
g_env_light.evt_wind_angle_x = angleX;
g_env_light.evt_wind_angle_y = angleY;
}
void dKyw_evt_wind_set_go() {
g_env_light.evt_wind_go = 1;
}
void dKyw_rain_set(int count) {
g_env_light.raincnt = count;
g_env_light.base_raincnt = count;
}