aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/mads/nebular/nebular_scenes4.cpp47
-rw-r--r--engines/mads/nebular/nebular_scenes4.h6
2 files changed, 48 insertions, 5 deletions
diff --git a/engines/mads/nebular/nebular_scenes4.cpp b/engines/mads/nebular/nebular_scenes4.cpp
index 1bb53ed857..91c522cd25 100644
--- a/engines/mads/nebular/nebular_scenes4.cpp
+++ b/engines/mads/nebular/nebular_scenes4.cpp
@@ -2729,6 +2729,12 @@ void Scene406::actions() {
_action._inProgress = false;
}
+void Scene406::synchronize(Common::Serializer &s) {
+ Scene4xx::synchronize(s);
+
+ s.syncAsByte(_hitStorageDoor);
+}
+
/*------------------------------------------------------------------------*/
void Scene407::setup() {
@@ -2782,16 +2788,16 @@ void Scene407::preActions() {
if (_game._player._needToWalk && _fromNorth) {
if (_globals[kSexOfRex] == REX_MALE)
- destPos = Common::Point(171, 95);
+ _destPos = Common::Point(171, 95);
else
- destPos = Common::Point(173, 96);
+ _destPos = Common::Point(173, 96);
- _game._player.walk(destPos, FACING_SOUTH);
+ _game._player.walk(_destPos, FACING_SOUTH);
}
}
void Scene407::actions() {
- if ((_game._player._playerPos == destPos) && _fromNorth) {
+ if ((_game._player._playerPos == _destPos) && _fromNorth) {
if (_globals[kSexOfRex] == REX_MALE) {
_game._triggerSetupMode = SEQUENCE_TRIGGER_DAEMON;
_game._player._stepEnabled = false;
@@ -2837,6 +2843,14 @@ void Scene407::actions() {
_action._inProgress = false;
}
+void Scene407::synchronize(Common::Serializer &s) {
+ Scene4xx::synchronize(s);
+
+ s.syncAsByte(_fromNorth);
+ s.syncAsSint16LE(_destPos.x);
+ s.syncAsSint16LE(_destPos.y);
+}
+
/*------------------------------------------------------------------------*/
void Scene408::setup() {
@@ -3957,6 +3971,24 @@ void Scene411::actions() {
_action._inProgress = false;
}
+void Scene411::synchronize(Common::Serializer &s) {
+ Scene4xx::synchronize(s);
+
+ s.syncAsSint32LE(_curAnimationFrame);
+ s.syncAsSint32LE(_newIngredient);
+ s.syncAsSint32LE(_newQuantity);
+ s.syncAsSint32LE(_resetFrame);
+ s.syncAsSint32LE(_badThreshold);
+
+ s.syncAsByte(_killRox);
+ s.syncAsByte(_makeMushroomCloud);
+
+ _dialog1.synchronize(s);
+ _dialog2.synchronize(s);
+ _dialog3.synchronize(s);
+ _dialog4.synchronize(s);
+}
+
/*------------------------------------------------------------------------*/
void Scene413::setup() {
@@ -4102,6 +4134,13 @@ void Scene413::actions() {
_action._inProgress = false;
}
+void Scene413::synchronize(Common::Serializer &s) {
+ Scene4xx::synchronize(s);
+
+ s.syncAsSint32LE(_rexDeath);
+ s.syncAsSint32LE(_canMove);
+}
+
/*------------------------------------------------------------------------*/
} // End of namespace Nebular
diff --git a/engines/mads/nebular/nebular_scenes4.h b/engines/mads/nebular/nebular_scenes4.h
index 1f7b56b5cd..f2e8961089 100644
--- a/engines/mads/nebular/nebular_scenes4.h
+++ b/engines/mads/nebular/nebular_scenes4.h
@@ -148,6 +148,7 @@ private:
public:
Scene406(MADSEngine *vm) : Scene4xx(vm) {}
+ void synchronize(Common::Serializer &s);
virtual void setup();
virtual void enter();
@@ -160,10 +161,11 @@ public:
class Scene407: public Scene4xx {
private:
bool _fromNorth;
- Common::Point destPos;
+ Common::Point _destPos;
public:
Scene407(MADSEngine *vm) : Scene4xx(vm) {}
+ void synchronize(Common::Serializer &s);
virtual void setup();
virtual void enter();
@@ -236,6 +238,7 @@ private:
public:
Scene411(MADSEngine *vm) : Scene4xx(vm) {}
+ void synchronize(Common::Serializer &s);
virtual void setup();
virtual void enter();
@@ -252,6 +255,7 @@ private:
public:
Scene413(MADSEngine *vm) : Scene4xx(vm) {}
+ void synchronize(Common::Serializer &s);
virtual void setup();
virtual void enter();