// 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 #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 aTStack_24(field_0xc->x, field_0xc->y, field_0xc->z); #else JGeometry::TVec3 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 aTStack_18; JGeometry::TVec3 aTStack_24; JGeometry::TVec3 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 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 local_cc; JGeometry::TVec3 aTStack_24; JGeometry::TVec3 aTStack_30; JGeometry::TVec3 aTStack_36; JGeometry::TVec3 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 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 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("------- %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("------- %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 aTStack_78(i_pos->x, i_pos->y, i_pos->z); #else JGeometry::TVec3 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 aTStack_a4(i_rotation->x, i_rotation->y, i_rotation->z); #else JGeometry::TVec3 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 aTStack_84(i_scale->x, i_scale->y, i_scale->z); #else JGeometry::TVec3 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 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 aTStack_9c(param_11->x, param_11->y, param_11->z); #else JGeometry::TVec3 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 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 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 local_100; JGeometry::TVec3 local_10c; JGeometry::TVec3 local_118; JGeometry::TVec3 local_124; JGeometry::TVec3 local_130; u8 globalAlpha = param_1->getGlobalAlpha() & 0xff; JGeometry::TVec3 local_13c; JGeometry::TVec3 local_148; JGeometry::TVec3 local_154; JGeometry::TVec3 local_160; JGeometry::TVec3 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 local_184; JGeometry::TVec3 local_190; JGeometry::TVec3 local_19c; JGeometry::TVec3 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 local_8c; JGeometry::TVec3 aTStack_98; JGeometry::TVec3 aTStack_a4; JGeometry::TVec3 aTStack_b0; JGeometry::TVec3 local_bc; u8 uVar7 = param_1->getGlobalAlpha(); JGeometry::TVec3 local_c8; JGeometry::TVec3 local_d4; JGeometry::TVec3 local_e0; JGeometry::TVec3 local_ec; JGeometry::TVec3 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 local_104; JGeometry::TVec3 local_110; JGeometry::TVec3 local_11c; JGeometry::TVec3 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 local_100; JGeometry::TVec3 local_10c; JGeometry::TVec3 local_118; JGeometry::TVec3 local_124; JGeometry::TVec3 local_130; u8 uVar6 = param_1->getGlobalAlpha(); JGeometry::TVec3 local_13c; JGeometry::TVec3 local_148; JGeometry::TVec3 local_154; JGeometry::TVec3 local_160; JGeometry::TVec3 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 local_184; JGeometry::TVec3 local_190; JGeometry::TVec3 local_19c; JGeometry::TVec3 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 aTStack_68; #if DEBUG JGeometry::TVec3 local_74(field_0x10->x, field_0x10->y, field_0x10->z); JGeometry::TVec3 local_80(field_0xc->x, field_0xc->y, field_0xc->z); #else JGeometry::TVec3 local_74; local_74.x = field_0x10->x; local_74.y = field_0x10->y; local_74.z = field_0x10->z; JGeometry::TVec3 local_80; local_80.x = field_0xc->x; local_80.y = field_0xc->y; local_80.z = field_0xc->z; #endif JGeometry::TVec3 local_8c; JGeometry::TVec3 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 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); } }