用户选择界面

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

做个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. nginx干货文档

    文档地址:https://files.cnblogs.com/files/sanduzxcvbnm/跟冰河学习Nginx技术.pdf

  2. 5_SpringMVC

    一. 什么是MVC框架 MVC全名是Model View Controller, 是模型(model), 视图(view), 控制器(controller)的缩写, 一种软件设计典范, 用一种业务逻辑 ...

  3. css语言

    css:样式表.级联样式表.层叠样式表 css写在style标签里面,放在head标签中:大括号中写键值对语法 color:文字颜色 Font-family:字体 Font-size:字号 text- ...

  4. localStorage概要

    在HTML5中,新加入了一个localStorage特性,这个特性主要是用来作为本地存储来使用的,解决了cookie存储空间不足的问题(cookie中每条cookie的存储空间为4k),localSt ...

  5. 图片 css剪切,等比例缩放

    object-fit: cover; .img1 {//自定义图片宽高,并且等比例缩放 width: 200px; height: 400px; object-fit: cover; }

  6. Vue中、参数传递以及重定向

    1.参数传递 关键部分代码 1.参数传递 <router-link :to="{name:'information',params:{id:1}}">用户信息</ ...

  7. win10操作系统下Android环境配置

    Windows命令行调试unity(Android)应用环境变量配置准备步骤:先下载好我们需要的Android SDK和JDK. Android SDK推荐地址:http://tools.androi ...

  8. 用昇腾AI护航“井下安全”

    摘要:基于CANN(异构计算架构)打造的"智能矿山安全生产管理平台",能够更便捷和更高效地服务于更多矿山安全生产建设. 本文分享自华为云社区<华为携手云话科技助力矿山智能化, ...

  9. CVE-2021-44832 log4j_2.17.0 RCE复现与吐槽

    先说一句,这傻x洞能给cve就离谱,大半夜给人喊起来浪费时间看了一个小时. 先说利用条件: 需要加载"特定"的配置文件信息,或者说实际利用中需要能够修改配置文件(你都能替换配置文件 ...

  10. 设计模式学习(二十四):Spring 中使用到的设计模式

    设计模式学习(二十四):Spring 中使用到的设计模式 作者:Grey 原文地址: 博客园:设计模式学习(二十四):Spring 中使用到的设计模式 CSDN:设计模式学习(二十四):Spring ...