mirror of
https://github.com/zeldaret/tww.git
synced 2026-06-13 05:46:18 -04:00
373 lines
12 KiB
C++
373 lines
12 KiB
C++
//
|
|
// Generated by dtk
|
|
// Translation Unit: d_grass.cpp
|
|
//
|
|
|
|
#include "d/d_grass.h"
|
|
#include "f_op/f_op_overlap_mng.h"
|
|
#include "d/d_bg_s_gnd_chk.h"
|
|
#include "d/d_com_inf_game.h"
|
|
#include "d/d_kankyo.h"
|
|
#include "d/d_kankyo_wether.h"
|
|
#include "m_Do/m_Do_mtx.h"
|
|
#include "m_Do/m_Do_lib.h"
|
|
#include "m_Do/m_Do_graphic.h"
|
|
#include "SSystem/SComponent/c_counter.h"
|
|
#include "dolphin/gf/GFGeometry.h"
|
|
#include "dolphin/gf/GFTev.h"
|
|
|
|
static Vec dummy[2] = {};
|
|
u8 l_K_kusa_00TEX[0x1000] ALIGN_DECL(32) = {};
|
|
Vec l_Vmori_pos[27] = {};
|
|
GXColor l_Vmori_color[5] = {};
|
|
cXy l_Vmori_texCoord[9] = {};
|
|
u8 l_Vmori_00DL[0xb0] ALIGN_DECL(32) = {};
|
|
u8 l_Vmori_01DL[0x8c] ALIGN_DECL(32) = {};
|
|
u8 l_Vmori_matDL[0xa8] ALIGN_DECL(32) = {};
|
|
|
|
u8 l_Txa_ob_kusa_aTEX[0x800] ALIGN_DECL(32) = {};
|
|
Vec l_pos[27] = {};
|
|
GXColor l_color[8] = {};
|
|
cXy l_texCoord[9] = {};
|
|
u8 l_Oba_kusa_aDL[0xa7] ALIGN_DECL(32) = {};
|
|
u8 l_Oba_kusa_a_cutDL[0x8c] ALIGN_DECL(32) = {};
|
|
u8 l_matDL[0xa8] ALIGN_DECL(32) = {};
|
|
|
|
static bool l_CutSoundFlag;
|
|
|
|
/* 80077048-8007712C .text setBatta__FP4cXyzP8_GXColor */
|
|
void setBatta(cXyz* pos, GXColor* color) {
|
|
if (!dKy_rain_check() && !dComIfGp_event_runCheck() && strncmp(dComIfGp_getStartStageName(), "kin", 3) != 0 && strcmp(dComIfGp_getStartStageName(), "Xboss1") != 0 && cM_rnd() > 0.99f)
|
|
dComIfGp_particle_set(0x453, pos, NULL, NULL, 0xFF, NULL, -1, color, color);
|
|
}
|
|
|
|
/* 8007712C-8007734C .text WorkCo__13dGrass_data_cFP10fopAc_ac_cUli */
|
|
void dGrass_data_c::WorkCo(fopAc_ac_c* other, u32, int roomNo) {
|
|
/* Nonmatching */
|
|
cXyz delta(mPos.x - other->current.pos.x, 0.0f, mPos.z - other->current.pos.z);
|
|
f32 distSq = delta.abs2();
|
|
if (distSq > 1600.0f)
|
|
return;
|
|
|
|
delta.y = mPos.y - other->current.pos.y;
|
|
s16 rotY = cM_atan2s(delta.x, delta.z);
|
|
f32 dist = sqrtf(distSq);
|
|
dGrass_anm_c* anm;
|
|
if (mAnimIdx < 8) {
|
|
if (other->speedF > 16.0f) {
|
|
cXyz ptclPos(mPos.x, mPos.y + 20.0f, mPos.z);
|
|
dKy_tevstr_c* tevStr = dComIfGp_roomControl_getTevStr(roomNo);
|
|
dComIfGp_particle_setSimple(dComIfGp_getGrass()->mCoParticle, &ptclPos, 0xFF, tevStr->mColorK0, tevStr->mColorK0, 1);
|
|
setBatta(&mPos, &tevStr->mColorK0);
|
|
}
|
|
|
|
s32 anmIdx = dComIfGp_getGrass()->newAnm();
|
|
if (anmIdx < 0)
|
|
return;
|
|
mAnimIdx = anmIdx;
|
|
anm = &dComIfGp_getGrass()->mGrassAnm[mAnimIdx];
|
|
} else {
|
|
anm = &dComIfGp_getGrass()->mGrassAnm[mAnimIdx];
|
|
}
|
|
|
|
anm->mRotY = rotY;
|
|
anm->mRotX = cM_atan2s(40.0f - dist, 40.0f);
|
|
anm->mState = 2;
|
|
}
|
|
|
|
/* 8007734C-800775E4 .text WorkAt_NoCutAnim__13dGrass_data_cFP10fopAc_ac_cUliP15dCcMassS_HitInfP8cCcD_Obj */
|
|
void dGrass_data_c::WorkAt_NoCutAnim(fopAc_ac_c*, u32, int, dCcMassS_HitInf*, cCcD_Obj*) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 800775EC-800777CC .text WorkAt__13dGrass_data_cFP10fopAc_ac_cUliP15dCcMassS_HitInf */
|
|
void dGrass_data_c::WorkAt(fopAc_ac_c*, u32, int, dCcMassS_HitInf*) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 800777CC-800779D4 .text hitCheck__13dGrass_data_cFi */
|
|
void dGrass_data_c::hitCheck(int) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 80077A1C-80077A2C .text newData__13dGrass_room_cFP13dGrass_data_c */
|
|
void dGrass_room_c::newData(dGrass_data_c* data) {
|
|
data->mpNextData = mpData;
|
|
mpData = data;
|
|
}
|
|
|
|
/* 80077A2C-80077A90 .text deleteData__13dGrass_room_cFv */
|
|
void dGrass_room_c::deleteData() {
|
|
while (mpData != NULL) {
|
|
mpData->mState = 0;
|
|
mDoAud_seDeleteObject(&mpData->mPos);
|
|
mpData = mpData->mpNextData;
|
|
}
|
|
}
|
|
|
|
/* 80077A90-80077CB8 .text __ct__15dGrass_packet_cFv */
|
|
dGrass_packet_c::dGrass_packet_c() {
|
|
dGrass_data_c* data = mGrassData;
|
|
for (s32 i = 0; i < ARRAY_SIZE(mGrassData); i++, data++)
|
|
data->mState = 0;
|
|
mNextIdx = 0;
|
|
dGrass_anm_c* anm = mGrassAnm;
|
|
for (s32 i = 0; i < ARRAY_SIZE(mGrassAnm); i++, anm++)
|
|
anm->mState = 0;
|
|
s16 angle = 0;
|
|
for (s32 i = 0; i < 8; i++, angle += 0x2000)
|
|
setAnm(i, angle);
|
|
if (strncmp(dComIfGp_getStartStageName(), "kin", 3) == 0 || strcmp(dComIfGp_getStartStageName(), "Xboss1") == 0) {
|
|
mpPosArr = (f32*)l_Vmori_pos;
|
|
mpColorArr = l_Vmori_color;
|
|
mpTexCoordArr = (f32*)l_Vmori_texCoord;
|
|
mpMatDL = l_Vmori_matDL;
|
|
mMatDLSize = 0xa0;
|
|
mpDL = l_Vmori_00DL;
|
|
mDLSize = 0xa0;
|
|
mpDLCut = l_Vmori_01DL;
|
|
mDLCutSize = 0x80;
|
|
mCoParticle = 0x8222;
|
|
field_0x1a66a = 0x8221;
|
|
} else {
|
|
mpPosArr = (f32*)l_pos;
|
|
mpColorArr = l_color;
|
|
mpTexCoordArr = (f32*)l_texCoord;
|
|
mpMatDL = l_matDL;
|
|
mMatDLSize = 0xa0;
|
|
mpDL = l_Oba_kusa_aDL;
|
|
mDLSize = 0xa0;
|
|
mpDLCut = l_Oba_kusa_a_cutDL;
|
|
mDLCutSize = 0x80;
|
|
mCoParticle = 0x03db;
|
|
field_0x1a66a = 0x03da;
|
|
}
|
|
}
|
|
|
|
/* 80077CB8-80077CC4 .text __ct__13dGrass_room_cFv */
|
|
dGrass_room_c::dGrass_room_c() {
|
|
mpData = NULL;
|
|
}
|
|
|
|
/* 80077CC4-80077CD0 .text __ct__12dGrass_anm_cFv */
|
|
dGrass_anm_c::dGrass_anm_c() {
|
|
mState = 0;
|
|
}
|
|
|
|
/* 80077CD0-80077CDC .text __ct__13dGrass_data_cFv */
|
|
dGrass_data_c::dGrass_data_c() {
|
|
mState = 0;
|
|
}
|
|
|
|
/* 80077CDC-80077E58 .text draw__15dGrass_packet_cFv */
|
|
void dGrass_packet_c::draw() {
|
|
j3dSys.reinitGX();
|
|
GXSetNumIndStages(0);
|
|
|
|
static GXVtxDescList l_vtxDescList[] = {
|
|
{GX_VA_POS, GX_INDEX8},
|
|
{GX_VA_CLR0, GX_INDEX8},
|
|
{GX_VA_TEX0, GX_INDEX8},
|
|
{GX_VA_NULL, GX_NONE},
|
|
};
|
|
|
|
static GXVtxAttrFmtList l_vtxAttrFmtList[] = {
|
|
{GX_VA_POS, GX_POS_XYZ, GX_F32, 0x00},
|
|
{GX_VA_CLR0, GX_CLR_RGBA, GX_RGBA8, 0x00},
|
|
{GX_VA_TEX0, GX_TEX_ST, GX_F32, 0x00},
|
|
{GX_VA_NULL, GX_POS_XYZ, GX_F32, 0x00},
|
|
};
|
|
|
|
GFSetVtxDescv(l_vtxDescList);
|
|
GFSetVtxAttrFmtv(GX_VTXFMT0, l_vtxAttrFmtList);
|
|
GFSetArray(GX_VA_POS, mpPosArr, sizeof(cXyz));
|
|
GFSetArray(GX_VA_CLR0, mpColorArr, sizeof(*mpColorArr));
|
|
GFSetArray(GX_VA_TEX0, mpTexCoordArr, sizeof(cXy));
|
|
GXCallDisplayList(mpMatDL, mMatDLSize);
|
|
|
|
dGrass_room_c* room = &mGrassRoom[0];
|
|
for (s32 i = 0; i < (s32)ARRAY_SIZE(mGrassRoom); room++, i++) {
|
|
dKy_tevstr_c* tevstr = dComIfGp_roomControl_getTevStr(i);
|
|
GFSetTevColorS10(GX_TEVREG0, tevstr->mColorC0);
|
|
GFSetTevColor(GX_TEVREG1, tevstr->mColorK0);
|
|
dKy_GfFog_tevstr_set(tevstr);
|
|
for (dGrass_data_c* data = room->mpData; data != NULL; data = data->mpNextData) {
|
|
if (!(data->mInitFlags & 2)) {
|
|
GXLoadPosMtxImm(data->mModelMtx, GX_PNMTX0);
|
|
if (data->mAnimIdx >= 0)
|
|
GXCallDisplayList(mpDL, mDLSize);
|
|
else
|
|
GXCallDisplayList(mpDLCut, mDLCutSize);
|
|
}
|
|
}
|
|
}
|
|
|
|
J3DShape::resetVcdVatCache();
|
|
}
|
|
|
|
/* 80077E58-80078008 .text calc__15dGrass_packet_cFv */
|
|
void dGrass_packet_c::calc() {
|
|
/* Nonmatching */
|
|
dGrass_anm_c* anm = mGrassAnm;
|
|
|
|
f32 windSpeed = 0.0f;
|
|
if (!mDoGph_gInf_c::isMonotone() || strcmp(dComIfGp_getStartStageName(), "Hyrule") != 0) {
|
|
windSpeed = dKyw_get_wind_pow() * 1000.0f + 1000.0f;
|
|
if (windSpeed > 2000.0f)
|
|
windSpeed = 2000.0f;
|
|
}
|
|
|
|
s32 theta = 0;
|
|
for (s32 i = 0; i < 8; anm++, theta += 0xFA, i++) {
|
|
anm->mRotX = windSpeed + windSpeed * cM_scos(windSpeed * (g_Counter.mTimer + theta));
|
|
}
|
|
|
|
s32 roomNo = dStage_roomControl_c::getStayNo();
|
|
dGrass_data_c* data = mGrassRoom[roomNo].mpData;
|
|
if (data != NULL) {
|
|
l_CutSoundFlag = 0;
|
|
dComIfG_Ccsp()->SetMassAttr(40.0f, 80.0f, 11, 0);
|
|
for (; data != NULL; data = data->mpNextData) {
|
|
if (!(data->mInitFlags & 2) && data->mAnimIdx >= 0)
|
|
data->hitCheck(roomNo);
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 80078008-800782B8 .text checkGroundY__FR4cXyz */
|
|
static f32 checkGroundY(cXyz& pos) {
|
|
dBgS_GndChk chk;
|
|
pos.y += 50.0f;
|
|
chk.SetPos(&pos);
|
|
f32 y = dComIfG_Bgsp()->GroundCross(&chk);
|
|
pos.y -= 50.0f;
|
|
if (y <= -1000000000.0f)
|
|
return pos.y;
|
|
else
|
|
return y;
|
|
}
|
|
|
|
/* 800782B8-800784E8 .text update__15dGrass_packet_cFv */
|
|
void dGrass_packet_c::update() {
|
|
/* Nonmatching */
|
|
dGrass_anm_c* anm = &mGrassAnm[0];
|
|
for (s32 i = 0; i < (s32)ARRAY_SIZE(mGrassAnm); anm++, i++) {
|
|
mDoMtx_stack_c::YrotS(anm->mRotY);
|
|
mDoMtx_stack_c::XrotM(anm->mRotX);
|
|
mDoMtx_stack_c::YrotM(-anm->mRotY);
|
|
mDoMtx_copy(mDoMtx_stack_c::get(), anm->mAnimMtx);
|
|
}
|
|
|
|
dGrass_data_c* data = &mGrassData[0];
|
|
mDoLib_clipper::changeFar(mDoLib_clipper::getFar() * 1.636364f);
|
|
s32 numPerFrame = 0;
|
|
s32 angle = 0;
|
|
for (s32 i = 0; i < (s32)ARRAY_SIZE(mGrassData); data++, i++) {
|
|
if (data->mState != 0) {
|
|
if (data->mState == 1 && numPerFrame < 30) {
|
|
data->mPos.y = checkGroundY(data->mPos);
|
|
data->mState = 2;
|
|
numPerFrame++;
|
|
}
|
|
|
|
cXyz pos(data->mPos.x, data->mPos.y + 260.0f, data->mPos.z);
|
|
if (mDoLib_clipper::clip(j3dSys.getViewMtx(), pos, 260.0f)) {
|
|
data->mInitFlags |= 2;
|
|
} else {
|
|
data->mInitFlags &= ~2;
|
|
if (data->mAnimIdx >= 0) {
|
|
Mtx& mtx = mGrassAnm[data->mAnimIdx].mAnimMtx;
|
|
mtx[0][3] = pos.x;
|
|
mtx[1][3] = pos.y;
|
|
mtx[2][3] = pos.z;
|
|
mDoMtx_concat(j3dSys.getViewMtx(), mtx, data->mModelMtx);
|
|
} else {
|
|
mDoMtx_trans(data->mModelMtx, pos.x, pos.y, pos.z);
|
|
mDoMtx_YrotM(data->mModelMtx, angle);
|
|
mDoMtx_concat(j3dSys.getViewMtx(), data->mModelMtx, data->mModelMtx);
|
|
}
|
|
}
|
|
}
|
|
angle += 3535;
|
|
}
|
|
mDoLib_clipper::resetFar();
|
|
j3dSys.getDrawBuffer(0)->entryImm(this, 0);
|
|
}
|
|
|
|
/* 800784E8-800785C0 .text setData__15dGrass_packet_cFP13dGrass_data_ciR4cXyziSc */
|
|
void dGrass_packet_c::setData(dGrass_data_c* data, int nextIdx, cXyz& pos, int i_roomNo, s8 itemIdx) {
|
|
f32 y;
|
|
if (fopOvlpM_IsPeek()) {
|
|
y = checkGroundY(pos);
|
|
data->mState = 2;
|
|
} else {
|
|
y = pos.y;
|
|
data->mState = 1;
|
|
}
|
|
data->mInitFlags = 2;
|
|
data->mAnimIdx = (u8)cM_rndF(7.0f);
|
|
data->mPos.set(pos.x, y, pos.z);
|
|
data->mItemIdx = itemIdx;
|
|
mGrassRoom[i_roomNo].newData(data);
|
|
mNextIdx = nextIdx;
|
|
}
|
|
|
|
/* 800785C0-800786FC .text newData__15dGrass_packet_cFR4cXyziSc */
|
|
dGrass_data_c* dGrass_packet_c::newData(cXyz& pos, int i_roomNo, s8 itemIdx) {
|
|
/* Nonmatching */
|
|
JUT_ASSERT(0x600, 0 <= i_roomNo && i_roomNo < 64);
|
|
u32 idx = mNextIdx;
|
|
dGrass_data_c* data = &mGrassData[idx];
|
|
s32 remain = ARRAY_SIZE(mGrassData) - idx;
|
|
if (idx < ARRAY_SIZE(mGrassData)) {
|
|
while (true) {
|
|
if (data->mState == 0) {
|
|
setData(data, idx, pos, i_roomNo, itemIdx);
|
|
return data;
|
|
}
|
|
data++;
|
|
idx++;
|
|
remain--;
|
|
if (remain == 0)
|
|
break;
|
|
}
|
|
}
|
|
|
|
data = mGrassData;
|
|
remain = 0;
|
|
while (idx > 0) {
|
|
if (data->mState == 0) {
|
|
setData(data, idx, pos, i_roomNo, itemIdx);
|
|
return data;
|
|
}
|
|
|
|
data++;
|
|
idx++;
|
|
remain--;
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
/* 800786FC-80078748 .text newAnm__15dGrass_packet_cFv */
|
|
s32 dGrass_packet_c::newAnm() {
|
|
dGrass_anm_c* anm = &mGrassAnm[8];
|
|
for (s32 i = 8; i < 104; anm++, i++) {
|
|
if (anm->mState == 0) {
|
|
anm->mState = 1;
|
|
anm->mRotY = 0;
|
|
anm->mRotX = 0;
|
|
return i;
|
|
}
|
|
}
|
|
return -1;
|
|
}
|
|
|
|
/* 80078748-80078770 .text setAnm__15dGrass_packet_cFis */
|
|
void dGrass_packet_c::setAnm(int idx, s16 angleY) {
|
|
dGrass_anm_c& anm = mGrassAnm[idx];
|
|
anm.mState = 1;
|
|
anm.mRotY = angleY;
|
|
anm.mRotX = 0;
|
|
}
|