基于GDAL库,读取.grd文件(以海洋地形数据为例)Java版
技术背景
海洋地形数据主要是通过美国全球地形起伏数据(GMT)获得,数据格式为grd(GSBG)二进制数据,打开软件通过是Surfer软件,surfer软件可进行数据的编辑处理,以及进一步的可视化表达等功能操作;由于Surfer软件不支持二次开发,没有提供相应的SDK供开发者进行使用,所以这一切只能通过相应类似的技术进行实现,首先,数据的读取,如何通过编程实现数据的读取操作呢?这里就要说一下GIS软件所使用的一个开源库-GDAL,GDAL库的具体解释资料,请查阅官方网站【https://www.gdal.org/index.html】,由于后期要进行数据入库的步骤,所以本文提供的是一种采用Java语言进行读取的方法,前面的GDAL库的编译方法请参考博客1【GDAL从源码到JAVA应用】,下面具体讲一下环境配置。
首先讲GDAL库文件进行整理,将jdal.jar、gdalalljni.dll、gdalalljni.exp、gdalalljni.lib四个文件拷到bin文件夹下,然后将bin文件夹拷贝到任一位置并更名为gdal,然后将该文件夹,设置入系统环境变量path内,这一步完成即成功了一半;然后打开Eclipse,创建项目gdalDemo,右击项目选择“构建路径”(Build Path),然后选择“configure Build Path”,再选择“Java Build Path”,选择“库”,点击“添加额外的JAR文件”,具体如下图所示

添加完成以后,创建Java类,开始编辑读取代码,话不多说,代码奉上
1 package gdalDemo;
2
3 import org.gdal.gdal.Band;
4 import org.gdal.gdal.Dataset;
5 import org.gdal.gdal.Driver;
6 import org.gdal.gdal.gdal;
7 import org.gdal.gdalconst.gdalconstConstants;
8 import org.gdal.ogr.ogr;
9
10 public class gealTest {
11
12 public static void main(String[] args) {
13
14 // 注册所有的驱动
15 ogr.RegisterAll();
16 // 为了支持中文路径,请添加下面这句代码
17 gdal.SetConfigOption("GDAL_FILENAME_IS_UTF8","YES");
18 // 为了使属性表字段支持中文,请添加下面这句
19 gdal.SetConfigOption("SHAPE_ENCODING","");
20
21 String fileName_tif = "E:/test/E135N30_sf.grd";
22
23 //使用只读方式打开图像
24 Dataset hDataset = gdal.Open(fileName_tif, gdalconstConstants.GA_ReadOnly);
25 if (hDataset == null)
26 {
27 System.err.println("GDALOpen failed - " + gdal.GetLastErrorNo());
28 System.err.println(gdal.GetLastErrorMsg());
29 System.exit(1);
30 }
31
32 //输出图像的格式信息
33 Driver hDriver = hDataset.GetDriver();
34 System.out.println("Driver: " + hDriver.getShortName() + "/" + hDriver.getLongName());
35
36 //输出图像的大小和波段个数
37 int iXSize = hDataset.getRasterXSize(); //列数
38 int iYSize = hDataset.getRasterYSize(); //行数
39 int iBandCount = hDataset.getRasterCount(); //元素(因素)数
40 System.out.println("Size is " + iYSize + " x " + iXSize + "\n" + "BandCount: " + iBandCount);
41
42 Band band = hDataset.GetRasterBand(1);
43 int itype = band.GetRasterDataType();
44 System.out.println("dataType: "+itype);
45
46 //输出图像的坐标和分辨率信息
47 double [] adfGeoTransform = new double[6];
48 hDataset.GetGeoTransform( adfGeoTransform);
49 System.out.printf( "Origin =(%.6f,%.6f)\n",adfGeoTransform[0], adfGeoTransform[3]);
50 System.out.printf( "PixelSize = (%.6f,%.6f)\n",adfGeoTransform[1], adfGeoTransform[5]);
51
52 //获取该波段的最大值最小值,如果获取失败,则进行统计
53 Double [] bGotMin = new Double [2];
54 Double [] bGotMax = new Double [2];
55 band.GetMinimum( bGotMin);
56 band.GetMaximum( bGotMax);
57 if(bGotMin[0] != null && bGotMax[0] != null){
58 System.out.printf( "Z value Min=%.3f,Max=%.3f\n", bGotMin[0], bGotMax[0]);
59 }
60
61 System.out.println("\nexample Data(10x10):");
62 //读取一行数据
63 float buf[] = new float[iXSize];
64
65 for(int i=0; i<10/*iYSize*/; i++)
66 {
67 band.ReadRaster(0, i, iXSize, 1, buf); //读取一行数据
68
69 // 下面是输出像元值,为了方便,我只输出了左上角 10×10的范围内的数据
70 for(int j=0; j<10/*iXSize*/; j++)
71 System.out.print(buf[j] + ", ");
72 System.out.println("\n");
73 }
74
75 hDataset.delete();
76
77 // 关闭驱动
78 gdal.GDALDestroyDriverManager();
79 }
80
81 }
读取结果

