@adobe/data 0.5.14 → 0.5.17
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/ecs/database/create-database.test.js +11 -0
- package/dist/ecs/database/create-database.test.js.map +1 -1
- package/dist/math/aabb/aabb.d.ts +42 -42
- package/dist/math/aabb/aabb.js +65 -62
- package/dist/math/aabb/aabb.js.map +1 -1
- package/dist/math/aabb-face/aabb-face.d.ts +59 -0
- package/dist/math/aabb-face/aabb-face.js +145 -0
- package/dist/math/aabb-face/aabb-face.js.map +1 -0
- package/dist/math/aabb-face/aabb-face.test.d.ts +1 -0
- package/dist/math/aabb-face/aabb-face.test.js +54 -0
- package/dist/math/aabb-face/aabb-face.test.js.map +1 -0
- package/dist/math/f32/f32.d.ts +8 -6
- package/dist/math/f32/f32.js +4 -1
- package/dist/math/f32/f32.js.map +1 -1
- package/dist/math/i32/i32.d.ts +9 -6
- package/dist/math/i32/i32.js +5 -2
- package/dist/math/i32/i32.js.map +1 -1
- package/dist/math/index.d.ts +13 -22
- package/dist/math/index.js +13 -22
- package/dist/math/index.js.map +1 -1
- package/dist/math/line2/line2.d.ts +36 -36
- package/dist/math/line2/line2.js +55 -52
- package/dist/math/line2/line2.js.map +1 -1
- package/dist/math/line3/line3.d.ts +48 -43
- package/dist/math/line3/line3.js +64 -52
- package/dist/math/line3/line3.js.map +1 -1
- package/dist/math/mat4x4/mat4x4.d.ts +34 -34
- package/dist/math/mat4x4/mat4x4.js +216 -213
- package/dist/math/mat4x4/mat4x4.js.map +1 -1
- package/dist/math/picking/get-closest-entity-to-line.d.ts +4 -0
- package/dist/math/picking/get-closest-entity-to-line.js +30 -0
- package/dist/math/picking/get-closest-entity-to-line.js.map +1 -0
- package/dist/math/picking/get-closest-entity-to-point.d.ts +4 -0
- package/dist/math/picking/get-closest-entity-to-point.js +27 -0
- package/dist/math/picking/get-closest-entity-to-point.js.map +1 -0
- package/dist/math/picking/get-intersecting-entities.d.ts +12 -0
- package/dist/math/picking/get-intersecting-entities.js +15 -0
- package/dist/math/picking/get-intersecting-entities.js.map +1 -0
- package/dist/math/picking/index.d.ts +4 -0
- package/dist/math/picking/index.js +4 -0
- package/dist/math/picking/index.js.map +1 -1
- package/dist/math/picking/pick-from-tables.d.ts +1 -0
- package/dist/math/picking/pick-from-tables.js +7 -98
- package/dist/math/picking/pick-from-tables.js.map +1 -1
- package/dist/math/picking/pick-result.d.ts +5 -2
- package/dist/math/plane/plane.d.ts +43 -0
- package/dist/math/plane/plane.js +70 -0
- package/dist/math/plane/plane.js.map +1 -0
- package/dist/math/plane/plane.test.d.ts +1 -0
- package/dist/math/plane/plane.test.js +132 -0
- package/dist/math/plane/plane.test.js.map +1 -0
- package/dist/math/quat/quat.d.ts +49 -39
- package/dist/math/quat/quat.js +225 -185
- package/dist/math/quat/quat.js.map +1 -1
- package/dist/math/u32/u32.d.ts +9 -7
- package/dist/math/u32/u32.js +4 -1
- package/dist/math/u32/u32.js.map +1 -1
- package/dist/math/vec2/vec2.d.ts +61 -61
- package/dist/math/vec2/vec2.js +93 -90
- package/dist/math/vec2/vec2.js.map +1 -1
- package/dist/math/vec3/vec3.d.ts +66 -63
- package/dist/math/vec3/vec3.js +137 -129
- package/dist/math/vec3/vec3.js.map +1 -1
- package/dist/math/vec4/vec4.d.ts +61 -61
- package/dist/math/vec4/vec4.js +132 -129
- package/dist/math/vec4/vec4.js.map +1 -1
- package/dist/observe/to-async-generator.js +4 -4
- package/dist/observe/to-async-generator.js.map +1 -1
- package/dist/old-ecs/action-ecs/action-ecs.test.js +1 -1
- package/dist/old-ecs/action-ecs/action-ecs.test.js.map +1 -1
- package/dist/old-ecs/action-ecs/action-types.d.ts +7 -0
- package/dist/old-ecs/action-ecs/action-types.js.map +1 -1
- package/dist/old-ecs/core-ecs/core-ecs-serialization.test.js +205 -1
- package/dist/old-ecs/core-ecs/core-ecs-serialization.test.js.map +1 -1
- package/dist/old-ecs/core-ecs/core-ecs-types.d.ts +4 -1
- package/dist/old-ecs/core-ecs/core-ecs.d.ts +2 -0
- package/dist/old-ecs/core-ecs/core-ecs.js +23 -9
- package/dist/old-ecs/core-ecs/core-ecs.js.map +1 -1
- package/dist/old-ecs/ecs/ecs-types.d.ts +7 -0
- package/dist/old-ecs/ecs/ecs.test.js +1 -1
- package/dist/old-ecs/ecs/ecs.test.js.map +1 -1
- package/dist/old-ecs/privacy/helper-functions.d.ts +43 -0
- package/dist/old-ecs/privacy/helper-functions.js +76 -0
- package/dist/old-ecs/privacy/helper-functions.js.map +1 -0
- package/dist/old-ecs/privacy/helper-functions.test.d.ts +1 -0
- package/dist/old-ecs/privacy/helper-functions.test.js +173 -0
- package/dist/old-ecs/privacy/helper-functions.test.js.map +1 -0
- package/dist/old-ecs/transaction-ecs/transaction-ecs.test.js +1 -1
- package/dist/old-ecs/transaction-ecs/transaction-ecs.test.js.map +1 -1
- package/dist/old-ecs/transaction-ecs/transaction-types.d.ts +7 -0
- package/dist/samples/todo/services/state-service/create-todo-database.d.ts +2 -2
- package/dist/samples/todo/services/state-service/create-todo-store.d.ts +2 -2
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +6 -3
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
/*MIT License
|
|
2
|
+
|
|
3
|
+
© Copyright 2025 Adobe. All rights reserved.
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.*/
|
|
22
|
+
import { Aabb } from "../index.js";
|
|
23
|
+
export var AabbFace;
|
|
24
|
+
(function (AabbFace) {
|
|
25
|
+
AabbFace.schema = {
|
|
26
|
+
type: 'number',
|
|
27
|
+
minimum: 0,
|
|
28
|
+
maximum: 5,
|
|
29
|
+
};
|
|
30
|
+
/**
|
|
31
|
+
* AABB face direction constants for cube faces
|
|
32
|
+
*/
|
|
33
|
+
AabbFace.POS_Z = 0;
|
|
34
|
+
AabbFace.POS_X = 1;
|
|
35
|
+
AabbFace.NEG_Z = 2;
|
|
36
|
+
AabbFace.NEG_X = 3;
|
|
37
|
+
AabbFace.POS_Y = 4;
|
|
38
|
+
AabbFace.NEG_Y = 5;
|
|
39
|
+
/**
|
|
40
|
+
* Array of all face directions
|
|
41
|
+
*/
|
|
42
|
+
AabbFace.ALL_FACES = [AabbFace.POS_Z, AabbFace.POS_X, AabbFace.NEG_Z, AabbFace.NEG_X, AabbFace.POS_Y, AabbFace.NEG_Y];
|
|
43
|
+
/**
|
|
44
|
+
* AABB face direction names for debugging/logging
|
|
45
|
+
*/
|
|
46
|
+
AabbFace.FACE_NAMES = [
|
|
47
|
+
'POS_Z', 'POS_X', 'NEG_Z', 'NEG_X', 'POS_Y', 'NEG_Y'
|
|
48
|
+
];
|
|
49
|
+
/**
|
|
50
|
+
* Get the AABB face name for debugging/logging
|
|
51
|
+
*/
|
|
52
|
+
AabbFace.getName = (face) => {
|
|
53
|
+
return AabbFace.FACE_NAMES[face];
|
|
54
|
+
};
|
|
55
|
+
/**
|
|
56
|
+
* Get the normal vector for a given AABB face
|
|
57
|
+
*/
|
|
58
|
+
AabbFace.getNormal = (face) => {
|
|
59
|
+
switch (face) {
|
|
60
|
+
case AabbFace.POS_Z: return [0, 0, 1];
|
|
61
|
+
case AabbFace.NEG_Z: return [0, 0, -1];
|
|
62
|
+
case AabbFace.POS_X: return [1, 0, 0];
|
|
63
|
+
case AabbFace.NEG_X: return [-1, 0, 0];
|
|
64
|
+
case AabbFace.POS_Y: return [0, 1, 0];
|
|
65
|
+
case AabbFace.NEG_Y: return [0, -1, 0];
|
|
66
|
+
default: throw new Error(`Invalid face index: ${face}`);
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
/**
|
|
70
|
+
* Get the opposite AABB face
|
|
71
|
+
*/
|
|
72
|
+
AabbFace.getOpposite = (face) => {
|
|
73
|
+
switch (face) {
|
|
74
|
+
case AabbFace.POS_Z: return AabbFace.NEG_Z;
|
|
75
|
+
case AabbFace.NEG_Z: return AabbFace.POS_Z;
|
|
76
|
+
case AabbFace.POS_X: return AabbFace.NEG_X;
|
|
77
|
+
case AabbFace.NEG_X: return AabbFace.POS_X;
|
|
78
|
+
case AabbFace.POS_Y: return AabbFace.NEG_Y;
|
|
79
|
+
case AabbFace.NEG_Y: return AabbFace.POS_Y;
|
|
80
|
+
default: throw new Error(`Invalid face index: ${face}`);
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
/**
|
|
84
|
+
* Check if two AABB faces are opposite
|
|
85
|
+
*/
|
|
86
|
+
AabbFace.isOpposite = (face1, face2) => {
|
|
87
|
+
return AabbFace.getOpposite(face1) === face2;
|
|
88
|
+
};
|
|
89
|
+
/**
|
|
90
|
+
* Get all AABB faces adjacent to the given face (faces that share an edge)
|
|
91
|
+
*/
|
|
92
|
+
AabbFace.getAdjacent = (face) => {
|
|
93
|
+
switch (face) {
|
|
94
|
+
case AabbFace.POS_Z:
|
|
95
|
+
case AabbFace.NEG_Z:
|
|
96
|
+
return [AabbFace.POS_X, AabbFace.NEG_X, AabbFace.POS_Y, AabbFace.NEG_Y];
|
|
97
|
+
case AabbFace.POS_X:
|
|
98
|
+
case AabbFace.NEG_X:
|
|
99
|
+
return [AabbFace.POS_Z, AabbFace.NEG_Z, AabbFace.POS_Y, AabbFace.NEG_Y];
|
|
100
|
+
case AabbFace.POS_Y:
|
|
101
|
+
case AabbFace.NEG_Y:
|
|
102
|
+
return [AabbFace.POS_Z, AabbFace.NEG_Z, AabbFace.POS_X, AabbFace.NEG_X];
|
|
103
|
+
default:
|
|
104
|
+
throw new Error(`Invalid face index: ${face}`);
|
|
105
|
+
}
|
|
106
|
+
};
|
|
107
|
+
/**
|
|
108
|
+
* Check if two AABB faces are adjacent (share an edge)
|
|
109
|
+
*/
|
|
110
|
+
AabbFace.isAdjacent = (face1, face2) => {
|
|
111
|
+
return AabbFace.getAdjacent(face1).includes(face2);
|
|
112
|
+
};
|
|
113
|
+
/**
|
|
114
|
+
* Determines which AABB face a position is closest to.
|
|
115
|
+
* Assumes the position is in normalized coordinate space - a cube with size 1 centered on the origin.
|
|
116
|
+
* @param position World position of the intersection point
|
|
117
|
+
* @param aabb Bounding box of the cube
|
|
118
|
+
* @returns AabbFace index: 0=POS_Z, 1=POS_X, 2=NEG_Z, 3=NEG_X, 4=POS_Y, 5=NEG_Y
|
|
119
|
+
*/
|
|
120
|
+
AabbFace.fromPosition = (position, aabb) => {
|
|
121
|
+
const aabbCenter = Aabb.center(aabb);
|
|
122
|
+
const localPos = [
|
|
123
|
+
position[0] - aabbCenter[0],
|
|
124
|
+
position[1] - aabbCenter[1],
|
|
125
|
+
position[2] - aabbCenter[2]
|
|
126
|
+
];
|
|
127
|
+
// Find the face with the largest absolute coordinate (closest to cube surface)
|
|
128
|
+
const absX = Math.abs(localPos[0]);
|
|
129
|
+
const absY = Math.abs(localPos[1]);
|
|
130
|
+
const absZ = Math.abs(localPos[2]);
|
|
131
|
+
if (absX >= absY && absX >= absZ) {
|
|
132
|
+
// X-axis face (NEG_X or POS_X)
|
|
133
|
+
return localPos[0] > 0 ? AabbFace.POS_X : AabbFace.NEG_X;
|
|
134
|
+
}
|
|
135
|
+
else if (absY >= absZ) {
|
|
136
|
+
// Y-axis face (NEG_Y or POS_Y)
|
|
137
|
+
return localPos[1] > 0 ? AabbFace.POS_Y : AabbFace.NEG_Y;
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
// Z-axis face (NEG_Z or POS_Z)
|
|
141
|
+
return localPos[2] > 0 ? AabbFace.POS_Z : AabbFace.NEG_Z;
|
|
142
|
+
}
|
|
143
|
+
};
|
|
144
|
+
})(AabbFace || (AabbFace = {}));
|
|
145
|
+
//# sourceMappingURL=aabb-face.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aabb-face.js","sourceRoot":"","sources":["../../../src/math/aabb-face/aabb-face.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
/*MIT License
|
|
2
|
+
|
|
3
|
+
© Copyright 2025 Adobe. All rights reserved.
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.*/
|
|
22
|
+
import { describe, it, expect } from 'vitest';
|
|
23
|
+
import { AabbFace } from './aabb-face.js';
|
|
24
|
+
describe('AabbFace', () => {
|
|
25
|
+
it('should get correct opposite faces', () => {
|
|
26
|
+
expect(AabbFace.getOpposite(AabbFace.POS_Z)).toBe(AabbFace.NEG_Z);
|
|
27
|
+
expect(AabbFace.getOpposite(AabbFace.POS_X)).toBe(AabbFace.NEG_X);
|
|
28
|
+
expect(AabbFace.getOpposite(AabbFace.POS_Y)).toBe(AabbFace.NEG_Y);
|
|
29
|
+
});
|
|
30
|
+
it('should get correct adjacent faces for each axis', () => {
|
|
31
|
+
const posZAdjacent = AabbFace.getAdjacent(AabbFace.POS_Z);
|
|
32
|
+
expect(posZAdjacent).toEqual([AabbFace.POS_X, AabbFace.NEG_X, AabbFace.POS_Y, AabbFace.NEG_Y]);
|
|
33
|
+
const posXAdjacent = AabbFace.getAdjacent(AabbFace.POS_X);
|
|
34
|
+
expect(posXAdjacent).toEqual([AabbFace.POS_Z, AabbFace.NEG_Z, AabbFace.POS_Y, AabbFace.NEG_Y]);
|
|
35
|
+
const posYAdjacent = AabbFace.getAdjacent(AabbFace.POS_Y);
|
|
36
|
+
expect(posYAdjacent).toEqual([AabbFace.POS_Z, AabbFace.NEG_Z, AabbFace.POS_X, AabbFace.NEG_X]);
|
|
37
|
+
});
|
|
38
|
+
it('should throw error for invalid face indices', () => {
|
|
39
|
+
expect(() => AabbFace.getNormal(6)).toThrow('Invalid face index: 6');
|
|
40
|
+
expect(() => AabbFace.getOpposite(6)).toThrow('Invalid face index: 6');
|
|
41
|
+
expect(() => AabbFace.getAdjacent(6)).toThrow('Invalid face index: 6');
|
|
42
|
+
});
|
|
43
|
+
it('should determine face from position correctly', () => {
|
|
44
|
+
const aabb = { min: [-1, -1, -1], max: [1, 1, 1] }; // Unit cube centered at origin
|
|
45
|
+
// Test positions on each face
|
|
46
|
+
expect(AabbFace.fromPosition([1, 0, 0], aabb)).toBe(AabbFace.POS_X);
|
|
47
|
+
expect(AabbFace.fromPosition([-1, 0, 0], aabb)).toBe(AabbFace.NEG_X);
|
|
48
|
+
expect(AabbFace.fromPosition([0, 1, 0], aabb)).toBe(AabbFace.POS_Y);
|
|
49
|
+
expect(AabbFace.fromPosition([0, -1, 0], aabb)).toBe(AabbFace.NEG_Y);
|
|
50
|
+
expect(AabbFace.fromPosition([0, 0, 1], aabb)).toBe(AabbFace.POS_Z);
|
|
51
|
+
expect(AabbFace.fromPosition([0, 0, -1], aabb)).toBe(AabbFace.NEG_Z);
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
//# sourceMappingURL=aabb-face.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aabb-face.test.js","sourceRoot":"","sources":["../../../src/math/aabb-face/aabb-face.test.ts"],"names":[],"mappings":"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"}
|
package/dist/math/f32/f32.d.ts
CHANGED
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { FromSchema } from "../../schema/index.js";
|
|
2
|
-
export
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
2
|
+
export type F32 = FromSchema<typeof F32.schema>;
|
|
3
|
+
export declare namespace F32 {
|
|
4
|
+
const schema: {
|
|
5
|
+
readonly type: "number";
|
|
6
|
+
readonly precision: 1;
|
|
7
|
+
readonly default: number;
|
|
8
|
+
};
|
|
9
|
+
}
|
package/dist/math/f32/f32.js
CHANGED
|
@@ -20,5 +20,8 @@ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
20
20
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
21
|
SOFTWARE.*/
|
|
22
22
|
import { F32Schema } from "../../schema/index.js";
|
|
23
|
-
export
|
|
23
|
+
export var F32;
|
|
24
|
+
(function (F32) {
|
|
25
|
+
F32.schema = F32Schema;
|
|
26
|
+
})(F32 || (F32 = {}));
|
|
24
27
|
//# sourceMappingURL=f32.js.map
|
package/dist/math/f32/f32.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"f32.js","sourceRoot":"","sources":["../../../src/math/f32/f32.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAEX,OAAO,EAAE,SAAS,EAAc,MAAM,uBAAuB,CAAC;
|
|
1
|
+
{"version":3,"file":"f32.js","sourceRoot":"","sources":["../../../src/math/f32/f32.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAEX,OAAO,EAAE,SAAS,EAAc,MAAM,uBAAuB,CAAC;AAI9D,MAAM,KAAW,GAAG,CAEnB;AAFD,WAAiB,GAAG;IACH,UAAM,GAAG,SAAS,CAAC;AACpC,CAAC,EAFgB,GAAG,KAAH,GAAG,QAEnB"}
|
package/dist/math/i32/i32.d.ts
CHANGED
|
@@ -1,7 +1,10 @@
|
|
|
1
1
|
import { FromSchema } from "../../schema/index.js";
|
|
2
|
-
export
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
2
|
+
export type I32 = FromSchema<typeof I32.schema>;
|
|
3
|
+
export declare namespace I32 {
|
|
4
|
+
const schema: {
|
|
5
|
+
readonly type: "integer";
|
|
6
|
+
readonly minimum: -2147483648;
|
|
7
|
+
readonly maximum: 2147483647;
|
|
8
|
+
readonly default: number;
|
|
9
|
+
};
|
|
10
|
+
}
|
package/dist/math/i32/i32.js
CHANGED
|
@@ -19,6 +19,9 @@ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
19
19
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
20
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
21
|
SOFTWARE.*/
|
|
22
|
-
import {
|
|
23
|
-
export
|
|
22
|
+
import { I32Schema } from "../../schema/index.js";
|
|
23
|
+
export var I32;
|
|
24
|
+
(function (I32) {
|
|
25
|
+
I32.schema = I32Schema;
|
|
26
|
+
})(I32 || (I32 = {}));
|
|
24
27
|
//# sourceMappingURL=i32.js.map
|
package/dist/math/i32/i32.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"i32.js","sourceRoot":"","sources":["../../../src/math/i32/i32.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAEX,OAAO,EAAE,SAAS,EAAc,MAAM,uBAAuB,CAAC;
|
|
1
|
+
{"version":3,"file":"i32.js","sourceRoot":"","sources":["../../../src/math/i32/i32.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAEX,OAAO,EAAE,SAAS,EAAc,MAAM,uBAAuB,CAAC;AAI9D,MAAM,KAAW,GAAG,CAEnB;AAFD,WAAiB,GAAG;IACH,UAAM,GAAG,SAAS,CAAC;AACpC,CAAC,EAFgB,GAAG,KAAH,GAAG,QAEnB"}
|
package/dist/math/index.d.ts
CHANGED
|
@@ -1,24 +1,15 @@
|
|
|
1
1
|
export * from "./constants.js";
|
|
2
|
-
export
|
|
3
|
-
export *
|
|
4
|
-
export
|
|
5
|
-
export *
|
|
6
|
-
export
|
|
7
|
-
export *
|
|
8
|
-
export
|
|
9
|
-
export *
|
|
10
|
-
export
|
|
11
|
-
export *
|
|
12
|
-
export
|
|
13
|
-
export *
|
|
14
|
-
export
|
|
15
|
-
export * as Vec4 from "./vec4/vec4.js";
|
|
16
|
-
export type Quat = import("./quat/quat.js").Type;
|
|
17
|
-
export * as Quat from "./quat/quat.js";
|
|
18
|
-
export type Aabb = import("./aabb/aabb.js").Type;
|
|
19
|
-
export * as Aabb from "./aabb/aabb.js";
|
|
20
|
-
export type Line2 = import("./line2/line2.js").Type;
|
|
21
|
-
export * as Line2 from "./line2/line2.js";
|
|
22
|
-
export type Line3 = import("./line3/line3.js").Type;
|
|
23
|
-
export * as Line3 from "./line3/line3.js";
|
|
2
|
+
export * from "./mat4x4/mat4x4.js";
|
|
3
|
+
export * from "./f32/f32.js";
|
|
4
|
+
export * from "./u32/u32.js";
|
|
5
|
+
export * from "./i32/i32.js";
|
|
6
|
+
export * from "./vec2/vec2.js";
|
|
7
|
+
export * from "./vec3/vec3.js";
|
|
8
|
+
export * from "./vec4/vec4.js";
|
|
9
|
+
export * from "./quat/quat.js";
|
|
10
|
+
export * from "./aabb/aabb.js";
|
|
11
|
+
export * from "./line2/line2.js";
|
|
12
|
+
export * from "./line3/line3.js";
|
|
13
|
+
export * from "./aabb-face/aabb-face.js";
|
|
14
|
+
export * from "./plane/plane.js";
|
|
24
15
|
export * from "./picking/index.js";
|
package/dist/math/index.js
CHANGED
|
@@ -20,27 +20,18 @@ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
20
20
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
21
|
SOFTWARE.*/
|
|
22
22
|
export * from "./constants.js";
|
|
23
|
-
|
|
24
|
-
export *
|
|
25
|
-
|
|
26
|
-
export *
|
|
27
|
-
|
|
28
|
-
export *
|
|
29
|
-
|
|
30
|
-
export *
|
|
31
|
-
|
|
32
|
-
export *
|
|
33
|
-
|
|
34
|
-
export *
|
|
35
|
-
|
|
36
|
-
export * as Vec4 from "./vec4/vec4.js";
|
|
37
|
-
// Export the namespace Quat
|
|
38
|
-
export * as Quat from "./quat/quat.js";
|
|
39
|
-
// Export the namespace Aabb
|
|
40
|
-
export * as Aabb from "./aabb/aabb.js";
|
|
41
|
-
// Export the namespace Line2
|
|
42
|
-
export * as Line2 from "./line2/line2.js";
|
|
43
|
-
// Export the namespace Line3
|
|
44
|
-
export * as Line3 from "./line3/line3.js";
|
|
23
|
+
export * from "./mat4x4/mat4x4.js";
|
|
24
|
+
export * from "./f32/f32.js";
|
|
25
|
+
export * from "./u32/u32.js";
|
|
26
|
+
export * from "./i32/i32.js";
|
|
27
|
+
export * from "./vec2/vec2.js";
|
|
28
|
+
export * from "./vec3/vec3.js";
|
|
29
|
+
export * from "./vec4/vec4.js";
|
|
30
|
+
export * from "./quat/quat.js";
|
|
31
|
+
export * from "./aabb/aabb.js";
|
|
32
|
+
export * from "./line2/line2.js";
|
|
33
|
+
export * from "./line3/line3.js";
|
|
34
|
+
export * from "./aabb-face/aabb-face.js";
|
|
35
|
+
export * from "./plane/plane.js";
|
|
45
36
|
export * from "./picking/index.js";
|
|
46
37
|
//# sourceMappingURL=index.js.map
|
package/dist/math/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/math/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAEX,cAAc,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/math/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAEX,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,0BAA0B,CAAC;AACzC,cAAc,kBAAkB,CAAC;AACjC,cAAc,oBAAoB,CAAC"}
|
|
@@ -1,42 +1,42 @@
|
|
|
1
1
|
import { FromSchema } from "../../schema/index.js";
|
|
2
2
|
import { Vec2 } from "../index.js";
|
|
3
|
-
export
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
readonly
|
|
7
|
-
|
|
8
|
-
readonly
|
|
9
|
-
readonly type: "
|
|
10
|
-
readonly
|
|
11
|
-
|
|
3
|
+
export type Line2 = FromSchema<typeof Line2.schema>;
|
|
4
|
+
export declare namespace Line2 {
|
|
5
|
+
const schema: {
|
|
6
|
+
readonly type: "object";
|
|
7
|
+
readonly properties: {
|
|
8
|
+
readonly a: {
|
|
9
|
+
readonly type: "array";
|
|
10
|
+
readonly items: {
|
|
11
|
+
readonly type: "number";
|
|
12
|
+
readonly precision: 1;
|
|
13
|
+
readonly default: number;
|
|
14
|
+
};
|
|
15
|
+
readonly minItems: 2;
|
|
16
|
+
readonly maxItems: 2;
|
|
17
|
+
readonly default: readonly [0, 0];
|
|
12
18
|
};
|
|
13
|
-
readonly
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
readonly
|
|
21
|
-
readonly
|
|
22
|
-
readonly default:
|
|
19
|
+
readonly b: {
|
|
20
|
+
readonly type: "array";
|
|
21
|
+
readonly items: {
|
|
22
|
+
readonly type: "number";
|
|
23
|
+
readonly precision: 1;
|
|
24
|
+
readonly default: number;
|
|
25
|
+
};
|
|
26
|
+
readonly minItems: 2;
|
|
27
|
+
readonly maxItems: 2;
|
|
28
|
+
readonly default: readonly [0, 0];
|
|
23
29
|
};
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
30
|
+
};
|
|
31
|
+
readonly required: readonly ["a", "b"];
|
|
32
|
+
readonly additionalProperties: false;
|
|
33
|
+
readonly default: {
|
|
34
|
+
readonly a: readonly [0, 0];
|
|
35
|
+
readonly b: readonly [0, 0];
|
|
27
36
|
};
|
|
28
37
|
};
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
};
|
|
35
|
-
};
|
|
36
|
-
export type Type = FromSchema<typeof schema>;
|
|
37
|
-
type Line2 = Type;
|
|
38
|
-
export declare const layout: import("../../typed-buffer/index.js").StructLayout;
|
|
39
|
-
export declare const interpolate: (line: Line2, alpha: number) => Vec2;
|
|
40
|
-
export declare const intersects: (line1: Line2, line2: Line2, includeEndpoints?: boolean) => boolean;
|
|
41
|
-
export declare const subLine: (line: Line2, alpha: number, beta: number) => Line2;
|
|
42
|
-
export {};
|
|
38
|
+
const layout: import("../../typed-buffer/index.js").StructLayout;
|
|
39
|
+
const interpolate: (line: Line2, alpha: number) => Vec2;
|
|
40
|
+
const intersects: (line1: Line2, line2: Line2, includeEndpoints?: boolean) => boolean;
|
|
41
|
+
const subLine: (line: Line2, alpha: number, beta: number) => Line2;
|
|
42
|
+
}
|
package/dist/math/line2/line2.js
CHANGED
|
@@ -22,57 +22,60 @@ SOFTWARE.*/
|
|
|
22
22
|
import { getStructLayout } from "../../typed-buffer/index.js";
|
|
23
23
|
import { Vec2 } from "../index.js";
|
|
24
24
|
import { epsilon } from "../constants.js";
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
// Line2 utility functions
|
|
41
|
-
export const interpolate = (line, alpha) => {
|
|
42
|
-
const a = line.a;
|
|
43
|
-
const b = line.b;
|
|
44
|
-
return [a[0] + alpha * (b[0] - a[0]), a[1] + alpha * (b[1] - a[1])];
|
|
45
|
-
};
|
|
46
|
-
export const intersects = (line1, line2, includeEndpoints = false) => {
|
|
47
|
-
const a = line1.a;
|
|
48
|
-
const b = line1.b;
|
|
49
|
-
const c = line2.a;
|
|
50
|
-
const d = line2.b;
|
|
51
|
-
// Check for endpoint intersections
|
|
52
|
-
if (includeEndpoints && ((Math.abs(a[0] - c[0]) < epsilon && Math.abs(a[1] - c[1]) < epsilon) ||
|
|
53
|
-
(Math.abs(a[0] - d[0]) < epsilon && Math.abs(a[1] - d[1]) < epsilon) ||
|
|
54
|
-
(Math.abs(b[0] - c[0]) < epsilon && Math.abs(b[1] - c[1]) < epsilon) ||
|
|
55
|
-
(Math.abs(b[0] - d[0]) < epsilon && Math.abs(b[1] - d[1]) < epsilon))) {
|
|
56
|
-
return true;
|
|
57
|
-
}
|
|
58
|
-
// Calculate the denominator
|
|
59
|
-
const denominator = (d[0] - c[0]) * (b[1] - a[1]) - (d[1] - c[1]) * (b[0] - a[0]);
|
|
60
|
-
// Check if lines are parallel or collinear
|
|
61
|
-
if (Math.abs(denominator) < epsilon) {
|
|
62
|
-
return false;
|
|
63
|
-
}
|
|
64
|
-
// Calculate intersection parameters
|
|
65
|
-
const numerator1 = (d[1] - c[1]) * (a[0] - c[0]) - (d[0] - c[0]) * (a[1] - c[1]);
|
|
66
|
-
const numerator2 = (b[1] - a[1]) * (a[0] - c[0]) - (b[0] - a[0]) * (a[1] - c[1]);
|
|
67
|
-
const ua = numerator1 / denominator;
|
|
68
|
-
const ub = numerator2 / denominator;
|
|
69
|
-
// Check if intersection point lies within both line segments
|
|
70
|
-
return ua >= -epsilon && ua <= 1 + epsilon && ub >= -epsilon && ub <= 1 + epsilon;
|
|
71
|
-
};
|
|
72
|
-
export const subLine = (line, alpha, beta) => {
|
|
73
|
-
return {
|
|
74
|
-
a: interpolate(line, alpha),
|
|
75
|
-
b: interpolate(line, beta),
|
|
25
|
+
export var Line2;
|
|
26
|
+
(function (Line2) {
|
|
27
|
+
const { schema: Vec2Schema } = Vec2;
|
|
28
|
+
Line2.schema = {
|
|
29
|
+
type: 'object',
|
|
30
|
+
properties: {
|
|
31
|
+
a: Vec2Schema,
|
|
32
|
+
b: Vec2Schema,
|
|
33
|
+
},
|
|
34
|
+
required: ['a', 'b'],
|
|
35
|
+
additionalProperties: false,
|
|
36
|
+
default: {
|
|
37
|
+
a: Vec2Schema.default,
|
|
38
|
+
b: Vec2Schema.default,
|
|
39
|
+
}
|
|
76
40
|
};
|
|
77
|
-
|
|
41
|
+
Line2.layout = getStructLayout(Line2.schema);
|
|
42
|
+
// Line2 utility functions
|
|
43
|
+
Line2.interpolate = (line, alpha) => {
|
|
44
|
+
const a = line.a;
|
|
45
|
+
const b = line.b;
|
|
46
|
+
return [a[0] + alpha * (b[0] - a[0]), a[1] + alpha * (b[1] - a[1])];
|
|
47
|
+
};
|
|
48
|
+
Line2.intersects = (line1, line2, includeEndpoints = false) => {
|
|
49
|
+
const a = line1.a;
|
|
50
|
+
const b = line1.b;
|
|
51
|
+
const c = line2.a;
|
|
52
|
+
const d = line2.b;
|
|
53
|
+
// Check for endpoint intersections
|
|
54
|
+
if (includeEndpoints && ((Math.abs(a[0] - c[0]) < epsilon && Math.abs(a[1] - c[1]) < epsilon) ||
|
|
55
|
+
(Math.abs(a[0] - d[0]) < epsilon && Math.abs(a[1] - d[1]) < epsilon) ||
|
|
56
|
+
(Math.abs(b[0] - c[0]) < epsilon && Math.abs(b[1] - c[1]) < epsilon) ||
|
|
57
|
+
(Math.abs(b[0] - d[0]) < epsilon && Math.abs(b[1] - d[1]) < epsilon))) {
|
|
58
|
+
return true;
|
|
59
|
+
}
|
|
60
|
+
// Calculate the denominator
|
|
61
|
+
const denominator = (d[0] - c[0]) * (b[1] - a[1]) - (d[1] - c[1]) * (b[0] - a[0]);
|
|
62
|
+
// Check if lines are parallel or collinear
|
|
63
|
+
if (Math.abs(denominator) < epsilon) {
|
|
64
|
+
return false;
|
|
65
|
+
}
|
|
66
|
+
// Calculate intersection parameters
|
|
67
|
+
const numerator1 = (d[1] - c[1]) * (a[0] - c[0]) - (d[0] - c[0]) * (a[1] - c[1]);
|
|
68
|
+
const numerator2 = (b[1] - a[1]) * (a[0] - c[0]) - (b[0] - a[0]) * (a[1] - c[1]);
|
|
69
|
+
const ua = numerator1 / denominator;
|
|
70
|
+
const ub = numerator2 / denominator;
|
|
71
|
+
// Check if intersection point lies within both line segments
|
|
72
|
+
return ua >= -epsilon && ua <= 1 + epsilon && ub >= -epsilon && ub <= 1 + epsilon;
|
|
73
|
+
};
|
|
74
|
+
Line2.subLine = (line, alpha, beta) => {
|
|
75
|
+
return {
|
|
76
|
+
a: Line2.interpolate(line, alpha),
|
|
77
|
+
b: Line2.interpolate(line, beta),
|
|
78
|
+
};
|
|
79
|
+
};
|
|
80
|
+
})(Line2 || (Line2 = {}));
|
|
78
81
|
//# sourceMappingURL=line2.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"line2.js","sourceRoot":"","sources":["../../../src/math/line2/line2.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAGX,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AACnC,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"line2.js","sourceRoot":"","sources":["../../../src/math/line2/line2.ts"],"names":[],"mappings":"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"}
|