Java用GDAL读写shapefile的方法示例

 更新时间:2016年12月15日 15:38:10   作者:jihite  
Shapefile文件是描述空间数据的几何和属性特征的非拓扑实体矢量数据结构的一种格式,由ESRI公司开发。这篇文章给大家介绍了Java如何用GDAL读写shapefile的方法示例,有需要的朋友们可以参考借鉴,下面来一起看看吧。

GDAL介绍

GDAL(Geospatial Data Abstraction Library)是一个在X/MIT许可协议下的开源栅格空间数据转换库。它利用抽象数据模型来表达所支持的各种文件格式。它还有一系列命令行工具来进行数据转换和处理。

GDAL官方网址:http://www.gdal.org/,它能支持当前流行的各种地图数据格式,包括栅格和矢量地图,具体参考官方网站。该库使用C/C++开发,在Java中使用需要自己编译,具体编译过程这里就不说了,下面来看看本文的主要内容吧。

Java使用GDAL读写shapefile的方法示例

读取shp文件,并把它转化为json

import org.gdal.ogr.*;
import org.gdal.ogr.Driver;
import org.gdal.gdal.*;

public class GdalShpTest {
 public static void main(String[] args) {
  // 注册所有的驱动
  ogr.RegisterAll();
  // 为了支持中文路径,请添加下面这句代码
  gdal.SetConfigOption("GDAL_FILENAME_IS_UTF8","YES");
  // 为了使属性表字段支持中文,请添加下面这句
  gdal.SetConfigOption("SHAPE_ENCODING","");

  String strVectorFile = "D:\\test\\NODE.shp";
  //打开文件
  DataSource ds = ogr.Open(strVectorFile,0);
  if (ds == null)
  {
   System.out.println("打开文件失败!" );
   return;
  }
  System.out.println("打开文件成功!" );
  Driver dv = ogr.GetDriverByName("GeoJSON");
  if (dv == null)
  {
   System.out.println("打开驱动失败!" );
   return;
  }
  System.out.println("打开驱动成功!" );
  dv.CopyDataSource(ds, "D:\\test\\node.json");
  System.out.println("转换成功!" );
 }
}

写shp文件

import org.gdal.ogr.*;
import org.gdal.gdal.*;
class writeShp2 {
 public static void main(String[] args) {
  writeShp2 readshpObj = new writeShp2();
  readshpObj.WriteVectorFile();
 }

