(四)Paint函数实现QTableView中增加QCheckBox的方法

    第四种方法是:实现QAbstractItemDelegate的paint()函数。

 

     这种方法和《C++_GUI_Qt4_编程(第二版)》中第十章的自定义委托例子,画星星的作法是一样的,都是通过 QApplication::style()->drawControl(QStyle::CE_CheckBox,&check_box_style_option,painter);这个函数,只不过选择的元素是QCheckBox的。

    使用Delegate Paint()函数 具体如下:

 

void QLineDelegate::paint(QPainter* painter, const QStyleOptionViewItem& option,const QModelIndex& index)const  
{  
    bool checked = index.model()->data(index, Qt::DisplayRole).toBool();  
  
    if(index.column() == 0)  
    {  
        QStyleOptionButton check_box_style_option;  
        check_box_style_option.state |= QStyle::State_Enabled;  
        if(checked)  
        {  
            check_box_style_option.state |= QStyle::State_On;  
        }  
        else  
        {  
            check_box_style_option.state |= QStyle::State_Off;  
        }  
        check_box_style_option.rect = CheckBoxRect(option);  
        QApplication::style()->drawControl(QStyle::CE_CheckBox,&check_box_style_option,painter);  
    }  
  
    QStyledItemDelegate::paint(painter,option,index);  
    QStyleOptionViewItem itemOption(option);  
    if(itemOption.state & QStyle::State_HasFocus)  
        itemOption.state = itemOption.state ^ QStyle::State_HasFocus;  
    QStyledItemDelegate::paint(painter,itemOption,index);  
    QPen oldPen = painter->pen();  
    painter->setPen(pen);  
    painter->drawLine(option.rect.topRight(),option.rect.bottomRight());  
    painter->drawLine(itemOption.rect.bottomLeft(),itemOption.rect.bottomRight());  
    painter->setPen(oldPen);  
}  
 

 

 

完整的源代码如下:

 

class QLineDelegate : public QStyledItemDelegate
{
    Q_OBJECT
public:
    QLineDelegate(QTableView* tableView);
protected:
    void paint(QPainter* painter,const QStyleOptionViewItem& option,const QModelIndex& index) const;
    bool editorEvent(QEvent *event,
                                         QAbstractItemModel *model,
                                         const QStyleOptionViewItem &option,
                                         const QModelIndex &index) ;
private:
    QPen         pen;
    QTableView*  view;
};

static QRect CheckBoxRect(const QStyleOptionViewItem &view_item_style_options)
{
    QStyleOptionButton check_box_style_option;
    QRect check_box_rect = QApplication::style()->subElementRect(
        QStyle::SE_CheckBoxIndicator,
        &check_box_style_option);

    QPoint check_box_point(view_item_style_options.rect.x() +
                           view_item_style_options.rect.width() / 2 -
                           check_box_rect.width() / 2,
                           view_item_style_options.rect.y() +
                           view_item_style_options.rect.height() / 2 -
                           check_box_rect.height() / 2);
    return QRect(check_box_point, check_box_rect.size());
}


QLineDelegate::QLineDelegate(QTableView* tableView)
{
    int gridHint = tableView->style()->styleHint(QStyle::SH_Table_GridLineColor, new QStyleOptionViewItemV4());
    QColor gridColor = static_cast<QRgb>(gridHint);
    pen = QPen(gridColor,0,tableView->gridStyle());
    view = tableView;
}

void QLineDelegate::paint(QPainter* painter, const QStyleOptionViewItem& option,const QModelIndex& index)const
{
    bool checked = index.model()->data(index, Qt::DisplayRole).toBool();

    if(index.column() == 0)
    {
        QStyleOptionButton check_box_style_option;
        check_box_style_option.state |= QStyle::State_Enabled;
        if(checked)
        {
            check_box_style_option.state |= QStyle::State_On;
        }
        else
        {
            check_box_style_option.state |= QStyle::State_Off;
        }
        check_box_style_option.rect = CheckBoxRect(option);
        QApplication::style()->drawControl(QStyle::CE_CheckBox,&check_box_style_option,painter);
    }

    QStyledItemDelegate::paint(painter,option,index);
    QStyleOptionViewItem itemOption(option);
    if(itemOption.state & QStyle::State_HasFocus)
        itemOption.state = itemOption.state ^ QStyle::State_HasFocus;
    QStyledItemDelegate::paint(painter,itemOption,index);
    QPen oldPen = painter->pen();
    painter->setPen(pen);
    painter->drawLine(option.rect.topRight(),option.rect.bottomRight());
    painter->drawLine(itemOption.rect.bottomLeft(),itemOption.rect.bottomRight());
    painter->setPen(oldPen);
}

