Final fix for end of movement

I was being dumb again : if we are adjacent to a target entity, stop moving
This commit is contained in:
trotFunky 2019-06-10 21:53:39 +02:00
parent b85d46e450
commit 2d8b1e53ce
2 changed files with 9 additions and 10 deletions

View file

@ -13,9 +13,7 @@ Rule::Rule(std::shared_ptr<Entity> entity, State targetState, EntityType targetT
targetType(targetType), targetType(targetType),
entities(entities), entities(entities),
occupiedSquares(occupiedSquares), occupiedSquares(occupiedSquares),
mapSize(mapSize), mapSize(mapSize)
previousPosition(this->entity->getPosition()),
previousTarget(this->entity->target)
{} {}
void Rule::update() void Rule::update()
@ -23,13 +21,10 @@ void Rule::update()
if (targetState == State::Moving || targetState == State::Fleeing) if (targetState == State::Moving || targetState == State::Fleeing)
{ {
pro_maat::GridPos target = findTarget(); pro_maat::GridPos target = findTarget();
if(target != previousPosition && (entity->getPosition() != previousTarget || entity->getPosition() == previousPosition)) if(target != entity->getPosition())
{ {
entity->nextTarget = target; entity->nextTarget = target;
entity->nextState = targetState; entity->nextState = targetState;
previousPosition = entity->getPosition();
previousTarget = entity->getTarget();
} }
else else
{ {
@ -130,6 +125,13 @@ pro_maat::GridPos Rule::findTarget()
std::sort(potentialTargets.begin(),potentialTargets.end(),distanceSortSquares); std::sort(potentialTargets.begin(),potentialTargets.end(),distanceSortSquares);
// If we are adjacent to a target, we do not need to move
if(std::find(potentialTargets.begin(),potentialTargets.end(),entity->getPosition()) != potentialTargets.end())
{
break;
}
auto target = std::min_element(potentialTargets.begin(),potentialTargets.end(),bestTarget); auto target = std::min_element(potentialTargets.begin(),potentialTargets.end(),bestTarget);
if(target != potentialTargets.end()) if(target != potentialTargets.end())

View file

@ -50,9 +50,6 @@ private:
const std::vector<pro_maat::GridPos>& occupiedSquares; const std::vector<pro_maat::GridPos>& occupiedSquares;
const pro_maat::GridPos& mapSize; const pro_maat::GridPos& mapSize;
pro_maat::GridPos previousPosition;
pro_maat::GridPos previousTarget;
}; };
#endif //PROJECT_MAAT_RULES_H #endif //PROJECT_MAAT_RULES_H