高分辨率问题

当程序运行在不同分辨率的电脑上时,由于缩放的问题会导致UI布局与设计的不一样,甚至有些控件上的字显示不全。

  • 设计的ui:

01pyqt5 + designer 初步 - 图1

  • 实际显示的ui:

01pyqt5 + designer 初步 - 图2

  • 解决方法:

在程序运行前添加一行代码

  1. QtCore.QCoreApplication.setAttribute(QtCore.Qt.AA_EnableHighDpiScaling)
  • 结果:

01pyqt5 + designer 初步 - 图3

完美

  • 参考链接:

https://zhuanlan.zhihu.com/p/401503085

pyqt5 加载UI的两种方法

静态加载(ui转换为py文件)

该方法需要用到pyqt5自带的一个工具pyuic5,pip安装pyqt5时自动安装,若没有则需要安装一下pyqt5-tool

该工具会将ui文件转为python的一个类,我们的程序需要加载该类

  1. from PyQt5 import QtCore, QtGui, QtWidgets
  2. class Ui_MainWindow(object):
  3. def setupUi(self, MainWindow):
  4. MainWindow.setObjectName("MainWindow")
  5. MainWindow.resize(800, 600)
  6. self.centralwidget = QtWidgets.QWidget(MainWindow)
  7. self.centralwidget.setObjectName("centralwidget")
  8. self.pushButton = QtWidgets.QPushButton(self.centralwidget)
  9. self.pushButton.setGeometry(QtCore.QRect(540, 460, 75, 23))
  10. self.pushButton.setObjectName("pushButton")
  11. self.plainTextEdit = QtWidgets.QPlainTextEdit(self.centralwidget)
  12. self.plainTextEdit.setGeometry(QtCore.QRect(240, 120, 311, 211))
  13. self.plainTextEdit.setObjectName("plainTextEdit")
  14. MainWindow.setCentralWidget(self.centralwidget)
  15. self.menubar = QtWidgets.QMenuBar(MainWindow)
  16. self.menubar.setGeometry(QtCore.QRect(0, 0, 800, 22))
  17. self.menubar.setObjectName("menubar")
  18. MainWindow.setMenuBar(self.menubar)
  19. self.statusbar = QtWidgets.QStatusBar(MainWindow)
  20. self.statusbar.setObjectName("statusbar")
  21. MainWindow.setStatusBar(self.statusbar)
  22. self.retranslateUi(MainWindow)
  23. QtCore.QMetaObject.connectSlotsByName(MainWindow)
  24. def retranslateUi(self, MainWindow):
  25. _translate = QtCore.QCoreApplication.translate
  26. MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
  27. self.pushButton.setText(_translate("MainWindow", "PushButton"))

优缺点:

加载时速度快,方便代码语法自动补全

每次都要重新生成一下py文件

动态加载(直接加载ui文件)

  1. import sys
  2. from PyQt5.QtWidgets import QApplication,QMainWindow
  3. from PyQt5 import uic
  4. # 动态载入
  5. class mainwindow(QMainWindow):
  6. def __init__(self):
  7. super().__init__()
  8. # PyQt5
  9. self.ui=uic.loadUi("main.ui")
  10. # 这里与静态载入不同,使用 self.ui.show()
  11. # 如果使用 self.show(),会产生一个空白的 MainWindow
  12. self.ui.show()
  13. if __name__=="__main__":
  14. app=QApplication(sys.argv)
  15. window=mainwindow()
  16. sys.exit(app.exec_())

优缺点:

加载方便

不支持代码补全和相关关键字高亮

参考链接:

https://blog.csdn.net/weixin_42309199/article/details/116069560

静态加载方法在修改UI文件后需要重新添加用户代码问题

为了避免修改UI文件都要重新添加用户代码的问题,采用继承的方法重构python代码

这样就可以不用在pyuic5生成的文件里面修改,直接在自己代码中修改

  1. import main_ui #加载ui
  2. from PyQt5 import QtWidgets,QtCore
  3. import sys
  4. class my_Ui_MainWindow(main_ui.Ui_MainWindow): #继承自Ui_MainWindow类
  5. def __init__(self,my_MainWindow):
  6. super().setupUi(my_MainWindow)
  7. self.pushButton.clicked.connect(self.helloworld)#将按钮点击事件和helloworld函数绑定
  8. def helloworld(self):#label上显示文字hello world
  9. self.plainTextEdit.appendPlainText("hello world")
  10. if __name__ == "__main__":
  11. QtCore.QCoreApplication.setAttribute(QtCore.Qt.AA_EnableHighDpiScaling) #适配高分辨率
  12. app = QtWidgets.QApplication(sys.argv) # 创建一个QApplication,也就是你要开发的软件app
  13. MainWindow = QtWidgets.QMainWindow() # 创建一个QMainWindow,用来装载你需要的各种组件、控件
  14. ui = my_Ui_MainWindow(MainWindow) # ui是Ui_MainWindow()类的实例化对象
  15. # ui.setupUi(MainWindow) # 执行类中的setupUi方法,方法的参数是第二步中创建的QMainWindow
  16. MainWindow.show() # 执行QMainWindow的show()方法,显示这个QMainWindow
  17. sys.exit(app.exec_()) # 使用exit()或者点击关闭按钮退出QApplication

自己定义一个类,加载pyqt5的主窗口类,然后继承

运行结果:

01pyqt5 + designer 初步 - 图4