【PyQt】切换界面的实现

  • 前言
  • 一、介绍
  • 二、代码
    • 2.1 QStackedWidget
      • 2.1.1 代码
      • 2.1.2 运行结果展示
    • 2.2 QTabWidget
      • 2.2.1 代码
      • 2.2.2 运行结果展示
    • 2.3 QDockWidget
      • 2.3.1 代码
      • 2.3.2 运行结果展示
  • PULSE
    • 结果
  • 总结


前言

实现几个界面的切换展示的效果。


一、介绍

在 PyQt 中实现一个主界面包含其他子界面的操作,通常可以通过多种方式来完成,比如使用 QStackedWidgetQTabWidgetQDockWidget 或简单地通过改变中央控件(central widget)来实现。

二、代码

2.1 QStackedWidget

QStackedWidget 提供了一个堆栈的方式来管理多个窗口部件(widgets),但一次只能显示一个。这非常适合于实现向导界面或者选项卡式界面,但不想显示选项卡本身时。

2.1.1 代码

'''
#Author :总要写点什么
#Creattime:2024/8/24
#FileName:51-Qwidgets
#Description: 网上抄的代码
'''
from PyQt5.QtWidgets import QApplication, QMainWindow, QStackedWidget, QPushButton, QVBoxLayout, QWidgetclass MainWindow ( QMainWindow ) :def __init__(self) :super ().__init__ ()# 创建 QStackedWidgetself.stackedWidget = QStackedWidget()# 添加几个子界面self.page1 = QWidget ()self.page1Layout = QVBoxLayout ()self.page1Button = QPushButton ( "去到Page 2" )self.page1Layout.addWidget ( self.page1Button )self.page1.setLayout ( self.page1Layout )self.page2 = QWidget ()self.page2Layout = QVBoxLayout ()self.page2Button = QPushButton ( "去到Page 1" )self.page2Layout.addWidget(self.page2Button )self.page2.setLayout(self.page2Layout )# 槽函数self.page2Button.clicked.connect ( self.go_to_page_1 )self.page1Button.clicked.connect ( self.go_to_page_2 )# 将子界面添加到 QStackedWidgetself.stackedWidget.addWidget ( self.page1 )self.stackedWidget.addWidget ( self.page2 )# 设置主窗口的中央控件为 QStackedWidgetself.setCentralWidget ( self.stackedWidget )def go_to_page_1(self) :self.stackedWidget.setCurrentIndex(0)def go_to_page_2(self) :self.stackedWidget.setCurrentIndex(1)if __name__ == '__main__':app = QApplication ( [] )window = MainWindow ()window.show ()app.exec_()

2.1.2 运行结果展示

主界面
在这里插入图片描述
也就是setCurrentIndex(0),从0开始没毛病。
点击按钮切换到setCurrentIndex(1)
在这里插入图片描述

2.2 QTabWidget

2.2.1 代码

from PyQt5.QtWidgets import QApplication, QMainWindow, QTabWidget, QWidget, QVBoxLayout, QLabelclass MainWindow ( QMainWindow ) :def __init__(self) :super ().__init__ ()# 设置窗口标题和大小self.setWindowTitle ( "QTabWidget 示例" )self.setGeometry ( 100, 100, 400, 300 )# 创建 QTabWidgetself.tabWidget = QTabWidget ( self )self.setCentralWidget ( self.tabWidget )# 创建第一个选项卡self.tab1 = QWidget ()self.tab1Layout = QVBoxLayout ()self.label1 = QLabel ( "这是第一个选项卡", self.tab1 )self.tab1Layout.addWidget ( self.label1 )self.tab1.setLayout ( self.tab1Layout )self.tabWidget.addTab ( self.tab1, "选项卡 1" )# 创建第二个选项卡self.tab2 = QWidget ()self.tab2Layout = QVBoxLayout ()self.label2 = QLabel ( "这是第二个选项卡", self.tab2 )self.tab2Layout.addWidget ( self.label2 )self.tab2.setLayout ( self.tab2Layout )self.tabWidget.addTab ( self.tab2, "选项卡 2" )if __name__ == '__main__':app = QApplication ( [] )window = MainWindow ()window.show ()app.exec_ ()

