OGRE-Next  2.3
Object-Oriented Graphics Rendering Engine
Ogre::ParticleEmitterFactory Class Referenceabstract

Abstract class defining the interface to be implemented by creators of ParticleEmitter subclasses. More...

#include <OgreParticleEmitterFactory.h>

+ Inheritance diagram for Ogre::ParticleEmitterFactory:

Public Member Functions

 ParticleEmitterFactory ()
 
virtual ~ParticleEmitterFactory ()
 
virtual ParticleEmittercreateEmitter (ParticleSystem *psys)=0
 Creates a new emitter instance. More...
 
virtual void destroyEmitter (ParticleEmitter *e)
 Destroys the emitter pointed to by the parameter (for early clean up if required). More...
 
virtual String getName () const =0
 Returns the name of the factory, the name which identifies the particle emitter type this factory creates. More...
 
void operator delete (void *ptr)
 
void operator delete (void *ptr, const char *, int, const char *)
 
void operator delete (void *ptr, void *)
 
void operator delete[] (void *ptr)
 
void operator delete[] (void *ptr, const char *, int, const char *)
 
void * operator new (size_t sz)
 
void * operator new (size_t sz, const char *file, int line, const char *func)
 operator new, with debug line info More...
 
void * operator new (size_t sz, void *ptr)
 placement operator new More...
 
void * operator new[] (size_t sz)
 
void * operator new[] (size_t sz, const char *file, int line, const char *func)
 array operator new, with debug line info More...
 

Detailed Description

Abstract class defining the interface to be implemented by creators of ParticleEmitter subclasses.

Remarks
Plugins or 3rd party applications can add new types of particle emitters to Ogre by creating subclasses of the ParticleEmitter class. Because multiple instances of these emitters may be required, a factory class to manage the instances is also required.
ParticleEmitterFactory subclasses must allow the creation and destruction of ParticleEmitter subclasses. They must also be registered with the ParticleSystemManager. All factories have a name which identifies them, examples might be 'point', 'cone', or 'box', and these can be also be used from particle system scripts.

Constructor & Destructor Documentation

◆ ParticleEmitterFactory()

Ogre::ParticleEmitterFactory::ParticleEmitterFactory ( )
inline

◆ ~ParticleEmitterFactory()

virtual Ogre::ParticleEmitterFactory::~ParticleEmitterFactory ( )
virtual

Member Function Documentation

◆ createEmitter()

virtual ParticleEmitter* Ogre::ParticleEmitterFactory::createEmitter ( ParticleSystem psys)
pure virtual

Creates a new emitter instance.

Remarks
The subclass MUST add a pointer to the created instance to mEmitters.

Implemented in Ogre::RingEmitterFactory, Ogre::PointEmitterFactory, Ogre::HollowEllipsoidEmitterFactory, Ogre::EllipsoidEmitterFactory, Ogre::CylinderEmitterFactory, and Ogre::BoxEmitterFactory.

◆ destroyEmitter()

virtual void Ogre::ParticleEmitterFactory::destroyEmitter ( ParticleEmitter e)
virtual

Destroys the emitter pointed to by the parameter (for early clean up if required).

◆ getName()

virtual String Ogre::ParticleEmitterFactory::getName ( ) const
pure virtual

Returns the name of the factory, the name which identifies the particle emitter type this factory creates.

Implemented in Ogre::RingEmitterFactory, Ogre::PointEmitterFactory, Ogre::HollowEllipsoidEmitterFactory, Ogre::EllipsoidEmitterFactory, Ogre::CylinderEmitterFactory, and Ogre::BoxEmitterFactory.

◆ operator delete() [1/3]

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete ( void *  ptr)
inlineinherited

◆ operator delete() [2/3]

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete ( void *  ptr,
const char *  ,
int  ,
const char *   
)
inlineinherited

◆ operator delete() [3/3]

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete ( void *  ptr,
void *   
)
inlineinherited

◆ operator delete[]() [1/2]

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete[] ( void *  ptr)
inlineinherited

◆ operator delete[]() [2/2]

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete[] ( void *  ptr,
const char *  ,
int  ,
const char *   
)
inlineinherited

◆ operator new() [1/3]

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new ( size_t  sz)
inlineinherited

◆ operator new() [2/3]

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new ( size_t  sz,
const char *  file,
int  line,
const char *  func 
)
inlineinherited

operator new, with debug line info

◆ operator new() [3/3]

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new ( size_t  sz,
void *  ptr 
)
inlineinherited

placement operator new

◆ operator new[]() [1/2]

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new[] ( size_t  sz)
inlineinherited

◆ operator new[]() [2/2]

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new[] ( size_t  sz,
const char *  file,
int  line,
const char *  func 
)
inlineinherited

array operator new, with debug line info


The documentation for this class was generated from the following file: