summaryrefslogtreecommitdiffstats
path: root/qt-ui/diveplanner.cpp
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2013-11-10 21:02:53 +0900
committerGravatar Dirk Hohndel <dirk@hohndel.org>2013-11-10 21:02:53 +0900
commit55c127f7c36ba9d46af7a4e68101c3687edc7cbc (patch)
treed92d8dd43263893708ceeacbcb6e8478c3875108 /qt-ui/diveplanner.cpp
parentaa4931e8c613f742cb05da77dfdad73c6f3008c9 (diff)
downloadsubsurface-55c127f7c36ba9d46af7a4e68101c3687edc7cbc.tar.gz
Enable adding cylinders in the dive planner
This is in preparation of using those to define the gases available for planning. Right now this doesn't seem to work quite right - I don't get the auto-completions for the cylinders that I was hoping for... This commit also corrects the tooltip for addint dive data points. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'qt-ui/diveplanner.cpp')
-rw-r--r--qt-ui/diveplanner.cpp21
1 files changed, 18 insertions, 3 deletions
diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp
index ba0bc80d7..9865c347a 100644
--- a/qt-ui/diveplanner.cpp
+++ b/qt-ui/diveplanner.cpp
@@ -439,8 +439,6 @@ void DivePlannerPointsModel::loadFromDive(dive* d)
for(int i = 0; i < d->dc.samples-1; i++){
backupSamples.push_back( d->dc.sample[i]);
}
- save_dive(stdout, current_dive);
- save_dive(stdout, backupDive);
Q_FOREACH(const sample &s, backupSamples){
int o2 = 0, he = 0;
get_gas_from_events(&backupDive->dc, s.time.seconds, &o2, &he);
@@ -880,8 +878,9 @@ DivePlannerWidget::DivePlannerWidget(QWidget* parent, Qt::WindowFlags f): QWidge
ui.tableWidget->view()->setItemDelegateForColumn(DivePlannerPointsModel::GAS, new AirTypesDelegate(this));
ui.cylinderTableWidget->setTitle(tr("Available Gases"));
ui.cylinderTableWidget->setModel(CylindersModel::instance());
-// connect(ui.cylinderTableWidget, SIGNAL(addButtonClicked()), CylindersModel::instance(), SLOT(add()));
+ connect(ui.cylinderTableWidget, SIGNAL(addButtonClicked()), DivePlannerPointsModel::instance(), SLOT(addCylinder_clicked()));
connect(ui.tableWidget, SIGNAL(addButtonClicked()), DivePlannerPointsModel::instance(), SLOT(addStop()));
+ ui.tableWidget->setBtnToolTip(tr("add dive data point"));
connect(ui.startTime, SIGNAL(timeChanged(QTime)), this, SLOT(startTimeChanged(QTime)));
connect(ui.ATMPressure, SIGNAL(textChanged(QString)), this, SLOT(atmPressureChanged(QString)));
connect(ui.bottomSAC, SIGNAL(textChanged(QString)), this, SLOT(bottomSacChanged(QString)));
@@ -910,6 +909,15 @@ DivePlannerWidget::DivePlannerWidget(QWidget* parent, Qt::WindowFlags f): QWidge
setMinimumHeight(0);
}
+void DivePlannerPointsModel::addCylinder_clicked()
+{
+ qDebug() << "add Cylinder clicked";
+ if (!stagingDive)
+ stagingDive = alloc_dive();
+ CylindersModel::instance()->setDive(stagingDive);
+ CylindersModel::instance()->add();
+}
+
void DivePlannerWidget::startTimeChanged(const QTime& time)
{
plannerModel->setStartTime(time);
@@ -1192,6 +1200,9 @@ void DivePlannerPointsModel::cancelPlan()
clear();
emit planCanceled();
setPlanMode(NOTHING);
+ free(stagingDive);
+ stagingDive = NULL;
+ CylindersModel::instance()->setDive(current_dive);
CylindersModel::instance()->update();
}
@@ -1205,6 +1216,7 @@ void DivePlannerPointsModel::clear()
beginRemoveRows(QModelIndex(), 0, rowCount()-1);
divepoints.clear();
endRemoveRows();
+ CylindersModel::instance()->clear();
}
@@ -1286,5 +1298,8 @@ void DivePlannerPointsModel::createPlan()
clear();
planCreated();
setPlanMode(NOTHING);
+ free(stagingDive);
+ stagingDive = NULL;
+ CylindersModel::instance()->setDive(current_dive);
CylindersModel::instance()->update();
}