GeoTools——读取shapefile数据

目录

一、引言

二、代码操作

1、服务端

2、返回数据

3、客户端

三、总结


 

 

一、引言

 

GeoTools在开源gis世界中使用极为常见,地位类比于arcgis中的arcgis engine,当我们要使用java进行解析shp的时候可以不用自己写底层代码直接使用geotools来进行编写服务层。udig和geoserver都使用geotools来进行二次开发。

GeoTools由GeoAPI和JTS组成:

GeoAPI为OpenGIS规范提供一组Java接口。

JTS是加拿大的 Vivid Solutions 做的一套开放源码的 Java API。它提供了一套空间数据操作的核心算法,为在兼容OGC标准的空间对象模型中进行基础的几何操作提供2D空间谓词API。

GeoTools的目标是致力于开发一个符合规范的gis工具包,既然是工具包,那么就要有很多工具用来对付构建一个完整的地理信息系统时会碰到的问题,常见的问题比如:投影的转换,基准面的设定,空间数据对象的渲染和样式,各种数据源的支持,各种GIS文件格式支持,空间数据过滤与搜索等等的问题………… 而在开发这些工具的时候,恰好在处理空间数据图形关系的时候,有一个非常好的解决方案,那就是JTS,JTS解决了对象与对象之间拓扑关系的判定和计算,并提供很多有用的算法来解决对象的面积,长度等等的问题。这样而言,JTS就相当于GeoTools中的一个子模块。但因为这个模块本身不是GeoTools工程的,所以在javadoc中找不到JTS的API,需要到JTS官网上面另外下载。至于GeoAPI则是GeoTools符合标准的模板,它制定了地理信息系统中所有的数据类型应该是什么,投影转换的方式有哪几种诸如此类的规范。这样兼容GeoAPI接口的GeoTools才是一个符合规范的地理信息系统工具包。

GeoTools——读取shapefile数据_第1张图片

下面介绍下使用geotools读取shape file文件,空间数据解析为WKT格式,整体作为json数据返回。

 

 

二、代码操作

 

1、服务端

从本地读取shapefile文件,得到featurecollection,得到feature,遍历feature的每个property,中间涉及到编码转换问题,因为我的原始shp文件是gbk编码,而这里默认iso8859-1解码,所以我又用iso8859-1编码后,重新使用gbk解码,然后得到了正确的汉字,不然都是??,这里可以参考官网一部分帮助

   /**
     * 后台读取shp,转为对象(wkt)返回
     * @return
     * @throws IOException
     */
    @RequestMapping("/shp")
    @ResponseBody
    public Object shp() throws IOException {

        long startTime=System.currentTimeMillis();
        //加载文件
        File file = new File(this.getClass().getResource("/").getFile()+"file/pointgbk.shp");
        if (file == null) {
            return 0;
        }
        //map记录shapefile key-value数据
        List> list = new ArrayList>();
        //通过store获取featurecollection
        FileDataStore store = FileDataStoreFinder.getDataStore(file);
        SimpleFeatureSource featureSource = store.getFeatureSource();
        SimpleFeatureCollection simpleFeatureCollection=featureSource.getFeatures();
        SimpleFeatureIterator itertor = simpleFeatureCollection.features();
        //遍历featurecollection
        while (itertor.hasNext())
        {
            Map data  = new HashMap();
            SimpleFeature feature = itertor.next();
            Collection p = feature.getProperties();
            Iterator it = p.iterator();
            //遍历feature的properties
            while(it.hasNext()) {
                Property pro = it.next();
                String field = pro.getName().toString();
                String value = pro.getValue().toString();
                field = field.equals("the_geom")?"wkt":field;
                byte[]bytes=value.getBytes("iso8859-1");
                value=new String(bytes, "gbk");
                data.put(field, value);
            }
            list.add(data);
        }

        long endTime=System.currentTimeMillis();
        System.out.println("当前程序耗时:"+(endTime-startTime)+"ms");

        return  list;
    }

 

2、返回数据

[{"ExtendedEn":"{ 83103 } { L31-20201081-10 L31-20201081-10 }","wkt":"POINT (508929.405 299800.519)","SubClasses":"AcDbEntity:AcDbText:AcDbText","EntityHand":"1521","Text":"37.04","Linetype":"","Layer":"文字层组-标注"},
{"ExtendedEn":"{ 83103 } { L31-20201081-24 L31-20201081-24 }","wkt":"POINT (508909.8539904643 299887.2300114852)","SubClasses":"AcDbEntity:AcDbText:AcDbText","EntityHand":"1522","Text":"37.24","Linetype":"","Layer":"文字层组-标注"}………………]

 

3、客户端

使用ajax请求数据,使用openlayers将返回数据进行展示




    
    Title
    
    
    


GeoTools——读取shapefile数据_第2张图片

 

三、总结

 

  • GeoTools基本组成与功能;

 

  • GeoTools读取shp中的属性和空间数据;

 

  • openlayers展示wkt数据;

 

 

你可能感兴趣的:(GIS)