[Scummvm-cvs-logs] SF.net SVN: scummvm:[55207]	scummvm/trunk/engines/mohawk
    mthreepwood at users.sourceforge.net 
    mthreepwood at users.sourceforge.net
       
    Tue Jan 11 20:44:55 CET 2011
    
    
  
Revision: 55207
          http://scummvm.svn.sourceforge.net/scummvm/?rev=55207&view=rev
Author:   mthreepwood
Date:     2011-01-11 19:44:55 +0000 (Tue, 11 Jan 2011)
Log Message:
-----------
MOHAWK: Implement Riven's whark number puzzle
Modified Paths:
--------------
    scummvm/trunk/engines/mohawk/riven_external.cpp
    scummvm/trunk/engines/mohawk/riven_external.h
    scummvm/trunk/engines/mohawk/riven_saveload.cpp
Modified: scummvm/trunk/engines/mohawk/riven_external.cpp
===================================================================
--- scummvm/trunk/engines/mohawk/riven_external.cpp	2011-01-11 19:23:24 UTC (rev 55206)
+++ scummvm/trunk/engines/mohawk/riven_external.cpp	2011-01-11 19:44:55 UTC (rev 55207)
@@ -144,6 +144,8 @@
 	COMMAND(xjlagoon800_alert);
 	COMMAND(xjlagoon1500_alert);
 	COMMAND(xschool280_playwhark);
+	COMMAND(xjschool280_resetleft);
+	COMMAND(xjschool280_resetright);
 	COMMAND(xjatboundary);
 
 	// ospit (Gehn's Office) external commands
@@ -1493,8 +1495,80 @@
 	}
 }
 
