Qt的属性动画和串行动画组结合的先淡入再淡出的小例子

我们先看效果:
在这里插入图片描述
点开“开始”:蝴蝶的透明度从0.5逐渐增加到1,然后又从1逐渐减少到0.5,这样不断循环变化。
点击“结束”按钮,动画停止。
其实这个用属性动画QPropertyAnimation和串行动画组QSequentialAnimationGroup,以及Q_PROPERTY,一起来做,非常简单。
首先我们需要一个变量,来存储图片的透明度:

double m_imageOpacity;

需要它的get和set方法
写法一:

Q_PROPERTY(double imageOpacity READ imageOpacity WRITE setImageOpacity)

private:
    double imageOpacity() const
    {
   
        return m_imageOpacity;
    }

    void setImageOpacity(double value)
    {
   
        m_imageOpacity = value;
    }
    
private:
    double m_imageOpacity;

写法二:

 Q_PROPERTY(double imageOpacity MEMBER m_imageOpacity)
 
private:
    double m_imageOpacity;

两种写法等效,这里我们用写法二。
新建一个基于QWidget的工程

全家福
widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>

QT_BEGIN_NAMESPACE
namespace Ui {
    class Widget; }
QT_END_NAMESPACE

class QSequentialAnimationGroup;
class QPropertyAnimation;

class Widget : public QWidget
{
   
    Q_OBJECT

    Q_PROPERTY(double imageOpacity MEMBER m_imageOpacity)

public:
    Widget(QWidget *parent =
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值