From 1832f1759de8b1fac56292580ad821940405b14c Mon Sep 17 00:00:00 2001 From: Andrei Kortunov Date: Sun, 28 Apr 2019 16:41:10 +0400 Subject: [PATCH] AI: use a consistent check if a target is hidden (bug #4920) --- CHANGELOG.md | 1 + apps/openmw/mwmechanics/aicombataction.cpp | 7 ++----- apps/openmw/mwmechanics/aipackage.cpp | 7 ------- apps/openmw/mwmechanics/aipackage.hpp | 2 -- apps/openmw/mwmechanics/aipursue.cpp | 1 + apps/openmw/mwmechanics/combat.cpp | 7 +++++++ apps/openmw/mwmechanics/combat.hpp | 2 ++ 7 files changed, 13 insertions(+), 14 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index e301ddefa0..a3cc8178fa 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -60,6 +60,7 @@ Bug #4911: Editor: QOpenGLContext::swapBuffers() warning with Qt5 Bug #4916: Specular power (shininess) material parameter is ignored when shaders are used. Bug #4918: Abilities don't play looping VFX when they're initially applied + Bug #4920: Combat AI uses incorrect invisibility check Bug #4922: Werewolves can not attack if the transformation happens during attack Bug #4927: Spell effect having both a skill and an attribute assigned is a fatal error Bug #4932: Invalid records matching when loading save with edited plugin diff --git a/apps/openmw/mwmechanics/aicombataction.cpp b/apps/openmw/mwmechanics/aicombataction.cpp index 804e0dd059..96ff0c308f 100644 --- a/apps/openmw/mwmechanics/aicombataction.cpp +++ b/apps/openmw/mwmechanics/aicombataction.cpp @@ -403,12 +403,9 @@ namespace MWMechanics ESM::Position actorPos = actor.getRefData().getPosition(); ESM::Position enemyPos = enemy.getRefData().getPosition(); - const CreatureStats& enemyStats = enemy.getClass().getCreatureStats(enemy); - if (enemyStats.getMagicEffects().get(ESM::MagicEffect::Invisibility).getMagnitude() > 0 - || enemyStats.getMagicEffects().get(ESM::MagicEffect::Chameleon).getMagnitude() > 0) + if (isTargetMagicallyHidden(enemy) && !MWBase::Environment::get().getMechanicsManager()->awarenessCheck(enemy, actor)) { - if (!MWBase::Environment::get().getMechanicsManager()->awarenessCheck(enemy, actor)) - return false; + return false; } if (actor.getClass().isPureWaterCreature(actor)) diff --git a/apps/openmw/mwmechanics/aipackage.cpp b/apps/openmw/mwmechanics/aipackage.cpp index c9a3717499..1113300907 100644 --- a/apps/openmw/mwmechanics/aipackage.cpp +++ b/apps/openmw/mwmechanics/aipackage.cpp @@ -335,13 +335,6 @@ bool MWMechanics::AiPackage::doesPathNeedRecalc(const osg::Vec3f& newDest, const || mPathFinder.getPathCell() != currentCell; } -bool MWMechanics::AiPackage::isTargetMagicallyHidden(const MWWorld::Ptr& target) -{ - const MagicEffects& magicEffects(target.getClass().getCreatureStats(target).getMagicEffects()); - return (magicEffects.get(ESM::MagicEffect::Invisibility).getMagnitude() > 0) - || (magicEffects.get(ESM::MagicEffect::Chameleon).getMagnitude() > 75); -} - bool MWMechanics::AiPackage::isNearInactiveCell(osg::Vec3f position) { const ESM::Cell* playerCell(getPlayer().getCell()->getCell()); diff --git a/apps/openmw/mwmechanics/aipackage.hpp b/apps/openmw/mwmechanics/aipackage.hpp index d7287cd2fc..9ccbfed59f 100644 --- a/apps/openmw/mwmechanics/aipackage.hpp +++ b/apps/openmw/mwmechanics/aipackage.hpp @@ -102,8 +102,6 @@ namespace MWMechanics /// Reset pathfinding state void reset(); - bool isTargetMagicallyHidden(const MWWorld::Ptr& target); - /// Return if actor's rotation speed is sufficient to rotate to the destination pathpoint on the run. Otherwise actor should rotate while standing. static bool isReachableRotatingOnTheRun(const MWWorld::Ptr& actor, const osg::Vec3f& dest); diff --git a/apps/openmw/mwmechanics/aipursue.cpp b/apps/openmw/mwmechanics/aipursue.cpp index 925f3adaa1..d6824f2b19 100644 --- a/apps/openmw/mwmechanics/aipursue.cpp +++ b/apps/openmw/mwmechanics/aipursue.cpp @@ -10,6 +10,7 @@ #include "movement.hpp" #include "creaturestats.hpp" +#include "combat.hpp" namespace MWMechanics { diff --git a/apps/openmw/mwmechanics/combat.cpp b/apps/openmw/mwmechanics/combat.cpp index 3f87363a32..3fbb625e4d 100644 --- a/apps/openmw/mwmechanics/combat.cpp +++ b/apps/openmw/mwmechanics/combat.cpp @@ -485,4 +485,11 @@ namespace MWMechanics return (iFightDistanceBase - fFightDistanceMultiplier * d); } + + bool isTargetMagicallyHidden(const MWWorld::Ptr& target) + { + const MagicEffects& magicEffects = target.getClass().getCreatureStats(target).getMagicEffects(); + return (magicEffects.get(ESM::MagicEffect::Invisibility).getMagnitude() > 0) + || (magicEffects.get(ESM::MagicEffect::Chameleon).getMagnitude() > 75); + } } diff --git a/apps/openmw/mwmechanics/combat.hpp b/apps/openmw/mwmechanics/combat.hpp index 6be7832196..fd2717b191 100644 --- a/apps/openmw/mwmechanics/combat.hpp +++ b/apps/openmw/mwmechanics/combat.hpp @@ -53,6 +53,8 @@ void getHandToHandDamage (const MWWorld::Ptr& attacker, const MWWorld::Ptr& vict void applyFatigueLoss(const MWWorld::Ptr& attacker, const MWWorld::Ptr& weapon, float attackStrength); float getFightDistanceBias(const MWWorld::Ptr& actor1, const MWWorld::Ptr& actor2); + +bool isTargetMagicallyHidden(const MWWorld::Ptr& target); } #endif