VS集成Qt步骤

1. 准备的安装包和工具
qt-win-opensource-src-4.5.2.zip
qt-vs-addin-1.0.2.exe
VS2008英文版
2. 将qt-win-opensource.src-4.5.2.zip解压到d:\Qt中,将修改文件夹名为qt4.5.2
3. 添加环境变量
确保你是以管理员的身份登录的系统;
在系统变量中添加变量,变量名为QTDIR,变量内容为D:\Qt\qt4.5.2;
在系统变量的Path中添加”D:\Qt\qt4.5.2\bin”例如, D:\Qt\qt4.5.2\bin;%SystemRoot%\system32;%SystemRoot%,如果Path里面已经有内容的话,用;号将新加的内容与碑内容隔开;
4. 使用Visual Studio 2008 Command Prompt,进入Microsoft Visual Studio 9.0\Common7\Tools\目录下,执行vcvarsall.bat,执行完,进入D:\Qt\qt4.5.2\bin。
5. 在Visual Studio 2008 Command Prompt中输入
configure -platform win32-msvc2008 -debug-and-release
并等上十几分钟。
6. 输入nmake,然后再等上三至四个小时,视机器的配置而定。(在nmake前务必将硬件加速调低或者设为无)
7.不要关闭Visual Studio 2008 Command Prompt窗口,将D:\Qt\qt4.5.2\bin下的.qmake.cache和configure.cache文件拷贝到别的地方,然后在Visual Studio 2008 Command Prompt中输入命名nmake confclean
8. 将.qmake.cache和configure.cache拷贝到原处。并将安装完成后的Qt4.5.2文件夹做个备份,以免下次使用的时候还需要备份。
9. 安装qt-vs-addin.exe
10. 在VS2008中设置QT
11.
VS2008中多了一个QT选项 属性

点击Add添加QT的安装目录,这里是d:\Qt\qt4.5.2

12.开始QT程序
在VS2008中新建个QT Application工程,命名为HelloQT,新建完成后,在main.cpp中输入以下的内容
#include <QtGui/QApplication>  
#include <QLabel>  

int main(int argc, char *argv[])  
{  
QApplication app(argc, argv);  
QLabel *label=new QLabel(" Hello Qt!");  
label->show();  
return app.exec();  
}  
运行一下,可以运行结果:

VC最好从VC提供的控制台启动,自己打开的VC终端,可能会因为环境变量不全引起编译错误,
光设置PATH环境变量没有用。建议执行一次 vcvarsall.bat 初始化环境变量。官方终端打开的是:
%comspec% /k ""C:\software\Microsoft Visual Studio 9.0\VC\vcvarsall.bat"" x86
因你的VC安装目录而不同。参数除X86外,还有 amd64 x64 ia64 x86_amd64 x86_ia64等。

准备工作:

1. 下载 VC++2008 SP1 英文 express 版, 中文版可能有问题,安装好备用。
2. 下载 windows 版的 perl,当前最新版是 strawberry-perl-5.10.0.6,解压备用。
3. 下载 QT4.5.3的源码,qt-all-opensource-src-4.5.3(不是sdk那个exe),解压备用。
4. 下载OpenSSL源码,当前最新版是 openssl-0.9.8k,解压备用。



第一部分:编译OpenSSL

1. 安装perl
2. 打开带有VC2008环境的console
3. 进入到 openssl 源码树的目录
4. perl Configure VC-WIN32
5. ms\do_ms.bat
6. nmake -f ms\ntdll.mak
7. nmake -f ms\nt.mak

ntdll.mak是编译dll,nt.mak是lib,如果漏掉3,会报错。



第二部分:安装 shared build 的QT

新建 C:\Software\QT45\qt 目录,其它目录也可以,只要路径中不含空格或中文。
复制 源码目录下的 mkspecs 目录到新建的qt目录,否则会报错。

