找回密码
 立即注册
首页 业界区 业界 pyqt图形化显示—3.常用控件

pyqt图形化显示—3.常用控件

浅皮懔 2026-1-20 02:55:00
前面已经能够通过组合构建一个基础的能交互的ui了,接下来就是丰富界面了,一些常用控件走起~
下拉框

界面

首先导入对应库
  1. from PySide6.QtWidgets import  QComboBox, QVBoxLayout
复制代码
QComboBox是下拉框的列表库,QVBoxLayout是垂直布局库,不使用垂直布局没办法表现下拉列表下面就是构建一个下拉框了
  1. cb = QComboBox()  # 创建下拉框cb.addItems(['a','b','c','d'])  # 添加选项        self.setWindowTitle('下拉框')  # 设置窗口标题ml = QVBoxLayout()  # 创建主布局ml.addWidget(cb)  # 将下拉框添加到主布局中self.setLayout(ml)  # 设置主布局
复制代码

界面属性和基础空间一样,可以通过QT Designer找属性设置 
那么页面ui完成,下面就是交互了
信号

常用的有以下两种
  1. cb.currentTextChanged.connect(self.test)cb.currentIndexChanged.connect(self.test)
复制代码
表示选项变化时,发出信号,触发test函数
不过这两个也是有一些细微差别的,返回的内容是有所不同的
我们用test函数测试一下
  1.     def test(self,x):        print('当前选项:', x)
复制代码
currentTextChanged的信号触发时候,会返回选项的内容       
currentIndexChanged的信号触发时,会返回选项在列表的位置【下标】    
当然 由于这个信号是变化时候出发的,也可以使用cb.currentText()读取当前选项选择框

界面

导入库
  1. from PySide6.QtWidgets import QCheckBox, QVBoxLayout
复制代码
QCheckBox就是这个选择框的库啦
界面ui类似于上面的下拉框,不过由于是选择框的形式,只有是否两种状态,所以只能填入一个元素
  1. cb = QCheckBox('测试一下')  # 创建选择框self.setWindowTitle('选择框')  # 设置窗口标题ml = QVBoxLayout()  # 创建主布局ml.addWidget(cb)  # 将选择框添加到主布局中self.setLayout(ml)  # 设置主布局
复制代码
创建选择框,添加得到布局中显示

信号

由于只有是否两种状态,信号上就没有那么花里胡哨了 只有一个
  1. cb.stateChanged.connect(self.test)
复制代码
状态改变就触发对应函数响应,返回值是一个整数
测试了一下这个选择框有结果,选择返回结果为2,不选择返回结果为0【也许还有半选的选项】    
  1. cb.stateChanged.connect(lambda :print(cb.isChecked()))
复制代码
也可以使用cb.isChecked()检测是否被选中,返回值为True和False,选中为True     

单选框

界面

导入库
  1. from PySide6.QtWidgets import QRadioButton, QButtonGroup, QVBoxLayout,
复制代码
QRadioButton库是单选框的库;QButtonGroup是选项按钮组的库,后续解决一些逻辑问题;QVBoxLayout是垂直布局库下面就是单选框的ui设置了
  1.         lb1 = QLabel('表头1')  # 添加选项标题        # 创建选项按钮        btn1 = QRadioButton('选项1')        btn2 = QRadioButton('选项2')        btn3 = QRadioButton('选项3')        ml = QVBoxLayout()  # 创建主布局        # 添加到主布局中        ml.addWidget(lb1)        ml.addWidget(btn1)        ml.addWidget(btn2)        ml.addWidget(btn3)        self.setLayout(ml)  # 设置主布局
复制代码
由于是单选框那么就出现非此即彼的关系如下图,我只能在三个选项中选择一个  

但只是如同上图一样一个表头三个选项那还好,如果两个表头,三个表头,我需要在多个问题中选择答案,那么这个非此即彼的关系就会让我们的选项总是只存在一个。关于这个逻辑问题就需要QButtonGroup来解决了,把特定的按钮进行组合,在这个组合内存在非此即彼的关系,与组合外无关。
  1.         self.group1 = QButtonGroup(self)  # 创建单选框组        lb1 = QLabel('表头1')  # 添加选项标题        # 创建选项按钮        btn1 = QRadioButton('选项1')        btn2 = QRadioButton('选项2')        btn3 = QRadioButton('选项3')          # 添加选项到单选框组中        self.group1.addButton(btn1)        self.group1.addButton(btn2)        self.group1.addButton(btn3)        # 创建布局        h1 = QVBoxLayout()  # 创建布局        # 添加到布局中        h1.addWidget(lb1)        h1.addWidget(btn1)        h1.addWidget(btn2)        h1.addWidget(btn3)        ml = QVBoxLayout()  # 创建主布局        ml.addLayout(h1)  # 布局添加到主布局中        self.setLayout(ml)  # 设置主布局
