@itwin/core-common 4.0.0-dev.44 → 4.0.0-dev.48

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 (951) hide show
  1. package/lib/cjs/AmbientOcclusion.d.ts +49 -49
  2. package/lib/cjs/AmbientOcclusion.js +55 -55
  3. package/lib/cjs/AmbientOcclusion.js.map +1 -1
  4. package/lib/cjs/AnalysisStyle.d.ts +134 -134
  5. package/lib/cjs/AnalysisStyle.js +165 -165
  6. package/lib/cjs/AnalysisStyle.js.map +1 -1
  7. package/lib/cjs/AuthorizationClient.d.ts +17 -17
  8. package/lib/cjs/AuthorizationClient.js +9 -9
  9. package/lib/cjs/AuthorizationClient.js.map +1 -1
  10. package/lib/cjs/BackendTypes.d.ts +12 -12
  11. package/lib/cjs/BackendTypes.js +9 -9
  12. package/lib/cjs/BackendTypes.js.map +1 -1
  13. package/lib/cjs/BackgroundMapProvider.d.ts +51 -51
  14. package/lib/cjs/BackgroundMapProvider.js +67 -67
  15. package/lib/cjs/BackgroundMapProvider.js.map +1 -1
  16. package/lib/cjs/BackgroundMapSettings.d.ts +136 -136
  17. package/lib/cjs/BackgroundMapSettings.js +154 -154
  18. package/lib/cjs/BackgroundMapSettings.js.map +1 -1
  19. package/lib/cjs/Base64EncodedString.d.ts +32 -32
  20. package/lib/cjs/Base64EncodedString.js +66 -66
  21. package/lib/cjs/Base64EncodedString.js.map +1 -1
  22. package/lib/cjs/BlobReader.d.ts +31 -31
  23. package/lib/cjs/BlobReader.js +84 -84
  24. package/lib/cjs/BlobReader.js.map +1 -1
  25. package/lib/cjs/BriefcaseTypes.d.ts +191 -191
  26. package/lib/cjs/BriefcaseTypes.js +95 -95
  27. package/lib/cjs/BriefcaseTypes.js.map +1 -1
  28. package/lib/cjs/Camera.d.ts +42 -42
  29. package/lib/cjs/Camera.js +62 -62
  30. package/lib/cjs/Camera.js.map +1 -1
  31. package/lib/cjs/ChangedElements.d.ts +85 -85
  32. package/lib/cjs/ChangedElements.js +23 -23
  33. package/lib/cjs/ChangedElements.js.map +1 -1
  34. package/lib/cjs/ChangedEntities.d.ts +45 -45
  35. package/lib/cjs/ChangedEntities.js +9 -9
  36. package/lib/cjs/ChangedEntities.js.map +1 -1
  37. package/lib/cjs/ChangesetProps.d.ts +98 -98
  38. package/lib/cjs/ChangesetProps.js +22 -22
  39. package/lib/cjs/ChangesetProps.js.map +1 -1
  40. package/lib/cjs/ClipStyle.d.ts +89 -89
  41. package/lib/cjs/ClipStyle.js +121 -121
  42. package/lib/cjs/ClipStyle.js.map +1 -1
  43. package/lib/cjs/CloudStorage.d.ts +62 -62
  44. package/lib/cjs/CloudStorage.js +113 -113
  45. package/lib/cjs/CloudStorage.js.map +1 -1
  46. package/lib/cjs/CloudStorageTileCache.d.ts +27 -27
  47. package/lib/cjs/CloudStorageTileCache.js +65 -65
  48. package/lib/cjs/CloudStorageTileCache.js.map +1 -1
  49. package/lib/cjs/Code.d.ts +277 -277
  50. package/lib/cjs/Code.js +268 -268
  51. package/lib/cjs/Code.js.map +1 -1
  52. package/lib/cjs/ColorByName.d.ts +161 -161
  53. package/lib/cjs/ColorByName.js +169 -169
  54. package/lib/cjs/ColorByName.js.map +1 -1
  55. package/lib/cjs/ColorDef.d.ts +208 -208
  56. package/lib/cjs/ColorDef.js +570 -570
  57. package/lib/cjs/ColorDef.js.map +1 -1
  58. package/lib/cjs/CommonLoggerCategory.d.ts +18 -18
  59. package/lib/cjs/CommonLoggerCategory.js +26 -26
  60. package/lib/cjs/CommonLoggerCategory.js.map +1 -1
  61. package/lib/cjs/ConcurrentQuery.d.ts +421 -421
  62. package/lib/cjs/ConcurrentQuery.js +552 -552
  63. package/lib/cjs/ConcurrentQuery.js.map +1 -1
  64. package/lib/cjs/ContextRealityModel.d.ts +303 -303
  65. package/lib/cjs/ContextRealityModel.js +371 -371
  66. package/lib/cjs/ContextRealityModel.js.map +1 -1
  67. package/lib/cjs/DisplayStyleSettings.d.ts +588 -588
  68. package/lib/cjs/DisplayStyleSettings.js +981 -981
  69. package/lib/cjs/DisplayStyleSettings.js.map +1 -1
  70. package/lib/cjs/ECSchemaProps.d.ts +39 -39
  71. package/lib/cjs/ECSchemaProps.js +9 -9
  72. package/lib/cjs/ECSchemaProps.js.map +1 -1
  73. package/lib/cjs/ECSqlReader.d.ts +70 -70
  74. package/lib/cjs/ECSqlReader.js +280 -280
  75. package/lib/cjs/ECSqlReader.js.map +1 -1
  76. package/lib/cjs/ECSqlTypes.d.ts +128 -128
  77. package/lib/cjs/ECSqlTypes.js +189 -189
  78. package/lib/cjs/ECSqlTypes.js.map +1 -1
  79. package/lib/cjs/ElementMesh.d.ts +39 -39
  80. package/lib/cjs/ElementMesh.js +56 -56
  81. package/lib/cjs/ElementMesh.js.map +1 -1
  82. package/lib/cjs/ElementProps.d.ts +483 -483
  83. package/lib/cjs/ElementProps.js +99 -99
  84. package/lib/cjs/ElementProps.js.map +1 -1
  85. package/lib/cjs/EmphasizeElementsProps.d.ts +55 -55
  86. package/lib/cjs/EmphasizeElementsProps.js +25 -25
  87. package/lib/cjs/EmphasizeElementsProps.js.map +1 -1
  88. package/lib/cjs/EntityProps.d.ts +177 -177
  89. package/lib/cjs/EntityProps.js +113 -113
  90. package/lib/cjs/EntityProps.js.map +1 -1
  91. package/lib/cjs/EntityReference.d.ts +51 -51
  92. package/lib/cjs/EntityReference.js +56 -56
  93. package/lib/cjs/EntityReference.js.map +1 -1
  94. package/lib/cjs/Environment.d.ts +61 -61
  95. package/lib/cjs/Environment.js +70 -70
  96. package/lib/cjs/Environment.js.map +1 -1
  97. package/lib/cjs/FeatureIndex.d.ts +39 -39
  98. package/lib/cjs/FeatureIndex.js +63 -63
  99. package/lib/cjs/FeatureIndex.js.map +1 -1
  100. package/lib/cjs/FeatureSymbology.d.ts +444 -444
  101. package/lib/cjs/FeatureSymbology.js +613 -613
  102. package/lib/cjs/FeatureSymbology.js.map +1 -1
  103. package/lib/cjs/FeatureTable.d.ts +141 -141
  104. package/lib/cjs/FeatureTable.js +278 -278
  105. package/lib/cjs/FeatureTable.js.map +1 -1
  106. package/lib/cjs/Fonts.d.ts +51 -51
  107. package/lib/cjs/Fonts.js +53 -53
  108. package/lib/cjs/Fonts.js.map +1 -1
  109. package/lib/cjs/Frustum.d.ts +114 -114
  110. package/lib/cjs/Frustum.js +292 -292
  111. package/lib/cjs/Frustum.js.map +1 -1
  112. package/lib/cjs/GeoCoordinateServices.d.ts +119 -119
  113. package/lib/cjs/GeoCoordinateServices.js +80 -80
  114. package/lib/cjs/GeoCoordinateServices.js.map +1 -1
  115. package/lib/cjs/GeometryContainment.d.ts +28 -28
  116. package/lib/cjs/GeometryContainment.js +9 -9
  117. package/lib/cjs/GeometryContainment.js.map +1 -1
  118. package/lib/cjs/GeometryParams.d.ts +130 -130
  119. package/lib/cjs/GeometryParams.js +174 -174
  120. package/lib/cjs/GeometryParams.js.map +1 -1
  121. package/lib/cjs/GeometrySummary.d.ts +45 -45
  122. package/lib/cjs/GeometrySummary.js +23 -23
  123. package/lib/cjs/GeometrySummary.js.map +1 -1
  124. package/lib/cjs/Gradient.d.ts +139 -139
  125. package/lib/cjs/Gradient.js +453 -453
  126. package/lib/cjs/Gradient.js.map +1 -1
  127. package/lib/cjs/GraphicParams.d.ts +58 -58
  128. package/lib/cjs/GraphicParams.js +85 -85
  129. package/lib/cjs/GraphicParams.js.map +1 -1
  130. package/lib/cjs/GroundPlane.d.ts +52 -52
  131. package/lib/cjs/GroundPlane.js +63 -63
  132. package/lib/cjs/GroundPlane.js.map +1 -1
  133. package/lib/cjs/HSLColor.d.ts +20 -20
  134. package/lib/cjs/HSLColor.js +32 -32
  135. package/lib/cjs/HSLColor.js.map +1 -1
  136. package/lib/cjs/HSVColor.d.ts +30 -30
  137. package/lib/cjs/HSVColor.js +59 -59
  138. package/lib/cjs/HSVColor.js.map +1 -1
  139. package/lib/cjs/HiddenLine.d.ts +97 -97
  140. package/lib/cjs/HiddenLine.js +160 -160
  141. package/lib/cjs/HiddenLine.js.map +1 -1
  142. package/lib/cjs/Hilite.d.ts +50 -50
  143. package/lib/cjs/Hilite.js +64 -64
  144. package/lib/cjs/Hilite.js.map +1 -1
  145. package/lib/cjs/IModel.d.ts +358 -358
  146. package/lib/cjs/IModel.js +347 -347
  147. package/lib/cjs/IModel.js.map +1 -1
  148. package/lib/cjs/IModelError.d.ts +42 -42
  149. package/lib/cjs/IModelError.js +71 -71
  150. package/lib/cjs/IModelError.js.map +1 -1
  151. package/lib/cjs/IModelVersion.d.ts +68 -68
  152. package/lib/cjs/IModelVersion.js +79 -79
  153. package/lib/cjs/IModelVersion.js.map +1 -1
  154. package/lib/cjs/Image.d.ts +86 -86
  155. package/lib/cjs/Image.js +128 -128
  156. package/lib/cjs/Image.js.map +1 -1
  157. package/lib/cjs/IpcAppProps.d.ts +141 -141
  158. package/lib/cjs/IpcAppProps.js +23 -23
  159. package/lib/cjs/IpcAppProps.js.map +1 -1
  160. package/lib/cjs/LightSettings.d.ts +224 -224
  161. package/lib/cjs/LightSettings.js +304 -304
  162. package/lib/cjs/LightSettings.js.map +1 -1
  163. package/lib/cjs/LinePixels.d.ts +34 -34
  164. package/lib/cjs/LinePixels.js +42 -42
  165. package/lib/cjs/LinePixels.js.map +1 -1
  166. package/lib/cjs/Localization.d.ts +113 -113
  167. package/lib/cjs/Localization.js +33 -33
  168. package/lib/cjs/Localization.js.map +1 -1
  169. package/lib/cjs/MapImagerySettings.d.ts +62 -62
  170. package/lib/cjs/MapImagerySettings.js +80 -80
  171. package/lib/cjs/MapImagerySettings.js.map +1 -1
  172. package/lib/cjs/MapLayerSettings.d.ts +272 -272
  173. package/lib/cjs/MapLayerSettings.js +407 -407
  174. package/lib/cjs/MapLayerSettings.js.map +1 -1
  175. package/lib/cjs/MassProperties.d.ts +64 -64
  176. package/lib/cjs/MassProperties.js +23 -23
  177. package/lib/cjs/MassProperties.js.map +1 -1
  178. package/lib/cjs/MaterialProps.d.ts +153 -153
  179. package/lib/cjs/MaterialProps.js +35 -35
  180. package/lib/cjs/MaterialProps.js.map +1 -1
  181. package/lib/cjs/ModelClipGroup.d.ts +67 -67
  182. package/lib/cjs/ModelClipGroup.js +96 -96
  183. package/lib/cjs/ModelClipGroup.js.map +1 -1
  184. package/lib/cjs/ModelGeometryChanges.d.ts +107 -107
  185. package/lib/cjs/ModelGeometryChanges.js +83 -83
  186. package/lib/cjs/ModelGeometryChanges.js.map +1 -1
  187. package/lib/cjs/ModelProps.d.ts +67 -67
  188. package/lib/cjs/ModelProps.js +9 -9
  189. package/lib/cjs/ModelProps.js.map +1 -1
  190. package/lib/cjs/NativeAppProps.d.ts +122 -122
  191. package/lib/cjs/NativeAppProps.js +30 -30
  192. package/lib/cjs/NativeAppProps.js.map +1 -1
  193. package/lib/cjs/OctEncodedNormal.d.ts +33 -33
  194. package/lib/cjs/OctEncodedNormal.js +98 -98
  195. package/lib/cjs/OctEncodedNormal.js.map +1 -1
  196. package/lib/cjs/PlanProjectionSettings.d.ts +47 -47
  197. package/lib/cjs/PlanProjectionSettings.js +63 -63
  198. package/lib/cjs/PlanProjectionSettings.js.map +1 -1
  199. package/lib/cjs/PlanarClipMask.d.ts +177 -177
  200. package/lib/cjs/PlanarClipMask.js +136 -136
  201. package/lib/cjs/PlanarClipMask.js.map +1 -1
  202. package/lib/cjs/QPoint.d.ts +479 -479
  203. package/lib/cjs/QPoint.js +824 -824
  204. package/lib/cjs/QPoint.js.map +1 -1
  205. package/lib/cjs/RealityDataAccessProps.d.ts +41 -41
  206. package/lib/cjs/RealityDataAccessProps.js +19 -19
  207. package/lib/cjs/RealityDataAccessProps.js.map +1 -1
  208. package/lib/cjs/RealityModelDisplaySettings.d.ts +183 -183
  209. package/lib/cjs/RealityModelDisplaySettings.js +141 -141
  210. package/lib/cjs/RealityModelDisplaySettings.js.map +1 -1
  211. package/lib/cjs/Render.d.ts +89 -89
  212. package/lib/cjs/Render.js +177 -177
  213. package/lib/cjs/Render.js.map +1 -1
  214. package/lib/cjs/RenderMaterial.d.ts +58 -58
  215. package/lib/cjs/RenderMaterial.js +75 -75
  216. package/lib/cjs/RenderMaterial.js.map +1 -1
  217. package/lib/cjs/RenderSchedule.d.ts +543 -543
  218. package/lib/cjs/RenderSchedule.js +992 -992
  219. package/lib/cjs/RenderTexture.d.ts +70 -70
  220. package/lib/cjs/RenderTexture.js +59 -59
  221. package/lib/cjs/RenderTexture.js.map +1 -1
  222. package/lib/cjs/RgbColor.d.ts +47 -47
  223. package/lib/cjs/RgbColor.js +77 -77
  224. package/lib/cjs/RgbColor.js.map +1 -1
  225. package/lib/cjs/RpcInterface.d.ts +33 -33
  226. package/lib/cjs/RpcInterface.js +137 -137
  227. package/lib/cjs/RpcInterface.js.map +1 -1
  228. package/lib/cjs/RpcManager.d.ts +40 -40
  229. package/lib/cjs/RpcManager.js +55 -55
  230. package/lib/cjs/RpcManager.js.map +1 -1
  231. package/lib/cjs/SessionProps.d.ts +16 -16
  232. package/lib/cjs/SessionProps.js +9 -9
  233. package/lib/cjs/SessionProps.js.map +1 -1
  234. package/lib/cjs/SkyBox.d.ts +215 -215
  235. package/lib/cjs/SkyBox.js +209 -209
  236. package/lib/cjs/SkyBox.js.map +1 -1
  237. package/lib/cjs/Snapping.d.ts +49 -49
  238. package/lib/cjs/Snapping.js +9 -9
  239. package/lib/cjs/Snapping.js.map +1 -1
  240. package/lib/cjs/SolarCalculate.d.ts +27 -27
  241. package/lib/cjs/SolarCalculate.js +211 -211
  242. package/lib/cjs/SolarCalculate.js.map +1 -1
  243. package/lib/cjs/SolarShadows.d.ts +35 -35
  244. package/lib/cjs/SolarShadows.js +61 -61
  245. package/lib/cjs/SolarShadows.js.map +1 -1
  246. package/lib/cjs/SpatialClassification.d.ts +208 -208
  247. package/lib/cjs/SpatialClassification.js +339 -339
  248. package/lib/cjs/SpatialClassification.js.map +1 -1
  249. package/lib/cjs/SubCategoryAppearance.d.ts +91 -91
  250. package/lib/cjs/SubCategoryAppearance.js +96 -96
  251. package/lib/cjs/SubCategoryAppearance.js.map +1 -1
  252. package/lib/cjs/SubCategoryOverride.d.ts +46 -46
  253. package/lib/cjs/SubCategoryOverride.js +104 -104
  254. package/lib/cjs/SubCategoryOverride.js.map +1 -1
  255. package/lib/cjs/TerrainSettings.d.ts +82 -82
  256. package/lib/cjs/TerrainSettings.js +100 -100
  257. package/lib/cjs/TerrainSettings.js.map +1 -1
  258. package/lib/cjs/TextureMapping.d.ts +118 -118
  259. package/lib/cjs/TextureMapping.js +173 -173
  260. package/lib/cjs/TextureMapping.js.map +1 -1
  261. package/lib/cjs/TextureProps.d.ts +65 -65
  262. package/lib/cjs/TextureProps.js +28 -28
  263. package/lib/cjs/TextureProps.js.map +1 -1
  264. package/lib/cjs/ThematicDisplay.d.ts +230 -230
  265. package/lib/cjs/ThematicDisplay.js +343 -343
  266. package/lib/cjs/ThematicDisplay.js.map +1 -1
  267. package/lib/cjs/Thumbnail.d.ts +26 -26
  268. package/lib/cjs/Thumbnail.js +9 -9
  269. package/lib/cjs/Thumbnail.js.map +1 -1
  270. package/lib/cjs/TileProps.d.ts +82 -82
  271. package/lib/cjs/TileProps.js +29 -29
  272. package/lib/cjs/TileProps.js.map +1 -1
  273. package/lib/cjs/Tween.d.ts +191 -191
  274. package/lib/cjs/Tween.js +570 -570
  275. package/lib/cjs/Tween.js.map +1 -1
  276. package/lib/cjs/TxnAction.d.ts +21 -21
  277. package/lib/cjs/TxnAction.js +29 -29
  278. package/lib/cjs/TxnAction.js.map +1 -1
  279. package/lib/cjs/ViewDetails.d.ts +125 -125
  280. package/lib/cjs/ViewDetails.js +166 -166
  281. package/lib/cjs/ViewDetails.js.map +1 -1
  282. package/lib/cjs/ViewFlags.d.ts +287 -287
  283. package/lib/cjs/ViewFlags.js +367 -367
  284. package/lib/cjs/ViewFlags.js.map +1 -1
  285. package/lib/cjs/ViewProps.d.ts +205 -205
  286. package/lib/cjs/ViewProps.js +9 -9
  287. package/lib/cjs/ViewProps.js.map +1 -1
  288. package/lib/cjs/WhiteOnWhiteReversalSettings.d.ts +36 -36
  289. package/lib/cjs/WhiteOnWhiteReversalSettings.js +37 -37
  290. package/lib/cjs/WhiteOnWhiteReversalSettings.js.map +1 -1
  291. package/lib/cjs/core-common.d.ts +245 -244
  292. package/lib/cjs/core-common.d.ts.map +1 -1
  293. package/lib/cjs/core-common.js +261 -260
  294. package/lib/cjs/core-common.js.map +1 -1
  295. package/lib/cjs/domains/FunctionalElementProps.d.ts +11 -11
  296. package/lib/cjs/domains/FunctionalElementProps.js +9 -9
  297. package/lib/cjs/domains/FunctionalElementProps.js.map +1 -1
  298. package/lib/cjs/domains/GenericElementProps.d.ts +18 -18
  299. package/lib/cjs/domains/GenericElementProps.js +9 -9
  300. package/lib/cjs/domains/GenericElementProps.js.map +1 -1
  301. package/lib/cjs/geometry/AdditionalTransform.d.ts +84 -84
  302. package/lib/cjs/geometry/AdditionalTransform.js +85 -85
  303. package/lib/cjs/geometry/AdditionalTransform.js.map +1 -1
  304. package/lib/cjs/geometry/AreaPattern.d.ts +82 -82
  305. package/lib/cjs/geometry/AreaPattern.js +203 -203
  306. package/lib/cjs/geometry/AreaPattern.js.map +1 -1
  307. package/lib/cjs/geometry/BoundingSphere.d.ts +27 -27
  308. package/lib/cjs/geometry/BoundingSphere.js +44 -44
  309. package/lib/cjs/geometry/BoundingSphere.js.map +1 -1
  310. package/lib/cjs/geometry/Cartographic.d.ts +137 -137
  311. package/lib/cjs/geometry/Cartographic.js +345 -345
  312. package/lib/cjs/geometry/Cartographic.js.map +1 -1
  313. package/lib/cjs/geometry/CoordinateReferenceSystem.d.ts +269 -269
  314. package/lib/cjs/geometry/CoordinateReferenceSystem.js +260 -260
  315. package/lib/cjs/geometry/CoordinateReferenceSystem.js.map +1 -1
  316. package/lib/cjs/geometry/ElementGeometry.d.ts +402 -402
  317. package/lib/cjs/geometry/ElementGeometry.js +1719 -1719
  318. package/lib/cjs/geometry/ElementGeometry.js.map +1 -1
  319. package/lib/cjs/geometry/ElementGeometryFB.d.ts +2372 -2372
  320. package/lib/cjs/geometry/ElementGeometryFB.js +3814 -3814
  321. package/lib/cjs/geometry/ElementGeometryFB.js.map +1 -1
  322. package/lib/cjs/geometry/FrustumPlanes.d.ts +81 -81
  323. package/lib/cjs/geometry/FrustumPlanes.js +189 -189
  324. package/lib/cjs/geometry/FrustumPlanes.js.map +1 -1
  325. package/lib/cjs/geometry/GeodeticDatum.d.ts +409 -409
  326. package/lib/cjs/geometry/GeodeticDatum.js +400 -400
  327. package/lib/cjs/geometry/GeodeticDatum.js.map +1 -1
  328. package/lib/cjs/geometry/GeodeticEllipsoid.d.ts +72 -72
  329. package/lib/cjs/geometry/GeodeticEllipsoid.js +71 -71
  330. package/lib/cjs/geometry/GeodeticEllipsoid.js.map +1 -1
  331. package/lib/cjs/geometry/GeometryStream.d.ts +347 -347
  332. package/lib/cjs/geometry/GeometryStream.js +468 -468
  333. package/lib/cjs/geometry/GeometryStream.js.map +1 -1
  334. package/lib/cjs/geometry/ImageGraphic.d.ts +74 -74
  335. package/lib/cjs/geometry/ImageGraphic.js +98 -98
  336. package/lib/cjs/geometry/ImageGraphic.js.map +1 -1
  337. package/lib/cjs/geometry/LineStyle.d.ts +71 -71
  338. package/lib/cjs/geometry/LineStyle.js +129 -129
  339. package/lib/cjs/geometry/LineStyle.js.map +1 -1
  340. package/lib/cjs/geometry/Placement.d.ts +95 -95
  341. package/lib/cjs/geometry/Placement.js +131 -131
  342. package/lib/cjs/geometry/Placement.js.map +1 -1
  343. package/lib/cjs/geometry/Projection.d.ts +251 -251
  344. package/lib/cjs/geometry/Projection.js +198 -198
  345. package/lib/cjs/geometry/Projection.js.map +1 -1
  346. package/lib/cjs/geometry/TextString.d.ts +55 -55
  347. package/lib/cjs/geometry/TextString.js +65 -65
  348. package/lib/cjs/geometry/TextString.js.map +1 -1
  349. package/lib/cjs/ipc/IpcSession.d.ts +23 -23
  350. package/lib/cjs/ipc/IpcSession.js +27 -27
  351. package/lib/cjs/ipc/IpcSession.js.map +1 -1
  352. package/lib/cjs/ipc/IpcSocket.d.ts +96 -96
  353. package/lib/cjs/ipc/IpcSocket.js +16 -16
  354. package/lib/cjs/ipc/IpcSocket.js.map +1 -1
  355. package/lib/cjs/ipc/IpcWebSocket.d.ts +61 -61
  356. package/lib/cjs/ipc/IpcWebSocket.js +150 -150
  357. package/lib/cjs/ipc/IpcWebSocket.js.map +1 -1
  358. package/lib/cjs/ipc/IpcWebSocketTransport.d.ts +15 -15
  359. package/lib/cjs/ipc/IpcWebSocketTransport.js +160 -160
  360. package/lib/cjs/ipc/IpcWebSocketTransport.js.map +1 -1
  361. package/lib/cjs/rpc/DevToolsRpcInterface.d.ts +32 -32
  362. package/lib/cjs/rpc/DevToolsRpcInterface.js +52 -52
  363. package/lib/cjs/rpc/DevToolsRpcInterface.js.map +1 -1
  364. package/lib/cjs/rpc/IModelReadRpcInterface.d.ts +99 -99
  365. package/lib/cjs/rpc/IModelReadRpcInterface.js +122 -122
  366. package/lib/cjs/rpc/IModelReadRpcInterface.js.map +1 -1
  367. package/lib/cjs/rpc/IModelTileRpcInterface.d.ts +61 -61
  368. package/lib/cjs/rpc/IModelTileRpcInterface.js +96 -96
  369. package/lib/cjs/rpc/IModelTileRpcInterface.js.map +1 -1
  370. package/lib/cjs/rpc/SnapshotIModelRpcInterface.d.ts +23 -23
  371. package/lib/cjs/rpc/SnapshotIModelRpcInterface.js +48 -48
  372. package/lib/cjs/rpc/SnapshotIModelRpcInterface.js.map +1 -1
  373. package/lib/cjs/rpc/TestRpcManager.d.ts +20 -20
  374. package/lib/cjs/rpc/TestRpcManager.js +40 -40
  375. package/lib/cjs/rpc/TestRpcManager.js.map +1 -1
  376. package/lib/cjs/rpc/WipRpcInterface.d.ts +29 -29
  377. package/lib/cjs/rpc/WipRpcInterface.js +40 -40
  378. package/lib/cjs/rpc/WipRpcInterface.js.map +1 -1
  379. package/lib/cjs/rpc/core/RpcConfiguration.d.ts +111 -111
  380. package/lib/cjs/rpc/core/RpcConfiguration.js +191 -191
  381. package/lib/cjs/rpc/core/RpcConfiguration.js.map +1 -1
  382. package/lib/cjs/rpc/core/RpcConstants.d.ts +90 -90
  383. package/lib/cjs/rpc/core/RpcConstants.js +109 -109
  384. package/lib/cjs/rpc/core/RpcConstants.js.map +1 -1
  385. package/lib/cjs/rpc/core/RpcControl.d.ts +54 -54
  386. package/lib/cjs/rpc/core/RpcControl.js +145 -145
  387. package/lib/cjs/rpc/core/RpcControl.js.map +1 -1
  388. package/lib/cjs/rpc/core/RpcInvocation.d.ts +89 -89
  389. package/lib/cjs/rpc/core/RpcInvocation.js +256 -256
  390. package/lib/cjs/rpc/core/RpcInvocation.js.map +1 -1
  391. package/lib/cjs/rpc/core/RpcMarshaling.d.ts +35 -35
  392. package/lib/cjs/rpc/core/RpcMarshaling.js +156 -156
  393. package/lib/cjs/rpc/core/RpcMarshaling.js.map +1 -1
  394. package/lib/cjs/rpc/core/RpcOperation.d.ts +67 -67
  395. package/lib/cjs/rpc/core/RpcOperation.js +134 -134
  396. package/lib/cjs/rpc/core/RpcOperation.js.map +1 -1
  397. package/lib/cjs/rpc/core/RpcPendingQueue.d.ts +21 -21
  398. package/lib/cjs/rpc/core/RpcPendingQueue.js +94 -94
  399. package/lib/cjs/rpc/core/RpcPendingQueue.js.map +1 -1
  400. package/lib/cjs/rpc/core/RpcProtocol.d.ts +132 -132
  401. package/lib/cjs/rpc/core/RpcProtocol.js +127 -127
  402. package/lib/cjs/rpc/core/RpcProtocol.js.map +1 -1
  403. package/lib/cjs/rpc/core/RpcPush.d.ts +68 -68
  404. package/lib/cjs/rpc/core/RpcPush.js +127 -127
  405. package/lib/cjs/rpc/core/RpcPush.js.map +1 -1
  406. package/lib/cjs/rpc/core/RpcRegistry.d.ts +48 -48
  407. package/lib/cjs/rpc/core/RpcRegistry.js +198 -198
  408. package/lib/cjs/rpc/core/RpcRegistry.js.map +1 -1
  409. package/lib/cjs/rpc/core/RpcRequest.d.ts +186 -186
  410. package/lib/cjs/rpc/core/RpcRequest.js +478 -478
  411. package/lib/cjs/rpc/core/RpcRequest.js.map +1 -1
  412. package/lib/cjs/rpc/core/RpcRequestContext.d.ts +14 -14
  413. package/lib/cjs/rpc/core/RpcRequestContext.js +2 -2
  414. package/lib/cjs/rpc/core/RpcRequestContext.js.map +1 -1
  415. package/lib/cjs/rpc/core/RpcRoutingToken.d.ts +12 -12
  416. package/lib/cjs/rpc/core/RpcRoutingToken.js +24 -24
  417. package/lib/cjs/rpc/core/RpcRoutingToken.js.map +1 -1
  418. package/lib/cjs/rpc/core/RpcSessionInvocation.d.ts +10 -10
  419. package/lib/cjs/rpc/core/RpcSessionInvocation.js +60 -60
  420. package/lib/cjs/rpc/core/RpcSessionInvocation.js.map +1 -1
  421. package/lib/cjs/rpc/web/BentleyCloudRpcManager.d.ts +46 -46
  422. package/lib/cjs/rpc/web/BentleyCloudRpcManager.js +73 -73
  423. package/lib/cjs/rpc/web/BentleyCloudRpcManager.js.map +1 -1
  424. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.d.ts +33 -33
  425. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.js +141 -141
  426. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.js.map +1 -1
  427. package/lib/cjs/rpc/web/OpenAPI.d.ts +140 -140
  428. package/lib/cjs/rpc/web/OpenAPI.js +60 -60
  429. package/lib/cjs/rpc/web/OpenAPI.js.map +1 -1
  430. package/lib/cjs/rpc/web/RpcMultipart.d.ts +35 -35
  431. package/lib/cjs/rpc/web/RpcMultipart.js +50 -50
  432. package/lib/cjs/rpc/web/RpcMultipart.js.map +1 -1
  433. package/lib/cjs/rpc/web/WebAppRpcLogging.d.ts +28 -28
  434. package/lib/cjs/rpc/web/WebAppRpcLogging.js +140 -140
  435. package/lib/cjs/rpc/web/WebAppRpcLogging.js.map +1 -1
  436. package/lib/cjs/rpc/web/WebAppRpcProtocol.d.ts +89 -89
  437. package/lib/cjs/rpc/web/WebAppRpcProtocol.js +116 -116
  438. package/lib/cjs/rpc/web/WebAppRpcProtocol.js.map +1 -1
  439. package/lib/cjs/rpc/web/WebAppRpcRequest.d.ts +67 -67
  440. package/lib/cjs/rpc/web/WebAppRpcRequest.js +239 -239
  441. package/lib/cjs/rpc/web/WebAppRpcRequest.js.map +1 -1
  442. package/lib/cjs/rpc/web/multipart/RpcMultipartParser.d.ts +32 -32
  443. package/lib/cjs/rpc/web/multipart/RpcMultipartParser.js +373 -373
  444. package/lib/cjs/rpc/web/multipart/RpcMultipartParser.js.map +1 -1
  445. package/lib/cjs/tile/B3dmTileIO.d.ts +19 -19
  446. package/lib/cjs/tile/B3dmTileIO.js +66 -66
  447. package/lib/cjs/tile/B3dmTileIO.js.map +1 -1
  448. package/lib/cjs/tile/CompositeTileIO.d.ts +15 -15
  449. package/lib/cjs/tile/CompositeTileIO.js +26 -26
  450. package/lib/cjs/tile/CompositeTileIO.js.map +1 -1
  451. package/lib/cjs/tile/ElementGraphics.d.ts +145 -145
  452. package/lib/cjs/tile/ElementGraphics.js +9 -9
  453. package/lib/cjs/tile/ElementGraphics.js.map +1 -1
  454. package/lib/cjs/tile/GltfTileIO.d.ts +45 -45
  455. package/lib/cjs/tile/GltfTileIO.js +109 -109
  456. package/lib/cjs/tile/GltfTileIO.js.map +1 -1
  457. package/lib/cjs/tile/I3dmTileIO.d.ts +20 -20
  458. package/lib/cjs/tile/I3dmTileIO.js +40 -40
  459. package/lib/cjs/tile/I3dmTileIO.js.map +1 -1
  460. package/lib/cjs/tile/IModelTileIO.d.ts +75 -75
  461. package/lib/cjs/tile/IModelTileIO.js +95 -95
  462. package/lib/cjs/tile/IModelTileIO.js.map +1 -1
  463. package/lib/cjs/tile/PntsTileIO.d.ts +17 -17
  464. package/lib/cjs/tile/PntsTileIO.js +26 -26
  465. package/lib/cjs/tile/PntsTileIO.js.map +1 -1
  466. package/lib/cjs/tile/TileIO.d.ts +66 -66
  467. package/lib/cjs/tile/TileIO.js +118 -118
  468. package/lib/cjs/tile/TileIO.js.map +1 -1
  469. package/lib/cjs/tile/TileMetadata.d.ts +228 -228
  470. package/lib/cjs/tile/TileMetadata.js +675 -675
  471. package/lib/cjs/tile/TileMetadata.js.map +1 -1
  472. package/lib/cjs/tile/Tileset3dSchema.d.ts +97 -0
  473. package/lib/cjs/tile/Tileset3dSchema.d.ts.map +1 -0
  474. package/lib/cjs/tile/Tileset3dSchema.js +10 -0
  475. package/lib/cjs/tile/Tileset3dSchema.js.map +1 -0
  476. package/lib/esm/AmbientOcclusion.d.ts +49 -49
  477. package/lib/esm/AmbientOcclusion.js +52 -52
  478. package/lib/esm/AmbientOcclusion.js.map +1 -1
  479. package/lib/esm/AnalysisStyle.d.ts +134 -134
  480. package/lib/esm/AnalysisStyle.js +159 -159
  481. package/lib/esm/AnalysisStyle.js.map +1 -1
  482. package/lib/esm/AuthorizationClient.d.ts +17 -17
  483. package/lib/esm/AuthorizationClient.js +8 -8
  484. package/lib/esm/AuthorizationClient.js.map +1 -1
  485. package/lib/esm/BackendTypes.d.ts +12 -12
  486. package/lib/esm/BackendTypes.js +8 -8
  487. package/lib/esm/BackendTypes.js.map +1 -1
  488. package/lib/esm/BackgroundMapProvider.d.ts +51 -51
  489. package/lib/esm/BackgroundMapProvider.js +63 -63
  490. package/lib/esm/BackgroundMapProvider.js.map +1 -1
  491. package/lib/esm/BackgroundMapSettings.d.ts +136 -136
  492. package/lib/esm/BackgroundMapSettings.js +150 -150
  493. package/lib/esm/BackgroundMapSettings.js.map +1 -1
  494. package/lib/esm/Base64EncodedString.d.ts +32 -32
  495. package/lib/esm/Base64EncodedString.js +63 -63
  496. package/lib/esm/Base64EncodedString.js.map +1 -1
  497. package/lib/esm/BlobReader.d.ts +31 -31
  498. package/lib/esm/BlobReader.js +79 -79
  499. package/lib/esm/BlobReader.js.map +1 -1
  500. package/lib/esm/BriefcaseTypes.d.ts +191 -191
  501. package/lib/esm/BriefcaseTypes.js +92 -92
  502. package/lib/esm/BriefcaseTypes.js.map +1 -1
  503. package/lib/esm/Camera.d.ts +42 -42
  504. package/lib/esm/Camera.js +58 -58
  505. package/lib/esm/Camera.js.map +1 -1
  506. package/lib/esm/ChangedElements.d.ts +85 -85
  507. package/lib/esm/ChangedElements.js +20 -20
  508. package/lib/esm/ChangedElements.js.map +1 -1
  509. package/lib/esm/ChangedEntities.d.ts +45 -45
  510. package/lib/esm/ChangedEntities.js +8 -8
  511. package/lib/esm/ChangedEntities.js.map +1 -1
  512. package/lib/esm/ChangesetProps.d.ts +98 -98
  513. package/lib/esm/ChangesetProps.js +19 -19
  514. package/lib/esm/ChangesetProps.js.map +1 -1
  515. package/lib/esm/ClipStyle.d.ts +89 -89
  516. package/lib/esm/ClipStyle.js +116 -116
  517. package/lib/esm/ClipStyle.js.map +1 -1
  518. package/lib/esm/CloudStorage.d.ts +62 -62
  519. package/lib/esm/CloudStorage.js +109 -109
  520. package/lib/esm/CloudStorage.js.map +1 -1
  521. package/lib/esm/CloudStorageTileCache.d.ts +27 -27
  522. package/lib/esm/CloudStorageTileCache.js +61 -61
  523. package/lib/esm/CloudStorageTileCache.js.map +1 -1
  524. package/lib/esm/Code.d.ts +277 -277
  525. package/lib/esm/Code.js +263 -263
  526. package/lib/esm/Code.js.map +1 -1
  527. package/lib/esm/ColorByName.d.ts +161 -161
  528. package/lib/esm/ColorByName.js +166 -166
  529. package/lib/esm/ColorByName.js.map +1 -1
  530. package/lib/esm/ColorDef.d.ts +208 -208
  531. package/lib/esm/ColorDef.js +566 -566
  532. package/lib/esm/ColorDef.js.map +1 -1
  533. package/lib/esm/CommonLoggerCategory.d.ts +18 -18
  534. package/lib/esm/CommonLoggerCategory.js +23 -23
  535. package/lib/esm/CommonLoggerCategory.js.map +1 -1
  536. package/lib/esm/ConcurrentQuery.d.ts +421 -421
  537. package/lib/esm/ConcurrentQuery.js +545 -545
  538. package/lib/esm/ConcurrentQuery.js.map +1 -1
  539. package/lib/esm/ContextRealityModel.d.ts +303 -303
  540. package/lib/esm/ContextRealityModel.js +366 -366
  541. package/lib/esm/ContextRealityModel.js.map +1 -1
  542. package/lib/esm/DisplayStyleSettings.d.ts +588 -588
  543. package/lib/esm/DisplayStyleSettings.js +976 -976
  544. package/lib/esm/DisplayStyleSettings.js.map +1 -1
  545. package/lib/esm/ECSchemaProps.d.ts +39 -39
  546. package/lib/esm/ECSchemaProps.js +8 -8
  547. package/lib/esm/ECSchemaProps.js.map +1 -1
  548. package/lib/esm/ECSqlReader.d.ts +70 -70
  549. package/lib/esm/ECSqlReader.js +275 -275
  550. package/lib/esm/ECSqlReader.js.map +1 -1
  551. package/lib/esm/ECSqlTypes.d.ts +128 -128
  552. package/lib/esm/ECSqlTypes.js +185 -185
  553. package/lib/esm/ECSqlTypes.js.map +1 -1
  554. package/lib/esm/ElementMesh.d.ts +39 -39
  555. package/lib/esm/ElementMesh.js +52 -52
  556. package/lib/esm/ElementMesh.js.map +1 -1
  557. package/lib/esm/ElementProps.d.ts +483 -483
  558. package/lib/esm/ElementProps.js +92 -92
  559. package/lib/esm/ElementProps.js.map +1 -1
  560. package/lib/esm/EmphasizeElementsProps.d.ts +55 -55
  561. package/lib/esm/EmphasizeElementsProps.js +22 -22
  562. package/lib/esm/EmphasizeElementsProps.js.map +1 -1
  563. package/lib/esm/EntityProps.d.ts +177 -177
  564. package/lib/esm/EntityProps.js +108 -108
  565. package/lib/esm/EntityProps.js.map +1 -1
  566. package/lib/esm/EntityReference.d.ts +51 -51
  567. package/lib/esm/EntityReference.js +52 -52
  568. package/lib/esm/EntityReference.js.map +1 -1
  569. package/lib/esm/Environment.d.ts +61 -61
  570. package/lib/esm/Environment.js +66 -66
  571. package/lib/esm/Environment.js.map +1 -1
  572. package/lib/esm/FeatureIndex.d.ts +39 -39
  573. package/lib/esm/FeatureIndex.js +57 -57
  574. package/lib/esm/FeatureIndex.js.map +1 -1
  575. package/lib/esm/FeatureSymbology.d.ts +444 -444
  576. package/lib/esm/FeatureSymbology.js +608 -608
  577. package/lib/esm/FeatureSymbology.js.map +1 -1
  578. package/lib/esm/FeatureTable.d.ts +141 -141
  579. package/lib/esm/FeatureTable.js +272 -272
  580. package/lib/esm/FeatureTable.js.map +1 -1
  581. package/lib/esm/Fonts.d.ts +51 -51
  582. package/lib/esm/Fonts.js +49 -49
  583. package/lib/esm/Fonts.js.map +1 -1
  584. package/lib/esm/Frustum.d.ts +114 -114
  585. package/lib/esm/Frustum.js +288 -288
  586. package/lib/esm/Frustum.js.map +1 -1
  587. package/lib/esm/GeoCoordinateServices.d.ts +119 -119
  588. package/lib/esm/GeoCoordinateServices.js +76 -76
  589. package/lib/esm/GeoCoordinateServices.js.map +1 -1
  590. package/lib/esm/GeometryContainment.d.ts +28 -28
  591. package/lib/esm/GeometryContainment.js +8 -8
  592. package/lib/esm/GeometryContainment.js.map +1 -1
  593. package/lib/esm/GeometryParams.d.ts +130 -130
  594. package/lib/esm/GeometryParams.js +170 -170
  595. package/lib/esm/GeometryParams.js.map +1 -1
  596. package/lib/esm/GeometrySummary.d.ts +45 -45
  597. package/lib/esm/GeometrySummary.js +20 -20
  598. package/lib/esm/GeometrySummary.js.map +1 -1
  599. package/lib/esm/Gradient.d.ts +139 -139
  600. package/lib/esm/Gradient.js +450 -450
  601. package/lib/esm/Gradient.js.map +1 -1
  602. package/lib/esm/GraphicParams.d.ts +58 -58
  603. package/lib/esm/GraphicParams.js +81 -81
  604. package/lib/esm/GraphicParams.js.map +1 -1
  605. package/lib/esm/GroundPlane.d.ts +52 -52
  606. package/lib/esm/GroundPlane.js +59 -59
  607. package/lib/esm/GroundPlane.js.map +1 -1
  608. package/lib/esm/HSLColor.d.ts +20 -20
  609. package/lib/esm/HSLColor.js +28 -28
  610. package/lib/esm/HSLColor.js.map +1 -1
  611. package/lib/esm/HSVColor.d.ts +30 -30
  612. package/lib/esm/HSVColor.js +55 -55
  613. package/lib/esm/HSVColor.js.map +1 -1
  614. package/lib/esm/HiddenLine.d.ts +97 -97
  615. package/lib/esm/HiddenLine.js +157 -157
  616. package/lib/esm/HiddenLine.js.map +1 -1
  617. package/lib/esm/Hilite.d.ts +50 -50
  618. package/lib/esm/Hilite.js +61 -61
  619. package/lib/esm/Hilite.js.map +1 -1
  620. package/lib/esm/IModel.d.ts +358 -358
  621. package/lib/esm/IModel.js +342 -342
  622. package/lib/esm/IModel.js.map +1 -1
  623. package/lib/esm/IModelError.d.ts +42 -42
  624. package/lib/esm/IModelError.js +56 -56
  625. package/lib/esm/IModelError.js.map +1 -1
  626. package/lib/esm/IModelVersion.d.ts +68 -68
  627. package/lib/esm/IModelVersion.js +75 -75
  628. package/lib/esm/IModelVersion.js.map +1 -1
  629. package/lib/esm/Image.d.ts +86 -86
  630. package/lib/esm/Image.js +120 -120
  631. package/lib/esm/Image.js.map +1 -1
  632. package/lib/esm/IpcAppProps.d.ts +141 -141
  633. package/lib/esm/IpcAppProps.js +19 -19
  634. package/lib/esm/IpcAppProps.js.map +1 -1
  635. package/lib/esm/LightSettings.d.ts +224 -224
  636. package/lib/esm/LightSettings.js +296 -296
  637. package/lib/esm/LightSettings.js.map +1 -1
  638. package/lib/esm/LinePixels.d.ts +34 -34
  639. package/lib/esm/LinePixels.js +39 -39
  640. package/lib/esm/LinePixels.js.map +1 -1
  641. package/lib/esm/Localization.d.ts +113 -113
  642. package/lib/esm/Localization.js +29 -29
  643. package/lib/esm/Localization.js.map +1 -1
  644. package/lib/esm/MapImagerySettings.d.ts +62 -62
  645. package/lib/esm/MapImagerySettings.js +76 -76
  646. package/lib/esm/MapImagerySettings.js.map +1 -1
  647. package/lib/esm/MapLayerSettings.d.ts +272 -272
  648. package/lib/esm/MapLayerSettings.js +399 -399
  649. package/lib/esm/MapLayerSettings.js.map +1 -1
  650. package/lib/esm/MassProperties.d.ts +64 -64
  651. package/lib/esm/MassProperties.js +20 -20
  652. package/lib/esm/MassProperties.js.map +1 -1
  653. package/lib/esm/MaterialProps.d.ts +153 -153
  654. package/lib/esm/MaterialProps.js +32 -32
  655. package/lib/esm/MaterialProps.js.map +1 -1
  656. package/lib/esm/ModelClipGroup.d.ts +67 -67
  657. package/lib/esm/ModelClipGroup.js +91 -91
  658. package/lib/esm/ModelClipGroup.js.map +1 -1
  659. package/lib/esm/ModelGeometryChanges.d.ts +107 -107
  660. package/lib/esm/ModelGeometryChanges.js +80 -80
  661. package/lib/esm/ModelGeometryChanges.js.map +1 -1
  662. package/lib/esm/ModelProps.d.ts +67 -67
  663. package/lib/esm/ModelProps.js +8 -8
  664. package/lib/esm/ModelProps.js.map +1 -1
  665. package/lib/esm/NativeAppProps.d.ts +122 -122
  666. package/lib/esm/NativeAppProps.js +27 -27
  667. package/lib/esm/NativeAppProps.js.map +1 -1
  668. package/lib/esm/OctEncodedNormal.d.ts +33 -33
  669. package/lib/esm/OctEncodedNormal.js +93 -93
  670. package/lib/esm/OctEncodedNormal.js.map +1 -1
  671. package/lib/esm/PlanProjectionSettings.d.ts +47 -47
  672. package/lib/esm/PlanProjectionSettings.js +59 -59
  673. package/lib/esm/PlanProjectionSettings.js.map +1 -1
  674. package/lib/esm/PlanarClipMask.d.ts +177 -177
  675. package/lib/esm/PlanarClipMask.js +132 -132
  676. package/lib/esm/PlanarClipMask.js.map +1 -1
  677. package/lib/esm/QPoint.d.ts +479 -479
  678. package/lib/esm/QPoint.js +813 -813
  679. package/lib/esm/QPoint.js.map +1 -1
  680. package/lib/esm/RealityDataAccessProps.d.ts +41 -41
  681. package/lib/esm/RealityDataAccessProps.js +16 -16
  682. package/lib/esm/RealityDataAccessProps.js.map +1 -1
  683. package/lib/esm/RealityModelDisplaySettings.d.ts +183 -183
  684. package/lib/esm/RealityModelDisplaySettings.js +136 -136
  685. package/lib/esm/RealityModelDisplaySettings.js.map +1 -1
  686. package/lib/esm/Render.d.ts +89 -89
  687. package/lib/esm/Render.js +165 -165
  688. package/lib/esm/Render.js.map +1 -1
  689. package/lib/esm/RenderMaterial.d.ts +58 -58
  690. package/lib/esm/RenderMaterial.js +71 -71
  691. package/lib/esm/RenderMaterial.js.map +1 -1
  692. package/lib/esm/RenderSchedule.d.ts +543 -543
  693. package/lib/esm/RenderSchedule.js +989 -989
  694. package/lib/esm/RenderTexture.d.ts +70 -70
  695. package/lib/esm/RenderTexture.js +55 -55
  696. package/lib/esm/RenderTexture.js.map +1 -1
  697. package/lib/esm/RgbColor.d.ts +47 -47
  698. package/lib/esm/RgbColor.js +73 -73
  699. package/lib/esm/RgbColor.js.map +1 -1
  700. package/lib/esm/RpcInterface.d.ts +33 -33
  701. package/lib/esm/RpcInterface.js +133 -133
  702. package/lib/esm/RpcInterface.js.map +1 -1
  703. package/lib/esm/RpcManager.d.ts +40 -40
  704. package/lib/esm/RpcManager.js +51 -51
  705. package/lib/esm/RpcManager.js.map +1 -1
  706. package/lib/esm/SessionProps.d.ts +16 -16
  707. package/lib/esm/SessionProps.js +8 -8
  708. package/lib/esm/SessionProps.js.map +1 -1
  709. package/lib/esm/SkyBox.d.ts +215 -215
  710. package/lib/esm/SkyBox.js +202 -202
  711. package/lib/esm/SkyBox.js.map +1 -1
  712. package/lib/esm/Snapping.d.ts +49 -49
  713. package/lib/esm/Snapping.js +8 -8
  714. package/lib/esm/Snapping.js.map +1 -1
  715. package/lib/esm/SolarCalculate.d.ts +27 -27
  716. package/lib/esm/SolarCalculate.js +204 -204
  717. package/lib/esm/SolarCalculate.js.map +1 -1
  718. package/lib/esm/SolarShadows.d.ts +35 -35
  719. package/lib/esm/SolarShadows.js +57 -57
  720. package/lib/esm/SolarShadows.js.map +1 -1
  721. package/lib/esm/SpatialClassification.d.ts +208 -208
  722. package/lib/esm/SpatialClassification.js +333 -333
  723. package/lib/esm/SpatialClassification.js.map +1 -1
  724. package/lib/esm/SubCategoryAppearance.d.ts +91 -91
  725. package/lib/esm/SubCategoryAppearance.js +92 -92
  726. package/lib/esm/SubCategoryAppearance.js.map +1 -1
  727. package/lib/esm/SubCategoryOverride.d.ts +46 -46
  728. package/lib/esm/SubCategoryOverride.js +100 -100
  729. package/lib/esm/SubCategoryOverride.js.map +1 -1
  730. package/lib/esm/TerrainSettings.d.ts +82 -82
  731. package/lib/esm/TerrainSettings.js +96 -96
  732. package/lib/esm/TerrainSettings.js.map +1 -1
  733. package/lib/esm/TextureMapping.d.ts +118 -118
  734. package/lib/esm/TextureMapping.js +169 -169
  735. package/lib/esm/TextureMapping.js.map +1 -1
  736. package/lib/esm/TextureProps.d.ts +65 -65
  737. package/lib/esm/TextureProps.js +25 -25
  738. package/lib/esm/TextureProps.js.map +1 -1
  739. package/lib/esm/ThematicDisplay.d.ts +230 -230
  740. package/lib/esm/ThematicDisplay.js +336 -336
  741. package/lib/esm/ThematicDisplay.js.map +1 -1
  742. package/lib/esm/Thumbnail.d.ts +26 -26
  743. package/lib/esm/Thumbnail.js +8 -8
  744. package/lib/esm/Thumbnail.js.map +1 -1
  745. package/lib/esm/TileProps.d.ts +82 -82
  746. package/lib/esm/TileProps.js +25 -25
  747. package/lib/esm/TileProps.js.map +1 -1
  748. package/lib/esm/Tween.d.ts +191 -191
  749. package/lib/esm/Tween.js +565 -565
  750. package/lib/esm/Tween.js.map +1 -1
  751. package/lib/esm/TxnAction.d.ts +21 -21
  752. package/lib/esm/TxnAction.js +26 -26
  753. package/lib/esm/TxnAction.js.map +1 -1
  754. package/lib/esm/ViewDetails.d.ts +125 -125
  755. package/lib/esm/ViewDetails.js +161 -161
  756. package/lib/esm/ViewDetails.js.map +1 -1
  757. package/lib/esm/ViewFlags.d.ts +287 -287
  758. package/lib/esm/ViewFlags.js +363 -363
  759. package/lib/esm/ViewFlags.js.map +1 -1
  760. package/lib/esm/ViewProps.d.ts +205 -205
  761. package/lib/esm/ViewProps.js +8 -8
  762. package/lib/esm/ViewProps.js.map +1 -1
  763. package/lib/esm/WhiteOnWhiteReversalSettings.d.ts +36 -36
  764. package/lib/esm/WhiteOnWhiteReversalSettings.js +33 -33
  765. package/lib/esm/WhiteOnWhiteReversalSettings.js.map +1 -1
  766. package/lib/esm/core-common.d.ts +245 -244
  767. package/lib/esm/core-common.d.ts.map +1 -1
  768. package/lib/esm/core-common.js +249 -248
  769. package/lib/esm/core-common.js.map +1 -1
  770. package/lib/esm/domains/FunctionalElementProps.d.ts +11 -11
  771. package/lib/esm/domains/FunctionalElementProps.js +8 -8
  772. package/lib/esm/domains/FunctionalElementProps.js.map +1 -1
  773. package/lib/esm/domains/GenericElementProps.d.ts +18 -18
  774. package/lib/esm/domains/GenericElementProps.js +8 -8
  775. package/lib/esm/domains/GenericElementProps.js.map +1 -1
  776. package/lib/esm/geometry/AdditionalTransform.d.ts +84 -84
  777. package/lib/esm/geometry/AdditionalTransform.js +80 -80
  778. package/lib/esm/geometry/AdditionalTransform.js.map +1 -1
  779. package/lib/esm/geometry/AreaPattern.d.ts +82 -82
  780. package/lib/esm/geometry/AreaPattern.js +200 -200
  781. package/lib/esm/geometry/AreaPattern.js.map +1 -1
  782. package/lib/esm/geometry/BoundingSphere.d.ts +27 -27
  783. package/lib/esm/geometry/BoundingSphere.js +40 -40
  784. package/lib/esm/geometry/BoundingSphere.js.map +1 -1
  785. package/lib/esm/geometry/Cartographic.d.ts +137 -137
  786. package/lib/esm/geometry/Cartographic.js +340 -340
  787. package/lib/esm/geometry/Cartographic.js.map +1 -1
  788. package/lib/esm/geometry/CoordinateReferenceSystem.d.ts +269 -269
  789. package/lib/esm/geometry/CoordinateReferenceSystem.js +253 -253
  790. package/lib/esm/geometry/CoordinateReferenceSystem.js.map +1 -1
  791. package/lib/esm/geometry/ElementGeometry.d.ts +402 -402
  792. package/lib/esm/geometry/ElementGeometry.js +1716 -1716
  793. package/lib/esm/geometry/ElementGeometry.js.map +1 -1
  794. package/lib/esm/geometry/ElementGeometryFB.d.ts +2372 -2372
  795. package/lib/esm/geometry/ElementGeometryFB.js +3811 -3811
  796. package/lib/esm/geometry/ElementGeometryFB.js.map +1 -1
  797. package/lib/esm/geometry/FrustumPlanes.d.ts +81 -81
  798. package/lib/esm/geometry/FrustumPlanes.js +185 -185
  799. package/lib/esm/geometry/FrustumPlanes.js.map +1 -1
  800. package/lib/esm/geometry/GeodeticDatum.d.ts +409 -409
  801. package/lib/esm/geometry/GeodeticDatum.js +389 -389
  802. package/lib/esm/geometry/GeodeticDatum.js.map +1 -1
  803. package/lib/esm/geometry/GeodeticEllipsoid.d.ts +72 -72
  804. package/lib/esm/geometry/GeodeticEllipsoid.js +67 -67
  805. package/lib/esm/geometry/GeodeticEllipsoid.js.map +1 -1
  806. package/lib/esm/geometry/GeometryStream.d.ts +347 -347
  807. package/lib/esm/geometry/GeometryStream.js +463 -463
  808. package/lib/esm/geometry/GeometryStream.js.map +1 -1
  809. package/lib/esm/geometry/ImageGraphic.d.ts +74 -74
  810. package/lib/esm/geometry/ImageGraphic.js +93 -93
  811. package/lib/esm/geometry/ImageGraphic.js.map +1 -1
  812. package/lib/esm/geometry/LineStyle.d.ts +71 -71
  813. package/lib/esm/geometry/LineStyle.js +126 -126
  814. package/lib/esm/geometry/LineStyle.js.map +1 -1
  815. package/lib/esm/geometry/Placement.d.ts +95 -95
  816. package/lib/esm/geometry/Placement.js +126 -126
  817. package/lib/esm/geometry/Placement.js.map +1 -1
  818. package/lib/esm/geometry/Projection.d.ts +251 -251
  819. package/lib/esm/geometry/Projection.js +192 -192
  820. package/lib/esm/geometry/Projection.js.map +1 -1
  821. package/lib/esm/geometry/TextString.d.ts +55 -55
  822. package/lib/esm/geometry/TextString.js +61 -61
  823. package/lib/esm/geometry/TextString.js.map +1 -1
  824. package/lib/esm/ipc/IpcSession.d.ts +23 -23
  825. package/lib/esm/ipc/IpcSession.js +23 -23
  826. package/lib/esm/ipc/IpcSession.js.map +1 -1
  827. package/lib/esm/ipc/IpcSocket.d.ts +96 -96
  828. package/lib/esm/ipc/IpcSocket.js +12 -12
  829. package/lib/esm/ipc/IpcSocket.js.map +1 -1
  830. package/lib/esm/ipc/IpcWebSocket.d.ts +61 -61
  831. package/lib/esm/ipc/IpcWebSocket.js +144 -144
  832. package/lib/esm/ipc/IpcWebSocket.js.map +1 -1
  833. package/lib/esm/ipc/IpcWebSocketTransport.d.ts +15 -15
  834. package/lib/esm/ipc/IpcWebSocketTransport.js +156 -156
  835. package/lib/esm/ipc/IpcWebSocketTransport.js.map +1 -1
  836. package/lib/esm/rpc/DevToolsRpcInterface.d.ts +32 -32
  837. package/lib/esm/rpc/DevToolsRpcInterface.js +48 -48
  838. package/lib/esm/rpc/DevToolsRpcInterface.js.map +1 -1
  839. package/lib/esm/rpc/IModelReadRpcInterface.d.ts +99 -99
  840. package/lib/esm/rpc/IModelReadRpcInterface.js +117 -117
  841. package/lib/esm/rpc/IModelReadRpcInterface.js.map +1 -1
  842. package/lib/esm/rpc/IModelTileRpcInterface.d.ts +61 -61
  843. package/lib/esm/rpc/IModelTileRpcInterface.js +92 -92
  844. package/lib/esm/rpc/IModelTileRpcInterface.js.map +1 -1
  845. package/lib/esm/rpc/SnapshotIModelRpcInterface.d.ts +23 -23
  846. package/lib/esm/rpc/SnapshotIModelRpcInterface.js +44 -44
  847. package/lib/esm/rpc/SnapshotIModelRpcInterface.js.map +1 -1
  848. package/lib/esm/rpc/TestRpcManager.d.ts +20 -20
  849. package/lib/esm/rpc/TestRpcManager.js +36 -36
  850. package/lib/esm/rpc/TestRpcManager.js.map +1 -1
  851. package/lib/esm/rpc/WipRpcInterface.d.ts +29 -29
  852. package/lib/esm/rpc/WipRpcInterface.js +36 -36
  853. package/lib/esm/rpc/WipRpcInterface.js.map +1 -1
  854. package/lib/esm/rpc/core/RpcConfiguration.d.ts +111 -111
  855. package/lib/esm/rpc/core/RpcConfiguration.js +184 -184
  856. package/lib/esm/rpc/core/RpcConfiguration.js.map +1 -1
  857. package/lib/esm/rpc/core/RpcConstants.d.ts +90 -90
  858. package/lib/esm/rpc/core/RpcConstants.js +106 -106
  859. package/lib/esm/rpc/core/RpcConstants.js.map +1 -1
  860. package/lib/esm/rpc/core/RpcControl.d.ts +54 -54
  861. package/lib/esm/rpc/core/RpcControl.js +138 -138
  862. package/lib/esm/rpc/core/RpcControl.js.map +1 -1
  863. package/lib/esm/rpc/core/RpcInvocation.d.ts +89 -89
  864. package/lib/esm/rpc/core/RpcInvocation.js +252 -252
  865. package/lib/esm/rpc/core/RpcInvocation.js.map +1 -1
  866. package/lib/esm/rpc/core/RpcMarshaling.d.ts +35 -35
  867. package/lib/esm/rpc/core/RpcMarshaling.js +152 -152
  868. package/lib/esm/rpc/core/RpcMarshaling.js.map +1 -1
  869. package/lib/esm/rpc/core/RpcOperation.d.ts +67 -67
  870. package/lib/esm/rpc/core/RpcOperation.js +129 -129
  871. package/lib/esm/rpc/core/RpcOperation.js.map +1 -1
  872. package/lib/esm/rpc/core/RpcPendingQueue.d.ts +21 -21
  873. package/lib/esm/rpc/core/RpcPendingQueue.js +90 -90
  874. package/lib/esm/rpc/core/RpcPendingQueue.js.map +1 -1
  875. package/lib/esm/rpc/core/RpcProtocol.d.ts +132 -132
  876. package/lib/esm/rpc/core/RpcProtocol.js +123 -123
  877. package/lib/esm/rpc/core/RpcProtocol.js.map +1 -1
  878. package/lib/esm/rpc/core/RpcPush.d.ts +68 -68
  879. package/lib/esm/rpc/core/RpcPush.js +119 -119
  880. package/lib/esm/rpc/core/RpcPush.js.map +1 -1
  881. package/lib/esm/rpc/core/RpcRegistry.d.ts +48 -48
  882. package/lib/esm/rpc/core/RpcRegistry.js +194 -194
  883. package/lib/esm/rpc/core/RpcRegistry.js.map +1 -1
  884. package/lib/esm/rpc/core/RpcRequest.d.ts +186 -186
  885. package/lib/esm/rpc/core/RpcRequest.js +473 -473
  886. package/lib/esm/rpc/core/RpcRequest.js.map +1 -1
  887. package/lib/esm/rpc/core/RpcRequestContext.d.ts +14 -14
  888. package/lib/esm/rpc/core/RpcRequestContext.js +1 -1
  889. package/lib/esm/rpc/core/RpcRequestContext.js.map +1 -1
  890. package/lib/esm/rpc/core/RpcRoutingToken.d.ts +12 -12
  891. package/lib/esm/rpc/core/RpcRoutingToken.js +20 -20
  892. package/lib/esm/rpc/core/RpcRoutingToken.js.map +1 -1
  893. package/lib/esm/rpc/core/RpcSessionInvocation.d.ts +10 -10
  894. package/lib/esm/rpc/core/RpcSessionInvocation.js +56 -56
  895. package/lib/esm/rpc/core/RpcSessionInvocation.js.map +1 -1
  896. package/lib/esm/rpc/web/BentleyCloudRpcManager.d.ts +46 -46
  897. package/lib/esm/rpc/web/BentleyCloudRpcManager.js +68 -68
  898. package/lib/esm/rpc/web/BentleyCloudRpcManager.js.map +1 -1
  899. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.d.ts +33 -33
  900. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.js +137 -137
  901. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.js.map +1 -1
  902. package/lib/esm/rpc/web/OpenAPI.d.ts +140 -140
  903. package/lib/esm/rpc/web/OpenAPI.js +56 -56
  904. package/lib/esm/rpc/web/OpenAPI.js.map +1 -1
  905. package/lib/esm/rpc/web/RpcMultipart.d.ts +35 -35
  906. package/lib/esm/rpc/web/RpcMultipart.js +46 -46
  907. package/lib/esm/rpc/web/RpcMultipart.js.map +1 -1
  908. package/lib/esm/rpc/web/WebAppRpcLogging.d.ts +28 -28
  909. package/lib/esm/rpc/web/WebAppRpcLogging.js +136 -136
  910. package/lib/esm/rpc/web/WebAppRpcLogging.js.map +1 -1
  911. package/lib/esm/rpc/web/WebAppRpcProtocol.d.ts +89 -89
  912. package/lib/esm/rpc/web/WebAppRpcProtocol.js +112 -112
  913. package/lib/esm/rpc/web/WebAppRpcProtocol.js.map +1 -1
  914. package/lib/esm/rpc/web/WebAppRpcRequest.d.ts +67 -67
  915. package/lib/esm/rpc/web/WebAppRpcRequest.js +235 -235
  916. package/lib/esm/rpc/web/WebAppRpcRequest.js.map +1 -1
  917. package/lib/esm/rpc/web/multipart/RpcMultipartParser.d.ts +32 -32
  918. package/lib/esm/rpc/web/multipart/RpcMultipartParser.js +369 -369
  919. package/lib/esm/rpc/web/multipart/RpcMultipartParser.js.map +1 -1
  920. package/lib/esm/tile/B3dmTileIO.d.ts +19 -19
  921. package/lib/esm/tile/B3dmTileIO.js +62 -62
  922. package/lib/esm/tile/B3dmTileIO.js.map +1 -1
  923. package/lib/esm/tile/CompositeTileIO.d.ts +15 -15
  924. package/lib/esm/tile/CompositeTileIO.js +22 -22
  925. package/lib/esm/tile/CompositeTileIO.js.map +1 -1
  926. package/lib/esm/tile/ElementGraphics.d.ts +145 -145
  927. package/lib/esm/tile/ElementGraphics.js +8 -8
  928. package/lib/esm/tile/ElementGraphics.js.map +1 -1
  929. package/lib/esm/tile/GltfTileIO.d.ts +45 -45
  930. package/lib/esm/tile/GltfTileIO.js +105 -105
  931. package/lib/esm/tile/GltfTileIO.js.map +1 -1
  932. package/lib/esm/tile/I3dmTileIO.d.ts +20 -20
  933. package/lib/esm/tile/I3dmTileIO.js +36 -36
  934. package/lib/esm/tile/I3dmTileIO.js.map +1 -1
  935. package/lib/esm/tile/IModelTileIO.d.ts +75 -75
  936. package/lib/esm/tile/IModelTileIO.js +90 -90
  937. package/lib/esm/tile/IModelTileIO.js.map +1 -1
  938. package/lib/esm/tile/PntsTileIO.d.ts +17 -17
  939. package/lib/esm/tile/PntsTileIO.js +22 -22
  940. package/lib/esm/tile/PntsTileIO.js.map +1 -1
  941. package/lib/esm/tile/TileIO.d.ts +66 -66
  942. package/lib/esm/tile/TileIO.js +110 -110
  943. package/lib/esm/tile/TileIO.js.map +1 -1
  944. package/lib/esm/tile/TileMetadata.d.ts +228 -228
  945. package/lib/esm/tile/TileMetadata.js +660 -660
  946. package/lib/esm/tile/TileMetadata.js.map +1 -1
  947. package/lib/esm/tile/Tileset3dSchema.d.ts +97 -0
  948. package/lib/esm/tile/Tileset3dSchema.d.ts.map +1 -0
  949. package/lib/esm/tile/Tileset3dSchema.js +9 -0
  950. package/lib/esm/tile/Tileset3dSchema.js.map +1 -0
  951. package/package.json +8 -8
