#ifndef Magnum_Math_Vector4_h #define Magnum_Math_Vector4_h /* Copyright © 2010, 2011 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::Vector4 */ #include "Vector3.h" namespace Magnum { namespace Math { /** @brief Vector (four-component) */ template class Vector4: public Vector { public: /** * @copydoc Vector::Vector * * W / A component is set to one. */ inline Vector4() { setW(T(1)); } /** @copydoc Vector::Vector(const T*) */ inline Vector4(const T* data): Vector(data) {} /** @copydoc Vector::Vector(const Vector&) */ inline Vector4(const Vector& other): Vector(other) {} /** * @brief Constructor * @param x X / R value * @param y Y / G value * @param z Z / B value * @param w W / A value */ inline Vector4(T x, T y, T z, T w = T(1)) { setX(x); setY(y); setZ(z); setW(w); } /** * @brief Constructor * @param other Three component vector * @param w W / A value */ inline Vector4(const Vector& other, T w = T(1)) { setX(other[0]); setY(other[1]); setZ(other[2]); setW(w); } inline T x() const { return Vector::at(0); } /**< @brief X component */ inline T y() const { return Vector::at(1); } /**< @brief Y component */ inline T z() const { return Vector::at(2); } /**< @brief Z component */ inline T w() const { return Vector::at(3); } /**< @brief W component */ inline void setX(T value) { set(0, value); } /**< @brief Set X component */ inline void setY(T value) { set(1, value); } /**< @brief Set Y component */ inline void setZ(T value) { set(2, value); } /**< @brief Set Z component */ inline void setW(T value) { set(3, value); } /**< @brief Set W component */ /** * @brief XYZ part of the vector * @return First three components of the vector */ inline Vector3 xyz() const { return Vector3(Vector::data()); } inline T r() const { return x(); } /**< @brief R component */ inline T g() const { return y(); } /**< @brief G component */ inline T b() const { return z(); } /**< @brief B component */ inline T a() const { return w(); } /**< @brief A component */ inline void setR(T value) { setX(value); } /**< @brief Set R component */ inline void setG(T value) { setY(value); } /**< @brief Set G component */ inline void setB(T value) { setZ(value); } /**< @brief Set B component */ inline void setA(T value) { setA(value); } /**< @brief Set A component */ /** * @brief RGB part of the vector * @return First three components of the vector */ inline Vector3 rgb() const { return xyz(); } /** @copydoc Vector::operator=() */ inline Vector4& operator=(const Vector& other) { return Vector::operator=(other); } /** @copydoc Vector::operator*(const Vector&) */ inline T operator*(const Vector& other) const { return Vector::operator*(other); } /** @copydoc Vector::operator*(T) */ inline Vector4 operator*(T number) const { return Vector::operator*(number); } /** @copydoc Vector::operator/() */ inline Vector4 operator/(T number) const { return Vector::operator/(number); } /** @copydoc Vector::operator+() */ inline Vector4 operator+(const Vector& other) const { return Vector::operator+(other); } /** @copydoc Vector::operator-(const Vector&) */ inline Vector4 operator-(const Vector& other) const { return Vector::operator-(other); } /** @copydoc Vector::operator-() */ inline Vector4 operator-() const { return Vector::operator-(); } /** @copydoc Vector::normalized() */ inline Vector4 normalized() const { return Vector::normalized(); } }; #ifndef DOXYGEN_GENERATING_OUTPUT template Corrade::Utility::Debug& operator<<(Corrade::Utility::Debug debug, const Magnum::Math::Vector4& value) { return debug << static_cast&>(value); } #endif }} #endif