Sdk/ParticleEmitterComponent: Update emitter (they are no longer attached to groups)
They are no longer attached to groups, groups attach emitters Former-commit-id: 9a586151ac4ce932cda5d6c36c3e40718aef7f2c [formerly 830dd96bb020bec7dc7b652acca43fdef2d01971] [formerly 26cf67777c40ca4a6bcc0643a8dea76d46debd30 [formerly d4d7e62390be2a4d44b5a67c5fbabc11aa080de5]] Former-commit-id: 653b321e01aa182a3dcb0531319cb9a053aadfa8 [formerly c4e742f3aab61f0941729a5739a80a838c6163cd] Former-commit-id: 6572d614b19d85cbc0844745c45c3bc92deef051
This commit is contained in:
parent
218dfc9bb1
commit
8f61e2f278
|
|
@ -19,28 +19,23 @@ namespace Ndk
|
||||||
public:
|
public:
|
||||||
using SetupFunc = std::function<void(const EntityHandle& /*entity*/, Nz::ParticleMapper& /*mapper*/, unsigned int /*count*/)>;
|
using SetupFunc = std::function<void(const EntityHandle& /*entity*/, Nz::ParticleMapper& /*mapper*/, unsigned int /*count*/)>;
|
||||||
|
|
||||||
ParticleEmitterComponent(Nz::ParticleGroup* group);
|
inline ParticleEmitterComponent();
|
||||||
ParticleEmitterComponent(const ParticleEmitterComponent& emitter);
|
ParticleEmitterComponent(const ParticleEmitterComponent& emitter) = default;
|
||||||
ParticleEmitterComponent(ParticleEmitterComponent&& emitter);
|
ParticleEmitterComponent(ParticleEmitterComponent&& emitter) = default;
|
||||||
~ParticleEmitterComponent();
|
~ParticleEmitterComponent() = default;
|
||||||
|
|
||||||
|
void Enable(bool active = true);
|
||||||
|
|
||||||
inline bool IsActive() const;
|
inline bool IsActive() const;
|
||||||
|
|
||||||
void SetActive(bool active = true);
|
|
||||||
void SetGroup(Nz::ParticleGroup* group);
|
|
||||||
inline void SetSetupFunc(SetupFunc func);
|
inline void SetSetupFunc(SetupFunc func);
|
||||||
|
|
||||||
static ComponentIndex componentIndex;
|
static ComponentIndex componentIndex;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void OnParticleGroupRelease(const Nz::ParticleGroup* particleGroup);
|
|
||||||
|
|
||||||
void SetupParticles(Nz::ParticleMapper& mapper, unsigned int count) const override;
|
void SetupParticles(Nz::ParticleMapper& mapper, unsigned int count) const override;
|
||||||
|
|
||||||
NazaraSlot(Nz::ParticleGroup, OnParticleGroupRelease, m_particleGroupRelease);
|
|
||||||
|
|
||||||
SetupFunc m_setupFunc;
|
SetupFunc m_setupFunc;
|
||||||
Nz::ParticleGroup* m_particleGroup;
|
|
||||||
bool m_isActive;
|
bool m_isActive;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,16 @@
|
||||||
|
|
||||||
namespace Ndk
|
namespace Ndk
|
||||||
{
|
{
|
||||||
|
inline ParticleEmitterComponent::ParticleEmitterComponent() :
|
||||||
|
m_isActive(true)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void Ndk::ParticleEmitterComponent::Enable(bool active)
|
||||||
|
{
|
||||||
|
m_isActive = active;
|
||||||
|
}
|
||||||
|
|
||||||
inline bool ParticleEmitterComponent::IsActive() const
|
inline bool ParticleEmitterComponent::IsActive() const
|
||||||
{
|
{
|
||||||
return m_isActive;
|
return m_isActive;
|
||||||
|
|
|
||||||
|
|
@ -7,51 +7,9 @@
|
||||||
|
|
||||||
namespace Ndk
|
namespace Ndk
|
||||||
{
|
{
|
||||||
ParticleEmitterComponent::ParticleEmitterComponent(Nz::ParticleGroup* group) :
|
void ParticleEmitterComponent::SetupParticles(Nz::ParticleMapper& mapper, unsigned int count) const
|
||||||
m_particleGroup(group),
|
|
||||||
m_isActive(true)
|
|
||||||
{
|
{
|
||||||
if (m_particleGroup)
|
if (m_isActive && m_setupFunc)
|
||||||
m_particleGroup->AddEmitter(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
ParticleEmitterComponent::ParticleEmitterComponent(const ParticleEmitterComponent& emitter) :
|
|
||||||
m_particleGroup(emitter.m_particleGroup),
|
|
||||||
m_isActive(emitter.m_isActive)
|
|
||||||
{
|
|
||||||
if (m_isActive)
|
|
||||||
m_particleGroup->AddEmitter(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
ParticleEmitterComponent::~ParticleEmitterComponent()
|
|
||||||
{
|
|
||||||
m_particleGroup->RemoveEmitter(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void Ndk::ParticleEmitterComponent::SetActive(bool active)
|
|
||||||
{
|
|
||||||
if (m_isActive != active)
|
|
||||||
{
|
|
||||||
if (active)
|
|
||||||
m_particleGroup->AddEmitter(this);
|
|
||||||
else
|
|
||||||
m_particleGroup->RemoveEmitter(this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void ParticleEmitterComponent::SetGroup(Nz::ParticleGroup* group)
|
|
||||||
{
|
|
||||||
if (m_particleGroup)
|
|
||||||
m_particleGroup->RemoveEmitter(this);
|
|
||||||
|
|
||||||
m_particleGroup = group;
|
|
||||||
if (m_particleGroup && m_isActive)
|
|
||||||
m_particleGroup = group;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void ParticleEmitterComponent::SetupParticles(Nz::ParticleMapper& mapper, unsigned int count) const
|
|
||||||
{
|
|
||||||
if (m_setupFunc)
|
|
||||||
m_setupFunc(m_entity, mapper, count);
|
m_setupFunc(m_entity, mapper, count);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue