#include "Spawner.hpp"
+#include "Chaser.hpp"
#include "RandomWalk.hpp"
#include "../world/BlockType.hpp"
#include "../world/BlockTypeRegistry.hpp"
}
Spawner::~Spawner() {
-
+ for (auto &ctrl : controllers) {
+ delete ctrl;
+ }
}
TrySpawn();
}
for (auto &ctrl : controllers) {
- ctrl.Update(dt);
+ ctrl->Update(dt);
}
}
void Spawner::CheckDespawn() noexcept {
const Entity &reference = world.Player();
for (auto iter = controllers.begin(), end = controllers.end(); iter != end;) {
- Entity &e = iter->Controlled();
+ Entity &e = (*iter)->Controlled();
glm::vec3 diff(reference.AbsoluteDifference(e));
if (dot(diff, diff) > despawn_range) {
e.Remove();
+ delete *iter;
iter = controllers.erase(iter);
} else {
++iter;
e.Bounds({ { -0.5f, -0.5f, -0.5f }, { 0.5f, 0.5f, 0.5f } });
e.WorldCollidable(true);
e.SetShape(world.BlockTypes()[1].shape, color);
- e.AngularVelocity(glm::quat(glm::vec3{ 0.00001f, 0.000006f, 0.000013f }));
- controllers.emplace_back(e);
+ e.AngularVelocity(rot);
+ Controller *ctrl;
+ if (rand() % 2) {
+ ctrl = new RandomWalk(e);
+ } else {
+ ctrl = new Chaser(e, world.Player());
+ }
+ controllers.emplace_back(ctrl);
}
}