*Support for quest 4245 - by guenex

--HG--
branch : trunk
This commit is contained in:
Blaymoira
2009-01-09 19:55:26 +01:00
parent 9b8c50bb3b
commit c2ee7cb4d3
8 changed files with 238 additions and 1 deletions

View File

@@ -0,0 +1,13 @@
DELETE FROM `script_texts` WHERE `entry` BETWEEN -1000205 AND -1000200;
INSERT INTO script_texts
(`entry`, `content_default`, `content_loc1`, `content_loc2`, `content_loc3`, `content_loc4`, `content_loc5`, `content_loc6`, `content_loc7`, `content_loc8`, `sound`, `type`, `language`, `emote`, `comment`)
VALUES
(-1000200, 'A-Me good.Good A-me.Follow...A-ME follow.Home.A-ME go home.', NULL, NULL, 'A-ME gut.Gut A-Me.Folgen...Heim.A-ME geht heim.', NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, NULL),
(-1000201, 'Bad Un´Goro Stomper.Stomper evil.', NULL, NULL, 'Böser Stampfer von Un´Goro. Stampfer von Un´Goro böse.', NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, NULL),
(-1000202, 'Good..good,A-ME. Home. Search way.', NULL, NULL, 'Gut...gut.A-ME.A-ME gut.Heim.Heim suchen.', NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, NULL),
(-1000203, 'A-Me home.A-ME go home!Tar Lord dont disturb A-ME.', NULL, NULL, 'A-ME daheim.A-ME geht heim!Teerfürst A-ME nicht aufhalten.', NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, NULL),
(-1000204, 'Tar Lord A-ME no hurt.A-ME good.', NULL, NULL, 'Teerfürst A-ME nicht wehtun.A-ME gut.', NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, NULL),
(-1000205, 'A-ME at home!A-ME good!Good A-ME.At home.Home.Home', NULL, NULL, 'A-ME daheim!A-ME gut!Gute A-ME.Daheim.Daheim.Daheim', NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, NULL);
UPDATE `quest_template` SET `QuestFlags` = 2, `SpecialFlags` = 2 WHERE `entry` = 4245;
UPDATE `creature_template` SET `ScriptName` = 'npc_ame' WHERE `entry` = 9623;

View File

@@ -381,6 +381,7 @@ scripts/zone/uldaman/instance_uldaman.cpp \
scripts/zone/uldaman/boss_ironaya.cpp \
scripts/zone/uldaman/uldaman.cpp \
scripts/zone/undercity/undercity.cpp \
scripts/zone/ungoro_crater/ungoro_crater.cpp \
scripts/zone/wailing_caverns/instance_wailing_caverns.cpp \
scripts/zone/western_plaguelands/western_plaguelands.cpp \
scripts/zone/westfall/westfall.cpp \

View File

@@ -563,6 +563,8 @@ extern void AddSC_instance_uldaman();
extern void AddSC_undercity();
//Un'Goro Crater
extern void AddSC_ungoro_crater();
//Upper blackrock spire
//Wailing caverns
@@ -1770,6 +1772,8 @@ void ScriptsInit()
AddSC_undercity();
//Un'Goro Crater
AddSC_ungoro_crater();
//Upper blackrock spire
//Wailing caverns

View File

@@ -1236,6 +1236,10 @@
<Filter
Name="Un&apos;Goro Crater"
>
<File
RelativePath="..\scripts\zone\ungoro_crater\ungoro_crater.cpp"
>
</File>
</Filter>
<Filter
Name="Aunchindoun"

View File

@@ -1413,6 +1413,10 @@
<Filter
Name="Un&apos;Goro Crater"
>
<File
RelativePath="..\scripts\zone\ungoro_crater\ungoro_crater.cpp"
>
</File>
</Filter>
<Filter
Name="Aunchindoun"

View File

@@ -1406,6 +1406,10 @@
<Filter
Name="Un&apos;Goro Crater"
>
<File
RelativePath="..\scripts\zone\ungoro_crater\ungoro_crater.cpp"
>
</File>
</Filter>
<Filter
Name="Aunchindoun"

View File

