| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277 |
- #ifndef MAPD_H
- #define MAPD_H
- #pragma warning (disable : 4482)
- #include <string>
- #include <vector>
- #include "global.h"
- #include "hch\CSemiDefHandler.h"
- #include "hch\CDefHandler.h"
- class CGDefInfo;
- enum ESortBy{name,playerAm,size,format, viccon,loscon};
- struct Sresource
- {
- std::string resName; //name of this resource
- int amount; //it can be greater and lesser than 0
- };
- struct TimeEvent
- {
- std::string eventName;
- std::string message;
- std::vector<Sresource> decIncRes; //decreases / increases of resources
- unsigned int whichPlayers; //which players are affected by this event (+1 - first, +2 - second, +4 - third, +8 - fourth etc.)
- bool areHumansAffected;
- bool areCompsAffected;
- int firstAfterNDays; //how many days after appears this event
- int nextAfterNDays; //how many days after the epperance before appaers this event
- //bajty wydarzeñ (59 + |teksty|)
- //4 bajty na d³ugoœæ nazwy zdarzenia
- //nazwa zdarzenia (bajty dodatkowe)
- //4 bajty na d³ugoœæ wiadomoœci
- //wiadomoϾ (bajty dodatkowe)
- //4 bajty na zwiêkszenie siê ilosci drewna (zapis normalny) lub ff,ff,ff,ff - iloœæ drewna do odebrania (maksymalna iloœæ drewna, któr¹ mo¿na daæ/odebraæ to 32767)
- //4 bajty na zwiêkszenie siê ilosci rtêci (zapis normalny) lub ff,ff,ff,ff - iloœæ rtêci do odebrania (maksymalna iloœæ rtêci, któr¹ mo¿na daæ/odebraæ to 32767)
- //4 bajty na zwiêkszenie siê ilosci rudy (zapis normalny) lub ff,ff,ff,ff - iloœæ rudy do odebrania (maksymalna iloœæ rudy, któr¹ mo¿na daæ/odebraæ to 32767)
- //4 bajty na zwiêkszenie siê ilosci siarki (zapis normalny) lub ff,ff,ff,ff - iloœæ siarki do odebrania (maksymalna iloœæ siarki, któr¹ mo¿na daæ/odebraæ to 32767)
- //4 bajty na zwiêkszenie siê ilosci kryszta³u (zapis normalny) lub ff,ff,ff,ff - iloœæ kryszta³u do odebrania (maksymalna iloœæ kryszta³u, któr¹ mo¿na daæ/odebraæ to 32767)
- //4 bajty na zwiêkszenie siê ilosci klejnotów (zapis normalny) lub ff,ff,ff,ff - iloœæ klejnotów do odebrania (maksymalna iloœæ klejnotów, któr¹ mo¿na daæ/odebraæ to 32767)
- //4 bajty na zwiêkszenie siê ilosci z³ota (zapis normalny) lub ff,ff,ff,ff - iloœæ z³ota do odebrania (maksymalna iloœæ z³ota, któr¹ mo¿na daæ/odebraæ to 32767)
- //1 bajt - których graczy dotyczy zdarzenie (pole bitowe, +1 - pierwszy, +2 - drugi, +4 - trzeci, +8 - czwarty, +16 - pi¹ty, +32 - szósty, +64 - siódmy, +128 - ósmy)
- //1 bajt - czy zdarzenie odnosi siê do graczy - ludzi (00 - nie, 01 - tak)
- //1 bajt - czy zdarzenie odnosi siê do graczy komputerowych (00 - nie, 01 - tak)
- //2 bajty - opóŸnienie pierwszego wyst¹pienia (w dniach, zapis normalny, maks 671)
- //1 bajt - co ile dni wystêpuje zdarzenie (maks 28, 00 oznacza zdarzenie jednorazowe)
- //17 bajtów zerowych
- };
- struct TerrainTile
- {
- EterrainType tertype; // type of terrain
- unsigned char terview; // look of terrain
- Eriver nuine; // type of Eriver (0 if there is no Eriver)
- unsigned char rivDir; // direction of Eriver
- Eroad malle; // type of Eroad (0 if there is no Eriver)
- unsigned char roadDir; // direction of Eroad
- unsigned char siodmyTajemniczyBajt; // mysterius byte // jak bedzie waidomo co to, to sie nazwie inaczej
- };
- struct DefInfo //information from def declaration
- {
- std::string name;
- int bytes [42];
- //CSemiDefHandler * handler;
- CDefHandler * handler;
- int printPriority;
- bool isOnDefList;
- bool isVisitable();
- };
- struct Location
- {
- int x, y;
- bool z; // underground
- };
- struct SheroName //name of starting hero
- {
- int heroID;
- std::string heroName;
- };
- struct PlayerInfo
- {
- int p8, p9;
- bool canHumanPlay;
- bool canComputerPlay;
- unsigned int AITactic; //(00 - random, 01 - warrior, 02 - builder, 03 - explorer)
- unsigned int allowedFactions; //(01 - castle; 02 - rampart; 04 - tower; 08 - inferno; 16 - necropolis; 32 - dungeon; 64 - stronghold; 128 - fortress; 256 - conflux);
- bool isFactionRandom;
- unsigned int mainHeroPortrait; //it's ID of hero with choosen portrait; 255 if standard
- std::string mainHeroName;
- std::vector<SheroName> heroesNames;
- bool hasMainTown;
- bool generateHeroAtMainTown;
- Location posOfMainTown;
- int team;
- bool generateHero;
- };
- struct LossCondition
- {
- ElossCon typeOfLossCon;
- union
- {
- Location castlePos;
- Location heroPos;
- int timeLimit; // in days
- };
- };
- struct CspecificVictoryConidtions
- {
- bool allowNormalVictory;
- bool appliesToAI;
- };
- struct VicCon0 : public CspecificVictoryConidtions //acquire artifact
- {
- int ArtifactID;
- };
- struct VicCon1 : public CspecificVictoryConidtions //accumulate creatures
- {
- int monsterID;
- int neededQuantity;
- };
- struct VicCon2 : public CspecificVictoryConidtions // accumulate resources
- {
- int resourceID;
- int neededQuantity;
- };
- struct VicCon3 : public CspecificVictoryConidtions // upgrade specific town
- {
- Location posOfCity;
- int councilNeededLevel; //0 - town; 1 - city; 2 - capitol
- int fortNeededLevel;// 0 - fort; 1 - citadel; 2 - castle
- };
- struct VicCon4 : public CspecificVictoryConidtions // build grail structure
- {
- bool anyLocation;
- Location whereBuildGrail;
- };
- struct VicCon5 : public CspecificVictoryConidtions // defeat a specific hero
- {
- Location locationOfHero;
- };
- struct VicCon6 : public CspecificVictoryConidtions // capture a specific town
- {
- Location locationOfTown;
- };
- struct VicCon7 : public CspecificVictoryConidtions // defeat a specific monster
- {
- Location locationOfMonster;
- };
- /*struct VicCon8 : public CspecificVictoryConidtions // flag all creature dwellings
- {
- };
- struct VicCon9 : public CspecificVictoryConidtions // flag all mines
- {
- };*/
- struct VicCona : public CspecificVictoryConidtions //transport specific artifact
- {
- int artifactID;
- Location destinationPlace;
- };
- struct Rumor
- {
- std::string name, text;
- };
- class CMapEvent
- {
- public:
- std::string name, message;
- int wood, mercury, ore, sulfur, crystal, gems, gold; //gained / taken resources
- unsigned char players; //affected players
- bool humanAffected;
- bool computerAffected;
- int firstOccurence;
- int nextOccurence; //after nextOccurance day event will occure; if it it 0, event occures only one time;
- };
- struct Mapa
- {
- Eformat version; // version of map Eformat
- int twoLevel; // if map has underground level
- int difficulty; // 0 easy - 4 impossible
- int levelLimit;
- bool areAnyPLayers; // if there are any playable players on map
- std::string name; //name of map
- std::string description; //and description
- int height, width;
- TerrainTile** terrain;
- TerrainTile** undergroungTerrain; // used only if there is underground level
- std::vector<Rumor> rumors;
- std::vector<CGDefInfo *> defy; // list of .def files
- PlayerInfo players[8]; // info about players
- std::vector<int> teams; // teams[i] = team of player no i
- LossCondition lossCondition;
- EvictoryConditions victoryCondition; //victory conditions
- CspecificVictoryConidtions * vicConDetails; // used only if vistory conditions aren't standard
- int howManyTeams;
- std::vector<CMapEvent> events;
- };
- class CMapHeader
- {
- public:
- Eformat version; // version of map Eformat
- bool areAnyPLayers; // if there are any playable players on map
- int height, width;
- bool twoLevel; // if map has underground level
- std::string name; //name of map
- std::string description; //and description
- int difficulty; // 0 easy - 4 impossible
- int levelLimit;
- LossCondition lossCondition;
- EvictoryConditions victoryCondition; //victory conditions
- CspecificVictoryConidtions * vicConDetails; // used only if vistory conditions aren't standard
- PlayerInfo players[8]; // info about players
- std::vector<int> teams; // teams[i] = team of player no i
- int howManyTeams;
- CMapHeader(unsigned char *map); //an argument is a reference to string described a map (unpacked)
- };
- class CMapInfo : public CMapHeader
- {
- public:
- std::string filename;
- int playerAmnt, humenPlayers;
- CMapInfo(std::string fname, unsigned char *map):CMapHeader(map),filename(fname)
- {
- playerAmnt=humenPlayers=0;
- for (int i=0;i<PLAYER_LIMIT;i++)
- {
- if (players[i].canHumanPlay) {playerAmnt++;humenPlayers++;}
- else if (players[i].canComputerPlay) {playerAmnt++;}
- }
- };
- };
- class mapSorter
- {
- public:
- ESortBy sortBy;
- bool operator()(CMapHeader & a, CMapHeader& b)
- {
- switch (sortBy)
- {
- case ESortBy::format:
- return (a.version<b.version);
- break;
- case ESortBy::loscon:
- return (a.lossCondition.typeOfLossCon<b.lossCondition.typeOfLossCon);
- break;
- case ESortBy::playerAm:
- int playerAmntB,humenPlayersB,playerAmntA,humenPlayersA;
- playerAmntB=humenPlayersB=playerAmntA=humenPlayersA=0;
- for (int i=0;i<8;i++)
- {
- if (a.players[i].canHumanPlay) {playerAmntA++;humenPlayersA++;}
- else if (a.players[i].canComputerPlay) {playerAmntA++;}
- if (b.players[i].canHumanPlay) {playerAmntB++;humenPlayersB++;}
- else if (b.players[i].canComputerPlay) {playerAmntB++;}
- }
- if (playerAmntB!=playerAmntA)
- return (playerAmntA<playerAmntB);
- else
- return (humenPlayersA<humenPlayersB);
- break;
- case ESortBy::size:
- return (a.width<b.width);
- break;
- case ESortBy::viccon:
- return (a.victoryCondition<b.victoryCondition);
- break;
- case ESortBy::name:
- return (a.name<b.name);
- break;
- default:
- return (a.name<b.name);
- break;
- }
- };
- mapSorter(ESortBy es):sortBy(es){};
- };
- #endif //MAPD_H
|