cmake qt 记录

参考:

C:\Qt\Qt5.13.0\5.13.0\msvc2017\bin
C:\Qt\Qt5.13.0\5.13.0\msvc2017\lib\cmake\Qt5

https://doc.qt.io/qt-5/cmake-manual.html
https://blog.youkuaiyun.com/aladinsmagiclamp/article/details/79075450
https://github.com/GlLamant/CMakeCompileQtProject

CMAKE学习经典书籍《Mastering CMake》,网上知识讲解碎片化,还是看看文档来的快。cmake效率高效,学起来也挺简单的。

CMake Practice.pdf
CMake 入门实战(精)
Cmake从入门到精通(pdf教程)
cmake简明教程-半小时从入门到精通
CMake实践——关于Cmake使用方法的书籍

通常cmake编译命令

cmake dir
想要指定cmake版本在其后附加参数 -G 即可

cmake dir -G “Visual Studio 11 2012”

https://cmake.org/cmake/help/v3.18/manual/cmake-server.7.html
https://cmake.org/cmake/help/v3.18/

正文

使用 qt creator 建立一个简单的 qt widgets 工程
得到如下几个文件
main.cpp
mainwindow.cpp
mainwindow.h
mainwindow.ui

放在 helloA目录下面
新建一个 build 目录

新建一个 CMakeLists.txt 文件
内容为:

cmake_minimum_required(VERSION 3.5.1)
project(qui)

set(Qt5_DIR "C:\\Qt\\Qt5.13.0\\5.13.0\\msvc2017\\lib\\cmake\\Qt5")

SET(CMAKE_INSTALL_PREFIX "F:\\qt_work\\qt5_code_plus_jack\\cmake_qt\\helloA\\build")

set(CMAKE_INCLUDE_CURRENT_DIR ON)
set(CMAKE_AUTOUIC ON)
set(CMAKE_AUTOMOC ON)
set(CMAKE_AUTORCC ON)

set(CMAKE_CXX_STANDARD 11)
set(CMAKE_CXX_STANDARD_REQUIRED ON)

#FIND_PACKAGE(Qt5 COMPONENTS Core Gui Qml Quick Widgets REQUIRED)
FIND_PACKAGE(Qt5 COMPONENTS Widgets REQUIRED)

SET(qui_SOURCES 
	main.cpp 
	mainwindow.cpp 
)

SET(qui_HEADERS 
	mainwindow.h
)

SET(qui_FORMS 
	mainwindow.ui
)

#SET(qui_RESOURCES 
#	img.qrc
#)

#调用预编译器moc,需要使用 QT5_WRAP_CPP宏
QT5_WRAP_CPP(qui_HEADERS_MOC ${qui_HEADERS})

#使用uic处理.ui文件
QT5_WRAP_UI(qui_FORMS_HEADERS ${qui_FORMS})

#使用rcc处理.qrc文件
QT5_ADD_RESOURCES(qui_RESOURCES_RCC ${qui_RESOURCES})

#这些生成的中间文件都会在build目录下,这样的话,编译器则不能定位由uic程序产生的诸如_ui_mainwindow.h等文件。所以,我们需要把build目录添加到包含目录中
INCLUDE_DIRECTORIES(${CMAKE_CURRENT_BINARY_DIR})

#生成可执行文件
ADD_EXECUTABLE(qui 
	${qui_SOURCES} 
	${qui_HEADERS_MOC} 
    ${qui_FORMS_HEADERS}
	${qui_RESOURCES_RCC} 
)

#为target添加需要链接的共享库
TARGET_LINK_LIBRARIES(qui Qt5::Core Qt5::Gui ${Qt5Widgets_LIBRARIES})
TARGET_LINK_LIBRARIES(qui ${Qt5Widgets_LIBRARIES})
INSTALL(TARGETS qui
    RUNTIME DESTINATION lib
    LIBRARY DESTINATION lib
    ARCHIVE DESTINATION lib
)


打开cmake gui
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

### 如何在 Qt Creator 中使用 CMake 进行项目配置和构建 #### 使用 CMake 创建新项目 为了创建一个新的基于 CMake 的项目,在启动 Qt Creator 后可以选择 `File` -> `New File or Project`,然后选择 `Application` 下的 `Non-Qt Project` 类型中的 `Plain C++ Application` 或者其他适合的选择。这会引导开发者通过一系列向导来设置项目的初始参数。 对于已有项目,可以直接打开包含 `CMakeLists.txt` 文件所在的目录作为项目根路径[^3]。 #### 设置 CMake 版本和支持工具链 确保安装了适当版本的 CMake 并且可以通过环境变量访问到它。如果需要特定编译器或其他开发工具,则应在 Qt Creator 内部指定这些选项。通常情况下,默认配置已经足够满足大多数需求[^5]。 #### 开始配置过程 当加载了一个支持 CMake 的项目之后,Qt Creator 自动检测并读取 `CMakeLists.txt` 文件的内容来进行初步解析。此时可以点击左下角的小扳手图标进入 Kit Options 页面确认所使用的 kit 是否正确无误;kit 是指一组关联在一起用于构建应用程序所需的资源集合,比如平台、编译器等信息。 接着可以在底部状态栏找到两个按钮:“Configure Project” 和 “Build All”。前者用来重新运行一次完整的 cmake 命令以更新内部缓存数据结构以及处理任何可能存在的更改;后者则是触发实际的 make 构建流程[^4]。 #### 执行构建操作 完成上述准备工作以后就可以按下绿色三角形按钮或者菜单里的 `Build` -> `Rebuild All Projects` 来开始整个工程的一次全新重建工作。期间产生的日志会被记录下来供后续查看分析之用。 一旦成功完成了所有阶段的任务,生成的应用程序二进制文件将会放置于预先定义好的输出位置等待进一步部署或调试[^1]。 ```cpp // 示例:简单的 CMakeLists.txt 文件内容展示 cmake_minimum_required(VERSION 3.10) project(MyProject) set(CMAKE_CXX_STANDARD 17) add_executable(${PROJECT_NAME} main.cpp) ``` #### 测试与打包功能 除了基本的构建能力之外,还可以利用内置的支持去调用ctest执行单元测试案例集,或是借助cpack实现跨平台分发包制作等功能特性[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值