@itwin/core-common 4.0.0-dev.8 → 4.0.0-dev.80

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 (984) hide show
  1. package/CHANGELOG.md +52 -1
  2. package/lib/cjs/AmbientOcclusion.d.ts +49 -49
  3. package/lib/cjs/AmbientOcclusion.js +55 -55
  4. package/lib/cjs/AnalysisStyle.d.ts +134 -134
  5. package/lib/cjs/AnalysisStyle.js +165 -165
  6. package/lib/cjs/AnalysisStyle.js.map +1 -1
  7. package/lib/cjs/Atmosphere.d.ts +99 -0
  8. package/lib/cjs/Atmosphere.d.ts.map +1 -0
  9. package/lib/cjs/Atmosphere.js +134 -0
  10. package/lib/cjs/Atmosphere.js.map +1 -0
  11. package/lib/cjs/AuthorizationClient.d.ts +17 -17
  12. package/lib/cjs/AuthorizationClient.js +9 -9
  13. package/lib/cjs/BackendTypes.d.ts +13 -12
  14. package/lib/cjs/BackendTypes.d.ts.map +1 -1
  15. package/lib/cjs/BackendTypes.js +9 -9
  16. package/lib/cjs/BackendTypes.js.map +1 -1
  17. package/lib/cjs/BackgroundMapProvider.d.ts +51 -51
  18. package/lib/cjs/BackgroundMapProvider.d.ts.map +1 -1
  19. package/lib/cjs/BackgroundMapProvider.js +67 -68
  20. package/lib/cjs/BackgroundMapProvider.js.map +1 -1
  21. package/lib/cjs/BackgroundMapSettings.d.ts +136 -136
  22. package/lib/cjs/BackgroundMapSettings.d.ts.map +1 -1
  23. package/lib/cjs/BackgroundMapSettings.js +154 -156
  24. package/lib/cjs/BackgroundMapSettings.js.map +1 -1
  25. package/lib/cjs/Base64EncodedString.d.ts +32 -32
  26. package/lib/cjs/Base64EncodedString.d.ts.map +1 -1
  27. package/lib/cjs/Base64EncodedString.js +66 -66
  28. package/lib/cjs/Base64EncodedString.js.map +1 -1
  29. package/lib/cjs/BlobReader.d.ts +31 -31
  30. package/lib/cjs/BlobReader.js +84 -84
  31. package/lib/cjs/BriefcaseTypes.d.ts +191 -189
  32. package/lib/cjs/BriefcaseTypes.d.ts.map +1 -1
  33. package/lib/cjs/BriefcaseTypes.js +95 -95
  34. package/lib/cjs/BriefcaseTypes.js.map +1 -1
  35. package/lib/cjs/Camera.d.ts +42 -42
  36. package/lib/cjs/Camera.js +62 -62
  37. package/lib/cjs/Camera.js.map +1 -1
  38. package/lib/cjs/ChangedElements.d.ts +85 -85
  39. package/lib/cjs/ChangedElements.js +23 -23
  40. package/lib/cjs/ChangedEntities.d.ts +45 -45
  41. package/lib/cjs/ChangedEntities.d.ts.map +1 -1
  42. package/lib/cjs/ChangedEntities.js +9 -9
  43. package/lib/cjs/ChangesetProps.d.ts +98 -98
  44. package/lib/cjs/ChangesetProps.d.ts.map +1 -1
  45. package/lib/cjs/ChangesetProps.js +22 -22
  46. package/lib/cjs/ClipStyle.d.ts +89 -89
  47. package/lib/cjs/ClipStyle.js +121 -123
  48. package/lib/cjs/ClipStyle.js.map +1 -1
  49. package/lib/cjs/Code.d.ts +277 -277
  50. package/lib/cjs/Code.d.ts.map +1 -1
  51. package/lib/cjs/Code.js +268 -269
  52. package/lib/cjs/Code.js.map +1 -1
  53. package/lib/cjs/ColorByName.d.ts +161 -161
  54. package/lib/cjs/ColorByName.js +169 -169
  55. package/lib/cjs/ColorDef.d.ts +210 -208
  56. package/lib/cjs/ColorDef.d.ts.map +1 -1
  57. package/lib/cjs/ColorDef.js +572 -571
  58. package/lib/cjs/ColorDef.js.map +1 -1
  59. package/lib/cjs/CommonLoggerCategory.d.ts +18 -18
  60. package/lib/cjs/CommonLoggerCategory.js +26 -26
  61. package/lib/cjs/ConcurrentQuery.d.ts +421 -421
  62. package/lib/cjs/ConcurrentQuery.d.ts.map +1 -1
  63. package/lib/cjs/ConcurrentQuery.js +552 -552
  64. package/lib/cjs/ConcurrentQuery.js.map +1 -1
  65. package/lib/cjs/ContextRealityModel.d.ts +303 -303
  66. package/lib/cjs/ContextRealityModel.js +371 -373
  67. package/lib/cjs/ContextRealityModel.js.map +1 -1
  68. package/lib/cjs/DisplayStyleSettings.d.ts +593 -588
  69. package/lib/cjs/DisplayStyleSettings.d.ts.map +1 -1
  70. package/lib/cjs/DisplayStyleSettings.js +990 -985
  71. package/lib/cjs/DisplayStyleSettings.js.map +1 -1
  72. package/lib/cjs/ECSchemaProps.d.ts +39 -39
  73. package/lib/cjs/ECSchemaProps.js +9 -9
  74. package/lib/cjs/ECSqlReader.d.ts +72 -70
  75. package/lib/cjs/ECSqlReader.d.ts.map +1 -1
  76. package/lib/cjs/ECSqlReader.js +297 -280
  77. package/lib/cjs/ECSqlReader.js.map +1 -1
  78. package/lib/cjs/ECSqlTypes.d.ts +128 -128
  79. package/lib/cjs/ECSqlTypes.js +189 -189
  80. package/lib/cjs/ElementMesh.d.ts +39 -39
  81. package/lib/cjs/ElementMesh.js +56 -56
  82. package/lib/cjs/ElementProps.d.ts +483 -483
  83. package/lib/cjs/ElementProps.d.ts.map +1 -1
  84. package/lib/cjs/ElementProps.js +99 -99
  85. package/lib/cjs/ElementProps.js.map +1 -1
  86. package/lib/cjs/EmphasizeElementsProps.d.ts +55 -55
  87. package/lib/cjs/EmphasizeElementsProps.js +25 -25
  88. package/lib/cjs/EntityProps.d.ts +177 -177
  89. package/lib/cjs/EntityProps.d.ts.map +1 -1
  90. package/lib/cjs/EntityProps.js +113 -113
  91. package/lib/cjs/EntityReference.d.ts +51 -51
  92. package/lib/cjs/EntityReference.d.ts.map +1 -1
  93. package/lib/cjs/EntityReference.js +56 -56
  94. package/lib/cjs/Environment.d.ts +74 -61
  95. package/lib/cjs/Environment.d.ts.map +1 -1
  96. package/lib/cjs/Environment.js +78 -73
  97. package/lib/cjs/Environment.js.map +1 -1
  98. package/lib/cjs/FeatureIndex.d.ts +39 -39
  99. package/lib/cjs/FeatureIndex.js +63 -63
  100. package/lib/cjs/FeatureIndex.js.map +1 -1
  101. package/lib/cjs/FeatureSymbology.d.ts +449 -444
  102. package/lib/cjs/FeatureSymbology.d.ts.map +1 -1
  103. package/lib/cjs/FeatureSymbology.js +618 -614
  104. package/lib/cjs/FeatureSymbology.js.map +1 -1
  105. package/lib/cjs/FeatureTable.d.ts +248 -141
  106. package/lib/cjs/FeatureTable.d.ts.map +1 -1
  107. package/lib/cjs/FeatureTable.js +470 -278
  108. package/lib/cjs/FeatureTable.js.map +1 -1
  109. package/lib/cjs/Fonts.d.ts +51 -51
  110. package/lib/cjs/Fonts.d.ts.map +1 -1
  111. package/lib/cjs/Fonts.js +53 -53
  112. package/lib/cjs/Frustum.d.ts +114 -114
  113. package/lib/cjs/Frustum.js +292 -292
  114. package/lib/cjs/GeoCoordinateServices.d.ts +123 -119
  115. package/lib/cjs/GeoCoordinateServices.d.ts.map +1 -1
  116. package/lib/cjs/GeoCoordinateServices.js +81 -80
  117. package/lib/cjs/GeoCoordinateServices.js.map +1 -1
  118. package/lib/cjs/GeometryContainment.d.ts +28 -28
  119. package/lib/cjs/GeometryContainment.js +9 -9
  120. package/lib/cjs/GeometryParams.d.ts +130 -130
  121. package/lib/cjs/GeometryParams.js +174 -174
  122. package/lib/cjs/GeometrySummary.d.ts +45 -45
  123. package/lib/cjs/GeometrySummary.js +23 -23
  124. package/lib/cjs/Gradient.d.ts +139 -139
  125. package/lib/cjs/Gradient.js +453 -455
  126. package/lib/cjs/Gradient.js.map +1 -1
  127. package/lib/cjs/GraphicParams.d.ts +58 -58
  128. package/lib/cjs/GraphicParams.js +85 -85
  129. package/lib/cjs/GraphicParams.js.map +1 -1
  130. package/lib/cjs/GroundPlane.d.ts +52 -52
  131. package/lib/cjs/GroundPlane.d.ts.map +1 -1
  132. package/lib/cjs/GroundPlane.js +63 -64
  133. package/lib/cjs/GroundPlane.js.map +1 -1
  134. package/lib/cjs/HSLColor.d.ts +20 -20
  135. package/lib/cjs/HSLColor.js +32 -32
  136. package/lib/cjs/HSLColor.js.map +1 -1
  137. package/lib/cjs/HSVColor.d.ts +30 -30
  138. package/lib/cjs/HSVColor.js +59 -59
  139. package/lib/cjs/HSVColor.js.map +1 -1
  140. package/lib/cjs/HiddenLine.d.ts +97 -97
  141. package/lib/cjs/HiddenLine.js +160 -162
  142. package/lib/cjs/HiddenLine.js.map +1 -1
  143. package/lib/cjs/Hilite.d.ts +50 -50
  144. package/lib/cjs/Hilite.js +64 -64
  145. package/lib/cjs/Hilite.js.map +1 -1
  146. package/lib/cjs/IModel.d.ts +358 -359
  147. package/lib/cjs/IModel.d.ts.map +1 -1
  148. package/lib/cjs/IModel.js +347 -347
  149. package/lib/cjs/IModel.js.map +1 -1
  150. package/lib/cjs/IModelError.d.ts +42 -42
  151. package/lib/cjs/IModelError.d.ts.map +1 -1
  152. package/lib/cjs/IModelError.js +71 -71
  153. package/lib/cjs/IModelVersion.d.ts +68 -68
  154. package/lib/cjs/IModelVersion.d.ts.map +1 -1
  155. package/lib/cjs/IModelVersion.js +79 -79
  156. package/lib/cjs/Image.d.ts +86 -86
  157. package/lib/cjs/Image.js +128 -128
  158. package/lib/cjs/Image.js.map +1 -1
  159. package/lib/cjs/IpcAppProps.d.ts +141 -141
  160. package/lib/cjs/IpcAppProps.js +23 -23
  161. package/lib/cjs/LightSettings.d.ts +224 -224
  162. package/lib/cjs/LightSettings.js +304 -309
  163. package/lib/cjs/LightSettings.js.map +1 -1
  164. package/lib/cjs/LinePixels.d.ts +34 -34
  165. package/lib/cjs/LinePixels.js +42 -42
  166. package/lib/cjs/Localization.d.ts +117 -113
  167. package/lib/cjs/Localization.d.ts.map +1 -1
  168. package/lib/cjs/Localization.js +33 -33
  169. package/lib/cjs/Localization.js.map +1 -1
  170. package/lib/cjs/MapImagerySettings.d.ts +62 -62
  171. package/lib/cjs/MapImagerySettings.d.ts.map +1 -1
  172. package/lib/cjs/MapImagerySettings.js +80 -80
  173. package/lib/cjs/MapImagerySettings.js.map +1 -1
  174. package/lib/cjs/MapLayerSettings.d.ts +272 -272
  175. package/lib/cjs/MapLayerSettings.d.ts.map +1 -1
  176. package/lib/cjs/MapLayerSettings.js +407 -411
  177. package/lib/cjs/MapLayerSettings.js.map +1 -1
  178. package/lib/cjs/MassProperties.d.ts +64 -64
  179. package/lib/cjs/MassProperties.js +23 -23
  180. package/lib/cjs/MaterialProps.d.ts +153 -153
  181. package/lib/cjs/MaterialProps.d.ts.map +1 -1
  182. package/lib/cjs/MaterialProps.js +35 -35
  183. package/lib/cjs/ModelClipGroup.d.ts +67 -67
  184. package/lib/cjs/ModelClipGroup.js +96 -98
  185. package/lib/cjs/ModelClipGroup.js.map +1 -1
  186. package/lib/cjs/ModelGeometryChanges.d.ts +107 -107
  187. package/lib/cjs/ModelGeometryChanges.d.ts.map +1 -1
  188. package/lib/cjs/ModelGeometryChanges.js +83 -83
  189. package/lib/cjs/ModelProps.d.ts +67 -67
  190. package/lib/cjs/ModelProps.js +9 -9
  191. package/lib/cjs/NativeAppProps.d.ts +122 -122
  192. package/lib/cjs/NativeAppProps.d.ts.map +1 -1
  193. package/lib/cjs/NativeAppProps.js +30 -30
  194. package/lib/cjs/OctEncodedNormal.d.ts +33 -33
  195. package/lib/cjs/OctEncodedNormal.js +98 -98
  196. package/lib/cjs/PlanProjectionSettings.d.ts +47 -47
  197. package/lib/cjs/PlanProjectionSettings.js +63 -63
  198. package/lib/cjs/PlanProjectionSettings.js.map +1 -1
  199. package/lib/cjs/PlanarClipMask.d.ts +177 -177
  200. package/lib/cjs/PlanarClipMask.js +136 -136
  201. package/lib/cjs/PlanarClipMask.js.map +1 -1
  202. package/lib/cjs/QPoint.d.ts +479 -479
  203. package/lib/cjs/QPoint.js +824 -826
  204. package/lib/cjs/QPoint.js.map +1 -1
  205. package/lib/cjs/RealityDataAccessProps.d.ts +41 -41
  206. package/lib/cjs/RealityDataAccessProps.js +19 -19
  207. package/lib/cjs/RealityModelDisplaySettings.d.ts +183 -183
  208. package/lib/cjs/RealityModelDisplaySettings.d.ts.map +1 -1
  209. package/lib/cjs/RealityModelDisplaySettings.js +141 -142
  210. package/lib/cjs/RealityModelDisplaySettings.js.map +1 -1
  211. package/lib/cjs/Render.d.ts +89 -89
  212. package/lib/cjs/Render.js +177 -177
  213. package/lib/cjs/RenderMaterial.d.ts +58 -58
  214. package/lib/cjs/RenderMaterial.js +75 -76
  215. package/lib/cjs/RenderMaterial.js.map +1 -1
  216. package/lib/cjs/RenderSchedule.d.ts +543 -543
  217. package/lib/cjs/RenderSchedule.js +992 -1002
  218. package/lib/cjs/RenderSchedule.js.map +1 -1
  219. package/lib/cjs/RenderTexture.d.ts +70 -70
  220. package/lib/cjs/RenderTexture.d.ts.map +1 -1
  221. package/lib/cjs/RenderTexture.js +59 -59
  222. package/lib/cjs/RenderTexture.js.map +1 -1
  223. package/lib/cjs/RgbColor.d.ts +47 -47
  224. package/lib/cjs/RgbColor.js +77 -77
  225. package/lib/cjs/RpcInterface.d.ts +40 -33
  226. package/lib/cjs/RpcInterface.d.ts.map +1 -1
  227. package/lib/cjs/RpcInterface.js +137 -137
  228. package/lib/cjs/RpcInterface.js.map +1 -1
  229. package/lib/cjs/RpcManager.d.ts +40 -40
  230. package/lib/cjs/RpcManager.js +55 -55
  231. package/lib/cjs/RpcManager.js.map +1 -1
  232. package/lib/cjs/SessionProps.d.ts +16 -16
  233. package/lib/cjs/SessionProps.js +9 -9
  234. package/lib/cjs/SkyBox.d.ts +217 -215
  235. package/lib/cjs/SkyBox.d.ts.map +1 -1
  236. package/lib/cjs/SkyBox.js +209 -210
  237. package/lib/cjs/SkyBox.js.map +1 -1
  238. package/lib/cjs/Snapping.d.ts +49 -49
  239. package/lib/cjs/Snapping.js +9 -9
  240. package/lib/cjs/SolarCalculate.d.ts +27 -27
  241. package/lib/cjs/SolarCalculate.js +211 -211
  242. package/lib/cjs/SolarShadows.d.ts +35 -35
  243. package/lib/cjs/SolarShadows.js +61 -62
  244. package/lib/cjs/SolarShadows.js.map +1 -1
  245. package/lib/cjs/SpatialClassification.d.ts +208 -208
  246. package/lib/cjs/SpatialClassification.js +339 -340
  247. package/lib/cjs/SpatialClassification.js.map +1 -1
  248. package/lib/cjs/SubCategoryAppearance.d.ts +91 -91
  249. package/lib/cjs/SubCategoryAppearance.js +96 -96
  250. package/lib/cjs/SubCategoryAppearance.js.map +1 -1
  251. package/lib/cjs/SubCategoryOverride.d.ts +46 -46
  252. package/lib/cjs/SubCategoryOverride.js +104 -104
  253. package/lib/cjs/SubCategoryOverride.js.map +1 -1
  254. package/lib/cjs/TerrainSettings.d.ts +82 -82
  255. package/lib/cjs/TerrainSettings.d.ts.map +1 -1
  256. package/lib/cjs/TerrainSettings.js +100 -102
  257. package/lib/cjs/TerrainSettings.js.map +1 -1
  258. package/lib/cjs/TextureMapping.d.ts +151 -118
  259. package/lib/cjs/TextureMapping.d.ts.map +1 -1
  260. package/lib/cjs/TextureMapping.js +180 -174
  261. package/lib/cjs/TextureMapping.js.map +1 -1
  262. package/lib/cjs/TextureProps.d.ts +65 -65
  263. package/lib/cjs/TextureProps.js +28 -28
  264. package/lib/cjs/ThematicDisplay.d.ts +230 -230
  265. package/lib/cjs/ThematicDisplay.js +343 -344
  266. package/lib/cjs/ThematicDisplay.js.map +1 -1
  267. package/lib/cjs/Thumbnail.d.ts +26 -26
  268. package/lib/cjs/Thumbnail.js +9 -9
  269. package/lib/cjs/TileProps.d.ts +88 -82
  270. package/lib/cjs/TileProps.d.ts.map +1 -1
  271. package/lib/cjs/TileProps.js +29 -29
  272. package/lib/cjs/TileProps.js.map +1 -1
  273. package/lib/cjs/Tween.d.ts +191 -191
  274. package/lib/cjs/Tween.d.ts.map +1 -1
  275. package/lib/cjs/Tween.js +570 -570
  276. package/lib/cjs/TxnAction.d.ts +21 -21
  277. package/lib/cjs/TxnAction.js +29 -29
  278. package/lib/cjs/ViewDetails.d.ts +125 -125
  279. package/lib/cjs/ViewDetails.js +166 -166
  280. package/lib/cjs/ViewDetails.js.map +1 -1
  281. package/lib/cjs/ViewFlags.d.ts +287 -287
  282. package/lib/cjs/ViewFlags.d.ts.map +1 -1
  283. package/lib/cjs/ViewFlags.js +367 -368
  284. package/lib/cjs/ViewFlags.js.map +1 -1
  285. package/lib/cjs/ViewProps.d.ts +205 -205
  286. package/lib/cjs/ViewProps.js +9 -9
  287. package/lib/cjs/WhiteOnWhiteReversalSettings.d.ts +36 -36
  288. package/lib/cjs/WhiteOnWhiteReversalSettings.js +37 -37
  289. package/lib/cjs/WhiteOnWhiteReversalSettings.js.map +1 -1
  290. package/lib/cjs/core-common.d.ts +244 -244
  291. package/lib/cjs/core-common.d.ts.map +1 -1
  292. package/lib/cjs/core-common.js +264 -260
  293. package/lib/cjs/core-common.js.map +1 -1
  294. package/lib/cjs/domains/FunctionalElementProps.d.ts +11 -11
  295. package/lib/cjs/domains/FunctionalElementProps.js +9 -9
  296. package/lib/cjs/domains/GenericElementProps.d.ts +18 -18
  297. package/lib/cjs/domains/GenericElementProps.js +9 -9
  298. package/lib/cjs/geometry/AdditionalTransform.d.ts +84 -84
  299. package/lib/cjs/geometry/AdditionalTransform.js +85 -85
  300. package/lib/cjs/geometry/AreaPattern.d.ts +82 -82
  301. package/lib/cjs/geometry/AreaPattern.js +203 -204
  302. package/lib/cjs/geometry/AreaPattern.js.map +1 -1
  303. package/lib/cjs/geometry/BoundingSphere.d.ts +27 -27
  304. package/lib/cjs/geometry/BoundingSphere.js +44 -44
  305. package/lib/cjs/geometry/BoundingSphere.js.map +1 -1
  306. package/lib/cjs/geometry/Cartographic.d.ts +137 -137
  307. package/lib/cjs/geometry/Cartographic.js +345 -345
  308. package/lib/cjs/geometry/Cartographic.js.map +1 -1
  309. package/lib/cjs/geometry/CoordinateReferenceSystem.d.ts +269 -269
  310. package/lib/cjs/geometry/CoordinateReferenceSystem.d.ts.map +1 -1
  311. package/lib/cjs/geometry/CoordinateReferenceSystem.js +260 -261
  312. package/lib/cjs/geometry/CoordinateReferenceSystem.js.map +1 -1
  313. package/lib/cjs/geometry/ElementGeometry.d.ts +402 -402
  314. package/lib/cjs/geometry/ElementGeometry.d.ts.map +1 -1
  315. package/lib/cjs/geometry/ElementGeometry.js +1719 -1719
  316. package/lib/cjs/geometry/ElementGeometry.js.map +1 -1
  317. package/lib/cjs/geometry/ElementGeometryFB.d.ts +2372 -2372
  318. package/lib/cjs/geometry/ElementGeometryFB.js +3814 -3814
  319. package/lib/cjs/geometry/ElementGeometryFB.js.map +1 -1
  320. package/lib/cjs/geometry/FrustumPlanes.d.ts +83 -81
  321. package/lib/cjs/geometry/FrustumPlanes.d.ts.map +1 -1
  322. package/lib/cjs/geometry/FrustumPlanes.js +227 -193
  323. package/lib/cjs/geometry/FrustumPlanes.js.map +1 -1
  324. package/lib/cjs/geometry/GeodeticDatum.d.ts +409 -409
  325. package/lib/cjs/geometry/GeodeticDatum.d.ts.map +1 -1
  326. package/lib/cjs/geometry/GeodeticDatum.js +400 -401
  327. package/lib/cjs/geometry/GeodeticDatum.js.map +1 -1
  328. package/lib/cjs/geometry/GeodeticEllipsoid.d.ts +72 -72
  329. package/lib/cjs/geometry/GeodeticEllipsoid.js +71 -72
  330. package/lib/cjs/geometry/GeodeticEllipsoid.js.map +1 -1
  331. package/lib/cjs/geometry/GeometryStream.d.ts +347 -347
  332. package/lib/cjs/geometry/GeometryStream.d.ts.map +1 -1
  333. package/lib/cjs/geometry/GeometryStream.js +468 -469
  334. package/lib/cjs/geometry/GeometryStream.js.map +1 -1
  335. package/lib/cjs/geometry/ImageGraphic.d.ts +74 -74
  336. package/lib/cjs/geometry/ImageGraphic.d.ts.map +1 -1
  337. package/lib/cjs/geometry/ImageGraphic.js +98 -98
  338. package/lib/cjs/geometry/LineStyle.d.ts +71 -71
  339. package/lib/cjs/geometry/LineStyle.js +129 -129
  340. package/lib/cjs/geometry/Placement.d.ts +95 -95
  341. package/lib/cjs/geometry/Placement.d.ts.map +1 -1
  342. package/lib/cjs/geometry/Placement.js +131 -131
  343. package/lib/cjs/geometry/Projection.d.ts +251 -251
  344. package/lib/cjs/geometry/Projection.d.ts.map +1 -1
  345. package/lib/cjs/geometry/Projection.js +198 -198
  346. package/lib/cjs/geometry/Projection.js.map +1 -1
  347. package/lib/cjs/geometry/TextString.d.ts +55 -55
  348. package/lib/cjs/geometry/TextString.js +65 -65
  349. package/lib/cjs/geometry/TextString.js.map +1 -1
  350. package/lib/cjs/ipc/IpcSession.d.ts +23 -23
  351. package/lib/cjs/ipc/IpcSession.js +27 -27
  352. package/lib/cjs/ipc/IpcSocket.d.ts +96 -96
  353. package/lib/cjs/ipc/IpcSocket.d.ts.map +1 -1
  354. package/lib/cjs/ipc/IpcSocket.js +16 -16
  355. package/lib/cjs/ipc/IpcWebSocket.d.ts +60 -61
  356. package/lib/cjs/ipc/IpcWebSocket.d.ts.map +1 -1
  357. package/lib/cjs/ipc/IpcWebSocket.js +148 -151
  358. package/lib/cjs/ipc/IpcWebSocket.js.map +1 -1
  359. package/lib/cjs/ipc/IpcWebSocketTransport.d.ts +15 -15
  360. package/lib/cjs/ipc/IpcWebSocketTransport.js +160 -160
  361. package/lib/cjs/ipc/IpcWebSocketTransport.js.map +1 -1
  362. package/lib/cjs/rpc/DevToolsRpcInterface.d.ts +32 -32
  363. package/lib/cjs/rpc/DevToolsRpcInterface.d.ts.map +1 -1
  364. package/lib/cjs/rpc/DevToolsRpcInterface.js +52 -48
  365. package/lib/cjs/rpc/DevToolsRpcInterface.js.map +1 -1
  366. package/lib/cjs/rpc/IModelReadRpcInterface.d.ts +99 -99
  367. package/lib/cjs/rpc/IModelReadRpcInterface.d.ts.map +1 -1
  368. package/lib/cjs/rpc/IModelReadRpcInterface.js +122 -122
  369. package/lib/cjs/rpc/IModelReadRpcInterface.js.map +1 -1
  370. package/lib/cjs/rpc/IModelTileRpcInterface.d.ts +49 -61
  371. package/lib/cjs/rpc/IModelTileRpcInterface.d.ts.map +1 -1
  372. package/lib/cjs/rpc/IModelTileRpcInterface.js +79 -96
  373. package/lib/cjs/rpc/IModelTileRpcInterface.js.map +1 -1
  374. package/lib/cjs/rpc/SnapshotIModelRpcInterface.d.ts +23 -23
  375. package/lib/cjs/rpc/SnapshotIModelRpcInterface.js +48 -48
  376. package/lib/cjs/rpc/SnapshotIModelRpcInterface.js.map +1 -1
  377. package/lib/cjs/rpc/TestRpcManager.d.ts +20 -20
  378. package/lib/cjs/rpc/TestRpcManager.js +40 -40
  379. package/lib/cjs/rpc/WipRpcInterface.d.ts +29 -29
  380. package/lib/cjs/rpc/WipRpcInterface.js +40 -40
  381. package/lib/cjs/rpc/WipRpcInterface.js.map +1 -1
  382. package/lib/cjs/rpc/core/RpcConfiguration.d.ts +111 -111
  383. package/lib/cjs/rpc/core/RpcConfiguration.d.ts.map +1 -1
  384. package/lib/cjs/rpc/core/RpcConfiguration.js +191 -191
  385. package/lib/cjs/rpc/core/RpcConfiguration.js.map +1 -1
  386. package/lib/cjs/rpc/core/RpcConstants.d.ts +90 -90
  387. package/lib/cjs/rpc/core/RpcConstants.js +109 -109
  388. package/lib/cjs/rpc/core/RpcControl.d.ts +54 -54
  389. package/lib/cjs/rpc/core/RpcControl.js +150 -145
  390. package/lib/cjs/rpc/core/RpcControl.js.map +1 -1
  391. package/lib/cjs/rpc/core/RpcInvocation.d.ts +89 -89
  392. package/lib/cjs/rpc/core/RpcInvocation.d.ts.map +1 -1
  393. package/lib/cjs/rpc/core/RpcInvocation.js +256 -258
  394. package/lib/cjs/rpc/core/RpcInvocation.js.map +1 -1
  395. package/lib/cjs/rpc/core/RpcMarshaling.d.ts +35 -35
  396. package/lib/cjs/rpc/core/RpcMarshaling.js +156 -156
  397. package/lib/cjs/rpc/core/RpcOperation.d.ts +67 -67
  398. package/lib/cjs/rpc/core/RpcOperation.d.ts.map +1 -1
  399. package/lib/cjs/rpc/core/RpcOperation.js +135 -134
  400. package/lib/cjs/rpc/core/RpcOperation.js.map +1 -1
  401. package/lib/cjs/rpc/core/RpcPendingQueue.d.ts +21 -21
  402. package/lib/cjs/rpc/core/RpcPendingQueue.js +94 -95
  403. package/lib/cjs/rpc/core/RpcPendingQueue.js.map +1 -1
  404. package/lib/cjs/rpc/core/RpcProtocol.d.ts +132 -132
  405. package/lib/cjs/rpc/core/RpcProtocol.d.ts.map +1 -1
  406. package/lib/cjs/rpc/core/RpcProtocol.js +127 -127
  407. package/lib/cjs/rpc/core/RpcProtocol.js.map +1 -1
  408. package/lib/cjs/rpc/core/RpcPush.d.ts +68 -68
  409. package/lib/cjs/rpc/core/RpcPush.d.ts.map +1 -1
  410. package/lib/cjs/rpc/core/RpcPush.js +127 -127
  411. package/lib/cjs/rpc/core/RpcPush.js.map +1 -1
  412. package/lib/cjs/rpc/core/RpcRegistry.d.ts +48 -48
  413. package/lib/cjs/rpc/core/RpcRegistry.js +198 -199
  414. package/lib/cjs/rpc/core/RpcRegistry.js.map +1 -1
  415. package/lib/cjs/rpc/core/RpcRequest.d.ts +186 -186
  416. package/lib/cjs/rpc/core/RpcRequest.d.ts.map +1 -1
  417. package/lib/cjs/rpc/core/RpcRequest.js +478 -478
  418. package/lib/cjs/rpc/core/RpcRequest.js.map +1 -1
  419. package/lib/cjs/rpc/core/RpcRequestContext.d.ts +14 -14
  420. package/lib/cjs/rpc/core/RpcRequestContext.js +2 -2
  421. package/lib/cjs/rpc/core/RpcRoutingToken.d.ts +12 -12
  422. package/lib/cjs/rpc/core/RpcRoutingToken.d.ts.map +1 -1
  423. package/lib/cjs/rpc/core/RpcRoutingToken.js +24 -24
  424. package/lib/cjs/rpc/core/RpcRoutingToken.js.map +1 -1
  425. package/lib/cjs/rpc/core/RpcSessionInvocation.d.ts +10 -10
  426. package/lib/cjs/rpc/core/RpcSessionInvocation.js +60 -60
  427. package/lib/cjs/rpc/core/RpcSessionInvocation.js.map +1 -1
  428. package/lib/cjs/rpc/web/BentleyCloudRpcManager.d.ts +48 -46
  429. package/lib/cjs/rpc/web/BentleyCloudRpcManager.d.ts.map +1 -1
  430. package/lib/cjs/rpc/web/BentleyCloudRpcManager.js +76 -73
  431. package/lib/cjs/rpc/web/BentleyCloudRpcManager.js.map +1 -1
  432. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.d.ts +33 -33
  433. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.js +141 -143
  434. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.js.map +1 -1
  435. package/lib/cjs/rpc/web/OpenAPI.d.ts +140 -140
  436. package/lib/cjs/rpc/web/OpenAPI.js +60 -60
  437. package/lib/cjs/rpc/web/OpenAPI.js.map +1 -1
  438. package/lib/cjs/rpc/web/RpcMultipart.d.ts +35 -35
  439. package/lib/cjs/rpc/web/RpcMultipart.js +50 -50
  440. package/lib/cjs/rpc/web/RpcMultipart.js.map +1 -1
  441. package/lib/cjs/rpc/web/WebAppRpcLogging.d.ts +28 -28
  442. package/lib/cjs/rpc/web/WebAppRpcLogging.js +140 -140
  443. package/lib/cjs/rpc/web/WebAppRpcProtocol.d.ts +89 -89
  444. package/lib/cjs/rpc/web/WebAppRpcProtocol.js +116 -116
  445. package/lib/cjs/rpc/web/WebAppRpcProtocol.js.map +1 -1
  446. package/lib/cjs/rpc/web/WebAppRpcRequest.d.ts +67 -67
  447. package/lib/cjs/rpc/web/WebAppRpcRequest.d.ts.map +1 -1
  448. package/lib/cjs/rpc/web/WebAppRpcRequest.js +239 -239
  449. package/lib/cjs/rpc/web/WebAppRpcRequest.js.map +1 -1
  450. package/lib/cjs/rpc/web/multipart/RpcMultipartParser.d.ts +32 -32
  451. package/lib/cjs/rpc/web/multipart/RpcMultipartParser.js +373 -373
  452. package/lib/cjs/tile/B3dmTileIO.d.ts +19 -19
  453. package/lib/cjs/tile/B3dmTileIO.js +66 -66
  454. package/lib/cjs/tile/B3dmTileIO.js.map +1 -1
  455. package/lib/cjs/tile/CompositeTileIO.d.ts +15 -15
  456. package/lib/cjs/tile/CompositeTileIO.js +26 -26
  457. package/lib/cjs/tile/CompositeTileIO.js.map +1 -1
  458. package/lib/cjs/tile/ElementGraphics.d.ts +145 -145
  459. package/lib/cjs/tile/ElementGraphics.d.ts.map +1 -1
  460. package/lib/cjs/tile/ElementGraphics.js +9 -9
  461. package/lib/cjs/tile/GltfTileIO.d.ts +45 -45
  462. package/lib/cjs/tile/GltfTileIO.d.ts.map +1 -1
  463. package/lib/cjs/tile/GltfTileIO.js +109 -109
  464. package/lib/cjs/tile/GltfTileIO.js.map +1 -1
  465. package/lib/cjs/tile/I3dmTileIO.d.ts +20 -20
  466. package/lib/cjs/tile/I3dmTileIO.js +40 -40
  467. package/lib/cjs/tile/I3dmTileIO.js.map +1 -1
  468. package/lib/cjs/tile/IModelTileIO.d.ts +77 -75
  469. package/lib/cjs/tile/IModelTileIO.d.ts.map +1 -1
  470. package/lib/cjs/tile/IModelTileIO.js +97 -95
  471. package/lib/cjs/tile/IModelTileIO.js.map +1 -1
  472. package/lib/cjs/tile/PntsTileIO.d.ts +17 -17
  473. package/lib/cjs/tile/PntsTileIO.js +26 -26
  474. package/lib/cjs/tile/PntsTileIO.js.map +1 -1
  475. package/lib/cjs/tile/TileIO.d.ts +66 -66
  476. package/lib/cjs/tile/TileIO.js +118 -118
  477. package/lib/cjs/tile/TileMetadata.d.ts +228 -228
  478. package/lib/cjs/tile/TileMetadata.d.ts.map +1 -1
  479. package/lib/cjs/tile/TileMetadata.js +675 -676
  480. package/lib/cjs/tile/TileMetadata.js.map +1 -1
  481. package/lib/cjs/tile/Tileset3dSchema.d.ts +97 -0
  482. package/lib/cjs/tile/Tileset3dSchema.d.ts.map +1 -0
  483. package/lib/cjs/tile/Tileset3dSchema.js +10 -0
  484. package/lib/cjs/tile/Tileset3dSchema.js.map +1 -0
  485. package/lib/esm/AmbientOcclusion.d.ts +49 -49
  486. package/lib/esm/AmbientOcclusion.js +52 -52
  487. package/lib/esm/AnalysisStyle.d.ts +134 -134
  488. package/lib/esm/AnalysisStyle.js +160 -159
  489. package/lib/esm/AnalysisStyle.js.map +1 -1
  490. package/lib/esm/Atmosphere.d.ts +99 -0
  491. package/lib/esm/Atmosphere.d.ts.map +1 -0
  492. package/lib/esm/Atmosphere.js +131 -0
  493. package/lib/esm/Atmosphere.js.map +1 -0
  494. package/lib/esm/AuthorizationClient.d.ts +17 -17
  495. package/lib/esm/AuthorizationClient.js +8 -8
  496. package/lib/esm/BackendTypes.d.ts +13 -12
  497. package/lib/esm/BackendTypes.d.ts.map +1 -1
  498. package/lib/esm/BackendTypes.js +8 -8
  499. package/lib/esm/BackendTypes.js.map +1 -1
  500. package/lib/esm/BackgroundMapProvider.d.ts +51 -51
  501. package/lib/esm/BackgroundMapProvider.d.ts.map +1 -1
  502. package/lib/esm/BackgroundMapProvider.js +63 -64
  503. package/lib/esm/BackgroundMapProvider.js.map +1 -1
  504. package/lib/esm/BackgroundMapSettings.d.ts +136 -136
  505. package/lib/esm/BackgroundMapSettings.d.ts.map +1 -1
  506. package/lib/esm/BackgroundMapSettings.js +150 -152
  507. package/lib/esm/BackgroundMapSettings.js.map +1 -1
  508. package/lib/esm/Base64EncodedString.d.ts +32 -32
  509. package/lib/esm/Base64EncodedString.d.ts.map +1 -1
  510. package/lib/esm/Base64EncodedString.js +63 -63
  511. package/lib/esm/Base64EncodedString.js.map +1 -1
  512. package/lib/esm/BlobReader.d.ts +31 -31
  513. package/lib/esm/BlobReader.js +79 -79
  514. package/lib/esm/BriefcaseTypes.d.ts +191 -189
  515. package/lib/esm/BriefcaseTypes.d.ts.map +1 -1
  516. package/lib/esm/BriefcaseTypes.js +92 -92
  517. package/lib/esm/BriefcaseTypes.js.map +1 -1
  518. package/lib/esm/Camera.d.ts +42 -42
  519. package/lib/esm/Camera.js +58 -58
  520. package/lib/esm/Camera.js.map +1 -1
  521. package/lib/esm/ChangedElements.d.ts +85 -85
  522. package/lib/esm/ChangedElements.js +20 -20
  523. package/lib/esm/ChangedEntities.d.ts +45 -45
  524. package/lib/esm/ChangedEntities.d.ts.map +1 -1
  525. package/lib/esm/ChangedEntities.js +8 -8
  526. package/lib/esm/ChangesetProps.d.ts +98 -98
  527. package/lib/esm/ChangesetProps.d.ts.map +1 -1
  528. package/lib/esm/ChangesetProps.js +19 -19
  529. package/lib/esm/ClipStyle.d.ts +89 -89
  530. package/lib/esm/ClipStyle.js +118 -118
  531. package/lib/esm/ClipStyle.js.map +1 -1
  532. package/lib/esm/Code.d.ts +277 -277
  533. package/lib/esm/Code.d.ts.map +1 -1
  534. package/lib/esm/Code.js +263 -264
  535. package/lib/esm/Code.js.map +1 -1
  536. package/lib/esm/ColorByName.d.ts +161 -161
  537. package/lib/esm/ColorByName.js +166 -166
  538. package/lib/esm/ColorDef.d.ts +210 -208
  539. package/lib/esm/ColorDef.d.ts.map +1 -1
  540. package/lib/esm/ColorDef.js +569 -567
  541. package/lib/esm/ColorDef.js.map +1 -1
  542. package/lib/esm/CommonLoggerCategory.d.ts +18 -18
  543. package/lib/esm/CommonLoggerCategory.js +23 -23
  544. package/lib/esm/ConcurrentQuery.d.ts +421 -421
  545. package/lib/esm/ConcurrentQuery.d.ts.map +1 -1
  546. package/lib/esm/ConcurrentQuery.js +545 -545
  547. package/lib/esm/ConcurrentQuery.js.map +1 -1
  548. package/lib/esm/ContextRealityModel.d.ts +303 -303
  549. package/lib/esm/ContextRealityModel.js +366 -368
  550. package/lib/esm/ContextRealityModel.js.map +1 -1
  551. package/lib/esm/DisplayStyleSettings.d.ts +593 -588
  552. package/lib/esm/DisplayStyleSettings.d.ts.map +1 -1
  553. package/lib/esm/DisplayStyleSettings.js +985 -980
  554. package/lib/esm/DisplayStyleSettings.js.map +1 -1
  555. package/lib/esm/ECSchemaProps.d.ts +39 -39
  556. package/lib/esm/ECSchemaProps.js +8 -8
  557. package/lib/esm/ECSqlReader.d.ts +72 -70
  558. package/lib/esm/ECSqlReader.d.ts.map +1 -1
  559. package/lib/esm/ECSqlReader.js +293 -275
  560. package/lib/esm/ECSqlReader.js.map +1 -1
  561. package/lib/esm/ECSqlTypes.d.ts +128 -128
  562. package/lib/esm/ECSqlTypes.js +185 -185
  563. package/lib/esm/ElementMesh.d.ts +39 -39
  564. package/lib/esm/ElementMesh.js +52 -52
  565. package/lib/esm/ElementProps.d.ts +483 -483
  566. package/lib/esm/ElementProps.d.ts.map +1 -1
  567. package/lib/esm/ElementProps.js +93 -92
  568. package/lib/esm/ElementProps.js.map +1 -1
  569. package/lib/esm/EmphasizeElementsProps.d.ts +55 -55
  570. package/lib/esm/EmphasizeElementsProps.js +22 -22
  571. package/lib/esm/EntityProps.d.ts +177 -177
  572. package/lib/esm/EntityProps.d.ts.map +1 -1
  573. package/lib/esm/EntityProps.js +108 -108
  574. package/lib/esm/EntityReference.d.ts +51 -51
  575. package/lib/esm/EntityReference.d.ts.map +1 -1
  576. package/lib/esm/EntityReference.js +52 -52
  577. package/lib/esm/Environment.d.ts +74 -61
  578. package/lib/esm/Environment.d.ts.map +1 -1
  579. package/lib/esm/Environment.js +75 -69
  580. package/lib/esm/Environment.js.map +1 -1
  581. package/lib/esm/FeatureIndex.d.ts +39 -39
  582. package/lib/esm/FeatureIndex.js +57 -57
  583. package/lib/esm/FeatureIndex.js.map +1 -1
  584. package/lib/esm/FeatureSymbology.d.ts +449 -444
  585. package/lib/esm/FeatureSymbology.d.ts.map +1 -1
  586. package/lib/esm/FeatureSymbology.js +615 -609
  587. package/lib/esm/FeatureSymbology.js.map +1 -1
  588. package/lib/esm/FeatureTable.d.ts +248 -141
  589. package/lib/esm/FeatureTable.d.ts.map +1 -1
  590. package/lib/esm/FeatureTable.js +462 -272
  591. package/lib/esm/FeatureTable.js.map +1 -1
  592. package/lib/esm/Fonts.d.ts +51 -51
  593. package/lib/esm/Fonts.d.ts.map +1 -1
  594. package/lib/esm/Fonts.js +49 -49
  595. package/lib/esm/Frustum.d.ts +114 -114
  596. package/lib/esm/Frustum.js +288 -288
  597. package/lib/esm/GeoCoordinateServices.d.ts +123 -119
  598. package/lib/esm/GeoCoordinateServices.d.ts.map +1 -1
  599. package/lib/esm/GeoCoordinateServices.js +77 -76
  600. package/lib/esm/GeoCoordinateServices.js.map +1 -1
  601. package/lib/esm/GeometryContainment.d.ts +28 -28
  602. package/lib/esm/GeometryContainment.js +8 -8
  603. package/lib/esm/GeometryParams.d.ts +130 -130
  604. package/lib/esm/GeometryParams.js +170 -170
  605. package/lib/esm/GeometrySummary.d.ts +45 -45
  606. package/lib/esm/GeometrySummary.js +20 -20
  607. package/lib/esm/Gradient.d.ts +139 -139
  608. package/lib/esm/Gradient.js +450 -452
  609. package/lib/esm/Gradient.js.map +1 -1
  610. package/lib/esm/GraphicParams.d.ts +58 -58
  611. package/lib/esm/GraphicParams.js +81 -81
  612. package/lib/esm/GraphicParams.js.map +1 -1
  613. package/lib/esm/GroundPlane.d.ts +52 -52
  614. package/lib/esm/GroundPlane.d.ts.map +1 -1
  615. package/lib/esm/GroundPlane.js +60 -60
  616. package/lib/esm/GroundPlane.js.map +1 -1
  617. package/lib/esm/HSLColor.d.ts +20 -20
  618. package/lib/esm/HSLColor.js +28 -28
  619. package/lib/esm/HSLColor.js.map +1 -1
  620. package/lib/esm/HSVColor.d.ts +30 -30
  621. package/lib/esm/HSVColor.js +55 -55
  622. package/lib/esm/HSVColor.js.map +1 -1
  623. package/lib/esm/HiddenLine.d.ts +97 -97
  624. package/lib/esm/HiddenLine.js +157 -159
  625. package/lib/esm/HiddenLine.js.map +1 -1
  626. package/lib/esm/Hilite.d.ts +50 -50
  627. package/lib/esm/Hilite.js +61 -61
  628. package/lib/esm/Hilite.js.map +1 -1
  629. package/lib/esm/IModel.d.ts +358 -359
  630. package/lib/esm/IModel.d.ts.map +1 -1
  631. package/lib/esm/IModel.js +343 -342
  632. package/lib/esm/IModel.js.map +1 -1
  633. package/lib/esm/IModelError.d.ts +42 -42
  634. package/lib/esm/IModelError.d.ts.map +1 -1
  635. package/lib/esm/IModelError.js +56 -56
  636. package/lib/esm/IModelVersion.d.ts +68 -68
  637. package/lib/esm/IModelVersion.d.ts.map +1 -1
  638. package/lib/esm/IModelVersion.js +75 -75
  639. package/lib/esm/Image.d.ts +86 -86
  640. package/lib/esm/Image.js +120 -120
  641. package/lib/esm/Image.js.map +1 -1
  642. package/lib/esm/IpcAppProps.d.ts +141 -141
  643. package/lib/esm/IpcAppProps.js +19 -19
  644. package/lib/esm/LightSettings.d.ts +224 -224
  645. package/lib/esm/LightSettings.js +297 -301
  646. package/lib/esm/LightSettings.js.map +1 -1
  647. package/lib/esm/LinePixels.d.ts +34 -34
  648. package/lib/esm/LinePixels.js +39 -39
  649. package/lib/esm/Localization.d.ts +117 -113
  650. package/lib/esm/Localization.d.ts.map +1 -1
  651. package/lib/esm/Localization.js +29 -29
  652. package/lib/esm/Localization.js.map +1 -1
  653. package/lib/esm/MapImagerySettings.d.ts +62 -62
  654. package/lib/esm/MapImagerySettings.d.ts.map +1 -1
  655. package/lib/esm/MapImagerySettings.js +76 -76
  656. package/lib/esm/MapImagerySettings.js.map +1 -1
  657. package/lib/esm/MapLayerSettings.d.ts +272 -272
  658. package/lib/esm/MapLayerSettings.d.ts.map +1 -1
  659. package/lib/esm/MapLayerSettings.js +399 -403
  660. package/lib/esm/MapLayerSettings.js.map +1 -1
  661. package/lib/esm/MassProperties.d.ts +64 -64
  662. package/lib/esm/MassProperties.js +20 -20
  663. package/lib/esm/MaterialProps.d.ts +153 -153
  664. package/lib/esm/MaterialProps.d.ts.map +1 -1
  665. package/lib/esm/MaterialProps.js +32 -32
  666. package/lib/esm/ModelClipGroup.d.ts +67 -67
  667. package/lib/esm/ModelClipGroup.js +91 -93
  668. package/lib/esm/ModelClipGroup.js.map +1 -1
  669. package/lib/esm/ModelGeometryChanges.d.ts +107 -107
  670. package/lib/esm/ModelGeometryChanges.d.ts.map +1 -1
  671. package/lib/esm/ModelGeometryChanges.js +80 -80
  672. package/lib/esm/ModelProps.d.ts +67 -67
  673. package/lib/esm/ModelProps.js +8 -8
  674. package/lib/esm/NativeAppProps.d.ts +122 -122
  675. package/lib/esm/NativeAppProps.d.ts.map +1 -1
  676. package/lib/esm/NativeAppProps.js +27 -27
  677. package/lib/esm/OctEncodedNormal.d.ts +33 -33
  678. package/lib/esm/OctEncodedNormal.js +93 -93
  679. package/lib/esm/PlanProjectionSettings.d.ts +47 -47
  680. package/lib/esm/PlanProjectionSettings.js +59 -59
  681. package/lib/esm/PlanProjectionSettings.js.map +1 -1
  682. package/lib/esm/PlanarClipMask.d.ts +177 -177
  683. package/lib/esm/PlanarClipMask.js +133 -132
  684. package/lib/esm/PlanarClipMask.js.map +1 -1
  685. package/lib/esm/QPoint.d.ts +479 -479
  686. package/lib/esm/QPoint.js +813 -815
  687. package/lib/esm/QPoint.js.map +1 -1
  688. package/lib/esm/RealityDataAccessProps.d.ts +41 -41
  689. package/lib/esm/RealityDataAccessProps.js +16 -16
  690. package/lib/esm/RealityModelDisplaySettings.d.ts +183 -183
  691. package/lib/esm/RealityModelDisplaySettings.d.ts.map +1 -1
  692. package/lib/esm/RealityModelDisplaySettings.js +138 -137
  693. package/lib/esm/RealityModelDisplaySettings.js.map +1 -1
  694. package/lib/esm/Render.d.ts +89 -89
  695. package/lib/esm/Render.js +165 -165
  696. package/lib/esm/RenderMaterial.d.ts +58 -58
  697. package/lib/esm/RenderMaterial.js +71 -72
  698. package/lib/esm/RenderMaterial.js.map +1 -1
  699. package/lib/esm/RenderSchedule.d.ts +543 -543
  700. package/lib/esm/RenderSchedule.js +989 -999
  701. package/lib/esm/RenderSchedule.js.map +1 -1
  702. package/lib/esm/RenderTexture.d.ts +70 -70
  703. package/lib/esm/RenderTexture.d.ts.map +1 -1
  704. package/lib/esm/RenderTexture.js +55 -55
  705. package/lib/esm/RenderTexture.js.map +1 -1
  706. package/lib/esm/RgbColor.d.ts +47 -47
  707. package/lib/esm/RgbColor.js +73 -73
  708. package/lib/esm/RpcInterface.d.ts +40 -33
  709. package/lib/esm/RpcInterface.d.ts.map +1 -1
  710. package/lib/esm/RpcInterface.js +133 -133
  711. package/lib/esm/RpcInterface.js.map +1 -1
  712. package/lib/esm/RpcManager.d.ts +40 -40
  713. package/lib/esm/RpcManager.js +51 -51
  714. package/lib/esm/RpcManager.js.map +1 -1
  715. package/lib/esm/SessionProps.d.ts +16 -16
  716. package/lib/esm/SessionProps.js +8 -8
  717. package/lib/esm/SkyBox.d.ts +217 -215
  718. package/lib/esm/SkyBox.d.ts.map +1 -1
  719. package/lib/esm/SkyBox.js +204 -203
  720. package/lib/esm/SkyBox.js.map +1 -1
  721. package/lib/esm/Snapping.d.ts +49 -49
  722. package/lib/esm/Snapping.js +8 -8
  723. package/lib/esm/SolarCalculate.d.ts +27 -27
  724. package/lib/esm/SolarCalculate.js +204 -204
  725. package/lib/esm/SolarShadows.d.ts +35 -35
  726. package/lib/esm/SolarShadows.js +58 -58
  727. package/lib/esm/SolarShadows.js.map +1 -1
  728. package/lib/esm/SpatialClassification.d.ts +208 -208
  729. package/lib/esm/SpatialClassification.js +333 -334
  730. package/lib/esm/SpatialClassification.js.map +1 -1
  731. package/lib/esm/SubCategoryAppearance.d.ts +91 -91
  732. package/lib/esm/SubCategoryAppearance.js +93 -92
  733. package/lib/esm/SubCategoryAppearance.js.map +1 -1
  734. package/lib/esm/SubCategoryOverride.d.ts +46 -46
  735. package/lib/esm/SubCategoryOverride.js +101 -100
  736. package/lib/esm/SubCategoryOverride.js.map +1 -1
  737. package/lib/esm/TerrainSettings.d.ts +82 -82
  738. package/lib/esm/TerrainSettings.d.ts.map +1 -1
  739. package/lib/esm/TerrainSettings.js +96 -98
  740. package/lib/esm/TerrainSettings.js.map +1 -1
  741. package/lib/esm/TextureMapping.d.ts +151 -118
  742. package/lib/esm/TextureMapping.d.ts.map +1 -1
  743. package/lib/esm/TextureMapping.js +176 -170
  744. package/lib/esm/TextureMapping.js.map +1 -1
  745. package/lib/esm/TextureProps.d.ts +65 -65
  746. package/lib/esm/TextureProps.js +25 -25
  747. package/lib/esm/ThematicDisplay.d.ts +230 -230
  748. package/lib/esm/ThematicDisplay.js +337 -337
  749. package/lib/esm/ThematicDisplay.js.map +1 -1
  750. package/lib/esm/Thumbnail.d.ts +26 -26
  751. package/lib/esm/Thumbnail.js +8 -8
  752. package/lib/esm/TileProps.d.ts +88 -82
  753. package/lib/esm/TileProps.d.ts.map +1 -1
  754. package/lib/esm/TileProps.js +25 -25
  755. package/lib/esm/TileProps.js.map +1 -1
  756. package/lib/esm/Tween.d.ts +191 -191
  757. package/lib/esm/Tween.d.ts.map +1 -1
  758. package/lib/esm/Tween.js +565 -565
  759. package/lib/esm/TxnAction.d.ts +21 -21
  760. package/lib/esm/TxnAction.js +26 -26
  761. package/lib/esm/ViewDetails.d.ts +125 -125
  762. package/lib/esm/ViewDetails.js +162 -161
  763. package/lib/esm/ViewDetails.js.map +1 -1
  764. package/lib/esm/ViewFlags.d.ts +287 -287
  765. package/lib/esm/ViewFlags.d.ts.map +1 -1
  766. package/lib/esm/ViewFlags.js +364 -364
  767. package/lib/esm/ViewFlags.js.map +1 -1
  768. package/lib/esm/ViewProps.d.ts +205 -205
  769. package/lib/esm/ViewProps.js +8 -8
  770. package/lib/esm/WhiteOnWhiteReversalSettings.d.ts +36 -36
  771. package/lib/esm/WhiteOnWhiteReversalSettings.js +34 -33
  772. package/lib/esm/WhiteOnWhiteReversalSettings.js.map +1 -1
  773. package/lib/esm/core-common.d.ts +244 -244
  774. package/lib/esm/core-common.d.ts.map +1 -1
  775. package/lib/esm/core-common.js +248 -248
  776. package/lib/esm/core-common.js.map +1 -1
  777. package/lib/esm/domains/FunctionalElementProps.d.ts +11 -11
  778. package/lib/esm/domains/FunctionalElementProps.js +8 -8
  779. package/lib/esm/domains/GenericElementProps.d.ts +18 -18
  780. package/lib/esm/domains/GenericElementProps.js +8 -8
  781. package/lib/esm/geometry/AdditionalTransform.d.ts +84 -84
  782. package/lib/esm/geometry/AdditionalTransform.js +80 -80
  783. package/lib/esm/geometry/AreaPattern.d.ts +82 -82
  784. package/lib/esm/geometry/AreaPattern.js +200 -201
  785. package/lib/esm/geometry/AreaPattern.js.map +1 -1
  786. package/lib/esm/geometry/BoundingSphere.d.ts +27 -27
  787. package/lib/esm/geometry/BoundingSphere.js +40 -40
  788. package/lib/esm/geometry/BoundingSphere.js.map +1 -1
  789. package/lib/esm/geometry/Cartographic.d.ts +137 -137
  790. package/lib/esm/geometry/Cartographic.js +341 -340
  791. package/lib/esm/geometry/Cartographic.js.map +1 -1
  792. package/lib/esm/geometry/CoordinateReferenceSystem.d.ts +269 -269
  793. package/lib/esm/geometry/CoordinateReferenceSystem.d.ts.map +1 -1
  794. package/lib/esm/geometry/CoordinateReferenceSystem.js +253 -254
  795. package/lib/esm/geometry/CoordinateReferenceSystem.js.map +1 -1
  796. package/lib/esm/geometry/ElementGeometry.d.ts +402 -402
  797. package/lib/esm/geometry/ElementGeometry.d.ts.map +1 -1
  798. package/lib/esm/geometry/ElementGeometry.js +1716 -1716
  799. package/lib/esm/geometry/ElementGeometry.js.map +1 -1
  800. package/lib/esm/geometry/ElementGeometryFB.d.ts +2372 -2372
  801. package/lib/esm/geometry/ElementGeometryFB.js +3811 -3811
  802. package/lib/esm/geometry/ElementGeometryFB.js.map +1 -1
  803. package/lib/esm/geometry/FrustumPlanes.d.ts +83 -81
  804. package/lib/esm/geometry/FrustumPlanes.d.ts.map +1 -1
  805. package/lib/esm/geometry/FrustumPlanes.js +223 -189
  806. package/lib/esm/geometry/FrustumPlanes.js.map +1 -1
  807. package/lib/esm/geometry/GeodeticDatum.d.ts +409 -409
  808. package/lib/esm/geometry/GeodeticDatum.d.ts.map +1 -1
  809. package/lib/esm/geometry/GeodeticDatum.js +389 -390
  810. package/lib/esm/geometry/GeodeticDatum.js.map +1 -1
  811. package/lib/esm/geometry/GeodeticEllipsoid.d.ts +72 -72
  812. package/lib/esm/geometry/GeodeticEllipsoid.js +67 -68
  813. package/lib/esm/geometry/GeodeticEllipsoid.js.map +1 -1
  814. package/lib/esm/geometry/GeometryStream.d.ts +347 -347
  815. package/lib/esm/geometry/GeometryStream.d.ts.map +1 -1
  816. package/lib/esm/geometry/GeometryStream.js +463 -464
  817. package/lib/esm/geometry/GeometryStream.js.map +1 -1
  818. package/lib/esm/geometry/ImageGraphic.d.ts +74 -74
  819. package/lib/esm/geometry/ImageGraphic.d.ts.map +1 -1
  820. package/lib/esm/geometry/ImageGraphic.js +93 -93
  821. package/lib/esm/geometry/LineStyle.d.ts +71 -71
  822. package/lib/esm/geometry/LineStyle.js +126 -126
  823. package/lib/esm/geometry/Placement.d.ts +95 -95
  824. package/lib/esm/geometry/Placement.d.ts.map +1 -1
  825. package/lib/esm/geometry/Placement.js +126 -126
  826. package/lib/esm/geometry/Projection.d.ts +251 -251
  827. package/lib/esm/geometry/Projection.d.ts.map +1 -1
  828. package/lib/esm/geometry/Projection.js +192 -192
  829. package/lib/esm/geometry/Projection.js.map +1 -1
  830. package/lib/esm/geometry/TextString.d.ts +55 -55
  831. package/lib/esm/geometry/TextString.js +61 -61
  832. package/lib/esm/geometry/TextString.js.map +1 -1
  833. package/lib/esm/ipc/IpcSession.d.ts +23 -23
  834. package/lib/esm/ipc/IpcSession.js +23 -23
  835. package/lib/esm/ipc/IpcSocket.d.ts +96 -96
  836. package/lib/esm/ipc/IpcSocket.d.ts.map +1 -1
  837. package/lib/esm/ipc/IpcSocket.js +12 -12
  838. package/lib/esm/ipc/IpcWebSocket.d.ts +60 -61
  839. package/lib/esm/ipc/IpcWebSocket.d.ts.map +1 -1
  840. package/lib/esm/ipc/IpcWebSocket.js +143 -145
  841. package/lib/esm/ipc/IpcWebSocket.js.map +1 -1
  842. package/lib/esm/ipc/IpcWebSocketTransport.d.ts +15 -15
  843. package/lib/esm/ipc/IpcWebSocketTransport.js +156 -156
  844. package/lib/esm/ipc/IpcWebSocketTransport.js.map +1 -1
  845. package/lib/esm/rpc/DevToolsRpcInterface.d.ts +32 -32
  846. package/lib/esm/rpc/DevToolsRpcInterface.d.ts.map +1 -1
  847. package/lib/esm/rpc/DevToolsRpcInterface.js +49 -44
  848. package/lib/esm/rpc/DevToolsRpcInterface.js.map +1 -1
  849. package/lib/esm/rpc/IModelReadRpcInterface.d.ts +99 -99
  850. package/lib/esm/rpc/IModelReadRpcInterface.d.ts.map +1 -1
  851. package/lib/esm/rpc/IModelReadRpcInterface.js +118 -117
  852. package/lib/esm/rpc/IModelReadRpcInterface.js.map +1 -1
  853. package/lib/esm/rpc/IModelTileRpcInterface.d.ts +49 -61
  854. package/lib/esm/rpc/IModelTileRpcInterface.d.ts.map +1 -1
  855. package/lib/esm/rpc/IModelTileRpcInterface.js +76 -92
  856. package/lib/esm/rpc/IModelTileRpcInterface.js.map +1 -1
  857. package/lib/esm/rpc/SnapshotIModelRpcInterface.d.ts +23 -23
  858. package/lib/esm/rpc/SnapshotIModelRpcInterface.js +45 -44
  859. package/lib/esm/rpc/SnapshotIModelRpcInterface.js.map +1 -1
  860. package/lib/esm/rpc/TestRpcManager.d.ts +20 -20
  861. package/lib/esm/rpc/TestRpcManager.js +36 -36
  862. package/lib/esm/rpc/WipRpcInterface.d.ts +29 -29
  863. package/lib/esm/rpc/WipRpcInterface.js +37 -36
  864. package/lib/esm/rpc/WipRpcInterface.js.map +1 -1
  865. package/lib/esm/rpc/core/RpcConfiguration.d.ts +111 -111
  866. package/lib/esm/rpc/core/RpcConfiguration.d.ts.map +1 -1
  867. package/lib/esm/rpc/core/RpcConfiguration.js +185 -184
  868. package/lib/esm/rpc/core/RpcConfiguration.js.map +1 -1
  869. package/lib/esm/rpc/core/RpcConstants.d.ts +90 -90
  870. package/lib/esm/rpc/core/RpcConstants.js +106 -106
  871. package/lib/esm/rpc/core/RpcControl.d.ts +54 -54
  872. package/lib/esm/rpc/core/RpcControl.js +144 -138
  873. package/lib/esm/rpc/core/RpcControl.js.map +1 -1
  874. package/lib/esm/rpc/core/RpcInvocation.d.ts +89 -89
  875. package/lib/esm/rpc/core/RpcInvocation.d.ts.map +1 -1
  876. package/lib/esm/rpc/core/RpcInvocation.js +253 -254
  877. package/lib/esm/rpc/core/RpcInvocation.js.map +1 -1
  878. package/lib/esm/rpc/core/RpcMarshaling.d.ts +35 -35
  879. package/lib/esm/rpc/core/RpcMarshaling.js +152 -152
  880. package/lib/esm/rpc/core/RpcOperation.d.ts +67 -67
  881. package/lib/esm/rpc/core/RpcOperation.d.ts.map +1 -1
  882. package/lib/esm/rpc/core/RpcOperation.js +130 -129
  883. package/lib/esm/rpc/core/RpcOperation.js.map +1 -1
  884. package/lib/esm/rpc/core/RpcPendingQueue.d.ts +21 -21
  885. package/lib/esm/rpc/core/RpcPendingQueue.js +90 -91
  886. package/lib/esm/rpc/core/RpcPendingQueue.js.map +1 -1
  887. package/lib/esm/rpc/core/RpcProtocol.d.ts +132 -132
  888. package/lib/esm/rpc/core/RpcProtocol.d.ts.map +1 -1
  889. package/lib/esm/rpc/core/RpcProtocol.js +124 -123
  890. package/lib/esm/rpc/core/RpcProtocol.js.map +1 -1
  891. package/lib/esm/rpc/core/RpcPush.d.ts +68 -68
  892. package/lib/esm/rpc/core/RpcPush.d.ts.map +1 -1
  893. package/lib/esm/rpc/core/RpcPush.js +121 -119
  894. package/lib/esm/rpc/core/RpcPush.js.map +1 -1
  895. package/lib/esm/rpc/core/RpcRegistry.d.ts +48 -48
  896. package/lib/esm/rpc/core/RpcRegistry.js +194 -195
  897. package/lib/esm/rpc/core/RpcRegistry.js.map +1 -1
  898. package/lib/esm/rpc/core/RpcRequest.d.ts +186 -186
  899. package/lib/esm/rpc/core/RpcRequest.d.ts.map +1 -1
  900. package/lib/esm/rpc/core/RpcRequest.js +474 -473
  901. package/lib/esm/rpc/core/RpcRequest.js.map +1 -1
  902. package/lib/esm/rpc/core/RpcRequestContext.d.ts +14 -14
  903. package/lib/esm/rpc/core/RpcRequestContext.js +1 -1
  904. package/lib/esm/rpc/core/RpcRoutingToken.d.ts +12 -12
  905. package/lib/esm/rpc/core/RpcRoutingToken.d.ts.map +1 -1
  906. package/lib/esm/rpc/core/RpcRoutingToken.js +21 -20
  907. package/lib/esm/rpc/core/RpcRoutingToken.js.map +1 -1
  908. package/lib/esm/rpc/core/RpcSessionInvocation.d.ts +10 -10
  909. package/lib/esm/rpc/core/RpcSessionInvocation.js +56 -56
  910. package/lib/esm/rpc/core/RpcSessionInvocation.js.map +1 -1
  911. package/lib/esm/rpc/web/BentleyCloudRpcManager.d.ts +48 -46
  912. package/lib/esm/rpc/web/BentleyCloudRpcManager.d.ts.map +1 -1
  913. package/lib/esm/rpc/web/BentleyCloudRpcManager.js +72 -68
  914. package/lib/esm/rpc/web/BentleyCloudRpcManager.js.map +1 -1
  915. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.d.ts +33 -33
  916. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.js +137 -139
  917. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.js.map +1 -1
  918. package/lib/esm/rpc/web/OpenAPI.d.ts +140 -140
  919. package/lib/esm/rpc/web/OpenAPI.js +56 -56
  920. package/lib/esm/rpc/web/OpenAPI.js.map +1 -1
  921. package/lib/esm/rpc/web/RpcMultipart.d.ts +35 -35
  922. package/lib/esm/rpc/web/RpcMultipart.js +47 -46
  923. package/lib/esm/rpc/web/RpcMultipart.js.map +1 -1
  924. package/lib/esm/rpc/web/WebAppRpcLogging.d.ts +28 -28
  925. package/lib/esm/rpc/web/WebAppRpcLogging.js +136 -136
  926. package/lib/esm/rpc/web/WebAppRpcProtocol.d.ts +89 -89
  927. package/lib/esm/rpc/web/WebAppRpcProtocol.js +112 -112
  928. package/lib/esm/rpc/web/WebAppRpcProtocol.js.map +1 -1
  929. package/lib/esm/rpc/web/WebAppRpcRequest.d.ts +67 -67
  930. package/lib/esm/rpc/web/WebAppRpcRequest.d.ts.map +1 -1
  931. package/lib/esm/rpc/web/WebAppRpcRequest.js +236 -235
  932. package/lib/esm/rpc/web/WebAppRpcRequest.js.map +1 -1
  933. package/lib/esm/rpc/web/multipart/RpcMultipartParser.d.ts +32 -32
  934. package/lib/esm/rpc/web/multipart/RpcMultipartParser.js +369 -369
  935. package/lib/esm/tile/B3dmTileIO.d.ts +19 -19
  936. package/lib/esm/tile/B3dmTileIO.js +62 -62
  937. package/lib/esm/tile/B3dmTileIO.js.map +1 -1
  938. package/lib/esm/tile/CompositeTileIO.d.ts +15 -15
  939. package/lib/esm/tile/CompositeTileIO.js +22 -22
  940. package/lib/esm/tile/CompositeTileIO.js.map +1 -1
  941. package/lib/esm/tile/ElementGraphics.d.ts +145 -145
  942. package/lib/esm/tile/ElementGraphics.d.ts.map +1 -1
  943. package/lib/esm/tile/ElementGraphics.js +8 -8
  944. package/lib/esm/tile/GltfTileIO.d.ts +45 -45
  945. package/lib/esm/tile/GltfTileIO.d.ts.map +1 -1
  946. package/lib/esm/tile/GltfTileIO.js +105 -105
  947. package/lib/esm/tile/GltfTileIO.js.map +1 -1
  948. package/lib/esm/tile/I3dmTileIO.d.ts +20 -20
  949. package/lib/esm/tile/I3dmTileIO.js +36 -36
  950. package/lib/esm/tile/I3dmTileIO.js.map +1 -1
  951. package/lib/esm/tile/IModelTileIO.d.ts +77 -75
  952. package/lib/esm/tile/IModelTileIO.d.ts.map +1 -1
  953. package/lib/esm/tile/IModelTileIO.js +93 -90
  954. package/lib/esm/tile/IModelTileIO.js.map +1 -1
  955. package/lib/esm/tile/PntsTileIO.d.ts +17 -17
  956. package/lib/esm/tile/PntsTileIO.js +22 -22
  957. package/lib/esm/tile/PntsTileIO.js.map +1 -1
  958. package/lib/esm/tile/TileIO.d.ts +66 -66
  959. package/lib/esm/tile/TileIO.js +110 -110
  960. package/lib/esm/tile/TileMetadata.d.ts +228 -228
  961. package/lib/esm/tile/TileMetadata.d.ts.map +1 -1
  962. package/lib/esm/tile/TileMetadata.js +660 -661
  963. package/lib/esm/tile/TileMetadata.js.map +1 -1
  964. package/lib/esm/tile/Tileset3dSchema.d.ts +97 -0
  965. package/lib/esm/tile/Tileset3dSchema.d.ts.map +1 -0
  966. package/lib/esm/tile/Tileset3dSchema.js +9 -0
  967. package/lib/esm/tile/Tileset3dSchema.js.map +1 -0
  968. package/package.json +14 -14
  969. package/lib/cjs/CloudStorage.d.ts +0 -63
  970. package/lib/cjs/CloudStorage.d.ts.map +0 -1
  971. package/lib/cjs/CloudStorage.js +0 -114
  972. package/lib/cjs/CloudStorage.js.map +0 -1
  973. package/lib/cjs/CloudStorageTileCache.d.ts +0 -28
  974. package/lib/cjs/CloudStorageTileCache.d.ts.map +0 -1
  975. package/lib/cjs/CloudStorageTileCache.js +0 -67
  976. package/lib/cjs/CloudStorageTileCache.js.map +0 -1
  977. package/lib/esm/CloudStorage.d.ts +0 -63
  978. package/lib/esm/CloudStorage.d.ts.map +0 -1
  979. package/lib/esm/CloudStorage.js +0 -110
  980. package/lib/esm/CloudStorage.js.map +0 -1
  981. package/lib/esm/CloudStorageTileCache.d.ts +0 -28
  982. package/lib/esm/CloudStorageTileCache.d.ts.map +0 -1
  983. package/lib/esm/CloudStorageTileCache.js +0 -63
  984. package/lib/esm/CloudStorageTileCache.js.map +0 -1
