用户选择界面

就我们在实际开发的时候可能需要面对这样一个界面

做个demo试试看

其实我们可以分解一下这个界面

就是除了控制相关的内容,最主要的就是这个界面之上,有一个个动态的输入的控件,上面都是学生的信息、头像等等数据,而且这个数据是动态变化的,也就是说主框架来条消息,我这个exe里的数据就要变动

那问题来了,这个部分怎么实现呢?不可能是让代码去一个个把空年间直接定位,这显然不显示,所以要用更自动化的方法-->栅格布局和scrollArea

栅格布局不用多说,就是可以栅格化摆放控件的一种布局,是Qt特有的部分

而scrollArea则是一个特殊的控件,在里面的内容如果超过当前scrollArea,则会令该控件自适应地生成滚动条

在实际开发中遇到了几个问题:

1.实际操作中,我们该如何使用栅格布局?

因为初始的时候我们在整个代码中是不带元素的,所以不能提前在我们需要的地方提前布置上栅格布局,这也为我们后面的一个问题出现奠定了基础。

由上,在实际的开发中栅格布局只能通过代码实现。我们在类中声明一个栅格布局的指针:

注意c++中的指针一定要给空间,也就是后面的这个new QGridLayout()是必须的,否则可能会导致一些不必要的错误信息出现。

因为我们的layout是给的指针,所以如果中途没有单独析构,那么整个指针会存续整个软件的生命周期中,所以我们实际开发中只需要对需要用到该布局的部分进行->setLayout(QLayout *) 操作即可。

2.向layout中添加部件

首先我们要确定layout每个部件的宽度,也就是最小大小。不然在实际的开发过程中,layout特性很可能就会导致宽度不够从而使得部件挤在一起,所以我们需要设置一下

这里有个问题,就是每行每列的长度都只能单独设定,两个方法中的参数,一个是当前行、列,第二个才是具体的数值。而不是设定一个总的外推到所有的行列,所以在这里我们也是每次更新数据的时候就修改一次即可。

添加部件的方法很简单,就是向其中输入命令,包含需要输入的widget,第几行,第几列。这里输入的temp是我自定义的控件

3.给scrollArea绑定了gridlayout,并向其中输入了控件之后,为什么没出现进度条?

因为scrollArea并不是一个独立的控件,其包含两部分,一部分是gridlayout本体,还有一个部分是scrollAreaWidgetContents,这是一个附属的widget控件,真正的内容要输入到scrollAreaWidgetContents中才可以自动地生成进度条,否则就不行

也就是说不论是我们的QGridLayout还是别的什么,都应该是直接输入到scrollAreaWidgetContents,这样就不会出现之前的问题了,控件也可以正常运行了。

7-3修改

其实完全没必要用gridlayout来进行这个修改,事实上有一个更简单的方法,就是直接一个个的插入widget,然后对应的位置就直接给它指定了(注:我们这里的窗体大小是要求不能变化的,如果要要求可以变化,则还是需要用到layout)

具体可以上代码

如果需要遍历整个ScrollArea的话,则可以如下:

