diff options
author | WBoerenkamps <wrj.boerenkamps@student.avans.nl> | 2025-01-08 12:43:54 +0100 |
---|---|---|
committer | WBoerenkamps <wrj.boerenkamps@student.avans.nl> | 2025-01-08 12:43:54 +0100 |
commit | 016b36b6d340be958bb047ca5f26dd54aa658c88 (patch) | |
tree | d5ea295632b4290cf2e5ef06e1b83e40a3e0c36c | |
parent | 9625b751757b8828b0edb0b7543c7cadfd25c119 (diff) |
battlescript battle won working
-rw-r--r-- | game/enemy/BattleScript.cpp | 9 | ||||
-rw-r--r-- | game/enemy/BattleScript.h | 1 | ||||
-rw-r--r-- | game/enemy/EnemyScript.cpp | 2 | ||||
-rw-r--r-- | game/main.cpp | 4 |
4 files changed, 9 insertions, 7 deletions
diff --git a/game/enemy/BattleScript.cpp b/game/enemy/BattleScript.cpp index 463ddf3..1d263a3 100644 --- a/game/enemy/BattleScript.cpp +++ b/game/enemy/BattleScript.cpp @@ -1,4 +1,3 @@ -#include <iostream> #include "BattleScript.h" #include <crepe/api/AI.h> #include "EnemyScript.h" @@ -8,10 +7,7 @@ #include "EnemyScript.h" using namespace std; using namespace crepe; -// stop player movement -// spawn enemies -// resume game once enemies are defeated -// optional: spawn lazers during fight + BattleScript::BattleScript(){ engine.seed(rd()); } @@ -24,6 +20,7 @@ void BattleScript::init(){ }); } void BattleScript::fixed_update(duration_t dt){ + if(!battle_active) return; bool enemies_alive = false; RefVector<BehaviorScript> enemy_scripts = this->get_components_by_tag<BehaviorScript>("enemy"); @@ -33,10 +30,12 @@ void BattleScript::fixed_update(duration_t dt){ } } if(!enemies_alive){ + this->battle_active = false; this->trigger_event<BattleWonEvent>(); } } bool BattleScript::create_battle(const BattleStartEvent& e){ + this->battle_active = true; RefVector<BehaviorScript> enemy_scripts = this->get_components_by_tag<BehaviorScript>("enemy"); std::uniform_real_distribution<float> dist(10,30); for(int i = 0; i < e.num_enemies;i++){ diff --git a/game/enemy/BattleScript.h b/game/enemy/BattleScript.h index d239e70..55ca166 100644 --- a/game/enemy/BattleScript.h +++ b/game/enemy/BattleScript.h @@ -14,6 +14,7 @@ class BattleScript : public crepe::Script{ void init() override; void fixed_update(crepe::duration_t dt) override; private: + bool battle_active = false; std::random_device rd; std::default_random_engine engine; bool create_battle(const BattleStartEvent& e); diff --git a/game/enemy/EnemyScript.cpp b/game/enemy/EnemyScript.cpp index 4b75846..f9b79ea 100644 --- a/game/enemy/EnemyScript.cpp +++ b/game/enemy/EnemyScript.cpp @@ -82,6 +82,8 @@ bool EnemyScript::on_collide(const CollisionEvent & e){ if(e.info.other.metadata.tag == "player_bullet"){ this->despawn_enemy(); } + BehaviorScript& enemy_script = this->get_component<BehaviorScript>(); + enemy_script.active = false; return false; } void EnemyScript::despawn_enemy(){ diff --git a/game/main.cpp b/game/main.cpp index 3f7e17e..9b25444 100644 --- a/game/main.cpp +++ b/game/main.cpp @@ -9,10 +9,10 @@ using namespace crepe; int main() { Engine gameloop; - gameloop.add_scene<GameScene>(); + gameloop.add_scene<MainMenuScene>(); gameloop.add_scene<ShopMenuScene>(); - + gameloop.add_scene<GameScene>(); return gameloop.main(); } |