强制焦点在ListView中进行文本编辑
考虑下面的例子强制焦点在ListView中进行文本编辑,listview,focus,qml,qtquick2,textedit,Listview,Focus,Qml,Qtquick2,Textedit,考虑下面的例子 Rectangle { height: 200 width: 200 ListView { id: lv anchors.fill: parent model: ListModel { ListElement { name: "aaa" } ListElement { nam
Rectangle {
height: 200
width: 200
ListView {
id: lv
anchors.fill: parent
model: ListModel {
ListElement {
name: "aaa"
}
ListElement {
name: "bbb"
}
ListElement {
name: "ccc"
}
}
delegate: TextEdit {
id: delegate
text: name
width: 200
height: 100
activeFocusOnPress: false
onActiveFocusChanged: {
if(activeFocus) {
font.italic = true;
} else {
font.italic = false;
}
}
MouseArea {
anchors.fill: parent
onDoubleClicked : {
delegate.focus = true;
lv.currentIndex = index;
}
}
}
}
}
我想能够激活文本编辑双击。如果它在列表视图之外,它将按预期工作,但在列表视图中它不工作。
我想问题在于列表视图是焦点范围,但我不知道如何修复它
提前谢谢 您可以利用:
此方法将焦点设置在项目上,确保对象层次结构中的所有祖先焦点镜对象也具有焦点
您可以使用重载版本(不带参数),也可以使用带参数的版本。下面是使用后者的代码的修改版本。我还做了两个小调整,并做了解释性评论:
import QtQuick 2.4
import QtQuick.Window 2.2
Window {
visible: true
width: 200
height: 200
ListView {
anchors.fill: parent
model: ListModel {
ListElement {
name: "aaa"
}
ListElement {
name: "bbb"
}
ListElement {
name: "ccc"
}
}
delegate: TextEdit {
text: name
// In the delegate you can access the ListView via "ListView.view"
width: ListView.view.width
height: 50
activeFocusOnPress: false
// directly bind the property to two properties (also saving the brackets)
onActiveFocusChanged: font.italic = activeFocus
MouseArea {
anchors.fill: parent
onDoubleClicked : {
parent.forceActiveFocus(Qt.MouseFocusReason)
parent.ListView.view.currentIndex = index
}
}
}
}
}