diff options
-rw-r--r-- | qt-ui/diveplanner.cpp | 66 | ||||
-rw-r--r-- | qt-ui/diveplanner.h | 4 | ||||
-rw-r--r-- | qt-ui/profile/profilewidget2.cpp | 3 |
3 files changed, 28 insertions, 45 deletions
diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp index 55fb19ceb..66bad705f 100644 --- a/qt-ui/diveplanner.cpp +++ b/qt-ui/diveplanner.cpp @@ -62,19 +62,16 @@ void DivePlannerPointsModel::removeSelectedPoints(const QVector<int> &rows) void DivePlannerPointsModel::createSimpleDive() { - int o2 = O2_IN_AIR; - int he = 0; - if (isPlanner()) { + struct gasmix gas = { 0 }; + if (isPlanner()) // let's use the gas from the first cylinder - o2 = stagingDive->cylinder[0].gasmix.o2.permille; - he = stagingDive->cylinder[0].gasmix.he.permille; - } - // plannerModel->addStop(0, 0, O2_IN_AIR, 0, 0); - plannerModel->addStop(M_OR_FT(15, 45), 1 * 60, o2, he, 0, true); - plannerModel->addStop(M_OR_FT(15, 45), 40 * 60, o2, he, 0, true); + gas = stagingDive->cylinder[0].gasmix; + + plannerModel->addStop(M_OR_FT(15, 45), 1 * 60, gas, 0, true); + plannerModel->addStop(M_OR_FT(15, 45), 40 * 60, gas, 0, true); if (!isPlanner()) { - plannerModel->addStop(M_OR_FT(5, 15), 42 * 60, o2, he, 0, true); - plannerModel->addStop(M_OR_FT(5, 15), 45 * 60, o2, he, 0, true); + plannerModel->addStop(M_OR_FT(5, 15), 42 * 60, gas, 0, true); + plannerModel->addStop(M_OR_FT(5, 15), 45 * 60, gas, 0, true); } } @@ -95,7 +92,7 @@ void DivePlannerPointsModel::loadFromDive(dive *d) if (s.time.seconds == 0) continue; get_gas_from_events(&backupDive.dc, lasttime, &gas); - plannerModel->addStop(s.depth.mm, s.time.seconds, get_o2(&gas), get_he(&gas), 0, true); + plannerModel->addStop(s.depth.mm, s.time.seconds, gas, 0, true); lasttime = s.time.seconds; } } @@ -519,29 +516,20 @@ bool divePointsLessThan(const divedatapoint &p1, const divedatapoint &p2) return p1.time <= p2.time; } -bool DivePlannerPointsModel::addGas(int o2, int he) +bool DivePlannerPointsModel::addGas(struct gasmix mix) { - struct gasmix mix; - - mix.o2.permille = o2; - mix.he.permille = he; sanitize_gasmix(&mix); - if (is_air(o2, he)) - o2 = 0; - for (int i = 0; i < MAX_CYLINDERS; i++) { cylinder_t *cyl = &stagingDive->cylinder[i]; if (cylinder_nodata(cyl)) { fill_default_cylinder(cyl); - cyl->gasmix.o2.permille = o2; - cyl->gasmix.he.permille = he; - sanitize_gasmix(&cyl->gasmix); + cyl->gasmix = mix; /* The depth to change to that gas is given by the depth where its pO2 is 1.6 bar. * The user should be able to change this depth manually. */ pressure_t modppO2; modppO2.mbar = 1600; - cyl->depth = gas_mod(&cyl->gasmix, modppO2); + cyl->depth = gas_mod(&mix, modppO2); CylindersModel::instance()->setDive(stagingDive); return true; } @@ -560,8 +548,9 @@ int DivePlannerPointsModel::lastEnteredPoint() return -1; } -int DivePlannerPointsModel::addStop(int milimeters, int seconds, int o2, int he, int ccpoint, bool entered) +int DivePlannerPointsModel::addStop(int milimeters, int seconds, struct gasmix gas, int ccpoint, bool entered, bool usePrevious) { + struct gasmix air = { 0 }; if (recalcQ()) removeDeco(); @@ -571,21 +560,18 @@ int DivePlannerPointsModel::addStop(int milimeters, int seconds, int o2, int he, const divedatapoint t = divepoints.at(lastEnteredPoint()); milimeters = t.depth; seconds = t.time + 600; // 10 minutes. - o2 = get_o2(&t.gasmix); - he = get_he(&t.gasmix); + gas = t.gasmix; ccpoint = t.po2; } else if (seconds == 0 && milimeters == 0 && row == 0) { milimeters = M_OR_FT(5, 15); // 5m / 15ft seconds = 600; // 10 min //Default to the first defined gas, if we got one. cylinder_t *cyl = &stagingDive->cylinder[0]; - if (cyl) { - o2 = get_o2(&cyl->gasmix); - he = get_he(&cyl->gasmix); - } + if (cyl) + gas = cyl->gasmix; } - if (o2 != -1) - if (!addGas(o2, he)) + if (!usePrevious) + if (!addGas(gas)) qDebug("addGas failed"); // FIXME add error propagation // check if there's already a new stop before this one: @@ -603,21 +589,18 @@ int DivePlannerPointsModel::addStop(int milimeters, int seconds, int o2, int he, break; } } - if (o2 == -1) { + if (usePrevious) { if (row > 0) { - o2 = get_o2(&divepoints.at(row - 1).gasmix); - he = get_he(&divepoints.at(row - 1).gasmix); + gas = divepoints.at(row - 1).gasmix; } else { // when we add a first data point we need to make sure that there is a // tank for it to use; // first check to the right, then to the left, but if there's nothing, // we simply default to AIR if (row < divepoints.count()) { - o2 = get_o2(&divepoints.at(row).gasmix); - he = get_he(&divepoints.at(row).gasmix); + gas = divepoints.at(row).gasmix; } else { - o2 = O2_IN_AIR; - if (!addGas(o2, 0)) + if (!addGas(air)) qDebug("addGas failed"); // FIXME add error propagation } } @@ -628,8 +611,7 @@ int DivePlannerPointsModel::addStop(int milimeters, int seconds, int o2, int he, divedatapoint point; point.depth = milimeters; point.time = seconds; - point.gasmix.o2.permille = o2; - point.gasmix.he.permille = he; + point.gasmix = gas; point.po2 = ccpoint; point.entered = entered; divepoints.append(point); diff --git a/qt-ui/diveplanner.h b/qt-ui/diveplanner.h index acfc83b90..eb6bf217e 100644 --- a/qt-ui/diveplanner.h +++ b/qt-ui/diveplanner.h @@ -64,7 +64,7 @@ public: public slots: - int addStop(int millimeters = 0, int seconds = 0, int o2 = 0, int he = 0, int ccpoint = 0, bool entered = true); + int addStop(int millimeters, int seconds, struct gasmix gas, int ccpoint, bool entered, bool usePrevious = false); void addCylinder_clicked(); void setGFHigh(const int gfhigh); void setGFLow(const int ghflow); @@ -88,7 +88,7 @@ signals: private: explicit DivePlannerPointsModel(QObject *parent = 0); - bool addGas(int o2, int he); + bool addGas(struct gasmix mix); struct diveplan diveplan; Mode mode; bool recalc; diff --git a/qt-ui/profile/profilewidget2.cpp b/qt-ui/profile/profilewidget2.cpp index 4cfd295f8..3d740ca1b 100644 --- a/qt-ui/profile/profilewidget2.cpp +++ b/qt-ui/profile/profilewidget2.cpp @@ -605,7 +605,8 @@ void ProfileWidget2::mouseDoubleClickEvent(QMouseEvent *event) int minutes = rint(timeAxis->valueAt(mappedPos) / 60); int milimeters = rint(profileYAxis->valueAt(mappedPos) / M_OR_FT(1, 1)) * M_OR_FT(1, 1); - plannerModel->addStop(milimeters, minutes * 60, -1, 0, 0, true); + struct gasmix ignore = { 0 }; + plannerModel->addStop(milimeters, minutes * 60, ignore, 0, true, true); } } |