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

相关文章

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

element-ui下拉输入框+resetFields无法回显的问题解决

《element-ui下拉输入框+resetFields无法回显的问题解决》本文主要介绍了在使用ElementUI的下拉输入框时,点击重置按钮后输入框无法回显数据的问题,具有一定的参考价值,感兴趣的... 目录描述原因问题重现解决方案方法一方法二总结描述第一次进入页面,不做任何操作,点击重置按钮,再进行下

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者