Windows图形界面(GUI)-QT-C/C++ - QT Stacked Widget

目录

一、概述

二、使用场景

[1. 多步表单](#1. 多步表单)

[2. 选项卡界面](#2. 选项卡界面)

[3. 状态机界面](#3. 状态机界面)

三、常见样式

四、属性设置

[1. 页面管理](#1. 页面管理)

[2. 布局管理](#2. 布局管理)

[3. 信号与槽](#3. 信号与槽)

五、内容处理

[1. 添加页面](#1. 添加页面)

[2. 移除页面](#2. 移除页面)

[3. 设置当前页面](#3. 设置当前页面)

[4. 获取当前页面](#4. 获取当前页面)

[5. 获取指定页面](#5. 获取指定页面)

[6. 获取页面总数](#6. 获取页面总数)

[7. 页面切换信号](#7. 页面切换信号)

[8. 页面移除信号](#8. 页面移除信号)


一、概述

QStackedWidget 是 Qt 框架中的一个重要组件,它允许开发者在同一个窗口区域内堆叠多个子窗口(页面),但一次只显示其中一个。这种设计非常适合需要动态切换界面的场景,如多步表单、选项卡界面、状态机界面等。

二、使用场景

1. 多步表单

在多步表单中,用户需要依次填写多个表单页面。QStackedWidget 可以很好地管理这些表单页面,通过按钮或程序逻辑控制页面的切换,确保用户按照预定的步骤完成表单填写。

2. 选项卡界面

虽然 Qt 提供了 QTabWidget 来实现选项卡界面,但在某些情况下,开发者可能希望自定义选项卡的外观或行为。QStackedWidget 可以通过按钮或其他控件来切换页面,从而实现自定义的选项卡界面。

3. 状态机界面

在状态机界面中,应用程序的不同状态对应不同的界面。QStackedWidget 可以根据应用程序的状态动态切换显示的页面,确保用户界面与应用程序状态保持一致。

三、常见样式

QStackedWidget 是一个堆叠的窗口小部件,它在同一个占位符中显示一个控件,多个控件堆叠在一起,但一次只能显示一个。通过程序或用户操作,可以切换当前显示的控件。

四、属性设置

1. 页面管理

  • 添加页面 :使用 addWidget(QWidget *widget) 方法向 QStackedWidget 中添加一个新的页面。

  • 删除页面 :使用 removeWidget(QWidget *widget) 方法从 QStackedWidget 中移除一个页面。

  • 重命名页面 :虽然 QStackedWidget 本身不提供直接重命名页面的方法,但可以通过自定义数据结构或标签来管理页面名称。

2. 布局管理

在每个页面上,开发者可以添加布局和控件,以构建复杂的用户界面。QStackedWidget 本身不限制页面的布局方式,开发者可以根据需要自由设计。

3. 信号与槽

  • 页面切换 :通过 setCurrentWidget(QWidget *widget)setCurrentIndex(int index) 方法切换页面时,可以连接 currentChanged(int index) 信号到自定义槽函数,以处理页面切换时的逻辑。

  • 页面移除 :当页面被移除时,widgetRemoved(int index) 信号会被发出,开发者可以连接此信号以处理页面移除后的逻辑。

五、内容处理

1. 添加页面

cpp 复制代码
QWidget *page1 = new QWidget();
QStackedWidget *stackedWidget = new QStackedWidget();
stackedWidget->addWidget(page1);

2. 移除页面

cpp 复制代码
stackedWidget->removeWidget(page1);

3. 设置当前页面

cpp 复制代码
stackedWidget->setCurrentWidget(page1);
// 或者通过索引设置
stackedWidget->setCurrentIndex(0);

4. 获取当前页面

cpp 复制代码
QWidget *currentPage = stackedWidget->currentWidget();
int currentIndex = stackedWidget->currentIndex();

5. 获取指定页面

cpp 复制代码
QWidget *page = stackedWidget->widget(0);

6. 获取页面总数

cpp 复制代码
int pageCount = stackedWidget->count();

7. 页面切换信号

cpp 复制代码
connect(stackedWidget, &QStackedWidget::currentChanged, this, &MyClass::onPageChanged);

8. 页面移除信号

cpp 复制代码
connect(stackedWidget, &QStackedWidget::widgetRemoved, this, &MyClass::onPageRemoved);
相关推荐
Murphy_lx1 小时前
Lambda表达式
开发语言·c++
yangpipi-1 小时前
C++并发编程-23. 线程间切分任务的方法
开发语言·c++
love530love2 小时前
【保姆级教程】阿里 Wan2.1-T2V-14B 模型本地部署全流程:从环境配置到视频生成(附避坑指南)
人工智能·windows·python·开源·大模型·github·音视频
爬虫程序猿2 小时前
利用 Java 爬虫获取淘宝商品 SKU 详细信息实战指南
java·开发语言·爬虫
F2E_Zhangmo2 小时前
基于cornerstone3D的dicom影像浏览器 第五章 在Displayer四个角落显示信息
开发语言·前端·javascript
楼田莉子2 小时前
C++算法专题学习——分治
数据结构·c++·学习·算法·leetcode·排序算法
He1955012 小时前
Go初级之十:错误处理与程序健壮性
开发语言·python·golang
m0_738120723 小时前
CTFshow系列——PHP特性Web93-96
开发语言·安全·web安全·php·ctfshow