From 5c0999cb674ceb43d2244e4eaba225f8ffa4ccb4 Mon Sep 17 00:00:00 2001 From: Andrei Karas Date: Wed, 25 Dec 2013 12:35:27 +0300 Subject: extend pet follow logic with follow in fixed position to owner. --- src/being/being.cpp | 44 +++++++++++++++++++++++++------------------- 1 file changed, 25 insertions(+), 19 deletions(-) (limited to 'src/being/being.cpp') diff --git a/src/being/being.cpp b/src/being/being.cpp index b7d6019ec..a8b3eaf8c 100644 --- a/src/being/being.cpp +++ b/src/being/being.cpp @@ -1650,28 +1650,34 @@ void Being::petLogic() } else if (divX > followDist || divY > followDist) { - if (divX > followDist) + if (!dist) { - if (dstX > mX + dist) - dstX -= dist; - else if (dstX + dist <= mX) - dstX += dist; + fixPetSpawnPos(dstX, dstY); } else { - dstX = mX; - } - - if (divY > followDist) - { - if (dstY > mY + dist) - dstY -= dist; - else if (dstX + dist <= mX) - dstY += dist; - } - else - { - dstY = mY; + if (divX > followDist) + { + if (dstX > mX + dist) + dstX -= dist; + else if (dstX + dist <= mX) + dstX += dist; + } + else + { + dstX = mX; + } + if (divY > followDist) + { + if (dstY > mY + dist) + dstY -= dist; + else if (dstX + dist <= mX) + dstY += dist; + } + else + { + dstY = mY; + } } const int walkMask = getWalkMask(); @@ -3191,7 +3197,7 @@ void Being::fixPetSpawnPos(int &dstX, int &dstY) const switch (mOwner->getDirection()) { case LEFT: - offsetX = offsetY1; + offsetX = -offsetY1; offsetY = -offsetX1; break; case RIGHT: -- cgit v1.2.3-60-g2f50