diff options
Diffstat (limited to '')
-rw-r--r-- | src/gameplay.cpp | 2 | ||||
-rw-r--r-- | src/weapon.hpp | 2 | ||||
-rw-r--r-- | src/wp_assaultrifle.cpp | 12 | ||||
-rw-r--r-- | src/wp_assaultrifle.hpp | 2 | ||||
-rw-r--r-- | src/wp_shotty.cpp | 9 | ||||
-rw-r--r-- | src/wp_shotty.hpp | 2 |
6 files changed, 18 insertions, 11 deletions
diff --git a/src/gameplay.cpp b/src/gameplay.cpp index 0fdc67c..6180ae4 100644 --- a/src/gameplay.cpp +++ b/src/gameplay.cpp @@ -277,7 +277,7 @@ Game::shoot() const if (player->currentWeapon->empty == true) { return (0); } - player->currentWeapon->bang(enemies, player->direction, (Vector2){player->posX, player->posY}, &player->victims); + player->currentWeapon->bang(enemies, player); if (player->currentWeapon->empty == true) { player->reloadTime = GetTime(); } diff --git a/src/weapon.hpp b/src/weapon.hpp index 36ac542..447cfe5 100644 --- a/src/weapon.hpp +++ b/src/weapon.hpp @@ -38,7 +38,7 @@ public: const char *r); ~AWeapon(); - virtual int bang(std::vector<Entity> * enemies, Vector2 playerDirection, Vector2 playerPosition, int * victims) = 0; + virtual int bang(std::vector<Entity> * enemies, Entity * player) = 0; void refill(); bool empty; diff --git a/src/wp_assaultrifle.cpp b/src/wp_assaultrifle.cpp index 7438b23..6b9a2c7 100644 --- a/src/wp_assaultrifle.cpp +++ b/src/wp_assaultrifle.cpp @@ -12,7 +12,7 @@ wp_assaultrifle::wp_assaultrifle(const char *s, const char *r) -int wp_assaultrifle::bang(std::vector<Entity> * enemies, Vector2 playerDirection, Vector2 playerPosition, int * victims) +int wp_assaultrifle::bang(std::vector<Entity> * enemies, Entity * player) { if (barrel == 0) { @@ -22,6 +22,8 @@ int wp_assaultrifle::bang(std::vector<Entity> * enemies, Vector2 playerDirection PlaySound(shot); // here // + Vector2 playerDirection = player->direction; + Vector2 playerPosition = (Vector2){player->posX, player->posY}; auto rot1 = Vector2Rotate(playerDirection, -0.2f); auto rot2 = Vector2Rotate(playerDirection, 0.2f); @@ -29,8 +31,8 @@ int wp_assaultrifle::bang(std::vector<Entity> * enemies, Vector2 playerDirection auto add2 = Vector2Add(playerPosition, rot2); auto r = playerDirection; - r.x *= 2; - r.y *= 2; + r.x *= 4; + r.y *= 4; for (auto en = enemies->begin(); en != enemies->end(); en++) { @@ -45,7 +47,9 @@ int wp_assaultrifle::bang(std::vector<Entity> * enemies, Vector2 playerDirection en->direction.x = (playerDirection.x / 2); en->direction.y = (playerDirection.y / 2); } - *victims += 1; + player->victims += 1; + player->fury += 1; + break ; } } // assaultrifle cone diff --git a/src/wp_assaultrifle.hpp b/src/wp_assaultrifle.hpp index 2780a29..c8016da 100644 --- a/src/wp_assaultrifle.hpp +++ b/src/wp_assaultrifle.hpp @@ -16,7 +16,7 @@ class wp_assaultrifle : public AWeapon { wp_assaultrifle(const char *s, const char *r); ~wp_assaultrifle(); - int bang(std::vector<Entity> * enemies, Vector2 playerDirection, Vector2 playerPosition, int * victims) ; + int bang(std::vector<Entity> * enemies, Entity * player); }; diff --git a/src/wp_shotty.cpp b/src/wp_shotty.cpp index 580450e..ae978f4 100644 --- a/src/wp_shotty.cpp +++ b/src/wp_shotty.cpp @@ -7,18 +7,20 @@ #include "entity.hpp" wp_shotty::wp_shotty(const char *s, const char *r) - : AWeapon(10, 10, 10, 1.0, s, r) + : AWeapon(10, 10, 10, 0.5, s, r) {} -int wp_shotty::bang(std::vector<Entity> * enemies, Vector2 playerDirection, Vector2 playerPosition, int * victims) +int wp_shotty::bang(std::vector<Entity> * enemies, Entity * player) { if (barrel == 0 || GetTime() < (t + cooldown)) { return (1); } else { + Vector2 playerDirection = player->direction; + Vector2 playerPosition = (Vector2){player->posX, player->posY}; barrel--; PlaySound(shot); t = GetTime(); @@ -48,7 +50,8 @@ int wp_shotty::bang(std::vector<Entity> * enemies, Vector2 playerDirection, Vect en->direction.x = (playerDirection.x / 2); en->direction.y = (playerDirection.y / 2); } - *victims += 1; + player->victims += 1; + player->fury += 1; } } // shotty cone diff --git a/src/wp_shotty.hpp b/src/wp_shotty.hpp index 2f9b917..48e443a 100644 --- a/src/wp_shotty.hpp +++ b/src/wp_shotty.hpp @@ -16,7 +16,7 @@ class wp_shotty : public AWeapon { wp_shotty(const char *s, const char *r); ~wp_shotty(); - int bang(std::vector<Entity> * enemies, Vector2 playerDirection, Vector2 playerPosition, int * victims) ; + int bang(std::vector<Entity> * enemies, Entity * player) ; }; |