PyQt5高级界面控件之QTabWidget(六)

QTabWidget

前言

QTabWidget控件提供了一个选项卡和一个页面区域,默认显示第一个选项卡的页面,通过单击各选项卡可以查看对应的界面,如果在一个窗口中显示的输入字段很多,则可以对这些字段进行拆分,分别放置在不同界面的选项卡中

QTabWidget类中常用的方法

方法描述
addTab()将一个控件添加到Tab控件的选项卡中
insertTab()将一个Tab控件的选项卡插入到指定的位置
removeTab()根据指定的索引删除Tab控件
setCurrentIndex()设置当前可见的选项卡所在的索引
setCurrentWidget()设置当前可见的界面
setTabBar()设置选项卡栏的小控件
setTabPosition()设置选项卡的位置
QTabWidget.North:显示在页面的上方
QTabWidget.South:显示在页面的下方
QTabWidget.West:显示在页面的左侧
QTabWidget.East:显示在页面的右侧
setTabText()定义Tab选项卡的显示值

QTabWidget类中的常用信号

信号描述
currentChanged切换当前页面时发射该信号

实例:QTabWidget的使用

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

class TabDemo(QTabWidget):
    def __init__(self,parent=None):
        super(TabDemo, self).__init__(parent)

        #创建3个选项卡小控件窗口
        self.tab1=QWidget()
        self.tab2=QWidget()
        self.tab3=QWidget()

        #将三个选项卡添加到顶层窗口中
        self.addTab(self.tab1, "Tab 1")
        self.addTab(self.tab2, "Tab 2")
        self.addTab(self.tab3, "Tab 3")

        #每个选项卡自定义的内容
        self.tab1UI()
        self.tab2UI()
        self.tab3UI()

    def tab1UI(self):
        #表单布局
        layout=QFormLayout()
        #添加姓名,地址的单行文本输入框
        layout.addRow('姓名',QLineEdit())
        layout.addRow('地址',QLineEdit())
        #设置选项卡的小标题与布局方式
        self.setTabText(0,'联系方式')
        self.tab1.setLayout(layout)

    def tab2UI(self):
        #zhu表单布局,次水平布局
        layout=QFormLayout()
        sex=QHBoxLayout()

        #水平布局添加单选按钮
        sex.addWidget(QRadioButton('男'))
        sex.addWidget(QRadioButton('女'))

        #表单布局添加控件
        layout.addRow(QLabel('性别'),sex)
        layout.addRow('生日',QLineEdit())

        #设置标题与布局
        self.setTabText(1,'个人详细信息')
        self.tab2.setLayout(layout)

    def tab3UI(self):
        #水平布局
        layout=QHBoxLayout()

        #添加控件到布局中
        layout.addWidget(QLabel('科目'))
        layout.addWidget(QCheckBox('物理'))
        layout.addWidget(QCheckBox('高数'))

        #设置小标题与布局方式
        self.setTabText(2,'教育程度')
        self.tab3.setLayout(layout)
if __name__ == '__main__':
    app=QApplication(sys.argv)
    demo=TabDemo()
    demo.show()
    sys.exit(app.exec_())

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

代码分析

在这个例子中,一个表单的内容分为3组,每一组小控件都显示在不同的选项卡中,顶层窗口是一个QTabWidget控件,将三个选项卡添加进去


        #创建3个选项卡小控件窗口
        self.tab1=QWidget()
        self.tab2=QWidget()
        self.tab3=QWidget()

        #将三个选项卡添加到顶层窗口中
        self.addTab(self.tab1, "Tab 1")
        self.addTab(self.tab2, "Tab 2")
        self.addTab(self.tab3, "Tab 3")

使用表单布局管理器,每个选项卡显示子表单的内容

self.setTabText(0,'联系方式')
self.setTabText(1,'个人详细信息')
self.setTabText(2,'教育程度')

相关文件及下载地址

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

  • 22
    点赞
  • 116
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
QTabWidget是一个Qt界面类,用于在单个窗口中显示多个标签页。 以下是QTabWidget的一些常用方法和属性: 1. 添加标签页:使用addTab()方法添加,参数为QWidget对象和标签名称。 2. 获取当前活动标签页:使用currentIndex()方法获取当前活动标签页索引。 3. 设置当前活动标签页:使用setCurrentIndex()方法设置当前活动标签页,参数为标签页索引。 4. 获取标签页数量:使用count()方法获取标签页数量。 5. 移除标签页:使用removeTab()方法移除标签页,参数为标签页索引。 6. 隐藏标签页:使用setTabEnabled()方法设置标签页是否可用,参数为标签页索引和布尔值。 下面是一个简单的例子: ```python import sys from PyQt5.QtWidgets import QApplication, QWidget, QTabWidget, QVBoxLayout, QLabel class TabWidget(QTabWidget): def __init__(self): super().__init__() self.initUI() def initUI(self): # 添加标签页 tab1 = QWidget() tab2 = QWidget() self.addTab(tab1, "标签1") self.addTab(tab2, "标签2") # 设置布局 layout1 = QVBoxLayout() layout1.addWidget(QLabel("这是标签1")) tab1.setLayout(layout1) layout2 = QVBoxLayout() layout2.addWidget(QLabel("这是标签2")) tab2.setLayout(layout2) # 设置当前活动标签页 self.setCurrentIndex(0) if __name__ == '__main__': app = QApplication(sys.argv) ex = TabWidget() ex.show() sys.exit(app.exec_()) ``` 在这个例子中,QTabWidget类继承自QWidget类,因此可以像使用其他QWidget类一样设置布局和添加子控件。使用addTab()方法添加标签页,并使用setCurrentIndex()方法设置当前活动标签页。最后,使用show()方法显示窗口并运行应用程序。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jia666666

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值