@itwin/core-common 3.4.0-dev.9 → 3.4.1

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