diff options
author | Matthew Hoops | 2011-01-18 00:42:16 +0000 |
---|---|---|
committer | Matthew Hoops | 2011-01-18 00:42:16 +0000 |
commit | 2a808be80436e84a93742b039fadec924897c884 (patch) | |
tree | 4e40b7df05d5715a5be8426ff6182947d149a9be /engines/mohawk | |
parent | f042e398eaea1bc15f76fd1739f98b3245c33cd0 (diff) | |
download | scummvm-rg350-2a808be80436e84a93742b039fadec924897c884.tar.gz scummvm-rg350-2a808be80436e84a93742b039fadec924897c884.tar.bz2 scummvm-rg350-2a808be80436e84a93742b039fadec924897c884.zip |
MOHAWK: Implement xgrviewer so the right viewer on gspit is usable
svn-id: r55282
Diffstat (limited to 'engines/mohawk')
-rw-r--r-- | engines/mohawk/riven_external.cpp | 30 |
1 files changed, 29 insertions, 1 deletions
diff --git a/engines/mohawk/riven_external.cpp b/engines/mohawk/riven_external.cpp index 59447bd696..22f778a78e 100644 --- a/engines/mohawk/riven_external.cpp +++ b/engines/mohawk/riven_external.cpp @@ -1239,7 +1239,35 @@ void RivenExternal::xgplaywhark(uint16 argc, uint16 *argv) { } void RivenExternal::xgrviewer(uint16 argc, uint16 *argv) { - // TODO: Image viewer related + // This controls the viewer on the right side of the 'throne' on Garden Island + // (It shows the colors of the marbles) + + // If the light is on, turn it off + uint32 *viewerLight = _vm->getVar("grview"); + if (*viewerLight == 1) { + *viewerLight = 0; + _vm->_sound->playSound(27); + _vm->refreshCard(); + + // Delay a bit before turning + _vm->_system->delayMillis(200); + } + + // Calculate how much we're moving + static const uint16 hotspotPositions[] = { 2, 1, 5, 4, 3 }; + uint32 *curPos = _vm->getVar("grviewpos"); + uint32 newPos = *curPos + hotspotPositions[_vm->_curHotspot - 1]; + + // Now play the movie + static const uint16 timeIntervals[] = { 0, 816, 1617, 2416, 3216, 4016, 4816, 5616, 6416, 7216, 8016, 8816 }; + VideoHandle handle = _vm->_video->playMovie(1); + assert(handle != NULL_VID_HANDLE); + _vm->_video->setVideoBounds(handle, Graphics::VideoTimestamp(timeIntervals[*curPos], 600), Graphics::VideoTimestamp(timeIntervals[newPos], 600)); + _vm->_video->waitUntilMovieEnds(handle); + + // Set the new position and let the card's scripts take over again + *curPos = newPos % 6; // Clip it to 0-5 + _vm->refreshCard(); } void RivenExternal::xgwharksnd(uint16 argc, uint16 *argv) { |