From aa872f4f35890027e65c930cc9cc603b5db22906 Mon Sep 17 00:00:00 2001 From: salaaad2 Date: Sat, 22 Jan 2022 07:39:54 +0100 Subject: Weapons: amazing job adding another weapon salade ! outstanding --- src/gameplay.cpp | 15 ++++++++++----- src/gameplay.hpp | 4 ++++ src/projectile.cpp | 11 ----------- src/projectile.hpp | 14 ++++++-------- src/weapon.cpp | 10 ++++++++-- src/weapon.hpp | 9 ++++++++- src/wp_assaultrifle.cpp | 6 +++++- src/wp_assaultrifle.hpp | 1 + src/wp_enemyslingshot.cpp | 6 +++++- src/wp_enemyslingshot.hpp | 1 + src/wp_nadelauncher.cpp | 39 +++++++++++++++++++++++++++++++++++++++ src/wp_nadelauncher.hpp | 23 +++++++++++++++++++++++ src/wp_shotty.cpp | 6 +++++- src/wp_shotty.hpp | 1 + 14 files changed, 116 insertions(+), 30 deletions(-) create mode 100644 src/wp_nadelauncher.cpp create mode 100644 src/wp_nadelauncher.hpp (limited to 'src') diff --git a/src/gameplay.cpp b/src/gameplay.cpp index 276d9e9..0e089ad 100644 --- a/src/gameplay.cpp +++ b/src/gameplay.cpp @@ -19,6 +19,7 @@ #include "window.hpp" #include "wp_assaultrifle.hpp" #include "wp_enemyslingshot.hpp" +#include "wp_nadelauncher.hpp" #include "wp_shotty.hpp" Level* Game::parse(std::string const& path) { @@ -76,6 +77,7 @@ Game::Game(std::string const& path) { AWeapon* shotty = new wp_shotty(SHOTTY_BANG, SHOTTY_RELOAD); AWeapon* ar = new wp_assaultrifle(AR_BANG, SHOTTY_RELOAD); + AWeapon* nadelauncher = new wp_nadelauncher(AR_BANG, SHOTTY_RELOAD); AWeapon* sling = new wp_enemysling(SHOTTY_BANG, SHOTTY_RELOAD); for (auto i = 0; i < level->nMinion; i++) { @@ -105,6 +107,7 @@ Game::Game(std::string const& path) { player->fury = 0; player->wp[0] = shotty; player->wp[1] = ar; + player->wp[2] = nadelauncher; player->currentWeapon = player->wp[0]; player->idleTex = LoadTexture(MUCHACHO_TEX); @@ -130,7 +133,6 @@ void Game::draw() { auto left = std::to_string(enemies->size()); for (auto& en : *enemies) { - DrawCircle(en.posX, en.posY, en.radius, GREEN); if (en.hp <= 0) DrawTextureEx(en.hurtTex, (Vector2){en.posX - en.radius, en.posY - en.radius}, @@ -142,7 +144,7 @@ void Game::draw() { } if (en.hp > 1) { for (auto j = 0; j < en.hp; j++) { - DrawRectangle(en.posX + (10 * j), en.posY - 100, 10, 10, + DrawRectangle((en.posX - 50) + (10 * j), en.posY - 100, 10, 10, COOLPURPLE); } } @@ -166,9 +168,9 @@ void Game::draw() { i++) { // draw weapon ammo DrawRectangle(40 + (i * 20), SCREENHEIGHT - 60, 10, 30, RED); } - for (auto i = 0; i < enemies->size(); i++) { - if (enemies->at(i).hp >= 2) { - } + + for (auto& pr : *projectiles) { + DrawCircle(pr.posX, pr.posY, pr.radius, COOLPURPLE); } } @@ -331,6 +333,9 @@ int Game::shoot() const { return (0); } player->currentWeapon->bang(enemies, player); + if (player->currentWeapon->hasProjectiles) { + projectiles->push_back(player->currentWeapon->getProjectile()); + } if (player->currentWeapon->empty == true) { player->reloadTime = GetTime(); } diff --git a/src/gameplay.hpp b/src/gameplay.hpp index da85c51..94b713f 100644 --- a/src/gameplay.hpp +++ b/src/gameplay.hpp @@ -11,11 +11,13 @@ #include "entity.hpp" #include "map.hpp" +#include "projectile.hpp" #include "terrain.hpp" #include "window.hpp" #include #include +#include #include // sound defines @@ -56,6 +58,8 @@ class Game { std::vector* enemies; + std::list* projectiles; + Entity* player; Level* level; diff --git a/src/projectile.cpp b/src/projectile.cpp index e65222e..e69de29 100644 --- a/src/projectile.cpp +++ b/src/projectile.cpp @@ -1,11 +0,0 @@ -#include "projectile.hpp" -#include - -Projectile::Projectile(Vector2 const& dir, Vector2 const& pos) - : direction(dir), position(pos) {} - -Projectile::~Projectile() {} - -Projectile* Projectile::getProjectile() { - return (this); -} diff --git a/src/projectile.hpp b/src/projectile.hpp index e25e5f4..3c0a1b6 100644 --- a/src/projectile.hpp +++ b/src/projectile.hpp @@ -3,13 +3,11 @@ #include -class Projectile { - Vector2 const& direction; - Vector2 const& position; - - public: - Projectile(Vector2 const& direction, Vector2 const& position); - ~Projectile(); -}; +typedef struct Projectile { + int posX, posY; + Vector2 dir; + float radius; + float damage; +} Projectile; #endif /* PROJECTILE_H */ diff --git a/src/weapon.cpp b/src/weapon.cpp index 4e56117..fb871ed 100644 --- a/src/weapon.cpp +++ b/src/weapon.cpp @@ -16,8 +16,14 @@ AWeapon::AWeapon(float const rg, double const& cd, const char* s, const char* r, - std::string const& nm) - : range(rg), damage(dmg), max(mag), cooldown(cd), name(nm) { + std::string const& nm, + bool const& hasProj) + : range(rg), + damage(dmg), + max(mag), + cooldown(cd), + name(nm), + hasProjectiles(hasProj) { shot = LoadSound(s); reload = LoadSound(r); SetSoundVolume(shot, 0.3f); diff --git a/src/weapon.hpp b/src/weapon.hpp index d7f8df3..5e8fde4 100644 --- a/src/weapon.hpp +++ b/src/weapon.hpp @@ -9,6 +9,7 @@ #ifndef WEAPON_H_ #define WEAPON_H_ +#include "projectile.hpp" #include "raylib.h" #include @@ -30,6 +31,8 @@ class AWeapon { unsigned int const damage; const std::string name; + Projectile projectile; + public: AWeapon(float const rg, // range unsigned int const& dmg, // damage @@ -37,14 +40,18 @@ class AWeapon { double const& cooldown, // duh const char* s, // shot sound path const char* r, // reload sound path - std::string const& nm); // name + std::string const& nm, // name + bool const& hasProj); // projectiles ? yea/nay ~AWeapon(); virtual int bang(std::vector* enemies, Entity* player) = 0; void refill(); + virtual Projectile const& getProjectile() const = 0; + bool empty; unsigned int barrel; + bool hasProjectiles; }; #endif // WEAPON_H_ diff --git a/src/wp_assaultrifle.cpp b/src/wp_assaultrifle.cpp index 0be3d5b..f985d78 100644 --- a/src/wp_assaultrifle.cpp +++ b/src/wp_assaultrifle.cpp @@ -7,7 +7,7 @@ #include "entity.hpp" wp_assaultrifle::wp_assaultrifle(const char* s, const char* r) - : AWeapon(300.0f, 1, 30, 0.0, s, r, "ar") {} + : AWeapon(300.0f, 1, 30, 0.0, s, r, "ar", false) {} int wp_assaultrifle::bang(std::vector* enemies, Entity* player) { if (barrel == 0) { @@ -66,3 +66,7 @@ int wp_assaultrifle::bang(std::vector* enemies, Entity* player) { return (0); } } + +Projectile const& wp_assaultrifle::getProjectile() const { + return (projectile); +} diff --git a/src/wp_assaultrifle.hpp b/src/wp_assaultrifle.hpp index 89ce8e6..9c66d91 100644 --- a/src/wp_assaultrifle.hpp +++ b/src/wp_assaultrifle.hpp @@ -17,6 +17,7 @@ class wp_assaultrifle : public AWeapon { ~wp_assaultrifle(); int bang(std::vector* enemies, Entity* player); + Projectile const& getProjectile() const; }; #endif diff --git a/src/wp_enemyslingshot.cpp b/src/wp_enemyslingshot.cpp index 068f404..2a212d6 100644 --- a/src/wp_enemyslingshot.cpp +++ b/src/wp_enemyslingshot.cpp @@ -8,7 +8,7 @@ #include "gameplay.hpp" wp_enemysling::wp_enemysling(const char* s, const char* r) - : AWeapon(300.0f, 10, 10, 0.0, s, r, "sling") {} + : AWeapon(300.0f, 10, 10, 0.0, s, r, "sling", false) {} int wp_enemysling::bang(std::vector* enemies, Entity* baddie) { if (barrel == 0) { @@ -39,3 +39,7 @@ int wp_enemysling::bang(std::vector* enemies, Entity* baddie) { return (0); } } + +Projectile const& wp_enemysling::getProjectile() const { + return (projectile); +} diff --git a/src/wp_enemyslingshot.hpp b/src/wp_enemyslingshot.hpp index bcaec09..92fff7f 100644 --- a/src/wp_enemyslingshot.hpp +++ b/src/wp_enemyslingshot.hpp @@ -17,6 +17,7 @@ class wp_enemysling : public AWeapon { ~wp_enemysling(); int bang(std::vector* enemies, Entity* player); + Projectile const& getProjectile() const; }; #endif diff --git a/src/wp_nadelauncher.cpp b/src/wp_nadelauncher.cpp new file mode 100644 index 0000000..7352b42 --- /dev/null +++ b/src/wp_nadelauncher.cpp @@ -0,0 +1,39 @@ +#include "wp_nadelauncher.hpp" + +#include +#include +#include + +#include "entity.hpp" +#include "projectile.hpp" + +wp_nadelauncher::wp_nadelauncher(const char* s, const char* r) + : AWeapon(300.0f, 1, 30, 0.0, s, r, "nade", true) {} + +int wp_nadelauncher::bang(std::vector* enemies, Entity* player) { + if (barrel == 0) { + return (1); + } else { + Projectile* proj = new Projectile(); + proj->dir = player->direction; + proj->radius = player->radius; + proj->posX = player->posX; + proj->posY = player->posY; + + barrel--; + PlaySound(shot); + t = GetTime(); + // here + // + // + // there + if (barrel == 0) { + empty = true; + } + return (0); + } +} + +Projectile const& wp_nadelauncher::getProjectile() const { + return (projectile); +} diff --git a/src/wp_nadelauncher.hpp b/src/wp_nadelauncher.hpp new file mode 100644 index 0000000..2619936 --- /dev/null +++ b/src/wp_nadelauncher.hpp @@ -0,0 +1,23 @@ +/*********************************/ +/* THRESHOLD ( // */ +/* rifle ( )/ */ +/* by salade )(/ */ +/* ________________ ( /) */ +/* ()__)____________))))) :^} */ +/*********************************/ + +#ifndef WP_NADELAUNCHER_H_ +#define WP_NADELAUNCHER_H_ + +#include "weapon.hpp" + +class wp_nadelauncher : public AWeapon { + public: + wp_nadelauncher(const char* s, const char* r); + ~wp_nadelauncher(); + + int bang(std::vector* enemies, Entity* player); + Projectile const& getProjectile() const; +}; + +#endif diff --git a/src/wp_shotty.cpp b/src/wp_shotty.cpp index 7d61ab3..f314e54 100644 --- a/src/wp_shotty.cpp +++ b/src/wp_shotty.cpp @@ -7,7 +7,7 @@ #include "entity.hpp" wp_shotty::wp_shotty(const char* s, const char* r) - : AWeapon(100.0f, 3, 10, 0.5, s, r, "shotty") {} + : AWeapon(100.0f, 3, 10, 0.5, s, r, "shotty", false) {} int wp_shotty::bang(std::vector* enemies, Entity* player) { if (barrel == 0 || GetTime() < (t + cooldown)) { @@ -66,3 +66,7 @@ int wp_shotty::bang(std::vector* enemies, Entity* player) { return (0); } } + +Projectile const& wp_shotty::getProjectile() const { + return (projectile); +} diff --git a/src/wp_shotty.hpp b/src/wp_shotty.hpp index c7d4074..a9383cc 100644 --- a/src/wp_shotty.hpp +++ b/src/wp_shotty.hpp @@ -17,6 +17,7 @@ class wp_shotty : public AWeapon { ~wp_shotty(); int bang(std::vector* enemies, Entity* player); + Projectile const& getProjectile() const; }; #endif -- cgit v1.2.3