@@ -1,82 +1,82 @@
1
- /** @packageDocumentation
2
- * @module Geometry
3
- */
4
- import { ClipPlane, Point3d, Vector3d } from "@itwin/core-geometry";
5
- import { Frustum } from "../Frustum";
6
- import { BoundingSphere } from "./BoundingSphere";
7
- /** Represents a the planes of a [[Frustum]] for testing containment and intersection.
8
- * A valid frustum produces six planes. A degenerate frustum produces zero planes.
9
- * @public
10
- * @extensions
11
- */
12
- export declare class FrustumPlanes {
13
- private _planes;
14
- private constructor();
15
- /** Compute the six planes of the specified frustum.
16
- * If the frustum is degenerate - that is, its points do not represent a truncated pyramid - then the returned `FrustumPlanes` will contain zero planes.
17
- * @see [[isValid]] to test this condition.
18
- */
19
- static fromFrustum(frustum: Frustum): FrustumPlanes;
20
- /** Create an empty set of frustum planes. [[isValid]] will be `true`. This can be useful when you want to create a `FrustumPlanes` object and initialize it later via [[init]] -
21
- * for example, if you intend to use the same object repeatedly with different [[Frustum]]s.
22
- */
23
- static createEmpty(): FrustumPlanes;
24
- /** Returns true if [[planes]] consists of six planes. This may return `false` if a degenerate [[Frustum]] was supplied to [[fromFrustum]], or if this object was created
25
- * via [[createEmpty]] - in either case, [[planes]] will be an empty array.
26
- */
27
- get isValid(): boolean;
28
- /** Obtain the list of planes defining the frustum. If [[isValid]] is `true`, it will have a length of six, with the planes ordered as
29
- * right, left, top, bottom, back, front. Otherwise, it will be empty.
30
- */
31
- get planes(): ClipPlane[];
32
- /** Recompute the planes from the specified frustum.
33
- * @returns true upon success, or false if the input frustum was degenerate, in which case [[isValid]] will be `false`.
34
- */
35
- init(frustum: Frustum): boolean;
36
- /** Compute to what degree a [[Frustum]] is contained with these frustum planes.
37
- * @param box The frustum to test for containment.
38
- * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.
39
- * @returns the degree to which `box` is contained within the clipping planes.
40
- */
41
- computeFrustumContainment(box: Frustum, sphere?: BoundingSphere): FrustumPlanes.Containment;
42
- /** Determines whether a [[Frustum]] intersects with or is fully contained within these frustum planes.
43
- * @param box The frustum to test for containment.
44
- * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.
45
- * @returns true if `box` is not entirely outside of the clipping planes.
46
- */
47
- intersectsFrustum(box: Frustum, sphere?: BoundingSphere): boolean;
48
- /** Determines whether a point is contained within these frustum planes.
49
- * @param point The point to test for containment.
50
- * @param tolerance The maximum distance from the interior of the frustum planes that will still be considered "contained".
51
- * @returns true if `point` is no further than `tolerance` meters outside of the clipping planes.
52
- */
53
- containsPoint(point: Point3d, tolerance?: number): boolean;
54
- /** Compute the degree to which a set of points is contained within these frustum planes.
55
- * @param points The points to test for containment.
56
- * @param sphere An optional spherical bounding volume fully containing all of the points. If supplied, this can reduce the amount of computation required.
57
- * @param tolerance The maximum distance from the interior of the frustum planes a point must be to be considered "contained".
58
- * @returns the degree to which all of the points are contained within the clipping planes.
59
- */
60
- computeContainment(points: Point3d[], sphere?: BoundingSphere, tolerance?: number): FrustumPlanes.Containment;
61
- /** Computes whether a ray intersects these clipping planes.
62
- * @param origin The origin of the ray.
63
- * @param direction The direction of the ray.
64
- * @returns true if the ray extending from `origin` in the specified `direction` intersects at least one of the clipping planes.
65
- */
66
- intersectsRay(origin: Point3d, direction: Vector3d): boolean;
67
- }
68
- /** @public @extensions */
69
- export declare namespace FrustumPlanes {
70
- /** Describes the degree to which an object is contained within the planes of a [[Frustum]].
71
- * @see [[FrustumPlanes.computeContainment]], for example.
72
- */
73
- enum Containment {
74
- /** The object is entirely outside of the frustum, intersecting none of its planes. */
75
- Outside = 0,
76
- /** The object intersects at least one of the frustum planes. placing it partially inside of the frustum. */
77
- Partial = 1,
78
- /** The object is entirely inside of the frustum, intersecting none of its planes. */
79
- Inside = 2
80
- }
81
- }
1
+ /** @packageDocumentation
2
+ * @module Geometry
3
+ */
4
+ import { ClipPlane, Point3d, Vector3d } from "@itwin/core-geometry";
5
+ import { Frustum } from "../Frustum";
6
+ import { BoundingSphere } from "./BoundingSphere";
7
+ /** Represents a the planes of a [[Frustum]] for testing containment and intersection.
8
+ * A valid frustum produces six planes. A degenerate frustum produces zero planes.
9
+ * @public
10
+ * @extensions
11
+ */
12
+ export declare class FrustumPlanes {
13
+ private _planes;
14
+ private constructor();
15
+ /** Compute the six planes of the specified frustum.
16
+ * If the frustum is degenerate - that is, its points do not represent a truncated pyramid - then the returned `FrustumPlanes` will contain zero planes.
17
+ * @see [[isValid]] to test this condition.
18
+ */
19
+ static fromFrustum(frustum: Frustum): FrustumPlanes;
20
+ /** Create an empty set of frustum planes. [[isValid]] will be `true`. This can be useful when you want to create a `FrustumPlanes` object and initialize it later via [[init]] -
21
+ * for example, if you intend to use the same object repeatedly with different [[Frustum]]s.
22
+ */
23
+ static createEmpty(): FrustumPlanes;
24
+ /** Returns true if [[planes]] consists of six planes. This may return `false` if a degenerate [[Frustum]] was supplied to [[fromFrustum]], or if this object was created
25
+ * via [[createEmpty]] - in either case, [[planes]] will be an empty array.
26
+ */
27
+ get isValid(): boolean;
28
+ /** Obtain the list of planes defining the frustum. If [[isValid]] is `true`, it will have a length of six, with the planes ordered as
29
+ * right, left, top, bottom, back, front. Otherwise, it will be empty.
30
+ */
31
+ get planes(): ClipPlane[];
32
+ /** Recompute the planes from the specified frustum.
33
+ * @returns true upon success, or false if the input frustum was degenerate, in which case [[isValid]] will be `false`.
34
+ */
35
+ init(frustum: Frustum): boolean;
36
+ /** Compute to what degree a [[Frustum]] is contained with these frustum planes.
37
+ * @param box The frustum to test for containment.
38
+ * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.
39
+ * @returns the degree to which `box` is contained within the clipping planes.
40
+ */
41
+ computeFrustumContainment(box: Frustum, sphere?: BoundingSphere): FrustumPlanes.Containment;
42
+ /** Determines whether a [[Frustum]] intersects with or is fully contained within these frustum planes.
43
+ * @param box The frustum to test for containment.
44
+ * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.
45
+ * @returns true if `box` is not entirely outside of the clipping planes.
46
+ */
47
+ intersectsFrustum(box: Frustum, sphere?: BoundingSphere): boolean;
48
+ /** Determines whether a point is contained within these frustum planes.
49
+ * @param point The point to test for containment.
50
+ * @param tolerance The maximum distance from the interior of the frustum planes that will still be considered "contained".
51
+ * @returns true if `point` is no further than `tolerance` meters outside of the clipping planes.
52
+ */
53
+ containsPoint(point: Point3d, tolerance?: number): boolean;
54
+ /** Compute the degree to which a set of points is contained within these frustum planes.
55
+ * @param points The points to test for containment.
56
+ * @param sphere An optional spherical bounding volume fully containing all of the points. If supplied, this can reduce the amount of computation required.
57
+ * @param tolerance The maximum distance from the interior of the frustum planes a point must be to be considered "contained".
58
+ * @returns the degree to which all of the points are contained within the clipping planes.
59
+ */
60
+ computeContainment(points: Point3d[], sphere?: BoundingSphere, tolerance?: number): FrustumPlanes.Containment;
61
+ /** Computes whether a ray intersects these clipping planes.
62
+ * @param origin The origin of the ray.
63
+ * @param direction The direction of the ray.
64
+ * @returns true if the ray extending from `origin` in the specified `direction` intersects at least one of the clipping planes.
65
+ */
66
+ intersectsRay(origin: Point3d, direction: Vector3d): boolean;
67
+ }
68
+ /** @public @extensions */
69
+ export declare namespace FrustumPlanes {
70
+ /** Describes the degree to which an object is contained within the planes of a [[Frustum]].
71
+ * @see [[FrustumPlanes.computeContainment]], for example.
72
+ */
73
+ enum Containment {
74
+ /** The object is entirely outside of the frustum, intersecting none of its planes. */
75
+ Outside = 0,
76
+ /** The object intersects at least one of the frustum planes. placing it partially inside of the frustum. */
77
+ Partial = 1,
78
+ /** The object is entirely inside of the frustum, intersecting none of its planes. */
79
+ Inside = 2
80
+ }
81
+ }
82
82
  //# sourceMappingURL=FrustumPlanes.d.ts.map
