Qt布局操作
Qt界面布局是用来界面上控件排序的,例如对齐、自适应分辨率等都要用到布局。
Qt界面布局跟Visual Studio系列完全不一样,VS系列的操作很简单,一般情况下,很快就能入手了,但比较死板(特别是老版本,对自适应分辨率界面设计支持很差,就像VC6,很麻烦)
ps:这一组操作,很熟悉,很方便。唯一不支持就是自适应分辨率,其他都很好,特别是对齐、排列很好用
Qt界面布局操作要复杂一点,需要一些技巧。
Qt布局,实际上他把他抽象了几个控件。
那么如何使用Qt进行布局设计呢?
- 要做好布局,首先确定该界面上有多少控件哪些控件。这个很重要。如果不确定,后面一点点增加,有时候不好拖,可能需要重新布局。例如图
上面有5个label,2个LineEdit,3个PushButton,1个TableView;2个Horizontal Spacer(为了占位置,后面会讲到这个辅助作用)。这些控件,最好在做布局前都拖好,位置大概调整下。换句话说,如果界面上没有控件,或很少控件,就很难做布局了,也没必要做布局。
- 设置布局的时候,一定要遵循从里到外的顺序这个原则。
就拿这个图来说,我们要划分的,先切成4块内容,这4块内容组成一个纵向布局,而每个块都是一个横向布局(除了最后一个tableview)。例如蓝色框框内,第一行就是第一块内容,是一个横向布局。尽量先拆分成先横向再纵向,或先纵向再纵向。不要一会纵向一会横向,这样容易造成混乱,导致后面布局不如意。
如果界面足够复杂,可以把一个界面理解成由多个子界面组成(每个子界面都是一个独立的Widget或Frame),而每个子界面就相当于一个控件(相对于大一级界面)。布局顺序也是先布局子界面,然后大一级界面。
这里的界面级数最好不要超过3级,否则乱。
- 同一个布局内的控件,都是自动对齐。
此时,控件位置、大小会随着主界面变大变小而变化。
一般来说,存在以下几种需求:
- 像第1块内容里的 “业务代码”、“输入0~255数字”、“0xFF”以及他们中间的那个LineEdit,我们希望在主界面拉大的时候,这些控件都是在靠左边显示的。
做法:我们只要在最右边,添加一个HorizontalSpacer即可,然后这个Spacer(就相当于一个控件)跟前面的几个控件组成一个横向的布局。
- 像第3个块内容里三个PushButton,我们希望在主界面拉大的时候,这些控件都是在靠右边显示的。
做法:我们只要在最左边,添加一个HorizontalSpacer即可,然后这个Spacer(就相当于一个控件)跟前面的几个控件组成一个横向的布局。
- 固定大小,在第1块内容里面,LineEdit控件默认是随着窗体变宽而变宽的,(高度默认是固定大小的)。但实际情况下,有时候,有这样需求,我们不希望LineEdit是固定大小的,不要随着窗体变大而变大。
做法:
选择LineEdit的属性(单选该控件,然后在右下角的属性编辑器)
这里minimumSize是指当界面缩小时,最小的值。
如果此值=maximumSize的值,那么就是固定大小了,不管界面怎么变都是这个值。
如果此值<maxmumSize,那么就是说控件会随着界面变化;在minimumSize与maxmumSize之间变化,这就是我们常见一般界面,会随着界面变大而变大,而变大到一定程度就不会再变化了,就是这个道理。
上面说的是横向的拉升,同理,如果纵向拉升也是这样操作。如果纵向跟横向都Fixed,那么就是固定大小了。(有些控件是默认是固定大小的,有些是默认一个方向固定大小的)
反之,如果我们希望我们控件随着界面大小而变化,那么在这两个地方,我们设置成Expanding即可。当然minimumSize、maxmumSize还是跟前面一个道理。
- 位置我不想平均分,也不是都靠左边也不是都靠右边。就是说我要3/7分,我要1/9分,等。这种需求我认为不多,一般来说,控件部分是固定位置,部分是随着变化而变化的。
这些比例分配的,都是要在同一个布局内完成,不能跨布局。
例如拿第3块内容来说,我们希望三个按钮在界面的右边1/2,其中“增加”占右边的1/6宽度,“修改”占2/6宽度,“删除”占3/6宽度。
做法:
1. 选择该布局,然后再属性编辑器里找到Layout
2. 在layoutStretch输入数据,注意一个控件一个数字,中间逗号不要弄丢了。0是默认,就是默认控件自身的。这里数字是指总数的几份,例如6,1,2,3 其中6表示6/12的意思,1表示1/12的意思。
效果如下:
同样纵向布局里若要调整比例也是这样操作的。
- 布局,控件之间间距太宽,我怎么调整?(边距的设置)
做法:
找到选择该布局,然后再属性编辑器里找到Layout
从上到下,分别是:这个布局与外部布局的左边距、上边距、右边距、下边距(这些是跟外部布局来说的,默认值是9,如果是0表示”紧挨着”。),这个布局内部控件之间的间距(相对内部控件而言,默认值是6)。
每个布局都有这样的独立参数的,因此不要默认9,就得改。
PS:有些子界面,例如是在Widget里面的控件布局边距,可能在属性编辑器的下方,需要下翻到下面!!
好了,基本上我们都学会了常规布局,总结下:
1.
先设计界面,需要哪些控件、大致放哪里
2.
然后按一定顺序先一组组布局,例如先横向布局,再纵向(先内部布局)
3.
每个布局都调整好控件排序,固定大小?靠右边?可以扩展?
4.
如果纵横比较复杂,可以利用Widget、Frame等
- 最后一点,很重要,就是大的界面布局
a)
一般界面是Dialog或Widget,一般默认是没有布局
b)
所以这布局很重要,否则没有效果
c)
这个布局一定要在前面,布局好之后再弄,否则要重新布局
Qt布局操作的更多相关文章
- 浅谈qt 布局器
在一个颜值当道的今天,无论买衣服,买车还是追星,颜值的高低已经变成了大家最看重的(不管男性女性都一样,千万别和我说你不是):而对于程序猿来说,开发一款软件,不再只注重逻辑和稳定性,美观和用户友好性也是 ...
- Qt 布局管理器
在一个颜值当道的今天,无论买衣服,买车还是追星,颜值的高低已经变成了大家最看重的(不管男性女性都一样,千万别和我说你不是):而对于程序猿来说,开发一款软件,不再只注重逻辑和稳定性,美观和用户友好性也是 ...
- Qt QAxObject操作excel文件过程总结(转):
正好同事问道Qt下操作excel. 转自:http://blog.csdn.net/a156392343/article/details/48092515 配制方面: 1.确保Excel软件在本地服务 ...
- 第六章 Qt布局管理器Layout
第六章 Qt布局管理器Layout 大家有没有发现一个现象,我们放置一个组件,给组件最原始的定位是给出这个控件的坐标和宽高值,这样Qt就知道这个组件的位置.当用户改变窗口的大小,组件还静静地呆在原来的 ...
- 2.大约QT数据库操作,简单的数据库连接操作,增删改查数据库,QSqlTableModel和QTableView,事务性操作,大约QItemDelegate 代理
Linux下的qt安装,命令时:sudoapt-get install qt-sdk 安装mysql数据库,安装方法參考博客:http://blog.csdn.net/tototuzuoquan ...
- Qt之操作系统环境
来源:http://blog.sina.com.cn/s/blog_a6fb6cc90102uy9k.html Qt中操作系统环境,官方解释如下: QStringList QProcess::syst ...
- qt 布局
说到qt布局,比起之前用的MFC好了许多,而且qt支持qss,可以更好的美化界面.qt提供了几种常见的布局管理 窗体布局,这对客户端程序来说是一个福音,再也不用操心程序界面放大缩小时界面控件怎么变化, ...
- 初识Qt布局管理器
Qt布局管理器的类有4种,它们分别为QHBoxLayout.QVBoxLayout.QGridLayout和QStackLayout.其中,QHBoxLayout实现水平布局,QVBoxLayout实 ...
- Qt之操作数据库(SQLite)实例
QtSql模块提供了与平台以及数据库种类无关的访问SQL数据库的接口,这个接口由利用Qt的模型视图结构将数据库与用户界面集成的一套类来支持.QSqlDatabase对象象征了数据库的关联.Qt使用驱动 ...
随机推荐
- ActiveMQ (一) 初识ActiveMQ
了解JMS JMS即Java消息服务(Java Message Service)应用程序接口是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中发送消息,进 ...
- gitlab 接入 openldap、AD
=============================================== 20171009_第2次修改 ccb_warlock === ...
- Fiddler如何模拟弱网环境进行测试
1.模拟弱网环境 打开Fiddler,Rules->Performance->勾选 Simulate Modem Speeds,勾选之后访问网站会发现网络慢了很多 2.Fiddler弱网的 ...
- TCP 建立连接:三次握手
转自:http://www.cnblogs.com/winner-0715/p/5032661.html 感谢! TCP 建立连接过程 TCP是因特网中的传输层协议,使用三次握手协议建立连接,下面是T ...
- Python配置文件实现
实现目标: 支持配置文件继承 支持本地配置文件 支持配置文件别名 简单的配置文件操作 最新的代码可以参考 https://github.com/blackmatrix7/matrix-toolkit/ ...
- centos6快速搭建nginx
step1:配置本地 yum库,保存 $vi /etc/yum.repos.d/nginx.repo [nginx] name=nginx repo baseurl=http://ngin ...
- 80、Flask用法简析
本篇导航: 基本使用 模板.请求和响应 Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于 ...
- 初学Vue之数量加减
效果图: HTML: <div class="count3"> <ul> <li v-for="(key,idx) in liList&qu ...
- 如何在java注解中加入原生html标签内容
你是否也遇到过类似的事情.想在java注解加入类似于下面这种注释: 结果出来却变成了这样 ,标签被解析了, 这怎么办呢 : 且看分解 我们在注解中直接放入下边这样的代码: <Response&g ...
- TLD算法原理--学习理解之(二)
正如名字所示,TLD算法主要由三个模块构成:追踪器(tracker),检测器(detector)和机器学习(learning). 对于视频追踪来说,常用的方法有两种,一是使用追踪器根据物体在上一帧的位 ...