diff options
author | Paul Gilbert | 2014-04-20 18:31:18 -0400 |
---|---|---|
committer | Paul Gilbert | 2014-04-20 18:31:18 -0400 |
commit | 254519296e87e8a6b29305b91c045446b1421d19 (patch) | |
tree | 699eabd623a20ebaecc086cb7158639f5f1208f2 /engines/mads | |
parent | 4559444c54a6e910f89532e899058448eb835b08 (diff) | |
download | scummvm-rg350-254519296e87e8a6b29305b91c045446b1421d19.tar.gz scummvm-rg350-254519296e87e8a6b29305b91c045446b1421d19.tar.bz2 scummvm-rg350-254519296e87e8a6b29305b91c045446b1421d19.zip |
MADS: Beginnings of implementing conversation methods
Diffstat (limited to 'engines/mads')
-rw-r--r-- | engines/mads/nebular/nebular_scenes1.cpp | 2 | ||||
-rw-r--r-- | engines/mads/nebular/nebular_scenes2.cpp | 157 | ||||
-rw-r--r-- | engines/mads/nebular/nebular_scenes2.h | 2 | ||||
-rw-r--r-- | engines/mads/user_interface.cpp | 20 | ||||
-rw-r--r-- | engines/mads/user_interface.h | 29 |
5 files changed, 90 insertions, 120 deletions
diff --git a/engines/mads/nebular/nebular_scenes1.cpp b/engines/mads/nebular/nebular_scenes1.cpp index c7ab075d4f..2440068698 100644 --- a/engines/mads/nebular/nebular_scenes1.cpp +++ b/engines/mads/nebular/nebular_scenes1.cpp @@ -2944,7 +2944,7 @@ void Scene112::enter() { _game._player._stepEnabled = false; _game._player._visible = false; - _scene->_userInterface.emptyTalkList(); + _scene->_userInterface.emptyConversationList(); _scene->_userInterface.setup(kInputConversation); _scene->loadAnimation(Resources::formatName(112, 'X', -1, EXT_AA, ""), 70); diff --git a/engines/mads/nebular/nebular_scenes2.cpp b/engines/mads/nebular/nebular_scenes2.cpp index a2d3c45460..22c7062446 100644 --- a/engines/mads/nebular/nebular_scenes2.cpp +++ b/engines/mads/nebular/nebular_scenes2.cpp @@ -3689,7 +3689,7 @@ void Scene210::setDialogNode(int node) { _shouldTalk = true; _game._player._stepEnabled = false; if (_twinklesTalking) { - _scene->_userInterface.emptyTalkList(); + _scene->_userInterface.emptyConversationList(); _scene->_userInterface.setup(kInputConversation); handleTwinklesSpeech(0xE4, -1, 0); _scene->_sequences.addTimer(180, 2); @@ -3805,6 +3805,8 @@ void Scene210::restoreDialogNode(int node, int msgId, int posY) { } void Scene210::enter() { + UserInterface &userInterface = _vm->_game->_scene._userInterface; + _globals._spriteIndexes[1] = _scene->_sprites.addSprites(formAnimName('c', -1)); if (!_game._visitedScenes._sceneRevisited) @@ -3832,7 +3834,8 @@ void Scene210::enter() { 0xB9, 0xBA, 0xBB, 0xBC, 0xBD, 0xBE, 0xBF, 0xC0, 0xC1, 0xC2, 0xC3, 0xC4, 0xC5, 0xC6, 0xC7, 0xC8, 0xC9, 0xCA, 0xCB, 0xCC, 0xCD, 0xCE, 0xCF, 0xD0, 0xD1, 0xD2, 0xD3, 0xD4, 0xD5, 0xD6, 0xD7, 0xD8, 0xD9, 0xDA, 0xDB, 0xDC, 0xDD, 0xDE, 0xDF, 0xE0, 0xE1, 0xE2, 0xE3, 0xE4, 0xE5, 0); - warning("TODO: sub71A50(&dialog1, 0x2E, 0xB4, 0xB5, 0xB6, 0xB7, 0xB8, 0);"); + + userInterface.initConversation(&_conv1, 0x2E, 0xB4, 0xB5, 0xB6, 0xB7, 0xB8, 0); if (!_game._visitedScenes._sceneRevisited) { warning("TODO: sub71B18(0x2E, 0xB4, 0xB5, 0xB6, 0xB8, 0);"); @@ -3841,12 +3844,13 @@ void Scene210::enter() { warning("TODO: \tsub71B9E(&dialog1, 0xB7, -1);"); } - warning("TODO: sub71A50(&dialog2, 0x2F, 0xBC, 0xBB, 0xBD, _game._visitedScenes._sceneRevisited ? 0, -1);"); - warning("TODO: sub71A50(&dialog3, 0x30, 0xC3, 0xC2, 0xC1, 0xC4, _game._visitedScenes._sceneRevisited ? 0, -1);"); - warning("TODO: sub71A50(&dialog5, 0x31, 0xCD, 0xCC, 0xCE, 0xCF, _game._visitedScenes._sceneRevisited ? 0, -1);"); - warning("TODO: sub71A50(&dialog6, 0x32, 0xD3, 0xD4, 0xD5, _game._visitedScenes._sceneRevisited ? 0, -1);"); - warning("TODO: sub71A50(&dialog7, 0x33, 0xD8, 0xDA, 0xD9, 0xDB, 0xDC, _game._visitedScenes._sceneRevisited ? 0, -1);"); - warning("TODO: sub71A50(&dialog8, 0x34, 0xDF, 0xE0, 0xE1, 0xE2, 0xE3, _game._visitedScenes._sceneRevisited ? 0, -1);"); + bool sceneRevisited = _game._visitedScenes._sceneRevisited; + userInterface.initConversation(&_conv2, 0x2F, 0xBC, 0xBB, 0xBD, (int)!sceneRevisited); + userInterface.initConversation(&_conv3, 0x30, 0xC3, 0xC2, 0xC1, 0xC4, (int)!sceneRevisited); + userInterface.initConversation(&_conv5, 0x31, 0xCD, 0xCC, 0xCE, 0xCF, (int)!sceneRevisited); + userInterface.initConversation(&_conv6, 0x32, 0xD3, 0xD4, 0xD5, (int)!sceneRevisited); + userInterface.initConversation(&_conv7, 0x33, 0xD8, 0xDA, 0xD9, 0xDB, 0xDC, (int)!sceneRevisited); + userInterface.initConversation(&_conv8, 0x34, 0xDF, 0xE0, 0xE1, 0xE2, 0xE3, (int)!sceneRevisited); _twinkleAnimationType = 0; _twinklesCurrentFrame = 0; @@ -4087,19 +4091,13 @@ void Scene210::preActions() { } void Scene210::actions() { + UserInterface &userInterface = _vm->_game->_scene._userInterface; + if (_action.isAction(VERB_LOOK, 0x27, 0x1C0)) { _vm->_dialogs->show(0x5219); - _action._inProgress = false; - return; - } - - if (_game._screenObjects._inputMode == 1) { + } else if (_game._screenObjects._inputMode == 1) { handleDialogs(); - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_TALKTO, 0x1DC) || + } else if (_action.isAction(VERB_TALKTO, 0x1DC) || ((_game._player._playerPos == Common::Point(214, 150)) && (_game._player._facing == FACING_NORTHWEST) && (_twinkleAnimationType == 1) && _stopWalking)) { switch (_game._trigger) { case 0: { @@ -4146,15 +4144,11 @@ void Scene210::actions() { if (_globals[kTwinklesApproached] < 2) _globals[kTwinklesApproached]++; - warning("TODO: talk_init(&dialog1);"); + userInterface.startConversation(&_conv1); _curDialogNode = 1; break; } - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_GIVE, 0x1DC) && _game._objects.isInInventory(_game._objects.getIdFromDesc(_action._activeAction._objectNameId))) { + } else if (_action.isAction(VERB_GIVE, 0x1DC) && _game._objects.isInInventory(_game._objects.getIdFromDesc(_action._activeAction._objectNameId))) { switch (_game._trigger) { case 0: { int quote = _vm->getRandomNumber(172, 174); @@ -4170,23 +4164,11 @@ void Scene210::actions() { _shouldMoveHead = false; break; } - _action._inProgress = false; - return; - } - - if (_action.isAction(0x1AD, 0x1BF) || _action.isAction(0x18C, 0x1C0)) { + } else if (_action.isAction(0x1AD, 0x1BF) || _action.isAction(0x18C, 0x1C0)) { _scene->_nextSceneId = 205; - _action._inProgress = false; - return; - } - - if (_action.isAction(0x18B, 0x70)) { + } else if (_action.isAction(0x18B, 0x70)) { _scene->_nextSceneId = 215; - _action._inProgress = false; - return; - } - - if ((_action.isAction(VERB_PULL, 0x5F) || _action.isAction(VERB_OPEN, 0x5F)) && !_globals[kCurtainOpen]) { + } else if ((_action.isAction(VERB_PULL, 0x5F) || _action.isAction(VERB_OPEN, 0x5F)) && !_globals[kCurtainOpen]) { switch (_game._trigger) { case 0: _game._player._stepEnabled = false; @@ -4204,11 +4186,7 @@ void Scene210::actions() { _scene->_dynamicHotspots.setCursor(_doorway, CURSOR_GO_UP); break; } - _action._inProgress = false; - return; - } - - if ((_action.isAction(VERB_PULL, 0x5F) || _action.isAction(VERB_CLOSE, 0x5F)) && _globals[kCurtainOpen]) { + } else if ((_action.isAction(VERB_PULL, 0x5F) || _action.isAction(VERB_CLOSE, 0x5F)) && _globals[kCurtainOpen]) { switch (_game._trigger) { case 0: _scene->_sequences.remove(_globals._sequenceIndexes[1]); @@ -4230,11 +4208,7 @@ void Scene210::actions() { _globals[kCurtainOpen] = false; break; } - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_LOOK, 0xAA)) { + } else if (_action.isAction(VERB_LOOK, 0xAA)) { if (_globals[kTwinklesStatus] == TWINKLES_GONE) { if (_game._storyMode == STORYMODE_NAUGHTY) _vm->_dialogs->show(0x520B); @@ -4243,87 +4217,38 @@ void Scene210::actions() { } else { _vm->_dialogs->show(0x5209); } - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_LOOK, 0x31)) { + } else if (_action.isAction(VERB_LOOK, 0x31)) { _vm->_dialogs->show(0x520C); - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_LOOK, 0xA7)) { + } else if (_action.isAction(VERB_LOOK, 0xA7)) { _vm->_dialogs->show(0x520D); - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_TAKE, 0xA7) || _action.isAction(VERB_TAKE, 0x31)) { + } else if (_action.isAction(VERB_TAKE, 0xA7) || _action.isAction(VERB_TAKE, 0x31)) { _vm->_dialogs->show(0x520E); - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_LOOK, 0x1C5)) { + } else if (_action.isAction(VERB_LOOK, 0x1C5)) { _vm->_dialogs->show(0x520F); - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_LOOK, 0x3A)) { + } else if (_action.isAction(VERB_LOOK, 0x3A)) { _vm->_dialogs->show(0x5210); - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_LOOK, 0x1B0)) { + } else if (_action.isAction(VERB_LOOK, 0x1B0)) { _vm->_dialogs->show(0x5211); - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_LOOK, 0x1DC)) { + } else if (_action.isAction(VERB_LOOK, 0x1DC)) { _vm->_dialogs->show(0x5212); - _action._inProgress = false; - return; - } - - if (_action.isAction(0x13A, 0x1DC) || _action.isAction(0xA6, 0x1DC)) { + } else if (_action.isAction(0x13A, 0x1DC) || _action.isAction(0xA6, 0x1DC)) { _vm->_dialogs->show(0x5213); - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_LOOK, 0x1BF)) { + } else if (_action.isAction(VERB_LOOK, 0x1BF)) { _vm->_dialogs->show(0x5214); - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_LOOK, 0x5F)) { + } else if (_action.isAction(VERB_LOOK, 0x5F)) { _vm->_dialogs->show(0x5215); - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_LOOK, 0x53)) { + } else if (_action.isAction(VERB_LOOK, 0x53)) { _vm->_dialogs->show(0x5216); - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_TAKE, 0x53)) { + } else if (_action.isAction(VERB_TAKE, 0x53)) { _vm->_dialogs->show(0x5217); - _action._inProgress = false; - return; - } - - if (_action.isAction(VERB_LOOK, 0x1C0)) { + } else if (_action.isAction(VERB_LOOK, 0x1C0)) { _vm->_dialogs->show(0x5218); - _action._inProgress = false; + } else { + // Not handled return; } + + _action._inProgress = false; } /*------------------------------------------------------------------------*/ @@ -4988,7 +4913,7 @@ void Scene216::enter() { _game._player._stepEnabled = false; _game._player._visible = false; - _scene->_userInterface.emptyTalkList(); + _scene->_userInterface.emptyConversationList(); _scene->_userInterface.setup(kInputConversation); _scene->loadAnimation(formAnimName('A', -1), 60); diff --git a/engines/mads/nebular/nebular_scenes2.h b/engines/mads/nebular/nebular_scenes2.h index 2537b113f8..f50789999b 100644 --- a/engines/mads/nebular/nebular_scenes2.h +++ b/engines/mads/nebular/nebular_scenes2.h @@ -214,6 +214,8 @@ private: bool _twinklesTalk2; int _doorway; Common::String _subQuote2; + Conversation _conv1, _conv2, _conv3; + Conversation _conv5, _conv6, _conv7, _conv8; void handleDialogs(); void handleSubDialog1(); diff --git a/engines/mads/user_interface.cpp b/engines/mads/user_interface.cpp index 09b3c8d5cf..0a0b8968e9 100644 --- a/engines/mads/user_interface.cpp +++ b/engines/mads/user_interface.cpp @@ -672,8 +672,24 @@ void UserInterface::drawTalkList() { warning("TODO: drawTalkList"); } -void UserInterface::emptyTalkList() { - warning("TODO: emptyTalkList"); +void UserInterface::initConversation(Conversation *conversatin, int globalId, int quoteId, ...) { + +} + +void UserInterface::setConversation(Conversation *conversation, int quoteId, ...) { + +} + +void UserInterface::writeConversation(Conversation *conversation, int quoteId, int flag) { + +} + +void UserInterface::emptyConversationList() { + _talkStrings.clear(); +} + +void UserInterface::startConversation(Conversation *conversation) { + } void UserInterface::loadInventoryAnim(int objectId) { diff --git a/engines/mads/user_interface.h b/engines/mads/user_interface.h index 52512ef6ca..a6cc9e3650 100644 --- a/engines/mads/user_interface.h +++ b/engines/mads/user_interface.h @@ -93,6 +93,10 @@ public: void draw(bool updateFlag, bool delFlag); }; +class Conversation { +public: + +}; class UserInterface : public MSurface { friend class UISlots; @@ -238,7 +242,30 @@ public: */ void updateInventoryScroller(); - void emptyTalkList(); + /** + * Set up a conversation sequence + */ + void initConversation(Conversation *conversatin, int globalId, int quoteId, ...); + + /** + * Activates the passed set of quotes in the given conversation node + */ + void setConversation(Conversation *conversation, int quoteId, ...); + + /** + * Activates or deactivates the specified quote in the given conversation node + */ + void writeConversation(Conversation *conversation, int quoteId, int flag); + + /** + * Start an interactive conversation + */ + void startConversation(Conversation *conversation); + + /** + * Empties the current conversation talk list + */ + void emptyConversationList(); }; } // End of namespace MADS |