在Visual Studio 2010中开发Qt程序

2024-09-01 10:32
文章标签 程序 qt 开发 visual studio 2010

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

本文演示如何用VS2010开发QT的应用程序界面,前提是已经搭建好了开发环境,搭建方法很简单,我在之前的博客也有描述。此处不再赘述。

1.打开VS2010的IDE开发环境,新建一个QT Application的项目命名为QtGrapher,所有的设置都可以保持默认,创建完成后可以编译运行程序,如果环境配置都正确,会弹出一个空白的GUI界面,如下所示,


2.在IDE的解决方案资源管理器中双击qtgrapher.ui,会在Qt Designer界面中打开该.ui文件,如下图所示,


3.在Qt Designer界面的右侧Buttons选项中找到Push Button控件,将其拖至qtgrapher界面中的适当位置,然后双击空间,修改控件的名称。再添加一个Label控件,如下所示,


4.在Designer界面的工具栏中选中“编辑信息/槽”按钮,将鼠标移到“打开图像”按钮上,按钮周围会出现红色框,然后按下鼠标会弹出一个“配置连接”的对话框,如下图所示,


5.在上图中点击“编辑”按钮,会弹出“×××信号/槽“的编辑对话框,点击槽的按钮添加一个槽函数OpenImageClick(),同样的方法在添加一个ExitClick()函数,然后单击确定按钮,如下图所示,


6.在配置连接窗口左侧中选择clicked(),在右侧选中OpenImageClick()函数,后单击确定按钮。这样就完整的为打开图像按钮添加了一个槽函数。同样的方法为处理图像连接刚才添加的ExitClick()槽函数,然后保存。连接完成后如下所示:


7.保存qtgrapher.ui文件,回到VS2010的IDE界面,双击qtgrapher.h头文件,为QtGrapher类手动添加两个按钮的响应函数的声明,函数名需和之间定义的槽函数名保持一致。如下所示:

#ifndef QTGRAPHER_H
#define QTGRAPHER_H
#include <QtGui/QMainWindow>
#include "ui_qtgrapher.h"
class QtGrapher : public QMainWindow
{Q_OBJECT
public:QtGrapher(QWidget *parent = 0, Qt::WFlags flags = 0);~QtGrapher();
private slots://响应打开图像文件的槽函数void OpenImageClick();//响应关闭的槽函数void ExitClick();
private:Ui::QtGrapherClass ui;
};
#endif // QTGRAPHER_H

8.在qtgrapher.cpp类实现文件中定义两个槽函数,如下:

#include "qtgrapher.h"
#include <QFileDialog>
#include <QMessageBox>
QtGrapher::QtGrapher(QWidget *parent, Qt::WFlags flags): QMainWindow(parent, flags)
{ui.setupUi(this);
}
QtGrapher::~QtGrapher()
{}
//打开图像
void QtGrapher::OpenImageClick()
{QString filename;filename=QFileDialog::getOpenFileName(this,tr("选择图像"),"",tr("Images File(*.png *.bmp *.jpg *.tif *.GIF )"));if(filename.isEmpty())return;else{QImage* img=new QImage;if(! ( img->load(filename) ) ) //加载图像{QMessageBox::information(this, tr("打开图像失败"), tr("打开图像失败!"));delete img;return;}ui.label->setPixmap(QPixmap::fromImage(*img));//在label控件中显示图片}
}
//关闭窗口
void QtGrapher::ExitClick()
{close();  //关闭窗口
}

9.保持main.cpp的结构不变,编译运行程序无错误,即可弹出设定的UI界面,如下所示:


10.单击“打开图像”按钮,弹出打开文件对话框,如下所示:


11.选择好要打开的图像后,单击打开按钮,就会在UI界面中打开所选中的图片,如下所示:


12.单击右上角的“关闭”按钮和窗口下边的"退出"按钮,都可以成功退出程序。


这篇关于在Visual Studio 2010中开发Qt程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

基于Python开发批量提取Excel图片的小工具

《基于Python开发批量提取Excel图片的小工具》这篇文章主要为大家详细介绍了如何使用Python中的openpyxl库开发一个小工具,可以实现批量提取Excel图片,有需要的小伙伴可以参考一下... 目前有一个需求,就是批量读取当前目录下所有文件夹里的Excel文件,去获取出Excel文件中的图片,并

Qt 中 isHidden 和 isVisible 的区别与使用小结

《Qt中isHidden和isVisible的区别与使用小结》Qt中的isHidden()和isVisible()方法都用于查询组件显示或隐藏状态,然而,它们有很大的区别,了解它们对于正确操... 目录1. 基础概念2. 区别清见3. 实际案例4. 注意事项5. 总结1. 基础概念Qt 中的 isHidd

QT移植到RK3568开发板的方法步骤

《QT移植到RK3568开发板的方法步骤》本文主要介绍了QT移植到RK3568开发板的方法步骤,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录前言一、获取SDK1. 安装依赖2. 获取SDK资源包3. SDK工程目录介绍4. 获取补丁包二

Qt把文件夹从A移动到B的实现示例

《Qt把文件夹从A移动到B的实现示例》本文主要介绍了Qt把文件夹从A移动到B的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录如何移动一个文件? 如何移动文件夹(包含里面的全部内容):如何删除文件夹:QT 文件复制,移动(

如何用java对接微信小程序下单后的发货接口

《如何用java对接微信小程序下单后的发货接口》:本文主要介绍在微信小程序后台实现发货通知的步骤,包括获取Access_token、使用RestTemplate调用发货接口、处理AccessTok... 目录配置参数 调用代码获取Access_token调用发货的接口类注意点总结配置参数 首先需要获取Ac

基于Python开发PDF转PNG的可视化工具

《基于Python开发PDF转PNG的可视化工具》在数字文档处理领域,PDF到图像格式的转换是常见需求,本文介绍如何利用Python的PyMuPDF库和Tkinter框架开发一个带图形界面的PDF转P... 目录一、引言二、功能特性三、技术架构1. 技术栈组成2. 系统架构javascript设计3.效果图