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

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 (698) 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/DevTools.d.ts.map +1 -1
  17. package/lib/cjs/DevTools.js.map +1 -1
  18. package/lib/cjs/DisplayStyleState.js +1 -1
  19. package/lib/cjs/DisplayStyleState.js.map +1 -1
  20. package/lib/cjs/ElementLocateManager.d.ts.map +1 -1
  21. package/lib/cjs/ElementLocateManager.js +4 -2
  22. package/lib/cjs/ElementLocateManager.js.map +1 -1
  23. package/lib/cjs/FrustumAnimator.d.ts.map +1 -1
  24. package/lib/cjs/FrustumAnimator.js +5 -1
  25. package/lib/cjs/FrustumAnimator.js.map +1 -1
  26. package/lib/cjs/FuzzySearch.d.ts.map +1 -1
  27. package/lib/cjs/FuzzySearch.js +9 -3
  28. package/lib/cjs/FuzzySearch.js.map +1 -1
  29. package/lib/cjs/HitDetail.d.ts.map +1 -1
  30. package/lib/cjs/HitDetail.js +13 -3
  31. package/lib/cjs/HitDetail.js.map +1 -1
  32. package/lib/cjs/IModelApp.d.ts +7 -2
  33. package/lib/cjs/IModelApp.d.ts.map +1 -1
  34. package/lib/cjs/IModelApp.js +10 -2
  35. package/lib/cjs/IModelApp.js.map +1 -1
  36. package/lib/cjs/IModelConnection.d.ts.map +1 -1
  37. package/lib/cjs/IModelConnection.js +3 -1
  38. package/lib/cjs/IModelConnection.js.map +1 -1
  39. package/lib/cjs/ImageUtil.d.ts +6 -0
  40. package/lib/cjs/ImageUtil.d.ts.map +1 -1
  41. package/lib/cjs/ImageUtil.js +14 -1
  42. package/lib/cjs/ImageUtil.js.map +1 -1
  43. package/lib/cjs/Marker.d.ts.map +1 -1
  44. package/lib/cjs/Marker.js +5 -1
  45. package/lib/cjs/Marker.js.map +1 -1
  46. package/lib/cjs/NativeAppLogger.d.ts.map +1 -1
  47. package/lib/cjs/NativeAppLogger.js +1 -1
  48. package/lib/cjs/NativeAppLogger.js.map +1 -1
  49. package/lib/cjs/TentativePoint.d.ts.map +1 -1
  50. package/lib/cjs/TentativePoint.js.map +1 -1
  51. package/lib/cjs/ViewManager.d.ts +4 -0
  52. package/lib/cjs/ViewManager.d.ts.map +1 -1
  53. package/lib/cjs/ViewManager.js +9 -3
  54. package/lib/cjs/ViewManager.js.map +1 -1
  55. package/lib/cjs/ViewRect.d.ts.map +1 -1
  56. package/lib/cjs/ViewRect.js +5 -1
  57. package/lib/cjs/ViewRect.js.map +1 -1
  58. package/lib/cjs/ViewState.d.ts +36 -12
  59. package/lib/cjs/ViewState.d.ts.map +1 -1
  60. package/lib/cjs/ViewState.js +35 -25
  61. package/lib/cjs/ViewState.js.map +1 -1
  62. package/lib/cjs/ViewingSpace.d.ts.map +1 -1
  63. package/lib/cjs/ViewingSpace.js +12 -5
  64. package/lib/cjs/ViewingSpace.js.map +1 -1
  65. package/lib/cjs/Viewport.d.ts +14 -0
  66. package/lib/cjs/Viewport.d.ts.map +1 -1
  67. package/lib/cjs/Viewport.js +106 -5
  68. package/lib/cjs/Viewport.js.map +1 -1
  69. package/lib/cjs/core-frontend.d.ts +6 -0
  70. package/lib/cjs/core-frontend.d.ts.map +1 -1
  71. package/lib/cjs/core-frontend.js +6 -0
  72. package/lib/cjs/core-frontend.js.map +1 -1
  73. package/lib/cjs/extension/ExtensionAdmin.d.ts.map +1 -1
  74. package/lib/cjs/extension/ExtensionAdmin.js.map +1 -1
  75. package/lib/cjs/extension/ExtensionImpl.d.ts.map +1 -1
  76. package/lib/cjs/extension/ExtensionImpl.js +3 -1
  77. package/lib/cjs/extension/ExtensionImpl.js.map +1 -1
  78. package/lib/cjs/public/scripts/checkbrowser.js +24 -0
  79. package/lib/cjs/render/Decorations.d.ts.map +1 -1
  80. package/lib/cjs/render/Decorations.js +24 -6
  81. package/lib/cjs/render/Decorations.js.map +1 -1
  82. package/lib/cjs/render/RealityMeshGraphicParams.d.ts +19 -0
  83. package/lib/cjs/render/RealityMeshGraphicParams.d.ts.map +1 -0
  84. package/lib/cjs/render/RealityMeshGraphicParams.js +10 -0
  85. package/lib/cjs/render/RealityMeshGraphicParams.js.map +1 -0
  86. package/lib/cjs/render/RealityMeshParams.d.ts +130 -0
  87. package/lib/cjs/render/RealityMeshParams.d.ts.map +1 -0
  88. package/lib/cjs/render/RealityMeshParams.js +176 -0
  89. package/lib/cjs/render/RealityMeshParams.js.map +1 -0
  90. package/lib/cjs/render/RenderSystem.d.ts +8 -4
  91. package/lib/cjs/render/RenderSystem.d.ts.map +1 -1
  92. package/lib/cjs/render/RenderSystem.js +7 -1
  93. package/lib/cjs/render/RenderSystem.js.map +1 -1
  94. package/lib/cjs/render/RenderTexture.d.ts +1 -1
  95. package/lib/cjs/render/RenderTexture.d.ts.map +1 -1
  96. package/lib/cjs/render/RenderTexture.js.map +1 -1
  97. package/lib/cjs/render/UpsampleRealityMeshParams.d.ts +11 -0
  98. package/lib/cjs/render/UpsampleRealityMeshParams.d.ts.map +1 -0
  99. package/lib/cjs/render/UpsampleRealityMeshParams.js +205 -0
  100. package/lib/cjs/render/UpsampleRealityMeshParams.js.map +1 -0
  101. package/lib/cjs/render/primitives/DisplayParams.d.ts.map +1 -1
  102. package/lib/cjs/render/primitives/DisplayParams.js.map +1 -1
  103. package/lib/cjs/render/primitives/Polyface.d.ts.map +1 -1
  104. package/lib/cjs/render/primitives/Polyface.js +3 -1
  105. package/lib/cjs/render/primitives/Polyface.js.map +1 -1
  106. package/lib/cjs/render/primitives/Primitives.d.ts.map +1 -1
  107. package/lib/cjs/render/primitives/Primitives.js.map +1 -1
  108. package/lib/cjs/render/primitives/Strokes.d.ts.map +1 -1
  109. package/lib/cjs/render/primitives/Strokes.js +6 -2
  110. package/lib/cjs/render/primitives/Strokes.js.map +1 -1
  111. package/lib/cjs/render/primitives/VertexTableSplitter.d.ts.map +1 -1
  112. package/lib/cjs/render/primitives/VertexTableSplitter.js +7 -85
  113. package/lib/cjs/render/primitives/VertexTableSplitter.js.map +1 -1
  114. package/lib/cjs/render/primitives/geometry/GeometryAccumulator.d.ts.map +1 -1
  115. package/lib/cjs/render/primitives/geometry/GeometryAccumulator.js +4 -1
  116. package/lib/cjs/render/primitives/geometry/GeometryAccumulator.js.map +1 -1
  117. package/lib/cjs/render/primitives/mesh/MeshBuilder.d.ts.map +1 -1
  118. package/lib/cjs/render/primitives/mesh/MeshBuilder.js.map +1 -1
  119. package/lib/cjs/render/webgl/BackgroundMapDrape.d.ts.map +1 -1
  120. package/lib/cjs/render/webgl/BackgroundMapDrape.js.map +1 -1
  121. package/lib/cjs/render/webgl/ColorInfo.d.ts.map +1 -1
  122. package/lib/cjs/render/webgl/ColorInfo.js +4 -1
  123. package/lib/cjs/render/webgl/ColorInfo.js.map +1 -1
  124. package/lib/cjs/render/webgl/DrawCommand.d.ts.map +1 -1
  125. package/lib/cjs/render/webgl/DrawCommand.js +12 -3
  126. package/lib/cjs/render/webgl/DrawCommand.js.map +1 -1
  127. package/lib/cjs/render/webgl/FrameBuffer.d.ts.map +1 -1
  128. package/lib/cjs/render/webgl/FrameBuffer.js +4 -1
  129. package/lib/cjs/render/webgl/FrameBuffer.js.map +1 -1
  130. package/lib/cjs/render/webgl/FrustumUniforms.js.map +1 -1
  131. package/lib/cjs/render/webgl/Graphic.d.ts.map +1 -1
  132. package/lib/cjs/render/webgl/Graphic.js +5 -2
  133. package/lib/cjs/render/webgl/Graphic.js.map +1 -1
  134. package/lib/cjs/render/webgl/Matrix.d.ts.map +1 -1
  135. package/lib/cjs/render/webgl/Matrix.js +16 -4
  136. package/lib/cjs/render/webgl/Matrix.js.map +1 -1
  137. package/lib/cjs/render/webgl/PerformanceMetrics.js +2 -2
  138. package/lib/cjs/render/webgl/PerformanceMetrics.js.map +1 -1
  139. package/lib/cjs/render/webgl/PlanarClassifier.d.ts.map +1 -1
  140. package/lib/cjs/render/webgl/PlanarClassifier.js +3 -1
  141. package/lib/cjs/render/webgl/PlanarClassifier.js.map +1 -1
  142. package/lib/cjs/render/webgl/PlanarTextureProjection.d.ts.map +1 -1
  143. package/lib/cjs/render/webgl/PlanarTextureProjection.js.map +1 -1
  144. package/lib/cjs/render/webgl/Primitive.d.ts.map +1 -1
  145. package/lib/cjs/render/webgl/Primitive.js.map +1 -1
  146. package/lib/cjs/render/webgl/RealityMesh.d.ts +6 -6
  147. package/lib/cjs/render/webgl/RealityMesh.d.ts.map +1 -1
  148. package/lib/cjs/render/webgl/RealityMesh.js +20 -12
  149. package/lib/cjs/render/webgl/RealityMesh.js.map +1 -1
  150. package/lib/cjs/render/webgl/RenderCommands.d.ts.map +1 -1
  151. package/lib/cjs/render/webgl/RenderCommands.js +3 -2
  152. package/lib/cjs/render/webgl/RenderCommands.js.map +1 -1
  153. package/lib/cjs/render/webgl/RenderFlags.d.ts.map +1 -1
  154. package/lib/cjs/render/webgl/RenderFlags.js +3 -1
  155. package/lib/cjs/render/webgl/RenderFlags.js.map +1 -1
  156. package/lib/cjs/render/webgl/ShaderBuilder.d.ts.map +1 -1
  157. package/lib/cjs/render/webgl/ShaderBuilder.js +4 -1
  158. package/lib/cjs/render/webgl/ShaderBuilder.js.map +1 -1
  159. package/lib/cjs/render/webgl/SolarShadowMap.d.ts.map +1 -1
  160. package/lib/cjs/render/webgl/SolarShadowMap.js +17 -5
  161. package/lib/cjs/render/webgl/SolarShadowMap.js.map +1 -1
  162. package/lib/cjs/render/webgl/System.d.ts +6 -4
  163. package/lib/cjs/render/webgl/System.d.ts.map +1 -1
  164. package/lib/cjs/render/webgl/System.js +21 -4
  165. package/lib/cjs/render/webgl/System.js.map +1 -1
  166. package/lib/cjs/render/webgl/Technique.d.ts.map +1 -1
  167. package/lib/cjs/render/webgl/Technique.js +3 -1
  168. package/lib/cjs/render/webgl/Technique.js.map +1 -1
  169. package/lib/cjs/render/webgl/TechniqueFlags.d.ts.map +1 -1
  170. package/lib/cjs/render/webgl/TechniqueFlags.js.map +1 -1
  171. package/lib/cjs/render/webgl/Texture.d.ts.map +1 -1
  172. package/lib/cjs/render/webgl/Texture.js +21 -12
  173. package/lib/cjs/render/webgl/Texture.js.map +1 -1
  174. package/lib/cjs/render/webgl/ThematicSensors.d.ts.map +1 -1
  175. package/lib/cjs/render/webgl/ThematicSensors.js +8 -2
  176. package/lib/cjs/render/webgl/ThematicSensors.js.map +1 -1
  177. package/lib/cjs/render/webgl/glsl/AmbientOcclusion.d.ts.map +1 -1
  178. package/lib/cjs/render/webgl/glsl/AmbientOcclusion.js +3 -1
  179. package/lib/cjs/render/webgl/glsl/AmbientOcclusion.js.map +1 -1
  180. package/lib/cjs/render/webgl/glsl/Common.js +1 -1
  181. package/lib/cjs/render/webgl/glsl/Common.js.map +1 -1
  182. package/lib/cjs/render/webgl/glsl/SkyBox.d.ts.map +1 -1
  183. package/lib/cjs/render/webgl/glsl/SkyBox.js.map +1 -1
  184. package/lib/cjs/tile/GltfReader.d.ts +3 -2
  185. package/lib/cjs/tile/GltfReader.d.ts.map +1 -1
  186. package/lib/cjs/tile/GltfReader.js +7 -3
  187. package/lib/cjs/tile/GltfReader.js.map +1 -1
  188. package/lib/cjs/tile/ImdlReader.d.ts +1 -1
  189. package/lib/cjs/tile/ImdlReader.js.map +1 -1
  190. package/lib/cjs/tile/OPCFormatInterpreter.d.ts.map +1 -1
  191. package/lib/cjs/tile/OPCFormatInterpreter.js +3 -1
  192. package/lib/cjs/tile/OPCFormatInterpreter.js.map +1 -1
  193. package/lib/cjs/tile/OrbitGtTileTree.d.ts.map +1 -1
  194. package/lib/cjs/tile/OrbitGtTileTree.js.map +1 -1
  195. package/lib/cjs/tile/PrimaryTileTree.d.ts.map +1 -1
  196. package/lib/cjs/tile/PrimaryTileTree.js +14 -11
  197. package/lib/cjs/tile/PrimaryTileTree.js.map +1 -1
  198. package/lib/cjs/tile/RealityTile.d.ts +57 -3
  199. package/lib/cjs/tile/RealityTile.d.ts.map +1 -1
  200. package/lib/cjs/tile/RealityTile.js +49 -5
  201. package/lib/cjs/tile/RealityTile.js.map +1 -1
  202. package/lib/cjs/tile/RealityTileLoader.d.ts.map +1 -1
  203. package/lib/cjs/tile/RealityTileLoader.js.map +1 -1
  204. package/lib/cjs/tile/RealityTileTree.d.ts +37 -2
  205. package/lib/cjs/tile/RealityTileTree.d.ts.map +1 -1
  206. package/lib/cjs/tile/RealityTileTree.js +30 -2
  207. package/lib/cjs/tile/RealityTileTree.js.map +1 -1
  208. package/lib/cjs/tile/ThreeDTileFormatInterpreter.d.ts.map +1 -1
  209. package/lib/cjs/tile/ThreeDTileFormatInterpreter.js +6 -2
  210. package/lib/cjs/tile/ThreeDTileFormatInterpreter.js.map +1 -1
  211. package/lib/cjs/tile/TileAdmin.d.ts +11 -0
  212. package/lib/cjs/tile/TileAdmin.d.ts.map +1 -1
  213. package/lib/cjs/tile/TileAdmin.js +47 -4
  214. package/lib/cjs/tile/TileAdmin.js.map +1 -1
  215. package/lib/cjs/tile/TileDrawArgs.d.ts.map +1 -1
  216. package/lib/cjs/tile/TileDrawArgs.js +10 -16
  217. package/lib/cjs/tile/TileDrawArgs.js.map +1 -1
  218. package/lib/cjs/tile/TileRequest.d.ts +5 -1
  219. package/lib/cjs/tile/TileRequest.d.ts.map +1 -1
  220. package/lib/cjs/tile/TileRequest.js +6 -2
  221. package/lib/cjs/tile/TileRequest.js.map +1 -1
  222. package/lib/cjs/tile/TileStorage.d.ts +13 -0
  223. package/lib/cjs/tile/TileStorage.d.ts.map +1 -0
  224. package/lib/cjs/tile/TileStorage.js +50 -0
  225. package/lib/cjs/tile/TileStorage.js.map +1 -0
  226. package/lib/cjs/tile/internal.d.ts +2 -0
  227. package/lib/cjs/tile/internal.d.ts.map +1 -1
  228. package/lib/cjs/tile/internal.js +2 -0
  229. package/lib/cjs/tile/internal.js.map +1 -1
  230. package/lib/cjs/tile/map/ArcGISTileMap.js +1 -1
  231. package/lib/cjs/tile/map/ArcGISTileMap.js.map +1 -1
  232. package/lib/cjs/tile/map/ArcGisUtilities.d.ts +0 -2
  233. package/lib/cjs/tile/map/ArcGisUtilities.d.ts.map +1 -1
  234. package/lib/cjs/tile/map/ArcGisUtilities.js +1 -24
  235. package/lib/cjs/tile/map/ArcGisUtilities.js.map +1 -1
  236. package/lib/cjs/tile/map/BingElevation.d.ts +8 -3
  237. package/lib/cjs/tile/map/BingElevation.d.ts.map +1 -1
  238. package/lib/cjs/tile/map/BingElevation.js +36 -14
  239. package/lib/cjs/tile/map/BingElevation.js.map +1 -1
  240. package/lib/cjs/tile/map/CesiumTerrainProvider.d.ts +2 -7
  241. package/lib/cjs/tile/map/CesiumTerrainProvider.d.ts.map +1 -1
  242. package/lib/cjs/tile/map/CesiumTerrainProvider.js +100 -90
  243. package/lib/cjs/tile/map/CesiumTerrainProvider.js.map +1 -1
  244. package/lib/cjs/tile/map/EllipsoidTerrainProvider.d.ts +9 -12
  245. package/lib/cjs/tile/map/EllipsoidTerrainProvider.d.ts.map +1 -1
  246. package/lib/cjs/tile/map/EllipsoidTerrainProvider.js +70 -67
  247. package/lib/cjs/tile/map/EllipsoidTerrainProvider.js.map +1 -1
  248. package/lib/cjs/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.d.ts.map +1 -1
  249. package/lib/cjs/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js +9 -16
  250. package/lib/cjs/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js.map +1 -1
  251. package/lib/cjs/tile/map/ImageryProviders/BingImageryProvider.d.ts.map +1 -1
  252. package/lib/cjs/tile/map/ImageryProviders/BingImageryProvider.js +1 -1
  253. package/lib/cjs/tile/map/ImageryProviders/BingImageryProvider.js.map +1 -1
  254. package/lib/cjs/tile/map/ImageryProviders/MapBoxLayerImageryProvider.d.ts.map +1 -1
  255. package/lib/cjs/tile/map/ImageryProviders/MapBoxLayerImageryProvider.js.map +1 -1
  256. package/lib/cjs/tile/map/ImageryProviders/WmsMapLayerImageryProvider.d.ts.map +1 -1
  257. package/lib/cjs/tile/map/ImageryProviders/WmsMapLayerImageryProvider.js +8 -6
  258. package/lib/cjs/tile/map/ImageryProviders/WmsMapLayerImageryProvider.js.map +1 -1
  259. package/lib/cjs/tile/map/ImageryProviders/WmtsMapLayerImageryProvider.js +3 -3
  260. package/lib/cjs/tile/map/ImageryProviders/WmtsMapLayerImageryProvider.js.map +1 -1
  261. package/lib/cjs/tile/map/ImageryTileTree.d.ts.map +1 -1
  262. package/lib/cjs/tile/map/ImageryTileTree.js +21 -6
  263. package/lib/cjs/tile/map/ImageryTileTree.js.map +1 -1
  264. package/lib/cjs/tile/map/MapCartoRectangle.d.ts +62 -6
  265. package/lib/cjs/tile/map/MapCartoRectangle.d.ts.map +1 -1
  266. package/lib/cjs/tile/map/MapCartoRectangle.js +103 -17
  267. package/lib/cjs/tile/map/MapCartoRectangle.js.map +1 -1
  268. package/lib/cjs/tile/map/MapLayerImageryFormats.d.ts.map +1 -1
  269. package/lib/cjs/tile/map/MapLayerImageryFormats.js +4 -2
  270. package/lib/cjs/tile/map/MapLayerImageryFormats.js.map +1 -1
  271. package/lib/cjs/tile/map/MapLayerImageryProvider.d.ts.map +1 -1
  272. package/lib/cjs/tile/map/MapLayerImageryProvider.js +1 -1
  273. package/lib/cjs/tile/map/MapLayerImageryProvider.js.map +1 -1
  274. package/lib/cjs/tile/map/MapLayerSources.d.ts.map +1 -1
  275. package/lib/cjs/tile/map/MapLayerSources.js +11 -7
  276. package/lib/cjs/tile/map/MapLayerSources.js.map +1 -1
  277. package/lib/cjs/tile/map/MapTile.d.ts +68 -15
  278. package/lib/cjs/tile/map/MapTile.d.ts.map +1 -1
  279. package/lib/cjs/tile/map/MapTile.js +88 -30
  280. package/lib/cjs/tile/map/MapTile.js.map +1 -1
  281. package/lib/cjs/tile/map/MapTileAvailability.d.ts.map +1 -1
  282. package/lib/cjs/tile/map/MapTileAvailability.js +1 -1
  283. package/lib/cjs/tile/map/MapTileAvailability.js.map +1 -1
  284. package/lib/cjs/tile/map/MapTileLoader.d.ts +2 -2
  285. package/lib/cjs/tile/map/MapTileLoader.d.ts.map +1 -1
  286. package/lib/cjs/tile/map/MapTileLoader.js +11 -20
  287. package/lib/cjs/tile/map/MapTileLoader.js.map +1 -1
  288. package/lib/cjs/tile/map/MapTileTree.d.ts +72 -7
  289. package/lib/cjs/tile/map/MapTileTree.d.ts.map +1 -1
  290. package/lib/cjs/tile/map/MapTileTree.js +72 -16
  291. package/lib/cjs/tile/map/MapTileTree.js.map +1 -1
  292. package/lib/cjs/tile/map/MapTilingScheme.d.ts +67 -55
  293. package/lib/cjs/tile/map/MapTilingScheme.d.ts.map +1 -1
  294. package/lib/cjs/tile/map/MapTilingScheme.js +71 -67
  295. package/lib/cjs/tile/map/MapTilingScheme.js.map +1 -1
  296. package/lib/cjs/tile/map/QuadId.d.ts +24 -2
  297. package/lib/cjs/tile/map/QuadId.d.ts.map +1 -1
  298. package/lib/cjs/tile/map/QuadId.js +49 -20
  299. package/lib/cjs/tile/map/QuadId.js.map +1 -1
  300. package/lib/cjs/tile/map/TerrainMeshProvider.d.ts +79 -19
  301. package/lib/cjs/tile/map/TerrainMeshProvider.d.ts.map +1 -1
  302. package/lib/cjs/tile/map/TerrainMeshProvider.js +28 -13
  303. package/lib/cjs/tile/map/TerrainMeshProvider.js.map +1 -1
  304. package/lib/cjs/tile/map/TerrainProvider.d.ts +34 -0
  305. package/lib/cjs/tile/map/TerrainProvider.d.ts.map +1 -0
  306. package/lib/cjs/tile/map/TerrainProvider.js +41 -0
  307. package/lib/cjs/tile/map/TerrainProvider.js.map +1 -0
  308. package/lib/cjs/tile/map/WmsCapabilities.js +1 -1
  309. package/lib/cjs/tile/map/WmsCapabilities.js.map +1 -1
  310. package/lib/cjs/tile/map/WmtsCapabilities.d.ts.map +1 -1
  311. package/lib/cjs/tile/map/WmtsCapabilities.js +7 -3
  312. package/lib/cjs/tile/map/WmtsCapabilities.js.map +1 -1
  313. package/lib/cjs/tile/object-storage-azure.js +5 -0
  314. package/lib/cjs/tools/AccuDrawTool.d.ts.map +1 -1
  315. package/lib/cjs/tools/AccuDrawTool.js +87 -26
  316. package/lib/cjs/tools/AccuDrawTool.js.map +1 -1
  317. package/lib/cjs/tools/ClipViewTool.d.ts +2 -2
  318. package/lib/cjs/tools/ClipViewTool.d.ts.map +1 -1
  319. package/lib/cjs/tools/ClipViewTool.js +29 -16
  320. package/lib/cjs/tools/ClipViewTool.js.map +1 -1
  321. package/lib/cjs/tools/ElementSetTool.d.ts.map +1 -1
  322. package/lib/cjs/tools/ElementSetTool.js +26 -10
  323. package/lib/cjs/tools/ElementSetTool.js.map +1 -1
  324. package/lib/cjs/tools/MeasureTool.d.ts.map +1 -1
  325. package/lib/cjs/tools/MeasureTool.js +65 -41
  326. package/lib/cjs/tools/MeasureTool.js.map +1 -1
  327. package/lib/cjs/tools/PrimitiveTool.d.ts.map +1 -1
  328. package/lib/cjs/tools/PrimitiveTool.js +9 -4
  329. package/lib/cjs/tools/PrimitiveTool.js.map +1 -1
  330. package/lib/cjs/tools/SelectTool.d.ts.map +1 -1
  331. package/lib/cjs/tools/SelectTool.js +20 -9
  332. package/lib/cjs/tools/SelectTool.js.map +1 -1
  333. package/lib/cjs/tools/Tool.d.ts.map +1 -1
  334. package/lib/cjs/tools/Tool.js +13 -5
  335. package/lib/cjs/tools/Tool.js.map +1 -1
  336. package/lib/cjs/tools/ToolAdmin.d.ts.map +1 -1
  337. package/lib/cjs/tools/ToolAdmin.js +27 -9
  338. package/lib/cjs/tools/ToolAdmin.js.map +1 -1
  339. package/lib/cjs/tools/ViewTool.d.ts.map +1 -1
  340. package/lib/cjs/tools/ViewTool.js +111 -40
  341. package/lib/cjs/tools/ViewTool.js.map +1 -1
  342. package/lib/esm/AccuDraw.d.ts.map +1 -1
  343. package/lib/esm/AccuDraw.js +60 -15
  344. package/lib/esm/AccuDraw.js.map +1 -1
  345. package/lib/esm/AccuSnap.d.ts.map +1 -1
  346. package/lib/esm/AccuSnap.js +47 -37
  347. package/lib/esm/AccuSnap.js.map +1 -1
  348. package/lib/esm/AuxCoordSys.d.ts.map +1 -1
  349. package/lib/esm/AuxCoordSys.js +2 -3
  350. package/lib/esm/AuxCoordSys.js.map +1 -1
  351. package/lib/esm/BackgroundMapGeometry.d.ts.map +1 -1
  352. package/lib/esm/BackgroundMapGeometry.js.map +1 -1
  353. package/lib/esm/CategorySelectorState.d.ts.map +1 -1
  354. package/lib/esm/CategorySelectorState.js +6 -4
  355. package/lib/esm/CategorySelectorState.js.map +1 -1
  356. package/lib/esm/DevTools.d.ts.map +1 -1
  357. package/lib/esm/DevTools.js.map +1 -1
  358. package/lib/esm/DisplayStyleState.js +1 -1
  359. package/lib/esm/DisplayStyleState.js.map +1 -1
  360. package/lib/esm/ElementLocateManager.d.ts.map +1 -1
  361. package/lib/esm/ElementLocateManager.js +4 -2
  362. package/lib/esm/ElementLocateManager.js.map +1 -1
  363. package/lib/esm/FrustumAnimator.d.ts.map +1 -1
  364. package/lib/esm/FrustumAnimator.js +5 -1
  365. package/lib/esm/FrustumAnimator.js.map +1 -1
  366. package/lib/esm/FuzzySearch.d.ts.map +1 -1
  367. package/lib/esm/FuzzySearch.js +9 -3
  368. package/lib/esm/FuzzySearch.js.map +1 -1
  369. package/lib/esm/HitDetail.d.ts.map +1 -1
  370. package/lib/esm/HitDetail.js +13 -3
  371. package/lib/esm/HitDetail.js.map +1 -1
  372. package/lib/esm/IModelApp.d.ts +7 -2
  373. package/lib/esm/IModelApp.d.ts.map +1 -1
  374. package/lib/esm/IModelApp.js +11 -3
  375. package/lib/esm/IModelApp.js.map +1 -1
  376. package/lib/esm/IModelConnection.d.ts.map +1 -1
  377. package/lib/esm/IModelConnection.js +3 -1
  378. package/lib/esm/IModelConnection.js.map +1 -1
  379. package/lib/esm/ImageUtil.d.ts +6 -0
  380. package/lib/esm/ImageUtil.d.ts.map +1 -1
  381. package/lib/esm/ImageUtil.js +12 -0
  382. package/lib/esm/ImageUtil.js.map +1 -1
  383. package/lib/esm/Marker.d.ts.map +1 -1
  384. package/lib/esm/Marker.js +5 -1
  385. package/lib/esm/Marker.js.map +1 -1
  386. package/lib/esm/NativeAppLogger.d.ts.map +1 -1
  387. package/lib/esm/NativeAppLogger.js +1 -1
  388. package/lib/esm/NativeAppLogger.js.map +1 -1
  389. package/lib/esm/TentativePoint.d.ts.map +1 -1
  390. package/lib/esm/TentativePoint.js.map +1 -1
  391. package/lib/esm/ViewManager.d.ts +4 -0
  392. package/lib/esm/ViewManager.d.ts.map +1 -1
  393. package/lib/esm/ViewManager.js +9 -3
  394. package/lib/esm/ViewManager.js.map +1 -1
  395. package/lib/esm/ViewRect.d.ts.map +1 -1
  396. package/lib/esm/ViewRect.js +5 -1
  397. package/lib/esm/ViewRect.js.map +1 -1
  398. package/lib/esm/ViewState.d.ts +36 -12
  399. package/lib/esm/ViewState.d.ts.map +1 -1
  400. package/lib/esm/ViewState.js +35 -25
  401. package/lib/esm/ViewState.js.map +1 -1
  402. package/lib/esm/ViewingSpace.d.ts.map +1 -1
  403. package/lib/esm/ViewingSpace.js +12 -5
  404. package/lib/esm/ViewingSpace.js.map +1 -1
  405. package/lib/esm/Viewport.d.ts +14 -0
  406. package/lib/esm/Viewport.d.ts.map +1 -1
  407. package/lib/esm/Viewport.js +106 -5
  408. package/lib/esm/Viewport.js.map +1 -1
  409. package/lib/esm/core-frontend.d.ts +6 -0
  410. package/lib/esm/core-frontend.d.ts.map +1 -1
  411. package/lib/esm/core-frontend.js +6 -0
  412. package/lib/esm/core-frontend.js.map +1 -1
  413. package/lib/esm/extension/ExtensionAdmin.d.ts.map +1 -1
  414. package/lib/esm/extension/ExtensionAdmin.js.map +1 -1
  415. package/lib/esm/extension/ExtensionImpl.d.ts.map +1 -1
  416. package/lib/esm/extension/ExtensionImpl.js +3 -1
  417. package/lib/esm/extension/ExtensionImpl.js.map +1 -1
  418. package/lib/esm/public/scripts/checkbrowser.js +24 -0
  419. package/lib/esm/render/Decorations.d.ts.map +1 -1
  420. package/lib/esm/render/Decorations.js +24 -6
  421. package/lib/esm/render/Decorations.js.map +1 -1
  422. package/lib/esm/render/RealityMeshGraphicParams.d.ts +19 -0
  423. package/lib/esm/render/RealityMeshGraphicParams.d.ts.map +1 -0
  424. package/lib/esm/render/RealityMeshGraphicParams.js +9 -0
  425. package/lib/esm/render/RealityMeshGraphicParams.js.map +1 -0
  426. package/lib/esm/render/RealityMeshParams.d.ts +130 -0
  427. package/lib/esm/render/RealityMeshParams.d.ts.map +1 -0
  428. package/lib/esm/render/RealityMeshParams.js +172 -0
  429. package/lib/esm/render/RealityMeshParams.js.map +1 -0
  430. package/lib/esm/render/RenderSystem.d.ts +8 -4
  431. package/lib/esm/render/RenderSystem.d.ts.map +1 -1
  432. package/lib/esm/render/RenderSystem.js +7 -1
  433. package/lib/esm/render/RenderSystem.js.map +1 -1
  434. package/lib/esm/render/RenderTexture.d.ts +1 -1
  435. package/lib/esm/render/RenderTexture.d.ts.map +1 -1
  436. package/lib/esm/render/RenderTexture.js.map +1 -1
  437. package/lib/esm/render/UpsampleRealityMeshParams.d.ts +11 -0
  438. package/lib/esm/render/UpsampleRealityMeshParams.d.ts.map +1 -0
  439. package/lib/esm/render/UpsampleRealityMeshParams.js +201 -0
  440. package/lib/esm/render/UpsampleRealityMeshParams.js.map +1 -0
  441. package/lib/esm/render/primitives/DisplayParams.d.ts.map +1 -1
  442. package/lib/esm/render/primitives/DisplayParams.js.map +1 -1
  443. package/lib/esm/render/primitives/Polyface.d.ts.map +1 -1
  444. package/lib/esm/render/primitives/Polyface.js +3 -1
  445. package/lib/esm/render/primitives/Polyface.js.map +1 -1
  446. package/lib/esm/render/primitives/Primitives.d.ts.map +1 -1
  447. package/lib/esm/render/primitives/Primitives.js.map +1 -1
  448. package/lib/esm/render/primitives/Strokes.d.ts.map +1 -1
  449. package/lib/esm/render/primitives/Strokes.js +6 -2
  450. package/lib/esm/render/primitives/Strokes.js.map +1 -1
  451. package/lib/esm/render/primitives/VertexTableSplitter.d.ts.map +1 -1
  452. package/lib/esm/render/primitives/VertexTableSplitter.js +1 -79
  453. package/lib/esm/render/primitives/VertexTableSplitter.js.map +1 -1
  454. package/lib/esm/render/primitives/geometry/GeometryAccumulator.d.ts.map +1 -1
  455. package/lib/esm/render/primitives/geometry/GeometryAccumulator.js +4 -1
  456. package/lib/esm/render/primitives/geometry/GeometryAccumulator.js.map +1 -1
  457. package/lib/esm/render/primitives/mesh/MeshBuilder.d.ts.map +1 -1
  458. package/lib/esm/render/primitives/mesh/MeshBuilder.js.map +1 -1
  459. package/lib/esm/render/webgl/BackgroundMapDrape.d.ts.map +1 -1
  460. package/lib/esm/render/webgl/BackgroundMapDrape.js.map +1 -1
  461. package/lib/esm/render/webgl/ColorInfo.d.ts.map +1 -1
  462. package/lib/esm/render/webgl/ColorInfo.js +4 -1
  463. package/lib/esm/render/webgl/ColorInfo.js.map +1 -1
  464. package/lib/esm/render/webgl/DrawCommand.d.ts.map +1 -1
  465. package/lib/esm/render/webgl/DrawCommand.js +12 -3
  466. package/lib/esm/render/webgl/DrawCommand.js.map +1 -1
  467. package/lib/esm/render/webgl/FrameBuffer.d.ts.map +1 -1
  468. package/lib/esm/render/webgl/FrameBuffer.js +4 -1
  469. package/lib/esm/render/webgl/FrameBuffer.js.map +1 -1
  470. package/lib/esm/render/webgl/FrustumUniforms.js.map +1 -1
  471. package/lib/esm/render/webgl/Graphic.d.ts.map +1 -1
  472. package/lib/esm/render/webgl/Graphic.js +5 -2
  473. package/lib/esm/render/webgl/Graphic.js.map +1 -1
  474. package/lib/esm/render/webgl/Matrix.d.ts.map +1 -1
  475. package/lib/esm/render/webgl/Matrix.js +16 -4
  476. package/lib/esm/render/webgl/Matrix.js.map +1 -1
  477. package/lib/esm/render/webgl/PerformanceMetrics.js +2 -2
  478. package/lib/esm/render/webgl/PerformanceMetrics.js.map +1 -1
  479. package/lib/esm/render/webgl/PlanarClassifier.d.ts.map +1 -1
  480. package/lib/esm/render/webgl/PlanarClassifier.js +3 -1
  481. package/lib/esm/render/webgl/PlanarClassifier.js.map +1 -1
  482. package/lib/esm/render/webgl/PlanarTextureProjection.d.ts.map +1 -1
  483. package/lib/esm/render/webgl/PlanarTextureProjection.js.map +1 -1
  484. package/lib/esm/render/webgl/Primitive.d.ts.map +1 -1
  485. package/lib/esm/render/webgl/Primitive.js.map +1 -1
  486. package/lib/esm/render/webgl/RealityMesh.d.ts +6 -6
  487. package/lib/esm/render/webgl/RealityMesh.d.ts.map +1 -1
  488. package/lib/esm/render/webgl/RealityMesh.js +20 -12
  489. package/lib/esm/render/webgl/RealityMesh.js.map +1 -1
  490. package/lib/esm/render/webgl/RenderCommands.d.ts.map +1 -1
  491. package/lib/esm/render/webgl/RenderCommands.js +3 -2
  492. package/lib/esm/render/webgl/RenderCommands.js.map +1 -1
  493. package/lib/esm/render/webgl/RenderFlags.d.ts.map +1 -1
  494. package/lib/esm/render/webgl/RenderFlags.js +3 -1
  495. package/lib/esm/render/webgl/RenderFlags.js.map +1 -1
  496. package/lib/esm/render/webgl/ShaderBuilder.d.ts.map +1 -1
  497. package/lib/esm/render/webgl/ShaderBuilder.js +4 -1
  498. package/lib/esm/render/webgl/ShaderBuilder.js.map +1 -1
  499. package/lib/esm/render/webgl/SolarShadowMap.d.ts.map +1 -1
  500. package/lib/esm/render/webgl/SolarShadowMap.js +17 -5
  501. package/lib/esm/render/webgl/SolarShadowMap.js.map +1 -1
  502. package/lib/esm/render/webgl/System.d.ts +6 -4
  503. package/lib/esm/render/webgl/System.d.ts.map +1 -1
  504. package/lib/esm/render/webgl/System.js +21 -4
  505. package/lib/esm/render/webgl/System.js.map +1 -1
  506. package/lib/esm/render/webgl/Technique.d.ts.map +1 -1
  507. package/lib/esm/render/webgl/Technique.js +3 -1
  508. package/lib/esm/render/webgl/Technique.js.map +1 -1
  509. package/lib/esm/render/webgl/TechniqueFlags.d.ts.map +1 -1
  510. package/lib/esm/render/webgl/TechniqueFlags.js.map +1 -1
  511. package/lib/esm/render/webgl/Texture.d.ts.map +1 -1
  512. package/lib/esm/render/webgl/Texture.js +21 -12
  513. package/lib/esm/render/webgl/Texture.js.map +1 -1
  514. package/lib/esm/render/webgl/ThematicSensors.d.ts.map +1 -1
  515. package/lib/esm/render/webgl/ThematicSensors.js +8 -2
  516. package/lib/esm/render/webgl/ThematicSensors.js.map +1 -1
  517. package/lib/esm/render/webgl/glsl/AmbientOcclusion.d.ts.map +1 -1
  518. package/lib/esm/render/webgl/glsl/AmbientOcclusion.js +3 -1
  519. package/lib/esm/render/webgl/glsl/AmbientOcclusion.js.map +1 -1
  520. package/lib/esm/render/webgl/glsl/Common.js +1 -1
  521. package/lib/esm/render/webgl/glsl/Common.js.map +1 -1
  522. package/lib/esm/render/webgl/glsl/SkyBox.d.ts.map +1 -1
  523. package/lib/esm/render/webgl/glsl/SkyBox.js.map +1 -1
  524. package/lib/esm/tile/GltfReader.d.ts +3 -2
  525. package/lib/esm/tile/GltfReader.d.ts.map +1 -1
  526. package/lib/esm/tile/GltfReader.js +8 -4
  527. package/lib/esm/tile/GltfReader.js.map +1 -1
  528. package/lib/esm/tile/ImdlReader.d.ts +1 -1
  529. package/lib/esm/tile/ImdlReader.js.map +1 -1
  530. package/lib/esm/tile/OPCFormatInterpreter.d.ts.map +1 -1
  531. package/lib/esm/tile/OPCFormatInterpreter.js +3 -1
  532. package/lib/esm/tile/OPCFormatInterpreter.js.map +1 -1
  533. package/lib/esm/tile/OrbitGtTileTree.d.ts.map +1 -1
  534. package/lib/esm/tile/OrbitGtTileTree.js.map +1 -1
  535. package/lib/esm/tile/PrimaryTileTree.d.ts.map +1 -1
  536. package/lib/esm/tile/PrimaryTileTree.js +14 -11
  537. package/lib/esm/tile/PrimaryTileTree.js.map +1 -1
  538. package/lib/esm/tile/RealityTile.d.ts +57 -3
  539. package/lib/esm/tile/RealityTile.d.ts.map +1 -1
  540. package/lib/esm/tile/RealityTile.js +49 -5
  541. package/lib/esm/tile/RealityTile.js.map +1 -1
  542. package/lib/esm/tile/RealityTileLoader.d.ts.map +1 -1
  543. package/lib/esm/tile/RealityTileLoader.js.map +1 -1
  544. package/lib/esm/tile/RealityTileTree.d.ts +37 -2
  545. package/lib/esm/tile/RealityTileTree.d.ts.map +1 -1
  546. package/lib/esm/tile/RealityTileTree.js +30 -2
  547. package/lib/esm/tile/RealityTileTree.js.map +1 -1
  548. package/lib/esm/tile/ThreeDTileFormatInterpreter.d.ts.map +1 -1
  549. package/lib/esm/tile/ThreeDTileFormatInterpreter.js +6 -2
  550. package/lib/esm/tile/ThreeDTileFormatInterpreter.js.map +1 -1
  551. package/lib/esm/tile/TileAdmin.d.ts +11 -0
  552. package/lib/esm/tile/TileAdmin.d.ts.map +1 -1
  553. package/lib/esm/tile/TileAdmin.js +28 -4
  554. package/lib/esm/tile/TileAdmin.js.map +1 -1
  555. package/lib/esm/tile/TileDrawArgs.d.ts.map +1 -1
  556. package/lib/esm/tile/TileDrawArgs.js +11 -17
  557. package/lib/esm/tile/TileDrawArgs.js.map +1 -1
  558. package/lib/esm/tile/TileRequest.d.ts +5 -1
  559. package/lib/esm/tile/TileRequest.d.ts.map +1 -1
  560. package/lib/esm/tile/TileRequest.js +6 -2
  561. package/lib/esm/tile/TileRequest.js.map +1 -1
  562. package/lib/esm/tile/TileStorage.d.ts +13 -0
  563. package/lib/esm/tile/TileStorage.d.ts.map +1 -0
  564. package/lib/esm/tile/TileStorage.js +46 -0
  565. package/lib/esm/tile/TileStorage.js.map +1 -0
  566. package/lib/esm/tile/internal.d.ts +2 -0
  567. package/lib/esm/tile/internal.d.ts.map +1 -1
  568. package/lib/esm/tile/internal.js +2 -0
  569. package/lib/esm/tile/internal.js.map +1 -1
  570. package/lib/esm/tile/map/ArcGISTileMap.js +1 -1
  571. package/lib/esm/tile/map/ArcGISTileMap.js.map +1 -1
  572. package/lib/esm/tile/map/ArcGisUtilities.d.ts +0 -2
  573. package/lib/esm/tile/map/ArcGisUtilities.d.ts.map +1 -1
  574. package/lib/esm/tile/map/ArcGisUtilities.js +1 -24
  575. package/lib/esm/tile/map/ArcGisUtilities.js.map +1 -1
  576. package/lib/esm/tile/map/BingElevation.d.ts +8 -3
  577. package/lib/esm/tile/map/BingElevation.d.ts.map +1 -1
  578. package/lib/esm/tile/map/BingElevation.js +36 -14
  579. package/lib/esm/tile/map/BingElevation.js.map +1 -1
  580. package/lib/esm/tile/map/CesiumTerrainProvider.d.ts +2 -7
  581. package/lib/esm/tile/map/CesiumTerrainProvider.d.ts.map +1 -1
  582. package/lib/esm/tile/map/CesiumTerrainProvider.js +101 -91
  583. package/lib/esm/tile/map/CesiumTerrainProvider.js.map +1 -1
  584. package/lib/esm/tile/map/EllipsoidTerrainProvider.d.ts +9 -12
  585. package/lib/esm/tile/map/EllipsoidTerrainProvider.d.ts.map +1 -1
  586. package/lib/esm/tile/map/EllipsoidTerrainProvider.js +71 -68
  587. package/lib/esm/tile/map/EllipsoidTerrainProvider.js.map +1 -1
  588. package/lib/esm/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.d.ts.map +1 -1
  589. package/lib/esm/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js +9 -16
  590. package/lib/esm/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js.map +1 -1
  591. package/lib/esm/tile/map/ImageryProviders/BingImageryProvider.d.ts.map +1 -1
  592. package/lib/esm/tile/map/ImageryProviders/BingImageryProvider.js +1 -1
  593. package/lib/esm/tile/map/ImageryProviders/BingImageryProvider.js.map +1 -1
  594. package/lib/esm/tile/map/ImageryProviders/MapBoxLayerImageryProvider.d.ts.map +1 -1
  595. package/lib/esm/tile/map/ImageryProviders/MapBoxLayerImageryProvider.js.map +1 -1
  596. package/lib/esm/tile/map/ImageryProviders/WmsMapLayerImageryProvider.d.ts.map +1 -1
  597. package/lib/esm/tile/map/ImageryProviders/WmsMapLayerImageryProvider.js +8 -6
  598. package/lib/esm/tile/map/ImageryProviders/WmsMapLayerImageryProvider.js.map +1 -1
  599. package/lib/esm/tile/map/ImageryProviders/WmtsMapLayerImageryProvider.js +3 -3
  600. package/lib/esm/tile/map/ImageryProviders/WmtsMapLayerImageryProvider.js.map +1 -1
  601. package/lib/esm/tile/map/ImageryTileTree.d.ts.map +1 -1
  602. package/lib/esm/tile/map/ImageryTileTree.js +21 -6
  603. package/lib/esm/tile/map/ImageryTileTree.js.map +1 -1
  604. package/lib/esm/tile/map/MapCartoRectangle.d.ts +62 -6
  605. package/lib/esm/tile/map/MapCartoRectangle.d.ts.map +1 -1
  606. package/lib/esm/tile/map/MapCartoRectangle.js +103 -17
  607. package/lib/esm/tile/map/MapCartoRectangle.js.map +1 -1
  608. package/lib/esm/tile/map/MapLayerImageryFormats.d.ts.map +1 -1
  609. package/lib/esm/tile/map/MapLayerImageryFormats.js +4 -2
  610. package/lib/esm/tile/map/MapLayerImageryFormats.js.map +1 -1
  611. package/lib/esm/tile/map/MapLayerImageryProvider.d.ts.map +1 -1
  612. package/lib/esm/tile/map/MapLayerImageryProvider.js +1 -1
  613. package/lib/esm/tile/map/MapLayerImageryProvider.js.map +1 -1
  614. package/lib/esm/tile/map/MapLayerSources.d.ts.map +1 -1
  615. package/lib/esm/tile/map/MapLayerSources.js +11 -7
  616. package/lib/esm/tile/map/MapLayerSources.js.map +1 -1
  617. package/lib/esm/tile/map/MapTile.d.ts +68 -15
  618. package/lib/esm/tile/map/MapTile.d.ts.map +1 -1
  619. package/lib/esm/tile/map/MapTile.js +88 -30
  620. package/lib/esm/tile/map/MapTile.js.map +1 -1
  621. package/lib/esm/tile/map/MapTileAvailability.d.ts.map +1 -1
  622. package/lib/esm/tile/map/MapTileAvailability.js +1 -1
  623. package/lib/esm/tile/map/MapTileAvailability.js.map +1 -1
  624. package/lib/esm/tile/map/MapTileLoader.d.ts +2 -2
  625. package/lib/esm/tile/map/MapTileLoader.d.ts.map +1 -1
  626. package/lib/esm/tile/map/MapTileLoader.js +12 -21
  627. package/lib/esm/tile/map/MapTileLoader.js.map +1 -1
  628. package/lib/esm/tile/map/MapTileTree.d.ts +72 -7
  629. package/lib/esm/tile/map/MapTileTree.d.ts.map +1 -1
  630. package/lib/esm/tile/map/MapTileTree.js +73 -17
  631. package/lib/esm/tile/map/MapTileTree.js.map +1 -1
  632. package/lib/esm/tile/map/MapTilingScheme.d.ts +67 -55
  633. package/lib/esm/tile/map/MapTilingScheme.d.ts.map +1 -1
  634. package/lib/esm/tile/map/MapTilingScheme.js +72 -68
  635. package/lib/esm/tile/map/MapTilingScheme.js.map +1 -1
  636. package/lib/esm/tile/map/QuadId.d.ts +24 -2
  637. package/lib/esm/tile/map/QuadId.d.ts.map +1 -1
  638. package/lib/esm/tile/map/QuadId.js +49 -20
  639. package/lib/esm/tile/map/QuadId.js.map +1 -1
  640. package/lib/esm/tile/map/TerrainMeshProvider.d.ts +79 -19
  641. package/lib/esm/tile/map/TerrainMeshProvider.d.ts.map +1 -1
  642. package/lib/esm/tile/map/TerrainMeshProvider.js +28 -13
  643. package/lib/esm/tile/map/TerrainMeshProvider.js.map +1 -1
  644. package/lib/esm/tile/map/TerrainProvider.d.ts +34 -0
  645. package/lib/esm/tile/map/TerrainProvider.d.ts.map +1 -0
  646. package/lib/esm/tile/map/TerrainProvider.js +37 -0
  647. package/lib/esm/tile/map/TerrainProvider.js.map +1 -0
  648. package/lib/esm/tile/map/WmsCapabilities.js +1 -1
  649. package/lib/esm/tile/map/WmsCapabilities.js.map +1 -1
  650. package/lib/esm/tile/map/WmtsCapabilities.d.ts.map +1 -1
  651. package/lib/esm/tile/map/WmtsCapabilities.js +7 -3
  652. package/lib/esm/tile/map/WmtsCapabilities.js.map +1 -1
  653. package/lib/esm/tile/object-storage-azure.js +5 -0
  654. package/lib/esm/tools/AccuDrawTool.d.ts.map +1 -1
  655. package/lib/esm/tools/AccuDrawTool.js +87 -26
  656. package/lib/esm/tools/AccuDrawTool.js.map +1 -1
  657. package/lib/esm/tools/ClipViewTool.d.ts +2 -2
  658. package/lib/esm/tools/ClipViewTool.d.ts.map +1 -1
  659. package/lib/esm/tools/ClipViewTool.js +29 -16
  660. package/lib/esm/tools/ClipViewTool.js.map +1 -1
  661. package/lib/esm/tools/ElementSetTool.d.ts.map +1 -1
  662. package/lib/esm/tools/ElementSetTool.js +26 -10
  663. package/lib/esm/tools/ElementSetTool.js.map +1 -1
  664. package/lib/esm/tools/MeasureTool.d.ts.map +1 -1
  665. package/lib/esm/tools/MeasureTool.js +65 -41
  666. package/lib/esm/tools/MeasureTool.js.map +1 -1
  667. package/lib/esm/tools/PrimitiveTool.d.ts.map +1 -1
  668. package/lib/esm/tools/PrimitiveTool.js +9 -4
  669. package/lib/esm/tools/PrimitiveTool.js.map +1 -1
  670. package/lib/esm/tools/SelectTool.d.ts.map +1 -1
  671. package/lib/esm/tools/SelectTool.js +20 -9
  672. package/lib/esm/tools/SelectTool.js.map +1 -1
  673. package/lib/esm/tools/Tool.d.ts.map +1 -1
  674. package/lib/esm/tools/Tool.js +13 -5
  675. package/lib/esm/tools/Tool.js.map +1 -1
  676. package/lib/esm/tools/ToolAdmin.d.ts.map +1 -1
  677. package/lib/esm/tools/ToolAdmin.js +27 -9
  678. package/lib/esm/tools/ToolAdmin.js.map +1 -1
  679. package/lib/esm/tools/ViewTool.d.ts.map +1 -1
  680. package/lib/esm/tools/ViewTool.js +111 -40
  681. package/lib/esm/tools/ViewTool.js.map +1 -1
  682. package/package.json +30 -24
  683. package/lib/cjs/render/primitives/mesh/RealityMeshPrimitive.d.ts +0 -47
  684. package/lib/cjs/render/primitives/mesh/RealityMeshPrimitive.d.ts.map +0 -1
  685. package/lib/cjs/render/primitives/mesh/RealityMeshPrimitive.js +0 -75
  686. package/lib/cjs/render/primitives/mesh/RealityMeshPrimitive.js.map +0 -1
  687. package/lib/cjs/render/primitives/mesh/TerrainMeshPrimitive.d.ts +0 -56
  688. package/lib/cjs/render/primitives/mesh/TerrainMeshPrimitive.d.ts.map +0 -1
  689. package/lib/cjs/render/primitives/mesh/TerrainMeshPrimitive.js +0 -270
  690. package/lib/cjs/render/primitives/mesh/TerrainMeshPrimitive.js.map +0 -1
  691. package/lib/esm/render/primitives/mesh/RealityMeshPrimitive.d.ts +0 -47
  692. package/lib/esm/render/primitives/mesh/RealityMeshPrimitive.d.ts.map +0 -1
  693. package/lib/esm/render/primitives/mesh/RealityMeshPrimitive.js +0 -71
  694. package/lib/esm/render/primitives/mesh/RealityMeshPrimitive.js.map +0 -1
  695. package/lib/esm/render/primitives/mesh/TerrainMeshPrimitive.d.ts +0 -56
  696. package/lib/esm/render/primitives/mesh/TerrainMeshPrimitive.d.ts.map +0 -1
  697. package/lib/esm/render/primitives/mesh/TerrainMeshPrimitive.js +0 -266
  698. package/lib/esm/render/primitives/mesh/TerrainMeshPrimitive.js.map +0 -1
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@itwin/core-frontend",
3
- "version": "3.4.0-dev.9",
3
+ "version": "3.5.0-dev.4",
4
4
  "description": "iTwin.js frontend components",
