QT最简单进度条实现

这篇博客介绍了使用QT框架实现进度条的简单方法,涉及QProgressBar、QTimer及信号与槽机制。作者通过创建UI,启动和停止定时器,并绑定槽函数更新进度条,实现了进度条的动态效果。提供了相关代码示例,适合初学者参考。
摘要由CSDN通过智能技术生成

用qt实现一个最简单的进度条

效果图

在这里插入图片描述

知识点

1.QProgressBar
2.QTimer
3.信号与槽

思路

核心就是利用定时器的原理,每跑一段时间会发出一个溢出信号,通过绑定这信号和要执行的槽函数,来不断增加进度条的进度。

顺序:
1.UI设计,一个进度条,两个按钮。
2.头文件,< QTimer >别忘了。
3.写代码
用了3个槽函数:1. void go(); 2. void over(); 3. void timeoutslots();
按开始键,槽函数1启动定时器Timer
按暂停键,槽函数2关闭定时器
通过定时器周期性发送信号,来不断执行槽函数3,对进度条的值进行获取和再赋值操作。

代码

ProgressBar.h

#pragma once

#include <QtWidgets/QWidget>
#include "ui_ProgressBar.h"
#include <QTimer>

class ProgressBar : public QWidget
{
   
	Q_OBJECT

public:
	ProgressBar(QWidget *parent = Q_NULLPTR); 

  • 8
    点赞
  • 61
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Qt一个跨平台的C++应用程序开发框架,它提供了丰富的图形界面和功能库。要实现不规则形状的进度条,可以使用Qt的绘图功能和自定义控件。 以下是一种实现不规则形状进度条的方法: 1. 创建一个自定义的QWidget子类,作为进度条的容器。 2. 在该自定义控件中重写paintEvent函数,使用Qt的绘图功能绘制进度条的背景和前景。 3. 根据进度值计算出前景的宽度,并使用绘图函数绘制前景。 4. 使用QPainterPath类创建一个不规则形状的路径,可以使用addRect、addEllipse等函数添加矩形、椭圆等形状。 5. 使用setClipPath函数将绘图区域限制在不规则形状的路径内。 6. 在paintEvent函数中绘制进度条的背景和前景。 下面是一个简单的示例代码: ```cpp #include <QtWidgets> class IrregularProgressBar : public QWidget { public: IrregularProgressBar(QWidget *parent = nullptr) : QWidget(parent), m_progress(0) { } void setProgress(int progress) { m_progress = progress; update(); } protected: void paintEvent(QPaintEvent *event) override { Q_UNUSED(event); QPainter painter(this); painter.setRenderHint(QPainter::Antialiasing); // 绘制背景 painter.fillRect(rect(), Qt::lightGray); // 绘制前景 QRectF foregroundRect(rect().x(), rect().y(), rect().width() * m_progress / 100.0, rect().height()); painter.fillRect(foregroundRect, Qt::blue); // 创建不规则形状的路径 QPainterPath path; path.addRoundedRect(rect(), 10, 10); // 设置绘图区域为不规则形状的路径 painter.setClipPath(path); // 绘制进度条的背景和前景 painter.fillRect(rect(), Qt::lightGray); painter.fillRect(foregroundRect, Qt::blue); } private: int m_progress; }; int main(int argc, char *argv[]) { QApplication app(argc, argv); IrregularProgressBar progressBar; progressBar.setProgress(50); progressBar.resize(300, 30); progressBar.show(); return app.exec(); } ``` 这个示例代码创建了一个自定义的QWidget子类IrregularProgressBar,通过重写paintEvent函数实现了不规则形状的进度条。在paintEvent函数中,首先绘制了背景和前景,然后创建了一个圆角矩形的路径,并使用setClipPath函数将绘图区域限制在该路径内,最后再次绘制了背景和前景。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值