X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fgraphics%2FAnimation.h;h=0c6ae288b4a5e04220f764d9c5ba6b4ee05597c4;hb=aedc31b88715246abc00a0ab333bea6e17bbb780;hp=0f33541f0397ce41ce479f4442246bf0b3fd8654;hpb=abede3a0c94a057bc70305a1a858363a2a686f7e;p=l2e.git diff --git a/src/graphics/Animation.h b/src/graphics/Animation.h index 0f33541..0c6ae28 100644 --- a/src/graphics/Animation.h +++ b/src/graphics/Animation.h @@ -42,12 +42,20 @@ public: bool Running() const { return timer.Running() && (repeat || timer.Iteration() < NumFrames()); } + bool JustFinished() const { + return timer.JustHit() && timer.Iteration() == NumFrames(); + } + + const app::Timer &GetTimer() { return timer; } void SetColOffset(int offset) { colOffset = offset; } int ColOffset() const { return colOffset; } void SetRowOffset(int offset) { rowOffset = offset; } int RowOffset() const { return rowOffset; } + const Sprite *GetSprite() const { return sprite; } + void ChangeSprite(const Sprite *s) { sprite = s; } + virtual void Draw(SDL_Surface *dest, geometry::Point position) const { sprite->Draw(dest, position, Col() + ColOffset(), Row() + RowOffset()); } @@ -64,8 +72,9 @@ public: Draw(dest, position + offset); } -protected: int Frame() const { return Running() ? (timer.Iteration() % NumFrames()) : 0; } + +protected: virtual int Col() const = 0; virtual int Row() const = 0; virtual int NumFrames() const = 0;