diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2013-11-12 11:12:43 +0900 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2013-11-12 11:17:40 +0900 |
commit | d72c69db7a49fc20ea7618deaac4b125614afb12 (patch) | |
tree | 3b6688950e02dc7e72e83c613666a2952d3488d6 /qt-ui/models.cpp | |
parent | cd1149e57fb077c2f3dbf0fce7a1a9478feb6743 (diff) | |
download | subsurface-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.cpp | 19 |
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; |