summaryrefslogtreecommitdiff
path: root/battles/src/BaseBattle.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'battles/src/BaseBattle.cpp')
-rw-r--r--battles/src/BaseBattle.cpp22
1 files changed, 14 insertions, 8 deletions
diff --git a/battles/src/BaseBattle.cpp b/battles/src/BaseBattle.cpp
index 98af764..e102d79 100644
--- a/battles/src/BaseBattle.cpp
+++ b/battles/src/BaseBattle.cpp
@@ -87,14 +87,20 @@ void
BaseBattle::floating_movement(const float dt)
{
auto view = _registry.view<Transform, FloatingMovement, AIState>();
- for (auto&& [entity, self, movement, ai] : view.each()) {
- const double speed = movement.speed * dt;
- const Point offset = ai.destination - self.position;
- if (offset.magnitude() > speed) {
- const Point move = offset.normalized().scale(speed);
- self.position.x += move.x;
- self.position.y += move.y;
- }
+ for (auto&& [entity, transform, movement, ai] : view.each()) {
+ const auto offset = ai.destination - transform.position;
+ const auto at_destination = offset.magnitude() > movement.destination_boundary;
+ const auto acceleration =
+ at_destination ?
+ offset.normalized().scale(movement.acceleration * dt) :
+ offset.normalized().scale(-1 * movement.deceleration * dt);
+ movement.speed.x += acceleration.x;
+ movement.speed.y += acceleration.y;
+ if (movement.speed.magnitude() > movement.max_speed)
+ movement.speed = movement.speed.normalized().scale(movement.max_speed);
+ const auto speed = movement.speed.scale(dt);
+ transform.position.x += speed.x;
+ transform.position.y += speed.y;
}
}