@itwin/core-common 4.0.0-dev.1 → 4.0.0-dev.100

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 (994) hide show
  1. package/CHANGELOG.md +64 -1
  2. package/lib/cjs/AmbientOcclusion.d.ts +49 -49
  3. package/lib/cjs/AmbientOcclusion.js +55 -55
  4. package/lib/cjs/AnalysisStyle.d.ts +134 -134
  5. package/lib/cjs/AnalysisStyle.js +165 -165
  6. package/lib/cjs/AnalysisStyle.js.map +1 -1
  7. package/lib/cjs/Atmosphere.d.ts +99 -0
  8. package/lib/cjs/Atmosphere.d.ts.map +1 -0
  9. package/lib/cjs/Atmosphere.js +134 -0
  10. package/lib/cjs/Atmosphere.js.map +1 -0
  11. package/lib/cjs/AuthorizationClient.d.ts +17 -17
  12. package/lib/cjs/AuthorizationClient.js +9 -9
  13. package/lib/cjs/BackendTypes.d.ts +13 -12
  14. package/lib/cjs/BackendTypes.d.ts.map +1 -1
  15. package/lib/cjs/BackendTypes.js +9 -9
  16. package/lib/cjs/BackendTypes.js.map +1 -1
  17. package/lib/cjs/BackgroundMapProvider.d.ts +51 -51
  18. package/lib/cjs/BackgroundMapProvider.d.ts.map +1 -1
  19. package/lib/cjs/BackgroundMapProvider.js +67 -68
  20. package/lib/cjs/BackgroundMapProvider.js.map +1 -1
  21. package/lib/cjs/BackgroundMapSettings.d.ts +136 -136
  22. package/lib/cjs/BackgroundMapSettings.d.ts.map +1 -1
  23. package/lib/cjs/BackgroundMapSettings.js +154 -156
  24. package/lib/cjs/BackgroundMapSettings.js.map +1 -1
  25. package/lib/cjs/Base64EncodedString.d.ts +32 -32
  26. package/lib/cjs/Base64EncodedString.d.ts.map +1 -1
  27. package/lib/cjs/Base64EncodedString.js +66 -66
  28. package/lib/cjs/Base64EncodedString.js.map +1 -1
  29. package/lib/cjs/BlobReader.d.ts +31 -31
  30. package/lib/cjs/BlobReader.js +84 -84
  31. package/lib/cjs/BriefcaseTypes.d.ts +191 -189
  32. package/lib/cjs/BriefcaseTypes.d.ts.map +1 -1
  33. package/lib/cjs/BriefcaseTypes.js +95 -95
  34. package/lib/cjs/BriefcaseTypes.js.map +1 -1
  35. package/lib/cjs/Camera.d.ts +42 -42
  36. package/lib/cjs/Camera.js +62 -62
  37. package/lib/cjs/Camera.js.map +1 -1
  38. package/lib/cjs/ChangedElements.d.ts +85 -85
  39. package/lib/cjs/ChangedElements.js +23 -23
  40. package/lib/cjs/ChangedEntities.d.ts +45 -45
  41. package/lib/cjs/ChangedEntities.d.ts.map +1 -1
  42. package/lib/cjs/ChangedEntities.js +9 -9
  43. package/lib/cjs/ChangesetProps.d.ts +98 -98
  44. package/lib/cjs/ChangesetProps.d.ts.map +1 -1
  45. package/lib/cjs/ChangesetProps.js +22 -22
  46. package/lib/cjs/ChangesetProps.js.map +1 -1
  47. package/lib/cjs/ClipStyle.d.ts +89 -89
  48. package/lib/cjs/ClipStyle.js +121 -123
  49. package/lib/cjs/ClipStyle.js.map +1 -1
  50. package/lib/cjs/Code.d.ts +278 -277
  51. package/lib/cjs/Code.d.ts.map +1 -1
  52. package/lib/cjs/Code.js +271 -269
  53. package/lib/cjs/Code.js.map +1 -1
  54. package/lib/cjs/ColorByName.d.ts +161 -161
  55. package/lib/cjs/ColorByName.js +169 -169
  56. package/lib/cjs/ColorDef.d.ts +210 -208
  57. package/lib/cjs/ColorDef.d.ts.map +1 -1
  58. package/lib/cjs/ColorDef.js +572 -571
  59. package/lib/cjs/ColorDef.js.map +1 -1
  60. package/lib/cjs/CommonLoggerCategory.d.ts +18 -18
  61. package/lib/cjs/CommonLoggerCategory.js +26 -26
  62. package/lib/cjs/ConcurrentQuery.d.ts +421 -421
  63. package/lib/cjs/ConcurrentQuery.d.ts.map +1 -1
  64. package/lib/cjs/ConcurrentQuery.js +552 -552
  65. package/lib/cjs/ConcurrentQuery.js.map +1 -1
  66. package/lib/cjs/ContextRealityModel.d.ts +303 -303
  67. package/lib/cjs/ContextRealityModel.js +371 -373
  68. package/lib/cjs/ContextRealityModel.js.map +1 -1
  69. package/lib/cjs/DisplayStyleSettings.d.ts +593 -588
  70. package/lib/cjs/DisplayStyleSettings.d.ts.map +1 -1
  71. package/lib/cjs/DisplayStyleSettings.js +990 -985
  72. package/lib/cjs/DisplayStyleSettings.js.map +1 -1
  73. package/lib/cjs/ECSchemaProps.d.ts +39 -39
  74. package/lib/cjs/ECSchemaProps.js +9 -9
  75. package/lib/cjs/ECSqlReader.d.ts +72 -70
  76. package/lib/cjs/ECSqlReader.d.ts.map +1 -1
  77. package/lib/cjs/ECSqlReader.js +297 -280
  78. package/lib/cjs/ECSqlReader.js.map +1 -1
  79. package/lib/cjs/ECSqlTypes.d.ts +128 -128
  80. package/lib/cjs/ECSqlTypes.js +189 -189
  81. package/lib/cjs/ElementMesh.d.ts +39 -39
  82. package/lib/cjs/ElementMesh.js +56 -56
  83. package/lib/cjs/ElementProps.d.ts +483 -483
  84. package/lib/cjs/ElementProps.d.ts.map +1 -1
  85. package/lib/cjs/ElementProps.js +99 -99
  86. package/lib/cjs/ElementProps.js.map +1 -1
  87. package/lib/cjs/EmphasizeElementsProps.d.ts +55 -55
  88. package/lib/cjs/EmphasizeElementsProps.js +25 -25
  89. package/lib/cjs/EntityProps.d.ts +177 -177
  90. package/lib/cjs/EntityProps.d.ts.map +1 -1
  91. package/lib/cjs/EntityProps.js +113 -113
  92. package/lib/cjs/EntityReference.d.ts +51 -51
  93. package/lib/cjs/EntityReference.d.ts.map +1 -1
  94. package/lib/cjs/EntityReference.js +56 -56
  95. package/lib/cjs/Environment.d.ts +74 -61
  96. package/lib/cjs/Environment.d.ts.map +1 -1
  97. package/lib/cjs/Environment.js +78 -73
  98. package/lib/cjs/Environment.js.map +1 -1
  99. package/lib/cjs/FeatureIndex.d.ts +39 -39
  100. package/lib/cjs/FeatureIndex.js +63 -63
  101. package/lib/cjs/FeatureIndex.js.map +1 -1
  102. package/lib/cjs/FeatureSymbology.d.ts +449 -444
  103. package/lib/cjs/FeatureSymbology.d.ts.map +1 -1
  104. package/lib/cjs/FeatureSymbology.js +618 -614
  105. package/lib/cjs/FeatureSymbology.js.map +1 -1
  106. package/lib/cjs/FeatureTable.d.ts +255 -141
  107. package/lib/cjs/FeatureTable.d.ts.map +1 -1
  108. package/lib/cjs/FeatureTable.js +484 -278
  109. package/lib/cjs/FeatureTable.js.map +1 -1
  110. package/lib/cjs/Fonts.d.ts +51 -51
  111. package/lib/cjs/Fonts.d.ts.map +1 -1
  112. package/lib/cjs/Fonts.js +53 -53
  113. package/lib/cjs/Frustum.d.ts +114 -114
  114. package/lib/cjs/Frustum.js +292 -292
  115. package/lib/cjs/GeoCoordinateServices.d.ts +123 -119
  116. package/lib/cjs/GeoCoordinateServices.d.ts.map +1 -1
  117. package/lib/cjs/GeoCoordinateServices.js +81 -80
  118. package/lib/cjs/GeoCoordinateServices.js.map +1 -1
  119. package/lib/cjs/GeometryContainment.d.ts +28 -28
  120. package/lib/cjs/GeometryContainment.js +9 -9
  121. package/lib/cjs/GeometryParams.d.ts +130 -130
  122. package/lib/cjs/GeometryParams.js +174 -174
  123. package/lib/cjs/GeometrySummary.d.ts +45 -45
  124. package/lib/cjs/GeometrySummary.js +23 -23
  125. package/lib/cjs/Gradient.d.ts +139 -139
  126. package/lib/cjs/Gradient.js +453 -455
  127. package/lib/cjs/Gradient.js.map +1 -1
  128. package/lib/cjs/GraphicParams.d.ts +58 -58
  129. package/lib/cjs/GraphicParams.js +85 -85
  130. package/lib/cjs/GraphicParams.js.map +1 -1
  131. package/lib/cjs/GroundPlane.d.ts +52 -52
  132. package/lib/cjs/GroundPlane.d.ts.map +1 -1
  133. package/lib/cjs/GroundPlane.js +63 -64
  134. package/lib/cjs/GroundPlane.js.map +1 -1
  135. package/lib/cjs/HSLColor.d.ts +20 -20
  136. package/lib/cjs/HSLColor.js +32 -32
  137. package/lib/cjs/HSLColor.js.map +1 -1
  138. package/lib/cjs/HSVColor.d.ts +30 -30
  139. package/lib/cjs/HSVColor.js +59 -59
  140. package/lib/cjs/HSVColor.js.map +1 -1
  141. package/lib/cjs/HiddenLine.d.ts +97 -97
  142. package/lib/cjs/HiddenLine.js +160 -162
  143. package/lib/cjs/HiddenLine.js.map +1 -1
  144. package/lib/cjs/Hilite.d.ts +50 -50
  145. package/lib/cjs/Hilite.js +64 -64
  146. package/lib/cjs/Hilite.js.map +1 -1
  147. package/lib/cjs/IModel.d.ts +358 -359
  148. package/lib/cjs/IModel.d.ts.map +1 -1
  149. package/lib/cjs/IModel.js +347 -347
  150. package/lib/cjs/IModel.js.map +1 -1
  151. package/lib/cjs/IModelError.d.ts +42 -42
  152. package/lib/cjs/IModelError.d.ts.map +1 -1
  153. package/lib/cjs/IModelError.js +71 -71
  154. package/lib/cjs/IModelError.js.map +1 -1
  155. package/lib/cjs/IModelVersion.d.ts +68 -68
  156. package/lib/cjs/IModelVersion.d.ts.map +1 -1
  157. package/lib/cjs/IModelVersion.js +79 -79
  158. package/lib/cjs/Image.d.ts +86 -86
  159. package/lib/cjs/Image.js +128 -128
  160. package/lib/cjs/Image.js.map +1 -1
  161. package/lib/cjs/IpcAppProps.d.ts +141 -141
  162. package/lib/cjs/IpcAppProps.js +23 -23
  163. package/lib/cjs/LightSettings.d.ts +224 -224
  164. package/lib/cjs/LightSettings.js +304 -309
  165. package/lib/cjs/LightSettings.js.map +1 -1
  166. package/lib/cjs/LinePixels.d.ts +34 -34
  167. package/lib/cjs/LinePixels.js +42 -42
  168. package/lib/cjs/Localization.d.ts +117 -113
  169. package/lib/cjs/Localization.d.ts.map +1 -1
  170. package/lib/cjs/Localization.js +33 -33
  171. package/lib/cjs/Localization.js.map +1 -1
  172. package/lib/cjs/MapImagerySettings.d.ts +62 -62
  173. package/lib/cjs/MapImagerySettings.d.ts.map +1 -1
  174. package/lib/cjs/MapImagerySettings.js +80 -80
  175. package/lib/cjs/MapImagerySettings.js.map +1 -1
  176. package/lib/cjs/MapLayerSettings.d.ts +272 -272
  177. package/lib/cjs/MapLayerSettings.d.ts.map +1 -1
  178. package/lib/cjs/MapLayerSettings.js +407 -411
  179. package/lib/cjs/MapLayerSettings.js.map +1 -1
  180. package/lib/cjs/MassProperties.d.ts +64 -64
  181. package/lib/cjs/MassProperties.js +23 -23
  182. package/lib/cjs/MaterialProps.d.ts +165 -153
  183. package/lib/cjs/MaterialProps.d.ts.map +1 -1
  184. package/lib/cjs/MaterialProps.js +37 -35
  185. package/lib/cjs/MaterialProps.js.map +1 -1
  186. package/lib/cjs/ModelClipGroup.d.ts +67 -67
  187. package/lib/cjs/ModelClipGroup.js +96 -98
  188. package/lib/cjs/ModelClipGroup.js.map +1 -1
  189. package/lib/cjs/ModelGeometryChanges.d.ts +107 -107
  190. package/lib/cjs/ModelGeometryChanges.d.ts.map +1 -1
  191. package/lib/cjs/ModelGeometryChanges.js +83 -83
  192. package/lib/cjs/ModelProps.d.ts +67 -67
  193. package/lib/cjs/ModelProps.js +9 -9
  194. package/lib/cjs/NativeAppProps.d.ts +122 -122
  195. package/lib/cjs/NativeAppProps.d.ts.map +1 -1
  196. package/lib/cjs/NativeAppProps.js +30 -30
  197. package/lib/cjs/OctEncodedNormal.d.ts +33 -33
  198. package/lib/cjs/OctEncodedNormal.js +98 -98
  199. package/lib/cjs/PlanProjectionSettings.d.ts +47 -47
  200. package/lib/cjs/PlanProjectionSettings.js +63 -63
  201. package/lib/cjs/PlanProjectionSettings.js.map +1 -1
  202. package/lib/cjs/PlanarClipMask.d.ts +177 -177
  203. package/lib/cjs/PlanarClipMask.js +136 -136
  204. package/lib/cjs/PlanarClipMask.js.map +1 -1
  205. package/lib/cjs/QPoint.d.ts +479 -479
  206. package/lib/cjs/QPoint.js +824 -826
  207. package/lib/cjs/QPoint.js.map +1 -1
  208. package/lib/cjs/RealityDataAccessProps.d.ts +41 -41
  209. package/lib/cjs/RealityDataAccessProps.js +19 -19
  210. package/lib/cjs/RealityModelDisplaySettings.d.ts +183 -183
  211. package/lib/cjs/RealityModelDisplaySettings.d.ts.map +1 -1
  212. package/lib/cjs/RealityModelDisplaySettings.js +141 -142
  213. package/lib/cjs/RealityModelDisplaySettings.js.map +1 -1
  214. package/lib/cjs/Render.d.ts +89 -89
  215. package/lib/cjs/Render.js +177 -177
  216. package/lib/cjs/RenderMaterial.d.ts +58 -58
  217. package/lib/cjs/RenderMaterial.js +75 -76
  218. package/lib/cjs/RenderMaterial.js.map +1 -1
  219. package/lib/cjs/RenderSchedule.d.ts +557 -543
  220. package/lib/cjs/RenderSchedule.d.ts.map +1 -1
  221. package/lib/cjs/RenderSchedule.js +1028 -1002
  222. package/lib/cjs/RenderSchedule.js.map +1 -1
  223. package/lib/cjs/RenderTexture.d.ts +70 -70
  224. package/lib/cjs/RenderTexture.d.ts.map +1 -1
  225. package/lib/cjs/RenderTexture.js +59 -59
  226. package/lib/cjs/RenderTexture.js.map +1 -1
  227. package/lib/cjs/RgbColor.d.ts +47 -47
  228. package/lib/cjs/RgbColor.js +77 -77
  229. package/lib/cjs/RpcInterface.d.ts +42 -33
  230. package/lib/cjs/RpcInterface.d.ts.map +1 -1
  231. package/lib/cjs/RpcInterface.js +158 -137
  232. package/lib/cjs/RpcInterface.js.map +1 -1
  233. package/lib/cjs/RpcManager.d.ts +40 -40
  234. package/lib/cjs/RpcManager.js +55 -55
  235. package/lib/cjs/RpcManager.js.map +1 -1
  236. package/lib/cjs/SessionProps.d.ts +16 -16
  237. package/lib/cjs/SessionProps.js +9 -9
  238. package/lib/cjs/SkyBox.d.ts +217 -215
  239. package/lib/cjs/SkyBox.d.ts.map +1 -1
  240. package/lib/cjs/SkyBox.js +209 -210
  241. package/lib/cjs/SkyBox.js.map +1 -1
  242. package/lib/cjs/Snapping.d.ts +49 -49
  243. package/lib/cjs/Snapping.js +9 -9
  244. package/lib/cjs/SolarCalculate.d.ts +27 -27
  245. package/lib/cjs/SolarCalculate.js +211 -211
  246. package/lib/cjs/SolarShadows.d.ts +35 -35
  247. package/lib/cjs/SolarShadows.js +61 -62
  248. package/lib/cjs/SolarShadows.js.map +1 -1
  249. package/lib/cjs/SpatialClassification.d.ts +208 -208
  250. package/lib/cjs/SpatialClassification.js +339 -340
  251. package/lib/cjs/SpatialClassification.js.map +1 -1
  252. package/lib/cjs/SubCategoryAppearance.d.ts +91 -91
  253. package/lib/cjs/SubCategoryAppearance.js +96 -96
  254. package/lib/cjs/SubCategoryAppearance.js.map +1 -1
  255. package/lib/cjs/SubCategoryOverride.d.ts +46 -46
  256. package/lib/cjs/SubCategoryOverride.js +104 -104
  257. package/lib/cjs/SubCategoryOverride.js.map +1 -1
  258. package/lib/cjs/TerrainSettings.d.ts +82 -82
  259. package/lib/cjs/TerrainSettings.d.ts.map +1 -1
  260. package/lib/cjs/TerrainSettings.js +100 -102
  261. package/lib/cjs/TerrainSettings.js.map +1 -1
  262. package/lib/cjs/TextureMapping.d.ts +151 -118
  263. package/lib/cjs/TextureMapping.d.ts.map +1 -1
  264. package/lib/cjs/TextureMapping.js +180 -174
  265. package/lib/cjs/TextureMapping.js.map +1 -1
  266. package/lib/cjs/TextureProps.d.ts +65 -65
  267. package/lib/cjs/TextureProps.js +28 -28
  268. package/lib/cjs/ThematicDisplay.d.ts +230 -230
  269. package/lib/cjs/ThematicDisplay.js +343 -344
  270. package/lib/cjs/ThematicDisplay.js.map +1 -1
  271. package/lib/cjs/Thumbnail.d.ts +26 -26
  272. package/lib/cjs/Thumbnail.js +9 -9
  273. package/lib/cjs/TileProps.d.ts +88 -82
  274. package/lib/cjs/TileProps.d.ts.map +1 -1
  275. package/lib/cjs/TileProps.js +29 -29
  276. package/lib/cjs/TileProps.js.map +1 -1
  277. package/lib/cjs/Tween.d.ts +191 -191
  278. package/lib/cjs/Tween.d.ts.map +1 -1
  279. package/lib/cjs/Tween.js +570 -570
  280. package/lib/cjs/TxnAction.d.ts +21 -21
  281. package/lib/cjs/TxnAction.js +29 -29
  282. package/lib/cjs/ViewDetails.d.ts +125 -125
  283. package/lib/cjs/ViewDetails.js +166 -166
  284. package/lib/cjs/ViewDetails.js.map +1 -1
  285. package/lib/cjs/ViewFlags.d.ts +287 -287
  286. package/lib/cjs/ViewFlags.d.ts.map +1 -1
  287. package/lib/cjs/ViewFlags.js +367 -368
  288. package/lib/cjs/ViewFlags.js.map +1 -1
  289. package/lib/cjs/ViewProps.d.ts +205 -205
  290. package/lib/cjs/ViewProps.js +9 -9
  291. package/lib/cjs/WhiteOnWhiteReversalSettings.d.ts +36 -36
  292. package/lib/cjs/WhiteOnWhiteReversalSettings.js +37 -37
  293. package/lib/cjs/WhiteOnWhiteReversalSettings.js.map +1 -1
  294. package/lib/cjs/core-common.d.ts +244 -244
  295. package/lib/cjs/core-common.d.ts.map +1 -1
  296. package/lib/cjs/core-common.js +264 -260
  297. package/lib/cjs/core-common.js.map +1 -1
  298. package/lib/cjs/domains/FunctionalElementProps.d.ts +11 -11
  299. package/lib/cjs/domains/FunctionalElementProps.js +9 -9
  300. package/lib/cjs/domains/GenericElementProps.d.ts +18 -18
  301. package/lib/cjs/domains/GenericElementProps.js +9 -9
  302. package/lib/cjs/geometry/AdditionalTransform.d.ts +84 -84
  303. package/lib/cjs/geometry/AdditionalTransform.js +85 -85
  304. package/lib/cjs/geometry/AreaPattern.d.ts +82 -82
  305. package/lib/cjs/geometry/AreaPattern.js +203 -204
  306. package/lib/cjs/geometry/AreaPattern.js.map +1 -1
  307. package/lib/cjs/geometry/BoundingSphere.d.ts +27 -27
  308. package/lib/cjs/geometry/BoundingSphere.js +44 -44
  309. package/lib/cjs/geometry/BoundingSphere.js.map +1 -1
  310. package/lib/cjs/geometry/Cartographic.d.ts +137 -137
  311. package/lib/cjs/geometry/Cartographic.js +345 -345
  312. package/lib/cjs/geometry/Cartographic.js.map +1 -1
  313. package/lib/cjs/geometry/CoordinateReferenceSystem.d.ts +269 -269
  314. package/lib/cjs/geometry/CoordinateReferenceSystem.d.ts.map +1 -1
  315. package/lib/cjs/geometry/CoordinateReferenceSystem.js +260 -261
  316. package/lib/cjs/geometry/CoordinateReferenceSystem.js.map +1 -1
  317. package/lib/cjs/geometry/ElementGeometry.d.ts +402 -402
  318. package/lib/cjs/geometry/ElementGeometry.d.ts.map +1 -1
  319. package/lib/cjs/geometry/ElementGeometry.js +1719 -1719
  320. package/lib/cjs/geometry/ElementGeometry.js.map +1 -1
  321. package/lib/cjs/geometry/ElementGeometryFB.d.ts +2372 -2372
  322. package/lib/cjs/geometry/ElementGeometryFB.js +3814 -3814
  323. package/lib/cjs/geometry/ElementGeometryFB.js.map +1 -1
  324. package/lib/cjs/geometry/FrustumPlanes.d.ts +83 -81
  325. package/lib/cjs/geometry/FrustumPlanes.d.ts.map +1 -1
  326. package/lib/cjs/geometry/FrustumPlanes.js +227 -193
  327. package/lib/cjs/geometry/FrustumPlanes.js.map +1 -1
  328. package/lib/cjs/geometry/GeodeticDatum.d.ts +409 -409
  329. package/lib/cjs/geometry/GeodeticDatum.d.ts.map +1 -1
  330. package/lib/cjs/geometry/GeodeticDatum.js +400 -401
  331. package/lib/cjs/geometry/GeodeticDatum.js.map +1 -1
  332. package/lib/cjs/geometry/GeodeticEllipsoid.d.ts +72 -72
  333. package/lib/cjs/geometry/GeodeticEllipsoid.js +71 -72
  334. package/lib/cjs/geometry/GeodeticEllipsoid.js.map +1 -1
  335. package/lib/cjs/geometry/GeometryStream.d.ts +347 -347
  336. package/lib/cjs/geometry/GeometryStream.d.ts.map +1 -1
  337. package/lib/cjs/geometry/GeometryStream.js +468 -469
  338. package/lib/cjs/geometry/GeometryStream.js.map +1 -1
  339. package/lib/cjs/geometry/ImageGraphic.d.ts +74 -74
  340. package/lib/cjs/geometry/ImageGraphic.d.ts.map +1 -1
  341. package/lib/cjs/geometry/ImageGraphic.js +98 -98
  342. package/lib/cjs/geometry/LineStyle.d.ts +71 -71
  343. package/lib/cjs/geometry/LineStyle.js +129 -129
  344. package/lib/cjs/geometry/Placement.d.ts +95 -95
  345. package/lib/cjs/geometry/Placement.d.ts.map +1 -1
  346. package/lib/cjs/geometry/Placement.js +131 -131
  347. package/lib/cjs/geometry/Projection.d.ts +251 -251
  348. package/lib/cjs/geometry/Projection.d.ts.map +1 -1
  349. package/lib/cjs/geometry/Projection.js +198 -198
  350. package/lib/cjs/geometry/Projection.js.map +1 -1
  351. package/lib/cjs/geometry/TextString.d.ts +55 -55
  352. package/lib/cjs/geometry/TextString.js +65 -65
  353. package/lib/cjs/geometry/TextString.js.map +1 -1
  354. package/lib/cjs/ipc/IpcSession.d.ts +23 -23
  355. package/lib/cjs/ipc/IpcSession.js +27 -27
  356. package/lib/cjs/ipc/IpcSocket.d.ts +96 -96
  357. package/lib/cjs/ipc/IpcSocket.d.ts.map +1 -1
  358. package/lib/cjs/ipc/IpcSocket.js +16 -16
  359. package/lib/cjs/ipc/IpcWebSocket.d.ts +60 -61
  360. package/lib/cjs/ipc/IpcWebSocket.d.ts.map +1 -1
  361. package/lib/cjs/ipc/IpcWebSocket.js +148 -151
  362. package/lib/cjs/ipc/IpcWebSocket.js.map +1 -1
  363. package/lib/cjs/ipc/IpcWebSocketTransport.d.ts +15 -15
  364. package/lib/cjs/ipc/IpcWebSocketTransport.js +160 -160
  365. package/lib/cjs/ipc/IpcWebSocketTransport.js.map +1 -1
  366. package/lib/cjs/rpc/DevToolsRpcInterface.d.ts +32 -32
  367. package/lib/cjs/rpc/DevToolsRpcInterface.d.ts.map +1 -1
  368. package/lib/cjs/rpc/DevToolsRpcInterface.js +52 -48
  369. package/lib/cjs/rpc/DevToolsRpcInterface.js.map +1 -1
  370. package/lib/cjs/rpc/IModelReadRpcInterface.d.ts +99 -99
  371. package/lib/cjs/rpc/IModelReadRpcInterface.d.ts.map +1 -1
  372. package/lib/cjs/rpc/IModelReadRpcInterface.js +122 -122
  373. package/lib/cjs/rpc/IModelReadRpcInterface.js.map +1 -1
  374. package/lib/cjs/rpc/IModelTileRpcInterface.d.ts +49 -61
  375. package/lib/cjs/rpc/IModelTileRpcInterface.d.ts.map +1 -1
  376. package/lib/cjs/rpc/IModelTileRpcInterface.js +79 -96
  377. package/lib/cjs/rpc/IModelTileRpcInterface.js.map +1 -1
  378. package/lib/cjs/rpc/SnapshotIModelRpcInterface.d.ts +23 -23
  379. package/lib/cjs/rpc/SnapshotIModelRpcInterface.js +48 -48
  380. package/lib/cjs/rpc/SnapshotIModelRpcInterface.js.map +1 -1
  381. package/lib/cjs/rpc/TestRpcManager.d.ts +20 -20
  382. package/lib/cjs/rpc/TestRpcManager.js +40 -40
  383. package/lib/cjs/rpc/WipRpcInterface.d.ts +29 -29
  384. package/lib/cjs/rpc/WipRpcInterface.js +40 -40
  385. package/lib/cjs/rpc/WipRpcInterface.js.map +1 -1
  386. package/lib/cjs/rpc/core/RpcConfiguration.d.ts +111 -111
  387. package/lib/cjs/rpc/core/RpcConfiguration.d.ts.map +1 -1
  388. package/lib/cjs/rpc/core/RpcConfiguration.js +191 -191
  389. package/lib/cjs/rpc/core/RpcConfiguration.js.map +1 -1
  390. package/lib/cjs/rpc/core/RpcConstants.d.ts +90 -90
  391. package/lib/cjs/rpc/core/RpcConstants.js +109 -109
  392. package/lib/cjs/rpc/core/RpcControl.d.ts +54 -57
  393. package/lib/cjs/rpc/core/RpcControl.d.ts.map +1 -1
  394. package/lib/cjs/rpc/core/RpcControl.js +150 -148
  395. package/lib/cjs/rpc/core/RpcControl.js.map +1 -1
  396. package/lib/cjs/rpc/core/RpcInvocation.d.ts +89 -89
  397. package/lib/cjs/rpc/core/RpcInvocation.d.ts.map +1 -1
  398. package/lib/cjs/rpc/core/RpcInvocation.js +256 -258
  399. package/lib/cjs/rpc/core/RpcInvocation.js.map +1 -1
  400. package/lib/cjs/rpc/core/RpcMarshaling.d.ts +35 -35
  401. package/lib/cjs/rpc/core/RpcMarshaling.js +156 -156
  402. package/lib/cjs/rpc/core/RpcOperation.d.ts +67 -67
  403. package/lib/cjs/rpc/core/RpcOperation.d.ts.map +1 -1
  404. package/lib/cjs/rpc/core/RpcOperation.js +135 -134
  405. package/lib/cjs/rpc/core/RpcOperation.js.map +1 -1
  406. package/lib/cjs/rpc/core/RpcPendingQueue.d.ts +21 -21
  407. package/lib/cjs/rpc/core/RpcPendingQueue.js +94 -95
  408. package/lib/cjs/rpc/core/RpcPendingQueue.js.map +1 -1
  409. package/lib/cjs/rpc/core/RpcProtocol.d.ts +132 -132
  410. package/lib/cjs/rpc/core/RpcProtocol.d.ts.map +1 -1
  411. package/lib/cjs/rpc/core/RpcProtocol.js +127 -127
  412. package/lib/cjs/rpc/core/RpcProtocol.js.map +1 -1
  413. package/lib/cjs/rpc/core/RpcPush.d.ts +68 -68
  414. package/lib/cjs/rpc/core/RpcPush.d.ts.map +1 -1
  415. package/lib/cjs/rpc/core/RpcPush.js +127 -127
  416. package/lib/cjs/rpc/core/RpcPush.js.map +1 -1
  417. package/lib/cjs/rpc/core/RpcRegistry.d.ts +48 -48
  418. package/lib/cjs/rpc/core/RpcRegistry.js +198 -199
  419. package/lib/cjs/rpc/core/RpcRegistry.js.map +1 -1
  420. package/lib/cjs/rpc/core/RpcRequest.d.ts +186 -186
  421. package/lib/cjs/rpc/core/RpcRequest.d.ts.map +1 -1
  422. package/lib/cjs/rpc/core/RpcRequest.js +478 -478
  423. package/lib/cjs/rpc/core/RpcRequest.js.map +1 -1
  424. package/lib/cjs/rpc/core/RpcRequestContext.d.ts +14 -14
  425. package/lib/cjs/rpc/core/RpcRequestContext.js +2 -2
  426. package/lib/cjs/rpc/core/RpcRoutingToken.d.ts +12 -12
  427. package/lib/cjs/rpc/core/RpcRoutingToken.d.ts.map +1 -1
  428. package/lib/cjs/rpc/core/RpcRoutingToken.js +24 -24
  429. package/lib/cjs/rpc/core/RpcRoutingToken.js.map +1 -1
  430. package/lib/cjs/rpc/core/RpcSessionInvocation.d.ts +10 -10
  431. package/lib/cjs/rpc/core/RpcSessionInvocation.js +60 -60
  432. package/lib/cjs/rpc/core/RpcSessionInvocation.js.map +1 -1
  433. package/lib/cjs/rpc/web/BentleyCloudRpcManager.d.ts +48 -46
  434. package/lib/cjs/rpc/web/BentleyCloudRpcManager.d.ts.map +1 -1
  435. package/lib/cjs/rpc/web/BentleyCloudRpcManager.js +76 -73
  436. package/lib/cjs/rpc/web/BentleyCloudRpcManager.js.map +1 -1
  437. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.d.ts +33 -33
  438. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.js +141 -143
  439. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.js.map +1 -1
  440. package/lib/cjs/rpc/web/OpenAPI.d.ts +140 -140
  441. package/lib/cjs/rpc/web/OpenAPI.js +60 -60
  442. package/lib/cjs/rpc/web/OpenAPI.js.map +1 -1
  443. package/lib/cjs/rpc/web/RpcMultipart.d.ts +35 -35
  444. package/lib/cjs/rpc/web/RpcMultipart.js +50 -50
  445. package/lib/cjs/rpc/web/RpcMultipart.js.map +1 -1
  446. package/lib/cjs/rpc/web/WebAppRpcLogging.d.ts +28 -28
  447. package/lib/cjs/rpc/web/WebAppRpcLogging.js +140 -140
  448. package/lib/cjs/rpc/web/WebAppRpcProtocol.d.ts +89 -89
  449. package/lib/cjs/rpc/web/WebAppRpcProtocol.js +116 -116
  450. package/lib/cjs/rpc/web/WebAppRpcProtocol.js.map +1 -1
  451. package/lib/cjs/rpc/web/WebAppRpcRequest.d.ts +67 -67
  452. package/lib/cjs/rpc/web/WebAppRpcRequest.d.ts.map +1 -1
  453. package/lib/cjs/rpc/web/WebAppRpcRequest.js +239 -239
  454. package/lib/cjs/rpc/web/WebAppRpcRequest.js.map +1 -1
  455. package/lib/cjs/rpc/web/multipart/RpcMultipartParser.d.ts +32 -32
  456. package/lib/cjs/rpc/web/multipart/RpcMultipartParser.js +373 -373
  457. package/lib/cjs/tile/B3dmTileIO.d.ts +19 -19
  458. package/lib/cjs/tile/B3dmTileIO.js +66 -66
  459. package/lib/cjs/tile/B3dmTileIO.js.map +1 -1
  460. package/lib/cjs/tile/CompositeTileIO.d.ts +15 -15
  461. package/lib/cjs/tile/CompositeTileIO.js +26 -26
  462. package/lib/cjs/tile/CompositeTileIO.js.map +1 -1
  463. package/lib/cjs/tile/ElementGraphics.d.ts +145 -145
  464. package/lib/cjs/tile/ElementGraphics.d.ts.map +1 -1
  465. package/lib/cjs/tile/ElementGraphics.js +9 -9
  466. package/lib/cjs/tile/GltfTileIO.d.ts +45 -45
  467. package/lib/cjs/tile/GltfTileIO.d.ts.map +1 -1
  468. package/lib/cjs/tile/GltfTileIO.js +109 -109
  469. package/lib/cjs/tile/GltfTileIO.js.map +1 -1
  470. package/lib/cjs/tile/I3dmTileIO.d.ts +20 -20
  471. package/lib/cjs/tile/I3dmTileIO.js +40 -40
  472. package/lib/cjs/tile/I3dmTileIO.js.map +1 -1
  473. package/lib/cjs/tile/IModelTileIO.d.ts +77 -75
  474. package/lib/cjs/tile/IModelTileIO.d.ts.map +1 -1
  475. package/lib/cjs/tile/IModelTileIO.js +97 -95
  476. package/lib/cjs/tile/IModelTileIO.js.map +1 -1
  477. package/lib/cjs/tile/PntsTileIO.d.ts +17 -17
  478. package/lib/cjs/tile/PntsTileIO.js +26 -26
  479. package/lib/cjs/tile/PntsTileIO.js.map +1 -1
  480. package/lib/cjs/tile/TileIO.d.ts +66 -66
  481. package/lib/cjs/tile/TileIO.js +118 -118
  482. package/lib/cjs/tile/TileMetadata.d.ts +240 -228
  483. package/lib/cjs/tile/TileMetadata.d.ts.map +1 -1
  484. package/lib/cjs/tile/TileMetadata.js +693 -676
  485. package/lib/cjs/tile/TileMetadata.js.map +1 -1
  486. package/lib/cjs/tile/Tileset3dSchema.d.ts +97 -0
  487. package/lib/cjs/tile/Tileset3dSchema.d.ts.map +1 -0
  488. package/lib/cjs/tile/Tileset3dSchema.js +10 -0
  489. package/lib/cjs/tile/Tileset3dSchema.js.map +1 -0
  490. package/lib/esm/AmbientOcclusion.d.ts +49 -49
  491. package/lib/esm/AmbientOcclusion.js +52 -52
  492. package/lib/esm/AnalysisStyle.d.ts +134 -134
  493. package/lib/esm/AnalysisStyle.js +160 -159
  494. package/lib/esm/AnalysisStyle.js.map +1 -1
  495. package/lib/esm/Atmosphere.d.ts +99 -0
  496. package/lib/esm/Atmosphere.d.ts.map +1 -0
  497. package/lib/esm/Atmosphere.js +131 -0
  498. package/lib/esm/Atmosphere.js.map +1 -0
  499. package/lib/esm/AuthorizationClient.d.ts +17 -17
  500. package/lib/esm/AuthorizationClient.js +8 -8
  501. package/lib/esm/BackendTypes.d.ts +13 -12
  502. package/lib/esm/BackendTypes.d.ts.map +1 -1
  503. package/lib/esm/BackendTypes.js +8 -8
  504. package/lib/esm/BackendTypes.js.map +1 -1
  505. package/lib/esm/BackgroundMapProvider.d.ts +51 -51
  506. package/lib/esm/BackgroundMapProvider.d.ts.map +1 -1
  507. package/lib/esm/BackgroundMapProvider.js +63 -64
  508. package/lib/esm/BackgroundMapProvider.js.map +1 -1
  509. package/lib/esm/BackgroundMapSettings.d.ts +136 -136
  510. package/lib/esm/BackgroundMapSettings.d.ts.map +1 -1
  511. package/lib/esm/BackgroundMapSettings.js +150 -152
  512. package/lib/esm/BackgroundMapSettings.js.map +1 -1
  513. package/lib/esm/Base64EncodedString.d.ts +32 -32
  514. package/lib/esm/Base64EncodedString.d.ts.map +1 -1
  515. package/lib/esm/Base64EncodedString.js +63 -63
  516. package/lib/esm/Base64EncodedString.js.map +1 -1
  517. package/lib/esm/BlobReader.d.ts +31 -31
  518. package/lib/esm/BlobReader.js +79 -79
  519. package/lib/esm/BriefcaseTypes.d.ts +191 -189
  520. package/lib/esm/BriefcaseTypes.d.ts.map +1 -1
  521. package/lib/esm/BriefcaseTypes.js +92 -92
  522. package/lib/esm/BriefcaseTypes.js.map +1 -1
  523. package/lib/esm/Camera.d.ts +42 -42
  524. package/lib/esm/Camera.js +58 -58
  525. package/lib/esm/Camera.js.map +1 -1
  526. package/lib/esm/ChangedElements.d.ts +85 -85
  527. package/lib/esm/ChangedElements.js +20 -20
  528. package/lib/esm/ChangedEntities.d.ts +45 -45
  529. package/lib/esm/ChangedEntities.d.ts.map +1 -1
  530. package/lib/esm/ChangedEntities.js +8 -8
  531. package/lib/esm/ChangesetProps.d.ts +98 -98
  532. package/lib/esm/ChangesetProps.d.ts.map +1 -1
  533. package/lib/esm/ChangesetProps.js +19 -19
  534. package/lib/esm/ChangesetProps.js.map +1 -1
  535. package/lib/esm/ClipStyle.d.ts +89 -89
  536. package/lib/esm/ClipStyle.js +118 -118
  537. package/lib/esm/ClipStyle.js.map +1 -1
  538. package/lib/esm/Code.d.ts +278 -277
  539. package/lib/esm/Code.d.ts.map +1 -1
  540. package/lib/esm/Code.js +266 -264
  541. package/lib/esm/Code.js.map +1 -1
  542. package/lib/esm/ColorByName.d.ts +161 -161
  543. package/lib/esm/ColorByName.js +166 -166
  544. package/lib/esm/ColorDef.d.ts +210 -208
  545. package/lib/esm/ColorDef.d.ts.map +1 -1
  546. package/lib/esm/ColorDef.js +569 -567
  547. package/lib/esm/ColorDef.js.map +1 -1
  548. package/lib/esm/CommonLoggerCategory.d.ts +18 -18
  549. package/lib/esm/CommonLoggerCategory.js +23 -23
  550. package/lib/esm/ConcurrentQuery.d.ts +421 -421
  551. package/lib/esm/ConcurrentQuery.d.ts.map +1 -1
  552. package/lib/esm/ConcurrentQuery.js +545 -545
  553. package/lib/esm/ConcurrentQuery.js.map +1 -1
  554. package/lib/esm/ContextRealityModel.d.ts +303 -303
  555. package/lib/esm/ContextRealityModel.js +366 -368
  556. package/lib/esm/ContextRealityModel.js.map +1 -1
  557. package/lib/esm/DisplayStyleSettings.d.ts +593 -588
  558. package/lib/esm/DisplayStyleSettings.d.ts.map +1 -1
  559. package/lib/esm/DisplayStyleSettings.js +985 -980
  560. package/lib/esm/DisplayStyleSettings.js.map +1 -1
  561. package/lib/esm/ECSchemaProps.d.ts +39 -39
  562. package/lib/esm/ECSchemaProps.js +8 -8
  563. package/lib/esm/ECSqlReader.d.ts +72 -70
  564. package/lib/esm/ECSqlReader.d.ts.map +1 -1
  565. package/lib/esm/ECSqlReader.js +293 -275
  566. package/lib/esm/ECSqlReader.js.map +1 -1
  567. package/lib/esm/ECSqlTypes.d.ts +128 -128
  568. package/lib/esm/ECSqlTypes.js +185 -185
  569. package/lib/esm/ElementMesh.d.ts +39 -39
  570. package/lib/esm/ElementMesh.js +52 -52
  571. package/lib/esm/ElementProps.d.ts +483 -483
  572. package/lib/esm/ElementProps.d.ts.map +1 -1
  573. package/lib/esm/ElementProps.js +93 -92
  574. package/lib/esm/ElementProps.js.map +1 -1
  575. package/lib/esm/EmphasizeElementsProps.d.ts +55 -55
  576. package/lib/esm/EmphasizeElementsProps.js +22 -22
  577. package/lib/esm/EntityProps.d.ts +177 -177
  578. package/lib/esm/EntityProps.d.ts.map +1 -1
  579. package/lib/esm/EntityProps.js +108 -108
  580. package/lib/esm/EntityReference.d.ts +51 -51
  581. package/lib/esm/EntityReference.d.ts.map +1 -1
  582. package/lib/esm/EntityReference.js +52 -52
  583. package/lib/esm/Environment.d.ts +74 -61
  584. package/lib/esm/Environment.d.ts.map +1 -1
  585. package/lib/esm/Environment.js +75 -69
  586. package/lib/esm/Environment.js.map +1 -1
  587. package/lib/esm/FeatureIndex.d.ts +39 -39
  588. package/lib/esm/FeatureIndex.js +57 -57
  589. package/lib/esm/FeatureIndex.js.map +1 -1
  590. package/lib/esm/FeatureSymbology.d.ts +449 -444
  591. package/lib/esm/FeatureSymbology.d.ts.map +1 -1
  592. package/lib/esm/FeatureSymbology.js +615 -609
  593. package/lib/esm/FeatureSymbology.js.map +1 -1
  594. package/lib/esm/FeatureTable.d.ts +255 -141
  595. package/lib/esm/FeatureTable.d.ts.map +1 -1
  596. package/lib/esm/FeatureTable.js +476 -272
  597. package/lib/esm/FeatureTable.js.map +1 -1
  598. package/lib/esm/Fonts.d.ts +51 -51
  599. package/lib/esm/Fonts.d.ts.map +1 -1
  600. package/lib/esm/Fonts.js +49 -49
  601. package/lib/esm/Frustum.d.ts +114 -114
  602. package/lib/esm/Frustum.js +288 -288
  603. package/lib/esm/GeoCoordinateServices.d.ts +123 -119
  604. package/lib/esm/GeoCoordinateServices.d.ts.map +1 -1
  605. package/lib/esm/GeoCoordinateServices.js +77 -76
  606. package/lib/esm/GeoCoordinateServices.js.map +1 -1
  607. package/lib/esm/GeometryContainment.d.ts +28 -28
  608. package/lib/esm/GeometryContainment.js +8 -8
  609. package/lib/esm/GeometryParams.d.ts +130 -130
  610. package/lib/esm/GeometryParams.js +170 -170
  611. package/lib/esm/GeometrySummary.d.ts +45 -45
  612. package/lib/esm/GeometrySummary.js +20 -20
  613. package/lib/esm/Gradient.d.ts +139 -139
  614. package/lib/esm/Gradient.js +450 -452
  615. package/lib/esm/Gradient.js.map +1 -1
  616. package/lib/esm/GraphicParams.d.ts +58 -58
  617. package/lib/esm/GraphicParams.js +81 -81
  618. package/lib/esm/GraphicParams.js.map +1 -1
  619. package/lib/esm/GroundPlane.d.ts +52 -52
  620. package/lib/esm/GroundPlane.d.ts.map +1 -1
  621. package/lib/esm/GroundPlane.js +60 -60
  622. package/lib/esm/GroundPlane.js.map +1 -1
  623. package/lib/esm/HSLColor.d.ts +20 -20
  624. package/lib/esm/HSLColor.js +28 -28
  625. package/lib/esm/HSLColor.js.map +1 -1
  626. package/lib/esm/HSVColor.d.ts +30 -30
  627. package/lib/esm/HSVColor.js +55 -55
  628. package/lib/esm/HSVColor.js.map +1 -1
  629. package/lib/esm/HiddenLine.d.ts +97 -97
  630. package/lib/esm/HiddenLine.js +157 -159
  631. package/lib/esm/HiddenLine.js.map +1 -1
  632. package/lib/esm/Hilite.d.ts +50 -50
  633. package/lib/esm/Hilite.js +61 -61
  634. package/lib/esm/Hilite.js.map +1 -1
  635. package/lib/esm/IModel.d.ts +358 -359
  636. package/lib/esm/IModel.d.ts.map +1 -1
  637. package/lib/esm/IModel.js +343 -342
  638. package/lib/esm/IModel.js.map +1 -1
  639. package/lib/esm/IModelError.d.ts +42 -42
  640. package/lib/esm/IModelError.d.ts.map +1 -1
  641. package/lib/esm/IModelError.js +56 -56
  642. package/lib/esm/IModelError.js.map +1 -1
  643. package/lib/esm/IModelVersion.d.ts +68 -68
  644. package/lib/esm/IModelVersion.d.ts.map +1 -1
  645. package/lib/esm/IModelVersion.js +75 -75
  646. package/lib/esm/Image.d.ts +86 -86
  647. package/lib/esm/Image.js +120 -120
  648. package/lib/esm/Image.js.map +1 -1
  649. package/lib/esm/IpcAppProps.d.ts +141 -141
  650. package/lib/esm/IpcAppProps.js +19 -19
  651. package/lib/esm/LightSettings.d.ts +224 -224
  652. package/lib/esm/LightSettings.js +297 -301
  653. package/lib/esm/LightSettings.js.map +1 -1
  654. package/lib/esm/LinePixels.d.ts +34 -34
  655. package/lib/esm/LinePixels.js +39 -39
  656. package/lib/esm/Localization.d.ts +117 -113
  657. package/lib/esm/Localization.d.ts.map +1 -1
  658. package/lib/esm/Localization.js +29 -29
  659. package/lib/esm/Localization.js.map +1 -1
  660. package/lib/esm/MapImagerySettings.d.ts +62 -62
  661. package/lib/esm/MapImagerySettings.d.ts.map +1 -1
  662. package/lib/esm/MapImagerySettings.js +76 -76
  663. package/lib/esm/MapImagerySettings.js.map +1 -1
  664. package/lib/esm/MapLayerSettings.d.ts +272 -272
  665. package/lib/esm/MapLayerSettings.d.ts.map +1 -1
  666. package/lib/esm/MapLayerSettings.js +399 -403
  667. package/lib/esm/MapLayerSettings.js.map +1 -1
  668. package/lib/esm/MassProperties.d.ts +64 -64
  669. package/lib/esm/MassProperties.js +20 -20
  670. package/lib/esm/MaterialProps.d.ts +165 -153
  671. package/lib/esm/MaterialProps.d.ts.map +1 -1
  672. package/lib/esm/MaterialProps.js +34 -32
  673. package/lib/esm/MaterialProps.js.map +1 -1
  674. package/lib/esm/ModelClipGroup.d.ts +67 -67
  675. package/lib/esm/ModelClipGroup.js +91 -93
  676. package/lib/esm/ModelClipGroup.js.map +1 -1
  677. package/lib/esm/ModelGeometryChanges.d.ts +107 -107
  678. package/lib/esm/ModelGeometryChanges.d.ts.map +1 -1
  679. package/lib/esm/ModelGeometryChanges.js +80 -80
  680. package/lib/esm/ModelProps.d.ts +67 -67
  681. package/lib/esm/ModelProps.js +8 -8
  682. package/lib/esm/NativeAppProps.d.ts +122 -122
  683. package/lib/esm/NativeAppProps.d.ts.map +1 -1
  684. package/lib/esm/NativeAppProps.js +27 -27
  685. package/lib/esm/OctEncodedNormal.d.ts +33 -33
  686. package/lib/esm/OctEncodedNormal.js +93 -93
  687. package/lib/esm/PlanProjectionSettings.d.ts +47 -47
  688. package/lib/esm/PlanProjectionSettings.js +59 -59
  689. package/lib/esm/PlanProjectionSettings.js.map +1 -1
  690. package/lib/esm/PlanarClipMask.d.ts +177 -177
  691. package/lib/esm/PlanarClipMask.js +133 -132
  692. package/lib/esm/PlanarClipMask.js.map +1 -1
  693. package/lib/esm/QPoint.d.ts +479 -479
  694. package/lib/esm/QPoint.js +813 -815
  695. package/lib/esm/QPoint.js.map +1 -1
  696. package/lib/esm/RealityDataAccessProps.d.ts +41 -41
  697. package/lib/esm/RealityDataAccessProps.js +16 -16
  698. package/lib/esm/RealityModelDisplaySettings.d.ts +183 -183
  699. package/lib/esm/RealityModelDisplaySettings.d.ts.map +1 -1
  700. package/lib/esm/RealityModelDisplaySettings.js +138 -137
  701. package/lib/esm/RealityModelDisplaySettings.js.map +1 -1
  702. package/lib/esm/Render.d.ts +89 -89
  703. package/lib/esm/Render.js +165 -165
  704. package/lib/esm/RenderMaterial.d.ts +58 -58
  705. package/lib/esm/RenderMaterial.js +71 -72
  706. package/lib/esm/RenderMaterial.js.map +1 -1
  707. package/lib/esm/RenderSchedule.d.ts +557 -543
  708. package/lib/esm/RenderSchedule.d.ts.map +1 -1
  709. package/lib/esm/RenderSchedule.js +1025 -999
  710. package/lib/esm/RenderSchedule.js.map +1 -1
  711. package/lib/esm/RenderTexture.d.ts +70 -70
  712. package/lib/esm/RenderTexture.d.ts.map +1 -1
  713. package/lib/esm/RenderTexture.js +55 -55
  714. package/lib/esm/RenderTexture.js.map +1 -1
  715. package/lib/esm/RgbColor.d.ts +47 -47
  716. package/lib/esm/RgbColor.js +73 -73
  717. package/lib/esm/RpcInterface.d.ts +42 -33
  718. package/lib/esm/RpcInterface.d.ts.map +1 -1
  719. package/lib/esm/RpcInterface.js +154 -133
  720. package/lib/esm/RpcInterface.js.map +1 -1
  721. package/lib/esm/RpcManager.d.ts +40 -40
  722. package/lib/esm/RpcManager.js +51 -51
  723. package/lib/esm/RpcManager.js.map +1 -1
  724. package/lib/esm/SessionProps.d.ts +16 -16
  725. package/lib/esm/SessionProps.js +8 -8
  726. package/lib/esm/SkyBox.d.ts +217 -215
  727. package/lib/esm/SkyBox.d.ts.map +1 -1
  728. package/lib/esm/SkyBox.js +204 -203
  729. package/lib/esm/SkyBox.js.map +1 -1
  730. package/lib/esm/Snapping.d.ts +49 -49
  731. package/lib/esm/Snapping.js +8 -8
  732. package/lib/esm/SolarCalculate.d.ts +27 -27
  733. package/lib/esm/SolarCalculate.js +204 -204
  734. package/lib/esm/SolarShadows.d.ts +35 -35
  735. package/lib/esm/SolarShadows.js +58 -58
  736. package/lib/esm/SolarShadows.js.map +1 -1
  737. package/lib/esm/SpatialClassification.d.ts +208 -208
  738. package/lib/esm/SpatialClassification.js +333 -334
  739. package/lib/esm/SpatialClassification.js.map +1 -1
  740. package/lib/esm/SubCategoryAppearance.d.ts +91 -91
  741. package/lib/esm/SubCategoryAppearance.js +93 -92
  742. package/lib/esm/SubCategoryAppearance.js.map +1 -1
  743. package/lib/esm/SubCategoryOverride.d.ts +46 -46
  744. package/lib/esm/SubCategoryOverride.js +101 -100
  745. package/lib/esm/SubCategoryOverride.js.map +1 -1
  746. package/lib/esm/TerrainSettings.d.ts +82 -82
  747. package/lib/esm/TerrainSettings.d.ts.map +1 -1
  748. package/lib/esm/TerrainSettings.js +96 -98
  749. package/lib/esm/TerrainSettings.js.map +1 -1
  750. package/lib/esm/TextureMapping.d.ts +151 -118
  751. package/lib/esm/TextureMapping.d.ts.map +1 -1
  752. package/lib/esm/TextureMapping.js +176 -170
  753. package/lib/esm/TextureMapping.js.map +1 -1
  754. package/lib/esm/TextureProps.d.ts +65 -65
  755. package/lib/esm/TextureProps.js +25 -25
  756. package/lib/esm/ThematicDisplay.d.ts +230 -230
  757. package/lib/esm/ThematicDisplay.js +337 -337
  758. package/lib/esm/ThematicDisplay.js.map +1 -1
  759. package/lib/esm/Thumbnail.d.ts +26 -26
  760. package/lib/esm/Thumbnail.js +8 -8
  761. package/lib/esm/TileProps.d.ts +88 -82
  762. package/lib/esm/TileProps.d.ts.map +1 -1
  763. package/lib/esm/TileProps.js +25 -25
  764. package/lib/esm/TileProps.js.map +1 -1
  765. package/lib/esm/Tween.d.ts +191 -191
  766. package/lib/esm/Tween.d.ts.map +1 -1
  767. package/lib/esm/Tween.js +565 -565
  768. package/lib/esm/TxnAction.d.ts +21 -21
  769. package/lib/esm/TxnAction.js +26 -26
  770. package/lib/esm/ViewDetails.d.ts +125 -125
  771. package/lib/esm/ViewDetails.js +162 -161
  772. package/lib/esm/ViewDetails.js.map +1 -1
  773. package/lib/esm/ViewFlags.d.ts +287 -287
  774. package/lib/esm/ViewFlags.d.ts.map +1 -1
  775. package/lib/esm/ViewFlags.js +364 -364
  776. package/lib/esm/ViewFlags.js.map +1 -1
  777. package/lib/esm/ViewProps.d.ts +205 -205
  778. package/lib/esm/ViewProps.js +8 -8
  779. package/lib/esm/WhiteOnWhiteReversalSettings.d.ts +36 -36
  780. package/lib/esm/WhiteOnWhiteReversalSettings.js +34 -33
  781. package/lib/esm/WhiteOnWhiteReversalSettings.js.map +1 -1
  782. package/lib/esm/core-common.d.ts +244 -244
  783. package/lib/esm/core-common.d.ts.map +1 -1
  784. package/lib/esm/core-common.js +248 -248
  785. package/lib/esm/core-common.js.map +1 -1
  786. package/lib/esm/domains/FunctionalElementProps.d.ts +11 -11
  787. package/lib/esm/domains/FunctionalElementProps.js +8 -8
  788. package/lib/esm/domains/GenericElementProps.d.ts +18 -18
  789. package/lib/esm/domains/GenericElementProps.js +8 -8
  790. package/lib/esm/geometry/AdditionalTransform.d.ts +84 -84
  791. package/lib/esm/geometry/AdditionalTransform.js +80 -80
  792. package/lib/esm/geometry/AreaPattern.d.ts +82 -82
  793. package/lib/esm/geometry/AreaPattern.js +200 -201
  794. package/lib/esm/geometry/AreaPattern.js.map +1 -1
  795. package/lib/esm/geometry/BoundingSphere.d.ts +27 -27
  796. package/lib/esm/geometry/BoundingSphere.js +40 -40
  797. package/lib/esm/geometry/BoundingSphere.js.map +1 -1
  798. package/lib/esm/geometry/Cartographic.d.ts +137 -137
  799. package/lib/esm/geometry/Cartographic.js +341 -340
  800. package/lib/esm/geometry/Cartographic.js.map +1 -1
  801. package/lib/esm/geometry/CoordinateReferenceSystem.d.ts +269 -269
  802. package/lib/esm/geometry/CoordinateReferenceSystem.d.ts.map +1 -1
  803. package/lib/esm/geometry/CoordinateReferenceSystem.js +253 -254
  804. package/lib/esm/geometry/CoordinateReferenceSystem.js.map +1 -1
  805. package/lib/esm/geometry/ElementGeometry.d.ts +402 -402
  806. package/lib/esm/geometry/ElementGeometry.d.ts.map +1 -1
  807. package/lib/esm/geometry/ElementGeometry.js +1716 -1716
  808. package/lib/esm/geometry/ElementGeometry.js.map +1 -1
  809. package/lib/esm/geometry/ElementGeometryFB.d.ts +2372 -2372
  810. package/lib/esm/geometry/ElementGeometryFB.js +3811 -3811
  811. package/lib/esm/geometry/ElementGeometryFB.js.map +1 -1
  812. package/lib/esm/geometry/FrustumPlanes.d.ts +83 -81
  813. package/lib/esm/geometry/FrustumPlanes.d.ts.map +1 -1
  814. package/lib/esm/geometry/FrustumPlanes.js +223 -189
  815. package/lib/esm/geometry/FrustumPlanes.js.map +1 -1
  816. package/lib/esm/geometry/GeodeticDatum.d.ts +409 -409
  817. package/lib/esm/geometry/GeodeticDatum.d.ts.map +1 -1
  818. package/lib/esm/geometry/GeodeticDatum.js +389 -390
  819. package/lib/esm/geometry/GeodeticDatum.js.map +1 -1
  820. package/lib/esm/geometry/GeodeticEllipsoid.d.ts +72 -72
  821. package/lib/esm/geometry/GeodeticEllipsoid.js +67 -68
  822. package/lib/esm/geometry/GeodeticEllipsoid.js.map +1 -1
  823. package/lib/esm/geometry/GeometryStream.d.ts +347 -347
  824. package/lib/esm/geometry/GeometryStream.d.ts.map +1 -1
  825. package/lib/esm/geometry/GeometryStream.js +463 -464
  826. package/lib/esm/geometry/GeometryStream.js.map +1 -1
  827. package/lib/esm/geometry/ImageGraphic.d.ts +74 -74
  828. package/lib/esm/geometry/ImageGraphic.d.ts.map +1 -1
  829. package/lib/esm/geometry/ImageGraphic.js +93 -93
  830. package/lib/esm/geometry/LineStyle.d.ts +71 -71
  831. package/lib/esm/geometry/LineStyle.js +126 -126
  832. package/lib/esm/geometry/Placement.d.ts +95 -95
  833. package/lib/esm/geometry/Placement.d.ts.map +1 -1
  834. package/lib/esm/geometry/Placement.js +126 -126
  835. package/lib/esm/geometry/Projection.d.ts +251 -251
  836. package/lib/esm/geometry/Projection.d.ts.map +1 -1
  837. package/lib/esm/geometry/Projection.js +192 -192
  838. package/lib/esm/geometry/Projection.js.map +1 -1
  839. package/lib/esm/geometry/TextString.d.ts +55 -55
  840. package/lib/esm/geometry/TextString.js +61 -61
  841. package/lib/esm/geometry/TextString.js.map +1 -1
  842. package/lib/esm/ipc/IpcSession.d.ts +23 -23
  843. package/lib/esm/ipc/IpcSession.js +23 -23
  844. package/lib/esm/ipc/IpcSocket.d.ts +96 -96
  845. package/lib/esm/ipc/IpcSocket.d.ts.map +1 -1
  846. package/lib/esm/ipc/IpcSocket.js +12 -12
  847. package/lib/esm/ipc/IpcWebSocket.d.ts +60 -61
  848. package/lib/esm/ipc/IpcWebSocket.d.ts.map +1 -1
  849. package/lib/esm/ipc/IpcWebSocket.js +143 -145
  850. package/lib/esm/ipc/IpcWebSocket.js.map +1 -1
  851. package/lib/esm/ipc/IpcWebSocketTransport.d.ts +15 -15
  852. package/lib/esm/ipc/IpcWebSocketTransport.js +156 -156
  853. package/lib/esm/ipc/IpcWebSocketTransport.js.map +1 -1
  854. package/lib/esm/rpc/DevToolsRpcInterface.d.ts +32 -32
  855. package/lib/esm/rpc/DevToolsRpcInterface.d.ts.map +1 -1
  856. package/lib/esm/rpc/DevToolsRpcInterface.js +49 -44
  857. package/lib/esm/rpc/DevToolsRpcInterface.js.map +1 -1
  858. package/lib/esm/rpc/IModelReadRpcInterface.d.ts +99 -99
  859. package/lib/esm/rpc/IModelReadRpcInterface.d.ts.map +1 -1
  860. package/lib/esm/rpc/IModelReadRpcInterface.js +118 -117
  861. package/lib/esm/rpc/IModelReadRpcInterface.js.map +1 -1
  862. package/lib/esm/rpc/IModelTileRpcInterface.d.ts +49 -61
  863. package/lib/esm/rpc/IModelTileRpcInterface.d.ts.map +1 -1
  864. package/lib/esm/rpc/IModelTileRpcInterface.js +76 -92
  865. package/lib/esm/rpc/IModelTileRpcInterface.js.map +1 -1
  866. package/lib/esm/rpc/SnapshotIModelRpcInterface.d.ts +23 -23
  867. package/lib/esm/rpc/SnapshotIModelRpcInterface.js +45 -44
  868. package/lib/esm/rpc/SnapshotIModelRpcInterface.js.map +1 -1
  869. package/lib/esm/rpc/TestRpcManager.d.ts +20 -20
  870. package/lib/esm/rpc/TestRpcManager.js +36 -36
  871. package/lib/esm/rpc/WipRpcInterface.d.ts +29 -29
  872. package/lib/esm/rpc/WipRpcInterface.js +37 -36
  873. package/lib/esm/rpc/WipRpcInterface.js.map +1 -1
  874. package/lib/esm/rpc/core/RpcConfiguration.d.ts +111 -111
  875. package/lib/esm/rpc/core/RpcConfiguration.d.ts.map +1 -1
  876. package/lib/esm/rpc/core/RpcConfiguration.js +185 -184
  877. package/lib/esm/rpc/core/RpcConfiguration.js.map +1 -1
  878. package/lib/esm/rpc/core/RpcConstants.d.ts +90 -90
  879. package/lib/esm/rpc/core/RpcConstants.js +106 -106
  880. package/lib/esm/rpc/core/RpcControl.d.ts +54 -57
  881. package/lib/esm/rpc/core/RpcControl.d.ts.map +1 -1
  882. package/lib/esm/rpc/core/RpcControl.js +144 -141
  883. package/lib/esm/rpc/core/RpcControl.js.map +1 -1
  884. package/lib/esm/rpc/core/RpcInvocation.d.ts +89 -89
  885. package/lib/esm/rpc/core/RpcInvocation.d.ts.map +1 -1
  886. package/lib/esm/rpc/core/RpcInvocation.js +253 -254
  887. package/lib/esm/rpc/core/RpcInvocation.js.map +1 -1
  888. package/lib/esm/rpc/core/RpcMarshaling.d.ts +35 -35
  889. package/lib/esm/rpc/core/RpcMarshaling.js +152 -152
  890. package/lib/esm/rpc/core/RpcOperation.d.ts +67 -67
  891. package/lib/esm/rpc/core/RpcOperation.d.ts.map +1 -1
  892. package/lib/esm/rpc/core/RpcOperation.js +130 -129
  893. package/lib/esm/rpc/core/RpcOperation.js.map +1 -1
  894. package/lib/esm/rpc/core/RpcPendingQueue.d.ts +21 -21
  895. package/lib/esm/rpc/core/RpcPendingQueue.js +90 -91
  896. package/lib/esm/rpc/core/RpcPendingQueue.js.map +1 -1
  897. package/lib/esm/rpc/core/RpcProtocol.d.ts +132 -132
  898. package/lib/esm/rpc/core/RpcProtocol.d.ts.map +1 -1
  899. package/lib/esm/rpc/core/RpcProtocol.js +124 -123
  900. package/lib/esm/rpc/core/RpcProtocol.js.map +1 -1
  901. package/lib/esm/rpc/core/RpcPush.d.ts +68 -68
  902. package/lib/esm/rpc/core/RpcPush.d.ts.map +1 -1
  903. package/lib/esm/rpc/core/RpcPush.js +121 -119
  904. package/lib/esm/rpc/core/RpcPush.js.map +1 -1
  905. package/lib/esm/rpc/core/RpcRegistry.d.ts +48 -48
  906. package/lib/esm/rpc/core/RpcRegistry.js +194 -195
  907. package/lib/esm/rpc/core/RpcRegistry.js.map +1 -1
  908. package/lib/esm/rpc/core/RpcRequest.d.ts +186 -186
  909. package/lib/esm/rpc/core/RpcRequest.d.ts.map +1 -1
  910. package/lib/esm/rpc/core/RpcRequest.js +474 -473
  911. package/lib/esm/rpc/core/RpcRequest.js.map +1 -1
  912. package/lib/esm/rpc/core/RpcRequestContext.d.ts +14 -14
  913. package/lib/esm/rpc/core/RpcRequestContext.js +1 -1
  914. package/lib/esm/rpc/core/RpcRoutingToken.d.ts +12 -12
  915. package/lib/esm/rpc/core/RpcRoutingToken.d.ts.map +1 -1
  916. package/lib/esm/rpc/core/RpcRoutingToken.js +21 -20
  917. package/lib/esm/rpc/core/RpcRoutingToken.js.map +1 -1
  918. package/lib/esm/rpc/core/RpcSessionInvocation.d.ts +10 -10
  919. package/lib/esm/rpc/core/RpcSessionInvocation.js +56 -56
  920. package/lib/esm/rpc/core/RpcSessionInvocation.js.map +1 -1
  921. package/lib/esm/rpc/web/BentleyCloudRpcManager.d.ts +48 -46
  922. package/lib/esm/rpc/web/BentleyCloudRpcManager.d.ts.map +1 -1
  923. package/lib/esm/rpc/web/BentleyCloudRpcManager.js +72 -68
  924. package/lib/esm/rpc/web/BentleyCloudRpcManager.js.map +1 -1
  925. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.d.ts +33 -33
  926. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.js +137 -139
  927. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.js.map +1 -1
  928. package/lib/esm/rpc/web/OpenAPI.d.ts +140 -140
  929. package/lib/esm/rpc/web/OpenAPI.js +56 -56
  930. package/lib/esm/rpc/web/OpenAPI.js.map +1 -1
  931. package/lib/esm/rpc/web/RpcMultipart.d.ts +35 -35
  932. package/lib/esm/rpc/web/RpcMultipart.js +47 -46
  933. package/lib/esm/rpc/web/RpcMultipart.js.map +1 -1
  934. package/lib/esm/rpc/web/WebAppRpcLogging.d.ts +28 -28
  935. package/lib/esm/rpc/web/WebAppRpcLogging.js +136 -136
  936. package/lib/esm/rpc/web/WebAppRpcProtocol.d.ts +89 -89
  937. package/lib/esm/rpc/web/WebAppRpcProtocol.js +112 -112
  938. package/lib/esm/rpc/web/WebAppRpcProtocol.js.map +1 -1
  939. package/lib/esm/rpc/web/WebAppRpcRequest.d.ts +67 -67
  940. package/lib/esm/rpc/web/WebAppRpcRequest.d.ts.map +1 -1
  941. package/lib/esm/rpc/web/WebAppRpcRequest.js +236 -235
  942. package/lib/esm/rpc/web/WebAppRpcRequest.js.map +1 -1
  943. package/lib/esm/rpc/web/multipart/RpcMultipartParser.d.ts +32 -32
  944. package/lib/esm/rpc/web/multipart/RpcMultipartParser.js +369 -369
  945. package/lib/esm/tile/B3dmTileIO.d.ts +19 -19
  946. package/lib/esm/tile/B3dmTileIO.js +62 -62
  947. package/lib/esm/tile/B3dmTileIO.js.map +1 -1
  948. package/lib/esm/tile/CompositeTileIO.d.ts +15 -15
  949. package/lib/esm/tile/CompositeTileIO.js +22 -22
  950. package/lib/esm/tile/CompositeTileIO.js.map +1 -1
  951. package/lib/esm/tile/ElementGraphics.d.ts +145 -145
  952. package/lib/esm/tile/ElementGraphics.d.ts.map +1 -1
  953. package/lib/esm/tile/ElementGraphics.js +8 -8
  954. package/lib/esm/tile/GltfTileIO.d.ts +45 -45
  955. package/lib/esm/tile/GltfTileIO.d.ts.map +1 -1
  956. package/lib/esm/tile/GltfTileIO.js +105 -105
  957. package/lib/esm/tile/GltfTileIO.js.map +1 -1
  958. package/lib/esm/tile/I3dmTileIO.d.ts +20 -20
  959. package/lib/esm/tile/I3dmTileIO.js +36 -36
  960. package/lib/esm/tile/I3dmTileIO.js.map +1 -1
  961. package/lib/esm/tile/IModelTileIO.d.ts +77 -75
  962. package/lib/esm/tile/IModelTileIO.d.ts.map +1 -1
  963. package/lib/esm/tile/IModelTileIO.js +93 -90
  964. package/lib/esm/tile/IModelTileIO.js.map +1 -1
  965. package/lib/esm/tile/PntsTileIO.d.ts +17 -17
  966. package/lib/esm/tile/PntsTileIO.js +22 -22
  967. package/lib/esm/tile/PntsTileIO.js.map +1 -1
  968. package/lib/esm/tile/TileIO.d.ts +66 -66
  969. package/lib/esm/tile/TileIO.js +110 -110
  970. package/lib/esm/tile/TileMetadata.d.ts +240 -228
  971. package/lib/esm/tile/TileMetadata.d.ts.map +1 -1
  972. package/lib/esm/tile/TileMetadata.js +677 -661
  973. package/lib/esm/tile/TileMetadata.js.map +1 -1
  974. package/lib/esm/tile/Tileset3dSchema.d.ts +97 -0
  975. package/lib/esm/tile/Tileset3dSchema.d.ts.map +1 -0
  976. package/lib/esm/tile/Tileset3dSchema.js +9 -0
  977. package/lib/esm/tile/Tileset3dSchema.js.map +1 -0
  978. package/package.json +15 -18
  979. package/lib/cjs/CloudStorage.d.ts +0 -63
  980. package/lib/cjs/CloudStorage.d.ts.map +0 -1
  981. package/lib/cjs/CloudStorage.js +0 -114
  982. package/lib/cjs/CloudStorage.js.map +0 -1
  983. package/lib/cjs/CloudStorageTileCache.d.ts +0 -28
  984. package/lib/cjs/CloudStorageTileCache.d.ts.map +0 -1
  985. package/lib/cjs/CloudStorageTileCache.js +0 -67
  986. package/lib/cjs/CloudStorageTileCache.js.map +0 -1
  987. package/lib/esm/CloudStorage.d.ts +0 -63
  988. package/lib/esm/CloudStorage.d.ts.map +0 -1
  989. package/lib/esm/CloudStorage.js +0 -110
  990. package/lib/esm/CloudStorage.js.map +0 -1
  991. package/lib/esm/CloudStorageTileCache.d.ts +0 -28
  992. package/lib/esm/CloudStorageTileCache.d.ts.map +0 -1
  993. package/lib/esm/CloudStorageTileCache.js +0 -63
  994. package/lib/esm/CloudStorageTileCache.js.map +0 -1
