X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fcreature%2FSteering.hpp;h=9af62b9c7573aaf78c824b8c8a0c0ec9d20a10fa;hb=HEAD;hp=51f2c63db710bc098d689f540ef00801a050cadb;hpb=8f6530c75730f901efd6708e4fde7e68a178adf1;p=blobs.git diff --git a/src/creature/Steering.hpp b/src/creature/Steering.hpp index 51f2c63..9af62b9 100644 --- a/src/creature/Steering.hpp +++ b/src/creature/Steering.hpp @@ -1,6 +1,7 @@ #ifndef BLOBS_CREATURE_STEERING_HPP_ #define BLOBS_CREATURE_STEERING_HPP_ +#include "Situation.hpp" #include "../math/glm.hpp" @@ -12,33 +13,48 @@ class Creature; class Steering { public: - Steering(); + explicit Steering(const Creature &); ~Steering(); public: - void MaxAcceleration(double a) noexcept { max_accel = a; } - double MaxAcceleration() const noexcept { return max_accel; } + /// factor in [0,1] of how fast you need to get there + void Haste(double h) noexcept { haste = h; } + double Haste() const noexcept { return haste; } + + void MaxForce(double f) noexcept { max_force = f; } + double MaxForce() const noexcept { return max_force; } void MaxSpeed(double s) noexcept { max_speed = s; } double MaxSpeed() const noexcept { return max_speed; } public: + void Off() noexcept; + void Separate(double min_distance, double max_lookaround) noexcept; + void DontSeparate() noexcept; + void ResumeSeparate() noexcept; void Halt() noexcept; + void Pass(const glm::dvec3 &) noexcept; void GoTo(const glm::dvec3 &) noexcept; - glm::dvec3 Acceleration(Creature &) const noexcept; + glm::dvec3 Force(const Situation::State &) const noexcept; private: - bool SumForce(glm::dvec3 &out, const glm::dvec3 &in) const noexcept; + glm::dvec3 TargetVelocity(const Situation::State &, const glm::dvec3 &, double acc) const noexcept; private: - glm::dvec3 seek_target; + const Creature &c; + glm::dvec3 target; - double max_accel = 1.0; - double max_speed = 1.0; + double haste; + double max_force; + double max_speed; + double min_dist; + double max_look; + bool separating; bool halting; bool seeking; + bool arriving; };