天天看点

《GDAL源码剖析与开发指南》一一1.7 SWIG编译

本节书摘来自异步社区出版社《gdal源码剖析与开发指南》一书中的第1章,第1.7节,作者:李民录 更多章节内容可以访问云栖社区“异步社区”公众号查看。

gdal源码剖析与开发指南

1.7.1 swig简介

下载安装swig的时候我们注意要下载swigwin文件而不是下载源代码。以swigwin-2.0.4为例,我们下载swigwin-2.0.4.zip文件后解压,将解压目录也添加到环境变量path中去,否则后面需要设置swig的所在目录。检验swig是否成功设置到环境变量path中的最简单的办法就是在运行中输入swig后回车,如果提示windows找不到swig,那么说明没有设置成功;如果出现一个黑屏一闪而过,那么说明已经设置成功了。

下面三小节需要在安装完swig之后才能进行编译。需要注意的是,编译下面三种语言的gdal之前,我们首先要编译c++版本的,就是1.6节的内容。

**

1.7.2 编译c#版本gdal**

首先,我们打开nmake.opt文件,找到swig = swig.exe这一句,假如没有将swig的目录添加到环境变量中,那么将这句后面的swig.exe修改为swig.exe的全路径,如f:work3rdpartswigwin-2.0.4swig.exe;如果设置了环境变量,那么就不需要进行修改了。

然后,我们按照1.6节中的使用cmd命令编译gdal的方式来进行编译,打开“visual studio 2008命令提示”并定位到gdal源代码目录,然后依次执行如下三行命令,其实就是编译c++版本的gdal。

执行以上三句之后,接下来我们使用cd命令,进入swigcsharp文件夹中并使用nmake工具编译,命令如下所示。

执行完以上两句命令后,系统会在csharp文件夹下生成8个dll文件,并将这8个dll文件复制到gdal输出目录下的csharp文件夹中。

这8个dll分别如下。

在c#工程中引用gdal的时候,我们只需要把上面8个dll中后面以_csharp.dll结尾的四个dll加入到c#工程中即可。需要注意的是,在使用这几个dll的时候我们需要将gdal110.dll以及它依赖的其他dll都复制到同一个目录中,才能使c#程序正常运行。

1.7.3 编译python版本gdal

在编译python版本之前,我们要确保自己的电脑中已经安装了python。如果我们安装了arcgis软件,那么就不用再安装python了,因为在安装arcgis的时候必须要安装python。将python的bin目录添加到环境变量path中去,然后我们就可以开始编译python版本的gdal了。

打开nmake.opt文件(1.10版本大概76行左右),将pydir后面的路径修改为本机python的路径。

修改完之后,保存nmake.opt文件。接下来使用cd命令将命令行定位到swigpython目录后,依次输入如下命令。

执行完上述命令后,我们会在python的site-packages目录看到多了gdal和ogr的文件以及一个osgeo的文件夹。我们将编译出来的gdal110.dll以及它依赖的所有dll都复制到site-packages文件夹中的osgeo文件夹中,最后就可以在python中用imort gdal来使用gdal了。测试python版本的gdal是否安装成功,可以使用如下python代码。

1.7.4 编译java版本gdal

在编译java版本的gdal时,除swig之外,我们还需要jre和ant这两个工具,没有的话需要先下载安装,其中ant只需直接解压,不用安装。接下来我们用记事本打开nmake.opt,找到第86行左右位置(1.10版本),将文件中的java_home和ant_home修改为本机的路径,只要修改到主文件夹即可(就是bin文件夹所在的文件夹);如果文件夹路径有空格的话,把路径用双引号引起来,修改后的内容与以下代码类似。

修改保存之后,我们就可以编译java版本的gdal了,首先还是要先编译c++版本的gdal,然后使用cd命令切换到swig文件夹中,开始编译java版本gdal。

正常情况下,执行完上面的命令后java版本的gdal应该就编译完成了。编译出来的文件存放在swigjava目录中,主要有以下五个文件。

如果目录中有上面的五个文件,那就说明编译成功,如果没有,则要根据命令行编译的输出信息排除错误重新生成。我们将上面五个文件以及编译gdal时生成的gdal110.dll复制到一个新建的文件夹,用于java程序调用。