@@ -1,544 +1,558 @@
1
- /** @packageDocumentation
2
- * @module DisplayStyles
3
- */
4
- import { CompressedId64Set, Constructor, Id64String } from "@itwin/core-bentley";
5
- import { EntityReferenceSet } from "./EntityReference";
6
- import { ClipVector, Plane3dByOriginAndUnitNormal, Point4d, Range1d, Transform, Vector3d, XYAndZ } from "@itwin/core-geometry";
7
- import { RgbColor } from "./RgbColor";
8
- import { FeatureAppearance, FeatureOverrides } from "./FeatureSymbology";
9
- /** Namespace containing types that collectively define a script that animates the contents of a view by adjusting the visibility, position,
10
- * and/or symbology of groups of elements over time. A [[RenderSchedule.Script]] is hosted by a [RenderTimeline]($backend) element. The script
11
- * can be associated with a [DisplayStyleState]($frontend) by way of its [[DisplayStyleSettings.renderTimeline]] property.
12
- * @public
13
- */
14
- export declare namespace RenderSchedule {
15
- /** Defines how two interpolate between two entries in a [[RenderSchedule.Timeline]].
16
- * @note Currently only Linear and Step are supported. Any other value is treated as Step.
17
- * @see [[RenderSchedule.TimelineEntry]].
18
- */
19
- enum Interpolation {
20
- /** Each timeline entry's value is discrete - the timeline jumps from one entry's value directly to another. */
21
- Step = 1,
22
- /** Given two entries on the timeline and a timepoint in between them, linearly interpolate based on the timepoint's distance between the
23
- * two entries.
24
- */
25
- Linear = 2
26
- }
27
- /** JSON representation of a [[RenderSchedule.TimelineEntry]]. */
28
- interface TimelineEntryProps {
29
- /** The time point in seconds in the [Unix Epoch](https://en.wikipedia.org/wiki/Unix_time). */
30
- time: number;
31
- /** How to interpolate from this entry to the next entry in the timeline.
32
- * Currently, anything other than [[RenderSchedule.Interpolation.Linear]] is treated as [[RenderSchedule.Interpolation.Step]].
33
- * Additional interpolation modes may become supported in the future.
34
- */
35
- interpolation?: Interpolation;
36
- }
37
- /** JSON representation of a [[RenderSchedule.VisibilityEntry]]. */
38
- interface VisibilityEntryProps extends TimelineEntryProps {
39
- /** Visibility of the geometry from 0 (invisible) to 100 (fully visible), with intermediate values appearing increasingly less transparent.
40
- * Default: 100 (fully visible).
41
- */
42
- value?: number;
43
- }
44
- /** JSON representation of a [[RenderSchedule.ColorEntry]]. */
45
- interface ColorEntryProps extends TimelineEntryProps {
46
- /** The color applied to the geometry, with each component specified as an integer in [0, 255].
47
- * e.g., (0, 0, 0) represents black and (255, 255, 255) represents white.
48
- * If `undefined`, the geometry is displayed in its actual color.
49
- */
50
- value?: {
51
- red: number;
52
- green: number;
53
- blue: number;
54
- };
55
- }
56
- /** JSON representation of a [[RenderSchedule.CuttingPlane]]. */
57
- interface CuttingPlaneProps {
58
- /** (x,y,z) of a point on the plane. */
59
- position: number[];
60
- /** (x, y, z) of the plane direction (towards the clip) */
61
- direction: number[];
62
- /** If true, the clip plane is ignored and the geometry is displayed unclipped. */
63
- visible?: boolean;
64
- /** If true, the clip plane is ignored and the geometry is not displayed. */
65
- hidden?: boolean;
66
- }
67
- /** JSON representation of a [[RenderSchedule.CuttingPlaneEntry]]. */
68
- interface CuttingPlaneEntryProps extends TimelineEntryProps {
69
- /** The clip plane, or undefined if the geometry is not clipped. */
70
- value?: CuttingPlaneProps;
71
- }
72
- /** JSON representation of a [[RenderSchedule.TransformComponents]]. */
73
- interface TransformComponentsProps {
74
- /** (x, y, z) of position - applied after rotation. */
75
- position?: number[];
76
- /** Quaternion representing rotation. */
77
- orientation?: number[];
78
- /** (x, y, z) of pivot - applied before rotation. */
79
- pivot?: number[];
80
- }
81
- /** JSON representation of a [Transform]($core-geometry) associated with a [[RenderSchedule.TransformEntryProps]]. */
82
- interface TransformProps extends TransformComponentsProps {
83
- /** 3 X 4 transformation matrix containing 3 arrays of matrix rows consisting of 4 numbers each: [qx qy qz ax]
84
- * where the fourth columnn in each row holds the translation.
85
- * `undefined` is equivalent to an identity transform.
86
- * This transform is only used if position, orientation, and/or pivot are undefined.
87
- */
88
- transform?: number[][];
89
- }
90
- /** JSON representation of a [[RenderSchedule.TransformEntry]]. */
91
- interface TransformEntryProps extends TimelineEntryProps {
92
- /** The transformation matrix, with `undefined` corresponding to an identity matrix. */
93
- value?: TransformProps;
94
- }
95
- /** JSON representation of a [[RenderSchedule.Timeline]]. */
96
- interface TimelineProps {
97
- /** Timeline controlling the visibility of the associated geometry. */
98
- visibilityTimeline?: VisibilityEntryProps[];
99
- /** Timeline controlling the colors of the associated geometry. */
100
- colorTimeline?: ColorEntryProps[];
101
- /** Timeline applying transforms to the associated geometry. */
102
- transformTimeline?: TransformEntryProps[];
103
- /** Timeline applying [ClipVector]($core-geometry)s to the associated geometry. */
104
- cuttingPlaneTimeline?: CuttingPlaneEntryProps[];
105
- }
106
- /** JSON representation of an [[RenderSchedule.ElementTimeline]]. */
107
- interface ElementTimelineProps extends TimelineProps {
108
- /** A positive integer that uniquely identifies this timeline among all element timelines in the [[RenderSchedule.Script]]. */
109
- batchId: number;
110
- /** The Ids of the elements to which this timeline applies.
111
- * @note Prefer the compressed representation - lists of element Ids can be comparatively enormous.
112
- * @note For a [[DisplayStyleSettingsProps]] associated with a [DisplayStyleState]($frontend) obtained via [IModelConnection.Views.load]($frontend),
113
- * this property will be an empty `CompressedId64Set`. They are omitted to conserve bandwidth and memory because they are not needed for display on the frontend.
114
- */
115
- elementIds: Id64String[] | CompressedId64Set;
116
- }
117
- /** JSON representation of a [[RenderSchedule.ModelTimeline]]. */
118
- interface ModelTimelineProps extends TimelineProps {
119
- /** The Id of the [GeometricModelState]($frontend) to which the timeline applies. */
120
- modelId: Id64String;
121
- /** @alpha */
122
- realityModelUrl?: string;
123
- /** Timelines affecting groups of elements. */
124
- elementTimelines: ElementTimelineProps[];
125
- }
126
- /** JSON representation of a [[RenderSchedule.Script]]. */
127
- type ScriptProps = ModelTimelineProps[];
128
- /** Describes the value of some property at a specific point along a [[RenderSchedule.Timeline]].
129
- * @see [[RenderSchedule.VisibilityEntry]]
130
- * @see [[RenderSchedule.ColorEntry]]
131
- * @see [[RenderSchedule.TransformEntry]]
132
- * @see [[RenderSchedule.CuttingPlaneEntry]]
133
- */
134
- class TimelineEntry {
135
- /** The time point in seconds in the [Unix Epoch](https://en.wikipedia.org/wiki/Unix_time). */
136
- readonly time: number;
137
- /** How to interpolate from this entry to the next entry in the timeline. */
138
- readonly interpolation: Interpolation;
139
- constructor(props: TimelineEntryProps);
140
- toJSON(): TimelineEntryProps;
141
- compareTo(other: TimelineEntry): number;
142
- equals(other: TimelineEntry): boolean;
143
- }
144
- /** A timeline entry that controls the visibility of the associated geometry. */
145
- class VisibilityEntry extends TimelineEntry {
146
- /** The visibility of the geometry at this point on the timeline, in the range [0, 100] where 0 is completely invisible, 100 is completely visible,
147
- * and values in between indicate increasing opacity.
148
- */
149
- readonly value: number;
150
- constructor(props: VisibilityEntryProps);
151
- toJSON(): VisibilityEntryProps;
152
- compareTo(other: VisibilityEntry): number;
153
- }
154
- /** A timeline entry controlling the color of the affected geometry. */
155
- class ColorEntry extends TimelineEntry {
156
- /** If defined, the color in which to draw the geometry. If undefined, the geometry is drawn in its actual color. */
157
- readonly value: RgbColor | undefined;
158
- constructor(props: ColorEntryProps);
159
- toJSON(): ColorEntryProps;
160
- compareTo(other: ColorEntry): number;
161
- }
162
- /** Describes the components of a [[RenderSchedule.TransformEntry]] as a rotation around a pivot point followed by a translation. */
163
- class TransformComponents {
164
- /** Pivot point - applied before rotation. */
165
- readonly pivot: Vector3d;
166
- /** Quaternion rotation. */
167
- readonly orientation: Point4d;
168
- /** Translation - applied after rotation. */
169
- readonly position: Vector3d;
170
- constructor(position: Vector3d, pivot: Vector3d, orientation: Point4d);
171
- static fromJSON(props: TransformComponentsProps): TransformComponents | undefined;
172
- toJSON(): TransformComponentsProps;
173
- compareTo(other: TransformComponents): number;
174
- equals(other: TransformComponents): boolean;
175
- }
176
- /** A timeline entry that applies rotation, scaling, and/or translation to the affected geometry. */
177
- class TransformEntry extends TimelineEntry {
178
- /** The transform matrix to be applied to the geometry, used only if [[components]] is not defined. */
179
- readonly value: Readonly<Transform>;
180
- /** The transform represented as a rotation about a pivot point followed by a translation. If undefined, [[value]] is used instead. */
181
- readonly components?: TransformComponents;
182
- constructor(props: TransformEntryProps);
183
- toJSON(): TransformEntryProps;
184
- compareTo(other: TransformEntry): number;
185
- }
186
- /** Defines a [ClipPlane]($core-geometry) associated with a [[RenderSchedule.CuttingPlaneEntry]]. */
187
- class CuttingPlane {
188
- /** A point on the plane. */
189
- readonly position: XYAndZ;
190
- /** The direction perpendicular to the plane pointing toward the clip. */
191
- readonly direction: XYAndZ;
192
- /** If true, the clip plane is ignored and the geometry is never clipped. */
193
- readonly visible: boolean;
194
- /** If true, the clip plane is ignored and the geometry is always clipped. */
195
- readonly hidden: boolean;
196
- constructor(props: CuttingPlaneProps);
197
- toJSON(): CuttingPlaneProps;
198
- compareTo(other: CuttingPlane): number;
199
- equals(other: CuttingPlane): boolean;
200
- }
201
- /** A timeline entry that applies a [ClipPlane]($core-geometry) to the affected geometry. */
202
- class CuttingPlaneEntry extends TimelineEntry {
203
- /** The definition of the [ClipPlane]($core-geometry), or undefined if this entry applies no clipping. */
204
- readonly value: CuttingPlane | undefined;
205
- constructor(props: CuttingPlaneEntryProps);
206
- toJSON(): CuttingPlaneEntryProps;
207
- compareTo(other: CuttingPlaneEntry): number;
208
- }
209
- /** Identifies a fractional position along a [[RenderSchedule.Timeline]] between any two [[RenderSchedule.TimelineEntry]]'s within a [[RenderSchedule.TimelineEntryList]].
210
- * @internal
211
- */
212
- class Interval {
213
- /** The index of the first timeline entry within the list. */
214
- lowerIndex: number;
215
- /** The index of the second timeline entry within the list. */
216
- upperIndex: number;
217
- /** The normalized distance between the two timeline entries. */
218
- fraction: number;
219
- constructor(lower?: number, upper?: number, fraction?: number);
220
- init(lower?: number, upper?: number, fraction?: number): void;
221
- }
222
- /** A list of the [[RenderSchedule.TimelineEntry]] objects within a [[RenderSchedule.Timeline]]. The type parameters are:
223
- * - T, a subclass of TimelineEntry with a `value` property specifying the value of the property controlled by the timeline at that entry's time point.
224
- * - P, the JSON representation from which T is to be constructed.
225
- * - V, the type of `T.value`.
226
- */
227
- class TimelineEntryList<T extends TimelineEntry & {
228
- readonly value: V;
229
- }, P extends TimelineEntryProps, V> implements Iterable<T> {
230
- private readonly _entries;
231
- /** The total time period represented by the entries in this list. */
232
- readonly duration: Range1d;
233
- constructor(props: P[], ctor: Constructor<T>);
234
- /** The number of entries in the list. */
235
- get length(): number;
236
- /** An iterator over the entries in the list. */
237
- [Symbol.iterator](): Iterator<T>;
238
- /** Look up an entry by its position in the list. */
239
- getEntry(index: number): T | undefined;
240
- /** Look up the value of an entry by its position in the list. */
241
- getValue(index: number): V | undefined;
242
- toJSON(): P[];
243
- compareTo(other: TimelineEntryList<T, P, V>): number;
244
- equals(other: TimelineEntryList<T, P, V>): boolean;
245
- /** @internal */
246
- findInterval(time: number, interval?: Interval): Interval | undefined;
247
- }
248
- /** A list of [[RenderSchedule.VisibilityEntry]]s within a [[RenderSchedule.Timeline]]. */
249
- class VisibilityTimelineEntries extends TimelineEntryList<VisibilityEntry, VisibilityEntryProps, number> {
250
- /** Returns the visibility value for the entry at the specified position in the list, or 100 (fully-visible) if no such entry exists. */
251
- getValue(index: number): number;
252
- }
253
- /** A list of [[RenderSchedule.TransformEntry]]s within a [[RenderSchedule.Timeline]]. */
254
- class TransformTimelineEntries extends TimelineEntryList<TransformEntry, TransformEntryProps, Readonly<Transform>> {
255
- /** Returns the transform for the entry at the specified position in the list, or an identity transform if no such entry exists. */
256
- getValue(index: number): Readonly<Transform>;
257
- }
258
- /** Specifies how to animate a set of geometry over time within a [[RenderSchedule.Script]].
259
- * A [[RenderSchedule.Script]] can contain any number of [[RenderSchedule.Timeline]]s, each affecting different sets of geometry.
260
- * @see [[RenderSchedule.ElementTimeline]] and [[RenderSchedule.ModelTimeline]].
261
- */
262
- class Timeline {
263
- /** Sequence controlling the visibility of the geometry. */
264
- readonly visibility?: VisibilityTimelineEntries;
265
- /** Sequence controlling the color of the geometry. */
266
- readonly color?: TimelineEntryList<ColorEntry, ColorEntryProps, RgbColor | undefined>;
267
- /** Sequence controlling the position, orientation, and/or scale of the geometry. */
268
- readonly transform?: TransformTimelineEntries;
269
- /** Sequence controlling how the geometry is clipped. */
270
- readonly cuttingPlane?: TimelineEntryList<CuttingPlaneEntry, CuttingPlaneEntryProps, CuttingPlane | undefined>;
271
- /** The total time period represented by this timeline. */
272
- readonly duration: Range1d;
273
- constructor(props: TimelineProps);
274
- toJSON(): TimelineProps;
275
- compareTo(other: Timeline): number;
276
- equals(other: Timeline): boolean;
277
- /** Get the visibility of the geometry at the specified time point. */
278
- getVisibility(time: number): number;
279
- /** Get the color of the geometry at the specified time point, or undefined if the color is not overridden at that time point. */
280
- getColor(time: number): RgbColor | undefined;
281
- /** Get the transform applied to the geometry at the specified time point. */
282
- getAnimationTransform(time: number): Readonly<Transform>;
283
- /** Get the clipping plane applied to the geometry at the specified time point, or undefined if the geometry is unclipped at that time point. */
284
- getCuttingPlane(time: number): Plane3dByOriginAndUnitNormal | undefined;
285
- /** Create a ClipVector from the [[RenderSchedule.CuttingPlane]] applied to the geometry at the specified time point, if any. */
286
- getClipVector(time: number): ClipVector | undefined;
287
- /** @internal */
288
- protected getFeatureAppearance(visibility: number, time: number): FeatureAppearance | undefined;
289
- }
290
- /** Specifies how to animate the geometry belonging to a set of [GeometricElement]($backend)s as part of a [[RenderSchedule.Script]]. */
291
- class ElementTimeline extends Timeline {
292
- /** A positive integer that uniquely identififes this timeline among all ElementTimelines in the [[RenderSchedule.Script]]. */
293
- readonly batchId: number;
294
- private readonly _elementIds;
295
- private constructor();
296
- static fromJSON(props?: ElementTimelineProps): ElementTimeline;
297
- toJSON(): ElementTimelineProps;
298
- get containsElementIds(): boolean;
299
- private compareElementIds;
300
- compareTo(other: ElementTimeline): number;
301
- /** @internal */
302
- static getElementIds(ids: Id64String[] | CompressedId64Set): Iterable<Id64String>;
303
- /** The Ids of the elements controlled by this timeline. */
304
- get elementIds(): Iterable<Id64String>;
305
- /** True if this timeline affects the color or transparency of the elements. */
306
- get containsFeatureOverrides(): boolean;
307
- /** If true, applying this timeline requires special tiles to be generated in which groups of elements are batched into nodes.
308
- * @internal
309
- */
310
- get requiresBatching(): boolean;
311
- /** True if this timeline affects the position, orientation, or scale of the elements. */
312
- get containsTransform(): boolean;
313
- /** @internal */
314
- addSymbologyOverrides(overrides: FeatureOverrides, time: number): void;
315
- }
316
- /** Specifies how to animate the geometry within a [GeometricModel]($backend) as part of a [[RenderSchedule.Script]]. */
317
- class ModelTimeline extends Timeline {
318
- /** The Id of the [GeometricModel]($backend) to be animated. */
319
- readonly modelId: Id64String;
320
- /** @internal */
321
- readonly realityModelUrl?: string;
322
- /** Timelines specifying how to animate groups of [GeometricElement]($backend)s within the model. */
323
- readonly elementTimelines: ReadonlyArray<ElementTimeline>;
324
- /** @internal */
325
- readonly transformBatchIds: ReadonlyArray<number>;
326
- /** True if this timeline affects the color or transparency of the geometry. */
327
- readonly containsFeatureOverrides: boolean;
328
- /** True if this timeline applies clipping to the model. */
329
- readonly containsModelClipping: boolean;
330
- /** If true, applying this timeline requires special tiles to be generated in which groups of elements are batched into nodes.
331
- * @internal
332
- */
333
- readonly requiresBatching: boolean;
334
- /** True if this timeline affects the position, orientation, or scale of the geometry. */
335
- readonly containsTransform: boolean;
336
- /** True if any [[RenderSchedule.ElementTimeline]]s exist and none of them contain any element Ids. This generally indicates that
337
- * the backend was instructed to omit the Ids to save space when supplying the script.
338
- */
339
- readonly omitsElementIds: boolean;
340
- private _maxBatchId?;
341
- /** Tile tree suppliers perform **very** frequent ordered comparisons of ModelTimelines. They need to be fast. */
342
- private readonly _cachedComparisons;
343
- /** When loading tiles we need to quickly map element Ids to batch Ids. This map is initialized on first call to [[getTimelineForElement]] to facilitate that lookup. */
344
- private _idPairToElementTimeline?;
345
- private _discreteBatchIds?;
346
- private constructor();
347
- static fromJSON(props?: ModelTimelineProps): ModelTimeline;
348
- toJSON(): ModelTimelineProps;
349
- compareTo(other: ModelTimeline): number;
350
- /** Look up the element timeline with the specified batch Id. */
351
- findByBatchId(batchId: number): ElementTimeline | undefined;
352
- /** @internal */
353
- addSymbologyOverrides(overrides: FeatureOverrides, time: number): void;
354
- /** Obtain the transform applied to the model at the specified time point, if any. */
355
- getTransform(batchId: number, time: number): Readonly<Transform> | undefined;
356
- /** Get the highest batchId of any ElementTimeline in this timeline. */
357
- get maxBatchId(): number;
358
- /** Given the two halves of an [Id64]($bentley) return the [[ElementTimeline]] containing the corresponding element.
359
- * @note The first call to this method populates a mapping for fast lookup.
360
- * @alpha
361
- */
362
- getTimelineForElement(idLo: number, idHi: number): ElementTimeline | undefined;
363
- /** The batch Ids of the subset of [[elementTimelines]] that apply a transform and/or cutting plane.
364
- * @alpha
365
- */
366
- get discreteBatchIds(): Set<number>;
367
- }
368
- /** Specifies how to animate the contents of a [ViewState]($frontend) over time. The script contains any number of [[RenderSchedule.ModelTimeline]]s, each describing how
369
- * to animate one of the models in the view.
370
- * @see [RenderTimeline]($backend) to create an [Element]($backend) to host a script.
371
- * @see [[DisplayStyleSettings.renderTimeline]] to associate a [RenderTimeline]($backend)'s script with a [DisplayStyle]($backend).
372
- * @see [DisplayStyleState.scheduleScript]($frontend) to obtain the script associated with a display style.
373
- * @see [[RenderSchedule.ScriptBuilder]] to define a new script.
374
- */
375
- class Script {
376
- /** Timelines specifying how to animate individual models within the view. */
377
- readonly modelTimelines: ReadonlyArray<ModelTimeline>;
378
- /** True if this script applies clipping to any models. */
379
- readonly containsModelClipping: boolean;
380
- /** If true, applying this timeline requires special tiles to be generated in which groups of elements are batched into nodes.
381
- * @internal
382
- */
383
- readonly requiresBatching: boolean;
384
- /** True if this script affects the position, orientation, or scale of the geometry. */
385
- readonly containsTransform: boolean;
386
- /** True if this script affects the color or transparency of the geometry. */
387
- readonly containsFeatureOverrides: boolean;
388
- /** The total time period over which this script animates. */
389
- readonly duration: Range1d;
390
- /** The batchIds of all nodes in all timelines that apply a transform.
391
- * @internal
392
- */
393
- readonly transformBatchIds: ReadonlySet<number>;
394
- /** Tile tree references perform **very** frequent ordered comparisons of Scripts. They need to be fast. */
395
- private readonly _cachedComparisons;
396
- compareTo(other: Script): number;
397
- equals(other: Script): boolean;
398
- protected constructor(props: Readonly<ScriptProps>);
399
- static fromJSON(props: Readonly<ScriptProps>): Script | undefined;
400
- toJSON(): ScriptProps;
401
- /** Look up the timeline that animates the specified model, if any. */
402
- find(modelId: Id64String): ModelTimeline | undefined;
403
- /** @internal */
404
- getTransformBatchIds(modelId: Id64String): ReadonlyArray<number> | undefined;
405
- /** @internal */
406
- getTransform(modelId: Id64String, batchId: number, time: number): Readonly<Transform> | undefined;
407
- /** @internal */
408
- addSymbologyOverrides(overrides: FeatureOverrides, time: number): void;
409
- /** Used by the [Entity.collectReferenceIds]($backend) method overrides in RenderTimeline and DisplayStyle.
410
- * @internal
411
- */
412
- discloseIds(ids: EntityReferenceSet): void;
413
- /** @internal */
414
- modelRequiresBatching(modelId: Id64String): boolean;
415
- }
416
- /** A reference to a [[RenderSchedule.Script]], optionally identifying the source of the script.
417
- * @see [DisplayStyle.loadScheduleScript]($backend) and [DisplayStyleState.scheduleScript]($frontend) to obtain the script reference for a display style on the frontend
418
- * and backend respectively.
419
- * @see [DisplayStyleState.scheduleScript]($frontend) or [DisplayStyleState.changeRenderTimeline]($frontend) to change a display style's script on the frontend.
420
- */
421
- class ScriptReference {
422
- /** The Id of the element - if any - from which the script originated.
423
- * A schedule script may originate from one of the following sources:
424
- * - A [RenderTimeline]($backend) element stored in the iModel; or
425
- * - The `scheduleScript` JSON property of a [DisplayStyle]($backend) element stored in the iModel; or
426
- * - Any other source outside of the iModel, such as code that generates the script on the frontend, a script obtained from some server, etc.
427
- *
428
- * The [[sourceId]] property identifies the Id of the element from which the script originated; an empty or invalid [Id64String]($bentley) indicates the script did not
429
- * originate from any persistent element. If the Id is valid, the contents of [[script]] are assumed to match those stored on the source element.
430
- */
431
- readonly sourceId: Id64String;
432
- /** The script defining the rendering timelines to be applied. */
433
- readonly script: Script;
434
- /** Create a reference to a [[script]] with no [[sourceId]]. */
435
- constructor(script: Script);
436
- /** Create a reference to a [[script]] with the specified [[sourceId]]. */
437
- constructor(sourceId: Id64String, script: Script);
438
- /** @internal Use one of the public constructor overloads which forward to this one. */
439
- constructor(sourceIdOrScript: Id64String | Script, scriptIfSourceId?: Script);
440
- }
441
- /** Used as part of a [[RenderSchedule.ScriptBuilder]] to define a [[RenderSchedule.Timeline]]. Functions that append
442
- * to the timeline expect entries to be appended in chronological order - i.e., you cannot append an entry that is earlier
443
- * than a previously appended entry.
444
- * @see [[RenderSchedule.ElementTimelineBuilder]] and [[RenderSchedule.ModelTimelineBuilder]].
445
- */
446
- class TimelineBuilder {
447
- /** Timeline controlling visibility. */
448
- visibility?: VisibilityEntryProps[];
449
- /** Timeline controlling color. */
450
- color?: ColorEntryProps[];
451
- /** Timeline controlling position and orientation. */
452
- transform?: TransformEntryProps[];
453
- /** Timeline controlling clipping. */
454
- cuttingPlane?: CuttingPlaneEntryProps[];
455
- /** Append a new [[RenderSchedule.VisibilityEntry]] to the timeline. `time` must be more recent than any previously-appended visibility entries. */
456
- addVisibility(time: number, visibility: number | undefined, interpolation?: Interpolation): void;
457
- /** Append a new [[RenderSchedule.ColorEntry]] to the timeline. `time` must be more recent than any previously-appended color entries. */
458
- addColor(time: number, color: RgbColor | {
459
- red: number;
460
- green: number;
461
- blue: number;
462
- } | undefined, interpolation?: Interpolation): void;
463
- /** Append a new [[RenderSchedule.CuttingPlaneEntry]] to the timeline. `time` must be more recent than any previously-appended cutting plane entries. */
464
- addCuttingPlane(time: number, plane: {
465
- position: XYAndZ;
466
- direction: XYAndZ;
467
- visible?: boolean;
468
- hidden?: boolean;
469
- } | undefined, interpolation?: Interpolation): void;
470
- /** Append a new [[RenderSchedule.TransformEntry]] to the timeline. `time` must be more recent than any previously-appended transform entries. */
471
- addTransform(time: number, transform: Readonly<Transform> | undefined, components?: {
472
- pivot: XYAndZ;
473
- orientation: Point4d;
474
- position: XYAndZ;
475
- }, interpolation?: Interpolation): void;
476
- /** Obtain the JSON representation of the [[RenderSchedule.Timeline]] produced by this builder.
477
- * @see [[RenderSchedule.ScriptBuilder.finish]] to obtain the JSON for the entire [[RenderSchedule.Script]].
478
- */
479
- finish(): TimelineProps;
480
- }
481
- /** As part of a [[RenderSchedule.ScriptBuilder]], assembles a [[RenderSchedule.ElementTimeline]].
482
- * @see [[RenderSchedule.ModelTimelineBuilder.addElementTimeline]].
483
- */
484
- class ElementTimelineBuilder extends TimelineBuilder {
485
- /** A positive integer that uniquely identifies this timeline among all element timelines in the [[RenderSchedule.Script]].
486
- * [[RenderSchedule.ScriptBuilder]] ensures each ElementTimelineBuilder receives a unique batch Id.
487
- */
488
- readonly batchId: number;
489
- /** The compressed set of Ids of the elements affected by this timeline. */
490
- readonly elementIds: CompressedId64Set;
491
- /** Constructor - typically not used directly.
492
- * @see [[RenderSchedule.ModelTimelineBuilder.addElementTimeline]] to create an ElementTimelineBuilder.
493
- */
494
- constructor(batchId: number, elementIds: CompressedId64Set);
495
- /** Obtain the JSON representation of the [[RenderSchedule.ElementTimeline]] produced by this builder.
496
- * @see [[RenderSchedule.ScriptBuilder.finish]] to obtain the JSON for the entire [[RenderSchedule.Script]].
497
- */
498
- finish(): ElementTimelineProps;
499
- }
500
- /** As part of a [[RenderSchedule.ScriptBuilder, assembles a [[RenderSchedule.ModelTimeline]].
501
- * @see [[RenderSchedule.ScriptBuilder.addModelTimeline]].
502
- */
503
- class ModelTimelineBuilder extends TimelineBuilder {
504
- /** The Id of the model affected by this timeline. */
505
- readonly modelId: Id64String;
506
- /** @internal */
507
- realityModelUrl?: string;
508
- private readonly _obtainNextBatchId;
509
- private readonly _elements;
510
- /** Constructor - typically not used directly.
511
- * @see [[RenderSchedule.ScriptBuilder.addModelTimeline]] to create a ModelTimelineBuilder.
512
- */
513
- constructor(modelId: Id64String, obtainNextBatchId: () => number);
514
- /** Add a new [[RenderSchedule.ElementTimeline]] to be applied to the specified elements.
515
- * This function will sort and compress the Ids if they are not already compressed.
516
- *
517
- */
518
- addElementTimeline(elementIds: CompressedId64Set | Iterable<Id64String>): ElementTimelineBuilder;
519
- /** Obtain the JSON representation of the [[RenderSchedule.ModelTimeline]] produced by this builder.
520
- * @see [[RenderSchedule.ScriptBuilder.finish]] to obtain the JSON for the entire [[RenderSchedule.Script]].
521
- */
522
- finish(): ModelTimelineProps;
523
- }
524
- /** Assembles the JSON representation for a new [[RenderSchedule.Script]]. Ensure that entries on any given element timeline are added chronologically. As an extremely simple example, the following code produces a script that changes the color of a single element:
525
- * ```ts
526
- * const script = new ScriptBuilder();
527
- * const model = script.addModelTimeline("0x123");
528
- * const element = model.addElementTimeline([ "0x456" ]);
529
- * element.addColor(Date.now(), new RgbColor(0xff, 0x7f, 0));
530
- * const scriptProps = script.finish();
531
- * ```
532
- */
533
- class ScriptBuilder {
534
- private _nextBatchId;
535
- private readonly _models;
536
- /** Add a new [[RenderSchedule.ModelTimeline]] to be applied to the specified model. */
537
- addModelTimeline(modelId: Id64String): ModelTimelineBuilder;
538
- /** Obtain the JSON representation of the [[RenderSchedule.Script]] produced by this builder.
539
- * @see [RenderTimeline.scriptProps]($backend) to assign the new script to a RenderTimeline element.
540
- */
541
- finish(): ScriptProps;
542
- }
543
- }
1
+ /** @packageDocumentation
2
+ * @module DisplayStyles
3
+ */
4
+ import { CompressedId64Set, Constructor, Id64String } from "@itwin/core-bentley";
5
+ import { EntityReferenceSet } from "./EntityReference";
6
+ import { ClipVector, Plane3dByOriginAndUnitNormal, Point4d, Range1d, Transform, Vector3d, XYAndZ } from "@itwin/core-geometry";
7
+ import { RgbColor } from "./RgbColor";
8
+ import { FeatureAppearance, FeatureOverrides } from "./FeatureSymbology";
9
+ import { PackedFeatureWithIndex } from "./FeatureTable";
10
+ /** Namespace containing types that collectively define a script that animates the contents of a view by adjusting the visibility, position,
11
+ * and/or symbology of groups of elements over time. A [[RenderSchedule.Script]] is hosted by a [RenderTimeline]($backend) element. The script
12
+ * can be associated with a [DisplayStyleState]($frontend) by way of its [[DisplayStyleSettings.renderTimeline]] property.
13
+ * @public
14
+ */
15
+ export declare namespace RenderSchedule {
16
+ /** Defines how two interpolate between two entries in a [[RenderSchedule.Timeline]].
17
+ * @note Currently only Linear and Step are supported. Any other value is treated as Step.
18
+ * @see [[RenderSchedule.TimelineEntry]].
19
+ */
20
+ enum Interpolation {
21
+ /** Each timeline entry's value is discrete - the timeline jumps from one entry's value directly to another. */
22
+ Step = 1,
23
+ /** Given two entries on the timeline and a timepoint in between them, linearly interpolate based on the timepoint's distance between the
24
+ * two entries.
25
+ */
26
+ Linear = 2
27
+ }
28
+ /** JSON representation of a [[RenderSchedule.TimelineEntry]]. */
29
+ interface TimelineEntryProps {
30
+ /** The time point in seconds in the [Unix Epoch](https://en.wikipedia.org/wiki/Unix_time). */
31
+ time: number;
32
+ /** How to interpolate from this entry to the next entry in the timeline.
33
+ * Currently, anything other than [[RenderSchedule.Interpolation.Linear]] is treated as [[RenderSchedule.Interpolation.Step]].
34
+ * Additional interpolation modes may become supported in the future.
35
+ */
36
+ interpolation?: Interpolation;
37
+ }
38
+ /** JSON representation of a [[RenderSchedule.VisibilityEntry]]. */
39
+ interface VisibilityEntryProps extends TimelineEntryProps {
40
+ /** Visibility of the geometry from 0 (invisible) to 100 (fully visible), with intermediate values appearing increasingly less transparent.
41
+ * Default: 100 (fully visible).
42
+ */
43
+ value?: number;
44
+ }
45
+ /** JSON representation of a [[RenderSchedule.ColorEntry]]. */
46
+ interface ColorEntryProps extends TimelineEntryProps {
47
+ /** The color applied to the geometry, with each component specified as an integer in [0, 255].
48
+ * e.g., (0, 0, 0) represents black and (255, 255, 255) represents white.
49
+ * If `undefined`, the geometry is displayed in its actual color.
50
+ */
51
+ value?: {
52
+ red: number;
53
+ green: number;
54
+ blue: number;
55
+ };
56
+ }
57
+ /** JSON representation of a [[RenderSchedule.CuttingPlane]]. */
58
+ interface CuttingPlaneProps {
59
+ /** (x,y,z) of a point on the plane. */
60
+ position: number[];
61
+ /** (x, y, z) of the plane direction (towards the clip) */
62
+ direction: number[];
63
+ /** If true, the clip plane is ignored and the geometry is displayed unclipped. */
64
+ visible?: boolean;
65
+ /** If true, the clip plane is ignored and the geometry is not displayed. */
66
+ hidden?: boolean;
67
+ }
68
+ /** JSON representation of a [[RenderSchedule.CuttingPlaneEntry]]. */
69
+ interface CuttingPlaneEntryProps extends TimelineEntryProps {
70
+ /** The clip plane, or undefined if the geometry is not clipped. */
71
+ value?: CuttingPlaneProps;
72
+ }
73
+ /** JSON representation of a [[RenderSchedule.TransformComponents]]. */
74
+ interface TransformComponentsProps {
75
+ /** (x, y, z) of position - applied after rotation. */
76
+ position?: number[];
77
+ /** Quaternion representing rotation. */
78
+ orientation?: number[];
79
+ /** (x, y, z) of pivot - applied before rotation. */
80
+ pivot?: number[];
81
+ }
82
+ /** JSON representation of a [Transform]($core-geometry) associated with a [[RenderSchedule.TransformEntryProps]]. */
83
+ interface TransformProps extends TransformComponentsProps {
84
+ /** 3 X 4 transformation matrix containing 3 arrays of matrix rows consisting of 4 numbers each: [qx qy qz ax]
85
+ * where the fourth columnn in each row holds the translation.
86
+ * `undefined` is equivalent to an identity transform.
87
+ * This transform is only used if position, orientation, and/or pivot are undefined.
88
+ */
89
+ transform?: number[][];
90
+ }
91
+ /** JSON representation of a [[RenderSchedule.TransformEntry]]. */
92
+ interface TransformEntryProps extends TimelineEntryProps {
93
+ /** The transformation matrix, with `undefined` corresponding to an identity matrix. */
94
+ value?: TransformProps;
95
+ }
96
+ /** JSON representation of a [[RenderSchedule.Timeline]]. */
97
+ interface TimelineProps {
98
+ /** Timeline controlling the visibility of the associated geometry. */
99
+ visibilityTimeline?: VisibilityEntryProps[];
100
+ /** Timeline controlling the colors of the associated geometry. */
101
+ colorTimeline?: ColorEntryProps[];
102
+ /** Timeline applying transforms to the associated geometry. */
103
+ transformTimeline?: TransformEntryProps[];
104
+ /** Timeline applying [ClipVector]($core-geometry)s to the associated geometry. */
105
+ cuttingPlaneTimeline?: CuttingPlaneEntryProps[];
106
+ }
107
+ /** JSON representation of an [[RenderSchedule.ElementTimeline]]. */
108
+ interface ElementTimelineProps extends TimelineProps {
109
+ /** A positive integer that uniquely identifies this timeline among all element timelines in the [[RenderSchedule.Script]]. */
110
+ batchId: number;
111
+ /** The Ids of the elements to which this timeline applies.
112
+ * @note Prefer the compressed representation - lists of element Ids can be comparatively enormous.
113
+ * @note For a [[DisplayStyleSettingsProps]] associated with a [DisplayStyleState]($frontend) obtained via [IModelConnection.Views.load]($frontend),
114
+ * this property will be an empty `CompressedId64Set`. They are omitted to conserve bandwidth and memory because they are not needed for display on the frontend.
115
+ */
116
+ elementIds: Id64String[] | CompressedId64Set;
117
+ }
118
+ /** JSON representation of a [[RenderSchedule.ModelTimeline]]. */
119
+ interface ModelTimelineProps extends TimelineProps {
120
+ /** The Id of the [GeometricModelState]($frontend) to which the timeline applies. */
121
+ modelId: Id64String;
122
+ /** @alpha */
123
+ realityModelUrl?: string;
124
+ /** Timelines affecting groups of elements. */
125
+ elementTimelines: ElementTimelineProps[];
126
+ }
127
+ /** JSON representation of a [[RenderSchedule.Script]]. */
128
+ type ScriptProps = ModelTimelineProps[];
129
+ /** Describes the value of some property at a specific point along a [[RenderSchedule.Timeline]].
130
+ * @see [[RenderSchedule.VisibilityEntry]]
131
+ * @see [[RenderSchedule.ColorEntry]]
132
+ * @see [[RenderSchedule.TransformEntry]]
133
+ * @see [[RenderSchedule.CuttingPlaneEntry]]
134
+ */
135
+ class TimelineEntry {
136
+ /** The time point in seconds in the [Unix Epoch](https://en.wikipedia.org/wiki/Unix_time). */
137
+ readonly time: number;
138
+ /** How to interpolate from this entry to the next entry in the timeline. */
139
+ readonly interpolation: Interpolation;
140
+ constructor(props: TimelineEntryProps);
141
+ toJSON(): TimelineEntryProps;
142
+ compareTo(other: TimelineEntry): number;
143
+ equals(other: TimelineEntry): boolean;
144
+ }
145
+ /** A timeline entry that controls the visibility of the associated geometry. */
146
+ class VisibilityEntry extends TimelineEntry {
147
+ /** The visibility of the geometry at this point on the timeline, in the range [0, 100] where 0 is completely invisible, 100 is completely visible,
148
+ * and values in between indicate increasing opacity.
149
+ */
150
+ readonly value: number;
151
+ constructor(props: VisibilityEntryProps);
152
+ toJSON(): VisibilityEntryProps;
153
+ compareTo(other: VisibilityEntry): number;
154
+ }
155
+ /** A timeline entry controlling the color of the affected geometry. */
156
+ class ColorEntry extends TimelineEntry {
157
+ /** If defined, the color in which to draw the geometry. If undefined, the geometry is drawn in its actual color. */
158
+ readonly value: RgbColor | undefined;
159
+ constructor(props: ColorEntryProps);
160
+ toJSON(): ColorEntryProps;
161
+ compareTo(other: ColorEntry): number;
162
+ }
163
+ /** Describes the components of a [[RenderSchedule.TransformEntry]] as a rotation around a pivot point followed by a translation. */
164
+ class TransformComponents {
165
+ /** Pivot point - applied before rotation. */
166
+ readonly pivot: Vector3d;
167
+ /** Quaternion rotation. */
168
+ readonly orientation: Point4d;
169
+ /** Translation - applied after rotation. */
170
+ readonly position: Vector3d;
171
+ constructor(position: Vector3d, pivot: Vector3d, orientation: Point4d);
172
+ static fromJSON(props: TransformComponentsProps): TransformComponents | undefined;
173
+ toJSON(): TransformComponentsProps;
174
+ compareTo(other: TransformComponents): number;
175
+ equals(other: TransformComponents): boolean;
176
+ }
177
+ /** A timeline entry that applies rotation, scaling, and/or translation to the affected geometry. */
178
+ class TransformEntry extends TimelineEntry {
179
+ /** The transform matrix to be applied to the geometry, used only if [[components]] is not defined. */
180
+ readonly value: Readonly<Transform>;
181
+ /** The transform represented as a rotation about a pivot point followed by a translation. If undefined, [[value]] is used instead. */
182
+ readonly components?: TransformComponents;
183
+ constructor(props: TransformEntryProps);
184
+ toJSON(): TransformEntryProps;
185
+ compareTo(other: TransformEntry): number;
186
+ }
187
+ /** Defines a [ClipPlane]($core-geometry) associated with a [[RenderSchedule.CuttingPlaneEntry]]. */
188
+ class CuttingPlane {
189
+ /** A point on the plane. */
190
+ readonly position: XYAndZ;
191
+ /** The direction perpendicular to the plane pointing toward the clip. */
192
+ readonly direction: XYAndZ;
193
+ /** If true, the clip plane is ignored and the geometry is never clipped. */
194
+ readonly visible: boolean;
195
+ /** If true, the clip plane is ignored and the geometry is always clipped. */
196
+ readonly hidden: boolean;
197
+ constructor(props: CuttingPlaneProps);
198
+ toJSON(): CuttingPlaneProps;
199
+ compareTo(other: CuttingPlane): number;
200
+ equals(other: CuttingPlane): boolean;
201
+ }
202
+ /** A timeline entry that applies a [ClipPlane]($core-geometry) to the affected geometry. */
203
+ class CuttingPlaneEntry extends TimelineEntry {
204
+ /** The definition of the [ClipPlane]($core-geometry), or undefined if this entry applies no clipping. */
205
+ readonly value: CuttingPlane | undefined;
206
+ constructor(props: CuttingPlaneEntryProps);
207
+ toJSON(): CuttingPlaneEntryProps;
208
+ compareTo(other: CuttingPlaneEntry): number;
209
+ }
210
+ /** Identifies a fractional position along a [[RenderSchedule.Timeline]] between any two [[RenderSchedule.TimelineEntry]]'s within a [[RenderSchedule.TimelineEntryList]].
211
+ * @internal
212
+ */
213
+ class Interval {
214
+ /** The index of the first timeline entry within the list. */
215
+ lowerIndex: number;
216
+ /** The index of the second timeline entry within the list. */
217
+ upperIndex: number;
218
+ /** The normalized distance between the two timeline entries. */
219
+ fraction: number;
220
+ constructor(lower?: number, upper?: number, fraction?: number);
221
+ init(lower?: number, upper?: number, fraction?: number): void;
222
+ }
223
+ /** A list of the [[RenderSchedule.TimelineEntry]] objects within a [[RenderSchedule.Timeline]]. The type parameters are:
224
+ * - T, a subclass of TimelineEntry with a `value` property specifying the value of the property controlled by the timeline at that entry's time point.
225
+ * - P, the JSON representation from which T is to be constructed.
226
+ * - V, the type of `T.value`.
227
+ */
228
+ class TimelineEntryList<T extends TimelineEntry & {
229
+ readonly value: V;
230
+ }, P extends TimelineEntryProps, V> implements Iterable<T> {
231
+ private readonly _entries;
232
+ /** The total time period represented by the entries in this list. */
233
+ readonly duration: Range1d;
234
+ constructor(props: P[], ctor: Constructor<T>);
235
+ /** The number of entries in the list. */
236
+ get length(): number;
237
+ /** An iterator over the entries in the list. */
238
+ [Symbol.iterator](): Iterator<T>;
239
+ /** Look up an entry by its position in the list. */
240
+ getEntry(index: number): T | undefined;
241
+ /** Look up the value of an entry by its position in the list. */
242
+ getValue(index: number): V | undefined;
243
+ toJSON(): P[];
244
+ compareTo(other: TimelineEntryList<T, P, V>): number;
245
+ equals(other: TimelineEntryList<T, P, V>): boolean;
246
+ /** @internal */
247
+ findInterval(time: number, interval?: Interval): Interval | undefined;
248
+ }
249
+ /** A list of [[RenderSchedule.VisibilityEntry]]s within a [[RenderSchedule.Timeline]]. */
250
+ class VisibilityTimelineEntries extends TimelineEntryList<VisibilityEntry, VisibilityEntryProps, number> {
251
+ /** Returns the visibility value for the entry at the specified position in the list, or 100 (fully-visible) if no such entry exists. */
252
+ getValue(index: number): number;
253
+ }
254
+ /** A list of [[RenderSchedule.TransformEntry]]s within a [[RenderSchedule.Timeline]]. */
255
+ class TransformTimelineEntries extends TimelineEntryList<TransformEntry, TransformEntryProps, Readonly<Transform>> {
256
+ /** Returns the transform for the entry at the specified position in the list, or an identity transform if no such entry exists. */
257
+ getValue(index: number): Readonly<Transform>;
258
+ }
259
+ /** Specifies how to animate a set of geometry over time within a [[RenderSchedule.Script]].
260
+ * A [[RenderSchedule.Script]] can contain any number of [[RenderSchedule.Timeline]]s, each affecting different sets of geometry.
261
+ * @see [[RenderSchedule.ElementTimeline]] and [[RenderSchedule.ModelTimeline]].
262
+ */
263
+ class Timeline {
264
+ /** Sequence controlling the visibility of the geometry. */
265
+ readonly visibility?: VisibilityTimelineEntries;
266
+ /** Sequence controlling the color of the geometry. */
267
+ readonly color?: TimelineEntryList<ColorEntry, ColorEntryProps, RgbColor | undefined>;
268
+ /** Sequence controlling the position, orientation, and/or scale of the geometry. */
269
+ readonly transform?: TransformTimelineEntries;
270
+ /** Sequence controlling how the geometry is clipped. */
271
+ readonly cuttingPlane?: TimelineEntryList<CuttingPlaneEntry, CuttingPlaneEntryProps, CuttingPlane | undefined>;
272
+ /** The total time period represented by this timeline. */
273
+ readonly duration: Range1d;
274
+ constructor(props: TimelineProps);
275
+ toJSON(): TimelineProps;
276
+ compareTo(other: Timeline): number;
277
+ equals(other: Timeline): boolean;
278
+ /** Get the visibility of the geometry at the specified time point. */
279
+ getVisibility(time: number): number;
280
+ /** Get the color of the geometry at the specified time point, or undefined if the color is not overridden at that time point. */
281
+ getColor(time: number): RgbColor | undefined;
282
+ /** Get the transform applied to the geometry at the specified time point. */
283
+ getAnimationTransform(time: number): Readonly<Transform>;
284
+ /** Get the clipping plane applied to the geometry at the specified time point, or undefined if the geometry is unclipped at that time point. */
285
+ getCuttingPlane(time: number): Plane3dByOriginAndUnitNormal | undefined;
286
+ /** Create a ClipVector from the [[RenderSchedule.CuttingPlane]] applied to the geometry at the specified time point, if any. */
287
+ getClipVector(time: number): ClipVector | undefined;
288
+ /** @internal */
289
+ protected getFeatureAppearance(visibility: number, time: number): FeatureAppearance | undefined;
290
+ }
291
+ /** Specifies how to animate the geometry belonging to a set of [GeometricElement]($backend)s as part of a [[RenderSchedule.Script]]. */
292
+ class ElementTimeline extends Timeline {
293
+ /** A positive integer that uniquely identififes this timeline among all ElementTimelines in the [[RenderSchedule.Script]]. */
294
+ readonly batchId: number;
295
+ private readonly _elementIds;
296
+ private constructor();
297
+ static fromJSON(props?: ElementTimelineProps): ElementTimeline;
298
+ toJSON(): ElementTimelineProps;
299
+ get containsElementIds(): boolean;
300
+ private compareElementIds;
301
+ compareTo(other: ElementTimeline): number;
302
+ /** @internal */
303
+ static getElementIds(ids: Id64String[] | CompressedId64Set): Iterable<Id64String>;
304
+ /** The Ids of the elements controlled by this timeline. */
305
+ get elementIds(): Iterable<Id64String>;
306
+ /** True if this timeline affects the color or transparency of the elements. */
307
+ get containsFeatureOverrides(): boolean;
308
+ /** If true, applying this timeline requires special tiles to be generated in which groups of elements are batched into nodes.
309
+ * @internal
310
+ */
311
+ get requiresBatching(): boolean;
312
+ /** True if this timeline affects the position, orientation, or scale of the elements. */
313
+ get containsTransform(): boolean;
314
+ /** @internal */
315
+ addSymbologyOverrides(overrides: FeatureOverrides, time: number): void;
316
+ }
317
+ /** Specifies how to animate the geometry within a [GeometricModel]($backend) as part of a [[RenderSchedule.Script]]. */
318
+ class ModelTimeline extends Timeline {
319
+ /** The Id of the [GeometricModel]($backend) to be animated. */
320
+ readonly modelId: Id64String;
321
+ /** @internal */
322
+ readonly realityModelUrl?: string;
323
+ /** Timelines specifying how to animate groups of [GeometricElement]($backend)s within the model. */
324
+ readonly elementTimelines: ReadonlyArray<ElementTimeline>;
325
+ /** @internal */
326
+ readonly transformBatchIds: ReadonlyArray<number>;
327
+ /** True if this timeline affects the color or transparency of the geometry. */
328
+ readonly containsFeatureOverrides: boolean;
329
+ /** True if this timeline applies clipping to the model. */
330
+ readonly containsModelClipping: boolean;
331
+ /** If true, applying this timeline requires special tiles to be generated in which groups of elements are batched into nodes.
332
+ * @internal
333
+ */
334
+ readonly requiresBatching: boolean;
335
+ /** True if this timeline affects the position, orientation, or scale of the geometry. */
336
+ readonly containsTransform: boolean;
337
+ /** True if any [[RenderSchedule.ElementTimeline]]s exist and none of them contain any element Ids. This generally indicates that
338
+ * the backend was instructed to omit the Ids to save space when supplying the script.
339
+ */
340
+ readonly omitsElementIds: boolean;
341
+ private _maxBatchId?;
342
+ /** Tile tree suppliers perform **very** frequent ordered comparisons of ModelTimelines. They need to be fast. */
343
+ private readonly _cachedComparisons;
344
+ /** When loading tiles we need to quickly map element Ids to batch Ids. This map is initialized on first call to [[getTimelineForElement]] to facilitate that lookup. */
345
+ private _idPairToElementTimeline?;
346
+ private _discreteBatchIds?;
347
+ private constructor();
348
+ static fromJSON(props?: ModelTimelineProps): ModelTimeline;
349
+ toJSON(): ModelTimelineProps;
350
+ compareTo(other: ModelTimeline): number;
351
+ /** Look up the element timeline with the specified batch Id. */
352
+ findByBatchId(batchId: number): ElementTimeline | undefined;
353
+ /** @internal */
354
+ addSymbologyOverrides(overrides: FeatureOverrides, time: number): void;
355
+ /** Obtain the transform applied to the model at the specified time point, if any. */
356
+ getTransform(batchId: number, time: number): Readonly<Transform> | undefined;
357
+ /** Get the highest batchId of any ElementTimeline in this timeline. */
358
+ get maxBatchId(): number;
359
+ /** Given the two halves of an [Id64]($bentley) return the [[ElementTimeline]] containing the corresponding element.
360
+ * @note The first call to this method populates a mapping for fast lookup.
361
+ * @alpha
362
+ */
363
+ getTimelineForElement(idLo: number, idHi: number): ElementTimeline | undefined;
364
+ /** The batch Ids of the subset of [[elementTimelines]] that apply a transform and/or cutting plane.
365
+ * @alpha
366
+ */
367
+ get discreteBatchIds(): Set<number>;
368
+ /** @internal see ImdlReader.readAnimationBranches */
369
+ getBatchIdForFeature(feature: PackedFeatureWithIndex): number;
370
+ }
371
+ /** Specifies how to animate the contents of a [ViewState]($frontend) over time. The script contains any number of [[RenderSchedule.ModelTimeline]]s, each describing how
372
+ * to animate one of the models in the view.
373
+ * @see [RenderTimeline]($backend) to create an [Element]($backend) to host a script.
374
+ * @see [[DisplayStyleSettings.renderTimeline]] to associate a [RenderTimeline]($backend)'s script with a [DisplayStyle]($backend).
375
+ * @see [DisplayStyleState.scheduleScript]($frontend) to obtain the script associated with a display style.
376
+ * @see [[RenderSchedule.ScriptBuilder]] to define a new script.
377
+ */
378
+ class Script {
379
+ /** Timelines specifying how to animate individual models within the view. */
380
+ readonly modelTimelines: ReadonlyArray<ModelTimeline>;
381
+ /** True if this script applies clipping to any models. */
382
+ readonly containsModelClipping: boolean;
383
+ /** If true, applying this timeline requires special tiles to be generated in which groups of elements are batched into nodes.
384
+ * @internal
385
+ */
386
+ readonly requiresBatching: boolean;
387
+ /** True if this script affects the position, orientation, or scale of the geometry. */
388
+ readonly containsTransform: boolean;
389
+ /** True if this script affects the color or transparency of the geometry. */
390
+ readonly containsFeatureOverrides: boolean;
391
+ /** The total time period over which this script animates. */
392
+ readonly duration: Range1d;
393
+ /** The batchIds of all nodes in all timelines that apply a transform.
394
+ * @internal
395
+ */
396
+ readonly transformBatchIds: ReadonlySet<number>;
397
+ /** Tile tree references perform **very** frequent ordered comparisons of Scripts. They need to be fast. */
398
+ private readonly _cachedComparisons;
399
+ private _discreteBatchIds?;
400
+ private _lastFeatureModelTimeline?;
401
+ private _maxBatchId?;
402
+ compareTo(other: Script): number;
403
+ equals(other: Script): boolean;
404
+ protected constructor(props: Readonly<ScriptProps>);
405
+ static fromJSON(props: Readonly<ScriptProps>): Script | undefined;
406
+ toJSON(): ScriptProps;
407
+ /** Look up the timeline that animates the specified model, if any. */
408
+ find(modelId: Id64String): ModelTimeline | undefined;
409
+ /** @internal */
410
+ getTransformBatchIds(modelId: Id64String): ReadonlyArray<number> | undefined;
411
+ /** @internal */
412
+ getTransform(modelId: Id64String, batchId: number, time: number): Readonly<Transform> | undefined;
413
+ /** @internal */
414
+ addSymbologyOverrides(overrides: FeatureOverrides, time: number): void;
415
+ /** Used by the [Entity.collectReferenceIds]($backend) method overrides in RenderTimeline and DisplayStyle.
416
+ * @internal
417
+ */
418
+ discloseIds(ids: EntityReferenceSet): void;
419
+ /** @internal */
420
+ modelRequiresBatching(modelId: Id64String): boolean;
421
+ /** The batch Ids of the subset of [[elementTimelines]] that apply a transform and/or cutting plane.
422
+ * @alpha
423
+ */
424
+ get discreteBatchIds(): Set<number>;
425
+ /** @internal see ImdlReader.readAnimationBranches. */
426
+ getBatchIdForFeature(feature: PackedFeatureWithIndex): number;
427
+ /** @alpha */
428
+ get maxBatchId(): number;
429
+ }
430
+ /** A reference to a [[RenderSchedule.Script]], optionally identifying the source of the script.
431
+ * @see [DisplayStyle.loadScheduleScript]($backend) and [DisplayStyleState.scheduleScript]($frontend) to obtain the script reference for a display style on the frontend
432
+ * and backend respectively.
433
+ * @see [DisplayStyleState.scheduleScript]($frontend) or [DisplayStyleState.changeRenderTimeline]($frontend) to change a display style's script on the frontend.
434
+ */
435
+ class ScriptReference {
436
+ /** The Id of the element - if any - from which the script originated.
437
+ * A schedule script may originate from one of the following sources:
438
+ * - A [RenderTimeline]($backend) element stored in the iModel; or
439
+ * - The `scheduleScript` JSON property of a [DisplayStyle]($backend) element stored in the iModel; or
440
+ * - Any other source outside of the iModel, such as code that generates the script on the frontend, a script obtained from some server, etc.
441
+ *
442
+ * The [[sourceId]] property identifies the Id of the element from which the script originated; an empty or invalid [Id64String]($bentley) indicates the script did not
443
+ * originate from any persistent element. If the Id is valid, the contents of [[script]] are assumed to match those stored on the source element.
444
+ */
445
+ readonly sourceId: Id64String;
446
+ /** The script defining the rendering timelines to be applied. */
447
+ readonly script: Script;
448
+ /** Create a reference to a [[script]] with no [[sourceId]]. */
449
+ constructor(script: Script);
450
+ /** Create a reference to a [[script]] with the specified [[sourceId]]. */
451
+ constructor(sourceId: Id64String, script: Script);
452
+ /** @internal Use one of the public constructor overloads which forward to this one. */
453
+ constructor(sourceIdOrScript: Id64String | Script, scriptIfSourceId?: Script);
454
+ }
455
+ /** Used as part of a [[RenderSchedule.ScriptBuilder]] to define a [[RenderSchedule.Timeline]]. Functions that append
456
+ * to the timeline expect entries to be appended in chronological order - i.e., you cannot append an entry that is earlier
457
+ * than a previously appended entry.
458
+ * @see [[RenderSchedule.ElementTimelineBuilder]] and [[RenderSchedule.ModelTimelineBuilder]].
459
+ */
460
+ class TimelineBuilder {
461
+ /** Timeline controlling visibility. */
462
+ visibility?: VisibilityEntryProps[];
463
+ /** Timeline controlling color. */
464
+ color?: ColorEntryProps[];
465
+ /** Timeline controlling position and orientation. */
466
+ transform?: TransformEntryProps[];
467
+ /** Timeline controlling clipping. */
468
+ cuttingPlane?: CuttingPlaneEntryProps[];
469
+ /** Append a new [[RenderSchedule.VisibilityEntry]] to the timeline. `time` must be more recent than any previously-appended visibility entries. */
470
+ addVisibility(time: number, visibility: number | undefined, interpolation?: Interpolation): void;
471
+ /** Append a new [[RenderSchedule.ColorEntry]] to the timeline. `time` must be more recent than any previously-appended color entries. */
472
+ addColor(time: number, color: RgbColor | {
473
+ red: number;
474
+ green: number;
475
+ blue: number;
476
+ } | undefined, interpolation?: Interpolation): void;
477
+ /** Append a new [[RenderSchedule.CuttingPlaneEntry]] to the timeline. `time` must be more recent than any previously-appended cutting plane entries. */
478
+ addCuttingPlane(time: number, plane: {
479
+ position: XYAndZ;
480
+ direction: XYAndZ;
481
+ visible?: boolean;
482
+ hidden?: boolean;
483
+ } | undefined, interpolation?: Interpolation): void;
484
+ /** Append a new [[RenderSchedule.TransformEntry]] to the timeline. `time` must be more recent than any previously-appended transform entries. */
485
+ addTransform(time: number, transform: Readonly<Transform> | undefined, components?: {
486
+ pivot: XYAndZ;
487
+ orientation: Point4d;
488
+ position: XYAndZ;
489
+ }, interpolation?: Interpolation): void;
490
+ /** Obtain the JSON representation of the [[RenderSchedule.Timeline]] produced by this builder.
491
+ * @see [[RenderSchedule.ScriptBuilder.finish]] to obtain the JSON for the entire [[RenderSchedule.Script]].
492
+ */
493
+ finish(): TimelineProps;
494
+ }
495
+ /** As part of a [[RenderSchedule.ScriptBuilder]], assembles a [[RenderSchedule.ElementTimeline]].
496
+ * @see [[RenderSchedule.ModelTimelineBuilder.addElementTimeline]].
497
+ */
498
+ class ElementTimelineBuilder extends TimelineBuilder {
499
+ /** A positive integer that uniquely identifies this timeline among all element timelines in the [[RenderSchedule.Script]].
500
+ * [[RenderSchedule.ScriptBuilder]] ensures each ElementTimelineBuilder receives a unique batch Id.
501
+ */
502
+ readonly batchId: number;
503
+ /** The compressed set of Ids of the elements affected by this timeline. */
504
+ readonly elementIds: CompressedId64Set;
505
+ /** Constructor - typically not used directly.
506
+ * @see [[RenderSchedule.ModelTimelineBuilder.addElementTimeline]] to create an ElementTimelineBuilder.
507
+ */
508
+ constructor(batchId: number, elementIds: CompressedId64Set);
509
+ /** Obtain the JSON representation of the [[RenderSchedule.ElementTimeline]] produced by this builder.
510
+ * @see [[RenderSchedule.ScriptBuilder.finish]] to obtain the JSON for the entire [[RenderSchedule.Script]].
511
+ */
512
+ finish(): ElementTimelineProps;
513
+ }
514
+ /** As part of a [[RenderSchedule.ScriptBuilder, assembles a [[RenderSchedule.ModelTimeline]].
515
+ * @see [[RenderSchedule.ScriptBuilder.addModelTimeline]].
516
+ */
517
+ class ModelTimelineBuilder extends TimelineBuilder {
518
+ /** The Id of the model affected by this timeline. */
519
+ readonly modelId: Id64String;
520
+ /** @internal */
521
+ realityModelUrl?: string;
522
+ private readonly _obtainNextBatchId;
523
+ private readonly _elements;
524
+ /** Constructor - typically not used directly.
525
+ * @see [[RenderSchedule.ScriptBuilder.addModelTimeline]] to create a ModelTimelineBuilder.
526
+ */
527
+ constructor(modelId: Id64String, obtainNextBatchId: () => number);
528
+ /** Add a new [[RenderSchedule.ElementTimeline]] to be applied to the specified elements.
529
+ * This function will sort and compress the Ids if they are not already compressed.
530
+ *
531
+ */
532
+ addElementTimeline(elementIds: CompressedId64Set | Iterable<Id64String>): ElementTimelineBuilder;
533
+ /** Obtain the JSON representation of the [[RenderSchedule.ModelTimeline]] produced by this builder.
534
+ * @see [[RenderSchedule.ScriptBuilder.finish]] to obtain the JSON for the entire [[RenderSchedule.Script]].
535
+ */
536
+ finish(): ModelTimelineProps;
537
+ }
538
+ /** Assembles the JSON representation for a new [[RenderSchedule.Script]]. Ensure that entries on any given element timeline are added chronologically. As an extremely simple example, the following code produces a script that changes the color of a single element:
539
+ * ```ts
540
+ * const script = new ScriptBuilder();
541
+ * const model = script.addModelTimeline("0x123");
542
+ * const element = model.addElementTimeline([ "0x456" ]);
543
+ * element.addColor(Date.now(), new RgbColor(0xff, 0x7f, 0));
544
+ * const scriptProps = script.finish();
545
+ * ```
546
+ */
547
+ class ScriptBuilder {
548
+ private _nextBatchId;
549
+ private readonly _models;
550
+ /** Add a new [[RenderSchedule.ModelTimeline]] to be applied to the specified model. */
551
+ addModelTimeline(modelId: Id64String): ModelTimelineBuilder;
552
+ /** Obtain the JSON representation of the [[RenderSchedule.Script]] produced by this builder.
553
+ * @see [RenderTimeline.scriptProps]($backend) to assign the new script to a RenderTimeline element.
554
+ */
555
+ finish(): ScriptProps;
556
+ }
557
+ }
544
558
  //# sourceMappingURL=RenderSchedule.d.ts.map