mirror of
https://github.com/zeldaret/tww.git
synced 2026-05-23 15:01:33 -04:00
2520 lines
92 KiB
C++
2520 lines
92 KiB
C++
//
|
|
// Generated by dtk
|
|
// Translation Unit: d_kankyo_rain.cpp
|
|
//
|
|
|
|
#include "d/d_kankyo_rain.h"
|
|
#include "d/d_bg_s_gnd_chk.h"
|
|
#include "d/d_bg_s_roof_chk.h"
|
|
#include "d/d_cc_d.h"
|
|
#include "d/d_com_inf_game.h"
|
|
#include "d/d_kankyo.h"
|
|
#include "d/d_kankyo_wether.h"
|
|
#include "d/d_procname.h"
|
|
#include "d/d_snap.h"
|
|
#include "f_op/f_op_camera.h"
|
|
#include "f_op/f_op_kankyo_mng.h"
|
|
#include "m_Do/m_Do_audio.h"
|
|
#include "m_Do/m_Do_lib.h"
|
|
#include "SSystem/SComponent/c_counter.h"
|
|
|
|
static u32 now_room = -1;
|
|
|
|
/* 8008AA30-8008AB3C .text vectle_calc__FP10DOUBLE_POSP4cXyz */
|
|
void vectle_calc(DOUBLE_POS* i_pos, cXyz* o_out) {
|
|
double s = sqrt(i_pos->x * i_pos->x + i_pos->y * i_pos->y + i_pos->z * i_pos->z);
|
|
|
|
if (s != 0.0) {
|
|
o_out->x = i_pos->x / s;
|
|
o_out->y = i_pos->y / s;
|
|
o_out->z = i_pos->z / s;
|
|
} else {
|
|
o_out->x = 0.0f;
|
|
o_out->y = 0.0f;
|
|
o_out->z = 0.0f;
|
|
}
|
|
}
|
|
|
|
/* 8008AB3C-8008AB94 .text get_vectle_calc__FP4cXyzP4cXyzP4cXyz */
|
|
void get_vectle_calc(cXyz* param_0, cXyz* param_1, cXyz* param_2) {
|
|
DOUBLE_POS pos;
|
|
pos.x = param_1->x - param_0->x;
|
|
pos.y = param_1->y - param_0->y;
|
|
pos.z = param_1->z - param_0->z;
|
|
|
|
vectle_calc(&pos, param_2);
|
|
}
|
|
|
|
/* 8008AB94-8008ABB4 .text dKyr_get_vectle_calc__FP4cXyzP4cXyzP4cXyz */
|
|
void dKyr_get_vectle_calc(cXyz* param_0, cXyz* param_1, cXyz* param_2) {
|
|
get_vectle_calc(param_0, param_1, param_2);
|
|
}
|
|
|
|
/* 8008ABB4-8008AC64 .text dKy_set_eyevect_calc__FP12camera_classP3Vecff */
|
|
void dKy_set_eyevect_calc(camera_class* i_camera, Vec* param_1, f32 param_2, f32 param_3) {
|
|
cXyz tmp;
|
|
get_vectle_calc(&i_camera->mLookat.mEye, &i_camera->mLookat.mCenter, &tmp);
|
|
param_1->x = i_camera->mLookat.mEye.x + tmp.x * param_2;
|
|
param_1->y = (i_camera->mLookat.mEye.y + tmp.y * param_3) - 200.0f;
|
|
param_1->z = i_camera->mLookat.mEye.z + tmp.z * param_2;
|
|
}
|
|
|
|
/* 8008AC64-8008AD60 .text dKy_set_eyevect_calc2__FP12camera_classP3Vecff */
|
|
void dKy_set_eyevect_calc2(camera_class* i_camera, Vec* param_1, f32 param_2, f32 param_3) {
|
|
cXyz tmp;
|
|
DOUBLE_POS pos;
|
|
|
|
pos.x = i_camera->mLookat.mCenter.x - i_camera->mLookat.mEye.x;
|
|
if (param_3 != 0.0f) {
|
|
pos.y = i_camera->mLookat.mCenter.y - i_camera->mLookat.mEye.y;
|
|
} else {
|
|
pos.y = 0.0f;
|
|
}
|
|
pos.z = i_camera->mLookat.mCenter.z - i_camera->mLookat.mEye.z;
|
|
|
|
vectle_calc(&pos, &tmp);
|
|
|
|
param_1->x = i_camera->mLookat.mEye.x + tmp.x * param_2;
|
|
param_1->y = i_camera->mLookat.mEye.y + tmp.y * param_3;
|
|
param_1->z = i_camera->mLookat.mEye.z + tmp.z * param_2;
|
|
|
|
if (param_3 == 0.0f) {
|
|
param_1->y = 0.0f;
|
|
}
|
|
}
|
|
|
|
static inline void dKyr_init_btitex(GXTexObj* i_obj, ResTIMG* i_img) {
|
|
GXInitTexObj(i_obj, (&i_img->format + i_img->imageOffset), i_img->width, i_img->height,
|
|
(GXTexFmt)i_img->format, (GXTexWrapMode)i_img->wrapS, (GXTexWrapMode)i_img->wrapT,
|
|
(GXBool)(i_img->mipmapCount > 1));
|
|
}
|
|
|
|
/* 8008AD60-8008AE54 .text dKyr_set_btitex__FP9_GXTexObjP7ResTIMG */
|
|
void dKyr_set_btitex(GXTexObj* i_obj, ResTIMG* i_img) {
|
|
GXInitTexObj(i_obj, (&i_img->format + i_img->imageOffset), i_img->width, i_img->height,
|
|
(GXTexFmt)i_img->format, (GXTexWrapMode)i_img->wrapS, (GXTexWrapMode)i_img->wrapT,
|
|
(GXBool)(i_img->mipmapCount > 1));
|
|
|
|
GXInitTexObjLOD(i_obj, (GXTexFilter)i_img->minFilter, (GXTexFilter)i_img->magFilter,
|
|
i_img->minLOD * 0.125f, i_img->maxLOD * 0.125f, i_img->LODBias * 0.01f,
|
|
(GXBool)i_img->biasClamp, (GXBool)i_img->doEdgeLOD,
|
|
(GXAnisotropy)i_img->maxAnisotropy);
|
|
|
|
GXLoadTexObj(i_obj, GX_TEXMAP0);
|
|
}
|
|
|
|
/* 8008AE54-8008B44C .text dKyr_kamome_move__Fv */
|
|
void dKyr_kamome_move() {
|
|
WINDEFF_SET* pWind = dKy_getEnvlight().mpWind;
|
|
camera_class* pCamera = (camera_class*)dComIfGp_getCamera(0);
|
|
|
|
dKyw_get_wind_vec();
|
|
|
|
cXyz newPos;
|
|
cXyz targetRot;
|
|
cXyz newTarget;
|
|
cXyz oldTarget;
|
|
|
|
BOOL spawnBirds = FALSE;
|
|
if (strcmp(dComIfGp_getStartStageName(), "sea") == 0) {
|
|
if ((g_env_light.mColpatCurr == 1 && g_env_light.mColPatBlend > 0.0f) ||
|
|
(g_env_light.mColpatPrev == 1 && g_env_light.mColPatBlend < 1.0f) ||
|
|
(g_env_light.mColpatCurr == 2 && g_env_light.mColPatBlend > 0.0f) ||
|
|
(g_env_light.mColpatPrev == 2 && g_env_light.mColPatBlend < 1.0f))
|
|
{
|
|
spawnBirds = FALSE;
|
|
} else {
|
|
spawnBirds = TRUE;
|
|
}
|
|
}
|
|
|
|
for (s32 i = 0; i < 2; i++) {
|
|
switch (pWind->mKamomeEff[i].mStatus) {
|
|
case 0:
|
|
if (spawnBirds) {
|
|
if (pWind->mKamomeEff[i].mTimer == 0) {
|
|
pWind->mKamomeEff[i].mAngleY = cM_rndFX(65535.0f);
|
|
pWind->mKamomeEff[i].mAngleX = cM_rndFX(65535.0f);
|
|
newPos.x = pCamera->mLookat.mEye.x + cM_ssin(pWind->mKamomeEff[i].mAngleY) * 7000.0f;
|
|
newPos.y = 4500.0f;
|
|
newPos.z = pCamera->mLookat.mEye.z + cM_scos(pWind->mKamomeEff[i].mAngleY) * 7000.0f;
|
|
pWind->mKamomeEff[i].mPos.set(newPos);
|
|
pWind->mKamomeEff[i].mAngleYSpeed = cM_rndFX(1.0f);
|
|
pWind->mKamomeEff[i].mScale = 0.0f;
|
|
pWind->mKamomeEff[i].mTimer = 300.0f + cM_rndF(180.0f);
|
|
pWind->mKamomeEff[i].mpEmitter = dComIfGp_particle_set(dPa_name::ID_COMMON_0429, &pWind->mKamomeEff[i].mPos);
|
|
pWind->mKamomeEff[i].mStatus++;
|
|
} else {
|
|
pWind->mKamomeEff[i].mTimer--;
|
|
}
|
|
}
|
|
break;
|
|
case 1:
|
|
if (pWind->mKamomeEff[i].mpEmitter != NULL) {
|
|
if (pWind->mKamomeEff[i].mAngleYSpeed >= 0.0f) {
|
|
pWind->mKamomeEff[i].mAngleYSpeed += cM_rndFX(1.0f);
|
|
if (pWind->mKamomeEff[i].mAngleYSpeed > 100.0f)
|
|
pWind->mKamomeEff[i].mAngleYSpeed = 100.0f;
|
|
if (pWind->mKamomeEff[i].mAngleYSpeed < 80.0f)
|
|
pWind->mKamomeEff[i].mAngleYSpeed = 80.0f;
|
|
} else {
|
|
pWind->mKamomeEff[i].mAngleYSpeed += cM_rndFX(1.0f);
|
|
if (pWind->mKamomeEff[i].mAngleYSpeed < -100.0f)
|
|
pWind->mKamomeEff[i].mAngleYSpeed = -100.0f;
|
|
if (pWind->mKamomeEff[i].mAngleYSpeed > -80.0f)
|
|
pWind->mKamomeEff[i].mAngleYSpeed = -80.0f;
|
|
}
|
|
|
|
oldTarget.x = cM_ssin(pWind->mKamomeEff[i].mAngleY) * 7000.0f;
|
|
oldTarget.y = std::fabsf(cM_ssin(pWind->mKamomeEff[i].mAngleX) * 3200.0f);
|
|
oldTarget.z = cM_scos(pWind->mKamomeEff[i].mAngleY) * 7000.0f;
|
|
|
|
pWind->mKamomeEff[i].mAngleY += pWind->mKamomeEff[i].mAngleYSpeed * pWind->mKamomeEff[i].mScale;
|
|
pWind->mKamomeEff[i].mAngleX += 15;
|
|
|
|
newTarget.x = cM_ssin(pWind->mKamomeEff[i].mAngleY) * 7000.0f;
|
|
newTarget.y = std::fabsf(cM_ssin(pWind->mKamomeEff[i].mAngleX) * 3200.0f);
|
|
newTarget.z = cM_scos(pWind->mKamomeEff[i].mAngleY) * 7000.0f;
|
|
|
|
newPos.x = pCamera->mLookat.mEye.x + newTarget.x;
|
|
newPos.y = newTarget.y + 4800.0f;
|
|
newPos.z = pCamera->mLookat.mEye.z + newTarget.z;
|
|
|
|
pWind->mKamomeEff[i].mPos.set(newPos);
|
|
pWind->mKamomeEff[i].mpEmitter->setGlobalTranslation(pWind->mKamomeEff[i].mPos);
|
|
|
|
if (pWind->mKamomeEff[i].mTimer != 0 && spawnBirds) {
|
|
cLib_addCalc(&pWind->mKamomeEff[i].mScale, 1.0f, 0.1f, 0.003f, 0.000001f);
|
|
pWind->mKamomeEff[i].mTimer--;
|
|
} else {
|
|
cLib_addCalc(&pWind->mKamomeEff[i].mScale, 0.0f, 0.1f, 0.003f, 0.000001f);
|
|
if (pWind->mKamomeEff[i].mScale < 0.001f)
|
|
pWind->mKamomeEff[i].mStatus++;
|
|
}
|
|
|
|
dKyr_get_vectle_calc(&oldTarget, &newTarget, &targetRot);
|
|
JGeometry::TVec3<s16> globalRot(0, 0, 0);
|
|
globalRot.y = (int)cM_atan2s(targetRot.x, targetRot.z);
|
|
pWind->mKamomeEff[i].mpEmitter->setGlobalRotation(globalRot);
|
|
}
|
|
break;
|
|
case 2:
|
|
pWind->mKamomeEff[i].mpEmitter->deleteAllParticle();
|
|
pWind->mKamomeEff[i].mpEmitter->becomeInvalidEmitter();
|
|
pWind->mKamomeEff[i].mpEmitter = NULL;
|
|
pWind->mKamomeEff[i].mStatus = 0;
|
|
pWind->mKamomeEff[i].mTimer = cM_rndF(600.0f) + 900.0f;
|
|
break;
|
|
}
|
|
|
|
if (pWind->mKamomeEff[i].mpEmitter != NULL) {
|
|
if (dComIfGd_getView() != NULL) {
|
|
f32 scale = dComIfGd_getView()->mFovy / 26.0f;
|
|
if (scale >= 1.0f)
|
|
scale = 1.0f;
|
|
|
|
scale = pWind->mKamomeEff[i].mScale * scale * 1.6f;
|
|
pWind->mKamomeEff[i].mpEmitter->setGlobalScale(JGeometry::TVec3<f32>(scale, scale, scale));
|
|
}
|
|
|
|
pWind->mKamomeEff[i].mpEmitter->setGlobalPrmColor(dKy_getEnvlight().mBG0_K0.r, dKy_getEnvlight().mBG0_K0.g, dKy_getEnvlight().mBG0_K0.b);
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 8008B44C-8008B504 .text dKyr_wind_init__Fv */
|
|
void dKyr_wind_init() {
|
|
g_env_light.mpWind->mbHasCustomWindPower = false;
|
|
g_env_light.mpWind->field_0x759 = 0;
|
|
|
|
for (int i = 0; i < 2; i++) {
|
|
g_env_light.mpWind->mKamomeEff[i].mStatus = 0;
|
|
g_env_light.mpWind->mKamomeEff[i].mScale = 0.0f;
|
|
g_env_light.mpWind->mKamomeEff[i].mTimer = cM_rndF(1800.0f);
|
|
g_env_light.mpWind->mKamomeEff[i].mpEmitter = NULL;
|
|
}
|
|
}
|
|
|
|
/* 8008B504-8008C4BC .text dKyr_wind_move__Fv */
|
|
void dKyr_wind_move() {
|
|
/* Nonmatching */
|
|
dScnKy_env_light_c& envLight = dKy_getEnvlight();
|
|
WINDEFF_SET* pWind = envLight.mpWind;
|
|
camera_class* pCamera = (camera_class*)dComIfGp_getCamera(0);
|
|
cXyz* pWindVec = dKyw_get_wind_vec();
|
|
f32 windPow = dKyw_get_wind_pow();
|
|
fopAc_ac_c* pPlayer = dComIfGp_getPlayer(0);
|
|
|
|
dBgS_ObjGndChk_All gndChk;
|
|
|
|
cXyz windVec = *pWindVec;
|
|
u32 particleNum = dComIfGp_particle_getParticleNum();
|
|
|
|
f32 fVar17 = 4000.0f;
|
|
f32 posRange = 2000.0f;
|
|
f32 fVar28 = 80.0f;
|
|
f32 posWindScale = 2500.0f;
|
|
f32 fVar25 = 250.0f;
|
|
f32 fVar18 = 800.0f;
|
|
f32 fVar23 = 1.0f;
|
|
f32 offsetY = 1000.0f;
|
|
|
|
s32 windlineCount = envLight.mWindlineCount;
|
|
if (dComIfGp_checkPlayerStatus1(0, daPyStts1_DEKU_LEAF_FLY_e)) {
|
|
windlineCount = 10;
|
|
}
|
|
|
|
bool customWindPowerChanged = false;
|
|
if (envLight.mWind.mCustomWindPower > 0.0f) {
|
|
windlineCount = 9;
|
|
fVar17 = 50.0f;
|
|
posWindScale = 160.0f;
|
|
fVar28 = 8.0f;
|
|
fVar18 = 150.0f;
|
|
offsetY = 200.0f;
|
|
fVar23 = 0.14f;
|
|
fVar25 = offsetY;
|
|
posRange = posWindScale;
|
|
|
|
if (!pWind->mbHasCustomWindPower) {
|
|
pWind->mbHasCustomWindPower = true;
|
|
customWindPowerChanged = true;
|
|
}
|
|
} else {
|
|
if (pWind->mbHasCustomWindPower) {
|
|
customWindPowerChanged = true;
|
|
pWind->mbHasCustomWindPower = false;
|
|
}
|
|
}
|
|
|
|
f32 fVar27 = 0.18f;
|
|
f32 fvar28 = 255.0f;
|
|
|
|
if (customWindPowerChanged) {
|
|
for (s32 i = 0; i < (s32)ARRAY_SIZE(pWind->mWindEff); i++) {
|
|
if (pWind->mWindEff[i].mpEmitter != NULL) {
|
|
pWind->mWindEff[i].mpEmitter->deleteAllParticle();
|
|
pWind->mWindEff[i].mpEmitter->becomeInvalidEmitter();
|
|
pWind->mWindEff[i].mpEmitter = NULL;
|
|
}
|
|
|
|
pWind->mWindEff[i].mState = 0;
|
|
}
|
|
}
|
|
|
|
cXyz pos;
|
|
dKy_set_eyevect_calc2(pCamera, &pos, fVar17, fVar17);
|
|
|
|
for (s32 i = 0; i < (s32)ARRAY_SIZE(pWind->mWindEff); i++) {
|
|
if (i >= windlineCount && pWind->mWindEff[i].mState == 0) {
|
|
if (pWind->mWindEff[i].mpEmitter != NULL) {
|
|
pWind->mWindEff[i].mpEmitter->deleteAllParticle();
|
|
pWind->mWindEff[i].mpEmitter->becomeInvalidEmitter();
|
|
pWind->mWindEff[i].mpEmitter = NULL;
|
|
}
|
|
continue;
|
|
}
|
|
|
|
WIND_EFF& windEff = pWind->mWindEff[i];
|
|
switch (windEff.mState) {
|
|
case 0:
|
|
if (windPow < 0.3f)
|
|
continue;
|
|
|
|
if (particleNum <= 1500 && (((g_Counter.mCounter0 >> 4 & 7) != (i & 3U)) || pWind->mbHasCustomWindPower)) {
|
|
windEff.mStateTimer = 0.0f;
|
|
windEff.mAlpha = 0.0f;
|
|
windEff.field_0x2c = 0;
|
|
|
|
if (pWind->mbHasCustomWindPower) {
|
|
windEff.mBasePos.set(pPlayer->current.pos);
|
|
} else {
|
|
windEff.mBasePos.set(pos);
|
|
}
|
|
|
|
windEff.mBasePos.y += offsetY;
|
|
|
|
windEff.mPos.x = cM_rndFX(posRange);
|
|
windEff.mPos.y = cM_rndFX(posRange);
|
|
windEff.mPos.z = cM_rndFX(posRange);
|
|
|
|
f32 windScale = posWindScale + posWindScale * cM_rndF(1.0f);
|
|
windEff.mPos.x -= windVec.x * windScale;
|
|
windEff.mPos.y -= windVec.y * windScale;
|
|
windEff.mPos.z -= windVec.z * windScale;
|
|
|
|
windEff.field_0x2c = cM_rndF(65535.0f);
|
|
|
|
cXyz pos;
|
|
pos.x = windEff.mBasePos.x + windEff.mPos.x;
|
|
pos.y = windEff.mBasePos.y + windEff.mPos.y;
|
|
pos.z = windEff.mBasePos.z + windEff.mPos.z;
|
|
|
|
if (pWind->mbHasCustomWindPower != TRUE) {
|
|
cXyz checkPos = pos;
|
|
checkPos.y += 10000.0f;
|
|
|
|
gndChk.SetPos(&checkPos);
|
|
|
|
f32 gndY = dComIfG_Bgsp()->GroundCross(&gndChk);
|
|
if (pos.y < gndY) {
|
|
windEff.mPos.y = (gndY + offsetY + cM_rndF(offsetY)) - windEff.mBasePos.y;
|
|
}
|
|
}
|
|
|
|
pos.x = windEff.mBasePos.x + windEff.mPos.x;
|
|
pos.y = windEff.mBasePos.y + windEff.mPos.y;
|
|
pos.z = windEff.mBasePos.z + windEff.mPos.z;
|
|
|
|
windEff.mpEmitter = dComIfGp_particle_set(dPa_name::ID_COMMON_0031, &pos);
|
|
if (windEff.mpEmitter != NULL) {
|
|
windEff.mpEmitter->setGlobalAlpha(0);
|
|
windEff.mpEmitter->setGlobalScale(JGeometry::TVec3<f32>(fVar23, fVar23, fVar23));
|
|
windEff.mState = 1;
|
|
}
|
|
|
|
f32 windVec_absXZ = std::sqrtf(windVec.x*windVec.x + windVec.z*windVec.z);
|
|
windEff.mAngleXZ = cM_atan2s(windVec.x, windVec.z);
|
|
windEff.mAngleY = cM_atan2s(windVec.y, windVec_absXZ);
|
|
|
|
windEff.field_0x28 = 0;
|
|
windEff.field_0x32 = cM_rndF(1.0f) >= 0.0f ? 1 : 0;
|
|
}
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
{
|
|
f32 fVar14 = fVar25 - fVar17 * (1.0f - windPow);
|
|
windEff.field_0x2c += fVar18; // mSwerveAnimCounter
|
|
if (i & 1) {
|
|
windEff.mAngleY += fVar14 * cM_ssin(windEff.field_0x2c);
|
|
windEff.mAngleXZ += fVar14 * cM_ssin(windEff.field_0x2c);
|
|
} else {
|
|
windEff.mAngleY += fVar14 * cM_ssin(windEff.field_0x2c);
|
|
windEff.mAngleXZ -= fVar14 * cM_ssin(windEff.field_0x2c);
|
|
}
|
|
|
|
if (windEff.mStateTimer > 0.4f && windEff.field_0x32 == 1) {
|
|
// do the loop-de-loop
|
|
windEff.field_0x28 += i * 200 + 3600;
|
|
windEff.mAngleY += i * 200 + 3600;
|
|
if (windEff.field_0x28 > 60535)
|
|
windEff.field_0x32 = 0;
|
|
} else {
|
|
f32 windVec_absXZ = std::sqrtf(windVec.x*windVec.x + windVec.z*windVec.z);
|
|
s16 targetAngleXZ = cM_atan2s(windVec.x, windVec.z);
|
|
s16 targetAngleY = cM_atan2s(windVec.y, windVec_absXZ);
|
|
cLib_addCalcAngleS(&windEff.mAngleY, targetAngleY, 10, 1000, 1);
|
|
cLib_addCalcAngleS(&windEff.mAngleXZ, targetAngleXZ, 10, 1000, 1);
|
|
}
|
|
|
|
cXyz move;
|
|
move.x = cM_scos(windEff.mAngleY) * cM_ssin(windEff.mAngleXZ);
|
|
move.y = cM_ssin(windEff.mAngleY);
|
|
move.z = cM_scos(windEff.mAngleY) * cM_scos(windEff.mAngleXZ);
|
|
|
|
fVar14 = fVar28 - (fVar28 * 0.2f) * (1.0f - windPow);
|
|
windEff.mPos.x += move.x * fVar14;
|
|
windEff.mPos.y += move.y * fVar14;
|
|
windEff.mPos.z += move.z * fVar14;
|
|
|
|
cXyz pos;
|
|
pos.x = windEff.mBasePos.x + windEff.mPos.x;
|
|
pos.y = windEff.mBasePos.y + windEff.mPos.y;
|
|
pos.z = windEff.mBasePos.z + windEff.mPos.z;
|
|
windEff.mpEmitter->setGlobalTranslation(pos);
|
|
|
|
// so much stuff is missing in here
|
|
|
|
fVar14 = fVar27 * (s32)(i / 30);
|
|
f32 distance = pos.getSquareDistance(pCamera->mLookat.mEye) / 200.0f;
|
|
if (distance > 1.0f) {
|
|
distance = 1.0f;
|
|
}
|
|
|
|
f32 fVar15 = 1.0f;
|
|
windEff.mpEmitter->setGlobalAlpha(fVar15 * 255.0f * windEff.mAlpha);
|
|
if (windEff.mState == 1) {
|
|
cLib_addCalc(&windEff.mStateTimer, 1.0f, 0.3f, fVar14 * 0.1f, 0.01f);
|
|
if (windEff.mStateTimer >= 1.0f)
|
|
windEff.mState = 2;
|
|
if (windEff.mStateTimer > 0.5f)
|
|
cLib_addCalc(&windEff.mAlpha, 1.0f, 0.5f, 0.05f, 0.001f);
|
|
} else {
|
|
cLib_addCalc(&windEff.mStateTimer, 0.0f, 0.4f, fVar14 * (i * 0.01f + 0.1f), 0.01f);
|
|
if (windEff.mStateTimer <= 0.0f) {
|
|
windEff.mpEmitter->deleteAllParticle();
|
|
windEff.mpEmitter->becomeInvalidEmitter();
|
|
windEff.mpEmitter = NULL;
|
|
windEff.mState = 0;
|
|
if (pWind->mbHasCustomWindPower == TRUE)
|
|
windEff.mState = 4;
|
|
}
|
|
if (windEff.mStateTimer < 0.5f)
|
|
cLib_addCalc(&windEff.mAlpha, 0.0f, 0.5f, 0.05f, 0.001f);
|
|
}
|
|
}
|
|
|
|
break;
|
|
case 3:
|
|
if (!pWind->mbHasCustomWindPower)
|
|
windEff.mState = 0;
|
|
break;
|
|
}
|
|
}
|
|
|
|
dKyr_kamome_move();
|
|
}
|
|
|
|
/* 8008C624-8008C888 .text dKyr_lenzflare_move__Fv */
|
|
void dKyr_lenzflare_move() {
|
|
dKankyo_sun_Packet* pSunPkt = g_env_light.mpSunPacket;
|
|
dKankyo_sunlenz_Packet* pLenzPkt = g_env_light.mpSunlenzPacket;
|
|
camera_class* pCamera = (camera_class*)dComIfGp_getCamera(0);
|
|
|
|
if (pSunPkt->mVisibility < 0.0001f)
|
|
return;
|
|
|
|
cXyz eyeVect;
|
|
cXyz sunDirSmth;
|
|
cXyz camFwd;
|
|
cXyz vectle;
|
|
cXyz projected;
|
|
cXyz center;
|
|
|
|
dKy_set_eyevect_calc(pCamera, &eyeVect, 7200.0005f, 7200.0005f);
|
|
|
|
dKyr_get_vectle_calc(&eyeVect, pSunPkt->mPos, &sunDirSmth);
|
|
pLenzPkt->mPositions[0] = pSunPkt->mPos[0];
|
|
pLenzPkt->mPositions[1] = pSunPkt->mPos[0];
|
|
|
|
mDoLib_project(pLenzPkt->mPositions, &projected);
|
|
|
|
center.x = 320.0f;
|
|
center.y = 240.0f;
|
|
center.z = 0.0f;
|
|
|
|
dKyr_get_vectle_calc(¢er, &projected, &vectle);
|
|
s16 angle = cM_atan2s(vectle.x, vectle.y);
|
|
|
|
pLenzPkt->mAngleDeg = angle;
|
|
pLenzPkt->mAngleDeg *= 0.005493164f;
|
|
pLenzPkt->mAngleDeg += 180.0f;
|
|
|
|
dKyr_get_vectle_calc(&pCamera->mLookat.mEye, &pCamera->mLookat.mCenter, &camFwd);
|
|
|
|
f32 size = sunDirSmth.abs(camFwd) * 350.0f + 250.0f;
|
|
|
|
for (int i = 2; i < 8; i++) {
|
|
pLenzPkt->mPositions[i].x = pSunPkt->mPos[0].x - sunDirSmth.x * size * i;
|
|
pLenzPkt->mPositions[i].y = pSunPkt->mPos[0].y - sunDirSmth.y * size * i;
|
|
pLenzPkt->mPositions[i].z = pSunPkt->mPos[0].z - sunDirSmth.z * size * i;
|
|
}
|
|
}
|
|
|
|
/* 8008C888-8008C8B8 .text dKyr_moon_arrival_check__Fv */
|
|
BOOL dKyr_moon_arrival_check() {
|
|
BOOL ret = false;
|
|
if (g_env_light.mCurTime > 277.5f || g_env_light.mCurTime < 112.5f)
|
|
ret = true;
|
|
return ret;
|
|
}
|
|
|
|
/* 8008C8B8-8008CF68 .text dKyr_sun_move__Fv */
|
|
void dKyr_sun_move() {
|
|
camera_class* pCamera;
|
|
dKankyo_sun_Packet* pSunPkt = dKy_getEnvlight().mpSunPacket;
|
|
dKankyo_sunlenz_Packet* pLenzPkt = dKy_getEnvlight().mpSunlenzPacket;
|
|
pCamera = (camera_class*)dComIfGp_getCamera(0);
|
|
|
|
f32 pulsePos;
|
|
f32 staringAtSunAmount = 0.0f;
|
|
u8 numPointsVisible = 0, numCenterPointsVisible = 0;
|
|
u32 stType = dStage_stagInfo_GetSTType(dComIfGp_getStageStagInfo());
|
|
cXyz lightDir;
|
|
if (dKy_getEnvlight().mBaseLightInfluence.mColor.r == 0 && stType != dStageType_MISC_e) {
|
|
dKyr_get_vectle_calc(&pCamera->mLookat.mEye, &dKy_getEnvlight().mBaseLightInfluence.mPos, &lightDir);
|
|
} else {
|
|
dKyr_get_vectle_calc(&pCamera->mLookat.mEye, &dKy_getEnvlight().mSunPos2, &lightDir);
|
|
}
|
|
|
|
pSunPkt->mPos[0].x = pCamera->mLookat.mEye.x + lightDir.x * 8000.0f;
|
|
pSunPkt->mPos[0].y = pCamera->mLookat.mEye.y + lightDir.y * 8000.0f;
|
|
pSunPkt->mPos[0].z = pCamera->mLookat.mEye.z + lightDir.z * 8000.0f;
|
|
|
|
f32 horizonY = (pSunPkt->mPos[0].y - pCamera->mLookat.mEye.y) / 8000.0f;
|
|
if (horizonY < 0.0f)
|
|
horizonY = 0.0f;
|
|
if (horizonY >= 1.0f)
|
|
horizonY = 1.0f;
|
|
horizonY = 1.0f - horizonY;
|
|
horizonY *= horizonY;
|
|
pulsePos = 1.0f - horizonY;
|
|
|
|
if (dComIfGp_getStageStagInfo() != NULL) {
|
|
dComIfGp_getStageStagInfo();
|
|
}
|
|
|
|
if (pSunPkt->field_0x3c != 0)
|
|
pSunPkt->field_0x3c--;
|
|
pSunPkt->field_0x3d = false;
|
|
|
|
if (dKy_getEnvlight().mCurTime > 97.5f && dKy_getEnvlight().mCurTime < 292.5f) {
|
|
f32 borderY = 0.0f;
|
|
s32 numPointsCulled = 0;
|
|
|
|
cLib_addCalc(&pSunPkt->mSunAlpha, 1.0f, 0.5f, 0.1f, 0.01f);
|
|
|
|
if (pCamera != NULL) {
|
|
borderY = pCamera->mCamera.mTrimHeight;
|
|
}
|
|
|
|
cXyz projected;
|
|
mDoLib_project(pSunPkt->mPos, &projected);
|
|
|
|
static const cXy sun_chkpnt[] = {
|
|
0.0f, 0.0f,
|
|
-10.0f, -20.0f,
|
|
10.0f, 20.0f,
|
|
-20.0f, 10.0f,
|
|
20.0f, -10.0f,
|
|
};
|
|
|
|
for (s32 i = 0; i < 5; i++) {
|
|
f32 screenBottom = 490.0f - borderY;
|
|
cXyz chkpnt = projected;
|
|
chkpnt.x -= sun_chkpnt[i].x;
|
|
chkpnt.y -= sun_chkpnt[i].y;
|
|
|
|
if (chkpnt.x > 0.0f && chkpnt.x < 640.0 && chkpnt.y > borderY && chkpnt.y < screenBottom) {
|
|
if (pSunPkt->mVizChkData[i] >= 0xFFFFFF) {
|
|
numPointsVisible++;
|
|
if (i == 0)
|
|
numCenterPointsVisible++;
|
|
}
|
|
|
|
dComIfGd_peekZ(chkpnt.x, chkpnt.y, &pSunPkt->mVizChkData[i]);
|
|
} else {
|
|
numPointsCulled++;
|
|
}
|
|
}
|
|
|
|
if (numPointsCulled != 0 && numPointsVisible != 0 && numCenterPointsVisible != 0) {
|
|
numCenterPointsVisible = 1;
|
|
numPointsVisible = 5;
|
|
}
|
|
|
|
if (numPointsVisible != 0) {
|
|
if (pSunPkt->field_0x3c < 5)
|
|
pSunPkt->field_0x3c += 2;
|
|
pSunPkt->field_0x3d = true;
|
|
}
|
|
|
|
pLenzPkt->field_0x80 = pLenzPkt->field_0x88;
|
|
pLenzPkt->field_0x84 = pLenzPkt->field_0x8c;
|
|
pLenzPkt->field_0x88 = 1000000000.0f;
|
|
pLenzPkt->field_0x8c = 0.0f;
|
|
|
|
cXyz center;
|
|
center.x = 320.0f;
|
|
center.y = 240.0f;
|
|
center.z = 0.0f;
|
|
pLenzPkt->mDistFalloff = center.abs(projected);
|
|
pLenzPkt->mDistFalloff /= 450.0f;
|
|
if (pLenzPkt->mDistFalloff > 1.0f)
|
|
pLenzPkt->mDistFalloff = 1.0f;
|
|
pLenzPkt->mDistFalloff = 1.0f - pLenzPkt->mDistFalloff;
|
|
staringAtSunAmount = (pLenzPkt->mDistFalloff * pLenzPkt->mDistFalloff);
|
|
pLenzPkt->mDistFalloff = 1.0f - staringAtSunAmount;
|
|
staringAtSunAmount = staringAtSunAmount * staringAtSunAmount;
|
|
} else {
|
|
cLib_addCalc(&pSunPkt->mSunAlpha, 0.0f, 0.5f, 0.1f, 0.01f);
|
|
numPointsVisible = 0;
|
|
pSunPkt->field_0x3c = 0;
|
|
pSunPkt->field_0x3d = false;
|
|
}
|
|
|
|
if (dKy_getEnvlight().mColpatWeather != 0 || (dKy_getEnvlight().mColpatCurr != 0 && dKy_getEnvlight().mColPatBlend > 0.5f)) {
|
|
numCenterPointsVisible = 0;
|
|
numPointsVisible = 0;
|
|
}
|
|
|
|
if (stType == dStageType_MISC_e) {
|
|
numCenterPointsVisible = 0;
|
|
numPointsVisible = 0;
|
|
}
|
|
|
|
if (dKy_getEnvlight().mCurTime < 120.0f || dKy_getEnvlight().mCurTime > 270.0f) {
|
|
numCenterPointsVisible = 0;
|
|
numPointsVisible = 0;
|
|
}
|
|
|
|
if (numCenterPointsVisible != 0) {
|
|
if (numPointsVisible == 4)
|
|
cLib_addCalc(&pSunPkt->mVisibility, 1.0f, 0.1f, 0.1f, 0.001f);
|
|
if (numPointsVisible <= 3)
|
|
cLib_addCalc(&pSunPkt->mVisibility, 0.0f, 0.1f, 0.2f, 0.001f);
|
|
else
|
|
cLib_addCalc(&pSunPkt->mVisibility, 1.0f, 0.5f, 0.2f, 0.01f);
|
|
} else {
|
|
if (numPointsVisible < 3)
|
|
cLib_addCalc(&pSunPkt->mVisibility, 0.0f, 0.5f, 0.2f, 0.001f);
|
|
else
|
|
cLib_addCalc(&pSunPkt->mVisibility, 1.0f, 0.1f, 0.1f, 0.001f);
|
|
}
|
|
|
|
if (numPointsVisible >= 2) {
|
|
dKy_getEnvlight().mpSunlenzPacket->mbDrawLenzInSky = false;
|
|
} else {
|
|
dKy_getEnvlight().mpSunlenzPacket->mbDrawLenzInSky = true;
|
|
}
|
|
|
|
if (pSunPkt->mPos[0].y > 0.0f && !dKy_getEnvlight().mpSunlenzPacket->mbDrawLenzInSky) {
|
|
dKy_set_actcol_ratio(1.0f - staringAtSunAmount * pSunPkt->mVisibility);
|
|
dKy_set_bgcol_ratio(1.0f - staringAtSunAmount * pSunPkt->mVisibility);
|
|
dKy_set_fogcol_ratio(staringAtSunAmount * pSunPkt->mVisibility * pulsePos * 0.5f + 1.0f);
|
|
dKy_set_vrboxcol_ratio(staringAtSunAmount * pSunPkt->mVisibility * pulsePos * 0.5f + 1.0f);
|
|
}
|
|
|
|
if (dKyr_moon_arrival_check()) {
|
|
f32 alpha = (pSunPkt->mPos[0].y - pCamera->mLookat.mEye.y) / -8000.0f;
|
|
alpha *= alpha;
|
|
alpha *= 6.0f;
|
|
if (alpha > 1.0f)
|
|
alpha = 1.0f;
|
|
cLib_addCalc(&pSunPkt->mMoonAlpha, alpha, 0.2f, 0.01f, 0.001f);
|
|
} else {
|
|
cLib_addCalc(&pSunPkt->mMoonAlpha, 0.0f, 0.2f, 0.01f, 0.001f);
|
|
}
|
|
}
|
|
|
|
/* 8008CF68-8008D0B4 .text dKyr_rain_init__Fv */
|
|
void dKyr_rain_init() {
|
|
camera_class * pCamera = (camera_class*)dComIfGp_getCamera(0);
|
|
g_env_light.mpRainPacket->mpTxSnow01 = (u8*)dComIfG_getObjectRes("Always", ALWAYS_I8_TX_SNOW01);
|
|
g_env_light.mpRainPacket->mpTxRingAHalf = (u8*)dComIfG_getObjectRes("Always", ALWAYS_BTI_TXA_RING_A_32HAFE);
|
|
g_env_light.mpRainPacket->mCamEyePos = pCamera->mLookat.mEye;
|
|
g_env_light.mpRainPacket->mCamCenterPos = pCamera->mLookat.mCenter;
|
|
g_env_light.mpRainPacket->mCenterDeltaMul = 0.0f;
|
|
g_env_light.mpRainPacket->field_0x3700 = 0.0f;
|
|
g_env_light.mpRainPacket->mSibukiAlpha = 0.0f;
|
|
g_env_light.mpRainPacket->mOverheadFade = 0.0f;
|
|
g_env_light.mpRainPacket->mFwd1Fade = 0.0f;
|
|
g_env_light.mpRainPacket->mFwdFade2 = 0.0f;
|
|
g_env_light.mpRainPacket->mStatus = 0;
|
|
g_env_light.mpRainPacket->mCenterDelta.x = 0.0f;
|
|
g_env_light.mpRainPacket->mCenterDelta.y = 0.0f;
|
|
g_env_light.mpRainPacket->mCenterDelta.z = 0.0f;
|
|
for (u32 i = 0; i < ARRAY_SIZE(g_env_light.mpRainPacket->mEff); i++)
|
|
g_env_light.mpRainPacket->mEff[i].mStatus = 0;
|
|
g_env_light.mpRainPacket->mRainCount = 0;
|
|
}
|
|
|
|
/* 8008D0B4-8008D0DC .text rain_bg_chk__FP19dKankyo_rain_Packeti */
|
|
void rain_bg_chk(dKankyo_rain_Packet* pPkt, int idx) {
|
|
pPkt->mEff[idx].field_0x30 = dComIfGp_getCamera(0)->mLookat.mCenter.y + -800.0f;
|
|
}
|
|
|
|
/* 8008D0DC-8008D53C .text overhead_bg_chk__Fv */
|
|
bool overhead_bg_chk() {
|
|
camera_class* pCamera = (camera_class*)dComIfGp_getCamera(0);
|
|
bool ret = false;
|
|
|
|
dBgS_ObjGndChk_All gndChk;
|
|
dBgS_RoofChk roofChk;
|
|
cXyz pos = pCamera->mLookat.mEye;
|
|
pos.y += 50.0f;
|
|
roofChk.SetPos(pos);
|
|
|
|
if (dComIfG_Bgsp()->RoofChk(&roofChk) != C_BG_MAX_HEIGHT)
|
|
ret = true;
|
|
pos.y += 10000.0f;
|
|
gndChk.SetPos(&pos);
|
|
|
|
if (dComIfG_Bgsp()->GroundCross(&gndChk) > (pCamera->mLookat.mEye.y + 50.0f))
|
|
ret = true;
|
|
|
|
return ret;
|
|
}
|
|
|
|
/* 8008D638-8008DAF0 .text forward_overhead_bg_chk__FP4cXyzf */
|
|
bool forward_overhead_bg_chk(cXyz* pPos, f32 dist) {
|
|
camera_class* pCamera = (camera_class*)dComIfGp_getCamera(0);
|
|
bool ret = false;
|
|
|
|
dBgS_ObjGndChk_All gndChk;
|
|
dBgS_RoofChk roofChk;
|
|
cXyz pos;
|
|
cXyz lookDir;
|
|
dKyr_get_vectle_calc(&pCamera->mLookat.mEye, &pCamera->mLookat.mCenter, &lookDir);
|
|
pos.x = pCamera->mLookat.mEye.x + lookDir.x * dist;
|
|
pos.y = pCamera->mLookat.mEye.y + lookDir.y * dist;
|
|
pos.z = pCamera->mLookat.mEye.z + lookDir.z * dist;
|
|
pos.y = pCamera->mLookat.mEye.y + 50.f;
|
|
|
|
*pPos = pos;
|
|
roofChk.SetPos(pos);
|
|
|
|
if (dComIfG_Bgsp()->RoofChk(&roofChk) != C_BG_MAX_HEIGHT)
|
|
ret = true;
|
|
pos.y += 10000.0f;
|
|
gndChk.SetPos(&pos);
|
|
|
|
if (dComIfG_Bgsp()->GroundCross(&gndChk) > (pCamera->mLookat.mEye.y + 50.0f))
|
|
ret = true;
|
|
|
|
return ret;
|
|
}
|
|
|
|
/* 8008DAF0-8008E79C .text dKyr_rain_move__Fv */
|
|
void dKyr_rain_move() {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 8008E79C-8008F0BC .text dKyr_housi_move__Fv */
|
|
void dKyr_housi_move() {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 8008F0BC-8008F23C .text dKyr_snow_init__Fv */
|
|
void dKyr_snow_init() {
|
|
camera_class* pCamera = (camera_class*)dComIfGp_getCamera(0);
|
|
g_env_light.mpSnowPacket = new(0x20) dKankyo_snow_Packet();
|
|
if (g_env_light.mpSnowPacket != NULL) {
|
|
if (strcmp(dComIfGp_getStartStageName(), "Adanmae") != 0) {
|
|
g_env_light.mpSnowPacket->mpTexture = (u8*)dComIfG_getObjectRes("Always", ALWAYS_I8_TX_SNOW01);
|
|
} else {
|
|
g_env_light.mpSnowPacket->mpTexture = (u8*)dComIfG_getStageRes("Stage", "ak_kazanbai00.bti");
|
|
}
|
|
|
|
for (u32 i = 0; i < ARRAY_SIZE(g_env_light.mpSnowPacket->mEff); i++)
|
|
g_env_light.mpSnowPacket->mEff[i].mStatus = 0;
|
|
g_env_light.mpSnowPacket->mEffCount = 0;
|
|
g_env_light.mpSnowPacket->mOldEyePos = pCamera->mLookat.mEye;
|
|
}
|
|
}
|
|
|
|
/* 8008F23C-8008F9FC .text dKyr_snow_move__Fv */
|
|
void dKyr_snow_move() {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 8008F9FC-8009065C .text dKyr_kazanbai_move__Fv */
|
|
void dKyr_kazanbai_move() {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 8009065C-80090C68 .text dKyr_kazanbai_tamari_move__Fv */
|
|
void dKyr_kazanbai_tamari_move() {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 80090C68-80090D50 .text dKyr_star_init__Fv */
|
|
void dKyr_star_init() {
|
|
g_env_light.mpStarPacket = new(0x20) dKankyo_star_Packet();
|
|
if (g_env_light.mpStarPacket != NULL) {
|
|
g_env_light.mpStarPacket->mpTexture = (u8*)dComIfG_getObjectRes("Always", ALWAYS_I8_TX_SNOW01);
|
|
g_env_light.mpStarPacket->mStarEff[0].mSin = 1.0f;
|
|
g_env_light.mpStarPacket->mCount = 0;
|
|
}
|
|
}
|
|
|
|
/* 80090D50-80090DE0 .text dKyr_star_move__Fv */
|
|
void dKyr_star_move() {
|
|
dKankyo_star_Packet* pPkt = g_env_light.mpStarPacket;
|
|
pPkt->mCount = g_env_light.mStarCount;
|
|
if (pPkt->mCount != 0) {
|
|
f32 wave = std::fabsf(cM_fsin(pPkt->mStarEff[0].mAnimCounter));
|
|
pPkt->mStarEff[0].mAnimCounter += 0.01f;
|
|
pPkt->mStarEff[0].mSin = wave;
|
|
cLib_addCalc(&pPkt->mStarEff[0].mSin, wave, 0.5f, 0.1f, 0.01f);
|
|
}
|
|
}
|
|
|
|
/* 80090DE0-80091964 .text wave_move__Fv */
|
|
void wave_move() {
|
|
/* Nonmatching */
|
|
dScnKy_env_light_c& envLight = dKy_getEnvlight();
|
|
dStage_FileList_dt_c* fili_p;
|
|
fopAc_ac_c* pPlayer;
|
|
cXyz* windVecP;
|
|
dKankyo_wave_Packet* pPkt;
|
|
camera_class* pCamera;
|
|
f32 seaLevel;
|
|
cXyz newPos2;
|
|
cXyz eyevect;
|
|
cXyz d0;
|
|
cXyz newPos3;
|
|
cXyz windPowVec2;
|
|
cXyz windPowVec;
|
|
cXyz windNrmVec2;
|
|
cXyz vectle;
|
|
cXyz pos;
|
|
cXyz newPos;
|
|
DOUBLE_POS deltaXZ;
|
|
Mtx drawMtx;
|
|
s32 roomNo;
|
|
f32 windPow;
|
|
s32 stageWindY;
|
|
s16 windX;
|
|
s16 windY;
|
|
|
|
windPowVec = dKyw_get_wind_vecpow();
|
|
|
|
fili_p = NULL;
|
|
pPkt = g_env_light.mpWavePacket;
|
|
pCamera = (camera_class*)dComIfGp_getCamera(0);
|
|
pPlayer = dComIfGp_getPlayer(0);
|
|
|
|
roomNo = dComIfGp_roomControl_getStayNo();
|
|
if (roomNo >= 0)
|
|
fili_p = dComIfGp_roomControl_getStatusRoomDt(roomNo)->getFileListInfo();
|
|
|
|
if (fili_p != NULL)
|
|
seaLevel = dStage_FileList_dt_SeaLevel(fili_p);
|
|
|
|
if (g_env_light.mWaveChan.mWaveFlatInter >= 1.0f)
|
|
return;
|
|
|
|
if (dComIfGd_getView() != NULL) {
|
|
MTXInverse(dComIfGd_getViewRotMtx(), drawMtx);
|
|
} else {
|
|
return;
|
|
}
|
|
|
|
dKy_set_eyevect_calc2(pCamera, &eyevect, g_env_light.mWaveChan.mWaveSpawnDist, 0.0f);
|
|
d0.zero();
|
|
|
|
windVecP = dKyw_get_wind_vec();
|
|
windPow = dKyw_get_wind_pow();
|
|
windPowVec2 = *windVecP;
|
|
|
|
if (dStage_stagInfo_GetSTType(dComIfGp_getStageStagInfo()) == dStageType_MISC_e) {
|
|
stageWindY = 0;
|
|
|
|
if (strcmp(dComIfGp_getStartStageName(), "LinkRM") == 0)
|
|
stageWindY = 0x4000;
|
|
else if (strcmp(dComIfGp_getStartStageName(), "Orichh") == 0)
|
|
stageWindY = -0x4000;
|
|
else if (strcmp(dComIfGp_getStartStageName(), "Ojhous2") == 0)
|
|
stageWindY = 0x7fff;
|
|
else if (strcmp(dComIfGp_getStartStageName(), "Omasao") == 0)
|
|
stageWindY = -0x4000;
|
|
else if (strcmp(dComIfGp_getStartStageName(), "Onobuta") == 0)
|
|
stageWindY = 0x4000;
|
|
|
|
if (dComIfGs_getWindX() == -1 && dComIfGs_getWindY() == -1) {
|
|
windX = 0;
|
|
windY = 0;
|
|
} else {
|
|
windX = g_env_light.mWind.mTactWindAngleX;
|
|
windY = g_env_light.mWind.mTactWindAngleY;
|
|
}
|
|
|
|
windY += stageWindY;
|
|
|
|
windNrmVec2.x = cM_scos(windX) * cM_scos(windY);
|
|
windNrmVec2.y = cM_ssin(windX);
|
|
windNrmVec2.z = cM_scos(windX) * cM_ssin(windY);
|
|
|
|
windPowVec.x = 0.6f * windNrmVec2.x;
|
|
windPowVec.y = 0.6f * windNrmVec2.y;
|
|
windPowVec.z = 0.6f * windNrmVec2.z;
|
|
windPowVec2 = windPowVec;
|
|
windPow = 0.6f;
|
|
}
|
|
|
|
d0.zero();
|
|
|
|
deltaXZ.x = pCamera->mLookat.mCenter.x - pCamera->mLookat.mEye.x;
|
|
deltaXZ.y = 0.0f;
|
|
deltaXZ.z = pCamera->mLookat.mCenter.z - pCamera->mLookat.mEye.z;
|
|
vectle_calc(&deltaXZ, &vectle);
|
|
|
|
pPkt->mSkewDir = cM3d_VectorProduct2d(0.0f, 0.0f, -windPowVec2.x, -windPowVec2.z, vectle.x, vectle.z);
|
|
pPkt->mSkewWidth = windPow * (1.0f - std::fabsf(windPowVec2.y)) * (1.0f - std::fabsf(windPowVec2.x * vectle.x + windPowVec2.z * vectle.z));
|
|
pPkt->mSkewWidth *= 0.6f * std::fabsf(pPkt->mSkewDir);
|
|
|
|
for (s32 i = 0; i < g_env_light.mWaveChan.mWaveCount; i++) {
|
|
if (g_env_light.mWaveChan.mWaveReset)
|
|
pPkt->mEff[i].mStatus = 0;
|
|
|
|
switch (pPkt->mEff[i].mStatus) {
|
|
case 0:
|
|
{
|
|
pPkt->mEff[i].mBasePos.x = eyevect.x;
|
|
pPkt->mEff[i].mBasePos.y = seaLevel;
|
|
pPkt->mEff[i].mBasePos.z = eyevect.z;
|
|
pPkt->mEff[i].mPos.x = cM_rndFX(g_env_light.mWaveChan.mWaveSpawnRadius);
|
|
pPkt->mEff[i].mPos.y = 0.0f;
|
|
pPkt->mEff[i].mPos.z = cM_rndFX(g_env_light.mWaveChan.mWaveSpawnRadius);
|
|
pPkt->mEff[i].mCounter = cM_rndF(65536.0f);
|
|
pPkt->mEff[i].mAlpha = 0.0f;
|
|
pPkt->mEff[i].field_0x32 = cM_rndF(65536.0f);
|
|
pPkt->mEff[i].mStrengthEnv = 1.0f;
|
|
pPkt->mEff[i].mScale = g_env_light.mWaveChan.mWaveScaleRand + cM_rndF(1.0f - g_env_light.mWaveChan.mWaveScaleRand);
|
|
pPkt->mEff[i].mSpeed = pPkt->mEff[i].mScale;
|
|
pPkt->mEff[i].mCounterSpeed = ((1.0f - pPkt->mEff[i].mScale) * 0.05f + 0.02f) * g_env_light.mWaveChan.mWaveCounterSpeedScale;
|
|
pPkt->mEff[i].field_0x30 = 0;
|
|
pPkt->mEff[i].mStatus++;
|
|
}
|
|
// fallthrough
|
|
case 1:
|
|
case 2:
|
|
{
|
|
pPkt->mEff[i].mPos.x += (windPowVec.x * g_env_light.mWaveChan.mWaveSpeed * pPkt->mEff[i].mSpeed) * (pPkt->mEff[i].mStrengthEnv * 0.5f + 0.5f) * (pPkt->mEff[i].mAlpha * 0.8f + 0.2f);
|
|
pPkt->mEff[i].mPos.z += (windPowVec.z * g_env_light.mWaveChan.mWaveSpeed * pPkt->mEff[i].mSpeed) * (pPkt->mEff[i].mStrengthEnv * 0.5f + 0.5f) * (pPkt->mEff[i].mAlpha * 0.8f + 0.2f);
|
|
pPkt->mEff[i].mCounter += pPkt->mEff[i].mCounterSpeed;
|
|
pos.x = pPkt->mEff[i].mBasePos.x + pPkt->mEff[i].mPos.x;
|
|
pos.y = pPkt->mEff[i].mBasePos.y + pPkt->mEff[i].mPos.y;
|
|
pos.z = pPkt->mEff[i].mBasePos.z + pPkt->mEff[i].mPos.z;
|
|
if (pos.abs(eyevect) > g_env_light.mWaveChan.mWaveSpawnRadius) {
|
|
pPkt->mEff[i].mBasePos.x = eyevect.x;
|
|
pPkt->mEff[i].mBasePos.z = eyevect.z;
|
|
if (pos.abs(eyevect) > (g_env_light.mWaveChan.mWaveSpawnRadius + 350.0f)) {
|
|
pPkt->mEff[i].mPos.x = cM_rndFX(g_env_light.mWaveChan.mWaveSpawnRadius);
|
|
pPkt->mEff[i].mPos.z = cM_rndFX(g_env_light.mWaveChan.mWaveSpawnRadius);
|
|
} else {
|
|
get_vectle_calc(&pos, &eyevect, &newPos);
|
|
pPkt->mEff[i].mPos.x = newPos.x * g_env_light.mWaveChan.mWaveSpawnRadius;
|
|
pPkt->mEff[i].mPos.z = newPos.z * g_env_light.mWaveChan.mWaveSpawnRadius;
|
|
}
|
|
pPkt->mEff[i].mAlpha = 0.0f;
|
|
}
|
|
pos.x = pPkt->mEff[i].mBasePos.x + pPkt->mEff[i].mPos.x;
|
|
pos.y = pPkt->mEff[i].mBasePos.y + pPkt->mEff[i].mPos.y;
|
|
pos.z = pPkt->mEff[i].mBasePos.z + pPkt->mEff[i].mPos.z;
|
|
|
|
pPkt->mEff[i].mStrengthEnv = 1.0f;
|
|
for (s32 j = 0; j < 10; j++) {
|
|
if (envLight.mpWaveInfl[j] == NULL)
|
|
continue;
|
|
|
|
envLight.mpWaveInfl[j]->mPos.y = pos.y;
|
|
f32 dist = pos.abs(envLight.mpWaveInfl[j]->mPos);
|
|
f32 outerRadius = envLight.mpWaveInfl[j]->mOuterRadius;
|
|
f32 innerRadius = envLight.mpWaveInfl[j]->mInnerRadius;
|
|
if (dist < outerRadius) {
|
|
if (dist < innerRadius) {
|
|
pPkt->mEff[i].mStrengthEnv = 0.0f;
|
|
break;
|
|
}
|
|
|
|
f32 range = outerRadius - innerRadius;
|
|
if (range > 0.0f) {
|
|
if (pPkt->mEff[i].mStrengthEnv > (dist - innerRadius) / range)
|
|
pPkt->mEff[i].mStrengthEnv = (dist - innerRadius) / range;
|
|
} else {
|
|
pPkt->mEff[i].mStrengthEnv = 0.0f;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (g_env_light.mWaveChan.mWaveFlatInter > 0.0f) {
|
|
newPos3 = pCamera->mLookat.mEye;
|
|
newPos3.y = pos.y;
|
|
|
|
f32 dist = pos.abs(newPos3);
|
|
f32 innerRadius = g_env_light.mWaveChan.mWaveFlatInter * (g_env_light.mWaveChan.mWaveSpawnRadius * 1.5f);
|
|
f32 outerRadius = innerRadius + 1000.0f;
|
|
f32 range = outerRadius - innerRadius;
|
|
if (range > 0.0f) {
|
|
if (pPkt->mEff[i].mStrengthEnv > (dist - innerRadius) / range)
|
|
pPkt->mEff[i].mStrengthEnv = (dist - innerRadius) / range;
|
|
} else {
|
|
pPkt->mEff[i].mStrengthEnv = 0.0f;
|
|
}
|
|
}
|
|
|
|
{
|
|
newPos3 = pPlayer->current.pos;
|
|
newPos3.y = pos.y;
|
|
|
|
f32 dist = pos.abs(newPos3);
|
|
f32 innerRadius = 200.0f;
|
|
f32 outerRadius = 2000.0f;
|
|
f32 range = outerRadius - innerRadius;
|
|
if (dist < outerRadius) {
|
|
if (innerRadius < dist) {
|
|
pPkt->mEff[i].mStrengthEnv = 0.0f;
|
|
} else {
|
|
f32 fade = (dist - innerRadius) / range;
|
|
pPkt->mEff[i].mStrengthEnv *= fade;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
break;
|
|
case 3:
|
|
{
|
|
pPkt->mEff[i].mStatus = 0;
|
|
}
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
{
|
|
newPos2.x = pPkt->mEff[i].mBasePos.x + pPkt->mEff[i].mPos.x;
|
|
newPos2.y = pPkt->mEff[i].mBasePos.y + pPkt->mEff[i].mPos.y;
|
|
newPos2.z = pPkt->mEff[i].mBasePos.z + pPkt->mEff[i].mPos.z;
|
|
f32 dist = newPos2.abs(pCamera->mLookat.mEye);
|
|
if (dist < 0.0f)
|
|
dist = 0.0f;
|
|
f32 alphaTarget = 1.0f - (dist / (2.0f * g_env_light.mWaveChan.mWaveSpawnDist));
|
|
alphaTarget *= 1.03f;
|
|
alphaTarget *= (f32)sin(pPkt->mEff[i].mCounter);
|
|
if (alphaTarget > 1.0f)
|
|
alphaTarget = 1.0f;
|
|
if (alphaTarget < 0.0f)
|
|
alphaTarget = 0.0f;
|
|
cLib_addCalc(&pPkt->mEff[i].mAlpha, alphaTarget, 0.5f, 0.5f, 0.001f);
|
|
pPkt->mEff[i].mBasePos.y = seaLevel;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 80091964-80092294 .text cloud_shadow_move__Fv */
|
|
void cloud_shadow_move() {
|
|
/* Nonmatching */
|
|
dKankyo_cloud_Packet* pPkt = dKy_getEnvlight().mpMoyaPacket;
|
|
camera_class* pCamera = (camera_class*)dComIfGp_getCamera(0);
|
|
Mtx camMtx;
|
|
cXyz windVecPow = dKyw_get_wind_vecpow();
|
|
cXyz center;
|
|
cXyz pos;
|
|
cXyz pntwind;
|
|
cXyz velRndm;
|
|
|
|
if (dComIfGd_getView() != NULL) {
|
|
MTXInverse(dComIfGd_getViewRotMtx(), camMtx);
|
|
} else {
|
|
return;
|
|
}
|
|
|
|
if (pPkt->mCount <= dKy_getEnvlight().mMoyaCount)
|
|
pPkt->mCount = dKy_getEnvlight().mMoyaCount;
|
|
|
|
if (pPkt->mCount == 0)
|
|
return;
|
|
|
|
dKy_set_eyevect_calc2(pCamera, ¢er, 1500.0f, 1500.0f);
|
|
|
|
for (s32 i = 0; i < pPkt->mCount; i++) {
|
|
switch (pPkt->mEff[i].mStatus) {
|
|
case 0:
|
|
pPkt->mEff[i].mInitialSize = 400.0f + cM_rndFX(80.0f);
|
|
pPkt->mEff[i].mSize = pPkt->mEff[i].mInitialSize;
|
|
pPkt->mEff[i].mBasePos.set(center);
|
|
pPkt->mEff[i].mPos.x = cM_rndFX(2000.0f);
|
|
pPkt->mEff[i].mPos.y = cM_rndFX(2000.0f);
|
|
pPkt->mEff[i].mPos.z = cM_rndFX(2000.0f);
|
|
pPkt->mEff[i].mWindSpeed = 0.7f + cM_rndF(0.3f);
|
|
pPkt->mEff[i].mAlpha = 0.0;
|
|
pPkt->mEff[i].mAnimCounter = cM_rndF(65535.0f);
|
|
pPkt->mEff[i].mVelRndm.x = cM_rndFX(360.0f);
|
|
pPkt->mEff[i].mVelRndm.y = cM_rndFX(360.0f);
|
|
pPkt->mEff[i].mVelRndm.z = cM_rndFX(360.0f);
|
|
pPkt->mEff[i].mPntWindVel.x = 0.0f;
|
|
pPkt->mEff[i].mPntWindVel.y = 0.0f;
|
|
pPkt->mEff[i].mPntWindVel.z = 0.0f;
|
|
pPkt->mEff[i].mStatus++;
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
{
|
|
pos.x = pPkt->mEff[i].mBasePos.x + pPkt->mEff[i].mPos.x;
|
|
pos.y = pPkt->mEff[i].mBasePos.y + pPkt->mEff[i].mPos.y;
|
|
pos.z = pPkt->mEff[i].mBasePos.z + pPkt->mEff[i].mPos.z;
|
|
pPkt->mEff[i].mAnimCounter += 120;
|
|
cLib_chaseF(&pPkt->mEff[i].field_0x34, pPkt->mEff[i].mWindSpeed, 7.0f);
|
|
if (dKy_getEnvlight().mMoyaMode & 1) {
|
|
if (strcmp(dComIfGp_getStartStageName(), "M_DragB") != 0 || dKy_getEnvlight().mbVrboxInvisible) {
|
|
if (dKy_getEnvlight().mMoyaMode == 1) {
|
|
pPkt->mEff[i].mPos.y += 20.0f;
|
|
}
|
|
} else {
|
|
pPkt->mEff[i].mPos.y += 5.0f;
|
|
}
|
|
}
|
|
|
|
f32 speed;
|
|
if (dKy_getEnvlight().mMoyaMode == 1) {
|
|
speed = 10.0f;
|
|
} else {
|
|
speed = 40.0f;
|
|
}
|
|
|
|
pPkt->mEff[i].mPos.x += windVecPow.x * speed * pPkt->mEff[i].mWindSpeed;
|
|
pPkt->mEff[i].mPos.y += windVecPow.y * speed * pPkt->mEff[i].mWindSpeed;
|
|
pPkt->mEff[i].mPos.z += windVecPow.z * speed * pPkt->mEff[i].mWindSpeed;
|
|
pntwind = dKyw_pntwind_get_vecpow(&pos);
|
|
if (pPkt->mEff[i].mPntWindVel.x < 30.0f)
|
|
pPkt->mEff[i].mPntWindVel.x += pntwind.x * 9.0f;
|
|
if (pPkt->mEff[i].mPntWindVel.y < 30.0f)
|
|
pPkt->mEff[i].mPntWindVel.y += pntwind.y * 9.0f;
|
|
if (pPkt->mEff[i].mPntWindVel.z < 30.0f)
|
|
pPkt->mEff[i].mPntWindVel.z += pntwind.z * 9.0f;
|
|
|
|
cLib_addCalc(&pPkt->mEff[i].mPntWindVel.x, 0.0f, 0.2f, 0.1f, 0.00001f);
|
|
cLib_addCalc(&pPkt->mEff[i].mPntWindVel.y, 0.0f, 0.2f, 0.1f, 0.00001f);
|
|
cLib_addCalc(&pPkt->mEff[i].mPntWindVel.z, 0.0f, 0.2f, 0.1f, 0.00001f);
|
|
|
|
pPkt->mEff[i].mPos.x += pPkt->mEff[i].mPntWindVel.x;
|
|
pPkt->mEff[i].mPos.y += pPkt->mEff[i].mPntWindVel.y;
|
|
pPkt->mEff[i].mPos.z += pPkt->mEff[i].mPntWindVel.z;
|
|
|
|
// botched comparison?
|
|
if (strcmp(dComIfGp_getStartStageName(), "kaze") == 0) {
|
|
|
|
}
|
|
|
|
if (strcmp(dComIfGp_getStartStageName(), "Adanmae") == 0) {
|
|
speed = 20.0f;
|
|
} else {
|
|
speed = 8.0f;
|
|
}
|
|
|
|
velRndm.x = (pPkt->mEff[i].mVelRndm.x / 360.0f - 0.5f) * speed;
|
|
velRndm.y = (pPkt->mEff[i].mVelRndm.y / 360.0f - 0.5f) * speed;
|
|
velRndm.z = (pPkt->mEff[i].mVelRndm.z / 360.0f - 0.5f) * speed;
|
|
|
|
pPkt->mEff[i].mPos.x += velRndm.x;
|
|
pPkt->mEff[i].mPos.y += velRndm.y;
|
|
pPkt->mEff[i].mPos.z += velRndm.z;
|
|
|
|
pos.x = pPkt->mEff[i].mBasePos.x + pPkt->mEff[i].mPos.x;
|
|
pos.y = pPkt->mEff[i].mBasePos.y + pPkt->mEff[i].mPos.y;
|
|
pos.z = pPkt->mEff[i].mBasePos.z + pPkt->mEff[i].mPos.z;
|
|
|
|
if (pos.abs(center) > 2000.0f) {
|
|
pPkt->mEff[i].mBasePos.set(center);
|
|
|
|
if (pos.abs(center) > 2200.0f) {
|
|
pPkt->mEff[i].mPos.x = cM_rndFX(2000.0f);
|
|
pPkt->mEff[i].mPos.y = cM_rndFX(2000.0f);
|
|
pPkt->mEff[i].mPos.z = cM_rndFX(2000.0f);
|
|
} else {
|
|
cLib_addCalc(&pPkt->mEff[i].mAlpha, 0.0f, 0.1f, 0.01f, 0.001f);
|
|
if (pPkt->mEff[i].mAlpha < 0.001f) {
|
|
get_vectle_calc(&pos, ¢er, &pntwind);
|
|
pntwind.x += cM_rndF(0.5f);
|
|
pntwind.y += cM_rndF(0.5f);
|
|
pntwind.z += cM_rndF(0.5f);
|
|
pPkt->mEff[i].mPos.x = pntwind.x * 2000.0f;
|
|
pPkt->mEff[i].mPos.y = pntwind.y * 2000.0f;
|
|
pPkt->mEff[i].mPos.z = pntwind.z * 2000.0f;
|
|
}
|
|
}
|
|
|
|
pPkt->mEff[i].mAlpha = 0.0f;
|
|
}
|
|
}
|
|
break;
|
|
case 3:
|
|
pPkt->mEff[i].mStatus = 0;
|
|
break;
|
|
}
|
|
|
|
pos.x = pPkt->mEff[i].mBasePos.x + pPkt->mEff[i].mPos.x;
|
|
pos.y = pPkt->mEff[i].mBasePos.y + pPkt->mEff[i].mPos.y;
|
|
pos.z = pPkt->mEff[i].mBasePos.z + pPkt->mEff[i].mPos.z;
|
|
|
|
pPkt->mEff[i].mSize = pPkt->mEff[i].mInitialSize + ((pos.abs(pCamera->mLookat.mEye) - 1000.0f) / 2000.0f) * 1.5f * pPkt->mEff[i].mInitialSize + (40.0f * cM_ssin(pPkt->mEff[i].mAnimCounter));
|
|
|
|
f32 distCenter = pos.abs(center);
|
|
if (distCenter < 0.0f)
|
|
distCenter = 0.0f;
|
|
|
|
f32 alphaTarget = 1.0f - distCenter / 1000.0f;
|
|
f32 maxAlpha = 0.035f;
|
|
if (dKy_getEnvlight().mMoyaMode == 3) {
|
|
maxAlpha = 0.06f;
|
|
} else if (dKy_getEnvlight().mMoyaMode == 4) {
|
|
maxAlpha = 0.05f;
|
|
}
|
|
maxAlpha *= 1.2f;
|
|
|
|
if (i > dKy_getEnvlight().mMoyaCount - 1) {
|
|
alphaTarget = 0.0f;
|
|
if (pPkt->mEff[i].mAlpha < 0.001f && i == pPkt->mCount - 1) {
|
|
pPkt->mCount--;
|
|
}
|
|
}
|
|
|
|
cLib_addCalc(&pPkt->mEff[i].mAlpha, alphaTarget * maxAlpha, 0.1f, 0.1f, 0.000000001f);
|
|
}
|
|
}
|
|
|
|
/* 80092294-80092310 .text light_at_hit_check__FP4cXyz */
|
|
BOOL light_at_hit_check(cXyz* pPos) {
|
|
dCcMassS_HitInf hitInfo;
|
|
BOOL ret = FALSE;
|
|
fopAc_ac_c * pActor;
|
|
u32 res = dComIfG_Ccsp()->ChkMass(pPos, &pActor, &hitInfo);
|
|
if (((res & 1) != 0) && (hitInfo.GetAtHitObj()->ChkAtType(AT_TYPE_LIGHT)))
|
|
ret = TRUE;
|
|
return ret;
|
|
}
|
|
|
|
/* 80092310-80092330 .text dKyr_poison_live_check__Fv */
|
|
BOOL dKyr_poison_live_check() {
|
|
BOOL ret = FALSE;
|
|
if (g_env_light.mPoisonCount != 0)
|
|
ret = TRUE;
|
|
return ret;
|
|
}
|
|
|
|
/* 80092330-80092448 .text dKyr_poison_light_colision__Fv */
|
|
void dKyr_poison_light_colision() {
|
|
dKankyo_poison_Packet * pPkt = g_env_light.mpPoisonPacket;
|
|
if (!dKyr_poison_live_check())
|
|
return;
|
|
|
|
dComIfG_Ccsp()->SetMassAttr(220.0f, 140.0f, 0x0B, 0x03);
|
|
|
|
f32 halfHeight = 70.0f;
|
|
for (s32 i = 0; i < g_env_light.mPoisonCount; i++) {
|
|
cXyz pos = pPkt->mBasePos + pPkt->mEff[i].mPos;
|
|
pos.y -= halfHeight;
|
|
if (light_at_hit_check(&pos) && pPkt->mEff[i].mStatus == 1) {
|
|
pPkt->mEff[i].mStatus = 2;
|
|
pPkt->mEff[i].field_0x2e = 60;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 80092448-8009258C .text poison_init__Fv */
|
|
void poison_init() {
|
|
g_env_light.mpPoisonPacket = new(0x20) dKankyo_poison_Packet();
|
|
g_env_light.mpPoisonPacket->field_0xbb9c.x = 0.0f;
|
|
g_env_light.mpPoisonPacket->field_0xbb9c.y = 0.0f;
|
|
g_env_light.mpPoisonPacket->field_0xbb9c.z = 0.0f;
|
|
g_env_light.mpPoisonPacket->mCount = 0;
|
|
if (g_env_light.mpPoisonPacket != NULL) {
|
|
g_env_light.mpPoisonPacket->mpTexture = (u8*)dComIfG_getObjectRes("Always", ALWAYS_BTI_AK_SMOKE01);
|
|
for (u32 i = 0; i < ARRAY_SIZE(g_env_light.mpPoisonPacket->mEff); i++)
|
|
g_env_light.mpPoisonPacket->mEff[i].mStatus = 0;
|
|
poison_move();
|
|
now_room = dComIfGp_roomControl_getStayNo();
|
|
}
|
|
}
|
|
|
|
/* 8009258C-800937BC .text poison_move__Fv */
|
|
void poison_move() {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 800937BC-800940D4 .text vrkumo_move__Fv */
|
|
void vrkumo_move() {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 800940D4-80094144 .text dKy_wave_chan_init__Fv */
|
|
void dKy_wave_chan_init() {
|
|
g_env_light.mWaveChan.mWaveCount = 0;
|
|
g_env_light.mWaveChan.field_0x0 = -1.0f;
|
|
g_env_light.mWaveChan.field_0x4 = 0.0f;
|
|
g_env_light.mWaveChan.field_0x8 = 0.0f;
|
|
g_env_light.mWaveChan.mWaveSpeed = 0.3f;
|
|
g_env_light.mWaveChan.mWaveSpawnDist = 3000.0f;
|
|
g_env_light.mWaveChan.mWaveSpawnRadius = 3150.0f;
|
|
g_env_light.mWaveChan.mWaveReset = 0;
|
|
g_env_light.mWaveChan.mWaveScale = 250.0f;
|
|
g_env_light.mWaveChan.mWaveScaleBottom = 5.0f;
|
|
g_env_light.mWaveChan.mWaveScaleRand = 0.217f;
|
|
g_env_light.mWaveChan.mWaveCounterSpeedScale = 1.6f;
|
|
g_env_light.mWaveChan.field_0x2f = 0;
|
|
g_env_light.mWaveChan.mWaveSpeed = 0.1f;
|
|
}
|
|
|
|
/* 80094144-8009428C .text snap_sunmoon_proc__FP4cXyzi */
|
|
void snap_sunmoon_proc(cXyz* pPos, int type) {
|
|
dSnap_Obj snapObj;
|
|
camera_class * pCamera = dComIfGp_getCamera(0);
|
|
|
|
if (dComIfGp_checkPlayerStatus1(0, daPyStts1_PICTO_BOX_AIM_e)) {
|
|
cXyz pos;
|
|
pos.x = (pPos->x - pCamera->mLookat.mEye.x);
|
|
pos.y = (pPos->y - pCamera->mLookat.mEye.y);
|
|
pos.z = (pPos->z - pCamera->mLookat.mEye.z);
|
|
pos.x *= 10.0f;
|
|
pos.y *= 10.0f;
|
|
pos.z *= 10.0f;
|
|
pos.x += pCamera->mLookat.mEye.x;
|
|
pos.y += pCamera->mLookat.mEye.y;
|
|
pos.z += pCamera->mLookat.mEye.z;
|
|
|
|
snapObj.SetGeoSph(pos, 8000.0f);
|
|
if (type == 9)
|
|
snapObj.SetInf(9, NULL, 0xFF, 4, 0x7FFF);
|
|
else if (type == 0)
|
|
snapObj.SetInf(7, NULL, 0xFF, 4, 0x7FFF);
|
|
else
|
|
snapObj.SetInf(8, NULL, 0xFF, 4, 0x7FFF);
|
|
dSnap_RegistSnapObj(snapObj);
|
|
}
|
|
}
|
|
|
|
/* 8009428C-8009514C .text dKyr_drawSun__FPA4_fP4cXyzR8GXColorPPUc */
|
|
void dKyr_drawSun(Mtx drawMtx, cXyz* pPos, GXColor& reg0, u8** pImg) {
|
|
/* Nonmatching */
|
|
dKankyo_sun_Packet* pSunPkt;
|
|
dKankyo_sunlenz_Packet* pSunlenzPkt;
|
|
camera_class* pCamera;
|
|
cXyz pos[4];
|
|
cXyz sunPos;
|
|
cXyz moonPos2;
|
|
cXyz moonPos;
|
|
cXyz vp;
|
|
cXyz lp;
|
|
bool bDrawSun;
|
|
bool bDrawMoon;
|
|
Mtx camMtx;
|
|
Mtx rotMtx;
|
|
GXColor reg1;
|
|
GXTexObj texObj;
|
|
|
|
pSunPkt = dKy_getEnvlight().mpSunPacket;
|
|
pSunlenzPkt = dKy_getEnvlight().mpSunlenzPacket;
|
|
pCamera = dComIfGp_getCamera(0);
|
|
|
|
bDrawMoon = false;
|
|
bDrawSun = false;
|
|
if (pSunPkt->mSunAlpha > 0.0f)
|
|
bDrawSun = true;
|
|
if (pSunPkt->mMoonAlpha > 0.0f)
|
|
bDrawMoon = true;
|
|
|
|
if (bDrawSun | bDrawMoon) {
|
|
sunPos = *pPos;
|
|
|
|
u32 stType = dStage_stagInfo_GetSTType(dComIfGp_getStageStagInfo());
|
|
if (dKy_getEnvlight().mBaseLightInfluence.mColor.r == 0 && stType != dStageType_MISC_e) {
|
|
if (dKy_getEnvlight().mCurTime > 285.0f || dKy_getEnvlight().mCurTime < 105.0f)
|
|
bDrawMoon = false;
|
|
|
|
moonPos2 = *pPos;
|
|
} else {
|
|
moonPos.x = -(pPos->x - pCamera->mLookat.mEye.x);
|
|
moonPos.y = -(pPos->y - pCamera->mLookat.mEye.y);
|
|
moonPos.z = -(pPos->z - pCamera->mLookat.mEye.z);
|
|
|
|
moonPos2.x = moonPos.x + pCamera->mLookat.mEye.x;
|
|
moonPos2.y = moonPos.y + pCamera->mLookat.mEye.y;
|
|
moonPos2.z = moonPos.z + pCamera->mLookat.mEye.z;
|
|
}
|
|
|
|
int dayofweek = dKy_get_dayofweek();
|
|
if (dComIfGs_getTime() < 180.0f) {
|
|
if (dayofweek != 0)
|
|
dayofweek--;
|
|
else
|
|
dayofweek = 6;
|
|
}
|
|
|
|
s32 texidx;
|
|
f32 flipX;
|
|
switch (dayofweek) {
|
|
case 0: texidx = 0; flipX = 1.0f; break;
|
|
case 1: texidx = 1; flipX = 1.0f; break;
|
|
case 2: texidx = 2; flipX = 1.0f; break;
|
|
case 3: texidx = 3; flipX = 1.0f; break;
|
|
case 4: texidx = 3; flipX = -1.0f; break;
|
|
case 5: texidx = 2; flipX = -1.0f; break;
|
|
case 6: texidx = 1; flipX = -1.0f; break;
|
|
}
|
|
|
|
reg0.r = dKy_getEnvlight().mFogColor.r;
|
|
reg0.g = dKy_getEnvlight().mFogColor.g;
|
|
reg0.b = dKy_getEnvlight().mFogColor.b;
|
|
reg0.a = 0xFF;
|
|
|
|
reg1.r = 0x00;
|
|
reg1.g = 0x00;
|
|
reg1.b = 0x00;
|
|
reg1.a = 0xFF;
|
|
|
|
if (dComIfGd_getView() != NULL) {
|
|
MTXInverse(dComIfGd_getViewRotMtx(), camMtx);
|
|
} else {
|
|
if (pSunPkt->field_0x3c < 5)
|
|
pSunPkt->field_0x3c += 2;
|
|
pSunPkt->field_0x3d = true;
|
|
return;
|
|
}
|
|
|
|
dKyr_set_btitex(&texObj, (ResTIMG*)pImg[texidx]);
|
|
|
|
GXSetNumChans(0);
|
|
GXSetTevColor(GX_TEVREG0, reg0);
|
|
GXSetTevColor(GX_TEVREG1, reg1);
|
|
GXSetNumTexGens(1);
|
|
GXSetTexCoordGen(GX_TEXCOORD0, GX_TG_MTX2x4, GX_TG_TEX0, GX_IDENTITY);
|
|
GXSetNumTevStages(1);
|
|
GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD0, GX_TEXMAP0, GX_COLOR_NULL);
|
|
GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_C1, GX_CC_C0, GX_CC_TEXC, GX_CC_ZERO);
|
|
GXSetTevColorOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
|
|
GXSetTevAlphaIn(GX_TEVSTAGE0, GX_CA_ZERO, GX_CA_A0, GX_CA_TEXA, GX_CA_ZERO);
|
|
GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
|
|
GXSetBlendMode(GX_BM_BLEND, GX_BL_SRC_ALPHA, GX_BL_INV_SRC_ALPHA, GX_LO_SET);
|
|
GXSetAlphaCompare(GX_GREATER, 0, GX_AOP_OR, GX_GREATER, 0);
|
|
GXSetZMode(GX_TRUE, GX_LEQUAL, GX_FALSE);
|
|
GXSetNumIndStages(0);
|
|
GXSetCullMode(GX_CULL_NONE);
|
|
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_TEX0, GX_TEX_ST, GX_S16, 8);
|
|
GXClearVtxDesc();
|
|
GXSetVtxDesc(GX_VA_POS, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_TEX0, GX_DIRECT);
|
|
|
|
if (bDrawMoon == true) {
|
|
cXyz camfwd;
|
|
f32 dayscale[7] = { 1.0f, 0.83f, 0.6f, 0.6f, 0.6f, 0.6f, 0.83f, };
|
|
|
|
snap_sunmoon_proc(&moonPos2, texidx);
|
|
dKyr_get_vectle_calc(&pCamera->mLookat.mEye, &pCamera->mLookat.mCenter, &camfwd);
|
|
|
|
f32 cam_distXZ = std::sqrtf(camfwd.x*camfwd.x + camfwd.z*camfwd.z);
|
|
f32 cam_theta = std::atan2f(camfwd.x, camfwd.z);
|
|
f32 cam_phi = std::atan2f(camfwd.y, cam_distXZ);
|
|
|
|
f32 moon_distXZ = std::sqrtf(moonPos.x*moonPos.x + moonPos.z*moonPos.z);
|
|
f32 moon_theta = std::atan2f(moonPos.x, moonPos.z);
|
|
f32 moon_phi = std::atan2f(moonPos.y, moon_distXZ);
|
|
|
|
f32 angle = 45.0f + (((moon_theta - cam_theta) / -8.0f) * moon_phi) * 360.0f;
|
|
MTXRotDeg(rotMtx, 'Z', angle);
|
|
MTXConcat(camMtx, rotMtx, camMtx);
|
|
GXLoadPosMtxImm(drawMtx, GX_PNMTX0);
|
|
GXSetCurrentMtx(GX_PNMTX0);
|
|
|
|
reg0.r = 0xF3;
|
|
reg0.g = 0xFF;
|
|
reg0.b = 0x94;
|
|
|
|
f32 size = 700.0f;
|
|
reg0.a = pSunPkt->mMoonAlpha * 255.0f;
|
|
GXSetTevColor(GX_TEVREG0, reg0);
|
|
|
|
for (s32 j = 0; j < 2; j++) {
|
|
if (j == 1) {
|
|
GXInitTexObj(&texObj, pSunlenzPkt->mpTexSnow01, 64, 64, GX_TF_I8, GX_CLAMP, GX_CLAMP, GX_FALSE);
|
|
GXInitTexObjLOD(&texObj, GX_LINEAR, GX_LINEAR, 0.0f, 0.0f, 0.0f, GX_FALSE, GX_FALSE, GX_ANISO_1);
|
|
GXLoadTexObj(&texObj, GX_TEXMAP0);
|
|
size *= 1.7f;
|
|
reg0.a = pSunPkt->mMoonAlpha * 76.0f;
|
|
reg0.r = 0xFF;
|
|
reg0.g = 0xFF;
|
|
reg0.b = 0xCF;
|
|
reg1.r = 0xC5;
|
|
reg1.g = 0x69;
|
|
reg1.b = 0x23;
|
|
MTXRotDeg(rotMtx, 'Z', 50.0f * flipX);
|
|
MTXConcat(camMtx, rotMtx, camMtx);
|
|
GXLoadPosMtxImm(drawMtx, GX_PNMTX0);
|
|
GXSetCurrentMtx(GX_PNMTX0);
|
|
}
|
|
|
|
GXSetTevColor(GX_TEVREG0, reg0);
|
|
GXSetTevColor(GX_TEVREG1, reg1);
|
|
|
|
vp.x = -size * flipX;
|
|
vp.y = size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[0].x = moonPos2.x + lp.x;
|
|
pos[0].y = moonPos2.y + lp.y;
|
|
pos[0].z = moonPos2.z + lp.z;
|
|
|
|
vp.x = size * flipX;
|
|
vp.y = size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[1].x = moonPos2.x + lp.x;
|
|
pos[1].y = moonPos2.y + lp.y;
|
|
pos[1].z = moonPos2.z + lp.z;
|
|
|
|
if (texidx == 0) {
|
|
vp.x = size * flipX;
|
|
vp.y = -size;
|
|
} else {
|
|
vp.x = size * flipX * dayscale[dayofweek];
|
|
vp.y = -size * dayscale[dayofweek];
|
|
}
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[2].x = moonPos2.x + lp.x;
|
|
pos[2].y = moonPos2.y + lp.y;
|
|
pos[2].z = moonPos2.z + lp.z;
|
|
|
|
vp.x = -size * flipX;
|
|
vp.y = -size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[3].x = moonPos2.x + lp.x;
|
|
pos[3].y = moonPos2.y + lp.y;
|
|
pos[3].z = moonPos2.z + lp.z;
|
|
|
|
GXBegin(GX_QUADS, GX_VTXFMT0, 4);
|
|
GXPosition3f32(pos[0].x, pos[0].y, pos[0].z);
|
|
GXTexCoord2s16(0, 0);
|
|
GXPosition3f32(pos[1].x, pos[1].y, pos[1].z);
|
|
GXTexCoord2s16(0xFF, 0);
|
|
GXPosition3f32(pos[2].x, pos[2].y, pos[2].z);
|
|
GXTexCoord2s16(0xFF, 0xFF);
|
|
GXPosition3f32(pos[3].x, pos[3].y, pos[3].z);
|
|
GXTexCoord2s16(0, 0xFF);
|
|
GXEnd();
|
|
}
|
|
}
|
|
|
|
if (bDrawSun == true) {
|
|
cXyz camfwd;
|
|
snap_sunmoon_proc(&sunPos, 9);
|
|
|
|
f32 sun_distXZ = std::sqrtf(sunPos.x*sunPos.x + sunPos.z*sunPos.z);
|
|
f32 sun_theta = std::atan2f(sunPos.x, sunPos.z);
|
|
f32 sun_phi = std::atan2f(sunPos.y, sun_distXZ);
|
|
|
|
dKyr_get_vectle_calc(&pCamera->mLookat.mEye, &pCamera->mLookat.mCenter, &camfwd);
|
|
|
|
f32 cam_distXZ = std::sqrtf(camfwd.x*camfwd.x + camfwd.z*camfwd.z);
|
|
f32 cam_theta = std::atan2f(camfwd.x, camfwd.z);
|
|
f32 cam_phi = std::atan2f(camfwd.y, cam_distXZ);
|
|
|
|
MTXRotDeg(rotMtx, 'Z', -50.0f + (360.0f * ((sun_theta - cam_theta) / -8.0f)));
|
|
MTXConcat(camMtx, rotMtx, camMtx);
|
|
GXLoadPosMtxImm(drawMtx, GX_PNMTX0);
|
|
GXSetCurrentMtx(GX_PNMTX0);
|
|
|
|
reg0.r = 0xFF;
|
|
reg0.g = 0xFF;
|
|
reg0.b = 0xF1;
|
|
|
|
reg1.r = 0xF1;
|
|
reg1.g = 0x91;
|
|
reg1.b = 0x49;
|
|
|
|
f32 dist = 1.0f - pSunlenzPkt->mDistFalloff;
|
|
f32 size = 575.0f;
|
|
if (pSunPkt->mVisibility > 0.0f)
|
|
size += 500.0f * (dist * dist) * pSunPkt->mVisibility;
|
|
|
|
for (s32 j = 0; j < 2; j++) {
|
|
if (j == 0) {
|
|
dKyr_set_btitex(&texObj, (ResTIMG*)pImg[4]);
|
|
reg0.a = pSunPkt->mSunAlpha * 255.0f;
|
|
} else {
|
|
GXInitTexObj(&texObj, pSunlenzPkt->mpTexSnow01, 64, 64, GX_TF_I8, GX_CLAMP, GX_CLAMP, GX_FALSE);
|
|
GXInitTexObjLOD(&texObj, GX_LINEAR, GX_LINEAR, 0.0f, 0.0f, 0.0f, GX_FALSE, GX_FALSE, GX_ANISO_1);
|
|
GXLoadTexObj(&texObj, GX_TEXMAP0);
|
|
size *= 1.6f;
|
|
reg0.a = pSunPkt->mSunAlpha * 76.0f;
|
|
}
|
|
|
|
GXSetTevColor(GX_TEVREG0, reg0);
|
|
GXSetTevColor(GX_TEVREG1, reg1);
|
|
|
|
vp.x = -size * flipX;
|
|
vp.y = size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[0].x = sunPos.x + lp.x;
|
|
pos[0].y = sunPos.y + lp.y;
|
|
pos[0].z = sunPos.z + lp.z;
|
|
|
|
vp.x = size * flipX;
|
|
vp.y = size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[1].x = sunPos.x + lp.x;
|
|
pos[1].y = sunPos.y + lp.y;
|
|
pos[1].z = sunPos.z + lp.z;
|
|
|
|
vp.x = size * flipX;
|
|
vp.y = -size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[2].x = sunPos.x + lp.x;
|
|
pos[2].y = sunPos.y + lp.y;
|
|
pos[2].z = sunPos.z + lp.z;
|
|
|
|
vp.x = -size * flipX;
|
|
vp.y = -size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[3].x = sunPos.x + lp.x;
|
|
pos[3].y = sunPos.y + lp.y;
|
|
pos[3].z = sunPos.z + lp.z;
|
|
|
|
GXBegin(GX_QUADS, GX_VTXFMT0, 4);
|
|
GXPosition3f32(pos[0].x, pos[0].y, pos[0].z);
|
|
GXTexCoord2s16(0, 0);
|
|
GXPosition3f32(pos[1].x, pos[1].y, pos[1].z);
|
|
GXTexCoord2s16(0xFF, 0);
|
|
GXPosition3f32(pos[2].x, pos[2].y, pos[2].z);
|
|
GXTexCoord2s16(0xFF, 0xFF);
|
|
GXPosition3f32(pos[3].x, pos[3].y, pos[3].z);
|
|
GXTexCoord2s16(0, 0xFF);
|
|
GXEnd();
|
|
}
|
|
}
|
|
#if VERSION != VERSION_JPN
|
|
J3DShape::resetVcdVatCache();
|
|
#endif
|
|
}
|
|
}
|
|
|
|
/* 8009514C-80095E8C .text dKyr_drawLenzflare__FPA4_fP4cXyzR8GXColorPPUc */
|
|
void dKyr_drawLenzflare(Mtx drawMtx, cXyz* pPos, GXColor& color, u8** pImg) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 80095E8C-8009682C .text dKyr_drawRain__FPA4_fPPUc */
|
|
void dKyr_drawRain(Mtx drawMtx, u8** pImg) {
|
|
/* Nonmatching */
|
|
dKankyo_rain_Packet* pPkt = g_env_light.mpRainPacket;
|
|
camera_class* pCamera = dComIfGp_getCamera(0);
|
|
|
|
Mtx camMtx;
|
|
cXyz pos[4];
|
|
cXyz windvec;
|
|
cXyz vp;
|
|
cXyz lp;
|
|
cXyz p;
|
|
cXyz dummy;
|
|
cXyz tilt;
|
|
Mtx rotMtx;
|
|
GXColor reg0, reg1;
|
|
|
|
windvec = dKyw_get_wind_vecpow();
|
|
|
|
static u32 rot = 0;
|
|
|
|
if (g_env_light.mSnowCount == 0) {
|
|
dummy.set(0.0f, -2.0f, 0.0f);
|
|
|
|
if (pPkt->mRainCount != 0) {
|
|
reg0.r = 0xFF;
|
|
reg0.g = 0xFF;
|
|
reg0.b = 0xFF;
|
|
|
|
reg1.r = 0x80;
|
|
reg1.g = 0x80;
|
|
reg1.b = 0x80;
|
|
|
|
reg0.a = 0x0A;
|
|
reg1.a = 0x0A;
|
|
|
|
if (dComIfGd_getView() != NULL) {
|
|
MTXInverse(dComIfGd_getViewRotMtx(), camMtx);
|
|
} else {
|
|
return;
|
|
}
|
|
|
|
GXTexObj texObj;
|
|
GXInitTexObj(&texObj, pImg[0], 64, 64, GX_TF_I8, GX_CLAMP, GX_CLAMP, GX_FALSE);
|
|
GXInitTexObjLOD(&texObj, GX_LINEAR, GX_LINEAR, 0.0f, 0.0f, 0.0f, GX_FALSE, GX_FALSE, GX_ANISO_1);
|
|
GXLoadTexObj(&texObj, GX_TEXMAP0);
|
|
GXSetNumChans(0);
|
|
GXSetTevColor(GX_TEVREG0, reg0);
|
|
GXSetTevColor(GX_TEVREG1, reg1);
|
|
GXSetNumTexGens(1);
|
|
GXSetTexCoordGen(GX_TEXCOORD0, GX_TG_MTX2x4, GX_TG_TEX0, GX_IDENTITY);
|
|
GXSetNumTevStages(1);
|
|
GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD0, GX_TEXMAP0, GX_COLOR_NULL);
|
|
GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_C1, GX_CC_C0, GX_CC_TEXC, GX_CC_ZERO);
|
|
GXSetTevColorOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, true, GX_TEVPREV);
|
|
GXSetTevAlphaIn(GX_TEVSTAGE0, GX_CA_ZERO, GX_CA_A0, GX_CA_TEXA, GX_CA_ZERO);
|
|
GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, true, GX_TEVPREV);
|
|
GXSetBlendMode(GX_BM_BLEND, GX_BL_SRC_ALPHA, GX_BL_INV_SRC_ALPHA, GX_LO_SET);
|
|
GXSetAlphaCompare(GX_GREATER, 0, GX_AOP_OR, GX_GREATER, 0);
|
|
GXSetZMode(true, GX_LEQUAL, false);
|
|
GXSetCullMode(GX_CULL_NONE);
|
|
#if VERSION != VERSION_JPN
|
|
GXSetClipMode(GX_CLIP_DISABLE);
|
|
#endif
|
|
GXSetNumIndStages(0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_TEX0, GX_TEX_ST, GX_S16, 8);
|
|
GXClearVtxDesc();
|
|
GXSetVtxDesc(GX_VA_POS, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_TEX0, GX_DIRECT);
|
|
MTXRotDeg(rotMtx, 'Z', rot);
|
|
MTXConcat(camMtx, rotMtx, drawMtx);
|
|
GXLoadPosMtxImm(drawMtx, GX_PNMTX0);
|
|
GXSetCurrentMtx(GX_PNMTX0);
|
|
|
|
for (s32 i = 0; i < pPkt->mRainCount; i++) {
|
|
f32 alpha = pPkt->mEff[i].mAlpha;
|
|
if (alpha <= 0.0f)
|
|
continue;
|
|
|
|
reg0.a = alpha * 14.0f;
|
|
GXSetTevColor(GX_TEVREG0, reg0);
|
|
|
|
p.x = pPkt->mEff[i].mBasePos.x + pPkt->mEff[i].mPos.x;
|
|
p.y = pPkt->mEff[i].mBasePos.y + pPkt->mEff[i].mPos.y;
|
|
p.z = pPkt->mEff[i].mBasePos.z + pPkt->mEff[i].mPos.z;
|
|
|
|
f32 dist = p.abs(pCamera->mLookat.mEye);
|
|
dist = dist / 1500.0f + 0.1f;
|
|
if (dist > 1.0f)
|
|
dist = 1.0f;
|
|
|
|
f32 size = 2.5f + (i / 250.0f);
|
|
f32 speed = dist * 70.0f + 5.0f;
|
|
tilt.x = speed * (dummy.x + pPkt->mCenterDelta.x * pPkt->mCenterDeltaMul * 10.0f + (i & 0x07) * 0.08f + windvec.x);
|
|
tilt.y = speed * (dummy.y + pPkt->mCenterDelta.y * pPkt->mCenterDeltaMul + windvec.y);
|
|
tilt.z = speed * (dummy.z + pPkt->mCenterDelta.z * pPkt->mCenterDeltaMul * 10.0f + (i & 0x03) * 0.08f + windvec.z);
|
|
|
|
vp.x = -1.0f * -size;
|
|
vp.y = 0.0f;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[0].x = (p.x + lp.x) - tilt.x;
|
|
pos[0].y = (p.y + lp.y) - tilt.y;
|
|
pos[0].z = (p.z + lp.z) - tilt.z;
|
|
|
|
vp.x = -1.0f * size;
|
|
vp.y = 0.0f;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[1].x = (p.x + lp.x) - tilt.x;
|
|
pos[1].y = (p.y + lp.y) - tilt.y;
|
|
pos[1].z = (p.z + lp.z) - tilt.z;
|
|
|
|
vp.x = -1.0f * -size;
|
|
vp.y = 0.0f;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[2].x = p.x + lp.x;
|
|
pos[2].y = p.y + lp.y;
|
|
pos[2].z = p.z + lp.z;
|
|
|
|
vp.x = -1.0f * size;
|
|
vp.y = 0.0f;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[3].x = p.x + lp.x;
|
|
pos[3].y = p.y + lp.y;
|
|
pos[3].z = p.z + lp.z;
|
|
|
|
for (s32 j = 0; j < 4; j++) {
|
|
static const cXyz add_table[4] = {
|
|
cXyz(150.0f, 0.0f, 0.0f),
|
|
cXyz(0.0f, 150.0f, 150.0f),
|
|
cXyz(150.0f, 320.0f, 150.0f),
|
|
cXyz(45.0f, 480.0f, 45.0f),
|
|
};
|
|
|
|
GXBegin(GX_QUADS, GX_VTXFMT0, 4);
|
|
GXPosition3f32(pos[0].x + add_table[j].x, pos[0].y + add_table[j].y, pos[0].z + add_table[j].z);
|
|
GXTexCoord2s16(0, 0);
|
|
GXPosition3f32(pos[1].x + add_table[j].x, pos[1].y + add_table[j].y, pos[1].z + add_table[j].z);
|
|
GXTexCoord2s16(0xFF, 0);
|
|
GXPosition3f32(pos[2].x + add_table[j].x, pos[2].y + add_table[j].y, pos[2].z + add_table[j].z);
|
|
GXTexCoord2s16(0xFF, 0xFF);
|
|
GXPosition3f32(pos[3].x + add_table[j].x, pos[3].y + add_table[j].y, pos[3].z + add_table[j].z);
|
|
GXTexCoord2s16(0, 0xFF);
|
|
GXEnd();
|
|
}
|
|
}
|
|
|
|
#if VERSION != VERSION_JPN
|
|
GXSetClipMode(GX_CLIP_ENABLE);
|
|
J3DShape::resetVcdVatCache();
|
|
#endif
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 8009682C-80096D18 .text dKyr_drawSibuki__FPA4_fPPUc */
|
|
void dKyr_drawSibuki(Mtx drawMtx, u8** pImg) {
|
|
camera_class *pCamera = dComIfGp_getCamera(0);
|
|
dKankyo_rain_Packet * pPkt = g_env_light.mpRainPacket;
|
|
|
|
if (g_env_light.mSnowCount == 0 && dComIfGd_getView() != NULL) {
|
|
Mtx camMtx;
|
|
MTXInverse(dComIfGd_getViewRotMtx(), camMtx);
|
|
} else {
|
|
return;
|
|
}
|
|
|
|
f32 alpha = 200.0f;
|
|
if (pPkt->mStatus & 1)
|
|
alpha = 0.0f;
|
|
else if (pPkt->mStatus & 2)
|
|
alpha = 200.0f;
|
|
|
|
cLib_addCalc(&pPkt->mSibukiAlpha, alpha, 0.2f, 30.0f, 0.001f);
|
|
|
|
cXyz eyevect, camDir;
|
|
dKy_set_eyevect_calc(pCamera, &eyevect, 7000.0f, 4000.0f);
|
|
dKyr_get_vectle_calc(&pCamera->mLookat.mEye, &pCamera->mLookat.mCenter, &camDir);
|
|
|
|
f32 alphaFade;
|
|
if (camDir.y > 0.0f) {
|
|
if (camDir.y < 0.5f) {
|
|
alphaFade = 1.0f - (camDir.y / 0.5f);
|
|
} else {
|
|
alphaFade = 0.0f;
|
|
}
|
|
} else {
|
|
alphaFade = 1.0f;
|
|
}
|
|
|
|
GXColor color;
|
|
color.r = 0xB4;
|
|
color.g = 0xC8;
|
|
color.b = 0xC8;
|
|
color.a = (u8)(pPkt->mSibukiAlpha * alphaFade);
|
|
|
|
GXTexObj texObj;
|
|
dKyr_init_btitex(&texObj, (ResTIMG*)pImg[1]);
|
|
GXLoadTexObj(&texObj, GX_TEXMAP0);
|
|
|
|
GXSetNumChans(0);
|
|
GXSetTevColor(GX_TEVREG0, color);
|
|
GXSetTevColor(GX_TEVREG1, color);
|
|
GXSetNumTexGens(1);
|
|
GXSetTexCoordGen(GX_TEXCOORD0, GX_TG_MTX2x4, GX_TG_TEX0, GX_IDENTITY);
|
|
GXSetNumTevStages(1);
|
|
GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD0, GX_TEXMAP0, GX_COLOR_NULL);
|
|
GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_C1, GX_CC_C0, GX_CC_TEXC, GX_CC_ZERO);
|
|
GXSetTevColorOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, true, GX_TEVPREV);
|
|
GXSetTevAlphaIn(GX_TEVSTAGE0, GX_CA_ZERO, GX_CA_A0, GX_CA_TEXA, GX_CA_ZERO);
|
|
GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, true, GX_TEVPREV);
|
|
GXSetBlendMode(GX_BM_BLEND, GX_BL_SRC_ALPHA, GX_BL_INV_SRC_ALPHA, GX_LO_SET);
|
|
GXSetAlphaCompare(GX_GREATER, 0, GX_AOP_OR, GX_GREATER, 0);
|
|
GXSetZMode(true, GX_GEQUAL, false);
|
|
GXSetCullMode(GX_CULL_NONE);
|
|
#if VERSION != VERSION_JPN
|
|
GXSetClipMode(GX_CLIP_DISABLE);
|
|
#endif
|
|
GXSetNumIndStages(0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_TEX0, GX_TEX_ST, GX_S16, 8);
|
|
GXClearVtxDesc();
|
|
GXSetVtxDesc(GX_VA_POS, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_TEX0, GX_DIRECT);
|
|
GXLoadPosMtxImm(drawMtx, GX_PNMTX0);
|
|
GXSetCurrentMtx(GX_PNMTX0);
|
|
|
|
f32 scale;
|
|
if (dComIfGd_getView() != NULL) {
|
|
scale = dComIfGd_getView()->mFovy / 20.0f;
|
|
if (scale >= 1.0f)
|
|
scale = 1.0f;
|
|
scale = 1.0f - scale;
|
|
} else {
|
|
scale = 0.2f;
|
|
}
|
|
|
|
for (s32 i = 0; i < g_env_light.mRainCount >> 1; i++) {
|
|
cXyz pos[4], p;
|
|
|
|
f32 size = 20.0f + (scale * cM_rndF(25.0f));
|
|
|
|
f32 localX = cM_rndFX(3600.0f);
|
|
f32 localY = cM_rndFX(1500.0f);
|
|
f32 localZ = cM_rndFX(3600.0f);
|
|
|
|
p.x = eyevect.x + localX;
|
|
p.y = eyevect.y + localY;
|
|
p.z = eyevect.z + localZ;
|
|
|
|
pos[0].x = p.x - size;
|
|
pos[0].y = p.y;
|
|
pos[0].z = p.z - size;
|
|
|
|
pos[1].x = p.x + size;
|
|
pos[1].y = p.y;
|
|
pos[1].z = p.z - size;
|
|
|
|
pos[2].x = p.x + size;
|
|
pos[2].y = p.y;
|
|
pos[2].z = p.z + size;
|
|
|
|
pos[3].x = p.x - size;
|
|
pos[3].y = p.y;
|
|
pos[3].z = p.z + size;
|
|
|
|
GXBegin(GX_QUADS, GX_VTXFMT0, 4);
|
|
GXPosition3f32(pos[0].x, pos[0].y, pos[0].z);
|
|
GXTexCoord2s16(0, 0);
|
|
GXPosition3f32(pos[1].x, pos[1].y, pos[1].z);
|
|
GXTexCoord2s16(0x1FF, 0);
|
|
GXPosition3f32(pos[2].x, pos[2].y, pos[2].z);
|
|
GXTexCoord2s16(0x1FF, 0x1FF);
|
|
GXPosition3f32(pos[3].x, pos[3].y, pos[3].z);
|
|
GXTexCoord2s16(0, 0x1FF);
|
|
GXEnd();
|
|
}
|
|
|
|
#if VERSION != VERSION_JPN
|
|
GXSetClipMode(GX_CLIP_ENABLE);
|
|
J3DShape::resetVcdVatCache();
|
|
#endif
|
|
}
|
|
|
|
/* 80096D18-800973CC .text drawPoison__FPA4_fPPUc */
|
|
void drawPoison(Mtx drawMtx, u8** pImg) {
|
|
/* Nonmatching - just mul order when computing reg0/reg1 */
|
|
dScnKy_env_light_c& envLight = dKy_getEnvlight();
|
|
dKankyo_poison_Packet* pPkt;
|
|
GXTexObj texObj;
|
|
Mtx camMtx;
|
|
Mtx rotMtx;
|
|
cXyz pos[4];
|
|
cXyz windvec;
|
|
cXyz vp;
|
|
cXyz lp;
|
|
cXyz p;
|
|
cXyz dummy;
|
|
cXyz tilt;
|
|
GXColor reg0, reg1;
|
|
|
|
pPkt = dKy_getEnvlight().mpPoisonPacket;
|
|
static f32 rot = 0.0f;
|
|
|
|
j3dSys.reinitGX();
|
|
if (dComIfGd_getView() != NULL) {
|
|
MTXInverse(dComIfGd_getViewRotMtx(), camMtx);
|
|
} else {
|
|
return;
|
|
}
|
|
|
|
reg0.r = 0x2D;
|
|
reg0.g = 0x88;
|
|
reg0.b = 0xAA;
|
|
|
|
reg1.r = 0x6D;
|
|
reg1.g = 0x3C;
|
|
reg1.b = 0xCD;
|
|
|
|
dKyr_set_btitex(&texObj, (ResTIMG*)pImg[0]);
|
|
|
|
GXSetNumChans(0);
|
|
GXSetTevColor(GX_TEVREG0, reg0);
|
|
GXSetTevColor(GX_TEVREG1, reg1);
|
|
GXSetNumTexGens(1);
|
|
GXSetTexCoordGen(GX_TEXCOORD0, GX_TG_MTX2x4, GX_TG_TEX0, GX_IDENTITY);
|
|
GXSetNumTevStages(1);
|
|
GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD0, GX_TEXMAP0, GX_COLOR_NULL);
|
|
GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_C1, GX_CC_C0, GX_CC_TEXC, GX_CC_ZERO);
|
|
GXSetTevColorOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
|
|
GXSetTevAlphaIn(GX_TEVSTAGE0, GX_CA_ZERO, GX_CA_A0, GX_CA_TEXA, GX_CA_ZERO);
|
|
GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
|
|
dKy_GxFog_set();
|
|
GXSetBlendMode(GX_BM_BLEND, GX_BL_SRC_ALPHA, GX_BL_INV_SRC_ALPHA, GX_LO_SET);
|
|
GXSetAlphaCompare(GX_GREATER, 0, GX_AOP_OR, GX_GREATER, 0);
|
|
GXSetZMode(GX_TRUE, GX_LEQUAL, GX_FALSE);
|
|
GXSetCullMode(GX_CULL_NONE);
|
|
GXSetNumIndStages(0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_TEX0, GX_TEX_ST, GX_S16, 8);
|
|
GXClearVtxDesc();
|
|
GXSetVtxDesc(GX_VA_POS, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_TEX0, GX_DIRECT);
|
|
MTXRotDeg(rotMtx, 'Z', rot);
|
|
MTXConcat(camMtx, rotMtx, camMtx);
|
|
GXLoadPosMtxImm(drawMtx, GX_PNMTX0);
|
|
rot += 1.3f;
|
|
if (rot < 0.0f)
|
|
rot = 719.0f;
|
|
GXSetCurrentMtx(GX_PNMTX0);
|
|
|
|
for (s32 i = 0; i < dKy_getEnvlight().mPoisonCount; i++) {
|
|
f32 size = pPkt->mEff[i].mSize;
|
|
if (pPkt->mEff[i].mAlpha <= 0.0f)
|
|
continue;
|
|
|
|
GXLoadTexObj(&texObj, GX_TEXMAP0);
|
|
|
|
f32 cosR = std::fabsf(cM_scos(envLight.mpPoisonPacket->mCount * 500.0f + i * 4000));
|
|
cosR *= cosR;
|
|
|
|
reg0.r = 95.0f + -50.0f * cosR;
|
|
reg0.g = 186.0f + -50.0f * cosR;
|
|
reg0.b = 226.0f + -56.0f * cosR;
|
|
|
|
reg1.r = 115.0f + -6.0f * cosR;
|
|
reg1.g = 206.0f + -146.0f * cosR;
|
|
reg1.b = 255.0f + -50.0f * cosR;
|
|
|
|
reg0.a = pPkt->mEff[i].mAlpha * 255.0f;
|
|
|
|
GXSetTevColor(GX_TEVREG0, reg0);
|
|
GXSetTevColor(GX_TEVREG1, reg1);
|
|
|
|
p.x = pPkt->mBasePos.x + pPkt->mEff[i].mPos.x;
|
|
p.y = pPkt->mBasePos.y + pPkt->mEff[i].mPos.y;
|
|
p.z = pPkt->mBasePos.z + pPkt->mEff[i].mPos.z;
|
|
|
|
vp.x = -size;
|
|
vp.y = size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[0].x = p.x + lp.x;
|
|
pos[0].y = p.y + lp.y;
|
|
pos[0].z = p.z + lp.z;
|
|
|
|
vp.x = size;
|
|
vp.y = size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[1].x = p.x + lp.x;
|
|
pos[1].y = p.y + lp.y;
|
|
pos[1].z = p.z + lp.z;
|
|
|
|
vp.x = size;
|
|
vp.y = -size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[2].x = p.x + lp.x;
|
|
pos[2].y = p.y + lp.y;
|
|
pos[2].z = p.z + lp.z;
|
|
|
|
vp.x = -size;
|
|
vp.y = -size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[3].x = p.x + lp.x;
|
|
pos[3].y = p.y + lp.y;
|
|
pos[3].z = p.z + lp.z;
|
|
|
|
GXBegin(GX_QUADS, GX_VTXFMT0, 4);
|
|
GXPosition3f32(pos[0].x, pos[0].y, pos[0].z);
|
|
GXTexCoord2s16(0, 0);
|
|
GXPosition3f32(pos[1].x, pos[1].y, pos[1].z);
|
|
GXTexCoord2s16(0xFF, 0);
|
|
GXPosition3f32(pos[2].x, pos[2].y, pos[2].z);
|
|
GXTexCoord2s16(0xFF, 0xFF);
|
|
GXPosition3f32(pos[3].x, pos[3].y, pos[3].z);
|
|
GXTexCoord2s16(0, 0xFF);
|
|
GXEnd();
|
|
}
|
|
|
|
#if VERSION != VERSION_JPN
|
|
GXSetClipMode(GX_CLIP_ENABLE);
|
|
J3DShape::resetVcdVatCache();
|
|
#endif
|
|
}
|
|
|
|
/* 800973CC-80097AD0 .text dKyr_drawHousi__FPA4_fPPUc */
|
|
void dKyr_drawHousi(Mtx drawMtx, u8** pImg) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 80097AD0-800987B8 .text dKyr_drawKazanbai__FPA4_fPPUc */
|
|
void dKyr_drawKazanbai(Mtx drawMtx, u8** pImg) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 800987B8-80098FF0 .text dKyr_drawSnow__FPA4_fPPUc */
|
|
void dKyr_drawSnow(Mtx drawMtx, u8** pImg) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 80098FF0-80099D38 .text dKyr_drawStar__FPA4_fPPUc */
|
|
void dKyr_drawStar(Mtx drawMtx, u8** pImg) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 80099D38-8009A5D4 .text drawWave__FPA4_fPPUc */
|
|
void drawWave(Mtx drawMtx, u8** pImg) {
|
|
/* Nonmatching */
|
|
dKankyo_wave_Packet* pPkt;
|
|
camera_class* pCamera;
|
|
GXTexObj texObj;
|
|
Mtx camMtx;
|
|
Mtx rotMtx;
|
|
cXyz pos[4];
|
|
cXyz windvec;
|
|
cXyz p;
|
|
cXyz vp;
|
|
cXyz lp;
|
|
cXyz dummy;
|
|
cXyz tilt;
|
|
GXColor dif, amb;
|
|
|
|
pPkt = dKy_getEnvlight().mpWavePacket;
|
|
pCamera = dComIfGp_getCamera(0);
|
|
|
|
if (!(dKy_getEnvlight().mWaveChan.mWaveFlatInter >= 1.0f) && dComIfGd_getView() != NULL) {
|
|
MTXInverse(dComIfGd_getViewRotMtx(), camMtx);
|
|
} else {
|
|
return;
|
|
}
|
|
|
|
f32 rot = cM_sht2d(pCamera->mBank);
|
|
j3dSys.reinitGX();
|
|
|
|
GXSetClipMode(GX_CLIP_ENABLE);
|
|
|
|
s32 texidx = strcmp(dComIfGp_getStartStageName(), "MajyuE") == 0 ? 1 : 0;
|
|
dKyr_set_btitex(&texObj, (ResTIMG*)pImg[texidx]);
|
|
|
|
GXSetNumChans(0);
|
|
GXSetNumTexGens(1);
|
|
GXSetTexCoordGen(GX_TEXCOORD0, GX_TG_MTX2x4, GX_TG_TEX0, GX_IDENTITY);
|
|
dKy_get_seacolor(&amb, &dif);
|
|
GXSetTevColor(GX_TEVREG0, dif);
|
|
GXSetTevKColorSel(GX_TEVSTAGE0, GX_TEV_KCSEL_K0);
|
|
GXSetTevKAlphaSel(GX_TEVSTAGE0, GX_TEV_KASEL_K3_A);
|
|
GXSetTevKColor(GX_KCOLOR0, amb);
|
|
GXSetTevKColor(GX_KCOLOR3, amb);
|
|
GXSetNumTevStages(1);
|
|
GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD0, GX_TEXMAP0, GX_COLOR_NULL);
|
|
GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_C0, GX_CC_KONST, GX_CC_TEXC, GX_CC_ZERO);
|
|
GXSetTevColorOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
|
|
GXSetTevAlphaIn(GX_TEVSTAGE0, GX_CA_ZERO, GX_CA_KONST, GX_CA_TEXA, GX_CA_ZERO);
|
|
GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
|
|
dKy_GxFog_sea_set();
|
|
GXSetBlendMode(GX_BM_BLEND, GX_BL_SRC_ALPHA, GX_BL_INV_SRC_ALPHA, GX_LO_SET);
|
|
GXSetAlphaCompare(GX_GREATER, 0, GX_AOP_OR, GX_GREATER, 0);
|
|
GXSetZCompLoc(GX_FALSE);
|
|
GXSetZMode(GX_TRUE, GX_LEQUAL, GX_TRUE);
|
|
GXSetCullMode(GX_CULL_NONE);
|
|
GXSetNumIndStages(0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_TEX0, GX_TEX_ST, GX_S16, 8);
|
|
GXClearVtxDesc();
|
|
GXSetVtxDesc(GX_VA_POS, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_TEX0, GX_DIRECT);
|
|
MTXRotDeg(rotMtx, 'Z', rot);
|
|
MTXConcat(camMtx, rotMtx, camMtx);
|
|
GXLoadPosMtxImm(drawMtx, GX_PNMTX0);
|
|
GXSetCurrentMtx(GX_PNMTX0);
|
|
|
|
for (s32 i = 0; i < dKy_getEnvlight().mWaveChan.mWaveCount; i++) {
|
|
p.x = pPkt->mEff[i].mBasePos.x + pPkt->mEff[i].mPos.x;
|
|
p.y = pPkt->mEff[i].mBasePos.y + pPkt->mEff[i].mPos.y;
|
|
p.z = pPkt->mEff[i].mBasePos.z + pPkt->mEff[i].mPos.z;
|
|
|
|
f32 wave = sin(pPkt->mEff[i].mCounter);
|
|
if (wave <= 0.0f)
|
|
continue;
|
|
|
|
f32 scale = dKy_getEnvlight().mWaveChan.mWaveScale * pPkt->mEff[i].mScale * wave;
|
|
f32 scaleBottom = dKy_getEnvlight().mWaveChan.mWaveScaleBottom * scale;
|
|
f32 strength = pPkt->mEff[i].mStrengthEnv;
|
|
f32 height = strength * scale;
|
|
f32 width = scaleBottom * (strength - 0.000015f * (i * 32) * height);
|
|
if (height <= 0.0f)
|
|
continue;
|
|
|
|
GXLoadTexObj(&texObj, GX_TEXMAP0);
|
|
amb.a = pPkt->mEff[i].mAlpha * 255.0f;
|
|
GXSetTevKColor(GX_KCOLOR3, amb);
|
|
|
|
if (pPkt->mSkewDir < 0.0f) {
|
|
vp.x = -width + width * -(pPkt->mEff[i].mSpeed * 1.2f) * pPkt->mSkewWidth;
|
|
} else {
|
|
vp.x = -width - width * -(pPkt->mEff[i].mSpeed * 1.2f) * pPkt->mSkewWidth;
|
|
}
|
|
vp.y = height;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[0].x = p.x + lp.x;
|
|
pos[0].y = p.y + lp.y;
|
|
pos[0].z = p.z + lp.z;
|
|
|
|
if (pPkt->mSkewDir < 0.0f) {
|
|
vp.x = width + width * -(pPkt->mEff[i].mSpeed * 1.2f) * pPkt->mSkewWidth;
|
|
} else {
|
|
vp.x = width - width * -(pPkt->mEff[i].mSpeed * 1.2f) * pPkt->mSkewWidth;
|
|
}
|
|
vp.y = height;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[1].x = p.x + lp.x;
|
|
pos[1].y = p.y + lp.y;
|
|
pos[1].z = p.z + lp.z;
|
|
|
|
vp.x = width;
|
|
vp.y = 0.0f;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[2].x = p.x + lp.x;
|
|
pos[2].y = p.y + lp.y;
|
|
pos[2].z = p.z + lp.z;
|
|
|
|
vp.x = -width;
|
|
vp.y = 0.0f;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[3].x = p.x + lp.x;
|
|
pos[3].y = p.y + lp.y;
|
|
pos[3].z = p.z + lp.z;
|
|
|
|
for (s32 j = 0; j < 1; j++) {
|
|
static const cXyz add_table[4] = {
|
|
cXyz(0.0f, 0.0f, 0.0f),
|
|
cXyz(800.0f, 0.0f, 400.0f),
|
|
cXyz(600.0f, 0.0f, 200.0f),
|
|
cXyz(200.0f, 0.0f, 800.0f),
|
|
};
|
|
|
|
GXBegin(GX_QUADS, GX_VTXFMT0, 4);
|
|
GXPosition3f32(pos[0].x + add_table[j].x, pos[0].y + add_table[j].y, pos[0].z + add_table[j].z);
|
|
GXTexCoord2s16(0, 0);
|
|
GXPosition3f32(pos[1].x + add_table[j].x, pos[1].y + add_table[j].y, pos[1].z + add_table[j].z);
|
|
GXTexCoord2s16(0xFA, 0);
|
|
GXPosition3f32(pos[2].x + add_table[j].x, pos[2].y + add_table[j].y, pos[2].z + add_table[j].z);
|
|
GXTexCoord2s16(0xFA, 0xFA);
|
|
GXPosition3f32(pos[3].x + add_table[j].x, pos[3].y + add_table[j].y, pos[3].z + add_table[j].z);
|
|
GXTexCoord2s16(0, 0xFA);
|
|
GXEnd();
|
|
}
|
|
}
|
|
|
|
#if VERSION != VERSION_JPN
|
|
J3DShape::resetVcdVatCache();
|
|
#endif
|
|
}
|
|
|
|
/* 8009A5D4-8009AB88 .text drawCloudShadow__FPA4_fPPUc */
|
|
void drawCloudShadow(Mtx drawMtx, u8** pImg) {
|
|
dScnKy_env_light_c& envLight = dKy_getEnvlight();
|
|
camera_class *pCamera = (camera_class*)dComIfGp_getCamera(0);
|
|
dKankyo_cloud_Packet* pPkt = g_env_light.mpMoyaPacket;
|
|
static f32 rot = 0.0f;
|
|
GXTexObj texObj;
|
|
Mtx camMtx;
|
|
Mtx rotMtx;
|
|
cXyz pos[4];
|
|
cXyz windvec;
|
|
cXyz vp;
|
|
cXyz lp;
|
|
cXyz p;
|
|
cXyz dummy;
|
|
cXyz tilt;
|
|
|
|
if (pPkt->mCount <= 0)
|
|
return;
|
|
|
|
j3dSys.reinitGX();
|
|
if (dComIfGd_getView() != NULL) {
|
|
MTXInverse(dComIfGd_getViewRotMtx(), camMtx);
|
|
} else {
|
|
return;
|
|
}
|
|
|
|
#if VERSION != VERSION_JPN
|
|
GXSetClipMode(GX_CLIP_DISABLE);
|
|
#endif
|
|
|
|
GXColor reg0, reg1;
|
|
if (dKy_getEnvlight().mMoyaMode != 3 && dKy_getEnvlight().mMoyaMode != 4) {
|
|
reg0.r = envLight.mBG0_K0.r;
|
|
reg0.g = envLight.mBG0_K0.g;
|
|
reg0.b = envLight.mBG0_K0.b;
|
|
|
|
reg1.r = envLight.mBG0_K0.r;
|
|
reg1.g = envLight.mBG0_K0.g;
|
|
reg1.b = envLight.mBG0_K0.b;
|
|
} else {
|
|
reg0.r = envLight.mBG3_K0.r;
|
|
reg0.g = envLight.mBG3_K0.g;
|
|
reg0.b = envLight.mBG3_K0.b;
|
|
|
|
reg1.r = envLight.mBG3_K0.r;
|
|
reg1.g = envLight.mBG3_K0.g;
|
|
reg1.b = envLight.mBG3_K0.b;
|
|
}
|
|
|
|
dKyr_set_btitex(&texObj, (ResTIMG*)pImg[0]);
|
|
|
|
GXSetNumChans(0);
|
|
GXSetTevColor(GX_TEVREG0, reg0);
|
|
GXSetTevColor(GX_TEVREG1, reg1);
|
|
GXSetNumTexGens(1);
|
|
GXSetTexCoordGen(GX_TEXCOORD0, GX_TG_MTX2x4, GX_TG_TEX0, GX_IDENTITY);
|
|
GXSetNumTevStages(1);
|
|
GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD0, GX_TEXMAP0, GX_COLOR_NULL);
|
|
GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_C1, GX_CC_C0, GX_CC_TEXC, GX_CC_ZERO);
|
|
GXSetTevColorOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, true, GX_TEVPREV);
|
|
GXSetTevAlphaIn(GX_TEVSTAGE0, GX_CA_ZERO, GX_CA_A0, GX_CA_TEXA, GX_CA_ZERO);
|
|
GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, true, GX_TEVPREV);
|
|
dKy_GxFog_set();
|
|
GXSetBlendMode(GX_BM_BLEND, GX_BL_SRC_ALPHA, GX_BL_INV_SRC_ALPHA, GX_LO_SET);
|
|
GXSetAlphaCompare(GX_GREATER, 0, GX_AOP_OR, GX_GREATER, 0);
|
|
GXSetZMode(GX_FALSE, GX_LEQUAL, GX_FALSE);
|
|
GXSetCullMode(GX_CULL_NONE);
|
|
GXSetNumIndStages(0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_TEX0, GX_TEX_ST, GX_S16, 8);
|
|
GXClearVtxDesc();
|
|
GXSetVtxDesc(GX_VA_POS, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_TEX0, GX_DIRECT);
|
|
MTXRotDeg(rotMtx, 'Z', rot);
|
|
MTXConcat(camMtx, rotMtx, camMtx);
|
|
GXLoadPosMtxImm(drawMtx, GX_PNMTX0);
|
|
rot -= 1.5f;
|
|
if (rot < 0.0f)
|
|
rot = 719.0f;
|
|
GXSetCurrentMtx(GX_PNMTX0);
|
|
|
|
for (s32 i = 0; i < pPkt->mCount; i++) {
|
|
f32 size = pPkt->mEff[i].mSize;
|
|
if (pPkt->mEff[i].mAlpha <= 0.000001f)
|
|
continue;
|
|
|
|
GXLoadTexObj(&texObj, GX_TEXMAP0);
|
|
|
|
reg0.a = pPkt->mEff[i].mAlpha * 255.0f;
|
|
GXSetTevColor(GX_TEVREG0, reg0);
|
|
|
|
p.x = pPkt->mEff[i].mBasePos.x + pPkt->mEff[i].mPos.x;
|
|
p.y = pPkt->mEff[i].mBasePos.y + pPkt->mEff[i].mPos.y;
|
|
p.z = pPkt->mEff[i].mBasePos.z + pPkt->mEff[i].mPos.z;
|
|
|
|
vp.x = -size;
|
|
vp.y = size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[0].x = p.x + lp.x;
|
|
pos[0].y = p.y + lp.y;
|
|
pos[0].z = p.z + lp.z;
|
|
|
|
vp.x = size;
|
|
vp.y = size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[1].x = p.x + lp.x;
|
|
pos[1].y = p.y + lp.y;
|
|
pos[1].z = p.z + lp.z;
|
|
|
|
vp.x = size;
|
|
vp.y = -size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[2].x = p.x + lp.x;
|
|
pos[2].y = p.y + lp.y;
|
|
pos[2].z = p.z + lp.z;
|
|
|
|
vp.x = -size;
|
|
vp.y = -size;
|
|
vp.z = 0.0f;
|
|
MTXMultVec(camMtx, &vp, &lp);
|
|
pos[3].x = p.x + lp.x;
|
|
pos[3].y = p.y + lp.y;
|
|
pos[3].z = p.z + lp.z;
|
|
|
|
GXBegin(GX_QUADS, GX_VTXFMT0, 4);
|
|
GXPosition3f32(pos[0].x, pos[0].y, pos[0].z);
|
|
GXTexCoord2s16(0, 0);
|
|
GXPosition3f32(pos[1].x, pos[1].y, pos[1].z);
|
|
GXTexCoord2s16(0xFF, 0);
|
|
GXPosition3f32(pos[2].x, pos[2].y, pos[2].z);
|
|
GXTexCoord2s16(0xFF, 0xFF);
|
|
GXPosition3f32(pos[3].x, pos[3].y, pos[3].z);
|
|
GXTexCoord2s16(0, 0xFF);
|
|
GXEnd();
|
|
}
|
|
|
|
#if VERSION != VERSION_JPN
|
|
GXSetClipMode(GX_CLIP_ENABLE);
|
|
J3DShape::resetVcdVatCache();
|
|
#endif
|
|
}
|
|
|
|
/* 8009AB88-8009B9C4 .text drawVrkumo__FPA4_fR8GXColorPPUc */
|
|
void drawVrkumo(Mtx drawMtx, GXColor& clr, u8** pImg) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 8009B9C4-8009B9D8 .text dKyr_thunder_init__Fv */
|
|
void dKyr_thunder_init() {
|
|
g_env_light.mThunderEff.mState = 0;
|
|
}
|
|
|
|
/* 8009B9D8-8009BDEC .text dKyr_thunder_move__Fv */
|
|
void dKyr_thunder_move() {
|
|
EF_THUNDER * pThunder = &g_env_light.mThunderEff;
|
|
camera_class * pCamera = dComIfGp_getCamera(0);
|
|
|
|
switch (pThunder->mState) {
|
|
case 0:
|
|
{
|
|
pThunder->mFlashTimer = 0.0f;
|
|
pThunder->field_0xc = 0.0f;
|
|
pThunder->field_0x10 = 0.0f;
|
|
|
|
if (cM_rndF(1.0f) < 0.007f) {
|
|
pThunder->mState = 11;
|
|
} else if (cM_rndF(1.0f) < 0.005f && g_env_light.mThunderEff.mMode < 10) {
|
|
pThunder->mLightInfluence.mPos.x = pCamera->mLookat.mEye.x;
|
|
pThunder->mLightInfluence.mPos.y = pCamera->mLookat.mEye.y;
|
|
pThunder->mLightInfluence.mPos.z = pCamera->mLookat.mEye.z;
|
|
pThunder->mLightInfluence.mColor.r = 0;
|
|
pThunder->mLightInfluence.mColor.g = 0;
|
|
pThunder->mLightInfluence.mColor.b = 0;
|
|
pThunder->mLightInfluence.mPower = 90000.0f;
|
|
pThunder->mLightInfluence.mFluctuation = 150.0f;
|
|
dKy_efplight_set(&pThunder->mLightInfluence);
|
|
pThunder->mState++;
|
|
}
|
|
}
|
|
break;
|
|
case 1:
|
|
case 11:
|
|
{
|
|
cLib_addCalc(&pThunder->mFlashTimer, 1.0f, 0.3f, 0.2f, 0.001f);
|
|
if (pThunder->mFlashTimer >= 1.0f) {
|
|
if (pThunder->mState < 10)
|
|
mDoAud_seStart(JA_SE_OBJ_THUNDER_NEAR, NULL);
|
|
pThunder->mState++;
|
|
}
|
|
|
|
if (cM_rndF(1.0f) < 0.18f)
|
|
fopKyM_create(PROC_KY_THUNDER, -1);
|
|
}
|
|
break;
|
|
case 2:
|
|
case 12:
|
|
{
|
|
cLib_addCalc(&pThunder->mFlashTimer, 0.0f, 0.1f, 0.05f, 0.001f);
|
|
if (pThunder->mFlashTimer <= 0.0f) {
|
|
if (pThunder->mState < 10)
|
|
dKy_efplight_cut(&pThunder->mLightInfluence);
|
|
|
|
pThunder->mState = 0;
|
|
if (g_env_light.mThunderEff.mMode == 0)
|
|
pThunder->mStatus = 0;
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
|
|
if (pThunder->mState != 0) {
|
|
if (pThunder->mState < 10) {
|
|
pThunder->mLightInfluence.mPos.x = pCamera->mLookat.mEye.x;
|
|
pThunder->mLightInfluence.mPos.y = pCamera->mLookat.mEye.y + 150.0f;
|
|
pThunder->mLightInfluence.mPos.z = pCamera->mLookat.mEye.z;
|
|
pThunder->mLightInfluence.mColor.r = (u8)(pThunder->mFlashTimer * 0.2f * 180.0f);
|
|
pThunder->mLightInfluence.mColor.g = (u8)(pThunder->mFlashTimer * 0.2f * 235.0f);
|
|
pThunder->mLightInfluence.mColor.b = (u8)(pThunder->mFlashTimer * 0.2f * 255.0f);
|
|
if (g_env_light.field_0xc98 == 0) {
|
|
dKy_actor_addcol_amb_set(0x5a, 0xa0, 0xf5, pThunder->mFlashTimer * 0.5f);
|
|
dKy_actor_addcol_dif_set(0x5a, 0xa0, 0xf5, pThunder->mFlashTimer * 0.5f);
|
|
dKy_bg_addcol_amb_set(0x32, 0x78, 0xff, pThunder->mFlashTimer * 0.7f);
|
|
dKy_bg_addcol_dif_set(0x32, 0x78, 0xff, pThunder->mFlashTimer * 0.7f);
|
|
dKy_bg1_addcol_amb_set(0x5a, 0xa0, 0xf5, pThunder->mFlashTimer * 0.35f);
|
|
dKy_bg1_addcol_dif_set(0x5a, 0xa0, 0xf5, pThunder->mFlashTimer * 0.35f);
|
|
dKy_vrbox_addcol_sky0_set(0x5a, 0xa0, 0xf5, pThunder->mFlashTimer * 0.4f);
|
|
dKy_vrbox_addcol_kasumi_set(0x5a, 0xa0, 0xf5, pThunder->mFlashTimer * 0.5f);
|
|
dKy_addcol_fog_set(0x5a, 0xa0, 0xf5, pThunder->mFlashTimer * 0.3f);
|
|
}
|
|
} else {
|
|
dKy_vrbox_addcol_sky0_set(0x5a,0xa0,0xf5,(pThunder->mFlashTimer * 0.15f));
|
|
dKy_vrbox_addcol_kasumi_set(0x5a,0xa0,0xf5,(pThunder->mFlashTimer * 0.35f));
|
|
dKy_addcol_fog_set(0x5a, 0xa0, 0xf5, pThunder->mFlashTimer * 0.12f);
|
|
}
|
|
}
|
|
}
|