mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-16 19:19:56 +00:00
Merge pull request #1308 from akortunov/spellpriority
Spell priority: dispel usage improvements
This commit is contained in:
commit
172cc65be9
1 changed files with 49 additions and 10 deletions
|
@ -61,7 +61,7 @@ float suggestCombatRange(int rangeTypes)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int numEffectsToCure (const MWWorld::Ptr& actor, int effectFilter=-1)
|
int numEffectsToDispel (const MWWorld::Ptr& actor, int effectFilter=-1, bool negative = true)
|
||||||
{
|
{
|
||||||
int toCure=0;
|
int toCure=0;
|
||||||
const MWMechanics::ActiveSpells& activeSpells = actor.getClass().getCreatureStats(actor).getActiveSpells();
|
const MWMechanics::ActiveSpells& activeSpells = actor.getClass().getCreatureStats(actor).getActiveSpells();
|
||||||
|
@ -75,9 +75,14 @@ int numEffectsToCure (const MWWorld::Ptr& actor, int effectFilter=-1)
|
||||||
if (effectFilter != -1 && effectId != effectFilter)
|
if (effectFilter != -1 && effectId != effectFilter)
|
||||||
continue;
|
continue;
|
||||||
const ESM::MagicEffect* magicEffect = MWBase::Environment::get().getWorld()->getStore().get<ESM::MagicEffect>().find(effectId);
|
const ESM::MagicEffect* magicEffect = MWBase::Environment::get().getWorld()->getStore().get<ESM::MagicEffect>().find(effectId);
|
||||||
if (magicEffect->mData.mFlags & ESM::MagicEffect::Harmful
|
|
||||||
&& effectIt->mDuration > 3 // Don't attempt to cure if effect runs out shortly anyway
|
if (effectIt->mDuration <= 3) // Don't attempt to dispel if effect runs out shortly anyway
|
||||||
)
|
continue;
|
||||||
|
|
||||||
|
if (negative && magicEffect->mData.mFlags & ESM::MagicEffect::Harmful)
|
||||||
|
++toCure;
|
||||||
|
|
||||||
|
if (!negative && !(magicEffect->mData.mFlags & ESM::MagicEffect::Harmful))
|
||||||
++toCure;
|
++toCure;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -400,14 +405,47 @@ namespace MWMechanics
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
// Prefer Cure effects over Dispel, because Dispel also removes positive effects
|
|
||||||
case ESM::MagicEffect::Dispel:
|
case ESM::MagicEffect::Dispel:
|
||||||
return 1000.f * numEffectsToCure(actor);
|
{
|
||||||
case ESM::MagicEffect::CureParalyzation:
|
int numPositive = 0;
|
||||||
return 1001.f * numEffectsToCure(actor, ESM::MagicEffect::Paralyze);
|
int numNegative = 0;
|
||||||
case ESM::MagicEffect::CurePoison:
|
int diff = 0;
|
||||||
return 1001.f * numEffectsToCure(actor, ESM::MagicEffect::Poison);
|
|
||||||
|
|
||||||
|
if (effect.mRange == ESM::RT_Self)
|
||||||
|
{
|
||||||
|
numPositive = numEffectsToDispel(actor, -1, false);
|
||||||
|
numNegative = numEffectsToDispel(actor);
|
||||||
|
|
||||||
|
diff = numNegative - numPositive;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (enemy.isEmpty())
|
||||||
|
return 0.f;
|
||||||
|
|
||||||
|
numPositive = numEffectsToDispel(enemy, -1, false);
|
||||||
|
numNegative = numEffectsToDispel(enemy);
|
||||||
|
|
||||||
|
diff = numPositive - numNegative;
|
||||||
|
|
||||||
|
// if rating < 0 here, the spell will be considered as negative later
|
||||||
|
rating *= -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (diff <= 0)
|
||||||
|
return 0.f;
|
||||||
|
|
||||||
|
rating *= (diff) / 5.f;
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Prefer Cure effects over Dispel, because Dispel also removes positive effects
|
||||||
|
case ESM::MagicEffect::CureParalyzation:
|
||||||
|
return 1001.f * numEffectsToDispel(actor, ESM::MagicEffect::Paralyze);
|
||||||
|
|
||||||
|
case ESM::MagicEffect::CurePoison:
|
||||||
|
return 1001.f * numEffectsToDispel(actor, ESM::MagicEffect::Poison);
|
||||||
case ESM::MagicEffect::DisintegrateArmor:
|
case ESM::MagicEffect::DisintegrateArmor:
|
||||||
{
|
{
|
||||||
if (enemy.isEmpty())
|
if (enemy.isEmpty())
|
||||||
|
@ -555,6 +593,7 @@ namespace MWMechanics
|
||||||
// Combat AI is egoistic, so doesn't consider applying positive effects to friendly actors.
|
// Combat AI is egoistic, so doesn't consider applying positive effects to friendly actors.
|
||||||
if (effect.mRange != ESM::RT_Self)
|
if (effect.mRange != ESM::RT_Self)
|
||||||
rating *= -1.f;
|
rating *= -1.f;
|
||||||
|
|
||||||
return rating;
|
return rating;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue