QStyledItemDelegate 刷新paint

在Qt中,使用QStyledItemDelegate定制QListView元素样式时,若需动态改变item元素,如按钮点击改变皮肤,直接修改paint函数内的样式无效。原因是QListView在初始化时绑定的ItemDelegate不会自动更新。解决办法是在修改了QStyledItemDelegate的属性后,需重新将修改后的delegate赋值给QListView,以确保新插入的元素根据新的paint函数绘制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

已知可以通过重写QStyledItemDelegate 的paint函数实现自定义item作为QListView的元素,但有时会有改变item中某一元素样式的需求(比如点击某一按钮更改皮肤),这时候直接在paint函数中修改并不起作用。

if (option.state.testFlag(QStyle::State_Selected)) {
            painter->setPen(QPen(QColor(select_color_)));
            painter->setBrush(QColor(select_color_));
            painter->drawPath(painter_path);
        }

以上代码是点击QListView中元素改变背景颜色的功能,如果想要更改背景色直接更改select_color_的值是不起作用的,QListView中点击的背景色仍然会是更改之前的颜色。

原因:

这是由于QListView最开始插入元素的时候绑定有一个ItemDelegate,如果后续不重新绑定新的ItemDelegate,那么再继续箱QListView中插入元素仍然会依据最初绑定 ItemDelegate的paint函数进行绘制。

解决方法:

当需要对paint中绘制的元素更改其显示风格时,在完成对其参数的修改之后,还应在QListView中重新绑定一个修改过之后的QStyledItemDelegate对象。

 //最初绑定的MyItemDelegate
MyItemDelegate* my_item_delegate = new MyItemDelegate(this);
    setItemDelegate(my_item_delegate);

//检测到滑动条到达底部之后重新绑定MyItemDelegate即可实现显示风格的更换
if (scroll_value == this->verticalScrollBar()->maximum()) {
        MyItemDelegate* my_item_delegate = new MyItemDelegate(this);
        my_item_delegate->GetInitDrawSetting(":/mainwnd/item_test.css");
        setItemDelegate(my_item_delegate);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值