5
5
  "main": "lib/cjs/core-frontend.js",
6
6
  "module": "lib/esm/core-frontend.js",
@@ -22,35 +22,35 @@
22
22
  "url": "http://www.bentley.com"
23
23
  },
24
24
  "peerDependencies": {
25
- "@itwin/appui-abstract": "^3.4.0-dev.9",
26
- "@itwin/core-bentley": "^3.4.0-dev.9",
27
- "@itwin/core-common": "^3.4.0-dev.9",
28
- "@itwin/core-geometry": "^3.4.0-dev.9",
29
- "@itwin/core-orbitgt": "^3.4.0-dev.9",
30
- "@itwin/core-quantity": "^3.4.0-dev.9",
31
- "@itwin/webgl-compatibility": "^3.4.0-dev.9"
25
+ "@itwin/appui-abstract": "^3.5.0-dev.4",
26
+ "@itwin/core-bentley": "^3.5.0-dev.4",
27
+ "@itwin/core-common": "^3.5.0-dev.4",
28
+ "@itwin/core-geometry": "^3.5.0-dev.4",
29
+ "@itwin/core-orbitgt": "^3.5.0-dev.4",
30
+ "@itwin/core-quantity": "^3.5.0-dev.4",
31
+ "@itwin/webgl-compatibility": "^3.5.0-dev.4"
32
32
  },
