使用QT+VS2008开发windows应用程序 .

    QT是跨平台的应用程序开发工具,闻名遐迩,下面使用VS2008结合QT开发一个应用程序。

(1)打开VS2008,新建QT工程

 

(2)点击下一步,这里是选择需要使用的QT库

“class name”:指定类的名称,这里写“qt_app”;

“Base class”:指定自定义类的父类,这里选择“QMainWindow”

其它四个项是保存文件的名称,这里保持默认。

(4)点击“Finish”生成工程。

 

 

在解决方案管理器中可以看到所有生成的文件

(1)“Form Files”是窗体的设计文件,可以双击打开QT Designer的窗体设计界面;

(2)“Generated Files”是项目的生成文件的目录,它在编译的时候生成;

(3)其它三个目录是生成的源代码文件,程序员可以自由修改;

(4)编译工程并运行,界面如下:

下面我们看看工程的代码:

(1)程序入口main.cpp

01.#include "qt_app.h"   
02.#include <QtGui/QApplication>   
03.  
04.int main(int argc, char *argv[])  
05.{  
06.    QApplication a(argc, argv);  
07.    qt_app w;  
08.    w.show();  
09.    return a.exec();  
10.} 


 

定义了QApplication的实例“a”,“a.exec()”启动windows消息泵。

定义了qt_app的实例,“w.show()”显示qt_app的窗体。

(2)qt_app的代码-qt_app.h/qt_app.cpp

qt_app.h

01.#ifndef QT_APP_H   
02.#define QT_APP_H   
03.  
04.#include <QtGui/QMainWindow>   
05.#include "ui_qt_app.h"    //从窗体设计器中生成的代码   
06.  
07.class qt_app : public QMainWindow    //从QMainWindow下继承   
08.{  
09.    Q_OBJECT  
10.  
11.public:  
12.    qt_app(QWidget *parent = 0, Qt::WFlags flags = 0);   //构造函数   
13.    ~qt_app();                        //析构函数   
14.  
15.private:  
16.    Ui::qt_appClass ui;   //窗体设计器设计的窗体的类   
17.};  
18.  
19.#endif // QT_APP_H  
#ifndef QT_APP_H
#define QT_APP_H

#include <QtGui/QMainWindow>
#include "ui_qt_app.h"    //从窗体设计器中生成的代码

class qt_app : public QMainWindow    //从QMainWindow下继承
{
	Q_OBJECT

public:
	qt_app(QWidget *parent = 0, Qt::WFlags flags = 0);   //构造函数
	~qt_app();                        //析构函数

private:
	Ui::qt_appClass ui;   //窗体设计器设计的窗体的类
};

#endif // QT_APP_H

 

qt_app.cpp

[cpp] view plaincopyprint?
01.#include "qt_app.h"   
02.  
03.qt_app::qt_app(QWidget *parent, Qt::WFlags flags)  
04.    : QMainWindow(parent, flags)  
05.{  
06.    ui.setupUi(this);    //创建窗体设计器设计的窗体   
07.}  
08.  
09.qt_app::~qt_app()  
10.{  
11.  
12.}  
#include "qt_app.h"

qt_app::qt_app(QWidget *parent, Qt::WFlags flags)
	: QMainWindow(parent, flags)
{
	ui.setupUi(this);    //创建窗体设计器设计的窗体
}

qt_app::~qt_app()
{

}
(3)下面看下生成的窗体设计器的代码ui_qt_app.h

[cpp] view plaincopyprint?
01.QT_BEGIN_NAMESPACE  
02.  
03.class Ui_qt_appClass  
04.{  
05.public:  
06.    QWidget *centralWidget;          //QWidget是所有界面元素的基类   
07.    QPushButton *pushButton;         //界面上添加一个按键   
08.  
09.    void setupUi(QMainWindow *qt_appClass)  
10.    {  
11.        if (qt_appClass->objectName().isEmpty())  
12.            qt_appClass->setObjectName(QString::fromUtf8("qt_appClass"));  
13.        qt_appClass->resize(485, 326);     //窗体的大小   
14.        centralWidget = new QWidget(qt_appClass);  
15.        centralWidget->setObjectName(QString::fromUtf8("centralWidget"));  
16.  
17.        //创建并初始化添加的按键   
18.        pushButton = new QPushButton(centralWidget);     //按键被添加到centralWidget上   
19.        pushButton->setObjectName(QString::fromUtf8("pushButton"));  
20.        pushButton->setGeometry(QRect(180, 120, 81, 31));  
21.  
22.        qt_appClass->setCentralWidget(centralWidget); //添加centralWidget   
23.  
24.        retranslateUi(qt_appClass); //此函数下面定义   
25.  
26.        QMetaObject::connectSlotsByName(qt_appClass);  
27.    } // setupUi   
28.  
29.    void retranslateUi(QMainWindow *qt_appClass)  
30.    {  
31.            //设置窗体标题   
32.            qt_appClass->setWindowTitle(QApplication::translate("qt_appClass", "qt_app", 0, QApplication::UnicodeUTF8));  
33.            //设置按键标签为“OK”   
34.    pushButton->setText(QApplication::translate("qt_appClass", "OK", 0, QApplication::UnicodeUTF8));  
35.    } // retranslateUi   
36.  
37.};  
38.  
39.namespace Ui {  
40.    class qt_appClass: public Ui_qt_appClass {};  
41.} // namespace Ui   
42.  
43.QT_END_NAMESPACE  


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值