summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--subsurface-core/gpslocation.cpp32
-rw-r--r--subsurface-core/gpslocation.h2
2 files changed, 24 insertions, 10 deletions
diff --git a/subsurface-core/gpslocation.cpp b/subsurface-core/gpslocation.cpp
index c0d55a0be..e75856a98 100644
--- a/subsurface-core/gpslocation.cpp
+++ b/subsurface-core/gpslocation.cpp
@@ -19,25 +19,39 @@ GpsLocation::GpsLocation(void (*showMsgCB)(const char *), QObject *parent)
// create a QSettings object that's separate from the main application settings
geoSettings = new QSettings(QSettings::NativeFormat, QSettings::UserScope,
QString("org.subsurfacedivelog"), QString("subsurfacelocation"), this);
- gpsSource = QGeoPositionInfoSource::createDefaultSource(parent);
- if (gpsSource != 0) {
- QString msg = QString("have position source %1").arg(gpsSource->sourceName());
- connect(gpsSource, SIGNAL(positionUpdated(QGeoPositionInfo)), this, SLOT(newPosition(QGeoPositionInfo)));
- connect(gpsSource, SIGNAL(updateTimeout()), this, SLOT(updateTimeout()));
- gpsSource->setUpdateInterval(5 * 60 * 1000); // 5 minutes so the device doesn't drain the battery
- } else {
- status("don't have GPS source");
- }
userAgent = getUserAgent();
}
+QGeoPositionInfoSource *GpsLocation::getGpsSource()
+{
+ static QGeoPositionInfoSource *gpsSource = NULL;
+ static bool initGpsSource = false;
+
+ if (!initGpsSource) {
+ gpsSource = QGeoPositionInfoSource::createDefaultSource(this);
+ initGpsSource = true;
+ if (gpsSource != 0) {
+ status("created GPS source");
+ QString msg = QString("have position source %1").arg(gpsSource->sourceName());
+ connect(gpsSource, SIGNAL(positionUpdated(QGeoPositionInfo)), this, SLOT(newPosition(QGeoPositionInfo)));
+ connect(gpsSource, SIGNAL(updateTimeout()), this, SLOT(updateTimeout()));
+ gpsSource->setUpdateInterval(5 * 60 * 1000); // 5 minutes so the device doesn't drain the battery
+ } else {
+ status("don't have GPS source");
+ }
+ }
+ return gpsSource;
+}
+
bool GpsLocation::hasLocationsSource()
{
+ QGeoPositionInfoSource *gpsSource = getGpsSource();
return gpsSource != 0 && (gpsSource->supportedPositioningMethods() & QGeoPositionInfoSource::SatellitePositioningMethods);
}
void GpsLocation::serviceEnable(bool toggle)
{
+ QGeoPositionInfoSource *gpsSource = getGpsSource();
if (!gpsSource) {
if (toggle)
status("Can't start location service, no location source available");
diff --git a/subsurface-core/gpslocation.h b/subsurface-core/gpslocation.h
index 8796b3100..e0e825cb1 100644
--- a/subsurface-core/gpslocation.h
+++ b/subsurface-core/gpslocation.h
@@ -21,7 +21,7 @@ public:
private:
QGeoPositionInfo lastPos;
- QGeoPositionInfoSource *gpsSource;
+ QGeoPositionInfoSource *getGpsSource();
void status(QString msg);
QSettings *geoSettings;
QNetworkReply *reply;