[Qt][布局管理器]详细讲解

embedded/2024/9/24 21:29:15/

目录


0.为什么?

  • 之前使⽤Qt在界⾯上创建的控件,都是通过"绝对定位"的⽅式来设定的,每个控件的所在位置,都需要计算坐标,最终通过setGeometrymove摆放过去
    • 这种设定⽅式其实并不⽅便,尤其是界⾯如果内容⽐较多,不好计算
    • 并且⼀个窗⼝⼤⼩往往是可以调整的,按照绝对定位的⽅式,也⽆法⾃适应窗⼝⼤⼩
  • 因此Qt引⼊布局管理器”(Layout)机制,来解决上述问题

1.注意事项

  • 一个Widget只能包含一个layout
    • 但是可以通过先创建一个新的Widget,再在这个新的Widget中添加一个Layout,即可达到"多个Layout"的目的
  • 布局管理器之间,可以进行嵌套

2.垂直布局

  • QVBoxLayout表⽰垂直的布局管理器
    • Layout只是⽤于界⾯布局,并没有提供信号
  • 核心属性
    • layoutLeftMargin:左侧边距
    • layoutRightMargin:右侧边距
    • layoutTopMargin:上方边距
    • layoutBottomMargin:下⽅边距
    • layoutSpacing:相邻元素之间的间距

3.水平布局

  • QHBoxLayout表⽰水平的布局管理器
  • 核⼼属性
    • layoutLeftMargin:左侧边距
    • layoutRightMargin:右侧边距
    • layoutTopMargin:上方边距
    • layoutBottomMargin:下⽅边距
    • layoutSpacing:相邻元素之间的间距

4.网格布局

  • QGridLayout⽤来实现⽹格布局的效果,可以达到N*M的这种⽹格的效果
  • 核心属性
    • layoutLeftMargin:左侧边距
    • layoutRightMargin:右侧边距
    • layoutTopMargin:上方边距
    • layoutBottomMargin:下⽅边距
    • layoutHorizontalSpacing:相邻元素之间水平方向的间距
    • layoutVerticalSpacing:相邻元素之间垂直⽅向的间距
    • layoutRowStretch:⾏⽅向的拉伸系数
      • 直接设置不明显,因为每个按钮的高度是固定的,需要把按钮的sizePolicy设置为QSizePolicy::Expanding,尽可能填充满布局管理器,才能看到效果
      • setSizePolicy()可设置的尺寸策略:
        • QSizePolicy::Ignored:忽略控件的尺⼨,不对布局产⽣影响
        • QSizePolicy::Minimum:控件的最⼩尺⼨为固定值,布局时不会超过该值
        • QSizePolicy::Maximum:控件的最⼤尺⼨为固定值,布局时不会⼩于该值
        • QSizePolicy::Preferred:控件的理想尺⼨为固定值,布局时会尽量接近该值
        • QSizePolicy::Expanding:控件的尺⼨可以根据空间调整,尽可能占据更多空间
        • QSizePolicy::Shrinking:控件的尺⼨可以根据空间调整,尽可能缩⼩以适应空间
    • layoutColumnStretch:列⽅向的拉伸系数
      • 最终按照每个控件对应比例来显示
      • 设置为0表示不参与拉伸,为固定值
  • 注意:添加控件时,设置⾏和列的时候,如果设置的是⼀个很⼤的值,但是这个值和上⼀个值之间并没有其他的元素,那么并不会在中间腾出额外的空间
  • 总结QGridLayout能够代替很多QHBoxLayoutQVBoxLayout的场景,毕竟嵌套的代码写起来时比较麻烦的
    • QGridLayout里面也能嵌套QHBoxLayoutQVBoxLayout
    • QHBoxLayoutQVBoxLayout里面也能嵌套QGridLayout

5.表单布局

  • QFormLayout属于是QGridLayout的特殊情况,专门用于实现两列表单的布局
    • 这种表单布局多⽤于让⽤⼾填写信息的场景,左侧列为提⽰,右侧列为输⼊框

