diff options
author | Stanislaw Halik <sthalik@misaki.pl> | 2017-10-22 11:10:34 +0200 |
---|---|---|
committer | Stanislaw Halik <sthalik@misaki.pl> | 2017-10-27 16:42:57 +0200 |
commit | 0a0000a6c4ca5ebfffd33d70f7b7963473be1471 (patch) | |
tree | 90e31f30303b4b4d4f4e83086ff4ee70d915fe77 /gui/options-dialog.cpp | |
parent | d20e3d4a3ac6114b296f0284f336b59c178b4e72 (diff) |
gui: rename source files only
Diffstat (limited to 'gui/options-dialog.cpp')
-rw-r--r-- | gui/options-dialog.cpp | 241 |
1 files changed, 0 insertions, 241 deletions
diff --git a/gui/options-dialog.cpp b/gui/options-dialog.cpp deleted file mode 100644 index c35a6b52..00000000 --- a/gui/options-dialog.cpp +++ /dev/null @@ -1,241 +0,0 @@ -/* 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 "options-dialog.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(); - } -} |