Python Qt GUI设计:QTabWidget、QStackedWidget和QDockWidget容器控件类(提升篇—2)

有时候我们可能会面临这样一种情况:所开发的程序包含了太多的控件,导致一个窗口装载不下或者装载的控件太多而不美观。

本篇博文就来解决这个问题,即如何在现有的窗口空间中装载更多的控件。

1、QTabWidget容器控件类

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

QTabWidget类中的常用方法如下表所示:

QTabWidget类中的常用信号如下表所示:

通过示例,了解QTabWidget容器控件类的使用方法,效果如下所示:

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

实现代码如下所示:

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) 

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

self.setWindowTitle("Tab 例子")

def tab1UI(self):

layout = QFormLayout()

layout.addRow("姓名",QLineEdit())

layout.addRow("地址",QLineEdit())

self.setTabText(0,"联系方式")

self.tab1.setLayout(layout)

def tab2UI(self):

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

2、QStackedWidget容器控件类

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

通过示例,了解QStackedWidget容器控件类的使用方法,效果如下所示:

示例中,在QStackedWidget对象中填充了三个子控件。每个子控件都可以有自己的布局,包含特定的表单元素。QStackedWidget控件不能在页面之间切换,它与当前选中的QListWidget控件中的选项进行连接。将QListWidget的currentRowChanged信号与display()槽函数相关联,从而改变堆叠控件的视图。

实现代码如下所示:

import sys

from PyQt5.QtCore import *

from PyQt5.QtGui import *

from PyQt5.QtWidgets import *

class StackedExample(QWidget):

def __init__(self):

super(StackedExample, self).__init__()

self.setGeometry(300, 50, 10,10)

self.setWindowTitle('StackedWidget 例子')

self.leftlist = QListWidget ()

self.leftlist.insertItem (0, '联系方式' )

self.leftlist.insertItem (1, '个人信息' )

self.leftlist.insertItem (2, '教育程度' )

self.stack1= QWidget()

self.stack2= QWidget()

self.stack3= QWidget()

self.stack1UI()

self.stack2UI()

self.stack3UI()

self.Stack = QStackedWidget (self)

self.Stack.addWidget (self.stack1)

self.Stack.addWidget (self.stack2)

self.Stack.addWidget (self.stack3)

hbox = QHBoxLayout(self)

hbox.addWidget(self.leftlist)

hbox.addWidget(self.Stack)

self.setLayout(hbox)

self.leftlist.currentRowChanged.connect(self.display)

def stack1UI(self):

layout=QFormLayout()

layout.addRow("姓名",QLineEdit())

layout.addRow("地址",QLineEdit())

self.stack1.setLayout(layout)

def stack2UI(self):

layout=QFormLayout()

sex=QHBoxLayout()

sex.addWidget(QRadioButton("男"))

sex.addWidget(QRadioButton("女"))

layout.addRow(QLabel("性别"),sex)

layout.addRow("生日",QLineEdit()) 

self.stack2.setLayout(layout)

def stack3UI(self):

layout=QHBoxLayout()

layout.addWidget(QLabel("科目"))

layout.addWidget(QCheckBox("物理"))

layout.addWidget(QCheckBox("高数"))

self.stack3.setLayout(layout)

def display(self,i):

self.Stack.setCurrentIndex(i)

if __name__ == '__main__':

app = QApplication(sys.argv)

demo = StackedExample()

demo.show()

sys.exit(app.exec_())

3、QDockWidget容器控件类

QDockWidget是一个可以停靠在QMainWindow内的窗口控件,它可以保持在浮动状态或者在指定位置作为子窗口附加到主窗口中。QMainWindow类的主窗口对象保留有一个用于停靠窗口的区域,这个区域在控件的中央周围,如下图所示:

QDockWidget控件在主窗口内可以移动到新的区域。QDockWidget类中的常用方法如下表所示:

通过示例,了解QDockWidget容器控件类的使用方法,效果如下所示:

示例中,顶层窗口是一个QMainWindow对象,QTextEdit对象是它的中央小控件,创建可停靠的窗口items,然后,在停靠窗口items内添加QListWidget对象,最后,将停靠窗口放置在中央小控件的右侧。

实现代码如下所示:

import sys

from PyQt5.QtCore import *

from PyQt5.QtGui import *

from PyQt5.QtWidgets import *

class DockDemo(QMainWindow):

def __init__(self, parent=None):

super(DockDemo, self).__init__(parent)

layout = QHBoxLayout()

bar=self.menuBar()

file=bar.addMenu("File")

file.addAction("New")

file.addAction("save")

file.addAction("quit")

self.items = QDockWidget("Dockable", self)

self.listWidget = QListWidget()

self.listWidget.addItem("item1")

self.listWidget.addItem("item2")

self.listWidget.addItem("item3")

self.items.setWidget(self.listWidget)

self.items.setFloating(False)

self.setCentralWidget(QTextEdit())

self.addDockWidget(Qt.RightDockWidgetArea, self.items)

self.setLayout(layout)

self.setWindowTitle("Dock 例子")

if __name__ == '__main__':

app = QApplication(sys.argv)

demo = DockDemo()

demo.show()

sys.exit(app.exec_())

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容