【移動GIS】如何解析WKT格式空間對象?

WKT(the Well-Known Text)是OpenGIS的說明書中定義了其中一個表述空間對象的標準方式,當我們獲得此對象時,我們需要對它進行解析並繪製在我們的地圖上,本文主要說的是用java解析方式

在解析之前,需要用到一個工具類,此工具類在我的資源中有上傳,大家可以到這裏來下:JTS.JAR

舉個簡單的例子吧:

 

/*WKT就是你得到的WKT字符串,可以是點也可以是線、多線、多面等*/

Geometry geo = new WKTReader().read(WKT);

 

下面是我在實際應用當中對線的解析方式:

linestring:

/**
	 * 增加一條路徑 
	 * 傳入WKT格式
	 * @param WKT
	 */
	public void addLine(String WKT){
		try {
			LineString lineString = (LineString) new WKTReader().read(WKT);
			this.addLine(lineString);
		} catch (ParseException e) {
			throw new IllegalArgumentException("WKT解析失敗:" + WKT);
		}
	}
	/**
	 * 增加一條路徑  
	 * 傳入LineString對象
	 * @param lineString
	 */
	public void addLine(final LineString lineString){
		ArrayList<Point> mPoints = new ArrayList<Point>();
		Coordinate[] coordinates = lineString.getCoordinates();
		for (Coordinate coordinate : coordinates) {
			system.out.println(coordinate);
		}
		paths.add(mPoints);
	}


多線MultiLineString

/**
	 * 增加路徑 
	 * 傳入WKT格式
	 * 
	 * @param WKT
	 */
	public void addMultiLine(final String WKT) {
		try {
			this.addMultiLine((MultiLineString) new WKTReader().read(WKT));
		} catch (ParseException e) {
			throw new IllegalArgumentException("WKT解析失敗:" + WKT);
		}
	}

	/**
	 * 增加路徑 
	 * 傳入MultiLineString格式
	 * 
	 * @param multiLineString
	 */
	public void addMultiLine(final MultiLineString multiLineString) {
		ArrayList<Point> mPoints = new ArrayList<Point>();
		int num = multiLineString.getNumGeometries();
		// 解析WKT
		for (int i = 0; i < num; i++) {
			LineString lineString = (LineString) multiLineString
					.getGeometryN(i);
			Coordinate[] coordinates = lineString.getCoordinates();
			for (Coordinate coordinate : coordinates) {
				mPoints.add(new Point((int) (coordinate.y * 1E6),
						(int) (coordinate.x * 1E6)));
			}
			paths.add(mPoints);
			mPoints = new ArrayList<Point>();
		}
	}


 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章