如何设置才能不显示QCheckBox自带的复选框呢

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何设置才能不显示QCheckBox自带的复选框呢相关的知识,希望对你有一定的参考价值。

使用了QCheckBox,默认会有一个复选框在左边,想使用图片覆盖掉这个复选框,使用了qss的样式,设置了image,但是图片却显示在中间了。
问:
1.如果隐藏默认生成的那个复选框。
2.如何通过qss设置这个image图标的位置,目前使用position:left不好用
截图与qss:
QCheckBox#saveCheck:enabled:checked
image:url(:/image/res/selected.png);
background-position:left;

其中还尝试了setIcon,但是icon前边还是存在那个默认的复选框,求大神指教
没有找到让复选框不显示的方法,可能通过PainEvent能实现。
但是通过QSS,可以设置复选框的样式,不是Window的样式,至少可以解决我的问题了。
弄好好一阵 终于反应过来 indicator这个是复选框的意思 不是别名。我之前替换了这个 所以一直没有实现。
QCheckBox::indicator:unchecked image:url(:/image/res/unselected.png);

参考技术A 重写paintEvent事件,先画你的红色背景图,然后画他自带的:QCheckBox::paintEvent(event);应该可以。 参考技术B ui.checkBox->setStyleSheet("#checkBox::indicatorwidth: 0px;"); //隐藏QCheckBox的复选框 参考技术C 忘了

如何在qtableview上创建qcheckbox,从qql数据库获取数据

我有一个QTableView显示来自sqlite数据库的数据。显然,我正在为所有可用的数据行创建一个复选框。问题是复选框不可检查,单击时显示以下错误。

if value.toBool():
    AttributeError: 'int' object has no attribute 'toBool'

下面是我得到的代码,但没有给出我要求的结果。我想突出显示已单击其复选框的行。

    self.table_model3 = CheckboxSqlModel(0)
    self.table_model3.setQuery("SELECT Name, Email FROM Individuals")
    self.tableView3.setModel(self.table_model3)
    self.tableView3.horizontalHeader().setStretchLastSection(True)
    self.tableView3.setShowGrid(False)
    self.table_model3.setHeaderData(0, QtCore.Qt.Horizontal, "All")
    self.table_model3.setHeaderData(1, QtCore.Qt.Horizontal, "Client Name")
    self.table_model3.setHeaderData(2, QtCore.Qt.Horizontal, "Email Address")
    self.tableView3.setStyleSheet('QHeaderView:section{Background-color:#cdcdcd; font-family: Arial Narrow; font-size: 15px; height: 30px;}')
    self.table_model3.insertColumn(0)
    self.tableView3.setColumnWidth(0, 30)


class CheckboxSqlModel(QtSql.QSqlQueryModel):
    def __init__(self, column):
        super(CheckboxSqlModel, self).__init__()
        self.column = column
        self.checkboxes = list() #List of checkbox states
        self.first = list() #Used to initialize checkboxes

    #Make column editable
    def flags(self, index):
        flags = QtSql.QSqlQueryModel.flags(self, index)
        if index.column() == self.column:
            flags |= QtCore.Qt.ItemIsUserCheckable
        return flags

    def data(self, index, role=QtCore.Qt.DisplayRole):
        row = index.row()
        if index.column() == self.column and role == QtCore.Qt.CheckStateRole:
            #Used to initialize
            if row not in self.first :
                index = self.createIndex(row, self.column)
                self.first.append(row)
                self.checkboxes.append(False)
                return QtCore.Qt.Unchecked
            #if checked
            elif self.checkboxes[row]:
                return QtCore.Qt.Checked
            else:
                return QtCore.Qt.Unchecked
        else:
            return QtSql.QSqlQueryModel.data(self, index, role)

    def setData(self, index, value, role=QtCore.Qt.DisplayRole):
        row = index.row()
        if index.column() == self.column and role == QtCore.Qt.CheckStateRole:
            if value.toBool():
                self.checkboxes[row] = True
            else:
                self.checkboxes[row] = False
            self.dataChanged.emit(index, index)
            return True
        else:
            return False
答案

问题是值被转换为保存的类型,在您的情况下,它是一个采用以下值Qt::CheckedQt::PartiallyCheckedQt::Checked的整数,解决方案是将它们与这些值进行比较。

def setData(self, index, value, role=QtCore.Qt.DisplayRole):
    row = index.row()
    if index.column() == self.column and role == QtCore.Qt.CheckStateRole:
        if value == QtCore.Qt.Checked:
            self.checkboxes[row] = True
        else:
            self.checkboxes[row] = False
        self.dataChanged.emit(index, index, [QtCore.Qt.CheckStateRole])
        return True
    else:
        return False

要选择或取消选择,我们使用以下方法

    self.table_model3.dataChanged.connect(self.on_data_changed)

def on_data_changed(self, topleft, bottomRight, roles):
    if QtCore.Qt.CheckStateRole in roles:
        row = topleft.row()
        isChecked = topleft.data(QtCore.Qt.CheckStateRole) == QtCore.Qt.Checked
        flag = QtCore.QItemSelectionModel.Select if isChecked else QtCore.QItemSelectionModel.Deselect
        for col in range(self.table_model3.columnCount()):
            ix = self.table_model3.index(row, col)
            self.tableView3.selectionModel().select(ix, flag)

以上是关于如何设置才能不显示QCheckBox自带的复选框呢的主要内容,如果未能解决你的问题,请参考以下文章

将QCheckBox的状态保存在文件中,程序重启时加载状态

如何在 PySide/PyQt 中设置“只读复选框”

如何在 QCheckBox 中的文本和复选框之间绘制一个正方形

如何在没有 QCheckBox 框的情况下绘制本机复选标记

pyqt4正确连接QCheckbox状态

如何获取 PyQt 中 QGroupbox 中存在的 Qcheckbox 的状态