 static void WriteVectorFile() {
  String strVectorFile = "D:\\test\\test.shp";

  ogr.RegisterAll();
  gdal.SetConfigOption("GDAL_FILENAME_IS_UTF8", "NO");
  gdal.SetConfigOption("SHAPE_ENCODING", "CP936");

  String strDriverName = "ESRI Shapefile";
  org.gdal.ogr.Driver oDriver = ogr.GetDriverByName(strDriverName);
  if (oDriver == null) {
   System.out.println(strVectorFile + " 驱动不可用!\n");
   return;
  }
  DataSource oDS = oDriver.CreateDataSource(strVectorFile, null);
  if (oDS == null) {
   System.out.println("创建矢量文件【" + strVectorFile + "】失败!\n");
   return;
  }

  Layer oLayer = oDS.CreateLayer("TestPolygon", null, ogr.wkbPolygon, null);
  if (oLayer == null) {
   System.out.println("图层创建失败!\n");
   return;
  }

  // 下面创建属性表
  // 先创建一个叫FieldID的整型属性
  FieldDefn oFieldID = new FieldDefn("FieldID", ogr.OFTInteger);
  oLayer.CreateField(oFieldID);

  // 再创建一个叫FeatureName的字符型属性,字符长度为50
  FieldDefn oFieldName = new FieldDefn("FieldName", ogr.OFTString);
  oFieldName.SetWidth(100);
  oLayer.CreateField(oFieldName);

  FeatureDefn oDefn = oLayer.GetLayerDefn();

  // 创建三角形要素
  Feature oFeatureTriangle = new Feature(oDefn);
  oFeatureTriangle.SetField(0, 0);
  oFeatureTriangle.SetField(1, "三角形");
  Geometry geomTriangle = Geometry.CreateFromWkt("POLYGON ((0 0,20 0,10 15,0 0))");
  oFeatureTriangle.SetGeometry(geomTriangle);
  oLayer.CreateFeature(oFeatureTriangle);

  // 创建矩形要素
  Feature oFeatureRectangle = new Feature(oDefn);
  oFeatureRectangle.SetField(0, 1);
  oFeatureRectangle.SetField(1, "矩形");
  Geometry geomRectangle = Geometry.CreateFromWkt("POLYGON ((30 0,60 0,60 30,30 30,30 0))");
  oFeatureRectangle.SetGeometry(geomRectangle);
  oLayer.CreateFeature(oFeatureRectangle);

  // 创建五角形要素
  Feature oFeaturePentagon = new Feature(oDefn);
  oFeaturePentagon.SetField(0, 2);
  oFeaturePentagon.SetField(1, "五角形");
  Geometry geomPentagon = Geometry.CreateFromWkt("POLYGON ((70 0,85 0,90 15,80 30,65 15,70 0))");
  oFeaturePentagon.SetGeometry(geomPentagon);
  oLayer.CreateFeature(oFeaturePentagon);

  oDS.SyncToDisk();
  System.out.println("\n数据集创建完成!\n");
 }
}

得到test.dbf, test.shp, test.shx。

test.dbf如下:

打开形状如下

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

相关文章

  • 浅谈Spring Boot: 接口压测及简要优化策略

    浅谈Spring Boot: 接口压测及简要优化策略

    这篇文章主要介绍了浅谈Spring Boot: 接口压测及简要优化策略,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • 23种设计模式(3) java原型模式

    23种设计模式(3) java原型模式

    这篇文章主要为大家详细介绍了23种设计模式之java原型模式,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • MyBatis几种不同类型传参的方式总结

    MyBatis几种不同类型传参的方式总结

    这篇文章主要介绍了MyBatis几种不同类型传参的方式总结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • Java常用命令汇总

    Java常用命令汇总

    这篇文章主要介绍了Java常用命令汇总,小编觉得挺不错的,这里给大家分享下,供需要的朋友参考。
    2017-10-10
  • 一个Java配置文件加密解密工具类分享

    一个Java配置文件加密解密工具类分享

    在 JavaEE 配置文件中,例如 XML 或者 properties 文件,由于某些敏感信息不希望普通人员看见,则可以采用加密的方式存储,程序读取后进行解密
    2014-04-04
  • Java import导入及访问控制权限修饰符原理解析

    Java import导入及访问控制权限修饰符原理解析

    这篇文章主要介绍了Java import导入及访问控制权限修饰符过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • java之多线程抢火车票的实现示例

    java之多线程抢火车票的实现示例

    生活中有很多多线程的案例,购票就是一个很常见的问题,本文主要介绍了java之多线程抢火车票的实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • 关于Scanner对象的输入结束标记问题

    关于Scanner对象的输入结束标记问题

    这篇文章主要介绍了关于Scanner对象的输入结束标记问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • Java中indexOf()方法详解及其日常使用举例

    Java中indexOf()方法详解及其日常使用举例

    这篇文章主要给大家介绍了关于Java中indexOf()方法详解及其日常使用举例的相关资料,indexOf()方法是JavaScript字符串的内置方法之一,它用于查找给定子字符串在原始字符串中第一次出现的位置,需要的朋友可以参考下
    2023-12-12
  • java使用JNA(Java Native Access)调用dll的方法

    java使用JNA(Java Native Access)调用dll的方法

    java使用JNA(Java Native Access)调用windows系统的dll文件的例子
    2013-11-11

最新评论