无法在 Python 中显示 TreeView

Could not display TreeView in Python

在 Python 中为 Qt 尝试一个非常简单的 TreeView 控件,但由于某种原因,GUI 只是空白。

main.qml

import QtQuick 2.14
import QtQuick.Controls 2.14
import QtQuick.Controls 1.4 as OldControls

ApplicationWindow {
    visible: true
    title: qsTr("Simple Tree View")

    OldControls.TreeView {
        anchors.fill: parent
        model: simpleModel
        OldControls.TableViewColumn {
            role: "display"
            title: "Name"
            width: 100
        }
    }
}

main.py

import sys
from os.path import abspath, dirname, join

from PySide2.QtGui import QGuiApplication, QStandardItemModel, QStandardItem
from PySide2.QtQml import QQmlApplicationEngine


class SimpleTreeView(QStandardItemModel):
    def __init__(self, parent=None):
        super().__init__(parent)

        self.setColumnCount(1)

        root = self.invisibleRootItem()
        group1 = QStandardItem("group1")
        group1.setText("group1")
        value1 = QStandardItem("value1")
        value1.setText("value1")
        group1.appendRow(value1)
        root.appendRow(group1)


if __name__ == '__main__':
    app = QGuiApplication(sys.argv)

    engine = QQmlApplicationEngine()
    qmlFile = join(dirname(__file__), 'main.qml')
    engine.rootContext().setContextProperty("simpleModel", SimpleTreeView())
    engine.load(abspath(qmlFile))

    if not engine.rootObjects():
        sys.exit(-1)

    sys.exit(app.exec_())

输出为Linux

问题在于,由于 SimpleTreeView 对象未分配给变量然后被销毁,可以使用 destroyed 信号进行验证。

class SimpleTreeView(QStandardItemModel):
    def __init__(self, parent=None):
        super().__init__(parent)

        <b>self.destroyed.connect(lambda o : print("destroyed:", o))</b>
        # ...

输出:

destroyed: <PySide2.QtCore.QObject(0x56377cf050f0) at 0x7ffa20deac40>

解决办法是给那个对象赋一个变量,这样生命周期就更长了:

qmlFile = join(dirname(__file__), 'main.qml')
<b>model = SimpleTreeView()</b>
engine.rootContext().setContextProperty("simpleModel", <b>model</b>)
# ...