From 4e266c0e8f0b49cb39f3f2c3bc43d0bc09cc3aca Mon Sep 17 00:00:00 2001 From: salaaad2 Date: Wed, 5 Jan 2022 21:42:26 +0100 Subject: reload works --- src/gameplay.cpp | 23 ++++++++++++++++------- 1 file changed, 16 insertions(+), 7 deletions(-) (limited to 'src/gameplay.cpp') diff --git a/src/gameplay.cpp b/src/gameplay.cpp index d732a48..9e37221 100644 --- a/src/gameplay.cpp +++ b/src/gameplay.cpp @@ -59,7 +59,6 @@ Game::~Game() { delete enemies; delete player; - delete terrain; } void Game::start() @@ -87,7 +86,7 @@ void Game::draw() const DrawCircleV((Vector2){en.posX, en.posY}, en.radius, DARKBLUE); } // Destination rectangle (screen rectangle where drawing part of texture) - Rectangle destRec = { player->posX, player->posY, frameWidth * 1.4f, frameHeight * 1.4f }; + Rectangle destRec = { player->posX, player->posY, frameWidth * 1.8f, frameHeight * 1.8f }; // Origin of the texture (rotation/scale point), it's relative to destination rectangle size DrawTexturePro(player->tex, sourceRec, destRec, origin, Vector2Angle((Vector2){0.0f, 0.0f}, player->direction), WHITE); @@ -101,7 +100,7 @@ void Game::draw() const // progress the game & check for player death -// NEW: go towards player NEXT: spawn at different times +// NEW: go towards player NEXT: spawn at different furyTimes int Game::tick() const { for (auto en = enemies->begin(); en != enemies->end(); en++) @@ -170,7 +169,7 @@ int Game::getKeys() const } if (player->fury >= 5 && IsKeyDown(KEY_E)) { - player->time = GetTime(); + player->furyTime = GetTime(); player->threshold = true; player->fury = 0; @@ -192,7 +191,7 @@ int Game::getKeys() const } if (player->threshold) { - if (GetTime() >= (player->time + 5)) + if (GetTime() >= (player->furyTime + 5)) { player->fury = 0; player->threshold = false; @@ -209,6 +208,13 @@ int Game::getKeys() const return (1); } } + if (player->wp->empty) { + if (GetTime() >= (player->reloadTime + 2)) + { + player->wp->refill(); + player->wp->empty = false; + } + } aimer.x = (player->direction.x / 3); aimer.y = (player->direction.y / 3); DrawLineEx((Vector2){player->posX, player->posY}, Vector2Add((Vector2){player->posX, player->posY}, aimer), 5, GREEN); @@ -225,10 +231,13 @@ Game::shoot() const auto add1 = Vector2Add((Vector2){player->posX, player->posY}, rot1); auto add2 = Vector2Add((Vector2){player->posX, player->posY}, rot2); + if (player->wp->empty == true) { + return (0); + } if (player->wp->bang() == 1) { + player->wp->empty = true; + player->reloadTime = GetTime(); return (0); - } else { - player->wp->bang(); } for (auto en = enemies->begin(); en != enemies->end(); en++) { -- cgit v1.2.3