CRmgTemplateZone.h 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  1. /*
  2. * CRmgTemplateZone.h, part of VCMI engine
  3. *
  4. * Authors: listed in file AUTHORS in main folder
  5. *
  6. * License: GNU General Public License v2.0 or later
  7. * Full text of license available in license.txt file, in main folder
  8. *
  9. */
  10. #pragma once
  11. #include "../GameConstants.h"
  12. #include "CMapGenerator.h"
  13. #include "float3.h"
  14. #include "../int3.h"
  15. #include "../ResourceSet.h" //for TResource (?)
  16. #include "../mapObjects/ObjectTemplate.h"
  17. #include <boost/heap/priority_queue.hpp> //A*
  18. class CMapGenerator;
  19. class CTileInfo;
  20. class int3;
  21. class CGObjectInstance;
  22. class ObjectTemplate;
  23. class CRmgTemplateZoneConnection;
  24. namespace ETemplateZoneType
  25. {
  26. enum ETemplateZoneType
  27. {
  28. PLAYER_START,
  29. CPU_START,
  30. TREASURE,
  31. JUNCTION
  32. };
  33. }
  34. namespace EObjectPlacingResult
  35. {
  36. enum EObjectPlacingResult
  37. {
  38. SUCCESS,
  39. CANNOT_FIT,
  40. SEALED_OFF
  41. };
  42. }
  43. class DLL_LINKAGE CTileInfo
  44. {
  45. public:
  46. CTileInfo();
  47. float getNearestObjectDistance() const;
  48. void setNearestObjectDistance(float value);
  49. bool isBlocked() const;
  50. bool shouldBeBlocked() const;
  51. bool isPossible() const;
  52. bool isFree() const;
  53. bool isUsed() const;
  54. bool isRoad() const;
  55. void setOccupied(ETileType::ETileType value);
  56. ETerrainType getTerrainType() const;
  57. ETileType::ETileType getTileType() const;
  58. void setTerrainType(ETerrainType value);
  59. void setRoadType(ERoadType::ERoadType value);
  60. private:
  61. float nearestObjectDistance;
  62. ETileType::ETileType occupied;
  63. ETerrainType terrain;
  64. ERoadType::ERoadType roadType;
  65. };
  66. class DLL_LINKAGE CTreasureInfo
  67. {
  68. public:
  69. ui32 min;
  70. ui32 max;
  71. ui16 density;
  72. };
  73. struct DLL_LINKAGE ObjectInfo
  74. {
  75. ObjectTemplate templ;
  76. ui32 value;
  77. ui16 probability;
  78. ui32 maxPerZone;
  79. //ui32 maxPerMap; //unused
  80. std::function<CGObjectInstance *()> generateObject;
  81. void setTemplate (si32 type, si32 subtype, ETerrainType terrain);
  82. ObjectInfo();
  83. bool operator==(const ObjectInfo& oi) const { return (templ == oi.templ); }
  84. };
  85. struct DLL_LINKAGE CTreasurePileInfo
  86. {
  87. std::set<int3> visitableFromBottomPositions; //can be visited only from bottom or side
  88. std::set<int3> visitableFromTopPositions; //they can be visited from any direction
  89. std::set<int3> blockedPositions;
  90. std::set<int3> occupiedPositions; //blocked + visitable
  91. int3 nextTreasurePos;
  92. };
  93. /// The CRmgTemplateZone describes a zone in a template.
  94. class DLL_LINKAGE CRmgTemplateZone
  95. {
  96. public:
  97. class DLL_LINKAGE CTownInfo
  98. {
  99. public:
  100. CTownInfo();
  101. int getTownCount() const; /// Default: 0
  102. void setTownCount(int value);
  103. int getCastleCount() const; /// Default: 0
  104. void setCastleCount(int value);
  105. int getTownDensity() const; /// Default: 0
  106. void setTownDensity(int value);
  107. int getCastleDensity() const; /// Default: 0
  108. void setCastleDensity(int value);
  109. private:
  110. int townCount, castleCount, townDensity, castleDensity;
  111. };
  112. CRmgTemplateZone();
  113. TRmgTemplateZoneId getId() const; /// Default: 0
  114. void setId(TRmgTemplateZoneId value);
  115. ETemplateZoneType::ETemplateZoneType getType() const; /// Default: ETemplateZoneType::PLAYER_START
  116. void setType(ETemplateZoneType::ETemplateZoneType value);
  117. int getSize() const; /// Default: 1
  118. void setSize(int value);
  119. boost::optional<int> getOwner() const;
  120. void setOwner(boost::optional<int> value);
  121. const CTownInfo & getPlayerTowns() const;
  122. void setPlayerTowns(const CTownInfo & value);
  123. const CTownInfo & getNeutralTowns() const;
  124. void setNeutralTowns(const CTownInfo & value);
  125. bool getTownsAreSameType() const; /// Default: false
  126. void setTownsAreSameType(bool value);
  127. const std::set<TFaction> & getTownTypes() const; /// Default: all
  128. void setTownTypes(const std::set<TFaction> & value);
  129. void setMonsterTypes(const std::set<TFaction> & value);
  130. std::set<TFaction> getDefaultTownTypes() const;
  131. bool getMatchTerrainToTown() const; /// Default: true
  132. void setMatchTerrainToTown(bool value);
  133. const std::set<ETerrainType> & getTerrainTypes() const; /// Default: all
  134. void setTerrainTypes(const std::set<ETerrainType> & value);
  135. std::set<ETerrainType> getDefaultTerrainTypes() const;
  136. void setMinesAmount (TResource res, ui16 amount);
  137. std::map<TResource, ui16> getMinesInfo() const;
  138. void setMonsterStrength (EMonsterStrength::EMonsterStrength val);
  139. float3 getCenter() const;
  140. void setCenter(const float3 &f);
  141. int3 getPos() const;
  142. void setPos(const int3 &pos);
  143. bool isAccessibleFromAnywhere(CMapGenerator* gen, ObjectTemplate &appearance, int3 &tile) const;
  144. int3 getAccessibleOffset(CMapGenerator* gen, ObjectTemplate &appearance, int3 &tile) const;
  145. void addTile (const int3 &pos);
  146. void initFreeTiles (CMapGenerator* gen);
  147. std::set<int3> getTileInfo() const;
  148. std::set<int3> getPossibleTiles() const;
  149. void discardDistantTiles (CMapGenerator* gen, float distance);
  150. void clearTiles();
  151. void addRequiredObject(CGObjectInstance * obj, si32 guardStrength=0);
  152. void addCloseObject(CGObjectInstance * obj, si32 guardStrength = 0);
  153. void addToConnectLater(const int3& src);
  154. bool addMonster(CMapGenerator* gen, int3 &pos, si32 strength, bool clearSurroundingTiles = true, bool zoneGuard = false);
  155. bool createTreasurePile(CMapGenerator* gen, int3 &pos, float minDistance, const CTreasureInfo& treasureInfo);
  156. bool fill (CMapGenerator* gen);
  157. bool placeMines (CMapGenerator* gen);
  158. void initTownType (CMapGenerator* gen);
  159. void paintZoneTerrain (CMapGenerator* gen, ETerrainType terrainType);
  160. void randomizeTownType(CMapGenerator* gen); //helper function
  161. void initTerrainType (CMapGenerator* gen);
  162. void createBorder(CMapGenerator* gen);
  163. void fractalize(CMapGenerator* gen);
  164. void connectLater(CMapGenerator* gen);
  165. EObjectPlacingResult::EObjectPlacingResult tryToPlaceObjectAndConnectToPath(CMapGenerator* gen, CGObjectInstance *obj, int3 &pos); //return true if the position cna be connected
  166. bool createRequiredObjects(CMapGenerator* gen);
  167. void createTreasures(CMapGenerator* gen);
  168. void createObstacles1(CMapGenerator* gen);
  169. void createObstacles2(CMapGenerator* gen);
  170. bool crunchPath(CMapGenerator* gen, const int3 &src, const int3 &dst, bool onlyStraight, std::set<int3>* clearedTiles = nullptr);
  171. bool connectPath(CMapGenerator* gen, const int3& src, bool onlyStraight);
  172. bool connectWithCenter(CMapGenerator* gen, const int3& src, bool onlyStraight);
  173. void updateDistances(CMapGenerator* gen, const int3 & pos);
  174. std::vector<int3> getAccessibleOffsets (CMapGenerator* gen, const CGObjectInstance* object);
  175. bool areAllTilesAvailable(CMapGenerator* gen, CGObjectInstance* obj, int3& tile, std::set<int3>& tilesBlockedByObject) const;
  176. void addConnection(TRmgTemplateZoneId otherZone);
  177. void setQuestArtZone(CRmgTemplateZone * otherZone);
  178. std::vector<TRmgTemplateZoneId> getConnections() const;
  179. void addTreasureInfo(CTreasureInfo & info);
  180. std::vector<CTreasureInfo> getTreasureInfo();
  181. std::set<int3>* getFreePaths();
  182. ObjectInfo getRandomObject (CMapGenerator* gen, CTreasurePileInfo &info, ui32 desiredValue, ui32 maxValue, ui32 currentValue);
  183. void placeSubterraneanGate(CMapGenerator* gen, int3 pos, si32 guardStrength);
  184. void placeObject(CMapGenerator* gen, CGObjectInstance* object, const int3 &pos, bool updateDistance = true);
  185. bool guardObject(CMapGenerator* gen, CGObjectInstance* object, si32 str, bool zoneGuard = false, bool addToFreePaths = false);
  186. void placeAndGuardObject(CMapGenerator* gen, CGObjectInstance* object, const int3 &pos, si32 str, bool zoneGuard = false);
  187. void addRoadNode(const int3 & node);
  188. void connectRoads(CMapGenerator * gen); //fills "roads" according to "roadNodes"
  189. //A* priority queue
  190. typedef std::pair<int3, float> TDistance;
  191. struct NodeComparer
  192. {
  193. bool operator()(const TDistance & lhs, const TDistance & rhs) const
  194. {
  195. return (rhs.second < lhs.second);
  196. }
  197. };
  198. boost::heap::priority_queue<TDistance, boost::heap::compare<NodeComparer>> createPiorityQueue();
  199. private:
  200. //template info
  201. TRmgTemplateZoneId id;
  202. ETemplateZoneType::ETemplateZoneType type;
  203. int size;
  204. boost::optional<int> owner;
  205. CTownInfo playerTowns, neutralTowns;
  206. bool townsAreSameType;
  207. std::set<TFaction> townTypes;
  208. std::set<TFaction> monsterTypes;
  209. bool matchTerrainToTown;
  210. std::set<ETerrainType> terrainTypes;
  211. std::map<TResource, ui16> mines; //obligatory mines to spawn in this zone
  212. si32 townType;
  213. ETerrainType terrainType;
  214. CRmgTemplateZone * questArtZone; //artifacts required for Seer Huts will be placed here - or not if null
  215. EMonsterStrength::EMonsterStrength zoneMonsterStrength;
  216. std::vector<CTreasureInfo> treasureInfo;
  217. std::vector<ObjectInfo> possibleObjects;
  218. int minGuardedValue;
  219. //content info
  220. std::vector<std::pair<CGObjectInstance*, ui32>> requiredObjects;
  221. std::vector<std::pair<CGObjectInstance*, ui32>> closeObjects;
  222. std::vector<CGObjectInstance*> objects;
  223. //placement info
  224. int3 pos;
  225. float3 center;
  226. std::set<int3> tileinfo; //irregular area assined to zone
  227. std::set<int3> possibleTiles; //optimization purposes for treasure generation
  228. std::vector<TRmgTemplateZoneId> connections; //list of adjacent zones
  229. std::set<int3> freePaths; //core paths of free tiles that all other objects will be linked to
  230. std::set<int3> roadNodes; //tiles to be connected with roads
  231. std::set<int3> roads; //all tiles with roads
  232. std::set<int3> tilesToConnectLater; //will be connected after paths are fractalized
  233. bool createRoad(CMapGenerator* gen, const int3 &src, const int3 &dst);
  234. void drawRoads(CMapGenerator * gen); //actually updates tiles
  235. bool pointIsIn(int x, int y);
  236. void addAllPossibleObjects (CMapGenerator* gen); //add objects, including zone-specific, to possibleObjects
  237. bool findPlaceForObject(CMapGenerator* gen, CGObjectInstance* obj, si32 min_dist, int3 &pos);
  238. bool findPlaceForTreasurePile(CMapGenerator* gen, float min_dist, int3 &pos, int value);
  239. bool canObstacleBePlacedHere(CMapGenerator* gen, ObjectTemplate &temp, int3 &pos);
  240. void setTemplateForObject(CMapGenerator* gen, CGObjectInstance* obj);
  241. void checkAndPlaceObject(CMapGenerator* gen, CGObjectInstance* object, const int3 &pos);
  242. };