@loaders.gl/gltf 4.0.0-alpha.22 → 4.0.0-alpha.24
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/dist.min.js +3626 -3028
- package/dist/es5/index.js +21 -0
- package/dist/es5/index.js.map +1 -1
- package/dist/es5/lib/api/gltf-extensions.js +3 -1
- package/dist/es5/lib/api/gltf-extensions.js.map +1 -1
- package/dist/es5/lib/extensions/EXT_mesh_features.js +111 -0
- package/dist/es5/lib/extensions/EXT_mesh_features.js.map +1 -0
- package/dist/es5/lib/extensions/EXT_structural_metadata.js +388 -0
- package/dist/es5/lib/extensions/EXT_structural_metadata.js.map +1 -0
- package/dist/es5/lib/extensions/deprecated/EXT_feature_metadata.js +32 -22
- package/dist/es5/lib/extensions/deprecated/EXT_feature_metadata.js.map +1 -1
- package/dist/es5/lib/extensions/utils/3d-tiles-utils.js +200 -0
- package/dist/es5/lib/extensions/utils/3d-tiles-utils.js.map +1 -0
- package/dist/es5/lib/types/gltf-ext-mesh-features-schema.js +2 -0
- package/dist/es5/lib/types/gltf-ext-mesh-features-schema.js.map +1 -0
- package/dist/es5/lib/types/gltf-ext-structural-metadata-schema.js +2 -0
- package/dist/es5/lib/types/gltf-ext-structural-metadata-schema.js.map +1 -0
- package/dist/es5/lib/types/gltf-json-schema.js.map +1 -1
- package/dist/es5/lib/utils/version.js +1 -1
- package/dist/esm/index.js +3 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/lib/api/gltf-extensions.js +3 -1
- package/dist/esm/lib/api/gltf-extensions.js.map +1 -1
- package/dist/esm/lib/extensions/EXT_mesh_features.js +55 -0
- package/dist/esm/lib/extensions/EXT_mesh_features.js.map +1 -0
- package/dist/esm/lib/extensions/EXT_structural_metadata.js +324 -0
- package/dist/esm/lib/extensions/EXT_structural_metadata.js.map +1 -0
- package/dist/esm/lib/extensions/deprecated/EXT_feature_metadata.js +30 -20
- package/dist/esm/lib/extensions/deprecated/EXT_feature_metadata.js.map +1 -1
- package/dist/esm/lib/extensions/utils/3d-tiles-utils.js +164 -0
- package/dist/esm/lib/extensions/utils/3d-tiles-utils.js.map +1 -0
- package/dist/esm/lib/types/gltf-ext-mesh-features-schema.js +2 -0
- package/dist/esm/lib/types/gltf-ext-mesh-features-schema.js.map +1 -0
- package/dist/esm/lib/types/gltf-ext-structural-metadata-schema.js +2 -0
- package/dist/esm/lib/types/gltf-ext-structural-metadata-schema.js.map +1 -0
- package/dist/esm/lib/types/gltf-json-schema.js.map +1 -1
- package/dist/esm/lib/utils/version.js +1 -1
- package/dist/index.d.ts +6 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/lib/api/gltf-extensions.d.ts.map +1 -1
- package/dist/lib/extensions/EXT_mesh_features.d.ts +7 -0
- package/dist/lib/extensions/EXT_mesh_features.d.ts.map +1 -0
- package/dist/lib/extensions/EXT_structural_metadata.d.ts +17 -0
- package/dist/lib/extensions/EXT_structural_metadata.d.ts.map +1 -0
- package/dist/lib/extensions/deprecated/EXT_feature_metadata.d.ts.map +1 -1
- package/dist/lib/extensions/utils/3d-tiles-utils.d.ts +52 -0
- package/dist/lib/extensions/utils/3d-tiles-utils.d.ts.map +1 -0
- package/dist/lib/types/gltf-ext-mesh-features-schema.d.ts +45 -0
- package/dist/lib/types/gltf-ext-mesh-features-schema.d.ts.map +1 -0
- package/dist/lib/types/gltf-ext-structural-metadata-schema.d.ts +310 -0
- package/dist/lib/types/gltf-ext-structural-metadata-schema.d.ts.map +1 -0
- package/dist/lib/types/gltf-json-schema.d.ts +12 -58
- package/dist/lib/types/gltf-json-schema.d.ts.map +1 -1
- package/package.json +6 -6
- package/src/index.ts +11 -3
- package/src/lib/api/gltf-extensions.ts +6 -2
- package/src/lib/extensions/EXT_mesh_features.ts +117 -0
- package/src/lib/extensions/EXT_structural_metadata.ts +797 -0
- package/src/lib/extensions/deprecated/EXT_feature_metadata.ts +129 -36
- package/src/lib/extensions/utils/3d-tiles-utils.ts +325 -0
- package/src/lib/types/gltf-ext-mesh-features-schema.ts +48 -0
- package/src/lib/types/gltf-ext-structural-metadata-schema.ts +359 -0
- package/src/lib/types/gltf-json-schema.ts +13 -61
- package/dist/bundle.js +0 -5
- package/dist/glb-loader.js +0 -34
- package/dist/glb-writer.js +0 -35
- package/dist/gltf-loader.js +0 -50
- package/dist/gltf-writer.js +0 -32
- package/dist/index.js +0 -28
- package/dist/lib/api/gltf-extensions.js +0 -83
- package/dist/lib/api/gltf-scenegraph.js +0 -580
- package/dist/lib/api/normalize-gltf-v1.js +0 -299
- package/dist/lib/api/post-process-gltf.js +0 -433
- package/dist/lib/encoders/encode-glb.js +0 -72
- package/dist/lib/encoders/encode-gltf.js +0 -32
- package/dist/lib/extensions/EXT_meshopt_compression.js +0 -41
- package/dist/lib/extensions/EXT_texture_webp.js +0 -36
- package/dist/lib/extensions/KHR_binary_gltf.js +0 -39
- package/dist/lib/extensions/KHR_draco_mesh_compression.js +0 -137
- package/dist/lib/extensions/KHR_texture_basisu.js +0 -29
- package/dist/lib/extensions/KHR_texture_transform.js +0 -227
- package/dist/lib/extensions/deprecated/EXT_feature_metadata.js +0 -291
- package/dist/lib/extensions/deprecated/KHR_lights_punctual.js +0 -59
- package/dist/lib/extensions/deprecated/KHR_materials_unlit.js +0 -44
- package/dist/lib/extensions/deprecated/KHR_techniques_webgl.js +0 -79
- package/dist/lib/gltf-utils/get-typed-array.js +0 -41
- package/dist/lib/gltf-utils/gltf-attribute-utils.js +0 -73
- package/dist/lib/gltf-utils/gltf-constants.js +0 -43
- package/dist/lib/gltf-utils/gltf-utils.js +0 -90
- package/dist/lib/gltf-utils/resolve-url.js +0 -18
- package/dist/lib/parsers/parse-glb.js +0 -166
- package/dist/lib/parsers/parse-gltf.js +0 -185
- package/dist/lib/types/glb-types.js +0 -2
- package/dist/lib/types/gltf-json-schema.js +0 -4
- package/dist/lib/types/gltf-postprocessed-schema.js +0 -4
- package/dist/lib/types/gltf-types.js +0 -3
- package/dist/lib/utils/assert.js +0 -12
- package/dist/lib/utils/version.js +0 -7
- package/dist/meshopt/meshopt-decoder.js +0 -118
- package/dist/webp/webp.js +0 -38
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
/* eslint-disable camelcase */
|
|
2
|
+
import type {GLTF, GLTFMeshPrimitive} from '../types/gltf-json-schema';
|
|
3
|
+
import {GLTFLoaderOptions} from '../../gltf-loader';
|
|
4
|
+
import type {
|
|
5
|
+
GLTF_EXT_mesh_features,
|
|
6
|
+
GLTF_EXT_mesh_features_featureId
|
|
7
|
+
} from '../types/gltf-ext-mesh-features-schema';
|
|
8
|
+
import type {GLTF_EXT_structural_metadata_PropertyTable} from '../types/gltf-ext-structural-metadata-schema';
|
|
9
|
+
|
|
10
|
+
import {GLTFScenegraph} from '../api/gltf-scenegraph';
|
|
11
|
+
import {getPrimitiveTextureData, primitivePropertyDataToAttributes} from './utils/3d-tiles-utils';
|
|
12
|
+
import {getPropertyTablePopulated} from './EXT_structural_metadata';
|
|
13
|
+
|
|
14
|
+
const EXT_MESH_FEATURES_NAME = 'EXT_mesh_features';
|
|
15
|
+
export const name = EXT_MESH_FEATURES_NAME;
|
|
16
|
+
|
|
17
|
+
export async function decode(gltfData: {json: GLTF}, options: GLTFLoaderOptions): Promise<void> {
|
|
18
|
+
const scenegraph = new GLTFScenegraph(gltfData);
|
|
19
|
+
decodeExtMeshFeatures(scenegraph, options);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Decodes feature metadata from extension
|
|
24
|
+
* @param {GLTFScenegraph} scenegraph - Instance of the class for structured access to GLTF data.
|
|
25
|
+
* @param {GLTFLoaderOptions} options - loader options.
|
|
26
|
+
*/
|
|
27
|
+
function decodeExtMeshFeatures(scenegraph: GLTFScenegraph, options: GLTFLoaderOptions): void {
|
|
28
|
+
const json = scenegraph.gltf.json;
|
|
29
|
+
if (!json.meshes) {
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
// Iterate through all meshes/primitives.
|
|
34
|
+
for (const mesh of json.meshes) {
|
|
35
|
+
for (const primitive of mesh.primitives) {
|
|
36
|
+
processMeshPrimitiveFeatures(scenegraph, primitive, options);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Takes data from EXT_mesh_features and store it in 'data' property of featureIds.
|
|
43
|
+
* If combined with EXT_structural_metadata, corresponding data are taken from the property tables of that extension.
|
|
44
|
+
* @param {GLTFScenegraph} scenegraph - Instance of the class for structured access to GLTF data.
|
|
45
|
+
* @param {GLTFMeshPrimitive} primitive - primitive that contains extensions.
|
|
46
|
+
* @param {GLTFLoaderOptions} options - loader options.
|
|
47
|
+
*/
|
|
48
|
+
function processMeshPrimitiveFeatures(
|
|
49
|
+
scenegraph: GLTFScenegraph,
|
|
50
|
+
primitive: GLTFMeshPrimitive,
|
|
51
|
+
options: GLTFLoaderOptions
|
|
52
|
+
): void {
|
|
53
|
+
const extension = primitive.extensions?.[EXT_MESH_FEATURES_NAME] as GLTF_EXT_mesh_features;
|
|
54
|
+
const featureIds: GLTF_EXT_mesh_features_featureId[] = extension?.featureIds;
|
|
55
|
+
if (!featureIds) return;
|
|
56
|
+
|
|
57
|
+
if (!extension.dataAttributeNames) {
|
|
58
|
+
extension.dataAttributeNames = [];
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
let featureIdCount = 0; // It can be used to name the feature if neither label nor property table name is provided.
|
|
62
|
+
for (const featureId of featureIds) {
|
|
63
|
+
/*
|
|
64
|
+
When combined with the EXT_structural_metadata extension, feature ID sets can be associated with property tables.
|
|
65
|
+
A property table maps each feature ID to a set of values that are associated with the respective feature.
|
|
66
|
+
The feature ID in this case serves as an index for the row of the table.
|
|
67
|
+
The index of the property table that a certain set of feature IDs is associated with is stored in the propertyTable of the feature ID set definition.
|
|
68
|
+
*/
|
|
69
|
+
let propertyTable: GLTF_EXT_structural_metadata_PropertyTable | null = null;
|
|
70
|
+
if (typeof featureId.propertyTable === 'number') {
|
|
71
|
+
propertyTable = getPropertyTablePopulated(scenegraph, featureId.propertyTable);
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
let propertyData: number[] | null = null;
|
|
75
|
+
// Process "Feature ID by Vertex"
|
|
76
|
+
if (typeof featureId.attribute !== 'undefined') {
|
|
77
|
+
const accessorKey = `_FEATURE_ID_${featureId.attribute}`;
|
|
78
|
+
const accessorIndex = primitive.attributes[accessorKey];
|
|
79
|
+
const propertyDataTypedArray = scenegraph.getTypedArrayForAccessor(accessorIndex);
|
|
80
|
+
propertyData = Array.prototype.slice.call(propertyDataTypedArray);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
// Process "Feature ID by Texture Coordinates"
|
|
84
|
+
else if (typeof featureId.texture !== 'undefined' && options?.gltf?.loadImages) {
|
|
85
|
+
propertyData = getPrimitiveTextureData(scenegraph, featureId.texture, primitive);
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
// Process "Feature ID by Index"
|
|
89
|
+
else {
|
|
90
|
+
/*
|
|
91
|
+
When both featureId.attribute and featureId.texture are undefined,
|
|
92
|
+
then the feature ID value for each vertex is given implicitly, via the index of the vertex.
|
|
93
|
+
In this case, the featureCount must match the number of vertices of the mesh primitive.
|
|
94
|
+
*/
|
|
95
|
+
// TODO: At the moment of writing we don't have a tileset with the data of that kind. Implement it later.
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
const attributeName =
|
|
99
|
+
featureId.label || propertyTable?.name || `featureAttribute${featureIdCount}`;
|
|
100
|
+
|
|
101
|
+
// featureTable - an array where unique data from the property data are being stored
|
|
102
|
+
const featureTable: number[] = [];
|
|
103
|
+
if (propertyData) {
|
|
104
|
+
primitivePropertyDataToAttributes(
|
|
105
|
+
scenegraph,
|
|
106
|
+
attributeName,
|
|
107
|
+
propertyData,
|
|
108
|
+
featureTable,
|
|
109
|
+
primitive
|
|
110
|
+
);
|
|
111
|
+
}
|
|
112
|
+
extension.dataAttributeNames.push(attributeName);
|
|
113
|
+
featureId.data = featureTable;
|
|
114
|
+
|
|
115
|
+
featureIdCount++;
|
|
116
|
+
}
|
|
117
|
+
}
|