Position Log Playback ¶
In this guide you will learn how to play back
a previously recorded position (GPS) log, using
DataSource
on an interactive map, displayed using
MapView
,
with frame per second (FPS) counter.
GPS Log Data Source ¶
data:image/s3,"s3://crabby-images/d3279/d3279828e23a8315574978e6596c13c91d9adf86" alt="QML data source playback example"
First, get an API key token, see the Getting Started guide.
Qt should be installed to continue.The Maps SDK for Qt should be installed, see the Setup Maps SDK for Qt guide.
Overview ¶
data:image/s3,"s3://crabby-images/12828/1282884755936d18a8d582e0edcc398ea3eb3ee4" alt="QML data source playback example"
PositionLogPlayback
demonstrates how easy it is to use
MapView
to display an interactive map, and play back a pre-recorded position (GPS) log, using
DataSource
The input position (GPS) logfile has to be generated/saved in the
.nmea
format.
Playback can be paused and resumed, and also set to repeat continuously (loop).
How it works
In Qt, go to the File menu and select Open File or Project…
then browse to the PositionLogPlayback example folder and open PositionLogPlayback.pro
You may want to have a look at Setting your API Key to see how to open and configure a project and set your API Key.
In main.qml, in the
Component.onCompleted:
block, the datasource is
set by specifying the filename of a previously recorded [GPS] position log:
ServicesManager.dataSource.playbackFile
=
Qt.resolvedUrl("gpslog_paris.nmea");
Also the content type that will be downloaded upon demand is specified:
let
updater
=
ServicesManager.contentUpdater(ContentItem.Type.RoadMap);
The
MapView
displaying the interactive map also has 4 buttons,
the one on the bottom left of the viewport to start/stop the position
datasource playback, and the one on the bottom right to start/resume
following position.
Playback ¶
data:image/s3,"s3://crabby-images/9a38d/9a38d49f62e22ca877163058038cd05ae519dba7" alt="QML data source playback example"
1Button {
2 text: ServicesManager.dataSource.type === DataSource.Type.Live
3 ? "Position Log playback" : "Live position"
4 background: Rectangle {
5 opacity: parent.hovered ? 1 : 0.5
6 color: enabled ? parent.down ? "#aa00aa" :
7 (parent.hovered ? "#0000ff" : "#2000ff") : "#aaaaaa"
8 }
9 palette { buttonText: "#ffffff"; }
10 onClicked: ServicesManager.dataSource.type = ServicesManager.dataSource.type
11 === DataSource.Type.Live ? DataSource.Type.Playback : DataSource.Type.Live;
12}
Playback starts automatically when the data source type is set to
DataSource.Type.Playback
and stops when the data source type is set to
DataSource.Type.Live
which means that the position indicator on the
map shows the actual position of the device, obtained from the
location (GPS) sensor.
To restart playback from the beginning, click
Live
position
to switch to
live GPS position sensor input, then click
Position
Log
playback
Follow Position ¶
data:image/s3,"s3://crabby-images/a7cf4/a7cf4cb19346917da75281935c2bf22af196ac81" alt="QML data source playback example"
1Button {
2 anchors.right: parent.right
3 anchors.bottom: parent.bottom
4 text: qsTr("Follow position")
5 enabled: !mapView.followingPosition
6 background: Rectangle {
7 opacity: parent.hovered ? 1 : 0.5
8 color: enabled ? parent.down ? "#aa00aa" :
9 (parent.hovered ? "#0000ff" : "#2000ff") : "#aaaaaa"
10 }
11 palette { buttonText: "#ffffff"; }
12 onClicked: mapView.followingPosition = true
13}
Panning the map during simulation/playback will stop follow position, and the button needs to be clicked again to resume following position.
Follow
position
means that the camera flies to the position
of the green arrow and then follows the simulated position arrow.
This is necessary, as the arrow is likely to be located elsewhere
on the map, not at the current location of the camera.
Pause / Resume Playback ¶
data:image/s3,"s3://crabby-images/7462e/7462e5de1fab916e9da7b9d19a93e3e73a52e541" alt="QML data source playback example"
The green position arrow plays back the previously recorded positions on the map, from the data source specified above.
1Button {
2 id: pauseResume
3 text: "Pause"
4 background: Rectangle {
5 opacity: parent.hovered ? 1 : 0.5
6 color: enabled ? parent.down ? "#aa00aa" :
7 (parent.hovered ? "#0000ff" : "#2000ff") : "#aaaaaa"
8 }
9 palette { buttonText: "#ffffff"; }
10 onClicked: {
11 if ( ServicesManager.dataSource.playbackStatus === DataSource.PlaybackStatus.Paused ) {
12 ServicesManager.dataSource.resume(); pauseResume.text = "Pause"
13 } else {
14 ServicesManager.dataSource.pause(); pauseResume.text = "Resume"
15 }
16 }
17}
The
Pause
/
Resume
button pauses and continues playback of the pre-recorded
position (GPS) log file, which is in the
.nmea
format,
by calling the
pause()
and
resume()
functions, respectively.
Continuous Playback Loop ¶
data:image/s3,"s3://crabby-images/ac926/ac92623cf8b15418dcb4edc7d681eaac93cf8ec9" alt="QML data source playback example"
1Button {
2 text: ServicesManager.dataSource.playbackLoopMode
3 ? "No playback loop" : "Loop playback"
4 background: Rectangle {
5 opacity: parent.hovered ? 1 : 0.5
6 color: enabled ? parent.down ? "#aa00aa" :
7 (parent.hovered ? "#0000ff" : "#2000ff") : "#aaaaaa"
8 }
9 palette { buttonText: "#ffffff"; }
10 onClicked: ServicesManager.dataSource.playbackLoopMode =
11 !ServicesManager.dataSource.playbackLoopMode;
12}
data:image/s3,"s3://crabby-images/f8d99/f8d992748203c15833977f80fb085ecf7f132d31" alt="QML data source playback example"
The
Loop
playback
button toggles the e playbackLoopMode true/false flag;
when this flag is true, playback is continuous, starting again from the
beginning after completing the playback of the position (GPS) log file.