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

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 (217) hide show
  1. package/dist/cesium-ion-loader.d.ts.map +1 -1
  2. package/dist/cesium-ion-loader.js +1 -0
  3. package/dist/dist.min.js +2517 -299
  4. package/dist/es5/cesium-ion-loader.js +23 -27
  5. package/dist/es5/cesium-ion-loader.js.map +1 -1
  6. package/dist/es5/index.js.map +1 -1
  7. package/dist/es5/lib/classes/helpers/tile-3d-accessor-utils.js +0 -2
  8. package/dist/es5/lib/classes/helpers/tile-3d-accessor-utils.js.map +1 -1
  9. package/dist/es5/lib/classes/tile-3d-batch-table-hierarchy.js +0 -6
  10. package/dist/es5/lib/classes/tile-3d-batch-table-hierarchy.js.map +1 -1
  11. package/dist/es5/lib/classes/tile-3d-batch-table.js +2 -19
  12. package/dist/es5/lib/classes/tile-3d-batch-table.js.map +1 -1
  13. package/dist/es5/lib/classes/tile-3d-feature-table.js +1 -4
  14. package/dist/es5/lib/classes/tile-3d-feature-table.js.map +1 -1
  15. package/dist/es5/lib/constants.js +0 -2
  16. package/dist/es5/lib/constants.js.map +1 -1
  17. package/dist/es5/lib/encoders/encode-3d-tile-batched-model.js +0 -5
  18. package/dist/es5/lib/encoders/encode-3d-tile-batched-model.js.map +1 -1
  19. package/dist/es5/lib/encoders/encode-3d-tile-composite.js +0 -2
  20. package/dist/es5/lib/encoders/encode-3d-tile-composite.js.map +1 -1
  21. package/dist/es5/lib/encoders/encode-3d-tile-instanced-model.js +0 -3
  22. package/dist/es5/lib/encoders/encode-3d-tile-instanced-model.js.map +1 -1
  23. package/dist/es5/lib/encoders/encode-3d-tile-point-cloud.js +0 -3
  24. package/dist/es5/lib/encoders/encode-3d-tile-point-cloud.js.map +1 -1
  25. package/dist/es5/lib/encoders/encode-3d-tile.js +0 -1
  26. package/dist/es5/lib/encoders/encode-3d-tile.js.map +1 -1
  27. package/dist/es5/lib/encoders/helpers/encode-3d-tile-header.js +0 -3
  28. package/dist/es5/lib/encoders/helpers/encode-3d-tile-header.js.map +1 -1
  29. package/dist/es5/lib/ion/ion.js +109 -117
  30. package/dist/es5/lib/ion/ion.js.map +1 -1
  31. package/dist/es5/lib/parsers/helpers/normalize-3d-tile-colors.js +0 -3
  32. package/dist/es5/lib/parsers/helpers/normalize-3d-tile-colors.js.map +1 -1
  33. package/dist/es5/lib/parsers/helpers/normalize-3d-tile-normals.js.map +1 -1
  34. package/dist/es5/lib/parsers/helpers/normalize-3d-tile-positions.js +0 -3
  35. package/dist/es5/lib/parsers/helpers/normalize-3d-tile-positions.js.map +1 -1
  36. package/dist/es5/lib/parsers/helpers/parse-3d-implicit-tiles.js +161 -131
  37. package/dist/es5/lib/parsers/helpers/parse-3d-implicit-tiles.js.map +1 -1
  38. package/dist/es5/lib/parsers/helpers/parse-3d-tile-gltf-view.js +34 -42
  39. package/dist/es5/lib/parsers/helpers/parse-3d-tile-gltf-view.js.map +1 -1
  40. package/dist/es5/lib/parsers/helpers/parse-3d-tile-header.js +0 -3
  41. package/dist/es5/lib/parsers/helpers/parse-3d-tile-header.js.map +1 -1
  42. package/dist/es5/lib/parsers/helpers/parse-3d-tile-subtree.js +93 -100
  43. package/dist/es5/lib/parsers/helpers/parse-3d-tile-subtree.js.map +1 -1
  44. package/dist/es5/lib/parsers/helpers/parse-3d-tile-tables.js +0 -5
  45. package/dist/es5/lib/parsers/helpers/parse-3d-tile-tables.js.map +1 -1
  46. package/dist/es5/lib/parsers/helpers/parse-utils.js +0 -2
  47. package/dist/es5/lib/parsers/helpers/parse-utils.js.map +1 -1
  48. package/dist/es5/lib/parsers/parse-3d-tile-batched-model.js +14 -16
  49. package/dist/es5/lib/parsers/parse-3d-tile-batched-model.js.map +1 -1
  50. package/dist/es5/lib/parsers/parse-3d-tile-composite.js +24 -27
  51. package/dist/es5/lib/parsers/parse-3d-tile-composite.js.map +1 -1
  52. package/dist/es5/lib/parsers/parse-3d-tile-gltf.js +12 -14
  53. package/dist/es5/lib/parsers/parse-3d-tile-gltf.js.map +1 -1
  54. package/dist/es5/lib/parsers/parse-3d-tile-header.js +152 -148
  55. package/dist/es5/lib/parsers/parse-3d-tile-header.js.map +1 -1
  56. package/dist/es5/lib/parsers/parse-3d-tile-instanced-model.js +10 -22
  57. package/dist/es5/lib/parsers/parse-3d-tile-instanced-model.js.map +1 -1
  58. package/dist/es5/lib/parsers/parse-3d-tile-point-cloud.js +111 -119
  59. package/dist/es5/lib/parsers/parse-3d-tile-point-cloud.js.map +1 -1
  60. package/dist/es5/lib/parsers/parse-3d-tile.js +41 -44
  61. package/dist/es5/lib/parsers/parse-3d-tile.js.map +1 -1
  62. package/dist/es5/lib/utils/obb/s2-corners-to-obb.js +30 -0
  63. package/dist/es5/lib/utils/obb/s2-corners-to-obb.js.map +1 -0
  64. package/dist/es5/lib/utils/s2/converters/s2-to-boundary.js +44 -0
  65. package/dist/es5/lib/utils/s2/converters/s2-to-boundary.js.map +1 -0
  66. package/dist/es5/lib/utils/s2/converters/s2-to-obb-points.js +30 -0
  67. package/dist/es5/lib/utils/s2/converters/s2-to-obb-points.js.map +1 -0
  68. package/dist/es5/lib/utils/s2/converters/s2-to-region.js +52 -0
  69. package/dist/es5/lib/utils/s2/converters/s2-to-region.js.map +1 -0
  70. package/dist/es5/lib/utils/s2/index.js +90 -0
  71. package/dist/es5/lib/utils/s2/index.js.map +1 -0
  72. package/dist/es5/lib/utils/s2/s2-geometry-functions.js +19 -0
  73. package/dist/es5/lib/utils/s2/s2-geometry-functions.js.map +1 -0
  74. package/dist/es5/lib/utils/s2/s2-token-functions.js +41 -0
  75. package/dist/es5/lib/utils/s2/s2-token-functions.js.map +1 -0
  76. package/dist/es5/lib/utils/s2/s2geometry/s2-cell-utils.js +22 -0
  77. package/dist/es5/lib/utils/s2/s2geometry/s2-cell-utils.js.map +1 -0
  78. package/dist/es5/lib/utils/s2/s2geometry/s2-geometry.js +207 -0
  79. package/dist/es5/lib/utils/s2/s2geometry/s2-geometry.js.map +1 -0
  80. package/dist/es5/lib/utils/version.js +1 -1
  81. package/dist/es5/lib/utils/version.js.map +1 -1
  82. package/dist/es5/tile-3d-subtree-loader.js.map +1 -1
  83. package/dist/es5/tile-3d-writer.js.map +1 -1
  84. package/dist/es5/tiles-3d-loader.js +59 -65
  85. package/dist/es5/tiles-3d-loader.js.map +1 -1
  86. package/dist/esm/bundle.js +0 -1
  87. package/dist/esm/bundle.js.map +1 -1
  88. package/dist/esm/cesium-ion-loader.js +0 -2
  89. package/dist/esm/cesium-ion-loader.js.map +1 -1
  90. package/dist/esm/index.js +0 -4
  91. package/dist/esm/index.js.map +1 -1
  92. package/dist/esm/lib/classes/helpers/tile-3d-accessor-utils.js +0 -1
  93. package/dist/esm/lib/classes/helpers/tile-3d-accessor-utils.js.map +1 -1
  94. package/dist/esm/lib/classes/tile-3d-batch-table-hierarchy.js +0 -7
  95. package/dist/esm/lib/classes/tile-3d-batch-table-hierarchy.js.map +1 -1
  96. package/dist/esm/lib/classes/tile-3d-batch-table.js +0 -13
  97. package/dist/esm/lib/classes/tile-3d-batch-table.js.map +1 -1
  98. package/dist/esm/lib/classes/tile-3d-feature-table.js +0 -3
  99. package/dist/esm/lib/classes/tile-3d-feature-table.js.map +1 -1
  100. package/dist/esm/lib/constants.js +0 -3
  101. package/dist/esm/lib/constants.js.map +1 -1
  102. package/dist/esm/lib/encoders/encode-3d-tile-batched-model.js +0 -8
  103. package/dist/esm/lib/encoders/encode-3d-tile-batched-model.js.map +1 -1
  104. package/dist/esm/lib/encoders/encode-3d-tile-composite.js +0 -4
  105. package/dist/esm/lib/encoders/encode-3d-tile-composite.js.map +1 -1
  106. package/dist/esm/lib/encoders/encode-3d-tile-instanced-model.js +0 -6
  107. package/dist/esm/lib/encoders/encode-3d-tile-instanced-model.js.map +1 -1
  108. package/dist/esm/lib/encoders/encode-3d-tile-point-cloud.js +0 -5
  109. package/dist/esm/lib/encoders/encode-3d-tile-point-cloud.js.map +1 -1
  110. package/dist/esm/lib/encoders/encode-3d-tile.js +0 -2
  111. package/dist/esm/lib/encoders/encode-3d-tile.js.map +1 -1
  112. package/dist/esm/lib/encoders/helpers/encode-3d-tile-header.js +0 -3
  113. package/dist/esm/lib/encoders/helpers/encode-3d-tile-header.js.map +1 -1
  114. package/dist/esm/lib/ion/ion.js +0 -9
  115. package/dist/esm/lib/ion/ion.js.map +1 -1
  116. package/dist/esm/lib/parsers/helpers/normalize-3d-tile-colors.js +0 -4
  117. package/dist/esm/lib/parsers/helpers/normalize-3d-tile-colors.js.map +1 -1
  118. package/dist/esm/lib/parsers/helpers/normalize-3d-tile-normals.js.map +1 -1
  119. package/dist/esm/lib/parsers/helpers/normalize-3d-tile-positions.js +0 -4
  120. package/dist/esm/lib/parsers/helpers/normalize-3d-tile-positions.js.map +1 -1
  121. package/dist/esm/lib/parsers/helpers/parse-3d-implicit-tiles.js +50 -19
  122. package/dist/esm/lib/parsers/helpers/parse-3d-implicit-tiles.js.map +1 -1
  123. package/dist/esm/lib/parsers/helpers/parse-3d-tile-gltf-view.js +1 -8
  124. package/dist/esm/lib/parsers/helpers/parse-3d-tile-gltf-view.js.map +1 -1
  125. package/dist/esm/lib/parsers/helpers/parse-3d-tile-header.js +0 -4
  126. package/dist/esm/lib/parsers/helpers/parse-3d-tile-header.js.map +1 -1
  127. package/dist/esm/lib/parsers/helpers/parse-3d-tile-subtree.js +0 -6
  128. package/dist/esm/lib/parsers/helpers/parse-3d-tile-subtree.js.map +1 -1
  129. package/dist/esm/lib/parsers/helpers/parse-3d-tile-tables.js +0 -6
  130. package/dist/esm/lib/parsers/helpers/parse-3d-tile-tables.js.map +1 -1
  131. package/dist/esm/lib/parsers/helpers/parse-utils.js +0 -4
  132. package/dist/esm/lib/parsers/helpers/parse-utils.js.map +1 -1
  133. package/dist/esm/lib/parsers/parse-3d-tile-batched-model.js +0 -3
  134. package/dist/esm/lib/parsers/parse-3d-tile-batched-model.js.map +1 -1
  135. package/dist/esm/lib/parsers/parse-3d-tile-composite.js +0 -6
  136. package/dist/esm/lib/parsers/parse-3d-tile-composite.js.map +1 -1
  137. package/dist/esm/lib/parsers/parse-3d-tile-gltf.js.map +1 -1
  138. package/dist/esm/lib/parsers/parse-3d-tile-header.js +13 -6
  139. package/dist/esm/lib/parsers/parse-3d-tile-header.js.map +1 -1
  140. package/dist/esm/lib/parsers/parse-3d-tile-instanced-model.js +0 -12
  141. package/dist/esm/lib/parsers/parse-3d-tile-instanced-model.js.map +1 -1
  142. package/dist/esm/lib/parsers/parse-3d-tile-point-cloud.js +0 -6
  143. package/dist/esm/lib/parsers/parse-3d-tile-point-cloud.js.map +1 -1
  144. package/dist/esm/lib/parsers/parse-3d-tile.js +0 -4
  145. package/dist/esm/lib/parsers/parse-3d-tile.js.map +1 -1
  146. package/dist/esm/lib/utils/obb/s2-corners-to-obb.js +23 -0
  147. package/dist/esm/lib/utils/obb/s2-corners-to-obb.js.map +1 -0
  148. package/dist/esm/lib/utils/s2/converters/s2-to-boundary.js +40 -0
  149. package/dist/esm/lib/utils/s2/converters/s2-to-boundary.js.map +1 -0
  150. package/dist/esm/lib/utils/s2/converters/s2-to-obb-points.js +24 -0
  151. package/dist/esm/lib/utils/s2/converters/s2-to-obb-points.js.map +1 -0
  152. package/dist/esm/lib/utils/s2/converters/s2-to-region.js +42 -0
  153. package/dist/esm/lib/utils/s2/converters/s2-to-region.js.map +1 -0
  154. package/dist/esm/lib/utils/s2/index.js +7 -0
  155. package/dist/esm/lib/utils/s2/index.js.map +1 -0
  156. package/dist/esm/lib/utils/s2/s2-geometry-functions.js +12 -0
  157. package/dist/esm/lib/utils/s2/s2-geometry-functions.js.map +1 -0
  158. package/dist/esm/lib/utils/s2/s2-token-functions.js +32 -0
  159. package/dist/esm/lib/utils/s2/s2-token-functions.js.map +1 -0
  160. package/dist/esm/lib/utils/s2/s2geometry/s2-cell-utils.js +15 -0
  161. package/dist/esm/lib/utils/s2/s2geometry/s2-cell-utils.js.map +1 -0
  162. package/dist/esm/lib/utils/s2/s2geometry/s2-geometry.js +186 -0
  163. package/dist/esm/lib/utils/s2/s2geometry/s2-geometry.js.map +1 -0
  164. package/dist/esm/lib/utils/version.js +1 -2
  165. package/dist/esm/lib/utils/version.js.map +1 -1
  166. package/dist/esm/tile-3d-subtree-loader.js +0 -1
  167. package/dist/esm/tile-3d-subtree-loader.js.map +1 -1
  168. package/dist/esm/tile-3d-writer.js +0 -1
  169. package/dist/esm/tile-3d-writer.js.map +1 -1
  170. package/dist/esm/tiles-3d-loader.js +0 -1
  171. package/dist/esm/tiles-3d-loader.js.map +1 -1
  172. package/dist/lib/parsers/helpers/parse-3d-implicit-tiles.d.ts +11 -0
  173. package/dist/lib/parsers/helpers/parse-3d-implicit-tiles.d.ts.map +1 -1
  174. package/dist/lib/parsers/helpers/parse-3d-implicit-tiles.js +60 -11
  175. package/dist/lib/parsers/parse-3d-tile-batched-model.js +1 -1
  176. package/dist/lib/parsers/parse-3d-tile-header.d.ts.map +1 -1
  177. package/dist/lib/parsers/parse-3d-tile-header.js +13 -1
  178. package/dist/lib/utils/obb/s2-corners-to-obb.d.ts +15 -0
  179. package/dist/lib/utils/obb/s2-corners-to-obb.d.ts.map +1 -0
  180. package/dist/lib/utils/obb/s2-corners-to-obb.js +37 -0
  181. package/dist/lib/utils/s2/converters/s2-to-boundary.d.ts +9 -0
  182. package/dist/lib/utils/s2/converters/s2-to-boundary.d.ts.map +1 -0
  183. package/dist/lib/utils/s2/converters/s2-to-boundary.js +61 -0
  184. package/dist/lib/utils/s2/converters/s2-to-obb-points.d.ts +15 -0
  185. package/dist/lib/utils/s2/converters/s2-to-obb-points.d.ts.map +1 -0
  186. package/dist/lib/utils/s2/converters/s2-to-obb-points.js +36 -0
  187. package/dist/lib/utils/s2/converters/s2-to-region.d.ts +13 -0
  188. package/dist/lib/utils/s2/converters/s2-to-region.d.ts.map +1 -0
  189. package/dist/lib/utils/s2/converters/s2-to-region.js +59 -0
  190. package/dist/lib/utils/s2/index.d.ts +8 -0
  191. package/dist/lib/utils/s2/index.d.ts.map +1 -0
  192. package/dist/lib/utils/s2/index.js +23 -0
  193. package/dist/lib/utils/s2/s2-geometry-functions.d.ts +14 -0
  194. package/dist/lib/utils/s2/s2-geometry-functions.d.ts.map +1 -0
  195. package/dist/lib/utils/s2/s2-geometry-functions.js +29 -0
  196. package/dist/lib/utils/s2/s2-token-functions.d.ts +23 -0
  197. package/dist/lib/utils/s2/s2-token-functions.d.ts.map +1 -0
  198. package/dist/lib/utils/s2/s2-token-functions.js +68 -0
  199. package/dist/lib/utils/s2/s2geometry/s2-cell-utils.d.ts +14 -0
  200. package/dist/lib/utils/s2/s2geometry/s2-cell-utils.d.ts.map +1 -0
  201. package/dist/lib/utils/s2/s2geometry/s2-cell-utils.js +32 -0
  202. package/dist/lib/utils/s2/s2geometry/s2-geometry.d.ts +52 -0
  203. package/dist/lib/utils/s2/s2geometry/s2-geometry.d.ts.map +1 -0
  204. package/dist/lib/utils/s2/s2geometry/s2-geometry.js +260 -0
  205. package/package.json +9 -8
  206. package/src/cesium-ion-loader.ts +1 -0
  207. package/src/lib/parsers/helpers/parse-3d-implicit-tiles.ts +102 -13
  208. package/src/lib/parsers/parse-3d-tile-header.ts +17 -1
  209. package/src/lib/utils/obb/s2-corners-to-obb.ts +51 -0
  210. package/src/lib/utils/s2/converters/s2-to-boundary.ts +67 -0
  211. package/src/lib/utils/s2/converters/s2-to-obb-points.ts +46 -0
  212. package/src/lib/utils/s2/converters/s2-to-region.ts +69 -0
  213. package/src/lib/utils/s2/index.ts +17 -0
  214. package/src/lib/utils/s2/s2-geometry-functions.ts +28 -0
  215. package/src/lib/utils/s2/s2-token-functions.ts +67 -0
  216. package/src/lib/utils/s2/s2geometry/s2-cell-utils.ts +33 -0
  217. package/src/lib/utils/s2/s2geometry/s2-geometry.ts +296 -0
