diff options
author | Aki <please@ignore.pl> | 2022-11-16 00:38:14 +0100 |
---|---|---|
committer | Aki <please@ignore.pl> | 2022-11-16 00:38:14 +0100 |
commit | 67442e86f53a27ddf9014cbe843ba63b08ef52bc (patch) | |
tree | f92631ef0edbbf33d7cec61e07ef9a1710b76962 /battles | |
parent | 9a93c0866c11116bdbdaf11bc0c1693771309244 (diff) | |
download | kurator-67442e86f53a27ddf9014cbe843ba63b08ef52bc.zip kurator-67442e86f53a27ddf9014cbe843ba63b08ef52bc.tar.gz kurator-67442e86f53a27ddf9014cbe843ba63b08ef52bc.tar.bz2 |
Implemented simple range limitation for turrets
Diffstat (limited to 'battles')
-rw-r--r-- | battles/src/BaseBattle.cpp | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/battles/src/BaseBattle.cpp b/battles/src/BaseBattle.cpp index 8a3dc37..87f450a 100644 --- a/battles/src/BaseBattle.cpp +++ b/battles/src/BaseBattle.cpp @@ -83,14 +83,17 @@ BaseBattle::update(const float dt) _registry.destroy(entity); continue; } - const auto& state = _registry.get<AIState>(control.owner); // no checks + const auto& [state, transform] = _registry.get<AIState, Transform>(control.owner); // no checks if (!_registry.valid(state.target)) continue; if (control.reload > 0.0) control.reload -= dt; if (control.reload <= 0.0) { auto& target_points = _registry.get<HitPoints>(state.target); - target_points.health -= def.base_damage; + const auto& target = _registry.get<Transform>(state.target); + const auto distance = transform.position - target.position; + if (def.range > distance.magnitude()) + target_points.health -= def.base_damage; control.reload = def.rate_of_fire; } } |