X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fmap%2FEntity.cpp;h=b9fba9797acc17246783793dac4cc4dfdf8ed1d1;hb=c055b357c50dd871b49c38191a9d867ff42ea420;hp=0e1b822ba32256e920e4767051a5e8f68fbecaec;hpb=1d6a9f01b8db0f5212b6a02603dd0670c6da38c7;p=l2e.git diff --git a/src/map/Entity.cpp b/src/map/Entity.cpp index 0e1b822..b9fba97 100644 --- a/src/map/Entity.cpp +++ b/src/map/Entity.cpp @@ -12,17 +12,17 @@ using geometry::Vector; namespace map { Entity::Entity() -: sprite(0) +: animation(0) , orientation(ORIENTATION_NORTH) , speed(0) { - + runner.SetFrameShift(1); } void Entity::SetOrientation(Orientation o) { orientation = o; UpdateVelocity(); - animation.SetColOffset(orientation); + runner.SetColOffset(orientation); } void Entity::SetSpeed(float s) { @@ -30,6 +30,12 @@ void Entity::SetSpeed(float s) { UpdateVelocity(); } +void Entity::SetAnimation(const graphics::Animation *a) { + animation = a; + runner.ChangeAnimation(animation); +} + + void Entity::UpdateVelocity() { if (speed == 0.0f) { velocity = Vector(); @@ -55,7 +61,7 @@ void Entity::UpdateVelocity() { 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); } @@ -66,10 +72,11 @@ void Entity::Update(float deltaT) { void Entity::Render(SDL_Surface *dest, const Vector &offset) const { - if (animation.Running()) { - animation.DrawCenterBottom(dest, offset + position); + // TODO: configurable sprite offsets + if (runner.Running()) { + runner.DrawCenter(dest, offset + position); } else { - sprite->DrawCenterBottom(dest, offset + position, orientation); + animation->GetSprite()->DrawCenter(dest, offset + position, orientation); } }