我的QML文件中有一个TableView,通过为其提供模型加载了几个项目。我可以通过箭头键(向上,向下)在项目之间导航,但我无法弄清楚如何按代码在项目之间导航。
以下是我尝试发送活动的方式,但似乎我将我的活动发送到了错误的组件:
QQuickItem* focusedItem = qobject_cast<QQuickItem*>(QGuiApplication::focusObject());
QKeyEvent *event1 = new QKeyEvent(QEvent::KeyPress,Qt::Key_Up,Qt::NoModifier);
QKeyEvent *event2 = new QKeyEvent(QEvent::KeyRelease,Qt::Key_Up,Qt::NoModifier);
QCoreApplication::postEvent (focusedItem, event1);
QCoreApplication::postEvent (focusedItem, event2);
焦点项目似乎是一个focusScope,它的父级是一个空的QObject!我用这个测试了这个:
qDebug () << "ITEM =>" << focusedItem;
qDebug () << "PARENT=>" << focusedItem->parent();
答案 0 :(得分:2)
寻找这样的东西的好地方是Qt本身的自动测试。例如,如果您查看tst_tableview.qml
,您会看到关键事件未发送到特定项目。相反,事先给予目标项目焦点,并将事件发送到窗口:
table.forceActiveFocus();
keyClick(Qt.Key_Down);
所以,作为一个小例子:
#include <QtGui>
#include <QtQuick>
class Controller : public QObject
{
Q_OBJECT
public:
Controller() :
mTarget(0),
mTimerId(0) {
}
void setTarget(QQuickItem *item) {
if (item == mTarget)
return;
mTarget = item;
if (mTarget)
mTimerId = startTimer(1000);
else
killTimer(mTimerId);
}
void timerEvent(QTimerEvent *) {
if (mTarget) {
QKeyEvent *event1 = new QKeyEvent(QEvent::KeyPress, Qt::Key_Down, Qt::NoModifier);
QKeyEvent *event2 = new QKeyEvent(QEvent::KeyRelease, Qt::Key_Down, Qt::NoModifier);
QCoreApplication::postEvent(mTarget->window(), event1);
QCoreApplication::postEvent(mTarget->window(), event2);
}
}
private:
QQuickItem *mTarget;
int mTimerId;
};
int main(int argc, char *argv[])
{
QGuiApplication app(argc, argv);
Controller controller;
QQmlApplicationEngine engine;
engine.load(QUrl(QStringLiteral("qrc:/main.qml")));
controller.setTarget(engine.rootObjects().first()->property("target").value<QQuickItem*>());
return app.exec();
}
#include "main.moc"
当在控制器上设置目标项目时,我们启动一个计时器,该计时器每秒向项目所在的窗口发送一个向下事件。如果您只有一个窗口,则没有必要具有目标的概念;在发送活动之前,只需将焦点放在QML中的正确项目上。
然后,在 main.qml
:
import QtQuick 2.5
import QtQuick.Controls 1.3
import QtQuick.Layouts 1.1
ApplicationWindow {
id: winRoot
visible: true
width: 500
height: 500
property alias target: tableView
TableView {
id: tableView
focus: true
model: ListModel {
id: libraryModel
ListElement {
title: "A Masterpiece"
author: "Gabriel"
}
ListElement {
title: "Brilliance"
author: "Jens"
}
ListElement {
title: "Outstanding"
author: "Frederik"
}
}
TableViewColumn {
role: "title"
title: "Title"
width: 100
}
TableViewColumn {
role: "author"
title: "Author"
width: 200
}
}
}