@@ -1 +1 @@
1
- {"version":3,"file":"parse-3d-tile-composite.js","names":["parseComposite3DTile","tile","arrayBuffer","byteOffset","options","context","parse3DTile","parse3DTileHeaderSync","view","DataView","tilesLength","getUint32","tiles","length","byteLength","subtile","push"],"sources":["../../../../src/lib/parsers/parse-3d-tile-composite.ts"],"sourcesContent":["// This file is derived from the Cesium code base under Apache 2 license\n// See LICENSE.md and https://github.com/AnalyticalGraphicsInc/cesium/blob/master/LICENSE.md\n\n// Reference code:\n// https://github.com/AnalyticalGraphicsInc/cesium/blob/master/Source/Scene/Composite3DTileContent.js#L182\n\nimport {parse3DTileHeaderSync} from './helpers/parse-3d-tile-header';\n\n// eslint-disable-next-line max-params\nexport async function parseComposite3DTile(\n tile,\n arrayBuffer,\n byteOffset,\n options,\n context,\n parse3DTile\n) {\n byteOffset = parse3DTileHeaderSync(tile, arrayBuffer, byteOffset);\n\n const view = new DataView(arrayBuffer);\n\n // Extract number of tiles\n tile.tilesLength = view.getUint32(byteOffset, true);\n byteOffset += 4;\n\n // extract each tile from the byte stream\n tile.tiles = [];\n while (tile.tiles.length < tile.tilesLength && tile.byteLength - byteOffset > 12) {\n const subtile = {};\n tile.tiles.push(subtile);\n byteOffset = await parse3DTile(arrayBuffer, byteOffset, options, context, subtile);\n // TODO - do we need to add any padding in between tiles?\n }\n\n return byteOffset;\n}\n"],"mappings":";;;;;;;;;AAMA;AAAqE,SAG/CA,oBAAoB;EAAA;AAAA;AAAA;EAAA,kFAAnC,iBACLC,IAAI,EACJC,WAAW,EACXC,UAAU,EACVC,OAAO,EACPC,OAAO,EACPC,WAAW;IAAA;IAAA;MAAA;QAAA;UAAA;YAEXH,UAAU,GAAG,IAAAI,wCAAqB,EAACN,IAAI,EAAEC,WAAW,EAAEC,UAAU,CAAC;YAE3DK,IAAI,GAAG,IAAIC,QAAQ,CAACP,WAAW,CAAC;YAGtCD,IAAI,CAACS,WAAW,GAAGF,IAAI,CAACG,SAAS,CAACR,UAAU,EAAE,IAAI,CAAC;YACnDA,UAAU,IAAI,CAAC;;YAGfF,IAAI,CAACW,KAAK,GAAG,EAAE;UAAC;YAAA,MACTX,IAAI,CAACW,KAAK,CAACC,MAAM,GAAGZ,IAAI,CAACS,WAAW,IAAIT,IAAI,CAACa,UAAU,GAAGX,UAAU,GAAG,EAAE;cAAA;cAAA;YAAA;YACxEY,OAAO,GAAG,CAAC,CAAC;YAClBd,IAAI,CAACW,KAAK,CAACI,IAAI,CAACD,OAAO,CAAC;YAAC;YAAA,OACNT,WAAW,CAACJ,WAAW,EAAEC,UAAU,EAAEC,OAAO,EAAEC,OAAO,EAAEU,OAAO,CAAC;UAAA;YAAlFZ,UAAU;YAAA;YAAA;UAAA;YAAA,iCAILA,UAAU;UAAA;UAAA;YAAA;QAAA;MAAA;IAAA;EAAA,CAClB;EAAA;AAAA"}
1
+ {"version":3,"file":"parse-3d-tile-composite.js","names":["_parse3dTileHeader","require","parseComposite3DTile","_x","_x2","_x3","_x4","_x5","_x6","_parseComposite3DTile","apply","arguments","_asyncToGenerator2","default","_regenerator","mark","_callee","tile","arrayBuffer","byteOffset","options","context","parse3DTile","view","subtile","wrap","_callee$","_context","prev","next","parse3DTileHeaderSync","DataView","tilesLength","getUint32","tiles","length","byteLength","push","sent","abrupt","stop"],"sources":["../../../../src/lib/parsers/parse-3d-tile-composite.ts"],"sourcesContent":["// This file is derived from the Cesium code base under Apache 2 license\n// See LICENSE.md and https://github.com/AnalyticalGraphicsInc/cesium/blob/master/LICENSE.md\n\n// Reference code:\n// https://github.com/AnalyticalGraphicsInc/cesium/blob/master/Source/Scene/Composite3DTileContent.js#L182\n\nimport {parse3DTileHeaderSync} from './helpers/parse-3d-tile-header';\n\n// eslint-disable-next-line max-params\nexport async function parseComposite3DTile(\n tile,\n arrayBuffer,\n byteOffset,\n options,\n context,\n parse3DTile\n) {\n byteOffset = parse3DTileHeaderSync(tile, arrayBuffer, byteOffset);\n\n const view = new DataView(arrayBuffer);\n\n // Extract number of tiles\n tile.tilesLength = view.getUint32(byteOffset, true);\n byteOffset += 4;\n\n // extract each tile from the byte stream\n tile.tiles = [];\n while (tile.tiles.length < tile.tilesLength && tile.byteLength - byteOffset > 12) {\n const subtile = {};\n tile.tiles.push(subtile);\n byteOffset = await parse3DTile(arrayBuffer, byteOffset, options, context, subtile);\n // TODO - do we need to add any padding in between tiles?\n }\n\n return byteOffset;\n}\n"],"mappings":";;;;;;;;;AAMA,IAAAA,kBAAA,GAAAC,OAAA;AAAqE,SAG/CC,oBAAoBA,CAAAC,EAAA,EAAAC,GAAA,EAAAC,GAAA,EAAAC,GAAA,EAAAC,GAAA,EAAAC,GAAA;EAAA,OAAAC,qBAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA;AAAA,SAAAF,sBAAA;EAAAA,qBAAA,OAAAG,kBAAA,CAAAC,OAAA,EAAAC,YAAA,CAAAD,OAAA,CAAAE,IAAA,CAAnC,SAAAC,QACLC,IAAI,EACJC,WAAW,EACXC,UAAU,EACVC,OAAO,EACPC,OAAO,EACPC,WAAW;IAAA,IAAAC,IAAA,EAAAC,OAAA;IAAA,OAAAV,YAAA,CAAAD,OAAA,CAAAY,IAAA,UAAAC,SAAAC,QAAA;MAAA,kBAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAE,IAAA;QAAA;UAEXV,UAAU,GAAG,IAAAW,wCAAqB,EAACb,IAAI,EAAEC,WAAW,EAAEC,UAAU,CAAC;UAE3DI,IAAI,GAAG,IAAIQ,QAAQ,CAACb,WAAW,CAAC;UAGtCD,IAAI,CAACe,WAAW,GAAGT,IAAI,CAACU,SAAS,CAACd,UAAU,EAAE,IAAI,CAAC;UACnDA,UAAU,IAAI,CAAC;UAGfF,IAAI,CAACiB,KAAK,GAAG,EAAE;QAAC;UAAA,MACTjB,IAAI,CAACiB,KAAK,CAACC,MAAM,GAAGlB,IAAI,CAACe,WAAW,IAAIf,IAAI,CAACmB,UAAU,GAAGjB,UAAU,GAAG,EAAE;YAAAQ,QAAA,CAAAE,IAAA;YAAA;UAAA;UACxEL,OAAO,GAAG,CAAC,CAAC;UAClBP,IAAI,CAACiB,KAAK,CAACG,IAAI,CAACb,OAAO,CAAC;UAACG,QAAA,CAAAE,IAAA;UAAA,OACNP,WAAW,CAACJ,WAAW,EAAEC,UAAU,EAAEC,OAAO,EAAEC,OAAO,EAAEG,OAAO,CAAC;QAAA;UAAlFL,UAAU,GAAAQ,QAAA,CAAAW,IAAA;UAAAX,QAAA,CAAAE,IAAA;UAAA;QAAA;UAAA,OAAAF,QAAA,CAAAY,MAAA,WAILpB,UAAU;QAAA;QAAA;UAAA,OAAAQ,QAAA,CAAAa,IAAA;MAAA;IAAA,GAAAxB,OAAA;EAAA,CAClB;EAAA,OAAAP,qBAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA"}
@@ -15,20 +15,18 @@ function _parseGltf3DTile() {
15
15
  _parseGltf3DTile = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(tile, arrayBuffer, options, context) {
16
16
  var parse;
17
17
  return _regenerator.default.wrap(function _callee$(_context) {
18
- while (1) {
19
- switch (_context.prev = _context.next) {
20
- case 0:
21
- tile.rotateYtoZ = true;
22
- tile.gltfUpAxis = options['3d-tiles'] && options['3d-tiles'].assetGltfUpAxis ? options['3d-tiles'].assetGltfUpAxis : 'Y';
23
- parse = context.parse;
24
- _context.next = 5;
25
- return parse(arrayBuffer, _gltf.GLTFLoader, options, context);
26
- case 5:
27
- tile.gltf = _context.sent;
28
- case 6:
29
- case "end":
30
- return _context.stop();
31
- }
18
+ while (1) switch (_context.prev = _context.next) {
19
+ case 0:
20
+ tile.rotateYtoZ = true;
21
+ tile.gltfUpAxis = options['3d-tiles'] && options['3d-tiles'].assetGltfUpAxis ? options['3d-tiles'].assetGltfUpAxis : 'Y';
22
+ parse = context.parse;
23
+ _context.next = 5;
24
+ return parse(arrayBuffer, _gltf.GLTFLoader, options, context);
25
+ case 5:
26
+ tile.gltf = _context.sent;
27
+ case 6:
28
+ case "end":
29
+ return _context.stop();
32
30
  }
33
31
  }, _callee);
34
32
  }));
