2007-05-20 18:03:49 +00:00
|
|
|
// Copyright (C) 2002-2007 Nikolaus Gebhardt
|
|
|
|
// This file is part of the "Irrlicht Engine".
|
|
|
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
|
|
|
|
|
|
|
#ifndef __I_PARTICLE_EMITTER_H_INCLUDED__
|
|
|
|
#define __I_PARTICLE_EMITTER_H_INCLUDED__
|
|
|
|
|
|
|
|
#include "IAttributeExchangingObject.h"
|
|
|
|
#include "SParticle.h"
|
|
|
|
|
|
|
|
namespace irr
|
|
|
|
{
|
|
|
|
namespace scene
|
|
|
|
{
|
|
|
|
|
|
|
|
//! Types of built in particle emitters
|
|
|
|
enum E_PARTICLE_EMITTER_TYPE
|
|
|
|
{
|
|
|
|
EPET_POINT = 0,
|
2007-08-29 23:03:08 +00:00
|
|
|
EPET_ANIMATED_MESH,
|
2007-05-20 18:03:49 +00:00
|
|
|
EPET_BOX,
|
2007-08-29 23:03:08 +00:00
|
|
|
EPET_CYLINDER,
|
|
|
|
EPET_MESH,
|
|
|
|
EPET_RING,
|
|
|
|
EPET_SPHERE,
|
2007-05-20 18:03:49 +00:00
|
|
|
EPET_COUNT
|
|
|
|
};
|
|
|
|
|
|
|
|
//! Names for built in particle emitters
|
2007-08-29 16:13:38 +00:00
|
|
|
const c8* const ParticleEmitterTypeNames[] =
|
2007-05-20 18:03:49 +00:00
|
|
|
{
|
|
|
|
"Point",
|
2007-08-29 23:03:08 +00:00
|
|
|
"AnimatedMesh",
|
2007-05-20 18:03:49 +00:00
|
|
|
"Box",
|
2007-08-29 23:03:08 +00:00
|
|
|
"Cylinder",
|
|
|
|
"Mesh",
|
|
|
|
"Ring",
|
|
|
|
"Sphere",
|
2007-05-20 18:03:49 +00:00
|
|
|
0
|
|
|
|
};
|
|
|
|
|
|
|
|
//! A particle emitter for using with particle systems.
|
|
|
|
/** A Particle emitter emitts new particles into a particle system.
|
|
|
|
*/
|
|
|
|
class IParticleEmitter : public virtual io::IAttributeExchangingObject
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
//! destructor
|
|
|
|
virtual ~IParticleEmitter() {};
|
|
|
|
|
|
|
|
//! Prepares an array with new particles to emitt into the system
|
|
|
|
//! and returns how much new particles there are.
|
|
|
|
//! \param now: Current time.
|
|
|
|
//! \param timeSinceLastCall: Time elapsed since last call, in milliseconds.
|
2007-08-29 16:13:38 +00:00
|
|
|
//! \param outArray: Pointer which will point to the array with the new
|
2007-05-20 18:03:49 +00:00
|
|
|
//! particles to add into the system.
|
|
|
|
//! \return Returns amount of new particles in the array. Can be 0.
|
|
|
|
virtual s32 emitt(u32 now, u32 timeSinceLastCall, SParticle*& outArray) = 0;
|
|
|
|
|
2007-08-29 16:13:38 +00:00
|
|
|
//! Set direction the emitter emits particles
|
|
|
|
virtual void setDirection( const core::vector3df& newDirection ) = 0;
|
|
|
|
|
|
|
|
//! Set minimum number of particles the emitter emits per second
|
|
|
|
virtual void setMinParticlesPerSecond( u32 minPPS ) = 0;
|
|
|
|
|
|
|
|
//! Set maximum number of particles the emitter emits per second
|
|
|
|
virtual void setMaxParticlesPerSecond( u32 maxPPS ) = 0;
|
|
|
|
|
|
|
|
//! Set minimum starting color for particles
|
|
|
|
virtual void setMinStartColor( const video::SColor& color ) = 0;
|
|
|
|
|
|
|
|
//! Set maximum starting color for particles
|
|
|
|
virtual void setMaxStartColor( const video::SColor& color ) = 0;
|
|
|
|
|
|
|
|
//! Get direction the emitter emits particles
|
|
|
|
virtual const core::vector3df& getDirection() const = 0;
|
|
|
|
|
|
|
|
//! Get the minimum number of particles the emitter emits per second
|
|
|
|
virtual u32 getMinParticlesPerSecond() const = 0;
|
|
|
|
|
|
|
|
//! Get the maximum number of particles the emitter emits per second
|
|
|
|
virtual u32 getMaxParticlesPerSecond() const = 0;
|
|
|
|
|
|
|
|
//! Get the minimum starting color for particles
|
|
|
|
virtual const video::SColor& getMinStartColor() const = 0;
|
|
|
|
|
|
|
|
//! Get the maximum starting color for particles
|
|
|
|
virtual const video::SColor& getMaxStartColor() const = 0;
|
|
|
|
|
2007-05-20 18:03:49 +00:00
|
|
|
//! Writes attributes of the object.
|
2007-08-29 16:13:38 +00:00
|
|
|
//! Implement this to expose the attributes of your scene node animator for
|
2007-05-20 18:03:49 +00:00
|
|
|
//! scripting languages, editors, debuggers or xml serialization purposes.
|
2007-09-14 22:25:59 +00:00
|
|
|
virtual void serializeAttributes(io::IAttributes* out, io::SAttributeReadWriteOptions* options=0) const {}
|
2007-05-20 18:03:49 +00:00
|
|
|
|
|
|
|
//! Reads attributes of the object.
|
2007-08-29 16:13:38 +00:00
|
|
|
//! Implement this to set the attributes of your scene node animator for
|
2007-05-20 18:03:49 +00:00
|
|
|
//! scripting languages, editors, debuggers or xml deserialization purposes.
|
|
|
|
//! \param startIndex: start index where to start reading attributes.
|
|
|
|
//! \param in: The attributes to work with.
|
|
|
|
//! \param options: Additional options.
|
|
|
|
//! \return: returns last index of an attribute read by this affector
|
|
|
|
virtual s32 deserializeAttributes(s32 startIndex, io::IAttributes* in, io::SAttributeReadWriteOptions* options=0) { return 0; }
|
|
|
|
|
|
|
|
//! Get emitter type
|
2007-08-29 16:13:38 +00:00
|
|
|
virtual E_PARTICLE_EMITTER_TYPE getType() const { return EPET_POINT; }
|
2007-05-20 18:03:49 +00:00
|
|
|
};
|
|
|
|
|
2007-08-29 16:13:38 +00:00
|
|
|
typedef IParticleEmitter IParticlePointEmitter;
|
|
|
|
|
2007-05-20 18:03:49 +00:00
|
|
|
} // end namespace scene
|
|
|
|
} // end namespace irr
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|