目录
一、布局Layout
1. 布局简介
2. 水平布局QHBoxLayout
3. 竖直布局QVBoxLayout
4. 表单布局QFormLayout
5. 布局嵌套
二、单选框和复选框
1. 单选框
2. 复选框
三、对话框
1. QMessageBox
2. QIputDialog
一、布局Layout
1. 布局简介
一个pyqt窗口中可以有多个控件。所谓布局,指的就是多个控件在窗口中的展示方式
布局方式大致分为:
- 水平布局
- 垂直布局
- 网格布局
- 表单布局
2. 水平布局QHBoxLayout
水平布局中,是按照从左往右的顺序添加控件的
示例代码:
import sysfrom PyQt5.QtWidgets import *# 创建QApplication对象
app = QApplication(sys.argv)# 创建QWidget对象 窗口
w = QWidget()# 创建QHBoxlayout对象
layout = QHBoxLayout()# 添加5个QPushButton控件
layout.addWidget(QPushButton("按钮1"))
layout.addWidget(QPushButton("按钮2"))
layout.addWidget(QPushButton("按钮3"))
layout.addWidget(QPushButton("按钮4"))
layout.addWidget(QPushButton("按钮5"))# 窗口添加布局
w.setLayout(layout)# 设置窗口大小
w.resize(400, 300)# 显示窗口
w.show()# 进入事件循环
sys.exit(app.exec_())
3. 竖直布局QVBoxLayout
竖直布局采用QVBoxLayout,是采用从上往下的方式添加控件的
示例代码:
import sysfrom PyQt5.QtWidgets import *# 创建QApplication对象
app = QApplication(sys.argv)# 创建QWidget对象 窗口
w = QWidget()# 创建QVBoxlayout对象
layout = QVBoxLayout()# 添加5个QPushButton控件
layout.addWidget(QPushButton("按钮1"))
layout.addWidget(QPushButton("按钮2"))
layout.addWidget(QPushButton("按钮3"))
layout.addWidget(QPushButton("按钮4"))
layout.addWidget(QPushButton("按钮5"))# 窗口添加布局
w.setLayout(layout)# 设置窗口大小
w.resize(400, 300)# 显示窗口
w.show()# 进入事件循环
sys.exit(app.exec_())
4. 表单布局QFormLayout
表单布局是label-field
式的表单布局,顾名思义就是实现表单方式的布局
示例代码:
import sysfrom PyQt5.QtWidgets import *# 创建QApplication对象
app = QApplication(sys.argv)# 创建QWidget对象 窗口
w = QWidget()# 创建QFromLayout对象
layout = QFormLayout()# 设置用户名QLineEdit对象
user = QLineEdit()# 设置密码QLineEdit对象
pwd = QLineEdit()
# 设置密码显示为*
pwd.setEchoMode(pwd.Password)# 设计手机号QLineEdit对象
phone = QLineEdit()
# 创建QPushButton对象
btn = QPushButton("注册信息")layout.addRow("用户名:", user)
layout.addRow("密码:", pwd)
layout.addRow("手机号:", phone)
layout.addRow("", btn)# 将layout设置到窗口
w.setLayout(layout)# 自定义槽函数
def on_submit():print("用户名:", user.text())print("密码:", pwd.text())print("手机号:", phone.text())# QPushButton对象信号clicked绑定自定义槽函数on_submit
btn.clicked.connect(on_submit)# 显示窗口
w.show()# 进入事件循环
sys.exit(app.exec_())
5. 布局嵌套
通过布局嵌套可以实现更加复杂的布局
示例代码:
import sysfrom PyQt5.QtWidgets import *# 创建QApplication对象
app = QApplication(sys.argv)# 创建QWidget对象 窗口
w = QWidget()# 1. 创建水平布局,代表最外层
h_layout = QHBoxLayout()
# 2. 创建三个垂直布局,添加到水平布局中
h_layout1 = QHBoxLayout()
v_layout1 = QVBoxLayout()
v_layout2 = QVBoxLayout()
v_layout3 = QVBoxLayout()htb1 = QPushButton("btn1")
htb2 = QPushButton("btn2")h_layout1.addWidget(htb1)
h_layout1.addWidget(htb2)h_layout.addLayout(h_layout1)# 3. 创建两个按钮添加到第一个垂直布局中
btn1 = QPushButton("按钮1")
btn2 = QPushButton("按钮2")v_layout1.addWidget(btn1)
v_layout1.addWidget(btn2)
# 4. 把第一个垂直布局添加到水平布局中
h_layout.addLayout(v_layout1)# 5. 创建三个按钮添加到第二个垂直布局中
vtb3 = QPushButton("按钮3")
vtb4 = QPushButton("按钮4")
vtb5 = QPushButton("按钮5")v_layout2.addWidget(vtb3)
v_layout2.addWidget(vtb4)
v_layout2.addWidget(vtb5)
# 6. 把第二个垂直布局添加到水平布局中
h_layout.addLayout(v_layout2)# 7. 创建四个按钮添加到第三个垂直布局中
vtb6 = QPushButton("按钮6")
vtb7 = QPushButton("按钮7")
vtb8 = QPushButton("按钮8")
vtb9 = QPushButton("按钮9")v_layout3.addWidget(vtb6)
v_layout3.addWidget(vtb7)
v_layout3.addWidget(vtb8)
v_layout3.addWidget(vtb9)
# 8. 把第三个垂直布局添加到水平布局中
h_layout.addLayout(v_layout3)# 9. 把水平布局添加到窗口中
w.setLayout(h_layout)# 设置窗口大小
w.resize(640, 400)# 设置窗口标题
w.setWindowTitle("嵌套布局")# 显示窗口
w.show()# 进入事件循环
sys.exit(app.exec_())
二、单选框和复选框
1. 单选框
QRadioButton
是单选按钮,它提供了一组可供选择的按钮和文本标签,用户可以选择其中一个选项
单选框选中的信号是:toggled
示例代码:
import sysfrom PyQt5.QtWidgets import *# 创建QApplication对象
app = QApplication(sys.argv)# 创建QWidget对象 窗口
w = QWidget()# 创建一个水平布局
layout = QHBoxLayout()# 创建QRadioButton对象,设置内容为男
rb1 = QRadioButton('男')# 创建QRadioButton对象,设置内容为女
rb2 = QRadioButton('女')# 设置为选中状态 默认rb2选中
rb2.setChecked(True)# 将rb1和rb2添加到布局中
layout.addWidget(rb1)
layout.addWidget(rb2)# 设置布局
w.setLayout(layout)# 设置窗口标题
w.setWindowTitle('单选框QRadioButton')# 设置窗口大小
w.resize(100, 50)# 定义按钮点击事件 判断是哪个按钮被点击
def on_toggled():if rb1.isChecked():print('男被选中')elif rb2.isChecked():print('女被选中',rb2.text())# 信号绑定
rb1.clicked.connect(on_toggled)
rb2.clicked.connect(on_toggled)# clicked 信号 当按钮被点击时触发 触发一次
# toggled 信号 当按钮状态发生改变时触发 可以多次触发# 显示窗口
w.show()# 进入事件循环
sys.exit(app.exec_())
如果想给QRadioButton
组设置监听事件,可按照如下代码添加:
# 声明槽函数
def on_group_toggle(btn: QRadioButton):print(btn, btn.isChecked())# 添加两个单选钮到QButtonGroup,并添加选中事件
group = QButtonGroup(w)
group.addButton(btn1)
group.addButton(btn2)
group.buttonToggled.connect(on_group_toggle)
2. 复选框
QCheckBox
提供了一组带文本标签的复选框,用户可以选择多个选项
复选框的状态变化信号是stateChanged
示例代码:
import sysfrom PyQt5.QtWidgets import *# 创建QApplication对象
app = QApplication(sys.argv)# 创建QWidget对象 窗口
w = QWidget()# 创建垂直布局
layout = QVBoxLayout()# 创建QCheckBox对象 复选框
cb1 = QCheckBox("语文")
cb2 = QCheckBox("数学")
cb3 = QCheckBox("英语")# 把复选框添加到layout布局中
layout.addWidget(cb1)
layout.addWidget(cb2)
layout.addWidget(cb3)# 把layout布局添加到窗口中
w.setLayout(layout)# 定义槽函数
def slot():if cb1.isChecked():print("今天上语文课")if cb2.isChecked():print("下节课上数学课")if cb3.isChecked():print("下节课上英语课")# cb1和cb2、cb3的信号statusChanged连接到槽函数
cb1.stateChanged.connect(slot)
cb2.stateChanged.connect(slot)
cb3.stateChanged.connect(slot)# stateChanged 信号 状态改变
# isChecked() 方法 判断是否选中# 显示窗口
w.show()# 进入事件循环
sys.exit(app.exec_())
三、对话框
对话框是为了更好地实现人与程序的交互
对话框主要是完成特定场景下的功能,比如删除确认等
QDialog的子类有QMessageBox
、QFileDialog
、QFontDialog
、QInputDialog
等
1. QMessageBox
QMessageBox是普通的对话框
示例代码:
import sysfrom PyQt5.QtWidgets import *# 创建QApplication对象
app = QApplication(sys.argv)# 创建QWidget对象 窗口
w = QWidget()# 设置按钮对象
# btn = QPushButton("点击抽奖")
btn = QPushButton()# 设置按钮的文本内容
btn.setText("点击抽奖")# 获取内容
print(btn.text())# 指定父对象
btn.setParent(w)def btn_clicked():res = QMessageBox.information(w, "title", "请确认协议内容", QMessageBox.Ok | QMessageBox.Cancel)# print(res)if res == QMessageBox.Ok:print("ok")else:print("error")# btn设置槽函数
btn.clicked.connect(btn_clicked)# 设置弹框标题
w.setWindowTitle("消息对话框")
# 显示窗口
w.show()# 进入事件循环
sys.exit(app.exec_())
2. QIputDialog
QIputDialog是输入对话框,由一个文本框和两个按钮(OK按钮和Cancel按钮)组成
示例代码:
import sysfrom PyQt5.QtWidgets import *# 创建QApplication对象
app = QApplication(sys.argv)# 创建QWidget对象 窗口
w = QWidget()# 创建QVBoxLayout对象
layout = QVBoxLayout()# 创建QLabel对象
label = QLabel('匿名')# # label设置为匿名
# label.setText("匿名")# layout添加label
layout.addWidget(label)
# 创建QPushButton对象
btn = QPushButton('创建角色')# layout添加按钮
layout.addWidget(btn)# 方法
def show_dialog():res, flag = QInputDialog.getText(w, "标题", "请创建角色")print(res, flag)if flag:print("创建角色成功:", res)# btn点击事件, 槽函数中创建QInputDialog对象,获取用户输入的内容,给label设置内容
btn.clicked.connect(show_dialog)# 添加窗口布局
w.setLayout(layout)# 设置窗口标题
w.setWindowTitle('QInputDialog输入对话框')# 显示窗口
w.show()# 进入事件循环
sys.exit(app.exec_())