《GDAL源码剖析与开发指南》一一1.5 GDAL源码目录

1.5 GDAL源码目录

GDAL源码剖析与开发指南
下载的GDAL源代码压缩包目录如图1-2所示,使用SVN迁出的GDAL源代码目录如图1-3所示。

从图1-2和图1-3所示可以看出,不管用什么方式获取GDAL的源代码,它的目录结构都是一样的。下面我们就针对目录结构中的每个文件夹和文件作一个简单的说明(按照字母顺序)。

1.5.1 文件夹说明
对于图1-3中所示的文件夹,详细说明如下。

alg:该文件夹存放的是GDAL库中提供的一些算法的源代码,这些算法包括但不限于:DEM生成等高线算法,图像纠正算法(几何纠正、TPS纠正、RPC纠正等),栅格矢量化算法,矢量栅格化算法,格网计算算法,PCT和RGB互转算法,分类图的小碎斑块去除算法等。

apps:该文件夹中存放的是GDAL库中提供的一些命令行工具集的源代码,这些工具集的介绍可以参考http://gdal.org/gdal_utilities.html。后面会对这些工具做一个简单的说明,其中有些工具非常有用,比如gdalinfo,可以用来查看图像的元数据信息等。

bridge:该文件夹中存放的是用来连接GDAL抽象类的定义与GDAL自己的结构体定义及其实现的源代码。后面涉及GDAL的实现原理时我们会对该文件夹作一个比较详细的介绍。

data:该文件夹中存放的是GDAL库中需要用到的一些“配置文件”(此处叫配置文件可能不太准确),这些文件主要有ESRI的投影文件,ESPG的投影文件,PCI的投影和椭球体文件,AutoCAD的DXF格式的头文件等。在使用GDAL库的过程中可以在程序中使用函数javascript
CPLSetConfigOption("GDAL_DATA","C:\GDAL\data");

设置该文件夹的目录,如果没有设置GDAL会自动从环境变量中查找,环境变量的名字叫GDAL_DATA,该变量的值就是data文件夹的路径;如果还是没有找到,那么GDAL可能会提示错误,比如在写入AtuoCAD的dxf格式的时候如果不设置GDAL_DATA,那么就会提示创建不成功,后面遇到时我们会再进行说明。

doc:该文件夹存放的是用来生成GDAL帮助文档的一些dox文件。dox文件是使用doxygen工具来进行生成的,后面我们会对doxygen工具作一个简单的介绍,并且说明在自己的工程中怎样使用doxygen生成程序的开发帮助文档。

frmts:这个文件夹可以说是GDAL代码中内容最多的一个文件夹了,每次更新GDAL的版本后这个文件夹中都会多出几个文件夹,同时在GDAL支持的文件格式中也会多出来几个新的文件格式。没错,这个文件夹存放的就是GDAL针对不同的特定图像格式解析的源代码,我们可以举几个简单的例子,比如bmp文件夹就是解析BMP图像的,hfa文件夹是用来解析Erdas的img图像格式,还有pcidsk文件夹是读取PCI的pix格式的文件等。所以这个文件夹存放的是解析各个文件格式的源代码。

gcore:这个文件夹是GDAL的灵魂所在,主要存放GDAL抽象类的数据集,图像、波段的读写接口等都是在这里面实现的。如果想知道GDAL的抽象类是怎么对图像格式进行抽象的,读者可以看看这个文件夹里面的代码。

html:这个文件夹主要用来存放GDAL生成的帮助文档,使用doxygen工具生成的GDAL帮助文档会出现在这个文件夹中。如果使用压缩包的话,该文件夹里面应该是空的。后面我们会和doc文件夹一起进行详细介绍。

m4:该文件夹存放的是以m4为后缀名的文件。m4文件叫Macro Processor Library,是编译基础中最核心的文件,这个文件主要是用autoconf来产生configure配置文件,继而自动生成Makefile文件。这个文件夹在Windows平台下没用,在此就不作细述了。

man:该文件夹是用来生成Linux或者其他平台下的帮助文件,Windows平台下也没用。

ogr:GDAL和OGR曾经是两个库,GDAL库负责读写栅格数据,OGR库负责读写矢量数据,然而GDAL的算法库中经常会用到矢量数据的读取,将这两个库分开会造成不便,现在这两个库已经整合到一起,OGR库就是GDAL库的一个子集。其实OGR库还是可以单独编译出来的。ogr文件夹就是存放OGR库源代码的文件夹。后面我们会对这个文件夹里的内容进行详细介绍。

