aboutsummaryrefslogtreecommitdiff
path: root/src/libjin/Graphics/animation
diff options
context:
space:
mode:
Diffstat (limited to 'src/libjin/Graphics/animation')
-rw-r--r--src/libjin/Graphics/animation/je_animation.h40
-rw-r--r--src/libjin/Graphics/animation/je_animator.cpp (renamed from src/libjin/Graphics/animation/je_clip.cpp)0
-rw-r--r--src/libjin/Graphics/animation/je_animator.h48
-rw-r--r--src/libjin/Graphics/animation/je_clip.h44
4 files changed, 72 insertions, 60 deletions
diff --git a/src/libjin/Graphics/animation/je_animation.h b/src/libjin/Graphics/animation/je_animation.h
index ca5758f..aa4c93f 100644
--- a/src/libjin/Graphics/animation/je_animation.h
+++ b/src/libjin/Graphics/animation/je_animation.h
@@ -1,11 +1,10 @@
#ifndef __JE_ANIMATION_H
#define __JE_ANIMATION_H
-#include <map>
#include <vector>
#include <string>
-#include "je_clip.h"
+#include "../je_sprite.h"
namespace JinEngine
{
@@ -13,32 +12,41 @@ namespace JinEngine
{
///
- ///
+ /// Animation clip with key.
///
class Animation
{
public:
- void addClip(const std::string& key, Clip* clip);
- bool hasKey(const std::string& key);
+ void onUpdate(float dt);
- void play();
- void switchClipByKey(const std::string& key);
- void switchClip(const Clip* clip);
+ void start();
+ void pause();
+ void stop();
+ void rewind();
+ void setSpeed(float speed);
///
- /// Control clips.
+ /// Get current frame index.
///
- void stopClip();
- void pauseClip();
- void rewindClip();
- void startClip();
+ uint getCurrentFrame();
+
+ ///
+ /// Set current frame index.
+ ///
+ /// @param frame Current frame to play.
+ ///
+ void setCurrentFrame(uint frame);
private:
///
- /// Map a key to clips.
+ /// Key frames.
+ ///
+ std::vector<Sprite*> mFrames;
+
+ ///
+ /// Animation playing speed.
///
- std::map<std::string, Clip*> mClips;
- Clip* mCurrentClip;
+ float mSpeed;
};
diff --git a/src/libjin/Graphics/animation/je_clip.cpp b/src/libjin/Graphics/animation/je_animator.cpp
index e69de29..e69de29 100644
--- a/src/libjin/Graphics/animation/je_clip.cpp
+++ b/src/libjin/Graphics/animation/je_animator.cpp
diff --git a/src/libjin/Graphics/animation/je_animator.h b/src/libjin/Graphics/animation/je_animator.h
new file mode 100644
index 0000000..973ff58
--- /dev/null
+++ b/src/libjin/Graphics/animation/je_animator.h
@@ -0,0 +1,48 @@
+#ifndef __JE_ANIMATOR_H
+#define __JE_ANIMATOR_H
+
+#include <map>
+#include <vector>
+#include <string>
+
+#include "je_animation.h"
+
+namespace JinEngine
+{
+ namespace Graphics
+ {
+
+ ///
+ ///
+ ///
+ class Animator
+ {
+ public:
+ void addAnimation(const std::string& key, Animation* clip);
+ bool hasKey(const std::string& key);
+
+ void play();
+ void switchAnimationByKey(const std::string& key);
+ void switchAnimation(const Animation* clip);
+
+ ///
+ /// Control clips.
+ ///
+ void stopAnimation();
+ void pauseAnimation();
+ void rewindAnimation();
+ void startAnimation();
+
+ private:
+ ///
+ /// Map a key to clips.
+ ///
+ std::map<std::string, Animation*> mAnimations;
+ Animation* mCurrentAnimation;
+
+ };
+
+ } // namespace Graphics
+} // namespace JinEngine
+
+#endif \ No newline at end of file
diff --git a/src/libjin/Graphics/animation/je_clip.h b/src/libjin/Graphics/animation/je_clip.h
deleted file mode 100644
index 6b6b0df..0000000
--- a/src/libjin/Graphics/animation/je_clip.h
+++ /dev/null
@@ -1,44 +0,0 @@
-#ifndef __JE_CLIP_H
-#define __JE_CLIP_H
-
-#include <vector>
-#include <string>
-
-#include "../je_sprite.h"
-
-namespace JinEngine
-{
- namespace Graphics
- {
-
- ///
- /// Animation clip with key.
- ///
- class Clip
- {
- public:
- void onUpdate(float dt);
-
- void start();
- void pause();
- void stop();
- void rewind();
- void setSpeed(float speed);
-
- private:
- ///
- /// Key frames.
- ///
- std::vector<Sprite*> mFrames;
-
- ///
- /// Clip playing speed.
- ///
- float mSpeed;
-
- };
-
- } // namespace Graphics
-} // namespace JinEngine
-
-#endif \ No newline at end of file