33
33
  "//devDependencies": [
34
34
  "NOTE: All peerDependencies should also be listed as devDependencies since peerDependencies are not considered by npm install",
35
35
  "NOTE: All tools used by scripts in this package must be listed as devDependencies"
36
36
  ],
37
37
  "devDependencies": {
38
- "@itwin/appui-abstract": "3.4.0-dev.9",
39
- "@itwin/build-tools": "3.4.0-dev.9",
40
- "@itwin/core-bentley": "3.4.0-dev.9",
41
- "@itwin/core-common": "3.4.0-dev.9",
42
- "@itwin/core-geometry": "3.4.0-dev.9",
43
- "@itwin/core-orbitgt": "3.4.0-dev.9",
44
- "@itwin/core-quantity": "3.4.0-dev.9",
45
- "@itwin/certa": "3.4.0-dev.9",
46
- "@itwin/eslint-plugin": "3.4.0-dev.9",
47
- "@itwin/webgl-compatibility": "3.4.0-dev.9",
38
+ "@itwin/appui-abstract": "3.5.0-dev.4",
39
+ "@itwin/build-tools": "3.5.0-dev.4",
40
+ "@itwin/core-bentley": "3.5.0-dev.4",
41
+ "@itwin/core-common": "3.5.0-dev.4",
42
+ "@itwin/core-geometry": "3.5.0-dev.4",
43
+ "@itwin/core-orbitgt": "3.5.0-dev.4",
44
+ "@itwin/core-quantity": "3.5.0-dev.4",
45
+ "@itwin/certa": "3.5.0-dev.4",
46
+ "@itwin/eslint-plugin": "3.5.0-dev.4",
47
+ "@itwin/webgl-compatibility": "3.5.0-dev.4",
48
48
  "@types/chai": "4.3.1",
49
49
  "@types/chai-as-promised": "^7",
50
50
  "@types/deep-assign": "^0.1.0",
51
51
  "@types/lodash": "^4.14.0",
52
52
  "@types/mocha": "^8.2.2",
53
- "@types/node": "16.11.7",
53
+ "@types/node": "16.11.59",
54
54
  "@types/qs": "^6.5.0",
55
55
  "@types/semver": "7.3.10",
56
56
  "@types/superagent": "^4.1.14",
@@ -73,8 +73,11 @@
73
73
  "NOTE: core-frontend should remain UI technology agnostic, so no react/angular dependencies are allowed"
74
74
  ],
