summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2014-10-20 17:36:24 -0700
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-10-20 17:40:11 -0700
commit71d21c375c404cd675e408689c79e9d58d315ccc (patch)
treeac4a160bc1f4861daf9bb66acf5e19b718dfd717
parente1db94ea0c049184d06393e59843812c684f57cd (diff)
downloadsubsurface-71d21c375c404cd675e408689c79e9d58d315ccc.tar.gz
Recalculate the decompression if the date / time of a dive changes
The pre-existing tissue load going into a dive can change if the start time of a dive changes. Therefore we need to recalculate the ceiling when editing start time (or date) of a dive. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--qt-ui/maintab.cpp2
-rw-r--r--qt-ui/maintab.h1
-rw-r--r--qt-ui/profile/diveprofileitem.cpp9
-rw-r--r--qt-ui/profile/diveprofileitem.h4
4 files changed, 15 insertions, 1 deletions
diff --git a/qt-ui/maintab.cpp b/qt-ui/maintab.cpp
index 4f253e150..7b052e984 100644
--- a/qt-ui/maintab.cpp
+++ b/qt-ui/maintab.cpp
@@ -978,6 +978,7 @@ void MainTab::on_dateEdit_dateChanged(const QDate &date)
dateTime.setTimeSpec(Qt::UTC);
dateTime.setDate(date);
DivePlannerPointsModel::instance()->getDiveplan().when = displayed_dive.when = dateTime.toTime_t();
+ emit dateTimeChanged();
}
void MainTab::on_timeEdit_timeChanged(const QTime &time)
@@ -989,6 +990,7 @@ void MainTab::on_timeEdit_timeChanged(const QTime &time)
dateTime.setTimeSpec(Qt::UTC);
dateTime.setTime(time);
DivePlannerPointsModel::instance()->getDiveplan().when = displayed_dive.when = dateTime.toTime_t();
+ emit dateTimeChanged();
}
// changing the tags on multiple dives is semantically strange - what's the right thing to do?
diff --git a/qt-ui/maintab.h b/qt-ui/maintab.h
index 93bb1c949..47e57c2b0 100644
--- a/qt-ui/maintab.h
+++ b/qt-ui/maintab.h
@@ -53,6 +53,7 @@ public:
signals:
void addDiveFinished();
+ void dateTimeChanged();
public
slots:
diff --git a/qt-ui/profile/diveprofileitem.cpp b/qt-ui/profile/diveprofileitem.cpp
index 10fb626b6..1e7a5b535 100644
--- a/qt-ui/profile/diveprofileitem.cpp
+++ b/qt-ui/profile/diveprofileitem.cpp
@@ -11,6 +11,7 @@
#include "helpers.h"
#include "diveplanner.h"
#include "libdivecomputer/parser.h"
+#include "mainwindow.h"
#include <QPen>
#include <QPainter>
@@ -675,6 +676,7 @@ DiveCalculatedCeiling::DiveCalculatedCeiling() : is3mIncrement(false), gradientF
gradientFactor->setY(0);
gradientFactor->setBrush(getColor(PRESSURE_TEXT));
gradientFactor->setAlignment(Qt::AlignHCenter | Qt::AlignBottom);
+ connect(MainWindow::instance()->information(), SIGNAL(dateTimeChanged()), this, SLOT(recalc()));
settingsChanged();
}
@@ -757,11 +759,16 @@ void DiveReportedCeiling::modelDataChanged(const QModelIndex &topLeft, const QMo
setBrush(pat);
}
+void DiveCalculatedCeiling::recalc()
+{
+ dataModel->calculateDecompression();
+}
+
void DiveCalculatedCeiling::settingsChanged()
{
if (dataModel && is3mIncrement != prefs.calcceiling3m) {
// recalculate that part.
- dataModel->calculateDecompression();
+ recalc();
}
is3mIncrement = prefs.calcceiling3m;
setVisible(prefs.calcceiling);
diff --git a/qt-ui/profile/diveprofileitem.h b/qt-ui/profile/diveprofileitem.h
index 300e4b265..86e90224a 100644
--- a/qt-ui/profile/diveprofileitem.h
+++ b/qt-ui/profile/diveprofileitem.h
@@ -162,6 +162,10 @@ public:
virtual void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget = 0);
virtual void settingsChanged();
+public
+slots:
+ void recalc();
+
private:
bool is3mIncrement;
DiveTextItem *gradientFactor;