aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStrangerke2014-03-25 22:01:25 +0100
committerStrangerke2014-03-25 22:01:25 +0100
commit633da299f694a9998a0cdb002a08613750f36e61 (patch)
treea84db625f5db41d10d582cf480bcae884dc70998
parentc09bfdab2f00c888debb0e81d956fb0c2397ef9c (diff)
downloadscummvm-rg350-633da299f694a9998a0cdb002a08613750f36e61.tar.gz
scummvm-rg350-633da299f694a9998a0cdb002a08613750f36e61.tar.bz2
scummvm-rg350-633da299f694a9998a0cdb002a08613750f36e61.zip
MADS: Add scene 208
-rw-r--r--engines/mads/game.h3
-rw-r--r--engines/mads/messages.h2
-rw-r--r--engines/mads/nebular/nebular_scenes.cpp2
-rw-r--r--engines/mads/nebular/nebular_scenes2.cpp181
-rw-r--r--engines/mads/nebular/nebular_scenes2.h12
5 files changed, 198 insertions, 2 deletions
diff --git a/engines/mads/game.h b/engines/mads/game.h
index bf81c23d81..c5a3dd3be0 100644
--- a/engines/mads/game.h
+++ b/engines/mads/game.h
@@ -62,7 +62,6 @@ private:
protected:
MADSEngine *_vm;
MSurface *_surface;
- Difficulty _difficultyLevel;
int _saveSlot;
int _statusFlag;
Common::StringArray _quotes;
@@ -110,9 +109,11 @@ protected:
public:
static Game *init(MADSEngine *vm);
+
public:
Player _player;
ScreenObjects _screenObjects;
+ Difficulty _difficultyLevel;
int _sectionNumber;
int _priorSectionNumber;
int _currentSectionNumber;
diff --git a/engines/mads/messages.h b/engines/mads/messages.h
index 90269c12b5..03a4e01234 100644
--- a/engines/mads/messages.h
+++ b/engines/mads/messages.h
@@ -68,8 +68,8 @@ class KernelMessages {
private:
MADSEngine *_vm;
Common::Array<KernelMessage> _entries;
- Font *_talkFont;
public:
+ Font *_talkFont;
KernelMessages(MADSEngine *vm);
~KernelMessages();
diff --git a/engines/mads/nebular/nebular_scenes.cpp b/engines/mads/nebular/nebular_scenes.cpp
index 0f35e5d406..39a8ed58b4 100644
--- a/engines/mads/nebular/nebular_scenes.cpp
+++ b/engines/mads/nebular/nebular_scenes.cpp
@@ -61,6 +61,8 @@ SceneLogic *SceneFactory::createScene(MADSEngine *vm) {
return new Scene205(vm);
case 207:
return new Scene207(vm);
+ case 208:
+ return new Scene208(vm);
// Scene group #8
case 804:
diff --git a/engines/mads/nebular/nebular_scenes2.cpp b/engines/mads/nebular/nebular_scenes2.cpp
index 0e6e715f71..c4fee2be68 100644
--- a/engines/mads/nebular/nebular_scenes2.cpp
+++ b/engines/mads/nebular/nebular_scenes2.cpp
@@ -1361,5 +1361,186 @@ void Scene207::actions() {
/*****************************************************************************/
+void Scene208::setup() {
+ setPlayerSpritesPrefix();
+ setAAName();
+ _scene->addActiveVocab(0x1A8);
+ _scene->addActiveVocab(0x1A9);
+ _scene->addActiveVocab(0x1AA);
+ _scene->addActiveVocab(NOUN_D);
+}
+
+void Scene208::enter() {
+ _globals._spriteIndexes[1] = _scene->_sprites.addSprites(formAnimName('a', 1), 0);
+ _globals._spriteIndexes[2] = _scene->_sprites.addSprites(formAnimName('x', 0), 0);
+ _globals._spriteIndexes[3] = _scene->_sprites.addSprites(formAnimName('x', 1), 0);
+ _globals._spriteIndexes[4] = _scene->_sprites.addSprites(formAnimName('x', 2), 0);
+ _globals._spriteIndexes[5] = _scene->_sprites.addSprites("*RXMBD_8");
+
+ warning("TODO: sub34648()");
+
+ _globals._v0 = 0;
+ _globals._frameTime = 0;
+ _scene->_kernelMessages._talkFont = _vm->_font->getFont(FONT_INTERFACE);
+ _scene->_textSpacing = 0;
+
+ if (_scene->_priorSceneId == 207) {
+ _game._player._playerPos = Common::Point(8, 122);
+ _game._player._direction = 6;
+ } else if (_scene->_priorSceneId == 203) {
+ _game._player._playerPos = Common::Point(142, 108);
+ _game._player._direction = 2;
+ } else if (_scene->_priorSceneId == 209) {
+ _game._player._playerPos = Common::Point(307, 123);
+ _game._player._direction = 4;
+ } else if (_scene->_priorSceneId != -2) {
+ _game._player._playerPos = Common::Point(162, 149);
+ _game._player._direction = 8;
+ }
+
+ _game.loadQuoteSet(0x81, 0x46, 0);
+
+ if ((_scene->_priorSceneId == 207) && (_globals[36] == 1)) {
+ int msgIndex = _scene->_kernelMessages.add(Common::Point(0, 0), 0x1110, 34, 0, 120, _game.getQuote(129));
+ _scene->_kernelMessages.setQuoted(msgIndex, 4, true);
+ }
+
+ _vm->_palette->setEntry(16, 0, 0, 63);
+ _vm->_palette->setEntry(17, 0, 0, 45);
+ sceneEntrySound();
+}
+
+void Scene208::step() {
+ if ((_globals._frameTime & 0xFFFF) && ((_globals._frameTime >> 16) <= _scene->_activeAnimation->getCurrentFrame())) {
+ _globals._frameTime = (_globals._frameTime & 0xFFFF) | (_scene->_activeAnimation->getCurrentFrame() << 16);
+
+ if (_scene->_activeAnimation->getCurrentFrame() == 125)
+ _scene->_sequences.remove(_globals._spriteIndexes[19]);
+ }
+
+ if (_globals._v0 == 0)
+ return;
+
+ if ((_game._player._playerPos != Common::Point(20, 148)) || (_game._player._direction != 6))
+ return;
+
+ if ((_game._abortTimers == 0) && ((_globals._frameTime & 0xFFFF) != 0))
+ return;
+
+ _globals._frameTime |= 0xFFFF;
+
+ if (_game._abortTimers == 82) {
+ _game._player._stepEnabled = true;
+ return;
+ }
+
+ if (_game._abortTimers > 82)
+ return;
+
+ if (_game._abortTimers & 0xFF) {
+ if ((_game._abortTimers & 0xFF) == 81) {
+ _scene->_sequences.remove(_globals._spriteIndexes[15]);
+ _globals[34] = 1;
+ warning("TODO: sub34648(...)");
+ _scene->_sequences.addTimer(90, 82);
+ }
+ } else {
+ _scene->loadAnimation(formAnimName('A', -1), 81);
+ }
+}
+
+void Scene208::preActions() {
+ if (_action.isAction(3, 0) && _action._walkFlag)
+ _action._startWalkFlag = true;
+
+ if (_action.isAction(0x18C, 0x9B, 0))
+ _game._player._v844BE = 209;
+
+ if (_action.isAction(0x18C, 0xF6, 0))
+ _game._player._v844BE = 207;
+}
+
+void Scene208::actions() {
+ if (_action.isAction(0x18C, 0x19F, 0)) {
+ if (_globals[34])
+ _scene->_nextSceneId = 203;
+ else if (_game._abortTimers == 0) {
+ _game._player._stepEnabled = false;
+ int msgIndex = _scene->_kernelMessages.add(Common::Point(0, 0), 0x1110, 34, 1, 120, _game.getQuote(70));
+ _scene->_kernelMessages.setQuoted(msgIndex, 4, true);
+ } else if (_game._abortTimers == 1) {
+ _scene->_nextSceneId = 203;
+ }
+ } else if (_action.isAction(0x18C, 0x83, 0)) {
+ _scene->_nextSceneId = 212;
+ } else if (_action.isAction(0x4, 0x1AA, 0) && (!_globals[35] || _game._abortTimers)) {
+ warning("TODO: sub3B282(1);");
+ if (_game._player._stepEnabled)
+ _vm->_dialogs->showPicture(OBJ_BIG_LEAVES, 0x326, 0);
+ } else if (_action.isAction(0x7, 0x23, 0x19E) && (_globals[35] == 1 || _game._abortTimers)) {
+ warning("TODO: sub3B282(2);");
+ } else if (_action.isAction(0x7, 0x17A, 0x1A9)) {
+ warning("TODO: sub3B282(3);");
+ if (_game._player._stepEnabled) {
+ _game._player._stepEnabled = false;
+ _globals._v0 = true;
+ _game._player.startWalking(Common::Point(20, 148), 6);
+ }
+ } else if (_action.isAction(0x7, 0x35, 0x1A9)) {
+ warning("TODO: sub3B282(4);");
+ if (_game._player._stepEnabled) {
+ Dialog::show(0x514C);
+ }
+ } else if (_action.isAction(0x7, 0x65, 0x1A9)) {
+ warning("TODO: sub3B282(5);");
+ if (_game._player._stepEnabled) {
+ Dialog::show(0x514C);
+ }
+ } else if (_action.isAction(0x3, 0x5D, 0)) {
+ Dialog::show(0x5141);
+ } else if (_action.isAction(0x3, 0xF6, 0)) {
+ Dialog::show(0x5142);
+ } else if (_action.isAction(0x3, 0x16F, 0)) {
+ Dialog::show(0x5143);
+ } else if (_action.isAction(0x3, 0x129, 0)) {
+ Dialog::show(0x5144);
+ } else if (_action.isAction(0x3, 0x1A1, 0)) {
+ Dialog::show(0x5145);
+ } else if (_action.isAction(0x4, 0x1A1, 0)) {
+ Dialog::show(0x5146);
+ } else if (_action.isAction(0x3, 0x9B, 0)) {
+ Dialog::show(0x5147);
+ } else if (_action.isAction(0x3, 0x19E, 0)) {
+ Dialog::show(0x5148);
+ } else if (_action.isAction(0x3, 0x1AA, 0)) {
+ Dialog::show(0x5149);
+ } else if (_action.isAction(0x3, 0x1A9, 0)) {
+ if (_game._difficultyLevel == DIFFICULTY_EASY)
+ Dialog::show(0x514A);
+ else
+ Dialog::show(0x514B);
+ } else if (_action.isAction(0x3, 0x174, 0) || _action.isAction(0x3, 0x175, 0)) {
+ Dialog::show(0x514D);
+ } else if (_action.isAction(0x4, 0x1A9, 0)) {
+ Dialog::show(0x514E);
+ } else if (_action.isAction(0x3, 0x1A8, 0)) {
+ Dialog::show(0x514F);
+ } else if (_action.isAction(0x4, 0x1A8, 0) || _action.isAction(0xA, 0x1A8, 0)) {
+ Dialog::show(0x5150);
+ } else if (_action._savedFields._lookFlag == 0) {
+ return;
+ } else if (_globals[34] == 1) {
+ Dialog::show(0x5153);
+ } else if (_globals[35] == 2) {
+ Dialog::show(0x5152);
+ } else {
+ Dialog::show(0x5151);
+ }
+
+ _action._inProgress = false;
+}
+
+/*****************************************************************************/
+
} // 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 6d25f5d172..7a5af6ff41 100644
--- a/engines/mads/nebular/nebular_scenes2.h
+++ b/engines/mads/nebular/nebular_scenes2.h
@@ -111,6 +111,18 @@ public:
virtual void actions();
virtual void postActions() {};
};
+
+class Scene208: public Scene2xx {
+public:
+ Scene208(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