當前位置: 首頁>>代碼示例>>Java>>正文


Java CRS.findMathTransform方法代碼示例

本文整理匯總了Java中org.geotools.referencing.CRS.findMathTransform方法的典型用法代碼示例。如果您正苦於以下問題:Java CRS.findMathTransform方法的具體用法?Java CRS.findMathTransform怎麽用?Java CRS.findMathTransform使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.geotools.referencing.CRS的用法示例。


在下文中一共展示了CRS.findMathTransform方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getGeoFromPixel

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
/**
   * Computes the map coordinates given the pixel location in the image reference
   * @param xpix the pixel location in x
   * @param ypix the pixel location in y
   * @param outputEpsgProjection is the projection system of the result (for instance "EPSG:4326")  if null use the original projection
   * @return [longitude, latitude]
   * 
   * 
   */
  public double[] getGeoFromPixel(double xpix, double ypix, String outputEpsgProjection) {
  	double[] out = new double[2];
pix2geo.transform(new double[]{xpix , ypix }, 0, out, 0, 1);
      //pix2geo.transform(new double[]{xpix + m_translationX, ypix + m_translationY}, 0, out, 0, 1);
      if (outputEpsgProjection != null) {
          try {
              double[] temp = new double[3];
              CoordinateReferenceSystem crs = CRS.decode(outputEpsgProjection);
              MathTransform math = CRS.findMathTransform(sourceCRS, crs);
              math.transform(new double[]{out[0], out[1], 0}, 0, temp, 0, 1);
              out[0] = temp[0];
              out[1] = temp[1];
          } catch (Exception ex) {
          	logger.error(ex.getMessage(),ex);
          }
      }
      return out;
  }
 
開發者ID:ec-europa,項目名稱:sumo,代碼行數:28,代碼來源:GcpsGeoTransform.java

示例2: getPixelFromGeo

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
/**
 * Computes the subpixel (i.e. precision greater than integer) location of a map coordinates
 * @param xgeo is the longitude
 * @param ygeo is the latitude
 * @param inputEpsgProjection is the projection system of (xgeo, ygeo) (for instance "EPSG:4326"). if null use the original projection
 * @return [xpixel, ypixel]
 *
 */
public double[] getPixelFromGeo(double xgeo, double ygeo, String inputEpsgProjection) {
	double[] out = new double[]{xgeo, ygeo};
    if (inputEpsgProjection != null) {
        try {
            double[] temp = new double[]{xgeo, ygeo, 0};
            CoordinateReferenceSystem crs = CRS.decode(inputEpsgProjection);
            MathTransform math = CRS.findMathTransform(crs, sourceCRS);
            math.transform(temp, 0, temp, 0, 1);
            out[0] = temp[0];
            out[1] = temp[1];
        } catch (Exception ex) {
        	logger.error(ex.getMessage(),ex);
        }
    }
    geo2pix.transform(out, 0, out, 0, 1);
    out[0] = out[0];
    out[1] = out[1];
    return out;
}
 
開發者ID:ec-europa,項目名稱:sumo,代碼行數:28,代碼來源:GcpsGeoTransform.java

示例3: getPixelFromGeo

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
/**
 * 
 */
public double[] getPixelFromGeo(double xgeo, double ygeo, String inputEpsgProjection) {
    double[] out = new double[]{xgeo, ygeo};
    if (inputEpsgProjection != null) {
        try {
            double[] temp = new double[]{xgeo, ygeo, 0};
            CoordinateReferenceSystem crs = CRS.decode(inputEpsgProjection);
            MathTransform math = CRS.findMathTransform(crs, sourceCRS);
            math.transform(temp, 0, temp, 0, 1);
            out[0] = temp[0];
            out[1] = temp[1];
        } catch (Exception ex) {
        	logger.error(ex.getMessage(),ex);
        }
    }
    geo2pix.transform(out, 0, out, 0, 1);
    return out;
}
 
開發者ID:ec-europa,項目名稱:sumo,代碼行數:21,代碼來源:AffineGeoTransform.java

示例4: getGeoFromPixel

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
public double[] getGeoFromPixel(double xpix, double ypix, String outputEpsgProjection) {
    double[] out = new double[2];
    pix2geo.transform(new double[]{xpix, ypix}, 0, out, 0, 1);
    if (outputEpsgProjection != null) {
        try {
            double[] temp = new double[3];
            CoordinateReferenceSystem crs = CRS.decode(outputEpsgProjection);
            MathTransform math = CRS.findMathTransform(sourceCRS, crs);
            math.transform(new double[]{out[0], out[1], 0}, 0, temp, 0, 1);
            out[0] = temp[0];
            out[1] = temp[1];
        } catch (Exception ex) {
        	logger.error(ex.getMessage(),ex);
        }
    }
    return out;
}
 
