summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--qt-ui/divelistview.cpp17
-rw-r--r--qt-ui/mainwindow.cpp151
-rw-r--r--qt-ui/mainwindow.h1
-rw-r--r--qt-ui/preferences.cpp2
4 files changed, 91 insertions, 80 deletions
diff --git a/qt-ui/divelistview.cpp b/qt-ui/divelistview.cpp
index 5883ea615..1e822869b 100644
--- a/qt-ui/divelistview.cpp
+++ b/qt-ui/divelistview.cpp
@@ -7,6 +7,7 @@
#include "divelistview.h"
#include "models.h"
#include "modeldelegates.h"
+#include "../display.h"
#include <QApplication>
#include <QHeaderView>
#include <QDebug>
@@ -136,12 +137,16 @@ void DiveListView::reload(DiveTripModel::Layout layout, bool forceSort)
return;
sortByColumn(0, Qt::DescendingOrder);
- QModelIndex firstDiveOrTrip = m->index(0,0);
- if (firstDiveOrTrip.isValid()) {
- if (m->index(0,0, firstDiveOrTrip).isValid())
- setCurrentIndex(m->index(0,0, firstDiveOrTrip));
- else
- setCurrentIndex(firstDiveOrTrip);
+ if (amount_selected && selected_dive >= 0) {
+ // magic happens and the selected dive is expanded and scrolled to
+ } else {
+ QModelIndex firstDiveOrTrip = m->index(0,0);
+ if (firstDiveOrTrip.isValid()) {
+ if (m->index(0,0, firstDiveOrTrip).isValid())
+ setCurrentIndex(m->index(0,0, firstDiveOrTrip));
+ else
+ setCurrentIndex(firstDiveOrTrip);
+ }
}
}
diff --git a/qt-ui/mainwindow.cpp b/qt-ui/mainwindow.cpp
index d8b73d636..dbf3b9c73 100644
--- a/qt-ui/mainwindow.cpp
+++ b/qt-ui/mainwindow.cpp
@@ -42,10 +42,12 @@ MainWindow::MainWindow() : ui(new Ui::MainWindow()), helpView(0)
setWindowIcon(QIcon(":subsurface-icon"));
connect(ui->ListWidget, SIGNAL(currentDiveChanged(int)), this, SLOT(current_dive_changed(int)));
connect(PreferencesDialog::instance(), SIGNAL(settingsChanged()), this, SLOT(readSettings()));
+ connect(PreferencesDialog::instance(), SIGNAL(settingsChanged()), this, SLOT(refreshDisplay()));
connect(PreferencesDialog::instance(), SIGNAL(settingsChanged()), ui->ProfileWidget, SLOT(refresh()));
ui->mainErrorMessage->hide();
ui->ProfileWidget->setFocusProxy(ui->ListWidget);
ui->ListWidget->reload();
+ initialUiSetup();
readSettings();
ui->ListWidget->reloadHeaderActions();
ui->ListWidget->setFocus();
@@ -63,7 +65,7 @@ void MainWindow::refreshDisplay()
void MainWindow::current_dive_changed(int divenr)
{
- if (amount_selected && divenr >= 0) {
+ if (divenr >= 0) {
select_dive(divenr);
ui->globe->centerOn(get_dive(selected_dive));
redrawProfile();
@@ -336,23 +338,39 @@ bool MainWindow::askSaveChanges()
return false;
}
-#define GET_UNIT(v, name, field, f, t) \
- v = settings.value(QString(name)); \
+#define GET_UNIT(name, field, f, t) \
+ v = s.value(QString(name)); \
if (v.isValid()) \
- prefs.units.field = (v.toInt() == (t)) ? (t) : (f)
+ prefs.units.field = (v.toInt() == (t)) ? (t) : (f); \
+ else \
+ prefs.units.field = default_prefs.units.field
-#define GET_BOOL(v, name, field) \
- v = settings.value(QString(name)); \
- if (v.isValid() && v.toInt()) \
- field = TRUE; \
+#define GET_BOOL(name, field) \
+ v = s.value(QString(name)); \
+ if (v.isValid()) \
+ prefs.field = v.toInt() ? TRUE : FALSE; \
else \
- field = FALSE
+ prefs.field = default_prefs.field
-void MainWindow::readSettings()
+#define GET_DOUBLE(name, field) \
+ v = s.value(QString(name)); \
+ if (v.isValid()) \
+ prefs.field = v.toDouble(); \
+ else \
+ prefs.field = default_prefs.field
+
+#define GET_INT(name, field) \
+ v = s.value(QString(name)); \
+ if (v.isValid()) \
+ prefs.field = v.toInt(); \
+ else \
+ prefs.field = default_prefs.field
+
+
+void MainWindow::initialUiSetup()
{
- int i;
- QVariant v;
QSettings settings;
+ int i;
settings.beginGroup("MainWindow");
QSize sz = settings.value("size").value<QSize>();
@@ -375,79 +393,64 @@ void MainWindow::readSettings()
ui->ListWidget->collapseAll();
ui->ListWidget->expand(ui->ListWidget->model()->index(0,0));
ui->ListWidget->scrollTo(ui->ListWidget->model()->index(0,0), QAbstractItemView::PositionAtCenter);
-
settings.endGroup();
- settings.beginGroup("Units");
- if (settings.value("unit_system").toString() == "metric") {
+}
+
+void MainWindow::readSettings()
+{
+ QVariant v;
+ QSettings s;
+
+ s.beginGroup("Units");
+ if (s.value("unit_system").toString() == "metric") {
prefs.unit_system = METRIC;
prefs.units = SI_units;
- } else if (settings.value("unit_system").toString() == "imperial") {
+ } else if (s.value("unit_system").toString() == "imperial") {
prefs.unit_system = IMPERIAL;
prefs.units = IMPERIAL_units;
} else {
prefs.unit_system = PERSONALIZE;
- GET_UNIT(v, "length", length, units::FEET, units::METERS);
- GET_UNIT(v, "pressure", pressure, units::PSI, units::BAR);
- GET_UNIT(v, "volume", volume, units::CUFT, units::LITER);
- GET_UNIT(v, "temperature", temperature, units::FAHRENHEIT, units::CELSIUS);
- GET_UNIT(v, "weight", weight, units::LBS, units::KG);
+ GET_UNIT("length", length, units::FEET, units::METERS);
+ GET_UNIT("pressure", pressure, units::PSI, units::BAR);
+ GET_UNIT("volume", volume, units::CUFT, units::LITER);
+ GET_UNIT("temperature", temperature, units::FAHRENHEIT, units::CELSIUS);
+ GET_UNIT("weight", weight, units::LBS, units::KG);
}
- settings.endGroup();
- settings.beginGroup("DisplayListColumns");
- GET_BOOL(v, "CYLINDER", prefs.visible_cols.cylinder);
- GET_BOOL(v, "TEMPERATURE", prefs.visible_cols.temperature);
- GET_BOOL(v, "TOTALWEIGHT", prefs.visible_cols.totalweight);
- GET_BOOL(v, "SUIT", prefs.visible_cols.suit);
- GET_BOOL(v, "NITROX", prefs.visible_cols.nitrox);
- GET_BOOL(v, "OTU", prefs.visible_cols.otu);
- GET_BOOL(v, "MAXCNS", prefs.visible_cols.maxcns);
- GET_BOOL(v, "SAC", prefs.visible_cols.sac);
- settings.endGroup();
- settings.beginGroup("TecDetails");
- GET_BOOL(v, "po2graph", prefs.pp_graphs.po2);
- GET_BOOL(v, "pn2graph", prefs.pp_graphs.pn2);
- GET_BOOL(v, "phegraph", prefs.pp_graphs.phe);
- v = settings.value(QString("po2threshold"));
- if (v.isValid())
- prefs.pp_graphs.po2_threshold = v.toDouble();
- v = settings.value(QString("pn2threshold"));
- if (v.isValid())
- prefs.pp_graphs.pn2_threshold = v.toDouble();
- v = settings.value(QString("phethreshold"));
- if (v.isValid())
- prefs.pp_graphs.phe_threshold = v.toDouble();
- GET_BOOL(v, "mod", prefs.mod);
- v = settings.value(QString("modppO2"));
- if (v.isValid())
- prefs.mod_ppO2 = v.toDouble();
- GET_BOOL(v, "ead", prefs.ead);
- GET_BOOL(v, "redceiling", prefs.profile_red_ceiling);
- GET_BOOL(v, "dcceiling", prefs.profile_dc_ceiling);
- GET_BOOL(v, "calcceiling", prefs.profile_calc_ceiling);
- GET_BOOL(v, "calcceiling3m", prefs.calc_ceiling_3m_incr);
- GET_BOOL(v, "calcalltissues", prefs.calc_all_tissues);
- v = settings.value(QString("gflow"));
- if (v.isValid())
- prefs.gflow = v.toInt();
- v = settings.value(QString("gfhigh"));
- if (v.isValid())
- prefs.gfhigh = v.toInt();
+ s.endGroup();
+ s.beginGroup("DisplayListColumns");
+ GET_BOOL("CYLINDER", visible_cols.cylinder);
+ GET_BOOL("TEMPERATURE", visible_cols.temperature);
+ GET_BOOL("TOTALWEIGHT", visible_cols.totalweight);
+ GET_BOOL("SUIT", visible_cols.suit);
+ GET_BOOL("NITROX", visible_cols.nitrox);
+ GET_BOOL("OTU", visible_cols.otu);
+ GET_BOOL("MAXCNS", visible_cols.maxcns);
+ GET_BOOL("SAC", visible_cols.sac);
+ s.endGroup();
+ s.beginGroup("TecDetails");
+ GET_BOOL("po2graph", pp_graphs.po2);
+ GET_BOOL("pn2graph", pp_graphs.pn2);
+ GET_BOOL("phegraph", pp_graphs.phe);
+ GET_DOUBLE("po2threshold", pp_graphs.po2_threshold);
+ GET_DOUBLE("pn2threshold", pp_graphs.pn2_threshold);
+ GET_DOUBLE("phethreshold", pp_graphs.phe_threshold);
+ GET_BOOL("mod", mod);
+ GET_DOUBLE("modppO2", mod_ppO2);
+ GET_BOOL("ead", ead);
+ GET_BOOL("redceiling", profile_red_ceiling);
+ GET_BOOL("dcceiling", profile_dc_ceiling);
+ GET_BOOL("calcceiling", profile_calc_ceiling);
+ GET_BOOL("calcceiling3m", calc_ceiling_3m_incr);
+ GET_BOOL("calcalltissues", calc_all_tissues);
+ GET_INT("gflow", gflow);
+ GET_INT("gfhigh", gfhigh);
set_gf(prefs.gflow, prefs.gfhigh);
- settings.endGroup();
+ s.endGroup();
-#if ONCE_WE_CAN_SET_FONTS
- settings.beginGroup("Display");
- v = settings.value(QString("divelist_font"));
+ s.beginGroup("Display");
+ v = s.value(QString("divelist_font"));
if (v.isValid())
- /* I don't think this is right */
- prefs.divelist_font = strdup(v.toString);
-#endif
-
-#if ONCE_WE_HAVE_MAPS
- v = settings.value(QString_int("map_provider"));
- if (v.isValid())
- prefs.map_provider = v.toInt();
-#endif
+ prefs.divelist_font = strdup(v.toString().toUtf8().data());
}
#define SAVE_VALUE(name, field) \
diff --git a/qt-ui/mainwindow.h b/qt-ui/mainwindow.h
index f3e728176..f3024ef8d 100644
--- a/qt-ui/mainwindow.h
+++ b/qt-ui/mainwindow.h
@@ -82,6 +82,7 @@ private Q_SLOTS:
void on_actionUserManual_triggered();
void current_dive_changed(int divenr);
+ void initialUiSetup();
protected:
void closeEvent(QCloseEvent *);
diff --git a/qt-ui/preferences.cpp b/qt-ui/preferences.cpp
index c4ca83e1f..9a2eff8f1 100644
--- a/qt-ui/preferences.cpp
+++ b/qt-ui/preferences.cpp
@@ -172,9 +172,11 @@ void PreferencesDialog::buttonClicked(QAbstractButton* button)
close();
break;
case QDialogButtonBox::Apply:
+ setPrefsFromUi();
syncSettings();
break;
case QDialogButtonBox::FirstButton:
+ setPrefsFromUi();
syncSettings();
close();
break;