@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.
Files changed (118) hide show
  1. package/README.md +110 -23
  2. package/package.json +3 -1
  3. package/s/{concepts → core}/quat.ts +56 -16
  4. package/s/{concepts → core}/vec2.ts +52 -38
  5. package/s/{concepts → core}/vec3.ts +57 -47
  6. package/s/{concepts → core}/vec4.ts +13 -16
  7. package/s/index.ts +25 -10
  8. package/s/optimizers/hash-map.ts +71 -0
  9. package/s/optimizers/hash-set.ts +50 -0
  10. package/s/optimizers/zen.ts +151 -0
  11. package/s/physics/2d/collide2d.ts +51 -0
  12. package/s/physics/2d/intersect2d.ts +80 -0
  13. package/s/shapes/2d/circle.ts +43 -0
  14. package/s/shapes/2d/edge.ts +3 -0
  15. package/s/shapes/2d/index.ts +6 -0
  16. package/s/shapes/2d/pill.ts +3 -0
  17. package/s/shapes/2d/rect.ts +74 -0
  18. package/s/shapes/3d/box.ts +84 -0
  19. package/s/shapes/3d/capsule.ts +3 -0
  20. package/s/shapes/3d/index.ts +6 -0
  21. package/s/shapes/3d/segment.ts +48 -0
  22. package/s/shapes/3d/sphere.ts +3 -0
  23. package/s/tools/angles.ts +49 -0
  24. package/s/{concepts → tools}/circular.ts +5 -3
  25. package/s/{concepts → tools}/randy.ts +0 -14
  26. package/s/{concepts → tools}/scalar.ts +11 -11
  27. package/s/{concepts → tools}/spline.ts +11 -10
  28. package/x/{concepts → core}/quat.d.ts +10 -5
  29. package/x/{concepts → core}/quat.js +49 -12
  30. package/x/core/quat.js.map +1 -0
  31. package/x/{concepts → core}/vec2.d.ts +16 -17
  32. package/x/{concepts → core}/vec2.js +37 -21
  33. package/x/core/vec2.js.map +1 -0
  34. package/x/{concepts → core}/vec3.d.ts +19 -20
  35. package/x/{concepts → core}/vec3.js +46 -27
  36. package/x/core/vec3.js.map +1 -0
  37. package/x/{concepts → core}/vec4.d.ts +5 -7
  38. package/x/{concepts → core}/vec4.js +12 -12
  39. package/x/core/vec4.js.map +1 -0
  40. package/x/index.d.ts +21 -10
  41. package/x/index.js +21 -10
  42. package/x/index.js.map +1 -1
  43. package/x/optimizers/hash-map.d.ts +17 -0
  44. package/x/optimizers/hash-map.js +55 -0
  45. package/x/optimizers/hash-map.js.map +1 -0
  46. package/x/optimizers/hash-set.d.ts +13 -0
  47. package/x/optimizers/hash-set.js +39 -0
  48. package/x/optimizers/hash-set.js.map +1 -0
  49. package/x/optimizers/zen.d.ts +33 -0
  50. package/x/optimizers/zen.js +121 -0
  51. package/x/optimizers/zen.js.map +1 -0
  52. package/x/physics/2d/collide2d.d.ts +8 -0
  53. package/x/physics/2d/collide2d.js +36 -0
  54. package/x/physics/2d/collide2d.js.map +1 -0
  55. package/x/physics/2d/intersect2d.d.ts +13 -0
  56. package/x/physics/2d/intersect2d.js +57 -0
  57. package/x/physics/2d/intersect2d.js.map +1 -0
  58. package/x/shapes/2d/circle.d.ts +18 -0
  59. package/x/shapes/2d/circle.js +34 -0
  60. package/x/shapes/2d/circle.js.map +1 -0
  61. package/x/shapes/2d/edge.d.ts +1 -0
  62. package/x/shapes/2d/edge.js +3 -0
  63. package/x/shapes/2d/edge.js.map +1 -0
  64. package/x/shapes/2d/index.d.ts +4 -0
  65. package/x/shapes/2d/index.js +5 -0
  66. package/x/shapes/2d/index.js.map +1 -0
  67. package/x/shapes/2d/pill.d.ts +1 -0
  68. package/x/shapes/2d/pill.js +3 -0
  69. package/x/shapes/2d/pill.js.map +1 -0
  70. package/x/shapes/2d/rect.d.ts +23 -0
  71. package/x/shapes/2d/rect.js +59 -0
  72. package/x/shapes/2d/rect.js.map +1 -0
  73. package/x/shapes/3d/box.d.ts +24 -0
  74. package/x/shapes/3d/box.js +68 -0
  75. package/x/shapes/3d/box.js.map +1 -0
  76. package/x/shapes/3d/capsule.d.ts +1 -0
  77. package/x/shapes/3d/capsule.js +3 -0
  78. package/x/shapes/3d/capsule.js.map +1 -0
  79. package/x/shapes/3d/index.d.ts +4 -0
  80. package/x/shapes/3d/index.js +5 -0
  81. package/x/shapes/3d/index.js.map +1 -0
  82. package/x/shapes/3d/segment.d.ts +13 -0
  83. package/x/shapes/3d/segment.js +37 -0
  84. package/x/shapes/3d/segment.js.map +1 -0
  85. package/x/shapes/3d/sphere.d.ts +1 -0
  86. package/x/shapes/3d/sphere.js +3 -0
  87. package/x/shapes/3d/sphere.js.map +1 -0
  88. package/x/{concepts → tools}/angles.d.ts +3 -13
  89. package/x/tools/angles.js +41 -0
  90. package/x/tools/angles.js.map +1 -0
  91. package/x/{concepts → tools}/circular.js +4 -3
  92. package/x/tools/circular.js.map +1 -0
  93. package/x/tools/noise.js.map +1 -0
  94. package/x/{concepts → tools}/randy.d.ts +0 -8
  95. package/x/{concepts → tools}/randy.js +0 -10
  96. package/x/tools/randy.js.map +1 -0
  97. package/x/{concepts → tools}/scalar.d.ts +4 -4
  98. package/x/{concepts → tools}/scalar.js +11 -11
  99. package/x/tools/scalar.js.map +1 -0
  100. package/x/{concepts → tools}/spline.d.ts +3 -3
  101. package/x/{concepts → tools}/spline.js +3 -1
  102. package/x/tools/spline.js.map +1 -0
  103. package/s/concepts/angles.ts +0 -74
  104. package/x/concepts/angles.js +0 -62
  105. package/x/concepts/angles.js.map +0 -1
  106. package/x/concepts/circular.js.map +0 -1
  107. package/x/concepts/noise.js.map +0 -1
  108. package/x/concepts/quat.js.map +0 -1
  109. package/x/concepts/randy.js.map +0 -1
  110. package/x/concepts/scalar.js.map +0 -1
  111. package/x/concepts/spline.js.map +0 -1
  112. package/x/concepts/vec2.js.map +0 -1
  113. package/x/concepts/vec3.js.map +0 -1
  114. package/x/concepts/vec4.js.map +0 -1
  115. /package/s/{concepts → tools}/noise.ts +0 -0
  116. /package/x/{concepts → tools}/circular.d.ts +0 -0
  117. /package/x/{concepts → tools}/noise.d.ts +0 -0
  118. /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,3 @@
