@loaders.gl/tile-converter 4.2.0-alpha.4 → 4.2.0-alpha.6

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 (192) hide show
  1. package/dist/3d-tiles-converter/3d-tiles-converter.d.ts +4 -4
  2. package/dist/3d-tiles-converter/3d-tiles-converter.d.ts.map +1 -1
  3. package/dist/3d-tiles-converter/3d-tiles-converter.js +349 -293
  4. package/dist/3d-tiles-converter/helpers/b3dm-converter.d.ts.map +1 -1
  5. package/dist/3d-tiles-converter/helpers/b3dm-converter.js +261 -200
  6. package/dist/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.js +14 -5
  7. package/dist/3d-tiles-converter/helpers/load-i3s.d.ts.map +1 -1
  8. package/dist/3d-tiles-converter/helpers/load-i3s.js +83 -77
  9. package/dist/3d-tiles-converter/helpers/texture-atlas.js +44 -21
  10. package/dist/3d-tiles-converter/json-templates/tileset.js +32 -33
  11. package/dist/constants.js +0 -1
  12. package/dist/converter-cli.js +257 -234
  13. package/dist/converter.min.cjs +95 -105
  14. package/dist/deps-installer/deps-installer.d.ts.map +1 -1
  15. package/dist/deps-installer/deps-installer.js +78 -59
  16. package/dist/i3s-converter/helpers/attribute-metadata-info.js +210 -153
  17. package/dist/i3s-converter/helpers/batch-ids-extensions.d.ts +1 -1
  18. package/dist/i3s-converter/helpers/batch-ids-extensions.d.ts.map +1 -1
  19. package/dist/i3s-converter/helpers/batch-ids-extensions.js +146 -103
  20. package/dist/i3s-converter/helpers/coordinate-converter.js +100 -65
  21. package/dist/i3s-converter/helpers/create-scene-server-path.js +14 -9
  22. package/dist/i3s-converter/helpers/feature-attributes.d.ts.map +1 -1
  23. package/dist/i3s-converter/helpers/feature-attributes.js +170 -105
  24. package/dist/i3s-converter/helpers/geometry-attributes.d.ts +1 -1
  25. package/dist/i3s-converter/helpers/geometry-attributes.d.ts.map +1 -1
  26. package/dist/i3s-converter/helpers/geometry-attributes.js +205 -212
  27. package/dist/i3s-converter/helpers/geometry-converter.d.ts +17 -3
  28. package/dist/i3s-converter/helpers/geometry-converter.d.ts.map +1 -1
  29. package/dist/i3s-converter/helpers/geometry-converter.js +1189 -830
  30. package/dist/i3s-converter/helpers/gltf-attributes.d.ts +1 -1
  31. package/dist/i3s-converter/helpers/gltf-attributes.d.ts.map +1 -1
  32. package/dist/i3s-converter/helpers/gltf-attributes.js +109 -97
  33. package/dist/i3s-converter/helpers/load-3d-tiles.js +103 -66
  34. package/dist/i3s-converter/helpers/node-debug.js +98 -54
  35. package/dist/i3s-converter/helpers/node-index-document.d.ts +11 -4
  36. package/dist/i3s-converter/helpers/node-index-document.d.ts.map +1 -1
  37. package/dist/i3s-converter/helpers/node-index-document.js +255 -177
  38. package/dist/i3s-converter/helpers/node-pages.d.ts +1 -1
  39. package/dist/i3s-converter/helpers/node-pages.d.ts.map +1 -1
  40. package/dist/i3s-converter/helpers/node-pages.js +299 -193
  41. package/dist/i3s-converter/helpers/preprocess-3d-tiles.d.ts +1 -1
  42. package/dist/i3s-converter/helpers/preprocess-3d-tiles.d.ts.map +1 -1
  43. package/dist/i3s-converter/helpers/preprocess-3d-tiles.js +92 -60
  44. package/dist/i3s-converter/helpers/progress.d.ts.map +1 -1
  45. package/dist/i3s-converter/helpers/progress.js +139 -83
  46. package/dist/i3s-converter/helpers/tileset-traversal.d.ts +9 -2
  47. package/dist/i3s-converter/helpers/tileset-traversal.d.ts.map +1 -1
  48. package/dist/i3s-converter/helpers/tileset-traversal.js +33 -13
  49. package/dist/i3s-converter/i3s-converter.d.ts +7 -7
  50. package/dist/i3s-converter/i3s-converter.d.ts.map +1 -1
  51. package/dist/i3s-converter/i3s-converter.js +1165 -895
  52. package/dist/i3s-converter/json-templates/geometry-definitions.js +70 -79
  53. package/dist/i3s-converter/json-templates/layers.js +120 -121
  54. package/dist/i3s-converter/json-templates/metadata.js +19 -20
  55. package/dist/i3s-converter/json-templates/node.js +73 -71
  56. package/dist/i3s-converter/json-templates/scene-server.js +25 -26
  57. package/dist/i3s-converter/json-templates/shared-resources.js +107 -108
  58. package/dist/i3s-converter/json-templates/store.js +96 -94
  59. package/dist/i3s-converter/types.js +35 -23
  60. package/dist/i3s-server/app.js +15 -12
  61. package/dist/i3s-server/bin/i3s-server.min.cjs +69 -69
  62. package/dist/i3s-server/bin/www.js +16 -7
  63. package/dist/i3s-server/controllers/index-controller.js +18 -15
  64. package/dist/i3s-server/controllers/slpk-controller.d.ts.map +1 -1
  65. package/dist/i3s-server/controllers/slpk-controller.js +24 -11
  66. package/dist/i3s-server/routes/index.js +13 -9
  67. package/dist/i3s-server/routes/slpk-router.d.ts.map +1 -1
  68. package/dist/i3s-server/routes/slpk-router.js +26 -19
  69. package/dist/i3s-server/utils/create-scene-server.js +15 -10
  70. package/dist/i3s-server/utils/server-utils.d.ts.map +1 -1
  71. package/dist/i3s-server/utils/server-utils.js +52 -32
  72. package/dist/index.cjs +616 -967
  73. package/dist/index.cjs.map +7 -0
  74. package/dist/index.d.ts +2 -2
  75. package/dist/index.d.ts.map +1 -1
  76. package/dist/index.js +0 -1
  77. package/dist/lib/json-schemas/conversion-dump-json-schema.js +243 -421
  78. package/dist/lib/utils/cli-utils.d.ts.map +1 -1
  79. package/dist/lib/utils/cli-utils.js +65 -36
  80. package/dist/lib/utils/compress-util.js +20 -15
  81. package/dist/lib/utils/conversion-dump.d.ts +10 -2
  82. package/dist/lib/utils/conversion-dump.d.ts.map +1 -1
  83. package/dist/lib/utils/conversion-dump.js +242 -197
  84. package/dist/lib/utils/file-utils.d.ts +1 -1
  85. package/dist/lib/utils/file-utils.d.ts.map +1 -1
  86. package/dist/lib/utils/file-utils.js +120 -74
  87. package/dist/lib/utils/geometry-utils.js +13 -7
  88. package/dist/lib/utils/lod-conversion-utils.js +65 -33
  89. package/dist/lib/utils/queue.js +12 -13
  90. package/dist/lib/utils/statistic-utills.d.ts +6 -23
  91. package/dist/lib/utils/statistic-utills.d.ts.map +1 -1
  92. package/dist/lib/utils/statistic-utills.js +58 -55
  93. package/dist/lib/utils/write-queue.d.ts +2 -2
  94. package/dist/lib/utils/write-queue.d.ts.map +1 -1
  95. package/dist/lib/utils/write-queue.js +72 -86
  96. package/dist/pgm-loader.js +17 -13
  97. package/dist/slpk-extractor/slpk-extractor.d.ts.map +1 -1
  98. package/dist/slpk-extractor/slpk-extractor.js +60 -50
  99. package/dist/slpk-extractor-cli.d.ts.map +1 -1
  100. package/dist/slpk-extractor-cli.js +90 -59
  101. package/dist/slpk-extractor.min.cjs +1 -1
  102. package/package.json +27 -26
  103. package/src/3d-tiles-converter/3d-tiles-converter.ts +21 -10
  104. package/src/3d-tiles-converter/helpers/b3dm-converter.ts +1 -0
  105. package/src/3d-tiles-converter/helpers/load-i3s.ts +3 -27
  106. package/src/converter-cli.ts +4 -2
  107. package/src/deps-installer/deps-installer.ts +7 -0
  108. package/src/i3s-converter/helpers/attribute-metadata-info.ts +1 -1
  109. package/src/i3s-converter/helpers/batch-ids-extensions.ts +3 -1
  110. package/src/i3s-converter/helpers/coordinate-converter.ts +2 -2
  111. package/src/i3s-converter/helpers/feature-attributes.ts +5 -2
  112. package/src/i3s-converter/helpers/geometry-attributes.ts +6 -5
  113. package/src/i3s-converter/helpers/geometry-converter.ts +118 -72
  114. package/src/i3s-converter/helpers/gltf-attributes.ts +12 -13
  115. package/src/i3s-converter/helpers/node-index-document.ts +18 -10
  116. package/src/i3s-converter/helpers/node-pages.ts +27 -29
  117. package/src/i3s-converter/helpers/preprocess-3d-tiles.ts +1 -0
  118. package/src/i3s-converter/helpers/progress.ts +1 -0
  119. package/src/i3s-converter/helpers/tileset-traversal.ts +22 -13
  120. package/src/i3s-converter/i3s-converter.ts +173 -114
  121. package/src/i3s-converter/json-templates/node.ts +1 -1
  122. package/src/i3s-server/bin/www.ts +6 -4
  123. package/src/i3s-server/controllers/slpk-controller.ts +4 -2
  124. package/src/i3s-server/routes/index.ts +10 -7
  125. package/src/i3s-server/routes/slpk-router.ts +22 -16
  126. package/src/i3s-server/utils/server-utils.ts +6 -4
  127. package/src/lib/utils/cli-utils.ts +2 -0
  128. package/src/lib/utils/conversion-dump.ts +35 -20
  129. package/src/lib/utils/file-utils.ts +11 -11
  130. package/src/lib/utils/statistic-utills.ts +5 -6
  131. package/src/lib/utils/write-queue.ts +2 -2
  132. package/src/slpk-extractor/slpk-extractor.ts +2 -1
  133. package/src/slpk-extractor-cli.ts +16 -8
  134. package/dist/3d-tiles-converter/3d-tiles-converter.js.map +0 -1
  135. package/dist/3d-tiles-converter/helpers/b3dm-converter.js.map +0 -1
  136. package/dist/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.js.map +0 -1
  137. package/dist/3d-tiles-converter/helpers/load-i3s.js.map +0 -1
  138. package/dist/3d-tiles-converter/helpers/texture-atlas.js.map +0 -1
  139. package/dist/3d-tiles-converter/json-templates/tileset.js.map +0 -1
  140. package/dist/constants.js.map +0 -1
  141. package/dist/converter-cli.js.map +0 -1
  142. package/dist/deps-installer/deps-installer.js.map +0 -1
  143. package/dist/i3s-converter/helpers/attribute-metadata-info.js.map +0 -1
  144. package/dist/i3s-converter/helpers/batch-ids-extensions.js.map +0 -1
  145. package/dist/i3s-converter/helpers/coordinate-converter.js.map +0 -1
  146. package/dist/i3s-converter/helpers/create-scene-server-path.js.map +0 -1
  147. package/dist/i3s-converter/helpers/feature-attributes.js.map +0 -1
  148. package/dist/i3s-converter/helpers/geometry-attributes.js.map +0 -1
  149. package/dist/i3s-converter/helpers/geometry-converter.js.map +0 -1
  150. package/dist/i3s-converter/helpers/gltf-attributes.js.map +0 -1
  151. package/dist/i3s-converter/helpers/load-3d-tiles.js.map +0 -1
  152. package/dist/i3s-converter/helpers/node-debug.js.map +0 -1
  153. package/dist/i3s-converter/helpers/node-index-document.js.map +0 -1
  154. package/dist/i3s-converter/helpers/node-pages.js.map +0 -1
  155. package/dist/i3s-converter/helpers/preprocess-3d-tiles.js.map +0 -1
  156. package/dist/i3s-converter/helpers/progress.js.map +0 -1
  157. package/dist/i3s-converter/helpers/tileset-traversal.js.map +0 -1
  158. package/dist/i3s-converter/i3s-converter.js.map +0 -1
  159. package/dist/i3s-converter/json-templates/geometry-definitions.js.map +0 -1
  160. package/dist/i3s-converter/json-templates/layers.js.map +0 -1
  161. package/dist/i3s-converter/json-templates/metadata.js.map +0 -1
  162. package/dist/i3s-converter/json-templates/node.js.map +0 -1
  163. package/dist/i3s-converter/json-templates/scene-server.js.map +0 -1
  164. package/dist/i3s-converter/json-templates/shared-resources.js.map +0 -1
  165. package/dist/i3s-converter/json-templates/store.js.map +0 -1
  166. package/dist/i3s-converter/types.js.map +0 -1
  167. package/dist/i3s-server/README.md +0 -63
  168. package/dist/i3s-server/app.js.map +0 -1
  169. package/dist/i3s-server/bin/www.js.map +0 -1
  170. package/dist/i3s-server/certs/cert.pem +0 -19
  171. package/dist/i3s-server/certs/key.pem +0 -27
  172. package/dist/i3s-server/controllers/index-controller.js.map +0 -1
  173. package/dist/i3s-server/controllers/slpk-controller.js.map +0 -1
  174. package/dist/i3s-server/routes/index.js.map +0 -1
  175. package/dist/i3s-server/routes/slpk-router.js.map +0 -1
  176. package/dist/i3s-server/utils/create-scene-server.js.map +0 -1
  177. package/dist/i3s-server/utils/server-utils.js.map +0 -1
  178. package/dist/index.js.map +0 -1
  179. package/dist/lib/json-schemas/conversion-dump-json-schema.js.map +0 -1
  180. package/dist/lib/utils/cli-utils.js.map +0 -1
  181. package/dist/lib/utils/compress-util.js.map +0 -1
  182. package/dist/lib/utils/conversion-dump.js.map +0 -1
  183. package/dist/lib/utils/file-utils.js.map +0 -1
  184. package/dist/lib/utils/geometry-utils.js.map +0 -1
  185. package/dist/lib/utils/lod-conversion-utils.js.map +0 -1
  186. package/dist/lib/utils/queue.js.map +0 -1
  187. package/dist/lib/utils/statistic-utills.js.map +0 -1
  188. package/dist/lib/utils/write-queue.js.map +0 -1
  189. package/dist/pgm-loader.js.map +0 -1
  190. package/dist/slpk-extractor/slpk-extractor.js.map +0 -1
  191. package/dist/slpk-extractor-cli.js.map +0 -1
  192. package/src/lib/utils/statistic-utills.d.ts +0 -25