@@ -368,7 +368,6 @@ bool GossipSelect_npc_skyguard_handler_deesak(Player *player, Creature *_Creatur
#define QUEST_EFTW_A 10051
#define GO_CAGE 182794
#define SPELL_CAT 32447
//update creature_template set scriptname='npc_isla_starmane' where entry=18760;
struct TRINITY_DLL_DECL npc_isla_starmaneAI : public npc_escortAI
{

View File

@@ -0,0 +1,208 @@
/* Copyright (C) 2006 - 2009 ScriptDev2 <https://scriptdev2.svn.sourceforge.net/>
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
/* ScriptData
SDName: Ungoro Crater
SD%Complete: 100
SDComment: Support for Quest: 4245
SDCategory: Ungoro Crater
EndScriptData */
/* ContentData
npc_a-me
EndContentData */
#include "precompiled.h"
#include "../../npc/npc_escortAI.h"
#define SAY_READY -1000200
#define SAY_AGGRO1 -1000201
#define SAY_SEARCH -1000202
#define SAY_AGGRO2 -1000203
#define SAY_AGGRO3 -1000204
#define SAY_FINISH -1000205
#define SPELL_DEMORALIZINGSHOUT 13730
#define QUEST_CHASING_AME 4245
#define ENTRY_TARLORD 6519
#define ENTRY_TARLORD1 6519
#define ENTRY_STOMPER 6513
struct TRINITY_DLL_DECL npc_ameAI : public npc_escortAI
{
npc_ameAI(Creature *c) : npc_escortAI(c) {Reset();}
uint32 DEMORALIZINGSHOUT_Timer;
void WaypointReached(uint32 i)
{
Unit* player = Unit::GetUnit((*m_creature), PlayerGUID);
if (!player)
return;
switch (i)
{
case 19:
m_creature->SummonCreature(ENTRY_STOMPER, -6391.69, -1730.49, -272.83, 4.96, TEMPSUMMON_TIMED_DESPAWN_OUT_OF_COMBAT, 25000);
DoScriptText(SAY_AGGRO1, m_creature, player);
break;
case 28:
DoScriptText(SAY_SEARCH, m_creature, player);
break;
case 38:
m_creature->SummonCreature(ENTRY_TARLORD, -6370.75, -1382.84, -270.51, 6.06, TEMPSUMMON_TIMED_DESPAWN_OUT_OF_COMBAT, 25000);
DoScriptText(SAY_AGGRO2, m_creature, player);
break;
case 49:
m_creature->SummonCreature(ENTRY_TARLORD1, -6324.44, -1181.05, -270.17, 4.34, TEMPSUMMON_TIMED_DESPAWN_OUT_OF_COMBAT, 25000);
DoScriptText(SAY_AGGRO3, m_creature, player);
break;
case 55:
DoScriptText(SAY_FINISH, m_creature, player);
if (player && player->GetTypeId() == TYPEID_PLAYER)
((Player*)player)->GroupEventHappens(QUEST_CHASING_AME,m_creature);
break;
}
}
void Reset()
{
DEMORALIZINGSHOUT_Timer = 5000;
}
void Aggro(Unit* who)
{}
void JustSummoned(Creature* summoned)
{
summoned->AI()->AttackStart(m_creature);
}
void JustDied(Unit* killer)
{
if (PlayerGUID)
{
if (Unit* player = Unit::GetUnit((*m_creature), PlayerGUID))
((Player*)player)->FailQuest(QUEST_CHASING_AME);
}
}
void UpdateAI(const uint32 diff)
{
npc_escortAI::UpdateAI(diff);
if (!m_creature->SelectHostilTarget() || !m_creature->getVictim())
return;
if (DEMORALIZINGSHOUT_Timer < diff)
{
DoCast(m_creature->getVictim(),SPELL_DEMORALIZINGSHOUT);
DEMORALIZINGSHOUT_Timer = 70000;
}else DEMORALIZINGSHOUT_Timer -= diff;
}
};
bool QuestAccept_npc_ame(Player* player, Creature* creature, Quest const* quest)
{
if (quest->GetQuestId() == QUEST_CHASING_AME)
{
((npc_escortAI*)(creature->AI()))->Start(false, true, false, player->GetGUID());
DoScriptText(SAY_READY, creature, player);
// Change faction so mobs attack
creature->setFaction(775);
}
return true;
}
CreatureAI* GetAI_npc_ame(Creature *_Creature)
{
npc_ameAI* thisAI = new npc_ameAI(_Creature);
thisAI->AddWaypoint(1, -6380.38, -1965.14, -258.292, 5000);
thisAI->AddWaypoint(2, -6383.06, -1962.9, -258.936);
thisAI->AddWaypoint(3, -6391.09, -1956.13, -260.291);
thisAI->AddWaypoint(4, -6395.29, -1933.58, -262.949);
thisAI->AddWaypoint(5, -6396.58, -1919.93, -263.838);
thisAI->AddWaypoint(6, -6389.01, -1912.64, -260.689);
thisAI->AddWaypoint(7, -6369.19, -1892.87, -255.924);
thisAI->AddWaypoint(8, -6373.77, -1879.36, -259.268);
thisAI->AddWaypoint(9, -6377.55, -1869.56, -260.503);
thisAI->AddWaypoint(10, -6376.58, -1860.79, -260.026);
thisAI->AddWaypoint(11, -6373.13, -1847.22, -259.249);
thisAI->AddWaypoint(12, -6370.54, -1837.04, -260.007);
thisAI->AddWaypoint(13, -6372.52, -1829.16, -260.071);
thisAI->AddWaypoint(14, -6377.13, -1815.94, -262.632);
thisAI->AddWaypoint(15, -6380.27, -1806.95, -265.53);
thisAI->AddWaypoint(16, -6386.04, -1790.43, -268.546);
thisAI->AddWaypoint(17, -6386.72, -1776.29, -269.851);
thisAI->AddWaypoint(18, -6385.92, -1762.31, -271.494);
thisAI->AddWaypoint(19, -6384.69, -1744.86, -272.196);
thisAI->AddWaypoint(20, -6383.8, -1732.66, -272.222);
thisAI->AddWaypoint(21, -6382.66, -1716.96, -272.235);
thisAI->AddWaypoint(22, -6381.5, -1703.01, -272.964);
thisAI->AddWaypoint(23, -6379.96, -1685.58, -272.842);
thisAI->AddWaypoint(24, -6379.34, -1678.61, -272.34);
thisAI->AddWaypoint(25, -6364.45, -1636.27, -271.065);
thisAI->AddWaypoint(26, -6371.85, -1626.36, -272.188);
thisAI->AddWaypoint(27, -6383.5, -1629.01, -272.206);
thisAI->AddWaypoint(28, -6388.09, -1635.37, -272.105, 5000);
thisAI->AddWaypoint(29, -6375.42, -1637.33, -272.193);
thisAI->AddWaypoint(30, -6365.46, -1617.25, -272.141);
thisAI->AddWaypoint(31, -6353.79, -1603.48, -271.932);
thisAI->AddWaypoint(32, -6340.24, -1592.41, -269.435);
thisAI->AddWaypoint(33, -6329.45, -1566.89, -269.895);
thisAI->AddWaypoint(34, -6312.2, -1499.06, -269.507);
thisAI->AddWaypoint(35, -6304.55, -1468.5, -269.431);
thisAI->AddWaypoint(36, -6310.36, -1440.94, -268.427);
thisAI->AddWaypoint(37, -6321, -1418.91, -266.525);
thisAI->AddWaypoint(38, -6358.76, -1389.97, -267.522);
thisAI->AddWaypoint(39, -6378.65, -1375.67, -271.749);
thisAI->AddWaypoint(40, -6387.22, -1360.95, -272.109);
thisAI->AddWaypoint(41, -6406.95, -1323.87, -271.586);
thisAI->AddWaypoint(42, -6405, -1311.92, -271.906);
thisAI->AddWaypoint(43, -6395.56, -1303.62, -271.902);
thisAI->AddWaypoint(44, -6375.97, -1296.08, -271.865);
thisAI->AddWaypoint(45, -6364.39, -1281.23, -269.012);
thisAI->AddWaypoint(46, -6353.71, -1263.19, -267.95);
thisAI->AddWaypoint(47, -6340.09, -1248.65, -267.441);
thisAI->AddWaypoint(48, -6338.21, -1237.11, -267.844);
thisAI->AddWaypoint(49, -6336.6, -1219.69, -269.196);
thisAI->AddWaypoint(50, -6334.44, -1202.33, -271.527);
thisAI->AddWaypoint(51, -6329.56, -1189.82, -270.947);
thisAI->AddWaypoint(52, -6324.66, -1179.46, -270.103);
thisAI->AddWaypoint(53, -6315.08, -1176.74, -269.735);
thisAI->AddWaypoint(54, -6308.49, -1179.12, -269.57);
thisAI->AddWaypoint(55, -6302.43, -1181.32, -269.328, 5000);
thisAI->AddWaypoint(56, -6298.87, -1185.79, -269.278);
return (CreatureAI*)thisAI;
}
void AddSC_ungoro_crater()
{
Script *newscript;
newscript = new Script;
newscript->Name = "npc_ame";
newscript->GetAI = &GetAI_npc_ame;
newscript->pQuestAccept = &QuestAccept_npc_ame;
newscript->RegisterSelf();
}