qt4 – 在QLabel中显示.gif动画

我想在QLabel小部件中显示.gif动画以及文本.

以下代码不起作用:

self.status_txt = QtGui.QLabel('Loading... <img src="etc/loading.gif">')

因为图像不会动画.

我尝试使用QMovie对象来实现它:

self.status_txt = QtGui.QLabel("Loading...")
movie = QtGui.QMovie("etc/loading.gif")
self.status_txt.setMovie(movie)
movie.start()

但后来我无法把动画和文字放在一起.
除了使用两种不同的标签外,还有其他解决方案吗

解决方法

你可以添加一个布局到标签,然后添加一个标签与文本…
self.status_txt = QtGui.QLabel()
movie = QtGui.QMovie("etc/loading.gif")
self.status_txt.setMovie(movie)
movie.start()
self.status_txt.setLayout(QtGui.QHBoxLayout())
self.status_txt.layout().addWidget(QLabel('Loading...'))

编辑:

如果您使用自己版本的QLabel和QPainter自行绘制文本,则可以:

from PyQt4.QtCore import QSize
from PyQt4.QtGui import QApplication,QLabel,QMovie,QPainter,QFontMetrics

class QTextMovieLabel(QLabel):
    def __init__(self,text,fileName):
        QLabel.__init__(self)
        self._text = text
        m = QMovie(fileName)
        m.start()
        self.setMovie(m)

    def setMovie(self,movie):
        QLabel.setMovie(self,movie)
        s=movie.currentimage().size()
        self._movieWidth = s.width()
        self._movieHeight = s.height()

    def paintEvent(self,evt):
        QLabel.paintEvent(self,evt)
        p = QPainter(self)
        p.setFont(self.font())
        x = self._movieWidth + 6
        y = (self.height() + p.fontMetrics().xHeight()) / 2
        p.drawText(x,y,self._text)
        p.end()

    def sizeHint(self):
        fm = QFontMetrics(self.font())
        return QSize(self._movieWidth + 6 + fm.width(self._text),self._movieHeight)

    def setText(self,text):
        self._text = text

if __name__ == '__main__':
    import sys
    app = QApplication(sys.argv)
    l = QTextMovieLabel('Loading...','loading.gif')
    l.show()
    app.exec_()

相关文章

vue阻止冒泡事件 阻止点击事件的执行 &lt;div @click=&a...
尝试过使用网友说的API接口获取 找到的都是失效了 暂时就使用...
后台我拿的数据是这样的格式: [ {id:1 , parentId: 0, name:...
JAVA下载文件防重复点击,防止多次下载请求,Cookie方式快速简...
Mip是什么意思以及作用有哪些