summaryrefslogtreecommitdiffstats
path: root/desktop-widgets/globe.h
diff options
context:
space:
mode:
authorGravatar Tomaz Canabrava <tomaz.canabrava@intel.com>2015-09-03 14:20:19 -0300
committerGravatar Dirk Hohndel <dirk@hohndel.org>2015-10-30 10:36:49 -0700
commite49d6213ad129284a45d53c3fcdc03249e84efe2 (patch)
tree2946a666ab38af3375e7bb2b8c5dd887d4a7f9a1 /desktop-widgets/globe.h
parent588abd019fb2ed3f607682f2b6c7fe86a7a5bb90 (diff)
downloadsubsurface-e49d6213ad129284a45d53c3fcdc03249e84efe2.tar.gz
Move qt-ui to desktop-widgets
Since we have now destkop and mobile versions, 'qt-ui' was a very poor name choice for a folder that contains only destkop-enabled widgets. Also, move the graphicsview-common.h/cpp to subsurface-core because it doesn't depend on qgraphicsview, it merely implements all the colors that we use throughout Subsurface, and we will use colors on both desktop and mobile versions Same thing applies for metrics.h/cpp Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'desktop-widgets/globe.h')
-rw-r--r--desktop-widgets/globe.h84
1 files changed, 84 insertions, 0 deletions
diff --git a/desktop-widgets/globe.h b/desktop-widgets/globe.h
new file mode 100644
index 000000000..8cc1265e4
--- /dev/null
+++ b/desktop-widgets/globe.h
@@ -0,0 +1,84 @@
+#ifndef GLOBE_H
+#define GLOBE_H
+
+#include <stdint.h>
+
+#ifndef NO_MARBLE
+#include <marble/MarbleWidget.h>
+#include <marble/GeoDataCoordinates.h>
+
+#include <QHash>
+
+namespace Marble{
+ class GeoDataDocument;
+}
+
+class KMessageWidget;
+using namespace Marble;
+struct dive;
+
+class GlobeGPS : public MarbleWidget {
+ Q_OBJECT
+public:
+ using MarbleWidget::centerOn;
+ static GlobeGPS *instance();
+ void reload();
+ bool eventFilter(QObject *, QEvent *);
+
+protected:
+ /* reimp */ void resizeEvent(QResizeEvent *event);
+ /* reimp */ void mousePressEvent(QMouseEvent *event);
+ /* reimp */ void contextMenuEvent(QContextMenuEvent *);
+
+private:
+ GeoDataDocument *loadedDives;
+ KMessageWidget *messageWidget;
+ QTimer *fixZoomTimer;
+ int currentZoomLevel;
+ bool needResetZoom;
+ bool editingDiveLocation;
+ bool doubleClick;
+ GlobeGPS(QWidget *parent = 0);
+
+signals:
+ void coordinatesChanged();
+
+public
+slots:
+ void repopulateLabels();
+ void changeDiveGeoPosition(qreal lon, qreal lat, GeoDataCoordinates::Unit);
+ void mouseClicked(qreal lon, qreal lat, GeoDataCoordinates::Unit);
+ void fixZoom(bool now = false);
+ void zoomOutForNoGPS();
+ void prepareForGetDiveCoordinates();
+ void endGetDiveCoordinates();
+ void centerOnDiveSite(struct dive_site *ds);
+ void centerOnIndex(const QModelIndex& idx);
+};
+
+#else // NO_MARBLE
+/* Dummy widget for when we don't have MarbleWidget */
+#include <QLabel>
+
+class GlobeGPS : public QLabel {
+ Q_OBJECT
+public:
+ GlobeGPS(QWidget *parent = 0);
+ static GlobeGPS *instance();
+ void reload();
+ void repopulateLabels();
+ void centerOnDiveSite(uint32_t uuid);
+ void centerOnIndex(const QModelIndex& idx);
+ void centerOnCurrentDive();
+ bool eventFilter(QObject *, QEvent *);
+public
+slots:
+ void prepareForGetDiveCoordinates();
+ void endGetDiveCoordinates();
+};
+
+#endif // NO_MARBLE
+
+extern "C" double getDistance(int lat1, int lon1, int lat2, int lon2);
+
+#endif // GLOBE_H