@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.
Files changed (48) hide show
  1. package/bin/converter.js +1 -1
  2. package/dist/3d-tiles-converter/3d-tiles-converter.d.ts +5 -4
  3. package/dist/3d-tiles-converter/3d-tiles-converter.d.ts.map +1 -1
  4. package/dist/3d-tiles-converter/3d-tiles-converter.js +39 -37
  5. package/dist/3d-tiles-converter/helpers/b3dm-converter.d.ts +3 -1
  6. package/dist/3d-tiles-converter/helpers/b3dm-converter.d.ts.map +1 -1
  7. package/dist/3d-tiles-converter/helpers/b3dm-converter.js +4 -2
  8. package/dist/3d-tiles-converter/helpers/load-i3s.d.ts +10 -0
  9. package/dist/3d-tiles-converter/helpers/load-i3s.d.ts.map +1 -0
  10. package/dist/3d-tiles-converter/helpers/load-i3s.js +42 -0
  11. package/dist/3d-tiles-converter/helpers/texture-atlas.d.ts +2 -1
  12. package/dist/3d-tiles-converter/helpers/texture-atlas.d.ts.map +1 -1
  13. package/dist/3d-tiles-converter/helpers/texture-atlas.js +2 -0
  14. package/dist/converter.min.js +79 -79
  15. package/dist/dist.min.js +753 -3022
  16. package/dist/es5/3d-tiles-converter/3d-tiles-converter.js +94 -81
  17. package/dist/es5/3d-tiles-converter/3d-tiles-converter.js.map +1 -1
  18. package/dist/es5/3d-tiles-converter/helpers/b3dm-converter.js +6 -4
  19. package/dist/es5/3d-tiles-converter/helpers/b3dm-converter.js.map +1 -1
  20. package/dist/es5/3d-tiles-converter/helpers/load-i3s.js +63 -0
  21. package/dist/es5/3d-tiles-converter/helpers/load-i3s.js.map +1 -0
  22. package/dist/es5/3d-tiles-converter/helpers/texture-atlas.js.map +1 -1
  23. package/dist/es5/deps-installer/deps-installer.js +1 -1
  24. package/dist/es5/lib/utils/lod-conversion-utils.js +10 -4
  25. package/dist/es5/lib/utils/lod-conversion-utils.js.map +1 -1
  26. package/dist/es5/pgm-loader.js +1 -1
  27. package/dist/esm/3d-tiles-converter/3d-tiles-converter.js +46 -43
  28. package/dist/esm/3d-tiles-converter/3d-tiles-converter.js.map +1 -1
  29. package/dist/esm/3d-tiles-converter/helpers/b3dm-converter.js +4 -3
  30. package/dist/esm/3d-tiles-converter/helpers/b3dm-converter.js.map +1 -1
  31. package/dist/esm/3d-tiles-converter/helpers/load-i3s.js +32 -0
  32. package/dist/esm/3d-tiles-converter/helpers/load-i3s.js.map +1 -0
  33. package/dist/esm/3d-tiles-converter/helpers/texture-atlas.js.map +1 -1
  34. package/dist/esm/deps-installer/deps-installer.js +1 -1
  35. package/dist/esm/i3s-server/bin/i3s-server.min.js +72 -72
  36. package/dist/esm/lib/utils/lod-conversion-utils.js +6 -4
  37. package/dist/esm/lib/utils/lod-conversion-utils.js.map +1 -1
  38. package/dist/esm/pgm-loader.js +1 -1
  39. package/dist/lib/utils/lod-conversion-utils.d.ts +2 -2
  40. package/dist/lib/utils/lod-conversion-utils.d.ts.map +1 -1
  41. package/dist/lib/utils/lod-conversion-utils.js +4 -4
  42. package/dist/slpk-extractor.min.js +38 -38
  43. package/package.json +14 -14
  44. package/src/3d-tiles-converter/3d-tiles-converter.ts +60 -46
  45. package/src/3d-tiles-converter/helpers/b3dm-converter.ts +11 -10
  46. package/src/3d-tiles-converter/helpers/load-i3s.ts +51 -0
  47. package/src/3d-tiles-converter/helpers/texture-atlas.ts +6 -2
  48. 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 inputUrl, outputPath, tilesetName, maxDepth, egmFilePath, sourceTilesetJson, rootNode, rootTile, tileset, workerFarm;
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
- sourceTilesetJson = _context.sent;
86
- this.sourceTileset = new _tiles.Tileset3D(sourceTilesetJson, {
87
- loadOptions: {
88
- _nodeWorkers: true,
89
- reuseWorkers: true,
90
- i3s: {
91
- coordinateSystem: _i3s.COORDINATE_SYSTEM.LNGLAT_OFFSETS,
92
- decodeTextures: false
93
- },
94
- 'i3s-content': {
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 = sourceTilesetJson.attributeStorageInfo;
108
- _context.prev = 21;
109
- _context.next = 24;
109
+ this.attributeStorageInfo = this.sourceTileset.attributeStorageInfo;
110
+ _context.prev = 20;
111
+ _context.next = 23;
110
112
  return (0, _fileUtils.removeDir)(this.tilesetPath);
111
- case 24:
112
- _context.next = 28;
113
+ case 23:
114
+ _context.next = 27;
113
115
  break;
114
- case 26:
115
- _context.prev = 26;
116
- _context.t0 = _context["catch"](21);
117
- case 28:
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.header.obb, this.geoidHeightModel)
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 = 31;
127
+ _context.next = 30;
126
128
  return this._addChildren(rootNode, rootTile, 1);
127
- case 31:
129
+ case 30:
128
130
  tileset = (0, _jsonMapTransform.default)({
129
131
  root: rootTile
130
132
  }, (0, _tileset.TILESET)());
131
- _context.next = 34;
133
+ _context.next = 33;
132
134
  return (0, _fileUtils.writeFile)(this.tilesetPath, JSON.stringify(tileset), 'tileset.json');
133
- case 34:
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 37:
143
+ case 36:
142
144
  case "end":
143
145
  return _context.stop();
144
146
  }
145
- }, _callee, this, [[21, 26]]);
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, _sourceChild$header, featureAttributes, boundingVolume, child, i3sAttributesData, b3dmConverter, b3dm;
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 = 30;
167
+ _context2.next = 33;
167
168
  break;
