mirror of
https://github.com/zeldaret/tp
synced 2026-05-23 06:54:28 -04:00
67b576ad9a
* f_op debug 1 * f_op debug 2 * f_op debug 3 * f_op debug 4 * f_op debug 5 * f_op_debug fix build * f_op linking * remove goto in fopac_create * fix regressions * fix regressions * pr comments
2333 lines
79 KiB
C++
2333 lines
79 KiB
C++
// d_particle is odd in that it doesn't appear to include dolzel.pch.
|
|
// It uses ...data pooling, but weak data from the PCH (e.g. Z2Calc::cNullVec)
|
|
// isn't present like would be expected for a TU using pooling.
|
|
//
|
|
// Note that it _is_ possible that it does include the PCH and there's just some
|
|
// not-yet-understood behavior causing the weak data to be stripped anyway.
|
|
// Notably, TWW's version of this TU _does_ use the PCH, but it also includes
|
|
// weak data from it (unlike here).
|
|
|
|
#include "d/d_particle.h"
|
|
#include "d/d_jnt_col.h"
|
|
#include "JSystem/JKernel/JKRExpHeap.h"
|
|
#include "JSystem/JKernel/JKRSolidHeap.h"
|
|
#include "JSystem/J3DGraphBase/J3DMaterial.h"
|
|
#include "JSystem/J3DGraphAnimator/J3DMaterialAnm.h"
|
|
#include "JSystem/JParticle/JPAEmitterManager.h"
|
|
#include "JSystem/JParticle/JPAResourceManager.h"
|
|
#include "JSystem/JMath/JMATrigonometric.h"
|
|
#include "d/d_s_play.h"
|
|
#include <stdio.h>
|
|
#include "d/d_com_inf_game.h"
|
|
#include "m_Do/m_Do_lib.h"
|
|
#include "m_Do/m_Do_graphic.h"
|
|
#include "f_op/f_op_actor_mng.h"
|
|
#include "d/actor/d_a_player.h"
|
|
#include "SSystem/SComponent/c_math.h"
|
|
|
|
#if DEBUG
|
|
#pragma nosyminline on
|
|
#endif
|
|
|
|
extern dPa_particleTracePcallBack_c JPTracePCB4;
|
|
|
|
void dPa_cleanupGX() {
|
|
GXSetTevColorOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
|
|
GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV);
|
|
GXEnableTexOffsets(GX_TEXCOORD0, GX_ENABLE, GX_ENABLE);
|
|
GXEnableTexOffsets(GX_TEXCOORD1, GX_ENABLE, GX_ENABLE);
|
|
GXEnableTexOffsets(GX_TEXCOORD2, GX_ENABLE, GX_ENABLE);
|
|
GXSetCullMode(GX_CULL_NONE);
|
|
GXSetCoPlanar(GX_FALSE);
|
|
GXClearVtxDesc();
|
|
GXSetVtxDesc(GX_VA_POS, GX_INDEX8);
|
|
GXSetVtxDesc(GX_VA_TEX0, GX_INDEX8);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_CLR_RGBA, GX_RGB8, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_TEX0, GX_CLR_RGBA, GX_RGB8, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT1, GX_VA_POS, GX_CLR_RGBA, GX_F32, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT1, GX_VA_TEX0, GX_CLR_RGBA, GX_F32, 0);
|
|
GXSetCurrentMtx(0);
|
|
GXSetChanCtrl(GX_COLOR0A0, GX_FALSE, GX_SRC_REG, GX_SRC_VTX, GX_LIGHT_NULL, GX_DF_NONE,
|
|
GX_AF_NONE);
|
|
GXSetChanCtrl(GX_COLOR1A1, GX_FALSE, GX_SRC_REG, GX_SRC_VTX, GX_LIGHT_NULL, GX_DF_NONE,
|
|
GX_AF_NONE);
|
|
GXSetNumChans(0);
|
|
}
|
|
|
|
static GXColor l_lifeBallColor[3] = {
|
|
{0xEB, 0x20, 0x78, 0xFF},
|
|
{0x20, 0xF1, 0x9B, 0xFF},
|
|
{0xEB, 0xD7, 0x2F, 0xFF},
|
|
};
|
|
|
|
dPa_followEcallBack::dPa_followEcallBack(u8 param_0, u8 param_1) {
|
|
field_0x11 = param_0;
|
|
field_0x12 = param_1;
|
|
field_0x13 = 0;
|
|
mpEmitter = NULL;
|
|
}
|
|
|
|
void dPa_followEcallBack::execute(JPABaseEmitter* i_emitter) {
|
|
if ((field_0x12 == 0) && ((field_0x10 & 2) == 0)) {
|
|
i_emitter->setGlobalTranslation(field_0x8->x, field_0x8->y, field_0x8->z);
|
|
if (field_0xc != NULL) {
|
|
// LIKELY FAKEMATCH
|
|
#if DEBUG
|
|
JGeometry::TVec3<s16> aTStack_24(field_0xc->x, field_0xc->y, field_0xc->z);
|
|
#else
|
|
JGeometry::TVec3<s16> aTStack_24;
|
|
aTStack_24.x = field_0xc->x;
|
|
aTStack_24.y = field_0xc->y;
|
|
aTStack_24.z = field_0xc->z;
|
|
#endif
|
|
i_emitter->setGlobalRotation(aTStack_24);
|
|
}
|
|
}
|
|
|
|
if (i_emitter->isEnableDeleteEmitter()) {
|
|
end();
|
|
}
|
|
if (isEnd()) {
|
|
s16 globalAlpha = i_emitter->getGlobalAlpha();
|
|
cLib_chaseS(&globalAlpha, 1, 4);
|
|
i_emitter->setGlobalAlpha(globalAlpha);
|
|
}
|
|
}
|
|
|
|
void dPa_followEcallBack::draw(JPABaseEmitter* i_emitter) {}
|
|
|
|
void dPa_followEcallBack::setup(JPABaseEmitter* i_emitter, cXyz const* param_1,
|
|
csXyz const* param_2, s8) {
|
|
remove();
|
|
|
|
if (field_0x13 == 0) {
|
|
mpEmitter = i_emitter;
|
|
i_emitter->becomeImmortalEmitter();
|
|
}
|
|
|
|
if (field_0x12 == 0) {
|
|
if (field_0x11 != 0) {
|
|
i_emitter->becomeContinuousParticle();
|
|
}
|
|
field_0x8 = param_1;
|
|
field_0xc = param_2;
|
|
field_0x10 = 0;
|
|
}
|
|
}
|
|
|
|
void dPa_followEcallBack::end() {
|
|
if (mpEmitter != NULL) {
|
|
mpEmitter->becomeInvalidEmitter();
|
|
mpEmitter->quitImmortalEmitter();
|
|
mpEmitter->setEmitterCallBackPtr(NULL);
|
|
field_0x10 |= (u8)1;
|
|
mpEmitter = NULL;
|
|
}
|
|
}
|
|
|
|
u32 dummy(JPABaseEmitter* i_emitter) {
|
|
return i_emitter->getAge();
|
|
}
|
|
|
|
dPa_modelEcallBack dPa_modelEcallBack::mEcallback;
|
|
|
|
dPa_modelPcallBack dPa_modelEcallBack::mPcallback;
|
|
|
|
dPa_modelEcallBack::model_c* dPa_modelEcallBack::mModel;
|
|
|
|
#if DEBUG
|
|
u8 dPa_modelEcallBack::mNum;
|
|
#endif
|
|
|
|
static u8 struct_80450E9C;
|
|
static u8 struct_80450E9D;
|
|
|
|
void dPa_light8EcallBack::setup(JPABaseEmitter* i_emitter, cXyz const* param_1, csXyz const* param_2, s8 param_3) {
|
|
i_emitter->setDrawTimes(2);
|
|
i_emitter->setParticleCallBackPtr(dPa_control_c::getLight8PcallBack());
|
|
}
|
|
|
|
void dPa_gen_b_light8EcallBack::setup(JPABaseEmitter* i_emitter, cXyz const* param_1, csXyz const* param_2, s8 param_3) {
|
|
u32 userWork = param_3;
|
|
i_emitter->setDrawTimes(2);
|
|
i_emitter->setParticleCallBackPtr(dPa_control_c::getGen_b_Light8PcallBack());
|
|
i_emitter->setUserWork((s8)userWork);
|
|
}
|
|
|
|
void dPa_gen_d_light8EcallBack::setup(JPABaseEmitter* i_emitter, cXyz const* param_1, csXyz const* param_2, s8 param_3) {
|
|
u32 userWork = param_3;
|
|
i_emitter->setDrawTimes(2);
|
|
i_emitter->setParticleCallBackPtr(dPa_control_c::getGen_d_Light8PcallBack());
|
|
i_emitter->setUserWork((s8)userWork);
|
|
}
|
|
|
|
static void dPa_group_id_change(u32* param_0, u8* param_1) {
|
|
if (*param_1 >= 15) {
|
|
return;
|
|
}
|
|
|
|
if (*param_0 & 1) {
|
|
param_1[0] = 0;
|
|
} else if (*param_0 & 2) {
|
|
param_1[0] = 1;
|
|
} else if (*param_0 & 4) {
|
|
param_1[0] = 2;
|
|
} else if (*param_0 & 8) {
|
|
param_1[0] = 3;
|
|
} else if (*param_0 & 0x4000) {
|
|
param_1[0] = 4;
|
|
} else if (*param_0 & 0x8000) {
|
|
param_1[0] = 5;
|
|
}
|
|
|
|
if (*param_0 & 0x10) {
|
|
switch(*param_1) {
|
|
case 0:
|
|
*param_1 = 8;
|
|
break;
|
|
case 1:
|
|
*param_1 = 9;
|
|
break;
|
|
case 2:
|
|
*param_1 = 10;
|
|
break;
|
|
case 3:
|
|
*param_1 = 11;
|
|
break;
|
|
case 4:
|
|
*param_1 = 6;
|
|
break;
|
|
case 5:
|
|
*param_1 = 7;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (*param_0 & 0x80) {
|
|
*param_1 = 13;
|
|
} else if (*param_0 & 0x1000) {
|
|
*param_1 = 12;
|
|
} else if (*param_0 & 0x2000) {
|
|
*param_1 = 14;
|
|
}
|
|
}
|
|
|
|
static void initiateLighting8(_GXColor& param_0, s16 param_1) {
|
|
GXSetChanCtrl(GX_COLOR0, true, GX_SRC_REG, GX_SRC_VTX, 0xfe, GX_DF_CLAMP, GX_AF_SPOT);
|
|
GXSetChanCtrl(GX_ALPHA0, false, GX_SRC_REG, GX_SRC_VTX, 0xfe, GX_DF_CLAMP, GX_AF_SPOT);
|
|
s32 r,g,b;
|
|
GXColor color0;
|
|
color0.r = r = (param_1 & 0x1F) << 1;
|
|
color0.g = g = ((param_1 >> 5) & 0x1F) << 1;
|
|
color0.b = b = ((param_1 >> 10) & 0x1F) << 1;
|
|
if (daPy_py_c::checkNowWolfPowerUp()) {
|
|
f32 fVar1 = (g_env_light.bg_amb_col[0].r / 255.0f);
|
|
color0.r = (r + 0x10) * (4.0f * (fVar1));
|
|
|
|
fVar1 = (g_env_light.bg_amb_col[0].g / 255.0f);
|
|
color0.g = (g + 0x10) * (4.0f * (fVar1));
|
|
|
|
fVar1 = (g_env_light.bg_amb_col[0].b / 255.0f);
|
|
color0.b = (b + 0x10) * (4.0f * (fVar1));
|
|
}
|
|
|
|
if (color0.r == 0x3e) {
|
|
color0.r = param_0.r & 0xFF;
|
|
}
|
|
if (color0.g == 0x3e) {
|
|
color0.g = param_0.g & 0xFF;
|
|
}
|
|
if (color0.b == 0x3e) {
|
|
color0.b = param_0.b & 0xFF;
|
|
}
|
|
GXSetChanAmbColor(GX_COLOR0A0, color0);
|
|
GXSetChanMatColor(GX_COLOR0A0, g_whiteColor);
|
|
}
|
|
|
|
static void initiate_b_Lighting8(_GXColor& param_0) {
|
|
GXSetChanCtrl(GX_COLOR0, true, GX_SRC_REG, GX_SRC_VTX, 0xfe, GX_DF_CLAMP, GX_AF_SPOT);
|
|
GXSetChanCtrl(GX_ALPHA0, false, GX_SRC_REG, GX_SRC_VTX, 0xfe, GX_DF_CLAMP, GX_AF_SPOT);
|
|
GXSetChanAmbColor(GX_COLOR0A0, param_0);
|
|
GXSetChanMatColor(GX_COLOR0A0, g_whiteColor);
|
|
}
|
|
|
|
static void drawFirst(JPABaseEmitter* i_emitter) {
|
|
GXSetColorUpdate(false);
|
|
GXSetAlphaCompare(GX_GEQUAL, i_emitter->getGlobalAlpha(), GX_AOP_OR, GX_GEQUAL, i_emitter->getGlobalAlpha());
|
|
GXSetZMode(true, GX_LEQUAL, true);
|
|
GXSetZCompLoc(false);
|
|
}
|
|
|
|
static void drawFirst_l8(JPABaseEmitter* i_emitter) {
|
|
GXSetColorUpdate(false);
|
|
}
|
|
|
|
static void drawSecond_light8(JPABaseEmitter* i_emitter) {
|
|
GXColor globalPrmColor;
|
|
i_emitter->getGlobalPrmColor(&globalPrmColor);
|
|
s16 sVar3 = (s16)((s16)globalPrmColor.r << 8) + (s16)globalPrmColor.g;
|
|
dScnKy_env_light_c* envLight = dKy_getEnvlight();
|
|
dKy_setLight_nowroom_grass(dComIfGp_roomControl_getStayNo(), 0.0f);
|
|
GXSetColorUpdate(1);
|
|
GXSetAlphaCompare(GX_ALWAYS, 0, GX_AOP_AND, GX_ALWAYS, 0);
|
|
GXSetZMode(true, GX_LEQUAL, false);
|
|
GXSetZCompLoc(0);
|
|
GXSetBlendMode(GX_BM_BLEND, GX_BL_SRCALPHA, GX_BL_INVSRCALPHA, GX_LO_SET);
|
|
GXSetNumChans(1);
|
|
GXColor color;
|
|
color.r = envLight->bg_amb_col[0].r;
|
|
color.g = envLight->bg_amb_col[0].g;
|
|
color.b = envLight->bg_amb_col[0].b;
|
|
color.a = envLight->bg_amb_col[0].a;
|
|
initiateLighting8(color, sVar3);
|
|
GXSetNumTexGens(1);
|
|
GXSetTexCoordGen(GX_TEXCOORD0, GX_TG_MTX2x4, GX_TG_TEX0, 0x3c);
|
|
GXSetNumTevStages(2);
|
|
GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD0, GX_TEXMAP0, GX_COLOR0A0);
|
|
GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_ZERO, GX_CC_TEXC, GX_CC_RASC, 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_ZERO, GX_CA_RASA, GX_CA_ZERO);
|
|
GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, true, GX_TEVPREV);
|
|
GXSetTevOrder(GX_TEVSTAGE1, GX_TEXCOORD0, GX_TEXMAP0, GX_COLOR0A0);
|
|
GXSetTevColorIn(GX_TEVSTAGE1, GX_CC_ZERO, GX_CC_ZERO, GX_CC_ZERO, GX_CC_CPREV);
|
|
GXSetTevColorOp(GX_TEVSTAGE1, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_4, true, GX_TEVPREV);
|
|
GXSetTevAlphaIn(GX_TEVSTAGE1, GX_CA_ZERO, GX_CA_TEXA, GX_CA_A0, GX_CA_ZERO);
|
|
GXSetTevAlphaOp(GX_TEVSTAGE1, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, true, GX_TEVPREV);
|
|
}
|
|
|
|
static void drawSecond_b_light8(JPABaseEmitter* i_emitter) {
|
|
dScnKy_env_light_c* envLight = dKy_getEnvlight();
|
|
dKy_setLight_nowroom(dComIfGp_roomControl_getStayNo());
|
|
GXSetColorUpdate(true);
|
|
GXSetNumChans(1);
|
|
GXColor local_18;
|
|
if (i_emitter->getUserWork() == 0) {
|
|
local_18.r = envLight->actor_amb_col.r;
|
|
local_18.g = envLight->actor_amb_col.g;
|
|
local_18.b = envLight->actor_amb_col.b;
|
|
local_18.a = envLight->actor_amb_col.a;
|
|
} else {
|
|
local_18.r = envLight->bg_amb_col[0].r;
|
|
local_18.g = envLight->bg_amb_col[0].g;
|
|
local_18.b = envLight->bg_amb_col[0].b;
|
|
local_18.a = envLight->bg_amb_col[0].a;
|
|
}
|
|
initiate_b_Lighting8(local_18);
|
|
GXSetNumTevStages(2);
|
|
GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD0, GX_TEXMAP0, GX_COLOR0A0);
|
|
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_ZERO, GX_CA_RASA, GX_CA_ZERO);
|
|
GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, true, GX_TEVPREV);
|
|
GXSetTevOrder(GX_TEVSTAGE1, GX_TEXCOORD0, GX_TEXMAP0, GX_COLOR0A0);
|
|
GXSetTevColorIn(GX_TEVSTAGE1, GX_CC_ZERO, GX_CC_CPREV, GX_CC_RASC, GX_CC_ZERO);
|
|
GXSetTevColorOp(GX_TEVSTAGE1, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_4, true, GX_TEVPREV);
|
|
GXSetTevAlphaIn(GX_TEVSTAGE1, GX_CA_ZERO, GX_CA_TEXA, GX_CA_A0, GX_CA_ZERO);
|
|
GXSetTevAlphaOp(GX_TEVSTAGE1, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, true, GX_TEVPREV);
|
|
}
|
|
|
|
static void static_light8EcallBack(JPABaseEmitter* i_emitter) {
|
|
GXFlush();
|
|
GXLoadPosMtxImm(j3dSys.getViewMtx(), 0);
|
|
GXLoadNrmMtxImm(j3dSys.getViewMtx(), 0);
|
|
GXInvalidateVtxCache();
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_CLR_RGBA, GX_F32, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_NRM, GX_CLR_RGB, GX_F32, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_CLR0, GX_CLR_RGBA, GX_RGBA8, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_TEX0, GX_CLR_RGBA, GX_F32, 0);
|
|
GXClearVtxDesc();
|
|
GXSetVtxDesc(GX_VA_POS, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_NRM, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_CLR0, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_TEX0, GX_DIRECT);
|
|
|
|
switch (i_emitter->getDrawCount()) {
|
|
case 1:
|
|
drawFirst(i_emitter);
|
|
break;
|
|
case 2:
|
|
drawSecond_light8(i_emitter);
|
|
break;
|
|
}
|
|
}
|
|
|
|
static void static_gen_b_light8EcallBack(JPABaseEmitter* i_emitter) {
|
|
GXFlush();
|
|
Mtx identity;
|
|
MTXIdentity(identity);
|
|
GXLoadPosMtxImm(identity, 0);
|
|
GXLoadNrmMtxImm(identity, 0);
|
|
GXInvalidateVtxCache();
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_CLR_RGBA, GX_F32, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_NRM, GX_CLR_RGB, GX_F32, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_CLR0, GX_CLR_RGBA, GX_RGBA8, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_TEX0, GX_CLR_RGBA, GX_F32, 0);
|
|
GXClearVtxDesc();
|
|
GXSetVtxDesc(GX_VA_POS, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_NRM, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_CLR0, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_TEX0, GX_DIRECT);
|
|
|
|
switch (i_emitter->getDrawCount()) {
|
|
case 1:
|
|
drawFirst_l8(i_emitter);
|
|
break;
|
|
case 2:
|
|
drawSecond_b_light8(i_emitter);
|
|
break;
|
|
}
|
|
}
|
|
|
|
static void static_gen_d_light8EcallBack(JPABaseEmitter* i_emitter) {
|
|
GXFlush();
|
|
GXLoadPosMtxImm(j3dSys.getViewMtx(), 0);
|
|
GXLoadNrmMtxImm(j3dSys.getViewMtx(), 0);
|
|
GXInvalidateVtxCache();
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_CLR_RGBA, GX_F32, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_NRM, GX_CLR_RGB, GX_F32, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_CLR0, GX_CLR_RGBA, GX_RGBA8, 0);
|
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_TEX0, GX_CLR_RGBA, GX_F32, 0);
|
|
GXClearVtxDesc();
|
|
GXSetVtxDesc(GX_VA_POS, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_NRM, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_CLR0, GX_DIRECT);
|
|
GXSetVtxDesc(GX_VA_TEX0, GX_DIRECT);
|
|
|
|
switch (i_emitter->getDrawCount()) {
|
|
case 1:
|
|
drawFirst_l8(i_emitter);
|
|
break;
|
|
case 2:
|
|
drawSecond_b_light8(i_emitter);
|
|
break;
|
|
}
|
|
}
|
|
|
|
void dPa_light8EcallBack::draw(JPABaseEmitter* i_emitter) {
|
|
static_light8EcallBack(i_emitter);
|
|
}
|
|
|
|
void dPa_gen_b_light8EcallBack::draw(JPABaseEmitter* i_emitter) {
|
|
static_gen_b_light8EcallBack(i_emitter);
|
|
}
|
|
|
|
void dPa_gen_d_light8EcallBack::draw(JPABaseEmitter* i_emitter) {
|
|
static_gen_d_light8EcallBack(i_emitter);
|
|
}
|
|
|
|
static void dPa_setWindPower(JPABaseParticle* param_0) {
|
|
f32 local_58;
|
|
JGeometry::TVec3<f32> aTStack_18;
|
|
JGeometry::TVec3<f32> aTStack_24;
|
|
JGeometry::TVec3<f32> aTStack_30;
|
|
cXyz cStack_3c;
|
|
param_0->getOffsetPosition(&aTStack_24);
|
|
dKyw_get_AllWind_vec((cXyz*)&aTStack_24, &cStack_3c, &local_58);
|
|
cStack_3c.y = 0.65f;
|
|
JGeometry::TVec3<f32> aTStack_48;
|
|
JGeometry::setTVec3f(cStack_3c * (9.0f * local_58), *(Vec*)&aTStack_48);
|
|
aTStack_24 += aTStack_48;
|
|
param_0->setOffsetPosition(aTStack_24);
|
|
}
|
|
|
|
void dPa_modelPcallBack::draw(JPABaseEmitter* i_emitter, JPABaseParticle* param_1) {
|
|
Mtx local_74;
|
|
Mtx local_44;
|
|
JGeometry::TVec3<f32> local_cc;
|
|
JGeometry::TVec3<f32> aTStack_24;
|
|
JGeometry::TVec3<f32> aTStack_30;
|
|
JGeometry::TVec3<f32> aTStack_36;
|
|
JGeometry::TVec3<f32> local_fc;
|
|
MTXIdentity(local_74);
|
|
MTXIdentity(local_44);
|
|
f32 f31 = -90.0f / 16384.0f * param_1->getRotateAngle();
|
|
if (f31) {
|
|
switch(dPa_modelEcallBack::getRotAxis(i_emitter)) {
|
|
case 0:
|
|
MTXRotRad(local_44, 0x79, DEG_TO_RAD(f31));
|
|
break;
|
|
case 1:
|
|
MTXRotRad(local_44, 0x78, DEG_TO_RAD(f31));
|
|
break;
|
|
case 2:
|
|
MTXRotRad(local_44, 0x7a, DEG_TO_RAD(f31));
|
|
break;
|
|
case 3:
|
|
Vec vec = {1.0f, 1.0f, 1.0f};
|
|
MTXRotAxisRad(local_44, &vec, DEG_TO_RAD(f31));
|
|
}
|
|
|
|
MTXConcat(local_74, local_44, local_74);
|
|
}
|
|
param_1->getGlobalPosition(&local_cc);
|
|
local_74[0][3] = local_cc.x;
|
|
local_74[1][3] = local_cc.y;
|
|
local_74[2][3] = local_cc.z;
|
|
i_emitter->getGlobalParticleScale(&local_fc);
|
|
local_fc.x *= param_1->getParticleScaleX();
|
|
local_fc.y *= param_1->getParticleScaleY();
|
|
Mtx auStack_c0;
|
|
local_fc.z = local_fc.x;
|
|
MTXScale(auStack_c0, local_fc.x, local_fc.y, local_fc.z);
|
|
MTXConcat(local_74, auStack_c0, local_74);
|
|
dPa_modelEcallBack::drawModel(i_emitter, local_74);
|
|
param_1->setInvisibleParticleFlag();
|
|
}
|
|
|
|
bool dPa_modelEcallBack::model_c::set(J3DModelData* i_modelData, dKy_tevstr_c const& param_1,
|
|
u8 rotAxis, void* param_3, u8 param_4, u8 param_5) {
|
|
if (mModelData != NULL) {
|
|
return false;
|
|
}
|
|
|
|
mModelData = i_modelData;
|
|
#if DEBUG
|
|
field_0x8 = param_1;
|
|
#else
|
|
field_0x8.mLightObj = param_1.mLightObj;
|
|
|
|
// Supposedly dKy_tevstr_c::operator= but it's too big to inline
|
|
J3DLightObj* end;
|
|
J3DLightObj* src;
|
|
J3DLightObj* dst;
|
|
dst = (J3DLightObj*)field_0x8.mLights;
|
|
src = (J3DLightObj*)param_1.mLights;
|
|
end = field_0x8.mLights + 6;
|
|
do {
|
|
*dst = *src;
|
|
dst++;
|
|
src++;
|
|
} while (dst < end);
|
|
field_0x8.field_0x32c = param_1.field_0x32c;
|
|
field_0x8.mLightPosWorld = param_1.mLightPosWorld;
|
|
field_0x8.field_0x344 = param_1.field_0x344;
|
|
typedef struct Arr{
|
|
int field_0x0[2];
|
|
};
|
|
*(Arr*)&field_0x8.AmbCol = *(Arr*)¶m_1.AmbCol;
|
|
*(Arr*)&field_0x8.FogCol = *(Arr*)¶m_1.FogCol;
|
|
*(Arr*)&field_0x8.TevColor = *(Arr*)¶m_1.TevColor;
|
|
*(int*)&field_0x8.TevKColor = *(int*)¶m_1.TevKColor;
|
|
*(int*)&field_0x8.mLightInf = *(int*)¶m_1.mLightInf;
|
|
|
|
field_0x8.mFogStartZ = param_1.mFogStartZ;
|
|
field_0x8.mFogEndZ = param_1.mFogEndZ;
|
|
field_0x8.pat_ratio = param_1.pat_ratio;
|
|
field_0x8.field_0x374 = param_1.field_0x374;
|
|
field_0x8.Material_id = param_1.Material_id;
|
|
field_0x8.Type = param_1.Type;
|
|
field_0x8.mInitTimer = param_1.mInitTimer;
|
|
field_0x8.UseCol = param_1.UseCol;
|
|
field_0x8.PrevCol = param_1.PrevCol;
|
|
field_0x8.wether_pat1 = param_1.wether_pat1;
|
|
field_0x8.wether_pat0 = param_1.wether_pat0;
|
|
field_0x8.room_no = param_1.room_no;
|
|
field_0x8.YukaCol = param_1.YukaCol;
|
|
field_0x8.mLightMode = param_1.mLightMode;
|
|
field_0x8.Material_use_fg = param_1.Material_use_fg;
|
|
field_0x8.field_0x384 = param_1.field_0x384;
|
|
field_0x8.field_0x385 = param_1.field_0x385;
|
|
#endif
|
|
mRotAxis = rotAxis;
|
|
field_0x391 = param_5;
|
|
field_0x4 = (J3DAnmBase*)param_3;
|
|
field_0x392 = param_4;
|
|
|
|
return true;
|
|
}
|
|
|
|
void dPa_modelEcallBack::model_c::setup() {
|
|
JUT_ASSERT(1284, mModelData != NULL);
|
|
|
|
if (field_0x4 != NULL) {
|
|
if (field_0x392 == 0) {
|
|
J3DAnmTexPattern* pattern = (J3DAnmTexPattern*)field_0x4;
|
|
pattern->searchUpdateMaterialID(mModelData);
|
|
pattern->setFrame(field_0x391);
|
|
mModelData->entryTexNoAnimator(pattern);
|
|
} else {
|
|
J3DAnmTevRegKey* tevRegKey = (J3DAnmTevRegKey*)field_0x4;
|
|
tevRegKey->searchUpdateMaterialID(mModelData);
|
|
tevRegKey->setFrame(field_0x391);
|
|
mModelData->entryTevRegAnimator(tevRegKey);
|
|
}
|
|
}
|
|
|
|
mModelData->syncJ3DSys();
|
|
J3DShape::resetVcdVatCache();
|
|
}
|
|
|
|
|
|
void dPa_modelEcallBack::model_c::cleanup() {
|
|
if (field_0x4 == NULL) {
|
|
return;
|
|
}
|
|
|
|
if (field_0x392 == 0) {
|
|
J3DAnmTexPattern* anm = (J3DAnmTexPattern*)field_0x4;
|
|
mModelData->removeTexNoAnimator(anm);
|
|
} else {
|
|
J3DAnmTevRegKey* anm = (J3DAnmTevRegKey*)field_0x4;
|
|
mModelData->removeTevRegAnimator(anm);
|
|
}
|
|
}
|
|
|
|
void dPa_modelEcallBack::model_c::draw(f32 (*param_0)[4]) {
|
|
J3DJoint* joint = mModelData->getJointNodePointer(0);
|
|
for (J3DMaterial* material = joint->getMesh(); material != NULL; material = material->getNext())
|
|
{
|
|
material->loadSharedDL();
|
|
material->getShape()->loadPreDrawSetting();
|
|
if (material->getMaterialAnm() != NULL) {
|
|
material->getMaterialAnm()->calc(material);
|
|
}
|
|
material->calc(param_0);
|
|
u16 texNo = material->getTevBlock()->getTexNo(0);
|
|
mModelData->getTexture()->loadGX(texNo, GX_TEXMAP0);
|
|
dKy_setLight_again();
|
|
dKy_Global_amb_set(&field_0x8);
|
|
dKy_GxFog_tevstr_set(&field_0x8);
|
|
Mtx auStack_48;
|
|
MTXConcat(j3dSys.getViewMtx(), param_0, auStack_48);
|
|
GXLoadPosMtxImm(auStack_48, 0);
|
|
GXLoadNrmMtxImm(auStack_48, 0);
|
|
material->getShape()->simpleDrawCache();
|
|
}
|
|
}
|
|
|
|
void dPa_modelEcallBack::draw(JPABaseEmitter* i_emitter) {
|
|
if (i_emitter->isEnableDeleteEmitter()) {
|
|
i_emitter->quitImmortalEmitter();
|
|
i_emitter->setEmitterCallBackPtr(NULL);
|
|
i_emitter->setParticleCallBackPtr(NULL);
|
|
resetModel(i_emitter);
|
|
} else {
|
|
setupModel(i_emitter);
|
|
}
|
|
}
|
|
|
|
void dPa_modelEcallBack::setup(JPABaseEmitter* i_emitter, cXyz const* param_1, csXyz const* param_2, s8 param_3) {
|
|
i_emitter->setEmitterCallBackPtr(NULL);
|
|
if (mModel != NULL) {
|
|
int sVar1 = struct_80450E9C;
|
|
for (int i = 0; i < sVar1; i++) {
|
|
int x = struct_80450E9D / sVar1;
|
|
struct_80450E9D -= (x) * sVar1;
|
|
if (mModel[struct_80450E9D].getModelData() == NULL) {
|
|
i_emitter->setUserWork(struct_80450E9D++);
|
|
i_emitter->setParticleCallBackPtr(&mPcallback);
|
|
return;
|
|
}
|
|
struct_80450E9D++;
|
|
}
|
|
}
|
|
}
|
|
|
|
void dPa_modelEcallBack::create(u8 param_0) {
|
|
mModel = new model_c[param_0];
|
|
struct_80450E9C = param_0;
|
|
struct_80450E9D = 0;
|
|
}
|
|
|
|
void dPa_modelEcallBack::remove() {
|
|
if (mModel != NULL) {
|
|
delete [] mModel;
|
|
mModel = NULL;
|
|
}
|
|
}
|
|
|
|
int dPa_modelEcallBack::setModel(JPABaseEmitter* i_emitter, J3DModelData* i_modelData,
|
|
dKy_tevstr_c const& param_2, u8 param_3, void* param_4,
|
|
u8 param_5, u8 param_6) {
|
|
JUT_ASSERT(1478, i_modelData != NULL);
|
|
|
|
model_c* pModel = getModel(i_emitter);
|
|
if (pModel != NULL) {
|
|
pModel->set(i_modelData, param_2, param_3, param_4, param_5, param_6);
|
|
i_emitter->setEmitterCallBackPtr((JPAEmitterCallBack*)&mEcallback);
|
|
i_emitter->becomeImmortalEmitter();
|
|
return 1;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
void dPa_modelEcallBack::resetModel(JPABaseEmitter* i_emitter) {
|
|
JUT_ASSERT(1507, i_emitter != NULL);
|
|
|
|
model_c* pModel = getModel(i_emitter);
|
|
if (pModel) {
|
|
pModel->reset();
|
|
}
|
|
}
|
|
|
|
void dPa_modelEcallBack::setupModel(JPABaseEmitter* i_emitter) {
|
|
JUT_ASSERT(1524, i_emitter != NULL);
|
|
|
|
model_c* pModel = getModel(i_emitter);
|
|
if (pModel) {
|
|
pModel->setup();
|
|
}
|
|
}
|
|
|
|
void dPa_modelEcallBack::drawModel(JPABaseEmitter* i_emitter, f32 (*param_1)[4]) {
|
|
JUT_ASSERT(1542, i_emitter != NULL);
|
|
|
|
model_c* pModel = getModel(i_emitter);
|
|
if (pModel) {
|
|
pModel->draw(param_1);
|
|
}
|
|
}
|
|
|
|
void dPa_modelEcallBack::cleanupModel(JPABaseEmitter* i_emitter) {
|
|
JUT_ASSERT(1559, i_emitter != NULL);
|
|
|
|
model_c* pModel = getModel(i_emitter);
|
|
if (pModel) {
|
|
pModel->cleanup();
|
|
}
|
|
dPa_cleanupGX();
|
|
}
|
|
|
|
dPa_modelEcallBack::model_c* dPa_modelEcallBack::getModel(JPABaseEmitter* i_emitter) {
|
|
if (mModel != NULL && i_emitter != NULL && i_emitter->getUserWork() != 0xFFFFFFFF) {
|
|
JUT_ASSERT(1585, i_emitter->getUserWork() < mNum);
|
|
return mModel + i_emitter->getUserWork();
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
u8 dPa_modelEcallBack::getRotAxis(JPABaseEmitter* i_emitter) {
|
|
JUT_ASSERT(1602, i_emitter != NULL);
|
|
|
|
model_c* pModel = getModel(i_emitter);
|
|
if (pModel) {
|
|
return pModel->getRotAxis();
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
void dPa_selectTexEcallBack::draw(JPABaseEmitter* i_emitter) {
|
|
i_emitter->loadTexture(field_0x4, GX_TEXMAP0);
|
|
}
|
|
|
|
dPa_simpleEcallBack::dPa_simpleEcallBack() {
|
|
mEmitter = NULL;
|
|
field_0xc = 0;
|
|
}
|
|
|
|
void dPa_simpleEcallBack::executeAfter(JPABaseEmitter* i_emitter) {
|
|
int currentCreateNumber = i_emitter->getCurrentCreateNumber();
|
|
if (currentCreateNumber <= 0) {
|
|
field_0xc = 0;
|
|
} else {
|
|
dPa_simpleData_c* pData = mData;
|
|
i_emitter->playCreateParticle();
|
|
for (; field_0xc != 0; field_0xc--) {
|
|
Vec local_3c;
|
|
if ((int)mDoLib_clipper::clip(j3dSys.getViewMtx(), *(Vec*)pData, 200.0f) == 0) {
|
|
JGeometry::TVec3<f32> aTStack_30;
|
|
i_emitter->getLocalTranslation(&aTStack_30);
|
|
i_emitter->setGlobalTranslation(pData->field_0x00.x, pData->field_0x00.y + aTStack_30.y, pData->field_0x00.z);
|
|
i_emitter->setGlobalPrmColor(pData->field_0x0c.r, pData->field_0x0c.g, pData->field_0x0c.b);
|
|
i_emitter->setGlobalAlpha(pData->field_0x0c.a);
|
|
i_emitter->setGlobalEnvColor(pData->field_0x10.r, pData->field_0x10.g, pData->field_0x10.b);
|
|
for (int i = 0; i < currentCreateNumber; i++) {
|
|
JPABaseParticle* particle = (JPABaseParticle*)i_emitter->createParticle();
|
|
if (particle == NULL)
|
|
break;
|
|
particle->setOffsetPosition(pData->field_0x00.x, pData->field_0x00.y + aTStack_30.y, pData->field_0x00.z);
|
|
}
|
|
}
|
|
pData++;
|
|
}
|
|
}
|
|
|
|
i_emitter->stopCreateParticle();
|
|
}
|
|
|
|
void dPa_simpleEcallBack::draw(JPABaseEmitter* i_emitter) {
|
|
/* empty function */
|
|
}
|
|
|
|
JPABaseEmitter* dPa_simpleEcallBack::create(JPAEmitterManager* param_0, u16 id, u8 param_2) {
|
|
mEmitter = NULL;
|
|
field_0xa = param_2;
|
|
mID = id;
|
|
field_0xe = 0x20;
|
|
mData = new dPa_simpleData_c[field_0xe];
|
|
JUT_ASSERT(1747, mData != NULL);
|
|
createEmitter(param_0);
|
|
return mEmitter;
|
|
}
|
|
|
|
dPa_simpleData_c::~dPa_simpleData_c() {}
|
|
|
|
dPa_simpleData_c::dPa_simpleData_c() {
|
|
/* empty function */
|
|
}
|
|
|
|
JPABaseEmitter* dPa_simpleEcallBack::createEmitter(JPAEmitterManager* param_0) {
|
|
u8 id = dPa_control_c::getRM_ID(mID);
|
|
JPAResourceManager* this_00 = param_0->getResourceManager(id);
|
|
u32 uVar1 = this_00->getResUserWork(mID);
|
|
if (mEmitter == NULL) {
|
|
static JGeometry::TVec3<f32> pos(0.0f, 0.0f, 0.0f);
|
|
|
|
mEmitter = param_0->createSimpleEmitterID(pos, mID, field_0xa, dPa_control_c::getRM_ID(mID), NULL, NULL);
|
|
if (mEmitter == NULL) {
|
|
return NULL;
|
|
}
|
|
|
|
if ((uVar1 & 0x100) != 0) {
|
|
mEmitter->setParticleCallBackPtr(dPa_control_c::getFsenthPcallBack());
|
|
}
|
|
|
|
mEmitter->setEmitterCallBackPtr(this);
|
|
mEmitter->becomeContinuousParticle();
|
|
mEmitter->stopCreateParticle();
|
|
}
|
|
|
|
return mEmitter;
|
|
}
|
|
|
|
u32 dPa_simpleEcallBack::set(cXyz const* i_pos, dKy_tevstr_c const* param_2, u8 param_3,
|
|
_GXColor const& param_4, _GXColor const& param_5, int param_6, f32 param_7) {
|
|
f32 fVar1;
|
|
f32 dVar7 = param_7;
|
|
if (param_2 != NULL && param_2->Material_use_fg != 124) {
|
|
OS_REPORT("\x1b[43;30mSimple Particle tevstr nonset !!\n");
|
|
return 0;
|
|
}
|
|
|
|
dPa_simpleData_c* pData = mData;
|
|
if (pData == NULL || field_0xc >= field_0xe) {
|
|
if (pData == NULL) {
|
|
OS_REPORT("\x1b[43;30mSimple Particle Nothing !!\n");
|
|
} else {
|
|
OS_REPORT("\x1b[43;30mSimple Particle Set Over !!\n");
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
pData = mData + field_0xc;
|
|
pData->field_0x00 = *i_pos;
|
|
u8 id = dPa_control_c::getRM_ID(mID);
|
|
JPAResourceManager* manager = dPa_control_c::getEmitterManager()->getResourceManager(id);
|
|
u32 uVar5 = manager->getResUserWork(mID);
|
|
if (((uVar5 & 0xEF0000) >> 16) < 100) {
|
|
dVar7 = ((uVar5 & 0xEF0000) >> 16) / 99.0f;
|
|
}
|
|
|
|
if (((uVar5 & 0xEF0000) >> 16) < 100) {
|
|
dVar7 = ((uVar5 & 0xEF0000) >> 16) / 99.0f;
|
|
}
|
|
|
|
if ((uVar5 & 0x20) != 0) {
|
|
GXColor local_5c;
|
|
GXColor local_60;
|
|
GXColor local_64 = {0xff, 0xff, 0xff, 0xff};
|
|
GXColor local_68 = {0xff, 0xff, 0xff, 0xff};
|
|
if (¶m_5 != NULL) {
|
|
local_64 = param_5;
|
|
}
|
|
|
|
if (¶m_4 != NULL) {
|
|
local_68 = param_4;
|
|
}
|
|
|
|
dKy_ParticleColor_get_actor((cXyz*)i_pos, (dKy_tevstr_c*)param_2, &local_5c, &local_60,
|
|
&local_64, &local_68, dVar7);
|
|
pData->field_0x0c.r = local_60.r;
|
|
pData->field_0x0c.g = local_60.g;
|
|
pData->field_0x0c.b = local_60.b;
|
|
pData->field_0x10.r = local_5c.r;
|
|
pData->field_0x10.g = local_5c.g;
|
|
pData->field_0x10.b = local_5c.b;
|
|
} else if ((uVar5 & 0x40) != 0) {
|
|
GXColor local_6c;
|
|
GXColor local_70;
|
|
GXColor local_74 = {0xff, 0xff, 0xff, 0xff};
|
|
GXColor local_78 = {0xff, 0xff, 0xff, 0xff};
|
|
if (¶m_5 != NULL) {
|
|
local_74 = param_5;
|
|
}
|
|
|
|
if (¶m_4 != NULL) {
|
|
local_78 = param_4;
|
|
}
|
|
|
|
dKy_ParticleColor_get_bg((cXyz*)i_pos, (dKy_tevstr_c*)param_2, &local_6c, &local_70, &local_74, &local_78,
|
|
dVar7);
|
|
f32 work__ratio = g_env_light.bg_light_influence +
|
|
(1.0f - g_env_light.bg_light_influence) * dVar7;
|
|
OS_REPORT("\nwork__ratio=[%f]", work__ratio);
|
|
local_6c = dKy_light_influence_col(&local_6c, work__ratio);
|
|
local_70 = dKy_light_influence_col(&local_70, work__ratio);
|
|
pData->field_0x0c.r = local_70.r;
|
|
pData->field_0x0c.g = local_70.g;
|
|
pData->field_0x0c.b = local_70.b;
|
|
pData->field_0x10.r = local_6c.r;
|
|
pData->field_0x10.g = local_6c.g;
|
|
pData->field_0x10.b = local_6c.b;
|
|
} else {
|
|
if (¶m_4 != NULL) {
|
|
pData->field_0x0c.r = param_4.r;
|
|
pData->field_0x0c.g = param_4.g;
|
|
pData->field_0x0c.b = param_4.b;
|
|
}
|
|
|
|
if (¶m_5 != NULL) {
|
|
pData->field_0x10.r = param_5.r;
|
|
pData->field_0x10.g = param_5.g;
|
|
pData->field_0x10.b = param_5.b;
|
|
}
|
|
}
|
|
|
|
pData->field_0x0c.a = param_3;
|
|
pData->field_0x10.a = param_6;
|
|
field_0xc++;
|
|
return 1;
|
|
}
|
|
|
|
void dPa_windPcallBack::execute(JPABaseEmitter* i_emitter, JPABaseParticle* param_1) {
|
|
dPa_setWindPower(param_1);
|
|
}
|
|
|
|
void dPa_control_c::level_c::emitter_c::onActive() {
|
|
mStatus |= (u8)1;
|
|
|
|
if (dComIfGp_event_runCheck()) {
|
|
onEventMove();
|
|
} else {
|
|
offEventMove();
|
|
}
|
|
}
|
|
|
|
void dPa_control_c::level_c::emitter_c::entry(u32 id, u16 name, JPABaseEmitter* i_emitter,
|
|
dPa_levelEcallBack* p_callback) {
|
|
mId = id;
|
|
mNameId = name;
|
|
onActive();
|
|
mEmitter = i_emitter;
|
|
mCallback = p_callback;
|
|
mPre = NULL;
|
|
mNext = NULL;
|
|
mEmitter->becomeImmortalEmitter();
|
|
}
|
|
|
|
void dPa_control_c::level_c::emitter_c::cleanup() {
|
|
JPAEmitterCallBack* pdVar1 = mEmitter->getEmitterCallBackPtr();
|
|
if (mCallback != NULL) {
|
|
mCallback->cleanup();
|
|
|
|
if (mEmitter->getEmitterCallBackPtr() != NULL) {
|
|
OS_REPORT("\x1b[32mdPa_control_c::level_c::emitter_c::cleanup emitte\n\x1b[m");
|
|
}
|
|
}
|
|
|
|
if (pdVar1 != dPa_control_c::getGen_b_Light8EcallBack() &&
|
|
pdVar1 != dPa_control_c::getGen_d_Light8EcallBack() &&
|
|
pdVar1 != dPa_control_c::getLight8EcallBack()) {
|
|
mEmitter->setEmitterCallBackPtr(NULL);
|
|
JPAParticleCallBack* cb = mEmitter->getParticleCallBackPtr();
|
|
if (cb == &JPTracePCB4 || cb == dPa_control_c::getParticleTracePCB()) {
|
|
mEmitter->setParticleCallBackPtr(NULL);
|
|
}
|
|
}
|
|
|
|
mEmitter->becomeInvalidEmitter();
|
|
mEmitter->quitImmortalEmitter();
|
|
mId = 0;
|
|
}
|
|
|
|
dPa_control_c::level_c::level_c() {
|
|
field_0x0 = 0;
|
|
mFreeNo = 0;
|
|
|
|
for (int i = 0; i < 0x100; i++) {
|
|
mTable[i] = NULL;
|
|
}
|
|
}
|
|
|
|
void dPa_control_c::level_c::execute(dPa_control_c::level_c::emitter_c* i_emitter) {
|
|
if (!i_emitter->isActive()) {
|
|
if (i_emitter->isEventMove() || !dComIfGp_event_runCheck()) {
|
|
i_emitter->getEmitter()->playCalcEmitter();
|
|
cutTable(i_emitter);
|
|
mFreeNo = ((i_emitter - mEmitter) / sizeof(emitter_c));
|
|
JUT_ASSERT(2110, mFreeNo < EMITTER_MAX);
|
|
} else {
|
|
i_emitter->getEmitter()->stopCalcEmitter();
|
|
}
|
|
} else {
|
|
i_emitter->offActive();
|
|
}
|
|
}
|
|
|
|
void dPa_control_c::level_c::execute() {
|
|
JUT_ASSERT(2134, dComIfG_inf_c::baseCsr_c::getNavi() != NULL);
|
|
#if PLATFORM_WII || VERSION == VERSION_SHIELD_DEBUG
|
|
u32 prtclId = dComIfG_inf_c::baseCsr_c::getNavi()->getParticleId();
|
|
u32 blurID = mDoGph_gInf_c::csr_c::getBlurID();
|
|
#endif
|
|
emitter_c* emitter = mEmitter;
|
|
|
|
for (int i = 0; i < EMITTER_MAX; i++) {
|
|
u32 id = emitter->getId();
|
|
if (id != 0) {
|
|
#if PLATFORM_WII || VERSION == VERSION_SHIELD_DEBUG
|
|
if (id != prtclId && id != blurID)
|
|
#endif
|
|
execute(emitter);
|
|
}
|
|
emitter++;
|
|
}
|
|
}
|
|
|
|
void dPa_control_c::level_c::cleanup() {
|
|
emitter_c* emitter = mEmitter;
|
|
|
|
for (int i = 0; i < EMITTER_MAX; i++) {
|
|
if (emitter->getId() != 0) {
|
|
emitter->clearStatus();
|
|
cutTable(emitter);
|
|
mFreeNo = i;
|
|
}
|
|
emitter++;
|
|
}
|
|
}
|
|
|
|
dPa_control_c::level_c::emitter_c* dPa_control_c::level_c::get(u32 id) {
|
|
if (id == 0) {
|
|
return NULL;
|
|
}
|
|
|
|
for (emitter_c* emitter = mTable[id & 0xFF]; emitter != NULL; emitter = emitter->getNext()) {
|
|
if (id == emitter->getId()) {
|
|
return emitter;
|
|
}
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
void dPa_control_c::level_c::forceOnEventMove(u32 id) {
|
|
emitter_c* emitter = get(id);
|
|
|
|
if (emitter != NULL) {
|
|
emitter->onEventMove();
|
|
}
|
|
}
|
|
|
|
void dPa_control_c::level_c::allForceOnEventMove() {
|
|
emitter_c* emitter = mEmitter;
|
|
|
|
for (int i = 0; i < EMITTER_MAX; i++, emitter++) {
|
|
if (emitter->getId() != 0) {
|
|
emitter->onEventMove();
|
|
}
|
|
}
|
|
}
|
|
|
|
JPABaseEmitter* dPa_control_c::level_c::getEmitter(u32 id) {
|
|
emitter_c* emitter = get(id);
|
|
|
|
if (emitter == NULL) {
|
|
return NULL;
|
|
}
|
|
|
|
return emitter->getEmitter();
|
|
}
|
|
|
|
u32 dPa_control_c::level_c::entry(u16 i_name, JPABaseEmitter* i_emitter, dPa_levelEcallBack* i_callback) {
|
|
JUT_ASSERT(2261, i_emitter != NULL);
|
|
|
|
for (int i = 0; i < EMITTER_MAX; i++) {
|
|
if (mEmitter[mFreeNo].getId() == 0) {
|
|
u32 uvar1 = field_0x0 + 1;
|
|
field_0x0 = uvar1;
|
|
|
|
if (uvar1 == 0) {
|
|
field_0x0++;
|
|
}
|
|
|
|
mEmitter[mFreeNo].entry(field_0x0, i_name, i_emitter, i_callback);
|
|
addTable(&mEmitter[mFreeNo]);
|
|
return field_0x0;
|
|
}
|
|
|
|
mFreeNo = (mFreeNo + 1) % EMITTER_MAX;
|
|
}
|
|
|
|
#if DEBUG
|
|
BOOL isConnect = mDoCPd_c::isConnect(PAD_3);
|
|
if (isConnect) {
|
|
JUT_WARN(2284, "%s", "Level Emitter Max Over !!\n");
|
|
}
|
|
#endif
|
|
|
|
i_emitter->becomeInvalidEmitter();
|
|
i_emitter->quitImmortalEmitter();
|
|
return 0;
|
|
}
|
|
|
|
void dPa_control_c::level_c::addTable(dPa_control_c::level_c::emitter_c* i_emitter) {
|
|
u32 id = i_emitter->getId() & 0xFF;
|
|
|
|
if (mTable[id] == NULL) {
|
|
mTable[id] = i_emitter;
|
|
return;
|
|
}
|
|
|
|
mTable[id]->setPre(i_emitter);
|
|
i_emitter->setNext(mTable[id]);
|
|
mTable[id] = i_emitter;
|
|
}
|
|
|
|
void dPa_control_c::level_c::cutTable(dPa_control_c::level_c::emitter_c* i_emitter) {
|
|
emitter_c* pre = i_emitter->getPre();
|
|
emitter_c* next = i_emitter->getNext();
|
|
|
|
if (pre == NULL) {
|
|
mTable[i_emitter->getId() & 0xFF] = next;
|
|
} else {
|
|
pre->setNext(next);
|
|
}
|
|
|
|
if (next != NULL) {
|
|
next->setPre(pre);
|
|
}
|
|
|
|
i_emitter->cleanup();
|
|
}
|
|
|
|
dPa_selectTexEcallBack dPa_control_c::mTsubo[] = {
|
|
dPa_selectTexEcallBack(0),
|
|
dPa_selectTexEcallBack(1),
|
|
dPa_selectTexEcallBack(2),
|
|
dPa_selectTexEcallBack(3),
|
|
dPa_selectTexEcallBack(4),
|
|
dPa_selectTexEcallBack(5),
|
|
dPa_selectTexEcallBack(6),
|
|
dPa_selectTexEcallBack(7),
|
|
};
|
|
|
|
dPa_setColorEcallBack dPa_control_c::mLifeBall[3] = {
|
|
dPa_setColorEcallBack(l_lifeBallColor[0]),
|
|
dPa_setColorEcallBack(l_lifeBallColor[1]),
|
|
dPa_setColorEcallBack(l_lifeBallColor[2]),
|
|
};
|
|
|
|
JPAEmitterManager* dPa_control_c::mEmitterMng;
|
|
|
|
dPa_wbPcallBack_c dPa_control_c::mWaterBubblePcallBack;
|
|
|
|
dPa_fsenthPcallBack dPa_control_c::mFsenthPcallBack;
|
|
|
|
dPa_light8EcallBack dPa_control_c::mLight8EcallBack;
|
|
|
|
dPa_light8PcallBack dPa_control_c::mLight8PcallBack;
|
|
|
|
dPa_gen_b_light8EcallBack dPa_control_c::m_b_Light8EcallBack;
|
|
|
|
dPa_gen_b_light8PcallBack dPa_control_c::m_b_Light8PcallBack;
|
|
|
|
dPa_gen_d_light8EcallBack dPa_control_c::m_d_Light8EcallBack;
|
|
|
|
dPa_gen_d_light8PcallBack dPa_control_c::m_d_Light8PcallBack;
|
|
|
|
u8 dPa_control_c::mStatus;
|
|
|
|
Mtx dPa_control_c::mWindViewMatrix;
|
|
|
|
dPa_particleTracePcallBack_c dPa_control_c::mParticleTracePCB;
|
|
|
|
dPa_control_c::dPa_control_c() {
|
|
m_resHeap = JKRCreateExpHeap(0x96000, mDoExt_getArchiveHeap(), false);
|
|
JUT_ASSERT(2426, m_resHeap != NULL);
|
|
mHeap = NULL;
|
|
mSceneHeap = NULL;
|
|
field_0x18 = 0xFF;
|
|
mEmitterMng = NULL;
|
|
field_0x19 = 0;
|
|
mCommonResMng = NULL;
|
|
mSceneResMng = NULL;
|
|
m_sceneRes = NULL;
|
|
|
|
MTXIdentity(mWindViewMatrix);
|
|
}
|
|
|
|
u8 dPa_control_c::getRM_ID(u16 param_0) {
|
|
return (param_0 >> 15) & 1;
|
|
}
|
|
|
|
void dPa_control_c::createCommon(void const* param_0) {
|
|
OS_REPORT("常駐パーティクルリソースサイズ<%d>\n", mHeap->getSize((void*)param_0));
|
|
mHeap = mDoExt_createSolidHeapFromSystem(0, 0);
|
|
JUT_ASSERT(2518, mHeap != NULL);
|
|
mCommonResMng = new (mHeap, 0) JPAResourceManager(param_0, mHeap);
|
|
JUT_ASSERT(2521, mCommonResMng != NULL);
|
|
mCommonResMng->swapTexture(mDoGph_gInf_c::getFrameBufferTimg(), "dummy");
|
|
mEmitterMng = new (mHeap, 0) JPAEmitterManager(3000, 250, *(JKRHeap**)this, 0x13, 2);
|
|
JUT_ASSERT(2531, mEmitterMng != NULL);
|
|
mEmitterMng->entryResourceManager(mCommonResMng, 0);
|
|
JKRHeap* prevHeap = mDoExt_setCurrentHeap(mHeap);
|
|
for (u16 i = 0; i < 5; i++) {
|
|
u16 uVar1 = dPa_name::j_o_id[i];
|
|
if (mCommonResMng->checkUserIndexDuplication(uVar1)) {
|
|
u32 local_30 = mCommonResMng->getResUserWork(uVar1);
|
|
u8 local_38 = 0;
|
|
dPa_group_id_change(&local_30, &local_38);
|
|
newSimple(uVar1, local_38, &local_30);
|
|
}
|
|
}
|
|
field_0x1a = field_0x19;
|
|
mDoExt_setCurrentHeap(prevHeap);
|
|
u32 memory = mDoExt_adjustSolidHeap(mHeap);
|
|
OS_REPORT("-------<Common Particle Memory> %d\n", memory);
|
|
}
|
|
|
|
void dPa_control_c::createRoomScene() {
|
|
mSceneHeap = mDoExt_createSolidHeapFromGame(0, 0);
|
|
JUT_ASSERT(2573, mSceneHeap != NULL);
|
|
mSceneResMng = new (mSceneHeap, 0) JPAResourceManager(m_sceneRes, mSceneHeap);
|
|
JUT_ASSERT(2576, mSceneResMng != NULL);
|
|
mSceneResMng->swapTexture(mDoGph_gInf_c::getFrameBufferTimg(), "dummy");
|
|
mEmitterMng->entryResourceManager(mSceneResMng, 1);
|
|
JKRHeap* prevHeap = mDoExt_setCurrentHeap(mSceneHeap);
|
|
for (u16 i = 0; i < 14; i++) {
|
|
u16 uVar1 = dPa_name::s_o_id[i];
|
|
if (mSceneResMng->checkUserIndexDuplication(uVar1)) {
|
|
u32 local_30 = mSceneResMng->getResUserWork(uVar1);
|
|
u8 local_38 = 0;
|
|
dPa_group_id_change(&local_30, &local_38);
|
|
newSimple(uVar1, local_38, &local_30);
|
|
}
|
|
}
|
|
mDoExt_setCurrentHeap(prevHeap);
|
|
u32 memory = mDoExt_adjustSolidHeap(mSceneHeap);
|
|
OS_REPORT("-------<Scene Particle Memory> %d\n", memory);
|
|
}
|
|
|
|
bool dPa_control_c::readScene(u8 param_0, mDoDvdThd_toMainRam_c** param_1) {
|
|
if (param_0 == 0xff || param_0 == field_0x18) {
|
|
return 0;
|
|
}
|
|
|
|
if (m_sceneRes) {
|
|
JUT_ASSERT(2641, !(--mSceneCount));
|
|
JKRFree(m_sceneRes);
|
|
m_sceneRes = NULL;
|
|
}
|
|
JUT_ASSERT(2647, !mSceneCount++);
|
|
field_0x18 = param_0;
|
|
static char jpcName[32];
|
|
sprintf(jpcName, "/res/Particle/Pscene%03d.jpc", param_0);
|
|
*param_1 = mDoDvdThd_toMainRam_c::create(jpcName, 0, m_resHeap);
|
|
return 1;
|
|
}
|
|
|
|
void dPa_control_c::createScene(void const* param_0) {
|
|
for (int i = 0; i < field_0x1a; i++) {
|
|
field_0x1c[i].createEmitter(mEmitterMng);
|
|
}
|
|
if (param_0 != NULL) {
|
|
m_sceneRes = (void*)param_0;
|
|
OS_REPORT("シーン依存パーティクルリソースサイズ<%d>\n", m_resHeap->getSize(m_sceneRes));
|
|
}
|
|
if (m_sceneRes != NULL) {
|
|
createRoomScene();
|
|
}
|
|
dPa_modelEcallBack::create(0x80);
|
|
}
|
|
|
|
bool dPa_control_c::removeRoomScene(bool param_0) {
|
|
if (mSceneHeap == NULL) {
|
|
return false;
|
|
}
|
|
|
|
mEmitterMng->clearResourceManager(true);
|
|
mDoExt_destroySolidHeap(mSceneHeap);
|
|
mSceneHeap = NULL;
|
|
mSceneResMng = NULL;
|
|
field_0x19 = field_0x1a;
|
|
if (param_0) {
|
|
JUT_ASSERT(2710, !(--mSceneCount));
|
|
JKRHeap::free(m_sceneRes, NULL);
|
|
m_sceneRes = NULL;
|
|
field_0x18 = 0xff;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
void dPa_control_c::removeScene(bool param_0) {
|
|
field_0x210.cleanup();
|
|
removeRoomScene(param_0);
|
|
for (int i = 0; i < field_0x1a; i++) {
|
|
field_0x1c[i].removeEmitter();
|
|
}
|
|
|
|
mEmitterMng->forceDeleteAllEmitter();
|
|
dPa_modelEcallBack::remove();
|
|
|
|
if (getEmitterNum()) {
|
|
OS_REPORT("\x1b[43;30m常駐エミッター開放してない!!");
|
|
}
|
|
}
|
|
|
|
void dPa_control_c::cleanup() {
|
|
field_0x210.cleanup();
|
|
}
|
|
|
|
void dPa_control_c::calc3D() {
|
|
if (isStatus(2)) {
|
|
offStatus(2);
|
|
} else {
|
|
for (u8 i = 0; i <= 13; i++) {
|
|
mEmitterMng->calc(i);
|
|
}
|
|
field_0x210.execute();
|
|
}
|
|
}
|
|
|
|
void dPa_control_c::calc2D() {
|
|
for (u8 i = 14; i <= 16; i++) {
|
|
mEmitterMng->calc(i);
|
|
}
|
|
}
|
|
|
|
void dPa_control_c::calcMenu() {
|
|
if (mEmitterMng != NULL) {
|
|
for (u8 i = 17; i <= 18; i++) {
|
|
mEmitterMng->calc(i);
|
|
}
|
|
|
|
#if PLATFORM_WII || VERSION == VERSION_SHIELD_DEBUG
|
|
dComIfG_inf_c::baseCsr_c::particleExecute();
|
|
mDoGph_gInf_c::csr_c::particleExecute();
|
|
#endif
|
|
}
|
|
}
|
|
|
|
void dPa_control_c::draw(JPADrawInfo* param_0, u8 param_1) {
|
|
if (mEmitterMng != NULL) {
|
|
j3dSys.reinitGX();
|
|
dKy_setLight_again();
|
|
|
|
if (param_1 >= 6 && param_1 <= 11) {
|
|
dKy_GxFog_set();
|
|
}
|
|
|
|
mEmitterMng->draw(param_0, param_1);
|
|
GXSetAlphaUpdate(GX_FALSE);
|
|
GXSetNumIndStages(0);
|
|
GXSetClipMode(GX_CLIP_ENABLE);
|
|
}
|
|
}
|
|
|
|
void dPa_control_c::setHitMark(u16 param_1, fopAc_ac_c* param_2, cXyz const* param_3, csXyz const* param_4, cXyz const* param_5, u32 param_6) {
|
|
cXyz const* pPos = param_3;
|
|
csXyz const* pAngle = param_4;
|
|
cXyz cStack_34;
|
|
csXyz cStack_78;
|
|
if (param_2 != NULL) {
|
|
if (fopAcM_CheckStatus(param_2, 0x40000000)) {
|
|
return;
|
|
}
|
|
|
|
fopAcM_OnStatus(param_2, 0x40000000);
|
|
if (fopAcM_GetJntCol(param_2) != NULL) {
|
|
dJntCol_c* jntCol = fopAcM_GetJntCol(param_2);
|
|
if (jntCol->getHitmarkPosAndAngle(pPos, pAngle, &cStack_34, &cStack_78, param_1 == 6) >= 0) {
|
|
pPos = &cStack_34;
|
|
pAngle = &cStack_78;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (param_1 == 3) {
|
|
dComIfGp_particle_set(ID_ZI_J_HITCR_A, pPos, pAngle, param_5);
|
|
dComIfGp_particle_set(ID_ZI_J_HITCR_B, pPos, 0, param_5);
|
|
dComIfGp_particle_set(ID_ZI_J_HITCR_C, pPos, 0, param_5);
|
|
if ((param_6 & 2) != 0 && param_2 != NULL && fopAcM_GetGroup(param_2) == 2) {
|
|
dComIfGp_particle_set(ID_ZI_J_HITCR_D, pPos, 0, param_5);
|
|
}
|
|
dComIfGp_particle_set(ID_ZI_J_HITCR_IND, pPos, 0, param_5);
|
|
dKy_SordFlush_set(*pPos, 1);
|
|
} else if (param_1 == 2 || param_1 == 5 || param_1 == 9 || param_1 == 8 || param_1 == 6) {
|
|
dComIfGp_particle_set(ID_ZI_J_HITNG_A, pPos, pAngle, param_5);
|
|
dComIfGp_particle_set(ID_ZI_J_HITNG_B, pPos, 0, param_5);
|
|
if (param_1 != 9) {
|
|
dKy_SordFlush_set(*pPos, 0);
|
|
}
|
|
} else if (param_1 == 7) {
|
|
cXyz cStack_40;
|
|
if (param_5 != NULL) {
|
|
cStack_40 = *param_5 * 0.5f;
|
|
} else {
|
|
cStack_40.set(0.5f, 0.5f, 0.5f);
|
|
}
|
|
|
|
dComIfGp_particle_set(ID_ZI_J_HITOK_A, pPos, pAngle, &cStack_40);
|
|
dComIfGp_particle_set(ID_ZI_J_HITOK_B, pPos, 0, &cStack_40);
|
|
dComIfGp_particle_set(ID_ZI_J_HITOK_C, pPos, 0, &cStack_40);
|
|
if ((param_6 & 2) != 0 && param_2 != NULL && fopAcM_GetGroup(param_2) == 2) {
|
|
dComIfGp_particle_set(ID_ZI_J_HITOK_D, pPos, 0, &cStack_40);
|
|
}
|
|
} else if (param_1 == 1 || param_1 == 4) {
|
|
dComIfGp_particle_set(ID_ZI_J_HITOK_A, pPos, pAngle, param_5);
|
|
dComIfGp_particle_set(ID_ZI_J_HITOK_B, pPos, 0, param_5);
|
|
dComIfGp_particle_set(ID_ZI_J_HITOK_C, pPos, 0, param_5);
|
|
if ((param_6 & 2) != 0 && param_2 != NULL && fopAcM_GetGroup(param_2) == 2) {
|
|
dComIfGp_particle_set(ID_ZI_J_HITOK_D, pPos, 0, param_5);
|
|
}
|
|
|
|
dKy_SordFlush_set(*pPos, 1);
|
|
}
|
|
}
|
|
|
|
void dPa_control_c::setWaterRipple(u32* param_0, cBgS_PolyInfo& param_1, cXyz const* param_2,
|
|
f32 param_3, dKy_tevstr_c const* param_4,
|
|
cXyz const* param_5, s8 param_6) {
|
|
f32 rate = 0.05f + 0.15f * (0.1f * param_3);
|
|
if (rate > 1.0f) {
|
|
rate = 1.0f;
|
|
}
|
|
csXyz local_50;
|
|
cM3dGPla acStack_48;
|
|
if (dComIfG_Bgsp().GetTriPla(param_1, &acStack_48)) {
|
|
local_50.x = cM_atan2s(acStack_48.mNormal.absXZ(), acStack_48.mNormal.y);
|
|
local_50.y = acStack_48.mNormal.atan2sX_Z();
|
|
local_50.z = 0;
|
|
}
|
|
|
|
static u16 const particleID[2] = {ID_ZI_J_HAMON_IND, ID_ZI_J_HAMON_A};
|
|
for (int i = 0; i < 2; i++, param_0++) {
|
|
*param_0 = dComIfGp_particle_setPolyColor(
|
|
*param_0, particleID[i], param_1, param_2, param_4,
|
|
&local_50, param_5, 0, 0, param_6, 0);
|
|
JPABaseEmitter* emitter = getEmitter(*param_0);
|
|
if (emitter != NULL) {
|
|
emitter->setRate(rate);
|
|
}
|
|
}
|
|
}
|
|
|
|
JPABaseEmitter* dPa_control_c::set(u8 param_0, u16 param_1, cXyz const* i_pos,
|
|
dKy_tevstr_c const* param_3, csXyz const* i_rotation,
|
|
cXyz const* i_scale, u8 i_alpha, dPa_levelEcallBack* param_7,
|
|
s8 param_8, _GXColor const* param_9, _GXColor const* param_10,
|
|
cXyz const* param_11, f32 param_12) {
|
|
u8 local_e0 = getRM_ID(param_1);
|
|
JPAResourceManager* local_a8 = mEmitterMng->getResourceManager(local_e0);
|
|
if (local_a8 == NULL) {
|
|
return NULL;
|
|
}
|
|
|
|
u32 local_ac = local_a8->getResUserWork(param_1);
|
|
if (param_3 != NULL && param_3->Material_use_fg != 0x7c) {
|
|
return NULL;
|
|
}
|
|
|
|
dPa_group_id_change(&local_ac, ¶m_0);
|
|
// FAKEMATCH
|
|
#if DEBUG
|
|
JGeometry::TVec3<f32> aTStack_78(i_pos->x, i_pos->y, i_pos->z);
|
|
#else
|
|
JGeometry::TVec3<f32> aTStack_78;
|
|
aTStack_78.set(i_pos->x, i_pos->y, i_pos->z);
|
|
#endif
|
|
JPABaseEmitter* this_00 = mEmitterMng->createSimpleEmitterID(
|
|
aTStack_78, param_1, param_0,
|
|
local_e0, NULL, NULL
|
|
);
|
|
|
|
#if DEBUG
|
|
g_envHIO.mOther.addSetEmitterID(param_1);
|
|
#endif
|
|
|
|
if (this_00 == NULL) {
|
|
#if DEBUG
|
|
g_envHIO.mOther.field_0x4e = 1;
|
|
#endif
|
|
return NULL;
|
|
}
|
|
|
|
if (i_rotation != NULL) {
|
|
#if DEBUG
|
|
JGeometry::TVec3<s16> aTStack_a4(i_rotation->x, i_rotation->y, i_rotation->z);
|
|
#else
|
|
JGeometry::TVec3<s16> aTStack_a4;
|
|
aTStack_a4.x = i_rotation->x;
|
|
aTStack_a4.y = i_rotation->y;
|
|
aTStack_a4.z = i_rotation->z;
|
|
#endif
|
|
this_00->setGlobalRotation(aTStack_a4);
|
|
}
|
|
|
|
if (i_scale != NULL) {
|
|
#if DEBUG
|
|
JGeometry::TVec3<f32> aTStack_84(i_scale->x, i_scale->y, i_scale->z);
|
|
#else
|
|
JGeometry::TVec3<f32> aTStack_84;
|
|
aTStack_84.x = i_scale->x;
|
|
aTStack_84.y = i_scale->y;
|
|
aTStack_84.z = i_scale->z;
|
|
#endif
|
|
this_00->setGlobalScale(aTStack_84);
|
|
}
|
|
|
|
#if DEBUG
|
|
if ((local_ac & 0xFF000000) == 0xFF000000) {
|
|
JGeometry::TVec3<f32> local_90;
|
|
this_00->getGlobalParticleScale(local_90);
|
|
local_90.x *= mDoGph_gInf_c::getScale();
|
|
this_00->setGlobalScale(local_90);
|
|
}
|
|
#endif
|
|
|
|
this_00->setGlobalAlpha(i_alpha);
|
|
if (param_7 != NULL) {
|
|
this_00->setEmitterCallBackPtr(param_7);
|
|
param_7->setup(this_00, i_pos, i_rotation, param_8);
|
|
}
|
|
|
|
if ((local_ac & 0x100) != 0) {
|
|
this_00->setParticleCallBackPtr(getFsenthPcallBack());
|
|
}
|
|
|
|
if ((local_ac & 0x800) != 0) {
|
|
this_00->setEmitterCallBackPtr(getGen_d_Light8EcallBack());
|
|
if ((local_ac & 0x20) != 0) {
|
|
getGen_d_Light8EcallBack()->setup(this_00, i_pos, i_rotation, 0);
|
|
} else {
|
|
getGen_d_Light8EcallBack()->setup(this_00, i_pos, i_rotation, 1);
|
|
}
|
|
} else if ((local_ac & 0x400) != 0) {
|
|
this_00->setEmitterCallBackPtr(getGen_b_Light8EcallBack());
|
|
if ((local_ac & 0x20) != 0) {
|
|
getGen_b_Light8EcallBack()->setup(this_00, i_pos, i_rotation, 0);
|
|
} else {
|
|
getGen_b_Light8EcallBack()->setup(this_00, i_pos, i_rotation, 1);
|
|
}
|
|
} else {
|
|
if ((local_ac & 0xef0000) >> 0x10 < 100) {
|
|
param_12 = ((local_ac & 0xef0000) >> 0x10) / 99.0f;
|
|
}
|
|
|
|
if ((local_ac & 0x20) != 0) {
|
|
GXColor local_b0;
|
|
GXColor local_b4;
|
|
GXColor local_b8 = {0xff, 0xff, 0xff, 0xff};
|
|
GXColor local_bc = {0xff, 0xff, 0xff, 0xff};
|
|
if (param_10 != NULL) {
|
|
local_b8 = *param_10;
|
|
}
|
|
|
|
if (param_9 != NULL) {
|
|
local_bc = *param_9;
|
|
}
|
|
|
|
dKy_ParticleColor_get_actor((cXyz*)i_pos, (dKy_tevstr_c*)param_3, &local_b0,
|
|
&local_b4, &local_b8, &local_bc, param_12);
|
|
this_00->setGlobalEnvColor(local_b0.r, local_b0.g, local_b0.b);
|
|
this_00->setGlobalPrmColor(local_b4.r, local_b4.g, local_b4.b);
|
|
} else if ((local_ac & 0x40) != 0) {
|
|
GXColor local_c0;
|
|
GXColor local_c4;
|
|
GXColor local_c8 = {0xff, 0xff, 0xff, 0xff};
|
|
GXColor local_cc = {0xff, 0xff, 0xff, 0xff};
|
|
f32 fVar1 = 0.0f;
|
|
if (param_10 != NULL) {
|
|
local_c8 = *param_10;
|
|
}
|
|
|
|
if (param_9 != NULL) {
|
|
local_cc = *param_9;
|
|
}
|
|
|
|
dKy_ParticleColor_get_bg((cXyz*)i_pos, (dKy_tevstr_c*)param_3, &local_c0,
|
|
&local_c4, &local_c8, &local_cc, param_12);
|
|
param_12 = g_env_light.bg_light_influence + (1.0f - g_env_light.bg_light_influence) * param_12;
|
|
local_c0 = dKy_light_influence_col(&local_c0, param_12);
|
|
local_c4 = dKy_light_influence_col(&local_c4, param_12);
|
|
this_00->setGlobalEnvColor(local_c0.r, local_c0.g, local_c0.b);
|
|
this_00->setGlobalPrmColor(local_c4.r, local_c4.g, local_c4.b);
|
|
} else {
|
|
if (param_9 != NULL) {
|
|
this_00->setGlobalPrmColor(param_9->r, param_9->g, param_9->b);
|
|
}
|
|
|
|
if (param_10 != NULL) {
|
|
this_00->setGlobalEnvColor(param_10->r, param_10->g, param_10->b);
|
|
}
|
|
}
|
|
}
|
|
|
|
if (param_11 != NULL) {
|
|
#if DEBUG
|
|
JGeometry::TVec3<f32> aTStack_9c(param_11->x, param_11->y, param_11->z);
|
|
#else
|
|
JGeometry::TVec3<f32> aTStack_9c;
|
|
aTStack_9c.set(param_11->x, param_11->y, param_11->z);
|
|
#endif
|
|
this_00->setGlobalParticleScale(aTStack_9c);
|
|
}
|
|
return this_00;
|
|
}
|
|
|
|
s32 dPa_control_c::getPolyColor(cBgS_PolyInfo& param_0, int param_1, _GXColor* param_2,
|
|
_GXColor* param_3, u8* param_4, f32* param_5) {
|
|
if (!dComIfG_Bgsp().ChkPolySafe(param_0)) {
|
|
return 0;
|
|
}
|
|
|
|
if (param_1 == NULL) {
|
|
dKy_pol_eff_prim_get(¶m_0, param_2);
|
|
dKy_pol_eff_env_get(¶m_0, param_3);
|
|
*param_4 = dKy_pol_eff_alpha_get(¶m_0);
|
|
*param_5 = dKy_pol_eff_ratio_get(¶m_0);
|
|
} else {
|
|
dKy_pol_eff2_prim_get(¶m_0, param_2);
|
|
dKy_pol_eff2_env_get(¶m_0, param_3);
|
|
*param_4 = dKy_pol_eff2_alpha_get(¶m_0);
|
|
*param_5 = dKy_pol_eff2_ratio_get(¶m_0);
|
|
}
|
|
|
|
return 1;
|
|
}
|
|
|
|
JPABaseEmitter* dPa_control_c::setPoly(u16 param_0, cBgS_PolyInfo& param_1, cXyz const* param_2,
|
|
dKy_tevstr_c const* param_3, csXyz const* param_4,
|
|
cXyz const* param_5, int param_6, dPa_levelEcallBack* param_7,
|
|
s8 param_8, cXyz const* param_9) {
|
|
u8 local_18;
|
|
float local_c;
|
|
GXColor a_Stack_10;
|
|
GXColor a_Stack_14;
|
|
|
|
if (!getPolyColor(param_1, param_6, &a_Stack_10,
|
|
&a_Stack_14, &local_18, &local_c)) {
|
|
return NULL;
|
|
}
|
|
|
|
return setNormal(param_0, param_2, param_3, param_4, param_5, local_18,
|
|
param_7, param_8, &a_Stack_10, &a_Stack_14, param_9, local_c);
|
|
}
|
|
|
|
bool dPa_control_c::newSimple(u16 param_0, u8 param_1, u32* param_2) {
|
|
if (
|
|
#if DEBUG
|
|
field_0x19 >= 0x30
|
|
#else
|
|
field_0x19 >= 0x19
|
|
#endif
|
|
) {
|
|
OSReport("\x1B[43;30m1エミッター登録数オーバー!!\n");
|
|
return false;
|
|
}
|
|
|
|
JPABaseEmitter* emitter = field_0x1c[field_0x19].create(mEmitterMng, param_0, param_1);
|
|
if (emitter == NULL) {
|
|
return false;;
|
|
}
|
|
field_0x19++;
|
|
return true;
|
|
}
|
|
|
|
u32 dPa_control_c::setSimple(u16 param_0, cXyz const* i_pos, dKy_tevstr_c const* param_2,
|
|
u8 param_3, _GXColor const& param_4, _GXColor const& param_5,
|
|
int param_6, f32 param_7) {
|
|
dPa_simpleEcallBack* cb = getSimple(param_0);
|
|
if (cb == NULL) {
|
|
JUT_WARN(3443, "One Emitter Error !! <%s>\n", dPa_name::getName(param_0));
|
|
return 0;
|
|
}
|
|
|
|
return cb->set(i_pos, param_2, param_3, param_4, param_5, param_6, param_7);
|
|
}
|
|
|
|
dPa_simpleEcallBack* dPa_control_c::getSimple(u16 param_0) {
|
|
dPa_simpleEcallBack* arr = field_0x1c;
|
|
for (int i = 0; i < field_0x19; i++, arr++) {
|
|
if (param_0 == arr->getID()) {
|
|
return arr;
|
|
}
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
static void dPa_kankyocolor_set(f32 param_0, JPABaseEmitter* param_1,
|
|
dKy_tevstr_c const* param_2, u32 param_3, cXyz const* param_4,
|
|
_GXColor const* param_5, _GXColor const* param_6) {
|
|
f32 fVar1 = param_0;
|
|
if ((param_3 & 0xef0000) >> 0x10 < 100) {
|
|
fVar1 = ((param_3 & 0xef0000) >> 0x10) / 99.0f;
|
|
}
|
|
|
|
if ((param_3 & 0x20) != 0) {
|
|
GXColor local_60;
|
|
GXColor local_64;
|
|
GXColor local_68 = {0xff, 0xff, 0xff, 0xff};
|
|
GXColor local_6c = {0xff, 0xff, 0xff, 0xff};
|
|
if (param_6 != NULL) {
|
|
local_68 = *param_6;
|
|
}
|
|
if (param_5 != NULL) {
|
|
local_6c = *param_5;
|
|
}
|
|
dKy_ParticleColor_get_actor((cXyz*)param_4, (dKy_tevstr_c*)param_2, &local_60, &local_64,
|
|
&local_68, &local_6c, fVar1);
|
|
param_1->setGlobalEnvColor(local_60.r, local_60.g, local_60.b);
|
|
param_1->setGlobalPrmColor(local_64.r, local_64.g, local_64.b);
|
|
} else if ((param_3 & 0x40) != 0) {
|
|
GXColor local_70;
|
|
GXColor local_74;
|
|
GXColor local_78 = {0xff, 0xff, 0xff, 0xff};
|
|
GXColor local_7c = {0xff, 0xff, 0xff, 0xff};
|
|
if (param_6 != NULL) {
|
|
local_78 = *param_6;
|
|
}
|
|
if (param_5 != NULL) {
|
|
local_7c = *param_5;
|
|
}
|
|
dKy_ParticleColor_get_bg((cXyz*)param_4, (dKy_tevstr_c*)param_2, &local_70, &local_74,
|
|
&local_78, &local_7c, fVar1);
|
|
fVar1 = g_env_light.bg_light_influence + (1.0f - g_env_light.bg_light_influence) * fVar1;
|
|
local_70 = dKy_light_influence_col(&local_70, fVar1);
|
|
//_GXColor::operator_ = (&local_70, (_GXColor*)&local_80);
|
|
local_74 = dKy_light_influence_col(&local_74, fVar1);
|
|
//_GXColor::operator_ = (&local_74, (_GXColor*)&local_84);
|
|
param_1->setGlobalEnvColor(local_70.r, local_70.g, local_70.b);
|
|
param_1->setGlobalPrmColor(local_74.r, local_74.g, local_74.b);
|
|
}
|
|
}
|
|
|
|
u32 dPa_control_c::set(u32 param_0, u8 param_1, u16 param_2, cXyz const* pos,
|
|
dKy_tevstr_c const* param_4, csXyz const* i_rotation, cXyz const* i_scale,
|
|
u8 alpha, dPa_levelEcallBack* param_8, s8 param_9, _GXColor const* param_10,
|
|
_GXColor const* param_11, cXyz const* param_12, f32 param_13) {
|
|
level_c::emitter_c* this_00 = field_0x210.get(param_0);
|
|
u8 uVar7 = getRM_ID(param_2);
|
|
JPAResourceManager* this_01 = mEmitterMng->getResourceManager(uVar7);
|
|
u32 uVar3 = this_01->getResUserWork(param_2);
|
|
if (this_00 != NULL) {
|
|
if (param_2 == this_00->getNameId()) {
|
|
this_00->onActive();
|
|
JPABaseEmitter* pJVar4 = this_00->getEmitter();
|
|
pJVar4->playCalcEmitter();
|
|
if (this_00->getCallback() == 0) {
|
|
pJVar4->setGlobalTranslation(pos->x, pos->y, pos->z);
|
|
if (i_rotation != NULL) {
|
|
JGeometry::TVec3<s16> aTStack_64;
|
|
aTStack_64.x = i_rotation->x;
|
|
aTStack_64.y = i_rotation->y;
|
|
aTStack_64.z = i_rotation->z;
|
|
pJVar4->setGlobalRotation(aTStack_64);
|
|
}
|
|
}
|
|
if (pJVar4->checkStatus(JPAEmtrStts_StopEmit)) {
|
|
pJVar4->playCreateParticle();
|
|
}
|
|
dPa_kankyocolor_set(param_13, pJVar4, param_4, uVar3, pos, param_10, param_11);
|
|
return this_00->getId();
|
|
}
|
|
field_0x210.cutTable(this_00);
|
|
}
|
|
if (param_8 != NULL) {
|
|
param_8->cleanup();
|
|
}
|
|
JPABaseEmitter* pJVar5 = set(param_1, param_2, pos, param_4, i_rotation, i_scale, alpha,
|
|
param_8, param_9, param_10, param_11, param_12, param_13);
|
|
if (pJVar5 == NULL) {
|
|
return 0;
|
|
}
|
|
|
|
return field_0x210.entry(param_2, pJVar5, param_8);
|
|
}
|
|
|
|
u32 dPa_control_c::setPoly(u32 param_0, u16 param_1, cBgS_PolyInfo& param_2,
|
|
cXyz const* param_3, dKy_tevstr_c const* param_4,
|
|
csXyz const* param_5, cXyz const* param_6, int param_7,
|
|
dPa_levelEcallBack* param_8, s8 param_9, cXyz const* param_10) {
|
|
f32 local_8;
|
|
GXColor local_10;
|
|
GXColor local_c;
|
|
u8 local_4;
|
|
if (!getPolyColor(param_2, param_7, &local_10,
|
|
&local_c, &local_4, (f32*)&local_8)) {
|
|
return 0;
|
|
}
|
|
|
|
return setNormal(param_0, param_1, param_3, param_4, param_5, param_6,
|
|
local_4, param_8, param_9, &local_10, &local_c, param_10, local_8);
|
|
}
|
|
|
|
u32 dPa_control_c::setStopContinue(u32 param_0) {
|
|
level_c::emitter_c* emitter = field_0x210.get(param_0);
|
|
if (emitter != NULL) {
|
|
emitter->onActive();
|
|
emitter->getEmitter()->stopCreateParticle();
|
|
return emitter->getId();
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
u32 dPa_control_c::setSimpleFoot(u32 param_0, u32* param_1, cBgS_PolyInfo& param_2,
|
|
cXyz const* param_3, dKy_tevstr_c const* param_4, int param_5,
|
|
csXyz const* param_6, cXyz const* param_7,
|
|
dPa_levelEcallBack* param_8, s8 param_9,
|
|
cXyz const* param_10) {
|
|
f32 local_44;
|
|
u8 local_50;
|
|
GXColor a_Stack_48;
|
|
GXColor a_Stack_4c;
|
|
if (getPolyColor(param_2, 0, &a_Stack_48, &a_Stack_4c, &local_50,
|
|
&local_44) == 0)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
u8 effType = dKy_pol_efftype_get(¶m_2);
|
|
if (effType >= 6) {
|
|
return 0;
|
|
}
|
|
static u16 effectIDTable[6][2] = {
|
|
{ID_ZI_J_DASHSMOKE_A, ID_ZI_J_DOWNSMOKE_A}, {ID_ZI_J_DASHKUSA_A, ID_ZI_J_DOWNKUSA_A}, {ID_ZI_J_DASHWTRA_A, ID_ZI_J_DOWNWTRA_A},
|
|
{dPa_RM(ID_ZI_S_DASHSAND_A), dPa_RM(ID_ZI_S_DOWNSAND_A)}, {dPa_RM(ID_ZI_S_DASHSNOW_A), dPa_RM(ID_ZI_S_DOWNSNOW_A)}, {dPa_RM(ID_ZI_S_DASHSMOKE_INWTR_A), dPa_RM(ID_ZI_S_DOWNSMOKE_INWTR_A)},
|
|
};
|
|
u32 rv = setNormal(param_0, effectIDTable[effType][param_5],
|
|
param_3, param_4, param_6, param_7, local_50, param_8, param_9, &a_Stack_48,
|
|
&a_Stack_4c, param_10, local_44);
|
|
u8 effType2 = dKy_pol_efftype2_get(¶m_2);
|
|
int polyAtt = dComIfG_Bgsp().GetPolyAtt0(param_2);
|
|
if (effType2 < 6 && (polyAtt != 1 || polyAtt != 3)) {
|
|
getPolyColor(param_2, 1, &a_Stack_48, &a_Stack_4c,
|
|
&local_50, &local_44);
|
|
*param_1 = setNormal(*param_1, effectIDTable[effType2][param_5],
|
|
param_3, param_4, param_6, param_7, local_50, param_8, param_9, &a_Stack_48,
|
|
&a_Stack_4c, param_10, local_44);
|
|
}
|
|
return rv;
|
|
}
|
|
|
|
u16 dPa_control_c::setCommonPoly(u32* param_0, cBgS_PolyInfo* param_1, cXyz const* param_2,
|
|
cXyz const* param_3, dKy_tevstr_c const* param_4, u32 param_5,
|
|
u32 param_6, csXyz const* param_7, cXyz const* param_8,
|
|
s8 param_9) {
|
|
f32 local_30;
|
|
GXColor a_Stack_34;
|
|
GXColor a_Stack_38;
|
|
int j;
|
|
int i;
|
|
u8 bVar3;
|
|
u16* puVar7;
|
|
const cXyz* local_40;
|
|
u32* ptr;
|
|
u16 uVar5 = 0;
|
|
u8 local_4c;
|
|
if (dComIfG_Bgsp().ChkPolySafe(*param_1) == 0) {
|
|
return 0;
|
|
}
|
|
|
|
int local_44 = dComIfG_Bgsp().GetPolyAtt0(*param_1);
|
|
for (i = 0; i < 2; i++) {
|
|
if (getPolyColor(*param_1, i, &a_Stack_34, &a_Stack_38, &local_4c, &local_30) == 0) {
|
|
return 0xffff;
|
|
}
|
|
if ((param_6 & 0x80000000) != 0) {
|
|
if (i == 1 && dKy_camera_water_in_status_check() && (local_44 == 1 || local_44 == 3)) {
|
|
bVar3 = 5;
|
|
} else {
|
|
bVar3 = 6;
|
|
}
|
|
} else {
|
|
if (i == 0) {
|
|
bVar3 = dKy_pol_efftype_get(param_1);
|
|
} else if (local_44 == 1 || local_44 == 3) {
|
|
bVar3 = 6;
|
|
} else {
|
|
bVar3 = dKy_pol_efftype2_get(param_1);
|
|
}
|
|
}
|
|
|
|
if (bVar3 >= 6 || (param_6 & (1 << bVar3)) != 0 ||
|
|
(bVar3 == 2 && (param_6 & 0x10000) != 0 && i == 1))
|
|
{
|
|
uVar5 |= (0xff << (i << 3));
|
|
} else {
|
|
static u16 ringID[6][4] = {
|
|
{ID_ZI_J_DOWNSMOKE_A, 0xFFFF, 0xFFFF, 0xFFFF}, {ID_ZI_J_DOWNKUSA_A, 0xFFFF, 0xFFFF, 0xFFFF},
|
|
{ID_ZI_J_DASHWTRA_A, ID_ZI_J_DASHWTRA_B, ID_ZI_J_DASHWTRA_C, 0xFFFF}, {dPa_RM(ID_ZI_S_DOWNSAND_A), 0xFFFF, 0xFFFF, 0xFFFF},
|
|
{dPa_RM(ID_ZI_S_DOWNSNOW_A), dPa_RM(ID_ZI_S_DOWNSNOW_B), 0xFFFF, 0xFFFF}, {dPa_RM(ID_ZI_S_DOWNSMOKE_INWTR_A), 0xFFFF, 0xFFFF, 0xFFFF},
|
|
};
|
|
static u16 normalID[6][4] = {
|
|
{ID_ZI_J_DASHSMOKE_A, 0xFFFF, 0xFFFF, 0xFFFF}, {ID_ZI_J_DASHKUSA_A, 0xFFFF, 0xFFFF, 0xFFFF},
|
|
{ID_ZI_J_DOWNWTRA_A, ID_ZI_J_DOWNWTRA_B, ID_ZI_J_DOWNWTRA_C, ID_ZI_J_DOWNWTRA_D}, {dPa_RM(ID_ZI_S_DASHSAND_A), 0xFFFF, 0xFFFF, 0xFFFF},
|
|
{dPa_RM(ID_ZI_S_DASHSNOW_A), dPa_RM(ID_ZI_S_DASHSNOW_B), 0xFFFF, 0xFFFF}, {dPa_RM(ID_ZI_S_DASHSMOKE_INWTR_A), 0xFFFF, 0xFFFF, 0xFFFF},
|
|
};
|
|
uVar5 |= bVar3 << (i << 3);
|
|
if (bVar3 == 2 && ((param_6 & 0x10000) != 0)) {
|
|
puVar7 = ringID[bVar3];
|
|
local_40 = param_2;
|
|
} else {
|
|
if ((param_5 & (1 << bVar3)) != 0) {
|
|
puVar7 = ringID[bVar3];
|
|
local_40 = param_3;
|
|
} else {
|
|
puVar7 = normalID[bVar3];
|
|
local_40 = param_3;
|
|
}
|
|
}
|
|
ptr = param_0 + 4*i;
|
|
for ( j = 0; j < 4; j++, ptr++, puVar7++) {
|
|
if (puVar7[0] == 0xffff) {
|
|
break;
|
|
}
|
|
ptr[0] = setNormal(ptr[0], puVar7[0], local_40, param_4, param_7, param_8,
|
|
local_4c, NULL, param_9, &a_Stack_34, &a_Stack_38, NULL, local_30);
|
|
dComIfGp_particle_levelEmitterOnEventMove(ptr[0]);
|
|
}
|
|
}
|
|
}
|
|
|
|
return uVar5;
|
|
}
|
|
|
|
void dPa_wbPcallBack_c::execute(JPABaseEmitter* i_emitter, JPABaseParticle* param_1) {
|
|
JGeometry::TVec3<f32> local_18;
|
|
param_1->getGlobalPosition(local_18);
|
|
cXyz cStack_24(local_18.x, local_18.y, local_18.z);
|
|
if (fopAcM_wt_c::waterCheck(&cStack_24) && cStack_24.y > fopAcM_wt_c::getWaterY()) {
|
|
param_1->setInvisibleParticleFlag();
|
|
param_1->setDeleteParticleFlag();
|
|
}
|
|
}
|
|
|
|
void dPa_fsenthPcallBack::execute(JPABaseEmitter* i_emitter, JPABaseParticle* param_1) {
|
|
if (g_env_light.now_senses_effect == 1 && g_env_light.senses_effect_strength > 0.0f) {
|
|
i_emitter->setGlobalAlpha(255.0f * g_env_light.senses_effect_strength);
|
|
i_emitter->playDrawParticle();
|
|
} else {
|
|
i_emitter->setGlobalAlpha(0);
|
|
i_emitter->stopDrawParticle();
|
|
}
|
|
}
|
|
|
|
void dPa_fsenthPcallBack::draw(JPABaseEmitter* i_emitter, JPABaseParticle* param_1) {
|
|
/* empty function */
|
|
}
|
|
|
|
void dPa_light8PcallBack::execute(JPABaseEmitter* i_emitter, JPABaseParticle* param_1) {
|
|
/* empty function */
|
|
}
|
|
|
|
void dPa_gen_b_light8PcallBack::execute(JPABaseEmitter* i_emitter, JPABaseParticle* param_1) {
|
|
/* empty function */
|
|
}
|
|
|
|
void dPa_gen_d_light8PcallBack::execute(JPABaseEmitter* i_emitter, JPABaseParticle* param_1) {
|
|
/* empty function */
|
|
}
|
|
|
|
void dPa_light8PcallBack::draw(JPABaseEmitter* param_1, JPABaseParticle* param_2) {
|
|
Mtx local_60;
|
|
Mtx auStack_90;
|
|
Mtx auStack_c0;
|
|
Mtx auStack_f0;
|
|
JGeometry::TVec3<f32> local_100;
|
|
JGeometry::TVec3<f32> local_10c;
|
|
JGeometry::TVec3<f32> local_118;
|
|
JGeometry::TVec3<f32> local_124;
|
|
JGeometry::TVec3<f32> local_130;
|
|
u8 globalAlpha = param_1->getGlobalAlpha() & 0xff;
|
|
JGeometry::TVec3<f32> local_13c;
|
|
JGeometry::TVec3<f32> local_148;
|
|
JGeometry::TVec3<f32> local_154;
|
|
JGeometry::TVec3<f32> local_160;
|
|
JGeometry::TVec3<f32> local_16c;
|
|
dPa_setWindPower(param_2);
|
|
MTXIdentity(local_60);
|
|
MTXIdentity(auStack_90);
|
|
param_2->getBaseAxis(&local_10c);
|
|
param_2->getLocalPosition(&local_118);
|
|
if (local_118.isZero()) {
|
|
local_118.set(0.0f, 1.0f, 0.0f);
|
|
} else {
|
|
local_118.normalize();
|
|
}
|
|
local_124.cross(local_10c, local_118);
|
|
if (local_124.isZero()) {
|
|
local_124.set(0.0f, 0.0f, 1.0f);
|
|
} else {
|
|
local_124.normalize();
|
|
}
|
|
local_10c.cross(local_118, local_124);
|
|
local_10c.normalize();
|
|
local_60[0][0] = local_10c.x;
|
|
local_60[0][1] = local_118.x;
|
|
local_60[0][2] = local_124.x;
|
|
local_60[1][0] = local_10c.y;
|
|
local_60[1][1] = local_118.y;
|
|
local_60[1][2] = local_124.y;
|
|
local_60[2][0] = local_10c.z;
|
|
local_60[2][1] = local_118.z;
|
|
local_60[2][2] = local_124.z;
|
|
f32 fVar3 = (-90.0f / 16384.0f) * param_2->getRotateAngle();
|
|
if (fVar3) {
|
|
Vec local_178 = {1.0f, 1.0f, 1.0f};
|
|
MTXRotAxisRad(auStack_90, &local_178, (M_PI / 180.0f) * fVar3);
|
|
MTXConcat(local_60, auStack_90, local_60);
|
|
}
|
|
param_2->getGlobalPosition(local_100);
|
|
local_60[0][3] = local_100.x;
|
|
local_60[1][3] = local_100.y;
|
|
local_60[2][3] = local_100.z;
|
|
param_1->getGlobalParticleScale(local_130);
|
|
local_130.x *= param_2->getParticleScaleX();
|
|
local_130.y *= param_2->getParticleScaleY();
|
|
local_130.x *= param_2->getWidth(param_1);
|
|
local_130.y *= param_2->getHeight(param_1);
|
|
local_130.x *= 10.0f;
|
|
local_130.y *= 10.0f;
|
|
local_130.z = 0.0f;
|
|
MTXScale(auStack_f0, local_130.x, local_130.y, local_130.z);
|
|
MTXConcat(local_60, auStack_f0, local_60);
|
|
MTXConcat(j3dSys.getViewMtx(), local_60, auStack_c0);
|
|
GXLoadPosMtxImm(auStack_c0, 0);
|
|
JGeometry::TVec3<f32> local_184;
|
|
JGeometry::TVec3<f32> local_190;
|
|
JGeometry::TVec3<f32> local_19c;
|
|
JGeometry::TVec3<f32> local_1a8;
|
|
local_184.set(1.0f, 2.0f, 0.0f);
|
|
local_190.set(1.0f, 0.0f, 0.0f);
|
|
local_19c.set(-1.0f, 0.0f, 0.0f);
|
|
local_1a8.set(-1.0f, 2.0f, 0.0f);
|
|
local_13c.x = 0.0f;
|
|
local_13c.y = 1.0f;
|
|
local_13c.z = 0.0f;
|
|
local_148.x = 0.0f;
|
|
local_148.y = 1.0f;
|
|
local_148.z = 0.0f;
|
|
local_154.x = 0.0f;
|
|
local_154.y = 1.0f;
|
|
local_154.z = 0.0f;
|
|
local_160.x = 0.0f;
|
|
local_160.y = 1.0f;
|
|
local_160.z = 0.0f;
|
|
local_16c.x = 0.0f;
|
|
local_16c.y = 1.0f;
|
|
local_16c.z = 0.0f;
|
|
local_13c.normalize();
|
|
local_148.normalize();
|
|
local_154.normalize();
|
|
local_160.normalize();
|
|
local_16c.normalize();
|
|
GXBegin(GX_TRIANGLEFAN, GX_VTXFMT0, 6);
|
|
GXPosition3f32(0.0f, 1.0f, 0.0f);
|
|
GXNormal3f32(local_13c.x, local_13c.y, local_13c.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, globalAlpha);
|
|
GXTexCoord2f32(0.5f, 0.5f);
|
|
GXPosition3f32(local_184.x, local_184.y, local_184.z);
|
|
GXNormal3f32(local_148.x, local_148.y, local_148.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, globalAlpha);
|
|
GXTexCoord2f32(1.0f, 0.0f);
|
|
GXPosition3f32(local_190.x, local_190.y, local_190.z);
|
|
GXNormal3f32(local_154.x, local_154.y, local_154.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, globalAlpha);
|
|
GXTexCoord2f32(1.0f, 1.0f);
|
|
GXPosition3f32(local_19c.x, local_19c.y, local_19c.z);
|
|
GXNormal3f32(local_160.x, local_160.y, local_160.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, globalAlpha);
|
|
GXTexCoord2f32(0.0f, 1.0f);
|
|
GXPosition3f32(local_1a8.x, local_1a8.y, local_1a8.z);
|
|
GXNormal3f32(local_16c.x, local_16c.y, local_16c.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, globalAlpha);
|
|
GXTexCoord2f32(0.0f, 0.0f);
|
|
GXPosition3f32(local_184.x, local_184.y, local_184.z);
|
|
GXNormal3f32(local_148.x, local_148.y, local_148.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, globalAlpha);
|
|
GXTexCoord2f32(1.0f, 0.0f);
|
|
GXEnd();
|
|
param_2->setInvisibleParticleFlag();
|
|
}
|
|
|
|
void dPa_gen_b_light8PcallBack::draw(JPABaseEmitter* param_1, JPABaseParticle* param_2) {
|
|
Mtx local_80;
|
|
JGeometry::TVec3<f32> local_8c;
|
|
JGeometry::TVec3<f32> aTStack_98;
|
|
JGeometry::TVec3<f32> aTStack_a4;
|
|
JGeometry::TVec3<f32> aTStack_b0;
|
|
JGeometry::TVec3<f32> local_bc;
|
|
u8 uVar7 = param_1->getGlobalAlpha();
|
|
JGeometry::TVec3<f32> local_c8;
|
|
JGeometry::TVec3<f32> local_d4;
|
|
JGeometry::TVec3<f32> local_e0;
|
|
JGeometry::TVec3<f32> local_ec;
|
|
JGeometry::TVec3<f32> local_f8;
|
|
param_2->getGlobalPosition(local_8c);
|
|
MTXMultVec(j3dSys.getViewMtx(), &local_8c, &local_8c);
|
|
f32 dVar9 = JMASSin(param_2->getRotateAngle());
|
|
f32 dVar10 = JMASCos(param_2->getRotateAngle());
|
|
param_1->getGlobalParticleScale(local_bc);
|
|
f32 var_f29 = local_bc.x * param_2->getWidth(param_1);
|
|
f32 var_f28 = local_bc.y * param_2->getHeight(param_1);
|
|
local_80[0][0] = dVar10 * var_f29;
|
|
local_80[0][1] = -dVar9 * var_f28;
|
|
local_80[0][3] = local_8c.x;
|
|
local_80[1][0] = dVar9 * var_f29;
|
|
local_80[1][1] = dVar10 * var_f28;
|
|
local_80[1][3] = local_8c.y;
|
|
local_80[2][2] = 1.0f;
|
|
local_80[2][3] = local_8c.z;
|
|
local_80[0][2] = local_80[1][2] = local_80[2][0] = local_80[2][1] = 0.0f;
|
|
GXLoadPosMtxImm(local_80, 0);
|
|
GXLoadNrmMtxImm(local_80, 0);
|
|
JGeometry::TVec3<f32> local_104;
|
|
JGeometry::TVec3<f32> local_110;
|
|
JGeometry::TVec3<f32> local_11c;
|
|
JGeometry::TVec3<f32> local_128;
|
|
local_104.set(12.5f, 12.5f, 0.0f);
|
|
local_110.set(12.5f, -12.5f, 0.0f);
|
|
local_11c.set(-12.5f, -12.5f, 0.0f);
|
|
local_128.set(-12.5f, 12.5f, 0.0f);
|
|
local_c8.x = 0.0f;
|
|
local_c8.y = 0.0f;
|
|
local_c8.z = 0.0f;
|
|
local_d4.x = 1.0f;
|
|
local_d4.y = 1.0f;
|
|
local_d4.z = 0.0f;
|
|
local_e0.x = 1.0f;
|
|
local_e0.y = -1.0f;
|
|
local_e0.z = 0.0f;
|
|
local_ec.x = -1.0f;
|
|
local_ec.y = -1.0f;
|
|
local_ec.z = 0.0f;
|
|
local_f8.x = -1.0f;
|
|
local_f8.y = 1.0f;
|
|
local_f8.z = 0.0f;
|
|
local_c8.normalize();
|
|
local_d4.normalize();
|
|
local_e0.normalize();
|
|
local_ec.normalize();
|
|
local_f8.normalize();
|
|
GXBegin(GX_TRIANGLEFAN, GX_VTXFMT0, 6);
|
|
GXPosition3f32(0.0f, 0.0f, 0.0f);
|
|
GXNormal3f32(local_c8.x, local_c8.y, local_c8.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, uVar7);
|
|
GXTexCoord2f32(0.5f, 0.5f);
|
|
GXPosition3f32(local_104.x, local_104.y, local_104.z);
|
|
GXNormal3f32(local_d4.x, local_d4.y, local_d4.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, uVar7);
|
|
GXTexCoord2f32(1.0f, 0.0f);
|
|
GXPosition3f32(local_110.x, local_110.y, local_110.z);
|
|
GXNormal3f32(local_e0.x, local_e0.y, local_e0.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, uVar7);
|
|
GXTexCoord2f32(1.0f, 1.0f);
|
|
GXPosition3f32(local_11c.x, local_11c.y, local_11c.z);
|
|
GXNormal3f32(local_ec.x, local_ec.y, local_ec.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, uVar7);
|
|
GXTexCoord2f32(0.0f, 1.0f);
|
|
GXPosition3f32(local_128.x, local_128.y, local_128.z);
|
|
GXNormal3f32(local_f8.x, local_f8.y, local_f8.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, uVar7);
|
|
GXTexCoord2f32(0.0f, 0.0f);
|
|
GXPosition3f32(local_104.x, local_104.y, local_104.z);
|
|
GXNormal3f32(local_d4.x, local_d4.y, local_d4.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, uVar7);
|
|
GXTexCoord2f32(1.0f, 0.0f);
|
|
GXEnd();
|
|
param_2->setInvisibleParticleFlag();
|
|
}
|
|
|
|
void dPa_gen_d_light8PcallBack::draw(JPABaseEmitter* param_1, JPABaseParticle* param_2) {
|
|
Mtx local_60;
|
|
Mtx auStack_90;
|
|
Mtx auStack_c0;
|
|
Mtx auStack_f0;
|
|
JGeometry::TVec3<f32> local_100;
|
|
JGeometry::TVec3<f32> local_10c;
|
|
JGeometry::TVec3<f32> local_118;
|
|
JGeometry::TVec3<f32> local_124;
|
|
JGeometry::TVec3<f32> local_130;
|
|
u8 uVar6 = param_1->getGlobalAlpha();
|
|
JGeometry::TVec3<f32> local_13c;
|
|
JGeometry::TVec3<f32> local_148;
|
|
JGeometry::TVec3<f32> local_154;
|
|
JGeometry::TVec3<f32> local_160;
|
|
JGeometry::TVec3<f32> local_16c;
|
|
MTXIdentity(local_60);
|
|
MTXIdentity(auStack_90);
|
|
param_2->getBaseAxis(local_10c);
|
|
param_2->getLocalPosition(local_118);
|
|
if (local_118.isZero()) {
|
|
local_118.set(0.0f, 1.0f, 0.0f);
|
|
} else {
|
|
local_118.normalize();
|
|
}
|
|
local_124.cross(local_10c, local_118);
|
|
if (local_124.isZero()) {
|
|
local_124.set(0.0f, 0.0f, 1.0f);
|
|
} else {
|
|
local_124.normalize();
|
|
}
|
|
local_10c.cross(local_118, local_124);
|
|
local_10c.normalize();
|
|
local_60[0][0] = local_10c.x;
|
|
local_60[0][1] = local_118.x;
|
|
local_60[0][2] = local_124.x;
|
|
local_60[1][0] = local_10c.y;
|
|
local_60[1][1] = local_118.y;
|
|
local_60[1][2] = local_124.y;
|
|
local_60[2][0] = local_10c.z;
|
|
local_60[2][1] = local_118.z;
|
|
local_60[2][2] = local_124.z;
|
|
f32 fVar3 = (-90.0f / 16384.0f) * param_2->getRotateAngle();
|
|
if (fVar3) {
|
|
Vec local_178 = {1.0f, 1.0f, 1.0f};
|
|
MTXRotAxisRad(auStack_90, &local_178, (M_PI / 180.0f) * fVar3);
|
|
MTXConcat(local_60, auStack_90, local_60);
|
|
}
|
|
param_2->getGlobalPosition(local_100);
|
|
local_60[0][3] = local_100.x;
|
|
local_60[1][3] = local_100.y;
|
|
local_60[2][3] = local_100.z;
|
|
param_1->getGlobalParticleScale(local_130);
|
|
local_130.x *= param_2->getWidth(param_1);
|
|
local_130.y *= param_2->getHeight(param_1);
|
|
local_130.z = 0.0f;
|
|
MTXScale(auStack_f0, local_130.x, local_130.y, local_130.z);
|
|
MTXConcat(local_60, auStack_f0, local_60);
|
|
MTXConcat(j3dSys.getViewMtx(), local_60, auStack_c0);
|
|
GXLoadPosMtxImm(auStack_c0, 0);
|
|
GXLoadNrmMtxImm(auStack_c0, 0);
|
|
JGeometry::TVec3<f32> local_184;
|
|
JGeometry::TVec3<f32> local_190;
|
|
JGeometry::TVec3<f32> local_19c;
|
|
JGeometry::TVec3<f32> local_1a8;
|
|
local_184.set(12.5f, 12.5f, 0.0f);
|
|
local_190.set(12.5f, -12.5f, 0.0f);
|
|
local_19c.set(-12.5f, -12.5f, 0.0f);
|
|
local_1a8.set(-12.5f, 12.5f, 0.0f);
|
|
local_13c.x = 0.0f;
|
|
local_13c.y = 0.0f;
|
|
local_13c.z = 0.0f;
|
|
local_148.x = 1.0f;
|
|
local_148.y = 1.0f;
|
|
local_148.z = 0.0f;
|
|
local_154.x = 1.0f;
|
|
local_154.y = -1.0f;
|
|
local_154.z = 0.0f;
|
|
local_160.x = -1.0f;
|
|
local_160.y = -1.0f;
|
|
local_160.z = 0.0f;
|
|
local_16c.x = -1.0f;
|
|
local_16c.y = 1.0f;
|
|
local_16c.z = 0.0f;
|
|
local_13c.normalize();
|
|
local_148.normalize();
|
|
local_154.normalize();
|
|
local_160.normalize();
|
|
local_16c.normalize();
|
|
GXBegin(GX_TRIANGLEFAN, GX_VTXFMT0, 6);
|
|
GXPosition3f32(0.0f, 0.0f, 0.0f);
|
|
GXNormal3f32(local_13c.x, local_13c.y, local_13c.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, uVar6);
|
|
GXTexCoord2f32(0.5f, 0.5f);
|
|
GXPosition3f32(local_184.x, local_184.y, local_184.z);
|
|
GXNormal3f32(local_148.x, local_148.y, local_148.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, uVar6);
|
|
GXTexCoord2f32(1.0f, 0.0f);
|
|
GXPosition3f32(local_190.x, local_190.y, local_190.z);
|
|
GXNormal3f32(local_154.x, local_154.y, local_154.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, uVar6);
|
|
GXTexCoord2f32(1.0f, 1.0f);
|
|
GXPosition3f32(local_19c.x, local_19c.y, local_19c.z);
|
|
GXNormal3f32(local_160.x, local_160.y, local_160.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, uVar6);
|
|
GXTexCoord2f32(0.0f, 1.0f);
|
|
GXPosition3f32(local_1a8.x, local_1a8.y, local_1a8.z);
|
|
GXNormal3f32(local_16c.x, local_16c.y, local_16c.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, uVar6);
|
|
GXTexCoord2f32(0.0f, 0.0f);
|
|
GXPosition3f32(local_184.x, local_184.y, local_184.z);
|
|
GXNormal3f32(local_148.x, local_148.y, local_148.z);
|
|
GXColor4u8(0xff, 0xff, 0xff, uVar6);
|
|
GXTexCoord2f32(1.0f, 0.0f);
|
|
GXEnd();
|
|
param_2->setInvisibleParticleFlag();
|
|
}
|
|
|
|
void dPa_hermiteEcallBack_c::setOldPosP(cXyz const* param_0, cXyz const* param_1) {
|
|
field_0x10 = param_0;
|
|
field_0x14 = param_1;
|
|
}
|
|
|
|
void dPa_hermiteEcallBack_c::executeAfter(JPABaseEmitter* param_1) {
|
|
JGeometry::TVec3<f32> aTStack_68;
|
|
#if DEBUG
|
|
JGeometry::TVec3<f32> local_74(field_0x10->x, field_0x10->y, field_0x10->z);
|
|
JGeometry::TVec3<f32> local_80(field_0xc->x, field_0xc->y, field_0xc->z);
|
|
#else
|
|
JGeometry::TVec3<f32> local_74;
|
|
local_74.x = field_0x10->x;
|
|
local_74.y = field_0x10->y;
|
|
local_74.z = field_0x10->z;
|
|
JGeometry::TVec3<f32> local_80;
|
|
local_80.x = field_0xc->x;
|
|
local_80.y = field_0xc->y;
|
|
local_80.z = field_0xc->z;
|
|
#endif
|
|
JGeometry::TVec3<f32> local_8c;
|
|
JGeometry::TVec3<f32> local_98;
|
|
param_1->setGlobalTranslation(local_80);
|
|
if (param_1->checkStatus(2) == 0) {
|
|
local_98.x = 0.5f * (local_80.x - local_74.x);
|
|
local_98.y = 0.5f * (local_80.y - local_74.y);
|
|
local_98.z = 0.5f * (local_80.z - local_74.z);
|
|
local_8c.x = 0.5f * (local_74.x - field_0x14->x);
|
|
local_8c.y = 0.5f * (local_74.y - field_0x14->y);
|
|
local_8c.z = 0.5f * (local_74.z - field_0x14->z);
|
|
f32 fVar2 = field_0xc->abs(*field_0x10);
|
|
f32 fVar1 = (0.1f * fVar2) * mRate;
|
|
if (mMaxCnt != 0) {
|
|
if (fVar1 > mMaxCnt) {
|
|
fVar1 = mMaxCnt;
|
|
}
|
|
}
|
|
if (fVar1 > 1.0f) {
|
|
f32 dVar9 = 1.0f / fVar1;
|
|
for (f32 dVar8 = dVar9; dVar8 < 1.0f; dVar8 += dVar9) {
|
|
aTStack_68.cubic(local_74, local_8c, local_98, local_80, dVar8);
|
|
JPABaseParticle* particle = param_1->createParticle();
|
|
if (particle != NULL) {
|
|
particle->setOffsetPosition(aTStack_68);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
void dPa_hermiteEcallBack_c::setup(JPABaseEmitter* i_emitter, cXyz const* param_1,
|
|
csXyz const* param_2, s8 param_3) {
|
|
field_0xc = param_1;
|
|
mRate = 1.0f;
|
|
mMaxCnt = 0;
|
|
}
|
|
|
|
void dPa_particleTracePcallBack_c::execute(JPABaseEmitter* i_emitter, JPABaseParticle* param_1) {
|
|
if (param_1->getAge() > 0) {
|
|
Vec* vec = (Vec*)i_emitter->getUserWork();
|
|
JGeometry::TVec3<f32> local_24;
|
|
param_1->getOffsetPosition(&local_24);
|
|
local_24.x += vec->x;
|
|
local_24.y += vec->y;
|
|
local_24.z += vec->z;
|
|
param_1->setOffsetPosition(local_24);
|
|
}
|
|
}
|