mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 15:56:37 +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