diff options
author | Paweł Kołodziejski | 2003-01-25 19:02:44 +0000 |
---|---|---|
committer | Paweł Kołodziejski | 2003-01-25 19:02:44 +0000 |
commit | 9ec9a96af152c057c2765feb49031a0347d35203 (patch) | |
tree | ed5b8cf3d18b2e5c90e228ecd06aa40a247ec4a6 | |
parent | 8e8575003bbfecfad605dc3fa8b3723d3f55027d (diff) | |
download | scummvm-rg350-9ec9a96af152c057c2765feb49031a0347d35203.tar.gz scummvm-rg350-9ec9a96af152c057c2765feb49031a0347d35203.tar.bz2 scummvm-rg350-9ec9a96af152c057c2765feb49031a0347d35203.zip |
applied patch: [ 674566 ] CMI: Further smush syncing
svn-id: r6539
-rw-r--r-- | scumm/smush/scumm_renderer.cpp | 29 | ||||
-rw-r--r-- | scumm/smush/scumm_renderer.h | 2 |
2 files changed, 20 insertions, 11 deletions
diff --git a/scumm/smush/scumm_renderer.cpp b/scumm/smush/scumm_renderer.cpp index 9947a5e380..0d04d541b7 100644 --- a/scumm/smush/scumm_renderer.cpp +++ b/scumm/smush/scumm_renderer.cpp @@ -199,7 +199,8 @@ bool ScummMixer::stop() { ScummRenderer::ScummRenderer(Scumm * scumm, uint32 speed) : _scumm(scumm), _smixer(0), - _insaneSpeed(speed) { + _insaneSpeed(speed), + _pending_updates(0) { } static ScummRenderer * s_renderer; @@ -239,9 +240,12 @@ ScummRenderer::~ScummRenderer() { } bool ScummRenderer::wait(int32 ms) { - while(_wait) { - _scumm->waitForTimer(1); - } + // Because waitForTimer() also is the function that checks for user + // input we always want to call it at least once between frames, or + // the user may become unable to interrupt the movie. + do { + _scumm->waitForTimer(1); + } while(_pending_updates <= 0); return true; } @@ -276,20 +280,25 @@ void ScummRenderer::save(int32 frame) { int width = MIN(getWidth(), _scumm->_realWidth); int height = MIN(getHeight(), _scumm->_realHeight); - _scumm->_system->copy_rect((const byte *)data(), getWidth(), 0, 0, width, height); - _scumm->_system->update_screen(); + + // In theory, this will always be true. In reality, there may be + // several pending updates because the computer wasn't fast enough to + // process them all. In that case, skip the frame to catch up. + if (--_pending_updates <= 0) { + _scumm->_system->copy_rect((const byte *)data(), getWidth(), 0, 0, width, height); + _scumm->_system->update_screen(); + } else { + warning("ScummRenderer: Skipping frame %d to catch up", getFrame()); + } _scumm->processKbd(); - _wait = true; } bool ScummRenderer::prematureClose() { - return _scumm->_videoFinished || _scumm->_saveLoadFlag; - } bool ScummRenderer::update() { - _wait = false; + _pending_updates++; return true; } diff --git a/scumm/smush/scumm_renderer.h b/scumm/smush/scumm_renderer.h index d59e586c47..48b770dc96 100644 --- a/scumm/smush/scumm_renderer.h +++ b/scumm/smush/scumm_renderer.h @@ -45,7 +45,7 @@ private: Scumm * _scumm; ScummMixer * _smixer; uint32 _insaneSpeed; - volatile bool _wait; + volatile int _pending_updates; public: ScummRenderer(Scumm * scumm, uint32 speed); virtual ~ScummRenderer(); |