1

有没有办法连续更新 QLabel (或其他)的工具提示?

例如,以下代码使用一个不断更新标签及其工具提示的计时器。虽然我可以看到标签更改,但如果我将鼠标悬停在 QLabel 上,我将获得一个带有最后一个当前值的工具提示。工具提示保持“固定”,直到我移动鼠标,这会将工具提示更新为新值。

!/usr/bin/env python
# -*- coding: utf-8 -*-
import sys
from PySide import QtGui, QtCore

class Example(QtGui.QWidget):
    def __init__(self):
        super(Example, self).__init__()
        self.value=0
        self.initUI()
    def initUI(self):      
        hbox = QtGui.QHBoxLayout(self)
        self.lbl = QtGui.QLabel(self)
        self.lbl.setText("foo")
        self.lbl.setToolTip("bar")
        self.timer = QtCore.QBasicTimer()
        self.timer.start(100, self)
        hbox.addWidget(self.lbl)
        self.setLayout(hbox)
        self.show()
    def timerEvent(self, x):
        self.value=self.value+1
        self.lbl.setText("foo: %03d" % self.value)
        self.lbl.setToolTip("bar: %03d" % self.value)

if __name__ == '__main__':
    app = QtGui.QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

有没有一种无需移动鼠标即可更新工具提示的方法?

4

2 回答 2

2

嗯,这并不容易,但这里是应该做你想做的代码:

!/usr/bin/env python
# -*- coding: utf-8 -*-
import sys
from PySide import QtGui, QtCore

class Example(QtGui.QWidget):
    def __init__(self):
        super(Example, self).__init__()
        self.initUI()
    def initUI(self):      
        hbox = QtGui.QHBoxLayout(self)
        self.lbl = MyLabel(self)
        self.lbl.setText("foo")
        self.lbl.setToolTip("bar")
        hbox.addWidget(self.lbl)
        label2 = QtGui.QLabel('another label')
        hbox.addWidget(label2)
        label2.setToolTip('a normal tooltip')
        self.setLayout(hbox)
        self.show()


class MyLabel(QtGui.QLabel):
    def __init__(self,*args,**kwargs):
        QtGui.QLabel.__init__(self,*args,**kwargs)
        self._timer = QtCore.QBasicTimer()
        self._timer.start(100, self)
        self._value = 0
        self._last_event_pos = None

    def event(self,event):
        if event.type() == QtCore.QEvent.ToolTip:
            self._last_event_pos = event.globalPos()
            return True
        elif event.type() == QtCore.QEvent.Leave:
            self._last_event_pos = None
            QtGui.QToolTip.hideText()
        return QtGui.QLabel.event(self,event)

    def timerEvent(self, x):
        self._value += 1
        if self._last_event_pos:
            QtGui.QToolTip.hideText()
            QtGui.QToolTip.showText(self._last_event_pos, "bar: %03d" % self._value)
        self.setText("foo: %03d" % self._value)


if __name__ == '__main__':
    app = QtGui.QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())
于 2013-10-19T04:10:03.890 回答
0

所以遵循@three_pineapples 最初的建议,这就是我想出的:

  • 覆盖setToolTip()要调用的函数hideText();showText(),但仅
  • 如果鼠标指针当前悬停在标签上(在 中检测到event()

这是代码:

class MyLabel(QtGui.QLabel):
    def __init__(self,*args,**kwargs):
        QtGui.QLabel.__init__(self,*args,**kwargs)
        self._setToolTip=QtGui.QLabel.setToolTip
        self._last_event_pos = None
        self._tooltip=QtGui.QLabel.toolTip(self)
    def event(self,event):
        if event.type() == QtCore.QEvent.ToolTip:
            self._last_event_pos = event.globalPos()
            return True
        elif event.type() == QtCore.QEvent.Leave:
            self._last_event_pos = None
            QtGui.QToolTip.hideText()
        return QtGui.QLabel.event(self,event)
    def setToolTip(self, tt):
        self._setToolTip(self, tt)
        if self._last_event_pos:
            QtGui.QToolTip.hideText()
            QtGui.QToolTip.showText(self._last_event_pos,
                                    QtGui.QLabel.toolTip(self))
于 2014-09-24T17:11:55.963 回答