Um mit dem globalen HotKey in Qt 5 zu arbeiten, gibt es eine virtuelle Methode nativeEvent . Diese Methode hat die Methoden winEvent , x11Event , macEvent aus Qt 4.8. ersetzt.
Der Clou bei der Arbeit mit HotKey mit Qt ist, dass wenn das Fenster nicht im Fokus ist, also zB in den Systemtray minimiert wird, dann wird einfach der QShortcut eingetragen wird nicht funktionieren. Daher ist es notwendig, mit globalen Ereignissen aus dem Betriebssystem zu arbeiten, dh zur Implementierung des plattformspezifischen Teils des Codes in die Qt-Anwendung überzugehen.
HotKey registrieren
Analysieren wir in diesem Beispiel die Möglichkeit, mit WinAPI zu arbeiten. Verwenden Sie dazu die Funktion RegisterHotKey.
BOOL WINAPI RegisterHotKey( _In_opt_ HWND hWnd, _In_ int id, _In_ UINT fsModifiers, _In_ UINT vk );
RegisterHotKey-Parameter
hWnd [in, optional]
Typ:
HWND
Ein Window-Handler, der
WM_HOTKEY
-Nachrichten empfängt, die vom Hotkey generiert werden.
id [in]
Typ:
int
Hotkey-ID. Wenn der
hWnd
-Parameter NULL ist, werden die Hotkeys dem aktuellen Thread und nicht einem bestimmten Fenster zugeordnet.
fsModifiers [in]
Typ:
UINT
Die Zusatztasten, die in Kombination mit der angegebenen Taste im Parameter
uVirtKey
gedrückt werden müssen, um die Nachricht zu generieren. Der Parameter
WM_HOTKEY.
fsModifiers
kann eine Kombination der folgenden Werte sein.
- MOD_ALT 0x0001 - Die ALT-Taste muss gedrückt gehalten werden;
- MOD_CONTROL 0x0002 - STRG-Taste muss gedrückt werden;
- MOD_NOREPEAT 0x4000 - Ändert das HotKey-Verhalten, sodass die Tastatur nicht mehrere HotKey-Meldungen generiert. Dieses Flag wird unter Windows Vista nicht unterstützt.
- MOD_SHIFT 0x0004 - SHIFT-Taste muss gedrückt werden;
- MOD_WIN 0x0008 - Die WINDOWS-Taste muss gedrückt gehalten werden. Dies ist die Windows-Logo-Taste.
vk [im]
Typ:
UINT
Code der virtuellen Tasten für HotKey.
HotKey abmelden
Hotkey-Kombinationen deaktivieren.
BOOL WINAPI UnregisterHotKey( _In_opt_ HWND hWnd, _In_ int id );
HotKey-Parameter abmelden
hWnd [in, optional]
Typ:
HWND
Das Fensterhandle, das dem Hotkey zugeordnet ist, der freigegeben werden muss. Dieser Parameter muss NULL sein, wenn er keinem Fenster zugeordnet ist.
id [in]
Typ:
int
Die Kennung der freizugebenden Hotkey-Kombination.
Ein Beispiel für die Arbeit mit HotKey in WinAPI
Lassen Sie uns ein Projekt erstellen, um mit HotKey. zu arbeiten. Dieses Projekt wird ein Objekt der Klasse QSystemTrayIcon. enthalten. Wir werden die Anwendung in der Taskleiste verstecken und die Hotkey-Kombination überprüfen. Diese Kombination wäre beispielsweise "ALT+SHIFT+D" . In diesem Projekt ist der Hotkey-Handler MainWindow. Die Hotkey-Kombination wird in nativeEvent. behandelt.
Wir werden mit qDebug() nach einer Kombination ausgewählter Hotkeys suchen.
Hauptfenster.h
#ifndef MAINWINDOW_H #define MAINWINDOW_H #include <QMainWindow> #include <QSystemTrayIcon> #include "windows.h" // Подключаем библиотеку WinAPI namespace Ui { class MainWindow; } class MainWindow : public QMainWindow { Q_OBJECT public: explicit MainWindow(QWidget *parent = 0); ~MainWindow(); protected: // Метод для обработки native событий от ОС в Qt bool nativeEvent(const QByteArray &eventType, void *message, long *result); private slots: void iconActivated(QSystemTrayIcon::ActivationReason reason); private: Ui::MainWindow *ui; QSystemTrayIcon *trayIcon; }; #endif // MAINWINDOW_H
Hauptfenster.cpp
#include "mainwindow.h" #include "ui_mainwindow.h" #include <QDebug> MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); /* Иконка системного трея нужна для того, чтобы * окно приложения было не в фокусе * */ trayIcon = new QSystemTrayIcon(this); trayIcon->setIcon(this->style()->standardIcon(QStyle::SP_ComputerIcon)); trayIcon->show(); connect(trayIcon, SIGNAL(activated(QSystemTrayIcon::ActivationReason)), this, SLOT(iconActivated(QSystemTrayIcon::ActivationReason))); // Регистрируем HotKey "ALT+SHIFT+D" RegisterHotKey((HWND)MainWindow::winId(), // Устанавливаем системный идентификатор окна виджета, который будет обрабатывать HotKey 100, // Устанавливаем идентификатор HotKey MOD_ALT | MOD_SHIFT, // Устанавливаем модификаторы 'D'); // Определяем Горячую Клавишу для HotKey } MainWindow::~MainWindow() { delete ui; } bool MainWindow::nativeEvent(const QByteArray &eventType, void *message, long *result) { Q_UNUSED(eventType) Q_UNUSED(result) // Преобразуем указатель message в MSG WinAPI MSG* msg = reinterpret_cast<MSG*>(message); // Если сообщение является HotKey, то ... if(msg->message == WM_HOTKEY){ // ... проверяем идентификатор HotKey if(msg->wParam == 100){ // Сообщаем об этом в консоль qDebug() << "HotKey worked"; return true; } } return false; } void MainWindow::iconActivated(QSystemTrayIcon::ActivationReason reason) { switch (reason){ case QSystemTrayIcon::Trigger: !isVisible() ? show() : hide(); break; default: break; } }
Notiz
Damit das Projekt mit dem MSVC-Buildkit kompiliert werden kann, fügen Sie der Pro-Projektdatei die folgenden Zeilen hinzu:
win32-msvc*{ LIBS += -luser32 }
Insgesamt
Als Ergebnis der Arbeit dieses Programmcodes wird die globale Hotkey-Kombination auch dann verarbeitet, wenn das Anwendungsfenster in der Taskleiste ausgeblendet ist. Eine Demonstration der Anwendung ist im Video-Tutorial zu sehen.