mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
Connect preferences to the rest of the code
The biggest problem here was that bool has different sizes in C and C++ code. So using this in a structure shared between the two sides wasn't a smart idea. Instead I went with 'short', but that caused problems with Qt being to smart for its own good and not doing the right thing when dealing with 'boolean' settings and a short value. This may be something in the way I implemented things (as I doubt that something this fundamental would be broken) but the workaround implemented here (explicitly using 0 or 1 depending on the value of the boolean) seems to work. I also decided to get rid of the confusion of where gflow/gfhigh are floating point (0..1) and when they are integers (0..100). We now use integers anywhere outside of deco.c. I also applied some serious spelling corrections to the preferences dialog's ui file. Finally, this enables the code that selects which partial pressure graph to show. Still to do: font size, metric/imperial logic Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
parent
8394828806
commit
4f53ad736d
10 changed files with 120 additions and 92 deletions
|
@ -1,6 +1,5 @@
|
|||
#include "preferences.h"
|
||||
#include "ui_preferences.h"
|
||||
#include "../dive.h"
|
||||
#include <QSettings>
|
||||
|
||||
PreferencesDialog* PreferencesDialog::instance()
|
||||
|
@ -9,32 +8,36 @@ PreferencesDialog* PreferencesDialog::instance()
|
|||
return dialog;
|
||||
}
|
||||
|
||||
#define B(V, P) s.value(#V, default_prefs.P).toBool()
|
||||
#define D(V, P) s.value(#V, default_prefs.P).toDouble()
|
||||
#define I(V, P) s.value(#V, default_prefs.P).toInt()
|
||||
|
||||
PreferencesDialog::PreferencesDialog(QWidget* parent, Qt::WindowFlags f) : QDialog(parent, f)
|
||||
, ui(new Ui::PreferencesDialog())
|
||||
{
|
||||
ui->setupUi(this);
|
||||
connect(ui->buttonBox, SIGNAL(accepted()), this, SLOT(syncSettings()));
|
||||
connect(ui->buttonBox, SIGNAL(rejected()), this, SLOT(resetSettings()));
|
||||
|
||||
#define B(X) s.value(#X, false).toBool()
|
||||
#define D(X) s.value(#X, 0.0).toDouble()
|
||||
oldPrefs = prefs;
|
||||
|
||||
QSettings s;
|
||||
|
||||
// Graph
|
||||
s.beginGroup("TecDetails");
|
||||
ui->calculated_ceiling->setChecked(B(show_calculated_ceiling));
|
||||
ui->phe->setChecked(B(show_phe));
|
||||
ui->po2->setChecked(B(show_po2));
|
||||
ui->pn2->setChecked(B(show_pn2));
|
||||
ui->pheThreshould->setValue(D(phe_threshould));
|
||||
ui->po2Threashould->setValue(D(po2_threshould));
|
||||
ui->pn2Threshould->setValue(D(pn2_threshould));
|
||||
ui->ead_end_eadd->setChecked(B(show_ead_end_eadd));
|
||||
ui->dc_reported_ceiling->setChecked(B(show_dc_reported_ceiling));
|
||||
ui->calculated_ceiling->setChecked(B(show_calculated_ceiling));
|
||||
ui->increment_3m->setChecked(B(show_3m_increments));
|
||||
ui->gflow->setValue(D(gflow));
|
||||
ui->gfhigh->setValue(D(gfhigh));
|
||||
ui->calculated_ceiling->setChecked(B(calcceiling, profile_calc_ceiling));
|
||||
ui->phe->setChecked(B(phegraph, pp_graphs.phe));
|
||||
ui->po2->setChecked(B(po2graph, pp_graphs.po2));
|
||||
ui->pn2->setChecked(B(pn2graph, pp_graphs.pn2));
|
||||
ui->pheThreshold->setValue(D(phethreshold, pp_graphs.phe_threshold));
|
||||
ui->po2Threshold->setValue(D(po2threshold, pp_graphs.po2_threshold));
|
||||
ui->pn2Threshold->setValue(D(pn2threshold, pp_graphs.pn2_threshold));
|
||||
ui->ead_end_eadd->setChecked(B(ead, ead));
|
||||
ui->dc_reported_ceiling->setChecked(B(dcceiling, profile_dc_ceiling));
|
||||
ui->calculated_ceiling->setChecked(B(calceiling, profile_calc_ceiling));
|
||||
ui->increment_3m->setChecked(B(calcceiling3m, calc_ceiling_3m_incr));
|
||||
ui->gflow->setValue((int)(I(gflow, gflow)));
|
||||
ui->gfhigh->setValue((int)(I(gfhigh, gfhigh)));
|
||||
s.endGroup();
|
||||
|
||||
// Units
|
||||
|
@ -68,36 +71,44 @@ PreferencesDialog::PreferencesDialog(QWidget* parent, Qt::WindowFlags f) : QDial
|
|||
// Defaults
|
||||
s.beginGroup("GeneralSettings");
|
||||
ui->font->setFont( QFont(s.value("table_fonts").toString()));
|
||||
ui->fontsize->setValue(D(font_size));
|
||||
ui->fontsize->setValue(D(font_size, font_size));
|
||||
|
||||
ui->defaultfilename->setText(s.value("default_file").toString());
|
||||
ui->displayinvalid->setChecked(B(show_invalid));
|
||||
ui->defaultfilename->setText(s.value("default_filename").toString());
|
||||
ui->displayinvalid->setChecked(B(show_invalid, show_invalid));
|
||||
s.endGroup();
|
||||
}
|
||||
|
||||
#undef B
|
||||
#undef D
|
||||
|
||||
void PreferencesDialog::resetSettings()
|
||||
{
|
||||
prefs = oldPrefs;
|
||||
}
|
||||
|
||||
#define SB(V, B) s.setValue(V, (int)(B->isChecked() ? 1 : 0))
|
||||
|
||||
void PreferencesDialog::syncSettings()
|
||||
{
|
||||
QSettings s;
|
||||
|
||||
// Graph
|
||||
s.beginGroup("TecDetails");
|
||||
s.setValue("show_calculated_ceiling", ui->calculated_ceiling->isChecked());
|
||||
s.setValue("show_phe", ui->phe->isChecked());
|
||||
s.setValue("show_po2", ui->po2->isChecked());
|
||||
s.setValue("show_pn2", ui->pn2->isChecked());
|
||||
s.setValue("phe_threshould", ui->pheThreshould->value());
|
||||
s.setValue("po2_threshould", ui->po2Threashould->value());
|
||||
s.setValue("pn2_threshould", ui->pn2Threshould->value());
|
||||
s.setValue("show_ead_end_eadd", ui->ead_end_eadd->isChecked());
|
||||
s.setValue("show_dc_reported_ceiling", ui->dc_reported_ceiling->isChecked());
|
||||
s.setValue("show_calculated_ceiling", ui->calculated_ceiling->isChecked());
|
||||
|
||||
s.setValue("show_3m_increments", ui->increment_3m->isChecked());
|
||||
SB("calcceiling", ui->calculated_ceiling);
|
||||
SB("phegraph", ui->phe);
|
||||
SB("po2graph", ui->po2);
|
||||
SB("pn2graph", ui->pn2);
|
||||
s.setValue("phethreshold", ui->pheThreshold->value());
|
||||
s.setValue("po2threshold", ui->po2Threshold->value());
|
||||
s.setValue("pn2threshold", ui->pn2Threshold->value());
|
||||
SB("ead", ui->ead_end_eadd);
|
||||
SB("dcceiling", ui->dc_reported_ceiling);
|
||||
SB("calceiling3m", ui->increment_3m);
|
||||
s.setValue("gflow", ui->gflow->value());
|
||||
s.setValue("gfhigh", ui->gfhigh->value());
|
||||
s.endGroup();
|
||||
|
||||
// Units
|
||||
s.beginGroup("Units");
|
||||
s.setValue("units_metric", ui->metric->isChecked());
|
||||
|
@ -111,10 +122,13 @@ void PreferencesDialog::syncSettings()
|
|||
s.beginGroup("GeneralSettings");
|
||||
s.value("table_fonts", ui->font->font().family());
|
||||
s.value("font_size", ui->fontsize->value());
|
||||
s.value("default_file", ui->defaultfilename->text());
|
||||
s.value("default_filename", ui->defaultfilename->text());
|
||||
s.value("displayinvalid", ui->displayinvalid->isChecked());
|
||||
s.endGroup();
|
||||
s.sync();
|
||||
|
||||
oldPrefs = prefs;
|
||||
emit settingsChanged();
|
||||
}
|
||||
|
||||
#undef SB
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue