(6)-圆角图片+边框动态闪烁

本文介绍了两种在Qt中实现圆角图片并添加边框动态闪烁的方法。第一种方法使用QPainter进行图片裁剪,推荐使用;第二种方法通过设置位图蒙版实现,但由于存在锯齿问题,建议尝试使用图片作为蒙版。
摘要由CSDN通过智能技术生成

话不多说先看图:
在这里插入图片描述
**第一种方法:**利用Qpainter裁剪图片,没什么毛病,推荐。
**第二种方法:**利用位图setMask()设置蒙版的方法(仔细看图片有锯齿,未解决,可以不用位图,试试用图片做蒙版)

MainWindow.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>
#include <QGraphicsDropShadowEffect>
#include <QPropertyAnimation>

QT_BEGIN_NAMESPACE
namespace Ui {
    class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
   
    Q_OBJECT
    Q_PROPERTY(int borderRadius READ getBorderRadius WRITE setBorderRadius)
public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();
private:

    void init();
protected:
    QPixmap scaledPixmap(const QPixmap &src,int width,int height);      // 压缩图片为指定宽高
    QPixmap generatePixmap(const QPixmap &src,const int &radius);       // 实现圆角图片
    QPixmap pixmapToRound(const QPixmap &src,const int &radius);        // mask实现圆角图片
    int getBorderRadius() const;
    void setBorderRadius(const int radius);

private:
    QGraphicsDropShadowEffect *m_labelDrawShadowEffect;                 // labelDraw边框阴影
    QGraphicsDropShadowEffect *m_labelMaskShadowEffect;                 // labelMask边框阴影
    QPropertyAnimation *m_labelDrawAnimation;
    QPropertyAnimation *m_labelMaskAnimation;
    int m_borderRadius;

private:
    Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H

MainWindow.cpp

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QPainter>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值