@loaders.gl/3d-tiles 3.4.0-alpha.3 → 3.4.0-alpha.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (68) hide show
  1. package/dist/dist.min.js +124 -77
  2. package/dist/es5/lib/classes/tile-3d-batch-table-hierarchy.js.map +1 -1
  3. package/dist/es5/lib/classes/tile-3d-batch-table.js.map +1 -1
  4. package/dist/es5/lib/classes/tile-3d-feature-table.js.map +1 -1
  5. package/dist/es5/lib/encoders/encode-3d-tile-instanced-model.js.map +1 -1
  6. package/dist/es5/lib/encoders/encode-3d-tile-point-cloud.js.map +1 -1
  7. package/dist/es5/lib/encoders/encode-3d-tile.js.map +1 -1
  8. package/dist/es5/lib/ion/ion.js.map +1 -1
  9. package/dist/es5/lib/parsers/helpers/normalize-3d-tile-normals.js.map +1 -1
  10. package/dist/es5/lib/parsers/helpers/normalize-3d-tile-positions.js.map +1 -1
  11. package/dist/es5/lib/parsers/helpers/parse-3d-implicit-tiles.js.map +1 -1
  12. package/dist/es5/lib/parsers/helpers/parse-3d-tile-gltf-view.js +4 -3
  13. package/dist/es5/lib/parsers/helpers/parse-3d-tile-gltf-view.js.map +1 -1
  14. package/dist/es5/lib/parsers/helpers/parse-3d-tile-header.js.map +1 -1
  15. package/dist/es5/lib/parsers/helpers/parse-3d-tile-subtree.js.map +1 -1
  16. package/dist/es5/lib/parsers/helpers/parse-3d-tile-tables.js.map +1 -1
  17. package/dist/es5/lib/parsers/parse-3d-tile-gltf.js +2 -1
  18. package/dist/es5/lib/parsers/parse-3d-tile-gltf.js.map +1 -1
  19. package/dist/es5/lib/parsers/parse-3d-tile-header.js +1 -1
  20. package/dist/es5/lib/parsers/parse-3d-tile-header.js.map +1 -1
  21. package/dist/es5/lib/parsers/parse-3d-tile-instanced-model.js.map +1 -1
  22. package/dist/es5/lib/parsers/parse-3d-tile-point-cloud.js.map +1 -1
  23. package/dist/es5/lib/parsers/parse-3d-tile.js.map +1 -1
  24. package/dist/es5/lib/utils/s2/s2-token-functions.js.map +1 -1
  25. package/dist/es5/lib/utils/s2/s2geometry/s2-geometry.js.map +1 -1
  26. package/dist/es5/lib/utils/version.js +1 -1
  27. package/dist/es5/tiles-3d-loader.js +4 -3
  28. package/dist/es5/tiles-3d-loader.js.map +1 -1
  29. package/dist/esm/lib/classes/tile-3d-batch-table-hierarchy.js.map +1 -1
  30. package/dist/esm/lib/classes/tile-3d-batch-table.js.map +1 -1
  31. package/dist/esm/lib/classes/tile-3d-feature-table.js.map +1 -1
  32. package/dist/esm/lib/encoders/encode-3d-tile-instanced-model.js.map +1 -1
  33. package/dist/esm/lib/encoders/encode-3d-tile-point-cloud.js.map +1 -1
  34. package/dist/esm/lib/encoders/encode-3d-tile.js.map +1 -1
  35. package/dist/esm/lib/ion/ion.js.map +1 -1
  36. package/dist/esm/lib/parsers/helpers/normalize-3d-tile-normals.js.map +1 -1
  37. package/dist/esm/lib/parsers/helpers/normalize-3d-tile-positions.js.map +1 -1
  38. package/dist/esm/lib/parsers/helpers/parse-3d-implicit-tiles.js.map +1 -1
  39. package/dist/esm/lib/parsers/helpers/parse-3d-tile-gltf-view.js +2 -1
  40. package/dist/esm/lib/parsers/helpers/parse-3d-tile-gltf-view.js.map +1 -1
  41. package/dist/esm/lib/parsers/helpers/parse-3d-tile-header.js.map +1 -1
  42. package/dist/esm/lib/parsers/helpers/parse-3d-tile-subtree.js.map +1 -1
  43. package/dist/esm/lib/parsers/helpers/parse-3d-tile-tables.js.map +1 -1
  44. package/dist/esm/lib/parsers/parse-3d-tile-gltf.js +2 -1
  45. package/dist/esm/lib/parsers/parse-3d-tile-gltf.js.map +1 -1
  46. package/dist/esm/lib/parsers/parse-3d-tile-header.js +1 -1
  47. package/dist/esm/lib/parsers/parse-3d-tile-header.js.map +1 -1
  48. package/dist/esm/lib/parsers/parse-3d-tile-instanced-model.js.map +1 -1
  49. package/dist/esm/lib/parsers/parse-3d-tile-point-cloud.js.map +1 -1
  50. package/dist/esm/lib/parsers/parse-3d-tile.js.map +1 -1
  51. package/dist/esm/lib/utils/s2/s2-token-functions.js.map +1 -1
  52. package/dist/esm/lib/utils/s2/s2geometry/s2-geometry.js.map +1 -1
  53. package/dist/esm/lib/utils/version.js +1 -1
  54. package/dist/esm/tiles-3d-loader.js +1 -0
  55. package/dist/esm/tiles-3d-loader.js.map +1 -1
  56. package/dist/lib/parsers/helpers/parse-3d-tile-gltf-view.d.ts.map +1 -1
  57. package/dist/lib/parsers/helpers/parse-3d-tile-gltf-view.js +1 -0
  58. package/dist/lib/parsers/helpers/parse-3d-tile-subtree.js +1 -1
  59. package/dist/lib/parsers/parse-3d-tile-gltf.d.ts.map +1 -1
  60. package/dist/lib/parsers/parse-3d-tile-gltf.js +1 -0
  61. package/dist/lib/parsers/parse-3d-tile-header.js +1 -1
  62. package/dist/tiles-3d-loader.js +1 -0
  63. package/package.json +7 -7
  64. package/src/lib/parsers/helpers/parse-3d-tile-gltf-view.ts +2 -1
  65. package/src/lib/parsers/helpers/parse-3d-tile-subtree.ts +1 -1
  66. package/src/lib/parsers/parse-3d-tile-gltf.ts +2 -1
  67. package/src/lib/parsers/parse-3d-tile-header.ts +1 -1
  68. package/src/tiles-3d-loader.ts +2 -0
package/dist/dist.min.js CHANGED
@@ -5341,39 +5341,60 @@
5341
5341
  }
5342
5342
  });
5343
5343
 
5344
+ // ../core/src/lib/utils/url-utils.ts
5345
+ function extractQueryString(url) {
5346
+ const matches3 = url.match(QUERY_STRING_PATTERN);
5347
+ return matches3 && matches3[0];
5348
+ }
5349
+ function stripQueryString(url) {
5350
+ return url.replace(QUERY_STRING_PATTERN, "");
5351
+ }
5352
+ var QUERY_STRING_PATTERN;
5353
+ var init_url_utils = __esm({
5354
+ "../core/src/lib/utils/url-utils.ts"() {
5355
+ QUERY_STRING_PATTERN = /\?.*/;
5356
+ }
5357
+ });
5358
+
5344
5359
  // ../core/src/lib/utils/resource-utils.ts
