@itwin/core-frontend 3.4.0-dev.9 → 3.5.0-dev.5

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 (808) hide show
  1. package/CHANGELOG.md +37 -1
  2. package/lib/cjs/AccuDraw.d.ts.map +1 -1
  3. package/lib/cjs/AccuDraw.js +60 -15
  4. package/lib/cjs/AccuDraw.js.map +1 -1
  5. package/lib/cjs/AccuSnap.d.ts.map +1 -1
  6. package/lib/cjs/AccuSnap.js +46 -36
  7. package/lib/cjs/AccuSnap.js.map +1 -1
  8. package/lib/cjs/AuxCoordSys.d.ts.map +1 -1
  9. package/lib/cjs/AuxCoordSys.js +2 -3
  10. package/lib/cjs/AuxCoordSys.js.map +1 -1
  11. package/lib/cjs/BackgroundMapGeometry.d.ts.map +1 -1
  12. package/lib/cjs/BackgroundMapGeometry.js.map +1 -1
  13. package/lib/cjs/CategorySelectorState.d.ts.map +1 -1
  14. package/lib/cjs/CategorySelectorState.js +6 -4
  15. package/lib/cjs/CategorySelectorState.js.map +1 -1
  16. package/lib/cjs/ContextRealityModelState.d.ts.map +1 -1
  17. package/lib/cjs/ContextRealityModelState.js +2 -0
  18. package/lib/cjs/ContextRealityModelState.js.map +1 -1
  19. package/lib/cjs/DevTools.d.ts.map +1 -1
  20. package/lib/cjs/DevTools.js.map +1 -1
  21. package/lib/cjs/DisplayStyleState.js +1 -1
  22. package/lib/cjs/DisplayStyleState.js.map +1 -1
  23. package/lib/cjs/ElementLocateManager.d.ts.map +1 -1
  24. package/lib/cjs/ElementLocateManager.js +4 -2
  25. package/lib/cjs/ElementLocateManager.js.map +1 -1
  26. package/lib/cjs/FrustumAnimator.d.ts.map +1 -1
  27. package/lib/cjs/FrustumAnimator.js +5 -1
  28. package/lib/cjs/FrustumAnimator.js.map +1 -1
  29. package/lib/cjs/FuzzySearch.d.ts.map +1 -1
  30. package/lib/cjs/FuzzySearch.js +9 -3
  31. package/lib/cjs/FuzzySearch.js.map +1 -1
  32. package/lib/cjs/HitDetail.d.ts.map +1 -1
  33. package/lib/cjs/HitDetail.js +13 -3
  34. package/lib/cjs/HitDetail.js.map +1 -1
  35. package/lib/cjs/IModelApp.d.ts +7 -2
  36. package/lib/cjs/IModelApp.d.ts.map +1 -1
  37. package/lib/cjs/IModelApp.js +10 -2
  38. package/lib/cjs/IModelApp.js.map +1 -1
  39. package/lib/cjs/IModelConnection.d.ts.map +1 -1
  40. package/lib/cjs/IModelConnection.js +3 -1
  41. package/lib/cjs/IModelConnection.js.map +1 -1
  42. package/lib/cjs/ImageUtil.d.ts +6 -0
  43. package/lib/cjs/ImageUtil.d.ts.map +1 -1
  44. package/lib/cjs/ImageUtil.js +14 -1
  45. package/lib/cjs/ImageUtil.js.map +1 -1
  46. package/lib/cjs/Marker.d.ts.map +1 -1
  47. package/lib/cjs/Marker.js +5 -1
  48. package/lib/cjs/Marker.js.map +1 -1
  49. package/lib/cjs/ModelState.d.ts.map +1 -1
  50. package/lib/cjs/ModelState.js +5 -0
  51. package/lib/cjs/ModelState.js.map +1 -1
  52. package/lib/cjs/NativeAppLogger.d.ts.map +1 -1
  53. package/lib/cjs/NativeAppLogger.js +1 -1
  54. package/lib/cjs/NativeAppLogger.js.map +1 -1
  55. package/lib/cjs/TentativePoint.d.ts.map +1 -1
  56. package/lib/cjs/TentativePoint.js.map +1 -1
  57. package/lib/cjs/ViewManager.d.ts +4 -0
  58. package/lib/cjs/ViewManager.d.ts.map +1 -1
  59. package/lib/cjs/ViewManager.js +9 -3
  60. package/lib/cjs/ViewManager.js.map +1 -1
  61. package/lib/cjs/ViewRect.d.ts.map +1 -1
  62. package/lib/cjs/ViewRect.js +5 -1
  63. package/lib/cjs/ViewRect.js.map +1 -1
  64. package/lib/cjs/ViewState.d.ts +36 -12
  65. package/lib/cjs/ViewState.d.ts.map +1 -1
  66. package/lib/cjs/ViewState.js +35 -25
  67. package/lib/cjs/ViewState.js.map +1 -1
  68. package/lib/cjs/ViewingSpace.d.ts.map +1 -1
  69. package/lib/cjs/ViewingSpace.js +12 -5
  70. package/lib/cjs/ViewingSpace.js.map +1 -1
  71. package/lib/cjs/Viewport.d.ts +14 -0
  72. package/lib/cjs/Viewport.d.ts.map +1 -1
  73. package/lib/cjs/Viewport.js +107 -5
  74. package/lib/cjs/Viewport.js.map +1 -1
  75. package/lib/cjs/core-frontend.d.ts +6 -0
  76. package/lib/cjs/core-frontend.d.ts.map +1 -1
  77. package/lib/cjs/core-frontend.js +6 -0
  78. package/lib/cjs/core-frontend.js.map +1 -1
  79. package/lib/cjs/extension/ExtensionAdmin.d.ts.map +1 -1
  80. package/lib/cjs/extension/ExtensionAdmin.js.map +1 -1
  81. package/lib/cjs/extension/ExtensionImpl.d.ts.map +1 -1
  82. package/lib/cjs/extension/ExtensionImpl.js +3 -1
  83. package/lib/cjs/extension/ExtensionImpl.js.map +1 -1
  84. package/lib/cjs/public/scripts/checkbrowser.js +24 -0
  85. package/lib/cjs/render/Decorations.d.ts.map +1 -1
  86. package/lib/cjs/render/Decorations.js +24 -6
  87. package/lib/cjs/render/Decorations.js.map +1 -1
  88. package/lib/cjs/render/GraphicBranch.d.ts +5 -1
  89. package/lib/cjs/render/GraphicBranch.d.ts.map +1 -1
  90. package/lib/cjs/render/GraphicBranch.js.map +1 -1
  91. package/lib/cjs/render/RealityMeshGraphicParams.d.ts +19 -0
  92. package/lib/cjs/render/RealityMeshGraphicParams.d.ts.map +1 -0
  93. package/lib/cjs/render/RealityMeshGraphicParams.js +10 -0
  94. package/lib/cjs/render/RealityMeshGraphicParams.js.map +1 -0
  95. package/lib/cjs/render/RealityMeshParams.d.ts +130 -0
  96. package/lib/cjs/render/RealityMeshParams.d.ts.map +1 -0
  97. package/lib/cjs/render/RealityMeshParams.js +176 -0
  98. package/lib/cjs/render/RealityMeshParams.js.map +1 -0
  99. package/lib/cjs/render/RenderSystem.d.ts +8 -4
  100. package/lib/cjs/render/RenderSystem.d.ts.map +1 -1
  101. package/lib/cjs/render/RenderSystem.js +7 -1
  102. package/lib/cjs/render/RenderSystem.js.map +1 -1
  103. package/lib/cjs/render/RenderTexture.d.ts +1 -1
  104. package/lib/cjs/render/RenderTexture.d.ts.map +1 -1
  105. package/lib/cjs/render/RenderTexture.js.map +1 -1
  106. package/lib/cjs/render/UpsampleRealityMeshParams.d.ts +11 -0
  107. package/lib/cjs/render/UpsampleRealityMeshParams.d.ts.map +1 -0
  108. package/lib/cjs/render/UpsampleRealityMeshParams.js +205 -0
  109. package/lib/cjs/render/UpsampleRealityMeshParams.js.map +1 -0
  110. package/lib/cjs/render/primitives/DisplayParams.d.ts.map +1 -1
  111. package/lib/cjs/render/primitives/DisplayParams.js.map +1 -1
  112. package/lib/cjs/render/primitives/PointCloudPrimitive.d.ts +4 -8
  113. package/lib/cjs/render/primitives/PointCloudPrimitive.d.ts.map +1 -1
  114. package/lib/cjs/render/primitives/PointCloudPrimitive.js +0 -16
  115. package/lib/cjs/render/primitives/PointCloudPrimitive.js.map +1 -1
  116. package/lib/cjs/render/primitives/Polyface.d.ts.map +1 -1
  117. package/lib/cjs/render/primitives/Polyface.js +3 -1
  118. package/lib/cjs/render/primitives/Polyface.js.map +1 -1
  119. package/lib/cjs/render/primitives/Primitives.d.ts.map +1 -1
  120. package/lib/cjs/render/primitives/Primitives.js.map +1 -1
  121. package/lib/cjs/render/primitives/Strokes.d.ts.map +1 -1
  122. package/lib/cjs/render/primitives/Strokes.js +6 -2
  123. package/lib/cjs/render/primitives/Strokes.js.map +1 -1
  124. package/lib/cjs/render/primitives/VertexTableSplitter.d.ts.map +1 -1
  125. package/lib/cjs/render/primitives/VertexTableSplitter.js +7 -85
  126. package/lib/cjs/render/primitives/VertexTableSplitter.js.map +1 -1
  127. package/lib/cjs/render/primitives/geometry/GeometryAccumulator.d.ts.map +1 -1
  128. package/lib/cjs/render/primitives/geometry/GeometryAccumulator.js +4 -1
  129. package/lib/cjs/render/primitives/geometry/GeometryAccumulator.js.map +1 -1
  130. package/lib/cjs/render/primitives/mesh/MeshBuilder.d.ts.map +1 -1
  131. package/lib/cjs/render/primitives/mesh/MeshBuilder.js.map +1 -1
  132. package/lib/cjs/render/primitives/mesh/MeshPrimitives.d.ts +1 -1
  133. package/lib/cjs/render/primitives/mesh/MeshPrimitives.d.ts.map +1 -1
  134. package/lib/cjs/render/primitives/mesh/MeshPrimitives.js +3 -1
  135. package/lib/cjs/render/primitives/mesh/MeshPrimitives.js.map +1 -1
  136. package/lib/cjs/render/webgl/BackgroundMapDrape.d.ts.map +1 -1
  137. package/lib/cjs/render/webgl/BackgroundMapDrape.js.map +1 -1
  138. package/lib/cjs/render/webgl/BranchState.d.ts +3 -1
  139. package/lib/cjs/render/webgl/BranchState.d.ts.map +1 -1
  140. package/lib/cjs/render/webgl/BranchState.js +18 -15
  141. package/lib/cjs/render/webgl/BranchState.js.map +1 -1
  142. package/lib/cjs/render/webgl/BranchUniforms.d.ts.map +1 -1
  143. package/lib/cjs/render/webgl/BranchUniforms.js +4 -0
  144. package/lib/cjs/render/webgl/BranchUniforms.js.map +1 -1
  145. package/lib/cjs/render/webgl/ColorInfo.d.ts.map +1 -1
  146. package/lib/cjs/render/webgl/ColorInfo.js +4 -1
  147. package/lib/cjs/render/webgl/ColorInfo.js.map +1 -1
  148. package/lib/cjs/render/webgl/DrawCommand.d.ts.map +1 -1
  149. package/lib/cjs/render/webgl/DrawCommand.js +12 -3
  150. package/lib/cjs/render/webgl/DrawCommand.js.map +1 -1
  151. package/lib/cjs/render/webgl/FrameBuffer.d.ts.map +1 -1
  152. package/lib/cjs/render/webgl/FrameBuffer.js +4 -1
  153. package/lib/cjs/render/webgl/FrameBuffer.js.map +1 -1
  154. package/lib/cjs/render/webgl/FrustumUniforms.js.map +1 -1
  155. package/lib/cjs/render/webgl/Graphic.d.ts.map +1 -1
  156. package/lib/cjs/render/webgl/Graphic.js +5 -2
  157. package/lib/cjs/render/webgl/Graphic.js.map +1 -1
  158. package/lib/cjs/render/webgl/Matrix.d.ts.map +1 -1
  159. package/lib/cjs/render/webgl/Matrix.js +16 -4
  160. package/lib/cjs/render/webgl/Matrix.js.map +1 -1
  161. package/lib/cjs/render/webgl/PerformanceMetrics.js +2 -2
  162. package/lib/cjs/render/webgl/PerformanceMetrics.js.map +1 -1
  163. package/lib/cjs/render/webgl/PlanarClassifier.d.ts.map +1 -1
  164. package/lib/cjs/render/webgl/PlanarClassifier.js +3 -1
  165. package/lib/cjs/render/webgl/PlanarClassifier.js.map +1 -1
  166. package/lib/cjs/render/webgl/PlanarTextureProjection.d.ts.map +1 -1
  167. package/lib/cjs/render/webgl/PlanarTextureProjection.js.map +1 -1
  168. package/lib/cjs/render/webgl/PointCloud.d.ts +1 -2
  169. package/lib/cjs/render/webgl/PointCloud.d.ts.map +1 -1
  170. package/lib/cjs/render/webgl/PointCloud.js +7 -7
  171. package/lib/cjs/render/webgl/PointCloud.js.map +1 -1
  172. package/lib/cjs/render/webgl/Primitive.d.ts.map +1 -1
  173. package/lib/cjs/render/webgl/Primitive.js.map +1 -1
  174. package/lib/cjs/render/webgl/RealityMesh.d.ts +6 -6
  175. package/lib/cjs/render/webgl/RealityMesh.d.ts.map +1 -1
  176. package/lib/cjs/render/webgl/RealityMesh.js +20 -12
  177. package/lib/cjs/render/webgl/RealityMesh.js.map +1 -1
  178. package/lib/cjs/render/webgl/RealityModelUniforms.d.ts +35 -0
  179. package/lib/cjs/render/webgl/RealityModelUniforms.d.ts.map +1 -0
  180. package/lib/cjs/render/webgl/RealityModelUniforms.js +73 -0
  181. package/lib/cjs/render/webgl/RealityModelUniforms.js.map +1 -0
  182. package/lib/cjs/render/webgl/RenderCommands.d.ts.map +1 -1
  183. package/lib/cjs/render/webgl/RenderCommands.js +3 -2
  184. package/lib/cjs/render/webgl/RenderCommands.js.map +1 -1
  185. package/lib/cjs/render/webgl/RenderFlags.d.ts.map +1 -1
  186. package/lib/cjs/render/webgl/RenderFlags.js +3 -1
  187. package/lib/cjs/render/webgl/RenderFlags.js.map +1 -1
  188. package/lib/cjs/render/webgl/ShaderBuilder.d.ts.map +1 -1
  189. package/lib/cjs/render/webgl/ShaderBuilder.js +4 -1
  190. package/lib/cjs/render/webgl/ShaderBuilder.js.map +1 -1
  191. package/lib/cjs/render/webgl/SolarShadowMap.d.ts.map +1 -1
  192. package/lib/cjs/render/webgl/SolarShadowMap.js +17 -5
  193. package/lib/cjs/render/webgl/SolarShadowMap.js.map +1 -1
  194. package/lib/cjs/render/webgl/System.d.ts +6 -4
  195. package/lib/cjs/render/webgl/System.d.ts.map +1 -1
  196. package/lib/cjs/render/webgl/System.js +21 -4
  197. package/lib/cjs/render/webgl/System.js.map +1 -1
  198. package/lib/cjs/render/webgl/TargetUniforms.d.ts +2 -0
  199. package/lib/cjs/render/webgl/TargetUniforms.d.ts.map +1 -1
  200. package/lib/cjs/render/webgl/TargetUniforms.js +2 -0
  201. package/lib/cjs/render/webgl/TargetUniforms.js.map +1 -1
  202. package/lib/cjs/render/webgl/Technique.d.ts.map +1 -1
  203. package/lib/cjs/render/webgl/Technique.js +6 -31
  204. package/lib/cjs/render/webgl/Technique.js.map +1 -1
  205. package/lib/cjs/render/webgl/TechniqueFlags.d.ts.map +1 -1
  206. package/lib/cjs/render/webgl/TechniqueFlags.js.map +1 -1
  207. package/lib/cjs/render/webgl/Texture.d.ts.map +1 -1
  208. package/lib/cjs/render/webgl/Texture.js +21 -12
  209. package/lib/cjs/render/webgl/Texture.js.map +1 -1
  210. package/lib/cjs/render/webgl/ThematicSensors.d.ts.map +1 -1
  211. package/lib/cjs/render/webgl/ThematicSensors.js +8 -2
  212. package/lib/cjs/render/webgl/ThematicSensors.js.map +1 -1
  213. package/lib/cjs/render/webgl/glsl/AmbientOcclusion.d.ts.map +1 -1
  214. package/lib/cjs/render/webgl/glsl/AmbientOcclusion.js +3 -1
  215. package/lib/cjs/render/webgl/glsl/AmbientOcclusion.js.map +1 -1
  216. package/lib/cjs/render/webgl/glsl/Common.js +1 -1
  217. package/lib/cjs/render/webgl/glsl/Common.js.map +1 -1
  218. package/lib/cjs/render/webgl/glsl/PointCloud.d.ts.map +1 -1
  219. package/lib/cjs/render/webgl/glsl/PointCloud.js +43 -20
  220. package/lib/cjs/render/webgl/glsl/PointCloud.js.map +1 -1
  221. package/lib/cjs/render/webgl/glsl/RealityMesh.d.ts +4 -2
  222. package/lib/cjs/render/webgl/glsl/RealityMesh.d.ts.map +1 -1
  223. package/lib/cjs/render/webgl/glsl/RealityMesh.js +5 -3
  224. package/lib/cjs/render/webgl/glsl/RealityMesh.js.map +1 -1
  225. package/lib/cjs/render/webgl/glsl/SkyBox.d.ts.map +1 -1
  226. package/lib/cjs/render/webgl/glsl/SkyBox.js.map +1 -1
  227. package/lib/cjs/tile/GltfReader.d.ts +3 -2
  228. package/lib/cjs/tile/GltfReader.d.ts.map +1 -1
  229. package/lib/cjs/tile/GltfReader.js +7 -3
  230. package/lib/cjs/tile/GltfReader.js.map +1 -1
  231. package/lib/cjs/tile/ImdlReader.d.ts +1 -1
  232. package/lib/cjs/tile/ImdlReader.js.map +1 -1
  233. package/lib/cjs/tile/OPCFormatInterpreter.d.ts.map +1 -1
  234. package/lib/cjs/tile/OPCFormatInterpreter.js +3 -1
  235. package/lib/cjs/tile/OPCFormatInterpreter.js.map +1 -1
  236. package/lib/cjs/tile/OrbitGtTileTree.d.ts.map +1 -1
  237. package/lib/cjs/tile/OrbitGtTileTree.js +8 -2
  238. package/lib/cjs/tile/OrbitGtTileTree.js.map +1 -1
  239. package/lib/cjs/tile/PntsReader.d.ts.map +1 -1
  240. package/lib/cjs/tile/PntsReader.js +8 -2
  241. package/lib/cjs/tile/PntsReader.js.map +1 -1
  242. package/lib/cjs/tile/PrimaryTileTree.d.ts.map +1 -1
  243. package/lib/cjs/tile/PrimaryTileTree.js +14 -11
  244. package/lib/cjs/tile/PrimaryTileTree.js.map +1 -1
  245. package/lib/cjs/tile/RealityModelTileTree.d.ts +4 -1
  246. package/lib/cjs/tile/RealityModelTileTree.d.ts.map +1 -1
  247. package/lib/cjs/tile/RealityModelTileTree.js +8 -0
  248. package/lib/cjs/tile/RealityModelTileTree.js.map +1 -1
  249. package/lib/cjs/tile/RealityTile.d.ts +57 -3
  250. package/lib/cjs/tile/RealityTile.d.ts.map +1 -1
  251. package/lib/cjs/tile/RealityTile.js +49 -5
  252. package/lib/cjs/tile/RealityTile.js.map +1 -1
  253. package/lib/cjs/tile/RealityTileLoader.d.ts.map +1 -1
  254. package/lib/cjs/tile/RealityTileLoader.js.map +1 -1
  255. package/lib/cjs/tile/RealityTileTree.d.ts +37 -2
  256. package/lib/cjs/tile/RealityTileTree.d.ts.map +1 -1
  257. package/lib/cjs/tile/RealityTileTree.js +30 -2
  258. package/lib/cjs/tile/RealityTileTree.js.map +1 -1
  259. package/lib/cjs/tile/ThreeDTileFormatInterpreter.d.ts.map +1 -1
  260. package/lib/cjs/tile/ThreeDTileFormatInterpreter.js +6 -2
  261. package/lib/cjs/tile/ThreeDTileFormatInterpreter.js.map +1 -1
  262. package/lib/cjs/tile/TileAdmin.d.ts +12 -0
  263. package/lib/cjs/tile/TileAdmin.d.ts.map +1 -1
  264. package/lib/cjs/tile/TileAdmin.js +54 -4
  265. package/lib/cjs/tile/TileAdmin.js.map +1 -1
  266. package/lib/cjs/tile/TileDrawArgs.d.ts.map +1 -1
  267. package/lib/cjs/tile/TileDrawArgs.js +10 -16
  268. package/lib/cjs/tile/TileDrawArgs.js.map +1 -1
  269. package/lib/cjs/tile/TileRequest.d.ts +5 -1
  270. package/lib/cjs/tile/TileRequest.d.ts.map +1 -1
  271. package/lib/cjs/tile/TileRequest.js +6 -2
  272. package/lib/cjs/tile/TileRequest.js.map +1 -1
  273. package/lib/cjs/tile/TileStorage.d.ts +13 -0
  274. package/lib/cjs/tile/TileStorage.d.ts.map +1 -0
  275. package/lib/cjs/tile/TileStorage.js +50 -0
  276. package/lib/cjs/tile/TileStorage.js.map +1 -0
  277. package/lib/cjs/tile/internal.d.ts +2 -0
  278. package/lib/cjs/tile/internal.d.ts.map +1 -1
  279. package/lib/cjs/tile/internal.js +2 -0
  280. package/lib/cjs/tile/internal.js.map +1 -1
  281. package/lib/cjs/tile/map/ArcGISTileMap.js +1 -1
  282. package/lib/cjs/tile/map/ArcGISTileMap.js.map +1 -1
  283. package/lib/cjs/tile/map/ArcGisUtilities.d.ts +0 -2
  284. package/lib/cjs/tile/map/ArcGisUtilities.d.ts.map +1 -1
  285. package/lib/cjs/tile/map/ArcGisUtilities.js +1 -24
  286. package/lib/cjs/tile/map/ArcGisUtilities.js.map +1 -1
  287. package/lib/cjs/tile/map/BingElevation.d.ts +8 -3
  288. package/lib/cjs/tile/map/BingElevation.d.ts.map +1 -1
  289. package/lib/cjs/tile/map/BingElevation.js +36 -14
  290. package/lib/cjs/tile/map/BingElevation.js.map +1 -1
  291. package/lib/cjs/tile/map/CesiumTerrainProvider.d.ts +2 -7
  292. package/lib/cjs/tile/map/CesiumTerrainProvider.d.ts.map +1 -1
  293. package/lib/cjs/tile/map/CesiumTerrainProvider.js +100 -90
  294. package/lib/cjs/tile/map/CesiumTerrainProvider.js.map +1 -1
  295. package/lib/cjs/tile/map/EllipsoidTerrainProvider.d.ts +9 -12
  296. package/lib/cjs/tile/map/EllipsoidTerrainProvider.d.ts.map +1 -1
  297. package/lib/cjs/tile/map/EllipsoidTerrainProvider.js +70 -67
  298. package/lib/cjs/tile/map/EllipsoidTerrainProvider.js.map +1 -1
  299. package/lib/cjs/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.d.ts.map +1 -1
  300. package/lib/cjs/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js +9 -16
  301. package/lib/cjs/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js.map +1 -1
  302. package/lib/cjs/tile/map/ImageryProviders/BingImageryProvider.d.ts.map +1 -1
  303. package/lib/cjs/tile/map/ImageryProviders/BingImageryProvider.js +1 -1
  304. package/lib/cjs/tile/map/ImageryProviders/BingImageryProvider.js.map +1 -1
  305. package/lib/cjs/tile/map/ImageryProviders/MapBoxLayerImageryProvider.d.ts.map +1 -1
  306. package/lib/cjs/tile/map/ImageryProviders/MapBoxLayerImageryProvider.js.map +1 -1
  307. package/lib/cjs/tile/map/ImageryProviders/WmsMapLayerImageryProvider.d.ts.map +1 -1
  308. package/lib/cjs/tile/map/ImageryProviders/WmsMapLayerImageryProvider.js +8 -6
  309. package/lib/cjs/tile/map/ImageryProviders/WmsMapLayerImageryProvider.js.map +1 -1
  310. package/lib/cjs/tile/map/ImageryProviders/WmtsMapLayerImageryProvider.js +3 -3
  311. package/lib/cjs/tile/map/ImageryProviders/WmtsMapLayerImageryProvider.js.map +1 -1
  312. package/lib/cjs/tile/map/ImageryTileTree.d.ts.map +1 -1
  313. package/lib/cjs/tile/map/ImageryTileTree.js +21 -6
  314. package/lib/cjs/tile/map/ImageryTileTree.js.map +1 -1
  315. package/lib/cjs/tile/map/MapCartoRectangle.d.ts +62 -6
  316. package/lib/cjs/tile/map/MapCartoRectangle.d.ts.map +1 -1
  317. package/lib/cjs/tile/map/MapCartoRectangle.js +103 -17
  318. package/lib/cjs/tile/map/MapCartoRectangle.js.map +1 -1
  319. package/lib/cjs/tile/map/MapLayerImageryFormats.d.ts.map +1 -1
  320. package/lib/cjs/tile/map/MapLayerImageryFormats.js +4 -2
  321. package/lib/cjs/tile/map/MapLayerImageryFormats.js.map +1 -1
  322. package/lib/cjs/tile/map/MapLayerImageryProvider.d.ts.map +1 -1
  323. package/lib/cjs/tile/map/MapLayerImageryProvider.js +1 -1
  324. package/lib/cjs/tile/map/MapLayerImageryProvider.js.map +1 -1
  325. package/lib/cjs/tile/map/MapLayerSources.d.ts.map +1 -1
  326. package/lib/cjs/tile/map/MapLayerSources.js +11 -7
  327. package/lib/cjs/tile/map/MapLayerSources.js.map +1 -1
  328. package/lib/cjs/tile/map/MapTile.d.ts +68 -15
  329. package/lib/cjs/tile/map/MapTile.d.ts.map +1 -1
  330. package/lib/cjs/tile/map/MapTile.js +88 -30
  331. package/lib/cjs/tile/map/MapTile.js.map +1 -1
  332. package/lib/cjs/tile/map/MapTileAvailability.d.ts.map +1 -1
  333. package/lib/cjs/tile/map/MapTileAvailability.js +1 -1
  334. package/lib/cjs/tile/map/MapTileAvailability.js.map +1 -1
  335. package/lib/cjs/tile/map/MapTileLoader.d.ts +2 -2
  336. package/lib/cjs/tile/map/MapTileLoader.d.ts.map +1 -1
  337. package/lib/cjs/tile/map/MapTileLoader.js +11 -20
  338. package/lib/cjs/tile/map/MapTileLoader.js.map +1 -1
  339. package/lib/cjs/tile/map/MapTileTree.d.ts +72 -7
  340. package/lib/cjs/tile/map/MapTileTree.d.ts.map +1 -1
  341. package/lib/cjs/tile/map/MapTileTree.js +72 -16
  342. package/lib/cjs/tile/map/MapTileTree.js.map +1 -1
  343. package/lib/cjs/tile/map/MapTilingScheme.d.ts +67 -55
  344. package/lib/cjs/tile/map/MapTilingScheme.d.ts.map +1 -1
  345. package/lib/cjs/tile/map/MapTilingScheme.js +71 -67
  346. package/lib/cjs/tile/map/MapTilingScheme.js.map +1 -1
  347. package/lib/cjs/tile/map/QuadId.d.ts +24 -2
  348. package/lib/cjs/tile/map/QuadId.d.ts.map +1 -1
  349. package/lib/cjs/tile/map/QuadId.js +49 -20
  350. package/lib/cjs/tile/map/QuadId.js.map +1 -1
  351. package/lib/cjs/tile/map/TerrainMeshProvider.d.ts +79 -19
  352. package/lib/cjs/tile/map/TerrainMeshProvider.d.ts.map +1 -1
  353. package/lib/cjs/tile/map/TerrainMeshProvider.js +28 -13
  354. package/lib/cjs/tile/map/TerrainMeshProvider.js.map +1 -1
  355. package/lib/cjs/tile/map/TerrainProvider.d.ts +34 -0
  356. package/lib/cjs/tile/map/TerrainProvider.d.ts.map +1 -0
  357. package/lib/cjs/tile/map/TerrainProvider.js +41 -0
  358. package/lib/cjs/tile/map/TerrainProvider.js.map +1 -0
  359. package/lib/cjs/tile/map/WmsCapabilities.js +1 -1
  360. package/lib/cjs/tile/map/WmsCapabilities.js.map +1 -1
  361. package/lib/cjs/tile/map/WmtsCapabilities.d.ts.map +1 -1
  362. package/lib/cjs/tile/map/WmtsCapabilities.js +7 -3
  363. package/lib/cjs/tile/map/WmtsCapabilities.js.map +1 -1
  364. package/lib/cjs/tile/object-storage-azure.js +5 -0
  365. package/lib/cjs/tools/AccuDrawTool.d.ts.map +1 -1
  366. package/lib/cjs/tools/AccuDrawTool.js +87 -26
  367. package/lib/cjs/tools/AccuDrawTool.js.map +1 -1
  368. package/lib/cjs/tools/ClipViewTool.d.ts +2 -2
  369. package/lib/cjs/tools/ClipViewTool.d.ts.map +1 -1
  370. package/lib/cjs/tools/ClipViewTool.js +29 -16
  371. package/lib/cjs/tools/ClipViewTool.js.map +1 -1
  372. package/lib/cjs/tools/ElementSetTool.d.ts.map +1 -1
  373. package/lib/cjs/tools/ElementSetTool.js +26 -10
  374. package/lib/cjs/tools/ElementSetTool.js.map +1 -1
  375. package/lib/cjs/tools/MeasureTool.d.ts.map +1 -1
  376. package/lib/cjs/tools/MeasureTool.js +65 -41
  377. package/lib/cjs/tools/MeasureTool.js.map +1 -1
  378. package/lib/cjs/tools/PrimitiveTool.d.ts.map +1 -1
  379. package/lib/cjs/tools/PrimitiveTool.js +9 -4
  380. package/lib/cjs/tools/PrimitiveTool.js.map +1 -1
  381. package/lib/cjs/tools/SelectTool.d.ts.map +1 -1
  382. package/lib/cjs/tools/SelectTool.js +20 -9
  383. package/lib/cjs/tools/SelectTool.js.map +1 -1
  384. package/lib/cjs/tools/Tool.d.ts.map +1 -1
  385. package/lib/cjs/tools/Tool.js +13 -5
  386. package/lib/cjs/tools/Tool.js.map +1 -1
  387. package/lib/cjs/tools/ToolAdmin.d.ts.map +1 -1
  388. package/lib/cjs/tools/ToolAdmin.js +27 -9
  389. package/lib/cjs/tools/ToolAdmin.js.map +1 -1
  390. package/lib/cjs/tools/ViewTool.d.ts.map +1 -1
  391. package/lib/cjs/tools/ViewTool.js +111 -40
  392. package/lib/cjs/tools/ViewTool.js.map +1 -1
  393. package/lib/cjs/webgl.d.ts +1 -0
  394. package/lib/cjs/webgl.d.ts.map +1 -1
  395. package/lib/cjs/webgl.js +1 -0
  396. package/lib/cjs/webgl.js.map +1 -1
  397. package/lib/esm/AccuDraw.d.ts.map +1 -1
  398. package/lib/esm/AccuDraw.js +60 -15
  399. package/lib/esm/AccuDraw.js.map +1 -1
  400. package/lib/esm/AccuSnap.d.ts.map +1 -1
  401. package/lib/esm/AccuSnap.js +47 -37
  402. package/lib/esm/AccuSnap.js.map +1 -1
  403. package/lib/esm/AuxCoordSys.d.ts.map +1 -1
  404. package/lib/esm/AuxCoordSys.js +2 -3
  405. package/lib/esm/AuxCoordSys.js.map +1 -1
  406. package/lib/esm/BackgroundMapGeometry.d.ts.map +1 -1
  407. package/lib/esm/BackgroundMapGeometry.js.map +1 -1
  408. package/lib/esm/CategorySelectorState.d.ts.map +1 -1
  409. package/lib/esm/CategorySelectorState.js +6 -4
  410. package/lib/esm/CategorySelectorState.js.map +1 -1
  411. package/lib/esm/ContextRealityModelState.d.ts.map +1 -1
  412. package/lib/esm/ContextRealityModelState.js +2 -0
  413. package/lib/esm/ContextRealityModelState.js.map +1 -1
  414. package/lib/esm/DevTools.d.ts.map +1 -1
  415. package/lib/esm/DevTools.js.map +1 -1
  416. package/lib/esm/DisplayStyleState.js +1 -1
  417. package/lib/esm/DisplayStyleState.js.map +1 -1
  418. package/lib/esm/ElementLocateManager.d.ts.map +1 -1
  419. package/lib/esm/ElementLocateManager.js +4 -2
  420. package/lib/esm/ElementLocateManager.js.map +1 -1
  421. package/lib/esm/FrustumAnimator.d.ts.map +1 -1
  422. package/lib/esm/FrustumAnimator.js +5 -1
  423. package/lib/esm/FrustumAnimator.js.map +1 -1
  424. package/lib/esm/FuzzySearch.d.ts.map +1 -1
  425. package/lib/esm/FuzzySearch.js +9 -3
  426. package/lib/esm/FuzzySearch.js.map +1 -1
  427. package/lib/esm/HitDetail.d.ts.map +1 -1
  428. package/lib/esm/HitDetail.js +13 -3
  429. package/lib/esm/HitDetail.js.map +1 -1
  430. package/lib/esm/IModelApp.d.ts +7 -2
  431. package/lib/esm/IModelApp.d.ts.map +1 -1
  432. package/lib/esm/IModelApp.js +11 -3
  433. package/lib/esm/IModelApp.js.map +1 -1
  434. package/lib/esm/IModelConnection.d.ts.map +1 -1
  435. package/lib/esm/IModelConnection.js +3 -1
  436. package/lib/esm/IModelConnection.js.map +1 -1
  437. package/lib/esm/ImageUtil.d.ts +6 -0
  438. package/lib/esm/ImageUtil.d.ts.map +1 -1
  439. package/lib/esm/ImageUtil.js +12 -0
  440. package/lib/esm/ImageUtil.js.map +1 -1
  441. package/lib/esm/Marker.d.ts.map +1 -1
  442. package/lib/esm/Marker.js +5 -1
  443. package/lib/esm/Marker.js.map +1 -1
  444. package/lib/esm/ModelState.d.ts.map +1 -1
  445. package/lib/esm/ModelState.js +6 -1
  446. package/lib/esm/ModelState.js.map +1 -1
  447. package/lib/esm/NativeAppLogger.d.ts.map +1 -1
  448. package/lib/esm/NativeAppLogger.js +1 -1
  449. package/lib/esm/NativeAppLogger.js.map +1 -1
  450. package/lib/esm/TentativePoint.d.ts.map +1 -1
  451. package/lib/esm/TentativePoint.js.map +1 -1
  452. package/lib/esm/ViewManager.d.ts +4 -0
  453. package/lib/esm/ViewManager.d.ts.map +1 -1
  454. package/lib/esm/ViewManager.js +9 -3
  455. package/lib/esm/ViewManager.js.map +1 -1
  456. package/lib/esm/ViewRect.d.ts.map +1 -1
  457. package/lib/esm/ViewRect.js +5 -1
  458. package/lib/esm/ViewRect.js.map +1 -1
  459. package/lib/esm/ViewState.d.ts +36 -12
  460. package/lib/esm/ViewState.d.ts.map +1 -1
  461. package/lib/esm/ViewState.js +35 -25
  462. package/lib/esm/ViewState.js.map +1 -1
  463. package/lib/esm/ViewingSpace.d.ts.map +1 -1
  464. package/lib/esm/ViewingSpace.js +12 -5
  465. package/lib/esm/ViewingSpace.js.map +1 -1
  466. package/lib/esm/Viewport.d.ts +14 -0
  467. package/lib/esm/Viewport.d.ts.map +1 -1
  468. package/lib/esm/Viewport.js +107 -5
  469. package/lib/esm/Viewport.js.map +1 -1
  470. package/lib/esm/core-frontend.d.ts +6 -0
  471. package/lib/esm/core-frontend.d.ts.map +1 -1
  472. package/lib/esm/core-frontend.js +6 -0
  473. package/lib/esm/core-frontend.js.map +1 -1
  474. package/lib/esm/extension/ExtensionAdmin.d.ts.map +1 -1
  475. package/lib/esm/extension/ExtensionAdmin.js.map +1 -1
  476. package/lib/esm/extension/ExtensionImpl.d.ts.map +1 -1
  477. package/lib/esm/extension/ExtensionImpl.js +3 -1
  478. package/lib/esm/extension/ExtensionImpl.js.map +1 -1
  479. package/lib/esm/public/scripts/checkbrowser.js +24 -0
  480. package/lib/esm/render/Decorations.d.ts.map +1 -1
  481. package/lib/esm/render/Decorations.js +24 -6
  482. package/lib/esm/render/Decorations.js.map +1 -1
  483. package/lib/esm/render/GraphicBranch.d.ts +5 -1
  484. package/lib/esm/render/GraphicBranch.d.ts.map +1 -1
  485. package/lib/esm/render/GraphicBranch.js.map +1 -1
  486. package/lib/esm/render/RealityMeshGraphicParams.d.ts +19 -0
  487. package/lib/esm/render/RealityMeshGraphicParams.d.ts.map +1 -0
  488. package/lib/esm/render/RealityMeshGraphicParams.js +9 -0
  489. package/lib/esm/render/RealityMeshGraphicParams.js.map +1 -0
  490. package/lib/esm/render/RealityMeshParams.d.ts +130 -0
  491. package/lib/esm/render/RealityMeshParams.d.ts.map +1 -0
  492. package/lib/esm/render/RealityMeshParams.js +172 -0
  493. package/lib/esm/render/RealityMeshParams.js.map +1 -0
  494. package/lib/esm/render/RenderSystem.d.ts +8 -4
  495. package/lib/esm/render/RenderSystem.d.ts.map +1 -1
  496. package/lib/esm/render/RenderSystem.js +7 -1
  497. package/lib/esm/render/RenderSystem.js.map +1 -1
  498. package/lib/esm/render/RenderTexture.d.ts +1 -1
  499. package/lib/esm/render/RenderTexture.d.ts.map +1 -1
  500. package/lib/esm/render/RenderTexture.js.map +1 -1
  501. package/lib/esm/render/UpsampleRealityMeshParams.d.ts +11 -0
  502. package/lib/esm/render/UpsampleRealityMeshParams.d.ts.map +1 -0
  503. package/lib/esm/render/UpsampleRealityMeshParams.js +201 -0
  504. package/lib/esm/render/UpsampleRealityMeshParams.js.map +1 -0
  505. package/lib/esm/render/primitives/DisplayParams.d.ts.map +1 -1
  506. package/lib/esm/render/primitives/DisplayParams.js.map +1 -1
  507. package/lib/esm/render/primitives/PointCloudPrimitive.d.ts +4 -8
  508. package/lib/esm/render/primitives/PointCloudPrimitive.d.ts.map +1 -1
  509. package/lib/esm/render/primitives/PointCloudPrimitive.js +1 -14
  510. package/lib/esm/render/primitives/PointCloudPrimitive.js.map +1 -1
  511. package/lib/esm/render/primitives/Polyface.d.ts.map +1 -1
  512. package/lib/esm/render/primitives/Polyface.js +3 -1
  513. package/lib/esm/render/primitives/Polyface.js.map +1 -1
  514. package/lib/esm/render/primitives/Primitives.d.ts.map +1 -1
  515. package/lib/esm/render/primitives/Primitives.js.map +1 -1
  516. package/lib/esm/render/primitives/Strokes.d.ts.map +1 -1
  517. package/lib/esm/render/primitives/Strokes.js +6 -2
  518. package/lib/esm/render/primitives/Strokes.js.map +1 -1
  519. package/lib/esm/render/primitives/VertexTableSplitter.d.ts.map +1 -1
  520. package/lib/esm/render/primitives/VertexTableSplitter.js +1 -79
  521. package/lib/esm/render/primitives/VertexTableSplitter.js.map +1 -1
  522. package/lib/esm/render/primitives/geometry/GeometryAccumulator.d.ts.map +1 -1
  523. package/lib/esm/render/primitives/geometry/GeometryAccumulator.js +4 -1
  524. package/lib/esm/render/primitives/geometry/GeometryAccumulator.js.map +1 -1
  525. package/lib/esm/render/primitives/mesh/MeshBuilder.d.ts.map +1 -1
  526. package/lib/esm/render/primitives/mesh/MeshBuilder.js.map +1 -1
  527. package/lib/esm/render/primitives/mesh/MeshPrimitives.d.ts +1 -1
  528. package/lib/esm/render/primitives/mesh/MeshPrimitives.d.ts.map +1 -1
  529. package/lib/esm/render/primitives/mesh/MeshPrimitives.js +3 -1
  530. package/lib/esm/render/primitives/mesh/MeshPrimitives.js.map +1 -1
  531. package/lib/esm/render/webgl/BackgroundMapDrape.d.ts.map +1 -1
  532. package/lib/esm/render/webgl/BackgroundMapDrape.js.map +1 -1
  533. package/lib/esm/render/webgl/BranchState.d.ts +3 -1
  534. package/lib/esm/render/webgl/BranchState.d.ts.map +1 -1
  535. package/lib/esm/render/webgl/BranchState.js +18 -15
  536. package/lib/esm/render/webgl/BranchState.js.map +1 -1
  537. package/lib/esm/render/webgl/BranchUniforms.d.ts.map +1 -1
  538. package/lib/esm/render/webgl/BranchUniforms.js +4 -0
  539. package/lib/esm/render/webgl/BranchUniforms.js.map +1 -1
  540. package/lib/esm/render/webgl/ColorInfo.d.ts.map +1 -1
  541. package/lib/esm/render/webgl/ColorInfo.js +4 -1
  542. package/lib/esm/render/webgl/ColorInfo.js.map +1 -1
  543. package/lib/esm/render/webgl/DrawCommand.d.ts.map +1 -1
  544. package/lib/esm/render/webgl/DrawCommand.js +12 -3
  545. package/lib/esm/render/webgl/DrawCommand.js.map +1 -1
  546. package/lib/esm/render/webgl/FrameBuffer.d.ts.map +1 -1
  547. package/lib/esm/render/webgl/FrameBuffer.js +4 -1
  548. package/lib/esm/render/webgl/FrameBuffer.js.map +1 -1
  549. package/lib/esm/render/webgl/FrustumUniforms.js.map +1 -1
  550. package/lib/esm/render/webgl/Graphic.d.ts.map +1 -1
  551. package/lib/esm/render/webgl/Graphic.js +5 -2
  552. package/lib/esm/render/webgl/Graphic.js.map +1 -1
  553. package/lib/esm/render/webgl/Matrix.d.ts.map +1 -1
  554. package/lib/esm/render/webgl/Matrix.js +16 -4
  555. package/lib/esm/render/webgl/Matrix.js.map +1 -1
  556. package/lib/esm/render/webgl/PerformanceMetrics.js +2 -2
  557. package/lib/esm/render/webgl/PerformanceMetrics.js.map +1 -1
  558. package/lib/esm/render/webgl/PlanarClassifier.d.ts.map +1 -1
  559. package/lib/esm/render/webgl/PlanarClassifier.js +3 -1
  560. package/lib/esm/render/webgl/PlanarClassifier.js.map +1 -1
  561. package/lib/esm/render/webgl/PlanarTextureProjection.d.ts.map +1 -1
  562. package/lib/esm/render/webgl/PlanarTextureProjection.js.map +1 -1
  563. package/lib/esm/render/webgl/PointCloud.d.ts +1 -2
  564. package/lib/esm/render/webgl/PointCloud.d.ts.map +1 -1
  565. package/lib/esm/render/webgl/PointCloud.js +7 -7
  566. package/lib/esm/render/webgl/PointCloud.js.map +1 -1
  567. package/lib/esm/render/webgl/Primitive.d.ts.map +1 -1
  568. package/lib/esm/render/webgl/Primitive.js.map +1 -1
  569. package/lib/esm/render/webgl/RealityMesh.d.ts +6 -6
  570. package/lib/esm/render/webgl/RealityMesh.d.ts.map +1 -1
  571. package/lib/esm/render/webgl/RealityMesh.js +20 -12
  572. package/lib/esm/render/webgl/RealityMesh.js.map +1 -1
  573. package/lib/esm/render/webgl/RealityModelUniforms.d.ts +35 -0
  574. package/lib/esm/render/webgl/RealityModelUniforms.d.ts.map +1 -0
  575. package/lib/esm/render/webgl/RealityModelUniforms.js +68 -0
  576. package/lib/esm/render/webgl/RealityModelUniforms.js.map +1 -0
  577. package/lib/esm/render/webgl/RenderCommands.d.ts.map +1 -1
  578. package/lib/esm/render/webgl/RenderCommands.js +3 -2
  579. package/lib/esm/render/webgl/RenderCommands.js.map +1 -1
  580. package/lib/esm/render/webgl/RenderFlags.d.ts.map +1 -1
  581. package/lib/esm/render/webgl/RenderFlags.js +3 -1
  582. package/lib/esm/render/webgl/RenderFlags.js.map +1 -1
  583. package/lib/esm/render/webgl/ShaderBuilder.d.ts.map +1 -1
  584. package/lib/esm/render/webgl/ShaderBuilder.js +4 -1
  585. package/lib/esm/render/webgl/ShaderBuilder.js.map +1 -1
  586. package/lib/esm/render/webgl/SolarShadowMap.d.ts.map +1 -1
  587. package/lib/esm/render/webgl/SolarShadowMap.js +17 -5
  588. package/lib/esm/render/webgl/SolarShadowMap.js.map +1 -1
  589. package/lib/esm/render/webgl/System.d.ts +6 -4
  590. package/lib/esm/render/webgl/System.d.ts.map +1 -1
  591. package/lib/esm/render/webgl/System.js +21 -4
  592. package/lib/esm/render/webgl/System.js.map +1 -1
  593. package/lib/esm/render/webgl/TargetUniforms.d.ts +2 -0
  594. package/lib/esm/render/webgl/TargetUniforms.d.ts.map +1 -1
  595. package/lib/esm/render/webgl/TargetUniforms.js +2 -0
  596. package/lib/esm/render/webgl/TargetUniforms.js.map +1 -1
  597. package/lib/esm/render/webgl/Technique.d.ts.map +1 -1
  598. package/lib/esm/render/webgl/Technique.js +5 -11
  599. package/lib/esm/render/webgl/Technique.js.map +1 -1
  600. package/lib/esm/render/webgl/TechniqueFlags.d.ts.map +1 -1
  601. package/lib/esm/render/webgl/TechniqueFlags.js.map +1 -1
  602. package/lib/esm/render/webgl/Texture.d.ts.map +1 -1
  603. package/lib/esm/render/webgl/Texture.js +21 -12
  604. package/lib/esm/render/webgl/Texture.js.map +1 -1
  605. package/lib/esm/render/webgl/ThematicSensors.d.ts.map +1 -1
  606. package/lib/esm/render/webgl/ThematicSensors.js +8 -2
  607. package/lib/esm/render/webgl/ThematicSensors.js.map +1 -1
  608. package/lib/esm/render/webgl/glsl/AmbientOcclusion.d.ts.map +1 -1
  609. package/lib/esm/render/webgl/glsl/AmbientOcclusion.js +3 -1
  610. package/lib/esm/render/webgl/glsl/AmbientOcclusion.js.map +1 -1
  611. package/lib/esm/render/webgl/glsl/Common.js +1 -1
  612. package/lib/esm/render/webgl/glsl/Common.js.map +1 -1
  613. package/lib/esm/render/webgl/glsl/PointCloud.d.ts.map +1 -1
  614. package/lib/esm/render/webgl/glsl/PointCloud.js +44 -21
  615. package/lib/esm/render/webgl/glsl/PointCloud.js.map +1 -1
  616. package/lib/esm/render/webgl/glsl/RealityMesh.d.ts +4 -2
  617. package/lib/esm/render/webgl/glsl/RealityMesh.d.ts.map +1 -1
  618. package/lib/esm/render/webgl/glsl/RealityMesh.js +4 -3
  619. package/lib/esm/render/webgl/glsl/RealityMesh.js.map +1 -1
  620. package/lib/esm/render/webgl/glsl/SkyBox.d.ts.map +1 -1
  621. package/lib/esm/render/webgl/glsl/SkyBox.js.map +1 -1
  622. package/lib/esm/tile/GltfReader.d.ts +3 -2
  623. package/lib/esm/tile/GltfReader.d.ts.map +1 -1
  624. package/lib/esm/tile/GltfReader.js +8 -4
  625. package/lib/esm/tile/GltfReader.js.map +1 -1
  626. package/lib/esm/tile/ImdlReader.d.ts +1 -1
  627. package/lib/esm/tile/ImdlReader.js.map +1 -1
  628. package/lib/esm/tile/OPCFormatInterpreter.d.ts.map +1 -1
  629. package/lib/esm/tile/OPCFormatInterpreter.js +3 -1
  630. package/lib/esm/tile/OPCFormatInterpreter.js.map +1 -1
  631. package/lib/esm/tile/OrbitGtTileTree.d.ts.map +1 -1
  632. package/lib/esm/tile/OrbitGtTileTree.js +8 -2
  633. package/lib/esm/tile/OrbitGtTileTree.js.map +1 -1
  634. package/lib/esm/tile/PntsReader.d.ts.map +1 -1
  635. package/lib/esm/tile/PntsReader.js +8 -2
  636. package/lib/esm/tile/PntsReader.js.map +1 -1
  637. package/lib/esm/tile/PrimaryTileTree.d.ts.map +1 -1
  638. package/lib/esm/tile/PrimaryTileTree.js +14 -11
  639. package/lib/esm/tile/PrimaryTileTree.js.map +1 -1
  640. package/lib/esm/tile/RealityModelTileTree.d.ts +4 -1
  641. package/lib/esm/tile/RealityModelTileTree.d.ts.map +1 -1
  642. package/lib/esm/tile/RealityModelTileTree.js +9 -1
  643. package/lib/esm/tile/RealityModelTileTree.js.map +1 -1
  644. package/lib/esm/tile/RealityTile.d.ts +57 -3
  645. package/lib/esm/tile/RealityTile.d.ts.map +1 -1
  646. package/lib/esm/tile/RealityTile.js +49 -5
  647. package/lib/esm/tile/RealityTile.js.map +1 -1
  648. package/lib/esm/tile/RealityTileLoader.d.ts.map +1 -1
  649. package/lib/esm/tile/RealityTileLoader.js.map +1 -1
  650. package/lib/esm/tile/RealityTileTree.d.ts +37 -2
  651. package/lib/esm/tile/RealityTileTree.d.ts.map +1 -1
  652. package/lib/esm/tile/RealityTileTree.js +30 -2
  653. package/lib/esm/tile/RealityTileTree.js.map +1 -1
  654. package/lib/esm/tile/ThreeDTileFormatInterpreter.d.ts.map +1 -1
  655. package/lib/esm/tile/ThreeDTileFormatInterpreter.js +6 -2
  656. package/lib/esm/tile/ThreeDTileFormatInterpreter.js.map +1 -1
  657. package/lib/esm/tile/TileAdmin.d.ts +12 -0
  658. package/lib/esm/tile/TileAdmin.d.ts.map +1 -1
  659. package/lib/esm/tile/TileAdmin.js +35 -4
  660. package/lib/esm/tile/TileAdmin.js.map +1 -1
  661. package/lib/esm/tile/TileDrawArgs.d.ts.map +1 -1
  662. package/lib/esm/tile/TileDrawArgs.js +11 -17
  663. package/lib/esm/tile/TileDrawArgs.js.map +1 -1
  664. package/lib/esm/tile/TileRequest.d.ts +5 -1
  665. package/lib/esm/tile/TileRequest.d.ts.map +1 -1
  666. package/lib/esm/tile/TileRequest.js +6 -2
  667. package/lib/esm/tile/TileRequest.js.map +1 -1
  668. package/lib/esm/tile/TileStorage.d.ts +13 -0
  669. package/lib/esm/tile/TileStorage.d.ts.map +1 -0
  670. package/lib/esm/tile/TileStorage.js +46 -0
  671. package/lib/esm/tile/TileStorage.js.map +1 -0
  672. package/lib/esm/tile/internal.d.ts +2 -0
  673. package/lib/esm/tile/internal.d.ts.map +1 -1
  674. package/lib/esm/tile/internal.js +2 -0
  675. package/lib/esm/tile/internal.js.map +1 -1
  676. package/lib/esm/tile/map/ArcGISTileMap.js +1 -1
  677. package/lib/esm/tile/map/ArcGISTileMap.js.map +1 -1
  678. package/lib/esm/tile/map/ArcGisUtilities.d.ts +0 -2
  679. package/lib/esm/tile/map/ArcGisUtilities.d.ts.map +1 -1
  680. package/lib/esm/tile/map/ArcGisUtilities.js +1 -24
  681. package/lib/esm/tile/map/ArcGisUtilities.js.map +1 -1
  682. package/lib/esm/tile/map/BingElevation.d.ts +8 -3
  683. package/lib/esm/tile/map/BingElevation.d.ts.map +1 -1
  684. package/lib/esm/tile/map/BingElevation.js +36 -14
  685. package/lib/esm/tile/map/BingElevation.js.map +1 -1
  686. package/lib/esm/tile/map/CesiumTerrainProvider.d.ts +2 -7
  687. package/lib/esm/tile/map/CesiumTerrainProvider.d.ts.map +1 -1
  688. package/lib/esm/tile/map/CesiumTerrainProvider.js +101 -91
  689. package/lib/esm/tile/map/CesiumTerrainProvider.js.map +1 -1
  690. package/lib/esm/tile/map/EllipsoidTerrainProvider.d.ts +9 -12
  691. package/lib/esm/tile/map/EllipsoidTerrainProvider.d.ts.map +1 -1
  692. package/lib/esm/tile/map/EllipsoidTerrainProvider.js +71 -68
  693. package/lib/esm/tile/map/EllipsoidTerrainProvider.js.map +1 -1
  694. package/lib/esm/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.d.ts.map +1 -1
  695. package/lib/esm/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js +9 -16
  696. package/lib/esm/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js.map +1 -1
  697. package/lib/esm/tile/map/ImageryProviders/BingImageryProvider.d.ts.map +1 -1
  698. package/lib/esm/tile/map/ImageryProviders/BingImageryProvider.js +1 -1
  699. package/lib/esm/tile/map/ImageryProviders/BingImageryProvider.js.map +1 -1
  700. package/lib/esm/tile/map/ImageryProviders/MapBoxLayerImageryProvider.d.ts.map +1 -1
  701. package/lib/esm/tile/map/ImageryProviders/MapBoxLayerImageryProvider.js.map +1 -1
  702. package/lib/esm/tile/map/ImageryProviders/WmsMapLayerImageryProvider.d.ts.map +1 -1
  703. package/lib/esm/tile/map/ImageryProviders/WmsMapLayerImageryProvider.js +8 -6
  704. package/lib/esm/tile/map/ImageryProviders/WmsMapLayerImageryProvider.js.map +1 -1
  705. package/lib/esm/tile/map/ImageryProviders/WmtsMapLayerImageryProvider.js +3 -3
  706. package/lib/esm/tile/map/ImageryProviders/WmtsMapLayerImageryProvider.js.map +1 -1
  707. package/lib/esm/tile/map/ImageryTileTree.d.ts.map +1 -1
  708. package/lib/esm/tile/map/ImageryTileTree.js +21 -6
  709. package/lib/esm/tile/map/ImageryTileTree.js.map +1 -1
  710. package/lib/esm/tile/map/MapCartoRectangle.d.ts +62 -6
  711. package/lib/esm/tile/map/MapCartoRectangle.d.ts.map +1 -1
  712. package/lib/esm/tile/map/MapCartoRectangle.js +103 -17
  713. package/lib/esm/tile/map/MapCartoRectangle.js.map +1 -1
  714. package/lib/esm/tile/map/MapLayerImageryFormats.d.ts.map +1 -1
  715. package/lib/esm/tile/map/MapLayerImageryFormats.js +4 -2
  716. package/lib/esm/tile/map/MapLayerImageryFormats.js.map +1 -1
  717. package/lib/esm/tile/map/MapLayerImageryProvider.d.ts.map +1 -1
  718. package/lib/esm/tile/map/MapLayerImageryProvider.js +1 -1
  719. package/lib/esm/tile/map/MapLayerImageryProvider.js.map +1 -1
  720. package/lib/esm/tile/map/MapLayerSources.d.ts.map +1 -1
  721. package/lib/esm/tile/map/MapLayerSources.js +11 -7
  722. package/lib/esm/tile/map/MapLayerSources.js.map +1 -1
  723. package/lib/esm/tile/map/MapTile.d.ts +68 -15
  724. package/lib/esm/tile/map/MapTile.d.ts.map +1 -1
  725. package/lib/esm/tile/map/MapTile.js +88 -30
  726. package/lib/esm/tile/map/MapTile.js.map +1 -1
  727. package/lib/esm/tile/map/MapTileAvailability.d.ts.map +1 -1
  728. package/lib/esm/tile/map/MapTileAvailability.js +1 -1
  729. package/lib/esm/tile/map/MapTileAvailability.js.map +1 -1
  730. package/lib/esm/tile/map/MapTileLoader.d.ts +2 -2
  731. package/lib/esm/tile/map/MapTileLoader.d.ts.map +1 -1
  732. package/lib/esm/tile/map/MapTileLoader.js +12 -21
  733. package/lib/esm/tile/map/MapTileLoader.js.map +1 -1
  734. package/lib/esm/tile/map/MapTileTree.d.ts +72 -7
  735. package/lib/esm/tile/map/MapTileTree.d.ts.map +1 -1
  736. package/lib/esm/tile/map/MapTileTree.js +73 -17
  737. package/lib/esm/tile/map/MapTileTree.js.map +1 -1
  738. package/lib/esm/tile/map/MapTilingScheme.d.ts +67 -55
  739. package/lib/esm/tile/map/MapTilingScheme.d.ts.map +1 -1
  740. package/lib/esm/tile/map/MapTilingScheme.js +72 -68
  741. package/lib/esm/tile/map/MapTilingScheme.js.map +1 -1
  742. package/lib/esm/tile/map/QuadId.d.ts +24 -2
  743. package/lib/esm/tile/map/QuadId.d.ts.map +1 -1
  744. package/lib/esm/tile/map/QuadId.js +49 -20
  745. package/lib/esm/tile/map/QuadId.js.map +1 -1
  746. package/lib/esm/tile/map/TerrainMeshProvider.d.ts +79 -19
  747. package/lib/esm/tile/map/TerrainMeshProvider.d.ts.map +1 -1
  748. package/lib/esm/tile/map/TerrainMeshProvider.js +28 -13
  749. package/lib/esm/tile/map/TerrainMeshProvider.js.map +1 -1
  750. package/lib/esm/tile/map/TerrainProvider.d.ts +34 -0
  751. package/lib/esm/tile/map/TerrainProvider.d.ts.map +1 -0
  752. package/lib/esm/tile/map/TerrainProvider.js +37 -0
  753. package/lib/esm/tile/map/TerrainProvider.js.map +1 -0
  754. package/lib/esm/tile/map/WmsCapabilities.js +1 -1
  755. package/lib/esm/tile/map/WmsCapabilities.js.map +1 -1
  756. package/lib/esm/tile/map/WmtsCapabilities.d.ts.map +1 -1
  757. package/lib/esm/tile/map/WmtsCapabilities.js +7 -3
  758. package/lib/esm/tile/map/WmtsCapabilities.js.map +1 -1
  759. package/lib/esm/tile/object-storage-azure.js +5 -0
  760. package/lib/esm/tools/AccuDrawTool.d.ts.map +1 -1
  761. package/lib/esm/tools/AccuDrawTool.js +87 -26
  762. package/lib/esm/tools/AccuDrawTool.js.map +1 -1
  763. package/lib/esm/tools/ClipViewTool.d.ts +2 -2
  764. package/lib/esm/tools/ClipViewTool.d.ts.map +1 -1
  765. package/lib/esm/tools/ClipViewTool.js +29 -16
  766. package/lib/esm/tools/ClipViewTool.js.map +1 -1
  767. package/lib/esm/tools/ElementSetTool.d.ts.map +1 -1
  768. package/lib/esm/tools/ElementSetTool.js +26 -10
  769. package/lib/esm/tools/ElementSetTool.js.map +1 -1
  770. package/lib/esm/tools/MeasureTool.d.ts.map +1 -1
  771. package/lib/esm/tools/MeasureTool.js +65 -41
  772. package/lib/esm/tools/MeasureTool.js.map +1 -1
  773. package/lib/esm/tools/PrimitiveTool.d.ts.map +1 -1
  774. package/lib/esm/tools/PrimitiveTool.js +9 -4
  775. package/lib/esm/tools/PrimitiveTool.js.map +1 -1
  776. package/lib/esm/tools/SelectTool.d.ts.map +1 -1
  777. package/lib/esm/tools/SelectTool.js +20 -9
  778. package/lib/esm/tools/SelectTool.js.map +1 -1
  779. package/lib/esm/tools/Tool.d.ts.map +1 -1
  780. package/lib/esm/tools/Tool.js +13 -5
  781. package/lib/esm/tools/Tool.js.map +1 -1
  782. package/lib/esm/tools/ToolAdmin.d.ts.map +1 -1
  783. package/lib/esm/tools/ToolAdmin.js +27 -9
  784. package/lib/esm/tools/ToolAdmin.js.map +1 -1
  785. package/lib/esm/tools/ViewTool.d.ts.map +1 -1
  786. package/lib/esm/tools/ViewTool.js +111 -40
  787. package/lib/esm/tools/ViewTool.js.map +1 -1
  788. package/lib/esm/webgl.d.ts +1 -0
  789. package/lib/esm/webgl.d.ts.map +1 -1
  790. package/lib/esm/webgl.js +1 -0
  791. package/lib/esm/webgl.js.map +1 -1
  792. package/package.json +30 -24
  793. package/lib/cjs/render/primitives/mesh/RealityMeshPrimitive.d.ts +0 -47
  794. package/lib/cjs/render/primitives/mesh/RealityMeshPrimitive.d.ts.map +0 -1
  795. package/lib/cjs/render/primitives/mesh/RealityMeshPrimitive.js +0 -75
  796. package/lib/cjs/render/primitives/mesh/RealityMeshPrimitive.js.map +0 -1
  797. package/lib/cjs/render/primitives/mesh/TerrainMeshPrimitive.d.ts +0 -56
  798. package/lib/cjs/render/primitives/mesh/TerrainMeshPrimitive.d.ts.map +0 -1
  799. package/lib/cjs/render/primitives/mesh/TerrainMeshPrimitive.js +0 -270
  800. package/lib/cjs/render/primitives/mesh/TerrainMeshPrimitive.js.map +0 -1
  801. package/lib/esm/render/primitives/mesh/RealityMeshPrimitive.d.ts +0 -47
  802. package/lib/esm/render/primitives/mesh/RealityMeshPrimitive.d.ts.map +0 -1
  803. package/lib/esm/render/primitives/mesh/RealityMeshPrimitive.js +0 -71
  804. package/lib/esm/render/primitives/mesh/RealityMeshPrimitive.js.map +0 -1
  805. package/lib/esm/render/primitives/mesh/TerrainMeshPrimitive.d.ts +0 -56
  806. package/lib/esm/render/primitives/mesh/TerrainMeshPrimitive.d.ts.map +0 -1
  807. package/lib/esm/render/primitives/mesh/TerrainMeshPrimitive.js +0 -266
  808. package/lib/esm/render/primitives/mesh/TerrainMeshPrimitive.js.map +0 -1