复制代码
View Code通过self.组合名 = QButtonGroup(self)创建按钮组合,self.组合名.addButton(按钮名)把按钮添加到组合内,实现组合内的逻辑关系
虽然界面是一致的,但多个表头的逻辑关系已经发生了区分
checkedButton 函数查看按钮是否被选中,有时候也是有用的
信号

由于上述已经将对应按钮进行了分组,那么我们可以直接对组进行信号处理
  1. self.group1.buttonClicked.connect(self.test)
复制代码
self.组合名.buttonClicked.connect(响应函数) 作用是该组合按钮被点击,触发对应函数响应,返回值是按钮名称地址,需要转换一下得到按钮有名称    
  1.     def test(self,x):        print(x.text())
复制代码
 文本框

文本框一般有两种形式一种是富文本框(QTextEdit),类似于ppt那种文本框可以插入图片,表格啊甚至HTML格式;另一种是纯文本框(QPlainTextEdit),只应用于纯文本。两者各有优劣,前者文本框内容表现更丰富,但相对的占用的资源就多;后者纯文本,对于大量文本处理响应更快
界面

导入库
  1. from PySide6.QtWidgets import QTextEdit, QPlainTextEdit
复制代码
已经介绍了一个是富文本框,一个是纯文本框
下面就是设置和属性部分了,作为对比两个文本框同时显示,上面为富文本框,下面为纯文本框
  1.         text1 = QTextEdit()  # 创建文本框        text1.setHtml('[size=6]标题[/size]
  2. [b]加粗[/b][i]斜体[/i][u]下划线[/u]')        #text1.setMarkdown('# 标题\n**加粗** *斜体* _下划线_')        #text1.setText('测试一下')        #text1.setPlainText('测试一下')        text2 = QPlainTextEdit()  # 创建文本框        text2.setPlainText('[size=6]标题[/size]
  3. [b]加粗[/b][i]斜体[/i][u]下划线[/u]')        ml = QVBoxLayout()  # 创建主布局        ml.addWidget(text1)  # 添加到主布局中        ml.addWidget(text2)        self.setLayout(ml)  # 设置主布局
复制代码
文本框

通过对比就可以发现两者的区别,同样的在属性上富文本框的属性会更多一些,超链接啊,图片啊等等,可以在文档中查到
.appendPlainText('xx')  在文本框结尾添加文本 ‘xx’
.clear() 清除 等等等等信号

常用的就一个textChanged 文本变化时触发响应,无返回值
滑条

界面

导入库
  1. from PySide6.QtWidgets import QSliderfrom PySide6.QtCore import Qt #枚举类需要使用
复制代码
下面就是设置参数和属性了
  1. sd = QSlider(Qt.Orientation.Horizontal)  # 创建水平滑条sd.setTickPosition(QSlider.TickPosition.TicksRight)  # 设置滑条刻度位置sd.setTickInterval(10)  # 设置滑条刻度间隔sd.setMinimum(0)  # 设置滑条的最小值sd.setMaximum(100)  # 设置滑条的最大值# sd.setRange(0, 100)  # 设置滑条的范围sd.setSingleStep(5)  # 设置滑条的单步值sd.setValue(50)  # 设置滑条的初始值
复制代码
设置完成后添加到布局内显示

 QSlider  如果不设置那么结果为垂直滑条
setTickPosition  可以设置刻度的位置参数如下  参数:   NoTicks      ——>无刻度      TicksBothSides  ——>两侧刻度      TicksAbove      ——>上侧刻度      TicksBelow      ——>下侧刻度      TicksLeft     ——>左侧刻度      TicksRight        ——>右侧刻度信号
  1. sd.valueChanged.connect(self.test)  # 连接滑条的valueChanged信号到槽函数
复制代码
数值发生改变时候,对应函数响应
  1.     def test(self):        widget = self.sender()  # 获取发送信号的对象        print(f'滑条的值已改变:{widget.value()}')
复制代码
注意返回值是对应的刻度数值

self.sender() 用于获取该信号是由那个变量发送的,方便大型项目多个同类型变量的逻辑处理 

来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

相关推荐

您需要登录后才可以回帖 登录 | 立即注册