00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015 #ifndef SPHEREVOLUMEEMITTER_H
00016 #define SPHEREVOLUMEEMITTER_H
00017
00018 #include "baseParticleEmitter.h"
00019
00020
00021
00022
00023
00024
00025 class EXPCL_PANDAPHYSICS SphereVolumeEmitter : public BaseParticleEmitter {
00026 PUBLISHED:
00027 SphereVolumeEmitter();
00028 SphereVolumeEmitter(const SphereVolumeEmitter ©);
00029 virtual ~SphereVolumeEmitter();
00030
00031 virtual BaseParticleEmitter *make_copy();
00032
00033 INLINE void set_radius(PN_stdfloat r);
00034 INLINE PN_stdfloat get_radius() const;
00035
00036 virtual void output(ostream &out) const;
00037 virtual void write(ostream &out, int indent=0) const;
00038
00039 private:
00040 PN_stdfloat _radius;
00041
00042
00043
00044
00045
00046
00047 LPoint3 _particle_pos;
00048
00049
00050 virtual void assign_initial_position(LPoint3& pos);
00051 virtual void assign_initial_velocity(LVector3& vel);
00052 };
00053
00054 #include "sphereVolumeEmitter.I"
00055
00056 #endif // SPHEREVOLUMEEMITTER_H