TimeSlider allows you to animate or manually step through a time range, with options to configure based on a time-aware layer or a GeoView.
- Supports stepping through the time extent with pre-defined steps. Steps can be customized.
- Supports animating, with play and pause functionality, the time extent
- Raises events when the time slider's time extent changes
- Supports initialization of the slider from a layer or a GeoView.
The following API methods, events, and properties are available to configure, interact, and respond to the time slider.
See the API reference for full details.
CurrentExtentChanged
- Raised when the current time extent in the slider changes. Listen to this if you want to update a GeoView's time extent.InitializeTimePropertiesAsync
- Initializes various properties, including full extent and time intervals, based on the GeoModel displayed by a GeoView, or a time-aware layer.InitializeTimeSteps
- Divides the slider into a specific number of stepsFullExtent
- Full time range for the sliderCurrentExtent
- Currently selected time range within the sliderTimeStepInterval
- Duration of a time stepTimeSteps
- Quantity of time stepsIsStartTimePinned
- Controls whether selected start time can be changedIsEndTimePinned
- Controls whether selected end time can be changed
IsPlaying
- Gets or sets a value indicating whether the time slider is animatingPlaybackInterval
- Controls how long (in user time) the time slider waits before stepping the current extent whenIsPlaying
is true.PlaybackDirection
- Controls whether playback is moving forward or backwardPlaybackLoopMode
- Controls the behavior when the time slider reaches the end of the animation
LabelMode
- Controls how intervals and extents are labeledFullExtentLabelFormat
- Controls the format for the extent labelsCurrentExtentLabelFormat
- Controls the format for the current extent labelsTimeStepIntervalLabelFormat
- Controls the format for the interval labels
Note: following code assumes that TimeSlider
has already been added to the view alongside a MapView
.
private async Task InitializeSliderAsync()
{
timeSlider.CurrentExtentChanged += Slider_CurrentExtentChanged;
await timeSlider.InitializeTimePropertiesAsync(mapView);
}
private void Slider_CurrentExtentChanged(object sender, UI.TimeExtentChangedEventArgs e)
{
mapView.TimeExtent = e.NewExtent;
}