@benev/math 0.1.0 → 0.2.0-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.
- package/README.md +110 -23
- package/package.json +3 -1
- package/s/{concepts → core}/quat.ts +56 -16
- package/s/{concepts → core}/vec2.ts +52 -38
- package/s/{concepts → core}/vec3.ts +57 -47
- package/s/{concepts → core}/vec4.ts +13 -16
- package/s/index.ts +25 -10
- package/s/optimizers/hash-map.ts +71 -0
- package/s/optimizers/hash-set.ts +50 -0
- package/s/optimizers/zen.ts +151 -0
- package/s/physics/2d/collide2d.ts +51 -0
- package/s/physics/2d/intersect2d.ts +80 -0
- package/s/shapes/2d/circle.ts +43 -0
- package/s/shapes/2d/edge.ts +3 -0
- package/s/shapes/2d/index.ts +6 -0
- package/s/shapes/2d/pill.ts +3 -0
- package/s/shapes/2d/rect.ts +74 -0
- package/s/shapes/3d/box.ts +84 -0
- package/s/shapes/3d/capsule.ts +3 -0
- package/s/shapes/3d/index.ts +6 -0
- package/s/shapes/3d/segment.ts +48 -0
- package/s/shapes/3d/sphere.ts +3 -0
- package/s/tools/angles.ts +49 -0
- package/s/{concepts → tools}/circular.ts +5 -3
- package/s/{concepts → tools}/randy.ts +0 -14
- package/s/{concepts → tools}/scalar.ts +11 -11
- package/s/{concepts → tools}/spline.ts +11 -10
- package/x/{concepts → core}/quat.d.ts +10 -5
- package/x/{concepts → core}/quat.js +49 -12
- package/x/core/quat.js.map +1 -0
- package/x/{concepts → core}/vec2.d.ts +16 -17
- package/x/{concepts → core}/vec2.js +37 -21
- package/x/core/vec2.js.map +1 -0
- package/x/{concepts → core}/vec3.d.ts +19 -20
- package/x/{concepts → core}/vec3.js +46 -27
- package/x/core/vec3.js.map +1 -0
- package/x/{concepts → core}/vec4.d.ts +5 -7
- package/x/{concepts → core}/vec4.js +12 -12
- package/x/core/vec4.js.map +1 -0
- package/x/index.d.ts +21 -10
- package/x/index.js +21 -10
- package/x/index.js.map +1 -1
- package/x/optimizers/hash-map.d.ts +17 -0
- package/x/optimizers/hash-map.js +55 -0
- package/x/optimizers/hash-map.js.map +1 -0
- package/x/optimizers/hash-set.d.ts +13 -0
- package/x/optimizers/hash-set.js +39 -0
- package/x/optimizers/hash-set.js.map +1 -0
- package/x/optimizers/zen.d.ts +33 -0
- package/x/optimizers/zen.js +121 -0
- package/x/optimizers/zen.js.map +1 -0
- package/x/physics/2d/collide2d.d.ts +8 -0
- package/x/physics/2d/collide2d.js +36 -0
- package/x/physics/2d/collide2d.js.map +1 -0
- package/x/physics/2d/intersect2d.d.ts +13 -0
- package/x/physics/2d/intersect2d.js +57 -0
- package/x/physics/2d/intersect2d.js.map +1 -0
- package/x/shapes/2d/circle.d.ts +18 -0
- package/x/shapes/2d/circle.js +34 -0
- package/x/shapes/2d/circle.js.map +1 -0
- package/x/shapes/2d/edge.d.ts +1 -0
- package/x/shapes/2d/edge.js +3 -0
- package/x/shapes/2d/edge.js.map +1 -0
- package/x/shapes/2d/index.d.ts +4 -0
- package/x/shapes/2d/index.js +5 -0
- package/x/shapes/2d/index.js.map +1 -0
- package/x/shapes/2d/pill.d.ts +1 -0
- package/x/shapes/2d/pill.js +3 -0
- package/x/shapes/2d/pill.js.map +1 -0
- package/x/shapes/2d/rect.d.ts +23 -0
- package/x/shapes/2d/rect.js +59 -0
- package/x/shapes/2d/rect.js.map +1 -0
- package/x/shapes/3d/box.d.ts +24 -0
- package/x/shapes/3d/box.js +68 -0
- package/x/shapes/3d/box.js.map +1 -0
- package/x/shapes/3d/capsule.d.ts +1 -0
- package/x/shapes/3d/capsule.js +3 -0
- package/x/shapes/3d/capsule.js.map +1 -0
- package/x/shapes/3d/index.d.ts +4 -0
- package/x/shapes/3d/index.js +5 -0
- package/x/shapes/3d/index.js.map +1 -0
- package/x/shapes/3d/segment.d.ts +13 -0
- package/x/shapes/3d/segment.js +37 -0
- package/x/shapes/3d/segment.js.map +1 -0
- package/x/shapes/3d/sphere.d.ts +1 -0
- package/x/shapes/3d/sphere.js +3 -0
- package/x/shapes/3d/sphere.js.map +1 -0
- package/x/{concepts → tools}/angles.d.ts +3 -13
- package/x/tools/angles.js +41 -0
- package/x/tools/angles.js.map +1 -0
- package/x/{concepts → tools}/circular.js +4 -3
- package/x/tools/circular.js.map +1 -0
- package/x/tools/noise.js.map +1 -0
- package/x/{concepts → tools}/randy.d.ts +0 -8
- package/x/{concepts → tools}/randy.js +0 -10
- package/x/tools/randy.js.map +1 -0
- package/x/{concepts → tools}/scalar.d.ts +4 -4
- package/x/{concepts → tools}/scalar.js +11 -11
- package/x/tools/scalar.js.map +1 -0
- package/x/{concepts → tools}/spline.d.ts +3 -3
- package/x/{concepts → tools}/spline.js +3 -1
- package/x/tools/spline.js.map +1 -0
- package/s/concepts/angles.ts +0 -74
- package/x/concepts/angles.js +0 -62
- package/x/concepts/angles.js.map +0 -1
- package/x/concepts/circular.js.map +0 -1
- package/x/concepts/noise.js.map +0 -1
- package/x/concepts/quat.js.map +0 -1
- package/x/concepts/randy.js.map +0 -1
- package/x/concepts/scalar.js.map +0 -1
- package/x/concepts/spline.js.map +0 -1
- package/x/concepts/vec2.js.map +0 -1
- package/x/concepts/vec3.js.map +0 -1
- package/x/concepts/vec4.js.map +0 -1
- /package/s/{concepts → tools}/noise.ts +0 -0
- /package/x/{concepts → tools}/circular.d.ts +0 -0
- /package/x/{concepts → tools}/noise.d.ts +0 -0
- /package/x/{concepts → tools}/noise.js +0 -0
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { MapG } from "@e280/stz";
|
|
2
|
+
import { Vec2 } from "../core/vec2.js";
|
|
3
|
+
import { Rect } from "../shapes/2d/rect.js";
|
|
4
|
+
import { rectVsRect } from "../physics/2d/collide2d.js";
|
|
5
|
+
export class Zen {
|
|
6
|
+
grid;
|
|
7
|
+
rect;
|
|
8
|
+
item;
|
|
9
|
+
zones = new Set();
|
|
10
|
+
constructor(grid, rect, item) {
|
|
11
|
+
this.grid = grid;
|
|
12
|
+
this.rect = rect;
|
|
13
|
+
this.item = item;
|
|
14
|
+
}
|
|
15
|
+
update() {
|
|
16
|
+
this.grid.update(this);
|
|
17
|
+
}
|
|
18
|
+
delete() {
|
|
19
|
+
this.grid.delete(this);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
export class ZenZone {
|
|
23
|
+
hash;
|
|
24
|
+
rect;
|
|
25
|
+
zens = new Set();
|
|
26
|
+
constructor(hash, center, size) {
|
|
27
|
+
this.hash = hash;
|
|
28
|
+
this.rect = Rect.fromCenter(center, size);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
export class ZenGrid {
|
|
32
|
+
zoneExtent;
|
|
33
|
+
#zones = new MapG();
|
|
34
|
+
constructor(zoneExtent) {
|
|
35
|
+
this.zoneExtent = zoneExtent;
|
|
36
|
+
}
|
|
37
|
+
count() {
|
|
38
|
+
let n = 0;
|
|
39
|
+
for (const zone of this.#zones.values())
|
|
40
|
+
n += zone.zens.size;
|
|
41
|
+
return n;
|
|
42
|
+
}
|
|
43
|
+
create(rect, item) {
|
|
44
|
+
const zen = new Zen(this, rect, item);
|
|
45
|
+
this.update(zen);
|
|
46
|
+
return zen;
|
|
47
|
+
}
|
|
48
|
+
update(zen) {
|
|
49
|
+
const wantedZones = this.#selectZones(zen.rect);
|
|
50
|
+
// delete stale zones
|
|
51
|
+
for (const zone of zen.zones) {
|
|
52
|
+
if (!wantedZones.has(zone)) {
|
|
53
|
+
zen.zones.delete(zone);
|
|
54
|
+
zone.zens.delete(zen);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
// add fresh zones
|
|
58
|
+
for (const zone of wantedZones) {
|
|
59
|
+
if (!zen.zones.has(zone)) {
|
|
60
|
+
zone.zens.add(zen);
|
|
61
|
+
zen.zones.add(zone);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
delete(zen) {
|
|
66
|
+
const emptyZones = [];
|
|
67
|
+
for (const zone of zen.zones) {
|
|
68
|
+
zone.zens.delete(zen);
|
|
69
|
+
if (zone.zens.size === 0)
|
|
70
|
+
emptyZones.push(zone);
|
|
71
|
+
}
|
|
72
|
+
for (const emptyZone of emptyZones)
|
|
73
|
+
this.#zones.delete(emptyZone.hash);
|
|
74
|
+
}
|
|
75
|
+
check(rect) {
|
|
76
|
+
const zones = this.#selectZones(rect);
|
|
77
|
+
for (const zone of zones)
|
|
78
|
+
for (const zen of zone.zens)
|
|
79
|
+
if (rectVsRect(rect, zen.rect))
|
|
80
|
+
return true;
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
/** return set of zens that touch the given rect */
|
|
84
|
+
query(rect) {
|
|
85
|
+
const zones = this.#selectZones(rect);
|
|
86
|
+
const selected = new Set();
|
|
87
|
+
for (const zone of zones)
|
|
88
|
+
for (const zen of zone.zens)
|
|
89
|
+
if (!selected.has(zen) && rectVsRect(rect, zen.rect))
|
|
90
|
+
selected.add(zen);
|
|
91
|
+
return selected;
|
|
92
|
+
}
|
|
93
|
+
/** return all zen items that touch the given rect */
|
|
94
|
+
queryItems(rect) {
|
|
95
|
+
return [...this.query(rect)].map(zen => zen.item);
|
|
96
|
+
}
|
|
97
|
+
/** return all zen rects that touch the given rect */
|
|
98
|
+
queryRects(rect) {
|
|
99
|
+
return [...this.query(rect)].map(zen => zen.rect);
|
|
100
|
+
}
|
|
101
|
+
#hash(v) {
|
|
102
|
+
return `${v.x},${v.y}`;
|
|
103
|
+
}
|
|
104
|
+
#calculateZoneCorner(point) {
|
|
105
|
+
return new Vec2(Math.floor(point.x / this.zoneExtent.x), Math.floor(point.y / this.zoneExtent.y)).multiply(this.zoneExtent);
|
|
106
|
+
}
|
|
107
|
+
#obtainZone(zoneCorner) {
|
|
108
|
+
const hash = this.#hash(zoneCorner);
|
|
109
|
+
return this.#zones.guarantee(hash, () => new ZenZone(hash, zoneCorner.clone().add(this.zoneExtent.clone().half()), this.zoneExtent));
|
|
110
|
+
}
|
|
111
|
+
#selectZones(rect) {
|
|
112
|
+
const zones = new Set();
|
|
113
|
+
const minZoneCorner = this.#calculateZoneCorner(rect.min);
|
|
114
|
+
const maxZoneCorner = this.#calculateZoneCorner(rect.max);
|
|
115
|
+
for (let x = minZoneCorner.x; x <= maxZoneCorner.x; x += this.zoneExtent.x)
|
|
116
|
+
for (let y = minZoneCorner.y; y <= maxZoneCorner.y; y += this.zoneExtent.y)
|
|
117
|
+
zones.add(this.#obtainZone(new Vec2(x, y)));
|
|
118
|
+
return zones;
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
//# sourceMappingURL=zen.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"zen.js","sourceRoot":"","sources":["../../s/optimizers/zen.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Vec2 } from "../../core/vec2.js";
|
|
2
|
+
import { Rect } from "../../shapes/2d/rect.js";
|
|
3
|
+
import { Circle } from "../../shapes/2d/circle.js";
|
|
4
|
+
export declare function pointVsRect(point: Vec2, box: Rect): boolean;
|
|
5
|
+
export declare function pointVsCircle(point: Vec2, circle: Circle): boolean;
|
|
6
|
+
export declare function rectVsRect(a: Rect, b: Rect): boolean;
|
|
7
|
+
export declare function rectVsCircle(rect: Rect, circle: Circle): boolean;
|
|
8
|
+
export declare function circleVsCircle(circleA: Circle, circleB: Circle): boolean;
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { Vec2 } from "../../core/vec2.js";
|
|
2
|
+
import { Scalar } from "../../tools/scalar.js";
|
|
3
|
+
export function pointVsRect(point, box) {
|
|
4
|
+
const { min, max } = box;
|
|
5
|
+
return (point.x >= min.x &&
|
|
6
|
+
point.x <= max.x &&
|
|
7
|
+
point.y >= min.y &&
|
|
8
|
+
point.y <= max.y);
|
|
9
|
+
}
|
|
10
|
+
export function pointVsCircle(point, circle) {
|
|
11
|
+
const dx = point.x - circle.center.x;
|
|
12
|
+
const dy = point.y - circle.center.y;
|
|
13
|
+
const distanceSquared = (dx ** 2) + (dy ** 2);
|
|
14
|
+
return distanceSquared <= (circle.radius ** 2);
|
|
15
|
+
}
|
|
16
|
+
export function rectVsRect(a, b) {
|
|
17
|
+
return !(a.max.x <= b.min.x ||
|
|
18
|
+
a.min.x >= b.max.x ||
|
|
19
|
+
a.max.y <= b.min.y ||
|
|
20
|
+
a.min.y >= b.max.y);
|
|
21
|
+
}
|
|
22
|
+
export function rectVsCircle(rect, circle) {
|
|
23
|
+
const clamped = new Vec2(Scalar.clamp(circle.center.x, rect.min.x, rect.max.x), Scalar.clamp(circle.center.y, rect.min.y, rect.max.y));
|
|
24
|
+
const difference = circle.center.clone().subtract(clamped);
|
|
25
|
+
const distanceSquared = (difference.x ** 2) + (difference.y ** 2);
|
|
26
|
+
const radiusSquared = circle.radius ** 2;
|
|
27
|
+
return distanceSquared <= radiusSquared;
|
|
28
|
+
}
|
|
29
|
+
export function circleVsCircle(circleA, circleB) {
|
|
30
|
+
const dx = circleB.center.x - circleA.center.x;
|
|
31
|
+
const dy = circleB.center.y - circleA.center.y;
|
|
32
|
+
const distanceSquared = (dx ** 2) + (dy ** 2);
|
|
33
|
+
const radiusSum = circleA.radius + circleB.radius;
|
|
34
|
+
return distanceSquared <= (radiusSum ** 2);
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=collide2d.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collide2d.js","sourceRoot":"","sources":["../../../s/physics/2d/collide2d.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Vec2 } from "../../core/vec2.js";
|
|
2
|
+
import { Rect } from "../../shapes/2d/rect.js";
|
|
3
|
+
import { Circle } from "../../shapes/2d/circle.js";
|
|
4
|
+
export declare class Intersection {
|
|
5
|
+
contactPoint: Vec2;
|
|
6
|
+
depth: number;
|
|
7
|
+
normalA: Vec2;
|
|
8
|
+
normalB: Vec2;
|
|
9
|
+
constructor(contactPoint: Vec2, depth: number, normalA: Vec2, normalB: Vec2);
|
|
10
|
+
}
|
|
11
|
+
export declare function intersectRectVsRect(a: Rect, b: Rect): Intersection | null;
|
|
12
|
+
export declare function intersectRectVsCircle(rect: Rect, circle: Circle): Intersection | null;
|
|
13
|
+
export declare function intersectCircleVsCircle(a: Circle, b: Circle): Intersection | null;
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { Vec2 } from "../../core/vec2.js";
|
|
2
|
+
import { Scalar } from "../../tools/scalar.js";
|
|
3
|
+
import { rectVsCircle, rectVsRect } from "./collide2d.js";
|
|
4
|
+
export class Intersection {
|
|
5
|
+
contactPoint;
|
|
6
|
+
depth;
|
|
7
|
+
normalA;
|
|
8
|
+
normalB;
|
|
9
|
+
constructor(contactPoint, depth, normalA, normalB) {
|
|
10
|
+
this.contactPoint = contactPoint;
|
|
11
|
+
this.depth = depth;
|
|
12
|
+
this.normalA = normalA;
|
|
13
|
+
this.normalB = normalB;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
export function intersectRectVsRect(a, b) {
|
|
17
|
+
if (!rectVsRect(a, b))
|
|
18
|
+
return null;
|
|
19
|
+
const overlapX = Math.min(a.max.x - b.min.x, b.max.x - a.min.x);
|
|
20
|
+
const overlapY = Math.min(a.max.y - b.min.y, b.max.y - a.min.y);
|
|
21
|
+
const depth = Math.min(overlapX, overlapY);
|
|
22
|
+
const aCenter = a.center();
|
|
23
|
+
const bCenter = b.center();
|
|
24
|
+
const contactPoint = new Vec2(Scalar.clamp((aCenter.x + bCenter.x) / 2, b.min.x, b.max.x), Scalar.clamp((aCenter.y + bCenter.y) / 2, b.min.y, b.max.y));
|
|
25
|
+
const normalA = depth === overlapX
|
|
26
|
+
? new Vec2(bCenter.x > aCenter.x ? -1 : 1, 0)
|
|
27
|
+
: new Vec2(0, bCenter.y > aCenter.y ? -1 : 1);
|
|
28
|
+
const normalB = normalA.clone().multiplyBy(-1);
|
|
29
|
+
return new Intersection(contactPoint, depth, normalA, normalB);
|
|
30
|
+
}
|
|
31
|
+
export function intersectRectVsCircle(rect, circle) {
|
|
32
|
+
if (!rectVsCircle(rect, circle))
|
|
33
|
+
return null;
|
|
34
|
+
const clamped = new Vec2(Scalar.clamp(circle.center.x, rect.min.x, rect.max.x), Scalar.clamp(circle.center.y, rect.min.y, rect.max.y));
|
|
35
|
+
const difference = circle.center.clone().subtract(clamped);
|
|
36
|
+
const distance = difference.magnitude();
|
|
37
|
+
const depth = circle.radius - distance;
|
|
38
|
+
const contactPoint = clamped;
|
|
39
|
+
const normalA = difference.normalize();
|
|
40
|
+
const normalB = normalA.clone().multiplyBy(-1);
|
|
41
|
+
return new Intersection(contactPoint, depth, normalA, normalB);
|
|
42
|
+
}
|
|
43
|
+
export function intersectCircleVsCircle(a, b) {
|
|
44
|
+
const dx = b.center.x - a.center.x;
|
|
45
|
+
const dy = b.center.y - a.center.y;
|
|
46
|
+
const distance = Math.sqrt(dx ** 2 + dy ** 2);
|
|
47
|
+
if (distance >= a.radius + b.radius)
|
|
48
|
+
return null;
|
|
49
|
+
const depth = Math.max(0, a.radius + b.radius - distance);
|
|
50
|
+
const normalA = distance === 0
|
|
51
|
+
? new Vec2(1, 0) // fallback for perfectly overlapping circles
|
|
52
|
+
: new Vec2(dx / distance, dy / distance);
|
|
53
|
+
const normalB = normalA.clone().multiplyBy(-1);
|
|
54
|
+
const contactPoint = new Vec2((a.center.x + b.center.x) / 2, (a.center.y + b.center.y) / 2);
|
|
55
|
+
return new Intersection(contactPoint, depth, normalA, normalB);
|
|
56
|
+
}
|
|
57
|
+
//# sourceMappingURL=intersect2d.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"intersect2d.js","sourceRoot":"","sources":["../../../s/physics/2d/intersect2d.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Rect } from "./rect.js";
|
|
2
|
+
import { Vec2, XyArray, Xy } from "../../core/vec2.js";
|
|
3
|
+
export type CircleJson = [center: XyArray, radius: number];
|
|
4
|
+
export type CircleLike = {
|
|
5
|
+
center: Xy;
|
|
6
|
+
radius: number;
|
|
7
|
+
};
|
|
8
|
+
export declare class Circle {
|
|
9
|
+
center: Vec2;
|
|
10
|
+
radius: number;
|
|
11
|
+
constructor(center: Vec2, radius: number);
|
|
12
|
+
static from(data: CircleJson | CircleLike): Circle;
|
|
13
|
+
toJSON(): CircleJson;
|
|
14
|
+
clone(): Circle;
|
|
15
|
+
set(circle: CircleLike): void;
|
|
16
|
+
translate(delta: Vec2): this;
|
|
17
|
+
boundingBox(): Rect;
|
|
18
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { Rect } from "./rect.js";
|
|
2
|
+
import { Vec2 } from "../../core/vec2.js";
|
|
3
|
+
export class Circle {
|
|
4
|
+
center;
|
|
5
|
+
radius;
|
|
6
|
+
constructor(center, radius) {
|
|
7
|
+
this.center = center;
|
|
8
|
+
this.radius = radius;
|
|
9
|
+
}
|
|
10
|
+
static from(data) {
|
|
11
|
+
return Array.isArray(data)
|
|
12
|
+
? new this(Vec2.from(data[0]), data[1])
|
|
13
|
+
: new this(Vec2.from(data.center), data.radius);
|
|
14
|
+
}
|
|
15
|
+
toJSON() {
|
|
16
|
+
return [this.center.clone().toJSON(), this.radius];
|
|
17
|
+
}
|
|
18
|
+
clone() {
|
|
19
|
+
return new Circle(this.center.clone(), this.radius);
|
|
20
|
+
}
|
|
21
|
+
set(circle) {
|
|
22
|
+
this.center.set(circle.center);
|
|
23
|
+
this.radius = circle.radius;
|
|
24
|
+
}
|
|
25
|
+
translate(delta) {
|
|
26
|
+
this.center.add(delta);
|
|
27
|
+
return this;
|
|
28
|
+
}
|
|
29
|
+
boundingBox() {
|
|
30
|
+
const size = Vec2.all(this.radius * 2);
|
|
31
|
+
return Rect.fromCenter(this.center.clone(), size);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=circle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"circle.js","sourceRoot":"","sources":["../../../s/shapes/2d/circle.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,IAAI,EAAC,MAAM,WAAW,CAAA;AAC9B,OAAO,EAAC,IAAI,EAAc,MAAM,oBAAoB,CAAA;AAKpD,MAAM,OAAO,MAAM;IAEV;IACA;IAFR,YACQ,MAAY,EACZ,MAAc;QADd,WAAM,GAAN,MAAM,CAAM;QACZ,WAAM,GAAN,MAAM,CAAQ;IACnB,CAAC;IAEJ,MAAM,CAAC,IAAI,CAAC,IAA6B;QACxC,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;YACzB,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;YACvC,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAA;IACjD,CAAC;IAED,MAAM;QACL,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,CAAA;IACnD,CAAC;IAED,KAAK;QACJ,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,CAAA;IACpD,CAAC;IAED,GAAG,CAAC,MAAkB;QACrB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;QAC9B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAA;IAC5B,CAAC;IAED,SAAS,CAAC,KAAW;QACpB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;QACtB,OAAO,IAAI,CAAA;IACZ,CAAC;IAED,WAAW;QACV,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;QACtC,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,CAAA;IAClD,CAAC;CACD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"edge.js","sourceRoot":"","sources":["../../../s/shapes/2d/edge.ts"],"names":[],"mappings":"AACA,OAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../s/shapes/2d/index.ts"],"names":[],"mappings":"AACA,cAAc,aAAa,CAAA;AAC3B,cAAc,WAAW,CAAA;AACzB,cAAc,WAAW,CAAA;AACzB,cAAc,WAAW,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pill.js","sourceRoot":"","sources":["../../../s/shapes/2d/pill.ts"],"names":[],"mappings":"AACA,OAAO"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { Vec2, XyArray, Xy } from "../../core/vec2.js";
|
|
2
|
+
export type RectJson = [min: XyArray, max: XyArray];
|
|
3
|
+
export type RectLike = {
|
|
4
|
+
min: Xy;
|
|
5
|
+
max: Xy;
|
|
6
|
+
};
|
|
7
|
+
export declare class Rect {
|
|
8
|
+
min: Vec2;
|
|
9
|
+
max: Vec2;
|
|
10
|
+
constructor(min: Vec2, max: Vec2);
|
|
11
|
+
static from(data: RectJson | RectLike): Rect;
|
|
12
|
+
static fromCorner(min: Vec2, size: Vec2): Rect;
|
|
13
|
+
static fromCenter(center: Vec2, size: Vec2): Rect;
|
|
14
|
+
clone(): Rect;
|
|
15
|
+
toJSON(): RectJson;
|
|
16
|
+
set(rect: RectLike): void;
|
|
17
|
+
normalize(): this;
|
|
18
|
+
size(): Vec2;
|
|
19
|
+
center(): Vec2;
|
|
20
|
+
translate(delta: Vec2): this;
|
|
21
|
+
contains(point: Vec2): boolean;
|
|
22
|
+
boundingBox(): Rect;
|
|
23
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { Vec2 } from "../../core/vec2.js";
|
|
2
|
+
import { pointVsRect } from "../../physics/2d/collide2d.js";
|
|
3
|
+
export class Rect {
|
|
4
|
+
min;
|
|
5
|
+
max;
|
|
6
|
+
constructor(min, max) {
|
|
7
|
+
this.min = min;
|
|
8
|
+
this.max = max;
|
|
9
|
+
}
|
|
10
|
+
static from(data) {
|
|
11
|
+
return Array.isArray(data)
|
|
12
|
+
? new this(Vec2.from(data[0]), Vec2.from(data[1]))
|
|
13
|
+
: new this(Vec2.from(data.min), Vec2.from(data.max));
|
|
14
|
+
}
|
|
15
|
+
static fromCorner(min, size) {
|
|
16
|
+
const max = min.clone().add(size);
|
|
17
|
+
return new this(min, max);
|
|
18
|
+
}
|
|
19
|
+
static fromCenter(center, size) {
|
|
20
|
+
const halfSize = size.clone().half();
|
|
21
|
+
const min = center.clone().subtract(halfSize);
|
|
22
|
+
const max = center.clone().add(halfSize);
|
|
23
|
+
return new this(min, max);
|
|
24
|
+
}
|
|
25
|
+
clone() {
|
|
26
|
+
return new Rect(this.min.clone(), this.max.clone());
|
|
27
|
+
}
|
|
28
|
+
toJSON() {
|
|
29
|
+
return [this.min.toJSON(), this.max.toJSON()];
|
|
30
|
+
}
|
|
31
|
+
set(rect) {
|
|
32
|
+
this.min.set(rect.min);
|
|
33
|
+
this.max.set(rect.max);
|
|
34
|
+
}
|
|
35
|
+
normalize() {
|
|
36
|
+
const { min, max } = this;
|
|
37
|
+
this.min.set(Vec2.min(min, max));
|
|
38
|
+
this.max.set(Vec2.max(min, max));
|
|
39
|
+
return this;
|
|
40
|
+
}
|
|
41
|
+
size() {
|
|
42
|
+
return this.max.clone().subtract(this.min);
|
|
43
|
+
}
|
|
44
|
+
center() {
|
|
45
|
+
return this.min.clone().add(this.size().half());
|
|
46
|
+
}
|
|
47
|
+
translate(delta) {
|
|
48
|
+
this.min.add(delta);
|
|
49
|
+
this.max.add(delta);
|
|
50
|
+
return this;
|
|
51
|
+
}
|
|
52
|
+
contains(point) {
|
|
53
|
+
return pointVsRect(point, this);
|
|
54
|
+
}
|
|
55
|
+
boundingBox() {
|
|
56
|
+
return this.clone();
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=rect.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rect.js","sourceRoot":"","sources":["../../../s/shapes/2d/rect.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Vec3, XyzArray, Xyz } from "../../core/vec3.js";
|
|
2
|
+
export type BoxJson = [min: XyzArray, max: XyzArray];
|
|
3
|
+
export type BoxLike = {
|
|
4
|
+
min: Xyz;
|
|
5
|
+
max: Xyz;
|
|
6
|
+
};
|
|
7
|
+
export declare class Box {
|
|
8
|
+
min: Vec3;
|
|
9
|
+
max: Vec3;
|
|
10
|
+
constructor(min: Vec3, max: Vec3);
|
|
11
|
+
static from(data: BoxJson | BoxLike): Box;
|
|
12
|
+
static fromCorner(min: Vec3, size: Vec3): Box;
|
|
13
|
+
static fromCenter(center: Vec3, size: Vec3): Box;
|
|
14
|
+
toJSON(): BoxJson;
|
|
15
|
+
clone(): Box;
|
|
16
|
+
set(box: BoxLike): void;
|
|
17
|
+
size(): Vec3;
|
|
18
|
+
center(): Vec3;
|
|
19
|
+
normalize(): this;
|
|
20
|
+
translate_(x: number, y: number, z: number): this;
|
|
21
|
+
translate(delta: Vec3): this;
|
|
22
|
+
grow(increase: Vec3): this;
|
|
23
|
+
growBy(increase: number): this;
|
|
24
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { Vec3 } from "../../core/vec3.js";
|
|
2
|
+
export class Box {
|
|
3
|
+
min;
|
|
4
|
+
max;
|
|
5
|
+
constructor(min, max) {
|
|
6
|
+
this.min = min;
|
|
7
|
+
this.max = max;
|
|
8
|
+
}
|
|
9
|
+
static from(data) {
|
|
10
|
+
return Array.isArray(data)
|
|
11
|
+
? new this(Vec3.from(data[0]), Vec3.from(data[1]))
|
|
12
|
+
: new this(Vec3.from(data.min), Vec3.from(data.max));
|
|
13
|
+
}
|
|
14
|
+
static fromCorner(min, size) {
|
|
15
|
+
return new this(min, min.clone().add(size));
|
|
16
|
+
}
|
|
17
|
+
static fromCenter(center, size) {
|
|
18
|
+
const halfSize = size.clone().half();
|
|
19
|
+
const min = center.clone().subtract(halfSize);
|
|
20
|
+
const max = center.clone().add(halfSize);
|
|
21
|
+
return new this(min, max);
|
|
22
|
+
}
|
|
23
|
+
toJSON() {
|
|
24
|
+
return [this.min.toJSON(), this.max.toJSON()];
|
|
25
|
+
}
|
|
26
|
+
clone() {
|
|
27
|
+
return new Box(this.min.clone(), this.max.clone());
|
|
28
|
+
}
|
|
29
|
+
set(box) {
|
|
30
|
+
this.min.set(box.min);
|
|
31
|
+
this.max.set(box.max);
|
|
32
|
+
}
|
|
33
|
+
size() {
|
|
34
|
+
return this.max.clone().subtract(this.min);
|
|
35
|
+
}
|
|
36
|
+
center() {
|
|
37
|
+
return this.min.clone().add(this.size().half());
|
|
38
|
+
}
|
|
39
|
+
normalize() {
|
|
40
|
+
const { min, max } = this;
|
|
41
|
+
this.min.set(Vec3.min(min, max));
|
|
42
|
+
this.max.set(Vec3.max(min, max));
|
|
43
|
+
return this;
|
|
44
|
+
}
|
|
45
|
+
translate_(x, y, z) {
|
|
46
|
+
this.min.add_(x, y, z);
|
|
47
|
+
this.max.add_(x, y, z);
|
|
48
|
+
return this;
|
|
49
|
+
}
|
|
50
|
+
translate(delta) {
|
|
51
|
+
this.min.add(delta);
|
|
52
|
+
this.max.add(delta);
|
|
53
|
+
return this;
|
|
54
|
+
}
|
|
55
|
+
grow(increase) {
|
|
56
|
+
const halfIncrease = increase.clone().half();
|
|
57
|
+
this.min.subtract(halfIncrease);
|
|
58
|
+
this.max.add(halfIncrease);
|
|
59
|
+
return this;
|
|
60
|
+
}
|
|
61
|
+
growBy(increase) {
|
|
62
|
+
const halfIncrease = increase / 2;
|
|
63
|
+
this.min.subtractBy(halfIncrease);
|
|
64
|
+
this.max.addBy(halfIncrease);
|
|
65
|
+
return this;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=box.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"box.js","sourceRoot":"","sources":["../../../s/shapes/3d/box.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"capsule.js","sourceRoot":"","sources":["../../../s/shapes/3d/capsule.ts"],"names":[],"mappings":"AACA,OAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../s/shapes/3d/index.ts"],"names":[],"mappings":"AACA,cAAc,UAAU,CAAA;AACxB,cAAc,cAAc,CAAA;AAC5B,cAAc,cAAc,CAAA;AAC5B,cAAc,aAAa,CAAA"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Vec3 } from "../../core/vec3.js";
|
|
2
|
+
export declare class Segment {
|
|
3
|
+
start: Vec3;
|
|
4
|
+
end: Vec3;
|
|
5
|
+
constructor(start: Vec3, end: Vec3);
|
|
6
|
+
vector(): Vec3;
|
|
7
|
+
length(): number;
|
|
8
|
+
center(): Vec3;
|
|
9
|
+
clone(): Segment;
|
|
10
|
+
fromStart(length: number): Vec3;
|
|
11
|
+
point(fraction: number): Vec3;
|
|
12
|
+
scale(fraction: number): this;
|
|
13
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
export class Segment {
|
|
2
|
+
start;
|
|
3
|
+
end;
|
|
4
|
+
constructor(start, end) {
|
|
5
|
+
this.start = start;
|
|
6
|
+
this.end = end;
|
|
7
|
+
}
|
|
8
|
+
vector() {
|
|
9
|
+
return this.end.clone().subtract(this.start);
|
|
10
|
+
}
|
|
11
|
+
length() {
|
|
12
|
+
return this.start.distance(this.end);
|
|
13
|
+
}
|
|
14
|
+
center() {
|
|
15
|
+
return this.start.clone()
|
|
16
|
+
.add(this.end)
|
|
17
|
+
.half();
|
|
18
|
+
}
|
|
19
|
+
clone() {
|
|
20
|
+
return new Segment(this.start.clone(), this.end.clone());
|
|
21
|
+
}
|
|
22
|
+
fromStart(length) {
|
|
23
|
+
const direction = this.vector().normalize();
|
|
24
|
+
return this.start.clone().add(direction.multiplyBy(length));
|
|
25
|
+
}
|
|
26
|
+
point(fraction) {
|
|
27
|
+
return this.start.clone().add(this.vector().multiplyBy(fraction));
|
|
28
|
+
}
|
|
29
|
+
scale(fraction) {
|
|
30
|
+
const { center } = this;
|
|
31
|
+
const newHalfVector = this.vector().multiplyBy(fraction / 2);
|
|
32
|
+
this.start.set(center().subtract(newHalfVector));
|
|
33
|
+
this.end.set(center().add(newHalfVector));
|
|
34
|
+
return this;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=segment.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"segment.js","sourceRoot":"","sources":["../../../s/shapes/3d/segment.ts"],"names":[],"mappings":"AAGA,MAAM,OAAO,OAAO;IAEX;IACA;IAFR,YACQ,KAAW,EACX,GAAS;QADT,UAAK,GAAL,KAAK,CAAM;QACX,QAAG,GAAH,GAAG,CAAM;IACd,CAAC;IAEJ,MAAM;QACL,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAC7C,CAAC;IAED,MAAM;QACL,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IACrC,CAAC;IAED,MAAM;QACL,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE;aACvB,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC;aACb,IAAI,EAAE,CAAA;IACT,CAAC;IAED,KAAK;QACJ,OAAO,IAAI,OAAO,CACjB,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,EAClB,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAChB,CAAA;IACF,CAAC;IAED,SAAS,CAAC,MAAc;QACvB,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,SAAS,EAAE,CAAA;QAC3C,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAA;IAC5D,CAAC;IAED,KAAK,CAAC,QAAgB;QACrB,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAA;IAClE,CAAC;IAED,KAAK,CAAC,QAAgB;QACrB,MAAM,EAAC,MAAM,EAAC,GAAG,IAAI,CAAA;QACrB,MAAM,aAAa,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAA;QAC5D,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAA;QAChD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,CAAA;QACzC,OAAO,IAAI,CAAA;IACZ,CAAC;CACD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|