75
75
  "dependencies": {
76
- "@itwin/core-i18n": "3.4.0-dev.9",
77
- "@itwin/core-telemetry": "3.4.0-dev.9",
76
+ "@itwin/object-storage-azure": "~1.4.0",
77
+ "@itwin/cloud-agnostic-core": "~1.4.0",
78
+ "@itwin/object-storage-core": "~1.4.0",
79
+ "@itwin/core-i18n": "3.5.0-dev.4",
80
+ "@itwin/core-telemetry": "3.5.0-dev.4",
78
81
  "@loaders.gl/core": "^3.1.6",
79
82
  "@loaders.gl/draco": "^3.1.6",
80
83
  "deep-assign": "^2.0.0",
@@ -84,7 +87,8 @@
84
87
  "semver": "^7.3.5",
85
88
  "superagent": "7.1.3",
86
89
  "wms-capabilities": "0.4.0",
87
- "xml-js": "~1.6.11"
90
+ "xml-js": "~1.6.11",
91
+ "reflect-metadata": "0.1.13"
88
92
  },
89
93
  "nyc": {
90
94
  "extends": "./node_modules/@itwin/build-tools/.nycrc"
@@ -130,10 +134,12 @@
130
134
  "scripts": {
131
135
  "build": "npm run -s copy:public && npm run -s build:cjs",
132
136
  "build:ci": "npm run -s build && npm run -s build:esm",
133
- "build:cjs": "tsc 1>&2 --outDir lib/cjs",
134
- "build:esm": "tsc 1>&2 --module ES2020 --outDir lib/esm",
137
+ "build:cjs": "npm run -s copy:js:cjs && tsc 1>&2 --outDir lib/cjs",
138
+ "build:esm": "npm run -s copy:js:esm && tsc 1>&2 --module ES2020 --outDir lib/esm",
135
139
  "clean": "rimraf lib .rush/temp/package-deps*.json",
136
140
  "copy:public": "cpx \"./src/public/**/*\" ./lib/public",
141
+ "copy:js:cjs": "cpx \"./src/**/*.js\" ./lib/cjs",
142
+ "copy:js:esm": "cpx \"./src/**/*.js\" ./lib/esm",
137
143
  "docs": "betools docs --includes=../../generated-docs/extract --json=../../generated-docs/core/core-frontend/file.json --tsIndexFile=./core-frontend.ts --onlyJson --excludes=webgl/**/*,**/primitives,**/map/*.d.ts,**/tile/*.d.ts,**/*-css.ts",
138
144
  "extract-api": "betools extract-api --entry=core-frontend && npm run extract-extension-api",
139
145
  "extract-extension-api": "eslint --no-eslintrc -c \"../../tools/eslint-plugin/dist/configs/extension-exports-config.js\" \"./src/**/*.ts\" 1>&2",
@@ -1,47 +0,0 @@
1
- /** @packageDocumentation
2
- * @module Rendering
3
- */
4
- import { Polyface, Transform } from "@itwin/core-geometry";
5
- import { ColorDef, PackedFeatureTable, QParams2d, QParams3d, RenderTexture } from "@itwin/core-common";
6
- import { GltfMeshData, MapCartoRectangle, MapTileProjection } from "../../../tile/internal";
7
- import { RenderMemory } from "../../RenderMemory";
8
- import { MapLayerClassifiers, RenderTerrainGeometry, TerrainTexture } from "../../RenderSystem";
9
- export interface RealityMeshProps {
10
- readonly indices: Uint16Array;
11
- readonly pointQParams: QParams3d;
12
- readonly points: Uint16Array;
13
- readonly normals?: Uint16Array;
14
- readonly uvQParams: QParams2d;
15
- readonly uvs: Uint16Array;
16
- readonly featureID: number;
17
- readonly texture?: RenderTexture;
18
- }
19
- /** @internal */
20
- export interface RealityMeshGraphicParams {
21
- readonly realityMesh: RenderTerrainGeometry;
22
- readonly projection: MapTileProjection;
23
- readonly tileRectangle: MapCartoRectangle;
24
- readonly featureTable: PackedFeatureTable;
25
- readonly tileId: string | undefined;
26
- readonly baseColor: ColorDef | undefined;
27
- readonly baseTransparent: boolean;
28
- readonly textures?: TerrainTexture[];
29
- readonly layerClassifiers?: MapLayerClassifiers;
30
- }
31
- /** @internal */
32
- export declare class RealityMeshPrimitive implements RenderMemory.Consumer {
33
- readonly indices: Uint16Array;
34
- readonly pointQParams: QParams3d;
35
- readonly points: Uint16Array;
36
- readonly normals?: Uint16Array;
37
- readonly uvQParams: QParams2d;
38
- readonly uvs: Uint16Array;
39
- readonly featureID: number;
40
- readonly texture?: RenderTexture;
41
- protected constructor(props: RealityMeshProps);
42
- static createFromGltfMesh(mesh: GltfMeshData): RealityMeshPrimitive | undefined;
43
- collectStatistics(stats: RenderMemory.Statistics): void;
44
- get bytesUsed(): number;
45
- createPolyface(transform: Transform | undefined, needNormals?: boolean, needParams?: boolean): Polyface | undefined;
46
- }
47
- //# sourceMappingURL=RealityMeshPrimitive.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"RealityMeshPrimitive.d.ts","sourceRoot":"","sources":["../../../../../src/render/primitives/mesh/RealityMeshPrimitive.ts"],"names":[],"mappings":"AAIA;;GAEG;AAGH,OAAO,EAAmB,QAAQ,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAC5E,OAAO,EAAE,QAAQ,EAAoB,kBAAkB,EAAE,SAAS,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACzH,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC5F,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAG,qBAAqB,EAAG,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAGlG,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,CAAC,OAAO,EAAE,WAAW,CAAC;IAC9B,QAAQ,CAAC,YAAY,EAAE,SAAS,CAAC;IACjC,QAAQ,CAAC,MAAM,EAAE,WAAW,CAAC;IAC7B,QAAQ,CAAC,OAAO,CAAC,EAAE,WAAW,CAAC;IAC/B,QAAQ,CAAC,SAAS,EAAE,SAAS,CAAC;IAC9B,QAAQ,CAAC,GAAG,EAAE,WAAW,CAAC;IAC1B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,OAAO,CAAC,EAAE,aAAa,CAAC;CAClC;AAED,gBAAgB;AAChB,MAAM,WAAW,wBAAwB;IACvC,QAAQ,CAAC,WAAW,EAAE,qBAAqB,CAAC;IAC5C,QAAQ,CAAC,UAAU,EAAE,iBAAiB,CAAC;IACvC,QAAQ,CAAC,aAAa,EAAE,iBAAiB,CAAC;IAC1C,QAAQ,CAAC,YAAY,EAAE,kBAAkB,CAAC;IAC1C,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC;IACpC,QAAQ,CAAC,SAAS,EAAE,QAAQ,GAAG,SAAS,CAAC;IACzC,QAAQ,CAAC,eAAe,EAAE,OAAO,CAAC;IAClC,QAAQ,CAAC,QAAQ,CAAC,EAAE,cAAc,EAAE,CAAC;IACrC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,mBAAmB,CAAC;CACjD;AAED,gBAAgB;AAChB,qBAAa,oBAAqB,YAAW,YAAY,CAAC,QAAQ;IAChE,SAAgB,OAAO,EAAE,WAAW,CAAC;IACrC,SAAgB,YAAY,EAAE,SAAS,CAAC;IACxC,SAAgB,MAAM,EAAE,WAAW,CAAC;IACpC,SAAgB,OAAO,CAAC,EAAE,WAAW,CAAC;IACtC,SAAgB,SAAS,EAAE,SAAS,CAAC;IACrC,SAAgB,GAAG,EAAE,WAAW,CAAC;IACjC,SAAgB,SAAS,EAAE,MAAM,CAAK;IACtC,SAAgB,OAAO,CAAC,EAAE,aAAa,CAAC;IACxC,SAAS,aAAa,KAAK,EAAE,gBAAgB;WAW/B,kBAAkB,CAAC,IAAI,EAAE,YAAY,GAAG,oBAAoB,GAAG,SAAS;IAO/E,iBAAiB,CAAC,KAAK,EAAE,YAAY,CAAC,UAAU,GAAG,IAAI;IAG9D,IAAW,SAAS,WAEnB;IAEM,cAAc,CAAC,SAAS,EAAE,SAAS,GAAG,SAAS,EAAE,WAAW,CAAC,EAAE,OAAO,EAAE,UAAU,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,SAAS;CAuC3H"}
@@ -1,75 +0,0 @@
1
- "use strict";
2
- /*---------------------------------------------------------------------------------------------
3
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
- * See LICENSE.md in the project root for license terms and full copyright notice.
5
- *--------------------------------------------------------------------------------------------*/
6
- /** @packageDocumentation
7
- * @module Rendering
8
- */
9
- Object.defineProperty(exports, "__esModule", { value: true });
10
- exports.RealityMeshPrimitive = void 0;
11
- const core_bentley_1 = require("@itwin/core-bentley");
12
- const core_geometry_1 = require("@itwin/core-geometry");
13
- const core_common_1 = require("@itwin/core-common");
14
- const MeshPrimitives_1 = require("./MeshPrimitives");
15
- /** @internal */
16
- class RealityMeshPrimitive {
17
- constructor(props) {
18
- this.featureID = 0;
19
- this.pointQParams = props.pointQParams;
20
- this.points = props.points;
21
- this.uvQParams = props.uvQParams;
22
- this.uvs = props.uvs;
23
- this.normals = props.normals;
24
- this.indices = props.indices;
25
- this.featureID = props.featureID;
26
- this.texture = props.texture;
27
- }
28
- static createFromGltfMesh(mesh) {
29
- var _a;
30
- if (mesh.primitive.type !== MeshPrimitives_1.Mesh.PrimitiveType.Mesh || mesh.primitive.edges || !mesh.pointQParams || !mesh.uvQParams || !mesh.points || !mesh.uvs || !mesh.indices || !(mesh.indices instanceof Uint16Array))
31
- return undefined; // Simple meshes have only triangles without edges and are textured.
32
- return new RealityMeshPrimitive({ indices: mesh.indices, pointQParams: mesh.pointQParams, points: mesh.points, uvQParams: mesh.uvQParams, uvs: mesh.uvs, normals: mesh.normals, featureID: 0, texture: (_a = mesh.primitive.displayParams.textureMapping) === null || _a === void 0 ? void 0 : _a.texture });
33
- }
34
- collectStatistics(stats) {
35
- stats.addTerrain(this.bytesUsed);
36
- }
37
- get bytesUsed() {
38
- return 2 * (this.indices.length + this.points.length + this.uvs.length + (this.normals ? this.normals.length : 0));
39
- }
40
- createPolyface(transform, needNormals, needParams) {
41
- if (!this.pointQParams || !this.points || !this.indices) {
42
- (0, core_bentley_1.assert)(false, "missing mesh points");
43
- return undefined;
44
- }
45
- const { points, pointQParams, normals, uvs, uvQParams, indices } = this;
46
- const includeNormals = needNormals && undefined !== normals;
47
- const includeParams = needParams && undefined !== uvQParams && undefined !== uvs;
48
- const polyface = core_geometry_1.IndexedPolyface.create(includeNormals, includeParams);
49
- for (let i = 0; i < points.length;) {
50
- const point = pointQParams.unquantize(points[i++], points[i++], points[i++]);
51
- if (transform)
52
- transform.multiplyPoint3d(point, point);
53
- polyface.addPoint(point);
54
- }
55
- if (includeNormals)
56
- for (let i = 0; i < normals.length;)
57
- polyface.addNormal(core_common_1.OctEncodedNormal.decodeValue(normals[i++]));
58
- if (includeParams)
59
- for (let i = 0; i < uvs.length;)
60
- polyface.addParam(uvQParams.unquantize(uvs[i++], uvs[i++]));
61
- let j = 0;
62
- indices.forEach((index) => {
63
- polyface.addPointIndex(index);
64
- if (includeNormals)
65
- polyface.addNormalIndex(index);
66
- if (includeParams)
67
- polyface.addParamIndex(index);
68
- if (0 === (++j % 3))
69
- polyface.terminateFacet();
70
- });
71
- return polyface;
72
- }
73
- }
74
- exports.RealityMeshPrimitive = RealityMeshPrimitive;
75
- //# sourceMappingURL=RealityMeshPrimitive.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"RealityMeshPrimitive.js","sourceRoot":"","sources":["../../../../../src/render/primitives/mesh/RealityMeshPrimitive.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 Rendering\r\n */\r\n\r\nimport { assert } from \"@itwin/core-bentley\";\r\nimport { IndexedPolyface, Polyface, Transform } from \"@itwin/core-geometry\";\r\nimport { ColorDef, OctEncodedNormal, PackedFeatureTable, QParams2d, QParams3d, RenderTexture } from \"@itwin/core-common\";\r\nimport { GltfMeshData, MapCartoRectangle, MapTileProjection } from \"../../../tile/internal\";\r\nimport { RenderMemory } from \"../../RenderMemory\";\r\nimport { MapLayerClassifiers, RenderTerrainGeometry, TerrainTexture } from \"../../RenderSystem\";\r\nimport { Mesh } from \"./MeshPrimitives\";\r\n\r\nexport interface RealityMeshProps {\r\n readonly indices: Uint16Array;\r\n readonly pointQParams: QParams3d;\r\n readonly points: Uint16Array;\r\n readonly normals?: Uint16Array;\r\n readonly uvQParams: QParams2d;\r\n readonly uvs: Uint16Array;\r\n readonly featureID: number;\r\n readonly texture?: RenderTexture;\r\n}\r\n\r\n/** @internal */\r\nexport interface RealityMeshGraphicParams {\r\n readonly realityMesh: RenderTerrainGeometry;\r\n readonly projection: MapTileProjection;\r\n readonly tileRectangle: MapCartoRectangle;\r\n readonly featureTable: PackedFeatureTable;\r\n readonly tileId: string | undefined;\r\n readonly baseColor: ColorDef | undefined;\r\n readonly baseTransparent: boolean;\r\n readonly textures?: TerrainTexture[];\r\n readonly layerClassifiers?: MapLayerClassifiers;\r\n}\r\n\r\n/** @internal */\r\nexport class RealityMeshPrimitive implements RenderMemory.Consumer {\r\n public readonly indices: Uint16Array;\r\n public readonly pointQParams: QParams3d;\r\n public readonly points: Uint16Array;\r\n public readonly normals?: Uint16Array;\r\n public readonly uvQParams: QParams2d;\r\n public readonly uvs: Uint16Array;\r\n public readonly featureID: number = 0;\r\n public readonly texture?: RenderTexture;\r\n protected constructor(props: RealityMeshProps) {\r\n this.pointQParams = props.pointQParams;\r\n this.points = props.points;\r\n this.uvQParams = props.uvQParams;\r\n this.uvs = props.uvs;\r\n this.normals = props.normals;\r\n this.indices = props.indices;\r\n this.featureID = props.featureID;\r\n this.texture = props.texture;\r\n }\r\n\r\n public static createFromGltfMesh(mesh: GltfMeshData): RealityMeshPrimitive | undefined {\r\n if (mesh.primitive.type !== Mesh.PrimitiveType.Mesh || mesh.primitive.edges || !mesh.pointQParams || !mesh.uvQParams || !mesh.points || !mesh.uvs || !mesh.indices || !(mesh.indices instanceof Uint16Array))\r\n return undefined; // Simple meshes have only triangles without edges and are textured.\r\n\r\n return new RealityMeshPrimitive({ indices: mesh.indices, pointQParams: mesh.pointQParams, points: mesh.points, uvQParams: mesh.uvQParams, uvs: mesh.uvs, normals: mesh.normals, featureID: 0, texture: mesh.primitive.displayParams.textureMapping?.texture });\r\n }\r\n\r\n public collectStatistics(stats: RenderMemory.Statistics): void {\r\n stats.addTerrain(this.bytesUsed);\r\n }\r\n public get bytesUsed() {\r\n return 2 * (this.indices.length + this.points.length + this.uvs.length + (this.normals ? this.normals.length : 0));\r\n }\r\n\r\n public createPolyface(transform: Transform | undefined, needNormals?: boolean, needParams?: boolean): Polyface | undefined {\r\n if (!this.pointQParams || !this.points || !this.indices) {\r\n assert (false, \"missing mesh points\");\r\n return undefined;\r\n }\r\n const { points, pointQParams, normals, uvs, uvQParams, indices } = this;\r\n const includeNormals = needNormals && undefined !== normals;\r\n const includeParams = needParams && undefined !== uvQParams && undefined !== uvs;\r\n\r\n const polyface = IndexedPolyface.create(includeNormals, includeParams);\r\n for (let i = 0; i < points.length; ) {\r\n const point = pointQParams.unquantize(points[i++], points[i++], points[i++]);\r\n if (transform)\r\n transform.multiplyPoint3d(point, point);\r\n\r\n polyface.addPoint(point);\r\n }\r\n\r\n if (includeNormals)\r\n for (let i = 0; i < normals.length; )\r\n polyface.addNormal(OctEncodedNormal.decodeValue(normals[i++]));\r\n\r\n if (includeParams)\r\n for (let i = 0; i < uvs.length; )\r\n polyface.addParam(uvQParams.unquantize(uvs[i++], uvs[i++]));\r\n\r\n let j = 0;\r\n indices.forEach((index: number) => {\r\n polyface.addPointIndex(index);\r\n if (includeNormals)\r\n polyface.addNormalIndex(index);\r\n if (includeParams)\r\n polyface.addParamIndex(index);\r\n if (0 === (++j % 3))\r\n polyface.terminateFacet();\r\n });\r\n return polyface;\r\n }\r\n\r\n}\r\n"]}
@@ -1,56 +0,0 @@
1
- /** @packageDocumentation
2
- * @module Rendering
3
- */
4
- import { Point3d, Range1d, Range2d } from "@itwin/core-geometry";
5
- import { QParams3d, QPoint2d, QPoint3d } from "@itwin/core-common";
6
- import { RenderMemory } from "../../RenderMemory";
7
- import { RealityMeshPrimitive } from "./RealityMeshPrimitive";
8
- export declare enum Child {
9
- Q00 = 0,
10
- Q01 = 1,
11
- Q10 = 2,
12
- Q11 = 3
13
- }
14
- /** These are currently retained on terrain leaf tiles for upsampling.
15
- * It may be worthwhile to pack the data into buffers...
16
- * @internal
17
- */
18
- export declare class TerrainMeshPrimitive extends RealityMeshPrimitive {
19
- private _pointCapacity;
20
- private _indexCapacity;
21
- private _currPointCount;
22
- private _currIndexCount;
23
- private constructor();
24
- get isCompleted(): boolean;
25
- get nextPointIndex(): number;
26
- static create(props: TerrainMesh.Props): TerrainMeshPrimitive;
27
- collectStatistics(stats: RenderMemory.Statistics): void;
28
- addVertex(point: Point3d, uvParam: QPoint2d, normal?: number): void;
29
- addQuantizedVertex(point: QPoint3d, uv: QPoint2d, normal?: number): void;
30
- addQuad(i0: number, i1: number, i2: number, i3: number): void;
31
- addTriangle(i0: number, i1: number, i2: number): void;
32
- addIndices(indices: number[]): void;
33
- private static _scratchZRange;
34
- private static _scratchTriangleRange;
35
- private static _scratchUVRange;
36
- private static _scratchUVQParams;
37
- upsample(uvSampleRange: Range2d): {
38
- heightRange: Range1d;
39
- mesh: TerrainMeshPrimitive;
40
- };
41
- private addClipped;
42
- }
43
- export declare namespace TerrainMesh {
44
- interface Props {
45
- readonly wantNormals: boolean;
46
- readonly pointQParams: QParams3d;
47
- readonly pointCount: number;
48
- readonly indexCount: number;
49
- readonly wantSkirts: boolean;
50
- readonly eastCount: number;
51
- readonly westCount: number;
52
- readonly northCount: number;
53
- readonly southCount: number;
54
- }
55
- }
56
- //# sourceMappingURL=TerrainMeshPrimitive.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TerrainMeshPrimitive.d.ts","sourceRoot":"","sources":["../../../../../src/render/primitives/mesh/TerrainMeshPrimitive.ts"],"names":[],"mappings":"AAIA;;GAEG;AAGH,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAY,MAAM,sBAAsB,CAAC;AAC3E,OAAO,EAA+B,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAgB,MAAM,oBAAoB,CAAC;AAC9G,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,oBAAoB,EAAoB,MAAM,wBAAwB,CAAC;AAEhF,oBAAY,KAAK;IAAG,GAAG,IAAA;IAAE,GAAG,IAAA;IAAE,GAAG,IAAA;IAAE,GAAG,IAAA;CAAE;AAoBxC;;;GAGG;AACH,qBAAa,oBAAqB,SAAQ,oBAAoB;IAIf,OAAO,CAAC,cAAc;IAAU,OAAO,CAAC,cAAc;IAHnG,OAAO,CAAC,eAAe,CAAK;IAC5B,OAAO,CAAC,eAAe,CAAK;IAE5B,OAAO;IAIP,IAAW,WAAW,YAA2G;IACjI,IAAW,cAAc,WAAmC;WAE9C,MAAM,CAAC,KAAK,EAAE,WAAW,CAAC,KAAK;IAc7B,iBAAiB,CAAC,KAAK,EAAE,YAAY,CAAC,UAAU,GAAG,IAAI;IAIhE,SAAS,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,CAAC,EAAE,MAAM;IAK5D,kBAAkB,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE,EAAE,QAAQ,EAAE,MAAM,CAAC,EAAE,MAAM;IAmBjE,OAAO,CAAC,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM;IAKtD,WAAW,CAAC,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM;IAS9C,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE;IAKnC,OAAO,CAAC,MAAM,CAAC,cAAc,CAAwB;IACrD,OAAO,CAAC,MAAM,CAAC,qBAAqB,CAAwB;IAC5D,OAAO,CAAC,MAAM,CAAC,eAAe,CAAwB;IACtD,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAA6B;IACtD,QAAQ,CAAC,aAAa,EAAE,OAAO,GAAG;QAAE,WAAW,EAAE,OAAO,CAAC;QAAC,IAAI,EAAE,oBAAoB,CAAA;KAAE;IAsE7F,OAAO,CAAC,UAAU;CAuEnB;AAyBD,yBAAiB,WAAW,CAAC;IAC3B,UAAiB,KAAK;QACpB,QAAQ,CAAC,WAAW,EAAE,OAAO,CAAC;QAC9B,QAAQ,CAAC,YAAY,EAAE,SAAS,CAAC;QACjC,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;QAC5B,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;QAC5B,QAAQ,CAAC,UAAU,EAAE,OAAO,CAAC;QAC7B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;QAC3B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;QAC3B,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;QAC5B,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;KAC7B;CACF"}
@@ -1,270 +0,0 @@
1
- "use strict";
2
- /*---------------------------------------------------------------------------------------------
3
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
- * See LICENSE.md in the project root for license terms and full copyright notice.
5
- *--------------------------------------------------------------------------------------------*/
6
- /** @packageDocumentation
7
- * @module Rendering
8
- */
9
- Object.defineProperty(exports, "__esModule", { value: true });
10
- exports.TerrainMeshPrimitive = exports.Child = void 0;
11
- const core_bentley_1 = require("@itwin/core-bentley");
12
- const core_geometry_1 = require("@itwin/core-geometry");
13
- const core_common_1 = require("@itwin/core-common");
14
- const RealityMeshPrimitive_1 = require("./RealityMeshPrimitive");
15
- var Child;
16
- (function (Child) {
17
- Child[Child["Q00"] = 0] = "Q00";
18
- Child[Child["Q01"] = 1] = "Q01";
19
- Child[Child["Q10"] = 2] = "Q10";
20
- Child[Child["Q11"] = 3] = "Q11";
21
- })(Child = exports.Child || (exports.Child = {}));
22
- class UpsampleIndexMap extends Map {
23
- constructor() {
24
- super(...arguments);
25
- this._next = 0;
26
- this.indices = new Array();
27
- }
28
- addTriangle(indices) {
29
- for (const index of indices) {
30
- let mapIndex = this.get(index);
31
- if (undefined === mapIndex)
32
- this.set(index, mapIndex = this._next++);
33
- this.indices.push(mapIndex);
34
- }
35
- }
36
- }
37
- class ClipAxis {
38
- constructor(vertical, lessThan, value) {
39
- this.vertical = vertical;
40
- this.lessThan = lessThan;
41
- this.value = value;
42
- }
43
- }
44
- const scratchQPoint3d = core_common_1.QPoint3d.fromScalars(0, 0, 0), scratchQPoint3d1 = core_common_1.QPoint3d.fromScalars(0, 0, 0);
45
- const scratchQPoint2d = new core_common_1.QPoint2d(), scratchQPoint2d1 = new core_common_1.QPoint2d();
46
- /** These are currently retained on terrain leaf tiles for upsampling.
47
- * It may be worthwhile to pack the data into buffers...
48
- * @internal
49
- */
50
- class TerrainMeshPrimitive extends RealityMeshPrimitive_1.RealityMeshPrimitive {
51
- constructor(props, _pointCapacity, _indexCapacity) {
52
- super(props);
53
- this._pointCapacity = _pointCapacity;
54
- this._indexCapacity = _indexCapacity;
55
- this._currPointCount = 0;
56
- this._currIndexCount = 0;
57
- }
58
- get isCompleted() { return this._currIndexCount === this._indexCapacity && this._currPointCount === this._pointCapacity; }
59
- get nextPointIndex() { return this._currPointCount; }
60
- static create(props) {
61
- let totalIndices = props.indexCount;
62
- let totalPoints = props.pointCount;
63
- if (props.wantSkirts) {
64
- totalIndices += 6 * (Math.max(0, props.northCount - 1) + Math.max(0, props.southCount - 1) + Math.max(0, props.eastCount - 1) + Math.max(0, props.westCount - 1));
65
- totalPoints += (props.northCount + props.southCount + props.eastCount + props.westCount);
66
- }
67
- const realityMeshProps = {
68
- indices: new Uint16Array(totalIndices), pointQParams: props.pointQParams, points: new Uint16Array(3 * totalPoints),
69
- uvQParams: core_common_1.QParams2d.fromZeroToOne(), uvs: new Uint16Array(2 * totalPoints), normals: props.wantNormals ? new Uint16Array(totalPoints) : undefined, featureID: 0,
70
- };
71
- return new TerrainMeshPrimitive(realityMeshProps, totalPoints, totalIndices);
72
- }
73
- collectStatistics(stats) {
74
- stats.addTerrain(this.bytesUsed);
75
- }
76
- addVertex(point, uvParam, normal) {
77
- scratchQPoint3d.init(point, this.pointQParams);
78
- this.addQuantizedVertex(scratchQPoint3d, uvParam, normal);
79
- }
80
- addQuantizedVertex(point, uv, normal) {
81
- if (this._currPointCount >= this._pointCapacity) {
82
- (0, core_bentley_1.assert)(false, "terrain point capacity exceeded");
83
- return;
84
- }
85
- let pointIndex = 3 * this._currPointCount;
86
- this.points[pointIndex++] = point.x;
87
- this.points[pointIndex++] = point.y;
88
- this.points[pointIndex++] = point.z;
89
- let paramIndex = 2 * this._currPointCount;
90
- this.uvs[paramIndex++] = uv.x;
91
- this.uvs[paramIndex++] = uv.y;
92
- if (normal && this.normals)
93
- this.normals[this._currPointCount] = normal;
94
- this._currPointCount++;
95
- }
96
- addQuad(i0, i1, i2, i3) {
97
- this.addTriangle(i0, i1, i2);
98
- this.addTriangle(i1, i3, i2);
99
- }
100
- addTriangle(i0, i1, i2) {
101
- if (this._currIndexCount + 3 > this._indexCapacity) {
102
- (0, core_bentley_1.assert)(false, "terrain index capacity exceeded");
103
- return;
104
- }
105
- this.indices[this._currIndexCount++] = i0;
106
- this.indices[this._currIndexCount++] = i1;
107
- this.indices[this._currIndexCount++] = i2;
108
- }
109
- addIndices(indices) {
110
- for (const index of indices)
111
- this.indices[this._currIndexCount++] = index;
112
- }
113
- upsample(uvSampleRange) {
114
- const indexMap = new UpsampleIndexMap();
115
- const uvLow = core_common_1.QPoint2d.create(uvSampleRange.low, TerrainMeshPrimitive._scratchUVQParams);
116
- const uvHigh = core_common_1.QPoint2d.create(uvSampleRange.high, TerrainMeshPrimitive._scratchUVQParams);
117
- const uvRange = core_geometry_1.Range2d.createXYXY(uvLow.x, uvLow.y, uvHigh.x, uvHigh.y, TerrainMeshPrimitive._scratchUVRange);
118
- const clipAxes = new Array();
119
- const addedPoints = new Array(), addedParams = new Array(), addedNormals = new Array();
120
- if (uvLow.x > 0)
121
- clipAxes.push(new ClipAxis(true, false, uvLow.x));
122
- if (uvHigh.x < core_common_1.Quantization.rangeScale16)
123
- clipAxes.push(new ClipAxis(true, true, uvHigh.x));
124
- if (uvLow.y > 0)
125
- clipAxes.push(new ClipAxis(false, false, uvLow.y));
126
- if (uvHigh.y < core_common_1.Quantization.rangeScale16)
127
- clipAxes.push(new ClipAxis(false, true, uvHigh.y));
128
- for (let i = 0; i < this.indices.length;) {
129
- const triangleIndices = [this.indices[i++], this.indices[i++], this.indices[i++]];
130
- const triangleRange = core_geometry_1.Range2d.createNull(TerrainMeshPrimitive._scratchTriangleRange);
131
- for (const index of triangleIndices) {
132
- const paramIndex = 2 * index;
133
- triangleRange.extendXY(this.uvs[paramIndex], this.uvs[paramIndex + 1]);
134
- }
135
- if (uvRange.intersectsRange(triangleRange)) {
136
- if (uvRange.containsRange(triangleRange)) {
137
- indexMap.addTriangle(triangleIndices);
138
- }
139
- else {
140
- this.addClipped(triangleIndices, indexMap, clipAxes, 0, addedPoints, addedParams, addedNormals);
141
- }
142
- }
143
- }
144
- const parentPoints = this.points;
145
- const parentParams = this.uvs;
146
- const parentNormals = this.normals;
147
- const parentPointCount = this.points.length / 3;
148
- const zRange = core_geometry_1.Range1d.createNull(TerrainMeshPrimitive._scratchZRange);
149
- const mesh = TerrainMeshPrimitive.create({ pointQParams: this.pointQParams, pointCount: indexMap.size, indexCount: indexMap.indices.length, wantSkirts: false, northCount: 0, southCount: 0, eastCount: 0, westCount: 0, wantNormals: this.normals !== undefined });
150
- for (const mapEntry of indexMap.entries()) {
151
- const parentIndex = mapEntry[0];
152
- let normal;
153
- if (parentIndex < parentPointCount) {
154
- const pointIndex = 3 * parentIndex;
155
- scratchQPoint3d.setFromScalars(parentPoints[pointIndex], parentPoints[pointIndex + 1], parentPoints[pointIndex + 2]);
156
- const paramIndex = 2 * parentIndex;
157
- scratchQPoint2d.setFromScalars(parentParams[paramIndex], parentParams[paramIndex + 1]);
158
- if (parentNormals)
159
- normal = parentNormals[parentIndex];
160
- }
161
- else {
162
- const addedIndex = parentIndex - parentPointCount;
163
- addedPoints[addedIndex].clone(scratchQPoint3d);
164
- addedParams[addedIndex].clone(scratchQPoint2d);
165
- if (addedNormals.length)
166
- normal = addedNormals[addedIndex];
167
- }
168
- mesh.addQuantizedVertex(scratchQPoint3d, scratchQPoint2d, normal);
169
- zRange.extendX(scratchQPoint3d.z);
170
- }
171
- mesh.addIndices(indexMap.indices);
172
- (0, core_bentley_1.assert)(mesh.isCompleted);
173
- const qParams = this.pointQParams;
174
- const heightRange = core_geometry_1.Range1d.createXX(core_common_1.Quantization.unquantize(zRange.low, qParams.origin.z, qParams.scale.z), core_common_1.Quantization.unquantize(zRange.high, qParams.origin.z, qParams.scale.z));
175
- return { heightRange, mesh };
176
- }
177
- addClipped(triangleIndices, indexMap, clipAxes, clipIndex, addedPoints, addedParams, addedNormals) {
178
- if (clipIndex === clipAxes.length) {
179
- indexMap.addTriangle(triangleIndices);
180
- return;
181
- }
182
- const inside = new Array(3);
183
- const values = new Array(3);
184
- const clipOutput = new Array();
185
- const clipAxis = clipAxes[clipIndex++];
186
- const parentPoints = this.points;
187
- const parentParams = this.uvs;
188
- const parentNormals = this.normals;
189
- const clipValue = clipAxis.value;
190
- const parentPointCount = parentPoints.length / 3;
191
- const getPoint = (index, result) => {
192
- if (index < parentPointCount) {
193
- const pointIndex = index * 3;
194
- result.setFromScalars(parentPoints[pointIndex], parentPoints[pointIndex + 1], parentPoints[pointIndex + 2]);
195
- }
196
- else {
197
- addedPoints[index - parentPointCount].clone(result);
198
- }
199
- return result;
200
- };
201
- const getParam = (index, result) => {
202
- if (index < parentPointCount) {
203
- const pointIndex = index * 2;
204
- result.setFromScalars(parentParams[pointIndex], parentParams[pointIndex + 1]);
205
- }
206
- else {
207
- addedParams[index - parentPointCount].clone(result);
208
- }
209
- return result;
210
- };
211
- const getNormal = (index) => {
212
- if (!parentNormals)
213
- return undefined;
214
- return (index < parentPointCount) ? parentNormals[index] : addedNormals[index - parentPointCount];
215
- };
216
- for (let i = 0; i < 3; i++) {
217
- const index = triangleIndices[i];
218
- const thisParam = getParam(index, scratchQPoint2d);
219
- const thisValue = clipAxis.vertical ? thisParam.x : thisParam.y;
220
- values[i] = thisValue;
221
- inside[i] = clipAxis.lessThan ? (thisValue < clipValue) : (thisValue > clipValue);
222
- }
223
- for (let i = 0; i < 3; i++) {
224
- const index = triangleIndices[i];
225
- const next = (i + 1) % 3;
226
- if (inside[i])
227
- clipOutput.push(index);
228
- if (inside[i] !== inside[next]) {
229
- const nextIndex = triangleIndices[next];
230
- const fraction = (clipValue - values[i]) / (values[next] - values[i]);
231
- clipOutput.push(parentPointCount + addedPoints.length);
232
- addedPoints.push(interpolateQPoint3d(getPoint(index, scratchQPoint3d), getPoint(nextIndex, scratchQPoint3d1), fraction));
233
- addedParams.push(interpolateQPoint2d(getParam(index, scratchQPoint2d), getParam(nextIndex, scratchQPoint2d1), fraction));
234
- if (parentNormals)
235
- addedNormals.push(interpolateOctEncodedNormal(getNormal(index), getNormal(nextIndex), fraction));
236
- }
237
- }
238
- if (clipOutput.length > 2) {
239
- this.addClipped(clipOutput.slice(0, 3), indexMap, clipAxes, clipIndex, addedPoints, addedParams, addedNormals);
240
- if (clipOutput.length > 3)
241
- this.addClipped([clipOutput[0], clipOutput[2], clipOutput[3]], indexMap, clipAxes, clipIndex, addedPoints, addedParams, addedNormals);
242
- }
243
- }
244
- }
245
- exports.TerrainMeshPrimitive = TerrainMeshPrimitive;
246
- TerrainMeshPrimitive._scratchZRange = core_geometry_1.Range1d.createNull();
247
- TerrainMeshPrimitive._scratchTriangleRange = core_geometry_1.Range2d.createNull();
248
- TerrainMeshPrimitive._scratchUVRange = core_geometry_1.Range2d.createNull();
249
- TerrainMeshPrimitive._scratchUVQParams = core_common_1.QParams2d.fromZeroToOne();
250
- function interpolate(value0, value1, fraction) { return value0 + (value1 - value0) * fraction; }
251
- function interpolateInt(value0, value1, fraction) { return Math.floor(.5 + interpolate(value0, value1, fraction)); }
252
- function interpolateQPoint3d(qPoint, qNext, fraction) {
253
- return core_common_1.QPoint3d.fromScalars(interpolateInt(qPoint.x, qNext.x, fraction), interpolateInt(qPoint.y, qNext.y, fraction), interpolateInt(qPoint.z, qNext.z, fraction));
254
- }
255
- function interpolateQPoint2d(qPoint, qNext, fraction) {
256
- return core_common_1.QPoint2d.fromScalars(interpolateInt(qPoint.x, qNext.x, fraction), interpolateInt(qPoint.y, qNext.y, fraction));
257
- }
258
- function interpolateOctEncodedNormal(normal0, normal1, fraction) {
259
- const n0 = core_common_1.OctEncodedNormal.decodeValue(normal0);
260
- const n1 = core_common_1.OctEncodedNormal.decodeValue(normal1);
261
- if (undefined !== n0 && undefined !== n1) {
262
- const n = core_geometry_1.Vector3d.create(interpolate(n0.x, n1.x, fraction), interpolate(n0.y, n1.y, fraction), interpolate(n0.z, n1.z, fraction));
263
- n.normalizeInPlace();
264
- return core_common_1.OctEncodedNormal.encode(n);
265
- }
266
- else {
267
- return core_common_1.OctEncodedNormal.encode(core_geometry_1.Vector3d.create(0, 0, 1));
268
- }
269
- }
270
- //# sourceMappingURL=TerrainMeshPrimitive.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TerrainMeshPrimitive.js","sourceRoot":"","sources":["../../../../../src/render/primitives/mesh/TerrainMeshPrimitive.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 Rendering\r\n */\r\n\r\nimport { assert } from \"@itwin/core-bentley\";\r\nimport { Point3d, Range1d, Range2d, Vector3d } from \"@itwin/core-geometry\";\r\nimport { OctEncodedNormal, QParams2d, QParams3d, QPoint2d, QPoint3d, Quantization } from \"@itwin/core-common\";\r\nimport { RenderMemory } from \"../../RenderMemory\";\r\nimport { RealityMeshPrimitive, RealityMeshProps } from \"./RealityMeshPrimitive\";\r\n\r\nexport enum Child { Q00, Q01, Q10, Q11 }\r\nclass UpsampleIndexMap extends Map<number, number> {\r\n private _next = 0;\r\n public indices = new Array<number>();\r\n public addTriangle(indices: number[]) {\r\n for (const index of indices) {\r\n let mapIndex = this.get(index);\r\n if (undefined === mapIndex)\r\n this.set(index, mapIndex = this._next++);\r\n this.indices.push(mapIndex);\r\n }\r\n }\r\n}\r\nclass ClipAxis {\r\n constructor(public vertical: boolean, public lessThan: boolean, public value: number) { }\r\n}\r\n\r\nconst scratchQPoint3d = QPoint3d.fromScalars(0, 0, 0), scratchQPoint3d1 = QPoint3d.fromScalars(0, 0, 0);\r\nconst scratchQPoint2d = new QPoint2d(), scratchQPoint2d1 = new QPoint2d();\r\n\r\n/** These are currently retained on terrain leaf tiles for upsampling.\r\n * It may be worthwhile to pack the data into buffers...\r\n * @internal\r\n */\r\nexport class TerrainMeshPrimitive extends RealityMeshPrimitive {\r\n private _currPointCount = 0;\r\n private _currIndexCount = 0;\r\n\r\n private constructor(props: RealityMeshProps, private _pointCapacity: number, private _indexCapacity: number) {\r\n super(props);\r\n }\r\n\r\n public get isCompleted() { return this._currIndexCount === this._indexCapacity && this._currPointCount === this._pointCapacity; }\r\n public get nextPointIndex() { return this._currPointCount; }\r\n\r\n public static create(props: TerrainMesh.Props) {\r\n let totalIndices = props.indexCount;\r\n let totalPoints = props.pointCount;\r\n if (props.wantSkirts) {\r\n totalIndices += 6 * (Math.max(0, props.northCount - 1) + Math.max(0, props.southCount - 1) + Math.max(0, props.eastCount - 1) + Math.max(0, props.westCount - 1));\r\n totalPoints += (props.northCount + props.southCount + props.eastCount + props.westCount);\r\n }\r\n const realityMeshProps = {\r\n indices: new Uint16Array(totalIndices), pointQParams: props.pointQParams, points: new Uint16Array(3 * totalPoints),\r\n uvQParams: QParams2d.fromZeroToOne(), uvs: new Uint16Array(2 * totalPoints), normals: props.wantNormals ? new Uint16Array(totalPoints) : undefined, featureID: 0,\r\n };\r\n return new TerrainMeshPrimitive(realityMeshProps, totalPoints, totalIndices);\r\n }\r\n\r\n public override collectStatistics(stats: RenderMemory.Statistics): void {\r\n stats.addTerrain(this.bytesUsed);\r\n }\r\n\r\n public addVertex(point: Point3d, uvParam: QPoint2d, normal?: number) {\r\n scratchQPoint3d.init(point, this.pointQParams);\r\n this.addQuantizedVertex(scratchQPoint3d, uvParam, normal);\r\n }\r\n\r\n public addQuantizedVertex(point: QPoint3d, uv: QPoint2d, normal?: number) {\r\n if (this._currPointCount >= this._pointCapacity) {\r\n assert(false, \"terrain point capacity exceeded\");\r\n return;\r\n }\r\n let pointIndex = 3 * this._currPointCount;\r\n this.points[pointIndex++] = point.x;\r\n this.points[pointIndex++] = point.y;\r\n this.points[pointIndex++] = point.z;\r\n\r\n let paramIndex = 2 * this._currPointCount;\r\n this.uvs[paramIndex++] = uv.x;\r\n this.uvs[paramIndex++] = uv.y;\r\n\r\n if (normal && this.normals)\r\n this.normals[this._currPointCount] = normal;\r\n\r\n this._currPointCount++;\r\n }\r\n public addQuad(i0: number, i1: number, i2: number, i3: number) {\r\n this.addTriangle(i0, i1, i2);\r\n this.addTriangle(i1, i3, i2);\r\n }\r\n\r\n public addTriangle(i0: number, i1: number, i2: number) {\r\n if (this._currIndexCount + 3 > this._indexCapacity) {\r\n assert(false, \"terrain index capacity exceeded\");\r\n return;\r\n }\r\n this.indices[this._currIndexCount++] = i0;\r\n this.indices[this._currIndexCount++] = i1;\r\n this.indices[this._currIndexCount++] = i2;\r\n }\r\n public addIndices(indices: number[]) {\r\n for (const index of indices)\r\n this.indices[this._currIndexCount++] = index;\r\n }\r\n\r\n private static _scratchZRange = Range1d.createNull();\r\n private static _scratchTriangleRange = Range2d.createNull();\r\n private static _scratchUVRange = Range2d.createNull();\r\n private static _scratchUVQParams = QParams2d.fromZeroToOne();\r\n public upsample(uvSampleRange: Range2d): { heightRange: Range1d, mesh: TerrainMeshPrimitive } {\r\n const indexMap = new UpsampleIndexMap();\r\n const uvLow = QPoint2d.create(uvSampleRange.low, TerrainMeshPrimitive._scratchUVQParams);\r\n const uvHigh = QPoint2d.create(uvSampleRange.high, TerrainMeshPrimitive._scratchUVQParams);\r\n const uvRange = Range2d.createXYXY(uvLow.x, uvLow.y, uvHigh.x, uvHigh.y, TerrainMeshPrimitive._scratchUVRange);\r\n const clipAxes = new Array<ClipAxis>();\r\n const addedPoints = new Array<QPoint3d>(), addedParams = new Array<QPoint2d>(), addedNormals = new Array<number>();\r\n if (uvLow.x > 0)\r\n clipAxes.push(new ClipAxis(true, false, uvLow.x));\r\n if (uvHigh.x < Quantization.rangeScale16)\r\n clipAxes.push(new ClipAxis(true, true, uvHigh.x));\r\n if (uvLow.y > 0)\r\n clipAxes.push(new ClipAxis(false, false, uvLow.y));\r\n if (uvHigh.y < Quantization.rangeScale16)\r\n clipAxes.push(new ClipAxis(false, true, uvHigh.y));\r\n\r\n for (let i = 0; i < this.indices.length;) {\r\n const triangleIndices = [this.indices[i++], this.indices[i++], this.indices[i++]];\r\n\r\n const triangleRange = Range2d.createNull(TerrainMeshPrimitive._scratchTriangleRange);\r\n for (const index of triangleIndices) {\r\n const paramIndex = 2 * index;\r\n triangleRange.extendXY(this.uvs[paramIndex], this.uvs[paramIndex + 1]);\r\n }\r\n\r\n if (uvRange.intersectsRange(triangleRange)) {\r\n if (uvRange.containsRange(triangleRange)) {\r\n indexMap.addTriangle(triangleIndices);\r\n } else {\r\n this.addClipped(triangleIndices, indexMap, clipAxes, 0, addedPoints, addedParams, addedNormals);\r\n }\r\n }\r\n }\r\n\r\n const parentPoints = this.points;\r\n const parentParams = this.uvs;\r\n const parentNormals = this.normals;\r\n const parentPointCount = this.points.length / 3;\r\n\r\n const zRange = Range1d.createNull(TerrainMeshPrimitive._scratchZRange);\r\n\r\n const mesh = TerrainMeshPrimitive.create({ pointQParams: this.pointQParams, pointCount: indexMap.size, indexCount: indexMap.indices.length, wantSkirts: false, northCount: 0, southCount: 0, eastCount: 0, westCount: 0, wantNormals: this.normals !== undefined });\r\n for (const mapEntry of indexMap.entries()) {\r\n const parentIndex = mapEntry[0];\r\n\r\n let normal: number | undefined;\r\n if (parentIndex < parentPointCount) {\r\n const pointIndex = 3 * parentIndex;\r\n scratchQPoint3d.setFromScalars(parentPoints[pointIndex], parentPoints[pointIndex + 1], parentPoints[pointIndex + 2]);\r\n const paramIndex = 2 * parentIndex;\r\n scratchQPoint2d.setFromScalars(parentParams[paramIndex], parentParams[paramIndex + 1]);\r\n if (parentNormals)\r\n normal = parentNormals[parentIndex];\r\n } else {\r\n const addedIndex = parentIndex - parentPointCount;\r\n addedPoints[addedIndex].clone(scratchQPoint3d);\r\n addedParams[addedIndex].clone(scratchQPoint2d);\r\n if (addedNormals.length)\r\n normal = addedNormals[addedIndex];\r\n }\r\n mesh.addQuantizedVertex(scratchQPoint3d, scratchQPoint2d, normal);\r\n zRange.extendX(scratchQPoint3d.z);\r\n }\r\n mesh.addIndices(indexMap.indices);\r\n\r\n assert(mesh.isCompleted);\r\n const qParams = this.pointQParams;\r\n const heightRange = Range1d.createXX(Quantization.unquantize(zRange.low, qParams.origin.z, qParams.scale.z), Quantization.unquantize(zRange.high, qParams.origin.z, qParams.scale.z));\r\n return { heightRange, mesh };\r\n }\r\n private addClipped(triangleIndices: number[], indexMap: UpsampleIndexMap, clipAxes: ClipAxis[], clipIndex: number, addedPoints: QPoint3d[], addedParams: QPoint2d[], addedNormals: number[]) {\r\n if (clipIndex === clipAxes.length) {\r\n indexMap.addTriangle(triangleIndices);\r\n return;\r\n }\r\n\r\n const inside = new Array<boolean>(3);\r\n const values = new Array<number>(3);\r\n const clipOutput = new Array<number>();\r\n const clipAxis = clipAxes[clipIndex++];\r\n const parentPoints = this.points;\r\n const parentParams = this.uvs;\r\n const parentNormals = this.normals;\r\n const clipValue = clipAxis.value;\r\n const parentPointCount = parentPoints.length / 3;\r\n const getPoint = (index: number, result: QPoint3d): QPoint3d => {\r\n if (index < parentPointCount) {\r\n const pointIndex = index * 3;\r\n result.setFromScalars(parentPoints[pointIndex], parentPoints[pointIndex + 1], parentPoints[pointIndex + 2]);\r\n } else {\r\n addedPoints[index - parentPointCount].clone(result);\r\n }\r\n return result;\r\n };\r\n const getParam = (index: number, result: QPoint2d): QPoint2d => {\r\n if (index < parentPointCount) {\r\n const pointIndex = index * 2;\r\n result.setFromScalars(parentParams[pointIndex], parentParams[pointIndex + 1]);\r\n } else {\r\n addedParams[index - parentPointCount].clone(result);\r\n }\r\n return result;\r\n };\r\n const getNormal = (index: number): number | undefined => {\r\n if (!parentNormals)\r\n return undefined;\r\n\r\n return (index < parentPointCount) ? parentNormals[index] : addedNormals[index - parentPointCount];\r\n };\r\n\r\n for (let i = 0; i < 3; i++) {\r\n const index = triangleIndices[i];\r\n const thisParam = getParam(index, scratchQPoint2d);\r\n const thisValue = clipAxis.vertical ? thisParam.x : thisParam.y;\r\n values[i] = thisValue;\r\n inside[i] = clipAxis.lessThan ? (thisValue < clipValue) : (thisValue > clipValue);\r\n }\r\n\r\n for (let i = 0; i < 3; i++) {\r\n const index = triangleIndices[i];\r\n const next = (i + 1) % 3;\r\n if (inside[i])\r\n clipOutput.push(index);\r\n if (inside[i] !== inside[next]) {\r\n const nextIndex = triangleIndices[next];\r\n const fraction = (clipValue - values[i]) / (values[next] - values[i]);\r\n\r\n clipOutput.push(parentPointCount + addedPoints.length);\r\n addedPoints.push(interpolateQPoint3d(getPoint(index, scratchQPoint3d), getPoint(nextIndex, scratchQPoint3d1), fraction));\r\n addedParams.push(interpolateQPoint2d(getParam(index, scratchQPoint2d), getParam(nextIndex, scratchQPoint2d1), fraction));\r\n if (parentNormals)\r\n addedNormals.push(interpolateOctEncodedNormal(getNormal(index)!, getNormal(nextIndex)!, fraction));\r\n\r\n }\r\n }\r\n if (clipOutput.length > 2) {\r\n this.addClipped(clipOutput.slice(0, 3), indexMap, clipAxes, clipIndex, addedPoints, addedParams, addedNormals);\r\n if (clipOutput.length > 3)\r\n this.addClipped([clipOutput[0], clipOutput[2], clipOutput[3]], indexMap, clipAxes, clipIndex, addedPoints, addedParams, addedNormals);\r\n }\r\n }\r\n}\r\n\r\nfunction interpolate(value0: number, value1: number, fraction: number) { return value0 + (value1 - value0) * fraction; }\r\nfunction interpolateInt(value0: number, value1: number, fraction: number) { return Math.floor(.5 + interpolate(value0, value1, fraction)); }\r\n\r\nfunction interpolateQPoint3d(qPoint: QPoint3d, qNext: QPoint3d, fraction: number): QPoint3d {\r\n return QPoint3d.fromScalars(interpolateInt(qPoint.x, qNext.x, fraction), interpolateInt(qPoint.y, qNext.y, fraction), interpolateInt(qPoint.z, qNext.z, fraction));\r\n}\r\n\r\nfunction interpolateQPoint2d(qPoint: QPoint2d, qNext: QPoint2d, fraction: number): QPoint2d {\r\n return QPoint2d.fromScalars(interpolateInt(qPoint.x, qNext.x, fraction), interpolateInt(qPoint.y, qNext.y, fraction));\r\n}\r\n\r\nfunction interpolateOctEncodedNormal(normal0: number, normal1: number, fraction: number): number {\r\n const n0 = OctEncodedNormal.decodeValue(normal0);\r\n const n1 = OctEncodedNormal.decodeValue(normal1);\r\n if (undefined !== n0 && undefined !== n1) {\r\n const n = Vector3d.create(interpolate(n0.x, n1.x, fraction), interpolate(n0.y, n1.y, fraction), interpolate(n0.z, n1.z, fraction));\r\n n.normalizeInPlace();\r\n return OctEncodedNormal.encode(n);\r\n } else {\r\n return OctEncodedNormal.encode(Vector3d.create(0, 0, 1));\r\n }\r\n}\r\n\r\nexport namespace TerrainMesh {\r\n export interface Props {\r\n readonly wantNormals: boolean;\r\n readonly pointQParams: QParams3d;\r\n readonly pointCount: number;\r\n readonly indexCount: number;\r\n readonly wantSkirts: boolean;\r\n readonly eastCount: number;\r\n readonly westCount: number;\r\n readonly northCount: number;\r\n readonly southCount: number;\r\n }\r\n}\r\n"]}