mirror of
https://github.com/SapphireServer/Sapphire.git
synced 2025-06-07 16:47:44 +00:00
Scripts/Quest
Add quest Subsea0012 (Quest Glory Days)
This commit is contained in:
parent
558ae87568
commit
332ac9e976
2 changed files with 159 additions and 0 deletions
|
@ -28,6 +28,7 @@
|
|||
#include "subquest/gridania/SubFst041.cpp"
|
||||
#include "subquest/gridania/SubFst045.cpp"
|
||||
#include "subquest/limsa/SubSea001.cpp"
|
||||
#include "subquest/limsa/SubSea012.cpp"
|
||||
#include "subquest/uldah/SubWil000.cpp"
|
||||
#include "subquest/uldah/SubWil001.cpp"
|
||||
#include "subquest/uldah/SubWil002.cpp"
|
||||
|
@ -72,6 +73,7 @@ const Sapphire::ScriptAPI::ScriptObject* ptrs[] =
|
|||
static_cast< Sapphire::ScriptAPI::ScriptObject* >( new SubFst041 ),
|
||||
static_cast< Sapphire::ScriptAPI::ScriptObject* >( new SubFst045 ),
|
||||
static_cast< Sapphire::ScriptAPI::ScriptObject* >( new SubSea001 ),
|
||||
static_cast< Sapphire::ScriptAPI::ScriptObject* >( new SubSea012 ),
|
||||
static_cast< Sapphire::ScriptAPI::ScriptObject* >( new SubWil000 ),
|
||||
static_cast< Sapphire::ScriptAPI::ScriptObject* >( new SubWil001 ),
|
||||
static_cast< Sapphire::ScriptAPI::ScriptObject* >( new SubWil002 ),
|
||||
|
|
157
src/scripts/quest/subquest/limsa/SubSea012.cpp
Normal file
157
src/scripts/quest/subquest/limsa/SubSea012.cpp
Normal file
|
@ -0,0 +1,157 @@
|
|||
#include <Script/NativeScriptApi.h>
|
||||
#include <Actor/Player.h>
|
||||
#include "Manager/EventMgr.h"
|
||||
#include <ScriptObject.h>
|
||||
#include "Framework.h"
|
||||
|
||||
using namespace Sapphire;
|
||||
|
||||
// Quest Script: SubSea012_00122
|
||||
// Quest Name: Glory Days
|
||||
// Quest ID: 65658
|
||||
// Start NPC: 1003601
|
||||
// End NPC: 1000972
|
||||
|
||||
class SubSea012 : public EventScript
|
||||
{
|
||||
private:
|
||||
// Basic quest information
|
||||
// Quest vars / flags used
|
||||
// GetQuestUI8AL
|
||||
// GetQuestUI8BH
|
||||
|
||||
// Steps in this quest ( 0 is before accepting,
|
||||
// 1 is first, 255 means ready for turning it in
|
||||
enum Sequence : uint8_t
|
||||
{
|
||||
Seq0 = 0,
|
||||
Seq1 = 1,
|
||||
Seq2 = 2,
|
||||
SeqFinish = 255,
|
||||
};
|
||||
|
||||
// Quest rewards
|
||||
static constexpr auto RewardExpFactor = 100;
|
||||
static constexpr auto RewardItem[] = { 0, 0, 0, 0, 0, 0 };
|
||||
static constexpr auto RewardItemCount[] = { 0, 0, 0, 0, 0, 0 };
|
||||
static constexpr auto RewardItemOptional[] = { 2999, 3010, 5823, 0, 0 };
|
||||
static constexpr auto RewardItemOptionalCount[] = { 1, 1, 3, 0, 0 };
|
||||
|
||||
// Entities found in the script data of the quest
|
||||
static constexpr auto Actor0 = 1003601;
|
||||
static constexpr auto Actor1 = 1001024;
|
||||
static constexpr auto Actor2 = 1000972;
|
||||
static constexpr auto Enemy0 = 324;
|
||||
static constexpr auto Item0 = 2000454;
|
||||
|
||||
public:
|
||||
SubSea012() : EventScript( 65658 ){};
|
||||
~SubSea012(){};
|
||||
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
// Event Handlers
|
||||
void onTalk( uint32_t eventId, Entity::Player& player, uint64_t actorId ) override
|
||||
{
|
||||
auto pEventMgr = m_framework->get< World::Manager::EventMgr >();
|
||||
auto actor = pEventMgr->mapEventActorToRealActor( static_cast< uint32_t >( actorId ) );
|
||||
if( actor == Actor0 )
|
||||
{
|
||||
Scene00000( player );
|
||||
}
|
||||
else if( actor == Actor1 )
|
||||
{
|
||||
Scene00003( player );
|
||||
}
|
||||
else if( actor == Actor2 )
|
||||
{
|
||||
Scene00004( player );
|
||||
}
|
||||
}
|
||||
|
||||
void onMobKill( Entity::Player& player, uint64_t npcId )
|
||||
{
|
||||
if( npcId != Enemy0 )
|
||||
return;
|
||||
|
||||
auto currentKC = player.getQuestUI8AL( getId() ) + 1;
|
||||
|
||||
if( currentKC >= 4 )
|
||||
player.updateQuest( getId(), SeqFinish );
|
||||
else
|
||||
{
|
||||
player.setQuestUI8AL( getId(), currentKC );
|
||||
player.sendQuestMessage( getId(), 0, 2, currentKC, 4 );
|
||||
}
|
||||
}
|
||||
|
||||
private:
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
// Available Scenes in this quest, not necessarly all are used
|
||||
void checkQuestCompletion( Entity::Player& player )
|
||||
{
|
||||
auto currentCC = player.getQuestUI8BH( getId() );
|
||||
|
||||
player.sendQuestMessage( getId(), X, Y, currentCC + 1, Z );
|
||||
|
||||
if( currentCC + 1 >= Z )
|
||||
{
|
||||
player.updateQuest( getId(), SeqFinish );
|
||||
player.setQuestUI8BH( getId(), currentCC + 1 );
|
||||
player.setQuestUI8AL( getId(), currentCC + 1 );
|
||||
}
|
||||
else
|
||||
{
|
||||
player.setQuestUI8BH( getId(), currentCC + 1 );
|
||||
player.setQuestUI8AL( getId(), currentCC + 1 );
|
||||
}
|
||||
}
|
||||
|
||||
void Scene00000( Entity::Player& player )
|
||||
{
|
||||
player.playScene( getId(), 0, HIDE_HOTBAR,
|
||||
[ & ]( Entity::Player& player, const Event::SceneResult& result )
|
||||
{
|
||||
if( result.param2 == 1 )
|
||||
player.updateQuest( getId(), 1 );
|
||||
} );
|
||||
}
|
||||
|
||||
void Scene00001( Entity::Player& player )
|
||||
{
|
||||
player.playScene( getId(), 1, HIDE_HOTBAR,
|
||||
[ & ]( Entity::Player& player, const Event::SceneResult& result )
|
||||
{
|
||||
} );
|
||||
}
|
||||
|
||||
void Scene00002( Entity::Player& player )
|
||||
{
|
||||
player.playScene( getId(), 2, HIDE_HOTBAR,
|
||||
[ & ]( Entity::Player& player, const Event::SceneResult& result )
|
||||
{
|
||||
} );
|
||||
}
|
||||
|
||||
void Scene00003( Entity::Player& player )
|
||||
{
|
||||
player.playScene( getId(), 3, HIDE_HOTBAR,
|
||||
[ & ]( Entity::Player& player, const Event::SceneResult& result )
|
||||
{
|
||||
if( result.param2 == 1 )
|
||||
player.updateQuest( getId(), 2 );
|
||||
} );
|
||||
}
|
||||
|
||||
void Scene00004( Entity::Player& player )
|
||||
{
|
||||
player.playScene( getId(), 4, HIDE_HOTBAR,
|
||||
[ & ]( Entity::Player& player, const Event::SceneResult& result )
|
||||
{
|
||||
if( result.param2 == 1 )
|
||||
if( player.giveQuestRewards( getId(), 0 ) )
|
||||
player.finishQuest( getId() );
|
||||
}
|
||||
} );
|
||||
}
|
||||
|
||||
};
|
Loading…
Add table
Reference in a new issue