aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorRushor <PBienati@web.de>2015-03-22 00:56:05 +0100
committerRushor <PBienati@web.de>2015-03-22 00:56:05 +0100
commit5098aba84036406e8c67cccd70e62a049184d1f6 (patch)
treeef4875e742e3a91d29b9c320a7d8d87f2aadf138 /src
parentccdc100d10143285bc058d968f0472ea4d073120 (diff)
Scripts/HellfireRamparts: Vazruden the Herald - Improve Reset-/ Aggrobehaviour
by @CDawg
Diffstat (limited to 'src')
-rw-r--r--src/server/scripts/Outland/HellfireCitadel/HellfireRamparts/boss_vazruden_the_herald.cpp34
1 files changed, 30 insertions, 4 deletions
diff --git a/src/server/scripts/Outland/HellfireCitadel/HellfireRamparts/boss_vazruden_the_herald.cpp b/src/server/scripts/Outland/HellfireCitadel/HellfireRamparts/boss_vazruden_the_herald.cpp
index a6c00c05dce..9da979d1105 100644
--- a/src/server/scripts/Outland/HellfireCitadel/HellfireRamparts/boss_vazruden_the_herald.cpp
+++ b/src/server/scripts/Outland/HellfireCitadel/HellfireRamparts/boss_vazruden_the_herald.cpp
@@ -426,11 +426,37 @@ class boss_vazruden_the_herald : public CreatureScript
if ((Nazan && Nazan->IsAlive()) || (Vazruden && Vazruden->IsAlive()))
{
if ((Nazan && Nazan->GetVictim()) || (Vazruden && Vazruden->GetVictim()))
- return;
- else
{
- UnsummonAdds();
- EnterEvadeMode();
+ if (Nazan->IsInCombat())
+ return;
+ else
+ {
+ const Position Nazan_FlyAggro = { -1380.425f, 1721.026f, 90.40f, 2.426f };
+ if (Nazan)
+ Nazan->GetMotionMaster()->MoveTakeoff(0, Nazan_FlyAggro);
+ }
+ }
+ else
+ { //reset, if by chance the party wipes (1st boss)
+ if (Vazruden && Vazruden->IsAlive())
+ {
+ if (phase != 1)
+ phase = 1;
+ }
+ else
+ {
+ if (phase != 2) //reset just Nazan, Vazruden is dead
+ phase = 2;
+ }
+
+ me->GetMotionMaster()->Clear(); // reset and move back into pos...
+ me->GetMotionMaster()->MovePoint(0, VazrudenMiddle[0], VazrudenMiddle[1], VazrudenMiddle[2]);
+
+ if (phase > 2)
+ {
+ EnterEvadeMode();
+ Reset();
+ }
return;
}
}