没有合适的资源?快使用搜索试试~ 我知道了~
首页GDAL--API手册.pdf
资源详情
资源评论
资源推荐

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 )
printf( "Projection is `%s'\n",
poDataset->GetProjectionRef() );
if( poDataset->GetGeoTransform( adfGeoTransform ) == CE_None )
{
printf( "Origin = (%.6f,%.6f)\n",
adfGeoTransform[0], adfGeoTransform[3] );
printf( "Pixel Size = (%.6f,%.6f)\n",
adfGeoTransform[1], adfGeoTransform[5] );
}
In C:
GDALDriverH hDriver;
double adfGeoTransform[6];
hDriver = GDALGetDatasetDriver( hDataset );
printf( "Driver: %s/%s\n",
GDALGetDriverShortName( hDriver ),
GDALGetDriverLongName( hDriver ) );
printf( "Size is %dx%dx%d\n",
GDALGetRasterXSize( hDataset ),
GDALGetRasterYSize( hDataset ),
GDALGetRasterCount( hDataset ) );
if( GDALGetProjectionRef( hDataset ) != NULL )
printf( "Projection is `%s'\n",
GDALGetProjectionRef( hDataset ) );
if( GDALGetGeoTransform( hDataset, adfGeoTransform ) == CE_None )
{
printf( "Origin = (%.6f,%.6f)\n",
adfGeoTransform[0], adfGeoTransform[3] );
printf( "Pixel Size = (%.6f,%.6f)\n",
adfGeoTransform[1], adfGeoTransform[5] );
}
In Python:

print 'Driver: ', dataset.GetDriver().ShortName,'/', \
dataset.GetDriver().LongName
print 'Size is ',dataset.RasterXSize,'x',dataset.RasterYSize, \
'x',dataset.RasterCount
print 'Projection is ',dataset.GetProjection()
geotransform = dataset.GetGeoTransform()
if not geotransform is None:
print 'Origin = (',geotransform[0], ',',geotransform[3],')'
print 'Pixel Size = (',geotransform[1], ',',geotransform[5],')'
1.3.
获取一个光栅波段
现在,我们可以通过 GDAL 获取光栅的一个波段。同样每个波段含有元数据、块
大小、 颜色表以前其他一些信息。下面的代码从 dataset 获取一个
GDALRasterBand 对象, 并且显示它的一些信息。
In C++:
GDALRasterBand *poBand;
int nBlockXSize, nBlockYSize;
int bGotMin, bGotMax;
double adfMinMax[2];
poBand = poDataset->GetRasterBand( 1 );
poBand->GetBlockSize( &nBlockXSize, &nBlockYSize );
printf( "Block=%dx%d Type=%s, ColorInterp=%s\n",
nBlockXSize, nBlockYSize,
GDALGetDataTypeName(poBand->GetRasterDataType()),
GDALGetColorInterpretationName(
poBand->GetColorInterpretation()) );
adfMinMax[0] = poBand->GetMinimum( &bGotMin );
adfMinMax[1] = poBand->GetMaximum( &bGotMax );
if( ! (bGotMin && bGotMax) )
GDALComputeRasterMinMax((GDALRasterBandH)poBand, TRUE,
adfMinMax);
printf( "Min=%.3fd, Max=%.3f\n", adfMinMax[0], adfMinMax[1] );
if( poBand->GetOverviewCount() > 0 )
printf( "Band has %d overviews.\n",
poBand->GetOverviewCount() );
剩余114页未读,继续阅读


















安全验证
文档复制为VIP权益,开通VIP直接复制

评论0