aboutsummaryrefslogtreecommitdiff
path: root/engines/access
diff options
context:
space:
mode:
authorStrangerke2014-11-24 23:29:57 +0100
committerPaul Gilbert2014-12-12 22:43:14 -0500
commitf1b99b0ede325c1f447ce79e2c00159871ee1462 (patch)
treeddd1d3016070f0bde5f18503292e3c8bc4499829 /engines/access
parent51ccd0c1fbbb2065441e6c7fbbe7f6ec6c3c3e3e (diff)
downloadscummvm-rg350-f1b99b0ede325c1f447ce79e2c00159871ee1462.tar.gz
scummvm-rg350-f1b99b0ede325c1f447ce79e2c00159871ee1462.tar.bz2
scummvm-rg350-f1b99b0ede325c1f447ce79e2c00159871ee1462.zip
ACCESS: Implement plotRiver
Diffstat (limited to 'engines/access')
-rw-r--r--engines/access/amazon/amazon_scripts.cpp45
-rw-r--r--engines/access/amazon/amazon_scripts.h2
2 files changed, 38 insertions, 9 deletions
diff --git a/engines/access/amazon/amazon_scripts.cpp b/engines/access/amazon/amazon_scripts.cpp
index 5e53e0b946..2c16938ea8 100644
--- a/engines/access/amazon/amazon_scripts.cpp
+++ b/engines/access/amazon/amazon_scripts.cpp
@@ -1903,11 +1903,10 @@ void AmazonScripts::UPDATEOBSTACLES() {
void AmazonScripts::riverSetPhysX() {
int val = (_vm->_screen->_scrollCol * 16) + _vm->_screen->_scrollX;
- RiverStruct *si = _game->_topList;
- RiverStruct *di = _game->_botList;
- while (si <= di) {
- si[0]._field5 = val - (_screenVertX - si[0]._field3);
- si = &si[1];
+ RiverStruct *cur = _game->_topList;
+ while (cur <= _game->_botList) {
+ cur[0]._field5 = val - (_screenVertX - cur[0]._field3);
+ ++cur;
}
}
@@ -1915,14 +1914,44 @@ void AmazonScripts::RIVERCOLLIDE() {
warning("TODO: RIVERCOLLIDE()");
}
-void AmazonScripts::PLOTRIVER() {
- warning("TODO: PLOTRIVER");
+void AmazonScripts::plotRiver() {
+ if (_vm->_timers[3]._flag == 0) {
+ ++_vm->_timers[3]._flag;
+ if (_game->_canoeFrame == 12)
+ _game->_canoeFrame = 0;
+ else
+ ++_game->_canoeFrame;
+ }
+
+ ImageEntry ie;
+ ie._flags = 8;
+ ie._spritesPtr = _vm->_objectsTable[45];
+ ie._frameNumber = _game->_canoeFrame;
+ ie._position.x = (_vm->_screen->_scrollCol * 16) + _vm->_screen->_scrollX + 160;
+ ie._position.y = _game->_canoeYPos - 41;
+ ie._offsetY = 41;
+ _vm->_images.addToList(ie);
+
+ RiverStruct *cur = _game->_topList;
+ while (cur <= _game->_botList) {
+ if (cur[0]._id != -1) {
+ ie._flags = 8;
+ ie._spritesPtr = _vm->_objectsTable[45];
+ ie._frameNumber = 0;
+ ie._position.x = cur[0]._field5;
+ int val = (cur[0]._lane * 5) + 56;
+ ie._position.y = val - cur[0]._field8;
+ ie._offsetY = cur[0]._field8;
+ _vm->_images.addToList(ie);
+ }
+ ++cur;
+ }
}
void AmazonScripts::scrollRiver1() {
_vm->copyBF1BF2();
_vm->_newRects.clear();
- PLOTRIVER();
+ plotRiver();
_vm->plotList();
_vm->copyRects();
_vm->copyBF2Vid();
diff --git a/engines/access/amazon/amazon_scripts.h b/engines/access/amazon/amazon_scripts.h
index 20fca8ea70..ef7ead60c9 100644
--- a/engines/access/amazon/amazon_scripts.h
+++ b/engines/access/amazon/amazon_scripts.h
@@ -104,7 +104,7 @@ protected:
void UPDATEOBSTACLES();
void riverSetPhysX();
void RIVERCOLLIDE();
- void PLOTRIVER();
+ void plotRiver();
void scrollRiver1();
void setRiverPan();
void RIVER();