Qt的QTableWidget如何在表头增加复选框

文章介绍了如何在QTableWidget的表头中添加复选框功能。提供了两种方法,一种是通过绘制图片的方式,另一种是通过绘制控件的方式。这两种方法均涉及到了自定义QHeaderView,以及对鼠标事件和绘制函数的重写,以实现复选框的显示和交互功能。

QTableWidget只能对表格中的单元格设置复选框,而且只能进行比较有限的控制,如果需要设置图标,显示居中等等,可能需要自定义Item或可以利用setCellWidget将单元格的控件设置为自定义控件,而表头如果是使用自带的表头则无法通过设置显示出复选框,必须进行自定义表头,自定义表头显示复选框有两种方法,具体如下。

1.采用绘制图片的方式在表头绘制复选框

核心代码如下

class CheckBoxHeaderView : public QHeaderView
{
    Q_OBJECT
public:
    CheckBoxHeaderView(int checkColumnIndex, Qt::Orientation orientation, QWidget*                                                         parent = 0) : QHeaderView(orientation, parent)
    {
        m_checkColIndex = checkColumnIndex;
        m_iChecked = Qt::UnChecked;
    }
    void setCheckState(int state)
    {
        m_iChecked = state;
        this->updateSection(m_checkColIndex);
    }
protected:
    void paintSection(QPainter* painter, const QRect &rect, int logicalIndex) const
    {
        painter->save();
        QHeaderView::paintSection(painter, rect, logicalIndex);
        painter->restore();
        if(logicalIndex == m_checkColIndex)
        {
           
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值