PyQt4 QAbstractListModel - 仅显示第一个数据小部件

时间:2015-12-07 13:24:42

标签: python python-2.7 user-interface pyqt4 model-view

我正在尝试实现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()

但它仍然不起作用。

2 个答案:

答案 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”:

enter image description here

修复行号并不能解决问题。小部件将在正确的行中,但仍将显示在左上角。这是因为data应该是return text for the display role

要显示简单的小部件,建议您使用QListWidgetsetItemWidget方法。否则你将不得不使用代表。