summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2014-06-28 08:07:59 -0700
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-06-28 08:07:59 -0700
commitd25e31525ca5050a955c17c1b7d54201d81a6186 (patch)
treecb1a53449b1e78a490fa8c04fa2014f68d8bb941
parent20e0aba0b49b6b496b473d08c1559217bb60a108 (diff)
parent06a8002a2de0dc731f0ecd5ec87cf210ec2b9c2c (diff)
downloadsubsurface-d25e31525ca5050a955c17c1b7d54201d81a6186.tar.gz
Merge branch 'fixPlannerStartTime'
-rw-r--r--qt-ui/diveplanner.cpp36
-rw-r--r--qt-ui/diveplanner.h7
-rw-r--r--qt-ui/diveplanner.ui22
-rw-r--r--qt-ui/mainwindow.cpp1
4 files changed, 60 insertions, 6 deletions
diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp
index d2d2e2a8d..9735fec36 100644
--- a/qt-ui/diveplanner.cpp
+++ b/qt-ui/diveplanner.cpp
@@ -82,6 +82,22 @@ void DivePlannerPointsModel::createSimpleDive()
}
}
+void DivePlannerPointsModel::setupStartTime()
+{
+ // if the latest dive is in the future, then start an hour after it ends
+ // otherwise start an hour from now
+ startTime = QDateTime::currentDateTimeUtc().addSecs(3600 + gettimezoneoffset());
+ if (dive_table.nr) {
+ struct dive *d = get_dive(dive_table.nr - 1);
+ time_t ends = d->when + d->duration.seconds;
+ time_t diff = ends - startTime.toTime_t();
+ if (diff > 0) {
+ startTime = startTime.addSecs(diff + 3600);
+ }
+ }
+ emit startTimeChanged(startTime);
+}
+
void DivePlannerPointsModel::loadFromDive(dive *d)
{
// We need to make a copy, because as soon as the model is modified, it will
@@ -276,8 +292,10 @@ DivePlannerWidget::DivePlannerWidget(QWidget *parent, Qt::WindowFlags f) : QWidg
ui.tableWidget->setBtnToolTip(tr("add dive data point"));
connect(ui.startTime, SIGNAL(timeChanged(QTime)), plannerModel, SLOT(setStartTime(QTime)));
+ connect(ui.dateEdit, SIGNAL(dateChanged(QDate)), plannerModel, SLOT(setStartDate(QDate)));
connect(ui.ATMPressure, SIGNAL(valueChanged(int)), this, SLOT(atmPressureChanged(int)));
connect(ui.atmHeight, SIGNAL(valueChanged(int)), this, SLOT(heightChanged(int)));
+ connect(DivePlannerPointsModel::instance(), SIGNAL(startTimeChanged(QDateTime)), this, SLOT(setupStartTime(QDateTime)));
// Creating (and canceling) the plan
connect(ui.buttonBox, SIGNAL(accepted()), plannerModel, SLOT(createPlan()));
@@ -286,7 +304,6 @@ DivePlannerWidget::DivePlannerWidget(QWidget *parent, Qt::WindowFlags f) : QWidg
connect(closeKey, SIGNAL(activated()), plannerModel, SLOT(cancelPlan()));
/* set defaults. */
- ui.startTime->setTime(QTime(1, 0));
ui.ATMPressure->setValue(1013);
ui.atmHeight->setValue(0);
@@ -294,6 +311,12 @@ DivePlannerWidget::DivePlannerWidget(QWidget *parent, Qt::WindowFlags f) : QWidg
setMinimumHeight(0);
}
+void DivePlannerWidget::setupStartTime(QDateTime startTime)
+{
+ ui.startTime->setTime(startTime.time());
+ ui.dateEdit->setDate(startTime.date());
+}
+
void DivePlannerWidget::settingsChanged()
{
// right now there's nothing special we do when settings change
@@ -595,6 +618,7 @@ DivePlannerPointsModel::DivePlannerPointsModel(QObject *parent) : QAbstractTable
{
memset(&diveplan, 0, sizeof(diveplan));
memset(&backupDive, 0, sizeof(backupDive));
+ startTime = QDateTime::currentDateTimeUtc();
}
DivePlannerPointsModel *DivePlannerPointsModel::instance()
@@ -690,9 +714,17 @@ void DivePlannerPointsModel::setDropStoneMode(bool value)
emit dataChanged(createIndex(0, 0), createIndex(rowCount() - 1, COLUMNS - 1));
}
+void DivePlannerPointsModel::setStartDate(const QDate &date)
+{
+ startTime.setDate(date);
+ diveplan.when = startTime.toTime_t();
+ emit dataChanged(createIndex(0, 0), createIndex(rowCount() - 1, COLUMNS - 1));
+}
+
void DivePlannerPointsModel::setStartTime(const QTime &t)
{
- diveplan.when = (t.msec() + QDateTime::currentMSecsSinceEpoch()) / 1000 - gettimezoneoffset();
+ startTime.setTime(t);
+ diveplan.when = startTime.toTime_t();
emit dataChanged(createIndex(0, 0), createIndex(rowCount() - 1, COLUMNS - 1));
}
diff --git a/qt-ui/diveplanner.h b/qt-ui/diveplanner.h
index 378707d96..08a1ba519 100644
--- a/qt-ui/diveplanner.h
+++ b/qt-ui/diveplanner.h
@@ -3,6 +3,7 @@
#include <QGraphicsPathItem>
#include <QAbstractTableModel>
+#include <QDateTime>
#include "dive.h"
@@ -37,6 +38,7 @@ public:
void setPlanMode(Mode mode);
bool isPlanner();
void createSimpleDive();
+ void setupStartTime();
void clear();
Mode currentMode() const;
bool setRecalc(bool recalc);
@@ -69,6 +71,7 @@ slots:
void setBottomSac(int sac);
void setDecoSac(int sac);
void setStartTime(const QTime &t);
+ void setStartDate(const QDate &date);
void setLastStop6m(bool value);
void setDropStoneMode(bool value);
void setVerbatim(bool value);
@@ -88,6 +91,7 @@ signals:
void planCreated();
void planCanceled();
void cylinderModelEdited();
+ void startTimeChanged(QDateTime);
private:
explicit DivePlannerPointsModel(QObject *parent = 0);
@@ -103,6 +107,7 @@ private:
struct dive *stagingDive;
QVector<QPair<int, int> > oldGases;
bool drop_stone_mode;
+ QDateTime startTime;
};
class DiveHandler : public QObject, public QGraphicsEllipseItem {
@@ -129,9 +134,9 @@ class DivePlannerWidget : public QWidget {
Q_OBJECT
public:
explicit DivePlannerWidget(QWidget *parent = 0, Qt::WindowFlags f = 0);
-
public
slots:
+ void setupStartTime(QDateTime startTime);
void settingsChanged();
void atmPressureChanged(const int pressure);
void heightChanged(const int height);
diff --git a/qt-ui/diveplanner.ui b/qt-ui/diveplanner.ui
index fffed0d99..5441c2a38 100644
--- a/qt-ui/diveplanner.ui
+++ b/qt-ui/diveplanner.ui
@@ -95,13 +95,12 @@
<height>50</height>
</size>
</property>
- <zorder>label_2</zorder>
</widget>
</item>
<item row="0" column="0">
<widget class="QLabel" name="label">
<property name="text">
- <string>Start Time</string>
+ <string>Planned Dive Time</string>
</property>
</widget>
</item>
@@ -113,7 +112,18 @@
</widget>
</item>
<item row="1" column="0">
- <widget class="QTimeEdit" name="startTime"/>
+ <layout class="QHBoxLayout" name="dateAndTime">
+ <item>
+ <widget class="DateWidget" name="dateEdit" native="true">
+ <property name="focusPolicy">
+ <enum>Qt::StrongFocus</enum>
+ </property>
+ </widget>
+ </item>
+ <item>
+ <widget class="QTimeEdit" name="startTime"/>
+ </item>
+ </layout>
</item>
<item row="2" column="0">
<widget class="QLabel" name="label_7">
@@ -165,6 +175,12 @@
<header>tableview.h</header>
<container>1</container>
</customwidget>
+ <customwidget>
+ <class>DateWidget</class>
+ <extends>QWidget</extends>
+ <header>simplewidgets.h</header>
+ <container>1</container>
+ </customwidget>
</customwidgets>
<tabstops>
<tabstop>startTime</tabstop>
diff --git a/qt-ui/mainwindow.cpp b/qt-ui/mainwindow.cpp
index 146dced4b..2cde8d992 100644
--- a/qt-ui/mainwindow.cpp
+++ b/qt-ui/mainwindow.cpp
@@ -483,6 +483,7 @@ void MainWindow::on_actionDivePlanner_triggered()
DivePlannerPointsModel::instance()->setupCylinders();
// create a simple starting dive, using the first gas from the just copied cylidners
+ DivePlannerPointsModel::instance()->setupStartTime();
createFakeDiveForAddAndPlan();
DivePlannerPointsModel::instance()->createSimpleDive();