diff options
author | Denis Kasak | 2009-07-03 19:05:58 +0000 |
---|---|---|
committer | Denis Kasak | 2009-07-03 19:05:58 +0000 |
commit | a4e6464a63fdf109df39c3c3106e1b3cd84bf5a7 (patch) | |
tree | 0d72528bfca99cc9db24ab6d03acc6b89637d3ce | |
parent | 63d0fdea68f8f43a84a22d7e8a72eef5a862a20a (diff) | |
download | scummvm-rg350-a4e6464a63fdf109df39c3c3106e1b3cd84bf5a7.tar.gz scummvm-rg350-a4e6464a63fdf109df39c3c3106e1b3cd84bf5a7.tar.bz2 scummvm-rg350-a4e6464a63fdf109df39c3c3106e1b3cd84bf5a7.zip |
Added support for playing and stopping animations.
svn-id: r42075
-rw-r--r-- | engines/draci/animation.cpp | 28 | ||||
-rw-r--r-- | engines/draci/animation.h | 11 |
2 files changed, 33 insertions, 6 deletions
diff --git a/engines/draci/animation.cpp b/engines/draci/animation.cpp index 94c12d1c51..5e6578de57 100644 --- a/engines/draci/animation.cpp +++ b/engines/draci/animation.cpp @@ -28,16 +28,31 @@ namespace Draci { -void Animation::addAnimation(uint id, uint z) { +void Animation::addAnimation(uint id, uint z, bool playing) { AnimObj *obj = new AnimObj(); obj->_id = id; obj->_z = z; obj->_currentFrame = 0; + obj->_playing = playing; insertAnimation(*obj); } +void Animation::play(uint id) { + + AnimObj &obj = *getAnimation(id); + + obj._playing = true; +} + +void Animation::stop(uint id) { + + AnimObj &obj = *getAnimation(id); + + obj._playing = false; +} + Common::List<AnimObj>::iterator Animation::getAnimation(uint id) { Common::List<AnimObj>::iterator it; @@ -75,6 +90,7 @@ void Animation::addOverlay(Drawable *overlay, uint z) { obj->_id = kOverlayImage; obj->_z = z; obj->_currentFrame = 0; + obj->_playing = true; obj->_frames.push_back(overlay); insertAnimation(*obj); @@ -85,7 +101,11 @@ void Animation::drawScene(Surface *surf) { Common::List<AnimObj>::iterator it; for (it = _animObjects.begin(); it != _animObjects.end(); ++it) { - if(it->_id == kOverlayImage) { + if (!it->_playing) { + continue; + } + + if (it->_id == kOverlayImage) { it->_frames[it->_currentFrame]->draw(surf, false); } else { @@ -98,7 +118,7 @@ void Animation::deleteAnimation(uint id) { Common::List<AnimObj>::iterator it = getAnimation(id); - for(uint i = 0; i < it->_frames.size(); ++i) { + for (uint i = 0; i < it->_frames.size(); ++i) { delete it->_frames[i]; } @@ -110,7 +130,7 @@ void Animation::deleteAll() { Common::List<AnimObj>::iterator it; for (it = _animObjects.begin(); it != _animObjects.end(); ++it) { - for(uint i = 0; i < it->_frames.size(); ++i) { + for (uint i = 0; i < it->_frames.size(); ++i) { delete it->_frames[i]; } } diff --git a/engines/draci/animation.h b/engines/draci/animation.h index c654155a03..c69947ea28 100644 --- a/engines/draci/animation.h +++ b/engines/draci/animation.h @@ -38,6 +38,7 @@ struct AnimObj { uint _id; uint _currentFrame; uint _z; + bool _playing; Common::Array<Drawable*> _frames; }; @@ -47,12 +48,18 @@ public: Animation(DraciEngine *vm) : _vm(vm) {}; ~Animation() { deleteAll(); } - void addAnimation(uint id, uint z = 0); + void addAnimation(uint id, uint z, bool playing = false); void addFrame(uint id, Drawable *frame); - void addOverlay(Drawable *overlay, uint z = 0); + void addOverlay(Drawable *overlay, uint z); + + void play(uint id); + void stop(uint id); + void deleteAnimation(uint id); void deleteAll(); + void drawScene(Surface *surf); + Common::List<AnimObj>::iterator getAnimation(uint id); private: |