Minor optimization for particle emitters

c++11
scrawl 10 years ago
parent df9ea917dd
commit 0b77ae43a4

@ -238,7 +238,12 @@ void Emitter::setCounter(osgParticle::Counter *counter)
void Emitter::emitParticles(double dt) void Emitter::emitParticles(double dt)
{ {
int n = mCounter->numParticlesToCreate(dt);
if (n == 0)
return;
osg::Matrix worldToPs; osg::Matrix worldToPs;
// maybe this could be optimized by halting at the lowest common ancestor of the particle and emitter nodes // maybe this could be optimized by halting at the lowest common ancestor of the particle and emitter nodes
osg::MatrixList worldMats = getParticleSystem()->getWorldMatrices(); osg::MatrixList worldMats = getParticleSystem()->getWorldMatrices();
if (!worldMats.empty()) if (!worldMats.empty())
@ -271,8 +276,6 @@ void Emitter::emitParticles(double dt)
emitterToPs.orthoNormalize(emitterToPs); emitterToPs.orthoNormalize(emitterToPs);
int n = mCounter->numParticlesToCreate(dt);
for (int i=0; i<n; ++i) for (int i=0; i<n; ++i)
{ {
osgParticle::Particle* P = getParticleSystem()->createParticle(0); osgParticle::Particle* P = getParticleSystem()->createParticle(0);

Loading…
Cancel
Save