Added support for setting the texture filename and more fine control over

the particle template used in ParticleEffects
This commit is contained in:
Robert Osfield
2005-05-11 15:26:16 +00:00
parent 4c613896ff
commit 52666a6dee
6 changed files with 112 additions and 54 deletions

View File

@@ -21,11 +21,12 @@ ParticleEffect::ParticleEffect(const ParticleEffect& copy, const osg::CopyOp& co
osg::Group(copy,copyop),/*,
_particleSystem(copy._particleSystem.valid()?copy._particleSystem->clone():0)*/
_useLocalParticleSystem(copy._useLocalParticleSystem),
_defaultParticleTemplate(copy._defaultParticleTemplate),
_position(copy._position),
_scale(copy._scale),
_intensity(copy._intensity),
_startTime(copy._startTime),
_emitterDuration(copy._emitterDuration),
_particleDuration(copy._particleDuration),
_wind(copy._wind)
{
}
@@ -38,6 +39,12 @@ void ParticleEffect::setUseLocalParticleSystem(bool local)
buildEffect();
}
void ParticleEffect::setDefaultParticleTemplate(const Particle& p)
{
_defaultParticleTemplate = p;
setUpEmitterAndProgram();
}
void ParticleEffect::setPosition(const osg::Vec3& position)
{
if (_position==position) return;
@@ -80,9 +87,10 @@ void ParticleEffect::setEmitterDuration(double duration)
void ParticleEffect::setParticleDuration(double duration)
{
if (_particleDuration==duration) return;
if (_defaultParticleTemplate.getLifeTime()==duration) return;
_particleDuration = duration;
_defaultParticleTemplate.setLifeTime(duration);
setUpEmitterAndProgram();
}
@@ -109,7 +117,6 @@ void ParticleEffect::setDefaults()
_intensity = 1.0f;
_startTime = 0.0;
_emitterDuration = 1.0;
_particleDuration = 1.0;
_wind.set(0.0f,0.0f,0.0f);
}