@itwin/core-common 3.5.0-dev.25 → 3.5.0-dev.27

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 (935) 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 +11 -11
  8. package/lib/cjs/AuthorizationClient.js +9 -9
  9. package/lib/cjs/AuthorizationClient.js.map +1 -1
  10. package/lib/cjs/BackgroundMapProvider.d.ts +51 -51
  11. package/lib/cjs/BackgroundMapProvider.js +68 -68
  12. package/lib/cjs/BackgroundMapProvider.js.map +1 -1
  13. package/lib/cjs/BackgroundMapSettings.d.ts +136 -136
  14. package/lib/cjs/BackgroundMapSettings.js +156 -156
  15. package/lib/cjs/BackgroundMapSettings.js.map +1 -1
  16. package/lib/cjs/Base64EncodedString.d.ts +30 -30
  17. package/lib/cjs/Base64EncodedString.js +56 -56
  18. package/lib/cjs/Base64EncodedString.js.map +1 -1
  19. package/lib/cjs/BlobReader.d.ts +31 -31
  20. package/lib/cjs/BlobReader.js +84 -84
  21. package/lib/cjs/BlobReader.js.map +1 -1
  22. package/lib/cjs/BriefcaseTypes.d.ts +189 -189
  23. package/lib/cjs/BriefcaseTypes.js +95 -95
  24. package/lib/cjs/BriefcaseTypes.js.map +1 -1
  25. package/lib/cjs/Camera.d.ts +42 -42
  26. package/lib/cjs/Camera.js +62 -62
  27. package/lib/cjs/Camera.js.map +1 -1
  28. package/lib/cjs/ChangedElements.d.ts +83 -83
  29. package/lib/cjs/ChangedElements.js +21 -21
  30. package/lib/cjs/ChangedElements.js.map +1 -1
  31. package/lib/cjs/ChangedEntities.d.ts +45 -45
  32. package/lib/cjs/ChangedEntities.js +9 -9
  33. package/lib/cjs/ChangedEntities.js.map +1 -1
  34. package/lib/cjs/ChangesetProps.d.ts +98 -98
  35. package/lib/cjs/ChangesetProps.js +22 -22
  36. package/lib/cjs/ChangesetProps.js.map +1 -1
  37. package/lib/cjs/ClipStyle.d.ts +89 -89
  38. package/lib/cjs/ClipStyle.js +123 -123
  39. package/lib/cjs/ClipStyle.js.map +1 -1
  40. package/lib/cjs/CloudStorage.d.ts +62 -62
  41. package/lib/cjs/CloudStorage.js +113 -113
  42. package/lib/cjs/CloudStorage.js.map +1 -1
  43. package/lib/cjs/CloudStorageTileCache.d.ts +27 -27
  44. package/lib/cjs/CloudStorageTileCache.js +66 -66
  45. package/lib/cjs/CloudStorageTileCache.js.map +1 -1
  46. package/lib/cjs/Code.d.ts +256 -256
  47. package/lib/cjs/Code.js +281 -281
  48. package/lib/cjs/Code.js.map +1 -1
  49. package/lib/cjs/ColorByName.d.ts +161 -161
  50. package/lib/cjs/ColorByName.js +169 -169
  51. package/lib/cjs/ColorByName.js.map +1 -1
  52. package/lib/cjs/ColorDef.d.ts +208 -208
  53. package/lib/cjs/ColorDef.js +571 -571
  54. package/lib/cjs/ColorDef.js.map +1 -1
  55. package/lib/cjs/CommonLoggerCategory.d.ts +18 -18
  56. package/lib/cjs/CommonLoggerCategory.js +26 -26
  57. package/lib/cjs/CommonLoggerCategory.js.map +1 -1
  58. package/lib/cjs/ConcurrentQuery.d.ts +241 -241
  59. package/lib/cjs/ConcurrentQuery.js +380 -380
  60. package/lib/cjs/ConcurrentQuery.js.map +1 -1
  61. package/lib/cjs/ContextRealityModel.d.ts +276 -276
  62. package/lib/cjs/ContextRealityModel.js +358 -358
  63. package/lib/cjs/ContextRealityModel.js.map +1 -1
  64. package/lib/cjs/DisplayStyleSettings.d.ts +584 -584
  65. package/lib/cjs/DisplayStyleSettings.js +981 -981
  66. package/lib/cjs/DisplayStyleSettings.js.map +1 -1
  67. package/lib/cjs/ECSchemaProps.d.ts +39 -39
  68. package/lib/cjs/ECSchemaProps.js +9 -9
  69. package/lib/cjs/ECSchemaProps.js.map +1 -1
  70. package/lib/cjs/ECSqlReader.d.ts +70 -70
  71. package/lib/cjs/ECSqlReader.js +280 -280
  72. package/lib/cjs/ECSqlReader.js.map +1 -1
  73. package/lib/cjs/ECSqlTypes.d.ts +128 -128
  74. package/lib/cjs/ECSqlTypes.js +189 -189
  75. package/lib/cjs/ECSqlTypes.js.map +1 -1
  76. package/lib/cjs/ElementProps.d.ts +476 -476
  77. package/lib/cjs/ElementProps.js +99 -99
  78. package/lib/cjs/ElementProps.js.map +1 -1
  79. package/lib/cjs/EmphasizeElementsProps.d.ts +55 -55
  80. package/lib/cjs/EmphasizeElementsProps.js +25 -25
  81. package/lib/cjs/EmphasizeElementsProps.js.map +1 -1
  82. package/lib/cjs/EntityProps.d.ts +176 -176
  83. package/lib/cjs/EntityProps.js +112 -112
  84. package/lib/cjs/EntityProps.js.map +1 -1
  85. package/lib/cjs/EntityReference.d.ts +51 -51
  86. package/lib/cjs/EntityReference.js +56 -56
  87. package/lib/cjs/EntityReference.js.map +1 -1
  88. package/lib/cjs/Environment.d.ts +61 -61
  89. package/lib/cjs/Environment.js +73 -73
  90. package/lib/cjs/Environment.js.map +1 -1
  91. package/lib/cjs/FeatureGates.d.ts +31 -31
  92. package/lib/cjs/FeatureGates.js +55 -55
  93. package/lib/cjs/FeatureGates.js.map +1 -1
  94. package/lib/cjs/FeatureIndex.d.ts +39 -39
  95. package/lib/cjs/FeatureIndex.js +63 -63
  96. package/lib/cjs/FeatureIndex.js.map +1 -1
  97. package/lib/cjs/FeatureSymbology.d.ts +444 -444
  98. package/lib/cjs/FeatureSymbology.js +614 -614
  99. package/lib/cjs/FeatureSymbology.js.map +1 -1
  100. package/lib/cjs/FeatureTable.d.ts +141 -141
  101. package/lib/cjs/FeatureTable.js +278 -278
  102. package/lib/cjs/FeatureTable.js.map +1 -1
  103. package/lib/cjs/Fonts.d.ts +51 -51
  104. package/lib/cjs/Fonts.js +53 -53
  105. package/lib/cjs/Fonts.js.map +1 -1
  106. package/lib/cjs/Frustum.d.ts +114 -114
  107. package/lib/cjs/Frustum.js +292 -292
  108. package/lib/cjs/Frustum.js.map +1 -1
  109. package/lib/cjs/GeoCoordinateServices.d.ts +119 -119
  110. package/lib/cjs/GeoCoordinateServices.js +80 -80
  111. package/lib/cjs/GeoCoordinateServices.js.map +1 -1
  112. package/lib/cjs/GeometryContainment.d.ts +28 -28
  113. package/lib/cjs/GeometryContainment.js +9 -9
  114. package/lib/cjs/GeometryContainment.js.map +1 -1
  115. package/lib/cjs/GeometryParams.d.ts +130 -130
  116. package/lib/cjs/GeometryParams.js +174 -174
  117. package/lib/cjs/GeometryParams.js.map +1 -1
  118. package/lib/cjs/GeometrySummary.d.ts +45 -45
  119. package/lib/cjs/GeometrySummary.js +23 -23
  120. package/lib/cjs/GeometrySummary.js.map +1 -1
  121. package/lib/cjs/Gradient.d.ts +139 -139
  122. package/lib/cjs/Gradient.js +455 -455
  123. package/lib/cjs/Gradient.js.map +1 -1
  124. package/lib/cjs/GraphicParams.d.ts +58 -58
  125. package/lib/cjs/GraphicParams.js +85 -85
  126. package/lib/cjs/GraphicParams.js.map +1 -1
  127. package/lib/cjs/GroundPlane.d.ts +52 -52
  128. package/lib/cjs/GroundPlane.js +64 -64
  129. package/lib/cjs/GroundPlane.js.map +1 -1
  130. package/lib/cjs/HSLColor.d.ts +20 -20
  131. package/lib/cjs/HSLColor.js +32 -32
  132. package/lib/cjs/HSLColor.js.map +1 -1
  133. package/lib/cjs/HSVColor.d.ts +30 -30
  134. package/lib/cjs/HSVColor.js +59 -59
  135. package/lib/cjs/HSVColor.js.map +1 -1
  136. package/lib/cjs/HiddenLine.d.ts +97 -97
  137. package/lib/cjs/HiddenLine.js +162 -162
  138. package/lib/cjs/HiddenLine.js.map +1 -1
  139. package/lib/cjs/Hilite.d.ts +50 -50
  140. package/lib/cjs/Hilite.js +64 -64
  141. package/lib/cjs/Hilite.js.map +1 -1
  142. package/lib/cjs/IModel.d.ts +359 -359
  143. package/lib/cjs/IModel.js +347 -347
  144. package/lib/cjs/IModel.js.map +1 -1
  145. package/lib/cjs/IModelError.d.ts +36 -36
  146. package/lib/cjs/IModelError.js +72 -72
  147. package/lib/cjs/IModelError.js.map +1 -1
  148. package/lib/cjs/IModelVersion.d.ts +68 -68
  149. package/lib/cjs/IModelVersion.js +79 -79
  150. package/lib/cjs/IModelVersion.js.map +1 -1
  151. package/lib/cjs/Image.d.ts +86 -86
  152. package/lib/cjs/Image.js +128 -128
  153. package/lib/cjs/Image.js.map +1 -1
  154. package/lib/cjs/IpcAppProps.d.ts +124 -124
  155. package/lib/cjs/IpcAppProps.js +18 -18
  156. package/lib/cjs/IpcAppProps.js.map +1 -1
  157. package/lib/cjs/LightSettings.d.ts +224 -224
  158. package/lib/cjs/LightSettings.js +309 -309
  159. package/lib/cjs/LightSettings.js.map +1 -1
  160. package/lib/cjs/LinePixels.d.ts +34 -34
  161. package/lib/cjs/LinePixels.js +42 -42
  162. package/lib/cjs/LinePixels.js.map +1 -1
  163. package/lib/cjs/Localization.d.ts +111 -111
  164. package/lib/cjs/Localization.js +26 -26
  165. package/lib/cjs/Localization.js.map +1 -1
  166. package/lib/cjs/MapImagerySettings.d.ts +62 -62
  167. package/lib/cjs/MapImagerySettings.js +80 -80
  168. package/lib/cjs/MapImagerySettings.js.map +1 -1
  169. package/lib/cjs/MapLayerSettings.d.ts +272 -272
  170. package/lib/cjs/MapLayerSettings.js +411 -411
  171. package/lib/cjs/MapLayerSettings.js.map +1 -1
  172. package/lib/cjs/MassProperties.d.ts +64 -64
  173. package/lib/cjs/MassProperties.js +23 -23
  174. package/lib/cjs/MassProperties.js.map +1 -1
  175. package/lib/cjs/MaterialProps.d.ts +118 -118
  176. package/lib/cjs/MaterialProps.js +23 -23
  177. package/lib/cjs/MaterialProps.js.map +1 -1
  178. package/lib/cjs/ModelClipGroup.d.ts +67 -67
  179. package/lib/cjs/ModelClipGroup.js +98 -98
  180. package/lib/cjs/ModelClipGroup.js.map +1 -1
  181. package/lib/cjs/ModelGeometryChanges.d.ts +107 -107
  182. package/lib/cjs/ModelGeometryChanges.js +83 -83
  183. package/lib/cjs/ModelGeometryChanges.js.map +1 -1
  184. package/lib/cjs/ModelProps.d.ts +67 -67
  185. package/lib/cjs/ModelProps.js +9 -9
  186. package/lib/cjs/ModelProps.js.map +1 -1
  187. package/lib/cjs/NativeAppProps.d.ts +122 -122
  188. package/lib/cjs/NativeAppProps.js +30 -30
  189. package/lib/cjs/NativeAppProps.js.map +1 -1
  190. package/lib/cjs/OctEncodedNormal.d.ts +33 -33
  191. package/lib/cjs/OctEncodedNormal.js +98 -98
  192. package/lib/cjs/OctEncodedNormal.js.map +1 -1
  193. package/lib/cjs/PlanProjectionSettings.d.ts +47 -47
  194. package/lib/cjs/PlanProjectionSettings.js +63 -63
  195. package/lib/cjs/PlanProjectionSettings.js.map +1 -1
  196. package/lib/cjs/PlanarClipMask.d.ts +177 -177
  197. package/lib/cjs/PlanarClipMask.js +136 -136
  198. package/lib/cjs/PlanarClipMask.js.map +1 -1
  199. package/lib/cjs/QPoint.d.ts +479 -479
  200. package/lib/cjs/QPoint.js +826 -826
  201. package/lib/cjs/QPoint.js.map +1 -1
  202. package/lib/cjs/RealityDataAccessProps.d.ts +41 -41
  203. package/lib/cjs/RealityDataAccessProps.js +19 -19
  204. package/lib/cjs/RealityDataAccessProps.js.map +1 -1
  205. package/lib/cjs/RealityModelDisplaySettings.d.ts +118 -118
  206. package/lib/cjs/RealityModelDisplaySettings.js +114 -114
  207. package/lib/cjs/RealityModelDisplaySettings.js.map +1 -1
  208. package/lib/cjs/Render.d.ts +89 -89
  209. package/lib/cjs/Render.js +177 -177
  210. package/lib/cjs/Render.js.map +1 -1
  211. package/lib/cjs/RenderMaterial.d.ts +58 -58
  212. package/lib/cjs/RenderMaterial.js +76 -76
  213. package/lib/cjs/RenderMaterial.js.map +1 -1
  214. package/lib/cjs/RenderSchedule.d.ts +541 -541
  215. package/lib/cjs/RenderSchedule.js +1000 -1000
  216. package/lib/cjs/RenderTexture.d.ts +70 -70
  217. package/lib/cjs/RenderTexture.js +59 -59
  218. package/lib/cjs/RenderTexture.js.map +1 -1
  219. package/lib/cjs/RgbColor.d.ts +47 -47
  220. package/lib/cjs/RgbColor.js +77 -77
  221. package/lib/cjs/RgbColor.js.map +1 -1
  222. package/lib/cjs/RpcInterface.d.ts +33 -33
  223. package/lib/cjs/RpcInterface.js +137 -137
  224. package/lib/cjs/RpcInterface.js.map +1 -1
  225. package/lib/cjs/RpcManager.d.ts +40 -40
  226. package/lib/cjs/RpcManager.js +55 -55
  227. package/lib/cjs/RpcManager.js.map +1 -1
  228. package/lib/cjs/SessionProps.d.ts +16 -16
  229. package/lib/cjs/SessionProps.js +9 -9
  230. package/lib/cjs/SessionProps.js.map +1 -1
  231. package/lib/cjs/SkyBox.d.ts +215 -215
  232. package/lib/cjs/SkyBox.js +210 -210
  233. package/lib/cjs/SkyBox.js.map +1 -1
  234. package/lib/cjs/Snapping.d.ts +49 -49
  235. package/lib/cjs/Snapping.js +9 -9
  236. package/lib/cjs/Snapping.js.map +1 -1
  237. package/lib/cjs/SolarCalculate.d.ts +27 -27
  238. package/lib/cjs/SolarCalculate.js +211 -211
  239. package/lib/cjs/SolarCalculate.js.map +1 -1
  240. package/lib/cjs/SolarShadows.d.ts +35 -35
  241. package/lib/cjs/SolarShadows.js +62 -62
  242. package/lib/cjs/SolarShadows.js.map +1 -1
  243. package/lib/cjs/SpatialClassification.d.ts +208 -208
  244. package/lib/cjs/SpatialClassification.js +340 -340
  245. package/lib/cjs/SpatialClassification.js.map +1 -1
  246. package/lib/cjs/SubCategoryAppearance.d.ts +91 -91
  247. package/lib/cjs/SubCategoryAppearance.js +96 -96
  248. package/lib/cjs/SubCategoryAppearance.js.map +1 -1
  249. package/lib/cjs/SubCategoryOverride.d.ts +46 -46
  250. package/lib/cjs/SubCategoryOverride.js +104 -104
  251. package/lib/cjs/SubCategoryOverride.js.map +1 -1
  252. package/lib/cjs/TerrainSettings.d.ts +82 -82
  253. package/lib/cjs/TerrainSettings.js +102 -102
  254. package/lib/cjs/TerrainSettings.js.map +1 -1
  255. package/lib/cjs/TextureMapping.d.ts +101 -101
  256. package/lib/cjs/TextureMapping.js +174 -174
  257. package/lib/cjs/TextureMapping.js.map +1 -1
  258. package/lib/cjs/TextureProps.d.ts +65 -65
  259. package/lib/cjs/TextureProps.js +28 -28
  260. package/lib/cjs/TextureProps.js.map +1 -1
  261. package/lib/cjs/ThematicDisplay.d.ts +230 -230
  262. package/lib/cjs/ThematicDisplay.js +344 -344
  263. package/lib/cjs/ThematicDisplay.js.map +1 -1
  264. package/lib/cjs/Thumbnail.d.ts +26 -26
  265. package/lib/cjs/Thumbnail.js +9 -9
  266. package/lib/cjs/Thumbnail.js.map +1 -1
  267. package/lib/cjs/TileProps.d.ts +82 -82
  268. package/lib/cjs/TileProps.js +29 -29
  269. package/lib/cjs/TileProps.js.map +1 -1
  270. package/lib/cjs/Tween.d.ts +191 -191
  271. package/lib/cjs/Tween.js +570 -570
  272. package/lib/cjs/Tween.js.map +1 -1
  273. package/lib/cjs/TxnAction.d.ts +21 -21
  274. package/lib/cjs/TxnAction.js +29 -29
  275. package/lib/cjs/TxnAction.js.map +1 -1
  276. package/lib/cjs/ViewDetails.d.ts +125 -125
  277. package/lib/cjs/ViewDetails.js +158 -158
  278. package/lib/cjs/ViewDetails.js.map +1 -1
  279. package/lib/cjs/ViewFlags.d.ts +291 -291
  280. package/lib/cjs/ViewFlags.js +368 -368
  281. package/lib/cjs/ViewFlags.js.map +1 -1
  282. package/lib/cjs/ViewProps.d.ts +205 -205
  283. package/lib/cjs/ViewProps.js +9 -9
  284. package/lib/cjs/ViewProps.js.map +1 -1
  285. package/lib/cjs/WhiteOnWhiteReversalSettings.d.ts +36 -36
  286. package/lib/cjs/WhiteOnWhiteReversalSettings.js +37 -37
  287. package/lib/cjs/WhiteOnWhiteReversalSettings.js.map +1 -1
  288. package/lib/cjs/core-common.d.ts +242 -242
  289. package/lib/cjs/core-common.js +258 -258
  290. package/lib/cjs/core-common.js.map +1 -1
  291. package/lib/cjs/domains/FunctionalElementProps.d.ts +11 -11
  292. package/lib/cjs/domains/FunctionalElementProps.js +9 -9
  293. package/lib/cjs/domains/FunctionalElementProps.js.map +1 -1
  294. package/lib/cjs/domains/GenericElementProps.d.ts +18 -18
  295. package/lib/cjs/domains/GenericElementProps.js +9 -9
  296. package/lib/cjs/domains/GenericElementProps.js.map +1 -1
  297. package/lib/cjs/geometry/AdditionalTransform.d.ts +84 -84
  298. package/lib/cjs/geometry/AdditionalTransform.js +85 -85
  299. package/lib/cjs/geometry/AdditionalTransform.js.map +1 -1
  300. package/lib/cjs/geometry/AreaPattern.d.ts +82 -82
  301. package/lib/cjs/geometry/AreaPattern.js +204 -204
  302. package/lib/cjs/geometry/AreaPattern.js.map +1 -1
  303. package/lib/cjs/geometry/BoundingSphere.d.ts +14 -14
  304. package/lib/cjs/geometry/BoundingSphere.js +30 -30
  305. package/lib/cjs/geometry/BoundingSphere.js.map +1 -1
  306. package/lib/cjs/geometry/Cartographic.d.ts +137 -137
  307. package/lib/cjs/geometry/Cartographic.js +345 -345
  308. package/lib/cjs/geometry/Cartographic.js.map +1 -1
  309. package/lib/cjs/geometry/CoordinateReferenceSystem.d.ts +269 -269
  310. package/lib/cjs/geometry/CoordinateReferenceSystem.js +261 -261
  311. package/lib/cjs/geometry/CoordinateReferenceSystem.js.map +1 -1
  312. package/lib/cjs/geometry/ElementGeometry.d.ts +402 -402
  313. package/lib/cjs/geometry/ElementGeometry.js +1719 -1719
  314. package/lib/cjs/geometry/ElementGeometry.js.map +1 -1
  315. package/lib/cjs/geometry/ElementGeometryFB.d.ts +2372 -2372
  316. package/lib/cjs/geometry/ElementGeometryFB.js +3814 -3814
  317. package/lib/cjs/geometry/ElementGeometryFB.js.map +1 -1
  318. package/lib/cjs/geometry/FrustumPlanes.d.ts +32 -32
  319. package/lib/cjs/geometry/FrustumPlanes.js +132 -132
  320. package/lib/cjs/geometry/FrustumPlanes.js.map +1 -1
  321. package/lib/cjs/geometry/GeodeticDatum.d.ts +409 -409
  322. package/lib/cjs/geometry/GeodeticDatum.js +401 -401
  323. package/lib/cjs/geometry/GeodeticDatum.js.map +1 -1
  324. package/lib/cjs/geometry/GeodeticEllipsoid.d.ts +72 -72
  325. package/lib/cjs/geometry/GeodeticEllipsoid.js +72 -72
  326. package/lib/cjs/geometry/GeodeticEllipsoid.js.map +1 -1
  327. package/lib/cjs/geometry/GeometryStream.d.ts +347 -347
  328. package/lib/cjs/geometry/GeometryStream.js +469 -469
  329. package/lib/cjs/geometry/GeometryStream.js.map +1 -1
  330. package/lib/cjs/geometry/ImageGraphic.d.ts +74 -74
  331. package/lib/cjs/geometry/ImageGraphic.js +98 -98
  332. package/lib/cjs/geometry/ImageGraphic.js.map +1 -1
  333. package/lib/cjs/geometry/LineStyle.d.ts +71 -71
  334. package/lib/cjs/geometry/LineStyle.js +129 -129
  335. package/lib/cjs/geometry/LineStyle.js.map +1 -1
  336. package/lib/cjs/geometry/Placement.d.ts +95 -95
  337. package/lib/cjs/geometry/Placement.js +131 -131
  338. package/lib/cjs/geometry/Placement.js.map +1 -1
  339. package/lib/cjs/geometry/Projection.d.ts +251 -251
  340. package/lib/cjs/geometry/Projection.js +198 -198
  341. package/lib/cjs/geometry/Projection.js.map +1 -1
  342. package/lib/cjs/geometry/TextString.d.ts +55 -55
  343. package/lib/cjs/geometry/TextString.js +65 -65
  344. package/lib/cjs/geometry/TextString.js.map +1 -1
  345. package/lib/cjs/ipc/IpcSession.d.ts +23 -23
  346. package/lib/cjs/ipc/IpcSession.js +27 -27
  347. package/lib/cjs/ipc/IpcSession.js.map +1 -1
  348. package/lib/cjs/ipc/IpcSocket.d.ts +96 -96
  349. package/lib/cjs/ipc/IpcSocket.js +16 -16
  350. package/lib/cjs/ipc/IpcSocket.js.map +1 -1
  351. package/lib/cjs/ipc/IpcWebSocket.d.ts +61 -61
  352. package/lib/cjs/ipc/IpcWebSocket.js +151 -151
  353. package/lib/cjs/ipc/IpcWebSocket.js.map +1 -1
  354. package/lib/cjs/ipc/IpcWebSocketTransport.d.ts +15 -15
  355. package/lib/cjs/ipc/IpcWebSocketTransport.js +158 -158
  356. package/lib/cjs/ipc/IpcWebSocketTransport.js.map +1 -1
  357. package/lib/cjs/rpc/DevToolsRpcInterface.d.ts +32 -32
  358. package/lib/cjs/rpc/DevToolsRpcInterface.js +48 -48
  359. package/lib/cjs/rpc/DevToolsRpcInterface.js.map +1 -1
  360. package/lib/cjs/rpc/IModelReadRpcInterface.d.ts +97 -97
  361. package/lib/cjs/rpc/IModelReadRpcInterface.js +119 -119
  362. package/lib/cjs/rpc/IModelReadRpcInterface.js.map +1 -1
  363. package/lib/cjs/rpc/IModelTileRpcInterface.d.ts +61 -61
  364. package/lib/cjs/rpc/IModelTileRpcInterface.js +96 -96
  365. package/lib/cjs/rpc/IModelTileRpcInterface.js.map +1 -1
  366. package/lib/cjs/rpc/SnapshotIModelRpcInterface.d.ts +23 -23
  367. package/lib/cjs/rpc/SnapshotIModelRpcInterface.js +48 -48
  368. package/lib/cjs/rpc/SnapshotIModelRpcInterface.js.map +1 -1
  369. package/lib/cjs/rpc/TestRpcManager.d.ts +20 -20
  370. package/lib/cjs/rpc/TestRpcManager.js +39 -39
  371. package/lib/cjs/rpc/TestRpcManager.js.map +1 -1
  372. package/lib/cjs/rpc/WipRpcInterface.d.ts +29 -29
  373. package/lib/cjs/rpc/WipRpcInterface.js +40 -40
  374. package/lib/cjs/rpc/WipRpcInterface.js.map +1 -1
  375. package/lib/cjs/rpc/core/RpcConfiguration.d.ts +111 -111
  376. package/lib/cjs/rpc/core/RpcConfiguration.js +192 -192
  377. package/lib/cjs/rpc/core/RpcConfiguration.js.map +1 -1
  378. package/lib/cjs/rpc/core/RpcConstants.d.ts +85 -85
  379. package/lib/cjs/rpc/core/RpcConstants.js +103 -103
  380. package/lib/cjs/rpc/core/RpcConstants.js.map +1 -1
  381. package/lib/cjs/rpc/core/RpcControl.d.ts +52 -52
  382. package/lib/cjs/rpc/core/RpcControl.js +149 -149
  383. package/lib/cjs/rpc/core/RpcControl.js.map +1 -1
  384. package/lib/cjs/rpc/core/RpcInvocation.d.ts +89 -89
  385. package/lib/cjs/rpc/core/RpcInvocation.js +257 -257
  386. package/lib/cjs/rpc/core/RpcInvocation.js.map +1 -1
  387. package/lib/cjs/rpc/core/RpcMarshaling.d.ts +36 -36
  388. package/lib/cjs/rpc/core/RpcMarshaling.js +153 -153
  389. package/lib/cjs/rpc/core/RpcMarshaling.js.map +1 -1
  390. package/lib/cjs/rpc/core/RpcOperation.d.ts +67 -67
  391. package/lib/cjs/rpc/core/RpcOperation.js +133 -133
  392. package/lib/cjs/rpc/core/RpcOperation.js.map +1 -1
  393. package/lib/cjs/rpc/core/RpcPendingQueue.d.ts +21 -21
  394. package/lib/cjs/rpc/core/RpcPendingQueue.js +94 -94
  395. package/lib/cjs/rpc/core/RpcPendingQueue.js.map +1 -1
  396. package/lib/cjs/rpc/core/RpcProtocol.d.ts +132 -132
  397. package/lib/cjs/rpc/core/RpcProtocol.js +127 -127
  398. package/lib/cjs/rpc/core/RpcProtocol.js.map +1 -1
  399. package/lib/cjs/rpc/core/RpcPush.d.ts +68 -68
  400. package/lib/cjs/rpc/core/RpcPush.js +127 -127
  401. package/lib/cjs/rpc/core/RpcPush.js.map +1 -1
  402. package/lib/cjs/rpc/core/RpcRegistry.d.ts +48 -48
  403. package/lib/cjs/rpc/core/RpcRegistry.js +198 -198
  404. package/lib/cjs/rpc/core/RpcRegistry.js.map +1 -1
  405. package/lib/cjs/rpc/core/RpcRequest.d.ts +186 -186
  406. package/lib/cjs/rpc/core/RpcRequest.js +477 -477
  407. package/lib/cjs/rpc/core/RpcRequest.js.map +1 -1
  408. package/lib/cjs/rpc/core/RpcRequestContext.d.ts +14 -14
  409. package/lib/cjs/rpc/core/RpcRequestContext.js +2 -2
  410. package/lib/cjs/rpc/core/RpcRequestContext.js.map +1 -1
  411. package/lib/cjs/rpc/core/RpcRoutingToken.d.ts +12 -12
  412. package/lib/cjs/rpc/core/RpcRoutingToken.js +23 -23
  413. package/lib/cjs/rpc/core/RpcRoutingToken.js.map +1 -1
  414. package/lib/cjs/rpc/core/RpcSessionInvocation.d.ts +10 -10
  415. package/lib/cjs/rpc/core/RpcSessionInvocation.js +59 -59
  416. package/lib/cjs/rpc/core/RpcSessionInvocation.js.map +1 -1
  417. package/lib/cjs/rpc/web/BentleyCloudRpcManager.d.ts +46 -46
  418. package/lib/cjs/rpc/web/BentleyCloudRpcManager.js +73 -73
  419. package/lib/cjs/rpc/web/BentleyCloudRpcManager.js.map +1 -1
  420. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.d.ts +33 -33
  421. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.js +142 -142
  422. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.js.map +1 -1
  423. package/lib/cjs/rpc/web/OpenAPI.d.ts +139 -139
  424. package/lib/cjs/rpc/web/OpenAPI.js +60 -60
  425. package/lib/cjs/rpc/web/OpenAPI.js.map +1 -1
  426. package/lib/cjs/rpc/web/RpcMultipart.d.ts +31 -31
  427. package/lib/cjs/rpc/web/RpcMultipart.js +45 -45
  428. package/lib/cjs/rpc/web/RpcMultipart.js.map +1 -1
  429. package/lib/cjs/rpc/web/WebAppRpcLogging.d.ts +17 -17
  430. package/lib/cjs/rpc/web/WebAppRpcLogging.js +140 -140
  431. package/lib/cjs/rpc/web/WebAppRpcLogging.js.map +1 -1
  432. package/lib/cjs/rpc/web/WebAppRpcProtocol.d.ts +86 -86
  433. package/lib/cjs/rpc/web/WebAppRpcProtocol.js +116 -116
  434. package/lib/cjs/rpc/web/WebAppRpcProtocol.js.map +1 -1
  435. package/lib/cjs/rpc/web/WebAppRpcRequest.d.ts +71 -71
  436. package/lib/cjs/rpc/web/WebAppRpcRequest.js +374 -374
  437. package/lib/cjs/rpc/web/WebAppRpcRequest.js.map +1 -1
  438. package/lib/cjs/rpc/web/multipart/RpcMultipartParser.d.ts +33 -33
  439. package/lib/cjs/rpc/web/multipart/RpcMultipartParser.js +359 -359
  440. package/lib/cjs/rpc/web/multipart/RpcMultipartParser.js.map +1 -1
  441. package/lib/cjs/tile/B3dmTileIO.d.ts +19 -19
  442. package/lib/cjs/tile/B3dmTileIO.js +66 -66
  443. package/lib/cjs/tile/B3dmTileIO.js.map +1 -1
  444. package/lib/cjs/tile/CompositeTileIO.d.ts +15 -15
  445. package/lib/cjs/tile/CompositeTileIO.js +26 -26
  446. package/lib/cjs/tile/CompositeTileIO.js.map +1 -1
  447. package/lib/cjs/tile/ElementGraphics.d.ts +145 -145
  448. package/lib/cjs/tile/ElementGraphics.js +9 -9
  449. package/lib/cjs/tile/ElementGraphics.js.map +1 -1
  450. package/lib/cjs/tile/GltfTileIO.d.ts +45 -45
  451. package/lib/cjs/tile/GltfTileIO.js +109 -109
  452. package/lib/cjs/tile/GltfTileIO.js.map +1 -1
  453. package/lib/cjs/tile/I3dmTileIO.d.ts +20 -20
  454. package/lib/cjs/tile/I3dmTileIO.js +40 -40
  455. package/lib/cjs/tile/I3dmTileIO.js.map +1 -1
  456. package/lib/cjs/tile/IModelTileIO.d.ts +75 -75
  457. package/lib/cjs/tile/IModelTileIO.js +95 -95
  458. package/lib/cjs/tile/IModelTileIO.js.map +1 -1
  459. package/lib/cjs/tile/PntsTileIO.d.ts +17 -17
  460. package/lib/cjs/tile/PntsTileIO.js +26 -26
  461. package/lib/cjs/tile/PntsTileIO.js.map +1 -1
  462. package/lib/cjs/tile/TileIO.d.ts +66 -66
  463. package/lib/cjs/tile/TileIO.js +118 -118
  464. package/lib/cjs/tile/TileIO.js.map +1 -1
  465. package/lib/cjs/tile/TileMetadata.d.ts +228 -228
  466. package/lib/cjs/tile/TileMetadata.js +676 -676
  467. package/lib/cjs/tile/TileMetadata.js.map +1 -1
  468. package/lib/esm/AmbientOcclusion.d.ts +49 -49
  469. package/lib/esm/AmbientOcclusion.js +52 -52
  470. package/lib/esm/AmbientOcclusion.js.map +1 -1
  471. package/lib/esm/AnalysisStyle.d.ts +134 -134
  472. package/lib/esm/AnalysisStyle.js +159 -159
  473. package/lib/esm/AnalysisStyle.js.map +1 -1
  474. package/lib/esm/AuthorizationClient.d.ts +11 -11
  475. package/lib/esm/AuthorizationClient.js +8 -8
  476. package/lib/esm/AuthorizationClient.js.map +1 -1
  477. package/lib/esm/BackgroundMapProvider.d.ts +51 -51
  478. package/lib/esm/BackgroundMapProvider.js +64 -64
  479. package/lib/esm/BackgroundMapProvider.js.map +1 -1
  480. package/lib/esm/BackgroundMapSettings.d.ts +136 -136
  481. package/lib/esm/BackgroundMapSettings.js +152 -152
  482. package/lib/esm/BackgroundMapSettings.js.map +1 -1
  483. package/lib/esm/Base64EncodedString.d.ts +30 -30
  484. package/lib/esm/Base64EncodedString.js +53 -53
  485. package/lib/esm/Base64EncodedString.js.map +1 -1
  486. package/lib/esm/BlobReader.d.ts +31 -31
  487. package/lib/esm/BlobReader.js +79 -79
  488. package/lib/esm/BlobReader.js.map +1 -1
  489. package/lib/esm/BriefcaseTypes.d.ts +189 -189
  490. package/lib/esm/BriefcaseTypes.js +92 -92
  491. package/lib/esm/BriefcaseTypes.js.map +1 -1
  492. package/lib/esm/Camera.d.ts +42 -42
  493. package/lib/esm/Camera.js +58 -58
  494. package/lib/esm/Camera.js.map +1 -1
  495. package/lib/esm/ChangedElements.d.ts +83 -83
  496. package/lib/esm/ChangedElements.js +18 -18
  497. package/lib/esm/ChangedElements.js.map +1 -1
  498. package/lib/esm/ChangedEntities.d.ts +45 -45
  499. package/lib/esm/ChangedEntities.js +8 -8
  500. package/lib/esm/ChangedEntities.js.map +1 -1
  501. package/lib/esm/ChangesetProps.d.ts +98 -98
  502. package/lib/esm/ChangesetProps.js +19 -19
  503. package/lib/esm/ChangesetProps.js.map +1 -1
  504. package/lib/esm/ClipStyle.d.ts +89 -89
  505. package/lib/esm/ClipStyle.js +118 -118
  506. package/lib/esm/ClipStyle.js.map +1 -1
  507. package/lib/esm/CloudStorage.d.ts +62 -62
  508. package/lib/esm/CloudStorage.js +109 -109
  509. package/lib/esm/CloudStorage.js.map +1 -1
  510. package/lib/esm/CloudStorageTileCache.d.ts +27 -27
  511. package/lib/esm/CloudStorageTileCache.js +62 -62
  512. package/lib/esm/CloudStorageTileCache.js.map +1 -1
  513. package/lib/esm/Code.d.ts +256 -256
  514. package/lib/esm/Code.js +276 -276
  515. package/lib/esm/Code.js.map +1 -1
  516. package/lib/esm/ColorByName.d.ts +161 -161
  517. package/lib/esm/ColorByName.js +166 -166
  518. package/lib/esm/ColorByName.js.map +1 -1
  519. package/lib/esm/ColorDef.d.ts +208 -208
  520. package/lib/esm/ColorDef.js +567 -567
  521. package/lib/esm/ColorDef.js.map +1 -1
  522. package/lib/esm/CommonLoggerCategory.d.ts +18 -18
  523. package/lib/esm/CommonLoggerCategory.js +23 -23
  524. package/lib/esm/CommonLoggerCategory.js.map +1 -1
  525. package/lib/esm/ConcurrentQuery.d.ts +241 -241
  526. package/lib/esm/ConcurrentQuery.js +373 -373
  527. package/lib/esm/ConcurrentQuery.js.map +1 -1
  528. package/lib/esm/ContextRealityModel.d.ts +276 -276
  529. package/lib/esm/ContextRealityModel.js +353 -353
  530. package/lib/esm/ContextRealityModel.js.map +1 -1
  531. package/lib/esm/DisplayStyleSettings.d.ts +584 -584
  532. package/lib/esm/DisplayStyleSettings.js +976 -976
  533. package/lib/esm/DisplayStyleSettings.js.map +1 -1
  534. package/lib/esm/ECSchemaProps.d.ts +39 -39
  535. package/lib/esm/ECSchemaProps.js +8 -8
  536. package/lib/esm/ECSchemaProps.js.map +1 -1
  537. package/lib/esm/ECSqlReader.d.ts +70 -70
  538. package/lib/esm/ECSqlReader.js +275 -275
  539. package/lib/esm/ECSqlReader.js.map +1 -1
  540. package/lib/esm/ECSqlTypes.d.ts +128 -128
  541. package/lib/esm/ECSqlTypes.js +185 -185
  542. package/lib/esm/ECSqlTypes.js.map +1 -1
  543. package/lib/esm/ElementProps.d.ts +476 -476
  544. package/lib/esm/ElementProps.js +92 -92
  545. package/lib/esm/ElementProps.js.map +1 -1
  546. package/lib/esm/EmphasizeElementsProps.d.ts +55 -55
  547. package/lib/esm/EmphasizeElementsProps.js +22 -22
  548. package/lib/esm/EmphasizeElementsProps.js.map +1 -1
  549. package/lib/esm/EntityProps.d.ts +176 -176
  550. package/lib/esm/EntityProps.js +107 -107
  551. package/lib/esm/EntityProps.js.map +1 -1
  552. package/lib/esm/EntityReference.d.ts +51 -51
  553. package/lib/esm/EntityReference.js +52 -52
  554. package/lib/esm/EntityReference.js.map +1 -1
  555. package/lib/esm/Environment.d.ts +61 -61
  556. package/lib/esm/Environment.js +69 -69
  557. package/lib/esm/Environment.js.map +1 -1
  558. package/lib/esm/FeatureGates.d.ts +31 -31
  559. package/lib/esm/FeatureGates.js +51 -51
  560. package/lib/esm/FeatureGates.js.map +1 -1
  561. package/lib/esm/FeatureIndex.d.ts +39 -39
  562. package/lib/esm/FeatureIndex.js +57 -57
  563. package/lib/esm/FeatureIndex.js.map +1 -1
  564. package/lib/esm/FeatureSymbology.d.ts +444 -444
  565. package/lib/esm/FeatureSymbology.js +609 -609
  566. package/lib/esm/FeatureSymbology.js.map +1 -1
  567. package/lib/esm/FeatureTable.d.ts +141 -141
  568. package/lib/esm/FeatureTable.js +272 -272
  569. package/lib/esm/FeatureTable.js.map +1 -1
  570. package/lib/esm/Fonts.d.ts +51 -51
  571. package/lib/esm/Fonts.js +49 -49
  572. package/lib/esm/Fonts.js.map +1 -1
  573. package/lib/esm/Frustum.d.ts +114 -114
  574. package/lib/esm/Frustum.js +288 -288
  575. package/lib/esm/Frustum.js.map +1 -1
  576. package/lib/esm/GeoCoordinateServices.d.ts +119 -119
  577. package/lib/esm/GeoCoordinateServices.js +76 -76
  578. package/lib/esm/GeoCoordinateServices.js.map +1 -1
  579. package/lib/esm/GeometryContainment.d.ts +28 -28
  580. package/lib/esm/GeometryContainment.js +8 -8
  581. package/lib/esm/GeometryContainment.js.map +1 -1
  582. package/lib/esm/GeometryParams.d.ts +130 -130
  583. package/lib/esm/GeometryParams.js +170 -170
  584. package/lib/esm/GeometryParams.js.map +1 -1
  585. package/lib/esm/GeometrySummary.d.ts +45 -45
  586. package/lib/esm/GeometrySummary.js +20 -20
  587. package/lib/esm/GeometrySummary.js.map +1 -1
  588. package/lib/esm/Gradient.d.ts +139 -139
  589. package/lib/esm/Gradient.js +452 -452
  590. package/lib/esm/Gradient.js.map +1 -1
  591. package/lib/esm/GraphicParams.d.ts +58 -58
  592. package/lib/esm/GraphicParams.js +81 -81
  593. package/lib/esm/GraphicParams.js.map +1 -1
  594. package/lib/esm/GroundPlane.d.ts +52 -52
  595. package/lib/esm/GroundPlane.js +60 -60
  596. package/lib/esm/GroundPlane.js.map +1 -1
  597. package/lib/esm/HSLColor.d.ts +20 -20
  598. package/lib/esm/HSLColor.js +28 -28
  599. package/lib/esm/HSLColor.js.map +1 -1
  600. package/lib/esm/HSVColor.d.ts +30 -30
  601. package/lib/esm/HSVColor.js +55 -55
  602. package/lib/esm/HSVColor.js.map +1 -1
  603. package/lib/esm/HiddenLine.d.ts +97 -97
  604. package/lib/esm/HiddenLine.js +159 -159
  605. package/lib/esm/HiddenLine.js.map +1 -1
  606. package/lib/esm/Hilite.d.ts +50 -50
  607. package/lib/esm/Hilite.js +61 -61
  608. package/lib/esm/Hilite.js.map +1 -1
  609. package/lib/esm/IModel.d.ts +359 -359
  610. package/lib/esm/IModel.js +342 -342
  611. package/lib/esm/IModel.js.map +1 -1
  612. package/lib/esm/IModelError.d.ts +36 -36
  613. package/lib/esm/IModelError.js +55 -55
  614. package/lib/esm/IModelError.js.map +1 -1
  615. package/lib/esm/IModelVersion.d.ts +68 -68
  616. package/lib/esm/IModelVersion.js +75 -75
  617. package/lib/esm/IModelVersion.js.map +1 -1
  618. package/lib/esm/Image.d.ts +86 -86
  619. package/lib/esm/Image.js +120 -120
  620. package/lib/esm/Image.js.map +1 -1
  621. package/lib/esm/IpcAppProps.d.ts +124 -124
  622. package/lib/esm/IpcAppProps.js +15 -15
  623. package/lib/esm/IpcAppProps.js.map +1 -1
  624. package/lib/esm/LightSettings.d.ts +224 -224
  625. package/lib/esm/LightSettings.js +301 -301
  626. package/lib/esm/LightSettings.js.map +1 -1
  627. package/lib/esm/LinePixels.d.ts +34 -34
  628. package/lib/esm/LinePixels.js +39 -39
  629. package/lib/esm/LinePixels.js.map +1 -1
  630. package/lib/esm/Localization.d.ts +111 -111
  631. package/lib/esm/Localization.js +22 -22
  632. package/lib/esm/Localization.js.map +1 -1
  633. package/lib/esm/MapImagerySettings.d.ts +62 -62
  634. package/lib/esm/MapImagerySettings.js +76 -76
  635. package/lib/esm/MapImagerySettings.js.map +1 -1
  636. package/lib/esm/MapLayerSettings.d.ts +272 -272
  637. package/lib/esm/MapLayerSettings.js +403 -403
  638. package/lib/esm/MapLayerSettings.js.map +1 -1
  639. package/lib/esm/MassProperties.d.ts +64 -64
  640. package/lib/esm/MassProperties.js +20 -20
  641. package/lib/esm/MassProperties.js.map +1 -1
  642. package/lib/esm/MaterialProps.d.ts +118 -118
  643. package/lib/esm/MaterialProps.js +20 -20
  644. package/lib/esm/MaterialProps.js.map +1 -1
  645. package/lib/esm/ModelClipGroup.d.ts +67 -67
  646. package/lib/esm/ModelClipGroup.js +93 -93
  647. package/lib/esm/ModelClipGroup.js.map +1 -1
  648. package/lib/esm/ModelGeometryChanges.d.ts +107 -107
  649. package/lib/esm/ModelGeometryChanges.js +80 -80
  650. package/lib/esm/ModelGeometryChanges.js.map +1 -1
  651. package/lib/esm/ModelProps.d.ts +67 -67
  652. package/lib/esm/ModelProps.js +8 -8
  653. package/lib/esm/ModelProps.js.map +1 -1
  654. package/lib/esm/NativeAppProps.d.ts +122 -122
  655. package/lib/esm/NativeAppProps.js +27 -27
  656. package/lib/esm/NativeAppProps.js.map +1 -1
  657. package/lib/esm/OctEncodedNormal.d.ts +33 -33
  658. package/lib/esm/OctEncodedNormal.js +93 -93
  659. package/lib/esm/OctEncodedNormal.js.map +1 -1
  660. package/lib/esm/PlanProjectionSettings.d.ts +47 -47
  661. package/lib/esm/PlanProjectionSettings.js +59 -59
  662. package/lib/esm/PlanProjectionSettings.js.map +1 -1
  663. package/lib/esm/PlanarClipMask.d.ts +177 -177
  664. package/lib/esm/PlanarClipMask.js +132 -132
  665. package/lib/esm/PlanarClipMask.js.map +1 -1
  666. package/lib/esm/QPoint.d.ts +479 -479
  667. package/lib/esm/QPoint.js +815 -815
  668. package/lib/esm/QPoint.js.map +1 -1
  669. package/lib/esm/RealityDataAccessProps.d.ts +41 -41
  670. package/lib/esm/RealityDataAccessProps.js +16 -16
  671. package/lib/esm/RealityDataAccessProps.js.map +1 -1
  672. package/lib/esm/RealityModelDisplaySettings.d.ts +118 -118
  673. package/lib/esm/RealityModelDisplaySettings.js +109 -109
  674. package/lib/esm/RealityModelDisplaySettings.js.map +1 -1
  675. package/lib/esm/Render.d.ts +89 -89
  676. package/lib/esm/Render.js +165 -165
  677. package/lib/esm/Render.js.map +1 -1
  678. package/lib/esm/RenderMaterial.d.ts +58 -58
  679. package/lib/esm/RenderMaterial.js +72 -72
  680. package/lib/esm/RenderMaterial.js.map +1 -1
  681. package/lib/esm/RenderSchedule.d.ts +541 -541
  682. package/lib/esm/RenderSchedule.js +997 -997
  683. package/lib/esm/RenderTexture.d.ts +70 -70
  684. package/lib/esm/RenderTexture.js +55 -55
  685. package/lib/esm/RenderTexture.js.map +1 -1
  686. package/lib/esm/RgbColor.d.ts +47 -47
  687. package/lib/esm/RgbColor.js +73 -73
  688. package/lib/esm/RgbColor.js.map +1 -1
  689. package/lib/esm/RpcInterface.d.ts +33 -33
  690. package/lib/esm/RpcInterface.js +133 -133
  691. package/lib/esm/RpcInterface.js.map +1 -1
  692. package/lib/esm/RpcManager.d.ts +40 -40
  693. package/lib/esm/RpcManager.js +51 -51
  694. package/lib/esm/RpcManager.js.map +1 -1
  695. package/lib/esm/SessionProps.d.ts +16 -16
  696. package/lib/esm/SessionProps.js +8 -8
  697. package/lib/esm/SessionProps.js.map +1 -1
  698. package/lib/esm/SkyBox.d.ts +215 -215
  699. package/lib/esm/SkyBox.js +203 -203
  700. package/lib/esm/SkyBox.js.map +1 -1
  701. package/lib/esm/Snapping.d.ts +49 -49
  702. package/lib/esm/Snapping.js +8 -8
  703. package/lib/esm/Snapping.js.map +1 -1
  704. package/lib/esm/SolarCalculate.d.ts +27 -27
  705. package/lib/esm/SolarCalculate.js +204 -204
  706. package/lib/esm/SolarCalculate.js.map +1 -1
  707. package/lib/esm/SolarShadows.d.ts +35 -35
  708. package/lib/esm/SolarShadows.js +58 -58
  709. package/lib/esm/SolarShadows.js.map +1 -1
  710. package/lib/esm/SpatialClassification.d.ts +208 -208
  711. package/lib/esm/SpatialClassification.js +334 -334
  712. package/lib/esm/SpatialClassification.js.map +1 -1
  713. package/lib/esm/SubCategoryAppearance.d.ts +91 -91
  714. package/lib/esm/SubCategoryAppearance.js +92 -92
  715. package/lib/esm/SubCategoryAppearance.js.map +1 -1
  716. package/lib/esm/SubCategoryOverride.d.ts +46 -46
  717. package/lib/esm/SubCategoryOverride.js +100 -100
  718. package/lib/esm/SubCategoryOverride.js.map +1 -1
  719. package/lib/esm/TerrainSettings.d.ts +82 -82
  720. package/lib/esm/TerrainSettings.js +98 -98
  721. package/lib/esm/TerrainSettings.js.map +1 -1
  722. package/lib/esm/TextureMapping.d.ts +101 -101
  723. package/lib/esm/TextureMapping.js +170 -170
  724. package/lib/esm/TextureMapping.js.map +1 -1
  725. package/lib/esm/TextureProps.d.ts +65 -65
  726. package/lib/esm/TextureProps.js +25 -25
  727. package/lib/esm/TextureProps.js.map +1 -1
  728. package/lib/esm/ThematicDisplay.d.ts +230 -230
  729. package/lib/esm/ThematicDisplay.js +337 -337
  730. package/lib/esm/ThematicDisplay.js.map +1 -1
  731. package/lib/esm/Thumbnail.d.ts +26 -26
  732. package/lib/esm/Thumbnail.js +8 -8
  733. package/lib/esm/Thumbnail.js.map +1 -1
  734. package/lib/esm/TileProps.d.ts +82 -82
  735. package/lib/esm/TileProps.js +25 -25
  736. package/lib/esm/TileProps.js.map +1 -1
  737. package/lib/esm/Tween.d.ts +191 -191
  738. package/lib/esm/Tween.js +565 -565
  739. package/lib/esm/Tween.js.map +1 -1
  740. package/lib/esm/TxnAction.d.ts +21 -21
  741. package/lib/esm/TxnAction.js +26 -26
  742. package/lib/esm/TxnAction.js.map +1 -1
  743. package/lib/esm/ViewDetails.d.ts +125 -125
  744. package/lib/esm/ViewDetails.js +153 -153
  745. package/lib/esm/ViewDetails.js.map +1 -1
  746. package/lib/esm/ViewFlags.d.ts +291 -291
  747. package/lib/esm/ViewFlags.js +364 -364
  748. package/lib/esm/ViewFlags.js.map +1 -1
  749. package/lib/esm/ViewProps.d.ts +205 -205
  750. package/lib/esm/ViewProps.js +8 -8
  751. package/lib/esm/ViewProps.js.map +1 -1
  752. package/lib/esm/WhiteOnWhiteReversalSettings.d.ts +36 -36
  753. package/lib/esm/WhiteOnWhiteReversalSettings.js +33 -33
  754. package/lib/esm/WhiteOnWhiteReversalSettings.js.map +1 -1
  755. package/lib/esm/core-common.d.ts +242 -242
  756. package/lib/esm/core-common.js +246 -246
  757. package/lib/esm/core-common.js.map +1 -1
  758. package/lib/esm/domains/FunctionalElementProps.d.ts +11 -11
  759. package/lib/esm/domains/FunctionalElementProps.js +8 -8
  760. package/lib/esm/domains/FunctionalElementProps.js.map +1 -1
  761. package/lib/esm/domains/GenericElementProps.d.ts +18 -18
  762. package/lib/esm/domains/GenericElementProps.js +8 -8
  763. package/lib/esm/domains/GenericElementProps.js.map +1 -1
  764. package/lib/esm/geometry/AdditionalTransform.d.ts +84 -84
  765. package/lib/esm/geometry/AdditionalTransform.js +80 -80
  766. package/lib/esm/geometry/AdditionalTransform.js.map +1 -1
  767. package/lib/esm/geometry/AreaPattern.d.ts +82 -82
  768. package/lib/esm/geometry/AreaPattern.js +201 -201
  769. package/lib/esm/geometry/AreaPattern.js.map +1 -1
  770. package/lib/esm/geometry/BoundingSphere.d.ts +14 -14
  771. package/lib/esm/geometry/BoundingSphere.js +26 -26
  772. package/lib/esm/geometry/BoundingSphere.js.map +1 -1
  773. package/lib/esm/geometry/Cartographic.d.ts +137 -137
  774. package/lib/esm/geometry/Cartographic.js +340 -340
  775. package/lib/esm/geometry/Cartographic.js.map +1 -1
  776. package/lib/esm/geometry/CoordinateReferenceSystem.d.ts +269 -269
  777. package/lib/esm/geometry/CoordinateReferenceSystem.js +254 -254
  778. package/lib/esm/geometry/CoordinateReferenceSystem.js.map +1 -1
  779. package/lib/esm/geometry/ElementGeometry.d.ts +402 -402
  780. package/lib/esm/geometry/ElementGeometry.js +1716 -1716
  781. package/lib/esm/geometry/ElementGeometry.js.map +1 -1
  782. package/lib/esm/geometry/ElementGeometryFB.d.ts +2372 -2372
  783. package/lib/esm/geometry/ElementGeometryFB.js +3811 -3811
  784. package/lib/esm/geometry/ElementGeometryFB.js.map +1 -1
  785. package/lib/esm/geometry/FrustumPlanes.d.ts +32 -32
  786. package/lib/esm/geometry/FrustumPlanes.js +128 -128
  787. package/lib/esm/geometry/FrustumPlanes.js.map +1 -1
  788. package/lib/esm/geometry/GeodeticDatum.d.ts +409 -409
  789. package/lib/esm/geometry/GeodeticDatum.js +390 -390
  790. package/lib/esm/geometry/GeodeticDatum.js.map +1 -1
  791. package/lib/esm/geometry/GeodeticEllipsoid.d.ts +72 -72
  792. package/lib/esm/geometry/GeodeticEllipsoid.js +68 -68
  793. package/lib/esm/geometry/GeodeticEllipsoid.js.map +1 -1
  794. package/lib/esm/geometry/GeometryStream.d.ts +347 -347
  795. package/lib/esm/geometry/GeometryStream.js +464 -464
  796. package/lib/esm/geometry/GeometryStream.js.map +1 -1
  797. package/lib/esm/geometry/ImageGraphic.d.ts +74 -74
  798. package/lib/esm/geometry/ImageGraphic.js +93 -93
  799. package/lib/esm/geometry/ImageGraphic.js.map +1 -1
  800. package/lib/esm/geometry/LineStyle.d.ts +71 -71
  801. package/lib/esm/geometry/LineStyle.js +126 -126
  802. package/lib/esm/geometry/LineStyle.js.map +1 -1
  803. package/lib/esm/geometry/Placement.d.ts +95 -95
  804. package/lib/esm/geometry/Placement.js +126 -126
  805. package/lib/esm/geometry/Placement.js.map +1 -1
  806. package/lib/esm/geometry/Projection.d.ts +251 -251
  807. package/lib/esm/geometry/Projection.js +192 -192
  808. package/lib/esm/geometry/Projection.js.map +1 -1
  809. package/lib/esm/geometry/TextString.d.ts +55 -55
  810. package/lib/esm/geometry/TextString.js +61 -61
  811. package/lib/esm/geometry/TextString.js.map +1 -1
  812. package/lib/esm/ipc/IpcSession.d.ts +23 -23
  813. package/lib/esm/ipc/IpcSession.js +23 -23
  814. package/lib/esm/ipc/IpcSession.js.map +1 -1
  815. package/lib/esm/ipc/IpcSocket.d.ts +96 -96
  816. package/lib/esm/ipc/IpcSocket.js +12 -12
  817. package/lib/esm/ipc/IpcSocket.js.map +1 -1
  818. package/lib/esm/ipc/IpcWebSocket.d.ts +61 -61
  819. package/lib/esm/ipc/IpcWebSocket.js +145 -145
  820. package/lib/esm/ipc/IpcWebSocket.js.map +1 -1
  821. package/lib/esm/ipc/IpcWebSocketTransport.d.ts +15 -15
  822. package/lib/esm/ipc/IpcWebSocketTransport.js +154 -154
  823. package/lib/esm/ipc/IpcWebSocketTransport.js.map +1 -1
  824. package/lib/esm/rpc/DevToolsRpcInterface.d.ts +32 -32
  825. package/lib/esm/rpc/DevToolsRpcInterface.js +44 -44
  826. package/lib/esm/rpc/DevToolsRpcInterface.js.map +1 -1
  827. package/lib/esm/rpc/IModelReadRpcInterface.d.ts +97 -97
  828. package/lib/esm/rpc/IModelReadRpcInterface.js +114 -114
  829. package/lib/esm/rpc/IModelReadRpcInterface.js.map +1 -1
  830. package/lib/esm/rpc/IModelTileRpcInterface.d.ts +61 -61
  831. package/lib/esm/rpc/IModelTileRpcInterface.js +92 -92
  832. package/lib/esm/rpc/IModelTileRpcInterface.js.map +1 -1
  833. package/lib/esm/rpc/SnapshotIModelRpcInterface.d.ts +23 -23
  834. package/lib/esm/rpc/SnapshotIModelRpcInterface.js +44 -44
  835. package/lib/esm/rpc/SnapshotIModelRpcInterface.js.map +1 -1
  836. package/lib/esm/rpc/TestRpcManager.d.ts +20 -20
  837. package/lib/esm/rpc/TestRpcManager.js +35 -35
  838. package/lib/esm/rpc/TestRpcManager.js.map +1 -1
  839. package/lib/esm/rpc/WipRpcInterface.d.ts +29 -29
  840. package/lib/esm/rpc/WipRpcInterface.js +36 -36
  841. package/lib/esm/rpc/WipRpcInterface.js.map +1 -1
  842. package/lib/esm/rpc/core/RpcConfiguration.d.ts +111 -111
  843. package/lib/esm/rpc/core/RpcConfiguration.js +185 -185
  844. package/lib/esm/rpc/core/RpcConfiguration.js.map +1 -1
  845. package/lib/esm/rpc/core/RpcConstants.d.ts +85 -85
  846. package/lib/esm/rpc/core/RpcConstants.js +100 -100
  847. package/lib/esm/rpc/core/RpcConstants.js.map +1 -1
  848. package/lib/esm/rpc/core/RpcControl.d.ts +52 -52
  849. package/lib/esm/rpc/core/RpcControl.js +142 -142
  850. package/lib/esm/rpc/core/RpcControl.js.map +1 -1
  851. package/lib/esm/rpc/core/RpcInvocation.d.ts +89 -89
  852. package/lib/esm/rpc/core/RpcInvocation.js +253 -253
  853. package/lib/esm/rpc/core/RpcInvocation.js.map +1 -1
  854. package/lib/esm/rpc/core/RpcMarshaling.d.ts +36 -36
  855. package/lib/esm/rpc/core/RpcMarshaling.js +149 -149
  856. package/lib/esm/rpc/core/RpcMarshaling.js.map +1 -1
  857. package/lib/esm/rpc/core/RpcOperation.d.ts +67 -67
  858. package/lib/esm/rpc/core/RpcOperation.js +128 -128
  859. package/lib/esm/rpc/core/RpcOperation.js.map +1 -1
  860. package/lib/esm/rpc/core/RpcPendingQueue.d.ts +21 -21
  861. package/lib/esm/rpc/core/RpcPendingQueue.js +90 -90
  862. package/lib/esm/rpc/core/RpcPendingQueue.js.map +1 -1
  863. package/lib/esm/rpc/core/RpcProtocol.d.ts +132 -132
  864. package/lib/esm/rpc/core/RpcProtocol.js +123 -123
  865. package/lib/esm/rpc/core/RpcProtocol.js.map +1 -1
  866. package/lib/esm/rpc/core/RpcPush.d.ts +68 -68
  867. package/lib/esm/rpc/core/RpcPush.js +119 -119
  868. package/lib/esm/rpc/core/RpcPush.js.map +1 -1
  869. package/lib/esm/rpc/core/RpcRegistry.d.ts +48 -48
  870. package/lib/esm/rpc/core/RpcRegistry.js +194 -194
  871. package/lib/esm/rpc/core/RpcRegistry.js.map +1 -1
  872. package/lib/esm/rpc/core/RpcRequest.d.ts +186 -186
  873. package/lib/esm/rpc/core/RpcRequest.js +472 -472
  874. package/lib/esm/rpc/core/RpcRequest.js.map +1 -1
  875. package/lib/esm/rpc/core/RpcRequestContext.d.ts +14 -14
  876. package/lib/esm/rpc/core/RpcRequestContext.js +1 -1
  877. package/lib/esm/rpc/core/RpcRequestContext.js.map +1 -1
  878. package/lib/esm/rpc/core/RpcRoutingToken.d.ts +12 -12
  879. package/lib/esm/rpc/core/RpcRoutingToken.js +19 -19
  880. package/lib/esm/rpc/core/RpcRoutingToken.js.map +1 -1
  881. package/lib/esm/rpc/core/RpcSessionInvocation.d.ts +10 -10
  882. package/lib/esm/rpc/core/RpcSessionInvocation.js +55 -55
  883. package/lib/esm/rpc/core/RpcSessionInvocation.js.map +1 -1
  884. package/lib/esm/rpc/web/BentleyCloudRpcManager.d.ts +46 -46
  885. package/lib/esm/rpc/web/BentleyCloudRpcManager.js +68 -68
  886. package/lib/esm/rpc/web/BentleyCloudRpcManager.js.map +1 -1
  887. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.d.ts +33 -33
  888. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.js +138 -138
  889. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.js.map +1 -1
  890. package/lib/esm/rpc/web/OpenAPI.d.ts +139 -139
  891. package/lib/esm/rpc/web/OpenAPI.js +56 -56
  892. package/lib/esm/rpc/web/OpenAPI.js.map +1 -1
  893. package/lib/esm/rpc/web/RpcMultipart.d.ts +31 -31
  894. package/lib/esm/rpc/web/RpcMultipart.js +41 -41
  895. package/lib/esm/rpc/web/RpcMultipart.js.map +1 -1
  896. package/lib/esm/rpc/web/WebAppRpcLogging.d.ts +17 -17
  897. package/lib/esm/rpc/web/WebAppRpcLogging.js +136 -136
  898. package/lib/esm/rpc/web/WebAppRpcLogging.js.map +1 -1
  899. package/lib/esm/rpc/web/WebAppRpcProtocol.d.ts +86 -86
  900. package/lib/esm/rpc/web/WebAppRpcProtocol.js +112 -112
  901. package/lib/esm/rpc/web/WebAppRpcProtocol.js.map +1 -1
  902. package/lib/esm/rpc/web/WebAppRpcRequest.d.ts +71 -71
  903. package/lib/esm/rpc/web/WebAppRpcRequest.js +370 -370
  904. package/lib/esm/rpc/web/WebAppRpcRequest.js.map +1 -1
  905. package/lib/esm/rpc/web/multipart/RpcMultipartParser.d.ts +33 -33
  906. package/lib/esm/rpc/web/multipart/RpcMultipartParser.js +355 -355
  907. package/lib/esm/rpc/web/multipart/RpcMultipartParser.js.map +1 -1
  908. package/lib/esm/tile/B3dmTileIO.d.ts +19 -19
  909. package/lib/esm/tile/B3dmTileIO.js +62 -62
  910. package/lib/esm/tile/B3dmTileIO.js.map +1 -1
  911. package/lib/esm/tile/CompositeTileIO.d.ts +15 -15
  912. package/lib/esm/tile/CompositeTileIO.js +22 -22
  913. package/lib/esm/tile/CompositeTileIO.js.map +1 -1
  914. package/lib/esm/tile/ElementGraphics.d.ts +145 -145
  915. package/lib/esm/tile/ElementGraphics.js +8 -8
  916. package/lib/esm/tile/ElementGraphics.js.map +1 -1
  917. package/lib/esm/tile/GltfTileIO.d.ts +45 -45
  918. package/lib/esm/tile/GltfTileIO.js +105 -105
  919. package/lib/esm/tile/GltfTileIO.js.map +1 -1
  920. package/lib/esm/tile/I3dmTileIO.d.ts +20 -20
  921. package/lib/esm/tile/I3dmTileIO.js +36 -36
  922. package/lib/esm/tile/I3dmTileIO.js.map +1 -1
  923. package/lib/esm/tile/IModelTileIO.d.ts +75 -75
  924. package/lib/esm/tile/IModelTileIO.js +90 -90
  925. package/lib/esm/tile/IModelTileIO.js.map +1 -1
  926. package/lib/esm/tile/PntsTileIO.d.ts +17 -17
  927. package/lib/esm/tile/PntsTileIO.js +22 -22
  928. package/lib/esm/tile/PntsTileIO.js.map +1 -1
  929. package/lib/esm/tile/TileIO.d.ts +66 -66
  930. package/lib/esm/tile/TileIO.js +110 -110
  931. package/lib/esm/tile/TileIO.js.map +1 -1
  932. package/lib/esm/tile/TileMetadata.d.ts +228 -228
  933. package/lib/esm/tile/TileMetadata.js +661 -661
  934. package/lib/esm/tile/TileMetadata.js.map +1 -1
  935. package/package.json +7 -7
