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