Qt栅格布局、ScrollArea和用户选择界面的更多相关文章

  1. Winform开发框架之权限管理系统改进的经验总结(2)-用户选择界面的设计

    在上篇总结随笔<Winform开发框架之权限管理系统改进的经验总结(1)-TreeListLookupEdit控件的使用>介绍了权限管理模块的用户管理部分,其中主要介绍了其中的用户所属公司 ...

  2. 编写Java程序,使用Swing布局管理器与常用控件,实现用户登录界面

    返回本章节 返回作业目录 需求说明: 使用Swing布局管理器与常用控件,实现用户登录界面 实现思路: 创建用户登录界面的类LoginFrame,在该类中创建无参数的构造方法,在构造方法中,设置窗体大 ...

  3. Bootstrap 框架 栅格布局系统设计原理

    如果你是初次接触Bootstrap,你一定会为它的栅格布局感到敬佩.事实上,这个布局系统提供了一套响应式的布局解决方案. 既然这么好用,那他是如何用CSS来实现的呢? 我特意去Bootstrap官方下 ...

  4. android中选择控件与选择界面自然过度效果的实现--一种新的交互设计

    转载请标明出处: http://blog.csdn.net/jianghejie123/article/details/40648931 在安卓中经常遇到须要选择一个东西的功能,比方选择日期.选择文件 ...

  5. 【转及总结】Bootstrap 框架 栅格布局系统底层设计原理

    如果你是初次接触Bootstrap,你一定会为它的栅格布局感到敬佩.事实上,这个布局系统提供了一套响应式的布局解决方案. 既然这么好用,那他是如何用CSS来实现的呢? 我特意去Bootstrap官方下 ...

  6. [Qt Creator 快速入门] 第8章 界面外观

    一个完善的应用程序不仅应该有实用的功能,还要有一个漂亮的外观,这样才能使应用程序更加友好,更加吸引用户.作为一个跨平台的UI开发框架,Qt提供了强大而灵活的界面外观设计机制.这一章将学习在Qt中设计应 ...

  7. Android6.0动态申请权限那些坑--以及避免用户选择不再提示后无法获取权限的问题

    Android 6.0 为了保护用户隐私,将一些权限的申请放在了应用运行的时候去申请, 比如以往的开发中,开发人员只需要将需要的权限在清单文件中配置即可,安装后用户可以在设置中的应用信息中看到:XX应 ...

  8. Qt Quick 布局介绍

    在 Qt Quick 中有两套与布局管理相关的类库,一套叫作 Item Positioner(定位器),一套叫作 Item Layout(布局). 定位器包括 Row(行定位器).Column(列定位 ...

  9. uniapp+nvue实现仿微信/得物相册插件:选择界面 +自定义相册+图片视频过滤

    本篇文章基于uniapp 框架+ nvue,实现了uniapp仿微信/得物相册选择功能实例项目,该插件实例实现了以下功能: 1: 相册过滤 2: 图视频过滤 3: 界面UI定制化 4: 栅格列数定制化 ...

  10. WPF整理-使用用户选择主题的颜色和字体

    “Sometimes it's useful to use one of the selected colors or fonts the user has chosen in theWindows ...

随机推荐

  1. 单台主机MySQL多实例部署

    二进制安装mysql-5.7.26 [root@mysql ~]# cd /server/tools/ [root@mysql tools]# ll total 629756 -rw-r--r-- 1 ...

  2. UDP协议编程

    #接收代码 import socket # 使用IPV4协议,使用UDP协议传输数据 s=socket.socket(socket.AF_INET, socket.SOCK_DGRAM) # 绑定端口 ...

  3. 聊聊Vim的工作原理

    聊聊Vim的工作原理 日常里一直在用Vim这个编辑器,前阵子学习关于Linux中的fd(文件描述符)时,发现vim的进程描述符会比上一个自动加一,后续了解到vim的工作原理后,解开了这个疑问,所以记录 ...

  4. 【题解】CF1720C

    题意简述 给你一个 01 矩阵,每一次你可以在这个矩阵中找到一个 \(L\) 型,将它全部变成 0.\(L\) 型的定义是在一个 \(2\times2\) 矩阵中,除开一个角之外的图形,其中必须包含至 ...

  5. 云计算_OpenStack

    部署方式-Fuel 注:部署失败且Fuel方式已过时. 部署方式-packstack 注:基于系统版本CentOS 7.9 2009部署 系统基本设置 设置静态IP=192.168.80.60 设置h ...

  6. Pycharm和IDEA利用Git操作Github仓库

    1. Git Bash 选择一个本地代码仓库文件夹:D:/Github_Code/新建文件夹,然后在此目录打开git bash 依次进行: git init //首次需执行,之后可不用 git add ...

  7. DevOps|1024程序员节怎么做?介绍下我的思路

    1024,祝每个程序员小哥哥小姐姐节日快乐. 因为在研发效能部门,我支持过几次 1024 程序员节的活动,所以经常有朋友问我1024 程序员节怎么做,本篇就是简单介绍下我的思路,希望对你有用. 102 ...

  8. 【深入浅出 Yarn 架构与实现】2-3 Yarn 基础库 - 服务库与事件库

    一个庞大的分布式系统,各个组件间是如何协调工作的?组件是如何解耦的?线程运行如何更高效,减少阻塞带来的低效问题?本节将对 Yarn 的服务库和事件库进行介绍,看看 Yarn 是如何解决这些问题的. 一 ...

  9. AIR32F103(五) FreeRTOSv202112核心库的集成和示例代码

    目录 AIR32F103(一) 合宙AIR32F103CBT6开发板上手报告 AIR32F103(二) Linux环境和LibOpenCM3项目模板 AIR32F103(三) Linux环境基于标准外 ...

  10. 表单的子元素可不在form标签内

    表单是网页用于向服务器发送数据的元素.其用法类似下面: <form method="POST" action="/login"> <input ...