X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fmap%2FEntity.cpp;h=391c711665dc63e7495dedcc6f13cc6470ee2396;hb=9302f6869530e5492c73ef6f12f9cea348e8b2a6;hp=c14c9a0e7321a25b43e5fa64875545c3be974dd5;hpb=657eed00ae73b8d06470cec0d955aeada537a90d;p=l2e.git diff --git a/src/map/Entity.cpp b/src/map/Entity.cpp index c14c9a0..391c711 100644 --- a/src/map/Entity.cpp +++ b/src/map/Entity.cpp @@ -12,15 +12,50 @@ using geometry::Vector; namespace map { Entity::Entity() -: sprite(0) { +: sprite(0) +, orientation(ORIENTATION_NORTH) +, speed(0) { } +void Entity::SetOrientation(Orientation o) { + orientation = o; + UpdateVelocity(); + animation.SetColOffset(orientation); +} + +void Entity::SetSpeed(float s) { + speed = s; + UpdateVelocity(); +} + +void Entity::UpdateVelocity() { + if (speed == 0.0f) { + velocity = Vector(); + return; + } + switch (orientation) { + case ORIENTATION_NORTH: + velocity = Vector(0.0f, -speed); + break; + case ORIENTATION_EAST: + velocity = Vector(speed, 0.0f); + break; + case ORIENTATION_SOUTH: + velocity = Vector(0.0f, speed); + break; + case ORIENTATION_WEST: + velocity = Vector(-speed, 0.0f); + break; + } +} + + bool Entity::TileLock(int width, int height) const { Vector tilePosition( position.X() - (width / 2), - position.Y() - height); + position.Y()); return (tilePosition.X() % width == 0) && (tilePosition.Y() % height == 0); } @@ -31,10 +66,11 @@ void Entity::Update(float deltaT) { void Entity::Render(SDL_Surface *dest, const Vector &offset) const { + // TODO: configurable sprite offsets if (animation.Running()) { - animation.DrawCenterBottom(dest, offset + position); + animation.DrawCenter(dest, offset + position); } else { - sprite->DrawCenterBottom(dest, offset + position); + sprite->DrawCenter(dest, offset + position, orientation); } }