mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2025-01-08 22:07:10 +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
91 lines
3.5 KiB
C++
91 lines
3.5 KiB
C++
#include "ForceMovementBehavior.h"
|
|
#include "BehaviorBranchContext.h"
|
|
#include "BehaviorContext.h"
|
|
#include "ControllablePhysicsComponent.h"
|
|
#include "EntityManager.h"
|
|
#include "Game.h"
|
|
#include "Logger.h"
|
|
|
|
void ForceMovementBehavior::Handle(BehaviorContext* context, RakNet::BitStream* bitStream, const BehaviorBranchContext branch) {
|
|
if (this->m_hitAction->m_templateId == BehaviorTemplates::BEHAVIOR_EMPTY && this->m_hitEnemyAction->m_templateId == BehaviorTemplates::BEHAVIOR_EMPTY && this->m_hitFactionAction->m_templateId == BehaviorTemplates::BEHAVIOR_EMPTY) {
|
|
return;
|
|
}
|
|
|
|
uint32_t handle{};
|
|
if (!bitStream->Read(handle)) {
|
|
LOG("Unable to read handle from bitStream, aborting Handle! %i", bitStream->GetNumberOfUnreadBits());
|
|
return;
|
|
}
|
|
context->RegisterSyncBehavior(handle, this, branch, this->m_Duration);
|
|
}
|
|
|
|
void ForceMovementBehavior::Sync(BehaviorContext* context, RakNet::BitStream* bitStream, BehaviorBranchContext branch) {
|
|
uint32_t next{};
|
|
if (!bitStream->Read(next)) {
|
|
LOG("Unable to read target from bitStream, aborting Sync! %i", bitStream->GetNumberOfUnreadBits());
|
|
return;
|
|
}
|
|
|
|
LWOOBJID target{};
|
|
if (!bitStream->Read(target)) {
|
|
LOG("Unable to read target from bitStream, aborting Sync! %i", bitStream->GetNumberOfUnreadBits());
|
|
return;
|
|
}
|
|
|
|
branch.target = target;
|
|
auto* behavior = CreateBehavior(next);
|
|
behavior->Handle(context, bitStream, branch);
|
|
}
|
|
|
|
void ForceMovementBehavior::Calculate(BehaviorContext* context, RakNet::BitStream* bitStream, BehaviorBranchContext branch) {
|
|
if (this->m_hitAction->m_templateId == BehaviorTemplates::BEHAVIOR_EMPTY && this->m_hitEnemyAction->m_templateId == BehaviorTemplates::BEHAVIOR_EMPTY && this->m_hitFactionAction->m_templateId == BehaviorTemplates::BEHAVIOR_EMPTY) {
|
|
return;
|
|
}
|
|
|
|
auto* casterEntity = Game::entityManager->GetEntity(context->caster);
|
|
if (casterEntity != nullptr) {
|
|
auto* controllablePhysicsComponent = casterEntity->GetComponent<ControllablePhysicsComponent>();
|
|
if (controllablePhysicsComponent != nullptr) {
|
|
|
|
if (m_Forward == 1) {
|
|
controllablePhysicsComponent->SetVelocity(controllablePhysicsComponent->GetRotation().GetForwardVector() * 25);
|
|
}
|
|
|
|
Game::entityManager->SerializeEntity(casterEntity);
|
|
}
|
|
}
|
|
|
|
const auto skillHandle = context->GetUniqueSkillId();
|
|
bitStream->Write(skillHandle);
|
|
|
|
context->SyncCalculation(skillHandle, this->m_Duration, this, branch);
|
|
}
|
|
|
|
void ForceMovementBehavior::Load() {
|
|
this->m_hitAction = GetAction("hit_action");
|
|
this->m_hitEnemyAction = GetAction("hit_action_enemy");
|
|
this->m_hitFactionAction = GetAction("hit_action_faction");
|
|
this->m_Duration = GetFloat("duration");
|
|
this->m_Forward = GetFloat("forward");
|
|
this->m_Left = GetFloat("left");
|
|
this->m_Yaw = GetFloat("yaw");
|
|
}
|
|
|
|
void ForceMovementBehavior::SyncCalculation(BehaviorContext* context, RakNet::BitStream* bitStream, BehaviorBranchContext branch) {
|
|
auto* casterEntity = Game::entityManager->GetEntity(context->caster);
|
|
if (casterEntity != nullptr) {
|
|
auto* controllablePhysicsComponent = casterEntity->GetComponent<ControllablePhysicsComponent>();
|
|
if (controllablePhysicsComponent != nullptr) {
|
|
|
|
controllablePhysicsComponent->SetPosition(controllablePhysicsComponent->GetPosition() + controllablePhysicsComponent->GetVelocity() * m_Duration);
|
|
controllablePhysicsComponent->SetVelocity({});
|
|
|
|
Game::entityManager->SerializeEntity(casterEntity);
|
|
}
|
|
}
|
|
|
|
this->m_hitAction->Calculate(context, bitStream, branch);
|
|
this->m_hitEnemyAction->Calculate(context, bitStream, branch);
|
|
this->m_hitFactionAction->Calculate(context, bitStream, branch);
|
|
}
|