diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2019-03-25 22:18:32 +0100 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2019-04-12 18:19:07 +0300 |
commit | 8287d86d2b83fb5a343f2638391b1393a73cde72 (patch) | |
tree | 7adfc3dfa1a871c0e400d506f0706ec7c61ce631 /desktop-widgets | |
parent | 22fe0c14e885161ae9a18a00b71283a77679d06c (diff) | |
download | subsurface-8287d86d2b83fb5a343f2638391b1393a73cde72.tar.gz |
Dive site: add proximity field to dive site list
Merging dive sites is currently only possible if dive sites are at
the exact same position.
Introduce a field where the user can enter a distance up to which all
dive sites should be listed. These can then be merged.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'desktop-widgets')
-rw-r--r-- | desktop-widgets/locationinformation.cpp | 26 | ||||
-rw-r--r-- | desktop-widgets/locationinformation.h | 3 | ||||
-rw-r--r-- | desktop-widgets/locationinformation.ui | 23 |
3 files changed, 50 insertions, 2 deletions
diff --git a/desktop-widgets/locationinformation.cpp b/desktop-widgets/locationinformation.cpp index 1a80486a3..e5e14fadb 100644 --- a/desktop-widgets/locationinformation.cpp +++ b/desktop-widgets/locationinformation.cpp @@ -11,6 +11,7 @@ #include "core/subsurface-qt/DiveListNotifier.h" #include "command.h" #include "core/taxonomy.h" +#include "core/settings/qPrefUnit.h" #include <QDebug> #include <QShowEvent> @@ -20,7 +21,7 @@ #include <QDesktopWidget> #include <QScrollBar> -LocationInformationWidget::LocationInformationWidget(QWidget *parent) : QGroupBox(parent), diveSite(nullptr) +LocationInformationWidget::LocationInformationWidget(QWidget *parent) : QGroupBox(parent), diveSite(nullptr), closeDistance(0) { ui.setupUi(this); ui.diveSiteMessage->setCloseButtonVisible(false); @@ -35,6 +36,8 @@ LocationInformationWidget::LocationInformationWidget(QWidget *parent) : QGroupBo ui.diveSiteCoordinates->installEventFilter(this); connect(&diveListNotifier, &DiveListNotifier::diveSiteChanged, this, &LocationInformationWidget::diveSiteChanged); + connect(qPrefUnits::instance(), &qPrefUnits::unit_systemChanged, this, &LocationInformationWidget::unitsChanged); + unitsChanged(); ui.diveSiteListView->setModel(&filter_model); ui.diveSiteListView->setModelColumn(LocationInformationModel::NAME); @@ -112,6 +115,17 @@ void LocationInformationWidget::updateLabels() ui.locationTags->setText(constructLocationTags(&diveSite->taxonomy, false)); } +void LocationInformationWidget::unitsChanged() +{ + if (prefs.units.length == units::METERS) { + ui.diveSiteDistanceUnits->setText("m"); + ui.diveSiteDistance->setText(QString::number(lrint(closeDistance / 1000.0))); + } else { + ui.diveSiteDistanceUnits->setText("ft"); + ui.diveSiteDistance->setText(QString::number(lrint(mm_to_feet(closeDistance)))); + } +} + void LocationInformationWidget::diveSiteChanged(struct dive_site *ds, int field) { if (diveSite != ds) @@ -222,6 +236,16 @@ void LocationInformationWidget::on_diveSiteNotes_editingFinished() Command::editDiveSiteNotes(diveSite, ui.diveSiteNotes->toPlainText()); } +void LocationInformationWidget::on_diveSiteDistance_textChanged(const QString &s) +{ + bool ok; + uint64_t d = s.toLongLong(&ok); + if (!ok) + d = 0; + closeDistance = prefs.units.length == units::METERS ? d * 1000 : feet_to_mm(d); + filter_model.setDistance(closeDistance); +} + void LocationInformationWidget::reverseGeocode() { location_t location = parseGpsText(ui.diveSiteCoordinates->text()); diff --git a/desktop-widgets/locationinformation.h b/desktop-widgets/locationinformation.h index beb5fd404..84066af71 100644 --- a/desktop-widgets/locationinformation.h +++ b/desktop-widgets/locationinformation.h @@ -27,17 +27,20 @@ public slots: void on_diveSiteDescription_editingFinished(); void on_diveSiteName_editingFinished(); void on_diveSiteNotes_editingFinished(); + void on_diveSiteDistance_textChanged(const QString &s); void reverseGeocode(); void mergeSelectedDiveSites(); private slots: void updateLabels(); void diveSiteChanged(struct dive_site *ds, int field); + void unitsChanged(); private: void keyPressEvent(QKeyEvent *e) override; void clearLabels(); Ui::LocationInformation ui; GPSLocationInformationModel filter_model; dive_site *diveSite; + int64_t closeDistance; // Distance of "close" dive sites in mm }; class DiveLocationFilterProxyModel : public QSortFilterProxyModel { diff --git a/desktop-widgets/locationinformation.ui b/desktop-widgets/locationinformation.ui index f45d0ceea..72e7fb2e1 100644 --- a/desktop-widgets/locationinformation.ui +++ b/desktop-widgets/locationinformation.ui @@ -94,10 +94,31 @@ <item row="9" column="0" colspan="5"> <widget class="QGroupBox" name="diveSiteGroupBox"> <property name="title"> - <string>Dive sites on same coordinates</string> + <string>Near dive sites</string> </property> <layout class="QVBoxLayout" name="verticalLayout"> <item> + <layout class="QHBoxLayout" name="horizontalLayout"> + <item> + <widget class="QLabel" name="label_8"> + <property name="text"> + <string>Show dive sites in the range of:</string> + </property> + </widget> + </item> + <item> + <widget class="QLineEdit" name="diveSiteDistance"/> + </item> + <item> + <widget class="QLabel" name="diveSiteDistanceUnits"> + <property name="text"> + <string></string> + </property> + </widget> + </item> + </layout> + </item> + <item> <widget class="QListView" name="diveSiteListView"> <property name="sizePolicy"> <sizepolicy hsizetype="Expanding" vsizetype="Preferred"> |