TerrainHandler.cpp 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. /*
  2. * Terrain.cpp, 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. #include "StdInc.h"
  11. #include "TerrainHandler.h"
  12. #include "CModHandler.h"
  13. #include "CGeneralTextHandler.h"
  14. VCMI_LIB_NAMESPACE_BEGIN
  15. TerrainType * TerrainTypeHandler::loadFromJson( const std::string & scope, const JsonNode & json, const std::string & identifier, size_t index)
  16. {
  17. assert(identifier.find(':') == std::string::npos);
  18. TerrainType * info = new TerrainType;
  19. info->id = TerrainId(index);
  20. if (identifier.find(':') == std::string::npos)
  21. info->identifier = scope + ":" + identifier;
  22. else
  23. info->identifier = identifier;
  24. info->moveCost = static_cast<int>(json["moveCost"].Integer());
  25. info->musicFilename = json["music"].String();
  26. info->tilesFilename = json["tiles"].String();
  27. info->horseSound = json["horseSound"].String();
  28. info->horseSoundPenalty = json["horseSoundPenalty"].String();
  29. info->transitionRequired = json["transitionRequired"].Bool();
  30. info->terrainViewPatterns = json["terrainViewPatterns"].String();
  31. VLC->generaltexth->registerString(info->getNameTextID(), json["text"].String());
  32. const JsonVector & unblockedVec = json["minimapUnblocked"].Vector();
  33. info->minimapUnblocked =
  34. {
  35. ui8(unblockedVec[0].Float()),
  36. ui8(unblockedVec[1].Float()),
  37. ui8(unblockedVec[2].Float())
  38. };
  39. const JsonVector &blockedVec = json["minimapBlocked"].Vector();
  40. info->minimapBlocked =
  41. {
  42. ui8(blockedVec[0].Float()),
  43. ui8(blockedVec[1].Float()),
  44. ui8(blockedVec[2].Float())
  45. };
  46. info->passabilityType = 0;
  47. for(const auto& node : json["type"].Vector())
  48. {
  49. //Set bits
  50. auto s = node.String();
  51. if (s == "LAND") info->passabilityType |= TerrainType::PassabilityType::LAND;
  52. if (s == "WATER") info->passabilityType |= TerrainType::PassabilityType::WATER;
  53. if (s == "ROCK") info->passabilityType |= TerrainType::PassabilityType::ROCK;
  54. if (s == "SURFACE") info->passabilityType |= TerrainType::PassabilityType::SURFACE;
  55. if (s == "SUB") info->passabilityType |= TerrainType::PassabilityType::SUBTERRANEAN;
  56. }
  57. info->river = River::NO_RIVER;
  58. if(!json["river"].isNull())
  59. {
  60. VLC->modh->identifiers.requestIdentifier("river", json["river"], [info](int32_t identifier)
  61. {
  62. info->river = RiverId(identifier);
  63. });
  64. }
  65. info->shortIdentifier = json["shortIdentifier"].String();
  66. assert(info->shortIdentifier.length() == 2);
  67. for(auto & t : json["battleFields"].Vector())
  68. {
  69. VLC->modh->identifiers.requestIdentifier("battlefield", t, [info](int32_t identifier)
  70. {
  71. info->battleFields.emplace_back(identifier);
  72. });
  73. }
  74. for(auto & t : json["prohibitTransitions"].Vector())
  75. {
  76. VLC->modh->identifiers.requestIdentifier("terrain", t, [info](int32_t identifier)
  77. {
  78. info->prohibitTransitions.emplace_back(identifier);
  79. });
  80. }
  81. info->rockTerrain = ETerrainId::ROCK;
  82. if(!json["rockTerrain"].isNull())
  83. {
  84. VLC->modh->identifiers.requestIdentifier("terrain", json["rockTerrain"], [info](int32_t identifier)
  85. {
  86. info->rockTerrain = TerrainId(identifier);
  87. });
  88. }
  89. return info;
  90. }
  91. const std::vector<std::string> & TerrainTypeHandler::getTypeNames() const
  92. {
  93. static const std::vector<std::string> typeNames = { "terrain" };
  94. return typeNames;
  95. }
  96. std::vector<JsonNode> TerrainTypeHandler::loadLegacyData(size_t dataSize)
  97. {
  98. objects.resize(dataSize);
  99. CLegacyConfigParser terrainParser("DATA/TERRNAME.TXT");
  100. std::vector<JsonNode> result;
  101. do
  102. {
  103. JsonNode terrain;
  104. terrain["text"].String() = terrainParser.readString();
  105. result.push_back(terrain);
  106. }
  107. while (terrainParser.endLine());
  108. return result;
  109. }
  110. std::vector<bool> TerrainTypeHandler::getDefaultAllowed() const
  111. {
  112. return {};
  113. }
  114. bool TerrainType::isLand() const
  115. {
  116. return !isWater();
  117. }
  118. bool TerrainType::isWater() const
  119. {
  120. return passabilityType & PassabilityType::WATER;
  121. }
  122. bool TerrainType::isPassable() const
  123. {
  124. return !(passabilityType & PassabilityType::ROCK);
  125. }
  126. bool TerrainType::isSurface() const
  127. {
  128. return passabilityType & PassabilityType::SURFACE;
  129. }
  130. bool TerrainType::isUnderground() const
  131. {
  132. return passabilityType & PassabilityType::SUBTERRANEAN;
  133. }
  134. bool TerrainType::isSurfaceCartographerCompatible() const
  135. {
  136. return isSurface();
  137. }
  138. bool TerrainType::isUndergroundCartographerCompatible() const
  139. {
  140. return isLand() && isPassable() && !isSurface();
  141. }
  142. bool TerrainType::isTransitionRequired() const
  143. {
  144. return transitionRequired;
  145. }
  146. std::string TerrainType::getNameTextID() const
  147. {
  148. return TextIdentifier( "terrain", identifier, "name" ).get();
  149. }
  150. std::string TerrainType::getNameTranslated() const
  151. {
  152. return VLC->generaltexth->translate(getNameTextID());
  153. }
  154. TerrainType::TerrainType()
  155. {}
  156. VCMI_LIB_NAMESPACE_END