@loaders.gl/i3s 4.0.0-alpha.5 → 4.0.0-alpha.7

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 (209) 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.js +2 -2
  5. package/dist/dist.min.js +9390 -8570
  6. package/dist/es5/arcgis-webscene-loader.js +40 -0
  7. package/dist/es5/arcgis-webscene-loader.js.map +1 -0
  8. package/dist/es5/bundle.js +6 -0
  9. package/dist/es5/bundle.js.map +1 -0
  10. package/dist/es5/i3s-attribute-loader.js +195 -0
  11. package/dist/es5/i3s-attribute-loader.js.map +1 -0
  12. package/dist/es5/i3s-building-scene-layer-loader.js +46 -0
  13. package/dist/es5/i3s-building-scene-layer-loader.js.map +1 -0
  14. package/dist/es5/i3s-content-loader.js +56 -0
  15. package/dist/es5/i3s-content-loader.js.map +1 -0
  16. package/dist/es5/i3s-loader.js +193 -0
  17. package/dist/es5/i3s-loader.js.map +1 -0
  18. package/dist/es5/i3s-node-page-loader.js +39 -0
  19. package/dist/es5/i3s-node-page-loader.js.map +1 -0
  20. package/dist/es5/i3s-slpk-loader.js +20 -0
  21. package/dist/es5/i3s-slpk-loader.js.map +1 -0
  22. package/dist/es5/index.js +68 -0
  23. package/dist/es5/index.js.map +1 -0
  24. package/dist/es5/lib/helpers/i3s-nodepages-tiles.js +312 -0
  25. package/dist/es5/lib/helpers/i3s-nodepages-tiles.js.map +1 -0
  26. package/dist/es5/lib/parsers/constants.js +72 -0
  27. package/dist/es5/lib/parsers/constants.js.map +1 -0
  28. package/dist/es5/lib/parsers/parse-arcgis-webscene.js +158 -0
  29. package/dist/es5/lib/parsers/parse-arcgis-webscene.js.map +1 -0
  30. package/dist/es5/lib/parsers/parse-i3s-attribute.js +76 -0
  31. package/dist/es5/lib/parsers/parse-i3s-attribute.js.map +1 -0
  32. package/dist/es5/lib/parsers/parse-i3s-building-scene-layer.js +65 -0
  33. package/dist/es5/lib/parsers/parse-i3s-building-scene-layer.js.map +1 -0
  34. package/dist/es5/lib/parsers/parse-i3s-tile-content.js +510 -0
  35. package/dist/es5/lib/parsers/parse-i3s-tile-content.js.map +1 -0
  36. package/dist/es5/lib/parsers/parse-i3s.js +116 -0
  37. package/dist/es5/lib/parsers/parse-i3s.js.map +1 -0
  38. package/dist/es5/lib/parsers/parse-slpk/parse-slpk.js +94 -0
  39. package/dist/es5/lib/parsers/parse-slpk/parse-slpk.js.map +1 -0
  40. package/dist/es5/lib/parsers/parse-slpk/slpk-archieve.js +112 -0
  41. package/dist/es5/lib/parsers/parse-slpk/slpk-archieve.js.map +1 -0
  42. package/dist/es5/lib/parsers/parse-zip/cd-file-header.js +44 -0
  43. package/dist/es5/lib/parsers/parse-zip/cd-file-header.js.map +1 -0
  44. package/dist/es5/lib/parsers/parse-zip/local-file-header.js +26 -0
  45. package/dist/es5/lib/parsers/parse-zip/local-file-header.js.map +1 -0
  46. package/dist/es5/lib/utils/convert-i3s-obb-to-mbs.js +17 -0
  47. package/dist/es5/lib/utils/convert-i3s-obb-to-mbs.js.map +1 -0
  48. package/dist/es5/lib/utils/customizeColors.js +159 -0
  49. package/dist/es5/lib/utils/customizeColors.js.map +1 -0
  50. package/dist/es5/lib/utils/url-utils.js +33 -0
  51. package/dist/es5/lib/utils/url-utils.js.map +1 -0
  52. package/dist/es5/types.js +26 -0
  53. package/dist/es5/types.js.map +1 -0
  54. package/dist/es5/workers/i3s-content-worker-node.js +7 -0
  55. package/dist/es5/workers/i3s-content-worker-node.js.map +1 -0
  56. package/dist/es5/workers/i3s-content-worker.js +6 -0
  57. package/dist/es5/workers/i3s-content-worker.js.map +1 -0
  58. package/dist/esm/arcgis-webscene-loader.js +16 -0
  59. package/dist/esm/arcgis-webscene-loader.js.map +1 -0
  60. package/dist/esm/bundle.js +4 -0
  61. package/dist/esm/bundle.js.map +1 -0
  62. package/dist/esm/i3s-attribute-loader.js +119 -0
  63. package/dist/esm/i3s-attribute-loader.js.map +1 -0
  64. package/dist/esm/i3s-building-scene-layer-loader.js +19 -0
  65. package/dist/esm/i3s-building-scene-layer-loader.js.map +1 -0
  66. package/dist/esm/i3s-content-loader.js +30 -0
  67. package/dist/esm/i3s-content-loader.js.map +1 -0
  68. package/dist/esm/i3s-loader.js +87 -0
  69. package/dist/esm/i3s-loader.js.map +1 -0
  70. package/dist/esm/i3s-node-page-loader.js +15 -0
  71. package/dist/esm/i3s-node-page-loader.js.map +1 -0
  72. package/dist/esm/i3s-slpk-loader.js +13 -0
  73. package/dist/esm/i3s-slpk-loader.js.map +1 -0
  74. package/dist/esm/index.js +9 -0
  75. package/dist/esm/index.js.map +1 -0
  76. package/dist/esm/lib/helpers/i3s-nodepages-tiles.js +198 -0
  77. package/dist/esm/lib/helpers/i3s-nodepages-tiles.js.map +1 -0
  78. package/dist/esm/lib/parsers/constants.js +57 -0
  79. package/dist/esm/lib/parsers/constants.js.map +1 -0
  80. package/dist/esm/lib/parsers/parse-arcgis-webscene.js +70 -0
  81. package/dist/esm/lib/parsers/parse-arcgis-webscene.js.map +1 -0
  82. package/dist/esm/lib/parsers/parse-i3s-attribute.js +60 -0
  83. package/dist/esm/lib/parsers/parse-i3s-attribute.js.map +1 -0
  84. package/dist/esm/lib/parsers/parse-i3s-building-scene-layer.js +39 -0
  85. package/dist/esm/lib/parsers/parse-i3s-building-scene-layer.js.map +1 -0
  86. package/dist/esm/lib/parsers/parse-i3s-tile-content.js +435 -0
  87. package/dist/esm/lib/parsers/parse-i3s-tile-content.js.map +1 -0
  88. package/dist/esm/lib/parsers/parse-i3s.js +83 -0
  89. package/dist/esm/lib/parsers/parse-i3s.js.map +1 -0
  90. package/dist/esm/lib/parsers/parse-slpk/parse-slpk.js +37 -0
  91. package/dist/esm/lib/parsers/parse-slpk/parse-slpk.js.map +1 -0
  92. package/dist/esm/lib/parsers/parse-slpk/slpk-archieve.js +58 -0
  93. package/dist/esm/lib/parsers/parse-slpk/slpk-archieve.js.map +1 -0
  94. package/dist/esm/lib/parsers/parse-zip/cd-file-header.js +37 -0
  95. package/dist/esm/lib/parsers/parse-zip/cd-file-header.js.map +1 -0
  96. package/dist/esm/lib/parsers/parse-zip/local-file-header.js +19 -0
  97. package/dist/esm/lib/parsers/parse-zip/local-file-header.js.map +1 -0
  98. package/dist/esm/lib/utils/convert-i3s-obb-to-mbs.js +9 -0
  99. package/dist/esm/lib/utils/convert-i3s-obb-to-mbs.js.map +1 -0
  100. package/dist/esm/lib/utils/customizeColors.js +92 -0
  101. package/dist/esm/lib/utils/customizeColors.js.map +1 -0
  102. package/dist/esm/lib/utils/url-utils.js +28 -0
  103. package/dist/esm/lib/utils/url-utils.js.map +1 -0
  104. package/dist/esm/types.js +18 -0
  105. package/dist/esm/types.js.map +1 -0
  106. package/dist/esm/workers/i3s-content-worker-node.js +5 -0
  107. package/dist/esm/workers/i3s-content-worker-node.js.map +1 -0
  108. package/dist/esm/workers/i3s-content-worker.js +4 -0
  109. package/dist/esm/workers/i3s-content-worker.js.map +1 -0
  110. package/dist/i3s-attribute-loader.d.ts +9 -2
  111. package/dist/i3s-attribute-loader.d.ts.map +1 -1
  112. package/dist/i3s-attribute-loader.js +155 -132
  113. package/dist/i3s-building-scene-layer-loader.js +23 -18
  114. package/dist/i3s-content-loader.d.ts.map +1 -1
  115. package/dist/i3s-content-loader.js +29 -22
  116. package/dist/i3s-content-worker-node.js +197 -0
  117. package/dist/i3s-content-worker-node.js.map +7 -0
  118. package/dist/i3s-content-worker.js +1178 -1137
  119. package/dist/i3s-loader.d.ts +5 -0
  120. package/dist/i3s-loader.d.ts.map +1 -1
  121. package/dist/i3s-loader.js +88 -83
  122. package/dist/i3s-node-page-loader.d.ts +3 -2
  123. package/dist/i3s-node-page-loader.d.ts.map +1 -1
  124. package/dist/i3s-node-page-loader.js +20 -20
  125. package/dist/i3s-slpk-loader.d.ts +10 -0
  126. package/dist/i3s-slpk-loader.d.ts.map +1 -0
  127. package/dist/i3s-slpk-loader.js +20 -0
  128. package/dist/index.d.ts +5 -2
  129. package/dist/index.d.ts.map +1 -1
  130. package/dist/index.js +21 -6
  131. package/dist/lib/helpers/i3s-nodepages-tiles.d.ts +1 -0
  132. package/dist/lib/helpers/i3s-nodepages-tiles.d.ts.map +1 -1
  133. package/dist/lib/helpers/i3s-nodepages-tiles.js +231 -228
  134. package/dist/lib/parsers/constants.js +85 -63
  135. package/dist/lib/parsers/parse-arcgis-webscene.d.ts +7 -0
  136. package/dist/lib/parsers/parse-arcgis-webscene.d.ts.map +1 -0
  137. package/dist/lib/parsers/parse-arcgis-webscene.js +88 -0
  138. package/dist/lib/parsers/parse-i3s-attribute.d.ts +6 -4
  139. package/dist/lib/parsers/parse-i3s-attribute.d.ts.map +1 -1
  140. package/dist/lib/parsers/parse-i3s-attribute.js +87 -62
  141. package/dist/lib/parsers/parse-i3s-building-scene-layer.js +41 -40
  142. package/dist/lib/parsers/parse-i3s-tile-content.d.ts +2 -2
  143. package/dist/lib/parsers/parse-i3s-tile-content.d.ts.map +1 -1
  144. package/dist/lib/parsers/parse-i3s-tile-content.js +454 -454
  145. package/dist/lib/parsers/parse-i3s.d.ts +1 -1
  146. package/dist/lib/parsers/parse-i3s.d.ts.map +1 -1
  147. package/dist/lib/parsers/parse-i3s.js +92 -88
  148. package/dist/lib/parsers/parse-slpk/parse-slpk.d.ts +4 -0
  149. package/dist/lib/parsers/parse-slpk/parse-slpk.d.ts.map +1 -0
  150. package/dist/lib/parsers/parse-slpk/parse-slpk.js +50 -0
  151. package/dist/lib/parsers/parse-slpk/slpk-archieve.d.ts +32 -0
  152. package/dist/lib/parsers/parse-slpk/slpk-archieve.d.ts.map +1 -0
  153. package/dist/lib/parsers/parse-slpk/slpk-archieve.js +79 -0
  154. package/dist/lib/parsers/parse-zip/cd-file-header.d.ts +38 -0
  155. package/dist/lib/parsers/parse-zip/cd-file-header.d.ts.map +1 -0
  156. package/dist/lib/parsers/parse-zip/cd-file-header.js +48 -0
  157. package/dist/lib/parsers/parse-zip/local-file-header.d.ts +30 -0
  158. package/dist/lib/parsers/parse-zip/local-file-header.d.ts.map +1 -0
  159. package/dist/lib/parsers/parse-zip/local-file-header.js +28 -0
  160. package/dist/lib/utils/convert-i3s-obb-to-mbs.js +19 -8
  161. package/dist/lib/utils/customizeColors.d.ts +14 -0
  162. package/dist/lib/utils/customizeColors.d.ts.map +1 -0
  163. package/dist/lib/utils/customizeColors.js +94 -0
  164. package/dist/lib/utils/url-utils.js +41 -28
  165. package/dist/types.d.ts +518 -97
  166. package/dist/types.d.ts.map +1 -1
  167. package/dist/types.js +18 -19
  168. package/dist/workers/i3s-content-worker-node.d.ts +2 -0
  169. package/dist/workers/i3s-content-worker-node.d.ts.map +1 -0
  170. package/dist/workers/i3s-content-worker-node.js +7 -0
  171. package/dist/workers/i3s-content-worker.js +5 -4
  172. package/package.json +16 -14
  173. package/src/arcgis-webscene-loader.ts +31 -0
  174. package/src/i3s-attribute-loader.ts +9 -9
  175. package/src/i3s-content-loader.ts +17 -5
  176. package/src/i3s-loader.ts +22 -13
  177. package/src/i3s-node-page-loader.ts +6 -10
  178. package/src/i3s-slpk-loader.ts +25 -0
  179. package/src/index.ts +22 -5
  180. package/src/lib/helpers/i3s-nodepages-tiles.ts +14 -3
  181. package/src/lib/parsers/constants.ts +1 -1
  182. package/src/lib/parsers/parse-arcgis-webscene.ts +102 -0
  183. package/src/lib/parsers/parse-i3s-attribute.ts +21 -14
  184. package/src/lib/parsers/parse-i3s-tile-content.ts +99 -76
  185. package/src/lib/parsers/parse-i3s.ts +8 -3
  186. package/src/lib/parsers/parse-slpk/parse-slpk.ts +61 -0
  187. package/src/lib/parsers/parse-slpk/slpk-archieve.ts +108 -0
  188. package/src/lib/parsers/parse-zip/cd-file-header.ts +93 -0
  189. package/src/lib/parsers/parse-zip/local-file-header.ts +56 -0
  190. package/src/lib/utils/customizeColors.ts +134 -0
  191. package/src/types.ts +482 -33
  192. package/src/workers/i3s-content-worker-node.ts +6 -0
  193. package/dist/bundle.js.map +0 -1
  194. package/dist/i3s-attribute-loader.js.map +0 -1
  195. package/dist/i3s-building-scene-layer-loader.js.map +0 -1
  196. package/dist/i3s-content-loader.js.map +0 -1
  197. package/dist/i3s-loader.js.map +0 -1
  198. package/dist/i3s-node-page-loader.js.map +0 -1
  199. package/dist/index.js.map +0 -1
  200. package/dist/lib/helpers/i3s-nodepages-tiles.js.map +0 -1
  201. package/dist/lib/parsers/constants.js.map +0 -1
  202. package/dist/lib/parsers/parse-i3s-attribute.js.map +0 -1
  203. package/dist/lib/parsers/parse-i3s-building-scene-layer.js.map +0 -1
  204. package/dist/lib/parsers/parse-i3s-tile-content.js.map +0 -1
  205. package/dist/lib/parsers/parse-i3s.js.map +0 -1
  206. package/dist/lib/utils/convert-i3s-obb-to-mbs.js.map +0 -1
  207. package/dist/lib/utils/url-utils.js.map +0 -1
  208. package/dist/types.js.map +0 -1
  209. package/dist/workers/i3s-content-worker.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i3s-content-loader.js","names":["parseI3STileContent","VERSION","I3SContentLoader","name","id","module","worker","version","mimeTypes","parse","extensions","options","data","context","tile","_tileOptions","tileset","_tilesetOptions","i3s","tileOptions","tilesetOptions"],"sources":["../../src/i3s-content-loader.ts"],"sourcesContent":["import type {LoaderWithParser, LoaderContext} from '@loaders.gl/loader-utils';\nimport type {I3SLoaderOptions} from './i3s-loader';\nimport {parseI3STileContent} from './lib/parsers/parse-i3s-tile-content';\nimport {I3STileOptions, I3STilesetOptions} from './types';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\n\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'beta';\n/**\n * Loader for I3S - Indexed 3D Scene Layer\n */\nexport const I3SContentLoader: LoaderWithParser = {\n name: 'I3S Content (Indexed Scene Layers)',\n id: 'i3s-content',\n module: 'i3s',\n worker: true,\n version: VERSION,\n mimeTypes: ['application/octet-stream'],\n parse,\n extensions: ['bin'],\n options: {\n 'i3s-content': {}\n }\n};\n\nasync function parse(data, options?: I3SLoaderOptions, context?: LoaderContext) {\n const {tile, _tileOptions, tileset, _tilesetOptions} = options?.i3s || {};\n const tileOptions = _tileOptions || tile;\n const tilesetOptions = _tilesetOptions || tileset;\n if (!tileOptions || !tilesetOptions) {\n return null;\n }\n return await parseI3STileContent(\n data,\n tileOptions as I3STileOptions,\n tilesetOptions as I3STilesetOptions,\n options,\n context\n );\n}\n"],"mappings":"AAEA,SAAQA,mBAAmB,QAAO,sCAAsC;AAMxE,MAAMC,OAAO,GAAG,sBAAkB,KAAK,WAAW,qBAAiB,MAAM;AAIzE,OAAO,MAAMC,gBAAkC,GAAG;EAChDC,IAAI,EAAE,oCAAoC;EAC1CC,EAAE,EAAE,aAAa;EACjBC,MAAM,EAAE,KAAK;EACbC,MAAM,EAAE,IAAI;EACZC,OAAO,EAAEN,OAAO;EAChBO,SAAS,EAAE,CAAC,0BAA0B,CAAC;EACvCC,KAAK;EACLC,UAAU,EAAE,CAAC,KAAK,CAAC;EACnBC,OAAO,EAAE;IACP,aAAa,EAAE,CAAC;EAClB;AACF,CAAC;AAED,eAAeF,KAAKA,CAACG,IAAI,EAAED,OAA0B,EAAEE,OAAuB,EAAE;EAC9E,MAAM;IAACC,IAAI;IAAEC,YAAY;IAAEC,OAAO;IAAEC;EAAe,CAAC,GAAG,CAAAN,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEO,GAAG,KAAI,CAAC,CAAC;EACzE,MAAMC,WAAW,GAAGJ,YAAY,IAAID,IAAI;EACxC,MAAMM,cAAc,GAAGH,eAAe,IAAID,OAAO;EACjD,IAAI,CAACG,WAAW,IAAI,CAACC,cAAc,EAAE;IACnC,OAAO,IAAI;EACb;EACA,OAAO,MAAMpB,mBAAmB,CAC9BY,IAAI,EACJO,WAAW,EACXC,cAAc,EACdT,OAAO,EACPE,OACF,CAAC;AACH"}