配置 shared 版:
configure -debug-and-release -platform win32-msvc2008 
-no-dsp -no-vcproj -no-qt3support -qt-libpng -qt-libjpeg 
-qt-libmng -qt-libtiff -qt-zlib -prefix C:\Software\Qt45\qt 
-openssl -I D:\download\openssl-0.9.8k\inc32 
-L d:\download\openssl-0.9.8k\out32dll -nomake translations

之前 openssl 只是编译了一下,没有安装,include目录是空的,配置的时候,要根据实际情况,给出
正确的include和lib目录。-platform 参数指出了目标编译器,在 mkspecs 下可看到非常多的编译器,
有些编译器无法编译webkit组件,有些则无法编译 phonon,vs2008是全部都可以的。

不打算开发 webkit 核心的浏览器人,建议不要编译webkit,此物极度耗时,体积也不小
光一个static配置的lib文件,release超过200M,debug接近500M。

隐藏参数 -nomake, 忽略某些buildpart,参考 tools\configure\configureapp.cpp 文件。
以下6个buildparts: libs, tools, examples, demos, docs, translations 可以忽略掉, 
(translations是语言文件,忽略的话,-prefix\bin下的工具就只有英文了)


完事后编译:
nmake

完事后安装:
nmake install

 openssl 源码下找 libeay32.dll 和 ssleay32.dll ,复制到 -prefix\bin。
-prefix\bin 不会自动加入到PATH环境变量,需要的话自己设置。

至此, OpenSSL 目录可以删除。正式+调试 的动态编译版QT装完,占用磁盘379M。若要卸载,
直接删除 -prefix\ 目录。QT源码目录达4G, nmake distclean ,或整个删除以节省空间。
如需接着编译静态版,OpenSSL目录勿删。

发现安装后bug一个,原因未知,不确定是QT自身问题,还是安装方式造成的。
qt demo调用的是 examples\xxx\xxx\debug或者release下的exe程序,而现在examples编译出的程序,
都不在debug或者release目录,直接在对应源码根目录下了,修改examples的pro文件可以修正错误。



第三部分:安装 static 版的QT

configure -static 只是静态链接QT的lib,仍然需要VC2008运行库,可以到微软主页下载。

静态,就要彻底。mkspecs目录,找到 win32-msvc2008 目录,编辑qmake.conf,
将QMAKE_CFLAGS_XXXXXXX全改成静态。就是把MD改成MT,把MDd改成MTd。
源码目录下 mkspecs 和目标目录下mkspecs里的都要改,前者最后安装时会覆盖掉后者。

根据qt官方文档,在重新configure的时候,必须先做些清理:

nmake distclean

以前的老版本是用 nmake confclean,它们的语义是不同的,纠缠这些蛛丝马迹没有意义,
我直接删除了源码目录,解压纯净的源码树来编译的,纯净的源码树,有利于减少潜在编译错误。

这里只编译正式版,其它版的 configure 要作相应调整,-openssl-linked 表示静态链接,
运行时不需要带 openssl的 dll, -opensll 正好相反,运行时需要dll。

配置 static 版:
configure -release -platform win32-msvc2008 -no-dsp -no-vcproj -no-qt3support 
-qt-libpng -qt-libjpeg -qt-libmng -qt-libtiff -qt-zlib -prefix C:\Software\Qt45\qts 
-openssl-linked -I D:\download\openssl-0.9.8k\inc32 -L d:\download\openssl-0.9.8k
\out32 -nomake examples -nomake docs -nomake demos -nomake translations -static

配置完后:
编辑 tools\xmlpatterns\makefile.RELEASE ,把gdi32.lib加上,否则xmlpatterns会报错。

编译:
nmake

安装:
nmake install

安装OpenSSL的库:
复制 d:\download\openssl-0.9.8k\out32\ 下的两个lib文件 -prefix\lib 下。

修正一些错误:
-prefix\lib\*.prl,QMAKE_PRL_LIBS 变量中,OpenSSL源码目录,QT自身的源码,都要清除出去。
前者会造成qmake生成的makefile依赖openssl目录,后者可能造成QT依赖自身的源码树。工作量
非常巨大,几十个文件,慢慢改,我用的vim,写个正则自动处理了。



第四部分:编写测试代码

