aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorsalaaad2 <arthurdurant263@gmail.com>2022-01-04 21:17:23 +0100
committersalaaad2 <arthurdurant263@gmail.com>2022-01-04 21:17:23 +0100
commitc9f83a504dc1566543a01dac955d368f8e9ace08 (patch)
treee301466a4f58acb90094507522802c3034f0863b /src
parentadd readme and optimize shooting vectors (diff)
downloadthreshold-c9f83a504dc1566543a01dac955d368f8e9ace08.tar.gz
threshold-c9f83a504dc1566543a01dac955d368f8e9ace08.tar.bz2
threshold-c9f83a504dc1566543a01dac955d368f8e9ace08.tar.xz
threshold-c9f83a504dc1566543a01dac955d368f8e9ace08.tar.zst
threshold-c9f83a504dc1566543a01dac955d368f8e9ace08.zip
two levels. moved shooting logic elsewhere
Diffstat (limited to 'src')
-rw-r--r--src/gameplay.cpp77
-rw-r--r--src/gameplay.hpp5
-rw-r--r--src/main.cpp31
-rw-r--r--src/window.hpp2
4 files changed, 90 insertions, 25 deletions
diff --git a/src/gameplay.cpp b/src/gameplay.cpp
index f52f665..59ef73a 100644
--- a/src/gameplay.cpp
+++ b/src/gameplay.cpp
@@ -28,7 +28,14 @@ Game::Game(std::string const & path)
ifs >> tok;
radius = std::atoi(tok.c_str());
}
+ if (tok == "N")
+ {
+ ifs >> tok;
+ next = tok;
+ std::cout << "next level is " << next;
+ }
}
+ ifs.close();
enemies = new std::vector<Entity>(nEnemies);
for (auto en = enemies->begin(); en != enemies->end(); en++) {
en->radius = radius;
@@ -39,7 +46,7 @@ Game::Game(std::string const & path)
player->direction.x = 100;
player->direction.y = 100;
player->radius = 10;
- ifs.close();
+ player->victims = 0;
}
Game::~Game()
@@ -124,27 +131,12 @@ int Game::getKeys() const
player->direction = Vector2Rotate(player->direction, 0.1f);
}
if (IsKeyPressed(KEY_SPACE)) {
- auto rot1 = Vector2Rotate(player->direction, -0.2f);
- auto rot2 = Vector2Rotate(player->direction, 0.2f);
-
- auto add1 = Vector2Add((Vector2){player->posX, player->posY}, rot1);
- auto add2 = Vector2Add((Vector2){player->posX, player->posY}, rot2);
- for (auto en = enemies->begin(); en != enemies->end(); en++)
- {
- if (CheckCollisionPointLine((Vector2){en->posX, en->posY}, (Vector2){player->posX, player->posY}, add1, (en->radius * 2)) ||
- CheckCollisionPointLine((Vector2){en->posX, en->posY}, (Vector2){player->posX, player->posY}, Vector2Add((Vector2){player->posX, player->posY}, Vector2Rotate(player->direction, 0.0f)), (en->radius * 2)) ||
- CheckCollisionPointLine((Vector2){en->posX, en->posY}, (Vector2){player->posX, player->posY}, add2, (en->radius * 2)))
- {
- std::cout << "hit enemy at " << en->posX << "|" << en->posY
- << std::endl;
- enemies->erase(en);
- player->victims++;
- return (0);
- }
+ if (shoot()) {
+ return (0);
+ }
+ if (player->victims == nEnemies) {
+ return (2);
}
- DrawLineEx((Vector2){player->posX, player->posY}, add1, 10, ORANGE);
- DrawLineEx((Vector2){player->posX, player->posY}, Vector2Add((Vector2){player->posX, player->posY}, player->direction), 10, ORANGE);
- DrawLineEx((Vector2){player->posX, player->posY}, add2, 10, ORANGE);
}
if (player->threshold)
{
@@ -165,3 +157,46 @@ int Game::getKeys() const
DrawLineEx((Vector2){player->posX, player->posY}, Vector2Add((Vector2){player->posX, player->posY}, aimer), 5, GREEN);
return (0);
}
+
+
+int
+Game::shoot() const
+{
+ auto rot1 = Vector2Rotate(player->direction, -0.2f);
+ auto rot2 = Vector2Rotate(player->direction, 0.2f);
+
+ auto add1 = Vector2Add((Vector2){player->posX, player->posY}, rot1);
+ auto add2 = Vector2Add((Vector2){player->posX, player->posY}, rot2);
+ for (auto en = enemies->begin(); en != enemies->end(); en++)
+ {
+ if (CheckCollisionPointLine((Vector2){en->posX, en->posY}, (Vector2){player->posX, player->posY}, add1, (en->radius * 2)) ||
+ CheckCollisionPointLine((Vector2){en->posX, en->posY}, (Vector2){player->posX, player->posY}, Vector2Add((Vector2){player->posX, player->posY}, Vector2Rotate(player->direction, 0.0f)), (en->radius * 2)) ||
+ CheckCollisionPointLine((Vector2){en->posX, en->posY}, (Vector2){player->posX, player->posY}, add2, (en->radius * 2)))
+ {
+ std::cout << "hit enemy at " << en->posX << "|" << en->posY
+ << std::endl;
+ enemies->erase(en);
+ player->victims++;
+ DrawLineEx((Vector2){player->posX, player->posY}, add1, 10,
+ ORANGE);
+ DrawLineEx((Vector2){player->posX, player->posY},
+ Vector2Add((Vector2){player->posX, player->posY},
+ player->direction),
+ 10, ORANGE);
+ DrawLineEx((Vector2){player->posX, player->posY}, add2, 10,
+ ORANGE);
+ return (1);
+ }
+ }
+ DrawLineEx((Vector2){player->posX, player->posY}, add1, 10, ORANGE);
+ DrawLineEx((Vector2){player->posX, player->posY},
+ Vector2Add((Vector2){player->posX, player->posY},
+ player->direction),
+ 10, ORANGE);
+ DrawLineEx((Vector2){player->posX, player->posY}, add2, 10, ORANGE);
+ return (0);
+}
+
+std::string const &
+Game::getNext() const
+{return next;}
diff --git a/src/gameplay.hpp b/src/gameplay.hpp
index 7097995..ccedb0e 100644
--- a/src/gameplay.hpp
+++ b/src/gameplay.hpp
@@ -22,6 +22,8 @@ class Game {
Entity * player;
+ std::string next;
+
public:
Game(std::string const & path);
~Game();
@@ -30,6 +32,9 @@ class Game {
void draw() const ;
int tick() const ;
int getKeys() const ;
+ int shoot() const ;
+
+ std::string const & getNext() const ;
};
#endif // GAMEPLAY_H_
diff --git a/src/main.cpp b/src/main.cpp
index 74b1adf..3136318 100644
--- a/src/main.cpp
+++ b/src/main.cpp
@@ -35,13 +35,31 @@ int main(void) {
{
break ;
}
+ case (NEXT):
+ {
+ if (IsKeyPressed(KEY_ENTER))
+ {
+ gs = TITLE;
+ std::string next("../meta/maps/");
+ next += game->getNext();
+
+ delete game;
+ if (next != "0") {
+ game = new Game(next);
+ }
+ }
+ break ;
+ }
case (ENDING):
{
if (IsKeyPressed(KEY_ENTER))
{
gs = TITLE;
+ auto next = game->getNext();
delete game;
- game = new Game("../meta/maps/stage_1_start.bfm");
+ if (next != "0") {
+ game = new Game("../meta/maps/stage_1_start.bfm");
+ }
}
break ;
}
@@ -59,12 +77,19 @@ int main(void) {
}
case (GAMEPLAY):
{
- if (game->getKeys()) {
- gs = ENDING;
+ if (auto code = game->getKeys()) {
+ if (code == 1)
+ gs = ENDING;
+ else if (code == 2)
+ gs = NEXT;
}
game->draw();
break ;
}
+ case (NEXT):
+ {
+ break ;
+ }
case (ENDING):
{
DrawCircle(SCREENWIDTH / 2, SCREENHEIGHT / 2, 200, BLACK);
diff --git a/src/window.hpp b/src/window.hpp
index 6316bfa..bba7c07 100644
--- a/src/window.hpp
+++ b/src/window.hpp
@@ -17,7 +17,7 @@ int initWindow(void);
#define SCREENHEIGHT 900
typedef enum gameState {
-TITLE = 0, GAMEPLAY, ENDING
+TITLE = 0, GAMEPLAY, NEXT, ENDING
} gameState ;
#endif // WINDOW_H_