aboutsummaryrefslogtreecommitdiff
path: root/scumm/smush/smush_player.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'scumm/smush/smush_player.cpp')
-rw-r--r--scumm/smush/smush_player.cpp8
1 files changed, 7 insertions, 1 deletions
diff --git a/scumm/smush/smush_player.cpp b/scumm/smush/smush_player.cpp
index bf67ee2ed0..e3bd305ea4 100644
--- a/scumm/smush/smush_player.cpp
+++ b/scumm/smush/smush_player.cpp
@@ -220,6 +220,7 @@ void SmushPlayer::timerCallback(void *refCon) {
((SmushPlayer *)refCon)->parseNextFrame();
#ifdef _WIN32_WCE
((SmushPlayer *)refCon)->_inTimer = true;
+ ((SmushPlayer *)refCon)->_inTimerCount++;
#endif
}
@@ -254,6 +255,8 @@ SmushPlayer::SmushPlayer(ScummEngine_v6 *scumm, int speed) {
_skipPalette = false;
#ifdef _WIN32_WCE
_inTimer = false;
+ _inTimerCount = 0;
+ _inTimerCountRedraw = ConfMan.getInt("Smush_force_redraw");
#endif
}
@@ -948,8 +951,10 @@ void SmushPlayer::handleFrame(Chunk &b) {
end_time = _vm->_system->getMillis();
#ifdef _WIN32_WCE
- if (!_inTimer)
+ if (!_inTimer || _inTimerCount == _inTimerCountRedraw) {
updateScreen();
+ _inTimerCount = 0;
+ }
#else
updateScreen();
#endif
@@ -1249,6 +1254,7 @@ void SmushPlayer::play(const char *filename, int32 offset, int32 startFrame) {
_updateNeeded = false;
#ifdef _WIN32_WCE
_inTimer = false;
+ _inTimerCount = 0;
#endif
end_time = _vm->_system->getMillis();