6.Spacer

  • 使⽤布局管理器的时候,可能需要在控件之间添加⼀段空⽩,就可以使⽤QSpacerItem来表⽰
  • 核心属性
    • width:宽度
    • height:高度
    • hData:⽔平⽅向的sizePolicy
      • QSizePolicy::Ignored:忽略控件的尺⼨,不对布局产⽣影响
      • QSizePolicy::Minimum:控件的最⼩尺⼨为固定值,布局时不会超过该值
      • QSizePolicy::Maximum:控件的最⼤尺⼨为固定值,布局时不会⼩于该值
      • QSizePolicy::Preferred:控件的理想尺⼨为固定值,布局时会尽量接近该值
      • QSizePolicy::Expanding:控件的尺⼨可以根据空间调整,尽可能占据更多空间
      • QSizePolicy::Shrinking:控件的尺⼨可以根据空间调整,尽可能缩⼩以适应空间
    • vData:垂直方向的sizePolicy
      • 选项同上

http://www.ppmy.cn/embedded/94070.html

相关文章

电子器件的液冷-EAK液冷电阻器

随着科技的进步和制作工艺的发展,电能的使用逐步渗透到人类社会生活的方方面面,人们开始憧憬对海洋、天空甚至太空的进一步探索开发各种高性能、高功率的电子设备层出不穷。因此,对元器件冷却而言,不但需要越来越高的制冷效率以保…

基于单片机的智能风扇设计

摘 要: 传统风扇无法根据周围环境的温度变化进行风速的调整,必须人为地干预才能达到需求 。 本文基于单片机的智能风扇主要解决以往风扇存在的问题,其有两种工作模式: 手动操作模式和自动运行模式,人们可以根据需要进行模式选择。 在自动运行…

Redis 为什么读写性能高?

Redis 为什么读写性能高? Redis 作为一种开源的、基于内存的数据结构存储系统,以其卓越的读写性能而闻名。它被广泛应用于缓存、消息队列、实时数据处理等场景。那么,是什么使得 Redis 拥有如此高的读写性能呢?本文将从以下几个方…

Sass/Scss基础

安装sass npm install -g sass Sass/Scss释义 ASS版本3.0之前的后缀名为.sass,而版本3.0之后的后缀名.scss。 Sass (Syntactically Awesome Stylesheets) 是一个最初由 Hampton Catlin 设计并由 Natalie Weizenbaum 开发的层叠样式表语言。 Sass 是一个由buby语言编…

白骑士的Matlab教学进阶篇 2.3 信号处理

系列目录 上一篇:白骑士的Matlab教学进阶篇 2.2 数值计算 信号处理在现代工程和科学领域中扮演着至关重要的角色。MATLAB作为一个强大的数学计算平台,提供了丰富的工具和函数来帮助研究人员和工程师处理各种信号问题。本文将深入介绍MATLAB中信号处理的…

最详细!教你学习haproxy七层代理

一、工作原理 (1)包括 监听端口:HAProxy 会在指定的端口上监听客户端的请求。 例如,它可以监听常见的 HTTP 和 HTTPS 端口,等待客户端连接。请求接收:当客户端发起请求时,HAProxy 接收到请求。…

2024下半年国际学术会议一览表

在科技与人文的交汇点,2024年的国际学术会议季即将拉开帷幕,一系列聚焦于计算机科学与人工智能、工程与技术、教育与社会科学的盛会,不仅展示了全球学术研究的最新成果,更促进了跨学科交流与合作,为未来的科技发展与社…

搜维尔科技:ART应用于大规模跟踪 、 高精度测量 、培训和维护 、虚拟电影制作

ART应用于大规模跟踪 、 高精度测量 、培训和维护 、虚拟电影制作 搜维尔科技:ART应用于大规模跟踪 、 高精度测量 、培训和维护 、虚拟电影制作