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