@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.
Files changed (94) hide show
  1. package/dist/ecs/database/create-database.test.js +11 -0
  2. package/dist/ecs/database/create-database.test.js.map +1 -1
  3. package/dist/math/aabb/aabb.d.ts +42 -42
  4. package/dist/math/aabb/aabb.js +65 -62
  5. package/dist/math/aabb/aabb.js.map +1 -1
  6. package/dist/math/aabb-face/aabb-face.d.ts +59 -0
  7. package/dist/math/aabb-face/aabb-face.js +145 -0
  8. package/dist/math/aabb-face/aabb-face.js.map +1 -0
  9. package/dist/math/aabb-face/aabb-face.test.d.ts +1 -0
  10. package/dist/math/aabb-face/aabb-face.test.js +54 -0
  11. package/dist/math/aabb-face/aabb-face.test.js.map +1 -0
  12. package/dist/math/f32/f32.d.ts +8 -6
  13. package/dist/math/f32/f32.js +4 -1
  14. package/dist/math/f32/f32.js.map +1 -1
  15. package/dist/math/i32/i32.d.ts +9 -6
  16. package/dist/math/i32/i32.js +5 -2
  17. package/dist/math/i32/i32.js.map +1 -1
  18. package/dist/math/index.d.ts +13 -22
  19. package/dist/math/index.js +13 -22
  20. package/dist/math/index.js.map +1 -1
  21. package/dist/math/line2/line2.d.ts +36 -36
  22. package/dist/math/line2/line2.js +55 -52
  23. package/dist/math/line2/line2.js.map +1 -1
  24. package/dist/math/line3/line3.d.ts +48 -43
  25. package/dist/math/line3/line3.js +64 -52
  26. package/dist/math/line3/line3.js.map +1 -1
  27. package/dist/math/mat4x4/mat4x4.d.ts +34 -34
  28. package/dist/math/mat4x4/mat4x4.js +216 -213
  29. package/dist/math/mat4x4/mat4x4.js.map +1 -1
  30. package/dist/math/picking/get-closest-entity-to-line.d.ts +4 -0
  31. package/dist/math/picking/get-closest-entity-to-line.js +30 -0
  32. package/dist/math/picking/get-closest-entity-to-line.js.map +1 -0
  33. package/dist/math/picking/get-closest-entity-to-point.d.ts +4 -0
  34. package/dist/math/picking/get-closest-entity-to-point.js +27 -0
  35. package/dist/math/picking/get-closest-entity-to-point.js.map +1 -0
  36. package/dist/math/picking/get-intersecting-entities.d.ts +12 -0
  37. package/dist/math/picking/get-intersecting-entities.js +15 -0
  38. package/dist/math/picking/get-intersecting-entities.js.map +1 -0
  39. package/dist/math/picking/index.d.ts +4 -0
  40. package/dist/math/picking/index.js +4 -0
  41. package/dist/math/picking/index.js.map +1 -1
  42. package/dist/math/picking/pick-from-tables.d.ts +1 -0
  43. package/dist/math/picking/pick-from-tables.js +7 -98
  44. package/dist/math/picking/pick-from-tables.js.map +1 -1
  45. package/dist/math/picking/pick-result.d.ts +5 -2
  46. package/dist/math/plane/plane.d.ts +43 -0
  47. package/dist/math/plane/plane.js +70 -0
  48. package/dist/math/plane/plane.js.map +1 -0
  49. package/dist/math/plane/plane.test.d.ts +1 -0
  50. package/dist/math/plane/plane.test.js +132 -0
  51. package/dist/math/plane/plane.test.js.map +1 -0
  52. package/dist/math/quat/quat.d.ts +49 -39
  53. package/dist/math/quat/quat.js +225 -185
  54. package/dist/math/quat/quat.js.map +1 -1
  55. package/dist/math/u32/u32.d.ts +9 -7
  56. package/dist/math/u32/u32.js +4 -1
  57. package/dist/math/u32/u32.js.map +1 -1
  58. package/dist/math/vec2/vec2.d.ts +61 -61
  59. package/dist/math/vec2/vec2.js +93 -90
  60. package/dist/math/vec2/vec2.js.map +1 -1
  61. package/dist/math/vec3/vec3.d.ts +66 -63
  62. package/dist/math/vec3/vec3.js +137 -129
  63. package/dist/math/vec3/vec3.js.map +1 -1
  64. package/dist/math/vec4/vec4.d.ts +61 -61
  65. package/dist/math/vec4/vec4.js +132 -129
  66. package/dist/math/vec4/vec4.js.map +1 -1
  67. package/dist/observe/to-async-generator.js +4 -4
  68. package/dist/observe/to-async-generator.js.map +1 -1
  69. package/dist/old-ecs/action-ecs/action-ecs.test.js +1 -1
  70. package/dist/old-ecs/action-ecs/action-ecs.test.js.map +1 -1
  71. package/dist/old-ecs/action-ecs/action-types.d.ts +7 -0
  72. package/dist/old-ecs/action-ecs/action-types.js.map +1 -1
  73. package/dist/old-ecs/core-ecs/core-ecs-serialization.test.js +205 -1
  74. package/dist/old-ecs/core-ecs/core-ecs-serialization.test.js.map +1 -1
  75. package/dist/old-ecs/core-ecs/core-ecs-types.d.ts +4 -1
  76. package/dist/old-ecs/core-ecs/core-ecs.d.ts +2 -0
  77. package/dist/old-ecs/core-ecs/core-ecs.js +23 -9
  78. package/dist/old-ecs/core-ecs/core-ecs.js.map +1 -1
  79. package/dist/old-ecs/ecs/ecs-types.d.ts +7 -0
  80. package/dist/old-ecs/ecs/ecs.test.js +1 -1
  81. package/dist/old-ecs/ecs/ecs.test.js.map +1 -1
  82. package/dist/old-ecs/privacy/helper-functions.d.ts +43 -0
  83. package/dist/old-ecs/privacy/helper-functions.js +76 -0
  84. package/dist/old-ecs/privacy/helper-functions.js.map +1 -0
  85. package/dist/old-ecs/privacy/helper-functions.test.d.ts +1 -0
  86. package/dist/old-ecs/privacy/helper-functions.test.js +173 -0
  87. package/dist/old-ecs/privacy/helper-functions.test.js.map +1 -0
  88. package/dist/old-ecs/transaction-ecs/transaction-ecs.test.js +1 -1
  89. package/dist/old-ecs/transaction-ecs/transaction-ecs.test.js.map +1 -1
  90. package/dist/old-ecs/transaction-ecs/transaction-types.d.ts +7 -0
  91. package/dist/samples/todo/services/state-service/create-todo-database.d.ts +2 -2
  92. package/dist/samples/todo/services/state-service/create-todo-store.d.ts +2 -2
  93. package/dist/tsconfig.tsbuildinfo +1 -1
  94. 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 const schema = {
26
- type: 'array',
27
- items: F32Schema,
28
- minItems: 16,
29
- maxItems: 16,
30
- default: [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1], // identity matrix
31
- };
32
- export const layout = getStructLayout(schema);
33
- // Basic Matrix Operations
34
- export const identity = () => [
35
- 1, 0, 0, 0,
36
- 0, 1, 0, 0,
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
- // Projection Matrices
196
- export const perspective = (fovy, aspect, near, far) => {
197
- if (fovy <= 0)
198
- throw new Error('Field of view must be greater than 0');
199
- if (aspect <= 0)
200
- throw new Error('Aspect ratio must be greater than 0');
201
- if (near <= 0)
202
- throw new Error('Near plane must be greater than 0');
203
- if (far <= near)
204
- throw new Error('Far plane must be greater than near plane');
205
- const f = 1.0 / Math.tan(fovy / 2);
206
- const nf = near / (near - far);
207
- return [
208
- f / aspect, 0, 0, 0,
209
- 0, f, 0, 0,
210
- 0, 0, nf, -1,
211
- 0, 0, near * nf, 0
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
- export const orthographic = (left, right, bottom, top, near, far) => {
215
- const lr = 1 / (left - right);
216
- const bt = 1 / (bottom - top);
217
- const nf = 1 / (near - far);
218
- return [
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
- // View Matrix
226
- export const lookAt = (eye, center, up) => {
227
- // Validate inputs
228
- if (Vec3.length(up) === 0)
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,4 @@
1
+ import { Entity } from "../../ecs/index.js";
2
+ import { Aabb, Line3 } from "../index.js";
3
+ import { PickResult } from "./pick-result.js";
4
+ export declare function getClosestEntityToLine(rows: Map<Entity, Aabb>, line: Line3): PickResult | null;
@@ -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,4 @@
1
+ import { Entity } from "../../ecs/index.js";
2
+ import { Aabb, Vec3 } from "../index.js";
3
+ import { PickResult } from "./pick-result.js";
4
+ export declare function getClosestEntityToPoint(rows: Map<Entity, Aabb>, point: Vec3): PickResult | null;
@@ -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"}
@@ -1 +1,5 @@
1
1
  export * from "./pick-from-tables.js";
2
+ export * from "./pick-result.js";
3
+ export * from "./get-closest-entity-to-point.js";
4
+ export * from "./get-closest-entity-to-line.js";
5
+ export * from "./get-intersecting-entities.js";
@@ -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<{