test.cpp 如下:
#include <QSslSocket>
#include <iostream>
#include <QString>
int main()

  QSslSocket socket;
  socket.connectToHostEncrypted("mail.qq.com", 443);
  if (!socket.waitForEncrypted()) {
  std::cout<<"ERROR"<<socket.errorString().toStdString();
  return false;
  }
  std::cout<<"Connect SUCC"<<std::endl;
  socket.write("GET / HTTP/1.1\r\n\r\n");
  while (socket.waitForReadyRead())
  std::cout<< socket.readAll().data();
}

test.pro如下:
TEMPLATE = app
TARGET = 
DEPENDPATH += .
INCLUDEPATH += .
QT += network
SOURCES += test.cpp
CONFIG += console release


预期的输出结果是
Connect SUCC
HTTP/1.0 200 OK
Server: TWS
Date: Sat, 03 Oct 2009 18:44:08 GMT
Expires: Sat, 03 Oct 2009 22:44:08 GMT
Cache-Control: max-age=14400
Content-Type: text/html
Content-Length: 95
Last-Modified: Tue, 24 Mar 2009 16:03:37 GMT
Age: 3230
X-Cache: HIT from m50.mail.qq.com
Via: 1.0 m50.mail.qq.com (squid/3.0.STABLE13)
Connection: close

<html>
<head>
<meta http-equiv="refresh" content="0; url=/cgi-bin/loginpage">
</head>
</html>

内容由mail.qq.com提供,可能会有所变化。



第五部分:测试 shared build 环境

C:\Software\QT45\qt\bin\qmake
nmake
运行,可能会报以下错误,别紧张,可能是找不到 openssl 的dll
QSslSocket: cannot call unresolved function SSLv3_client_method
QSslSocket: cannot call unresolved function SSL_CTX_new
QSslSocket: cannot call unresolved function SSL_library_init
QSslSocket: cannot call unresolved function ERR_get_error
QSslSocket: cannot call unresolved function ERR_error_string
可以复制前面提到的两个OpenSSL的dll文件,到temp.exe所在目录



第六部分:测试 static build 环境

C:\Software\QT45\qts\bin\qmake
nmake clean && nmake
运行看结果



第七部分:为vim添加QT类库的自动补全

先配置好vim,并且确保ctags.exe在PATH下能找到,然后:
ctags -R --c++-kinds=+p --fields=+iaS --extra=+q C:\Software\Qt45\qt\include
生成了一个接近18M的tags文件,把这个文件复制到C:\Software\Qt45\
在vim的配置文件中,把 C:\Software\Qt45\tags 添加进 tags 变量,建议不要这么做,因为

QT的tags有18M,并非所有的项目都需要QT,可以绑定到快捷键,需要的时候再打开QT自动补全。



下载NOKIA网站上的QT SDK,解压或安装到相关目录。

本文以QT 4.6.2为例,下载地址:http://get.qt.nokia.com/qt/source/qt-win-opensource-4.6.2-vs2008.exe
或者直接下载源码:http://get.qt.nokia.com/qt/source/qt-everywhere-opensource-src-4.6.2.zip

下载后安装好的目录结构为(假设安装到D:\QT):
├─share
├─lib
├─bin
├─mingw
└─qt
    ├─translations(QT语言文件目录)
    ├─tools(QT相关工具源码目录)
    ├─src(源代码目录)
    ├─qmake(qmake源代码目录)
    ├─plugins(图形,数据库等插件目录)
    ├─mkspecs(平台配置文件)
    ├─lib(库文件)
    ├─include(头文件)
    ├─examples(示例程序)
    ├─doc(文档)
    ├─demos(演示程序)
    ├─config.tests
    ├─bin(命令行工具)
    └─qtc-debugging-helper

configure配置工具在qt目录,以下假设QTDIR=D:\QT\SDK\qt,编译前最好清空 lib,demos,examples,docs四个目录,配置完成后在这几个目录下放一个空的Makefile文件,避免make时报错。

VS2005动态编译

