如何使用PyQT提示跟随滑块的处理程序?

时间:2015-07-27 12:53:38

标签: python-2.7 qt pyqt pyqt4 qslider

一个简单的问题,我正在寻找像pyqt这样的效果:

Jquery UI slider how to make a box follow the handler?

但是这些代码是JQuery,我试图用PyQT实现它

import sys
from PyQt4 import QtGui, QtCore

class Window(QtGui.QMainWindow):

    def __init__(self):
        super(Window, self).__init__()
        self.setGeometry(50, 50, 500, 500)
        self.setWindowTitle("PyQT example!")
        slider = QtGui.QSlider(self)
        slider.setOrientation(QtCore.Qt.Horizontal)
        slider.move(50, 50)
        slider.valueChanged.connect(self.value_changed)
        self.show()

    def value_changed(self, value):
        QtGui.QToolTip.showText(QtGui.QCursor.pos(), str(value), self)

app = QtGui.QApplication(sys.argv)
GUI = Window()
sys.exit(app.exec_())

此代码成功制作了提示气球跟随光标。 现在是否可以使提示跟随我的滑块处理程序?

2 个答案:

答案 0 :(得分:4)

我喜欢@ tmoreau的想法,但最好将新逻辑放入QSlider的子类中:

class TipSlider(QtGui.QSlider):
    def __init__(self, *args, tip_offset=QPoint(0, -45)):
        super(QtGui.QSlider, self).__init__(*args)
        self.tip_offset = tip_offset

        self.style = QtGui.QApplication.style()
        self.opt = QtGui.QStyleOptionSlider()

        self.valueChanged.connect(self.show_tip)
        # self.enterEvent = self.show_tip
        # self.mouseReleaseEvent = self.show_tip

    def show_tip(self, _):
        self.initStyleOption(self.opt)
        rectHandle = self.style.subControlRect(self.style.CC_Slider, self.opt, self.style.SC_SliderHandle)

        pos_local = rectHandle.topLeft() + self.tip_offset
        pos_global = self.mapToGlobal(pos_local)
        QtGui.QToolTip.showText(pos_global, str(self.value()), self)

答案 1 :(得分:3)

你的问题并不那么简单。这是我不完美的解决方案:

  1. 首先,我们需要跟踪QSlider,因此您需要将所有slider替换为self.slider

  2. QSlider,我们可以提取包含句柄的矩形:

    style=self.slider.style()
    opt=QtGui.QStyleOptionSlider()
    self.slider.initStyleOption(opt)
    rectHandle=style.subControlRect(QtGui.QStyle.CC_Slider,opt, QtGui.QStyle.SC_SliderHandle,self)
    
  3. rectHandle是一个QRect,有多种方法可以获得以像素为单位的位置。
    你可以int QRect.bottom()QRect.right() ...或QPoint QRect.center()QRect.bottomRight ......所有职位都会相对于父窗口小部件,这里是滑块 例如,要获得矩形右下角的绝对位置,您可以执行以下操作:

    myPoint=rectHandle.bottomRight()+self.slider.pos()
    
  4. 改进:找到工具提示的正确位置
    我最好的尝试,有一些神奇的数字:

    magicX = 5
    magicY = 15
    
    x = rectHandle.right() + rectHandle.width() + self.slider.pos().x() + magicX
    y = rectHandle.bottom() + rectHandle.height() + self.slider.pos().y() + magicY
    
  5. 当然,我们需要在我们的自定义位置显示工具提示:

    QtGui.QToolTip.showText(QtCore.QPoint(x,y), str(value), self)
    
  6. NB: 所有计算都是在value_changed方法中完成的。