aboutsummaryrefslogtreecommitdiff
path: root/src/server/scripts
diff options
context:
space:
mode:
authorOvahlord <dreadkiller@gmx.de>2025-01-11 20:36:09 +0100
committerOvahlord <dreadkiller@gmx.de>2025-01-11 20:36:09 +0100
commitc1d8e30015805fc017fbebd69f2f0fb465444f0c (patch)
tree921e7db01ae19f1f8f61f3a80e565857d0abd998 /src/server/scripts
parent7f29956937b807c371ee3f3057d96f7601b4bc19 (diff)
Scripts/Spells: fixed Howling Blast damage calculation
Diffstat (limited to 'src/server/scripts')
-rw-r--r--src/server/scripts/Spells/spell_dk.cpp18
1 files changed, 18 insertions, 0 deletions
diff --git a/src/server/scripts/Spells/spell_dk.cpp b/src/server/scripts/Spells/spell_dk.cpp
index 1c5848675d0..871ef2b2935 100644
--- a/src/server/scripts/Spells/spell_dk.cpp
+++ b/src/server/scripts/Spells/spell_dk.cpp
@@ -281,6 +281,23 @@ class spell_dk_blood_plague: public AuraScript
DoEffectCalcDamageAndHealing += AuraEffectCalcDamageFn(spell_dk_blood_plague::CalculateDamage, EFFECT_0, SPELL_AURA_PERIODIC_DAMAGE);
}
};
+
+// 49184 - Howling Blast
+class spell_dk_howling_blast : public SpellScript
+{
+ // According to tooltip: (($m2+$M2)/2)+($AP*0.44) and (0.5*((($m2+$M2)/2)+($AP*0.44))) for non-primary targets
+ void CalculateDamage(SpellEffectInfo const& /*effectInfo*/, Unit* victim, int32& damage, int32& /*flatMod*/, float& /*pctMod*/)
+ {
+ damage += GetCaster()->GetTotalAttackPowerValue(BASE_ATTACK) * 0.4f;
+ if (victim != GetExplTargetUnit())
+ damage *= 0.5f;
+ }
+
+ void Register() override
+ {
+ CalcDamage += SpellCalcDamageFn(spell_dk_howling_blast::CalculateDamage);
+ }
+};
}
void AddSC_deathknight_spell_scripts()
@@ -291,6 +308,7 @@ void AddSC_deathknight_spell_scripts()
RegisterSpellScript(spell_dk_dark_simulacrum_buff);
RegisterSpellScript(spell_dk_death_coil);
RegisterSpellScript(spell_dk_frost_fever);
+ RegisterSpellScript(spell_dk_howling_blast);
RegisterSpellScript(spell_dk_icy_touch);
RegisterSpellScript(spell_dk_runic_empowerment);
}