port:该文件夹中存放的是CPL库的东西,CPL是一个GDAL的底层支持库,CPL库中定义了一些字符串的操作、文件处理、网页请求、数据库连接、哈希表、字符加密文件压缩等基础的函数。比如GDAL中所有的导出函数符号CPL_DLL就是在这个CPL文件夹中定义的;还有frmts文件夹中,打开文件、打开数据库、打开网络路径以及字符串的处理等都是用的port库。

swig:该文件夹主要是存放swig的脚本。SWIG全称叫Simplified Wrapper and Interface Generator,官方网站是http://www.swig.org/。SWIG的作用就是可以将C/C++写的库封装为Python、C#、Java、Perl和Ruby等其他语言的访问接口。GDAL的C#版本就是使用swig来编译出来实现的。

vb6:这个文件夹用来将GDAL编译成一个VB6的模块,对于里面具体的文件说明以及如何编译参考文件夹中的readme.txt,这里就不作具体说明了。

wince:顾名思义,这个文件夹中的文件就是用来编译Windows CE平台下的GDAL库的,具体编译请参考其中的说明文档。

1.5.2 文件说明
aclocal.m4:同1.5.1小节介绍的m4文件夹。

autogen.sh:Linux平台下的shell文件,通过调用autoconf来产生configure配置文件。

COMMITERS:该文件中的内容是GDAL开发人员的信息,包括姓名、联系邮箱以及各自负责开发的模块说明等。

config.guess、config.sub、configure、configure.in:这四个文件在Windows下没有具体作用,在此略过。

Doxyfile:Doxyfile就是前面doc文件夹说明中提到的doxygen的工程文件,用来生成帮助文档,后面我们在介绍doxygen的使用时会对该文件进行说明。

GDALmake.opt.in:这个文件是Linux平台下的GDAL库编译配置文件,在后面的nmake.opt中我们会介绍其功能。

gdalnightlysvn.sh:Linux平台下调用svn获取GDAL源代码的一个shell脚本。

GNUmakefile:GNU的make文件。

HOWTO-RELEASE:GDAL发布版本的一些说明。

install-sh:Linux平台下GDAL的安装shell脚本。

LICENSE.TXT:GDAL的许可说明文件。

ltmain.sh:Linux平台下libtool的shell脚本,Windows下没用到。

makefile.vc:GDAL的编译文件,用来将源代码编译成dll文件,后面我们会在GDAL编译中作进一步说明。

makegdal_gen.bat:一个用来生成VS的工程文件的批处理文件,后面在GDAL编译中我们会对该文件的使用方式进行说明。

makegdal10.sln:文件夹中所有的sln文件都是VS的项目文件,文件名后的数字代表的是VS的版本号。

makegdal10.vcxproj、makegdal71.vcproj:VS的工程文件,该文件可以由makegdal_gen.bat文件自动生成,后面我们会详细介绍。

mkbindist.sh、mkgdaldist.sh、mktestdist.sh:三个shell脚本文件,Windows下没用,略过。

NEWS:介绍GDAL的新增功能以及修复的bug记录等。

nmake.opt:GDAL编译选项配置文件,在编译GDAL中,可以指定GDAL绑定的其他库等都在这里进行设置。在后面的GDAL编译中我们会详细说明。

nmake-wince.opt:编译wince版本的编译选项配置文件。

PROVENANCE.TXT:GDAL目录说明文件,如果上面说明的不够清楚,可以参考这个文件。

submake.bat:一个编译的批处理文件。

svnkeywords.sh:SVN的又一个shell脚本。

VERSION:GDAL版本信息。

时间: 2024-09-17 04:09:45

《GDAL源码剖析与开发指南》一一1.5 GDAL源码目录的相关文章

《GDAL源码剖析与开发指南》一一1.8 GDAL帮助文档生成

1.8 GDAL帮助文档生成 GDAL源码剖析与开发指南1.8.1 Doxygen简介 Doxygen是生成C++注释文档的标准工具,也支持其他语言,如C.Objective-C.C#.PHP.Java.Python.IDL (Corba and Microsoft flavors).Fortran.VHDL.Tcl等. 我们可以通过三种方式来使用Doxygen. 1.从源文件中以HTML形式生成在线文档浏览器,或者以LATEX形式生成非在线的参考手册,也支持RTF (MS-Word).Post

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

