QT实例1--使用UI文件创建登陆窗口

2024-08-25 21:44

本文主要是介绍QT实例1--使用UI文件创建登陆窗口,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基础信息
  • 平台:window 10

  • QT版本
    :5.14.2

  • 时间:2024.08.25

  • 本工程是QLayout专题,使用UI文件创建一个登陆窗体

  • 本例程原始资料来源于B站,UP主“爱编程的大丙”的视频教程《QT开发编程-入门基础教程QT5–6.2窗口布局举例-制作一个登陆界面》

  • 本笔记,用于实践上述例程,并进行笔记整理,提取最重要的干货信息。

创建工程

创建一个工程,工程名称=Login
在这里插入图片描述
使用默认的MainWindow工程即可
在这里插入图片描述

工程创建好以后,右键工程名称,添加一个“QT设计师界面类”,注意不要选错。

在这里插入图片描述
一般登陆窗口用对话框类即可。“QT设计师界面类”,选择使用不带按钮的即可。
在这里插入图片描述

新建的“QT设计师界面类”,名称=Login

在这里插入图片描述

控件布局

重点来临:研究QT的布局,要掌握一些最基本的知识,如水平布局,垂直布局,网络布局。在我看完了一本《QT5开发及实例》,并且手敲了一些代码,对QT有了一个基本的认识后,对一些知识点的理解和掌握,与脑海中想象的有偏差,这也是我想做几个练手的小例子来加深理解的原因。

用实战来纠正脑海中的偏差。

QT中的布局,就是这样一个例子。拖一拖、点一点、会把人搞蒙圈,这一点对入门的新手不太友好,还是要学习一下的。使用C++或C#在VS中开发,相比来说对新手要友好多了。

  • 给登陆界面设计一个标题,插入一个QLabel,起名叫“密码”,再把这个QLabel放入一个Widget中。如下2图:

在这里插入图片描述
在这里插入图片描述

  • 把QLable拖入到Widget中,未进行任何布局时,是下面的样子。

请注意:不要想当然的、惯性思维的去手动去调整位置,停下来,不要动!

请注意:不要想当然的、惯性思维的去手动去调整位置,停下来,不要动!

请注意:不要想当然的、惯性思维的去手动去调整位置,停下来,不要动!

在这里插入图片描述

  • 观察此时,右侧对象列表的状态,在未进行任何布局的情况下,图标右下角有一个红色的禁止图标。如下图:
    在这里插入图片描述
  • 点击工具栏中的“水平布局”图标,QT会自动调整控件在Widget内水平布局,自动排列,无需手动操作。

在这里插入图片描述

  • “水平”布局,如下图所示,注意观察右侧红色禁止图标消失了,更新变成了水平布局的图标。
    在这里插入图片描述

登陆窗口中的其它控件,如用户名、密码、输入框QLineEdit、单选按钮QRadioButton、复选框QCheckBox、按钮QPushButton等,不再赘述,见下图。

特别注意:用户名及输入框,和密码及输入框,请采用“网格布局”。

这相当于2行2列的矩阵,想像一下excel表格,然后把这4个控件,放入到了这2行2列的位置中去。网格布局,会使用户名的输入框与密码输入框是对齐的状态。无论窗体如何拉伸,它们都是对齐的。

在这里插入图片描述

  • 先中5个水平对齐,再点击工具栏的“垂直布局”,把5个水平布局的Widget容器再垂直布局,如下图所示。

这怎么这么难看?Q

T是如何处理左对齐、居中、右对齐的?

QT是如何处理控件间的间距的?

QT是如何处理窗体在拉伸时,控件的布局的?

重点来临:

“水平空格”和“垂直空格”来解决此问题。

好多网友也称“水平弹簧”、“垂直弹簧”

还有直接叫“弹簧”的、叫“刀哥”的。高手在民间啊~!

在这里插入图片描述

在这里插入图片描述

“弹簧”登场后,所见即所得,知道左对齐、居中、右对齐是怎么来的了吧~!一根弹簧往一侧挤,2根弹簧往中间挤,这下,不难理解了。

居中也不是问题了,Ctrl+R运行后,拉伸窗体看一看效果~!

在这里插入图片描述

弹簧可以设置sizeType,默认是Expanding扩展的,可以设置为Fixed固定的,然后再指定宽度,这就是设计控件间间距的方法。设置为FIxed后,窗体拉伸,控件间的间距保持不变。

在这里插入图片描述

扩展的,可以设置为Fixed固定的,然后再指定宽度,这就是设计控件间间距的方法。设置为FIxed后,窗体拉伸,控件间的间距保持不变。

这篇关于QT实例1--使用UI文件创建登陆窗口的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1106734

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他