2.2.2 运行结果展示

选项1
在这里插入图片描述

选项2
在这里插入图片描述

2.3 QDockWidget

2.3.1 代码

'''
#Author :susocool
#Creattime:2024/8/26
#FileName:53-QDockWidget 示例
#Description:
'''
from PyQt5.QtCore import Qt
from PyQt5.QtWidgets import QApplication, QMainWindow, QTextEdit, QDockWidget, QVBoxLayout, QWidgetclass MainWindow ( QMainWindow ) :def __init__(self) :super ().__init__ ()# 设置窗口标题和大小self.setWindowTitle ( "QDockWidget 示例" )self.setGeometry ( 100, 100, 800, 600 )# 创建两个 QTextEdit 控件作为停靠窗口的内容self.textEdit1 = QTextEdit()self.textEdit2 = QTextEdit()# 创建 QDockWidget 控件并设置其标题和内容self.dock1 = QDockWidget ( "停靠窗口 1", self )self.dock1.setWidget ( self.textEdit1 )self.dock2 = QDockWidget ( "停靠窗口 2", self )self.dock2.setWidget ( self.textEdit2 )# 将停靠窗口添加到主窗口# 默认情况下,停靠窗口会停靠在主窗口的左侧,但你可以通过 addDockWidget 的参数来改变它的位置self.addDockWidget ( Qt.LeftDockWidgetArea, self.dock1 )self.addDockWidget ( Qt.RightDockWidgetArea, self.dock2 )if __name__ == '__main__':app = QApplication ( [] )window = MainWindow ()window.show ()app.exec_ ()

2.3.2 运行结果展示

在这里插入图片描述

PULSE

'''
#Author :susocool
#Creattime:2024/8/26
#FileName:乱写的切换界面
#Description:综合使用一下,以后使用参考这个来
'''
from PyQt5.QtWidgets import QApplication, QMainWindow, QPushButton, QWidget, QVBoxLayout, QDialog,QLabel,QTextEdit, QDockWidget
from PyQt5.QtCore import Qt  class MainWindow(QMainWindow):  def __init__(self):  super().__init__()  # 设置窗口标题和大小  self.setWindowTitle("主界面")  self.setGeometry(100, 100, 400, 300)  # 创建一个中心小部件,用于放置按钮  central_widget = QWidget(self)  self.setCentralWidget(central_widget)  # 创建一个垂直布局  layout = QVBoxLayout(central_widget)  # 创建并添加按钮  self.button1 = QPushButton("打开新窗口 1", self)  self.button1.clicked.connect(self.open_new_window)  layout.addWidget(self.button1)self.button2 = QPushButton ( "打开新窗口 2", self )self.button2.clicked.connect ( self.open_2_window )layout.addWidget ( self.button2 )# 你可以根据需要添加更多的按钮  def open_new_window(self):dialog = NewWindowDialog(self)  dialog.show()def open_2_window(self):dialogwindos = QDockMainWindow(self)dialogwindos.show()class NewWindowDialog(QDialog):  def __init__(self, parent=None):  super().__init__(parent)  # 设置窗口标题和大小  self.setWindowTitle("新窗口")  self.setGeometry(100, 100, 300, 200)  self.label = QLabel("这是一个新窗口", self)  self.label.move(50, 50)  # 简单地使用move来放置控件(注意:这不是最佳实践)  # QDialog 默认就支持窗口支持最小化和关闭等基本操作,因为它继承自 QWidgetclass QDockMainWindow ( QMainWindow ) :def __init__(self, parent=None) :super(QDockMainWindow, self).__init__(parent)# 设置窗口标题和大小self.setWindowTitle ( "QDockWidget 示例" )self.setGeometry ( 100, 100, 800, 600 )# 创建两个 QTextEdit 控件作为停靠窗口的内容self.textEdit1 = QTextEdit()self.textEdit2 = QTextEdit()# 创建 QDockWidget 控件并设置其标题和内容self.dock1 = QDockWidget ( "停靠窗口 1", self )self.dock1.setWidget ( self.textEdit1 )self.dock2 = QDockWidget ( "停靠窗口 2", self )self.dock2.setWidget ( self.textEdit2 )# 将停靠窗口添加到主窗口# 默认情况下,停靠窗口会停靠在主窗口的左侧,但你可以通过 addDockWidget 的参数来改变它的位置self.addDockWidget ( Qt.LeftDockWidgetArea, self.dock1 )self.addDockWidget ( Qt.RightDockWidgetArea, self.dock2 )if __name__ == '__main__':app = QApplication([])  window = MainWindow()  window.show()  app.exec_()

