summaryrefslogtreecommitdiffhomepage
path: root/gui/settings.cpp
diff options
context:
space:
mode:
authorStanislaw Halik <sthalik@misaki.pl>2017-10-22 11:10:34 +0200
committerStanislaw Halik <sthalik@misaki.pl>2017-10-27 16:42:57 +0200
commit0a0000a6c4ca5ebfffd33d70f7b7963473be1471 (patch)
tree90e31f30303b4b4d4f4e83086ff4ee70d915fe77 /gui/settings.cpp
parentd20e3d4a3ac6114b296f0284f336b59c178b4e72 (diff)
gui: rename source files only
Diffstat (limited to 'gui/settings.cpp')
-rw-r--r--gui/settings.cpp241
1 files changed, 241 insertions, 0 deletions
diff --git a/gui/settings.cpp b/gui/settings.cpp
new file mode 100644
index 00000000..3105bad9
--- /dev/null
+++ b/gui/settings.cpp
@@ -0,0 +1,241 @@
+/* Copyright (c) 2015, Stanislaw Halik <sthalik@misaki.pl>
+
+ * Permission to use, copy, modify, and/or distribute this
+ * software for any purpose with or without fee is hereby granted,
+ * provided that the above copyright notice and this permission
+ * notice appear in all copies.
+ */
+
+#include "settings.hpp"
+#include "keyboard.h"
+#include "opentrack-library-path.h"
+#include <QPushButton>
+#include <QLayout>
+#include <QDialog>
+#include <QFileDialog>
+
+QString OptionsDialog::kopts_to_string(const key_opts& kopts)
+{
+ if (static_cast<QString>(kopts.guid) != "")
+ {
+ const int btn = kopts.button & ~Qt::KeyboardModifierMask;
+ const int mods = kopts.button & Qt::KeyboardModifierMask;
+ QString mm;
+ if (mods & Qt::ControlModifier) mm += "Control+";
+ if (mods & Qt::AltModifier) mm += "Alt+";
+ if (mods & Qt::ShiftModifier) mm += "Shift+";
+ return mm + tr("Joy button %1").arg(QString::number(btn));
+ }
+ if (static_cast<QString>(kopts.keycode) == "")
+ return tr("None");
+ return kopts.keycode;
+}
+
+void OptionsDialog::set_disable_translation_state(bool value)
+{
+ group::with_global_settings_object([&](QSettings& s)
+ {
+ s.setValue("disable-translation", value);
+ });
+}
+
+OptionsDialog::OptionsDialog(std::function<void(bool)> pause_keybindings) :
+ pause_keybindings(pause_keybindings)
+{
+ ui.setupUi(this);
+
+ connect(ui.buttonBox, SIGNAL(accepted()), this, SLOT(doOK()));
+ connect(ui.buttonBox, SIGNAL(rejected()), this, SLOT(doCancel()));
+
+ tie_setting(main.tray_enabled, ui.trayp);
+ tie_setting(main.tray_start, ui.tray_start);
+
+ tie_setting(main.center_at_startup, ui.center_at_startup);
+
+ tie_setting(main.tcomp_p, ui.tcomp_enable);
+
+ tie_setting(main.tcomp_disable_tx, ui.tcomp_tx_disable);
+ tie_setting(main.tcomp_disable_ty, ui.tcomp_ty_disable);
+ tie_setting(main.tcomp_disable_tz, ui.tcomp_tz_disable);
+
+ tie_setting(main.tcomp_disable_src_yaw, ui.tcomp_src_yaw_disable);
+ tie_setting(main.tcomp_disable_src_pitch, ui.tcomp_src_pitch_disable);
+ tie_setting(main.tcomp_disable_src_roll, ui.tcomp_src_roll_disable);
+
+ tie_setting(main.neck_z, ui.neck_z);
+
+ tie_setting(main.a_x.zero, ui.pos_tx);
+ tie_setting(main.a_y.zero, ui.pos_ty);
+ tie_setting(main.a_z.zero, ui.pos_tz);
+ tie_setting(main.a_yaw.zero, ui.pos_rx);
+ tie_setting(main.a_pitch.zero, ui.pos_ry);
+ tie_setting(main.a_roll.zero, ui.pos_rz);
+
+ tie_setting(main.a_yaw.invert, ui.invert_yaw);
+ tie_setting(main.a_pitch.invert, ui.invert_pitch);
+ tie_setting(main.a_roll.invert, ui.invert_roll);
+ tie_setting(main.a_x.invert, ui.invert_x);
+ tie_setting(main.a_y.invert, ui.invert_y);
+ tie_setting(main.a_z.invert, ui.invert_z);
+
+ tie_setting(main.a_yaw.src, ui.src_yaw);
+ tie_setting(main.a_pitch.src, ui.src_pitch);
+ tie_setting(main.a_roll.src, ui.src_roll);
+ tie_setting(main.a_x.src, ui.src_x);
+ tie_setting(main.a_y.src, ui.src_y);
+ tie_setting(main.a_z.src, ui.src_z);
+
+ tie_setting(main.center_method, ui.center_method);
+
+ tie_setting(main.tracklogging_enabled, ui.tracklogging_enabled);
+
+ tie_setting(main.neck_enable, ui.neck_enable);
+
+ const bool is_translation_disabled = group::with_global_settings_object([] (QSettings& s) {
+ return s.value("disable-translation", false).toBool();
+ });
+ ui.disable_translation->setChecked(is_translation_disabled);
+
+ struct tmp
+ {
+ key_opts& opt;
+ QLabel* label;
+ QPushButton* button;
+ } tuples[] =
+ {
+ { main.key_center1, ui.center_text, ui.bind_center },
+ { main.key_center2, ui.center_text_2, ui.bind_center_2 },
+
+ { main.key_toggle1, ui.toggle_text, ui.bind_toggle },
+ { main.key_toggle2, ui.toggle_text_2, ui.bind_toggle_2 },
+
+ { main.key_toggle_press1, ui.toggle_held_text, ui.bind_toggle_held },
+ { main.key_toggle_press2, ui.toggle_held_text_2, ui.bind_toggle_held_2 },
+
+ { main.key_zero1, ui.zero_text, ui.bind_zero },
+ { main.key_zero2, ui.zero_text_2, ui.bind_zero_2 },
+
+ { main.key_zero_press1, ui.zero_held_text, ui.bind_zero_held },
+ { main.key_zero_press2, ui.zero_held_text_2, ui.bind_zero_held_2 },
+
+ { main.key_start_tracking1, ui.start_tracking_text, ui.bind_start },
+ { main.key_start_tracking2, ui.start_tracking_text_2, ui.bind_start_2 },
+
+ { main.key_stop_tracking1, ui.stop_tracking_text , ui.bind_stop },
+ { main.key_stop_tracking2, ui.stop_tracking_text_2 , ui.bind_stop_2 },
+
+ { main.key_toggle_tracking1, ui.toggle_tracking_text, ui.bind_toggle_tracking },
+ { main.key_toggle_tracking2, ui.toggle_tracking_text_2, ui.bind_toggle_tracking_2 },
+
+ { main.key_restart_tracking1, ui.restart_tracking_text, ui.bind_restart_tracking },
+ { main.key_restart_tracking2, ui.restart_tracking_text_2, ui.bind_restart_tracking_2 },
+ };
+
+ for (const tmp& val_ : tuples)
+ {
+ tmp val = val_;
+ val.label->setText(kopts_to_string(val.opt));
+ connect(&val.opt.keycode,
+ static_cast<void (base_value::*)(const QString&) const>(&base_value::valueChanged),
+ val.label,
+ [=](const QString&) -> void { val.label->setText(kopts_to_string(val.opt)); });
+ {
+ connect(val.button, &QPushButton::clicked, this, [=]() -> void { bind_key(val.opt, val.label); });
+ }
+ }
+}
+
+void OptionsDialog::closeEvent(QCloseEvent *)
+{
+ done(result());
+}
+
+void OptionsDialog::bind_key(key_opts& kopts, QLabel* label)
+{
+ kopts.button = -1;
+ kopts.guid = "";
+ kopts.keycode = "";
+ auto k = new KeyboardListener;
+ k->setWindowModality(Qt::ApplicationModal);
+ k->deleteLater();
+
+ connect(k,
+ &KeyboardListener::key_pressed,
+ this,
+ [&](const QKeySequence& s)
+ {
+ kopts.keycode = s.toString(QKeySequence::PortableText);
+ kopts.guid = "";
+ kopts.button = -1;
+ k->close();
+ });
+ connect(k, &KeyboardListener::joystick_button_pressed,
+ this,
+ [&](const QString& guid, int idx, bool held)
+ {
+ if (!held)
+ {
+ kopts.guid = guid;
+ kopts.keycode = "";
+ kopts.button = idx;
+ k->close();
+ }
+ });
+ connect(main.b.get(), &options::detail::bundle::reloading, k, &QDialog::close);
+ pause_keybindings(true);
+ k->exec();
+ pause_keybindings(false);
+ const bool is_crap = progn(
+ for (const QChar& c : kopts.keycode())
+ if (!c.isPrint())
+ return true;
+ return false;
+ );
+ if (is_crap)
+ {
+ kopts.keycode = QStringLiteral("");
+ kopts.guid = QStringLiteral("");
+ kopts.button = -1;
+ label->setText(tr("None"));
+ }
+ else
+ label->setText(kopts_to_string(kopts));
+}
+
+void OptionsDialog::doOK()
+{
+ if (isHidden()) // close() can return true twice in a row it seems
+ return;
+ hide();
+ if (!close()) // dialog was closed already
+ return;
+
+ main.b->save();
+ ui.game_detector->save();
+ set_disable_translation_state(ui.disable_translation->isChecked());
+ emit closing();
+}
+
+void OptionsDialog::doCancel()
+{
+ if (isHidden()) // close() can return true twice in a row it seems
+ return;
+ hide();
+ if (!close()) // dialog was closed already
+ return;
+
+ main.b->reload();
+ ui.game_detector->revert();
+ emit closing();
+}
+
+void OptionsDialog::done(int res)
+{
+ if (isVisible())
+ {
+ if (res == QDialog::Accepted)
+ doOK();
+ else
+ doCancel();
+ }
+}