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

相关文章

Windows的CMD窗口如何查看并杀死nginx进程

《Windows的CMD窗口如何查看并杀死nginx进程》:本文主要介绍Windows的CMD窗口如何查看并杀死nginx进程问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows的CMD窗口查看并杀死nginx进程开启nginx查看nginx进程停止nginx服务

MySQL分区表的具体使用

《MySQL分区表的具体使用》MySQL分区表通过规则将数据分至不同物理存储,提升管理与查询效率,本文主要介绍了MySQL分区表的具体使用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、分区的类型1. Range partition(范围分区)2. List partition(列表分区)3. H

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

Go语言中Recover机制的使用

《Go语言中Recover机制的使用》Go语言的recover机制通过defer函数捕获panic,实现异常恢复与程序稳定性,具有一定的参考价值,感兴趣的可以了解一下... 目录引言Recover 的基本概念基本代码示例简单的 Recover 示例嵌套函数中的 Recover项目场景中的应用Web 服务器中

CnPlugin是PL/SQL Developer工具插件使用教程

《CnPlugin是PL/SQLDeveloper工具插件使用教程》:本文主要介绍CnPlugin是PL/SQLDeveloper工具插件使用教程,具有很好的参考价值,希望对大家有所帮助,如有错... 目录PL/SQL Developer工具插件使用安装拷贝文件配置总结PL/SQL Developer工具插

SpringBoot3中使用虚拟线程的完整步骤

《SpringBoot3中使用虚拟线程的完整步骤》在SpringBoot3中使用Java21+的虚拟线程(VirtualThreads)可以显著提升I/O密集型应用的并发能力,这篇文章为大家介绍了详细... 目录1. 环境准备2. 配置虚拟线程方式一:全局启用虚拟线程(Tomcat/Jetty)方式二:异步

使用Python实现base64字符串与图片互转的详细步骤

《使用Python实现base64字符串与图片互转的详细步骤》要将一个Base64编码的字符串转换为图片文件并保存下来,可以使用Python的base64模块来实现,这一过程包括解码Base64字符串... 目录1. 图片编码为 Base64 字符串2. Base64 字符串解码为图片文件3. 示例使用注意

使用Python实现获取屏幕像素颜色值

《使用Python实现获取屏幕像素颜色值》这篇文章主要为大家详细介绍了如何使用Python实现获取屏幕像素颜色值,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、一个小工具,按住F10键,颜色值会跟着显示。完整代码import tkinter as tkimport pyau

Linux使用scp进行远程目录文件复制的详细步骤和示例

《Linux使用scp进行远程目录文件复制的详细步骤和示例》在Linux系统中,scp(安全复制协议)是一个使用SSH(安全外壳协议)进行文件和目录安全传输的命令,它允许在远程主机之间复制文件和目录,... 目录1. 什么是scp?2. 语法3. 示例示例 1: 复制本地目录到远程主机示例 2: 复制远程主