Files
tww/src/d/actor/d_a_sail.cpp
T
2025-08-08 21:51:30 -04:00

866 lines
29 KiB
C++

//
// Generated by dtk
// Translation Unit: d_a_sail.cpp
//
#include "d/actor/d_a_sail.h"
#if VERSION == VERSION_DEMO
#include "d/d_s_play.h"
#endif
#include "d/res/res_kaizokusen.h"
#include "d/res/res_cloth.h"
#include "d/d_procname.h"
#include "d/d_priority.h"
#include "d/d_com_inf_game.h"
#include "d/d_kankyo_wether.h"
#include "d/actor/d_a_obj_pirateship.h"
#include "f_op/f_op_actor_mng.h"
#include "m_Do/m_Do_mtx.h"
#include "SSystem/SComponent/c_lib.h"
#include "SSystem/SComponent/c_angle.h"
#include "weak_bss_936_to_1036.h" // IWYU pragma: keep
#include "weak_data_1811.h" // IWYU pragma: keep
#if VERSION == VERSION_DEMO
#define REG_SAIL_F(i) REG10_F(i)
#define REG_SAIL_S(i) REG10_S(i)
#else
#define REG_SAIL_F(i) 0.0f
#define REG_SAIL_S(i) 0
#endif
static daObjPirateship::Act_c* l_p_ship;
static daSail_HIO_c l_HIO;
Vec l_pos[] = {
{-840.0f, 0.0f, 0.0f},
{-560.0f, 0.0f, 0.0f},
{-280.0f, 0.0f, 0.0f},
{0.0f, 0.0f, 0.0f},
{280.0f, 0.0f, 0.0f},
{560.0f, 0.0f, 0.0f},
{840.0f, 0.0f, 0.0f},
{-840.0f, -100.0f, 0.0f},
{-560.0f, -100.0f, 0.0f},
{-280.0f, -100.0f, 0.0f},
{0.0f, -100.0f, 0.0f},
{280.0f, -100.0f, 0.0f},
{560.0f, -100.0f, 0.0f},
{840.0f, -100.0f, 0.0f},
{-840.0f, -200.0f, 0.0f},
{-560.0f, -200.0f, 0.0f},
{-280.0f, -200.0f, 0.0f},
{0.0f, -200.0f, 0.0f},
{280.0f, -200.0f, 0.0f},
{560.0f, -200.0f, 0.0f},
{840.0f, -200.0f, 0.0f},
{-840.0f, -300.0f, 0.0f},
{-560.0f, -300.0f, 0.0f},
{-280.0f, -300.0f, 0.0f},
{0.0f, -300.0f, 0.0f},
{280.0f, -300.0f, 0.0f},
{560.0f, -300.0f, 0.0f},
{840.0f, -300.0f, 0.0f},
{-840.0f, -400.0f, 0.0f},
{-560.0f, -400.0f, 0.0f},
{-280.0f, -400.0f, 0.0f},
{0.0f, -400.0f, 0.0f},
{280.0f, -400.0f, 0.0f},
{560.0f, -400.0f, 0.0f},
{840.0f, -400.0f, 0.0f},
{-840.0f, -500.0f, 0.0f},
{-560.0f, -500.0f, 0.0f},
{-280.0f, -500.0f, 0.0f},
{0.0f, -500.0f, 0.0f},
{280.0f, -500.0f, 0.0f},
{560.0f, -500.0f, 0.0f},
{840.0f, -500.0f, 0.0f},
{-840.0f, -600.0f, 0.0f},
{-560.0f, -600.0f, 0.0f},
{-280.0f, -600.0f, 0.0f},
{0.0f, -600.0f, 0.0f},
{280.0f, -600.0f, 0.0f},
{560.0f, -600.0f, 0.0f},
{840.0f, -600.0f, 0.0f},
{-840.0f, -700.0f, 0.0f},
{-560.0f, -700.0f, 0.0f},
{-280.0f, -700.0f, 0.0f},
{0.0f, -700.0f, 0.0f},
{280.0f, -700.0f, 0.0f},
{560.0f, -700.0f, 0.0f},
{840.0f, -700.0f, 0.0f},
{-840.0f, -800.0f, 0.0f},
{-560.0f, -800.0f, 0.0f},
{-280.0f, -800.0f, 0.0f},
{0.0f, -800.0f, 0.0f},
{280.0f, -800.0f, 0.0f},
{560.0f, -800.0f, 0.0f},
{840.0f, -800.0f, 0.0f},
{-840.0f, -900.0f, 0.0f},
{-560.0f, -900.0f, 0.0f},
{-280.0f, -900.0f, 0.0f},
{0.0f, -900.0f, 0.0f},
{280.0f, -900.0f, 0.0f},
{560.0f, -900.0f, 0.0f},
{840.0f, -900.0f, 0.0f},
{-840.0f, -1000.0f, 0.0f},
{-560.0f, -1000.0f, 0.0f},
{-280.0f, -1000.0f, 0.0f},
{0.0f, -1000.0f, 0.0f},
{280.0f, -1000.0f, 0.0f},
{560.0f, -1000.0f, 0.0f},
{840.0f, -1000.0f, 0.0f},
{-840.0f, -1100.0f, 0.0f},
{-560.0f, -1100.0f, 0.0f},
{-280.0f, -1100.0f, 0.0f},
{0.0f, -1100.0f, 0.0f},
{280.0f, -1100.0f, 0.0f},
{560.0f, -1100.0f, 0.0f},
{840.0f, -1100.0f, 0.0f},
};
cXy l_texCoord[] = {
{0.0f, 0.0f},
{0.165f, 0.0f},
{0.33f, 0.0f},
{0.495f, 0.0f},
{0.66f, 0.0f},
{0.825f, 0.0f},
{1.0f, 0.0f},
{0.0f, 0.09f},
{0.165f, 0.09f},
{0.33f, 0.09f},
{0.495f, 0.09f},
{0.66f, 0.09f},
{0.825f, 0.09f},
{1.0f, 0.09f},
{0.0f, 0.18f},
{0.165f, 0.18f},
{0.33f, 0.18f},
{0.495f, 0.18f},
{0.66f, 0.18f},
{0.825f, 0.18f},
{1.0f, 0.18f},
{0.0f, 0.27f},
{0.165f, 0.27f},
{0.33f, 0.27f},
{0.495f, 0.27f},
{0.66f, 0.27f},
{0.825f, 0.27f},
{1.0f, 0.27f},
{0.0f, 0.36f},
{0.165f, 0.36f},
{0.33f, 0.36f},
{0.495f, 0.36f},
{0.66f, 0.36f},
{0.825f, 0.36f},
{1.0f, 0.36f},
{0.0f, 0.45f},
{0.165f, 0.45f},
{0.33f, 0.45f},
{0.495f, 0.45f},
{0.66f, 0.45f},
{0.825f, 0.45f},
{1.0f, 0.45f},
{0.0f, 0.54f},
{0.165f, 0.54f},
{0.33f, 0.54f},
{0.495f, 0.54f},
{0.66f, 0.54f},
{0.825f, 0.54f},
{1.0f, 0.54f},
{0.0f, 0.63f},
{0.165f, 0.63f},
{0.33f, 0.63f},
{0.495f, 0.63f},
{0.66f, 0.63f},
{0.825f, 0.63f},
{1.0f, 0.63f},
{0.0f, 0.72f},
{0.165f, 0.72f},
{0.33f, 0.72f},
{0.495f, 0.72f},
{0.66f, 0.72f},
{0.825f, 0.72f},
{1.0f, 0.72f},
{0.0f, 0.81f},
{0.165f, 0.81f},
{0.33f, 0.81f},
{0.495f, 0.81f},
{0.66f, 0.81f},
{0.825f, 0.81f},
{1.0f, 0.81f},
{0.0f, 0.9f},
{0.165f, 0.9f},
{0.33f, 0.9f},
{0.495f, 0.9f},
{0.66f, 0.9f},
{0.825f, 0.9f},
{1.0f, 0.9f},
{0.0f, 1.0f},
{0.165f, 1.0f},
{0.33f, 1.0f},
{0.495f, 1.0f},
{0.66f, 1.0f},
{0.825f, 1.0f},
{1.0f, 1.0f},
};
#include "assets/l_sail_DL.h"
#include "assets/l_sail_matDL.h"
#include "assets/l_Txa_kizoku_mastTEX.h"
Vec l_mast_pos[] = {
{900.0f, 9.676933f, -16.760941f},
{900.0f, -9.676933f, -16.760941f},
{900.0f, -19.353867f, -0.000004f},
{900.0f, -9.676933f, 16.760941f},
{900.0f, 9.676933f, 16.760941f},
{900.0f, 19.353867f, -0.000001f},
{-900.0f, 9.676933f, -16.760941f},
{-900.0f, -9.676933f, -16.760941f},
{-900.0f, -19.353867f, -0.000004f},
{-900.0f, -9.676933f, 16.760941f},
{-900.0f, 9.676933f, 16.760941f},
{-900.0f, 19.353867f, -0.000001f},
{900.0f, -0.000001f, -0.000001f},
{-900.0f, -0.000001f, -0.000001f},
{0.0f, 6.105309f, 28.277588f},
{0.0f, -26.54686f, 28.277588f},
{0.0f, -42.875366f, -0.000005f},
{0.0f, -26.546822f, -28.277588f},
{0.0f, 6.105347f, -28.277588f},
{0.0f, 22.42897f, 0.0f},
};
GXColor l_mast_color[] = {
{0xA8, 0xA8, 0xA8, 0xFF},
{0x5D, 0x5D, 0x5D, 0xFF},
{0xF3, 0xF3, 0xF3, 0xFF},
{0xC6, 0xC6, 0xC6, 0xFF},
{0x38, 0x38, 0x38, 0xFF},
{0x56, 0x56, 0x56, 0xFF},
{0x0B, 0x0B, 0x0B, 0xFF},
{0xA1, 0xA1, 0xA1, 0xFF},
};
cXy l_mast_texCoord[] = {
{1.0f, 0.0f},
{1.0f, 1.0f},
{0.0f, 1.0f},
{0.0f, 0.0f},
{0.881686f, 1.0f},
{0.89115f, 0.0f},
{0.888606f, 1.0f},
{0.888606f, 0.0f},
};
#include "assets/l_AmastDL.h"
/* 000000EC-00000364 .text setCorrectNrmAngle__15daSail_packet_cFsf */
void daSail_packet_c::setCorrectNrmAngle(s16 param_0, f32 param_1) {
m1C38 += (s16)(900 + REG_SAIL_S(0) + (s32)cM_rndF(REG_SAIL_S(1) + 200.0f));
m1C34 = (REG_SAIL_F(0) + 300.0f) * cM_ssin(m1C38);
s16 r28 = param_0 + 0x8000;
s32 r27 = param_0;
s16 r26 = l_HIO.m10 * (1.0f - 0.5f * param_1);
if (abs(r28) < cAngle::d2s(1.25f * r26)) {
s16 targetAngle = r28 > 0 ? (s16)cAngle::d2s(-r26) : (s16)cAngle::d2s(r26);
cLib_addCalcAngleS2(&m1C36, targetAngle, 5, 192);
} else if (abs(r27) < cAngle::d2s(1.25f * r26)) {
s16 targetAngle = (s16)r27 > 0 ? (s16)cAngle::d2s(-r26) : (s16)cAngle::d2s(r26);
cLib_addCalcAngleS2(&m1C36, targetAngle, 5, 192);
} else {
cLib_addCalcAngleS2(&m1C36, 0, 5, 192);
}
m1C34 += m1C36;
}
/* 00000364-00000398 .text setNrmMtx__15daSail_packet_cFv */
void daSail_packet_c::setNrmMtx() {
cMtx_YrotS(*calc_mtx, m1C34);
}
/* 00000398-00000424 .text setBackNrm__15daSail_packet_cFv */
void daSail_packet_c::setBackNrm() {
cXyz* nrm = mNrm[m1C3A];
cXyz* backNrm = mBackNrm[m1C3A];
for (int i = 0; i < 0x54; i++) {
backNrm->setall(0.0f);
*backNrm -= *nrm;
nrm++;
backNrm++;
}
}
/* 00000424-00000834 .text setNrmVtx__15daSail_packet_cFP4cXyzii */
void daSail_packet_c::setNrmVtx(cXyz* param_0, int param_1, int param_2) {
cXyz spF8;
cXyz spEC;
cXyz spE0;
cXyz spD4;
cXyz spC8;
cXyz* vtxPos = getPos();
s32 idx = param_2 * 7;
spC8.set(vtxPos[param_1 + idx]);
spD4.setall(0.0f);
if (param_1 != 0) {
spF8 = vtxPos[idx - 1 + param_1] - spC8;
if (param_2 != 0) {
spEC = vtxPos[(param_2 - 1) * 7 + param_1] - spC8;
spE0 = spEC.outprod(spF8);
spE0 = spE0.normZC();
spD4 += spE0;
}
if (param_2 != 11) {
spEC = vtxPos[(param_2 + 1) * 7 + param_1] - spC8;
spE0 = spF8.outprod(spEC);
spE0 = spE0.normZC();
spD4 += spE0;
}
}
if (param_1 != 6) {
spF8 = vtxPos[param_1 + 1 + idx] - spC8;
if (param_2 != 0) {
spEC = vtxPos[(param_2 - 1) * 7 + param_1] - spC8;
spE0 = spF8.outprod(spEC);
spE0 = spE0.normZC();
spD4 += spE0;
}
if (param_2 != 11) {
spEC = vtxPos[(param_2 + 1) * 7 + param_1] - spC8;
spE0 = spEC.outprod(spF8);
spE0 = spE0.normZC();
spD4 += spE0;
}
}
spD4 = spD4.normZC();
MtxPush();
cMtx_YrotM(*calc_mtx, cM_ssin((REG_SAIL_S(3) - 800) * (param_1 + param_2)) * (REG_SAIL_S(2) + 900));
MtxPosition(&spD4, &spE0);
*param_0 = spE0.normZC();
MtxPull();
}
/* 00000870-000010D8 .text draw__15daSail_packet_cFv */
void daSail_packet_c::draw() {
j3dSys.reinitGX();
#if VERSION > VERSION_JPN
GXSetNumIndStages(0);
#endif
dKy_GxFog_tevstr_set(mTevStr);
GXClearVtxDesc();
GXSetVtxDesc(GX_VA_POS, GX_INDEX8);
GXSetVtxDesc(GX_VA_NRM, GX_INDEX8);
GXSetVtxDesc(GX_VA_TEX0, GX_INDEX8);
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0);
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_NRM, GX_POS_XY, GX_F32, 0);
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_TEX0, GX_POS_XYZ, GX_F32, 0);
GXSetArray(GX_VA_POS, mPos[m1C3A], sizeof(cXyz));
GXSetArray(GX_VA_NRM, mNrm[m1C3A], sizeof(cXyz));
GXSetArray(GX_VA_TEX0, l_texCoord, sizeof(*l_texCoord));
GXTexObj texObj;
ResTIMG* kaizokusen = (ResTIMG*)dComIfG_getObjectRes("Kaizokusen", KAIZOKUSEN_INDEX_BTI_TXA_KAIZOKU_HO);
GXInitTexObj(&texObj, (u8*)kaizokusen + kaizokusen->imageOffset, kaizokusen->width, kaizokusen->height,
(GXTexFmt)kaizokusen->format, (GXTexWrapMode)kaizokusen->wrapS, (GXTexWrapMode)kaizokusen->wrapT,
kaizokusen->mipmapCount > 1);
GXInitTexObjLOD(&texObj, (GXTexFilter)kaizokusen->minFilter, (GXTexFilter)kaizokusen->magFilter,
kaizokusen->minLOD * 0.125f, kaizokusen->maxLOD * 0.125f, kaizokusen->LODBias * 0.01f,
kaizokusen->biasClamp, kaizokusen->doEdgeLOD, (GXAnisotropy)kaizokusen->maxAnisotropy);
GXLoadTexObj(&texObj, GX_TEXMAP0);
ResTIMG* cloth = (ResTIMG*)dComIfG_getObjectRes("Cloth", CLOTH_BTI_CLOTHTOON);
GXInitTexObj(&texObj, (u8*)cloth + cloth->imageOffset, cloth->width, cloth->height,
(GXTexFmt)cloth->format, (GXTexWrapMode)cloth->wrapS, (GXTexWrapMode)cloth->wrapT,
cloth->mipmapCount > 1);
GXInitTexObjLOD(&texObj, (GXTexFilter)cloth->minFilter, (GXTexFilter)cloth->magFilter,
cloth->minLOD * 0.125f, cloth->maxLOD * 0.125f, cloth->LODBias * 0.01f,
cloth->biasClamp, cloth->doEdgeLOD, (GXAnisotropy)cloth->maxAnisotropy);
GXLoadTexObj(&texObj, GX_TEXMAP1);
GXSetNumChans(1);
u8 numTevStages, lightMask;
if (mTevStr->mColorK1.a != 0) {
numTevStages = 3;
lightMask = GX_LIGHT0 | GX_LIGHT1;
} else {
numTevStages = 2;
lightMask = GX_LIGHT0;
}
if (l_HIO.m05 != 0) {
GXSetChanCtrl(GX_COLOR0, 1, GX_SRC_REG, GX_SRC_REG, lightMask, GX_DF_CLAMP, GX_AF_NONE);
GXSetNumTexGens(2);
GXLoadTexMtxImm(*getTexMtx(), 30, GX_MTX3x4);
GXSetTexCoordGen(GX_TEXCOORD0, GX_TG_MTX3x4, GX_TG_TEX0, 30);
GXSetTexCoordGen(GX_TEXCOORD1, GX_TG_SRTG, GX_TG_COLOR0, 60);
GXSetNumTevStages(numTevStages);
GXSetTevSwapMode(GX_TEVSTAGE0, GX_TEV_SWAP0, GX_TEV_SWAP1);
GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD1, GX_TEXMAP1, GX_COLOR0A0);
GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_C0, GX_CC_C1, 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_ZERO, GX_CA_ZERO, GX_CA_ZERO);
GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
GXSetTevSwapMode(GX_TEVSTAGE1, GX_TEV_SWAP0, GX_TEV_SWAP0);
GXSetTevOrder(GX_TEVSTAGE1, GX_TEXCOORD0, GX_TEXMAP0, GX_COLOR_NULL);
GXSetTevColorIn(GX_TEVSTAGE1, GX_CC_ZERO, GX_CC_TEXC, GX_CC_CPREV, GX_CC_ZERO);
GXSetTevColorOp(GX_TEVSTAGE1, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
GXSetTevAlphaIn(GX_TEVSTAGE1, GX_CA_ZERO, GX_CA_ZERO, GX_CA_ZERO, GX_CA_TEXA);
GXSetTevAlphaOp(GX_TEVSTAGE1, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
if (numTevStages == 3) {
GXSetTevSwapMode(GX_TEVSTAGE2, GX_TEV_SWAP0, GX_TEV_SWAP2);
GXSetTevOrder(GX_TEVSTAGE2, GX_TEXCOORD1, GX_TEXMAP1, GX_COLOR_NULL);
GXSetTevColorIn(GX_TEVSTAGE2, GX_CC_ZERO, GX_CC_C2, GX_CC_TEXC, GX_CC_CPREV);
GXSetTevColorOp(GX_TEVSTAGE2, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
GXSetTevAlphaIn(GX_TEVSTAGE2, GX_CA_ZERO, GX_CA_ZERO, GX_CA_ZERO, GX_CA_APREV);
GXSetTevAlphaOp(GX_TEVSTAGE2, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
}
} else {
GXSetChanCtrl(GX_COLOR0, 1, GX_SRC_REG, GX_SRC_REG, lightMask, GX_DF_CLAMP, GX_AF_NONE);
GXSetNumTexGens(1);
GXLoadTexMtxImm(*getTexMtx(), 30, GX_MTX3x4);
GXSetTexCoordGen(GX_TEXCOORD0, GX_TG_MTX3x4, GX_TG_TEX0, 30);
GXSetTexCoordGen(GX_TEXCOORD0, GX_TG_MTX2x4, GX_TG_TEX0, 60);
GXSetNumTevStages(numTevStages);
GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD_NULL, GX_TEXMAP_NULL, GX_COLOR0A0);
GXSetTevSwapMode(GX_TEVSTAGE0, GX_TEV_SWAP1, GX_TEV_SWAP0);
GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_C0, GX_CC_C1, GX_CC_RASC, 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_ZERO, GX_CA_ZERO, GX_CA_ZERO);
GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
GXSetTevSwapMode(GX_TEVSTAGE1, GX_TEV_SWAP0, GX_TEV_SWAP0);
GXSetTevOrder(GX_TEVSTAGE1, GX_TEXCOORD0, GX_TEXMAP0, GX_COLOR_NULL);
GXSetTevColorIn(GX_TEVSTAGE1, GX_CC_ZERO, GX_CC_CPREV, GX_CC_TEXC, GX_CC_ZERO);
GXSetTevColorOp(GX_TEVSTAGE1, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
GXSetTevAlphaIn(GX_TEVSTAGE1, GX_CA_ZERO, GX_CA_ZERO, GX_CA_ZERO, GX_CA_TEXA);
GXSetTevAlphaOp(GX_TEVSTAGE1, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
if (numTevStages == 3) {
GXSetTevSwapMode(GX_TEVSTAGE2, GX_TEV_SWAP2, GX_TEV_SWAP0);
GXSetTevOrder(GX_TEVSTAGE2, GX_TEXCOORD_NULL, GX_TEXMAP_NULL, GX_COLOR_NULL);
GXSetTevColorIn(GX_TEVSTAGE2, GX_CC_ZERO, GX_CC_C2, GX_CC_RASC, GX_CC_CPREV);
GXSetTevColorOp(GX_TEVSTAGE2, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
GXSetTevAlphaIn(GX_TEVSTAGE2, GX_CA_ZERO, GX_CA_ZERO, GX_CA_ZERO, GX_CA_APREV);
GXSetTevAlphaOp(GX_TEVSTAGE2, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
}
}
GXSetTevColorS10(GX_TEVREG0, mTevStr->mColorC0);
GXSetTevColor(GX_TEVREG1, mTevStr->mColorK0);
GXSetTevColor(GX_TEVREG2, mTevStr->mColorK1);
GXCallDisplayList(l_sail_matDL, 0x20);
GXLoadPosMtxImm(*getMtx(), 0);
GXLoadNrmMtxImm(*getMtx(), 0);
GXSetZCompLoc(GX_FALSE);
GXSetZMode(GX_TRUE, GX_LEQUAL, GX_TRUE);
GXSetCullMode(GX_CULL_BACK);
GXCallDisplayList(l_sail_DL, 0x200);
GXSetCullMode(GX_CULL_FRONT);
GXSetArray(GX_VA_NRM, mBackNrm[m1C3A], sizeof(cXyz));
GXCallDisplayList(l_sail_DL, 0x200);
#if VERSION > VERSION_JPN
J3DShape::resetVcdVatCache();
#endif
}
/* 000010D8-000013CC .text daSail_Draw__FP10sail_class */
static BOOL daSail_Draw(sail_class* i_this) {
if (l_p_ship->m2CC == 0) {
return FALSE;
}
i_this->tevStr = l_p_ship->tevStr;
#if VERSION > VERSION_DEMO
g_env_light.settingTevStruct(TEV_TYPE_ACTOR, &i_this->current.pos, &i_this->tevStr);
#endif
g_env_light.setLightTevColorType(i_this->mSailPacket.mStickModel, &i_this->tevStr);
mDoExt_modelUpdateDL(i_this->mSailPacket.mStickModel);
MtxTrans(i_this->current.pos.x, i_this->current.pos.y, i_this->current.pos.z, 0);
cMtx_YrotM(*calc_mtx, i_this->current.angle.y);
cMtx_XrotM(*calc_mtx, i_this->current.angle.x);
cMtx_ZrotM(*calc_mtx, i_this->current.angle.z);
cMtx_concat(j3dSys.getViewMtx(), *calc_mtx, *i_this->mSailPacket.getMtx());
cXyz* vtxPos = i_this->mSailPacket.getPos();
MtxTrans(
i_this->current.pos.x,
i_this->current.pos.y + vtxPos[0x53].y,
i_this->current.pos.z,
0
);
cMtx_YrotM(*calc_mtx, i_this->current.angle.y);
cMtx_XrotM(*calc_mtx, i_this->current.angle.x);
cMtx_ZrotM(*calc_mtx, i_this->current.angle.z);
cMtx_concat(j3dSys.getViewMtx(), *calc_mtx, *i_this->mSailPacket.getStickMtx());
i_this->mSailPacket.mStickModel->setBaseTRMtx(*calc_mtx);
MtxTrans(0.0f, 0.0f, 0.0f, 0);
MTXCopy(*calc_mtx, *i_this->mSailPacket.getTexMtx());
i_this->mSailPacket.setTevStr(&i_this->tevStr);
j3dSys.getDrawBuffer(0)->entryImm(&i_this->mSailPacket, 0);
return TRUE;
}
/* 000013CC-00001CEC .text sail_pos_move__FP10sail_class */
static void sail_pos_move(sail_class* i_this) {
cXyz* windVec = dKyw_get_wind_vec();
f32 f15 = 0.8f;
s16 windAngle = cM_atan2s(windVec->x, windVec->z);
cMtx_YrotS(*calc_mtx, -(i_this->current.angle.y - windAngle));
cXyz sp28;
cXyz sp1C;
cXyz sp10;
f32 f14 = 0.08f * 0.8f;
sp28.set(0.0f, 0.0f, f14);
MtxPosition(&sp28, &sp1C);
f32 f31 = (0.9f * std::fabsf(sp1C.z)) + 0.02f + (f14 * 0.1f);
sp28.x = 0.0f;
sp28.z = 1.0f;
MtxPosition(&sp28, &sp1C);
f32 f25 = (0.9f * std::fabsf(sp1C.z)) + 0.1f;
f32 f0 = std::fabsf(sp1C.x);
s32 tmp = f15 * (REG_SAIL_F(9) + 5000.0f) * (1.0f - (i_this->mSailPacket.m1C44 * 0.95f));
i_this->mSailPacket.m1C40 += tmp * ((f25 * 0.85f) + 0.15f);
i_this->mSailPacket.m1C50 = ((f0 * 1.5f) + 1.0f) * 7500.0f;
i_this->mSailPacket.m1C52 = ((f25 * 0.95f) + 0.05f) * 7200.0f;
cXyz* vtxPos = i_this->mSailPacket.getPos();
f32 sp6C[7] = {};
f32 sp34[7] = {};
f25 *= 1.0f - (0.5f * i_this->mSailPacket.m1C44 * i_this->mSailPacket.m1C4C);
f0 *= 1.0f - (0.75f * i_this->mSailPacket.m1C44);
for (int i = 0; i < 12; i++) {
f32 f12 = i - 6;
f32 f13 = i - 5.5f;
f32 tmp = REG_SAIL_F(10) + 11.0f;
sp10.z = f25 * (-tmp * f12 * f12 + (tmp * 36.0f));
for (int j = 0; j < 7; j++, vtxPos++) {
f32 f24;
f32 f23 = j - 3;
f32 tmp = 5.0f + REG_SAIL_F(11);
f32 f17 = tmp * i;
f32 f22, f21, f20; // these are xyz components
// these explicit casts are necessary
u32 r22 = (i_this->mSailPacket.m1C50 * (s32)f23) + (i_this->mSailPacket.m1C52 * (s32)f12);
f20 = (1750.0f + REG_SAIL_F(13)) * (SQUARE(f0) + 0.05f) * cM_ssin(-i_this->mSailPacket.m1C40 + r22) * f31;
f22 = (550.0f + REG_SAIL_F(12)) * (SQUARE(f0) + 0.1f) * cM_scos(i_this->mSailPacket.m1C40 + r22) * f31;
f21 = std::sqrtf(SQUARE(f22) + SQUARE(f20)) * 0.1f;
f24 = (f25 * ((10.0f * f17) + (-f17 * f23 * f23)));
f24 += ((sp10.z * (18.0f - f23 * f23)) / 18.0f);
f32 f15 = f24 - sp34[j];
f32 f16;
if (f15 > 100.0f) {
f16 = 100.0f;
sp34[j] += 100.0f;
} else {
f16 = -100.0f;
if (f15 < f16) {
sp34[j] -= 100.0f;
} else {
f16 = f15;
sp34[j] = f24;
}
}
f32 f14 = 100.0f - std::sqrtf(SQUARE(125.0f) - SQUARE(f16));
sp6C[j] += f14 > -10.0f ? f14 : -10.0f;
sp10.x = 0.0f;
sp10.y = 0.0f;
if (i < 3) {
f22 *= i * 0.33f;
f21 *= i * 0.33f;
f20 *= i * 0.33f;
} else if (i == 11 && std::fabsf(f23) == 3.0f) {
f22 = 0.0f;
f21 = 0.0f;
f20 = 0.0f;
}
vtxPos->x = sp10.x + f22;
vtxPos->y = ((sp6C[j] + sp10.y + f21) - (i * 1.25f * SQUARE(f23)));
vtxPos->z = f24 + f20;
vtxPos->x += l_pos[i * 7 + j].x;
vtxPos->y += l_pos[i * 7 + j].y;
vtxPos->z += l_pos[i * 7 + j].z;
vtxPos->y *= (1.0f - ((i_this->mSailPacket.m1C44 * SQUARE(f13)) / 30.25f));
vtxPos->y *= ((11.0f - (i_this->mSailPacket.m1C44 * i)) / 11.0f);
vtxPos->z *= (1.0f - ((i_this->mSailPacket.m1C44 * SQUARE(f13)) / 30.25f));
vtxPos->z *= ((11.0f - (i_this->mSailPacket.m1C44 * i)) / 11.0f);
if (i_this->mSailPacket.m1C44 > 0.0f && i < 6) {
f32 f15_2 = i - 3;
f32 f20 = (9.0f - SQUARE(f15_2)) / 9.0f;
vtxPos->z += ((REG_SAIL_F(26) * 10.0f + 3.5f) * 200.0f * f20 * i_this->mSailPacket.m1C44);
vtxPos->y -= ((REG_SAIL_F(29) * 10.0f + 1.5f) * 100.0f * f20 * i_this->mSailPacket.m1C44);
}
vtxPos->y *= ((REG_SAIL_F(27) + 0.3f) * (j & 1) * i_this->mSailPacket.m1C44) + (1.0f - i_this->mSailPacket.m1C44);
vtxPos->z *= ((REG_SAIL_F(28) + 0.15f) * (j & 1) * i_this->mSailPacket.m1C44) + (1.0f - i_this->mSailPacket.m1C44);
}
}
}
/* 00001CEC-00001DB0 .text demo_move__FP10sail_class */
static BOOL demo_move(sail_class* i_this) {
if (i_this->demoActorID == 0) {
return FALSE;
}
dDemo_actor_c* demo_actor = dComIfGp_demo_getActor(i_this->demoActorID);
if (demo_actor != NULL) {
if (demo_actor->checkEnable(dDemo_actor_c::ENABLE_ANM_FRAME_e)) {
f32 frame = demo_actor->getAnmFrame();
frame = 0.6f - (frame * 0.006f);
i_this->mSailPacket.m1C44 = frame;
i_this->mSailPacket.m1C44 = cLib_minMaxLimit<f32>(i_this->mSailPacket.m1C44, 0.0f, 0.6f);
}
return TRUE;
}
return FALSE;
}
/* 00001DB0-00002094 .text sail_move__FP10sail_class */
static void sail_move(sail_class* i_this) {
f32 f31 = 0.8f;
cXyz* windVec = dKyw_get_wind_vec();
if (l_HIO.m06 == 0 && i_this->mSailPacket.m1C44 < REG_SAIL_F(25) + 0.6f) {
if (i_this->mSailPacket.m1C48 <= 0.0f) {
i_this->mSailPacket.m1C48 = 0.015f;
} else {
i_this->mSailPacket.m1C48 -= 0.001f;
}
cLib_addCalc(&i_this->mSailPacket.m1C44, REG_SAIL_F(25) + 0.6f, 0.1f, i_this->mSailPacket.m1C48, 0.01f);
} else {
if (l_HIO.m06 == 1 && i_this->mSailPacket.m1C44 > 0.0f) {
i_this->mSailPacket.m1C48 += 0.0075f;
cLib_addCalc(&i_this->mSailPacket.m1C44, 0.0f, 0.3f, i_this->mSailPacket.m1C48, 0.01f);
} else {
i_this->mSailPacket.m1C48 = 0.0f;
}
}
if (i_this->mSailPacket.m1C44 > 1.0f) {
i_this->mSailPacket.m1C44 = 1.0f;
} else if (i_this->mSailPacket.m1C44 < 0.0f) {
i_this->mSailPacket.m1C44 = 0.0f;
}
if (!demo_move(i_this) && l_HIO.m08 != 0) {
i_this->mSailPacket.m1C44 = l_HIO.m0C;
}
i_this->mSailPacket.m1C4C = (i_this->mSailPacket.m1C44 - 0.6f) * 15.0f;
s16 windAngle = cM_atan2s(windVec->x, windVec->z);
cMtx_YrotS(*calc_mtx, -(i_this->current.angle.y - windAngle));
f32 temp = 0.08f * f31;
cXyz sp2C(0.0f, 0.0f, temp);
cXyz sp20;
MtxPosition(&sp2C, &sp20);
sp2C.x = 0.0f;
sp2C.z = 1.0f;
MtxPosition(&sp2C, &sp20);
f32 f31_1 = std::fabsf(sp20.z);
sail_pos_move(i_this);
f32 f31_2 = f31_1 * (1.0f - (i_this->mSailPacket.m1C44 * 0.5f * i_this->mSailPacket.m1C4C));
cXyz* vtxNrm = i_this->mSailPacket.getNrm();
s16 angleY = i_this->current.angle.y;
cXyz light;
dKy_FirstlightVec_get(&light);
s16 lightAngle = cM_atan2s(light.x, light.z);
s16 tmp = lightAngle - angleY;
i_this->mSailPacket.setCorrectNrmAngle(tmp, f31_2);
i_this->mSailPacket.setNrmMtx();
for (int i = 0; i < 12; i++) {
for (int j = 0; j < 7; j++) {
i_this->mSailPacket.setNrmVtx(vtxNrm, j, i);
vtxNrm++;
}
}
i_this->mSailPacket.setBackNrm();
#if VERSION <= VERSION_JPN
// Bug: The number of bytes (0x14AC0) passed here is way too large and causes an overflow.
// The below sizeof calculation is a guess as to what led the devs to arriving at this wrong number.
DCStoreRangeNoSync(i_this->mSailPacket.getPos(), sizeof(*i_this->mSailPacket.mPos) * sizeof(*i_this->mSailPacket.mNrm) / sizeof(cXyz));
#else
DCStoreRangeNoSync(i_this->mSailPacket.getPos(), sizeof(*i_this->mSailPacket.mPos));
DCStoreRangeNoSync(i_this->mSailPacket.getNrm(), sizeof(*i_this->mSailPacket.mNrm));
DCStoreRangeNoSync(i_this->mSailPacket.getBackNrm(), sizeof(*i_this->mSailPacket.mBackNrm));
#endif
}
/* 00002094-00002154 .text daSail_Execute__FP10sail_class */
static BOOL daSail_Execute(sail_class* i_this) {
static cXyz sail_offset(0.0f, 2100.0f, 100.0f);
cMtx_multVec(l_p_ship->mModel->getBaseTRMtx(), &sail_offset, &i_this->current.pos);
i_this->current.angle = l_p_ship->shape_angle;
sail_move(i_this);
return TRUE;
}
/* 00002154-0000215C .text daSail_IsDelete__FP10sail_class */
static BOOL daSail_IsDelete(sail_class* i_this) {
return TRUE;
}
/* 0000215C-000021D8 .text daSail_Delete__FP10sail_class */
static BOOL daSail_Delete(sail_class* i_this) {
dComIfG_resDeleteDemo(&i_this->mClothPhase, "Cloth");
dComIfG_resDeleteDemo(&i_this->mKaizokusenPhase, "Kaizokusen");
if (l_HIO.mNo >= 0) {
mDoHIO_root.m_subroot.deleteChild(l_HIO.mNo);
l_HIO.mNo = -1;
}
return TRUE;
}
/* 000021D8-00002254 .text daSail_checkCreateHeap__FP10fopAc_ac_c */
static BOOL daSail_checkCreateHeap(fopAc_ac_c* i_actor) {
sail_class* i_this = (sail_class*)i_actor;
J3DModelData* modelData = (J3DModelData*)dComIfG_getObjectRes("Kaizokusen", KAIZOKUSEN_INDEX_BDL_AMAST);
if (modelData == NULL) {
return FALSE;
}
i_this->mSailPacket.mStickModel = mDoExt_J3DModel__create(modelData, 0x00080000, 0x11000002);
if (i_this->mSailPacket.mStickModel != NULL) {
return TRUE;
} else {
return FALSE;
}
}
/* 00002254-000024E4 .text daSail_Create__FP10fopAc_ac_c */
static cPhs_State daSail_Create(fopAc_ac_c* i_actor) {
fopAcM_SetupActor(i_actor, sail_class);
sail_class* i_this = (sail_class*)i_actor;
{
cPhs_State rt1 = dComIfG_resLoad(&i_this->mClothPhase, "Cloth");
#if VERSION > VERSION_DEMO
if (rt1 != cPhs_COMPLEATE_e) {
return rt1;
}
#endif
cPhs_State rt2 = dComIfG_resLoad(&i_this->mKaizokusenPhase, "Kaizokusen");
#if VERSION == VERSION_DEMO
if (rt1 == cPhs_ERROR_e || rt2 == cPhs_ERROR_e) {
return cPhs_ERROR_e;
}
if (rt1 != cPhs_COMPLEATE_e) {
return rt1;
}
#endif
if (rt2 != cPhs_COMPLEATE_e) {
return rt2;
}
}
cPhs_State phase_state = cPhs_COMPLEATE_e;
if (phase_state == cPhs_COMPLEATE_e) {
if (fopAcM_entrySolidHeap(i_this, daSail_checkCreateHeap, 0x4C0)) {
if (l_HIO.mNo < 0) {
l_HIO.mNo = mDoHIO_root.m_subroot.createChild("海賊船の帆", &l_HIO); // "Pirate Ship's Sail"
}
i_this->mSailPacket.m1C44 = 0.0f;
i_this->mSailPacket.m1C48 = 0.0f;
cXyz* vtxPosSpd = i_this->mSailPacket.getPosSpd();
cXyz* vtxPos = i_this->mSailPacket.getPos();
for (int i = 0; i < ARRAY_SIZE(l_pos); i++, vtxPosSpd++, vtxPos++) {
vtxPosSpd->setall(0.0f);
vtxPos->set(l_pos[i]);
}
l_p_ship = (daObjPirateship::Act_c*)fopAcM_SearchByID(i_this->parentActorID);
if (l_p_ship->m2CE == 0) {
l_HIO.m06 = 0;
i_this->mSailPacket.m1C44 = 0.6f;
} else {
l_HIO.m06 = 1;
}
sail_move(i_this);
} else {
phase_state = cPhs_ERROR_e;
}
}
return phase_state;
}
static actor_method_class l_daSail_Method = {
(process_method_func)daSail_Create,
(process_method_func)daSail_Delete,
(process_method_func)daSail_Execute,
(process_method_func)daSail_IsDelete,
(process_method_func)daSail_Draw,
};
actor_process_profile_definition g_profile_SAIL = {
/* LayerID */ fpcLy_CURRENT_e,
/* ListID */ 0x0007,
/* ListPrio */ fpcPi_CURRENT_e,
/* ProcName */ PROC_SAIL,
/* Proc SubMtd */ &g_fpcLf_Method.base,
/* Size */ sizeof(sail_class),
/* SizeOther */ 0,
/* Parameters */ 0,
/* Leaf SubMtd */ &g_fopAc_Method.base,
/* Priority */ PRIO_SAIL,
/* Actor SubMtd */ &l_daSail_Method,
/* Status */ fopAcStts_UNK4000_e | fopAcStts_UNK40000_e,
/* Group */ fopAc_ACTOR_e,
/* CullType */ fopAc_CULLBOX_0_e,
};