World Wind Java开发之五——读取本地shp文件

World Wind Java 使用IconLayer图层类表现点和多点数据,使用RenderableLayer图层表现线和面数据,一个图层只能对应一组shape文件。World Wind Java首先使用ShapefileLoader类完成对shape文件的读取和加载,再通过createLayerFromSource方法创建RenderableLayer,最后将创建的Layer加在layers上。源码如下:

/**
	 * 
	 * 方法名称: AddShapeData ;
	 * 方法描述:  添加本地shape文件 ;
	 * 参数 :@param filePath :文件路径 
	 * 参数 :@param fileName :文件名
	 * 参数 :@param layerTitle :图层名称
	 * 参数 :@param maxActiveAltitude :图层可见最高视点
	 * 参数 :@param minActiveAltitude :图层可见最低视点
	 * 参数 :@return 
	 * 返回类型: boolean ;
	 * 创建人:James;
	 * 创建时间:2014-11-25 下午5:19:48;
	 * @throws
	 */
	public boolean AddShapeData(String filePath, String fileName,
			String layerTitle, double maxActiveAltitude,
			double minActiveAltitude)
	{
		boolean result = false;
		try
		{

			ShapefileLoader pShapefileLoader = new ShapefileLoader();
			pShapeLayer = pShapefileLoader.createLayerFromSource(filePath
					+ fileName + ".shp");
			pShapeLayer.setName(layerTitle);// 设置图层名称
			pShapeLayer.setMaxActiveAltitude(maxActiveAltitude);
			pShapeLayer.setMinActiveAltitude(minActiveAltitude);
			
			worldWindowGLCanvas.getModel().getLayers().add(pShapeLayer);
			//添加图层树节点
			pVectorNode.add(new DefaultMutableTreeNode(layerTitle));
			pLayerTree.updateUI();
			result = true;

		}

		catch (Exception e)
		{
			// TODO: handle exception
			System.out.println(e.getMessage());

		}
		return result;
	}
效果图如下图所示:



本文将介绍如何使用World Wind Java SDK解析shape文件,并在地球上绘制出来。 第一步,需要下载Shapefile插件。Shapefile插件是World Wind Java SDK的一个扩展,它提供了对shape文件的支持。下载地址为:http://builds.worldwind.arc.nasa.gov/worldwind-releases/2.1.0/worldwind-shapefile-2.1.0.zip 第二步,将下载的压缩包解压到你的工程目录下,并将其中的worldwind-shapefile.jar文件添加到你的工程中。 第三步,创建一个ShapefileLayer对象,并指定shape文件的路径。例如: ShapefileLayer layer = new ShapefileLayer(); layer.setPath("path/to/your/shapefile.shp"); 第四步,将该layer添加到WorldWindow对象中。例如: worldWindow.getModel().getLayers().add(layer); 现在,你已经成功地在地球上绘制出了shape文件中的几何图形。 完整代码示例: ``` import gov.nasa.worldwind.BasicModel; import gov.nasa.worldwind.awt.WorldWindowGLCanvas; import gov.nasa.worldwind.geom.Position; import gov.nasa.worldwind.layers.RenderableLayer; import gov.nasa.worldwind.layers.ShapefileLayer; import gov.nasa.worldwind.render.*; import gov.nasa.worldwind.util.*; import javax.swing.*; import java.awt.*; import java.io.File; import java.util.*; public class ShapefileExample extends JFrame { public ShapefileExample() { WorldWindowGLCanvas wwd = new WorldWindowGLCanvas(); wwd.setPreferredSize(new Dimension(1000, 800)); this.getContentPane().add(wwd, BorderLayout.CENTER); this.pack(); WWUtil.alignComponent(null, this, AVKey.CENTER); this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); this.setVisible(true); // Set up a basic layer containing the shapefile ShapefileLayer layer = new ShapefileLayer(); layer.setPath("path/to/your/shapefile.shp"); // Set up a renderable layer to hold our labels RenderableLayer labelLayer = new RenderableLayer(); // Create a label for each shape in the shapefile for (ShapefileRecord record : layer.getRecords()) { // Get the shape's attributes Iterable<? extends Map.Entry<? extends String, ? extends Object>> attrs = record.getAttributes(); Iterator<? extends Map.Entry<? extends String, ? extends Object>> iterator = attrs.iterator(); String name = ""; while (iterator.hasNext()) { Map.Entry<? extends String, ? extends Object> attr = iterator.next(); if ("name".equalsIgnoreCase(attr.getKey())) { name = attr.getValue().toString(); break; } } // Create a label for the shape Shapefile shape = record.getShape(); if (shape instanceof Polyline) { Polyline polyline = (Polyline) shape; Position position = polyline.getStartPosition(); Polygon polygon = new Polygon(polyline.getPositions()); labelLayer.addRenderable(new SurfacePolyline(polygon, 5)); labelLayer.addRenderable(new SurfaceText(name, position)); } else if (shape instanceof Polygon) { Polygon polygon = (Polygon) shape; Position position = polygon.getCentroid(); labelLayer.addRenderable(new SurfacePolygon(polygon)); labelLayer.addRenderable(new SurfaceText(name, position)); } } // Add the layers to the WorldWindow wwd.getModel().getLayers().add(layer); wwd.getModel().getLayers().add(labelLayer); wwd.getModel().setGlobe(new Earth()); wwd.getModel().setView(new BasicOrbitView()); } public static void main(String[] args) { SwingUtilities.invokeLater(new Runnable() { public void run() { new ShapefileExample(); } }); } } ```
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值