diff options
-rw-r--r-- | inc/creature.hpp | 2 | ||||
-rw-r--r-- | src/creature.cpp | 13 |
2 files changed, 10 insertions, 5 deletions
diff --git a/inc/creature.hpp b/inc/creature.hpp index cfdd317..90b0b17 100644 --- a/inc/creature.hpp +++ b/inc/creature.hpp @@ -9,7 +9,7 @@ class Creature: public Entity public: Creature(Window m, std::string s); void Behavior(); - void Action(); + bool Action(); void Priority(); Location getLocation(); void giveKnown(std::vector<Location> Z){location = Z;}; diff --git a/src/creature.cpp b/src/creature.cpp index dcc8337..7f31003 100644 --- a/src/creature.cpp +++ b/src/creature.cpp @@ -14,9 +14,13 @@ Creature::Creature(Window m, std::string s) //Constructor void Creature::Behavior() { - health-=5; //Decrements health each time a behavior is executed + health-=1; //Decrements health each time a behavior is executed this->Priority(); //Checks which action has priority (doesn't really do this right now) - this->Action(); //Does action + + if(this->Action()) + { + health+=10; + } } void Creature::Priority() @@ -33,11 +37,11 @@ void Creature::Priority() } } -void Creature::Action() +bool Creature::Action() { //If the distance is close, will return an bool if(sqrt(pow(xPosition - xTarget, 2) + pow(yPosition - yTarget, 2)) < 2) - return; //<--- eat action should be here + return true; //Makes moves towards target coordinates if(xPosition==xTarget) @@ -85,6 +89,7 @@ void Creature::Action() yPosition--; } } + return false; } Location Creature::getLocation() |