diff options
author | salaaad2 <arthurdurant263@gmail.com> | 2022-01-05 14:12:14 +0100 |
---|---|---|
committer | salaaad2 <arthurdurant263@gmail.com> | 2022-01-05 14:12:14 +0100 |
commit | c47730c5fc58c33c001cccb132633d598cf8ed96 (patch) | |
tree | 8aac1e34e5f1d48fe960e95eb5b3af512fa2e19c /src | |
parent | spawn not random anymore. this got a whole bunch harder (diff) | |
download | threshold-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 'src')
-rw-r--r-- | src/gameplay.cpp | 54 | ||||
-rw-r--r-- | src/main.cpp | 2 |
2 files changed, 35 insertions, 21 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, diff --git a/src/main.cpp b/src/main.cpp index 48a24f8..52db18e 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -45,7 +45,7 @@ int main(void) { delete game; CloseAudioDevice(); - if (next != "0") { + if (game->getNext() != "0") { game = new Game(next); } } |