/** * d_particle_copoly.cpp * */ #include "d/d_particle_copoly.h" #include "f_op/f_op_kankyo_mng.h" /* 80050C9C-80050CC4 04B5DC 0028+00 0/0 2/2 27/27 .text init__7dPaPo_cFP9dBgS_Acchff */ void dPaPo_c::init(dBgS_Acch* param_0, f32 i_waterOffset, f32 i_rippleOffset) { field_0x28 = param_0; mWaterOffset = i_waterOffset; mRippleOffset = i_rippleOffset; field_0x28->ClrWaterNone(); field_0x37 = 1; } /* 80050CC4-80050E7C 04B604 01B8+00 1/1 0/0 0/0 .text * checkWaterIn__7dPaPo_cFP4cXyzPC4cXyzPC12dKy_tevstr_cUlScff */ int dPaPo_c::checkWaterIn(cXyz* param_0, cXyz const* param_1, dKy_tevstr_c const* param_2, u32 param_3, s8 param_4, f32 param_5, f32 param_6) { if (field_0x28->ChkWaterHit() && dComIfG_Bgsp().ChkPolySafe(field_0x28->m_wtr) && dComIfG_Bgsp().GetPolyAtt0(field_0x28->m_wtr) != 6) { f32 wtr_height = field_0x28->m_wtr.GetHeight(); f32 var_f31 = wtr_height - param_0->y; if (var_f31 >= 0.0f) { param_0->y = wtr_height; if (!field_0x37) { field_0x37 = 1; if (!(param_3 & 0x40000) && field_0x28->m_wtr.GetHeight() - field_0x28->GetGroundH() >= mWaterOffset) { fopKyM_createWpillar(param_0, param_5, 0); } } if (var_f31 < mRippleOffset && !(param_3 & 0x20000)) { dComIfGp_particle_setWaterRipple(field_0x0, field_0x28->m_wtr, param_0, param_6, param_2, param_1, param_4); } if (var_f31 < mWaterOffset) { return 1; } param_0->y -= var_f31; return 2; } field_0x37 = 0; } else { field_0x37 = 0; } return 0; } /* 80050E7C-80051008 04B7BC 018C+00 3/3 0/0 0/0 .text * setEffect__7dPaPo_cFPUliPC12dKy_tevstr_cPC4cXyzUlUlPC4cXyzPC5csXyzScPUcPUc */ void dPaPo_c::setEffect(u32* param_0, int param_1, dKy_tevstr_c const* param_2, cXyz const* param_3, u32 param_4, u32 param_5, cXyz const* param_6, csXyz const* param_7, s8 param_8, u8* param_9, u8* param_10) { if (param_6 != NULL) { cXyz sp18(*param_6); cBgS_PolyInfo* poly_p; if (param_1 == 1) { sp18.y = field_0x28->m_wtr.GetHeight(); poly_p = &field_0x28->m_wtr; } else { if (param_1 == 2) { param_5 |= 0x80000000; } poly_p = &field_0x28->m_gnd; } u16 temp_r29 = dComIfGp_particle_setCommonPoly(param_0, poly_p, param_3, &sp18, param_2, param_4, param_5, param_7, NULL, param_8); param_9[0] = temp_r29 & 0xFF; param_9[1] = (temp_r29 >> 8) & 0xFF; if (param_9[0] != 0xFF) { if (param_4 & (1 << param_9[0])) { *param_10 = 0; } else { *param_10 = 20; } } else if (param_9[1] != 0xFF) { if (param_4 & (1 << param_9[1])) { *param_10 = 0; } else { *param_10 = 20; } } } else if (*param_10 != 0) { *param_10 -= 1; u32* var_r31 = param_0; for (int i = 0; i < 8; i++) { if (*var_r31 != 0) { *var_r31 = dComIfGp_particle_setStopContinue(*var_r31); } var_r31++; } } } /* 80051008-8005113C 04B948 0134+00 1/1 1/1 12/12 .text * setEffectCenter__7dPaPo_cFPC12dKy_tevstr_cPC4cXyzUlUlPC4cXyzPC5csXyzPC4cXyzScff */ int dPaPo_c::setEffectCenter(dKy_tevstr_c const* param_0, cXyz const* param_1, u32 param_2, u32 param_3, cXyz const* param_4, csXyz const* param_5, cXyz const* param_6, s8 param_7, f32 param_8, f32 param_9) { cXyz sp18(*param_1); int rt = checkWaterIn(&sp18, param_6, param_0, param_3, param_7, param_8, param_9); mCenterEffType[0] = 0xFF; mCenterEffType[1] = 0xFF; if (rt == 1 && (param_3 & 0x10000)) { setEffect(field_0x8[0], rt, param_0, &sp18, param_2, param_3, &sp18, param_5, param_7, &mCenterEffType[0], &field_0x36); if (mCenterEffType[0] == 2) { mCenterEffType[0] = 16; field_0x36 = 20; } return 3; } else { setEffect(field_0x8[0], rt, param_0, &sp18, param_2, param_3, param_4, param_5, param_7, &mCenterEffType[0], &field_0x36); } return rt; } /* 8005113C-8005115C 04BA7C 0020+00 2/2 0/0 0/0 .text clearID__7dPaPo_cFPUlPUc */ void dPaPo_c::clearID(u32* param_0, u8* param_1) { *param_1 = 0; for (int i = 0; i < 8; i++) { *param_0 = 0; param_0++; } } /* 8005115C-80051294 04BA9C 0138+00 1/1 1/1 2/2 .text * setEffectTwo__8dPaPoT_cFPC12dKy_tevstr_cPC4cXyzUlUlPC4cXyzPC4cXyzPC4cXyzPC5csXyzPC4cXyzScff */ int dPaPoT_c::setEffectTwo(dKy_tevstr_c const* param_0, cXyz const* param_1, u32 param_2, u32 param_3, cXyz const* param_4, cXyz const* param_5, cXyz const* param_6, csXyz const* param_7, cXyz const* param_8, s8 param_9, f32 param_10, f32 param_11) { mLeftEffType[0] = 0xFF; mLeftEffType[1] = 0xFF; mRightEffType[0] = 0xFF; mRightEffType[1] = 0xFF; int rt = setEffectCenter(param_0, param_1, param_2, param_3, param_4, param_7, param_8, param_9, param_10, param_11); if (rt != 3) { cXyz sp18(*param_1); if (rt == 1) { sp18.y = field_0x28->m_wtr.GetHeight(); } setEffect(mLeftEmitter[0], rt, param_0, &sp18, param_2, param_3, param_5, param_7, param_9, mLeftEffType, &field_0x7c); setEffect(mRightEmitter[0], rt, param_0, &sp18, param_2, param_3, param_6, param_7, param_9, mRightEffType, &field_0x7d); } else { field_0x7c = 0; field_0x7d = 0; } return rt; } /* 80051294-800512E8 04BBD4 0054+00 1/1 0/0 0/0 .text clearTwoAllID__8dPaPoT_cFv */ void dPaPoT_c::clearTwoAllID() { clearLeftID(); clearRightID(); clearCenterID(); } /* 800512E8-80051424 04BC28 013C+00 0/0 1/1 1/1 .text * setEffectFour__8dPaPoF_cFPC12dKy_tevstr_cPC4cXyzUlUlPC4cXyzPC4cXyzPC4cXyzPC4cXyzPC4cXyzPC5csXyzPC4cXyzScff */ int dPaPoF_c::setEffectFour(dKy_tevstr_c const* param_0, cXyz const* param_1, u32 param_2, u32 param_3, cXyz const* param_4, cXyz const* param_5, cXyz const* param_6, cXyz const* param_7, cXyz const* param_8, csXyz const* param_9, cXyz const* param_10, s8 param_11, f32 param_12, f32 param_13) { mBackLeftEffType[0] = 0xFF; mBackLeftEffType[1] = 0xFF; mBackRightEffType[0] = 0xFF; mBackRightEffType[1] = 0xFF; int rt = setEffectTwo(param_0, param_1, param_2, param_3, param_4, param_5, param_6, param_9, param_10, param_11, param_12, param_13); if (rt != 3) { cXyz sp18(*param_1); if (rt == 1) { sp18.y = field_0x28->m_wtr.GetHeight(); } setEffect(mBackLeftEmitter[0], rt, param_0, &sp18, param_2, param_3, param_7, param_9, param_11, mBackLeftEffType, &field_0xc4); setEffect(mBackRightEmitter[0], rt, param_0, &sp18, param_2, param_3, param_8, param_9, param_11, mBackRightEffType, &field_0xc5); } else { field_0xc4 = 0; field_0xc5 = 0; } return rt; } /* 80051424-80051470 04BD64 004C+00 0/0 1/1 0/0 .text clearFourAllID__8dPaPoF_cFv */ void dPaPoF_c::clearFourAllID() { clearBLeftID(); clearBRightID(); clearTwoAllID(); } /* ############################################################################################## */ /* 803A85F8-803A8604 005718 000C+00 1/1 0/0 0/0 .data cNullVec__6Z2Calc */ static u8 cNullVec__6Z2Calc[12] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, }; /* 803A8628-803A864C 005748 0024+00 0/1 0/0 0/0 .data m_typeTwoData__8dPaPoT_c */ dPaPoT_c::effTypeFunc dPaPoT_c::m_typeTwoData[] = { &dPaPoT_c::getCenterEffType, &dPaPoT_c::getLeftEffType, &dPaPoT_c::getRightEffType, }; /* 803A8670-803A8694 005790 0024+00 0/1 0/0 1/1 .data m_emitterTwoData__8dPaPoT_c */ dPaPoT_c::emitterFunc dPaPoT_c::m_emitterTwoData[] = { &dPaPoT_c::getCenterEmitter, &dPaPoT_c::getLeftEmitter, &dPaPoT_c::getRightEmitter, }; /* 803A86D0-803A870C 0057F0 003C+00 0/1 5/5 1/1 .data m_typeFourData__8dPaPoF_c */ dPaPoF_c::effTypeFunc dPaPoF_c::m_typeFourData[] = { &dPaPoF_c::getCenterEffType, &dPaPoF_c::getLeftEffType, &dPaPoF_c::getRightEffType, &dPaPoF_c::getBackLeftEffType, &dPaPoF_c::getBackRightEffType, }; /* 803A8748-803A87A0 005868 003C+1C 0/1 5/5 1/1 .data m_emitterFourData__8dPaPoF_c */ dPaPoF_c::emitterFunc dPaPoF_c::m_emitterFourData[] = { &dPaPoF_c::getCenterEmitter, &dPaPoF_c::getLeftEmitter, &dPaPoF_c::getRightEmitter, &dPaPoF_c::getBackLeftEmitter, &dPaPoF_c::getBackRightEmitter, };