1
+ // TODO
2
+ export {};
3
+ //# sourceMappingURL=edge.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"edge.js","sourceRoot":"","sources":["../../../s/shapes/2d/edge.ts"],"names":[],"mappings":"AACA,OAAO"}
@@ -0,0 +1,4 @@
1
+ export * from "./circle.js";
2
+ export * from "./edge.js";
3
+ export * from "./pill.js";
4
+ export * from "./rect.js";
@@ -0,0 +1,5 @@
1
+ export * from "./circle.js";
2
+ export * from "./edge.js";
3
+ export * from "./pill.js";
4
+ export * from "./rect.js";
5
+ //# sourceMappingURL=index.js.map
@@ -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,3 @@
1
+ // TODO
2
+ export {};
3
+ //# sourceMappingURL=pill.js.map
@@ -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,3 @@
1
+ // TODO
2
+ export {};
3
+ //# sourceMappingURL=capsule.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"capsule.js","sourceRoot":"","sources":["../../../s/shapes/3d/capsule.ts"],"names":[],"mappings":"AACA,OAAO"}
@@ -0,0 +1,4 @@
1
+ export * from "./box.js";
2
+ export * from "./capsule.js";
3
+ export * from "./segment.js";
4
+ export * from "./sphere.js";
@@ -0,0 +1,5 @@
1
+ export * from "./box.js";
2
+ export * from "./capsule.js";
3
+ export * from "./segment.js";
4
+ export * from "./sphere.js";
5
+ //# sourceMappingURL=index.js.map
@@ -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 {};