summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--gpslocation.cpp29
-rw-r--r--gpslocation.h13
-rw-r--r--subsurface-mobile-helper.cpp3
3 files changed, 41 insertions, 4 deletions
diff --git a/gpslocation.cpp b/gpslocation.cpp
index 6725abfb9..da4734897 100644
--- a/gpslocation.cpp
+++ b/gpslocation.cpp
@@ -1,7 +1,32 @@
#include "gpslocation.h"
+#include <QDebug>
-GpsLocation::GpsLocation()
-{
+GpsLocation::GpsLocation(QObject *parent)
+{
+ QGeoPositionInfoSource *gpsSource = QGeoPositionInfoSource::createDefaultSource(parent);
+ if (gpsSource != 0) {
+ qDebug() << "have position source" << gpsSource->sourceName();
+ connect(gpsSource, SIGNAL(positionUpdated(QGeoPositionInfo)), this, SLOT(newPosition(QGeoPositionInfo)));
+ connect(gpsSource, SIGNAL(updateTimeout()), this, SLOT(updateTimeout()));
+ lastPos = gpsSource->lastKnownPosition();
+ gpsSource->requestUpdate(1000);
+ QGeoCoordinate lastCoord = lastPos.coordinate();
+ if (lastCoord.isValid()) {
+ qDebug() << lastCoord.toString();
+ } else {
+ qDebug() << "invalid last position";
+ }
+ } else {
+ qDebug() << "don't have GPS source";
+ }
+}
+void GpsLocation::newPosition(QGeoPositionInfo pos)
+{
+ qDebug() << "received new position" << pos.coordinate().toString();
}
+void GpsLocation::updateTimeout()
+{
+ qDebug() << "request to get new position timed out";
+}
diff --git a/gpslocation.h b/gpslocation.h
index 68f574bd7..8e26fd25e 100644
--- a/gpslocation.h
+++ b/gpslocation.h
@@ -1,16 +1,25 @@
#ifndef GPSLOCATION_H
#define GPSLOCATION_H
+#include <QObject>
#include <QGeoCoordinate>
+#include <QGeoPositionInfoSource>
+#include <QGeoPositionInfo>
-class GpsLocation
+class GpsLocation : QObject
{
+ Q_OBJECT
public:
- GpsLocation();
+ GpsLocation(QObject *parent);
+
+private:
+ QGeoPositionInfo lastPos;
signals:
public slots:
+ void newPosition(QGeoPositionInfo pos);
+ void updateTimeout();
};
#endif // GPSLOCATION_H
diff --git a/subsurface-mobile-helper.cpp b/subsurface-mobile-helper.cpp
index e982760f8..0643ae9e0 100644
--- a/subsurface-mobile-helper.cpp
+++ b/subsurface-mobile-helper.cpp
@@ -18,6 +18,8 @@
#include "qt-mobile/qmlmanager.h"
#include "qt-models/divelistmodel.h"
#include "qt-mobile/qmlprofile.h"
+#include "gpslocation.h"
+GpsLocation *locationProvider;
QObject *qqWindowObject = NULL;
@@ -52,6 +54,7 @@ void run_ui()
qml_window->setHeight(1200);
qml_window->setWidth(800);
#endif
+ locationProvider = new GpsLocation(qml_window);
qml_window->show();
qApp->exec();
}