@@ -11,83 +11,83 @@ exports.WebMercatorTilingScheme = exports.WebMercatorProjection = exports.Geogra
11
11
  const core_geometry_1 = require("@itwin/core-geometry");
12
12
  const core_common_1 = require("@itwin/core-common");
13
13
  const internal_1 = require("../internal");
14
- /** @internal */
14
+ /** A scheme for converting between two representations of the surface of the Earth: an ellipsoid and a rectangular [tiled map](https://en.wikipedia.org/wiki/Tiled_web_map).
15
+ * Positions on the surface of the ellipsoid are expressed in [Cartographic]($common) coordinates.
16
+ * Rectangular [[MapTile]]s are projected onto this ellipsoid by the tiling scheme. Tile coordinates are represented by [[QuadId]]s.
17
+ *
18
+ * The tiling scheme represents the (x,y) coordinates of its tiles as fractions in [0,1] along the X and Y axes.
19
+ * An X fraction of 0 corresponds to the easternmost longitude and an X fraction of 1 to the westernmost longitude.
20
+ * The scheme can choose to correlate a Y fraction of 0 with either the north or south pole, as specified by [[rowZeroAtNorthPole]].
21
+ * Implementing a tiling scheme only requires implementing the abstract method [[yFractionToLatitude]] and its inverse, [[latitudeToYFraction]].
22
+ * @beta
23
+ */
15
24
  class MapTilingScheme {
16
- constructor(numberOfLevelZeroTilesX, numberOfLevelZeroTilesY, rowZeroAtNorthPole, _rectangle = core_geometry_1.Range2d.createXYXY(-core_geometry_1.Angle.piRadians, -core_geometry_1.Angle.piOver2Radians, core_geometry_1.Angle.piRadians, core_geometry_1.Angle.piOver2Radians)) {
25
+ constructor(numberOfLevelZeroTilesX, numberOfLevelZeroTilesY, rowZeroAtNorthPole) {
26
+ this._scratchFraction = core_geometry_1.Point2d.createZero();
27
+ this._scratchPoint2d = core_geometry_1.Point2d.createZero();
28
+ this.rowZeroAtNorthPole = rowZeroAtNorthPole;
17
29
  this.numberOfLevelZeroTilesX = numberOfLevelZeroTilesX;
18
30
  this.numberOfLevelZeroTilesY = numberOfLevelZeroTilesY;
19
- this.rowZeroAtNorthPole = rowZeroAtNorthPole;
20
- this._rectangle = _rectangle;
21
- this._scratchFraction = core_geometry_1.Point2d.createZero();
22
31
  }
23
- /**
24
- * @param longitude in radians (-pi to pi)
25
- */
32
+ /** Convert a longitude in [-pi, pi] radisn to a fraction in [0, 1] along the X axis. */
26
33
  longitudeToXFraction(longitude) {
27
34
  return longitude / core_geometry_1.Angle.pi2Radians + .5;
28
35
  }
29
- /**
30
- * Return longitude in radians (-pi to pi from fraction).
31
- */
36
+ /** Convert a fraction in [0, 1] along the X axis into a longitude in [-pi, pi] radians. */
32
37
  xFractionToLongitude(xFraction) {
33
38
  return core_geometry_1.Angle.pi2Radians * (xFraction - .5);
34
39
  }
35
- /**
36
- * Gets the total number of tiles in the X direction at a specified level-of-detail.
37
- *
38
- * @param {Number} level The level-of-detail. Level 0 is the root tile.
39
- * @returns {Number} The number of tiles in the X direction at the given level.
40
+ /** The total number of tiles in the X direction at the specified level of detail.
41
+ * @param level The level of detail, with 0 corresponding to the root tile.
40
42
  */
41
43
  getNumberOfXTilesAtLevel(level) {
42
44
  return level < 0 ? 1 : this.numberOfLevelZeroTilesX << level;
43
45
  }
44
- /**
45
- * Gets the total number of tiles in the Y direction at a specified level-of-detail.
46
- *
47
- *
48
- * @param {Number} level The level-of-detail. Level 0 is the root tile.
49
- * @returns {Number} The number of tiles in the Y direction at the given level.
46
+ /** The total number of tiles in the Y direction at the specified level of detail.
47
+ * @param level The level of detail, with 0 corresponding to the root tile.
50
48
  */
51
49
  getNumberOfYTilesAtLevel(level) {
52
50
  return level < 0 ? 1 : this.numberOfLevelZeroTilesY << level;
53
51
  }
52
+ /** @alpha */
54
53
  get rootLevel() {
55
54
  return this.numberOfLevelZeroTilesX > 1 || this.numberOfLevelZeroTilesY > 1 ? -1 : 0;
56
55
  }
56
+ /** @alpha */
57
57
  getNumberOfXChildrenAtLevel(level) {
58
58
  return level === 0 ? this.numberOfLevelZeroTilesX : 2;
59
59
  }
60
+ /** @alpha */
60
61
  getNumberOfYChildrenAtLevel(level) {
61
62
  return level === 0 ? this.numberOfLevelZeroTilesY : 2;
62
63
  }
64
+ /** Given the X component and level of a [[QuadId]], convert it to a fractional distance along the X axis. */
63
65
  tileXToFraction(x, level) {
64
66
  return x / this.getNumberOfXTilesAtLevel(level);
65
67
  }
68
+ /** Given the Y component and level of a [[QuadId]], convert it to a fractional distance along the Y axis. */
66
69
  tileYToFraction(y, level) {
67
70
  return y / this.getNumberOfYTilesAtLevel(level);
68
71
  }
72
+ /** Given a fractional distance along the X axis and a level of the quad tree, compute the X component of the corresponding [[QuadId]]. */
69
73
  xFractionToTileX(xFraction, level) {
70
74
  const nTiles = this.getNumberOfXTilesAtLevel(level);
71
75
  return Math.min(Math.floor(xFraction * nTiles), nTiles - 1);
72
76
  }
77
+ /** Given a fractional distance along the Y axis and a level of the quad tree, compute the Y component of the corresponding [[QuadId]]. */
73
78
  yFractionToTileY(yFraction, level) {
74
79
  const nTiles = this.getNumberOfYTilesAtLevel(level);
75
80
  return Math.min(Math.floor(yFraction * nTiles), nTiles - 1);
76
81
  }
82
+ /** Given the X component and level of a [[QuadId]], compute its longitude in [-pi, pi] radians. */
77
83
  tileXToLongitude(x, level) {
78
84
  return this.xFractionToLongitude(this.tileXToFraction(x, level));
79
85
  }
86
+ /** Given the Y component and level of a [[QuadId]], compute its latitude in [-pi/2, pi/2] radians. */
80
87
  tileYToLatitude(y, level) {
81
88
  return this.yFractionToLatitude(this.tileYToFraction(y, level));
82
89
  }
83
- /**
84
- * Gets the fraction of the normalized (0-1) coordinates with at left, bottom.
85
- *
86
- * @param x column
87
- * @param y row
88
- * @param level depth
89
- * @param result result (0-1 from left, bottom
90
- */
90
+ /** Given the components of a [[QuadId]], compute its fractional coordinates in the XY plane. */
91
91
  tileXYToFraction(x, y, level, result) {
92
92
  if (undefined === result)
93
93
  result = core_geometry_1.Point2d.createZero();
@@ -95,61 +95,57 @@ class MapTilingScheme {
95
95
  result.y = this.tileYToFraction(y, level);
96
96
  return result;
97
97
  }
98
- /** Get Cartographic from tile XY
99
- *
100
- * @param x column
101
- * @param y row
102
- * @param level depth
103
- * @param result result longitude, latitude.
104
- * @param height height (optional)
98
+ /** Given the components of a [[QuadId]] and an elevation, compute the corresponding [Cartographic]($common) position.
99
+ * @param x The X component of the QuadId.
100
+ * @param y The Y component of the QuadId.
101
+ * @param level The level component of the QuadId.
102
+ * @param height The elevation above the ellipsoid.
103
+ * @returns the corresponding cartographic position.
105
104
  */
106
- tileXYToCartographic(x, y, level, result, height) {
107
- this.tileXYToFraction(x, y, level, this._scratchFraction);
108
- return this.fractionToCartographic(this._scratchFraction.x, this._scratchFraction.y, result, height);
105
+ tileXYToCartographic(x, y, level, result, height = 0) {
106
+ const pt = this.tileXYToFraction(x, y, level, this._scratchFraction);
107
+ return this.fractionToCartographic(pt.x, pt.y, result, height);
109
108
  }
109
+ /** Given the components of a [[QuadId]], compute the corresponding region of the Earth's surface. */
110
110
  tileXYToRectangle(x, y, level, result) {
111
- return level < 0 ? internal_1.MapCartoRectangle.create() : internal_1.MapCartoRectangle.create(this.tileXToLongitude(x, level), this.tileYToLatitude(this.rowZeroAtNorthPole ? (y + 1) : y, level), this.tileXToLongitude(x + 1, level), this.tileYToLatitude(this.rowZeroAtNorthPole ? y : (y + 1), level), result);
111
+ if (level < 0)
112
+ return internal_1.MapCartoRectangle.createMaximum();
113
+ return internal_1.MapCartoRectangle.fromRadians(this.tileXToLongitude(x, level), this.tileYToLatitude(this.rowZeroAtNorthPole ? (y + 1) : y, level), this.tileXToLongitude(x + 1, level), this.tileYToLatitude(this.rowZeroAtNorthPole ? y : (y + 1), level), result);
112
114
  }
115
+ /** Returns true if the tile at the specified X coordinate and level is adjacent to the north pole. */
113
116
  tileBordersNorthPole(row, level) {
114
117
  return this.rowZeroAtNorthPole ? this.tileYToFraction(row, level) === 0.0 : this.tileYToFraction(row + 1, level) === 1.0;
115
118
  }
119
+ /** Returns true if the tile at the specified X coordinate and level is adjacent to the south pole. */
116
120
  tileBordersSouthPole(row, level) {
117
121
  return this.rowZeroAtNorthPole ? this.tileYToFraction(row + 1, level) === 1.0 : this.tileYToFraction(row, level) === 0.0;
118
122
  }
119
- /** Get tile XY from Cartographic.
120
- *
121
- * @param x column
122
- * @param y row
123
- * @param level depth
124
- * @param result result longitude, latitude.
125
- * @param height height (optional)
123
+ /** Given a cartographic position, compute the corresponding position on the surface of the Earth as fractional distances along the
124
+ * X and Y axes.
126
125
  */
127
126
  cartographicToTileXY(carto, level, result) {
128
- const fraction = this.cartographicToFraction(carto.latitude, carto.longitude, MapTilingScheme._scratchPoint2d);
127
+ const fraction = this.cartographicToFraction(carto.latitude, carto.longitude, this._scratchPoint2d);
129
128
  return core_geometry_1.Point2d.create(this.xFractionToTileX(fraction.x, level), this.yFractionToTileY(fraction.y, level), result);
130
129
  }
131
- /** Get fraction from Cartographic.
132
- * @param xFraction
133
- * @param yFraction
134
- * @param result
135
- * @param height
136
- */
137
- fractionToCartographic(xFraction, yFraction, result, height) {
130
+ /** Given fractional coordinates in the XY plane and an elevation, compute the corresponding cartographic position. */
131
+ fractionToCartographic(xFraction, yFraction, result, height = 0) {
138
132
  result.longitude = this.xFractionToLongitude(xFraction);
139
133
  result.latitude = this.yFractionToLatitude(yFraction);
140
- result.height = undefined === height ? 0.0 : height;
134
+ result.height = height;
141
135
  return result;
142
136
  }
137
+ /** Given a cartographic location on the surface of the Earth, convert it to fractional coordinates in the XY plane. */
143
138
  cartographicToFraction(latitudeRadians, longitudeRadians, result) {
144
139
  result.x = this.longitudeToXFraction(longitudeRadians);
145
140
  result.y = this.latitudeToYFraction(latitudeRadians);
146
141
  return result;
147
142
  }
148
- // gets the longitude and latitude into a point with coordinates between 0 and 1
143
+ /** @alpha */
149
144
  ecefToPixelFraction(point, applyTerrain) {
150
145
  const cartoGraphic = core_common_1.Cartographic.fromEcef(point);
151
146
  return core_geometry_1.Point3d.create(this.longitudeToXFraction(cartoGraphic.longitude), this.latitudeToYFraction(cartoGraphic.latitude), applyTerrain ? cartoGraphic.height : 0);
152
147
  }
148
+ /** @alpha */
153
149
  computeMercatorFractionToDb(ecefToDb, bimElevationOffset, iModel, applyTerrain) {
154
150
  const dbToEcef = ecefToDb.inverse();
155
151
  const projectCenter = core_geometry_1.Point3d.create(iModel.projectExtents.center.x, iModel.projectExtents.center.y, bimElevationOffset);
@@ -165,26 +161,31 @@ class MapTilingScheme {
165
161
  const mercatorToDb = dbToMercator.inverse();
166
162
  return mercatorToDb === undefined ? core_geometry_1.Transform.createIdentity() : mercatorToDb;
167
163
  }
164
+ /** @alpha */
168
165
  yFractionFlip(fraction) {
169
166
  return this.rowZeroAtNorthPole ? (1.0 - fraction) : fraction;
170
167
  }
171
168
  }
172
169
  exports.MapTilingScheme = MapTilingScheme;
173
- MapTilingScheme._scratchPoint2d = core_geometry_1.Point2d.createZero();
174
- /** @internal */
170
+ /** A [[MapTilingScheme]] using a simple geographic projection by which longitude and latitude are mapped directly to X and Y.
171
+ * This projection is commonly known as "geographic", "equirectangular", "equidistant cylindrical", or "plate carrée".
172
+ * @beta
173
+ */
175
174
  class GeographicTilingScheme extends MapTilingScheme {
176
175
  constructor(numberOfLevelZeroTilesX = 2, numberOfLevelZeroTilesY = 1, rowZeroAtNorthPole = false) {
177
176
  super(numberOfLevelZeroTilesX, numberOfLevelZeroTilesY, rowZeroAtNorthPole);
178
177
  }
178
+ /** @internal override */
179
179
  yFractionToLatitude(yFraction) {
180
180
  return Math.PI * (this.yFractionFlip(yFraction) - .5);
181
181
  }
182
+ /** @internal override */
182
183
  latitudeToYFraction(latitude) {
183
184
  return this.yFractionFlip(.5 + latitude / Math.PI);
184
185
  }
185
186
  }
186
187
  exports.GeographicTilingScheme = GeographicTilingScheme;
187
- /** @internal */
188
+ /** @alpha */
188
189
  class WebMercatorProjection {
189
190
  /**
190
191
  * Converts a Mercator angle, in the range -PI to PI, to a geodetic latitude
@@ -198,27 +199,30 @@ class WebMercatorProjection {
198
199
  }
199
200
  static geodeticLatitudeToMercatorAngle(latitude) {
200
201
  // Clamp the latitude coordinate to the valid Mercator bounds.
201
- if (latitude > WebMercatorProjection.maximumLatitude) {
202
+ if (latitude > WebMercatorProjection.maximumLatitude)
202
203
  latitude = WebMercatorProjection.maximumLatitude;
203
- }
204
- else if (latitude < -WebMercatorProjection.maximumLatitude) {
204
+ else if (latitude < -WebMercatorProjection.maximumLatitude)
205
205
  latitude = -WebMercatorProjection.maximumLatitude;
206
- }
207
206
  const sinLatitude = Math.sin(latitude);
208
207
  return 0.5 * Math.log((1.0 + sinLatitude) / (1.0 - sinLatitude));
209
208
  }
210
209
  }
211
210
  exports.WebMercatorProjection = WebMercatorProjection;
212
211
  WebMercatorProjection.maximumLatitude = WebMercatorProjection.mercatorAngleToGeodeticLatitude(core_geometry_1.Angle.piRadians);
213
- /** @internal */
212
+ /** A [[MapTilingScheme]] using the [EPSG:3857](https://en.wikipedia.org/wiki/Web_Mercator_projection) projection.
213
+ * This scheme is used by most [tiled web maps](https://en.wikipedia.org/wiki/Tiled_web_map), including Bing Maps and Google Maps.
214
+ * @beta
215
+ */
214
216
  class WebMercatorTilingScheme extends MapTilingScheme {
215
- constructor(numberOfLevelZeroTilesX = 1, numberOfLevelZeroTilesY = 1, rowZeroAtNorthPole = true /* Bing uses 0 north */) {
217
+ constructor(numberOfLevelZeroTilesX = 1, numberOfLevelZeroTilesY = 1, rowZeroAtNorthPole = true) {
216
218
  super(numberOfLevelZeroTilesX, numberOfLevelZeroTilesY, rowZeroAtNorthPole);
217
219
  }
220
+ /** @internal override */
218
221
  yFractionToLatitude(yFraction) {
219
222
  const mercatorAngle = core_geometry_1.Angle.pi2Radians * (this.rowZeroAtNorthPole ? (.5 - yFraction) : (yFraction - .5));
220
223
  return WebMercatorProjection.mercatorAngleToGeodeticLatitude(mercatorAngle);
221
224
  }
225
+ /** @internal override */
222
226
  latitudeToYFraction(latitude) {
223
227
  // Clamp the latitude coordinate to the valid Mercator bounds.
224
228
  if (latitude > WebMercatorProjection.maximumLatitude) {
@@ -1 +1 @@
1
- {"version":3,"file":"MapTilingScheme.js","sourceRoot":"","sources":["../../../../src/tile/map/MapTilingScheme.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module Tiles\r\n */\r\n\r\nimport { Angle, Matrix3d, Point2d, Point3d, Range2d, Transform, Vector3d } from \"@itwin/core-geometry\";\r\nimport { Cartographic } from \"@itwin/core-common\";\r\nimport { IModelConnection } from \"../../IModelConnection\";\r\nimport { MapCartoRectangle } from \"../internal\";\r\n\r\n/** @internal */\r\nexport abstract class MapTilingScheme {\r\n private _scratchFraction = Point2d.createZero();\r\n\r\n /**\r\n * @param longitude in radians (-pi to pi)\r\n */\r\n public longitudeToXFraction(longitude: number) {\r\n return longitude / Angle.pi2Radians + .5;\r\n }\r\n\r\n /**\r\n * Return longitude in radians (-pi to pi from fraction).\r\n */\r\n public xFractionToLongitude(xFraction: number) {\r\n return Angle.pi2Radians * (xFraction - .5);\r\n }\r\n\r\n public abstract yFractionToLatitude(yFraction: number): number;\r\n public abstract latitudeToYFraction(latitude: number): number;\r\n\r\n protected constructor(public readonly numberOfLevelZeroTilesX: number, public readonly numberOfLevelZeroTilesY: number, public rowZeroAtNorthPole: boolean, private _rectangle = Range2d.createXYXY(-Angle.piRadians, -Angle.piOver2Radians, Angle.piRadians, Angle.piOver2Radians)) {\r\n }\r\n /**\r\n * Gets the total number of tiles in the X direction at a specified level-of-detail.\r\n *\r\n * @param {Number} level The level-of-detail. Level 0 is the root tile.\r\n * @returns {Number} The number of tiles in the X direction at the given level.\r\n */\r\n public getNumberOfXTilesAtLevel(level: number) {\r\n return level < 0 ? 1 : this.numberOfLevelZeroTilesX << level;\r\n }\r\n\r\n /**\r\n * Gets the total number of tiles in the Y direction at a specified level-of-detail.\r\n *\r\n *\r\n * @param {Number} level The level-of-detail. Level 0 is the root tile.\r\n * @returns {Number} The number of tiles in the Y direction at the given level.\r\n */\r\n public getNumberOfYTilesAtLevel(level: number): number {\r\n return level < 0 ? 1 : this.numberOfLevelZeroTilesY << level;\r\n }\r\n\r\n public get rootLevel() {\r\n return this.numberOfLevelZeroTilesX > 1 || this.numberOfLevelZeroTilesY > 1 ? -1 : 0;\r\n }\r\n public getNumberOfXChildrenAtLevel(level: number): number {\r\n return level === 0 ? this.numberOfLevelZeroTilesX : 2;\r\n }\r\n public getNumberOfYChildrenAtLevel(level: number): number {\r\n return level === 0 ? this.numberOfLevelZeroTilesY : 2;\r\n }\r\n public tileXToFraction(x: number, level: number): number {\r\n return x / this.getNumberOfXTilesAtLevel(level);\r\n }\r\n\r\n public tileYToFraction(y: number, level: number): number {\r\n return y / this.getNumberOfYTilesAtLevel(level);\r\n }\r\n public xFractionToTileX(xFraction: number, level: number): number {\r\n const nTiles = this.getNumberOfXTilesAtLevel(level);\r\n return Math.min(Math.floor(xFraction * nTiles), nTiles - 1);\r\n }\r\n\r\n public yFractionToTileY(yFraction: number, level: number): number {\r\n const nTiles = this.getNumberOfYTilesAtLevel(level);\r\n return Math.min(Math.floor(yFraction * nTiles), nTiles - 1);\r\n }\r\n\r\n public tileXToLongitude(x: number, level: number) {\r\n return this.xFractionToLongitude(this.tileXToFraction(x, level));\r\n }\r\n public tileYToLatitude(y: number, level: number) {\r\n return this.yFractionToLatitude(this.tileYToFraction(y, level));\r\n }\r\n /**\r\n * Gets the fraction of the normalized (0-1) coordinates with at left, bottom.\r\n *\r\n * @param x column\r\n * @param y row\r\n * @param level depth\r\n * @param result result (0-1 from left, bottom\r\n */\r\n public tileXYToFraction(x: number, y: number, level: number, result?: Point2d): Point2d {\r\n if (undefined === result)\r\n result = Point2d.createZero();\r\n\r\n result.x = this.tileXToFraction(x, level);\r\n result.y = this.tileYToFraction(y, level);\r\n\r\n return result;\r\n }\r\n private static _scratchPoint2d = Point2d.createZero();\r\n /** Get Cartographic from tile XY\r\n *\r\n * @param x column\r\n * @param y row\r\n * @param level depth\r\n * @param result result longitude, latitude.\r\n * @param height height (optional)\r\n */\r\n public tileXYToCartographic(x: number, y: number, level: number, result: Cartographic, height?: number): Cartographic {\r\n this.tileXYToFraction(x, y, level, this._scratchFraction);\r\n return this.fractionToCartographic(this._scratchFraction.x, this._scratchFraction.y, result, height);\r\n }\r\n\r\n public tileXYToRectangle(x: number, y: number, level: number, result?: MapCartoRectangle) {\r\n return level < 0 ? MapCartoRectangle.create() : MapCartoRectangle.create(this.tileXToLongitude(x, level), this.tileYToLatitude(this.rowZeroAtNorthPole ? (y + 1) : y, level), this.tileXToLongitude(x + 1, level), this.tileYToLatitude(this.rowZeroAtNorthPole ? y : (y + 1), level), result);\r\n }\r\n public tileBordersNorthPole(row: number, level: number) {\r\n return this.rowZeroAtNorthPole ? this.tileYToFraction(row, level) === 0.0 : this.tileYToFraction(row + 1, level) === 1.0;\r\n }\r\n\r\n public tileBordersSouthPole(row: number, level: number) {\r\n return this.rowZeroAtNorthPole ? this.tileYToFraction(row + 1, level) === 1.0 : this.tileYToFraction(row, level) === 0.0;\r\n }\r\n\r\n /** Get tile XY from Cartographic.\r\n *\r\n * @param x column\r\n * @param y row\r\n * @param level depth\r\n * @param result result longitude, latitude.\r\n * @param height height (optional)\r\n */\r\n public cartographicToTileXY(carto: Cartographic, level: number, result?: Point2d): Point2d {\r\n const fraction = this.cartographicToFraction(carto.latitude, carto.longitude, MapTilingScheme._scratchPoint2d);\r\n return Point2d.create(this.xFractionToTileX(fraction.x, level), this.yFractionToTileY(fraction.y, level), result);\r\n\r\n }\r\n /** Get fraction from Cartographic.\r\n * @param xFraction\r\n * @param yFraction\r\n * @param result\r\n * @param height\r\n */\r\n public fractionToCartographic(xFraction: number, yFraction: number, result: Cartographic, height?: number): Cartographic {\r\n result.longitude = this.xFractionToLongitude(xFraction);\r\n result.latitude = this.yFractionToLatitude(yFraction);\r\n result.height = undefined === height ? 0.0 : height;\r\n return result;\r\n }\r\n\r\n public cartographicToFraction(latitudeRadians: number, longitudeRadians: number, result: Point2d): Point2d {\r\n result.x = this.longitudeToXFraction(longitudeRadians);\r\n result.y = this.latitudeToYFraction(latitudeRadians);\r\n return result;\r\n }\r\n\r\n // gets the longitude and latitude into a point with coordinates between 0 and 1\r\n private ecefToPixelFraction(point: Point3d, applyTerrain: boolean): Point3d {\r\n const cartoGraphic = Cartographic.fromEcef(point)!;\r\n return Point3d.create(this.longitudeToXFraction(cartoGraphic.longitude), this.latitudeToYFraction(cartoGraphic.latitude), applyTerrain ? cartoGraphic.height : 0);\r\n }\r\n\r\n public computeMercatorFractionToDb(ecefToDb: Transform, bimElevationOffset: number, iModel: IModelConnection, applyTerrain: boolean) {\r\n const dbToEcef = ecefToDb.inverse()!;\r\n\r\n const projectCenter = Point3d.create(iModel.projectExtents.center.x, iModel.projectExtents.center.y, bimElevationOffset);\r\n const projectEast = projectCenter.plusXYZ(1, 0, 0);\r\n const projectNorth = projectCenter.plusXYZ(0, 1, 0);\r\n\r\n const mercatorOrigin = this.ecefToPixelFraction(dbToEcef.multiplyPoint3d(projectCenter), applyTerrain);\r\n const mercatorX = this.ecefToPixelFraction(dbToEcef.multiplyPoint3d(projectEast), applyTerrain);\r\n const mercatorY = this.ecefToPixelFraction(dbToEcef.multiplyPoint3d(projectNorth), applyTerrain);\r\n\r\n const deltaX = Vector3d.createStartEnd(mercatorOrigin, mercatorX);\r\n const deltaY = Vector3d.createStartEnd(mercatorOrigin, mercatorY);\r\n const matrix = Matrix3d.createColumns(deltaX, deltaY, Vector3d.create(0, 0, 1));\r\n\r\n const dbToMercator = Transform.createMatrixPickupPutdown(matrix, projectCenter, mercatorOrigin);\r\n const mercatorToDb = dbToMercator.inverse();\r\n return mercatorToDb === undefined ? Transform.createIdentity() : mercatorToDb;\r\n }\r\n\r\n protected yFractionFlip(fraction: number) {\r\n return this.rowZeroAtNorthPole ? (1.0 - fraction) : fraction;\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport class GeographicTilingScheme extends MapTilingScheme {\r\n public constructor(numberOfLevelZeroTilesX: number = 2, numberOfLevelZeroTilesY: number = 1, rowZeroAtNorthPole = false) {\r\n super(numberOfLevelZeroTilesX, numberOfLevelZeroTilesY, rowZeroAtNorthPole);\r\n }\r\n\r\n public yFractionToLatitude(yFraction: number): number {\r\n return Math.PI * (this.yFractionFlip(yFraction) - .5);\r\n }\r\n\r\n public latitudeToYFraction(latitude: number): number {\r\n return this.yFractionFlip(.5 + latitude / Math.PI);\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport class WebMercatorProjection {\r\n /**\r\n * Converts a Mercator angle, in the range -PI to PI, to a geodetic latitude\r\n * in the range -PI/2 to PI/2.\r\n *\r\n * @param {Number} mercatorAngle The angle to convert.\r\n * @returns {Number} The geodetic latitude in radians.\r\n */\r\n public static mercatorAngleToGeodeticLatitude(mercatorAngle: number) {\r\n return Angle.piOver2Radians - (2.0 * Math.atan(Math.exp(-mercatorAngle)));\r\n }\r\n\r\n public static maximumLatitude = WebMercatorProjection.mercatorAngleToGeodeticLatitude(Angle.piRadians);\r\n public static geodeticLatitudeToMercatorAngle(latitude: number) {\r\n // Clamp the latitude coordinate to the valid Mercator bounds.\r\n if (latitude > WebMercatorProjection.maximumLatitude) {\r\n latitude = WebMercatorProjection.maximumLatitude;\r\n } else if (latitude < -WebMercatorProjection.maximumLatitude) {\r\n latitude = -WebMercatorProjection.maximumLatitude;\r\n }\r\n const sinLatitude = Math.sin(latitude);\r\n return 0.5 * Math.log((1.0 + sinLatitude) / (1.0 - sinLatitude));\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport class WebMercatorTilingScheme extends MapTilingScheme {\r\n\r\n public constructor(numberOfLevelZeroTilesX: number = 1, numberOfLevelZeroTilesY: number = 1, rowZeroAtNorthPole: boolean = true /* Bing uses 0 north */) {\r\n super(numberOfLevelZeroTilesX, numberOfLevelZeroTilesY, rowZeroAtNorthPole);\r\n }\r\n\r\n public yFractionToLatitude(yFraction: number): number {\r\n const mercatorAngle = Angle.pi2Radians * (this.rowZeroAtNorthPole ? (.5 - yFraction) : (yFraction - .5));\r\n return WebMercatorProjection.mercatorAngleToGeodeticLatitude(mercatorAngle);\r\n }\r\n\r\n public latitudeToYFraction(latitude: number): number {\r\n // Clamp the latitude coordinate to the valid Mercator bounds.\r\n if (latitude > WebMercatorProjection.maximumLatitude) {\r\n latitude = WebMercatorProjection.maximumLatitude;\r\n } else if (latitude < -WebMercatorProjection.maximumLatitude) {\r\n latitude = -WebMercatorProjection.maximumLatitude;\r\n }\r\n const sinLatitude = Math.sin(latitude);\r\n return (0.5 - Math.log((1.0 + sinLatitude) / (1.0 - sinLatitude)) / (4.0 * Angle.piRadians)); // https://msdn.microsoft.com/en-us/library/bb259689.aspx\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"MapTilingScheme.js","sourceRoot":"","sources":["../../../../src/tile/map/MapTilingScheme.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module Tiles\r\n */\r\n\r\nimport { Angle, Matrix3d, Point2d, Point3d, Transform, Vector3d } from \"@itwin/core-geometry\";\r\nimport { Cartographic } from \"@itwin/core-common\";\r\nimport { IModelConnection } from \"../../IModelConnection\";\r\nimport { MapCartoRectangle } from \"../internal\";\r\n\r\n/** A scheme for converting between two representations of the surface of the Earth: an ellipsoid and a rectangular [tiled map](https://en.wikipedia.org/wiki/Tiled_web_map).\r\n * Positions on the surface of the ellipsoid are expressed in [Cartographic]($common) coordinates.\r\n * Rectangular [[MapTile]]s are projected onto this ellipsoid by the tiling scheme. Tile coordinates are represented by [[QuadId]]s.\r\n *\r\n * The tiling scheme represents the (x,y) coordinates of its tiles as fractions in [0,1] along the X and Y axes.\r\n * An X fraction of 0 corresponds to the easternmost longitude and an X fraction of 1 to the westernmost longitude.\r\n * The scheme can choose to correlate a Y fraction of 0 with either the north or south pole, as specified by [[rowZeroAtNorthPole]].\r\n * Implementing a tiling scheme only requires implementing the abstract method [[yFractionToLatitude]] and its inverse, [[latitudeToYFraction]].\r\n * @beta\r\n */\r\nexport abstract class MapTilingScheme {\r\n /** If true, the fractional Y coordinate 0 corresponds to the north pole and 1 to the south pole; otherwise,\r\n * 0 corresponds to the south pole and 1 to the north.\r\n */\r\n public readonly rowZeroAtNorthPole: boolean;\r\n /** The number of tiles in the X direction at level 0 of the quad tree. */\r\n public readonly numberOfLevelZeroTilesX;\r\n /** The number of tiles in the Y direction at level 0 of the quad tree. */\r\n public readonly numberOfLevelZeroTilesY;\r\n private readonly _scratchFraction = Point2d.createZero();\r\n private readonly _scratchPoint2d = Point2d.createZero();\r\n\r\n /** Convert a longitude in [-pi, pi] radisn to a fraction in [0, 1] along the X axis. */\r\n public longitudeToXFraction(longitude: number) {\r\n return longitude / Angle.pi2Radians + .5;\r\n }\r\n\r\n /** Convert a fraction in [0, 1] along the X axis into a longitude in [-pi, pi] radians. */\r\n public xFractionToLongitude(xFraction: number) {\r\n return Angle.pi2Radians * (xFraction - .5);\r\n }\r\n\r\n /** Convert a fraction in [0, 1] along the Y axis into a latitude in [-pi/2, pi/2] radians. */\r\n public abstract yFractionToLatitude(yFraction: number): number;\r\n\r\n /** Convert a latitude in [-pi/2, pi/2] radians into a fraction in [0, 1] along the Y axis. */\r\n public abstract latitudeToYFraction(latitude: number): number;\r\n\r\n protected constructor(numberOfLevelZeroTilesX: number, numberOfLevelZeroTilesY: number, rowZeroAtNorthPole: boolean) {\r\n this.rowZeroAtNorthPole = rowZeroAtNorthPole;\r\n this.numberOfLevelZeroTilesX = numberOfLevelZeroTilesX;\r\n this.numberOfLevelZeroTilesY = numberOfLevelZeroTilesY;\r\n }\r\n\r\n /** The total number of tiles in the X direction at the specified level of detail.\r\n * @param level The level of detail, with 0 corresponding to the root tile.\r\n */\r\n public getNumberOfXTilesAtLevel(level: number) {\r\n return level < 0 ? 1 : this.numberOfLevelZeroTilesX << level;\r\n }\r\n\r\n /** The total number of tiles in the Y direction at the specified level of detail.\r\n * @param level The level of detail, with 0 corresponding to the root tile.\r\n */\r\n public getNumberOfYTilesAtLevel(level: number): number {\r\n return level < 0 ? 1 : this.numberOfLevelZeroTilesY << level;\r\n }\r\n\r\n /** @alpha */\r\n public get rootLevel() {\r\n return this.numberOfLevelZeroTilesX > 1 || this.numberOfLevelZeroTilesY > 1 ? -1 : 0;\r\n }\r\n\r\n /** @alpha */\r\n public getNumberOfXChildrenAtLevel(level: number): number {\r\n return level === 0 ? this.numberOfLevelZeroTilesX : 2;\r\n }\r\n\r\n /** @alpha */\r\n public getNumberOfYChildrenAtLevel(level: number): number {\r\n return level === 0 ? this.numberOfLevelZeroTilesY : 2;\r\n }\r\n\r\n /** Given the X component and level of a [[QuadId]], convert it to a fractional distance along the X axis. */\r\n public tileXToFraction(x: number, level: number): number {\r\n return x / this.getNumberOfXTilesAtLevel(level);\r\n }\r\n\r\n /** Given the Y component and level of a [[QuadId]], convert it to a fractional distance along the Y axis. */\r\n public tileYToFraction(y: number, level: number): number {\r\n return y / this.getNumberOfYTilesAtLevel(level);\r\n }\r\n\r\n /** Given a fractional distance along the X axis and a level of the quad tree, compute the X component of the corresponding [[QuadId]]. */\r\n public xFractionToTileX(xFraction: number, level: number): number {\r\n const nTiles = this.getNumberOfXTilesAtLevel(level);\r\n return Math.min(Math.floor(xFraction * nTiles), nTiles - 1);\r\n }\r\n\r\n /** Given a fractional distance along the Y axis and a level of the quad tree, compute the Y component of the corresponding [[QuadId]]. */\r\n public yFractionToTileY(yFraction: number, level: number): number {\r\n const nTiles = this.getNumberOfYTilesAtLevel(level);\r\n return Math.min(Math.floor(yFraction * nTiles), nTiles - 1);\r\n }\r\n\r\n /** Given the X component and level of a [[QuadId]], compute its longitude in [-pi, pi] radians. */\r\n public tileXToLongitude(x: number, level: number) {\r\n return this.xFractionToLongitude(this.tileXToFraction(x, level));\r\n }\r\n\r\n /** Given the Y component and level of a [[QuadId]], compute its latitude in [-pi/2, pi/2] radians. */\r\n public tileYToLatitude(y: number, level: number) {\r\n return this.yFractionToLatitude(this.tileYToFraction(y, level));\r\n }\r\n\r\n /** Given the components of a [[QuadId]], compute its fractional coordinates in the XY plane. */\r\n public tileXYToFraction(x: number, y: number, level: number, result?: Point2d): Point2d {\r\n if (undefined === result)\r\n result = Point2d.createZero();\r\n\r\n result.x = this.tileXToFraction(x, level);\r\n result.y = this.tileYToFraction(y, level);\r\n\r\n return result;\r\n }\r\n\r\n /** Given the components of a [[QuadId]] and an elevation, compute the corresponding [Cartographic]($common) position.\r\n * @param x The X component of the QuadId.\r\n * @param y The Y component of the QuadId.\r\n * @param level The level component of the QuadId.\r\n * @param height The elevation above the ellipsoid.\r\n * @returns the corresponding cartographic position.\r\n */\r\n public tileXYToCartographic(x: number, y: number, level: number, result: Cartographic, height = 0): Cartographic {\r\n const pt = this.tileXYToFraction(x, y, level, this._scratchFraction);\r\n return this.fractionToCartographic(pt.x, pt.y, result, height);\r\n }\r\n\r\n /** Given the components of a [[QuadId]], compute the corresponding region of the Earth's surface. */\r\n public tileXYToRectangle(x: number, y: number, level: number, result?: MapCartoRectangle) {\r\n if (level < 0)\r\n return MapCartoRectangle.createMaximum();\r\n\r\n return MapCartoRectangle.fromRadians(\r\n this.tileXToLongitude(x, level),\r\n this.tileYToLatitude(this.rowZeroAtNorthPole ? (y + 1) : y, level),\r\n this.tileXToLongitude(x + 1, level),\r\n this.tileYToLatitude(this.rowZeroAtNorthPole ? y : (y + 1), level),\r\n result\r\n );\r\n }\r\n\r\n /** Returns true if the tile at the specified X coordinate and level is adjacent to the north pole. */\r\n public tileBordersNorthPole(row: number, level: number) {\r\n return this.rowZeroAtNorthPole ? this.tileYToFraction(row, level) === 0.0 : this.tileYToFraction(row + 1, level) === 1.0;\r\n }\r\n\r\n /** Returns true if the tile at the specified X coordinate and level is adjacent to the south pole. */\r\n public tileBordersSouthPole(row: number, level: number) {\r\n return this.rowZeroAtNorthPole ? this.tileYToFraction(row + 1, level) === 1.0 : this.tileYToFraction(row, level) === 0.0;\r\n }\r\n\r\n /** Given a cartographic position, compute the corresponding position on the surface of the Earth as fractional distances along the\r\n * X and Y axes.\r\n */\r\n public cartographicToTileXY(carto: Cartographic, level: number, result?: Point2d): Point2d {\r\n const fraction = this.cartographicToFraction(carto.latitude, carto.longitude, this._scratchPoint2d);\r\n return Point2d.create(this.xFractionToTileX(fraction.x, level), this.yFractionToTileY(fraction.y, level), result);\r\n\r\n }\r\n\r\n /** Given fractional coordinates in the XY plane and an elevation, compute the corresponding cartographic position. */\r\n public fractionToCartographic(xFraction: number, yFraction: number, result: Cartographic, height = 0): Cartographic {\r\n result.longitude = this.xFractionToLongitude(xFraction);\r\n result.latitude = this.yFractionToLatitude(yFraction);\r\n result.height = height;\r\n return result;\r\n }\r\n\r\n /** Given a cartographic location on the surface of the Earth, convert it to fractional coordinates in the XY plane. */\r\n public cartographicToFraction(latitudeRadians: number, longitudeRadians: number, result: Point2d): Point2d {\r\n result.x = this.longitudeToXFraction(longitudeRadians);\r\n result.y = this.latitudeToYFraction(latitudeRadians);\r\n return result;\r\n }\r\n\r\n /** @alpha */\r\n private ecefToPixelFraction(point: Point3d, applyTerrain: boolean): Point3d {\r\n const cartoGraphic = Cartographic.fromEcef(point)!;\r\n return Point3d.create(this.longitudeToXFraction(cartoGraphic.longitude), this.latitudeToYFraction(cartoGraphic.latitude), applyTerrain ? cartoGraphic.height : 0);\r\n }\r\n\r\n /** @alpha */\r\n public computeMercatorFractionToDb(ecefToDb: Transform, bimElevationOffset: number, iModel: IModelConnection, applyTerrain: boolean) {\r\n const dbToEcef = ecefToDb.inverse()!;\r\n\r\n const projectCenter = Point3d.create(iModel.projectExtents.center.x, iModel.projectExtents.center.y, bimElevationOffset);\r\n const projectEast = projectCenter.plusXYZ(1, 0, 0);\r\n const projectNorth = projectCenter.plusXYZ(0, 1, 0);\r\n\r\n const mercatorOrigin = this.ecefToPixelFraction(dbToEcef.multiplyPoint3d(projectCenter), applyTerrain);\r\n const mercatorX = this.ecefToPixelFraction(dbToEcef.multiplyPoint3d(projectEast), applyTerrain);\r\n const mercatorY = this.ecefToPixelFraction(dbToEcef.multiplyPoint3d(projectNorth), applyTerrain);\r\n\r\n const deltaX = Vector3d.createStartEnd(mercatorOrigin, mercatorX);\r\n const deltaY = Vector3d.createStartEnd(mercatorOrigin, mercatorY);\r\n const matrix = Matrix3d.createColumns(deltaX, deltaY, Vector3d.create(0, 0, 1));\r\n\r\n const dbToMercator = Transform.createMatrixPickupPutdown(matrix, projectCenter, mercatorOrigin);\r\n const mercatorToDb = dbToMercator.inverse();\r\n return mercatorToDb === undefined ? Transform.createIdentity() : mercatorToDb;\r\n }\r\n\r\n /** @alpha */\r\n protected yFractionFlip(fraction: number) {\r\n return this.rowZeroAtNorthPole ? (1.0 - fraction) : fraction;\r\n }\r\n}\r\n\r\n/** A [[MapTilingScheme]] using a simple geographic projection by which longitude and latitude are mapped directly to X and Y.\r\n * This projection is commonly known as \"geographic\", \"equirectangular\", \"equidistant cylindrical\", or \"plate carrée\".\r\n * @beta\r\n */\r\nexport class GeographicTilingScheme extends MapTilingScheme {\r\n public constructor(numberOfLevelZeroTilesX = 2, numberOfLevelZeroTilesY = 1, rowZeroAtNorthPole = false) {\r\n super(numberOfLevelZeroTilesX, numberOfLevelZeroTilesY, rowZeroAtNorthPole);\r\n }\r\n\r\n /** @internal override */\r\n public yFractionToLatitude(yFraction: number): number {\r\n return Math.PI * (this.yFractionFlip(yFraction) - .5);\r\n }\r\n\r\n /** @internal override */\r\n public latitudeToYFraction(latitude: number): number {\r\n return this.yFractionFlip(.5 + latitude / Math.PI);\r\n }\r\n}\r\n\r\n/** @alpha */\r\nexport class WebMercatorProjection {\r\n /**\r\n * Converts a Mercator angle, in the range -PI to PI, to a geodetic latitude\r\n * in the range -PI/2 to PI/2.\r\n *\r\n * @param {Number} mercatorAngle The angle to convert.\r\n * @returns {Number} The geodetic latitude in radians.\r\n */\r\n public static mercatorAngleToGeodeticLatitude(mercatorAngle: number) {\r\n return Angle.piOver2Radians - (2.0 * Math.atan(Math.exp(-mercatorAngle)));\r\n }\r\n\r\n public static maximumLatitude = WebMercatorProjection.mercatorAngleToGeodeticLatitude(Angle.piRadians);\r\n\r\n public static geodeticLatitudeToMercatorAngle(latitude: number) {\r\n // Clamp the latitude coordinate to the valid Mercator bounds.\r\n if (latitude > WebMercatorProjection.maximumLatitude)\r\n latitude = WebMercatorProjection.maximumLatitude;\r\n else if (latitude < -WebMercatorProjection.maximumLatitude)\r\n latitude = -WebMercatorProjection.maximumLatitude;\r\n\r\n const sinLatitude = Math.sin(latitude);\r\n return 0.5 * Math.log((1.0 + sinLatitude) / (1.0 - sinLatitude));\r\n }\r\n}\r\n\r\n/** A [[MapTilingScheme]] using the [EPSG:3857](https://en.wikipedia.org/wiki/Web_Mercator_projection) projection.\r\n * This scheme is used by most [tiled web maps](https://en.wikipedia.org/wiki/Tiled_web_map), including Bing Maps and Google Maps.\r\n * @beta\r\n */\r\nexport class WebMercatorTilingScheme extends MapTilingScheme {\r\n public constructor(numberOfLevelZeroTilesX = 1, numberOfLevelZeroTilesY = 1, rowZeroAtNorthPole = true) {\r\n super(numberOfLevelZeroTilesX, numberOfLevelZeroTilesY, rowZeroAtNorthPole);\r\n }\r\n\r\n /** @internal override */\r\n public yFractionToLatitude(yFraction: number): number {\r\n const mercatorAngle = Angle.pi2Radians * (this.rowZeroAtNorthPole ? (.5 - yFraction) : (yFraction - .5));\r\n return WebMercatorProjection.mercatorAngleToGeodeticLatitude(mercatorAngle);\r\n }\r\n\r\n /** @internal override */\r\n public latitudeToYFraction(latitude: number): number {\r\n // Clamp the latitude coordinate to the valid Mercator bounds.\r\n if (latitude > WebMercatorProjection.maximumLatitude) {\r\n latitude = WebMercatorProjection.maximumLatitude;\r\n } else if (latitude < -WebMercatorProjection.maximumLatitude) {\r\n latitude = -WebMercatorProjection.maximumLatitude;\r\n }\r\n const sinLatitude = Math.sin(latitude);\r\n return (0.5 - Math.log((1.0 + sinLatitude) / (1.0 - sinLatitude)) / (4.0 * Angle.piRadians)); // https://msdn.microsoft.com/en-us/library/bb259689.aspx\r\n }\r\n}\r\n"]}
@@ -3,25 +3,47 @@
3
3
  */
4
4
  import { AngleSweep, Range2d } from "@itwin/core-geometry";
5
5
  import { MapTilingScheme } from "../internal";
6
- /** @internal */
6
+ /** Identifies a node within a [quad tree](https://en.wikipedia.org/wiki/Quadtree), such as a [[MapTile]] within a [[MapTileTree]].
7
+ * A quad tree recursively sub-divides a two-dimensional space along the X and Y axes such that each node on level L has four child nodes on
8
+ * level L+1.
9
+ * @beta
10
+ */
7
11
  export declare class QuadId {
12
+ /** The level of the node within the tree, increasing with each subdivision, as a non-negative integer. */
8
13
  level: number;
14
+ /** The node's position along the X axis as a non-negative integer. */
9
15
  column: number;
16
+ /** The node's position along the Y axis as a non-negative integer. */
10
17
  row: number;
18
+ /** @alpha */
11
19
  get isValid(): boolean;
20
+ /** @alpha */
12
21
  static createFromContentId(stringId: string): QuadId;
22
+ /** @alpha */
13
23
  get contentId(): string;
24
+ /** @alpha */
14
25
  static getTileContentId(level: number, column: number, row: number): string;
26
+ /** @alpha */
15
27
  get debugString(): string;
28
+ /** Construct a new QuadId. The inputs are expected to be non-negative integers. */
16
29
  constructor(level: number, column: number, row: number);
30
+ /** Compute the QuadIds corresponding to this node's four child nodes. */
17
31
  getChildIds(columnCount?: number, rowCount?: number): QuadId[];
18
- getLatLongRange(mapTilingScheme: MapTilingScheme): Range2d;
32
+ /** Compute the region of the surface of the Earth represented by this node according to the specified tiling scheme. */
33
+ getLatLongRangeDegrees(mapTilingScheme: MapTilingScheme): Range2d;
34
+ /** Compute the region of the surface of the Earth represented by this node according to the specified tiling scheme. */
35
+ getLatLongRangeRadians(mapTilingScheme: MapTilingScheme): Range2d;
36
+ private _getLatLongRange;
37
+ /** @alpha */
19
38
  getAngleSweep(mapTilingScheme: MapTilingScheme): {
20
39
  longitude: AngleSweep;
21
40
  latitude: AngleSweep;
22
41
  };
42
+ /** Returns true if this node is adjacent to the south pole according to the specified tiling scheme. */
23
43
  bordersSouthPole(mapTilingScheme: MapTilingScheme): boolean;
44
+ /** Returns true if this node is adjacent to the north pole according to the specified tiling scheme. */
24
45
  bordersNorthPole(mapTilingScheme: MapTilingScheme): boolean;
46
+ /** Compares this Id to another according to the conventions of an [OrderedComparator]($bentley). */
25
47
  compare(other: QuadId): number;
26
48
  }
27
49
  //# sourceMappingURL=QuadId.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"QuadId.d.ts","sourceRoot":"","sources":["../../../../src/tile/map/QuadId.ts"],"names":[],"mappings":"AAIA;;GAEG;AAGH,OAAO,EAAS,UAAU,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAElE,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAK9C,gBAAgB;AAChB,qBAAa,MAAM;IACV,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,MAAM,CAAC;IACnB,IAAW,OAAO,YAA8B;WAElC,mBAAmB,CAAC,QAAQ,EAAE,MAAM;IAUlD,IAAW,SAAS,IAAI,MAAM,CAAwE;WACxF,gBAAgB,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,MAAM;IAElF,IAAW,WAAW,IAAI,MAAM,CAA2E;gBAExF,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM;IAKtD,WAAW,CAAC,WAAW,SAAI,EAAE,QAAQ,SAAI,GAAG,MAAM,EAAE;IAapD,eAAe,CAAC,eAAe,EAAE,eAAe,GAAG,OAAO;IAU1D,aAAa,CAAC,eAAe,EAAE,eAAe,GAAG;QAAE,SAAS,EAAE,UAAU,CAAC;QAAC,QAAQ,EAAE,UAAU,CAAA;KAAE;IAMhG,gBAAgB,CAAC,eAAe,EAAE,eAAe;IAIjD,gBAAgB,CAAC,eAAe,EAAE,eAAe;IAGjD,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;CAStC"}
1
+ {"version":3,"file":"QuadId.d.ts","sourceRoot":"","sources":["../../../../src/tile/map/QuadId.ts"],"names":[],"mappings":"AAIA;;GAEG;AAGH,OAAO,EAAS,UAAU,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAElE,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAK9C;;;;GAIG;AACH,qBAAa,MAAM;IACjB,0GAA0G;IACnG,KAAK,EAAE,MAAM,CAAC;IACrB,sEAAsE;IAC/D,MAAM,EAAE,MAAM,CAAC;IACtB,sEAAsE;IAC/D,GAAG,EAAE,MAAM,CAAC;IAEnB,aAAa;IACb,IAAW,OAAO,YAEjB;IAED,aAAa;WACC,mBAAmB,CAAC,QAAQ,EAAE,MAAM;IASlD,aAAa;IACb,IAAW,SAAS,IAAI,MAAM,CAE7B;IAED,aAAa;WACC,gBAAgB,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,MAAM;IAIlF,aAAa;IACb,IAAW,WAAW,IAAI,MAAM,CAE/B;IAED,mFAAmF;gBAChE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM;IAM7D,yEAAyE;IAClE,WAAW,CAAC,WAAW,SAAI,EAAE,QAAQ,SAAI,GAAG,MAAM,EAAE;IAY3D,wHAAwH;IACjH,sBAAsB,CAAC,eAAe,EAAE,eAAe,GAAG,OAAO;IAIxE,wHAAwH;IACjH,sBAAsB,CAAC,eAAe,EAAE,eAAe,GAAG,OAAO;IAIxE,OAAO,CAAC,gBAAgB;IAYxB,aAAa;IACN,aAAa,CAAC,eAAe,EAAE,eAAe,GAAG;QAAE,SAAS,EAAE,UAAU,CAAC;QAAC,QAAQ,EAAE,UAAU,CAAA;KAAE;IAYvG,wGAAwG;IACjG,gBAAgB,CAAC,eAAe,EAAE,eAAe;IAIxD,wGAAwG;IACjG,gBAAgB,CAAC,eAAe,EAAE,eAAe;IAIxD,oGAAoG;IAC7F,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;CAKtC"}
@@ -13,25 +13,43 @@ const core_geometry_1 = require("@itwin/core-geometry");
13
13
  const core_common_1 = require("@itwin/core-common");
14
14
  const scratchCartographic1 = core_common_1.Cartographic.createZero();
15
15
  const scratchCartographic2 = core_common_1.Cartographic.createZero();
16
- /** @internal */
16
+ /** Identifies a node within a [quad tree](https://en.wikipedia.org/wiki/Quadtree), such as a [[MapTile]] within a [[MapTileTree]].
17
+ * A quad tree recursively sub-divides a two-dimensional space along the X and Y axes such that each node on level L has four child nodes on
18
+ * level L+1.
19
+ * @beta
20
+ */
17
21
  class QuadId {
22
+ /** Construct a new QuadId. The inputs are expected to be non-negative integers. */
18
23
  constructor(level, column, row) {
19
24
  this.level = level;
20
25
  this.column = column;
21
26
  this.row = row;
22
27
  }
23
- get isValid() { return this.level >= 0; }
28
+ /** @alpha */
29
+ get isValid() {
30
+ return this.level >= 0;
31
+ }
32
+ /** @alpha */
24
33
  static createFromContentId(stringId) {
25
34
  const idParts = stringId.split("_");
26
- if (3 !== idParts.length) {
27
- (0, core_bentley_1.assert)(false, "Invalid quad tree ID");
35
+ (0, core_bentley_1.assert)(idParts.length === 3);
36
+ if (3 !== idParts.length)
28
37
  return new QuadId(-1, -1, -1);
29
- }
30
38
  return new QuadId(parseInt(idParts[0], 10), parseInt(idParts[1], 10), parseInt(idParts[2], 10));
31
39
  }
32
- get contentId() { return QuadId.getTileContentId(this.level, this.column, this.row); }
33
- static getTileContentId(level, column, row) { return `${level}_${column}_${row}`; }
34
- get debugString() { return `Level: ${this.level} Column: ${this.column} Row: ${this.row}`; }
40
+ /** @alpha */
41
+ get contentId() {
42
+ return QuadId.getTileContentId(this.level, this.column, this.row);
43
+ }
44
+ /** @alpha */
45
+ static getTileContentId(level, column, row) {
46
+ return `${level}_${column}_${row}`;
47
+ }
48
+ /** @alpha */
49
+ get debugString() {
50
+ return `Level: ${this.level} Column: ${this.column} Row: ${this.row}`;
51
+ }
52
+ /** Compute the QuadIds corresponding to this node's four child nodes. */
35
53
  getChildIds(columnCount = 2, rowCount = 2) {
36
54
  const childIds = [];
37
55
  const level = this.level + 1;
@@ -42,34 +60,45 @@ class QuadId {
42
60
  childIds.push(new QuadId(level, column + i, row + j));
43
61
  return childIds;
44
62
  }
45
- // Not used in display - used only to tell whether this tile overlaps the range provided by a tile provider for attribution.
46
- getLatLongRange(mapTilingScheme) {
63
+ /** Compute the region of the surface of the Earth represented by this node according to the specified tiling scheme. */
64
+ getLatLongRangeDegrees(mapTilingScheme) {
65
+ return this._getLatLongRange(mapTilingScheme, "degrees");
66
+ }
67
+ /** Compute the region of the surface of the Earth represented by this node according to the specified tiling scheme. */
68
+ getLatLongRangeRadians(mapTilingScheme) {
69
+ return this._getLatLongRange(mapTilingScheme, "radians");
70
+ }
71
+ _getLatLongRange(mapTilingScheme, units) {
47
72
  const range = core_geometry_1.Range2d.createNull();
73
+ const factor = "degrees" === units ? core_geometry_1.Angle.degreesPerRadian : 1;
48
74
  mapTilingScheme.tileXYToCartographic(this.column, this.row, this.level, scratchCartographic1);
49
- range.extendXY(scratchCartographic1.longitude * core_geometry_1.Angle.degreesPerRadian, scratchCartographic1.latitude * core_geometry_1.Angle.degreesPerRadian);
75
+ range.extendXY(scratchCartographic1.longitude * factor, scratchCartographic1.latitude * factor);
50
76
  mapTilingScheme.tileXYToCartographic(this.column + 1, this.row + 1, this.level, scratchCartographic2);
51
- range.extendXY(scratchCartographic2.longitude * core_geometry_1.Angle.degreesPerRadian, scratchCartographic2.latitude * core_geometry_1.Angle.degreesPerRadian);
77
+ range.extendXY(scratchCartographic2.longitude * factor, scratchCartographic2.latitude * factor);
52
78
  return range;
53
79
  }
80
+ /** @alpha */
54
81
  getAngleSweep(mapTilingScheme) {
55
82
  mapTilingScheme.tileXYToCartographic(this.column, this.row, this.level, scratchCartographic1);
56
83
  mapTilingScheme.tileXYToCartographic(this.column + 1, this.row + 1, this.level, scratchCartographic2);
57
- return { longitude: core_geometry_1.AngleSweep.createStartEndRadians(scratchCartographic1.longitude, scratchCartographic2.longitude), latitude: core_geometry_1.AngleSweep.createStartEndRadians(core_common_1.Cartographic.parametricLatitudeFromGeodeticLatitude(scratchCartographic1.latitude), core_common_1.Cartographic.parametricLatitudeFromGeodeticLatitude(scratchCartographic2.latitude)) };
84
+ return {
85
+ longitude: core_geometry_1.AngleSweep.createStartEndRadians(scratchCartographic1.longitude, scratchCartographic2.longitude),
86
+ latitude: core_geometry_1.AngleSweep.createStartEndRadians(core_common_1.Cartographic.parametricLatitudeFromGeodeticLatitude(scratchCartographic1.latitude), core_common_1.Cartographic.parametricLatitudeFromGeodeticLatitude(scratchCartographic2.latitude)),
87
+ };
58
88
  }
89
+ /** Returns true if this node is adjacent to the south pole according to the specified tiling scheme. */
59
90
  bordersSouthPole(mapTilingScheme) {
60
91
  return mapTilingScheme.tileBordersSouthPole(this.row, this.level);
61
92
  }
93
+ /** Returns true if this node is adjacent to the north pole according to the specified tiling scheme. */
62
94
  bordersNorthPole(mapTilingScheme) {
63
95
  return mapTilingScheme.tileBordersNorthPole(this.row, this.level);
64
96
  }
97
+ /** Compares this Id to another according to the conventions of an [OrderedComparator]($bentley). */
65
98
  compare(other) {
66
- let cmp = (0, core_bentley_1.compareNumbers)(this.level, other.level);
67
- if (0 === cmp) {
68
- cmp = (0, core_bentley_1.compareNumbers)(this.row, other.row);
69
- if (0 === cmp)
70
- cmp = (0, core_bentley_1.compareNumbers)(this.column, other.column);
71
- }
72
- return cmp;
99
+ return (0, core_bentley_1.compareNumbers)(this.level, other.level) ||
100
+ (0, core_bentley_1.compareNumbers)(this.row, other.row) ||
101
+ (0, core_bentley_1.compareNumbers)(this.column, other.column);
73
102
  }
74
103
  }
75
104
  exports.QuadId = QuadId;
@@ -1 +1 @@
1
- {"version":3,"file":"QuadId.js","sourceRoot":"","sources":["../../../../src/tile/map/QuadId.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module Tiles\r\n */\r\n\r\nimport { assert, compareNumbers } from \"@itwin/core-bentley\";\r\nimport { Angle, AngleSweep, Range2d } from \"@itwin/core-geometry\";\r\nimport { Cartographic } from \"@itwin/core-common\";\r\nimport { MapTilingScheme } from \"../internal\";\r\n\r\nconst scratchCartographic1 = Cartographic.createZero();\r\nconst scratchCartographic2 = Cartographic.createZero();\r\n\r\n/** @internal */\r\nexport class QuadId {\r\n public level: number;\r\n public column: number;\r\n public row: number;\r\n public get isValid() { return this.level >= 0; }\r\n\r\n public static createFromContentId(stringId: string) {\r\n const idParts = stringId.split(\"_\");\r\n if (3 !== idParts.length) {\r\n assert(false, \"Invalid quad tree ID\");\r\n return new QuadId(-1, -1, -1);\r\n }\r\n\r\n return new QuadId(parseInt(idParts[0], 10), parseInt(idParts[1], 10), parseInt(idParts[2], 10));\r\n }\r\n\r\n public get contentId(): string { return QuadId.getTileContentId(this.level, this.column, this.row); }\r\n public static getTileContentId(level: number, column: number, row: number): string { return `${level}_${column}_${row}`; }\r\n\r\n public get debugString(): string { return `Level: ${this.level} Column: ${this.column} Row: ${this.row}`; }\r\n\r\n public constructor(level: number, column: number, row: number) {\r\n this.level = level;\r\n this.column = column;\r\n this.row = row;\r\n }\r\n public getChildIds(columnCount = 2, rowCount = 2): QuadId[] {\r\n const childIds = [];\r\n const level = this.level + 1;\r\n const column = this.column * 2;\r\n const row = this.row * 2;\r\n for (let j = 0; j < rowCount; j++)\r\n for (let i = 0; i < columnCount; i++)\r\n childIds.push(new QuadId(level, column + i, row + j));\r\n\r\n return childIds;\r\n }\r\n\r\n // Not used in display - used only to tell whether this tile overlaps the range provided by a tile provider for attribution.\r\n public getLatLongRange(mapTilingScheme: MapTilingScheme): Range2d {\r\n const range = Range2d.createNull();\r\n mapTilingScheme.tileXYToCartographic(this.column, this.row, this.level, scratchCartographic1);\r\n range.extendXY(scratchCartographic1.longitude * Angle.degreesPerRadian, scratchCartographic1.latitude * Angle.degreesPerRadian);\r\n mapTilingScheme.tileXYToCartographic(this.column + 1, this.row + 1, this.level, scratchCartographic2);\r\n range.extendXY(scratchCartographic2.longitude * Angle.degreesPerRadian, scratchCartographic2.latitude * Angle.degreesPerRadian);\r\n\r\n return range;\r\n }\r\n\r\n public getAngleSweep(mapTilingScheme: MapTilingScheme): { longitude: AngleSweep, latitude: AngleSweep } {\r\n mapTilingScheme.tileXYToCartographic(this.column, this.row, this.level, scratchCartographic1);\r\n mapTilingScheme.tileXYToCartographic(this.column + 1, this.row + 1, this.level, scratchCartographic2);\r\n return { longitude: AngleSweep.createStartEndRadians(scratchCartographic1.longitude, scratchCartographic2.longitude), latitude: AngleSweep.createStartEndRadians(Cartographic.parametricLatitudeFromGeodeticLatitude(scratchCartographic1.latitude), Cartographic.parametricLatitudeFromGeodeticLatitude(scratchCartographic2.latitude)) };\r\n }\r\n\r\n public bordersSouthPole(mapTilingScheme: MapTilingScheme) {\r\n return mapTilingScheme.tileBordersSouthPole(this.row, this.level);\r\n }\r\n\r\n public bordersNorthPole(mapTilingScheme: MapTilingScheme) {\r\n return mapTilingScheme.tileBordersNorthPole(this.row, this.level);\r\n }\r\n public compare(other: QuadId): number {\r\n let cmp = compareNumbers(this.level, other.level);\r\n if (0 === cmp) {\r\n cmp = compareNumbers(this.row, other.row);\r\n if (0 === cmp)\r\n cmp = compareNumbers(this.column, other.column);\r\n }\r\n return cmp;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"QuadId.js","sourceRoot":"","sources":["../../../../src/tile/map/QuadId.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module Tiles\r\n */\r\n\r\nimport { assert, compareNumbers } from \"@itwin/core-bentley\";\r\nimport { Angle, AngleSweep, Range2d } from \"@itwin/core-geometry\";\r\nimport { Cartographic } from \"@itwin/core-common\";\r\nimport { MapTilingScheme } from \"../internal\";\r\n\r\nconst scratchCartographic1 = Cartographic.createZero();\r\nconst scratchCartographic2 = Cartographic.createZero();\r\n\r\n/** Identifies a node within a [quad tree](https://en.wikipedia.org/wiki/Quadtree), such as a [[MapTile]] within a [[MapTileTree]].\r\n * A quad tree recursively sub-divides a two-dimensional space along the X and Y axes such that each node on level L has four child nodes on\r\n * level L+1.\r\n * @beta\r\n */\r\nexport class QuadId {\r\n /** The level of the node within the tree, increasing with each subdivision, as a non-negative integer. */\r\n public level: number;\r\n /** The node's position along the X axis as a non-negative integer. */\r\n public column: number;\r\n /** The node's position along the Y axis as a non-negative integer. */\r\n public row: number;\r\n\r\n /** @alpha */\r\n public get isValid() {\r\n return this.level >= 0;\r\n }\r\n\r\n /** @alpha */\r\n public static createFromContentId(stringId: string) {\r\n const idParts = stringId.split(\"_\");\r\n assert(idParts.length === 3);\r\n if (3 !== idParts.length)\r\n return new QuadId(-1, -1, -1);\r\n\r\n return new QuadId(parseInt(idParts[0], 10), parseInt(idParts[1], 10), parseInt(idParts[2], 10));\r\n }\r\n\r\n /** @alpha */\r\n public get contentId(): string {\r\n return QuadId.getTileContentId(this.level, this.column, this.row);\r\n }\r\n\r\n /** @alpha */\r\n public static getTileContentId(level: number, column: number, row: number): string {\r\n return `${level}_${column}_${row}`;\r\n }\r\n\r\n /** @alpha */\r\n public get debugString(): string {\r\n return `Level: ${this.level} Column: ${this.column} Row: ${this.row}`;\r\n }\r\n\r\n /** Construct a new QuadId. The inputs are expected to be non-negative integers. */\r\n public constructor(level: number, column: number, row: number) {\r\n this.level = level;\r\n this.column = column;\r\n this.row = row;\r\n }\r\n\r\n /** Compute the QuadIds corresponding to this node's four child nodes. */\r\n public getChildIds(columnCount = 2, rowCount = 2): QuadId[] {\r\n const childIds = [];\r\n const level = this.level + 1;\r\n const column = this.column * 2;\r\n const row = this.row * 2;\r\n for (let j = 0; j < rowCount; j++)\r\n for (let i = 0; i < columnCount; i++)\r\n childIds.push(new QuadId(level, column + i, row + j));\r\n\r\n return childIds;\r\n }\r\n\r\n /** Compute the region of the surface of the Earth represented by this node according to the specified tiling scheme. */\r\n public getLatLongRangeDegrees(mapTilingScheme: MapTilingScheme): Range2d {\r\n return this._getLatLongRange(mapTilingScheme, \"degrees\");\r\n }\r\n\r\n /** Compute the region of the surface of the Earth represented by this node according to the specified tiling scheme. */\r\n public getLatLongRangeRadians(mapTilingScheme: MapTilingScheme): Range2d {\r\n return this._getLatLongRange(mapTilingScheme, \"radians\");\r\n }\r\n\r\n private _getLatLongRange(mapTilingScheme: MapTilingScheme, units: \"radians\" | \"degrees\"): Range2d {\r\n const range = Range2d.createNull();\r\n const factor = \"degrees\" === units ? Angle.degreesPerRadian : 1;\r\n\r\n mapTilingScheme.tileXYToCartographic(this.column, this.row, this.level, scratchCartographic1);\r\n range.extendXY(scratchCartographic1.longitude * factor, scratchCartographic1.latitude * factor);\r\n mapTilingScheme.tileXYToCartographic(this.column + 1, this.row + 1, this.level, scratchCartographic2);\r\n range.extendXY(scratchCartographic2.longitude * factor, scratchCartographic2.latitude * factor);\r\n\r\n return range;\r\n }\r\n\r\n /** @alpha */\r\n public getAngleSweep(mapTilingScheme: MapTilingScheme): { longitude: AngleSweep, latitude: AngleSweep } {\r\n mapTilingScheme.tileXYToCartographic(this.column, this.row, this.level, scratchCartographic1);\r\n mapTilingScheme.tileXYToCartographic(this.column + 1, this.row + 1, this.level, scratchCartographic2);\r\n return {\r\n longitude: AngleSweep.createStartEndRadians(scratchCartographic1.longitude, scratchCartographic2.longitude),\r\n latitude: AngleSweep.createStartEndRadians(\r\n Cartographic.parametricLatitudeFromGeodeticLatitude(scratchCartographic1.latitude),\r\n Cartographic.parametricLatitudeFromGeodeticLatitude(scratchCartographic2.latitude)\r\n ),\r\n };\r\n }\r\n\r\n /** Returns true if this node is adjacent to the south pole according to the specified tiling scheme. */\r\n public bordersSouthPole(mapTilingScheme: MapTilingScheme) {\r\n return mapTilingScheme.tileBordersSouthPole(this.row, this.level);\r\n }\r\n\r\n /** Returns true if this node is adjacent to the north pole according to the specified tiling scheme. */\r\n public bordersNorthPole(mapTilingScheme: MapTilingScheme) {\r\n return mapTilingScheme.tileBordersNorthPole(this.row, this.level);\r\n }\r\n\r\n /** Compares this Id to another according to the conventions of an [OrderedComparator]($bentley). */\r\n public compare(other: QuadId): number {\r\n return compareNumbers(this.level, other.level) ||\r\n compareNumbers(this.row, other.row) ||\r\n compareNumbers(this.column, other.column);\r\n }\r\n}\r\n"]}