2012-05-29 15:13:44 +02:00
|
|
|
#ifndef MWMECHANICS_SPELLSUCCESS_H
|
|
|
|
#define MWMECHANICS_SPELLSUCCESS_H
|
|
|
|
|
2012-07-03 12:30:50 +02:00
|
|
|
#include "../mwworld/ptr.hpp"
|
2012-05-29 15:13:44 +02:00
|
|
|
|
2014-02-23 20:11:05 +01:00
|
|
|
#include <components/esm/loadskil.hpp>
|
|
|
|
|
|
|
|
namespace ESM
|
|
|
|
{
|
|
|
|
struct Spell;
|
|
|
|
struct Ingredient;
|
|
|
|
struct Potion;
|
|
|
|
struct EffectList;
|
|
|
|
}
|
|
|
|
|
2012-05-29 15:13:44 +02:00
|
|
|
namespace MWMechanics
|
|
|
|
{
|
2015-03-06 21:36:42 +13:00
|
|
|
struct EffectKey;
|
2014-06-17 22:24:56 +02:00
|
|
|
class MagicEffects;
|
2015-07-18 20:39:45 +02:00
|
|
|
class CreatureStats;
|
2014-01-18 10:52:16 +01:00
|
|
|
|
|
|
|
ESM::Skill::SkillEnum spellSchoolToSkill(int school);
|
2012-05-29 18:33:01 +02:00
|
|
|
|
2015-01-22 04:12:08 +01:00
|
|
|
bool isSummoningEffect(int effectId);
|
|
|
|
|
2012-05-29 18:33:01 +02:00
|
|
|
/**
|
2012-10-23 11:42:38 +02:00
|
|
|
* @param spell spell to cast
|
2012-05-29 18:33:01 +02:00
|
|
|
* @param actor calculate spell success chance for this actor (depends on actor's skills)
|
2013-11-14 19:19:32 +01:00
|
|
|
* @param effectiveSchool the spell's effective school (relevant for skill progress) will be written here
|
2014-07-31 01:14:44 +02:00
|
|
|
* @param cap cap the result to 100%?
|
|
|
|
* @note actor can be an NPC or a creature
|
|
|
|
* @return success chance from 0 to 100 (in percent), if cap=false then chance above 100 may be returned.
|
2012-05-29 18:33:01 +02:00
|
|
|
*/
|
2014-07-31 01:14:44 +02:00
|
|
|
float getSpellSuccessChance (const ESM::Spell* spell, const MWWorld::Ptr& actor, int* effectiveSchool = NULL, bool cap=true);
|
|
|
|
float getSpellSuccessChance (const std::string& spellId, const MWWorld::Ptr& actor, int* effectiveSchool = NULL, bool cap=true);
|
2013-11-14 19:19:32 +01:00
|
|
|
|
2014-01-18 10:52:16 +01:00
|
|
|
int getSpellSchool(const std::string& spellId, const MWWorld::Ptr& actor);
|
|
|
|
int getSpellSchool(const ESM::Spell* spell, const MWWorld::Ptr& actor);
|
2013-11-14 19:19:32 +01:00
|
|
|
|
2014-08-24 20:36:31 +02:00
|
|
|
/// Get whether or not the given spell contributes to skill progress.
|
|
|
|
bool spellIncreasesSkill(const ESM::Spell* spell);
|
|
|
|
bool spellIncreasesSkill(const std::string& spellId);
|
|
|
|
|
2014-07-15 22:06:46 +02:00
|
|
|
/// Get the resistance attribute against an effect for a given actor. This will add together
|
|
|
|
/// ResistX and Weakness to X effects relevant against the given effect.
|
|
|
|
float getEffectResistanceAttribute (short effectId, const MagicEffects* actorEffects);
|
|
|
|
|
|
|
|
/// Get the effective resistance against an effect casted by the given actor in the given spell (optional).
|
2013-11-16 02:34:43 +01:00
|
|
|
/// @return >=100 for fully resisted. can also return negative value for damage amplification.
|
2014-06-17 22:24:56 +02:00
|
|
|
/// @param effects Override the actor's current magicEffects. Useful if there are effects currently
|
|
|
|
/// being applied (but not applied yet) that should also be considered.
|
|
|
|
float getEffectResistance (short effectId, const MWWorld::Ptr& actor, const MWWorld::Ptr& caster,
|
|
|
|
const ESM::Spell* spell = NULL, const MagicEffects* effects = NULL);
|
2013-11-16 02:34:43 +01:00
|
|
|
|
2014-10-06 21:56:41 -05:00
|
|
|
/// Get an effect multiplier for applying an effect cast by the given actor in the given spell (optional).
|
|
|
|
/// @return effect multiplier from 0 to 2. (100% net resistance to 100% net weakness)
|
|
|
|
/// @param effects Override the actor's current magicEffects. Useful if there are effects currently
|
|
|
|
/// being applied (but not applied yet) that should also be considered.
|
2014-06-17 22:24:56 +02:00
|
|
|
float getEffectMultiplier(short effectId, const MWWorld::Ptr& actor, const MWWorld::Ptr& caster,
|
|
|
|
const ESM::Spell* spell = NULL, const MagicEffects* effects = NULL);
|
2013-11-17 23:15:57 +01:00
|
|
|
|
2015-01-07 04:28:56 +01:00
|
|
|
int getEffectiveEnchantmentCastCost (float castCost, const MWWorld::Ptr& actor);
|
|
|
|
|
2015-07-18 20:39:45 +02:00
|
|
|
void effectTick(CreatureStats& creatureStats, const MWWorld::Ptr& actor, const MWMechanics::EffectKey& effectKey, float magnitude);
|
|
|
|
|
2013-11-17 23:15:57 +01:00
|
|
|
class CastSpell
|
|
|
|
{
|
|
|
|
private:
|
2014-06-18 01:41:07 +02:00
|
|
|
MWWorld::Ptr mCaster; // May be empty
|
|
|
|
MWWorld::Ptr mTarget; // May be empty
|
2013-11-28 17:31:17 +01:00
|
|
|
public:
|
2013-11-17 23:15:57 +01:00
|
|
|
bool mStack;
|
|
|
|
std::string mId; // ID of spell, potion, item etc
|
|
|
|
std::string mSourceName; // Display name for spell, potion, etc
|
2015-06-01 21:41:13 +02:00
|
|
|
osg::Vec3f mHitPosition; // Used for spawning area orb
|
2014-10-09 01:39:35 +02:00
|
|
|
bool mAlwaysSucceed; // Always succeed spells casted by NPCs/creatures regardless of their chance (default: false)
|
2013-11-17 23:15:57 +01:00
|
|
|
|
|
|
|
public:
|
|
|
|
CastSpell(const MWWorld::Ptr& caster, const MWWorld::Ptr& target);
|
|
|
|
|
|
|
|
bool cast (const ESM::Spell* spell);
|
2014-06-18 01:41:07 +02:00
|
|
|
|
|
|
|
/// @note mCaster must be an actor
|
2013-11-17 23:15:57 +01:00
|
|
|
bool cast (const MWWorld::Ptr& item);
|
2014-06-18 01:41:07 +02:00
|
|
|
|
|
|
|
/// @note mCaster must be an NPC
|
2013-11-17 23:15:57 +01:00
|
|
|
bool cast (const ESM::Ingredient* ingredient);
|
2014-06-18 01:41:07 +02:00
|
|
|
|
2013-11-17 23:15:57 +01:00
|
|
|
bool cast (const ESM::Potion* potion);
|
|
|
|
|
|
|
|
/// @note Auto detects if spell, ingredient or potion
|
|
|
|
bool cast (const std::string& id);
|
|
|
|
|
2014-05-14 05:33:18 +02:00
|
|
|
/// @note \a target can be any type of object, not just actors.
|
2014-05-15 02:37:20 +02:00
|
|
|
/// @note \a caster can be any type of object, or even an empty object.
|
2013-11-17 23:15:57 +01:00
|
|
|
void inflict (const MWWorld::Ptr& target, const MWWorld::Ptr& caster,
|
2014-01-20 15:48:06 +01:00
|
|
|
const ESM::EffectList& effects, ESM::RangeType range, bool reflected=false, bool exploded=false);
|
2013-11-17 23:15:57 +01:00
|
|
|
|
2014-05-15 02:37:20 +02:00
|
|
|
/// @note \a caster can be any type of object, or even an empty object.
|
2015-08-04 17:55:38 +02:00
|
|
|
/// @return was the target suitable for the effect?
|
|
|
|
bool applyInstantEffect (const MWWorld::Ptr& target, const MWWorld::Ptr& caster, const MWMechanics::EffectKey& effect, float magnitude);
|
2013-11-17 23:15:57 +01:00
|
|
|
};
|
|
|
|
|
2012-05-29 15:13:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|