aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNaddley <64811442+Naddley@users.noreply.github.com>2024-02-24 06:01:49 +0100
committerGitHub <noreply@github.com>2024-02-24 06:01:49 +0100
commit345a08970d7014dbd761c815fbd10ecc88d2dc29 (patch)
tree10d044e6a36cb56609162fcf8574f13273e58730 /src
parent8b1dde2e9fbe969d3c28232f614ec0600b45e297 (diff)
Scripts/ForbiddenReach: Added spawn handling for dracthyr intro personal summons (#29682)
Co-Authored-By: ModoX <moardox@gmail.com>
Diffstat (limited to 'src')
-rw-r--r--src/server/scripts/DragonIsles/zone_the_forbidden_reach.cpp129
1 files changed, 111 insertions, 18 deletions
diff --git a/src/server/scripts/DragonIsles/zone_the_forbidden_reach.cpp b/src/server/scripts/DragonIsles/zone_the_forbidden_reach.cpp
index 4e9057b6c28..4c756e8afa9 100644
--- a/src/server/scripts/DragonIsles/zone_the_forbidden_reach.cpp
+++ b/src/server/scripts/DragonIsles/zone_the_forbidden_reach.cpp
@@ -15,6 +15,8 @@
* with this program. If not, see <http://www.gnu.org/licenses/>.
*/
+#include "AreaTrigger.h"
+#include "AreaTriggerAI.h"
#include "ScriptMgr.h"
#include "Containers.h"
#include "Player.h"
@@ -25,29 +27,58 @@
enum DracthyrLoginSpells
{
// Spells
- SPELL_DRACTHYR_LOGIN = 369728, // teleports to random room, plays scene for the room, binds the home position
- SPELL_STASIS_1 = 369735, // triggers 366620
- SPELL_STASIS_2 = 366620, // triggers 366636
- SPELL_STASIS_3 = 366636, // removes 365560, sends first quest (64864)
- SPELL_STASIS_4 = 365560, // freeze the target
- SPELL_DRACTHYR_MOVIE_ROOM_01 = 394245, // scene for room 1
- SPELL_DRACTHYR_MOVIE_ROOM_02 = 394279, // scene for room 2
- SPELL_DRACTHYR_MOVIE_ROOM_03 = 394281, // scene for room 3
- SPELL_DRACTHYR_MOVIE_ROOM_04 = 394282, // scene for room 4
- //SPELL_DRACTHYR_MOVIE_ROOM_05 = 394283, // scene for room 5 (only plays sound, unused?)
+ SPELL_DRACTHYR_LOGIN = 369728, // teleports to random room, plays scene for the room, binds the home position
+ SPELL_STASIS_1 = 369735, // triggers 366620
+ SPELL_STASIS_2 = 366620, // triggers 366636
+ SPELL_STASIS_3 = 366636, // removes 365560, sends first quest (64864)
+ SPELL_STASIS_4 = 365560, // freeze the target
+ SPELL_DRACTHYR_MOVIE_ROOM_01 = 394245, // scene for room 1
+ SPELL_DRACTHYR_MOVIE_ROOM_02 = 394279, // scene for room 2
+ SPELL_DRACTHYR_MOVIE_ROOM_03 = 394281, // scene for room 3
+ SPELL_DRACTHYR_MOVIE_ROOM_04 = 394282, // scene for room 4
+ //SPELL_DRACTHYR_MOVIE_ROOM_05 = 394283, // scene for room 5 (only plays sound, unused?)
+ SPELL_MAINTAIN_DERVISHIAN = 369731, // Alliance Personal Summon
+ SPELL_MAINTAIN_KODETHI = 370112, // Horde Personal Summon
+ SPELL_AWAKEN_DRACTYHR_QUEST_ABANDON = 369744,
+ SPELL_STASIS_FEEDBACK_KNOCKBACK = 364074,
+ SPELL_STASIS_FEEDBACK_VISUAL = 374633
};
-std::array<std::pair<uint32, Position>, 4> LoginRoomData =
+struct DracthyrLoginRoom
+{
+ uint32 MovieSpellId;
+ Position PlayerPosition;
+ Position SummonPosition;
+};
+
+std::array<DracthyrLoginRoom, 4> LoginRoomData =
{
{
- { SPELL_DRACTHYR_MOVIE_ROOM_01, { 5725.32f, -3024.26f, 251.047f, 0.01745329238474369f } },
- { SPELL_DRACTHYR_MOVIE_ROOM_02, { 5743.03f, -3067.28f, 251.047f, 0.798488140106201171f } },
- { SPELL_DRACTHYR_MOVIE_ROOM_03, { 5787.1597f, -3083.3906f, 251.04698f, 1.570796370506286621f } },
- { SPELL_DRACTHYR_MOVIE_ROOM_04, { 5829.32f, -3064.49f, 251.047f, 2.364955902099609375f } }
+ {
+ SPELL_DRACTHYR_MOVIE_ROOM_01,
+ { 5725.32f, -3024.26f, 251.047f, 0.01745329238474369f },
+ { 5739.97216796875f, -3023.970458984375f, 251.172332763671875f, 3.193952560424804687f }
+ },
+ {
+ SPELL_DRACTHYR_MOVIE_ROOM_02,
+ { 5743.03f, -3067.28f, 251.047f, 0.798488140106201171f },
+ { 5754.3046875f, -3056.34716796875f, 251.1725006103515625f, 3.926990747451782226f }
+ },
+ {
+ SPELL_DRACTHYR_MOVIE_ROOM_03,
+ { 5787.1597f, -3083.3906f, 251.04698f, 1.570796370506286621f },
+ { 5787.44970703125f, -3069.335205078125f, 251.168121337890625f, 4.729842185974121093f }
+ },
+ {
+ SPELL_DRACTHYR_MOVIE_ROOM_04,
+ { 5829.32f, -3064.49f, 251.047f, 2.364955902099609375f },
+ { 5818.533203125f, -3054.5625f, 251.3630828857421875f, 5.480333805084228515f }
+ }
}
};
// 369728 - Dracthyr Login
+// 369744 - Awaken, Dracthyr OnquestAbandon
class spell_dracthyr_login : public SpellScript
{
bool Validate(SpellInfo const* /*spellInfo*/) override
@@ -57,14 +88,14 @@ class spell_dracthyr_login : public SpellScript
void HandleTeleport(SpellEffIndex /*effIndex*/)
{
- std::pair<uint32, Position> const& room = LoginRoomData[urand(0, 3)];
+ DracthyrLoginRoom const& room = LoginRoomData[urand(0, 3)];
WorldLocation dest = GetHitUnit()->GetWorldLocation();
SetExplTargetDest(dest);
- GetHitDest()->Relocate(room.second);
+ GetHitDest()->Relocate(room.PlayerPosition);
- GetCaster()->CastSpell(GetHitUnit(), room.first, true);
+ GetCaster()->CastSpell(GetHitUnit(), room.MovieSpellId, true);
}
void Register() override
@@ -90,8 +121,70 @@ public:
}
};
+// 369730 - Summon Dervishian
+// 370111 - Summon Kodethi
+class spell_dracthyr_summon_dervishian : public SpellScript
+{
+ void SetDest(SpellDestination& dest)
+ {
+ float currentDist = 1000.0f;
+ DracthyrLoginRoom const* currentRoom = nullptr;
+
+ for (DracthyrLoginRoom const& room : LoginRoomData)
+ {
+ float dist = GetCaster()->GetDistance(room.PlayerPosition);
+ if (dist < currentDist)
+ {
+ currentDist = dist;
+ currentRoom = &room;
+ }
+ }
+ if (!currentRoom)
+ return;
+
+ dest.Relocate(currentRoom->SummonPosition);
+ }
+
+ void Register() override
+ {
+ OnDestinationTargetSelect += SpellDestinationTargetSelectFn(spell_dracthyr_summon_dervishian::SetDest, EFFECT_0, TARGET_DEST_NEARBY_ENTRY);
+ }
+};
+
+// 64864 - Awaken, Dracthyr
+class quest_awaken_dracthyr : public QuestScript
+{
+public:
+ quest_awaken_dracthyr() : QuestScript("quest_awaken_dracthyr") { }
+
+ void OnQuestStatusChange(Player* player, Quest const* /*quest*/, QuestStatus /*oldStatus*/, QuestStatus newStatus) override
+ {
+ if (newStatus == QUEST_STATUS_NONE)
+ player->CastSpell(player, SPELL_AWAKEN_DRACTYHR_QUEST_ABANDON, false);
+ }
+};
+
+// 30308 - Stasis Feedback
+struct at_dracthyr_stasis_feedback : AreaTriggerAI
+{
+ at_dracthyr_stasis_feedback(AreaTrigger* areatrigger) : AreaTriggerAI(areatrigger) { }
+
+ void OnUnitEnter(Unit* unit) override
+ {
+ if (!unit->IsPlayer())
+ return;
+
+ unit->CastSpell(nullptr, SPELL_STASIS_FEEDBACK_KNOCKBACK, false);
+ if (Unit* caster = at->GetCaster())
+ caster->CastSpell(caster->GetPosition(), SPELL_STASIS_FEEDBACK_VISUAL, true);
+ }
+};
+
void AddSC_zone_the_forbidden_reach()
{
RegisterSpellScript(spell_dracthyr_login);
new scene_dracthyr_evoker_intro();
+ RegisterSpellScript(spell_dracthyr_summon_dervishian);
+ new quest_awaken_dracthyr();
+ RegisterAreaTriggerAI(at_dracthyr_stasis_feedback);
}