CSpellHandler.h 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. #pragma once
  2. #include "../lib/ConstTransitivePtr.h"
  3. #include "int3.h"
  4. #include "GameConstants.h"
  5. #include "HeroBonus.h"
  6. /*
  7. * CSpellHandler.h, part of VCMI engine
  8. *
  9. * Authors: listed in file AUTHORS in main folder
  10. *
  11. * License: GNU General Public License v2.0 or later
  12. * Full text of license available in license.txt file, in main folder
  13. *
  14. */
  15. class CLegacyConfigParser;
  16. struct BattleHex;
  17. class DLL_LINKAGE CSpell
  18. {
  19. public:
  20. enum ETargetType {NO_TARGET, CREATURE, CREATURE_EXPERT_MASSIVE, OBSTACLE};
  21. enum ESpellPositiveness {NEGATIVE = -1, NEUTRAL = 0, POSITIVE = 1};
  22. SpellID id;
  23. std::string identifier;
  24. std::string name;
  25. std::string abbName; //abbreviated name
  26. std::vector<std::string> descriptions; //descriptions of spell for skill levels: 0 - none, 1 - basic, etc
  27. si32 level;
  28. bool earth;
  29. bool water;
  30. bool fire;
  31. bool air;
  32. si32 power; //spell's power
  33. std::vector<si32> costs; //per skill level: 0 - none, 1 - basic, etc
  34. std::vector<si32> powers; //[er skill level: 0 - none, 1 - basic, etc
  35. std::map<TFaction, si32> probabilities; //% chance to gain for castles
  36. std::vector<si32> AIVals; //AI values: per skill level: 0 - none, 1 - basic, etc
  37. std::string attributes; //reference only attributes
  38. bool combatSpell; //is this spell combat (true) or adventure (false)
  39. bool creatureAbility; //if true, only creatures can use this spell
  40. si8 positiveness; //1 if spell is positive for influenced stacks, 0 if it is indifferent, -1 if it's negative
  41. std::vector<std::string> range; //description of spell's range in SRSL by magic school level
  42. std::vector<SpellID> counteredSpells; //spells that are removed when effect of this spell is placed on creature (for bless-curse, haste-slow, and similar pairs)
  43. CSpell();
  44. std::vector<BattleHex> rangeInHexes(BattleHex centralHex, ui8 schoolLvl, ui8 side, bool *outDroppedHexes = NULL ) const; //convert range to specific hexes; last optional out parameter is set to true, if spell would cover unavailable hexes (that are not included in ret)
  45. si16 mainEffectAnim; //main spell effect animation, in AC format (or -1 when none)
  46. ETargetType getTargetType() const;
  47. inline bool isCombatSpell() const;
  48. inline bool isAdventureSpell() const;
  49. inline bool isCreatureAbility() const;
  50. inline bool isPositive() const;
  51. inline bool isNegative() const;
  52. inline bool isRisingSpell() const;
  53. inline bool isDamageSpell() const;
  54. inline bool isMindSpell() const; //TODO: deprecated - remove, refactor
  55. inline bool isOffensiveSpell() const;
  56. inline bool hasEffects() const;
  57. void getEffects(std::vector<Bonus> &lst, const int level) const;
  58. bool isImmuneBy(const IBonusBearer *obj) const;
  59. template <typename Handler> void serialize(Handler &h, const int version)
  60. {
  61. h & identifier & id & name & abbName & descriptions & level & earth & water & fire & air & power & costs
  62. & powers & probabilities & AIVals & attributes & combatSpell & creatureAbility & positiveness & range & counteredSpells & mainEffectAnim;
  63. h & isRising & isDamage & isMind;
  64. h & effects & immunities & limiters;
  65. }
  66. friend class CSpellHandler;
  67. private:
  68. bool isRising;
  69. bool isDamage;
  70. bool isMind;
  71. bool isOffensive;
  72. std::vector<Bonus> effects [4];
  73. std::vector<Bonus::BonusType> immunities; //any of these hrants immunity
  74. std::vector<Bonus::BonusType> limiters; //all of them are required
  75. };
  76. ///CSpell inlines
  77. bool CSpell::isCombatSpell() const
  78. {
  79. return combatSpell;
  80. }
  81. bool CSpell::isAdventureSpell() const
  82. {
  83. return !combatSpell;
  84. }
  85. bool CSpell::isCreatureAbility() const
  86. {
  87. return creatureAbility;
  88. }
  89. bool CSpell::isPositive() const
  90. {
  91. return positiveness == POSITIVE;
  92. }
  93. bool CSpell::isNegative() const
  94. {
  95. return positiveness == NEGATIVE;
  96. }
  97. bool CSpell::isRisingSpell() const
  98. {
  99. return isRising;
  100. }
  101. bool CSpell::isDamageSpell() const
  102. {
  103. return isDamage;
  104. }
  105. bool CSpell::isMindSpell() const
  106. {
  107. return isMind;
  108. }
  109. bool CSpell::isOffensiveSpell() const
  110. {
  111. return isOffensive;
  112. }
  113. bool CSpell::hasEffects() const
  114. {
  115. return !effects[0].empty();
  116. }
  117. bool DLL_LINKAGE isInScreenRange(const int3 &center, const int3 &pos); //for spells like Dimension Door
  118. class DLL_LINKAGE CSpellHandler
  119. {
  120. CSpell * loadSpell(CLegacyConfigParser & parser);
  121. public:
  122. CSpellHandler();
  123. std::vector< ConstTransitivePtr<CSpell> > spells;
  124. void loadSpells();
  125. /**
  126. * Gets a list of default allowed spells. OH3 spells are all allowed by default.
  127. *
  128. * @return a list of allowed spells, the index is the spell id and the value either 0 for not allowed or 1 for allowed
  129. */
  130. std::vector<bool> getDefaultAllowedSpells() const;
  131. template <typename Handler> void serialize(Handler &h, const int version)
  132. {
  133. h & spells ;
  134. }
  135. };