编译完GDAL和JAVA接口后,如果需要使用C#调用,就需要编译C#的接口。方法如下:

注意:使用的SWIG版本不能使用太高版本,否则,会报一堆的类型未找到的错误,我是无从下手。使用swig2.0.7(据说2.0.6到2.0.9)表现都是一样的问题,后面详细解释修改代码的方法。

配置好nmake.opt里的swig后。启动vs2015的64位命令行工具,并切到gdal源码的swig/csharp目录下。执行如下命令:

nmake /f makefile.vc interface

等待执行完后,先不要编译,进入到swig/csharp目录下,修改如下生成的源码文件:

swig\csharp\gdal\GdalPINVOKE.cs

swig\csharp\ogr\OgrPINVOKE.cs

swig\csharp\osr\OsrPINVOKE.cs 

这三个文件,分别按下图注释掉多余的代码:

编译GDAL2.3.0的C#接口-LMLPHP

编译GDAL2.3.0的C#接口-LMLPHP

编译GDAL2.3.0的C#接口-LMLPHP

然后分别打开如下三个文件

csharp\gdal\Band.cs

csharp\gdal\Dataset.cs

csharp\gdal\Driver.cs

修改第17行,将红色位置部分按如下修改,解决接口成员名错误问题。

Band.cs文件:

 public Band(IntPtr cPtr, bool cMemoryOwn, object parent) : base(GdalPINVOKE.Band_SWIGUpcast(cPtr), cMemoryOwn, parent)

Dataset.cs文件:

 public Dataset(IntPtr cPtr, bool cMemoryOwn, object parent) : base(GdalPINVOKE.Dataset_SWIGUpcast(cPtr), cMemoryOwn, parent)

Driver.cs文件:

 public Driver(IntPtr cPtr, bool cMemoryOwn, object parent) : base(GdalPINVOKE.Driver_SWIGUpcast(cPtr), cMemoryOwn, parent) {
完成以上修改后,就可以切回到命令行窗口,切换到swig/csharp目录下执行如下命令:

nmake /f makefile.vc

等待一会儿,就会辨已完成,然后执行

nmake /f makefile.vc install

会把编译出来的8个dll复制到安装目录下的csharp目录下。

把gdal203.dll复制到这个目录下备用。

使用的时候,c#工程下引入这8个文件,然后把gdal203.dll这个文件系统路径或则工程路径对应的目录下,就可以使用了。

01-20 22:29