aboutsummaryrefslogtreecommitdiff
path: root/world.c
diff options
context:
space:
mode:
authorquou <quou@disroot.org>2024-10-02 21:23:04 +1000
committerquou <quou@disroot.org>2024-10-02 21:24:37 +1000
commit8d2ba1419c060078c0aeeb33ef4e84da482b78f5 (patch)
tree1148ecab21daf9e02062896689b965402aafb6a4 /world.c
parent52d93d98018c47cb9f8d9271e4ded8ab96b7bfbd (diff)
particle effects
Diffstat (limited to 'world.c')
-rw-r--r--world.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/world.c b/world.c
index b1f73ec..1881df2 100644
--- a/world.c
+++ b/world.c
@@ -54,6 +54,21 @@ Deathzone* inst_deathzone(
return d;
}
+Effect* inst_effect(
+ World* w,
+ int x,
+ int y,
+ int vx,
+ int vy,
+ int c
+) {
+ Effect* e;
+ assert(w->effect_count < max_effects);
+ e = &w->effects[w->effect_count++];
+ init_effect(e, x, y, vx, vy, c);
+ return e;
+}
+
void update_world(World* w, const App* a) {
int i;
if (w->laser.life)
@@ -69,6 +84,9 @@ void update_world(World* w, const App* a) {
for (i = w->particle_count - 1; i >= 0; i--)
if (update_particle(&w->particles[i]))
w->particles[i] = w->particles[--w->particle_count];
+ for (i = w->effect_count - 1; i >= 0; i--)
+ if (update_effect(&w->effects[i]))
+ w->effects[i] = w->effects[--w->effect_count];
for (i = w->enemy_count - 1; i >= 0; i--)
if (update_enemy(&w->enemies[i], w))
w->enemies[i] = w->enemies[--w->enemy_count];
@@ -81,6 +99,8 @@ void ren_world(const World* w, struct Renderer* r) {
render_map(&w->map, r);
for (i = 0; i < w->particle_count; i++)
ren_particle(&w->particles[i], r);
+ for (i = 0; i < w->effect_count; i++)
+ ren_effect(&w->effects[i], r);
for (i = 0; i < w->enemy_count; i++)
ren_enemy(&w->enemies[i], r);
if (w->laser.life)