TerrainHandler.cpp 4.6 KB

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