Qt关于窗口一直调用paintEvent的踩坑实录

embedded/2024/11/25 7:27:05/

首先看以下代码:

void ItemBlockWidget::paintEvent(QPaintEvent *ev) {// 先调用父类的 paintEvent 以执行默认绘制行为QWidget::paintEvent(ev);qDebug()<<"ItemBlockWidget重绘";QStyleOption opt;opt.initFrom(this);QPainter p(this);style()->drawPrimitive(QStyle::PE_Widget, &opt, &p, this);p.setRenderHint(QPainter::Antialiasing, true);// 如果鼠标悬停,绘制半透明蒙层if (this->m_isHoverCoverLab) {this->m_mask->show();this->m_mask->raise();this->m_popularBtn->setStyleSheet(QStringLiteral("color:white;border-radius:10px;background-color: rgba(60,60,60, 127);"));} else {this->m_popularBtn->setStyleSheet(QStringLiteral("color:white;border-radius:10px;background-color: rgba(128, 128, 128, 127);"));this->m_mask->hide();}
}

我一开始的目的是让窗口在绘制的时候考虑到是否鼠标悬停在该控件上方从而判断遮罩是否出现以及控制流行按钮的样式,从而达到不同的显示效果,但是一但运行会发现他一直在调用paintEvent

函数,如图:

通常来说遇到这种情况一般都是首先会考虑 是否在其他地方频繁调用了update或者repaint函数,但是在意料之中,我并没有频繁调用这两种函数,那么问题就复杂了,一下还摸不着头脑,通过一系列手段得知,问题出在样式表的设置,它不应该出现在paintEvent函数里面!!!!!!!

修改如下:
 


void ItemBlockWidget::paintEvent(QPaintEvent *ev) {// 先调用父类的 paintEvent 以执行默认绘制行为QWidget::paintEvent(ev);qDebug()<<"ItemBlockWidget重绘";QStyleOption opt;opt.initFrom(this);QPainter p(this);style()->drawPrimitive(QStyle::PE_Widget, &opt, &p, this);p.setRenderHint(QPainter::Antialiasing, true);// 如果鼠标悬停,绘制半透明蒙层/*if (this->m_isHoverCoverLab) {this->m_mask->show();this->m_mask->raise();this->m_popularBtn->setStyleSheet(QStringLiteral("color:white;border-radius:10px;background-color: rgba(60,60,60, 127);"));} else {this->m_popularBtn->setStyleSheet(QStringLiteral("color:white;border-radius:10px;background-color: rgba(128, 128, 128, 127);"));this->m_mask->hide();}*/
}void ItemBlockWidget::enterEvent(QEnterEvent *ev) {// 先调用父类的 paintEvent 以执行默认绘制行为QWidget::enterEvent(ev);if(!this->m_isHoverCoverLab) {this->m_isHoverCoverLab = true;this->m_mask->show();this->m_mask->raise();this->m_popularBtn->setStyleSheet(QStringLiteral("color:white;border-radius:10px;background-color: rgba(60,60,60, 127);"));update();}}void ItemBlockWidget::leaveEvent(QEvent *ev) {// 先调用父类的 paintEvent 以执行默认绘制行为QWidget::leaveEvent(ev);if(this->m_isHoverCoverLab) {this->m_isHoverCoverLab = false;this->m_popularBtn->setStyleSheet(QStringLiteral("color:white;border-radius:10px;background-color: rgba(128, 128, 128, 127);"));this->m_mask->hide();update();}
}

成功解决问题。。。


http://www.ppmy.cn/embedded/140323.html

相关文章

windows11下git与 openssl要注意的问题

看了一下自己贴文的历史&#xff0c;有一条重要的忘了写了。 当时帮有位同事配置gitlab&#xff0c;众说周知gitlab是不太好操作。 但我还是自认自己git还是相当熟的。 解决了一系列问题&#xff0c;如配置代理&#xff0c;sshkey&#xff0c;私有库&#xff0c;等等&#xff0…

Selenium + 数据驱动测试:从入门到实战!

引言 在软件测试中&#xff0c;测试数据的多样性和灵活性对测试覆盖率至关重要。而数据驱动测试&#xff08;Data-Driven Testing&#xff09;通过将测试逻辑与数据分离&#xff0c;极大地提高了测试用例的可维护性和可扩展性。本文将结合Selenium这一流行的测试工具&#xff0…

Vue进阶面试题目(一)

Vue 自定义事件中&#xff0c;父组件如何接收子组件传递的多个参数? 在 Vue 中&#xff0c;子组件可以通过 $emit 方法触发自定义事件&#xff0c;并传递参数。父组件可以通过监听这个事件来接收参数。如果子组件需要传递多个参数&#xff0c;可以将这些参数作为数组或对象传…

golang实现TCP服务器与客户端的断线自动重连功能

1.服务端 2.客户端 生成服务端口程序: 生成客户端程序: 测试断线重连: 初始连接成功

Linux之管道,system V的共享内存,消息队列和信号量

Linux之管道&#xff0c;systemV共享内存和信号量 一.进程间通信1.1进程间通信的目的1.2进程间通信的方式 二.管道2.1管道的概念2.2匿名管道2.3命名管道 三.system V3.1共享内存3.2消息队列3.3信号量 一.进程间通信 在我们之前有关Linux指令的学习时我们使用过“|”这个命令&a…

电子应用设计方案-22:智能门禁系统方案设计

智能门禁系统方案设计 一、系统概述 本智能门禁系统旨在提供高效、安全、便捷的人员出入管理解决方案&#xff0c;适用于各类场所&#xff0c;如住宅、办公楼、商业中心等。 二、系统组成 1. 前端设备 - 读卡器&#xff1a;支持多种识别方式&#xff0c;如射频卡、指纹、人脸识…

关于Tomcat服务器下载

目录 Tomcat的概述 Tomcat服务器下载 步骤 1 浏览器搜索tomcat 官网 2 下载对应操作系统的压缩包 3 配置环境 4 在命令行窗口检验是否环境配置成功 出现如同所示&#xff0c;表示tomcat环境配置成功&#xff0c;但发现&#xff0c;乱码了 解决办法 Tomcat的概述 Tomcat…

利用 Watchtower 自动监听并更新正在运行的 Docker 容器

本文首发于只抄博客&#xff0c;欢迎点击原文链接了解更多内容。 前言 大部分 VPS 和 NAS 用户或多或少都有用 Docker 来部署一些 Self-hosting 的服务&#xff0c;其中大部分项目都是开源项目&#xff0c;更新频率非常高&#xff0c;特别是一些版本 0.x 的项目&#xff0c;及…