@loaders.gl/i3s 4.0.0-alpha.1 → 4.0.0-alpha.10

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 (226) hide show
  1. package/dist/arcgis-webscene-loader.d.ts +7 -0
  2. package/dist/arcgis-webscene-loader.d.ts.map +1 -0
  3. package/dist/arcgis-webscene-loader.js +28 -0
  4. package/dist/bundle.d.ts +2 -0
  5. package/dist/bundle.d.ts.map +1 -0
  6. package/dist/bundle.js +2 -2
  7. package/dist/dist.min.js +11262 -0
  8. package/dist/es5/arcgis-webscene-loader.js +40 -0
  9. package/dist/es5/arcgis-webscene-loader.js.map +1 -0
  10. package/dist/es5/bundle.js +6 -0
  11. package/dist/es5/bundle.js.map +1 -0
  12. package/dist/es5/i3s-attribute-loader.js +195 -0
  13. package/dist/es5/i3s-attribute-loader.js.map +1 -0
  14. package/dist/es5/i3s-building-scene-layer-loader.js +46 -0
  15. package/dist/es5/i3s-building-scene-layer-loader.js.map +1 -0
  16. package/dist/es5/i3s-content-loader.js +56 -0
  17. package/dist/es5/i3s-content-loader.js.map +1 -0
  18. package/dist/es5/i3s-loader.js +193 -0
  19. package/dist/es5/i3s-loader.js.map +1 -0
  20. package/dist/es5/i3s-node-page-loader.js +39 -0
  21. package/dist/es5/i3s-node-page-loader.js.map +1 -0
  22. package/dist/es5/i3s-slpk-loader.js +20 -0
  23. package/dist/es5/i3s-slpk-loader.js.map +1 -0
  24. package/dist/es5/index.js +68 -0
  25. package/dist/es5/index.js.map +1 -0
  26. package/dist/es5/lib/helpers/i3s-nodepages-tiles.js +312 -0
  27. package/dist/es5/lib/helpers/i3s-nodepages-tiles.js.map +1 -0
  28. package/dist/es5/lib/parsers/constants.js +72 -0
  29. package/dist/es5/lib/parsers/constants.js.map +1 -0
  30. package/dist/es5/lib/parsers/parse-arcgis-webscene.js +158 -0
  31. package/dist/es5/lib/parsers/parse-arcgis-webscene.js.map +1 -0
  32. package/dist/es5/lib/parsers/parse-i3s-attribute.js +76 -0
  33. package/dist/es5/lib/parsers/parse-i3s-attribute.js.map +1 -0
  34. package/dist/es5/lib/parsers/parse-i3s-building-scene-layer.js +65 -0
  35. package/dist/es5/lib/parsers/parse-i3s-building-scene-layer.js.map +1 -0
  36. package/dist/es5/lib/parsers/parse-i3s-tile-content.js +510 -0
  37. package/dist/es5/lib/parsers/parse-i3s-tile-content.js.map +1 -0
  38. package/dist/es5/lib/parsers/parse-i3s.js +116 -0
  39. package/dist/es5/lib/parsers/parse-i3s.js.map +1 -0
  40. package/dist/es5/lib/parsers/parse-slpk/parse-slpk.js +94 -0
  41. package/dist/es5/lib/parsers/parse-slpk/parse-slpk.js.map +1 -0
  42. package/dist/es5/lib/parsers/parse-slpk/slpk-archieve.js +229 -0
  43. package/dist/es5/lib/parsers/parse-slpk/slpk-archieve.js.map +1 -0
  44. package/dist/es5/lib/parsers/parse-zip/cd-file-header.js +44 -0
  45. package/dist/es5/lib/parsers/parse-zip/cd-file-header.js.map +1 -0
  46. package/dist/es5/lib/parsers/parse-zip/local-file-header.js +26 -0
  47. package/dist/es5/lib/parsers/parse-zip/local-file-header.js.map +1 -0
  48. package/dist/es5/lib/utils/convert-i3s-obb-to-mbs.js +17 -0
  49. package/dist/es5/lib/utils/convert-i3s-obb-to-mbs.js.map +1 -0
  50. package/dist/es5/lib/utils/customize-/321/201olors.js +184 -0
  51. package/dist/es5/lib/utils/customize-/321/201olors.js.map +1 -0
  52. package/dist/es5/lib/utils/url-utils.js +33 -0
  53. package/dist/es5/lib/utils/url-utils.js.map +1 -0
  54. package/dist/es5/types.js +26 -0
  55. package/dist/es5/types.js.map +1 -0
  56. package/dist/es5/workers/i3s-content-worker-node.js +7 -0
  57. package/dist/es5/workers/i3s-content-worker-node.js.map +1 -0
  58. package/dist/es5/workers/i3s-content-worker.js +6 -0
  59. package/dist/es5/workers/i3s-content-worker.js.map +1 -0
  60. package/dist/esm/arcgis-webscene-loader.js +16 -0
  61. package/dist/esm/arcgis-webscene-loader.js.map +1 -0
  62. package/dist/esm/bundle.js +4 -0
  63. package/dist/esm/bundle.js.map +1 -0
  64. package/dist/esm/i3s-attribute-loader.js +119 -0
  65. package/dist/esm/i3s-attribute-loader.js.map +1 -0
  66. package/dist/esm/i3s-building-scene-layer-loader.js +19 -0
  67. package/dist/esm/i3s-building-scene-layer-loader.js.map +1 -0
  68. package/dist/esm/i3s-content-loader.js +30 -0
  69. package/dist/esm/i3s-content-loader.js.map +1 -0
  70. package/dist/esm/i3s-loader.js +87 -0
  71. package/dist/esm/i3s-loader.js.map +1 -0
  72. package/dist/esm/i3s-node-page-loader.js +15 -0
  73. package/dist/esm/i3s-node-page-loader.js.map +1 -0
  74. package/dist/esm/i3s-slpk-loader.js +13 -0
  75. package/dist/esm/i3s-slpk-loader.js.map +1 -0
  76. package/dist/esm/index.js +9 -0
  77. package/dist/esm/index.js.map +1 -0
  78. package/dist/esm/lib/helpers/i3s-nodepages-tiles.js +198 -0
  79. package/dist/esm/lib/helpers/i3s-nodepages-tiles.js.map +1 -0
  80. package/dist/esm/lib/parsers/constants.js +57 -0
  81. package/dist/esm/lib/parsers/constants.js.map +1 -0
  82. package/dist/esm/lib/parsers/parse-arcgis-webscene.js +70 -0
  83. package/dist/esm/lib/parsers/parse-arcgis-webscene.js.map +1 -0
  84. package/dist/esm/lib/parsers/parse-i3s-attribute.js +60 -0
  85. package/dist/esm/lib/parsers/parse-i3s-attribute.js.map +1 -0
  86. package/dist/esm/lib/parsers/parse-i3s-building-scene-layer.js +39 -0
  87. package/dist/esm/lib/parsers/parse-i3s-building-scene-layer.js.map +1 -0
  88. package/dist/esm/lib/parsers/parse-i3s-tile-content.js +435 -0
  89. package/dist/esm/lib/parsers/parse-i3s-tile-content.js.map +1 -0
  90. package/dist/esm/lib/parsers/parse-i3s.js +83 -0
  91. package/dist/esm/lib/parsers/parse-i3s.js.map +1 -0
  92. package/dist/esm/lib/parsers/parse-slpk/parse-slpk.js +37 -0
  93. package/dist/esm/lib/parsers/parse-slpk/parse-slpk.js.map +1 -0
  94. package/dist/esm/lib/parsers/parse-slpk/slpk-archieve.js +108 -0
  95. package/dist/esm/lib/parsers/parse-slpk/slpk-archieve.js.map +1 -0
  96. package/dist/esm/lib/parsers/parse-zip/cd-file-header.js +37 -0
  97. package/dist/esm/lib/parsers/parse-zip/cd-file-header.js.map +1 -0
  98. package/dist/esm/lib/parsers/parse-zip/local-file-header.js +19 -0
  99. package/dist/esm/lib/parsers/parse-zip/local-file-header.js.map +1 -0
  100. package/dist/esm/lib/utils/convert-i3s-obb-to-mbs.js +9 -0
  101. package/dist/esm/lib/utils/convert-i3s-obb-to-mbs.js.map +1 -0
  102. package/dist/esm/lib/utils/customize-/321/201olors.js +98 -0
  103. package/dist/esm/lib/utils/customize-/321/201olors.js.map +1 -0
  104. package/dist/esm/lib/utils/url-utils.js +28 -0
  105. package/dist/esm/lib/utils/url-utils.js.map +1 -0
  106. package/dist/esm/types.js +18 -0
  107. package/dist/esm/types.js.map +1 -0
  108. package/dist/esm/workers/i3s-content-worker-node.js +5 -0
  109. package/dist/esm/workers/i3s-content-worker-node.js.map +1 -0
  110. package/dist/esm/workers/i3s-content-worker.js +4 -0
  111. package/dist/esm/workers/i3s-content-worker.js.map +1 -0
  112. package/dist/i3s-attribute-loader.d.ts +21 -0
  113. package/dist/i3s-attribute-loader.d.ts.map +1 -0
  114. package/dist/i3s-attribute-loader.js +155 -132
  115. package/dist/i3s-building-scene-layer-loader.d.ts +6 -0
  116. package/dist/i3s-building-scene-layer-loader.d.ts.map +1 -0
  117. package/dist/i3s-building-scene-layer-loader.js +23 -18
  118. package/dist/i3s-content-loader.d.ts +6 -0
  119. package/dist/i3s-content-loader.d.ts.map +1 -0
  120. package/dist/i3s-content-loader.js +29 -22
  121. package/dist/i3s-content-worker-node.js +197 -0
  122. package/dist/i3s-content-worker-node.js.map +7 -0
  123. package/dist/i3s-content-worker.js +2308 -1376
  124. package/dist/i3s-loader.d.ts +11 -0
  125. package/dist/i3s-loader.d.ts.map +1 -0
  126. package/dist/i3s-loader.js +88 -81
  127. package/dist/i3s-node-page-loader.d.ts +7 -0
  128. package/dist/i3s-node-page-loader.d.ts.map +1 -0
  129. package/dist/i3s-node-page-loader.js +20 -20
  130. package/dist/i3s-slpk-loader.d.ts +13 -0
  131. package/dist/i3s-slpk-loader.d.ts.map +1 -0
  132. package/dist/i3s-slpk-loader.js +20 -0
  133. package/dist/index.d.ts +10 -0
  134. package/dist/index.d.ts.map +1 -0
  135. package/dist/index.js +21 -5
  136. package/dist/lib/helpers/i3s-nodepages-tiles.d.ts +74 -0
  137. package/dist/lib/helpers/i3s-nodepages-tiles.d.ts.map +1 -0
  138. package/dist/lib/helpers/i3s-nodepages-tiles.js +232 -219
  139. package/dist/lib/parsers/constants.d.ts +40 -0
  140. package/dist/lib/parsers/constants.d.ts.map +1 -0
  141. package/dist/lib/parsers/constants.js +87 -42
  142. package/dist/lib/parsers/parse-arcgis-webscene.d.ts +7 -0
  143. package/dist/lib/parsers/parse-arcgis-webscene.d.ts.map +1 -0
  144. package/dist/lib/parsers/parse-arcgis-webscene.js +88 -0
  145. package/dist/lib/parsers/parse-i3s-attribute.d.ts +12 -0
  146. package/dist/lib/parsers/parse-i3s-attribute.d.ts.map +1 -0
  147. package/dist/lib/parsers/parse-i3s-attribute.js +87 -62
  148. package/dist/lib/parsers/parse-i3s-building-scene-layer.d.ts +9 -0
  149. package/dist/lib/parsers/parse-i3s-building-scene-layer.d.ts.map +1 -0
  150. package/dist/lib/parsers/parse-i3s-building-scene-layer.js +41 -38
  151. package/dist/lib/parsers/parse-i3s-tile-content.d.ts +4 -0
  152. package/dist/lib/parsers/parse-i3s-tile-content.d.ts.map +1 -0
  153. package/dist/lib/parsers/parse-i3s-tile-content.js +460 -415
  154. package/dist/lib/parsers/parse-i3s.d.ts +6 -0
  155. package/dist/lib/parsers/parse-i3s.d.ts.map +1 -0
  156. package/dist/lib/parsers/parse-i3s.js +92 -73
  157. package/dist/lib/parsers/parse-slpk/parse-slpk.d.ts +4 -0
  158. package/dist/lib/parsers/parse-slpk/parse-slpk.d.ts.map +1 -0
  159. package/dist/lib/parsers/parse-slpk/parse-slpk.js +50 -0
  160. package/dist/lib/parsers/parse-slpk/slpk-archieve.d.ts +38 -0
  161. package/dist/lib/parsers/parse-slpk/slpk-archieve.d.ts.map +1 -0
  162. package/dist/lib/parsers/parse-slpk/slpk-archieve.js +142 -0
  163. package/dist/lib/parsers/parse-zip/cd-file-header.d.ts +38 -0
  164. package/dist/lib/parsers/parse-zip/cd-file-header.d.ts.map +1 -0
  165. package/dist/lib/parsers/parse-zip/cd-file-header.js +48 -0
  166. package/dist/lib/parsers/parse-zip/local-file-header.d.ts +30 -0
  167. package/dist/lib/parsers/parse-zip/local-file-header.d.ts.map +1 -0
  168. package/dist/lib/parsers/parse-zip/local-file-header.js +28 -0
  169. package/dist/lib/utils/convert-i3s-obb-to-mbs.d.ts +2 -0
  170. package/dist/lib/utils/convert-i3s-obb-to-mbs.d.ts.map +1 -0
  171. package/dist/lib/utils/convert-i3s-obb-to-mbs.js +19 -8
  172. package/dist/lib/utils/customize-/321/201olors.d.ts +14 -0
  173. package/dist/lib/utils/customize-/321/201olors.d.ts.map +1 -0
  174. package/dist/lib/utils/customize-/321/201olors.js +104 -0
  175. package/dist/lib/utils/url-utils.d.ts +22 -0
  176. package/dist/lib/utils/url-utils.d.ts.map +1 -0
  177. package/dist/lib/utils/url-utils.js +41 -29
  178. package/dist/types.d.ts +1065 -0
  179. package/dist/types.d.ts.map +1 -0
  180. package/dist/types.js +20 -2
  181. package/dist/workers/i3s-content-worker-node.d.ts +2 -0
  182. package/dist/workers/i3s-content-worker-node.d.ts.map +1 -0
  183. package/dist/workers/i3s-content-worker-node.js +7 -0
  184. package/dist/workers/i3s-content-worker.d.ts +2 -0
  185. package/dist/workers/i3s-content-worker.d.ts.map +1 -0
  186. package/dist/workers/i3s-content-worker.js +5 -4
  187. package/package.json +18 -16
  188. package/src/arcgis-webscene-loader.ts +31 -0
  189. package/src/i3s-attribute-loader.ts +9 -9
  190. package/src/i3s-content-loader.ts +17 -5
  191. package/src/i3s-loader.ts +24 -13
  192. package/src/i3s-node-page-loader.ts +6 -10
  193. package/src/i3s-slpk-loader.ts +27 -0
  194. package/src/index.ts +26 -7
  195. package/src/lib/helpers/i3s-nodepages-tiles.ts +84 -57
  196. package/src/lib/parsers/constants.ts +71 -37
  197. package/src/lib/parsers/parse-arcgis-webscene.ts +102 -0
  198. package/src/lib/parsers/parse-i3s-attribute.ts +21 -14
  199. package/src/lib/parsers/parse-i3s-building-scene-layer.ts +2 -1
  200. package/src/lib/parsers/parse-i3s-tile-content.ts +278 -194
  201. package/src/lib/parsers/parse-i3s.ts +55 -39
  202. package/src/lib/parsers/parse-slpk/parse-slpk.ts +64 -0
  203. package/src/lib/parsers/parse-slpk/slpk-archieve.ts +172 -0
  204. package/src/lib/parsers/parse-zip/cd-file-header.ts +93 -0
  205. package/src/lib/parsers/parse-zip/local-file-header.ts +56 -0
  206. package/src/lib/utils/customize-/321/201olors.ts +144 -0
  207. package/src/lib/utils/url-utils.ts +7 -7
  208. package/src/types.ts +875 -86
  209. package/src/workers/i3s-content-worker-node.ts +6 -0
  210. package/dist/bundle.js.map +0 -1
  211. package/dist/i3s-attribute-loader.js.map +0 -1
  212. package/dist/i3s-building-scene-layer-loader.js.map +0 -1
  213. package/dist/i3s-content-loader.js.map +0 -1
  214. package/dist/i3s-loader.js.map +0 -1
  215. package/dist/i3s-node-page-loader.js.map +0 -1
  216. package/dist/index.js.map +0 -1
  217. package/dist/lib/helpers/i3s-nodepages-tiles.js.map +0 -1
  218. package/dist/lib/parsers/constants.js.map +0 -1
  219. package/dist/lib/parsers/parse-i3s-attribute.js.map +0 -1
  220. package/dist/lib/parsers/parse-i3s-building-scene-layer.js.map +0 -1
  221. package/dist/lib/parsers/parse-i3s-tile-content.js.map +0 -1
  222. package/dist/lib/parsers/parse-i3s.js.map +0 -1
  223. package/dist/lib/utils/convert-i3s-obb-to-mbs.js.map +0 -1
  224. package/dist/lib/utils/url-utils.js.map +0 -1
  225. package/dist/types.js.map +0 -1
  226. package/dist/workers/i3s-content-worker.js.map +0 -1
