Qt编写自定义控件:简单的方式绘制渐变进度条

本文详细介绍了如何在Qt中创建一个带有渐变颜色的自定义QProgressBar,通过继承QProgressBar并重写paintEvent方法,展示了如何设置进度条样式和文本。适合学习Qt界面定制的开发者。

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

代码:

#ifndef MYPROGRESSBAR_H
#define MYPROGRESSBAR_H

#include <QProgressBar>

class myProgressBar : public QProgressBar
{
public:
    myProgressBar(QWidget * parent = nullptr);

protected:
    void paintEvent(QPaintEvent *event)override;
};

#endif // MYPROGRESSBAR_H
#include "myprogressbar.h"
#include <QPainter>
#include <QStyleOptionProgressBar>
#include <QStylePainter>
#include <QDebug>
#include <QPaintEvent>

myProgressBar::myProgressBar(QWidget *parent)
    :QProgressBar(parent)
{
    setMinimumSize(180,150);
    setAlignment(Qt::AlignCenter);
}

void myProgressBar::paintEvent(QPaintEvent *event)
{
    QStylePainter painter(this);
    painter.setRenderHint(QPainter::Antialiasing,true);
    QStyleOptionProgressBar option;

    initStyleOption(&option);
//    painter.drawControl(QStyle::CE_ProgressBar,option);
    QStyleOptionProgressBar opt1 = option;
    opt1.rect = this->style()->subElementRect(QStyle::SE_ProgressBarContents, &opt1, this);

    QStyleOptionProgressBar opt2 = option;

    QRect rect = QRect(opt1.rect.topLeft().x(),
                       opt1.rect.topLeft().y(),
                       opt1.rect.width() * opt1.progress / opt1.maximum,
                       opt1.rect.height());

    auto eventRect = event->rect();
    QLinearGradient linearGradient(eventRect.topLeft(),eventRect.topRight());
    linearGradient.setColorAt(0.0,Qt::red);
    linearGradient.setColorAt(0.3,Qt::cyan);
    linearGradient.setColorAt(0.7,Qt::green);
    linearGradient.setColorAt(1.0,Qt::blue);

    painter.fillRect(rect,linearGradient);

    if (option.textVisible)
    {
        opt2.rect = this->style()->subElementRect(QStyle::SE_ProgressBarLabel, &opt2, this);
        painter.setPen(Qt::red);
        painter.drawControl(QStyle::CE_ProgressBarLabel, opt2);
    }
}

使用:

Widget::Widget(QWidget *parent)
    : QWidget(parent)
{
    QVBoxLayout * vb = new QVBoxLayout(this);
    myProgressBar * bar = new myProgressBar(this);
    QSlider * slider = new QSlider(Qt::Horizontal,this);
    slider->setRange(0,100);
    bar->setRange(0,100);
    vb->setContentsMargins(20,20,20,20);
    vb->addWidget(bar);
    vb->addStretch();
    vb->addWidget(slider);
    connect(slider,&QSlider::valueChanged,bar,&QProgressBar::setValue);
}

效果:

相关博文:QT风格(QStyle):绘制一个自定义QProgressBar_友善啊,朋友的博客-优快云博客 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值