一、效果展示
二、功能包安装与使用
1.安装QtDesigner
在虚拟环境下输入:
pip install PyQt5Designer
完成安装
2.启动QtDesigner
在终端下输入designer.exe
打开界面编辑器,并选择建立一个主窗口。
保存当前设计文档为demo06.ui到一个文件夹下。
三、设计界面
1.布局
拖动一个标签Label和一个PushButton,合理排版如下图所示,双机相应的控件可以修改其展示的文字,这里我将label展示一个Hello World!:
2.修改控件属性
修改Label控件的objectName名字为HelloworldLabel,如下:
修改PushButton控件的objectName名字为click_me_Button,如下:
3.ui转py文件
在ui文件的终端下输入如下指令,可以将ui文件转换成py文件。
pyuic5 -x demo06.ui -o demo06.py
此时在ui文件的同一目录下多了一个同名的py文件。注意:这个py文件是每次执行上述指令会被更新的。所以如果要对这个py文件进行修改,最好复制到另一个地方。以防下次进行ui转py的时候将修改过的py文件更新掉。
4.修改py文件
我们在Ui_MainWindow类中建立一个press_it()方法,用来响应按钮按下。
def press_it(self):
self.HelloworldLabel.setText("Clicked")
在大约20行处,为新建的按钮添加按钮按下的响应函数接口press_it():
self.click_me_Button = QtWidgets.QPushButton(self.centralwidget,clicked=lambda :self.press_it())
执行demo06.py文件,出现文章开头的效果展示图。
三、源代码
demo06.py文件内容
# -*- coding: utf-8 -*-
# Form implementation generated from reading ui file 'demo06.ui'
#
# Created by: PyQt5 UI code generator 5.15.4
#
# WARNING: Any manual changes made to this file will be lost when pyuic5 is
# run again. Do not edit this file unless you know what you are doing.
from PyQt5 import QtCore, QtGui, QtWidgets
class Ui_MainWindow(object):
def setupUi(self, MainWindow):
MainWindow.setObjectName("MainWindow")
MainWindow.resize(351, 304)
self.centralwidget = QtWidgets.QWidget(MainWindow)
self.centralwidget.setObjectName("centralwidget")
self.click_me_Button = QtWidgets.QPushButton(self.centralwidget,clicked=lambda :self.press_it())
self.click_me_Button.setGeometry(QtCore.QRect(40, 130, 261, 111))
self.click_me_Button.setObjectName("click_me_Button")
self.HelloworldLabel = QtWidgets.QLabel(self.centralwidget)
self.HelloworldLabel.setGeometry(QtCore.QRect(10, 0, 331, 131))
font = QtGui.QFont()
font.setFamily("Adobe Caslon Pro")
font.setPointSize(18)
self.HelloworldLabel.setFont(font)
self.HelloworldLabel.setLayoutDirection(QtCore.Qt.LeftToRight)
self.HelloworldLabel.setAlignment(QtCore.Qt.AlignCenter)
self.HelloworldLabel.setObjectName("HelloworldLabel")
MainWindow.setCentralWidget(self.centralwidget)
self.menubar = QtWidgets.QMenuBar(MainWindow)
self.menubar.setGeometry(QtCore.QRect(0, 0, 351, 26))
self.menubar.setObjectName("menubar")
MainWindow.setMenuBar(self.menubar)
self.statusbar = QtWidgets.QStatusBar(MainWindow)
self.statusbar.setObjectName("statusbar")
MainWindow.setStatusBar(self.statusbar)
self.retranslateUi(MainWindow)
QtCore.QMetaObject.connectSlotsByName(MainWindow)
def press_it(self):
self.HelloworldLabel.setText("Clicked")
def retranslateUi(self, MainWindow):
_translate = QtCore.QCoreApplication.translate
MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
self.click_me_Button.setText(_translate("MainWindow", "Click Me!"))
self.HelloworldLabel.setText(_translate("MainWindow", "Hello World!!!"))
if __name__ == "__main__":
import sys
app = QtWidgets.QApplication(sys.argv)
MainWindow = QtWidgets.QMainWindow()
ui = Ui_MainWindow()
ui.setupUi(MainWindow)
MainWindow.show()
sys.exit(app.exec_())