嵌入式学习之QT学习----3 制作简单的QT界面(如:QQ登录界面)

article/2025/9/15 7:47:19

1、创建一个QT工程

new project —> Application —> Qt Widgets Application —> choose…(注意不要有中文路径)填写名称(我写的名称为class2)和创建路径(D:\qt\qt_demo\class2) —> 填写类名,这里基类要选择“QWidget”,这样一个QT工程就创建好啦。
在这里插入图片描述
qt的移植性非常强,一套代码我们不用修改太多,直接通用所有的平台。
说明:

  • QMain Window:主窗口类,主窗口具有主菜单栏、工具栏和状态栏,类似于一般的应用程序的主窗口。
  • QWidget:它是所有具有可视界面的基类,选择QWidget创建的界面对各种界面组件都可以支持。
  • QDialog:对话框类,可建立一个基于对话框的界面。

2、工程目录下的.pro工程文件分析

.pro文件是项目管理文件,文件名就是项目的名称,如:class2.pro
项目管理文件用于记录项目的一些设置,以及项目包含文件的组织管理。

#-------------------------------------------------
#
# Project created by QtCreator 2022-05-01T13:51:06
#
#-------------------------------------------------QT       += core gui
#往qt工程里面加入core gui模块greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
# 假如qt库的版本大于4 就加入一个widgets的模块
TARGET = class2
# 生成APP的名字
TEMPLATE = app
#编译产物的类型# The following define makes your compiler emit warnings if you use
# any feature of Qt which has been marked as deprecated (the exact warnings
# depend on your compiler). Please consult the documentation of the
# deprecated API in order to know how to port your code away from it.
DEFINES += QT_DEPRECATED_WARNINGS
#定义一个宏# You can also make your code fail to compile if you use deprecated APIs.
# In order to do so, uncomment the following line.
# You can also select to disable deprecated APIs only up to a certain version of Qt.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0#指定工程里面都有哪些cpp
SOURCES += \main.cpp \widget.cpp
#指定工程里面都有哪些头文件
HEADERS += \widget.h
#指定工程里面都有哪些ui文件
FORMS += \widget.ui

3、ui编辑器(界面文件)

点击工程下的“forms”,然后双击widget.ui文件(.ui为后缀的文件就是界面文件),就可以进入ui编辑器。
在这里插入图片描述

4、制作简单的QQ登录界面

在这里插入图片描述

参照腾讯qq的登录界面,我们知道qq登录界面需要有账号、密码、qq图标以及qq字样、注册、登录字样和按钮等。具体怎么做呢?利用组件来实现一下吧。

  • 放置文本、图片、gif的组件是:Display Widgets----》 Label(qlabel),直接将其拖入待设计的窗体,修改名字为“QQ登录界面”
  • 以同样地方式设计“账号”、“密码”
  • 接下来设计“文本输入框”,在我们输入账号以及密码的时候,无论账号和密码有多长,都不会换行,所以还需要用到一行文本输入框Input Widgets----》 Line Edit(qlineedit)
  • 设计登录以及注册按钮Buttons-----》Push Button,将该控件拖拽至待设计的窗体,双击该组件就可以更改该组件的名字啦
  • 使用快捷键ctrl+r或者直接点击编译按钮进行编译即可
    设计好的窗体如下:在这里插入图片描述
    编译结果如下:在这里插入图片描述
    可以在账号密码处填写信息,但是可以发现密码也是可视的,需要调整一下,一般密码是不可视的。
    在这里插入图片描述
    先关闭运行结果框,点击待设计窗体中的密码输入框组件,在属性编辑器里面,找到echoMode,将其设置为passwd即可。
    在这里插入图片描述在这里插入图片描述
    有一点需要注意,在设计完之后,需要给控件改名字,为了分析代码方便,也为了使得我们的设计通俗易懂,可读性高,不然拿给别人看,别人看我们设计的这个东西就很蓝的啦。
    选中要修改名字的控件,在属性编辑器里面就可以修改。
    在这里插入图片描述
    将注册以及登录按钮控件的名字分别改为了“registBt”、“logoBt”;账号输入以及密码输入的一行文本输入框的名字分别改为“userEdit”、“passwdEdit”
    在这里插入图片描述

5、信号和槽

信号:信号是指控件发出的特定的信号。
槽:槽是槽函数的意思,我们可以把槽函数绑定在某一个控件的信号上。比如控件pushButton就有自己的信号,它一共有四个信号。
点击菜单栏里面的“帮助”—》“索引”,搜索“pushbutton”即可看到相关信息
在这里插入图片描述
在这里插入图片描述
点击一下它的父类,可以看到该控件的四个信号如下:
在这里插入图片描述

6、怎么关联信号和槽?