+void RivenExternal::xjschool280_resetleft(uint16 argc, uint16 *argv) {
+	// Dummy function. This resets the unneeded video timing variable (dropLeftStart) in
+	// the DVD version.
+}
+
+void RivenExternal::xjschool280_resetright(uint16 argc, uint16 *argv) {
+	// Dummy function. This resets the unneeded video timing variable (dropRightStart) in
+	// the DVD version.
+}
+
+void RivenExternal::redrawWharkNumberPuzzle(uint16 overlay, uint16 number) {
+	// Update the screen for the whark number puzzle
+	// We don't update the whole screen here because we don't want to overwrite the video data
+	_vm->_gfx->drawPLST(overlay);
+	_vm->_gfx->drawPLST(number + 1);
+	_vm->_gfx->updateScreen(Common::Rect(80, 212, 477, 392));
+	_vm->_system->updateScreen();
+}
+
 void RivenExternal::xschool280_playwhark(uint16 argc, uint16 *argv) {
-	// TODO: The "monstrous" whark puzzle that teaches the number system
+	// The "monstrous" whark puzzle that teaches the number system
+
+	uint32 *posVar;
+	uint16 spinMLST, overlayPLST, doomMLST, snackMLST;
+
+	// Choose left or right based on jwharkpos (which is set by the scripts)
+	if (*_vm->getVar("jwharkpos") == 1) {
+		posVar = _vm->getVar("jleftpos");
+		spinMLST = 1;
+		overlayPLST = 12;
+		doomMLST = 3;
+		snackMLST = 4;
+	} else {
+		posVar = _vm->getVar("jrightpos");
+		spinMLST = 2;
+		overlayPLST = 13;
+		doomMLST = 5;
+		snackMLST = 6;
+	}
+
+	// Hide the cursor
+	_vm->_cursor->setCursor(kRivenHideCursor);
+
+	// Play the spin movie
+	_vm->_video->playMovieBlocking(spinMLST);
+
+	// Get our random number and redraw the area
+	uint16 number = _vm->_rnd->getRandomNumberRng(1, 10);
+	redrawWharkNumberPuzzle(overlayPLST, number);
+
+	// Handle movement
+	// (11560/600)s is the length of each of the two movies. We divide it into 19 parts
+	// (one for each of the possible positions the villager can have).
+	VideoHandle handle = _vm->_video->playMovie(doomMLST);
+	Graphics::VideoTimestamp startTime = Graphics::VideoTimestamp((11560 / 19) * (*posVar), 600);
+	*posVar += number; // Adjust to the end
+	Graphics::VideoTimestamp endTime = Graphics::VideoTimestamp((11560 / 19) * (*posVar), 600);
+	_vm->_video->setVideoBounds(handle, startTime, endTime);
+	_vm->_video->waitUntilMovieEnds(handle);
+
+	if (*posVar > 19) {
+		// The villager has died :(
+		_vm->_video->playMovieBlocking(snackMLST);
+		redrawWharkNumberPuzzle(overlayPLST, number);
+		*posVar = 0;
+	}
+
+	// Enable the correct hotspots for the movement now
+	_vm->_hotspots[2].enabled = !_vm->_hotspots[2].enabled;
+	_vm->_hotspots[3].enabled = !_vm->_hotspots[3].enabled;
+
+	// Update the cursor
+	_vm->_curHotspot = -1;
+	_vm->checkHotspotChange();
 }
 
 void RivenExternal::xjatboundary(uint16 argc, uint16 *argv) {
Modified: scummvm/trunk/engines/mohawk/riven_external.h
===================================================================
--- scummvm/trunk/engines/mohawk/riven_external.h	2011-01-11 19:23:24 UTC (rev 55206)
+++ scummvm/trunk/engines/mohawk/riven_external.h	2011-01-11 19:44:55 UTC (rev 55207)
@@ -72,6 +72,7 @@
 	void drawDomeSliders(uint16 startHotspot);
 	void drawMarbles();
 	void setMarbleHotspots();
+	void redrawWharkNumberPuzzle(uint16 overlay, uint16 number);
 
 	// -----------------------------------------------------
 	// aspit (Main Menu, Books, Setup) external commands
@@ -194,6 +195,8 @@
 	void xjlagoon1500_alert(uint16 argc, uint16 *argv);
 	// Play the Whark Game
 	void xschool280_playwhark(uint16 argc, uint16 *argv);
+	void xjschool280_resetleft(uint16 argc, uint16 *argv); // DVD only
+	void xjschool280_resetright(uint16 argc, uint16 *argv); // DVD only
 	// jspit Demo-specific commands
 	void xjatboundary(uint16 argc, uint16 *argv);
 
Modified: scummvm/trunk/engines/mohawk/riven_saveload.cpp
===================================================================
--- scummvm/trunk/engines/mohawk/riven_saveload.cpp	2011-01-11 19:23:24 UTC (rev 55206)
+++ scummvm/trunk/engines/mohawk/riven_saveload.cpp	2011-01-11 19:44:55 UTC (rev 55207)
@@ -147,7 +147,7 @@
 	uint16 stackID = 0;
 	uint16 cardID = 0;
 
-	for (uint32 i = 0; i < rawVariables.size() && i < namesCount && !names->eos(); i++) {
+	for (uint32 i = 0; i < namesCount && !names->eos(); i++) {
 		names->seek(curNamesPos);
 		names->seek(stringOffsets[i], SEEK_CUR);
 
@@ -159,10 +159,9 @@
 			c = (char)names->readByte();
 		}
 
-		// TODO: Some versions have two extra variables. However, the saves are
-		// still compatible with other saves of the same version (they come from DVD v1.1).
-		// There are used in the whark number puzzle. I thought jleftpos and jrightpos were
-		// for this purpose.
+		// These are timing variables used with the DVD version of Riven for the whark
+		// puzzle and are not needed at all. See xjschool280_resetleft() and
+		// xjschool280_resetright.
 		if (name == "dropLeftStart" || name == "dropRightStart")
 			continue;
 
This was sent by the SourceForge.net collaborative development platform, the world's largest Open Source development site.
    
    
More information about the Scummvm-git-logs
mailing list