@onerjs/serializers 8.23.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/OBJ/index.d.ts +1 -0
- package/OBJ/index.js +2 -0
- package/OBJ/index.js.map +1 -0
- package/OBJ/objSerializer.d.ts +21 -0
- package/OBJ/objSerializer.js +171 -0
- package/OBJ/objSerializer.js.map +1 -0
- package/USDZ/index.d.ts +1 -0
- package/USDZ/index.js +3 -0
- package/USDZ/index.js.map +1 -0
- package/USDZ/usdzExporter.d.ts +50 -0
- package/USDZ/usdzExporter.js +589 -0
- package/USDZ/usdzExporter.js.map +1 -0
- package/exportUtils.d.ts +12 -0
- package/exportUtils.js +37 -0
- package/exportUtils.js.map +1 -0
- package/glTF/2.0/Extensions/EXT_materials_diffuse_roughness.d.ts +24 -0
- package/glTF/2.0/Extensions/EXT_materials_diffuse_roughness.js +61 -0
- package/glTF/2.0/Extensions/EXT_materials_diffuse_roughness.js.map +1 -0
- package/glTF/2.0/Extensions/EXT_mesh_gpu_instancing.d.ts +36 -0
- package/glTF/2.0/Extensions/EXT_mesh_gpu_instancing.js +109 -0
- package/glTF/2.0/Extensions/EXT_mesh_gpu_instancing.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_draco_mesh_compression.d.ts +32 -0
- package/glTF/2.0/Extensions/KHR_draco_mesh_compression.js +135 -0
- package/glTF/2.0/Extensions/KHR_draco_mesh_compression.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_lights_punctual.d.ts +39 -0
- package/glTF/2.0/Extensions/KHR_lights_punctual.js +145 -0
- package/glTF/2.0/Extensions/KHR_lights_punctual.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_materials_anisotropy.d.ts +24 -0
- package/glTF/2.0/Extensions/KHR_materials_anisotropy.js +62 -0
- package/glTF/2.0/Extensions/KHR_materials_anisotropy.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_materials_clearcoat.d.ts +24 -0
- package/glTF/2.0/Extensions/KHR_materials_clearcoat.js +85 -0
- package/glTF/2.0/Extensions/KHR_materials_clearcoat.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_materials_diffuse_transmission.d.ts +40 -0
- package/glTF/2.0/Extensions/KHR_materials_diffuse_transmission.js +118 -0
- package/glTF/2.0/Extensions/KHR_materials_diffuse_transmission.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_materials_dispersion.d.ts +31 -0
- package/glTF/2.0/Extensions/KHR_materials_dispersion.js +63 -0
- package/glTF/2.0/Extensions/KHR_materials_dispersion.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_materials_emissive_strength.d.ts +27 -0
- package/glTF/2.0/Extensions/KHR_materials_emissive_strength.js +54 -0
- package/glTF/2.0/Extensions/KHR_materials_emissive_strength.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_materials_ior.d.ts +29 -0
- package/glTF/2.0/Extensions/KHR_materials_ior.js +55 -0
- package/glTF/2.0/Extensions/KHR_materials_ior.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_materials_iridescence.d.ts +24 -0
- package/glTF/2.0/Extensions/KHR_materials_iridescence.js +69 -0
- package/glTF/2.0/Extensions/KHR_materials_iridescence.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_materials_sheen.d.ts +24 -0
- package/glTF/2.0/Extensions/KHR_materials_sheen.js +66 -0
- package/glTF/2.0/Extensions/KHR_materials_sheen.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_materials_specular.d.ts +41 -0
- package/glTF/2.0/Extensions/KHR_materials_specular.js +94 -0
- package/glTF/2.0/Extensions/KHR_materials_specular.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_materials_transmission.d.ts +41 -0
- package/glTF/2.0/Extensions/KHR_materials_transmission.js +92 -0
- package/glTF/2.0/Extensions/KHR_materials_transmission.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_materials_unlit.d.ts +20 -0
- package/glTF/2.0/Extensions/KHR_materials_unlit.js +46 -0
- package/glTF/2.0/Extensions/KHR_materials_unlit.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_materials_volume.d.ts +40 -0
- package/glTF/2.0/Extensions/KHR_materials_volume.js +96 -0
- package/glTF/2.0/Extensions/KHR_materials_volume.js.map +1 -0
- package/glTF/2.0/Extensions/KHR_texture_transform.d.ts +21 -0
- package/glTF/2.0/Extensions/KHR_texture_transform.js +93 -0
- package/glTF/2.0/Extensions/KHR_texture_transform.js.map +1 -0
- package/glTF/2.0/Extensions/index.d.ts +17 -0
- package/glTF/2.0/Extensions/index.js +18 -0
- package/glTF/2.0/Extensions/index.js.map +1 -0
- package/glTF/2.0/bufferManager.d.ts +68 -0
- package/glTF/2.0/bufferManager.js +154 -0
- package/glTF/2.0/bufferManager.js.map +1 -0
- package/glTF/2.0/dataWriter.d.ts +20 -0
- package/glTF/2.0/dataWriter.js +83 -0
- package/glTF/2.0/dataWriter.js.map +1 -0
- package/glTF/2.0/glTFAnimation.d.ts +191 -0
- package/glTF/2.0/glTFAnimation.js +786 -0
- package/glTF/2.0/glTFAnimation.js.map +1 -0
- package/glTF/2.0/glTFData.d.ts +21 -0
- package/glTF/2.0/glTFData.js +30 -0
- package/glTF/2.0/glTFData.js.map +1 -0
- package/glTF/2.0/glTFExporter.d.ts +109 -0
- package/glTF/2.0/glTFExporter.js +1166 -0
- package/glTF/2.0/glTFExporter.js.map +1 -0
- package/glTF/2.0/glTFExporterExtension.d.ts +77 -0
- package/glTF/2.0/glTFExporterExtension.js +4 -0
- package/glTF/2.0/glTFExporterExtension.js.map +1 -0
- package/glTF/2.0/glTFMaterialExporter.d.ts +99 -0
- package/glTF/2.0/glTFMaterialExporter.js +778 -0
- package/glTF/2.0/glTFMaterialExporter.js.map +1 -0
- package/glTF/2.0/glTFMorphTargetsUtilities.d.ts +14 -0
- package/glTF/2.0/glTFMorphTargetsUtilities.js +149 -0
- package/glTF/2.0/glTFMorphTargetsUtilities.js.map +1 -0
- package/glTF/2.0/glTFSerializer.d.ts +78 -0
- package/glTF/2.0/glTFSerializer.js +39 -0
- package/glTF/2.0/glTFSerializer.js.map +1 -0
- package/glTF/2.0/glTFUtilities.d.ts +89 -0
- package/glTF/2.0/glTFUtilities.js +349 -0
- package/glTF/2.0/glTFUtilities.js.map +1 -0
- package/glTF/2.0/index.d.ts +4 -0
- package/glTF/2.0/index.js +6 -0
- package/glTF/2.0/index.js.map +1 -0
- package/glTF/glTFFileExporter.d.ts +20 -0
- package/glTF/glTFFileExporter.js +4 -0
- package/glTF/glTFFileExporter.js.map +1 -0
- package/glTF/index.d.ts +2 -0
- package/glTF/index.js +4 -0
- package/glTF/index.js.map +1 -0
- package/index.d.ts +4 -0
- package/index.js +6 -0
- package/index.js.map +1 -0
- package/legacy/legacy-glTF2Serializer.d.ts +2 -0
- package/legacy/legacy-glTF2Serializer.js +45 -0
- package/legacy/legacy-glTF2Serializer.js.map +1 -0
- package/legacy/legacy-objSerializer.d.ts +1 -0
- package/legacy/legacy-objSerializer.js +14 -0
- package/legacy/legacy-objSerializer.js.map +1 -0
- package/legacy/legacy-stlSerializer.d.ts +1 -0
- package/legacy/legacy-stlSerializer.js +14 -0
- package/legacy/legacy-stlSerializer.js.map +1 -0
- package/legacy/legacy-usdzSerializer.d.ts +1 -0
- package/legacy/legacy-usdzSerializer.js +14 -0
- package/legacy/legacy-usdzSerializer.js.map +1 -0
- package/legacy/legacy.d.ts +5 -0
- package/legacy/legacy.js +8 -0
- package/legacy/legacy.js.map +1 -0
- package/license.md +71 -0
- package/package.json +49 -0
- package/readme.md +29 -0
- package/stl/index.d.ts +1 -0
- package/stl/index.js +2 -0
- package/stl/index.js.map +1 -0
- package/stl/stlSerializer.d.ts +20 -0
- package/stl/stlSerializer.js +135 -0
- package/stl/stlSerializer.js.map +1 -0
|
@@ -0,0 +1,349 @@
|
|
|
1
|
+
import { Quaternion, TmpVectors, Matrix, Vector3 } from "@babylonjs/core/Maths/math.vector.js";
|
|
2
|
+
import { VertexBuffer } from "@babylonjs/core/Buffers/buffer.js";
|
|
3
|
+
import { Material } from "@babylonjs/core/Materials/material.js";
|
|
4
|
+
import { TransformNode } from "@babylonjs/core/Meshes/transformNode.js";
|
|
5
|
+
import { EnumerateFloatValues } from "@babylonjs/core/Buffers/bufferUtils.js";
|
|
6
|
+
import { Logger } from "@babylonjs/core/Misc/logger.js";
|
|
7
|
+
import { TargetCamera } from "@babylonjs/core/Cameras/targetCamera.js";
|
|
8
|
+
import { Epsilon } from "@babylonjs/core/Maths/math.constants.js";
|
|
9
|
+
import { ConvertHandednessMatrix } from "../../exportUtils.js";
|
|
10
|
+
// Default values for comparison.
|
|
11
|
+
export const DefaultTranslation = Vector3.Zero();
|
|
12
|
+
export const DefaultRotation = Quaternion.Identity();
|
|
13
|
+
export const DefaultScale = Vector3.One();
|
|
14
|
+
const DefaultLoaderCameraParentScaleLh = new Vector3(-1, 1, 1);
|
|
15
|
+
/**
|
|
16
|
+
* Get the information necessary for enumerating a vertex buffer.
|
|
17
|
+
* @param vertexBuffer the vertex buffer to enumerate
|
|
18
|
+
* @param meshes the meshes that use the vertex buffer
|
|
19
|
+
* @returns the information necessary to enumerate the vertex buffer
|
|
20
|
+
*/
|
|
21
|
+
export function GetVertexBufferInfo(vertexBuffer, meshes) {
|
|
22
|
+
const { byteOffset, byteStride, type, normalized } = vertexBuffer;
|
|
23
|
+
const componentCount = vertexBuffer.getSize();
|
|
24
|
+
const totalVertices = meshes.reduce((max, current) => {
|
|
25
|
+
return current.getTotalVertices() > max ? current.getTotalVertices() : max;
|
|
26
|
+
}, -Number.MAX_VALUE); // Get the max total vertices count, to ensure we capture the full range of vertex data used by the meshes.
|
|
27
|
+
const count = totalVertices * componentCount;
|
|
28
|
+
const kind = vertexBuffer.getKind();
|
|
29
|
+
return { byteOffset, byteStride, componentCount, type, count, normalized, totalVertices, kind };
|
|
30
|
+
}
|
|
31
|
+
export function GetAccessorElementCount(accessorType) {
|
|
32
|
+
switch (accessorType) {
|
|
33
|
+
case "MAT2" /* AccessorType.MAT2 */:
|
|
34
|
+
return 4;
|
|
35
|
+
case "MAT3" /* AccessorType.MAT3 */:
|
|
36
|
+
return 9;
|
|
37
|
+
case "MAT4" /* AccessorType.MAT4 */:
|
|
38
|
+
return 16;
|
|
39
|
+
case "SCALAR" /* AccessorType.SCALAR */:
|
|
40
|
+
return 1;
|
|
41
|
+
case "VEC2" /* AccessorType.VEC2 */:
|
|
42
|
+
return 2;
|
|
43
|
+
case "VEC3" /* AccessorType.VEC3 */:
|
|
44
|
+
return 3;
|
|
45
|
+
case "VEC4" /* AccessorType.VEC4 */:
|
|
46
|
+
return 4;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
export function FloatsNeed16BitInteger(floatArray) {
|
|
50
|
+
return floatArray.some((value) => value >= 256);
|
|
51
|
+
}
|
|
52
|
+
export function IsStandardVertexAttribute(type) {
|
|
53
|
+
switch (type) {
|
|
54
|
+
case VertexBuffer.PositionKind:
|
|
55
|
+
case VertexBuffer.NormalKind:
|
|
56
|
+
case VertexBuffer.TangentKind:
|
|
57
|
+
case VertexBuffer.ColorKind:
|
|
58
|
+
case VertexBuffer.MatricesIndicesKind:
|
|
59
|
+
case VertexBuffer.MatricesIndicesExtraKind:
|
|
60
|
+
case VertexBuffer.MatricesWeightsKind:
|
|
61
|
+
case VertexBuffer.MatricesWeightsExtraKind:
|
|
62
|
+
case VertexBuffer.UVKind:
|
|
63
|
+
case VertexBuffer.UV2Kind:
|
|
64
|
+
case VertexBuffer.UV3Kind:
|
|
65
|
+
case VertexBuffer.UV4Kind:
|
|
66
|
+
case VertexBuffer.UV5Kind:
|
|
67
|
+
case VertexBuffer.UV6Kind:
|
|
68
|
+
return true;
|
|
69
|
+
}
|
|
70
|
+
return false;
|
|
71
|
+
}
|
|
72
|
+
export function GetAccessorType(kind, hasVertexColorAlpha) {
|
|
73
|
+
if (kind == VertexBuffer.ColorKind) {
|
|
74
|
+
return hasVertexColorAlpha ? "VEC4" /* AccessorType.VEC4 */ : "VEC3" /* AccessorType.VEC3 */;
|
|
75
|
+
}
|
|
76
|
+
switch (kind) {
|
|
77
|
+
case VertexBuffer.PositionKind:
|
|
78
|
+
case VertexBuffer.NormalKind:
|
|
79
|
+
return "VEC3" /* AccessorType.VEC3 */;
|
|
80
|
+
case VertexBuffer.TangentKind:
|
|
81
|
+
case VertexBuffer.MatricesIndicesKind:
|
|
82
|
+
case VertexBuffer.MatricesIndicesExtraKind:
|
|
83
|
+
case VertexBuffer.MatricesWeightsKind:
|
|
84
|
+
case VertexBuffer.MatricesWeightsExtraKind:
|
|
85
|
+
return "VEC4" /* AccessorType.VEC4 */;
|
|
86
|
+
case VertexBuffer.UVKind:
|
|
87
|
+
case VertexBuffer.UV2Kind:
|
|
88
|
+
case VertexBuffer.UV3Kind:
|
|
89
|
+
case VertexBuffer.UV4Kind:
|
|
90
|
+
case VertexBuffer.UV5Kind:
|
|
91
|
+
case VertexBuffer.UV6Kind:
|
|
92
|
+
return "VEC2" /* AccessorType.VEC2 */;
|
|
93
|
+
}
|
|
94
|
+
throw new Error(`Unknown kind ${kind}`);
|
|
95
|
+
}
|
|
96
|
+
export function GetAttributeType(kind) {
|
|
97
|
+
switch (kind) {
|
|
98
|
+
case VertexBuffer.PositionKind:
|
|
99
|
+
return "POSITION";
|
|
100
|
+
case VertexBuffer.NormalKind:
|
|
101
|
+
return "NORMAL";
|
|
102
|
+
case VertexBuffer.TangentKind:
|
|
103
|
+
return "TANGENT";
|
|
104
|
+
case VertexBuffer.ColorKind:
|
|
105
|
+
return "COLOR_0";
|
|
106
|
+
case VertexBuffer.UVKind:
|
|
107
|
+
return "TEXCOORD_0";
|
|
108
|
+
case VertexBuffer.UV2Kind:
|
|
109
|
+
return "TEXCOORD_1";
|
|
110
|
+
case VertexBuffer.UV3Kind:
|
|
111
|
+
return "TEXCOORD_2";
|
|
112
|
+
case VertexBuffer.UV4Kind:
|
|
113
|
+
return "TEXCOORD_3";
|
|
114
|
+
case VertexBuffer.UV5Kind:
|
|
115
|
+
return "TEXCOORD_4";
|
|
116
|
+
case VertexBuffer.UV6Kind:
|
|
117
|
+
return "TEXCOORD_5";
|
|
118
|
+
case VertexBuffer.MatricesIndicesKind:
|
|
119
|
+
return "JOINTS_0";
|
|
120
|
+
case VertexBuffer.MatricesIndicesExtraKind:
|
|
121
|
+
return "JOINTS_1";
|
|
122
|
+
case VertexBuffer.MatricesWeightsKind:
|
|
123
|
+
return "WEIGHTS_0";
|
|
124
|
+
case VertexBuffer.MatricesWeightsExtraKind:
|
|
125
|
+
return "WEIGHTS_1";
|
|
126
|
+
}
|
|
127
|
+
throw new Error(`Unknown kind: ${kind}`);
|
|
128
|
+
}
|
|
129
|
+
export function GetPrimitiveMode(fillMode) {
|
|
130
|
+
switch (fillMode) {
|
|
131
|
+
case Material.TriangleFillMode:
|
|
132
|
+
return 4 /* MeshPrimitiveMode.TRIANGLES */;
|
|
133
|
+
case Material.TriangleStripDrawMode:
|
|
134
|
+
return 5 /* MeshPrimitiveMode.TRIANGLE_STRIP */;
|
|
135
|
+
case Material.TriangleFanDrawMode:
|
|
136
|
+
return 6 /* MeshPrimitiveMode.TRIANGLE_FAN */;
|
|
137
|
+
case Material.PointListDrawMode:
|
|
138
|
+
case Material.PointFillMode:
|
|
139
|
+
return 0 /* MeshPrimitiveMode.POINTS */;
|
|
140
|
+
case Material.LineLoopDrawMode:
|
|
141
|
+
return 2 /* MeshPrimitiveMode.LINE_LOOP */;
|
|
142
|
+
case Material.LineListDrawMode:
|
|
143
|
+
return 1 /* MeshPrimitiveMode.LINES */;
|
|
144
|
+
case Material.LineStripDrawMode:
|
|
145
|
+
return 3 /* MeshPrimitiveMode.LINE_STRIP */;
|
|
146
|
+
}
|
|
147
|
+
throw new Error(`Unknown fill mode: ${fillMode}`);
|
|
148
|
+
}
|
|
149
|
+
export function IsTriangleFillMode(fillMode) {
|
|
150
|
+
switch (fillMode) {
|
|
151
|
+
case Material.TriangleFillMode:
|
|
152
|
+
case Material.TriangleStripDrawMode:
|
|
153
|
+
case Material.TriangleFanDrawMode:
|
|
154
|
+
return true;
|
|
155
|
+
}
|
|
156
|
+
return false;
|
|
157
|
+
}
|
|
158
|
+
export function NormalizeTangent(tangent) {
|
|
159
|
+
const length = Math.sqrt(tangent.x * tangent.x + tangent.y * tangent.y + tangent.z * tangent.z);
|
|
160
|
+
if (length > 0) {
|
|
161
|
+
tangent.x /= length;
|
|
162
|
+
tangent.y /= length;
|
|
163
|
+
tangent.z /= length;
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
export function ConvertToRightHandedPosition(value) {
|
|
167
|
+
value.x *= -1;
|
|
168
|
+
return value;
|
|
169
|
+
}
|
|
170
|
+
/** @internal */
|
|
171
|
+
export function ConvertToRightHandedTransformMatrix(matrix) {
|
|
172
|
+
ConvertHandednessMatrix.invertToRef(TmpVectors.Matrix[0]).multiplyToRef(matrix, matrix).multiplyToRef(ConvertHandednessMatrix, matrix);
|
|
173
|
+
return matrix;
|
|
174
|
+
}
|
|
175
|
+
/**
|
|
176
|
+
* Converts, in-place, a left-handed quaternion to a right-handed quaternion via a change of basis.
|
|
177
|
+
* @param value the unit quaternion to convert
|
|
178
|
+
* @returns the converted quaternion
|
|
179
|
+
*/
|
|
180
|
+
export function ConvertToRightHandedRotation(value) {
|
|
181
|
+
/**
|
|
182
|
+
* This is the simplified version of the following equation:
|
|
183
|
+
* q' = to_quaternion(M * to_matrix(q) * M^-1)
|
|
184
|
+
* where M is the conversion matrix `convertHandednessMatrix`,
|
|
185
|
+
* q is the input quaternion, and q' is the converted quaternion.
|
|
186
|
+
* Reference: https://d3cw3dd2w32x2b.cloudfront.net/wp-content/uploads/2015/01/matrix-to-quat.pdf
|
|
187
|
+
*/
|
|
188
|
+
if (value.x * value.x + value.y * value.y > 0.5) {
|
|
189
|
+
const absX = Math.abs(value.x);
|
|
190
|
+
const absY = Math.abs(value.y);
|
|
191
|
+
if (absX > absY) {
|
|
192
|
+
const sign = Math.sign(value.x);
|
|
193
|
+
value.x = absX;
|
|
194
|
+
value.y *= -sign;
|
|
195
|
+
value.z *= -sign;
|
|
196
|
+
value.w *= sign;
|
|
197
|
+
}
|
|
198
|
+
else {
|
|
199
|
+
const sign = Math.sign(value.y);
|
|
200
|
+
value.x *= -sign;
|
|
201
|
+
value.y = absY;
|
|
202
|
+
value.z *= sign;
|
|
203
|
+
value.w *= -sign;
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
else {
|
|
207
|
+
const absZ = Math.abs(value.z);
|
|
208
|
+
const absW = Math.abs(value.w);
|
|
209
|
+
if (absZ > absW) {
|
|
210
|
+
const sign = Math.sign(value.z);
|
|
211
|
+
value.x *= -sign;
|
|
212
|
+
value.y *= sign;
|
|
213
|
+
value.z = absZ;
|
|
214
|
+
value.w *= -sign;
|
|
215
|
+
}
|
|
216
|
+
else {
|
|
217
|
+
const sign = Math.sign(value.w);
|
|
218
|
+
value.x *= sign;
|
|
219
|
+
value.y *= -sign;
|
|
220
|
+
value.z *= -sign;
|
|
221
|
+
value.w = absW;
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
return value;
|
|
225
|
+
}
|
|
226
|
+
/**
|
|
227
|
+
* Pre-multiplies a 180-degree Y rotation to the quaternion, in order to match glTF's flipped forward direction for cameras.
|
|
228
|
+
* @param rotation Target camera rotation.
|
|
229
|
+
*/
|
|
230
|
+
export function Rotate180Y(rotation) {
|
|
231
|
+
// Simplified from: rotation * (0, 1, 0, 0).
|
|
232
|
+
rotation.copyFromFloats(-rotation.z, rotation.w, rotation.x, -rotation.y);
|
|
233
|
+
}
|
|
234
|
+
/**
|
|
235
|
+
* Collapses GLTF parent and node into a single node, ignoring scaling.
|
|
236
|
+
* This is useful for removing nodes that were added by the GLTF importer.
|
|
237
|
+
* @param node Original GLTF node (Light or Camera).
|
|
238
|
+
* @param parentNode Target parent node.
|
|
239
|
+
*/
|
|
240
|
+
export function CollapseChildIntoParent(node, parentNode) {
|
|
241
|
+
const parentTranslation = Vector3.FromArrayToRef(parentNode.translation || [0, 0, 0], 0, TmpVectors.Vector3[0]);
|
|
242
|
+
const parentRotation = Quaternion.FromArrayToRef(parentNode.rotation || [0, 0, 0, 1], 0, TmpVectors.Quaternion[0]);
|
|
243
|
+
const parentMatrix = Matrix.ComposeToRef(DefaultScale, parentRotation, parentTranslation, TmpVectors.Matrix[0]);
|
|
244
|
+
const translation = Vector3.FromArrayToRef(node.translation || [0, 0, 0], 0, TmpVectors.Vector3[2]);
|
|
245
|
+
const rotation = Quaternion.FromArrayToRef(node.rotation || [0, 0, 0, 1], 0, TmpVectors.Quaternion[1]);
|
|
246
|
+
const matrix = Matrix.ComposeToRef(DefaultScale, rotation, translation, TmpVectors.Matrix[1]);
|
|
247
|
+
parentMatrix.multiplyToRef(matrix, matrix);
|
|
248
|
+
matrix.decompose(undefined, parentRotation, parentTranslation);
|
|
249
|
+
if (parentTranslation.equalsWithEpsilon(DefaultTranslation, Epsilon)) {
|
|
250
|
+
delete parentNode.translation;
|
|
251
|
+
}
|
|
252
|
+
else {
|
|
253
|
+
parentNode.translation = parentTranslation.asArray();
|
|
254
|
+
}
|
|
255
|
+
if (parentRotation.equalsWithEpsilon(DefaultRotation, Epsilon)) {
|
|
256
|
+
delete parentNode.rotation;
|
|
257
|
+
}
|
|
258
|
+
else {
|
|
259
|
+
parentNode.rotation = parentRotation.asArray();
|
|
260
|
+
}
|
|
261
|
+
if (parentNode.scale) {
|
|
262
|
+
delete parentNode.scale;
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
/**
|
|
266
|
+
* Checks whether a camera or light node is candidate for collapsing with its parent node.
|
|
267
|
+
* This is useful for roundtrips, as the glTF Importer parents a new node to
|
|
268
|
+
* lights and cameras to store their original transformation information.
|
|
269
|
+
* @param babylonNode Babylon light or camera node.
|
|
270
|
+
* @param parentBabylonNode Target Babylon parent node.
|
|
271
|
+
* @returns True if the two nodes can be merged, false otherwise.
|
|
272
|
+
*/
|
|
273
|
+
export function IsChildCollapsible(babylonNode, parentBabylonNode) {
|
|
274
|
+
if (!(parentBabylonNode instanceof TransformNode)) {
|
|
275
|
+
return false;
|
|
276
|
+
}
|
|
277
|
+
// Verify child is the only descendant
|
|
278
|
+
const isOnlyDescendant = parentBabylonNode.getChildren().length === 1 && babylonNode.getChildren().length === 0 && babylonNode.parent === parentBabylonNode;
|
|
279
|
+
if (!isOnlyDescendant) {
|
|
280
|
+
return false;
|
|
281
|
+
}
|
|
282
|
+
// Verify parent has the expected scaling, determined by the node type and scene's coordinate system.
|
|
283
|
+
const scene = babylonNode.getScene();
|
|
284
|
+
const expectedScale = babylonNode instanceof TargetCamera && !scene.useRightHandedSystem ? DefaultLoaderCameraParentScaleLh : DefaultScale;
|
|
285
|
+
if (!parentBabylonNode.scaling.equalsWithEpsilon(expectedScale, Epsilon)) {
|
|
286
|
+
Logger.Warn(`Cannot collapse node ${babylonNode.name} into parent node ${parentBabylonNode.name} with modified scaling.`);
|
|
287
|
+
return false;
|
|
288
|
+
}
|
|
289
|
+
return true;
|
|
290
|
+
}
|
|
291
|
+
/**
|
|
292
|
+
* Converts an IndicesArray into either Uint32Array or Uint16Array, only copying if the data is number[].
|
|
293
|
+
* @param indices input array to be converted
|
|
294
|
+
* @param start starting index to copy from
|
|
295
|
+
* @param count number of indices to copy
|
|
296
|
+
* @returns a Uint32Array or Uint16Array
|
|
297
|
+
* @internal
|
|
298
|
+
*/
|
|
299
|
+
export function IndicesArrayToTypedArray(indices, start, count, is32Bits) {
|
|
300
|
+
if (indices instanceof Uint16Array || indices instanceof Uint32Array) {
|
|
301
|
+
return indices;
|
|
302
|
+
}
|
|
303
|
+
// If Int32Array, cast the indices (which are all positive) to Uint32Array
|
|
304
|
+
if (indices instanceof Int32Array) {
|
|
305
|
+
return new Uint32Array(indices.buffer, indices.byteOffset, indices.length);
|
|
306
|
+
}
|
|
307
|
+
const subarray = indices.slice(start, start + count);
|
|
308
|
+
return is32Bits ? new Uint32Array(subarray) : new Uint16Array(subarray);
|
|
309
|
+
}
|
|
310
|
+
export function DataArrayToUint8Array(data) {
|
|
311
|
+
if (data instanceof Array) {
|
|
312
|
+
const floatData = new Float32Array(data);
|
|
313
|
+
return new Uint8Array(floatData.buffer, floatData.byteOffset, floatData.byteLength);
|
|
314
|
+
}
|
|
315
|
+
return ArrayBuffer.isView(data) ? new Uint8Array(data.buffer, data.byteOffset, data.byteLength) : new Uint8Array(data);
|
|
316
|
+
}
|
|
317
|
+
export function GetMinMax(data, vertexBuffer, start, count) {
|
|
318
|
+
const { byteOffset, byteStride, type, normalized } = vertexBuffer;
|
|
319
|
+
const size = vertexBuffer.getSize();
|
|
320
|
+
const min = new Array(size).fill(Infinity);
|
|
321
|
+
const max = new Array(size).fill(-Infinity);
|
|
322
|
+
EnumerateFloatValues(data, byteOffset + start * byteStride, byteStride, size, type, count * size, normalized, (values) => {
|
|
323
|
+
for (let i = 0; i < size; i++) {
|
|
324
|
+
min[i] = Math.min(min[i], values[i]);
|
|
325
|
+
max[i] = Math.max(max[i], values[i]);
|
|
326
|
+
}
|
|
327
|
+
});
|
|
328
|
+
return { min, max };
|
|
329
|
+
}
|
|
330
|
+
/**
|
|
331
|
+
* Removes, in-place, object properties which have the same value as the default value.
|
|
332
|
+
* Useful for avoiding unnecessary properties in the glTF JSON.
|
|
333
|
+
* @param object the object to omit default values from
|
|
334
|
+
* @param defaultValues a partial object with default values
|
|
335
|
+
* @returns object with default values omitted
|
|
336
|
+
*/
|
|
337
|
+
export function OmitDefaultValues(object, defaultValues) {
|
|
338
|
+
for (const [key, value] of Object.entries(object)) {
|
|
339
|
+
const defaultValue = defaultValues[key];
|
|
340
|
+
if ((Array.isArray(value) && Array.isArray(defaultValue) && AreArraysEqual(value, defaultValue)) || value === defaultValue) {
|
|
341
|
+
delete object[key];
|
|
342
|
+
}
|
|
343
|
+
}
|
|
344
|
+
return object;
|
|
345
|
+
}
|
|
346
|
+
function AreArraysEqual(array1, array2) {
|
|
347
|
+
return array1.length === array2.length && array1.every((val, i) => val === array2[i]);
|
|
348
|
+
}
|
|
349
|
+
//# sourceMappingURL=glTFUtilities.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"glTFUtilities.js","sourceRoot":"","sources":["../../../../../dev/serializers/src/glTF/2.0/glTFUtilities.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\r\nimport type { INode } from \"babylonjs-gltf2interface\";\r\nimport { AccessorType, MeshPrimitiveMode } from \"babylonjs-gltf2interface\";\r\nimport type { FloatArray, DataArray, IndicesArray } from \"core/types\";\r\nimport type { Vector4 } from \"core/Maths/math.vector\";\r\nimport { Quaternion, TmpVectors, Matrix, Vector3 } from \"core/Maths/math.vector\";\r\nimport { VertexBuffer } from \"core/Buffers/buffer\";\r\nimport { Material } from \"core/Materials/material\";\r\nimport { TransformNode } from \"core/Meshes/transformNode\";\r\nimport type { AbstractMesh } from \"core/Meshes/abstractMesh\";\r\nimport { EnumerateFloatValues } from \"core/Buffers/bufferUtils\";\r\nimport type { Node } from \"core/node\";\r\nimport { Logger } from \"core/Misc/logger\";\r\nimport { TargetCamera } from \"core/Cameras/targetCamera\";\r\nimport type { ShadowLight } from \"core/Lights/shadowLight\";\r\nimport { Epsilon } from \"core/Maths/math.constants\";\r\nimport { ConvertHandednessMatrix } from \"../../exportUtils\";\r\n\r\n// Default values for comparison.\r\nexport const DefaultTranslation = Vector3.Zero();\r\nexport const DefaultRotation = Quaternion.Identity();\r\nexport const DefaultScale = Vector3.One();\r\nconst DefaultLoaderCameraParentScaleLh = new Vector3(-1, 1, 1);\r\n\r\n/**\r\n * Get the information necessary for enumerating a vertex buffer.\r\n * @param vertexBuffer the vertex buffer to enumerate\r\n * @param meshes the meshes that use the vertex buffer\r\n * @returns the information necessary to enumerate the vertex buffer\r\n */\r\nexport function GetVertexBufferInfo(vertexBuffer: VertexBuffer, meshes: AbstractMesh[]) {\r\n const { byteOffset, byteStride, type, normalized } = vertexBuffer;\r\n const componentCount = vertexBuffer.getSize();\r\n const totalVertices = meshes.reduce((max, current) => {\r\n return current.getTotalVertices() > max ? current.getTotalVertices() : max;\r\n }, -Number.MAX_VALUE); // Get the max total vertices count, to ensure we capture the full range of vertex data used by the meshes.\r\n const count = totalVertices * componentCount;\r\n const kind = vertexBuffer.getKind();\r\n\r\n return { byteOffset, byteStride, componentCount, type, count, normalized, totalVertices, kind };\r\n}\r\n\r\nexport function GetAccessorElementCount(accessorType: AccessorType): number {\r\n switch (accessorType) {\r\n case AccessorType.MAT2:\r\n return 4;\r\n case AccessorType.MAT3:\r\n return 9;\r\n case AccessorType.MAT4:\r\n return 16;\r\n case AccessorType.SCALAR:\r\n return 1;\r\n case AccessorType.VEC2:\r\n return 2;\r\n case AccessorType.VEC3:\r\n return 3;\r\n case AccessorType.VEC4:\r\n return 4;\r\n }\r\n}\r\n\r\nexport function FloatsNeed16BitInteger(floatArray: FloatArray): boolean {\r\n return floatArray.some((value) => value >= 256);\r\n}\r\n\r\nexport function IsStandardVertexAttribute(type: string): boolean {\r\n switch (type) {\r\n case VertexBuffer.PositionKind:\r\n case VertexBuffer.NormalKind:\r\n case VertexBuffer.TangentKind:\r\n case VertexBuffer.ColorKind:\r\n case VertexBuffer.MatricesIndicesKind:\r\n case VertexBuffer.MatricesIndicesExtraKind:\r\n case VertexBuffer.MatricesWeightsKind:\r\n case VertexBuffer.MatricesWeightsExtraKind:\r\n case VertexBuffer.UVKind:\r\n case VertexBuffer.UV2Kind:\r\n case VertexBuffer.UV3Kind:\r\n case VertexBuffer.UV4Kind:\r\n case VertexBuffer.UV5Kind:\r\n case VertexBuffer.UV6Kind:\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\nexport function GetAccessorType(kind: string, hasVertexColorAlpha: boolean): AccessorType {\r\n if (kind == VertexBuffer.ColorKind) {\r\n return hasVertexColorAlpha ? AccessorType.VEC4 : AccessorType.VEC3;\r\n }\r\n\r\n switch (kind) {\r\n case VertexBuffer.PositionKind:\r\n case VertexBuffer.NormalKind:\r\n return AccessorType.VEC3;\r\n case VertexBuffer.TangentKind:\r\n case VertexBuffer.MatricesIndicesKind:\r\n case VertexBuffer.MatricesIndicesExtraKind:\r\n case VertexBuffer.MatricesWeightsKind:\r\n case VertexBuffer.MatricesWeightsExtraKind:\r\n return AccessorType.VEC4;\r\n case VertexBuffer.UVKind:\r\n case VertexBuffer.UV2Kind:\r\n case VertexBuffer.UV3Kind:\r\n case VertexBuffer.UV4Kind:\r\n case VertexBuffer.UV5Kind:\r\n case VertexBuffer.UV6Kind:\r\n return AccessorType.VEC2;\r\n }\r\n\r\n throw new Error(`Unknown kind ${kind}`);\r\n}\r\n\r\nexport function GetAttributeType(kind: string): string {\r\n switch (kind) {\r\n case VertexBuffer.PositionKind:\r\n return \"POSITION\";\r\n case VertexBuffer.NormalKind:\r\n return \"NORMAL\";\r\n case VertexBuffer.TangentKind:\r\n return \"TANGENT\";\r\n case VertexBuffer.ColorKind:\r\n return \"COLOR_0\";\r\n case VertexBuffer.UVKind:\r\n return \"TEXCOORD_0\";\r\n case VertexBuffer.UV2Kind:\r\n return \"TEXCOORD_1\";\r\n case VertexBuffer.UV3Kind:\r\n return \"TEXCOORD_2\";\r\n case VertexBuffer.UV4Kind:\r\n return \"TEXCOORD_3\";\r\n case VertexBuffer.UV5Kind:\r\n return \"TEXCOORD_4\";\r\n case VertexBuffer.UV6Kind:\r\n return \"TEXCOORD_5\";\r\n case VertexBuffer.MatricesIndicesKind:\r\n return \"JOINTS_0\";\r\n case VertexBuffer.MatricesIndicesExtraKind:\r\n return \"JOINTS_1\";\r\n case VertexBuffer.MatricesWeightsKind:\r\n return \"WEIGHTS_0\";\r\n case VertexBuffer.MatricesWeightsExtraKind:\r\n return \"WEIGHTS_1\";\r\n }\r\n\r\n throw new Error(`Unknown kind: ${kind}`);\r\n}\r\n\r\nexport function GetPrimitiveMode(fillMode: number): MeshPrimitiveMode {\r\n switch (fillMode) {\r\n case Material.TriangleFillMode:\r\n return MeshPrimitiveMode.TRIANGLES;\r\n case Material.TriangleStripDrawMode:\r\n return MeshPrimitiveMode.TRIANGLE_STRIP;\r\n case Material.TriangleFanDrawMode:\r\n return MeshPrimitiveMode.TRIANGLE_FAN;\r\n case Material.PointListDrawMode:\r\n case Material.PointFillMode:\r\n return MeshPrimitiveMode.POINTS;\r\n case Material.LineLoopDrawMode:\r\n return MeshPrimitiveMode.LINE_LOOP;\r\n case Material.LineListDrawMode:\r\n return MeshPrimitiveMode.LINES;\r\n case Material.LineStripDrawMode:\r\n return MeshPrimitiveMode.LINE_STRIP;\r\n }\r\n\r\n throw new Error(`Unknown fill mode: ${fillMode}`);\r\n}\r\n\r\nexport function IsTriangleFillMode(fillMode: number): boolean {\r\n switch (fillMode) {\r\n case Material.TriangleFillMode:\r\n case Material.TriangleStripDrawMode:\r\n case Material.TriangleFanDrawMode:\r\n return true;\r\n }\r\n\r\n return false;\r\n}\r\n\r\nexport function NormalizeTangent(tangent: Vector4 | Vector3) {\r\n const length = Math.sqrt(tangent.x * tangent.x + tangent.y * tangent.y + tangent.z * tangent.z);\r\n if (length > 0) {\r\n tangent.x /= length;\r\n tangent.y /= length;\r\n tangent.z /= length;\r\n }\r\n}\r\n\r\nexport function ConvertToRightHandedPosition(value: Vector3): Vector3 {\r\n value.x *= -1;\r\n return value;\r\n}\r\n\r\n/** @internal */\r\nexport function ConvertToRightHandedTransformMatrix(matrix: Matrix): Matrix {\r\n ConvertHandednessMatrix.invertToRef(TmpVectors.Matrix[0]).multiplyToRef(matrix, matrix).multiplyToRef(ConvertHandednessMatrix, matrix);\r\n return matrix;\r\n}\r\n\r\n/**\r\n * Converts, in-place, a left-handed quaternion to a right-handed quaternion via a change of basis.\r\n * @param value the unit quaternion to convert\r\n * @returns the converted quaternion\r\n */\r\nexport function ConvertToRightHandedRotation(value: Quaternion): Quaternion {\r\n /**\r\n * This is the simplified version of the following equation:\r\n * q' = to_quaternion(M * to_matrix(q) * M^-1)\r\n * where M is the conversion matrix `convertHandednessMatrix`,\r\n * q is the input quaternion, and q' is the converted quaternion.\r\n * Reference: https://d3cw3dd2w32x2b.cloudfront.net/wp-content/uploads/2015/01/matrix-to-quat.pdf\r\n */\r\n if (value.x * value.x + value.y * value.y > 0.5) {\r\n const absX = Math.abs(value.x);\r\n const absY = Math.abs(value.y);\r\n if (absX > absY) {\r\n const sign = Math.sign(value.x);\r\n value.x = absX;\r\n value.y *= -sign;\r\n value.z *= -sign;\r\n value.w *= sign;\r\n } else {\r\n const sign = Math.sign(value.y);\r\n value.x *= -sign;\r\n value.y = absY;\r\n value.z *= sign;\r\n value.w *= -sign;\r\n }\r\n } else {\r\n const absZ = Math.abs(value.z);\r\n const absW = Math.abs(value.w);\r\n if (absZ > absW) {\r\n const sign = Math.sign(value.z);\r\n value.x *= -sign;\r\n value.y *= sign;\r\n value.z = absZ;\r\n value.w *= -sign;\r\n } else {\r\n const sign = Math.sign(value.w);\r\n value.x *= sign;\r\n value.y *= -sign;\r\n value.z *= -sign;\r\n value.w = absW;\r\n }\r\n }\r\n\r\n return value;\r\n}\r\n\r\n/**\r\n * Pre-multiplies a 180-degree Y rotation to the quaternion, in order to match glTF's flipped forward direction for cameras.\r\n * @param rotation Target camera rotation.\r\n */\r\nexport function Rotate180Y(rotation: Quaternion): void {\r\n // Simplified from: rotation * (0, 1, 0, 0).\r\n rotation.copyFromFloats(-rotation.z, rotation.w, rotation.x, -rotation.y);\r\n}\r\n\r\n/**\r\n * Collapses GLTF parent and node into a single node, ignoring scaling.\r\n * This is useful for removing nodes that were added by the GLTF importer.\r\n * @param node Original GLTF node (Light or Camera).\r\n * @param parentNode Target parent node.\r\n */\r\nexport function CollapseChildIntoParent(node: INode, parentNode: INode): void {\r\n const parentTranslation = Vector3.FromArrayToRef(parentNode.translation || [0, 0, 0], 0, TmpVectors.Vector3[0]);\r\n const parentRotation = Quaternion.FromArrayToRef(parentNode.rotation || [0, 0, 0, 1], 0, TmpVectors.Quaternion[0]);\r\n const parentMatrix = Matrix.ComposeToRef(DefaultScale, parentRotation, parentTranslation, TmpVectors.Matrix[0]);\r\n\r\n const translation = Vector3.FromArrayToRef(node.translation || [0, 0, 0], 0, TmpVectors.Vector3[2]);\r\n const rotation = Quaternion.FromArrayToRef(node.rotation || [0, 0, 0, 1], 0, TmpVectors.Quaternion[1]);\r\n const matrix = Matrix.ComposeToRef(DefaultScale, rotation, translation, TmpVectors.Matrix[1]);\r\n\r\n parentMatrix.multiplyToRef(matrix, matrix);\r\n matrix.decompose(undefined, parentRotation, parentTranslation);\r\n\r\n if (parentTranslation.equalsWithEpsilon(DefaultTranslation, Epsilon)) {\r\n delete parentNode.translation;\r\n } else {\r\n parentNode.translation = parentTranslation.asArray();\r\n }\r\n\r\n if (parentRotation.equalsWithEpsilon(DefaultRotation, Epsilon)) {\r\n delete parentNode.rotation;\r\n } else {\r\n parentNode.rotation = parentRotation.asArray();\r\n }\r\n\r\n if (parentNode.scale) {\r\n delete parentNode.scale;\r\n }\r\n}\r\n\r\n/**\r\n * Checks whether a camera or light node is candidate for collapsing with its parent node.\r\n * This is useful for roundtrips, as the glTF Importer parents a new node to\r\n * lights and cameras to store their original transformation information.\r\n * @param babylonNode Babylon light or camera node.\r\n * @param parentBabylonNode Target Babylon parent node.\r\n * @returns True if the two nodes can be merged, false otherwise.\r\n */\r\nexport function IsChildCollapsible(babylonNode: ShadowLight | TargetCamera, parentBabylonNode: Node): boolean {\r\n if (!(parentBabylonNode instanceof TransformNode)) {\r\n return false;\r\n }\r\n\r\n // Verify child is the only descendant\r\n const isOnlyDescendant = parentBabylonNode.getChildren().length === 1 && babylonNode.getChildren().length === 0 && babylonNode.parent === parentBabylonNode;\r\n if (!isOnlyDescendant) {\r\n return false;\r\n }\r\n\r\n // Verify parent has the expected scaling, determined by the node type and scene's coordinate system.\r\n const scene = babylonNode.getScene();\r\n const expectedScale = babylonNode instanceof TargetCamera && !scene.useRightHandedSystem ? DefaultLoaderCameraParentScaleLh : DefaultScale;\r\n\r\n if (!parentBabylonNode.scaling.equalsWithEpsilon(expectedScale, Epsilon)) {\r\n Logger.Warn(`Cannot collapse node ${babylonNode.name} into parent node ${parentBabylonNode.name} with modified scaling.`);\r\n return false;\r\n }\r\n\r\n return true;\r\n}\r\n\r\n/**\r\n * Converts an IndicesArray into either Uint32Array or Uint16Array, only copying if the data is number[].\r\n * @param indices input array to be converted\r\n * @param start starting index to copy from\r\n * @param count number of indices to copy\r\n * @returns a Uint32Array or Uint16Array\r\n * @internal\r\n */\r\nexport function IndicesArrayToTypedArray(indices: IndicesArray, start: number, count: number, is32Bits: boolean): Uint32Array | Uint16Array {\r\n if (indices instanceof Uint16Array || indices instanceof Uint32Array) {\r\n return indices;\r\n }\r\n\r\n // If Int32Array, cast the indices (which are all positive) to Uint32Array\r\n if (indices instanceof Int32Array) {\r\n return new Uint32Array(indices.buffer, indices.byteOffset, indices.length);\r\n }\r\n\r\n const subarray = indices.slice(start, start + count);\r\n return is32Bits ? new Uint32Array(subarray) : new Uint16Array(subarray);\r\n}\r\n\r\nexport function DataArrayToUint8Array(data: DataArray): Uint8Array {\r\n if (data instanceof Array) {\r\n const floatData = new Float32Array(data);\r\n return new Uint8Array(floatData.buffer, floatData.byteOffset, floatData.byteLength);\r\n }\r\n\r\n return ArrayBuffer.isView(data) ? new Uint8Array(data.buffer, data.byteOffset, data.byteLength) : new Uint8Array(data);\r\n}\r\n\r\nexport function GetMinMax(data: DataArray, vertexBuffer: VertexBuffer, start: number, count: number): { min: number[]; max: number[] } {\r\n const { byteOffset, byteStride, type, normalized } = vertexBuffer;\r\n const size = vertexBuffer.getSize();\r\n const min = new Array<number>(size).fill(Infinity);\r\n const max = new Array<number>(size).fill(-Infinity);\r\n EnumerateFloatValues(data, byteOffset + start * byteStride, byteStride, size, type, count * size, normalized, (values) => {\r\n for (let i = 0; i < size; i++) {\r\n min[i] = Math.min(min[i], values[i]);\r\n max[i] = Math.max(max[i], values[i]);\r\n }\r\n });\r\n\r\n return { min, max };\r\n}\r\n\r\n/**\r\n * Removes, in-place, object properties which have the same value as the default value.\r\n * Useful for avoiding unnecessary properties in the glTF JSON.\r\n * @param object the object to omit default values from\r\n * @param defaultValues a partial object with default values\r\n * @returns object with default values omitted\r\n */\r\nexport function OmitDefaultValues<T extends object>(object: T, defaultValues: Partial<T>): T {\r\n for (const [key, value] of Object.entries(object)) {\r\n const defaultValue = defaultValues[key as keyof T];\r\n if ((Array.isArray(value) && Array.isArray(defaultValue) && AreArraysEqual(value, defaultValue)) || value === defaultValue) {\r\n delete object[key as keyof T];\r\n }\r\n }\r\n return object;\r\n}\r\n\r\nfunction AreArraysEqual(array1: unknown[], array2: unknown[]): boolean {\r\n return array1.length === array2.length && array1.every((val, i) => val === array2[i]);\r\n}\r\n"]}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-restricted-imports */
|
|
2
|
+
export * from "./glTFData.js";
|
|
3
|
+
export * from "./glTFSerializer.js";
|
|
4
|
+
export { _SolveMetallic, _ConvertToGLTFPBRMetallicRoughness } from "./glTFMaterialExporter.js";
|
|
5
|
+
export * from "./Extensions/index.js";
|
|
6
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../dev/serializers/src/glTF/2.0/index.ts"],"names":[],"mappings":"AAAA,6DAA6D;AAC7D,cAAc,YAAY,CAAC;AAC3B,cAAc,kBAAkB,CAAC;AACjC,OAAO,EAAE,cAAc,EAAE,kCAAkC,EAAE,MAAM,wBAAwB,CAAC;AAC5F,cAAc,oBAAoB,CAAC","sourcesContent":["/* eslint-disable @typescript-eslint/no-restricted-imports */\r\nexport * from \"./glTFData\";\r\nexport * from \"./glTFSerializer\";\r\nexport { _SolveMetallic, _ConvertToGLTFPBRMetallicRoughness } from \"./glTFMaterialExporter\";\r\nexport * from \"./Extensions/index\";\r\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/** @internal */
|
|
2
|
+
export declare var __IGLTFExporterExtension: number;
|
|
3
|
+
/**
|
|
4
|
+
* Interface for extending the exporter
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
export interface IGLTFExporterExtension {
|
|
8
|
+
/**
|
|
9
|
+
* The name of this extension
|
|
10
|
+
*/
|
|
11
|
+
readonly name: string;
|
|
12
|
+
/**
|
|
13
|
+
* Defines whether this extension is enabled
|
|
14
|
+
*/
|
|
15
|
+
enabled: boolean;
|
|
16
|
+
/**
|
|
17
|
+
* Defines whether this extension is required
|
|
18
|
+
*/
|
|
19
|
+
required: boolean;
|
|
20
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"glTFFileExporter.js","sourceRoot":"","sources":["../../../../dev/serializers/src/glTF/glTFFileExporter.ts"],"names":[],"mappings":"AAAA,gBAAgB;AAChB,wEAAwE;AACxE,MAAM,CAAC,IAAI,wBAAwB,GAAG,CAAC,CAAC,CAAC,uCAAuC","sourcesContent":["/** @internal */\r\n// eslint-disable-next-line no-var, @typescript-eslint/naming-convention\r\nexport var __IGLTFExporterExtension = 0; // I am here to allow dts to be created\r\n\r\n/**\r\n * Interface for extending the exporter\r\n * @internal\r\n */\r\nexport interface IGLTFExporterExtension {\r\n /**\r\n * The name of this extension\r\n */\r\n readonly name: string;\r\n /**\r\n * Defines whether this extension is enabled\r\n */\r\n enabled: boolean;\r\n\r\n /**\r\n * Defines whether this extension is required\r\n */\r\n required: boolean;\r\n}\r\n"]}
|
package/glTF/index.d.ts
ADDED
package/glTF/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../dev/serializers/src/glTF/index.ts"],"names":[],"mappings":"AAAA,6DAA6D;AAC7D,cAAc,oBAAoB,CAAC;AACnC,cAAc,aAAa,CAAC","sourcesContent":["/* eslint-disable @typescript-eslint/no-restricted-imports */\r\nexport * from \"./glTFFileExporter\";\r\nexport * from \"./2.0/index\";\r\n"]}
|
package/index.d.ts
ADDED
package/index.js
ADDED
package/index.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../dev/serializers/src/index.ts"],"names":[],"mappings":"AAAA,6DAA6D;AAC7D,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC","sourcesContent":["/* eslint-disable @typescript-eslint/no-restricted-imports */\r\nexport * from \"./OBJ/index\";\r\nexport * from \"./glTF/index\";\r\nexport * from \"./stl/index\";\r\nexport * from \"./USDZ/index\";\r\n"]}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-restricted-imports */
|
|
2
|
+
import * as Exporters from "../glTF/glTFFileExporter.js";
|
|
3
|
+
import * as Datas from "../glTF/2.0/glTFData.js";
|
|
4
|
+
import * as Serializers from "../glTF/2.0/glTFSerializer.js";
|
|
5
|
+
import * as Extensions from "../glTF/2.0/Extensions/index.js";
|
|
6
|
+
import * as GLTF2 from "../glTF/2.0/index.js";
|
|
7
|
+
/**
|
|
8
|
+
* This is the entry point for the UMD module.
|
|
9
|
+
* The entry point for a future ESM package should be index.ts
|
|
10
|
+
*/
|
|
11
|
+
const globalObject = typeof global !== "undefined" ? global : typeof window !== "undefined" ? window : undefined;
|
|
12
|
+
if (typeof globalObject !== "undefined") {
|
|
13
|
+
globalObject.BABYLON = globalObject.BABYLON || {};
|
|
14
|
+
const BABYLON = globalObject.BABYLON;
|
|
15
|
+
BABYLON.GLTF2 = BABYLON.GLTF2 || {};
|
|
16
|
+
BABYLON.GLTF2.Exporter = BABYLON.GLTF2.Exporter || {};
|
|
17
|
+
BABYLON.GLTF2.Exporter.Extensions = BABYLON.GLTF2.Exporter.Extensions || {};
|
|
18
|
+
const keys = [];
|
|
19
|
+
for (const key in Exporters) {
|
|
20
|
+
BABYLON[key] = Exporters[key];
|
|
21
|
+
keys.push(key);
|
|
22
|
+
}
|
|
23
|
+
for (const key in Datas) {
|
|
24
|
+
BABYLON[key] = Datas[key];
|
|
25
|
+
keys.push(key);
|
|
26
|
+
}
|
|
27
|
+
for (const key in Serializers) {
|
|
28
|
+
BABYLON[key] = Serializers[key];
|
|
29
|
+
keys.push(key);
|
|
30
|
+
}
|
|
31
|
+
for (const key in Extensions) {
|
|
32
|
+
BABYLON.GLTF2.Exporter.Extensions[key] = Extensions[key];
|
|
33
|
+
keys.push(key);
|
|
34
|
+
}
|
|
35
|
+
for (const key in GLTF2) {
|
|
36
|
+
// Prevent Reassignment.
|
|
37
|
+
if (keys.indexOf(key) > -1) {
|
|
38
|
+
continue;
|
|
39
|
+
}
|
|
40
|
+
BABYLON.GLTF2.Exporter[key] = GLTF2[key];
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
export * from "../glTF/glTFFileExporter.js";
|
|
44
|
+
export * from "../glTF/2.0/index.js";
|
|
45
|
+
//# sourceMappingURL=legacy-glTF2Serializer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"legacy-glTF2Serializer.js","sourceRoot":"","sources":["../../../../lts/serializers/src/legacy/legacy-glTF2Serializer.ts"],"names":[],"mappings":"AAAA,6DAA6D;AAC7D,OAAO,KAAK,SAAS,oCAA0C;AAC/D,OAAO,KAAK,KAAK,gCAAsC;AACvD,OAAO,KAAK,WAAW,sCAA4C;AACnE,OAAO,KAAK,UAAU,wCAA8C;AACpE,OAAO,KAAK,KAAK,6BAAmC;AAEpD;;;GAGG;AACH,MAAM,YAAY,GAAG,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;AACjH,IAAI,OAAO,YAAY,KAAK,WAAW,EAAE,CAAC;IAChC,YAAa,CAAC,OAAO,GAAS,YAAa,CAAC,OAAO,IAAI,EAAE,CAAC;IAChE,MAAM,OAAO,GAAS,YAAa,CAAC,OAAO,CAAC;IAC5C,OAAO,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC;IACpC,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,QAAQ,IAAI,EAAE,CAAC;IACtD,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,IAAI,EAAE,CAAC;IAE5E,MAAM,IAAI,GAAG,EAAE,CAAC;IAChB,KAAK,MAAM,GAAG,IAAI,SAAS,EAAE,CAAC;QAC1B,OAAO,CAAC,GAAG,CAAC,GAAS,SAAU,CAAC,GAAG,CAAC,CAAC;QACrC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACnB,CAAC;IACD,KAAK,MAAM,GAAG,IAAI,KAAK,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,GAAS,KAAM,CAAC,GAAG,CAAC,CAAC;QACjC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACnB,CAAC;IACD,KAAK,MAAM,GAAG,IAAI,WAAW,EAAE,CAAC;QAC5B,OAAO,CAAC,GAAG,CAAC,GAAS,WAAY,CAAC,GAAG,CAAC,CAAC;QACvC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACnB,CAAC;IAED,KAAK,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAC3B,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,GAAS,UAAW,CAAC,GAAG,CAAC,CAAC;QAChE,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACnB,CAAC;IAED,KAAK,MAAM,GAAG,IAAI,KAAK,EAAE,CAAC;QACtB,wBAAwB;QACxB,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;YACzB,SAAS;QACb,CAAC;QAED,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAS,KAAM,CAAC,GAAG,CAAC,CAAC;IACpD,CAAC;AACL,CAAC;AAED,4CAAkD;AAClD,qCAA2C","sourcesContent":["/* eslint-disable @typescript-eslint/no-restricted-imports */\r\nimport * as Exporters from \"serializers/glTF/glTFFileExporter\";\r\nimport * as Datas from \"serializers/glTF/2.0/glTFData\";\r\nimport * as Serializers from \"serializers/glTF/2.0/glTFSerializer\";\r\nimport * as Extensions from \"serializers/glTF/2.0/Extensions/index\";\r\nimport * as GLTF2 from \"serializers/glTF/2.0/index\";\r\n\r\n/**\r\n * This is the entry point for the UMD module.\r\n * The entry point for a future ESM package should be index.ts\r\n */\r\nconst globalObject = typeof global !== \"undefined\" ? global : typeof window !== \"undefined\" ? window : undefined;\r\nif (typeof globalObject !== \"undefined\") {\r\n (<any>globalObject).BABYLON = (<any>globalObject).BABYLON || {};\r\n const BABYLON = (<any>globalObject).BABYLON;\r\n BABYLON.GLTF2 = BABYLON.GLTF2 || {};\r\n BABYLON.GLTF2.Exporter = BABYLON.GLTF2.Exporter || {};\r\n BABYLON.GLTF2.Exporter.Extensions = BABYLON.GLTF2.Exporter.Extensions || {};\r\n\r\n const keys = [];\r\n for (const key in Exporters) {\r\n BABYLON[key] = (<any>Exporters)[key];\r\n keys.push(key);\r\n }\r\n for (const key in Datas) {\r\n BABYLON[key] = (<any>Datas)[key];\r\n keys.push(key);\r\n }\r\n for (const key in Serializers) {\r\n BABYLON[key] = (<any>Serializers)[key];\r\n keys.push(key);\r\n }\r\n\r\n for (const key in Extensions) {\r\n BABYLON.GLTF2.Exporter.Extensions[key] = (<any>Extensions)[key];\r\n keys.push(key);\r\n }\r\n\r\n for (const key in GLTF2) {\r\n // Prevent Reassignment.\r\n if (keys.indexOf(key) > -1) {\r\n continue;\r\n }\r\n\r\n BABYLON.GLTF2.Exporter[key] = (<any>GLTF2)[key];\r\n }\r\n}\r\n\r\nexport * from \"serializers/glTF/glTFFileExporter\";\r\nexport * from \"serializers/glTF/2.0/index\";\r\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "../OBJ/index.js";
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-restricted-imports */
|
|
2
|
+
import * as Serializers from "../OBJ/index.js";
|
|
3
|
+
/**
|
|
4
|
+
* This is the entry point for the UMD module.
|
|
5
|
+
* The entry point for a future ESM package should be index.ts
|
|
6
|
+
*/
|
|
7
|
+
const globalObject = typeof global !== "undefined" ? global : typeof window !== "undefined" ? window : undefined;
|
|
8
|
+
if (typeof globalObject !== "undefined") {
|
|
9
|
+
for (const serializer in Serializers) {
|
|
10
|
+
globalObject.BABYLON[serializer] = Serializers[serializer];
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
export * from "../OBJ/index.js";
|
|
14
|
+
//# sourceMappingURL=legacy-objSerializer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"legacy-objSerializer.js","sourceRoot":"","sources":["../../../../lts/serializers/src/legacy/legacy-objSerializer.ts"],"names":[],"mappings":"AAAA,6DAA6D;AAC7D,OAAO,KAAK,WAAW,wBAA8B;AAErD;;;GAGG;AACH,MAAM,YAAY,GAAG,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;AACjH,IAAI,OAAO,YAAY,KAAK,WAAW,EAAE,CAAC;IACtC,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE,CAAC;QAC7B,YAAa,CAAC,OAAO,CAAC,UAAU,CAAC,GAAS,WAAY,CAAC,UAAU,CAAC,CAAC;IAC7E,CAAC;AACL,CAAC;AAED,gCAAsC","sourcesContent":["/* eslint-disable @typescript-eslint/no-restricted-imports */\r\nimport * as Serializers from \"serializers/OBJ/index\";\r\n\r\n/**\r\n * This is the entry point for the UMD module.\r\n * The entry point for a future ESM package should be index.ts\r\n */\r\nconst globalObject = typeof global !== \"undefined\" ? global : typeof window !== \"undefined\" ? window : undefined;\r\nif (typeof globalObject !== \"undefined\") {\r\n for (const serializer in Serializers) {\r\n (<any>globalObject).BABYLON[serializer] = (<any>Serializers)[serializer];\r\n }\r\n}\r\n\r\nexport * from \"serializers/OBJ/index\";\r\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "../stl/index.js";
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-restricted-imports */
|
|
2
|
+
import * as Serializers from "../stl/index.js";
|
|
3
|
+
/**
|
|
4
|
+
* This is the entry point for the UMD module.
|
|
5
|
+
* The entry point for a future ESM package should be index.ts
|
|
6
|
+
*/
|
|
7
|
+
const globalObject = typeof global !== "undefined" ? global : typeof window !== "undefined" ? window : undefined;
|
|
8
|
+
if (typeof globalObject !== "undefined") {
|
|
9
|
+
for (const serializer in Serializers) {
|
|
10
|
+
globalObject.BABYLON[serializer] = Serializers[serializer];
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
export * from "../stl/index.js";
|
|
14
|
+
//# sourceMappingURL=legacy-stlSerializer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"legacy-stlSerializer.js","sourceRoot":"","sources":["../../../../lts/serializers/src/legacy/legacy-stlSerializer.ts"],"names":[],"mappings":"AAAA,6DAA6D;AAC7D,OAAO,KAAK,WAAW,wBAA8B;AAErD;;;GAGG;AACH,MAAM,YAAY,GAAG,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;AACjH,IAAI,OAAO,YAAY,KAAK,WAAW,EAAE,CAAC;IACtC,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE,CAAC;QAC7B,YAAa,CAAC,OAAO,CAAC,UAAU,CAAC,GAAS,WAAY,CAAC,UAAU,CAAC,CAAC;IAC7E,CAAC;AACL,CAAC;AAED,gCAAsC","sourcesContent":["/* eslint-disable @typescript-eslint/no-restricted-imports */\r\nimport * as Serializers from \"serializers/stl/index\";\r\n\r\n/**\r\n * This is the entry point for the UMD module.\r\n * The entry point for a future ESM package should be index.ts\r\n */\r\nconst globalObject = typeof global !== \"undefined\" ? global : typeof window !== \"undefined\" ? window : undefined;\r\nif (typeof globalObject !== \"undefined\") {\r\n for (const serializer in Serializers) {\r\n (<any>globalObject).BABYLON[serializer] = (<any>Serializers)[serializer];\r\n }\r\n}\r\n\r\nexport * from \"serializers/stl/index\";\r\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "../USDZ/index.js";
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-restricted-imports */
|
|
2
|
+
import * as Serializers from "../USDZ/index.js";
|
|
3
|
+
/**
|
|
4
|
+
* This is the entry point for the UMD module.
|
|
5
|
+
* The entry point for a future ESM package should be index.ts
|
|
6
|
+
*/
|
|
7
|
+
const globalObject = typeof global !== "undefined" ? global : typeof window !== "undefined" ? window : undefined;
|
|
8
|
+
if (typeof globalObject !== "undefined") {
|
|
9
|
+
for (const serializer in Serializers) {
|
|
10
|
+
globalObject.BABYLON[serializer] = Serializers[serializer];
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
export * from "../USDZ/index.js";
|
|
14
|
+
//# sourceMappingURL=legacy-usdzSerializer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"legacy-usdzSerializer.js","sourceRoot":"","sources":["../../../../lts/serializers/src/legacy/legacy-usdzSerializer.ts"],"names":[],"mappings":"AAAA,6DAA6D;AAC7D,OAAO,KAAK,WAAW,yBAA+B;AAEtD;;;GAGG;AACH,MAAM,YAAY,GAAG,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;AACjH,IAAI,OAAO,YAAY,KAAK,WAAW,EAAE,CAAC;IACtC,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE,CAAC;QAC7B,YAAa,CAAC,OAAO,CAAC,UAAU,CAAC,GAAS,WAAY,CAAC,UAAU,CAAC,CAAC;IAC7E,CAAC;AACL,CAAC;AAED,iCAAuC","sourcesContent":["/* eslint-disable @typescript-eslint/no-restricted-imports */\r\nimport * as Serializers from \"serializers/USDZ/index\";\r\n\r\n/**\r\n * This is the entry point for the UMD module.\r\n * The entry point for a future ESM package should be index.ts\r\n */\r\nconst globalObject = typeof global !== \"undefined\" ? global : typeof window !== \"undefined\" ? window : undefined;\r\nif (typeof globalObject !== \"undefined\") {\r\n for (const serializer in Serializers) {\r\n (<any>globalObject).BABYLON[serializer] = (<any>Serializers)[serializer];\r\n }\r\n}\r\n\r\nexport * from \"serializers/USDZ/index\";\r\n"]}
|