日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

Qt动画之鼠标水滴点击效果

發(fā)布時(shí)間:2024/1/8 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Qt动画之鼠标水滴点击效果 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

一、簡(jiǎn)述

前幾天在群里看見(jiàn)有個(gè)小伙伴用的一款gif錄屏軟件有一個(gè)類(lèi)似水滴的點(diǎn)擊效果。于是想了想,便開(kāi)始了Code。思路也很簡(jiǎn)單,就是借助Qt的動(dòng)畫(huà)類(lèi)QVariantAnimation然后不斷重繪達(dá)到點(diǎn)擊的動(dòng)畫(huà)效果,先看一下效果圖。

二、代碼之路

WaterDrop.h

#include <QtWidgets/QWidget> #include <QVariantAnimation>class WaterDrop : public QWidget {Q_OBJECTpublic:WaterDrop(QWidget *parent = Q_NULLPTR);~WaterDrop();void show();void move(const QPoint &point);void setColor(QColor color);private:void paintEvent(QPaintEvent *event); public slots:void onRaduisChanged(QVariant value);private:QVariantAnimation* m_waterDropAnimation;// 水滴變化的半徑;int m_animationRadius;// 水滴的顏色;QColor m_waterDropColor; };

WaterDrop.cpp

#include "WaterDrop.h" #include <QPainter>// 水滴的半徑; #define WATER_DROP_RADIUS 15WaterDrop::WaterDrop(QWidget *parent): QWidget(parent), m_waterDropAnimation(NULL), m_animationRadius(0), m_waterDropColor(QColor(255, 120, 0, 150)) // 默認(rèn)為橘黃色; {this->setFixedSize(QSize(WATER_DROP_RADIUS * 2, WATER_DROP_RADIUS *2));this->setWindowFlags(Qt::FramelessWindowHint | Qt::Tool);this->setAttribute(Qt::WA_TranslucentBackground);// 控件顯示完關(guān)閉后自動(dòng)刪除;this->setAttribute(Qt::WA_DeleteOnClose);m_waterDropAnimation = new QVariantAnimation(this); }WaterDrop::~WaterDrop() { }void WaterDrop::move(const QPoint &point) {// 這里要把鼠標(biāo)點(diǎn)擊的點(diǎn)轉(zhuǎn)換為圓心點(diǎn)坐標(biāo);QPoint translatePoint = point - QPoint(WATER_DROP_RADIUS, WATER_DROP_RADIUS);__super::move(translatePoint); }void WaterDrop::show() {QWidget::show();// 通過(guò)動(dòng)畫(huà)類(lèi)不斷進(jìn)行重繪;m_waterDropAnimation->setStartValue(0);m_waterDropAnimation->setEndValue(WATER_DROP_RADIUS);m_waterDropAnimation->setDuration(350);connect(m_waterDropAnimation, &QVariantAnimation::valueChanged, this, &WaterDrop::onRaduisChanged);connect(m_waterDropAnimation, &QVariantAnimation::finished, this, &WaterDrop::close);m_waterDropAnimation->start();} // 設(shè)置水滴的顏色; void WaterDrop::setColor(QColor color) {m_waterDropColor = color; } // 繪制鼠標(biāo)的水滴點(diǎn)擊效果; void WaterDrop::paintEvent(QPaintEvent *event) {QPainter painter(this);painter.setRenderHint(QPainter::Antialiasing);painter.setPen(Qt::NoPen);painter.setBrush(QBrush(m_waterDropColor));// 思路就是先繪制一個(gè)固定大小的圓A,然后繪制同一圓心的透明的圓B,然后通過(guò)動(dòng)畫(huà)類(lèi)是圓B的半徑從0增長(zhǎng)到WATER_DROP_RADIUS,以致覆蓋固定的圓A;QPainterPath waterDropPath;waterDropPath.addEllipse(QPoint(WATER_DROP_RADIUS, WATER_DROP_RADIUS), WATER_DROP_RADIUS, WATER_DROP_RADIUS);QPainterPath hidePath;hidePath.addEllipse(QPoint(WATER_DROP_RADIUS, WATER_DROP_RADIUS), m_animationRadius, m_animationRadius);waterDropPath -= hidePath;painter.drawPath(waterDropPath); }void WaterDrop::onRaduisChanged(QVariant value) {// 不斷增加圓B的半徑值,并重繪;m_animationRadius = value.toInt();update(); }

測(cè)試代碼

// 新建一窗口類(lèi),重寫(xiě)mousePressEvent事件即可; void MyWidget::mousePressEvent(QMouseEvent *event) {QPoint cursorPos = event->pos();qDebug() << "mousePressEvent" << cursorPos;WaterDrop* waterDrop = new WaterDrop();waterDrop->move(this->mapToGlobal(cursorPos));waterDrop->setColor(Qt::green);waterDrop->show(); }

總結(jié)

以上是生活随笔為你收集整理的Qt动画之鼠标水滴点击效果的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。