实现带进度条效果的QPushButton

本文介绍如何在已有的QPushButton基础上添加进度条功能。通过`paintEvent`方法实现按钮的绘制,包括图片的缩放和透明背景,并在进度条未初始化且总时间不为0时,根据进度绘制矩形条,展示进度效果。

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

既上一片的实现QPushButton定制功能后,在此基础上增加可定制进度条功能
void ProgressButton::paintEvent(QPaintEvent *event)
{
    Q_UNUSED(event)
    QPainter painter(this);

    static QImage img;
    if (m_currentImage.isNull()) {
        return;
    }
    QSize size =  m_currentImage.size();
    m_currentImage = m_currentImage.scaled(rect().width(), rect().height()
                                             , Qt::IgnoreAspectRatio, Qt::SmoothTransformation);
    if (img.isNull() || img.width() != m_currentImage.width() || img.height() != m_currentImage.width()) {
        img = QImage(m_currentImage.size(), QImage::Format_RGBA8888);
    }
 &nbs

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值