我已经能够在我的表格视图中使我的复选框可编辑。它们出现在我的表格视图中,但我对它们无能为力。就像没有正确设置标志一样。
class CheckBox(QtGui.QStyledItemDelegate):
def __init__(self, parent = None):
QtGui.QGraphicsWidget.__init__(self)
def flags(self, index):
return QtCore.Qt.ItemIsEditable | QtCore.Qt.ItemIsUserCheckable | Qt.ItemIsEnabled
def paint (self, painter, option, index):
item = QtGui.QTableWidgetItem()
item.setFlags(QtCore.Qt.ItemIsUserCheckable | QtCore.Qt.ItemIsEnabled)
# picks up data from database
checked = index.model().data(index, Qt.EditRole).toBool()
# Then draw the checkbox
box = QtGui.QStyleOptionButton()
box.palette = option.palette
box.rect = option.rect
box.state = QtGui.QStyle.State_Enabled
if checked:
box.state |= QtGui.QStyle.State_On
else:
box.state |= QtGui.QStyle.State_Off
style = QtGui.QApplication.instance().style()
style.drawControl(QtGui.QStyle.CE_CheckBox, box, painter)
painter.restore()
嗨,这是基于 Avaris 评论的审查代码,使用 checkrole 而不是委托。但我仍然可以解决问题。我无法勾选复选框,而是显示一个旋转框。它正在正确地从数据库中读取值(0 或 1),但我想隐藏这个值。任何帮助,将不胜感激!
class EditableShoSqlModel(QtSql.QSqlQueryModel):
def __init__(self, parent=None):
super(EditableShoSqlModel, self).__init__(parent)
def flags(self, index):
flags = super(EditableShoSqlModel, self).flags(index)
if index.column() in (12):
flags |= QtCore.Qt.ItemIsEditable | QtCore.Qt.ItemIsUserCheckable | Qt.ItemIsEnabled
return flags
def data(self, index, role=QtCore.Qt.DisplayRole):
value2 = super(EditableShoSqlModel, self).data(index)
if index.column() == 12 and role == QtCore.Qt.CheckStateRole:
if value2 != 0:
return QtCore.Qt.Checked
else:
return QtCore.Qt.Unchecked
return QtSql.QSqlQueryModel.data(self, index, role)
def setData(self, index, value, role):
if index.column() not in (12):
return False
primaryKeyIndex = self.index(index.row(), 0)
id = self.data(primaryKeyIndex)
#self.clear()
if index.column() == 12 and role == QtCore.Qt.CheckStateRole:
value2 = super(EditableShoSqlModel, self).data(index)
if value2 != 0:
ok = self.setAniStatus(id, value)
return QtCore.Qt.Unchecked
else:
ok = self.setAniStatus(id, value)
return QtCore.Qt.Checked
return True
self.refresh()
return ok
def refresh(self):
MainWindow.AllShotsFromProject ()
def setAniStatus(self, id, Number):
mon = Number
if mon != False:
mon = 1
else:
mon = 0
print "ANIS"
query = QtSql.QSqlQuery()
sql = "UPDATE Shot SET Ani= '{0}' WHERE idShot = {1}".format(int(mon), id.toString())
query.prepare(sql)
print 'lastQuery:', query.lastQuery()
return query.exec_()