Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: downloads/PlugIns/ParticleFX/include/OgreHollowEllipsoidEmitter.h @ 3

Last change on this file since 3 was 3, checked in by anonymous, 17 years ago

=update

File size: 4.9 KB
Line 
1/*
2-----------------------------------------------------------------------------
3This source file is part of OGRE
4    (Object-oriented Graphics Rendering Engine)
5For the latest info, see http://www.ogre3d.org/
6
7Copyright ) 2002 Tels <http://bloodgate.com> based on BoxEmitter
8Also see acknowledgements in Readme.html
9
10This program is free software; you can redistribute it and/or modify it under
11the terms of the GNU Lesser General Public License as published by the Free Software
12Foundation; either version 2 of the License, or (at your option) any later
13version.
14
15This program is distributed in the hope that it will be useful, but WITHOUT
16ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
17FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
18
19You should have received a copy of the GNU Lesser General Public License along with
20this program; if not, write to the Free Software Foundation, Inc., 59 Temple
21Place - Suite 330, Boston, MA 02111-1307, USA, or go to
22http://www.gnu.org/copyleft/lesser.txt.
23
24You may alternatively use this source under the terms of a specific version of
25the OGRE Unrestricted License provided you have obtained such a license from
26Torus Knot Software Ltd.
27-----------------------------------------------------------------------------
28*/
29#ifndef __HollowEllipsoidEmitter_H__
30#define __HollowEllipsoidEmitter_H__
31
32#include "OgreParticleFXPrerequisites.h"
33#include "OgreEllipsoidEmitter.h"
34
35namespace Ogre {
36
37    /** Particle emitter which emits particles randomly from points inside a hollow ellipsoid.
38    @remarks
39        This particle emitter emits particles from a hollow ellipsoid area.
40        The initial direction of these particles can either be a single
41        direction (i.e. a line), a random scattering inside a cone, or a random
42        scattering in all directions, depending the 'angle' parameter, which
43        is the angle across which to scatter the particles either side of the
44        base direction of the emitter.
45    */
46    class _OgreParticleFXExport HollowEllipsoidEmitter : public EllipsoidEmitter
47    {
48    public:
49        /** Command object for inner size (see ParamCommand).*/
50        class CmdInnerX : public ParamCommand
51        {
52        public:
53            String doGet(const void* target) const;
54            void doSet(void* target, const String& val);
55        };
56        /** Command object for inner size (see ParamCommand).*/
57        class CmdInnerY : public ParamCommand
58        {
59        public:
60            String doGet(const void* target) const;
61            void doSet(void* target, const String& val);
62        };
63        /** Command object for inner size (see ParamCommand).*/
64        class CmdInnerZ : public ParamCommand
65        {
66        public:
67            String doGet(const void* target) const;
68            void doSet(void* target, const String& val);
69        };
70        // See AreaEmitter
71
72        HollowEllipsoidEmitter(ParticleSystem* psys);
73
74        /** See ParticleEmitter. */
75        void _initParticle(Particle* pParticle);
76
77        /** Sets the size of the clear space inside the area from where NO particles are emitted.
78        @param x,y,z
79            Parametric values describing the proportion of the shape which is hollow in each direction.
80            E.g. 0 is solid, 0.5 is half-hollow etc
81        */
82        void setInnerSize(Real x, Real y, Real z);
83
84        /** Sets the x component of the area inside the ellipsoid which doesn't emit particles.
85        @param x
86            Parametric value describing the proportion of the shape which is hollow in this direction.
87            E.g. 0 is solid, 0.5 is half-hollow etc
88        */
89        void setInnerSizeX(Real x);
90        /** Sets the y component of the area inside the ellipsoid which doesn't emit particles.
91        @param y
92            Parametric value describing the proportion of the shape which is hollow in this direction.
93            E.g. 0 is solid, 0.5 is half-hollow etc
94        */
95        void setInnerSizeY(Real y);
96        /** Sets the z component of the area inside the ellipsoid which doesn't emit particles.
97        @param z
98            Parametric value describing the proportion of the shape which is hollow in this direction.
99            E.g. 0 is solid, 0.5 is half-hollow etc
100        */
101        void setInnerSizeZ(Real z);
102        /** Gets the x component of the area inside the ellipsoid which doesn't emit particles. */
103        Real getInnerSizeX(void) const;
104        /** Gets the y component of the area inside the ellipsoid which doesn't emit particles. */
105        Real getInnerSizeY(void) const;
106        /** Gets the z component of the area inside the ellipsoid which doesn't emit particles. */
107        Real getInnerSizeZ(void) const;
108
109    protected:
110        // See ParticleEmitter
111
112        /// Size of 'clear' center area (> 0 and < 1.0)
113        Vector3 mInnerSize;
114
115        static CmdInnerX msCmdInnerX;
116        static CmdInnerY msCmdInnerY;
117        static CmdInnerZ msCmdInnerZ;
118
119
120
121    };
122
123}
124
125#endif
126
Note: See TracBrowser for help on using the repository browser.