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

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 (393) hide show
  1. package/dist/bundle.d.ts +2 -0
  2. package/dist/bundle.d.ts.map +1 -0
  3. package/dist/bundle.js +2 -2
  4. package/dist/cesium-ion-loader.d.ts +6 -0
  5. package/dist/cesium-ion-loader.d.ts.map +1 -0
  6. package/dist/cesium-ion-loader.js +37 -32
  7. package/dist/dist.min.js +14805 -0
  8. package/dist/es5/bundle.js +6 -0
  9. package/dist/es5/bundle.js.map +1 -0
  10. package/dist/es5/cesium-ion-loader.js +77 -0
  11. package/dist/es5/cesium-ion-loader.js.map +1 -0
  12. package/dist/es5/index.js +63 -0
  13. package/dist/es5/index.js.map +1 -0
  14. package/dist/es5/lib/classes/helpers/tile-3d-accessor-utils.js +114 -0
  15. package/dist/es5/lib/classes/helpers/tile-3d-accessor-utils.js.map +1 -0
  16. package/dist/es5/lib/classes/tile-3d-batch-table-hierarchy.js +180 -0
  17. package/dist/es5/lib/classes/tile-3d-batch-table-hierarchy.js.map +1 -0
  18. package/dist/es5/lib/classes/tile-3d-batch-table.js +285 -0
  19. package/dist/es5/lib/classes/tile-3d-batch-table.js.map +1 -0
  20. package/dist/es5/lib/classes/tile-3d-feature-table.js +97 -0
  21. package/dist/es5/lib/classes/tile-3d-feature-table.js.map +1 -0
  22. package/dist/es5/lib/constants.js +32 -0
  23. package/dist/es5/lib/constants.js.map +1 -0
  24. package/dist/es5/lib/encoders/encode-3d-tile-batched-model.js +49 -0
  25. package/dist/es5/lib/encoders/encode-3d-tile-batched-model.js.map +1 -0
  26. package/dist/es5/lib/encoders/encode-3d-tile-composite.js +30 -0
  27. package/dist/es5/lib/encoders/encode-3d-tile-composite.js.map +1 -0
  28. package/dist/es5/lib/encoders/encode-3d-tile-instanced-model.js +47 -0
  29. package/dist/es5/lib/encoders/encode-3d-tile-instanced-model.js.map +1 -0
  30. package/dist/es5/lib/encoders/encode-3d-tile-point-cloud.js +48 -0
  31. package/dist/es5/lib/encoders/encode-3d-tile-point-cloud.js.map +1 -0
  32. package/dist/es5/lib/encoders/encode-3d-tile.js +35 -0
  33. package/dist/es5/lib/encoders/encode-3d-tile.js.map +1 -0
  34. package/dist/es5/lib/encoders/helpers/encode-3d-tile-header.js +35 -0
  35. package/dist/es5/lib/encoders/helpers/encode-3d-tile-header.js.map +1 -0
  36. package/dist/es5/lib/ion/ion.js +170 -0
  37. package/dist/es5/lib/ion/ion.js.map +1 -0
  38. package/dist/es5/lib/parsers/helpers/normalize-3d-tile-colors.js +65 -0
  39. package/dist/es5/lib/parsers/helpers/normalize-3d-tile-colors.js.map +1 -0
  40. package/dist/es5/lib/parsers/helpers/normalize-3d-tile-normals.js +32 -0
  41. package/dist/es5/lib/parsers/helpers/normalize-3d-tile-normals.js.map +1 -0
  42. package/dist/es5/lib/parsers/helpers/normalize-3d-tile-positions.js +32 -0
  43. package/dist/es5/lib/parsers/helpers/normalize-3d-tile-positions.js.map +1 -0
  44. package/dist/es5/lib/parsers/helpers/parse-3d-implicit-tiles.js +280 -0
  45. package/dist/es5/lib/parsers/helpers/parse-3d-implicit-tiles.js.map +1 -0
  46. package/dist/es5/lib/parsers/helpers/parse-3d-tile-gltf-view.js +110 -0
  47. package/dist/es5/lib/parsers/helpers/parse-3d-tile-gltf-view.js.map +1 -0
  48. package/dist/es5/lib/parsers/helpers/parse-3d-tile-header.js +22 -0
  49. package/dist/es5/lib/parsers/helpers/parse-3d-tile-header.js.map +1 -0
  50. package/dist/es5/lib/parsers/helpers/parse-3d-tile-subtree.js +145 -0
  51. package/dist/es5/lib/parsers/helpers/parse-3d-tile-subtree.js.map +1 -0
  52. package/dist/es5/lib/parsers/helpers/parse-3d-tile-tables.js +85 -0
  53. package/dist/es5/lib/parsers/helpers/parse-3d-tile-tables.js.map +1 -0
  54. package/dist/es5/lib/parsers/helpers/parse-utils.js +28 -0
  55. package/dist/es5/lib/parsers/helpers/parse-utils.js.map +1 -0
  56. package/dist/es5/lib/parsers/parse-3d-tile-batched-model.js +51 -0
  57. package/dist/es5/lib/parsers/parse-3d-tile-batched-model.js.map +1 -0
  58. package/dist/es5/lib/parsers/parse-3d-tile-composite.js +48 -0
  59. package/dist/es5/lib/parsers/parse-3d-tile-composite.js.map +1 -0
  60. package/dist/es5/lib/parsers/parse-3d-tile-gltf.js +52 -0
  61. package/dist/es5/lib/parsers/parse-3d-tile-gltf.js.map +1 -0
  62. package/dist/es5/lib/parsers/parse-3d-tile-header.js +289 -0
  63. package/dist/es5/lib/parsers/parse-3d-tile-header.js.map +1 -0
  64. package/dist/es5/lib/parsers/parse-3d-tile-instanced-model.js +163 -0
  65. package/dist/es5/lib/parsers/parse-3d-tile-instanced-model.js.map +1 -0
  66. package/dist/es5/lib/parsers/parse-3d-tile-point-cloud.js +295 -0
  67. package/dist/es5/lib/parsers/parse-3d-tile-point-cloud.js.map +1 -0
  68. package/dist/es5/lib/parsers/parse-3d-tile.js +74 -0
  69. package/dist/es5/lib/parsers/parse-3d-tile.js.map +1 -0
  70. package/dist/es5/lib/utils/obb/s2-corners-to-obb.js +30 -0
  71. package/dist/es5/lib/utils/obb/s2-corners-to-obb.js.map +1 -0
  72. package/dist/es5/lib/utils/s2/converters/s2-to-boundary.js +44 -0
  73. package/dist/es5/lib/utils/s2/converters/s2-to-boundary.js.map +1 -0
  74. package/dist/es5/lib/utils/s2/converters/s2-to-obb-points.js +30 -0
  75. package/dist/es5/lib/utils/s2/converters/s2-to-obb-points.js.map +1 -0
  76. package/dist/es5/lib/utils/s2/converters/s2-to-region.js +52 -0
  77. package/dist/es5/lib/utils/s2/converters/s2-to-region.js.map +1 -0
  78. package/dist/es5/lib/utils/s2/index.js +90 -0
  79. package/dist/es5/lib/utils/s2/index.js.map +1 -0
  80. package/dist/es5/lib/utils/s2/s2-geometry-functions.js +19 -0
  81. package/dist/es5/lib/utils/s2/s2-geometry-functions.js.map +1 -0
  82. package/dist/es5/lib/utils/s2/s2-token-functions.js +41 -0
  83. package/dist/es5/lib/utils/s2/s2-token-functions.js.map +1 -0
  84. package/dist/es5/lib/utils/s2/s2geometry/s2-cell-utils.js +22 -0
  85. package/dist/es5/lib/utils/s2/s2geometry/s2-cell-utils.js.map +1 -0
  86. package/dist/es5/lib/utils/s2/s2geometry/s2-geometry.js +207 -0
  87. package/dist/es5/lib/utils/s2/s2geometry/s2-geometry.js.map +1 -0
  88. package/dist/es5/lib/utils/version.js +9 -0
  89. package/dist/es5/lib/utils/version.js.map +1 -0
  90. package/dist/es5/tile-3d-subtree-loader.js +22 -0
  91. package/dist/es5/tile-3d-subtree-loader.js.map +1 -0
  92. package/dist/es5/tile-3d-writer.js +26 -0
  93. package/dist/es5/tile-3d-writer.js.map +1 -0
  94. package/dist/es5/tiles-3d-loader.js +133 -0
  95. package/dist/es5/tiles-3d-loader.js.map +1 -0
  96. package/dist/es5/types.js +2 -0
  97. package/dist/es5/types.js.map +1 -0
  98. package/dist/esm/bundle.js +4 -0
  99. package/dist/esm/bundle.js.map +1 -0
  100. package/dist/esm/cesium-ion-loader.js +36 -0
  101. package/dist/esm/cesium-ion-loader.js.map +1 -0
  102. package/dist/esm/index.js +9 -0
  103. package/dist/esm/index.js.map +1 -0
  104. package/dist/esm/lib/classes/helpers/tile-3d-accessor-utils.js +96 -0
  105. package/dist/esm/lib/classes/helpers/tile-3d-accessor-utils.js.map +1 -0
  106. package/dist/esm/lib/classes/tile-3d-batch-table-hierarchy.js +171 -0
  107. package/dist/esm/lib/classes/tile-3d-batch-table-hierarchy.js.map +1 -0
  108. package/dist/esm/lib/classes/tile-3d-batch-table.js +231 -0
  109. package/dist/esm/lib/classes/tile-3d-batch-table.js.map +1 -0
  110. package/dist/esm/lib/classes/tile-3d-feature-table.js +70 -0
  111. package/dist/esm/lib/classes/tile-3d-feature-table.js.map +1 -0
  112. package/dist/esm/lib/constants.js +22 -0
  113. package/dist/esm/lib/constants.js.map +1 -0
  114. package/dist/esm/lib/encoders/encode-3d-tile-batched-model.js +40 -0
  115. package/dist/esm/lib/encoders/encode-3d-tile-batched-model.js.map +1 -0
  116. package/dist/esm/lib/encoders/encode-3d-tile-composite.js +21 -0
  117. package/dist/esm/lib/encoders/encode-3d-tile-composite.js.map +1 -0
  118. package/dist/esm/lib/encoders/encode-3d-tile-instanced-model.js +36 -0
  119. package/dist/esm/lib/encoders/encode-3d-tile-instanced-model.js.map +1 -0
  120. package/dist/esm/lib/encoders/encode-3d-tile-point-cloud.js +39 -0
  121. package/dist/esm/lib/encoders/encode-3d-tile-point-cloud.js.map +1 -0
  122. package/dist/esm/lib/encoders/encode-3d-tile.js +29 -0
  123. package/dist/esm/lib/encoders/encode-3d-tile.js.map +1 -0
  124. package/dist/esm/lib/encoders/helpers/encode-3d-tile-header.js +28 -0
  125. package/dist/esm/lib/encoders/helpers/encode-3d-tile-header.js.map +1 -0
  126. package/dist/esm/lib/ion/ion.js +70 -0
  127. package/dist/esm/lib/ion/ion.js.map +1 -0
  128. package/dist/esm/lib/parsers/helpers/normalize-3d-tile-colors.js +58 -0
  129. package/dist/esm/lib/parsers/helpers/normalize-3d-tile-colors.js.map +1 -0
  130. package/{src → dist/esm}/lib/parsers/helpers/normalize-3d-tile-normals.js +5 -10
  131. package/dist/esm/lib/parsers/helpers/normalize-3d-tile-normals.js.map +1 -0
  132. package/dist/esm/lib/parsers/helpers/normalize-3d-tile-positions.js +26 -0
  133. package/dist/esm/lib/parsers/helpers/normalize-3d-tile-positions.js.map +1 -0
  134. package/dist/esm/lib/parsers/helpers/parse-3d-implicit-tiles.js +241 -0
  135. package/dist/esm/lib/parsers/helpers/parse-3d-implicit-tiles.js.map +1 -0
  136. package/dist/esm/lib/parsers/helpers/parse-3d-tile-gltf-view.js +67 -0
  137. package/dist/esm/lib/parsers/helpers/parse-3d-tile-gltf-view.js.map +1 -0
  138. package/dist/esm/lib/parsers/helpers/parse-3d-tile-header.js +16 -0
  139. package/dist/esm/lib/parsers/helpers/parse-3d-tile-header.js.map +1 -0
  140. package/dist/esm/lib/parsers/helpers/parse-3d-tile-subtree.js +67 -0
  141. package/dist/esm/lib/parsers/helpers/parse-3d-tile-subtree.js.map +1 -0
  142. package/dist/esm/lib/parsers/helpers/parse-3d-tile-tables.js +80 -0
  143. package/dist/esm/lib/parsers/helpers/parse-3d-tile-tables.js.map +1 -0
  144. package/dist/esm/lib/parsers/helpers/parse-utils.js +20 -0
  145. package/dist/esm/lib/parsers/helpers/parse-utils.js.map +1 -0
  146. package/dist/esm/lib/parsers/parse-3d-tile-batched-model.js +25 -0
  147. package/dist/esm/lib/parsers/parse-3d-tile-batched-model.js.map +1 -0
  148. package/dist/esm/lib/parsers/parse-3d-tile-composite.js +15 -0
  149. package/dist/esm/lib/parsers/parse-3d-tile-composite.js.map +1 -0
  150. package/dist/esm/lib/parsers/parse-3d-tile-gltf.js +20 -0
  151. package/dist/esm/lib/parsers/parse-3d-tile-gltf.js.map +1 -0
  152. package/dist/esm/lib/parsers/parse-3d-tile-header.js +181 -0
  153. package/dist/esm/lib/parsers/parse-3d-tile-header.js.map +1 -0
  154. package/dist/esm/lib/parsers/parse-3d-tile-instanced-model.js +138 -0
  155. package/dist/esm/lib/parsers/parse-3d-tile-instanced-model.js.map +1 -0
  156. package/dist/esm/lib/parsers/parse-3d-tile-point-cloud.js +232 -0
  157. package/dist/esm/lib/parsers/parse-3d-tile-point-cloud.js.map +1 -0
  158. package/dist/esm/lib/parsers/parse-3d-tile.js +30 -0
  159. package/dist/esm/lib/parsers/parse-3d-tile.js.map +1 -0
  160. package/dist/esm/lib/utils/obb/s2-corners-to-obb.js +23 -0
  161. package/dist/esm/lib/utils/obb/s2-corners-to-obb.js.map +1 -0
  162. package/dist/esm/lib/utils/s2/converters/s2-to-boundary.js +40 -0
  163. package/dist/esm/lib/utils/s2/converters/s2-to-boundary.js.map +1 -0
  164. package/dist/esm/lib/utils/s2/converters/s2-to-obb-points.js +24 -0
  165. package/dist/esm/lib/utils/s2/converters/s2-to-obb-points.js.map +1 -0
  166. package/dist/esm/lib/utils/s2/converters/s2-to-region.js +42 -0
  167. package/dist/esm/lib/utils/s2/converters/s2-to-region.js.map +1 -0
  168. package/dist/esm/lib/utils/s2/index.js +7 -0
  169. package/dist/esm/lib/utils/s2/index.js.map +1 -0
  170. package/dist/esm/lib/utils/s2/s2-geometry-functions.js +12 -0
  171. package/dist/esm/lib/utils/s2/s2-geometry-functions.js.map +1 -0
  172. package/dist/esm/lib/utils/s2/s2-token-functions.js +32 -0
  173. package/dist/esm/lib/utils/s2/s2-token-functions.js.map +1 -0
  174. package/dist/esm/lib/utils/s2/s2geometry/s2-cell-utils.js +15 -0
  175. package/dist/esm/lib/utils/s2/s2geometry/s2-cell-utils.js.map +1 -0
  176. package/dist/esm/lib/utils/s2/s2geometry/s2-geometry.js +186 -0
  177. package/dist/esm/lib/utils/s2/s2geometry/s2-geometry.js.map +1 -0
  178. package/dist/esm/lib/utils/version.js +2 -0
  179. package/dist/esm/lib/utils/version.js.map +1 -0
  180. package/dist/esm/tile-3d-subtree-loader.js +14 -0
  181. package/dist/esm/tile-3d-subtree-loader.js.map +1 -0
  182. package/dist/esm/tile-3d-writer.js +19 -0
  183. package/dist/esm/tile-3d-writer.js.map +1 -0
  184. package/dist/esm/tiles-3d-loader.js +68 -0
  185. package/dist/esm/tiles-3d-loader.js.map +1 -0
  186. package/dist/esm/types.js +2 -0
  187. package/dist/esm/types.js.map +1 -0
  188. package/dist/index.d.ts +11 -0
  189. package/dist/index.d.ts.map +1 -0
  190. package/dist/index.js +26 -8
  191. package/dist/lib/classes/helpers/tile-3d-accessor-utils.d.ts +8 -0
  192. package/dist/lib/classes/helpers/tile-3d-accessor-utils.d.ts.map +1 -0
  193. package/dist/lib/classes/helpers/tile-3d-accessor-utils.js +106 -89
  194. package/dist/lib/classes/tile-3d-batch-table-hierarchy.d.ts +10 -0
  195. package/dist/lib/classes/tile-3d-batch-table-hierarchy.d.ts.map +1 -0
  196. package/dist/lib/classes/tile-3d-batch-table-hierarchy.js +184 -202
  197. package/dist/lib/classes/tile-3d-batch-table.d.ts +34 -0
  198. package/dist/lib/classes/tile-3d-batch-table.d.ts.map +1 -0
  199. package/dist/lib/classes/tile-3d-batch-table.js +223 -267
  200. package/dist/lib/classes/tile-3d-feature-table.d.ts +15 -0
  201. package/dist/lib/classes/tile-3d-feature-table.d.ts.map +1 -0
  202. package/dist/lib/classes/tile-3d-feature-table.js +64 -79
  203. package/dist/lib/constants.d.ts +22 -0
  204. package/dist/lib/constants.d.ts.map +1 -0
  205. package/dist/lib/constants.js +23 -18
  206. package/dist/lib/encoders/encode-3d-tile-batched-model.d.ts +2 -0
  207. package/dist/lib/encoders/encode-3d-tile-batched-model.d.ts.map +1 -0
  208. package/dist/lib/encoders/encode-3d-tile-batched-model.js +45 -45
  209. package/dist/lib/encoders/encode-3d-tile-composite.d.ts +2 -0
  210. package/dist/lib/encoders/encode-3d-tile-composite.d.ts.map +1 -0
  211. package/dist/lib/encoders/encode-3d-tile-composite.js +23 -24
  212. package/dist/lib/encoders/encode-3d-tile-instanced-model.d.ts +2 -0
  213. package/dist/lib/encoders/encode-3d-tile-instanced-model.d.ts.map +1 -0
  214. package/dist/lib/encoders/encode-3d-tile-instanced-model.js +37 -37
  215. package/dist/lib/encoders/encode-3d-tile-point-cloud.d.ts +2 -0
  216. package/dist/lib/encoders/encode-3d-tile-point-cloud.d.ts.map +1 -0
  217. package/dist/lib/encoders/encode-3d-tile-point-cloud.js +36 -38
  218. package/dist/lib/encoders/encode-3d-tile.d.ts +2 -0
  219. package/dist/lib/encoders/encode-3d-tile.d.ts.map +1 -0
  220. package/dist/lib/encoders/encode-3d-tile.js +30 -32
  221. package/dist/lib/encoders/helpers/encode-3d-tile-header.d.ts +3 -0
  222. package/dist/lib/encoders/helpers/encode-3d-tile-header.d.ts.map +1 -0
  223. package/dist/lib/encoders/helpers/encode-3d-tile-header.js +28 -29
  224. package/dist/lib/ion/ion.d.ts +4 -0
  225. package/dist/lib/ion/ion.d.ts.map +1 -0
  226. package/dist/lib/ion/ion.js +60 -69
  227. package/dist/lib/parsers/helpers/normalize-3d-tile-colors.d.ts +9 -0
  228. package/dist/lib/parsers/helpers/normalize-3d-tile-colors.d.ts.map +1 -0
  229. package/dist/lib/parsers/helpers/normalize-3d-tile-colors.js +60 -62
  230. package/dist/lib/parsers/helpers/normalize-3d-tile-normals.d.ts +7 -0
  231. package/dist/lib/parsers/helpers/normalize-3d-tile-normals.d.ts.map +1 -0
  232. package/dist/lib/parsers/helpers/normalize-3d-tile-normals.js +26 -26
  233. package/dist/lib/parsers/helpers/normalize-3d-tile-positions.d.ts +2 -0
  234. package/dist/lib/parsers/helpers/normalize-3d-tile-positions.d.ts.map +1 -0
  235. package/dist/lib/parsers/helpers/normalize-3d-tile-positions.js +39 -28
  236. package/dist/lib/parsers/helpers/parse-3d-implicit-tiles.d.ts +57 -0
  237. package/dist/lib/parsers/helpers/parse-3d-implicit-tiles.d.ts.map +1 -0
  238. package/dist/lib/parsers/helpers/parse-3d-implicit-tiles.js +266 -0
  239. package/dist/lib/parsers/helpers/parse-3d-tile-gltf-view.d.ts +10 -0
  240. package/dist/lib/parsers/helpers/parse-3d-tile-gltf-view.d.ts.map +1 -0
  241. package/dist/lib/parsers/helpers/parse-3d-tile-gltf-view.js +90 -63
  242. package/dist/lib/parsers/helpers/parse-3d-tile-header.d.ts +3 -0
  243. package/dist/lib/parsers/helpers/parse-3d-tile-header.d.ts.map +1 -0
  244. package/dist/lib/parsers/helpers/parse-3d-tile-header.js +26 -15
  245. package/dist/lib/parsers/helpers/parse-3d-tile-subtree.d.ts +10 -0
  246. package/dist/lib/parsers/helpers/parse-3d-tile-subtree.d.ts.map +1 -0
  247. package/dist/lib/parsers/helpers/parse-3d-tile-subtree.js +104 -0
  248. package/dist/lib/parsers/helpers/parse-3d-tile-tables.d.ts +5 -0
  249. package/dist/lib/parsers/helpers/parse-3d-tile-tables.d.ts.map +1 -0
  250. package/dist/lib/parsers/helpers/parse-3d-tile-tables.js +85 -81
  251. package/dist/lib/parsers/helpers/parse-utils.d.ts +4 -0
  252. package/dist/lib/parsers/helpers/parse-utils.d.ts.map +1 -0
  253. package/dist/lib/parsers/helpers/parse-utils.js +29 -16
  254. package/dist/lib/parsers/parse-3d-tile-batched-model.d.ts +5 -0
  255. package/dist/lib/parsers/parse-3d-tile-batched-model.d.ts.map +1 -0
  256. package/dist/lib/parsers/parse-3d-tile-batched-model.js +30 -26
  257. package/dist/lib/parsers/parse-3d-tile-composite.d.ts +8 -0
  258. package/dist/lib/parsers/parse-3d-tile-composite.d.ts.map +1 -0
  259. package/dist/lib/parsers/parse-3d-tile-composite.js +23 -16
  260. package/dist/lib/parsers/parse-3d-tile-gltf.d.ts +5 -0
  261. package/dist/lib/parsers/parse-3d-tile-gltf.d.ts.map +1 -0
  262. package/dist/lib/parsers/parse-3d-tile-gltf.js +28 -0
  263. package/dist/lib/parsers/parse-3d-tile-header.d.ts +20 -0
  264. package/dist/lib/parsers/parse-3d-tile-header.d.ts.map +1 -0
  265. package/dist/lib/parsers/parse-3d-tile-header.js +186 -71
  266. package/dist/lib/parsers/parse-3d-tile-instanced-model.d.ts +5 -0
  267. package/dist/lib/parsers/parse-3d-tile-instanced-model.d.ts.map +1 -0
  268. package/dist/lib/parsers/parse-3d-tile-instanced-model.js +165 -170
  269. package/dist/lib/parsers/parse-3d-tile-point-cloud.d.ts +6 -0
  270. package/dist/lib/parsers/parse-3d-tile-point-cloud.d.ts.map +1 -0
  271. package/dist/lib/parsers/parse-3d-tile-point-cloud.js +372 -184
  272. package/dist/lib/parsers/parse-3d-tile.d.ts +5 -0
  273. package/dist/lib/parsers/parse-3d-tile.d.ts.map +1 -0
  274. package/dist/lib/parsers/parse-3d-tile.js +32 -27
  275. package/dist/lib/utils/obb/s2-corners-to-obb.d.ts +15 -0
  276. package/dist/lib/utils/obb/s2-corners-to-obb.d.ts.map +1 -0
  277. package/dist/lib/utils/obb/s2-corners-to-obb.js +37 -0
  278. package/dist/lib/utils/s2/converters/s2-to-boundary.d.ts +9 -0
  279. package/dist/lib/utils/s2/converters/s2-to-boundary.d.ts.map +1 -0
  280. package/dist/lib/utils/s2/converters/s2-to-boundary.js +61 -0
  281. package/dist/lib/utils/s2/converters/s2-to-obb-points.d.ts +15 -0
  282. package/dist/lib/utils/s2/converters/s2-to-obb-points.d.ts.map +1 -0
  283. package/dist/lib/utils/s2/converters/s2-to-obb-points.js +36 -0
  284. package/dist/lib/utils/s2/converters/s2-to-region.d.ts +13 -0
  285. package/dist/lib/utils/s2/converters/s2-to-region.d.ts.map +1 -0
  286. package/dist/lib/utils/s2/converters/s2-to-region.js +59 -0
  287. package/dist/lib/utils/s2/index.d.ts +8 -0
  288. package/dist/lib/utils/s2/index.d.ts.map +1 -0
  289. package/dist/lib/utils/s2/index.js +23 -0
  290. package/dist/lib/utils/s2/s2-geometry-functions.d.ts +14 -0
  291. package/dist/lib/utils/s2/s2-geometry-functions.d.ts.map +1 -0
  292. package/dist/lib/utils/s2/s2-geometry-functions.js +29 -0
  293. package/dist/lib/utils/s2/s2-token-functions.d.ts +23 -0
  294. package/dist/lib/utils/s2/s2-token-functions.d.ts.map +1 -0
  295. package/dist/lib/utils/s2/s2-token-functions.js +68 -0
  296. package/dist/lib/utils/s2/s2geometry/s2-cell-utils.d.ts +14 -0
  297. package/dist/lib/utils/s2/s2geometry/s2-cell-utils.d.ts.map +1 -0
  298. package/dist/lib/utils/s2/s2geometry/s2-cell-utils.js +32 -0
  299. package/dist/lib/utils/s2/s2geometry/s2-geometry.d.ts +52 -0
  300. package/dist/lib/utils/s2/s2geometry/s2-geometry.d.ts.map +1 -0
  301. package/dist/lib/utils/s2/s2geometry/s2-geometry.js +260 -0
  302. package/dist/lib/utils/version.d.ts +2 -0
  303. package/dist/lib/utils/version.d.ts.map +1 -0
  304. package/dist/lib/utils/version.js +7 -2
  305. package/dist/tile-3d-subtree-loader.d.ts +7 -0
  306. package/dist/tile-3d-subtree-loader.d.ts.map +1 -0
  307. package/dist/tile-3d-subtree-loader.js +23 -0
  308. package/dist/tile-3d-writer.d.ts +6 -0
  309. package/dist/tile-3d-writer.d.ts.map +1 -0
  310. package/dist/tile-3d-writer.js +24 -17
  311. package/dist/tiles-3d-loader.d.ts +20 -0
  312. package/dist/tiles-3d-loader.d.ts.map +1 -0
  313. package/dist/tiles-3d-loader.js +69 -65
  314. package/dist/types.d.ts +335 -0
  315. package/dist/types.d.ts.map +1 -0
  316. package/dist/types.js +2 -2
  317. package/package.json +14 -13
  318. package/src/cesium-ion-loader.ts +1 -0
  319. package/src/index.ts +13 -1
  320. package/src/lib/classes/{tile-3d-batch-table.js → tile-3d-batch-table.ts} +14 -4
  321. package/src/lib/classes/{tile-3d-feature-table.js → tile-3d-feature-table.ts} +5 -2
  322. package/src/lib/{constants.js → constants.ts} +2 -1
  323. package/src/lib/parsers/helpers/{normalize-3d-tile-colors.js → normalize-3d-tile-colors.ts} +10 -4
  324. package/src/lib/parsers/helpers/normalize-3d-tile-normals.ts +35 -0
  325. package/src/lib/parsers/helpers/parse-3d-implicit-tiles.ts +396 -0
  326. package/src/lib/parsers/helpers/{parse-3d-tile-gltf-view.js → parse-3d-tile-gltf-view.ts} +40 -16
  327. package/src/lib/parsers/helpers/{parse-3d-tile-header.js → parse-3d-tile-header.ts} +7 -1
  328. package/src/lib/parsers/helpers/parse-3d-tile-subtree.ts +148 -0
  329. package/src/lib/parsers/helpers/{parse-3d-tile-tables.js → parse-3d-tile-tables.ts} +33 -12
  330. package/src/lib/parsers/{parse-3d-tile-batched-model.js → parse-3d-tile-batched-model.ts} +18 -3
  331. package/src/lib/parsers/{parse-3d-tile-composite.js → parse-3d-tile-composite.ts} +20 -8
  332. package/src/lib/parsers/parse-3d-tile-gltf.ts +33 -0
  333. package/src/lib/parsers/parse-3d-tile-header.ts +253 -0
  334. package/src/lib/parsers/{parse-3d-tile-instanced-model.js → parse-3d-tile-instanced-model.ts} +41 -30
  335. package/src/lib/parsers/{parse-3d-tile-point-cloud.js → parse-3d-tile-point-cloud.ts} +73 -14
  336. package/src/lib/parsers/{parse-3d-tile.js → parse-3d-tile.ts} +14 -1
  337. package/src/lib/utils/obb/s2-corners-to-obb.ts +51 -0
  338. package/src/lib/utils/s2/converters/s2-to-boundary.ts +67 -0
  339. package/src/lib/utils/s2/converters/s2-to-obb-points.ts +46 -0
  340. package/src/lib/utils/s2/converters/s2-to-region.ts +69 -0
  341. package/src/lib/utils/s2/index.ts +17 -0
  342. package/src/lib/utils/s2/s2-geometry-functions.ts +28 -0
  343. package/src/lib/utils/s2/s2-token-functions.ts +67 -0
  344. package/src/lib/utils/s2/s2geometry/s2-cell-utils.ts +33 -0
  345. package/src/lib/utils/s2/s2geometry/s2-geometry.ts +296 -0
  346. package/src/tile-3d-subtree-loader.ts +19 -0
  347. package/src/tiles-3d-loader.ts +68 -37
  348. package/src/types.ts +321 -13
  349. package/dist/bundle.js.map +0 -1
  350. package/dist/cesium-ion-loader.js.map +0 -1
  351. package/dist/index.js.map +0 -1
  352. package/dist/lib/classes/helpers/tile-3d-accessor-utils.js.map +0 -1
  353. package/dist/lib/classes/tile-3d-batch-table-hierarchy.js.map +0 -1
  354. package/dist/lib/classes/tile-3d-batch-table.js.map +0 -1
  355. package/dist/lib/classes/tile-3d-feature-table.js.map +0 -1
  356. package/dist/lib/constants.js.map +0 -1
  357. package/dist/lib/encoders/encode-3d-tile-batched-model.js.map +0 -1
  358. package/dist/lib/encoders/encode-3d-tile-composite.js.map +0 -1
  359. package/dist/lib/encoders/encode-3d-tile-instanced-model.js.map +0 -1
  360. package/dist/lib/encoders/encode-3d-tile-point-cloud.js.map +0 -1
  361. package/dist/lib/encoders/encode-3d-tile.js.map +0 -1
  362. package/dist/lib/encoders/helpers/encode-3d-tile-header.js.map +0 -1
  363. package/dist/lib/ion/ion.js.map +0 -1
  364. package/dist/lib/parsers/helpers/normalize-3d-tile-colors.js.map +0 -1
  365. package/dist/lib/parsers/helpers/normalize-3d-tile-normals.js.map +0 -1
  366. package/dist/lib/parsers/helpers/normalize-3d-tile-positions.js.map +0 -1
  367. package/dist/lib/parsers/helpers/parse-3d-tile-gltf-view.js.map +0 -1
  368. package/dist/lib/parsers/helpers/parse-3d-tile-header.js.map +0 -1
  369. package/dist/lib/parsers/helpers/parse-3d-tile-tables.js.map +0 -1
  370. package/dist/lib/parsers/helpers/parse-utils.js.map +0 -1
  371. package/dist/lib/parsers/parse-3d-tile-batched-model.js.map +0 -1
  372. package/dist/lib/parsers/parse-3d-tile-composite.js.map +0 -1
  373. package/dist/lib/parsers/parse-3d-tile-header.js.map +0 -1
  374. package/dist/lib/parsers/parse-3d-tile-instanced-model.js.map +0 -1
  375. package/dist/lib/parsers/parse-3d-tile-point-cloud.js.map +0 -1
  376. package/dist/lib/parsers/parse-3d-tile.js.map +0 -1
  377. package/dist/lib/utils/version.js.map +0 -1
  378. package/dist/tile-3d-writer.js.map +0 -1
  379. package/dist/tiles-3d-loader.js.map +0 -1
  380. package/dist/types.js.map +0 -1
  381. package/src/lib/parsers/parse-3d-tile-header.js +0 -69
  382. /package/src/lib/classes/helpers/{tile-3d-accessor-utils.js → tile-3d-accessor-utils.ts} +0 -0
  383. /package/src/lib/classes/{tile-3d-batch-table-hierarchy.js → tile-3d-batch-table-hierarchy.ts} +0 -0
  384. /package/src/lib/encoders/{encode-3d-tile-batched-model.js → encode-3d-tile-batched-model.ts} +0 -0
  385. /package/src/lib/encoders/{encode-3d-tile-composite.js → encode-3d-tile-composite.ts} +0 -0
  386. /package/src/lib/encoders/{encode-3d-tile-instanced-model.js → encode-3d-tile-instanced-model.ts} +0 -0
  387. /package/src/lib/encoders/{encode-3d-tile-point-cloud.js → encode-3d-tile-point-cloud.ts} +0 -0
  388. /package/src/lib/encoders/{encode-3d-tile.js → encode-3d-tile.ts} +0 -0
  389. /package/src/lib/encoders/helpers/{encode-3d-tile-header.js → encode-3d-tile-header.ts} +0 -0
  390. /package/src/lib/ion/{ion.js → ion.ts} +0 -0
  391. /package/src/lib/parsers/helpers/{normalize-3d-tile-positions.js → normalize-3d-tile-positions.ts} +0 -0
  392. /package/src/lib/parsers/helpers/{parse-utils.js → parse-utils.ts} +0 -0
  393. /package/src/lib/utils/{version.js → version.ts} +0 -0
