QT制作自定义进度条(圆环状)

其实实现原理基本上是使用paintEvent进行绘制,在paintevent中绘制时设置变量,自己传入变量值。然后进行update就可以了。
直接看代码
drawpie.h

#ifndef DRAWPIE_H
#define DRAWPIE_H

#include <QWidget>
#include <qtoolbar.h>
#include <QSlider>

class drawpie : public QWidget
{
    Q_OBJECT

public:
    drawpie(QWidget *parent = nullptr);
    ~drawpie();

protected:
    void paintEvent(QPaintEvent *event);

protected slots:
    void setSliderValue();
private:
    QSlider *m_slider;

    int m_value=0;

};
#endif // DRAWPIE_H

drawpie.cpp

#include "drawpie.h"
#include <QPainter>
#include <QPaintEvent>
#include <QDebug>
#include <QHBoxLayout>


drawpie::drawpie(QWidget *parent)
    : QWidget(parent)
{
    this->setStyleSheet("background-color:white");
    m_slider=new QSlider(this);
    connect(m_slider,&QSlider::valueChanged,this,&drawpie::setSliderValue);
    m_slider->setRange(0,100);
    QHBoxLayout *mainLayout=new QHBoxLayout(this);
    mainLayout->addStretch();
    mainLayout->addWidget(m_slider);
    this->setLayout(mainLayout);
}

drawpie::~drawpie()
{
}

void drawpie::paintEvent(QPaintEvent *event)
{
    QPainter painter(this);
    painter.setPen(QPen(Qt::transparent,4,Qt::SolidLine));
    painter.setRenderHint(QPainter::Antialiasing);
    QPainterPath path;
    path.addEllipse(0, 0, 200, 200);
    path.addEllipse(50, 50, 100, 100);
    painter.setBrush( QBrush(QColor("lightblue")) );
    painter.drawPath(path);
    painter.setBrush(QBrush(QColor("green")));
    QRect rect(0,0,200,200);
    QRect rect1(50, 50, 100, 100);
    painter.drawPie(rect,270*16,3.6*m_value*16);
    painter.setBrush(QBrush(QColor("white")));
    painter.drawPie(rect1,270*16,3.6*m_value*16);


}

void drawpie::setSliderValue()
{
    m_value=m_slider->value();
    qDebug()<<"slider::"<<m_value;
    update();
}



showwgt.h

#ifndef SHOWWGT_H
#define SHOWWGT_H

#include <QWidget>
#include "drawpie.h"

class ShowWgt : public QWidget
{
    Q_OBJECT
public:
    explicit ShowWgt(QWidget *parent = nullptr);
    ~ShowWgt();
signals:

public slots:

private:
    drawpie *m_pie[20][10];
};

#endif // SHOWWGT_H

showwgt.cpp

#include "showwgt.h"
#include <qscrollbar.h>
#include <qgridlayout.h>
#include <QScrollArea>

ShowWgt::ShowWgt(QWidget *parent) : QWidget(parent)
{
    QScrollArea *area=new QScrollArea(this);
    QGridLayout *gridLayout=new QGridLayout(this);
    QWidget *containWgt=new QWidget(this);

    for(int i=0;i<20;i++)
    {
        for(int j=0;j<10;j++)
        {
            m_pie[i][j]=new drawpie(containWgt);
            gridLayout->addWidget(m_pie[i][j],i,j);
            m_pie[i][j]->setFixedSize(250,200);
        }
    }
    containWgt->setLayout(gridLayout);
    area->setWidget(containWgt);
    QVBoxLayout *mainLayout=new QVBoxLayout(this);
    mainLayout->addWidget(area);
    mainLayout->setMargin(0);
    this->setLayout(mainLayout);


}

ShowWgt::~ShowWgt()
{

}

main.cpp

#include "drawpie.h"
#include "showwgt.h"
#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    ShowWgt w;
    w.show();
    return a.exec();
}

亲测可用。
效果图如下:
在这里插入图片描述
有什么不懂的可以在评论区留言 Bye。

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

加油吧,小杜

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值