Changed how pet data is loaded

This commit is contained in:
jadebenn 2023-12-15 21:47:16 -06:00
parent 1c7ce6eac3
commit cecf0653c7
2 changed files with 17 additions and 24 deletions

View File

@ -104,19 +104,16 @@ 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);

View File

@ -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;