@@ -1 +1 @@
1
- {"version":3,"file":"parse-3d-tile-gltf.js","names":["parseGltf3DTile","tile","arrayBuffer","options","context","rotateYtoZ","gltfUpAxis","assetGltfUpAxis","parse","GLTFLoader","gltf"],"sources":["../../../../src/lib/parsers/parse-3d-tile-gltf.ts"],"sourcesContent":["import {GLTFLoader} from '@loaders.gl/gltf';\n\nexport async function parseGltf3DTile(tile, arrayBuffer, options, context) {\n // Set flags\n // glTF models need to be rotated from Y to Z up\n // https://github.com/AnalyticalGraphicsInc/3d-tiles/tree/master/specification#y-up-to-z-up\n tile.rotateYtoZ = true;\n // Save gltf up axis\n tile.gltfUpAxis =\n options['3d-tiles'] && options['3d-tiles'].assetGltfUpAxis\n ? options['3d-tiles'].assetGltfUpAxis\n : 'Y';\n\n const {parse} = context;\n tile.gltf = await parse(arrayBuffer, GLTFLoader, options, context);\n}\n"],"mappings":";;;;;;;;;AAAA;AAA4C,SAEtBA,eAAe;EAAA;AAAA;AAAA;EAAA,6EAA9B,iBAA+BC,IAAI,EAAEC,WAAW,EAAEC,OAAO,EAAEC,OAAO;IAAA;IAAA;MAAA;QAAA;UAAA;YAIvEH,IAAI,CAACI,UAAU,GAAG,IAAI;YAEtBJ,IAAI,CAACK,UAAU,GACbH,OAAO,CAAC,UAAU,CAAC,IAAIA,OAAO,CAAC,UAAU,CAAC,CAACI,eAAe,GACtDJ,OAAO,CAAC,UAAU,CAAC,CAACI,eAAe,GACnC,GAAG;YAEFC,KAAK,GAAIJ,OAAO,CAAhBI,KAAK;YAAA;YAAA,OACMA,KAAK,CAACN,WAAW,EAAEO,gBAAU,EAAEN,OAAO,EAAEC,OAAO,CAAC;UAAA;YAAlEH,IAAI,CAACS,IAAI;UAAA;UAAA;YAAA;QAAA;MAAA;IAAA;EAAA,CACV;EAAA;AAAA"}
1
+ {"version":3,"file":"parse-3d-tile-gltf.js","names":["_gltf","require","parseGltf3DTile","_x","_x2","_x3","_x4","_parseGltf3DTile","apply","arguments","_asyncToGenerator2","default","_regenerator","mark","_callee","tile","arrayBuffer","options","context","parse","wrap","_callee$","_context","prev","next","rotateYtoZ","gltfUpAxis","assetGltfUpAxis","GLTFLoader","gltf","sent","stop"],"sources":["../../../../src/lib/parsers/parse-3d-tile-gltf.ts"],"sourcesContent":["import {GLTFLoader} from '@loaders.gl/gltf';\n\nexport async function parseGltf3DTile(tile, arrayBuffer, options, context) {\n // Set flags\n // glTF models need to be rotated from Y to Z up\n // https://github.com/AnalyticalGraphicsInc/3d-tiles/tree/master/specification#y-up-to-z-up\n tile.rotateYtoZ = true;\n // Save gltf up axis\n tile.gltfUpAxis =\n options['3d-tiles'] && options['3d-tiles'].assetGltfUpAxis\n ? options['3d-tiles'].assetGltfUpAxis\n : 'Y';\n\n const {parse} = context;\n tile.gltf = await parse(arrayBuffer, GLTFLoader, options, context);\n}\n"],"mappings":";;;;;;;;;AAAA,IAAAA,KAAA,GAAAC,OAAA;AAA4C,SAEtBC,eAAeA,CAAAC,EAAA,EAAAC,GAAA,EAAAC,GAAA,EAAAC,GAAA;EAAA,OAAAC,gBAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA;AAAA,SAAAF,iBAAA;EAAAA,gBAAA,OAAAG,kBAAA,CAAAC,OAAA,EAAAC,YAAA,CAAAD,OAAA,CAAAE,IAAA,CAA9B,SAAAC,QAA+BC,IAAI,EAAEC,WAAW,EAAEC,OAAO,EAAEC,OAAO;IAAA,IAAAC,KAAA;IAAA,OAAAP,YAAA,CAAAD,OAAA,CAAAS,IAAA,UAAAC,SAAAC,QAAA;MAAA,kBAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAE,IAAA;QAAA;UAIvET,IAAI,CAACU,UAAU,GAAG,IAAI;UAEtBV,IAAI,CAACW,UAAU,GACbT,OAAO,CAAC,UAAU,CAAC,IAAIA,OAAO,CAAC,UAAU,CAAC,CAACU,eAAe,GACtDV,OAAO,CAAC,UAAU,CAAC,CAACU,eAAe,GACnC,GAAG;UAEFR,KAAK,GAAID,OAAO,CAAhBC,KAAK;UAAAG,QAAA,CAAAE,IAAA;UAAA,OACML,KAAK,CAACH,WAAW,EAAEY,gBAAU,EAAEX,OAAO,EAAEC,OAAO,CAAC;QAAA;UAAlEH,IAAI,CAACc,IAAI,GAAAP,QAAA,CAAAQ,IAAA;QAAA;QAAA;UAAA,OAAAR,QAAA,CAAAS,IAAA;MAAA;IAAA,GAAAjB,OAAA;EAAA,CACV;EAAA,OAAAP,gBAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA"}
@@ -14,9 +14,10 @@ var _tile3dSubtreeLoader = require("../../tile-3d-subtree-loader");
14
14
  var _core = require("@loaders.gl/core");
