@loaders.gl/tile-converter 3.3.0-alpha.3 → 3.3.0-alpha.5
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/3d-tiles-attributes-worker.d.ts +1 -1
- package/dist/3d-tiles-attributes-worker.js +2 -2
- package/dist/3d-tiles-attributes-worker.js.map +2 -2
- package/dist/3d-tiles-converter/3d-tiles-converter.d.ts +8 -0
- package/dist/3d-tiles-converter/3d-tiles-converter.d.ts.map +1 -1
- package/dist/3d-tiles-converter/3d-tiles-converter.js +57 -43
- package/dist/3d-tiles-converter/helpers/b3dm-converter.d.ts +5 -5
- package/dist/3d-tiles-converter/helpers/b3dm-converter.d.ts.map +1 -1
- package/dist/3d-tiles-converter/helpers/b3dm-converter.js +21 -17
- package/dist/converter.min.js +21 -21
- package/dist/deps-installer/deps-installer.d.ts +5 -1
- package/dist/deps-installer/deps-installer.d.ts.map +1 -1
- package/dist/deps-installer/deps-installer.js +21 -1
- package/dist/dist.min.js +662 -1018
- package/dist/es5/3d-tiles-attributes-worker.js +2 -2
- package/dist/es5/3d-tiles-attributes-worker.js.map +1 -1
- package/dist/es5/3d-tiles-converter/3d-tiles-converter.js +115 -101
- package/dist/es5/3d-tiles-converter/3d-tiles-converter.js.map +1 -1
- package/dist/es5/3d-tiles-converter/helpers/b3dm-converter.js +27 -19
- package/dist/es5/3d-tiles-converter/helpers/b3dm-converter.js.map +1 -1
- package/dist/es5/deps-installer/deps-installer.js +70 -6
- package/dist/es5/deps-installer/deps-installer.js.map +1 -1
- package/dist/es5/i3s-attributes-worker.js +1 -1
- package/dist/es5/i3s-attributes-worker.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/batch-ids-extensions.js +4 -0
- package/dist/es5/i3s-converter/helpers/batch-ids-extensions.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/coordinate-converter.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/feature-attributes.js +153 -0
- package/dist/es5/i3s-converter/helpers/feature-attributes.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/geometry-converter.js +40 -44
- package/dist/es5/i3s-converter/helpers/geometry-converter.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/gltf-attributes.js +55 -36
- package/dist/es5/i3s-converter/helpers/gltf-attributes.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/node-pages.js +10 -2
- package/dist/es5/i3s-converter/helpers/node-pages.js.map +1 -1
- package/dist/es5/i3s-converter/i3s-converter.js +364 -435
- package/dist/es5/i3s-converter/i3s-converter.js.map +1 -1
- package/dist/es5/pgm-loader.js +1 -1
- package/dist/es5/workers/3d-tiles-attributes-worker.js +1 -1
- package/dist/es5/workers/3d-tiles-attributes-worker.js.map +1 -1
- package/dist/esm/3d-tiles-attributes-worker.js +2 -2
- package/dist/esm/3d-tiles-attributes-worker.js.map +1 -1
- package/dist/esm/3d-tiles-converter/3d-tiles-converter.js +59 -44
- package/dist/esm/3d-tiles-converter/3d-tiles-converter.js.map +1 -1
- package/dist/esm/3d-tiles-converter/helpers/b3dm-converter.js +25 -15
- package/dist/esm/3d-tiles-converter/helpers/b3dm-converter.js.map +1 -1
- package/dist/esm/deps-installer/deps-installer.js +21 -2
- package/dist/esm/deps-installer/deps-installer.js.map +1 -1
- package/dist/esm/i3s-attributes-worker.js +1 -1
- package/dist/esm/i3s-attributes-worker.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/batch-ids-extensions.js +4 -0
- package/dist/esm/i3s-converter/helpers/batch-ids-extensions.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/coordinate-converter.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/feature-attributes.js +138 -0
- package/dist/esm/i3s-converter/helpers/feature-attributes.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/geometry-converter.js +19 -21
- package/dist/esm/i3s-converter/helpers/geometry-converter.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/gltf-attributes.js +55 -36
- package/dist/esm/i3s-converter/helpers/gltf-attributes.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/node-pages.js +9 -2
- package/dist/esm/i3s-converter/helpers/node-pages.js.map +1 -1
- package/dist/esm/i3s-converter/i3s-converter.js +93 -183
- package/dist/esm/i3s-converter/i3s-converter.js.map +1 -1
- package/dist/esm/pgm-loader.js +1 -1
- package/dist/esm/workers/3d-tiles-attributes-worker.js +1 -1
- package/dist/esm/workers/3d-tiles-attributes-worker.js.map +1 -1
- package/dist/i3s-attributes-worker.d.ts +5 -1
- package/dist/i3s-attributes-worker.d.ts.map +1 -1
- package/dist/i3s-attributes-worker.js +3 -3
- package/dist/i3s-attributes-worker.js.map +2 -2
- package/dist/i3s-converter/helpers/batch-ids-extensions.d.ts +2 -3
- package/dist/i3s-converter/helpers/batch-ids-extensions.d.ts.map +1 -1
- package/dist/i3s-converter/helpers/batch-ids-extensions.js +3 -0
- package/dist/i3s-converter/helpers/coordinate-converter.d.ts +2 -2
- package/dist/i3s-converter/helpers/coordinate-converter.d.ts.map +1 -1
- package/dist/i3s-converter/helpers/feature-attributes.d.ts +32 -0
- package/dist/i3s-converter/helpers/feature-attributes.d.ts.map +1 -1
- package/dist/i3s-converter/helpers/feature-attributes.js +162 -1
- package/dist/i3s-converter/helpers/geometry-converter.d.ts +5 -4
- package/dist/i3s-converter/helpers/geometry-converter.d.ts.map +1 -1
- package/dist/i3s-converter/helpers/geometry-converter.js +29 -27
- package/dist/i3s-converter/helpers/gltf-attributes.d.ts.map +1 -1
- package/dist/i3s-converter/helpers/gltf-attributes.js +50 -30
- package/dist/i3s-converter/helpers/node-pages.d.ts +4 -0
- package/dist/i3s-converter/helpers/node-pages.d.ts.map +1 -1
- package/dist/i3s-converter/helpers/node-pages.js +9 -2
- package/dist/i3s-converter/i3s-converter.d.ts +24 -48
- package/dist/i3s-converter/i3s-converter.d.ts.map +1 -1
- package/dist/i3s-converter/i3s-converter.js +88 -186
- package/dist/i3s-converter/types.d.ts +4 -0
- package/dist/i3s-converter/types.d.ts.map +1 -1
- package/dist/workers/3d-tiles-attributes-worker.js +1 -1
- package/package.json +15 -15
- package/src/3d-tiles-attributes-worker.ts +1 -1
- package/src/3d-tiles-converter/3d-tiles-converter.ts +71 -55
- package/src/3d-tiles-converter/helpers/b3dm-converter.ts +25 -18
- package/src/deps-installer/deps-installer.ts +29 -2
- package/src/i3s-attributes-worker.ts +5 -1
- package/src/i3s-converter/helpers/batch-ids-extensions.ts +13 -6
- package/src/i3s-converter/helpers/coordinate-converter.ts +2 -2
- package/src/i3s-converter/helpers/feature-attributes.ts +182 -0
- package/src/i3s-converter/helpers/geometry-converter.ts +45 -36
- package/src/i3s-converter/helpers/gltf-attributes.ts +54 -33
- package/src/i3s-converter/helpers/node-pages.ts +10 -2
- package/src/i3s-converter/i3s-converter.ts +125 -210
- package/src/i3s-converter/types.ts +4 -0
- package/src/workers/3d-tiles-attributes-worker.ts +1 -1
|
@@ -32,6 +32,14 @@ export default class Tiles3DConverter {
|
|
|
32
32
|
maxDepth?: number;
|
|
33
33
|
egmFilePath: string;
|
|
34
34
|
}): Promise<any>;
|
|
35
|
+
/**
|
|
36
|
+
* Convert particular I3S Node
|
|
37
|
+
* @param parentSourceNode the parent node tile object (@loaders.gl/tiles/Tile3D)
|
|
38
|
+
* @param parentNode object in resulting tileset
|
|
39
|
+
* @param level a current level of a tree depth
|
|
40
|
+
* @param childNodeInfo child node to convert
|
|
41
|
+
*/
|
|
42
|
+
private convertChildNode;
|
|
35
43
|
/**
|
|
36
44
|
* The recursive function of traversal of a nodes tree
|
|
37
45
|
* @param parentSourceNode the parent node tile object (@loaders.gl/tiles/Tile3D)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"3d-tiles-converter.d.ts","sourceRoot":"","sources":["../../src/3d-tiles-converter/3d-tiles-converter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,oBAAoB,EAAkC,MAAM,iBAAiB,CAAC;AAQ3F,OAAO,EAAC,SAAS,EAAS,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAC,KAAK,EAAC,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"3d-tiles-converter.d.ts","sourceRoot":"","sources":["../../src/3d-tiles-converter/3d-tiles-converter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,oBAAoB,EAAkC,MAAM,iBAAiB,CAAC;AAQ3F,OAAO,EAAC,SAAS,EAAS,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAC,KAAK,EAAC,MAAM,gBAAgB,CAAC;AAmBrC;;GAEG;AACH,MAAM,CAAC,OAAO,OAAO,gBAAgB;IACnC,OAAO,EAAE,GAAG,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,aAAa,EAAE,MAAM,CAAC;IACtB,mBAAmB,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACtC,gBAAgB,EAAE,KAAK,GAAG,IAAI,CAAC;IAC/B,aAAa,EAAE,SAAS,GAAG,IAAI,CAAC;IAChC,oBAAoB,EAAE,oBAAoB,GAAG,IAAI,CAAC;IAClD,YAAY,EAAE;QAAC,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;KAAC,CAAM;;IAa3C;;;;;;;;OAQG;IACU,OAAO,CAAC,OAAO,EAAE;QAC5B,QAAQ,EAAE,MAAM,CAAC;QACjB,UAAU,EAAE,MAAM,CAAC;QACnB,WAAW,EAAE,MAAM,CAAC;QACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,WAAW,EAAE,MAAM,CAAC;KACrB,GAAG,OAAO,CAAC,GAAG,CAAC;IA+DhB;;;;;;OAMG;YACW,gBAAgB;IAsD9B;;;;;OAKG;YACW,YAAY;IAe1B;;;;;OAKG;YACW,cAAc;IAyB5B;;;;OAIG;IACH,OAAO,CAAC,qBAAqB;IAiB7B;;;;;OAKG;YACW,oBAAoB;IAsBlC;;;;;;OAMG;IACH,OAAO,CAAC,iBAAiB;IASzB;;;OAGG;IACH,OAAO,CAAC,oBAAoB;IAU5B;;;OAGG;YACW,iBAAiB;YAiBjB,WAAW;CAS1B"}
|
|
@@ -15,7 +15,6 @@ const lod_conversion_utils_1 = require("../lib/utils/lod-conversion-utils");
|
|
|
15
15
|
const file_utils_1 = require("../lib/utils/file-utils");
|
|
16
16
|
const statistic_utills_1 = require("../lib/utils/statistic-utills");
|
|
17
17
|
const tileset_1 = require("./json-templates/tileset");
|
|
18
|
-
const b3dm_converter_1 = __importDefault(require("./helpers/b3dm-converter"));
|
|
19
18
|
const coordinate_converter_1 = require("../i3s-converter/helpers/coordinate-converter");
|
|
20
19
|
const _3d_tiles_attributes_worker_1 = require("../3d-tiles-attributes-worker");
|
|
21
20
|
const worker_utils_1 = require("@loaders.gl/worker-utils");
|
|
@@ -60,6 +59,11 @@ class Tiles3DConverter {
|
|
|
60
59
|
const sourceTilesetJson = await (0, core_1.load)(inputUrl, i3s_1.I3SLoader, {});
|
|
61
60
|
this.sourceTileset = new tiles_1.Tileset3D(sourceTilesetJson, {
|
|
62
61
|
loadOptions: {
|
|
62
|
+
_nodeWorkers: true,
|
|
63
|
+
reuseWorkers: true,
|
|
64
|
+
'i3s-content-nodejs': {
|
|
65
|
+
workerUrl: './modules/i3s/dist/i3s-content-nodejs-worker.js'
|
|
66
|
+
},
|
|
63
67
|
i3s: { coordinateSystem: i3s_1.COORDINATE_SYSTEM.LNGLAT_OFFSETS, decodeTextures: false }
|
|
64
68
|
}
|
|
65
69
|
});
|
|
@@ -92,6 +96,55 @@ class Tiles3DConverter {
|
|
|
92
96
|
const workerFarm = worker_utils_1.WorkerFarm.getWorkerFarm({});
|
|
93
97
|
workerFarm.destroy();
|
|
94
98
|
}
|
|
99
|
+
/**
|
|
100
|
+
* Convert particular I3S Node
|
|
101
|
+
* @param parentSourceNode the parent node tile object (@loaders.gl/tiles/Tile3D)
|
|
102
|
+
* @param parentNode object in resulting tileset
|
|
103
|
+
* @param level a current level of a tree depth
|
|
104
|
+
* @param childNodeInfo child node to convert
|
|
105
|
+
*/
|
|
106
|
+
async convertChildNode(parentSourceNode, parentNode, level, childNodeInfo) {
|
|
107
|
+
const sourceChild = await this._loadChildNode(parentSourceNode, childNodeInfo);
|
|
108
|
+
parentSourceNode.children.push(sourceChild);
|
|
109
|
+
if (sourceChild.contentUrl) {
|
|
110
|
+
await this.sourceTileset._loadTile(sourceChild);
|
|
111
|
+
this.vertexCounter += sourceChild.content.vertexCount;
|
|
112
|
+
let featureAttributes = null;
|
|
113
|
+
if (this.attributeStorageInfo) {
|
|
114
|
+
featureAttributes = await this._loadChildAttributes(sourceChild, this.attributeStorageInfo);
|
|
115
|
+
}
|
|
116
|
+
if (!sourceChild.header.obb) {
|
|
117
|
+
sourceChild.header.obb = (0, coordinate_converter_1.createObbFromMbs)(sourceChild.header.mbs);
|
|
118
|
+
}
|
|
119
|
+
const boundingVolume = {
|
|
120
|
+
box: (0, i3s_obb_to_3d_tiles_obb_1.i3sObbTo3dTilesObb)(sourceChild.header.obb, this.geoidHeightModel)
|
|
121
|
+
};
|
|
122
|
+
const child = {
|
|
123
|
+
boundingVolume,
|
|
124
|
+
geometricError: (0, lod_conversion_utils_1.convertScreenThresholdToGeometricError)(sourceChild),
|
|
125
|
+
children: []
|
|
126
|
+
};
|
|
127
|
+
const i3sAttributesData = {
|
|
128
|
+
tileContent: sourceChild.content,
|
|
129
|
+
textureFormat: sourceChild?.header?.textureFormat
|
|
130
|
+
};
|
|
131
|
+
const b3dm = await (0, _3d_tiles_attributes_worker_1.transform3DTilesAttributesOnWorker)(i3sAttributesData, {
|
|
132
|
+
source: this.workerSource.tile3dWorkerSource,
|
|
133
|
+
featureAttributes
|
|
134
|
+
});
|
|
135
|
+
child.content = {
|
|
136
|
+
uri: `${sourceChild.id}.b3dm`,
|
|
137
|
+
boundingVolume
|
|
138
|
+
};
|
|
139
|
+
await (0, file_utils_1.writeFile)(this.tilesetPath, new Uint8Array(b3dm), `${sourceChild.id}.b3dm`);
|
|
140
|
+
parentNode.children.push(child);
|
|
141
|
+
sourceChild.unloadContent();
|
|
142
|
+
await this._addChildren(sourceChild, child, level + 1);
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
await this._addChildren(sourceChild, parentNode, level + 1);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
95
148
|
/**
|
|
96
149
|
* The recursive function of traversal of a nodes tree
|
|
97
150
|
* @param parentSourceNode the parent node tile object (@loaders.gl/tiles/Tile3D)
|
|
@@ -102,50 +155,11 @@ class Tiles3DConverter {
|
|
|
102
155
|
if (this.options.maxDepth && level > this.options.maxDepth) {
|
|
103
156
|
return;
|
|
104
157
|
}
|
|
158
|
+
const promises = [];
|
|
105
159
|
for (const childNodeInfo of parentSourceNode.header.children || []) {
|
|
106
|
-
|
|
107
|
-
parentSourceNode.children.push(sourceChild);
|
|
108
|
-
if (sourceChild.contentUrl) {
|
|
109
|
-
await this.sourceTileset._loadTile(sourceChild);
|
|
110
|
-
this.vertexCounter += sourceChild.content.vertexCount;
|
|
111
|
-
let featureAttributes = null;
|
|
112
|
-
if (this.attributeStorageInfo) {
|
|
113
|
-
featureAttributes = await this._loadChildAttributes(sourceChild, this.attributeStorageInfo);
|
|
114
|
-
}
|
|
115
|
-
if (!sourceChild.header.obb) {
|
|
116
|
-
sourceChild.header.obb = (0, coordinate_converter_1.createObbFromMbs)(sourceChild.header.mbs);
|
|
117
|
-
}
|
|
118
|
-
const boundingVolume = {
|
|
119
|
-
box: (0, i3s_obb_to_3d_tiles_obb_1.i3sObbTo3dTilesObb)(sourceChild.header.obb, this.geoidHeightModel)
|
|
120
|
-
};
|
|
121
|
-
const child = {
|
|
122
|
-
boundingVolume,
|
|
123
|
-
geometricError: (0, lod_conversion_utils_1.convertScreenThresholdToGeometricError)(sourceChild),
|
|
124
|
-
children: []
|
|
125
|
-
};
|
|
126
|
-
const i3sAttributesData = {
|
|
127
|
-
tileContent: sourceChild.content,
|
|
128
|
-
textureFormat: sourceChild?.header?.textureFormat
|
|
129
|
-
};
|
|
130
|
-
// TODO Uncomment when 3d-tiles-attributes-worker will be published on CDN.
|
|
131
|
-
// const b3dm = await transform3DTilesAttributesOnWorker(i3sAttributesData, {
|
|
132
|
-
// source: this.workerSource.tile3dWorkerSource,
|
|
133
|
-
// featureAttributes
|
|
134
|
-
// });
|
|
135
|
-
const b3dm = await new b3dm_converter_1.default().convert(i3sAttributesData, featureAttributes);
|
|
136
|
-
child.content = {
|
|
137
|
-
uri: `${sourceChild.id}.b3dm`,
|
|
138
|
-
boundingVolume
|
|
139
|
-
};
|
|
140
|
-
await (0, file_utils_1.writeFile)(this.tilesetPath, new Uint8Array(b3dm), `${sourceChild.id}.b3dm`);
|
|
141
|
-
parentNode.children.push(child);
|
|
142
|
-
sourceChild.unloadContent();
|
|
143
|
-
await this._addChildren(sourceChild, child, level + 1);
|
|
144
|
-
}
|
|
145
|
-
else {
|
|
146
|
-
await this._addChildren(sourceChild, parentNode, level + 1);
|
|
147
|
-
}
|
|
160
|
+
promises.push(this.convertChildNode(parentSourceNode, parentNode, level, childNodeInfo));
|
|
148
161
|
}
|
|
162
|
+
await Promise.all(promises);
|
|
149
163
|
}
|
|
150
164
|
/**
|
|
151
165
|
* Load a child node having information from the node header
|
|
@@ -17,7 +17,7 @@ export default class B3dmConverter {
|
|
|
17
17
|
* @param i3sTile - Tile3D instance for I3S node
|
|
18
18
|
* @returns - encoded glb content
|
|
19
19
|
*/
|
|
20
|
-
buildGltf(i3sAttributesData: I3SAttributesData): Promise<ArrayBuffer>;
|
|
20
|
+
buildGltf(i3sAttributesData: I3SAttributesData, featureAttributes: any): Promise<ArrayBuffer>;
|
|
21
21
|
/**
|
|
22
22
|
* Update gltfBuilder with texture from I3S tile
|
|
23
23
|
* @param {object} i3sTile - Tile3D object
|
|
@@ -44,11 +44,11 @@ export default class B3dmConverter {
|
|
|
44
44
|
*/
|
|
45
45
|
_generateTransformMatrix(cartesianOrigin: any): Matrix4;
|
|
46
46
|
/**
|
|
47
|
-
*
|
|
48
|
-
* @param {
|
|
49
|
-
* @returns {
|
|
47
|
+
* Create _BATCHID attribute
|
|
48
|
+
* @param {Object} i3sContent - the source object
|
|
49
|
+
* @returns {void}
|
|
50
50
|
*/
|
|
51
|
-
|
|
51
|
+
_createBatchIds(i3sContent: any, featureAttributes: any): void;
|
|
52
52
|
/**
|
|
53
53
|
* luma.gl can not work without indices now:
|
|
54
54
|
* https://github.com/visgl/luma.gl/blob/d8cad75b9f8ca3e578cf078ed9d19e619c2ddbc9/modules/experimental/src/gltf/gltf-instantiator.js#L115
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"b3dm-converter.d.ts","sourceRoot":"","sources":["../../../src/3d-tiles-converter/helpers/b3dm-converter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,kCAAkC,CAAC;AAKxE,OAAO,EAAC,OAAO,EAAU,MAAM,eAAe,CAAC;AAO/C;;GAEG;AACH,MAAM,CAAC,OAAO,OAAO,aAAa;IAEhC,SAAS,EAAE,YAAY,CAAC;IACxB,OAAO,EAAE,GAAG,CAAC;IAEb;;;;OAIG;IACG,OAAO,CACX,iBAAiB,EAAE,iBAAiB,EACpC,iBAAiB,GAAE,GAAU,GAC5B,OAAO,CAAC,WAAW,CAAC;IAcvB;;;;OAIG;IACG,SAAS,
|
|
1
|
+
{"version":3,"file":"b3dm-converter.d.ts","sourceRoot":"","sources":["../../../src/3d-tiles-converter/helpers/b3dm-converter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,kCAAkC,CAAC;AAKxE,OAAO,EAAC,OAAO,EAAU,MAAM,eAAe,CAAC;AAO/C;;GAEG;AACH,MAAM,CAAC,OAAO,OAAO,aAAa;IAEhC,SAAS,EAAE,YAAY,CAAC;IACxB,OAAO,EAAE,GAAG,CAAC;IAEb;;;;OAIG;IACG,OAAO,CACX,iBAAiB,EAAE,iBAAiB,EACpC,iBAAiB,GAAE,GAAU,GAC5B,OAAO,CAAC,WAAW,CAAC;IAcvB;;;;OAIG;IACG,SAAS,CACb,iBAAiB,EAAE,iBAAiB,EACpC,iBAAiB,EAAE,GAAG,GACrB,OAAO,CAAC,WAAW,CAAC;IAwDvB;;;;;OAKG;IACG,oBAAoB,CAAC,WAAW,KAAA,EAAE,aAAa,KAAA,EAAE,WAAW,KAAA;IAmBlE;;;;;;;OAOG;IACH,mBAAmB,CAAC,cAAc,KAAA,EAAE,eAAe,KAAA,EAAE,kBAAkB,KAAA,EAAE,WAAW,KAAA;IAepF;;;;;;;OAOG;IACH,wBAAwB,CAAC,eAAe,KAAA;IAMxC;;;;OAIG;IACH,eAAe,CAAC,UAAU,KAAA,EAAE,iBAAiB,KAAA;IAoB7C;;;;;;OAMG;IACH,wBAAwB,CAAC,WAAW,KAAA;IAQpC;;;;;OAKG;IACH,yBAAyB,CAAC,MAAM,KAAA;IAchC;;;;;OAKG;IACH,iCAAiC,CAAC,QAAQ,KAAA,EAAE,YAAY,KAAA;IAgCxD;;;;;OAKG;IACH,eAAe,CAAC,kBAAkB,KAAA,EAAE,YAAY,KAAA;IA+ChD,kBAAkB,CAAC,UAAU,KAAA;IAY7B,aAAa,CAAC,OAAO,KAAA;CAItB"}
|
|
@@ -18,7 +18,7 @@ class B3dmConverter {
|
|
|
18
18
|
* @returns - encoded content
|
|
19
19
|
*/
|
|
20
20
|
async convert(i3sAttributesData, featureAttributes = null) {
|
|
21
|
-
const gltf = await this.buildGltf(i3sAttributesData);
|
|
21
|
+
const gltf = await this.buildGltf(i3sAttributesData, featureAttributes);
|
|
22
22
|
const b3dm = (0, core_1.encodeSync)({
|
|
23
23
|
gltfEncoded: new Uint8Array(gltf),
|
|
24
24
|
type: 'b3dm',
|
|
@@ -32,7 +32,7 @@ class B3dmConverter {
|
|
|
32
32
|
* @param i3sTile - Tile3D instance for I3S node
|
|
33
33
|
* @returns - encoded glb content
|
|
34
34
|
*/
|
|
35
|
-
async buildGltf(i3sAttributesData) {
|
|
35
|
+
async buildGltf(i3sAttributesData, featureAttributes) {
|
|
36
36
|
const { tileContent, textureFormat } = i3sAttributesData;
|
|
37
37
|
const { material, attributes, indices: originalIndices, cartesianOrigin, cartographicOrigin, modelMatrix } = tileContent;
|
|
38
38
|
const gltfBuilder = new gltf_1.GLTFScenegraph();
|
|
@@ -45,6 +45,7 @@ class B3dmConverter {
|
|
|
45
45
|
attributes.texCoords.value = (0, texture_atlas_1.convertTextureAtlas)(attributes.texCoords.value, attributes.uvRegions.value);
|
|
46
46
|
}
|
|
47
47
|
attributes.positions.value = this._normalizePositions(positionsValue, cartesianOrigin, cartographicOrigin, modelMatrix);
|
|
48
|
+
this._createBatchIds(tileContent, featureAttributes);
|
|
48
49
|
if (attributes.normals && !this._checkNormals(attributes.normals.value)) {
|
|
49
50
|
delete attributes.normals;
|
|
50
51
|
}
|
|
@@ -123,23 +124,26 @@ class B3dmConverter {
|
|
|
123
124
|
return result;
|
|
124
125
|
}
|
|
125
126
|
/**
|
|
126
|
-
*
|
|
127
|
-
* @param {
|
|
128
|
-
* @returns {
|
|
127
|
+
* Create _BATCHID attribute
|
|
128
|
+
* @param {Object} i3sContent - the source object
|
|
129
|
+
* @returns {void}
|
|
129
130
|
*/
|
|
130
|
-
|
|
131
|
-
const
|
|
132
|
-
const
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
const
|
|
138
|
-
batchId.
|
|
139
|
-
|
|
140
|
-
currentBatchId += 1;
|
|
131
|
+
_createBatchIds(i3sContent, featureAttributes) {
|
|
132
|
+
const { featureIds } = i3sContent;
|
|
133
|
+
const { OBJECTID: objectIds } = featureAttributes || {};
|
|
134
|
+
if (!featureIds || !objectIds) {
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
for (let i = 0; i < featureIds.length; i++) {
|
|
138
|
+
const featureId = featureIds[i];
|
|
139
|
+
const batchId = objectIds.indexOf(featureId);
|
|
140
|
+
featureIds[i] = batchId;
|
|
141
141
|
}
|
|
142
|
-
|
|
142
|
+
i3sContent.attributes._BATCHID = {
|
|
143
|
+
size: 1,
|
|
144
|
+
byteOffset: 0,
|
|
145
|
+
value: featureIds
|
|
146
|
+
};
|
|
143
147
|
}
|
|
144
148
|
/**
|
|
145
149
|
* luma.gl can not work without indices now:
|