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

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