当前位置: 移动技术网 > IT编程>脚本编程>Python > PyQt5每天必学之滑块控件QSlider

PyQt5每天必学之滑块控件QSlider

2019年06月17日  | 移动技术网IT编程  | 我要评论

森蓝传奇,kgservice.exe,余姚生活网信息广场

qslider 是一个具有可来回拉动手柄的控件。有时使用滑块比输入数字或使用旋转框更方便。

在我们的例子中,我们将创建一个滑块和一个标签。标签显示图像。滑块将控制标签显示的图像。

#!/usr/bin/python3
# -*- coding: utf-8 -*-

"""
pyqt5 教程

这个例子显示了一个qslider控件的使用方法。

作者:我的世界你曾经来过
博客:http://blog.csdn.net/weiaitaowang
最后编辑:2016年8月3日
"""

import sys
from pyqt5.qtwidgets import qapplication, qwidget, qlabel, qslider
from pyqt5.qtgui import qpixmap
from pyqt5.qtcore import qt

class example(qwidget):

 def __init__(self):
  super().__init__()

  self.initui()

 def initui(self):

  sld = qslider(qt.horizontal, self)
  sld.setfocuspolicy(qt.nofocus)
  sld.setgeometry(30, 40, 100, 30)
  sld.valuechanged[int].connect(self.changevalue)

  self.label = qlabel(self)
  self.label.setpixmap(qpixmap('f:\python\pyqt5\widgets\images\mute.png'))
  self.label.setgeometry(160, 30, 80, 50)

  self.setgeometry(300, 300, 280, 170)
  self.setwindowtitle('滑块控件')  
  self.show()

 def changevalue(self, value):

  if value == 0:
   self.label.setpixmap(qpixmap('f:\python\pyqt5\widgets\images\mute.png'))
  elif value > 0 and value <= 30:
   self.label.setpixmap(qpixmap('f:\python\pyqt5\widgets\images\min.png'))
  elif value > 30 and value < 80:
   self.label.setpixmap(qpixmap('f:\python\pyqt5\widgets\images\med.png'))
  else:
   self.label.setpixmap(qpixmap('f:\python\pyqt5\widgets\images\max.png'))

if __name__ == '__main__':

 app = qapplication(sys.argv)
 ex = example()
 sys.exit(app.exec_())


在我们的例子中,我们模拟音量控制。通过拖动滑块的手柄,我们改变标签上的图像。

sld = qslider(qt.horizontal, self)

创建一个水平滑块 qslider

self.label = qlabel(self)
self.label.setpixmap(qpixmap('f:\python\pyqt5\widgets\images\mute.png'))

创建一个标签 qlabel 控件并设置要显示的初始图像

sld.valuechanged[int].connect(self.changevalue)

将滑块的 valuechanged 信号连接到 changevalue() 方法(槽)

if value == 0:
 self.label.setpixmap(qpixmap('f:\python\pyqt5\widgets\images\mute.png'))

我们根据滑块的值设置标签上的图像。在上面的代码中,如果滑块等于零标签的图像设置为mute.png。

程序执行后

这里写图片描述 这里写图片描述

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网