aboutsummaryrefslogtreecommitdiffstats
path: root/src/gameplay.cpp
diff options
context:
space:
mode:
authorsalaaad2 <arthurdurant263@gmail.com>2022-01-05 14:12:14 +0100
committersalaaad2 <arthurdurant263@gmail.com>2022-01-05 14:12:14 +0100
commitc47730c5fc58c33c001cccb132633d598cf8ed96 (patch)
tree8aac1e34e5f1d48fe960e95eb5b3af512fa2e19c /src/gameplay.cpp
parentspawn not random anymore. this got a whole bunch harder (diff)
downloadthreshold-c47730c5fc58c33c001cccb132633d598cf8ed96.tar.gz
threshold-c47730c5fc58c33c001cccb132633d598cf8ed96.tar.bz2
threshold-c47730c5fc58c33c001cccb132633d598cf8ed96.tar.xz
threshold-c47730c5fc58c33c001cccb132633d598cf8ed96.tar.zst
threshold-c47730c5fc58c33c001cccb132633d598cf8ed96.zip
release v0.0.2
Diffstat (limited to '')
-rw-r--r--src/gameplay.cpp54
1 files changed, 34 insertions, 20 deletions
diff --git a/src/gameplay.cpp b/src/gameplay.cpp
index 04facc2..622ff5a 100644
--- a/src/gameplay.cpp
+++ b/src/gameplay.cpp
@@ -89,31 +89,41 @@ void Game::draw() const
// NEW: go towards player NEXT: spawn at different times
int Game::tick() const
{
- for (auto & en : *enemies)
+ for (auto en = enemies->begin(); en != enemies->end(); en++)
{
- if (en.posX >= SCREENWIDTH || en.posX <= 0) {
- en.direction.x = -en.direction.x;
+ if (en->hp != 0)
+ {
+ if (en->posX >= SCREENWIDTH || en->posX <= 0) {
+ en->direction.x = -en->direction.x;
}
- if (en.posY >= SCREENHEIGHT || en.posY <= 0) {
- en.direction.y = -en.direction.y;
+ if (en->posY >= SCREENHEIGHT || en->posY <= 0) {
+ en->direction.y = -en->direction.y;
}
- if (en.posX >= player->posX) {
- en.direction.x -= 0.1f;
+ if (en->posX >= player->posX) {
+ en->direction.x -= 0.1f;
}
- if (en.posY >= player->posY) {
- en.direction.y -= 0.1f;
+ if (en->posY >= player->posY) {
+ en->direction.y -= 0.1f;
}
- if (en.posX <= player->posX) {
- en.direction.x += 0.1f;
+ if (en->posX <= player->posX) {
+ en->direction.x += 0.1f;
}
- if (en.posY <= player->posY) {
- en.direction.y += 0.1f;
+ if (en->posY <= player->posY) {
+ en->direction.y += 0.1f;
}
- en.posX += en.direction.x;
- en.posY += en.direction.y;
- if (CheckCollisionCircles((Vector2){player->posX, player->posY}, 10,
- (Vector2){en.posX, en.posY}, 10)) { // check for player death (one shot one kill)
- return (1);
+ } else {
+ if (en->posX >= SCREENWIDTH || en->posX <= 0 || en->posY >= SCREENHEIGHT ) {
+ enemies->erase(en);
+ return (0);
+ }
+ }
+
+ en->posX += en->direction.x;
+ en->posY += en->direction.y;
+ if (en->hp != 0 && // check for player death (one shot one kill)
+ CheckCollisionCircles((Vector2){player->posX, player->posY}, 10,
+ (Vector2){en->posX, en->posY}, 10)) {
+ return (1);
}
}
return (0);
@@ -163,6 +173,7 @@ int Game::getKeys() const
if (player->victims == nEnemies) {
return (2);
}
+ std::cout << player->victims << "|" << nEnemies << std::endl;
}
if (player->threshold)
{
@@ -207,12 +218,15 @@ Game::shoot() const
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}, Vector2Add((Vector2){player->posX, player->posY}, player->direction), (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);
+ en->hp = 0;
+ en->direction.x = (player->direction.x / 2);
+ en->direction.y = (player->direction.y / 2);
+ // enemies->erase(en);
player->victims++;
player->fury++;
DrawLineEx((Vector2){player->posX, player->posY}, add1, 10,