• 控件2
    • 图片
    • 行编辑
    • QSplitter
    • 下拉选框

    控件2

    本章我们继续介绍PyQt5控件。这次的有QPixmapQLineEditQSplitter,和QComboBox

    图片

    QPixmap是处理图片的组件。本例中,我们使用QPixmap在窗口里显示一张图片。

    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)

    QPixmap实例放到QLabel组件里。

    程序展示:

    pixmap

    行编辑

    QLineEdit组件提供了编辑文本的功能,自带了撤销、重做、剪切、粘贴、拖拽等功能。

    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()方法让标签自适应文本内容。

    程序展示:

    QLineEdit

    QSplitter

    QSplitter组件能让用户通过拖拽分割线的方式改变子窗口大小的组件。本例中我们展示用两个分割线隔开的三个QFrame组件。

    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. def onChanged(self, text):
    39. self.lbl.setText(text)
    40. self.lbl.adjustSize()
    41. if __name__ == '__main__':
    42. app = QApplication(sys.argv)
    43. ex = Example()
    44. sys.exit(app.exec_())

    三个窗口和两个分割线的布局创建完成了,但是要注意,有些主题下,分割线的显示效果不太好。

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

    为了更清楚的看到分割线,我们使用了设置好的子窗口样式。

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

    创建一个QSplitter组件,并在里面添加了两个框架。

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

    也可以在分割线里面再进行分割。

    程序展示:

    QSplitter widget

    下拉选框

    QComboBox组件能让用户在多个选择项中选择一个。

    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_())

    本例包含了一个QComboBox和一个QLabel。下拉选择框有五个选项,都是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()

    在方法内部,设置标签内容为选定的字符串,然后设置自适应文本大小。

    程序展示:

    QComboBox