@loaders.gl/tile-converter 4.0.0-alpha.16 → 4.0.0-alpha.18
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/bin/converter.js +1 -1
- package/dist/3d-tiles-converter/3d-tiles-converter.d.ts +5 -4
- package/dist/3d-tiles-converter/3d-tiles-converter.d.ts.map +1 -1
- package/dist/3d-tiles-converter/3d-tiles-converter.js +39 -37
- package/dist/3d-tiles-converter/helpers/b3dm-converter.d.ts +3 -1
- package/dist/3d-tiles-converter/helpers/b3dm-converter.d.ts.map +1 -1
- package/dist/3d-tiles-converter/helpers/b3dm-converter.js +4 -2
- package/dist/3d-tiles-converter/helpers/load-i3s.d.ts +10 -0
- package/dist/3d-tiles-converter/helpers/load-i3s.d.ts.map +1 -0
- package/dist/3d-tiles-converter/helpers/load-i3s.js +42 -0
- package/dist/3d-tiles-converter/helpers/texture-atlas.d.ts +2 -1
- package/dist/3d-tiles-converter/helpers/texture-atlas.d.ts.map +1 -1
- package/dist/3d-tiles-converter/helpers/texture-atlas.js +2 -0
- package/dist/converter.min.js +79 -79
- package/dist/dist.min.js +753 -3022
- package/dist/es5/3d-tiles-converter/3d-tiles-converter.js +94 -81
- package/dist/es5/3d-tiles-converter/3d-tiles-converter.js.map +1 -1
- package/dist/es5/3d-tiles-converter/helpers/b3dm-converter.js +6 -4
- package/dist/es5/3d-tiles-converter/helpers/b3dm-converter.js.map +1 -1
- package/dist/es5/3d-tiles-converter/helpers/load-i3s.js +63 -0
- package/dist/es5/3d-tiles-converter/helpers/load-i3s.js.map +1 -0
- package/dist/es5/3d-tiles-converter/helpers/texture-atlas.js.map +1 -1
- package/dist/es5/deps-installer/deps-installer.js +1 -1
- package/dist/es5/lib/utils/lod-conversion-utils.js +10 -4
- package/dist/es5/lib/utils/lod-conversion-utils.js.map +1 -1
- package/dist/es5/pgm-loader.js +1 -1
- package/dist/esm/3d-tiles-converter/3d-tiles-converter.js +46 -43
- package/dist/esm/3d-tiles-converter/3d-tiles-converter.js.map +1 -1
- package/dist/esm/3d-tiles-converter/helpers/b3dm-converter.js +4 -3
- package/dist/esm/3d-tiles-converter/helpers/b3dm-converter.js.map +1 -1
- package/dist/esm/3d-tiles-converter/helpers/load-i3s.js +32 -0
- package/dist/esm/3d-tiles-converter/helpers/load-i3s.js.map +1 -0
- package/dist/esm/3d-tiles-converter/helpers/texture-atlas.js.map +1 -1
- package/dist/esm/deps-installer/deps-installer.js +1 -1
- package/dist/esm/i3s-server/bin/i3s-server.min.js +72 -72
- package/dist/esm/lib/utils/lod-conversion-utils.js +6 -4
- package/dist/esm/lib/utils/lod-conversion-utils.js.map +1 -1
- package/dist/esm/pgm-loader.js +1 -1
- package/dist/lib/utils/lod-conversion-utils.d.ts +2 -2
- package/dist/lib/utils/lod-conversion-utils.d.ts.map +1 -1
- package/dist/lib/utils/lod-conversion-utils.js +4 -4
- package/dist/slpk-extractor.min.js +38 -38
- package/package.json +14 -14
- package/src/3d-tiles-converter/3d-tiles-converter.ts +60 -46
- package/src/3d-tiles-converter/helpers/b3dm-converter.ts +11 -10
- package/src/3d-tiles-converter/helpers/load-i3s.ts +51 -0
- package/src/3d-tiles-converter/helpers/texture-atlas.ts +6 -2
- package/src/lib/utils/lod-conversion-utils.ts +10 -6
|
@@ -16,7 +16,6 @@ var _process = _interopRequireDefault(require("process"));
|
|
|
16
16
|
var _jsonMapTransform = _interopRequireDefault(require("json-map-transform"));
|
|
17
17
|
var _core = require("@loaders.gl/core");
|
|
18
18
|
var _i3s = require("@loaders.gl/i3s");
|
|
19
|
-
var _tiles = require("@loaders.gl/tiles");
|
|
20
19
|
var _pgmLoader = require("../pgm-loader");
|
|
21
20
|
var _i3sObbTo3dTilesObb = require("./helpers/i3s-obb-to-3d-tiles-obb");
|
|
22
21
|
var _lodConversionUtils = require("../lib/utils/lod-conversion-utils");
|
|
@@ -27,6 +26,7 @@ var _coordinateConverter = require("../i3s-converter/helpers/coordinate-converte
|
|
|
27
26
|
var _workerUtils = require("@loaders.gl/worker-utils");
|
|
28
27
|
var _constants = require("../constants");
|
|
29
28
|
var _b3dmConverter = _interopRequireDefault(require("./helpers/b3dm-converter"));
|
|
29
|
+
var _loadI3s = require("./helpers/load-i3s");
|
|
30
30
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
31
31
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
32
32
|
function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
|
|
@@ -44,6 +44,17 @@ var Tiles3DConverter = function () {
|
|
|
44
44
|
(0, _defineProperty2.default)(this, "sourceTileset", void 0);
|
|
45
45
|
(0, _defineProperty2.default)(this, "attributeStorageInfo", void 0);
|
|
46
46
|
(0, _defineProperty2.default)(this, "workerSource", {});
|
|
47
|
+
(0, _defineProperty2.default)(this, "loaderOptions", {
|
|
48
|
+
_nodeWorkers: true,
|
|
49
|
+
reuseWorkers: true,
|
|
50
|
+
i3s: {
|
|
51
|
+
coordinateSystem: _i3s.COORDINATE_SYSTEM.LNGLAT_OFFSETS,
|
|
52
|
+
decodeTextures: false
|
|
53
|
+
},
|
|
54
|
+
'i3s-content': {
|
|
55
|
+
workerUrl: './modules/i3s/dist/i3s-content-worker-node.js'
|
|
56
|
+
}
|
|
57
|
+
});
|
|
47
58
|
this.options = {};
|
|
48
59
|
this.tilesetPath = '';
|
|
49
60
|
this.vertexCounter = 0;
|
|
@@ -57,7 +68,8 @@ var Tiles3DConverter = function () {
|
|
|
57
68
|
key: "convert",
|
|
58
69
|
value: function () {
|
|
59
70
|
var _convert = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(options) {
|
|
60
|
-
var
|
|
71
|
+
var _this$sourceTileset;
|
|
72
|
+
var inputUrl, outputPath, tilesetName, maxDepth, egmFilePath, rootNode, rootTile, tileset, workerFarm;
|
|
61
73
|
return _regenerator.default.wrap(function _callee$(_context) {
|
|
62
74
|
while (1) switch (_context.prev = _context.next) {
|
|
63
75
|
case 0:
|
|
@@ -80,57 +92,47 @@ var Tiles3DConverter = function () {
|
|
|
80
92
|
this.geoidHeightModel = _context.sent;
|
|
81
93
|
console.log('Loading egm file completed!');
|
|
82
94
|
_context.next = 13;
|
|
83
|
-
return (0, _core.load)(inputUrl, _i3s.I3SLoader,
|
|
95
|
+
return (0, _core.load)(inputUrl, _i3s.I3SLoader, this.loaderOptions);
|
|
84
96
|
case 13:
|
|
85
|
-
|
|
86
|
-
this.sourceTileset
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
workerUrl: './modules/i3s/dist/i3s-content-worker-node.js'
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
});
|
|
99
|
-
_context.next = 17;
|
|
100
|
-
return this.sourceTileset.tilesetInitializationPromise;
|
|
101
|
-
case 17:
|
|
102
|
-
rootNode = this.sourceTileset.root;
|
|
103
|
-
if (!rootNode.header.obb) {
|
|
104
|
-
rootNode.header.obb = (0, _coordinateConverter.createObbFromMbs)(rootNode.header.mbs);
|
|
97
|
+
this.sourceTileset = _context.sent;
|
|
98
|
+
if (this.sourceTileset) {
|
|
99
|
+
_context.next = 16;
|
|
100
|
+
break;
|
|
101
|
+
}
|
|
102
|
+
return _context.abrupt("return");
|
|
103
|
+
case 16:
|
|
104
|
+
rootNode = (_this$sourceTileset = this.sourceTileset) === null || _this$sourceTileset === void 0 ? void 0 : _this$sourceTileset.root;
|
|
105
|
+
if (!rootNode.obb) {
|
|
106
|
+
rootNode.obb = (0, _coordinateConverter.createObbFromMbs)(rootNode.mbs);
|
|
105
107
|
}
|
|
106
108
|
this.tilesetPath = (0, _path.join)("".concat(outputPath), "".concat(tilesetName));
|
|
107
|
-
this.attributeStorageInfo =
|
|
108
|
-
_context.prev =
|
|
109
|
-
_context.next =
|
|
109
|
+
this.attributeStorageInfo = this.sourceTileset.attributeStorageInfo;
|
|
110
|
+
_context.prev = 20;
|
|
111
|
+
_context.next = 23;
|
|
110
112
|
return (0, _fileUtils.removeDir)(this.tilesetPath);
|
|
111
|
-
case
|
|
112
|
-
_context.next =
|
|
113
|
+
case 23:
|
|
114
|
+
_context.next = 27;
|
|
113
115
|
break;
|
|
114
|
-
case
|
|
115
|
-
_context.prev =
|
|
116
|
-
_context.t0 = _context["catch"](
|
|
117
|
-
case
|
|
116
|
+
case 25:
|
|
117
|
+
_context.prev = 25;
|
|
118
|
+
_context.t0 = _context["catch"](20);
|
|
119
|
+
case 27:
|
|
118
120
|
rootTile = {
|
|
119
121
|
boundingVolume: {
|
|
120
|
-
box: (0, _i3sObbTo3dTilesObb.i3sObbTo3dTilesObb)(rootNode.
|
|
122
|
+
box: (0, _i3sObbTo3dTilesObb.i3sObbTo3dTilesObb)(rootNode.obb, this.geoidHeightModel)
|
|
121
123
|
},
|
|
122
124
|
geometricError: (0, _lodConversionUtils.convertScreenThresholdToGeometricError)(rootNode),
|
|
123
125
|
children: []
|
|
124
126
|
};
|
|
125
|
-
_context.next =
|
|
127
|
+
_context.next = 30;
|
|
126
128
|
return this._addChildren(rootNode, rootTile, 1);
|
|
127
|
-
case
|
|
129
|
+
case 30:
|
|
128
130
|
tileset = (0, _jsonMapTransform.default)({
|
|
129
131
|
root: rootTile
|
|
130
132
|
}, (0, _tileset.TILESET)());
|
|
131
|
-
_context.next =
|
|
133
|
+
_context.next = 33;
|
|
132
134
|
return (0, _fileUtils.writeFile)(this.tilesetPath, JSON.stringify(tileset), 'tileset.json');
|
|
133
|
-
case
|
|
135
|
+
case 33:
|
|
134
136
|
this._finishConversion({
|
|
135
137
|
slpk: false,
|
|
136
138
|
outputPath: outputPath,
|
|
@@ -138,11 +140,11 @@ var Tiles3DConverter = function () {
|
|
|
138
140
|
});
|
|
139
141
|
workerFarm = _workerUtils.WorkerFarm.getWorkerFarm({});
|
|
140
142
|
workerFarm.destroy();
|
|
141
|
-
case
|
|
143
|
+
case 36:
|
|
142
144
|
case "end":
|
|
143
145
|
return _context.stop();
|
|
144
146
|
}
|
|
145
|
-
}, _callee, this, [[
|
|
147
|
+
}, _callee, this, [[20, 25]]);
|
|
146
148
|
}));
|
|
147
149
|
function convert(_x) {
|
|
148
150
|
return _convert.apply(this, arguments);
|
|
@@ -153,7 +155,7 @@ var Tiles3DConverter = function () {
|
|
|
153
155
|
key: "convertChildNode",
|
|
154
156
|
value: function () {
|
|
155
157
|
var _convertChildNode = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(parentSourceNode, parentNode, level, childNodeInfo) {
|
|
156
|
-
var sourceChild,
|
|
158
|
+
var sourceChild, content, featureAttributes, boundingVolume, child, i3sAttributesData, b3dmConverter, b3dm;
|
|
157
159
|
return _regenerator.default.wrap(function _callee2$(_context2) {
|
|
158
160
|
while (1) switch (_context2.prev = _context2.next) {
|
|
159
161
|
case 0:
|
|
@@ -161,30 +163,39 @@ var Tiles3DConverter = function () {
|
|
|
161
163
|
return this._loadChildNode(parentSourceNode, childNodeInfo);
|
|
162
164
|
case 2:
|
|
163
165
|
sourceChild = _context2.sent;
|
|
164
|
-
parentSourceNode.children.push(sourceChild);
|
|
165
166
|
if (!sourceChild.contentUrl) {
|
|
166
|
-
_context2.next =
|
|
167
|
+
_context2.next = 33;
|
|
167
168
|
break;
|
|
168
169
|
}
|
|
169
|
-
_context2.next =
|
|
170
|
-
return this.sourceTileset.
|
|
171
|
-
case
|
|
172
|
-
|
|
170
|
+
_context2.next = 6;
|
|
171
|
+
return (0, _loadI3s.loadI3SContent)(this.sourceTileset, sourceChild, this.loaderOptions);
|
|
172
|
+
case 6:
|
|
173
|
+
content = _context2.sent;
|
|
174
|
+
if (content) {
|
|
175
|
+
_context2.next = 11;
|
|
176
|
+
break;
|
|
177
|
+
}
|
|
178
|
+
_context2.next = 10;
|
|
179
|
+
return this._addChildren(sourceChild, parentNode, level + 1);
|
|
180
|
+
case 10:
|
|
181
|
+
return _context2.abrupt("return");
|
|
182
|
+
case 11:
|
|
183
|
+
this.vertexCounter += (content === null || content === void 0 ? void 0 : content.vertexCount) || 0;
|
|
173
184
|
featureAttributes = null;
|
|
174
185
|
if (!this.attributeStorageInfo) {
|
|
175
|
-
_context2.next =
|
|
186
|
+
_context2.next = 17;
|
|
176
187
|
break;
|
|
177
188
|
}
|
|
178
|
-
_context2.next =
|
|
189
|
+
_context2.next = 16;
|
|
179
190
|
return this._loadChildAttributes(sourceChild, this.attributeStorageInfo);
|
|
180
|
-
case
|
|
191
|
+
case 16:
|
|
181
192
|
featureAttributes = _context2.sent;
|
|
182
|
-
case
|
|
183
|
-
if (!sourceChild.
|
|
184
|
-
sourceChild.
|
|
193
|
+
case 17:
|
|
194
|
+
if (!sourceChild.obb) {
|
|
195
|
+
sourceChild.obb = (0, _coordinateConverter.createObbFromMbs)(sourceChild.mbs);
|
|
185
196
|
}
|
|
186
197
|
boundingVolume = {
|
|
187
|
-
box: (0, _i3sObbTo3dTilesObb.i3sObbTo3dTilesObb)(sourceChild.
|
|
198
|
+
box: (0, _i3sObbTo3dTilesObb.i3sObbTo3dTilesObb)(sourceChild.obb, this.geoidHeightModel)
|
|
188
199
|
};
|
|
189
200
|
child = {
|
|
190
201
|
boundingVolume: boundingVolume,
|
|
@@ -192,32 +203,32 @@ var Tiles3DConverter = function () {
|
|
|
192
203
|
children: []
|
|
193
204
|
};
|
|
194
205
|
i3sAttributesData = {
|
|
195
|
-
tileContent:
|
|
196
|
-
|
|
206
|
+
tileContent: content,
|
|
207
|
+
box: boundingVolume.box,
|
|
208
|
+
textureFormat: sourceChild.textureFormat
|
|
197
209
|
};
|
|
198
210
|
b3dmConverter = new _b3dmConverter.default();
|
|
199
|
-
_context2.next =
|
|
211
|
+
_context2.next = 24;
|
|
200
212
|
return b3dmConverter.convert(i3sAttributesData, featureAttributes);
|
|
201
|
-
case
|
|
213
|
+
case 24:
|
|
202
214
|
b3dm = _context2.sent;
|
|
203
215
|
child.content = {
|
|
204
216
|
uri: "".concat(sourceChild.id, ".b3dm"),
|
|
205
217
|
boundingVolume: boundingVolume
|
|
206
218
|
};
|
|
207
|
-
_context2.next =
|
|
219
|
+
_context2.next = 28;
|
|
208
220
|
return (0, _fileUtils.writeFile)(this.tilesetPath, new Uint8Array(b3dm), "".concat(sourceChild.id, ".b3dm"));
|
|
209
|
-
case
|
|
221
|
+
case 28:
|
|
210
222
|
parentNode.children.push(child);
|
|
211
|
-
|
|
212
|
-
_context2.next = 28;
|
|
223
|
+
_context2.next = 31;
|
|
213
224
|
return this._addChildren(sourceChild, child, level + 1);
|
|
214
|
-
case
|
|
215
|
-
_context2.next =
|
|
225
|
+
case 31:
|
|
226
|
+
_context2.next = 35;
|
|
216
227
|
break;
|
|
217
|
-
case
|
|
218
|
-
_context2.next =
|
|
228
|
+
case 33:
|
|
229
|
+
_context2.next = 35;
|
|
219
230
|
return this._addChildren(sourceChild, parentNode, level + 1);
|
|
220
|
-
case
|
|
231
|
+
case 35:
|
|
221
232
|
case "end":
|
|
222
233
|
return _context2.stop();
|
|
223
234
|
}
|
|
@@ -243,7 +254,7 @@ var Tiles3DConverter = function () {
|
|
|
243
254
|
return _context3.abrupt("return");
|
|
244
255
|
case 2:
|
|
245
256
|
promises = [];
|
|
246
|
-
_iterator = _createForOfIteratorHelper(parentSourceNode.
|
|
257
|
+
_iterator = _createForOfIteratorHelper(parentSourceNode.children || []);
|
|
247
258
|
try {
|
|
248
259
|
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
249
260
|
childNodeInfo = _step.value;
|
|
@@ -271,38 +282,38 @@ var Tiles3DConverter = function () {
|
|
|
271
282
|
key: "_loadChildNode",
|
|
272
283
|
value: function () {
|
|
273
284
|
var _loadChildNode2 = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee4(parentNode, childNodeInfo) {
|
|
274
|
-
var
|
|
285
|
+
var _this$sourceTileset2;
|
|
286
|
+
var header, nodeUrl, options;
|
|
275
287
|
return _regenerator.default.wrap(function _callee4$(_context4) {
|
|
276
288
|
while (1) switch (_context4.prev = _context4.next) {
|
|
277
289
|
case 0:
|
|
278
|
-
if (!this.sourceTileset.
|
|
290
|
+
if (!((_this$sourceTileset2 = this.sourceTileset) !== null && _this$sourceTileset2 !== void 0 && _this$sourceTileset2.nodePagesTile)) {
|
|
279
291
|
_context4.next = 7;
|
|
280
292
|
break;
|
|
281
293
|
}
|
|
282
294
|
console.log("Node conversion: ".concat(childNodeInfo.id));
|
|
283
295
|
_context4.next = 4;
|
|
284
|
-
return this.sourceTileset.
|
|
296
|
+
return this.sourceTileset.nodePagesTile.formTileFromNodePages(parseInt(childNodeInfo.id));
|
|
285
297
|
case 4:
|
|
286
298
|
header = _context4.sent;
|
|
287
|
-
_context4.next =
|
|
299
|
+
_context4.next = 13;
|
|
288
300
|
break;
|
|
289
301
|
case 7:
|
|
290
|
-
_ref = this.sourceTileset, loader = _ref.loader;
|
|
291
302
|
nodeUrl = this._relativeUrlToFullUrl(parentNode.url, childNodeInfo.href);
|
|
292
303
|
options = {
|
|
293
|
-
i3s: _objectSpread(_objectSpread({}, this.
|
|
304
|
+
i3s: _objectSpread(_objectSpread({}, this.loaderOptions), {}, {
|
|
294
305
|
isTileHeader: true,
|
|
295
306
|
loadContent: false
|
|
296
307
|
})
|
|
297
308
|
};
|
|
298
309
|
console.log("Node conversion: ".concat(nodeUrl));
|
|
299
|
-
_context4.next =
|
|
300
|
-
return (0, _core.load)(nodeUrl,
|
|
301
|
-
case
|
|
310
|
+
_context4.next = 12;
|
|
311
|
+
return (0, _core.load)(nodeUrl, _i3s.I3SLoader, options);
|
|
312
|
+
case 12:
|
|
302
313
|
header = _context4.sent;
|
|
314
|
+
case 13:
|
|
315
|
+
return _context4.abrupt("return", header);
|
|
303
316
|
case 14:
|
|
304
|
-
return _context4.abrupt("return", new _tiles.Tile3D(this.sourceTileset, header, parentNode));
|
|
305
|
-
case 15:
|
|
306
317
|
case "end":
|
|
307
318
|
return _context4.stop();
|
|
308
319
|
}
|
|
@@ -315,7 +326,9 @@ var Tiles3DConverter = function () {
|
|
|
315
326
|
}()
|
|
316
327
|
}, {
|
|
317
328
|
key: "_relativeUrlToFullUrl",
|
|
318
|
-
value: function _relativeUrlToFullUrl(
|
|
329
|
+
value: function _relativeUrlToFullUrl() {
|
|
330
|
+
var baseUrl = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
|
|
331
|
+
var relativeUrl = arguments.length > 1 ? arguments[1] : undefined;
|
|
319
332
|
var resultArray = baseUrl.split('/');
|
|
320
333
|
var relativeUrlArray = relativeUrl.split('/');
|
|
321
334
|
var _iterator2 = _createForOfIteratorHelper(relativeUrlArray),
|
|
@@ -344,12 +357,12 @@ var Tiles3DConverter = function () {
|
|
|
344
357
|
key: "_loadChildAttributes",
|
|
345
358
|
value: function () {
|
|
346
359
|
var _loadChildAttributes2 = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee5(sourceChild, attributeStorageInfo) {
|
|
347
|
-
var promises, attributeUrls, index, inputUrl, attribute, options, attributesList;
|
|
360
|
+
var promises, _sourceChild$attribut, attributeUrls, index, inputUrl, attribute, options, attributesList;
|
|
348
361
|
return _regenerator.default.wrap(function _callee5$(_context5) {
|
|
349
362
|
while (1) switch (_context5.prev = _context5.next) {
|
|
350
363
|
case 0:
|
|
351
364
|
promises = [];
|
|
352
|
-
|
|
365
|
+
_sourceChild$attribut = sourceChild.attributeUrls, attributeUrls = _sourceChild$attribut === void 0 ? [] : _sourceChild$attribut;
|
|
353
366
|
for (index = 0; index < attributeUrls.length; index++) {
|
|
354
367
|
inputUrl = attributeUrls[index];
|
|
355
368
|
attribute = attributeStorageInfo[index];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"3d-tiles-converter.js","names":["_path","require","_process","_interopRequireDefault","_jsonMapTransform","_core","_i3s","_tiles","_pgmLoader","_i3sObbTo3dTilesObb","_lodConversionUtils","_fileUtils","_statisticUtills","_tileset","_coordinateConverter","_workerUtils","_constants","_b3dmConverter","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","_createForOfIteratorHelper","o","allowArrayLike","it","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","F","s","n","done","value","e","_e","f","TypeError","normalCompletion","didErr","err","call","step","next","_e2","return","minLen","_arrayLikeToArray","prototype","toString","slice","constructor","name","from","test","arr","len","arr2","I3S","Tiles3DConverter","_classCallCheck2","options","tilesetPath","vertexCounter","conversionStartTime","geoidHeightModel","sourceTileset","attributeStorageInfo","workerSource","_createClass2","_convert","_asyncToGenerator2","_regenerator","mark","_callee","inputUrl","outputPath","tilesetName","maxDepth","egmFilePath","sourceTilesetJson","rootNode","rootTile","tileset","workerFarm","wrap","_callee$","_context","prev","isBrowser","console","log","BROWSER_ERROR_MESSAGE","abrupt","process","hrtime","load","PGMLoader","sent","I3SLoader","Tileset3D","loadOptions","_nodeWorkers","reuseWorkers","i3s","coordinateSystem","COORDINATE_SYSTEM","LNGLAT_OFFSETS","decodeTextures","workerUrl","tilesetInitializationPromise","root","header","obb","createObbFromMbs","mbs","join","concat","removeDir","t0","boundingVolume","box","i3sObbTo3dTilesObb","geometricError","convertScreenThresholdToGeometricError","children","_addChildren","transform","tilesetTemplate","writeFile","JSON","stringify","_finishConversion","slpk","WorkerFarm","getWorkerFarm","destroy","stop","convert","_x","_convertChildNode","_callee2","parentSourceNode","parentNode","level","childNodeInfo","sourceChild","_sourceChild$header","featureAttributes","child","i3sAttributesData","b3dmConverter","b3dm","_callee2$","_context2","_loadChildNode","contentUrl","_loadTile","content","vertexCount","_loadChildAttributes","tileContent","textureFormat","B3dmConverter","uri","id","Uint8Array","unloadContent","convertChildNode","_x2","_x3","_x4","_x5","_addChildren2","_callee3","promises","_iterator","_step","_callee3$","_context3","Promise","all","_x6","_x7","_x8","_loadChildNode2","_callee4","_ref","loader","nodeUrl","_callee4$","_context4","nodePages","nodePagesTile","formTileFromNodePages","_relativeUrlToFullUrl","url","href","isTileHeader","loadContent","Tile3D","_x9","_x10","baseUrl","relativeUrl","resultArray","split","relativeUrlArray","_iterator2","_step2","folder","_loadChildAttributes2","_callee5","attributeUrls","index","attribute","attributesList","_callee5$","_context5","attributeName","attributeType","_getAttributeType","I3SAttributeLoader","_replaceNestedArrays","assign","_toConsumableArray2","_x11","_x12","attributeValues","valueType","objectIds","attributeObject","_finishConversion2","_callee6","params","filesSize","diff","conversionTime","_callee6$","_context6","calculateFilesSize","timeConverter","_x13","exports"],"sources":["../../../src/3d-tiles-converter/3d-tiles-converter.ts"],"sourcesContent":["import type {AttributeStorageInfo, FeatureAttribute, NodeReference} from '@loaders.gl/i3s';\nimport type {Tiles3DTileJSON} from '@loaders.gl/3d-tiles';\n\nimport {join} from 'path';\nimport process from 'process';\nimport transform from 'json-map-transform';\nimport {load, isBrowser} from '@loaders.gl/core';\nimport {I3SLoader, I3SAttributeLoader, COORDINATE_SYSTEM} from '@loaders.gl/i3s';\nimport {Tileset3D, Tile3D} from '@loaders.gl/tiles';\nimport {Geoid} from '@math.gl/geoid';\n\nimport {PGMLoader} from '../pgm-loader';\nimport {i3sObbTo3dTilesObb} from './helpers/i3s-obb-to-3d-tiles-obb';\nimport {convertScreenThresholdToGeometricError} from '../lib/utils/lod-conversion-utils';\nimport {writeFile, removeDir} from '../lib/utils/file-utils';\nimport {calculateFilesSize, timeConverter} from '../lib/utils/statistic-utills';\nimport {TILESET as tilesetTemplate} from './json-templates/tileset';\nimport {createObbFromMbs} from '../i3s-converter/helpers/coordinate-converter';\nimport {WorkerFarm} from '@loaders.gl/worker-utils';\nimport {BROWSER_ERROR_MESSAGE} from '../constants';\nimport B3dmConverter, {I3SAttributesData} from './helpers/b3dm-converter';\n\nconst I3S = 'I3S';\n\n/**\n * Converter from i3s to 3d-tiles\n */\nexport default class Tiles3DConverter {\n options: any;\n tilesetPath: string;\n vertexCounter: number;\n conversionStartTime: [number, number];\n geoidHeightModel: Geoid | null;\n sourceTileset: Tileset3D | null;\n attributeStorageInfo: AttributeStorageInfo | null;\n workerSource: {[key: string]: string} = {};\n\n constructor() {\n this.options = {};\n this.tilesetPath = '';\n this.vertexCounter = 0;\n this.conversionStartTime = [0, 0];\n this.geoidHeightModel = null;\n this.sourceTileset = null;\n this.attributeStorageInfo = null;\n this.workerSource = {};\n }\n\n /**\n * Convert i3s format data to 3dTiles\n * @param options\n * @param options.inputUrl the url to read the tileset from\n * @param options.outputPath the output filename\n * @param options.tilesetName the output name of the tileset\n * @param options.egmFilePath location of *.pgm file to convert heights from ellipsoidal to gravity-related format\n * @param options.maxDepth The max tree depth of conversion\n */\n public async convert(options: {\n inputUrl: string;\n outputPath: string;\n tilesetName: string;\n maxDepth?: number;\n egmFilePath: string;\n }): Promise<any> {\n if (isBrowser) {\n console.log(BROWSER_ERROR_MESSAGE);\n return BROWSER_ERROR_MESSAGE;\n }\n const {inputUrl, outputPath, tilesetName, maxDepth, egmFilePath} = options;\n this.conversionStartTime = process.hrtime();\n this.options = {maxDepth};\n\n console.log('Loading egm file...'); // eslint-disable-line\n this.geoidHeightModel = await load(egmFilePath, PGMLoader);\n console.log('Loading egm file completed!'); // eslint-disable-line\n\n const sourceTilesetJson = await load(inputUrl, I3SLoader, {});\n\n this.sourceTileset = new Tileset3D(sourceTilesetJson, {\n loadOptions: {\n _nodeWorkers: true,\n reuseWorkers: true,\n i3s: {coordinateSystem: COORDINATE_SYSTEM.LNGLAT_OFFSETS, decodeTextures: false},\n // We need to load local fs workers because nodejs can't load workers from the Internet\n 'i3s-content': {\n workerUrl: './modules/i3s/dist/i3s-content-worker-node.js'\n }\n }\n });\n\n await this.sourceTileset.tilesetInitializationPromise;\n const rootNode = this.sourceTileset.root!;\n if (!rootNode.header.obb) {\n rootNode.header.obb = createObbFromMbs(rootNode.header.mbs);\n }\n\n this.tilesetPath = join(`${outputPath}`, `${tilesetName}`);\n this.attributeStorageInfo = sourceTilesetJson.attributeStorageInfo;\n // Removing the tilesetPath needed to exclude erroneous files after conversion\n try {\n await removeDir(this.tilesetPath);\n } catch (e) {\n // do nothing\n }\n\n const rootTile: Tiles3DTileJSON = {\n boundingVolume: {\n box: i3sObbTo3dTilesObb(rootNode.header.obb, this.geoidHeightModel)\n },\n geometricError: convertScreenThresholdToGeometricError(rootNode),\n children: []\n };\n\n await this._addChildren(rootNode, rootTile, 1);\n\n const tileset = transform({root: rootTile}, tilesetTemplate());\n await writeFile(this.tilesetPath, JSON.stringify(tileset), 'tileset.json');\n\n this._finishConversion({slpk: false, outputPath, tilesetName});\n\n // Clean up worker pools\n const workerFarm = WorkerFarm.getWorkerFarm({});\n workerFarm.destroy();\n }\n\n /**\n * Convert particular I3S Node\n * @param parentSourceNode the parent node tile object (@loaders.gl/tiles/Tile3D)\n * @param parentNode object in resulting tileset\n * @param level a current level of a tree depth\n * @param childNodeInfo child node to convert\n */\n private async convertChildNode(\n parentSourceNode: Tile3D,\n parentNode: Tiles3DTileJSON,\n level: number,\n childNodeInfo: NodeReference\n ): Promise<void> {\n const sourceChild = await this._loadChildNode(parentSourceNode, childNodeInfo);\n parentSourceNode.children.push(sourceChild);\n if (sourceChild.contentUrl) {\n await this.sourceTileset!._loadTile(sourceChild);\n this.vertexCounter += sourceChild.content.vertexCount;\n\n let featureAttributes: FeatureAttribute | null = null;\n if (this.attributeStorageInfo) {\n featureAttributes = await this._loadChildAttributes(sourceChild, this.attributeStorageInfo);\n }\n\n if (!sourceChild.header.obb) {\n sourceChild.header.obb = createObbFromMbs(sourceChild.header.mbs);\n }\n\n const boundingVolume = {\n box: i3sObbTo3dTilesObb(sourceChild.header.obb, this.geoidHeightModel)\n };\n const child: Tiles3DTileJSON = {\n boundingVolume,\n geometricError: convertScreenThresholdToGeometricError(sourceChild),\n children: []\n };\n\n const i3sAttributesData: I3SAttributesData = {\n tileContent: sourceChild.content,\n textureFormat: sourceChild?.header?.textureFormat\n };\n\n const b3dmConverter = new B3dmConverter();\n const b3dm = await b3dmConverter.convert(i3sAttributesData, featureAttributes);\n\n child.content = {\n uri: `${sourceChild.id}.b3dm`,\n boundingVolume\n };\n await writeFile(this.tilesetPath, new Uint8Array(b3dm), `${sourceChild.id}.b3dm`);\n parentNode.children.push(child);\n\n sourceChild.unloadContent();\n await this._addChildren(sourceChild, child, level + 1);\n } else {\n await this._addChildren(sourceChild, parentNode, level + 1);\n }\n }\n\n /**\n * The recursive function of traversal of a nodes tree\n * @param parentSourceNode the parent node tile object (@loaders.gl/tiles/Tile3D)\n * @param parentNode object in resulting tileset\n * @param level a current level of a tree depth\n */\n private async _addChildren(\n parentSourceNode: Tile3D,\n parentNode: Tiles3DTileJSON,\n level: number\n ): Promise<void> {\n if (this.options.maxDepth && level > this.options.maxDepth) {\n return;\n }\n const promises: Promise<void>[] = [];\n for (const childNodeInfo of parentSourceNode.header.children || []) {\n promises.push(this.convertChildNode(parentSourceNode, parentNode, level, childNodeInfo));\n }\n await Promise.all(promises);\n }\n\n /**\n * Load a child node having information from the node header\n * @param parentNode a parent node tile object (@loaders.gl/tiles/Tile3D)\n * @param childNodeInfo child information from 3DNodeIndexDocument\n * (https://github.com/Esri/i3s-spec/blob/master/docs/1.7/nodeReference.cmn.md)\n */\n private async _loadChildNode(parentNode: Tile3D, childNodeInfo: NodeReference): Promise<Tile3D> {\n let header;\n if (this.sourceTileset!.tileset.nodePages) {\n console.log(`Node conversion: ${childNodeInfo.id}`); // eslint-disable-line no-console,no-undef\n header = await this.sourceTileset!.tileset.nodePagesTile.formTileFromNodePages(\n childNodeInfo.id\n );\n } else {\n const {loader} = this.sourceTileset!;\n const nodeUrl = this._relativeUrlToFullUrl(parentNode.url, childNodeInfo.href!);\n // load metadata\n const options = {\n i3s: {\n ...this.sourceTileset!.loadOptions,\n isTileHeader: true,\n loadContent: false\n }\n };\n\n console.log(`Node conversion: ${nodeUrl}`); // eslint-disable-line no-console,no-undef\n header = await load(nodeUrl, loader, options);\n }\n return new Tile3D(this.sourceTileset!, header, parentNode);\n }\n\n /**\n * Make an url of a resource from its relative url having the base url\n * @param baseUrl the base url. A resulting url will be related from this url\n * @param relativeUrl a realtive url of a resource\n */\n private _relativeUrlToFullUrl(baseUrl: string, relativeUrl: string): string {\n let resultArray = baseUrl.split('/');\n const relativeUrlArray = relativeUrl.split('/');\n for (const folder of relativeUrlArray) {\n switch (folder) {\n case '.':\n continue; // eslint-disable-line no-continue\n case '..':\n resultArray = resultArray.slice(0, -1);\n break;\n default:\n resultArray.push(folder);\n }\n }\n return resultArray.join('/');\n }\n\n /**\n * Do loading all attributes related to particular node.\n * @param sourceChild\n * @param attributeStorageInfo\n * @returns Promise of attributes object.\n */\n private async _loadChildAttributes(\n sourceChild: Tile3D,\n attributeStorageInfo: AttributeStorageInfo\n ): Promise<FeatureAttribute> {\n const promises: any[] = [];\n const {attributeUrls} = sourceChild.header;\n\n for (let index = 0; index < attributeUrls.length; index++) {\n const inputUrl = attributeUrls[index];\n const attribute = attributeStorageInfo[index];\n const options = {\n attributeName: attribute.name,\n attributeType: this._getAttributeType(attribute)\n };\n\n promises.push(load(inputUrl, I3SAttributeLoader, options));\n }\n const attributesList = await Promise.all(promises);\n this._replaceNestedArrays(attributesList);\n return Object.assign({}, ...attributesList);\n }\n\n /**\n * Returns attribute type for loading attributes\n * @param attribute\n * Workaround for I3S v1.6. There is no attribute.attributeValues.valueType field in attribute.\n * There is an 'Oid32' type if attribute has objectIds property.\n * Doc: https://github.com/Esri/i3s-spec/blob/master/docs/1.6/attributeStorageInfo.cmn.md\n */\n private _getAttributeType(attribute: AttributeStorageInfo): string {\n if (attribute.attributeValues) {\n return attribute.attributeValues.valueType;\n } else if (attribute.objectIds) {\n return 'Oid32';\n }\n return '';\n }\n\n /**\n * Make simple arrays from attribute typed arrays.\n * @param attributesList\n */\n private _replaceNestedArrays(attributesList: FeatureAttribute[]): void {\n for (let index = 0; index < attributesList.length; index++) {\n const attributeObject = attributesList[index];\n\n for (const key in attributeObject) {\n attributeObject[key] = Array.from(attributeObject[key]);\n }\n }\n }\n\n /**\n * Print statistics in the end of conversion\n * @param params - output files data\n */\n private async _finishConversion(params: {\n slpk: boolean;\n outputPath: string;\n tilesetName: string;\n }): Promise<void> {\n const filesSize = await calculateFilesSize(params);\n const diff = process.hrtime(this.conversionStartTime);\n const conversionTime = timeConverter(diff);\n\n console.log(`------------------------------------------------`); // eslint-disable-line\n console.log(`Finish conversion of ${I3S}`); // eslint-disable-line\n console.log(`Total conversion time: ${conversionTime}`); // eslint-disable-line\n console.log(`Vertex count: `, this.vertexCounter); // eslint-disable-line\n console.log(`File(s) size: `, filesSize, ' bytes'); // eslint-disable-line\n console.log(`------------------------------------------------`); // eslint-disable-line\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"3d-tiles-converter.js","names":["_path","require","_process","_interopRequireDefault","_jsonMapTransform","_core","_i3s","_pgmLoader","_i3sObbTo3dTilesObb","_lodConversionUtils","_fileUtils","_statisticUtills","_tileset","_coordinateConverter","_workerUtils","_constants","_b3dmConverter","_loadI3s","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","_createForOfIteratorHelper","o","allowArrayLike","it","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","F","s","n","done","value","e","_e","f","TypeError","normalCompletion","didErr","err","call","step","next","_e2","return","minLen","_arrayLikeToArray","prototype","toString","slice","constructor","name","from","test","arr","len","arr2","I3S","Tiles3DConverter","_classCallCheck2","_nodeWorkers","reuseWorkers","i3s","coordinateSystem","COORDINATE_SYSTEM","LNGLAT_OFFSETS","decodeTextures","workerUrl","options","tilesetPath","vertexCounter","conversionStartTime","geoidHeightModel","sourceTileset","attributeStorageInfo","workerSource","_createClass2","_convert","_asyncToGenerator2","_regenerator","mark","_callee","_this$sourceTileset","inputUrl","outputPath","tilesetName","maxDepth","egmFilePath","rootNode","rootTile","tileset","workerFarm","wrap","_callee$","_context","prev","isBrowser","console","log","BROWSER_ERROR_MESSAGE","abrupt","process","hrtime","load","PGMLoader","sent","I3SLoader","loaderOptions","root","obb","createObbFromMbs","mbs","join","concat","removeDir","t0","boundingVolume","box","i3sObbTo3dTilesObb","geometricError","convertScreenThresholdToGeometricError","children","_addChildren","transform","tilesetTemplate","writeFile","JSON","stringify","_finishConversion","slpk","WorkerFarm","getWorkerFarm","destroy","stop","convert","_x","_convertChildNode","_callee2","parentSourceNode","parentNode","level","childNodeInfo","sourceChild","content","featureAttributes","child","i3sAttributesData","b3dmConverter","b3dm","_callee2$","_context2","_loadChildNode","contentUrl","loadI3SContent","vertexCount","_loadChildAttributes","tileContent","textureFormat","B3dmConverter","uri","id","Uint8Array","convertChildNode","_x2","_x3","_x4","_x5","_addChildren2","_callee3","promises","_iterator","_step","_callee3$","_context3","Promise","all","_x6","_x7","_x8","_loadChildNode2","_callee4","_this$sourceTileset2","header","nodeUrl","_callee4$","_context4","nodePagesTile","formTileFromNodePages","parseInt","_relativeUrlToFullUrl","url","href","isTileHeader","loadContent","_x9","_x10","baseUrl","undefined","relativeUrl","resultArray","split","relativeUrlArray","_iterator2","_step2","folder","_loadChildAttributes2","_callee5","_sourceChild$attribut","attributeUrls","index","attribute","attributesList","_callee5$","_context5","attributeName","attributeType","_getAttributeType","I3SAttributeLoader","_replaceNestedArrays","assign","_toConsumableArray2","_x11","_x12","attributeValues","valueType","objectIds","attributeObject","_finishConversion2","_callee6","params","filesSize","diff","conversionTime","_callee6$","_context6","calculateFilesSize","timeConverter","_x13","exports"],"sources":["../../../src/3d-tiles-converter/3d-tiles-converter.ts"],"sourcesContent":["import type {\n AttributeStorageInfo,\n FeatureAttribute,\n NodeReference,\n I3STilesetHeader\n} from '@loaders.gl/i3s';\nimport type {Tiles3DTileJSON} from '@loaders.gl/3d-tiles';\n\nimport {join} from 'path';\nimport process from 'process';\nimport transform from 'json-map-transform';\nimport {load, isBrowser} from '@loaders.gl/core';\nimport {I3SLoader, I3SAttributeLoader, COORDINATE_SYSTEM} from '@loaders.gl/i3s';\nimport {Geoid} from '@math.gl/geoid';\n\nimport {PGMLoader} from '../pgm-loader';\nimport {i3sObbTo3dTilesObb} from './helpers/i3s-obb-to-3d-tiles-obb';\nimport {convertScreenThresholdToGeometricError} from '../lib/utils/lod-conversion-utils';\nimport {writeFile, removeDir} from '../lib/utils/file-utils';\nimport {calculateFilesSize, timeConverter} from '../lib/utils/statistic-utills';\nimport {TILESET as tilesetTemplate} from './json-templates/tileset';\nimport {createObbFromMbs} from '../i3s-converter/helpers/coordinate-converter';\nimport {WorkerFarm} from '@loaders.gl/worker-utils';\nimport {BROWSER_ERROR_MESSAGE} from '../constants';\nimport B3dmConverter, {I3SAttributesData} from './helpers/b3dm-converter';\nimport {I3STileHeader} from '@loaders.gl/i3s/src/types';\nimport {loadI3SContent} from './helpers/load-i3s';\nimport {I3SLoaderOptions} from '@loaders.gl/i3s/src/i3s-loader';\n\nconst I3S = 'I3S';\n\n/**\n * Converter from i3s to 3d-tiles\n */\nexport default class Tiles3DConverter {\n options: any;\n tilesetPath: string;\n vertexCounter: number;\n conversionStartTime: [number, number];\n geoidHeightModel: Geoid | null;\n sourceTileset: I3STilesetHeader | null;\n attributeStorageInfo?: AttributeStorageInfo[] | null;\n workerSource: {[key: string]: string} = {};\n loaderOptions: I3SLoaderOptions = {\n _nodeWorkers: true,\n reuseWorkers: true,\n i3s: {coordinateSystem: COORDINATE_SYSTEM.LNGLAT_OFFSETS, decodeTextures: false},\n // We need to load local fs workers because nodejs can't load workers from the Internet\n 'i3s-content': {\n workerUrl: './modules/i3s/dist/i3s-content-worker-node.js'\n }\n };\n\n constructor() {\n this.options = {};\n this.tilesetPath = '';\n this.vertexCounter = 0;\n this.conversionStartTime = [0, 0];\n this.geoidHeightModel = null;\n this.sourceTileset = null;\n this.attributeStorageInfo = null;\n this.workerSource = {};\n }\n\n /**\n * Convert i3s format data to 3dTiles\n * @param options\n * @param options.inputUrl the url to read the tileset from\n * @param options.outputPath the output filename\n * @param options.tilesetName the output name of the tileset\n * @param options.egmFilePath location of *.pgm file to convert heights from ellipsoidal to gravity-related format\n * @param options.maxDepth The max tree depth of conversion\n */\n public async convert(options: {\n inputUrl: string;\n outputPath: string;\n tilesetName: string;\n maxDepth?: number;\n egmFilePath: string;\n }): Promise<any> {\n if (isBrowser) {\n console.log(BROWSER_ERROR_MESSAGE);\n return BROWSER_ERROR_MESSAGE;\n }\n const {inputUrl, outputPath, tilesetName, maxDepth, egmFilePath} = options;\n this.conversionStartTime = process.hrtime();\n this.options = {maxDepth};\n\n console.log('Loading egm file...'); // eslint-disable-line\n this.geoidHeightModel = await load(egmFilePath, PGMLoader);\n console.log('Loading egm file completed!'); // eslint-disable-line\n\n this.sourceTileset = await load(inputUrl, I3SLoader, this.loaderOptions);\n\n if (!this.sourceTileset) {\n return;\n }\n\n const rootNode = this.sourceTileset?.root;\n if (!rootNode.obb) {\n rootNode.obb = createObbFromMbs(rootNode.mbs);\n }\n\n this.tilesetPath = join(`${outputPath}`, `${tilesetName}`);\n this.attributeStorageInfo = this.sourceTileset.attributeStorageInfo;\n // Removing the tilesetPath needed to exclude erroneous files after conversion\n try {\n await removeDir(this.tilesetPath);\n } catch (e) {\n // do nothing\n }\n\n const rootTile: Tiles3DTileJSON = {\n boundingVolume: {\n box: i3sObbTo3dTilesObb(rootNode.obb, this.geoidHeightModel)\n },\n geometricError: convertScreenThresholdToGeometricError(rootNode),\n children: []\n };\n\n await this._addChildren(rootNode, rootTile, 1);\n\n const tileset = transform({root: rootTile}, tilesetTemplate());\n await writeFile(this.tilesetPath, JSON.stringify(tileset), 'tileset.json');\n\n this._finishConversion({slpk: false, outputPath, tilesetName});\n\n // Clean up worker pools\n const workerFarm = WorkerFarm.getWorkerFarm({});\n workerFarm.destroy();\n }\n\n /**\n * Convert particular I3S Node\n * @param parentSourceNode the parent node tile object (@loaders.gl/tiles/Tile3D)\n * @param parentNode object in resulting tileset\n * @param level a current level of a tree depth\n * @param childNodeInfo child node to convert\n */\n private async convertChildNode(\n parentSourceNode: I3STileHeader,\n parentNode: Tiles3DTileJSON,\n level: number,\n childNodeInfo: NodeReference\n ): Promise<void> {\n const sourceChild = await this._loadChildNode(parentSourceNode, childNodeInfo);\n if (sourceChild.contentUrl) {\n const content = await loadI3SContent(this.sourceTileset, sourceChild, this.loaderOptions);\n\n if (!content) {\n await this._addChildren(sourceChild, parentNode, level + 1);\n return;\n }\n\n this.vertexCounter += content?.vertexCount || 0;\n\n let featureAttributes: FeatureAttribute | null = null;\n if (this.attributeStorageInfo) {\n featureAttributes = await this._loadChildAttributes(sourceChild, this.attributeStorageInfo);\n }\n\n if (!sourceChild.obb) {\n sourceChild.obb = createObbFromMbs(sourceChild.mbs);\n }\n\n const boundingVolume = {\n box: i3sObbTo3dTilesObb(sourceChild.obb, this.geoidHeightModel)\n };\n const child: Tiles3DTileJSON = {\n boundingVolume,\n geometricError: convertScreenThresholdToGeometricError(sourceChild),\n children: []\n };\n\n const i3sAttributesData: I3SAttributesData = {\n tileContent: content,\n box: boundingVolume.box,\n textureFormat: sourceChild.textureFormat\n };\n\n const b3dmConverter = new B3dmConverter();\n const b3dm = await b3dmConverter.convert(i3sAttributesData, featureAttributes);\n\n child.content = {\n uri: `${sourceChild.id}.b3dm`,\n boundingVolume\n };\n await writeFile(this.tilesetPath, new Uint8Array(b3dm), `${sourceChild.id}.b3dm`);\n parentNode.children.push(child);\n\n await this._addChildren(sourceChild, child, level + 1);\n } else {\n await this._addChildren(sourceChild, parentNode, level + 1);\n }\n }\n\n /**\n * The recursive function of traversal of a nodes tree\n * @param parentSourceNode the parent node tile object (@loaders.gl/tiles/Tile3D)\n * @param parentNode object in resulting tileset\n * @param level a current level of a tree depth\n */\n private async _addChildren(\n parentSourceNode: I3STileHeader,\n parentNode: Tiles3DTileJSON,\n level: number\n ): Promise<void> {\n if (this.options.maxDepth && level > this.options.maxDepth) {\n return;\n }\n const promises: Promise<void>[] = [];\n for (const childNodeInfo of parentSourceNode.children || []) {\n promises.push(this.convertChildNode(parentSourceNode, parentNode, level, childNodeInfo));\n }\n await Promise.all(promises);\n }\n\n /**\n * Load a child node having information from the node header\n * @param parentNode a parent node tile object (@loaders.gl/tiles/Tile3D)\n * @param childNodeInfo child information from 3DNodeIndexDocument\n * (https://github.com/Esri/i3s-spec/blob/master/docs/1.7/nodeReference.cmn.md)\n */\n private async _loadChildNode(\n parentNode: I3STileHeader,\n childNodeInfo: NodeReference\n ): Promise<I3STileHeader> {\n let header;\n if (this.sourceTileset?.nodePagesTile) {\n console.log(`Node conversion: ${childNodeInfo.id}`); // eslint-disable-line no-console,no-undef\n header = await this.sourceTileset.nodePagesTile.formTileFromNodePages(\n parseInt(childNodeInfo.id)\n );\n } else {\n const nodeUrl = this._relativeUrlToFullUrl(parentNode.url, childNodeInfo.href!);\n // load metadata\n const options = {\n i3s: {\n ...this.loaderOptions,\n isTileHeader: true,\n loadContent: false\n }\n };\n\n console.log(`Node conversion: ${nodeUrl}`); // eslint-disable-line no-console,no-undef\n header = await load(nodeUrl, I3SLoader, options);\n }\n return header;\n }\n\n /**\n * Make an url of a resource from its relative url having the base url\n * @param baseUrl the base url. A resulting url will be related from this url\n * @param relativeUrl a realtive url of a resource\n */\n private _relativeUrlToFullUrl(baseUrl: string = '', relativeUrl: string): string {\n let resultArray = baseUrl.split('/');\n const relativeUrlArray = relativeUrl.split('/');\n for (const folder of relativeUrlArray) {\n switch (folder) {\n case '.':\n continue; // eslint-disable-line no-continue\n case '..':\n resultArray = resultArray.slice(0, -1);\n break;\n default:\n resultArray.push(folder);\n }\n }\n return resultArray.join('/');\n }\n\n /**\n * Do loading all attributes related to particular node.\n * @param sourceChild\n * @param attributeStorageInfo\n * @returns Promise of attributes object.\n */\n private async _loadChildAttributes(\n sourceChild: I3STileHeader,\n attributeStorageInfo: AttributeStorageInfo[]\n ): Promise<FeatureAttribute> {\n const promises: any[] = [];\n const {attributeUrls = []} = sourceChild;\n\n for (let index = 0; index < attributeUrls.length; index++) {\n const inputUrl = attributeUrls[index];\n const attribute = attributeStorageInfo[index];\n const options = {\n attributeName: attribute.name,\n attributeType: this._getAttributeType(attribute)\n };\n\n promises.push(load(inputUrl, I3SAttributeLoader, options));\n }\n const attributesList = await Promise.all(promises);\n this._replaceNestedArrays(attributesList);\n return Object.assign({}, ...attributesList);\n }\n\n /**\n * Returns attribute type for loading attributes\n * @param attribute\n * Workaround for I3S v1.6. There is no attribute.attributeValues.valueType field in attribute.\n * There is an 'Oid32' type if attribute has objectIds property.\n * Doc: https://github.com/Esri/i3s-spec/blob/master/docs/1.6/attributeStorageInfo.cmn.md\n */\n private _getAttributeType(attribute: AttributeStorageInfo): string {\n if (attribute.attributeValues) {\n return attribute.attributeValues.valueType;\n } else if (attribute.objectIds) {\n return 'Oid32';\n }\n return '';\n }\n\n /**\n * Make simple arrays from attribute typed arrays.\n * @param attributesList\n */\n private _replaceNestedArrays(attributesList: FeatureAttribute[]): void {\n for (let index = 0; index < attributesList.length; index++) {\n const attributeObject = attributesList[index];\n\n for (const key in attributeObject) {\n attributeObject[key] = Array.from(attributeObject[key]);\n }\n }\n }\n\n /**\n * Print statistics in the end of conversion\n * @param params - output files data\n */\n private async _finishConversion(params: {\n slpk: boolean;\n outputPath: string;\n tilesetName: string;\n }): Promise<void> {\n const filesSize = await calculateFilesSize(params);\n const diff = process.hrtime(this.conversionStartTime);\n const conversionTime = timeConverter(diff);\n\n console.log(`------------------------------------------------`); // eslint-disable-line\n console.log(`Finish conversion of ${I3S}`); // eslint-disable-line\n console.log(`Total conversion time: ${conversionTime}`); // eslint-disable-line\n console.log(`Vertex count: `, this.vertexCounter); // eslint-disable-line\n console.log(`File(s) size: `, filesSize, ' bytes'); // eslint-disable-line\n console.log(`------------------------------------------------`); // eslint-disable-line\n }\n}\n"],"mappings":"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"}
|
|
@@ -65,12 +65,12 @@ var B3dmConverter = function () {
|
|
|
65
65
|
key: "buildGltf",
|
|
66
66
|
value: function () {
|
|
67
67
|
var _buildGltf = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(i3sAttributesData, featureAttributes) {
|
|
68
|
-
var tileContent, textureFormat, material, attributes, originalIndices,
|
|
68
|
+
var tileContent, textureFormat, box, material, attributes, originalIndices, modelMatrix, gltfBuilder, textureIndex, pbrMaterialInfo, materialIndex, positions, positionsValue, cartesianOrigin, cartographicOrigin, indices, meshIndex, transformMatrix, nodeIndex, sceneIndex, gltfBuffer;
|
|
69
69
|
return _regenerator.default.wrap(function _callee2$(_context2) {
|
|
70
70
|
while (1) switch (_context2.prev = _context2.next) {
|
|
71
71
|
case 0:
|
|
72
|
-
tileContent = i3sAttributesData.tileContent, textureFormat = i3sAttributesData.textureFormat;
|
|
73
|
-
material = tileContent.material, attributes = tileContent.attributes, originalIndices = tileContent.indices,
|
|
72
|
+
tileContent = i3sAttributesData.tileContent, textureFormat = i3sAttributesData.textureFormat, box = i3sAttributesData.box;
|
|
73
|
+
material = tileContent.material, attributes = tileContent.attributes, originalIndices = tileContent.indices, modelMatrix = tileContent.modelMatrix;
|
|
74
74
|
gltfBuilder = new _gltf.GLTFScenegraph();
|
|
75
75
|
_context2.next = 5;
|
|
76
76
|
return this._addI3sTextureToGltf(tileContent, textureFormat, gltfBuilder);
|
|
@@ -83,6 +83,8 @@ var B3dmConverter = function () {
|
|
|
83
83
|
if (attributes.uvRegions && attributes.texCoords) {
|
|
84
84
|
attributes.texCoords.value = (0, _textureAtlas.convertTextureAtlas)(attributes.texCoords.value, attributes.uvRegions.value);
|
|
85
85
|
}
|
|
86
|
+
cartesianOrigin = new _core2.Vector3(box);
|
|
87
|
+
cartographicOrigin = _geospatial.Ellipsoid.WGS84.cartesianToCartographic(cartesianOrigin, new _core2.Vector3());
|
|
86
88
|
attributes.positions.value = this._normalizePositions(positionsValue, cartesianOrigin, cartographicOrigin, modelMatrix);
|
|
87
89
|
this._createBatchIds(tileContent, featureAttributes);
|
|
88
90
|
if (attributes.normals && !this._checkNormals(attributes.normals.value)) {
|
|
@@ -107,7 +109,7 @@ var B3dmConverter = function () {
|
|
|
107
109
|
gltfBuilder.createBinaryChunk();
|
|
108
110
|
gltfBuffer = (0, _core.encodeSync)(gltfBuilder.gltf, _gltf.GLTFWriter);
|
|
109
111
|
return _context2.abrupt("return", gltfBuffer);
|
|
110
|
-
case
|
|
112
|
+
case 25:
|
|
111
113
|
case "end":
|
|
112
114
|
return _context2.stop();
|
|
113
115
|
}
|