2021-12-05 17:54:36 +00:00
|
|
|
#include "DamagingPets.h"
|
|
|
|
#include "PetComponent.h"
|
|
|
|
#include "DestroyableComponent.h"
|
|
|
|
#include "BaseCombatAIComponent.h"
|
|
|
|
#include "RenderComponent.h"
|
2023-05-02 22:39:21 +00:00
|
|
|
#include "ePetTamingNotifyType.h"
|
2021-12-05 17:54:36 +00:00
|
|
|
|
|
|
|
void DamagingPets::OnStartup(Entity* self) {
|
|
|
|
|
|
|
|
// Make the pet hostile or non-hostile based on whether or not it is tamed
|
|
|
|
const auto* petComponent = self->GetComponent<PetComponent>();
|
|
|
|
if (petComponent != nullptr && petComponent->GetOwner() == nullptr) {
|
|
|
|
self->AddTimer("GoEvil", 0.5f);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void DamagingPets::OnPlayerLoaded(Entity* self, Entity* player) {
|
2022-07-28 13:39:57 +00:00
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
// Makes it so that new players also see the effect
|
|
|
|
self->AddCallbackTimer(2.5f, [self]() {
|
|
|
|
if (self != nullptr) {
|
|
|
|
const auto* petComponent = self->GetComponent<PetComponent>();
|
|
|
|
if (petComponent != nullptr && petComponent->GetOwner() == nullptr && self->GetVar<bool>(u"IsEvil")) {
|
|
|
|
auto* renderComponent = self->GetComponent<RenderComponent>();
|
|
|
|
if (renderComponent != nullptr) {
|
|
|
|
auto counter = 1;
|
|
|
|
for (const auto petEffect : GetPetInfo(self).effect) {
|
|
|
|
renderComponent->PlayEffect(petEffect, u"create", "FXname" + std::to_string(counter));
|
|
|
|
counter++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2023-05-02 22:39:21 +00:00
|
|
|
void DamagingPets::OnNotifyPetTamingMinigame(Entity* self, Entity* tamer, ePetTamingNotifyType type) {
|
2021-12-05 17:54:36 +00:00
|
|
|
switch (type) {
|
2023-05-02 22:39:21 +00:00
|
|
|
case ePetTamingNotifyType::SUCCESS:
|
|
|
|
case ePetTamingNotifyType::BEGIN:
|
2021-12-05 17:54:36 +00:00
|
|
|
self->CancelAllTimers();
|
|
|
|
ClearEffects(self);
|
|
|
|
break;
|
2023-05-02 22:39:21 +00:00
|
|
|
case ePetTamingNotifyType::FAILED:
|
|
|
|
case ePetTamingNotifyType::QUIT:
|
2021-12-05 17:54:36 +00:00
|
|
|
{
|
|
|
|
self->SetNetworkVar<bool>(u"bIAmTamable", false);
|
|
|
|
self->AddTimer("GoEvil", 1.0f);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void DamagingPets::OnSkillEventFired(Entity* self, Entity* caster, const std::string& message) {
|
|
|
|
const auto infoForPet = GetPetInfo(self);
|
|
|
|
if (infoForPet.skill == message) {
|
2022-07-28 13:39:57 +00:00
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
// Only make pets tamable that aren't tamed yet
|
|
|
|
const auto* petComponent = self->GetComponent<PetComponent>();
|
|
|
|
if (petComponent != nullptr && petComponent->GetOwner() == nullptr && self->GetVar<bool>(u"IsEvil")) {
|
|
|
|
ClearEffects(self);
|
|
|
|
self->AddTimer("GoEvil", 30.0f);
|
|
|
|
self->SetNetworkVar<bool>(u"bIAmTamable", true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void DamagingPets::OnTimerDone(Entity* self, std::string message) {
|
|
|
|
if (message == "GoEvil") {
|
|
|
|
MakeUntamable(self);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void DamagingPets::MakeUntamable(Entity* self) {
|
2024-03-04 01:02:11 +00:00
|
|
|
auto* const petComponent = self->GetComponent<PetComponent>();
|
2022-07-28 13:39:57 +00:00
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
// If the pet is currently not being tamed, make it hostile
|
2024-04-20 02:53:52 +00:00
|
|
|
if (petComponent != nullptr && !petComponent->m_Flags.Has(PetFlag::NOT_WAITING)) {
|
2021-12-05 17:54:36 +00:00
|
|
|
self->SetNetworkVar<bool>(u"bIAmTamable", false);
|
|
|
|
self->SetVar<bool>(u"IsEvil", true);
|
2024-04-20 02:53:52 +00:00
|
|
|
petComponent->m_Flags.Set(PetFlag::IDLE);
|
2022-07-28 13:39:57 +00:00
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
auto* combatAIComponent = self->GetComponent<BaseCombatAIComponent>();
|
|
|
|
if (combatAIComponent != nullptr) {
|
|
|
|
combatAIComponent->SetDisabled(false);
|
|
|
|
}
|
2022-07-28 13:39:57 +00:00
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
// Special faction that can attack the player but the player can't attack
|
|
|
|
auto* destroyableComponent = self->GetComponent<DestroyableComponent>();
|
|
|
|
if (destroyableComponent != nullptr) {
|
|
|
|
destroyableComponent->SetFaction(114);
|
|
|
|
destroyableComponent->SetHealth(5);
|
|
|
|
}
|
2022-07-28 13:39:57 +00:00
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
auto* renderComponent = self->GetComponent<RenderComponent>();
|
|
|
|
if (renderComponent != nullptr) {
|
|
|
|
auto counter = 1;
|
|
|
|
for (const auto petEffect : GetPetInfo(self).effect) {
|
|
|
|
renderComponent->PlayEffect(petEffect, u"create", "FXname" + std::to_string(counter));
|
|
|
|
counter++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void DamagingPets::ClearEffects(Entity* self) {
|
|
|
|
self->SetVar<bool>(u"IsEvil", false);
|
2022-07-28 13:39:57 +00:00
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
auto* petComponent = self->GetComponent<PetComponent>();
|
|
|
|
if (petComponent != nullptr) {
|
2024-04-20 02:53:52 +00:00
|
|
|
petComponent->m_Flags.Set(PetFlag::TAMEABLE, PetFlag::UNKNOWN2);
|
2021-12-05 17:54:36 +00:00
|
|
|
}
|
2022-07-28 13:39:57 +00:00
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
auto* combatAIComponent = self->GetComponent<BaseCombatAIComponent>();
|
|
|
|
if (combatAIComponent != nullptr) {
|
|
|
|
combatAIComponent->SetDisabled(true);
|
|
|
|
}
|
2022-07-28 13:39:57 +00:00
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
auto* destroyableComponent = self->GetComponent<DestroyableComponent>();
|
|
|
|
if (destroyableComponent != nullptr) {
|
|
|
|
destroyableComponent->SetFaction(99);
|
|
|
|
}
|
2022-07-28 13:39:57 +00:00
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
auto* renderComponent = self->GetComponent<RenderComponent>();
|
|
|
|
if (renderComponent != nullptr) {
|
|
|
|
auto counter = 1;
|
|
|
|
for (const auto petEffect : GetPetInfo(self).effect) {
|
|
|
|
renderComponent->StopEffect("FXname" + std::to_string(counter));
|
|
|
|
counter++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
PetInfo DamagingPets::GetPetInfo(Entity* self) {
|
|
|
|
const auto infoForPet = petInfo.find(self->GetLOT());
|
|
|
|
return infoForPet != petInfo.end() ? infoForPet->second : petInfo.begin()->second;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Does not compile on Win32 with name specifiers
|
|
|
|
const std::map<LOT, PetInfo> DamagingPets::petInfo = {
|
|
|
|
{ 5639, { /*.effect =*/ { 3170, 4058 }, /*.skill =*/ "waterspray"}}, // Red dragon
|
|
|
|
{ 5641, { /*.effect =*/ { 3170, 4058 }, /*.skill =*/ "waterspray"}}, // Green dragon
|
|
|
|
{ 3261, { /*.effect =*/ { 1490 }, /*.skill =*/ "waterspray"}}, // Skunk
|
|
|
|
};
|