QT工程pro设置实践(with QtCreator)----非弄的像VS一样才顺手?
来源:互联网 发布:js保存map 编辑:程序博客网 时间:2024/04/28 11:42
相信大家很多和我一样,用多了微软给的便利,用人家的就十分不习惯.于是就琢磨原来用到的功能现在要整顺手来,不然可让人怎么活啊! 本篇主要介绍实践使用,并非一篇完整教程,有待读者补充.^_^
我们原本在VS上有一个大工程sln,里面有lib,有dll有exe,甚至还混搭了C#.用起来一点不觉得水土不服.现在要用QT重整,并且需要处处考虑换个平台不要让我改东西.作为探路先锋,先挑了几个基础工程出来做实验:
↑当然,图中是已经成事之后了.想在qtcreator中弄一个工程集还真不是那么方便,我到处找过了,压根没有创建工程集的办法.纵使你可以一个pro一个pro的拖进去,最后也没法保存,下次打开还得重新一个一个pro的拖,没哪个傻蛋总这么干吧..所以首先就是要手动创建一个subdirs型的pro做为工程集,也就是上面看到的
**CloudBoard_win32.pro**(subdirs举例)
01
TEMPLATE = subdirs
02
03
SUBDIRS =\
04
raknet\
05
onetengine \
06
omisc \
07
testDebugShow
08
09
onetengine.depends = raknet omisc
10
testDebugShow.depends = omisc
11
#CONFIG += ordered
关于这个pro的详细写法,感觉qt文档写的很细碎,反正我是没看明白.就着广大网友的例子才有了上面一段.TEMPLATE=subdirs这是固定写法,声明是做工程集目录的.SUBDIRS是指明目录中有哪些项,可以嵌套另一个subdirs型的pro. 接下来可以详细定义其中的项目.如.depends表示左边的依赖=后面的项目.
.subdir指定子项的目录,不使用子项本身的名字.
.file
明确指定该子项使用的pro文件,默认是根据名字自动找的,该项不和.subdir同时使用
.condition
Specifies a bld.inf define that must be true for subproject to be built. Available only on Symbian platform.
.depends
该子项依赖指定的子项,只在使用makefiles的平台有效.makefile
该子项的makefile,只在使用makefiles的平台有效.target
该子项的TARGET,只在使用makefiles的平台有效
以上翻译可能有问题.重新总结一下.使用subdirs =a b c d声明的其实是4个子项的名字.默认你不多做说明的话,qmake根据名字自动去找子目录,启用子目录中的pro文件(名字优先匹配).如果你特别说明a.subdir=./z或者a.file=./z/z.pro就可以不受名字限制. 至于.makefile,应该是你混用第三方库的时候才有必要手动指定使用的makefile. target可以在子pro中指定,除非你觉得这里比较统一方便修改.其余的未实践不多说.
**omisc.pro**(staticlib举例)
01
QT -= gui ①
02
03
TARGET = misc ②
04
TEMPLATE = lib #固定写法
05
CONFIG += staticlib #静态库固定写法
06
#DEFINES += ③
07
DESTDIR = $$_PRO_FILE_PWD_/../lib ④
08
SOURCES += \
09
ostatic.cpp \
10
odebugoutput.cpp
11
12
HEADERS += omisc.h \
13
ostatic.h \
14
ostringmap.hpp \
15
odebugoutput.h
16
unix:!symbian { ⑤
17
maemo5 {
18
target.path = /opt/usr/lib
19
}
else
{
20
target.path = /usr/lib
21
}
22
INSTALLS += target
23
}
QT-=core gui.此处QT-=gui表示我们还用了core
②TARGET是生成目标,名字不做修饰(不加.a/.lib/.dll)的好处是让qt帮我们加,在不同平台不用我们考虑差别.
同时这里的名字是可以前置路径的,如../lib/misc.它会生成在相对生成目录上一级的lib下.不过我劝你还是不要写相对路径了,因为在windows下会多出debug/release目录,目录深度不同,你换一个平台得重写.这还有更好的办法,后面继续.
③DEFINES是VS里面的预定义头,就是定义宏,哎哟总算见着熟人了~
④DESTDIR就是刚才②说的好办法.它控制最终的输出,相当于VS的OurDir.此处我们控制它输出到$$_PRO_FILE_PWD_/../lib.前面$$开头的是一个pro变量 ,存放的是工程路径,就是CloudBoard_win32.pro的路径,还有更多的定义参考Qt助手. 你可以用类似message($$_PRO_FILE_)的语句测试变量到底是什么值.具体使用是:写在pro中,右键pro的工程执行qmake.从编译输出中可以看到.
⑤最后这段是自动产生的,本人实在没有仔细研究,看样子应该是一种指定target目录的办法.而unix:!symbian让人不难想到,这是在筛选特定平台.具体的欢迎您测试后补充^_^
raknet相信很多童鞋了解,本案简单将其代码编译成staticlib,DESTDIR=$$_PRO_FILE_PWD_/../lib完工
**onetengine.pro**(动态库举例)
01
!include( ../common.pri ) { ①
02
error
(
" Couldn't find the common.pri file! "
)
03
}
04
05
QT -= gui
06
QT += network xml
07
08
TARGET = netengine
09
TEMPLATE = lib
10
DESTDIR = ../bin #基于生成目录
11
12
INCLUDEPATH += ../omisc ../raknet/source ②
13
DEPENDPATH += ../omisc ../raknet/source #基于工程目录
14
win32:LIBS += -lWs2_32 ③
15
LIBS += -lmisc -lraknet
16
17
DEFINES += ONETENGINE_LIBRARY ④
18
19
SOURCES += onetengine.cpp \
20
netengine_export.cpp
21
22
HEADERS += onetengine.h\
23
onetengine_global.h \
24
../include/macrodefine.h \
25
../interface/isinkfornetengine.h \
26
../interface/inetengine.h
**common.pri**(pro包含举例)
1
INCLUDEPATH += ../interface ../include ⑤
2
#LIBS += -L$$QTDIR/lib
3
LIBS += -L../../src/lib
4
LIBS += -L../lib
②INCLUDEPATH是包含目录,类似于VS中的附加包含目录.至于 DEPENDPATH本人实事求是没有研究不明白有什么用.欢迎补充^_^
③使用筛选器,仅在win32下增加Ws2_32.lib的导入. LIBS相当于VS中的附加依赖库,不同的是可以通过-L指定库目录,-l指定库名.其间没有空格的哦.例如上面的LIBS+=-L../lib -lmisc就是可以到../lib中找misc库.misc没有说明.a还是.lib是让qt帮我们做.你也可以指定.lib,然后通过筛选器把其他平台的也写一下.
④提供宏定义ONETENGINE_LIBRARY是因为在向导创建动态库的时候qtcreator帮我们定义了这样的
01
#ifndef ONETENGINE_GLOBAL_H
02
#define ONETENGINE_GLOBAL_H
03
04
#include <QtCore/qglobal.h>
05
06
#if defined(ONETENGINE_LIBRARY)
07
# define ONETENGINESHARED_EXPORT Q_DECL_EXPORT
08
#else
09
# define ONETENGINESHARED_EXPORT Q_DECL_IMPORT
10
#endif
11
12
#endif // ONETENGINE_GLOBAL_H
提供宏定义ONETENGINE_LIBRARY决定了该工程的作用是导出动态库的.
⑤最后common.pri只是定义了几项公共的没有平台差异的信息
好了,testDebugShow的工程pro就不多说了,它和动态库的很相似,只有TEMPLATE=app没有XXXX_LIBRARY的宏定义而已.
最后补充一点,为什么总的工程名要叫CloudBoard_win32呢,明眼人一看就知道这是要分平台了呢.没错,一开始我也觉得一个pro就搞定了,里面可以有筛选器,一份pro足以应付.但是实际是qtcreator会为pro产生同名的.user文件,qtcreator的一些配置会写在.user里面,例如最关键的qtSDK位置,编译工具,构建/生成设置等.这些必须根据生成所处的环境区别设置. 所以当你原样跑到Linux下,启动pro就会告诉你配置是别处读来的,是否使用?是:配置一定是错的,否:配置被清洗.这都不是我们希望的.所以唯有分平台建总pro了.
秉承开源精神,以上内容欢迎纠正,补充!
尊重原创,尊重知识产权,从我做起.@2013/01/09
本文感谢众多网贴,不过因为大片雷同,我也不知道原作者究竟是谁.
对一搜一大片全部雷同文章的现状很烦恼,很浪费时间.倡议大家多做总结,分享消化提炼后的有用知识!
- QT工程pro设置实践(with QtCreator)----非弄的像VS一样才顺手?
- QT工程pro设置实践(with QtCreator)----非弄的像VS一样才顺手?
- QT工程pro设置实践(with QtCreator)
- VS+QT和qtcreator工程的互相转换
- Qt pro->vs工程和vs工程->pro
- QT的qmake 通过pro文件生成vs工程
- Qt 像VS一样建立解决方案(Qt 子项目)
- VS建立的Qt工程(或项目)生成pro文件
- XCODE如何像VS(visual studio)一样设置监视变量
- 使用VS创建的Qt工程,设置应用程序图标
- 使用QtCreator创建Qt工程
- CSS设置像文字一样的按钮
- QtCreator下用openpose搭建自己的QT工程
- 关于Qt的.pro工程文件说明
- 编译QT时的工程文件pro
- QT pro工程文件的格式
- Qt的.pro工程文件语法学习
- Qt的.pro工程文件语法学习
- typedef 和 #define 修饰指针类型的区别
- ARM内核全解析
- 远程操作linux网络设置(四)-ssh配置
- 介绍Linux系统如何初始化和启动系统服务的(Linux的开机流程)
- c编程习惯要点
- QT工程pro设置实践(with QtCreator)----非弄的像VS一样才顺手?
- C语言之输入的统计
- photoshop 通道抠图
- AI回合制游戏,过程比较简单。程序中的f变量和条件语句用的很经典。
- db2 自动备份(linux 、windows)总结
- c++ STL 红黑树实现
- org.apache.jasper.JasperException: java.lang.ClassCastException
- dbms_profile工具的使用
- Hibernate映射继承树关系