diff options
author | Paweł Kołodziejski | 2004-04-26 09:04:08 +0000 |
---|---|---|
committer | Paweł Kołodziejski | 2004-04-26 09:04:08 +0000 |
commit | 17332e393ef369acae3a43a25f859bd52f8022ed (patch) | |
tree | efcb352f82aff073f2ac1693131c5dfd09069e99 /scumm | |
parent | 883fdfdb7caba62c07dcc8bdaf59a4fc2e75f3fb (diff) | |
download | scummvm-rg350-17332e393ef369acae3a43a25f859bd52f8022ed.tar.gz scummvm-rg350-17332e393ef369acae3a43a25f859bd52f8022ed.tar.bz2 scummvm-rg350-17332e393ef369acae3a43a25f859bd52f8022ed.zip |
added mutex into smush player
svn-id: r13639
Diffstat (limited to 'scumm')
-rw-r--r-- | scumm/smush/smush_player.cpp | 22 | ||||
-rw-r--r-- | scumm/smush/smush_player.h | 3 |
2 files changed, 15 insertions, 10 deletions
diff --git a/scumm/smush/smush_player.cpp b/scumm/smush/smush_player.cpp index 67c6fa4dc7..5cb3a5ec04 100644 --- a/scumm/smush/smush_player.cpp +++ b/scumm/smush/smush_player.cpp @@ -217,6 +217,8 @@ void SmushPlayer::timerCallback(void *refCon) { SmushPlayer::SmushPlayer(ScummEngine_v6 *scumm, int speed) { _vm = scumm; + _mutex = g_system->createMutex(); + _version = -1; _nbframes = 0; _smixer = 0; @@ -245,27 +247,28 @@ SmushPlayer::SmushPlayer(ScummEngine_v6 *scumm, int speed) { } SmushPlayer::~SmushPlayer() { - deinit(); + release(); + g_system->deleteMutex(_mutex); } void SmushPlayer::init() { - + Common::StackLock lock(_mutex, "SmushPlayer::init()"); _frame = 0; - _vm->_videoFinished = false; - - _smixer = new SmushMixer(_vm->_mixer); - _vm->setDirtyColors(0, 255); _dst = _vm->virtscr[0].screenPtr + _vm->virtscr[0].xstart; + _smixer = new SmushMixer(_vm->_mixer); g_timer->installTimerProc(&timerCallback, _speed, this); _alreadyInit = false; } -void SmushPlayer::deinit() { +void SmushPlayer::release() { + Common::StackLock lock(_mutex, "SmushPlayer::release()"); _vm->_timer->removeTimerProc(&timerCallback); + _vm->_videoFinished = true; + for (int i = 0; i < 5; i++) { if (_sf[i]) { delete _sf[i]; @@ -956,6 +959,7 @@ void SmushPlayer::setupAnim(const char *file, const char *directory) { } void SmushPlayer::parseNextFrame() { + Common::StackLock lock(_mutex, "SmushPlayer::parseNextFrame()"); if (_vm->_smushPaused) return; @@ -1150,8 +1154,8 @@ void SmushPlayer::play(const char *filename, const char *directory, int32 offset _vm->_system->delay_msecs(10); }; - deinit(); - + release(); + // Reset mouse state _vm->_system->showMouse(oldMouseState); } diff --git a/scumm/smush/smush_player.h b/scumm/smush/smush_player.h index 019edef85f..2b155f3e27 100644 --- a/scumm/smush/smush_player.h +++ b/scumm/smush/smush_player.h @@ -42,6 +42,7 @@ private: int _version; int32 _nbframes; SmushMixer *_smixer; + OSystem::MutexRef _mutex; int16 _deltaPal[0x300]; byte _pal[0x300]; StringResource *_strings; @@ -91,7 +92,7 @@ private: void updatePalette(void); void parseNextFrame(); void init(); - void deinit(); + void release(); void setupAnim(const char *file, const char *directory); void updateScreen(); |