Qt实战案例(43)——利用QPainter实现自定义加载中动画控件(Loading.gif)

本文介绍了如何在Qt中不依赖图片,仅通过代码实现Loading加载动画。项目配置了一个简单的UI界面,包含加载和取消按钮。加载动画通过自定义的Loading类实现,可设置圆点数量、颜色、直径等参数,并在主程序中响应按钮事件来显示和关闭动画。
摘要由CSDN通过智能技术生成

一、项目介绍

在Photoshop介绍:PhotoShop简单案例(4)——利用ps制作正在加载中动画(loading.gif)中介绍了一下利用Photoshop制作加载中动画(Loading.gif),可以在Qt中直接调用这个动图,但是毕竟不太方便,因此为了简洁,本文不使用图片,仅仅利用代码实现Loading加载中动画。

二、项目基本配置

新建一个Qt案例,项目名称为“LoadTest”,基类选择“QWidget”,点击选中创建UI界面复选框,完成项目创建。

三、UI界面设置

UI界面如下:
在这里插入图片描述

为简单起见,这里只设计三个控件:

序号名称类型属性
pushButtonQPushButtontext:Load
pushButton_2QPushButtontext:Cancel
gridLayoutQGridLayout/

四、主程序实现

4.1 Loading.h和Loading.cpp

由于Loading.h和Loading.cpp代码量较大,这里不进行展示,仅作简要说明。
函数如下:

    //设置圆点个数
    void setDotCount(int);
    //设置点颜色
    void setDotColor(const QColor&);
    //开始
    void start();
    //设置圆点最大直径
    void setMaxDiameter(float);
    //设置圆点最小直径
    void setMinDiameter(float);

可以设置圆点个数、点的颜色、开始显示加载、设置圆点最大直径、设置圆点最小直径。在构造函数中进行了如下初始化设定:

    setDotColor(QColor(49, 177, 190));
    setDotCount(20);
    connect(&timer,&QTimer::timeout,this,&Loading::refresh);
    setMaxDiameter(30);
    setMinDiameter(5);

设置圆点颜色为(49,170,190),设置原点数量为20,将timeout信号和refresh槽(即repaint)连接,设置最大直径为30,最小直径为5。

4.2 widget.h头文件

头文件中引入Loading.h头文件,两个按钮点击槽函数和loading1对象:

private slots:
    void on_pushButton_clicked();
    void on_pushButton_2_clicked();

private:
    Loading* loading1;

4.3 widget.cpp源文件

源文件定义按钮点击槽函数:

//按钮点击
void Widget::on_pushButton_clicked()
{
    loading1=new Loading(this);
    loading1->start();
    ui->gridLayout->addWidget(loading1,0,0);


}

//取消
void Widget::on_pushButton_2_clicked()
{
    delete loading1;
}

五、效果演示

完整效果如下:
在这里插入图片描述

如果没有看懂的话,完整代码可以参考:https://download.csdn.net/download/didi_ya/85212107


ok,以上便是本文的全部内容了,如果对你有所帮助,记得点个赞哟~

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

wendy_ya

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

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

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

打赏作者

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

抵扣说明:

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

余额充值