X-Git-Url: https://git.rohieb.name/hackover2013-badge-firmware.git/blobdiff_plain/47c27a4c712e6a1927656c69651354df40c3864a..5245ad67d7984b14a389a66d6c4435bf08c5739a:/badge/jumpnrun/enemies.c?ds=sidebyside diff --git a/badge/jumpnrun/enemies.c b/badge/jumpnrun/enemies.c index ed044bd..0ca8ad0 100644 --- a/badge/jumpnrun/enemies.c +++ b/badge/jumpnrun/enemies.c @@ -99,9 +99,14 @@ static void enemy_spawn(jumpnrun_enemy *self) { self->base.jumpable_frames = 0; } +static void jumpnrun_enemy_kill(jumpnrun_enemy *self) { + self->base.flags |= JUMPNRUN_MOVEABLE_DYING; + self->base.tick_minor = 0; +} + void jumpnrun_enemy_despawn(jumpnrun_enemy *self) { // Despawned enemies are reset to their spawn position, so enemy_in_spawn_area will determine whether the spawn point is in the spawn area. - self->base.flags &= ~(JUMPNRUN_ENEMY_SPAWNED | JUMPNRUN_ENEMY_MOVING); + self->base.flags &= ~(JUMPNRUN_ENEMY_SPAWNED | JUMPNRUN_ENEMY_MOVING | JUMPNRUN_MOVEABLE_DYING); self->base.hitbox = rectangle_new(self->spawn_pos, self->type->hitbox.extent); self->base.inertia = self->type->spawn_inertia; } @@ -147,6 +152,15 @@ void jumpnrun_process_enemy(jumpnrun_enemy *self, if(self->base.flags & JUMPNRUN_ENEMY_SPAWNED) { if(!enemy_in_spawn_area(self, state) || fixed_point_gt(rectangle_top (enemy_hitbox(self)), FIXED_INT(BADGE_DISPLAY_HEIGHT))) { jumpnrun_enemy_despawn(self); + } else if(jumpnrun_moveable_dying(&self->base)) { + if(jumpnrun_moveable_finished_dying(&self->base)) { + jumpnrun_enemy_despawn(self); + } else { + if(fb) { + jumpnrun_render_splosion(fb, state, &self->base); + } + ++self->base.tick_minor; + } } else { if((self->base.flags & JUMPNRUN_ENEMY_MOVING) || enemy_on_screen(self, state)) { self->base.flags |= JUMPNRUN_ENEMY_MOVING; @@ -182,9 +196,10 @@ void enemy_collision_tiles_bounce_horiz(jumpnrun_enemy *self, lv, visible_tiles, &inertia_mod); + self->base.inertia.y = inertia_mod.y; if(killed) { - jumpnrun_enemy_despawn(self); + jumpnrun_enemy_kill(self); } else if(fixed_point_ne(inertia_mod.x, self->base.inertia.x)) { enemy_bounce(self); } @@ -196,7 +211,7 @@ void enemy_collision_player_deadly(struct jumpnrun_enemy *self, (void) player_inertia_mod; if(rectangle_intersect(enemy_hitbox(self), &state->player.base.hitbox)) { - state->player.base.flags |= JUMPNRUN_PLAYER_DEAD; + jumpnrun_player_kill(&state->player); } } @@ -206,13 +221,14 @@ void enemy_collision_player_jumpable(jumpnrun_enemy *self, { if(rectangle_intersect(enemy_hitbox(self), &state->player.base.hitbox)) { if(fixed_point_lt(rectangle_top(&state->player.base.hitbox), rectangle_top(enemy_hitbox(self))) && - fixed_point_gt(state->player.base.inertia.y, FIXED_INT(0))) + fixed_point_gt(state->player.base.inertia.y, FIXED_INT(0)) && + jumpnrun_player_alive(&state->player)) { - jumpnrun_enemy_despawn(self); + jumpnrun_enemy_kill(self); player_inertia_mod->y = FIXED_POINT(0, -250); state->player.base.jumpable_frames = 12; } else { - state->player.base.flags |= JUMPNRUN_PLAYER_DEAD; + jumpnrun_player_kill(&state->player); } } } @@ -234,7 +250,7 @@ void enemy_collision_shots_die(struct jumpnrun_enemy *self, if(jumpnrun_shot_spawned(shot)) { if(rectangle_intersect(enemy_hitbox(self), &shot->current_box)) { - self->base.flags &= ~JUMPNRUN_ENEMY_SPAWNED; + jumpnrun_enemy_kill(self); jumpnrun_shot_despawn(shot); } }