gdal 压缩tif_GDAL实现遥感影像数据压缩

该博客介绍了一个自定义的BaseProcesses函数,用于封装GDAL库进行遥感影像操作。博主首先注册了GDAL库,然后打开并获取了源影像的信息,如大小、波段数、数据类型和地理投影。接着,创建了一个新的TIFF文件,并将源影像复制到目标文件中。最后,博主读取源影像的每个波段数据并写入到目标文件相应波段中,确保数据迁移的完整性。
摘要由CSDN通过智能技术生成

/**

*    BaseProcesses是我自己封装的一个函数,大家使用正常GDAL API即可,功能都是一样的

**/

Gdal.AllRegister();

BaseProcesses.GdalRegister();

Dataset ds ;

Dataset dd;

int strict = 0;

int xsize;

int ysize;

int iBandNumRef;

string sBandDataType;

double[] dGeoTransform;

string sGeoProjectionRef;

string [] options=new string[]{"TILED=YES", "COMPRESS=LZW"};

string path = "D:\\hxl\\yasuotest\\cptest3.tif";

BaseProcesses.OpenImage(out ds,"D:\\hxl\\yasuotest\\610325201610190000006256250160001.tif");

BaseProcesses.GetBaseInforOfImage(ds, out xsize, out ysize, out iBandNumRef, out sBandDataType, out dGeoTransform, out sGeoProjectionRef);

Driver di = ds.GetDriver();

di.CreateCopy(path, ds, strict, options, null, null);

BaseProcesses.OpenImage(out dd, path);

for (int i = 1; i <= ds.RasterCount;i++)

{

int[] dataarry = new int[xsize*ysize];

ds.GetRasterBand(i).ReadRaster(0, 0, xsize, ysize, dataarry, xsize, ysize,0,0);

dd.GetRasterBand(i).WriteRaster(0, 0, xsize, ysize, dataarry, xsize, ysize, 0, 0);

}

dd.FlushCache();

dd.Dispose();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值