Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: downloads/PlugIns/ParticleFX/src/OgrePointEmitter.cpp @ 1

Last change on this file since 1 was 1, checked in by landauf, 17 years ago
File size: 2.7 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 (c) 2000-2006 Torus Knot Software Ltd
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#include "OgrePointEmitter.h"
30#include "OgreParticle.h"
31
32
33
34namespace Ogre {
35
36    //-----------------------------------------------------------------------
37    PointEmitter::PointEmitter(ParticleSystem* psys)
38        :ParticleEmitter(psys)
39    {
40        mType = "Point";
41        // Set up parameters
42        if (createParamDictionary("PointEmitter"))
43        {
44            addBaseParameters();
45        }
46        // No custom parameters
47    }
48    //-----------------------------------------------------------------------
49    void PointEmitter::_initParticle(Particle* pParticle)
50    {
51        // Very simple emitter, uses default implementations with no modification
52
53        // Call superclass
54        ParticleEmitter::_initParticle(pParticle);
55
56        // Point emitter emits from own position
57        pParticle->position = mPosition;
58
59        // Generate complex data by reference
60        genEmissionColour(pParticle->colour);
61        genEmissionDirection(pParticle->direction);
62        genEmissionVelocity(pParticle->direction);
63
64        // Generate simpler data
65        pParticle->timeToLive = pParticle->totalTimeToLive = genEmissionTTL();
66       
67    }
68    //-----------------------------------------------------------------------
69    unsigned short PointEmitter::_getEmissionCount(Real timeElapsed)
70    {
71        // Use basic constant emission
72        return genConstantEmissionCount(timeElapsed);
73    }
74}
75
76
Note: See TracBrowser for help on using the repository browser.