From 932222de7dd32ff0a0b643a2e9d756160bff27bf Mon Sep 17 00:00:00 2001 From: Paul Gilbert Date: Wed, 21 Jan 2015 20:42:44 -0500 Subject: XEEN: Skeleton beginnings of script handling --- engines/xeen/files.cpp | 11 ++++ engines/xeen/files.h | 2 + engines/xeen/interface.cpp | 4 +- engines/xeen/interface.h | 3 +- engines/xeen/map.cpp | 5 +- engines/xeen/scripts.cpp | 161 +++++++++++++++++++++++++++++++++++++++++++++ engines/xeen/scripts.h | 78 +++++++++++++++++++++- 7 files changed, 257 insertions(+), 7 deletions(-) (limited to 'engines/xeen') diff --git a/engines/xeen/files.cpp b/engines/xeen/files.cpp index f8e7a3fc0c..0c3402f00d 100644 --- a/engines/xeen/files.cpp +++ b/engines/xeen/files.cpp @@ -232,4 +232,15 @@ void File::openFile(const Common::String &filename, Common::Archive &archive) { error("Could not open file - %s", filename.c_str()); } +Common::String File::readString() { + Common::String result; + char c; + + while (pos() < size() && (c = (char)readByte()) != '\0') + result += c; + + return result; +} + + } // End of namespace Xeen diff --git a/engines/xeen/files.h b/engines/xeen/files.h index f350e34166..f0c92d1050 100644 --- a/engines/xeen/files.h +++ b/engines/xeen/files.h @@ -75,6 +75,8 @@ public: void openFile(const Common::String &filename); void openFile(const Common::String &filename, Common::Archive &archive); + + Common::String readString(); }; class XeenSerializer : public Common::Serializer { diff --git a/engines/xeen/interface.cpp b/engines/xeen/interface.cpp index d2fea36872..e31b9e240a 100644 --- a/engines/xeen/interface.cpp +++ b/engines/xeen/interface.cpp @@ -43,7 +43,6 @@ Interface::Interface(XeenEngine *vm) : ButtonContainer(), InterfaceMap(vm), _vm( _hiliteChar = -1; _intrIndex1 = 0; _flag1 = false; - _animCounter = 0; _isAnimReset = false; _tillMove = 0; _overallFrame = 0; @@ -542,6 +541,7 @@ void Interface::draw3d(bool updateFlag) { Map &map = *_vm->_map; Party &party = *_vm->_party; Screen &screen = *_vm->_screen; + Scripts &scripts = *_vm->_scripts; if (screen._windows[11]._enabled) return; @@ -570,7 +570,7 @@ void Interface::draw3d(bool updateFlag) { mazeObject._frame = animEntry._frame1._frames[directionIndex]; } else { ++mazeObject._frame; - if ((int)idx == objNum && _animCounter > 0 && ( + if ((int)idx == objNum && scripts._animCounter > 0 && ( objObject._spriteId == (_vm->_files->_isDarkCc ? 15 : 16) || objObject._spriteId == 58 || objObject._spriteId == 73)) { if (mazeObject._frame > 4 || mazeObject._spriteId == 58) diff --git a/engines/xeen/interface.h b/engines/xeen/interface.h index 93c861e0cd..37ac7be5be 100644 --- a/engines/xeen/interface.h +++ b/engines/xeen/interface.h @@ -66,10 +66,8 @@ private: int _heroismUIFrame; int _flipUIFrame; bool _buttonsLoaded; - Common::String _interfaceText; int _hiliteChar; bool _flag1; - int _animCounter; bool _isAnimReset; byte _tillMove; int _overallFrame; @@ -107,6 +105,7 @@ private: bool checkMoveDirection(int key); public: int _intrIndex1; + Common::String _interfaceText; public: Interface(XeenEngine *vm); diff --git a/engines/xeen/map.cpp b/engines/xeen/map.cpp index e541d374d6..d2f4c5e18d 100644 --- a/engines/xeen/map.cpp +++ b/engines/xeen/map.cpp @@ -1284,8 +1284,9 @@ void Map::loadEvents(int mapId) { filename = Common::String::format("aaze%c%03d.txt", (mapId >= 100) ? 'x' : '0', mapId); File fText(filename); - _events._text.resize(fText.size()); - fText.read(&_events._text[0], fText.size()); + _events._text.clear(); + while (fText.pos() < fText.size()) + _events._text.push_back(fText.readString()); fText.close(); } diff --git a/engines/xeen/scripts.cpp b/engines/xeen/scripts.cpp index 55388ec343..50584a2551 100644 --- a/engines/xeen/scripts.cpp +++ b/engines/xeen/scripts.cpp @@ -22,6 +22,7 @@ #include "xeen/scripts.h" #include "xeen/party.h" +#include "xeen/xeen.h" namespace Xeen { @@ -65,9 +66,76 @@ void MazeEvents::synchronize(XeenSerializer &s) { /*------------------------------------------------------------------------*/ Scripts::Scripts(XeenEngine *vm) : _vm(vm) { + Common::fill(&_charFX[0], &_charFX[MAX_ACTIVE_PARTY], 0); + _whoWill = 0; + _itemType = 0; + _treasureItems = 0; + _treasureGold = 0; + _treasureGems = 0; + + _v2 = 0; + _nEdamageType = 0; + _animCounter = 0; + _eventSkipped = false; } void Scripts::checkEvents() { + Combat &combat = *_vm->_combat; + Interface &intf = *_vm->_interface; + Map &map = *_vm->_map; + Party &party = *_vm->_party; + + int var18 = 0; + _itemType = 0; + int var4F = 0; + bool var50 = false; + _whoWill = 0; + Mode oldMode = _vm->_mode; + Common::fill(&_charFX[0], &_charFX[MAX_ACTIVE_PARTY], 0); + int items = _treasureItems; + + if (_treasureGold & _treasureItems) { + // TODO + } else { + // TODO + } + + do { + int var4 = 0; + int varA = 0; + _animCounter = 0; + int var4E = 0; + const Common::Point pt = party._mazePosition; + int varC = 1; + _v2 = 1; + _nEdamageType = 0; + int var40 = -1; + + // Break out of the events if there's an attacking monster + if (combat._attackMonsters[0] != -1) { + _eventSkipped = true; + break; + } + + _eventSkipped = false; + + for (uint eventIndex = 0; eventIndex < map._events.size(); ++eventIndex) { + MazeEvent &event = map._events[eventIndex]; + + if (event._position == pt && party._mazeDirection != (pt.x | pt.y)) { + if (event._direction == party._mazeDirection || event._direction == DIR_ALL) { + _vm->_mode = MODE_9; + intf._interfaceText = event._parameters.size() == 0 ? "" : + map._events._text[event._parameters[0]]; + doOpcode(event._opcode, event._parameters); + + } else { + var50 = true; + } + } + } + } while (0); + // TODO } @@ -79,4 +147,97 @@ void Scripts::openGrate(int v1, int v2) { // TODO } +typedef void(Scripts::*ScriptMethodPtr)(Common::Array &); + +void Scripts::doOpcode(Opcode opcode, Common::Array ¶ms) { + static const ScriptMethodPtr COMMAND_LIST[] = { + &Scripts::cmdNone, &Scripts::cmdDisplay0x01, &Scripts::cmdDoorTextSml, + &Scripts::cmdDoorTextLrg, &Scripts::cmdSignText, + &Scripts::cmdNPC, &Scripts::cmdPlayFX, &Scripts::cmdTeleportAndExit, + &Scripts::cmdIf1, &Scripts::cmdIf2, &Scripts::cmdIf3, + &Scripts::cmdMoveObj, &Scripts::cmdTakeOrGive, &Scripts::cmdNoAction, + &Scripts::cmdRemove, &Scripts::cmdSetChar, &Scripts::cmdSpawn, + &Scripts::cmdDoTownEvent, &Scripts::cmdExit, &Scripts::cmdAfterMap, + &Scripts::cmdGiveExtended, &Scripts::cmdConfirmWord, &Scripts::cmdDamage, + &Scripts::cmdJumpRnd, &Scripts::cmdAfterEvent, &Scripts::cmdCallEvent, + &Scripts::cmdReturn, &Scripts::cmdSetVar, &Scripts::cmdTakeOrGive2, + &Scripts::cmdTakeOrGive3, &Scripts::cmdCutsceneEndClouds, + &Scripts::cmdTeleportAndContinue, &Scripts::cmdWhoWill, + &Scripts::cmdRndDamage, &Scripts::cmdMoveWallObj, &Scripts::cmdAlterCellFlag, + &Scripts::cmdAlterHed, &Scripts::cmdDisplayStat, &Scripts::cmdTakeOrGive4, + &Scripts::cmdSeatTextSml, &Scripts::cmdPlayEventVoc, &Scripts::cmdDisplayBottom, + &Scripts::cmdIfMapFlag, &Scripts::cmdSelRndChar, &Scripts::cmdGiveEnchanted, + &Scripts::cmdItemType, &Scripts::cmdMakeNothingHere, &Scripts::cmdNoAction2, + &Scripts::cmdChooseNumeric, &Scripts::cmdDisplayBottomTwoLines, + &Scripts::cmdDisplayLarge, &Scripts::cmdExchObj, &Scripts::cmdFallToMap, + &Scripts::cmdDisplayMain, &Scripts::cmdGoto, &Scripts::cmdConfirmWord2, + &Scripts::cmdGotoRandom, &Scripts::cmdCutsceneEndDarkside, + &Scripts::cmdCutsceneEdWorld, &Scripts::cmdFlipWorld, &Scripts::cmdPlayCD + }; + + (this->*COMMAND_LIST[opcode])(params); +} + +void Scripts::cmdNone(Common::Array ¶ms) {} +void Scripts::cmdDisplay0x01(Common::Array ¶ms) {} +void Scripts::cmdDoorTextSml(Common::Array ¶ms) {} +void Scripts::cmdDoorTextLrg(Common::Array ¶ms) {} +void Scripts::cmdSignText(Common::Array ¶ms) {} +void Scripts::cmdNPC(Common::Array ¶ms) {} +void Scripts::cmdPlayFX(Common::Array ¶ms) {} +void Scripts::cmdTeleportAndExit(Common::Array ¶ms) {} +void Scripts::cmdIf1(Common::Array ¶ms) {} +void Scripts::cmdIf2(Common::Array ¶ms) {} +void Scripts::cmdIf3(Common::Array ¶ms) {} +void Scripts::cmdMoveObj(Common::Array ¶ms) {} +void Scripts::cmdTakeOrGive(Common::Array ¶ms) {} +void Scripts::cmdNoAction(Common::Array ¶ms) {} +void Scripts::cmdRemove(Common::Array ¶ms) {} +void Scripts::cmdSetChar(Common::Array ¶ms) {} +void Scripts::cmdSpawn(Common::Array ¶ms) {} +void Scripts::cmdDoTownEvent(Common::Array ¶ms) {} +void Scripts::cmdExit(Common::Array ¶ms) {} +void Scripts::cmdAfterMap(Common::Array ¶ms) {} +void Scripts::cmdGiveExtended(Common::Array ¶ms) {} +void Scripts::cmdConfirmWord(Common::Array ¶ms) {} +void Scripts::cmdDamage(Common::Array ¶ms) {} +void Scripts::cmdJumpRnd(Common::Array ¶ms) {} +void Scripts::cmdAfterEvent(Common::Array ¶ms) {} +void Scripts::cmdCallEvent(Common::Array ¶ms) {} +void Scripts::cmdReturn(Common::Array ¶ms) {} +void Scripts::cmdSetVar(Common::Array ¶ms) {} +void Scripts::cmdTakeOrGive2(Common::Array ¶ms) {} +void Scripts::cmdTakeOrGive3(Common::Array ¶ms) {} +void Scripts::cmdCutsceneEndClouds(Common::Array ¶ms) {} +void Scripts::cmdTeleportAndContinue(Common::Array ¶ms) {} +void Scripts::cmdWhoWill(Common::Array ¶ms) {} +void Scripts::cmdRndDamage(Common::Array ¶ms) {} +void Scripts::cmdMoveWallObj(Common::Array ¶ms) {} +void Scripts::cmdAlterCellFlag(Common::Array ¶ms) {} +void Scripts::cmdAlterHed(Common::Array ¶ms) {} +void Scripts::cmdDisplayStat(Common::Array ¶ms) {} +void Scripts::cmdTakeOrGive4(Common::Array ¶ms) {} +void Scripts::cmdSeatTextSml(Common::Array ¶ms) {} +void Scripts::cmdPlayEventVoc(Common::Array ¶ms) {} +void Scripts::cmdDisplayBottom(Common::Array ¶ms) {} +void Scripts::cmdIfMapFlag(Common::Array ¶ms) {} +void Scripts::cmdSelRndChar(Common::Array ¶ms) {} +void Scripts::cmdGiveEnchanted(Common::Array ¶ms) {} +void Scripts::cmdItemType(Common::Array ¶ms) {} +void Scripts::cmdMakeNothingHere(Common::Array ¶ms) {} +void Scripts::cmdNoAction2(Common::Array ¶ms) {} +void Scripts::cmdChooseNumeric(Common::Array ¶ms) {} +void Scripts::cmdDisplayBottomTwoLines(Common::Array ¶ms) {} +void Scripts::cmdDisplayLarge(Common::Array ¶ms) {} +void Scripts::cmdExchObj(Common::Array ¶ms) {} +void Scripts::cmdFallToMap(Common::Array ¶ms) {} +void Scripts::cmdDisplayMain(Common::Array ¶ms) {} +void Scripts::cmdGoto(Common::Array ¶ms) {} +void Scripts::cmdConfirmWord2(Common::Array ¶ms) {} +void Scripts::cmdGotoRandom(Common::Array ¶ms) {} +void Scripts::cmdCutsceneEndDarkside(Common::Array ¶ms) {} +void Scripts::cmdCutsceneEdWorld(Common::Array ¶ms) {} +void Scripts::cmdFlipWorld(Common::Array ¶ms) {} +void Scripts::cmdPlayCD(Common::Array ¶ms) {} + } // End of namespace Xeen diff --git a/engines/xeen/scripts.h b/engines/xeen/scripts.h index 9974892221..2fbcf78b38 100644 --- a/engines/xeen/scripts.h +++ b/engines/xeen/scripts.h @@ -26,6 +26,7 @@ #include "common/scummsys.h" #include "common/system.h" #include "common/serializer.h" +#include "common/str-array.h" #include "xeen/files.h" namespace Xeen { @@ -111,7 +112,7 @@ public: class MazeEvents : public Common::Array { public: - Common::Array _text; + Common::StringArray _text; public: void synchronize(XeenSerializer &s); }; @@ -119,6 +120,81 @@ public: class Scripts { private: XeenEngine *_vm; + int _charFX[6]; + int _whoWill; + int _itemType; + int _treasureItems; + int _treasureGold; + int _treasureGems; + + int _v2; + int _nEdamageType; + + void doOpcode(Opcode opcode, Common::Array ¶ms); + void cmdNone(Common::Array ¶ms); + void cmdDisplay0x01(Common::Array ¶ms); + void cmdDoorTextSml(Common::Array ¶ms); + void cmdDoorTextLrg(Common::Array ¶ms); + void cmdSignText(Common::Array ¶ms); + void cmdNPC(Common::Array ¶ms); + void cmdPlayFX(Common::Array ¶ms); + void cmdTeleportAndExit(Common::Array ¶ms); + void cmdIf1(Common::Array ¶ms); + void cmdIf2(Common::Array ¶ms); + void cmdIf3(Common::Array ¶ms); + void cmdMoveObj(Common::Array ¶ms); + void cmdTakeOrGive(Common::Array ¶ms); + void cmdNoAction(Common::Array ¶ms); + void cmdRemove(Common::Array ¶ms); + void cmdSetChar(Common::Array ¶ms); + void cmdSpawn(Common::Array ¶ms); + void cmdDoTownEvent(Common::Array ¶ms); + void cmdExit(Common::Array ¶ms); + void cmdAfterMap(Common::Array ¶ms); + void cmdGiveExtended(Common::Array ¶ms); + void cmdConfirmWord(Common::Array ¶ms); + void cmdDamage(Common::Array ¶ms); + void cmdJumpRnd(Common::Array ¶ms); + void cmdAfterEvent(Common::Array ¶ms); + void cmdCallEvent(Common::Array ¶ms); + void cmdReturn(Common::Array ¶ms); + void cmdSetVar(Common::Array ¶ms); + void cmdTakeOrGive2(Common::Array ¶ms); + void cmdTakeOrGive3(Common::Array ¶ms); + void cmdCutsceneEndClouds(Common::Array ¶ms); + void cmdTeleportAndContinue(Common::Array ¶ms); + void cmdWhoWill(Common::Array ¶ms); + void cmdRndDamage(Common::Array ¶ms); + void cmdMoveWallObj(Common::Array ¶ms); + void cmdAlterCellFlag(Common::Array ¶ms); + void cmdAlterHed(Common::Array ¶ms); + void cmdDisplayStat(Common::Array ¶ms); + void cmdTakeOrGive4(Common::Array ¶ms); + void cmdSeatTextSml(Common::Array ¶ms); + void cmdPlayEventVoc(Common::Array ¶ms); + void cmdDisplayBottom(Common::Array ¶ms); + void cmdIfMapFlag(Common::Array ¶ms); + void cmdSelRndChar(Common::Array ¶ms); + void cmdGiveEnchanted(Common::Array ¶ms); + void cmdItemType(Common::Array ¶ms); + void cmdMakeNothingHere(Common::Array ¶ms); + void cmdNoAction2(Common::Array ¶ms); + void cmdChooseNumeric(Common::Array ¶ms); + void cmdDisplayBottomTwoLines(Common::Array ¶ms); + void cmdDisplayLarge(Common::Array ¶ms); + void cmdExchObj(Common::Array ¶ms); + void cmdFallToMap(Common::Array ¶ms); + void cmdDisplayMain(Common::Array ¶ms); + void cmdGoto(Common::Array ¶ms); + void cmdConfirmWord2(Common::Array ¶ms); + void cmdGotoRandom(Common::Array ¶ms); + void cmdCutsceneEndDarkside(Common::Array ¶ms); + void cmdCutsceneEdWorld(Common::Array ¶ms); + void cmdFlipWorld(Common::Array ¶ms); + void cmdPlayCD(Common::Array ¶ms); +public: + int _animCounter; + bool _eventSkipped; public: Scripts(XeenEngine *vm); -- cgit v1.2.3