本文主要是介绍【QT】QT从零入门教程(二):开始入门,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
配置
第一个教程简单介绍了图像处理自编软件的基本界面和功能,本节开始讲解如何制作这个软件。首先是配置环境,博主用的是VS2017+OpenCV3.30+QT5.9.2,其他版本也可以实现,不过要注意链接依赖项的区别。网上的配置教程数不胜数,在此不赘述,QT配置可以参考VS2017专业版使用最新版Qt5.9.2教程,OpenCV配置用CMake完成。
新建项目
文件——新建——项目——Qt GUI Application——选择路径和项目名称。
接着默认选项。
在这里可以选择自己想要修改的头文件名和Cpp名。
进入页面运行无误后,就可以准备大施拳脚了。
Hello World
如果仅仅运行个空白界面,就说成入门,可能略显尴尬。那就来个简单的小项目练练手,就以经典的Hello World 开始吧。
先讲明几个点,编写QT程序时,运行可能会出现汉字乱码问题,解决方式是加上#pragma execution_character_set("utf-8")
。QT的按钮等响应事件不同于MFC,是通过信号与槽机制实现的,原理解释在下文给出。
// 头文件
#include <QtWidgets/QMainWindow>
#include "ui_ImageProcessing.h"class ImageProcessing : public QMainWindow
{Q_OBJECTpublic:ImageProcessing(QWidget *parent = Q_NULLPTR);~ImageProcessing();void helloWorld(); // 函数声明private:Ui::ImageProcessingClass ui;private slots: // 槽函数void iSlot();
};
// cpp
#include <QMainWindow>
#include <QtGui>
#include <QtWidgets>
#include "MainWindow.h"#pragma execution_character_set("utf-8") // 解决汉字乱码问题,注意!!!ImageProcessing::ImageProcessing(QWidget *parent): QMainWindow(parent)
{ui.setupUi(this);this->resize(400, 400); // 改变主窗口大小,后续教程中还有其他方式可以设置helloWorld();
}ImageProcessing::~ImageProcessing()
{
}void ImageProcessing::helloWorld() // 函数定义
{QPushButton *button = new QPushButton(this); // QPushButton是QT的按钮类button->setText(tr("你好,QT !")); // 按钮显示的文本button->move(100,100); // 重设按钮位置connect(button, SIGNAL(clicked()), this, SLOT(iSlot())); // 连接信号与槽
}void ImageProcessing::iSlot() // 槽函数
{QMessageBox::information(this, tr("hello"), tr("Hello World!"));
}
这篇关于【QT】QT从零入门教程(二):开始入门的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!