summaryrefslogtreecommitdiff
path: root/src/plugins/position
diff options
context:
space:
mode:
authorAlex Blasche <alexander.blasche@qt.io>2016-12-05 12:43:52 +0100
committerAlex Blasche <alexander.blasche@qt.io>2016-12-05 12:43:52 +0100
commit335116ea024f51e1693bba39f78e15131870f1b0 (patch)
tree148ccdb4703b4a35afb1b0e3875573b1eb90d0ce /src/plugins/position
parent5e4bc1fe908896e9b90e8ad9c3896f35b5ec37be (diff)
parentba9b7b9ef674d93680070f6c4bb1053d0d2325dd (diff)
downloadqtlocation-335116ea024f51e1693bba39f78e15131870f1b0.tar.gz
Merge remote-tracking branch 'gerrit/5.8' into dev
Conflicts: src/imports/location/qdeclarativegeomap.cpp src/location/maps/maps.pri src/location/maps/qgeomap_p_p.h src/plugins/geoservices/nokia/qgeocodereply_nokia.cpp src/plugins/geoservices/osm/qgeoroutereplyosm.cpp Change-Id: I18d31cff9233648178fe3e2636ce294026dfaeb7
Diffstat (limited to 'src/plugins/position')
-rw-r--r--src/plugins/position/winrt/qgeopositioninfosource_winrt.cpp21
1 files changed, 19 insertions, 2 deletions
diff --git a/src/plugins/position/winrt/qgeopositioninfosource_winrt.cpp b/src/plugins/position/winrt/qgeopositioninfosource_winrt.cpp
index a1cda7f6..a8e5e201 100644
--- a/src/plugins/position/winrt/qgeopositioninfosource_winrt.cpp
+++ b/src/plugins/position/winrt/qgeopositioninfosource_winrt.cpp
@@ -343,7 +343,7 @@ void QGeoPositionInfoSourceWinRT::virtualPositionUpdate()
// We can only do this if we received a valid position before
if (d->lastPosition.isValid()) {
QGeoPositionInfo sent = d->lastPosition;
- sent.setTimestamp(QDateTime::currentDateTime());
+ sent.setTimestamp(sent.timestamp().addMSecs(updateInterval()));
d->lastPosition = sent;
emit positionUpdated(sent);
}
@@ -498,7 +498,24 @@ HRESULT QGeoPositionInfoSourceWinRT::onPositionChanged(IGeolocator *locator, IPo
currentInfo.setAttribute(QGeoPositionInfo::Direction, value);
}
- currentInfo.setTimestamp(QDateTime::currentDateTime());
+ DateTime dateTime;
+ hr = coord->get_Timestamp(&dateTime);
+
+ if (dateTime.UniversalTime > 0) {
+ ULARGE_INTEGER uLarge;
+ uLarge.QuadPart = dateTime.UniversalTime;
+ FILETIME fileTime;
+ fileTime.dwHighDateTime = uLarge.HighPart;
+ fileTime.dwLowDateTime = uLarge.LowPart;
+ SYSTEMTIME systemTime;
+ if (FileTimeToSystemTime(&fileTime, &systemTime)) {
+ currentInfo.setTimestamp(QDateTime(QDate(systemTime.wYear, systemTime.wMonth,
+ systemTime.wDay),
+ QTime(systemTime.wHour, systemTime.wMinute,
+ systemTime.wSecond, systemTime.wMilliseconds),
+ Qt::UTC));
+ }
+ }
emit nativePositionUpdate(currentInfo);