PyQt5高级界面控件之QStackedWidget(七)

末蓝、 2023-05-31 07:42 91阅读 0赞

前言

QTackedWidget是一个堆栈窗口控件,可以填充一些小控件,但是同一时间只有一个小控件可以显示,QStackedWidget使用QStackedLayout布局。QSTackedWidget控件与QTabWidget类似,可以有效的显示窗口的控件

实例:QStackedWidget的使用

  1. import sys
  2. from PyQt5.QtGui import *
  3. from PyQt5.QtCore import *
  4. from PyQt5.QtWidgets import *
  5. class StackedExample(QWidget):
  6. def __init__(self):
  7. super(StackedExample, self).__init__()
  8. #设置窗口初始位置和大小
  9. self.setGeometry(300,50,10,10)
  10. self.setWindowTitle('StackedWidget 例子')
  11. #创建列表窗口,添加条目
  12. self.leftlist=QListWidget()
  13. self.leftlist.insertItem(0,'联系方式')
  14. self.leftlist.insertItem(1,'个人信息')
  15. self.leftlist.insertItem(2,'教育程度')
  16. #创建三个小控件
  17. self.stack1=QWidget()
  18. self.stack2=QWidget()
  19. self.stack3=QWidget()
  20. self.stack1UI()
  21. self.stack2UI()
  22. self.stack3UI()
  23. #在QStackedWidget对象中填充了三个子控件
  24. self.stack=QStackedWidget(self)
  25. self.stack.addWidget(self.stack1)
  26. self.stack.addWidget(self.stack2)
  27. self.stack.addWidget(self.stack3)
  28. #水平布局,添加部件到布局中
  29. HBox=QHBoxLayout()
  30. HBox.addWidget(self.leftlist)
  31. HBox.addWidget(self.stack)
  32. self.setLayout(HBox)
  33. self.leftlist.currentRowChanged.connect(self.display)
  34. def stack1UI(self):
  35. layout=QFormLayout()
  36. layout.addRow('姓名',QLineEdit())
  37. layout.addRow('地址',QLineEdit())
  38. self.stack1.setLayout(layout)
  39. def stack2UI(self):
  40. # zhu表单布局,次水平布局
  41. layout = QFormLayout()
  42. sex = QHBoxLayout()
  43. # 水平布局添加单选按钮
  44. sex.addWidget(QRadioButton('男'))
  45. sex.addWidget(QRadioButton('女'))
  46. # 表单布局添加控件
  47. layout.addRow(QLabel('性别'), sex)
  48. layout.addRow('生日', QLineEdit())
  49. self.stack2.setLayout(layout)
  50. def stack3UI(self):
  51. # 水平布局
  52. layout = QHBoxLayout()
  53. # 添加控件到布局中
  54. layout.addWidget(QLabel('科目'))
  55. layout.addWidget(QCheckBox('物理'))
  56. layout.addWidget(QCheckBox('高数'))
  57. self.stack3.setLayout(layout)
  58. def display(self,i):
  59. #设置当前可见的选项卡的索引
  60. self.stack.setCurrentIndex(i)
  61. if __name__ == '__main__':
  62. app=QApplication(sys.argv)
  63. demo=StackedExample()
  64. demo.show()
  65. sys.exit(app.exec_())

运行效果如图
这里写图片描述这里写图片描述这里写图片描述

代码分析

在这个例子中,在QStackedWidget对象中填充了三个子控件

  1. self.stack1=QWidget()
  2. self.stack2=QWidget()
  3. self.stack3=QWidget()
  4. #在QStackedWidget对象中填充了三个子控件
  5. self.stack=QStackedWidget(self)
  6. self.stack.addWidget(self.stack1)
  7. self.stack.addWidget(self.stack2)
  8. self.stack.addWidget(self.stack3)
  9. 1
  10. 2
  11. 3
  12. 4
  13. 5
  14. 6
  15. 7
  16. 8
  17. 9
  18. 10

每个子控件都可以有自己的布局,包含特定的表单元素,QStackedWidget控件不能在页面之间进行切换,它与当前选中的QListWidget控件中的选项进行连接

  1. #创建列表窗口,添加条目
  2. self.leftlist=QListWidget()
  3. self.leftlist.insertItem(0,'联系方式')
  4. self.leftlist.insertItem(

将QListWidget的currentRowChanged信号与display()槽函数相关联,从而改变堆叠控件的视图

  1. def display(self,i):
  2. #设置当前可见的选项卡的索引
  3. self.stack.setCurrentIndex(i)
  • QStackedWidget

    • 前言
    • 实例:QStackedWidget的使用
    • 代码分析

        • 相关文件及下载地址

相关文件及下载地址

https://download.csdn.net/download/jia666666/10609488

发表评论

表情:
评论列表 (有 0 条评论,91人围观)

还没有评论,来说两句吧...

相关阅读