開發者ID:ec-europa,項目名稱:sumo,代碼行數:18,代碼來源:AffineGeoTransform.java

示例5: NLSDEMTask

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
public NLSDEMTask(String apiKey, URI prjFileLocation, String tiffStorage) throws URISyntaxException {
    if (prjFileLocation == null)
        // Fallback to EPSG3067 found within JAR
        prjFileLocation = NLSDEMTask.class.getResource("EPSG3067.prj").toURI();

    if (tiffStorage == null)
        tiffStorage = System.getProperty("java.io.tmpdir");

    Path prjFile = Paths.get(prjFileLocation);
    if (!Files.isReadable(prjFile))
        throw new IllegalArgumentException(
                ".prj file " + prjFileLocation + " cannot be read. See that it exists and is readable!");

    this.sourceCRS = DefaultGeographicCRS.WGS84;
    try {
        PrjFileReader reader = new PrjFileReader(FileChannel.open(prjFile, StandardOpenOption.READ));
        targetCRS = reader.getCoordinateReferenceSystem();
        transform = CRS.findMathTransform(sourceCRS, targetCRS);
    } catch (FactoryException | IOException e) {
        throw new IllegalArgumentException(".prj file provided is invalid!", e);
    }
    this.nlsXmlClient = new NLSXMLClient(apiKey, tiffStorage);
    this.tiffDownloaderService = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors(),
            new NLSTiffDownloaderFactory());
}
 
開發者ID:jsimomaa,項目名稱:osmosis-nls-dem,代碼行數:26,代碼來源:NLSDEMTask.java

示例6: getTransform

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
/**
 * Get the {@code MathTransform} to reproject data from the coordinate system of
 * the {@code MapContext's} to that of the {@code MapLayer}.
 *
 * @return the transform or {@code null} if either the layer's coordinate system is the same
 *         as that of the map context, or either has a {@code null} CRS.
 */
public MathTransform getTransform() {
    if (transform == null && !transformFailed && dataCRS != null) {
        MapContent content = getMapContent();
        if (content == null) {
            throw new IllegalStateException("map context should not be null");
        }

        CoordinateReferenceSystem contextCRS = content.getCoordinateReferenceSystem();
        try {
            transform = CRS.findMathTransform(contextCRS, dataCRS, true);
        } catch (Exception ex) {
            LOGGER.warning("Can't transform map context to map layer CRS");
            transformFailed = true;
        }
    }

    return transform;
}
 
開發者ID:gama-platform,項目名稱:gama,代碼行數:26,代碼來源:InfoToolHelper.java

示例7: setCrs

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
public void setCrs(final CoordinateReferenceSystem crs) {
	try {
		// System.out.println(content.layers().size());
		final ReferencedEnvelope rEnv = getDisplayArea();
		// System.out.println(rEnv);

		final CoordinateReferenceSystem sourceCRS = rEnv.getCoordinateReferenceSystem();
		final CoordinateReferenceSystem targetCRS = crs;

		final MathTransform transform = CRS.findMathTransform(sourceCRS, targetCRS);
		final com.vividsolutions.jts.geom.Envelope newJtsEnv = JTS.transform(rEnv, transform);

		final ReferencedEnvelope newEnvelope = new ReferencedEnvelope(newJtsEnv, targetCRS);
		content.getViewport().setBounds(newEnvelope);
		fullExtent = null;
		doSetDisplayArea(newEnvelope);

		// ReferencedEnvelope displayArea =
		getDisplayArea();
		// System.out.println(displayArea);
	} catch (final Exception e) {
		e.printStackTrace();
	}
}
 
開發者ID:gama-platform,項目名稱:gama,代碼行數:25,代碼來源:SwtMapPane.java

示例8: CRSTransform

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
/**
 * CRS transform.
 *
 * @param sourceEpsgCRSCode the source epsg CRS code
 * @param targetEpsgCRSCode the target epsg CRS code
 * @return true, if successful
 */
