123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- /****************************************************************************
- Copyright (C) 2013 Henry van Merode. All rights reserved.
- Copyright (c) 2015-2016 Chukong Technologies Inc.
- Copyright (c) 2017-2018 Xiamen Yaji Software Co., Ltd.
-
- http://www.cocos2d-x.org
-
- Permission is hereby granted, free of charge, to any person obtaining a copy
- of this software and associated documentation files (the "Software"), to deal
- in the Software without restriction, including without limitation the rights
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- copies of the Software, and to permit persons to whom the Software is
- furnished to do so, subject to the following conditions:
-
- The above copyright notice and this permission notice shall be included in
- all copies or substantial portions of the Software.
-
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- THE SOFTWARE.
- ****************************************************************************/
- #ifndef __CC_PU_PARTICLE_3D_LINE_EMITTER_H__
- #define __CC_PU_PARTICLE_3D_LINE_EMITTER_H__
- #include "extensions/Particle3D/PU/CCPUEmitter.h"
- NS_CC_BEGIN
- struct PUParticle3D;
- class CC_DLL PULineEmitter : public PUEmitter
- {
- public:
- // Constants
- static const Vec3 DEFAULT_END;
- static const float DEFAULT_MIN_INCREMENT;
- static const float DEFAULT_MAX_INCREMENT;
- static const float DEFAULT_MAX_DEVIATION;
- static PULineEmitter* create();
- /**
- */
- virtual void notifyStart (void) override;
- /** Override the default implementation, to allow that no particles are emitted if there
- is an incremental emission of particles (along a path), and the end of the line has
- been reached.
- */
- virtual unsigned short calculateRequestedParticles(float timeElapsed) override;
- /**
- */
- float getMaxDeviation(void) const;
- void setMaxDeviation(float maxDeviation);
- /**
- */
- float getMaxIncrement(void) const;
- void setMaxIncrement(float maxIncrement);
-
- /**
- */
- float getMinIncrement(void) const;
- void setMinIncrement(float minIncrement);
-
- /** Get the end vector. This is the vector that defines the end of the line (in local space).
- */
- const Vec3& getEnd(void) const;
- /** Set the end vector.
- */
- void setEnd(const Vec3& end);
- /**
- */
- virtual void notifyRescaled(const Vec3& scale) override;
- /**
- */
- virtual void initParticlePosition(PUParticle3D* particle) override;
- /**
- */
- virtual void initParticleDirection(PUParticle3D* particle) override;
- virtual PULineEmitter* clone() override;
- virtual void copyAttributesTo (PUEmitter* emitter) override;
- CC_CONSTRUCTOR_ACCESS:
- PULineEmitter(void);
- virtual ~PULineEmitter(void) {};
- protected:
- Vec3 _end; // End point of the line (startpoint is determined by means of position)
- Vec3 _perpendicular; // Generated unit vector perpendicular on the line
- float _maxDeviation; // Determines how far from the line a particle is emitted.
- // This attribute defines the maximum value.
- float _minIncrement; // Defines the minimum increment value.
- float _maxIncrement; // If > 0, it defines the maximum (random) increment value that is
- // taken on the line traject. If not set, there is no particular
- // order in particle generation.
- float _increment; // Defines the trajectory path along the line in terms of increments
- float _length; // The length of the line
- bool _incrementsLeft; // Indicates whether there are more increments on the path towards the end
- // of the line.
- bool _first; // True when the first particle is emitted (only for generating particles incremental)
- // Internal scaled values
- Vec3 _scaledEnd;
- float _scaledMaxDeviation;
- float _scaledMinIncrement;
- float _scaledMaxIncrement;
- float _scaledLength;
- };
- NS_CC_END
- #endif
|