今天和大家分享一个文本风格的加载动画, 有两类,其中一个可以设置文本内容和文本颜色,演示了两份. 共三个动画, 效果如下:
一共三个文件,可以直接编译 , 如果对您有所帮助的话 , 不要忘了点赞呢.
//main.cpp
#include "LoadingAnimWidget.h"
#include <QApplication>
#include <QGridLayout>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
QWidget w;
w.setWindowTitle("加载动画 第8季");
QGridLayout * mainLayout = new QGridLayout;
auto* anim1= new TextInBouncingBox("正在加载");
mainLayout->addWidget(anim1,0,0);
auto* anim2 = new TextInBouncingBox("正在加载中");
anim2->setBoxColor("slateblue");
anim2->setTextColor("white");
mainLayout->addWidget(anim2,0,1);
auto* anim3 = new ExpandingScroll;
mainLayout->addWidget(anim3,0,2);
w.setLayout(mainLayout);
w.show();
anim1->start();
anim2->start();
anim3->start();
return a.exec();
}
//LoadingAnimWidget.h
#ifndef LOADINGANIMWIDGET_H
#define LOADINGANIMWIDGET_H
#include <QPropertyAnimation>
#include <QWidget>
class LoadingAnimBase:public QWidget
{
Q_OBJECT
Q_PROPERTY(qreal angle READ angle WRITE setAngle)
public:
LoadingAnimBase(QWidget* parent=nullptr);
virtual ~LoadingAnimBase();
qreal angle()const;
void setAngle(qreal an);
public slots:
virtual void exec();
virtual void start();
virtual void stop();
protected:
QPropertyAnimation mAnim;
qreal mAngle;
};
class TextInBouncingBox:public LoadingAnimBase{
//显示装在上下跳动的盒子里的字符
public:
TextInBouncingBox(const QString & str,QWidget* parent = nullptr);
void setTextColor(const QColor& color);
void setBoxColor(const QColor& color);
protected:
void paintEvent(QPaintEvent*);
private:
QString mText;
QColor mTextColor;
QColor mBoxColor;
};
class ExpandingScroll:public LoadingAnimBase{
//一个圆环转动两圈之后像卷轴一样展示"正在加载"
public:
ExpandingScroll(QWidget* parent = nullptr);
protected:
void paintEvent(QPaintEvent*);
};
#endif
//LoadingAnimWidget.cpp
#include "LoadingAnimWidget.h"
#include <QDebug>
#include <QPaintEvent>
#include <QPainter>
#include <QtMath>
#include <QRandomGenerator>