package/lib/cjs/QPoint.js CHANGED
@@ -1,827 +1,827 @@
1
- "use strict";
2
- /*---------------------------------------------------------------------------------------------
3
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
- * See LICENSE.md in the project root for license terms and full copyright notice.
5
- *--------------------------------------------------------------------------------------------*/
6
- /** @packageDocumentation
7
- * @module Geometry
8
- */
9
- Object.defineProperty(exports, "__esModule", { value: true });
10
- exports.QPoint3dBufferBuilder = exports.QPoint2dBufferBuilder = exports.QPoint3dList = exports.QPoint3dBuffer = exports.QPoint3d = exports.QParams3d = exports.QPoint2dList = exports.QPoint2dBuffer = exports.QPoint2d = exports.QParams2d = exports.Quantization = void 0;
11
- const core_bentley_1 = require("@itwin/core-bentley");
12
- const core_geometry_1 = require("@itwin/core-geometry");
13
- /**
14
- * Provides facilities for quantizing floating point values within a specified range into 16-bit unsigned integers.
15
- * This is a lossy compression technique.
16
- * Given a floating point range [min, max], a floating point value `x` within that range is quantized by subtracting
17
- * `min`, scaling the result according to `max`, and truncating the result to an integer.
18
- * Therefore min quantizes to 0, max to 0xffff, (min+max)/2 to 0x7fff, and so on.
19
- * These routines are chiefly used by classes like [[QPoint2d]] and [[QPoint3d]] to reduce the space required to store
20
- * coordinate values for [RenderGraphic]($frontend)s.
21
- * @public
22
- * @extensions
23
- */
24
- var Quantization;
25
- (function (Quantization) {
26
- Quantization.rangeScale16 = 0xffff;
27
- Quantization.rangeScale8 = 0xff;
28
- /** Compute the scale factor required to quantize `extent` to `rangeScale` discrete values. */
29
- function computeScale(extent, rangeScale = Quantization.rangeScale16) {
30
- return 0.0 === extent ? extent : rangeScale / extent;
31
- }
32
- Quantization.computeScale = computeScale;
33
- /** @internal */
34
- function isInRange(qpos, rangeScale = Quantization.rangeScale16) {
35
- return qpos >= 0.0 && qpos < rangeScale + 1.0;
36
- }
37
- Quantization.isInRange = isInRange;
38
- /** Return `pos` quantized to the range [`origin`, `origin + rangeScale`].
39
- * @see [[Quantization.unquantize]] for the inverse operation.
40
- */
41
- function quantize(pos, origin, scale, rangeScale = Quantization.rangeScale16) {
42
- return Math.floor(Math.max(0.0, Math.min(rangeScale, 0.5 + (pos - origin) * scale)));
43
- }
44
- Quantization.quantize = quantize;
45
- /** @internal */
46
- function isQuantizable(pos, origin, scale, rangeScale = Quantization.rangeScale16) {
47
- return isInRange(quantize(pos, origin, scale, rangeScale));
48
- }
49
- Quantization.isQuantizable = isQuantizable;
50
- /** Give `qpos` quantized to the range [`origin`, `origin + rangeScale`], return the unquantized value.
51
- * @see [[Quantization.quantize]] for the inverse operation.
52
- */
53
- function unquantize(qpos, origin, scale) {
54
- return 0.0 === scale ? origin : origin + qpos / scale;
55
- }
56
- Quantization.unquantize = unquantize;
57
- /** @internal */
58
- function isQuantized(qpos) {
59
- return isInRange(qpos) && qpos === Math.floor(qpos);
60
- }
61
- Quantization.isQuantized = isQuantized;
62
- })(Quantization = exports.Quantization || (exports.Quantization = {}));
63
- /** Parameters used for [[Quantization]] of 2d points such that the `x` and `y` components are each quantized to 16-bit unsigned integers.
64
- * @see [[QPoint2d]] for the quantized representation of a [Point2d]($core-geometry).
65
- * @see [[QPoint2dList]] for a list of [[QPoint2d]]s quantized using a [[QParams2d]].
66
- * @public
67
- * @extensions
68
- */
69
- class QParams2d {
70
- constructor(ox = 0, oy = 0, sx = 0, sy = 0) {
71
- /** The origin of the quantization range. */
72
- this.origin = new core_geometry_1.Point2d();
73
- /** The scale applied to coordinates to quantize them. */
74
- this.scale = new core_geometry_1.Point2d();
75
- this.setFrom(ox, oy, sx, sy);
76
- }
77
- setFrom(ox, oy, sx, sy) {
78
- this.origin.x = ox;
79
- this.origin.y = oy;
80
- this.scale.x = sx;
81
- this.scale.y = sy;
82
- }
83
- /** Set [[origin]] and [[scale]] from `src`. */
84
- copyFrom(src) {
85
- this.setFrom(src.origin.x, src.origin.y, src.scale.x, src.scale.y);
86
- }
87
- /** Create a copy of these params.
88
- * @param out If supplied, these QParams2d will be modified and returned; otherwise a new QParams2d object will be created and returned.
89
- */
90
- clone(out) {
91
- const result = undefined !== out ? out : new QParams2d();
92
- result.copyFrom(this);
93
- return result;
94
- }
95
- /** Initialize these parameters to support quantization of values within the specified range. */
96
- setFromRange(range, rangeScale = Quantization.rangeScale16) {
97
- if (!range.isNull) {
98
- 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));
99
- }
100
- else {
101
- this.origin.x = this.origin.y = this.scale.x = this.scale.y = 0;
102
- }
103
- }
104
- /** Create parameters to support quantization of values within the specified range. */
105
- static fromRange(range, out, rangeScale = Quantization.rangeScale16) {
106
- const params = undefined !== out ? out : new QParams2d();
107
- params.setFromRange(range, rangeScale);
108
- return params;
109
- }
110
- /** 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. */
111
- unquantize(x, y, out) {
112
- out = out !== null && out !== void 0 ? out : new core_geometry_1.Point2d();
113
- out.x = Quantization.unquantize(x, this.origin.x, this.scale.x);
114
- out.y = Quantization.unquantize(y, this.origin.y, this.scale.y);
115
- return out;
116
- }
117
- /** Creates parameters supporting quantization of values within the range [-1.0, 1.0], appropriate for normalized 2d vectors. */
118
- static fromNormalizedRange(rangeScale = Quantization.rangeScale16) {
119
- return QParams2d.fromRange(core_geometry_1.Range2d.createArray([core_geometry_1.Point2d.create(-1, -1), core_geometry_1.Point2d.create(1, 1)]), undefined, rangeScale);
120
- }
121
- /** Create parameters supporting quantization of values within the range [0.0, 1.0]. */
122
- static fromZeroToOne(rangeScale = Quantization.rangeScale16) {
123
- return QParams2d.fromRange(core_geometry_1.Range2d.createArray([core_geometry_1.Point2d.create(0, 0), core_geometry_1.Point2d.create(1, 1)]), undefined, rangeScale);
124
- }
125
- /** Create parameters from origin and scale components */
126
- static fromOriginAndScale(originX, originY, scaleX, scaleY) {
127
- return new QParams2d(originX, originY, scaleX, scaleY);
128
- }
129
- /** @internal */
130
- get rangeDiagonal() {
131
- return core_geometry_1.Vector2d.createFrom({ x: 0 === this.scale.x ? 0 : Quantization.rangeScale16 / this.scale.x, y: 0 === this.scale.y ? 0 : Quantization.rangeScale16 / this.scale.y });
132
- }
133
- /** Return true if the point point is quantizable using these parameters. */
134
- isQuantizable(point) {
135
- return Quantization.isQuantizable(point.x, this.origin.x, this.scale.x) && Quantization.isQuantizable(point.y, this.origin.y, this.scale.y);
136
- }
137
- }
138
- exports.QParams2d = QParams2d;
139
- /** Represents a [Point2d]($core-geometry) compressed such that each component `x` and `y` is quantized to the 16-bit integer range [0, 0xffff].
140
- * These are primarily used to reduce the space required for coordinates used by [RenderGraphic]($frontend)s.
141
- * @see [[QParams2d]] to define quantization parameters for a range of points.
142
- * @see [[QPoint2dList]] for a list of points all quantized to the same range.
143
- * @public
144
- * @extensions
145
- */
146
- class QPoint2d {
147
- /** Construct with `x` and `y` initialized to zero. */
148
- constructor() {
149
- this._x = 0;
150
- this._y = 0;
151
- }
152
- /** The quantized x component. */
153
- get x() { return this._x; }
154
- set x(x) {
155
- (0, core_bentley_1.assert)(Quantization.isQuantized(x));
156
- this._x = x;
157
- }
158
- /** The quantized y component. */
159
- get y() { return this._y; }
160
- set y(y) {
161
- (0, core_bentley_1.assert)(Quantization.isQuantized(y));
162
- this._y = y;
163
- }
164
- /** Initialize this point by quantizing the supplied { x, y } using the specified params */
165
- init(pos, params) {
166
- this.x = Quantization.quantize(pos.x, params.origin.x, params.scale.x);
167
- this.y = Quantization.quantize(pos.y, params.origin.y, params.scale.y);
168
- }
169
- /** Create a quantized point from the supplied Point2d using the specified params */
170
- static create(pos, params) {
171
- const qpt = new QPoint2d();
172
- qpt.init(pos, params);
173
- return qpt;
174
- }
175
- /** Initialize `x` and `y` from `src`. */
176
- copyFrom(src) {
177
- this.x = src.x;
178
- this.y = src.y;
179
- }
180
- /** Create a copy of this point.
181
- * @param out If supplied, it will be modified in-place and returned; otherwise a new QPoint2d will be allocated and returned.
182
- */
183
- clone(out) {
184
- const result = undefined !== out ? out : new QPoint2d();
185
- result.copyFrom(this);
186
- return result;
187
- }
188
- /**
189
- * Set the x and y components directly.
190
- * @param x Must be an integer in the range [0, 0xffff]
191
- * @param y Must be an integer in the range [0, 0xffff]
192
- */
193
- setFromScalars(x, y) {
194
- this.x = x;
195
- this.y = y;
196
- }
197
- /**
198
- * Create a QPoint2d directly from x and y components.
199
- * @param x Must be an integer in the range [0, 0xffff]
200
- * @param y Must be an integer in the range [0, 0xffff]
201
- */
202
- static fromScalars(x, y) {
203
- const pt = new QPoint2d();
204
- pt.setFromScalars(x, y);
205
- return pt;
206
- }
207
- /** Return a Point2d unquantized according to the supplied `params`. If `out` is supplied, it will be modified in-place and returned. */
208
- unquantize(params, out) {
209
- const pt = undefined !== out ? out : new core_geometry_1.Point2d();
210
- pt.x = Quantization.unquantize(this.x, params.origin.x, params.scale.x);
211
- pt.y = Quantization.unquantize(this.y, params.origin.y, params.scale.y);
212
- return pt;
213
- }
214
- }
215
- exports.QPoint2d = QPoint2d;
216
- /** @public
217
- * @extensions
218
- */
219
- var QPoint2dBuffer;
220
- (function (QPoint2dBuffer) {
221
- const scratchQPoint2d = new QPoint2d();
222
- /** Extracts the point at the specified index from a buffer.
223
- * @param points The buffer in which each consecutive pair of integers is a 2d quantized point.
224
- * @param pointIndex The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
225
- * @param result If supplied, a preallocated [[QPoint2d]] to initialize with the result and return.
226
- * @returns The point at `pointIndex`.
227
- * @throws Error if `pointIndex` is out of bounds.
228
- */
229
- function getQPoint(points, pointIndex, result) {
230
- const index = pointIndex * 2;
231
- const x = points[index + 0];
232
- const y = points[index + 1];
233
- if (undefined === x || undefined === y)
234
- throw new Error("Index out of range");
235
- result = result !== null && result !== void 0 ? result : new QPoint2d();
236
- result.setFromScalars(x, y);
237
- return result;
238
- }
239
- QPoint2dBuffer.getQPoint = getQPoint;
240
- /** Extracts and unquantizes the point at the specified index from a buffer.
241
- * @param buffer The array of points and the quantization parameters.
242
- * @param The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
243
- * @param result If supplied, a preallocated [Point2d]($core-geometry) to initialize with the result and return.
244
- * @returns The point at `pointIndex`.
245
- * @throws Error if `pointIndex` is out of bounds.
246
- */
247
- function unquantizePoint(buffer, pointIndex, result) {
248
- const qpt = getQPoint(buffer.points, pointIndex, scratchQPoint2d);
249
- return qpt.unquantize(buffer.params, result);
250
- }
251
- QPoint2dBuffer.unquantizePoint = unquantizePoint;
252
- })(QPoint2dBuffer = exports.QPoint2dBuffer || (exports.QPoint2dBuffer = {}));
253
- /** A list of [[QPoint2d]]s all quantized to the same range.
254
- * @public
255
- * @extensions
256
- */
257
- class QPoint2dList {
258
- /** Construct an empty list set up to use the supplied quantization parameters. */
259
- constructor(params) {
260
- this._list = new Array();
261
- this.params = params.clone();
262
- }
263
- /** The list of quantized points. */
264
- get list() {
265
- return this._list;
266
- }
267
- /** Removes all points from the list. */
268
- clear() {
269
- this._list.length = 0;
270
- }
271
- /** Removes all points from the list and change the quantization parameters. */
272
- reset(params) {
273
- this.clear();
274
- this.params.copyFrom(params);
275
- }
276
- /** Quantizes the supplied Point2d to this list's range and appends it to the list. */
277
- add(pt) {
278
- this._list.push(QPoint2d.create(pt, this.params));
279
- }
280
- /** Adds a previously-quantized point to this list. */
281
- push(qpt) {
282
- this._list.push(qpt.clone());
283
- }
284
- /** The number of points in the list. */
285
- get length() {
286
- return this._list.length;
287
- }
288
- /** Returns the unquantized value of the point at the specified index in the list. */
289
- unquantize(index, out) {
290
- (0, core_bentley_1.assert)(index < this.length);
291
- if (index < this.length) {
292
- return this._list[index].unquantize(this.params, out);
293
- }
294
- else {
295
- return undefined !== out ? out : new core_geometry_1.Point2d();
296
- }
297
- }
298
- /** Changes the quantization parameters and requantizes all points in the list to the new range.
299
- * @note The loss of precision is compounded each time the points are requantized to a new range.
300
- */
301
- requantize(params) {
302
- for (let i = 0; i < this.length; i++) {
303
- const pt = this.unquantize(i);
304
- this._list[i].init(pt, params);
305
- }
306
- this.params.copyFrom(params);
307
- }
308
- /** 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,
309
- * the second to the first point's `y` component, and so on.
310
- */
311
- toTypedArray() {
312
- const array = new Uint16Array(this.length * 2);
313
- const pts = this._list;
314
- for (let i = 0; i < this.length; i++) {
315
- const pt = pts[i];
316
- array[i * 2] = pt.x;
317
- array[i * 2 + 1] = pt.y;
318
- }
319
- return array;
320
- }
321
- /** 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. */
322
- fromTypedArray(range, array) {
323
- this.params.setFromRange(range);
324
- this._list.length = array.length / 2;
325
- for (let i = 0, j = 0; i < this.list.length; i++)
326
- this._list[i] = QPoint2d.fromScalars(array[j++], array[j++]);
327
- }
328
- /** Construct a QPoint2dList containing all points in the supplied list, quantized to the range of those points. */
329
- static fromPoints(points, out) {
330
- let qPoints;
331
- const qParams = QParams2d.fromRange(core_geometry_1.Range2d.createArray(points));
332
- if (out) {
333
- qPoints = out;
334
- qPoints.reset(qParams);
335
- }
336
- else {
337
- qPoints = new QPoint2dList(qParams);
338
- }
339
- for (const point of points)
340
- qPoints.add(point);
341
- return qPoints;
342
- }
343
- }
344
- exports.QPoint2dList = QPoint2dList;
345
- /** Parameters used for [[Quantization]] of 3d points such that the `x`, `y`, and `z` components are each quantized to 16-bit unsigned integers.
346
- * @see [[QPoint3d]] for the quantized representation of a [Point3d]($core-geometry).
347
- * @see [[QPoint3dList]] for a list of [[QPoint3d]]s quantized using a [[QParams3d]].
348
- * @public
349
- * @extensions
350
- */
351
- class QParams3d {
352
- constructor(ox = 0, oy = 0, oz = 0, sx = 0, sy = 0, sz = 0) {
353
- /** The origin of the quantization range. */
354
- this.origin = new core_geometry_1.Point3d();
355
- /** The scale applied to coordinates to quantize them. */
356
- this.scale = new core_geometry_1.Point3d();
357
- this.setFrom(ox, oy, oz, sx, sy, sz);
358
- }
359
- setFrom(ox, oy, oz, sx, sy, sz) {
360
- this.origin.x = ox;
361
- this.origin.y = oy;
362
- this.origin.z = oz;
363
- this.scale.x = sx;
364
- this.scale.y = sy;
365
- this.scale.z = sz;
366
- }
367
- /** Set `x`, `y`, and `z` from `src. */
368
- copyFrom(src) {
369
- this.setFrom(src.origin.x, src.origin.y, src.origin.z, src.scale.x, src.scale.y, src.scale.z);
370
- }
371
- /** Create a copy of these parameters.
372
- * @param out If supplied, it will be modified in-place and returned instead of allocating a new QParams3d.
373
- */
374
- clone(out) {
375
- const result = undefined !== out ? out : new QParams3d();
376
- result.copyFrom(this);
377
- return result;
378
- }
379
- /** Initialize from origin and scale */
380
- setFromOriginAndScale(origin, scale) {
381
- this.setFrom(origin.x, origin.y, origin.z, scale.x, scale.y, scale.z);
382
- }
383
- /** Initialize these parameters to support quantization of values within the specified range. */
384
- setFromRange(range, rangeScale = Quantization.rangeScale16) {
385
- if (!range.isNull) {
386
- 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));
387
- }
388
- else {
389
- this.origin.x = this.origin.y = this.origin.z = 0;
390
- this.scale.x = this.scale.y = this.scale.z = 0;
391
- }
392
- }
393
- /** Return the unquantized point for the input components.
394
- * @param out If supplied, it will be modified in-place and returned instead of allocating a new Point3d.
395
- */
396
- unquantize(x, y, z, out) {
397
- const pt = undefined !== out ? out : new core_geometry_1.Point3d();
398
- pt.x = Quantization.unquantize(x, this.origin.x, this.scale.x);
399
- pt.y = Quantization.unquantize(y, this.origin.y, this.scale.y);
400
- pt.z = Quantization.unquantize(z, this.origin.z, this.scale.z);
401
- return pt;
402
- }
403
- /** Creates parameters to support quantization of values within the specified range.
404
- * If `out` is supplied, it will be modified in-place and returned instead of allocating a new QParams3d.
405
- */
406
- static fromRange(range, out, rangeScale = Quantization.rangeScale16) {
407
- const params = undefined !== out ? out : new QParams3d();
408
- params.setFromRange(range, rangeScale);
409
- return params;
410
- }
411
- /** Creates parameters supporting quantization of values within the range [-1.0, 1.0].
412
- * If `out` is supplied, it will be modified in-place and returned instead of allocating a new QParams3d.
413
- */
414
- static fromOriginAndScale(origin, scale, out) {
415
- const params = undefined !== out ? out : new QParams3d();
416
- params.setFromOriginAndScale(origin, scale);
417
- return params;
418
- }
419
- /** Creates parameters supporting quantization of values within the range [-1.0, 1.0]. */
420
- static fromNormalizedRange(rangeScale = Quantization.rangeScale16) {
421
- return QParams3d.fromRange(core_geometry_1.Range3d.createArray([core_geometry_1.Point3d.create(-1, -1, -1), core_geometry_1.Point3d.create(1, 1, 1)]), undefined, rangeScale);
422
- }
423
- /** Creates parameters supporting quantization of values within the range [0.0, 1.0]. */
424
- static fromZeroToOne(rangeScale = Quantization.rangeScale16) {
425
- return QParams3d.fromRange(core_geometry_1.Range3d.createArray([core_geometry_1.Point3d.create(0, 0, 0), core_geometry_1.Point3d.create(1, 1, 1)]), undefined, rangeScale);
426
- }
427
- /** @internal */
428
- get rangeDiagonal() {
429
- return core_geometry_1.Vector3d.createFrom({
430
- x: this.scale.x === 0 ? 0 : Quantization.rangeScale16 / this.scale.x,
431
- y: this.scale.y === 0 ? 0 : Quantization.rangeScale16 / this.scale.y,
432
- z: this.scale.z === 0 ? 0 : Quantization.rangeScale16 / this.scale.z,
433
- });
434
- }
435
- /** Return true if the point point is quantizable using these parameters. */
436
- isQuantizable(point) {
437
- 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);
438
- }
439
- /** Compute the range to which these parameters quantize. */
440
- computeRange(out) {
441
- const range = core_geometry_1.Range3d.createNull(out);
442
- range.extendPoint(this.origin);
443
- range.extendPoint(this.origin.plus(this.rangeDiagonal));
444
- return range;
445
- }
446
- }
447
- exports.QParams3d = QParams3d;
448
- /** Represents a [Point3d]($core-geometry) compressed such that each component `x`, `y`, and `z` is quantized to the 16-bit integer range [0, 0xffff].
449
- * These are primarily used to reduce the space required for coordinates used by [RenderGraphic]($frontend)s.
450
- * @see [[QParams3d]] to define quantization parameters for a range of points.
451
- * @see [[QPoint3dList]] for a list of points all quantized to the same range.
452
- * @public
453
- * @extensions
454
- */
455
- class QPoint3d {
456
- /** Construct with all components initialized to zero. */
457
- constructor() {
458
- this._x = 0;
459
- this._y = 0;
460
- this._z = 0;
461
- }
462
- /** The quantized x component. */
463
- get x() { return this._x; }
464
- set x(x) {
465
- (0, core_bentley_1.assert)(Quantization.isQuantized(x));
466
- this._x = x;
467
- }
468
- /** The quantized y component. */
469
- get y() { return this._y; }
470
- set y(y) {
471
- (0, core_bentley_1.assert)(Quantization.isQuantized(y));
472
- this._y = y;
473
- }
474
- /** The quantized z component. */
475
- get z() { return this._z; }
476
- set z(z) {
477
- (0, core_bentley_1.assert)(Quantization.isQuantized(z));
478
- this._z = z;
479
- }
480
- /** Initialize this point by quantizing the supplied { x, y, z } using the specified params */
481
- init(pos, params) {
482
- this.x = Quantization.quantize(pos.x, params.origin.x, params.scale.x);
483
- this.y = Quantization.quantize(pos.y, params.origin.y, params.scale.y);
484
- this.z = Quantization.quantize(pos.z, params.origin.z, params.scale.z);
485
- }
486
- /** Creates a quantized point from the supplied Point3d using the specified params */
487
- static create(pos, params) {
488
- const qpt = new QPoint3d();
489
- qpt.init(pos, params);
490
- return qpt;
491
- }
492
- /** Set this points components from `src`. */
493
- copyFrom(src) {
494
- this.x = src.x;
495
- this.y = src.y;
496
- this.z = src.z;
497
- }
498
- /** Create a copy of this point.
499
- * @param out If supplied, it will be modified in-place instead of allocating a new QPoint3d.
500
- */
501
- clone(out) {
502
- const result = undefined !== out ? out : new QPoint3d();
503
- result.copyFrom(this);
504
- return result;
505
- }
506
- /**
507
- * Sets the x, y, and z components directly.
508
- * @param x Must be an integer in the range [0, 0xffff]
509
- * @param y Must be an integer in the range [0, 0xffff]
510
- * @param z Must be an integer in the range [0, 0xffff]
511
- */
512
- setFromScalars(x, y, z) {
513
- this.x = x;
514
- this.y = y;
515
- this.z = z;
516
- }
517
- /**
518
- * Creates a QPoint3d directly from x, y, and z components.
519
- * @param x Must be an integer in the range [0, 0xffff]
520
- * @param y Must be an integer in the range [0, 0xffff]
521
- * @param z Must be an integer in the range [0, 0xffff]
522
- * @param out If supplied, it will be modified in-place instead of allocating a new QPoint3d.
523
- */
524
- static fromScalars(x, y, z, out) {
525
- const pt = undefined === out ? new QPoint3d() : out;
526
- pt.setFromScalars(x, y, z);
527
- return pt;
528
- }
529
- /** Returns a Point3d unquantized according to the supplied params.
530
- * If `out` is supplied, it will be modified in-place instead of allocating a new Point3d.
531
- */
532
- unquantize(params, out) {
533
- const pt = undefined !== out ? out : new core_geometry_1.Point3d();
534
- pt.x = Quantization.unquantize(this.x, params.origin.x, params.scale.x);
535
- pt.y = Quantization.unquantize(this.y, params.origin.y, params.scale.y);
536
- pt.z = Quantization.unquantize(this.z, params.origin.z, params.scale.z);
537
- return pt;
538
- }
539
- /** Return true if this point's components are identical to the other point's components. */
540
- equals(other) {
541
- return this.x === other.x && this.y === other.y && this.z === other.z;
542
- }
543
- /** Perform ordinal comparison to another point. The function returns:
544
- * - Zero if this point is identical to `rhs`; or
545
- * - A number less than zero if this point is ordered before `rhs`; or
546
- * - A number greater than zero if this point is ordered after `rhs`.
547
- * @see [OrderedComparator]($core-bentley).
548
- */
549
- compare(rhs) {
550
- let diff = this.x - rhs.x;
551
- if (0 === diff) {
552
- diff = this.y - rhs.y;
553
- if (0 === diff) {
554
- diff = this.z - rhs.z;
555
- }
556
- }
557
- return diff;
558
- }
559
- }
560
- exports.QPoint3d = QPoint3d;
561
- /** @public
562
- * @extensions
563
- */
564
- var QPoint3dBuffer;
565
- (function (QPoint3dBuffer) {
566
- const scratchQPoint3d = new QPoint3d();
567
- /** Extracts the point at the specified index from a buffer.
568
- * @param points The buffer in which each consecutive pair of integers is a 3d quantized point.
569
- * @param pointIndex The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
570
- * @param result If supplied, a preallocated [[QPoint3d]] to initialize with the result and return.
571
- * @returns The point at `pointIndex`.
572
- * @throws Error if `pointIndex` is out of bounds.
573
- */
574
- function getQPoint(points, pointIndex, result) {
575
- const index = pointIndex * 3;
576
- const x = points[index + 0];
577
- const y = points[index + 1];
578
- const z = points[index + 2];
579
- if (undefined === x || undefined === y || undefined === z)
580
- throw new Error("Index out of range");
581
- result = result !== null && result !== void 0 ? result : new QPoint3d();
582
- result.setFromScalars(x, y, z);
583
- return result;
584
- }
585
- QPoint3dBuffer.getQPoint = getQPoint;
586
- /** Extracts and unquantizes the point at the specified index from a buffer.
587
- * @param buffer The array of points and the quantization parameters.
588
- * @param The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
589
- * @param result If supplied, a preallocated [Point3d]($core-geometry) to initialize with the result and return.
590
- * @returns The point at `pointIndex`.
591
- * @throws Error if `pointIndex` is out of bounds.
592
- */
593
- function unquantizePoint(buffer, pointIndex, result) {
594
- const qpt = getQPoint(buffer.points, pointIndex, scratchQPoint3d);
595
- return qpt.unquantize(buffer.params, result);
596
- }
597
- QPoint3dBuffer.unquantizePoint = unquantizePoint;
598
- })(QPoint3dBuffer = exports.QPoint3dBuffer || (exports.QPoint3dBuffer = {}));
599
- /** A list of [[QPoint3d]]s all quantized to the same range.
600
- * @public
601
- * @extensions
602
- */
603
- class QPoint3dList {
604
- /** Construct an empty list set up to quantize to the supplied range.
605
- * @param The quantization parameters. If omitted, a null range will be used.
606
- */
607
- constructor(params) {
608
- this._list = [];
609
- this.params = params ? params.clone() : QParams3d.fromRange(core_geometry_1.Range3d.createNull());
610
- }
611
- /** The list of quantized points. */
612
- get list() {
613
- return this._list;
614
- }
615
- /** Construct a QPoint3dList containing all points in the supplied list, quantized to the range of those points.
616
- * @param The points to quantize and add to the list.
617
- * @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.
618
- */
619
- static fromPoints(points, out) {
620
- let qPoints;
621
- const qParams = QParams3d.fromRange(core_geometry_1.Range3d.createArray(points));
622
- if (out) {
623
- qPoints = out;
624
- qPoints.reset(qParams);
625
- }
626
- else {
627
- qPoints = new QPoint3dList(qParams);
628
- }
629
- for (const point of points)
630
- qPoints.add(point);
631
- return qPoints;
632
- }
633
- /** Removes all points from the list. */
634
- clear() {
635
- this._list.length = 0;
636
- }
637
- /** Clears out the contents of the list and changes the quantization parameters. */
638
- reset(params) {
639
- this.clear();
640
- this.params.copyFrom(params);
641
- }
642
- /** Quantizes the supplied Point3d to this list's range and appends it to the list. */
643
- add(pt) {
644
- this._list.push(QPoint3d.create(pt, this.params));
645
- }
646
- /** Adds a previously-quantized point to this list. */
647
- push(qpt) {
648
- this._list.push(qpt.clone());
649
- }
650
- /** The number of points in the list. */
651
- get length() {
652
- return this._list.length;
653
- }
654
- /** Returns the unquantized value of the point at the specified index in the list. */
655
- unquantize(index, out) {
656
- (0, core_bentley_1.assert)(index < this.length);
657
- if (index < this.length) {
658
- return this._list[index].unquantize(this.params, out);
659
- }
660
- else {
661
- return undefined !== out ? out : new core_geometry_1.Point3d();
662
- }
663
- }
664
- /** Changes the quantization parameters and requantizes all points in the list to the new range.
665
- * @note The loss of precision is compounded each time the points are requantized to a new range.
666
- */
667
- requantize(params) {
668
- for (let i = 0; i < this.length; i++) {
669
- const pt = this.unquantize(i);
670
- this._list[i].init(pt, params);
671
- }
672
- this.params.copyFrom(params);
673
- }
674
- /** 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,
675
- * the second three elements contain the second point's components, and so on.
676
- */
677
- toTypedArray() {
678
- const array = new Uint16Array(this.length * 3);
679
- const pts = this._list;
680
- for (let i = 0; i < this.length; i++) {
681
- const pt = pts[i];
682
- array[i * 3 + 0] = pt.x;
683
- array[i * 3 + 1] = pt.y;
684
- array[i * 3 + 2] = pt.z;
685
- }
686
- return array;
687
- }
688
- /** 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
689
- * of the second point, and so on.
690
- */
691
- fromTypedArray(range, array) {
692
- this.params.setFromRange(range);
693
- this._list.length = array.length / 3;
694
- for (let i = 0, j = 0; i < this.list.length; i++)
695
- this._list[i] = QPoint3d.fromScalars(array[j++], array[j++], array[j++]);
696
- }
697
- /** Construct a list containing all points in the supplied list, quantized using the supplied parameters. */
698
- static createFrom(points, params) {
699
- const list = new QPoint3dList(params);
700
- for (const point of points)
701
- list.add(point);
702
- return list;
703
- }
704
- /** An iterator over the points in the list. */
705
- [Symbol.iterator]() {
706
- return this.list[Symbol.iterator]();
707
- }
708
- }
709
- exports.QPoint3dList = QPoint3dList;
710
- /** Constructs a [[QPoint2dBuffer]] using a [Uint16ArrayBuilder]($bentley).
711
- * @public
712
- * @extensions
713
- */
714
- class QPoint2dBufferBuilder {
715
- /** Construct a new buffer with a [[length]] of zero. */
716
- constructor(options) {
717
- var _a;
718
- this._scratchQPoint2d = new QPoint2d();
719
- this.params = QParams2d.fromRange(options.range);
720
- const initialCapacity = (_a = options.initialCapacity) !== null && _a !== void 0 ? _a : 0;
721
- this.buffer = new core_bentley_1.Uint16ArrayBuilder({
722
- growthFactor: options.growthFactor,
723
- initialCapacity: 2 * initialCapacity,
724
- });
725
- }
726
- /** Append a point with the specified quantized coordinates. */
727
- pushXY(x, y) {
728
- this.buffer.push(x);
729
- this.buffer.push(y);
730
- }
731
- /** Append a point with the specified quantized coordinates. */
732
- push(pt) {
733
- this.pushXY(pt.x, pt.y);
734
- }
735
- /** The number of points currently in the [[buffer]]. */
736
- get length() {
737
- const len = this.buffer.length;
738
- (0, core_bentley_1.assert)(len % 2 === 0);
739
- return len / 2;
740
- }
741
- /** Returns the quantized point at the specified index in [[buffer]].
742
- * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
743
- * @param result If supplied, a [[QPoint2d]] to initialize with the result and return.
744
- * @returns The quantized point at the specified index in [[buffer]].
745
- * @throws Error if `pointIndex` is out of bounds.
746
- */
747
- get(pointIndex, result) {
748
- return QPoint2dBuffer.getQPoint(this.buffer.toTypedArray(), pointIndex, result);
749
- }
750
- /** Returns the unquantized point at the specified index in [[buffer]].
751
- * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
752
- * @param result If supplied, a [Point2d]($core-geometry) to initialize with the result and return.
753
- * @returns The unquantized point at the specified index in [[buffer]].
754
- * @throws Error if `pointIndex` is out of bounds.
755
- */
756
- unquantize(pointIndex, result) {
757
- return this.get(pointIndex, this._scratchQPoint2d).unquantize(this.params, result);
758
- }
759
- /** Obtain a [[QPoint2dBuffer]] containing all of the points that have been appended by this builder. */
760
- finish() {
761
- return {
762
- params: this.params,
763
- points: this.buffer.toTypedArray(),
764
- };
765
- }
766
- }
767
- exports.QPoint2dBufferBuilder = QPoint2dBufferBuilder;
768
- /** Constructs a [[QPoint3dBuffer]] using a [Uint16ArrayBuilder]($bentley).
769
- * @public
770
- * @extensions
771
- */
772
- class QPoint3dBufferBuilder {
773
- /** Construct a new buffer with a [[length]] of zero. */
774
- constructor(options) {
775
- var _a;
776
- this._scratchQPoint3d = new QPoint3d();
777
- this.params = QParams3d.fromRange(options.range);
778
- const initialCapacity = (_a = options.initialCapacity) !== null && _a !== void 0 ? _a : 0;
779
- this.buffer = new core_bentley_1.Uint16ArrayBuilder({
780
- growthFactor: options.growthFactor,
781
- initialCapacity: 3 * initialCapacity,
782
- });
783
- }
784
- /** Append a point with the specified quantized coordinates. */
785
- pushXYZ(x, y, z) {
786
- this.buffer.push(x);
787
- this.buffer.push(y);
788
- this.buffer.push(z);
789
- }
790
- /** Append a point with the specified quantized coordinates. */
791
- push(pt) {
792
- this.pushXYZ(pt.x, pt.y, pt.z);
793
- }
794
- /** The number of points currently in the [[buffer]]. */
795
- get length() {
796
- const len = this.buffer.length;
797
- (0, core_bentley_1.assert)(len % 3 === 0);
798
- return len / 3;
799
- }
800
- /** Returns the quantized point at the specified index in [[buffer]].
801
- * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
802
- * @param result If supplied, a [[QPoint3d]] to initialize with the result and return.
803
- * @returns The quantized point at the specified index in [[buffer]].
804
- * @throws Error if `pointIndex` is out of bounds.
805
- */
806
- get(pointIndex, result) {
807
- return QPoint3dBuffer.getQPoint(this.buffer.toTypedArray(), pointIndex, result);
808
- }
809
- /** Returns the unquantized point at the specified index in [[buffer]].
810
- * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
811
- * @param result If supplied, a [Point3d]($core-geometry) to initialize with the result and return.
812
- * @returns The unquantized point at the specified index in [[buffer]].
813
- * @throws Error if `pointIndex` is out of bounds.
814
- */
815
- unquantize(pointIndex, result) {
816
- return this.get(pointIndex, this._scratchQPoint3d).unquantize(this.params, result);
817
- }
818
- /** Obtain a [[QPoint3dBuffer]] containing all of the points that have been appended by this builder. */
819
- finish() {
820
- return {
821
- params: this.params,
822
- points: this.buffer.toTypedArray(),
823
- };
824
- }
825
- }
826
- exports.QPoint3dBufferBuilder = QPoint3dBufferBuilder;
1
+ "use strict";
2
+ /*---------------------------------------------------------------------------------------------
3
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
+ * See LICENSE.md in the project root for license terms and full copyright notice.
5
+ *--------------------------------------------------------------------------------------------*/
6
+ /** @packageDocumentation
7
+ * @module Geometry
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.QPoint3dBufferBuilder = exports.QPoint2dBufferBuilder = exports.QPoint3dList = exports.QPoint3dBuffer = exports.QPoint3d = exports.QParams3d = exports.QPoint2dList = exports.QPoint2dBuffer = exports.QPoint2d = exports.QParams2d = exports.Quantization = void 0;
11
+ const core_bentley_1 = require("@itwin/core-bentley");
12
+ const core_geometry_1 = require("@itwin/core-geometry");
13
+ /**
14
+ * Provides facilities for quantizing floating point values within a specified range into 16-bit unsigned integers.
15
+ * This is a lossy compression technique.
16
+ * Given a floating point range [min, max], a floating point value `x` within that range is quantized by subtracting
17
+ * `min`, scaling the result according to `max`, and truncating the result to an integer.
18
+ * Therefore min quantizes to 0, max to 0xffff, (min+max)/2 to 0x7fff, and so on.
19
+ * These routines are chiefly used by classes like [[QPoint2d]] and [[QPoint3d]] to reduce the space required to store
20
+ * coordinate values for [RenderGraphic]($frontend)s.
21
+ * @public
22
+ * @extensions
23
+ */
24
+ var Quantization;
25
+ (function (Quantization) {
26
+ Quantization.rangeScale16 = 0xffff;
27
+ Quantization.rangeScale8 = 0xff;
28
+ /** Compute the scale factor required to quantize `extent` to `rangeScale` discrete values. */
29
+ function computeScale(extent, rangeScale = Quantization.rangeScale16) {
30
+ return 0.0 === extent ? extent : rangeScale / extent;
31
+ }
32
+ Quantization.computeScale = computeScale;
33
+ /** @internal */
34
+ function isInRange(qpos, rangeScale = Quantization.rangeScale16) {
35
+ return qpos >= 0.0 && qpos < rangeScale + 1.0;
36
+ }
37
+ Quantization.isInRange = isInRange;
38
+ /** Return `pos` quantized to the range [`origin`, `origin + rangeScale`].
39
+ * @see [[Quantization.unquantize]] for the inverse operation.
40
+ */
41
+ function quantize(pos, origin, scale, rangeScale = Quantization.rangeScale16) {
42
+ return Math.floor(Math.max(0.0, Math.min(rangeScale, 0.5 + (pos - origin) * scale)));
43
+ }
44
+ Quantization.quantize = quantize;
45
+ /** @internal */
46
+ function isQuantizable(pos, origin, scale, rangeScale = Quantization.rangeScale16) {
47
+ return isInRange(quantize(pos, origin, scale, rangeScale));
48
+ }
49
+ Quantization.isQuantizable = isQuantizable;
50
+ /** Give `qpos` quantized to the range [`origin`, `origin + rangeScale`], return the unquantized value.
51
+ * @see [[Quantization.quantize]] for the inverse operation.
52
+ */
53
+ function unquantize(qpos, origin, scale) {
54
+ return 0.0 === scale ? origin : origin + qpos / scale;
55
+ }
56
+ Quantization.unquantize = unquantize;
57
+ /** @internal */
58
+ function isQuantized(qpos) {
59
+ return isInRange(qpos) && qpos === Math.floor(qpos);
60
+ }
61
+ Quantization.isQuantized = isQuantized;
62
+ })(Quantization = exports.Quantization || (exports.Quantization = {}));
63
+ /** Parameters used for [[Quantization]] of 2d points such that the `x` and `y` components are each quantized to 16-bit unsigned integers.
64
+ * @see [[QPoint2d]] for the quantized representation of a [Point2d]($core-geometry).
65
+ * @see [[QPoint2dList]] for a list of [[QPoint2d]]s quantized using a [[QParams2d]].
66
+ * @public
67
+ * @extensions
68
+ */
69
+ class QParams2d {
70
+ constructor(ox = 0, oy = 0, sx = 0, sy = 0) {
71
+ /** The origin of the quantization range. */
72
+ this.origin = new core_geometry_1.Point2d();
73
+ /** The scale applied to coordinates to quantize them. */
74
+ this.scale = new core_geometry_1.Point2d();
75
+ this.setFrom(ox, oy, sx, sy);
76
+ }
77
+ setFrom(ox, oy, sx, sy) {
78
+ this.origin.x = ox;
79
+ this.origin.y = oy;
80
+ this.scale.x = sx;
81
+ this.scale.y = sy;
82
+ }
83
+ /** Set [[origin]] and [[scale]] from `src`. */
84
+ copyFrom(src) {
85
+ this.setFrom(src.origin.x, src.origin.y, src.scale.x, src.scale.y);
86
+ }
87
+ /** Create a copy of these params.
88
+ * @param out If supplied, these QParams2d will be modified and returned; otherwise a new QParams2d object will be created and returned.
89
+ */
90
+ clone(out) {
91
+ const result = undefined !== out ? out : new QParams2d();
92
+ result.copyFrom(this);
93
+ return result;
94
+ }
95
+ /** Initialize these parameters to support quantization of values within the specified range. */
96
+ setFromRange(range, rangeScale = Quantization.rangeScale16) {
97
+ if (!range.isNull) {
98
+ 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));
99
+ }
100
+ else {
101
+ this.origin.x = this.origin.y = this.scale.x = this.scale.y = 0;
102
+ }
103
+ }
104
+ /** Create parameters to support quantization of values within the specified range. */
105
+ static fromRange(range, out, rangeScale = Quantization.rangeScale16) {
106
+ const params = undefined !== out ? out : new QParams2d();
107
+ params.setFromRange(range, rangeScale);
108
+ return params;
109
+ }
110
+ /** 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. */
111
+ unquantize(x, y, out) {
112
+ out = out !== null && out !== void 0 ? out : new core_geometry_1.Point2d();
113
+ out.x = Quantization.unquantize(x, this.origin.x, this.scale.x);
114
+ out.y = Quantization.unquantize(y, this.origin.y, this.scale.y);
115
+ return out;
116
+ }
117
+ /** Creates parameters supporting quantization of values within the range [-1.0, 1.0], appropriate for normalized 2d vectors. */
118
+ static fromNormalizedRange(rangeScale = Quantization.rangeScale16) {
119
+ return QParams2d.fromRange(core_geometry_1.Range2d.createArray([core_geometry_1.Point2d.create(-1, -1), core_geometry_1.Point2d.create(1, 1)]), undefined, rangeScale);
120
+ }
121
+ /** Create parameters supporting quantization of values within the range [0.0, 1.0]. */
122
+ static fromZeroToOne(rangeScale = Quantization.rangeScale16) {
123
+ return QParams2d.fromRange(core_geometry_1.Range2d.createArray([core_geometry_1.Point2d.create(0, 0), core_geometry_1.Point2d.create(1, 1)]), undefined, rangeScale);
124
+ }
125
+ /** Create parameters from origin and scale components */
126
+ static fromOriginAndScale(originX, originY, scaleX, scaleY) {
127
+ return new QParams2d(originX, originY, scaleX, scaleY);
128
+ }
129
+ /** @internal */
130
+ get rangeDiagonal() {
131
+ return core_geometry_1.Vector2d.createFrom({ x: 0 === this.scale.x ? 0 : Quantization.rangeScale16 / this.scale.x, y: 0 === this.scale.y ? 0 : Quantization.rangeScale16 / this.scale.y });
132
+ }
133
+ /** Return true if the point point is quantizable using these parameters. */
134
+ isQuantizable(point) {
135
+ return Quantization.isQuantizable(point.x, this.origin.x, this.scale.x) && Quantization.isQuantizable(point.y, this.origin.y, this.scale.y);
136
+ }
137
+ }
138
+ exports.QParams2d = QParams2d;
139
+ /** Represents a [Point2d]($core-geometry) compressed such that each component `x` and `y` is quantized to the 16-bit integer range [0, 0xffff].
140
+ * These are primarily used to reduce the space required for coordinates used by [RenderGraphic]($frontend)s.
141
+ * @see [[QParams2d]] to define quantization parameters for a range of points.
142
+ * @see [[QPoint2dList]] for a list of points all quantized to the same range.
143
+ * @public
144
+ * @extensions
145
+ */
146
+ class QPoint2d {
147
+ /** Construct with `x` and `y` initialized to zero. */
148
+ constructor() {
149
+ this._x = 0;
150
+ this._y = 0;
151
+ }
152
+ /** The quantized x component. */
153
+ get x() { return this._x; }
154
+ set x(x) {
155
+ (0, core_bentley_1.assert)(Quantization.isQuantized(x));
156
+ this._x = x;
157
+ }
158
+ /** The quantized y component. */
159
+ get y() { return this._y; }
160
+ set y(y) {
161
+ (0, core_bentley_1.assert)(Quantization.isQuantized(y));
162
+ this._y = y;
163
+ }
164
+ /** Initialize this point by quantizing the supplied { x, y } using the specified params */
165
+ init(pos, params) {
166
+ this.x = Quantization.quantize(pos.x, params.origin.x, params.scale.x);
167
+ this.y = Quantization.quantize(pos.y, params.origin.y, params.scale.y);
168
+ }
169
+ /** Create a quantized point from the supplied Point2d using the specified params */
170
+ static create(pos, params) {
171
+ const qpt = new QPoint2d();
172
+ qpt.init(pos, params);
173
+ return qpt;
174
+ }
175
+ /** Initialize `x` and `y` from `src`. */
176
+ copyFrom(src) {
177
+ this.x = src.x;
178
+ this.y = src.y;
179
+ }
180
+ /** Create a copy of this point.
181
+ * @param out If supplied, it will be modified in-place and returned; otherwise a new QPoint2d will be allocated and returned.
182
+ */
183
+ clone(out) {
184
+ const result = undefined !== out ? out : new QPoint2d();
185
+ result.copyFrom(this);
186
+ return result;
187
+ }
188
+ /**
189
+ * Set the x and y components directly.
190
+ * @param x Must be an integer in the range [0, 0xffff]
191
+ * @param y Must be an integer in the range [0, 0xffff]
192
+ */
193
+ setFromScalars(x, y) {
194
+ this.x = x;
195
+ this.y = y;
196
+ }
197
+ /**
198
+ * Create a QPoint2d directly from x and y components.
199
+ * @param x Must be an integer in the range [0, 0xffff]
200
+ * @param y Must be an integer in the range [0, 0xffff]
201
+ */
202
+ static fromScalars(x, y) {
203
+ const pt = new QPoint2d();
204
+ pt.setFromScalars(x, y);
205
+ return pt;
206
+ }
207
+ /** Return a Point2d unquantized according to the supplied `params`. If `out` is supplied, it will be modified in-place and returned. */
208
+ unquantize(params, out) {
209
+ const pt = undefined !== out ? out : new core_geometry_1.Point2d();
210
+ pt.x = Quantization.unquantize(this.x, params.origin.x, params.scale.x);
211
+ pt.y = Quantization.unquantize(this.y, params.origin.y, params.scale.y);
212
+ return pt;
213
+ }
214
+ }
215
+ exports.QPoint2d = QPoint2d;
216
+ /** @public
217
+ * @extensions
218
+ */
219
+ var QPoint2dBuffer;
220
+ (function (QPoint2dBuffer) {
221
+ const scratchQPoint2d = new QPoint2d();
222
+ /** Extracts the point at the specified index from a buffer.
223
+ * @param points The buffer in which each consecutive pair of integers is a 2d quantized point.
224
+ * @param pointIndex The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
225
+ * @param result If supplied, a preallocated [[QPoint2d]] to initialize with the result and return.
226
+ * @returns The point at `pointIndex`.
227
+ * @throws Error if `pointIndex` is out of bounds.
228
+ */
229
+ function getQPoint(points, pointIndex, result) {
230
+ const index = pointIndex * 2;
231
+ const x = points[index + 0];
232
+ const y = points[index + 1];
233
+ if (undefined === x || undefined === y)
234
+ throw new Error("Index out of range");
235
+ result = result !== null && result !== void 0 ? result : new QPoint2d();
236
+ result.setFromScalars(x, y);
237
+ return result;
238
+ }
239
+ QPoint2dBuffer.getQPoint = getQPoint;
240
+ /** Extracts and unquantizes the point at the specified index from a buffer.
241
+ * @param buffer The array of points and the quantization parameters.
242
+ * @param The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
243
+ * @param result If supplied, a preallocated [Point2d]($core-geometry) to initialize with the result and return.
244
+ * @returns The point at `pointIndex`.
245
+ * @throws Error if `pointIndex` is out of bounds.
246
+ */
247
+ function unquantizePoint(buffer, pointIndex, result) {
248
+ const qpt = getQPoint(buffer.points, pointIndex, scratchQPoint2d);
249
+ return qpt.unquantize(buffer.params, result);
250
+ }
251
+ QPoint2dBuffer.unquantizePoint = unquantizePoint;
252
+ })(QPoint2dBuffer = exports.QPoint2dBuffer || (exports.QPoint2dBuffer = {}));
253
+ /** A list of [[QPoint2d]]s all quantized to the same range.
254
+ * @public
255
+ * @extensions
256
+ */
257
+ class QPoint2dList {
258
+ /** Construct an empty list set up to use the supplied quantization parameters. */
259
+ constructor(params) {
260
+ this._list = new Array();
261
+ this.params = params.clone();
262
+ }
263
+ /** The list of quantized points. */
264
+ get list() {
265
+ return this._list;
266
+ }
267
+ /** Removes all points from the list. */
268
+ clear() {
269
+ this._list.length = 0;
270
+ }
271
+ /** Removes all points from the list and change the quantization parameters. */
272
+ reset(params) {
273
+ this.clear();
274
+ this.params.copyFrom(params);
275
+ }
276
+ /** Quantizes the supplied Point2d to this list's range and appends it to the list. */
277
+ add(pt) {
278
+ this._list.push(QPoint2d.create(pt, this.params));
279
+ }
280
+ /** Adds a previously-quantized point to this list. */
281
+ push(qpt) {
282
+ this._list.push(qpt.clone());
283
+ }
284
+ /** The number of points in the list. */
285
+ get length() {
286
+ return this._list.length;
287
+ }
288
+ /** Returns the unquantized value of the point at the specified index in the list. */
289
+ unquantize(index, out) {
290
+ (0, core_bentley_1.assert)(index < this.length);
291
+ if (index < this.length) {
292
+ return this._list[index].unquantize(this.params, out);
293
+ }
294
+ else {
295
+ return undefined !== out ? out : new core_geometry_1.Point2d();
296
+ }
297
+ }
298
+ /** Changes the quantization parameters and requantizes all points in the list to the new range.
299
+ * @note The loss of precision is compounded each time the points are requantized to a new range.
300
+ */
301
+ requantize(params) {
302
+ for (let i = 0; i < this.length; i++) {
303
+ const pt = this.unquantize(i);
304
+ this._list[i].init(pt, params);
305
+ }
306
+ this.params.copyFrom(params);
307
+ }
308
+ /** 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,
309
+ * the second to the first point's `y` component, and so on.
310
+ */
311
+ toTypedArray() {
312
+ const array = new Uint16Array(this.length * 2);
313
+ const pts = this._list;
314
+ for (let i = 0; i < this.length; i++) {
315
+ const pt = pts[i];
316
+ array[i * 2] = pt.x;
317
+ array[i * 2 + 1] = pt.y;
318
+ }
319
+ return array;
320
+ }
321
+ /** 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. */
322
+ fromTypedArray(range, array) {
323
+ this.params.setFromRange(range);
324
+ this._list.length = array.length / 2;
325
+ for (let i = 0, j = 0; i < this.list.length; i++)
326
+ this._list[i] = QPoint2d.fromScalars(array[j++], array[j++]);
327
+ }
328
+ /** Construct a QPoint2dList containing all points in the supplied list, quantized to the range of those points. */
329
+ static fromPoints(points, out) {
330
+ let qPoints;
331
+ const qParams = QParams2d.fromRange(core_geometry_1.Range2d.createArray(points));
332
+ if (out) {
333
+ qPoints = out;
334
+ qPoints.reset(qParams);
335
+ }
336
+ else {
337
+ qPoints = new QPoint2dList(qParams);
338
+ }
339
+ for (const point of points)
340
+ qPoints.add(point);
341
+ return qPoints;
342
+ }
343
+ }
344
+ exports.QPoint2dList = QPoint2dList;
345
+ /** Parameters used for [[Quantization]] of 3d points such that the `x`, `y`, and `z` components are each quantized to 16-bit unsigned integers.
346
+ * @see [[QPoint3d]] for the quantized representation of a [Point3d]($core-geometry).
347
+ * @see [[QPoint3dList]] for a list of [[QPoint3d]]s quantized using a [[QParams3d]].
348
+ * @public
349
+ * @extensions
350
+ */
351
+ class QParams3d {
352
+ constructor(ox = 0, oy = 0, oz = 0, sx = 0, sy = 0, sz = 0) {
353
+ /** The origin of the quantization range. */
354
+ this.origin = new core_geometry_1.Point3d();
355
+ /** The scale applied to coordinates to quantize them. */
356
+ this.scale = new core_geometry_1.Point3d();
357
+ this.setFrom(ox, oy, oz, sx, sy, sz);
358
+ }
359
+ setFrom(ox, oy, oz, sx, sy, sz) {
360
+ this.origin.x = ox;
361
+ this.origin.y = oy;
362
+ this.origin.z = oz;
363
+ this.scale.x = sx;
364
+ this.scale.y = sy;
365
+ this.scale.z = sz;
366
+ }
367
+ /** Set `x`, `y`, and `z` from `src. */
368
+ copyFrom(src) {
369
+ this.setFrom(src.origin.x, src.origin.y, src.origin.z, src.scale.x, src.scale.y, src.scale.z);
370
+ }
371
+ /** Create a copy of these parameters.
372
+ * @param out If supplied, it will be modified in-place and returned instead of allocating a new QParams3d.
373
+ */
374
+ clone(out) {
375
+ const result = undefined !== out ? out : new QParams3d();
376
+ result.copyFrom(this);
377
+ return result;
378
+ }
379
+ /** Initialize from origin and scale */
380
+ setFromOriginAndScale(origin, scale) {
381
+ this.setFrom(origin.x, origin.y, origin.z, scale.x, scale.y, scale.z);
382
+ }
383
+ /** Initialize these parameters to support quantization of values within the specified range. */
384
+ setFromRange(range, rangeScale = Quantization.rangeScale16) {
385
+ if (!range.isNull) {
386
+ 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));
387
+ }
388
+ else {
389
+ this.origin.x = this.origin.y = this.origin.z = 0;
390
+ this.scale.x = this.scale.y = this.scale.z = 0;
391
+ }
392
+ }
393
+ /** Return the unquantized point for the input components.
394
+ * @param out If supplied, it will be modified in-place and returned instead of allocating a new Point3d.
395
+ */
396
+ unquantize(x, y, z, out) {
397
+ const pt = undefined !== out ? out : new core_geometry_1.Point3d();
398
+ pt.x = Quantization.unquantize(x, this.origin.x, this.scale.x);
399
+ pt.y = Quantization.unquantize(y, this.origin.y, this.scale.y);
400
+ pt.z = Quantization.unquantize(z, this.origin.z, this.scale.z);
401
+ return pt;
402
+ }
403
+ /** Creates parameters to support quantization of values within the specified range.
404
+ * If `out` is supplied, it will be modified in-place and returned instead of allocating a new QParams3d.
405
+ */
406
+ static fromRange(range, out, rangeScale = Quantization.rangeScale16) {
407
+ const params = undefined !== out ? out : new QParams3d();
408
+ params.setFromRange(range, rangeScale);
409
+ return params;
410
+ }
411
+ /** Creates parameters supporting quantization of values within the range [-1.0, 1.0].
412
+ * If `out` is supplied, it will be modified in-place and returned instead of allocating a new QParams3d.
413
+ */
414
+ static fromOriginAndScale(origin, scale, out) {
415
+ const params = undefined !== out ? out : new QParams3d();
416
+ params.setFromOriginAndScale(origin, scale);
417
+ return params;
418
+ }
419
+ /** Creates parameters supporting quantization of values within the range [-1.0, 1.0]. */
420
+ static fromNormalizedRange(rangeScale = Quantization.rangeScale16) {
421
+ return QParams3d.fromRange(core_geometry_1.Range3d.createArray([core_geometry_1.Point3d.create(-1, -1, -1), core_geometry_1.Point3d.create(1, 1, 1)]), undefined, rangeScale);
422
+ }
423
+ /** Creates parameters supporting quantization of values within the range [0.0, 1.0]. */
424
+ static fromZeroToOne(rangeScale = Quantization.rangeScale16) {
425
+ return QParams3d.fromRange(core_geometry_1.Range3d.createArray([core_geometry_1.Point3d.create(0, 0, 0), core_geometry_1.Point3d.create(1, 1, 1)]), undefined, rangeScale);
426
+ }
427
+ /** @internal */
428
+ get rangeDiagonal() {
429
+ return core_geometry_1.Vector3d.createFrom({
430
+ x: this.scale.x === 0 ? 0 : Quantization.rangeScale16 / this.scale.x,
431
+ y: this.scale.y === 0 ? 0 : Quantization.rangeScale16 / this.scale.y,
432
+ z: this.scale.z === 0 ? 0 : Quantization.rangeScale16 / this.scale.z,
433
+ });
434
+ }
435
+ /** Return true if the point point is quantizable using these parameters. */
436
+ isQuantizable(point) {
437
+ 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);
438
+ }
439
+ /** Compute the range to which these parameters quantize. */
440
+ computeRange(out) {
441
+ const range = core_geometry_1.Range3d.createNull(out);
442
+ range.extendPoint(this.origin);
443
+ range.extendPoint(this.origin.plus(this.rangeDiagonal));
444
+ return range;
445
+ }
446
+ }
447
+ exports.QParams3d = QParams3d;
448
+ /** Represents a [Point3d]($core-geometry) compressed such that each component `x`, `y`, and `z` is quantized to the 16-bit integer range [0, 0xffff].
449
+ * These are primarily used to reduce the space required for coordinates used by [RenderGraphic]($frontend)s.
450
+ * @see [[QParams3d]] to define quantization parameters for a range of points.
451
+ * @see [[QPoint3dList]] for a list of points all quantized to the same range.
452
+ * @public
453
+ * @extensions
454
+ */
455
+ class QPoint3d {
456
+ /** Construct with all components initialized to zero. */
457
+ constructor() {
458
+ this._x = 0;
459
+ this._y = 0;
460
+ this._z = 0;
461
+ }
462
+ /** The quantized x component. */
463
+ get x() { return this._x; }
464
+ set x(x) {
465
+ (0, core_bentley_1.assert)(Quantization.isQuantized(x));
466
+ this._x = x;
467
+ }
468
+ /** The quantized y component. */
469
+ get y() { return this._y; }
470
+ set y(y) {
471
+ (0, core_bentley_1.assert)(Quantization.isQuantized(y));
472
+ this._y = y;
473
+ }
474
+ /** The quantized z component. */
475
+ get z() { return this._z; }
476
+ set z(z) {
477
+ (0, core_bentley_1.assert)(Quantization.isQuantized(z));
478
+ this._z = z;
479
+ }
480
+ /** Initialize this point by quantizing the supplied { x, y, z } using the specified params */
481
+ init(pos, params) {
482
+ this.x = Quantization.quantize(pos.x, params.origin.x, params.scale.x);
483
+ this.y = Quantization.quantize(pos.y, params.origin.y, params.scale.y);
484
+ this.z = Quantization.quantize(pos.z, params.origin.z, params.scale.z);
485
+ }
486
+ /** Creates a quantized point from the supplied Point3d using the specified params */
487
+ static create(pos, params) {
488
+ const qpt = new QPoint3d();
489
+ qpt.init(pos, params);
490
+ return qpt;
491
+ }
492
+ /** Set this points components from `src`. */
493
+ copyFrom(src) {
494
+ this.x = src.x;
495
+ this.y = src.y;
496
+ this.z = src.z;
497
+ }
498
+ /** Create a copy of this point.
499
+ * @param out If supplied, it will be modified in-place instead of allocating a new QPoint3d.
500
+ */
501
+ clone(out) {
502
+ const result = undefined !== out ? out : new QPoint3d();
503
+ result.copyFrom(this);
504
+ return result;
505
+ }
506
+ /**
507
+ * Sets the x, y, and z components directly.
508
+ * @param x Must be an integer in the range [0, 0xffff]
509
+ * @param y Must be an integer in the range [0, 0xffff]
510
+ * @param z Must be an integer in the range [0, 0xffff]
511
+ */
512
+ setFromScalars(x, y, z) {
513
+ this.x = x;
514
+ this.y = y;
515
+ this.z = z;
516
+ }
517
+ /**
518
+ * Creates a QPoint3d directly from x, y, and z components.
519
+ * @param x Must be an integer in the range [0, 0xffff]
520
+ * @param y Must be an integer in the range [0, 0xffff]
521
+ * @param z Must be an integer in the range [0, 0xffff]
522
+ * @param out If supplied, it will be modified in-place instead of allocating a new QPoint3d.
523
+ */
524
+ static fromScalars(x, y, z, out) {
525
+ const pt = undefined === out ? new QPoint3d() : out;
526
+ pt.setFromScalars(x, y, z);
527
+ return pt;
528
+ }
529
+ /** Returns a Point3d unquantized according to the supplied params.
530
+ * If `out` is supplied, it will be modified in-place instead of allocating a new Point3d.
531
+ */
532
+ unquantize(params, out) {
533
+ const pt = undefined !== out ? out : new core_geometry_1.Point3d();
534
+ pt.x = Quantization.unquantize(this.x, params.origin.x, params.scale.x);
535
+ pt.y = Quantization.unquantize(this.y, params.origin.y, params.scale.y);
536
+ pt.z = Quantization.unquantize(this.z, params.origin.z, params.scale.z);
537
+ return pt;
538
+ }
539
+ /** Return true if this point's components are identical to the other point's components. */
540
+ equals(other) {
541
+ return this.x === other.x && this.y === other.y && this.z === other.z;
542
+ }
543
+ /** Perform ordinal comparison to another point. The function returns:
544
+ * - Zero if this point is identical to `rhs`; or
545
+ * - A number less than zero if this point is ordered before `rhs`; or
546
+ * - A number greater than zero if this point is ordered after `rhs`.
547
+ * @see [OrderedComparator]($core-bentley).
548
+ */
549
+ compare(rhs) {
550
+ let diff = this.x - rhs.x;
551
+ if (0 === diff) {
552
+ diff = this.y - rhs.y;
553
+ if (0 === diff) {
554
+ diff = this.z - rhs.z;
555
+ }
556
+ }
557
+ return diff;
558
+ }
559
+ }
560
+ exports.QPoint3d = QPoint3d;
561
+ /** @public
562
+ * @extensions
563
+ */
564
+ var QPoint3dBuffer;
565
+ (function (QPoint3dBuffer) {
566
+ const scratchQPoint3d = new QPoint3d();
567
+ /** Extracts the point at the specified index from a buffer.
568
+ * @param points The buffer in which each consecutive pair of integers is a 3d quantized point.
569
+ * @param pointIndex The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
570
+ * @param result If supplied, a preallocated [[QPoint3d]] to initialize with the result and return.
571
+ * @returns The point at `pointIndex`.
572
+ * @throws Error if `pointIndex` is out of bounds.
573
+ */
574
+ function getQPoint(points, pointIndex, result) {
575
+ const index = pointIndex * 3;
576
+ const x = points[index + 0];
577
+ const y = points[index + 1];
578
+ const z = points[index + 2];
579
+ if (undefined === x || undefined === y || undefined === z)
580
+ throw new Error("Index out of range");
581
+ result = result !== null && result !== void 0 ? result : new QPoint3d();
582
+ result.setFromScalars(x, y, z);
583
+ return result;
584
+ }
585
+ QPoint3dBuffer.getQPoint = getQPoint;
586
+ /** Extracts and unquantizes the point at the specified index from a buffer.
587
+ * @param buffer The array of points and the quantization parameters.
588
+ * @param The index of the point to extract, ranging from zero to one less than the number of points in the buffer.
589
+ * @param result If supplied, a preallocated [Point3d]($core-geometry) to initialize with the result and return.
590
+ * @returns The point at `pointIndex`.
591
+ * @throws Error if `pointIndex` is out of bounds.
592
+ */
593
+ function unquantizePoint(buffer, pointIndex, result) {
594
+ const qpt = getQPoint(buffer.points, pointIndex, scratchQPoint3d);
595
+ return qpt.unquantize(buffer.params, result);
596
+ }
597
+ QPoint3dBuffer.unquantizePoint = unquantizePoint;
598
+ })(QPoint3dBuffer = exports.QPoint3dBuffer || (exports.QPoint3dBuffer = {}));
599
+ /** A list of [[QPoint3d]]s all quantized to the same range.
600
+ * @public
601
+ * @extensions
602
+ */
603
+ class QPoint3dList {
604
+ /** Construct an empty list set up to quantize to the supplied range.
605
+ * @param The quantization parameters. If omitted, a null range will be used.
606
+ */
607
+ constructor(params) {
608
+ this._list = [];
609
+ this.params = params ? params.clone() : QParams3d.fromRange(core_geometry_1.Range3d.createNull());
610
+ }
611
+ /** The list of quantized points. */
612
+ get list() {
613
+ return this._list;
614
+ }
615
+ /** Construct a QPoint3dList containing all points in the supplied list, quantized to the range of those points.
616
+ * @param The points to quantize and add to the list.
617
+ * @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.
618
+ */
619
+ static fromPoints(points, out) {
620
+ let qPoints;
621
+ const qParams = QParams3d.fromRange(core_geometry_1.Range3d.createArray(points));
622
+ if (out) {
623
+ qPoints = out;
624
+ qPoints.reset(qParams);
625
+ }
626
+ else {
627
+ qPoints = new QPoint3dList(qParams);
628
+ }
629
+ for (const point of points)
630
+ qPoints.add(point);
631
+ return qPoints;
632
+ }
633
+ /** Removes all points from the list. */
634
+ clear() {
635
+ this._list.length = 0;
636
+ }
637
+ /** Clears out the contents of the list and changes the quantization parameters. */
638
+ reset(params) {
639
+ this.clear();
640
+ this.params.copyFrom(params);
641
+ }
642
+ /** Quantizes the supplied Point3d to this list's range and appends it to the list. */
643
+ add(pt) {
644
+ this._list.push(QPoint3d.create(pt, this.params));
645
+ }
646
+ /** Adds a previously-quantized point to this list. */
647
+ push(qpt) {
648
+ this._list.push(qpt.clone());
649
+ }
650
+ /** The number of points in the list. */
651
+ get length() {
652
+ return this._list.length;
653
+ }
654
+ /** Returns the unquantized value of the point at the specified index in the list. */
655
+ unquantize(index, out) {
656
+ (0, core_bentley_1.assert)(index < this.length);
657
+ if (index < this.length) {
658
+ return this._list[index].unquantize(this.params, out);
659
+ }
660
+ else {
661
+ return undefined !== out ? out : new core_geometry_1.Point3d();
662
+ }
663
+ }
664
+ /** Changes the quantization parameters and requantizes all points in the list to the new range.
665
+ * @note The loss of precision is compounded each time the points are requantized to a new range.
666
+ */
667
+ requantize(params) {
668
+ for (let i = 0; i < this.length; i++) {
669
+ const pt = this.unquantize(i);
670
+ this._list[i].init(pt, params);
671
+ }
672
+ this.params.copyFrom(params);
673
+ }
674
+ /** 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,
675
+ * the second three elements contain the second point's components, and so on.
676
+ */
677
+ toTypedArray() {
678
+ const array = new Uint16Array(this.length * 3);
679
+ const pts = this._list;
680
+ for (let i = 0; i < this.length; i++) {
681
+ const pt = pts[i];
682
+ array[i * 3 + 0] = pt.x;
683
+ array[i * 3 + 1] = pt.y;
684
+ array[i * 3 + 2] = pt.z;
685
+ }
686
+ return array;
687
+ }
688
+ /** 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
689
+ * of the second point, and so on.
690
+ */
691
+ fromTypedArray(range, array) {
692
+ this.params.setFromRange(range);
693
+ this._list.length = array.length / 3;
694
+ for (let i = 0, j = 0; i < this.list.length; i++)
695
+ this._list[i] = QPoint3d.fromScalars(array[j++], array[j++], array[j++]);
696
+ }
697
+ /** Construct a list containing all points in the supplied list, quantized using the supplied parameters. */
698
+ static createFrom(points, params) {
699
+ const list = new QPoint3dList(params);
700
+ for (const point of points)
701
+ list.add(point);
702
+ return list;
703
+ }
704
+ /** An iterator over the points in the list. */
705
+ [Symbol.iterator]() {
706
+ return this.list[Symbol.iterator]();
707
+ }
708
+ }
709
+ exports.QPoint3dList = QPoint3dList;
710
+ /** Constructs a [[QPoint2dBuffer]] using a [Uint16ArrayBuilder]($bentley).
711
+ * @public
712
+ * @extensions
713
+ */
714
+ class QPoint2dBufferBuilder {
715
+ /** Construct a new buffer with a [[length]] of zero. */
716
+ constructor(options) {
717
+ var _a;
718
+ this._scratchQPoint2d = new QPoint2d();
719
+ this.params = QParams2d.fromRange(options.range);
720
+ const initialCapacity = (_a = options.initialCapacity) !== null && _a !== void 0 ? _a : 0;
721
+ this.buffer = new core_bentley_1.Uint16ArrayBuilder({
722
+ growthFactor: options.growthFactor,
723
+ initialCapacity: 2 * initialCapacity,
724
+ });
725
+ }
726
+ /** Append a point with the specified quantized coordinates. */
727
+ pushXY(x, y) {
728
+ this.buffer.push(x);
729
+ this.buffer.push(y);
730
+ }
731
+ /** Append a point with the specified quantized coordinates. */
732
+ push(pt) {
733
+ this.pushXY(pt.x, pt.y);
734
+ }
735
+ /** The number of points currently in the [[buffer]]. */
736
+ get length() {
737
+ const len = this.buffer.length;
738
+ (0, core_bentley_1.assert)(len % 2 === 0);
739
+ return len / 2;
740
+ }
741
+ /** Returns the quantized point at the specified index in [[buffer]].
742
+ * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
743
+ * @param result If supplied, a [[QPoint2d]] to initialize with the result and return.
744
+ * @returns The quantized point at the specified index in [[buffer]].
745
+ * @throws Error if `pointIndex` is out of bounds.
746
+ */
747
+ get(pointIndex, result) {
748
+ return QPoint2dBuffer.getQPoint(this.buffer.toTypedArray(), pointIndex, result);
749
+ }
750
+ /** Returns the unquantized point at the specified index in [[buffer]].
751
+ * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
752
+ * @param result If supplied, a [Point2d]($core-geometry) to initialize with the result and return.
753
+ * @returns The unquantized point at the specified index in [[buffer]].
754
+ * @throws Error if `pointIndex` is out of bounds.
755
+ */
756
+ unquantize(pointIndex, result) {
757
+ return this.get(pointIndex, this._scratchQPoint2d).unquantize(this.params, result);
758
+ }
759
+ /** Obtain a [[QPoint2dBuffer]] containing all of the points that have been appended by this builder. */
760
+ finish() {
761
+ return {
762
+ params: this.params,
763
+ points: this.buffer.toTypedArray(),
764
+ };
765
+ }
766
+ }
767
+ exports.QPoint2dBufferBuilder = QPoint2dBufferBuilder;
768
+ /** Constructs a [[QPoint3dBuffer]] using a [Uint16ArrayBuilder]($bentley).
769
+ * @public
770
+ * @extensions
771
+ */
772
+ class QPoint3dBufferBuilder {
773
+ /** Construct a new buffer with a [[length]] of zero. */
774
+ constructor(options) {
775
+ var _a;
776
+ this._scratchQPoint3d = new QPoint3d();
777
+ this.params = QParams3d.fromRange(options.range);
778
+ const initialCapacity = (_a = options.initialCapacity) !== null && _a !== void 0 ? _a : 0;
779
+ this.buffer = new core_bentley_1.Uint16ArrayBuilder({
780
+ growthFactor: options.growthFactor,
781
+ initialCapacity: 3 * initialCapacity,
782
+ });
783
+ }
784
+ /** Append a point with the specified quantized coordinates. */
785
+ pushXYZ(x, y, z) {
786
+ this.buffer.push(x);
787
+ this.buffer.push(y);
788
+ this.buffer.push(z);
789
+ }
790
+ /** Append a point with the specified quantized coordinates. */
791
+ push(pt) {
792
+ this.pushXYZ(pt.x, pt.y, pt.z);
793
+ }
794
+ /** The number of points currently in the [[buffer]]. */
795
+ get length() {
796
+ const len = this.buffer.length;
797
+ (0, core_bentley_1.assert)(len % 3 === 0);
798
+ return len / 3;
799
+ }
800
+ /** Returns the quantized point at the specified index in [[buffer]].
801
+ * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
802
+ * @param result If supplied, a [[QPoint3d]] to initialize with the result and return.
803
+ * @returns The quantized point at the specified index in [[buffer]].
804
+ * @throws Error if `pointIndex` is out of bounds.
805
+ */
806
+ get(pointIndex, result) {
807
+ return QPoint3dBuffer.getQPoint(this.buffer.toTypedArray(), pointIndex, result);
808
+ }
809
+ /** Returns the unquantized point at the specified index in [[buffer]].
810
+ * @param pointIndex The index of the point of interest, ranging from zero to one minus the number of points currently in the [[buffer]].
811
+ * @param result If supplied, a [Point3d]($core-geometry) to initialize with the result and return.
812
+ * @returns The unquantized point at the specified index in [[buffer]].
813
+ * @throws Error if `pointIndex` is out of bounds.
814
+ */
815
+ unquantize(pointIndex, result) {
816
+ return this.get(pointIndex, this._scratchQPoint3d).unquantize(this.params, result);
817
+ }
818
+ /** Obtain a [[QPoint3dBuffer]] containing all of the points that have been appended by this builder. */
819
+ finish() {
820
+ return {
821
+ params: this.params,
822
+ points: this.buffer.toTypedArray(),
823
+ };
824
+ }
825
+ }
826
+ exports.QPoint3dBufferBuilder = QPoint3dBufferBuilder;
827
827
  //# sourceMappingURL=QPoint.js.map