summaryrefslogtreecommitdiff
path: root/main.c
diff options
context:
space:
mode:
authorJuan Manuel Tomas <jtomas1815@gmail.com>2022-01-20 04:56:45 -0300
committerJuan Manuel Tomas <jtomas1815@gmail.com>2022-01-20 04:56:45 -0300
commit9384448fd3e54d9d787d7c35bc1069487ab07d88 (patch)
tree9e77f745047ab62b320a87befb818798989f3f11 /main.c
parent53ab36dc7b21f6bb5ebed3130fb026b0779122fe (diff)
downloadcannons-9384448fd3e54d9d787d7c35bc1069487ab07d88.tar.gz
cannons-9384448fd3e54d9d787d7c35bc1069487ab07d88.zip
Separate most platform code into separate file
Diffstat (limited to 'main.c')
-rw-r--r--main.c102
1 files changed, 13 insertions, 89 deletions
diff --git a/main.c b/main.c
index ebca8cf..9d53b94 100644
--- a/main.c
+++ b/main.c
@@ -1,12 +1,9 @@
#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
-#include <SDL2/SDL.h>
+#include "platform.c"
-#define WINDOW_W 1280
-#define WINDOW_H 720
-
-void editMask(float *mask, float x, float y, float color, float size) {
+void PaintMask(float *mask, float x, float y, float color, float size) {
for (int j = y - size / 2; j < y + size / 2; j++) {
for (int i = x - size / 2; i < x + size / 2; i++) {
if (i > 0 && i < WINDOW_W && j > 0 && j < WINDOW_H) {
@@ -17,59 +14,12 @@ void editMask(float *mask, float x, float y, float color, float size) {
}
}
-SDL_Texture *createTiledTexture(SDL_Renderer *context, const char *filename) {
- SDL_Surface *texture_surface = SDL_LoadBMP(filename);
- SDL_Texture *texture_tile = SDL_CreateTextureFromSurface(context, texture_surface);
- int tile_w = texture_surface->w;
- int tile_h = texture_surface->h;
- SDL_FreeSurface(texture_surface);
-
- SDL_Texture *texture = SDL_CreateTexture(context,
- SDL_PIXELFORMAT_RGBA8888,
- SDL_TEXTUREACCESS_TARGET,
- WINDOW_W, WINDOW_H);
- SDL_SetRenderTarget(context, texture);
- for (int y = 0; y < WINDOW_H; y += tile_h) {
- for (int x = 0; x < WINDOW_W; x += tile_w) {
- SDL_Rect tile_rect = { x, y, tile_w, tile_h };
- SDL_RenderCopy(context, texture_tile, 0, &tile_rect);
- }
- }
- SDL_DestroyTexture(texture_tile);
- SDL_SetRenderTarget(context, 0);
- return texture;
-}
-
-int main() {
- SDL_Init(SDL_INIT_VIDEO);
-
- SDL_Window *window = SDL_CreateWindow("Cannons",
- SDL_WINDOWPOS_UNDEFINED,
- SDL_WINDOWPOS_UNDEFINED,
- WINDOW_W,
- WINDOW_H,
- 0);
-
- SDL_Renderer *context = SDL_CreateRenderer(window, -1, SDL_RENDERER_ACCELERATED);
-
- SDL_Texture *background = createTiledTexture(context, "background.bmp");
-
- SDL_Texture *foreground = createTiledTexture(context, "foreground.bmp");
- SDL_SetTextureBlendMode(foreground, SDL_BLENDMODE_MOD);
-
- SDL_Texture *terrain = SDL_CreateTexture(context,
- SDL_PIXELFORMAT_RGBA8888,
- SDL_TEXTUREACCESS_TARGET,
- WINDOW_W, WINDOW_H);
- SDL_SetTextureBlendMode(terrain, SDL_BLENDMODE_BLEND);
-
+void GameMain() {
// Terrain generation
float *mask = calloc(WINDOW_W * WINDOW_H, sizeof(float));
- for (int i = 500 * WINDOW_W; i < WINDOW_W * WINDOW_H; i++) {
+ for (int i = 0; i < 100 * WINDOW_W; i++) {
mask[i] = 1.0;
}
- SDL_Surface *mask_surface = SDL_CreateRGBSurfaceWithFormat(0,
- WINDOW_W, WINDOW_H, 32, SDL_PIXELFORMAT_RGBA8888);
// Player variables
float player_x = 100;
@@ -83,7 +33,7 @@ int main() {
// Event handling
int exit = 0;
while (!exit) {
- SDL_Event event = {0};
+ SDL_Event event;
while (SDL_PollEvent(&event)) {
if (event.type == SDL_QUIT) {
exit = 1;
@@ -93,39 +43,18 @@ int main() {
Uint32 mouse_state = SDL_GetMouseState(&mouse_x, &mouse_y);
float size = 100;
if (mouse_state & SDL_BUTTON_LMASK) {
- editMask(mask, mouse_x, mouse_y, 1.0, size);
+ PaintMask(mask, mouse_x, WINDOW_H - mouse_y, 1.0, size);
} else if (mouse_state & SDL_BUTTON_RMASK) {
- editMask(mask, mouse_x, mouse_y, 0.0, size);
- }
-
- // Main loop
- SDL_SetRenderDrawColor(context, 40, 40, 40, 255);
- SDL_RenderClear(context);
-
- SDL_RenderCopy(context, background, 0, 0);
-
- SDL_LockSurface(mask_surface);
- for (int i = 0; i < mask_surface->w * mask_surface->h; i++) {
- ((Uint32 *)mask_surface->pixels)[i] = mask[i] ? 0xffffffff : 0x00000000;
+ PaintMask(mask, mouse_x, WINDOW_H - mouse_y, 0.0, size);
}
- SDL_UnlockSurface(mask_surface);
- SDL_Texture *mask_texture = SDL_CreateTextureFromSurface(context, mask_surface);
- SDL_SetRenderTarget(context, terrain);
- SDL_SetRenderDrawColor(context, 0, 0, 0, 0);
- SDL_RenderClear(context);
- SDL_RenderCopy(context, mask_texture, 0, 0);
- SDL_RenderCopy(context, foreground, 0, 0);
- SDL_SetRenderTarget(context, 0);
- SDL_RenderCopy(context, terrain, 0, 0);
- SDL_DestroyTexture(mask_texture);
// Time delta calculation
- double new_t = (double) SDL_GetTicks64() / 1000.0;
+ double new_t = GetCurrentTimestamp();
double dt = new_t - old_t;
old_t = new_t;
// Player logic
- if (mask[(int)player_x + (WINDOW_H - (int)player_y) * WINDOW_W] == 0.0) {
+ if (mask[(int)player_x + (int)player_y * WINDOW_W] == 0.0) {
player_y += player_vy * dt;
player_vy += player_ay * dt;
} else {
@@ -133,17 +62,12 @@ int main() {
player_vy = 0;
}
- // Draw player
- SDL_SetRenderDrawColor(context, 255, 0, 0, 255);
- SDL_Rect player_rect = {player_x - 5, WINDOW_H - player_y - 10, 10, 10 };
- SDL_RenderFillRect(context, &player_rect);
-
- SDL_RenderPresent(context);
+ RenderScene(mask, player_x, player_y);
SDL_Delay(1);
}
+}
- SDL_DestroyRenderer(context);
- SDL_DestroyWindow(window);
- SDL_Quit();
+int main() {
+ PlatformMain(GameMain);
return 0;
}