QT Layout布局,隐藏其中的某些部件后,不影响原来的布局

最近在工作时,被要求,需要将布局中的某些部件隐藏后,但不能影响原来的布局。

现在记录解决方案!

一、水平布局(垂直布局一样)

ui中的布局

效果:

按钮可以任意隐藏,都不影响其中布局。

隐藏代码:

cpp 复制代码
ui->pushButton_1->hide();    // 需要使用hide()
QSizePolicy retain = ui->pushButton_1->sizePolicy();    // 获取控件的大小调整策略
retain.setRetainSizeWhenHidden(true);    // 设置控件被隐藏时,任然保持在布局中的位置大小
ui->pushButton_1->setSizePolicy(retain);    // 重新设置大小策略

需要使用到**hide()**函数。

显示代码:

cpp 复制代码
ui->pushButton_1->setHidden(false);
// 也可以  ui->pushButton_1->show();

这种是在ui布局中的

二、网格布局 GridLayout (其他布局类似)

代码中自定义控件的布局

实现效果:

将第一个,第三个,第七个按钮给隐藏掉了,但是并不影原来的布局。

布局代码:

cpp 复制代码
QGridLayout *gLayout = new QGridLayout(this);       
QList<QPushButton *> pList;                         
for (int i = 0; i < 3; i++) {                       
    for (int j = 0; j < 3; j++) {                   
        QPushButton *btn = new QPushButton(this);   
        btn->setText("我是按钮");                       
        pList.append(btn);  // 添加到链表,用于隐藏部件按钮       
        btn->hide();        // 1.需要先隐藏              
        gLayout->addWidget(btn, i, j);  // 2.再添加到布局 
    }                                               
}                                                   
// 上面被隐藏了,这里显示出来                                    
for (QPushButton *btn : pList) {                    
    btn->setHidden(false);                          
} 
                                                  
this->setLayout(gLayout);

注意,需要先隐藏控件后,再添加到布局管理器中!

为什么需要这样呢?某些场景下不这样操作,无法达到最终效果!

隐藏代码:

cpp 复制代码
pList[0]->hide();    // 需要使用hide()                        
QSizePolicy retain = pList[0]->sizePolicy(); 
retain.setRetainSizeWhenHidden(true);        
pList[0]->setSizePolicy(retain);             
// ... 其他按钮隐藏类似,修改索引即可

需要恢复显示,可以使用 setHidden 函数或者 show 函数。

完!

相关推荐
尘中远4 小时前
Qwt 7.0 新特性介绍 — 更现代、更强大的Qt数据可视化库
qt·qwt·科学绘图·曲线图
会飞的胖达喵7 小时前
基于qt开发的RedisDesk
开发语言·qt
油炸自行车7 小时前
【Qt】运行 `windeployqt.exe` 打包Qt发布包,遇到警告的解决方法 (Warning: Cannot find any.....)
开发语言·qt·vs·打包·windeployqt·软件部署
Westward-sun.8 小时前
PyQt5入门实战:从零实现一个表达式输入式计算器(附完整代码)
开发语言·qt
Stone_OverLooking9 小时前
vscode 配置Qt qmake项目
ide·vscode·qt
sycmancia9 小时前
Qt——应用程序中的主窗口
开发语言·qt
blog.pytool.com9 小时前
Ubuntu + VSCODE +aarch64 +qt +qmake +clangd
linux·qt·ubuntu
不懒不懒10 小时前
【零基础学 PyQt5:环境搭建、Qt Designer 配置、UI 转 PY、窗口开发全流程】
开发语言·qt·ui
秋月的私语10 小时前
遥感影像拼接线优化工具:基于Qt+GDAL+OpenCV的从二到三实践
开发语言·qt·opencv
ol木子李lo11 小时前
Qt6 替代废弃 QMediaPlaylist 的解决方案
c语言·c++·vscode·qt·个人开发·visual studio·qt6.3