annotate utils/src/math.rs @ 790:d005f5927447

utils: Use const_for to make more const fn
author Link Mauve <linkmauve@linkmauve.fr>
date Sat, 17 Jan 2026 14:12:08 +0100
parents b5bca9274335
children a29122662cde
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
1 //! Various helpers to deal with vectors and matrices.
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
2
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
3 use const_for::const_for;
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
4
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
5 /// A 4×4 f32 matrix type.
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
6 pub struct Mat4 {
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
7 inner: [[f32; 4]; 4]
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
8 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
9
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
10 impl Mat4 {
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
11 /// Create a new matrix from a set of 16 f32.
789
b5bca9274335 utils: Make some math functions const
Link Mauve <linkmauve@linkmauve.fr>
parents: 757
diff changeset
12 pub const fn new(inner: [[f32; 4]; 4]) -> Mat4 {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
13 Mat4 {
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
14 inner
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
15 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
16 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
17
789
b5bca9274335 utils: Make some math functions const
Link Mauve <linkmauve@linkmauve.fr>
parents: 757
diff changeset
18 const fn zero() -> Mat4 {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
19 Mat4 {
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
20 inner: [[0.; 4]; 4]
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
21 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
22 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
23
789
b5bca9274335 utils: Make some math functions const
Link Mauve <linkmauve@linkmauve.fr>
parents: 757
diff changeset
24 const fn identity() -> Mat4 {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
25 Mat4 {
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
26 inner: [[1., 0., 0., 0.],
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
27 [0., 1., 0., 0.],
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
28 [0., 0., 1., 0.],
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
29 [0., 0., 0., 1.]]
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
30 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
31 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
32
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
33 /// Immutably borrow the array of f32 inside this matrix.
789
b5bca9274335 utils: Make some math functions const
Link Mauve <linkmauve@linkmauve.fr>
parents: 757
diff changeset
34 pub const fn borrow_inner(&self) -> &[[f32; 4]; 4] {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
35 &self.inner
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
36 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
37
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
38 /// Scale the matrix in 2D.
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
39 pub const fn scale2d(&mut self, x: f32, y: f32) {
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
40 const_for!(i in 0..4 => {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
41 self.inner[0][i] *= x;
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
42 self.inner[1][i] *= y;
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
43 });
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
44 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
45
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
46 /// Flip the matrix.
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
47 pub const fn flip(&mut self) {
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
48 const_for!(i in 0..4 => {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
49 self.inner[0][i] = -self.inner[0][i];
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
50 });
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
51 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
52
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
53 /// Rotate the matrix around its x angle (in radians).
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
54 pub fn rotate_x(&mut self, angle: f32) {
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
55 let mut lines: [f32; 8] = [0.; 8];
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
56 let cos_a = angle.cos();
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
57 let sin_a = angle.sin();
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
58 const_for!(i in 0..4 => {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
59 lines[ i] = self.inner[0][i];
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
60 lines[4 + i] = self.inner[1][i];
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
61 });
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
62 const_for!(i in 0..4 => {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
63 self.inner[1][i] = cos_a * lines[i] - sin_a * lines[4+i];
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
64 self.inner[2][i] = sin_a * lines[i] + cos_a * lines[4+i];
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
65 });
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
66 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
67
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
68 /// Rotate the matrix around its y angle (in radians).
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
69 pub fn rotate_y(&mut self, angle: f32) {
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
70 let mut lines: [f32; 8] = [0.; 8];
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
71 let cos_a = angle.cos();
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
72 let sin_a = angle.sin();
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
73 const_for!(i in 0..4 => {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
74 lines[ i] = self.inner[0][i];
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
75 lines[4 + i] = self.inner[2][i];
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
76 });
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
77 const_for!(i in 0..4 => {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
78 self.inner[0][i] = cos_a * lines[i] + sin_a * lines[4+i];
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
79 self.inner[2][i] = -sin_a * lines[i] + cos_a * lines[4+i];
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
80 });
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
81 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
82
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
83 /// Rotate the matrix around its z angle (in radians).
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
84 pub fn rotate_z(&mut self, angle: f32) {
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
85 let mut lines: [f32; 8] = [0.; 8];
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
86 let cos_a = angle.cos();
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
87 let sin_a = angle.sin();
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
88 const_for!(i in 0..4 => {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
89 lines[ i] = self.inner[0][i];
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
90 lines[4 + i] = self.inner[1][i];
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
91 });
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
92 const_for!(i in 0..4 => {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
93 self.inner[0][i] = cos_a * lines[i] - sin_a * lines[4+i];
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
94 self.inner[1][i] = sin_a * lines[i] + cos_a * lines[4+i];
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
95 });
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
96 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
97
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
98 /// Translate the matrix by a 3D offset.
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
99 pub const fn translate(&mut self, offset: [f32; 3]) {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
100 let mut item: [f32; 3] = [0.; 3];
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
101 const_for!(i in 0..3 => {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
102 item[i] = self.inner[3][i] * offset[i];
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
103 });
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
104 const_for!(i in 0..3 => {
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
105 const_for!(j in 0..4 => {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
106 self.inner[i][j] += item[i];
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
107 });
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
108 });
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
109 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
110
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
111 /// Translate the matrix by a 2D offset.
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
112 pub const fn translate_2d(&mut self, x: f32, y: f32) {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
113 let offset = [x, y, 0.];
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
114 self.translate(offset);
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
115 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
116 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
117
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
118 impl std::ops::Mul<Mat4> for Mat4 {
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
119 type Output = Mat4;
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
120 fn mul(self, rhs: Mat4) -> Mat4 {
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
121 let mut tmp = Mat4::zero();
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
122 const_for!(i in 0..4 => {
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
123 const_for!(j in 0..4 => {
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
124 const_for!(k in 0..4 => {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
125 tmp.inner[i][j] += self.inner[i][k] * rhs.inner[k][j];
790
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
126 });
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
127 });
d005f5927447 utils: Use const_for to make more const fn
Link Mauve <linkmauve@linkmauve.fr>
parents: 789
diff changeset
128 });
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
129 tmp
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
130 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
131 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
132
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
133 /// Create an orthographic projection matrix.
789
b5bca9274335 utils: Make some math functions const
Link Mauve <linkmauve@linkmauve.fr>
parents: 757
diff changeset
134 pub const fn ortho_2d(left: f32, right: f32, bottom: f32, top: f32) -> Mat4 {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
135 let mut mat = Mat4::identity();
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
136 mat.inner[0][0] = 2. / (right - left);
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
137 mat.inner[1][1] = 2. / (top - bottom);
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
138 mat.inner[2][2] = -1.;
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
139 mat.inner[3][0] = -(right + left) / (right - left);
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
140 mat.inner[3][1] = -(top + bottom) / (top - bottom);
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
141 mat
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
142 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
143
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
144 /// Setup a camera view matrix.
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
145 pub fn setup_camera(dx: f32, dy: f32, dz: f32) -> Mat4 {
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
146 // Some explanations on the magic constants:
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
147 // 192. = 384. / 2. = width / 2.
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
148 // 224. = 448. / 2. = height / 2.
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
149 // 835.979370 = 224./math.tan(math.radians(15)) = (height/2.)/math.tan(math.radians(fov/2))
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
150 // This is so that objects on the (O, x, y) plane use pixel coordinates
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
151 look_at([192., 224., -835.979370 * dz], [192. + dx, 224. - dy, 0.], [0., -1., 0.])
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
152 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
153
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
154 /// Creates a perspective projection matrix.
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
155 pub fn perspective(fov_y: f32, aspect: f32, z_near: f32, z_far: f32) -> Mat4 {
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
156 let top = (fov_y / 2.).tan() * z_near;
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
157 let bottom = -top;
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
158 let left = -top * aspect;
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
159 let right = top * aspect;
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
160
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
161 let mut mat = Mat4::identity();
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
162 mat.inner[0][0] = (2. * z_near) / (right - left);
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
163 mat.inner[1][1] = (2. * z_near) / (top - bottom);
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
164 mat.inner[2][2] = -(z_far + z_near) / (z_far - z_near);
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
165 mat.inner[2][3] = -1.;
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
166 mat.inner[3][2] = -(2. * z_far * z_near) / (z_far - z_near);
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
167 mat.inner[3][3] = 0.;
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
168 mat
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
169 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
170
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
171 type Vec3 = [f32; 3];
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
172
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
173 fn look_at(eye: Vec3, center: Vec3, up: Vec3) -> Mat4 {
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
174 let f = normalize(sub(center, eye));
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
175 let u = normalize(up);
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
176 let s = normalize(cross(f, u));
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
177 let u = cross(s, f);
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
178
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
179 Mat4::new([[s[0], u[0], -f[0], 0.],
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
180 [s[1], u[1], -f[1], 0.],
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
181 [s[2], u[2], -f[2], 0.],
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
182 [-dot(s, eye), -dot(u, eye), dot(f, eye), 1.]])
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
183 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
184
789
b5bca9274335 utils: Make some math functions const
Link Mauve <linkmauve@linkmauve.fr>
parents: 757
diff changeset
185 const fn sub(a: Vec3, b: Vec3) -> Vec3 {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
186 [a[0] - b[0],
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
187 a[1] - b[1],
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
188 a[2] - b[2]]
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
189 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
190
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
191 fn normalize(vec: Vec3) -> Vec3 {
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
192 let normal = 1. / (vec[0] * vec[0] + vec[1] * vec[1] + vec[2] * vec[2]).sqrt();
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
193 [vec[0] * normal, vec[1] * normal, vec[2] * normal]
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
194 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
195
789
b5bca9274335 utils: Make some math functions const
Link Mauve <linkmauve@linkmauve.fr>
parents: 757
diff changeset
196 const fn cross(a: Vec3, b: Vec3) -> Vec3 {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
197 [a[1] * b[2] - b[1] * a[2],
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
198 a[2] * b[0] - b[2] * a[0],
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
199 a[0] * b[1] - b[0] * a[1]]
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
200 }
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
201
789
b5bca9274335 utils: Make some math functions const
Link Mauve <linkmauve@linkmauve.fr>
parents: 757
diff changeset
202 const fn dot(a: Vec3, b: Vec3) -> f32 {
643
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
203 a[0] * b[0] + a[1] * b[1] + a[2] * b[2]
01849ffd0180 Add an anmrenderer binary.
Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
parents:
diff changeset
204 }