linearly 0.3.0 → 0.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (79) hide show
  1. package/lib/{common.d.ts → cjs/common.d.ts} +1 -0
  2. package/lib/cjs/common.d.ts.map +1 -0
  3. package/lib/cjs/common.js +20 -0
  4. package/lib/{index.d.ts → cjs/index.d.ts} +1 -0
  5. package/lib/cjs/index.d.ts.map +1 -0
  6. package/lib/cjs/index.js +35 -0
  7. package/lib/{mat2.d.ts → cjs/mat2.d.ts} +1 -0
  8. package/lib/cjs/mat2.d.ts.map +1 -0
  9. package/lib/cjs/mat2.js +224 -0
  10. package/lib/{mat2d.d.ts → cjs/mat2d.d.ts} +1 -0
  11. package/lib/cjs/mat2d.d.ts.map +1 -0
  12. package/lib/cjs/mat2d.js +291 -0
  13. package/lib/{mat3.d.ts → cjs/mat3.d.ts} +1 -0
  14. package/lib/cjs/mat3.d.ts.map +1 -0
  15. package/lib/cjs/mat3.js +450 -0
  16. package/lib/{mat4.d.ts → cjs/mat4.d.ts} +1 -0
  17. package/lib/cjs/mat4.d.ts.map +1 -0
  18. package/lib/cjs/mat4.js +1250 -0
  19. package/lib/{quat.d.ts → cjs/quat.d.ts} +1 -0
  20. package/lib/cjs/quat.d.ts.map +1 -0
  21. package/lib/cjs/quat.js +504 -0
  22. package/lib/{vec2.d.ts → cjs/vec2.d.ts} +1 -0
  23. package/lib/cjs/vec2.d.ts.map +1 -0
  24. package/lib/cjs/vec2.js +205 -0
  25. package/lib/{vec3.d.ts → cjs/vec3.d.ts} +1 -0
  26. package/lib/cjs/vec3.d.ts.map +1 -0
  27. package/lib/cjs/vec3.js +409 -0
  28. package/lib/{vec4.d.ts → cjs/vec4.d.ts} +1 -0
  29. package/lib/cjs/vec4.d.ts.map +1 -0
  30. package/lib/cjs/vec4.js +319 -0
  31. package/lib/esm/common.d.ts +12 -0
  32. package/lib/esm/common.d.ts.map +1 -0
  33. package/lib/esm/common.js +16 -0
  34. package/lib/esm/index.d.ts +17 -0
  35. package/lib/esm/index.d.ts.map +1 -0
  36. package/lib/esm/index.js +9 -0
  37. package/lib/esm/mat2.d.ts +91 -0
  38. package/lib/esm/mat2.d.ts.map +1 -0
  39. package/lib/esm/mat2.js +179 -0
  40. package/lib/esm/mat2d.d.ts +102 -0
  41. package/lib/esm/mat2d.d.ts.map +1 -0
  42. package/lib/esm/mat2d.js +246 -0
  43. package/lib/esm/mat3.d.ts +120 -0
  44. package/lib/esm/mat3.d.ts.map +1 -0
  45. package/lib/esm/mat3.js +400 -0
  46. package/lib/esm/mat4.d.ts +313 -0
  47. package/lib/esm/mat4.d.ts.map +1 -0
  48. package/lib/esm/mat4.js +1183 -0
  49. package/lib/esm/quat.d.ts +220 -0
  50. package/lib/esm/quat.d.ts.map +1 -0
  51. package/lib/esm/quat.js +458 -0
  52. package/lib/esm/vec2.d.ts +66 -0
  53. package/lib/esm/vec2.d.ts.map +1 -0
  54. package/lib/esm/vec2.js +149 -0
  55. package/lib/esm/vec3.d.ts +167 -0
  56. package/lib/esm/vec3.d.ts.map +1 -0
  57. package/lib/esm/vec3.js +348 -0
  58. package/lib/esm/vec4.d.ts +116 -0
  59. package/lib/esm/vec4.d.ts.map +1 -0
  60. package/lib/esm/vec4.js +266 -0
  61. package/package.json +6 -4
  62. package/lib/common.js +0 -30
  63. package/lib/index.js +0 -45
  64. package/lib/mat2.js +0 -234
  65. package/lib/mat2d.js +0 -301
  66. package/lib/mat2d.test.d.ts +0 -1
  67. package/lib/mat2d.test.js +0 -123
  68. package/lib/mat3.js +0 -460
  69. package/lib/mat4.js +0 -1260
  70. package/lib/quat.js +0 -514
  71. package/lib/vec2.js +0 -215
  72. package/lib/vec2.test.d.ts +0 -1
  73. package/lib/vec2.test.js +0 -147
  74. package/lib/vec3.js +0 -419
  75. package/lib/vec3.test.d.ts +0 -1
  76. package/lib/vec3.test.js +0 -149
  77. package/lib/vec4.js +0 -329
  78. package/lib/vec4.test.d.ts +0 -1
  79. package/lib/vec4.test.js +0 -45
