使用GDAL 的GDALBuildVRT  解决影像融合接边均色 问题

问题:  多幅影像切片,但是影像直接有重叠还有黑边, 还有色差.

如图:

   

需要达到的效果:

解决方案:  

使用GDALBuildVRT  构建 虚拟数据集, 并使用额外参数 hidenodata  srcnodata vrtnodata

关键代码如下: 其中names 就是一堆tif,img的 GDAL能打开的影像数据集, 创建完成后就可以把返回的t当作普通GDAL栅格数据操作,非常方便. 但是要注意 如果影像中间有纯黑将会被透明点,  不过一般影像都是彩色,纯黑很少,基本没多大影像.

	GDALBuildVRTOptionsForBinary* VRTFB = NULL;
	
	std::vector<char*> papszArgv = { "-hidenodata", "-srcnodata", "0", "-vrtnodata", "0", nullptr}; 
	GDALBuildVRTOptions *VRTOptions = NULL;
	VRTOptions = GDALBuildVRTOptionsNew(&papszArgv[0], VRTFB);
	GDALDatasetH t = GDALBuildVRT("", size, NULL, names, VRTOptions, &bUsageError);
	if (bUsageError != 0)
	{
		ReleaseDataSet((GDALDataset*)t);
		GDALBuildVRTOptionsFree(VRTOptions);
		return;
	}

 

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
对于Java中使用GDAL进行波段融合,您可以使用GDAL的Java绑定库。下面是一个示例代码,演示了如何使用Java和GDAL进行波段融合: ```java import org.gdal.gdal.Dataset; import org.gdal.gdal.gdal; import org.gdal.gdalconst.gdalconst; public class BandFusion { public static void main(String[] args) { // 注册GDAL驱动 gdal.AllRegister(); // 输入波段文件路径 String[] inputFiles = {"path_to_input_band1.tif", "path_to_input_band2.tif"}; // 输出融合后的文件路径 String outputFile = "path_to_output_fusion.tif"; // 打开输入波段文件 Dataset[] inputDatasets = new Dataset[inputFiles.length]; for (int i = 0; i < inputFiles.length; i++) { inputDatasets[i] = gdal.Open(inputFiles[i], gdalconst.GA_ReadOnly); } // 设置输出文件的投影和地理变换信息 String[] options = {"-of", "GTiff", "-co", "COMPRESS=LZW"}; Dataset outputDataset = gdal.Warp(outputFile, inputDatasets, options); // 释放资源 for (Dataset inputDataset : inputDatasets) { inputDataset.delete(); } outputDataset.delete(); } } ``` 在上述示例代码中,首先通过调用`gdal.AllRegister()`方法注册GDAL驱动。然后,打开输入波段文件,`inputFiles`数组中存储了输入波段文件的路径,通过`gdal.Open()`方法打开每个波段文件。 接下来,通过设置输出文件的投影和地理变换信息,使用`gdal.Warp()`方法进行波段融合操作。在`options`数组中,可以指定输出文件的格式(这里使用GTiff格式)以及其他选项。 最后,释放打开的输入和输出数据集资源,以免内存泄漏。 请注意,上述代码仅提供了一个简单的示例,并未对异常进行处理。在实际使用中,您可能需要进行错误处理和异常捕获。 希望对您有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值