1///////////////////////////////////////////////////////////////////////////////////////////////////
2// OpenGL Mathematics Copyright (c) 2005 - 2014 G-Truc Creation (www.g-truc.net)
3///////////////////////////////////////////////////////////////////////////////////////////////////
4// Created : 2005-02-28
5// Updated : 2005-04-23
6// Licence : This source is under MIT License
7// File : glm/gtx/transform2.inl
8///////////////////////////////////////////////////////////////////////////////////////////////////
9
10namespace glm
11{
12	template <typename T, precision P>
13	GLM_FUNC_QUALIFIER detail::tmat3x3<T, P> shearX2D(
14		const detail::tmat3x3<T, P>& m,
15		T s)
16	{
17		detail::tmat3x3<T, P> r(1);
18		r[0][1] = s;
19		return m * r;
20	}
21
22	template <typename T, precision P>
23	GLM_FUNC_QUALIFIER detail::tmat3x3<T, P> shearY2D(
24		const detail::tmat3x3<T, P>& m,
25		T s)
26	{
27		detail::tmat3x3<T, P> r(1);
28		r[1][0] = s;
29		return m * r;
30	}
31
32	template <typename T, precision P>
33	GLM_FUNC_QUALIFIER detail::tmat4x4<T, P> shearX3D(
34		const detail::tmat4x4<T, P>& m,
35		T s,
36		T t)
37	{
38		detail::tmat4x4<T, P> r(1);
39		r[1][0] = s;
40		r[2][0] = t;
41		return m * r;
42	}
43
44	template <typename T, precision P>
45	GLM_FUNC_QUALIFIER detail::tmat4x4<T, P> shearY3D(
46		const detail::tmat4x4<T, P>& m,
47		T s,
48		T t)
49	{
50		detail::tmat4x4<T, P> r(1);
51		r[0][1] = s;
52		r[2][1] = t;
53		return m * r;
54	}
55
56	template <typename T, precision P>
57	GLM_FUNC_QUALIFIER detail::tmat4x4<T, P> shearZ3D(
58		const detail::tmat4x4<T, P>& m,
59		T s,
60		T t)
61	{
62		detail::tmat4x4<T, P> r(1);
63		r[0][2] = s;
64		r[1][2] = t;
65		return m * r;
66	}
67
68	template <typename T, precision P>
69	GLM_FUNC_QUALIFIER detail::tmat3x3<T, P> reflect2D(
70		const detail::tmat3x3<T, P>& m,
71		const detail::tvec3<T, P>& normal)
72	{
73		detail::tmat3x3<T, P> r(1);
74		r[0][0] = 1 - 2 * normal.x * normal.x;
75		r[0][1] = -2 * normal.x * normal.y;
76		r[1][0] = -2 * normal.x * normal.y;
77		r[1][1] = 1 - 2 * normal.y * normal.y;
78		return m * r;
79	}
80
81	template <typename T, precision P>
82	GLM_FUNC_QUALIFIER detail::tmat4x4<T, P> reflect3D(
83		const detail::tmat4x4<T, P>& m,
84		const detail::tvec3<T, P>& normal)
85	{
86		detail::tmat4x4<T, P> r(1);
87		r[0][0] = 1 - 2 * normal.x * normal.x;
88		r[0][1] = -2 * normal.x * normal.y;
89		r[0][2] = -2 * normal.x * normal.z;
90
91		r[1][0] = -2 * normal.x * normal.y;
92		r[1][1] = 1 - 2 * normal.y * normal.y;
93		r[1][2] = -2 * normal.y * normal.z;
94
95		r[2][0] = -2 * normal.x * normal.z;
96		r[2][1] = -2 * normal.y * normal.z;
97		r[2][2] = 1 - 2 * normal.z * normal.z;
98		return m * r;
99	}
100
101	template <typename T, precision P>
102	GLM_FUNC_QUALIFIER detail::tmat3x3<T, P> proj2D(
103		const detail::tmat3x3<T, P>& m,
104		const detail::tvec3<T, P>& normal)
105	{
106		detail::tmat3x3<T, P> r(1);
107		r[0][0] = 1 - normal.x * normal.x;
108		r[0][1] = - normal.x * normal.y;
109		r[1][0] = - normal.x * normal.y;
110		r[1][1] = 1 - normal.y * normal.y;
111		return m * r;
112	}
113
114	template <typename T, precision P>
115	GLM_FUNC_QUALIFIER detail::tmat4x4<T, P> proj3D(
116		const detail::tmat4x4<T, P>& m,
117		const detail::tvec3<T, P>& normal)
118	{
119		detail::tmat4x4<T, P> r(1);
120		r[0][0] = 1 - normal.x * normal.x;
121		r[0][1] = - normal.x * normal.y;
122		r[0][2] = - normal.x * normal.z;
123		r[1][0] = - normal.x * normal.y;
124		r[1][1] = 1 - normal.y * normal.y;
125		r[1][2] = - normal.y * normal.z;
126		r[2][0] = - normal.x * normal.z;
127		r[2][1] = - normal.y * normal.z;
128		r[2][2] = 1 - normal.z * normal.z;
129		return m * r;
130	}
131
132	template <typename T, precision P>
133	GLM_FUNC_QUALIFIER detail::tmat4x4<T, P> scaleBias(
134		T scale,
135		T bias)
136	{
137		detail::tmat4x4<T, P> result;
138		result[3] = detail::tvec4<T, P>(detail::tvec3<T, P>(bias), T(1));
139		result[0][0] = scale;
140		result[1][1] = scale;
141		result[2][2] = scale;
142		return result;
143	}
144
145	template <typename T, precision P>
146	GLM_FUNC_QUALIFIER detail::tmat4x4<T, P> scaleBias(
147		const detail::tmat4x4<T, P>& m,
148		T scale,
149		T bias)
150	{
151		return m * scaleBias(scale, bias);
152	}
153}//namespace glm
154
155