X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fai%2FSpawner.hpp;h=be2ff31b7307e99f484c5b183c788e329d260e82;hb=7e782291e0ce39eb2d4e8c1df28f682c313e6f8d;hp=d0c6f97c4695cbdf9db26202c8e8b8be4bf176fb;hpb=8fdc24f0b3fb287f5d4e1c7d1f85ad85d5ed2414;p=blank.git diff --git a/src/ai/Spawner.hpp b/src/ai/Spawner.hpp index d0c6f97..be2ff31 100644 --- a/src/ai/Spawner.hpp +++ b/src/ai/Spawner.hpp @@ -2,7 +2,6 @@ #define BLANK_AI_SPAWNER_HPP_ #include "../app/IntervalTimer.hpp" -#include "../rand/GaloisLFSR.hpp" #include #include @@ -10,19 +9,20 @@ namespace blank { -class CompositeModel; class Controller; class Entity; -class Skeletons; +class GaloisLFSR; +class Model; +class ModelRegistry; class World; class Spawner { public: - Spawner(World &, Skeletons &, std::uint64_t seed); + Spawner(World &, ModelRegistry &, GaloisLFSR &); ~Spawner(); - void LimitSkeletons(std::size_t begin, std::size_t end); + void LimitModels(std::size_t begin, std::size_t end); void Update(int dt); @@ -31,14 +31,14 @@ private: void TrySpawn(); void Spawn(Entity &reference, const glm::ivec3 &, const glm::vec3 &); - CompositeModel &RandomSkeleton() noexcept; + Model &RandomModel() noexcept; private: World &world; - Skeletons &skeletons; + ModelRegistry ⊧ std::vector controllers; - GaloisLFSR random; + GaloisLFSR &random; IntervalTimer timer; float despawn_range; @@ -46,8 +46,8 @@ private: unsigned int max_entities; int chunk_range; - std::size_t skeletons_offset; - std::size_t skeletons_length; + std::size_t model_offset; + std::size_t model_length; };