aboutsummaryrefslogtreecommitdiff
path: root/source/render.c
diff options
context:
space:
mode:
authorEmil Williams2026-02-11 22:40:44 +0000
committerEmil Williams2026-02-14 00:52:41 +0000
commitdc655ac2079e0eea55c56b6712bf6a2167b57845 (patch)
tree1006f06ddda24c87ffdf549ab7639c89703cc9fb /source/render.c
parentcd111fbabfa1f84c9c9aa35f1242d4edbec15b22 (diff)
downloadMonobomberman-dc655ac2079e0eea55c56b6712bf6a2167b57845.tar.xz
Monobomberman-dc655ac2079e0eea55c56b6712bf6a2167b57845.tar.zst
primitive implementation
added movement, explosions, the conception of death, and bugs
Diffstat (limited to 'source/render.c')
-rw-r--r--source/render.c76
1 files changed, 76 insertions, 0 deletions
diff --git a/source/render.c b/source/render.c
new file mode 100644
index 0000000..5af04f8
--- /dev/null
+++ b/source/render.c
@@ -0,0 +1,76 @@
+#include "all.h"
+
+static void RenderTiles(game_t * game);
+static void RenderPlayers(game_t * game);
+static void RenderBombs(game_t * game);
+
+void Render(game_t * game, f64 interpolation) {
+ (void)game;
+ (void)interpolation;
+
+ BeginDrawing();
+ ClearBackground(BLACK);
+ BeginMode2D(game->camera);
+ RenderTiles(game);
+ RenderBombs(game);
+ RenderPlayers(game);
+ EndMode2D();
+ /* --- */
+ rlDrawRenderBatchActive();
+ SwapScreenBuffer();
+}
+
+void RenderTiles(game_t * game) {
+ for (int i = 0; i < game->config.map_x; ++i) {
+ for (int j = 0; j < game->config.map_y; ++j) {
+ if ((game->tiles.state[i][j]._ | 1) & PASSIBLE || game->tiles.state[i][j]._ == IMPASSIBLE_NOTHING) {
+ DrawRectangleRec((Rectangle) {i*game->config.spritesheet_scale, j*game->config.spritesheet_scale, game->config.spritesheet_scale, game->config.spritesheet_scale}, COLOR_TO_RAYLIB(game->tiles.color));
+ }
+
+ if (game->tiles.state[i][j]._ < 2) {
+ DrawTextureRec(
+ game->spritesheet,
+ game->tiles.wall[game->tiles.state[i][j].texture],
+ (Vector2) {i*game->config.spritesheet_scale, j*game->config.spritesheet_scale},
+ COLOR_TO_RAYLIB(game->tiles.color));
+ }
+
+ /* This almost requires horrible no good melding. Almost. */
+ if (game->tiles.state[i][j]._ & EXPLOSIVE) {
+ DrawTextureRec(
+ game->spritesheet,
+ game->tiles.explosion[game->tiles.state[i][j].texture],
+ (Vector2) {i*game->config.spritesheet_scale, j*game->config.spritesheet_scale},
+ WHITE);
+ }
+
+
+ }
+ }
+}
+
+void RenderPlayers(game_t * game) {
+ for (int i = 0; i < PLAYER_LIMIT; ++i) {
+ if (game->players.state[i].alive) {
+ DrawTextureRec(
+ game->spritesheet,
+ game->players.player[game->players.state[i].direction],
+ (Vector2) {game->players.x[i] * game->config.spritesheet_scale, game->players.y[i] * game->config.spritesheet_scale},
+ COLOR_TO_RAYLIB(game->players.color[i]));
+ }
+ }
+}
+
+void RenderBombs(game_t * game) {
+ for (int i = 0; i < PLAYER_LIMIT; ++i) {
+ for (int j = 0; j < PLAYER_LIMIT; ++j) {
+ if (game->bombs.timer[i][j]) {
+ DrawTextureRec(
+ game->spritesheet,
+ game->bombs.bomb[game->bombs.timer[i][j] % 4],
+ (Vector2) {game->bombs.x[i][j]*game->config.spritesheet_scale, game->bombs.y[i][j]*game->config.spritesheet_scale},
+ COLOR_TO_RAYLIB(game->bombs.color[game->bombs.timer[i][j]%2]));
+ }
+ }
+ }
+}