Bullets now expire

This commit is contained in:
Bill Rossi 2025-03-01 11:34:51 -05:00
parent 8622d86c2f
commit 62bb35a311
5 changed files with 47 additions and 0 deletions

View File

@ -18,6 +18,7 @@ Entity *spawn_bullet(Vector2 spawn_at) {
Entity *e = malloc(sizeof(Entity)); Entity *e = malloc(sizeof(Entity));
e->name = "Bullet"; e->name = "Bullet";
e->properties = malloc(sizeof(Entity)); e->properties = malloc(sizeof(Entity));
e->timer = 0.5;
BulletProperties *props = (BulletProperties*)e->properties; BulletProperties *props = (BulletProperties*)e->properties;
props->position.x = spawn_at.x; props->position.x = spawn_at.x;
props->position.y = spawn_at.y; props->position.y = spawn_at.y;
@ -38,6 +39,7 @@ void draw_bullet(Entity *e) {
void tick_bullet(Entity *e, float dt) { void tick_bullet(Entity *e, float dt) {
BulletProperties *props = e->properties; BulletProperties *props = e->properties;
e->timer -= dt;
props->position.y += props->velocity.y; props->position.y += props->velocity.y;
} }

View File

@ -18,6 +18,7 @@ Entity *spawn_enemy(void) {
Entity *e = malloc(sizeof(Entity)); Entity *e = malloc(sizeof(Entity));
e->name = "Enemy"; e->name = "Enemy";
e->properties = malloc(sizeof(Entity)); e->properties = malloc(sizeof(Entity));
e->timer = 1.0;
EnemyProperties *props = (EnemyProperties*)e->properties; EnemyProperties *props = (EnemyProperties*)e->properties;
props->position.x = 400; props->position.x = 400;
props->position.y = 50; props->position.y = 50;

15
entity.c Normal file
View File

@ -0,0 +1,15 @@
// Copyright 2025 Bill Rossi
//
// This file is part of Starship Futuretime
//
// Starship Futuretime is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
//
// Starship Futuretime is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License along with Starship Futuretime. If not, see <https://www.gnu.org/licenses/>.
#include "entity.h"
bool entity_expired(Entity *e) {
return e->timer < 0;
}

View File

@ -11,12 +11,16 @@
#ifndef ENTITY_H #ifndef ENTITY_H
#define ENTITY_H #define ENTITY_H
#include <stdbool.h>
#include <stddef.h>
typedef struct Entity Entity; typedef struct Entity Entity;
typedef struct Entities Entities; typedef struct Entities Entities;
struct Entity { struct Entity {
char *name; char *name;
void *properties; void *properties;
float timer;
void (*draw)(Entity *e); void (*draw)(Entity *e);
void (*tick)(Entity *e, float dt); void (*tick)(Entity *e, float dt);
void (*free)(Entity *e); void (*free)(Entity *e);
@ -28,4 +32,6 @@ struct Entities {
size_t capacity; size_t capacity;
}; };
bool entity_expired(Entity *e);
#endif #endif

23
game.c
View File

@ -8,6 +8,7 @@
// //
// You should have received a copy of the GNU General Public License along with Starship Futuretime. If not, see <https://www.gnu.org/licenses/>. // You should have received a copy of the GNU General Public License along with Starship Futuretime. If not, see <https://www.gnu.org/licenses/>.
#include <stdlib.h> #include <stdlib.h>
#include <stdio.h>
#include <stdbool.h> #include <stdbool.h>
#include <raylib.h> #include <raylib.h>
@ -42,6 +43,20 @@ void add_entity(Entities *entities, Entity *e) {
entities->entities[entities->count++] = e; entities->entities[entities->count++] = e;
} }
void remove_entity(Entities *entities, Entity *e) {
size_t i;
for (i = 0; entities->entities[i] != e; i++) {
if (i > entities->count) {
printf("Couldn't find entity %s\n", e->name);
return;
}
}
for (; i < entities->count - 1; i++) {
entities->entities[i] = entities->entities[i + 1];
}
entities->count--;
}
void handle_input(Game *g) { void handle_input(Game *g) {
handle_player_input(g->player); handle_player_input(g->player);
if (IsKeyPressed(KEY_S)) { if (IsKeyPressed(KEY_S)) {
@ -57,11 +72,19 @@ void run_frame(Game *g) {
move_player(g->player); move_player(g->player);
FOREACH_ENEMY { FOREACH_ENEMY {
INIT_ENEMY; INIT_ENEMY;
if (entity_expired(e)) {
remove_entity(g->enemies, e);
continue;
}
e->tick(e, GetFrameTime()); e->tick(e, GetFrameTime());
} }
FOREACH_BULLET { FOREACH_BULLET {
INIT_BULLET; INIT_BULLET;
if (entity_expired(e)) {
remove_entity(g->bullets, e);
continue;
}
e->tick(e, GetFrameTime()); e->tick(e, GetFrameTime());
} }
} }