0
如何將一組hk80網格轉換爲緯度/經度?如何使用GeoTools/ProJ.4(或其他api)將座標從HK80 GRID轉換爲緯度/經度?
HK 1980年電網是EPSG 2326,而緯度/經度WGS84是EPSG 4326
或者是還有什麼是這樣做的
如何將一組hk80網格轉換爲緯度/經度?如何使用GeoTools/ProJ.4(或其他api)將座標從HK80 GRID轉換爲緯度/經度?
HK 1980年電網是EPSG 2326,而緯度/經度WGS84是EPSG 4326
或者是還有什麼是這樣做的
我希望下面的代碼可以幫助您更suitible。我需要使用GeoTools來實現您的目的。此外,您還需要爲epsg 2326插入相關的北行和東行。但是,我仍然無法解決異常問題。爲了正確使用此代碼,您需要下載並導入除gt-epsg-postgresql以外的所有GeoTools罐。
package org.geotools.tutorial;
import java.awt.geom.Point2D;
import java.io.File;
import org.geotools.data.FileDataStore;
import org.geotools.data.FileDataStoreFinder;
import org.geotools.data.simple.SimpleFeatureSource;
import org.geotools.factory.Hints;
import org.geotools.map.FeatureLayer;
import org.geotools.map.Layer;
import org.geotools.map.MapContent;
import org.geotools.referencing.CRS;
import org.geotools.referencing.ReferencingFactoryFinder;
import org.geotools.styling.SLD;
import org.geotools.styling.Style;
import org.geotools.swing.JMapFrame;
import org.geotools.swing.data.JFileDataStoreChooser;
import org.opengis.referencing.crs.CRSAuthorityFactory;
import org.opengis.referencing.crs.CoordinateReferenceSystem;
import org.opengis.referencing.operation.MathTransform;
import org.geotools.referencing.*;
/**
* Prompts the user for a shapefile and displays the contents on the screen in a map frame.
* <p>
* This is the GeoTools Quickstart application used in documentationa and tutorials. *
*/
public class quickstart {
/**
* GeoTools Quickstart demo application. Prompts the user for a shapefile and displays its
* contents on the screen in a map frame
*/
public static void main(String[] args) throws Exception {
//Point2D.Double srcProjec = new Point2D.Double (836694.050, 819069.800);
//Point2D.Double dstProjec = new Point2D.Double (132,37);
// display a data store file chooser dialog for shapefiles
//Hints hints = new Hints(Hints.FORCE_LONGITUDE_FIRST_AXIS_ORDER, Boolean.TRUE);
//CRSAuthorityFactory factory = ReferencingFactoryFinder.getCRSAuthorityFactory("EPSG", hints);
//CoordinateReferenceSystem crs = factory.createCoordinateReferenceSystem("EPSG:4326");
CRSAuthorityFactory factory = CRS.getAuthorityFactory(true);
CoordinateReferenceSystem srcCRS = factory.createCoordinateReferenceSystem("EPSG:2326");
CoordinateReferenceSystem dstCRS = factory.createCoordinateReferenceSystem("EPSG:4326");
boolean lenient = true; // allow for some error due to different datums
MathTransform transform = CRS.findMathTransform(srcCRS, dstCRS, lenient);
double[] srcProjec = {818039, 836361};// easting, northing,
double[] dstProjec = {0, 0};
transform.transform(srcProjec, 0, dstProjec, 0, 1);
System.out.println("longitude: " + dstProjec[0] + ", latitude: " + dstProjec[1]);
}
}
雖然問題已經半年前發佈的,謝謝你的answer.I記得我還用geotool來解決問題(雖然我已經使用了1個月至弄清楚geotool API的存在) – Alvar 2012-08-17 07:56:30
我工作的東西完全一樣,但在Android中。它無法編譯,因爲Android中缺少java lib。你能告訴我座標轉換需要哪些jar文件嗎? – 2013-03-07 05:28:24