原文: http://zetcode.com/gui/pyqt5/widgets2/

在这里,我们将继续介绍 PyQt5 小部件。 我们将介绍QPixmapQLineEditQSplitterQComboBox

QPixmap

QPixmap是用于处理图像的小部件之一。 它经过优化,可在屏幕上显示图像。 在我们的代码示例中,我们将使用QPixmap在窗口上显示图像。

pixmap.py

  1. #!/usr/bin/python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. ZetCode PyQt5 tutorial
  5. In this example, we dispay an image
  6. on the window.
  7. Author: Jan Bodnar
  8. Website: zetcode.com
  9. Last edited: August 2017
  10. """
  11. from PyQt5.QtWidgets import (QWidget, QHBoxLayout,
  12. QLabel, QApplication)
  13. from PyQt5.QtGui import QPixmap
  14. import sys
  15. class Example(QWidget):
  16. def __init__(self):
  17. super().__init__()
  18. self.initUI()
  19. def initUI(self):
  20. hbox = QHBoxLayout(self)
  21. pixmap = QPixmap("redrock.png")
  22. lbl = QLabel(self)
  23. lbl.setPixmap(pixmap)
  24. hbox.addWidget(lbl)
  25. self.setLayout(hbox)
  26. self.move(300, 200)
  27. self.setWindowTitle('Red Rock')
  28. self.show()
  29. if __name__ == '__main__':
  30. app = QApplication(sys.argv)
  31. ex = Example()
  32. sys.exit(app.exec_())

在我们的示例中,我们在窗口上显示图像。

  1. pixmap = QPixmap("redrock.png")

我们创建一个QPixmap对象。 它以文件名作为参数。

  1. lbl = QLabel(self)
  2. lbl.setPixmap(pixmap)

我们将像素图放入QLabel小部件。

QLineEdit

QLineEdit是一个小部件,允许输入和编辑单行纯文本。 该小部件具有撤消和重做,剪切和粘贴以及拖放功能。

lineedit.py

  1. #!/usr/bin/python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. ZetCode PyQt5 tutorial
  5. This example shows text which
  6. is entered in a QLineEdit
  7. in a QLabel widget.
  8. Author: Jan Bodnar
  9. Website: zetcode.com
  10. Last edited: August 2017
  11. """
  12. import sys
  13. from PyQt5.QtWidgets import (QWidget, QLabel,
  14. QLineEdit, QApplication)
  15. class Example(QWidget):
  16. def __init__(self):
  17. super().__init__()
  18. self.initUI()
  19. def initUI(self):
  20. self.lbl = QLabel(self)
  21. qle = QLineEdit(self)
  22. qle.move(60, 100)
  23. self.lbl.move(60, 40)
  24. qle.textChanged[str].connect(self.onChanged)
  25. self.setGeometry(300, 300, 280, 170)
  26. self.setWindowTitle('QLineEdit')
  27. self.show()
  28. def onChanged(self, text):
  29. self.lbl.setText(text)
  30. self.lbl.adjustSize()
  31. if __name__ == '__main__':
  32. app = QApplication(sys.argv)
  33. ex = Example()
  34. sys.exit(app.exec_())

此示例显示了行编辑小部件和标签。 我们在行编辑中键入的文本会立即显示在标签窗口小部件中。

  1. qle = QLineEdit(self)

QLineEdit小部件已创建。

  1. qle.textChanged[str].connect(self.onChanged)

如果行编辑窗口小部件中的文本更改,我们将调用onChanged()方法。

  1. def onChanged(self, text):
  2. self.lbl.setText(text)
  3. self.lbl.adjustSize()

onChanged()方法内部,我们将键入的文本设置为标签小部件。 我们调用adjustSize()方法将标签的大小调整为文本的长度。

PyQt5 小部件 II - 图1

图:QLineEdit

QSplitter

QSplitter允许用户通过拖动子控件之间的边界来控制子控件的大小。 在我们的示例中,我们显示了由两个拆分器组成的三个QFrame小部件。