@@ -1,233 +1,226 @@
1
1
  import { concatenateTypedArrays } from '@loaders.gl/loader-utils';
2
2
  const VALUES_PER_VERTEX = 3;
3
3
  const POSITIONS_AND_NORMALS_PER_TRIANGLE = 9;
4
+ /**
5
+ * Generate geometry attributes with faceRange and featureCount
6
+ * @param attributes
7
+ * @returns attirbutes with featureCount, featureIds and changed faceRange.
8
+ */
4
9
  export function generateAttributes(attributes) {
5
- const {
6
- positions,
7
- normals,
8
- texCoords,
9
- colors,
10
- uvRegions,
11
- featureIndices
12
- } = attributes;
13
- const triangleCount = positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;
14
- if (!featureIndices.length) {
15
- return {
16
- faceRange: new Uint32Array([0, triangleCount - 1]),
17
- featureIds: [0],
18
- featureCount: 1,
19
- positions,
20
- normals,
21
- texCoords,
22
- colors,
23
- uvRegions
24
- };
25
- }
26
- const data = calculateFaceRangesAndFeaturesCount(featureIndices);
27
- const attributeObjects = makeAttributeObjects({
28
- ...data,
29
- ...attributes
30
- });
31
- const unifiedAttributeObjectsByFeatureIds = unifyObjectsByFeatureId(attributeObjects);
32
- const groupedAttributes = groupAttributesAndRangesByFeatureId(unifiedAttributeObjectsByFeatureIds, data.featureCount);
33
- return groupedAttributes;
10
+ const { positions, normals, texCoords, colors, uvRegions, featureIndices } = attributes;
11
+ const triangleCount = positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;
12
+ if (!featureIndices.length) {
13
+ return {
14
+ faceRange: new Uint32Array([0, triangleCount - 1]),
15
+ featureIds: [0],
16
+ featureCount: 1,
17
+ positions,
18
+ normals,
19
+ texCoords,
20
+ colors,
21
+ uvRegions
22
+ };
23
+ }
24
+ const data = calculateFaceRangesAndFeaturesCount(featureIndices);
25
+ const attributeObjects = makeAttributeObjects({ ...data, ...attributes });
26
+ const unifiedAttributeObjectsByFeatureIds = unifyObjectsByFeatureId(attributeObjects);
27
+ const groupedAttributes = groupAttributesAndRangesByFeatureId(unifiedAttributeObjectsByFeatureIds, data.featureCount);
28
+ return groupedAttributes;
34
29
  }
