awagink 发表于 2021-1-4 16:05:34

PyQt5显示对话框Dialog及在对话框中显示内容的两种方法代码直接写dialog方法和ui设计法实例

Table of Contents

方法一:用Python代码编写一个对话框类然后显示

方法二:用QtDesigner设计一个对话框UI然后让其显示

总结

PyQt5对话框有很多种,从PyQt5类关系图中可以看出,常用的有QMessageBox, QInputDialog,QFontDialog, QFileDialog, QColorDialog等。本文主要是用两种方法来演示如何显示一个普通的对话框。代码本质是一样的,大家可以根据需要自由发挥。

​​​​​​​方法一:用Python代码编写一个对话框类然后显示
1. 新建一个testDialog.py,输入以下代码

#! /usr/bin/env python
# -*- coding: utf-8 -*-
import sys
from PyQt5.QtWidgets import QApplication, QDialog, QLabel
from PyQt5 import QtCore


"""
Lily PyQt5 tutorial
In this example, we show a dialog.
Author: Lily Yu
Website: https://blog.csdn.net/yl_best/article/category/8312614
Last edited: November 2018
"""


class Example(QDialog):

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

      self.initUI()

    def initUI(self):
      self.setWindowTitle('Dialog')
      self.resize(400, 300)   # set dialog size to 400*300
      self.lb = QLabel("Code style - Hello PyQt5 Dialog!",self)      # add a label to this dialog
      self.lb.setGeometry(QtCore.QRect(70, 40, 201, 51))   # set label position and size
      self.show()


if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())
2. 右击,选择“Run ‘testDialog’”,执行画面如下



​​​​​​​方法二:用QtDesigner设计一个对话框UI然后让其显示
用QtDesigner创建一个UI,选择“Dialog without Buttons”
在其上添加一个Label,输入文字“UI style - Hello PyQt5 Dialog!”,如下图
保存为“dialog_test.ui”




4. 使用我们之前配置好的工具pyuic来将其转为dialog_test_ui.py.(不会配置的朋友可以参考我的配置说明文章《PyCharm+PyUic快捷菜单工具配置(高级)---分离界面和逻辑》)

5. 新建一个test.py,输入以下代码

#! /usr/bin/env python
# -*- coding: utf-8 -*-
import sys
from PyQt5.QtWidgets import QApplication, QDialog
import dialog_test_ui   # module dialog_test_ui.py
from PyQt5.QtCore import *      # for Qt.ApplicationModal

if __name__ == '__main__':
    app = QApplication(sys.argv)

    # 因为使用Qt Designer设计的ui是默认继承自object类,不提供show()显示方法,
    # 所以我们需要生成一个QDialog对象来重载我们设计的Ui_Dialog类,从而达到显示效果。
    MainDialog = QDialog()      # 创建一个主窗体(必须要有一个主窗体)
    myDialog = dialog_test_ui.Ui_Dialog()   # 创建对话框
    myDialog.setupUi(MainDialog)   # 将对话框依附于主窗体
    # 设置窗口的属性为ApplicationModal模态,用户只有关闭弹窗后,才能关闭主界面
    # MainDialog.setWindowModality(Qt.ApplicationModal)
    MainDialog.show()

    sys.exit(app.exec_())
需要特别说明的是,因为使用Qt Designer设计的ui是默认继承自object类,可以查看“dialog_test_ui.py”文件,不提供show()显示方法,所以我们需要生成一个QDialog对象来重载我们设计的Ui_Dialog类,从而达到显示效果。

   6. 右击,选择“Run ‘test’”,执行画面如下



​​​​​​​总结
用Python代码编写的需要自己提前构思并一点点实现代码,

用QtDesigner设计的比较方便,可以直观显示,维护起来简单,尤其是开发复杂窗体时效率较高。个人推荐这种方法。

这两个方法大家看个人喜好选择。

pyqt5 按钮 弹出 对话框 简单例子 QDialog
import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

class DialogDemo( QMainWindow ):

        def __init__(self, parent=None):
                super(DialogDemo, self).__init__(parent)                
                self.setWindowTitle("Dialog 例子")
                self.resize(350,300)
   
                self.btn = QPushButton( self)
                self.btn.setText("弹出对话框")
                self.btn.move(50,50)               
                self.btn.clicked.connect(self.showdialog)
               
        def showdialog(self ):
                dialog = QDialog()
                btn = QPushButton("ok", dialog )
                btn.move(50,50)
                dialog.setWindowTitle("Dialog")
                dialog.setWindowModality(Qt.ApplicationModal)
                dialog.exec_()

if __name__ == '__main__':
        app = QApplication(sys.argv)
        demo = DialogDemo()
        demo.show()
        sys.exit(app.exec_())


运行效果:




页: [1]
查看完整版本: PyQt5显示对话框Dialog及在对话框中显示内容的两种方法代码直接写dialog方法和ui设计法实例