splitter.py

  1. #!/usr/bin/python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. ZetCode PyQt5 tutorial
  5. This example shows
  6. how to use QSplitter widget.
  7. Author: Jan Bodnar
  8. Website: zetcode.com
  9. Last edited: August 2017
  10. """
  11. from PyQt5.QtWidgets import (QWidget, QHBoxLayout, QFrame,
  12. QSplitter, QStyleFactory, QApplication)
  13. from PyQt5.QtCore import Qt
  14. import sys
  15. class Example(QWidget):
  16. def __init__(self):
  17. super().__init__()
  18. self.initUI()
  19. def initUI(self):
  20. hbox = QHBoxLayout(self)
  21. topleft = QFrame(self)
  22. topleft.setFrameShape(QFrame.StyledPanel)
  23. topright = QFrame(self)
  24. topright.setFrameShape(QFrame.StyledPanel)
  25. bottom = QFrame(self)
  26. bottom.setFrameShape(QFrame.StyledPanel)
  27. splitter1 = QSplitter(Qt.Horizontal)
  28. splitter1.addWidget(topleft)
  29. splitter1.addWidget(topright)
  30. splitter2 = QSplitter(Qt.Vertical)
  31. splitter2.addWidget(splitter1)
  32. splitter2.addWidget(bottom)
  33. hbox.addWidget(splitter2)
  34. self.setLayout(hbox)
  35. self.setGeometry(300, 300, 300, 200)
  36. self.setWindowTitle('QSplitter')
  37. self.show()
  38. if __name__ == '__main__':
  39. app = QApplication(sys.argv)
  40. ex = Example()
  41. sys.exit(app.exec_())

在我们的示例中,我们有三个框架小部件和两个拆分器。 请注意,在某些主题下,拆分器可能无法很好地显示。

  1. topleft = QFrame(self)
  2. topleft.setFrameShape(QFrame.StyledPanel)

我们使用样式化的框架以查看QFrame小部件之间的边界。

  1. splitter1 = QSplitter(Qt.Horizontal)
  2. splitter1.addWidget(topleft)
  3. splitter1.addWidget(topright)

我们创建一个QSplitter小部件,并在其中添加两个框架。

  1. splitter2 = QSplitter(Qt.Vertical)
  2. splitter2.addWidget(splitter1)

我们还可以将拆分器添加到另一个拆分器小部件。

PyQt5 小部件 II - 图2

图:QSplitter小部件

QComboBox

QComboBox是一个小部件,允许用户从选项列表中进行选择。

combobox.py

  1. #!/usr/bin/python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. ZetCode PyQt5 tutorial
  5. This example shows how to use
  6. a QComboBox widget.
  7. Author: Jan Bodnar
  8. Website: zetcode.com
  9. Last edited: August 2017
  10. """
  11. from PyQt5.QtWidgets import (QWidget, QLabel,
  12. QComboBox, QApplication)
  13. import sys
  14. class Example(QWidget):
  15. def __init__(self):
  16. super().__init__()
  17. self.initUI()
  18. def initUI(self):
  19. self.lbl = QLabel("Ubuntu", self)
  20. combo = QComboBox(self)
  21. combo.addItem("Ubuntu")
  22. combo.addItem("Mandriva")
  23. combo.addItem("Fedora")
  24. combo.addItem("Arch")
  25. combo.addItem("Gentoo")
  26. combo.move(50, 50)
  27. self.lbl.move(50, 150)
  28. combo.activated[str].connect(self.onActivated)
  29. self.setGeometry(300, 300, 300, 200)
  30. self.setWindowTitle('QComboBox')
  31. self.show()
  32. def onActivated(self, text):
  33. self.lbl.setText(text)
  34. self.lbl.adjustSize()
  35. if __name__ == '__main__':
  36. app = QApplication(sys.argv)
  37. ex = Example()
  38. sys.exit(app.exec_())

该示例显示了QComboBoxQLabel。 组合框具有五个选项的列表。 这些是 Linux 发行版的名称。 标签窗口小部件显示从组合框中选择的选项。

  1. combo = QComboBox(self)
  2. combo.addItem("Ubuntu")
  3. combo.addItem("Mandriva")
  4. combo.addItem("Fedora")
  5. combo.addItem("Arch")
  6. combo.addItem("Gentoo")

我们创建具有五个选项的QComboBox小部件。

  1. combo.activated[str].connect(self.onActivated)

选择项目后,我们调用onActivated()方法。

  1. def onActivated(self, text):
  2. self.lbl.setText(text)
  3. self.lbl.adjustSize()

在方法内部,我们将所选项目的文本设置为标签小部件。 我们调整标签的大小。

PyQt5 小部件 II - 图3

图:QComboBox

在 PyQt5 教程的这一部分中,我们介绍了QPixmapQLineEditQSplitterQComboBox