summaryrefslogtreecommitdiff
path: root/Week1-Pacman/src/pacman.c
diff options
context:
space:
mode:
Diffstat (limited to 'Week1-Pacman/src/pacman.c')
-rw-r--r--Week1-Pacman/src/pacman.c67
1 files changed, 62 insertions, 5 deletions
diff --git a/Week1-Pacman/src/pacman.c b/Week1-Pacman/src/pacman.c
index f3a4769..de9774d 100644
--- a/Week1-Pacman/src/pacman.c
+++ b/Week1-Pacman/src/pacman.c
@@ -1,10 +1,13 @@
#include <SDL2/SDL.h>
#include <stdbool.h>
#include "pacman.h"
+#include "collision.h"
#define PACMAN_SPEED 261
#define PACMAN_SIDE 40
+SDL_Rect* get_colliding_tile(struct pacman* pacman, struct map* map);
+
void handle_pacman_input(SDL_Event* e, struct pacman* pacman) {
if(e->type == SDL_KEYDOWN) {
@@ -25,19 +28,56 @@ void handle_pacman_input(SDL_Event* e, struct pacman* pacman) {
}
}
-void update_pacman(struct pacman* pacman, float dt) {
-
+void update_pacman(struct pacman* pacman, float dt, struct map* map) {
if(pacman->facing == FACING_UP) {
pacman->ypos -= PACMAN_SPEED * dt;
+
+ SDL_Rect* colliding_tile =
+ get_colliding_tile(pacman, map);
+
+ if(colliding_tile != NULL) {
+ pacman->ypos =
+ colliding_tile->y + colliding_tile->h;
+ } else {
+ update_animation(&pacman->animations[pacman->facing], dt);
+ }
} else if(pacman->facing == FACING_DOWN) {
pacman->ypos += PACMAN_SPEED * dt;
+
+ SDL_Rect* colliding_tile =
+ get_colliding_tile(pacman, map);
+
+ if(colliding_tile != NULL) {
+ pacman->ypos =
+ colliding_tile->y - PACMAN_SIDE;
+ } else {
+ update_animation(&pacman->animations[pacman->facing], dt);
+ }
} else if(pacman->facing == FACING_LEFT) {
pacman->xpos -= PACMAN_SPEED * dt;
- } else {
+
+ SDL_Rect* colliding_tile =
+ get_colliding_tile(pacman, map);
+
+ if(colliding_tile != NULL) {
+ pacman->xpos =
+ colliding_tile->x + colliding_tile->w;
+ } else {
+ update_animation(&pacman->animations[pacman->facing], dt);
+ }
+ } else if(pacman->facing == FACING_RIGHT) {
pacman->xpos += PACMAN_SPEED * dt;
- }
- update_animation(&pacman->animations[pacman->facing], dt);
+ SDL_Rect* colliding_tile =
+ get_colliding_tile(pacman, map);
+
+ if(colliding_tile != NULL) {
+ pacman->xpos =
+ colliding_tile->x - PACMAN_SIDE;
+ } else {
+ update_animation(&pacman->animations[pacman->facing], dt);
+ }
+ }
}
void draw_pacman(struct demo* demo, const struct pacman* pacman) {
@@ -53,3 +93,20 @@ void draw_pacman(struct demo* demo, const struct pacman* pacman) {
draw_animation(demo, current_animation, &d_rect);
}
+
+SDL_Rect* get_colliding_tile(struct pacman* pacman, struct map* map) {
+ SDL_Rect r = (SDL_Rect){
+ .x = pacman->xpos,
+ .y = pacman->ypos,
+ .w = PACMAN_SIDE,
+ .h = PACMAN_SIDE
+ };
+
+ for(int i = 0; i < map->collider_count; i++) {
+ if(is_colliding(&r, &map->colliders[i])) {
+ return &map->colliders[i];
+ }
+ }
+
+ return NULL;
+}