summaryrefslogtreecommitdiffstats
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
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>
-rw-r--r--qt-ui/diveplanner.cpp21
-rw-r--r--qt-ui/diveplanner.h2
2 files changed, 20 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();
}
diff --git a/qt-ui/diveplanner.h b/qt-ui/diveplanner.h
index 9fc9cc641..ce89d1df1 100644
--- a/qt-ui/diveplanner.h
+++ b/qt-ui/diveplanner.h
@@ -43,6 +43,7 @@ public:
struct diveplan getDiveplan();
public slots:
int addStop(int meters = 0, int minutes = 0, int o2 = 0, int he = 0, int ccpoint = 0 );
+ void addCylinder_clicked();
void setGFHigh(short gfhigh);
void setGFLow(short ghflow);
void setSurfacePressure(int pressure);
@@ -69,6 +70,7 @@ private:
struct dive *tempDive;
void deleteTemporaryPlan(struct divedatapoint *dp);
QVector<sample> backupSamples; // For editing added dives.
+ struct dive *stagingDive;
};
class Button : public QObject, public QGraphicsRectItem {