diff options
-rw-r--r-- | engines/supernova2/ms2_def.h | 20 | ||||
-rw-r--r-- | engines/supernova2/rooms.cpp | 150 | ||||
-rw-r--r-- | engines/supernova2/rooms.h | 4 |
3 files changed, 161 insertions, 13 deletions
diff --git a/engines/supernova2/ms2_def.h b/engines/supernova2/ms2_def.h index 40ce6d7289..a216bba514 100644 --- a/engines/supernova2/ms2_def.h +++ b/engines/supernova2/ms2_def.h @@ -192,13 +192,13 @@ kString10Xa, kStringSlotDescription1, kStringSlotDescription2, kStringChair, kSt kStringScribble, kStringFace, kStringFaceDescription, kStringBooks, kStringDictionary, kStringPlant, kStringMask, kStringSnake, kStringCup, kStringJoystick, kStringToothbrushDescription, kStringMusic, kStringMusicDescription, kStringBottle, kStringBottleDescription, -kStringBox, kStringSeller, kString332, kString333, kString334, -kString335, kString336, kString337, kString338, kString339, -kString340, kString341, kString342, kString343, kString344, -kString345, kString346, kString347, kString348, kString349, -kString350, kString351, kString352, kString353, kString354, -kString355, kString356, kString357, kString358, kString359, -kString360, kString361, kString362, kString363, kString364, +kStringBox, kStringSeller, kStringWhat, kStringNotInformed, kStringHorstHummel, +kStringNiceWeather, kStringTellTicket, kStringHereIsXa, kString500Xa, kString1000Xa, +kString5000Xa, kString10000Xa, kStringThankYou, kStringWhatYouOffer, kStringHello2, +kStringWhatYouWant, kStringWhoAreYou, kStringHorstHummel2, kStringNeverHeard, kStringYouDontKnow, +kStringImOnTV, kStringIDontKnow, kStringFunny, kStringAha, kStringICan, +kStringFromWhom, kStringCost, kStringAsYouSay, kStringGetCard, kStringOnlyParticipation, +kStringWhatForIt, kStringMakeOffer, kStringGoodOffer, kStringGiveCard, kStringIdiot, kString365, kString366, kString367, kString368, kString369, kString370, kString371, kString372, kString373, kString374, kString375, kString376, kString377, kString378, kString379, @@ -235,8 +235,8 @@ kString525, kString526, kString527, kString528, kString529, kString530, kString531, kString532, kString533, kString534, kString535, kString536, kString537, kString538, kString539, kString540, kString541, kString542, kString543, kString544, -kString545, kString546, kString547, kString548, kString549, -kString550, kString551, kString552, kString553, kString554, +kString545, kString546, kStringFascinating, kStringTaxis, kStringTaxisDescription, +kStringAxacussan, kStringParticipationCard, kString552, kString553, kString554, kString555, kString556, kString557, kString558, kString559, kString560, kString561, kString562, kString563, kString564, kString565, kString566, kString567, kString568, kString569, @@ -249,7 +249,7 @@ kStringIntroTV3, kStringIntroTV4, kStringIntroTV5, kStringIntroTV6, kStringIntro kStringIntroTV8, kStringIntroTV9, kStringIntroTV10, kStringIntroTV11, kStringIntroTV12, kStringIntroTV13, kStringIntroTV14, kStringIntroTV15, kStringIntroTV16, kStringIntro9, kStringIntro10, kStringIntro11, kStringIntro12, kStringIntro13, kStringIntro14, -kStringDialogSeparator +kStringDialogSeparator, kStringForMusicConcert }; ObjectType operator|(ObjectType a, ObjectType b); diff --git a/engines/supernova2/rooms.cpp b/engines/supernova2/rooms.cpp index 329f529877..6641f6aa3a 100644 --- a/engines/supernova2/rooms.cpp +++ b/engines/supernova2/rooms.cpp @@ -763,9 +763,9 @@ void Cabin::onEntrance() { void Cabin::animation() { if (_paid) { if (isSectionVisible(1)) - _vm->renderImage(1 + 128); + setSectionVisible(1, kShownFalse); else - _vm->renderImage(1); + setSectionVisible(1, kShownTrue); } _gm->setAnimationTimer(4); } @@ -995,9 +995,19 @@ CulturePalace::CulturePalace(Supernova2Engine *vm, GameManager *gm) { _vm = vm; _gm = gm; - _fileNumber = 6; + _fileNumber = 20; _id = CULTURE_PALACE; _shown[0] = kShownTrue; + + _var1 = false; + _var2 = false; + _var3 = false; + + _objectState[0] = Object(_id, kStringExit, kStringDefaultDescription, NULLOBJECT, EXIT, 1, 1, 0, CASHBOX, 6); + _objectState[1] = Object(_id, kStringCulturePalace, kStringFascinating, NULLOBJECT, NULLTYPE, 0, 0, 0); + _objectState[2] = Object(_id, kStringTaxis, kStringTaxisDescription, NULLOBJECT, NULLTYPE, 3, 3, 0); + _objectState[3] = Object(_id, kStringAxacussan, kStringDefaultDescription, AXACUSSER, TALK, 4, 4, 0); + _objectState[4] = Object(_id, kStringParticipationCard, kStringDefaultDescription, CARD, TAKE, 255, 255, 0); } void CulturePalace::onEntrance() { @@ -1005,9 +1015,143 @@ void CulturePalace::onEntrance() { } void CulturePalace::animation() { + static int i; + if (isSectionVisible(4)) + setSectionVisible(4, kShownFalse); + else + setSectionVisible(4, kShownTrue); + i--; + if (i <= 0) { + if (isSectionVisible(3)) { + setSectionVisible(3, kShownFalse); + i = 4; + } else { + setSectionVisible(3, kShownTrue); + i = 10; + } + } + _gm->setAnimationTimer(2); +} + +void CulturePalace::notEnoughMoney() { + _gm->reply(kStringWhat, 2, 1); + _gm->reply(kStringNotInformed, 2, 1); + _vm->renderImage(1 + 128); + setSectionVisible(2, kShownFalse); } bool CulturePalace::interact(Action verb, Object &obj1, Object &obj2) { + static StringId dial1[4] = { + kStringHorstHummel, + kStringNiceWeather, + kStringTellTicket, + kStringForMusicConcert + }; + static byte dials1[] = {1, 1, 2}; + + static StringId dial2[2] = { + kStringHereIsXa, + kStringYouAreCrazy + }; + static StringId dial3[4] = { + kString500Xa, + kString1000Xa, + kString5000Xa, + kString10000Xa + }; + + int e; + if (verb == ACTION_TALK && obj1._id == AXACUSSER) { + if (_var3) { + _vm->renderImage(1); + _gm->reply(kStringThankYou, 2, 1); + } else if (_var2) { + _vm->renderImage(1); + _gm->reply(kStringWhatYouOffer, 2, 1); + } else { + _gm->say(kStringHello2); + _vm->renderImage(1); + _gm->reply(kStringWhatYouWant, 2, 1); + addSentence(1, 1); + switch (_gm->dialog(3, dials1, dial1, 1)) { + case 0: + _gm->reply(kStringWhoAreYou, 2, 1); + _gm->say(kStringHorstHummel2); + _gm->reply(kStringNeverHeard, 2, 1); + _gm->say(kStringYouDontKnow); + _gm->say(kStringImOnTV); + _gm->reply(kStringIDontKnow, 2, 1); + _gm->say(kStringFunny); + break; + case 1: + _gm->reply(kStringAha, 2, 1); + break; + case 2: + _gm->reply(kStringICan, 2, 1); + _gm->say(kStringFromWhom); + _gm->reply(kStringCost, 2, 1); + if(!_gm->_state._money) + addSentence(2, 1); + else if (_gm->dialog(2, _gm->_dials, dial2, 0)) { + _gm->reply(kStringAsYouSay, 2, 1); + addSentence(2, 1); + } else { + _gm->takeMoney(-1); + _gm->reply(kStringGetCard, 2, 1); + _gm->reply(kStringOnlyParticipation, 2, 1); + _gm->say(kStringWhatForIt); + _gm->reply(kStringMakeOffer, 2, 1); + _var2 = true; + } + break; + } + } + _vm->renderImage(1 + 128); + setSectionVisible(2, kShownFalse); + _gm->drawStatus(); + _gm->drawInventory(); + _gm->drawMapExits(); + _gm->drawCommandBox(); + } + else if (verb == ACTION_GIVE && obj2._id == AXACUSSER && _var2) { + _vm->renderImage(1); + if (obj1._id != MONEY) + notEnoughMoney(); + else { + if (_gm->_state._money >= 10000) { + if ((e = _gm->dialog(4, _gm->_dials, dial3, 0)) >= 2) { + _gm->reply(kStringGoodOffer, 2, 1); + _vm->playSound(kAudioSuccess); + _gm->reply(kStringGiveCard, 2, 1); + if (e == 2) + _gm->takeMoney(-5000); + else + _gm->takeMoney(-10000); + _gm->takeObject(*getObject(4)); + _vm->renderImage(1 + 128); + setSectionVisible(2, false); + _gm->reply(kStringIdiot, 0, 0); + _var2 = false; + _var3 = true; + _gm->_rooms[CASHBOX]->addSentence(1,1); + _gm->drawStatus(); + _gm->drawInventory(); + _gm->drawMapExits(); + _gm->drawCommandBox(); + } else { + notEnoughMoney(); + _gm->drawStatus(); + _gm->drawInventory(); + _gm->drawMapExits(); + _gm->drawCommandBox(); + } + } + else + notEnoughMoney(); + } + } + else + return false; return true; } diff --git a/engines/supernova2/rooms.h b/engines/supernova2/rooms.h index 288023c786..6045fb509d 100644 --- a/engines/supernova2/rooms.h +++ b/engines/supernova2/rooms.h @@ -160,6 +160,10 @@ public: virtual bool interact(Action verb, Object &obj1, Object &obj2); private: + void notEnoughMoney(); + bool _var1; + bool _var2; + bool _var3; }; class Cashbox : public Room { |