Added check to deactivate existing entity effects when new entity effects are added.
This commit is contained in:
parent
0854ed01a4
commit
92ac45d27e
@ -197,6 +197,13 @@ void cPawn::AddEntityEffect(cEntityEffect::eType a_EffectType, int a_Duration, s
|
|||||||
}
|
}
|
||||||
a_Duration = static_cast<int>(a_Duration * a_DistanceModifier);
|
a_Duration = static_cast<int>(a_Duration * a_DistanceModifier);
|
||||||
|
|
||||||
|
// If we already have the effect, we have to deactivate it or else it will act cumulatively
|
||||||
|
auto ExistingEffect = m_EntityEffects.find(a_EffectType);
|
||||||
|
if (ExistingEffect != m_EntityEffects.end())
|
||||||
|
{
|
||||||
|
ExistingEffect->second->OnDeactivate(*this);
|
||||||
|
}
|
||||||
|
|
||||||
auto Res = m_EntityEffects.emplace(a_EffectType, cEntityEffect::CreateEntityEffect(a_EffectType, a_Duration, a_Intensity, a_DistanceModifier));
|
auto Res = m_EntityEffects.emplace(a_EffectType, cEntityEffect::CreateEntityEffect(a_EffectType, a_Duration, a_Intensity, a_DistanceModifier));
|
||||||
m_World->BroadcastEntityEffect(*this, a_EffectType, a_Intensity, static_cast<short>(a_Duration));
|
m_World->BroadcastEntityEffect(*this, a_EffectType, a_Intensity, static_cast<short>(a_Duration));
|
||||||
cEntityEffect * Effect = Res.first->second.get();
|
cEntityEffect * Effect = Res.first->second.get();
|
||||||
|
Loading…
Reference in New Issue
Block a user