Playback
When visualizing a local or remote data file, you can navigate its contents using the playback bar controls.
Message ordering
The Foxglove app (and WebSocket protocol) order and play messages by log time. Foxglove has some interpretation for log time in every supported data format, including MCAP, WebSocket, ROS 1, ROS 2, and ULog. In other contexts, log time is sometimes known as "receipt time", "receive time", or simply "timestamp".
The log time typically refers to the time when the message was recorded, but can be set to the timestamp that best reflects the reality that you would like to visualize for time-critical signals. It’s important to choose your log times carefully and consider sources of time skew such as network latency, batching, and buffering.
Robotics data is often associated with other timestamps, in addition to the log time. The Plot and State Transitions panels can be configured to order data using the following alternative timestamp fields:
Timestamp | Source | Description |
---|---|---|
Header stamp | ROS 1, ROS 2, custom messages | A header.stamp field within the message data containing sec and nsec integers |
Publish time | MCAP | Optional MCAP-specific field |
Message loading
Foxglove optimizes how it loads your complex robotics data, for more streamlined seeking and playback.
Message "lookback"
When seeking to an arbitrary point in your loaded data, it's unlikely that every topic you are visualizing has a message at exactly the time you jumped to. The vast majority of your topics will have messages sometime before or after that exact seek point.
To ensure that your layout still displays something reasonable, Foxglove performs a “lookback” on your data. Essentially, it looks for the most recent message on each subscribed topic. This ensures that even when seeking to an arbitrary point in your data, Foxglove will still display reasonable data for all the panels in your layout – even if their messages occurred at different times.
Latched topics
By default, ROS 1 .bag
files, MCAP files, and Foxglove data streams will play back using message latching.
When seeking within your data, Foxglove fetches the last message on all subscribed topics – even if they occurred multiple minutes before your seek location. Every panel in the layout will then automatically display the last data it saw for that topic – even if that data is infrequently published or was not published at that exact moment in time. For Foxglove data streams, Foxglove will load the last seen messages for each subscribed topic – even if those messages are from before your current data segment's start time.
Message latching allows panels to accurately display data from infrequently published topics (like a map, for example), even while seeking around to multiple points in your data at random.
Preloading
While most Foxglove panels – like the Raw Messages and Image panels – display just the most recent message for a given topic, others like the Plot and Map panels benefit from visualizing messages across the data's entire time range. Seeing a complete view of one's data makes spotting anomalies, summarizing robot behavior, and recognizing trends and patterns much easier. Preloading data allows these panels to access all their historical data throughout playback.
Even panels that visualize their most recently seen data can benefit from preloading. For example, the 3D panel preloads its transform messages to accurately position its markers. Robots often have many coordinate frames (e.g. joints of a robot arm, cameras on a self-driving car), each with their own markers. To render markers from different frames in a single 3D scene, the panel needs to use transforms to calculate the position of these visual elements in a common coordinate space. Since transforms accumulate and update over time, looking at just the latest message would result in an incompletely or incorrectly rendered scene. By preloading all transforms, the 3D panel can accurately position its markers, regardless of where and how often you decide to seek in your data.
User interactions
- Create, view, and search events
- Trim or expand the range of the active data
- Format the current timestamp display
- Seek back and forth at increments of 100ms
- Loop playback
- Configure playback speed
Adjusting the playback range
You can adjust the playback start and end time when viewing a local file, streaming a recording, or streaming data for a device + time range. Drag the handles on the playback bar to make quick adjustments or edit the input fields for precise adjustments. The time format will match your current timestamp display.
If you make an adjustment and the resulting start/end time do not match what you expected, it's likely one of two scenarios occurred:
- You're viewing a fixed-length recording and tried to extend beyond the start/end. In this case, we will automatically adjust the range to match the full recording.
- You're viewing device data and the new playback range did not include any additional data. In this case, we will automatically trim the playback range around available data.
Shortcuts
Space
– Pause or playShift
+←
– Seek backward 10msShift
+→
– Seek forward 10ms←
– Seek backward 100ms→
– Seek forward 100msAlt
+←
– Seek backward 500msAlt
+→
– Seek forward 500ms