结果

在这里插入图片描述
点击按钮的结果

在这里插入图片描述


总结

这篇文章依旧没有总结

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/409372.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue3 获取农历(阴历)日期,并封装日历展示组件

前言:哈喽,大家好,我是码喽的自我修养!今天给大家分享vue3项目中使用 chinese-lunar-calendar 插件获取农历(阴历)日期,并封装了日历展示组件!提供了具体的代码帮助大家深入理解,彻底掌握&#…

【SpringBoot】11 多数据源(MyBatis:dynamic-datasource)

介绍 多数据源:指的是一个单一应用程序中涉及了两个及以上的数据库,这种配置允许应用程序根据业务需求灵活地管理和操作不同的数据库。 需求 一个应用服务中,连接多个数据库,有本地的也有远程的,有MysQL、Oracle、P…

Python和MATLAB梯度下降导图

🎯要点 寻找局部最小值普通最小二乘法和随机梯度下降的动量线性回归媒体广告销售光学字符识别和最小化均方误差男女医疗费用最快速下降方向函数优化等高线图可视化共轭梯度下降可视化损失函数、动量、涅斯特洛夫动量、权衰减量化不确定性拓扑结构算法分类中权重归一…

Threejs学习-三维坐标系、相机控件

坐标系: Three.js 使用的是右手坐标系,x 轴朝右,y 轴朝上,z 轴朝向自己。 相机控件轨道控制器 相机控件OrbitControls 通过相机控件OrbitControls实现旋转缩放预览效果。 // 设置相机控件轨道控制器OrbitControls const contr…

OpenCV几何图像变换(6)计算反转仿射变换函数invertAffineTransform()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 反转一个仿射变换。 该函数计算由 23 矩阵 M 表示的逆仿射变换: [ a 11 a 12 b 1 a 21 a 22 b 2 ] \begin{bmatrix} a_{11} & a…

windows vs2022 MFC使用webview2嵌入网页

Microsoft Edge WebView2 控件允许在本机应用中嵌入 web 技术(HTML、CSS 以及 JavaScript)。 WebView2 控件使用 Microsoft Edge 作为绘制引擎,以在本机应用中显示 web 内容。 一、通过菜单“项目”-“管理NuGet程序包”,下载相关包 二、安装 Microsof…

结构化与面向对象

人类认识世界总是循序渐进的过程,软件工程也一样,从最开始的单兵作战,再到软件作坊,直到如今的大规模软件开发,软件工程从业者不断总结实践中存在的问题以及解决途径,逐渐形成了一系列的软件工程方法&#…

ZooKeeper--基于Kubernetes部署ZooKeeper

ZooKeeper 服务 服务类型: 无头服务(clusterIP: None),这是 StatefulSet(有状态集)必需的配置。 端口: 2181 (客户端): 用于客户端连接。 2888 (跟随者): 用于 ZooKeeper 服务器之间的连接。 3888 (领导者): 用于领导者…

Linux查看jvm相关参数以及设置调优参数

1、查看jvm相关参数 1.1、查看Java进程命令 jcmd会显示出来对应的Java进程id 1.2、查看堆内存各个区域的使用大小、具体大小和GC次数以及耗时 jstat -gc 4036145jstat -gc 进程id 各个参数的含义。 如上图,4036145的进程,FGCT是0.452,FGC是4.平均每次full gc耗时0.11秒。 …

