diff options
author | Alyssa Milburn | 2011-12-08 23:08:34 +0100 |
---|---|---|
committer | Alyssa Milburn | 2011-12-08 23:08:34 +0100 |
commit | 0db0bf45046205f5a55d88896c215dbaa8a9397a (patch) | |
tree | 179e9a8e2701c687d8566eb2b92786f8ce0bad8a /engines | |
parent | 74a5b8db426fed87d1a31cb69b2bd5382eeb3557 (diff) | |
download | scummvm-rg350-0db0bf45046205f5a55d88896c215dbaa8a9397a.tar.gz scummvm-rg350-0db0bf45046205f5a55d88896c215dbaa8a9397a.tar.bz2 scummvm-rg350-0db0bf45046205f5a55d88896c215dbaa8a9397a.zip |
MOHAWK: Name the LB phases, and default to kLBPhaseLoad for v3+.
Diffstat (limited to 'engines')
-rw-r--r-- | engines/mohawk/livingbooks.cpp | 33 | ||||
-rw-r--r-- | engines/mohawk/livingbooks.h | 9 |
2 files changed, 27 insertions, 15 deletions
diff --git a/engines/mohawk/livingbooks.cpp b/engines/mohawk/livingbooks.cpp index f0d918129e..bcc13e2707 100644 --- a/engines/mohawk/livingbooks.cpp +++ b/engines/mohawk/livingbooks.cpp @@ -104,7 +104,7 @@ void LBPage::open(Archive *mhk, uint16 baseId) { _items[i]->init(); for (uint32 i = 0; i < _items.size(); i++) - _items[i]->startPhase(0xFFFE); + _items[i]->startPhase(kLBPhaseLoad); } void LBPage::itemDestroyed(LBItem *item) { @@ -444,9 +444,9 @@ bool MohawkEngine_LivingBooks::loadPage(LBMode mode, uint page, uint subpage) { void MohawkEngine_LivingBooks::updatePage() { switch (_phase) { - case 0: + case kLBPhaseInit: for (uint32 i = 0; i < _items.size(); i++) - _items[i]->startPhase(0xFFFF); + _items[i]->startPhase(kLBPhaseCreate); for (uint32 i = 0; i < _items.size(); i++) _items[i]->startPhase(_phase); @@ -542,7 +542,7 @@ void MohawkEngine_LivingBooks::updatePage() { _phase++; break; - case 1: + case kLBPhaseIntro: for (uint32 i = 0; i < _items.size(); i++) _items[i]->startPhase(_phase); @@ -555,7 +555,7 @@ void MohawkEngine_LivingBooks::updatePage() { _phase++; break; - case 2: + case kLBPhaseMain: if (!_introDone) break; @@ -1954,7 +1954,10 @@ LBScriptEntry::~LBScriptEntry() { } LBItem::LBItem(MohawkEngine_LivingBooks *vm, LBPage *page, Common::Rect rect) : _vm(vm), _page(page), _rect(rect) { - _phase = 0; + if (_vm->getGameType() == GType_LIVINGBOOKSV1 || _vm->getGameType() == GType_LIVINGBOOKSV2) + _phase = kLBPhaseInit; + else + _phase = kLBPhaseLoad; _loopMode = 0; _delayMin = 0; @@ -2446,7 +2449,7 @@ bool LBItem::contains(Common::Point point) { } void LBItem::update() { - if (_phase != 0x7FFF && (!_loaded || !_enabled || !_globalEnabled)) + if (_phase != kLBPhaseNone && (!_loaded || !_enabled || !_globalEnabled)) return; if (_nextTime == 0 || _nextTime > (uint32)(_vm->_system->getMillis() / 16)) @@ -2484,7 +2487,7 @@ bool LBItem::togglePlaying(bool playing, bool restart) { _vm->queueDelayedEvent(DelayedEvent(this, kLBDelayedEventDone)); return true; } - if (((_loaded && _enabled && _globalEnabled) || _phase == 0x7FFF) && !_playing) { + if (((_loaded && _enabled && _globalEnabled) || _phase == kLBPhaseNone) && !_playing) { _playing = togglePlaying(true, restart); if (_playing) { _nextTime = 0; @@ -2574,7 +2577,7 @@ void LBItem::setGlobalVisible(bool visible) { void LBItem::startPhase(uint phase) { if (_phase == phase) { - if (_phase != 0x7fff) { + if (_phase != kLBPhaseNone) { setEnabled(true); } @@ -2582,31 +2585,31 @@ void LBItem::startPhase(uint phase) { } switch (phase) { - case 0xFFFE: + case kLBPhaseLoad: runScript(kLBEventListLoad); break; - case 0xFFFF: + case kLBPhaseCreate: runScript(kLBEventPhaseCreate); if (_timingMode == kLBAutoCreate) { debug(2, "Phase create: time startup"); setNextTime(_periodMin, _periodMax); } break; - case 0: + case kLBPhaseInit: runScript(kLBEventPhaseInit); if (_timingMode == kLBAutoInit) { debug(2, "Phase init: time startup"); setNextTime(_periodMin, _periodMax); } break; - case 1: + case kLBPhaseIntro: runScript(kLBEventPhaseIntro); if (_timingMode == kLBAutoIntro || _timingMode == kLBAutoUserIdle) { debug(2, "Phase intro: time startup"); setNextTime(_periodMin, _periodMax); } break; - case 2: + case kLBPhaseMain: runScript(kLBEventPhaseMain); if (_timingMode == kLBAutoUserIdle || _timingMode == kLBAutoMain) { debug(2, "Phase main: time startup"); @@ -3720,7 +3723,7 @@ void LBMovieItem::update() { bool LBMovieItem::togglePlaying(bool playing, bool restart) { if (playing) { - if ((_loaded && _enabled && _globalEnabled) || _phase == 0x7FFF) { + if ((_loaded && _enabled && _globalEnabled) || _phase == kLBPhaseNone) { _vm->_video->playMovie(_resourceId, _rect.left, _rect.top); return true; diff --git a/engines/mohawk/livingbooks.h b/engines/mohawk/livingbooks.h index 28dd49e78a..0a7c4f0965 100644 --- a/engines/mohawk/livingbooks.h +++ b/engines/mohawk/livingbooks.h @@ -68,6 +68,15 @@ enum LBMode { kLBPlayMode = 6 }; +enum { + kLBPhaseInit = 0x0, + kLBPhaseIntro = 0x1, + kLBPhaseMain = 0x2, + kLBPhaseNone = 0x7fff, + kLBPhaseLoad = 0xfffe, + kLBPhaseCreate = 0xffff +}; + // automatic modes used in _timingMode enum { kLBAutoNone = 0, |