type_quat.hpp 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. /// @ref core
  2. /// @file glm/detail/type_quat.hpp
  3. #pragma once
  4. // Dependency:
  5. #include "../detail/type_mat3x3.hpp"
  6. #include "../detail/type_mat4x4.hpp"
  7. #include "../detail/type_vec3.hpp"
  8. #include "../detail/type_vec4.hpp"
  9. #include "../ext/vector_relational.hpp"
  10. #include "../ext/quaternion_relational.hpp"
  11. #include "../gtc/constants.hpp"
  12. #include "../gtc/matrix_transform.hpp"
  13. namespace glm
  14. {
  15. template<typename T, qualifier Q>
  16. struct qua
  17. {
  18. // -- Implementation detail --
  19. typedef qua<T, Q> type;
  20. typedef T value_type;
  21. // -- Data --
  22. # if GLM_SILENT_WARNINGS == GLM_ENABLE
  23. # if GLM_COMPILER & GLM_COMPILER_GCC
  24. # pragma GCC diagnostic push
  25. # pragma GCC diagnostic ignored "-Wpedantic"
  26. # elif GLM_COMPILER & GLM_COMPILER_CLANG
  27. # pragma clang diagnostic push
  28. # pragma clang diagnostic ignored "-Wgnu-anonymous-struct"
  29. # pragma clang diagnostic ignored "-Wnested-anon-types"
  30. # elif GLM_COMPILER & GLM_COMPILER_VC
  31. # pragma warning(push)
  32. # pragma warning(disable: 4201) // nonstandard extension used : nameless struct/union
  33. # endif
  34. # endif
  35. # if GLM_LANG & GLM_LANG_CXXMS_FLAG
  36. union
  37. {
  38. # ifdef GLM_FORCE_QUAT_DATA_WXYZ
  39. struct { T w, x, y, z; };
  40. # else
  41. struct { T x, y, z, w; };
  42. # endif
  43. typename detail::storage<4, T, detail::is_aligned<Q>::value>::type data;
  44. };
  45. # else
  46. # ifdef GLM_FORCE_QUAT_DATA_WXYZ
  47. T w, x, y, z;
  48. # else
  49. T x, y, z, w;
  50. # endif
  51. # endif
  52. # if GLM_SILENT_WARNINGS == GLM_ENABLE
  53. # if GLM_COMPILER & GLM_COMPILER_CLANG
  54. # pragma clang diagnostic pop
  55. # elif GLM_COMPILER & GLM_COMPILER_GCC
  56. # pragma GCC diagnostic pop
  57. # elif GLM_COMPILER & GLM_COMPILER_VC
  58. # pragma warning(pop)
  59. # endif
  60. # endif
  61. // -- Component accesses --
  62. typedef length_t length_type;
  63. /// Return the count of components of a quaternion
  64. GLM_FUNC_DECL static GLM_CONSTEXPR length_type length(){return 4;}
  65. GLM_FUNC_DECL GLM_CONSTEXPR T & operator[](length_type i);
  66. GLM_FUNC_DECL GLM_CONSTEXPR T const& operator[](length_type i) const;
  67. // -- Implicit basic constructors --
  68. GLM_FUNC_DECL GLM_CONSTEXPR qua() GLM_DEFAULT;
  69. GLM_FUNC_DECL GLM_CONSTEXPR qua(qua<T, Q> const& q) GLM_DEFAULT;
  70. template<qualifier P>
  71. GLM_FUNC_DECL GLM_CONSTEXPR qua(qua<T, P> const& q);
  72. // -- Explicit basic constructors --
  73. GLM_FUNC_DECL GLM_CONSTEXPR qua(T s, vec<3, T, Q> const& v);
  74. GLM_FUNC_DECL GLM_CONSTEXPR qua(T w, T x, T y, T z);
  75. // -- Conversion constructors --
  76. template<typename U, qualifier P>
  77. GLM_FUNC_DECL GLM_CONSTEXPR GLM_EXPLICIT qua(qua<U, P> const& q);
  78. /// Explicit conversion operators
  79. # if GLM_HAS_EXPLICIT_CONVERSION_OPERATORS
  80. GLM_FUNC_DECL explicit operator mat<3, 3, T, Q>() const;
  81. GLM_FUNC_DECL explicit operator mat<4, 4, T, Q>() const;
  82. # endif
  83. /// Create a quaternion from two normalized axis
  84. ///
  85. /// @param u A first normalized axis
  86. /// @param v A second normalized axis
  87. /// @see gtc_quaternion
  88. /// @see http://lolengine.net/blog/2013/09/18/beautiful-maths-quaternion-from-vectors
  89. GLM_FUNC_DECL qua(vec<3, T, Q> const& u, vec<3, T, Q> const& v);
  90. /// Build a quaternion from euler angles (pitch, yaw, roll), in radians.
  91. GLM_FUNC_DECL GLM_CONSTEXPR GLM_EXPLICIT qua(vec<3, T, Q> const& eulerAngles);
  92. GLM_FUNC_DECL GLM_EXPLICIT qua(mat<3, 3, T, Q> const& q);
  93. GLM_FUNC_DECL GLM_EXPLICIT qua(mat<4, 4, T, Q> const& q);
  94. // -- Unary arithmetic operators --
  95. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q>& operator=(qua<T, Q> const& q) GLM_DEFAULT;
  96. template<typename U>
  97. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q>& operator=(qua<U, Q> const& q);
  98. template<typename U>
  99. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q>& operator+=(qua<U, Q> const& q);
  100. template<typename U>
  101. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q>& operator-=(qua<U, Q> const& q);
  102. template<typename U>
  103. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q>& operator*=(qua<U, Q> const& q);
  104. template<typename U>
  105. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q>& operator*=(U s);
  106. template<typename U>
  107. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q>& operator/=(U s);
  108. };
  109. // -- Unary bit operators --
  110. template<typename T, qualifier Q>
  111. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q> operator+(qua<T, Q> const& q);
  112. template<typename T, qualifier Q>
  113. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q> operator-(qua<T, Q> const& q);
  114. // -- Binary operators --
  115. template<typename T, qualifier Q>
  116. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q> operator+(qua<T, Q> const& q, qua<T, Q> const& p);
  117. template<typename T, qualifier Q>
  118. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q> operator-(qua<T, Q> const& q, qua<T, Q> const& p);
  119. template<typename T, qualifier Q>
  120. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q> operator*(qua<T, Q> const& q, qua<T, Q> const& p);
  121. template<typename T, qualifier Q>
  122. GLM_FUNC_DECL GLM_CONSTEXPR vec<3, T, Q> operator*(qua<T, Q> const& q, vec<3, T, Q> const& v);
  123. template<typename T, qualifier Q>
  124. GLM_FUNC_DECL GLM_CONSTEXPR vec<3, T, Q> operator*(vec<3, T, Q> const& v, qua<T, Q> const& q);
  125. template<typename T, qualifier Q>
  126. GLM_FUNC_DECL GLM_CONSTEXPR vec<4, T, Q> operator*(qua<T, Q> const& q, vec<4, T, Q> const& v);
  127. template<typename T, qualifier Q>
  128. GLM_FUNC_DECL GLM_CONSTEXPR vec<4, T, Q> operator*(vec<4, T, Q> const& v, qua<T, Q> const& q);
  129. template<typename T, qualifier Q>
  130. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q> operator*(qua<T, Q> const& q, T const& s);
  131. template<typename T, qualifier Q>
  132. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q> operator*(T const& s, qua<T, Q> const& q);
  133. template<typename T, qualifier Q>
  134. GLM_FUNC_DECL GLM_CONSTEXPR qua<T, Q> operator/(qua<T, Q> const& q, T const& s);
  135. // -- Boolean operators --
  136. template<typename T, qualifier Q>
  137. GLM_FUNC_DECL GLM_CONSTEXPR bool operator==(qua<T, Q> const& q1, qua<T, Q> const& q2);
  138. template<typename T, qualifier Q>
  139. GLM_FUNC_DECL GLM_CONSTEXPR bool operator!=(qua<T, Q> const& q1, qua<T, Q> const& q2);
  140. } //namespace glm
  141. #ifndef GLM_EXTERNAL_TEMPLATE
  142. #include "type_quat.inl"
  143. #endif//GLM_EXTERNAL_TEMPLATE