2021-12-05 17:54:36 +00:00
|
|
|
#include "QbEnemyStunner.h"
|
|
|
|
#include "SkillComponent.h"
|
2022-12-18 15:46:04 +00:00
|
|
|
#include "CDClientManager.h"
|
2021-12-05 17:54:36 +00:00
|
|
|
#include "DestroyableComponent.h"
|
|
|
|
|
2023-03-17 14:36:21 +00:00
|
|
|
#include "CDObjectSkillsTable.h"
|
|
|
|
#include "CDSkillBehaviorTable.h"
|
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
void QbEnemyStunner::OnRebuildComplete(Entity* self, Entity* target) {
|
|
|
|
auto* destroyable = self->GetComponent<DestroyableComponent>();
|
2021-12-05 17:54:36 +00:00
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
if (destroyable != nullptr) {
|
|
|
|
destroyable->SetFaction(115);
|
|
|
|
}
|
2021-12-05 17:54:36 +00:00
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
auto skillComponent = self->GetComponent<SkillComponent>();
|
|
|
|
if (!skillComponent) return;
|
2021-12-05 17:54:36 +00:00
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
// Get the skill IDs of this object.
|
2023-03-17 14:36:21 +00:00
|
|
|
CDObjectSkillsTable* skillsTable = CDClientManager::Instance().GetTable<CDObjectSkillsTable>();
|
2022-07-28 13:39:57 +00:00
|
|
|
auto skills = skillsTable->Query([=](CDObjectSkills entry) {return (entry.objectTemplate == self->GetLOT()); });
|
|
|
|
std::map<uint32_t, uint32_t> skillBehaviorMap;
|
|
|
|
// For each skill, cast it with the associated behavior ID.
|
|
|
|
for (auto skill : skills) {
|
2023-03-17 14:36:21 +00:00
|
|
|
CDSkillBehaviorTable* skillBehaviorTable = CDClientManager::Instance().GetTable<CDSkillBehaviorTable>();
|
2022-06-29 06:17:45 +00:00
|
|
|
CDSkillBehavior behaviorData = skillBehaviorTable->GetSkillByID(skill.skillID);
|
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
skillBehaviorMap.insert(std::make_pair(skill.skillID, behaviorData.behaviorID));
|
|
|
|
}
|
2021-12-05 17:54:36 +00:00
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
// If there are no skills found, insert a default skill to use.
|
|
|
|
if (skillBehaviorMap.size() == 0) {
|
|
|
|
skillBehaviorMap.insert(std::make_pair(499U, 6095U));
|
|
|
|
}
|
2022-06-29 06:17:45 +00:00
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
// Start all skills associated with the object next tick
|
|
|
|
self->AddTimer("TickTime", 0);
|
2021-12-05 17:54:36 +00:00
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
self->AddTimer("PlayEffect", 20);
|
2022-06-29 06:17:45 +00:00
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
self->SetVar<std::map<uint32_t, uint32_t>>(u"skillBehaviorMap", skillBehaviorMap);
|
2021-12-05 17:54:36 +00:00
|
|
|
}
|
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
void QbEnemyStunner::OnTimerDone(Entity* self, std::string timerName) {
|
|
|
|
if (timerName == "DieTime") {
|
|
|
|
self->Smash();
|
2021-12-05 17:54:36 +00:00
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
self->CancelAllTimers();
|
|
|
|
} else if (timerName == "PlayEffect") {
|
|
|
|
self->SetNetworkVar(u"startEffect", 5.0f, UNASSIGNED_SYSTEM_ADDRESS);
|
2021-12-05 17:54:36 +00:00
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
self->AddTimer("DieTime", 5.0f);
|
|
|
|
} else if (timerName == "TickTime") {
|
|
|
|
auto* skillComponent = self->GetComponent<SkillComponent>();
|
2021-12-05 17:54:36 +00:00
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
if (skillComponent != nullptr) {
|
|
|
|
auto skillBehaviorMap = self->GetVar<std::map<uint32_t, uint32_t>>(u"skillBehaviorMap");
|
|
|
|
if (skillBehaviorMap.size() == 0) {
|
|
|
|
// Should no skills have been found, default to the mermaid stunner
|
|
|
|
skillComponent->CalculateBehavior(499U, 6095U, LWOOBJID_EMPTY);
|
|
|
|
} else {
|
|
|
|
for (auto pair : skillBehaviorMap) {
|
|
|
|
skillComponent->CalculateBehavior(pair.first, pair.second, LWOOBJID_EMPTY);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
self->AddTimer("TickTime", 1);
|
|
|
|
}
|
2021-12-05 17:54:36 +00:00
|
|
|
}
|