15
15
  var _tiles = require("@loaders.gl/tiles");
16
16
  var _parse3dImplicitTiles = require("./helpers/parse-3d-implicit-tiles");
17
+ var _s2CornersToObb = require("../utils/obb/s2-corners-to-obb");
17
18
  function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
18
19
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
19
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
20
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
20
21
  function getTileType(tile) {
21
22
  if (!tile.contentUrl) {
22
23
  return _tiles.TILE_TYPE.EMPTY;
@@ -73,7 +74,6 @@ function normalizeTileData(tile, options) {
73
74
  tile.refine = getRefine(tile.refine);
74
75
  return tile;
75
76
  }
76
-
77
77
  function normalizeTileHeaders(_x, _x2) {
78
78
  return _normalizeTileHeaders.apply(this, arguments);
79
79
  }
@@ -81,82 +81,80 @@ function _normalizeTileHeaders() {
81
81
  _normalizeTileHeaders = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(tileset, options) {
82
82
  var basePath, root, rootImplicitTilingExtension, stack, tile, children, _iterator, _step, childHeader, childImplicitTilingExtension;
83
83
  return _regenerator.default.wrap(function _callee$(_context) {
84
- while (1) {
85
- switch (_context.prev = _context.next) {
86
- case 0:
87
- basePath = tileset.basePath;
88
- rootImplicitTilingExtension = getImplicitTilingExtensionData(tileset === null || tileset === void 0 ? void 0 : tileset.root);
89
- if (!(rootImplicitTilingExtension && tileset.root)) {
90
- _context.next = 8;
91
- break;
92
- }
93
- _context.next = 5;
94
- return normalizeImplicitTileHeaders(tileset.root, tileset, rootImplicitTilingExtension, options);
95
- case 5:
96
- root = _context.sent;
97
- _context.next = 9;
98
- break;
99
- case 8:
100
- root = normalizeTileData(tileset.root, tileset);
101
- case 9:
102
- stack = [];
103
- stack.push(root);
104
- case 11:
105
- if (!(stack.length > 0)) {
106
- _context.next = 40;
107
- break;
108
- }
109
- tile = stack.pop() || {};
110
- children = tile.children || [];
111
- _iterator = _createForOfIteratorHelper(children);
112
- _context.prev = 15;
113
- _iterator.s();
114
- case 17:
115
- if ((_step = _iterator.n()).done) {
116
- _context.next = 30;
117
- break;
118
- }
119
- childHeader = _step.value;
120
- childImplicitTilingExtension = getImplicitTilingExtensionData(childHeader);
121
- if (!childImplicitTilingExtension) {
122
- _context.next = 26;
123
- break;
124
- }
125
- _context.next = 23;
126
- return normalizeImplicitTileHeaders(childHeader, tileset, childImplicitTilingExtension, options);
127
- case 23:
128
- childHeader = _context.sent;
129
- _context.next = 27;
84
+ while (1) switch (_context.prev = _context.next) {
85
+ case 0:
86
+ basePath = tileset.basePath;
87
+ rootImplicitTilingExtension = getImplicitTilingExtensionData(tileset === null || tileset === void 0 ? void 0 : tileset.root);
88
+ if (!(rootImplicitTilingExtension && tileset.root)) {
89
+ _context.next = 8;
130
90
  break;
131
- case 26:
132
- normalizeTileData(childHeader, {
133
- basePath: basePath
134
- });
135
- case 27:
136
- stack.push(childHeader);
137
- case 28:
138
- _context.next = 17;
91
+ }
92
+ _context.next = 5;
93
+ return normalizeImplicitTileHeaders(tileset.root, tileset, rootImplicitTilingExtension, options);
94
+ case 5:
95
+ root = _context.sent;
96
+ _context.next = 9;
97
+ break;
98
+ case 8:
99
+ root = normalizeTileData(tileset.root, tileset);
100
+ case 9:
101
+ stack = [];
102
+ stack.push(root);
103
+ case 11:
104
+ if (!(stack.length > 0)) {
105
+ _context.next = 40;
139
106
  break;
140
- case 30:
141
- _context.next = 35;
107
+ }
108
+ tile = stack.pop() || {};
109
+ children = tile.children || [];
110
+ _iterator = _createForOfIteratorHelper(children);
111
+ _context.prev = 15;
112
+ _iterator.s();
113
+ case 17:
114
+ if ((_step = _iterator.n()).done) {
115
+ _context.next = 30;
142
116
  break;
143
- case 32:
144
- _context.prev = 32;
145
- _context.t0 = _context["catch"](15);
146
- _iterator.e(_context.t0);
147
- case 35:
148
- _context.prev = 35;
149
- _iterator.f();
150
- return _context.finish(35);
151
- case 38:
152
- _context.next = 11;
117
+ }
118
+ childHeader = _step.value;
119
+ childImplicitTilingExtension = getImplicitTilingExtensionData(childHeader);
120
+ if (!childImplicitTilingExtension) {
121
+ _context.next = 26;
153
122
  break;
154
- case 40:
155
- return _context.abrupt("return", root);
156
- case 41:
157
- case "end":
158
- return _context.stop();
159
- }
123
+ }
124
+ _context.next = 23;
125
+ return normalizeImplicitTileHeaders(childHeader, tileset, childImplicitTilingExtension, options);
126
+ case 23:
127
+ childHeader = _context.sent;
128
+ _context.next = 27;
129
+ break;
130
+ case 26:
131
+ normalizeTileData(childHeader, {
132
+ basePath: basePath
133
+ });
134
+ case 27:
135
+ stack.push(childHeader);
136
+ case 28:
137
+ _context.next = 17;
138
+ break;
139
+ case 30:
140
+ _context.next = 35;
141
+ break;
142
+ case 32:
143
+ _context.prev = 32;
144
+ _context.t0 = _context["catch"](15);
145
+ _iterator.e(_context.t0);
146
+ case 35:
147
+ _context.prev = 35;
148
+ _iterator.f();
149
+ return _context.finish(35);
150
+ case 38:
151
+ _context.next = 11;
152
+ break;
153
+ case 40:
154
+ return _context.abrupt("return", root);
155
+ case 41:
156
+ case "end":
157
+ return _context.stop();
160
158
  }
161
159
  }, _callee, null, [[15, 32, 35, 38]]);
162
160
  }));
@@ -167,46 +165,53 @@ function normalizeImplicitTileHeaders(_x3, _x4, _x5, _x6) {
167
165
  }
168
166
  function _normalizeImplicitTileHeaders() {
169
167
  _normalizeImplicitTileHeaders = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(tile, tileset, implicitTilingExtension, options) {
170
- var _tileset$root;
171
- var basePath, subdivisionScheme, maximumLevel, subtreeLevels, subtreesUriTemplate, replacedUrlTemplate, subtreeUrl, subtree, contentUrlTemplate, refine, rootLodMetricValue, rootBoundingVolume, implicitOptions;
168
+ var _tileset$root, _tile$boundingVolume$;
169
+ var basePath, subdivisionScheme, maximumLevel, subtreeLevels, subtreesUriTemplate, replacedUrlTemplate, subtreeUrl, subtree, contentUrlTemplate, refine, rootLodMetricValue, s2VolumeInfo, box, s2VolumeBox, rootBoundingVolume, implicitOptions;
172
170
  return _regenerator.default.wrap(function _callee2$(_context2) {
173
- while (1) {
174
- switch (_context2.prev = _context2.next) {
175
- case 0:
176
- basePath = tileset.basePath;
177
- subdivisionScheme = implicitTilingExtension.subdivisionScheme, maximumLevel = implicitTilingExtension.maximumLevel, subtreeLevels = implicitTilingExtension.subtreeLevels, subtreesUriTemplate = implicitTilingExtension.subtrees.uri;
178
- replacedUrlTemplate = (0, _parse3dImplicitTiles.replaceContentUrlTemplate)(subtreesUriTemplate, 0, 0, 0, 0);
179
- subtreeUrl = resolveUri(replacedUrlTemplate, basePath);
180
- _context2.next = 6;
181
- return (0, _core.load)(subtreeUrl, _tile3dSubtreeLoader.Tile3DSubtreeLoader, options);
182
- case 6:
183
- subtree = _context2.sent;
184
- contentUrlTemplate = resolveUri(tile.content.uri, basePath);
185
- refine = tileset === null || tileset === void 0 ? void 0 : (_tileset$root = tileset.root) === null || _tileset$root === void 0 ? void 0 : _tileset$root.refine;
186
- rootLodMetricValue = tile.geometricError;
187
- rootBoundingVolume = tile.boundingVolume;
188
- implicitOptions = {
189
- contentUrlTemplate: contentUrlTemplate,
190
- subtreesUriTemplate: subtreesUriTemplate,
191
- subdivisionScheme: subdivisionScheme,
192
- subtreeLevels: subtreeLevels,
193
- maximumLevel: maximumLevel,
194
- refine: refine,
195
- basePath: basePath,
196
- lodMetricType: _tiles.LOD_METRIC_TYPE.GEOMETRIC_ERROR,
197
- rootLodMetricValue: rootLodMetricValue,
198
- rootBoundingVolume: rootBoundingVolume,
199
- getTileType: getTileType,
200
- getRefine: getRefine
171
+ while (1) switch (_context2.prev = _context2.next) {
172
+ case 0:
173
+ basePath = tileset.basePath;
174
+ subdivisionScheme = implicitTilingExtension.subdivisionScheme, maximumLevel = implicitTilingExtension.maximumLevel, subtreeLevels = implicitTilingExtension.subtreeLevels, subtreesUriTemplate = implicitTilingExtension.subtrees.uri;
175
+ replacedUrlTemplate = (0, _parse3dImplicitTiles.replaceContentUrlTemplate)(subtreesUriTemplate, 0, 0, 0, 0);
176
+ subtreeUrl = resolveUri(replacedUrlTemplate, basePath);
177
+ _context2.next = 6;
178
+ return (0, _core.load)(subtreeUrl, _tile3dSubtreeLoader.Tile3DSubtreeLoader, options);
179
+ case 6:
180
+ subtree = _context2.sent;
181
+ contentUrlTemplate = resolveUri(tile.content.uri, basePath);
182
+ refine = tileset === null || tileset === void 0 ? void 0 : (_tileset$root = tileset.root) === null || _tileset$root === void 0 ? void 0 : _tileset$root.refine;
183
+ rootLodMetricValue = tile.geometricError;
184
+ s2VolumeInfo = (_tile$boundingVolume$ = tile.boundingVolume.extensions) === null || _tile$boundingVolume$ === void 0 ? void 0 : _tile$boundingVolume$['3DTILES_bounding_volume_S2'];
185
+ if (s2VolumeInfo) {
186
+ box = (0, _s2CornersToObb.convertS2BoundingVolumetoOBB)(s2VolumeInfo);
187
+ s2VolumeBox = {
188
+ box: box,
189
+ s2VolumeInfo: s2VolumeInfo
201
190
  };
202
- _context2.next = 14;
203
- return normalizeImplicitTileData(tile, subtree, implicitOptions);
204
- case 14:
205
- return _context2.abrupt("return", _context2.sent);
206
- case 15:
207
- case "end":
208
- return _context2.stop();
209
- }
191
+ tile.boundingVolume = s2VolumeBox;
192
+ }
193
+ rootBoundingVolume = tile.boundingVolume;
194
+ implicitOptions = {
195
+ contentUrlTemplate: contentUrlTemplate,
196
+ subtreesUriTemplate: subtreesUriTemplate,
197
+ subdivisionScheme: subdivisionScheme,
198
+ subtreeLevels: subtreeLevels,
199
+ maximumLevel: maximumLevel,
200
+ refine: refine,
201
+ basePath: basePath,
202
+ lodMetricType: _tiles.LOD_METRIC_TYPE.GEOMETRIC_ERROR,
203
+ rootLodMetricValue: rootLodMetricValue,
204
+ rootBoundingVolume: rootBoundingVolume,
205
+ getTileType: getTileType,
206
+ getRefine: getRefine
207
+ };
208
+ _context2.next = 16;
209
+ return normalizeImplicitTileData(tile, subtree, implicitOptions);
210
+ case 16:
211
+ return _context2.abrupt("return", _context2.sent);
212
+ case 17:
213
+ case "end":
214
+ return _context2.stop();
210
215
  }
211
216
  }, _callee2);
212
217
  }));
@@ -219,42 +224,41 @@ function _normalizeImplicitTileData() {
219
224
  _normalizeImplicitTileData = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee3(tile, rootSubtree, options) {
220
225
  var _yield$parseImplicitT, children, contentUrl;
221
226
  return _regenerator.default.wrap(function _callee3$(_context3) {
222
- while (1) {
223
- switch (_context3.prev = _context3.next) {
224
- case 0:
225
- if (tile) {
226
- _context3.next = 2;
227
- break;
228
- }
229
- return _context3.abrupt("return", null);
230
- case 2:
231
- tile.lodMetricType = _tiles.LOD_METRIC_TYPE.GEOMETRIC_ERROR;
232
- tile.lodMetricValue = tile.geometricError;
233
- tile.transformMatrix = tile.transform;
234
- _context3.next = 7;
235
- return (0, _parse3dImplicitTiles.parseImplicitTiles)({
236
- subtree: rootSubtree,
237
- options: options
238
- });
239
- case 7:
240
- _yield$parseImplicitT = _context3.sent;
241
- children = _yield$parseImplicitT.children;
242
- contentUrl = _yield$parseImplicitT.contentUrl;
243
- if (contentUrl) {
244
- tile.contentUrl = contentUrl;
245
- tile.content = {
246
- uri: contentUrl.replace("".concat(options.basePath, "/"), '')
247
- };
248
- }
249
- tile.refine = getRefine(tile.refine);
250
- tile.type = getTileType(tile);
251
- tile.children = children;
252
- tile.id = tile.contentUrl;
253
- return _context3.abrupt("return", tile);
254
- case 16:
255
- case "end":
256
- return _context3.stop();
257
- }
227
+ while (1) switch (_context3.prev = _context3.next) {
228
+ case 0:
229
+ if (tile) {
230
+ _context3.next = 2;
231
+ break;
232
+ }
233
+ return _context3.abrupt("return", null);
234
+ case 2:
235
+ tile.lodMetricType = _tiles.LOD_METRIC_TYPE.GEOMETRIC_ERROR;
236
+ tile.lodMetricValue = tile.geometricError;
237
+ tile.transformMatrix = tile.transform;
238
+ _context3.next = 7;
239
+ return (0, _parse3dImplicitTiles.parseImplicitTiles)({
240
+ subtree: rootSubtree,
241
+ options: options,
242
+ s2VolumeBox: tile
243
+ });
244
+ case 7:
245
+ _yield$parseImplicitT = _context3.sent;
246
+ children = _yield$parseImplicitT.children;
247
+ contentUrl = _yield$parseImplicitT.contentUrl;
248
+ if (contentUrl) {
249
+ tile.contentUrl = contentUrl;
250
+ tile.content = {
251
+ uri: contentUrl.replace("".concat(options.basePath, "/"), '')
252
+ };
253
+ }
254
+ tile.refine = getRefine(tile.refine);
255
+ tile.type = getTileType(tile);
256
+ tile.children = children;
257
+ tile.id = tile.contentUrl;
258
+ return _context3.abrupt("return", tile);
259
+ case 16:
260
+ case "end":
261
+ return _context3.stop();
258
262
  }
259
263
  }, _callee3);
260
264
  }));
@@ -1 +1 @@
1
- {"version":3,"file":"parse-3d-tile-header.js","names":["getTileType","tile","contentUrl","TILE_TYPE","EMPTY","fileExtension","split","pop","POINTCLOUD","SCENEGRAPH","getRefine","refine","TILE_REFINEMENT","REPLACE","ADD","resolveUri","uri","basePath","urlSchemeRegex","test","url","URL","decodeURI","toString","startsWith","normalizeTileData","options","content","contentUri","id","lodMetricType","LOD_METRIC_TYPE","GEOMETRIC_ERROR","lodMetricValue","geometricError","transformMatrix","transform","type","normalizeTileHeaders","tileset","rootImplicitTilingExtension","getImplicitTilingExtensionData","root","normalizeImplicitTileHeaders","stack","push","length","children","childHeader","childImplicitTilingExtension","implicitTilingExtension","subdivisionScheme","maximumLevel","subtreeLevels","subtreesUriTemplate","subtrees","replacedUrlTemplate","replaceContentUrlTemplate","subtreeUrl","load","Tile3DSubtreeLoader","subtree","contentUrlTemplate","rootLodMetricValue","rootBoundingVolume","boundingVolume","implicitOptions","normalizeImplicitTileData","rootSubtree","parseImplicitTiles","replace","extensions","implicitTiling"],"sources":["../../../../src/lib/parsers/parse-3d-tile-header.ts"],"sourcesContent":["import type {LoaderOptions} from '@loaders.gl/loader-utils';\nimport {Tile3DSubtreeLoader} from '../../tile-3d-subtree-loader';\nimport {load} from '@loaders.gl/core';\nimport {Tileset3D, LOD_METRIC_TYPE, TILE_REFINEMENT, TILE_TYPE, Tile3D} from '@loaders.gl/tiles';\nimport {ImplicitTilingExtension, Subtree} from '../../types';\nimport {parseImplicitTiles, replaceContentUrlTemplate} from './helpers/parse-3d-implicit-tiles';\n\nfunction getTileType(tile) {\n if (!tile.contentUrl) {\n return TILE_TYPE.EMPTY;\n }\n\n const contentUrl = tile.contentUrl;\n const fileExtension = contentUrl.split('.').pop();\n switch (fileExtension) {\n case 'pnts':\n return TILE_TYPE.POINTCLOUD;\n case 'i3dm':\n case 'b3dm':\n case 'glb':\n case 'gltf':\n return TILE_TYPE.SCENEGRAPH;\n default:\n return fileExtension;\n }\n}\n\nfunction getRefine(refine) {\n switch (refine) {\n case 'REPLACE':\n case 'replace':\n return TILE_REFINEMENT.REPLACE;\n case 'ADD':\n case 'add':\n return TILE_REFINEMENT.ADD;\n default:\n return refine;\n }\n}\n\nfunction resolveUri(uri, basePath) {\n // url scheme per RFC3986\n const urlSchemeRegex = /^[a-z][0-9a-z+.-]*:/i;\n\n if (urlSchemeRegex.test(basePath)) {\n const url = new URL(uri, `${basePath}/`);\n return decodeURI(url.toString());\n } else if (uri.startsWith('/')) {\n return uri;\n }\n\n return `${basePath}/${uri}`;\n}\n\nexport function normalizeTileData(tile, options) {\n if (!tile) {\n return null;\n }\n if (tile.content) {\n const contentUri = tile.content.uri || tile.content.url;\n tile.contentUrl = resolveUri(contentUri, options.basePath);\n }\n tile.id = tile.contentUrl;\n tile.lodMetricType = LOD_METRIC_TYPE.GEOMETRIC_ERROR;\n tile.lodMetricValue = tile.geometricError;\n tile.transformMatrix = tile.transform;\n tile.type = getTileType(tile);\n tile.refine = getRefine(tile.refine);\n\n return tile;\n}\n\n// normalize tile headers\nexport async function normalizeTileHeaders(\n tileset: Tileset3D,\n options: LoaderOptions\n): Promise<Tileset3D> {\n const basePath = tileset.basePath;\n let root: Tileset3D;\n\n const rootImplicitTilingExtension = getImplicitTilingExtensionData(tileset?.root);\n if (rootImplicitTilingExtension && tileset.root) {\n root = await normalizeImplicitTileHeaders(\n tileset.root,\n tileset,\n rootImplicitTilingExtension,\n options\n );\n } else {\n root = normalizeTileData(tileset.root, tileset);\n }\n\n const stack: any[] = [];\n stack.push(root);\n\n while (stack.length > 0) {\n const tile = stack.pop() || {};\n const children = tile.children || [];\n for (let childHeader of children) {\n const childImplicitTilingExtension = getImplicitTilingExtensionData(childHeader);\n if (childImplicitTilingExtension) {\n childHeader = await normalizeImplicitTileHeaders(\n childHeader,\n tileset,\n childImplicitTilingExtension,\n options\n );\n } else {\n normalizeTileData(childHeader, {basePath});\n }\n\n stack.push(childHeader);\n }\n }\n\n return root;\n}\n\n/**\n * Do normalisation of implicit tile headers\n * TODO Check if Tile3D class can be a return type here.\n * @param tileset\n */\nexport async function normalizeImplicitTileHeaders(\n tile: Tile3D,\n tileset: Tileset3D,\n implicitTilingExtension: ImplicitTilingExtension,\n options: LoaderOptions\n) {\n const basePath = tileset.basePath;\n const {\n subdivisionScheme,\n maximumLevel,\n subtreeLevels,\n subtrees: {uri: subtreesUriTemplate}\n } = implicitTilingExtension;\n const replacedUrlTemplate = replaceContentUrlTemplate(subtreesUriTemplate, 0, 0, 0, 0);\n const subtreeUrl = resolveUri(replacedUrlTemplate, basePath);\n const subtree = await load(subtreeUrl, Tile3DSubtreeLoader, options);\n const contentUrlTemplate = resolveUri(tile.content.uri, basePath);\n const refine = tileset?.root?.refine;\n // @ts-ignore\n const rootLodMetricValue = tile.geometricError;\n const rootBoundingVolume = tile.boundingVolume;\n\n const implicitOptions = {\n contentUrlTemplate,\n subtreesUriTemplate,\n subdivisionScheme,\n subtreeLevels,\n maximumLevel,\n refine,\n basePath,\n lodMetricType: LOD_METRIC_TYPE.GEOMETRIC_ERROR,\n rootLodMetricValue,\n rootBoundingVolume,\n getTileType,\n getRefine\n };\n\n return await normalizeImplicitTileData(tile, subtree, implicitOptions);\n}\n\n/**\n * Do implicit data normalisation to create hierarchical tile structure\n * @param tile\n * @param rootSubtree\n * @param options\n * @returns\n */\nexport async function normalizeImplicitTileData(tile, rootSubtree: Subtree, options: any) {\n if (!tile) {\n return null;\n }\n\n tile.lodMetricType = LOD_METRIC_TYPE.GEOMETRIC_ERROR;\n tile.lodMetricValue = tile.geometricError;\n tile.transformMatrix = tile.transform;\n\n const {children, contentUrl} = await parseImplicitTiles({subtree: rootSubtree, options});\n\n if (contentUrl) {\n tile.contentUrl = contentUrl;\n tile.content = {uri: contentUrl.replace(`${options.basePath}/`, '')};\n }\n\n tile.refine = getRefine(tile.refine);\n tile.type = getTileType(tile);\n tile.children = children;\n tile.id = tile.contentUrl;\n\n return tile;\n}\n\n/**\n * Implicit Tiling data can be in 3DTILES_implicit_tiling for 3DTiles v.Next or directly in implicitTiling object for 3DTiles v1.1.\n * Spec 3DTiles v.Next - https://github.com/CesiumGS/3d-tiles/tree/main/extensions/3DTILES_implicit_tiling\n * Spec 3DTiles v.1.1 - https://github.com/CesiumGS/3d-tiles/tree/draft-1.1/specification/ImplicitTiling\n * @param tile\n * @returns\n */\nfunction getImplicitTilingExtensionData(tile: Tile3D | null): ImplicitTilingExtension {\n return tile?.extensions?.['3DTILES_implicit_tiling'] || tile?.implicitTiling;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"parse-3d-tile-header.js","names":["_tile3dSubtreeLoader","require","_core","_tiles","_parse3dImplicitTiles","_s2CornersToObb","_createForOfIteratorHelper","o","allowArrayLike","it","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","i","F","s","n","done","value","e","_e","f","TypeError","normalCompletion","didErr","err","call","step","next","_e2","return","minLen","_arrayLikeToArray","Object","prototype","toString","slice","constructor","name","from","test","arr","len","arr2","getTileType","tile","contentUrl","TILE_TYPE","EMPTY","fileExtension","split","pop","POINTCLOUD","SCENEGRAPH","getRefine","refine","TILE_REFINEMENT","REPLACE","ADD","resolveUri","uri","basePath","urlSchemeRegex","url","URL","concat","decodeURI","startsWith","normalizeTileData","options","content","contentUri","id","lodMetricType","LOD_METRIC_TYPE","GEOMETRIC_ERROR","lodMetricValue","geometricError","transformMatrix","transform","type","normalizeTileHeaders","_x","_x2","_normalizeTileHeaders","apply","arguments","_asyncToGenerator2","default","_regenerator","mark","_callee","tileset","root","rootImplicitTilingExtension","stack","children","_iterator","_step","childHeader","childImplicitTilingExtension","wrap","_callee$","_context","prev","getImplicitTilingExtensionData","normalizeImplicitTileHeaders","sent","push","t0","finish","abrupt","stop","_x3","_x4","_x5","_x6","_normalizeImplicitTileHeaders","_callee2","implicitTilingExtension","_tileset$root","_tile$boundingVolume$","subdivisionScheme","maximumLevel","subtreeLevels","subtreesUriTemplate","replacedUrlTemplate","subtreeUrl","subtree","contentUrlTemplate","rootLodMetricValue","s2VolumeInfo","box","s2VolumeBox","rootBoundingVolume","implicitOptions","_callee2$","_context2","subtrees","replaceContentUrlTemplate","load","Tile3DSubtreeLoader","boundingVolume","extensions","convertS2BoundingVolumetoOBB","normalizeImplicitTileData","_x7","_x8","_x9","_normalizeImplicitTileData","_callee3","rootSubtree","_yield$parseImplicitT","_callee3$","_context3","parseImplicitTiles","replace","_tile$extensions","implicitTiling"],"sources":["../../../../src/lib/parsers/parse-3d-tile-header.ts"],"sourcesContent":["import type {LoaderOptions} from '@loaders.gl/loader-utils';\nimport {Tile3DSubtreeLoader} from '../../tile-3d-subtree-loader';\nimport {load} from '@loaders.gl/core';\nimport {Tileset3D, LOD_METRIC_TYPE, TILE_REFINEMENT, TILE_TYPE, Tile3D} from '@loaders.gl/tiles';\nimport {ImplicitTilingExtension, Subtree} from '../../types';\nimport type {S2VolumeBox} from './helpers/parse-3d-implicit-tiles';\nimport {parseImplicitTiles, replaceContentUrlTemplate} from './helpers/parse-3d-implicit-tiles';\nimport type {S2VolumeInfo} from '../utils/obb/s2-corners-to-obb';\nimport {convertS2BoundingVolumetoOBB} from '../utils/obb/s2-corners-to-obb';\n\nfunction getTileType(tile) {\n if (!tile.contentUrl) {\n return TILE_TYPE.EMPTY;\n }\n\n const contentUrl = tile.contentUrl;\n const fileExtension = contentUrl.split('.').pop();\n switch (fileExtension) {\n case 'pnts':\n return TILE_TYPE.POINTCLOUD;\n case 'i3dm':\n case 'b3dm':\n case 'glb':\n case 'gltf':\n return TILE_TYPE.SCENEGRAPH;\n default:\n return fileExtension;\n }\n}\n\nfunction getRefine(refine) {\n switch (refine) {\n case 'REPLACE':\n case 'replace':\n return TILE_REFINEMENT.REPLACE;\n case 'ADD':\n case 'add':\n return TILE_REFINEMENT.ADD;\n default:\n return refine;\n }\n}\n\nfunction resolveUri(uri, basePath) {\n // url scheme per RFC3986\n const urlSchemeRegex = /^[a-z][0-9a-z+.-]*:/i;\n\n if (urlSchemeRegex.test(basePath)) {\n const url = new URL(uri, `${basePath}/`);\n return decodeURI(url.toString());\n } else if (uri.startsWith('/')) {\n return uri;\n }\n\n return `${basePath}/${uri}`;\n}\n\nexport function normalizeTileData(tile, options) {\n if (!tile) {\n return null;\n }\n if (tile.content) {\n const contentUri = tile.content.uri || tile.content.url;\n tile.contentUrl = resolveUri(contentUri, options.basePath);\n }\n tile.id = tile.contentUrl;\n tile.lodMetricType = LOD_METRIC_TYPE.GEOMETRIC_ERROR;\n tile.lodMetricValue = tile.geometricError;\n tile.transformMatrix = tile.transform;\n tile.type = getTileType(tile);\n tile.refine = getRefine(tile.refine);\n\n return tile;\n}\n\n// normalize tile headers\nexport async function normalizeTileHeaders(\n tileset: Tileset3D,\n options: LoaderOptions\n): Promise<Tileset3D> {\n const basePath = tileset.basePath;\n let root: Tileset3D;\n\n const rootImplicitTilingExtension = getImplicitTilingExtensionData(tileset?.root);\n if (rootImplicitTilingExtension && tileset.root) {\n root = await normalizeImplicitTileHeaders(\n tileset.root,\n tileset,\n rootImplicitTilingExtension,\n options\n );\n } else {\n root = normalizeTileData(tileset.root, tileset);\n }\n\n const stack: any[] = [];\n stack.push(root);\n\n while (stack.length > 0) {\n const tile = stack.pop() || {};\n const children = tile.children || [];\n for (let childHeader of children) {\n const childImplicitTilingExtension = getImplicitTilingExtensionData(childHeader);\n if (childImplicitTilingExtension) {\n childHeader = await normalizeImplicitTileHeaders(\n childHeader,\n tileset,\n childImplicitTilingExtension,\n options\n );\n } else {\n normalizeTileData(childHeader, {basePath});\n }\n\n stack.push(childHeader);\n }\n }\n\n return root;\n}\n\n/**\n * Do normalisation of implicit tile headers\n * TODO Check if Tile3D class can be a return type here.\n * @param tileset\n */\nexport async function normalizeImplicitTileHeaders(\n tile: Tile3D,\n tileset: Tileset3D,\n implicitTilingExtension: ImplicitTilingExtension,\n options: LoaderOptions\n) {\n const basePath = tileset.basePath;\n const {\n subdivisionScheme,\n maximumLevel,\n subtreeLevels,\n subtrees: {uri: subtreesUriTemplate}\n } = implicitTilingExtension;\n const replacedUrlTemplate = replaceContentUrlTemplate(subtreesUriTemplate, 0, 0, 0, 0);\n const subtreeUrl = resolveUri(replacedUrlTemplate, basePath);\n const subtree = await load(subtreeUrl, Tile3DSubtreeLoader, options);\n const contentUrlTemplate = resolveUri(tile.content.uri, basePath);\n const refine = tileset?.root?.refine;\n // @ts-ignore\n const rootLodMetricValue = tile.geometricError;\n\n // Replace tile.boundingVolume with the the bounding volume specified by the extensions['3DTILES_bounding_volume_S2']\n const s2VolumeInfo: S2VolumeInfo = tile.boundingVolume.extensions?.['3DTILES_bounding_volume_S2'];\n if (s2VolumeInfo) {\n const box = convertS2BoundingVolumetoOBB(s2VolumeInfo);\n const s2VolumeBox: S2VolumeBox = {box, s2VolumeInfo};\n tile.boundingVolume = s2VolumeBox;\n }\n\n const rootBoundingVolume = tile.boundingVolume;\n\n const implicitOptions = {\n contentUrlTemplate,\n subtreesUriTemplate,\n subdivisionScheme,\n subtreeLevels,\n maximumLevel,\n refine,\n basePath,\n lodMetricType: LOD_METRIC_TYPE.GEOMETRIC_ERROR,\n rootLodMetricValue,\n rootBoundingVolume,\n getTileType,\n getRefine\n };\n\n return await normalizeImplicitTileData(tile, subtree, implicitOptions);\n}\n\n/**\n * Do implicit data normalisation to create hierarchical tile structure\n * @param tile\n * @param rootSubtree\n * @param options\n * @returns\n */\nexport async function normalizeImplicitTileData(tile, rootSubtree: Subtree, options: any) {\n if (!tile) {\n return null;\n }\n\n tile.lodMetricType = LOD_METRIC_TYPE.GEOMETRIC_ERROR;\n tile.lodMetricValue = tile.geometricError;\n tile.transformMatrix = tile.transform;\n\n const {children, contentUrl} = await parseImplicitTiles({\n subtree: rootSubtree,\n options,\n s2VolumeBox: tile\n });\n\n if (contentUrl) {\n tile.contentUrl = contentUrl;\n tile.content = {uri: contentUrl.replace(`${options.basePath}/`, '')};\n }\n\n tile.refine = getRefine(tile.refine);\n tile.type = getTileType(tile);\n tile.children = children;\n tile.id = tile.contentUrl;\n\n return tile;\n}\n\n/**\n * Implicit Tiling data can be in 3DTILES_implicit_tiling for 3DTiles v.Next or directly in implicitTiling object for 3DTiles v1.1.\n * Spec 3DTiles v.Next - https://github.com/CesiumGS/3d-tiles/tree/main/extensions/3DTILES_implicit_tiling\n * Spec 3DTiles v.1.1 - https://github.com/CesiumGS/3d-tiles/tree/draft-1.1/specification/ImplicitTiling\n * @param tile\n * @returns\n */\nfunction getImplicitTilingExtensionData(tile: Tile3D | null): ImplicitTilingExtension {\n return tile?.extensions?.['3DTILES_implicit_tiling'] || tile?.implicitTiling;\n}\n"],"mappings":"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"}
@@ -21,18 +21,16 @@ function parseInstancedModel3DTile(_x, _x2, _x3, _x4, _x5) {
21
21
  function _parseInstancedModel3DTile() {
22
22
  _parseInstancedModel3DTile = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(tile, arrayBuffer, byteOffset, options, context) {
23
23
  return _regenerator.default.wrap(function _callee$(_context) {
24
- while (1) {
25
- switch (_context.prev = _context.next) {
26
- case 0:
27
- byteOffset = parseInstancedModel(tile, arrayBuffer, byteOffset, options, context);
28
- _context.next = 3;
29
- return (0, _parse3dTileGltfView.extractGLTF)(tile, tile.gltfFormat, options, context);
30
- case 3:
31
- return _context.abrupt("return", byteOffset);
32
- case 4:
33
- case "end":
34
- return _context.stop();
35
- }
24
+ while (1) switch (_context.prev = _context.next) {
25
+ case 0:
26
+ byteOffset = parseInstancedModel(tile, arrayBuffer, byteOffset, options, context);
27
+ _context.next = 3;
28
+ return (0, _parse3dTileGltfView.extractGLTF)(tile, tile.gltfFormat, options, context);
29
+ case 3:
30
+ return _context.abrupt("return", byteOffset);
31
+ case 4:
32
+ case "end":
33
+ return _context.stop();
36
34
  }
37
35
  }, _callee);
38
36
  }));
@@ -47,10 +45,8 @@ function parseInstancedModel(tile, arrayBuffer, byteOffset, options, context) {
47
45
  var view = new DataView(arrayBuffer);
48
46
  tile.gltfFormat = view.getUint32(byteOffset, true);
49
47
  byteOffset += 4;
50
-
51
48
  byteOffset = (0, _parse3dTileTables.parse3DTileTablesSync)(tile, arrayBuffer, byteOffset, options);
52
49
  byteOffset = (0, _parse3dTileGltfView.parse3DTileGLTFViewSync)(tile, arrayBuffer, byteOffset, options);
53
-
54
50
  if (tile.featureTableJsonByteLength === 0) {
55
51
  throw new Error('i3dm parser: featureTableJsonByteLength is zero.');
56
52
  }
@@ -66,7 +62,6 @@ function parseInstancedModel(tile, arrayBuffer, byteOffset, options, context) {
66
62
  extractInstancedAttributes(tile, featureTable, batchTable, instancesLength);
67
63
  return byteOffset;
68
64
  }
69
-
70
65
  function extractInstancedAttributes(tile, featureTable, batchTable, instancesLength) {
71
66
  var collectionOptions = {
72
67
  instances: new Array(instancesLength),
@@ -94,7 +89,6 @@ function extractInstancedAttributes(tile, featureTable, batchTable, instancesLen
94
89
  var scratchVector2 = new _core.Vector3();
95
90
  for (var i = 0; i < instancesLength; i++) {
96
91
  var position = void 0;
97
-
98
92
  if (featureTable.hasProperty('POSITION')) {
99
93
  position = featureTable.getProperty('POSITION', _math.GL.FLOAT, 3, i, instancePosition);
100
94
  } else if (featureTable.hasProperty('POSITION_QUANTIZED')) {
@@ -117,7 +111,6 @@ function extractInstancedAttributes(tile, featureTable, batchTable, instancesLen
117
111
  }
118
112
  instancePosition.copy(position);
119
113
  instanceTranslationRotationScale.translation = instancePosition;
120
-
121
114
  tile.normalUp = featureTable.getProperty('NORMAL_UP', _math.GL.FLOAT, 3, i, scratch1);
122
115
  tile.normalRight = featureTable.getProperty('NORMAL_RIGHT', _math.GL.FLOAT, 3, i, scratch2);
123
116
  var hasCustomOrientation = false;
@@ -149,7 +142,6 @@ function extractInstancedAttributes(tile, featureTable, batchTable, instancesLen
149
142
  }
150
143
  instanceQuaternion.fromMatrix3(instanceRotation);
151
144
  instanceTranslationRotationScale.rotation = instanceQuaternion;
152
-
153
145
  instanceScale.set(1.0, 1.0, 1.0);
154
146
  var scale = featureTable.getProperty('SCALE', _math.GL.FLOAT, 1, i);
155
147
  if (Number.isFinite(scale)) {
@@ -159,16 +151,12 @@ function extractInstancedAttributes(tile, featureTable, batchTable, instancesLen
159
151
  if (nonUniformScale) {
160
152
  instanceScale.scale(nonUniformScale);
161
153
  }
162
-
163
154
  instanceTranslationRotationScale.scale = instanceScale;
164
-
165
155
  var batchId = featureTable.getProperty('BATCH_ID', _math.GL.UNSIGNED_SHORT, 1, i);
166
156
  if (batchId === undefined) {
167
157
  batchId = i;
168
158
  }
169
-
170
159
  var rotationMatrix = new _core.Matrix4().fromQuaternion(instanceTranslationRotationScale.rotation);
171
-
172
160
  instanceTransform.identity();
173
161
  instanceTransform.translate(instanceTranslationRotationScale.translation);
174
162
  instanceTransform.multiplyRight(rotationMatrix);