X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fmap%2FEntity.cpp;fp=src%2Fmap%2FEntity.cpp;h=302ce5c195ac856ab8aafaaae7befb0b5634b226;hb=72988b5f9bd449cffea97273bebfc788735ce14d;hp=391c711665dc63e7495dedcc6f13cc6470ee2396;hpb=8add322195bf2f619ba61bfea4335d28627b0b68;p=l2e.git diff --git a/src/map/Entity.cpp b/src/map/Entity.cpp index 391c711..302ce5c 100644 --- a/src/map/Entity.cpp +++ b/src/map/Entity.cpp @@ -12,7 +12,7 @@ using geometry::Vector; namespace map { Entity::Entity() -: sprite(0) +: animation(0) , orientation(ORIENTATION_NORTH) , speed(0) { @@ -22,7 +22,7 @@ Entity::Entity() 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(); @@ -67,10 +73,10 @@ void Entity::Update(float deltaT) { void Entity::Render(SDL_Surface *dest, const Vector &offset) const { // TODO: configurable sprite offsets - if (animation.Running()) { - animation.DrawCenter(dest, offset + position); + if (runner.Running()) { + runner.DrawCenter(dest, offset + position); } else { - sprite->DrawCenter(dest, offset + position, orientation); + animation->GetSprite()->DrawCenter(dest, offset + position, orientation); } }