X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fcreature%2FCreature.hpp;h=59bfcb77396dc569c3e0c480c05da729e0de7ffe;hb=HEAD;hp=2c0b6b8dabd8198d85c6f6ef9dc9743e5710b7d4;hpb=76c09039792065ca1c259fb4b681c84c29a9dbd8;p=blobs.git diff --git a/src/creature/Creature.hpp b/src/creature/Creature.hpp index 2c0b6b8..59bfcb7 100644 --- a/src/creature/Creature.hpp +++ b/src/creature/Creature.hpp @@ -3,7 +3,6 @@ #include "Composition.hpp" #include "Genome.hpp" -#include "Goal.hpp" #include "Memory.hpp" #include "Situation.hpp" #include "Steering.hpp" @@ -11,6 +10,7 @@ #include "../math/geometry.hpp" #include "../math/glm.hpp" +#include #include #include #include @@ -30,6 +30,8 @@ namespace world { } namespace creature { +class Goal; + class Creature { public: @@ -101,6 +103,12 @@ public: void HighlightColor(const glm::dvec3 &c) noexcept; glm::dvec4 HighlightColor() const noexcept { return highlight_color; } + void BackSkin(double s) noexcept { skin_back = s; } + double BackSkin() const noexcept { return skin_back; } + + void SideSkin(double s) noexcept { skin_side = s; } + double SideSkin() const noexcept { return skin_side; } + void Mass(double m) noexcept { mass = m; } double Mass() const noexcept { return mass; } void Ingest(int res, double amount) noexcept; @@ -163,8 +171,8 @@ public: const Memory &GetMemory() const noexcept { return memory; } /// constantly active goal. every creature in the simulation is required to have one - void SetBackgroundTask(std::unique_ptr &&g) { bg_task = std::move(g); } - Goal &BackgroundTask() { return *bg_task; } + void SetBackgroundTask(std::unique_ptr &&g); + Goal &BackgroundTask(); void AddGoal(std::unique_ptr &&); const std::vector> &Goals() const noexcept { return goals; } @@ -177,9 +185,13 @@ public: Steering &GetSteering() noexcept { return steering; } const Steering &GetSteering() const noexcept { return steering; } - math::AABB CollisionBox() const noexcept; + void HeadingTarget(const glm::dvec3 &t) noexcept { heading_target = t; heading_manual = true; } + + math::AABB CollisionBounds() const noexcept; glm::dmat4 CollisionTransform() const noexcept; + void OnCollide(Creature &other); + glm::dmat4 LocalTransform() noexcept; void BuildVAO(); @@ -187,6 +199,7 @@ public: void Draw(graphics::Viewport &); private: + void Cache() noexcept; void TickState(double dt); void TickStats(double dt); void TickBrain(double dt); @@ -202,6 +215,8 @@ private: glm::dvec3 base_color; glm::dvec4 highlight_color; + double skin_back; + double skin_side; double mass; double size; @@ -221,6 +236,15 @@ private: Situation situation; Steering steering; + glm::dvec3 heading_target; + bool heading_manual; + + // cached because steering makes heavy use of this + double perception_range; + double perception_range_squared; + double perception_omni_range; + double perception_omni_range_squared; + double perception_field; struct Attributes { glm::vec3 position;