Qt QShortcut快捷键类详解

1.简介

QShortcut是一个方便的工具类,用于在应用程序中创建快捷键。通过设置快捷键和关联的处理函数,可以实现快速执行某个操作的功能。

cpp 复制代码
// 创建一个快捷键,关联到MyWidget类的keyPressEvent()函数
QShortcut *shortcut = new QShortcut(QKeySequence("Ctrl+K"), this);
connect(shortcut, &QShortcut::activated, this, &MyWidget::keyPressEvent)

QKeySequence是一个字符串序列,用于表示一系列的键盘按键。通过使用QKeySequence,可以方便地生成快捷键,并将其与特定的处理函数关联起来。

cpp 复制代码
QKeySequence sequence("Ctrl+K"); // 创建一个表示"Ctrl+K"的键盘序列
QShortcut *shortcut = new QShortcut(sequence, this);
connect(shortcut, &QShortcut::activated, this, &MyWidget::keyPressEvent);

QKeySequence是一个可选组合了Shift、Ctrl和Alt的键序列。可以通过多种方式提供该键序列:

cpp 复制代码
  setKey(0);                  // no signal emitted
  setKey(QKeySequence());     // no signal emitted
  setKey(0x3b1);              // Greek letter alpha
  setKey(Qt::Key_D);              // 'd', e.g. to delete
  setKey('q');                // 'q', e.g. to quit
  setKey(Qt::CTRL + Qt::Key_P);       // Ctrl+P, e.g. to print document
  setKey("Ctrl+P");           // Ctrl+P, e.g. to print document

QShortcut的工作原理主要基于Qt的事件处理机制,当用户按下键盘上的键时,Qt 会生成一个键盘事件(QKeyEvent),QShortcut监听这些事件,并在检测到与已注册的快捷键匹配的键组合时触发相应的动作。

需要注意的是,QShortcut只对键盘事件有效。如果你需要监听鼠标事件或其他类型的事件,你需要使用其他机制,比如QAction或自定义的事件过滤器。

2.常用方法

构造函数:创建一个 QShortcut 实例,key 是快捷键组合,parent 是父对象。

cpp 复制代码
QShortcut(const QKeySequence &key, QObject *parent):

设置快捷键:设置快捷键组合。

cpp 复制代码
 setKey(const QKeySequence &key)

设置快捷键的描述,这可以在帮助系统中显示。

cpp 复制代码
setWhatsThis(const QString &text):

激活快捷键: 启用或禁用快捷键。

cpp 复制代码
setEnabled(bool enabled)

设置快捷方式有效的上下文 。

cpp 复制代码
setContext(Qt::ShortcutContext context)

信号:

当快捷键可能不明确(即有多个快捷键具有相同的键组合)时发出这个信号。

cpp 复制代码
activatedAmbiguously()

当快捷键被激活时发出这个信号。

cpp 复制代码
activated():

3.示例

cpp 复制代码
#include "widget.h"
#include <QApplication>
#include <QShortcut>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    Widget w;
    w.show();

    //创建一个快捷键,当用户按下 Ctrl+P 时退出程序
    QShortcut *shortcut = new QShortcut(QKeySequence(Qt::CTRL | Qt::Key_P), &w);
    QObject::connect(shortcut, &QShortcut::activated, [&]() {
       qApp->exit();
    });


    return a.exec();
}

4.避免快捷键冲突

可能会出现快捷键冲突的情况,即两个或多个快捷键具有相同的键组合,或者在特定的上下文中,一个快捷键被另一个窗口或应用程序占用。这可能导致快捷键无法按预期工作,或者触发错误的动作。

检查可用性:在注册快捷键之前,可以检查该快捷键是否已经被其他 QShortcut 实例使用,或者是否与操作系统的快捷键冲突。QShortcut 提供了一个 setContext 方法,可以用来限制快捷键的触发上下文(例如,只在应用程序有焦点时触发)。

使用独一无二的组合:尽量使用不常见的键组合作为快捷键,比如使用功能键(F1-F12)或者组合键(Ctrl+Alt+Shift+Key)。

使用 activatedAmbiguously 信号:当快捷键可能不明确时,QShortcut 会发出 activatedAmbiguously 信号。你可以连接这个信号来处理潜在的冲突,例如,显示一个警告对话框或者忽略该快捷键的触发。

5.更多参考

libVLC 专栏介绍-CSDN博客

Qt+FFmpeg+opengl从零制作视频播放器-1.项目介绍_qt opengl视频播放器-CSDN博客

QCharts -1.概述-CSDN博客

相关推荐
健康平安的活着12 分钟前
java之 junit4单元测试Mockito的使用
java·开发语言·单元测试
No0d1es14 分钟前
电子学会青少年软件编程(C/C++)5级等级考试真题试卷(2024年6月)
c语言·c++·算法·青少年编程·电子学会·五级
DjangoJason2 小时前
C++ 仿RabbitMQ实现消息队列项目
开发语言·c++·rabbitmq
m0_480502642 小时前
Rust 入门 KV存储HashMap (十七)
java·开发语言·rust
大阳1232 小时前
线程(基本概念和相关命令)
开发语言·数据结构·经验分享·算法·线程·学习经验
YA3332 小时前
java基础(九)sql基础及索引
java·开发语言·sql
奇树谦3 小时前
QT|windwos桌面端应用程序开发,当连接多个显示器的时候,如何获取屏幕编号?
开发语言·qt
weixin_307779133 小时前
VS Code配置MinGW64编译GNU 科学库 (GSL)
开发语言·c++·vscode·算法
froginwe114 小时前
HTML 框架:构建网页布局的基石
开发语言
Yn3124 小时前
在 Python 中使用 json 模块的完整指南
开发语言·python·json