mirror of
https://github.com/zeldaret/tww.git
synced 2026-06-12 05:27:14 -04:00
415 lines
12 KiB
C++
415 lines
12 KiB
C++
//
|
|
// Generated by dtk
|
|
// Translation Unit: d_a_sea.cpp
|
|
//
|
|
|
|
#include "d/actor/d_a_sea.h"
|
|
#include "d/d_com_inf_game.h"
|
|
#include "d/d_procname.h"
|
|
#include "d/d_stage.h"
|
|
#include "m_Do/m_Do_lib.h"
|
|
#include "d/actor/d_a_daiocta.h"
|
|
|
|
daSea_packet_c l_cloth;
|
|
|
|
f32 daSea_packet_c::BASE_HEIGHT = 1.0f;
|
|
|
|
daSea_WaveInfoDat wi_prm_ocean[4] = {
|
|
{
|
|
2.5f, // mHeight
|
|
7.352941E-5f, // mKm
|
|
0, // mPhase
|
|
0.98f, // mScaleX
|
|
0.2f, // mScaleZ
|
|
200, // mCounterMax
|
|
},
|
|
{
|
|
2.5f, // mHeight
|
|
8.928571E-5f, // mKm
|
|
4000, // mPhase
|
|
0.2f, // mScaleX
|
|
0.98f, // mScaleZ
|
|
190, // mCounterMax
|
|
},
|
|
{
|
|
2.5f, // mHeight
|
|
1.13636364E-4f, // mKm
|
|
8000, // mPhase
|
|
-0.98f, // mScaleX
|
|
0.2f, // mScaleZ
|
|
210, // mCounterMax
|
|
},
|
|
{
|
|
2.5f, // mHeight
|
|
1.5625E-4f, // mKm
|
|
12000, // mPhase
|
|
0.2f, // mScaleX
|
|
-0.98f, // mScaleZ
|
|
180, // mCounterMax
|
|
},
|
|
};
|
|
|
|
u8 pos_around[16] = {
|
|
0xFF, 0xFF, 0x00, 0XFF,
|
|
0x01, 0xFF, 0x01, 0x00,
|
|
0x01, 0x01, 0x00, 0x01,
|
|
0xFF, 0x01, 0xFF, 0x00,
|
|
};
|
|
|
|
/* 8015B0A4-8015B0FC .text Pos2Index__25daSea_WaterHeightInfo_MngFfPf */
|
|
int daSea_WaterHeightInfo_Mng::Pos2Index(f32 v, f32* dst) {
|
|
int idx = (v + 450000.0f) / 100000.0f;
|
|
if (dst != NULL)
|
|
*dst = (v + 450000.0f) - idx * 100000.0f;
|
|
return idx;
|
|
}
|
|
|
|
/* 8015B0FC-8015B164 .text GetHeight__25daSea_WaterHeightInfo_MngFff */
|
|
u32 daSea_WaterHeightInfo_Mng::GetHeight(f32 x, f32 z) {
|
|
int xi = Pos2Index(x, NULL);
|
|
int zi = Pos2Index(z, NULL);
|
|
return GetHeight(xi, zi);
|
|
}
|
|
|
|
/* 8015B164-8015B1E8 .text get_wave_max__Fi */
|
|
int get_wave_max(int roomNo) {
|
|
dStage_Multi_c * multi = dComIfGp_getStage().getMulti();
|
|
if (multi == NULL)
|
|
return 10;
|
|
|
|
dStage_Mult_info* entry = multi->m_entries;
|
|
for (int i = 0; i < multi->num; i++, entry++)
|
|
if (roomNo == entry->mRoomNo)
|
|
return entry->mWaveMax;
|
|
|
|
return 10;
|
|
}
|
|
|
|
/* 8015B1E8-8015B288 .text GetHeight__25daSea_WaterHeightInfo_MngFii */
|
|
u32 daSea_WaterHeightInfo_Mng::GetHeight(int x, int z) {
|
|
if (x < 0 || 9 <= x || z < 0 || 9 <= z)
|
|
return 10;
|
|
|
|
if (dStage_stagInfo_GetSTType(dComIfGp_getStageStagInfo()) == dStageType_SEA_e) {
|
|
return mHeight[z][x];
|
|
} else {
|
|
return get_wave_max(dComIfGp_roomControl_getStayNo());
|
|
}
|
|
}
|
|
|
|
/* 8015B288-8015B2D0 .text calcMinMax__FiPfPf */
|
|
void calcMinMax(int v, f32* min, f32* max) {
|
|
*min = v * 100000.0f - 450000.0f;
|
|
*max = *min + 100000.0f;
|
|
}
|
|
|
|
/* 8015B2D0-8015B328 .text GetArea__25daSea_WaterHeightInfo_MngFiiPfPfPfPf */
|
|
void daSea_WaterHeightInfo_Mng::GetArea(int x, int z, f32* minX, f32* minZ, f32* maxX, f32* maxZ) {
|
|
calcMinMax(x, minX, maxX);
|
|
calcMinMax(z, minZ, maxZ);
|
|
}
|
|
|
|
/* 8015B328-8015B3FC .text SetInf__25daSea_WaterHeightInfo_MngFv */
|
|
void daSea_WaterHeightInfo_Mng::SetInf() {
|
|
dStage_Multi_c * multi = dComIfGp_getStage().getMulti();
|
|
|
|
for (s32 i = 0; i < 9; i++)
|
|
for (s32 j = 0; j < 9; j++)
|
|
mHeight[i][j] = 10;
|
|
|
|
if (multi != NULL) {
|
|
s32 roomNo = 1;
|
|
for (s32 i = 1; i < 8; i++) {
|
|
for (s32 j = 1; j < 8; j++) {
|
|
mHeight[i][j] = get_wave_max(roomNo);
|
|
roomNo++;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 8015B3FC-8015B43C .text __ct__14daSea_WaveInfoFv */
|
|
daSea_WaveInfo::daSea_WaveInfo() {
|
|
for (s32 i = 0; i < (s32)ARRAY_SIZE(mCounters); i++) {
|
|
m04[i] = 0.0f;
|
|
mCounters[i] = 0;
|
|
}
|
|
mCurScale = 1.0f;
|
|
}
|
|
|
|
/* 8015B43C-8015B484 .text __dt__14daSea_WaveInfoFv */
|
|
daSea_WaveInfo::~daSea_WaveInfo() {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 8015B484-8015B4D4 .text AddCounter__14daSea_WaveInfoFv */
|
|
void daSea_WaveInfo::AddCounter() {
|
|
for (s32 i = 0; i < (s32)ARRAY_SIZE(mCounters); i++) {
|
|
mCounters[i]++;
|
|
if (mCounters[i] >= mWaveInfoTable[i].mCounterMax)
|
|
mCounters[i] = 0;
|
|
}
|
|
}
|
|
|
|
/* 8015B4D4-8015B530 .text GetRatio__14daSea_WaveInfoFi */
|
|
f32 daSea_WaveInfo::GetRatio(int idx) {
|
|
return (f32)mCounters[idx] / (f32)mWaveInfoTable[idx].mCounterMax;
|
|
}
|
|
|
|
/* 8015B530-8015B54C .text GetKm__14daSea_WaveInfoFi */
|
|
f32 daSea_WaveInfo::GetKm(int idx) {
|
|
return mWaveInfoTable[idx].mKm * 6.28f;
|
|
}
|
|
|
|
/* 8015B54C-8015B56C .text GetScale__14daSea_WaveInfoFf */
|
|
f32 daSea_WaveInfo::GetScale(f32 v) {
|
|
mCurScale += (v - mCurScale) / 100.0f;
|
|
return mCurScale;
|
|
}
|
|
|
|
/* 8015B56C-8015B7A0 .text create__14daSea_packet_cFR4cXyz */
|
|
bool daSea_packet_c::create(cXyz& pos) {
|
|
/* Nonmatching */
|
|
BASE_HEIGHT = 1.0f;
|
|
BASE_HEIGHT = pos.y + 1.0f;
|
|
|
|
mFlatInter = 0.0f;
|
|
mpHeightTable = new f32[65 * 65];
|
|
if (mpHeightTable == NULL)
|
|
return false;
|
|
|
|
mWaterHeightMgr.SetInf();
|
|
mWaveInfo.SetDat(wi_prm_ocean);
|
|
CleanUp();
|
|
mInitFlag = true;
|
|
mRoomNo = -1;
|
|
mFlags = 0;
|
|
mAnimCounter = 0;
|
|
|
|
ResTIMG* timg = (ResTIMG*)dComIfG_getObjectRes("Always", ALWAYS_BTI_B_SEA_TEX0AND2);
|
|
GXInitTexObj(&mTexSea0, (char*)timg + timg->imageOffset, timg->width, timg->height,
|
|
(GXTexFmt)timg->format, (GXTexWrapMode)timg->wrapS, (GXTexWrapMode)timg->wrapT,
|
|
(GXBool)(timg->mipmapCount > 1));
|
|
GXInitTexObjLOD(&mTexSea0, (GXTexFilter)timg->minFilter, (GXTexFilter)timg->magFilter,
|
|
timg->minLOD * 0.125f, timg->maxLOD * 0.125f, 0.9f,
|
|
(GXBool)timg->biasClamp, (GXBool)timg->doEdgeLOD,
|
|
(GXAnisotropy)timg->maxAnisotropy);
|
|
GXInitTexObj(&mTexSea1, (char*)timg + timg->imageOffset, timg->width, timg->height,
|
|
(GXTexFmt)timg->format, (GXTexWrapMode)timg->wrapS, (GXTexWrapMode)timg->wrapT,
|
|
(GXBool)(timg->mipmapCount > 1));
|
|
GXInitTexObjLOD(&mTexSea1, (GXTexFilter)timg->minFilter, (GXTexFilter)timg->magFilter,
|
|
timg->minLOD * 0.125f, timg->maxLOD * 0.125f, 0.0f,
|
|
(GXBool)timg->biasClamp, (GXBool)timg->doEdgeLOD,
|
|
(GXAnisotropy)timg->maxAnisotropy);
|
|
|
|
timg = (ResTIMG*)dComIfG_getObjectRes("Always", ALWAYS_BTI_B_WYURAYURA_TEX1);
|
|
mDoLib_setResTimgObj(timg, &mTexYura, 0, NULL);
|
|
|
|
return true;
|
|
}
|
|
|
|
/* 8015B7A0-8015B7E4 .text CleanUp__14daSea_packet_cFv */
|
|
void daSea_packet_c::CleanUp() {
|
|
s32 idx = 0;
|
|
for (s32 i = 0; i < 65; i++)
|
|
for (s32 j = 0; j < 65; j++)
|
|
mpHeightTable[idx++] = BASE_HEIGHT;
|
|
mCurPos.zero();
|
|
}
|
|
|
|
/* 8015B7E4-8015B84C .text __ct__14daSea_packet_cFv */
|
|
daSea_packet_c::daSea_packet_c() {}
|
|
|
|
/* 8015B84C-8015B86C .text SetFlat__14daSea_packet_cFv */
|
|
void daSea_packet_c::SetFlat() {
|
|
mFlags |= 0x01;
|
|
mFlatTarget = 0.0f;
|
|
mFlatInterCounter = 150.0f;
|
|
}
|
|
|
|
/* 8015B86C-8015B884 .text ClrFlat__14daSea_packet_cFv */
|
|
void daSea_packet_c::ClrFlat() {
|
|
mFlags &= ~0x01;
|
|
mFlatInterCounter = 150.0f;
|
|
}
|
|
|
|
/* 8015B884-8015BA18 .text CalcFlatInterTarget__14daSea_packet_cFR4cXyz */
|
|
f32 daSea_packet_c::CalcFlatInterTarget(cXyz&) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 8015BA18-8015BAD8 .text CalcFlatInter__14daSea_packet_cFv */
|
|
void daSea_packet_c::CalcFlatInter() {
|
|
if (mFlags & 1) {
|
|
if (mFlatInterCounter != 0.0f) {
|
|
mFlatInter += (mFlatTarget - mFlatInter) / mFlatInterCounter;
|
|
mFlatInterCounter--;
|
|
} else {
|
|
mFlatInter = mFlatTarget;
|
|
}
|
|
} else {
|
|
f32 target = CalcFlatInterTarget(mPlayerPos);
|
|
if (mFlatInterCounter != 0.0f) {
|
|
mFlatInter += (target - mFlatInter) / mFlatInterCounter;
|
|
mFlatInterCounter--;
|
|
} else {
|
|
mFlatInter = target;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 8015BAD8-8015BAF8 .text daSea_Init__Fv */
|
|
void daSea_Init() {
|
|
l_cloth.mInitFlag = false;
|
|
l_cloth.mCullStopFlag = true;
|
|
l_cloth.m13A = true;
|
|
}
|
|
|
|
/* 8015BAF8-8015BB60 .text daSea_ChkAreaBeforePos__Fff */
|
|
void daSea_ChkAreaBeforePos(f32, f32) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 8015BB60-8015BBFC .text daSea_ChkArea__Fff */
|
|
bool daSea_ChkArea(f32, f32) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 8015BBFC-8015BDB0 .text daSea_calcWave__Fff */
|
|
f32 daSea_calcWave(f32, f32) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 8015BDB0-8015C010 .text daSea_GetPoly__FPvPFPvR4cXyzR4cXyzR4cXyz_vRC4cXyzRC4cXyz */
|
|
void daSea_GetPoly(void*, void (*)(void*, cXyz&, cXyz&, cXyz&), const cXyz&, const cXyz&) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 8015C010-8015C11C .text SetCullStopFlag__14daSea_packet_cFv */
|
|
void daSea_packet_c::SetCullStopFlag() {
|
|
/* Nonmatching */
|
|
if (strcmp(dComIfGp_getStartStageName(), "A_umikz") == 0) {
|
|
mCullStopFlag = false;
|
|
} else {
|
|
s32 height = mWaterHeightMgr.GetHeight(mIdxX, mIdxZ);
|
|
if (height != 0) {
|
|
mCullStopFlag = false;
|
|
} else {
|
|
f32 minX, minZ, maxX, maxZ;
|
|
mWaterHeightMgr.GetArea(mIdxX, mIdxZ, &minX, &minZ, &maxX, &maxZ);
|
|
|
|
f32 gridZ1 = minZ + 25600.0f;
|
|
f32 gridZ0 = minZ - 25600.0f;
|
|
f32 gridX1 = minX + 25600.0f;
|
|
f32 gridX0 = minX - 25600.0f;
|
|
|
|
if ((gridX0 < mPlayerPos.x) && (mPlayerPos.x < gridX1) && (gridZ0 < mPlayerPos.z) && (mPlayerPos.z < gridZ1))
|
|
mCullStopFlag = true;
|
|
else
|
|
mCullStopFlag = false;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 8015C11C-8015C1DC .text CheckRoomChange__14daSea_packet_cFv */
|
|
void daSea_packet_c::CheckRoomChange() {
|
|
dStage_roomDt_c * room = dComIfGp_roomControl_getStatusRoomDt(dComIfGp_roomControl_getStayNo());
|
|
if (room != NULL) {
|
|
mRoomNo = dComIfGp_roomControl_getStayNo();
|
|
u32 procName = PROC_DAIOCTA;
|
|
daDaiocta_c* octa = (daDaiocta_c *)fopAcM_SearchByName(PROC_DAIOCTA);
|
|
if (octa == NULL) {
|
|
if (mFlags & 0x01) {
|
|
ClrFlat();
|
|
}
|
|
} else {
|
|
if (!dComIfGs_isSwitch(octa->getSw(), fopAcM_GetHomeRoomNo(octa))) {
|
|
SetFlat();
|
|
} else {
|
|
ClrFlat();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 8015C1DC-8015C214 .text daSea_execute__FR4cXyz */
|
|
void daSea_execute(cXyz& pos) {
|
|
if (l_cloth.mInitFlag)
|
|
l_cloth.execute(pos);
|
|
}
|
|
|
|
/* 8015C214-8015C75C .text execute__14daSea_packet_cFR4cXyz */
|
|
void daSea_packet_c::execute(cXyz&) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 8015C75C-8015D80C .text draw__14daSea_packet_cFv */
|
|
void daSea_packet_c::draw() {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 8015D80C-8015D87C .text daSea_Draw__FP9sea_class */
|
|
static BOOL daSea_Draw(sea_class* i_this) {
|
|
dComIfGd_setListSky();
|
|
j3dSys.getDrawBuffer(1)->entryImm(&l_cloth, 31);
|
|
dComIfGd_setList();
|
|
return TRUE;
|
|
}
|
|
|
|
/* 8015D87C-8015D8D0 .text daSea_Execute__FP9sea_class */
|
|
static BOOL daSea_Execute(sea_class* i_this) {
|
|
fopAc_ac_c* player = dComIfGp_getPlayer(0);
|
|
cXyz pos = player->current.pos;
|
|
l_cloth.execute(pos);
|
|
return TRUE;
|
|
}
|
|
|
|
/* 8015D8D0-8015D8E8 .text daSea_IsDelete__FP9sea_class */
|
|
static BOOL daSea_IsDelete(sea_class*) {
|
|
l_cloth.mInitFlag = false;
|
|
return TRUE;
|
|
}
|
|
|
|
/* 8015D8E8-8015D8F0 .text daSea_Delete__FP9sea_class */
|
|
static BOOL daSea_Delete(sea_class*) {
|
|
return TRUE;
|
|
}
|
|
|
|
/* 8015D8F0-8015D924 .text CheckCreateHeap__FP10fopAc_ac_c */
|
|
static BOOL CheckCreateHeap(fopAc_ac_c* i_this) {
|
|
return l_cloth.create(i_this->current.pos);
|
|
}
|
|
|
|
/* 8015D924-8015D99C .text daSea_Create__FP10fopAc_ac_c */
|
|
static s32 daSea_Create(fopAc_ac_c* i_this) {
|
|
fopAcM_SetupActor(i_this, sea_class);
|
|
if (!fopAcM_entrySolidHeap(i_this, CheckCreateHeap, 0xA000))
|
|
return cPhs_ERROR_e;
|
|
return cPhs_COMPLEATE_e;
|
|
}
|
|
|
|
actor_method_class l_daSea_Method = {
|
|
(process_method_func)daSea_Create,
|
|
(process_method_func)daSea_Delete,
|
|
(process_method_func)daSea_Execute,
|
|
(process_method_func)daSea_IsDelete,
|
|
(process_method_func)daSea_Draw,
|
|
};
|
|
|
|
actor_process_profile_definition g_profile_SEA = {
|
|
/* LayerID */ fpcLy_CURRENT_e,
|
|
/* ListID */ 2,
|
|
/* ListPrio */ fpcPi_CURRENT_e,
|
|
/* ProcName */ PROC_SEA,
|
|
/* Proc SubMtd */ &g_fpcLf_Method.mBase,
|
|
/* Size */ sizeof(sea_class),
|
|
/* SizeOther */ 0,
|
|
/* Parameters */ 0,
|
|
/* Leaf SubMtd */ &g_fopAc_Method.base,
|
|
/* Priority */ 0x0077,
|
|
/* Actor SubMtd */ &l_daSea_Method,
|
|
/* Status */ fopAcStts_UNK40000_e,
|
|
/* Group */ fopAc_ACTOR_e,
|
|
/* CullType */ fopAc_CULLBOX_0_e,
|
|
};
|