QT之动态进度条

简介

前两天需要接到一个需求需要做一个好看的进度条,在网上搜了一圈发现要不然就是不符合我的需求要不然就是没有源码,最后找到一个大佬写的有部分源码的,自己也折腾了一个(原文链接)。

效果图

在这里插入图片描述

思路

主要就是重写了QProcessBar的paintEvent事件,让其先执行完QProcessBar自己的绘制事件,在绘制一层光效在上面。
在内存中维护一个变量m_currvalue用来决定当前需要绘制的区域,m_currvalue不能大于进度条当前的值,然后定一个定时器QTimer,让其每隔一段时间自增一次,达到光效前进的效果,当其与进度条当前的值相等时又置为零。

关键代码

void MyProcessBar::paintEvent(QPaintEvent *e)
{
    QProgressBar::paintEvent(e);
    QStyleOptionProgressBar opt;
    initStyleOption(&opt);

    if (m_currvalue != 0)
    {
        QPainter painter(this);
        QRect rect1 = style()->subElementRect(QStyle::SE_ProgressBarContents, &opt, this);
        //QRectF rect1=this->rect();
        double _width=static_cast<double>(m_currvalue)/static_cast<double>(m_maxvalue)*rect1.width();
        QLinearGradient gradient(0,0,_width,rect1.height());
        gradient.setColorAt(0,Qt::red);
        gradient.setColorAt(1,Qt::blue);
        painter.setBrush(gradient);
        QRectF rect2=QRectF(rect1.topLeft(),QSize(static_cast<int>(_width),static_cast<int>(rect1.height())));
        rect2.adjust(0,0.8,0,-2);
        painter.drawRoundedRect(rect2, 10, 10);
        //painter.drawRect(rect);
    }

}

完整代码链接

  • 3
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Qt是一个跨平台的C++应用程序开发框架,它提供了丰富的GUI和媒体功能,使开发者能够快速创建各种应用程序。在Qt中,我们可以使用动态进度条和启动画面来增强用户体验。 动态进度条是一个可以显示任务进度的控件,它与任务的完成情况同步更新。我们可以使用Qt中的QProgressBar类来创建和管理动态进度条。在启动画面中,我们可以使用Qt中的QSplashScreen类来显示一个带有应用程序标识和加载信息的启动画面。 要创建动态进度条和启动画面,我们可以按照以下步骤进行: 1. 创建一个QSplashScreen实例,并设置启动画面的背景图片和显示文本。 2. 在应用程序主窗口的构造函数中,创建一个QProgressBar实例,并设置其初始值和范围。 3. 在任务执行过程中,使用QTimer类来模拟任务的进度,通过更新QProgressBar的value属性来更新进度条的显示。 4. 在任务完成后,关闭启动画面并显示应用程序主窗口。 下面是一个使用动态进度条和启动画面的示例代码: ```cpp #include <QtWidgets> int main(int argc, char *argv[]) { QApplication app(argc, argv); QSplashScreen splash(QPixmap(":/splash_image.png")); QProgressBar progressBar; splash.showMessage("Loading...", Qt::AlignBottom|Qt::AlignHCenter, Qt::white); splash.show(); QTime waitTime = QTime::currentTime().addSecs(3); // 模拟加载过程 while (QTime::currentTime() < waitTime) { app.processEvents(); } progressBar.setRange(0, 100); progressBar.setValue(0); progressBar.setAlignment(Qt::AlignCenter); QMainWindow mainWindow; mainWindow.setCentralWidget(&progressBar); mainWindow.show(); QTimer timer; QObject::connect(&timer, &QTimer::timeout, [&progressBar]() mutable { int value = progressBar.value() + 10; if (value <= progressBar.maximum()) { progressBar.setValue(value); } }); timer.start(500); splash.finish(&mainWindow); return app.exec(); } ``` 以上代码中,我们使用了一张启动画面图片,并设置了加载信息。然后,程序会在启动画面显示3秒钟,模拟加载过程。加载完成后,我们创建了应用程序的主窗口,并将QProgressBar设置为其中央部件。通过QTimer来定时更新进度条的值,最后关闭启动画面并显示主窗口。 使用动态进度条和启动画面可以给用户一个友好的界面提示,提升用户体验。在实际的应用程序中,我们可以根据具体需求来设计和实现更丰富和复杂的动态进度条和启动画面。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值