QStackedLayout 实现遮罩层

cpp 复制代码
QTabWidget 包含 QStackedWidget;
QStackedWidget 包含 QStackedLayout。

大家且看QStackedWidget的源码

cpp 复制代码
QStackedWidget::QStackedWidget(QWidget *parent)
    : QFrame(*new QStackedWidgetPrivate, parent)
{
    Q_D(QStackedWidget);
    d->layout = new QStackedLayout(this); //重点1
    connect(d->layout, SIGNAL(widgetRemoved(int)), this, SIGNAL(widgetRemoved(int)));
    connect(d->layout, SIGNAL(currentChanged(int)), this, SIGNAL(currentChanged(int)));
}

int QStackedWidget::addWidget(QWidget *widget)
{
    return d_func()->layout->addWidget(widget); //重点2
}

在构造函数里面创建一个QStackedLayout,之后addWidget直接用QStackedLayout的函数添加,其它的成员函数几乎都是这样。

看到这里时我有个疑问,既然都是直接套用的QStackedLayout了,那为啥不干脆直接用呢?难道因为是继承了QFrame想额外添加个边框么

函数部分

其它的函数自不必说了,和QStackedWidget如出一辙,但QStackedLayout还有个特殊的成员函数

setStackingMode

设置被管理的子QWidget的显示模式

cpp 复制代码
QStackedLayout::StackOne
//每次就显示一个Widget,默认值
QStackedLayout::StackAll
//全部显示出来,堆叠在一起

使用示例

用StackAll很适合来做透明遮罩或者水印这些,因为QStackLayout会自动把子控件的大小保持一致,省掉了我们重写resize相关事件的代码。上代码:

cpp 复制代码
QStackedLayout *stackLayout = new QStackedLayout;
stackLayout->setStackingMode(QStackedLayout::StackAll);

//添加遮罩
QPushButton *btn = new QPushButton("我就是个遮罩...点下就没", this);
btn->setStyleSheet("background-color: rgba(0,0,0,120); color: white");
stackLayout->addWidget(btn);
connect(btn, &QPushButton::clicked, this, [=](){
    //隐藏遮罩
    btn->hide();
});

//添加底层内容
auto label = new QLabel("我是底层正常内容,一直可见", this);
label->setStyleSheet("color: red;");
stackLayout->addWidget(label);
this->setLayout(stackLayout);

看下效果:

除了直接隐藏遮罩外,也可以修改下堆布局的当前下标,让QLabel显示最前面,像这样修改下代码

cpp 复制代码
stackLayout->setCurrentIndex(1);

但有个前提,就是QLabel的背景不能透明的,不然就露馅了。

相关推荐
charlie11451419114 小时前
现代Qt开发教程(新手篇)2.3——QImage、QPixmap、QIcon 图像处理基础
开发语言·图像处理·qt
AoDeLuo16 小时前
SOEM2.0编译与Qt调用
qt·机器视觉
大树学长17 小时前
【QT开发】Windows 10 + Qt 5.15.2 手动编译安装 Qt OPC UA 模块完整记录
开发语言·windows·qt
小短腿的代码世界19 小时前
Qt低级网络编程与零拷贝技术在高频交易中的应用:从QTcpSocket到共享内存的全链路优化
开发语言·网络·qt
qq_4017004120 小时前
Qt 自定义无边框窗口:标题栏、拖拽移动与缩放
开发语言·qt
xiaoye-duck1 天前
Qt 信号与槽深度解析:connect 用法、自定义信号槽与 Lambda 实战
开发语言·qt
郝学胜-神的一滴1 天前
Qt 高级开发 008: 使用QSetting记住上次打开路径
开发语言·c++·qt·开源软件
W.W.H.1 天前
Qt 应用防多开:极简单例方案
开发语言·qt·单例模式·共享内存
qq_401700411 天前
Qt 中获取程序路径、用户目录、桌面路径等常用特殊路径
开发语言·qt
LostSpeed1 天前
QT5 - 添加Astyle外部格式化工具
qt·astyle