2014-01-21 00:01:21 +00:00
|
|
|
#ifndef OPENMW_MECHANICS_COMBAT_H
|
|
|
|
#define OPENMW_MECHANICS_COMBAT_H
|
|
|
|
|
|
|
|
#include "../mwworld/ptr.hpp"
|
2014-03-08 04:51:47 +00:00
|
|
|
#include <OgreVector3.h>
|
2014-01-21 00:01:21 +00:00
|
|
|
|
|
|
|
namespace MWMechanics
|
|
|
|
{
|
|
|
|
|
|
|
|
/// @return can we block the attack?
|
|
|
|
bool blockMeleeAttack (const MWWorld::Ptr& attacker, const MWWorld::Ptr& blocker, const MWWorld::Ptr& weapon, float damage);
|
|
|
|
|
2014-01-22 11:09:44 +00:00
|
|
|
void resistNormalWeapon (const MWWorld::Ptr& actor, const MWWorld::Ptr& attacker, const MWWorld::Ptr& weapon, float& damage);
|
|
|
|
|
2014-03-08 04:51:47 +00:00
|
|
|
/// @note for a thrown weapon, \a weapon == \a projectile, for bows/crossbows, \a projectile is the arrow/bolt
|
2014-08-02 21:14:17 +00:00
|
|
|
/// @note \a victim may be empty (e.g. for a hit on terrain), a non-actor (environment objects) or an actor
|
2014-03-08 04:51:47 +00:00
|
|
|
void projectileHit (const MWWorld::Ptr& attacker, const MWWorld::Ptr& victim, MWWorld::Ptr weapon, const MWWorld::Ptr& projectile,
|
|
|
|
const Ogre::Vector3& hitPosition);
|
|
|
|
|
|
|
|
/// Get the chance (in percent) for \a attacker to successfully hit \a victim with a given weapon skill value
|
|
|
|
float getHitChance (const MWWorld::Ptr& attacker, const MWWorld::Ptr& victim, int skillValue);
|
|
|
|
|
2014-07-15 19:53:11 +00:00
|
|
|
/// Applies damage to attacker based on the victim's elemental shields.
|
|
|
|
void applyElementalShields(const MWWorld::Ptr& attacker, const MWWorld::Ptr& victim);
|
|
|
|
|
2014-08-02 21:14:17 +00:00
|
|
|
/// @param damage Unmitigated weapon damage of the attack
|
|
|
|
/// @param hit Was the attack successful?
|
|
|
|
/// @param weapon The weapon used.
|
|
|
|
/// @note if the weapon is unequipped as result of condition damage, a new Ptr will be assigned to \a weapon.
|
|
|
|
void reduceWeaponCondition (float damage, bool hit, MWWorld::Ptr& weapon, const MWWorld::Ptr& attacker);
|
|
|
|
|
|
|
|
/// Adjust weapon damage based on its condition. A used weapon will be less effective.
|
2015-03-12 02:08:58 +00:00
|
|
|
void adjustWeaponDamage (float& damage, const MWWorld::Ptr& weapon, const MWWorld::Ptr& attacker);
|
2014-08-02 21:14:17 +00:00
|
|
|
|
2014-12-31 22:13:36 +00:00
|
|
|
void getHandToHandDamage (const MWWorld::Ptr& attacker, const MWWorld::Ptr& victim, float& damage, bool& healthdmg);
|
|
|
|
|
2015-01-31 21:28:23 +00:00
|
|
|
/// Apply the fatigue loss incurred by attacking with the given weapon (weapon may be empty = hand-to-hand)
|
|
|
|
void applyFatigueLoss(const MWWorld::Ptr& attacker, const MWWorld::Ptr& weapon);
|
|
|
|
|
2015-01-11 01:25:46 +00:00
|
|
|
/// Can attacker operate in victim's environment?
|
|
|
|
/// e.g. If attacker is a fish, is victim in water? Or, if attacker can't swim, is victim on land?
|
|
|
|
bool isEnvironmentCompatible(const MWWorld::Ptr& attacker, const MWWorld::Ptr& victim);
|
|
|
|
|
2014-01-21 00:01:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|