我想在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()
但是我不能把动画和文字放在一起。 除了使用两个不同的标签之外,还有其他解决方案吗?
答案 0 :(得分:18)
您可以在标签上添加一个布局,然后添加另一个带有文本的标签......
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_()
答案 1 :(得分:1)
我发现没有办法为这项工作使用相同的小部件。必须使用两个不同的QLabel。
答案 2 :(得分:1)
简短,直截了当:
movie = QtGui.QMovie('file.gif')
my_label.setMovie(movie)
movie.start()
请注意,这种情况下的import语句为from PyQt5 import QtCore, QtGui, QtWidgets
,这是Qt Designer生成的默认语句。