我正在尝试实现QAbstractListModel
类以显示几个类似的小部件。
以下代码显示了我的问题:
import sys
from PyQt4 import QtCore
from PyQt4 import QtGui
class Model(QtCore.QAbstractListModel):
def __init__(self, parent=None):
super(QtCore.QAbstractListModel, self).__init__(parent)
self._widgets = []
def headerData(self, section, orientation, role):
""" Returns header for columns """
return "bla"
def rowCount(self, parentIndex=QtCore.QModelIndex()):
""" Returns number of interfaces """
return len(self._widgets)
def data(self, index, role):
""" Returns the data to be displayed """
if role == QtCore.Qt.DisplayRole:
row = index.row()
return self._widgets[row]
def insertRow(self, widget, parentIndex=QtCore.QModelIndex()):
""" Inserts a row into the model """
self.beginInsertRows(parentIndex, 0, 1)
self._widgets.append(widget)
self.endInsertRows()
class Widget(QtGui.QWidget):
def __init__(self, parent=None, name="None"):
super(QtGui.QWidget, self).__init__(parent)
self.layout = QtGui.QHBoxLayout()
self.setLayout(self.layout)
self.checkbox = QtGui.QCheckBox()
self.button = QtGui.QPushButton(self)
self.label = QtGui.QLabel(self)
self.label.setText(name)
self.layout.addWidget(self.checkbox)
self.layout.addWidget(self.button)
self.layout.addWidget(self.label)
class Window(QtGui.QMainWindow):
def __init__(self, parent=None):
super(QtGui.QMainWindow, self).__init__(parent)
self.view = QtGui.QListView(self)
self.model = Model()
self.view.setModel(self.model)
self.setCentralWidget(self.view)
self.model.insertRow(
widget=Widget(self)
)
self.model.insertRow(
widget=Widget(self)
)
self.model.insertRow(
widget=Widget(self)
)
self.model.insertRow(
widget=Widget(self)
)
self.show()
app = QtGui.QApplication(sys.argv)
window = Window()
sys.exit(app.exec_())
它有效,列表中有四个可点击的条目,但实际上只显示了其中一个小部件。那是为什么?
我猜这种行为要么是由data()
造成的,要么是我如何使用beginInsertRows()
,但我无法弄清楚错误的位置。
ìnsertRow()
功能现在看起来像那样
def insertRow(self, widget, parentIndex=QtCore.QModelIndex()):
""" Inserts a row into the model """
self.beginInsertRows(parentIndex, len(self._widgets), len(self._widgets))
self._widgets.append(widget)
self.endInsertRows()
但它仍然不起作用。
答案 0 :(得分:1)
self.beginInsertRows(parentIndex, 0, 1)
0 - 开始 1 - 结束
在插入
期间只刷新第一行self.beginInsertRows(parentIndex, len(self._widgets), len(self._widgets))
必须工作。别忘了这个方法
self.model.reset()
此刷新所有列表,没有特定的行
答案 1 :(得分:1)
实际上,会显示四个小部件。问题是,它们都显示在左上角。如果你输入名字,你可以看到它们重叠,这里是“1”,“2”,“3”,“4”:
修复行号并不能解决问题。小部件将在正确的行中,但仍将显示在左上角。这是因为data
应该是return text for the display role。
要显示简单的小部件,建议您使用QListWidget
和setItemWidget方法。否则你将不得不使用代表。