156 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			156 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| ////////////////////////////////////////////////////////////
 | |
| //
 | |
| // SFML - Simple and Fast Multimedia Library
 | |
| // Copyright (C) 2007-2018 Laurent Gomila (laurent@sfml-dev.org)
 | |
| //
 | |
| // 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.
 | |
| //
 | |
| ////////////////////////////////////////////////////////////
 | |
| 
 | |
| 
 | |
| ////////////////////////////////////////////////////////////
 | |
| /// \brief Helper functions to copy sf::Transform to sf::Glsl::Mat3/4
 | |
| ///
 | |
| ////////////////////////////////////////////////////////////
 | |
| void SFML_GRAPHICS_API copyMatrix(const Transform& source, Matrix<3, 3>& dest);
 | |
| void SFML_GRAPHICS_API copyMatrix(const Transform& source, Matrix<4, 4>& dest);
 | |
| 
 | |
| ////////////////////////////////////////////////////////////
 | |
| /// \brief Copy array-based matrix with given number of elements
 | |
| ///
 | |
| /// Indirection to std::copy() to avoid inclusion of
 | |
| /// <algorithm> and MSVC's annoying 4996 warning in header
 | |
| ///
 | |
| ////////////////////////////////////////////////////////////
 | |
| void SFML_GRAPHICS_API copyMatrix(const float* source, std::size_t elements, float* dest);
 | |
| 
 | |
| ////////////////////////////////////////////////////////////
 | |
| /// \brief Helper functions to copy sf::Color to sf::Glsl::Vec4/Ivec4
 | |
| ///
 | |
| ////////////////////////////////////////////////////////////
 | |
| void SFML_GRAPHICS_API copyVector(const Color& source, Vector4<float>& dest);
 | |
| void SFML_GRAPHICS_API copyVector(const Color& source, Vector4<int>& dest);
 | |
| 
 | |
| 
 | |
| ////////////////////////////////////////////////////////////
 | |
| /// \brief Matrix type, used to set uniforms in GLSL
 | |
| ///
 | |
| ////////////////////////////////////////////////////////////
 | |
| template <std::size_t Columns, std::size_t Rows>
 | |
| struct Matrix
 | |
| {
 | |
|     ////////////////////////////////////////////////////////////
 | |
|     /// \brief Construct from raw data
 | |
|     ///
 | |
|     /// \param pointer Points to the beginning of an array that
 | |
|     ///                has the size of the matrix. The elements
 | |
|     ///                are copied to the instance.
 | |
|     ///
 | |
|     ////////////////////////////////////////////////////////////
 | |
|     explicit Matrix(const float* pointer)
 | |
|     {
 | |
|         copyMatrix(pointer, Columns * Rows, array);
 | |
|     }
 | |
| 
 | |
|     ////////////////////////////////////////////////////////////
 | |
|     /// \brief Construct implicitly from SFML transform
 | |
|     ///
 | |
|     /// This constructor is only supported for 3x3 and 4x4
 | |
|     /// matrices.
 | |
|     ///
 | |
|     /// \param transform Object containing a transform.
 | |
|     ///
 | |
|     ////////////////////////////////////////////////////////////
 | |
|     Matrix(const Transform& transform)
 | |
|     {
 | |
|         copyMatrix(transform, *this);
 | |
|     }
 | |
| 
 | |
|     float array[Columns * Rows]; ///< Array holding matrix data
 | |
| };
 | |
| 
 | |
| ////////////////////////////////////////////////////////////
 | |
| /// \brief 4D vector type, used to set uniforms in GLSL
 | |
| ///
 | |
| ////////////////////////////////////////////////////////////
 | |
| template <typename T>
 | |
| struct Vector4
 | |
| {
 | |
|     ////////////////////////////////////////////////////////////
 | |
|     /// \brief Default constructor, creates a zero vector
 | |
|     ///
 | |
|     ////////////////////////////////////////////////////////////
 | |
|     Vector4() :
 | |
|     x(0),
 | |
|     y(0),
 | |
|     z(0),
 | |
|     w(0)
 | |
|     {
 | |
|     }
 | |
| 
 | |
|     ////////////////////////////////////////////////////////////
 | |
|     /// \brief Construct from 4 vector components
 | |
|     ///
 | |
|     /// \param X Component of the 4D vector
 | |
|     /// \param Y Component of the 4D vector
 | |
|     /// \param Z Component of the 4D vector
 | |
|     /// \param W Component of the 4D vector
 | |
|     ///
 | |
|     ////////////////////////////////////////////////////////////
 | |
|     Vector4(T X, T Y, T Z, T W) :
 | |
|     x(X),
 | |
|     y(Y),
 | |
|     z(Z),
 | |
|     w(W)
 | |
|     {
 | |
|     }
 | |
| 
 | |
|     ////////////////////////////////////////////////////////////
 | |
|     /// \brief Conversion constructor
 | |
|     ///
 | |
|     /// \param other 4D vector of different type
 | |
|     ///
 | |
|     ////////////////////////////////////////////////////////////
 | |
|     template <typename U>
 | |
|     explicit Vector4(const Vector4<U>& other) :
 | |
|     x(static_cast<T>(other.x)),
 | |
|     y(static_cast<T>(other.y)),
 | |
|     z(static_cast<T>(other.z)),
 | |
|     w(static_cast<T>(other.w))
 | |
|     {
 | |
|     }
 | |
| 
 | |
|     ////////////////////////////////////////////////////////////
 | |
|     /// \brief Construct float vector implicitly from color
 | |
|     ///
 | |
|     /// \param color Color instance. Is normalized to [0, 1]
 | |
|     ///              for floats, and left as-is for ints.
 | |
|     ///
 | |
|     ////////////////////////////////////////////////////////////
 | |
|     Vector4(const Color& color)
 | |
|     // uninitialized
 | |
|     {
 | |
|         copyVector(color, *this);
 | |
|     }
 | |
| 
 | |
|     T x; ///< 1st component (X) of the 4D vector
 | |
|     T y; ///< 2nd component (Y) of the 4D vector
 | |
|     T z; ///< 3rd component (Z) of the 4D vector
 | |
|     T w; ///< 4th component (W) of the 4D vector
 | |
| };
 |