Android13系统源码内置App并通过AIDL调用获取内置存储卡的真实大小

jix 进行从事Android系统源码开发不得不在原有的系统上内置自己的App。通过内置App一般都需要调用些系统才能访问的系统级App。App的部署和调试需要依赖源码系统。通过命令 : mm 来实现。 第三方App想调用内置的app需要通过跨进程调用。 这里通过AIDL来实现跨进程…

Qt第二十章 数据库操作

文章目录 Qt操作数据库QSqlDataBaseQSqlQuery执行SQL语句 QSqlRecordQSqlField数据库模型QSqlQueryModelQSqlTableModelQSqlRelationalTableModel 编译MySql驱动msvc版本MySql客户端程序部署 Qt操作数据库 需要在cmakelist加上Sql模块 QSqlDataBase 可以通过静态成员查看支持的…

苹果已删除照片的恢复方法有哪些?盘点几种实用办法

苹果设备上的照片往往是珍贵的回忆,但不小心删除照片的情况时有发生。幸运的是,苹果提供了几种方法来帮助用户恢复已删除的照片。本文将详细介绍几种有效的恢复方法,帮助您找回那些重要的照片。 方法一:通过“最近删除”文件夹恢复…

SQL-DCL-数据控制语言

一、 DCL-管理用户 二、DCL-权限控制 一、 DCL-管理用户,主要是DBA数据库管理员使用,开发使用较少 # 1、查询用户 use mysql; show tables; desc user; select * from user; # host为主机地址, 主机地址和用户名确定唯一性# 2、创建用户 create user itcastlocalh…

【AD9361 数字基带】多片基带内FPGA补偿 I/Q Rotation

I/Q 旋转 Rotation 在许多多通道射频系统中,如 AD-FMCOMMS5,甚至在 AD-FMCOMMS2、AD-FMCOMMS3 上,都需要测量或校正两个复数 (I/Q) RF 信号之间的相位差。 从纯粹的数学描述来看,单个正弦波没有相位&…

【数学建模】趣味数学模型——等额还款数学模型

问题 在银行贷款中,通常采用等额还款。假定银行贷款的年利率为 p,贷款 k 元,分 m 年采用每月等额还款方式还清。问每月还款多少钱?总共还的钱是多少?每月还款中还本金和利息各是多少元? 如果考虑每月等额…

VTK随笔一:初识VTK(QT中嵌入VTK窗口)

VTK(Visualization Toolkit)是一个用于可视化和图形处理的开源软件库。它提供了一系列的算法和工具,可以用来创建、渲染和处理二维和三维的图形数据。VTK可以在多个平台上运行,并支持各种编程语言,包括C、Python和Java…

基于Springboot + vue + mysql 车辆充电桩管理系统 设计实现

目录 📚 前言 📑摘要 1.1 研究背景 📑操作流程 📚 系统架构设计 📚 数据库设计 💬 E-R表 3.4.2 数据库具体设计 系统功能模块 系统首页 用户注册 充电桩 个人中心 用户后台管理模块 用户登录…

完成课题ssrf实现.SSH未创建写shell,同时完成其他漏洞复现

SSRF 一种网络安全漏洞,发生在服务器端应用程序中,允许攻击者通过服务器向任意网络资源发送请求,而无需用户直接参与。这种漏洞通常源于程序设计错误,例如当应用程序使用用户的输入作为URL请求的一部分,而没有适当的验…

Ansible初识

ansible初识 Ansible是一种自动化工具,用于配置管理、应用程序部署和任务自动化。它基于Python语言开发,使用SSH协议进行通信,并且不需要在被管理的主机上安装任何客户端。Ansible使用简单的YAML语言来描述任务和配置,使得操作简…

Vue3的三种样式控制及实现原理

你好,我是沐爸,欢迎点赞、收藏和关注。个人知乎 Vue3中一共有三种样式控制,分别是全局样式控制、局部作用域样式控制和深度样式控制,今天我们一起看下这三种样式控制的使用,以及实现的原理是什么。 一、全局样式控制…