Compare commits

...

3 Commits

Author SHA1 Message Date
nemo 22a245f9d7 keyboard layout control 2024-09-25 10:23:51 +02:00
nemo 8374c58a9b delta time movement 2024-09-25 10:15:27 +02:00
nemo b5a3b66030 camera shake + refacto 2024-09-25 09:50:25 +02:00
2 changed files with 58 additions and 41 deletions

View File

@ -1,5 +1,5 @@
all: all:
gcc -Wall -Wextra main.c -o voleur -lraylib gcc -Wall -Wextra -ggdb main.c -o voleur -lraylib
release: release:
gcc -Wall -Wextra -O3 -DRELEASE main.c -o voleur -lraylib gcc -Wall -Wextra -O3 -DRELEASE main.c -o voleur -lraylib

97
main.c
View File

@ -1,32 +1,37 @@
#include <stdio.h> #include <stdio.h>
#include "raylib.h" #include "raylib.h"
#define SCREEN_MIDDLE ((Vector2) {window_size.x/2, window_size.y/2})
typedef struct Player { typedef struct Player {
Vector2 screen;
float radius; float radius;
Vector2 coord; Vector2 coord;
} Player; } Player;
typedef struct Map { typedef struct Map {
const Texture texture; const Texture texture;
const Vector2 screen;
const Rectangle box; const Rectangle box;
} Map; } Map;
Camera2D shake(Camera2D cam, int force)
{
cam.offset.x += GetRandomValue(-force/2, force/2);
cam.offset.y += GetRandomValue(-force/2, force/2);
return cam;
}
int main(void) int main(void)
{ {
Vector2 window_size = { 800.0f, 600.0f }; Vector2 window_size = { 800.0f, 600.0f };
Camera2D camera = { Camera2D camera = {
.target = {0}, .target = {0},
.offset = (Vector2) {window_size.x/2, window_size.y/2}, .offset = SCREEN_MIDDLE,
.rotation = 0.0f, .rotation = 0.0f,
.zoom = 1.0f, .zoom = 1.0f,
}; };
Player player = { Player player = {
.screen = (Vector2) {window_size.x/2, window_size.y/2},
.radius = 25.0f, .radius = 25.0f,
}; };
@ -36,67 +41,79 @@ int main(void)
Map map = { Map map = {
.texture = LoadTexture("data/map2.png"), .texture = LoadTexture("data/map2.png"),
.screen = {-map.texture.width/2, -map.texture.height/2},
.box = (Rectangle) { .box = (Rectangle) {
.x = map.screen.x, .y = map.screen.y, .x = -map.texture.width/2, .y = -map.texture.height/2,
.width = map.texture.width, .height = map.texture.height, .width = map.texture.width, .height = map.texture.height,
}, },
}; };
int keyboard_layout_azerty = 1;
while (!WindowShouldClose()) { while (!WindowShouldClose()) {
float DT = GetFrameTime();
if (IsWindowResized()) { if (IsWindowResized()) {
window_size = (Vector2) {GetScreenWidth(), GetScreenHeight()}; window_size = (Vector2) {GetScreenWidth(), GetScreenHeight()};
camera.offset = (Vector2) {window_size.x/2, window_size.y/2}; camera.offset = SCREEN_MIDDLE;
player.screen = (Vector2) {window_size.x/2, window_size.y/2};
} }
float movement_speed = 10.0f; float movement_speed = 10.0f * DT * 50;
if ((IsKeyDown(KEY_LEFT) || IsKeyDown(KEY_RIGHT)) && (IsKeyDown(KEY_UP) || IsKeyDown(KEY_DOWN))) if ((IsKeyDown(KEY_LEFT) || IsKeyDown(KEY_RIGHT)) && (IsKeyDown(KEY_UP) || IsKeyDown(KEY_DOWN)))
movement_speed = 6.324f; movement_speed = 6.324f * DT * 50;
if (IsKeyDown(KEY_LEFT_SHIFT)) if (IsKeyDown(KEY_LEFT_SHIFT))
movement_speed /= 2.0f; movement_speed /= 2.0f;
if (IsKeyDown(KEY_LEFT)) if (keyboard_layout_azerty) {
camera.target.x -= movement_speed ; if (IsKeyDown(KEY_A))
if (IsKeyDown(KEY_RIGHT)) camera.target.x -= movement_speed ;
camera.target.x += movement_speed ; if (IsKeyDown(KEY_D))
if (IsKeyDown(KEY_UP)) camera.target.x += movement_speed ;
camera.target.y -= movement_speed ; if (IsKeyDown(KEY_W))
if (IsKeyDown(KEY_DOWN)) camera.target.y -= movement_speed ;
camera.target.y += movement_speed ; if (IsKeyDown(KEY_S))
camera.target.y += movement_speed ;
} else {
if (IsKeyDown(KEY_Q))
camera.target.x -= movement_speed ;
if (IsKeyDown(KEY_D))
camera.target.x += movement_speed ;
if (IsKeyDown(KEY_Z))
camera.target.y -= movement_speed ;
if (IsKeyDown(KEY_S))
camera.target.y += movement_speed ;
}
if (IsKeyDown(KEY_A)) if (IsKeyReleased(KEY_F))
camera.rotation++; camera.target = player.coord;
if (IsKeyDown(KEY_D)) if (!IsKeyDown(KEY_F)) {
camera.rotation--; player.coord = GetScreenToWorld2D(SCREEN_MIDDLE, camera);
if (IsKeyDown(KEY_W))
player.radius++;
if (IsKeyDown(KEY_S))
player.radius--;
player.coord = GetScreenToWorld2D(player.screen, camera); if (player.coord.x - player.radius < map.box.x)
camera.target.x = map.box.x + player.radius;
else if (player.coord.x + player.radius > map.box.x + map.box.width)
camera.target.x = map.box.x + map.box.width - player.radius;
if (player.coord.x - player.radius < map.box.x) if (player.coord.y - player.radius < map.box.y)
camera.target.x = map.box.x + player.radius; camera.target.y = map.box.y + player.radius;
else if (player.coord.x + player.radius > map.box.x + map.box.width) else if (player.coord.y + player.radius > map.box.y + map.box.height)
camera.target.x = map.box.x + map.box.width - player.radius; camera.target.y = map.box.y + map.box.height - player.radius;
if (player.coord.y - player.radius < map.box.y) player.coord = GetScreenToWorld2D(SCREEN_MIDDLE, camera);
camera.target.y = map.box.y + player.radius; }
else if (player.coord.y + player.radius > map.box.y + map.box.height)
camera.target.y = map.box.y + map.box.height - player.radius; Camera2D effect_camera = camera;
if (IsKeyDown(KEY_SPACE))
effect_camera = shake(camera, 12);
BeginDrawing(); BeginDrawing();
{ {
ClearBackground(LIME); ClearBackground(LIME);
BeginMode2D(camera); BeginMode2D(effect_camera);
{ {
DrawTexture(map.texture, map.screen.x, map.screen.y, WHITE); DrawTexture(map.texture, map.box.x, map.box.y, WHITE);
DrawCircle(player.coord.x, player.coord.y, player.radius, RED);
} }
EndMode2D(); EndMode2D();
DrawCircle(player.screen.x, player.screen.y, player.radius, RED);
} }
EndDrawing(); EndDrawing();
} }