| /// @ref gtx_matrix_major_storage |
| /// @file glm/gtx/matrix_major_storage.hpp |
| |
| namespace glm |
| { |
| template <typename T, precision P> |
| GLM_FUNC_QUALIFIER tmat2x2<T, P> rowMajor2 |
| ( |
| tvec2<T, P> const & v1, |
| tvec2<T, P> const & v2 |
| ) |
| { |
| tmat2x2<T, P> Result; |
| Result[0][0] = v1.x; |
| Result[1][0] = v1.y; |
| Result[0][1] = v2.x; |
| Result[1][1] = v2.y; |
| return Result; |
| } |
| |
| template <typename T, precision P> |
| GLM_FUNC_QUALIFIER tmat2x2<T, P> rowMajor2( |
| const tmat2x2<T, P>& m) |
| { |
| tmat2x2<T, P> Result; |
| Result[0][0] = m[0][0]; |
| Result[0][1] = m[1][0]; |
| Result[1][0] = m[0][1]; |
| Result[1][1] = m[1][1]; |
| return Result; |
| } |
| |
| template <typename T, precision P> |
| GLM_FUNC_QUALIFIER tmat3x3<T, P> rowMajor3( |
| const tvec3<T, P>& v1, |
| const tvec3<T, P>& v2, |
| const tvec3<T, P>& v3) |
| { |
| tmat3x3<T, P> Result; |
| Result[0][0] = v1.x; |
| Result[1][0] = v1.y; |
| Result[2][0] = v1.z; |
| Result[0][1] = v2.x; |
| Result[1][1] = v2.y; |
| Result[2][1] = v2.z; |
| Result[0][2] = v3.x; |
| Result[1][2] = v3.y; |
| Result[2][2] = v3.z; |
| return Result; |
| } |
| |
| template <typename T, precision P> |
| GLM_FUNC_QUALIFIER tmat3x3<T, P> rowMajor3( |
| const tmat3x3<T, P>& m) |
| { |
| tmat3x3<T, P> Result; |
| Result[0][0] = m[0][0]; |
| Result[0][1] = m[1][0]; |
| Result[0][2] = m[2][0]; |
| Result[1][0] = m[0][1]; |
| Result[1][1] = m[1][1]; |
| Result[1][2] = m[2][1]; |
| Result[2][0] = m[0][2]; |
| Result[2][1] = m[1][2]; |
| Result[2][2] = m[2][2]; |
| return Result; |
| } |
| |
| template <typename T, precision P> |
| GLM_FUNC_QUALIFIER tmat4x4<T, P> rowMajor4( |
| const tvec4<T, P>& v1, |
| const tvec4<T, P>& v2, |
| const tvec4<T, P>& v3, |
| const tvec4<T, P>& v4) |
| { |
| tmat4x4<T, P> Result; |
| Result[0][0] = v1.x; |
| Result[1][0] = v1.y; |
| Result[2][0] = v1.z; |
| Result[3][0] = v1.w; |
| Result[0][1] = v2.x; |
| Result[1][1] = v2.y; |
| Result[2][1] = v2.z; |
| Result[3][1] = v2.w; |
| Result[0][2] = v3.x; |
| Result[1][2] = v3.y; |
| Result[2][2] = v3.z; |
| Result[3][2] = v3.w; |
| Result[0][3] = v4.x; |
| Result[1][3] = v4.y; |
| Result[2][3] = v4.z; |
| Result[3][3] = v4.w; |
| return Result; |
| } |
| |
| template <typename T, precision P> |
| GLM_FUNC_QUALIFIER tmat4x4<T, P> rowMajor4( |
| const tmat4x4<T, P>& m) |
| { |
| tmat4x4<T, P> Result; |
| Result[0][0] = m[0][0]; |
| Result[0][1] = m[1][0]; |
| Result[0][2] = m[2][0]; |
| Result[0][3] = m[3][0]; |
| Result[1][0] = m[0][1]; |
| Result[1][1] = m[1][1]; |
| Result[1][2] = m[2][1]; |
| Result[1][3] = m[3][1]; |
| Result[2][0] = m[0][2]; |
| Result[2][1] = m[1][2]; |
| Result[2][2] = m[2][2]; |
| Result[2][3] = m[3][2]; |
| Result[3][0] = m[0][3]; |
| Result[3][1] = m[1][3]; |
| Result[3][2] = m[2][3]; |
| Result[3][3] = m[3][3]; |
| return Result; |
| } |
| |
| template <typename T, precision P> |
| GLM_FUNC_QUALIFIER tmat2x2<T, P> colMajor2( |
| const tvec2<T, P>& v1, |
| const tvec2<T, P>& v2) |
| { |
| return tmat2x2<T, P>(v1, v2); |
| } |
| |
| template <typename T, precision P> |
| GLM_FUNC_QUALIFIER tmat2x2<T, P> colMajor2( |
| const tmat2x2<T, P>& m) |
| { |
| return tmat2x2<T, P>(m); |
| } |
| |
| template <typename T, precision P> |
| GLM_FUNC_QUALIFIER tmat3x3<T, P> colMajor3( |
| const tvec3<T, P>& v1, |
| const tvec3<T, P>& v2, |
| const tvec3<T, P>& v3) |
| { |
| return tmat3x3<T, P>(v1, v2, v3); |
| } |
| |
| template <typename T, precision P> |
| GLM_FUNC_QUALIFIER tmat3x3<T, P> colMajor3( |
| const tmat3x3<T, P>& m) |
| { |
| return tmat3x3<T, P>(m); |
| } |
| |
| template <typename T, precision P> |
| GLM_FUNC_QUALIFIER tmat4x4<T, P> colMajor4( |
| const tvec4<T, P>& v1, |
| const tvec4<T, P>& v2, |
| const tvec4<T, P>& v3, |
| const tvec4<T, P>& v4) |
| { |
| return tmat4x4<T, P>(v1, v2, v3, v4); |
| } |
| |
| template <typename T, precision P> |
| GLM_FUNC_QUALIFIER tmat4x4<T, P> colMajor4( |
| const tmat4x4<T, P>& m) |
| { |
| return tmat4x4<T, P>(m); |
| } |
| }//namespace glm |