tp/include/d/d_particle_copoly.h

110 lines
4.3 KiB
C++

#ifndef D_PARTICLE_D_PARTICLE_COPOLY_H
#define D_PARTICLE_D_PARTICLE_COPOLY_H
#include "d/d_com_inf_game.h"
class dBgS_Acch;
class dKy_tevstr_c;
class JPABaseEmitter;
class dPaPo_c {
public:
/* 80050C9C */ void init(dBgS_Acch*, f32, f32);
/* 80050CC4 */ int checkWaterIn(cXyz*, cXyz const*, dKy_tevstr_c const*, u32, s8, f32, f32);
/* 80050E7C */ void setEffect(u32*, int, dKy_tevstr_c const*, cXyz const*, u32, u32,
cXyz const*, csXyz const*, s8, u8*, u8*);
/* 80051008 */ int setEffectCenter(dKy_tevstr_c const*, cXyz const*, u32, u32, cXyz const*,
csXyz const*, cXyz const*, s8, f32, f32);
/* 8005113C */ void clearID(u32*, u8*);
void clearCenterID() { clearID(field_0x8[0], &field_0x36); }
void changeWaterOffset(f32 i_offset) { mWaterOffset = i_offset; }
void changeRippleOffset(f32 i_offset) { mRippleOffset = i_offset; }
u8 getCenterEffType(int i_idx) const { return mCenterEffType[i_idx]; }
JPABaseEmitter* getCenterEmitter(int param_0, int param_1) {
return dComIfGp_particle_getEmitter(field_0x8[param_0][param_1]);
}
/* 0x00 */ u32 field_0x0[2];
/* 0x08 */ u32 field_0x8[2][4];
/* 0x28 */ dBgS_Acch* field_0x28;
/* 0x2C */ f32 mWaterOffset;
/* 0x30 */ f32 mRippleOffset;
/* 0x34 */ u8 mCenterEffType[2];
/* 0x36 */ u8 field_0x36;
/* 0x37 */ u8 field_0x37;
};
class dPaPoT_c : public dPaPo_c {
public:
/* 8005115C */ int setEffectTwo(dKy_tevstr_c const*, cXyz const*, u32, u32, cXyz const*,
cXyz const*, cXyz const*, csXyz const*, cXyz const*, s8, f32,
f32);
/* 80051294 */ void clearTwoAllID();
void clearLeftID() { clearID(mLeftEmitter[0], &field_0x7c); }
void clearRightID() { clearID(mRightEmitter[0], &field_0x7d); }
u8 getRightEffType(int i_idx) const { return mRightEffType[i_idx]; }
u8 getLeftEffType(int i_idx) const { return mLeftEffType[i_idx]; }
JPABaseEmitter* getRightEmitter(int param_0, int param_1) {
return dComIfGp_particle_getEmitter(mRightEmitter[param_0][param_1]);
}
JPABaseEmitter* getLeftEmitter(int param_0, int param_1) {
return dComIfGp_particle_getEmitter(mLeftEmitter[param_0][param_1]);
}
typedef u8 (dPaPoT_c::*effTypeFunc)(int) const;
typedef JPABaseEmitter* (dPaPoT_c::*emitterFunc)(int, int);
static effTypeFunc m_typeTwoData[];
static emitterFunc m_emitterTwoData[];
/* 0x38 */ u32 mLeftEmitter[2][4];
/* 0x58 */ u32 mRightEmitter[2][4];
/* 0x78 */ u8 mLeftEffType[2];
/* 0x7A */ u8 mRightEffType[2];
/* 0x7C */ u8 field_0x7c;
/* 0x7D */ u8 field_0x7d;
};
class dPaPoF_c : public dPaPoT_c {
public:
/* 800512E8 */ int setEffectFour(dKy_tevstr_c const*, cXyz const*, u32, u32, cXyz const*,
cXyz const*, cXyz const*, cXyz const*, cXyz const*,
csXyz const*, cXyz const*, s8, f32, f32);
/* 80051424 */ void clearFourAllID();
void clearBLeftID() { clearID(mBackLeftEmitter[0], &field_0xc4); }
void clearBRightID() { clearID(mBackRightEmitter[0], &field_0xc5); }
u8 getBackRightEffType(int i_idx) const { return mBackRightEffType[i_idx]; }
u8 getBackLeftEffType(int i_idx) const { return mBackLeftEffType[i_idx]; }
JPABaseEmitter* getBackRightEmitter(int param_0, int param_1) {
return dComIfGp_particle_getEmitter(mBackRightEmitter[param_0][param_1]);
}
JPABaseEmitter* getBackLeftEmitter(int param_0, int param_1) {
return dComIfGp_particle_getEmitter(mBackLeftEmitter[param_0][param_1]);
}
typedef u8 (dPaPoF_c::*effTypeFunc)(int) const;
typedef JPABaseEmitter* (dPaPoF_c::*emitterFunc)(int, int);
u8 getTypeFour(int param_0, int param_1) const {
return (this->*m_typeFourData[param_0])(param_1);
}
JPABaseEmitter* getEmitterFour(int param_0, int param_1, int param_2) {
return (this->*m_emitterFourData[param_0])(param_1, param_2);
}
static effTypeFunc m_typeFourData[];
static emitterFunc m_emitterFourData[];
/* 0x80 */ u32 mBackLeftEmitter[2][4];
/* 0xA0 */ u32 mBackRightEmitter[2][4];
/* 0xC0 */ u8 mBackLeftEffType[2];
/* 0xC2 */ u8 mBackRightEffType[2];
/* 0xC4 */ u8 field_0xc4;
/* 0xC5 */ u8 field_0xc5;
};
#endif /* D_PARTICLE_D_PARTICLE_COPOLY_H */