@@ -1,77 +1,192 @@
1
- import { LOD_METRIC_TYPE, TILE_REFINEMENT, TILE_TYPE } from '@loaders.gl/tiles';
2
-
3
- function getTileType(tile) {
4
- if (!tile.contentUrl) {
5
- return TILE_TYPE.EMPTY;
6
- }
7
-
8
- const contentUrl = tile.contentUrl;
9
- const fileExtension = contentUrl.split('.').pop();
10
-
11
- switch (fileExtension) {
12
- case 'pnts':
13
- return TILE_TYPE.POINTCLOUD;
14
-
15
- case 'i3dm':
16
- case 'b3dm':
17
- return TILE_TYPE.SCENEGRAPH;
18
-
19
- default:
20
- return fileExtension;
21
- }
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.normalizeImplicitTileData = exports.normalizeImplicitTileHeaders = exports.normalizeTileHeaders = exports.normalizeTileData = void 0;
4
+ const tile_3d_subtree_loader_1 = require("../../tile-3d-subtree-loader");
5
+ const core_1 = require("@loaders.gl/core");
6
+ const tiles_1 = require("@loaders.gl/tiles");
7
+ const parse_3d_implicit_tiles_1 = require("./helpers/parse-3d-implicit-tiles");
8
+ const s2_corners_to_obb_1 = require("../utils/obb/s2-corners-to-obb");
9
+ function getTileType(tile, tileContentUrl = '') {
10
+ if (!tileContentUrl) {
11
+ return tiles_1.TILE_TYPE.EMPTY;
12
+ }
13
+ const contentUrl = tileContentUrl.split('?')[0]; // Discard query string
14
+ const fileExtension = contentUrl.split('.').pop();
15
+ switch (fileExtension) {
16
+ case 'pnts':
17
+ return tiles_1.TILE_TYPE.POINTCLOUD;
18
+ case 'i3dm':
19
+ case 'b3dm':
20
+ case 'glb':
21
+ case 'gltf':
22
+ return tiles_1.TILE_TYPE.SCENEGRAPH;
23
+ default:
24
+ return fileExtension || tiles_1.TILE_TYPE.EMPTY;
25
+ }
22
26
  }
23
-
24
27
  function getRefine(refine) {
25
- switch (refine) {
26
- case 'REPLACE':
27
- case 'replace':
28
- return TILE_REFINEMENT.REPLACE;
29
-
30
- case 'ADD':
31
- case 'add':
32
- return TILE_REFINEMENT.ADD;
33
-
34
- default:
35
- return refine;
36
- }
28
+ switch (refine) {
29
+ case 'REPLACE':
30
+ case 'replace':
31
+ return tiles_1.TILE_REFINEMENT.REPLACE;
32
+ case 'ADD':
33
+ case 'add':
34
+ return tiles_1.TILE_REFINEMENT.ADD;
35
+ default:
36
+ return refine;
37
+ }
38
+ }
39
+ function resolveUri(uri = '', basePath) {
40
+ // url scheme per RFC3986
41
+ const urlSchemeRegex = /^[a-z][0-9a-z+.-]*:/i;
42
+ if (urlSchemeRegex.test(basePath)) {
43
+ const url = new URL(uri, `${basePath}/`);
44
+ return decodeURI(url.toString());
45
+ }
46
+ else if (uri.startsWith('/')) {
47
+ return uri;
48
+ }
49
+ return `${basePath}/${uri}`;
50
+ }
51
+ function normalizeTileData(tile, basePath) {
52
+ if (!tile) {
53
+ return null;
54
+ }
55
+ let tileContentUrl;
56
+ if (tile.content) {
57
+ const contentUri = tile.content.uri || tile.content?.url;
58
+ tileContentUrl = resolveUri(contentUri, basePath);
59
+ }
60
+ const tilePostprocessed = {
61
+ ...tile,
62
+ id: tileContentUrl,
63
+ contentUrl: tileContentUrl,
64
+ lodMetricType: tiles_1.LOD_METRIC_TYPE.GEOMETRIC_ERROR,
65
+ lodMetricValue: tile.geometricError,
66
+ transformMatrix: tile.transform,
67
+ type: getTileType(tile, tileContentUrl),
68
+ refine: getRefine(tile.refine)
69
+ };
70
+ return tilePostprocessed;
71
+ }
72
+ exports.normalizeTileData = normalizeTileData;
73
+ // normalize tile headers
74
+ async function normalizeTileHeaders(tileset, basePath, options) {
75
+ let root = null;
76
+ const rootImplicitTilingExtension = getImplicitTilingExtensionData(tileset.root);
77
+ if (rootImplicitTilingExtension && tileset.root) {
78
+ root = await normalizeImplicitTileHeaders(tileset.root, tileset, basePath, rootImplicitTilingExtension, options);
79
+ }
80
+ else {
81
+ root = normalizeTileData(tileset.root, basePath);
82
+ }
83
+ const stack = [];
84
+ stack.push(root);
85
+ while (stack.length > 0) {
86
+ const tile = stack.pop() || {};
87
+ const children = tile.children || [];
88
+ const childrenPostprocessed = [];
89
+ for (const childHeader of children) {
90
+ const childImplicitTilingExtension = getImplicitTilingExtensionData(childHeader);
91
+ let childHeaderPostprocessed;
92
+ if (childImplicitTilingExtension) {
93
+ childHeaderPostprocessed = await normalizeImplicitTileHeaders(childHeader, tileset, basePath, childImplicitTilingExtension, options);
94
+ }
95
+ else {
96
+ childHeaderPostprocessed = normalizeTileData(childHeader, basePath);
97
+ }
98
+ if (childHeaderPostprocessed) {
99
+ childrenPostprocessed.push(childHeaderPostprocessed);
100
+ stack.push(childHeaderPostprocessed);
101
+ }
102
+ }
103
+ tile.children = childrenPostprocessed;
104
+ }
105
+ return root;
37
106
  }
38
-
39
- export function normalizeTileData(tile, options) {
40
- if (!tile) {
41
- return null;
42
- }
43
-
44
- if (tile.content) {
45
- const contentUri = tile.content.uri || tile.content.url;
46
- tile.contentUrl = "".concat(options.basePath, "/").concat(contentUri);
47
- }
48
-
49
- tile.id = tile.contentUrl;
50
- tile.lodMetricType = LOD_METRIC_TYPE.GEOMETRIC_ERROR;
51
- tile.lodMetricValue = tile.geometricError;
52
- tile.transformMatrix = tile.transform;
53
- tile.type = getTileType(tile);
54
- tile.refine = getRefine(tile.refine);
55
- return tile;
107
+ exports.normalizeTileHeaders = normalizeTileHeaders;
108
+ /**
109
+ * Do normalisation of implicit tile headers
110
+ * TODO Check if Tile3D class can be a return type here.
111
+ * @param tileset
112
+ */
113
+ async function normalizeImplicitTileHeaders(tile, tileset, basePath, implicitTilingExtension, options) {
114
+ const { subdivisionScheme, maximumLevel, subtreeLevels, subtrees: { uri: subtreesUriTemplate } } = implicitTilingExtension;
115
+ const replacedUrlTemplate = (0, parse_3d_implicit_tiles_1.replaceContentUrlTemplate)(subtreesUriTemplate, 0, 0, 0, 0);
116
+ const subtreeUrl = resolveUri(replacedUrlTemplate, basePath);
117
+ const subtree = await (0, core_1.load)(subtreeUrl, tile_3d_subtree_loader_1.Tile3DSubtreeLoader, options);
118
+ const contentUrlTemplate = resolveUri(tile.content?.uri, basePath);
119
+ const refine = tileset?.root?.refine;
120
+ // @ts-ignore
121
+ const rootLodMetricValue = tile.geometricError;
122
+ // Replace tile.boundingVolume with the the bounding volume specified by the extensions['3DTILES_bounding_volume_S2']
123
+ const s2VolumeInfo = tile.boundingVolume.extensions?.['3DTILES_bounding_volume_S2'];
124
+ if (s2VolumeInfo) {
125
+ const box = (0, s2_corners_to_obb_1.convertS2BoundingVolumetoOBB)(s2VolumeInfo);
126
+ const s2VolumeBox = { box, s2VolumeInfo };
127
+ tile.boundingVolume = s2VolumeBox;
128
+ }
129
+ const rootBoundingVolume = tile.boundingVolume;
130
+ const implicitOptions = {
131
+ contentUrlTemplate,
132
+ subtreesUriTemplate,
133
+ subdivisionScheme,
134
+ subtreeLevels,
135
+ maximumLevel,
136
+ refine,
137
+ basePath,
138
+ lodMetricType: tiles_1.LOD_METRIC_TYPE.GEOMETRIC_ERROR,
139
+ rootLodMetricValue,
140
+ rootBoundingVolume,
141
+ getTileType,
142
+ getRefine
143
+ };
144
+ return await normalizeImplicitTileData(tile, basePath, subtree, implicitOptions);
56
145
  }
57
- export function normalizeTileHeaders(tileset) {
58
- const basePath = tileset.basePath;
59
- const root = normalizeTileData(tileset.root, tileset);
60
- const stack = [];
61
- stack.push(root);
62
-
63
- while (stack.length > 0) {
64
- const tile = stack.pop() || {};
65
- const children = tile.children || [];
66
-
67
- for (const childHeader of children) {
68
- normalizeTileData(childHeader, {
69
- basePath
70
- });
71
- stack.push(childHeader);
146
+ exports.normalizeImplicitTileHeaders = normalizeImplicitTileHeaders;
147
+ /**
148
+ * Do implicit data normalisation to create hierarchical tile structure
149
+ * @param tile
150
+ * @param rootSubtree
151
+ * @param options
152
+ * @returns
153
+ */
154
+ async function normalizeImplicitTileData(tile, basePath, rootSubtree, options) {
155
+ if (!tile) {
156
+ return null;
72
157
  }
73
- }
74
-
75
- return root;
158
+ const { children, contentUrl } = await (0, parse_3d_implicit_tiles_1.parseImplicitTiles)({
159
+ subtree: rootSubtree,
160
+ options
161
+ });
162
+ let tileContentUrl;
163
+ let tileContent = null;
164
+ if (contentUrl) {
165
+ tileContentUrl = contentUrl;
166
+ tileContent = { uri: contentUrl.replace(`${basePath}/`, '') };
167
+ }
168
+ const tilePostprocessed = {
169
+ ...tile,
170
+ id: tileContentUrl,
171
+ contentUrl: tileContentUrl,
172
+ lodMetricType: tiles_1.LOD_METRIC_TYPE.GEOMETRIC_ERROR,
173
+ lodMetricValue: tile.geometricError,
174
+ transformMatrix: tile.transform,
175
+ type: getTileType(tile, tileContentUrl),
176
+ refine: getRefine(tile.refine),
177
+ content: tileContent || tile.content,
178
+ children
179
+ };
180
+ return tilePostprocessed;
181
+ }
182
+ exports.normalizeImplicitTileData = normalizeImplicitTileData;
183
+ /**
184
+ * Implicit Tiling data can be in 3DTILES_implicit_tiling for 3DTiles v.Next or directly in implicitTiling object for 3DTiles v1.1.
185
+ * Spec 3DTiles v.Next - https://github.com/CesiumGS/3d-tiles/tree/main/extensions/3DTILES_implicit_tiling
186
+ * Spec 3DTiles v.1.1 - https://github.com/CesiumGS/3d-tiles/tree/draft-1.1/specification/ImplicitTiling
187
+ * @param tile
188
+ * @returns
189
+ */
190
+ function getImplicitTilingExtensionData(tile) {
191
+ return tile?.extensions?.['3DTILES_implicit_tiling'] || tile?.implicitTiling;
76
192
  }
77
- //# sourceMappingURL=parse-3d-tile-header.js.map
@@ -0,0 +1,5 @@
1
+ import { Tiles3DLoaderOptions } from '../../tiles-3d-loader';
2
+ import { LoaderContext } from '@loaders.gl/loader-utils';
3
+ import { Tiles3DTileContent } from '../../types';
4
+ export declare function parseInstancedModel3DTile(tile: Tiles3DTileContent, arrayBuffer: ArrayBuffer, byteOffset: number, options?: Tiles3DLoaderOptions, context?: LoaderContext): Promise<number>;
5
+ //# sourceMappingURL=parse-3d-tile-instanced-model.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parse-3d-tile-instanced-model.d.ts","sourceRoot":"","sources":["../../../src/lib/parsers/parse-3d-tile-instanced-model.ts"],"names":[],"mappings":"AAYA,OAAO,EAAC,oBAAoB,EAAC,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAC,aAAa,EAAC,MAAM,0BAA0B,CAAC;AACvD,OAAO,EAAC,kBAAkB,EAAC,MAAM,aAAa,CAAC;AAE/C,wBAAsB,yBAAyB,CAC7C,IAAI,EAAE,kBAAkB,EACxB,WAAW,EAAE,WAAW,EACxB,UAAU,EAAE,MAAM,EAClB,OAAO,CAAC,EAAE,oBAAoB,EAC9B,OAAO,CAAC,EAAE,aAAa,GACtB,OAAO,CAAC,MAAM,CAAC,CAIjB"}
@@ -1,177 +1,172 @@
1
- import { Vector3, Matrix3, Matrix4, Quaternion } from '@math.gl/core';
2
- import { Ellipsoid } from '@math.gl/geospatial';
3
- import { GL } from '@loaders.gl/math';
4
- import Tile3DFeatureTable from '../classes/tile-3d-feature-table';
5
- import Tile3DBatchTable from '../classes/tile-3d-batch-table';
6
- import { parse3DTileHeaderSync } from './helpers/parse-3d-tile-header';
7
- import { parse3DTileTablesHeaderSync, parse3DTileTablesSync } from './helpers/parse-3d-tile-tables';
8
- import { parse3DTileGLTFViewSync, extractGLTF } from './helpers/parse-3d-tile-gltf-view';
9
- export async function parseInstancedModel3DTile(tile, arrayBuffer, byteOffset, options, context) {
10
- byteOffset = parseInstancedModel(tile, arrayBuffer, byteOffset, options, context);
11
- await extractGLTF(tile, tile.gltfFormat, options, context);
12
- return byteOffset;
1
+ "use strict";
2
+ // This file is derived from the Cesium code base under Apache 2 license
3
+ // See LICENSE.md and https://github.com/AnalyticalGraphicsInc/cesium/blob/master/LICENSE.md
4
+ var __importDefault = (this && this.__importDefault) || function (mod) {
5
+ return (mod && mod.__esModule) ? mod : { "default": mod };
6
+ };
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.parseInstancedModel3DTile = void 0;
9
+ const core_1 = require("@math.gl/core");
10
+ const geospatial_1 = require("@math.gl/geospatial");
11
+ const math_1 = require("@loaders.gl/math"); // 'math.gl/geometry';
12
+ const tile_3d_feature_table_1 = __importDefault(require("../classes/tile-3d-feature-table"));
13
+ const tile_3d_batch_table_1 = __importDefault(require("../classes/tile-3d-batch-table"));
14
+ const parse_3d_tile_header_1 = require("./helpers/parse-3d-tile-header");
15
+ const parse_3d_tile_tables_1 = require("./helpers/parse-3d-tile-tables");
16
+ const parse_3d_tile_gltf_view_1 = require("./helpers/parse-3d-tile-gltf-view");
17
+ async function parseInstancedModel3DTile(tile, arrayBuffer, byteOffset, options, context) {
18
+ byteOffset = parseInstancedModel(tile, arrayBuffer, byteOffset, options, context);
19
+ await (0, parse_3d_tile_gltf_view_1.extractGLTF)(tile, tile.gltfFormat || 0, options, context);
20
+ return byteOffset;
13
21
  }
14
-
22
+ exports.parseInstancedModel3DTile = parseInstancedModel3DTile;
15
23
  function parseInstancedModel(tile, arrayBuffer, byteOffset, options, context) {
16
- byteOffset = parse3DTileHeaderSync(tile, arrayBuffer, byteOffset);
17
-
18
- if (tile.version !== 1) {
19
- throw new Error("Instanced 3D Model version ".concat(tile.version, " is not supported"));
20
- }
21
-
22
- byteOffset = parse3DTileTablesHeaderSync(tile, arrayBuffer, byteOffset);
23
- const view = new DataView(arrayBuffer);
24
- tile.gltfFormat = view.getUint32(byteOffset, true);
25
- byteOffset += 4;
26
- byteOffset = parse3DTileTablesSync(tile, arrayBuffer, byteOffset, options);
27
- byteOffset = parse3DTileGLTFViewSync(tile, arrayBuffer, byteOffset, options);
28
-
29
- if (tile.featureTableJsonByteLength === 0) {
30
- throw new Error('i3dm parser: featureTableJsonByteLength is zero.');
31
- }
32
-
33
- const featureTable = new Tile3DFeatureTable(tile.featureTableJson, tile.featureTableBinary);
34
- const instancesLength = featureTable.getGlobalProperty('INSTANCES_LENGTH');
35
- featureTable.featuresLength = instancesLength;
36
-
37
- if (!Number.isFinite(instancesLength)) {
38
- throw new Error('i3dm parser: INSTANCES_LENGTH must be defined');
39
- }
40
-
41
- tile.eastNorthUp = featureTable.getGlobalProperty('EAST_NORTH_UP');
42
- tile.rtcCenter = featureTable.getGlobalProperty('RTC_CENTER', GL.FLOAT, 3);
43
- const batchTable = new Tile3DBatchTable(tile.batchTableJson, tile.batchTableBinary, instancesLength);
44
- extractInstancedAttributes(tile, featureTable, batchTable, instancesLength);
45
- return byteOffset;
46
- }
47
-
48
- function extractInstancedAttributes(tile, featureTable, batchTable, instancesLength) {
49
- const collectionOptions = {
50
- instances: new Array(instancesLength),
51
- batchTable: tile._batchTable,
52
- cull: false,
53
- url: undefined,
54
- gltf: undefined,
55
- basePath: undefined,
56
- incrementallyLoadTextures: false,
57
- forwardAxis: [1, 0, 0]
58
- };
59
- const instances = collectionOptions.instances;
60
- const instancePosition = new Vector3();
61
- const instanceNormalRight = new Vector3();
62
- const instanceNormalUp = new Vector3();
63
- const instanceNormalForward = new Vector3();
64
- const instanceRotation = new Matrix3();
65
- const instanceQuaternion = new Quaternion();
66
- const instanceScale = new Vector3();
67
- const instanceTranslationRotationScale = {};
68
- const instanceTransform = new Matrix4();
69
- const scratch1 = [];
70
- const scratch2 = [];
71
- const scratchVector1 = new Vector3();
72
- const scratchVector2 = new Vector3();
73
-
74
- for (let i = 0; i < instancesLength; i++) {
75
- let position;
76
-
77
- if (featureTable.hasProperty('POSITION')) {
78
- position = featureTable.getProperty('POSITION', GL.FLOAT, 3, i, instancePosition);
79
- } else if (featureTable.hasProperty('POSITION_QUANTIZED')) {
80
- position = featureTable.getProperty('POSITION_QUANTIZED', GL.UNSIGNED_SHORT, 3, i, instancePosition);
81
- const quantizedVolumeOffset = featureTable.getGlobalProperty('QUANTIZED_VOLUME_OFFSET', GL.FLOAT, 3, scratchVector1);
82
-
83
- if (!quantizedVolumeOffset) {
84
- throw new Error('i3dm parser: QUANTIZED_VOLUME_OFFSET must be defined for quantized positions.');
85
- }
86
-
87
- const quantizedVolumeScale = featureTable.getGlobalProperty('QUANTIZED_VOLUME_SCALE', GL.FLOAT, 3, scratchVector2);
88
-
89
- if (!quantizedVolumeScale) {
90
- throw new Error('i3dm parser: QUANTIZED_VOLUME_SCALE must be defined for quantized positions.');
91
- }
92
-
93
- const MAX_UNSIGNED_SHORT = 65535.0;
94
-
95
- for (let j = 0; j < 3; j++) {
96
- position[j] = position[j] / MAX_UNSIGNED_SHORT * quantizedVolumeScale[j] + quantizedVolumeOffset[j];
97
- }
98
- }
99
-
100
- if (!position) {
101
- throw new Error('i3dm: POSITION or POSITION_QUANTIZED must be defined for each instance.');
102
- }
103
-
104
- instancePosition.copy(position);
105
- instanceTranslationRotationScale.translation = instancePosition;
106
- tile.normalUp = featureTable.getProperty('NORMAL_UP', GL.FLOAT, 3, i, scratch1);
107
- tile.normalRight = featureTable.getProperty('NORMAL_RIGHT', GL.FLOAT, 3, i, scratch2);
108
- const hasCustomOrientation = false;
109
-
110
- if (tile.normalUp) {
111
- if (!tile.normalRight) {
112
- throw new Error('i3dm: Custom orientation requires both NORMAL_UP and NORMAL_RIGHT.');
113
- }
114
-
115
- tile.hasCustomOrientation = true;
116
- } else {
117
- tile.octNormalUp = featureTable.getProperty('NORMAL_UP_OCT32P', GL.UNSIGNED_SHORT, 2, scratch1);
118
- tile.octNormalRight = featureTable.getProperty('NORMAL_RIGHT_OCT32P', GL.UNSIGNED_SHORT, 2, scratch2);
119
-
120
- if (tile.octNormalUp) {
121
- if (!tile.octNormalRight) {
122
- throw new Error('i3dm: oct-encoded orientation requires NORMAL_UP_OCT32P and NORMAL_RIGHT_OCT32P');
123
- }
124
-
125
- throw new Error('i3dm: oct-encoded orientation not implemented');
126
- } else if (tile.eastNorthUp) {
127
- Ellipsoid.WGS84.eastNorthUpToFixedFrame(instancePosition, instanceTransform);
128
- instanceTransform.getRotationMatrix3(instanceRotation);
129
- } else {
130
- instanceRotation.identity();
131
- }
24
+ byteOffset = (0, parse_3d_tile_header_1.parse3DTileHeaderSync)(tile, arrayBuffer, byteOffset);
25
+ if (tile.version !== 1) {
26
+ throw new Error(`Instanced 3D Model version ${tile.version} is not supported`);
132
27
  }
133
-
134
- if (hasCustomOrientation) {
135
- instanceNormalForward.copy(instanceNormalRight).cross(instanceNormalUp).normalize();
136
- instanceRotation.setColumn(0, instanceNormalRight);
137
- instanceRotation.setColumn(1, instanceNormalUp);
138
- instanceRotation.setColumn(2, instanceNormalForward);
28
+ byteOffset = (0, parse_3d_tile_tables_1.parse3DTileTablesHeaderSync)(tile, arrayBuffer, byteOffset);
29
+ const view = new DataView(arrayBuffer);
30
+ tile.gltfFormat = view.getUint32(byteOffset, true);
31
+ byteOffset += 4;
32
+ // PARSE FEATURE TABLE
33
+ byteOffset = (0, parse_3d_tile_tables_1.parse3DTileTablesSync)(tile, arrayBuffer, byteOffset, options);
34
+ byteOffset = (0, parse_3d_tile_gltf_view_1.parse3DTileGLTFViewSync)(tile, arrayBuffer, byteOffset, options);
35
+ // TODO - Is the feature table sometimes optional or can check be moved into table header parser?
36
+ if (!tile?.header?.featureTableJsonByteLength || tile.header.featureTableJsonByteLength === 0) {
37
+ throw new Error('i3dm parser: featureTableJsonByteLength is zero.');
139
38
  }
140
-
141
- instanceQuaternion.fromMatrix3(instanceRotation);
142
- instanceTranslationRotationScale.rotation = instanceQuaternion;
143
- instanceScale.set(1.0, 1.0, 1.0);
144
- const scale = featureTable.getProperty('SCALE', GL.FLOAT, 1, i);
145
-
146
- if (Number.isFinite(scale)) {
147
- instanceScale.multiplyByScalar(scale);
39
+ const featureTable = new tile_3d_feature_table_1.default(tile.featureTableJson, tile.featureTableBinary);
40
+ const instancesLength = featureTable.getGlobalProperty('INSTANCES_LENGTH');
41
+ featureTable.featuresLength = instancesLength;
42
+ if (!Number.isFinite(instancesLength)) {
43
+ throw new Error('i3dm parser: INSTANCES_LENGTH must be defined');
148
44
  }
149
-
150
- const nonUniformScale = featureTable.getProperty('SCALE_NON_UNIFORM', GL.FLOAT, 3, i, scratch1);
151
-
152
- if (nonUniformScale) {
153
- instanceScale.scale(nonUniformScale);
154
- }
155
-
156
- instanceTranslationRotationScale.scale = instanceScale;
157
- let batchId = featureTable.getProperty('BATCH_ID', GL.UNSIGNED_SHORT, 1, i);
158
-
159
- if (batchId === undefined) {
160
- batchId = i;
45
+ tile.eastNorthUp = featureTable.getGlobalProperty('EAST_NORTH_UP');
46
+ tile.rtcCenter = featureTable.getGlobalProperty('RTC_CENTER', math_1.GL.FLOAT, 3);
47
+ const batchTable = new tile_3d_batch_table_1.default(tile.batchTableJson, tile.batchTableBinary, instancesLength);
48
+ extractInstancedAttributes(tile, featureTable, batchTable, instancesLength);
49
+ return byteOffset;
50
+ }
51
+ // eslint-disable-next-line max-statements, complexity
52
+ function extractInstancedAttributes(tile, featureTable, batchTable, instancesLength) {
53
+ const instances = new Array(instancesLength);
54
+ const instancePosition = new core_1.Vector3();
55
+ const instanceNormalRight = new core_1.Vector3();
56
+ const instanceNormalUp = new core_1.Vector3();
57
+ const instanceNormalForward = new core_1.Vector3();
58
+ const instanceRotation = new core_1.Matrix3();
59
+ const instanceQuaternion = new core_1.Quaternion();
60
+ const instanceScale = new core_1.Vector3();
61
+ const instanceTranslationRotationScale = {};
62
+ const instanceTransform = new core_1.Matrix4();
63
+ const scratch1 = [];
64
+ const scratch2 = [];
65
+ const scratch3 = [];
66
+ const scratch4 = [];
67
+ for (let i = 0; i < instancesLength; i++) {
68
+ let position;
69
+ // Get the instance position
70
+ if (featureTable.hasProperty('POSITION')) {
71
+ position = featureTable.getProperty('POSITION', math_1.GL.FLOAT, 3, i, instancePosition);
72
+ }
73
+ else if (featureTable.hasProperty('POSITION_QUANTIZED')) {
74
+ position = featureTable.getProperty('POSITION_QUANTIZED', math_1.GL.UNSIGNED_SHORT, 3, i, instancePosition);
75
+ const quantizedVolumeOffset = featureTable.getGlobalProperty('QUANTIZED_VOLUME_OFFSET', math_1.GL.FLOAT, 3);
76
+ if (!quantizedVolumeOffset) {
77
+ throw new Error('i3dm parser: QUANTIZED_VOLUME_OFFSET must be defined for quantized positions.');
78
+ }
79
+ const quantizedVolumeScale = featureTable.getGlobalProperty('QUANTIZED_VOLUME_SCALE', math_1.GL.FLOAT, 3);
80
+ if (!quantizedVolumeScale) {
81
+ throw new Error('i3dm parser: QUANTIZED_VOLUME_SCALE must be defined for quantized positions.');
82
+ }
83
+ const MAX_UNSIGNED_SHORT = 65535.0;
84
+ for (let j = 0; j < 3; j++) {
85
+ position[j] =
86
+ (position[j] / MAX_UNSIGNED_SHORT) * quantizedVolumeScale[j] + quantizedVolumeOffset[j];
87
+ }
88
+ }
89
+ if (!position) {
90
+ throw new Error('i3dm: POSITION or POSITION_QUANTIZED must be defined for each instance.');
91
+ }
92
+ instancePosition.copy(position);
93
+ // @ts-expect-error
94
+ instanceTranslationRotationScale.translation = instancePosition;
95
+ // Get the instance rotation
96
+ tile.normalUp = featureTable.getProperty('NORMAL_UP', math_1.GL.FLOAT, 3, i, scratch1);
97
+ tile.normalRight = featureTable.getProperty('NORMAL_RIGHT', math_1.GL.FLOAT, 3, i, scratch2);
98
+ const hasCustomOrientation = false;
99
+ if (tile.normalUp) {
100
+ if (!tile.normalRight) {
101
+ throw new Error('i3dm: Custom orientation requires both NORMAL_UP and NORMAL_RIGHT.');
102
+ }
103
+ // Vector3.unpack(normalUp, 0, instanceNormalUp);
104
+ // Vector3.unpack(normalRight, 0, instanceNormalRight);
105
+ tile.hasCustomOrientation = true;
106
+ }
107
+ else {
108
+ tile.octNormalUp = featureTable.getProperty('NORMAL_UP_OCT32P', math_1.GL.UNSIGNED_SHORT, 2, i, scratch1);
109
+ tile.octNormalRight = featureTable.getProperty('NORMAL_RIGHT_OCT32P', math_1.GL.UNSIGNED_SHORT, 2, i, scratch2);
110
+ if (tile.octNormalUp) {
111
+ if (!tile.octNormalRight) {
112
+ throw new Error('i3dm: oct-encoded orientation requires NORMAL_UP_OCT32P and NORMAL_RIGHT_OCT32P');
113
+ }
114
+ throw new Error('i3dm: oct-encoded orientation not implemented');
115
+ /*
116
+ AttributeCompression.octDecodeInRange(octNormalUp[0], octNormalUp[1], 65535, instanceNormalUp);
117
+ AttributeCompression.octDecodeInRange(octNormalRight[0], octNormalRight[1], 65535, instanceNormalRight);
118
+ hasCustomOrientation = true;
119
+ */
120
+ }
121
+ else if (tile.eastNorthUp) {
122
+ geospatial_1.Ellipsoid.WGS84.eastNorthUpToFixedFrame(instancePosition, instanceTransform);
123
+ instanceTransform.getRotationMatrix3(instanceRotation);
124
+ }
125
+ else {
126
+ instanceRotation.identity();
127
+ }
128
+ }
129
+ if (hasCustomOrientation) {
130
+ instanceNormalForward.copy(instanceNormalRight).cross(instanceNormalUp).normalize();
131
+ instanceRotation.setColumn(0, instanceNormalRight);
132
+ instanceRotation.setColumn(1, instanceNormalUp);
133
+ instanceRotation.setColumn(2, instanceNormalForward);
134
+ }
135
+ instanceQuaternion.fromMatrix3(instanceRotation);
136
+ // @ts-expect-error
137
+ instanceTranslationRotationScale.rotation = instanceQuaternion;
138
+ // Get the instance scale
139
+ instanceScale.set(1.0, 1.0, 1.0);
140
+ const scale = featureTable.getProperty('SCALE', math_1.GL.FLOAT, 1, i, scratch3);
141
+ if (Number.isFinite(scale)) {
142
+ instanceScale.multiplyByScalar(scale);
143
+ }
144
+ const nonUniformScale = featureTable.getProperty('SCALE_NON_UNIFORM', math_1.GL.FLOAT, 3, i, scratch1);
145
+ if (nonUniformScale) {
146
+ instanceScale.scale(nonUniformScale);
147
+ }
148
+ // @ts-expect-error
149
+ instanceTranslationRotationScale.scale = instanceScale;
150
+ // Get the batchId
151
+ let batchId = featureTable.getProperty('BATCH_ID', math_1.GL.UNSIGNED_SHORT, 1, i, scratch4);
152
+ if (batchId === undefined) {
153
+ // If BATCH_ID semantic is undefined, batchId is just the instance number
154
+ batchId = i;
155
+ }
156
+ // @ts-expect-error
157
+ const rotationMatrix = new core_1.Matrix4().fromQuaternion(instanceTranslationRotationScale.rotation);
158
+ // Create the model matrix and the instance
159
+ instanceTransform.identity();
160
+ // @ts-expect-error
161
+ instanceTransform.translate(instanceTranslationRotationScale.translation);
162
+ instanceTransform.multiplyRight(rotationMatrix);
163
+ // @ts-expect-error
164
+ instanceTransform.scale(instanceTranslationRotationScale.scale);
165
+ const modelMatrix = instanceTransform.clone();
166
+ instances[i] = {
167
+ modelMatrix,
168
+ batchId
169
+ };
161
170
  }
162
-
163
- const rotationMatrix = new Matrix4().fromQuaternion(instanceTranslationRotationScale.rotation);
164
- instanceTransform.identity();
165
- instanceTransform.translate(instanceTranslationRotationScale.translation);
166
- instanceTransform.multiplyRight(rotationMatrix);
167
- instanceTransform.scale(instanceTranslationRotationScale.scale);
168
- const modelMatrix = instanceTransform.clone();
169
- instances[i] = {
170
- modelMatrix,
171
- batchId
172
- };
173
- }
174
-
175
- tile.instances = instances;
171
+ tile.instances = instances;
176
172
  }
177
- //# sourceMappingURL=parse-3d-tile-instanced-model.js.map
@@ -0,0 +1,6 @@
1
+ import { Tiles3DLoaderOptions } from '../../tiles-3d-loader';
2
+ import { LoaderContext } from '@loaders.gl/loader-utils';
3
+ import { Tiles3DTileContent } from '../../types';
4
+ export declare function parsePointCloud3DTile(tile: Tiles3DTileContent, arrayBuffer: ArrayBuffer, byteOffset: number, options?: Tiles3DLoaderOptions, context?: LoaderContext): Promise<number>;
5
+ export declare function loadDraco(tile: Tiles3DTileContent, dracoData: any, options?: Tiles3DLoaderOptions, context?: LoaderContext): Promise<void>;
6
+ //# sourceMappingURL=parse-3d-tile-point-cloud.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parse-3d-tile-point-cloud.d.ts","sourceRoot":"","sources":["../../../src/lib/parsers/parse-3d-tile-point-cloud.ts"],"names":[],"mappings":"AAcA,OAAO,EAAC,oBAAoB,EAAC,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAC,aAAa,EAAC,MAAM,0BAA0B,CAAC;AACvD,OAAO,EAAC,kBAAkB,EAAC,MAAM,aAAa,CAAC;AAE/C,wBAAsB,qBAAqB,CACzC,IAAI,EAAE,kBAAkB,EACxB,WAAW,EAAE,WAAW,EACxB,UAAU,EAAE,MAAM,EAClB,OAAO,CAAC,EAAE,oBAAoB,EAC9B,OAAO,CAAC,EAAE,aAAa,GACtB,OAAO,CAAC,MAAM,CAAC,CAgBjB;AAuND,wBAAsB,SAAS,CAC7B,IAAI,EAAE,kBAAkB,EACxB,SAAS,KAAA,EACT,OAAO,CAAC,EAAE,oBAAoB,EAC9B,OAAO,CAAC,EAAE,aAAa,GACtB,OAAO,CAAC,IAAI,CAAC,CAwDf"}