@@ -1,186 +1,186 @@
1
- /*---------------------------------------------------------------------------------------------
2
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
- * See LICENSE.md in the project root for license terms and full copyright notice.
4
- *--------------------------------------------------------------------------------------------*/
5
- /** @packageDocumentation
6
- * @module Geometry
7
- */
8
- import { ClipPlane, Vector3d } from "@itwin/core-geometry";
9
- const planePointIndices = [
10
- [1, 3, 5],
11
- [0, 4, 2],
12
- [2, 6, 3],
13
- [0, 1, 4],
14
- [0, 2, 1],
15
- [4, 5, 6], // front
16
- ];
17
- function computeFrustumPlanes(frustum) {
18
- const planes = [];
19
- const points = frustum.points;
20
- const expandPlaneDistance = 1e-6;
21
- for (const indices of planePointIndices) {
22
- const i0 = indices[0], i1 = indices[1], i2 = indices[2];
23
- const normal = Vector3d.createCrossProductToPoints(points[i2], points[i1], points[i0]);
24
- normal.normalizeInPlace();
25
- const plane = ClipPlane.createNormalAndDistance(normal, normal.dotProduct(points[i0]) - expandPlaneDistance);
26
- if (!plane)
27
- return [];
28
- planes.push(plane);
29
- }
30
- return planes;
31
- }
32
- // Scratch variable used by FrustumPlanes.computeContainment.
33
- const planesContainingSphere = [false, false, false, false, false, false];
34
- /** Represents a the planes of a [[Frustum]] for testing containment and intersection.
35
- * A valid frustum produces six planes. A degenerate frustum produces zero planes.
36
- * @public
37
- * @extensions
38
- */
39
- export class FrustumPlanes {
40
- constructor(planes) {
41
- this._planes = planes;
42
- }
43
- /** Compute the six planes of the specified frustum.
44
- * If the frustum is degenerate - that is, its points do not represent a truncated pyramid - then the returned `FrustumPlanes` will contain zero planes.
45
- * @see [[isValid]] to test this condition.
46
- */
47
- static fromFrustum(frustum) {
48
- const planes = computeFrustumPlanes(frustum);
49
- return new FrustumPlanes(planes);
50
- }
51
- /** Create an empty set of frustum planes. [[isValid]] will be `true`. This can be useful when you want to create a `FrustumPlanes` object and initialize it later via [[init]] -
52
- * for example, if you intend to use the same object repeatedly with different [[Frustum]]s.
53
- */
54
- static createEmpty() {
55
- return new FrustumPlanes([]);
56
- }
57
- /** Returns true if [[planes]] consists of six planes. This may return `false` if a degenerate [[Frustum]] was supplied to [[fromFrustum]], or if this object was created
58
- * via [[createEmpty]] - in either case, [[planes]] will be an empty array.
59
- */
60
- get isValid() {
61
- return this._planes.length === 6;
62
- }
63
- /** Obtain the list of planes defining the frustum. If [[isValid]] is `true`, it will have a length of six, with the planes ordered as
64
- * right, left, top, bottom, back, front. Otherwise, it will be empty.
65
- */
66
- get planes() {
67
- return this._planes;
68
- }
69
- /** Recompute the planes from the specified frustum.
70
- * @returns true upon success, or false if the input frustum was degenerate, in which case [[isValid]] will be `false`.
71
- */
72
- init(frustum) {
73
- this._planes = computeFrustumPlanes(frustum);
74
- return this.isValid;
75
- }
76
- /** Compute to what degree a [[Frustum]] is contained with these frustum planes.
77
- * @param box The frustum to test for containment.
78
- * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.
79
- * @returns the degree to which `box` is contained within the clipping planes.
80
- */
81
- computeFrustumContainment(box, sphere) {
82
- return this.computeContainment(box.points, sphere);
83
- }
84
- /** Determines whether a [[Frustum]] intersects with or is fully contained within these frustum planes.
85
- * @param box The frustum to test for containment.
86
- * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.
87
- * @returns true if `box` is not entirely outside of the clipping planes.
88
- */
89
- intersectsFrustum(box, sphere) {
90
- return FrustumPlanes.Containment.Outside !== this.computeFrustumContainment(box, sphere);
91
- }
92
- /** Determines whether a point is contained within these frustum planes.
93
- * @param point The point to test for containment.
94
- * @param tolerance The maximum distance from the interior of the frustum planes that will still be considered "contained".
95
- * @returns true if `point` is no further than `tolerance` meters outside of the clipping planes.
96
- */
97
- containsPoint(point, tolerance = 1.0e-8) {
98
- return FrustumPlanes.Containment.Outside !== this.computeContainment([point], undefined, tolerance);
99
- }
100
- /** Compute the degree to which a set of points is contained within these frustum planes.
101
- * @param points The points to test for containment.
102
- * @param sphere An optional spherical bounding volume fully containing all of the points. If supplied, this can reduce the amount of computation required.
103
- * @param tolerance The maximum distance from the interior of the frustum planes a point must be to be considered "contained".
104
- * @returns the degree to which all of the points are contained within the clipping planes.
105
- */
106
- computeContainment(points, sphere, tolerance = 1.0e-8) {
107
- if (undefined === this._planes)
108
- return FrustumPlanes.Containment.Outside;
109
- // Do the cheap test against bounding sphere first.
110
- if (sphere) {
111
- for (let i = 0; i < this._planes.length; i++) {
112
- const plane = this._planes[i];
113
- const centerDistance = plane.altitude(sphere.center);
114
- const tolerancePlusRadius = tolerance + sphere.radius;
115
- if (centerDistance < -tolerancePlusRadius)
116
- return FrustumPlanes.Containment.Outside;
117
- planesContainingSphere[i] = centerDistance > tolerancePlusRadius;
118
- }
119
- }
120
- // Test against points.
121
- let allInside = true;
122
- for (let i = 0; i < this._planes.length; i++) {
123
- if (sphere && planesContainingSphere[i])
124
- continue;
125
- const plane = this._planes[i];
126
- let nOutside = 0;
127
- for (const point of points) {
128
- if (plane.altitude(point) + tolerance < 0) {
129
- ++nOutside;
130
- allInside = false;
131
- }
132
- }
133
- if (nOutside === points.length)
134
- return FrustumPlanes.Containment.Outside;
135
- }
136
- return allInside ? FrustumPlanes.Containment.Inside : FrustumPlanes.Containment.Partial;
137
- }
138
- /** Computes whether a ray intersects these clipping planes.
139
- * @param origin The origin of the ray.
140
- * @param direction The direction of the ray.
141
- * @returns true if the ray extending from `origin` in the specified `direction` intersects at least one of the clipping planes.
142
- */
143
- intersectsRay(origin, direction) {
144
- if (undefined === this._planes) {
145
- return false;
146
- }
147
- let tFar = 1e37;
148
- let tNear = -tFar;
149
- for (const plane of this._planes) {
150
- const vD = plane.velocity(direction);
151
- const vN = plane.altitude(origin);
152
- if (0.0 === vD) {
153
- // ray is parallel... no need to continue testing if outside halfspace.
154
- if (vN < 0.0) {
155
- return false;
156
- }
157
- }
158
- else {
159
- const rayDistance = -vN / vD;
160
- if (vD < 0.0) {
161
- tFar = Math.min(rayDistance, tFar);
162
- }
163
- else {
164
- tNear = Math.max(rayDistance, tNear);
165
- }
166
- }
167
- }
168
- return tNear <= tFar;
169
- }
170
- }
171
- /** @public @extensions */
172
- (function (FrustumPlanes) {
173
- /** Describes the degree to which an object is contained within the planes of a [[Frustum]].
174
- * @see [[FrustumPlanes.computeContainment]], for example.
175
- */
176
- let Containment;
177
- (function (Containment) {
178
- /** The object is entirely outside of the frustum, intersecting none of its planes. */
179
- Containment[Containment["Outside"] = 0] = "Outside";
180
- /** The object intersects at least one of the frustum planes. placing it partially inside of the frustum. */
181
- Containment[Containment["Partial"] = 1] = "Partial";
182
- /** The object is entirely inside of the frustum, intersecting none of its planes. */
183
- Containment[Containment["Inside"] = 2] = "Inside";
184
- })(Containment = FrustumPlanes.Containment || (FrustumPlanes.Containment = {}));
185
- })(FrustumPlanes || (FrustumPlanes = {}));
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
+ * See LICENSE.md in the project root for license terms and full copyright notice.
4
+ *--------------------------------------------------------------------------------------------*/
5
+ /** @packageDocumentation
6
+ * @module Geometry
7
+ */
8
+ import { ClipPlane, Vector3d } from "@itwin/core-geometry";
9
+ const planePointIndices = [
10
+ [1, 3, 5],
11
+ [0, 4, 2],
12
+ [2, 6, 3],
13
+ [0, 1, 4],
14
+ [0, 2, 1],
15
+ [4, 5, 6], // front
16
+ ];
17
+ function computeFrustumPlanes(frustum) {
18
+ const planes = [];
19
+ const points = frustum.points;
20
+ const expandPlaneDistance = 1e-6;
21
+ for (const indices of planePointIndices) {
22
+ const i0 = indices[0], i1 = indices[1], i2 = indices[2];
23
+ const normal = Vector3d.createCrossProductToPoints(points[i2], points[i1], points[i0]);
24
+ normal.normalizeInPlace();
25
+ const plane = ClipPlane.createNormalAndDistance(normal, normal.dotProduct(points[i0]) - expandPlaneDistance);
26
+ if (!plane)
27
+ return [];
28
+ planes.push(plane);
29
+ }
30
+ return planes;
31
+ }
32
+ // Scratch variable used by FrustumPlanes.computeContainment.
33
+ const planesContainingSphere = [false, false, false, false, false, false];
34
+ /** Represents a the planes of a [[Frustum]] for testing containment and intersection.
35
+ * A valid frustum produces six planes. A degenerate frustum produces zero planes.
36
+ * @public
37
+ * @extensions
38
+ */
39
+ export class FrustumPlanes {
40
+ constructor(planes) {
41
+ this._planes = planes;
42
+ }
43
+ /** Compute the six planes of the specified frustum.
44
+ * If the frustum is degenerate - that is, its points do not represent a truncated pyramid - then the returned `FrustumPlanes` will contain zero planes.
45
+ * @see [[isValid]] to test this condition.
46
+ */
47
+ static fromFrustum(frustum) {
48
+ const planes = computeFrustumPlanes(frustum);
49
+ return new FrustumPlanes(planes);
50
+ }
51
+ /** Create an empty set of frustum planes. [[isValid]] will be `true`. This can be useful when you want to create a `FrustumPlanes` object and initialize it later via [[init]] -
52
+ * for example, if you intend to use the same object repeatedly with different [[Frustum]]s.
53
+ */
54
+ static createEmpty() {
55
+ return new FrustumPlanes([]);
56
+ }
57
+ /** Returns true if [[planes]] consists of six planes. This may return `false` if a degenerate [[Frustum]] was supplied to [[fromFrustum]], or if this object was created
58
+ * via [[createEmpty]] - in either case, [[planes]] will be an empty array.
59
+ */
60
+ get isValid() {
61
+ return this._planes.length === 6;
62
+ }
63
+ /** Obtain the list of planes defining the frustum. If [[isValid]] is `true`, it will have a length of six, with the planes ordered as
64
+ * right, left, top, bottom, back, front. Otherwise, it will be empty.
65
+ */
66
+ get planes() {
67
+ return this._planes;
68
+ }
69
+ /** Recompute the planes from the specified frustum.
70
+ * @returns true upon success, or false if the input frustum was degenerate, in which case [[isValid]] will be `false`.
71
+ */
72
+ init(frustum) {
73
+ this._planes = computeFrustumPlanes(frustum);
74
+ return this.isValid;
75
+ }
76
+ /** Compute to what degree a [[Frustum]] is contained with these frustum planes.
77
+ * @param box The frustum to test for containment.
78
+ * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.
79
+ * @returns the degree to which `box` is contained within the clipping planes.
80
+ */
81
+ computeFrustumContainment(box, sphere) {
82
+ return this.computeContainment(box.points, sphere);
83
+ }
84
+ /** Determines whether a [[Frustum]] intersects with or is fully contained within these frustum planes.
85
+ * @param box The frustum to test for containment.
86
+ * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.
87
+ * @returns true if `box` is not entirely outside of the clipping planes.
88
+ */
89
+ intersectsFrustum(box, sphere) {
90
+ return FrustumPlanes.Containment.Outside !== this.computeFrustumContainment(box, sphere);
91
+ }
92
+ /** Determines whether a point is contained within these frustum planes.
93
+ * @param point The point to test for containment.
94
+ * @param tolerance The maximum distance from the interior of the frustum planes that will still be considered "contained".
95
+ * @returns true if `point` is no further than `tolerance` meters outside of the clipping planes.
96
+ */
97
+ containsPoint(point, tolerance = 1.0e-8) {
98
+ return FrustumPlanes.Containment.Outside !== this.computeContainment([point], undefined, tolerance);
99
+ }
100
+ /** Compute the degree to which a set of points is contained within these frustum planes.
101
+ * @param points The points to test for containment.
102
+ * @param sphere An optional spherical bounding volume fully containing all of the points. If supplied, this can reduce the amount of computation required.
103
+ * @param tolerance The maximum distance from the interior of the frustum planes a point must be to be considered "contained".
104
+ * @returns the degree to which all of the points are contained within the clipping planes.
105
+ */
106
+ computeContainment(points, sphere, tolerance = 1.0e-8) {
107
+ if (undefined === this._planes)
108
+ return FrustumPlanes.Containment.Outside;
109
+ // Do the cheap test against bounding sphere first.
110
+ if (sphere) {
111
+ for (let i = 0; i < this._planes.length; i++) {
112
+ const plane = this._planes[i];
113
+ const centerDistance = plane.altitude(sphere.center);
114
+ const tolerancePlusRadius = tolerance + sphere.radius;
115
+ if (centerDistance < -tolerancePlusRadius)
116
+ return FrustumPlanes.Containment.Outside;
117
+ planesContainingSphere[i] = centerDistance > tolerancePlusRadius;
118
+ }
119
+ }
120
+ // Test against points.
121
+ let allInside = true;
122
+ for (let i = 0; i < this._planes.length; i++) {
123
+ if (sphere && planesContainingSphere[i])
124
+ continue;
125
+ const plane = this._planes[i];
126
+ let nOutside = 0;
127
+ for (const point of points) {
128
+ if (plane.altitude(point) + tolerance < 0) {
129
+ ++nOutside;
130
+ allInside = false;
131
+ }
132
+ }
133
+ if (nOutside === points.length)
134
+ return FrustumPlanes.Containment.Outside;
135
+ }
136
+ return allInside ? FrustumPlanes.Containment.Inside : FrustumPlanes.Containment.Partial;
137
+ }
138
+ /** Computes whether a ray intersects these clipping planes.
139
+ * @param origin The origin of the ray.
140
+ * @param direction The direction of the ray.
141
+ * @returns true if the ray extending from `origin` in the specified `direction` intersects at least one of the clipping planes.
142
+ */
143
+ intersectsRay(origin, direction) {
144
+ if (undefined === this._planes) {
145
+ return false;
146
+ }
147
+ let tFar = 1e37;
148
+ let tNear = -tFar;
149
+ for (const plane of this._planes) {
150
+ const vD = plane.velocity(direction);
151
+ const vN = plane.altitude(origin);
152
+ if (0.0 === vD) {
153
+ // ray is parallel... no need to continue testing if outside halfspace.
154
+ if (vN < 0.0) {
155
+ return false;
156
+ }
157
+ }
158
+ else {
159
+ const rayDistance = -vN / vD;
160
+ if (vD < 0.0) {
161
+ tFar = Math.min(rayDistance, tFar);
162
+ }
163
+ else {
164
+ tNear = Math.max(rayDistance, tNear);
165
+ }
166
+ }
167
+ }
168
+ return tNear <= tFar;
169
+ }
170
+ }
171
+ /** @public @extensions */
172
+ (function (FrustumPlanes) {
173
+ /** Describes the degree to which an object is contained within the planes of a [[Frustum]].
174
+ * @see [[FrustumPlanes.computeContainment]], for example.
175
+ */
176
+ let Containment;
177
+ (function (Containment) {
178
+ /** The object is entirely outside of the frustum, intersecting none of its planes. */
179
+ Containment[Containment["Outside"] = 0] = "Outside";
180
+ /** The object intersects at least one of the frustum planes. placing it partially inside of the frustum. */
181
+ Containment[Containment["Partial"] = 1] = "Partial";
182
+ /** The object is entirely inside of the frustum, intersecting none of its planes. */
183
+ Containment[Containment["Inside"] = 2] = "Inside";
184
+ })(Containment = FrustumPlanes.Containment || (FrustumPlanes.Containment = {}));
185
+ })(FrustumPlanes || (FrustumPlanes = {}));
186
186
  //# sourceMappingURL=FrustumPlanes.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"FrustumPlanes.js","sourceRoot":"","sources":["../../../src/geometry/FrustumPlanes.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 Geometry\r\n */\r\n\r\nimport { ClipPlane, Point3d, Vector3d } from \"@itwin/core-geometry\";\r\nimport { Frustum } from \"../Frustum\";\r\nimport { BoundingSphere } from \"./BoundingSphere\";\r\n\r\nconst planePointIndices = [\r\n [1, 3, 5], // right\r\n [0, 4, 2], // left\r\n [2, 6, 3], // top\r\n [0, 1, 4], // bottom\r\n [0, 2, 1], // back\r\n [4, 5, 6], // front\r\n];\r\n\r\nfunction computeFrustumPlanes(frustum: Frustum): ClipPlane[] {\r\n const planes = [];\r\n const points = frustum.points;\r\n const expandPlaneDistance = 1e-6;\r\n\r\n for (const indices of planePointIndices) {\r\n const i0 = indices[0], i1 = indices[1], i2 = indices[2];\r\n const normal = Vector3d.createCrossProductToPoints(points[i2], points[i1], points[i0]);\r\n normal.normalizeInPlace();\r\n\r\n const plane = ClipPlane.createNormalAndDistance(normal, normal.dotProduct(points[i0]) - expandPlaneDistance);\r\n if (!plane)\r\n return [];\r\n\r\n planes.push(plane);\r\n }\r\n\r\n return planes;\r\n}\r\n\r\n// Scratch variable used by FrustumPlanes.computeContainment.\r\nconst planesContainingSphere = [false, false, false, false, false, false];\r\n\r\n/** Represents a the planes of a [[Frustum]] for testing containment and intersection.\r\n * A valid frustum produces six planes. A degenerate frustum produces zero planes.\r\n * @public\r\n * @extensions\r\n */\r\nexport class FrustumPlanes {\r\n private _planes: ClipPlane[];\r\n\r\n private constructor(planes: ClipPlane[]) {\r\n this._planes = planes;\r\n }\r\n\r\n /** Compute the six planes of the specified frustum.\r\n * If the frustum is degenerate - that is, its points do not represent a truncated pyramid - then the returned `FrustumPlanes` will contain zero planes.\r\n * @see [[isValid]] to test this condition.\r\n */\r\n public static fromFrustum(frustum: Frustum): FrustumPlanes {\r\n const planes = computeFrustumPlanes(frustum);\r\n return new FrustumPlanes(planes);\r\n }\r\n\r\n /** Create an empty set of frustum planes. [[isValid]] will be `true`. This can be useful when you want to create a `FrustumPlanes` object and initialize it later via [[init]] -\r\n * for example, if you intend to use the same object repeatedly with different [[Frustum]]s.\r\n */\r\n public static createEmpty(): FrustumPlanes {\r\n return new FrustumPlanes([]);\r\n }\r\n\r\n /** Returns true if [[planes]] consists of six planes. This may return `false` if a degenerate [[Frustum]] was supplied to [[fromFrustum]], or if this object was created\r\n * via [[createEmpty]] - in either case, [[planes]] will be an empty array.\r\n */\r\n public get isValid(): boolean {\r\n return this._planes.length === 6;\r\n }\r\n\r\n /** Obtain the list of planes defining the frustum. If [[isValid]] is `true`, it will have a length of six, with the planes ordered as\r\n * right, left, top, bottom, back, front. Otherwise, it will be empty.\r\n */\r\n public get planes(): ClipPlane[] {\r\n return this._planes;\r\n }\r\n\r\n /** Recompute the planes from the specified frustum.\r\n * @returns true upon success, or false if the input frustum was degenerate, in which case [[isValid]] will be `false`.\r\n */\r\n public init(frustum: Frustum): boolean {\r\n this._planes = computeFrustumPlanes(frustum);\r\n return this.isValid;\r\n }\r\n\r\n /** Compute to what degree a [[Frustum]] is contained with these frustum planes.\r\n * @param box The frustum to test for containment.\r\n * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.\r\n * @returns the degree to which `box` is contained within the clipping planes.\r\n */\r\n public computeFrustumContainment(box: Frustum, sphere?: BoundingSphere): FrustumPlanes.Containment {\r\n return this.computeContainment(box.points, sphere);\r\n }\r\n\r\n /** Determines whether a [[Frustum]] intersects with or is fully contained within these frustum planes.\r\n * @param box The frustum to test for containment.\r\n * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.\r\n * @returns true if `box` is not entirely outside of the clipping planes.\r\n */\r\n public intersectsFrustum(box: Frustum, sphere?: BoundingSphere): boolean {\r\n return FrustumPlanes.Containment.Outside !== this.computeFrustumContainment(box, sphere);\r\n }\r\n\r\n /** Determines whether a point is contained within these frustum planes.\r\n * @param point The point to test for containment.\r\n * @param tolerance The maximum distance from the interior of the frustum planes that will still be considered \"contained\".\r\n * @returns true if `point` is no further than `tolerance` meters outside of the clipping planes.\r\n */\r\n public containsPoint(point: Point3d, tolerance: number = 1.0e-8): boolean {\r\n return FrustumPlanes.Containment.Outside !== this.computeContainment([point], undefined, tolerance);\r\n }\r\n\r\n /** Compute the degree to which a set of points is contained within these frustum planes.\r\n * @param points The points to test for containment.\r\n * @param sphere An optional spherical bounding volume fully containing all of the points. If supplied, this can reduce the amount of computation required.\r\n * @param tolerance The maximum distance from the interior of the frustum planes a point must be to be considered \"contained\".\r\n * @returns the degree to which all of the points are contained within the clipping planes.\r\n */\r\n public computeContainment(points: Point3d[], sphere?: BoundingSphere, tolerance: number = 1.0e-8): FrustumPlanes.Containment {\r\n if (undefined === this._planes)\r\n return FrustumPlanes.Containment.Outside;\r\n\r\n // Do the cheap test against bounding sphere first.\r\n if (sphere) {\r\n for (let i = 0; i < this._planes.length; i++) {\r\n const plane = this._planes[i];\r\n const centerDistance = plane.altitude(sphere.center);\r\n const tolerancePlusRadius = tolerance + sphere.radius;\r\n if (centerDistance < -tolerancePlusRadius)\r\n return FrustumPlanes.Containment.Outside;\r\n\r\n planesContainingSphere[i] = centerDistance > tolerancePlusRadius;\r\n }\r\n }\r\n\r\n // Test against points.\r\n let allInside = true;\r\n for (let i = 0; i < this._planes.length; i++) {\r\n if (sphere && planesContainingSphere[i])\r\n continue;\r\n\r\n const plane = this._planes[i];\r\n let nOutside = 0;\r\n for (const point of points) {\r\n if (plane.altitude(point) + tolerance < 0) {\r\n ++nOutside;\r\n allInside = false;\r\n }\r\n }\r\n\r\n if (nOutside === points.length)\r\n return FrustumPlanes.Containment.Outside;\r\n }\r\n\r\n return allInside ? FrustumPlanes.Containment.Inside : FrustumPlanes.Containment.Partial;\r\n }\r\n\r\n /** Computes whether a ray intersects these clipping planes.\r\n * @param origin The origin of the ray.\r\n * @param direction The direction of the ray.\r\n * @returns true if the ray extending from `origin` in the specified `direction` intersects at least one of the clipping planes.\r\n */\r\n public intersectsRay(origin: Point3d, direction: Vector3d): boolean {\r\n if (undefined === this._planes) {\r\n return false;\r\n }\r\n\r\n let tFar = 1e37;\r\n let tNear = -tFar;\r\n\r\n for (const plane of this._planes) {\r\n const vD = plane.velocity(direction);\r\n const vN = plane.altitude(origin);\r\n if (0.0 === vD) {\r\n // ray is parallel... no need to continue testing if outside halfspace.\r\n if (vN < 0.0) {\r\n return false;\r\n }\r\n } else {\r\n const rayDistance = -vN / vD;\r\n if (vD < 0.0) {\r\n tFar = Math.min(rayDistance, tFar);\r\n } else {\r\n tNear = Math.max(rayDistance, tNear);\r\n }\r\n }\r\n }\r\n\r\n return tNear <= tFar;\r\n }\r\n}\r\n\r\n/** @public @extensions */\r\nexport namespace FrustumPlanes { // eslint-disable-line no-redeclare\r\n /** Describes the degree to which an object is contained within the planes of a [[Frustum]].\r\n * @see [[FrustumPlanes.computeContainment]], for example.\r\n */\r\n export enum Containment {\r\n /** The object is entirely outside of the frustum, intersecting none of its planes. */\r\n Outside = 0,\r\n /** The object intersects at least one of the frustum planes. placing it partially inside of the frustum. */\r\n Partial = 1,\r\n /** The object is entirely inside of the frustum, intersecting none of its planes. */\r\n Inside = 2,\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"FrustumPlanes.js","sourceRoot":"","sources":["../../../src/geometry/FrustumPlanes.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module Geometry\n */\n\nimport { ClipPlane, Point3d, Vector3d } from \"@itwin/core-geometry\";\nimport { Frustum } from \"../Frustum\";\nimport { BoundingSphere } from \"./BoundingSphere\";\n\nconst planePointIndices = [\n [1, 3, 5], // right\n [0, 4, 2], // left\n [2, 6, 3], // top\n [0, 1, 4], // bottom\n [0, 2, 1], // back\n [4, 5, 6], // front\n];\n\nfunction computeFrustumPlanes(frustum: Frustum): ClipPlane[] {\n const planes = [];\n const points = frustum.points;\n const expandPlaneDistance = 1e-6;\n\n for (const indices of planePointIndices) {\n const i0 = indices[0], i1 = indices[1], i2 = indices[2];\n const normal = Vector3d.createCrossProductToPoints(points[i2], points[i1], points[i0]);\n normal.normalizeInPlace();\n\n const plane = ClipPlane.createNormalAndDistance(normal, normal.dotProduct(points[i0]) - expandPlaneDistance);\n if (!plane)\n return [];\n\n planes.push(plane);\n }\n\n return planes;\n}\n\n// Scratch variable used by FrustumPlanes.computeContainment.\nconst planesContainingSphere = [false, false, false, false, false, false];\n\n/** Represents a the planes of a [[Frustum]] for testing containment and intersection.\n * A valid frustum produces six planes. A degenerate frustum produces zero planes.\n * @public\n * @extensions\n */\nexport class FrustumPlanes {\n private _planes: ClipPlane[];\n\n private constructor(planes: ClipPlane[]) {\n this._planes = planes;\n }\n\n /** Compute the six planes of the specified frustum.\n * If the frustum is degenerate - that is, its points do not represent a truncated pyramid - then the returned `FrustumPlanes` will contain zero planes.\n * @see [[isValid]] to test this condition.\n */\n public static fromFrustum(frustum: Frustum): FrustumPlanes {\n const planes = computeFrustumPlanes(frustum);\n return new FrustumPlanes(planes);\n }\n\n /** Create an empty set of frustum planes. [[isValid]] will be `true`. This can be useful when you want to create a `FrustumPlanes` object and initialize it later via [[init]] -\n * for example, if you intend to use the same object repeatedly with different [[Frustum]]s.\n */\n public static createEmpty(): FrustumPlanes {\n return new FrustumPlanes([]);\n }\n\n /** Returns true if [[planes]] consists of six planes. This may return `false` if a degenerate [[Frustum]] was supplied to [[fromFrustum]], or if this object was created\n * via [[createEmpty]] - in either case, [[planes]] will be an empty array.\n */\n public get isValid(): boolean {\n return this._planes.length === 6;\n }\n\n /** Obtain the list of planes defining the frustum. If [[isValid]] is `true`, it will have a length of six, with the planes ordered as\n * right, left, top, bottom, back, front. Otherwise, it will be empty.\n */\n public get planes(): ClipPlane[] {\n return this._planes;\n }\n\n /** Recompute the planes from the specified frustum.\n * @returns true upon success, or false if the input frustum was degenerate, in which case [[isValid]] will be `false`.\n */\n public init(frustum: Frustum): boolean {\n this._planes = computeFrustumPlanes(frustum);\n return this.isValid;\n }\n\n /** Compute to what degree a [[Frustum]] is contained with these frustum planes.\n * @param box The frustum to test for containment.\n * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.\n * @returns the degree to which `box` is contained within the clipping planes.\n */\n public computeFrustumContainment(box: Frustum, sphere?: BoundingSphere): FrustumPlanes.Containment {\n return this.computeContainment(box.points, sphere);\n }\n\n /** Determines whether a [[Frustum]] intersects with or is fully contained within these frustum planes.\n * @param box The frustum to test for containment.\n * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.\n * @returns true if `box` is not entirely outside of the clipping planes.\n */\n public intersectsFrustum(box: Frustum, sphere?: BoundingSphere): boolean {\n return FrustumPlanes.Containment.Outside !== this.computeFrustumContainment(box, sphere);\n }\n\n /** Determines whether a point is contained within these frustum planes.\n * @param point The point to test for containment.\n * @param tolerance The maximum distance from the interior of the frustum planes that will still be considered \"contained\".\n * @returns true if `point` is no further than `tolerance` meters outside of the clipping planes.\n */\n public containsPoint(point: Point3d, tolerance: number = 1.0e-8): boolean {\n return FrustumPlanes.Containment.Outside !== this.computeContainment([point], undefined, tolerance);\n }\n\n /** Compute the degree to which a set of points is contained within these frustum planes.\n * @param points The points to test for containment.\n * @param sphere An optional spherical bounding volume fully containing all of the points. If supplied, this can reduce the amount of computation required.\n * @param tolerance The maximum distance from the interior of the frustum planes a point must be to be considered \"contained\".\n * @returns the degree to which all of the points are contained within the clipping planes.\n */\n public computeContainment(points: Point3d[], sphere?: BoundingSphere, tolerance: number = 1.0e-8): FrustumPlanes.Containment {\n if (undefined === this._planes)\n return FrustumPlanes.Containment.Outside;\n\n // Do the cheap test against bounding sphere first.\n if (sphere) {\n for (let i = 0; i < this._planes.length; i++) {\n const plane = this._planes[i];\n const centerDistance = plane.altitude(sphere.center);\n const tolerancePlusRadius = tolerance + sphere.radius;\n if (centerDistance < -tolerancePlusRadius)\n return FrustumPlanes.Containment.Outside;\n\n planesContainingSphere[i] = centerDistance > tolerancePlusRadius;\n }\n }\n\n // Test against points.\n let allInside = true;\n for (let i = 0; i < this._planes.length; i++) {\n if (sphere && planesContainingSphere[i])\n continue;\n\n const plane = this._planes[i];\n let nOutside = 0;\n for (const point of points) {\n if (plane.altitude(point) + tolerance < 0) {\n ++nOutside;\n allInside = false;\n }\n }\n\n if (nOutside === points.length)\n return FrustumPlanes.Containment.Outside;\n }\n\n return allInside ? FrustumPlanes.Containment.Inside : FrustumPlanes.Containment.Partial;\n }\n\n /** Computes whether a ray intersects these clipping planes.\n * @param origin The origin of the ray.\n * @param direction The direction of the ray.\n * @returns true if the ray extending from `origin` in the specified `direction` intersects at least one of the clipping planes.\n */\n public intersectsRay(origin: Point3d, direction: Vector3d): boolean {\n if (undefined === this._planes) {\n return false;\n }\n\n let tFar = 1e37;\n let tNear = -tFar;\n\n for (const plane of this._planes) {\n const vD = plane.velocity(direction);\n const vN = plane.altitude(origin);\n if (0.0 === vD) {\n // ray is parallel... no need to continue testing if outside halfspace.\n if (vN < 0.0) {\n return false;\n }\n } else {\n const rayDistance = -vN / vD;\n if (vD < 0.0) {\n tFar = Math.min(rayDistance, tFar);\n } else {\n tNear = Math.max(rayDistance, tNear);\n }\n }\n }\n\n return tNear <= tFar;\n }\n}\n\n/** @public @extensions */\nexport namespace FrustumPlanes { // eslint-disable-line no-redeclare\n /** Describes the degree to which an object is contained within the planes of a [[Frustum]].\n * @see [[FrustumPlanes.computeContainment]], for example.\n */\n export enum Containment {\n /** The object is entirely outside of the frustum, intersecting none of its planes. */\n Outside = 0,\n /** The object intersects at least one of the frustum planes. placing it partially inside of the frustum. */\n Partial = 1,\n /** The object is entirely inside of the frustum, intersecting none of its planes. */\n Inside = 2,\n }\n}\n"]}