带组合框的 QTableView

发布于 2024-11-05 21:32:59 字数 2813 浏览 4 评论 0原文

我希望我的 QTableView 有一列组合框。经过多次尝试,我已经达到了我的目标:显示组合框。

现在我的问题是他们不会保留所选项目的显示。

我使用自定义委托来完成此操作,下面是相关代码:

class ComboBoxDelegate(QtGui.QItemDelegate):

def __init__(self, owner, itemslist):
    QtGui.QItemDelegate.__init__(self, owner)
    self.itemslist = itemslist

def paint(self, painter, option, index):        
    # Get Item Data
    value = index.data(QtCore.Qt.DisplayRole).toInt()[0]
    # fill style options with item data
    style = QtGui.QApplication.style()
    opt = QtGui.QStyleOptionComboBox()
    opt.currentText = str(self.itemslist[value])
    opt.rect = option.rect

    # draw item data as ComboBox
    style.drawComplexControl(QtGui.QStyle.CC_ComboBox, opt, painter)

def createEditor(self, parent, option, index):
    # create the ProgressBar as our editor.
    editor = QtGui.QComboBox(parent)
    editor.addItems(self.itemslist)
    editor.setCurrentIndex(0)
    editor.installEventFilter(self)         
    return editor

def setEditorData(self, editor, index):
    value = index.data(QtCore.Qt.DisplayRole).toInt()[0]
    editor.setCurrentIndex(value)

def setModelData(self,editor,model,index):
    value = editor.currentIndex()
    model.setData(index, QtCore.QVariant(value))

def updateEditorGeometry(self, editor, option, index):
    editor.setGeometry(option.rect)



class SequenceGridModel(QtCore.QAbstractTableModel):
def __init__(self, datain, headerdata, parent=None, *args):
    QtCore.QAbstractTableModel.__init__(self, parent, *args)
    self.parent = parent
    self.arraydata = datain
    self.headerdata = headerdata

def flags(self, index):
    if index.column() == 13:
        return QtCore.Qt.ItemIsEnabled | QtCore.Qt.ItemIsSelectable | QtCore.Qt.ItemIsEditable
    return QtCore.QAbstractTableModel.flags(self, index)


def data(self, index, role = QtCore.Qt.DisplayRole):
  if not index.isValid():
     if role == QtCore.Qt.UserRole:
        return None
     else:
        return QtCore.QVariant()

  value = QtCore.QVariant(self.arraydata[index.row()][index.column()])

  if QtCore.Qt.UserRole == role:
     return value
  elif role == QtCore.Qt.DisplayRole or role == QtCore.Qt.EditRole:
     return QtCore.QVariant(value)
  return QtCore.QVariant()



class SequenceGrid(QtGui.QTableView):
def __init__(self, parent=None):
    QtGui.QTableView.__init__(self, parent) 

    self.selectedIndexes = []
    self.parent = parent

    self.checkValues = ['TODO', 'WAITING', 'RETAKE', 'OK']

    self.model = SequenceGridModel(self.data, header, self)
    self.setModel(self.model)
    self.setEditTriggers(QtGui.QAbstractItemView.CurrentChanged)
    self.viewport().installEventFilter(self)
    self.setItemDelegateForColumn(13,ComboBoxDelegate(self, self.checkValues))

    self.setColumnWidth(13, 64)

感谢您的关注!

I want my QTableView to have a column of comboBoxes. After a lot of try-outs, I've reached my goal : display the comboBoxes.

Now my problem is that they won't keep the selected item displayed.

I use a custom delegate to do it, below is the relevant code :

class ComboBoxDelegate(QtGui.QItemDelegate):

def __init__(self, owner, itemslist):
    QtGui.QItemDelegate.__init__(self, owner)
    self.itemslist = itemslist

def paint(self, painter, option, index):        
    # Get Item Data
    value = index.data(QtCore.Qt.DisplayRole).toInt()[0]
    # fill style options with item data
    style = QtGui.QApplication.style()
    opt = QtGui.QStyleOptionComboBox()
    opt.currentText = str(self.itemslist[value])
    opt.rect = option.rect

    # draw item data as ComboBox
    style.drawComplexControl(QtGui.QStyle.CC_ComboBox, opt, painter)

def createEditor(self, parent, option, index):
    # create the ProgressBar as our editor.
    editor = QtGui.QComboBox(parent)
    editor.addItems(self.itemslist)
    editor.setCurrentIndex(0)
    editor.installEventFilter(self)         
    return editor

def setEditorData(self, editor, index):
    value = index.data(QtCore.Qt.DisplayRole).toInt()[0]
    editor.setCurrentIndex(value)

def setModelData(self,editor,model,index):
    value = editor.currentIndex()
    model.setData(index, QtCore.QVariant(value))

def updateEditorGeometry(self, editor, option, index):
    editor.setGeometry(option.rect)



class SequenceGridModel(QtCore.QAbstractTableModel):
def __init__(self, datain, headerdata, parent=None, *args):
    QtCore.QAbstractTableModel.__init__(self, parent, *args)
    self.parent = parent
    self.arraydata = datain
    self.headerdata = headerdata

def flags(self, index):
    if index.column() == 13:
        return QtCore.Qt.ItemIsEnabled | QtCore.Qt.ItemIsSelectable | QtCore.Qt.ItemIsEditable
    return QtCore.QAbstractTableModel.flags(self, index)


def data(self, index, role = QtCore.Qt.DisplayRole):
  if not index.isValid():
     if role == QtCore.Qt.UserRole:
        return None
     else:
        return QtCore.QVariant()

  value = QtCore.QVariant(self.arraydata[index.row()][index.column()])

  if QtCore.Qt.UserRole == role:
     return value
  elif role == QtCore.Qt.DisplayRole or role == QtCore.Qt.EditRole:
     return QtCore.QVariant(value)
  return QtCore.QVariant()



class SequenceGrid(QtGui.QTableView):
def __init__(self, parent=None):
    QtGui.QTableView.__init__(self, parent) 

    self.selectedIndexes = []
    self.parent = parent

    self.checkValues = ['TODO', 'WAITING', 'RETAKE', 'OK']

    self.model = SequenceGridModel(self.data, header, self)
    self.setModel(self.model)
    self.setEditTriggers(QtGui.QAbstractItemView.CurrentChanged)
    self.viewport().installEventFilter(self)
    self.setItemDelegateForColumn(13,ComboBoxDelegate(self, self.checkValues))

    self.setColumnWidth(13, 64)

Thanks for your attention !

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文