/* * Licensed to Prodevelop SL under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The Prodevelop SL licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * * For more information, contact: * * Prodevelop, S.L. * Pza. Don Juan de Villarrasa, 14 - 5 * 46001 Valencia * Spain * * +34 963 510 612 * +34 963 510 968 * prode@prodevelop.es * http://www.prodevelop.es * * @author Alberto Romeu Carrasco http://www.albertoromeu.com */ package es.alrocar.poiproxy.geotools; import org.geotools.geometry.DirectPosition2D; import org.geotools.referencing.CRS; import org.opengis.referencing.crs.CoordinateReferenceSystem; import org.opengis.referencing.operation.MathTransform; public class GeotoolsUtils { static { System.setProperty("org.geotools.referencing.forceXY", "true"); } public static double[] transform(String from, String to, double[] xy) { try { if (from == null || to == null) { return xy; } if (from.compareToIgnoreCase("EPSG:4326") == 0) { // E6 support if (xy[0] > 181 || xy[0] < -181) { xy[0] /= 1000000; } if (xy[1] > 91 || xy[1] < -91) { xy[1] /= 1000000; } } if (from.equals(to)) { return xy; } CoordinateReferenceSystem from_crs = CRS.decode(from); // The 'true' means: // "I'm going to use the order (longitude, latitude)" CoordinateReferenceSystem to_crs = CRS.decode(to, true); // The 'false' means: // "There will be an exception if Geotools doesn't know how to do it" MathTransform transform1 = CRS.findMathTransform(from_crs, to_crs, false); DirectPosition2D from_point = new DirectPosition2D(xy[0], xy[1]); DirectPosition2D to_point = new DirectPosition2D(0, 0); transform1.transform(from_point, to_point); return new double[] { to_point.x, to_point.y }; } catch (Exception exc) { exc.printStackTrace(); return null; } } }