public boolean CRSTransform(String sourceEpsgCRSCode, String targetEpsgCRSCode)
{
	try {
   	CoordinateReferenceSystem sourceCRS = CRS.decode(sourceEpsgCRSCode);
	CoordinateReferenceSystem targetCRS = CRS.decode(targetEpsgCRSCode);
	final MathTransform transform = CRS.findMathTransform(sourceCRS, targetCRS, false);
	this.CRStransformation=true;
	this.sourceEpsgCode=sourceEpsgCRSCode;
	this.targetEpgsgCode=targetEpsgCRSCode;
	this.rawSpatialRDD = this.rawSpatialRDD.map(new Function<T,T>()
	{
		@Override
		public T call(T originalObject) throws Exception {
			return (T) JTS.transform(originalObject,transform);
		}
	});
	return true;
	} catch (FactoryException e) {
		// TODO Auto-generated catch block
		e.printStackTrace();
		return false;
	}
}
 
開發者ID:DataSystemsLab,項目名稱:GeoSpark,代碼行數:31,代碼來源:SpatialRDD.java

示例9: getCells

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
private Object getCells( Envelope env ) throws Exception {

        MathTransform ll2CRSTransform = CRS.findMathTransform(leafletCRS, databaseCrs);
        MathTransform crs2llTransform = CRS.findMathTransform(databaseCrs, leafletCRS);

        Polygon searchPolygonLL = GeometryUtilities.createPolygonFromEnvelope(env);
        Geometry searchPolygonLLCRS = JTS.transform(searchPolygonLL, ll2CRSTransform);

        long t1 = System.currentTimeMillis();
        List<LasCell> lasCells = LasCellsTable.getLasCells(currentConnectedDatabase, searchPolygonLLCRS, true, true, false, false,
                false);
        int size = lasCells.size();
        long t2 = System.currentTimeMillis();
        System.out.println("time: " + (t2 - t1) + " size = " + size);

        if (size == 0) {
            return null;
        }

        loadedElementsNumText.setText("" + size);

        JSONObject rootObj = cells2Json(crs2llTransform, lasCells);
        return rootObj.toString();
    }
 
開發者ID:moovida,項目名稱:STAGE,代碼行數:25,代碼來源:LidarViewerEntryPoint.java

示例10: reprojectToEqualArea

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
/**
 * Private method which reprojects the input Geometry in the input CRS to a Lambert-Equal Area CRS used for calculating Geometry Area and
 * perimeter.
 * 
 * @param sourceCRS Source geometry CRS.
 * @param sourceGeometry Source Geometry
 * @return
 * @throws FactoryException
 * @throws TransformException
 */
private Geometry reprojectToEqualArea(CoordinateReferenceSystem sourceCRS,
        Geometry sourceGeometry) throws FactoryException, TransformException {
    // Reproject to the Lambert Equal Area
    // Geometry center used for centering the reprojection on the Geometry(reduces distance artifacts)
    Point center = sourceGeometry.getCentroid();
    // Creation of the MathTransform associated to the reprojection
    MathTransform transPoint = CRS.findMathTransform(sourceCRS, WGS84, true);
    Point centerRP = (Point) JTS.transform(center, transPoint);
    // Creation of a wkt for the selected Geometry
    String wkt = PROJ_4326.replace("%LAT0%", String.valueOf(centerRP.getY()));
    wkt = wkt.replace("%LON0%", String.valueOf(centerRP.getX()));
    // Parsing of the selected WKT
    final CoordinateReferenceSystem targetCRS = CRS.parseWKT(wkt);
    // Creation of the MathTransform associated to the reprojection
    MathTransform trans = CRS.findMathTransform(sourceCRS, targetCRS);
    // Geometry reprojection
    Geometry geoPrj;
    if (!trans.isIdentity()) {
        geoPrj = JTS.transform(sourceGeometry, trans);
    } else {
        geoPrj = sourceGeometry;
    }
    return geoPrj;
}
 
開發者ID:geosolutions-it,項目名稱:soil_sealing,代碼行數:35,代碼來源:UrbanGridProcess.java

示例11: getAreaSimple

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
public double getAreaSimple(
		Geometry polygon )
		throws Exception {
	Point centroid = polygon.getCentroid();
	CoordinateReferenceSystem equalAreaCRS = lookupUtmCrs(
			centroid.getY(),
			centroid.getX());

	MathTransform transform = CRS.findMathTransform(
			DefaultGeographicCRS.WGS84,
			equalAreaCRS,
			true);

	Geometry transformedPolygon = JTS.transform(
			polygon,
			transform);

	return transformedPolygon.getArea() * SQM_2_SQKM;
}
 
