|
1 | | -import math { close, veryclose } |
| 1 | +import math { close, radians, veryclose } |
2 | 2 | import math.vec |
3 | 3 |
|
4 | 4 | fn test_vec2_int() { |
@@ -160,3 +160,71 @@ fn test_vec2_angle_towards() { |
160 | 160 | } |
161 | 161 | } |
162 | 162 | } |
| 163 | + |
| 164 | +fn test_vec2_rotate_around_cw() { |
| 165 | + origin := vec.vec2(0.0, 0.0) |
| 166 | + mut v := vec.vec2(0.0, 1.0) |
| 167 | + v = v.rotate_around_cw(origin, radians(90)) |
| 168 | + assert close(v.x, 1.0) |
| 169 | + assert close(v.y, 0.0) |
| 170 | + v = v.rotate_around_cw(origin, radians(90)) |
| 171 | + assert close(v.x, 0.0) |
| 172 | + assert close(v.y, -1.0) |
| 173 | + v = v.rotate_around_cw(origin, radians(90)) |
| 174 | + assert close(v.x, -1.0) |
| 175 | + assert close(v.y, 0.0) |
| 176 | + v = v.rotate_around_cw(origin, radians(90)) |
| 177 | + assert close(v.x, 0.0) |
| 178 | + assert close(v.y, 1.0) |
| 179 | +} |
| 180 | + |
| 181 | +fn test_vec2_rotate_around_ccw() { |
| 182 | + origin := vec.vec2(0.0, 0.0) |
| 183 | + mut v := vec.vec2(0.0, 1.0) |
| 184 | + v = v.rotate_around_ccw(origin, radians(90)) |
| 185 | + assert close(v.x, -1.0) |
| 186 | + assert close(v.y, 0.0) |
| 187 | + v = v.rotate_around_ccw(origin, radians(90)) |
| 188 | + assert close(v.x, 0.0) |
| 189 | + assert close(v.y, -1.0) |
| 190 | + v = v.rotate_around_ccw(origin, radians(90)) |
| 191 | + assert close(v.x, 1.0) |
| 192 | + assert close(v.y, 0.0) |
| 193 | + v = v.rotate_around_ccw(origin, radians(90)) |
| 194 | + assert close(v.x, 0.0) |
| 195 | + assert close(v.y, 1.0) |
| 196 | +} |
| 197 | + |
| 198 | +fn test_vec2_rotate_around_cw_2() { |
| 199 | + origin := vec.vec2(1.0, 1.0) |
| 200 | + mut v := vec.vec2(1.0, 2.0) |
| 201 | + v = v.rotate_around_cw(origin, radians(90)) |
| 202 | + assert close(v.x, 2.0) |
| 203 | + assert close(v.y, 1.0) |
| 204 | + v = v.rotate_around_cw(origin, radians(90)) |
| 205 | + assert close(v.x, 1.0) |
| 206 | + assert close(v.y, 0.0) |
| 207 | + v = v.rotate_around_cw(origin, radians(90)) |
| 208 | + assert close(v.x, 0.0) |
| 209 | + assert close(v.y, 1.0) |
| 210 | + v = v.rotate_around_cw(origin, radians(90)) |
| 211 | + assert close(v.x, 1.0) |
| 212 | + assert close(v.y, 2.0) |
| 213 | +} |
| 214 | + |
| 215 | +fn test_vec2_rotate_around_ccw_2() { |
| 216 | + origin := vec.vec2(-1.0, 1.0) |
| 217 | + mut v := vec.vec2(-1.0, -1.0) |
| 218 | + v = v.rotate_around_ccw(origin, radians(90)) |
| 219 | + assert close(v.x, 1.0) |
| 220 | + assert close(v.y, 1.0) |
| 221 | + v = v.rotate_around_ccw(origin, radians(90)) |
| 222 | + assert close(v.x, -1.0) |
| 223 | + assert close(v.y, 3.0) |
| 224 | + v = v.rotate_around_ccw(origin, radians(90)) |
| 225 | + assert close(v.x, -3.0) |
| 226 | + assert close(v.y, 1.0) |
| 227 | + v = v.rotate_around_ccw(origin, radians(90)) |
| 228 | + assert close(v.x, -1.0) |
| 229 | + assert close(v.y, -1.0) |
| 230 | +} |
0 commit comments