30
+ /**
31
+ * Calculates face Ranges and feature count based on featureIndices.
32
+ * @param featureIndices
33
+ * @returns Object with featureCount, reordered attributes and changed faceRange.
34
+ */
35
35
  function calculateFaceRangesAndFeaturesCount(featureIndices) {
36
- let rangeIndex = 1;
37
- let featureIndex = 1;
38
- let currentFeatureId = getFrequentValue(featureIndices.slice(0, VALUES_PER_VERTEX));
39
- const faceRangeList = [];
40
- const featureIds = [];
41
- const uniqueFeatureIds = [currentFeatureId];
42
- faceRangeList[0] = 0;
43
- featureIds[0] = currentFeatureId;
44
- for (let index = VALUES_PER_VERTEX; index < featureIndices.length; index += VALUES_PER_VERTEX) {
45
- const newFeatureId = getFrequentValue(featureIndices.slice(index, index + VALUES_PER_VERTEX));
46
- if (currentFeatureId !== newFeatureId) {
47
- faceRangeList[rangeIndex] = index / VALUES_PER_VERTEX - 1;
48
- faceRangeList[rangeIndex + 1] = index / VALUES_PER_VERTEX;
49
- featureIds[featureIndex] = newFeatureId;
50
- if (!uniqueFeatureIds.includes(newFeatureId)) {
51
- uniqueFeatureIds.push(newFeatureId);
52
- }
53
- rangeIndex += 2;
54
- featureIndex += 1;
36
+ let rangeIndex = 1;
37
+ let featureIndex = 1;
38
+ let currentFeatureId = getFrequentValue(featureIndices.slice(0, VALUES_PER_VERTEX));
39
+ const faceRangeList = [];
40
+ const featureIds = [];
41
+ const uniqueFeatureIds = [currentFeatureId];
42
+ faceRangeList[0] = 0;
43
+ featureIds[0] = currentFeatureId;
44
+ for (let index = VALUES_PER_VERTEX; index < featureIndices.length; index += VALUES_PER_VERTEX) {
45
+ const newFeatureId = getFrequentValue(featureIndices.slice(index, index + VALUES_PER_VERTEX));
46
+ if (currentFeatureId !== newFeatureId) {
47
+ faceRangeList[rangeIndex] = index / VALUES_PER_VERTEX - 1;
48
+ faceRangeList[rangeIndex + 1] = index / VALUES_PER_VERTEX;
49
+ featureIds[featureIndex] = newFeatureId;
50
+ if (!uniqueFeatureIds.includes(newFeatureId)) {
51
+ uniqueFeatureIds.push(newFeatureId);
52
+ }
53
+ rangeIndex += 2;
54
+ featureIndex += 1;
55
+ }
56
+ currentFeatureId = newFeatureId;
55
57
  }
56
- currentFeatureId = newFeatureId;
57
- }
58
- faceRangeList[rangeIndex] = featureIndices.length / VALUES_PER_VERTEX - 1;
59
- const faceRange = new Uint32Array(faceRangeList);
60
- const featureCount = uniqueFeatureIds.length;
61
- return {
62
- faceRange,
63
- featureCount,
64
- featureIds
65
- };
58
+ faceRangeList[rangeIndex] = featureIndices.length / VALUES_PER_VERTEX - 1;
59
+ const faceRange = new Uint32Array(faceRangeList);
60
+ const featureCount = uniqueFeatureIds.length;
61
+ return { faceRange, featureCount, featureIds };
66
62
  }
63
+ /**
64
+ * Find most frequent value to avoid situation where one vertex can be part of multiple features (objects).
65
+ * @param values
66
+ */
67
67
  function getFrequentValue(values) {
68
- const map = {};
69
- let mostFrequentValue = values[0];
70
- let maxCount = 1;
71
- for (const value of values) {
72
- map[value] = (map[value] || 0) + 1;
73
- maxCount = maxCount > map[value] ? maxCount : map[value];
74
- mostFrequentValue = maxCount > map[value] ? mostFrequentValue : value;
75
- }
76
- return mostFrequentValue;
68
+ const map = {};
69
+ let mostFrequentValue = values[0];
70
+ let maxCount = 1;
71
+ for (const value of values) {
72
+ // Save item and it's frequency count to the map.
73
+ map[value] = (map[value] || 0) + 1;
74
+ // Find max count of frequency.
75
+ maxCount = maxCount > map[value] ? maxCount : map[value];
76
+ // Find the most frequent value.
77
+ mostFrequentValue = maxCount > map[value] ? mostFrequentValue : value;
78
+ }
79
+ return mostFrequentValue;
77
80
  }
81
+ /**
82
+ * Generate list of attribute object grouped by feature ids.
83
+ * @param attributes
84
+ * @returns sorted list of attribute objects.
85
+ */
86
+ // eslint-disable-next-line max-statements
78
87
  function makeAttributeObjects(attributes) {
79
- const {
80
- featureIds,
81
- positions,
82
- normals,
83
- colors,
84
- uvRegions,
85
- texCoords,
86
- faceRange = new Uint32Array(0)
87
- } = attributes;
88
- const groupedData = [];
89
- let positionsList = new Float32Array(positions);
90
- let normalsList = new Float32Array(normals);
91
- let colorsList = new Uint8Array(colors);
92
- let texCoordsList = new Float32Array(texCoords);
93
- let uvRegionsList = new Uint16Array(uvRegions);
94
- let positionsOffset = 0;
95
- let normalsOffset = 0;
96
- let colorsOffset = 0;
97
- let uvRegionsOffset = 0;
98
- let texCoordsOffset = 0;
99
- for (let index = 0; index < featureIds.length; index++) {
100
- const startIndex = faceRange[index * 2];
101
- const endIndex = faceRange[index * 2 + 1];
102
- const positionsCount = getSliceAttributeCount('positions', startIndex, endIndex);
103
- const normalsCount = getSliceAttributeCount('normals', startIndex, endIndex);
104
- const colorsCount = getSliceAttributeCount('colors', startIndex, endIndex);
105
- const uvRegionsCount = getSliceAttributeCount('uvRegions', startIndex, endIndex);
106
- const texCoordsCount = getSliceAttributeCount('texCoords', startIndex, endIndex);
107
- groupedData.push({
108
- featureId: featureIds[index],
109
- positions: positionsList.subarray(positionsOffset, positionsOffset + positionsCount),
110
- normals: normalsList.subarray(normalsOffset, normalsOffset + normalsCount),
111
- colors: colorsList.subarray(colorsOffset, colorsOffset + colorsCount),
112
- uvRegions: uvRegionsList.subarray(uvRegionsOffset, uvRegionsOffset + uvRegionsCount),
113
- texCoords: texCoordsList.subarray(texCoordsOffset, texCoordsOffset + texCoordsCount)
114
- });
115
- positionsOffset += positionsCount;
116
- normalsOffset += normalsCount;
117
- colorsOffset += colorsCount;
118
- uvRegionsOffset += uvRegionsCount;
119
- texCoordsOffset += texCoordsCount;
120
- }
121
- return groupedData;
88
+ const { featureIds, positions, normals, colors, uvRegions, texCoords, faceRange = new Uint32Array(0) } = attributes;
89
+ const groupedData = [];
90
+ const positionsList = new Float32Array(positions);
91
+ const normalsList = new Float32Array(normals);
92
+ const colorsList = new Uint8Array(colors);
93
+ const texCoordsList = new Float32Array(texCoords);
94
+ const uvRegionsList = new Uint16Array(uvRegions);
95
+ let positionsOffset = 0;
96
+ let normalsOffset = 0;
97
+ let colorsOffset = 0;
98
+ let uvRegionsOffset = 0;
99
+ let texCoordsOffset = 0;
100
+ for (let index = 0; index < featureIds.length; index++) {
101
+ const startIndex = faceRange[index * 2];
102
+ const endIndex = faceRange[index * 2 + 1];
103
+ const positionsCount = getSliceAttributeCount('positions', startIndex, endIndex);
104
+ const normalsCount = getSliceAttributeCount('normals', startIndex, endIndex);
105
+ const colorsCount = getSliceAttributeCount('colors', startIndex, endIndex);
106
+ const uvRegionsCount = getSliceAttributeCount('uvRegions', startIndex, endIndex);
107
+ const texCoordsCount = getSliceAttributeCount('texCoords', startIndex, endIndex);
108
+ groupedData.push({
109
+ featureId: featureIds[index],
110
+ positions: positionsList.subarray(positionsOffset, positionsOffset + positionsCount),
111
+ normals: normalsList.subarray(normalsOffset, normalsOffset + normalsCount),
112
+ colors: colorsList.subarray(colorsOffset, colorsOffset + colorsCount),
113
+ uvRegions: uvRegionsList.subarray(uvRegionsOffset, uvRegionsOffset + uvRegionsCount),
114
+ texCoords: texCoordsList.subarray(texCoordsOffset, texCoordsOffset + texCoordsCount)
115
+ });
116
+ positionsOffset += positionsCount;
117
+ normalsOffset += normalsCount;
118
+ colorsOffset += colorsCount;
119
+ uvRegionsOffset += uvRegionsCount;
120
+ texCoordsOffset += texCoordsCount;
121
+ }
122
+ return groupedData;
122
123
  }
124
+ /**
125
+ * Generate sliced count for generating attribute objects depends on attribute name and range.
126
+ * @param attributeName
127
+ * @param startIndex
128
+ * @param endIndex
129
+ * @returns sliced count
130
+ */
123
131
  function getSliceAttributeCount(attributeName, startIndex, endIndex) {
124
- const itemsPerVertex4 = 4;
125
- const texCoordsPerVertex = 2;
126
- const trianglesCount = endIndex - startIndex + 1;
127
- const vertexCount = trianglesCount * 3;
128
- switch (attributeName) {
129
- case 'positions':
130
- case 'normals':
131
- return trianglesCount * POSITIONS_AND_NORMALS_PER_TRIANGLE;
132
- case 'colors':
133
- case 'uvRegions':
134
- return vertexCount * itemsPerVertex4;
135
- case 'texCoords':
136
- return vertexCount * texCoordsPerVertex;
137
- default:
138
- return 0;
139
- }
132
+ const itemsPerVertex4 = 4;
133
+ const texCoordsPerVertex = 2;
134
+ const trianglesCount = endIndex - startIndex + 1;
135
+ const vertexCount = trianglesCount * 3;
136
+ switch (attributeName) {
137
+ case 'positions':
138
+ case 'normals':
139
+ return trianglesCount * POSITIONS_AND_NORMALS_PER_TRIANGLE;
140
+ case 'colors':
141
+ case 'uvRegions':
142
+ return vertexCount * itemsPerVertex4;
143
+ case 'texCoords':
144
+ return vertexCount * texCoordsPerVertex;
145
+ default:
146
+ return 0;
147
+ }
140
148
  }
149
+ /**
150
+ * Generates unique object list depends on feature ids and concantenate their attributes.
151
+ * @param sortedData
152
+ * @returns unique list of objects
153
+ */
141
154
  function unifyObjectsByFeatureId(sortedData) {
142
- const groupedMetadata = [];
143
- for (const data of sortedData) {
144
- const existingObject = groupedMetadata.find(obj => obj.featureId === data.featureId);
145
- if (existingObject) {
146
- existingObject.attributes.push(data);
147
- } else {
148
- groupedMetadata.push({
149
- featureId: data.featureId,
150
- attributes: [data]
151
- });
155
+ const groupedMetadata = [];
156
+ for (const data of sortedData) {
157
+ const existingObject = groupedMetadata.find((obj) => obj.featureId === data.featureId);
158
+ if (existingObject) {
159
+ existingObject.attributes.push(data);
160
+ }
161
+ else {
162
+ groupedMetadata.push({
163
+ featureId: data.featureId,
164
+ attributes: [data]
165
+ });
166
+ }
167
+ }
168
+ const uniqueObjects = [];
169
+ for (const metatada of groupedMetadata) {
170
+ const attributes = concatenateAttributes(metatada.attributes);
171
+ uniqueObjects.push({
172
+ featureId: metatada.featureId,
173
+ ...attributes
174
+ });
152
175
  }
153
- }
154
- const uniqueObjects = [];
155
- for (const metatada of groupedMetadata) {
156
- const attributes = concatenateAttributes(metatada.attributes);
157
- uniqueObjects.push({
158
- featureId: metatada.featureId,
159
- ...attributes
160
- });
161
- }
162
- return uniqueObjects;
176
+ return uniqueObjects;
163
177
  }
178
+ /**
179
+ * Generates attribute objects with new faceRange and reordered attributes.
180
+ * @param unifiedObjects
181
+ * @returns generated attributes with new faceRange.
182
+ */
164
183
  function groupAttributesAndRangesByFeatureId(unifiedObjects, featureCount) {
165
- const firstAttributeObject = unifiedObjects[0];
166
- const featureIds = [firstAttributeObject.featureId || 0];
167
- const range = [0];
168
- let objIndex = 0;
169
- let sum = 0;
170
- for (let index = 1; index < unifiedObjects.length; index++) {
171
- const currentAttributesObject = unifiedObjects[index];
172
- featureIds.push(currentAttributesObject.featureId || 0);
173
- const groupedObject = unifiedObjects[objIndex];
174
- range.push(groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE - 1 + sum);
175
- range.push(groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE + sum);
176
- sum += groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;
177
- objIndex += 1;
178
- }
179
- const attributes = concatenateAttributes(unifiedObjects);
180
- range.push(attributes.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE - 1);
181
- const faceRange = new Uint32Array(range);
182
- return {
183
- faceRange,
184
- featureIds,
185
- featureCount,
186
- ...attributes
187
- };
184
+ const firstAttributeObject = unifiedObjects[0];
185
+ const featureIds = [firstAttributeObject.featureId || 0];
186
+ const range = [0];
187
+ let objIndex = 0;
188
+ let sum = 0;
189
+ for (let index = 1; index < unifiedObjects.length; index++) {
190
+ const currentAttributesObject = unifiedObjects[index];
191
+ featureIds.push(currentAttributesObject.featureId || 0);
192
+ const groupedObject = unifiedObjects[objIndex];
193
+ range.push(groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE - 1 + sum);
194
+ range.push(groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE + sum);
195
+ sum += groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;
196
+ objIndex += 1;
197
+ }
198
+ const attributes = concatenateAttributes(unifiedObjects);
199
+ range.push(attributes.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE - 1);
200
+ const faceRange = new Uint32Array(range);
201
+ return { faceRange, featureIds, featureCount, ...attributes };
188
202
  }
203
+ /**
204
+ * Concatenate attributes typed arrays
205
+ * @param attributes - grouped by featureId typed arrays
206
+ * @returns - concatenated typed array list
207
+ */
189
208
  function concatenateAttributes(attributes) {
190
- const positionGroups = attributes.map(_ref => {
191
- let {
192
- positions
193
- } = _ref;
194
- return positions;
195
- });
196
- const positions = positionGroups.length > 1 ? concatenateTypedArrays(...positionGroups) : positionGroups[0];
197
- const normalGroups = attributes.map(_ref2 => {
198
- let {
199
- normals
200
- } = _ref2;
201
- return normals;
202
- });
203
- const normals = normalGroups.length > 1 ? concatenateTypedArrays(...normalGroups) : normalGroups[0];
204
- const colorGroups = attributes.map(_ref3 => {
205
- let {
206
- colors
207
- } = _ref3;
208
- return colors;
209
- });
210
- const colors = colorGroups.length > 1 ? concatenateTypedArrays(...colorGroups) : colorGroups[0];
211
- const texCoordGroups = attributes.map(_ref4 => {
212
- let {
213
- texCoords
214
- } = _ref4;
215
- return texCoords;
216
- });
217
- const texCoords = texCoordGroups.length > 1 ? concatenateTypedArrays(...texCoordGroups) : texCoordGroups[0];
218
- const uvRegionGroups = attributes.map(_ref5 => {
219
- let {
220
- uvRegions
221
- } = _ref5;
222
- return uvRegions;
223
- });
224
- const uvRegions = uvRegionGroups.length > 1 ? concatenateTypedArrays(...uvRegionGroups) : uvRegionGroups[0];
225
- return {
226
- positions,
227
- normals,
228
- colors,
229
- texCoords,
230
- uvRegions
231
- };
209
+ const positionGroups = attributes.map(({ positions }) => positions);
210
+ const positions = positionGroups.length > 1 ? concatenateTypedArrays(...positionGroups) : positionGroups[0];
211
+ const normalGroups = attributes.map(({ normals }) => normals);
212
+ const normals = normalGroups.length > 1 ? concatenateTypedArrays(...normalGroups) : normalGroups[0];
213
+ const colorGroups = attributes.map(({ colors }) => colors);
214
+ const colors = colorGroups.length > 1 ? concatenateTypedArrays(...colorGroups) : colorGroups[0];
215
+ const texCoordGroups = attributes.map(({ texCoords }) => texCoords);
216
+ const texCoords = texCoordGroups.length > 1 ? concatenateTypedArrays(...texCoordGroups) : texCoordGroups[0];
217
+ const uvRegionGroups = attributes.map(({ uvRegions }) => uvRegions);
218
+ const uvRegions = uvRegionGroups.length > 1 ? concatenateTypedArrays(...uvRegionGroups) : uvRegionGroups[0];
219
+ return {
220
+ positions,
221
+ normals,
222
+ colors,
223
+ texCoords,
224
+ uvRegions
225
+ };
232
226
  }
233
- //# sourceMappingURL=geometry-attributes.js.map
@@ -1,9 +1,9 @@
1
1
  import type { FeatureTableJson, Tiles3DTileContent } from '@loaders.gl/3d-tiles';
2
2
  import { Matrix4 } from '@math.gl/core';
3
- import { ConvertedAttributes, I3SConvertedResources, I3SMaterialWithTexture } from '../types';
3
+ import { ConvertedAttributes, I3SConvertedResources, I3SMaterialWithTexture } from "../types.js";
4
4
  import { AttributeStorageInfo } from '@loaders.gl/i3s';
5
5
  import { Geoid } from '@math.gl/geoid';
6
- import type { GLTFAttributesData } from '../types';
6
+ import type { GLTFAttributesData } from "../types.js";
7
7
  import { BoundingSphere, OrientedBoundingBox } from '@math.gl/culling';
8
8
  /**
9
9
  * Convert binary data from b3dm file to i3s resources
@@ -24,7 +24,21 @@ import { BoundingSphere, OrientedBoundingBox } from '@math.gl/culling';
24
24
  * @param metadataClass `- user selected feature metadata class name`
25
25
  * @returns Array of node resources to create one or more i3s nodes
26
26
  */
27
- export default function convertB3dmToI3sGeometry(tileContent: Tiles3DTileContent, tileTransform: Matrix4, tileBoundingVolume: OrientedBoundingBox | BoundingSphere, addNodeToNodePage: () => Promise<number>, propertyTable: FeatureTableJson | null, featuresHashArray: string[], attributeStorageInfo: AttributeStorageInfo[] | undefined, draco: boolean, generateBoundingVolumes: boolean, shouldMergeMaterials: boolean, geoidHeightModel: Geoid, libraries: Record<string, string>, metadataClass?: string): Promise<I3SConvertedResources[] | null>;
27
+ export default function convertB3dmToI3sGeometry({ tileContent, tileTransform, tileBoundingVolume, addNodeToNodePage, propertyTable, featuresHashArray, attributeStorageInfo, draco, generateBoundingVolumes, shouldMergeMaterials, geoidHeightModel, libraries, metadataClass }: {
28
+ tileContent: Tiles3DTileContent;
29
+ tileTransform: Matrix4;
30
+ tileBoundingVolume: OrientedBoundingBox | BoundingSphere;
31
+ addNodeToNodePage: () => Promise<number>;
32
+ propertyTable: FeatureTableJson | null;
33
+ featuresHashArray: string[];
34
+ attributeStorageInfo: AttributeStorageInfo[] | undefined;
35
+ draco: boolean;
36
+ generateBoundingVolumes: boolean;
37
+ shouldMergeMaterials: boolean;
38
+ geoidHeightModel: Geoid;
39
+ libraries: Record<string, string>;
40
+ metadataClass?: string;
41
+ }): Promise<I3SConvertedResources[] | null>;
28
42
  /**
29
43
  * Convert attributes from the gltf nodes tree to i3s plain geometry
30
44
  * @param attributesData - geometry attributes from gltf
@@ -1 +1 @@
1
- {"version":3,"file":"geometry-converter.d.ts","sourceRoot":"","sources":["../../../src/i3s-converter/helpers/geometry-converter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,gBAAgB,EAAE,kBAAkB,EAAC,MAAM,sBAAsB,CAAC;AAgB/E,OAAO,EAAU,OAAO,EAAU,MAAM,eAAe,CAAC;AAUxD,OAAO,EACL,mBAAmB,EACnB,qBAAqB,EACrB,sBAAsB,EAGvB,MAAM,UAAU,CAAC;AAClB,OAAO,EACL,oBAAoB,EAIrB,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAC,KAAK,EAAC,MAAM,gBAAgB,CAAC;AAWrC,OAAO,KAAK,EAAC,kBAAkB,EAAgD,MAAM,UAAU,CAAC;AAEhG,OAAO,EAAC,cAAc,EAAE,mBAAmB,EAAC,MAAM,kBAAkB,CAAC;AAyBrE;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAA8B,wBAAwB,CACpD,WAAW,EAAE,kBAAkB,EAC/B,aAAa,EAAE,OAAO,EACtB,kBAAkB,EAAE,mBAAmB,GAAG,cAAc,EACxD,iBAAiB,EAAE,MAAM,OAAO,CAAC,MAAM,CAAC,EACxC,aAAa,EAAE,gBAAgB,GAAG,IAAI,EACtC,iBAAiB,EAAE,MAAM,EAAE,EAC3B,oBAAoB,EAAE,oBAAoB,EAAE,GAAG,SAAS,EACxD,KAAK,EAAE,OAAO,EACd,uBAAuB,EAAE,OAAO,EAChC,oBAAoB,EAAE,OAAO,EAC7B,gBAAgB,EAAE,KAAK,EACvB,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACjC,aAAa,CAAC,EAAE,MAAM,GACrB,OAAO,CAAC,qBAAqB,EAAE,GAAG,IAAI,CAAC,CAgEzC;AAoJD;;;;;;;;GAQG;AACH,wBAAsB,iBAAiB,CACrC,cAAc,EAAE,kBAAkB,EAClC,sBAAsB,EAAE,sBAAsB,EAAE,EAChD,qBAAqB,EAAE,OAAO,EAC9B,cAAc,EAAE,MAAM,GAAG,IAAI,GAC5B,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAC,CAkD3C;AAwsCD;;;;;;GAMG;AACH,wBAAgB,gBAAgB,CAC9B,WAAW,EAAE,kBAAkB,GAAG,IAAI,EACtC,aAAa,CAAC,EAAE,MAAM,GACrB,gBAAgB,GAAG,IAAI,CA+BzB"}
1
+ {"version":3,"file":"geometry-converter.d.ts","sourceRoot":"","sources":["../../../src/i3s-converter/helpers/geometry-converter.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAC,gBAAgB,EAAE,kBAAkB,EAAC,MAAM,sBAAsB,CAAC;AAgB/E,OAAO,EAAU,OAAO,EAAU,MAAM,eAAe,CAAC;AAUxD,OAAO,EACL,mBAAmB,EACnB,qBAAqB,EACrB,sBAAsB,EAGvB,oBAAiB;AAClB,OAAO,EACL,oBAAoB,EAIrB,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAC,KAAK,EAAC,MAAM,gBAAgB,CAAC;AAWrC,OAAO,KAAK,EAAC,kBAAkB,EAAgD,oBAAiB;AAEhG,OAAO,EAAC,cAAc,EAAE,mBAAmB,EAAC,MAAM,kBAAkB,CAAC;AAyBrE;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAA8B,wBAAwB,CAAC,EACrD,WAAW,EACX,aAAa,EACb,kBAAkB,EAClB,iBAAiB,EACjB,aAAa,EACb,iBAAiB,EACjB,oBAAoB,EACpB,KAAK,EACL,uBAAuB,EACvB,oBAAoB,EACpB,gBAAgB,EAChB,SAAS,EACT,aAAa,EACd,EAAE;IACD,WAAW,EAAE,kBAAkB,CAAC;IAChC,aAAa,EAAE,OAAO,CAAC;IACvB,kBAAkB,EAAE,mBAAmB,GAAG,cAAc,CAAC;IACzD,iBAAiB,EAAE,MAAM,OAAO,CAAC,MAAM,CAAC,CAAC;IACzC,aAAa,EAAE,gBAAgB,GAAG,IAAI,CAAC;IACvC,iBAAiB,EAAE,MAAM,EAAE,CAAC;IAC5B,oBAAoB,EAAE,oBAAoB,EAAE,GAAG,SAAS,CAAC;IACzD,KAAK,EAAE,OAAO,CAAC;IACf,uBAAuB,EAAE,OAAO,CAAC;IACjC,oBAAoB,EAAE,OAAO,CAAC;IAC9B,gBAAgB,EAAE,KAAK,CAAC;IACxB,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAClC,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,GAAG,OAAO,CAAC,qBAAqB,EAAE,GAAG,IAAI,CAAC,CAgE1C;AAqJD;;;;;;;;GAQG;AACH,wBAAsB,iBAAiB,CACrC,cAAc,EAAE,kBAAkB,EAClC,sBAAsB,EAAE,sBAAsB,EAAE,EAChD,qBAAqB,EAAE,OAAO,EAC9B,cAAc,EAAE,MAAM,GAAG,IAAI,GAC5B,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAC,CAiD3C;AAuuCD;;;;;;GAMG;AACH,wBAAgB,gBAAgB,CAC9B,WAAW,EAAE,kBAAkB,GAAG,IAAI,EACtC,aAAa,CAAC,EAAE,MAAM,GACrB,gBAAgB,GAAG,IAAI,CA+BzB"}