diff --git a/desktop-widgets/preferences.cpp b/desktop-widgets/preferences.cpp
index 672d75906..9ef93fafc 100644
--- a/desktop-widgets/preferences.cpp
+++ b/desktop-widgets/preferences.cpp
@@ -64,8 +64,7 @@ PreferencesDialog::PreferencesDialog(QWidget *parent, Qt::WindowFlags f) : QDial
#endif
connect(ui.proxyType, SIGNAL(currentIndexChanged(int)), this, SLOT(proxyType_changed(int)));
connect(ui.buttonBox, SIGNAL(clicked(QAbstractButton *)), this, SLOT(buttonClicked(QAbstractButton *)));
- connect(ui.gflow, SIGNAL(valueChanged(int)), this, SLOT(gflowChanged(int)));
- connect(ui.gfhigh, SIGNAL(valueChanged(int)), this, SLOT(gfhighChanged(int)));
+
// connect(ui.defaultSetpoint, SIGNAL(valueChanged(double)), this, SLOT(defaultSetpointChanged(double)));
QShortcut *close = new QShortcut(QKeySequence(Qt::CTRL + Qt::Key_W), this);
connect(close, SIGNAL(activated()), this, SLOT(close()));
@@ -120,17 +119,6 @@ void PreferencesDialog::cloudPinNeeded()
MainWindow::instance()->enableDisableCloudActions();
}
-#define DANGER_GF (gf > 100) ? "* { color: red; }" : ""
-void PreferencesDialog::gflowChanged(int gf)
-{
- ui.gflow->setStyleSheet(DANGER_GF);
-}
-void PreferencesDialog::gfhighChanged(int gf)
-{
- ui.gfhigh->setStyleSheet(DANGER_GF);
-}
-#undef DANGER_GF
-
void PreferencesDialog::showEvent(QShowEvent *event)
{
setUiFromPrefs();
@@ -140,25 +128,6 @@ void PreferencesDialog::showEvent(QShowEvent *event)
void PreferencesDialog::setUiFromPrefs()
{
- // graphs
- ui.pheThreshold->setValue(prefs.pp_graphs.phe_threshold);
- ui.po2Threshold->setValue(prefs.pp_graphs.po2_threshold);
- ui.pn2Threshold->setValue(prefs.pp_graphs.pn2_threshold);
- ui.maxpo2->setValue(prefs.modpO2);
- ui.red_ceiling->setChecked(prefs.redceiling);
-
- ui.gflow->setValue(prefs.gflow);
- ui.gfhigh->setValue(prefs.gfhigh);
- ui.gf_low_at_maxdepth->setChecked(prefs.gf_low_at_maxdepth);
- ui.show_ccr_setpoint->setChecked(prefs.show_ccr_setpoint);
- ui.show_ccr_sensors->setChecked(prefs.show_ccr_sensors);
- ui.defaultSetpoint->setValue((double)prefs.defaultsetpoint / 1000.0);
- ui.psro2rate->setValue(prefs.o2consumption / 1000.0);
- ui.pscrfactor->setValue(rint(1000.0 / prefs.pscr_ratio));
-
- ui.display_unused_tanks->setChecked(prefs.display_unused_tanks);
- ui.show_average_depth->setChecked(prefs.show_average_depth);
-
QSettings s;
ui.save_uid_local->setChecked(s.value("save_uid_local").toBool());
@@ -197,29 +166,6 @@ void PreferencesDialog::syncSettings()
s.setValue("subsurface_webservice_uid", ui.default_uid->text().toUpper());
set_save_userid_local(ui.save_uid_local->checkState());
- // Graph
- s.beginGroup("TecDetails");
- SAVE_OR_REMOVE("phethreshold", default_prefs.pp_graphs.phe_threshold, ui.pheThreshold->value());
- SAVE_OR_REMOVE("po2threshold", default_prefs.pp_graphs.po2_threshold, ui.po2Threshold->value());
- SAVE_OR_REMOVE("pn2threshold", default_prefs.pp_graphs.pn2_threshold, ui.pn2Threshold->value());
- SAVE_OR_REMOVE("modpO2", default_prefs.modpO2, ui.maxpo2->value());
- SAVE_OR_REMOVE("redceiling", default_prefs.redceiling, ui.red_ceiling->isChecked());
- SAVE_OR_REMOVE("gflow", default_prefs.gflow, ui.gflow->value());
- SAVE_OR_REMOVE("gfhigh", default_prefs.gfhigh, ui.gfhigh->value());
- SAVE_OR_REMOVE("gf_low_at_maxdepth", default_prefs.gf_low_at_maxdepth, ui.gf_low_at_maxdepth->isChecked());
- SAVE_OR_REMOVE("show_ccr_setpoint", default_prefs.show_ccr_setpoint, ui.show_ccr_setpoint->isChecked());
- SAVE_OR_REMOVE("show_ccr_sensors", default_prefs.show_ccr_sensors, ui.show_ccr_sensors->isChecked());
- SAVE_OR_REMOVE("display_unused_tanks", default_prefs.display_unused_tanks, ui.display_unused_tanks->isChecked());
- SAVE_OR_REMOVE("show_average_depth", default_prefs.show_average_depth, ui.show_average_depth->isChecked());
- s.endGroup();
-
- // Defaults
- s.beginGroup("GeneralSettings");
- s.setValue("defaultsetpoint", rint(ui.defaultSetpoint->value() * 1000.0));
- s.setValue("o2consumption", rint(ui.psro2rate->value() *1000.0));
- s.setValue("pscr_ratio", rint(1000.0 / ui.pscrfactor->value()));
- s.endGroup();
-
s.beginGroup("Network");
s.setValue("proxy_type", ui.proxyType->itemData(ui.proxyType->currentIndex()).toInt());
s.setValue("proxy_host", ui.proxyHost->text());
diff --git a/desktop-widgets/preferences.h b/desktop-widgets/preferences.h
index c05145611..4d2c33e76 100644
--- a/desktop-widgets/preferences.h
+++ b/desktop-widgets/preferences.h
@@ -29,8 +29,6 @@ slots:
void loadSettings();
void restorePrefs();
void rememberPrefs();
- void gflowChanged(int gf);
- void gfhighChanged(int gf);
void proxyType_changed(int idx);
void facebookLoggedIn();
void facebookDisconnect();
diff --git a/desktop-widgets/preferences.ui b/desktop-widgets/preferences.ui
index 12ba10d4b..97e281433 100644
--- a/desktop-widgets/preferences.ui
+++ b/desktop-widgets/preferences.ui
@@ -6,8 +6,8 @@
0
0
- 711
- 662
+ 835
+ 698
@@ -19,7 +19,16 @@
-
+
+ 5
+
+
+ 5
+
+
+ 5
+
+
5
-
@@ -83,16 +92,6 @@
-1
-
-
-
- Graph
-
-
-
- :/graph
-
-
-
-
Network
@@ -126,297 +125,6 @@
0
-
-
-
- 0
- 0
-
-
-
-
- 5
-
-
- 5
-
-
-
-
-
- Show
-
-
-
-
-
-
-
-
-
- true
-
-
- Threshold when showing pO₂
-
-
-
- -
-
-
- true
-
-
- 0.100000000000000
-
-
-
-
-
- -
-
-
-
-
-
- true
-
-
- Threshold when showing pN₂
-
-
-
- -
-
-
- true
-
-
- 0.100000000000000
-
-
-
-
-
- -
-
-
-
-
-
- true
-
-
- Threshold when showing pHe
-
-
-
- -
-
-
- true
-
-
- 0.100000000000000
-
-
-
-
-
- -
-
-
-
-
-
- true
-
-
- Max pO₂ when showing MOD
-
-
-
- -
-
-
- true
-
-
- 0.100000000000000
-
-
-
-
-
- -
-
-
-
-
-
- true
-
-
- Draw dive computer reported ceiling red
-
-
-
-
-
- -
-
-
-
-
-
- Show unused cylinders in Equipment tab
-
-
-
-
-
- -
-
-
-
-
-
- Show average depth
-
-
-
-
-
-
-
-
- -
-
-
- Misc
-
-
-
-
-
-
- GFLow
-
-
-
- -
-
-
- 1
-
-
- 150
-
-
-
- -
-
-
- GFHigh
-
-
-
- -
-
-
- 1
-
-
- 150
-
-
-
- -
-
-
- GFLow at max depth
-
-
-
- -
-
-
- CCR: show setpoints when viewing pO₂
-
-
-
- -
-
-
- CCR: show individual O₂ sensor values when viewing pO₂
-
-
-
- -
-
-
- Default CCR set-point for dive planning
-
-
-
- -
-
-
- bar
-
-
- 2
-
-
- 10.000000000000000
-
-
- 0.100000000000000
-
-
-
- -
-
-
- pSCR O₂ metabolism rate
-
-
-
- -
-
-
- pSCR ratio
-
-
-
- -
-
-
- ℓ/min
-
-
- 3
-
-
-
- -
-
-
-
-
-
- 1:
-
-
-
-
-
-
- -
-
-
- Qt::Vertical
-
-
-
- 0
- 0
-
-
-
-
-
-
@@ -428,7 +136,16 @@
5
-
+
+ 5
+
+
+ 5
+
+
+ 5
+
+
5
-
@@ -658,7 +375,16 @@
5
-
+
+ 5
+
+
+ 5
+
+
+ 5
+
+
5
-
@@ -707,7 +433,16 @@
5
-
+
+ 5
+
+
+ 5
+
+
+ 5
+
+
5
-
@@ -842,15 +577,4 @@
-
-
-
-
-
-
-
-
-
-
-
diff --git a/desktop-widgets/preferences/CMakeLists.txt b/desktop-widgets/preferences/CMakeLists.txt
index 8ea4bd79c..b3ef4e3d5 100644
--- a/desktop-widgets/preferences/CMakeLists.txt
+++ b/desktop-widgets/preferences/CMakeLists.txt
@@ -16,6 +16,7 @@ set(SUBSURFACE_PREFERENCES_LIB_SRCS
preferences_georeference.cpp
preferences_defaults.cpp
preferences_units.cpp
+ preferences_graph.cpp
)
source_group("Subsurface Preferences" FILES ${SUBSURFACE_PREFERENCES_LIB_SRCS})
diff --git a/desktop-widgets/preferences/preferences_graph.cpp b/desktop-widgets/preferences/preferences_graph.cpp
new file mode 100644
index 000000000..f671076f4
--- /dev/null
+++ b/desktop-widgets/preferences/preferences_graph.cpp
@@ -0,0 +1,78 @@
+#include "preferences_graph.h"
+#include "ui_preferences_graph.h"
+#include "subsurface-core/prefs-macros.h"
+
+#include
+#include
+
+#include "qt-models/models.h"
+
+PreferencesGraph::PreferencesGraph() : AbstractPreferencesWidget(tr("Graph"), QIcon(":graph"), 5)
+{
+ ui = new Ui::PreferencesGraph();
+ ui->setupUi(this);
+}
+
+PreferencesGraph::~PreferencesGraph()
+{
+ delete ui;
+}
+
+void PreferencesGraph::refreshSettings()
+{
+ ui->pheThreshold->setValue(prefs.pp_graphs.phe_threshold);
+ ui->po2Threshold->setValue(prefs.pp_graphs.po2_threshold);
+ ui->pn2Threshold->setValue(prefs.pp_graphs.pn2_threshold);
+ ui->maxpo2->setValue(prefs.modpO2);
+ ui->red_ceiling->setChecked(prefs.redceiling);
+
+ ui->gflow->setValue(prefs.gflow);
+ ui->gfhigh->setValue(prefs.gfhigh);
+ ui->gf_low_at_maxdepth->setChecked(prefs.gf_low_at_maxdepth);
+ ui->show_ccr_setpoint->setChecked(prefs.show_ccr_setpoint);
+ ui->show_ccr_sensors->setChecked(prefs.show_ccr_sensors);
+ ui->defaultSetpoint->setValue((double)prefs.defaultsetpoint / 1000.0);
+ ui->psro2rate->setValue(prefs.o2consumption / 1000.0);
+ ui->pscrfactor->setValue(rint(1000.0 / prefs.pscr_ratio));
+
+ ui->display_unused_tanks->setChecked(prefs.display_unused_tanks);
+ ui->show_average_depth->setChecked(prefs.show_average_depth);
+}
+
+void PreferencesGraph::syncSettings()
+{
+ QSettings s;
+
+ s.beginGroup("GeneralSettings");
+ s.setValue("defaultsetpoint", rint(ui->defaultSetpoint->value() * 1000.0));
+ s.setValue("o2consumption", rint(ui->psro2rate->value() *1000.0));
+ s.setValue("pscr_ratio", rint(1000.0 / ui->pscrfactor->value()));
+ s.endGroup();
+
+ // Graph
+ s.beginGroup("TecDetails");
+ SAVE_OR_REMOVE("phethreshold", default_prefs.pp_graphs.phe_threshold, ui->pheThreshold->value());
+ SAVE_OR_REMOVE("po2threshold", default_prefs.pp_graphs.po2_threshold, ui->po2Threshold->value());
+ SAVE_OR_REMOVE("pn2threshold", default_prefs.pp_graphs.pn2_threshold, ui->pn2Threshold->value());
+ SAVE_OR_REMOVE("modpO2", default_prefs.modpO2, ui->maxpo2->value());
+ SAVE_OR_REMOVE("redceiling", default_prefs.redceiling, ui->red_ceiling->isChecked());
+ SAVE_OR_REMOVE("gflow", default_prefs.gflow, ui->gflow->value());
+ SAVE_OR_REMOVE("gfhigh", default_prefs.gfhigh, ui->gfhigh->value());
+ SAVE_OR_REMOVE("gf_low_at_maxdepth", default_prefs.gf_low_at_maxdepth, ui->gf_low_at_maxdepth->isChecked());
+ SAVE_OR_REMOVE("show_ccr_setpoint", default_prefs.show_ccr_setpoint, ui->show_ccr_setpoint->isChecked());
+ SAVE_OR_REMOVE("show_ccr_sensors", default_prefs.show_ccr_sensors, ui->show_ccr_sensors->isChecked());
+ SAVE_OR_REMOVE("display_unused_tanks", default_prefs.display_unused_tanks, ui->display_unused_tanks->isChecked());
+ SAVE_OR_REMOVE("show_average_depth", default_prefs.show_average_depth, ui->show_average_depth->isChecked());
+ s.endGroup();
+}
+
+#define DANGER_GF (gf > 100) ? "* { color: red; }" : ""
+void PreferencesGraph::on_gflow_valueChanged(int gf)
+{
+ ui->gflow->setStyleSheet(DANGER_GF);
+}
+void PreferencesGraph::on_gfhigh_valueChanged(int gf)
+{
+ ui->gfhigh->setStyleSheet(DANGER_GF);
+}
+#undef DANGER_GF
\ No newline at end of file
diff --git a/desktop-widgets/preferences/preferences_graph.h b/desktop-widgets/preferences/preferences_graph.h
new file mode 100644
index 000000000..ca40c0a92
--- /dev/null
+++ b/desktop-widgets/preferences/preferences_graph.h
@@ -0,0 +1,27 @@
+#ifndef PREFERENCES_GRAPH_H
+#define PREFERENCES_GRAPH_H
+
+#include "abstractpreferenceswidget.h"
+
+namespace Ui {
+ class PreferencesGraph;
+}
+
+class PreferencesGraph : public AbstractPreferencesWidget {
+ Q_OBJECT
+public:
+ PreferencesGraph();
+ virtual ~PreferencesGraph();
+ virtual void refreshSettings();
+ virtual void syncSettings();
+
+private slots:
+ void on_gflow_valueChanged(int gf);
+ void on_gfhigh_valueChanged(int gf);
+
+private:
+ Ui::PreferencesGraph *ui;
+
+};
+
+#endif
\ No newline at end of file
diff --git a/desktop-widgets/preferences/preferences_graph.ui b/desktop-widgets/preferences/preferences_graph.ui
new file mode 100644
index 000000000..bdbbc75d3
--- /dev/null
+++ b/desktop-widgets/preferences/preferences_graph.ui
@@ -0,0 +1,268 @@
+
+
+ PreferencesGraph
+
+
+
+ 0
+ 0
+ 505
+ 623
+
+
+
+ Form
+
+
+
-
+
+
+ Show
+
+
+
-
+
+
+ true
+
+
+ Threshold when showing pO₂
+
+
+
+ -
+
+
+ true
+
+
+ 0.100000000000000
+
+
+
+ -
+
+
+ true
+
+
+ Threshold when showing pN₂
+
+
+
+ -
+
+
+ true
+
+
+ 0.100000000000000
+
+
+
+ -
+
+
+ true
+
+
+ Threshold when showing pHe
+
+
+
+ -
+
+
+ true
+
+
+ 0.100000000000000
+
+
+
+ -
+
+
+ true
+
+
+ Max pO₂ when showing MOD
+
+
+
+ -
+
+
+ true
+
+
+ 0.100000000000000
+
+
+
+ -
+
+
+ true
+
+
+ Draw dive computer reported ceiling red
+
+
+
+ -
+
+
+ Show unused cylinders in Equipment tab
+
+
+
+ -
+
+
+ Show average depth
+
+
+
+
+
+
+ -
+
+
+ Misc
+
+
+
-
+
+
+ 1
+
+
+ 150
+
+
+
+ -
+
+
+ bar
+
+
+ 2
+
+
+ 10.000000000000000
+
+
+ 0.100000000000000
+
+
+
+ -
+
+
+ Default CCR set-point for dive planning
+
+
+
+ -
+
+
+ pSCR O₂ metabolism rate
+
+
+
+ -
+
+
+ GFLow
+
+
+
+ -
+
+
+ GFHigh
+
+
+
+ -
+
+
+ 1
+
+
+ 150
+
+
+
+ -
+
+
+ ℓ/min
+
+
+ 3
+
+
+
+ -
+
+
+ pSCR ratio
+
+
+
+ -
+
+
+
+
+
+ 1:
+
+
+
+ -
+
+
+ CCR: show individual O₂ sensor values when viewing pO₂
+
+
+
+ -
+
+
+ CCR: show setpoints when viewing pO₂
+
+
+
+ -
+
+
+ GFLow at max depth
+
+
+
+
+
+
+ -
+
+
+ Qt::Vertical
+
+
+
+ 20
+ 40
+
+
+
+
+
+
+
+
+
diff --git a/desktop-widgets/preferences/preferencesdialog.cpp b/desktop-widgets/preferences/preferencesdialog.cpp
index 7d9e17d7e..db1d30113 100644
--- a/desktop-widgets/preferences/preferencesdialog.cpp
+++ b/desktop-widgets/preferences/preferencesdialog.cpp
@@ -5,6 +5,7 @@
#include "preferences_georeference.h"
#include "preferences_defaults.h"
#include "preferences_units.h"
+#include "preferences_graph.h"
#include
#include
@@ -39,6 +40,7 @@ PreferencesDialogV2::PreferencesDialogV2()
addPreferencePage(new PreferencesGeoreference());
addPreferencePage(new PreferencesDefaults());
addPreferencePage(new PreferencesUnits());
+ addPreferencePage(new PreferencesGraph());
refreshPages();
connect(pagesList, &QListWidget::currentRowChanged,