利用CMake工具从源码编译出osgEarth库

1.前言

       osgEarth是基于三维引擎osg开发的三维数字地球引擎库,在OpenSceneGraph(为了便于后文表述,简称为osg)基础上实现了瓦片调度插件,可选四叉树调度插件,更多的地理数据加载插件(包括GDAL,ogr,WMS,TMS,VPB,filesystem等),再结合一套地理投影转换插件,这样就能够实现高效处理加载调度地理数据在三维地球上的显示,实现三维虚拟地球。

         本文讲解如何利用cmake等工具从osgEarth源码编译出osgEarth库。

2.源码下载及相关文档链接

  •  osgEarth源码可以从osgEarth源码下载。
  • 从Download | Download | CMake下载 CMake图形化工具,截至2023年4月5日,最新版本为3.26.3。直接双击安装即可。

  •  官网学习文档为:Welcome to osgEarth! — osgEarth 3.3 documentation

3.环境说明

      本人环境说明如下:

  • Windows 11 家庭中文版 22H2 22621.1413
  • Microsoft Visual Studio Community 2022 (64 位) - Current
    版本 17.5.1
  • CMake 3.23.0-rc2
  • OpenSceneGraph-3.6.2
  • osgearth-3.2

特别说明:osgearth和osg版本代差不能太大,否则编译osgearth时会报很多osg的头文件找不到的错误。现实中,我用osgearth3.2版本,而osg用3.4.1版本,则报很多类似如下的错误:

无法打开包括文件: “osg/BindImageTexture”: No such file or directory
error C2039: "VertexArrayState": 不是 "osg" 的成员

这是因为osgearth3.2版本用到很多osg新加入的功能,而这些功能在版本较低的osg中没有导致。

4.第三方库编译

  • 从GitHub - protocolbuffers/protobuf: Protocol Buffers - Google's data interchange format下载prototbuffers库,并用CMake生成VS工程进行编译。注意版本不要选得太老,也不要选的太新,我选的是prototbuffers 3.13.0。
  • 从OpenGL SDK: GLEW - The OpenGL Extension Wrangler Library下载glew库。
  • 从GitHub - libgeos/geos: Geometry Engine, Open Source下载geos库。并用CMake生成VS工程进行编译。
  • 从Download — GDAL documentation下载gdal库。并用CMake生成VS工程进行编译。
  • 从https://github.com/curl/curl下载curl库,并用CMake生成VS工程进行编译。
  • 从zlib Home Site下载zlib库,并编译出lib和dll。

关于如何用CMake生成VS工程,参见 后文描述,和后文利用CMake编译osgEarth类似。

5.编译及编译错误处理

5.1 编译

1):因为osgearth是在osg库基础上开发的,需要配置osg库才行,所以需先从osg源码编译出osg库,具体编译方法参见《windows平台下用CMake编译osg》博文。

2):打开CMake界面,在CMake图形界面中的“Where is the source code:”的编辑框中输入osgearth-3.2源码目录,注意:该目录必须是CMakeList.stxt所在目录,且目录路径不能有中文,否则CMake会报错。 

3):在“Where to build the binaries”中输入osgearth-3.2编译、链接后生成文件的存放目录。为避免编译产生的文件和源码混放在一起,一般在源码目录的同级目录新建一个类似build目录来存放编译输出结果文件。CMake界面如下:

利用CMake工具从源码编译出osgEarth库_第1张图片

 图1

 4):点击cmake图形界面中的“configure”按钮或“Tools->Configure”菜单,如果是初次执行,则弹出如下界面:

利用CMake工具从源码编译出osgEarth库_第2张图片

  根据本机装的VS选择VS版本,我本机装的是VS2022。注意:后面一项得选x64,相信现在用win32的已经很少了。单击Finish按钮,关闭该对话框回到cmake主界面,单击左下角的“Genrerate”,出现如下错误:

利用CMake工具从源码编译出osgEarth库_第3张图片

 这是因为osg相关库及某些第三方库没有配置,如下:

利用CMake工具从源码编译出osgEarth库_第4张图片

解决方法如下: 

  • 找到步骤1)编译出来的osg库和头文件,并将上图蓝色框中所有和osg有关的NOTFOUND的信息都配置好。
  • 将上图中cur、gdal、GEOS、GLEW、zlib、protobug库有关的NOTFOUND的信息都配置好。
  • 从SQLite Download Page下载sqlite3库和头文件,并配置好。

说明:

  • 暂时只需cur、gdal、GEOS、GLEW、zlib、protobug、sqlite3这几个必须库
  • 其它第三方库不用配置、不用管,要下载全部第三方库挺不容易的,一旦在cmake中配置了其它非必须库,则又会带出很多其它库,且因为其它非必须库在网上很难找全,从而又会导致如下错误:
 Error in configuration process, project files may be invalid
  • 不要勾选CMake中的OSGEARTH_BUILD_LEGACY_SPLAT_NODEKIT、OSGEARTH_BUILD_PROCEDURAL_NODEKIT、OSGEARTH_BUILD_ROCKSDB_CACHE、OSGEARTH_BUILD_SILVERLINING_NODEKIT,否则需要下载LEGACY、PROCED、ROCKSDB、SILVERLINING库,这几个库很难在网上找到,暂时不知道这几个库起什么作用。
  • 我的cmake配置如下:

利用CMake工具从源码编译出osgEarth库_第5张图片

利用CMake工具从源码编译出osgEarth库_第6张图片利用CMake工具从源码编译出osgEarth库_第7张图片

利用CMake工具从源码编译出osgEarth库_第8张图片

利用CMake工具从源码编译出osgEarth库_第9张图片

利用CMake工具从源码编译出osgEarth库_第10张图片

利用CMake工具从源码编译出osgEarth库_第11张图片

利用CMake工具从源码编译出osgEarth库_第12张图片

所有配置好后,单击“configure”,之后单击“Generate”,然后单击“Open Project”启动VS开始编译。

 5.2.编译错误处理

1)无法打开包括文件: “sqlite3.h”: No such file or directory

     这是在CMake中没有配置sqlite3引起的,请按前文描述配置好该库。

2)无法打开包括文件: “vector_tile.pb.h”: No such file or directory

     这是在CMake中没有配置protobuf引起的,请按前文描述配置好该库。

3)   error LNK2038: 检测到“RuntimeLibrary”的不匹配项: 值     “MDd_DynamicDebug”不匹配值“MTd_StaticDebug”

解决方法:找到报错的工程,然后在该工程单击右键,选择“属性->配置属性->C++->代码生成”属性页中的“运行库”下拉框中选择“多线程 (/MTd)”,如果还不行改为其它的试试,如:MT、Md等 。
 

你可能感兴趣的:(osgEarth,osgEarth)