bool QLineDelegate::editorEvent(QEvent *event,
                                   QAbstractItemModel *model,
                                   const QStyleOptionViewItem &option,
                                   const QModelIndex &index) {
    if((event->type() == QEvent::MouseButtonRelease) ||
        (event->type() == QEvent::MouseButtonDblClick))
    {
        QMouseEvent *mouse_event = static_cast<QMouseEvent*>(event);
        if(mouse_event->button() != Qt::LeftButton ||
           !CheckBoxRect(option).contains(mouse_event->pos()))
        {
            return false;
        }

        if(event->type() == QEvent::MouseButtonDblClick)
        {
            return true;
        }
    }
    else if(event->type() == QEvent::KeyPress)
    {
        if(static_cast<QKeyEvent*>(event)->key() != Qt::Key_Space &&
           static_cast<QKeyEvent*>(event)->key() != Qt::Key_Select)
        {
            return false;
        }
    }
    else
    {
        return false;
    }

    bool checked = index.model()->data(index, Qt::DisplayRole).toBool();
    return model->setData(index, !checked, Qt::EditRole);
}

 

 不过有一个小问题,CheckBox旁边有false/true或其它字符的原因是:你的Model中的data返回值,应该排除这列。

 

转:http://www.cppblog.com/gaimor/archive/2011/11/26/160993.html

 

【Qt】QTableView中嵌入复选框CheckBox 的四种方法总结 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: QTableView 是一个显示表格数据的控件,它提供了一种在界面上展示数据的方式,可以方便地查看和编辑表格数据。 QCheckBox 是一个单选框控件,它提供了一种选择或取消选择某个选项的方式。当需要用户在多个选项进行单选操作时,可以使用 QCheckBox 控件来增加用户的交互体验。 在使用 QTableView 和 QCheckBox 控件时,可以将 QCheckBox 添加到 QTableView 的某一列的每一个单元格,用来标识该行数据是否被选。这样就可以实现在表格选择或取消选择某些特定的行数据。 当用户点击某个 QCheckBox 控件时,可以通过信号和槽机制来捕捉到 QCheckBox 被选或取消选的事件,然后根据事件来改变 QTableView 相应行数据的状态。 除此之外,还可以通过通过编程的方式操作 QCheckBox 控件,例如通过代码设置某一行的 QCheckBox 控件为选状态或取消选状态,或者获取某一行 QCheckBox 控件的状态来进行相关的处理。 总之,使用 QTableView 和 QCheckBox 控件可以方便地对表格数据进行展示和选择操作,提供了一种方便和快捷的方式来处理表格数据。 ### 回答2: QTableView是一个表格视图,它是Qt数据展示的一种常用方式。它可以显示一张表格,其包含了行和列的数据。 QCheckbox是一个复选框,它是Qt常用的一种控件。它可以同时显示未选和选两种状态,并且可以通过用户的操作来切换状态。 当我们将这两个控件结合使用时,可以实现一些有趣的功能。 例如,我们可以在QTableView的某一列插入QCheckbox,这样每一行都会有一个复选框。用户可以通过勾选或取消勾选这些复选框来选择其的某些行。 此外,我们还可以编写代码来实现全选或全不选的功能。比如,当用户点击一个全选的复选框时,所有的行的复选框都会变为选状态,当用户取消勾选全选的复选框时,所有的行的复选框都会变为未选状态。 我们还可以在QTableView使用QCheckbox来控制一些与数据相关的操作。比如,当用户勾选某个复选框时,可以执行某个特定的操作,比如删除该行的数据。 综上所述,QTableView和QCheckbox是两个常用的Qt控件,结合使用可以实现很多有用的功能。在开发Qt应用程序时,我们可以根据具体需求来使用它们,提供更好的用户体验。 ### 回答3: QTableView和QCheckBoxQt框架常用的两个控件。 QTableView是一个表格视图控件,用于显示二维数据。通过QTableView,可以将数据以表格的形式展示出来,并支持对数据进行排序、筛选、编辑等操作。QTableView可以根据需要自定义表头、行数、列数、单元格内容和格式等。同时,还可以通过设置不同的选择模式,实现单选、多选或无选择的功能。 QCheckBox则是一个复选框控件,用于表示二选一或多选一的状态。通过QCheckBox,用户可以在多个选项进行选择,并可以通过勾选或取消勾选的方式改变其状态。QCheckBox可以设置默认状态、选状态、禁用状态等,并且可以通过信号和槽机制,实现对状态变化的响应。 在使用QTableView时,可以将QCheckBox作为一个自定义的编辑控件嵌入到表格的某一列,用于表示某个特定的列为复选框的选择状态。例如,在一个任务列表,可以将某一列设为复选框,用于选择是否完成相应的任务。这样,用户可以通过对复选框进行勾选或取消勾选的操作来改变任务的完成状态。 总而言之,QTableView和QCheckBoxQt框架十分有用的两个控件。通过QTableView,可以轻松地展示和处理二维数据,而QCheckBox则为用户提供了一种方便的选择和控制状态的方式。它们的结合使用,可以帮助我们开发出更加灵活和交互性的应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值