2021-12-05 17:54:36 +00:00
|
|
|
#ifndef SWITCHCOMPONENT_H
|
|
|
|
#define SWITCHCOMPONENT_H
|
|
|
|
|
|
|
|
#include "RakNetTypes.h"
|
|
|
|
#include "Entity.h"
|
|
|
|
#include "GameMessages.h"
|
|
|
|
#include "EntityManager.h"
|
|
|
|
#include "RebuildComponent.h"
|
|
|
|
#include "BouncerComponent.h"
|
|
|
|
#include <algorithm>
|
|
|
|
#include "Component.h"
|
2023-03-04 07:16:37 +00:00
|
|
|
#include "eReplicaComponentType.h"
|
2021-12-05 17:54:36 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A component for switches in game, including pet triggered switches.
|
|
|
|
*/
|
|
|
|
class SwitchComponent : public Component {
|
|
|
|
public:
|
2023-10-23 01:08:49 +00:00
|
|
|
inline static const eReplicaComponentType ComponentType = eReplicaComponentType::SWITCH;
|
2022-07-28 13:39:57 +00:00
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
SwitchComponent(Entity* parent);
|
|
|
|
~SwitchComponent() override;
|
|
|
|
|
|
|
|
void Update(float deltaTime) override;
|
2022-07-28 13:39:57 +00:00
|
|
|
|
2023-11-18 01:29:42 +00:00
|
|
|
void OnUse(Entity* originator) override;
|
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
Entity* GetParentEntity() const;
|
|
|
|
|
2023-08-10 21:33:15 +00:00
|
|
|
void Serialize(RakNet::BitStream* outBitStream, bool bIsInitialUpdate) override;
|
2021-12-05 17:54:36 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets whether the switch is on or off.
|
|
|
|
* @param active whether the switch is on or off.
|
|
|
|
*/
|
|
|
|
void SetActive(bool active);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns whether the switch is on or off.
|
|
|
|
*/
|
|
|
|
bool GetActive() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the attached pet bouncer
|
|
|
|
* @param value the attached pet bouncer
|
|
|
|
*/
|
|
|
|
void SetPetBouncer(BouncerComponent* value);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the attached pet bouncer
|
|
|
|
*/
|
|
|
|
BouncerComponent* GetPetBouncer() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Invoked when a entity enters the trigger area.
|
|
|
|
*/
|
|
|
|
void EntityEnter(Entity* entity);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Invoked when a entity leaves the trigger area.
|
|
|
|
*/
|
|
|
|
void EntityLeave(Entity* entity);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the closest switch from a given position
|
|
|
|
* @param position the position to check
|
|
|
|
* @return the closest switch from a given position
|
|
|
|
*/
|
|
|
|
static SwitchComponent* GetClosestSwitch(NiPoint3 position);
|
|
|
|
|
|
|
|
private:
|
|
|
|
/**
|
|
|
|
* A list of all pet switches.
|
|
|
|
*/
|
|
|
|
static std::vector<SwitchComponent*> petSwitches;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Attached rebuild component.
|
|
|
|
*/
|
|
|
|
RebuildComponent* m_Rebuild;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* If the switch is on or off.
|
|
|
|
*/
|
|
|
|
bool m_Active;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The amount of entities in the trigger area.
|
|
|
|
*/
|
|
|
|
int m_EntitiesOnSwitch = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The switch reset time
|
|
|
|
*/
|
|
|
|
int m_ResetTime = INT_MAX;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Timer for resetting the switch
|
|
|
|
*/
|
|
|
|
float m_Timer = 0.0f;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Attached pet bouncer
|
|
|
|
*/
|
|
|
|
BouncerComponent* m_PetBouncer = nullptr;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // SWITCHCOMPONENT_H
|