#ifndef GAME_MWMECHANICS_NPCSTATS_H #define GAME_MWMECHANICS_NPCSTATS_H #include #include #include #include #include "stat.hpp" #include "drawstate.hpp" namespace ESM { struct Class; } namespace MWMechanics { /// \brief Additional stats for NPCs /// /// For non-NPC-specific stats, see the CreatureStats struct. /// /// \note For technical reasons the spell list and the currently selected spell is also handled by /// CreatureStats, even though they are actually NPC stats. class NpcStats { public: enum Flag { Flag_ForceRun = 1, Flag_ForceSneak = 2, Flag_Run = 4, Flag_Sneak = 8 }; private: /// NPCs other than the player can only have one faction. But for the sake of consistency /// we use the same data structure for the PC and the NPCs. /// \note the faction key must be in lowercase std::map mFactionRank; DrawState_ mDrawState; unsigned int mMovementFlags; Stat mSkill[27]; int mLevelProgress; // 0-10 std::vector mSkillIncreases; // number of skill increases for each attribute std::set mUsedIds; public: NpcStats(); DrawState_ getDrawState() const; void setDrawState (DrawState_ state); bool getMovementFlag (Flag flag) const; void setMovementFlag (Flag flag, bool state); const Stat& getSkill (int index) const; Stat& getSkill (int index); std::map& getFactionRanks(); const std::map& getFactionRanks() const; float getSkillGain (int skillIndex, const ESM::Class& class_, int usageType = -1, int level = -1) const; ///< \param usageType: Usage specific factor, specified in the respective skill record; /// -1: use a factor of 1.0 instead. /// \param level Level to base calculation on; -1: use current level. void useSkill (int skillIndex, const ESM::Class& class_, int usageType = -1); ///< Increase skill by usage. void increaseSkill (int skillIndex, const ESM::Class& class_, bool preserveProgress); int getLevelProgress() const; int getLevelupAttributeMultiplier(int attribute) const; void levelUp(); void flagAsUsed (const std::string& id); bool hasBeenUsed (const std::string& id) const; }; } #endif