至此,文件读取完成。
致谢
感谢李民录老师的指导,以及相关技术博主的技术分享,谢谢!
参考博客
1、GDAL从源码到JAVA应用【https://blog.csdn.net/lw19910913/article/details/77746164】
2、Build Instructions for GDAL/OGR In Java【http://trac.osgeo.org/gdal/wiki/GdalOgrInJavaBuildInstructions】
3、GDAL-JavaAPI【https://gdal.org/java/overview-summary.html】
4、Java使用GDAL【https://blog.csdn.net/liminlu0314/article/details/8395622】
基于GDAL库,读取.grd文件(以海洋地形数据为例)Java版的更多相关文章
- 基于GDAL库,读取.grd文件(以海洋地形数据为例)C++版
技术背景 海洋地形数据主要是通过美国全球地形起伏数据(GMT)获得,数据格式为grd(GSBG)二进制数据,打开软件通过是Surfer软件,surfer软件可进行数据的编辑处理,以及进一步的可视化表达 ...
- 使用C#版本的gdal库打开hdf文件
作者:朱金灿 来源:http://blog.csdn.net/clever101 最近应同事的请求帮忙研究下使用C#版的gdal库读取hdf文件,今天算是有一点成果,特地做一些记录. 首先是编译C#版 ...
- 基于GDAL库,读取海洋风场数据(.nc格式)c++版
经过这一段时间的对海洋数据的处理,接触了大量的与海洋相关的数据,例如海洋地形.海洋表面温度.盐度.湿度.云场.风场等数据,除了地形数据是grd格式外,其他的都是nc格式的数据.本文将以海洋风场数据为例 ...
- 关于基于GDAL库QT软件平台下C++语言开发使用说明
背景前提 地理空间数据抽象库(GDAL)是一个用于读取和编写栅格和矢量地理空间数据格式的计算机软件库,由开源地理空间基金会在许可的X / MIT风格免费软件许可下发布. 作为一个库,它为调用应用程序提 ...
- 基于GDAL库,读取.nc文件(以海洋表温数据为例)C++版
对于做海洋数据处理的同学,会经常遇到nc格式的文件,nc文件的格式全称是NetCDF,具体的详细解释请查询官网[https://www.unidata.ucar.edu/software/netcdf ...
- 基于GDAL库海洋表温日平均计算工具设计与实现 C++版
技术背景 在对物理海洋数据处理过程中,表层温度是众多要素中的一种,本文书要是针对海洋表温数据批量日平均处理的一个工具设计.首先要在对当前的SST数据文件作一下简要的说明,SST全称为sea surfe ...
- C++调用GDAL库读取并输出tif文件,并计算斑块面积输出景观指数:CSD
部分源码选自GDAL库的官方网址:www.gdal.org,其余的代码为笔者自己编写. // readfile.cpp : 定义控制台应用程序的入口点. // /* part of the codes ...
- GDAL库——读取图像并提取基本信息
GDAL库是一个跨平台的栅格地理数据格式库,包括读取.写入.转换.处理各种栅格数据格式(有些特定的格式对一些操作如写入等不支持).它使用了一个单一的抽象数据模型就支持了大多数的栅格数据.这里有GDAL ...
- gdal库对ENVI文件的一点支持不好
作者:朱金灿 来源:http://blog.csdn.net/clever101 使用GDALOpen函数打开ENVI的img文件,如果使用更新的方式即GA_Update会改写对应的hdr文件.改写h ...
随机推荐
- JMeter_性能压测报错address already in use:connect
报错截图如下: 原因分析: 这个问题的原因是windows端口被耗尽了(默认1024-5000),而且操作系统要 2~4分钟才会重新释放这些端口,所以可以增加windows的可用端口来解决.windo ...
- android 解决报错 installation failed with message Failed to finalize session : INSTALL_PARSE_FAILED_UNEXPECTED_EXCEPTION: Failed parse during installPackageLI: Failed to read manifest from /xx/xx/xx.apk
新工程启动报错 怎么办? 解决: 将这个选项去掉勾选后点击ok即可
- [ flask ] 解耦models(解决models文件太臃肿的问题)
问题描述 用博客项目来描述,我们在models中定义了用户表(User).文章表(Post).通知表(Notification).等等.随着我们开发的深入,添加的功能越来越多,到后期models文件会 ...
- vue3.0+vite+ts项目搭建--基础配置(二)
集成vue-router 使用yarn yarn add vue-router@next --save 安装完成之后在src目录下创建文件夹router/index.ts,创建完成之后需要在Vue-R ...
- Android官方文档翻译 六 1.4Starting Another Activity
Starting Another Activity 开启另一个Activity This lesson teaches you to 这节课教给你: Respond to the Send Butto ...
- Solon 开发,七、自定义注解开发汇总
Solon 开发 一.注入或手动获取配置 二.注入或手动获取Bean 三.构建一个Bean的三种方式 四.Bean 扫描的三种方式 五.切面与环绕拦截 六.提取Bean的函数进行定制开发 七.自定义注 ...
- Java将引入新的对象类型来解决内存利用问题
2022年Java将有什么新的特性和改进,我相信很多Java开发者都想知道.结合Java语言架构师布莱恩·格茨(Brian Goetz)最近的一些分享,胖哥给大家爆个料.老规矩,点赞走起. Valha ...
- C# 实现Parallel.For
static class MyParallel { //4.0及以上用Task, Task的背后的实现也是使用了线程池线程 //static List<Task> tasks = new ...
- .Net Core依赖注入
一.配置文件的读取 利用Startup类中的configuration读取appsettings.json中的配置 { "Logging": { "LogLevel&qu ...
- 流言粉碎机:JAVA使用 try catch 会严重影响性能
目录 一.JVM 异常处理逻辑 二.关于JVM的编译优化 1. 分层编译 2. 即时编译器 1. 解释模式 2. 编译模式 3. 提前编译器:jaotc 三.关于测试的约束 执行用时统计 编译器优化的 ...