【Qt】学习Day1

2024-06-23 06:44
文章标签 学习 qt day1

本文主要是介绍【Qt】学习Day1,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • Qt简介
  • 创建第一个Qt程序
  • 创建过程
  • 介绍
    • main函数
    • 工程文件
    • 头文件
    • 控件源文件
    • 快捷键
    • 按钮控件常用API
    • 对象树
    • 坐标系
  • 信号和槽
    • 自定义信号
    • 自定义槽函数
    • 触发自定义的信号
    • 案例-下课后,老师触发饿了信号,学生响应信号,请客吃饭
    • 重载
    • 信号连接信号
    • Lambda表达式
    • 函数对象参数
    • 操作符重载函数参数
    • 可修改标志符mutable
    • 函数返回值
    • 函数体
    • lamdba表达式的应用
  • 作业

Qt简介

是一种跨平台图形界面引擎
1991年由奇趣科技创建
优点

  • 跨平台
  • 接口简单,容易上手
  • 一定程度上简化了内存回收

成功案例:
Linux桌面环境 KDE、谷歌地图、VLC多媒体播放器…

创建第一个Qt程序

创建过程

名称 - 不能有中文 不能有空格
路径 - 不能有中文路径
在这里插入图片描述

在这里插入图片描述
QWidget是一个父类
QMainWindow是子类,多了菜单栏、工具、状态栏
QDialog是子类,多了对话框
在这里插入图片描述
如图创建成功。
在这里插入图片描述

介绍

main函数

