mirror of
https://github.com/mod-playerbots/azerothcore-wotlk.git
synced 2025-11-29 17:38:24 +08:00
fix(DN/SAI): Move Beryl Sorcerer behaviour into SmartAI. (#23839)
This commit is contained in:
22
data/sql/updates/pending_db_world/Beryl_sorcerer.sql
Normal file
22
data/sql/updates/pending_db_world/Beryl_sorcerer.sql
Normal file
@@ -0,0 +1,22 @@
|
||||
|
||||
-- Clean Script Name & add SmartAI (Beryl Sorcerer, Captured Beryl Sorcerer)
|
||||
UPDATE `creature_template` SET `AIName` = 'SmartAI', `ScriptName` = '' WHERE (`entry` IN (25316, 25474));
|
||||
|
||||
DELETE FROM `smart_scripts` WHERE (`source_type` = 0) AND (`entryorguid` IN (25316, 25474));
|
||||
INSERT INTO `smart_scripts` (`entryorguid`, `source_type`, `id`, `link`, `event_type`, `event_phase_mask`, `event_chance`, `event_flags`, `event_param1`, `event_param2`, `event_param3`, `event_param4`, `event_param5`, `event_param6`, `action_type`, `action_param1`, `action_param2`, `action_param3`, `action_param4`, `action_param5`, `action_param6`, `target_type`, `target_param1`, `target_param2`, `target_param3`, `target_param4`, `target_x`, `target_y`, `target_z`, `target_o`, `comment`) VALUES
|
||||
(25316, 0, 0, 0, 8, 0, 100, 0, 45611, 0, 0, 0, 0, 0, 80, 2531600, 2, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 'Beryl Sorcerer - On Spellhit \'Arcane Chains\' - Run Script'),
|
||||
(25316, 0, 1, 0, 0, 0, 100, 0, 3000, 4000, 4000, 8000, 0, 0, 11, 9672, 64, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 'Beryl Sorcerer - In Combat - Cast \'Frostbolt\''),
|
||||
(25316, 0, 2, 0, 2, 0, 100, 0, 35, 50, 8000, 12000, 0, 0, 11, 50648, 64, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 'Beryl Sorcerer - Between 35-50% Health - Cast \'Blink\''),
|
||||
(25474, 0, 0, 0, 54, 0, 100, 0, 0, 0, 0, 0, 0, 0, 80, 2547400, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 'Captured Beryl Sorcerer - On Just Summoned - Run Script'),
|
||||
(25474, 0, 1, 0, 65, 0, 100, 0, 0, 0, 0, 0, 0, 0, 41, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 'Captured Beryl Sorcerer - On Follow Complete - Despawn Instant');
|
||||
|
||||
-- Set Action Lists (Beryl Sorcerer, Captured Beryl Sorcerer)
|
||||
DELETE FROM `smart_scripts` WHERE (`source_type` = 9) AND (`entryorguid` IN (2531600, 2547400));
|
||||
INSERT INTO `smart_scripts` (`entryorguid`, `source_type`, `id`, `link`, `event_type`, `event_phase_mask`, `event_chance`, `event_flags`, `event_param1`, `event_param2`, `event_param3`, `event_param4`, `event_param5`, `event_param6`, `action_type`, `action_param1`, `action_param2`, `action_param3`, `action_param4`, `action_param5`, `action_param6`, `target_type`, `target_param1`, `target_param2`, `target_param3`, `target_param4`, `target_x`, `target_y`, `target_z`, `target_o`, `comment`) VALUES
|
||||
(2531600, 9, 0, 0, 0, 0, 100, 0, 3000, 3000, 0, 0, 0, 0, 11, 45625, 0, 524023, 0, 0, 0, 7, 0, 0, 0, 0, 0, 0, 0, 0, 'Beryl Sorcerer - Actionlist - Cast \'Arcane Chains: Character Force Cast\''),
|
||||
(2531600, 9, 1, 0, 0, 0, 100, 0, 0, 0, 0, 0, 0, 0, 33, 25474, 0, 0, 0, 0, 0, 7, 0, 0, 0, 0, 0, 0, 0, 0, 'Beryl Sorcerer - Actionlist - Quest Credit \'null\''),
|
||||
(2531600, 9, 2, 0, 0, 0, 100, 0, 0, 0, 0, 0, 0, 0, 41, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 'Beryl Sorcerer - Actionlist - Despawn Instant'),
|
||||
(2547400, 9, 0, 0, 0, 0, 100, 0, 0, 0, 0, 0, 0, 0, 18, 10, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 'Captured Beryl Sorcerer - Actionlist - Set Flags Not Attackable & Player Controlled'),
|
||||
(2547400, 9, 1, 0, 0, 0, 100, 0, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 'Captured Beryl Sorcerer - Actionlist - Set Reactstate Passive'),
|
||||
(2547400, 9, 2, 0, 0, 0, 100, 0, 200, 200, 0, 0, 0, 0, 11, 45632, 0, 0, 0, 0, 0, 23, 0, 0, 0, 0, 0, 0, 0, 0, 'Captured Beryl Sorcerer - Actionlist - Cast \'Enslaved Arcane Chains: Character Force Cast\''),
|
||||
(2547400, 9, 3, 0, 0, 0, 100, 0, 0, 0, 0, 0, 0, 0, 29, 2, 180, 25262, 0, 0, 0, 23, 0, 0, 0, 0, 0, 0, 0, 0, 'Captured Beryl Sorcerer - Actionlist - Start Follow Owner Or Summoner');
|
||||
@@ -562,201 +562,13 @@ private:
|
||||
Position _fezzix;
|
||||
};
|
||||
|
||||
/*######
|
||||
## Quest 11590: Abduction
|
||||
######*/
|
||||
|
||||
// NPC 25316: Beryl Sorcerer
|
||||
enum BerylSorcerer
|
||||
{
|
||||
EVENT_FROSTBOLT = 1,
|
||||
EVENT_ARCANE_CHAINS = 2,
|
||||
NPC_LIBRARIAN_DONATHAN = 25262,
|
||||
NPC_CAPTURED_BERLY_SORCERER = 25474,
|
||||
SPELL_FROSTBOLT = 9672,
|
||||
SPELL_ARCANE_CHAINS = 45611,
|
||||
SPELL_ARCANE_CHAINS_CHARACTER_FORCE_CAST = 45625,
|
||||
SPELL_ARCANE_CHAINS_SUMMON_CHAINED_MAGE_HUNTER = 45626,
|
||||
SPELL_COSMETIC_ENSLAVE_CHAINS_SELF = 45631,
|
||||
SPELL_ARCANE_CHAINS_CHANNEL_II = 45735
|
||||
};
|
||||
|
||||
class npc_beryl_sorcerer : public CreatureScript
|
||||
{
|
||||
public:
|
||||
npc_beryl_sorcerer() : CreatureScript("npc_beryl_sorcerer") { }
|
||||
|
||||
struct npc_beryl_sorcererAI : public CreatureAI
|
||||
{
|
||||
npc_beryl_sorcererAI(Creature* creature) : CreatureAI(creature)
|
||||
{
|
||||
Initialize();
|
||||
}
|
||||
|
||||
void Initialize()
|
||||
{
|
||||
_playerGUID.Clear();
|
||||
_chainsCast = false;
|
||||
}
|
||||
|
||||
void Reset() override
|
||||
{
|
||||
me->SetReactState(REACT_AGGRESSIVE);
|
||||
Initialize();
|
||||
}
|
||||
|
||||
void JustEngagedWith(Unit* who) override
|
||||
{
|
||||
if (me->IsValidAttackTarget(who))
|
||||
{
|
||||
AttackStart(who);
|
||||
}
|
||||
|
||||
_events.ScheduleEvent(EVENT_FROSTBOLT, 3s, 4s);
|
||||
}
|
||||
|
||||
void SpellHit(Unit* unit, SpellInfo const* spell) override
|
||||
{
|
||||
if (spell->Id == SPELL_ARCANE_CHAINS && !_chainsCast)
|
||||
{
|
||||
if (Player* player = unit->ToPlayer())
|
||||
{
|
||||
_playerGUID = player->GetGUID();
|
||||
_chainsCast = true;
|
||||
_events.ScheduleEvent(EVENT_ARCANE_CHAINS, 4s);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void UpdateAI(uint32 diff) override
|
||||
{
|
||||
if (!UpdateVictim())
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
_events.Update(diff);
|
||||
|
||||
if (uint32 eventId = _events.ExecuteEvent())
|
||||
{
|
||||
switch (eventId)
|
||||
{
|
||||
case EVENT_FROSTBOLT:
|
||||
DoCastVictim(SPELL_FROSTBOLT);
|
||||
_events.ScheduleEvent(EVENT_FROSTBOLT, 3s, 4s);
|
||||
break;
|
||||
case EVENT_ARCANE_CHAINS:
|
||||
if (me->HasAura(SPELL_ARCANE_CHAINS))
|
||||
{
|
||||
if (Player* player = ObjectAccessor::GetPlayer(*me, _playerGUID))
|
||||
{
|
||||
me->CastSpell(player, SPELL_ARCANE_CHAINS_CHARACTER_FORCE_CAST, TriggerCastFlags(TRIGGERED_FULL_MASK & ~TRIGGERED_IGNORE_AURA_INTERRUPT_FLAGS & ~TRIGGERED_IGNORE_CAST_ITEM));
|
||||
player->KilledMonsterCredit(NPC_CAPTURED_BERLY_SORCERER);
|
||||
me->DisappearAndDie();
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
DoMeleeAttackIfReady();
|
||||
}
|
||||
|
||||
private:
|
||||
EventMap _events;
|
||||
ObjectGuid _playerGUID;
|
||||
bool _chainsCast;
|
||||
};
|
||||
|
||||
CreatureAI* GetAI(Creature* creature) const override
|
||||
{
|
||||
return new npc_beryl_sorcererAI(creature);
|
||||
}
|
||||
};
|
||||
|
||||
// NPC 25474: Captured Beryl Sorcerer
|
||||
enum CapturedBerylSorcerer
|
||||
{
|
||||
EVENT_ADD_ARCANE_CHAINS = 1,
|
||||
EVENT_FOLLOW_PLAYER = 2
|
||||
};
|
||||
|
||||
class npc_captured_beryl_sorcerer : public CreatureScript
|
||||
{
|
||||
public:
|
||||
npc_captured_beryl_sorcerer() : CreatureScript("npc_captured_beryl_sorcerer") {}
|
||||
|
||||
struct npc_captured_beryl_sorcererAI : public FollowerAI
|
||||
{
|
||||
npc_captured_beryl_sorcererAI(Creature* creature) : FollowerAI(creature)
|
||||
{
|
||||
Initialize();
|
||||
}
|
||||
|
||||
void Initialize()
|
||||
{
|
||||
me->SetReactState(REACT_PASSIVE);
|
||||
me->SetUnitFlag(UNIT_FLAG_NON_ATTACKABLE);
|
||||
_events.ScheduleEvent(EVENT_ADD_ARCANE_CHAINS, 0ms);
|
||||
}
|
||||
|
||||
void Reset() override
|
||||
{
|
||||
Initialize();
|
||||
}
|
||||
|
||||
void UpdateAI(uint32 diff) override
|
||||
{
|
||||
_events.Update(diff);
|
||||
|
||||
if (uint32 eventId = _events.ExecuteEvent())
|
||||
{
|
||||
switch (eventId)
|
||||
{
|
||||
case EVENT_ADD_ARCANE_CHAINS:
|
||||
if (TempSummon* tempSummon = me->ToTempSummon())
|
||||
{
|
||||
if (Unit* summoner = tempSummon->GetSummonerUnit())
|
||||
{
|
||||
summoner->CastSpell(summoner, SPELL_ARCANE_CHAINS_CHANNEL_II, TriggerCastFlags(TRIGGERED_FULL_MASK & ~TRIGGERED_IGNORE_AURA_INTERRUPT_FLAGS & ~TRIGGERED_IGNORE_CAST_ITEM & ~TRIGGERED_IGNORE_POWER_AND_REAGENT_COST & ~TRIGGERED_IGNORE_GCD));
|
||||
_events.ScheduleEvent(EVENT_FOLLOW_PLAYER, 1s);
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
||||
case EVENT_FOLLOW_PLAYER:
|
||||
if (TempSummon* tempSummon = me->ToTempSummon())
|
||||
{
|
||||
if (Player* summoner = tempSummon->GetSummonerUnit()->ToPlayer())
|
||||
{
|
||||
StartFollow(summoner);
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void MoveInLineOfSight(Unit* who) override
|
||||
{
|
||||
FollowerAI::MoveInLineOfSight(who);
|
||||
|
||||
if (who->GetEntry() == NPC_LIBRARIAN_DONATHAN && me->IsWithinDistInMap(who, INTERACTION_DISTANCE))
|
||||
{
|
||||
SetFollowComplete();
|
||||
me->DespawnOrUnsummon();
|
||||
}
|
||||
}
|
||||
private:
|
||||
EventMap _events;
|
||||
};
|
||||
|
||||
CreatureAI* GetAI(Creature* creature) const override
|
||||
{
|
||||
return new npc_captured_beryl_sorcererAI(creature);
|
||||
}
|
||||
};
|
||||
|
||||
// Spell 45625: - Arcane Chains: Character Force Cast
|
||||
enum ArcaneChains
|
||||
{
|
||||
SPELL_ARCANE_CHAINS_CHARACTER_FORCE_CAST = 45625,
|
||||
SPELL_ARCANE_CHAINS_SUMMON_CHAINED_MAGE_HUNTER = 45626
|
||||
};
|
||||
|
||||
class spell_arcane_chains_character_force_cast : public SpellScript
|
||||
{
|
||||
PrepareSpellScript(spell_arcane_chains_character_force_cast);
|
||||
@@ -783,6 +595,7 @@ class spell_arcane_chains_character_force_cast : public SpellScript
|
||||
enum ImprisionedBerylSorcerer
|
||||
{
|
||||
SPELL_NEURAL_NEEDLE = 45634,
|
||||
SPELL_COSMETIC_ENSLAVE_CHAINS_SELF = 45631,
|
||||
|
||||
NPC_IMPRISONED_BERYL_SORCERER = 25478,
|
||||
|
||||
@@ -2222,8 +2035,6 @@ void AddSC_borean_tundra()
|
||||
new npc_iruk();
|
||||
new npc_nerubar_victim();
|
||||
new npc_lurgglbr();
|
||||
new npc_beryl_sorcerer();
|
||||
new npc_captured_beryl_sorcerer();
|
||||
RegisterSpellScript(spell_arcane_chains_character_force_cast);
|
||||
new npc_imprisoned_beryl_sorcerer();
|
||||
new npc_mootoo_the_younger();
|
||||
|
||||
Reference in New Issue
Block a user