X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fgraphics%2FComplexAnimation.h;h=4e2cb32a0e9146bc19a5bf73149c0248f0d27b6c;hb=9648fd7d258ae1a2baccb8dd5b6f7a9491e55803;hp=815e9c5a6e4183c88de7225e4721b67a4521033c;hpb=bb7326004878abeadbe171db75d2caa0eae74431;p=l2e.git diff --git a/src/graphics/ComplexAnimation.h b/src/graphics/ComplexAnimation.h index 815e9c5..4e2cb32 100644 --- a/src/graphics/ComplexAnimation.h +++ b/src/graphics/ComplexAnimation.h @@ -10,30 +10,22 @@ #include "Animation.h" -#include - namespace graphics { class ComplexAnimation : public Animation { public: - ComplexAnimation() { } - ComplexAnimation(const Sprite *sprite, int frameTime, bool repeat = false) - : Animation(sprite, frameTime, repeat) { } + static const int TYPE_ID = 402; public: - void AddFrame(int col, int row, const geometry::Vector &disposition = geometry::Vector()) { - frames.push_back(FrameProp(col, row, disposition)); - } - void AddFrames(int col, int row, const geometry::Vector &disposition, int amount) { - for (int i(0); i < amount; ++i) { - AddFrame(col, row, disposition); - } - } + ComplexAnimation() : frames(0), numFrames(0) { } + ComplexAnimation(const Sprite *sprite, int frameTime, bool repeat = false) + : Animation(sprite, frameTime, repeat), frames(0), numFrames(0) { } public: struct FrameProp { + static const int TYPE_ID = 403; FrameProp() : col(0), row(0) { } FrameProp(int col, int row, const geometry::Vector &disposition) : col(col), row(row), disposition(disposition) {} @@ -41,16 +33,20 @@ public: int row; geometry::Vector disposition; }; - void AddFrame(const FrameProp &f) { frames.push_back(f); } + void SetFrames(const FrameProp *f, int num) { frames = f; numFrames = num; } + + static void CreateTypeDescription(); + static void Construct(void *); protected: - virtual int NumFrames() const { return frames.size(); }; + virtual int NumFrames() const { return numFrames; }; virtual int Col(int frame) const { return frames[frame].col; } virtual int Row(int frame) const { return frames[frame].row; } virtual geometry::Vector Offset(int frame) const { return frames[frame].disposition; } private: - std::vector frames; + const FrameProp *frames; + int numFrames; };