From 294c5e8e8af72ade357bf3d786662e587ce85b1b Mon Sep 17 00:00:00 2001 From: Kaehvaman Date: Thu, 12 Dec 2024 15:02:30 +0400 Subject: [PATCH] editMap --- lab16 with raylib/resources/savefile.txt | 20 +-- lab16 with raylib/src/main.c | 150 ++++++++++++++++------- 2 files changed, 115 insertions(+), 55 deletions(-) diff --git a/lab16 with raylib/resources/savefile.txt b/lab16 with raylib/resources/savefile.txt index b3b05d2..2c55229 100644 --- a/lab16 with raylib/resources/savefile.txt +++ b/lab16 with raylib/resources/savefile.txt @@ -1,13 +1,13 @@ -10 25 +10 15 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 +0 0 0 0 0 0 0 3 0 0 0 0 0 0 0 +0 0 0 0 0 0 3 3 3 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 +0 0 0 0 0 0 3 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 -0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 -0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 -0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 -0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 -0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 -0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 -0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 -0 0 9 34 -3 4 2 +0 0 0 0 0 0 0 3 0 0 0 0 0 0 0 +0 0 0 0 3 0 0 3 3 0 0 0 0 0 0 +0 0 0 0 3 0 0 0 3 0 0 0 0 0 0 +0 0 0 0 3 3 3 0 0 0 3 0 0 0 0 +0 0 25 37 +3 3 3 diff --git a/lab16 with raylib/src/main.c b/lab16 with raylib/src/main.c index 571566c..1b55e65 100644 --- a/lab16 with raylib/src/main.c +++ b/lab16 with raylib/src/main.c @@ -3,18 +3,20 @@ #include #include "raylib.h" #include "raymath.h" +#include "resource_dir.h" #define RAYGUI_IMPLEMENTATION #include "raygui.h" -#include "resource_dir.h" - #define M 10 #define N 15 #define HEIGHT 50 #define WIDTH 50 #define VOFFSET 50 +#define FWIDTH (float)WIDTH +#define FHEIGHT (float)HEIGHT + #define PUREBLUE (Color) { 0, 0, 255, 255 } #define BLACKGRAY (Color) {30, 30, 30, 255} #define VSGRAY (Color) {78, 201, 176, 255} @@ -137,11 +139,11 @@ void doMidashand() { bool netToggle = false; void drawNet() { - for (int i = 0; i <= N * WIDTH; i = i + WIDTH) { + for (int i = 0; i <= N * WIDTH; i += WIDTH) { DrawLine(i, 0, i, M * HEIGHT, BLACK); } - for (int i = 0; i <= M * HEIGHT; i = i + HEIGHT) { + for (int i = 0; i <= M * HEIGHT; i += HEIGHT) { DrawLine(0, i, N * WIDTH, i, BLACK); } } @@ -256,9 +258,58 @@ void load() { fclose(fin); } +bool editMap = 0; void handleKeys() { + + /*if (IsKeyPressedRepeat(KEY_W)) movePlayer(up); + if (IsKeyPressedRepeat(KEY_S)) movePlayer(down); + if (IsKeyPressedRepeat(KEY_D)) movePlayer(right); + if (IsKeyPressedRepeat(KEY_A)) movePlayer(left);*/ + int key; while (key = GetKeyPressed()) { + if (not editMap) { + switch (key) + { + case KEY_W: + movePlayer(up); + break; + case KEY_S: + movePlayer(down); + break; + case KEY_D: + movePlayer(right); + break; + case KEY_A: + movePlayer(left); + break; + case KEY_ONE: + stomp(1); + break; + case KEY_TWO: + stomp(2); + break; + case KEY_Z: + deathbeam(right); + break; + case KEY_M: + doMidashand(); + break; + case KEY_LEFT: + putElement(left, selected_element); + break; + case KEY_RIGHT: + putElement(right, selected_element); + break; + case KEY_UP: + putElement(up, selected_element); + break; + case KEY_DOWN: + putElement(down, selected_element); + break; + } + } + switch (key) { case KEY_F5: @@ -270,52 +321,18 @@ void handleKeys() { case KEY_SPACE: netToggle = !netToggle; break; - case KEY_W: - movePlayer(up); - break; - case KEY_S: - movePlayer(down); - break; - case KEY_D: - movePlayer(right); - break; - case KEY_A: - movePlayer(left); - break; - case KEY_ONE: - stomp(1); - break; - case KEY_TWO: - stomp(2); - break; - case KEY_Z: - deathbeam(right); - break; - case KEY_M: - doMidashand(); + case KEY_ENTER: + editMap = !editMap; break; case KEY_G: if (selected_element == gold) selected_element = wall; else selected_element = gold; break; - case KEY_LEFT: - putElement(left, selected_element); - break; - case KEY_RIGHT: - putElement(right, selected_element); - break; - case KEY_UP: - putElement(up, selected_element); - break; - case KEY_DOWN: - putElement(down, selected_element); - break; } } } - -#define CDPSIZE 213 +#define CPSIZE 213 int main() { //SetConfigFlags(FLAG_WINDOW_HIGHDPI); @@ -325,25 +342,47 @@ int main() { SearchAndSetResourceDir("resources"); - int codepoints[CDPSIZE] = { 0 }; + int codepoints[CPSIZE] = { 0 }; for (int i = 0; i < 127 - 32; i++) codepoints[i] = 32 + i; // Basic ASCII characters for (int i = 0; i < 118; i++) codepoints[95 + i] = 1024 + i; // Cyrillic characters //Font InconsolataRegular = LoadFontEx("Inconsolata-Regular.ttf", 24, NULL, 0); //Font InconsolataSemiBold = LoadFontEx("Inconsolata-SemiBold.ttf", 48, codepoints, 512); - Font InconsolataBold = LoadFontEx("Inconsolata-LGC-Bold.ttf", 48, codepoints, CDPSIZE); + Font InconsolataBold = LoadFontEx("Inconsolata-LGC-Bold.ttf", 48, codepoints, CPSIZE); SetTextureFilter(InconsolataBold.texture, TEXTURE_FILTER_BILINEAR); //GuiSetFont(InconsolataBold); + Vector2 mousePos = { 0 }; + int mouseCellX = 0; + int mouseCellY = 0; + // game loop while (!WindowShouldClose()) // run the loop untill the user presses ESCAPE or presses the Close button on the window { + //------------------------------------------------------------------ + // Update + //------------------------------------------------------------------ handleKeys(); + mousePos = GetMousePosition(); - // drawing + if (editMap) { + mouseCellX = (int)(Clamp(mousePos.x, 0, FWIDTH * N - 1) / WIDTH); + mouseCellY = (int)(Clamp(mousePos.y, 0, FHEIGHT * M - 1) / HEIGHT); + + if (IsMouseButtonDown(MOUSE_BUTTON_LEFT) and not(mouseCellX == player_x and mouseCellY == player_y)) { + map[mouseCellY][mouseCellX] = selected_element; + } + else if (IsMouseButtonDown(MOUSE_BUTTON_RIGHT)) { + map[mouseCellY][mouseCellX] = empty; + } + + } + + //------------------------------------------------------------------ + // Draw + //------------------------------------------------------------------ BeginDrawing(); - // Setup the back buffer for drawing (clear color and depth buffers) ClearBackground(WHITE); @@ -351,10 +390,31 @@ int main() { drawPlayer(); drawBottomBar(InconsolataBold, 24); + if (editMap) { + Rectangle rec = { + mouseCellX * FWIDTH, + mouseCellY * FHEIGHT, + FWIDTH, FHEIGHT + }; + + Color color = { 0, 0, 0, 255 }; + if (mouseCellX == player_x and mouseCellY == player_y) { + color.r = 255; + } + else { + color.g = 255; + } + + DrawRectangleLinesEx(rec, 2, color); + } + if (netToggle) { drawNet(); } + // show mouse position + //DrawText(TextFormat("%.1f %.1f", mousePos.x, mousePos.y), 5, M * HEIGHT - 30, 30, ORANGE); + // show FPS and frametime //DrawText(TextFormat("%2d FPS", GetFPS()), 0, 0, 34, ORANGE); //DrawText(TextFormat("%4f ms", GetFrameTime()), 0, 34, 34, BEIGE);