summaryrefslogtreecommitdiffhomepage
path: root/gui/keyboard.h
diff options
context:
space:
mode:
authorStanislaw Halik <sthalik@misaki.pl>2015-10-30 09:01:32 +0100
committerStanislaw Halik <sthalik@misaki.pl>2015-10-30 09:01:32 +0100
commitd785d3616500d5846ac8c5f5a6347da832a593b4 (patch)
treeac670a125c5b880ad7e4b4f24a8635da4e66f0da /gui/keyboard.h
parent232c2ba8aca7900eaa950c48813ddfaca8a749a8 (diff)
parent9b736d361bcde7a2ddaf3fe54b471c0e658e94f4 (diff)
Merge branch 'unstable' into trackhat
* unstable: cmake: cleanup hydra rename gui directory move to subdirectory-based build system cmake: switch to GNU CC 5.2.0 in mingw-w64 toolchain file rift-080: forgot ovr_Initialize() rift 025: fix name
Diffstat (limited to 'gui/keyboard.h')
-rw-r--r--gui/keyboard.h50
1 files changed, 50 insertions, 0 deletions
diff --git a/gui/keyboard.h b/gui/keyboard.h
new file mode 100644
index 00000000..62a9ce20
--- /dev/null
+++ b/gui/keyboard.h
@@ -0,0 +1,50 @@
+#pragma once
+#include "ui_keyboard_listener.h"
+#ifdef _WIN32
+#include "opentrack/win32-shortcuts.h"
+#include "opentrack/shortcuts.h"
+#endif
+#include <QLabel>
+#include <QKeyEvent>
+#include <QDebug>
+
+class KeyboardListener : public QLabel
+{
+ Q_OBJECT
+ Ui_keyboard_listener ui;
+#ifdef _WIN32
+ KeybindingWorker w;
+#endif
+public:
+ KeyboardListener(QWidget* parent = nullptr) : QLabel(parent)
+#ifdef _WIN32
+ , w([&](Key& k)
+ {
+ Qt::KeyboardModifiers m;
+ QKeySequence k_;
+ if (win_key::to_qt(k, k_, m))
+ key_pressed(static_cast<QVariant>(k_).toInt() | m);
+ }, this->winId())
+#endif
+ {
+ ui.setupUi(this);
+ setFocusPolicy(Qt::StrongFocus);
+#ifdef _WIN32
+ w.start();
+#endif
+ }
+#ifndef _WIN32
+ void keyPressEvent(QKeyEvent* event) override
+ {
+ //qDebug() << "k" << (event->key() | event->modifiers());
+ switch (event->key() | event->modifiers())
+ {
+ default:
+ emit key_pressed(QKeySequence(event->key() | event->modifiers()));
+ break;
+ }
+ }
+#endif
+signals:
+ void key_pressed(QKeySequence k);
+};