翻译自原文:Dialogs in PyQt5

翻译时间 2020 年 8 月 19 日

对话定义为两个或多人之间的对话。在计算机应用程序中,对话框是用户与应用程序"对话"的窗口。对话框用于从用户获取数据或更改应用程序设置等操作。

PyQt5 QInputDialog

QInputDialog提供了一个简便对话框,从用户获取单个值。输入值可以是字符串、数字或列表中的项。

input_dialog.py

from PyQt5.QtWidgets import (QWidget, QPushButton, QLineEdit,
                             QInputDialog, QApplication)
import sys


class Example(QWidget):

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

        self.initUI()

    def initUI(self):
        self.btn = QPushButton('Dialog', self)
        self.btn.move(20, 20)
        self.btn.clicked.connect(self.showDialog)

        self.le = QLineEdit(self)
        self.le.move(130, 22)

        self.setGeometry(300, 300, 450, 350)
        self.setWindowTitle('Input dialog')
        self.show()

    def showDialog(self):
        text, ok = QInputDialog.getText(self, 'Input Dialog',
                                        'Enter your name:')

        if ok:
            self.le.setText(str(text))


def main():
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())


if __name__ == '__main__':
    main()

该示例具有一个按钮和一个行编辑部件。该按钮显示用于获取文本值的输入对话框。输入的文本将显示在行编辑部件中。

text, ok = QInputDialog.getText(self, 'Input Dialog',
    'Enter your name:')

此行显示输入对话框。第一个字符串是对话框标题,第二个字符串是对话框中的消息。该对话框返回输入的文本和布尔值。如果我们单击"确定"按钮,则布尔值为 true。

if ok:
    self.le.setText(str(text))

我们通过setText()将行编辑部件的文本内容设置为从对话框中收到的文本。

image-20200819170027455

图:输入对话框

PyQt5 QColorDialog

QColorDialog提供用于选择颜色值的对话框部件。

color_dialog.py

from PyQt5.QtWidgets import (QWidget, QPushButton, QFrame,
                             QColorDialog, QApplication)
from PyQt5.QtGui import QColor
import sys


class Example(QWidget):

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

        self.initUI()

    def initUI(self):
        col = QColor(0, 0, 0)

        self.btn = QPushButton('Dialog', self)
        self.btn.move(20, 20)

        self.btn.clicked.connect(self.showDialog)

        self.frm = QFrame(self)
        self.frm.setStyleSheet("QWidget { background-color: %s }"
                               % col.name())
        self.frm.setGeometry(130, 22, 200, 200)

        self.setGeometry(300, 300, 450, 350)
        self.setWindowTitle('Color dialog')
        self.show()

    def showDialog(self):
        col = QColorDialog.getColor()

        if col.isValid():
            self.frm.setStyleSheet('QWidget { background-color: %s }'
                                   % col.name())


def main():
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())


if __name__ == '__main__':
    main()

应用程序示例显示按钮和 。QFrame部件背景设置为黑色。使用 QColorDialog我们可以更改其背景。

col = QColor(0, 0, 0)

这是QFrame背景的初始颜色。

col = QColorDialog.getColor()

弹出QColorDialog

if col.isValid():
    self.frm.setStyleSheet("QWidget { background-color: %s }"
        % col.name())

我们检查颜色是否有效。如果我们单击"取消"按钮,则不会返回任何有效颜色。如果颜色有效,我们使用样式表更改背景颜色。

image-20200819170635485

PyQt5 QFontDialog

QFontDialog是用于选择字体的对话框部件。

font_dialog.py

from PyQt5.QtWidgets import (QWidget, QVBoxLayout, QPushButton,
                             QSizePolicy, QLabel, QFontDialog, QApplication)
import sys


class Example(QWidget):

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

        self.initUI()

    def initUI(self):
        vbox = QVBoxLayout()

        btn = QPushButton('Dialog', self)
        btn.setSizePolicy(QSizePolicy.Fixed, QSizePolicy.Fixed)
        btn.move(20, 20)

        vbox.addWidget(btn)

        btn.clicked.connect(self.showDialog)

        self.lbl = QLabel('Knowledge only matters', self)
        self.lbl.move(130, 20)

        vbox.addWidget(self.lbl)
        self.setLayout(vbox)

        self.setGeometry(300, 300, 450, 350)
        self.setWindowTitle('Font dialog')
        self.show()

    def showDialog(self):

        font, ok = QFontDialog.getFont()
        if ok:
            self.lbl.setFont(font)


def main():
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())


if __name__ == '__main__':
    main()

在我们的示例中,我们有一个按钮和一个标签。使用QFontDialog我们更改标签的字体。

font, ok = QFontDialog.getFont()

在这里,我们弹出字体对话框。getFont方法返回字体名称和 OK 参数。如果用户单击"确定",OK将等于"True",否则它是”False“的。

if ok:
    self.label.setFont(font)

如果我们单击"确定",则setFont将更改标签的字体。

image-20200819171024413

PyQt5 QFileDialog

QFileDialog是允许用户选择文件或目录的对话框。可以选择这些文件进行打开和保存。

file_dialog.py

from PyQt5.QtWidgets import (QMainWindow, QTextEdit,
                             QAction, QFileDialog, QApplication)
from PyQt5.QtGui import QIcon
import sys
from pathlib import Path
from PyQt5.QtCore import QFileInfo


class Example(QMainWindow):

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

        self.initUI()

    def initUI(self):
        self.textEdit = QTextEdit()
        self.setCentralWidget(self.textEdit)
        self.statusBar()

        root = QFileInfo(__file__).absolutePath()
        openFile = QAction(QIcon(root + '/web.png'), 'Open', self)
        openFile.setShortcut('Ctrl+O')
        openFile.setStatusTip('Open new File')
        openFile.triggered.connect(self.showDialog)

        menubar = self.menuBar()
        fileMenu = menubar.addMenu('&File')
        fileMenu.addAction(openFile)

        self.setGeometry(300, 300, 550, 450)
        self.setWindowTitle('File dialog')
        self.show()

    def showDialog(self):

        home_dir = str(Path.home())
        fname = QFileDialog.getOpenFileName(self, 'Open file', home_dir)

        if fname[0]:
            f = open(fname[0], 'r')

            with f:
                data = f.read()
                self.textEdit.setText(data)


def main():
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())


if __name__ == '__main__':
    main()

该示例显示菜单栏、文本编辑部件(中心部件)和状态栏。菜单项显示用于选择文件的QFileDialog。文件的内容加载到文本编辑部件中。

class Example(QMainWindow):

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

        self.initUI()

该示例基于QMainWindow部件,因为我们设置了文本编辑小部件为center。

home_dir = str(Path.home())
fname = QFileDialog.getOpenFileName(self, 'Open file', home_dir)

我们弹出QFileDialoggetOpenFileName()方法中的第一个字符串是标题,第二个字符串指定对话框工作目录。我们使用path模块来确定用户主目录。默认情况下,文件筛选器设置为"所有文件"(*)。

if fname[0]:
    f = open(fname[0], 'r')

    with f:
        data = f.read()
        self.textEdit.setText(data)

读取所选文件名,将文件内容设置为文本编辑小部件。

在 PyQt5 教程的这一部分中,我们使用对话框。

image-20200819172232428