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


Java MathTransform.transform方法代碼示例

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


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

示例1: getPixelFromGeo

import org.opengis.referencing.operation.MathTransform; //導入方法依賴的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

示例2: getGeoFromPixel

import org.opengis.referencing.operation.MathTransform; //導入方法依賴的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

示例3: getPixelFromGeo

import org.opengis.referencing.operation.MathTransform; //導入方法依賴的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.opengis.referencing.operation.MathTransform; //導入方法依賴的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: getTransformed

import org.opengis.referencing.operation.MathTransform; //導入方法依賴的package包/類
/**
 * Transform the query position into the coordinate reference system of the
 * data (if different to that of the {@code MapContext}).
 *
 * @param pos
 *            query position in {@code MapContext} coordinates
 *
 * @return query position in data ({@code MapLayer}) coordinates
 */
private DirectPosition2D getTransformed(final DirectPosition2D pos) {
	if (isTransformRequired()) {
		final MathTransform tr = getTransform();
		if (tr == null) {
			throw new IllegalStateException("MathTransform should not be null");
		}

		try {
			return (DirectPosition2D) tr.transform(pos, null);
		} catch (final Exception ex) {
			throw new IllegalStateException(ex);
		}
	}

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

示例6: initialise

import org.opengis.referencing.operation.MathTransform; //導入方法依賴的package包/類
@Override
public boolean initialise() {
	try {
		this.displayName=manifestFile.getName();
		setFile(manifestFile);
    	
    	parseProductXML(productxml);
    	
    	tiffImages = getImages();
    	//TIFF image = tiffImages.values().iterator().next();
        bounds = new Rectangle(0, 0, getMetaWidth(),getMetaHeight());
        
        gcps = getGcps();
        if (gcps == null) {
            dispose();
            return false;
        }
        //get satellite altitude
        geotransform = GeoTransformFactory.createFromGcps(gcps, "EPSG:4326");
        double radialdist = Math.pow(xposition * xposition + yposition * yposition + zposition * zposition, 0.5);
        MathTransform convert;
        double[] latlon = getGeoTransform().getGeoFromPixel(0, 0);
        double[] position = new double[3];
        convert = CRS.findMathTransform(DefaultGeographicCRS.WGS84, DefaultGeocentricCRS.CARTESIAN);
        convert.transform(latlon, 0, position, 0, 1);
        double earthradial = Math.pow(position[0] * position[0] + position[1] * position[1] + position[2] * position[2], 0.5);
        setSatelliteAltitude(radialdist - earthradial);

        // get incidence angles from gcps
        // !!possible to improve
        float firstIncidenceangle = (float) (this.gcps.get(0).getAngle());
        float lastIncidenceAngle = (float) (this.gcps.get(this.gcps.size() - 1).getAngle());
        setIncidenceNear(firstIncidenceangle < lastIncidenceAngle ? firstIncidenceangle : lastIncidenceAngle);
        setIncidenceFar(firstIncidenceangle > lastIncidenceAngle ? firstIncidenceangle : lastIncidenceAngle);

    } catch (TransformException | FactoryException | GeoTransformException ex) {
    	logger.error(ex.getMessage(),ex);
    }
    return true;
}
 
開發者ID:ec-europa,項目名稱:sumo,代碼行數:41,代碼來源:TerrasarXImage_SLC.java

示例7: addCoords

import org.opengis.referencing.operation.MathTransform; //導入方法依賴的package包/類
private void addCoords (Coordinate coords[], MathTransform transform) throws Throwable {
		for (Pair<Coordinate, Coordinate> pair : new ConsecutivePairs<Coordinate>( Arrays.asList( coords ) , true)) {
			
			double 
				x1 = pair.first().x,// - cen.getCoordinate().x, 
				y1 = pair.first().y,// - cen.getCoordinate().y,
				x2 = pair.second().x,// - cen.getCoordinate().x, 
				y2 = pair.second().y;// - cen.getCoordinate().y;

			if (targetCRS != null && transform != null)
			{
				double[] result = new double[] {x1, y1, x2, y2, 0, 0};
				transform.transform( result, 0, result, 0, 2 );
				
				addLine (
						new double[] {result[0], result[1], result[2]}, 
						new double[] {result[3], result[4], result[5]}
						);
				
			}
			else {
				
				addLine(new double[] {x1, y1}, new double[] { x2, y2} );
			}
			
//			GML2Graph.this.result.newLine(new Point2d(x1, y1), new Point2d(x2, y2));
			
		}

	}
 
開發者ID:twak,項目名稱:chordatlas,代碼行數:31,代碼來源:GMLReader.java

示例8: createBandImages

import org.opengis.referencing.operation.MathTransform; //導入方法依賴的package包/類
/**
 * STEP 5 methods
 */

private void createBandImages() throws TransformException {
    for (Band band : this.targetProduct.getBands()) {
        Band[] srcBands = new Band[this.sourceProducts.length];
        for (int index = 0; index < this.sourceProducts.length; index++){
            for(MosaicOp.Variable outputVariable : this.variables) {
                if(outputVariable.getName().equals(band.getName())) {
                    srcBands[index] = this.sourceProducts[index].getBand(getSourceBandName(outputVariable.getExpression()));
                }
            }
        }
        final Dimension tileSize = JAIUtils.computePreferredTileSize(band.getRasterWidth(), band.getRasterHeight(), 1);
        int levels = srcBands[0].getSourceImage().getModel().getLevelCount();
        for(Product product: this.sourceProducts){
            int lowestLevel = product.getBandAt(0).getSourceImage().getModel().getLevelCount();
            if(lowestLevel < levels){
                levels = lowestLevel;
            }
        }
        MathTransform mapTransform = band.getGeoCoding().getImageToMapTransform();
        DirectPosition bandOrigin = mapTransform.transform(new DirectPosition2D(0, 0), null);
        S2MosaicMultiLevelSource bandSource =
                new S2MosaicMultiLevelSource(srcBands,
                        bandOrigin.getOrdinate(0),
                        bandOrigin.getOrdinate(1),
                        band.getRasterWidth(), band.getRasterHeight(),
                        tileSize.width, tileSize.height, levels,
                        band.getGeoCoding(),
                        this.overlappingMethod);
        band.setSourceImage(new DefaultMultiLevelImage(bandSource));
    }
}
 
開發者ID:senbox-org,項目名稱:s2tbx,代碼行數:36,代碼來源:S2tbxMosaicOp.java

示例9: transformPosition

import org.opengis.referencing.operation.MathTransform; //導入方法依賴的package包/類
/**
 * Transforms the given HorizontalPosition to a new position in the given
 * coordinate reference system.
 *
 * @param pos
 *            The position to translate.
 * @param targetCrs
 *            The CRS to translate into
 * @return a new position in the given CRS, or the same position if the new
 *         CRS is the same as the point's CRS. The returned point's CRS will
 *         be set to {@code targetCrs}. If the CRS of the position is null,
 *         the CRS will simply be set to the targetCrs.
 * @throws NullPointerException
 *             if {@code targetCrs} is null.
 */
public static HorizontalPosition transformPosition(HorizontalPosition pos,
        CoordinateReferenceSystem targetCrs) {
    if (pos == null) {
        return null;
    }
    CoordinateReferenceSystem sourceCrs = pos.getCoordinateReferenceSystem();
    if (sourceCrs == null) {
        return new HorizontalPosition(pos.getX(), pos.getY(), targetCrs);
    }
    if (targetCrs == null) {
        throw new NullPointerException("Target CRS cannot be null");
    }
    /*
     * CRS.findMathTransform() caches recently-used transform objects so we
     * should incur no large penalty for multiple invocations
     */
    try {
        MathTransform transform = CRS.findOperation(sourceCrs, targetCrs, null)
                .getMathTransform();
        if (transform.isIdentity())
            return pos;
        double[] point = new double[] { pos.getX(), pos.getY() };
        transform.transform(point, 0, point, 0, 1);
        return new HorizontalPosition(point[0], point[1], targetCrs);
    } catch (Exception e) {
        throw new RuntimeException(e);
    }
}
 
開發者ID:Reading-eScience-Centre,項目名稱:edal-java,代碼行數:44,代碼來源:GISUtils.java

示例10: getWorldCoordinates

import org.opengis.referencing.operation.MathTransform; //導入方法依賴的package包/類
private static Coordinate[] getWorldCoordinates(
		final double minX,
		final double minY,
		final double maxX,
		final double maxY,
		final int numPointsPerSegment,
		final MathTransform gridToCRS )
		throws MismatchedDimensionException,
		TransformException {
	final Point2D[] gridCoordinates = getGridCoordinates(
			minX,
			minY,
			maxX,
			maxY,
			numPointsPerSegment);
	final Coordinate[] worldCoordinates = new Coordinate[gridCoordinates.length];
	for (int i = 0; i < gridCoordinates.length; i++) {
		final DirectPosition2D worldPt = new DirectPosition2D();
		final DirectPosition2D dp = new DirectPosition2D(
				gridCoordinates[i]);
		gridToCRS.transform(
				dp,
				worldPt);
		worldCoordinates[i] = new Coordinate(
				worldPt.getX(),
				worldPt.getY());
	}
	return worldCoordinates;
}
 
開發者ID:locationtech,項目名稱:geowave,代碼行數:30,代碼來源:RasterUtils.java

示例11: getPatchCoordinates

import org.opengis.referencing.operation.MathTransform; //導入方法依賴的package包/類
/**
 * Returns the patch coordinates for a tile rectangle.
 *
 * @param r The tile rectangle (only {@code r.x} and {@code r.y} are used).
 * @param t The image-to-map transform used for the tile.
 *
 * @return the patch coordinates.
 *
 * @throws TransformException
 */
public Point getPatchCoordinates(Rectangle r, MathTransform t) throws TransformException {
    final DirectPosition p = new DirectPosition2D(r.getX(), r.getY());
    t.transform(p, p);

    final double lon = p.getOrdinate(0);
    final double lat = p.getOrdinate(1);

    final int patchX = getPatchX(lon);
    final int patchY = getPatchY(lat);

    return new Point(patchX, patchY);
}
 
開發者ID:bcdev,項目名稱:esa-pfa,代碼行數:23,代碼來源:PatchGrid.java

示例12: transform2DPoint

import org.opengis.referencing.operation.MathTransform; //導入方法依賴的package包/類
public static double[] transform2DPoint(String fromEPSG, String toEPSG, double x, double y) throws FactoryException, TransformException {	
	MathTransform transform = CRS.findMathTransform(CRS.decode(fromEPSG), CRS.decode(toEPSG), false);
	DirectPosition srcPoint = new DirectPosition2D(x, y);
	DirectPosition dstPoint = new DirectPosition2D();
	transform.transform(srcPoint, dstPoint);
	
	return dstPoint.getCoordinate();
}
 
開發者ID:oscarfonts,項目名稱:geocalc,代碼行數:9,代碼來源:Geocalc.java

示例13: initialise

import org.opengis.referencing.operation.MathTransform; //導入方法依賴的package包/類
@Override
public boolean initialise() {
	 try {

		 this.imgName=manifestFile.getParentFile().getName();

 	setFile(manifestFile);
 	parseProductXML(productxml);
 	tiffImages = getImages();

     if(tiffImages==null) return false;

        //System.out.println(reader.getNumImages(false));
        TIFF image = tiffImages.values().iterator().next();
        this.displayName= this.imgName;//image.getImageFile().getName();

        image.xSize = getWidth();
        image.ySize = getHeight();

        bounds = new Rectangle(0, 0, image.xSize, image.ySize);
        gcps = getGcps();
        if (gcps == null) {
            dispose();
            return false;
        }

        //get satellite altitude
        geotransform = GeoTransformFactory.createFromGcps(gcps, "EPSG:4326");
        double radialdist = Math.pow(xposition * xposition + yposition * yposition + zposition * zposition, 0.5);
        MathTransform convert;
        double[] latlon = getGeoTransform().getGeoFromPixel(0, 0);
        double[] position = new double[3];
        convert = CRS.findMathTransform(DefaultGeographicCRS.WGS84, DefaultGeocentricCRS.CARTESIAN);
        convert.transform(latlon, 0, position, 0, 1);
        double earthradial = Math.pow(position[0] * position[0] + position[1] * position[1] + position[2] * position[2], 0.5);
        setSatelliteAltitude(radialdist - earthradial);

        // get incidence angles from gcps
        // !!possible to improve
        float firstIncidenceangle = (float) (this.gcps.get(0).getAngle());
        float lastIncidenceAngle = (float) (this.gcps.get(this.gcps.size() - 1).getAngle());
        setIncidenceNear(firstIncidenceangle < lastIncidenceAngle ? firstIncidenceangle : lastIncidenceAngle);
        setIncidenceFar(firstIncidenceangle > lastIncidenceAngle ? firstIncidenceangle : lastIncidenceAngle);


    } catch (TransformException|FactoryException|GeoTransformException ex) {
    	dispose();
    	logger.error(ex.getMessage(),ex);
    }
    return true;
}
 
開發者ID:ec-europa,項目名稱:sumo,代碼行數:52,代碼來源:TerrasarXImage.java

示例14: buildOrigin

import org.opengis.referencing.operation.MathTransform; //導入方法依賴的package包/類
/**
 * Transform toCartesian (around x,y) to a renderable coordinate system with y-up.
 */
private Matrix4d buildOrigin( double x, double y, MathTransform toCartesian ) throws TransformException {
	
	double delta = 1e-6;
	
	double[] frame = new double[] {
			x      , y, 
			x+delta, y, 
			x      , y+delta, 
			0      , 0      ,0 };
	
	toCartesian.transform( frame, 0, frame, 0, 3 );
	
	Vector3d o = new Vector3d(frame[0], frame[1], frame[2]),
			 a = new Vector3d(frame[3], frame[4], frame[5]),
			 b = new Vector3d(frame[6], frame[7], frame[8]),
			 c = new Vector3d();
	
	a.sub( o );
	b.sub( o );
			
	a.normalize();
	b.normalize();
	
	c.cross( a, b );
	
	Matrix4d out = new Matrix4d();
	
	out.setRow( 0, -a.x, -a.y, -a.z, 0 );
	out.setRow( 1, c.x, c.y, c.z, 0 );
	out.setRow( 2, b.x, b.y, b.z, 0 );
	out.setRow( 3, 0, 0, 0, 1 );
	
	out.transform( o );
	
	out.m03 = -o.x;
	out.m13 = -o.y;
	out.m23 = -o.z;
	
	return out;
}
 
開發者ID:twak,項目名稱:chordatlas,代碼行數:44,代碼來源:Tweed.java

示例15: updatePositionValues

import org.opengis.referencing.operation.MathTransform; //導入方法依賴的package包/類
private void updatePositionValues() {
    final boolean availableInRaster = pixelPosValidInRaster &&
            coordinatesAreInRasterBounds(currentRaster, pixelX, pixelY, rasterLevel);
    final boolean availableInScene = isSampleValueAvailableInScene();
    final double offset = 0.5 + (pixelInfoView.getShowPixelPosOffset1() ? 1.0 : 0.0);
    final double pX = levelZeroRasterX + offset;
    final double pY = levelZeroRasterY + offset;

    String tix, tiy, tsx, tsy, tmx, tmy, tgx, tgy;
    tix = tiy = tsx = tsy = tmx = tmy = tgx = tgy = INVALID_POS_TEXT;
    GeoCoding geoCoding = currentRaster.getGeoCoding();
    if (availableInRaster) {
        if (pixelInfoView.getShowPixelPosDecimal()) {
            tix = String.valueOf(pX);
            tiy = String.valueOf(pY);
        } else {
            tix = String.valueOf((int) Math.floor(pX));
            tiy = String.valueOf((int) Math.floor(pY));
        }
    }
    if (getCurrentProduct().isMultiSize()) {
        if (!availableInScene) {
            tsx = PixelInfoViewModelUpdater.INVALID_POS_TEXT;
            tsy = PixelInfoViewModelUpdater.INVALID_POS_TEXT;
        } else {
            double sX = levelZeroSceneX + offset;
            double sY = levelZeroSceneY + offset;
            if (pixelInfoView.getShowPixelPosDecimal()) {
                tsx = String.valueOf(sX);
                tsy = String.valueOf(sY);
            } else {
                tsx = String.valueOf((int) Math.floor(sX));
                tsy = String.valueOf((int) Math.floor(sY));
            }
        }
    }
    if (availableInRaster && geoCoding != null) {
        PixelPos pixelPos = new PixelPos(pX, pY);
        GeoPos geoPos = geoCoding.getGeoPos(pixelPos, null);
        if (pixelInfoView.getShowGeoPosDecimals()) {
            tgx = String.format("%.6f", geoPos.getLon());
            tgy = String.format("%.6f", geoPos.getLat());
        } else {
            tgx = geoPos.getLonString();
            tgy = geoPos.getLatString();
        }
        if (geoCoding instanceof MapGeoCoding) {
            final MapGeoCoding mapGeoCoding = (MapGeoCoding) geoCoding;
            final MapTransform mapTransform = mapGeoCoding.getMapInfo().getMapProjection().getMapTransform();
            Point2D mapPoint = mapTransform.forward(geoPos, null);
            tmx = String.valueOf(MathUtils.round(mapPoint.getX(), 10000.0));
            tmy = String.valueOf(MathUtils.round(mapPoint.getY(), 10000.0));
        } else if (geoCoding instanceof CrsGeoCoding) {
            MathTransform transform = geoCoding.getImageToMapTransform();
            try {
                DirectPosition position = transform.transform(new DirectPosition2D(pX, pY), null);
                double[] coordinate = position.getCoordinate();
                tmx = String.valueOf(coordinate[0]);
                tmy = String.valueOf(coordinate[1]);
            } catch (TransformException ignore) {
            }
        }
    }
    int rowCount = 0;
    positionModel.updateValue(tix, rowCount++);
    positionModel.updateValue(tiy, rowCount++);
    if (getCurrentProduct().isMultiSize()) {
        positionModel.updateValue(tsx, rowCount++);
        positionModel.updateValue(tsy, rowCount++);
    }
    if (geoCoding != null) {
        positionModel.updateValue(tgx, rowCount++);
        positionModel.updateValue(tgy, rowCount++);
        if (geoCoding instanceof MapGeoCoding || geoCoding instanceof CrsGeoCoding) {
            positionModel.updateValue(tmx, rowCount++);
            positionModel.updateValue(tmy, rowCount);
        }
    }
}
 
開發者ID:senbox-org,項目名稱:snap-desktop,代碼行數:80,代碼來源:PixelInfoViewModelUpdater.java


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