mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2024-11-26 23:47:21 +00:00
5942182486
* Logger: Rename logger to Logger from dLogger * Logger: Add compile time filename Fix include issues Add writers Add macros Add macro to force compilation * Logger: Replace calls with macros Allows for filename and line number to be logged * Logger: Add comments and remove extra define Logger: Replace with unique_ptr also flush console at exit. regular file writer should be flushed on file close. Logger: Remove constexpr on variable * Logger: Simplify code * Update Logger.cpp
180 lines
5.2 KiB
C++
180 lines
5.2 KiB
C++
#include "FvMaelstromDragon.h"
|
|
#include "EntityManager.h"
|
|
#include "SkillComponent.h"
|
|
#include "BaseCombatAIComponent.h"
|
|
#include "DestroyableComponent.h"
|
|
#include "eAninmationFlags.h"
|
|
#include "EntityInfo.h"
|
|
#include "RenderComponent.h"
|
|
|
|
void FvMaelstromDragon::OnStartup(Entity* self) {
|
|
self->SetVar<int32_t>(u"weakspot", 0);
|
|
|
|
auto* baseCombatAIComponent = self->GetComponent<BaseCombatAIComponent>();
|
|
|
|
if (baseCombatAIComponent != nullptr) {
|
|
baseCombatAIComponent->SetStunImmune(true);
|
|
}
|
|
}
|
|
|
|
void FvMaelstromDragon::OnDie(Entity* self, Entity* killer) {
|
|
if (self->GetVar<bool>(u"bDied")) {
|
|
return;
|
|
}
|
|
|
|
self->SetVar<bool>(u"bDied", true);
|
|
|
|
auto position = self->GetPosition();
|
|
auto rotation = self->GetRotation();
|
|
|
|
auto chestObject = 11229;
|
|
|
|
EntityInfo info{};
|
|
info.lot = chestObject;
|
|
info.pos = position;
|
|
info.rot = rotation;
|
|
info.spawnerID = self->GetObjectID();
|
|
|
|
auto* chest = Game::entityManager->CreateEntity(info);
|
|
|
|
Game::entityManager->ConstructEntity(chest);
|
|
|
|
auto golemId = self->GetVar<LWOOBJID>(u"Golem");
|
|
|
|
auto* golem = Game::entityManager->GetEntity(golemId);
|
|
|
|
if (golem != nullptr) {
|
|
golem->Smash(self->GetObjectID());
|
|
}
|
|
}
|
|
|
|
void FvMaelstromDragon::OnHitOrHealResult(Entity* self, Entity* attacker, int32_t damage) {
|
|
GameMessages::SendPlayFXEffect(self, -1, u"gothit", "", LWOOBJID_EMPTY, 1, 1, true);
|
|
|
|
if (true) {
|
|
auto weakpoint = self->GetVar<int32_t>(u"weakspot");
|
|
|
|
if (weakpoint == 1) {
|
|
self->Smash(attacker->GetObjectID());
|
|
}
|
|
}
|
|
|
|
auto* destroyableComponent = self->GetComponent<DestroyableComponent>();
|
|
|
|
if (destroyableComponent != nullptr) {
|
|
if (destroyableComponent->GetArmor() > 0) return;
|
|
|
|
auto weakpoint = self->GetVar<int32_t>(u"weakpoint");
|
|
|
|
if (weakpoint == 0) {
|
|
LOG("Activating weakpoint");
|
|
|
|
self->AddTimer("ReviveTimer", 12);
|
|
|
|
auto* baseCombatAIComponent = self->GetComponent<BaseCombatAIComponent>();
|
|
auto* skillComponent = self->GetComponent<SkillComponent>();
|
|
|
|
if (baseCombatAIComponent != nullptr) {
|
|
baseCombatAIComponent->SetDisabled(true);
|
|
baseCombatAIComponent->SetStunned(true);
|
|
}
|
|
|
|
if (skillComponent != nullptr) {
|
|
skillComponent->Interrupt();
|
|
skillComponent->Reset();
|
|
}
|
|
|
|
self->SetVar<int32_t>(u"weakpoint", 2);
|
|
|
|
GameMessages::SendChangeIdleFlags(self->GetObjectID(), eAnimationFlags::IDLE_NONE, eAnimationFlags::IDLE_COMBAT, UNASSIGNED_SYSTEM_ADDRESS);
|
|
RenderComponent::PlayAnimation(self, u"stunstart", 1.7f);
|
|
|
|
self->AddTimer("timeToStunLoop", 1.0f);
|
|
|
|
auto position = self->GetPosition();
|
|
auto forward = self->GetRotation().GetForwardVector();
|
|
auto backwards = forward * -1;
|
|
|
|
forward.x *= 10;
|
|
forward.z *= 10;
|
|
|
|
auto rotation = self->GetRotation();
|
|
|
|
auto objectPosition = NiPoint3();
|
|
|
|
objectPosition.y = position.y;
|
|
objectPosition.x = position.x - (backwards.x * 8);
|
|
objectPosition.z = position.z - (backwards.z * 8);
|
|
|
|
auto golem = self->GetVar<int32_t>(u"DragonSmashingGolem");
|
|
|
|
EntityInfo info{};
|
|
info.lot = golem != 0 ? golem : 8340;
|
|
info.pos = objectPosition;
|
|
info.rot = rotation;
|
|
info.spawnerID = self->GetObjectID();
|
|
info.settings = {
|
|
new LDFData<std::string>(u"rebuild_activators",
|
|
std::to_string(objectPosition.x + forward.x) + "\x1f" +
|
|
std::to_string(objectPosition.y) + "\x1f" +
|
|
std::to_string(objectPosition.z + forward.z)
|
|
),
|
|
new LDFData<int32_t>(u"respawn", 100000),
|
|
new LDFData<float>(u"rebuild_reset_time", 15),
|
|
new LDFData<bool>(u"no_timed_spawn", true),
|
|
new LDFData<LWOOBJID>(u"Dragon", self->GetObjectID())
|
|
};
|
|
|
|
auto* golemObject = Game::entityManager->CreateEntity(info);
|
|
|
|
Game::entityManager->ConstructEntity(golemObject);
|
|
}
|
|
}
|
|
}
|
|
|
|
void FvMaelstromDragon::OnTimerDone(Entity* self, std::string timerName) {
|
|
if (timerName == "ReviveHeldTimer") {
|
|
self->AddTimer("backToAttack", 2.5);
|
|
} else if (timerName == "ExposeWeakSpotTimer") {
|
|
self->SetVar<int32_t>(u"weakspot", 1);
|
|
} else if (timerName == "timeToStunLoop") {
|
|
RenderComponent::PlayAnimation(self, u"stunloop", 1.8f);
|
|
} else if (timerName == "ReviveTimer") {
|
|
RenderComponent::PlayAnimation(self, u"stunend", 2.0f);
|
|
self->AddTimer("backToAttack", 1.0f);
|
|
} else if (timerName == "backToAttack") {
|
|
auto* baseCombatAIComponent = self->GetComponent<BaseCombatAIComponent>();
|
|
auto* skillComponent = self->GetComponent<SkillComponent>();
|
|
|
|
if (baseCombatAIComponent != nullptr) {
|
|
baseCombatAIComponent->SetDisabled(false);
|
|
baseCombatAIComponent->SetStunned(false);
|
|
}
|
|
|
|
if (skillComponent != nullptr) {
|
|
skillComponent->Interrupt();
|
|
skillComponent->Reset();
|
|
}
|
|
GameMessages::SendChangeIdleFlags(self->GetObjectID(), eAnimationFlags::IDLE_COMBAT, eAnimationFlags::IDLE_NONE, UNASSIGNED_SYSTEM_ADDRESS);
|
|
self->SetVar<int32_t>(u"weakspot", -1);
|
|
|
|
GameMessages::SendNotifyObject(self->GetObjectID(), self->GetObjectID(), u"DragonRevive", UNASSIGNED_SYSTEM_ADDRESS);
|
|
}
|
|
}
|
|
|
|
void
|
|
FvMaelstromDragon::OnFireEventServerSide(Entity* self, Entity* sender, std::string args, int32_t param1, int32_t param2,
|
|
int32_t param3) {
|
|
if (args != "rebuildDone") return;
|
|
|
|
self->AddTimer("ExposeWeakSpotTimer", 3.8f);
|
|
|
|
self->CancelTimer("ReviveTimer");
|
|
|
|
self->AddTimer("ReviveHeldTimer", 10.5f);
|
|
|
|
self->SetVar<LWOOBJID>(u"Golem", sender->GetObjectID());
|
|
|
|
RenderComponent::PlayAnimation(self, u"quickbuildhold", 1.9f);
|
|
}
|