diff options
author | Strangerke | 2014-03-25 22:01:25 +0100 |
---|---|---|
committer | Strangerke | 2014-03-25 22:01:25 +0100 |
commit | 633da299f694a9998a0cdb002a08613750f36e61 (patch) | |
tree | a84db625f5db41d10d582cf480bcae884dc70998 | |
parent | c09bfdab2f00c888debb0e81d956fb0c2397ef9c (diff) | |
download | scummvm-rg350-633da299f694a9998a0cdb002a08613750f36e61.tar.gz scummvm-rg350-633da299f694a9998a0cdb002a08613750f36e61.tar.bz2 scummvm-rg350-633da299f694a9998a0cdb002a08613750f36e61.zip |
MADS: Add scene 208
-rw-r--r-- | engines/mads/game.h | 3 | ||||
-rw-r--r-- | engines/mads/messages.h | 2 | ||||
-rw-r--r-- | engines/mads/nebular/nebular_scenes.cpp | 2 | ||||
-rw-r--r-- | engines/mads/nebular/nebular_scenes2.cpp | 181 | ||||
-rw-r--r-- | engines/mads/nebular/nebular_scenes2.h | 12 |
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 |