@itwin/core-common 4.0.0-dev.52 → 4.0.0-dev.55

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