aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/mads/nebular/nebular_scenes2.cpp85
-rw-r--r--engines/mads/nebular/nebular_scenes2.h18
-rw-r--r--engines/mads/user_interface.cpp10
3 files changed, 58 insertions, 55 deletions
diff --git a/engines/mads/nebular/nebular_scenes2.cpp b/engines/mads/nebular/nebular_scenes2.cpp
index 37e7aaab20..5054fbef0d 100644
--- a/engines/mads/nebular/nebular_scenes2.cpp
+++ b/engines/mads/nebular/nebular_scenes2.cpp
@@ -3287,7 +3287,7 @@ void Scene210::setup() {
_scene->addActiveVocab(0x18B);
}
-void Scene210::handleDialogs() {
+void Scene210::handleConversations() {
if (_game._trigger == 0) {
_scene->_kernelMessages.reset();
_game._player._stepEnabled = false;
@@ -3298,7 +3298,7 @@ void Scene210::handleDialogs() {
_scene->_kernelMessages.add(Common::Point(0, -14), 0x1110, 34, 0, 240, subQuote1);
_scene->_sequences.addTimer(60, 50);
} else {
- _scene->_kernelMessages.add(Common::Point(0, 0), 0x1110, 34, 1, 12, curQuote);
+ _scene->_kernelMessages.add(Common::Point(0, 0), 0x1110, 34, 1, 120, curQuote);
}
} else if (_game._trigger == 50) {
_scene->_kernelMessages.add(Common::Point(0, 0), 0x1110, 34, 0, 240, _subQuote2);
@@ -3309,37 +3309,37 @@ void Scene210::handleDialogs() {
switch (_curDialogNode) {
case 1:
- handleSubDialog1();
+ handleConversation1();
break;
case 2:
- handleSubDialog2();
+ handleConversation2();
break;
case 3:
- handleSubDialog3();
+ handleConversation3();
break;
case 5:
- handleSubDialog5();
+ handleConversation5();
break;
case 6:
- handleSubDialog6();
+ handleConversation6();
break;
case 7:
- handleSubDialog7();
+ handleConversation7();
break;
case 8:
- handleSubDialog8();
+ handleConversation8();
break;
}
}
}
-void Scene210::handleSubDialog1() {
+void Scene210::handleConversation1() {
switch (_action._activeAction._verbId) {
case 180:
setDialogNode(2);
@@ -3363,7 +3363,7 @@ void Scene210::handleSubDialog1() {
}
}
-void Scene210::handleSubDialog2() {
+void Scene210::handleConversation2() {
switch (_action._activeAction._verbId) {
case 187:
setDialogNode(3);
@@ -3379,7 +3379,7 @@ void Scene210::handleSubDialog2() {
}
}
-void Scene210::handleSubDialog3() {
+void Scene210::handleConversation3() {
switch (_action._activeAction._verbId) {
case 193:
setDialogNode(6);
@@ -3399,7 +3399,7 @@ void Scene210::handleSubDialog3() {
}
}
-void Scene210::handleSubDialog5() {
+void Scene210::handleConversation5() {
switch (_action._activeAction._verbId) {
case 204:
setDialogNode(6);
@@ -3416,7 +3416,7 @@ void Scene210::handleSubDialog5() {
}
}
-void Scene210::handleSubDialog6() {
+void Scene210::handleConversation6() {
switch (_action._activeAction._verbId) {
case 211:
setDialogNode(7);
@@ -3432,7 +3432,7 @@ void Scene210::handleSubDialog6() {
}
}
-void Scene210::handleSubDialog7() {
+void Scene210::handleConversation7() {
switch (_action._activeAction._verbId) {
case 216:
case 217:
@@ -3450,7 +3450,7 @@ void Scene210::handleSubDialog7() {
}
}
-void Scene210::handleSubDialog8() {
+void Scene210::handleConversation8() {
switch (_action._activeAction._verbId) {
case 223:
case 224:
@@ -3502,7 +3502,7 @@ void Scene210::setDialogNode(int node) {
_nextHandsPlace = 0;
_shouldTalk = false;
_game._player._stepEnabled = true;
- initNode(2);
+ newNode(2);
break;
}
break;
@@ -3533,7 +3533,7 @@ void Scene210::setDialogNode(int node) {
default:
_shouldTalk = false;
_game._player._stepEnabled = true;
- initNode(3);
+ newNode(3);
break;
}
break;
@@ -3588,7 +3588,7 @@ void Scene210::setDialogNode(int node) {
_nextHandsPlace = 2;
_shouldTalk = false;
_game._player._stepEnabled = true;
- initNode(5);
+ newNode(5);
break;
}
break;
@@ -3622,7 +3622,7 @@ void Scene210::setDialogNode(int node) {
_nextHandsPlace = 0;
_shouldTalk = false;
_game._player._stepEnabled = true;
- initNode(6);
+ newNode(6);
break;
}
break;
@@ -3649,7 +3649,7 @@ void Scene210::setDialogNode(int node) {
default:
_shouldTalk = false;
_game._player._stepEnabled = true;
- initNode(7);
+ newNode(7);
break;
}
break;
@@ -3676,7 +3676,7 @@ void Scene210::setDialogNode(int node) {
default:
_shouldTalk = false;
_game._player._stepEnabled = true;
- initNode(8);
+ newNode(8);
break;
}
break;
@@ -3758,36 +3758,39 @@ void Scene210::handleTwinklesSpeech(int quoteId, int shiftX, uint32 delay) {
_scene->_kernelMessages.add(Common::Point(10, 70 + (shiftX * 14)), 0xFDFC, 0, 0, (delay == 0) ? 9999999 : delay, _game.getQuote(quoteId));
}
-void Scene210::initNode(int node) {
+void Scene210::newNode(int node) {
_curDialogNode = node;
switch (_curDialogNode) {
case 1:
- warning("TODO: talk_init(&dialog1);");
+ _conv1.start();
break;
case 2:
- warning("TODO: talk_init(&dialog2);");
+ _conv2.start();
break;
case 3:
- warning("TODO: talk_init(&dialog3);");
+ _conv3.start();
break;
case 5:
- warning("TODO: talk_init(&dialog5);");
+ _conv5.start();
break;
case 6:
- warning("TODO: talk_init(&dialog6);");
+ _conv6.start();
break;
case 7:
- warning("TODO: talk_init(&dialog7);");
+ _conv7.start();
break;
case 8:
- warning("TODO: talk_init(&dialog8);");
+ _conv8.start();
+ break;
+
+ default:
break;
}
}
@@ -3801,12 +3804,10 @@ void Scene210::restoreDialogNode(int node, int msgId, int posY) {
curQuoteId++;
}
- initNode(node);
+ newNode(node);
}
void Scene210::enter() {
- UserInterface &userInterface = _vm->_game->_scene._userInterface;
-
_globals._spriteIndexes[1] = _scene->_sprites.addSprites(formAnimName('c', -1));
if (!_game._visitedScenes._sceneRevisited)
@@ -3841,16 +3842,16 @@ void Scene210::enter() {
_conv1.set(0x2E, 0xB4, 0xB5, 0xB6, 0xB8, 0);
if (_game._widepipeCtr >= 2)
- _conv1.write(0xB7, -1);
+ _conv1.write(0xB7, true);
}
bool sceneRevisited = _game._visitedScenes._sceneRevisited;
- _conv2.setup(0x2F, 0xBC, 0xBB, 0xBD, (int)!sceneRevisited);
- _conv3.setup(0x30, 0xC3, 0xC2, 0xC1, 0xC4, (int)!sceneRevisited);
- _conv5.setup(0x31, 0xCD, 0xCC, 0xCE, 0xCF, (int)!sceneRevisited);
- _conv6.setup(0x32, 0xD3, 0xD4, 0xD5, (int)!sceneRevisited);
- _conv7.setup(0x33, 0xD8, 0xDA, 0xD9, 0xDB, 0xDC, (int)!sceneRevisited);
- _conv8.setup(0x34, 0xDF, 0xE0, 0xE1, 0xE2, 0xE3, (int)!sceneRevisited);
+ _conv2.setup(0x2F, 0xBC, 0xBB, 0xBD, sceneRevisited ? 0 : -1);
+ _conv3.setup(0x30, 0xC3, 0xC2, 0xC1, 0xC4, sceneRevisited ? 0 : -1);
+ _conv5.setup(0x31, 0xCD, 0xCC, 0xCE, 0xCF, sceneRevisited ? 0 : -1);
+ _conv6.setup(0x32, 0xD3, 0xD4, 0xD5, sceneRevisited ? 0 : -1);
+ _conv7.setup(0x33, 0xD8, 0xDA, 0xD9, 0xDB, 0xDC, sceneRevisited ? 0 : -1);
+ _conv8.setup(0x34, 0xDF, 0xE0, 0xE1, 0xE2, 0xE3, sceneRevisited ? 0 : -1);
_twinkleAnimationType = 0;
_twinklesCurrentFrame = 0;
@@ -4091,12 +4092,10 @@ void Scene210::preActions() {
}
void Scene210::actions() {
- UserInterface &userInterface = _vm->_game->_scene._userInterface;
-
if (_action.isAction(VERB_LOOK, 0x27, 0x1C0)) {
_vm->_dialogs->show(0x5219);
} else if (_game._screenObjects._inputMode == 1) {
- handleDialogs();
+ handleConversations();
} 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) {
diff --git a/engines/mads/nebular/nebular_scenes2.h b/engines/mads/nebular/nebular_scenes2.h
index f50789999b..ad87681aac 100644
--- a/engines/mads/nebular/nebular_scenes2.h
+++ b/engines/mads/nebular/nebular_scenes2.h
@@ -217,17 +217,17 @@ private:
Conversation _conv1, _conv2, _conv3;
Conversation _conv5, _conv6, _conv7, _conv8;
- void handleDialogs();
- void handleSubDialog1();
- void handleSubDialog2();
- void handleSubDialog3();
- void handleSubDialog5();
- void handleSubDialog6();
- void handleSubDialog7();
- void handleSubDialog8();
+ void handleConversations();
+ void handleConversation1();
+ void handleConversation2();
+ void handleConversation3();
+ void handleConversation5();
+ void handleConversation6();
+ void handleConversation7();
+ void handleConversation8();
void setDialogNode(int node);
void handleTwinklesSpeech(int quoteId, int shiftX, uint32 delay);
- void initNode(int node);
+ void newNode(int node);
void restoreDialogNode(int node, int msgId, int posY);
public:
Scene210(MADSEngine *vm) : Scene2xx(vm), _curDialogNode(-1), _nextHandsPlace(0), _twinkleAnimationType(0), _twinklesCurrentFrame(0),
diff --git a/engines/mads/user_interface.cpp b/engines/mads/user_interface.cpp
index 48e62a5ae5..a5e8a844f9 100644
--- a/engines/mads/user_interface.cpp
+++ b/engines/mads/user_interface.cpp
@@ -226,9 +226,13 @@ void Conversation::setup(int globalId, ...) {
}
va_end(va);
- assert(_vm->getGameID() == GType_RexNebular);
- Nebular::GameNebular *game = (Nebular::GameNebular *)_vm->_game;
- game->_globals[globalId] = -1;
+ if (quoteId < 0) {
+ // For an ending value of -1, also initial the bitflags for the global
+ // associated with the conversation entry, which enables all the quote Ids
+ assert(_vm->getGameID() == GType_RexNebular);
+ Nebular::GameNebular *game = (Nebular::GameNebular *)_vm->_game;
+ game->_globals[globalId] = (int16)0xffff;
+ }
_globalId = globalId;
}