X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fai%2FSpawner.hpp;h=e460bbc2dfccf5d7c3499327e71f5956ed54c31d;hb=825f479edf9867938b6789215ad7ae6303596cba;hp=127a8606dbdfbb8a2a6e491d75b632a8fb22ba99;hpb=549646ac3e5bede5e77031f773649edf8de83608;p=blank.git diff --git a/src/ai/Spawner.hpp b/src/ai/Spawner.hpp index 127a860..e460bbc 100644 --- a/src/ai/Spawner.hpp +++ b/src/ai/Spawner.hpp @@ -9,32 +9,46 @@ namespace blank { +class CompositeModel; class Controller; +class Entity; +class GaloisLFSR; +class Skeletons; class World; class Spawner { public: - explicit Spawner(World &); + Spawner(World &, Skeletons &, GaloisLFSR &); ~Spawner(); + void LimitSkeletons(std::size_t begin, std::size_t end); + void Update(int dt); private: void CheckDespawn() noexcept; void TrySpawn(); - void Spawn(const glm::ivec3 &, const glm::vec3 &); + void Spawn(Entity &reference, const glm::ivec3 &, const glm::vec3 &); + + CompositeModel &RandomSkeleton() noexcept; private: World &world; + Skeletons &skeletons; std::vector controllers; + GaloisLFSR &random; + IntervalTimer timer; float despawn_range; float spawn_distance; unsigned int max_entities; int chunk_range; + std::size_t skeletons_offset; + std::size_t skeletons_length; + }; }