#include <QMovie>
#include <QLabel>
#include <QMouseEvent>
#include <QLine>
QLabel *label_g ;
QMovie *movie ;
{
label_g = new QLabel(main_widget);
label_g->setAttribute(Qt::WA_TranslucentBackground);
movie = new QMovie(":/tu/ggit.gif");//加载gif图片
//设置label自动适应gif的大小
label_g->setScaledContents(true);
label_g->setMovie(movie);
//这里为了调用move方便,进行resize,需要知道的是gif的大小本来也就是150*150
label_g->resize(180,180);
label_g->setStyleSheet("background-color:rgba(0,0,0,0);");
//设置鼠标穿透
label_g->setAttribute(Qt::WA_TransparentForMouseEvents, true);
//绑定QMovie的信号,判断gif播放次数
connect(movie, &QMovie::frameChanged, [=](int frameNumber) {
if (frameNumber == movie->frameCount() - 1)//gif播放次数为1,关闭标签
label_g->close();
});
}
void menuWidget::mousePressEvent(QMouseEvent *e)
{
if (e->button() == Qt::LeftButton) {
//让label的中心在当前鼠标双击位置
label_g->move(e-&
QT 鼠标点击动态纹波GUI设计,鼠标点击水纹
于 2024-03-07 20:08:25 首次发布
本文介绍了如何在Qt应用中使用QMovie和QLabel控件加载GIF图片,并通过信号槽机制实现鼠标左键点击时在指定位置播放并自动关闭的动画效果。

最低0.47元/天 解锁文章
619

被折叠的 条评论
为什么被折叠?



