summaryrefslogtreecommitdiffstats
path: root/qt-ui/globe.cpp
diff options
context:
space:
mode:
authorGravatar Tomaz Canabrava <tcanabrava@kde.org>2014-05-01 14:47:52 -0300
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-05-01 15:23:33 -0700
commit4243fcb9156218f54b3103ce7c8de6ea222f3cfb (patch)
tree7b09846deb68cde5e4d60ede981fff9c8a17c20c /qt-ui/globe.cpp
parent7f3b487c77c71cc7e3f62bfd2ebde4559a0a6e56 (diff)
downloadsubsurface-4243fcb9156218f54b3103ce7c8de6ea222f3cfb.tar.gz
Dont set coordinates when two or more dives are selectedv4.0.97
If a trip is selected (or for other reasons more than one dive), this would change the GPS coordinates of the whole selection which almost certainly isn't what the user wanted. Instead, only allow changes of the coordinates on the globe if exactly one dive is selected. [Dirk Hohndel: massively rewritten and extended - but I didn't want to simply "steal" the commit from Tomaz... This now maintains the "zoom out mode" for dives without GPS coordinates and deals with edits of multiple dives that are initiated the "normal way" by starting to edit other data as well.] Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'qt-ui/globe.cpp')
-rw-r--r--qt-ui/globe.cpp52
1 files changed, 33 insertions, 19 deletions
diff --git a/qt-ui/globe.cpp b/qt-ui/globe.cpp
index 03dccfe14..1fcbdea1d 100644
--- a/qt-ui/globe.cpp
+++ b/qt-ui/globe.cpp
@@ -3,9 +3,10 @@
#include "kmessagewidget.h"
#include "mainwindow.h"
#include "ui_mainwindow.h"
-#include "../dive.h"
-#include "../divelist.h"
-#include "../helpers.h"
+#include "dive.h"
+#include "divelist.h"
+#include "helpers.h"
+#include "display.h"
#include <QDebug>
#include <QTimer>
@@ -203,15 +204,24 @@ void GlobeGPS::reload()
void GlobeGPS::centerOn(dive *dive)
{
// dive has changed, if we had the 'editingDive', hide it.
- if (messageWidget->isVisible() && (!dive || dive_has_gps_location(dive)))
+ if (messageWidget->isVisible()
+ && (!dive || dive_has_gps_location(dive) || amount_selected != 1 ))
messageWidget->hide();
+
+ editingDiveLocation = false;
if (!dive)
return;
+
qreal longitude = dive->longitude.udeg / 1000000.0;
qreal latitude = dive->latitude.udeg / 1000000.0;
- if (!longitude || !latitude || MainWindow::instance()->information()->isEditing()) {
- prepareForGetDiveCoordinates();
+ if ((!dive_has_gps_location(dive) || MainWindow::instance()->information()->isEditing())
+ && amount_selected == 1) {
+ prepareForGetDiveCoordinates(dive);
+ return;
+ }
+ if (!dive_has_gps_location(dive)) {
+ zoomOutForNoGPS();
return;
}
@@ -239,7 +249,21 @@ void GlobeGPS::fixZoom()
setZoom(currentZoomLevel, Marble::Linear);
}
-void GlobeGPS::prepareForGetDiveCoordinates()
+void GlobeGPS::zoomOutForNoGPS()
+{
+ // this is called if the dive has no GPS location.
+ // zoom out quite a bit to show the globe and remember that the next time
+ // we show a dive with GPS location we need to zoom in again
+ if(fixZoomTimer->isActive())
+ fixZoomTimer->stop();
+ setZoom(1200, Marble::Automatic);
+ if (!needResetZoom) {
+ needResetZoom = true;
+ currentZoomLevel = zoom();
+ }
+}
+
+void GlobeGPS::prepareForGetDiveCoordinates(struct dive *dive)
{
if (!messageWidget->isVisible()) {
messageWidget->setMessageType(KMessageWidget::Warning);
@@ -247,18 +271,8 @@ void GlobeGPS::prepareForGetDiveCoordinates()
messageWidget->setWordWrap(true);
messageWidget->animatedShow();
editingDiveLocation = true;
- // if the dive has no GPS location, zoom out quite a bit to show the globe
- // and remember that the next time we show a dive with GPS location we need
- // to zoom in again
- if (!dive_has_gps_location(current_dive)) {
- if(fixZoomTimer->isActive())
- fixZoomTimer->stop();
- setZoom(1200, Marble::Automatic);
- if (!needResetZoom) {
- needResetZoom = true;
- currentZoomLevel = zoom();
- }
- }
+ if (!dive_has_gps_location(dive))
+ zoomOutForNoGPS();
}
}