@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
package/lib/esm/QPoint.js CHANGED
@@ -1,814 +1,814 @@
1
- /*---------------------------------------------------------------------------------------------
2
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
- * See LICENSE.md in the project root for license terms and full copyright notice.
4
- *--------------------------------------------------------------------------------------------*/
5
- /** @packageDocumentation
6
- * @module Geometry
7
- */
8
- import { assert, Uint16ArrayBuilder } from "@itwin/core-bentley";
9
- import { Point2d, Point3d, Range2d, Range3d, Vector2d, Vector3d, } from "@itwin/core-geometry";
10
- /**
11
- * Provides facilities for quantizing floating point values within a specified range into 16-bit unsigned integers.
12
- * This is a lossy compression technique.
13
- * Given a floating point range [min, max], a floating point value `x` within that range is quantized by subtracting
14
- * `min`, scaling the result according to `max`, and truncating the result to an integer.
15
- * Therefore min quantizes to 0, max to 0xffff, (min+max)/2 to 0x7fff, and so on.
16
- * These routines are chiefly used by classes like [[QPoint2d]] and [[QPoint3d]] to reduce the space required to store
17
- * coordinate values for [RenderGraphic]($frontend)s.
18
- * @public
19
- * @extensions
20
- */
21
- export var Quantization;
22
- (function (Quantization) {
23
- Quantization.rangeScale16 = 0xffff;
24
- Quantization.rangeScale8 = 0xff;
25
- /** Compute the scale factor required to quantize `extent` to `rangeScale` discrete values. */
26
- function computeScale(extent, rangeScale = Quantization.rangeScale16) {
27
- return 0.0 === extent ? extent : rangeScale / extent;
28
- }
29
- Quantization.computeScale = computeScale;
30
- /** @internal */
31
- function isInRange(qpos, rangeScale = Quantization.rangeScale16) {
32
- return qpos >= 0.0 && qpos < rangeScale + 1.0;
33
- }
34
- Quantization.isInRange = isInRange;
35
- /** Return `pos` quantized to the range [`origin`, `origin + rangeScale`].
36
- * @see [[Quantization.unquantize]] for the inverse operation.
37
- */
38
- function quantize(pos, origin, scale, rangeScale = Quantization.rangeScale16) {
39
- return Math.floor(Math.max(0.0, Math.min(rangeScale, 0.5 + (pos - origin) * scale)));
40
- }
41
- Quantization.quantize = quantize;
42
- /** @internal */
43
- function isQuantizable(pos, origin, scale, rangeScale = Quantization.rangeScale16) {
44
- return isInRange(quantize(pos, origin, scale, rangeScale));
45
- }
46
- Quantization.isQuantizable = isQuantizable;
47
- /** Give `qpos` quantized to the range [`origin`, `origin + rangeScale`], return the unquantized value.
48
- * @see [[Quantization.quantize]] for the inverse operation.
49
- */
50
- function unquantize(qpos, origin, scale) {
51
- return 0.0 === scale ? origin : origin + qpos / scale;
52
- }
53
- Quantization.unquantize = unquantize;
54
- /** @internal */
55
- function isQuantized(qpos) {
56
- return isInRange(qpos) && qpos === Math.floor(qpos);
57
- }
58
- Quantization.isQuantized = isQuantized;
59
- })(Quantization || (Quantization = {}));
60
- /** Parameters used for [[Quantization]] of 2d points such that the `x` and `y` components are each quantized to 16-bit unsigned integers.
61
- * @see [[QPoint2d]] for the quantized representation of a [Point2d]($core-geometry).
62
- * @see [[QPoint2dList]] for a list of [[QPoint2d]]s quantized using a [[QParams2d]].
63
- * @public
64
- * @extensions
65
- */
66
- export class QParams2d {
67
- constructor(ox = 0, oy = 0, sx = 0, sy = 0) {
68
- /** The origin of the quantization range. */
69
- this.origin = new Point2d();
70
- /** The scale applied to coordinates to quantize them. */
71
- this.scale = new Point2d();
72
- this.setFrom(ox, oy, sx, sy);
73
- }
74
- setFrom(ox, oy, sx, sy) {
75
- this.origin.x = ox;
76
- this.origin.y = oy;
77
- this.scale.x = sx;
78
- this.scale.y = sy;
79
- }
80
- /** Set [[origin]] and [[scale]] from `src`. */
81
- copyFrom(src) {
82
- this.setFrom(src.origin.x, src.origin.y, src.scale.x, src.scale.y);
83
- }
84
- /** Create a copy of these params.
85
- * @param out If supplied, these QParams2d will be modified and returned; otherwise a new QParams2d object will be created and returned.
86
- */
87
- clone(out) {
88
- const result = undefined !== out ? out : new QParams2d();
89
- result.copyFrom(this);
90
- return result;
91
- }
92
- /** Initialize these parameters to support quantization of values within the specified range. */
93
- setFromRange(range, rangeScale = Quantization.rangeScale16) {
94
- if (!range.isNull) {
95
- this.setFrom(range.low.x, range.low.y, Quantization.computeScale(range.high.x - range.low.x, rangeScale), Quantization.computeScale(range.high.y - range.low.y, rangeScale));
96
- }
97
- else {
98
- this.origin.x = this.origin.y = this.scale.x = this.scale.y = 0;
99
- }
100
- }
101
- /** Create parameters to support quantization of values within the specified range. */
102
- static fromRange(range, out, rangeScale = Quantization.rangeScale16) {
103
- const params = undefined !== out ? out : new QParams2d();
104
- params.setFromRange(range, rangeScale);
105
- return params;
106
- }
107
- /** Return the unquantized point for the input `x` and `y` components. If `out` is supplied, it will be modified to hold the result and returned. */
108
- unquantize(x, y, out) {
109
- out = out ?? new Point2d();
110
- out.x = Quantization.unquantize(x, this.origin.x, this.scale.x);
111
- out.y = Quantization.unquantize(y, this.origin.y, this.scale.y);
112
- return out;
113
- }
114
- /** Creates parameters supporting quantization of values within the range [-1.0, 1.0], appropriate for normalized 2d vectors. */
115
- static fromNormalizedRange(rangeScale = Quantization.rangeScale16) {
116
- return QParams2d.fromRange(Range2d.createArray([Point2d.create(-1, -1), Point2d.create(1, 1)]), undefined, rangeScale);
117
- }
118
- /** Create parameters supporting quantization of values within the range [0.0, 1.0]. */
119
- static fromZeroToOne(rangeScale = Quantization.rangeScale16) {
120
- return QParams2d.fromRange(Range2d.createArray([Point2d.create(0, 0), Point2d.create(1, 1)]), undefined, rangeScale);
121
- }
122
- /** Create parameters from origin and scale components */
123
- static fromOriginAndScale(originX, originY, scaleX, scaleY) {
124
- return new QParams2d(originX, originY, scaleX, scaleY);
125
- }
126
- /** @internal */
127
- get rangeDiagonal() {
128
- return Vector2d.createFrom({ x: 0 === this.scale.x ? 0 : Quantization.rangeScale16 / this.scale.x, y: 0 === this.scale.y ? 0 : Quantization.rangeScale16 / this.scale.y });
129
- }
130
- /** Return true if the point point is quantizable using these parameters. */
131
- isQuantizable(point) {
132
- return Quantization.isQuantizable(point.x, this.origin.x, this.scale.x) && Quantization.isQuantizable(point.y, this.origin.y, this.scale.y);
133
- }
134
- }
135
- /** Represents a [Point2d]($core-geometry) compressed such that each component `x` and `y` is quantized to the 16-bit integer range [0, 0xffff].
136
- * These are primarily used to reduce the space required for coordinates used by [RenderGraphic]($frontend)s.
137
- * @see [[QParams2d]] to define quantization parameters for a range of points.
138
- * @see [[QPoint2dList]] for a list of points all quantized to the same range.
139
- * @public
140
- * @extensions
141
- */
142
- export class QPoint2d {
143
- /** Construct with `x` and `y` initialized to zero. */
144
- constructor() {
145
- this._x = 0;
146
- this._y = 0;
147
- }
148
- /** The quantized x component. */
149
- get x() { return this._x; }
150
- set x(x) {
151
- assert(Quantization.isQuantized(x));
152
- this._x = x;
153
- }
154
- /** The quantized y component. */
155
- get y() { return this._y; }
156
- set y(y) {
157
- assert(Quantization.isQuantized(y));
158
- this._y = y;
159
- }
160
- /** Initialize this point by quantizing the supplied { x, y } using the specified params */
161
- init(pos, params) {
162
- this.x = Quantization.quantize(pos.x, params.origin.x, params.scale.x);
163
- this.y = Quantization.quantize(pos.y, params.origin.y, params.scale.y);
164
- }
165
- /** Create a quantized point from the supplied Point2d using the specified params */
166
- static create(pos, params) {
167
- const qpt = new QPoint2d();
168
- qpt.init(pos, params);
169
- return qpt;
170
- }
171
- /** Initialize `x` and `y` from `src`. */
172
- copyFrom(src) {
173
- this.x = src.x;
174
- this.y = src.y;
175
- }
176
- /** Create a copy of this point.
177
- * @param out If supplied, it will be modified in-place and returned; otherwise a new QPoint2d will be allocated and returned.
178
- */
179
- clone(out) {
180
- const result = undefined !== out ? out : new QPoint2d();
181
- result.copyFrom(this);
182
- return result;
183
- }
184
- /**
185
- * Set the x and y components directly.
186
- * @param x Must be an integer in the range [0, 0xffff]
187
- * @param y Must be an integer in the range [0, 0xffff]
188
- */
189
- setFromScalars(x, y) {
190
- this.x = x;
191
- this.y = y;
192
- }
193
- /**
194
- * Create a QPoint2d directly from x and y components.
195
- * @param x Must be an integer in the range [0, 0xffff]
196
- * @param y Must be an integer in the range [0, 0xffff]
197
- */
198
- static fromScalars(x, y) {
199
- const pt = new QPoint2d();
200
- pt.setFromScalars(x, y);
201
- return pt;
202
- }
203
- /** Return a Point2d unquantized according to the supplied `params`. If `out` is supplied, it will be modified in-place and returned. */
204
- unquantize(params, out) {
205
- const pt = undefined !== out ? out : new Point2d();
206
- pt.x = Quantization.unquantize(this.x, params.origin.x, params.scale.x);
207
- pt.y = Quantization.unquantize(this.y, params.origin.y, params.scale.y);
208
- return pt;
209
- }
210
- }
211
- /** @public
212
- * @extensions
213
- */
214
- export var QPoint2dBuffer;
215
- (function (QPoint2dBuffer) {
216
- const scratchQPoint2d = new QPoint2d();
217
- /** Extracts the point at the specified index from a buffer.
218
- * @param points The buffer in which each consecutive pair of integers is a 2d quantized point.
219
- * @param pointIndex The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
220
- * @param result If supplied, a preallocated [[QPoint2d]] to initialize with the result and return.
221
- * @returns The point at `pointIndex`.
222
- * @throws Error if `pointIndex` is out of bounds.
223
- */
224
- function getQPoint(points, pointIndex, result) {
225
- const index = pointIndex * 2;
226
- const x = points[index + 0];
227
- const y = points[index + 1];
228
- if (undefined === x || undefined === y)
229
- throw new Error("Index out of range");
230
- result = result ?? new QPoint2d();
231
- result.setFromScalars(x, y);
232
- return result;
233
- }
234
- QPoint2dBuffer.getQPoint = getQPoint;
235
- /** Extracts and unquantizes the point at the specified index from a buffer.
236
- * @param buffer The array of points and the quantization parameters.
237
- * @param The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
238
- * @param result If supplied, a preallocated [Point2d]($core-geometry) to initialize with the result and return.
239
- * @returns The point at `pointIndex`.
240
- * @throws Error if `pointIndex` is out of bounds.
241
- */
242
- function unquantizePoint(buffer, pointIndex, result) {
243
- const qpt = getQPoint(buffer.points, pointIndex, scratchQPoint2d);
244
- return qpt.unquantize(buffer.params, result);
245
- }
246
- QPoint2dBuffer.unquantizePoint = unquantizePoint;
247
- })(QPoint2dBuffer || (QPoint2dBuffer = {}));
248
- /** A list of [[QPoint2d]]s all quantized to the same range.
249
- * @public
250
- * @extensions
251
- */
252
- export class QPoint2dList {
253
- /** Construct an empty list set up to use the supplied quantization parameters. */
254
- constructor(params) {
255
- this._list = new Array();
256
- this.params = params.clone();
257
- }
258
- /** The list of quantized points. */
259
- get list() {
260
- return this._list;
261
- }
262
- /** Removes all points from the list. */
263
- clear() {
264
- this._list.length = 0;
265
- }
266
- /** Removes all points from the list and change the quantization parameters. */
267
- reset(params) {
268
- this.clear();
269
- this.params.copyFrom(params);
270
- }
271
- /** Quantizes the supplied Point2d to this list's range and appends it to the list. */
272
- add(pt) {
273
- this._list.push(QPoint2d.create(pt, this.params));
274
- }
275
- /** Adds a previously-quantized point to this list. */
276
- push(qpt) {
277
- this._list.push(qpt.clone());
278
- }
279
- /** The number of points in the list. */
280
- get length() {
281
- return this._list.length;
282
- }
283
- /** Returns the unquantized value of the point at the specified index in the list. */
284
- unquantize(index, out) {
285
- assert(index < this.length);
286
- if (index < this.length) {
287
- return this._list[index].unquantize(this.params, out);
288
- }
289
- else {
290
- return undefined !== out ? out : new Point2d();
291
- }
292
- }
293
- /** Changes the quantization parameters and requantizes all points in the list to the new range.
294
- * @note The loss of precision is compounded each time the points are requantized to a new range.
295
- */
296
- requantize(params) {
297
- for (let i = 0; i < this.length; i++) {
298
- const pt = this.unquantize(i);
299
- this._list[i].init(pt, params);
300
- }
301
- this.params.copyFrom(params);
302
- }
303
- /** Extracts the current contents of the list as a Uint16Array such that the first element of the array corresponds to the first point's `x` component,
304
- * the second to the first point's `y` component, and so on.
305
- */
306
- toTypedArray() {
307
- const array = new Uint16Array(this.length * 2);
308
- const pts = this._list;
309
- for (let i = 0; i < this.length; i++) {
310
- const pt = pts[i];
311
- array[i * 2] = pt.x;
312
- array[i * 2 + 1] = pt.y;
313
- }
314
- return array;
315
- }
316
- /** Create from a Uint16Array laid out such that `array[0]` corresponds to the first point's `x` component, `array[1]` to the first point's `y` component, and so on. */
317
- fromTypedArray(range, array) {
318
- this.params.setFromRange(range);
319
- this._list.length = array.length / 2;
320
- for (let i = 0, j = 0; i < this.list.length; i++)
321
- this._list[i] = QPoint2d.fromScalars(array[j++], array[j++]);
322
- }
323
- /** Construct a QPoint2dList containing all points in the supplied list, quantized to the range of those points. */
324
- static fromPoints(points, out) {
325
- let qPoints;
326
- const qParams = QParams2d.fromRange(Range2d.createArray(points));
327
- if (out) {
328
- qPoints = out;
329
- qPoints.reset(qParams);
330
- }
331
- else {
332
- qPoints = new QPoint2dList(qParams);
333
- }
334
- for (const point of points)
335
- qPoints.add(point);
336
- return qPoints;
337
- }
338
- }
339
- /** Parameters used for [[Quantization]] of 3d points such that the `x`, `y`, and `z` components are each quantized to 16-bit unsigned integers.
340
- * @see [[QPoint3d]] for the quantized representation of a [Point3d]($core-geometry).
341
- * @see [[QPoint3dList]] for a list of [[QPoint3d]]s quantized using a [[QParams3d]].
342
- * @public
343
- * @extensions
344
- */
345
- export class QParams3d {
346
- constructor(ox = 0, oy = 0, oz = 0, sx = 0, sy = 0, sz = 0) {
347
- /** The origin of the quantization range. */
348
- this.origin = new Point3d();
349
- /** The scale applied to coordinates to quantize them. */
350
- this.scale = new Point3d();
351
- this.setFrom(ox, oy, oz, sx, sy, sz);
352
- }
353
- setFrom(ox, oy, oz, sx, sy, sz) {
354
- this.origin.x = ox;
355
- this.origin.y = oy;
356
- this.origin.z = oz;
357
- this.scale.x = sx;
358
- this.scale.y = sy;
359
- this.scale.z = sz;
360
- }
361
- /** Set `x`, `y`, and `z` from `src. */
362
- copyFrom(src) {
363
- this.setFrom(src.origin.x, src.origin.y, src.origin.z, src.scale.x, src.scale.y, src.scale.z);
364
- }
365
- /** Create a copy of these parameters.
366
- * @param out If supplied, it will be modified in-place and returned instead of allocating a new QParams3d.
367
- */
368
- clone(out) {
369
- const result = undefined !== out ? out : new QParams3d();
370
- result.copyFrom(this);
371
- return result;
372
- }
373
- /** Initialize from origin and scale */
374
- setFromOriginAndScale(origin, scale) {
375
- this.setFrom(origin.x, origin.y, origin.z, scale.x, scale.y, scale.z);
376
- }
377
- /** Initialize these parameters to support quantization of values within the specified range. */
378
- setFromRange(range, rangeScale = Quantization.rangeScale16) {
379
- if (!range.isNull) {
380
- this.setFrom(range.low.x, range.low.y, range.low.z, Quantization.computeScale(range.high.x - range.low.x, rangeScale), Quantization.computeScale(range.high.y - range.low.y, rangeScale), Quantization.computeScale(range.high.z - range.low.z, rangeScale));
381
- }
382
- else {
383
- this.origin.x = this.origin.y = this.origin.z = 0;
384
- this.scale.x = this.scale.y = this.scale.z = 0;
385
- }
386
- }
387
- /** Return the unquantized point for the input components.
388
- * @param out If supplied, it will be modified in-place and returned instead of allocating a new Point3d.
389
- */
390
- unquantize(x, y, z, out) {
391
- const pt = undefined !== out ? out : new Point3d();
392
- pt.x = Quantization.unquantize(x, this.origin.x, this.scale.x);
393
- pt.y = Quantization.unquantize(y, this.origin.y, this.scale.y);
394
- pt.z = Quantization.unquantize(z, this.origin.z, this.scale.z);
395
- return pt;
396
- }
397
- /** Creates parameters to support quantization of values within the specified range.
398
- * If `out` is supplied, it will be modified in-place and returned instead of allocating a new QParams3d.
399
- */
400
- static fromRange(range, out, rangeScale = Quantization.rangeScale16) {
401
- const params = undefined !== out ? out : new QParams3d();
402
- params.setFromRange(range, rangeScale);
403
- return params;
404
- }
405
- /** Creates parameters supporting quantization of values within the range [-1.0, 1.0].
406
- * If `out` is supplied, it will be modified in-place and returned instead of allocating a new QParams3d.
407
- */
408
- static fromOriginAndScale(origin, scale, out) {
409
- const params = undefined !== out ? out : new QParams3d();
410
- params.setFromOriginAndScale(origin, scale);
411
- return params;
412
- }
413
- /** Creates parameters supporting quantization of values within the range [-1.0, 1.0]. */
414
- static fromNormalizedRange(rangeScale = Quantization.rangeScale16) {
415
- return QParams3d.fromRange(Range3d.createArray([Point3d.create(-1, -1, -1), Point3d.create(1, 1, 1)]), undefined, rangeScale);
416
- }
417
- /** Creates parameters supporting quantization of values within the range [0.0, 1.0]. */
418
- static fromZeroToOne(rangeScale = Quantization.rangeScale16) {
419
- return QParams3d.fromRange(Range3d.createArray([Point3d.create(0, 0, 0), Point3d.create(1, 1, 1)]), undefined, rangeScale);
420
- }
421
- /** @internal */
422
- get rangeDiagonal() {
423
- return Vector3d.createFrom({
424
- x: this.scale.x === 0 ? 0 : Quantization.rangeScale16 / this.scale.x,
425
- y: this.scale.y === 0 ? 0 : Quantization.rangeScale16 / this.scale.y,
426
- z: this.scale.z === 0 ? 0 : Quantization.rangeScale16 / this.scale.z,
427
- });
428
- }
429
- /** Return true if the point point is quantizable using these parameters. */
430
- isQuantizable(point) {
431
- return Quantization.isQuantizable(point.x, this.origin.x, this.scale.x) && Quantization.isQuantizable(point.y, this.origin.y, this.scale.y) && Quantization.isQuantizable(point.z, this.origin.z, this.scale.z);
432
- }
433
- /** Compute the range to which these parameters quantize. */
434
- computeRange(out) {
435
- const range = Range3d.createNull(out);
436
- range.extendPoint(this.origin);
437
- range.extendPoint(this.origin.plus(this.rangeDiagonal));
438
- return range;
439
- }
440
- }
441
- /** Represents a [Point3d]($core-geometry) compressed such that each component `x`, `y`, and `z` is quantized to the 16-bit integer range [0, 0xffff].
442
- * These are primarily used to reduce the space required for coordinates used by [RenderGraphic]($frontend)s.
443
- * @see [[QParams3d]] to define quantization parameters for a range of points.
444
- * @see [[QPoint3dList]] for a list of points all quantized to the same range.
445
- * @public
446
- * @extensions
447
- */
448
- export class QPoint3d {
449
- /** Construct with all components initialized to zero. */
450
- constructor() {
451
- this._x = 0;
452
- this._y = 0;
453
- this._z = 0;
454
- }
455
- /** The quantized x component. */
456
- get x() { return this._x; }
457
- set x(x) {
458
- assert(Quantization.isQuantized(x));
459
- this._x = x;
460
- }
461
- /** The quantized y component. */
462
- get y() { return this._y; }
463
- set y(y) {
464
- assert(Quantization.isQuantized(y));
465
- this._y = y;
466
- }
467
- /** The quantized z component. */
468
- get z() { return this._z; }
469
- set z(z) {
470
- assert(Quantization.isQuantized(z));
471
- this._z = z;
472
- }
473
- /** Initialize this point by quantizing the supplied { x, y, z } using the specified params */
474
- init(pos, params) {
475
- this.x = Quantization.quantize(pos.x, params.origin.x, params.scale.x);
476
- this.y = Quantization.quantize(pos.y, params.origin.y, params.scale.y);
477
- this.z = Quantization.quantize(pos.z, params.origin.z, params.scale.z);
478
- }
479
- /** Creates a quantized point from the supplied Point3d using the specified params */
480
- static create(pos, params) {
481
- const qpt = new QPoint3d();
482
- qpt.init(pos, params);
483
- return qpt;
484
- }
485
- /** Set this points components from `src`. */
486
- copyFrom(src) {
487
- this.x = src.x;
488
- this.y = src.y;
489
- this.z = src.z;
490
- }
491
- /** Create a copy of this point.
492
- * @param out If supplied, it will be modified in-place instead of allocating a new QPoint3d.
493
- */
494
- clone(out) {
495
- const result = undefined !== out ? out : new QPoint3d();
496
- result.copyFrom(this);
497
- return result;
498
- }
499
- /**
500
- * Sets the x, y, and z components directly.
501
- * @param x Must be an integer in the range [0, 0xffff]
502
- * @param y Must be an integer in the range [0, 0xffff]
503
- * @param z Must be an integer in the range [0, 0xffff]
504
- */
505
- setFromScalars(x, y, z) {
506
- this.x = x;
507
- this.y = y;
508
- this.z = z;
509
- }
510
- /**
511
- * Creates a QPoint3d directly from x, y, and z components.
512
- * @param x Must be an integer in the range [0, 0xffff]
513
- * @param y Must be an integer in the range [0, 0xffff]
514
- * @param z Must be an integer in the range [0, 0xffff]
515
- * @param out If supplied, it will be modified in-place instead of allocating a new QPoint3d.
516
- */
517
- static fromScalars(x, y, z, out) {
518
- const pt = undefined === out ? new QPoint3d() : out;
519
- pt.setFromScalars(x, y, z);
520
- return pt;
521
- }
522
- /** Returns a Point3d unquantized according to the supplied params.
523
- * If `out` is supplied, it will be modified in-place instead of allocating a new Point3d.
524
- */
525
- unquantize(params, out) {
526
- const pt = undefined !== out ? out : new Point3d();
527
- pt.x = Quantization.unquantize(this.x, params.origin.x, params.scale.x);
528
- pt.y = Quantization.unquantize(this.y, params.origin.y, params.scale.y);
529
- pt.z = Quantization.unquantize(this.z, params.origin.z, params.scale.z);
530
- return pt;
531
- }
532
- /** Return true if this point's components are identical to the other point's components. */
533
- equals(other) {
534
- return this.x === other.x && this.y === other.y && this.z === other.z;
535
- }
536
- /** Perform ordinal comparison to another point. The function returns:
537
- * - Zero if this point is identical to `rhs`; or
538
- * - A number less than zero if this point is ordered before `rhs`; or
539
- * - A number greater than zero if this point is ordered after `rhs`.
540
- * @see [OrderedComparator]($core-bentley).
541
- */
542
- compare(rhs) {
543
- let diff = this.x - rhs.x;
544
- if (0 === diff) {
545
- diff = this.y - rhs.y;
546
- if (0 === diff) {
547
- diff = this.z - rhs.z;
548
- }
549
- }
550
- return diff;
551
- }
552
- }
553
- /** @public
554
- * @extensions
555
- */
556
- export var QPoint3dBuffer;
557
- (function (QPoint3dBuffer) {
558
- const scratchQPoint3d = new QPoint3d();
559
- /** Extracts the point at the specified index from a buffer.
560
- * @param points The buffer in which each consecutive pair of integers is a 3d quantized point.
561
- * @param pointIndex The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
562
- * @param result If supplied, a preallocated [[QPoint3d]] to initialize with the result and return.
563
- * @returns The point at `pointIndex`.
564
- * @throws Error if `pointIndex` is out of bounds.
565
- */
566
- function getQPoint(points, pointIndex, result) {
567
- const index = pointIndex * 3;
568
- const x = points[index + 0];
569
- const y = points[index + 1];
570
- const z = points[index + 2];
571
- if (undefined === x || undefined === y || undefined === z)
572
- throw new Error("Index out of range");
573
- result = result ?? new QPoint3d();
574
- result.setFromScalars(x, y, z);
575
- return result;
576
- }
577
- QPoint3dBuffer.getQPoint = getQPoint;
578
- /** Extracts and unquantizes the point at the specified index from a buffer.
579
- * @param buffer The array of points and the quantization parameters.
580
- * @param The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
581
- * @param result If supplied, a preallocated [Point3d]($core-geometry) to initialize with the result and return.
582
- * @returns The point at `pointIndex`.
583
- * @throws Error if `pointIndex` is out of bounds.
584
- */
585
- function unquantizePoint(buffer, pointIndex, result) {
586
- const qpt = getQPoint(buffer.points, pointIndex, scratchQPoint3d);
587
- return qpt.unquantize(buffer.params, result);
588
- }
589
- QPoint3dBuffer.unquantizePoint = unquantizePoint;
590
- })(QPoint3dBuffer || (QPoint3dBuffer = {}));
591
- /** A list of [[QPoint3d]]s all quantized to the same range.
592
- * @public
593
- * @extensions
594
- */
595
- export class QPoint3dList {
596
- /** Construct an empty list set up to quantize to the supplied range.
597
- * @param The quantization parameters. If omitted, a null range will be used.
598
- */
599
- constructor(params) {
600
- this._list = [];
601
- this.params = params ? params.clone() : QParams3d.fromRange(Range3d.createNull());
602
- }
603
- /** The list of quantized points. */
604
- get list() {
605
- return this._list;
606
- }
607
- /** Construct a QPoint3dList containing all points in the supplied list, quantized to the range of those points.
608
- * @param The points to quantize and add to the list.
609
- * @param out If supplied, it will be cleared, its parameters recomputed, and the points will be added to it; otherwise, a new QPoint3dList will be created and returned.
610
- */
611
- static fromPoints(points, out) {
612
- let qPoints;
613
- const qParams = QParams3d.fromRange(Range3d.createArray(points));
614
- if (out) {
615
- qPoints = out;
616
- qPoints.reset(qParams);
617
- }
618
- else {
619
- qPoints = new QPoint3dList(qParams);
620
- }
621
- for (const point of points)
622
- qPoints.add(point);
623
- return qPoints;
624
- }
625
- /** Removes all points from the list. */
626
- clear() {
627
- this._list.length = 0;
628
- }
629
- /** Clears out the contents of the list and changes the quantization parameters. */
630
- reset(params) {
631
- this.clear();
632
- this.params.copyFrom(params);
633
- }
634
- /** Quantizes the supplied Point3d to this list's range and appends it to the list. */
635
- add(pt) {
636
- this._list.push(QPoint3d.create(pt, this.params));
637
- }
638
- /** Adds a previously-quantized point to this list. */
639
- push(qpt) {
640
- this._list.push(qpt.clone());
641
- }
642
- /** The number of points in the list. */
643
- get length() {
644
- return this._list.length;
645
- }
646
- /** Returns the unquantized value of the point at the specified index in the list. */
647
- unquantize(index, out) {
648
- assert(index < this.length);
649
- if (index < this.length) {
650
- return this._list[index].unquantize(this.params, out);
651
- }
652
- else {
653
- return undefined !== out ? out : new Point3d();
654
- }
655
- }
656
- /** Changes the quantization parameters and requantizes all points in the list to the new range.
657
- * @note The loss of precision is compounded each time the points are requantized to a new range.
658
- */
659
- requantize(params) {
660
- for (let i = 0; i < this.length; i++) {
661
- const pt = this.unquantize(i);
662
- this._list[i].init(pt, params);
663
- }
664
- this.params.copyFrom(params);
665
- }
666
- /** Extracts the current contents of the list as a Uint16Array such that the first 3 elements contain the first point's x, y, and z components,
667
- * the second three elements contain the second point's components, and so on.
668
- */
669
- toTypedArray() {
670
- const array = new Uint16Array(this.length * 3);
671
- const pts = this._list;
672
- for (let i = 0; i < this.length; i++) {
673
- const pt = pts[i];
674
- array[i * 3 + 0] = pt.x;
675
- array[i * 3 + 1] = pt.y;
676
- array[i * 3 + 2] = pt.z;
677
- }
678
- return array;
679
- }
680
- /** Reinitialize from a Uint16Array in which the first three elements specify the x, y, and z components of the first point, the second three elements specify the components
681
- * of the second point, and so on.
682
- */
683
- fromTypedArray(range, array) {
684
- this.params.setFromRange(range);
685
- this._list.length = array.length / 3;
686
- for (let i = 0, j = 0; i < this.list.length; i++)
687
- this._list[i] = QPoint3d.fromScalars(array[j++], array[j++], array[j++]);
688
- }
689
- /** Construct a list containing all points in the supplied list, quantized using the supplied parameters. */
690
- static createFrom(points, params) {
691
- const list = new QPoint3dList(params);
692
- for (const point of points)
693
- list.add(point);
694
- return list;
695
- }
696
- /** An iterator over the points in the list. */
697
- [Symbol.iterator]() {
698
- return this.list[Symbol.iterator]();
699
- }
700
- }
701
- /** Constructs a [[QPoint2dBuffer]] using a [Uint16ArrayBuilder]($bentley).
702
- * @public
703
- * @extensions
704
- */
705
- export class QPoint2dBufferBuilder {
706
- /** Construct a new buffer with a [[length]] of zero. */
707
- constructor(options) {
708
- this._scratchQPoint2d = new QPoint2d();
709
- this.params = QParams2d.fromRange(options.range);
710
- const initialCapacity = options.initialCapacity ?? 0;
711
- this.buffer = new Uint16ArrayBuilder({
712
- growthFactor: options.growthFactor,
713
- initialCapacity: 2 * initialCapacity,
714
- });
715
- }
716
- /** Append a point with the specified quantized coordinates. */
717
- pushXY(x, y) {
718
- this.buffer.push(x);
719
- this.buffer.push(y);
720
- }
721
- /** Append a point with the specified quantized coordinates. */
722
- push(pt) {
723
- this.pushXY(pt.x, pt.y);
724
- }
725
- /** The number of points currently in the [[buffer]]. */
726
- get length() {
727
- const len = this.buffer.length;
728
- assert(len % 2 === 0);
729
- return len / 2;
730
- }
731
- /** Returns the quantized point at the specified index in [[buffer]].
732
- * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
733
- * @param result If supplied, a [[QPoint2d]] to initialize with the result and return.
734
- * @returns The quantized point at the specified index in [[buffer]].
735
- * @throws Error if `pointIndex` is out of bounds.
736
- */
737
- get(pointIndex, result) {
738
- return QPoint2dBuffer.getQPoint(this.buffer.toTypedArray(), pointIndex, result);
739
- }
740
- /** Returns the unquantized point at the specified index in [[buffer]].
741
- * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
742
- * @param result If supplied, a [Point2d]($core-geometry) to initialize with the result and return.
743
- * @returns The unquantized point at the specified index in [[buffer]].
744
- * @throws Error if `pointIndex` is out of bounds.
745
- */
746
- unquantize(pointIndex, result) {
747
- return this.get(pointIndex, this._scratchQPoint2d).unquantize(this.params, result);
748
- }
749
- /** Obtain a [[QPoint2dBuffer]] containing all of the points that have been appended by this builder. */
750
- finish() {
751
- return {
752
- params: this.params,
753
- points: this.buffer.toTypedArray(),
754
- };
755
- }
756
- }
757
- /** Constructs a [[QPoint3dBuffer]] using a [Uint16ArrayBuilder]($bentley).
758
- * @public
759
- * @extensions
760
- */
761
- export class QPoint3dBufferBuilder {
762
- /** Construct a new buffer with a [[length]] of zero. */
763
- constructor(options) {
764
- this._scratchQPoint3d = new QPoint3d();
765
- this.params = QParams3d.fromRange(options.range);
766
- const initialCapacity = options.initialCapacity ?? 0;
767
- this.buffer = new Uint16ArrayBuilder({
768
- growthFactor: options.growthFactor,
769
- initialCapacity: 3 * initialCapacity,
770
- });
771
- }
772
- /** Append a point with the specified quantized coordinates. */
773
- pushXYZ(x, y, z) {
774
- this.buffer.push(x);
775
- this.buffer.push(y);
776
- this.buffer.push(z);
777
- }
778
- /** Append a point with the specified quantized coordinates. */
779
- push(pt) {
780
- this.pushXYZ(pt.x, pt.y, pt.z);
781
- }
782
- /** The number of points currently in the [[buffer]]. */
783
- get length() {
784
- const len = this.buffer.length;
785
- assert(len % 3 === 0);
786
- return len / 3;
787
- }
788
- /** Returns the quantized point at the specified index in [[buffer]].
789
- * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
790
- * @param result If supplied, a [[QPoint3d]] to initialize with the result and return.
791
- * @returns The quantized point at the specified index in [[buffer]].
792
- * @throws Error if `pointIndex` is out of bounds.
793
- */
794
- get(pointIndex, result) {
795
- return QPoint3dBuffer.getQPoint(this.buffer.toTypedArray(), pointIndex, result);
796
- }
797
- /** Returns the unquantized point at the specified index in [[buffer]].
798
- * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
799
- * @param result If supplied, a [Point3d]($core-geometry) to initialize with the result and return.
800
- * @returns The unquantized point at the specified index in [[buffer]].
801
- * @throws Error if `pointIndex` is out of bounds.
802
- */
803
- unquantize(pointIndex, result) {
804
- return this.get(pointIndex, this._scratchQPoint3d).unquantize(this.params, result);
805
- }
806
- /** Obtain a [[QPoint3dBuffer]] containing all of the points that have been appended by this builder. */
807
- finish() {
808
- return {
809
- params: this.params,
810
- points: this.buffer.toTypedArray(),
811
- };
812
- }
813
- }
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
+ * See LICENSE.md in the project root for license terms and full copyright notice.
4
+ *--------------------------------------------------------------------------------------------*/
5
+ /** @packageDocumentation
6
+ * @module Geometry
7
+ */
8
+ import { assert, Uint16ArrayBuilder } from "@itwin/core-bentley";
9
+ import { Point2d, Point3d, Range2d, Range3d, Vector2d, Vector3d, } from "@itwin/core-geometry";
10
+ /**
11
+ * Provides facilities for quantizing floating point values within a specified range into 16-bit unsigned integers.
12
+ * This is a lossy compression technique.
13
+ * Given a floating point range [min, max], a floating point value `x` within that range is quantized by subtracting
14
+ * `min`, scaling the result according to `max`, and truncating the result to an integer.
15
+ * Therefore min quantizes to 0, max to 0xffff, (min+max)/2 to 0x7fff, and so on.
16
+ * These routines are chiefly used by classes like [[QPoint2d]] and [[QPoint3d]] to reduce the space required to store
17
+ * coordinate values for [RenderGraphic]($frontend)s.
18
+ * @public
19
+ * @extensions
20
+ */
21
+ export var Quantization;
22
+ (function (Quantization) {
23
+ Quantization.rangeScale16 = 0xffff;
24
+ Quantization.rangeScale8 = 0xff;
25
+ /** Compute the scale factor required to quantize `extent` to `rangeScale` discrete values. */
26
+ function computeScale(extent, rangeScale = Quantization.rangeScale16) {
27
+ return 0.0 === extent ? extent : rangeScale / extent;
28
+ }
29
+ Quantization.computeScale = computeScale;
30
+ /** @internal */
31
+ function isInRange(qpos, rangeScale = Quantization.rangeScale16) {
32
+ return qpos >= 0.0 && qpos < rangeScale + 1.0;
33
+ }
34
+ Quantization.isInRange = isInRange;
35
+ /** Return `pos` quantized to the range [`origin`, `origin + rangeScale`].
36
+ * @see [[Quantization.unquantize]] for the inverse operation.
37
+ */
38
+ function quantize(pos, origin, scale, rangeScale = Quantization.rangeScale16) {
39
+ return Math.floor(Math.max(0.0, Math.min(rangeScale, 0.5 + (pos - origin) * scale)));
40
+ }
41
+ Quantization.quantize = quantize;
42
+ /** @internal */
43
+ function isQuantizable(pos, origin, scale, rangeScale = Quantization.rangeScale16) {
44
+ return isInRange(quantize(pos, origin, scale, rangeScale));
45
+ }
46
+ Quantization.isQuantizable = isQuantizable;
47
+ /** Give `qpos` quantized to the range [`origin`, `origin + rangeScale`], return the unquantized value.
48
+ * @see [[Quantization.quantize]] for the inverse operation.
49
+ */
50
+ function unquantize(qpos, origin, scale) {
51
+ return 0.0 === scale ? origin : origin + qpos / scale;
52
+ }
53
+ Quantization.unquantize = unquantize;
54
+ /** @internal */
55
+ function isQuantized(qpos) {
56
+ return isInRange(qpos) && qpos === Math.floor(qpos);
57
+ }
58
+ Quantization.isQuantized = isQuantized;
59
+ })(Quantization || (Quantization = {}));
60
+ /** Parameters used for [[Quantization]] of 2d points such that the `x` and `y` components are each quantized to 16-bit unsigned integers.
61
+ * @see [[QPoint2d]] for the quantized representation of a [Point2d]($core-geometry).
62
+ * @see [[QPoint2dList]] for a list of [[QPoint2d]]s quantized using a [[QParams2d]].
63
+ * @public
64
+ * @extensions
65
+ */
66
+ export class QParams2d {
67
+ constructor(ox = 0, oy = 0, sx = 0, sy = 0) {
68
+ /** The origin of the quantization range. */
69
+ this.origin = new Point2d();
70
+ /** The scale applied to coordinates to quantize them. */
71
+ this.scale = new Point2d();
72
+ this.setFrom(ox, oy, sx, sy);
73
+ }
74
+ setFrom(ox, oy, sx, sy) {
75
+ this.origin.x = ox;
76
+ this.origin.y = oy;
77
+ this.scale.x = sx;
78
+ this.scale.y = sy;
79
+ }
80
+ /** Set [[origin]] and [[scale]] from `src`. */
81
+ copyFrom(src) {
82
+ this.setFrom(src.origin.x, src.origin.y, src.scale.x, src.scale.y);
83
+ }
84
+ /** Create a copy of these params.
85
+ * @param out If supplied, these QParams2d will be modified and returned; otherwise a new QParams2d object will be created and returned.
86
+ */
87
+ clone(out) {
88
+ const result = undefined !== out ? out : new QParams2d();
89
+ result.copyFrom(this);
90
+ return result;
91
+ }
92
+ /** Initialize these parameters to support quantization of values within the specified range. */
93
+ setFromRange(range, rangeScale = Quantization.rangeScale16) {
94
+ if (!range.isNull) {
95
+ this.setFrom(range.low.x, range.low.y, Quantization.computeScale(range.high.x - range.low.x, rangeScale), Quantization.computeScale(range.high.y - range.low.y, rangeScale));
96
+ }
97
+ else {
98
+ this.origin.x = this.origin.y = this.scale.x = this.scale.y = 0;
99
+ }
100
+ }
101
+ /** Create parameters to support quantization of values within the specified range. */
102
+ static fromRange(range, out, rangeScale = Quantization.rangeScale16) {
103
+ const params = undefined !== out ? out : new QParams2d();
104
+ params.setFromRange(range, rangeScale);
105
+ return params;
106
+ }
107
+ /** Return the unquantized point for the input `x` and `y` components. If `out` is supplied, it will be modified to hold the result and returned. */
108
+ unquantize(x, y, out) {
109
+ out = out ?? new Point2d();
110
+ out.x = Quantization.unquantize(x, this.origin.x, this.scale.x);
111
+ out.y = Quantization.unquantize(y, this.origin.y, this.scale.y);
112
+ return out;
113
+ }
114
+ /** Creates parameters supporting quantization of values within the range [-1.0, 1.0], appropriate for normalized 2d vectors. */
115
+ static fromNormalizedRange(rangeScale = Quantization.rangeScale16) {
116
+ return QParams2d.fromRange(Range2d.createArray([Point2d.create(-1, -1), Point2d.create(1, 1)]), undefined, rangeScale);
117
+ }
118
+ /** Create parameters supporting quantization of values within the range [0.0, 1.0]. */
119
+ static fromZeroToOne(rangeScale = Quantization.rangeScale16) {
120
+ return QParams2d.fromRange(Range2d.createArray([Point2d.create(0, 0), Point2d.create(1, 1)]), undefined, rangeScale);
121
+ }
122
+ /** Create parameters from origin and scale components */
123
+ static fromOriginAndScale(originX, originY, scaleX, scaleY) {
124
+ return new QParams2d(originX, originY, scaleX, scaleY);
125
+ }
126
+ /** @internal */
127
+ get rangeDiagonal() {
128
+ return Vector2d.createFrom({ x: 0 === this.scale.x ? 0 : Quantization.rangeScale16 / this.scale.x, y: 0 === this.scale.y ? 0 : Quantization.rangeScale16 / this.scale.y });
129
+ }
130
+ /** Return true if the point point is quantizable using these parameters. */
131
+ isQuantizable(point) {
132
+ return Quantization.isQuantizable(point.x, this.origin.x, this.scale.x) && Quantization.isQuantizable(point.y, this.origin.y, this.scale.y);
133
+ }
134
+ }
135
+ /** Represents a [Point2d]($core-geometry) compressed such that each component `x` and `y` is quantized to the 16-bit integer range [0, 0xffff].
136
+ * These are primarily used to reduce the space required for coordinates used by [RenderGraphic]($frontend)s.
137
+ * @see [[QParams2d]] to define quantization parameters for a range of points.
138
+ * @see [[QPoint2dList]] for a list of points all quantized to the same range.
139
+ * @public
140
+ * @extensions
141
+ */
142
+ export class QPoint2d {
143
+ /** Construct with `x` and `y` initialized to zero. */
144
+ constructor() {
145
+ this._x = 0;
146
+ this._y = 0;
147
+ }
148
+ /** The quantized x component. */
149
+ get x() { return this._x; }
150
+ set x(x) {
151
+ assert(Quantization.isQuantized(x));
152
+ this._x = x;
153
+ }
154
+ /** The quantized y component. */
155
+ get y() { return this._y; }
156
+ set y(y) {
157
+ assert(Quantization.isQuantized(y));
158
+ this._y = y;
159
+ }
160
+ /** Initialize this point by quantizing the supplied { x, y } using the specified params */
161
+ init(pos, params) {
162
+ this.x = Quantization.quantize(pos.x, params.origin.x, params.scale.x);
163
+ this.y = Quantization.quantize(pos.y, params.origin.y, params.scale.y);
164
+ }
165
+ /** Create a quantized point from the supplied Point2d using the specified params */
166
+ static create(pos, params) {
167
+ const qpt = new QPoint2d();
168
+ qpt.init(pos, params);
169
+ return qpt;
170
+ }
171
+ /** Initialize `x` and `y` from `src`. */
172
+ copyFrom(src) {
173
+ this.x = src.x;
174
+ this.y = src.y;
175
+ }
176
+ /** Create a copy of this point.
177
+ * @param out If supplied, it will be modified in-place and returned; otherwise a new QPoint2d will be allocated and returned.
178
+ */
179
+ clone(out) {
180
+ const result = undefined !== out ? out : new QPoint2d();
181
+ result.copyFrom(this);
182
+ return result;
183
+ }
184
+ /**
185
+ * Set the x and y components directly.
186
+ * @param x Must be an integer in the range [0, 0xffff]
187
+ * @param y Must be an integer in the range [0, 0xffff]
188
+ */
189
+ setFromScalars(x, y) {
190
+ this.x = x;
191
+ this.y = y;
192
+ }
193
+ /**
194
+ * Create a QPoint2d directly from x and y components.
195
+ * @param x Must be an integer in the range [0, 0xffff]
196
+ * @param y Must be an integer in the range [0, 0xffff]
197
+ */
198
+ static fromScalars(x, y) {
199
+ const pt = new QPoint2d();
200
+ pt.setFromScalars(x, y);
201
+ return pt;
202
+ }
203
+ /** Return a Point2d unquantized according to the supplied `params`. If `out` is supplied, it will be modified in-place and returned. */
204
+ unquantize(params, out) {
205
+ const pt = undefined !== out ? out : new Point2d();
206
+ pt.x = Quantization.unquantize(this.x, params.origin.x, params.scale.x);
207
+ pt.y = Quantization.unquantize(this.y, params.origin.y, params.scale.y);
208
+ return pt;
209
+ }
210
+ }
211
+ /** @public
212
+ * @extensions
213
+ */
214
+ export var QPoint2dBuffer;
215
+ (function (QPoint2dBuffer) {
216
+ const scratchQPoint2d = new QPoint2d();
217
+ /** Extracts the point at the specified index from a buffer.
218
+ * @param points The buffer in which each consecutive pair of integers is a 2d quantized point.
219
+ * @param pointIndex The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
220
+ * @param result If supplied, a preallocated [[QPoint2d]] to initialize with the result and return.
221
+ * @returns The point at `pointIndex`.
222
+ * @throws Error if `pointIndex` is out of bounds.
223
+ */
224
+ function getQPoint(points, pointIndex, result) {
225
+ const index = pointIndex * 2;
226
+ const x = points[index + 0];
227
+ const y = points[index + 1];
228
+ if (undefined === x || undefined === y)
229
+ throw new Error("Index out of range");
230
+ result = result ?? new QPoint2d();
231
+ result.setFromScalars(x, y);
232
+ return result;
233
+ }
234
+ QPoint2dBuffer.getQPoint = getQPoint;
235
+ /** Extracts and unquantizes the point at the specified index from a buffer.
236
+ * @param buffer The array of points and the quantization parameters.
237
+ * @param The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
238
+ * @param result If supplied, a preallocated [Point2d]($core-geometry) to initialize with the result and return.
239
+ * @returns The point at `pointIndex`.
240
+ * @throws Error if `pointIndex` is out of bounds.
241
+ */
242
+ function unquantizePoint(buffer, pointIndex, result) {
243
+ const qpt = getQPoint(buffer.points, pointIndex, scratchQPoint2d);
244
+ return qpt.unquantize(buffer.params, result);
245
+ }
246
+ QPoint2dBuffer.unquantizePoint = unquantizePoint;
247
+ })(QPoint2dBuffer || (QPoint2dBuffer = {}));
248
+ /** A list of [[QPoint2d]]s all quantized to the same range.
249
+ * @public
250
+ * @extensions
251
+ */
252
+ export class QPoint2dList {
253
+ /** Construct an empty list set up to use the supplied quantization parameters. */
254
+ constructor(params) {
255
+ this._list = new Array();
256
+ this.params = params.clone();
257
+ }
258
+ /** The list of quantized points. */
259
+ get list() {
260
+ return this._list;
261
+ }
262
+ /** Removes all points from the list. */
263
+ clear() {
264
+ this._list.length = 0;
265
+ }
266
+ /** Removes all points from the list and change the quantization parameters. */
267
+ reset(params) {
268
+ this.clear();
269
+ this.params.copyFrom(params);
270
+ }
271
+ /** Quantizes the supplied Point2d to this list's range and appends it to the list. */
272
+ add(pt) {
273
+ this._list.push(QPoint2d.create(pt, this.params));
274
+ }
275
+ /** Adds a previously-quantized point to this list. */
276
+ push(qpt) {
277
+ this._list.push(qpt.clone());
278
+ }
279
+ /** The number of points in the list. */
280
+ get length() {
281
+ return this._list.length;
282
+ }
283
+ /** Returns the unquantized value of the point at the specified index in the list. */
284
+ unquantize(index, out) {
285
+ assert(index < this.length);
286
+ if (index < this.length) {
287
+ return this._list[index].unquantize(this.params, out);
288
+ }
289
+ else {
290
+ return undefined !== out ? out : new Point2d();
291
+ }
292
+ }
293
+ /** Changes the quantization parameters and requantizes all points in the list to the new range.
294
+ * @note The loss of precision is compounded each time the points are requantized to a new range.
295
+ */
296
+ requantize(params) {
297
+ for (let i = 0; i < this.length; i++) {
298
+ const pt = this.unquantize(i);
299
+ this._list[i].init(pt, params);
300
+ }
301
+ this.params.copyFrom(params);
302
+ }
303
+ /** Extracts the current contents of the list as a Uint16Array such that the first element of the array corresponds to the first point's `x` component,
304
+ * the second to the first point's `y` component, and so on.
305
+ */
306
+ toTypedArray() {
307
+ const array = new Uint16Array(this.length * 2);
308
+ const pts = this._list;
309
+ for (let i = 0; i < this.length; i++) {
310
+ const pt = pts[i];
311
+ array[i * 2] = pt.x;
312
+ array[i * 2 + 1] = pt.y;
313
+ }
314
+ return array;
315
+ }
316
+ /** Create from a Uint16Array laid out such that `array[0]` corresponds to the first point's `x` component, `array[1]` to the first point's `y` component, and so on. */
317
+ fromTypedArray(range, array) {
318
+ this.params.setFromRange(range);
319
+ this._list.length = array.length / 2;
320
+ for (let i = 0, j = 0; i < this.list.length; i++)
321
+ this._list[i] = QPoint2d.fromScalars(array[j++], array[j++]);
322
+ }
323
+ /** Construct a QPoint2dList containing all points in the supplied list, quantized to the range of those points. */
324
+ static fromPoints(points, out) {
325
+ let qPoints;
326
+ const qParams = QParams2d.fromRange(Range2d.createArray(points));
327
+ if (out) {
328
+ qPoints = out;
329
+ qPoints.reset(qParams);
330
+ }
331
+ else {
332
+ qPoints = new QPoint2dList(qParams);
333
+ }
334
+ for (const point of points)
335
+ qPoints.add(point);
336
+ return qPoints;
337
+ }
338
+ }
339
+ /** Parameters used for [[Quantization]] of 3d points such that the `x`, `y`, and `z` components are each quantized to 16-bit unsigned integers.
340
+ * @see [[QPoint3d]] for the quantized representation of a [Point3d]($core-geometry).
341
+ * @see [[QPoint3dList]] for a list of [[QPoint3d]]s quantized using a [[QParams3d]].
342
+ * @public
343
+ * @extensions
344
+ */
345
+ export class QParams3d {
346
+ constructor(ox = 0, oy = 0, oz = 0, sx = 0, sy = 0, sz = 0) {
347
+ /** The origin of the quantization range. */
348
+ this.origin = new Point3d();
349
+ /** The scale applied to coordinates to quantize them. */
350
+ this.scale = new Point3d();
351
+ this.setFrom(ox, oy, oz, sx, sy, sz);
352
+ }
353
+ setFrom(ox, oy, oz, sx, sy, sz) {
354
+ this.origin.x = ox;
355
+ this.origin.y = oy;
356
+ this.origin.z = oz;
357
+ this.scale.x = sx;
358
+ this.scale.y = sy;
359
+ this.scale.z = sz;
360
+ }
361
+ /** Set `x`, `y`, and `z` from `src. */
362
+ copyFrom(src) {
363
+ this.setFrom(src.origin.x, src.origin.y, src.origin.z, src.scale.x, src.scale.y, src.scale.z);
364
+ }
365
+ /** Create a copy of these parameters.
366
+ * @param out If supplied, it will be modified in-place and returned instead of allocating a new QParams3d.
367
+ */
368
+ clone(out) {
369
+ const result = undefined !== out ? out : new QParams3d();
370
+ result.copyFrom(this);
371
+ return result;
372
+ }
373
+ /** Initialize from origin and scale */
374
+ setFromOriginAndScale(origin, scale) {
375
+ this.setFrom(origin.x, origin.y, origin.z, scale.x, scale.y, scale.z);
376
+ }
377
+ /** Initialize these parameters to support quantization of values within the specified range. */
378
+ setFromRange(range, rangeScale = Quantization.rangeScale16) {
379
+ if (!range.isNull) {
380
+ this.setFrom(range.low.x, range.low.y, range.low.z, Quantization.computeScale(range.high.x - range.low.x, rangeScale), Quantization.computeScale(range.high.y - range.low.y, rangeScale), Quantization.computeScale(range.high.z - range.low.z, rangeScale));
381
+ }
382
+ else {
383
+ this.origin.x = this.origin.y = this.origin.z = 0;
384
+ this.scale.x = this.scale.y = this.scale.z = 0;
385
+ }
386
+ }
387
+ /** Return the unquantized point for the input components.
388
+ * @param out If supplied, it will be modified in-place and returned instead of allocating a new Point3d.
389
+ */
390
+ unquantize(x, y, z, out) {
391
+ const pt = undefined !== out ? out : new Point3d();
392
+ pt.x = Quantization.unquantize(x, this.origin.x, this.scale.x);
393
+ pt.y = Quantization.unquantize(y, this.origin.y, this.scale.y);
394
+ pt.z = Quantization.unquantize(z, this.origin.z, this.scale.z);
395
+ return pt;
396
+ }
397
+ /** Creates parameters to support quantization of values within the specified range.
398
+ * If `out` is supplied, it will be modified in-place and returned instead of allocating a new QParams3d.
399
+ */
400
+ static fromRange(range, out, rangeScale = Quantization.rangeScale16) {
401
+ const params = undefined !== out ? out : new QParams3d();
402
+ params.setFromRange(range, rangeScale);
403
+ return params;
404
+ }
405
+ /** Creates parameters supporting quantization of values within the range [-1.0, 1.0].
406
+ * If `out` is supplied, it will be modified in-place and returned instead of allocating a new QParams3d.
407
+ */
408
+ static fromOriginAndScale(origin, scale, out) {
409
+ const params = undefined !== out ? out : new QParams3d();
410
+ params.setFromOriginAndScale(origin, scale);
411
+ return params;
412
+ }
413
+ /** Creates parameters supporting quantization of values within the range [-1.0, 1.0]. */
414
+ static fromNormalizedRange(rangeScale = Quantization.rangeScale16) {
415
+ return QParams3d.fromRange(Range3d.createArray([Point3d.create(-1, -1, -1), Point3d.create(1, 1, 1)]), undefined, rangeScale);
416
+ }
417
+ /** Creates parameters supporting quantization of values within the range [0.0, 1.0]. */
418
+ static fromZeroToOne(rangeScale = Quantization.rangeScale16) {
419
+ return QParams3d.fromRange(Range3d.createArray([Point3d.create(0, 0, 0), Point3d.create(1, 1, 1)]), undefined, rangeScale);
420
+ }
421
+ /** @internal */
422
+ get rangeDiagonal() {
423
+ return Vector3d.createFrom({
424
+ x: this.scale.x === 0 ? 0 : Quantization.rangeScale16 / this.scale.x,
425
+ y: this.scale.y === 0 ? 0 : Quantization.rangeScale16 / this.scale.y,
426
+ z: this.scale.z === 0 ? 0 : Quantization.rangeScale16 / this.scale.z,
427
+ });
428
+ }
429
+ /** Return true if the point point is quantizable using these parameters. */
430
+ isQuantizable(point) {
431
+ return Quantization.isQuantizable(point.x, this.origin.x, this.scale.x) && Quantization.isQuantizable(point.y, this.origin.y, this.scale.y) && Quantization.isQuantizable(point.z, this.origin.z, this.scale.z);
432
+ }
433
+ /** Compute the range to which these parameters quantize. */
434
+ computeRange(out) {
435
+ const range = Range3d.createNull(out);
436
+ range.extendPoint(this.origin);
437
+ range.extendPoint(this.origin.plus(this.rangeDiagonal));
438
+ return range;
439
+ }
440
+ }
441
+ /** Represents a [Point3d]($core-geometry) compressed such that each component `x`, `y`, and `z` is quantized to the 16-bit integer range [0, 0xffff].
442
+ * These are primarily used to reduce the space required for coordinates used by [RenderGraphic]($frontend)s.
443
+ * @see [[QParams3d]] to define quantization parameters for a range of points.
444
+ * @see [[QPoint3dList]] for a list of points all quantized to the same range.
445
+ * @public
446
+ * @extensions
447
+ */
448
+ export class QPoint3d {
449
+ /** Construct with all components initialized to zero. */
450
+ constructor() {
451
+ this._x = 0;
452
+ this._y = 0;
453
+ this._z = 0;
454
+ }
455
+ /** The quantized x component. */
456
+ get x() { return this._x; }
457
+ set x(x) {
458
+ assert(Quantization.isQuantized(x));
459
+ this._x = x;
460
+ }
461
+ /** The quantized y component. */
462
+ get y() { return this._y; }
463
+ set y(y) {
464
+ assert(Quantization.isQuantized(y));
465
+ this._y = y;
466
+ }
467
+ /** The quantized z component. */
468
+ get z() { return this._z; }
469
+ set z(z) {
470
+ assert(Quantization.isQuantized(z));
471
+ this._z = z;
472
+ }
473
+ /** Initialize this point by quantizing the supplied { x, y, z } using the specified params */
474
+ init(pos, params) {
475
+ this.x = Quantization.quantize(pos.x, params.origin.x, params.scale.x);
476
+ this.y = Quantization.quantize(pos.y, params.origin.y, params.scale.y);
477
+ this.z = Quantization.quantize(pos.z, params.origin.z, params.scale.z);
478
+ }
479
+ /** Creates a quantized point from the supplied Point3d using the specified params */
480
+ static create(pos, params) {
481
+ const qpt = new QPoint3d();
482
+ qpt.init(pos, params);
483
+ return qpt;
484
+ }
485
+ /** Set this points components from `src`. */
486
+ copyFrom(src) {
487
+ this.x = src.x;
488
+ this.y = src.y;
489
+ this.z = src.z;
490
+ }
491
+ /** Create a copy of this point.
492
+ * @param out If supplied, it will be modified in-place instead of allocating a new QPoint3d.
493
+ */
494
+ clone(out) {
495
+ const result = undefined !== out ? out : new QPoint3d();
496
+ result.copyFrom(this);
497
+ return result;
498
+ }
499
+ /**
500
+ * Sets the x, y, and z components directly.
501
+ * @param x Must be an integer in the range [0, 0xffff]
502
+ * @param y Must be an integer in the range [0, 0xffff]
503
+ * @param z Must be an integer in the range [0, 0xffff]
504
+ */
505
+ setFromScalars(x, y, z) {
506
+ this.x = x;
507
+ this.y = y;
508
+ this.z = z;
509
+ }
510
+ /**
511
+ * Creates a QPoint3d directly from x, y, and z components.
512
+ * @param x Must be an integer in the range [0, 0xffff]
513
+ * @param y Must be an integer in the range [0, 0xffff]
514
+ * @param z Must be an integer in the range [0, 0xffff]
515
+ * @param out If supplied, it will be modified in-place instead of allocating a new QPoint3d.
516
+ */
517
+ static fromScalars(x, y, z, out) {
518
+ const pt = undefined === out ? new QPoint3d() : out;
519
+ pt.setFromScalars(x, y, z);
520
+ return pt;
521
+ }
522
+ /** Returns a Point3d unquantized according to the supplied params.
523
+ * If `out` is supplied, it will be modified in-place instead of allocating a new Point3d.
524
+ */
525
+ unquantize(params, out) {
526
+ const pt = undefined !== out ? out : new Point3d();
527
+ pt.x = Quantization.unquantize(this.x, params.origin.x, params.scale.x);
528
+ pt.y = Quantization.unquantize(this.y, params.origin.y, params.scale.y);
529
+ pt.z = Quantization.unquantize(this.z, params.origin.z, params.scale.z);
530
+ return pt;
531
+ }
532
+ /** Return true if this point's components are identical to the other point's components. */
533
+ equals(other) {
534
+ return this.x === other.x && this.y === other.y && this.z === other.z;
535
+ }
536
+ /** Perform ordinal comparison to another point. The function returns:
537
+ * - Zero if this point is identical to `rhs`; or
538
+ * - A number less than zero if this point is ordered before `rhs`; or
539
+ * - A number greater than zero if this point is ordered after `rhs`.
540
+ * @see [OrderedComparator]($core-bentley).
541
+ */
542
+ compare(rhs) {
543
+ let diff = this.x - rhs.x;
544
+ if (0 === diff) {
545
+ diff = this.y - rhs.y;
546
+ if (0 === diff) {
547
+ diff = this.z - rhs.z;
548
+ }
549
+ }
550
+ return diff;
551
+ }
552
+ }
553
+ /** @public
554
+ * @extensions
555
+ */
556
+ export var QPoint3dBuffer;
557
+ (function (QPoint3dBuffer) {
558
+ const scratchQPoint3d = new QPoint3d();
559
+ /** Extracts the point at the specified index from a buffer.
560
+ * @param points The buffer in which each consecutive pair of integers is a 3d quantized point.
561
+ * @param pointIndex The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
562
+ * @param result If supplied, a preallocated [[QPoint3d]] to initialize with the result and return.
563
+ * @returns The point at `pointIndex`.
564
+ * @throws Error if `pointIndex` is out of bounds.
565
+ */
566
+ function getQPoint(points, pointIndex, result) {
567
+ const index = pointIndex * 3;
568
+ const x = points[index + 0];
569
+ const y = points[index + 1];
570
+ const z = points[index + 2];
571
+ if (undefined === x || undefined === y || undefined === z)
572
+ throw new Error("Index out of range");
573
+ result = result ?? new QPoint3d();
574
+ result.setFromScalars(x, y, z);
575
+ return result;
576
+ }
577
+ QPoint3dBuffer.getQPoint = getQPoint;
578
+ /** Extracts and unquantizes the point at the specified index from a buffer.
579
+ * @param buffer The array of points and the quantization parameters.
580
+ * @param The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
581
+ * @param result If supplied, a preallocated [Point3d]($core-geometry) to initialize with the result and return.
582
+ * @returns The point at `pointIndex`.
583
+ * @throws Error if `pointIndex` is out of bounds.
584
+ */
585
+ function unquantizePoint(buffer, pointIndex, result) {
586
+ const qpt = getQPoint(buffer.points, pointIndex, scratchQPoint3d);
587
+ return qpt.unquantize(buffer.params, result);
588
+ }
589
+ QPoint3dBuffer.unquantizePoint = unquantizePoint;
590
+ })(QPoint3dBuffer || (QPoint3dBuffer = {}));
591
+ /** A list of [[QPoint3d]]s all quantized to the same range.
592
+ * @public
593
+ * @extensions
594
+ */
595
+ export class QPoint3dList {
596
+ /** Construct an empty list set up to quantize to the supplied range.
597
+ * @param The quantization parameters. If omitted, a null range will be used.
598
+ */
599
+ constructor(params) {
600
+ this._list = [];
601
+ this.params = params ? params.clone() : QParams3d.fromRange(Range3d.createNull());
602
+ }
603
+ /** The list of quantized points. */
604
+ get list() {
605
+ return this._list;
606
+ }
607
+ /** Construct a QPoint3dList containing all points in the supplied list, quantized to the range of those points.
608
+ * @param The points to quantize and add to the list.
609
+ * @param out If supplied, it will be cleared, its parameters recomputed, and the points will be added to it; otherwise, a new QPoint3dList will be created and returned.
610
+ */
611
+ static fromPoints(points, out) {
612
+ let qPoints;
613
+ const qParams = QParams3d.fromRange(Range3d.createArray(points));
614
+ if (out) {
615
+ qPoints = out;
616
+ qPoints.reset(qParams);
617
+ }
618
+ else {
619
+ qPoints = new QPoint3dList(qParams);
620
+ }
621
+ for (const point of points)
622
+ qPoints.add(point);
623
+ return qPoints;
624
+ }
625
+ /** Removes all points from the list. */
626
+ clear() {
627
+ this._list.length = 0;
628
+ }
629
+ /** Clears out the contents of the list and changes the quantization parameters. */
630
+ reset(params) {
631
+ this.clear();
632
+ this.params.copyFrom(params);
633
+ }
634
+ /** Quantizes the supplied Point3d to this list's range and appends it to the list. */
635
+ add(pt) {
636
+ this._list.push(QPoint3d.create(pt, this.params));
637
+ }
638
+ /** Adds a previously-quantized point to this list. */
639
+ push(qpt) {
640
+ this._list.push(qpt.clone());
641
+ }
642
+ /** The number of points in the list. */
643
+ get length() {
644
+ return this._list.length;
645
+ }
646
+ /** Returns the unquantized value of the point at the specified index in the list. */
647
+ unquantize(index, out) {
648
+ assert(index < this.length);
649
+ if (index < this.length) {
650
+ return this._list[index].unquantize(this.params, out);
651
+ }
652
+ else {
653
+ return undefined !== out ? out : new Point3d();
654
+ }
655
+ }
656
+ /** Changes the quantization parameters and requantizes all points in the list to the new range.
657
+ * @note The loss of precision is compounded each time the points are requantized to a new range.
658
+ */
659
+ requantize(params) {
660
+ for (let i = 0; i < this.length; i++) {
661
+ const pt = this.unquantize(i);
662
+ this._list[i].init(pt, params);
663
+ }
664
+ this.params.copyFrom(params);
665
+ }
666
+ /** Extracts the current contents of the list as a Uint16Array such that the first 3 elements contain the first point's x, y, and z components,
667
+ * the second three elements contain the second point's components, and so on.
668
+ */
669
+ toTypedArray() {
670
+ const array = new Uint16Array(this.length * 3);
671
+ const pts = this._list;
672
+ for (let i = 0; i < this.length; i++) {
673
+ const pt = pts[i];
674
+ array[i * 3 + 0] = pt.x;
675
+ array[i * 3 + 1] = pt.y;
676
+ array[i * 3 + 2] = pt.z;
677
+ }
678
+ return array;
679
+ }
680
+ /** Reinitialize from a Uint16Array in which the first three elements specify the x, y, and z components of the first point, the second three elements specify the components
681
+ * of the second point, and so on.
682
+ */
683
+ fromTypedArray(range, array) {
684
+ this.params.setFromRange(range);
685
+ this._list.length = array.length / 3;
686
+ for (let i = 0, j = 0; i < this.list.length; i++)
687
+ this._list[i] = QPoint3d.fromScalars(array[j++], array[j++], array[j++]);
688
+ }
689
+ /** Construct a list containing all points in the supplied list, quantized using the supplied parameters. */
690
+ static createFrom(points, params) {
691
+ const list = new QPoint3dList(params);
692
+ for (const point of points)
693
+ list.add(point);
694
+ return list;
695
+ }
696
+ /** An iterator over the points in the list. */
697
+ [Symbol.iterator]() {
698
+ return this.list[Symbol.iterator]();
699
+ }
700
+ }
701
+ /** Constructs a [[QPoint2dBuffer]] using a [Uint16ArrayBuilder]($bentley).
702
+ * @public
703
+ * @extensions
704
+ */
705
+ export class QPoint2dBufferBuilder {
706
+ /** Construct a new buffer with a [[length]] of zero. */
707
+ constructor(options) {
708
+ this._scratchQPoint2d = new QPoint2d();
709
+ this.params = QParams2d.fromRange(options.range);
710
+ const initialCapacity = options.initialCapacity ?? 0;
711
+ this.buffer = new Uint16ArrayBuilder({
712
+ growthFactor: options.growthFactor,
713
+ initialCapacity: 2 * initialCapacity,
714
+ });
715
+ }
716
+ /** Append a point with the specified quantized coordinates. */
717
+ pushXY(x, y) {
718
+ this.buffer.push(x);
719
+ this.buffer.push(y);
720
+ }
721
+ /** Append a point with the specified quantized coordinates. */
722
+ push(pt) {
723
+ this.pushXY(pt.x, pt.y);
724
+ }
725
+ /** The number of points currently in the [[buffer]]. */
726
+ get length() {
727
+ const len = this.buffer.length;
728
+ assert(len % 2 === 0);
729
+ return len / 2;
730
+ }
731
+ /** Returns the quantized point at the specified index in [[buffer]].
732
+ * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
733
+ * @param result If supplied, a [[QPoint2d]] to initialize with the result and return.
734
+ * @returns The quantized point at the specified index in [[buffer]].
735
+ * @throws Error if `pointIndex` is out of bounds.
736
+ */
737
+ get(pointIndex, result) {
738
+ return QPoint2dBuffer.getQPoint(this.buffer.toTypedArray(), pointIndex, result);
739
+ }
740
+ /** Returns the unquantized point at the specified index in [[buffer]].
741
+ * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
742
+ * @param result If supplied, a [Point2d]($core-geometry) to initialize with the result and return.
743
+ * @returns The unquantized point at the specified index in [[buffer]].
744
+ * @throws Error if `pointIndex` is out of bounds.
745
+ */
746
+ unquantize(pointIndex, result) {
747
+ return this.get(pointIndex, this._scratchQPoint2d).unquantize(this.params, result);
748
+ }
749
+ /** Obtain a [[QPoint2dBuffer]] containing all of the points that have been appended by this builder. */
750
+ finish() {
751
+ return {
752
+ params: this.params,
753
+ points: this.buffer.toTypedArray(),
754
+ };
755
+ }
756
+ }
757
+ /** Constructs a [[QPoint3dBuffer]] using a [Uint16ArrayBuilder]($bentley).
758
+ * @public
759
+ * @extensions
760
+ */
761
+ export class QPoint3dBufferBuilder {
762
+ /** Construct a new buffer with a [[length]] of zero. */
763
+ constructor(options) {
764
+ this._scratchQPoint3d = new QPoint3d();
765
+ this.params = QParams3d.fromRange(options.range);
766
+ const initialCapacity = options.initialCapacity ?? 0;
767
+ this.buffer = new Uint16ArrayBuilder({
768
+ growthFactor: options.growthFactor,
769
+ initialCapacity: 3 * initialCapacity,
770
+ });
771
+ }
772
+ /** Append a point with the specified quantized coordinates. */
773
+ pushXYZ(x, y, z) {
774
+ this.buffer.push(x);
775
+ this.buffer.push(y);
776
+ this.buffer.push(z);
777
+ }
778
+ /** Append a point with the specified quantized coordinates. */
779
+ push(pt) {
780
+ this.pushXYZ(pt.x, pt.y, pt.z);
781
+ }
782
+ /** The number of points currently in the [[buffer]]. */
783
+ get length() {
784
+ const len = this.buffer.length;
785
+ assert(len % 3 === 0);
786
+ return len / 3;
787
+ }
788
+ /** Returns the quantized point at the specified index in [[buffer]].
789
+ * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
790
+ * @param result If supplied, a [[QPoint3d]] to initialize with the result and return.
791
+ * @returns The quantized point at the specified index in [[buffer]].
792
+ * @throws Error if `pointIndex` is out of bounds.
793
+ */
794
+ get(pointIndex, result) {
795
+ return QPoint3dBuffer.getQPoint(this.buffer.toTypedArray(), pointIndex, result);
796
+ }
797
+ /** Returns the unquantized point at the specified index in [[buffer]].
798
+ * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
799
+ * @param result If supplied, a [Point3d]($core-geometry) to initialize with the result and return.
800
+ * @returns The unquantized point at the specified index in [[buffer]].
801
+ * @throws Error if `pointIndex` is out of bounds.
802
+ */
803
+ unquantize(pointIndex, result) {
804
+ return this.get(pointIndex, this._scratchQPoint3d).unquantize(this.params, result);
805
+ }
806
+ /** Obtain a [[QPoint3dBuffer]] containing all of the points that have been appended by this builder. */
807
+ finish() {
808
+ return {
809
+ params: this.params,
810
+ points: this.buffer.toTypedArray(),
811
+ };
812
+ }
813
+ }
814
814
  //# sourceMappingURL=QPoint.js.map