#ifndef Magnum_Math_Vector3_h #define Magnum_Math_Vector3_h /* Copyright © 2010, 2011, 2012 Vladimír Vondruš This file is part of Magnum. Magnum is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License version 3 only, as published by the Free Software Foundation. Magnum is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License version 3 for more details. */ /** @file * @brief Class Magnum::Math::Vector3 */ #include "Vector2.h" namespace Magnum { namespace Math { /** @brief Three-component vector */ template class Vector3: public Vector<3, T> { public: /** @brief %Vector in direction of X axis */ inline constexpr static Vector3 xAxis(T length = T(1)) { return Vector3(length, T(), T()); } /** @brief %Vector in direction of Y axis */ inline constexpr static Vector3 yAxis(T length = T(1)) { return Vector3(T(), length, T()); } /** @brief %Vector in direction of Z axis */ inline constexpr static Vector3 zAxis(T length = T(1)) { return Vector3(T(), T(), length); } /** * @brief Cross product * * @f[ * \begin{pmatrix} c_0 \\ c_1 \\ c_2 \end{pmatrix} = * \begin{pmatrix}a_1b_2 - a_2b_1 \\ a_2b_0 - a_0b_2 \\ a_0b_1 - a_1b_0 \end{pmatrix} * @f] */ inline constexpr static Vector3 cross(const Vector3& a, const Vector3& b) { return Vector3(a[1]*b[2]-a[2]*b[1], a[2]*b[0]-a[0]*b[2], a[0]*b[1]-a[1]*b[0]); } /** @copydoc Vector::Vector() */ inline constexpr Vector3() {} /** @copydoc Vector::Vector(T) */ inline constexpr explicit Vector3(T value): Vector<3, T>(value, value, value) {} /** @copydoc Vector::Vector(const Vector&) */ inline constexpr Vector3(const Vector<3, T>& other): Vector<3, T>(other) {} /** * @brief Constructor * @param x X value * @param y Y value * @param z Z value */ inline constexpr Vector3(T x, T y, T z): Vector<3, T>(x, y, z) {} /** * @brief Constructor * @param other Two component vector * @param z Z value */ inline constexpr Vector3(const Vector<2, T>& other, T z): Vector<3, T>(other[0], other[1], z) {} inline constexpr T x() const { return (*this)[0]; } /**< @brief X component */ inline constexpr T y() const { return (*this)[1]; } /**< @brief Y component */ inline constexpr T z() const { return (*this)[2]; } /**< @brief Z component */ inline void setX(T value) { (*this)[0] = value; } /**< @brief Set X component */ inline void setY(T value) { (*this)[1] = value; } /**< @brief Set Y component */ inline void setZ(T value) { (*this)[2] = value; } /**< @brief Set Z component */ /** * @brief XY part of the vector * @return First two components of the vector * * @see swizzle() */ inline constexpr Vector2 xy() const { return Vector2::from(Vector<3, T>::data()); } MAGNUM_VECTOR_SUBCLASS_IMPLEMENTATION(Vector3, 3) }; /** @debugoperator{Vector3} */ template Corrade::Utility::Debug operator<<(Corrade::Utility::Debug debug, const Magnum::Math::Vector3& value) { return debug << static_cast&>(value); } }} #endif