5345
- function getResourceUrlAndType(resource) {
5360
+ function getResourceUrl(resource) {
5346
5361
  if (isResponse(resource)) {
5347
- const url = stripQueryString(resource.url || "");
5348
- const contentTypeHeader = resource.headers.get("content-type") || "";
5349
- return {
5350
- url,
5351
- type: parseMIMEType(contentTypeHeader) || parseMIMETypeFromURL(url)
5352
- };
5362
+ const response = resource;
5363
+ return response.url;
5353
5364
  }
5354
5365
  if (isBlob(resource)) {
5355
- return {
5356
- url: stripQueryString(resource.name || ""),
5357
- type: resource.type || ""
5358
- };
5366
+ const blob = resource;
5367
+ return blob.name || "";
5359
5368
  }
5360
5369
  if (typeof resource === "string") {
5361
- return {
5362
- url: stripQueryString(resource),
5363
- type: parseMIMETypeFromURL(resource)
5364
- };
5370
+ return resource;
5365
5371
  }
5366
- return {
5367
- url: "",
5368
- type: ""
5369
- };
5372
+ return "";
5373
+ }
5374
+ function getResourceMIMEType(resource) {
5375
+ if (isResponse(resource)) {
5376
+ const response = resource;
5377
+ const contentTypeHeader = response.headers.get("content-type") || "";
5378
+ const noQueryUrl = stripQueryString(response.url);
5379
+ return parseMIMEType(contentTypeHeader) || parseMIMETypeFromURL(noQueryUrl);
5380
+ }
5381
+ if (isBlob(resource)) {
5382
+ const blob = resource;
5383
+ return blob.type || "";
5384
+ }
5385
+ if (typeof resource === "string") {
5386
+ return parseMIMETypeFromURL(resource);
5387
+ }
5388
+ return "";
5370
5389
  }
5371
5390
  function getResourceContentLength(resource) {
5372
5391
  if (isResponse(resource)) {
5373
- return resource.headers["content-length"] || -1;
5392
+ const response = resource;
5393
+ return response.headers["content-length"] || -1;
5374
5394
  }
5375
5395
  if (isBlob(resource)) {
5376
- return resource.size;
5396
+ const blob = resource;
5397
+ return blob.size;
5377
5398
  }
5378
5399
  if (typeof resource === "string") {
5379
5400
  return resource.length;
@@ -5386,15 +5407,11 @@
5386
5407
  }
5387
5408
  return -1;
5388
5409
  }
5389
- function stripQueryString(url) {
5390
- return url.replace(QUERY_STRING_PATTERN, "");
5391
- }
5392
- var QUERY_STRING_PATTERN;
5393
5410
  var init_resource_utils = __esm({
5394
5411
  "../core/src/lib/utils/resource-utils.ts"() {
5395
5412
  init_is_type();
5396
5413
  init_mime_type_utils();
5397
- QUERY_STRING_PATTERN = /\?.*/;
5414
+ init_url_utils();
5398
5415
  }
5399
5416
  });
5400
5417
 
@@ -5408,7 +5425,8 @@
5408
5425
  if (contentLength >= 0) {
5409
5426
  headers["content-length"] = String(contentLength);
5410
5427
  }
5411
- const { url, type } = getResourceUrlAndType(resource);
5428
+ const url = getResourceUrl(resource);
5429
+ const type = getResourceMIMEType(resource);
5412
5430
  if (type) {
5413
5431
  headers["content-type"] = type;
5414
5432
  }
@@ -5497,7 +5515,7 @@
5497
5515
  }
5498
5516
  });
5499
5517
 
