QT 控件闪烁效果


widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QDebug>
#include <QVariantAnimation>
#include <QGraphicsDropShadowEffect>
#include <QPropertyAnimation>

QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = nullptr);
    ~Widget();

private slots:
    void on_toolButton_clicked();

    void on_toolButton_2_clicked();

private:
    Ui::Widget *ui;

    QVariantAnimation *shadowEffectAnimation;
};
#endif // WIDGET_H

widget.cpp
 

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
   ui->setupUi(this);
   // 设置边框阴影
   QGraphicsDropShadowEffect * shadowEffect = new QGraphicsDropShadowEffect(this);
   shadowEffect->setColor(Qt::red);
   shadowEffect->setOffset(0,0);
   shadowEffect->setBlurRadius(0);
   ui->label->setStyleSheet(".QLabel{background-color:#FFFFFF;border-radius:3px;}");
   ui->label->setGraphicsEffect(shadowEffect);

   // 创建动画
   shadowEffectAnimation = new QVariantAnimation(this);
   shadowEffectAnimation->setDuration(1000);
   shadowEffectAnimation->setKeyValueAt(0, 0);
   shadowEffectAnimation->setKeyValueAt(0, 100);
   shadowEffectAnimation->setKeyValueAt(1, 0);
   shadowEffectAnimation->setLoopCount(-1);
   connect(shadowEffectAnimation, &QVariantAnimation::valueChanged, this, [=](QVariant value) {
       auto radius = value.toInt();
       if (shadowEffect) {
           shadowEffect->setBlurRadius(radius);
       }
   });
}

Widget::~Widget()
{
    delete ui;
}


void Widget::on_toolButton_clicked()
{
    shadowEffectAnimation->start();
}

void Widget::on_toolButton_2_clicked()
{
    shadowEffectAnimation->stop();
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值