关联信号和槽有两种方式,一种是自动关联,一种是手动关联。

(1)自动关联
若选择自动关联,只需要选住控件,然后点击右键,选择“转到槽”即可。
自动关联会给工程的“Headers”下的文件里面声明槽函数。
如:给“登录”控件自动关联槽,就选择默认的信号“clicked()”,点击“ok”在这里插入图片描述
关联完毕之后,会自动跳转到Sources文件夹下的widget.cpp文件,并且声明槽函数,具体的功能我们在里面直接添加就可以。
在这里插入图片描述
在该文件里面添加槽函数的功能(一点登录就打印“logo success”),编译运行:
在这里插入图片描述
其次,有一点需要注意,也是自动在widget.h文件的private slots下面声明槽函数的。槽函数只能声明到private slots或者public slots下面
在这里插入图片描述
这个是qt特有的,标准的c++里面是没有这个的。
(2)手动关联
手动关联的话,需要用到一个函数connect函数,可以在菜单栏的“帮助”--->"索引",查找一下connect,便可了解其用法。
手动关联的具体实现是在widget.cpp文件中进行操作的。

  • 先使用connect函数
 connect(ui->registBt,SIGNAL(clicked()),this,SLOT(registBt_clicked_slots()));//ui指的是大的界面,这些控件都是在大的界面里面的,当访问这个界面里面的控件的时候,前面都要加上ui//要关联的信号是SIGNAL(clicked())//SLOT(registBt_clicked_slots()是要绑定的槽函数,在widget.h文件里面声明一下槽函数//注意槽函数的声明一定要声明到private slots或public slots里面------------void registBt_clicked_slots();//然后在现在这个文件里面实现一下刚刚声明的槽函数
  • 再去widget.h文件里面去声明槽函数
private slots:void on_logoBt_clicked();void registBt_clicked_slots();
  • 最后在widget.cpp文件里面实现刚刚声明的槽函数
//实现手动关联时声明的槽函数
void Widget::registBt_clicked_slots()
{qDebug("regist success!");
}

编译运行一下试试,点击了两次登录,两次注册,效果ok的啦。
在这里插入图片描述


http://chatgpt.dhexx.cn/article/I2D2HmLR.shtml

相关文章

QT界面布局和设计

一、设计 对功能和模块进行分析,然后设计对应的模块,将每个模块都用widget展示作为组件。工程结构示例:二、完成模块 代码分别设计各个组件,合适即可三、主界面连接 主界面连接各个子模块。在这里插入代码片#include "AutoFl…

tomcat配置url跳转_tomcat安装目录详解

