1. 为什么需要CMake与GLM库整合
刚开始接触OpenGL开发时,我经常被各种数学计算搞得头大。比如要实现一个简单的3D立方体旋转效果,光是矩阵变换就写了上百行代码。直到发现了GLM库,这个专门为OpenGL设计的数学库彻底改变了我的开发体验。
GLM全称OpenGL Mathematics,它完美复刻了GLSL的数学函数和数据类型。这意味着如果你熟悉GLSL着色器编程,就能无缝切换到C++端使用相同的数学操作。但问题来了:如何把这个强大的工具优雅地集成到项目中?这就是CMake的用武之地。
记得我第一次手动配置GLM时,直接把头文件复制到项目目录。虽然能用,但每次更新版本都要重新复制,项目结构也变得混乱。后来发现用CMake管理依赖,不仅能自动处理路径问题,还能方便地切换版本。更重要的是,团队协作时再也不用挨个交代"记得把GLM放在那个文件夹里"。
2. 项目环境搭建与基础配置
2.1 创建CMake项目骨架
先来看一个最基础的OpenGL项目结构。我习惯这样组织文件:
MyOpenGLProject/
├── CMakeLists.txt
├── include/
├── src/
│ └── main.cpp
└── external/
└── glm/
对应的CMakeLists.txt基础配置如下:
cmake_minimum_required(VERSION 3.10)
project(OpenGLWithGLM LANGUAGES CXX)
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
add_executable(${PROJECT_NAME} src/main.cpp)
这里有几个关键点需要注意:
- 指定C++17标准(GLM的部分功能需要C++11以上)
- 项目名称使用变量${PROJECT_NAME}便于复用
- 源文件路径要写对,否则编译会报错
2.2 获取GLM库的两种方式
第一种是手动下载,直接从GLM的GitHub仓库下载zip包。但我更推荐第二种方式——使用Git子模块:
git submodule add https://github.com/g-truc/glm.git external/glm
这样做的优势是:
- 版本可控,可以锁定特定commit
- 团队协作时自动同步依赖版本
- 更新方便,一条命令就能升级到最新版
如果不想用Git,也可以用C

3508

被折叠的 条评论
为什么被折叠?



