diff options
author | Andrei Karas <akaras@inbox.ru> | 2012-03-20 01:48:55 +0300 |
---|---|---|
committer | Andrei Karas <akaras@inbox.ru> | 2012-03-20 01:48:55 +0300 |
commit | 66d5da1cb7e1551ac019a08075896ba04b172e36 (patch) | |
tree | 4e574c152b7094ee10ce91c25ce2a1750d6abda2 | |
parent | d8505394ee7e109c3fd1d35450ed106a5ceefcfb (diff) | |
download | mv-66d5da1cb7e1551ac019a08075896ba04b172e36.tar.gz mv-66d5da1cb7e1551ac019a08075896ba04b172e36.tar.bz2 mv-66d5da1cb7e1551ac019a08075896ba04b172e36.tar.xz mv-66d5da1cb7e1551ac019a08075896ba04b172e36.zip |
Fix tiles animation in opengl mode in non fringe layers.
-rw-r--r-- | src/map.cpp | 12 | ||||
-rw-r--r-- | src/map.h | 6 | ||||
-rw-r--r-- | src/simpleanimation.cpp | 8 | ||||
-rw-r--r-- | src/simpleanimation.h | 2 |
4 files changed, 18 insertions, 10 deletions
diff --git a/src/map.cpp b/src/map.cpp index d983508b1..b649922ae 100644 --- a/src/map.cpp +++ b/src/map.cpp @@ -95,13 +95,14 @@ TileAnimation::~TileAnimation() mAnimation = nullptr; } -void TileAnimation::update(int ticks) +bool TileAnimation::update(int ticks) { if (!mAnimation) - return; + return false; // update animation - mAnimation->update(ticks); + if (!mAnimation->update(ticks)) + return false; // exchange images Image *img = mAnimation->getCurrentImage(); @@ -115,6 +116,7 @@ void TileAnimation::update(int ticks) } mLastImage = img; } + return true; } Map::Map(int width, int height, int tileWidth, int tileHeight): @@ -306,8 +308,8 @@ void Map::update(int ticks) iAni = mTileAnimations.begin(); iAni != mTileAnimations.end(); ++iAni) { - if (iAni->second) - iAni->second->update(ticks); + if (iAni->second && iAni->second->update(ticks)) + mRedrawMap = true; } } @@ -75,10 +75,14 @@ class TileAnimation { public: TileAnimation(Animation *ani); + ~TileAnimation(); - void update(int ticks = 1); + + bool update(int ticks = 1); + void addAffectedTile(MapLayer *layer, int index) { mAffected.push_back(std::make_pair(layer, index)); } + private: std::vector<std::pair<MapLayer*, int> > mAffected; SimpleAnimation *mAnimation; diff --git a/src/simpleanimation.cpp b/src/simpleanimation.cpp index 2b7cc328d..89431a916 100644 --- a/src/simpleanimation.cpp +++ b/src/simpleanimation.cpp @@ -93,11 +93,12 @@ void SimpleAnimation::setFrame(int frame) mCurrentFrame = mAnimation->getFrame(mAnimationPhase); } -void SimpleAnimation::update(int timePassed) +bool SimpleAnimation::update(int timePassed) { if (!mCurrentFrame || !mAnimation) - return; + return false; + bool updated(false); if (mInitialized && mAnimation) { mAnimationTime += timePassed; @@ -105,6 +106,7 @@ void SimpleAnimation::update(int timePassed) while (mAnimationTime > mCurrentFrame->delay && mCurrentFrame->delay > 0) { + updated = true; mAnimationTime -= mCurrentFrame->delay; mAnimationPhase++; @@ -117,7 +119,7 @@ void SimpleAnimation::update(int timePassed) mCurrentFrame = mAnimation->getFrame(mAnimationPhase); } } - + return updated; } int SimpleAnimation::getLength() const diff --git a/src/simpleanimation.h b/src/simpleanimation.h index de1203662..a7355a929 100644 --- a/src/simpleanimation.h +++ b/src/simpleanimation.h @@ -56,7 +56,7 @@ class SimpleAnimation int getLength() const; - void update(int timePassed); + bool update(int timePassed); bool draw(Graphics *graphics, int posX, int posY) const; |