gdal java api 中文_GDAL-API手册.pdf

这篇博客介绍了如何使用GDAL的Java API来打开和处理遥感数据。首先,通过GDALAllRegister()注册驱动,然后使用GDALOpen()函数以只读或更新模式打开数据集。GDALDataset包含了光栅数据的波段信息、元数据、坐标系统等。文章还展示了获取数据集基本信息的方法,如驱动信息、尺寸和投影参考。
摘要由CSDN通过智能技术生成

GDAL-API手册

GDAL API 开发手册

第一部分:GDAL DEVELOPER GUIDE

1.1. 打开文件

在打开GDAL 所支持的光栅数据之前需要注册驱动。这里的驱动是针对GDAL 支持

的所有 数据格式。通常可以通过调用 GDALAllRegister() 函数来注册所有已知

的驱动,同时 也包含那些用 GDALDriverManager::AutoLoadDrivers() 从.so

文件中自动装载驱动。 如果程序需要对某些驱动做限制,可以参考

gdalallregister.cpp 代码。

当驱动被注册之后,我们就可以用 GDALOpen() 函数来打开一个数据集。打开的

方式 可以是 GA_ReadOnly 或者 GA_Update。

In C++:

#include "gdal_priv.h"

int main()

{

GDALDataset *poDataset;

GDALAllRegister();

poDataset = (GDALDataset *) GDALOpen( pszFilename, GA_ReadOnly );

if( poDataset == NULL )

{

...;

}

In C:

#include "gdal.h"

int main()

{

GDALDatasetH hDataset;

GDALAllRegister();

hDataset = GDALOpen( pszFilename, GA_ReadOnly );

if( hDataset == NULL )

{

...;

}

In Python:

import gdal

from gdalconst import *

dataset = gdal.Open( filename, GA_ReadOnly )

if dataset is None:

...

如果 GDALOpen() 函数返回NULL 则表示打开失败,同时 CPLError() 函数产生

相应的错误信息。如果您需要对错误进行处理可以参考 CPLError() 相关文档。

通常情况下,所有的 GDAL 函数都通过CPLError()报 告错误。另外需要注意的

是pszFilename 并不一定对应一个 实际的文件名(当然也可以就是一个文件

名)。它的具体解释由相应的驱动程序负责。 它可能是一个URL,或者是文件

名以后后面带有许多用于控制打开方式的参数。通常建议, 不要在打开文件的

选择对话框中对文件的类型做太多的限制。

1.2. 获取Dataset 信息

如果GDAL 数据模型一节所描述的,一个GDALDataset 包含了光栅数据的一系列

的波段信息。 同时它还包含元数据、一个坐标系统、投影类型、光栅的大小以

及其他许多信息。

adfGeoTransform[0] /* 左上角 x */

adfGeoTransform[1] /* 东西方向一个像素对应的距离 */

adfGeoTransform[2] /* 旋转, 0 表示上面为北方 */

adfGeoTransform[3] /* 左上角 y */

adfGeoTransform[4] /* 旋转, 0 表示上面为北方 */

adfGeoTransform[5] /* 南北方向一个像素对应的距离 */

如果需要输出dataset 的基本信息,可以这样:

In C++:

double adfGeoTransform[6];

printf( "Driver: %s/%s\n",

poDataset->GetDriver()->GetDescription(),

poDataset->GetDriver()->GetMetadataItem( GDAL_DMD_LONGNAME ) );

printf( "Size is %dx%dx%d\n",

poDataset->GetRasterXSize(), poDataset->GetRasterYSize(),

poDataset->GetRasterCount() );

if( poDataset->GetProjectionRef() != NULL )

GDAL开发手册API详细说明,内含详细示例代码,适合初学者使用,非常棒的入门书!In pythe Import go from gdalconst import s datasct-gdal. Open( filename, GA ReadOnly if dataset is none 如果 GDALOpen(函数返回NUL则表示打开失败,同时 CPLError(函数产生 相应的错误信息。如果您需要对错误迂行处理可以参考 CPLError相关文档 通常情况下,所有的GDAL函数都通过 CPLError(报告错误。另外需要注意的 是 pszFilename并不一定对应一个实际的文件名(当然也可以就是一个文件 名)。它的具休解释由相应的驱动程序负责。它可能是一个URL,或者是文件 名以后后面带有许多用于控制打开方式的参数。通常建议,不要在打开文件的 选择对话框中对文件的类型做太多的限制。 1.2.获取 Dataset信息 如果GL数据模型一节所描述的,一个 GDALDataset包含了光栅数据的一系列 的泼段信息。同时它还包含元数据、一个坐标系统、投影类型、光枥的大小以 及其他许多信息。 dfGeotransform[0]/米左上角x*/ dfGeoTrans lori[1]/东西方向一个像素对应的距离*/ adfGeotransform[2]/米旋转,0表示上面为北方 adfGeotransform[3]米左上角y*/ adfGeotrans form[4]/*旋转,0表示上面为北方米/ adfGeoTransform[5]/*南北方向一个像素对应的距离*/ 如果需要输出 dataset的基木信息,可以这样: In c+t adfGcotransform[6] printf( Driver: %s/%s\n poDataset->GetDriver(->GetDescription o poDataset->GetDriver()->GetMetadataltem( GDAL DMD LONGNAME)) printr( Size is %dx%dx%d\n poDataset->GetRasterXSizeo, poDataset->GetRasterYSize( poDataset->GetRasterCounto) if( poDataset->GetProjectionRef(!= NULL printf( Projection is %s'n poDataset->GetProjectionRef() if( poDataset->GetGeoTransform( adfGeoTransform one printf( Origin=(%. 6f, %. 6f)\n adfGeoTransform[01, adfGeoTrans form[3]) printf(Pixel Size=(%. 6f, %. 6f)\n adfGcoTransform[1, adfGco Transform[5 In c GDALDriverh dRiver double adfGeoTransform[6] hDriver- GDALGctDatasctDriver( hDatasct printf( Driver: %s /%s\n GDALGetDriver ShortName( hDriver GDALGetDriverlongName ( dRiver)) printf size is %dx%dx%d\n GDALGetRasterXSize( hDataset GDALGetRasterYSize( dAtaset GDALGetRasterCount( hDataset)) if( GDALGetProjectionRef( hDataset )! -NULL printf( Projection is %s\n GDALGetProjectionRef( dAtaset )) if( GDALGetGeoTransform( hDataset, adfGeoTransform )==CE None printf( Origin =(9%.6f, %.6f)\n adfGeo Transform[01, adfGeo Transform[3]) printf( pixel Size=(%. 6f, %.6f)\n adfGeoTransform[1, adfGeoTrans form[5) In Python print Driver:', dataset GetDriver(. ShortName, /', dataset. Get Driver(. Lon
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值