当前位置: 首页 > article >正文

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

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

现在记录解决方案!

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

ui中的布局

效果:

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

隐藏代码:

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

需要使用到hide()函数。 

显示代码:

ui->pushButton_1->setHidden(false);
// 也可以  ui->pushButton_1->show();

这种是在ui布局中的

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

代码中自定义控件的布局

实现效果:

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

布局代码:

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

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

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

隐藏代码:

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

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

完!


http://www.kler.cn/news/312464.html

相关文章:

  • 【数据结构】5——哈夫曼树(Huffman Tree)
  • Linux网络——手撕TCP服务器,制定应用层协议,实现网络版计算器
  • websocketpp服务器搭建
  • 使用knn算法对iris数据集进行分类
  • 人力资源数据集分析(一)_t-test、卡方检验和描述性统计
  • Spring Cloud常见面试题
  • 电子电气架构---智能汽车应该是怎么样的架构?
  • 24.9.18学习笔记
  • opengl-redbook环境搭建(静态库)
  • 『功能项目』事件中心处理怪物死亡【55】
  • Vue3:props实现组件通信
  • react 创建react项目
  • 高级java每日一道面试题-2024年9月14日-基础篇-如何处理事务中的性能问题?
  • 已知曲线满足正余弦函数,根据其峰值,还原出整条曲线
  • Bio-Linux-shell详解-1-从0开始
  • 【Ubuntu】虚拟机安装USB摄像头ROS驱动 usb_cam(最新方法)
  • ES5 在 Web 上的现状
  • [ffmpeg] packet
  • element-plus的菜单组件el-menu
  • 7--SpringBoot-后端开发、原理详解(面试高频提问点)
  • Web开发:ABP框架3——入门级别的接口增删改查实现原理
  • 基于SpringBoot的自习室预订系统
  • 莱卡相机sd内存卡格式化了怎么恢复数据
  • Volta无障碍的 JavaScript 工具管理器
  • Java 中使用 Redis 的几种方式优缺点对比
  • Linux 生成 git ssh 公钥
  • 站群服务器适用于哪些场景当中?
  • Linux服务器及应用环境快速部署、调试、迁移、维护、监控
  • Jenkins怎么设置每日自动执行构建任务?
  • 使用 nvm 管理 node 版本:如何在 macOS 和 Windows 上安装使用nvm