@@ -0,0 +1,83 @@
1
+ import { OrientedBoundingBox } from '@math.gl/culling';
2
+ import { Ellipsoid } from '@math.gl/geospatial';
3
+ import { load } from '@loaders.gl/core';
4
+ import { TILE_TYPE, TILE_REFINEMENT, TILESET_TYPE } from '@loaders.gl/tiles';
5
+ import I3SNodePagesTiles from '../helpers/i3s-nodepages-tiles';
6
+ import { generateTileAttributeUrls, getUrlWithToken } from '../utils/url-utils';
7
+ export function normalizeTileData(tile, context) {
8
+ const url = context.url || '';
9
+ let contentUrl;
10
+ if (tile.geometryData) {
11
+ contentUrl = "".concat(url, "/").concat(tile.geometryData[0].href);
12
+ }
13
+ let textureUrl;
14
+ if (tile.textureData) {
15
+ textureUrl = "".concat(url, "/").concat(tile.textureData[0].href);
16
+ }
17
+ let attributeUrls;
18
+ if (tile.attributeData) {
19
+ attributeUrls = generateTileAttributeUrls(url, tile);
20
+ }
21
+ return normalizeTileNonUrlData({
22
+ ...tile,
23
+ url,
24
+ contentUrl,
25
+ textureUrl,
26
+ attributeUrls,
27
+ isDracoGeometry: false
28
+ });
29
+ }
30
+ export function normalizeTileNonUrlData(tile) {
31
+ var _tile$lodSelection, _tile$lodSelection2;
32
+ const boundingVolume = {};
33
+ let mbs = [0, 0, 0, 1];
34
+ if (tile.mbs) {
35
+ mbs = tile.mbs;
36
+ boundingVolume.sphere = [...Ellipsoid.WGS84.cartographicToCartesian(tile.mbs.slice(0, 3)), tile.mbs[3]];
37
+ } else if (tile.obb) {
38
+ boundingVolume.box = [...Ellipsoid.WGS84.cartographicToCartesian(tile.obb.center), ...tile.obb.halfSize, ...tile.obb.quaternion];
39
+ const obb = new OrientedBoundingBox().fromCenterHalfSizeQuaternion(boundingVolume.box.slice(0, 3), tile.obb.halfSize, tile.obb.quaternion);
40
+ const boundingSphere = obb.getBoundingSphere();
41
+ boundingVolume.sphere = [...boundingSphere.center, boundingSphere.radius];
42
+ mbs = [...tile.obb.center, boundingSphere.radius];
43
+ }
44
+ const lodMetricType = (_tile$lodSelection = tile.lodSelection) === null || _tile$lodSelection === void 0 ? void 0 : _tile$lodSelection[0].metricType;
45
+ const lodMetricValue = (_tile$lodSelection2 = tile.lodSelection) === null || _tile$lodSelection2 === void 0 ? void 0 : _tile$lodSelection2[0].maxError;
46
+ const transformMatrix = tile.transform;
47
+ const type = TILE_TYPE.MESH;
48
+ const refine = TILE_REFINEMENT.REPLACE;
49
+ return {
50
+ ...tile,
51
+ mbs,
52
+ boundingVolume,
53
+ lodMetricType,
54
+ lodMetricValue,
55
+ transformMatrix,
56
+ type,
57
+ refine
58
+ };
59
+ }
60
+ export async function normalizeTilesetData(tileset, options, context) {
61
+ tileset.url = context.url;
62
+ if (tileset.nodePages) {
63
+ tileset.nodePagesTile = new I3SNodePagesTiles(tileset, options);
64
+ tileset.root = tileset.nodePagesTile.formTileFromNodePages(0);
65
+ } else {
66
+ var _options$i3s;
67
+ const rootNodeUrl = getUrlWithToken("".concat(tileset.url, "/nodes/root"), (_options$i3s = options.i3s) === null || _options$i3s === void 0 ? void 0 : _options$i3s.token);
68
+ tileset.root = await load(rootNodeUrl, tileset.loader, {
69
+ ...options,
70
+ i3s: {
71
+ ...options.i3s,
72
+ loadContent: false,
73
+ isTileHeader: true,
74
+ isTileset: false
75
+ }
76
+ });
77
+ }
78
+ tileset.basePath = tileset.url;
79
+ tileset.type = TILESET_TYPE.I3S;
80
+ tileset.lodMetricType = tileset.root.lodMetricType;
81
+ tileset.lodMetricValue = tileset.root.lodMetricValue;
82
+ }
83
+ //# sourceMappingURL=parse-i3s.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parse-i3s.js","names":["OrientedBoundingBox","Ellipsoid","load","TILE_TYPE","TILE_REFINEMENT","TILESET_TYPE","I3SNodePagesTiles","generateTileAttributeUrls","getUrlWithToken","normalizeTileData","tile","context","url","contentUrl","geometryData","concat","href","textureUrl","textureData","attributeUrls","attributeData","normalizeTileNonUrlData","isDracoGeometry","_tile$lodSelection","_tile$lodSelection2","boundingVolume","mbs","sphere","WGS84","cartographicToCartesian","slice","obb","box","center","halfSize","quaternion","fromCenterHalfSizeQuaternion","boundingSphere","getBoundingSphere","radius","lodMetricType","lodSelection","metricType","lodMetricValue","maxError","transformMatrix","transform","type","MESH","refine","REPLACE","normalizeTilesetData","tileset","options","nodePages","nodePagesTile","root","formTileFromNodePages","_options$i3s","rootNodeUrl","i3s","token","loader","loadContent","isTileHeader","isTileset","basePath","I3S"],"sources":["../../../../src/lib/parsers/parse-i3s.ts"],"sourcesContent":["import {OrientedBoundingBox} from '@math.gl/culling';\nimport {Ellipsoid} from '@math.gl/geospatial';\nimport {load} from '@loaders.gl/core';\nimport {TILE_TYPE, TILE_REFINEMENT, TILESET_TYPE} from '@loaders.gl/tiles';\nimport I3SNodePagesTiles from '../helpers/i3s-nodepages-tiles';\nimport {generateTileAttributeUrls, getUrlWithToken} from '../utils/url-utils';\nimport {\n I3STilesetHeader,\n I3STileHeader,\n Mbs,\n I3SMinimalNodeData,\n Node3DIndexDocument\n} from '../../types';\nimport type {LoaderOptions, LoaderContext} from '@loaders.gl/loader-utils';\n\nexport function normalizeTileData(tile : Node3DIndexDocument, context: LoaderContext): I3STileHeader {\n const url: string = context.url || '';\n let contentUrl: string | undefined;\n if (tile.geometryData) {\n contentUrl = `${url}/${tile.geometryData[0].href}`;\n }\n\n let textureUrl: string | undefined;\n if (tile.textureData) {\n textureUrl = `${url}/${tile.textureData[0].href}`;\n }\n\n let attributeUrls: string[] | undefined;\n if (tile.attributeData) {\n attributeUrls = generateTileAttributeUrls(url, tile);\n }\n\n return normalizeTileNonUrlData({\n ...tile,\n url,\n contentUrl,\n textureUrl,\n attributeUrls,\n isDracoGeometry: false\n });\n}\n\nexport function normalizeTileNonUrlData(tile : I3SMinimalNodeData): I3STileHeader {\n const boundingVolume: {box?: number[]; sphere?: number[]} = {};\n let mbs: Mbs = [0, 0, 0, 1];\n if (tile.mbs) {\n mbs = tile.mbs;\n boundingVolume.sphere = [\n ...Ellipsoid.WGS84.cartographicToCartesian(tile.mbs.slice(0, 3)), // cartesian center of sphere\n tile.mbs[3] // radius of sphere\n ] as Mbs;\n } else if (tile.obb) {\n boundingVolume.box = [\n ...Ellipsoid.WGS84.cartographicToCartesian(tile.obb.center), // cartesian center of box\n ...tile.obb.halfSize, // halfSize\n ...tile.obb.quaternion // quaternion\n ];\n const obb = new OrientedBoundingBox().fromCenterHalfSizeQuaternion(\n boundingVolume.box.slice(0, 3),\n tile.obb.halfSize,\n tile.obb.quaternion\n );\n const boundingSphere = obb.getBoundingSphere();\n boundingVolume.sphere = [...boundingSphere.center , boundingSphere.radius] as Mbs;\n mbs = [...tile.obb.center, boundingSphere.radius] as Mbs;\n }\n\n const lodMetricType = tile.lodSelection?.[0].metricType;\n const lodMetricValue = tile.lodSelection?.[0].maxError;\n const transformMatrix = tile.transform;\n const type = TILE_TYPE.MESH;\n /**\n * I3S specification supports only REPLACE\n */\n const refine = TILE_REFINEMENT.REPLACE;\n\n return {...tile, mbs, boundingVolume, lodMetricType, lodMetricValue, transformMatrix, type, refine};\n}\n\nexport async function normalizeTilesetData(tileset : I3STilesetHeader, options : LoaderOptions, context: LoaderContext) {\n tileset.url = context.url;\n\n if (tileset.nodePages) {\n tileset.nodePagesTile = new I3SNodePagesTiles(tileset, options);\n tileset.root = tileset.nodePagesTile.formTileFromNodePages(0);\n } else {\n // @ts-expect-error options is not properly typed\n const rootNodeUrl = getUrlWithToken(`${tileset.url}/nodes/root`, options.i3s?.token);\n // eslint-disable-next-line no-use-before-define\n tileset.root = await load(rootNodeUrl, tileset.loader, {\n ...options,\n i3s: {\n // @ts-expect-error options is not properly typed\n ...options.i3s,\n loadContent: false, isTileHeader: true, isTileset: false}\n });\n }\n\n // base path that non-absolute paths in tileset are relative to.\n tileset.basePath = tileset.url;\n tileset.type = TILESET_TYPE.I3S;\n\n // populate from root node\n tileset.lodMetricType = tileset.root.lodMetricType;\n tileset.lodMetricValue = tileset.root.lodMetricValue;\n}\n"],"mappings":"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"}
@@ -0,0 +1,37 @@
1
+ import { parseZipCDFileHeader } from '../parse-zip/cd-file-header';
2
+ import { parseZipLocalFileHeader } from '../parse-zip/local-file-header';
3
+ import { SLPKArchive } from './slpk-archieve';
4
+ const getByteAt = (offset, buffer) => {
5
+ return buffer.getUint8(buffer.byteOffset + offset);
6
+ };
7
+ export async function parseSLPK(data) {
8
+ var _options$slpk$path, _options$slpk, _options$slpk2;
9
+ let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
10
+ const archive = new DataView(data);
11
+ const cdFileHeaderSignature = [80, 75, 1, 2];
12
+ const searchWindow = [getByteAt(archive.byteLength - 1, archive), getByteAt(archive.byteLength - 2, archive), getByteAt(archive.byteLength - 3, archive), undefined];
13
+ let hashCDOffset = 0;
14
+ for (let i = archive.byteLength - 4; i > -1; i--) {
15
+ searchWindow[3] = searchWindow[2];
16
+ searchWindow[2] = searchWindow[1];
17
+ searchWindow[1] = searchWindow[0];
18
+ searchWindow[0] = getByteAt(i, archive);
19
+ if (searchWindow.every((val, index) => val === cdFileHeaderSignature[index])) {
20
+ hashCDOffset = i;
21
+ break;
22
+ }
23
+ }
24
+ const cdFileHeader = parseZipCDFileHeader(hashCDOffset, archive);
25
+ const textDecoder = new TextDecoder();
26
+ if (textDecoder.decode(cdFileHeader.fileName) !== '@specialIndexFileHASH128@') {
27
+ throw new Error('No hash file in slpk');
28
+ }
29
+ const localFileHeader = parseZipLocalFileHeader(cdFileHeader.localHeaderOffset, archive);
30
+ const fileDataOffset = localFileHeader.fileDataOffset;
31
+ const hashFile = archive.buffer.slice(fileDataOffset, fileDataOffset + localFileHeader.compressedSize);
32
+ if (!hashFile) {
33
+ throw new Error('No hash file in slpk');
34
+ }
35
+ return await new SLPKArchive(data, hashFile).getFile((_options$slpk$path = (_options$slpk = options.slpk) === null || _options$slpk === void 0 ? void 0 : _options$slpk.path) !== null && _options$slpk$path !== void 0 ? _options$slpk$path : '', (_options$slpk2 = options.slpk) === null || _options$slpk2 === void 0 ? void 0 : _options$slpk2.pathMode);
36
+ }
37
+ //# sourceMappingURL=parse-slpk.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parse-slpk.js","names":["parseZipCDFileHeader","parseZipLocalFileHeader","SLPKArchive","getByteAt","offset","buffer","getUint8","byteOffset","parseSLPK","data","_options$slpk$path","_options$slpk","_options$slpk2","options","arguments","length","undefined","archive","DataView","cdFileHeaderSignature","searchWindow","byteLength","hashCDOffset","i","every","val","index","cdFileHeader","textDecoder","TextDecoder","decode","fileName","Error","localFileHeader","localHeaderOffset","fileDataOffset","hashFile","slice","compressedSize","getFile","slpk","path","pathMode"],"sources":["../../../../../src/lib/parsers/parse-slpk/parse-slpk.ts"],"sourcesContent":["import type {SLPKLoaderOptions} from '../../../i3s-slpk-loader';\nimport {parseZipCDFileHeader} from '../parse-zip/cd-file-header';\nimport {parseZipLocalFileHeader} from '../parse-zip/local-file-header';\nimport {SLPKArchive} from './slpk-archieve';\n\n/**\n * Returns one byte from the provided buffer at the provided position\n * @param offset - position where to read\n * @param buffer - buffer to read\n * @returns one byte from the provided buffer at the provided position\n */\nconst getByteAt = (offset: number, buffer: DataView): number => {\n return buffer.getUint8(buffer.byteOffset + offset);\n};\n\nexport async function parseSLPK(data: ArrayBuffer, options: SLPKLoaderOptions = {}) {\n const archive = new DataView(data);\n const cdFileHeaderSignature = [80, 75, 1, 2];\n\n const searchWindow = [\n getByteAt(archive.byteLength - 1, archive),\n getByteAt(archive.byteLength - 2, archive),\n getByteAt(archive.byteLength - 3, archive),\n undefined\n ];\n\n let hashCDOffset = 0;\n\n // looking for the last record in the central directory\n for (let i = archive.byteLength - 4; i > -1; i--) {\n searchWindow[3] = searchWindow[2];\n searchWindow[2] = searchWindow[1];\n searchWindow[1] = searchWindow[0];\n searchWindow[0] = getByteAt(i, archive);\n if (searchWindow.every((val, index) => val === cdFileHeaderSignature[index])) {\n hashCDOffset = i;\n break;\n }\n }\n\n const cdFileHeader = parseZipCDFileHeader(hashCDOffset, archive);\n\n const textDecoder = new TextDecoder();\n if (textDecoder.decode(cdFileHeader.fileName) !== '@specialIndexFileHASH128@') {\n throw new Error('No hash file in slpk');\n }\n\n const localFileHeader = parseZipLocalFileHeader(cdFileHeader.localHeaderOffset, archive);\n\n const fileDataOffset = localFileHeader.fileDataOffset;\n const hashFile = archive.buffer.slice(\n fileDataOffset,\n fileDataOffset + localFileHeader.compressedSize\n );\n\n if (!hashFile) {\n throw new Error('No hash file in slpk');\n }\n\n return await new SLPKArchive(data, hashFile).getFile(\n options.slpk?.path ?? '',\n options.slpk?.pathMode\n );\n}\n"],"mappings":"AACA,SAAQA,oBAAoB,QAAO,6BAA6B;AAChE,SAAQC,uBAAuB,QAAO,gCAAgC;AACtE,SAAQC,WAAW,QAAO,iBAAiB;AAQ3C,MAAMC,SAAS,GAAGA,CAACC,MAAc,EAAEC,MAAgB,KAAa;EAC9D,OAAOA,MAAM,CAACC,QAAQ,CAACD,MAAM,CAACE,UAAU,GAAGH,MAAM,CAAC;AACpD,CAAC;AAED,OAAO,eAAeI,SAASA,CAACC,IAAiB,EAAmC;EAAA,IAAAC,kBAAA,EAAAC,aAAA,EAAAC,cAAA;EAAA,IAAjCC,OAA0B,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC,CAAC;EAChF,MAAMG,OAAO,GAAG,IAAIC,QAAQ,CAACT,IAAI,CAAC;EAClC,MAAMU,qBAAqB,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC;EAE5C,MAAMC,YAAY,GAAG,CACnBjB,SAAS,CAACc,OAAO,CAACI,UAAU,GAAG,CAAC,EAAEJ,OAAO,CAAC,EAC1Cd,SAAS,CAACc,OAAO,CAACI,UAAU,GAAG,CAAC,EAAEJ,OAAO,CAAC,EAC1Cd,SAAS,CAACc,OAAO,CAACI,UAAU,GAAG,CAAC,EAAEJ,OAAO,CAAC,EAC1CD,SAAS,CACV;EAED,IAAIM,YAAY,GAAG,CAAC;EAGpB,KAAK,IAAIC,CAAC,GAAGN,OAAO,CAACI,UAAU,GAAG,CAAC,EAAEE,CAAC,GAAG,CAAC,CAAC,EAAEA,CAAC,EAAE,EAAE;IAChDH,YAAY,CAAC,CAAC,CAAC,GAAGA,YAAY,CAAC,CAAC,CAAC;IACjCA,YAAY,CAAC,CAAC,CAAC,GAAGA,YAAY,CAAC,CAAC,CAAC;IACjCA,YAAY,CAAC,CAAC,CAAC,GAAGA,YAAY,CAAC,CAAC,CAAC;IACjCA,YAAY,CAAC,CAAC,CAAC,GAAGjB,SAAS,CAACoB,CAAC,EAAEN,OAAO,CAAC;IACvC,IAAIG,YAAY,CAACI,KAAK,CAAC,CAACC,GAAG,EAAEC,KAAK,KAAKD,GAAG,KAAKN,qBAAqB,CAACO,KAAK,CAAC,CAAC,EAAE;MAC5EJ,YAAY,GAAGC,CAAC;MAChB;IACF;EACF;EAEA,MAAMI,YAAY,GAAG3B,oBAAoB,CAACsB,YAAY,EAAEL,OAAO,CAAC;EAEhE,MAAMW,WAAW,GAAG,IAAIC,WAAW,CAAC,CAAC;EACrC,IAAID,WAAW,CAACE,MAAM,CAACH,YAAY,CAACI,QAAQ,CAAC,KAAK,2BAA2B,EAAE;IAC7E,MAAM,IAAIC,KAAK,CAAC,sBAAsB,CAAC;EACzC;EAEA,MAAMC,eAAe,GAAGhC,uBAAuB,CAAC0B,YAAY,CAACO,iBAAiB,EAAEjB,OAAO,CAAC;EAExF,MAAMkB,cAAc,GAAGF,eAAe,CAACE,cAAc;EACrD,MAAMC,QAAQ,GAAGnB,OAAO,CAACZ,MAAM,CAACgC,KAAK,CACnCF,cAAc,EACdA,cAAc,GAAGF,eAAe,CAACK,cACnC,CAAC;EAED,IAAI,CAACF,QAAQ,EAAE;IACb,MAAM,IAAIJ,KAAK,CAAC,sBAAsB,CAAC;EACzC;EAEA,OAAO,MAAM,IAAI9B,WAAW,CAACO,IAAI,EAAE2B,QAAQ,CAAC,CAACG,OAAO,EAAA7B,kBAAA,IAAAC,aAAA,GAClDE,OAAO,CAAC2B,IAAI,cAAA7B,aAAA,uBAAZA,aAAA,CAAc8B,IAAI,cAAA/B,kBAAA,cAAAA,kBAAA,GAAI,EAAE,GAAAE,cAAA,GACxBC,OAAO,CAAC2B,IAAI,cAAA5B,cAAA,uBAAZA,cAAA,CAAc8B,QAChB,CAAC;AACH"}
@@ -0,0 +1,108 @@
1
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
+ import { processOnWorker } from '@loaders.gl/worker-utils';
3
+ import md5 from 'md5';
4
+ import { CompressionWorker } from '@loaders.gl/compression';
5
+ import { parseZipLocalFileHeader } from '../parse-zip/local-file-header';
6
+ const PATH_DESCRIPTIONS = [{
7
+ test: /^$/,
8
+ extensions: ['3dSceneLayer.json.gz']
9
+ }, {
10
+ test: /^nodepages\/\d+$/,
11
+ extensions: ['.json.gz']
12
+ }, {
13
+ test: /^nodes\/\d+$/,
14
+ extensions: ['/3dNodeIndexDocument.json.gz']
15
+ }, {
16
+ test: /^nodes\/\d+\/textures\/.+$/,
17
+ extensions: ['.jpg', '.png', '.bin.dds.gz', '.ktx']
18
+ }, {
19
+ test: /^nodes\/\d+\/geometries\/\d+$/,
20
+ extensions: ['.bin.gz', '.draco.gz']
21
+ }, {
22
+ test: /^nodes\/\d+\/attributes\/f_\d+\/\d+$/,
23
+ extensions: ['.bin.gz']
24
+ }, {
25
+ test: /^statistics\/f_\d+\/\d+$/,
26
+ extensions: ['.json.gz']
27
+ }, {
28
+ test: /^nodes\/\d+\/shared$/,
29
+ extensions: ['/sharedResource.json.gz']
30
+ }];
31
+ export class SLPKArchive {
32
+ constructor(slpkArchiveBuffer, hashFile) {
33
+ _defineProperty(this, "slpkArchive", void 0);
34
+ _defineProperty(this, "hashArray", void 0);
35
+ this.slpkArchive = new DataView(slpkArchiveBuffer);
36
+ this.hashArray = this.parseHashFile(hashFile);
37
+ }
38
+ parseHashFile(hashFile) {
39
+ const hashFileBuffer = Buffer.from(hashFile);
40
+ const hashArray = [];
41
+ for (let i = 0; i < hashFileBuffer.buffer.byteLength; i = i + 24) {
42
+ const offsetBuffer = new DataView(hashFileBuffer.buffer.slice(hashFileBuffer.byteOffset + i + 16, hashFileBuffer.byteOffset + i + 24));
43
+ const offset = offsetBuffer.getUint32(offsetBuffer.byteOffset, true);
44
+ hashArray.push({
45
+ hash: Buffer.from(hashFileBuffer.subarray(hashFileBuffer.byteOffset + i, hashFileBuffer.byteOffset + i + 16)),
46
+ offset
47
+ });
48
+ }
49
+ return hashArray;
50
+ }
51
+ async getFile(path) {
52
+ let mode = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'raw';
53
+ if (mode === 'http') {
54
+ var _PATH_DESCRIPTIONS$fi;
55
+ const extensions = (_PATH_DESCRIPTIONS$fi = PATH_DESCRIPTIONS.find(val => val.test.test(path))) === null || _PATH_DESCRIPTIONS$fi === void 0 ? void 0 : _PATH_DESCRIPTIONS$fi.extensions;
56
+ if (extensions) {
57
+ let data;
58
+ for (const ext of extensions) {
59
+ data = await this.getDataByPath("".concat(path).concat(ext));
60
+ if (data) {
61
+ break;
62
+ }
63
+ }
64
+ if (data) {
65
+ return Buffer.from(data);
66
+ }
67
+ }
68
+ }
69
+ if (mode === 'raw') {
70
+ const decompressedFile = await this.getDataByPath("".concat(path, ".gz"));
71
+ if (decompressedFile) {
72
+ return Buffer.from(decompressedFile);
73
+ }
74
+ const fileWithoutCompression = this.getFileBytes(path);
75
+ if (fileWithoutCompression) {
76
+ return Buffer.from(fileWithoutCompression);
77
+ }
78
+ }
79
+ throw new Error('No such file in the archieve');
80
+ }
81
+ async getDataByPath(path) {
82
+ const data = this.getFileBytes(path);
83
+ if (!data) {
84
+ return undefined;
85
+ }
86
+ if (/\.gz$/.test(path)) {
87
+ const decompressedData = await processOnWorker(CompressionWorker, data, {
88
+ compression: 'gzip',
89
+ operation: 'decompress',
90
+ _workerType: 'test',
91
+ gzip: {}
92
+ });
93
+ return decompressedData;
94
+ }
95
+ return Buffer.from(data);
96
+ }
97
+ getFileBytes(path) {
98
+ const nameHash = Buffer.from(md5(path), 'hex');
99
+ const fileInfo = this.hashArray.find(val => Buffer.compare(val.hash, nameHash) === 0);
100
+ if (!fileInfo) {
101
+ return undefined;
102
+ }
103
+ const localFileHeader = parseZipLocalFileHeader(this.slpkArchive.byteOffset + (fileInfo === null || fileInfo === void 0 ? void 0 : fileInfo.offset), this.slpkArchive);
104
+ const compressedFile = this.slpkArchive.buffer.slice(localFileHeader.fileDataOffset, localFileHeader.fileDataOffset + localFileHeader.compressedSize);
105
+ return compressedFile;
106
+ }
107
+ }
108
+ //# sourceMappingURL=slpk-archieve.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"slpk-archieve.js","names":["processOnWorker","md5","CompressionWorker","parseZipLocalFileHeader","PATH_DESCRIPTIONS","test","extensions","SLPKArchive","constructor","slpkArchiveBuffer","hashFile","_defineProperty","slpkArchive","DataView","hashArray","parseHashFile","hashFileBuffer","Buffer","from","i","buffer","byteLength","offsetBuffer","slice","byteOffset","offset","getUint32","push","hash","subarray","getFile","path","mode","arguments","length","undefined","_PATH_DESCRIPTIONS$fi","find","val","data","ext","getDataByPath","concat","decompressedFile","fileWithoutCompression","getFileBytes","Error","decompressedData","compression","operation","_workerType","gzip","nameHash","fileInfo","compare","localFileHeader","compressedFile","fileDataOffset","compressedSize"],"sources":["../../../../../src/lib/parsers/parse-slpk/slpk-archieve.ts"],"sourcesContent":["import {processOnWorker} from '@loaders.gl/worker-utils';\nimport md5 from 'md5';\nimport {CompressionWorker} from '@loaders.gl/compression';\nimport {parseZipLocalFileHeader} from '../parse-zip/local-file-header';\n\n/** Element of hash array */\ntype HashElement = {\n /**\n * File name hash\n */\n hash: Buffer;\n /**\n * File offset in the archive\n */\n offset: number;\n};\n\nconst PATH_DESCRIPTIONS: {test: RegExp; extensions: string[]}[] = [\n {\n test: /^$/,\n extensions: ['3dSceneLayer.json.gz']\n },\n {\n test: /^nodepages\\/\\d+$/,\n extensions: ['.json.gz']\n },\n {\n test: /^nodes\\/\\d+$/,\n extensions: ['/3dNodeIndexDocument.json.gz']\n },\n {\n test: /^nodes\\/\\d+\\/textures\\/.+$/,\n extensions: ['.jpg', '.png', '.bin.dds.gz', '.ktx']\n },\n {\n test: /^nodes\\/\\d+\\/geometries\\/\\d+$/,\n extensions: ['.bin.gz', '.draco.gz']\n },\n {\n test: /^nodes\\/\\d+\\/attributes\\/f_\\d+\\/\\d+$/,\n extensions: ['.bin.gz']\n },\n {\n test: /^statistics\\/f_\\d+\\/\\d+$/,\n extensions: ['.json.gz']\n },\n {\n test: /^nodes\\/\\d+\\/shared$/,\n extensions: ['/sharedResource.json.gz']\n }\n];\n\n/**\n * Class for handling information about slpk file\n */\nexport class SLPKArchive {\n slpkArchive: DataView;\n hashArray: {hash: Buffer; offset: number}[];\n constructor(slpkArchiveBuffer: ArrayBuffer, hashFile: ArrayBuffer) {\n this.slpkArchive = new DataView(slpkArchiveBuffer);\n this.hashArray = this.parseHashFile(hashFile);\n }\n\n /**\n * Reads hash file from buffer and returns it in ready-to-use form\n * @param hashFile - bufer containing hash file\n * @returns Array containing file info\n */\n private parseHashFile(hashFile: ArrayBuffer): HashElement[] {\n const hashFileBuffer = Buffer.from(hashFile);\n const hashArray: HashElement[] = [];\n for (let i = 0; i < hashFileBuffer.buffer.byteLength; i = i + 24) {\n const offsetBuffer = new DataView(\n hashFileBuffer.buffer.slice(\n hashFileBuffer.byteOffset + i + 16,\n hashFileBuffer.byteOffset + i + 24\n )\n );\n const offset = offsetBuffer.getUint32(offsetBuffer.byteOffset, true);\n hashArray.push({\n hash: Buffer.from(\n hashFileBuffer.subarray(hashFileBuffer.byteOffset + i, hashFileBuffer.byteOffset + i + 16)\n ),\n offset\n });\n }\n return hashArray;\n }\n\n /**\n * Returns file with the given path from slpk archive\n * @param path - path inside the slpk\n * @param mode - currently only raw mode supported\n * @returns buffer with ready to use file\n */\n async getFile(path: string, mode: 'http' | 'raw' = 'raw'): Promise<Buffer> {\n if (mode === 'http') {\n const extensions = PATH_DESCRIPTIONS.find((val) => val.test.test(path))?.extensions;\n if (extensions) {\n let data: ArrayBuffer | undefined;\n for (const ext of extensions) {\n data = await this.getDataByPath(`${path}${ext}`);\n if (data) {\n break;\n }\n }\n if (data) {\n return Buffer.from(data);\n }\n }\n }\n if (mode === 'raw') {\n const decompressedFile = await this.getDataByPath(`${path}.gz`);\n if (decompressedFile) {\n return Buffer.from(decompressedFile);\n }\n const fileWithoutCompression = this.getFileBytes(path);\n if (fileWithoutCompression) {\n return Buffer.from(fileWithoutCompression);\n }\n }\n\n throw new Error('No such file in the archieve');\n }\n\n /**\n * returning uncompressed data for paths that ends with .gz and raw data for all other paths\n * @param path - path inside the archive\n * @returns buffer with the file data\n */\n private async getDataByPath(path: string): Promise<ArrayBuffer | undefined> {\n const data = this.getFileBytes(path);\n if (!data) {\n return undefined;\n }\n if (/\\.gz$/.test(path)) {\n const decompressedData = await processOnWorker(CompressionWorker, data, {\n compression: 'gzip',\n operation: 'decompress',\n _workerType: 'test',\n gzip: {}\n });\n return decompressedData;\n }\n return Buffer.from(data);\n }\n\n /**\n * Trying to get raw file data by adress\n * @param path - path inside the archive\n * @returns buffer with the raw file data\n */\n private getFileBytes(path: string): ArrayBuffer | undefined {\n const nameHash = Buffer.from(md5(path), 'hex');\n const fileInfo = this.hashArray.find((val) => Buffer.compare(val.hash, nameHash) === 0);\n if (!fileInfo) {\n return undefined;\n }\n\n const localFileHeader = parseZipLocalFileHeader(\n this.slpkArchive.byteOffset + fileInfo?.offset,\n this.slpkArchive\n );\n\n const compressedFile = this.slpkArchive.buffer.slice(\n localFileHeader.fileDataOffset,\n localFileHeader.fileDataOffset + localFileHeader.compressedSize\n );\n\n return compressedFile;\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,37 @@
1
+ export const parseZipCDFileHeader = (headerOffset, buffer) => {
2
+ const offsets = {
3
+ CD_COMPRESSED_SIZE_OFFSET: 20,
4
+ CD_UNCOMPRESSED_SIZE_OFFSET: 24,
5
+ CD_FILE_NAME_LENGTH_OFFSET: 28,
6
+ CD_EXTRA_FIELD_LENGTH_OFFSET: 30,
7
+ CD_LOCAL_HEADER_OFFSET_OFFSET: 42,
8
+ CD_FILE_NAME_OFFSET: 46
9
+ };
10
+ const compressedSize = buffer.getUint32(headerOffset + offsets.CD_COMPRESSED_SIZE_OFFSET, true);
11
+ const uncompressedSize = buffer.getUint32(headerOffset + offsets.CD_UNCOMPRESSED_SIZE_OFFSET, true);
12
+ const fileNameLength = buffer.getUint16(headerOffset + offsets.CD_FILE_NAME_LENGTH_OFFSET, true);
13
+ const fileName = buffer.buffer.slice(headerOffset + offsets.CD_FILE_NAME_OFFSET, headerOffset + offsets.CD_FILE_NAME_OFFSET + fileNameLength);
14
+ const extraOffset = headerOffset + offsets.CD_FILE_NAME_OFFSET + fileNameLength;
15
+ const oldFormatOffset = buffer.getUint32(headerOffset + offsets.CD_LOCAL_HEADER_OFFSET_OFFSET, true);
16
+ let fileDataOffset = oldFormatOffset;
17
+ if (fileDataOffset === 0xffffffff) {
18
+ let offsetInZip64Data = 4;
19
+ if (compressedSize === 0xffffffff) {
20
+ offsetInZip64Data += 8;
21
+ }
22
+ if (uncompressedSize === 0xffffffff) {
23
+ offsetInZip64Data += 8;
24
+ }
25
+ fileDataOffset = buffer.getUint32(extraOffset + offsetInZip64Data, true);
26
+ }
27
+ const localHeaderOffset = fileDataOffset;
28
+ return {
29
+ compressedSize,
30
+ uncompressedSize,
31
+ fileNameLength,
32
+ fileName,
33
+ extraOffset,
34
+ localHeaderOffset
35
+ };
36
+ };
37
+ //# sourceMappingURL=cd-file-header.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cd-file-header.js","names":["parseZipCDFileHeader","headerOffset","buffer","offsets","CD_COMPRESSED_SIZE_OFFSET","CD_UNCOMPRESSED_SIZE_OFFSET","CD_FILE_NAME_LENGTH_OFFSET","CD_EXTRA_FIELD_LENGTH_OFFSET","CD_LOCAL_HEADER_OFFSET_OFFSET","CD_FILE_NAME_OFFSET","compressedSize","getUint32","uncompressedSize","fileNameLength","getUint16","fileName","slice","extraOffset","oldFormatOffset","fileDataOffset","offsetInZip64Data","localHeaderOffset"],"sources":["../../../../../src/lib/parsers/parse-zip/cd-file-header.ts"],"sourcesContent":["/**\n * zip central directory file header info\n * according to https://en.wikipedia.org/wiki/ZIP_(file_format)\n */\nexport type ZipCDFileHeader = {\n /**\n * Compressed size\n */\n compressedSize: number;\n /**\n * Uncompressed size\n */\n uncompressedSize: number;\n /**\n * File name length\n */\n fileNameLength: number;\n /**\n * File name\n */\n fileName: ArrayBuffer;\n /**\n * Extra field offset\n */\n extraOffset: number;\n /**\n * Relative offset of local file header\n */\n localHeaderOffset: number;\n};\n\n/**\n * Parses central directory file header of zip file\n * @param headerOffset - offset in the archive where header starts\n * @param buffer - buffer containing whole array\n * @returns Info from the header\n */\nexport const parseZipCDFileHeader = (headerOffset: number, buffer: DataView): ZipCDFileHeader => {\n const offsets = {\n CD_COMPRESSED_SIZE_OFFSET: 20,\n CD_UNCOMPRESSED_SIZE_OFFSET: 24,\n CD_FILE_NAME_LENGTH_OFFSET: 28,\n CD_EXTRA_FIELD_LENGTH_OFFSET: 30,\n CD_LOCAL_HEADER_OFFSET_OFFSET: 42,\n CD_FILE_NAME_OFFSET: 46\n };\n\n const compressedSize = buffer.getUint32(headerOffset + offsets.CD_COMPRESSED_SIZE_OFFSET, true);\n\n const uncompressedSize = buffer.getUint32(\n headerOffset + offsets.CD_UNCOMPRESSED_SIZE_OFFSET,\n true\n );\n\n const fileNameLength = buffer.getUint16(headerOffset + offsets.CD_FILE_NAME_LENGTH_OFFSET, true);\n\n const fileName = buffer.buffer.slice(\n headerOffset + offsets.CD_FILE_NAME_OFFSET,\n headerOffset + offsets.CD_FILE_NAME_OFFSET + fileNameLength\n );\n\n const extraOffset = headerOffset + offsets.CD_FILE_NAME_OFFSET + fileNameLength;\n\n const oldFormatOffset = buffer.getUint32(\n headerOffset + offsets.CD_LOCAL_HEADER_OFFSET_OFFSET,\n true\n );\n\n let fileDataOffset = oldFormatOffset;\n if (fileDataOffset === 0xffffffff) {\n let offsetInZip64Data = 4;\n // looking for info that might be also be in zip64 extra field\n if (compressedSize === 0xffffffff) {\n offsetInZip64Data += 8;\n }\n if (uncompressedSize === 0xffffffff) {\n offsetInZip64Data += 8;\n }\n\n // getUint32 needs to be replaced with getBigUint64 for archieves bigger than 2gb\n fileDataOffset = buffer.getUint32(extraOffset + offsetInZip64Data, true); // setting it to the one from zip64\n }\n const localHeaderOffset = fileDataOffset;\n\n return {\n compressedSize,\n uncompressedSize,\n fileNameLength,\n fileName,\n extraOffset,\n localHeaderOffset\n };\n};\n"],"mappings":"AAqCA,OAAO,MAAMA,oBAAoB,GAAGA,CAACC,YAAoB,EAAEC,MAAgB,KAAsB;EAC/F,MAAMC,OAAO,GAAG;IACdC,yBAAyB,EAAE,EAAE;IAC7BC,2BAA2B,EAAE,EAAE;IAC/BC,0BAA0B,EAAE,EAAE;IAC9BC,4BAA4B,EAAE,EAAE;IAChCC,6BAA6B,EAAE,EAAE;IACjCC,mBAAmB,EAAE;EACvB,CAAC;EAED,MAAMC,cAAc,GAAGR,MAAM,CAACS,SAAS,CAACV,YAAY,GAAGE,OAAO,CAACC,yBAAyB,EAAE,IAAI,CAAC;EAE/F,MAAMQ,gBAAgB,GAAGV,MAAM,CAACS,SAAS,CACvCV,YAAY,GAAGE,OAAO,CAACE,2BAA2B,EAClD,IACF,CAAC;EAED,MAAMQ,cAAc,GAAGX,MAAM,CAACY,SAAS,CAACb,YAAY,GAAGE,OAAO,CAACG,0BAA0B,EAAE,IAAI,CAAC;EAEhG,MAAMS,QAAQ,GAAGb,MAAM,CAACA,MAAM,CAACc,KAAK,CAClCf,YAAY,GAAGE,OAAO,CAACM,mBAAmB,EAC1CR,YAAY,GAAGE,OAAO,CAACM,mBAAmB,GAAGI,cAC/C,CAAC;EAED,MAAMI,WAAW,GAAGhB,YAAY,GAAGE,OAAO,CAACM,mBAAmB,GAAGI,cAAc;EAE/E,MAAMK,eAAe,GAAGhB,MAAM,CAACS,SAAS,CACtCV,YAAY,GAAGE,OAAO,CAACK,6BAA6B,EACpD,IACF,CAAC;EAED,IAAIW,cAAc,GAAGD,eAAe;EACpC,IAAIC,cAAc,KAAK,UAAU,EAAE;IACjC,IAAIC,iBAAiB,GAAG,CAAC;IAEzB,IAAIV,cAAc,KAAK,UAAU,EAAE;MACjCU,iBAAiB,IAAI,CAAC;IACxB;IACA,IAAIR,gBAAgB,KAAK,UAAU,EAAE;MACnCQ,iBAAiB,IAAI,CAAC;IACxB;IAGAD,cAAc,GAAGjB,MAAM,CAACS,SAAS,CAACM,WAAW,GAAGG,iBAAiB,EAAE,IAAI,CAAC;EAC1E;EACA,MAAMC,iBAAiB,GAAGF,cAAc;EAExC,OAAO;IACLT,cAAc;IACdE,gBAAgB;IAChBC,cAAc;IACdE,QAAQ;IACRE,WAAW;IACXI;EACF,CAAC;AACH,CAAC"}
@@ -0,0 +1,19 @@
1
+ export const parseZipLocalFileHeader = (headerOffset, buffer) => {
2
+ const offsets = {
3
+ COMPRESSED_SIZE_OFFSET: 18,
4
+ FILE_NAME_LENGTH_OFFSET: 26,
5
+ EXTRA_FIELD_LENGTH_OFFSET: 28,
6
+ FILE_NAME_OFFSET: 30
7
+ };
8
+ const fileNameLength = buffer.getUint16(headerOffset + offsets.FILE_NAME_LENGTH_OFFSET, true);
9
+ const extraFieldLength = buffer.getUint16(headerOffset + offsets.EXTRA_FIELD_LENGTH_OFFSET, true);
10
+ const fileDataOffset = headerOffset + offsets.FILE_NAME_OFFSET + fileNameLength + extraFieldLength;
11
+ const compressedSize = buffer.getUint32(headerOffset + offsets.COMPRESSED_SIZE_OFFSET, true);
12
+ return {
13
+ fileNameLength,
14
+ extraFieldLength,
15
+ fileDataOffset,
16
+ compressedSize
17
+ };
18
+ };
19
+ //# sourceMappingURL=local-file-header.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"local-file-header.js","names":["parseZipLocalFileHeader","headerOffset","buffer","offsets","COMPRESSED_SIZE_OFFSET","FILE_NAME_LENGTH_OFFSET","EXTRA_FIELD_LENGTH_OFFSET","FILE_NAME_OFFSET","fileNameLength","getUint16","extraFieldLength","fileDataOffset","compressedSize","getUint32"],"sources":["../../../../../src/lib/parsers/parse-zip/local-file-header.ts"],"sourcesContent":["/**\n * zip local file header info\n * according to https://en.wikipedia.org/wiki/ZIP_(file_format)\n */\nexport type ZipLocalFileHeader = {\n /**\n * File name length\n */\n fileNameLength: number;\n /**\n * Extra field length\n */\n extraFieldLength: number;\n /**\n * Offset of the file data\n */\n fileDataOffset: number;\n /**\n * Compressed size\n */\n compressedSize: number;\n};\n\n/**\n * Parses local file header of zip file\n * @param headerOffset - offset in the archive where header starts\n * @param buffer - buffer containing whole array\n * @returns Info from the header\n */\nexport const parseZipLocalFileHeader = (\n headerOffset: number,\n buffer: DataView\n): ZipLocalFileHeader => {\n const offsets = {\n COMPRESSED_SIZE_OFFSET: 18,\n FILE_NAME_LENGTH_OFFSET: 26,\n EXTRA_FIELD_LENGTH_OFFSET: 28,\n FILE_NAME_OFFSET: 30\n };\n\n const fileNameLength = buffer.getUint16(headerOffset + offsets.FILE_NAME_LENGTH_OFFSET, true);\n\n const extraFieldLength = buffer.getUint16(headerOffset + offsets.EXTRA_FIELD_LENGTH_OFFSET, true);\n\n const fileDataOffset =\n headerOffset + offsets.FILE_NAME_OFFSET + fileNameLength + extraFieldLength;\n\n const compressedSize = buffer.getUint32(headerOffset + offsets.COMPRESSED_SIZE_OFFSET, true);\n\n return {\n fileNameLength,\n extraFieldLength,\n fileDataOffset,\n compressedSize\n };\n};\n"],"mappings":"AA6BA,OAAO,MAAMA,uBAAuB,GAAGA,CACrCC,YAAoB,EACpBC,MAAgB,KACO;EACvB,MAAMC,OAAO,GAAG;IACdC,sBAAsB,EAAE,EAAE;IAC1BC,uBAAuB,EAAE,EAAE;IAC3BC,yBAAyB,EAAE,EAAE;IAC7BC,gBAAgB,EAAE;EACpB,CAAC;EAED,MAAMC,cAAc,GAAGN,MAAM,CAACO,SAAS,CAACR,YAAY,GAAGE,OAAO,CAACE,uBAAuB,EAAE,IAAI,CAAC;EAE7F,MAAMK,gBAAgB,GAAGR,MAAM,CAACO,SAAS,CAACR,YAAY,GAAGE,OAAO,CAACG,yBAAyB,EAAE,IAAI,CAAC;EAEjG,MAAMK,cAAc,GAClBV,YAAY,GAAGE,OAAO,CAACI,gBAAgB,GAAGC,cAAc,GAAGE,gBAAgB;EAE7E,MAAME,cAAc,GAAGV,MAAM,CAACW,SAAS,CAACZ,YAAY,GAAGE,OAAO,CAACC,sBAAsB,EAAE,IAAI,CAAC;EAE5F,OAAO;IACLI,cAAc;IACdE,gBAAgB;IAChBC,cAAc;IACdC;EACF,CAAC;AACH,CAAC"}
@@ -0,0 +1,9 @@
1
+ import { BoundingSphere } from '@math.gl/culling';
2
+ import { Ellipsoid } from '@math.gl/geospatial';
3
+ export function convertI3SObbToMbs(obb) {
4
+ const halfSize = obb.halfSize;
5
+ const centerCartesian = Ellipsoid.WGS84.cartographicToCartesian(obb.center);
6
+ const sphere = new BoundingSphere().fromCornerPoints([centerCartesian[0] - halfSize[0], centerCartesian[1] - halfSize[1], centerCartesian[2] - halfSize[2]], [centerCartesian[0] + halfSize[0], centerCartesian[1] + halfSize[1], centerCartesian[2] + halfSize[2]]);
7
+ return [...obb.center, sphere.radius];
8
+ }
9
+ //# sourceMappingURL=convert-i3s-obb-to-mbs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"convert-i3s-obb-to-mbs.js","names":["BoundingSphere","Ellipsoid","convertI3SObbToMbs","obb","halfSize","centerCartesian","WGS84","cartographicToCartesian","center","sphere","fromCornerPoints","radius"],"sources":["../../../../src/lib/utils/convert-i3s-obb-to-mbs.ts"],"sourcesContent":["import {BoundingSphere} from '@math.gl/culling';\nimport {Ellipsoid} from '@math.gl/geospatial';\n\nexport function convertI3SObbToMbs(obb) {\n const halfSize = obb.halfSize;\n const centerCartesian = Ellipsoid.WGS84.cartographicToCartesian(obb.center);\n const sphere = new BoundingSphere().fromCornerPoints(\n [\n centerCartesian[0] - halfSize[0],\n centerCartesian[1] - halfSize[1],\n centerCartesian[2] - halfSize[2]\n ],\n [\n centerCartesian[0] + halfSize[0],\n centerCartesian[1] + halfSize[1],\n centerCartesian[2] + halfSize[2]\n ]\n );\n return [...obb.center, sphere.radius];\n}\n"],"mappings":"AAAA,SAAQA,cAAc,QAAO,kBAAkB;AAC/C,SAAQC,SAAS,QAAO,qBAAqB;AAE7C,OAAO,SAASC,kBAAkBA,CAACC,GAAG,EAAE;EACtC,MAAMC,QAAQ,GAAGD,GAAG,CAACC,QAAQ;EAC7B,MAAMC,eAAe,GAAGJ,SAAS,CAACK,KAAK,CAACC,uBAAuB,CAACJ,GAAG,CAACK,MAAM,CAAC;EAC3E,MAAMC,MAAM,GAAG,IAAIT,cAAc,CAAC,CAAC,CAACU,gBAAgB,CAClD,CACEL,eAAe,CAAC,CAAC,CAAC,GAAGD,QAAQ,CAAC,CAAC,CAAC,EAChCC,eAAe,CAAC,CAAC,CAAC,GAAGD,QAAQ,CAAC,CAAC,CAAC,EAChCC,eAAe,CAAC,CAAC,CAAC,GAAGD,QAAQ,CAAC,CAAC,CAAC,CACjC,EACD,CACEC,eAAe,CAAC,CAAC,CAAC,GAAGD,QAAQ,CAAC,CAAC,CAAC,EAChCC,eAAe,CAAC,CAAC,CAAC,GAAGD,QAAQ,CAAC,CAAC,CAAC,EAChCC,eAAe,CAAC,CAAC,CAAC,GAAGD,QAAQ,CAAC,CAAC,CAAC,CAEpC,CAAC;EACD,OAAO,CAAC,GAAGD,GAAG,CAACK,MAAM,EAAEC,MAAM,CAACE,MAAM,CAAC;AACvC"}
@@ -0,0 +1,98 @@
1
+ import { load } from '@loaders.gl/core';
2
+ import { getAttributeValueType, I3SAttributeLoader } from '../../i3s-attribute-loader';
3
+ import { getUrlWithToken } from './url-utils';
4
+ export async function customizeColors(colors, featureIds, tileOptions, tilesetOptions, options) {
5
+ var _options$i3s;
6
+ if (!(options !== null && options !== void 0 && (_options$i3s = options.i3s) !== null && _options$i3s !== void 0 && _options$i3s.colorsByAttribute)) {
7
+ return colors;
8
+ }
9
+ const colorizeAttributeField = tilesetOptions.fields.find(_ref => {
10
+ var _options$i3s2, _options$i3s2$colorsB;
11
+ let {
12
+ name
13
+ } = _ref;
14
+ return name === (options === null || options === void 0 ? void 0 : (_options$i3s2 = options.i3s) === null || _options$i3s2 === void 0 ? void 0 : (_options$i3s2$colorsB = _options$i3s2.colorsByAttribute) === null || _options$i3s2$colorsB === void 0 ? void 0 : _options$i3s2$colorsB.attributeName);
15
+ });
16
+ if (!colorizeAttributeField || !['esriFieldTypeDouble', 'esriFieldTypeInteger', 'esriFieldTypeSmallInteger'].includes(colorizeAttributeField.type)) {
17
+ return colors;
18
+ }
19
+ const colorizeAttributeData = await loadFeatureAttributeData(colorizeAttributeField.name, tileOptions, tilesetOptions, options);
20
+ if (!colorizeAttributeData) {
21
+ return colors;
22
+ }
23
+ const objectIdField = tilesetOptions.fields.find(_ref2 => {
24
+ let {
25
+ type
26
+ } = _ref2;
27
+ return type === 'esriFieldTypeOID';
28
+ });
29
+ if (!objectIdField) {
30
+ return colors;
31
+ }
32
+ const objectIdAttributeData = await loadFeatureAttributeData(objectIdField.name, tileOptions, tilesetOptions, options);
33
+ if (!objectIdAttributeData) {
34
+ return colors;
35
+ }
36
+ const attributeValuesMap = {};
37
+ for (let i = 0; i < objectIdAttributeData[objectIdField.name].length; i++) {
38
+ attributeValuesMap[objectIdAttributeData[objectIdField.name][i]] = calculateColorForAttribute(colorizeAttributeData[colorizeAttributeField.name][i], options);
39
+ }
40
+ for (let i = 0; i < featureIds.value.length; i++) {
41
+ const color = attributeValuesMap[featureIds.value[i]];
42
+ if (!color) {
43
+ continue;
44
+ }
45
+ if (options.i3s.colorsByAttribute.mode === 'multiply') {
46
+ color.forEach((colorItem, index) => {
47
+ colors.value[i * 4 + index] = colors.value[i * 4 + index] * colorItem / 255;
48
+ });
49
+ } else {
50
+ colors.value.set(color, i * 4);
51
+ }
52
+ }
53
+ return colors;
54
+ }
55
+ function calculateColorForAttribute(attributeValue, options) {
56
+ var _options$i3s3;
57
+ if (!(options !== null && options !== void 0 && (_options$i3s3 = options.i3s) !== null && _options$i3s3 !== void 0 && _options$i3s3.colorsByAttribute)) {
58
+ return [255, 255, 255, 255];
59
+ }
60
+ const {
61
+ minValue,
62
+ maxValue,
63
+ minColor,
64
+ maxColor
65
+ } = options.i3s.colorsByAttribute;
66
+ const rate = (attributeValue - minValue) / (maxValue - minValue);
67
+ const color = [255, 255, 255, 255];
68
+ for (let i = 0; i < minColor.length; i++) {
69
+ color[i] = Math.round((maxColor[i] - minColor[i]) * rate + minColor[i]);
70
+ }
71
+ return color;
72
+ }
73
+ async function loadFeatureAttributeData(attributeName, _ref3, _ref4, options) {
74
+ var _options$i3s4;
75
+ let {
76
+ attributeUrls
77
+ } = _ref3;
78
+ let {
79
+ attributeStorageInfo
80
+ } = _ref4;
81
+ const attributeIndex = attributeStorageInfo.findIndex(_ref5 => {
82
+ let {
83
+ name
84
+ } = _ref5;
85
+ return attributeName === name;
86
+ });
87
+ if (attributeIndex === -1) {
88
+ return null;
89
+ }
90
+ const objectIdAttributeUrl = getUrlWithToken(attributeUrls[attributeIndex], options === null || options === void 0 ? void 0 : (_options$i3s4 = options.i3s) === null || _options$i3s4 === void 0 ? void 0 : _options$i3s4.token);
91
+ const attributeType = getAttributeValueType(attributeStorageInfo[attributeIndex]);
92
+ const objectIdAttributeData = await load(objectIdAttributeUrl, I3SAttributeLoader, {
93
+ attributeName,
94
+ attributeType
95
+ });
96
+ return objectIdAttributeData;
97
+ }
98
+ //# sourceMappingURL=customize-сolors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"customize-сolors.js","names":["load","getAttributeValueType","I3SAttributeLoader","getUrlWithToken","customizeColors","colors","featureIds","tileOptions","tilesetOptions","options","_options$i3s","i3s","colorsByAttribute","colorizeAttributeField","fields","find","_ref","_options$i3s2","_options$i3s2$colorsB","name","attributeName","includes","type","colorizeAttributeData","loadFeatureAttributeData","objectIdField","_ref2","objectIdAttributeData","attributeValuesMap","i","length","calculateColorForAttribute","value","color","mode","forEach","colorItem","index","set","attributeValue","_options$i3s3","minValue","maxValue","minColor","maxColor","rate","Math","round","_ref3","_ref4","_options$i3s4","attributeUrls","attributeStorageInfo","attributeIndex","findIndex","_ref5","objectIdAttributeUrl","token","attributeType"],"sources":["../../../../src/lib/utils/customize-сolors.ts"],"sourcesContent":["import type {MeshAttribute} from '@loaders.gl/schema';\nimport type {COLOR, I3STileOptions, I3STilesetOptions} from '../../types';\n\nimport {load} from '@loaders.gl/core';\nimport {getAttributeValueType, I3SAttributeLoader} from '../../i3s-attribute-loader';\nimport {I3SLoaderOptions} from '../../i3s-loader';\nimport {getUrlWithToken} from './url-utils';\n\n/**\n * Modify vertex colors array to visualize 3D objects in a attribute driven way\n * @param colors - vertex colors attribute\n * @param featureIds - feature Ids attribute\n * @param tileOptions - tile - related options\n * @param tilesetOptions - tileset-related options\n * @param options - loader options\n * @returns midified colors attribute\n */\nexport async function customizeColors(\n colors: MeshAttribute,\n featureIds: MeshAttribute,\n tileOptions: I3STileOptions,\n tilesetOptions: I3STilesetOptions,\n options?: I3SLoaderOptions\n): Promise<MeshAttribute> {\n if (!options?.i3s?.colorsByAttribute) {\n return colors;\n }\n\n const colorizeAttributeField = tilesetOptions.fields.find(\n ({name}) => name === options?.i3s?.colorsByAttribute?.attributeName\n );\n if (\n !colorizeAttributeField ||\n !['esriFieldTypeDouble', 'esriFieldTypeInteger', 'esriFieldTypeSmallInteger'].includes(\n colorizeAttributeField.type\n )\n ) {\n return colors;\n }\n\n const colorizeAttributeData = await loadFeatureAttributeData(\n colorizeAttributeField.name,\n tileOptions,\n tilesetOptions,\n options\n );\n if (!colorizeAttributeData) {\n return colors;\n }\n\n const objectIdField = tilesetOptions.fields.find(({type}) => type === 'esriFieldTypeOID');\n if (!objectIdField) {\n return colors;\n }\n\n const objectIdAttributeData = await loadFeatureAttributeData(\n objectIdField.name,\n tileOptions,\n tilesetOptions,\n options\n );\n if (!objectIdAttributeData) {\n return colors;\n }\n\n const attributeValuesMap: {[key: number]: COLOR} = {};\n // @ts-expect-error\n for (let i = 0; i < objectIdAttributeData[objectIdField.name].length; i++) {\n // @ts-expect-error\n attributeValuesMap[objectIdAttributeData[objectIdField.name][i]] = calculateColorForAttribute(\n // @ts-expect-error\n colorizeAttributeData[colorizeAttributeField.name][i] as number,\n options\n );\n }\n\n for (let i = 0; i < featureIds.value.length; i++) {\n const color = attributeValuesMap[featureIds.value[i]];\n if (!color) {\n continue; // eslint-disable-line no-continue\n }\n\n /* eslint max-statements: [\"error\", 30] */\n /* eslint complexity: [\"error\", 12] */\n if (options.i3s.colorsByAttribute.mode === 'multiply') {\n // multiplying original mesh and calculated for attribute rgba colors in range 0-255\n color.forEach((colorItem, index) => {\n colors.value[i * 4 + index] = (colors.value[i * 4 + index] * colorItem) / 255;\n });\n } else {\n colors.value.set(color, i * 4);\n }\n }\n\n return colors;\n}\n\n/**\n * Calculate rgba color from the attribute value\n * @param attributeValue - value of the attribute\n * @param options - loader options\n * @returns - color array for a specific attribute value\n */\nfunction calculateColorForAttribute(attributeValue: number, options?: I3SLoaderOptions): COLOR {\n if (!options?.i3s?.colorsByAttribute) {\n return [255, 255, 255, 255];\n }\n const {minValue, maxValue, minColor, maxColor} = options.i3s.colorsByAttribute;\n const rate = (attributeValue - minValue) / (maxValue - minValue);\n const color: COLOR = [255, 255, 255, 255];\n for (let i = 0; i < minColor.length; i++) {\n color[i] = Math.round((maxColor[i] - minColor[i]) * rate + minColor[i]);\n }\n return color;\n}\n\n/**\n * Load feature attribute data from the ArcGIS rest service\n * @param attributeName - attribute name\n * @param tileOptions - tile-related options\n * @param tilesetOptions - tileset-related options\n * @param options - loader options\n * @returns - Array-like list of the attribute values\n */\nasync function loadFeatureAttributeData(\n attributeName: string,\n {attributeUrls}: I3STileOptions,\n {attributeStorageInfo}: I3STilesetOptions,\n options?: I3SLoaderOptions\n): Promise<{[key: string]: string[] | Uint32Array | Uint16Array | Float64Array | null} | null> {\n const attributeIndex = attributeStorageInfo.findIndex(({name}) => attributeName === name);\n if (attributeIndex === -1) {\n return null;\n }\n const objectIdAttributeUrl = getUrlWithToken(attributeUrls[attributeIndex], options?.i3s?.token);\n const attributeType = getAttributeValueType(attributeStorageInfo[attributeIndex]);\n const objectIdAttributeData = await load(objectIdAttributeUrl, I3SAttributeLoader, {\n attributeName,\n attributeType\n });\n\n // @ts-expect-error TODO action engine\n return objectIdAttributeData;\n}\n"],"mappings":"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"}
@@ -0,0 +1,28 @@
1
+ export function getUrlWithToken(url) {
2
+ let token = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;
3
+ return token ? "".concat(url, "?token=").concat(token) : url;
4
+ }
5
+ export function generateTileAttributeUrls(url, tile) {
6
+ const {
7
+ attributeData = []
8
+ } = tile;
9
+ const attributeUrls = [];
10
+ for (let index = 0; index < attributeData.length; index++) {
11
+ const attributeUrl = attributeData[index].href.replace('./', '');
12
+ attributeUrls.push("".concat(url, "/").concat(attributeUrl));
13
+ }
14
+ return attributeUrls;
15
+ }
16
+ export function generateTilesetAttributeUrls(tileset, resource) {
17
+ const attributeUrls = [];
18
+ const {
19
+ attributeStorageInfo,
20
+ url
21
+ } = tileset;
22
+ for (let index = 0; index < attributeStorageInfo.length; index++) {
23
+ const fileName = attributeStorageInfo[index].key;
24
+ attributeUrls.push("".concat(url, "/nodes/").concat(resource, "/attributes/").concat(fileName, "/0"));
25
+ }
26
+ return attributeUrls;
27
+ }
28
+ //# sourceMappingURL=url-utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"url-utils.js","names":["getUrlWithToken","url","token","arguments","length","undefined","concat","generateTileAttributeUrls","tile","attributeData","attributeUrls","index","attributeUrl","href","replace","push","generateTilesetAttributeUrls","tileset","resource","attributeStorageInfo","fileName","key"],"sources":["../../../../src/lib/utils/url-utils.ts"],"sourcesContent":["import {Node3DIndexDocument} from '../../types';\n\n/**\n * Generates url with token if it is exists.\n * @param url\n * @param token\n * @returns\n */\nexport function getUrlWithToken(url: string, token: string | null = null): string {\n return token ? `${url}?token=${token}` : url;\n}\n\n/**\n * Generates attribute urls for tile.\n * @param tile\n * @returns list of attribute urls\n */\nexport function generateTileAttributeUrls(url: string, tile: Node3DIndexDocument): string[] {\n const {attributeData = []} = tile;\n const attributeUrls: string[] = [];\n\n for (let index = 0; index < attributeData.length; index++) {\n const attributeUrl = attributeData[index].href.replace('./', '');\n attributeUrls.push(`${url}/${attributeUrl}`);\n }\n\n return attributeUrls;\n}\n\n/**\n * Generates attribute urls for tileset based on tileset and resource\n * @param {Object} tileset\n * @param {number} resource\n * @returns {Array}\n */\nexport function generateTilesetAttributeUrls(tileset, resource) {\n const attributeUrls: string[] = [];\n const {attributeStorageInfo, url} = tileset;\n\n for (let index = 0; index < attributeStorageInfo.length; index++) {\n const fileName = attributeStorageInfo[index].key;\n attributeUrls.push(`${url}/nodes/${resource}/attributes/${fileName}/0`);\n }\n\n return attributeUrls;\n}\n"],"mappings":"AAQA,OAAO,SAASA,eAAeA,CAACC,GAAW,EAAuC;EAAA,IAArCC,KAAoB,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,IAAI;EACtE,OAAOD,KAAK,MAAAI,MAAA,CAAML,GAAG,aAAAK,MAAA,CAAUJ,KAAK,IAAKD,GAAG;AAC9C;AAOA,OAAO,SAASM,yBAAyBA,CAACN,GAAW,EAAEO,IAAyB,EAAY;EAC1F,MAAM;IAACC,aAAa,GAAG;EAAE,CAAC,GAAGD,IAAI;EACjC,MAAME,aAAuB,GAAG,EAAE;EAElC,KAAK,IAAIC,KAAK,GAAG,CAAC,EAAEA,KAAK,GAAGF,aAAa,CAACL,MAAM,EAAEO,KAAK,EAAE,EAAE;IACzD,MAAMC,YAAY,GAAGH,aAAa,CAACE,KAAK,CAAC,CAACE,IAAI,CAACC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC;IAChEJ,aAAa,CAACK,IAAI,IAAAT,MAAA,CAAIL,GAAG,OAAAK,MAAA,CAAIM,YAAY,CAAE,CAAC;EAC9C;EAEA,OAAOF,aAAa;AACtB;AAQA,OAAO,SAASM,4BAA4BA,CAACC,OAAO,EAAEC,QAAQ,EAAE;EAC9D,MAAMR,aAAuB,GAAG,EAAE;EAClC,MAAM;IAACS,oBAAoB;IAAElB;EAAG,CAAC,GAAGgB,OAAO;EAE3C,KAAK,IAAIN,KAAK,GAAG,CAAC,EAAEA,KAAK,GAAGQ,oBAAoB,CAACf,MAAM,EAAEO,KAAK,EAAE,EAAE;IAChE,MAAMS,QAAQ,GAAGD,oBAAoB,CAACR,KAAK,CAAC,CAACU,GAAG;IAChDX,aAAa,CAACK,IAAI,IAAAT,MAAA,CAAIL,GAAG,aAAAK,MAAA,CAAUY,QAAQ,kBAAAZ,MAAA,CAAec,QAAQ,OAAI,CAAC;EACzE;EAEA,OAAOV,aAAa;AACtB"}
@@ -0,0 +1,18 @@
1
+ export let DATA_TYPE = function (DATA_TYPE) {
2
+ DATA_TYPE["UInt8"] = "UInt8";
3
+ DATA_TYPE["UInt16"] = "UInt16";
4
+ DATA_TYPE["UInt32"] = "UInt32";
5
+ DATA_TYPE["UInt64"] = "UInt64";
6
+ DATA_TYPE["Int16"] = "Int16";
7
+ DATA_TYPE["Int32"] = "Int32";
8
+ DATA_TYPE["Int64"] = "Int64";
9
+ DATA_TYPE["Float32"] = "Float32";
10
+ DATA_TYPE["Float64"] = "Float64";
11
+ return DATA_TYPE;
12
+ }({});
13
+ export let HeaderAttributeProperty = function (HeaderAttributeProperty) {
14
+ HeaderAttributeProperty["vertexCount"] = "vertexCount";
15
+ HeaderAttributeProperty["featureCount"] = "featureCount";
16
+ return HeaderAttributeProperty;
17
+ }({});
18
+ //# sourceMappingURL=types.js.map