如何在QML应用程序中安装和使用Qt C编写的事件过滤器

如何在QML应用程序中安装和使用Qt C编写的事件过滤器,第1张

概述我有一种情况需要将键盘快捷键添加到主要由QtQuick用户界面组成的应用程序中.不幸的是,Qt Quick的版本被锁定到Qt5.3,而快捷方式(我们需要它们的方式)分别仅在Qt5.5和Qt5.7中引入. 因此,作为一个解决方案,我编写了一个事件过滤器,其功能类似于QShortcut(不能使用QShortcut,因此事件过滤器). 有人知道如何在QML中安装和使用这个eventfilter吗? 一种 我有一种情况需要将键盘快捷键添加到主要由QtQuick用户界面组成的应用程序中.不幸的是,Qt Quick的版本被锁定到Qt5.3,而快捷方式(我们需要它们的方式)分别仅在Qt5.5和Qt5.7中引入.

因此,作为一个解决方案,我编写了一个事件过滤器,其功能类似于QShortcut(不能使用QShortcut,因此事件过滤器).

有人知道如何在QML中安装和使用这个eventfilter吗?

解决方法 一种方法是将单例类型公开给QML:

#include <QtGui>#include <QtQml>class ShortcutListener : public QObject{    Q_OBJECTpublic:    ShortcutListener(QObject *parent = nullptr) :        QObject(parent)    {    }    Q_INVOKABLE voID ListenTo(QObject *object)    {        if (!object)            return;        object->installEventFilter(this);    }    bool eventFilter(QObject *object,QEvent *event) overrIDe    {        if (event->type() == QEvent::KeyPress) {            QKeyEvent *keyEvent = static_cast<QKeyEvent*>(event);            qDeBUG() << "key" << keyEvent->key() << "pressed on" << object;            return true;        }        return false;    }};static QObject *shortcutListenerInstance(QQmlEngine *,qjsengine *engine){    return new ShortcutListener(engine);}int main(int argc,char *argv[]){    QGuiApplication app(argc,argv);    qmlRegisterSingletonType<ShortcutListener>("App",1,"ShortcutListener",shortcutListenerInstance);    QQmlApplicationEngine engine;    engine.load(QUrl(QStringliteral("qrc:/main.qml")));    return app.exec();}#include "main.moc"

main.qml:

import QtQuick 2.5import QtQuick.Window 2.2import App 1.0Window {    ID: window    wIDth: 640    height: 480    visible: true    Component.onCompleted: ShortcutListener.ListenTo(window)}

如果你有几个不同的监听器,你也可以通过向ShortcutListener添加一个对象属性来声明性地执行它,它将在设置时安装事件过滤器.

有关详细信息,请参阅Integrating QML and C++.

总结

以上是内存溢出为你收集整理的如何在QML应用程序中安装和使用Qt C编写的事件过滤器全部内容,希望文章能够帮你解决如何在QML应用程序中安装和使用Qt C编写的事件过滤器所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1217375.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存