5500
- // ../core/node_modules/@probe.gl/env/dist/lib/is-electron.js
5518
+ // ../../node_modules/@probe.gl/env/dist/lib/is-electron.js
5501
5519
  function isElectron(mockUserAgent) {
5502
5520
  if (typeof window !== "undefined" && typeof window.process === "object" && window.process.type === "renderer") {
5503
5521
  return true;
@@ -5513,54 +5531,54 @@
5513
5531
  return false;
5514
5532
  }
5515
5533
  var init_is_electron = __esm({
5516
- "../core/node_modules/@probe.gl/env/dist/lib/is-electron.js"() {
5534
+ "../../node_modules/@probe.gl/env/dist/lib/is-electron.js"() {
5517
5535
  }
5518
5536
  });
5519
5537
 
5520
- // ../core/node_modules/@probe.gl/env/dist/lib/is-browser.js
5538
+ // ../../node_modules/@probe.gl/env/dist/lib/is-browser.js
5521
5539
  function isBrowser3() {
5522
5540
  const isNode = typeof process === "object" && String(process) === "[object process]" && !process.browser;
5523
5541
  return !isNode || isElectron();
5524
5542
  }
5525
5543
  var init_is_browser = __esm({
5526
- "../core/node_modules/@probe.gl/env/dist/lib/is-browser.js"() {
5544
+ "../../node_modules/@probe.gl/env/dist/lib/is-browser.js"() {
5527
5545
  init_is_electron();
5528
5546
  }
5529
5547
  });
5530
5548
 
5531
- // ../core/node_modules/@probe.gl/env/dist/lib/globals.js
5532
- var self2, window2, document2, process2, console2, navigator2;
5549
+ // ../../node_modules/@probe.gl/env/dist/lib/globals.js
5550
+ var self_3, window_3, document_3, process_, console_, navigator_;
5533
5551
  var init_globals3 = __esm({
5534
- "../core/node_modules/@probe.gl/env/dist/lib/globals.js"() {
5535
- self2 = globalThis.self || globalThis.window || globalThis.global;
5536
- window2 = globalThis.window || globalThis.self || globalThis.global;
5537
- document2 = globalThis.document || {};
5538
- process2 = globalThis.process || {};
5539
- console2 = globalThis.console;
5540
- navigator2 = globalThis.navigator || {};
5552
+ "../../node_modules/@probe.gl/env/dist/lib/globals.js"() {
5553
+ self_3 = globalThis.self || globalThis.window || globalThis.global;
5554
+ window_3 = globalThis.window || globalThis.self || globalThis.global;
5555
+ document_3 = globalThis.document || {};
5556
+ process_ = globalThis.process || {};
5557
+ console_ = globalThis.console;
5558
+ navigator_ = globalThis.navigator || {};
5541
5559
  }
5542
5560
  });
5543
5561
 
5544
- // ../core/node_modules/@probe.gl/env/dist/utils/globals.js
5562
+ // ../../node_modules/@probe.gl/env/dist/utils/globals.js
5545
5563
  var VERSION3, isBrowser4;
5546
5564
  var init_globals4 = __esm({
5547
- "../core/node_modules/@probe.gl/env/dist/utils/globals.js"() {
5565
+ "../../node_modules/@probe.gl/env/dist/utils/globals.js"() {
5548
5566
  init_is_browser();
5549
5567
  VERSION3 = typeof __VERSION__ !== "undefined" ? __VERSION__ : "untranspiled source";
5550
5568
  isBrowser4 = isBrowser3();
5551
5569
  }
5552
5570
  });
5553
5571
 
5554
- // ../core/node_modules/@probe.gl/env/dist/index.js
5572
+ // ../../node_modules/@probe.gl/env/dist/index.js
5555
5573
  var init_dist = __esm({
5556
- "../core/node_modules/@probe.gl/env/dist/index.js"() {
5574
+ "../../node_modules/@probe.gl/env/dist/index.js"() {
5557
5575
  init_globals4();
5558
5576
  init_globals3();
5559
5577
  init_is_browser();
5560
5578
  }
5561
5579
  });
5562
5580
 
5563
- // ../core/node_modules/@probe.gl/log/dist/utils/local-storage.js
5581
+ // ../../node_modules/@probe.gl/log/dist/utils/local-storage.js
5564
5582
  function getStorage(type) {
5565
5583
  try {
5566
5584
  const storage = window[type];
@@ -5574,7 +5592,7 @@
5574
5592
  }
5575
5593
  var LocalStorage;
5576
5594
  var init_local_storage = __esm({
5577
- "../core/node_modules/@probe.gl/log/dist/utils/local-storage.js"() {
5595
+ "../../node_modules/@probe.gl/log/dist/utils/local-storage.js"() {
5578
5596
  init_defineProperty();
5579
5597
  LocalStorage = class {
5580
5598
  constructor(id, defaultConfig) {
@@ -5610,7 +5628,7 @@
5610
5628
  }
5611
5629
  });
5612
5630
 
5613
- // ../core/node_modules/@probe.gl/log/dist/utils/formatters.js
5631
+ // ../../node_modules/@probe.gl/log/dist/utils/formatters.js
5614
5632
  function formatTime(ms) {
5615
5633
  let formatted;
5616
5634
  if (ms < 10) {
@@ -5641,11 +5659,11 @@
5641
5659
  return ["".concat(message, " %c+"), style];
5642
5660
  }
5643
5661
  var init_formatters = __esm({
5644
- "../core/node_modules/@probe.gl/log/dist/utils/formatters.js"() {
5662
+ "../../node_modules/@probe.gl/log/dist/utils/formatters.js"() {
5645
5663
  }
5646
5664
  });
5647
5665
 
5648
- // ../core/node_modules/@probe.gl/log/dist/utils/color.js
5666
+ // ../../node_modules/@probe.gl/log/dist/utils/color.js
5649
5667
  function getColor(color) {
5650
5668
  if (typeof color !== "string") {
5651
5669
  return color;
@@ -5668,7 +5686,7 @@
5668
5686
  }
5669
5687
  var COLOR, BACKGROUND_INCREMENT;
5670
5688
  var init_color = __esm({
5671
- "../core/node_modules/@probe.gl/log/dist/utils/color.js"() {
5689
+ "../../node_modules/@probe.gl/log/dist/utils/color.js"() {
5672
5690
  init_dist();
5673
5691
  (function(COLOR2) {
5674
5692
  COLOR2[COLOR2["BLACK"] = 30] = "BLACK";
@@ -5692,7 +5710,7 @@
5692
5710
  }
5693
5711
  });
5694
5712
 
5695
- // ../core/node_modules/@probe.gl/log/dist/utils/autobind.js
5713
+ // ../../node_modules/@probe.gl/log/dist/utils/autobind.js
5696
5714
  function autobind(obj) {
5697
5715
  let predefined = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : ["constructor"];
5698
5716
  const proto = Object.getPrototypeOf(obj);
@@ -5708,30 +5726,30 @@
5708
5726
  }
5709
5727
  }
5710
5728
  var init_autobind = __esm({
5711
- "../core/node_modules/@probe.gl/log/dist/utils/autobind.js"() {
5729
+ "../../node_modules/@probe.gl/log/dist/utils/autobind.js"() {
5712
5730
  }
5713
5731
  });
5714
5732
 
5715
- // ../core/node_modules/@probe.gl/log/dist/utils/assert.js
5733
+ // ../../node_modules/@probe.gl/log/dist/utils/assert.js
5716
5734
  function assert5(condition, message) {
5717
5735
  if (!condition) {
5718
5736
  throw new Error(message || "Assertion failed");
5719
5737
  }
5720
5738
  }
5721
5739
  var init_assert4 = __esm({
5722
- "../core/node_modules/@probe.gl/log/dist/utils/assert.js"() {
5740
+ "../../node_modules/@probe.gl/log/dist/utils/assert.js"() {
5723
5741
  }
5724
5742
  });
5725
5743
 
5726
- // ../core/node_modules/@probe.gl/log/dist/utils/hi-res-timestamp.js
5744
+ // ../../node_modules/@probe.gl/log/dist/utils/hi-res-timestamp.js
5727
5745
  function getHiResTimestamp() {
5728
5746
  let timestamp;
5729
- if (isBrowser3() && window2.performance) {
5747
+ if (isBrowser3() && window_3.performance) {
5730
5748
  var _window$performance, _window$performance$n;
5731
- timestamp = window2 === null || window2 === void 0 ? void 0 : (_window$performance = window2.performance) === null || _window$performance === void 0 ? void 0 : (_window$performance$n = _window$performance.now) === null || _window$performance$n === void 0 ? void 0 : _window$performance$n.call(_window$performance);
5732
- } else if ("hrtime" in process2) {
5749
+ timestamp = window_3 === null || window_3 === void 0 ? void 0 : (_window$performance = window_3.performance) === null || _window$performance === void 0 ? void 0 : (_window$performance$n = _window$performance.now) === null || _window$performance$n === void 0 ? void 0 : _window$performance$n.call(_window$performance);
5750
+ } else if ("hrtime" in process_) {
5733
5751
  var _process$hrtime;
5734
- const timeParts = process2 === null || process2 === void 0 ? void 0 : (_process$hrtime = process2.hrtime) === null || _process$hrtime === void 0 ? void 0 : _process$hrtime.call(process2);
5752
+ const timeParts = process_ === null || process_ === void 0 ? void 0 : (_process$hrtime = process_.hrtime) === null || _process$hrtime === void 0 ? void 0 : _process$hrtime.call(process_);
5735
5753
  timestamp = timeParts[0] * 1e3 + timeParts[1] / 1e6;
5736
5754
  } else {
5737
5755
  timestamp = Date.now();
@@ -5739,12 +5757,12 @@
5739
5757
  return timestamp;
5740
5758
  }
5741
5759
  var init_hi_res_timestamp = __esm({
5742
- "../core/node_modules/@probe.gl/log/dist/utils/hi-res-timestamp.js"() {
5760
+ "../../node_modules/@probe.gl/log/dist/utils/hi-res-timestamp.js"() {
5743
5761
  init_dist();
5744
5762
  }
5745
5763
  });
5746
5764
 
5747
- // ../core/node_modules/@probe.gl/log/dist/log.js
5765
+ // ../../node_modules/@probe.gl/log/dist/log.js
5748
5766
  function noop() {
5749
5767
  }
5750
5768
  function normalizeLogLevel(logLevel) {
@@ -5851,7 +5869,7 @@
5851
5869
  }
5852
5870
  var originalConsole, DEFAULT_LOG_CONFIGURATION, cache, ONCE, Log;
5853
5871
  var init_log = __esm({
5854
- "../core/node_modules/@probe.gl/log/dist/log.js"() {
5872
+ "../../node_modules/@probe.gl/log/dist/log.js"() {
5855
5873
  init_defineProperty();
5856
5874
  init_dist();
5857
5875
  init_local_storage();
@@ -6090,10 +6108,10 @@
6090
6108
  }
6091
6109
  });
6092
6110
 
6093
- // ../core/node_modules/@probe.gl/log/dist/index.js
6111
+ // ../../node_modules/@probe.gl/log/dist/index.js
6094
6112
  var dist_default;
6095
6113
  var init_dist2 = __esm({
6096
- "../core/node_modules/@probe.gl/log/dist/index.js"() {
6114
+ "../../node_modules/@probe.gl/log/dist/index.js"() {
6097
6115
  init_log();
6098
6116
  init_log();
6099
6117
  dist_default = new Log({
@@ -6394,8 +6412,9 @@
6394
6412
  return loader;
6395
6413
  }
6396
6414
  function selectLoaderInternal(data, loaders, options, context) {
6397
- const { url, type } = getResourceUrlAndType(data);
6398
- const testUrl = url || context?.url;
6415
+ const url = getResourceUrl(data);
6416
+ const type = getResourceMIMEType(data);
6417
+ const testUrl = stripQueryString(url) || context?.url;
6399
6418
  let loader = null;
6400
6419
  let reason = "";
6401
6420
  if (options?.mimeType) {
@@ -6424,7 +6443,8 @@
6424
6443
  return true;
6425
6444
  }
6426
6445
  function getNoValidLoaderMessage(data) {
6427
- const { url, type } = getResourceUrlAndType(data);
6446
+ const url = getResourceUrl(data);
6447
+ const type = getResourceMIMEType(data);
6428
6448
  let message = "No valid loader found (";
6429
6449
  message += url ? `${path_exports.filename(url)}, ` : "no url provided, ";
6430
6450
  message += `MIME type: ${type ? `"${type}"` : "not provided"}, `;
@@ -6543,6 +6563,7 @@
6543
6563
  init_resource_utils();
6544
6564
  init_register_loaders();
6545
6565
  init_is_type();
6566
+ init_url_utils();
6546
6567
  EXT_PATTERN = /\.([^.]+)$/;
6547
6568
  }
6548
6569
  });
@@ -6755,18 +6776,25 @@
6755
6776
  });
6756
6777
 
6757
6778
  // ../core/src/lib/loader-utils/loader-context.ts
6758
- function getLoaderContext(context, options, previousContext = null) {
6759
- if (previousContext) {
6760
- return previousContext;
6779
+ function getLoaderContext(context, options, parentContext) {
6780
+ if (parentContext) {
6781
+ return parentContext;
6761
6782
  }
6762
- const resolvedContext = {
6783
+ const newContext = {
6763
6784
  fetch: getFetchFunction(options, context),
6764
6785
  ...context
6765
6786
  };
6766
- if (!Array.isArray(resolvedContext.loaders)) {
6767
- resolvedContext.loaders = null;
6787
+ if (newContext.url) {
6788
+ const baseUrl = stripQueryString(newContext.url);
6789
+ newContext.baseUrl = baseUrl;
6790
+ newContext.queryString = extractQueryString(newContext.url);
6791
+ newContext.filename = path_exports.filename(baseUrl);
6792
+ newContext.baseUrl = path_exports.dirname(baseUrl);
6768
6793
  }
6769
- return resolvedContext;
6794
+ if (!Array.isArray(newContext.loaders)) {
6795
+ newContext.loaders = null;
6796
+ }
6797
+ return newContext;
6770
6798
  }
6771
6799
  function getLoadersFromContext(loaders, context) {
6772
6800
  if (!context && loaders && !Array.isArray(loaders)) {
@@ -6785,6 +6813,8 @@
6785
6813
  var init_loader_context = __esm({
6786
6814
  "../core/src/lib/loader-utils/loader-context.ts"() {
6787
6815
  init_get_fetch_function();
6816
+ init_url_utils();
6817
+ init_src2();
6788
6818
  }
6789
6819
  });
6790
6820
 
@@ -6798,7 +6828,7 @@
6798
6828
  }
6799
6829
  data = await data;
6800
6830
  options = options || {};
6801
- const { url } = getResourceUrlAndType(data);
6831
+ const url = getResourceUrl(data);
6802
6832
  const typedLoaders = loaders;
6803
6833
  const candidateLoaders = getLoadersFromContext(typedLoaders, context);
6804
6834
  const loader = await selectLoader(data, candidateLoaders, options);
@@ -6806,7 +6836,7 @@
6806
6836
  return null;
6807
6837
  }
6808
6838
  options = normalizeOptions(options, loader, candidateLoaders, url);
6809
- context = getLoaderContext({ url, parse, loaders: candidateLoaders }, options, context);
6839
+ context = getLoaderContext({ url, parse, loaders: candidateLoaders }, options, context || null);
6810
6840
  return await parseWithLoader(loader, data, options, context);
6811
6841
  }
6812
6842
  async function parseWithLoader(loader, data, options, context) {
@@ -10312,6 +10342,19 @@
10312
10342
  assert8(byteLength >= 0 && byteLength <= bufferView.byteLength);
10313
10343
  return { ArrayType, length: length4, byteLength };
10314
10344
  }
10345
+ function getMemoryUsageGLTF(gltf) {
10346
+ let { images, bufferViews } = gltf;
10347
+ images = images || [];
10348
+ bufferViews = bufferViews || [];
10349
+ const imageBufferViews = images.map((i2) => i2.bufferView);
10350
+ bufferViews = bufferViews.filter((view) => !imageBufferViews.includes(view));
10351
+ const bufferMemory = bufferViews.reduce((acc, view) => acc + view.byteLength, 0);
10352
+ const pixelCount = images.reduce((acc, image) => {
10353
+ const { width, height } = image.image;
10354
+ return acc + width * height;
10355
+ }, 0);
10356
+ return bufferMemory + Math.ceil(4 * pixelCount * 1.33);
10357
+ }
10315
10358
  var TYPES, ARRAY_CONSTRUCTOR_TO_WEBGL_CONSTANT, ARRAY_TO_COMPONENT_TYPE, ATTRIBUTE_TYPE_TO_COMPONENTS, ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE, ATTRIBUTE_COMPONENT_TYPE_TO_ARRAY;
10316
10359
  var init_gltf_utils = __esm({
10317
10360
  "../gltf/src/lib/gltf-utils/gltf-utils.ts"() {
@@ -12557,6 +12600,7 @@
12557
12600
  var init_src10 = __esm({
12558
12601
  "../gltf/src/index.ts"() {
12559
12602
  init_gltf_loader();
12603
+ init_gltf_utils();
12560
12604
  }
12561
12605
  });
12562
12606
 
@@ -12588,6 +12632,7 @@
12588
12632
  }
12589
12633
  if (tile.gltfArrayBuffer) {
12590
12634
  tile.gltf = await parse5(tile.gltfArrayBuffer, GLTFLoader, options, context);
12635
+ tile.gpuMemoryUsageInBytes = getMemoryUsageGLTF(tile.gltf);
12591
12636
  delete tile.gltfArrayBuffer;
12592
12637
  delete tile.gltfByteOffset;
12593
12638
  delete tile.gltfByteLength;
@@ -12830,6 +12875,7 @@
12830
12875
  tile.gltfUpAxis = options["3d-tiles"] && options["3d-tiles"].assetGltfUpAxis ? options["3d-tiles"].assetGltfUpAxis : "Y";
12831
12876
  const { parse: parse5 } = context;
12832
12877
  tile.gltf = await parse5(arrayBuffer, GLTFLoader, options, context);
12878
+ tile.gpuMemoryUsageInBytes = getMemoryUsageGLTF(tile.gltf);
12833
12879
  }
12834
12880
  var init_parse_3d_tile_gltf = __esm({
12835
12881
  "src/lib/parsers/parse-3d-tile-gltf.ts"() {
@@ -14410,7 +14456,7 @@
14410
14456
  if (!tile.contentUrl) {
14411
14457
  return TILE_TYPE.EMPTY;
14412
14458
  }
14413
- const contentUrl = tile.contentUrl;
14459
+ const contentUrl = tile.contentUrl.split("?")[0];
14414
14460
  const fileExtension = contentUrl.split(".").pop();
14415
14461
  switch (fileExtension) {
14416
14462
  case "pnts":
@@ -14578,6 +14624,7 @@
14578
14624
  const tilesetJson = JSON.parse(new TextDecoder().decode(data));
14579
14625
  tilesetJson.loader = options.loader || Tiles3DLoader;
14580
14626
  tilesetJson.url = context.url;
14627
+ tilesetJson.queryString = context.queryString;
14581
14628
  tilesetJson.basePath = getBaseUri(tilesetJson);
14582
14629
  tilesetJson.root = await normalizeTileHeaders(tilesetJson, options);
14583
14630
  tilesetJson.type = TILESET_TYPE.TILES3D;
@@ -1 +1 @@
1
- {"version":3,"file":"tile-3d-batch-table-hierarchy.js","names":["defined","x","undefined","initializeHierarchy","batchTable","jsonHeader","binaryBody","hierarchy","getExtension","legacyHierarchy","HIERARCHY","console","warn","extensions","initializeHierarchyValues","hierarchyJson","i","classId","binaryAccessor","instancesLength","classes","classIds","parentCounts","parentIds","parentIdsLength","byteOffset","componentType","defaultValue","GL","UNSIGNED_SHORT","type","AttributeType","SCALAR","getBinaryAccessor","createArrayBufferView","buffer","parentIndexes","Uint16Array","classesLength","length","classInstancesLength","properties","instances","binaryProperties","getBinaryProperties","combine","classCounts","Array","fill","classIndexes","validateHierarchy","traverseHierarchy","instanceIndex","endConditionCallback","traverseHierarchyMultipleParents","traverseHierarchySingleParent","visited","scratchVisited","Math","max","visitedMarker","marker","stack","scratchStack","push","pop","result","parentCount","parentIndex","parentId","hasParent","Error","scratchValidateStack","validateInstance","assert","concat","indexOf"],"sources":["../../../../src/lib/classes/tile-3d-batch-table-hierarchy.ts"],"sourcesContent":["// This file is derived from the Cesium code base under Apache 2 license\n// See LICENSE.md and https://github.com/AnalyticalGraphicsInc/cesium/blob/master/LICENSE.md\n\n// TODO - Finish hierarchy suypport: this file is only half ported\n/* eslint-disable */\n// @ts-nocheck\nconst defined = (x) => x !== undefined;\n\nexport function initializeHierarchy(batchTable, jsonHeader, binaryBody) {\n if (!jsonHeader) {\n return null;\n }\n\n let hierarchy = batchTable.getExtension('3DTILES_batch_table_hierarchy');\n\n const legacyHierarchy = jsonHeader.HIERARCHY;\n if (legacyHierarchy) {\n // eslint-disable-next-line\n console.warn('3D Tile Parser: HIERARCHY is deprecated. Use 3DTILES_batch_table_hierarchy.');\n jsonHeader.extensions = jsonHeader.extensions || {};\n jsonHeader.extensions['3DTILES_batch_table_hierarchy'] = legacyHierarchy;\n hierarchy = legacyHierarchy;\n }\n\n if (!hierarchy) {\n return null;\n }\n\n return initializeHierarchyValues(hierarchy, binaryBody);\n}\n\n// eslint-disable-next-line max-statements\nfunction initializeHierarchyValues(hierarchyJson, binaryBody) {\n let i;\n let classId;\n let binaryAccessor;\n\n const instancesLength = hierarchyJson.instancesLength;\n const classes = hierarchyJson.classes;\n let classIds = hierarchyJson.classIds;\n let parentCounts = hierarchyJson.parentCounts;\n let parentIds = hierarchyJson.parentIds;\n let parentIdsLength = instancesLength;\n\n if (defined(classIds.byteOffset)) {\n classIds.componentType = defaultValue(classIds.componentType, GL.UNSIGNED_SHORT);\n classIds.type = AttributeType.SCALAR;\n binaryAccessor = getBinaryAccessor(classIds);\n classIds = binaryAccessor.createArrayBufferView(\n binaryBody.buffer,\n binaryBody.byteOffset + classIds.byteOffset,\n instancesLength\n );\n }\n\n let parentIndexes;\n if (defined(parentCounts)) {\n if (defined(parentCounts.byteOffset)) {\n parentCounts.componentType = defaultValue(parentCounts.componentType, GL.UNSIGNED_SHORT);\n parentCounts.type = AttributeType.SCALAR;\n binaryAccessor = getBinaryAccessor(parentCounts);\n parentCounts = binaryAccessor.createArrayBufferView(\n binaryBody.buffer,\n binaryBody.byteOffset + parentCounts.byteOffset,\n instancesLength\n );\n }\n parentIndexes = new Uint16Array(instancesLength);\n parentIdsLength = 0;\n for (i = 0; i < instancesLength; ++i) {\n parentIndexes[i] = parentIdsLength;\n parentIdsLength += parentCounts[i];\n }\n }\n\n if (defined(parentIds) && defined(parentIds.byteOffset)) {\n parentIds.componentType = defaultValue(parentIds.componentType, GL.UNSIGNED_SHORT);\n parentIds.type = AttributeType.SCALAR;\n binaryAccessor = getBinaryAccessor(parentIds);\n parentIds = binaryAccessor.createArrayBufferView(\n binaryBody.buffer,\n binaryBody.byteOffset + parentIds.byteOffset,\n parentIdsLength\n );\n }\n\n const classesLength = classes.length;\n for (i = 0; i < classesLength; ++i) {\n const classInstancesLength = classes[i].length;\n const properties = classes[i].instances;\n const binaryProperties = getBinaryProperties(classInstancesLength, properties, binaryBody);\n classes[i].instances = combine(binaryProperties, properties);\n }\n\n const classCounts = new Array(classesLength).fill(0);\n const classIndexes = new Uint16Array(instancesLength);\n for (i = 0; i < instancesLength; ++i) {\n classId = classIds[i];\n classIndexes[i] = classCounts[classId];\n ++classCounts[classId];\n }\n\n const hierarchy = {\n classes,\n classIds,\n classIndexes,\n parentCounts,\n parentIndexes,\n parentIds\n };\n\n validateHierarchy(hierarchy);\n\n return hierarchy;\n}\n\n// HELPER CODE\n\n// Traverse over the hierarchy and process each instance with the endConditionCallback.\n// When the endConditionCallback returns a value, the traversal stops and that value is returned.\nexport function traverseHierarchy(hierarchy, instanceIndex, endConditionCallback) {\n if (!hierarchy) {\n return;\n }\n\n const parentCounts = hierarchy.parentCounts;\n const parentIds = hierarchy.parentIds;\n if (parentIds) {\n return endConditionCallback(hierarchy, instanceIndex);\n }\n if (parentCounts > 0) {\n return traverseHierarchyMultipleParents(hierarchy, instanceIndex, endConditionCallback);\n }\n return traverseHierarchySingleParent(hierarchy, instanceIndex, endConditionCallback);\n}\n\n// eslint-disable-next-line max-statements\nfunction traverseHierarchyMultipleParents(hierarchy, instanceIndex, endConditionCallback) {\n const classIds = hierarchy.classIds;\n const parentCounts = hierarchy.parentCounts;\n const parentIds = hierarchy.parentIds;\n const parentIndexes = hierarchy.parentIndexes;\n const instancesLength = classIds.length;\n\n // Ignore instances that have already been visited. This occurs in diamond inheritance situations.\n // Use a marker value to indicate that an instance has been visited, which increments with each run.\n // This is more efficient than clearing the visited array every time.\n const visited = scratchVisited;\n visited.length = Math.max(visited.length, instancesLength);\n const visitedMarker = ++marker;\n\n const stack = scratchStack;\n stack.length = 0;\n stack.push(instanceIndex);\n\n while (stack.length > 0) {\n instanceIndex = stack.pop();\n if (visited[instanceIndex] === visitedMarker) {\n // This instance has already been visited, stop traversal\n continue;\n }\n visited[instanceIndex] = visitedMarker;\n const result = endConditionCallback(hierarchy, instanceIndex);\n if (defined(result)) {\n // The end condition was met, stop the traversal and return the result\n return result;\n }\n const parentCount = parentCounts[instanceIndex];\n const parentIndex = parentIndexes[instanceIndex];\n for (let i = 0; i < parentCount; ++i) {\n const parentId = parentIds[parentIndex + i];\n // Stop the traversal when the instance has no parent (its parentId equals itself)\n // else add the parent to the stack to continue the traversal.\n if (parentId !== instanceIndex) {\n stack.push(parentId);\n }\n }\n }\n\n return null;\n}\n\nfunction traverseHierarchySingleParent(hierarchy, instanceIndex, endConditionCallback) {\n let hasParent = true;\n while (hasParent) {\n const result = endConditionCallback(hierarchy, instanceIndex);\n if (defined(result)) {\n // The end condition was met, stop the traversal and return the result\n return result;\n }\n const parentId = hierarchy.parentIds[instanceIndex];\n hasParent = parentId !== instanceIndex;\n instanceIndex = parentId;\n }\n throw new Error('traverseHierarchySingleParent');\n}\n\n// DEBUG CODE\n\nfunction validateHierarchy(hierarchy) {\n const scratchValidateStack = [];\n\n const classIds = hierarchy.classIds;\n const instancesLength = classIds.length;\n\n for (let i = 0; i < instancesLength; ++i) {\n validateInstance(hierarchy, i, stack);\n }\n}\n\nfunction validateInstance(hierarchy, instanceIndex, stack) {\n const parentCounts = hierarchy.parentCounts;\n const parentIds = hierarchy.parentIds;\n const parentIndexes = hierarchy.parentIndexes;\n const classIds = hierarchy.classIds;\n const instancesLength = classIds.length;\n\n if (!defined(parentIds)) {\n // No need to validate if there are no parents\n return;\n }\n\n assert(\n instanceIndex < instancesLength,\n `Parent index ${instanceIndex} exceeds the total number of instances: ${instancesLength}`\n );\n assert(\n stack.indexOf(instanceIndex) === -1,\n 'Circular dependency detected in the batch table hierarchy.'\n );\n\n stack.push(instanceIndex);\n const parentCount = defined(parentCounts) ? parentCounts[instanceIndex] : 1;\n const parentIndex = defined(parentCounts) ? parentIndexes[instanceIndex] : instanceIndex;\n for (let i = 0; i < parentCount; ++i) {\n const parentId = parentIds[parentIndex + i];\n // Stop the traversal when the instance has no parent (its parentId equals itself), else continue the traversal.\n if (parentId !== instanceIndex) {\n validateInstance(hierarchy, parentId, stack);\n }\n }\n stack.pop(instanceIndex);\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"tile-3d-batch-table-hierarchy.js","names":["defined","x","undefined","initializeHierarchy","batchTable","jsonHeader","binaryBody","hierarchy","getExtension","legacyHierarchy","HIERARCHY","console","warn","extensions","initializeHierarchyValues","hierarchyJson","i","classId","binaryAccessor","instancesLength","classes","classIds","parentCounts","parentIds","parentIdsLength","byteOffset","componentType","defaultValue","GL","UNSIGNED_SHORT","type","AttributeType","SCALAR","getBinaryAccessor","createArrayBufferView","buffer","parentIndexes","Uint16Array","classesLength","length","classInstancesLength","properties","instances","binaryProperties","getBinaryProperties","combine","classCounts","Array","fill","classIndexes","validateHierarchy","traverseHierarchy","instanceIndex","endConditionCallback","traverseHierarchyMultipleParents","traverseHierarchySingleParent","visited","scratchVisited","Math","max","visitedMarker","marker","stack","scratchStack","push","pop","result","parentCount","parentIndex","parentId","hasParent","Error","scratchValidateStack","validateInstance","assert","concat","indexOf"],"sources":["../../../../src/lib/classes/tile-3d-batch-table-hierarchy.ts"],"sourcesContent":["// This file is derived from the Cesium code base under Apache 2 license\n// See LICENSE.md and https://github.com/AnalyticalGraphicsInc/cesium/blob/master/LICENSE.md\n\n// TODO - Finish hierarchy suypport: this file is only half ported\n/* eslint-disable */\n// @ts-nocheck\nconst defined = (x) => x !== undefined;\n\nexport function initializeHierarchy(batchTable, jsonHeader, binaryBody) {\n if (!jsonHeader) {\n return null;\n }\n\n let hierarchy = batchTable.getExtension('3DTILES_batch_table_hierarchy');\n\n const legacyHierarchy = jsonHeader.HIERARCHY;\n if (legacyHierarchy) {\n // eslint-disable-next-line\n console.warn('3D Tile Parser: HIERARCHY is deprecated. Use 3DTILES_batch_table_hierarchy.');\n jsonHeader.extensions = jsonHeader.extensions || {};\n jsonHeader.extensions['3DTILES_batch_table_hierarchy'] = legacyHierarchy;\n hierarchy = legacyHierarchy;\n }\n\n if (!hierarchy) {\n return null;\n }\n\n return initializeHierarchyValues(hierarchy, binaryBody);\n}\n\n// eslint-disable-next-line max-statements\nfunction initializeHierarchyValues(hierarchyJson, binaryBody) {\n let i;\n let classId;\n let binaryAccessor;\n\n const instancesLength = hierarchyJson.instancesLength;\n const classes = hierarchyJson.classes;\n let classIds = hierarchyJson.classIds;\n let parentCounts = hierarchyJson.parentCounts;\n let parentIds = hierarchyJson.parentIds;\n let parentIdsLength = instancesLength;\n\n if (defined(classIds.byteOffset)) {\n classIds.componentType = defaultValue(classIds.componentType, GL.UNSIGNED_SHORT);\n classIds.type = AttributeType.SCALAR;\n binaryAccessor = getBinaryAccessor(classIds);\n classIds = binaryAccessor.createArrayBufferView(\n binaryBody.buffer,\n binaryBody.byteOffset + classIds.byteOffset,\n instancesLength\n );\n }\n\n let parentIndexes;\n if (defined(parentCounts)) {\n if (defined(parentCounts.byteOffset)) {\n parentCounts.componentType = defaultValue(parentCounts.componentType, GL.UNSIGNED_SHORT);\n parentCounts.type = AttributeType.SCALAR;\n binaryAccessor = getBinaryAccessor(parentCounts);\n parentCounts = binaryAccessor.createArrayBufferView(\n binaryBody.buffer,\n binaryBody.byteOffset + parentCounts.byteOffset,\n instancesLength\n );\n }\n parentIndexes = new Uint16Array(instancesLength);\n parentIdsLength = 0;\n for (i = 0; i < instancesLength; ++i) {\n parentIndexes[i] = parentIdsLength;\n parentIdsLength += parentCounts[i];\n }\n }\n\n if (defined(parentIds) && defined(parentIds.byteOffset)) {\n parentIds.componentType = defaultValue(parentIds.componentType, GL.UNSIGNED_SHORT);\n parentIds.type = AttributeType.SCALAR;\n binaryAccessor = getBinaryAccessor(parentIds);\n parentIds = binaryAccessor.createArrayBufferView(\n binaryBody.buffer,\n binaryBody.byteOffset + parentIds.byteOffset,\n parentIdsLength\n );\n }\n\n const classesLength = classes.length;\n for (i = 0; i < classesLength; ++i) {\n const classInstancesLength = classes[i].length;\n const properties = classes[i].instances;\n const binaryProperties = getBinaryProperties(classInstancesLength, properties, binaryBody);\n classes[i].instances = combine(binaryProperties, properties);\n }\n\n const classCounts = new Array(classesLength).fill(0);\n const classIndexes = new Uint16Array(instancesLength);\n for (i = 0; i < instancesLength; ++i) {\n classId = classIds[i];\n classIndexes[i] = classCounts[classId];\n ++classCounts[classId];\n }\n\n const hierarchy = {\n classes,\n classIds,\n classIndexes,\n parentCounts,\n parentIndexes,\n parentIds\n };\n\n validateHierarchy(hierarchy);\n\n return hierarchy;\n}\n\n// HELPER CODE\n\n// Traverse over the hierarchy and process each instance with the endConditionCallback.\n// When the endConditionCallback returns a value, the traversal stops and that value is returned.\nexport function traverseHierarchy(hierarchy, instanceIndex, endConditionCallback) {\n if (!hierarchy) {\n return;\n }\n\n const parentCounts = hierarchy.parentCounts;\n const parentIds = hierarchy.parentIds;\n if (parentIds) {\n return endConditionCallback(hierarchy, instanceIndex);\n }\n if (parentCounts > 0) {\n return traverseHierarchyMultipleParents(hierarchy, instanceIndex, endConditionCallback);\n }\n return traverseHierarchySingleParent(hierarchy, instanceIndex, endConditionCallback);\n}\n\n// eslint-disable-next-line max-statements\nfunction traverseHierarchyMultipleParents(hierarchy, instanceIndex, endConditionCallback) {\n const classIds = hierarchy.classIds;\n const parentCounts = hierarchy.parentCounts;\n const parentIds = hierarchy.parentIds;\n const parentIndexes = hierarchy.parentIndexes;\n const instancesLength = classIds.length;\n\n // Ignore instances that have already been visited. This occurs in diamond inheritance situations.\n // Use a marker value to indicate that an instance has been visited, which increments with each run.\n // This is more efficient than clearing the visited array every time.\n const visited = scratchVisited;\n visited.length = Math.max(visited.length, instancesLength);\n const visitedMarker = ++marker;\n\n const stack = scratchStack;\n stack.length = 0;\n stack.push(instanceIndex);\n\n while (stack.length > 0) {\n instanceIndex = stack.pop();\n if (visited[instanceIndex] === visitedMarker) {\n // This instance has already been visited, stop traversal\n continue;\n }\n visited[instanceIndex] = visitedMarker;\n const result = endConditionCallback(hierarchy, instanceIndex);\n if (defined(result)) {\n // The end condition was met, stop the traversal and return the result\n return result;\n }\n const parentCount = parentCounts[instanceIndex];\n const parentIndex = parentIndexes[instanceIndex];\n for (let i = 0; i < parentCount; ++i) {\n const parentId = parentIds[parentIndex + i];\n // Stop the traversal when the instance has no parent (its parentId equals itself)\n // else add the parent to the stack to continue the traversal.\n if (parentId !== instanceIndex) {\n stack.push(parentId);\n }\n }\n }\n\n return null;\n}\n\nfunction traverseHierarchySingleParent(hierarchy, instanceIndex, endConditionCallback) {\n let hasParent = true;\n while (hasParent) {\n const result = endConditionCallback(hierarchy, instanceIndex);\n if (defined(result)) {\n // The end condition was met, stop the traversal and return the result\n return result;\n }\n const parentId = hierarchy.parentIds[instanceIndex];\n hasParent = parentId !== instanceIndex;\n instanceIndex = parentId;\n }\n throw new Error('traverseHierarchySingleParent');\n}\n\n// DEBUG CODE\n\nfunction validateHierarchy(hierarchy) {\n const scratchValidateStack = [];\n\n const classIds = hierarchy.classIds;\n const instancesLength = classIds.length;\n\n for (let i = 0; i < instancesLength; ++i) {\n validateInstance(hierarchy, i, stack);\n }\n}\n\nfunction validateInstance(hierarchy, instanceIndex, stack) {\n const parentCounts = hierarchy.parentCounts;\n const parentIds = hierarchy.parentIds;\n const parentIndexes = hierarchy.parentIndexes;\n const classIds = hierarchy.classIds;\n const instancesLength = classIds.length;\n\n if (!defined(parentIds)) {\n // No need to validate if there are no parents\n return;\n }\n\n assert(\n instanceIndex < instancesLength,\n `Parent index ${instanceIndex} exceeds the total number of instances: ${instancesLength}`\n );\n assert(\n stack.indexOf(instanceIndex) === -1,\n 'Circular dependency detected in the batch table hierarchy.'\n );\n\n stack.push(instanceIndex);\n const parentCount = defined(parentCounts) ? parentCounts[instanceIndex] : 1;\n const parentIndex = defined(parentCounts) ? parentIndexes[instanceIndex] : instanceIndex;\n for (let i = 0; i < parentCount; ++i) {\n const parentId = parentIds[parentIndex + i];\n // Stop the traversal when the instance has no parent (its parentId equals itself), else continue the traversal.\n if (parentId !== instanceIndex) {\n validateInstance(hierarchy, parentId, stack);\n }\n }\n stack.pop(instanceIndex);\n}\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"tile-3d-batch-table.js","names":["_loaderUtils","require","_tile3dAccessorUtils","_tile3dBatchTableHierarchy","defined","x","undefined","clone","y","IGNORED_PROPERTY_FIELDS","HIERARCHY","extensions","extras","Tile3DBatchTableParser","json","binary","featureCount","_this$json","options","arguments","length","_classCallCheck2","default","_defineProperty2","assert","_extensions","_properties","propertyName","_binaryProperties","_initializeBinaryProperties","_hierarchy","initializeHierarchy","_createClass2","key","value","getExtension","extensionName","memorySizeInBytes","isClass","batchId","className","_checkBatchId","result","traverseHierarchy","hierarchy","instanceIndex","classId","classIds","instanceClass","classes","name","isExactClass","getExactClassName","hasProperty","_hasPropertyInHierarchy","getPropertyNames","results","_results","propertyNames","Object","keys","push","apply","_getPropertyNamesInHierarchy","getProperty","binaryProperty","_getBinaryProperty","propertyValues","hierarchyProperty","_getHierarchyProperty","setProperty","_setBinaryProperty","_setHierarchyProperty","Array","valid","Error","index","unpack","typedArray","pack","binaryProperties","property","_initializeBinaryProperty","tile3DAccessor","concat","type","accessor","createTypedArrayFromAccessor","buffer","byteOffset","values","componentCount","size","unpacker","packer","instances","hasOwnProperty","indexOf","_this","indexInClass","classIndexes","batchTable","_this2","exports"],"sources":["../../../../src/lib/classes/tile-3d-batch-table.ts"],"sourcesContent":["// This file is derived from the Cesium code base under Apache 2 license\n// See LICENSE.md and https://github.com/AnalyticalGraphicsInc/cesium/blob/master/LICENSE.md\n\nimport {assert} from '@loaders.gl/loader-utils';\n\nimport {createTypedArrayFromAccessor} from './helpers/tile-3d-accessor-utils';\nimport {initializeHierarchy, traverseHierarchy} from './tile-3d-batch-table-hierarchy';\n\nfunction defined(x) {\n return x !== undefined && x !== null;\n}\n\nconst clone = (x, y) => x;\n\n// These top level fields in the batch table json are not properties\nconst IGNORED_PROPERTY_FIELDS = {\n HIERARCHY: true, // Deprecated HIERARCHY property\n extensions: true,\n extras: true\n};\n\n// The size of this array equals the maximum instance count among all loaded tiles, which has the potential to be large.\nexport default class Tile3DBatchTableParser {\n json;\n binary;\n featureCount;\n _extensions;\n // Copy all top-level property fields from the json object, ignoring special fields\n _properties;\n _binaryProperties;\n // TODO: hierarchy support is only partially implemented and not tested\n _hierarchy;\n\n constructor(json, binary, featureCount, options = {}) {\n assert(featureCount >= 0);\n this.json = json || {};\n this.binary = binary;\n this.featureCount = featureCount;\n\n this._extensions = this.json?.extensions || {};\n\n // Copy all top-level property fields from the json object, ignoring special fields\n this._properties = {};\n for (const propertyName in this.json) {\n if (!IGNORED_PROPERTY_FIELDS[propertyName]) {\n this._properties[propertyName] = this.json[propertyName];\n }\n }\n\n this._binaryProperties = this._initializeBinaryProperties();\n\n // TODO: hierarchy support is only partially implemented and not tested\n if (options['3DTILES_batch_table_hierarchy']) {\n this._hierarchy = initializeHierarchy(this, this.json, this.binary);\n }\n }\n\n getExtension(extensionName) {\n return this.json && this.json.extensions && this.json.extensions[extensionName];\n }\n\n memorySizeInBytes(): number {\n return 0;\n }\n\n isClass(batchId, className: string): boolean {\n this._checkBatchId(batchId);\n assert(typeof className === 'string', className);\n\n // extension: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n // PERFORMANCE_IDEA : cache results in the ancestor classes\n // to speed up this check if this area becomes a hotspot\n // PERFORMANCE_IDEA : treat class names as integers for faster comparisons\n const result = traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instanceClass = hierarchy.classes[classId];\n return instanceClass.name === className;\n });\n return defined(result);\n }\n\n return false;\n }\n\n isExactClass(batchId, className) {\n assert(typeof className === 'string', className);\n\n return this.getExactClassName(batchId) === className;\n }\n\n getExactClassName(batchId) {\n this._checkBatchId(batchId);\n\n // extension: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n const classId = this._hierarchy.classIds[batchId];\n const instanceClass = this._hierarchy.classes[classId];\n return instanceClass.name;\n }\n\n return undefined;\n }\n\n hasProperty(batchId, name) {\n this._checkBatchId(batchId);\n assert(typeof name === 'string', name);\n\n return defined(this._properties[name]) || this._hasPropertyInHierarchy(batchId, name);\n }\n\n getPropertyNames(batchId, results) {\n this._checkBatchId(batchId);\n\n results = defined(results) ? results : [];\n results.length = 0;\n\n const propertyNames = Object.keys(this._properties);\n results.push(...propertyNames);\n\n if (this._hierarchy) {\n this._getPropertyNamesInHierarchy(batchId, results);\n }\n\n return results;\n }\n\n getProperty(batchId, name) {\n this._checkBatchId(batchId);\n assert(typeof name === 'string', name);\n\n if (this._binaryProperties) {\n const binaryProperty = this._binaryProperties[name];\n if (defined(binaryProperty)) {\n return this._getBinaryProperty(binaryProperty, batchId);\n }\n }\n\n const propertyValues = this._properties[name];\n if (defined(propertyValues)) {\n return clone(propertyValues[batchId], true);\n }\n\n // EXTENSION: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n const hierarchyProperty = this._getHierarchyProperty(batchId, name);\n if (defined(hierarchyProperty)) {\n return hierarchyProperty;\n }\n }\n\n return undefined;\n }\n\n setProperty(batchId, name, value) {\n const featureCount = this.featureCount;\n\n this._checkBatchId(batchId);\n assert(typeof name === 'string', name);\n\n if (this._binaryProperties) {\n const binaryProperty = this._binaryProperties[name];\n if (binaryProperty) {\n this._setBinaryProperty(binaryProperty, batchId, value);\n return;\n }\n }\n\n // EXTENSION: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n if (this._setHierarchyProperty(this, batchId, name, value)) {\n return;\n }\n }\n\n let propertyValues = this._properties[name];\n if (!defined(propertyValues)) {\n // Property does not exist. Create it.\n this._properties[name] = new Array(featureCount);\n propertyValues = this._properties[name];\n }\n\n propertyValues[batchId] = clone(value, true);\n }\n\n // PRIVATE METHODS\n\n _checkBatchId(batchId) {\n const valid = batchId >= 0 && batchId < this.featureCount;\n if (!valid) {\n throw new Error('batchId not in range [0, featureCount - 1].');\n }\n }\n\n _getBinaryProperty(binaryProperty, index) {\n return binaryProperty.unpack(binaryProperty.typedArray, index);\n }\n\n _setBinaryProperty(binaryProperty, index, value) {\n binaryProperty.pack(value, binaryProperty.typedArray, index);\n }\n\n _initializeBinaryProperties() {\n let binaryProperties: Record<string, any> | null = null;\n for (const name in this._properties) {\n const property = this._properties[name];\n const binaryProperty = this._initializeBinaryProperty(name, property);\n // Store any information needed to access the binary data, including the typed array,\n // componentCount (e.g. a VEC4 would be 4), and the type used to pack and unpack (e.g. Cartesian4).\n if (binaryProperty) {\n binaryProperties = binaryProperties || {};\n binaryProperties[name] = binaryProperty;\n }\n }\n return binaryProperties;\n }\n\n _initializeBinaryProperty(name, property) {\n if ('byteOffset' in property) {\n // This is a binary property\n const tile3DAccessor = property;\n\n assert(this.binary, `Property ${name} requires a batch table binary.`);\n assert(tile3DAccessor.type, `Property ${name} requires a type.`);\n\n const accessor = createTypedArrayFromAccessor(\n tile3DAccessor,\n this.binary.buffer,\n this.binary.byteOffset | 0,\n this.featureCount\n );\n\n // Store any information needed to access the binary data, including the typed array,\n // componentCount (e.g. a VEC4 would be 4), and the type used to pack and unpack (e.g. Cartesian4).\n return {\n typedArray: accessor.values,\n componentCount: accessor.size,\n unpack: accessor.unpacker,\n pack: accessor.packer\n };\n }\n\n return null;\n }\n\n // EXTENSION SUPPORT: 3DTILES_batch_table_hierarchy\n\n _hasPropertyInHierarchy(batchId, name) {\n if (!this._hierarchy) {\n return false;\n }\n\n const result = traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instances = hierarchy.classes[classId].instances;\n return defined(instances[name]);\n });\n\n return defined(result);\n }\n\n _getPropertyNamesInHierarchy(batchId, results) {\n traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instances = hierarchy.classes[classId].instances;\n for (const name in instances) {\n if (instances.hasOwnProperty(name)) {\n if (results.indexOf(name) === -1) {\n results.push(name);\n }\n }\n }\n });\n }\n\n _getHierarchyProperty(batchId, name) {\n return traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instanceClass = hierarchy.classes[classId];\n const indexInClass = hierarchy.classIndexes[instanceIndex];\n const propertyValues = instanceClass.instances[name];\n if (defined(propertyValues)) {\n if (defined(propertyValues.typedArray)) {\n return this._getBinaryProperty(propertyValues, indexInClass);\n }\n return clone(propertyValues[indexInClass], true);\n }\n return null;\n });\n }\n\n _setHierarchyProperty(batchTable, batchId, name, value) {\n const result = traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instanceClass = hierarchy.classes[classId];\n const indexInClass = hierarchy.classIndexes[instanceIndex];\n const propertyValues = instanceClass.instances[name];\n if (defined(propertyValues)) {\n assert(instanceIndex === batchId, `Inherited property \"${name}\" is read-only.`);\n if (defined(propertyValues.typedArray)) {\n this._setBinaryProperty(propertyValues, indexInClass, value);\n } else {\n propertyValues[indexInClass] = clone(value, true);\n }\n return true;\n }\n return false;\n });\n return defined(result);\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"tile-3d-batch-table.js","names":["_loaderUtils","require","_tile3dAccessorUtils","_tile3dBatchTableHierarchy","defined","x","undefined","clone","y","IGNORED_PROPERTY_FIELDS","HIERARCHY","extensions","extras","Tile3DBatchTableParser","json","binary","featureCount","_this$json","options","arguments","length","_classCallCheck2","default","_defineProperty2","assert","_extensions","_properties","propertyName","_binaryProperties","_initializeBinaryProperties","_hierarchy","initializeHierarchy","_createClass2","key","value","getExtension","extensionName","memorySizeInBytes","isClass","batchId","className","_checkBatchId","result","traverseHierarchy","hierarchy","instanceIndex","classId","classIds","instanceClass","classes","name","isExactClass","getExactClassName","hasProperty","_hasPropertyInHierarchy","getPropertyNames","results","_results","propertyNames","Object","keys","push","apply","_getPropertyNamesInHierarchy","getProperty","binaryProperty","_getBinaryProperty","propertyValues","hierarchyProperty","_getHierarchyProperty","setProperty","_setBinaryProperty","_setHierarchyProperty","Array","valid","Error","index","unpack","typedArray","pack","binaryProperties","property","_initializeBinaryProperty","tile3DAccessor","concat","type","accessor","createTypedArrayFromAccessor","buffer","byteOffset","values","componentCount","size","unpacker","packer","instances","hasOwnProperty","indexOf","_this","indexInClass","classIndexes","batchTable","_this2","exports"],"sources":["../../../../src/lib/classes/tile-3d-batch-table.ts"],"sourcesContent":["// This file is derived from the Cesium code base under Apache 2 license\n// See LICENSE.md and https://github.com/AnalyticalGraphicsInc/cesium/blob/master/LICENSE.md\n\nimport {assert} from '@loaders.gl/loader-utils';\n\nimport {createTypedArrayFromAccessor} from './helpers/tile-3d-accessor-utils';\nimport {initializeHierarchy, traverseHierarchy} from './tile-3d-batch-table-hierarchy';\n\nfunction defined(x) {\n return x !== undefined && x !== null;\n}\n\nconst clone = (x, y) => x;\n\n// These top level fields in the batch table json are not properties\nconst IGNORED_PROPERTY_FIELDS = {\n HIERARCHY: true, // Deprecated HIERARCHY property\n extensions: true,\n extras: true\n};\n\n// The size of this array equals the maximum instance count among all loaded tiles, which has the potential to be large.\nexport default class Tile3DBatchTableParser {\n json;\n binary;\n featureCount;\n _extensions;\n // Copy all top-level property fields from the json object, ignoring special fields\n _properties;\n _binaryProperties;\n // TODO: hierarchy support is only partially implemented and not tested\n _hierarchy;\n\n constructor(json, binary, featureCount, options = {}) {\n assert(featureCount >= 0);\n this.json = json || {};\n this.binary = binary;\n this.featureCount = featureCount;\n\n this._extensions = this.json?.extensions || {};\n\n // Copy all top-level property fields from the json object, ignoring special fields\n this._properties = {};\n for (const propertyName in this.json) {\n if (!IGNORED_PROPERTY_FIELDS[propertyName]) {\n this._properties[propertyName] = this.json[propertyName];\n }\n }\n\n this._binaryProperties = this._initializeBinaryProperties();\n\n // TODO: hierarchy support is only partially implemented and not tested\n if (options['3DTILES_batch_table_hierarchy']) {\n this._hierarchy = initializeHierarchy(this, this.json, this.binary);\n }\n }\n\n getExtension(extensionName) {\n return this.json && this.json.extensions && this.json.extensions[extensionName];\n }\n\n memorySizeInBytes(): number {\n return 0;\n }\n\n isClass(batchId, className: string): boolean {\n this._checkBatchId(batchId);\n assert(typeof className === 'string', className);\n\n // extension: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n // PERFORMANCE_IDEA : cache results in the ancestor classes\n // to speed up this check if this area becomes a hotspot\n // PERFORMANCE_IDEA : treat class names as integers for faster comparisons\n const result = traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instanceClass = hierarchy.classes[classId];\n return instanceClass.name === className;\n });\n return defined(result);\n }\n\n return false;\n }\n\n isExactClass(batchId, className) {\n assert(typeof className === 'string', className);\n\n return this.getExactClassName(batchId) === className;\n }\n\n getExactClassName(batchId) {\n this._checkBatchId(batchId);\n\n // extension: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n const classId = this._hierarchy.classIds[batchId];\n const instanceClass = this._hierarchy.classes[classId];\n return instanceClass.name;\n }\n\n return undefined;\n }\n\n hasProperty(batchId, name) {\n this._checkBatchId(batchId);\n assert(typeof name === 'string', name);\n\n return defined(this._properties[name]) || this._hasPropertyInHierarchy(batchId, name);\n }\n\n getPropertyNames(batchId, results) {\n this._checkBatchId(batchId);\n\n results = defined(results) ? results : [];\n results.length = 0;\n\n const propertyNames = Object.keys(this._properties);\n results.push(...propertyNames);\n\n if (this._hierarchy) {\n this._getPropertyNamesInHierarchy(batchId, results);\n }\n\n return results;\n }\n\n getProperty(batchId, name) {\n this._checkBatchId(batchId);\n assert(typeof name === 'string', name);\n\n if (this._binaryProperties) {\n const binaryProperty = this._binaryProperties[name];\n if (defined(binaryProperty)) {\n return this._getBinaryProperty(binaryProperty, batchId);\n }\n }\n\n const propertyValues = this._properties[name];\n if (defined(propertyValues)) {\n return clone(propertyValues[batchId], true);\n }\n\n // EXTENSION: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n const hierarchyProperty = this._getHierarchyProperty(batchId, name);\n if (defined(hierarchyProperty)) {\n return hierarchyProperty;\n }\n }\n\n return undefined;\n }\n\n setProperty(batchId, name, value) {\n const featureCount = this.featureCount;\n\n this._checkBatchId(batchId);\n assert(typeof name === 'string', name);\n\n if (this._binaryProperties) {\n const binaryProperty = this._binaryProperties[name];\n if (binaryProperty) {\n this._setBinaryProperty(binaryProperty, batchId, value);\n return;\n }\n }\n\n // EXTENSION: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n if (this._setHierarchyProperty(this, batchId, name, value)) {\n return;\n }\n }\n\n let propertyValues = this._properties[name];\n if (!defined(propertyValues)) {\n // Property does not exist. Create it.\n this._properties[name] = new Array(featureCount);\n propertyValues = this._properties[name];\n }\n\n propertyValues[batchId] = clone(value, true);\n }\n\n // PRIVATE METHODS\n\n _checkBatchId(batchId) {\n const valid = batchId >= 0 && batchId < this.featureCount;\n if (!valid) {\n throw new Error('batchId not in range [0, featureCount - 1].');\n }\n }\n\n _getBinaryProperty(binaryProperty, index) {\n return binaryProperty.unpack(binaryProperty.typedArray, index);\n }\n\n _setBinaryProperty(binaryProperty, index, value) {\n binaryProperty.pack(value, binaryProperty.typedArray, index);\n }\n\n _initializeBinaryProperties() {\n let binaryProperties: Record<string, any> | null = null;\n for (const name in this._properties) {\n const property = this._properties[name];\n const binaryProperty = this._initializeBinaryProperty(name, property);\n // Store any information needed to access the binary data, including the typed array,\n // componentCount (e.g. a VEC4 would be 4), and the type used to pack and unpack (e.g. Cartesian4).\n if (binaryProperty) {\n binaryProperties = binaryProperties || {};\n binaryProperties[name] = binaryProperty;\n }\n }\n return binaryProperties;\n }\n\n _initializeBinaryProperty(name, property) {\n if ('byteOffset' in property) {\n // This is a binary property\n const tile3DAccessor = property;\n\n assert(this.binary, `Property ${name} requires a batch table binary.`);\n assert(tile3DAccessor.type, `Property ${name} requires a type.`);\n\n const accessor = createTypedArrayFromAccessor(\n tile3DAccessor,\n this.binary.buffer,\n this.binary.byteOffset | 0,\n this.featureCount\n );\n\n // Store any information needed to access the binary data, including the typed array,\n // componentCount (e.g. a VEC4 would be 4), and the type used to pack and unpack (e.g. Cartesian4).\n return {\n typedArray: accessor.values,\n componentCount: accessor.size,\n unpack: accessor.unpacker,\n pack: accessor.packer\n };\n }\n\n return null;\n }\n\n // EXTENSION SUPPORT: 3DTILES_batch_table_hierarchy\n\n _hasPropertyInHierarchy(batchId, name) {\n if (!this._hierarchy) {\n return false;\n }\n\n const result = traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instances = hierarchy.classes[classId].instances;\n return defined(instances[name]);\n });\n\n return defined(result);\n }\n\n _getPropertyNamesInHierarchy(batchId, results) {\n traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instances = hierarchy.classes[classId].instances;\n for (const name in instances) {\n if (instances.hasOwnProperty(name)) {\n if (results.indexOf(name) === -1) {\n results.push(name);\n }\n }\n }\n });\n }\n\n _getHierarchyProperty(batchId, name) {\n return traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instanceClass = hierarchy.classes[classId];\n const indexInClass = hierarchy.classIndexes[instanceIndex];\n const propertyValues = instanceClass.instances[name];\n if (defined(propertyValues)) {\n if (defined(propertyValues.typedArray)) {\n return this._getBinaryProperty(propertyValues, indexInClass);\n }\n return clone(propertyValues[indexInClass], true);\n }\n return null;\n });\n }\n\n _setHierarchyProperty(batchTable, batchId, name, value) {\n const result = traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instanceClass = hierarchy.classes[classId];\n const indexInClass = hierarchy.classIndexes[instanceIndex];\n const propertyValues = instanceClass.instances[name];\n if (defined(propertyValues)) {\n assert(instanceIndex === batchId, `Inherited property \"${name}\" is read-only.`);\n if (defined(propertyValues.typedArray)) {\n this._setBinaryProperty(propertyValues, indexInClass, value);\n } else {\n propertyValues[indexInClass] = clone(value, true);\n }\n return true;\n }\n return false;\n });\n return defined(result);\n }\n}\n"],"mappings":"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"}