開發者ID:locationtech,項目名稱:geowave,代碼行數:20,代碼來源:PolygonAreaCalculator.java

示例12: RL2NwwLayer

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
public RL2NwwLayer( RL2CoverageHandler rl2Handler, Integer tileSize ) throws Exception {
    super(makeLevels(rl2Handler, tileSize));
    RasterCoverage rasterCoverage = rl2Handler.getRasterCoverage();
    this.layerName = rasterCoverage.coverage_name;

    double w = rasterCoverage.extent_minx;
    double s = rasterCoverage.extent_miny;
    double e = rasterCoverage.extent_maxx;
    double n = rasterCoverage.extent_maxy;

    double centerX = w + (e - w) / 2.0;
    double centerY = s + (n - s) / 2.0;
    Coordinate centerCoordinate = new Coordinate(centerX, centerY);

    CoordinateReferenceSystem targetCRS = DefaultGeographicCRS.WGS84;
    CoordinateReferenceSystem sourceCRS = CrsUtilities.getCrsFromSrid(rasterCoverage.srid);

    MathTransform transform = CRS.findMathTransform(sourceCRS, targetCRS);
    centerCoordinateLL = JTS.transform(centerCoordinate, null, transform);

    this.setUseTransparentTextures(true);

}
 
開發者ID:TheHortonMachine,項目名稱:hortonmachine,代碼行數:24,代碼來源:RL2NwwLayer.java

示例13: transformJTSGeometry

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
protected Geometry transformJTSGeometry(Geometry geom, final CoordinateReferenceSystem sourceCRS, final CoordinateReferenceSystem crs) throws Exception {
	final MathTransform transform = CRS.findMathTransform(sourceCRS, crs, true);
	final Mutable<Boolean> anyChanged = new Mutable<Boolean>(false);
	
	geom = (Geometry) geom.clone();
	geom.apply(new CoordinateFilter() {
		@Override
		public void filter(Coordinate c) {
			DirectPosition dpFrom = new DirectPosition2D(sourceCRS, c.x, c.y);
			DirectPosition dpTo = new DirectPosition2D();
			try {
				transform.transform(dpFrom, dpTo);
				c.x = dpTo.getOrdinate(0);
				c.y = dpTo.getOrdinate(1);
				anyChanged.set(true);
			} catch (TransformException e) {
				LOG.warn("Failed to transform point " + c, e);
			}
		}
	});
	if (anyChanged.get()) {
		geom.geometryChanged();
	}
	return geom;
}
 
開發者ID:opengeospatial,項目名稱:geopackager,代碼行數:26,代碼來源:AbstractFeatureHarvester.java

示例14: FeatureCollectionIterator

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
public FeatureCollectionIterator(
		FeatureCollection<SimpleFeatureType, SimpleFeature> features,
		int sourceEpsg) {
	if (features != null) {
		iter = features.features();
		if (sourceEpsg != targetEpsg) {
			try {
				CoordinateReferenceSystem targetCRS = CRS.decode(
						SRS_NAMESPACE + targetEpsg, true);
				CoordinateReferenceSystem sourceCRS = CRS.decode(
						SRS_NAMESPACE + sourceEpsg, true);
				transform = CRS.findMathTransform(sourceCRS, targetCRS,
						true);
			} catch (Exception e) {
				LOGGER.warn("Could not detemine source and target CRS definitions. Geometry will not be indexed!");
			}
		}
	}
}
 
開發者ID:Geodan,項目名稱:solr-dataimporthandler-wfs,代碼行數:20,代碼來源:WFSDataSource.java

示例15: setDefaultProjection

import org.geotools.referencing.CRS; //導入方法依賴的package包/類
public void setDefaultProjection(String epsgGeoProj){
	this.defaultEpsgProjection=epsgGeoProj;
    try {
        sourceCRS = CRS.decode(epsgGeoProj);
        defaultCrs = CRS.decode(defaultEpsgProjection);
        defaultMath = CRS.findMathTransform(defaultCrs, sourceCRS);
    } catch (Exception ex) {
    	logger.error(ex.getMessage(),ex);
    }
}
 
開發者ID:ec-europa,項目名稱:sumo,代碼行數:11,代碼來源:GcpsGeoTransform.java


注:本文中的org.geotools.referencing.CRS.findMathTransform方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。