Java gdal裁切灰度图_基于GDAL的影像切图工具

1 功能需求

对一副3857坐标系的卫星影像按照谷歌TMS进行切片,并将切片文件存储在符合MBTiles规范的SQLite数据库中

2 依赖库

GDAL ,GeoTools

3 环境搭建

由于个人对Java语言比较熟悉,因此使用Java语言开发环境,Java工程复用原有的SpringBoot工程,然后在pom文件中添加对GeoTools库的依赖即可实现GeoTools的引入。

3.1 Windows环境下搭建GDAL Java Binding开发环境

GDAL是当前最流行的遥感影像处理库,提供了一系列对遥感影像数据的操作函数,支持常见的影像数据格式,并提供了相应的抽象结构方便进行算法操作。GDAL的源代码是用C和C++编写的,并通过SWIG发布其他语言版本的bindings。

首先访问http://www.gisinternals.com/下载对应版本的编译好的GDAL库,下载并解压到本地文件夹下,注意路径不能有中文。然后在计算机-环境变量Path中添加对GDAL DLL的引用。E:\soft\GIS\gdal\bin;E:\soft\GIS\gdal\bin\gdal\java

在E:\soft\GIS\gdal\bin\gdal\java即可找到GDAL对应的JAR包,在工程中引用后即完成了GDAL的引入。完成后运行测试代码,成功显示影像信息后即代表GDAL库引入成功。

public class GDALTest {

public static void main(String[] args) {

gdal.AllRegister();

String fileName = "D:\\images\\2011_output_cai.tif";

Dataset dataset = gdal.Open(fileName, gdalconstConstants.GA_ReadOnly);

if (dataset == null) {

System.err.println("GDALOpen failed - " + gdal.GetLastErrorNo());

System.err.println(gdal.GetLastErrorMsg());

System.exit(1);

}

double[] ori_transform = dataset.GetGeoTransform();

System.out.println(String.format("Origin = (%s, %s)", ori_transform[0], ori_transform[3]));

System.out.println(String.format("Pixel Size = (%s, %s)", ori_transform[1], ori_transform[5]));

}

}

4

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值