1.设置VS2005的环境变量
2.设置目标平台
set QMAKESPEC=win32-msvc2005
3.进入 QTDIR目录运行配置,生成Makefile文件
configure -platform win32-msvc2005 -release -opensource -shared -fast -qt-sql-sqlite -plugin-sql-sqlite -no-qt3support  -qt-zlib -qt-gif -qt-libpng -qt-libmng -qt-libtiff -qt-libjpeg -no-webkit -qt-style-windowsxp -qt-style-windowsvista
4. 运行nmake /I /K(附带/I /K 选项可以避免出现错误时编译自动终止,用于跳过错误继续编译其它文件)

经过这样编译的Qt库不依赖mingwm10.dll,libgcc_s_dw2-1.dll,但依赖Qt库的Dll文件和微软的CRT运行时库,使用此Qt库编译Windows平台下的程序,发布时需带上用到的Qt链接库Dll文件和微软的CRT运行时库Dll文件。

VS2005静态编译

(VS2008 编译同理,启动相应的命令行,设置相应的目标平台,修改相应的配置文件)
1.设置VS2005的环境变量
2.设置目标平台
set QMAKESPEC=win32-msvc2005
3.修改mkspecs/win32-msvc2005目录下的配置文件 qmake.conf
将下面两行:
QMAKE_CFLAGS_RELEASE    = -O2 -MD
QMAKE_CFLAGS_DEBUG      = -Zi -MDd
修改为:
QMAKE_CFLAGS_RELEASE    = -O2 -MT
QMAKE_CFLAGS_DEBUG      = -Zi -MTd
(D是指dynamic,T是指static,d是指debug)
4.进入QTDIR目录,运行配置,生成 Makefile文件
set QMAKESPEC=win32-msvc2005
configure -platform win32-msvc2005 -release -no-exceptions -opensource -static -fast -qt-sql-sqlite -plugin-sql-sqlite -no-qt3support  -qt-zlib -qt-gif -qt-libpng -qt-libmng -qt-libtiff -qt-libjpeg -no-webkit -qt-style-windowsxp -qt-style-windowsvista
5.运行运行nmake /I /K

经过这样编译的Qt库不依赖于任何Dll文件(如微软的CRT运行时库),使用此Qt库编译Windows平台下的程序发布时不需要附带任何额外的 Dll文件。

MinGW静态编译

1.设置MinGW的环境变量
2.设置目标平台
set QMAKESPEC=win32-g++
3.修改 mkspecs/win32-g++目录下的配置文件qmake.conf
将下面一行:
QMAKE_LFLAGS = -enable-stdcall-fixup -Wl,-enable-auto-import -Wl,-enable-runtime-pseudo-reloc
修改为:
QMAKE_LFLAGS = -static -enable-stdcall-fixup -Wl,-enable-auto-import -Wl,-enable-runtime-pseudo-reloc
然后将下面一行:
QMAKE_LFLAGS_DLL        = -shared
修改为:
QMAKE_LFLAGS_DLL        = -static
4.QTDIR目录,运行配置,生成Makefile文件
set QMAKESPEC=win32-g++
configure -platform win32-g++ -release -no-exceptions -opensource -static -fast -qt-sql-sqlite -plugin-sql-sqlite -no-qt3support  -qt-zlib -qt-gif -qt-libpng -qt-libmng -qt-libtiff -qt-libjpeg -no-webkit -qt-style-windowsxp -qt-style-windowsvista
5.运行运行mingw32-make -i -k(-i -k选项的含义与上面nmake的相同)

经过这样编译的Qt库,不依赖任何Dll文件(如mingwm10.dll,libgcc_s_dw2-1.dll),使用此Qt库编译的 Windows平台下的程序发布时不需要附带任何额外的Dll文件。

编译事项说明

编译完成后可以删除bin目录中所有不是当前编译日期的文件。

建议编译前移除examples和demos文件夹的所有文件,避免重编译这两个文件夹,加快编译速度。

