@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
|
@@ -22,225 +22,228 @@ SOFTWARE.*/
|
|
|
22
22
|
import { F32Schema } from "../../schema/index.js";
|
|
23
23
|
import { getStructLayout } from "../../typed-buffer/index.js";
|
|
24
24
|
import { Vec3 } from "../index.js";
|
|
25
|
-
export
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
0, 0, 1, 0,
|
|
38
|
-
0, 0, 0, 1
|
|
39
|
-
];
|
|
40
|
-
export const zero = () => [
|
|
41
|
-
0, 0, 0, 0,
|
|
42
|
-
0, 0, 0, 0,
|
|
43
|
-
0, 0, 0, 0,
|
|
44
|
-
0, 0, 0, 0
|
|
45
|
-
];
|
|
46
|
-
// Matrix-Matrix Operations
|
|
47
|
-
export const add = (a, b) => [
|
|
48
|
-
a[0] + b[0], a[1] + b[1], a[2] + b[2], a[3] + b[3],
|
|
49
|
-
a[4] + b[4], a[5] + b[5], a[6] + b[6], a[7] + b[7],
|
|
50
|
-
a[8] + b[8], a[9] + b[9], a[10] + b[10], a[11] + b[11],
|
|
51
|
-
a[12] + b[12], a[13] + b[13], a[14] + b[14], a[15] + b[15]
|
|
52
|
-
];
|
|
53
|
-
export const subtract = (a, b) => [
|
|
54
|
-
a[0] - b[0], a[1] - b[1], a[2] - b[2], a[3] - b[3],
|
|
55
|
-
a[4] - b[4], a[5] - b[5], a[6] - b[6], a[7] - b[7],
|
|
56
|
-
a[8] - b[8], a[9] - b[9], a[10] - b[10], a[11] - b[11],
|
|
57
|
-
a[12] - b[12], a[13] - b[13], a[14] - b[14], a[15] - b[15]
|
|
58
|
-
];
|
|
59
|
-
export const multiply = (a, b) => {
|
|
60
|
-
const result = new Array(16);
|
|
61
|
-
for (let i = 0; i < 4; i++) {
|
|
62
|
-
for (let j = 0; j < 4; j++) {
|
|
63
|
-
let sum = 0;
|
|
64
|
-
for (let k = 0; k < 4; k++) {
|
|
65
|
-
sum += a[k * 4 + i] * b[j * 4 + k];
|
|
66
|
-
}
|
|
67
|
-
result[j * 4 + i] = sum;
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
return result;
|
|
71
|
-
};
|
|
72
|
-
// Matrix-Scalar Operations
|
|
73
|
-
export const scale = (m, s) => [
|
|
74
|
-
m[0] * s, m[1] * s, m[2] * s, m[3] * s,
|
|
75
|
-
m[4] * s, m[5] * s, m[6] * s, m[7] * s,
|
|
76
|
-
m[8] * s, m[9] * s, m[10] * s, m[11] * s,
|
|
77
|
-
m[12] * s, m[13] * s, m[14] * s, m[15] * s
|
|
78
|
-
];
|
|
79
|
-
// Matrix-Vector Operations
|
|
80
|
-
export const multiplyVec4 = (m, v) => [
|
|
81
|
-
m[0] * v[0] + m[4] * v[1] + m[8] * v[2] + m[12] * v[3],
|
|
82
|
-
m[1] * v[0] + m[5] * v[1] + m[9] * v[2] + m[13] * v[3],
|
|
83
|
-
m[2] * v[0] + m[6] * v[1] + m[10] * v[2] + m[14] * v[3],
|
|
84
|
-
m[3] * v[0] + m[7] * v[1] + m[11] * v[2] + m[15] * v[3]
|
|
85
|
-
];
|
|
86
|
-
export const multiplyVec3 = (m, v) => [
|
|
87
|
-
m[0] * v[0] + m[4] * v[1] + m[8] * v[2] + m[12],
|
|
88
|
-
m[1] * v[0] + m[5] * v[1] + m[9] * v[2] + m[13],
|
|
89
|
-
m[2] * v[0] + m[6] * v[1] + m[10] * v[2] + m[14]
|
|
90
|
-
];
|
|
91
|
-
// Matrix Properties
|
|
92
|
-
export const determinant = (m) => {
|
|
93
|
-
const [m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33] = m;
|
|
94
|
-
const b00 = m00 * m11 - m01 * m10;
|
|
95
|
-
const b01 = m00 * m12 - m02 * m10;
|
|
96
|
-
const b02 = m00 * m13 - m03 * m10;
|
|
97
|
-
const b03 = m01 * m12 - m02 * m11;
|
|
98
|
-
const b04 = m01 * m13 - m03 * m11;
|
|
99
|
-
const b05 = m02 * m13 - m03 * m12;
|
|
100
|
-
const b06 = m20 * m31 - m21 * m30;
|
|
101
|
-
const b07 = m20 * m32 - m22 * m30;
|
|
102
|
-
const b08 = m20 * m33 - m23 * m30;
|
|
103
|
-
const b09 = m21 * m32 - m22 * m31;
|
|
104
|
-
const b10 = m21 * m33 - m23 * m31;
|
|
105
|
-
const b11 = m22 * m33 - m23 * m32;
|
|
106
|
-
return b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;
|
|
107
|
-
};
|
|
108
|
-
export const inverse = (m) => {
|
|
109
|
-
const det = determinant(m);
|
|
110
|
-
if (det === 0) {
|
|
111
|
-
throw new Error('Matrix is not invertible');
|
|
112
|
-
}
|
|
113
|
-
const [m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33] = m;
|
|
114
|
-
const b00 = m00 * m11 - m01 * m10;
|
|
115
|
-
const b01 = m00 * m12 - m02 * m10;
|
|
116
|
-
const b02 = m00 * m13 - m03 * m10;
|
|
117
|
-
const b03 = m01 * m12 - m02 * m11;
|
|
118
|
-
const b04 = m01 * m13 - m03 * m11;
|
|
119
|
-
const b05 = m02 * m13 - m03 * m12;
|
|
120
|
-
const b06 = m20 * m31 - m21 * m30;
|
|
121
|
-
const b07 = m20 * m32 - m22 * m30;
|
|
122
|
-
const b08 = m20 * m33 - m23 * m30;
|
|
123
|
-
const b09 = m21 * m32 - m22 * m31;
|
|
124
|
-
const b10 = m21 * m33 - m23 * m31;
|
|
125
|
-
const b11 = m22 * m33 - m23 * m32;
|
|
126
|
-
const invDet = 1.0 / det;
|
|
127
|
-
return [
|
|
128
|
-
(m11 * b11 - m12 * b10 + m13 * b09) * invDet,
|
|
129
|
-
(m02 * b10 - m01 * b11 - m03 * b09) * invDet,
|
|
130
|
-
(m31 * b05 - m32 * b04 + m33 * b03) * invDet,
|
|
131
|
-
(m22 * b04 - m21 * b05 - m23 * b03) * invDet,
|
|
132
|
-
(m12 * b08 - m10 * b11 - m13 * b07) * invDet,
|
|
133
|
-
(m00 * b11 - m02 * b08 + m03 * b07) * invDet,
|
|
134
|
-
(m32 * b02 - m30 * b05 - m33 * b01) * invDet,
|
|
135
|
-
(m20 * b05 - m22 * b02 + m23 * b01) * invDet,
|
|
136
|
-
(m10 * b10 - m11 * b08 + m13 * b06) * invDet,
|
|
137
|
-
(m01 * b08 - m00 * b10 - m03 * b06) * invDet,
|
|
138
|
-
(m30 * b04 - m31 * b02 + m33 * b00) * invDet,
|
|
139
|
-
(m21 * b02 - m20 * b04 - m23 * b00) * invDet,
|
|
140
|
-
(m11 * b07 - m10 * b09 - m12 * b06) * invDet,
|
|
141
|
-
(m00 * b09 - m01 * b07 + m02 * b06) * invDet,
|
|
142
|
-
(m31 * b01 - m30 * b03 - m32 * b00) * invDet,
|
|
143
|
-
(m20 * b03 - m21 * b01 + m22 * b00) * invDet
|
|
144
|
-
];
|
|
145
|
-
};
|
|
146
|
-
export const transpose = (m) => [
|
|
147
|
-
m[0], m[4], m[8], m[12],
|
|
148
|
-
m[1], m[5], m[9], m[13],
|
|
149
|
-
m[2], m[6], m[10], m[14],
|
|
150
|
-
m[3], m[7], m[11], m[15]
|
|
151
|
-
];
|
|
152
|
-
// Transformation Matrices
|
|
153
|
-
export const translation = (x, y, z) => [
|
|
154
|
-
1, 0, 0, 0,
|
|
155
|
-
0, 1, 0, 0,
|
|
156
|
-
0, 0, 1, 0,
|
|
157
|
-
x, y, z, 1
|
|
158
|
-
];
|
|
159
|
-
export const scaling = (x, y, z) => [
|
|
160
|
-
x, 0, 0, 0,
|
|
161
|
-
0, y, 0, 0,
|
|
162
|
-
0, 0, z, 0,
|
|
163
|
-
0, 0, 0, 1
|
|
164
|
-
];
|
|
165
|
-
export const rotationX = (angle) => {
|
|
166
|
-
const c = Math.cos(angle);
|
|
167
|
-
const s = Math.sin(angle);
|
|
168
|
-
return [
|
|
25
|
+
export var Mat4x4;
|
|
26
|
+
(function (Mat4x4) {
|
|
27
|
+
Mat4x4.schema = {
|
|
28
|
+
type: 'array',
|
|
29
|
+
items: F32Schema,
|
|
30
|
+
minItems: 16,
|
|
31
|
+
maxItems: 16,
|
|
32
|
+
default: [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1], // identity matrix
|
|
33
|
+
};
|
|
34
|
+
Mat4x4.layout = getStructLayout(Mat4x4.schema);
|
|
35
|
+
// Basic Matrix Operations
|
|
36
|
+
Mat4x4.identity = [
|
|
169
37
|
1, 0, 0, 0,
|
|
170
|
-
0, c, s, 0,
|
|
171
|
-
0, -s, c, 0,
|
|
172
|
-
0, 0, 0, 1
|
|
173
|
-
];
|
|
174
|
-
};
|
|
175
|
-
export const rotationY = (angle) => {
|
|
176
|
-
const c = Math.cos(angle);
|
|
177
|
-
const s = Math.sin(angle);
|
|
178
|
-
return [
|
|
179
|
-
c, 0, s, 0,
|
|
180
38
|
0, 1, 0, 0,
|
|
181
|
-
-s, 0, c, 0,
|
|
182
|
-
0, 0, 0, 1
|
|
183
|
-
];
|
|
184
|
-
};
|
|
185
|
-
export const rotationZ = (angle) => {
|
|
186
|
-
const c = Math.cos(angle);
|
|
187
|
-
const s = Math.sin(angle);
|
|
188
|
-
return [
|
|
189
|
-
c, -s, 0, 0,
|
|
190
|
-
s, c, 0, 0,
|
|
191
39
|
0, 0, 1, 0,
|
|
192
40
|
0, 0, 0, 1
|
|
193
41
|
];
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
42
|
+
Mat4x4.zero = [
|
|
43
|
+
0, 0, 0, 0,
|
|
44
|
+
0, 0, 0, 0,
|
|
45
|
+
0, 0, 0, 0,
|
|
46
|
+
0, 0, 0, 0
|
|
47
|
+
];
|
|
48
|
+
// Matrix-Matrix Operations
|
|
49
|
+
Mat4x4.add = (a, b) => [
|
|
50
|
+
a[0] + b[0], a[1] + b[1], a[2] + b[2], a[3] + b[3],
|
|
51
|
+
a[4] + b[4], a[5] + b[5], a[6] + b[6], a[7] + b[7],
|
|
52
|
+
a[8] + b[8], a[9] + b[9], a[10] + b[10], a[11] + b[11],
|
|
53
|
+
a[12] + b[12], a[13] + b[13], a[14] + b[14], a[15] + b[15]
|
|
54
|
+
];
|
|
55
|
+
Mat4x4.subtract = (a, b) => [
|
|
56
|
+
a[0] - b[0], a[1] - b[1], a[2] - b[2], a[3] - b[3],
|
|
57
|
+
a[4] - b[4], a[5] - b[5], a[6] - b[6], a[7] - b[7],
|
|
58
|
+
a[8] - b[8], a[9] - b[9], a[10] - b[10], a[11] - b[11],
|
|
59
|
+
a[12] - b[12], a[13] - b[13], a[14] - b[14], a[15] - b[15]
|
|
60
|
+
];
|
|
61
|
+
Mat4x4.multiply = (a, b) => {
|
|
62
|
+
const result = new Array(16);
|
|
63
|
+
for (let i = 0; i < 4; i++) {
|
|
64
|
+
for (let j = 0; j < 4; j++) {
|
|
65
|
+
let sum = 0;
|
|
66
|
+
for (let k = 0; k < 4; k++) {
|
|
67
|
+
sum += a[k * 4 + i] * b[j * 4 + k];
|
|
68
|
+
}
|
|
69
|
+
result[j * 4 + i] = sum;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return result;
|
|
73
|
+
};
|
|
74
|
+
// Matrix-Scalar Operations
|
|
75
|
+
Mat4x4.scale = (m, s) => [
|
|
76
|
+
m[0] * s, m[1] * s, m[2] * s, m[3] * s,
|
|
77
|
+
m[4] * s, m[5] * s, m[6] * s, m[7] * s,
|
|
78
|
+
m[8] * s, m[9] * s, m[10] * s, m[11] * s,
|
|
79
|
+
m[12] * s, m[13] * s, m[14] * s, m[15] * s
|
|
80
|
+
];
|
|
81
|
+
// Matrix-Vector Operations
|
|
82
|
+
Mat4x4.multiplyVec4 = (m, v) => [
|
|
83
|
+
m[0] * v[0] + m[4] * v[1] + m[8] * v[2] + m[12] * v[3],
|
|
84
|
+
m[1] * v[0] + m[5] * v[1] + m[9] * v[2] + m[13] * v[3],
|
|
85
|
+
m[2] * v[0] + m[6] * v[1] + m[10] * v[2] + m[14] * v[3],
|
|
86
|
+
m[3] * v[0] + m[7] * v[1] + m[11] * v[2] + m[15] * v[3]
|
|
87
|
+
];
|
|
88
|
+
Mat4x4.multiplyVec3 = (m, v) => [
|
|
89
|
+
m[0] * v[0] + m[4] * v[1] + m[8] * v[2] + m[12],
|
|
90
|
+
m[1] * v[0] + m[5] * v[1] + m[9] * v[2] + m[13],
|
|
91
|
+
m[2] * v[0] + m[6] * v[1] + m[10] * v[2] + m[14]
|
|
92
|
+
];
|
|
93
|
+
// Matrix Properties
|
|
94
|
+
Mat4x4.determinant = (m) => {
|
|
95
|
+
const [m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33] = m;
|
|
96
|
+
const b00 = m00 * m11 - m01 * m10;
|
|
97
|
+
const b01 = m00 * m12 - m02 * m10;
|
|
98
|
+
const b02 = m00 * m13 - m03 * m10;
|
|
99
|
+
const b03 = m01 * m12 - m02 * m11;
|
|
100
|
+
const b04 = m01 * m13 - m03 * m11;
|
|
101
|
+
const b05 = m02 * m13 - m03 * m12;
|
|
102
|
+
const b06 = m20 * m31 - m21 * m30;
|
|
103
|
+
const b07 = m20 * m32 - m22 * m30;
|
|
104
|
+
const b08 = m20 * m33 - m23 * m30;
|
|
105
|
+
const b09 = m21 * m32 - m22 * m31;
|
|
106
|
+
const b10 = m21 * m33 - m23 * m31;
|
|
107
|
+
const b11 = m22 * m33 - m23 * m32;
|
|
108
|
+
return b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;
|
|
109
|
+
};
|
|
110
|
+
Mat4x4.inverse = (m) => {
|
|
111
|
+
const det = Mat4x4.determinant(m);
|
|
112
|
+
if (det === 0) {
|
|
113
|
+
throw new Error('Matrix is not invertible');
|
|
114
|
+
}
|
|
115
|
+
const [m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33] = m;
|
|
116
|
+
const b00 = m00 * m11 - m01 * m10;
|
|
117
|
+
const b01 = m00 * m12 - m02 * m10;
|
|
118
|
+
const b02 = m00 * m13 - m03 * m10;
|
|
119
|
+
const b03 = m01 * m12 - m02 * m11;
|
|
120
|
+
const b04 = m01 * m13 - m03 * m11;
|
|
121
|
+
const b05 = m02 * m13 - m03 * m12;
|
|
122
|
+
const b06 = m20 * m31 - m21 * m30;
|
|
123
|
+
const b07 = m20 * m32 - m22 * m30;
|
|
124
|
+
const b08 = m20 * m33 - m23 * m30;
|
|
125
|
+
const b09 = m21 * m32 - m22 * m31;
|
|
126
|
+
const b10 = m21 * m33 - m23 * m31;
|
|
127
|
+
const b11 = m22 * m33 - m23 * m32;
|
|
128
|
+
const invDet = 1.0 / det;
|
|
129
|
+
return [
|
|
130
|
+
(m11 * b11 - m12 * b10 + m13 * b09) * invDet,
|
|
131
|
+
(m02 * b10 - m01 * b11 - m03 * b09) * invDet,
|
|
132
|
+
(m31 * b05 - m32 * b04 + m33 * b03) * invDet,
|
|
133
|
+
(m22 * b04 - m21 * b05 - m23 * b03) * invDet,
|
|
134
|
+
(m12 * b08 - m10 * b11 - m13 * b07) * invDet,
|
|
135
|
+
(m00 * b11 - m02 * b08 + m03 * b07) * invDet,
|
|
136
|
+
(m32 * b02 - m30 * b05 - m33 * b01) * invDet,
|
|
137
|
+
(m20 * b05 - m22 * b02 + m23 * b01) * invDet,
|
|
138
|
+
(m10 * b10 - m11 * b08 + m13 * b06) * invDet,
|
|
139
|
+
(m01 * b08 - m00 * b10 - m03 * b06) * invDet,
|
|
140
|
+
(m30 * b04 - m31 * b02 + m33 * b00) * invDet,
|
|
141
|
+
(m21 * b02 - m20 * b04 - m23 * b00) * invDet,
|
|
142
|
+
(m11 * b07 - m10 * b09 - m12 * b06) * invDet,
|
|
143
|
+
(m00 * b09 - m01 * b07 + m02 * b06) * invDet,
|
|
144
|
+
(m31 * b01 - m30 * b03 - m32 * b00) * invDet,
|
|
145
|
+
(m20 * b03 - m21 * b01 + m22 * b00) * invDet
|
|
146
|
+
];
|
|
147
|
+
};
|
|
148
|
+
Mat4x4.transpose = (m) => [
|
|
149
|
+
m[0], m[4], m[8], m[12],
|
|
150
|
+
m[1], m[5], m[9], m[13],
|
|
151
|
+
m[2], m[6], m[10], m[14],
|
|
152
|
+
m[3], m[7], m[11], m[15]
|
|
212
153
|
];
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
-2 * lr, 0, 0, 0,
|
|
220
|
-
0, -2 * bt, 0, 0,
|
|
221
|
-
0, 0, 2 * nf, 0,
|
|
222
|
-
(left + right) * lr, (bottom + top) * bt, (far + near) * nf, 1
|
|
154
|
+
// Transformation Matrices
|
|
155
|
+
Mat4x4.translation = (x, y, z) => [
|
|
156
|
+
1, 0, 0, 0,
|
|
157
|
+
0, 1, 0, 0,
|
|
158
|
+
0, 0, 1, 0,
|
|
159
|
+
x, y, z, 1
|
|
223
160
|
];
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
throw new Error('Up vector cannot be zero');
|
|
230
|
-
const forward = Vec3.subtract(center, eye);
|
|
231
|
-
if (Vec3.length(forward) === 0)
|
|
232
|
-
throw new Error('Eye and center cannot be the same position');
|
|
233
|
-
const f = Vec3.normalize(forward);
|
|
234
|
-
const s = Vec3.normalize(Vec3.cross(f, up));
|
|
235
|
-
// Check if up vector is parallel to view direction
|
|
236
|
-
if (Vec3.length(s) === 0)
|
|
237
|
-
throw new Error('Up vector cannot be parallel to view direction');
|
|
238
|
-
const u = Vec3.normalize(Vec3.cross(s, f));
|
|
239
|
-
return [
|
|
240
|
-
s[0], u[0], -f[0], 0,
|
|
241
|
-
s[1], u[1], -f[1], 0,
|
|
242
|
-
s[2], u[2], -f[2], 0,
|
|
243
|
-
-Vec3.dot(s, eye), -Vec3.dot(u, eye), Vec3.dot(f, eye), 1
|
|
161
|
+
Mat4x4.scaling = (x, y, z) => [
|
|
162
|
+
x, 0, 0, 0,
|
|
163
|
+
0, y, 0, 0,
|
|
164
|
+
0, 0, z, 0,
|
|
165
|
+
0, 0, 0, 1
|
|
244
166
|
];
|
|
245
|
-
|
|
167
|
+
Mat4x4.rotationX = (angle) => {
|
|
168
|
+
const c = Math.cos(angle);
|
|
169
|
+
const s = Math.sin(angle);
|
|
170
|
+
return [
|
|
171
|
+
1, 0, 0, 0,
|
|
172
|
+
0, c, s, 0,
|
|
173
|
+
0, -s, c, 0,
|
|
174
|
+
0, 0, 0, 1
|
|
175
|
+
];
|
|
176
|
+
};
|
|
177
|
+
Mat4x4.rotationY = (angle) => {
|
|
178
|
+
const c = Math.cos(angle);
|
|
179
|
+
const s = Math.sin(angle);
|
|
180
|
+
return [
|
|
181
|
+
c, 0, s, 0,
|
|
182
|
+
0, 1, 0, 0,
|
|
183
|
+
-s, 0, c, 0,
|
|
184
|
+
0, 0, 0, 1
|
|
185
|
+
];
|
|
186
|
+
};
|
|
187
|
+
Mat4x4.rotationZ = (angle) => {
|
|
188
|
+
const c = Math.cos(angle);
|
|
189
|
+
const s = Math.sin(angle);
|
|
190
|
+
return [
|
|
191
|
+
c, -s, 0, 0,
|
|
192
|
+
s, c, 0, 0,
|
|
193
|
+
0, 0, 1, 0,
|
|
194
|
+
0, 0, 0, 1
|
|
195
|
+
];
|
|
196
|
+
};
|
|
197
|
+
// Projection Matrices
|
|
198
|
+
Mat4x4.perspective = (fovy, aspect, near, far) => {
|
|
199
|
+
if (fovy <= 0)
|
|
200
|
+
throw new Error('Field of view must be greater than 0');
|
|
201
|
+
if (aspect <= 0)
|
|
202
|
+
throw new Error('Aspect ratio must be greater than 0');
|
|
203
|
+
if (near <= 0)
|
|
204
|
+
throw new Error('Near plane must be greater than 0');
|
|
205
|
+
if (far <= near)
|
|
206
|
+
throw new Error('Far plane must be greater than near plane');
|
|
207
|
+
const f = 1.0 / Math.tan(fovy / 2);
|
|
208
|
+
const nf = near / (near - far);
|
|
209
|
+
return [
|
|
210
|
+
f / aspect, 0, 0, 0,
|
|
211
|
+
0, f, 0, 0,
|
|
212
|
+
0, 0, nf, -1,
|
|
213
|
+
0, 0, near * nf, 0
|
|
214
|
+
];
|
|
215
|
+
};
|
|
216
|
+
Mat4x4.orthographic = (left, right, bottom, top, near, far) => {
|
|
217
|
+
const lr = 1 / (left - right);
|
|
218
|
+
const bt = 1 / (bottom - top);
|
|
219
|
+
const nf = 1 / (near - far);
|
|
220
|
+
return [
|
|
221
|
+
-2 * lr, 0, 0, 0,
|
|
222
|
+
0, -2 * bt, 0, 0,
|
|
223
|
+
0, 0, 2 * nf, 0,
|
|
224
|
+
(left + right) * lr, (bottom + top) * bt, (far + near) * nf, 1
|
|
225
|
+
];
|
|
226
|
+
};
|
|
227
|
+
// View Matrix
|
|
228
|
+
Mat4x4.lookAt = (eye, center, up) => {
|
|
229
|
+
// Validate inputs
|
|
230
|
+
if (Vec3.length(up) === 0)
|
|
231
|
+
throw new Error('Up vector cannot be zero');
|
|
232
|
+
const forward = Vec3.subtract(center, eye);
|
|
233
|
+
if (Vec3.length(forward) === 0)
|
|
234
|
+
throw new Error('Eye and center cannot be the same position');
|
|
235
|
+
const f = Vec3.normalize(forward);
|
|
236
|
+
const s = Vec3.normalize(Vec3.cross(f, up));
|
|
237
|
+
// Check if up vector is parallel to view direction
|
|
238
|
+
if (Vec3.length(s) === 0)
|
|
239
|
+
throw new Error('Up vector cannot be parallel to view direction');
|
|
240
|
+
const u = Vec3.normalize(Vec3.cross(s, f));
|
|
241
|
+
return [
|
|
242
|
+
s[0], u[0], -f[0], 0,
|
|
243
|
+
s[1], u[1], -f[1], 0,
|
|
244
|
+
s[2], u[2], -f[2], 0,
|
|
245
|
+
-Vec3.dot(s, eye), -Vec3.dot(u, eye), Vec3.dot(f, eye), 1
|
|
246
|
+
];
|
|
247
|
+
};
|
|
248
|
+
})(Mat4x4 || (Mat4x4 = {}));
|
|
246
249
|
//# sourceMappingURL=mat4x4.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mat4x4.js","sourceRoot":"","sources":["../../../src/math/mat4x4/mat4x4.ts"],"names":[],"mappings":"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IAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAElC,MAAM,MAAM,GAAG,GAAG,GAAG,GAAG,CAAC;IACzB,OAAO;QACH,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;QAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;QAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;QAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;QAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;QAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;QAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;QAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GA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"}
|
|
1
|
+
{"version":3,"file":"mat4x4.js","sourceRoot":"","sources":["../../../src/math/mat4x4/mat4x4.ts"],"names":[],"mappings":"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AG,GAAG,GAAG,GAAG,GAAG,CAAC;QAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAClC,MAAM,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAElC,MAAM,MAAM,GAAG,GAAG,GAAG,GAAG,CAAC;QACzB,OAAO;YACH,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;YAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;YAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;YAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;YAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;YAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;YAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;YAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;YAC5C,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,MAAM;YAC5C,CAAC,GAAG,GAAG,GAAG,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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { Aabb, Line3, Vec3 } from "../index.js";
|
|
2
|
+
export function getClosestEntityToLine(rows, line) {
|
|
3
|
+
let closestEntity = null;
|
|
4
|
+
let closestDistanceSquared = Infinity;
|
|
5
|
+
let closestAlpha = Infinity;
|
|
6
|
+
let pickedPosition = null;
|
|
7
|
+
for (const [id, aabb] of rows) {
|
|
8
|
+
const aabbCenter = Aabb.center(aabb);
|
|
9
|
+
const alpha = Line3.closestPointOnLine(line, aabbCenter);
|
|
10
|
+
const closestPointOnLineSegment = Line3.interpolate(line, alpha);
|
|
11
|
+
const distSquared = Vec3.distanceSquared(aabbCenter, closestPointOnLineSegment);
|
|
12
|
+
if (distSquared < closestDistanceSquared ||
|
|
13
|
+
(distSquared === closestDistanceSquared && alpha < closestAlpha)) {
|
|
14
|
+
closestDistanceSquared = distSquared;
|
|
15
|
+
closestAlpha = alpha;
|
|
16
|
+
closestEntity = id;
|
|
17
|
+
pickedPosition = closestPointOnLineSegment;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
if (closestEntity !== null && pickedPosition) {
|
|
21
|
+
return {
|
|
22
|
+
entity: closestEntity,
|
|
23
|
+
lineAlpha: closestAlpha,
|
|
24
|
+
entityPosition: pickedPosition,
|
|
25
|
+
// face: AabbFace.fromPosition(pickedPosition, rows.get(closestEntity)!),
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
return null;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=get-closest-entity-to-line.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-closest-entity-to-line.js","sourceRoot":"","sources":["../../../src/math/picking/get-closest-entity-to-line.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAGhD,MAAM,UAAU,sBAAsB,CAAC,IAAuB,EAAE,IAAW;IACvE,IAAI,aAAa,GAAkB,IAAI,CAAC;IACxC,IAAI,sBAAsB,GAAG,QAAQ,CAAC;IACtC,IAAI,YAAY,GAAG,QAAQ,CAAC;IAC5B,IAAI,cAAc,GAAgB,IAAI,CAAC;IACvC,KAAK,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;QAC5B,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACrC,MAAM,KAAK,GAAG,KAAK,CAAC,kBAAkB,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;QACzD,MAAM,yBAAyB,GAAG,KAAK,CAAC,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACjE,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,yBAAyB,CAAC,CAAC;QAChF,IAAI,WAAW,GAAG,sBAAsB;YACpC,CAAC,WAAW,KAAK,sBAAsB,IAAI,KAAK,GAAG,YAAY,CAAC,EAAE,CAAC;YACnE,sBAAsB,GAAG,WAAW,CAAC;YACrC,YAAY,GAAG,KAAK,CAAC;YACrB,aAAa,GAAG,EAAE,CAAC;YACnB,cAAc,GAAG,yBAAyB,CAAC;QAC/C,CAAC;IACL,CAAC;IACD,IAAI,aAAa,KAAK,IAAI,IAAI,cAAc,EAAE,CAAC;QAC3C,OAAO;YACH,MAAM,EAAE,aAAa;YACrB,SAAS,EAAE,YAAY;YACvB,cAAc,EAAE,cAAc;YAC9B,yEAAyE;SAC5E,CAAC;IACN,CAAC;IACD,OAAO,IAAI,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { Aabb, Vec3 } from "../index.js";
|
|
2
|
+
export function getClosestEntityToPoint(rows, point) {
|
|
3
|
+
let closestRow = -1;
|
|
4
|
+
let closestDistanceSquared = Infinity;
|
|
5
|
+
let closestAabb = null;
|
|
6
|
+
for (const [row, aabb] of rows) {
|
|
7
|
+
const distSquared = Vec3.distanceSquared(point, Aabb.center(aabb));
|
|
8
|
+
if (distSquared < closestDistanceSquared) {
|
|
9
|
+
closestDistanceSquared = distSquared;
|
|
10
|
+
closestRow = row;
|
|
11
|
+
closestAabb = aabb;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
if (closestRow !== -1 && closestAabb) {
|
|
15
|
+
// For point-based picking, we need to calculate the alpha along the line
|
|
16
|
+
// that would put us at the closest point to the AABB center
|
|
17
|
+
// Since this function is called with a point (line.a), alpha should be 0
|
|
18
|
+
return {
|
|
19
|
+
entity: closestRow,
|
|
20
|
+
lineAlpha: 0,
|
|
21
|
+
entityPosition: point,
|
|
22
|
+
// face: AabbFace.fromPosition(point, closestAabb),
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
return null;
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=get-closest-entity-to-point.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-closest-entity-to-point.js","sourceRoot":"","sources":["../../../src/math/picking/get-closest-entity-to-point.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAGzC,MAAM,UAAU,uBAAuB,CAAC,IAAuB,EAAE,KAAW;IACxE,IAAI,UAAU,GAAG,CAAC,CAAC,CAAC;IACpB,IAAI,sBAAsB,GAAG,QAAQ,CAAC;IACtC,IAAI,WAAW,GAAgB,IAAI,CAAC;IACpC,KAAK,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;QAC7B,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QACnE,IAAI,WAAW,GAAG,sBAAsB,EAAE,CAAC;YACvC,sBAAsB,GAAG,WAAW,CAAC;YACrC,UAAU,GAAG,GAAG,CAAC;YACjB,WAAW,GAAG,IAAI,CAAC;QACvB,CAAC;IACL,CAAC;IACD,IAAI,UAAU,KAAK,CAAC,CAAC,IAAI,WAAW,EAAE,CAAC;QACnC,yEAAyE;QACzE,4DAA4D;QAC5D,yEAAyE;QACzE,OAAO;YACH,MAAM,EAAE,UAAU;YAClB,SAAS,EAAE,CAAC;YACZ,cAAc,EAAE,KAAK;YACrB,mDAAmD;SACtD,CAAC;IACN,CAAC;IACD,OAAO,IAAI,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Entity } from "../../ecs/index.js";
|
|
2
|
+
import { Table } from "../../table/table.js";
|
|
3
|
+
import { Aabb, Line3 } from "../index.js";
|
|
4
|
+
export declare function getIntersectingEntities<T extends Table<{
|
|
5
|
+
id: Entity;
|
|
6
|
+
boundingBox: Aabb;
|
|
7
|
+
}>>(options: {
|
|
8
|
+
tables: readonly T[];
|
|
9
|
+
line: Line3;
|
|
10
|
+
radius?: number;
|
|
11
|
+
predicate?: (table: T, row: number) => boolean;
|
|
12
|
+
}): Map<Entity, Aabb>;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Aabb } from "../index.js";
|
|
2
|
+
export function getIntersectingEntities(options) {
|
|
3
|
+
const { tables, line, radius = 0, predicate } = options;
|
|
4
|
+
const rows = new Map();
|
|
5
|
+
for (const table of tables) {
|
|
6
|
+
for (let row = 0; row < table.rowCount; row++) {
|
|
7
|
+
const boundingBox = table.columns.boundingBox.get(row);
|
|
8
|
+
if (Aabb.lineIntersection(boundingBox, line, radius) !== -1 && (predicate?.(table, row) ?? true)) {
|
|
9
|
+
rows.set(table.columns.id.get(row), boundingBox);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
return rows;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=get-intersecting-entities.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-intersecting-entities.js","sourceRoot":"","sources":["../../../src/math/picking/get-intersecting-entities.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,IAAI,EAAS,MAAM,aAAa,CAAC;AAE1C,MAAM,UAAU,uBAAuB,CAAsD,OAK5F;IACG,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,CAAC,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC;IACxD,MAAM,IAAI,GAAG,IAAI,GAAG,EAAgB,CAAC;IACrC,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QACzB,KAAK,IAAI,GAAG,GAAG,CAAC,EAAE,GAAG,GAAG,KAAK,CAAC,QAAQ,EAAE,GAAG,EAAE,EAAE,CAAC;YAC5C,MAAM,WAAW,GAAG,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACvD,IAAI,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,GAAG,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC;gBAC/F,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,WAAW,CAAC,CAAC;YACrD,CAAC;QACL,CAAC;IACL,CAAC;IACD,OAAO,IAAI,CAAC;AAChB,CAAC"}
|
|
@@ -20,4 +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
|
export * from "./pick-from-tables.js";
|
|
23
|
+
export * from "./pick-result.js";
|
|
24
|
+
export * from "./get-closest-entity-to-point.js";
|
|
25
|
+
export * from "./get-closest-entity-to-line.js";
|
|
26
|
+
export * from "./get-intersecting-entities.js";
|
|
23
27
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/math/picking/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAGX,cAAc,uBAAuB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/math/picking/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAGX,cAAc,uBAAuB,CAAC;AACtC,cAAc,kBAAkB,CAAC;AACjC,cAAc,kCAAkC,CAAC;AACjD,cAAc,iCAAiC,CAAC;AAChD,cAAc,gCAAgC,CAAC"}
|
|
@@ -5,6 +5,7 @@ import { Entity } from "../../ecs/index.js";
|
|
|
5
5
|
import { PickResult } from "./pick-result.js";
|
|
6
6
|
/**
|
|
7
7
|
* Picks the closest intersecting row from a table.
|
|
8
|
+
* This would be the broad phase picking step.
|
|
8
9
|
* @returns The entity id and picked position, or null if no entity is found.
|
|
9
10
|
*/
|
|
10
11
|
export declare function pickFromTables<T extends Table<{
|