打开tomcat的解压之后的目录可以看到如下的目录结构: 1.bin: bin目录主要是用来存放tomcat的命令,主要有两大类,一类是以.sh结尾的(linux命令),另一类是以.bat结尾的(windows命令&a…

【转】URL访问地址和Tomcat项目部署中不得不说的小秘密(JAVA之Tomcat服务器)

今天来简单讲讲tomcat项目部署和url地址访问栏的关系,顺便和大家分享下,叙述不当之处,还请大家多多指导! 众所周知,Tomcat项目发布的默认访问地址格式如下:http://localhost:8080/MyDemo/index.jsp 由于we…

tomcat配置url跳转_Tomcat

Tomcat介绍 1.Web服务器介绍 Web服务器可以解析HTTP协议,收到请求后可以进行响应,比如响应静态资源、进行页面跳转等 Web服务器响应可委托给CGI脚本、JSP脚本、ASP脚本、服务器端JS等程序或其它服务器端技术 Web服务器通常产生一个html响应以便浏览器浏览 2.常见Web服务器 We…

web服务之Tomcat

目录 Tomcat介绍 Tomcat组件 Tomcat组件 JavaServlet JSP容器 Tomcat部署步骤 关闭防火墙,将安装 Tomcat 所需软件包上传到 /opt 目录下 安装 JDK 设置 JDK 环境变量 安装启动 Tomcat tomcat的主要目录 Tomcat 虚拟主机配置 创建test1和test2项目目录和文…

Tomcat实现Https服务

Tomcat实现Https服务 1、JDK生成证书 进入JDK/bin目录键盘按下shift 鼠标右键,选择“在此处打开命令窗口”打开DOS命令窗键入命令”keytool -v -genkey -alias myKey -keyalg RSA -keystore F:/jdk1.6.0_45/myKey.keystore” 证书密码123456 2、配置tomcat 配置…

【转】URL访问地址和Tomcat项目部署中不得不说的小秘密

今天来简单讲讲tomcat项目部署和url地址访问栏的关系,顺便和大家分享下,叙述不当之处,还请大家多多指导! 众所周知,Tomcat项目发布的默认访问地址格式如下:http://localhost:8080/MyDemo/index.jsp 由于we…

【tomcat路径匹配源码分析】搞懂tomcat中web.xml配置servlet的url-pattern为“/“和“/*“的区别

搞懂tomcat中web.xml配置servlet的url-pattern为"/"和"/*"的区别 前言结论Servlet匹配规则(tomcat源码)分析举个例子路径配置为/导致拦截静态资源问题的解决方案 总结 原文地址 前言 我在写原生javaWEB项目时,想通过注册…

通过URL请求tomcat服务器直接下载文件

从一个服务器上下载文件,是很常见的情况。通常我们想通过URL来访问直接下载一个文件,对于Tomcat服务器而言,是非常简单的,Tomcat本身就是作为一个web服务器的,通过简单的配置就可以实现。 配置如下: 1、在…

tomcat配置使得访问http协议(或者直接输入www.网址.com) 直接跳转访问https协议

由于https协议比http协议安全,但是如果网站安装了ssl(如果没有安装,可百度搜索"阿里云ssl免费证书",阿里官网会提供安装方法,比较简单),发现每次输入网址必须得手动输入https,而且大家习惯输入www.网址.com,会直接导致访问不到网站的.下面介绍直接修改tomcat配置,使得…

URL请求省略端口号和项目名访问Tomcat部署的项目

前言:很多时候Tomcat部署好Web项目之后访问项目的时候都需要加上端口号和项目名,如:http://localhost:8080/项目名,下面我会介绍可以不用输端口号和项目名便可以直接进行访问的方法,其实就是修改Tomcat下conf目录中的s…

让tomcat服务器使用url rewrite

第一步:首先到这里下载 http://tuckey.org/urlrewrite/ 稳定版:urlrewrite-2.6.0.jar 第二步:将urlrewrite-2.6.0.jar 放到tomcat的lib目录下。 第三步:将urlrewrite-2.6.0.jar 放到Netbeans的工程目录下的…

Tomcat之中文URL问题

背景 如果你需要访问带有中文路径的URL怎么办?比如说mp3、mp4文件。 比如这样的路径: http://127.0.0.1:8080/LZPlayer/mp3/1168/徐小凤 - 顺流逆流.mp3 那么,需要去修改Tomcat的配置文件,让他支持中文即可。 步骤 修改配置文…

URL访问地址和Tomcat项目部署中不得不说的小秘密

今天来简单讲讲tomcat项目部署和url地址访问栏的关系,顺便和大家分享下,叙述不当之处,还请大家多多指导! 众所周知,Tomcat项目发布的默认访问地址格式如下:http://localhost:8080/MyDemo/index.jsp 由于we…

opencv——边缘检测算法(总结)

前言 笔记。 一、边缘检测算法 边缘检测算法是指利用灰度值的不连续性质,以灰度突变为基础分割出目标区域。对铝铸件表面进行成像后会产生一些带缺陷的区域,这些区域的灰度值比较低,与背景图像相比在灰度上会有突变,这是由于这…

用OpenCV的边缘检测

使用OpenCV的边缘检测 代码如下: #include "infer.h"using namespace cv; using namespace std;int main::getResult(string fileName) {Mat src imread(fileName);Mat dst;cvtColor(src, src, COLOR_BGR2GRAY);blur(src, src, Size(3, 3));Canny(src,…

基于opencv的边缘检测方法

1、梯度运算 用OpenCV的形态变换( 膨胀、腐蚀、开运算和闭运算)函数morphologyEx 梯度运算即膨胀结果-腐蚀结果: 【注意】对于二值图像来说,必须是前景图像为白色,背景为黑色,否则需要进行反二值化处理 …

OpenCV——Canny边缘检测

目录 简介 实现步骤 代码 原图 效果图 简介 Canny边缘检测是一种使用多级边缘检测算法检测边缘的方法。 实现步骤 step1:去噪。噪声会影响边缘检测的准确性,因此首先要将噪声过滤掉。 方法:图像边缘容易受到噪声的干扰,因此…

OpenCV——边缘检测原理

边缘检测原理 图像的边缘指的是图像中像素灰度值突然发生变化的区域,如果将图像的每一行像素和每一列像素都描述成一个关于灰度值的函数,那么图像的边缘对应在灰度值函数中是函数值突然变大的区域。函数值的变化趋势可以用函数的导数描述。当函数值突然…

OpenCV 边缘检测之Canny算法(代码应用)

Canny算法 Canny是边缘检测算法,在1986年提出的。 是一个很好的边缘检测器 很常用也很实用的图像处理方法 Canny算法步骤 消除噪声:高斯模糊 - GaussianBlur灰度转换 - cvtColor计算梯度 – Sobel/Scharr非最大信号抑制高低阈值输出二值图像 API&…