@@ -0,0 +1,87 @@
1
+ import { parse } from '@loaders.gl/core';
2
+ import { I3SContentLoader } from './i3s-content-loader';
3
+ import { normalizeTileData, normalizeTilesetData } from './lib/parsers/parse-i3s';
4
+ import { COORDINATE_SYSTEM } from './lib/parsers/constants';
5
+ const VERSION = typeof "4.0.0-alpha.7" !== 'undefined' ? "4.0.0-alpha.7" : 'latest';
6
+ const TILESET_REGEX = /layers\/[0-9]+$/;
7
+ const TILE_HEADER_REGEX = /nodes\/([0-9-]+|root)$/;
8
+ const SLPK_HEX = '504b0304';
9
+ const POINT_CLOUD = 'PointCloud';
10
+ export const I3SLoader = {
11
+ name: 'I3S (Indexed Scene Layers)',
12
+ id: 'i3s',
13
+ module: 'i3s',
14
+ version: VERSION,
15
+ mimeTypes: ['application/octet-stream'],
16
+ parse: parseI3S,
17
+ extensions: ['bin'],
18
+ options: {
19
+ i3s: {
20
+ token: null,
21
+ isTileset: 'auto',
22
+ isTileHeader: 'auto',
23
+ tile: null,
24
+ tileset: null,
25
+ _tileOptions: null,
26
+ _tilesetOptions: null,
27
+ useDracoGeometry: true,
28
+ useCompressedTextures: true,
29
+ decodeTextures: true,
30
+ coordinateSystem: COORDINATE_SYSTEM.METER_OFFSETS,
31
+ colorsByAttribute: null
32
+ }
33
+ }
34
+ };
35
+ async function parseI3S(data) {
36
+ let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
37
+ let context = arguments.length > 2 ? arguments[2] : undefined;
38
+ const url = context.url;
39
+ options.i3s = options.i3s || {};
40
+ const magicNumber = getMagicNumber(data);
41
+ if (magicNumber === SLPK_HEX) {
42
+ throw new Error('Files with .slpk extention currently are not supported by I3SLoader');
43
+ }
44
+ let isTileset;
45
+ if (options.i3s.isTileset === 'auto') {
46
+ isTileset = TILESET_REGEX.test(url);
47
+ } else {
48
+ isTileset = options.i3s.isTileset;
49
+ }
50
+ let isTileHeader;
51
+ if (options.isTileHeader === 'auto') {
52
+ isTileHeader = TILE_HEADER_REGEX.test(url);
53
+ } else {
54
+ isTileHeader = options.i3s.isTileHeader;
55
+ }
56
+ if (isTileset) {
57
+ data = await parseTileset(data, options, context);
58
+ } else if (isTileHeader) {
59
+ data = await parseTile(data, context);
60
+ } else {
61
+ data = await parseTileContent(data, options);
62
+ }
63
+ return data;
64
+ }
65
+ async function parseTileContent(arrayBuffer, options) {
66
+ return await parse(arrayBuffer, I3SContentLoader, options);
67
+ }
68
+ async function parseTileset(data, options, context) {
69
+ const tilesetJson = JSON.parse(new TextDecoder().decode(data));
70
+ if ((tilesetJson === null || tilesetJson === void 0 ? void 0 : tilesetJson.layerType) === POINT_CLOUD) {
71
+ throw new Error('Point Cloud layers currently are not supported by I3SLoader');
72
+ }
73
+ tilesetJson.loader = I3SLoader;
74
+ await normalizeTilesetData(tilesetJson, options, context);
75
+ return tilesetJson;
76
+ }
77
+ async function parseTile(data, context) {
78
+ data = JSON.parse(new TextDecoder().decode(data));
79
+ return normalizeTileData(data, context);
80
+ }
81
+ function getMagicNumber(data) {
82
+ if (data instanceof ArrayBuffer) {
83
+ return [...new Uint8Array(data, 0, 4)].map(value => value.toString(16).padStart(2, '0')).join('');
84
+ }
85
+ return null;
86
+ }
87
+ //# sourceMappingURL=i3s-loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i3s-loader.js","names":["parse","I3SContentLoader","normalizeTileData","normalizeTilesetData","COORDINATE_SYSTEM","VERSION","TILESET_REGEX","TILE_HEADER_REGEX","SLPK_HEX","POINT_CLOUD","I3SLoader","name","id","module","version","mimeTypes","parseI3S","extensions","options","i3s","token","isTileset","isTileHeader","tile","tileset","_tileOptions","_tilesetOptions","useDracoGeometry","useCompressedTextures","decodeTextures","coordinateSystem","METER_OFFSETS","colorsByAttribute","data","arguments","length","undefined","context","url","magicNumber","getMagicNumber","Error","test","parseTileset","parseTile","parseTileContent","arrayBuffer","tilesetJson","JSON","TextDecoder","decode","layerType","loader","ArrayBuffer","Uint8Array","map","value","toString","padStart","join"],"sources":["../../src/i3s-loader.ts"],"sourcesContent":["import type {LoaderWithParser} from '@loaders.gl/loader-utils';\nimport {parse} from '@loaders.gl/core';\nimport {I3SContentLoader} from './i3s-content-loader';\nimport {normalizeTileData, normalizeTilesetData} from './lib/parsers/parse-i3s';\nimport {COORDINATE_SYSTEM} from './lib/parsers/constants';\nimport {I3SParseOptions} from './types';\nimport {LoaderOptions} from './../../loader-utils/src/types';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nconst TILESET_REGEX = /layers\\/[0-9]+$/;\nconst TILE_HEADER_REGEX = /nodes\\/([0-9-]+|root)$/;\nconst SLPK_HEX = '504b0304';\nconst POINT_CLOUD = 'PointCloud';\n\nexport type I3SLoaderOptions = LoaderOptions & {\n i3s?: I3SParseOptions;\n};\n\n/**\n * Loader for I3S - Indexed 3D Scene Layer\n */\nexport const I3SLoader: LoaderWithParser = {\n name: 'I3S (Indexed Scene Layers)',\n id: 'i3s',\n module: 'i3s',\n version: VERSION,\n mimeTypes: ['application/octet-stream'],\n parse: parseI3S,\n extensions: ['bin'],\n options: {\n i3s: {\n token: null,\n isTileset: 'auto',\n isTileHeader: 'auto',\n tile: null,\n tileset: null,\n _tileOptions: null,\n _tilesetOptions: null,\n useDracoGeometry: true,\n useCompressedTextures: true,\n decodeTextures: true,\n coordinateSystem: COORDINATE_SYSTEM.METER_OFFSETS,\n colorsByAttribute: null\n }\n }\n};\n\nasync function parseI3S(data, options: I3SLoaderOptions = {}, context) {\n const url = context.url;\n options.i3s = options.i3s || {};\n const magicNumber = getMagicNumber(data);\n\n // check if file is slpk\n if (magicNumber === SLPK_HEX) {\n throw new Error('Files with .slpk extention currently are not supported by I3SLoader');\n }\n\n // auto detect file type based on url\n let isTileset;\n if (options.i3s.isTileset === 'auto') {\n isTileset = TILESET_REGEX.test(url);\n } else {\n isTileset = options.i3s.isTileset;\n }\n\n let isTileHeader;\n if (options.isTileHeader === 'auto') {\n isTileHeader = TILE_HEADER_REGEX.test(url);\n } else {\n isTileHeader = options.i3s.isTileHeader;\n }\n\n if (isTileset) {\n data = await parseTileset(data, options, context);\n } else if (isTileHeader) {\n data = await parseTile(data, context);\n } else {\n data = await parseTileContent(data, options);\n }\n\n return data;\n}\n\nasync function parseTileContent(arrayBuffer, options: I3SLoaderOptions) {\n return await parse(arrayBuffer, I3SContentLoader, options);\n}\n\nasync function parseTileset(data, options: I3SLoaderOptions, context) {\n const tilesetJson = JSON.parse(new TextDecoder().decode(data));\n\n if (tilesetJson?.layerType === POINT_CLOUD) {\n throw new Error('Point Cloud layers currently are not supported by I3SLoader');\n }\n // eslint-disable-next-line no-use-before-define\n tilesetJson.loader = I3SLoader;\n await normalizeTilesetData(tilesetJson, options, context);\n\n return tilesetJson;\n}\n\nasync function parseTile(data, context) {\n data = JSON.parse(new TextDecoder().decode(data));\n return normalizeTileData(data, context);\n}\n\nfunction getMagicNumber(data) {\n if (data instanceof ArrayBuffer) {\n // slice binary data (4 bytes from the beginning) and transform it to hexadecimal numeral system\n return [...new Uint8Array(data, 0, 4)]\n .map((value) => value.toString(16).padStart(2, '0'))\n .join('');\n }\n return null;\n}\n"],"mappings":"AACA,SAAQA,KAAK,QAAO,kBAAkB;AACtC,SAAQC,gBAAgB,QAAO,sBAAsB;AACrD,SAAQC,iBAAiB,EAAEC,oBAAoB,QAAO,yBAAyB;AAC/E,SAAQC,iBAAiB,QAAO,yBAAyB;AAMzD,MAAMC,OAAO,GAAG,sBAAkB,KAAK,WAAW,qBAAiB,QAAQ;AAE3E,MAAMC,aAAa,GAAG,iBAAiB;AACvC,MAAMC,iBAAiB,GAAG,wBAAwB;AAClD,MAAMC,QAAQ,GAAG,UAAU;AAC3B,MAAMC,WAAW,GAAG,YAAY;AAShC,OAAO,MAAMC,SAA2B,GAAG;EACzCC,IAAI,EAAE,4BAA4B;EAClCC,EAAE,EAAE,KAAK;EACTC,MAAM,EAAE,KAAK;EACbC,OAAO,EAAET,OAAO;EAChBU,SAAS,EAAE,CAAC,0BAA0B,CAAC;EACvCf,KAAK,EAAEgB,QAAQ;EACfC,UAAU,EAAE,CAAC,KAAK,CAAC;EACnBC,OAAO,EAAE;IACPC,GAAG,EAAE;MACHC,KAAK,EAAE,IAAI;MACXC,SAAS,EAAE,MAAM;MACjBC,YAAY,EAAE,MAAM;MACpBC,IAAI,EAAE,IAAI;MACVC,OAAO,EAAE,IAAI;MACbC,YAAY,EAAE,IAAI;MAClBC,eAAe,EAAE,IAAI;MACrBC,gBAAgB,EAAE,IAAI;MACtBC,qBAAqB,EAAE,IAAI;MAC3BC,cAAc,EAAE,IAAI;MACpBC,gBAAgB,EAAE1B,iBAAiB,CAAC2B,aAAa;MACjDC,iBAAiB,EAAE;IACrB;EACF;AACF,CAAC;AAED,eAAehB,QAAQA,CAACiB,IAAI,EAA2C;EAAA,IAAzCf,OAAyB,GAAAgB,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC,CAAC;EAAA,IAAEG,OAAO,GAAAH,SAAA,CAAAC,MAAA,OAAAD,SAAA,MAAAE,SAAA;EACnE,MAAME,GAAG,GAAGD,OAAO,CAACC,GAAG;EACvBpB,OAAO,CAACC,GAAG,GAAGD,OAAO,CAACC,GAAG,IAAI,CAAC,CAAC;EAC/B,MAAMoB,WAAW,GAAGC,cAAc,CAACP,IAAI,CAAC;EAGxC,IAAIM,WAAW,KAAK/B,QAAQ,EAAE;IAC5B,MAAM,IAAIiC,KAAK,CAAC,qEAAqE,CAAC;EACxF;EAGA,IAAIpB,SAAS;EACb,IAAIH,OAAO,CAACC,GAAG,CAACE,SAAS,KAAK,MAAM,EAAE;IACpCA,SAAS,GAAGf,aAAa,CAACoC,IAAI,CAACJ,GAAG,CAAC;EACrC,CAAC,MAAM;IACLjB,SAAS,GAAGH,OAAO,CAACC,GAAG,CAACE,SAAS;EACnC;EAEA,IAAIC,YAAY;EAChB,IAAIJ,OAAO,CAACI,YAAY,KAAK,MAAM,EAAE;IACnCA,YAAY,GAAGf,iBAAiB,CAACmC,IAAI,CAACJ,GAAG,CAAC;EAC5C,CAAC,MAAM;IACLhB,YAAY,GAAGJ,OAAO,CAACC,GAAG,CAACG,YAAY;EACzC;EAEA,IAAID,SAAS,EAAE;IACbY,IAAI,GAAG,MAAMU,YAAY,CAACV,IAAI,EAAEf,OAAO,EAAEmB,OAAO,CAAC;EACnD,CAAC,MAAM,IAAIf,YAAY,EAAE;IACvBW,IAAI,GAAG,MAAMW,SAAS,CAACX,IAAI,EAAEI,OAAO,CAAC;EACvC,CAAC,MAAM;IACLJ,IAAI,GAAG,MAAMY,gBAAgB,CAACZ,IAAI,EAAEf,OAAO,CAAC;EAC9C;EAEA,OAAOe,IAAI;AACb;AAEA,eAAeY,gBAAgBA,CAACC,WAAW,EAAE5B,OAAyB,EAAE;EACtE,OAAO,MAAMlB,KAAK,CAAC8C,WAAW,EAAE7C,gBAAgB,EAAEiB,OAAO,CAAC;AAC5D;AAEA,eAAeyB,YAAYA,CAACV,IAAI,EAAEf,OAAyB,EAAEmB,OAAO,EAAE;EACpE,MAAMU,WAAW,GAAGC,IAAI,CAAChD,KAAK,CAAC,IAAIiD,WAAW,CAAC,CAAC,CAACC,MAAM,CAACjB,IAAI,CAAC,CAAC;EAE9D,IAAI,CAAAc,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEI,SAAS,MAAK1C,WAAW,EAAE;IAC1C,MAAM,IAAIgC,KAAK,CAAC,6DAA6D,CAAC;EAChF;EAEAM,WAAW,CAACK,MAAM,GAAG1C,SAAS;EAC9B,MAAMP,oBAAoB,CAAC4C,WAAW,EAAE7B,OAAO,EAAEmB,OAAO,CAAC;EAEzD,OAAOU,WAAW;AACpB;AAEA,eAAeH,SAASA,CAACX,IAAI,EAAEI,OAAO,EAAE;EACtCJ,IAAI,GAAGe,IAAI,CAAChD,KAAK,CAAC,IAAIiD,WAAW,CAAC,CAAC,CAACC,MAAM,CAACjB,IAAI,CAAC,CAAC;EACjD,OAAO/B,iBAAiB,CAAC+B,IAAI,EAAEI,OAAO,CAAC;AACzC;AAEA,SAASG,cAAcA,CAACP,IAAI,EAAE;EAC5B,IAAIA,IAAI,YAAYoB,WAAW,EAAE;IAE/B,OAAO,CAAC,GAAG,IAAIC,UAAU,CAACrB,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CACnCsB,GAAG,CAAEC,KAAK,IAAKA,KAAK,CAACC,QAAQ,CAAC,EAAE,CAAC,CAACC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CACnDC,IAAI,CAAC,EAAE,CAAC;EACb;EACA,OAAO,IAAI;AACb"}
@@ -0,0 +1,15 @@
1
+ const VERSION = typeof "4.0.0-alpha.7" !== 'undefined' ? "4.0.0-alpha.7" : 'latest';
2
+ async function parseNodePage(data, options) {
3
+ return JSON.parse(new TextDecoder().decode(data));
4
+ }
5
+ export const I3SNodePageLoader = {
6
+ name: 'I3S Node Page',
7
+ id: 'i3s-node-page',
8
+ module: 'i3s',
9
+ version: VERSION,
10
+ mimeTypes: ['application/json'],
11
+ parse: parseNodePage,
12
+ extensions: ['json'],
13
+ options: {}
14
+ };
15
+ //# sourceMappingURL=i3s-node-page-loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i3s-node-page-loader.js","names":["VERSION","parseNodePage","data","options","JSON","parse","TextDecoder","decode","I3SNodePageLoader","name","id","module","version","mimeTypes","extensions"],"sources":["../../src/i3s-node-page-loader.ts"],"sourcesContent":["import type {LoaderOptions, LoaderWithParser} from '@loaders.gl/loader-utils';\nimport type {NodePage} from './types';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nasync function parseNodePage(data: ArrayBuffer, options?: LoaderOptions): Promise<NodePage> {\n return JSON.parse(new TextDecoder().decode(data)) as NodePage;\n}\n\n/**\n * Loader for I3S node pages\n */\nexport const I3SNodePageLoader: LoaderWithParser<NodePage, never, LoaderOptions> = {\n name: 'I3S Node Page',\n id: 'i3s-node-page',\n module: 'i3s',\n version: VERSION,\n mimeTypes: ['application/json'],\n parse: parseNodePage,\n extensions: ['json'],\n options: {}\n};\n"],"mappings":"AAKA,MAAMA,OAAO,GAAG,sBAAkB,KAAK,WAAW,qBAAiB,QAAQ;AAE3E,eAAeC,aAAaA,CAACC,IAAiB,EAAEC,OAAuB,EAAqB;EAC1F,OAAOC,IAAI,CAACC,KAAK,CAAC,IAAIC,WAAW,CAAC,CAAC,CAACC,MAAM,CAACL,IAAI,CAAC,CAAC;AACnD;AAKA,OAAO,MAAMM,iBAAmE,GAAG;EACjFC,IAAI,EAAE,eAAe;EACrBC,EAAE,EAAE,eAAe;EACnBC,MAAM,EAAE,KAAK;EACbC,OAAO,EAAEZ,OAAO;EAChBa,SAAS,EAAE,CAAC,kBAAkB,CAAC;EAC/BR,KAAK,EAAEJ,aAAa;EACpBa,UAAU,EAAE,CAAC,MAAM,CAAC;EACpBX,OAAO,EAAE,CAAC;AACZ,CAAC"}
@@ -0,0 +1,13 @@
1
+ import { parseSLPK } from './lib/parsers/parse-slpk/parse-slpk';
2
+ const VERSION = typeof "4.0.0-alpha.7" !== 'undefined' ? "4.0.0-alpha.7" : 'latest';
3
+ export const SLPKLoader = {
4
+ name: 'I3S SLPK (Scene Layer Package)',
5
+ id: 'slpk',
6
+ module: 'i3s',
7
+ version: VERSION,
8
+ mimeTypes: ['application/octet-stream'],
9
+ parse: parseSLPK,
10
+ extensions: ['slpk'],
11
+ options: {}
12
+ };
13
+ //# sourceMappingURL=i3s-slpk-loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i3s-slpk-loader.js","names":["parseSLPK","VERSION","SLPKLoader","name","id","module","version","mimeTypes","parse","extensions","options"],"sources":["../../src/i3s-slpk-loader.ts"],"sourcesContent":["import {LoaderOptions, LoaderWithParser} from '@loaders.gl/loader-utils';\nimport {parseSLPK} from './lib/parsers/parse-slpk/parse-slpk';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nexport type SLPKLoaderOptions = LoaderOptions & {\n path?: string;\n mode?: 'http' | 'raw';\n};\n\n/**\n * Loader for SLPK - Scene Layer Package\n */\nexport const SLPKLoader: LoaderWithParser = {\n name: 'I3S SLPK (Scene Layer Package)',\n id: 'slpk',\n module: 'i3s',\n version: VERSION,\n mimeTypes: ['application/octet-stream'],\n parse: parseSLPK,\n extensions: ['slpk'],\n options: {}\n};\n"],"mappings":"AACA,SAAQA,SAAS,QAAO,qCAAqC;AAI7D,MAAMC,OAAO,GAAG,sBAAkB,KAAK,WAAW,qBAAiB,QAAQ;AAU3E,OAAO,MAAMC,UAA4B,GAAG;EAC1CC,IAAI,EAAE,gCAAgC;EACtCC,EAAE,EAAE,MAAM;EACVC,MAAM,EAAE,KAAK;EACbC,OAAO,EAAEL,OAAO;EAChBM,SAAS,EAAE,CAAC,0BAA0B,CAAC;EACvCC,KAAK,EAAER,SAAS;EAChBS,UAAU,EAAE,CAAC,MAAM,CAAC;EACpBC,OAAO,EAAE,CAAC;AACZ,CAAC"}
@@ -0,0 +1,9 @@
1
+ export { COORDINATE_SYSTEM } from './lib/parsers/constants';
2
+ export { I3SLoader } from './i3s-loader';
3
+ export { SLPKLoader } from './i3s-slpk-loader';
4
+ export { I3SContentLoader } from './i3s-content-loader';
5
+ export { I3SAttributeLoader, loadFeatureAttributes } from './i3s-attribute-loader';
6
+ export { I3SBuildingSceneLayerLoader } from './i3s-building-scene-layer-loader';
7
+ export { I3SNodePageLoader } from './i3s-node-page-loader';
8
+ export { ArcGisWebSceneLoader } from './arcgis-webscene-loader';
9
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","names":["COORDINATE_SYSTEM","I3SLoader","SLPKLoader","I3SContentLoader","I3SAttributeLoader","loadFeatureAttributes","I3SBuildingSceneLayerLoader","I3SNodePageLoader","ArcGisWebSceneLoader"],"sources":["../../src/index.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nexport type {\n BoundingVolumes,\n Mbs,\n Obb,\n SceneLayer3D,\n AttributeStorageInfo,\n Field,\n ESRIField,\n PopupInfo,\n Node3DIndexDocument,\n LodSelection,\n NodeReference,\n Resource,\n MaxScreenThresholdSQ,\n NodeInPage,\n SharedResources,\n Attribute,\n Extent,\n FeatureAttribute,\n FieldInfo,\n I3SMaterialDefinition,\n TextureDefinitionInfo,\n MaterialDefinitionInfo,\n FullExtent,\n StatisticsInfo,\n StatsInfo,\n Histogram,\n ValueCount,\n BuildingSceneSublayer,\n DATA_TYPE,\n OperationalLayer\n} from './types';\n\nexport {COORDINATE_SYSTEM} from './lib/parsers/constants';\n\nexport {I3SLoader} from './i3s-loader';\nexport {SLPKLoader} from './i3s-slpk-loader';\nexport {I3SContentLoader} from './i3s-content-loader';\nexport {I3SAttributeLoader, loadFeatureAttributes} from './i3s-attribute-loader';\nexport {I3SBuildingSceneLayerLoader} from './i3s-building-scene-layer-loader';\nexport {I3SNodePageLoader} from './i3s-node-page-loader';\nexport {ArcGisWebSceneLoader} from './arcgis-webscene-loader';\n"],"mappings":"AAmCA,SAAQA,iBAAiB,QAAO,yBAAyB;AAEzD,SAAQC,SAAS,QAAO,cAAc;AACtC,SAAQC,UAAU,QAAO,mBAAmB;AAC5C,SAAQC,gBAAgB,QAAO,sBAAsB;AACrD,SAAQC,kBAAkB,EAAEC,qBAAqB,QAAO,wBAAwB;AAChF,SAAQC,2BAA2B,QAAO,mCAAmC;AAC7E,SAAQC,iBAAiB,QAAO,wBAAwB;AACxD,SAAQC,oBAAoB,QAAO,0BAA0B"}
@@ -0,0 +1,198 @@
1
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
+ import { load } from '@loaders.gl/core';
3
+ import { getSupportedGPUTextureFormats, selectSupportedBasisFormat } from '@loaders.gl/textures';
4
+ import { I3SNodePageLoader } from '../../i3s-node-page-loader';
5
+ import { normalizeTileNonUrlData } from '../parsers/parse-i3s';
6
+ import { getUrlWithToken, generateTilesetAttributeUrls } from '../utils/url-utils';
7
+ export default class I3SNodePagesTiles {
8
+ constructor(tileset, options) {
9
+ var _tileset$nodePages, _tileset$nodePages2;
10
+ _defineProperty(this, "tileset", void 0);
11
+ _defineProperty(this, "nodePages", []);
12
+ _defineProperty(this, "pendingNodePages", []);
13
+ _defineProperty(this, "nodesPerPage", void 0);
14
+ _defineProperty(this, "options", void 0);
15
+ _defineProperty(this, "lodSelectionMetricType", void 0);
16
+ _defineProperty(this, "textureDefinitionsSelectedFormats", []);
17
+ _defineProperty(this, "nodesInNodePages", void 0);
18
+ _defineProperty(this, "textureLoaderOptions", {});
19
+ this.tileset = {
20
+ ...tileset
21
+ };
22
+ this.nodesPerPage = ((_tileset$nodePages = tileset.nodePages) === null || _tileset$nodePages === void 0 ? void 0 : _tileset$nodePages.nodesPerPage) || 64;
23
+ this.lodSelectionMetricType = (_tileset$nodePages2 = tileset.nodePages) === null || _tileset$nodePages2 === void 0 ? void 0 : _tileset$nodePages2.lodSelectionMetricType;
24
+ this.options = options;
25
+ this.nodesInNodePages = 0;
26
+ this.initSelectedFormatsForTextureDefinitions(tileset);
27
+ }
28
+ async getNodeById(id) {
29
+ const pageIndex = Math.floor(id / this.nodesPerPage);
30
+ if (!this.nodePages[pageIndex] && !this.pendingNodePages[pageIndex]) {
31
+ var _this$options$i3s;
32
+ const nodePageUrl = getUrlWithToken("".concat(this.tileset.url, "/nodepages/").concat(pageIndex), (_this$options$i3s = this.options.i3s) === null || _this$options$i3s === void 0 ? void 0 : _this$options$i3s.token);
33
+ this.pendingNodePages[pageIndex] = {
34
+ status: 'Pending',
35
+ promise: load(nodePageUrl, I3SNodePageLoader, this.options)
36
+ };
37
+ this.nodePages[pageIndex] = await this.pendingNodePages[pageIndex].promise;
38
+ this.nodesInNodePages += this.nodePages[pageIndex].nodes.length;
39
+ this.pendingNodePages[pageIndex].status = 'Done';
40
+ }
41
+ if (this.pendingNodePages[pageIndex].status === 'Pending') {
42
+ this.nodePages[pageIndex] = await this.pendingNodePages[pageIndex].promise;
43
+ }
44
+ const nodeIndex = id % this.nodesPerPage;
45
+ return this.nodePages[pageIndex].nodes[nodeIndex];
46
+ }
47
+ async formTileFromNodePages(id) {
48
+ const node = await this.getNodeById(id);
49
+ const children = [];
50
+ const childNodesPromises = [];
51
+ for (const child of node.children || []) {
52
+ childNodesPromises.push(this.getNodeById(child));
53
+ }
54
+ const childNodes = await Promise.all(childNodesPromises);
55
+ for (const childNode of childNodes) {
56
+ children.push({
57
+ id: childNode.index.toString(),
58
+ obb: childNode.obb
59
+ });
60
+ }
61
+ let contentUrl;
62
+ let textureUrl;
63
+ let materialDefinition;
64
+ let textureFormat = 'jpg';
65
+ let attributeUrls = [];
66
+ let isDracoGeometry = false;
67
+ if (node && node.mesh) {
68
+ const {
69
+ url,
70
+ isDracoGeometry: isDracoGeometryResult
71
+ } = node.mesh.geometry && this.getContentUrl(node.mesh.geometry) || {
72
+ isDracoGeometry: false
73
+ };
74
+ contentUrl = url;
75
+ isDracoGeometry = isDracoGeometryResult;
76
+ const {
77
+ textureData,
78
+ materialDefinition: nodeMaterialDefinition
79
+ } = this.getInformationFromMaterial(node.mesh.material);
80
+ materialDefinition = nodeMaterialDefinition;
81
+ textureFormat = textureData.format || textureFormat;
82
+ if (textureData.name) {
83
+ textureUrl = "".concat(this.tileset.url, "/nodes/").concat(node.mesh.material.resource, "/textures/").concat(textureData.name);
84
+ }
85
+ if (this.tileset.attributeStorageInfo) {
86
+ attributeUrls = generateTilesetAttributeUrls(this.tileset, node.mesh.attribute.resource);
87
+ }
88
+ }
89
+ const lodSelection = this.getLodSelection(node);
90
+ return normalizeTileNonUrlData({
91
+ id: id.toString(),
92
+ lodSelection,
93
+ obb: node.obb,
94
+ contentUrl,
95
+ textureUrl,
96
+ attributeUrls,
97
+ materialDefinition,
98
+ textureFormat,
99
+ textureLoaderOptions: this.textureLoaderOptions,
100
+ children,
101
+ isDracoGeometry
102
+ });
103
+ }
104
+ getContentUrl(meshGeometryData) {
105
+ let result = null;
106
+ const geometryDefinition = this.tileset.geometryDefinitions[meshGeometryData.definition];
107
+ let geometryIndex = -1;
108
+ if (this.options.i3s && this.options.i3s.useDracoGeometry) {
109
+ geometryIndex = geometryDefinition.geometryBuffers.findIndex(buffer => buffer.compressedAttributes && buffer.compressedAttributes.encoding === 'draco');
110
+ }
111
+ if (geometryIndex === -1) {
112
+ geometryIndex = geometryDefinition.geometryBuffers.findIndex(buffer => !buffer.compressedAttributes);
113
+ }
114
+ if (geometryIndex !== -1) {
115
+ const isDracoGeometry = Boolean(geometryDefinition.geometryBuffers[geometryIndex].compressedAttributes);
116
+ result = {
117
+ url: "".concat(this.tileset.url, "/nodes/").concat(meshGeometryData.resource, "/geometries/").concat(geometryIndex),
118
+ isDracoGeometry
119
+ };
120
+ }
121
+ return result;
122
+ }
123
+ getLodSelection(node) {
124
+ const lodSelection = [];
125
+ if (this.lodSelectionMetricType === 'maxScreenThresholdSQ') {
126
+ lodSelection.push({
127
+ metricType: 'maxScreenThreshold',
128
+ maxError: Math.sqrt(node.lodThreshold / (Math.PI * 0.25))
129
+ });
130
+ }
131
+ lodSelection.push({
132
+ metricType: this.lodSelectionMetricType,
133
+ maxError: node.lodThreshold
134
+ });
135
+ return lodSelection;
136
+ }
137
+ getInformationFromMaterial(material) {
138
+ const informationFromMaterial = {
139
+ textureData: {
140
+ name: null
141
+ }
142
+ };
143
+ if (material) {
144
+ var _this$tileset$materia;
145
+ const materialDefinition = (_this$tileset$materia = this.tileset.materialDefinitions) === null || _this$tileset$materia === void 0 ? void 0 : _this$tileset$materia[material.definition];
146
+ if (materialDefinition) {
147
+ var _materialDefinition$p, _materialDefinition$p2;
148
+ informationFromMaterial.materialDefinition = materialDefinition;
149
+ const textureSetDefinitionIndex = materialDefinition === null || materialDefinition === void 0 ? void 0 : (_materialDefinition$p = materialDefinition.pbrMetallicRoughness) === null || _materialDefinition$p === void 0 ? void 0 : (_materialDefinition$p2 = _materialDefinition$p.baseColorTexture) === null || _materialDefinition$p2 === void 0 ? void 0 : _materialDefinition$p2.textureSetDefinitionId;
150
+ if (typeof textureSetDefinitionIndex === 'number') {
151
+ informationFromMaterial.textureData = this.textureDefinitionsSelectedFormats[textureSetDefinitionIndex] || informationFromMaterial.textureData;
152
+ }
153
+ }
154
+ }
155
+ return informationFromMaterial;
156
+ }
157
+ initSelectedFormatsForTextureDefinitions(tileset) {
158
+ this.textureDefinitionsSelectedFormats = [];
159
+ const possibleI3sFormats = this.getSupportedTextureFormats();
160
+ const textureSetDefinitions = tileset.textureSetDefinitions || [];
161
+ for (const textureSetDefinition of textureSetDefinitions) {
162
+ const formats = textureSetDefinition && textureSetDefinition.formats || [];
163
+ let selectedFormat = null;
164
+ for (const i3sFormat of possibleI3sFormats) {
165
+ const format = formats.find(value => value.format === i3sFormat);
166
+ if (format) {
167
+ selectedFormat = format;
168
+ break;
169
+ }
170
+ }
171
+ if (selectedFormat && selectedFormat.format === 'ktx2') {
172
+ this.textureLoaderOptions.basis = {
173
+ format: selectSupportedBasisFormat(),
174
+ containerFormat: 'ktx2',
175
+ module: 'encoder'
176
+ };
177
+ }
178
+ this.textureDefinitionsSelectedFormats.push(selectedFormat);
179
+ }
180
+ }
181
+ getSupportedTextureFormats() {
182
+ const formats = [];
183
+ if (!this.options.i3s || this.options.i3s.useCompressedTextures) {
184
+ const supportedCompressedFormats = getSupportedGPUTextureFormats();
185
+ if (supportedCompressedFormats.has('etc2')) {
186
+ formats.push('ktx-etc2');
187
+ }
188
+ if (supportedCompressedFormats.has('dxt')) {
189
+ formats.push('dds');
190
+ }
191
+ formats.push('ktx2');
192
+ }
193
+ formats.push('jpg');
194
+ formats.push('png');
195
+ return formats;
196
+ }
197
+ }
198
+ //# sourceMappingURL=i3s-nodepages-tiles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i3s-nodepages-tiles.js","names":["load","getSupportedGPUTextureFormats","selectSupportedBasisFormat","I3SNodePageLoader","normalizeTileNonUrlData","getUrlWithToken","generateTilesetAttributeUrls","I3SNodePagesTiles","constructor","tileset","options","_tileset$nodePages","_tileset$nodePages2","_defineProperty","nodesPerPage","nodePages","lodSelectionMetricType","nodesInNodePages","initSelectedFormatsForTextureDefinitions","getNodeById","id","pageIndex","Math","floor","pendingNodePages","_this$options$i3s","nodePageUrl","concat","url","i3s","token","status","promise","nodes","length","nodeIndex","formTileFromNodePages","node","children","childNodesPromises","child","push","childNodes","Promise","all","childNode","index","toString","obb","contentUrl","textureUrl","materialDefinition","textureFormat","attributeUrls","isDracoGeometry","mesh","isDracoGeometryResult","geometry","getContentUrl","textureData","nodeMaterialDefinition","getInformationFromMaterial","material","format","name","resource","attributeStorageInfo","attribute","lodSelection","getLodSelection","textureLoaderOptions","meshGeometryData","result","geometryDefinition","geometryDefinitions","definition","geometryIndex","useDracoGeometry","geometryBuffers","findIndex","buffer","compressedAttributes","encoding","Boolean","metricType","maxError","sqrt","lodThreshold","PI","informationFromMaterial","_this$tileset$materia","materialDefinitions","_materialDefinition$p","_materialDefinition$p2","textureSetDefinitionIndex","pbrMetallicRoughness","baseColorTexture","textureSetDefinitionId","textureDefinitionsSelectedFormats","possibleI3sFormats","getSupportedTextureFormats","textureSetDefinitions","textureSetDefinition","formats","selectedFormat","i3sFormat","find","value","basis","containerFormat","module","useCompressedTextures","supportedCompressedFormats","has"],"sources":["../../../../src/lib/helpers/i3s-nodepages-tiles.ts"],"sourcesContent":["import {load} from '@loaders.gl/core';\nimport {getSupportedGPUTextureFormats, selectSupportedBasisFormat} from '@loaders.gl/textures';\nimport {I3SNodePageLoader} from '../../i3s-node-page-loader';\nimport {normalizeTileNonUrlData} from '../parsers/parse-i3s';\nimport {getUrlWithToken, generateTilesetAttributeUrls} from '../utils/url-utils';\nimport type {LoaderOptions} from '@loaders.gl/loader-utils';\nimport {\n I3STilesetHeader,\n LodSelection,\n NodePage,\n NodeInPage,\n Obb,\n MeshMaterial,\n I3SMaterialDefinition,\n I3STextureFormat,\n MeshGeometry,\n I3STileHeader\n} from '../../types';\n\n/**\n * class I3SNodePagesTiles - loads nodePages and form i3s tiles from them\n */\nexport default class I3SNodePagesTiles {\n tileset: I3STilesetHeader;\n nodePages: NodePage[] = [];\n pendingNodePages: {promise: Promise<NodePage>; status: 'Pending' | 'Done'}[] = [];\n nodesPerPage: number;\n options: LoaderOptions;\n lodSelectionMetricType?: string;\n textureDefinitionsSelectedFormats: ({format: I3STextureFormat; name: string} | null)[] = [];\n nodesInNodePages: number;\n private textureLoaderOptions: {[key: string]: any} = {};\n\n /**\n * @constructs\n * Create a I3SNodePagesTiles instance.\n * @param tileset - i3s tileset header ('layers/0')\n * @param options - i3s loader options\n */\n constructor(tileset: I3STilesetHeader, options: LoaderOptions) {\n this.tileset = {...tileset}; // spread the tileset to avoid circular reference\n this.nodesPerPage = tileset.nodePages?.nodesPerPage || 64;\n this.lodSelectionMetricType = tileset.nodePages?.lodSelectionMetricType;\n this.options = options;\n this.nodesInNodePages = 0;\n\n this.initSelectedFormatsForTextureDefinitions(tileset);\n }\n\n /**\n * Loads some nodePage and return a particular node from it\n * @param id - id of node through all node pages\n */\n async getNodeById(id: number): Promise<NodeInPage> {\n const pageIndex = Math.floor(id / this.nodesPerPage);\n if (!this.nodePages[pageIndex] && !this.pendingNodePages[pageIndex]) {\n const nodePageUrl = getUrlWithToken(\n `${this.tileset.url}/nodepages/${pageIndex}`,\n // @ts-expect-error this.options is not properly typed\n this.options.i3s?.token\n );\n this.pendingNodePages[pageIndex] = {\n status: 'Pending',\n promise: load(nodePageUrl, I3SNodePageLoader, this.options)\n };\n this.nodePages[pageIndex] = await this.pendingNodePages[pageIndex].promise;\n this.nodesInNodePages += this.nodePages[pageIndex].nodes.length;\n this.pendingNodePages[pageIndex].status = 'Done';\n }\n if (this.pendingNodePages[pageIndex].status === 'Pending') {\n this.nodePages[pageIndex] = await this.pendingNodePages[pageIndex].promise;\n }\n const nodeIndex = id % this.nodesPerPage;\n return this.nodePages[pageIndex].nodes[nodeIndex];\n }\n\n /**\n * Forms tile header using node and tileset data\n * @param id - id of node through all node pages\n */\n // eslint-disable-next-line complexity, max-statements\n async formTileFromNodePages(id: number): Promise<I3STileHeader> {\n const node: NodeInPage = await this.getNodeById(id);\n const children: {id: string; obb: Obb}[] = [];\n const childNodesPromises: Promise<NodeInPage>[] = [];\n for (const child of node.children || []) {\n childNodesPromises.push(this.getNodeById(child));\n }\n\n const childNodes = await Promise.all(childNodesPromises);\n for (const childNode of childNodes) {\n children.push({\n id: childNode.index.toString(),\n obb: childNode.obb\n });\n }\n\n let contentUrl: string | undefined;\n let textureUrl: string | undefined;\n let materialDefinition: I3SMaterialDefinition | undefined;\n let textureFormat: I3STextureFormat = 'jpg';\n let attributeUrls: string[] = [];\n let isDracoGeometry: boolean = false;\n\n if (node && node.mesh) {\n // Get geometry resource URL and type (compressed / non-compressed)\n const {url, isDracoGeometry: isDracoGeometryResult} = (node.mesh.geometry &&\n this.getContentUrl(node.mesh.geometry)) || {isDracoGeometry: false};\n contentUrl = url;\n isDracoGeometry = isDracoGeometryResult;\n\n const {textureData, materialDefinition: nodeMaterialDefinition} =\n this.getInformationFromMaterial(node.mesh.material);\n materialDefinition = nodeMaterialDefinition;\n textureFormat = textureData.format || textureFormat;\n if (textureData.name) {\n textureUrl = `${this.tileset.url}/nodes/${node.mesh.material.resource}/textures/${textureData.name}`;\n }\n\n if (this.tileset.attributeStorageInfo) {\n attributeUrls = generateTilesetAttributeUrls(this.tileset, node.mesh.attribute.resource);\n }\n }\n\n const lodSelection = this.getLodSelection(node);\n\n return normalizeTileNonUrlData({\n id: id.toString(),\n lodSelection,\n obb: node.obb,\n contentUrl,\n textureUrl,\n attributeUrls,\n materialDefinition,\n textureFormat,\n textureLoaderOptions: this.textureLoaderOptions,\n children,\n isDracoGeometry\n });\n }\n\n /**\n * Forms url and type of geometry resource by nodepage's data and `geometryDefinitions` in the tileset\n * @param - data about the node's mesh from the nodepage\n * @returns -\n * {string} url - url to the geometry resource\n * {boolean} isDracoGeometry - whether the geometry resource contain DRACO compressed geometry\n */\n private getContentUrl(meshGeometryData: MeshGeometry) {\n let result: {url: string; isDracoGeometry: boolean} | null = null;\n // @ts-ignore\n const geometryDefinition = this.tileset.geometryDefinitions[meshGeometryData.definition];\n let geometryIndex = -1;\n // Try to find DRACO geometryDefinition of `useDracoGeometry` option is set\n // @ts-expect-error this.options is not properly typed\n if (this.options.i3s && this.options.i3s.useDracoGeometry) {\n geometryIndex = geometryDefinition.geometryBuffers.findIndex(\n (buffer) => buffer.compressedAttributes && buffer.compressedAttributes.encoding === 'draco'\n );\n }\n // If DRACO geometry is not applicable try to select non-compressed geometry\n if (geometryIndex === -1) {\n geometryIndex = geometryDefinition.geometryBuffers.findIndex(\n (buffer) => !buffer.compressedAttributes\n );\n }\n if (geometryIndex !== -1) {\n const isDracoGeometry = Boolean(\n geometryDefinition.geometryBuffers[geometryIndex].compressedAttributes\n );\n result = {\n url: `${this.tileset.url}/nodes/${meshGeometryData.resource}/geometries/${geometryIndex}`,\n isDracoGeometry\n };\n }\n return result;\n }\n\n /**\n * Forms 1.6 compatible LOD selection object from a nodepage's node data\n * @param node - a node from nodepage\n * @returns- Array of LodSelection\n */\n private getLodSelection(node: NodeInPage): LodSelection[] {\n const lodSelection: LodSelection[] = [];\n if (this.lodSelectionMetricType === 'maxScreenThresholdSQ') {\n lodSelection.push({\n metricType: 'maxScreenThreshold',\n // @ts-ignore\n maxError: Math.sqrt(node.lodThreshold / (Math.PI * 0.25))\n });\n }\n lodSelection.push({\n metricType: this.lodSelectionMetricType,\n // @ts-ignore\n maxError: node.lodThreshold\n });\n return lodSelection;\n }\n\n /**\n * Returns information about texture and material from `materialDefinitions`\n * @param material - material data from nodepage\n * @returns - Couple {textureData, materialDefinition}\n * {string} textureData.name - path name of the texture\n * {string} textureData.format - format of the texture\n * materialDefinition - PBR-like material definition from `materialDefinitions`\n */\n private getInformationFromMaterial(material: MeshMaterial) {\n const informationFromMaterial: {\n textureData: {name: string | null; format?: I3STextureFormat};\n materialDefinition?: I3SMaterialDefinition;\n } = {textureData: {name: null}};\n\n if (material) {\n const materialDefinition = this.tileset.materialDefinitions?.[material.definition];\n if (materialDefinition) {\n informationFromMaterial.materialDefinition = materialDefinition;\n const textureSetDefinitionIndex =\n materialDefinition?.pbrMetallicRoughness?.baseColorTexture?.textureSetDefinitionId;\n\n if (typeof textureSetDefinitionIndex === 'number') {\n informationFromMaterial.textureData =\n this.textureDefinitionsSelectedFormats[textureSetDefinitionIndex] ||\n informationFromMaterial.textureData;\n }\n }\n }\n return informationFromMaterial;\n }\n\n /**\n * Sets preferable and supported format for each textureDefinition of the tileset\n * @param tileset - I3S layer data\n * @returns\n */\n private initSelectedFormatsForTextureDefinitions(tileset: I3STilesetHeader): void {\n this.textureDefinitionsSelectedFormats = [];\n const possibleI3sFormats = this.getSupportedTextureFormats();\n const textureSetDefinitions = tileset.textureSetDefinitions || [];\n for (const textureSetDefinition of textureSetDefinitions) {\n const formats = (textureSetDefinition && textureSetDefinition.formats) || [];\n let selectedFormat: {name: string; format: I3STextureFormat} | null = null;\n for (const i3sFormat of possibleI3sFormats) {\n const format = formats.find((value) => value.format === i3sFormat);\n if (format) {\n selectedFormat = format;\n break;\n }\n }\n // For I3S 1.8 need to define basis target format to decode\n if (selectedFormat && selectedFormat.format === 'ktx2') {\n this.textureLoaderOptions.basis = {\n format: selectSupportedBasisFormat(),\n containerFormat: 'ktx2',\n module: 'encoder'\n };\n }\n\n this.textureDefinitionsSelectedFormats.push(selectedFormat);\n }\n }\n\n /**\n * Returns the array of supported texture format\n * @returns list of format strings\n */\n private getSupportedTextureFormats(): I3STextureFormat[] {\n const formats: I3STextureFormat[] = [];\n // @ts-expect-error this.options is not properly typed\n if (!this.options.i3s || this.options.i3s.useCompressedTextures) {\n // I3S 1.7 selection\n const supportedCompressedFormats = getSupportedGPUTextureFormats();\n // List of possible in i3s formats:\n // https://github.com/Esri/i3s-spec/blob/master/docs/1.7/textureSetDefinitionFormat.cmn.md\n if (supportedCompressedFormats.has('etc2')) {\n formats.push('ktx-etc2');\n }\n if (supportedCompressedFormats.has('dxt')) {\n formats.push('dds');\n }\n\n // I3S 1.8 selection\n // ktx2 wraps basis texture which at the edge case can be decoded as uncompressed image\n formats.push('ktx2');\n }\n\n formats.push('jpg');\n formats.push('png');\n return formats;\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,57 @@
1
+ import GL from '@luma.gl/constants';
2
+ import { DATA_TYPE } from '../../types';
3
+ export function getConstructorForDataFormat(dataType) {
4
+ switch (dataType) {
5
+ case DATA_TYPE.UInt8:
6
+ return Uint8Array;
7
+ case DATA_TYPE.UInt16:
8
+ return Uint16Array;
9
+ case DATA_TYPE.UInt32:
10
+ return Uint32Array;
11
+ case DATA_TYPE.Float32:
12
+ return Float32Array;
13
+ case DATA_TYPE.UInt64:
14
+ return Float64Array;
15
+ default:
16
+ throw new Error("parse i3s tile content: unknown type of data: ".concat(dataType));
17
+ }
18
+ }
19
+ export const GL_TYPE_MAP = {
20
+ UInt8: GL.UNSIGNED_BYTE,
21
+ UInt16: GL.UNSIGNED_SHORT,
22
+ Float32: GL.FLOAT,
23
+ UInt32: GL.UNSIGNED_INT,
24
+ UInt64: GL.DOUBLE
25
+ };
26
+ export function sizeOf(dataType) {
27
+ switch (dataType) {
28
+ case DATA_TYPE.UInt8:
29
+ return 1;
30
+ case DATA_TYPE.UInt16:
31
+ case DATA_TYPE.Int16:
32
+ return 2;
33
+ case DATA_TYPE.UInt32:
34
+ case DATA_TYPE.Int32:
35
+ case DATA_TYPE.Float32:
36
+ return 4;
37
+ case DATA_TYPE.UInt64:
38
+ case DATA_TYPE.Int64:
39
+ case DATA_TYPE.Float64:
40
+ return 8;
41
+ default:
42
+ throw new Error("parse i3s tile content: unknown size of data: ".concat(dataType));
43
+ }
44
+ }
45
+ export const STRING_ATTRIBUTE_TYPE = 'String';
46
+ export const OBJECT_ID_ATTRIBUTE_TYPE = 'Oid32';
47
+ export const FLOAT_64_TYPE = 'Float64';
48
+ export const INT_16_ATTRIBUTE_TYPE = 'Int16';
49
+ export let COORDINATE_SYSTEM = function (COORDINATE_SYSTEM) {
50
+ COORDINATE_SYSTEM[COORDINATE_SYSTEM["DEFAULT"] = -1] = "DEFAULT";
51
+ COORDINATE_SYSTEM[COORDINATE_SYSTEM["LNGLAT"] = 1] = "LNGLAT";
52
+ COORDINATE_SYSTEM[COORDINATE_SYSTEM["METER_OFFSETS"] = 2] = "METER_OFFSETS";
53
+ COORDINATE_SYSTEM[COORDINATE_SYSTEM["LNGLAT_OFFSETS"] = 3] = "LNGLAT_OFFSETS";
54
+ COORDINATE_SYSTEM[COORDINATE_SYSTEM["CARTESIAN"] = 0] = "CARTESIAN";
55
+ return COORDINATE_SYSTEM;
56
+ }({});
57
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","names":["GL","DATA_TYPE","getConstructorForDataFormat","dataType","UInt8","Uint8Array","UInt16","Uint16Array","UInt32","Uint32Array","Float32","Float32Array","UInt64","Float64Array","Error","concat","GL_TYPE_MAP","UNSIGNED_BYTE","UNSIGNED_SHORT","FLOAT","UNSIGNED_INT","DOUBLE","sizeOf","Int16","Int32","Int64","Float64","STRING_ATTRIBUTE_TYPE","OBJECT_ID_ATTRIBUTE_TYPE","FLOAT_64_TYPE","INT_16_ATTRIBUTE_TYPE","COORDINATE_SYSTEM"],"sources":["../../../../src/lib/parsers/constants.ts"],"sourcesContent":["import GL from '@luma.gl/constants';\nimport {DATA_TYPE} from '../../types';\n\nexport function getConstructorForDataFormat(dataType: string) {\n switch (dataType) {\n case DATA_TYPE.UInt8:\n return Uint8Array;\n case DATA_TYPE.UInt16:\n return Uint16Array;\n case DATA_TYPE.UInt32:\n return Uint32Array;\n case DATA_TYPE.Float32:\n return Float32Array;\n case DATA_TYPE.UInt64:\n return Float64Array;\n default:\n throw new Error(`parse i3s tile content: unknown type of data: ${dataType}`);\n }\n}\n\nexport const GL_TYPE_MAP: {[key: string]: number} = {\n UInt8: GL.UNSIGNED_BYTE,\n UInt16: GL.UNSIGNED_SHORT,\n Float32: GL.FLOAT,\n UInt32: GL.UNSIGNED_INT,\n UInt64: GL.DOUBLE\n};\n/**\n * Returns how many bytes a type occupies\n * @param dataType\n * @returns\n */\nexport function sizeOf(dataType: string): number {\n switch (dataType) {\n case DATA_TYPE.UInt8:\n return 1;\n case DATA_TYPE.UInt16:\n case DATA_TYPE.Int16:\n return 2;\n case DATA_TYPE.UInt32:\n case DATA_TYPE.Int32:\n case DATA_TYPE.Float32:\n return 4;\n case DATA_TYPE.UInt64:\n case DATA_TYPE.Int64:\n case DATA_TYPE.Float64:\n return 8;\n default:\n throw new Error(`parse i3s tile content: unknown size of data: ${dataType}`);\n }\n}\n\nexport const STRING_ATTRIBUTE_TYPE = 'String';\nexport const OBJECT_ID_ATTRIBUTE_TYPE = 'Oid32';\nexport const FLOAT_64_TYPE = 'Float64';\nexport const INT_16_ATTRIBUTE_TYPE = 'Int16';\n\n// https://github.com/visgl/deck.gl/blob/9548f43cba2234a1f4877b6b17f6c88eb35b2e08/modules/core/src/lib/constants.js#L27\n// Describes the format of positions\nexport enum COORDINATE_SYSTEM {\n /**\n * `LNGLAT` if rendering into a geospatial viewport, `CARTESIAN` otherwise\n */\n DEFAULT = -1,\n /**\n * Positions are interpreted as [lng, lat, elevation]\n * lng lat are degrees, elevation is meters. distances as meters.\n */\n LNGLAT = 1,\n /**\n * Positions are interpreted as meter offsets, distances as meters\n */\n METER_OFFSETS = 2,\n /**\n * Positions are interpreted as lng lat offsets: [deltaLng, deltaLat, elevation]\n * deltaLng, deltaLat are delta degrees, elevation is meters.\n * distances as meters.\n */\n LNGLAT_OFFSETS = 3,\n /**\n * Non-geospatial\n */\n CARTESIAN = 0\n}\n"],"mappings":"AAAA,OAAOA,EAAE,MAAM,oBAAoB;AACnC,SAAQC,SAAS,QAAO,aAAa;AAErC,OAAO,SAASC,2BAA2BA,CAACC,QAAgB,EAAE;EAC5D,QAAQA,QAAQ;IACd,KAAKF,SAAS,CAACG,KAAK;MAClB,OAAOC,UAAU;IACnB,KAAKJ,SAAS,CAACK,MAAM;MACnB,OAAOC,WAAW;IACpB,KAAKN,SAAS,CAACO,MAAM;MACnB,OAAOC,WAAW;IACpB,KAAKR,SAAS,CAACS,OAAO;MACpB,OAAOC,YAAY;IACrB,KAAKV,SAAS,CAACW,MAAM;MACnB,OAAOC,YAAY;IACrB;MACE,MAAM,IAAIC,KAAK,kDAAAC,MAAA,CAAkDZ,QAAQ,CAAE,CAAC;EAChF;AACF;AAEA,OAAO,MAAMa,WAAoC,GAAG;EAClDZ,KAAK,EAAEJ,EAAE,CAACiB,aAAa;EACvBX,MAAM,EAAEN,EAAE,CAACkB,cAAc;EACzBR,OAAO,EAAEV,EAAE,CAACmB,KAAK;EACjBX,MAAM,EAAER,EAAE,CAACoB,YAAY;EACvBR,MAAM,EAAEZ,EAAE,CAACqB;AACb,CAAC;AAMD,OAAO,SAASC,MAAMA,CAACnB,QAAgB,EAAU;EAC/C,QAAQA,QAAQ;IACd,KAAKF,SAAS,CAACG,KAAK;MAClB,OAAO,CAAC;IACV,KAAKH,SAAS,CAACK,MAAM;IACrB,KAAKL,SAAS,CAACsB,KAAK;MAClB,OAAO,CAAC;IACV,KAAKtB,SAAS,CAACO,MAAM;IACrB,KAAKP,SAAS,CAACuB,KAAK;IACpB,KAAKvB,SAAS,CAACS,OAAO;MACpB,OAAO,CAAC;IACV,KAAKT,SAAS,CAACW,MAAM;IACrB,KAAKX,SAAS,CAACwB,KAAK;IACpB,KAAKxB,SAAS,CAACyB,OAAO;MACpB,OAAO,CAAC;IACV;MACE,MAAM,IAAIZ,KAAK,kDAAAC,MAAA,CAAkDZ,QAAQ,CAAE,CAAC;EAChF;AACF;AAEA,OAAO,MAAMwB,qBAAqB,GAAG,QAAQ;AAC7C,OAAO,MAAMC,wBAAwB,GAAG,OAAO;AAC/C,OAAO,MAAMC,aAAa,GAAG,SAAS;AACtC,OAAO,MAAMC,qBAAqB,GAAG,OAAO;AAI5C,WAAYC,iBAAiB,aAAjBA,iBAAiB;EAAjBA,iBAAiB,CAAjBA,iBAAiB;EAAjBA,iBAAiB,CAAjBA,iBAAiB;EAAjBA,iBAAiB,CAAjBA,iBAAiB;EAAjBA,iBAAiB,CAAjBA,iBAAiB;EAAjBA,iBAAiB,CAAjBA,iBAAiB;EAAA,OAAjBA,iBAAiB;AAAA"}
@@ -0,0 +1,70 @@
1
+ import { JSONLoader, load } from '@loaders.gl/core';
2
+ const SUPPORTED_WKID = 4326;
3
+ const ARCGIS_SCENE_SERVER_LAYER_TYPE = 'ArcGISSceneServiceLayer';
4
+ const BUILDING_SCENE_LAYER = 'BuildingSceneLayer';
5
+ const INTEGRATED_MESH_LAYER = 'IntegratedMeshLayer';
6
+ const GROUP_LAYER = 'GroupLayer';
7
+ const SUPPORTED_LAYERS_TYPES = [ARCGIS_SCENE_SERVER_LAYER_TYPE, INTEGRATED_MESH_LAYER, BUILDING_SCENE_LAYER, GROUP_LAYER];
8
+ const NO_AVAILABLE_SUPPORTED_LAYERS_ERROR = 'NO_AVAILABLE_SUPPORTED_LAYERS_ERROR';
9
+ const NOT_SUPPORTED_CRS_ERROR = 'NOT_SUPPORTED_CRS_ERROR';
10
+ export async function parseWebscene(data) {
11
+ const layer0 = JSON.parse(new TextDecoder().decode(data));
12
+ const {
13
+ operationalLayers
14
+ } = layer0;
15
+ const {
16
+ layers,
17
+ unsupportedLayers
18
+ } = await parseOperationalLayers(operationalLayers, true);
19
+ if (!layers.length) {
20
+ throw new Error(NO_AVAILABLE_SUPPORTED_LAYERS_ERROR);
21
+ }
22
+ return {
23
+ header: layer0,
24
+ layers,
25
+ unsupportedLayers
26
+ };
27
+ }
28
+ async function parseOperationalLayers(layersList, needToCheckCRS) {
29
+ const layers = [];
30
+ let unsupportedLayers = [];
31
+ for (let index = 0; index < layersList.length; index++) {
32
+ var _layer$layers;
33
+ const layer = layersList[index];
34
+ const isLayerSupported = SUPPORTED_LAYERS_TYPES.includes(layer.layerType);
35
+ if (isLayerSupported) {
36
+ if (needToCheckCRS && layer.layerType !== GROUP_LAYER) {
37
+ await checkSupportedIndexCRS(layer);
38
+ needToCheckCRS = false;
39
+ }
40
+ layers.push(layer);
41
+ } else {
42
+ unsupportedLayers.push(layer);
43
+ }
44
+ if ((_layer$layers = layer.layers) !== null && _layer$layers !== void 0 && _layer$layers.length) {
45
+ const {
46
+ layers: childLayers,
47
+ unsupportedLayers: childUnsupportedLayers
48
+ } = await parseOperationalLayers(layer.layers, needToCheckCRS);
49
+ layer.layers = childLayers;
50
+ unsupportedLayers = [...unsupportedLayers, ...childUnsupportedLayers];
51
+ }
52
+ }
53
+ return {
54
+ layers,
55
+ unsupportedLayers
56
+ };
57
+ }
58
+ async function checkSupportedIndexCRS(layer) {
59
+ try {
60
+ var _layerJson$spatialRef;
61
+ const layerJson = await load(layer.url, JSONLoader);
62
+ const wkid = layerJson === null || layerJson === void 0 ? void 0 : (_layerJson$spatialRef = layerJson.spatialReference) === null || _layerJson$spatialRef === void 0 ? void 0 : _layerJson$spatialRef.wkid;
63
+ if (wkid !== SUPPORTED_WKID) {
64
+ throw new Error(NOT_SUPPORTED_CRS_ERROR);
65
+ }
66
+ } catch (error) {
67
+ throw error;
68
+ }
69
+ }
70
+ //# sourceMappingURL=parse-arcgis-webscene.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parse-arcgis-webscene.js","names":["JSONLoader","load","SUPPORTED_WKID","ARCGIS_SCENE_SERVER_LAYER_TYPE","BUILDING_SCENE_LAYER","INTEGRATED_MESH_LAYER","GROUP_LAYER","SUPPORTED_LAYERS_TYPES","NO_AVAILABLE_SUPPORTED_LAYERS_ERROR","NOT_SUPPORTED_CRS_ERROR","parseWebscene","data","layer0","JSON","parse","TextDecoder","decode","operationalLayers","layers","unsupportedLayers","parseOperationalLayers","length","Error","header","layersList","needToCheckCRS","index","_layer$layers","layer","isLayerSupported","includes","layerType","checkSupportedIndexCRS","push","childLayers","childUnsupportedLayers","_layerJson$spatialRef","layerJson","url","wkid","spatialReference","error"],"sources":["../../../../src/lib/parsers/parse-arcgis-webscene.ts"],"sourcesContent":["import {JSONLoader, load} from '@loaders.gl/core';\nimport type {ArcGisWebSceneData, OperationalLayer} from '../../types';\n\n/**\n * WKID, or Well-Known ID, of the CRS. Specify either WKID or WKT of the CRS.\n * Spec - https://github.com/Esri/i3s-spec/blob/master/docs/1.8/spatialReference.cmn.md\n */\nconst SUPPORTED_WKID = 4326;\n\nconst ARCGIS_SCENE_SERVER_LAYER_TYPE = 'ArcGISSceneServiceLayer';\nconst BUILDING_SCENE_LAYER = 'BuildingSceneLayer';\nconst INTEGRATED_MESH_LAYER = 'IntegratedMeshLayer';\nconst GROUP_LAYER = 'GroupLayer';\n\n/**\n * Supported layers list\n * Possible operational layers in WebScene: https://developers.arcgis.com/web-scene-specification/objects/operationalLayers/\n */\nconst SUPPORTED_LAYERS_TYPES = [\n ARCGIS_SCENE_SERVER_LAYER_TYPE,\n INTEGRATED_MESH_LAYER,\n BUILDING_SCENE_LAYER,\n GROUP_LAYER\n];\n\nconst NO_AVAILABLE_SUPPORTED_LAYERS_ERROR = 'NO_AVAILABLE_SUPPORTED_LAYERS_ERROR';\nconst NOT_SUPPORTED_CRS_ERROR = 'NOT_SUPPORTED_CRS_ERROR';\n\n/**\n * Parses ArcGIS WebScene\n * @param data\n */\nexport async function parseWebscene(data: ArrayBuffer): Promise<ArcGisWebSceneData> {\n const layer0 = JSON.parse(new TextDecoder().decode(data));\n const {operationalLayers} = layer0;\n const {layers, unsupportedLayers} = await parseOperationalLayers(operationalLayers, true);\n\n if (!layers.length) {\n throw new Error(NO_AVAILABLE_SUPPORTED_LAYERS_ERROR);\n }\n\n return {\n header: layer0,\n layers,\n unsupportedLayers\n };\n}\n\n/**\n * Recursively parses WebScene operational layers.\n * @param layersList\n */\nasync function parseOperationalLayers(\n layersList: OperationalLayer[],\n needToCheckCRS: boolean\n): Promise<{layers: OperationalLayer[]; unsupportedLayers: OperationalLayer[]}> {\n const layers: OperationalLayer[] = [];\n let unsupportedLayers: OperationalLayer[] = [];\n\n for (let index = 0; index < layersList.length; index++) {\n const layer = layersList[index];\n const isLayerSupported = SUPPORTED_LAYERS_TYPES.includes(layer.layerType);\n\n if (isLayerSupported) {\n if (needToCheckCRS && layer.layerType !== GROUP_LAYER) {\n await checkSupportedIndexCRS(layer);\n needToCheckCRS = false;\n }\n\n layers.push(layer);\n } else {\n unsupportedLayers.push(layer);\n }\n\n if (layer.layers?.length) {\n const {layers: childLayers, unsupportedLayers: childUnsupportedLayers} =\n await parseOperationalLayers(layer.layers, needToCheckCRS);\n layer.layers = childLayers;\n unsupportedLayers = [...unsupportedLayers, ...childUnsupportedLayers];\n }\n }\n\n return {layers, unsupportedLayers};\n}\n\n/**\n * Check if layer has supported CRS\n * @param layer\n */\nasync function checkSupportedIndexCRS(layer: OperationalLayer) {\n try {\n const layerJson = await load(layer.url, JSONLoader);\n // @ts-expect-error\n const wkid = layerJson?.spatialReference?.wkid;\n\n if (wkid !== SUPPORTED_WKID) {\n throw new Error(NOT_SUPPORTED_CRS_ERROR);\n }\n } catch (error) {\n throw error;\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,60 @@
1
+ import { STRING_ATTRIBUTE_TYPE, OBJECT_ID_ATTRIBUTE_TYPE, FLOAT_64_TYPE, INT_16_ATTRIBUTE_TYPE } from './constants';
2
+ export function parseI3STileAttribute(arrayBuffer, options) {
3
+ const {
4
+ attributeName,
5
+ attributeType
6
+ } = options;
7
+ if (!attributeName) {
8
+ return {};
9
+ }
10
+ return {
11
+ [attributeName]: attributeType ? parseAttribute(attributeType, arrayBuffer) : null
12
+ };
13
+ }
14
+ function parseAttribute(attributeType, arrayBuffer) {
15
+ switch (attributeType) {
16
+ case STRING_ATTRIBUTE_TYPE:
17
+ return parseStringsAttribute(arrayBuffer);
18
+ case OBJECT_ID_ATTRIBUTE_TYPE:
19
+ return parseShortNumberAttribute(arrayBuffer);
20
+ case FLOAT_64_TYPE:
21
+ return parseFloatAttribute(arrayBuffer);
22
+ case INT_16_ATTRIBUTE_TYPE:
23
+ return parseInt16ShortNumberAttribute(arrayBuffer);
24
+ default:
25
+ return parseShortNumberAttribute(arrayBuffer);
26
+ }
27
+ }
28
+ function parseShortNumberAttribute(arrayBuffer) {
29
+ const countOffset = 4;
30
+ return new Uint32Array(arrayBuffer, countOffset);
31
+ }
32
+ function parseInt16ShortNumberAttribute(arrayBuffer) {
33
+ const countOffset = 4;
34
+ return new Int16Array(arrayBuffer, countOffset);
35
+ }
36
+ function parseFloatAttribute(arrayBuffer) {
37
+ const countOffset = 8;
38
+ return new Float64Array(arrayBuffer, countOffset);
39
+ }
40
+ function parseStringsAttribute(arrayBuffer) {
41
+ const stringsCountOffset = 0;
42
+ const dataOffset = 8;
43
+ const bytesPerStringSize = 4;
44
+ const stringsArray = [];
45
+ try {
46
+ const stringsCount = new DataView(arrayBuffer, stringsCountOffset, bytesPerStringSize).getUint32(stringsCountOffset, true);
47
+ const stringSizes = new Uint32Array(arrayBuffer, dataOffset, stringsCount);
48
+ let stringOffset = dataOffset + stringsCount * bytesPerStringSize;
49
+ for (const stringByteSize of stringSizes) {
50
+ const textDecoder = new TextDecoder('utf-8');
51
+ const stringAttribute = new Uint8Array(arrayBuffer, stringOffset, stringByteSize);
52
+ stringsArray.push(textDecoder.decode(stringAttribute));
53
+ stringOffset += stringByteSize;
54
+ }
55
+ } catch (error) {
56
+ console.error('Parse string attribute error: ', error.message);
57
+ }
58
+ return stringsArray;
59
+ }
60
+ //# sourceMappingURL=parse-i3s-attribute.js.map