2021-12-05 17:54:36 +00:00
|
|
|
#ifndef BOUNCERCOMPONENT_H
|
|
|
|
#define BOUNCERCOMPONENT_H
|
|
|
|
|
|
|
|
#include "dCommonVars.h"
|
|
|
|
#include "RakNetTypes.h"
|
|
|
|
#include "Entity.h"
|
|
|
|
#include "Component.h"
|
2023-03-04 07:16:37 +00:00
|
|
|
#include "eReplicaComponentType.h"
|
2021-12-05 17:54:36 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Attached to bouncer entities, allowing other entities to bounce off of it
|
|
|
|
*/
|
|
|
|
class BouncerComponent : public Component {
|
|
|
|
public:
|
2023-10-23 01:08:49 +00:00
|
|
|
inline static const eReplicaComponentType ComponentType = eReplicaComponentType::BOUNCER;
|
2022-07-28 13:39:57 +00:00
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
BouncerComponent(Entity* parentEntity);
|
|
|
|
~BouncerComponent() override;
|
|
|
|
|
2023-08-10 21:33:15 +00:00
|
|
|
void Serialize(RakNet::BitStream* outBitStream, bool bIsInitialUpdate) override;
|
2021-12-05 17:54:36 +00:00
|
|
|
|
|
|
|
Entity* GetParentEntity() const;
|
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
/**
|
|
|
|
* Sets whether or not this bouncer needs to be activated by a pet
|
|
|
|
* @param value whether or not this bouncer needs to be activated by a pet
|
|
|
|
*/
|
2021-12-05 17:54:36 +00:00
|
|
|
void SetPetEnabled(bool value);
|
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
/**
|
|
|
|
* Sets whether or not this bouncer is currently being activated by a pet, allowing entities to bounce off of it,
|
|
|
|
* also displays FX accordingly.
|
|
|
|
* @param value whether or not this bouncer is activated by a pet
|
|
|
|
*/
|
2021-12-05 17:54:36 +00:00
|
|
|
void SetPetBouncerEnabled(bool value);
|
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
/**
|
|
|
|
* Gets whether this bouncer should be enabled using pets
|
|
|
|
* @return whether this bouncer should be enabled using pets
|
|
|
|
*/
|
2021-12-05 17:54:36 +00:00
|
|
|
bool GetPetEnabled() const;
|
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
/**
|
|
|
|
* Gets whether this bouncer is currently activated by a pet
|
|
|
|
* @return whether this bouncer is currently activated by a pet
|
|
|
|
*/
|
2021-12-05 17:54:36 +00:00
|
|
|
bool GetPetBouncerEnabled() const;
|
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
/**
|
|
|
|
* Finds the switch used to activate this bouncer if its pet-enabled and stores this components' state there
|
|
|
|
*/
|
2021-12-05 17:54:36 +00:00
|
|
|
void LookupPetSwitch();
|
|
|
|
|
|
|
|
private:
|
2022-07-28 13:39:57 +00:00
|
|
|
/**
|
|
|
|
* Whether this bouncer needs to be activated by a pet
|
|
|
|
*/
|
2021-12-05 17:54:36 +00:00
|
|
|
bool m_PetEnabled;
|
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
/**
|
|
|
|
* Whether this bouncer is currently being activated by a pet
|
|
|
|
*/
|
2021-12-05 17:54:36 +00:00
|
|
|
bool m_PetBouncerEnabled;
|
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
/**
|
|
|
|
* Whether the pet switch for this bouncer has been located
|
|
|
|
*/
|
2021-12-05 17:54:36 +00:00
|
|
|
bool m_PetSwitchLoaded;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // BOUNCERCOMPONENT_H
|