QListView 自定义Delegate 实现鼠标状态获取,绘制自定义控件

通过自定义delegate,实现根据鼠标状态对添加的自定义控件显示不同图标

 先上效果图

 首先需要重写 editorEvent 在其中判断鼠标状态 并将状态值存入 QModelIndex 

bool editorEvent(QEvent *event, QAbstractItemModel *model, const QStyleOptionViewItem &option, const QModelIndex &index)
{

    //button的rect
    QRect rect = calculate_btn_rect(option.rect);
    //按钮点击事件
    QMouseEvent *mevent = static_cast<QMouseEvent*>(event);
    if(rect.contains(mevent->pos())){
        if(event->type() == QEvent::MouseButtonPress)
        {
            model->setData(index, event->type(), Qt::UserRole + 1);//将鼠标事件类型存入index
            model->dataChanged(index, index);
        }else if (event->type() == QEvent::Mou
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值