diff options
Diffstat (limited to 'engines/mads/nebular/nebular_scenes2.cpp')
-rw-r--r-- | engines/mads/nebular/nebular_scenes2.cpp | 122 |
1 files changed, 60 insertions, 62 deletions
diff --git a/engines/mads/nebular/nebular_scenes2.cpp b/engines/mads/nebular/nebular_scenes2.cpp index 39437045f7..b38aaceec1 100644 --- a/engines/mads/nebular/nebular_scenes2.cpp +++ b/engines/mads/nebular/nebular_scenes2.cpp @@ -99,7 +99,7 @@ void Scene2xx::sceneEntrySound() { _vm->_sound->command(10); break; case 213: - if (_globals[kMeteorologistWatch] == 0) + if (_globals[kMeteorologistWatch] == METEOROLOGIST_NORMAL) _vm->_sound->command(1); else _vm->_sound->command(9); @@ -419,26 +419,23 @@ void Scene202::enter() { if (_scene->_roomChanged) _game._objects.addToInventory(OBJ_BINOCULARS); - if (_globals[kMeteorologistWatch]) { + if (_globals[kMeteorologistWatch] != METEOROLOGIST_NORMAL) { _game._player._visible = false; _game._player._stepEnabled = false; - if (_globals[kMeteorologistWatch] == 2) - _ladderTopFl = true; - else - _ladderTopFl = false; - - if (_globals[kMeteorologistWatch] < 1) - _globals._sequenceIndexes[10] = _scene->_sequences.startCycle(_globals._spriteIndexes[9], false, 6); - else - _globals._sequenceIndexes[10] = _scene->_sequences.startCycle(_globals._spriteIndexes[9], false, 8); - _scene->_sequences.setDepth(_globals._sequenceIndexes[10], 1); + _ladderTopFl = (_globals[kMeteorologistWatch] == METEOROLOGIST_TOWER); if (_ladderTopFl) { + _globals._sequenceIndexes[10] = _scene->_sequences.startCycle(_globals._spriteIndexes[9], true, 8); + _scene->_sequences.setDepth(_globals._sequenceIndexes[10], 1); + _scene->_sequences.setMsgPosition(_globals._sequenceIndexes[10], Common::Point(247, 82)); _game._player._playerPos = Common::Point(246, 124); _game._player._facing = FACING_NORTH; _globals[kTeleporterUnderstood] = true; } else { + _globals._sequenceIndexes[10] = _scene->_sequences.startCycle(_globals._spriteIndexes[9], false, 6); + _scene->_sequences.setDepth(_globals._sequenceIndexes[10], 1); + _scene->_sequences.setMsgPosition(_globals._sequenceIndexes[10], Common::Point(172, 123)); _game._player._playerPos = Common::Point(171, 122); _game._player._facing = FACING_NORTH; @@ -447,15 +444,17 @@ void Scene202::enter() { _scene->loadAnimation(formAnimName('M', -1), 71); _scene->_activeAnimation->setCurrentFrame(200); } else { - _game._player._visible = false; - _scene->_sequences.startCycle(_globals._sequenceIndexes[9], true, 1); - _scene->_sequences.setDepth(_globals._sequenceIndexes[9], 1); - _scene->_sequences.setMsgPosition(_globals._sequenceIndexes[9], Common::Point(247, 82)); - _game._player._playerPos = Common::Point(246, 124); - _game._player._facing = FACING_NORTH; + if (_ladderTopFl) { + _game._player._visible = false; + _scene->_sequences.startCycle(_globals._sequenceIndexes[9], true, 1); + _scene->_sequences.setDepth(_globals._sequenceIndexes[9], 1); + _scene->_sequences.setMsgPosition(_globals._sequenceIndexes[9], Common::Point(247, 82)); + _game._player._playerPos = Common::Point(246, 124); + _game._player._facing = FACING_NORTH; + } } - _meteorologistSpecial = 0; + _meteorologistSpecial = false; } void Scene202::setRandomKernelMessage() { @@ -480,30 +479,35 @@ void Scene202::step() { if (_game._trigger == 71) { _vm->_sound->command(3); _vm->_sound->command(9); - _meteoClock1 = 900 + _scene->_frameStartTime; - Common::Point msgPos; - int msgFlag; - if (!_ladderTopFl) { - msgPos = Common::Point(0, 0); - msgFlag = 2; - } else { - msgPos = Common::Point(248, 15); - msgFlag = 0; - } - int msgIndex = _scene->_kernelMessages.add(msgPos, 0x1110, msgFlag | 32, 0, 120, _game.getQuote(102)); - _scene->_kernelMessages.setQuoted(msgIndex, 4, true); - if (_globals[kMeteorologistWatch] == 1) { - _action._activeAction._verbId = VERB_LOOK; - _action._activeAction._objectNameId = 39; - _action._activeAction._indirectObjectId = 438; - _game._triggerSetupMode = SEQUENCE_TRIGGER_PARSER; - _scene->_sequences.addTimer(120, 2); - _meteorologistSpecial = -1; - } else if (_globals[kMeteorologistWatch] == 2) { - _scene->_sequences.addTimer(120, 90); + _meteoClock1 = _scene->_frameStartTime + 15 * 60; + + if (_globals[kMeteorologistWatch] != METEOROLOGIST_NORMAL) { + Common::Point msgPos; + int msgFlag; + if (!_ladderTopFl) { + msgPos = Common::Point(0, 0); + msgFlag = 2; + } else { + msgPos = Common::Point(248, 15); + msgFlag = 0; + } + int msgIndex = _scene->_kernelMessages.add(msgPos, 0x1110, msgFlag | 32, 0, 120, _game.getQuote(102)); + _scene->_kernelMessages.setQuoted(msgIndex, 4, true); + + if (_globals[kMeteorologistWatch] == METEOROLOGIST_GROUND) { + _action._activeAction._verbId = VERB_LOOK; + _action._activeAction._objectNameId = NOUN_BINOCULARS; + _action._activeAction._indirectObjectId = NOUN_STRANGE_DEVICE; + _game._triggerSetupMode = SEQUENCE_TRIGGER_PARSER; + _scene->_sequences.addTimer(2 * 60, 2); + _meteorologistSpecial = true; + } else if (_globals[kMeteorologistWatch] == METEOROLOGIST_TOWER) { + _scene->_sequences.addTimer(2 * 60, 90); + } } - _globals[kMeteorologistWatch] = 0; + + _globals[kMeteorologistWatch] = METEOROLOGIST_NORMAL; } switch (_game._trigger) { @@ -550,7 +554,7 @@ void Scene202::step() { break; } - if (!_scene->_activeAnimation && (_globals[kMeteorologistStatus] != 2) && (_meteoClock2 <= _scene->_frameStartTime) && (_meteoClock1 <= _scene->_frameStartTime)) { + if (!_scene->_activeAnimation && (_globals[kMeteorologistStatus] != METEOROLOGIST_GONE) && (_meteoClock2 <= _scene->_frameStartTime) && (_meteoClock1 <= _scene->_frameStartTime)) { int randVal = _vm->getRandomNumber(1, 500); int threshold = 1; if (_ladderTopFl) @@ -574,10 +578,10 @@ void Scene202::step() { if (_waitingMeteoFl) { if (_scene->_activeAnimation->getCurrentFrame() >= 200) { - if ((_globals[kMeteorologistWatch] == 2) || _globals[kLadderBroken]) { + if ((_globals[kMeteorologistWatch] == METEOROLOGIST_TOWER) || _globals[kLadderBroken]) { _scene->_nextSceneId = 213; } else { - _vm->_dialogs->show(0x4EE9); + _vm->_dialogs->show(20201); _scene->_reloadSceneFlag = true; } } @@ -597,7 +601,7 @@ void Scene202::step() { } } - if (_meteoClock2 + 7200 <= _scene->_frameStartTime) { + if (_meteoClock2 + 120 * 60 <= _scene->_frameStartTime) { _toTeleportFl = true; } @@ -613,10 +617,12 @@ void Scene202::step() { case 42: case 77: case 96: + _stationCounter = 0; frameStep = subStep1(randVal); break; case 51: case 74: + _toStationFl = false; frameStep = subStep2(randVal); break; case 27: @@ -645,19 +651,13 @@ void Scene202::step() { break; } - if (frameStep < 0) - return; - - int nextFrame = 1 + _scene->_activeAnimation->getCurrentFrame() - frameStep; - if (nextFrame) { - _scene->_activeAnimation->setCurrentFrame(nextFrame); - _meteoFrame = nextFrame; + if (frameStep >= 0 && frameStep != _scene->_activeAnimation->getCurrentFrame() + 1) { + _scene->_activeAnimation->setCurrentFrame(frameStep); + _meteoFrame = frameStep; } } int Scene202::subStep1(int randVal) { - _stationCounter = 0; - if ((randVal <= 100) || _toStationFl) return 42; @@ -671,8 +671,6 @@ int Scene202::subStep1(int randVal) { } int Scene202::subStep2(int randVal) { - _toStationFl = false; - if ((randVal <= 150) && (_stationCounter < 5)) return 51; @@ -849,7 +847,7 @@ void Scene202::actions() { _scene->_sequences.setMsgPosition(_globals._sequenceIndexes[10], Common::Point(172, 123)); if (_scene->_activeAnimation) { _waitingMeteoFl = true; - _globals[kMeteorologistWatch] = 1; + _globals[kMeteorologistWatch] = METEOROLOGIST_GROUND; } else { _scene->_sequences.addTimer(120, 2); } @@ -894,7 +892,7 @@ void Scene202::actions() { _scene->_sequences.addTimer(120, 2); } else { _waitingMeteoFl = true; - _globals[kMeteorologistWatch] = 2; + _globals[kMeteorologistWatch] = METEOROLOGIST_GONE; if ((_scene->_activeAnimation->getCurrentFrame() >= 44) && (_scene->_activeAnimation->getCurrentFrame() <= 75)) { _scene->_kernelMessages.reset(); int msgIndex = _scene->_kernelMessages.add(Common::Point(248, 15), 0x1110, 32, 0, 60, _game.getQuote(100)); @@ -911,7 +909,7 @@ void Scene202::actions() { case 2: if (!_scene->_activeAnimation) _vm->_dialogs->show(0x4EFE); - _meteorologistSpecial = 0; + _meteorologistSpecial = false; _scene->_sequences.remove(_globals._sequenceIndexes[10]); _globals._sequenceIndexes[9] = _scene->_sequences.addReverseSpriteCycle(_globals._spriteIndexes[9], false, 6, 1, 0, 0); _scene->_sequences.setMsgPosition(_globals._sequenceIndexes[9], Common::Point(247, 82)); @@ -1000,7 +998,7 @@ void Scene202::synchronize(Common::Serializer &s) { s.syncAsUint32LE(_meteoClock2); s.syncAsUint32LE(_startTime); - s.syncAsSint32LE(_meteorologistSpecial); + s.syncAsByte(_meteorologistSpecial); } /*****************************************************************************/ @@ -4863,7 +4861,7 @@ void Scene213::setup() { } void Scene213::enter() { - if (_globals[kMeteorologistWatch] != 0) + if (_globals[kMeteorologistWatch] != METEOROLOGIST_ABSENT) _handSpriteId = _scene->_sprites.addSprites("*METHAND"); else if (_globals[kSexOfRex] == REX_MALE) _handSpriteId = _scene->_sprites.addSprites("*REXHAND"); @@ -4874,7 +4872,7 @@ void Scene213::enter() { // The original is calling Scene2xx::sceneEntrySound() if (_vm->_musicFlag) { - if (_globals[kMeteorologistWatch] == 0) + if (_globals[kMeteorologistWatch] == METEOROLOGIST_ABSENT) _vm->_sound->command(1); else _vm->_sound->command(9); |