@ntf/math 1.1.3 → 1.3.0
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.
- package/dist/index.cjs +2536 -0
- package/dist/index.d.cts +738 -0
- package/dist/index.d.mts +738 -0
- package/dist/index.mjs +2489 -0
- package/package.json +19 -12
- package/dist/cjs/algebra/function.js +0 -7
- package/dist/cjs/algebra/function.js.map +0 -1
- package/dist/cjs/algebra/linear.js +0 -42
- package/dist/cjs/algebra/linear.js.map +0 -1
- package/dist/cjs/algebra/quad.js +0 -53
- package/dist/cjs/algebra/quad.js.map +0 -1
- package/dist/cjs/color.js +0 -232
- package/dist/cjs/color.js.map +0 -1
- package/dist/cjs/common/error.js +0 -14
- package/dist/cjs/common/error.js.map +0 -1
- package/dist/cjs/common/sign.js +0 -14
- package/dist/cjs/common/sign.js.map +0 -1
- package/dist/cjs/common/types.js +0 -77
- package/dist/cjs/common/types.js.map +0 -1
- package/dist/cjs/geometry/angle.js +0 -11
- package/dist/cjs/geometry/angle.js.map +0 -1
- package/dist/cjs/geometry/bbox.js +0 -87
- package/dist/cjs/geometry/bbox.js.map +0 -1
- package/dist/cjs/geometry/circle.js +0 -64
- package/dist/cjs/geometry/circle.js.map +0 -1
- package/dist/cjs/geometry/object.js +0 -3
- package/dist/cjs/geometry/object.js.map +0 -1
- package/dist/cjs/geometry/rectangle.js +0 -83
- package/dist/cjs/geometry/rectangle.js.map +0 -1
- package/dist/cjs/geometry/square.js +0 -66
- package/dist/cjs/geometry/square.js.map +0 -1
- package/dist/cjs/geometry/triangle.js +0 -65
- package/dist/cjs/geometry/triangle.js.map +0 -1
- package/dist/cjs/index.js +0 -59
- package/dist/cjs/index.js.map +0 -1
- package/dist/cjs/matrices/mat3.js +0 -184
- package/dist/cjs/matrices/mat3.js.map +0 -1
- package/dist/cjs/matrices/mat4.js +0 -275
- package/dist/cjs/matrices/mat4.js.map +0 -1
- package/dist/cjs/quaternion.js +0 -196
- package/dist/cjs/quaternion.js.map +0 -1
- package/dist/cjs/vectors/vec2.js +0 -154
- package/dist/cjs/vectors/vec2.js.map +0 -1
- package/dist/cjs/vectors/vec3.js +0 -161
- package/dist/cjs/vectors/vec3.js.map +0 -1
- package/dist/esm/algebra/function.js +0 -3
- package/dist/esm/algebra/function.js.map +0 -1
- package/dist/esm/algebra/linear.js +0 -38
- package/dist/esm/algebra/linear.js.map +0 -1
- package/dist/esm/algebra/quad.js +0 -49
- package/dist/esm/algebra/quad.js.map +0 -1
- package/dist/esm/color.js +0 -226
- package/dist/esm/color.js.map +0 -1
- package/dist/esm/common/error.js +0 -10
- package/dist/esm/common/error.js.map +0 -1
- package/dist/esm/common/sign.js +0 -10
- package/dist/esm/common/sign.js.map +0 -1
- package/dist/esm/common/types.js +0 -65
- package/dist/esm/common/types.js.map +0 -1
- package/dist/esm/geometry/angle.js +0 -5
- package/dist/esm/geometry/angle.js.map +0 -1
- package/dist/esm/geometry/bbox.js +0 -83
- package/dist/esm/geometry/bbox.js.map +0 -1
- package/dist/esm/geometry/circle.js +0 -60
- package/dist/esm/geometry/circle.js.map +0 -1
- package/dist/esm/geometry/object.js +0 -2
- package/dist/esm/geometry/object.js.map +0 -1
- package/dist/esm/geometry/rectangle.js +0 -79
- package/dist/esm/geometry/rectangle.js.map +0 -1
- package/dist/esm/geometry/square.js +0 -62
- package/dist/esm/geometry/square.js.map +0 -1
- package/dist/esm/geometry/triangle.js +0 -59
- package/dist/esm/geometry/triangle.js.map +0 -1
- package/dist/esm/index.js +0 -40
- package/dist/esm/index.js.map +0 -1
- package/dist/esm/matrices/mat3.js +0 -180
- package/dist/esm/matrices/mat3.js.map +0 -1
- package/dist/esm/matrices/mat4.js +0 -271
- package/dist/esm/matrices/mat4.js.map +0 -1
- package/dist/esm/quaternion.js +0 -192
- package/dist/esm/quaternion.js.map +0 -1
- package/dist/esm/vectors/vec2.js +0 -150
- package/dist/esm/vectors/vec2.js.map +0 -1
- package/dist/esm/vectors/vec3.js +0 -157
- package/dist/esm/vectors/vec3.js.map +0 -1
- package/dist/types/algebra/function.d.ts +0 -6
- package/dist/types/algebra/function.d.ts.map +0 -1
- package/dist/types/algebra/linear.d.ts +0 -14
- package/dist/types/algebra/linear.d.ts.map +0 -1
- package/dist/types/algebra/quad.d.ts +0 -18
- package/dist/types/algebra/quad.d.ts.map +0 -1
- package/dist/types/color.d.ts +0 -87
- package/dist/types/color.d.ts.map +0 -1
- package/dist/types/common/error.d.ts +0 -6
- package/dist/types/common/error.d.ts.map +0 -1
- package/dist/types/common/sign.d.ts +0 -2
- package/dist/types/common/sign.d.ts.map +0 -1
- package/dist/types/common/types.d.ts +0 -26
- package/dist/types/common/types.d.ts.map +0 -1
- package/dist/types/geometry/angle.d.ts +0 -5
- package/dist/types/geometry/angle.d.ts.map +0 -1
- package/dist/types/geometry/bbox.d.ts +0 -35
- package/dist/types/geometry/bbox.d.ts.map +0 -1
- package/dist/types/geometry/circle.d.ts +0 -26
- package/dist/types/geometry/circle.d.ts.map +0 -1
- package/dist/types/geometry/object.d.ts +0 -5
- package/dist/types/geometry/object.d.ts.map +0 -1
- package/dist/types/geometry/rectangle.d.ts +0 -31
- package/dist/types/geometry/rectangle.d.ts.map +0 -1
- package/dist/types/geometry/square.d.ts +0 -27
- package/dist/types/geometry/square.d.ts.map +0 -1
- package/dist/types/geometry/triangle.d.ts +0 -42
- package/dist/types/geometry/triangle.d.ts.map +0 -1
- package/dist/types/index.d.ts +0 -23
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/matrices/mat3.d.ts +0 -58
- package/dist/types/matrices/mat3.d.ts.map +0 -1
- package/dist/types/matrices/mat4.d.ts +0 -85
- package/dist/types/matrices/mat4.d.ts.map +0 -1
- package/dist/types/quaternion.d.ts +0 -49
- package/dist/types/quaternion.d.ts.map +0 -1
- package/dist/types/vectors/vec2.d.ts +0 -56
- package/dist/types/vectors/vec2.d.ts.map +0 -1
- package/dist/types/vectors/vec3.d.ts +0 -55
- package/dist/types/vectors/vec3.d.ts.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"bbox.js","sourceRoot":"","sources":["../../../source/geometry/bbox.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,64 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Circle = void 0;
|
|
4
|
-
const error_1 = require("../common/error");
|
|
5
|
-
const types_1 = require("../common/types");
|
|
6
|
-
const vec2_1 = require("../vectors/vec2");
|
|
7
|
-
class Circle {
|
|
8
|
-
radius;
|
|
9
|
-
get perimeter() { return this.radius * Math.PI * 2; }
|
|
10
|
-
get area() { return Math.PI * Math.pow(this.radius, 2); }
|
|
11
|
-
position;
|
|
12
|
-
get x() { return this.position.x; }
|
|
13
|
-
set x(val) { this.position.x = val; }
|
|
14
|
-
get y() { return this.position.y; }
|
|
15
|
-
set y(val) { this.position.y = val; }
|
|
16
|
-
get w() { return this.position.w; }
|
|
17
|
-
set w(val) { this.position.w = val; }
|
|
18
|
-
static resolve(a) {
|
|
19
|
-
if (a == null || typeof a == "undefined")
|
|
20
|
-
throw new error_1.ResolveError("Circle", a);
|
|
21
|
-
if ((0, types_1.check_number_array)(a, 3))
|
|
22
|
-
return new this([a[0], a[1]], a[2]);
|
|
23
|
-
if ((0, types_1.check_number_array)(a, 4)) {
|
|
24
|
-
const c = new this([a[0], a[1]], a[3]);
|
|
25
|
-
c.w = a[2];
|
|
26
|
-
return c;
|
|
27
|
-
}
|
|
28
|
-
if ((0, types_1.has_property)(a, "x", "number") && (0, types_1.has_property)(a, "y", "number") && (0, types_1.has_property)(a, "radius", "number"))
|
|
29
|
-
return new this((0, types_1.has_property)(a, "w", "number") ? [a.x, a.y, a.w] : [a.x, a.y], a.radius);
|
|
30
|
-
if ((0, types_1.check_string)(a)) {
|
|
31
|
-
const [spos, sradius] = a.split("|");
|
|
32
|
-
const pos = vec2_1.Vec2.resolve(spos);
|
|
33
|
-
const radius = parseFloat(sradius);
|
|
34
|
-
if (!isNaN(radius))
|
|
35
|
-
return new this(pos, radius);
|
|
36
|
-
}
|
|
37
|
-
throw new error_1.ResolveError("Circle", a);
|
|
38
|
-
}
|
|
39
|
-
static is(a) {
|
|
40
|
-
try {
|
|
41
|
-
this.resolve(a);
|
|
42
|
-
}
|
|
43
|
-
catch (e) {
|
|
44
|
-
return false;
|
|
45
|
-
}
|
|
46
|
-
return true;
|
|
47
|
-
}
|
|
48
|
-
constructor(position, radius) {
|
|
49
|
-
this.radius = radius;
|
|
50
|
-
this.position = vec2_1.Vec2.resolve(position);
|
|
51
|
-
}
|
|
52
|
-
inside(a) {
|
|
53
|
-
const circle = Circle.resolve(a);
|
|
54
|
-
const distX = circle.x - this.x;
|
|
55
|
-
const distY = circle.y - this.y;
|
|
56
|
-
const dist = Math.sqrt((distX * distX) + (distY + distY));
|
|
57
|
-
return dist <= this.radius + circle.radius;
|
|
58
|
-
}
|
|
59
|
-
insidePoint(a) {
|
|
60
|
-
return this.position.distance(a) <= this.radius;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
exports.Circle = Circle;
|
|
64
|
-
//# sourceMappingURL=circle.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"circle.js","sourceRoot":"","sources":["../../../source/geometry/circle.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"object.js","sourceRoot":"","sources":["../../../source/geometry/object.ts"],"names":[],"mappings":""}
|
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Rectangle = void 0;
|
|
4
|
-
const error_1 = require("../common/error");
|
|
5
|
-
const types_1 = require("../common/types");
|
|
6
|
-
const vec2_1 = require("../vectors/vec2");
|
|
7
|
-
const bbox_1 = require("./bbox");
|
|
8
|
-
const square_1 = require("./square");
|
|
9
|
-
class Rectangle {
|
|
10
|
-
position;
|
|
11
|
-
size;
|
|
12
|
-
get x() { return this.position.x; }
|
|
13
|
-
set x(val) { this.position.x = val; }
|
|
14
|
-
get y() { return this.position.y; }
|
|
15
|
-
set y(val) { this.position.y = val; }
|
|
16
|
-
get w() { return this.position.w; }
|
|
17
|
-
set w(val) { this.position.w = val; }
|
|
18
|
-
get width() { return this.size.width; }
|
|
19
|
-
set width(val) { this.size.width = val; }
|
|
20
|
-
get height() { return this.size.height; }
|
|
21
|
-
set height(val) { this.size.height = val; }
|
|
22
|
-
static resolve(a) {
|
|
23
|
-
if (a == null || typeof a == "undefined")
|
|
24
|
-
throw new error_1.ResolveError("Rectangle", a);
|
|
25
|
-
if ((0, types_1.check_number_array)(a, 4))
|
|
26
|
-
return new this(a[0], a[1], a[2], a[3]);
|
|
27
|
-
if ((0, types_1.check_number_array)(a, 5)) {
|
|
28
|
-
const rect = new this(a[0], a[1], a[3], a[4]);
|
|
29
|
-
rect.w = a[2];
|
|
30
|
-
return rect;
|
|
31
|
-
}
|
|
32
|
-
if ((0, types_1.check_string)(a)) {
|
|
33
|
-
const [spos, ssize] = a.split("|");
|
|
34
|
-
const pos = vec2_1.Vec2.resolve(spos);
|
|
35
|
-
const size = square_1.Square.resolve(ssize);
|
|
36
|
-
const rect = new this(pos.x, pos.y, size.width, size.height);
|
|
37
|
-
rect.w = pos.w;
|
|
38
|
-
return rect;
|
|
39
|
-
}
|
|
40
|
-
if ((0, types_1.has_property)(a, "x", "number") && (0, types_1.has_property)(a, "y", "number") && (0, types_1.has_property)(a, "width", "number") && (0, types_1.has_property)(a, "height", "number")) {
|
|
41
|
-
const rect = new this(a.x, a.y, a.width, a.height);
|
|
42
|
-
if ((0, types_1.has_property)(a, "w", "number"))
|
|
43
|
-
rect.w = a.w;
|
|
44
|
-
return rect;
|
|
45
|
-
}
|
|
46
|
-
throw new error_1.ResolveError("Rectangle", a);
|
|
47
|
-
}
|
|
48
|
-
static is(a) {
|
|
49
|
-
try {
|
|
50
|
-
this.resolve(a);
|
|
51
|
-
}
|
|
52
|
-
catch (e) {
|
|
53
|
-
return false;
|
|
54
|
-
}
|
|
55
|
-
return true;
|
|
56
|
-
}
|
|
57
|
-
constructor(a, b, c, d) {
|
|
58
|
-
const vec = vec2_1.Vec2.is(a) ? vec2_1.Vec2.resolve(a) : undefined;
|
|
59
|
-
const size = square_1.Square.is(b) ? square_1.Square.resolve(b) : undefined;
|
|
60
|
-
const x = typeof a == "number" ? a : vec?.x;
|
|
61
|
-
const y = typeof b == "number" ? b : vec?.y;
|
|
62
|
-
const width = typeof c == "number" ? c : size?.width;
|
|
63
|
-
const height = typeof d == "number" ? d : size?.height;
|
|
64
|
-
if (!x || !y || !width || !height)
|
|
65
|
-
throw new TypeError;
|
|
66
|
-
this.position = new vec2_1.Vec2(x, y);
|
|
67
|
-
this.size = new square_1.Square(width, height);
|
|
68
|
-
}
|
|
69
|
-
toArray(w = false) {
|
|
70
|
-
return [...this.position.toArray(w), ...this.size.toArray()];
|
|
71
|
-
}
|
|
72
|
-
toString(w = false) {
|
|
73
|
-
return `${this.position.toString(w)}|${this.size.toString()}`;
|
|
74
|
-
}
|
|
75
|
-
toJSON() {
|
|
76
|
-
return { ...this.position.toJSON(), ...this.size.toJSON() };
|
|
77
|
-
}
|
|
78
|
-
toBoundingBox() {
|
|
79
|
-
return new bbox_1.BoundingBox(this.x, this.x + this.width, this.y, this.y + this.height);
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
exports.Rectangle = Rectangle;
|
|
83
|
-
//# sourceMappingURL=rectangle.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rectangle.js","sourceRoot":"","sources":["../../../source/geometry/rectangle.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Square = void 0;
|
|
4
|
-
const error_1 = require("../common/error");
|
|
5
|
-
const types_1 = require("../common/types");
|
|
6
|
-
const vec2_1 = require("../vectors/vec2");
|
|
7
|
-
class Square {
|
|
8
|
-
width;
|
|
9
|
-
height;
|
|
10
|
-
get aspectRatio() { return this.height / this.width; }
|
|
11
|
-
get area() { return this.width * this.height; }
|
|
12
|
-
get perimeter() { return this.width + this.width + this.height + this.height; }
|
|
13
|
-
static resolve(a) {
|
|
14
|
-
if (a == null || typeof a == "undefined")
|
|
15
|
-
throw new error_1.ResolveError("Square", a);
|
|
16
|
-
if ((0, types_1.check_number_array)(a, 2))
|
|
17
|
-
return new this(a[0], a[1]);
|
|
18
|
-
if ((0, types_1.has_property)(a, "width", "number") && (0, types_1.has_property)(a, "height", "number"))
|
|
19
|
-
return new this(a.width, a.height);
|
|
20
|
-
if ((0, types_1.check_string)(a)) {
|
|
21
|
-
const parts = a.split("x").map((v) => parseFloat(v));
|
|
22
|
-
if ((0, types_1.check_number_array)(parts, 2))
|
|
23
|
-
return this.resolve(parts);
|
|
24
|
-
}
|
|
25
|
-
if ((0, types_1.check_number)(a))
|
|
26
|
-
return new this(a, a);
|
|
27
|
-
throw new error_1.ResolveError("Square", a);
|
|
28
|
-
}
|
|
29
|
-
static fromVector(a) {
|
|
30
|
-
const vec = vec2_1.Vec2.resolve(a);
|
|
31
|
-
return new this(vec.x, vec.y);
|
|
32
|
-
}
|
|
33
|
-
static is(a) {
|
|
34
|
-
try {
|
|
35
|
-
this.resolve(a);
|
|
36
|
-
}
|
|
37
|
-
catch (e) {
|
|
38
|
-
return false;
|
|
39
|
-
}
|
|
40
|
-
return true;
|
|
41
|
-
}
|
|
42
|
-
constructor(width, height) {
|
|
43
|
-
this.width = width;
|
|
44
|
-
this.height = height;
|
|
45
|
-
}
|
|
46
|
-
toArray() {
|
|
47
|
-
return [this.width, this.height];
|
|
48
|
-
}
|
|
49
|
-
toString() {
|
|
50
|
-
return `${this.width}x${this.height}`;
|
|
51
|
-
}
|
|
52
|
-
toJSON() {
|
|
53
|
-
return {
|
|
54
|
-
width: this.width,
|
|
55
|
-
height: this.height
|
|
56
|
-
};
|
|
57
|
-
}
|
|
58
|
-
clone() {
|
|
59
|
-
return new Square(this.width, this.height);
|
|
60
|
-
}
|
|
61
|
-
toVector() {
|
|
62
|
-
return new vec2_1.Vec2(this.width, this.height);
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
exports.Square = Square;
|
|
66
|
-
//# sourceMappingURL=square.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"square.js","sourceRoot":"","sources":["../../../source/geometry/square.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Triangle3D = exports.Triangle2D = exports.ATriangle = void 0;
|
|
4
|
-
const vec2_1 = require("../vectors/vec2");
|
|
5
|
-
const vec3_1 = require("../vectors/vec3");
|
|
6
|
-
class ATriangle {
|
|
7
|
-
A;
|
|
8
|
-
B;
|
|
9
|
-
C;
|
|
10
|
-
constructor(A, B, C) {
|
|
11
|
-
this.A = A;
|
|
12
|
-
this.B = B;
|
|
13
|
-
this.C = C;
|
|
14
|
-
}
|
|
15
|
-
get alpha() {
|
|
16
|
-
return Math.acos((this.b * this.b + this.c * this.c - this.a * this.a) / (2 * this.b * this.c));
|
|
17
|
-
}
|
|
18
|
-
get beta() {
|
|
19
|
-
return Math.acos((this.c * this.c + this.a * this.a - this.b * this.b) / (2 * this.c * this.a));
|
|
20
|
-
}
|
|
21
|
-
get gamma() {
|
|
22
|
-
return Math.acos((this.a * this.a + this.b * this.b - this.c * this.c) / (2 * this.a * this.b));
|
|
23
|
-
}
|
|
24
|
-
get perimeter() {
|
|
25
|
-
return this.a + this.b + this.c;
|
|
26
|
-
}
|
|
27
|
-
get semiperimeter() {
|
|
28
|
-
return this.perimeter / 2;
|
|
29
|
-
}
|
|
30
|
-
get area() {
|
|
31
|
-
return Math.sqrt(this.semiperimeter * (this.semiperimeter - this.a) * (this.semiperimeter - this.b) * (this.semiperimeter - this.c));
|
|
32
|
-
}
|
|
33
|
-
get base() {
|
|
34
|
-
return 2 * (this.area / (this.a * Math.sin(this.gamma)));
|
|
35
|
-
}
|
|
36
|
-
get height() {
|
|
37
|
-
return 2 * (this.area / this.base);
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
exports.ATriangle = ATriangle;
|
|
41
|
-
class Triangle2D extends ATriangle {
|
|
42
|
-
get a() {
|
|
43
|
-
return vec2_1.Vec2.fromPoints(this.B, this.C).length();
|
|
44
|
-
}
|
|
45
|
-
get b() {
|
|
46
|
-
return vec2_1.Vec2.fromPoints(this.A, this.C).length();
|
|
47
|
-
}
|
|
48
|
-
get c() {
|
|
49
|
-
return vec2_1.Vec2.fromPoints(this.A, this.B).length();
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
exports.Triangle2D = Triangle2D;
|
|
53
|
-
class Triangle3D extends ATriangle {
|
|
54
|
-
get a() {
|
|
55
|
-
return vec3_1.Vec3.fromPoints(this.B, this.C).length();
|
|
56
|
-
}
|
|
57
|
-
get b() {
|
|
58
|
-
return vec3_1.Vec3.fromPoints(this.A, this.C).length();
|
|
59
|
-
}
|
|
60
|
-
get c() {
|
|
61
|
-
return vec3_1.Vec3.fromPoints(this.A, this.B).length();
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
exports.Triangle3D = Triangle3D;
|
|
65
|
-
//# sourceMappingURL=triangle.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"triangle.js","sourceRoot":"","sources":["../../../source/geometry/triangle.ts"],"names":[],"mappings":"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"}
|
package/dist/cjs/index.js
DELETED
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.EPSILON = exports.clamp = exports.log_hypot = void 0;
|
|
18
|
-
__exportStar(require("./algebra/function"), exports);
|
|
19
|
-
__exportStar(require("./algebra/linear"), exports);
|
|
20
|
-
__exportStar(require("./algebra/quad"), exports);
|
|
21
|
-
__exportStar(require("./common/error"), exports);
|
|
22
|
-
__exportStar(require("./common/sign"), exports);
|
|
23
|
-
__exportStar(require("./common/types"), exports);
|
|
24
|
-
__exportStar(require("./geometry/angle"), exports);
|
|
25
|
-
__exportStar(require("./geometry/bbox"), exports);
|
|
26
|
-
__exportStar(require("./geometry/circle"), exports);
|
|
27
|
-
__exportStar(require("./geometry/object"), exports);
|
|
28
|
-
__exportStar(require("./geometry/rectangle"), exports);
|
|
29
|
-
__exportStar(require("./geometry/square"), exports);
|
|
30
|
-
__exportStar(require("./geometry/triangle"), exports);
|
|
31
|
-
__exportStar(require("./matrices/mat3"), exports);
|
|
32
|
-
__exportStar(require("./matrices/mat4"), exports);
|
|
33
|
-
__exportStar(require("./vectors/vec2"), exports);
|
|
34
|
-
__exportStar(require("./vectors/vec3"), exports);
|
|
35
|
-
__exportStar(require("./quaternion"), exports);
|
|
36
|
-
__exportStar(require("./color"), exports);
|
|
37
|
-
function log_hypot(a, b) {
|
|
38
|
-
const a_abs = Math.abs(a);
|
|
39
|
-
const b_abs = Math.abs(b);
|
|
40
|
-
if (a == 0)
|
|
41
|
-
return Math.log(b_abs);
|
|
42
|
-
if (b == 0)
|
|
43
|
-
return Math.log(a_abs);
|
|
44
|
-
if (a_abs < 3000 && b_abs < 3000)
|
|
45
|
-
return 0.5 * Math.log(a * a + b * b);
|
|
46
|
-
const _a = a / 2, _b = b / 2;
|
|
47
|
-
return 0.5 * Math.log(_a * _a + _b * _b) + Math.LN2;
|
|
48
|
-
}
|
|
49
|
-
exports.log_hypot = log_hypot;
|
|
50
|
-
function clamp(value, min, max) {
|
|
51
|
-
if (value <= min)
|
|
52
|
-
return min;
|
|
53
|
-
if (value >= max)
|
|
54
|
-
return max;
|
|
55
|
-
return value;
|
|
56
|
-
}
|
|
57
|
-
exports.clamp = clamp;
|
|
58
|
-
exports.EPSILON = 1e-16;
|
|
59
|
-
//# sourceMappingURL=index.js.map
|
package/dist/cjs/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../source/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,qDAAkC;AAClC,mDAAgC;AAChC,iDAA8B;AAC9B,iDAA8B;AAC9B,gDAA6B;AAC7B,iDAA8B;AAC9B,mDAAgC;AAChC,kDAA+B;AAC/B,oDAAiC;AACjC,oDAAiC;AACjC,uDAAoC;AACpC,oDAAiC;AACjC,sDAAmC;AACnC,kDAA+B;AAC/B,kDAA+B;AAC/B,iDAA8B;AAC9B,iDAA8B;AAC9B,+CAA4B;AAC5B,0CAAuB;AAEvB,SAAgB,SAAS,CAAC,CAAS,EAAC,CAAS;IAEzC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;IACzB,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;IACzB,IAAG,CAAC,IAAI,CAAC;QACL,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;IAC1B,IAAG,CAAC,IAAI,CAAC;QACL,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;IAC1B,IAAG,KAAK,GAAG,IAAI,IAAI,KAAK,GAAG,IAAI;QAC3B,OAAO,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAC,CAAC,GAAC,CAAC,GAAC,CAAC,CAAC,CAAA;IAClC,MAAM,EAAE,GAAG,CAAC,GAAC,CAAC,EAAE,EAAE,GAAG,CAAC,GAAC,CAAC,CAAA;IACxB,OAAO,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAC,EAAE,GAAC,EAAE,GAAC,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAA;AACjD,CAAC;AAZD,8BAYC;AAED,SAAgB,KAAK,CAA4B,KAAQ,EAAC,GAAM,EAAC,GAAM;IAEnE,IAAG,KAAK,IAAI,GAAG;QACX,OAAO,GAAG,CAAA;IACd,IAAG,KAAK,IAAI,GAAG;QACX,OAAO,GAAG,CAAA;IACd,OAAO,KAAK,CAAA;AAChB,CAAC;AAPD,sBAOC;AAEY,QAAA,OAAO,GAAG,KAAK,CAAA"}
|
|
@@ -1,184 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Mat3 = void 0;
|
|
4
|
-
const error_1 = require("../common/error");
|
|
5
|
-
const types_1 = require("../common/types");
|
|
6
|
-
const vec2_1 = require("../vectors/vec2");
|
|
7
|
-
class Mat3 {
|
|
8
|
-
_raw;
|
|
9
|
-
get m00() { return this._raw[0]; }
|
|
10
|
-
set m00(val) { this._raw[0] = val; }
|
|
11
|
-
get m01() { return this._raw[1]; }
|
|
12
|
-
set m01(val) { this._raw[1] = val; }
|
|
13
|
-
get m02() { return this._raw[2]; }
|
|
14
|
-
set m02(val) { this._raw[2] = val; }
|
|
15
|
-
get m10() { return this._raw[3]; }
|
|
16
|
-
set m10(val) { this._raw[3] = val; }
|
|
17
|
-
get m11() { return this._raw[4]; }
|
|
18
|
-
set m11(val) { this._raw[4] = val; }
|
|
19
|
-
get m12() { return this._raw[5]; }
|
|
20
|
-
set m12(val) { this._raw[5] = val; }
|
|
21
|
-
get m20() { return this._raw[6]; }
|
|
22
|
-
set m20(val) { this._raw[6] = val; }
|
|
23
|
-
get m21() { return this._raw[7]; }
|
|
24
|
-
set m21(val) { this._raw[7] = val; }
|
|
25
|
-
get m22() { return this._raw[8]; }
|
|
26
|
-
set m22(val) { this._raw[8] = val; }
|
|
27
|
-
static resolve(a) {
|
|
28
|
-
if (a == null || typeof a == "undefined")
|
|
29
|
-
throw new error_1.ResolveError("Mat3", a);
|
|
30
|
-
if ((0, types_1.check_number_array)(a, 9)) {
|
|
31
|
-
return new this(a);
|
|
32
|
-
}
|
|
33
|
-
if ((0, types_1.check_array)(a, undefined, 3)) {
|
|
34
|
-
const row0 = a[0], row1 = a[1], row2 = a[2];
|
|
35
|
-
if ((0, types_1.check_number_array)(row0, 3) && (0, types_1.check_number_array)(row1, 3) && (0, types_1.check_number_array)(row2, 3))
|
|
36
|
-
return new this([
|
|
37
|
-
row0[0], row0[1], row0[2],
|
|
38
|
-
row1[0], row1[1], row1[2],
|
|
39
|
-
row2[0], row2[1], row2[2],
|
|
40
|
-
]);
|
|
41
|
-
}
|
|
42
|
-
if ((0, types_1.check_string)(a)) {
|
|
43
|
-
const parts = a.split(",");
|
|
44
|
-
if ((0, types_1.check_string_array)(parts, 9))
|
|
45
|
-
return this.resolve(parts.map((i) => parseFloat(i)));
|
|
46
|
-
}
|
|
47
|
-
if ((0, types_1.has_property)(a, "m00", "number") && (0, types_1.has_property)(a, "m01", "number") && (0, types_1.has_property)(a, "m02", "number") &&
|
|
48
|
-
(0, types_1.has_property)(a, "m10", "number") && (0, types_1.has_property)(a, "m11", "number") && (0, types_1.has_property)(a, "m12", "number") &&
|
|
49
|
-
(0, types_1.has_property)(a, "m20", "number") && (0, types_1.has_property)(a, "m21", "number") && (0, types_1.has_property)(a, "m22", "number"))
|
|
50
|
-
return new this([
|
|
51
|
-
a.m00, a.m01, a.m02,
|
|
52
|
-
a.m10, a.m11, a.m12,
|
|
53
|
-
a.m20, a.m21, a.m22
|
|
54
|
-
]);
|
|
55
|
-
if ((0, types_1.check_number)(a)) {
|
|
56
|
-
return new this([a, a, a, a, a, a, a, a, a]);
|
|
57
|
-
}
|
|
58
|
-
throw new error_1.ResolveError("Mat3", a);
|
|
59
|
-
}
|
|
60
|
-
static is(a) {
|
|
61
|
-
try {
|
|
62
|
-
this.resolve(a);
|
|
63
|
-
}
|
|
64
|
-
catch (e) {
|
|
65
|
-
return false;
|
|
66
|
-
}
|
|
67
|
-
return true;
|
|
68
|
-
}
|
|
69
|
-
static projection(width, height) {
|
|
70
|
-
return new this([
|
|
71
|
-
2 / width, 0, 0,
|
|
72
|
-
0, -2 / height, 0,
|
|
73
|
-
-1, 1, 1
|
|
74
|
-
]);
|
|
75
|
-
}
|
|
76
|
-
constructor(init = [1, 0, 0, 0, 1, 0, 0, 0, 1]) {
|
|
77
|
-
this._raw = init;
|
|
78
|
-
}
|
|
79
|
-
toArray() {
|
|
80
|
-
return [
|
|
81
|
-
this.m00, this.m01, this.m02,
|
|
82
|
-
this.m10, this.m11, this.m12,
|
|
83
|
-
this.m20, this.m21, this.m22
|
|
84
|
-
];
|
|
85
|
-
}
|
|
86
|
-
toNestetArray() {
|
|
87
|
-
return [
|
|
88
|
-
[this.m00, this.m01, this.m02],
|
|
89
|
-
[this.m10, this.m11, this.m12],
|
|
90
|
-
[this.m20, this.m21, this.m22]
|
|
91
|
-
];
|
|
92
|
-
}
|
|
93
|
-
toJSON() {
|
|
94
|
-
return {
|
|
95
|
-
m00: this.m00, m01: this.m01, m02: this.m02,
|
|
96
|
-
m10: this.m10, m11: this.m11, m12: this.m12,
|
|
97
|
-
m20: this.m20, m21: this.m21, m22: this.m22
|
|
98
|
-
};
|
|
99
|
-
}
|
|
100
|
-
toString() {
|
|
101
|
-
return `${this.m00},${this.m01},${this.m02},${this.m10},${this.m11},${this.m12},${this.m20},${this.m21},${this.m22}`;
|
|
102
|
-
}
|
|
103
|
-
clone() {
|
|
104
|
-
return new Mat3([
|
|
105
|
-
this.m00, this.m01, this.m02,
|
|
106
|
-
this.m10, this.m11, this.m12,
|
|
107
|
-
this.m20, this.m21, this.m22
|
|
108
|
-
]);
|
|
109
|
-
}
|
|
110
|
-
add(mat) {
|
|
111
|
-
const b = Mat3.resolve(mat);
|
|
112
|
-
const m = new Mat3;
|
|
113
|
-
for (let index = 0; index < this._raw.length; index++)
|
|
114
|
-
m._raw[index] = this._raw[index] + b._raw[index];
|
|
115
|
-
return this;
|
|
116
|
-
}
|
|
117
|
-
subtract(mat) {
|
|
118
|
-
const b = Mat3.resolve(mat);
|
|
119
|
-
const m = new Mat3;
|
|
120
|
-
for (let index = 0; index < this._raw.length; index++)
|
|
121
|
-
m._raw[index] = this._raw[index] - b._raw[index];
|
|
122
|
-
return this;
|
|
123
|
-
}
|
|
124
|
-
multiply(a) {
|
|
125
|
-
if ((0, types_1.check_number)(a))
|
|
126
|
-
return new Mat3([
|
|
127
|
-
this.m00 * a, this.m01 * a, this.m02 * a,
|
|
128
|
-
this.m10 * a, this.m11 * a, this.m12 * a,
|
|
129
|
-
this.m20 * a, this.m21 * a, this.m22 * a
|
|
130
|
-
]);
|
|
131
|
-
const b = Mat3.resolve(a);
|
|
132
|
-
return new Mat3([
|
|
133
|
-
b.m00 * this.m00 + b.m01 * this.m10 + b.m02 * this.m20,
|
|
134
|
-
b.m00 * this.m01 + b.m01 * this.m11 + b.m02 * this.m21,
|
|
135
|
-
b.m00 * this.m02 + b.m01 * this.m12 + b.m02 * this.m22,
|
|
136
|
-
b.m10 * this.m00 + b.m11 * this.m10 + b.m12 * this.m20,
|
|
137
|
-
b.m10 * this.m01 + b.m11 * this.m11 + b.m12 * this.m21,
|
|
138
|
-
b.m10 * this.m02 + b.m11 * this.m12 + b.m12 * this.m22,
|
|
139
|
-
b.m20 * this.m00 + b.m21 * this.m10 + b.m22 * this.m20,
|
|
140
|
-
b.m20 * this.m01 + b.m21 * this.m11 + b.m22 * this.m21,
|
|
141
|
-
b.m20 * this.m02 + b.m21 * this.m12 + b.m22 * this.m22
|
|
142
|
-
]);
|
|
143
|
-
}
|
|
144
|
-
translate(...args) {
|
|
145
|
-
const vec = vec2_1.Vec2.resolveArgs(args);
|
|
146
|
-
return this.multiply([
|
|
147
|
-
1, 0, 0,
|
|
148
|
-
0, 1, 0,
|
|
149
|
-
vec.x, vec.y, 1
|
|
150
|
-
]);
|
|
151
|
-
}
|
|
152
|
-
rotate(angle) {
|
|
153
|
-
const c = Math.cos(angle);
|
|
154
|
-
const s = Math.sin(angle);
|
|
155
|
-
return this.multiply([
|
|
156
|
-
c, -s, 0,
|
|
157
|
-
s, c, 0,
|
|
158
|
-
0, 0, 1
|
|
159
|
-
]);
|
|
160
|
-
}
|
|
161
|
-
scale(...args) {
|
|
162
|
-
const vec = vec2_1.Vec2.resolve(args);
|
|
163
|
-
return this.multiply([
|
|
164
|
-
vec.x, 0, 0,
|
|
165
|
-
0, vec.y, 0,
|
|
166
|
-
0, 0, 1
|
|
167
|
-
]);
|
|
168
|
-
}
|
|
169
|
-
determinant() {
|
|
170
|
-
return this.m00 * this.m11 * this.m22 - this.m21 * this.m12 -
|
|
171
|
-
this.m01 * this.m10 * this.m22 - this.m12 * this.m20 +
|
|
172
|
-
this.m02 * this.m10 * this.m21 - this.m11 * this.m20;
|
|
173
|
-
}
|
|
174
|
-
inverse() {
|
|
175
|
-
const det = this.determinant();
|
|
176
|
-
return new Mat3([
|
|
177
|
-
(this.m11 * this.m22 - this.m21 * this.m12) * det, (this.m02 * this.m21 - this.m01 * this.m22) * det, (this.m01 * this.m12 - this.m02 * this.m11) * det,
|
|
178
|
-
(this.m12 * this.m20 - this.m10 * this.m22) * det, (this.m00 * this.m22 - this.m02 * this.m20) * det, (this.m10 * this.m02 - this.m00 * this.m12) * det,
|
|
179
|
-
(this.m10 * this.m21 - this.m20 * this.m11) * det, (this.m20 * this.m01 - this.m00 * this.m21) * det, (this.m00 * this.m11 - this.m10 * this.m01) * det
|
|
180
|
-
]);
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
exports.Mat3 = Mat3;
|
|
184
|
-
//# sourceMappingURL=mat3.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mat3.js","sourceRoot":"","sources":["../../../source/matrices/mat3.ts"],"names":[],"mappings":"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"}
|