PyQT5之多页面切换
1.PyQT5图像2.PyQT5水平垂直布局3.PyQT5之图片左右翻页4.PyQT5之QPushButton和布局5.PyQT5之label6.PyQT5之选择图片7.PyQT5之自定义信号8.PyQT5之窗口9.PyQT5之菜单栏和工具栏10.PyQT5之QComboBox11.PyQT5之Checkbox12.PyQT5之QRadioButton13.PyQT5之单行文本输入到多行显示窗14.PyQT5之网格布局多图片显示15.PyQtGraph绘制折线图16.PyQT5之PyQtGraph实时数据显示17.PyQT5之窗口最大化最小化18.PyQT5之QSS基础/子控件选择器19.PyQT5样式设置20.PyQT5绘图21.PyQT5窗口样式设置22.PyQT5之设置窗口控件风格23.PyQT5之多窗口交互24.PyQT5之override覆盖槽函数25.PyQT5之为槽函数传递参数26.PyQT5信号与槽的连接27.PyQT5信号刷新时间28.PyQT5之信号关闭窗口29.信号与槽N对N30.PyQT5之多个信号31.PyQT5之QTreeView32.PyQT5内嵌html33.PyQT5加载本地web页面34.PyQT5之QWebEngineView35.PyQT5之QThread36.PyQT5之QTimer37.PyQT5之QStackedWidget38.PyQT5之QTreeWidget-QTabWidget39.PyQT5之QTableWidget40.PyQT5之QListWidget41.PyQT5之QListView42.PyQT5之二维表QTableView43.PyQT5打印机44.PyQT5之QPainter45.PyQT5之QFontDialog46.PyQT5之QInputDialog47.PyQT5之QMessageBox48.PyQT5之QDialog
49.PyQT5之多页面切换
50.PyQT5之计数器控件QSpinBox51.PyQT5之滑块控件QSlider52.PyQtGraph绘图参考53.PyQtGraph之多图绘制54.PyQtGraph之柱状图55.PyQt5选择文件控件QFileDialogfrom PyQt5.QtWidgets import QApplication, QWidget, QStackedLayout, QVBoxLayout
from PyQt5.QtWidgets import QPushButton, QComboBox, QSizePolicy
import sys
if __name__ == '__main__':
app = QApplication(sys.argv)
my_widget = QWidget()
my_widget_1 = QWidget(my_widget)
my_widget_2 = QWidget()
# 容器my_widget_1使用QVBoxLayout布局,布局中包含2个button
my_page1_btn1 = QPushButton('A')
my_page1_btn2 = QPushButton('B')
# page1中将2个button加入QVBoxLayout布局
my_page1_vbox_layout = QVBoxLayout()
my_page1_vbox_layout.addWidget(my_page1_btn1)
my_page1_vbox_layout.addWidget(my_page1_btn2)
my_widget_1.setLayout(my_page1_vbox_layout)
# 容器my_widget_2也使用QVBoxLayout布局,布局中包含2个button
my_page2_btn1 = QPushButton('C')
my_page2_btn2 = QPushButton('D')
# page2中将2个button加入QVBoxLayout布局
my_page2_vbox_layout = QVBoxLayout()
my_page2_vbox_layout.addWidget(my_page2_btn1)
my_page2_vbox_layout.addWidget(my_page2_btn2)
my_widget_2.setLayout(my_page2_vbox_layout)
# 将两个页面加入到QStackedLayout中
my_stacked_layout = QStackedLayout()
my_stacked_layout.addWidget(my_widget_1)
my_stacked_layout.addWidget(my_widget_2)
# 定义一个combobox用于选择分页
my_combo_box = QComboBox()
my_combo_box.addItem('页面1')
my_combo_box.addItem('页面2')
my_combo_box.setMinimumWidth(100)
my_combo_box.setSizePolicy(QSizePolicy.Policy.Fixed, QSizePolicy.Policy.Fixed)
# 顶层窗口上,使用QVBoxLayout布局,进行展示
my_page_vbox_layout = QVBoxLayout()
my_page_vbox_layout.addWidget(my_combo_box)
my_page_vbox_layout.addLayout(my_stacked_layout)
my_widget.setLayout(my_page_vbox_layout)
# 关联信号和槽以实现多页面切换(关键步骤)
my_combo_box.activated[int].connect(my_stacked_layout.setCurrentIndex)
my_widget.show()
sys.exit(app.exec_())
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析