X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fcreature%2FLocateResourceGoal.hpp;h=c87f4f18a07b47712ca8ea776139288de1c11e16;hb=d921cba26f21e4a75b22f5e9d9be988707bf6a8f;hp=b5d390c7c69e71e9bdd519e90529fbd786ff0eae;hpb=8a3907bb0bed257bf5d6f40f39f15114e8345913;p=blobs.git diff --git a/src/creature/LocateResourceGoal.hpp b/src/creature/LocateResourceGoal.hpp index b5d390c..c87f4f1 100644 --- a/src/creature/LocateResourceGoal.hpp +++ b/src/creature/LocateResourceGoal.hpp @@ -1,6 +1,10 @@ #ifndef BLOBS_CREATURE_LOCATERESOURCEGOAL_HPP_ #define BLOBS_CREATURE_LOCATERESOURCEGOAL_HPP_ +#include "Composition.hpp" +#include "../math/glm.hpp" + + namespace blobs { namespace creature { @@ -8,16 +12,28 @@ class LocateResourceGoal : public Goal { public: - explicit LocateResourceGoal(int resource); + LocateResourceGoal(Creature &); ~LocateResourceGoal() noexcept override; public: - void Enable(Creature &) override; + void Accept(int resource, double attractiveness); + + std::string Describe() const override; + void Enable() override; void Tick(double dt) override; - void Action(Creature &) override; + void Action() override; + +private: + void LocateResource(); + void SearchVicinity(); + bool NearTarget() const noexcept; private: - int res; + Composition accept; + bool found; + glm::dvec3 target_pos; + bool searching; + double reevaluate; };