#include "mywidget.h"
#include <QApplication>// 包含一个应用程序类的头文件//main程序入口  argc命令行变量的数量  argv命令行变量的数组
int main(int argc, char *argv[])
{//a应用程序对象,在Qt中,应用程序对象 有且仅有一个QApplication a(argc, argv);//窗口对象  myWidget父类  -> QWidgetmyWidget w;//窗口对象 默认不会显示,必须要调用show方法显示窗口w.show();//让应用程序对象进入消息循环//当代码阻塞到这行return a.exec();//    while(true)
//    {
//         if(点击叉子)
//        {
//            break;
//        }
//    }}

QApplication a :应用程序对象,有且仅有一个
myWidget w;:实例化窗口对象
w.show():调用show函数 显示窗口
return a.exec() :让应用程序对象进入消息循环机制中,代码阻塞到当前行

工程文件

QT       += core gui		//Qt包含的模块greaterThan(QT_MAJOR_VERSION, 4): QT += widgets    //大于4版本以上 包含 widget模块CONFIG += c++17TARGET = study01  //目标 生成.exe程序的名称
TENPLATE = app    //模块 应用程序模块 ApplicationSOURCES += \		//源文件main.cpp \mywidget.cppHEADERS += \		//头文件mywidget.h

头文件

#ifndef MYWIDGET_H
#define MYWIDGET_H#include <QWidget>  //包含头文件 QWidget窗口类class myWidget : public QWidget
{Q_OBJECT	//宏,允许类中使用信号的槽的机制public:myWidget(QWidget *parent = nullptr);  //构造函数~myWidget();  //析构函数
};
#endif // MYWIDGET_H

#ifndef,#endif:防止头文件重包含

控件源文件

命名规范
类名 首字母大写,单词和单词之间首字母大写
函数名 变量名称 首字母小写,单词和单词之间首字母大写

1.查看控件的头文件、模块是否引用
模块引用加在设备文件中,如加network模块,则QT += core gui network
在这里插入图片描述

Header:头文件
qmake:模块
Inherite:父类
Inherited By:子类

模块引用加在设备文件中,如加network模块,则QT += core gui network

#include "mywidget.h"
#include <QPushButton> //按钮控件的头文件
#include "mypushbutton.h"
#include <QDebug>myWidget::myWidget(QWidget *parent): QWidget(parent)
{//创建一个按钮QPushButton * btn = new QPushButton;//btn->show(); //show以顶层方式弹出窗口控件//让btn对象 依赖在 myWidget窗口中btn->setParent(this);//显示文本btn->setText("第一个按钮");//创建第二个按钮 按照控件的大小创建窗口QPushButton * btn2 = new QPushButton("第二个按钮",this);//移动btn2按钮btn2->move(100,100);//按钮可不可以 重新制定大小 可以!btn2->resize(50,50);//重置窗口大小resize(600,400);//设置固定窗口大小setFixedSize(600,400);//设置窗口标题setWindowTitle("第一个窗口");//创建一个自己的按钮对象MyPushButton * myBtn = new MyPushButton;myBtn->setText("我自己的按钮");myBtn->move(200,0);myBtn->setParent(this); //设置到对象树中//需求  点击我的按钮 关闭窗口//参数1  信号的发送者 参数2  发送的信号(函数的地址) 参数3  信号的接受者 参数4  处理的槽函数//connect( myBtn, &MyPushButton::clicked, this, &myWidget::close  );connect( myBtn, &QPushButton::clicked, this, &QWidget::close  );
}myWidget::~myWidget()
{qDebug() << "myWidget的析构调用";
}

快捷键

快捷键
注释ctrl + /
运行ctrl + r
编译ctrl + b
字体缩放ctrl + 滚轮
查找ctrl + f
整行移动ctrl + shift + ↑/↓
帮助文档F1
自动对齐ctrl + i
同名之间的.h和.cpp切换F1

按钮控件常用API

API
创建QPushButton * btn = new QPushButton
设置父亲setParent(this)
设置文本setText(“文字”)
设置位置
重新指定窗口大小resize
设置窗口标题setWindowTitle
设置窗口固定大小setFixedSize
自动对齐ctrl + i
同名之间的.h和.cpp切换F1

对象树

当创建的对象在堆区时候,如果指定的父亲是QObject派生下来的类或者QObject子类派生下来的类,可以不用管理释放的操作,将对象会放入到对象树中。

坐标系

以左上角为原点(0,0),X向右增加,Y向下增加。
在这里插入图片描述
对于嵌套窗口,其坐标是相对于父窗口来说的。

信号和槽

connect(信号的发送者,发送的具体信号,信号的接收者,信号的处理(槽) )

connect(from,what,to,do)

信号槽的优点:松散耦合
信号的发送槽和接受槽本身是没有关联的,通过connect连接将两端耦合在一起。

案例:实现点击按钮关闭窗口
connect(btn,&QPushButton::click,this,&QWidget::close)

自定义信号

1.写到 signals下
2.返回 void
3.需要声明,不需要实现
4.可以有参数 ,可以重载

自定义槽函数

1.返回void
2.需要声明 ,也需要实现
3.可以有参数 ,可以重载
4.写到 public slot下 或者public 或者全局函数

触发自定义的信号

emit 自定义信号

案例-下课后,老师触发饿了信号,学生响应信号,请客吃饭

1.定义两个类Teacher和Student
在这里插入图片描述

2.在分别在.h文件写入信号量和槽
在这里插入图片描述

在这里插入图片描述

3.槽函数在.cpp文件去实现
在这里插入图片描述
4.回到窗口,在.h文件实例类并定义classIsOver函数,在cpp文件写流程顺序并实现classIsOver函数实现。
在这里插入图片描述
在这里插入图片描述

重载

1.在信号量和槽添加有参函数
在这里插入图片描述
在这里插入图片描述

2.更改emit和connect,需要用到函数指针明确指出函数地址void (* Teacher:: *tSignal)(QString) = &Teacher::hungry;

在这里插入图片描述
3.为了使得去掉双引号,需要将QString 转为char *
在这里插入图片描述

4.结果如图
在这里插入图片描述

信号连接信号

、

在这里插入图片描述

1.信号是可以连接信号的
2.一个信号可以连接多个槽函数
3.多个信号 可以连接 同一个槽函数
4.信号和槽函数的参数 必须类型一一对应
5.信号的参数个数 可以多余槽函数的个数

Lambda表达式

[函数对象参数](操作符重载函数参数)mutable ->返回值{函数体}

lambda表达式 最常用 [=](){}

函数对象参数

  • [ ]:没有使用任何函数对象参数
  • [=]:函数体可以使用可见的局部变量,且是值传递
  • [&]:函数体可以使用可见的局部变量,且是值传递

操作符重载函数参数

参数可以通过按值(如:(a,b))和按引用(如:(&a,&b))两种方式进行传递

可修改标志符mutable

按值传递函数对象参数时,加上mutable修饰符后,可以修改按值传递进来的拷贝(注意是能修改拷贝,而不是值本身)。

QPushButton * myBtn = new QPushButton (this);
QPushButton * myBtn2 = new QPushButton (this);
myBtn2->move(100,100);
int m = 10;connect(myBtn,&QPushButton::clicked,this,[m] ()mutable { m = 100 + 10; qDebug() << m; });
connect(myBtn2,&QPushButton::clicked,this,[=] ()  { qDebug() << m; });
qDebug() << m;

函数返回值

->函数返回值,要什么样的返回类型就加上什么类型。

int ret = []()->int{return 1000;}();
qDebug() << "ret="<<ret;

函数体

{ },标识函数的实现,这部分不能省略,但函数体可以为空。

lamdba表达式的应用

案例:点击按钮,关闭关口,输出“请老师吃饭,老师要吃宫保鸡丁”

    QPushButton * btn2 = new QPushButton ;btn2->setText("关闭");btn2->move(100,0);btn2->setParent(this);connect(btn2,&QPushButton::clicked, [=](){this->close();emit zt->hungry("宫保鸡丁");});

作业

1.设计两个按钮"open" “close”,当按下open时,打开一个新窗口;当按下close时,关闭新窗口

#include "mainwindow.h"
#include <QPushButton>MainWindow::MainWindow(QWidget *parent): QMainWindow(parent)
{QWidget *one=new QWidget;QPushButton * btn1 = new QPushButton("open",this);btn1->move(200,100);btn1->resize(100,50);QPushButton * btn2 = new QPushButton("close",this);btn2->move(200,250);btn2->resize(100,50);setFixedSize(600,400);connect(btn1,&QPushButton::clicked,this,[=](){one->show();});connect(btn2,&QPushButton::clicked,this,[=](){one->close();});}MainWindow::~MainWindow() {}

2.设计一个按钮"open" ,当按下open时,按钮变为"close"并打开一个新窗口;当按下close时,按钮变为’"open"并关闭新窗口。

#include "mainwindow.h"
#include <QPushButton>MainWindow::MainWindow(QWidget *parent): QMainWindow(parent)
{QWidget *one=new QWidget;one->setWindowTitle("新窗口");QPushButton * btn = new QPushButton;btn->setParent(this);btn->setText("open");btn->resize(100,50);connect(btn,&QPushButton::clicked,one,[=](){if(btn->text()=="close"){one->close();btn->setText("open");}else{one->show();btn->setText("close");}});}MainWindow::~MainWindow() {}

这篇关于【Qt】学习Day1的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

基于Qt Qml实现时间轴组件

《基于QtQml实现时间轴组件》时间轴组件是现代用户界面中常见的元素,用于按时间顺序展示事件,本文主要为大家详细介绍了如何使用Qml实现一个简单的时间轴组件,需要的可以参考下... 目录写在前面效果图组件概述实现细节1. 组件结构2. 属性定义3. 数据模型4. 事件项的添加和排序5. 事件项的渲染如何使用

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

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

python与QT联合的详细步骤记录

《python与QT联合的详细步骤记录》:本文主要介绍python与QT联合的详细步骤,文章还展示了如何在Python中调用QT的.ui文件来实现GUI界面,并介绍了多窗口的应用,文中通过代码介绍... 目录一、文章简介二、安装pyqt5三、GUI页面设计四、python的使用python文件创建pytho

QT实现TCP客户端自动连接

《QT实现TCP客户端自动连接》这篇文章主要为大家详细介绍了QT中一个TCP客户端自动连接的测试模型,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录版本 1:没有取消按钮 测试效果测试代码版本 2:有取消按钮测试效果测试代码版本 1:没有取消按钮 测试效果缺陷:无法手动停

基于Qt实现系统主题感知功能

《基于Qt实现系统主题感知功能》在现代桌面应用程序开发中,系统主题感知是一项重要的功能,它使得应用程序能够根据用户的系统主题设置(如深色模式或浅色模式)自动调整其外观,Qt作为一个跨平台的C++图形用... 目录【正文开始】一、使用效果二、系统主题感知助手类(SystemThemeHelper)三、实现细节

Qt实现文件的压缩和解压缩操作

《Qt实现文件的压缩和解压缩操作》这篇文章主要为大家详细介绍了如何使用Qt库中的QZipReader和QZipWriter实现文件的压缩和解压缩功能,文中的示例代码简洁易懂,需要的可以参考一下... 目录一、实现方式二、具体步骤1、在.pro文件中添加模块gui-private2、通过QObject方式创建

Qt QWidget实现图片旋转动画

《QtQWidget实现图片旋转动画》这篇文章主要为大家详细介绍了如何使用了Qt和QWidget实现图片旋转动画效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、效果展示二、源码分享本例程通过QGraphicsView实现svg格式图片旋转。.hpjavascript

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06