mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2025-01-11 15:27:07 +00:00
Changed how pet data is loaded
This commit is contained in:
parent
1c7ce6eac3
commit
cecf0653c7
@ -104,20 +104,17 @@ PetComponent::PetComponent(Entity* parent, uint32_t componentId): Component(pare
|
|||||||
|
|
||||||
// Load database values
|
// Load database values
|
||||||
m_FollowRadius = Game::zoneManager->GetPetFollowRadius();
|
m_FollowRadius = Game::zoneManager->GetPetFollowRadius();
|
||||||
if (!GetPetInfo(m_ComponentId, m_PetInfo)) LOG("Failed to load PetComponent information from CDClient!");
|
if (!LoadPetInfo(componentId, m_PetInfo)) LOG("Failed to load PetComponent (id: %d) information from CDClient!", componentId);
|
||||||
|
|
||||||
/*m_PetInfo.id;
|
|
||||||
m_PetInfo.runSpeed;
|
|
||||||
m_PetInfo.sprintSpeed;
|
|
||||||
m_PetInfo.walkSpeed;*/
|
|
||||||
|
|
||||||
//CDClientManager::GetTable<CDComp>()
|
|
||||||
//LoadDataFromTemplate(); // TODO: Figure out how to load this with the tests (DarkflameServer/dDatabase/CDClientDatabase/CDClientTables/)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool PetComponent::GetPetInfo(uint32_t petId, CDPetComponent& result) {
|
bool PetComponent::LoadPetInfo(uint32_t petId, CDPetComponent& result) {
|
||||||
auto* petTable = CDClientManager::Instance().GetTable<CDPetComponentTable>();
|
CDPetComponentTable* petTable;
|
||||||
|
try {
|
||||||
|
petTable = CDClientManager::Instance().GetTable<CDPetComponentTable>();
|
||||||
|
} catch(...) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
const auto pet = petTable->GetByID(petId);
|
const auto pet = petTable->GetByID(petId);
|
||||||
if (!pet) return false;
|
if (!pet) return false;
|
||||||
|
|
||||||
@ -381,7 +378,6 @@ void PetComponent::Update(float deltaTime) {
|
|||||||
// Handle pet AI states
|
// Handle pet AI states
|
||||||
switch (m_State) {
|
switch (m_State) {
|
||||||
case PetAiState::spawn:
|
case PetAiState::spawn:
|
||||||
LOG_DEBUG("Pet spawn beginning!");
|
|
||||||
OnSpawn();
|
OnSpawn();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -613,7 +609,7 @@ void PetComponent::NotifyTamingBuildSuccess(NiPoint3 position) {
|
|||||||
missionComponent->Progress(eMissionTaskType::PET_TAMING, m_Parent->GetLOT());
|
missionComponent->Progress(eMissionTaskType::PET_TAMING, m_Parent->GetLOT());
|
||||||
}
|
}
|
||||||
|
|
||||||
SetFlag(UNKNOWN1); // SetStatus(1);
|
SetOnlyFlag(UNKNOWN1); // SetStatus(1);
|
||||||
|
|
||||||
auto* characterComponent = tamer->GetComponent<CharacterComponent>();
|
auto* characterComponent = tamer->GetComponent<CharacterComponent>();
|
||||||
if (characterComponent != nullptr) {
|
if (characterComponent != nullptr) {
|
||||||
@ -726,7 +722,7 @@ void PetComponent::ClientExitTamingMinigame(bool voluntaryExit) {
|
|||||||
|
|
||||||
currentActivities.erase(m_Tamer);
|
currentActivities.erase(m_Tamer);
|
||||||
|
|
||||||
SetStatus(PetFlag::TAMEABLE);
|
SetOnlyFlag(TAMEABLE); //SetStatus(PetFlag::TAMEABLE);
|
||||||
m_Tamer = LWOOBJID_EMPTY;
|
m_Tamer = LWOOBJID_EMPTY;
|
||||||
m_Timer = 0;
|
m_Timer = 0;
|
||||||
|
|
||||||
@ -777,7 +773,7 @@ void PetComponent::ClientFailTamingMinigame() {
|
|||||||
|
|
||||||
currentActivities.erase(m_Tamer);
|
currentActivities.erase(m_Tamer);
|
||||||
|
|
||||||
SetStatus(PetFlag::TAMEABLE);
|
SetOnlyFlag(TAMEABLE); //SetStatus(PetFlag::TAMEABLE);
|
||||||
m_Tamer = LWOOBJID_EMPTY;
|
m_Tamer = LWOOBJID_EMPTY;
|
||||||
m_Timer = 0;
|
m_Timer = 0;
|
||||||
|
|
||||||
@ -830,19 +826,16 @@ void PetComponent::Wander() {
|
|||||||
|
|
||||||
void PetComponent::OnSpawn() {
|
void PetComponent::OnSpawn() {
|
||||||
m_MovementAI = m_Parent->GetComponent<MovementAIComponent>();
|
m_MovementAI = m_Parent->GetComponent<MovementAIComponent>();
|
||||||
//if (!m_MovementAI) return;
|
|
||||||
|
|
||||||
if (m_StartPosition == NiPoint3::ZERO) {
|
if (m_StartPosition == NiPoint3::ZERO) {
|
||||||
m_StartPosition = m_Parent->GetPosition();
|
m_StartPosition = m_Parent->GetPosition();
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG_DEBUG("Pet spawn complete, setting AI state.");
|
|
||||||
|
|
||||||
if (m_Owner != LWOOBJID_EMPTY) {
|
if (m_Owner != LWOOBJID_EMPTY) {
|
||||||
m_Parent->SetOwnerOverride(m_Owner);
|
m_Parent->SetOwnerOverride(m_Owner);
|
||||||
m_MovementAI->SetMaxSpeed(m_PetInfo.sprintSpeed);
|
m_MovementAI->SetMaxSpeed(m_PetInfo.sprintSpeed);
|
||||||
m_MovementAI->SetHaltDistance(m_FollowRadius);
|
m_MovementAI->SetHaltDistance(m_FollowRadius);
|
||||||
SetStatus(PetFlag::NONE);
|
SetOnlyFlag(UNKNOWN1); //SetStatus(PetFlag::NONE);
|
||||||
SetPetAiState(PetAiState::follow);
|
SetPetAiState(PetAiState::follow);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -953,7 +946,7 @@ void PetComponent::StopInteract() {
|
|||||||
SetInteractType(PetInteractType::none);
|
SetInteractType(PetInteractType::none);
|
||||||
SetAbility(petAbility);
|
SetAbility(petAbility);
|
||||||
SetPetAiState(PetAiState::follow);
|
SetPetAiState(PetAiState::follow);
|
||||||
SetOnlyFlag(NONE); //SetStatus(PetFlag::NONE);
|
SetOnlyFlag(UNKNOWN1); //SetStatus(PetFlag::NONE);
|
||||||
SetIsReadyToInteract(false);
|
SetIsReadyToInteract(false);
|
||||||
SetIsHandlingInteraction(false); // Needed?
|
SetIsHandlingInteraction(false); // Needed?
|
||||||
m_MovementAI->SetMaxSpeed(m_PetInfo.sprintSpeed);
|
m_MovementAI->SetMaxSpeed(m_PetInfo.sprintSpeed);
|
||||||
|
@ -35,7 +35,7 @@ enum PetInteractType : uint8_t {
|
|||||||
*/
|
*/
|
||||||
enum PetFlag : uint32_t {
|
enum PetFlag : uint32_t {
|
||||||
NONE,
|
NONE,
|
||||||
UNKNOWN1 = 1 << 0, //0x01,
|
UNKNOWN1 = 1 << 0, //0x01 - Seems to be "idle," which the game doesn't differentiate from "follow"
|
||||||
UNKNOWN4 = 1 << 2, //0x04,
|
UNKNOWN4 = 1 << 2, //0x04,
|
||||||
BEING_TAMED = 1 << 4, //0x10,
|
BEING_TAMED = 1 << 4, //0x10,
|
||||||
NOT_WAITING = 1 << 5, //0x20,
|
NOT_WAITING = 1 << 5, //0x20,
|
||||||
@ -66,7 +66,7 @@ public:
|
|||||||
/**
|
/**
|
||||||
* Loads pet info from CDClient
|
* Loads pet info from CDClient
|
||||||
*/
|
*/
|
||||||
bool GetPetInfo(uint32_t petId, CDPetComponent& result);
|
bool LoadPetInfo(uint32_t petId, CDPetComponent& result);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Serializes the pet
|
* Serializes the pet
|
||||||
@ -427,7 +427,7 @@ private:
|
|||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Information that describes the different variables used to make a pet entity move around
|
* Pet information loaded from the CDClientDatabase
|
||||||
*/
|
*/
|
||||||
CDPetComponent m_PetInfo;
|
CDPetComponent m_PetInfo;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user