summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Robert C. Helling <helling@atdotde.de>2014-05-06 15:28:32 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-05-08 13:13:49 -0700
commite3ef1b7a1ea58d7f6f912dc00412d7ee954cb5fe (patch)
tree5d766766991600395f4dc28d647503d7fb351f3c
parenta422aa29860840d7ac7738b25789501ff9f530e1 (diff)
downloadsubsurface-e3ef1b7a1ea58d7f6f912dc00412d7ee954cb5fe.tar.gz
Planner: show gas for the NEXT segment
For deco stops show the gas of the next segment in the table. In recalculation remove old deco stops earlier. In struct diveplan, the items are "segments" with a beginning, a duration, and a gas. In contrast, the UI of the planner uses "waypoints" which are the boundaries between segments. It is conventional at least for deco stops to display the gas of the _next_ segment in the runtime table (i.e. the gas possibly to be switched to). Furthermore, in addStop, the old deco stops have to be removed earlier as otherwise a new waypoint later than a previous generated gas switch inherits the gas of the old switch. Signed-off-by: Robert C. Helling <helling@atdotde.de> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--qt-ui/diveplanner.cpp18
1 files changed, 6 insertions, 12 deletions
diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp
index 8a85070e6..cef6610ac 100644
--- a/qt-ui/diveplanner.cpp
+++ b/qt-ui/diveplanner.cpp
@@ -456,11 +456,13 @@ QStringList &DivePlannerPointsModel::getGasList()
void DivePlannerPointsModel::removeDeco()
{
+ bool oldrec = setRecalc(false);
QVector<int> computedPoints;
for (int i = 0; i < plannerModel->rowCount(); i++)
if (!plannerModel->at(i).entered)
computedPoints.push_back(i);
removeSelectedPoints(computedPoints);
+ setRecalc(oldrec);
}
void DivePlannerGraphics::drawProfile()
@@ -539,7 +541,7 @@ void DivePlannerGraphics::drawProfile()
lines << item;
if (dp->depth) {
if (dp->depth == lastdepth || dp->o2 != dp->next->o2 || dp->he != dp->next->he)
- plannerModel->addStop(dp->depth, dp->time, dp->o2, dp->he, 0, false);
+ plannerModel->addStop(dp->depth, dp->time, dp->next->o2, dp->next->he, 0, false);
lastdepth = dp->depth;
}
}
@@ -1087,7 +1089,6 @@ QVariant DivePlannerPointsModel::data(const QModelIndex &index, int role) const
else
return p.time / 60;
case GAS:
-
return dpGasToStr(p);
}
} else if (role == Qt::DecorationRole) {
@@ -1275,6 +1276,9 @@ int DivePlannerPointsModel::lastEnteredPoint()
int DivePlannerPointsModel::addStop(int milimeters, int seconds, int o2, int he, int ccpoint, bool entered)
{
+ if (recalcQ())
+ removeDeco();
+
int row = divepoints.count();
if (seconds == 0 && milimeters == 0 && row != 0) {
/* this is only possible if the user clicked on the 'plus' sign on the DivePoints Table */
@@ -1333,16 +1337,6 @@ int DivePlannerPointsModel::addStop(int milimeters, int seconds, int o2, int he,
}
}
- // Get rid of deco stops before adding waypoints
- bool oldRecalc = setRecalc(false);
- if (oldRecalc) {
- QVector<int> computedPoints;
- for (int i = 0; i < plannerModel->rowCount(); i++)
- if (!plannerModel->at(i).entered)
- computedPoints.push_back(i);
- plannerModel->removeSelectedPoints(computedPoints);
- }
- setRecalc(oldRecalc);
// add the new stop
beginInsertRows(QModelIndex(), row, row);
divedatapoint point;