diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/game.c | 30 | ||||
-rw-r--r-- | src/local.mk | 3 | ||||
-rw-r--r-- | src/paddle.c | 16 | ||||
-rw-r--r-- | src/paddle.h | 7 | ||||
-rw-r--r-- | src/player.c | 2 |
5 files changed, 32 insertions, 26 deletions
@@ -4,6 +4,7 @@ #include "game.h" #include "player.h" +#include "paddle.h" static void draw_paddles(struct game *g); static void wait(struct game *g); @@ -83,31 +84,10 @@ input(struct game *g) static void update(struct game *g) { - struct paddle *pad; - - /* Player 1 horizontal paddle */ - pad = &g->players[0]->paddle_h; - pad->pos += pad->speed * pad->dir; - if (pad->pos < pad->size / 2 + 2) pad->pos = pad->size / 2 + 2; - if (pad->pos > 78 - pad->size / 2) pad->pos = 78 - pad->size / 2; - - /* Player 1 vertical paddle */ - pad = &g->players[0]->paddle_v; - pad->pos += pad->speed * pad->dir; - if (pad->pos < pad->size / 2 + 2) pad->pos = pad->size / 2 + 2; - if (pad->pos > 23 - pad->size / 2) pad->pos = 23 - pad->size / 2; - - /* Player 2 horizontal paddle */ - pad = &g->players[1]->paddle_h; - pad->pos += pad->speed * pad->dir; - if (pad->pos < pad->size / 2 + 2) pad->pos = pad->size / 2 + 2; - if (pad->pos > 78 - pad->size / 2) pad->pos = 78 - pad->size / 2; - - /* Player 2 vertical paddle */ - pad = &g->players[1]->paddle_v; - pad->pos += pad->speed * pad->dir; - if (pad->pos < pad->size / 2 + 2) pad->pos = pad->size / 2 + 2; - if (pad->pos > 23 - pad->size / 2) pad->pos = 23 - pad->size / 2; + update_paddle(&g->players[0]->paddle_h); + update_paddle(&g->players[0]->paddle_v); + update_paddle(&g->players[1]->paddle_h); + update_paddle(&g->players[1]->paddle_v); } static void diff --git a/src/local.mk b/src/local.mk index 199d4e5..3f3338d 100644 --- a/src/local.mk +++ b/src/local.mk @@ -1,4 +1,5 @@ src_SOURCES = \ src/main.c \ src/game.c \ - src/player.c + src/player.c \ + src/paddle.c diff --git a/src/paddle.c b/src/paddle.c new file mode 100644 index 0000000..57cdbb5 --- /dev/null +++ b/src/paddle.c @@ -0,0 +1,16 @@ +#include "paddle.h" + +void +update_paddle(struct paddle *pad) +{ + int max; + + pad->pos += pad->speed * pad->dir; + if (pad->type == PADDLE_TYPE_H) { + max = 78; + } else { + max = 23; + } + if (pad->pos < pad->size / 2 + 2) pad->pos = pad->size / 2 + 2; + if (pad->pos > max - pad->size / 2) pad->pos = max - pad->size / 2; +} diff --git a/src/paddle.h b/src/paddle.h index 5f7de67..46891ba 100644 --- a/src/paddle.h +++ b/src/paddle.h @@ -7,12 +7,19 @@ static const int PADDLE_H_SIZE_NORMAL = 8; static const int PADDLE_V_SIZE_NORMAL = 4; static const int PADDLE_H_SPEED_NORMAL = 2; static const int PADDLE_V_SPEED_NORMAL = 1; +enum paddle_type { + PADDLE_TYPE_H, + PADDLE_TYPE_V +}; struct paddle { int pos; int size; int speed; int dir; + int type; }; +void update_paddle(struct paddle *pad); + #endif diff --git a/src/player.c b/src/player.c index a0cf7bb..ad0166a 100644 --- a/src/player.c +++ b/src/player.c @@ -22,6 +22,8 @@ new_player(void) p->paddle_v.speed = PADDLE_V_SPEED_NORMAL; p->paddle_h.dir = 0; p->paddle_v.dir = 0; + p->paddle_h.type = PADDLE_TYPE_H; + p->paddle_v.type = PADDLE_TYPE_V; return p; } |