@@ -1,610 +1,616 @@
1
- /*---------------------------------------------------------------------------------------------
2
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
- * See LICENSE.md in the project root for license terms and full copyright notice.
4
- *--------------------------------------------------------------------------------------------*/
5
- /** @packageDocumentation
6
- * @module Rendering
7
- */
8
- import { assert, Id64 } from "@itwin/core-bentley";
9
- import { BatchType } from "./FeatureTable";
10
- import { GeometryClass } from "./GeometryParams";
11
- import { RgbColor } from "./RgbColor";
12
- function copyIdSetToUint32Set(dst, src) {
13
- dst.clear();
14
- if (typeof src === "string") {
15
- dst.addId(src);
16
- }
17
- else {
18
- for (const id of src)
19
- dst.addId(id);
20
- }
21
- }
22
- /** Defines overrides for selected aspects of a [[Feature]]'s symbology.
23
- * Any member defined in the appearance overrides that aspect of symbology for all [[Feature]]s to which the appearance is applied.
24
- * @see [[FeatureOverrides]] to customize the appearance of multiple features.
25
- * @public
26
- */
27
- export class FeatureAppearance {
28
- constructor(props) {
29
- this.rgb = undefined !== props.rgb ? RgbColor.fromJSON(props.rgb) : undefined;
30
- this.weight = props.weight;
31
- this.transparency = props.transparency;
32
- this.linePixels = props.linePixels;
33
- this.ignoresMaterial = props.ignoresMaterial;
34
- this.nonLocatable = props.nonLocatable;
35
- this.emphasized = props.emphasized;
36
- if (undefined !== this.weight)
37
- this.weight = Math.max(1, Math.min(this.weight, 32));
38
- if (undefined !== this.transparency) {
39
- if (props.viewDependentTransparency)
40
- this.viewDependentTransparency = true;
41
- this.transparency = Math.max(0, Math.min(this.transparency, 1));
42
- // Fix up rounding errors...
43
- const smallDelta = 0.0001;
44
- if (1.0 - this.transparency < smallDelta)
45
- this.transparency = 1.0;
46
- else if (this.transparency < smallDelta)
47
- this.transparency = 0.0;
48
- }
49
- }
50
- static fromJSON(props) {
51
- if (undefined === props || (undefined === props.rgb && undefined === props.weight && undefined === props.transparency && undefined === props.linePixels && !props.ignoresMaterial && !props.nonLocatable && !props.emphasized))
52
- return this.defaults;
53
- else
54
- return new FeatureAppearance(props);
55
- }
56
- /** Create a FeatureAppearance that overrides only the RGB color.
57
- * @note The transparency component of the ColorDef is ignored.
58
- */
59
- static fromRgb(color) {
60
- return this.fromJSON({ rgb: RgbColor.fromColorDef(color) });
61
- }
62
- /** Create a FeatureAppearance that overrides the RGB and transparency.
63
- * The appearance's transparency is derived from the transparency component of the ColorDef.
64
- */
65
- static fromRgba(color, viewDependentTransparency = false) {
66
- return this.fromJSON({
67
- rgb: RgbColor.fromColorDef(color),
68
- transparency: color.colors.t / 255,
69
- viewDependentTransparency: viewDependentTransparency ? true : undefined,
70
- });
71
- }
72
- /** Create a FeatureAppearance that overrides only the transparency */
73
- static fromTransparency(transparencyValue, viewDependent = false) {
74
- return this.fromJSON({
75
- transparency: transparencyValue,
76
- viewDependentTransparency: viewDependent ? true : undefined,
77
- });
78
- }
79
- /** Create a FeatureAppearance with overrides corresponding to those defined by the supplied SubCategoryOverride.
80
- * @note Subcategory overrides set [[viewDependentTransparency]] to `true`.
81
- */
82
- static fromSubCategoryOverride(ovr) {
83
- const rgb = undefined !== ovr.color ? RgbColor.fromColorDef(ovr.color) : undefined;
84
- const transparency = ovr.transparency;
85
- const weight = ovr.weight;
86
- const ignoresMaterial = undefined !== ovr.material && Id64.isValid(ovr.material) ? true : undefined;
87
- return this.fromJSON({ rgb, transparency, weight, ignoresMaterial, viewDependentTransparency: true });
88
- }
89
- /** Returns true if this appearance does not override any aspects of symbology. */
90
- get matchesDefaults() {
91
- return this.equals(FeatureAppearance.defaults);
92
- }
93
- get overridesRgb() { return undefined !== this.rgb; }
94
- get overridesTransparency() { return undefined !== this.transparency; }
95
- get overridesLinePixels() { return undefined !== this.linePixels; }
96
- get overridesWeight() { return undefined !== this.weight; }
97
- get overridesSymbology() {
98
- return this.overridesRgb || this.overridesTransparency || this.overridesWeight || this.overridesLinePixels || !!this.ignoresMaterial
99
- || this.emphasized || this.overridesNonLocatable;
100
- }
101
- get overridesNonLocatable() { return undefined !== this.nonLocatable; }
102
- get isFullyTransparent() { return undefined !== this.transparency && this.transparency >= 1.0; }
103
- /** Returns true if any aspect of the appearance is overridden (i.e., if any member is not undefined). */
104
- get anyOverridden() { return this.overridesSymbology || this.overridesNonLocatable; }
105
- equals(other) {
106
- if (this === other)
107
- return true;
108
- return this.rgbIsEqual(other.rgb)
109
- && this.weight === other.weight
110
- && this.transparencyIsEqual(other.transparency)
111
- && this.linePixels === other.linePixels
112
- && this.ignoresMaterial === other.ignoresMaterial
113
- && this.nonLocatable === other.nonLocatable
114
- && this.emphasized === other.emphasized
115
- && this.viewDependentTransparency === other.viewDependentTransparency;
116
- }
117
- toJSON() {
118
- const props = {};
119
- if (this.rgb)
120
- props.rgb = this.rgb.toJSON();
121
- if (undefined !== this.weight)
122
- props.weight = this.weight;
123
- if (undefined !== this.transparency) {
124
- props.transparency = this.transparency;
125
- if (this.viewDependentTransparency)
126
- props.viewDependentTransparency = true;
127
- }
128
- if (undefined !== this.linePixels)
129
- props.linePixels = this.linePixels;
130
- if (true === this.ignoresMaterial)
131
- props.ignoresMaterial = true;
132
- if (true === this.nonLocatable)
133
- props.nonLocatable = true;
134
- if (true === this.emphasized)
135
- props.emphasized = true;
136
- return props;
137
- }
138
- /** Convert this appearance to JSON, and override any properties explicitly specified by `changedProps` in the result.
139
- * Example:
140
- * ```ts
141
- * const base = FeatureAppearance.fromRgba(ColorDef.white); // transparency=0, rgb=white
142
- * const clone = base.cloneProps({ transparency: undefined, weight: 5 }); // transparency=undefined, rgb=white, weight=5
143
- * ```
144
- * @see [[FeatureAppearance.clone]].
145
- */
146
- cloneProps(changedProps) {
147
- return {
148
- ...this.toJSON(),
149
- ...changedProps,
150
- };
151
- }
152
- /** Create a copy of this appearance, overriding any properties explicitly specified by `changedProps`.
153
- * Example:
154
- * ```ts
155
- * const base = FeatureAppearance.fromRgba(ColorDef.white); // transparency=0, rgb=white
156
- * const clone = base.clone({ transparency: undefined, weight: 5 }); // transparency=undefined, rgb=white, weight=5
157
- * ```
158
- * @see [[FeatureAppearance.cloneProps]].
159
- */
160
- clone(changedProps) {
161
- return FeatureAppearance.fromJSON(this.cloneProps(changedProps));
162
- }
163
- /** Produce a FeatureAppearance from the supplied appearance in which any aspect not defined by the base appearance is overridden by this appearance. */
164
- extendAppearance(base) {
165
- if (!this.overridesSymbology)
166
- return base;
167
- const props = base.toJSON();
168
- if (undefined === props.rgb)
169
- props.rgb = this.rgb;
170
- if (undefined === props.transparency)
171
- props.transparency = this.transparency;
172
- if (undefined === props.linePixels)
173
- props.linePixels = this.linePixels;
174
- if (undefined === props.weight)
175
- props.weight = this.weight;
176
- if (undefined === props.ignoresMaterial && this.ignoresMaterial)
177
- props.ignoresMaterial = true;
178
- if (undefined === props.nonLocatable && this.nonLocatable)
179
- props.nonLocatable = true;
180
- if (undefined === props.emphasized && this.emphasized)
181
- props.emphasized = true;
182
- if (undefined !== props.transparency && this.viewDependentTransparency)
183
- props.viewDependentTransparency = true;
184
- return FeatureAppearance.fromJSON(props);
185
- }
186
- rgbIsEqual(rgb) {
187
- if (undefined === this.rgb)
188
- return undefined === rgb;
189
- else if (undefined === rgb)
190
- return false;
191
- else
192
- return this.rgb.equals(rgb);
193
- }
194
- transparencyIsEqual(transp) {
195
- if (undefined === this.transparency)
196
- return undefined === transp;
197
- else if (undefined === transp)
198
- return false;
199
- else
200
- return Math.floor(this.transparency * 0xff) === Math.floor(transp * 0xff);
201
- }
202
- }
203
- /** An appearance that overrides nothing. */
204
- FeatureAppearance.defaults = new FeatureAppearance({});
205
- const scratchIgnoreAnimationOverridesArgs = {
206
- elementId: { lower: 0, upper: 0 },
207
- animationNodeId: 0,
208
- };
209
- /** Specifies how to customize the appearance of individual [[Feature]]s, typically within the context of a [Viewport]($frontend).
210
- * Individual aspects of a feature's appearance - like visibility, color, and transparency - are overridden by supplying a [[FeatureAppearance]].
211
- * Those overrides can be specified on the basis of the feature's model, element, and/or subcategory. A default set of overrides can also be specified to
212
- * apply to the appearance of any feature not otherwise overridden.
213
- *
214
- * It is possible to override multiple aspects of a feature on different bases. For example, you might specify that all features belonging to subcategory "A" should be drawn in red,
215
- * and that all features belonging to model "B" should be drawn 50% transparent. In this case, a feature belonging to both subcategory "A" and model "B" will be drawn as 50% transparent red -
216
- * the separate overrides are combined to produce the feature's overall appearance.
217
- *
218
- * In the case of conflicts, there is an order of precedence:
219
- * - Model overrides take highest precedence.
220
- * - Element overrides are of higher precedence than subcategory and animation overrides.
221
- * - Overrides applied by a [[RenderSchedule.Script]]'s [[RenderSchedule.ElementTimeline]] are of higher precedence than subcategory overrides, but can be suppressed on a per-element basis via [[ignoreAnimationOverrides]].
222
- * - Subcategory overrides have lowest precedence.
223
- *
224
- * For example, you might specify that all features belonging to subcategory "A" should be drawn in red, and all those belonging to model "B" should be drawn in green.
225
- * Then a feature belonging to subcategory "A" and model "B" will be drawn in green, because the model overrides take precedence.
226
- *
227
- * Instances of this class are not typically instantiated by an application directly; instead, an application can implement a [FeatureOverrideProvider]($frontend)
228
- * that augments the overrides supplied by a viewport.
229
- *
230
- * @see [FeatureSymbology.Overrides]($frontend) to create overrides specific to a [Viewport]($frontend) or [ViewState]($frontend).
231
- * @see [FeatureOverrideProvider]($frontend) to customize the appearance of features within a [Viewport]($frontend).
232
- * @public
233
- */
234
- export class FeatureOverrides {
235
- /** Construct a new Overrides that overrides nothing.
236
- * @see [FeatureSymbology.Overrides]($frontend) to construct overrides based on a [ViewState]($frontend) or [Viewport]($frontend).
237
- */
238
- constructor() {
239
- /** @internal */
240
- this._ignoreAnimationOverrides = [];
241
- /** Ids of elements that should never be drawn. This takes precedence over [[alwaysDrawn]]. @internal */
242
- this._neverDrawn = new Id64.Uint32Set();
243
- /** Ids of elements that should always be drawn. [[neverDrawn]] takes precedence over this set. @internal */
244
- this._alwaysDrawn = new Id64.Uint32Set();
245
- /** If true, no elements *except* those defined in the "always drawn" set will be drawn.
246
- * @see [[setAlwaysDrawn]]
247
- */
248
- this.isAlwaysDrawnExclusive = false;
249
- /** If true, the always-drawn elements are drawn even if their subcategories are not visible.
250
- * @see [[setAlwaysDrawn]]
251
- */
252
- this.alwaysDrawnIgnoresSubCategory = true;
253
- /** If true, all subcategories are considered visible. This is used for drawing sheets via section callouts in the absence of an actual sheet view.
254
- * @internal
255
- */
256
- this.ignoreSubCategory = false;
257
- /** Overrides applied to any feature not explicitly overridden. @internal */
258
- this._defaultOverrides = FeatureAppearance.defaults;
259
- /** Whether construction geometry should be drawn. @internal */
260
- this._constructions = false;
261
- /** Whether dimensions should be drawn. @internal */
262
- this._dimensions = false;
263
- /** Whether area patterns should be drawn. @internal */
264
- this._patterns = false;
265
- /** Whether line weights should be applied. If false, all lines are rendered 1-pixel wide. @internal */
266
- this._lineWeights = true;
267
- /** Overrides applied to all elements belonging to each model. @internal */
268
- this._modelOverrides = new Id64.Uint32Map();
269
- /** Overrides applied to specific elements. @internal */
270
- this._elementOverrides = new Id64.Uint32Map();
271
- /** Overrides applied to geometry belonging to each subcategory. @internal */
272
- this._subCategoryOverrides = new Id64.Uint32Map();
273
- /** The set of displayed subcategories. Geometry belonging to subcategories not included in this set will not be drawn. @internal */
274
- this._visibleSubCategories = new Id64.Uint32Set();
275
- /** Display priorities assigned to subcategories, possibly overridden by display style. Only applicable for plan projection models. @internal */
276
- this._subCategoryPriorities = new Id64.Uint32Map();
277
- /** Per-model, a set of subcategories whose visibility should be inverted for elements within that model.
278
- * Populated by Viewport.
279
- * @internal
280
- */
281
- this._modelSubCategoryOverrides = new Id64.Uint32Map();
282
- /** Ids of animation nodes that should never be drawn.
283
- * @internal
284
- */
285
- this.neverDrawnAnimationNodes = new Set();
286
- /** Mapping of animation node Ids to overrides applied to the corresponding animation nodes.
287
- * @internal
288
- */
289
- this.animationNodeOverrides = new Map();
290
- //
291
- }
292
- /** Accepts a criterion that determines whether color and transparency overrides originating from the view's [[RenderSchedule.Script]] should be ignored for a given element.
293
- * The function receives a description of the element in question and returns `true` if the script's overrides should be ignored.
294
- * Any number of such functions can be registered; if any one of them returns `true`, the script's overrides are not applied to the specified element.
295
- *
296
- * For example, applications commonly emphasize a set of elements by applying a [[FeatureAppearance.emphasized]] override to them, and specifying a highly-transparent
297
- * default appearance to de-emphasize the rest of the elements in the view. If some of the de-emphasized elements' appearances are also being overridden by the schedule script, then
298
- * they won't appear de-emphasized, making it difficult for the emphasized elements to stand out. In situations like this, [FeatureOverrideProvider]($frontend)s like [EmphasizeElements]($frontend) can register an [[IgnoreAnimationOverrides]] function that returns true if the element in question is not in the set of emphasized elements.
299
- */
300
- ignoreAnimationOverrides(ignore) {
301
- this._ignoreAnimationOverrides.push(ignore);
302
- }
303
- /** Overrides applied to features for which no other overrides are defined */
304
- get defaultOverrides() { return this._defaultOverrides; }
305
- /** Whether or not line weights are applied. If false, all lines are drawn with a weight of 1. */
306
- get lineWeights() { return this._lineWeights; }
307
- /** @internal */
308
- get neverDrawn() { return this._neverDrawn; }
309
- /** @internal */
310
- get alwaysDrawn() { return this._alwaysDrawn; }
311
- /** @internal */
312
- isNeverDrawn(elemIdLo, elemIdHi, animationNodeId) {
313
- if (this._neverDrawn.has(elemIdLo, elemIdHi))
314
- return true;
315
- else
316
- return this.neverDrawnAnimationNodes.has(animationNodeId);
317
- }
318
- /** @internal */
319
- isAlwaysDrawn(idLo, idHi) { return this._alwaysDrawn.has(idLo, idHi); }
320
- /** Returns true if the [SubCategory]($backend) specified by Id is in the set of visible subcategories. @internal */
321
- isSubCategoryVisible(idLo, idHi) { return this._visibleSubCategories.has(idLo, idHi); }
322
- /** @internal */
323
- isSubCategoryVisibleInModel(subcatLo, subcatHi, modelLo, modelHi) {
324
- if (this.ignoreSubCategory)
325
- return true;
326
- let vis = this.isSubCategoryVisible(subcatLo, subcatHi);
327
- const modelOvr = this._modelSubCategoryOverrides.get(modelLo, modelHi);
328
- if (undefined !== modelOvr && modelOvr.has(subcatLo, subcatHi))
329
- vis = !vis;
330
- return vis;
331
- }
332
- /** @internal */
333
- getModelOverrides(idLo, idHi) {
334
- return this._modelOverrides.get(idLo, idHi);
335
- }
336
- getElementAnimationOverrides(idLo, idHi, animationNodeId) {
337
- if (this.animationNodeOverrides.size === 0)
338
- return undefined;
339
- // NB: An animation node Id of zero means "not animated". Some providers like EmphasizeElements may provide an appearance override for unanimated nodes.
340
- // That should be preserved.
341
- const app = this.animationNodeOverrides.get(animationNodeId);
342
- if (!app || 0 === animationNodeId || this._ignoreAnimationOverrides.length === 0)
343
- return app;
344
- const args = scratchIgnoreAnimationOverridesArgs;
345
- args.elementId.lower = idLo;
346
- args.elementId.upper = idHi;
347
- args.animationNodeId = animationNodeId;
348
- return this._ignoreAnimationOverrides.some((ignore) => ignore(args)) ? undefined : app;
349
- }
350
- /** @internal */
351
- getElementOverrides(idLo, idHi, animationNodeId) {
352
- const elemApp = this._elementOverrides.get(idLo, idHi);
353
- const nodeApp = this.getElementAnimationOverrides(idLo, idHi, animationNodeId);
354
- if (elemApp)
355
- return nodeApp ? nodeApp.extendAppearance(elemApp) : elemApp;
356
- return nodeApp;
357
- }
358
- /** @internal */
359
- getSubCategoryOverrides(idLo, idHi) { return this._subCategoryOverrides.get(idLo, idHi); }
360
- /** Add a [SubCategory]($backend) to the set of visible subcategories. */
361
- setVisibleSubCategory(id) { this._visibleSubCategories.addId(id); }
362
- /** Specify the Id of an element that should never be drawn. */
363
- setNeverDrawn(id) { this._neverDrawn.addId(id); }
364
- /** Specify the Id of an element that should always be drawn. */
365
- setAlwaysDrawn(id) { this._alwaysDrawn.addId(id); }
366
- /** Specify the Id of a animation node that should never be drawn. */
367
- setAnimationNodeNeverDrawn(id) { this.neverDrawnAnimationNodes.add(id); }
368
- /** Specify the Ids of elements that should never be drawn. */
369
- setNeverDrawnSet(ids) { copyIdSetToUint32Set(this._neverDrawn, ids); }
370
- /** Specify the Ids of elements that should always be drawn. */
371
- setAlwaysDrawnSet(ids, exclusive, ignoreSubCategory = true) {
372
- copyIdSetToUint32Set(this._alwaysDrawn, ids);
373
- this.isAlwaysDrawnExclusive = exclusive;
374
- this.alwaysDrawnIgnoresSubCategory = ignoreSubCategory;
375
- }
376
- /** Returns the feature's appearance overrides, or undefined if the feature is not visible. */
377
- getFeatureAppearance(feature, modelId, type = BatchType.Primary, animationNodeId = 0) {
378
- return this.getAppearance(Id64.getLowerUint32(feature.elementId), Id64.getUpperUint32(feature.elementId), Id64.getLowerUint32(feature.subCategoryId), Id64.getUpperUint32(feature.subCategoryId), feature.geometryClass, Id64.getLowerUint32(modelId), Id64.getUpperUint32(modelId), type, animationNodeId);
379
- }
380
- /** Returns a feature's appearance overrides, or undefined if the feature is not visible.
381
- * Takes Id64s as pairs of unsigned 32-bit integers for efficiency, because that is how they are stored by the PackedFeatureTable associated with each batch of graphics.
382
- * @see [[getFeatureAppearance]] for an equivalent function that accepts [Id64String]($core-bentley)s instead of integer pairs.
383
- */
384
- getAppearance(elemLo, elemHi, subcatLo, subcatHi, geomClass, modelLo, modelHi, type, animationNodeId) {
385
- if (BatchType.VolumeClassifier === type || BatchType.PlanarClassifier === type)
386
- return this.getClassifierAppearance(elemLo, elemHi, subcatLo, subcatHi, modelLo, modelHi, animationNodeId);
387
- let app = !this._lineWeights ? FeatureOverrides._weight1Appearance : FeatureAppearance.defaults;
388
- const modelApp = this.getModelOverrides(modelLo, modelHi);
389
- if (undefined !== modelApp)
390
- app = modelApp.extendAppearance(app);
391
- // Is the element visible?
392
- let elemApp, alwaysDrawn = false;
393
- if (Id64.isValidUint32Pair(elemLo, elemHi)) {
394
- if (this.isNeverDrawn(elemLo, elemHi, animationNodeId))
395
- return undefined;
396
- alwaysDrawn = this.isAlwaysDrawn(elemLo, elemHi);
397
- if (!alwaysDrawn && this.isAlwaysDrawnExclusive)
398
- return undefined;
399
- // Element overrides take precedence
400
- elemApp = this.getElementOverrides(elemLo, elemHi, animationNodeId);
401
- if (undefined !== elemApp)
402
- app = undefined !== modelApp ? elemApp.extendAppearance(app) : elemApp;
403
- }
404
- let subCatApp;
405
- if (!this.ignoreSubCategory && Id64.isValidUint32Pair(subcatLo, subcatHi)) {
406
- if ((!alwaysDrawn || !this.alwaysDrawnIgnoresSubCategory) && !this.isSubCategoryVisibleInModel(subcatLo, subcatHi, modelLo, modelHi))
407
- return undefined;
408
- subCatApp = this.getSubCategoryOverrides(subcatLo, subcatHi);
409
- if (undefined !== subCatApp)
410
- app = subCatApp.extendAppearance(app);
411
- }
412
- // Only apply default if *no* appearance was explicitly registered (doesn't matter if registered appearance does not actually override anything)
413
- if (undefined === elemApp && undefined === modelApp && undefined === subCatApp)
414
- app = this._defaultOverrides.extendAppearance(app);
415
- let visible = alwaysDrawn || this.isClassVisible(geomClass);
416
- if (visible && app.isFullyTransparent)
417
- visible = false; // don't bother rendering something with full transparency...
418
- return visible ? app : undefined;
419
- }
420
- /** Classifiers behave totally differently...in particular they are never invisible unless fully-transparent.
421
- * @internal
422
- */
423
- getClassifierAppearance(elemLo, elemHi, subcatLo, subcatHi, modelLo, modelHi, animationNodeId) {
424
- let app = FeatureAppearance.defaults;
425
- const modelApp = this.getModelOverrides(modelLo, modelHi);
426
- if (undefined !== modelApp)
427
- app = modelApp.extendAppearance(app);
428
- const elemApp = this.getElementOverrides(elemLo, elemHi, animationNodeId);
429
- if (undefined !== elemApp)
430
- app = undefined !== modelApp ? elemApp.extendAppearance(app) : elemApp;
431
- if (!this.ignoreSubCategory && Id64.isValidUint32Pair(subcatLo, subcatHi)) {
432
- const subCat = this.getSubCategoryOverrides(subcatLo, subcatHi);
433
- if (undefined !== subCat)
434
- app = subCat.extendAppearance(app);
435
- }
436
- if (undefined === elemApp && undefined === modelApp)
437
- app = this._defaultOverrides.extendAppearance(app);
438
- // NB: A fully-transparent classifier means the classifier is a clip mask - classified pixels will be discarded.
439
- return app;
440
- }
441
- /** Return whether geometry of the specified class should be drawn.
442
- * @see [[ViewFlags.constructions]], [[ViewFlags.dimensions]], and [[ViewFlags.patterns]].
443
- */
444
- isClassVisible(geomClass) {
445
- switch (geomClass) {
446
- case GeometryClass.Construction: return this._constructions;
447
- case GeometryClass.Dimension: return this._dimensions;
448
- case GeometryClass.Pattern: return this._patterns;
449
- default: return true;
450
- }
451
- }
452
- /** Specify overrides for all elements belonging to a specified [GeometricModel]($backend), or all geometry belonging to a specified [GeometricElement]($backend) or [SubCategory]($backend). */
453
- override(args) {
454
- let id;
455
- let map;
456
- if (undefined !== args.elementId) {
457
- id = args.elementId;
458
- map = this._elementOverrides;
459
- }
460
- else if (undefined !== args.modelId) {
461
- id = args.modelId;
462
- map = this._modelOverrides;
463
- }
464
- else {
465
- id = args.subCategoryId;
466
- map = this._subCategoryOverrides;
467
- }
468
- let app = args.appearance;
469
- const idLo = Id64.getLowerUint32(id);
470
- const idHi = Id64.getUpperUint32(id);
471
- if (undefined !== args.elementId && this.isNeverDrawn(idLo, idHi, 0))
472
- return;
473
- const replace = "replace" === args.onConflict;
474
- const existing = replace ? undefined : map.get(idLo, idHi);
475
- if (existing) {
476
- assert("replace" !== args.onConflict);
477
- switch (args.onConflict) {
478
- case "skip":
479
- return;
480
- case "extend":
481
- app = app.extendAppearance(existing);
482
- break;
483
- default:
484
- app = existing.extendAppearance(app);
485
- break;
486
- }
487
- }
488
- map.set(idLo, idHi, app);
489
- }
490
- /** Specify overrides for all elements within the specified model.
491
- * @param id The Id of the model.
492
- * @param app The symbology overrides.
493
- * @param replaceExisting Specifies whether to replace a pre-existing override for the same model.
494
- * @note These overrides take priority over all other overrides.
495
- * @note If [[defaultOverrides]] are defined, they will not apply to any element within this model, even if the supplied appearance overrides nothing.
496
- * @deprecated in 3.x. Use [[FeatureOverrides.override]].
497
- */
498
- overrideModel(id, app, replaceExisting = true) {
499
- this.override({ modelId: id, appearance: app, onConflict: replaceExisting ? "replace" : "skip" });
500
- }
501
- /** Specify overrides for all geometry belonging to the specified [SubCategory]($backend).
502
- * @param id The Id of the subcategory.
503
- * @param app The symbology overrides.
504
- * @param replaceExisting Specifies whether to replace a pre-existing override for the same subcategory.
505
- * @note These overrides have lower priority than element and model overrides.
506
- * @note If [[defaultOverrides]] are defined, they will not apply to any geometry within this subcategory, even if the supplied appearance overrides nothing.
507
- * @deprecated in 3.x. Use [[FeatureOverrides.override]].
508
- */
509
- overrideSubCategory(id, app, replaceExisting = true) {
510
- this.override({ subCategoryId: id, appearance: app, onConflict: replaceExisting ? "replace" : "skip" });
511
- }
512
- /** Specify overrides for all geometry originating from the specified element.
513
- * @param id The Id of the element.
514
- * @param app The symbology overrides.
515
- * @param replaceExisting Specifies whether to replace a pre-existing override for the same element.
516
- * @note These overrides take precedence over subcategory overrides, but not over model overrides.
517
- * @note If [[defaultOverrides]] are defined, they will not apply to this element, even if the supplied appearance overrides nothing.
518
- * @deprecated in 3.x. Use [[FeatureOverrides.override]].
519
- */
520
- overrideElement(id, app, replaceExisting = true) {
521
- this.override({ elementId: id, appearance: app, onConflict: replaceExisting ? "replace" : "skip" });
522
- }
523
- /** Specify overrides for all geometry originating from the specified animation node.
524
- * @param id The Id of the animation node.
525
- * @param app The symbology overrides.
526
- * @note These overrides do not take precedence over element overrides.
527
- */
528
- overrideAnimationNode(id, app) {
529
- this.animationNodeOverrides.set(id, app);
530
- }
531
- /** Defines a default appearance to be applied to any [[Feature]] *not* explicitly overridden.
532
- * @param appearance The symbology overrides.
533
- * @param replaceExisting Specifies whether to replace the current default overrides if they are already defined.
534
- */
535
- setDefaultOverrides(appearance, replaceExisting = true) {
536
- if (replaceExisting || !appearance.overridesSymbology)
537
- this._defaultOverrides = appearance;
538
- }
539
- /** Get the display priority of a subcategory. This is only relevant when using [[PlanProjectionSettings]].
540
- * @internal
541
- */
542
- getSubCategoryPriority(idLo, idHi) {
543
- var _a;
544
- return (_a = this._subCategoryPriorities.get(idLo, idHi)) !== null && _a !== void 0 ? _a : 0;
545
- }
546
- /** Returns true if geometry belonging to the specified subcategory will be drawn. */
547
- isSubCategoryIdVisible(id) { return this.isSubCategoryVisible(Id64.getLowerUint32(id), Id64.getUpperUint32(id)); }
548
- /** Returns the overrides applied to geometry belonging to the specified model, if any such are defined. */
549
- getModelOverridesById(id) { return this.getModelOverrides(Id64.getLowerUint32(id), Id64.getUpperUint32(id)); }
550
- /** Returns the overrides applied to geometry belonging to the specified element, if any such are defined. */
551
- getElementOverridesById(id) { return this.getElementOverrides(Id64.getLowerUint32(id), Id64.getUpperUint32(id), 0); }
552
- /** Returns the overrides applied to geometry belonging to the specified subcategory, if any such are defined. */
553
- getSubCategoryOverridesById(id) { return this.getSubCategoryOverrides(Id64.getLowerUint32(id), Id64.getUpperUint32(id)); }
554
- /** Returns true if the specified Feature will be drawn. */
555
- isFeatureVisible(feature) {
556
- const { elementId, subCategoryId, geometryClass } = feature;
557
- const isValidElemId = !Id64.isInvalid(elementId);
558
- const elemIdParts = isValidElemId ? Id64.getUint32Pair(elementId) : undefined;
559
- if (undefined !== elemIdParts && this.isNeverDrawn(elemIdParts.lower, elemIdParts.upper, 0))
560
- return false;
561
- const alwaysDrawn = undefined !== elemIdParts && this.isAlwaysDrawn(elemIdParts.lower, elemIdParts.upper);
562
- if (alwaysDrawn || this.isAlwaysDrawnExclusive)
563
- return alwaysDrawn;
564
- // NB: This ignores per-model subcategory visibility overrides, because caller did not specify a model.
565
- if (!this.isSubCategoryIdVisible(subCategoryId))
566
- return false;
567
- return this.isClassVisible(geometryClass);
568
- }
569
- }
570
- FeatureOverrides._weight1Appearance = FeatureAppearance.fromJSON({ weight: 1 });
571
- /** @public */
572
- export var FeatureAppearanceProvider;
573
- (function (FeatureAppearanceProvider) {
574
- /** Produce a FeatureAppearanceSource for which `getAppearance()` returns the appearance specified in `source`, potentially modified by `provider`. */
575
- function wrap(source, provider) {
576
- return {
577
- getAppearance: (elemLo, elemHi, subcatLo, subcatHi, geomClass, modelLo, modelHi, type, animationNodeId) => {
578
- return provider.getFeatureAppearance(source, elemLo, elemHi, subcatLo, subcatHi, geomClass, modelLo, modelHi, type, animationNodeId);
579
- },
580
- };
581
- }
582
- /** Create a provider that obtains each feature's appearance from the source, and if the feature is visible, modifies the appearance.
583
- * @param supplementAppearance A function accepting the feature's base appearance and returning a supplemental appearance.
584
- * @public
585
- */
586
- function supplement(supplementAppearance) {
587
- return {
588
- getFeatureAppearance: (source, elemLo, elemHi, subcatLo, subcatHi, geomClass, modelLo, modelHi, type, animationNodeId) => {
589
- const app = source.getAppearance(elemLo, elemHi, subcatLo, subcatHi, geomClass, modelLo, modelHi, type, animationNodeId);
590
- return app ? supplementAppearance(app) : app;
591
- },
592
- };
593
- }
594
- FeatureAppearanceProvider.supplement = supplement;
595
- /** Chain two FeatureAppearanceProviders together such that `first`'s `getFeatureAppearance` function is applied before `second`'s.
596
- * If `second` invokes `source.getAppearance()`, the returned appearance will include any modifications applied by `first`.
597
- * @public
598
- */
599
- function chain(first, second) {
600
- if (first === second)
601
- return first;
602
- return {
603
- getFeatureAppearance: (source, elemLo, elemHi, subcatLo, subcatHi, geomClass, modelLo, modelHi, type, animationNodeId) => {
604
- return second.getFeatureAppearance(wrap(source, first), elemLo, elemHi, subcatLo, subcatHi, geomClass, modelLo, modelHi, type, animationNodeId);
605
- },
606
- };
607
- }
608
- FeatureAppearanceProvider.chain = chain;
609
- })(FeatureAppearanceProvider || (FeatureAppearanceProvider = {}));
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
+ * See LICENSE.md in the project root for license terms and full copyright notice.
4
+ *--------------------------------------------------------------------------------------------*/
5
+ /** @packageDocumentation
6
+ * @module Rendering
7
+ */
8
+ import { assert, Id64 } from "@itwin/core-bentley";
9
+ import { BatchType } from "./FeatureTable";
10
+ import { GeometryClass } from "./GeometryParams";
11
+ import { RgbColor } from "./RgbColor";
12
+ function copyIdSetToUint32Set(dst, src) {
13
+ dst.clear();
14
+ if (typeof src === "string") {
15
+ dst.addId(src);
16
+ }
17
+ else {
18
+ for (const id of src)
19
+ dst.addId(id);
20
+ }
21
+ }
22
+ /** Defines overrides for selected aspects of a [[Feature]]'s symbology.
23
+ * Any member defined in the appearance overrides that aspect of symbology for all [[Feature]]s to which the appearance is applied.
24
+ * @see [[FeatureOverrides]] to customize the appearance of multiple features.
25
+ * @public
26
+ */
27
+ class FeatureAppearance {
28
+ static fromJSON(props) {
29
+ if (undefined === props || (undefined === props.rgb && undefined === props.weight && undefined === props.transparency && undefined === props.linePixels && !props.ignoresMaterial && !props.nonLocatable && !props.emphasized))
30
+ return this.defaults;
31
+ else
32
+ return new FeatureAppearance(props);
33
+ }
34
+ /** Create a FeatureAppearance that overrides only the RGB color.
35
+ * @note The transparency component of the ColorDef is ignored.
36
+ */
37
+ static fromRgb(color) {
38
+ return this.fromJSON({ rgb: RgbColor.fromColorDef(color) });
39
+ }
40
+ /** Create a FeatureAppearance that overrides the RGB and transparency.
41
+ * The appearance's transparency is derived from the transparency component of the ColorDef.
42
+ */
43
+ static fromRgba(color, viewDependentTransparency = false) {
44
+ return this.fromJSON({
45
+ rgb: RgbColor.fromColorDef(color),
46
+ transparency: color.colors.t / 255,
47
+ viewDependentTransparency: viewDependentTransparency ? true : undefined,
48
+ });
49
+ }
50
+ /** Create a FeatureAppearance that overrides only the transparency */
51
+ static fromTransparency(transparencyValue, viewDependent = false) {
52
+ return this.fromJSON({
53
+ transparency: transparencyValue,
54
+ viewDependentTransparency: viewDependent ? true : undefined,
55
+ });
56
+ }
57
+ /** Create a FeatureAppearance with overrides corresponding to those defined by the supplied SubCategoryOverride.
58
+ * @note Subcategory overrides set [[viewDependentTransparency]] to `true`.
59
+ */
60
+ static fromSubCategoryOverride(ovr) {
61
+ const rgb = undefined !== ovr.color ? RgbColor.fromColorDef(ovr.color) : undefined;
62
+ const transparency = ovr.transparency;
63
+ const weight = ovr.weight;
64
+ const ignoresMaterial = undefined !== ovr.material && Id64.isValid(ovr.material) ? true : undefined;
65
+ return this.fromJSON({ rgb, transparency, weight, ignoresMaterial, viewDependentTransparency: true });
66
+ }
67
+ /** Returns true if this appearance does not override any aspects of symbology. */
68
+ get matchesDefaults() {
69
+ return this.equals(FeatureAppearance.defaults);
70
+ }
71
+ get overridesRgb() { return undefined !== this.rgb; }
72
+ get overridesTransparency() { return undefined !== this.transparency; }
73
+ get overridesLinePixels() { return undefined !== this.linePixels; }
74
+ get overridesWeight() { return undefined !== this.weight; }
75
+ get overridesSymbology() {
76
+ return this.overridesRgb || this.overridesTransparency || this.overridesWeight || this.overridesLinePixels || !!this.ignoresMaterial
77
+ || this.emphasized || this.overridesNonLocatable;
78
+ }
79
+ get overridesNonLocatable() { return undefined !== this.nonLocatable; }
80
+ get isFullyTransparent() { return undefined !== this.transparency && this.transparency >= 1.0; }
81
+ /** Returns true if any aspect of the appearance is overridden (i.e., if any member is not undefined). */
82
+ get anyOverridden() { return this.overridesSymbology || this.overridesNonLocatable; }
83
+ equals(other) {
84
+ if (this === other)
85
+ return true;
86
+ return this.rgbIsEqual(other.rgb)
87
+ && this.weight === other.weight
88
+ && this.transparencyIsEqual(other.transparency)
89
+ && this.linePixels === other.linePixels
90
+ && this.ignoresMaterial === other.ignoresMaterial
91
+ && this.nonLocatable === other.nonLocatable
92
+ && this.emphasized === other.emphasized
93
+ && this.viewDependentTransparency === other.viewDependentTransparency;
94
+ }
95
+ toJSON() {
96
+ const props = {};
97
+ if (this.rgb)
98
+ props.rgb = this.rgb.toJSON();
99
+ if (undefined !== this.weight)
100
+ props.weight = this.weight;
101
+ if (undefined !== this.transparency) {
102
+ props.transparency = this.transparency;
103
+ if (this.viewDependentTransparency)
104
+ props.viewDependentTransparency = true;
105
+ }
106
+ if (undefined !== this.linePixels)
107
+ props.linePixels = this.linePixels;
108
+ if (true === this.ignoresMaterial)
109
+ props.ignoresMaterial = true;
110
+ if (true === this.nonLocatable)
111
+ props.nonLocatable = true;
112
+ if (true === this.emphasized)
113
+ props.emphasized = true;
114
+ return props;
115
+ }
116
+ /** Convert this appearance to JSON, and override any properties explicitly specified by `changedProps` in the result.
117
+ * Example:
118
+ * ```ts
119
+ * const base = FeatureAppearance.fromRgba(ColorDef.white); // transparency=0, rgb=white
120
+ * const clone = base.cloneProps({ transparency: undefined, weight: 5 }); // transparency=undefined, rgb=white, weight=5
121
+ * ```
122
+ * @see [[FeatureAppearance.clone]].
123
+ */
124
+ cloneProps(changedProps) {
125
+ return {
126
+ ...this.toJSON(),
127
+ ...changedProps,
128
+ };
129
+ }
130
+ /** Create a copy of this appearance, overriding any properties explicitly specified by `changedProps`.
131
+ * Example:
132
+ * ```ts
133
+ * const base = FeatureAppearance.fromRgba(ColorDef.white); // transparency=0, rgb=white
134
+ * const clone = base.clone({ transparency: undefined, weight: 5 }); // transparency=undefined, rgb=white, weight=5
135
+ * ```
136
+ * @see [[FeatureAppearance.cloneProps]].
137
+ */
138
+ clone(changedProps) {
139
+ return FeatureAppearance.fromJSON(this.cloneProps(changedProps));
140
+ }
141
+ /** Produce a FeatureAppearance from the supplied appearance in which any aspect not defined by the base appearance is overridden by this appearance. */
142
+ extendAppearance(base) {
143
+ if (!this.overridesSymbology)
144
+ return base;
145
+ const props = base.toJSON();
146
+ if (undefined === props.rgb)
147
+ props.rgb = this.rgb;
148
+ if (undefined === props.transparency)
149
+ props.transparency = this.transparency;
150
+ if (undefined === props.linePixels)
151
+ props.linePixels = this.linePixels;
152
+ if (undefined === props.weight)
153
+ props.weight = this.weight;
154
+ if (undefined === props.ignoresMaterial && this.ignoresMaterial)
155
+ props.ignoresMaterial = true;
156
+ if (undefined === props.nonLocatable && this.nonLocatable)
157
+ props.nonLocatable = true;
158
+ if (undefined === props.emphasized && this.emphasized)
159
+ props.emphasized = true;
160
+ if (undefined !== props.transparency && this.viewDependentTransparency)
161
+ props.viewDependentTransparency = true;
162
+ return FeatureAppearance.fromJSON(props);
163
+ }
164
+ constructor(props) {
165
+ this.rgb = undefined !== props.rgb ? RgbColor.fromJSON(props.rgb) : undefined;
166
+ this.weight = props.weight;
167
+ this.transparency = props.transparency;
168
+ this.linePixels = props.linePixels;
169
+ this.ignoresMaterial = props.ignoresMaterial;
170
+ this.nonLocatable = props.nonLocatable;
171
+ this.emphasized = props.emphasized;
172
+ if (undefined !== this.weight)
173
+ this.weight = Math.max(1, Math.min(this.weight, 32));
174
+ if (undefined !== this.transparency) {
175
+ if (props.viewDependentTransparency)
176
+ this.viewDependentTransparency = true;
177
+ this.transparency = Math.max(0, Math.min(this.transparency, 1));
178
+ // Fix up rounding errors...
179
+ const smallDelta = 0.0001;
180
+ if (1.0 - this.transparency < smallDelta)
181
+ this.transparency = 1.0;
182
+ else if (this.transparency < smallDelta)
183
+ this.transparency = 0.0;
184
+ }
185
+ }
186
+ rgbIsEqual(rgb) {
187
+ if (undefined === this.rgb)
188
+ return undefined === rgb;
189
+ else if (undefined === rgb)
190
+ return false;
191
+ else
192
+ return this.rgb.equals(rgb);
193
+ }
194
+ transparencyIsEqual(transp) {
195
+ if (undefined === this.transparency)
196
+ return undefined === transp;
197
+ else if (undefined === transp)
198
+ return false;
199
+ else
200
+ return Math.floor(this.transparency * 0xff) === Math.floor(transp * 0xff);
201
+ }
202
+ }
203
+ /** An appearance that overrides nothing. */
204
+ FeatureAppearance.defaults = new FeatureAppearance({});
205
+ export { FeatureAppearance };
206
+ const scratchIgnoreAnimationOverridesArgs = {
207
+ elementId: { lower: 0, upper: 0 },
208
+ animationNodeId: 0,
209
+ };
210
+ /** Specifies how to customize the appearance of individual [[Feature]]s, typically within the context of a [Viewport]($frontend).
211
+ * Individual aspects of a feature's appearance - like visibility, color, and transparency - are overridden by supplying a [[FeatureAppearance]].
212
+ * Those overrides can be specified on the basis of the feature's model, element, and/or subcategory. A default set of overrides can also be specified to
213
+ * apply to the appearance of any feature not otherwise overridden.
214
+ *
215
+ * It is possible to override multiple aspects of a feature on different bases. For example, you might specify that all features belonging to subcategory "A" should be drawn in red,
216
+ * and that all features belonging to model "B" should be drawn 50% transparent. In this case, a feature belonging to both subcategory "A" and model "B" will be drawn as 50% transparent red -
217
+ * the separate overrides are combined to produce the feature's overall appearance.
218
+ *
219
+ * In the case of conflicts, there is an order of precedence:
220
+ * - Model overrides take highest precedence.
221
+ * - Element overrides are of higher precedence than subcategory and animation overrides.
222
+ * - Overrides applied by a [[RenderSchedule.Script]]'s [[RenderSchedule.ElementTimeline]] are of higher precedence than subcategory overrides, but can be suppressed on a per-element basis via [[ignoreAnimationOverrides]].
223
+ * - Subcategory overrides have lowest precedence.
224
+ *
225
+ * For example, you might specify that all features belonging to subcategory "A" should be drawn in red, and all those belonging to model "B" should be drawn in green.
226
+ * Then a feature belonging to subcategory "A" and model "B" will be drawn in green, because the model overrides take precedence.
227
+ *
228
+ * Instances of this class are not typically instantiated by an application directly; instead, an application can implement a [FeatureOverrideProvider]($frontend)
229
+ * that augments the overrides supplied by a viewport.
230
+ *
231
+ * @see [FeatureSymbology.Overrides]($frontend) to create overrides specific to a [Viewport]($frontend) or [ViewState]($frontend).
232
+ * @see [FeatureOverrideProvider]($frontend) to customize the appearance of features within a [Viewport]($frontend).
233
+ * @public
234
+ */
235
+ class FeatureOverrides {
236
+ /** Accepts a criterion that determines whether color and transparency overrides originating from the view's [[RenderSchedule.Script]] should be ignored for a given element.
237
+ * The function receives a description of the element in question and returns `true` if the script's overrides should be ignored.
238
+ * Any number of such functions can be registered; if any one of them returns `true`, the script's overrides are not applied to the specified element.
239
+ *
240
+ * For example, applications commonly emphasize a set of elements by applying a [[FeatureAppearance.emphasized]] override to them, and specifying a highly-transparent
241
+ * default appearance to de-emphasize the rest of the elements in the view. If some of the de-emphasized elements' appearances are also being overridden by the schedule script, then
242
+ * they won't appear de-emphasized, making it difficult for the emphasized elements to stand out. In situations like this, [FeatureOverrideProvider]($frontend)s like [EmphasizeElements]($frontend) can register an [[IgnoreAnimationOverrides]] function that returns true if the element in question is not in the set of emphasized elements.
243
+ */
244
+ ignoreAnimationOverrides(ignore) {
245
+ this._ignoreAnimationOverrides.push(ignore);
246
+ }
247
+ /** Overrides applied to features for which no other overrides are defined */
248
+ get defaultOverrides() { return this._defaultOverrides; }
249
+ /** Whether or not line weights are applied. If false, all lines are drawn with a weight of 1. */
250
+ get lineWeights() { return this._lineWeights; }
251
+ /** A set of elements that are always invisible.
252
+ * @note If an element is present in both `alwaysDrawn` and [[neverDrawn]], it will not be displayed - `neverDrawn` takes precedence.
253
+ */
254
+ get neverDrawn() { return this._neverDrawn; }
255
+ /** A set of elements that are unconditionally displayed.
256
+ * @see [[isAlwaysDrawnExclusive]] to specify that *only* elements in this set will be displayed.
257
+ * @note If an element is present in both `alwaysDrawn` and [[neverDrawn]], it will not be displayed - `neverDrawn` takes precedence.
258
+ */
259
+ get alwaysDrawn() { return this._alwaysDrawn; }
260
+ /** @internal */
261
+ isNeverDrawn(elemIdLo, elemIdHi, animationNodeId) {
262
+ if (this._neverDrawn.has(elemIdLo, elemIdHi))
263
+ return true;
264
+ else
265
+ return this.neverDrawnAnimationNodes.has(animationNodeId);
266
+ }
267
+ /** @internal */
268
+ isAlwaysDrawn(idLo, idHi) { return this._alwaysDrawn.has(idLo, idHi); }
269
+ /** Returns true if the [SubCategory]($backend) specified by Id is in the set of visible subcategories. @internal */
270
+ isSubCategoryVisible(idLo, idHi) { return this._visibleSubCategories.has(idLo, idHi); }
271
+ /** @internal */
272
+ isSubCategoryVisibleInModel(subcatLo, subcatHi, modelLo, modelHi) {
273
+ if (this.ignoreSubCategory)
274
+ return true;
275
+ let vis = this.isSubCategoryVisible(subcatLo, subcatHi);
276
+ const modelOvr = this._modelSubCategoryOverrides.get(modelLo, modelHi);
277
+ if (undefined !== modelOvr && modelOvr.has(subcatLo, subcatHi))
278
+ vis = !vis;
279
+ return vis;
280
+ }
281
+ /** @internal */
282
+ getModelOverrides(idLo, idHi) {
283
+ return this._modelOverrides.get(idLo, idHi);
284
+ }
285
+ getElementAnimationOverrides(idLo, idHi, animationNodeId) {
286
+ if (this.animationNodeOverrides.size === 0)
287
+ return undefined;
288
+ // NB: An animation node Id of zero means "not animated". Some providers like EmphasizeElements may provide an appearance override for unanimated nodes.
289
+ // That should be preserved.
290
+ const app = this.animationNodeOverrides.get(animationNodeId);
291
+ if (!app || 0 === animationNodeId || this._ignoreAnimationOverrides.length === 0)
292
+ return app;
293
+ const args = scratchIgnoreAnimationOverridesArgs;
294
+ args.elementId.lower = idLo;
295
+ args.elementId.upper = idHi;
296
+ args.animationNodeId = animationNodeId;
297
+ return this._ignoreAnimationOverrides.some((ignore) => ignore(args)) ? undefined : app;
298
+ }
299
+ /** @internal */
300
+ getElementOverrides(idLo, idHi, animationNodeId) {
301
+ const elemApp = this._elementOverrides.get(idLo, idHi);
302
+ const nodeApp = this.getElementAnimationOverrides(idLo, idHi, animationNodeId);
303
+ if (elemApp)
304
+ return nodeApp ? nodeApp.extendAppearance(elemApp) : elemApp;
305
+ return nodeApp;
306
+ }
307
+ /** @internal */
308
+ getSubCategoryOverrides(idLo, idHi) { return this._subCategoryOverrides.get(idLo, idHi); }
309
+ /** Add a [SubCategory]($backend) to the set of visible subcategories. */
310
+ setVisibleSubCategory(id) { this._visibleSubCategories.addId(id); }
311
+ /** Specify the Id of an element that should never be drawn. */
312
+ setNeverDrawn(id) { this._neverDrawn.addId(id); }
313
+ /** Specify the Id of an element that should always be drawn. */
314
+ setAlwaysDrawn(id) { this._alwaysDrawn.addId(id); }
315
+ /** Specify the Id of a animation node that should never be drawn. */
316
+ setAnimationNodeNeverDrawn(id) { this.neverDrawnAnimationNodes.add(id); }
317
+ /** Specify the Ids of elements that should never be drawn. */
318
+ setNeverDrawnSet(ids) { copyIdSetToUint32Set(this._neverDrawn, ids); }
319
+ /** Specify the Ids of elements that should always be drawn. */
320
+ setAlwaysDrawnSet(ids, exclusive, ignoreSubCategory = true) {
321
+ copyIdSetToUint32Set(this._alwaysDrawn, ids);
322
+ this.isAlwaysDrawnExclusive = exclusive;
323
+ this.alwaysDrawnIgnoresSubCategory = ignoreSubCategory;
324
+ }
325
+ /** Returns the feature's appearance overrides, or undefined if the feature is not visible. */
326
+ getFeatureAppearance(feature, modelId, type = BatchType.Primary, animationNodeId = 0) {
327
+ return this.getAppearance(Id64.getLowerUint32(feature.elementId), Id64.getUpperUint32(feature.elementId), Id64.getLowerUint32(feature.subCategoryId), Id64.getUpperUint32(feature.subCategoryId), feature.geometryClass, Id64.getLowerUint32(modelId), Id64.getUpperUint32(modelId), type, animationNodeId);
328
+ }
329
+ /** Returns a feature's appearance overrides, or undefined if the feature is not visible.
330
+ * Takes Id64s as pairs of unsigned 32-bit integers for efficiency, because that is how they are stored by the PackedFeatureTable associated with each batch of graphics.
331
+ * @see [[getFeatureAppearance]] for an equivalent function that accepts [Id64String]($core-bentley)s instead of integer pairs.
332
+ */
333
+ getAppearance(elemLo, elemHi, subcatLo, subcatHi, geomClass, modelLo, modelHi, type, animationNodeId) {
334
+ if (BatchType.VolumeClassifier === type || BatchType.PlanarClassifier === type)
335
+ return this.getClassifierAppearance(elemLo, elemHi, subcatLo, subcatHi, modelLo, modelHi, animationNodeId);
336
+ let app = !this._lineWeights ? FeatureOverrides._weight1Appearance : FeatureAppearance.defaults;
337
+ const modelApp = this.getModelOverrides(modelLo, modelHi);
338
+ if (undefined !== modelApp)
339
+ app = modelApp.extendAppearance(app);
340
+ // Is the element visible?
341
+ let elemApp, alwaysDrawn = false;
342
+ if (Id64.isValidUint32Pair(elemLo, elemHi)) {
343
+ if (this.isNeverDrawn(elemLo, elemHi, animationNodeId))
344
+ return undefined;
345
+ alwaysDrawn = this.isAlwaysDrawn(elemLo, elemHi);
346
+ if (!alwaysDrawn && this.isAlwaysDrawnExclusive)
347
+ return undefined;
348
+ // Element overrides take precedence
349
+ elemApp = this.getElementOverrides(elemLo, elemHi, animationNodeId);
350
+ if (undefined !== elemApp)
351
+ app = undefined !== modelApp ? elemApp.extendAppearance(app) : elemApp;
352
+ }
353
+ let subCatApp;
354
+ if (!this.ignoreSubCategory && Id64.isValidUint32Pair(subcatLo, subcatHi)) {
355
+ if ((!alwaysDrawn || !this.alwaysDrawnIgnoresSubCategory) && !this.isSubCategoryVisibleInModel(subcatLo, subcatHi, modelLo, modelHi))
356
+ return undefined;
357
+ subCatApp = this.getSubCategoryOverrides(subcatLo, subcatHi);
358
+ if (undefined !== subCatApp)
359
+ app = subCatApp.extendAppearance(app);
360
+ }
361
+ // Only apply default if *no* appearance was explicitly registered (doesn't matter if registered appearance does not actually override anything)
362
+ if (undefined === elemApp && undefined === modelApp && undefined === subCatApp)
363
+ app = this._defaultOverrides.extendAppearance(app);
364
+ let visible = alwaysDrawn || this.isClassVisible(geomClass);
365
+ if (visible && app.isFullyTransparent)
366
+ visible = false; // don't bother rendering something with full transparency...
367
+ return visible ? app : undefined;
368
+ }
369
+ /** Classifiers behave totally differently...in particular they are never invisible unless fully-transparent.
370
+ * @internal
371
+ */
372
+ getClassifierAppearance(elemLo, elemHi, subcatLo, subcatHi, modelLo, modelHi, animationNodeId) {
373
+ let app = FeatureAppearance.defaults;
374
+ const modelApp = this.getModelOverrides(modelLo, modelHi);
375
+ if (undefined !== modelApp)
376
+ app = modelApp.extendAppearance(app);
377
+ const elemApp = this.getElementOverrides(elemLo, elemHi, animationNodeId);
378
+ if (undefined !== elemApp)
379
+ app = undefined !== modelApp ? elemApp.extendAppearance(app) : elemApp;
380
+ if (!this.ignoreSubCategory && Id64.isValidUint32Pair(subcatLo, subcatHi)) {
381
+ const subCat = this.getSubCategoryOverrides(subcatLo, subcatHi);
382
+ if (undefined !== subCat)
383
+ app = subCat.extendAppearance(app);
384
+ }
385
+ if (undefined === elemApp && undefined === modelApp)
386
+ app = this._defaultOverrides.extendAppearance(app);
387
+ // NB: A fully-transparent classifier means the classifier is a clip mask - classified pixels will be discarded.
388
+ return app;
389
+ }
390
+ /** Return whether geometry of the specified class should be drawn.
391
+ * @see [[ViewFlags.constructions]], [[ViewFlags.dimensions]], and [[ViewFlags.patterns]].
392
+ */
393
+ isClassVisible(geomClass) {
394
+ switch (geomClass) {
395
+ case GeometryClass.Construction: return this._constructions;
396
+ case GeometryClass.Dimension: return this._dimensions;
397
+ case GeometryClass.Pattern: return this._patterns;
398
+ default: return true;
399
+ }
400
+ }
401
+ /** Specify overrides for all elements belonging to a specified [GeometricModel]($backend), or all geometry belonging to a specified [GeometricElement]($backend) or [SubCategory]($backend). */
402
+ override(args) {
403
+ let id;
404
+ let map;
405
+ if (undefined !== args.elementId) {
406
+ id = args.elementId;
407
+ map = this._elementOverrides;
408
+ }
409
+ else if (undefined !== args.modelId) {
410
+ id = args.modelId;
411
+ map = this._modelOverrides;
412
+ }
413
+ else {
414
+ id = args.subCategoryId;
415
+ map = this._subCategoryOverrides;
416
+ }
417
+ let app = args.appearance;
418
+ const idLo = Id64.getLowerUint32(id);
419
+ const idHi = Id64.getUpperUint32(id);
420
+ if (undefined !== args.elementId && this.isNeverDrawn(idLo, idHi, 0))
421
+ return;
422
+ const replace = "replace" === args.onConflict;
423
+ const existing = replace ? undefined : map.get(idLo, idHi);
424
+ if (existing) {
425
+ assert("replace" !== args.onConflict);
426
+ switch (args.onConflict) {
427
+ case "skip":
428
+ return;
429
+ case "extend":
430
+ app = app.extendAppearance(existing);
431
+ break;
432
+ default:
433
+ app = existing.extendAppearance(app);
434
+ break;
435
+ }
436
+ }
437
+ map.set(idLo, idHi, app);
438
+ }
439
+ /** Specify overrides for all elements within the specified model.
440
+ * @param id The Id of the model.
441
+ * @param app The symbology overrides.
442
+ * @param replaceExisting Specifies whether to replace a pre-existing override for the same model.
443
+ * @note These overrides take priority over all other overrides.
444
+ * @note If [[defaultOverrides]] are defined, they will not apply to any element within this model, even if the supplied appearance overrides nothing.
445
+ * @deprecated in 3.x. Use [[FeatureOverrides.override]].
446
+ */
447
+ overrideModel(id, app, replaceExisting = true) {
448
+ this.override({ modelId: id, appearance: app, onConflict: replaceExisting ? "replace" : "skip" });
449
+ }
450
+ /** Specify overrides for all geometry belonging to the specified [SubCategory]($backend).
451
+ * @param id The Id of the subcategory.
452
+ * @param app The symbology overrides.
453
+ * @param replaceExisting Specifies whether to replace a pre-existing override for the same subcategory.
454
+ * @note These overrides have lower priority than element and model overrides.
455
+ * @note If [[defaultOverrides]] are defined, they will not apply to any geometry within this subcategory, even if the supplied appearance overrides nothing.
456
+ * @deprecated in 3.x. Use [[FeatureOverrides.override]].
457
+ */
458
+ overrideSubCategory(id, app, replaceExisting = true) {
459
+ this.override({ subCategoryId: id, appearance: app, onConflict: replaceExisting ? "replace" : "skip" });
460
+ }
461
+ /** Specify overrides for all geometry originating from the specified element.
462
+ * @param id The Id of the element.
463
+ * @param app The symbology overrides.
464
+ * @param replaceExisting Specifies whether to replace a pre-existing override for the same element.
465
+ * @note These overrides take precedence over subcategory overrides, but not over model overrides.
466
+ * @note If [[defaultOverrides]] are defined, they will not apply to this element, even if the supplied appearance overrides nothing.
467
+ * @deprecated in 3.x. Use [[FeatureOverrides.override]].
468
+ */
469
+ overrideElement(id, app, replaceExisting = true) {
470
+ this.override({ elementId: id, appearance: app, onConflict: replaceExisting ? "replace" : "skip" });
471
+ }
472
+ /** Specify overrides for all geometry originating from the specified animation node.
473
+ * @param id The Id of the animation node.
474
+ * @param app The symbology overrides.
475
+ * @note These overrides do not take precedence over element overrides.
476
+ */
477
+ overrideAnimationNode(id, app) {
478
+ this.animationNodeOverrides.set(id, app);
479
+ }
480
+ /** Defines a default appearance to be applied to any [[Feature]] *not* explicitly overridden.
481
+ * @param appearance The symbology overrides.
482
+ * @param replaceExisting Specifies whether to replace the current default overrides if they are already defined.
483
+ */
484
+ setDefaultOverrides(appearance, replaceExisting = true) {
485
+ if (replaceExisting || !appearance.overridesSymbology)
486
+ this._defaultOverrides = appearance;
487
+ }
488
+ /** Get the display priority of a subcategory. This is only relevant when using [[PlanProjectionSettings]].
489
+ * @internal
490
+ */
491
+ getSubCategoryPriority(idLo, idHi) {
492
+ return this._subCategoryPriorities.get(idLo, idHi) ?? 0;
493
+ }
494
+ /** Construct a new Overrides that overrides nothing.
495
+ * @see [FeatureSymbology.Overrides]($frontend) to construct overrides based on a [ViewState]($frontend) or [Viewport]($frontend).
496
+ */
497
+ constructor() {
498
+ /** @internal */
499
+ this._ignoreAnimationOverrides = [];
500
+ /** Ids of elements that should never be drawn. This takes precedence over [[alwaysDrawn]]. @internal */
501
+ this._neverDrawn = new Id64.Uint32Set();
502
+ /** Ids of elements that should always be drawn. [[neverDrawn]] takes precedence over this set. @internal */
503
+ this._alwaysDrawn = new Id64.Uint32Set();
504
+ /** If true, no elements *except* those defined in the "always drawn" set will be drawn.
505
+ * @see [[setAlwaysDrawn]]
506
+ */
507
+ this.isAlwaysDrawnExclusive = false;
508
+ /** If true, the always-drawn elements are drawn even if their subcategories are not visible.
509
+ * @see [[setAlwaysDrawn]]
510
+ */
511
+ this.alwaysDrawnIgnoresSubCategory = true;
512
+ /** If true, all subcategories are considered visible. This is used for drawing sheets via section callouts in the absence of an actual sheet view.
513
+ * @internal
514
+ */
515
+ this.ignoreSubCategory = false;
516
+ /** Overrides applied to any feature not explicitly overridden. @internal */
517
+ this._defaultOverrides = FeatureAppearance.defaults;
518
+ /** Whether construction geometry should be drawn. @internal */
519
+ this._constructions = false;
520
+ /** Whether dimensions should be drawn. @internal */
521
+ this._dimensions = false;
522
+ /** Whether area patterns should be drawn. @internal */
523
+ this._patterns = false;
524
+ /** Whether line weights should be applied. If false, all lines are rendered 1-pixel wide. @internal */
525
+ this._lineWeights = true;
526
+ /** Overrides applied to all elements belonging to each model. @internal */
527
+ this._modelOverrides = new Id64.Uint32Map();
528
+ /** Overrides applied to specific elements. @internal */
529
+ this._elementOverrides = new Id64.Uint32Map();
530
+ /** Overrides applied to geometry belonging to each subcategory. @internal */
531
+ this._subCategoryOverrides = new Id64.Uint32Map();
532
+ /** The set of displayed subcategories. Geometry belonging to subcategories not included in this set will not be drawn. @internal */
533
+ this._visibleSubCategories = new Id64.Uint32Set();
534
+ /** Display priorities assigned to subcategories, possibly overridden by display style. Only applicable for plan projection models. @internal */
535
+ this._subCategoryPriorities = new Id64.Uint32Map();
536
+ /** Per-model, a set of subcategories whose visibility should be inverted for elements within that model.
537
+ * Populated by Viewport.
538
+ * @internal
539
+ */
540
+ this._modelSubCategoryOverrides = new Id64.Uint32Map();
541
+ /** Ids of animation nodes that should never be drawn.
542
+ * @internal
543
+ */
544
+ this.neverDrawnAnimationNodes = new Set();
545
+ /** Mapping of animation node Ids to overrides applied to the corresponding animation nodes.
546
+ * @internal
547
+ */
548
+ this.animationNodeOverrides = new Map();
549
+ //
550
+ }
551
+ /** Returns true if geometry belonging to the specified subcategory will be drawn. */
552
+ isSubCategoryIdVisible(id) { return this.isSubCategoryVisible(Id64.getLowerUint32(id), Id64.getUpperUint32(id)); }
553
+ /** Returns the overrides applied to geometry belonging to the specified model, if any such are defined. */
554
+ getModelOverridesById(id) { return this.getModelOverrides(Id64.getLowerUint32(id), Id64.getUpperUint32(id)); }
555
+ /** Returns the overrides applied to geometry belonging to the specified element, if any such are defined. */
556
+ getElementOverridesById(id) { return this.getElementOverrides(Id64.getLowerUint32(id), Id64.getUpperUint32(id), 0); }
557
+ /** Returns the overrides applied to geometry belonging to the specified subcategory, if any such are defined. */
558
+ getSubCategoryOverridesById(id) { return this.getSubCategoryOverrides(Id64.getLowerUint32(id), Id64.getUpperUint32(id)); }
559
+ /** Returns true if the specified Feature will be drawn. */
560
+ isFeatureVisible(feature) {
561
+ const { elementId, subCategoryId, geometryClass } = feature;
562
+ const isValidElemId = !Id64.isInvalid(elementId);
563
+ const elemIdParts = isValidElemId ? Id64.getUint32Pair(elementId) : undefined;
564
+ if (undefined !== elemIdParts && this.isNeverDrawn(elemIdParts.lower, elemIdParts.upper, 0))
565
+ return false;
566
+ const alwaysDrawn = undefined !== elemIdParts && this.isAlwaysDrawn(elemIdParts.lower, elemIdParts.upper);
567
+ if (alwaysDrawn || this.isAlwaysDrawnExclusive)
568
+ return alwaysDrawn;
569
+ // NB: This ignores per-model subcategory visibility overrides, because caller did not specify a model.
570
+ if (!this.isSubCategoryIdVisible(subCategoryId))
571
+ return false;
572
+ return this.isClassVisible(geometryClass);
573
+ }
574
+ }
575
+ FeatureOverrides._weight1Appearance = FeatureAppearance.fromJSON({ weight: 1 });
576
+ export { FeatureOverrides };
577
+ /** @public */
578
+ export var FeatureAppearanceProvider;
579
+ (function (FeatureAppearanceProvider) {
580
+ /** Produce a FeatureAppearanceSource for which `getAppearance()` returns the appearance specified in `source`, potentially modified by `provider`. */
581
+ function wrap(source, provider) {
582
+ return {
583
+ getAppearance: (elemLo, elemHi, subcatLo, subcatHi, geomClass, modelLo, modelHi, type, animationNodeId) => {
584
+ return provider.getFeatureAppearance(source, elemLo, elemHi, subcatLo, subcatHi, geomClass, modelLo, modelHi, type, animationNodeId);
585
+ },
586
+ };
587
+ }
588
+ /** Create a provider that obtains each feature's appearance from the source, and if the feature is visible, modifies the appearance.
589
+ * @param supplementAppearance A function accepting the feature's base appearance and returning a supplemental appearance.
590
+ * @public
591
+ */
592
+ function supplement(supplementAppearance) {
593
+ return {
594
+ getFeatureAppearance: (source, elemLo, elemHi, subcatLo, subcatHi, geomClass, modelLo, modelHi, type, animationNodeId) => {
595
+ const app = source.getAppearance(elemLo, elemHi, subcatLo, subcatHi, geomClass, modelLo, modelHi, type, animationNodeId);
596
+ return app ? supplementAppearance(app) : app;
597
+ },
598
+ };
599
+ }
600
+ FeatureAppearanceProvider.supplement = supplement;
601
+ /** Chain two FeatureAppearanceProviders together such that `first`'s `getFeatureAppearance` function is applied before `second`'s.
602
+ * If `second` invokes `source.getAppearance()`, the returned appearance will include any modifications applied by `first`.
603
+ * @public
604
+ */
605
+ function chain(first, second) {
606
+ if (first === second)
607
+ return first;
608
+ return {
609
+ getFeatureAppearance: (source, elemLo, elemHi, subcatLo, subcatHi, geomClass, modelLo, modelHi, type, animationNodeId) => {
610
+ return second.getFeatureAppearance(wrap(source, first), elemLo, elemHi, subcatLo, subcatHi, geomClass, modelLo, modelHi, type, animationNodeId);
611
+ },
612
+ };
613
+ }
614
+ FeatureAppearanceProvider.chain = chain;
615
+ })(FeatureAppearanceProvider || (FeatureAppearanceProvider = {}));
610
616
  //# sourceMappingURL=FeatureSymbology.js.map