• Gdal浅析(一)读取栅格数据到Dataset


    gdal读取栅格数据的流程分析
    今天,利用gdal写了一个demo用来读取栅格数据、并显示其波段、色调等信息。
    在此分享一下,我对gdal读取栅格数据的流程的浅析。

    1、使用gdal的第一步肯定是先要注册。使用静态函数gdal.AllRegister();
    2、gdal将所有的栅格数据都是读取到一个它自己定义的dataset中,所以OSGeo.GDAL.Dataset ds=new OSGeo.GDAL.Dataset();
    3、使用open函数 ds = gdal.Open(inputFileName, gdalconst.GA_ReadOnly);
    4、至此,全路径为inputFileName的栅格文件已经读到ds中,下面介绍OSGeo.GDAL.Dataset类
    总体来说,OSGeo.GDAL.Dataset实际上就是一系列相关联的波段的组合。
    其共有成员如下:

    virtual  ~GDALDataset ()
    int  GetRasterXSize (void)
    int  GetRasterYSize (void)
    int  GetRasterCount (void)
    GDALRasterBand *  GetRasterBand (int)
    virtual void  FlushCache (void)
    virtual const char *  GetProjectionRef (void)
    virtual CPLErr  SetProjection (const char *)
    virtual CPLErr  GetGeoTransform (double *)
    virtual CPLErr  SetGeoTransform (double *)
    virtual CPLErr  AddBand (GDALDataType eType, char **papszOptions=NULL)
    virtual void *  GetInternalHandle (const char *)
    virtual GDALDriver *  GetDriver (void)
    virtual int  GetGCPCount ()
    virtual const char *  GetGCPProjection ()
    virtual const GDAL_GCP *  GetGCPs ()
    virtual CPLErr  SetGCPs (int nGCPCount, const GDAL_GCP *pasGCPList, const char *pszGCPProjection)
    virtual CPLErr  AdviseRead (int nXOff, int nYOff, int nXSize, int nYSize, int nBufXSize, int nBufYSize, GDALDataType eDT, int nBandCount, int *panBandList, char **papszOptions)
    CPLErr  RasterIO (GDALRWFlag, int, int, int, int, void *, int, int, GDALDataType, int, int *, int, int, int)
    int  Reference ()
    int  Dereference ()
    GDALAccess  GetAccess ()
    int  GetShared ()
    void  MarkAsShared ()
    CPLErr  BuildOverviews (const char *, int, int *, int, int *, GDALProgressFunc, void *)

    上述代码是C语言的,有比较烦躁的指针。不过只要大家仔细思考,还是可以很轻松的将其转换成C#语言的。
    5、其中我们要使用的、或者说比较常用的方法有以下几个。

    获取驱动,例如对于tif文件的驱动就是GeoTiff。
    virtual GDALDriver *  GetDriver (void)

    获取投影方式,在.NET中,返回值是string类型的投影描述语句
    virtual const char *  GetProjectionRef (void)


    获取波段数目,这个值决定了下面的分别获取每一个波段的循环次数

    int  GetRasterCount (void)

    for (int iBand = 1; iBand <= ds.RasterCount; iBand++)
    {
           Band band = ds.GetRasterBand(iBand);//获取制定波段
    }


    int  GetRasterXSize (void)
    int  GetRasterYSize (void)
    获取波段的size
    最后一个:

    CPLErr  BuildOverviews (const char *, int, int *, int, int *, GDALProgressFunc, void *)


    这个是在ds上构建Overviews,我猜想是建类似金字塔的抽取,或称之为视图。目前还在摸索,希望高手指教!


    6、这次就先研究到Band,下次从Band入手,继续摸索。

    Demo的效果图如下:

    --

  • 相关阅读:
    a[::-1]相当于 a[-1:-len(a)-1:-1],也就是从最后一个元素到第一个元素复制一遍。
    +=
    map 和reduce
    赋值语句
    高阶函数
    函数式编程
    迭代器
    如何判断一个对象是可迭代对象呢?方法是通过collections模块的Iterable类型判断:
    ie11升级的过程中遇到的问题以及解决办法
    .csporj 文件部分节点解析
  • 原文地址:https://www.cnblogs.com/nudtchengguo/p/1284733.html
Copyright © 2020-2023  润新知