4

我已经阅读了一些关于如何为QComboBox小部件定义自定义模型的示例。

这是我定义模型的方式:

class LevelListModel(QAbstractListModel):
    def __init__(self, parent=None, *args):
        """ datain: a list where each item is a row
        """
        QAbstractListModel.__init__(self, parent, *args)
        self.levelList = []
    def rowCount(self, parent=QModelIndex()):
        return len(self.levelList)

    def data(self, index, role):
        if index.isValid() and role == Qt.DisplayRole:
            return QVariant(index.row())
        else:
            return QVariant()
    def addLevel(self,level):
        self.beginResetModel()
        self.levelList.append(level)
        self.endResetModel()

我将模型设置为我的QComboBox

self.levelListModel = LevelListModel()
self.ui.levelComboBox.setModel(self.levelListModel)

我以这种方式将模型添加到我的列表中:

newLevel = Level (self.levelListModel.rowCount() + 1)
self.levelListModel.addLevel(newLevel)

该项目已正确添加,我可以在组合框中看到它,但我想将 currentIndex 更改为新项目的索引。

我想QAbstractListModel可能会引发某种QComboBox可以收听的事件,但我还没有找到如何做到这一点。

我的问题是:

  1. 如何通知QComboBox模型数据已更改,并监听该事件以相应地修改 currentIndex?
  2. 我使用[begin|end]ResetModel是因为我的条目应该是一个有序的整数序列。因此,一旦列表中间的项目被删除,我需要完全重建数据列表。我不知道这是否是正确的方法。有更好的解决方案吗?
4

1 回答 1

3

1

如何通知 QComboBox 模型数据已更改,并监听该事件以相应地修改 currentIndex?

无需从您做事的方式中监听事件。您知道模型数据何时更改,因为您自己添加内容。只需currentIndex在添加数据后更改。

我可能会修改addLevel方法以返回添加项的,QModelIndex然后使用它来设置currentIndexQComboBox

class LevelListModel(QAbstractListModel):
    # [skipped]
    def addLevel(self,level):
        self.beginInsertRows(QModelIndex(), len(self.levelList), len(self.levelList))
        self.levelList.append(level)
        self.endInsertRows()
        return self.index(len(self.levelList)-1)

newLevel = Level (self.levelListModel.rowCount() + 1)
newIndex = self.levelListModel.addLevel(newLevel)
self.ui.levelComboBox.setCurrentIndex(newIndex)

2

我使用 [begin|end]ResetModel 因为我的条目应该是一个有序的整数序列。因此,一旦列表中间的项目被删除,我需要完全重建数据列表。我不知道这是否是正确的方法。有更好的解决方案吗?

那要看。[begin|end]ResetModel是为了真正剧烈的变化。我看不出保持有序的整数列表会如何导致单项添加/删除的此类更改。根据您的描述,您应该使用[begin|end]InsertRowsand [begin|end]RemoveRows

于 2012-11-27T22:47:56.220 回答