aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
Diffstat (limited to 'engines')
-rw-r--r--engines/mads/nebular/nebular_scenes.cpp2
-rw-r--r--engines/mads/nebular/nebular_scenes2.cpp68
-rw-r--r--engines/mads/nebular/nebular_scenes2.h12
3 files changed, 59 insertions, 23 deletions
diff --git a/engines/mads/nebular/nebular_scenes.cpp b/engines/mads/nebular/nebular_scenes.cpp
index 7f3a7a44e8..562f31c3b2 100644
--- a/engines/mads/nebular/nebular_scenes.cpp
+++ b/engines/mads/nebular/nebular_scenes.cpp
@@ -98,6 +98,8 @@ SceneLogic *SceneFactory::createScene(MADSEngine *vm) {
return new Scene214(vm);
case 215:
return new Scene215(vm);
+ case 216:
+ return new Scene216(vm);
// Scene group #8
case 804:
diff --git a/engines/mads/nebular/nebular_scenes2.cpp b/engines/mads/nebular/nebular_scenes2.cpp
index 45ea496132..6080c09fd4 100644
--- a/engines/mads/nebular/nebular_scenes2.cpp
+++ b/engines/mads/nebular/nebular_scenes2.cpp
@@ -11,7 +11,7 @@
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
@@ -4537,12 +4537,11 @@ void Scene211::preActions() {
&& (_scene->_customDest.x <= 52) && (_scene->_customDest.y >= 132))
_game._player.walk(Common::Point(52, 132), FACING_WEST);
- if (_action.isAction(0x1AD, 0x1AE)) {
- if (_game._objects.isInInventory(OBJ_BINOCULARS) && (_globals[kMonkeyStatus] == MONKEY_AMBUSH_READY) ) {
+ if (_action.isAction(0x1AD, 0x1AE)) {
+ if (_game._objects.isInInventory(OBJ_BINOCULARS) && (_globals[kMonkeyStatus] == MONKEY_AMBUSH_READY))
_game._player.walk(Common::Point(52, 132), FACING_WEST);
- } else {
+ else
_game._player._walkOffScreenSceneId = 210;
- }
}
if (_action.isAction(0x1AD, 0x1B1))
@@ -4550,16 +4549,16 @@ void Scene211::preActions() {
}
void Scene211::actions() {
- if (_action._lookFlag && (_globals[kMonkeyStatus] == MONKEY_AMBUSH_READY)) {
+ if (_action._lookFlag && (_globals[kMonkeyStatus] == MONKEY_AMBUSH_READY))
_vm->_dialogs->show(0x5277);
- } else if (_action.isAction(VERB_LOOK, 0x27, 0x100)) {
+ else if (_action.isAction(VERB_LOOK, 0x27, 0x100))
_vm->_dialogs->show(0x527C);
- } else if (_action.isAction(VERB_LOOK, 0x3A)) {
+ else if (_action.isAction(VERB_LOOK, 0x3A))
_vm->_dialogs->show(0x526D);
- } else if (_action.isAction(VERB_LOOK, 0x1B2)) {
+ else if (_action.isAction(VERB_LOOK, 0x1B2))
_vm->_dialogs->show(0x526E);
- } else if (_action.isAction(VERB_LOOK, 0x100)) {
- if (_globals[kMonkeyStatus] == MONKEY_AMBUSH_READY) {
+ else if (_action.isAction(VERB_LOOK, 0x100)) {
+ if (_globals[kMonkeyStatus] == MONKEY_AMBUSH_READY) {
if (_game._storyMode == STORYMODE_NAUGHTY)
_vm->_dialogs->show(0x526F);
else
@@ -4572,19 +4571,19 @@ void Scene211::actions() {
_vm->_dialogs->show(0x5272);
else
_vm->_dialogs->show(0x5273);
- } else if (_action.isAction(VERB_LOOK, 0xB8)) {
+ } else if (_action.isAction(VERB_LOOK, 0xB8))
_vm->_dialogs->show(0x5274);
- } else if (_action.isAction(VERB_LOOK, 0x1B1)) {
+ else if (_action.isAction(VERB_LOOK, 0x1B1))
_vm->_dialogs->show(0x5275);
- } else if (_action.isAction(VERB_LOOK, 0x1AE)) {
+ else if (_action.isAction(VERB_LOOK, 0x1AE))
_vm->_dialogs->show(0x5276);
- } else if (_action.isAction(VERB_LOOK, 0x144)) {
+ else if (_action.isAction(VERB_LOOK, 0x144))
_vm->_dialogs->show(0x5279);
- } else if (_action.isAction(VERB_TAKE, 0x144)) {
+ else if (_action.isAction(VERB_TAKE, 0x144))
_vm->_dialogs->show(0x527A);
- } else if (_action.isAction(VERB_LOOK, 0x129)) {
+ else if (_action.isAction(VERB_LOOK, 0x129))
_vm->_dialogs->show(0x527B);
- } else
+ else
return;
_action._inProgress = false;
@@ -4681,7 +4680,7 @@ void Scene214::enter() {
}
if (_game._objects.isInRoom(OBJ_BLOWGUN)) {
- _globals._sequenceIndexes[2] = _scene->_sequences.addSpriteCycle(_globals._spriteIndexes[2], false, 6, 0, 0, 0);
+ _globals._sequenceIndexes[2] = _scene->_sequences.addSpriteCycle(_globals._spriteIndexes[2], false, 6, 0, 0, 0);
_scene->_sequences.setMsgPosition(_globals._sequenceIndexes[2], Common::Point(90, 87));
_scene->_sequences.setDepth(_globals._sequenceIndexes[2], 13);
} else {
@@ -4741,7 +4740,7 @@ void Scene214::actions() {
switch (_game._trigger) {
case 0:
_game._player._stepEnabled = false;
- _game._player._visible = false;
+ _game._player._visible = false;
_globals._sequenceIndexes[4] = _scene->_sequences.addSpriteCycle(_globals._spriteIndexes[4], true, 6, 1, 0, 0);
_scene->_sequences.setMsgLayout(_globals._sequenceIndexes[4]);
_scene->_sequences.addSubEntry(_globals._sequenceIndexes[4], SEQUENCE_TRIGGER_EXPIRE, 0, 1);
@@ -4846,7 +4845,7 @@ void Scene214::actions() {
_vm->_dialogs->show(0x53AF);
} else if (_game._objects.isInRoom(OBJ_POISON_DARTS) && !_game._objects.isInRoom(OBJ_BLOWGUN)) {
_vm->_dialogs->show(0x53B0);
- } else if (!_game._objects.isInRoom(OBJ_POISON_DARTS) && _game._objects.isInRoom(OBJ_BLOWGUN)) {
+ } else if (!_game._objects.isInRoom(OBJ_POISON_DARTS) && _game._objects.isInRoom(OBJ_BLOWGUN)) {
_vm->_dialogs->show(0x53B1);
} else {
_vm->_dialogs->show(0x53B2);
@@ -4868,7 +4867,7 @@ void Scene215::enter() {
_globals._spriteIndexes[1] = _scene->_sprites.addSprites(formAnimName('e', 0));
_globals._spriteIndexes[3] = _scene->_sprites.addSprites(formAnimName('a', 0));
- _globals._sequenceIndexes[1] = _scene->_sequences.addSpriteCycle (_globals._spriteIndexes[1], false, 7, 0, 0, 0);
+ _globals._sequenceIndexes[1] = _scene->_sequences.addSpriteCycle (_globals._spriteIndexes[1], false, 7, 0, 0, 0);
_scene->_sequences.setMsgPosition(_globals._sequenceIndexes[1], Common::Point(235, 83));
_scene->_sequences.setDepth(_globals._sequenceIndexes[1], 15);
@@ -4936,7 +4935,7 @@ void Scene215::actions() {
break;
case 2:
- _game._player._visible = true;
+ _game._player._visible = true;
_game._player._stepEnabled = true;
_scene->_sequences.updateTimeout(-1, _globals._sequenceIndexes[2]);
break;
@@ -4980,5 +4979,28 @@ void Scene215::actions() {
/*------------------------------------------------------------------------*/
+void Scene216::setup() {
+ setPlayerSpritesPrefix();
+ setAAName();
+}
+
+void Scene216::enter() {
+ _game._player._stepEnabled = false;
+ _game._player._visible = false;
+
+ _scene->_userInterface.emptyTalkList();
+ _scene->_userInterface.setup(kInputConversation);
+ _scene->loadAnimation(formAnimName('A', -1), 60);
+
+ sceneEntrySound();
+}
+
+void Scene216::step() {
+ if (_game._trigger == 60)
+ _scene->_nextSceneId = 215;
+}
+
+/*------------------------------------------------------------------------*/
+
} // End of namespace Nebular
} // End of namespace MADS
diff --git a/engines/mads/nebular/nebular_scenes2.h b/engines/mads/nebular/nebular_scenes2.h
index c5a9cb8426..2537b113f8 100644
--- a/engines/mads/nebular/nebular_scenes2.h
+++ b/engines/mads/nebular/nebular_scenes2.h
@@ -293,6 +293,18 @@ public:
virtual void actions();
virtual void postActions() {};
};
+
+class Scene216: public Scene2xx {
+public:
+ Scene216(MADSEngine *vm) : Scene2xx(vm) {}
+
+ virtual void setup();
+ virtual void enter();
+ virtual void step();
+ virtual void preActions() {};
+ virtual void actions() {};
+ virtual void postActions() {};
+};
} // End of namespace Nebular
} // End of namespace MADS