summaryrefslogtreecommitdiffstats
path: root/qt-models
diff options
context:
space:
mode:
Diffstat (limited to 'qt-models')
-rw-r--r--qt-models/CMakeLists.txt2
-rw-r--r--qt-models/gpslistmodel.cpp54
-rw-r--r--qt-models/gpslistmodel.h30
3 files changed, 20 insertions, 66 deletions
diff --git a/qt-models/CMakeLists.txt b/qt-models/CMakeLists.txt
index c35ca4377..34e462fa3 100644
--- a/qt-models/CMakeLists.txt
+++ b/qt-models/CMakeLists.txt
@@ -20,6 +20,8 @@ set(SUBSURFACE_MODELS_LIB_SRCS
divelocationmodel.cpp
divesitepicturesmodel.cpp
ssrfsortfilterproxymodel.cpp
+ divelistmodel.cpp
+ gpslistmodel.cpp
)
source_group("Subsurface Models" FILES ${SUBSURFACE_MODELS})
diff --git a/qt-models/gpslistmodel.cpp b/qt-models/gpslistmodel.cpp
index 6bd1cfdf0..2c6fe6b5c 100644
--- a/qt-models/gpslistmodel.cpp
+++ b/qt-models/gpslistmodel.cpp
@@ -1,38 +1,6 @@
#include "gpslistmodel.h"
#include "helpers.h"
-GpsTracker::GpsTracker()
-{
- m_latitude = 0;
- m_longitude = 0;
- m_when = 0;
- m_name = QString();
-}
-
-GpsTracker::~GpsTracker()
-{
-}
-
-uint64_t GpsTracker::when() const
-{
- return m_when;
-}
-
-int32_t GpsTracker::latitude() const
-{
- return m_latitude;
-}
-
-int32_t GpsTracker::longitude() const
-{
- return m_longitude;
-}
-
-QString GpsTracker::name() const
-{
- return m_name;
-}
-
GpsListModel *GpsListModel::m_instance = NULL;
GpsListModel::GpsListModel(QObject *parent) : QAbstractListModel(parent)
@@ -40,13 +8,21 @@ GpsListModel::GpsListModel(QObject *parent) : QAbstractListModel(parent)
m_instance = this;
}
-void GpsListModel::addGpsFix(gpsTracker *g)
+void GpsListModel::addGpsFix(gpsTracker g)
{
beginInsertColumns(QModelIndex(), rowCount(), rowCount());
- m_gpsFixes.append(GpsTracker(g));
+ m_gpsFixes.append(g);
endInsertRows();
}
+void GpsListModel::update()
+{
+ QVector<gpsTracker> trackers = GpsLocation::instance()->currentGPSInfo();
+ beginResetModel();
+ m_gpsFixes = trackers;
+ endResetModel();
+}
+
void GpsListModel::clear()
{
if (m_gpsFixes.count()) {
@@ -66,16 +42,16 @@ QVariant GpsListModel::data(const QModelIndex &index, int role) const
if (index.row() < 0 || index.row() > m_gpsFixes.count())
return QVariant();
- const GpsTracker &gt = m_gpsFixes[index.row()];
+ const gpsTracker &gt = m_gpsFixes[index.row()];
if (role == GpsDateRole)
- return get_short_dive_date_string(gt.when());
+ return get_short_dive_date_string(gt.when);
else if (role == GpsNameRole)
- return QString(gt.name());
+ return gt.name;
else if (role == GpsLatitudeRole)
- return QString::number(gt.latitude() / 1000000.0, 'f', 6);
+ return QString::number(gt.latitude.udeg / 1000000.0, 'f', 6);
else if (role == GpsLongitudeRole)
- return QString::number(gt.longitude() / 1000000.0, 'f', 6);
+ return QString::number(gt.longitude.udeg / 1000000.0, 'f', 6);
return QVariant();
}
diff --git a/qt-models/gpslistmodel.h b/qt-models/gpslistmodel.h
index 35a5a03c4..91a15540f 100644
--- a/qt-models/gpslistmodel.h
+++ b/qt-models/gpslistmodel.h
@@ -5,30 +5,6 @@
#include <QObject>
#include <QAbstractListModel>
-class GpsTracker
-{
-private:
- quint64 m_when;
- qint32 m_latitude;
- qint32 m_longitude;
- QString m_name;
-
-public:
- GpsTracker(struct gpsTracker *gt)
- {
- m_when = gt->when;
- m_latitude = gt->latitude.udeg;
- m_longitude = gt->longitude.udeg;
- m_name = gt->name;
- }
- GpsTracker();
- ~GpsTracker();
- uint64_t when() const;
- int32_t latitude() const;
- int32_t longitude() const;
- QString name() const;
-};
-
class GpsListModel : public QAbstractListModel
{
Q_OBJECT
@@ -43,14 +19,14 @@ public:
static GpsListModel *instance();
GpsListModel(QObject *parent = 0);
- void addGpsFix(struct gpsTracker *g);
+ void addGpsFix(gpsTracker g);
void clear();
int rowCount(const QModelIndex &parent = QModelIndex()) const;
QHash<int, QByteArray> roleNames() const;
QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const;
-
+ void update();
private:
- QList<GpsTracker> m_gpsFixes;
+ QVector<gpsTracker> m_gpsFixes;
static GpsListModel *m_instance;
};