summaryrefslogtreecommitdiffstats
path: root/qt-ui/models.cpp
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2013-11-12 11:12:43 +0900
committerGravatar Dirk Hohndel <dirk@hohndel.org>2013-11-12 11:17:40 +0900
commitd72c69db7a49fc20ea7618deaac4b125614afb12 (patch)
tree3b6688950e02dc7e72e83c613666a2952d3488d6 /qt-ui/models.cpp
parentcd1149e57fb077c2f3dbf0fce7a1a9478feb6743 (diff)
downloadsubsurface-d72c69db7a49fc20ea7618deaac4b125614afb12.tar.gz
Add depth colum to cylinder model
To make the planner work this adds a new column to the Cylinder widget (depth - for the depth at which we want to change to a certain gas during deco). This also tries to hide that column in the equipment view and hide the start/end pressure columns in the planner view. Oddly that fails :-( Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'qt-ui/models.cpp')
-rw-r--r--qt-ui/models.cpp19
1 files changed, 17 insertions, 2 deletions
diff --git a/qt-ui/models.cpp b/qt-ui/models.cpp
index 22e422273..7a80521a2 100644
--- a/qt-ui/models.cpp
+++ b/qt-ui/models.cpp
@@ -58,8 +58,8 @@ void CleanerTableModel::setHeaderDataStrings(const QStringList& newHeaders)
CylindersModel::CylindersModel(QObject* parent): current(0), rows(0)
{
- // enum{REMOVE, TYPE, SIZE, WORKINGPRESS, START, END, O2, HE,};
- setHeaderDataStrings( QStringList() << "" << tr("Type") << tr("Size") << tr("WorkPress") << tr("StartPress") << tr("EndPress") << tr("O2%") << tr("HE"));
+ // enum{REMOVE, TYPE, SIZE, WORKINGPRESS, START, END, O2, HE, DEPTH};
+ setHeaderDataStrings( QStringList() << "" << tr("Type") << tr("Size") << tr("WorkPress") << tr("StartPress") << tr("EndPress") << tr("O2%") << tr("HE") << tr("Switch at"));
}
CylindersModel *CylindersModel::instance()
@@ -148,6 +148,12 @@ QVariant CylindersModel::data(const QModelIndex& index, int role) const
case HE:
ret = percent_string(cyl->gasmix.he);
break;
+ case DEPTH:
+ if (prefs.units.length == prefs.units.FEET)
+ ret = mm_to_feet(cyl->depth.mm);
+ else
+ ret = cyl->depth.mm / 1000;
+ break;
}
break;
case Qt::DecorationRole:
@@ -279,6 +285,15 @@ bool CylindersModel::setData(const QModelIndex& index, const QVariant& value, in
changed = true;
}
break;
+ case DEPTH:
+ if (CHANGED(toDouble, "ft", "m")) {
+ if (value.toInt() != 0) {
+ if (prefs.units.length == prefs.units.FEET)
+ cyl->depth.mm = feet_to_mm(value.toString().remove("ft").remove("m").toInt());
+ else
+ cyl->depth.mm = value.toString().remove("ft").remove("m").toInt() * 1000;
+ }
+ }
}
dataChanged(index, index);
return true;