另外,编译命令请根据自己的实际情况配置,上面我的配置是(以VS2005静态编译为例):
-platform win32-msvc2005 目标平台
-release 关闭调试信息
-no-exceptions 除去异常支持
-opensource 开源
-static 创建静态库
-fast 快速配置,只生成Qt库文件及子目录的Makefile文件,其它的Makefile文件后面再使用qmake生成
-qt-sql-sqlite SQLite驱动支持
-plugin-sql-sqlite  SQLite链接插件支持
-no-qt3support  不编译Qt3兼容库
-qt-zlib zlib库
-qt-gif -qt-libpng -qt-libmng -qt-libtiff -qt-libjpeg 图形格式插件库
-no-webkit 不编译webkit,此选项可极大加快编译速度,需要使用WebKit的可以删除此选项
-qt-style-windowsxp -qt-style-windowsvista 支持XP和Vista主题样式

注意:使用静态编译的程序通常较大,建议发布前使用UPX压缩,一般可以减少至少50%的大小。(文/mcxiaoke


问题一: 无法编译

   按照QT指南一书,编译的方法是在项目目录下在qt命令行提示符输入命令:

    qmake -project  

    qmake xx.pro

然后在vs2008的命令行提示符内输入nmake编译程序。编译完成后会生成debug子目录,并在其中有exe文件。但执行该exe后会出现警告“无法定位程序输入点xxxxx于动态连接库QtCored4.dll上”。程序无法进行。

    在qt下命令行提示符下打命令qmake -tp vc xx.pro 欲将项目转化为vs2008项目来编译,则会出现如下错误信息,无法进行转化。

WARNING: Unable to generate output for: C:/Documents and Settings/Administrator/??/qt-book/chap01/age//Makefile.Debug [TEMPLATE vcapp]
WARNING: Unable to generate output for: C:/Documents and Settings/Administrator/??/qt-book/chap01/age//Makefile.Release [TEMPLATE vcapp]

   最后发现问题在于我并没有指定编译平台,使qt无法将生成该编译平台下的项目文件,导致编译失败。处理方式是:

   在qt命令行提示符下输入:set QMAKESPEC=win32-msvc2008 (指定为vs2008编译环境)

所有问题都解决了。。。。

问题二:qt designer 显示的窗体不完整

    搞了半天,原来是我的XP的主题问题,将XP的桌面主题改为XP默认主题,问题搞定。。。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt5中集成log4qt的过程主要包括以下几个步骤: 1. 下载log4qt库:首先需要从log4qt的官方网站或者其他可靠的资源网站下载log4qt的源代码库。将下载的库解压到任意目录下。 2. 添加库到Qt项目:打开Qt Creator,打开需要集成log4qt的项目。在项目的.pro文件中添加log4qt库,可以使用类似于`LIBS += -L/path/to/log4qt -llog4qt`的方式添加。 3. 配置log4qt的头文件和源文件:在Qt Creator中,找到项目目录中的头文件和源文件文件夹,将解压的log4qt库中的包含文件和源文件拷贝到对应的文件夹中。 4. 编译并链接log4qt库:在Qt Creator中,点击编译按钮进行编译,并确保log4qt库能够成功链接到项目中。如果编译或链接出现问题,可以检查是否添加了正确的库路径和库文件。 5. 使用log4qt:在需要使用日志功能的代码文件中,包含log4qt的头文件,并根据需要创建log4qt的日志记录器对象。通过设置日志记录器的级别、格式等参数,可以配置日志的输出方式。 6. 输出日志:使用log4qt的日志记录器对象,可以通过不同的日志级别(如DEBUG、INFO、ERROR等)输出不同等级的日志信息。可以使用log4qt提供的API函数,将日志输出到控制台、文件等不同的目的地。 7. 测试和调试:完成上述步骤后,可以对项目进行测试和调试。在运行项目时,可以根据配置的日志级别,查看和分析log4qt输出的日志信息,以辅助项目的测试和调试工作。 总结起来,集成log4qtQt5项目中的过程包括添加库、配置头文件和源文件、编译链接库、使用log4qt输出日志等步骤。通过正确配置和使用log4qt,可以方便地实现日志功能,从而提高项目的测试和调试效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值