Fix one-shot stream emitter

scene_man
En Yi 2023-11-22 00:12:09 +08:00
parent ec9e21dc8a
commit 637319cfd0
1 changed files with 17 additions and 13 deletions

View File

@ -136,7 +136,7 @@ bool is_emitter_handle_alive(ParticleSystem_t* system, EmitterHandle handle)
EmitterHandle play_particle_emitter(ParticleSystem_t* system, const ParticleEmitter_t* in_emitter) EmitterHandle play_particle_emitter(ParticleSystem_t* system, const ParticleEmitter_t* in_emitter)
{ {
EmitterHandle idx = load_in_particle_emitter(system, in_emitter); EmitterHandle idx = load_in_particle_emitter(system, in_emitter);
if (idx == 0) return 0 ; if (idx == 0) return 0;
play_emitter_handle(system, idx); play_emitter_handle(system, idx);
return idx; return idx;
@ -181,9 +181,12 @@ void update_particle_system(ParticleSystem_t* system)
else else
{ {
emitter->particles[i].spawned = true; emitter->particles[i].spawned = true;
spawn_particle(emitter, i);
} }
} }
if (emitter->particles[i].spawned)
{
if (!emitter->particles[i].alive) if (!emitter->particles[i].alive)
{ {
if (!emitter->active) if (!emitter->active)
@ -194,13 +197,14 @@ void update_particle_system(ParticleSystem_t* system)
{ {
inactive_count++; inactive_count++;
} }
else if (emitter->particles[i].spawned) else
{ {
// If not one shot, immediately revive the particle // If not one shot, immediately revive the particle
spawn_particle(emitter, i); spawn_particle(emitter, i);
} }
} }
} }
}
if (inactive_count == emitter->n_particles) if (inactive_count == emitter->n_particles)
{ {