@loaders.gl/tile-converter 3.3.0-alpha.7 → 3.3.0

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 (136) hide show
  1. package/dist/3d-tiles-attributes-worker.d.ts +2 -2
  2. package/dist/3d-tiles-attributes-worker.d.ts.map +1 -1
  3. package/dist/3d-tiles-attributes-worker.js +2 -2
  4. package/dist/3d-tiles-attributes-worker.js.map +3 -3
  5. package/dist/converter-cli.js +14 -2
  6. package/dist/converter.min.js +22 -22
  7. package/dist/deps-installer/deps-installer.d.ts.map +1 -1
  8. package/dist/deps-installer/deps-installer.js +8 -0
  9. package/dist/dist.min.js +1407 -1242
  10. package/dist/es5/3d-tiles-attributes-worker.js +1 -1
  11. package/dist/es5/3d-tiles-attributes-worker.js.map +1 -1
  12. package/dist/es5/converter-cli.js +14 -2
  13. package/dist/es5/converter-cli.js.map +1 -1
  14. package/dist/es5/deps-installer/deps-installer.js +13 -2
  15. package/dist/es5/deps-installer/deps-installer.js.map +1 -1
  16. package/dist/es5/i3s-attributes-worker.js +1 -1
  17. package/dist/es5/i3s-attributes-worker.js.map +1 -1
  18. package/dist/es5/i3s-converter/helpers/batch-ids-extensions.js.map +1 -1
  19. package/dist/es5/i3s-converter/helpers/geometry-attributes.js +16 -7
  20. package/dist/es5/i3s-converter/helpers/geometry-attributes.js.map +1 -1
  21. package/dist/es5/i3s-converter/helpers/geometry-converter.js +363 -113
  22. package/dist/es5/i3s-converter/helpers/geometry-converter.js.map +1 -1
  23. package/dist/es5/i3s-converter/helpers/gltf-attributes.js +6 -11
  24. package/dist/es5/i3s-converter/helpers/gltf-attributes.js.map +1 -1
  25. package/dist/es5/i3s-converter/helpers/node-index-document.js +517 -0
  26. package/dist/es5/i3s-converter/helpers/node-index-document.js.map +1 -0
  27. package/dist/es5/i3s-converter/helpers/node-pages.js +455 -173
  28. package/dist/es5/i3s-converter/helpers/node-pages.js.map +1 -1
  29. package/dist/es5/i3s-converter/i3s-converter.js +549 -618
  30. package/dist/es5/i3s-converter/i3s-converter.js.map +1 -1
  31. package/dist/es5/i3s-converter/json-templates/geometry-definitions.js +107 -0
  32. package/dist/es5/i3s-converter/json-templates/geometry-definitions.js.map +1 -0
  33. package/dist/es5/i3s-converter/json-templates/layers.js +2 -93
  34. package/dist/es5/i3s-converter/json-templates/layers.js.map +1 -1
  35. package/dist/es5/i3s-converter/json-templates/shared-resources.js +3 -3
  36. package/dist/es5/i3s-converter/json-templates/shared-resources.js.map +1 -1
  37. package/dist/es5/i3s-converter/types.js.map +1 -1
  38. package/dist/es5/lib/utils/file-utils.js +93 -9
  39. package/dist/es5/lib/utils/file-utils.js.map +1 -1
  40. package/dist/es5/lib/utils/write-queue.js +38 -25
  41. package/dist/es5/lib/utils/write-queue.js.map +1 -1
  42. package/dist/es5/pgm-loader.js +1 -1
  43. package/dist/es5/pgm-loader.js.map +1 -1
  44. package/dist/es5/workers/i3s-attributes-worker.js +1 -1
  45. package/dist/es5/workers/i3s-attributes-worker.js.map +1 -1
  46. package/dist/esm/3d-tiles-attributes-worker.js +1 -1
  47. package/dist/esm/3d-tiles-attributes-worker.js.map +1 -1
  48. package/dist/esm/converter-cli.js +14 -2
  49. package/dist/esm/converter-cli.js.map +1 -1
  50. package/dist/esm/deps-installer/deps-installer.js +9 -1
  51. package/dist/esm/deps-installer/deps-installer.js.map +1 -1
  52. package/dist/esm/i3s-attributes-worker.js +1 -1
  53. package/dist/esm/i3s-attributes-worker.js.map +1 -1
  54. package/dist/esm/i3s-converter/helpers/batch-ids-extensions.js.map +1 -1
  55. package/dist/esm/i3s-converter/helpers/geometry-attributes.js +16 -7
  56. package/dist/esm/i3s-converter/helpers/geometry-attributes.js.map +1 -1
  57. package/dist/esm/i3s-converter/helpers/geometry-converter.js +150 -40
  58. package/dist/esm/i3s-converter/helpers/geometry-converter.js.map +1 -1
  59. package/dist/esm/i3s-converter/helpers/gltf-attributes.js +6 -9
  60. package/dist/esm/i3s-converter/helpers/gltf-attributes.js.map +1 -1
  61. package/dist/esm/i3s-converter/helpers/node-index-document.js +202 -0
  62. package/dist/esm/i3s-converter/helpers/node-index-document.js.map +1 -0
  63. package/dist/esm/i3s-converter/helpers/node-pages.js +162 -76
  64. package/dist/esm/i3s-converter/helpers/node-pages.js.map +1 -1
  65. package/dist/esm/i3s-converter/i3s-converter.js +115 -220
  66. package/dist/esm/i3s-converter/i3s-converter.js.map +1 -1
  67. package/dist/esm/i3s-converter/json-templates/geometry-definitions.js +89 -0
  68. package/dist/esm/i3s-converter/json-templates/geometry-definitions.js.map +1 -0
  69. package/dist/esm/i3s-converter/json-templates/layers.js +2 -85
  70. package/dist/esm/i3s-converter/json-templates/layers.js.map +1 -1
  71. package/dist/esm/i3s-converter/json-templates/shared-resources.js +3 -3
  72. package/dist/esm/i3s-converter/json-templates/shared-resources.js.map +1 -1
  73. package/dist/esm/i3s-converter/types.js.map +1 -1
  74. package/dist/esm/lib/utils/file-utils.js +44 -3
  75. package/dist/esm/lib/utils/file-utils.js.map +1 -1
  76. package/dist/esm/lib/utils/write-queue.js +19 -10
  77. package/dist/esm/lib/utils/write-queue.js.map +1 -1
  78. package/dist/esm/pgm-loader.js +1 -1
  79. package/dist/esm/pgm-loader.js.map +1 -1
  80. package/dist/esm/workers/i3s-attributes-worker.js +1 -1
  81. package/dist/esm/workers/i3s-attributes-worker.js.map +1 -1
  82. package/dist/i3s-attributes-worker.d.ts +2 -2
  83. package/dist/i3s-attributes-worker.d.ts.map +1 -1
  84. package/dist/i3s-attributes-worker.js +2 -2
  85. package/dist/i3s-attributes-worker.js.map +2 -2
  86. package/dist/i3s-converter/helpers/batch-ids-extensions.d.ts +3 -3
  87. package/dist/i3s-converter/helpers/batch-ids-extensions.js +3 -3
  88. package/dist/i3s-converter/helpers/geometry-attributes.d.ts.map +1 -1
  89. package/dist/i3s-converter/helpers/geometry-attributes.js +16 -10
  90. package/dist/i3s-converter/helpers/geometry-converter.d.ts +8 -4
  91. package/dist/i3s-converter/helpers/geometry-converter.d.ts.map +1 -1
  92. package/dist/i3s-converter/helpers/geometry-converter.js +200 -44
  93. package/dist/i3s-converter/helpers/gltf-attributes.d.ts.map +1 -1
  94. package/dist/i3s-converter/helpers/gltf-attributes.js +2 -3
  95. package/dist/i3s-converter/helpers/node-index-document.d.ts +95 -0
  96. package/dist/i3s-converter/helpers/node-index-document.d.ts.map +1 -0
  97. package/dist/i3s-converter/helpers/node-index-document.js +250 -0
  98. package/dist/i3s-converter/helpers/node-pages.d.ts +78 -43
  99. package/dist/i3s-converter/helpers/node-pages.d.ts.map +1 -1
  100. package/dist/i3s-converter/helpers/node-pages.js +195 -94
  101. package/dist/i3s-converter/i3s-converter.d.ts +33 -58
  102. package/dist/i3s-converter/i3s-converter.d.ts.map +1 -1
  103. package/dist/i3s-converter/i3s-converter.js +122 -233
  104. package/dist/i3s-converter/json-templates/geometry-definitions.d.ts +7 -0
  105. package/dist/i3s-converter/json-templates/geometry-definitions.d.ts.map +1 -0
  106. package/dist/i3s-converter/json-templates/geometry-definitions.js +87 -0
  107. package/dist/i3s-converter/json-templates/layers.d.ts +1 -30
  108. package/dist/i3s-converter/json-templates/layers.d.ts.map +1 -1
  109. package/dist/i3s-converter/json-templates/layers.js +2 -86
  110. package/dist/i3s-converter/json-templates/shared-resources.js +3 -3
  111. package/dist/i3s-converter/types.d.ts +34 -8
  112. package/dist/i3s-converter/types.d.ts.map +1 -1
  113. package/dist/lib/utils/file-utils.d.ts +17 -1
  114. package/dist/lib/utils/file-utils.d.ts.map +1 -1
  115. package/dist/lib/utils/file-utils.js +64 -7
  116. package/dist/lib/utils/write-queue.d.ts +19 -3
  117. package/dist/lib/utils/write-queue.d.ts.map +1 -1
  118. package/dist/lib/utils/write-queue.js +18 -12
  119. package/dist/workers/i3s-attributes-worker.js +1 -1
  120. package/package.json +25 -20
  121. package/src/converter-cli.ts +22 -2
  122. package/src/deps-installer/deps-installer.ts +9 -0
  123. package/src/i3s-converter/helpers/batch-ids-extensions.ts +3 -3
  124. package/src/i3s-converter/helpers/geometry-attributes.ts +16 -11
  125. package/src/i3s-converter/helpers/geometry-converter.ts +217 -48
  126. package/src/i3s-converter/helpers/gltf-attributes.ts +2 -3
  127. package/src/i3s-converter/helpers/node-index-document.ts +315 -0
  128. package/src/i3s-converter/helpers/node-pages.ts +215 -110
  129. package/src/i3s-converter/i3s-converter.ts +170 -312
  130. package/src/i3s-converter/json-templates/geometry-definitions.ts +83 -0
  131. package/src/i3s-converter/json-templates/layers.ts +2 -91
  132. package/src/i3s-converter/json-templates/shared-resources.ts +3 -3
  133. package/src/i3s-converter/types.ts +29 -2
  134. package/src/lib/utils/file-utils.ts +62 -7
  135. package/src/lib/utils/write-queue.ts +36 -15
  136. package/src/workers/i3s-attributes-worker.ts +2 -1
@@ -6,7 +6,7 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports._typecheckI3SAttributesWorker = exports.Tile3dAttributesWorker = void 0;
7
7
  exports.transform3DTilesAttributesOnWorker = transform3DTilesAttributesOnWorker;
8
8
  var _workerUtils = require("@loaders.gl/worker-utils");
