CGAL库在Windows下的安装与配置
CGAL库是一个强大的开源工具,以C++库的形式为开发者提供了高效可靠的几何算法。最近再一次使用到这个库,在新的环境下重新配置了一番,发现里面还是有很多丰富的、值得研究的功能的,遂记录下其在Windows下的安装与配置流程。
一、获取CGAL源码
我们可以在CGAL的GitHub仓库的release页面中下载到最新版本的源码压缩包CGAL-6.0.1.zip
,将其解压,放在一个合适的位置。
然后需要添加一个环境变量CGAL_DIR
,值为源码所在的路径,如D:\MyInclude\cpp\CGAL-6.0.1
二、安装Boost
Boost是CGAL的强制依赖项,二进制版本的Boost可以在SourceForge上找到,这里我们下载的是boost_1_86_0-msvc-14.1-64.exe
,下载好后运行程序即可将Boost安装在你指定的位置,这里我将它安装在了D:\MyInclude\cpp\boost_1_86_0
安装好后我们需要设置两个环境变量分别指向库和头文件路径
BOOST_LIBRARYDIR = D:\MyInclude\cpp\boost_1_86_0\lib64-msvc-14.3
BOOST_INCLUDEDIR = D:\MyInclude\cpp\boost_1_86_0
这将使cmake能够找到Boost。
此外,需将dll所在文件夹的路径(D:\MyInclude\cpp\boost_1_86_0\lib64-msvc-14.3
)添加到PATH环境变量中
tip:上述路径请根据自身情况调整
三、安装GMP和MPFR
GMP和MPFR同样是CGAL所必需的依赖项,在CGAL的release页面我们可以找到作者提供的预编译版本(CGAL-6.0.1-win64-auxiliary-libraries-gmp-mpfr.zip)下载后解压到CGAL的目录中,这样cmake便能够自动检测这些依赖项。
tip:CGAL目录下有文件夹auxiliary,这个压缩包解压出来后也是一个文件夹auxiliary,将其移动过去本质上就是把这个文件夹里的东西放到CGAL\auxiliary文件夹中。
此时,我们便完成了CGAL及其所有必需依赖项的安装。
四、通过CMake使用CGAL
通过在CMakeLists.txt
中添加如下语句,便可将程序与CGAL链接起来
find_package(CGAL REQUIRED)
add_executable(my_executable my_source_file.cpp)
target_link_libraries(my_executable CGAL::CGAL)
CGAL库中的其他组件也是类似地进行链接,如CGAL_core
find_package(CGAL REQUIRED COMPONENTS Core)
target_link_libraries(my_executable CGAL::CGAL CGAL::CGAL_Core)
五、使用CGAL+Qt6的示例
这里展示了一个使用CGAL和Qt6实现的一些GUI功能的程序演示(前提是安装了Qt6)
CMakeLists.txt:
cmake_minimum_required(VERSION 3.20.0)
project(Surface_mesh_Examples)
#CGAL_Qt6 is needed for the drawing.
find_package(CGAL REQUIRED OPTIONAL_COMPONENTS Qt6)
#create the executable of the application
create_single_source_cgal_program("draw_surface_mesh.cpp")
if(CGAL_Qt6_FOUND)
#link it with the required CGAL libraries
target_link_libraries(draw_surface_mesh PUBLIC CGAL::CGAL_Basic_viewer)
endif()
draw_surface_mesh.cpp:
#include <CGAL/Simple_cartesian.h>
#include <CGAL/Surface_mesh.h>
#include <CGAL/draw_surface_mesh.h>
#include <fstream>
typedef CGAL::Simple_cartesian<double> Kernel;
typedef Kernel::Point_3 Point;
typedef CGAL::Surface_mesh<Point> Mesh;
int main(int argc, char* argv[])
{
const std::string filename = (argc>1) ? argv[1] : CGAL::data_file_path("meshes/elephant.off");
Mesh sm;
if(!CGAL::IO::read_polygon_mesh(filename, sm))
{
std::cerr << "Invalid input file: " << filename << std::endl;
return EXIT_FAILURE;
}
// Internal color property maps are used if they exist and are called "v:color", "e:color" and "f:color".
auto vcm = sm.add_property_map<Mesh::Vertex_index, CGAL::IO::Color>("v:color").first;
auto ecm = sm.add_property_map<Mesh::Edge_index, CGAL::IO::Color>("e:color").first;
auto fcm = sm.add_property_map<Mesh::Face_index>("f:color", CGAL::IO::white() /*default*/).first;
for(auto v : vertices(sm))
{
if(v.idx()%2)
{ put(vcm, v, CGAL::IO::black()); }
else
{ put(vcm, v, CGAL::IO::blue()); }
}
for(auto e : edges(sm))
{ put(ecm, e, CGAL::IO::gray()); }
put(fcm, *(sm.faces().begin()), CGAL::IO::red());
// Draw!
CGAL::draw(sm);
return EXIT_SUCCESS;
}
编译生成后,注意需在生成的可执行程序draw_surface_mesh.exe
所在路径下执行以下命令,将此程序所需的Qt6的dll文件自动复制过来
windeployqt.exe ./draw_surface_mesh.exe
并手动将gmp的dll文件gmp-10.dll
复制过来
然后运行程序便有如下GUI显示