假设我们有一个列表模型:
from PySide2.QtCore import Qt, QAbstractListModel, QModelIndex
import numpy as np
class AxisModel(QAbstractListModel):
MaxRole = Qt.UserRole + 1015
MinRole = Qt.UserRole + 1016
TicksRole = Qt.UserRole + 1017
def __init__(self, min_, max_, price_unit, parent=None):
super(AxisModel, self).__init__(parent)
self.max = float(max_)
self.min = float(min_)
self.price_unit = float(price_unit)
self.ticks = np.arange(self.min, self.max + self.price_unit, self.price_unit).tolist()
def rowCount(self, parent=QModelIndex()):
if parent.isValid():
return 0
return len(self.ticks)
def data(self, index: QModelIndex, role):
if 0 > index.row() > self.rowCount() and not index.isValid():
return None
if role == AxisModel.MinRole:
return self.min
if role == AxisModel.MaxRole:
return self.max
if role == AxisModel.TicksRole:
return self.ticks[index.row()]
def roleNames(self):
roles = dict()
roles[AxisModel.MinRole] = b"min"
roles[AxisModel.MaxRole] = b"max"
roles[AxisModel.TicksRole] = b"ticks"
return roles
这稍后在 python 代码中使用:
(...)
axismodel = AxisModel(min_=min_, max_=max_, price_unit=0.25)
app = QGuiApplication(sys.argv)
view = QQuickView()
view.setResizeMode(QQuickView.SizeRootObjectToView)
# register models
view.rootContext().setContextProperty("axis_model", axismodel)
view.rootContext().setContextProperty("ts_model", tsmodel) # some other model
qml_file = os.path.join("/home/user/code/project", "simple_test.qml")
view.setSource(QUrl.fromLocalFile(os.path.abspath(qml_file)))
if view.status() == QQuickView.Error:
sys.exit(-1)
view.show()
app.exec_()
使用它的 QML 文件(简化):
Item {
Axis {
model: axis_model
}
}
轴项:
Item {
id: axis
property ListModel model
property real max: model.max
property real min: model.min
(...)
}
这会产生一个错误:
Unable to assign AxisModel to QQmlListModel
好的,AxisModel 在技术上不是 QQmlListModel,但它们都继承自 QAbstractItemModel。我不知道如何解决这个问题。我的两个想法是:
ListModel
使用与Axis.qml 定义中不同的类型。我不知道是哪一个。我尝试了 QObject、QVariant,结果不是 QML 类型。Item 不起作用,因为 AxisModel 不是 QQuickItem 实例- 在 python 代码中使用一些 PySide2 注释来注释 AxisModel 类,这将通知 QML 引擎有关类型。我不知道如何解决这个问题。
谢谢你的时间。