@@ -0,0 +1,458 @@
1
+ import * as Common from './common';
2
+ import * as vec3 from './vec3';
3
+ import * as vec4 from './vec4';
4
+ export function of(x, y, z, w) {
5
+ return [x, y, z, w];
6
+ }
7
+ /**
8
+ * The identity quaternion
9
+ */
10
+ export const identity = Object.freeze([0, 0, 0, 1]);
11
+ /**
12
+ * Sets a quat from the given angle and rotation axis,
13
+ * then returns it.
14
+ *
15
+ * @param axis the axis around which to rotate
16
+ * @param rad the angle in radians
17
+ **/
18
+ export function setAxisAngle(axis, rad) {
19
+ rad = rad * 0.5;
20
+ const s = Math.sin(rad);
21
+ return [s * axis[0], s * axis[1], s * axis[2], Math.cos(rad)];
22
+ }
23
+ /**
24
+ * Gets the rotation axis and angle for a given
25
+ * quaternion. If a quaternion is created with
26
+ * setAxisAngle, this method will return the same
27
+ * values as providied in the original parameter list
28
+ * OR functionally equivalent values.
29
+ * Example: The quaternion formed by axis [0, 0, 1] and
30
+ * angle -90 is the same as the quaternion formed by
31
+ * [0, 0, 1] and 270. This method favors the latter.
32
+ *
33
+ * @param q Quaternion to be decomposed
34
+ */
35
+ export function getAxisAngle(q) {
36
+ const rad = Math.acos(q[3]) * 2;
37
+ const s = Math.sin(rad / 2);
38
+ let axis;
39
+ if (s > Common.EPSILON) {
40
+ axis = [q[0] / s, q[1] / s, q[2] / s];
41
+ }
42
+ else {
43
+ // If s is zero, return any axis (no rotation - axis does not matter)
44
+ axis = [1, 0, 0];
45
+ }
46
+ return { axis, rad };
47
+ }
48
+ /**
49
+ * Gets the angular distance between two unit quaternions
50
+ *
51
+ * @param a Origin unit quaternion
52
+ * @param b Destination unit quaternion
53
+ * @return Angle, in radians, between the two quaternions
54
+ */
55
+ export function getAngle(a, b) {
56
+ const dotproduct = dot(a, b);
57
+ return Math.acos(2 * dotproduct * dotproduct - 1);
58
+ }
59
+ /**
60
+ * Multiplies two quat's
61
+ *
62
+ * @param a the first operand
63
+ * @param b the second operand
64
+ */
65
+ export function multiply(a, b) {
66
+ const [ax, ay, az, aw] = a;
67
+ const [bx, by, bz, bw] = b;
68
+ return [
69
+ ax * bw + aw * bx + ay * bz - az * by,
70
+ ay * bw + aw * by + az * bx - ax * bz,
71
+ az * bw + aw * bz + ax * by - ay * bx,
72
+ aw * bw - ax * bx - ay * by - az * bz,
73
+ ];
74
+ }
75
+ /**
76
+ * Rotates a quaternion by the given angle about the X axis
77
+ *
78
+ * @param a quat to rotate
79
+ * @param rad angle (in radians) to rotate
80
+ */
81
+ export function rotateX(a, rad) {
82
+ rad *= 0.5;
83
+ const ax = a[0], ay = a[1], az = a[2], aw = a[3];
84
+ const bx = Math.sin(rad), bw = Math.cos(rad);
85
+ return [
86
+ ax * bw + aw * bx,
87
+ ay * bw + az * bx,
88
+ az * bw - ay * bx,
89
+ aw * bw - ax * bx,
90
+ ];
91
+ }
92
+ /**
93
+ * Rotates a quaternion by the given angle about the Y axis
94
+ *
95
+ * @param a quat to rotate
96
+ * @param rad angle (in radians) to rotate
97
+ */
98
+ export function rotateY(a, rad) {
99
+ rad *= 0.5;
100
+ const ax = a[0], ay = a[1], az = a[2], aw = a[3];
101
+ const by = Math.sin(rad), bw = Math.cos(rad);
102
+ return [
103
+ ax * bw - az * by,
104
+ ay * bw + aw * by,
105
+ az * bw + ax * by,
106
+ aw * bw - ay * by,
107
+ ];
108
+ }
109
+ /**
110
+ * Rotates a quaternion by the given angle about the Z axis
111
+ *
112
+ * @param a quat to rotate
113
+ * @param rad angle (in radians) to rotate
114
+ */
115
+ export function rotateZ(a, rad) {
116
+ rad *= 0.5;
117
+ const ax = a[0], ay = a[1], az = a[2], aw = a[3];
118
+ const bz = Math.sin(rad), bw = Math.cos(rad);
119
+ return [
120
+ ax * bw + ay * bz,
121
+ ay * bw - ax * bz,
122
+ az * bw + aw * bz,
123
+ aw * bw - az * bz,
124
+ ];
125
+ }
126
+ /**
127
+ * Calculates the W component of a quat from the X, Y, and Z components.
128
+ * Assumes that quaternion is 1 unit in length.
129
+ * Any existing W component will be ignored.
130
+ */
131
+ export function calculateW(a) {
132
+ const [x, y, z] = a;
133
+ return [x, y, z, Math.sqrt(Math.abs(1 - x * x - y * y - z * z))];
134
+ }
135
+ /**
136
+ * Calculate the exponential of a unit quaternion.
137
+ */
138
+ export function exp(a) {
139
+ const [x, y, z, w] = a;
140
+ const r = Math.sqrt(x * x + y * y + z * z);
141
+ const et = Math.exp(w);
142
+ const s = r > 0 ? (et * Math.sin(r)) / r : 0;
143
+ return [x * s, y * s, z * s, et * Math.cos(r)];
144
+ }
145
+ /**
146
+ * Calculate the natural logarithm of a unit quaternion.
147
+ */
148
+ export function ln(a) {
149
+ const [x, y, z, w] = a;
150
+ const r = Math.sqrt(x * x + y * y + z * z);
151
+ const t = r > 0 ? Math.atan2(r, w) / r : 0;
152
+ return [x * t, y * t, z * t, 0.5 * Math.log(x * x + y * y + z * z + w * w)];
153
+ }
154
+ /**
155
+ * Calculate the scalar power of a unit quaternion.
156
+ */
157
+ export function pow(a, b) {
158
+ return exp(scale(ln(a), b));
159
+ }
160
+ /**
161
+ * Performs a spherical linear interpolation between two quat
162
+ *
163
+ * @param a the first operand
164
+ * @param b the second operand
165
+ * @param t interpolation amount, in the range [0-1], between the two inputs
166
+ */
167
+ export function slerp(a, b, t) {
168
+ // benchmarks:
169
+ // http://jsperf.com/quaternion-slerp-implementations
170
+ const [ax, ay, az, aw] = a;
171
+ let [bx, by, bz, bw] = b;
172
+ let omega, cosom, sinom, scale0, scale1;
173
+ // calc cosine
174
+ cosom = ax * bx + ay * by + az * bz + aw * bw;
175
+ // adjust signs (if necessary)
176
+ if (cosom < 0) {
177
+ cosom *= -1;
178
+ bx *= -1;
179
+ by *= -1;
180
+ bz *= -1;
181
+ bw *= -1;
182
+ }
183
+ // calculate coefficients
184
+ if (1 - cosom > Common.EPSILON) {
185
+ // standard case (slerp)
186
+ omega = Math.acos(cosom);
187
+ sinom = Math.sin(omega);
188
+ scale0 = Math.sin((1 - t) * omega) / sinom;
189
+ scale1 = Math.sin(t * omega) / sinom;
190
+ }
191
+ else {
192
+ // "from" and "to" quaternions are very close
193
+ // ... so we can do a linear interpolation
194
+ scale0 = 1 - t;
195
+ scale1 = t;
196
+ }
197
+ // calculate final values
198
+ return [
199
+ scale0 * ax + scale1 * bx,
200
+ scale0 * ay + scale1 * by,
201
+ scale0 * az + scale1 * bz,
202
+ scale0 * aw + scale1 * bw,
203
+ ];
204
+ }
205
+ /**
206
+ * Calculates the inverse of a quat
207
+ */
208
+ export function invert(a) {
209
+ const a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3];
210
+ const dot = a0 * a0 + a1 * a1 + a2 * a2 + a3 * a3;
211
+ const invDot = dot ? 1 / dot : 0;
212
+ // TODO: Would be faster to return [0,0,0,0] immediately if dot == 0
213
+ return [-a0 * invDot, -a1 * invDot, -a2 * invDot, a3 * invDot];
214
+ }
215
+ /**
216
+ * Calculates the conjugate of a quat
217
+ * If the quaternion is normalized, this function is faster than quat.inverse and produces the same result.
218
+ */
219
+ export function conjugate(a) {
220
+ return [-a[0], -a[1], -a[2], a[3]];
221
+ }
222
+ /**
223
+ * Creates a quaternion from the given 3x3 rotation matrix.
224
+ *
225
+ * NOTE: The resultant quaternion is not normalized, so you should be sure
226
+ * to renormalize the quaternion yourself where necessary.
227
+ */
228
+ export function fromMat3(m) {
229
+ // Algorithm in Ken Shoemake's article in 1987 SIGGRAPH course notes
230
+ // article "Quaternion Calculus and Fast Animation".
231
+ const fTrace = m[0] + m[4] + m[8];
232
+ let fRoot;
233
+ const out = [0, 0, 0, 0];
234
+ if (fTrace > 0) {
235
+ // |w| > 1/2, may as well choose w > 1/2
236
+ fRoot = Math.sqrt(fTrace + 1); // 2w
237
+ out[3] = 0.5 * fRoot;
238
+ fRoot = 0.5 / fRoot; // 1/(4w)
239
+ out[0] = (m[5] - m[7]) * fRoot;
240
+ out[1] = (m[6] - m[2]) * fRoot;
241
+ out[2] = (m[1] - m[3]) * fRoot;
242
+ }
243
+ else {
244
+ // |w| <= 1/2
245
+ let i = 0;
246
+ if (m[4] > m[0])
247
+ i = 1;
248
+ if (m[8] > m[i * 3 + i])
249
+ i = 2;
250
+ const j = (i + 1) % 3;
251
+ const k = (i + 2) % 3;
252
+ fRoot = Math.sqrt(m[i * 3 + i] - m[j * 3 + j] - m[k * 3 + k] + 1);
253
+ out[i] = 0.5 * fRoot;
254
+ fRoot = 0.5 / fRoot;
255
+ out[3] = (m[j * 3 + k] - m[k * 3 + j]) * fRoot;
256
+ out[j] = (m[j * 3 + i] + m[i * 3 + j]) * fRoot;
257
+ out[k] = (m[k * 3 + i] + m[i * 3 + k]) * fRoot;
258
+ }
259
+ return out;
260
+ }
261
+ /**
262
+ * Creates a quaternion from the given euler angle x, y, z using the provided intrinsic order for the conversion.
263
+ *
264
+ * @param x Angle to rotate around X axis in degrees.
265
+ * @param y Angle to rotate around Y axis in degrees.
266
+ * @param z Angle to rotate around Z axis in degrees.
267
+ * @param order Intrinsic order for conversion, default is zyx.
268
+ * @function
269
+ */
270
+ export function fromEuler(x, y, z, order = Common.DEFAULT_ANGLE_ORDER) {
271
+ const halfToRad = Math.PI / 360;
272
+ x *= halfToRad;
273
+ z *= halfToRad;
274
+ y *= halfToRad;
275
+ const sx = Math.sin(x);
276
+ const cx = Math.cos(x);
277
+ const sy = Math.sin(y);
278
+ const cy = Math.cos(y);
279
+ const sz = Math.sin(z);
280
+ const cz = Math.cos(z);
281
+ switch (order) {
282
+ case 'xyz':
283
+ return [
284
+ sx * cy * cz + cx * sy * sz,
285
+ cx * sy * cz - sx * cy * sz,
286
+ cx * cy * sz + sx * sy * cz,
287
+ cx * cy * cz - sx * sy * sz,
288
+ ];
289
+ case 'xzy':
290
+ return [
291
+ sx * cy * cz - cx * sy * sz,
292
+ cx * sy * cz - sx * cy * sz,
293
+ cx * cy * sz + sx * sy * cz,
294
+ cx * cy * cz + sx * sy * sz,
295
+ ];
296
+ case 'yxz':
297
+ return [
298
+ sx * cy * cz + cx * sy * sz,
299
+ cx * sy * cz - sx * cy * sz,
300
+ cx * cy * sz - sx * sy * cz,
301
+ cx * cy * cz + sx * sy * sz,
302
+ ];
303
+ case 'yzx':
304
+ return [
305
+ sx * cy * cz + cx * sy * sz,
306
+ cx * sy * cz + sx * cy * sz,
307
+ cx * cy * sz - sx * sy * cz,
308
+ cx * cy * cz - sx * sy * sz,
309
+ ];
310
+ case 'zxy':
311
+ return [
312
+ sx * cy * cz - cx * sy * sz,
313
+ cx * sy * cz + sx * cy * sz,
314
+ cx * cy * sz + sx * sy * cz,
315
+ cx * cy * cz - sx * sy * sz,
316
+ ];
317
+ case 'zyx':
318
+ return [
319
+ sx * cy * cz - cx * sy * sz,
320
+ cx * sy * cz + sx * cy * sz,
321
+ cx * cy * sz - sx * sy * cz,
322
+ cx * cy * cz + sx * sy * sz,
323
+ ];
324
+ }
325
+ }
326
+ /**
327
+ * Adds two quat's
328
+ */
329
+ export const add = vec4.add;
330
+ /**
331
+ * Scales a quat by a scalar number
332
+ */
333
+ export const scale = vec4.scale;
334
+ /**
335
+ * Calculates the dot product of two quat's
336
+ */
337
+ export const dot = vec4.dot;
338
+ /**
339
+ * Performs a linear interpolation between two quat's
340
+ *
341
+ * @param a the first operand
342
+ * @param b the second operand
343
+ * @param t interpolation amount, in the range [0-1], between the two inputs
344
+ */
345
+ export const lerp = vec4.lerp;
346
+ /**
347
+ * Calculates the length of a quat
348
+ *
349
+ * @param a vector to calculate length of
350
+ * @returns length of a
351
+ */
352
+ export const length = vec4.length;
353
+ /**
354
+ * Alias for {@link quat.length}
355
+ * @function
356
+ */
357
+ export const len = length;
358
+ /**
359
+ * Calculates the squared length of a quat
360
+ *
361
+ * @param a vector to calculate squared length of
362
+ * @returns squared length of a
363
+ * @function
364
+ */
365
+ export const squaredLength = vec4.squaredLength;
366
+ /**
367
+ * Alias for {@link quat.squaredLength}
368
+ * @function
369
+ */
370
+ export const sqrLen = squaredLength;
371
+ /**
372
+ * Normalize a quat
373
+ *
374
+ * @param a quaternion to normalize
375
+ */
376
+ export const normalize = vec4.normalize;
377
+ /**
378
+ * Returns whether or not the quaternions have exactly the same elements in the same position (when compared with ===)
379
+ */
380
+ export const exactEquals = vec4.exactEquals;
381
+ /**
382
+ * Returns whether or not the quaternions point approximately to the same direction.
383
+ *
384
+ * Both quaternions are assumed to be unit length.
385
+ */
386
+ export function equals(a, b) {
387
+ return Math.abs(vec4.dot(a, b)) >= 1 - Common.EPSILON;
388
+ }
389
+ /**
390
+ * Sets a quaternion to represent the shortest rotation from one
391
+ * vector to another.
392
+ *
393
+ * Both vectors are assumed to be unit length.
394
+ *
395
+ * @param a the initial vector
396
+ * @param b the destination vector
397
+ */
398
+ export const rotationTo = (function () {
399
+ const xUnitVec3 = [1, 0, 0];
400
+ const yUnitVec3 = [0, 1, 0];
401
+ return (a, b) => {
402
+ const dot = vec3.dot(a, b);
403
+ if (dot > 1 - Common.EPSILON) {
404
+ return identity;
405
+ }
406
+ else if (dot < -1 + Common.EPSILON) {
407
+ let temp = vec3.cross(xUnitVec3, a);
408
+ if (vec3.length(temp) < 0.000001) {
409
+ temp = vec3.cross(yUnitVec3, a);
410
+ }
411
+ temp = vec3.normalize(temp);
412
+ return setAxisAngle(temp, Math.PI);
413
+ }
414
+ else {
415
+ const tmp = vec3.cross(a, b);
416
+ const out = [tmp[0], tmp[1], tmp[2], 1 + dot];
417
+ return normalize(out);
418
+ }
419
+ };
420
+ })();
421
+ /**
422
+ * Performs a spherical linear interpolation with two control points
423
+ *
424
+ * @param a the first operand
425
+ * @param b the second operand
426
+ * @param c the third operand
427
+ * @param d the fourth operand
428
+ * @param t interpolation amount, in the range [0-1], between the two inputs
429
+ */
430
+ export function sqlerp(a, b, c, d, t) {
431
+ const temp1 = slerp(a, d, t);
432
+ const temp2 = slerp(b, c, t);
433
+ return slerp(temp1, temp2, 2 * t * (1 - t));
434
+ }
435
+ /**
436
+ * Sets the specified quaternion with values corresponding to the given
437
+ * axes. Each axis is a vec3 and is expected to be unit length and
438
+ * perpendicular to all other specified axes.
439
+ *
440
+ * @param view the vector representing the viewing direction
441
+ * @param right the vector representing the local "right" direction
442
+ * @param up the vector representing the local "up" direction
443
+ */
444
+ export function setAxes(view, right, up) {
445
+ const matr = [
446
+ right[0],
447
+ up[0],
448
+ -view[0],
449
+ right[1],
450
+ up[1],
451
+ -view[1],
452
+ right[2],
453
+ up[2],
454
+ -view[2],
455
+ ];
456
+ return normalize(fromMat3(matr));
457
+ }
458
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVhdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWF0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxNQUFNLE1BQU0sVUFBVSxDQUFBO0FBR2xDLE9BQU8sS0FBSyxJQUFJLE1BQU0sUUFBUSxDQUFBO0FBQzlCLE9BQU8sS0FBSyxJQUFJLE1BQU0sUUFBUSxDQUFBO0FBUzlCLE1BQU0sVUFBVSxFQUFFLENBQUMsQ0FBUyxFQUFFLENBQVMsRUFBRSxDQUFTLEVBQUUsQ0FBUztJQUM1RCxPQUFPLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUE7QUFDcEIsQ0FBQztBQUVEOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFTLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFBO0FBRXpEOzs7Ozs7SUFNSTtBQUNKLE1BQU0sVUFBVSxZQUFZLENBQUMsSUFBVSxFQUFFLEdBQVc7SUFDbkQsR0FBRyxHQUFHLEdBQUcsR0FBRyxHQUFHLENBQUE7SUFDZixNQUFNLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFBO0lBRXZCLE9BQU8sQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUE7QUFDOUQsQ0FBQztBQU9EOzs7Ozs7Ozs7OztHQVdHO0FBQ0gsTUFBTSxVQUFVLFlBQVksQ0FBQyxDQUFPO0lBQ25DLE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FB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
@@ -0,0 +1,66 @@
1
+ import { Mat2 } from './mat2';
2
+ import { Mat2d } from './mat2d';
3
+ import { Mat3 } from './mat3';
4
+ import { Vec3 } from './vec3';
5
+ export type Vec2 = readonly [number, number];
6
+ export declare function of(x: number, y?: number): Vec2;
7
+ export declare const zero: Vec2;
8
+ export declare const one: Vec2;
9
+ export declare function add(a: Vec2, b: Vec2): Vec2;
10
+ export declare function subtract(a: Vec2, b: Vec2): Vec2;
11
+ export declare function multiply(a: Vec2, b: Vec2): Vec2;
12
+ export declare function divide(a: Vec2, b: Vec2): Vec2;
13
+ export declare function ceil(a: Vec2): Vec2;
14
+ export declare function floor(a: Vec2): Vec2;
15
+ export declare function min(a: Vec2, b: Vec2): Vec2;
16
+ export declare function max(a: Vec2, b: Vec2): Vec2;
17
+ /**
18
+ * Constrain a value to lie between two further values
19
+ */
20
+ export declare function clamp(a: Vec2, min: Vec2, max: Vec2): Vec2;
21
+ /**
22
+ * symmetric round the components of a vec2
23
+ */
24
+ export declare function round(a: Vec2): Vec2;
25
+ export declare function scale(a: Vec2, s: number): Vec2;
26
+ /**
27
+ * Adds two vec2's after scaling the second operand by a scalar value
28
+ */
29
+ export declare function scaleAndAdd(a: Vec2, b: Vec2, scale: number): Vec2;
30
+ export declare function distance(a: Vec2, b: Vec2): number;
31
+ export declare function squaredDistance(a: Vec2, b: Vec2): number;
32
+ export declare function length(v: Vec2): number;
33
+ export declare function squaredLength(v: Vec2): number;
34
+ export declare function negate(v: Vec2): Vec2;
35
+ export declare function inverse(v: Vec2): Vec2;
36
+ export declare function normalize(v: Vec2): Vec2;
37
+ export declare function dot(a: Vec2, b: Vec2): number;
38
+ export declare function cross(a: Vec2, b: Vec2): Vec3;
39
+ /**
40
+ * Performs a linear interpolation between two Vec2's
41
+ */
42
+ export declare function lerp(a: Vec2, b: Vec2, t: number): Vec2;
43
+ export declare function transformMat2(a: Vec2, m: Mat2): Vec2;
44
+ export declare function transformMat2d(a: Vec2, m: Mat2d): Vec2;
45
+ /**
46
+ * Transforms the vec2 with a mat3
47
+ * 3rd vector component is implicitly '1'
48
+ */
49
+ export declare function transformMat3(a: Vec2, m: Mat3): Vec2;
50
+ /**
51
+ * Rotate a 2D vector
52
+ */
53
+ export declare function rotate(a: Vec2, origin: Vec2, rad: number): Vec2;
54
+ /**
55
+ * Get the angle between two 2D vectors
56
+ */
57
+ export declare function angle(a: Vec2, b: Vec2): number;
58
+ /**
59
+ * Returns whether or not the vectors exactly have the same elements in the same position (when compared with ===)
60
+ */
61
+ export declare function exactEquals(a: Vec2, b: Vec2): boolean;
62
+ /**
63
+ * Returns whether or not the vectors have approximately the same elements in the same position.
64
+ */
65
+ export declare function equals(a: Vec2, b: Vec2): boolean;
66
+ //# sourceMappingURL=vec2.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vec2.d.ts","sourceRoot":"","sources":["../../src/vec2.ts"],"names":[],"mappings":"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"}