168
169
  }
169
- _context2.next = 7;
170
- return this.sourceTileset._loadTile(sourceChild);
171
- case 7:
172
- this.vertexCounter += sourceChild.content.vertexCount;
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 = 13;
186
+ _context2.next = 17;
176
187
  break;
177
188
  }
178
- _context2.next = 12;
189
+ _context2.next = 16;
179
190
  return this._loadChildAttributes(sourceChild, this.attributeStorageInfo);
180
- case 12:
191
+ case 16:
181
192
  featureAttributes = _context2.sent;
182
- case 13:
183
- if (!sourceChild.header.obb) {
184
- sourceChild.header.obb = (0, _coordinateConverter.createObbFromMbs)(sourceChild.header.mbs);
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.header.obb, this.geoidHeightModel)
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: sourceChild.content,
196
- textureFormat: sourceChild === null || sourceChild === void 0 ? void 0 : (_sourceChild$header = sourceChild.header) === null || _sourceChild$header === void 0 ? void 0 : _sourceChild$header.textureFormat
206
+ tileContent: content,
207
+ box: boundingVolume.box,
208
+ textureFormat: sourceChild.textureFormat
197
209
  };
198
210
  b3dmConverter = new _b3dmConverter.default();
199
- _context2.next = 20;
211
+ _context2.next = 24;
200
212
  return b3dmConverter.convert(i3sAttributesData, featureAttributes);
201
- case 20:
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 = 24;
219
+ _context2.next = 28;
208
220
  return (0, _fileUtils.writeFile)(this.tilesetPath, new Uint8Array(b3dm), "".concat(sourceChild.id, ".b3dm"));
209
- case 24:
221
+ case 28:
210
222
  parentNode.children.push(child);
211
- sourceChild.unloadContent();
212
- _context2.next = 28;
223
+ _context2.next = 31;
213
224
  return this._addChildren(sourceChild, child, level + 1);
214
- case 28:
215
- _context2.next = 32;
225
+ case 31:
226
+ _context2.next = 35;
216
227
  break;
217
- case 30:
218
- _context2.next = 32;
228
+ case 33:
229
+ _context2.next = 35;
219
230
  return this._addChildren(sourceChild, parentNode, level + 1);
