|
|
@ -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);
|
|
|
|