164 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			164 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //////////////////////////////////////////////////////////////////////////////////
 | |
| // SPARK particle engine														//
 | |
| // Copyright (C) 2008-2009 - Julien Fryer - julienfryer@gmail.com				//
 | |
| //																				//
 | |
| // This software is provided 'as-is', without any express or implied			//
 | |
| // warranty.  In no event will the authors be held liable for any damages		//
 | |
| // arising from the use of this software.										//
 | |
| //																				//
 | |
| // Permission is granted to anyone to use this software for any purpose,		//
 | |
| // including commercial applications, and to alter it and redistribute it		//
 | |
| // freely, subject to the following restrictions:								//
 | |
| //																				//
 | |
| // 1. The origin of this software must not be misrepresented; you must not		//
 | |
| //    claim that you wrote the original software. If you use this software		//
 | |
| //    in a product, an acknowledgment in the product documentation would be		//
 | |
| //    appreciated but is not required.											//
 | |
| // 2. Altered source versions must be plainly marked as such, and must not be	//
 | |
| //    misrepresented as being the original software.							//
 | |
| // 3. This notice may not be removed or altered from any source distribution.	//
 | |
| //////////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| 
 | |
| #ifndef H_SPK_PLANE
 | |
| #define H_SPK_PLANE
 | |
| 
 | |
| #include "Core/SPK_Zone.h"
 | |
| #include "Core/SPK_Particle.h"
 | |
| 
 | |
| namespace SPK
 | |
| {
 | |
| 	/**
 | |
| 	* @class Plane
 | |
| 	* @brief A Zone defining a plane in the universe
 | |
| 	*
 | |
| 	* A Plane is defined by 2 parameters :
 | |
| 	* <ul>
 | |
| 	* <li>A Position is the universe</li>
 | |
| 	* <li>A Normal</li>
 | |
| 	* </ul>
 | |
| 	* The defined Plane is the Plane having the normal and passing by the position.<br>
 | |
| 	* The direction of the normal defines the sens of the plane. The normal goes from inside the Plane to outside.<br>
 | |
| 	* <br>
 | |
| 	* Note that the normal does not have to be normalized as it is normalized internally when set.
 | |
| 	*/
 | |
| 	class SPK_PREFIX Plane : public Zone
 | |
| 	{
 | |
| 		SPK_IMPLEMENT_REGISTERABLE(Plane)
 | |
| 
 | |
| 	public :
 | |
| 
 | |
| 		//////////////////
 | |
| 		// Constructors //
 | |
| 		//////////////////
 | |
| 
 | |
| 		/**
 | |
| 		* @brief Constructor of Plane
 | |
| 		* @param position : the position of the Plane
 | |
| 		* @param normal : the normal of the Plane
 | |
| 		*/
 | |
| 		Plane(const Vector3D& position = Vector3D(0.0f,0.0f,0.0f),const Vector3D& normal = Vector3D(0.0f,1.0f,0.0f));
 | |
| 
 | |
| 		/**
 | |
| 		* @brief Creates and registers a new Plane
 | |
| 		* @param position : the position of the Plane
 | |
| 		* @param normal : the normal of the Plane
 | |
| 		* @return a new registered plane
 | |
| 		* @since 1.04.00
 | |
| 		*/
 | |
| 		static inline Plane* create(const Vector3D& position = Vector3D(0.0f,0.0f,0.0f),const Vector3D& normal = Vector3D(0.0f,1.0f,0.0f));
 | |
| 
 | |
| 		/////////////
 | |
| 		// Setters //
 | |
| 		/////////////
 | |
| 
 | |
| 		/**
 | |
| 		* @brief Sets the normal of this Plane
 | |
| 		*
 | |
| 		* Note that the normal is normalized internally.
 | |
| 		*
 | |
| 		* @param normal :  the normal of this Plane
 | |
| 		*/
 | |
| 		inline void setNormal(const Vector3D& normal);
 | |
| 
 | |
| 		/////////////
 | |
| 		// Getters //
 | |
| 		/////////////
 | |
| 
 | |
| 		/**
 | |
| 		* @brief Gets the normal of this Plane
 | |
| 		* @return the normal of this Plane
 | |
| 		*/
 | |
| 		inline const Vector3D& getNormal() const;
 | |
| 
 | |
| 		/**
 | |
| 		* @brief Gets the transformed normal of this Plane
 | |
| 		* @return the transformed normal of this Plane
 | |
| 		* @since 1.05.00
 | |
| 		*/
 | |
| 		inline const Vector3D& getTransformedNormal() const;
 | |
| 
 | |
| 		///////////////
 | |
| 		// Interface //
 | |
| 		///////////////
 | |
| 
 | |
| 		virtual inline void generatePosition(Particle& particle,bool full) const;
 | |
| 		virtual inline bool contains(const Vector3D& v) const;
 | |
| 		virtual bool intersects(const Vector3D& v0,const Vector3D& v1,Vector3D* intersection,Vector3D* normal) const;
 | |
| 		virtual void moveAtBorder(Vector3D& v,bool inside) const;
 | |
| 		virtual inline Vector3D computeNormal(const Vector3D& point) const;
 | |
| 
 | |
| 	protected :
 | |
| 
 | |
| 		virtual void innerUpdateTransform();
 | |
| 
 | |
| 	private :
 | |
| 
 | |
| 		Vector3D normal;
 | |
| 		Vector3D tNormal;
 | |
| 	};
 | |
| 
 | |
| 
 | |
| 	inline Plane* Plane::create(const Vector3D& position,const Vector3D& normal)
 | |
| 	{
 | |
| 		Plane* obj = new Plane(position,normal);
 | |
| 		registerObject(obj);
 | |
| 		return obj;
 | |
| 	}
 | |
| 		
 | |
| 	inline void Plane::setNormal(const Vector3D& normal)
 | |
| 	{
 | |
| 		this->normal = normal;
 | |
| 		this->normal.normalize();
 | |
| 		tNormal = this->normal;
 | |
| 		notifyForUpdate();
 | |
| 	}
 | |
| 
 | |
| 	inline const Vector3D& Plane::getNormal() const
 | |
| 	{
 | |
| 		return normal;
 | |
| 	}
 | |
| 
 | |
| 	inline const Vector3D& Plane::getTransformedNormal() const
 | |
| 	{
 | |
| 		return tNormal;
 | |
| 	}
 | |
| 
 | |
| 	inline void Plane::generatePosition(Particle& particle,bool full) const
 | |
| 	{
 | |
| 		particle.position() = getTransformedPosition();
 | |
| 	}
 | |
| 
 | |
| 	inline bool Plane::contains(const Vector3D& v) const
 | |
| 	{
 | |
| 		return dotProduct(normal,v - getTransformedPosition()) <= 0.0f;
 | |
| 	}
 | |
| 
 | |
| 	inline Vector3D Plane::computeNormal(const Vector3D& point) const
 | |
| 	{
 | |
| 		return tNormal;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| #endif
 | 