220
- case 32:
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.header.children || []);
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 header, _ref, loader, nodeUrl, options;
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.tileset.nodePages) {
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.tileset.nodePagesTile.formTileFromNodePages(childNodeInfo.id);
296
+ return this.sourceTileset.nodePagesTile.formTileFromNodePages(parseInt(childNodeInfo.id));
285
297
  case 4:
286
298
  header = _context4.sent;
287
- _context4.next = 14;
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.sourceTileset.loadOptions), {}, {
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 = 13;
300
- return (0, _core.load)(nodeUrl, loader, options);
301
- case 13:
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(baseUrl, relativeUrl) {
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
- attributeUrls = sourceChild.header.attributeUrls;
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":";;;;;;;;;;;;;AAQA,IAAAA,KAAA,GAAAC,OAAA;AACA,IAAAC,QAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,KAAA,GAAAJ,OAAA;AACA,IAAAK,IAAA,GAAAL,OAAA;AAGA,IAAAM,UAAA,GAAAN,OAAA;AACA,IAAAO,mBAAA,GAAAP,OAAA;AACA,IAAAQ,mBAAA,GAAAR,OAAA;AACA,IAAAS,UAAA,GAAAT,OAAA;AACA,IAAAU,gBAAA,GAAAV,OAAA;AACA,IAAAW,QAAA,GAAAX,OAAA;AACA,IAAAY,oBAAA,GAAAZ,OAAA;AACA,IAAAa,YAAA,GAAAb,OAAA;AACA,IAAAc,UAAA,GAAAd,OAAA;AACA,IAAAe,cAAA,GAAAb,sBAAA,CAAAF,OAAA;AAEA,IAAAgB,QAAA,GAAAhB,OAAA;AAAkD,SAAAiB,QAAAC,MAAA,EAAAC,cAAA,QAAAC,IAAA,GAAAC,MAAA,CAAAD,IAAA,CAAAF,MAAA,OAAAG,MAAA,CAAAC,qBAAA,QAAAC,OAAA,GAAAF,MAAA,CAAAC,qBAAA,CAAAJ,MAAA,GAAAC,cAAA,KAAAI,OAAA,GAAAA,OAAA,CAAAC,MAAA,WAAAC,GAAA,WAAAJ,MAAA,CAAAK,wBAAA,CAAAR,MAAA,EAAAO,GAAA,EAAAE,UAAA,OAAAP,IAAA,CAAAQ,IAAA,CAAAC,KAAA,CAAAT,IAAA,EAAAG,OAAA,YAAAH,IAAA;AAAA,SAAAU,cAAAC,MAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAC,SAAA,CAAAC,MAAA,EAAAF,CAAA,UAAAG,MAAA,WAAAF,SAAA,CAAAD,CAAA,IAAAC,SAAA,CAAAD,CAAA,QAAAA,CAAA,OAAAf,OAAA,CAAAI,MAAA,CAAAc,MAAA,OAAAC,OAAA,WAAAC,GAAA,QAAAC,gBAAA,CAAAC,OAAA,EAAAR,MAAA,EAAAM,GAAA,EAAAF,MAAA,CAAAE,GAAA,SAAAhB,MAAA,CAAAmB,yBAAA,GAAAnB,MAAA,CAAAoB,gBAAA,CAAAV,MAAA,EAAAV,MAAA,CAAAmB,yBAAA,CAAAL,MAAA,KAAAlB,OAAA,CAAAI,MAAA,CAAAc,MAAA,GAAAC,OAAA,WAAAC,GAAA,IAAAhB,MAAA,CAAAqB,cAAA,CAAAX,MAAA,EAAAM,GAAA,EAAAhB,MAAA,CAAAK,wBAAA,CAAAS,MAAA,EAAAE,GAAA,iBAAAN,MAAA;AAAA,SAAAY,2BAAAC,CAAA,EAAAC,cAAA,QAAAC,EAAA,UAAAC,MAAA,oBAAAH,CAAA,CAAAG,MAAA,CAAAC,QAAA,KAAAJ,CAAA,qBAAAE,EAAA,QAAAG,KAAA,CAAAC,OAAA,CAAAN,CAAA,MAAAE,EAAA,GAAAK,2BAAA,CAAAP,CAAA,MAAAC,cAAA,IAAAD,CAAA,WAAAA,CAAA,CAAAV,MAAA,qBAAAY,EAAA,EAAAF,CAAA,GAAAE,EAAA,MAAAd,CAAA,UAAAoB,CAAA,YAAAA,EAAA,eAAAC,CAAA,EAAAD,CAAA,EAAAE,CAAA,WAAAA,EAAA,QAAAtB,CAAA,IAAAY,CAAA,CAAAV,MAAA,WAAAqB,IAAA,mBAAAA,IAAA,SAAAC,KAAA,EAAAZ,CAAA,CAAAZ,CAAA,UAAAyB,CAAA,WAAAA,EAAAC,EAAA,UAAAA,EAAA,KAAAC,CAAA,EAAAP,CAAA,gBAAAQ,SAAA,iJAAAC,gBAAA,SAAAC,MAAA,UAAAC,GAAA,WAAAV,CAAA,WAAAA,EAAA,IAAAP,EAAA,GAAAA,EAAA,CAAAkB,IAAA,CAAApB,CAAA,MAAAU,CAAA,WAAAA,EAAA,QAAAW,IAAA,GAAAnB,EAAA,CAAAoB,IAAA,IAAAL,gBAAA,GAAAI,IAAA,CAAAV,IAAA,SAAAU,IAAA,KAAAR,CAAA,WAAAA,EAAAU,GAAA,IAAAL,MAAA,SAAAC,GAAA,GAAAI,GAAA,KAAAR,CAAA,WAAAA,EAAA,eAAAE,gBAAA,IAAAf,EAAA,CAAAsB,MAAA,UAAAtB,EAAA,CAAAsB,MAAA,oBAAAN,MAAA,QAAAC,GAAA;AAAA,SAAAZ,4BAAAP,CAAA,EAAAyB,MAAA,SAAAzB,CAAA,qBAAAA,CAAA,sBAAA0B,iBAAA,CAAA1B,CAAA,EAAAyB,MAAA,OAAAf,CAAA,GAAAjC,MAAA,CAAAkD,SAAA,CAAAC,QAAA,CAAAR,IAAA,CAAApB,CAAA,EAAA6B,KAAA,aAAAnB,CAAA,iBAAAV,CAAA,CAAA8B,WAAA,EAAApB,CAAA,GAAAV,CAAA,CAAA8B,WAAA,CAAAC,IAAA,MAAArB,CAAA,cAAAA,CAAA,mBAAAL,KAAA,CAAA2B,IAAA,CAAAhC,CAAA,OAAAU,CAAA,+DAAAuB,IAAA,CAAAvB,CAAA,UAAAgB,iBAAA,CAAA1B,CAAA,EAAAyB,MAAA;AAAA,SAAAC,kBAAAQ,GAAA,EAAAC,GAAA,QAAAA,GAAA,YAAAA,GAAA,GAAAD,GAAA,CAAA5C,MAAA,EAAA6C,GAAA,GAAAD,GAAA,CAAA5C,MAAA,WAAAF,CAAA,MAAAgD,IAAA,OAAA/B,KAAA,CAAA8B,GAAA,GAAA/C,CAAA,GAAA+C,GAAA,EAAA/C,CAAA,IAAAgD,IAAA,CAAAhD,CAAA,IAAA8C,GAAA,CAAA9C,CAAA,UAAAgD,IAAA;AAGlD,IAAMC,GAAG,GAAG,KAAK;AAAC,IAKGC,gBAAgB;EAmBnC,SAAAA,iBAAA,EAAc;IAAA,IAAAC,gBAAA,CAAA5C,OAAA,QAAA2C,gBAAA;IAAA,IAAA5C,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA,wBAX0B,CAAC,CAAC;IAAA,IAAAD,gBAAA,CAAAC,OAAA,yBACR;MAChC6C,YAAY,EAAE,IAAI;MAClBC,YAAY,EAAE,IAAI;MAClBC,GAAG,EAAE;QAACC,gBAAgB,EAAEC,sBAAiB,CAACC,cAAc;QAAEC,cAAc,EAAE;MAAK,CAAC;MAEhF,aAAa,EAAE;QACbC,SAAS,EAAE;MACb;IACF,CAAC;IAGC,IAAI,CAACC,OAAO,GAAG,CAAC,CAAC;IACjB,IAAI,CAACC,WAAW,GAAG,EAAE;IACrB,IAAI,CAACC,aAAa,GAAG,CAAC;IACtB,IAAI,CAACC,mBAAmB,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;IACjC,IAAI,CAACC,gBAAgB,GAAG,IAAI;IAC5B,IAAI,CAACC,aAAa,GAAG,IAAI;IACzB,IAAI,CAACC,oBAAoB,GAAG,IAAI;IAChC,IAAI,CAACC,YAAY,GAAG,CAAC,CAAC;EACxB;EAAC,IAAAC,aAAA,CAAA7D,OAAA,EAAA2C,gBAAA;IAAA7C,GAAA;IAAAmB,KAAA;MAAA,IAAA6C,QAAA,OAAAC,kBAAA,CAAA/D,OAAA,EAAAgE,YAAA,CAAAhE,OAAA,CAAAiE,IAAA,CAWD,SAAAC,QAAqBb,OAMpB;QAAA,IAAAc,mBAAA;QAAA,IAAAC,QAAA,EAAAC,UAAA,EAAAC,WAAA,EAAAC,QAAA,EAAAC,WAAA,EAAAC,QAAA,EAAAC,QAAA,EAAAC,OAAA,EAAAC,UAAA;QAAA,OAAAZ,YAAA,CAAAhE,OAAA,CAAA6E,IAAA,UAAAC,SAAAC,QAAA;UAAA,kBAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAApD,IAAA;YAAA;cAAA,KACKsD,eAAS;gBAAAF,QAAA,CAAApD,IAAA;gBAAA;cAAA;cACXuD,OAAO,CAACC,GAAG,CAACC,gCAAqB,CAAC;cAAC,OAAAL,QAAA,CAAAM,MAAA,WAC5BD,gCAAqB;YAAA;cAEvBhB,QAAQ,GAAoDf,OAAO,CAAnEe,QAAQ,EAAEC,UAAU,GAAwChB,OAAO,CAAzDgB,UAAU,EAAEC,WAAW,GAA2BjB,OAAO,CAA7CiB,WAAW,EAAEC,QAAQ,GAAiBlB,OAAO,CAAhCkB,QAAQ,EAAEC,WAAW,GAAInB,OAAO,CAAtBmB,WAAW;cAC/D,IAAI,CAAChB,mBAAmB,GAAG8B,gBAAO,CAACC,MAAM,CAAC,CAAC;cAC3C,IAAI,CAAClC,OAAO,GAAG;gBAACkB,QAAQ,EAARA;cAAQ,CAAC;cAEzBW,OAAO,CAACC,GAAG,CAAC,qBAAqB,CAAC;cAACJ,QAAA,CAAApD,IAAA;cAAA,OACL,IAAA6D,UAAI,EAAChB,WAAW,EAAEiB,oBAAS,CAAC;YAAA;cAA1D,IAAI,CAAChC,gBAAgB,GAAAsB,QAAA,CAAAW,IAAA;cACrBR,OAAO,CAACC,GAAG,CAAC,6BAA6B,CAAC;cAACJ,QAAA,CAAApD,IAAA;cAAA,OAEhB,IAAA6D,UAAI,EAACpB,QAAQ,EAAEuB,cAAS,EAAE,IAAI,CAACC,aAAa,CAAC;YAAA;cAAxE,IAAI,CAAClC,aAAa,GAAAqB,QAAA,CAAAW,IAAA;cAAA,IAEb,IAAI,CAAChC,aAAa;gBAAAqB,QAAA,CAAApD,IAAA;gBAAA;cAAA;cAAA,OAAAoD,QAAA,CAAAM,MAAA;YAAA;cAIjBZ,QAAQ,IAAAN,mBAAA,GAAG,IAAI,CAACT,aAAa,cAAAS,mBAAA,uBAAlBA,mBAAA,CAAoB0B,IAAI;cACzC,IAAI,CAACpB,QAAQ,CAACqB,GAAG,EAAE;gBACjBrB,QAAQ,CAACqB,GAAG,GAAG,IAAAC,qCAAgB,EAACtB,QAAQ,CAACuB,GAAG,CAAC;cAC/C;cAEA,IAAI,CAAC1C,WAAW,GAAG,IAAA2C,UAAI,KAAAC,MAAA,CAAI7B,UAAU,MAAA6B,MAAA,CAAO5B,WAAW,CAAE,CAAC;cAC1D,IAAI,CAACX,oBAAoB,GAAG,IAAI,CAACD,aAAa,CAACC,oBAAoB;cAACoB,QAAA,CAAAC,IAAA;cAAAD,QAAA,CAAApD,IAAA;cAAA,OAG5D,IAAAwE,oBAAS,EAAC,IAAI,CAAC7C,WAAW,CAAC;YAAA;cAAAyB,QAAA,CAAApD,IAAA;cAAA;YAAA;cAAAoD,QAAA,CAAAC,IAAA;cAAAD,QAAA,CAAAqB,EAAA,GAAArB,QAAA;YAAA;cAK7BL,QAAyB,GAAG;gBAChC2B,cAAc,EAAE;kBACdC,GAAG,EAAE,IAAAC,sCAAkB,EAAC9B,QAAQ,CAACqB,GAAG,EAAE,IAAI,CAACrC,gBAAgB;gBAC7D,CAAC;gBACD+C,cAAc,EAAE,IAAAC,0DAAsC,EAAChC,QAAQ,CAAC;gBAChEiC,QAAQ,EAAE;cACZ,CAAC;cAAA3B,QAAA,CAAApD,IAAA;cAAA,OAEK,IAAI,CAACgF,YAAY,CAAClC,QAAQ,EAAEC,QAAQ,EAAE,CAAC,CAAC;YAAA;cAExCC,OAAO,GAAG,IAAAiC,yBAAS,EAAC;gBAACf,IAAI,EAAEnB;cAAQ,CAAC,EAAE,IAAAmC,gBAAe,EAAC,CAAC,CAAC;cAAA9B,QAAA,CAAApD,IAAA;cAAA,OACxD,IAAAmF,oBAAS,EAAC,IAAI,CAACxD,WAAW,EAAEyD,IAAI,CAACC,SAAS,CAACrC,OAAO,CAAC,EAAE,cAAc,CAAC;YAAA;cAE1E,IAAI,CAACsC,iBAAiB,CAAC;gBAACC,IAAI,EAAE,KAAK;gBAAE7C,UAAU,EAAVA,UAAU;gBAAEC,WAAW,EAAXA;cAAW,CAAC,CAAC;cAGxDM,UAAU,GAAGuC,uBAAU,CAACC,aAAa,CAAC,CAAC,CAAC,CAAC;cAC/CxC,UAAU,CAACyC,OAAO,CAAC,CAAC;YAAC;YAAA;cAAA,OAAAtC,QAAA,CAAAuC,IAAA;UAAA;QAAA,GAAApD,OAAA;MAAA,CACtB;MAAA,SAAAqD,QAAAC,EAAA;QAAA,OAAA1D,QAAA,CAAAxE,KAAA,OAAAI,SAAA;MAAA;MAAA,OAAA6H,OAAA;IAAA;EAAA;IAAAzH,GAAA;IAAAmB,KAAA;MAAA,IAAAwG,iBAAA,OAAA1D,kBAAA,CAAA/D,OAAA,EAAAgE,YAAA,CAAAhE,OAAA,CAAAiE,IAAA,CASD,SAAAyD,SACEC,gBAA+B,EAC/BC,UAA2B,EAC3BC,KAAa,EACbC,aAA4B;QAAA,IAAAC,WAAA,EAAAC,OAAA,EAAAC,iBAAA,EAAA5B,cAAA,EAAA6B,KAAA,EAAAC,iBAAA,EAAAC,aAAA,EAAAC,IAAA;QAAA,OAAArE,YAAA,CAAAhE,OAAA,CAAA6E,IAAA,UAAAyD,UAAAC,SAAA;UAAA,kBAAAA,SAAA,CAAAvD,IAAA,GAAAuD,SAAA,CAAA5G,IAAA;YAAA;cAAA4G,SAAA,CAAA5G,IAAA;cAAA,OAEF,IAAI,CAAC6G,cAAc,CAACb,gBAAgB,EAAEG,aAAa,CAAC;YAAA;cAAxEC,WAAW,GAAAQ,SAAA,CAAA7C,IAAA;cAAA,KACbqC,WAAW,CAACU,UAAU;gBAAAF,SAAA,CAAA5G,IAAA;gBAAA;cAAA;cAAA4G,SAAA,CAAA5G,IAAA;cAAA,OACF,IAAA+G,uBAAc,EAAC,IAAI,CAAChF,aAAa,EAAEqE,WAAW,EAAE,IAAI,CAACnC,aAAa,CAAC;YAAA;cAAnFoC,OAAO,GAAAO,SAAA,CAAA7C,IAAA;cAAA,IAERsC,OAAO;gBAAAO,SAAA,CAAA5G,IAAA;gBAAA;cAAA;cAAA4G,SAAA,CAAA5G,IAAA;cAAA,OACJ,IAAI,CAACgF,YAAY,CAACoB,WAAW,EAAEH,UAAU,EAAEC,KAAK,GAAG,CAAC,CAAC;YAAA;cAAA,OAAAU,SAAA,CAAAlD,MAAA;YAAA;cAI7D,IAAI,CAAC9B,aAAa,IAAI,CAAAyE,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEW,WAAW,KAAI,CAAC;cAE3CV,iBAA0C,GAAG,IAAI;cAAA,KACjD,IAAI,CAACtE,oBAAoB;gBAAA4E,SAAA,CAAA5G,IAAA;gBAAA;cAAA;cAAA4G,SAAA,CAAA5G,IAAA;cAAA,OACD,IAAI,CAACiH,oBAAoB,CAACb,WAAW,EAAE,IAAI,CAACpE,oBAAoB,CAAC;YAAA;cAA3FsE,iBAAiB,GAAAM,SAAA,CAAA7C,IAAA;YAAA;cAGnB,IAAI,CAACqC,WAAW,CAACjC,GAAG,EAAE;gBACpBiC,WAAW,CAACjC,GAAG,GAAG,IAAAC,qCAAgB,EAACgC,WAAW,CAAC/B,GAAG,CAAC;cACrD;cAEMK,cAAc,GAAG;gBACrBC,GAAG,EAAE,IAAAC,sCAAkB,EAACwB,WAAW,CAACjC,GAAG,EAAE,IAAI,CAACrC,gBAAgB;cAChE,CAAC;cACKyE,KAAsB,GAAG;gBAC7B7B,cAAc,EAAdA,cAAc;gBACdG,cAAc,EAAE,IAAAC,0DAAsC,EAACsB,WAAW,CAAC;gBACnErB,QAAQ,EAAE;cACZ,CAAC;cAEKyB,iBAAoC,GAAG;gBAC3CU,WAAW,EAAEb,OAAO;gBACpB1B,GAAG,EAAED,cAAc,CAACC,GAAG;gBACvBwC,aAAa,EAAEf,WAAW,CAACe;cAC7B,CAAC;cAEKV,aAAa,GAAG,IAAIW,sBAAa,CAAC,CAAC;cAAAR,SAAA,CAAA5G,IAAA;cAAA,OACtByG,aAAa,CAACb,OAAO,CAACY,iBAAiB,EAAEF,iBAAiB,CAAC;YAAA;cAAxEI,IAAI,GAAAE,SAAA,CAAA7C,IAAA;cAEVwC,KAAK,CAACF,OAAO,GAAG;gBACdgB,GAAG,KAAA9C,MAAA,CAAK6B,WAAW,CAACkB,EAAE,UAAO;gBAC7B5C,cAAc,EAAdA;cACF,CAAC;cAACkC,SAAA,CAAA5G,IAAA;cAAA,OACI,IAAAmF,oBAAS,EAAC,IAAI,CAACxD,WAAW,EAAE,IAAI4F,UAAU,CAACb,IAAI,CAAC,KAAAnC,MAAA,CAAK6B,WAAW,CAACkB,EAAE,UAAO,CAAC;YAAA;cACjFrB,UAAU,CAAClB,QAAQ,CAACrH,IAAI,CAAC6I,KAAK,CAAC;cAACK,SAAA,CAAA5G,IAAA;cAAA,OAE1B,IAAI,CAACgF,YAAY,CAACoB,WAAW,EAAEG,KAAK,EAAEL,KAAK,GAAG,CAAC,CAAC;YAAA;cAAAU,SAAA,CAAA5G,IAAA;cAAA;YAAA;cAAA4G,SAAA,CAAA5G,IAAA;cAAA,OAEhD,IAAI,CAACgF,YAAY,CAACoB,WAAW,EAAEH,UAAU,EAAEC,KAAK,GAAG,CAAC,CAAC;YAAA;YAAA;cAAA,OAAAU,SAAA,CAAAjB,IAAA;UAAA;QAAA,GAAAI,QAAA;MAAA,CAE9D;MAAA,SAAAyB,iBAAAC,GAAA,EAAAC,GAAA,EAAAC,GAAA,EAAAC,GAAA;QAAA,OAAA9B,iBAAA,CAAAnI,KAAA,OAAAI,SAAA;MAAA;MAAA,OAAAyJ,gBAAA;IAAA;EAAA;IAAArJ,GAAA;IAAAmB,KAAA;MAAA,IAAAuI,aAAA,OAAAzF,kBAAA,CAAA/D,OAAA,EAAAgE,YAAA,CAAAhE,OAAA,CAAAiE,IAAA,CAQD,SAAAwF,SACE9B,gBAA+B,EAC/BC,UAA2B,EAC3BC,KAAa;QAAA,IAAA6B,QAAA,EAAAC,SAAA,EAAAC,KAAA,EAAA9B,aAAA;QAAA,OAAA9D,YAAA,CAAAhE,OAAA,CAAA6E,IAAA,UAAAgF,UAAAC,SAAA;UAAA,kBAAAA,SAAA,CAAA9E,IAAA,GAAA8E,SAAA,CAAAnI,IAAA;YAAA;cAAA,MAET,IAAI,CAAC0B,OAAO,CAACkB,QAAQ,IAAIsD,KAAK,GAAG,IAAI,CAACxE,OAAO,CAACkB,QAAQ;gBAAAuF,SAAA,CAAAnI,IAAA;gBAAA;cAAA;cAAA,OAAAmI,SAAA,CAAAzE,MAAA;YAAA;cAGpDqE,QAAyB,GAAG,EAAE;cAAAC,SAAA,GAAAvJ,0BAAA,CACRuH,gBAAgB,CAACjB,QAAQ,IAAI,EAAE;cAAA;gBAA3D,KAAAiD,SAAA,CAAA7I,CAAA,MAAA8I,KAAA,GAAAD,SAAA,CAAA5I,CAAA,IAAAC,IAAA,GAA6D;kBAAlD8G,aAAa,GAAA8B,KAAA,CAAA3I,KAAA;kBACtByI,QAAQ,CAACrK,IAAI,CAAC,IAAI,CAAC8J,gBAAgB,CAACxB,gBAAgB,EAAEC,UAAU,EAAEC,KAAK,EAAEC,aAAa,CAAC,CAAC;gBAC1F;cAAC,SAAAtG,GAAA;gBAAAmI,SAAA,CAAAzI,CAAA,CAAAM,GAAA;cAAA;gBAAAmI,SAAA,CAAAvI,CAAA;cAAA;cAAA0I,SAAA,CAAAnI,IAAA;cAAA,OACKoI,OAAO,CAACC,GAAG,CAACN,QAAQ,CAAC;YAAA;YAAA;cAAA,OAAAI,SAAA,CAAAxC,IAAA;UAAA;QAAA,GAAAmC,QAAA;MAAA,CAC5B;MAAA,SAAA9C,aAAAsD,GAAA,EAAAC,GAAA,EAAAC,GAAA;QAAA,OAAAX,aAAA,CAAAlK,KAAA,OAAAI,SAAA;MAAA;MAAA,OAAAiH,YAAA;IAAA;EAAA;IAAA7G,GAAA;IAAAmB,KAAA;MAAA,IAAAmJ,eAAA,OAAArG,kBAAA,CAAA/D,OAAA,EAAAgE,YAAA,CAAAhE,OAAA,CAAAiE,IAAA,CAQD,SAAAoG,SACEzC,UAAyB,EACzBE,aAA4B;QAAA,IAAAwC,oBAAA;QAAA,IAAAC,MAAA,EAAAC,OAAA,EAAAnH,OAAA;QAAA,OAAAW,YAAA,CAAAhE,OAAA,CAAA6E,IAAA,UAAA4F,UAAAC,SAAA;UAAA,kBAAAA,SAAA,CAAA1F,IAAA,GAAA0F,SAAA,CAAA/I,IAAA;YAAA;cAAA,OAAA2I,oBAAA,GAGxB,IAAI,CAAC5G,aAAa,cAAA4G,oBAAA,eAAlBA,oBAAA,CAAoBK,aAAa;gBAAAD,SAAA,CAAA/I,IAAA;gBAAA;cAAA;cACnCuD,OAAO,CAACC,GAAG,qBAAAe,MAAA,CAAqB4B,aAAa,CAACmB,EAAE,CAAE,CAAC;cAACyB,SAAA,CAAA/I,IAAA;cAAA,OACrC,IAAI,CAAC+B,aAAa,CAACiH,aAAa,CAACC,qBAAqB,CACnEC,QAAQ,CAAC/C,aAAa,CAACmB,EAAE,CAC3B,CAAC;YAAA;cAFDsB,MAAM,GAAAG,SAAA,CAAAhF,IAAA;cAAAgF,SAAA,CAAA/I,IAAA;cAAA;YAAA;cAIA6I,OAAO,GAAG,IAAI,CAACM,qBAAqB,CAAClD,UAAU,CAACmD,GAAG,EAAEjD,aAAa,CAACkD,IAAK,CAAC;cAEzE3H,OAAO,GAAG;gBACdN,GAAG,EAAAxD,aAAA,CAAAA,aAAA,KACE,IAAI,CAACqG,aAAa;kBACrBqF,YAAY,EAAE,IAAI;kBAClBC,WAAW,EAAE;gBAAK;cAEtB,CAAC;cAEDhG,OAAO,CAACC,GAAG,qBAAAe,MAAA,CAAqBsE,OAAO,CAAE,CAAC;cAACE,SAAA,CAAA/I,IAAA;cAAA,OAC5B,IAAA6D,UAAI,EAACgF,OAAO,EAAE7E,cAAS,EAAEtC,OAAO,CAAC;YAAA;cAAhDkH,MAAM,GAAAG,SAAA,CAAAhF,IAAA;YAAA;cAAA,OAAAgF,SAAA,CAAArF,MAAA,WAEDkF,MAAM;YAAA;YAAA;cAAA,OAAAG,SAAA,CAAApD,IAAA;UAAA;QAAA,GAAA+C,QAAA;MAAA,CACd;MAAA,SAAA7B,eAAA2C,GAAA,EAAAC,IAAA;QAAA,OAAAhB,eAAA,CAAA9K,KAAA,OAAAI,SAAA;MAAA;MAAA,OAAA8I,cAAA;IAAA;EAAA;IAAA1I,GAAA;IAAAmB,KAAA,EAOD,SAAA6J,sBAAA,EAAiF;MAAA,IAAnDO,OAAe,GAAA3L,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAA4L,SAAA,GAAA5L,SAAA,MAAG,EAAE;MAAA,IAAE6L,WAAmB,GAAA7L,SAAA,CAAAC,MAAA,OAAAD,SAAA,MAAA4L,SAAA;MACrE,IAAIE,WAAW,GAAGH,OAAO,CAACI,KAAK,CAAC,GAAG,CAAC;MACpC,IAAMC,gBAAgB,GAAGH,WAAW,CAACE,KAAK,CAAC,GAAG,CAAC;MAAC,IAAAE,UAAA,GAAAvL,0BAAA,CAC3BsL,gBAAgB;QAAAE,MAAA;MAAA;QAArC,KAAAD,UAAA,CAAA7K,CAAA,MAAA8K,MAAA,GAAAD,UAAA,CAAA5K,CAAA,IAAAC,IAAA,GAAuC;UAAA,IAA5B6K,MAAM,GAAAD,MAAA,CAAA3K,KAAA;UACf,QAAQ4K,MAAM;YACZ,KAAK,GAAG;cACN;YACF,KAAK,IAAI;cACPL,WAAW,GAAGA,WAAW,CAACtJ,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;cACtC;YACF;cACEsJ,WAAW,CAACnM,IAAI,CAACwM,MAAM,CAAC;UAC5B;QACF;MAAC,SAAArK,GAAA;QAAAmK,UAAA,CAAAzK,CAAA,CAAAM,GAAA;MAAA;QAAAmK,UAAA,CAAAvK,CAAA;MAAA;MACD,OAAOoK,WAAW,CAACvF,IAAI,CAAC,GAAG,CAAC;IAC9B;EAAC;IAAAnG,GAAA;IAAAmB,KAAA;MAAA,IAAA6K,qBAAA,OAAA/H,kBAAA,CAAA/D,OAAA,EAAAgE,YAAA,CAAAhE,OAAA,CAAAiE,IAAA,CAQD,SAAA8H,SACEhE,WAA0B,EAC1BpE,oBAA4C;QAAA,IAAA+F,QAAA,EAAAsC,qBAAA,EAAAC,aAAA,EAAAC,KAAA,EAAA9H,QAAA,EAAA+H,SAAA,EAAA9I,OAAA,EAAA+I,cAAA;QAAA,OAAApI,YAAA,CAAAhE,OAAA,CAAA6E,IAAA,UAAAwH,UAAAC,SAAA;UAAA,kBAAAA,SAAA,CAAAtH,IAAA,GAAAsH,SAAA,CAAA3K,IAAA;YAAA;cAEtC+H,QAAe,GAAG,EAAE;cAAAsC,qBAAA,GACGjE,WAAW,CAAjCkE,aAAa,EAAbA,aAAa,GAAAD,qBAAA,cAAG,EAAE,GAAAA,qBAAA;cAEzB,KAASE,KAAK,GAAG,CAAC,EAAEA,KAAK,GAAGD,aAAa,CAACtM,MAAM,EAAEuM,KAAK,EAAE,EAAE;gBACnD9H,QAAQ,GAAG6H,aAAa,CAACC,KAAK,CAAC;gBAC/BC,SAAS,GAAGxI,oBAAoB,CAACuI,KAAK,CAAC;gBACvC7I,OAAO,GAAG;kBACdkJ,aAAa,EAAEJ,SAAS,CAAC/J,IAAI;kBAC7BoK,aAAa,EAAE,IAAI,CAACC,iBAAiB,CAACN,SAAS;gBACjD,CAAC;gBAEDzC,QAAQ,CAACrK,IAAI,CAAC,IAAAmG,UAAI,EAACpB,QAAQ,EAAEsI,uBAAkB,EAAErJ,OAAO,CAAC,CAAC;cAC5D;cAACiJ,SAAA,CAAA3K,IAAA;cAAA,OAC4BoI,OAAO,CAACC,GAAG,CAACN,QAAQ,CAAC;YAAA;cAA5C0C,cAAc,GAAAE,SAAA,CAAA5G,IAAA;cACpB,IAAI,CAACiH,oBAAoB,CAACP,cAAc,CAAC;cAAC,OAAAE,SAAA,CAAAjH,MAAA,WACnCvG,MAAM,CAAC8N,MAAM,CAAAtN,KAAA,CAAbR,MAAM,GAAQ,CAAC,CAAC,EAAAoH,MAAA,KAAA2G,mBAAA,CAAA7M,OAAA,EAAKoM,cAAc,GAAC;YAAA;YAAA;cAAA,OAAAE,SAAA,CAAAhF,IAAA;UAAA;QAAA,GAAAyE,QAAA;MAAA,CAC5C;MAAA,SAAAnD,qBAAAkE,IAAA,EAAAC,IAAA;QAAA,OAAAjB,qBAAA,CAAAxM,KAAA,OAAAI,SAAA;MAAA;MAAA,OAAAkJ,oBAAA;IAAA;EAAA;IAAA9I,GAAA;IAAAmB,KAAA,EASD,SAAAwL,kBAA0BN,SAA+B,EAAU;MACjE,IAAIA,SAAS,CAACa,eAAe,EAAE;QAC7B,OAAOb,SAAS,CAACa,eAAe,CAACC,SAAS;MAC5C,CAAC,MAAM,IAAId,SAAS,CAACe,SAAS,EAAE;QAC9B,OAAO,OAAO;MAChB;MACA,OAAO,EAAE;IACX;EAAC;IAAApN,GAAA;IAAAmB,KAAA,EAMD,SAAA0L,qBAA6BP,cAAkC,EAAQ;MACrE,KAAK,IAAIF,KAAK,GAAG,CAAC,EAAEA,KAAK,GAAGE,cAAc,CAACzM,MAAM,EAAEuM,KAAK,EAAE,EAAE;QAC1D,IAAMiB,eAAe,GAAGf,cAAc,CAACF,KAAK,CAAC;QAE7C,KAAK,IAAMpM,IAAG,IAAIqN,eAAe,EAAE;UACjCA,eAAe,CAACrN,IAAG,CAAC,GAAGY,KAAK,CAAC2B,IAAI,CAAC8K,eAAe,CAACrN,IAAG,CAAC,CAAC;QACzD;MACF;IACF;EAAC;IAAAA,GAAA;IAAAmB,KAAA;MAAA,IAAAmM,kBAAA,OAAArJ,kBAAA,CAAA/D,OAAA,EAAAgE,YAAA,CAAAhE,OAAA,CAAAiE,IAAA,CAMD,SAAAoJ,SAAgCC,MAI/B;QAAA,IAAAC,SAAA,EAAAC,IAAA,EAAAC,cAAA;QAAA,OAAAzJ,YAAA,CAAAhE,OAAA,CAAA6E,IAAA,UAAA6I,UAAAC,SAAA;UAAA,kBAAAA,SAAA,CAAA3I,IAAA,GAAA2I,SAAA,CAAAhM,IAAA;YAAA;cAAAgM,SAAA,CAAAhM,IAAA;cAAA,OACyB,IAAAiM,mCAAkB,EAACN,MAAM,CAAC;YAAA;cAA5CC,SAAS,GAAAI,SAAA,CAAAjI,IAAA;cACT8H,IAAI,GAAGlI,gBAAO,CAACC,MAAM,CAAC,IAAI,CAAC/B,mBAAmB,CAAC;cAC/CiK,cAAc,GAAG,IAAAI,8BAAa,EAACL,IAAI,CAAC;cAE1CtI,OAAO,CAACC,GAAG,mDAAmD,CAAC;cAC/DD,OAAO,CAACC,GAAG,yBAAAe,MAAA,CAAyBxD,GAAG,CAAE,CAAC;cAC1CwC,OAAO,CAACC,GAAG,2BAAAe,MAAA,CAA2BuH,cAAc,CAAE,CAAC;cACvDvI,OAAO,CAACC,GAAG,mBAAmB,IAAI,CAAC5B,aAAa,CAAC;cACjD2B,OAAO,CAACC,GAAG,mBAAmBoI,SAAS,EAAE,QAAQ,CAAC;cAClDrI,OAAO,CAACC,GAAG,mDAAmD,CAAC;YAAC;YAAA;cAAA,OAAAwI,SAAA,CAAArG,IAAA;UAAA;QAAA,GAAA+F,QAAA;MAAA,CACjE;MAAA,SAAApG,kBAAA6G,IAAA;QAAA,OAAAV,kBAAA,CAAA9N,KAAA,OAAAI,SAAA;MAAA;MAAA,OAAAuH,iBAAA;IAAA;EAAA;EAAA,OAAAtE,gBAAA;AAAA;AAAAoL,OAAA,CAAA/N,OAAA,GAAA2C,gBAAA"}
@@ -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, cartesianOrigin, cartographicOrigin, modelMatrix, gltfBuilder, textureIndex, pbrMaterialInfo, materialIndex, positions, positionsValue, indices, meshIndex, transformMatrix, nodeIndex, sceneIndex, gltfBuffer;
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, cartesianOrigin = tileContent.cartesianOrigin, cartographicOrigin = tileContent.cartographicOrigin, modelMatrix = tileContent.modelMatrix;
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 23:
112
+ case 25:
111
113
  case "end":
112
114
  return _context2.stop();
113
115
  }