X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fmap%2FEntity.cpp;h=610e58551510a556db8c6045db23ae9de81ddc15;hb=ed792d6d00d822384d79d049e644e372f7c3b4cd;hp=08be97b96c93208ab95774ed4168377e02cc007d;hpb=a1c89e41e38eca790e168b8acd3beee974685fcd;p=l2e.git diff --git a/src/map/Entity.cpp b/src/map/Entity.cpp index 08be97b..610e585 100644 --- a/src/map/Entity.cpp +++ b/src/map/Entity.cpp @@ -15,7 +15,8 @@ Entity::Entity() : follower(0) , animation(0) , orientation(ORIENTATION_NORTH) -, speed(0) { +, speed(0) +, flags(0) { runner.SetFrameShift(1); } @@ -87,11 +88,10 @@ void Entity::UpdateVelocity() { } -bool Entity::TileLock(int width, int height) const { - Vector tilePosition( - position.X() - (width / 2), - position.Y()); - return (tilePosition.X() % width == 0) && (tilePosition.Y() % height == 0); +bool Entity::TileLock(const geometry::Vector &tileSize) const { + // TODO: change position to point to the top-left corner of a tile + Vector tilePosition(position); + return (tilePosition.X() % tileSize.X() == 0) && (tilePosition.Y() % tileSize.Y() == 0); } @@ -103,9 +103,9 @@ void Entity::Update(float deltaT) { void Entity::Render(SDL_Surface *dest, const Vector &offset) const { // TODO: configurable sprite offsets if (runner.Running()) { - runner.DrawCenter(dest, offset + position); + runner.Draw(dest, offset + position + spriteOffset); } else { - animation->GetSprite()->DrawCenter(dest, offset + position, orientation); + animation->GetSprite()->Draw(dest, offset + position + spriteOffset, orientation); } }