zoukankan      html  css  js  c++  java
  • QT 显示动态gif图片

    在ui界面添加Qlabel控件,在QLabel中使用QMovie播放gif。

    #include "WaitDialog.h"
    #include<QPainter>
    #include<QMovie>
    
    WaitDialog::WaitDialog(QWidget *parent, QString fileName, int picWidth, int picHeight)
        : QWidget(parent)
    {
        ui.setupUi(this);
    
        m_picWidth = picWidth;
        m_picHeight = picHeight;
        this->setFixedSize(m_picWidth,m_picHeight);
        this->setWindowFlags(Qt::Dialog|Qt::FramelessWindowHint);
        this->setAutoFillBackground(true);
        this->setContentsMargins(0,0,0,0);
        ui.label->setContentsMargins(0,0,0,0);
        QMovie*movie=new QMovie(fileName);
        ui.label->setMovie(movie);
        movie->start();
    }
    
    WaitDialog::~WaitDialog()
    {
    }

    gif图片在release下不显示问题:

      在Qt的目录下有plugins/imageformats这样一个目录,里面有qgif.dll,qjpeg4.dll等动态链接库,当在安装过QT的机器上,这些库能被成功指定调用,所以本机gif能正常显示;

      当是移到其他没有安装QT的机器时,因为找不到这些库文件,所以导致图片无法显示.

    解决方案如下:

      在exe应用程序目录下建立plugins/imageformats文件夹,将需要的图像支持插件拷贝进去;

      在程序源文件main.cpp 的QApplication a(argc, argv);一行前添加如下代码QApplication::addLibraryPath("./plugins");

    另:

    假如使用资源图片显示,例如:

    QMovie* movie = new QMovie(":/display/Resources/loading.gif"); //注意此处路径,可打开qrc 查看图片文件的 resource url,路径需与url一致。

  • 相关阅读:
    sql 保存,性能高
    老生常谈-从输入url到页面展示到底发生了什么
    HTTP 协议入门
    理解HTTP协议
    利用Vue v-model实现一个自定义的表单组件
    浅谈 Vue v-model指令的实现原理
    vuex介绍--一篇看懂vuejs的状态管理神器
    ES6之 =>箭头函数
    position定位-absolute与fixed
    JavaScript:理解事件、事件处理函数、钩子函数、回调函数
  • 原文地址:https://www.cnblogs.com/liuyunfeifei/p/2823289.html
Copyright © 2011-2022 走看看