`
jjxliu306
  • 浏览: 153492 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

基于udig(开源GIS软件)二次开发(4)

    博客分类:
  • GIS
阅读更多

本次主要基于udig做一个简单的二次开发实例,假如我们手里有一批经纬度的信息,想直接在地图上查看。当然这时候方法非常多,譬如我通过postgis+geoserver+openlayers很容易实现,或者在udig里有create point也可以直接绘制,还有通过openlayers的marker只需要一个简单的txt文件也行,完全用不到二次开发,但这里只是说做一个简单的范例看看udig是怎么样加载地图数据和怎么样我们可以生成一份地图数据。

    本次我们生成比较通用的shp文件(postgis等以后再说),生成shp我们这里需要用到geotools,不过udig里已经集成进去了geotoolsjar包,我们只需要在我们自己的插件里引用net.refractions.udig.libs这个插件即可。闲话不多说,我们开始先创建一个插件项目(因为是DEMO,所以就一个插件,记得勾选RCP)

1、 创建项目,如图:

 

 

 

1、 2、创建几个包,如图:


 

 

 

其中command下我们生成一个类ImportDataCommand extends  AbstractHandler pojo下我们生成一个基础的点实体类 DemoPoint {

       private double lon ;

    private double lat ;

    private String site_name ;

   

   

    public double getLon() {

       return lon;

    }

    public void setLon(double lon) {

       this.lon = lon;

    }

    public double getLat() {

       return lat;

    }

    public void setLat(double lat) {

       this.lat = lat;

    }

    public String getSite_name() {

       return site_name;

    }

    public void setSite_name(String site_name) {

       this.site_name = site_name;

}

 

 

}

 

 

3、1、 Command中实现 public Object execute(ExecutionEvent event) throws ExecutionException {} 这个方法。里面需要的操作有

a、 a  弹出选择文件对话框,要求使用者导入需要导入的经纬度文件(文件格式预先定义好)

b、 b  读取文件转换为实体数据

c、 c  根据实体数据生成shp 图层数据文件

d、 d  shp图层数据文件加载显示到udig的地图中

 

 

1、 4、多话不说,我贴代码

a、 a 弹出对话框要求用户选择需要导入的文件。

 

//弹出选择文件对话框 要求选择文件,要求格式csv  字段要求为LON,LAT,SITE_NAME

FileDialog dialog = new FileDialog(Display.getDefault().getActiveShell(), SWT.OPEN);

       dialog.setText("请选择要导入的文件");

      

       String path = dialog.open();

       if(path != null) {

           //选择的文件不为空 开始读取文件信息 转换为实体数据

          

          

     }

 

b、 b  解析文件,转换为我们需要的实体数据

 

/**

     * 解析文件,转换为我们需要的实体数据

     * @param path 文件路径

     * @return 演示用的点信息集合  文件不存在时返回空

     */

    private Collection<DemoPoint> parseFile(String path) {

      

       List<DemoPoint> points = new LinkedList<DemoPoint>();

      

       BufferedReader br = null;

      

       try {

           br = new BufferedReader(new FileReader(path));

          

           String line = br.readLine() ;//跳过表头

          

          

           while((line = br.readLine()) != null) {

             

              String[] _ss = line.split(",");

             

              //由于是演示 所以这里不做数据检查

              DemoPoint point = new DemoPoint();

              point.setLon(Double.valueOf(_ss[0]));

              point.setLat(Double.valueOf(_ss[1]));

              point.setSite_name(_ss[2]);

             

              points.add(point);

             

           }

          

          

       } catch (FileNotFoundException e) {

           // TODO Auto-generated catch block

           e.printStackTrace();

           return null;

       } catch (IOException e) {

           // TODO Auto-generated catch block

           e.printStackTrace();

       } finally {

           if(br != null) {

              try {

                  br.close();

              } catch (IOException e) {

                  // TODO Auto-generated catch block

                  e.printStackTrace();

              }

           }

       }

      

       return points ;

      

      

}

 

c、c  生成shp图层文件

 

/**

     * 根据数据生成图层文件

     * @param data

     * @return 返回生成好的图层文件地图 SHP图层  数据保存在当前workspace

     */

    protected String createShpData(Collection<DemoPoint> data){

      

       //拿到当前的workspace路径

      

       String ws = Platform.getInstanceLocation().getURL().getPath();

      

       //文件名用当前系统时间

       String layerName = String.valueOf(System.currentTimeMillis()) ;

      

       File shpFile = new File(ws , layerName + ".shp");

      

       //图层的属性配置 坐标系采用4326

       String layerFeatures = "GEOM:Point:srid=4326,LON:Double,LAT:Double,SITE_NAME:String" ;

      

        

      

      

       FeatureWriter<SimpleFeatureType, SimpleFeature> fw = null;

      

       try {

          

           ShapefileDataStore myData = new ShapefileDataStore(shpFile

                  .toURI().toURL());

 

           myData.setStringCharset(Charset.forName("GBK"));

 

           SimpleFeatureType ft = DataUtilities.createType(layerName,

                  layerFeatures);

 

           myData.createSchema( ft);

 

           //手动事物 发现有时候给自动回出些问题

           Transaction tran = new DefaultTransaction();

          

          

           fw = myData.getFeatureWriter(layerName,

                  tran);

 

           GeometryFactory gf = new GeometryFactory();

          

          

          

           for(DemoPoint point : data) {

             

               Geometry geo =   gf.createPoint(new Coordinate(point.getLon(), point.getLat()));

             

              SimpleFeature sf = (SimpleFeature) fw.next();

             

              sf.setDefaultGeometry(geo);

             

              //添加属性

              sf.setAttribute("SITE_NAME",point.getSite_name());

              fw.write();

             

          

              

           }

          

           fw.close();

          

           tran.commit();

           tran.close();

          

       } catch (IOException e) {

           // TODO Auto-generated catch block

           e.printStackTrace();

       } catch (SchemaException e) {

           // TODO Auto-generated catch block

           e.printStackTrace();

       } finally {

          

           try {

              if(fw != null)

                  fw.close();

             

           } catch (IOException e) {

              // TODO Auto-generated catch block

              e.printStackTrace();

           }

       }  

      

      

      

      

      

      

       return shpFile.getAbsolutePath();

      

      

}

 

d、 d  创建一个新的地图,加载我们刚才生成的shp图层文件

 

/**

     * 创建一个新地图并打开shp图层文件

     * @param path 文件路径

     */

    protected void createMapAndOpenShp(String path) {

      

       IRepository local = CatalogPlugin.getDefault().getLocal();

        

       IService service = null;

        

       List<IGeoResource> resources = null;

        

       try {

           service = local.acquire(

                  URLUtils.fileToURL(new File(path)),

                  new NullProgressMonitor());

           resources = (List<IGeoResource>) service.resources(new NullProgressMonitor());

   

           //发布

           ApplicationGIS.createAndOpenMap(resources);

          

       } catch (IOException e) {

           // TODO Auto-generated catch block

           e.printStackTrace();

       }

      

        

      

 

    }

 

 

 


 5、
注意事项

插件中引用要因为udigapplicationgis,并且需要生成图层,所以在当前插件里我们要引入5个插件(本次的开发环境udig1.2的版本):




 
创建product文件后,最好引入udig的所有包(新手必须).

 

 

 

 

6、1、 好了 打开看看效果

 

 

 



 



 

 

 

代码和演示数据在附件中可以下载,有问题请留言或者加我们的 群  251615521

251615521251615521251615521
 

  • 大小: 19.9 KB
  • 大小: 51.5 KB
  • 大小: 75.1 KB
  • 大小: 23.9 KB
  • 大小: 17 KB
  • 大小: 19.9 KB
  • 大小: 32.4 KB
分享到:
评论

相关推荐

    uDig 二次开发指南

    uDig 是一款开源桌面 GIS 软件,基于 Java 和 Eclipse 平台,可以进行 shp 格式地图文件的编辑和查看······ 但是,纵观整个网络,都是泛泛地讲了讲如何简单地使用 uDig,却从未见过讲解如何对其进行二次开发的...

    GIS - udig - gis桌面应用工具

    是一款开源桌面GIS软件,基于Java和Eclipse平台,可以进行shp格式地图文件的编辑和查看;是一个开源空间数据查看器/编辑器,对OpenGIS标准,关于互联网GIS、网络地图服务器和网络功能服务器有特别的加强。uDig提供一...

    udig软件安装包解压即用.zip

    uDig软件安装包,解压后,即可使用,本安装包使用Java开发,和Eclipes很像,使用也相似,适合开发人员使用,GIS的不二选择

    uDig文档两篇

    uDig文档两篇 了解uDig平台及其应用 javaGIS桌面应用

    udig开发环境大礼包,eclipse rpc+eclipse modeling Tools+udig_sdk

    下载资源的兄弟如果会udig开发跟我说说,我走了一遍eclipse rpc开发,整个人感觉不好了。如果有同志会eclipse RCP开发可能会入门简单一些,我按照官网走了一片,udig到时配置起来了,但是单独开发应用真的太难了。

    udig2.0安装程序包

    更好用的udig制图软件,因官网下载速度慢,特此分享!

    图层样式配置软件udig,配置并导出 .sld 样式文件

    图层样式配置软件udig,配置并导出 .sld 样式文件 导出的sld样式文件可以导入到geoserver中,对geoserver发布的wms,wmts,wfs等服务的图层进行样式配置,并提供给前端调用渲染 直接点击 udig_internal.exe 即可运行...

    基于OpenLayer的通信网GIS平台的研究

    依托于光纤在线监测系统,基于在光缆网管理中遇到的实际问题,在通 信管线资源GIS模型的基础上,对光缆网GIS平台进行了需求...选择了开源的uDig、Geoserver作为GIS平台,利用饰enLayer工具包设计并实现了光缆网GIS平台。

    udig-1.5.0.RC1.win32.win32.x86_64地理信息遥感软件

    打开遥感影像的最简单软件udig,一键安装,支持遥感数据、地理信息shp数据。

    udig-2.0.0.win32.x64解压版

    好用的udig制图软件,美化地图的实用工具,因官网下载速度慢,特此分享!

    利用udig美化shape文件并由Geoserver发布

    这是gis方向文档,用于shape文件美化显示,用udig软件对shape文件添加美化style,并导出style文件,利用geoserver加载style文件并发布,可以通过openlayers显示

    uDig 快速入门

    uDig 快速入门,详细图示化讲解uDig软件的操作与使用,方便入门与提高

    GeoServer 和GeoWebCache

    基于GeoServer的WebGIS开发.pdf 基于GeoServer和OpenLayers的WebGIS实现.pdf 基于GOESERVER_2.0.2的地图发布(webgis作业).do 使用geoserver创建样式简单图解.doc 优化_geoserver的运行.txt Geoserver+MapBuilder+...

    qgis和udig安装包.zip

    qgis和udig安装包

    利用UDig在图层上显示属性信息

    利用UDig在图层上显示属性信息,另外还有不同比例尺显示不同图像

    uDig简单使用教程.pdf

    uDig简单使用教程.pdf

    udig2.0中文语言包.rar

    udig2.0中文语言包.rar udig2.0中文语言包.rar udig2.0中文语言包.rar udig2.0中文语言包.rar udig2.0中文语言包.rar

    udig2.0_nl_zh

    udig2.0汉化包,亲测可用。将解压后文件放入本地udig安装目录

Global site tag (gtag.js) - Google Analytics