1.7 SWIG编译 GDAL源码剖析与开发指南1.7.1 SWIG简介 SWIG全称是Simplified Wrapper and Interface Generator,官方网站是http://www.swig.org/.SWIG是一个开发工具,能够将使用C或者C++编写的软件与其他各种高级编程语言进行嵌入联接.SWIG能应用于各种不同类型的语言,包括常用脚本编译语言例如Perl.PHP.Python.Tcl.Ruby.PHP等,也包括非脚本编译语言,如C#.Common Lisp (CLI

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

1.6 GDAL编译 GDAL源码剖析与开发指南 GDAL的编译分为三个小节,第一节是常规编译,使用微软的Visual Studio 2008进行编译,如果用微软的其他编译器,编译过程与此类似.需要注意的是,GDAL已经不再支持Visual C++6.0编译器.第二小节主要说明怎样修改GDAL的配置文件,以使GDAL支持更多的数据格式以及算法等.第三小节对编译GDAL的64位版本进行说明. 1.6.1 常规编译 1.使用Visual Studio 2008 IDE编译 在GDAL的源代码目录中,

《GDAL源码剖析与开发指南》一一1.1 什么是GDAL

1.1 什么是GDAL GDAL源码剖析与开发指南 GDAL全称是Geospatial Data Abstraction Library(地理空间数据抽象库),是一个在X/MIT许可协议下读写空间数据(包括栅格数据和矢量数据)的开源库,它利用抽象数据模型来表达所支持的各种文件格式,还使用一系列命令行工具来进行数据转换和处理. OGR(OGR Simple Features Library)是GDAL项目的一个分支,功能与GDAL类似,只是它提供对矢量数据的读写支持.同时它实现了一个对空间参考信息

《GDAL源码剖析与开发指南》一一1.3 GDAL支持的数据格式

1.3 GDAL支持的数据格式 GDAL源码剖析与开发指南 GDAL支持的数据格式分为两种:栅格数据格式和矢量数据格式.GDAL在每次版本更新的时候,都会加入对新的格式的支持.本书使用GDAL1.10版本中支持的栅格数据格式,如表1-1所示,支持的矢量数据格式如表1-2所示. 注意 文件的最大存储大小不仅由文件的格式决定,而且和操作系统有关系.

《GDAL源码剖析与开发指南》一一1.4 GDAL源码下载

1.4 GDAL源码下载 GDAL源码剖析与开发指南 GDAL的源码下载有两种方式.第一种是直接下载打包好的压缩包,下载地址为:http://trac.osgeo.org/gdal/wiki/DownloadSource.另外,GDAL的各个历史版本都可以在这个地址进行下载:http://download.osgeo.org/gdal/.这种下载方式很简单,此处不作说明.下载完成,使用压缩软件解压即可. 第二种下载方式是使用SVN源代码管理工具直接从GDAL的源码服务器进行下载.下载地址是:ht

《GDAL源码剖析与开发指南》一一1.2 GDAL特点

1.2 GDAL特点 GDAL源码剖析与开发指南GDAL提供对多种栅格数据的支持,包括Arc/Info ASCII Grid(asc),GeoTiff (tiff),Erdas Imagine Images(img),ASCII DEM(dem) 等格式. OGR提供对矢量数据格式的读写支持,包括ESRI Shapefiles.S-57.SDTS.PostGIS.Oracle Spatial.Mapinfo mid/mif和Mapinfo TAB等. GDAL库还提供了一系列算法接口,比如矢量栅

《GDAL源码剖析与开发指南》一一1.9 简单的调用

1.9 简单的调用 GDAL源码剖析与开发指南关于GDAL的使用,关键是要熟悉GDAL的组织结构.类以及类的函数等.最常用的就是动态库的GDAL,当然我们也可以使用静态库,这里只是简单地介绍使用动态GDAL库来做开发. 下面我们简单地使用C++.C#.Python和Java 4种语言分别进行示例,来说明如何使用GDAL进行开发. 1.9.1 C ++使用GDAL首先我们打开Visual Studio2008,新建一个Win32的控制台工程(名字叫GDALCppTest),然后在工程的属性对话框中

《GDAL源码剖析与开发指南》导读

前言 GDAL源码剖析与开发指南 GDAL全称是Geospatial Data Abstraction Library(地理空间数据抽象库),是一个在X/MIT许可协议下读写空间数据(包括栅格数据和矢量数据)的开源库,它利用抽象数据模型来表达所支持的各种文件格式,还使用一系列命令行工具来进行数据转换和处理. 由于GDAL库支持很多数据格式,目前几乎所有的GIS和RS软件底层都使用GDAL来读写空间数据. 目前国内外关于GDAL的图书非常少,比较权威的只有GDAL官网的说明文档,导致用户缺少实用的