9
- var VERSION = typeof "3.3.0-alpha.7" !== 'undefined' ? "3.3.0-alpha.7" : 'latest';
9
+ var VERSION = typeof "3.3.0" !== 'undefined' ? "3.3.0" : 'latest';
10
10
  var Tile3dAttributesWorker = {
11
11
  id: '3d-tiles-attributes',
12
12
  name: '3DTiles Attributes Worker',
@@ -1 +1 @@
1
- {"version":3,"file":"3d-tiles-attributes-worker.js","names":["VERSION","Tile3dAttributesWorker","id","name","module","version","options","featureAttributes","transform3DTilesAttributesOnWorker","i3sAttributesData","processOnWorker","_typecheckI3SAttributesWorker"],"sources":["../../src/3d-tiles-attributes-worker.ts"],"sourcesContent":["import type {WorkerObject} from '@loaders.gl/worker-utils';\nimport type {FeatureAttribute} from '@loaders.gl/i3s';\n\nimport {processOnWorker} from '@loaders.gl/worker-utils';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nexport type Tile3DAttributesWorkerOptions = {\n featureAttributes: FeatureAttribute | null;\n source: string;\n};\n\nexport type I3SAttributesData = {\n tileContent: any;\n textureFormat: string;\n};\n\n/**\n * I3S Attributes Worker to handle B3DM object\n */\nexport const Tile3dAttributesWorker = {\n id: '3d-tiles-attributes',\n name: '3DTiles Attributes Worker',\n module: 'tile-converter',\n version: VERSION,\n options: {\n featureAttributes: null\n }\n};\n\n/**\n * Performs I3S attributes transformation\n */\nexport function transform3DTilesAttributesOnWorker(\n i3sAttributesData: I3SAttributesData,\n options: Tile3DAttributesWorkerOptions\n): Promise<ArrayBuffer> {\n return processOnWorker(Tile3dAttributesWorker, i3sAttributesData, options);\n}\n\nexport const _typecheckI3SAttributesWorker: WorkerObject = Tile3dAttributesWorker;\n"],"mappings":";;;;;;;AAGA;AAIA,IAAMA,OAAO,GAAG,sBAAkB,KAAK,WAAW,qBAAiB,QAAQ;AAepE,IAAMC,sBAAsB,GAAG;EACpCC,EAAE,EAAE,qBAAqB;EACzBC,IAAI,EAAE,2BAA2B;EACjCC,MAAM,EAAE,gBAAgB;EACxBC,OAAO,EAAEL,OAAO;EAChBM,OAAO,EAAE;IACPC,iBAAiB,EAAE;EACrB;AACF,CAAC;;AAAC;AAKK,SAASC,kCAAkC,CAChDC,iBAAoC,EACpCH,OAAsC,EAChB;EACtB,OAAO,IAAAI,4BAAe,EAACT,sBAAsB,EAAEQ,iBAAiB,EAAEH,OAAO,CAAC;AAC5E;AAEO,IAAMK,6BAA2C,GAAGV,sBAAsB;AAAC"}
1
+ {"version":3,"file":"3d-tiles-attributes-worker.js","names":["VERSION","Tile3dAttributesWorker","id","name","module","version","options","featureAttributes","transform3DTilesAttributesOnWorker","i3sAttributesData","processOnWorker","_typecheckI3SAttributesWorker"],"sources":["../../src/3d-tiles-attributes-worker.ts"],"sourcesContent":["import type {WorkerObject} from '@loaders.gl/worker-utils';\nimport type {FeatureAttribute} from '@loaders.gl/i3s';\n\nimport {processOnWorker} from '@loaders.gl/worker-utils';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nexport type Tile3DAttributesWorkerOptions = {\n featureAttributes: FeatureAttribute | null;\n source: string;\n};\n\nexport type I3SAttributesData = {\n tileContent: any;\n textureFormat: string;\n};\n\n/**\n * I3S Attributes Worker to handle B3DM object\n */\nexport const Tile3dAttributesWorker = {\n id: '3d-tiles-attributes',\n name: '3DTiles Attributes Worker',\n module: 'tile-converter',\n version: VERSION,\n options: {\n featureAttributes: null\n }\n};\n\n/**\n * Performs I3S attributes transformation\n */\nexport function transform3DTilesAttributesOnWorker(\n i3sAttributesData: I3SAttributesData,\n options: Tile3DAttributesWorkerOptions\n): Promise<ArrayBuffer> {\n return processOnWorker(Tile3dAttributesWorker, i3sAttributesData, options);\n}\n\nexport const _typecheckI3SAttributesWorker: WorkerObject = Tile3dAttributesWorker;\n"],"mappings":";;;;;;;AAGA;AAIA,IAAMA,OAAO,GAAG,cAAkB,KAAK,WAAW,aAAiB,QAAQ;AAepE,IAAMC,sBAAsB,GAAG;EACpCC,EAAE,EAAE,qBAAqB;EACzBC,IAAI,EAAE,2BAA2B;EACjCC,MAAM,EAAE,gBAAgB;EACxBC,OAAO,EAAEL,OAAO;EAChBM,OAAO,EAAE;IACPC,iBAAiB,EAAE;EACrB;AACF,CAAC;;AAAC;AAKK,SAASC,kCAAkC,CAChDC,iBAAoC,EACpCH,OAAsC,EAChB;EACtB,OAAO,IAAAI,4BAAe,EAACT,sBAAsB,EAAEQ,iBAAiB,EAAEH,OAAO,CAAC;AAC5E;AAEO,IAAMK,6BAA2C,GAAGV,sBAAsB;AAAC"}
@@ -61,6 +61,8 @@ function printHelp() {
61
61
  console.log('--max-depth [Maximal depth of hierarchical tiles tree traversal, default: infinite]');
62
62
  console.log('--name [Tileset name]');
63
63
  console.log('--output [Output folder, default: "data" folder]');
64
+ console.log('--instant-node-writing [Keep created 3DNodeIndexDocument files on disk instead of memory. This option reduce memory usage but decelerates conversion speed]');
65
+ console.log('--split-nodes [Prevent to merge similar materials that could lead to incorrect visualization (I3S to 3DTiles conversion only)]');
64
66
  console.log('--slpk [Generate slpk (Scene Layer Packages) I3S output file]');
65
67
  console.log('--tileset [tileset.json file (3DTiles) / http://..../SceneServer/layers/0 resource (I3S)]');
66
68
  console.log('--input-type [tileset input type: I3S or 3DTILES]');
@@ -114,9 +116,11 @@ function _convert() {
114
116
  egmFilePath: options.egm,
115
117
  token: options.token,
116
118
  draco: options.draco,
119
+ mergeMaterials: options.mergeMaterials,
117
120
  generateTextures: options.generateTextures,
118
121
  generateBoundingVolumes: options.generateBoundingVolumes,
119
- validate: options.validate
122
+ validate: options.validate,
123
+ instantNodeWriting: options.instantNodeWriting
120
124
  });
121
125
  case 13:
122
126
  return _context2.abrupt("break", 15);
@@ -184,6 +188,8 @@ function validateOptionsWithEqual(args) {
184
188
  function parseOptions(args) {
185
189
  var opts = {
186
190
  output: 'data',
191
+ instantNodeWriting: false,
192
+ mergeMaterials: true,
187
193
  sevenZipExe: 'C:\\Program Files\\7-Zip\\7z.exe',
188
194
  egm: (0, _path.join)(process.cwd(), 'deps', 'egm2008-5.pgm'),
189
195
  draco: true,
@@ -209,6 +215,12 @@ function parseOptions(args) {
209
215
  case '--output':
210
216
  opts.output = getStringValue(index, args);
211
217
  break;
218
+ case '--instant-node-writing':
219
+ opts.instantNodeWriting = getBooleanValue(index, args);
220
+ break;
221
+ case '--split-nodes':
222
+ opts.mergeMaterials = getBooleanValue(index, args);
223
+ break;
212
224
  case '--max-depth':
213
225
  opts.maxDepth = getIntegerValue(index, args);
214
226
  break;
@@ -280,7 +292,7 @@ function getIntegerValue(index, args) {
280
292
  }
281
293
  function getBooleanValue(index, args) {
282
294
  var stringValue = getStringValue(index, args).toLowerCase().trim();
283
- if (args[index] === '--no-draco' && !stringValue) {
295
+ if (['--no-draco', '--split-nodes'].includes(args[index]) && !stringValue) {
284
296
  return false;
285
297
  }
286
298
  if (!stringValue || stringValue === 'true') {
@@ -1 +1 @@
1
- {"version":3,"file":"converter-cli.js","names":["TILESET_TYPE","I3S","_3DTILES","main","process","argv","args","length","printHelp","validatedOptionsArr","validateOptionsWithEqual","options","parseOptions","installDependencies","depthInstaller","DepsInstaller","install","validatedOptions","validateOptions","convert","catch","error","console","log","exit","inputType","toUpperCase","tiles3DConverter","Tiles3DConverter","inputUrl","tileset","outputPath","output","tilesetName","name","maxDepth","egmFilePath","egm","converter","I3SConverter","slpk","sevenZipExe","token","draco","generateTextures","generateBoundingVolumes","validate","mandatoryOptionsWithExceptions","exceptions","mandatoryOption","optionValue","isWrongInputType","Boolean","Object","values","includes","push","forEach","exeption","reduce","acc","curr","equalSignIndex","indexOf","beforeEqual","slice","afterEqual","condition","startsWith","concat","opts","join","cwd","arg","index","getStringValue","getURLValue","getIntegerValue","getBooleanValue","warn","value","replace","stringValue","result","Number","parseInt","isFinite","NaN","toLowerCase","trim"],"sources":["../../src/converter-cli.ts"],"sourcesContent":["/* eslint-disable no-console */\nimport '@loaders.gl/polyfills';\nimport {join} from 'path';\nimport {I3SConverter, Tiles3DConverter} from '@loaders.gl/tile-converter';\nimport {DepsInstaller} from './deps-installer/deps-installer';\n\ntype TileConversionOptions = {\n /** \"I3S\" - for I3S to 3DTiles conversion, \"3DTILES\" for 3DTiles to I3S conversion */\n inputType?: string;\n /** \"tileset.json\" file (3DTiles) / \"http://..../SceneServer/layers/0\" resource (I3S) */\n tileset?: string;\n /** Tileset name. This option is used for naming in resulting json resouces and for resulting path/*.slpk file naming */\n name?: string;\n /** Output folder. This folder will be created by converter if doesn't exist. It is relative to the converter path.\n * Default: \"data\" folder */\n output: string;\n /** 3DTiles->I3S only. location of 7z.exe archiver to create slpk on Windows OS, default: \"C:\\Program Files\\7-Zip\\7z.exe\" */\n sevenZipExe: string;\n /** location of the Earth Gravity Model (*.pgm) file to convert heights from ellipsoidal to gravity-related format,\n * default: \"./deps/egm2008-5.pgm\". A model file can be loaded from GeographicLib\n * https://geographiclib.sourceforge.io/html/geoid.html */\n egm: string;\n /** 3DTile->I3S only. Token for Cesium ION tileset authentication. */\n token?: string;\n /** 3DTiles->I3S only. Enable draco compression for geometry. Default: true */\n draco: boolean;\n /** Run the script for installing dependencies. Run this options separate from others. Now \"*.pgm\" file installation is\n * implemented */\n installDependencies: boolean;\n /** 3DTile->I3S only. Enable KTX2 textures generation if only one of (JPG, PNG) texture is provided or generate JPG texture\n * if only KTX2 is provided */\n generateTextures: boolean;\n /** 3DTile->I3S only. Will generate obb and mbs bounding volumes from geometry */\n generateBoundingVolumes: boolean;\n /** Validate the dataset during conversion. Validation messages will be posted in the console output */\n validate: boolean;\n /** Maximal depth of the hierarchical tiles tree traversal, default: infinite */\n maxDepth?: number;\n /** 3DTiles->I3S only. Whether the converter generates *.slpk (Scene Layer Package) I3S output file */\n slpk: boolean;\n};\n\n/* During validation we check that particular options are defined so they can't be undefined */\ntype ValidatedTileConversionOptions = TileConversionOptions & {\n /** \"I3S\" - for I3S to 3DTiles conversion, \"3DTILES\" for 3DTiles to I3S conversion */\n inputType: string;\n /** \"tileset.json\" file (3DTiles) / \"http://..../SceneServer/layers/0\" resource (I3S) */\n tileset: string;\n /** Tileset name. This option is used for naming in resulting json resouces and for resulting path/*.slpk file naming */\n name: string;\n};\n\nconst TILESET_TYPE = {\n I3S: 'I3S',\n _3DTILES: '3DTILES'\n};\n\n/**\n * CLI entry\n * @returns\n */\nasync function main() {\n const [, , ...args] = process.argv;\n\n if (args.length === 0) {\n printHelp();\n }\n\n const validatedOptionsArr = validateOptionsWithEqual(args);\n\n const options: TileConversionOptions = parseOptions(validatedOptionsArr);\n\n if (options.installDependencies) {\n const depthInstaller = new DepsInstaller();\n depthInstaller.install('deps');\n return;\n }\n\n const validatedOptions: ValidatedTileConversionOptions = validateOptions(options);\n\n await convert(validatedOptions);\n}\n\nmain().catch((error) => {\n console.log(error);\n process.exit(1); // eslint-disable-line\n});\n\n/**\n * Output for `npx tile-converter --help`\n */\nfunction printHelp(): void {\n console.log('cli: converter 3dTiles to I3S or I3S to 3dTiles...');\n console.log(\n '--install-dependencies [Run the script for installing dependencies. Run this options separate from others. Now \"*.pgm\" file installation is implemented]'\n );\n console.log(\n '--max-depth [Maximal depth of hierarchical tiles tree traversal, default: infinite]'\n );\n console.log('--name [Tileset name]');\n console.log('--output [Output folder, default: \"data\" folder]');\n console.log('--slpk [Generate slpk (Scene Layer Packages) I3S output file]');\n console.log(\n '--tileset [tileset.json file (3DTiles) / http://..../SceneServer/layers/0 resource (I3S)]'\n );\n console.log('--input-type [tileset input type: I3S or 3DTILES]');\n console.log(\n '--7zExe [location of 7z.exe archiver to create slpk on Windows, default: \"C:\\\\Program Files\\\\7-Zip\\\\7z.exe\"]'\n );\n console.log(\n '--egm [location of Earth Gravity Model *.pgm file to convert heights from ellipsoidal to gravity-related format. A model file can be loaded from GeographicLib https://geographiclib.sourceforge.io/html/geoid.html], default: \"./deps/egm2008-5.zip\"'\n );\n console.log('--token [Token for Cesium ION tilesets authentication]');\n console.log('--no-draco [Disable draco compression for geometry]');\n console.log(\n '--generate-textures [Enable KTX2 textures generation if only one of (JPG, PNG) texture is provided or generate JPG texture if only KTX2 is provided]'\n );\n console.log(\n '--generate-bounding-volumes [Will generate obb and mbs bounding volumes from geometry]'\n );\n console.log('--validate [Enable validation]');\n process.exit(0); // eslint-disable-line\n}\n\n/**\n * Run conversion process\n * @param options validated tile-converter options\n */\nasync function convert(options: ValidatedTileConversionOptions) {\n console.log(`------------------------------------------------`); // eslint-disable-line\n console.log(`Starting conversion of ${options.inputType}`); // eslint-disable-line\n console.log(`------------------------------------------------`); // eslint-disable-line\n const inputType = options.inputType.toUpperCase();\n switch (inputType) {\n case TILESET_TYPE.I3S:\n const tiles3DConverter = new Tiles3DConverter();\n tiles3DConverter.convert({\n inputUrl: options.tileset,\n outputPath: options.output,\n tilesetName: options.name,\n maxDepth: options.maxDepth,\n egmFilePath: options.egm\n });\n break;\n case TILESET_TYPE._3DTILES:\n const converter = new I3SConverter();\n await converter.convert({\n inputUrl: options.tileset,\n outputPath: options.output,\n tilesetName: options.name,\n maxDepth: options.maxDepth,\n slpk: options.slpk,\n sevenZipExe: options.sevenZipExe,\n egmFilePath: options.egm,\n token: options.token,\n draco: options.draco,\n generateTextures: options.generateTextures,\n generateBoundingVolumes: options.generateBoundingVolumes,\n validate: options.validate\n });\n break;\n default:\n printHelp();\n }\n}\n\n// OPTIONS\n/**\n * Validate input options of the CLI command\n * @param options - input options of the CLI command\n * @returns validated options\n */\nfunction validateOptions(options: TileConversionOptions): ValidatedTileConversionOptions {\n const mandatoryOptionsWithExceptions: {\n [key: string]: () => void;\n } = {\n name: () => console.log('Missed: --name [Tileset name]'),\n output: () => console.log('Missed: --output [Output path name]'),\n sevenZipExe: () => console.log('Missed: --7zExe [7z archiver executable path]'),\n egm: () => console.log('Missed: --egm [*.pgm earth gravity model file path]'),\n tileset: () => console.log('Missed: --tileset [tileset.json file]'),\n inputType: () =>\n console.log('Missed/Incorrect: --input-type [tileset input type: I3S or 3DTILES]')\n };\n const exceptions: (() => void)[] = [];\n for (const mandatoryOption in mandatoryOptionsWithExceptions) {\n const optionValue = options[mandatoryOption];\n const isWrongInputType =\n Boolean(optionValue) &&\n mandatoryOption === 'inputType' &&\n !Object.values(TILESET_TYPE).includes(optionValue.toUpperCase());\n\n if (!optionValue || isWrongInputType) {\n exceptions.push(mandatoryOptionsWithExceptions[mandatoryOption]);\n }\n }\n if (exceptions.length) {\n exceptions.forEach((exeption) => exeption());\n process.exit(1);\n }\n return <ValidatedTileConversionOptions>options;\n}\n\nfunction validateOptionsWithEqual(args: string[]): string[] {\n return args.reduce((acc: string[], curr) => {\n const equalSignIndex = curr.indexOf('=');\n const beforeEqual = curr.slice(0, equalSignIndex);\n const afterEqual = curr.slice(equalSignIndex + 1, curr.length);\n const condition = curr.includes('=') && curr.startsWith('--') && afterEqual;\n if (condition) {\n return acc.concat(beforeEqual, afterEqual);\n }\n return acc.concat(curr);\n }, []);\n}\n\n/**\n * Parse option from the cli arguments array\n * @param args\n * @returns\n */\nfunction parseOptions(args: string[]): TileConversionOptions {\n const opts: TileConversionOptions = {\n output: 'data',\n sevenZipExe: 'C:\\\\Program Files\\\\7-Zip\\\\7z.exe',\n egm: join(process.cwd(), 'deps', 'egm2008-5.pgm'),\n draco: true,\n installDependencies: false,\n generateTextures: false,\n generateBoundingVolumes: false,\n validate: false,\n slpk: false\n };\n\n // eslint-disable-next-line complexity\n args.forEach((arg, index) => {\n if (arg.indexOf('--') === 0) {\n switch (arg) {\n case '--input-type':\n opts.inputType = getStringValue(index, args);\n break;\n case '--tileset':\n opts.tileset = getURLValue(index, args);\n break;\n case '--name':\n opts.name = getStringValue(index, args);\n break;\n case '--output':\n opts.output = getStringValue(index, args);\n break;\n case '--max-depth':\n opts.maxDepth = getIntegerValue(index, args);\n break;\n case '--slpk':\n opts.slpk = getBooleanValue(index, args);\n break;\n case '--7zExe':\n opts.sevenZipExe = getStringValue(index, args);\n break;\n case '--egm':\n opts.egm = getStringValue(index, args);\n break;\n case '--token':\n opts.token = getStringValue(index, args);\n break;\n case '--no-draco':\n opts.draco = getBooleanValue(index, args);\n break;\n case '--validate':\n opts.validate = getBooleanValue(index, args);\n break;\n case '--install-dependencies':\n opts.installDependencies = getBooleanValue(index, args);\n break;\n case '--generate-textures':\n opts.generateTextures = getBooleanValue(index, args);\n break;\n case '--generate-bounding-volumes':\n opts.generateBoundingVolumes = getBooleanValue(index, args);\n break;\n case '--help':\n printHelp();\n break;\n default:\n console.warn(`Unknown option ${arg}`);\n process.exit(0); // eslint-disable-line\n }\n }\n });\n return opts;\n}\n\n/**\n * Get string option value from cli arguments\n * @param index - option's name index in the argument's array.\n * The value of the option should be next to name of the option.\n * @param args - cli arguments array\n * @returns - string value of the option\n */\nfunction getStringValue(index: number, args: string[]): string {\n if (index + 1 >= args.length) {\n return '';\n }\n const value = args[index + 1];\n if (value.indexOf('--') === 0) {\n return '';\n }\n return value;\n}\n\n/**\n * Modyfy URL path to be compatible with fetch\n * @param index - option's name index in the argument's array.\n * The value of the option should be next to name of the option.\n * @param args - cli arguments array\n * @returns - string value of the option\n */\nfunction getURLValue(index: number, args: string[]): string {\n const value = getStringValue(index, args);\n console.log(`Input tileset value: ${value}`);\n console.log(`Modified tileset value: ${value.replace(/\\\\/g, '/')}`);\n return value.replace(/\\\\/g, '/');\n}\n\n/**\n * Get integer option value from cli arguments\n * @param index - option's name index in the argument's array\n * The value of the option should be next to name of the option.\n * @param args - cli arguments array\n * @returns - number value of the option\n */\nfunction getIntegerValue(index: number, args: string[]): number {\n const stringValue: string = getStringValue(index, args);\n const result: number = Number.parseInt(stringValue);\n if (isFinite(result)) {\n return result;\n }\n return NaN;\n}\n\nfunction getBooleanValue(index: number, args: string[]): boolean {\n const stringValue: string = getStringValue(index, args).toLowerCase().trim();\n if (args[index] === '--no-draco' && !stringValue) {\n return false;\n }\n if (!stringValue || stringValue === 'true') {\n return true;\n }\n return false;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"converter-cli.js","names":["TILESET_TYPE","I3S","_3DTILES","main","process","argv","args","length","printHelp","validatedOptionsArr","validateOptionsWithEqual","options","parseOptions","installDependencies","depthInstaller","DepsInstaller","install","validatedOptions","validateOptions","convert","catch","error","console","log","exit","inputType","toUpperCase","tiles3DConverter","Tiles3DConverter","inputUrl","tileset","outputPath","output","tilesetName","name","maxDepth","egmFilePath","egm","converter","I3SConverter","slpk","sevenZipExe","token","draco","mergeMaterials","generateTextures","generateBoundingVolumes","validate","instantNodeWriting","mandatoryOptionsWithExceptions","exceptions","mandatoryOption","optionValue","isWrongInputType","Boolean","Object","values","includes","push","forEach","exeption","reduce","acc","curr","equalSignIndex","indexOf","beforeEqual","slice","afterEqual","condition","startsWith","concat","opts","join","cwd","arg","index","getStringValue","getURLValue","getBooleanValue","getIntegerValue","warn","value","replace","stringValue","result","Number","parseInt","isFinite","NaN","toLowerCase","trim"],"sources":["../../src/converter-cli.ts"],"sourcesContent":["/* eslint-disable no-console */\nimport '@loaders.gl/polyfills';\nimport {join} from 'path';\nimport {I3SConverter, Tiles3DConverter} from '@loaders.gl/tile-converter';\nimport {DepsInstaller} from './deps-installer/deps-installer';\n\ntype TileConversionOptions = {\n /** \"I3S\" - for I3S to 3DTiles conversion, \"3DTILES\" for 3DTiles to I3S conversion */\n inputType?: string;\n /** \"tileset.json\" file (3DTiles) / \"http://..../SceneServer/layers/0\" resource (I3S) */\n tileset?: string;\n /** Tileset name. This option is used for naming in resulting json resouces and for resulting path/*.slpk file naming */\n name?: string;\n /** Output folder. This folder will be created by converter if doesn't exist. It is relative to the converter path.\n * Default: \"data\" folder */\n output: string;\n /** Keep created 3DNodeIndexDocument files on disk instead of memory. This option reduce memory usage but decelerates conversion speed */\n instantNodeWriting: boolean;\n /** Try to merge similar materials to be able to merge meshes into one node (I3S to 3DTiles conversion only) */\n mergeMaterials: boolean;\n /** 3DTiles->I3S only. location of 7z.exe archiver to create slpk on Windows OS, default: \"C:\\Program Files\\7-Zip\\7z.exe\" */\n sevenZipExe: string;\n /** location of the Earth Gravity Model (*.pgm) file to convert heights from ellipsoidal to gravity-related format,\n * default: \"./deps/egm2008-5.pgm\". A model file can be loaded from GeographicLib\n * https://geographiclib.sourceforge.io/html/geoid.html */\n egm: string;\n /** 3DTile->I3S only. Token for Cesium ION tileset authentication. */\n token?: string;\n /** 3DTiles->I3S only. Enable draco compression for geometry. Default: true */\n draco: boolean;\n /** Run the script for installing dependencies. Run this options separate from others. Now \"*.pgm\" file installation is\n * implemented */\n installDependencies: boolean;\n /** 3DTile->I3S only. Enable KTX2 textures generation if only one of (JPG, PNG) texture is provided or generate JPG texture\n * if only KTX2 is provided */\n generateTextures: boolean;\n /** 3DTile->I3S only. Will generate obb and mbs bounding volumes from geometry */\n generateBoundingVolumes: boolean;\n /** Validate the dataset during conversion. Validation messages will be posted in the console output */\n validate: boolean;\n /** Maximal depth of the hierarchical tiles tree traversal, default: infinite */\n maxDepth?: number;\n /** 3DTiles->I3S only. Whether the converter generates *.slpk (Scene Layer Package) I3S output file */\n slpk: boolean;\n};\n\n/* During validation we check that particular options are defined so they can't be undefined */\ntype ValidatedTileConversionOptions = TileConversionOptions & {\n /** \"I3S\" - for I3S to 3DTiles conversion, \"3DTILES\" for 3DTiles to I3S conversion */\n inputType: string;\n /** \"tileset.json\" file (3DTiles) / \"http://..../SceneServer/layers/0\" resource (I3S) */\n tileset: string;\n /** Tileset name. This option is used for naming in resulting json resouces and for resulting path/*.slpk file naming */\n name: string;\n};\n\nconst TILESET_TYPE = {\n I3S: 'I3S',\n _3DTILES: '3DTILES'\n};\n\n/**\n * CLI entry\n * @returns\n */\nasync function main() {\n const [, , ...args] = process.argv;\n\n if (args.length === 0) {\n printHelp();\n }\n\n const validatedOptionsArr = validateOptionsWithEqual(args);\n\n const options: TileConversionOptions = parseOptions(validatedOptionsArr);\n\n if (options.installDependencies) {\n const depthInstaller = new DepsInstaller();\n depthInstaller.install('deps');\n return;\n }\n\n const validatedOptions: ValidatedTileConversionOptions = validateOptions(options);\n\n await convert(validatedOptions);\n}\n\nmain().catch((error) => {\n console.log(error);\n process.exit(1); // eslint-disable-line\n});\n\n/**\n * Output for `npx tile-converter --help`\n */\nfunction printHelp(): void {\n console.log('cli: converter 3dTiles to I3S or I3S to 3dTiles...');\n console.log(\n '--install-dependencies [Run the script for installing dependencies. Run this options separate from others. Now \"*.pgm\" file installation is implemented]'\n );\n console.log(\n '--max-depth [Maximal depth of hierarchical tiles tree traversal, default: infinite]'\n );\n console.log('--name [Tileset name]');\n console.log('--output [Output folder, default: \"data\" folder]');\n console.log(\n '--instant-node-writing [Keep created 3DNodeIndexDocument files on disk instead of memory. This option reduce memory usage but decelerates conversion speed]'\n );\n console.log(\n '--split-nodes [Prevent to merge similar materials that could lead to incorrect visualization (I3S to 3DTiles conversion only)]'\n );\n console.log('--slpk [Generate slpk (Scene Layer Packages) I3S output file]');\n console.log(\n '--tileset [tileset.json file (3DTiles) / http://..../SceneServer/layers/0 resource (I3S)]'\n );\n console.log('--input-type [tileset input type: I3S or 3DTILES]');\n console.log(\n '--7zExe [location of 7z.exe archiver to create slpk on Windows, default: \"C:\\\\Program Files\\\\7-Zip\\\\7z.exe\"]'\n );\n console.log(\n '--egm [location of Earth Gravity Model *.pgm file to convert heights from ellipsoidal to gravity-related format. A model file can be loaded from GeographicLib https://geographiclib.sourceforge.io/html/geoid.html], default: \"./deps/egm2008-5.zip\"'\n );\n console.log('--token [Token for Cesium ION tilesets authentication]');\n console.log('--no-draco [Disable draco compression for geometry]');\n console.log(\n '--generate-textures [Enable KTX2 textures generation if only one of (JPG, PNG) texture is provided or generate JPG texture if only KTX2 is provided]'\n );\n console.log(\n '--generate-bounding-volumes [Will generate obb and mbs bounding volumes from geometry]'\n );\n console.log('--validate [Enable validation]');\n process.exit(0); // eslint-disable-line\n}\n\n/**\n * Run conversion process\n * @param options validated tile-converter options\n */\nasync function convert(options: ValidatedTileConversionOptions) {\n console.log(`------------------------------------------------`); // eslint-disable-line\n console.log(`Starting conversion of ${options.inputType}`); // eslint-disable-line\n console.log(`------------------------------------------------`); // eslint-disable-line\n const inputType = options.inputType.toUpperCase();\n switch (inputType) {\n case TILESET_TYPE.I3S:\n const tiles3DConverter = new Tiles3DConverter();\n tiles3DConverter.convert({\n inputUrl: options.tileset,\n outputPath: options.output,\n tilesetName: options.name,\n maxDepth: options.maxDepth,\n egmFilePath: options.egm\n });\n break;\n case TILESET_TYPE._3DTILES:\n const converter = new I3SConverter();\n await converter.convert({\n inputUrl: options.tileset,\n outputPath: options.output,\n tilesetName: options.name,\n maxDepth: options.maxDepth,\n slpk: options.slpk,\n sevenZipExe: options.sevenZipExe,\n egmFilePath: options.egm,\n token: options.token,\n draco: options.draco,\n mergeMaterials: options.mergeMaterials,\n generateTextures: options.generateTextures,\n generateBoundingVolumes: options.generateBoundingVolumes,\n validate: options.validate,\n instantNodeWriting: options.instantNodeWriting\n });\n break;\n default:\n printHelp();\n }\n}\n\n// OPTIONS\n/**\n * Validate input options of the CLI command\n * @param options - input options of the CLI command\n * @returns validated options\n */\nfunction validateOptions(options: TileConversionOptions): ValidatedTileConversionOptions {\n const mandatoryOptionsWithExceptions: {\n [key: string]: () => void;\n } = {\n name: () => console.log('Missed: --name [Tileset name]'),\n output: () => console.log('Missed: --output [Output path name]'),\n sevenZipExe: () => console.log('Missed: --7zExe [7z archiver executable path]'),\n egm: () => console.log('Missed: --egm [*.pgm earth gravity model file path]'),\n tileset: () => console.log('Missed: --tileset [tileset.json file]'),\n inputType: () =>\n console.log('Missed/Incorrect: --input-type [tileset input type: I3S or 3DTILES]')\n };\n const exceptions: (() => void)[] = [];\n for (const mandatoryOption in mandatoryOptionsWithExceptions) {\n const optionValue = options[mandatoryOption];\n const isWrongInputType =\n Boolean(optionValue) &&\n mandatoryOption === 'inputType' &&\n !Object.values(TILESET_TYPE).includes(optionValue.toUpperCase());\n\n if (!optionValue || isWrongInputType) {\n exceptions.push(mandatoryOptionsWithExceptions[mandatoryOption]);\n }\n }\n if (exceptions.length) {\n exceptions.forEach((exeption) => exeption());\n process.exit(1);\n }\n return <ValidatedTileConversionOptions>options;\n}\n\nfunction validateOptionsWithEqual(args: string[]): string[] {\n return args.reduce((acc: string[], curr) => {\n const equalSignIndex = curr.indexOf('=');\n const beforeEqual = curr.slice(0, equalSignIndex);\n const afterEqual = curr.slice(equalSignIndex + 1, curr.length);\n const condition = curr.includes('=') && curr.startsWith('--') && afterEqual;\n if (condition) {\n return acc.concat(beforeEqual, afterEqual);\n }\n return acc.concat(curr);\n }, []);\n}\n\n/**\n * Parse option from the cli arguments array\n * @param args\n * @returns\n */\nfunction parseOptions(args: string[]): TileConversionOptions {\n const opts: TileConversionOptions = {\n output: 'data',\n instantNodeWriting: false,\n mergeMaterials: true,\n sevenZipExe: 'C:\\\\Program Files\\\\7-Zip\\\\7z.exe',\n egm: join(process.cwd(), 'deps', 'egm2008-5.pgm'),\n draco: true,\n installDependencies: false,\n generateTextures: false,\n generateBoundingVolumes: false,\n validate: false,\n slpk: false\n };\n\n // eslint-disable-next-line complexity\n args.forEach((arg, index) => {\n if (arg.indexOf('--') === 0) {\n switch (arg) {\n case '--input-type':\n opts.inputType = getStringValue(index, args);\n break;\n case '--tileset':\n opts.tileset = getURLValue(index, args);\n break;\n case '--name':\n opts.name = getStringValue(index, args);\n break;\n case '--output':\n opts.output = getStringValue(index, args);\n break;\n case '--instant-node-writing':\n opts.instantNodeWriting = getBooleanValue(index, args);\n break;\n case '--split-nodes':\n opts.mergeMaterials = getBooleanValue(index, args);\n break;\n case '--max-depth':\n opts.maxDepth = getIntegerValue(index, args);\n break;\n case '--slpk':\n opts.slpk = getBooleanValue(index, args);\n break;\n case '--7zExe':\n opts.sevenZipExe = getStringValue(index, args);\n break;\n case '--egm':\n opts.egm = getStringValue(index, args);\n break;\n case '--token':\n opts.token = getStringValue(index, args);\n break;\n case '--no-draco':\n opts.draco = getBooleanValue(index, args);\n break;\n case '--validate':\n opts.validate = getBooleanValue(index, args);\n break;\n case '--install-dependencies':\n opts.installDependencies = getBooleanValue(index, args);\n break;\n case '--generate-textures':\n opts.generateTextures = getBooleanValue(index, args);\n break;\n case '--generate-bounding-volumes':\n opts.generateBoundingVolumes = getBooleanValue(index, args);\n break;\n case '--help':\n printHelp();\n break;\n default:\n console.warn(`Unknown option ${arg}`);\n process.exit(0); // eslint-disable-line\n }\n }\n });\n return opts;\n}\n\n/**\n * Get string option value from cli arguments\n * @param index - option's name index in the argument's array.\n * The value of the option should be next to name of the option.\n * @param args - cli arguments array\n * @returns - string value of the option\n */\nfunction getStringValue(index: number, args: string[]): string {\n if (index + 1 >= args.length) {\n return '';\n }\n const value = args[index + 1];\n if (value.indexOf('--') === 0) {\n return '';\n }\n return value;\n}\n\n/**\n * Modyfy URL path to be compatible with fetch\n * @param index - option's name index in the argument's array.\n * The value of the option should be next to name of the option.\n * @param args - cli arguments array\n * @returns - string value of the option\n */\nfunction getURLValue(index: number, args: string[]): string {\n const value = getStringValue(index, args);\n console.log(`Input tileset value: ${value}`);\n console.log(`Modified tileset value: ${value.replace(/\\\\/g, '/')}`);\n return value.replace(/\\\\/g, '/');\n}\n\n/**\n * Get integer option value from cli arguments\n * @param index - option's name index in the argument's array\n * The value of the option should be next to name of the option.\n * @param args - cli arguments array\n * @returns - number value of the option\n */\nfunction getIntegerValue(index: number, args: string[]): number {\n const stringValue: string = getStringValue(index, args);\n const result: number = Number.parseInt(stringValue);\n if (isFinite(result)) {\n return result;\n }\n return NaN;\n}\n\nfunction getBooleanValue(index: number, args: string[]): boolean {\n const stringValue: string = getStringValue(index, args).toLowerCase().trim();\n if (['--no-draco', '--split-nodes'].includes(args[index]) && !stringValue) {\n return false;\n }\n if (!stringValue || stringValue === 'true') {\n return true;\n }\n return false;\n}\n"],"mappings":"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"}
@@ -13,7 +13,8 @@ var _core = require("@loaders.gl/core");
13
13
  var _zip = require("@loaders.gl/zip");
14
14
  var _fileUtils = require("../lib/utils/file-utils");
15
15
  var _path = require("path");
16
- var VERSION = typeof "3.3.0-alpha.7" !== 'undefined' ? "3.3.0-alpha.7" : 'beta';
16
+ var _workerUtils = require("@loaders.gl/worker-utils");
17
+ var VERSION = typeof "3.3.0" !== 'undefined' ? "3.3.0" : 'beta';
17
18
  var PGM_LINK = 'https://raw.githubusercontent.com/visgl/deck.gl-data/master/egm/egm2008-5.zip';
18
19
 
19
20
  var DepsInstaller = function () {
@@ -28,6 +29,7 @@ var DepsInstaller = function () {
28
29
  workersPath,
29
30
  fileMap,
30
31
  depsPath,
32
+ childProcess,
31
33
  _args = arguments;
32
34
  return _regenerator.default.wrap(function _callee$(_context) {
33
35
  while (1) {
@@ -59,8 +61,17 @@ var DepsInstaller = function () {
59
61
  _context.next = 19;
60
62
  return this.installWorker('textures', 'basis-nodejs-worker.js', workersPath);
61
63
  case 19:
64
+ console.log('Installing "join-images" npm package');
65
+ childProcess = new _workerUtils.ChildProcessProxy();
66
+ _context.next = 23;
67
+ return childProcess.start({
68
+ command: 'npm',
69
+ arguments: ['install', 'sharp', 'join-images'],
70
+ wait: 0
71
+ });
72
+ case 23:
62
73
  console.log('All dependencies were installed succesfully.');
63
- case 20:
74
+ case 24:
64
75
  case "end":
65
76
  return _context.stop();
66
77
  }
@@ -1 +1 @@
1
- {"version":3,"file":"deps-installer.js","names":["VERSION","PGM_LINK","DepsInstaller","path","workersPath","console","log","load","ZipLoader","fileMap","depsPath","process","cwd","join","writeFile","Uint8Array","installWorker","module","name","extraPath","fetchFile","fileResponse","arrayBuffer","fileData"],"sources":["../../../src/deps-installer/deps-installer.ts"],"sourcesContent":["import {load, fetchFile} from '@loaders.gl/core';\nimport {ZipLoader} from '@loaders.gl/zip';\nimport {writeFile} from '../lib/utils/file-utils';\nimport {join} from 'path';\n\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'beta';\n\nconst PGM_LINK = 'https://raw.githubusercontent.com/visgl/deck.gl-data/master/egm/egm2008-5.zip';\n\n/**\n * Install external dependencies for converter:\n * * PGM file (implemented);\n * * Draco library (not implemented);\n * * 7z archiver (not implemented);\n */\nexport class DepsInstaller {\n /**\n * Run instalation\n * @param path destination folder\n * @param workersPath destination folder for workers.\n * This path is '' by default and is not used by tile-converter.\n * It is used in tests to prevent rewriting actual workers during tests running\n */\n async install(path: string = '', workersPath: string = ''): Promise<void> {\n console.log('Installing \"EGM2008-5\" model...'); // eslint-disable-line no-console\n const fileMap = await load(PGM_LINK, ZipLoader, {});\n\n let depsPath = process.cwd();\n if (path) {\n depsPath = join(depsPath, path);\n }\n\n await writeFile(depsPath, new Uint8Array(fileMap['geoids/egm2008-5.pgm']), 'egm2008-5.pgm');\n\n console.log('Installing \"I3S Content Loader worker\"'); // eslint-disable-line no-console\n await this.installWorker('i3s', 'i3s-content-nodejs-worker.js', workersPath);\n\n console.log('Installing \"Draco Loader worker\"'); // eslint-disable-line no-console\n await this.installWorker('draco', 'draco-nodejs-worker.js', workersPath);\n\n console.log('Installing \"Basis Loader worker\"'); // eslint-disable-line no-console\n await this.installWorker('textures', 'basis-nodejs-worker.js', workersPath);\n\n console.log('All dependencies were installed succesfully.'); // eslint-disable-line no-console\n }\n\n private async installWorker(module: string, name: string, extraPath: string) {\n const fileResponse = await fetchFile(\n `https://unpkg.com/@loaders.gl/${module}@${VERSION}/dist/${name}`\n );\n const fileData = await fileResponse.arrayBuffer();\n if (!fileData) {\n return;\n }\n const path = join(process.cwd(), extraPath, 'modules', module, 'dist');\n await writeFile(path, fileData, name);\n }\n}\n"],"mappings":";;;;;;;;;;;AAAA;AACA;AACA;AACA;AAGA,IAAMA,OAAO,GAAG,sBAAkB,KAAK,WAAW,qBAAiB,MAAM;AAEzE,IAAMC,QAAQ,GAAG,+EAA+E;;AAAC,IAQpFC,aAAa;EAAA;IAAA;EAAA;EAAA;IAAA;IAAA;MAAA,yEAQxB;QAAA;UAAA;UAAA;UAAA;UAAA;QAAA;UAAA;YAAA;cAAA;gBAAcC,IAAY,2DAAG,EAAE;gBAAEC,WAAmB,2DAAG,EAAE;gBACvDC,OAAO,CAACC,GAAG,CAAC,iCAAiC,CAAC;gBAAC;gBAAA,OACzB,IAAAC,UAAI,EAACN,QAAQ,EAAEO,cAAS,EAAE,CAAC,CAAC,CAAC;cAAA;gBAA7CC,OAAO;gBAETC,QAAQ,GAAGC,OAAO,CAACC,GAAG,EAAE;gBAC5B,IAAIT,IAAI,EAAE;kBACRO,QAAQ,GAAG,IAAAG,UAAI,EAACH,QAAQ,EAAEP,IAAI,CAAC;gBACjC;gBAAC;gBAAA,OAEK,IAAAW,oBAAS,EAACJ,QAAQ,EAAE,IAAIK,UAAU,CAACN,OAAO,CAAC,sBAAsB,CAAC,CAAC,EAAE,eAAe,CAAC;cAAA;gBAE3FJ,OAAO,CAACC,GAAG,CAAC,wCAAwC,CAAC;gBAAC;gBAAA,OAChD,IAAI,CAACU,aAAa,CAAC,KAAK,EAAE,8BAA8B,EAAEZ,WAAW,CAAC;cAAA;gBAE5EC,OAAO,CAACC,GAAG,CAAC,kCAAkC,CAAC;gBAAC;gBAAA,OAC1C,IAAI,CAACU,aAAa,CAAC,OAAO,EAAE,wBAAwB,EAAEZ,WAAW,CAAC;cAAA;gBAExEC,OAAO,CAACC,GAAG,CAAC,kCAAkC,CAAC;gBAAC;gBAAA,OAC1C,IAAI,CAACU,aAAa,CAAC,UAAU,EAAE,wBAAwB,EAAEZ,WAAW,CAAC;cAAA;gBAE3EC,OAAO,CAACC,GAAG,CAAC,8CAA8C,CAAC;cAAC;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA,CAC7D;MAAA;QAAA;MAAA;MAAA;IAAA;EAAA;IAAA;IAAA;MAAA,+EAED,kBAA4BW,MAAc,EAAEC,IAAY,EAAEC,SAAiB;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA;gBAAA,OAC9C,IAAAC,eAAS,0CACDH,MAAM,cAAIjB,OAAO,mBAASkB,IAAI,EAChE;cAAA;gBAFKG,YAAY;gBAAA;gBAAA,OAGKA,YAAY,CAACC,WAAW,EAAE;cAAA;gBAA3CC,QAAQ;gBAAA,IACTA,QAAQ;kBAAA;kBAAA;gBAAA;gBAAA;cAAA;gBAGPpB,IAAI,GAAG,IAAAU,UAAI,EAACF,OAAO,CAACC,GAAG,EAAE,EAAEO,SAAS,EAAE,SAAS,EAAEF,MAAM,EAAE,MAAM,CAAC;gBAAA;gBAAA,OAChE,IAAAH,oBAAS,EAACX,IAAI,EAAEoB,QAAQ,EAAEL,IAAI,CAAC;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA,CACtC;MAAA;QAAA;MAAA;MAAA;IAAA;EAAA;EAAA;AAAA;AAAA"}
1
+ {"version":3,"file":"deps-installer.js","names":["VERSION","PGM_LINK","DepsInstaller","path","workersPath","console","log","load","ZipLoader","fileMap","depsPath","process","cwd","join","writeFile","Uint8Array","installWorker","childProcess","ChildProcessProxy","start","command","arguments","wait","module","name","extraPath","fetchFile","fileResponse","arrayBuffer","fileData"],"sources":["../../../src/deps-installer/deps-installer.ts"],"sourcesContent":["import {load, fetchFile} from '@loaders.gl/core';\nimport {ZipLoader} from '@loaders.gl/zip';\nimport {writeFile} from '../lib/utils/file-utils';\nimport {join} from 'path';\nimport {ChildProcessProxy} from '@loaders.gl/worker-utils';\n\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'beta';\n\nconst PGM_LINK = 'https://raw.githubusercontent.com/visgl/deck.gl-data/master/egm/egm2008-5.zip';\n\n/**\n * Install external dependencies for converter:\n * * PGM file (implemented);\n * * Draco library (not implemented);\n * * 7z archiver (not implemented);\n */\nexport class DepsInstaller {\n /**\n * Run instalation\n * @param path destination folder\n * @param workersPath destination folder for workers.\n * This path is '' by default and is not used by tile-converter.\n * It is used in tests to prevent rewriting actual workers during tests running\n */\n async install(path: string = '', workersPath: string = ''): Promise<void> {\n console.log('Installing \"EGM2008-5\" model...'); // eslint-disable-line no-console\n const fileMap = await load(PGM_LINK, ZipLoader, {});\n\n let depsPath = process.cwd();\n if (path) {\n depsPath = join(depsPath, path);\n }\n\n await writeFile(depsPath, new Uint8Array(fileMap['geoids/egm2008-5.pgm']), 'egm2008-5.pgm');\n\n console.log('Installing \"I3S Content Loader worker\"'); // eslint-disable-line no-console\n await this.installWorker('i3s', 'i3s-content-nodejs-worker.js', workersPath);\n\n console.log('Installing \"Draco Loader worker\"'); // eslint-disable-line no-console\n await this.installWorker('draco', 'draco-nodejs-worker.js', workersPath);\n\n console.log('Installing \"Basis Loader worker\"'); // eslint-disable-line no-console\n await this.installWorker('textures', 'basis-nodejs-worker.js', workersPath);\n\n console.log('Installing \"join-images\" npm package');\n const childProcess = new ChildProcessProxy();\n await childProcess.start({\n command: 'npm',\n arguments: ['install', 'sharp', 'join-images'],\n wait: 0\n });\n\n console.log('All dependencies were installed succesfully.'); // eslint-disable-line no-console\n }\n\n private async installWorker(module: string, name: string, extraPath: string) {\n const fileResponse = await fetchFile(\n `https://unpkg.com/@loaders.gl/${module}@${VERSION}/dist/${name}`\n );\n const fileData = await fileResponse.arrayBuffer();\n if (!fileData) {\n return;\n }\n const path = join(process.cwd(), extraPath, 'modules', module, 'dist');\n await writeFile(path, fileData, name);\n }\n}\n"],"mappings":";;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AAGA,IAAMA,OAAO,GAAG,cAAkB,KAAK,WAAW,aAAiB,MAAM;AAEzE,IAAMC,QAAQ,GAAG,+EAA+E;;AAAC,IAQpFC,aAAa;EAAA;IAAA;EAAA;EAAA;IAAA;IAAA;MAAA,yEAQxB;QAAA;UAAA;UAAA;UAAA;UAAA;UAAA;QAAA;UAAA;YAAA;cAAA;gBAAcC,IAAY,2DAAG,EAAE;gBAAEC,WAAmB,2DAAG,EAAE;gBACvDC,OAAO,CAACC,GAAG,CAAC,iCAAiC,CAAC;gBAAC;gBAAA,OACzB,IAAAC,UAAI,EAACN,QAAQ,EAAEO,cAAS,EAAE,CAAC,CAAC,CAAC;cAAA;gBAA7CC,OAAO;gBAETC,QAAQ,GAAGC,OAAO,CAACC,GAAG,EAAE;gBAC5B,IAAIT,IAAI,EAAE;kBACRO,QAAQ,GAAG,IAAAG,UAAI,EAACH,QAAQ,EAAEP,IAAI,CAAC;gBACjC;gBAAC;gBAAA,OAEK,IAAAW,oBAAS,EAACJ,QAAQ,EAAE,IAAIK,UAAU,CAACN,OAAO,CAAC,sBAAsB,CAAC,CAAC,EAAE,eAAe,CAAC;cAAA;gBAE3FJ,OAAO,CAACC,GAAG,CAAC,wCAAwC,CAAC;gBAAC;gBAAA,OAChD,IAAI,CAACU,aAAa,CAAC,KAAK,EAAE,8BAA8B,EAAEZ,WAAW,CAAC;cAAA;gBAE5EC,OAAO,CAACC,GAAG,CAAC,kCAAkC,CAAC;gBAAC;gBAAA,OAC1C,IAAI,CAACU,aAAa,CAAC,OAAO,EAAE,wBAAwB,EAAEZ,WAAW,CAAC;cAAA;gBAExEC,OAAO,CAACC,GAAG,CAAC,kCAAkC,CAAC;gBAAC;gBAAA,OAC1C,IAAI,CAACU,aAAa,CAAC,UAAU,EAAE,wBAAwB,EAAEZ,WAAW,CAAC;cAAA;gBAE3EC,OAAO,CAACC,GAAG,CAAC,sCAAsC,CAAC;gBAC7CW,YAAY,GAAG,IAAIC,8BAAiB,EAAE;gBAAA;gBAAA,OACtCD,YAAY,CAACE,KAAK,CAAC;kBACvBC,OAAO,EAAE,KAAK;kBACdC,SAAS,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,aAAa,CAAC;kBAC9CC,IAAI,EAAE;gBACR,CAAC,CAAC;cAAA;gBAEFjB,OAAO,CAACC,GAAG,CAAC,8CAA8C,CAAC;cAAC;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA,CAC7D;MAAA;QAAA;MAAA;MAAA;IAAA;EAAA;IAAA;IAAA;MAAA,+EAED,kBAA4BiB,MAAc,EAAEC,IAAY,EAAEC,SAAiB;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA;gBAAA,OAC9C,IAAAC,eAAS,0CACDH,MAAM,cAAIvB,OAAO,mBAASwB,IAAI,EAChE;cAAA;gBAFKG,YAAY;gBAAA;gBAAA,OAGKA,YAAY,CAACC,WAAW,EAAE;cAAA;gBAA3CC,QAAQ;gBAAA,IACTA,QAAQ;kBAAA;kBAAA;gBAAA;gBAAA;cAAA;gBAGP1B,IAAI,GAAG,IAAAU,UAAI,EAACF,OAAO,CAACC,GAAG,EAAE,EAAEa,SAAS,EAAE,SAAS,EAAEF,MAAM,EAAE,MAAM,CAAC;gBAAA;gBAAA,OAChE,IAAAT,oBAAS,EAACX,IAAI,EAAE0B,QAAQ,EAAEL,IAAI,CAAC;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA,CACtC;MAAA;QAAA;MAAA;MAAA;IAAA;EAAA;EAAA;AAAA;AAAA"}
@@ -6,7 +6,7 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports._typecheckI3SAttributesWorker = exports.I3SAttributesWorker = void 0;
7
7
  exports.transformI3SAttributesOnWorker = transformI3SAttributesOnWorker;
8
8
  var _workerUtils = require("@loaders.gl/worker-utils");
9
- var VERSION = typeof "3.3.0-alpha.7" !== 'undefined' ? "3.3.0-alpha.7" : 'latest';
9
+ var VERSION = typeof "3.3.0" !== 'undefined' ? "3.3.0" : 'latest';
10
10
  var I3SAttributesWorker = {
11
11
  id: 'i3s-attributes',
12
12
  name: 'I3S Attributes Worker',
@@ -1 +1 @@
1
- {"version":3,"file":"i3s-attributes-worker.js","names":["VERSION","I3SAttributesWorker","id","name","module","version","options","useCartesianPositions","transformI3SAttributesOnWorker","attributesData","processOnWorker","_typecheckI3SAttributesWorker"],"sources":["../../src/i3s-attributes-worker.ts"],"sourcesContent":["import type {WorkerObject} from '@loaders.gl/worker-utils';\nimport type {ConvertedAttributes} from './i3s-converter/types';\nimport type {Matrix4, Vector3} from '@math.gl/core';\nimport type {GLTFImagePostprocessed, GLTFNodePostprocessed} from '@loaders.gl/gltf';\n\nimport {processOnWorker} from '@loaders.gl/worker-utils';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nexport type I3SAttributesWorkerOptions = {\n _nodeWorkers: boolean;\n reuseWorkers: boolean;\n useCartesianPositions: boolean;\n source: string;\n};\n\nexport type B3DMAttributesData = {\n gltfMaterials?: {id: string}[];\n nodes: GLTFNodePostprocessed[];\n images: GLTFImagePostprocessed[];\n cartographicOrigin: Vector3;\n cartesianModelMatrix: Matrix4;\n};\n\n/**\n * I3S Attributes Worker to handle B3DM object\n */\nexport const I3SAttributesWorker = {\n id: 'i3s-attributes',\n name: 'I3S Attributes Worker',\n module: 'tile-converter',\n version: VERSION,\n options: {\n useCartesianPositions: false\n }\n};\n\n/**\n * Performs I3S attributes transformation\n */\nexport function transformI3SAttributesOnWorker(\n attributesData: B3DMAttributesData,\n options: I3SAttributesWorkerOptions\n): Promise<Map<string, ConvertedAttributes>> {\n return processOnWorker(I3SAttributesWorker, attributesData, options);\n}\n\nexport const _typecheckI3SAttributesWorker: WorkerObject = I3SAttributesWorker;\n"],"mappings":";;;;;;;AAKA;AAIA,IAAMA,OAAO,GAAG,sBAAkB,KAAK,WAAW,qBAAiB,QAAQ;AAoBpE,IAAMC,mBAAmB,GAAG;EACjCC,EAAE,EAAE,gBAAgB;EACpBC,IAAI,EAAE,uBAAuB;EAC7BC,MAAM,EAAE,gBAAgB;EACxBC,OAAO,EAAEL,OAAO;EAChBM,OAAO,EAAE;IACPC,qBAAqB,EAAE;EACzB;AACF,CAAC;;AAAC;AAKK,SAASC,8BAA8B,CAC5CC,cAAkC,EAClCH,OAAmC,EACQ;EAC3C,OAAO,IAAAI,4BAAe,EAACT,mBAAmB,EAAEQ,cAAc,EAAEH,OAAO,CAAC;AACtE;AAEO,IAAMK,6BAA2C,GAAGV,mBAAmB;AAAC"}
1
+ {"version":3,"file":"i3s-attributes-worker.js","names":["VERSION","I3SAttributesWorker","id","name","module","version","options","useCartesianPositions","transformI3SAttributesOnWorker","attributesData","processOnWorker","_typecheckI3SAttributesWorker"],"sources":["../../src/i3s-attributes-worker.ts"],"sourcesContent":["import type {WorkerObject} from '@loaders.gl/worker-utils';\nimport type {ConvertedAttributes} from './i3s-converter/types';\nimport type {Matrix4, Vector3} from '@math.gl/core';\nimport type {GLTFImagePostprocessed, GLTFNodePostprocessed} from '@loaders.gl/gltf';\n\nimport {processOnWorker} from '@loaders.gl/worker-utils';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nexport type I3SAttributesWorkerOptions = {\n _nodeWorkers: boolean;\n reuseWorkers: boolean;\n useCartesianPositions: boolean;\n source: string;\n};\n\nexport type B3DMAttributesData = {\n gltfMaterials?: {id: string}[];\n nodes: GLTFNodePostprocessed[];\n images: GLTFImagePostprocessed[];\n cartographicOrigin: Vector3;\n cartesianModelMatrix: Matrix4;\n};\n\n/**\n * I3S Attributes Worker to handle B3DM object\n */\nexport const I3SAttributesWorker = {\n id: 'i3s-attributes',\n name: 'I3S Attributes Worker',\n module: 'tile-converter',\n version: VERSION,\n options: {\n useCartesianPositions: false\n }\n};\n\n/**\n * Performs I3S attributes transformation\n */\nexport function transformI3SAttributesOnWorker(\n attributesData: B3DMAttributesData,\n options: I3SAttributesWorkerOptions\n): Promise<Map<string, ConvertedAttributes>> {\n return processOnWorker(I3SAttributesWorker, attributesData, options);\n}\n\nexport const _typecheckI3SAttributesWorker: WorkerObject = I3SAttributesWorker;\n"],"mappings":";;;;;;;AAKA;AAIA,IAAMA,OAAO,GAAG,cAAkB,KAAK,WAAW,aAAiB,QAAQ;AAoBpE,IAAMC,mBAAmB,GAAG;EACjCC,EAAE,EAAE,gBAAgB;EACpBC,IAAI,EAAE,uBAAuB;EAC7BC,MAAM,EAAE,gBAAgB;EACxBC,OAAO,EAAEL,OAAO;EAChBM,OAAO,EAAE;IACPC,qBAAqB,EAAE;EACzB;AACF,CAAC;;AAAC;AAKK,SAASC,8BAA8B,CAC5CC,cAAkC,EAClCH,OAAmC,EACQ;EAC3C,OAAO,IAAAI,4BAAe,EAACT,mBAAmB,EAAEQ,cAAc,EAAEH,OAAO,CAAC;AACtE;AAEO,IAAMK,6BAA2C,GAAGV,mBAAmB;AAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"batch-ids-extensions.js","names":["EXT_MESH_FEATURES","EXT_FEATURE_METADATA","handleBatchIdsExtensions","attributes","primitive","images","extensions","Object","entries","extensionName","extensionData","handleExtFeatureMetadataExtension","console","warn","extFeatureMetadata","featureIdAttribute","featureIdAttributes","featureIds","attribute","batchIdsAttribute","value","hasOwnProperty","featuresCount","POSITIONS","length","generateImplicitFeatureIds","constant","divisor","featureIdTexture","featureIdTextures","textureAttributeIndex","texture","texCoord","textCoordAttribute","textureCoordinates","generateBatchIdsFromTexture","featureTexture","featureTextures","currentValue","devisorCounter","index","push","Array","fill","CHANNELS_MAP","r","g","b","a","textureIndex","featureChannel","channels","undefined","image","batchIds","compressed","u","v","tx","Math","min","emod","width","ty","height","offset","components","batchId","Uint8Array","data","mimeType","n"],"sources":["../../../../src/i3s-converter/helpers/batch-ids-extensions.ts"],"sourcesContent":["import {\n GLTFAccessorPostprocessed,\n GLTFImagePostprocessed,\n GLTFMeshPrimitivePostprocessed\n} from '@loaders.gl/gltf';\nimport type {\n GLTF_EXT_feature_metadata_attribute,\n GLTF_EXT_feature_metadata_primitive\n} from 'modules/gltf/src/lib/types/gltf-json-schema';\n\nconst EXT_MESH_FEATURES = 'EXT_mesh_features';\nconst EXT_FEATURE_METADATA = 'EXT_feature_metadata';\n\n/**\n * Getting batchIds from 3DTilesNext extensions.\n * @param attributes\n * @param primitive\n * @param textures\n */\nexport function handleBatchIdsExtensions(\n attributes: {\n [key: string]: GLTFAccessorPostprocessed;\n },\n primitive: GLTFMeshPrimitivePostprocessed,\n images: GLTFImagePostprocessed[]\n): number[] {\n const extensions = primitive?.extensions;\n\n if (!extensions) {\n return [];\n }\n\n for (const [extensionName, extensionData] of Object.entries(extensions || {})) {\n switch (extensionName) {\n case EXT_FEATURE_METADATA:\n return handleExtFeatureMetadataExtension(\n attributes,\n extensionData as GLTF_EXT_feature_metadata_primitive,\n images\n );\n case EXT_MESH_FEATURES:\n console.warn('EXT_mesh_features extension is not supported yet');\n return [];\n default:\n return [];\n }\n }\n\n return [];\n}\n\n/**\n * Get batchIds from EXT_feature_metadata extension.\n * Docs - https://github.com/CesiumGS/glTF/tree/3d-tiles-next/extensions/2.0/Vendor/EXT_feature_metadata\n * @param attributes\n * @param extFeatureMetadata\n * @param textures\n */\nfunction handleExtFeatureMetadataExtension(\n attributes: {\n [key: string]: GLTFAccessorPostprocessed;\n },\n extFeatureMetadata: GLTF_EXT_feature_metadata_primitive,\n images: GLTFImagePostprocessed[]\n): number[] {\n // Take only first extension object to get batchIds attribute name.\n const featureIdAttribute = extFeatureMetadata?.featureIdAttributes?.[0];\n\n if (featureIdAttribute?.featureIds?.attribute) {\n const batchIdsAttribute = attributes[featureIdAttribute.featureIds.attribute];\n return batchIdsAttribute.value;\n }\n\n if (\n featureIdAttribute?.featureIds?.hasOwnProperty('constant') &&\n featureIdAttribute?.featureIds?.hasOwnProperty('divisor')\n ) {\n const featuresCount = attributes?.POSITIONS?.value.length / 3 || 0;\n return generateImplicitFeatureIds(\n featuresCount,\n featureIdAttribute.featureIds.constant,\n featureIdAttribute.featureIds.divisor\n );\n }\n\n // Take only first extension object to get batchIds attribute name.\n const featureIdTexture =\n extFeatureMetadata?.featureIdTextures && extFeatureMetadata?.featureIdTextures[0];\n\n if (featureIdTexture) {\n const textureAttributeIndex = featureIdTexture?.featureIds?.texture?.texCoord || 0;\n const textCoordAttribute = `TEXCOORD_${textureAttributeIndex}`;\n const textureCoordinates = attributes[textCoordAttribute].value;\n return generateBatchIdsFromTexture(featureIdTexture, textureCoordinates, images);\n }\n\n // Take only first extension texture to get batchIds from the root EXT_feature_metadata object.\n const featureTexture =\n extFeatureMetadata?.featureTextures && extFeatureMetadata?.featureTextures[0];\n\n /**\n * TODO need to get batchIds from root extension\n */\n if (featureTexture) {\n console.warn(\"EXT_feature_metadata doesn't yet support featureTextures in primitive\");\n return [];\n }\n\n return [];\n}\n\n/**\n * Generates implicit feature ids\n * Spec - https://github.com/CesiumGS/glTF/tree/3d-tiles-next/extensions/2.0/Vendor/EXT_feature_metadata#implicit-feature-ids\n * @param featuresCount\n * @param constant\n * @param devisor\n */\nfunction generateImplicitFeatureIds(\n featuresCount: number,\n constant: number = 0,\n divisor: number = 0\n): number[] {\n let featureIds: number[] = [];\n\n if (divisor > 0) {\n let currentValue = constant;\n let devisorCounter = divisor;\n\n for (let index = 0; index < featuresCount; index++) {\n featureIds.push(currentValue);\n\n devisorCounter -= 1;\n\n if (devisorCounter === 0) {\n currentValue++;\n devisorCounter = divisor;\n }\n }\n } else {\n featureIds = Array<number>(featuresCount).fill(constant, 0, featuresCount);\n }\n\n return featureIds;\n}\n\n/**\n * Get batchIds from texture.\n * @param primitive\n * @param featureIdTextures\n */\nfunction generateBatchIdsFromTexture(\n featureIdTexture: GLTF_EXT_feature_metadata_attribute,\n textureCoordinates: Float32Array,\n images: GLTFImagePostprocessed[]\n) {\n if (!images?.length) {\n return [];\n }\n\n const CHANNELS_MAP = {\n r: 0,\n g: 1,\n b: 2,\n a: 3\n };\n\n const textureIndex = featureIdTexture?.featureIds?.texture?.index;\n const featureChannel = featureIdTexture?.featureIds?.channels;\n\n if (!featureChannel || textureIndex === undefined) {\n return [];\n }\n\n const image = images[textureIndex];\n const batchIds: number[] = [];\n const channels = CHANNELS_MAP[featureChannel];\n\n if (!image.compressed) {\n for (let index = 0; index < textureCoordinates.length; index += 2) {\n const u = textureCoordinates[index];\n const v = textureCoordinates[index + 1];\n\n const tx = Math.min((emod(u) * image.width) | 0, image.width - 1);\n const ty = Math.min((emod(v) * image.height) | 0, image.height - 1);\n\n const offset = (ty * image.width + tx) * image.components + channels;\n const batchId = new Uint8Array(image.data)[offset];\n\n batchIds.push(batchId);\n }\n } else {\n console.warn(`Can't get batch Ids from ${image.mimeType} compressed texture`);\n }\n\n return batchIds;\n}\n\n/**\n * Handle UVs if they are out of range [0,1].\n * @param n\n * @param m\n */\nfunction emod(n: number): number {\n return ((n % 1) + 1) % 1;\n}\n"],"mappings":";;;;;;;;AAUA,IAAMA,iBAAiB,GAAG,mBAAmB;AAC7C,IAAMC,oBAAoB,GAAG,sBAAsB;;AAQ5C,SAASC,wBAAwB,CACtCC,UAEC,EACDC,SAAyC,EACzCC,MAAgC,EACtB;EACV,IAAMC,UAAU,GAAGF,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEE,UAAU;EAExC,IAAI,CAACA,UAAU,EAAE;IACf,OAAO,EAAE;EACX;EAEA,mCAA6CC,MAAM,CAACC,OAAO,CAACF,UAAU,IAAI,CAAC,CAAC,CAAC,qCAAE;IAA1E;MAAOG,aAAa;MAAEC,aAAa;IACtC,QAAQD,aAAa;MACnB,KAAKR,oBAAoB;QACvB,OAAOU,iCAAiC,CACtCR,UAAU,EACVO,aAAa,EACbL,MAAM,CACP;MACH,KAAKL,iBAAiB;QACpBY,OAAO,CAACC,IAAI,CAAC,kDAAkD,CAAC;QAChE,OAAO,EAAE;MACX;QACE,OAAO,EAAE;IAAC;EAEhB;EAEA,OAAO,EAAE;AACX;;AASA,SAASF,iCAAiC,CACxCR,UAEC,EACDW,kBAAuD,EACvDT,MAAgC,EACtB;EAAA;EAEV,IAAMU,kBAAkB,GAAGD,kBAAkB,aAAlBA,kBAAkB,gDAAlBA,kBAAkB,CAAEE,mBAAmB,0DAAvC,sBAA0C,CAAC,CAAC;EAEvE,IAAID,kBAAkB,aAAlBA,kBAAkB,wCAAlBA,kBAAkB,CAAEE,UAAU,kDAA9B,sBAAgCC,SAAS,EAAE;IAC7C,IAAMC,iBAAiB,GAAGhB,UAAU,CAACY,kBAAkB,CAACE,UAAU,CAACC,SAAS,CAAC;IAC7E,OAAOC,iBAAiB,CAACC,KAAK;EAChC;EAEA,IACEL,kBAAkB,aAAlBA,kBAAkB,yCAAlBA,kBAAkB,CAAEE,UAAU,mDAA9B,uBAAgCI,cAAc,CAAC,UAAU,CAAC,IAC1DN,kBAAkB,aAAlBA,kBAAkB,yCAAlBA,kBAAkB,CAAEE,UAAU,mDAA9B,uBAAgCI,cAAc,CAAC,SAAS,CAAC,EACzD;IAAA;IACA,IAAMC,aAAa,GAAG,CAAAnB,UAAU,aAAVA,UAAU,gDAAVA,UAAU,CAAEoB,SAAS,0DAArB,sBAAuBH,KAAK,CAACI,MAAM,IAAG,CAAC,IAAI,CAAC;IAClE,OAAOC,0BAA0B,CAC/BH,aAAa,EACbP,kBAAkB,CAACE,UAAU,CAACS,QAAQ,EACtCX,kBAAkB,CAACE,UAAU,CAACU,OAAO,CACtC;EACH;;EAGA,IAAMC,gBAAgB,GACpB,CAAAd,kBAAkB,aAAlBA,kBAAkB,uBAAlBA,kBAAkB,CAAEe,iBAAiB,MAAIf,kBAAkB,aAAlBA,kBAAkB,uBAAlBA,kBAAkB,CAAEe,iBAAiB,CAAC,CAAC,CAAC;EAEnF,IAAID,gBAAgB,EAAE;IAAA;IACpB,IAAME,qBAAqB,GAAG,CAAAF,gBAAgB,aAAhBA,gBAAgB,gDAAhBA,gBAAgB,CAAEX,UAAU,oFAA5B,sBAA8Bc,OAAO,2DAArC,uBAAuCC,QAAQ,KAAI,CAAC;IAClF,IAAMC,kBAAkB,sBAAeH,qBAAqB,CAAE;IAC9D,IAAMI,kBAAkB,GAAG/B,UAAU,CAAC8B,kBAAkB,CAAC,CAACb,KAAK;IAC/D,OAAOe,2BAA2B,CAACP,gBAAgB,EAAEM,kBAAkB,EAAE7B,MAAM,CAAC;EAClF;;EAGA,IAAM+B,cAAc,GAClB,CAAAtB,kBAAkB,aAAlBA,kBAAkB,uBAAlBA,kBAAkB,CAAEuB,eAAe,MAAIvB,kBAAkB,aAAlBA,kBAAkB,uBAAlBA,kBAAkB,CAAEuB,eAAe,CAAC,CAAC,CAAC;;EAK/E,IAAID,cAAc,EAAE;IAClBxB,OAAO,CAACC,IAAI,CAAC,uEAAuE,CAAC;IACrF,OAAO,EAAE;EACX;EAEA,OAAO,EAAE;AACX;;AASA,SAASY,0BAA0B,CACjCH,aAAqB,EAGX;EAAA,IAFVI,QAAgB,uEAAG,CAAC;EAAA,IACpBC,OAAe,uEAAG,CAAC;EAEnB,IAAIV,UAAoB,GAAG,EAAE;EAE7B,IAAIU,OAAO,GAAG,CAAC,EAAE;IACf,IAAIW,YAAY,GAAGZ,QAAQ;IAC3B,IAAIa,cAAc,GAAGZ,OAAO;IAE5B,KAAK,IAAIa,KAAK,GAAG,CAAC,EAAEA,KAAK,GAAGlB,aAAa,EAAEkB,KAAK,EAAE,EAAE;MAClDvB,UAAU,CAACwB,IAAI,CAACH,YAAY,CAAC;MAE7BC,cAAc,IAAI,CAAC;MAEnB,IAAIA,cAAc,KAAK,CAAC,EAAE;QACxBD,YAAY,EAAE;QACdC,cAAc,GAAGZ,OAAO;MAC1B;IACF;EACF,CAAC,MAAM;IACLV,UAAU,GAAGyB,KAAK,CAASpB,aAAa,CAAC,CAACqB,IAAI,CAACjB,QAAQ,EAAE,CAAC,EAAEJ,aAAa,CAAC;EAC5E;EAEA,OAAOL,UAAU;AACnB;;AAOA,SAASkB,2BAA2B,CAClCP,gBAAqD,EACrDM,kBAAgC,EAChC7B,MAAgC,EAChC;EAAA;EACA,IAAI,EAACA,MAAM,aAANA,MAAM,eAANA,MAAM,CAAEmB,MAAM,GAAE;IACnB,OAAO,EAAE;EACX;EAEA,IAAMoB,YAAY,GAAG;IACnBC,CAAC,EAAE,CAAC;IACJC,CAAC,EAAE,CAAC;IACJC,CAAC,EAAE,CAAC;IACJC,CAAC,EAAE;EACL,CAAC;EAED,IAAMC,YAAY,GAAGrB,gBAAgB,aAAhBA,gBAAgB,iDAAhBA,gBAAgB,CAAEX,UAAU,qFAA5B,uBAA8Bc,OAAO,2DAArC,uBAAuCS,KAAK;EACjE,IAAMU,cAAc,GAAGtB,gBAAgB,aAAhBA,gBAAgB,iDAAhBA,gBAAgB,CAAEX,UAAU,2DAA5B,uBAA8BkC,QAAQ;EAE7D,IAAI,CAACD,cAAc,IAAID,YAAY,KAAKG,SAAS,EAAE;IACjD,OAAO,EAAE;EACX;EAEA,IAAMC,KAAK,GAAGhD,MAAM,CAAC4C,YAAY,CAAC;EAClC,IAAMK,QAAkB,GAAG,EAAE;EAC7B,IAAMH,QAAQ,GAAGP,YAAY,CAACM,cAAc,CAAC;EAE7C,IAAI,CAACG,KAAK,CAACE,UAAU,EAAE;IACrB,KAAK,IAAIf,KAAK,GAAG,CAAC,EAAEA,KAAK,GAAGN,kBAAkB,CAACV,MAAM,EAAEgB,KAAK,IAAI,CAAC,EAAE;MACjE,IAAMgB,CAAC,GAAGtB,kBAAkB,CAACM,KAAK,CAAC;MACnC,IAAMiB,CAAC,GAAGvB,kBAAkB,CAACM,KAAK,GAAG,CAAC,CAAC;MAEvC,IAAMkB,EAAE,GAAGC,IAAI,CAACC,GAAG,CAAEC,IAAI,CAACL,CAAC,CAAC,GAAGH,KAAK,CAACS,KAAK,GAAI,CAAC,EAAET,KAAK,CAACS,KAAK,GAAG,CAAC,CAAC;MACjE,IAAMC,EAAE,GAAGJ,IAAI,CAACC,GAAG,CAAEC,IAAI,CAACJ,CAAC,CAAC,GAAGJ,KAAK,CAACW,MAAM,GAAI,CAAC,EAAEX,KAAK,CAACW,MAAM,GAAG,CAAC,CAAC;MAEnE,IAAMC,MAAM,GAAG,CAACF,EAAE,GAAGV,KAAK,CAACS,KAAK,GAAGJ,EAAE,IAAIL,KAAK,CAACa,UAAU,GAAGf,QAAQ;MACpE,IAAMgB,OAAO,GAAG,IAAIC,UAAU,CAACf,KAAK,CAACgB,IAAI,CAAC,CAACJ,MAAM,CAAC;MAElDX,QAAQ,CAACb,IAAI,CAAC0B,OAAO,CAAC;IACxB;EACF,CAAC,MAAM;IACLvD,OAAO,CAACC,IAAI,oCAA6BwC,KAAK,CAACiB,QAAQ,yBAAsB;EAC/E;EAEA,OAAOhB,QAAQ;AACjB;;AAOA,SAASO,IAAI,CAACU,CAAS,EAAU;EAC/B,OAAO,CAAEA,CAAC,GAAG,CAAC,GAAI,CAAC,IAAI,CAAC;AAC1B"}
1
+ {"version":3,"file":"batch-ids-extensions.js","names":["EXT_MESH_FEATURES","EXT_FEATURE_METADATA","handleBatchIdsExtensions","attributes","primitive","images","extensions","Object","entries","extensionName","extensionData","handleExtFeatureMetadataExtension","console","warn","extFeatureMetadata","featureIdAttribute","featureIdAttributes","featureIds","attribute","batchIdsAttribute","value","hasOwnProperty","featuresCount","POSITIONS","length","generateImplicitFeatureIds","constant","divisor","featureIdTexture","featureIdTextures","textureAttributeIndex","texture","texCoord","textCoordAttribute","textureCoordinates","generateBatchIdsFromTexture","featureTexture","featureTextures","currentValue","devisorCounter","index","push","Array","fill","CHANNELS_MAP","r","g","b","a","textureIndex","featureChannel","channels","undefined","image","batchIds","compressed","u","v","tx","Math","min","emod","width","ty","height","offset","components","batchId","Uint8Array","data","mimeType","n"],"sources":["../../../../src/i3s-converter/helpers/batch-ids-extensions.ts"],"sourcesContent":["import {\n GLTFAccessorPostprocessed,\n GLTFImagePostprocessed,\n GLTFMeshPrimitivePostprocessed\n} from '@loaders.gl/gltf';\nimport type {\n GLTF_EXT_feature_metadata_attribute,\n GLTF_EXT_feature_metadata_primitive\n} from 'modules/gltf/src/lib/types/gltf-json-schema';\n\nconst EXT_MESH_FEATURES = 'EXT_mesh_features';\nconst EXT_FEATURE_METADATA = 'EXT_feature_metadata';\n\n/**\n * Getting batchIds from 3DTilesNext extensions.\n * @param attributes - gltf accessors\n * @param primitive - gltf primitive data\n * @param images - gltf texture images\n */\nexport function handleBatchIdsExtensions(\n attributes: {\n [key: string]: GLTFAccessorPostprocessed;\n },\n primitive: GLTFMeshPrimitivePostprocessed,\n images: GLTFImagePostprocessed[]\n): number[] {\n const extensions = primitive?.extensions;\n\n if (!extensions) {\n return [];\n }\n\n for (const [extensionName, extensionData] of Object.entries(extensions || {})) {\n switch (extensionName) {\n case EXT_FEATURE_METADATA:\n return handleExtFeatureMetadataExtension(\n attributes,\n extensionData as GLTF_EXT_feature_metadata_primitive,\n images\n );\n case EXT_MESH_FEATURES:\n console.warn('EXT_mesh_features extension is not supported yet');\n return [];\n default:\n return [];\n }\n }\n\n return [];\n}\n\n/**\n * Get batchIds from EXT_feature_metadata extension.\n * Docs - https://github.com/CesiumGS/glTF/tree/3d-tiles-next/extensions/2.0/Vendor/EXT_feature_metadata\n * @param attributes\n * @param extFeatureMetadata\n * @param textures\n */\nfunction handleExtFeatureMetadataExtension(\n attributes: {\n [key: string]: GLTFAccessorPostprocessed;\n },\n extFeatureMetadata: GLTF_EXT_feature_metadata_primitive,\n images: GLTFImagePostprocessed[]\n): number[] {\n // Take only first extension object to get batchIds attribute name.\n const featureIdAttribute = extFeatureMetadata?.featureIdAttributes?.[0];\n\n if (featureIdAttribute?.featureIds?.attribute) {\n const batchIdsAttribute = attributes[featureIdAttribute.featureIds.attribute];\n return batchIdsAttribute.value;\n }\n\n if (\n featureIdAttribute?.featureIds?.hasOwnProperty('constant') &&\n featureIdAttribute?.featureIds?.hasOwnProperty('divisor')\n ) {\n const featuresCount = attributes?.POSITIONS?.value.length / 3 || 0;\n return generateImplicitFeatureIds(\n featuresCount,\n featureIdAttribute.featureIds.constant,\n featureIdAttribute.featureIds.divisor\n );\n }\n\n // Take only first extension object to get batchIds attribute name.\n const featureIdTexture =\n extFeatureMetadata?.featureIdTextures && extFeatureMetadata?.featureIdTextures[0];\n\n if (featureIdTexture) {\n const textureAttributeIndex = featureIdTexture?.featureIds?.texture?.texCoord || 0;\n const textCoordAttribute = `TEXCOORD_${textureAttributeIndex}`;\n const textureCoordinates = attributes[textCoordAttribute].value;\n return generateBatchIdsFromTexture(featureIdTexture, textureCoordinates, images);\n }\n\n // Take only first extension texture to get batchIds from the root EXT_feature_metadata object.\n const featureTexture =\n extFeatureMetadata?.featureTextures && extFeatureMetadata?.featureTextures[0];\n\n /**\n * TODO need to get batchIds from root extension\n */\n if (featureTexture) {\n console.warn(\"EXT_feature_metadata doesn't yet support featureTextures in primitive\");\n return [];\n }\n\n return [];\n}\n\n/**\n * Generates implicit feature ids\n * Spec - https://github.com/CesiumGS/glTF/tree/3d-tiles-next/extensions/2.0/Vendor/EXT_feature_metadata#implicit-feature-ids\n * @param featuresCount\n * @param constant\n * @param devisor\n */\nfunction generateImplicitFeatureIds(\n featuresCount: number,\n constant: number = 0,\n divisor: number = 0\n): number[] {\n let featureIds: number[] = [];\n\n if (divisor > 0) {\n let currentValue = constant;\n let devisorCounter = divisor;\n\n for (let index = 0; index < featuresCount; index++) {\n featureIds.push(currentValue);\n\n devisorCounter -= 1;\n\n if (devisorCounter === 0) {\n currentValue++;\n devisorCounter = divisor;\n }\n }\n } else {\n featureIds = Array<number>(featuresCount).fill(constant, 0, featuresCount);\n }\n\n return featureIds;\n}\n\n/**\n * Get batchIds from texture.\n * @param primitive\n * @param featureIdTextures\n */\nfunction generateBatchIdsFromTexture(\n featureIdTexture: GLTF_EXT_feature_metadata_attribute,\n textureCoordinates: Float32Array,\n images: GLTFImagePostprocessed[]\n) {\n if (!images?.length) {\n return [];\n }\n\n const CHANNELS_MAP = {\n r: 0,\n g: 1,\n b: 2,\n a: 3\n };\n\n const textureIndex = featureIdTexture?.featureIds?.texture?.index;\n const featureChannel = featureIdTexture?.featureIds?.channels;\n\n if (!featureChannel || textureIndex === undefined) {\n return [];\n }\n\n const image = images[textureIndex];\n const batchIds: number[] = [];\n const channels = CHANNELS_MAP[featureChannel];\n\n if (!image.compressed) {\n for (let index = 0; index < textureCoordinates.length; index += 2) {\n const u = textureCoordinates[index];\n const v = textureCoordinates[index + 1];\n\n const tx = Math.min((emod(u) * image.width) | 0, image.width - 1);\n const ty = Math.min((emod(v) * image.height) | 0, image.height - 1);\n\n const offset = (ty * image.width + tx) * image.components + channels;\n const batchId = new Uint8Array(image.data)[offset];\n\n batchIds.push(batchId);\n }\n } else {\n console.warn(`Can't get batch Ids from ${image.mimeType} compressed texture`);\n }\n\n return batchIds;\n}\n\n/**\n * Handle UVs if they are out of range [0,1].\n * @param n\n * @param m\n */\nfunction emod(n: number): number {\n return ((n % 1) + 1) % 1;\n}\n"],"mappings":"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"}
@@ -20,6 +20,7 @@ function generateAttributes(attributes) {
20
20
  normals = attributes.normals,
21
21
  texCoords = attributes.texCoords,
22
22
  colors = attributes.colors,
23
+ uvRegions = attributes.uvRegions,
23
24
  featureIndices = attributes.featureIndices;
24
25
  var triangleCount = positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;
25
26
  if (!featureIndices.length) {
@@ -30,7 +31,8 @@ function generateAttributes(attributes) {
30
31
  positions: positions,
31
32
  normals: normals,
32
33
  texCoords: texCoords,
33
- colors: colors
34
+ colors: colors,
35
+ uvRegions: uvRegions
34
36
  };
35
37
  }
36
38
  var data = calculateFaceRangesAndFeaturesCount(featureIndices);
@@ -99,6 +101,7 @@ function makeAttributeObjects(attributes) {
99
101
  positions = attributes.positions,
100
102
  normals = attributes.normals,
101
103
  colors = attributes.colors,
104
+ uvRegions = attributes.uvRegions,
102
105
  texCoords = attributes.texCoords,
103
106
  _attributes$faceRange = attributes.faceRange,
104
107
  faceRange = _attributes$faceRange === void 0 ? new Uint32Array(0) : _attributes$faceRange;
@@ -107,26 +110,28 @@ function makeAttributeObjects(attributes) {
107
110
  var normalsList = new Float32Array(normals);
108
111
  var colorsList = new Uint8Array(colors);
109
112
  var texCoordsList = new Float32Array(texCoords);
110
- var faceRangeIndex = 0;
113
+ var uvRegionsList = new Uint16Array(uvRegions);
111
114
  for (var index = 0; index < featureIds.length; index++) {
112
- var startIndex = faceRange[index + faceRangeIndex];
113
- var endIndex = faceRange[index + faceRangeIndex + 1];
115
+ var startIndex = faceRange[index * 2];
116
+ var endIndex = faceRange[index * 2 + 1];
114
117
  var positionsCount = getSliceAttributeCount('positions', startIndex, endIndex);
115
118
  var normalsCount = getSliceAttributeCount('normals', startIndex, endIndex);
116
119
  var colorsCount = getSliceAttributeCount('colors', startIndex, endIndex);
120
+ var uvRegionsCount = getSliceAttributeCount('uvRegions', startIndex, endIndex);
117
121
  var texCoordsCount = getSliceAttributeCount('texCoords', startIndex, endIndex);
118
122
  groupedData.push({
119
123
  featureId: featureIds[index],
120
124
  positions: positionsList.slice(0, positionsCount),
121
125
  normals: normalsList.slice(0, normalsCount),
122
126
  colors: colorsList.slice(0, colorsCount),
127
+ uvRegions: uvRegionsList.slice(0, uvRegionsCount),
123
128
  texCoords: texCoordsList.slice(0, texCoordsCount)
124
129
  });
125
130
  positionsList = positionsList.slice(positionsCount);
126
131
  normalsList = normalsList.slice(normalsCount);
127
132
  colorsList = colorsList.slice(colorsCount);
133
+ uvRegionsList = uvRegionsList.slice(uvRegionsCount);
128
134
  texCoordsList = texCoordsList.slice(texCoordsCount);
129
- faceRangeIndex += 1;
130
135
  }
131
136
  return groupedData.sort(function (first, second) {
132
137
  return first.featureId - second.featureId;
@@ -134,7 +139,7 @@ function makeAttributeObjects(attributes) {
134
139
  }
135
140
 
136
141
  function getSliceAttributeCount(attributeName, startIndex, endIndex) {
137
- var colorsPerVertex = 4;
142
+ var itemsPerVertex4 = 4;
138
143
  var texCoordsPerVertex = 2;
139
144
  var trianglesCount = endIndex - startIndex + 1;
140
145
  var vertexCount = trianglesCount * 3;
@@ -143,7 +148,8 @@ function getSliceAttributeCount(attributeName, startIndex, endIndex) {
143
148
  case 'normals':
144
149
  return trianglesCount * POSITIONS_AND_NORMALS_PER_TRIANGLE;
145
150
  case 'colors':
146
- return vertexCount * colorsPerVertex;
151
+ case 'uvRegions':
152
+ return vertexCount * itemsPerVertex4;
147
153
  case 'texCoords':
148
154
  return vertexCount * texCoordsPerVertex;
149
155
  default:
@@ -179,6 +185,7 @@ function groupAttributesAndRangesByFeatureId(unifiedObjects, featureCount) {
179
185
  var positions = new Float32Array(firstAttributeObject.positions);
180
186
  var normals = new Float32Array(firstAttributeObject.normals);
181
187
  var colors = new Uint8Array(firstAttributeObject.colors);
188
+ var uvRegions = new Uint16Array(firstAttributeObject.uvRegions);
182
189
  var texCoords = new Float32Array(firstAttributeObject.texCoords);
183
190
  var range = [0];
184
191
  var objIndex = 0;
@@ -189,6 +196,7 @@ function groupAttributesAndRangesByFeatureId(unifiedObjects, featureCount) {
189
196
  positions = (0, _loaderUtils.concatenateTypedArrays)(positions, currentAttributesObject.positions);
190
197
  normals = (0, _loaderUtils.concatenateTypedArrays)(normals, currentAttributesObject.normals);
191
198
  colors = (0, _loaderUtils.concatenateTypedArrays)(colors, currentAttributesObject.colors);
199
+ uvRegions = (0, _loaderUtils.concatenateTypedArrays)(uvRegions, currentAttributesObject.uvRegions);
192
200
  texCoords = (0, _loaderUtils.concatenateTypedArrays)(texCoords, currentAttributesObject.texCoords);
193
201
  var groupedObject = unifiedObjects[objIndex];
194
202
  range.push(groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE - 1 + sum);
@@ -204,6 +212,7 @@ function groupAttributesAndRangesByFeatureId(unifiedObjects, featureCount) {
204
212
  positions: positions,
205
213
  normals: normals,
206
214
  colors: colors,
215
+ uvRegions: uvRegions,
207
216
  texCoords: texCoords,
208
217
  featureCount: featureCount
209
218
  };
@@ -1 +1 @@
1
- {"version":3,"file":"geometry-attributes.js","names":["VALUES_PER_VERTEX","POSITIONS_AND_NORMALS_PER_TRIANGLE","generateAttributes","attributes","positions","normals","texCoords","colors","featureIndices","triangleCount","length","faceRange","Uint32Array","featureIds","featureCount","data","calculateFaceRangesAndFeaturesCount","attributeObjects","makeAttributeObjects","unifiedAttributeObjectsByFeatureIds","unifyObjectsByFeatureId","groupedAttributes","groupAttributesAndRangesByFeatureId","rangeIndex","featureIndex","currentFeatureId","getFrequentValue","slice","faceRangeList","uniqueFeatureIds","index","newFeatureId","includes","push","values","map","mostFrequentValue","maxCount","value","groupedData","positionsList","Float32Array","normalsList","colorsList","Uint8Array","texCoordsList","faceRangeIndex","startIndex","endIndex","positionsCount","getSliceAttributeCount","normalsCount","colorsCount","texCoordsCount","featureId","sort","first","second","attributeName","colorsPerVertex","texCoordsPerVertex","trianglesCount","vertexCount","sortedData","uniqueObjects","currentObject","existedObject","find","obj","concatenateTypedArrays","unifiedObjects","firstAttributeObject","range","objIndex","sum","currentAttributesObject","groupedObject"],"sources":["../../../../src/i3s-converter/helpers/geometry-attributes.ts"],"sourcesContent":["import type {GeometryAttributes, ConvertedAttributes, GroupedByFeatureIdAttributes} from '../types';\nimport {concatenateTypedArrays} from '@loaders.gl/loader-utils';\n\nconst VALUES_PER_VERTEX = 3;\nconst POSITIONS_AND_NORMALS_PER_TRIANGLE = 9;\n\n/**\n * Generate geometry attributes with faceRange and featureCount\n * @param attributes\n * @returns attirbutes with featureCount, featureIds and changed faceRange.\n */\nexport function generateAttributes(attributes: ConvertedAttributes): GeometryAttributes {\n const {positions, normals, texCoords, colors, featureIndices} = attributes;\n const triangleCount = positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;\n\n if (!featureIndices.length) {\n return {\n faceRange: new Uint32Array([0, triangleCount - 1]),\n featureIds: [0],\n featureCount: 1,\n positions,\n normals,\n texCoords,\n colors\n };\n }\n\n const data = calculateFaceRangesAndFeaturesCount(featureIndices);\n const attributeObjects = makeAttributeObjects({...data, ...attributes});\n const unifiedAttributeObjectsByFeatureIds = unifyObjectsByFeatureId(attributeObjects);\n const groupedAttributes = groupAttributesAndRangesByFeatureId(\n unifiedAttributeObjectsByFeatureIds,\n data.featureCount\n );\n return groupedAttributes;\n}\n\n/**\n * Calculates face Ranges and feature count based on featureIndices.\n * @param featureIndices\n * @returns Object with featureCount, reordered attributes and changed faceRange.\n */\nfunction calculateFaceRangesAndFeaturesCount(featureIndices: number[]): {\n faceRange: Uint32Array;\n featureCount: number;\n featureIds: number[];\n} {\n let rangeIndex = 1;\n let featureIndex = 1;\n let currentFeatureId = getFrequentValue(featureIndices.slice(0, VALUES_PER_VERTEX));\n const faceRangeList: any[] = [];\n const featureIds: any[] = [];\n const uniqueFeatureIds = [currentFeatureId];\n\n faceRangeList[0] = 0;\n featureIds[0] = currentFeatureId;\n\n for (let index = VALUES_PER_VERTEX; index < featureIndices.length; index += VALUES_PER_VERTEX) {\n const newFeatureId = getFrequentValue(featureIndices.slice(index, index + VALUES_PER_VERTEX));\n if (currentFeatureId !== newFeatureId) {\n faceRangeList[rangeIndex] = index / VALUES_PER_VERTEX - 1;\n faceRangeList[rangeIndex + 1] = index / VALUES_PER_VERTEX;\n featureIds[featureIndex] = newFeatureId;\n\n if (!uniqueFeatureIds.includes(newFeatureId)) {\n uniqueFeatureIds.push(newFeatureId);\n }\n\n rangeIndex += 2;\n featureIndex += 1;\n }\n currentFeatureId = newFeatureId;\n }\n\n faceRangeList[rangeIndex] = featureIndices.length / VALUES_PER_VERTEX - 1;\n\n const faceRange = new Uint32Array(faceRangeList);\n const featureCount = uniqueFeatureIds.length;\n\n return {faceRange, featureCount, featureIds};\n}\n\n/**\n * Find most frequent value to avoid situation where one vertex can be part of multiple features (objects).\n * @param values\n */\nfunction getFrequentValue(values: number[]): number {\n const map: {[key: number]: number} = {};\n\n let mostFrequentValue = values[0];\n let maxCount = 1;\n\n for (const value of values) {\n // Save item and it's frequency count to the map.\n map[value] = (map[value] || 0) + 1;\n // Find max count of frequency.\n maxCount = maxCount > map[value] ? maxCount : map[value];\n // Find the most frequent value.\n mostFrequentValue = maxCount > map[value] ? mostFrequentValue : value;\n }\n\n return mostFrequentValue;\n}\n\n/**\n * Generate list of attribute object grouped by feature ids.\n * @param attributes\n * @returns sorted list of attribute objects.\n */\nfunction makeAttributeObjects(attributes: GeometryAttributes): GroupedByFeatureIdAttributes[] {\n const {\n featureIds,\n positions,\n normals,\n colors,\n texCoords,\n faceRange = new Uint32Array(0)\n } = attributes;\n const groupedData: GroupedByFeatureIdAttributes[] = [];\n\n let positionsList = new Float32Array(positions);\n let normalsList = new Float32Array(normals);\n let colorsList = new Uint8Array(colors);\n let texCoordsList = new Float32Array(texCoords);\n\n let faceRangeIndex = 0;\n\n for (let index = 0; index < featureIds.length; index++) {\n const startIndex = faceRange[index + faceRangeIndex];\n const endIndex = faceRange[index + faceRangeIndex + 1];\n\n const positionsCount = getSliceAttributeCount('positions', startIndex, endIndex);\n const normalsCount = getSliceAttributeCount('normals', startIndex, endIndex);\n const colorsCount = getSliceAttributeCount('colors', startIndex, endIndex);\n const texCoordsCount = getSliceAttributeCount('texCoords', startIndex, endIndex);\n\n groupedData.push({\n featureId: featureIds[index],\n positions: positionsList.slice(0, positionsCount),\n normals: normalsList.slice(0, normalsCount),\n colors: colorsList.slice(0, colorsCount),\n texCoords: texCoordsList.slice(0, texCoordsCount)\n });\n\n positionsList = positionsList.slice(positionsCount);\n normalsList = normalsList.slice(normalsCount);\n colorsList = colorsList.slice(colorsCount);\n texCoordsList = texCoordsList.slice(texCoordsCount);\n\n faceRangeIndex += 1;\n }\n\n return groupedData.sort((first, second) => first.featureId - second.featureId);\n}\n\n/**\n * Generate sliced count for generating attribute objects depends on attribute name and range.\n * @param attributeName\n * @param startIndex\n * @param endIndex\n * @returns sliced count\n */\nfunction getSliceAttributeCount(\n attributeName: string,\n startIndex: number,\n endIndex: number\n): number {\n const colorsPerVertex = 4;\n const texCoordsPerVertex = 2;\n\n const trianglesCount = endIndex - startIndex + 1;\n const vertexCount = trianglesCount * 3;\n\n switch (attributeName) {\n case 'positions':\n case 'normals':\n return trianglesCount * POSITIONS_AND_NORMALS_PER_TRIANGLE;\n case 'colors':\n return vertexCount * colorsPerVertex;\n case 'texCoords':\n return vertexCount * texCoordsPerVertex;\n default:\n return 0;\n }\n}\n\n/**\n * Generates unique object list depends on feature ids and concantenate their attributes.\n * @param sortedData\n * @returns unique list of objects\n */\nfunction unifyObjectsByFeatureId(\n sortedData: GroupedByFeatureIdAttributes[]\n): GroupedByFeatureIdAttributes[] {\n const uniqueObjects: GroupedByFeatureIdAttributes[] = [];\n\n for (let index = 0; index < sortedData.length; index++) {\n const currentObject = sortedData[index];\n const existedObject = uniqueObjects.find((obj) => obj.featureId === currentObject.featureId);\n\n if (existedObject) {\n existedObject.positions = concatenateTypedArrays(\n existedObject.positions,\n currentObject.positions\n );\n existedObject.normals = concatenateTypedArrays(existedObject.normals, currentObject.normals);\n existedObject.colors = concatenateTypedArrays(existedObject.colors, currentObject.colors);\n existedObject.texCoords = concatenateTypedArrays(\n existedObject.texCoords,\n currentObject.texCoords\n );\n } else {\n uniqueObjects.push(currentObject);\n }\n }\n\n return uniqueObjects;\n}\n\n/**\n * Generates attribute objects with new faceRange and reordered attributes.\n * @param unifiedObjects\n * @returns generated attributes with new faceRange.\n */\nfunction groupAttributesAndRangesByFeatureId(\n unifiedObjects: GroupedByFeatureIdAttributes[],\n featureCount: number\n): GeometryAttributes {\n const firstAttributeObject = unifiedObjects[0];\n const featureIds = [firstAttributeObject.featureId || 0];\n\n let positions = new Float32Array(firstAttributeObject.positions);\n let normals = new Float32Array(firstAttributeObject.normals);\n let colors = new Uint8Array(firstAttributeObject.colors);\n let texCoords = new Float32Array(firstAttributeObject.texCoords);\n const range = [0];\n\n let objIndex = 0;\n let sum = 0;\n\n for (let index = 1; index < unifiedObjects.length; index++) {\n const currentAttributesObject = unifiedObjects[index];\n featureIds.push(currentAttributesObject.featureId || 0);\n\n positions = concatenateTypedArrays(positions, currentAttributesObject.positions);\n normals = concatenateTypedArrays(normals, currentAttributesObject.normals);\n colors = concatenateTypedArrays(colors, currentAttributesObject.colors);\n texCoords = concatenateTypedArrays(texCoords, currentAttributesObject.texCoords);\n\n const groupedObject = unifiedObjects[objIndex];\n range.push(groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE - 1 + sum);\n range.push(groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE + sum);\n\n sum += groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;\n objIndex += 1;\n }\n\n range.push(positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE - 1);\n\n const faceRange = new Uint32Array(range);\n return {faceRange, featureIds, positions, normals, colors, texCoords, featureCount};\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"geometry-attributes.js","names":["VALUES_PER_VERTEX","POSITIONS_AND_NORMALS_PER_TRIANGLE","generateAttributes","attributes","positions","normals","texCoords","colors","uvRegions","featureIndices","triangleCount","length","faceRange","Uint32Array","featureIds","featureCount","data","calculateFaceRangesAndFeaturesCount","attributeObjects","makeAttributeObjects","unifiedAttributeObjectsByFeatureIds","unifyObjectsByFeatureId","groupedAttributes","groupAttributesAndRangesByFeatureId","rangeIndex","featureIndex","currentFeatureId","getFrequentValue","slice","faceRangeList","uniqueFeatureIds","index","newFeatureId","includes","push","values","map","mostFrequentValue","maxCount","value","groupedData","positionsList","Float32Array","normalsList","colorsList","Uint8Array","texCoordsList","uvRegionsList","Uint16Array","startIndex","endIndex","positionsCount","getSliceAttributeCount","normalsCount","colorsCount","uvRegionsCount","texCoordsCount","featureId","sort","first","second","attributeName","itemsPerVertex4","texCoordsPerVertex","trianglesCount","vertexCount","sortedData","uniqueObjects","currentObject","existedObject","find","obj","concatenateTypedArrays","unifiedObjects","firstAttributeObject","range","objIndex","sum","currentAttributesObject","groupedObject"],"sources":["../../../../src/i3s-converter/helpers/geometry-attributes.ts"],"sourcesContent":["import type {GeometryAttributes, ConvertedAttributes, GroupedByFeatureIdAttributes} from '../types';\nimport {concatenateTypedArrays} from '@loaders.gl/loader-utils';\n\nconst VALUES_PER_VERTEX = 3;\nconst POSITIONS_AND_NORMALS_PER_TRIANGLE = 9;\n\n/**\n * Generate geometry attributes with faceRange and featureCount\n * @param attributes\n * @returns attirbutes with featureCount, featureIds and changed faceRange.\n */\nexport function generateAttributes(attributes: ConvertedAttributes): GeometryAttributes {\n const {positions, normals, texCoords, colors, uvRegions, featureIndices} = attributes;\n const triangleCount = positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;\n\n if (!featureIndices.length) {\n return {\n faceRange: new Uint32Array([0, triangleCount - 1]),\n featureIds: [0],\n featureCount: 1,\n positions,\n normals,\n texCoords,\n colors,\n uvRegions\n };\n }\n\n const data = calculateFaceRangesAndFeaturesCount(featureIndices);\n const attributeObjects = makeAttributeObjects({...data, ...attributes});\n const unifiedAttributeObjectsByFeatureIds = unifyObjectsByFeatureId(attributeObjects);\n const groupedAttributes = groupAttributesAndRangesByFeatureId(\n unifiedAttributeObjectsByFeatureIds,\n data.featureCount\n );\n return groupedAttributes;\n}\n\n/**\n * Calculates face Ranges and feature count based on featureIndices.\n * @param featureIndices\n * @returns Object with featureCount, reordered attributes and changed faceRange.\n */\nfunction calculateFaceRangesAndFeaturesCount(featureIndices: number[]): {\n faceRange: Uint32Array;\n featureCount: number;\n featureIds: number[];\n} {\n let rangeIndex = 1;\n let featureIndex = 1;\n let currentFeatureId = getFrequentValue(featureIndices.slice(0, VALUES_PER_VERTEX));\n const faceRangeList: any[] = [];\n const featureIds: any[] = [];\n const uniqueFeatureIds = [currentFeatureId];\n\n faceRangeList[0] = 0;\n featureIds[0] = currentFeatureId;\n\n for (let index = VALUES_PER_VERTEX; index < featureIndices.length; index += VALUES_PER_VERTEX) {\n const newFeatureId = getFrequentValue(featureIndices.slice(index, index + VALUES_PER_VERTEX));\n if (currentFeatureId !== newFeatureId) {\n faceRangeList[rangeIndex] = index / VALUES_PER_VERTEX - 1;\n faceRangeList[rangeIndex + 1] = index / VALUES_PER_VERTEX;\n featureIds[featureIndex] = newFeatureId;\n\n if (!uniqueFeatureIds.includes(newFeatureId)) {\n uniqueFeatureIds.push(newFeatureId);\n }\n\n rangeIndex += 2;\n featureIndex += 1;\n }\n currentFeatureId = newFeatureId;\n }\n\n faceRangeList[rangeIndex] = featureIndices.length / VALUES_PER_VERTEX - 1;\n\n const faceRange = new Uint32Array(faceRangeList);\n const featureCount = uniqueFeatureIds.length;\n\n return {faceRange, featureCount, featureIds};\n}\n\n/**\n * Find most frequent value to avoid situation where one vertex can be part of multiple features (objects).\n * @param values\n */\nfunction getFrequentValue(values: number[]): number {\n const map: {[key: number]: number} = {};\n\n let mostFrequentValue = values[0];\n let maxCount = 1;\n\n for (const value of values) {\n // Save item and it's frequency count to the map.\n map[value] = (map[value] || 0) + 1;\n // Find max count of frequency.\n maxCount = maxCount > map[value] ? maxCount : map[value];\n // Find the most frequent value.\n mostFrequentValue = maxCount > map[value] ? mostFrequentValue : value;\n }\n\n return mostFrequentValue;\n}\n\n/**\n * Generate list of attribute object grouped by feature ids.\n * @param attributes\n * @returns sorted list of attribute objects.\n */\nfunction makeAttributeObjects(attributes: GeometryAttributes): GroupedByFeatureIdAttributes[] {\n const {\n featureIds,\n positions,\n normals,\n colors,\n uvRegions,\n texCoords,\n faceRange = new Uint32Array(0)\n } = attributes;\n const groupedData: GroupedByFeatureIdAttributes[] = [];\n\n let positionsList = new Float32Array(positions);\n let normalsList = new Float32Array(normals);\n let colorsList = new Uint8Array(colors);\n let texCoordsList = new Float32Array(texCoords);\n let uvRegionsList = new Uint16Array(uvRegions);\n\n for (let index = 0; index < featureIds.length; index++) {\n const startIndex = faceRange[index * 2];\n const endIndex = faceRange[index * 2 + 1];\n\n const positionsCount = getSliceAttributeCount('positions', startIndex, endIndex);\n const normalsCount = getSliceAttributeCount('normals', startIndex, endIndex);\n const colorsCount = getSliceAttributeCount('colors', startIndex, endIndex);\n const uvRegionsCount = getSliceAttributeCount('uvRegions', startIndex, endIndex);\n const texCoordsCount = getSliceAttributeCount('texCoords', startIndex, endIndex);\n\n groupedData.push({\n featureId: featureIds[index],\n positions: positionsList.slice(0, positionsCount),\n normals: normalsList.slice(0, normalsCount),\n colors: colorsList.slice(0, colorsCount),\n uvRegions: uvRegionsList.slice(0, uvRegionsCount),\n texCoords: texCoordsList.slice(0, texCoordsCount)\n });\n\n positionsList = positionsList.slice(positionsCount);\n normalsList = normalsList.slice(normalsCount);\n colorsList = colorsList.slice(colorsCount);\n uvRegionsList = uvRegionsList.slice(uvRegionsCount);\n texCoordsList = texCoordsList.slice(texCoordsCount);\n }\n\n return groupedData.sort((first, second) => first.featureId - second.featureId);\n}\n\n/**\n * Generate sliced count for generating attribute objects depends on attribute name and range.\n * @param attributeName\n * @param startIndex\n * @param endIndex\n * @returns sliced count\n */\nfunction getSliceAttributeCount(\n attributeName: string,\n startIndex: number,\n endIndex: number\n): number {\n const itemsPerVertex4 = 4;\n const texCoordsPerVertex = 2;\n\n const trianglesCount = endIndex - startIndex + 1;\n const vertexCount = trianglesCount * 3;\n\n switch (attributeName) {\n case 'positions':\n case 'normals':\n return trianglesCount * POSITIONS_AND_NORMALS_PER_TRIANGLE;\n case 'colors':\n case 'uvRegions':\n return vertexCount * itemsPerVertex4;\n case 'texCoords':\n return vertexCount * texCoordsPerVertex;\n default:\n return 0;\n }\n}\n\n/**\n * Generates unique object list depends on feature ids and concantenate their attributes.\n * @param sortedData\n * @returns unique list of objects\n */\nfunction unifyObjectsByFeatureId(\n sortedData: GroupedByFeatureIdAttributes[]\n): GroupedByFeatureIdAttributes[] {\n const uniqueObjects: GroupedByFeatureIdAttributes[] = [];\n\n for (let index = 0; index < sortedData.length; index++) {\n const currentObject = sortedData[index];\n const existedObject = uniqueObjects.find((obj) => obj.featureId === currentObject.featureId);\n\n if (existedObject) {\n existedObject.positions = concatenateTypedArrays(\n existedObject.positions,\n currentObject.positions\n );\n existedObject.normals = concatenateTypedArrays(existedObject.normals, currentObject.normals);\n existedObject.colors = concatenateTypedArrays(existedObject.colors, currentObject.colors);\n existedObject.texCoords = concatenateTypedArrays(\n existedObject.texCoords,\n currentObject.texCoords\n );\n } else {\n uniqueObjects.push(currentObject);\n }\n }\n\n return uniqueObjects;\n}\n\n/**\n * Generates attribute objects with new faceRange and reordered attributes.\n * @param unifiedObjects\n * @returns generated attributes with new faceRange.\n */\nfunction groupAttributesAndRangesByFeatureId(\n unifiedObjects: GroupedByFeatureIdAttributes[],\n featureCount: number\n): GeometryAttributes {\n const firstAttributeObject = unifiedObjects[0];\n const featureIds = [firstAttributeObject.featureId || 0];\n\n let positions = new Float32Array(firstAttributeObject.positions);\n let normals = new Float32Array(firstAttributeObject.normals);\n let colors = new Uint8Array(firstAttributeObject.colors);\n let uvRegions = new Uint16Array(firstAttributeObject.uvRegions);\n let texCoords = new Float32Array(firstAttributeObject.texCoords);\n const range = [0];\n\n let objIndex = 0;\n let sum = 0;\n\n for (let index = 1; index < unifiedObjects.length; index++) {\n const currentAttributesObject = unifiedObjects[index];\n featureIds.push(currentAttributesObject.featureId || 0);\n\n positions = concatenateTypedArrays(positions, currentAttributesObject.positions);\n normals = concatenateTypedArrays(normals, currentAttributesObject.normals);\n colors = concatenateTypedArrays(colors, currentAttributesObject.colors);\n uvRegions = concatenateTypedArrays(uvRegions, currentAttributesObject.uvRegions);\n texCoords = concatenateTypedArrays(texCoords, currentAttributesObject.texCoords);\n\n const groupedObject = unifiedObjects[objIndex];\n range.push(groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE - 1 + sum);\n range.push(groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE + sum);\n\n sum += groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;\n objIndex += 1;\n }\n\n range.push(positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE - 1);\n\n const faceRange = new Uint32Array(range);\n return {faceRange, featureIds, positions, normals, colors, uvRegions, texCoords, featureCount};\n}\n"],"mappings":"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"}