mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2024-11-26 23:47:21 +00:00
b261e63233
* chore: Change entity and component logic to use bitstream references * merge
49 lines
1.3 KiB
C++
49 lines
1.3 KiB
C++
#include "CarBoostBehavior.h"
|
|
#include "BehaviorBranchContext.h"
|
|
#include "GameMessages.h"
|
|
#include "EntityManager.h"
|
|
#include "BehaviorContext.h"
|
|
#include "CharacterComponent.h"
|
|
#include "Game.h"
|
|
#include "Logger.h"
|
|
#include "PossessableComponent.h"
|
|
|
|
void CarBoostBehavior::Handle(BehaviorContext* context, RakNet::BitStream& bitStream, BehaviorBranchContext branch) {
|
|
GameMessages::SendVehicleAddPassiveBoostAction(branch.target, UNASSIGNED_SYSTEM_ADDRESS);
|
|
|
|
auto* entity = Game::entityManager->GetEntity(context->originator);
|
|
|
|
if (entity == nullptr) {
|
|
return;
|
|
}
|
|
|
|
LOG("Activating car boost!");
|
|
|
|
auto* possessableComponent = entity->GetComponent<PossessableComponent>();
|
|
if (possessableComponent != nullptr) {
|
|
|
|
auto* possessor = Game::entityManager->GetEntity(possessableComponent->GetPossessor());
|
|
if (possessor != nullptr) {
|
|
|
|
auto* characterComponent = possessor->GetComponent<CharacterComponent>();
|
|
if (characterComponent != nullptr) {
|
|
LOG("Tracking car boost!");
|
|
characterComponent->UpdatePlayerStatistic(RacingCarBoostsActivated);
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
m_Action->Handle(context, bitStream, branch);
|
|
|
|
entity->AddCallbackTimer(m_Time, [entity]() {
|
|
GameMessages::SendVehicleRemovePassiveBoostAction(entity->GetObjectID(), UNASSIGNED_SYSTEM_ADDRESS);
|
|
});
|
|
}
|
|
|
|
void CarBoostBehavior::Load() {
|
|
m_Action = GetAction("action");
|
|
|
|
m_Time = GetFloat("time");
|
|
}
|