aboutsummaryrefslogtreecommitdiffstats
path: root/src/main.cpp
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/main.cpp278
1 files changed, 134 insertions, 144 deletions
diff --git a/src/main.cpp b/src/main.cpp
index a2f616d..d277919 100644
--- a/src/main.cpp
+++ b/src/main.cpp
@@ -6,181 +6,171 @@
/* ()__)____________))))) :^} */
/*********************************/
-
-#include "window.hpp"
-#include "gameplay.hpp"
+#include <raylib.h> // basic libs
#include <iostream>
-#include <raylib.h> // basic libs
+#include "gameplay.hpp"
+#include "window.hpp"
+#include <filesystem> // additional libs
#include <map>
-#include <filesystem> // additional libs
gameState gs = TITLE;
std::map<int, std::string> pick;
int main(void) {
- initWindow();
- InitWindow(SCREENWIDTH, SCREENHEIGHT, "WIP -- muchashooter THRESHOLD");
- auto nPick = 0;
+ initWindow();
+ InitWindow(SCREENWIDTH, SCREENHEIGHT, "WIP -- muchashooter THRESHOLD");
+ auto nPick = 0;
- Game* game = nullptr;
+ Game* game = nullptr;
std::string path = "../meta/maps";
int i = 0;
- for (const auto & entry : std::filesystem::directory_iterator(path)) { // c++17 lol
- if (entry.path().filename().generic_string().find("start") != std::string::npos)
- {
+ for (const auto& entry :
+ std::filesystem::directory_iterator(path)) { // c++17 lol
+ if (entry.path().filename().generic_string().find("start") !=
+ std::string::npos) {
pick[i] = entry.path().filename().generic_string();
i++;
}
}
- // Main game loop
- while (!WindowShouldClose()) /* Detect window close button or ESC key */
- {
- switch (gs) {
- case (TITLE):
- {
- if (IsKeyPressed(KEY_ENTER))
- {
- gs = PICK;
- }
- break ;
- }
- case (PICK):
- {
- if (IsKeyPressed(KEY_ENTER))
- {
- std::string s(path);
- s += "/";
- s += pick[nPick];
- game = new Game(s);
- gs = GAMEPLAY;
- game->start();
- }
- if (IsKeyPressed(KEY_DOWN) && nPick < (pick.size() - 1))
- {
- nPick++;
+ // Main game loop
+ while (!WindowShouldClose()) /* Detect window close button or ESC key */
+ {
+ switch (gs) {
+ case (TITLE): {
+ if (IsKeyPressed(KEY_ENTER)) {
+ gs = PICK;
+ }
+ break;
}
- if (IsKeyPressed(KEY_UP) && nPick > 0)
- {
- nPick--;
+ case (PICK): {
+ if (IsKeyPressed(KEY_ENTER)) {
+ std::string s(path);
+ s += "/";
+ s += pick[nPick];
+ game = new Game(s);
+ gs = GAMEPLAY;
+ game->start();
+ }
+ if (IsKeyPressed(KEY_DOWN) && nPick < (pick.size() - 1)) {
+ nPick++;
+ }
+ if (IsKeyPressed(KEY_UP) && nPick > 0) {
+ nPick--;
+ }
}
- }
- case (DEATH):
- {
- if (IsKeyPressed(KEY_ENTER)) {
- auto current = game->getCurrent();
+ case (DEATH): {
+ if (IsKeyPressed(KEY_ENTER)) {
+ auto current = game->getCurrent();
- delete game;
- CloseAudioDevice();
- game = new Game(current);
- gs = GAMEPLAY;
+ delete game;
+ CloseAudioDevice();
+ game = new Game(current);
+ gs = GAMEPLAY;
+ }
+ break;
}
- break ;
- }
- case (GAMEPLAY):
- {
- break ;
- }
- case (NEXT):
- {
- if (IsKeyPressed(KEY_ENTER))
- {
- std::string next("../meta/maps/");
- next += game->getNext();
+ case (GAMEPLAY): {
+ break;
+ }
+ case (NEXT): {
+ if (IsKeyPressed(KEY_ENTER)) {
+ std::string next("../meta/maps/");
+ next += game->getNext();
- delete game;
- CloseAudioDevice();
- std::cout << "next level " << next << std::endl;
- if (game->getNext() != "0") {
- game = new Game(next);
- gs = GAMEPLAY;
+ delete game;
+ CloseAudioDevice();
+ std::cout << "next level " << next << std::endl;
+ if (game->getNext() != "0") {
+ game = new Game(next);
+ gs = GAMEPLAY;
+ }
}
+ break;
}
- break ;
- }
- case (ENDING):
- {
- if (IsKeyPressed(KEY_ENTER))
- {
- gs = TITLE;
- auto current = game->getCurrent();
- delete game;
- CloseAudioDevice();
- game = new Game(current);
+ case (ENDING): {
+ if (IsKeyPressed(KEY_ENTER)) {
+ gs = TITLE;
+ auto current = game->getCurrent();
+ delete game;
+ CloseAudioDevice();
+ game = new Game(current);
+ }
+ break;
}
- break ;
}
- }
- BeginDrawing();
+ BeginDrawing();
- ClearBackground(COOLPURPLE);
+ ClearBackground(COOLPURPLE);
+ switch (gs) {
+ case (TITLE): {
+ DrawRectangle(200, 100, 1200, 700, RAYWHITE);
+ DrawRectangle(250, 150, 1100, 600, COOLPURPLE);
+ DrawText("THRESHOLD", 260, 160, 30, RAYWHITE);
+ DrawRectangle(300, 200, 1000, 500, RAYWHITE);
+ DrawText("PRESS ENTER", (SCREENWIDTH / 2) - 140,
+ (SCREENHEIGHT / 2) + 50, 40, MAROON);
+ break;
+ }
+ case (PICK): {
+ DrawRectangle(200, 100, 1200, 700, RAYWHITE);
+ DrawRectangle(250, 150, 1100, 600, COOLPURPLE);
+ DrawRectangle(300, 200, 1000, 500, RAYWHITE);
+ DrawText("THRESHOLD", 260, 160, 30, RAYWHITE);
- switch (gs) {
- case (TITLE):
- {
- DrawRectangle(200, 100, 1200, 700, RAYWHITE);
- DrawRectangle(250, 150, 1100, 600, COOLPURPLE);
- DrawText("THRESHOLD", 260, 160, 30, RAYWHITE);
- DrawRectangle(300, 200, 1000, 500, RAYWHITE);
- DrawText("PRESS ENTER", (SCREENWIDTH / 2) - 140, (SCREENHEIGHT / 2) + 50, 40, MAROON);
- break ;
- }
- case (PICK):
- {
- DrawRectangle(200, 100, 1200, 700, RAYWHITE);
- DrawRectangle(250, 150, 1100, 600, COOLPURPLE);
- DrawRectangle(300, 200, 1000, 500, RAYWHITE);
- DrawText("THRESHOLD", 260, 160, 30, RAYWHITE);
-
- DrawRectangle(350, 240 + (nPick * 40), 900, 50, PURPLE);
- for (auto n = 0 ; n < pick.size(); n++)
- {
- DrawText(pick[n].c_str(), 400,
- 240 + (n * 40), 40, COOLPURPLE);
+ DrawRectangle(350, 240 + (nPick * 40), 900, 50, PURPLE);
+ for (auto n = 0; n < pick.size(); n++) {
+ DrawText(pick[n].c_str(), 400, 240 + (n * 40), 40,
+ COOLPURPLE);
+ }
+ break;
}
- break ;
- }
- case (DEATH):
- {
- DrawRectangle(250, 150, 1100, 600, COOLPURPLE);
- ClearBackground(COOLPURPLE);
- DrawCircle(SCREENWIDTH / 2, SCREENHEIGHT / 2, 200, BLACK);
- DrawText("YOU DIED", (SCREENWIDTH / 2) - 200, (SCREENHEIGHT / 2) - 50, 40, WHITE);
- DrawText(game->getCurrent().c_str(), (SCREENWIDTH / 2) - 100, (SCREENHEIGHT / 2) + 50, 40, WHITE);
- break ;
- }
- case (GAMEPLAY):
- {
- if (auto code = game->getKeys()) {
- if (code == 1) // death
- {gs = DEATH;}
- else if (code == 2) // level end
- {gs = NEXT;}
+ case (DEATH): {
+ DrawRectangle(250, 150, 1100, 600, COOLPURPLE);
+ ClearBackground(COOLPURPLE);
+ DrawCircle(SCREENWIDTH / 2, SCREENHEIGHT / 2, 200, BLACK);
+ DrawText("YOU DIED", (SCREENWIDTH / 2) - 200,
+ (SCREENHEIGHT / 2) - 50, 40, WHITE);
+ DrawText(game->getCurrent().c_str(), (SCREENWIDTH / 2) - 100,
+ (SCREENHEIGHT / 2) + 50, 40, WHITE);
+ break;
+ }
+ case (GAMEPLAY): {
+ if (auto code = game->getKeys()) {
+ if (code == 1) // death
+ {
+ gs = DEATH;
+ } else if (code == 2) // level end
+ {
+ gs = NEXT;
+ }
+ }
+ BeginMode2D(game->cam);
+ game->draw();
+ break;
+ }
+ case (NEXT): {
+ ClearBackground(COOLPURPLE);
+ DrawCircle(SCREENWIDTH / 2, SCREENHEIGHT / 2, 200, BLACK);
+ DrawText("STAGE CLEARED\nNEXT LEVEL :\n",
+ (SCREENWIDTH / 2) - 200, (SCREENHEIGHT / 2) - 50, 40,
+ WHITE);
+ DrawText(game->getNext().c_str(), (SCREENWIDTH / 2) - 100,
+ (SCREENHEIGHT / 2) + 60, 40, WHITE);
+ break;
+ }
+ case (ENDING): {
+ DrawCircle(SCREENWIDTH / 2, SCREENHEIGHT / 2, 200, BLACK);
+ DrawText("GOOD BYE", (SCREENWIDTH / 2) - 100, SCREENHEIGHT / 2,
+ 40, WHITE);
+ break;
}
- BeginMode2D(game->cam);
- game->draw();
- break ;
- }
- case (NEXT):
- {
- ClearBackground(COOLPURPLE);
- DrawCircle(SCREENWIDTH / 2, SCREENHEIGHT / 2, 200, BLACK);
- DrawText("STAGE CLEARED\nNEXT LEVEL :\n", (SCREENWIDTH / 2) - 200, (SCREENHEIGHT / 2) - 50, 40, WHITE);
- DrawText(game->getNext().c_str(), (SCREENWIDTH / 2) - 100, (SCREENHEIGHT / 2) + 60, 40, WHITE);
- break ;
- }
- case (ENDING):
- {
- DrawCircle(SCREENWIDTH / 2, SCREENHEIGHT / 2, 200, BLACK);
- DrawText("GOOD BYE", (SCREENWIDTH / 2) - 100, SCREENHEIGHT / 2, 40, WHITE);
- break ;
}
+ EndDrawing();
}
- EndDrawing();
- }
- CloseWindow();
- return 0;
+ CloseWindow();
+ return 0;
}