All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.geotools.data.WorldFileWriter Maven / Gradle / Ivy

Go to download

The main module contains the GeoTools public interfaces that are used by other GeoTools modules (and GeoTools applications). Where possible we make use industry standard terms as provided by OGC and ISO standards. The formal GeoTools public api consists of gt-metadata, jts and the gt-main module. The main module contains the default implementations that are available provided to other GeoTools modules using our factory system. Factories are obtained from an appropriate FactoryFinder, giving applications a chance configure the factory used using the Factory Hints facilities. FilterFactory ff = CommonFactoryFinder.getFilterFactory(); Expression expr = ff.add( expression1, expression2 ); If you find yourself using implementation specific classes chances are you doing it wrong: Expression expr = new AddImpl( expression1, expressiom2 );

There is a newer version: 24.2-oss84-1
Show newest version
/*
 *    GeoTools - The Open Source Java GIS Toolkit
 *    http://geotools.org
 *
 *    (C) 2002-2008, Open Source Geospatial Foundation (OSGeo)
 *
 *    This library is free software; you can redistribute it and/or
 *    modify it under the terms of the GNU Lesser General Public
 *    License as published by the Free Software Foundation;
 *    version 2.1 of the License.
 *
 *    This library is distributed in the hope that it will be useful,
 *    but WITHOUT ANY WARRANTY; without even the implied warranty of
 *    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 *    Lesser General Public License for more details.
 */
package org.geotools.data;

import java.awt.geom.AffineTransform;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.geotools.metadata.i18n.ErrorKeys;
import org.geotools.metadata.i18n.Errors;
import org.geotools.referencing.operation.transform.AffineTransform2D;
import org.geotools.referencing.operation.transform.IdentityTransform;
import org.geotools.referencing.operation.transform.ProjectiveTransform;
import org.opengis.referencing.operation.MathTransform;

/**
 * This class is responsible for creating a world file from a {@link MathTransform} or {@link
 * AffineTransform}.
 *
 * 

The content of a world file describes an affine transformation which was used by the ESRI * software to map from the rater world to the spatial world (what we usually call a grid to world * transform). * *

Specifically a world file should be as follows: * *

scalex shearx sheary scaley upperleftx upperlefty * *

which translates into the following affine transformation. * *

| : | | scalex shearx : translatex| | : | | sheary scaley : transaltey| * |----------------------------| | 0 0 : 1 | | : | * *

Note that a world file usually takes as reference the centre of the pixel. * * @author Simone Giannecchini, GeoSolutions */ public class WorldFileWriter { /** Default buffer size we wil luse to write out. */ public static final int DEFAULT_BUFFER_SIZE = 4096; private static AffineTransform checkTransform(AffineTransform transform) { if (transform == null) throw new IllegalArgumentException( Errors.format(ErrorKeys.NULL_ARGUMENT_$1, "transform")); return transform; } private static MathTransform checkMathTransform(MathTransform transform) { if (transform == null) throw new IllegalArgumentException( Errors.format(ErrorKeys.NULL_ARGUMENT_$1, "transform")); return transform; } /** Logger for this class. */ private static final Logger LOGGER = org.geotools.util.logging.Logging.getLogger(WorldFileWriter.class); /** * Constructor. * * @param outLocation where to create the world file. * @param transform the transformation that we want to write out. * @throws IOException in case something bad happens. */ public WorldFileWriter(final File outLocation, final AffineTransform transform) throws IOException { this( outLocation, ProjectiveTransform.create(checkTransform(transform)), DEFAULT_BUFFER_SIZE); } /** * Constructor. * * @param outLocation where to create the world file. * @param transform the transformation that we want to write out. * @param buffSize size of the buffer to use. * @throws IOException in case something bad happens. */ public WorldFileWriter( final File outLocation, final AffineTransform transform, final int buffSize) throws IOException { this(outLocation, ProjectiveTransform.create(checkTransform(transform)), buffSize); } /** * Constructor. * * @param outLocation where to create the world file. * @param transform the transformation that we want to write out. * @throws IOException in case something bad happens. */ public WorldFileWriter(final OutputStream outLocation, final AffineTransform transform) throws IOException { this(outLocation, ProjectiveTransform.create(checkTransform(transform))); } /** * Constructor. * * @param outLocation where to create the world file. * @param transform the transformation that we want to write out. * @param buffSize size of the buffer to use. * @throws IOException in case something bad happens. */ public WorldFileWriter( final OutputStream outLocation, final AffineTransform transform, final int buffSize) throws IOException { this(outLocation, ProjectiveTransform.create(checkTransform(transform)), buffSize); } /** * Constructor. * *

Note that the {@link MathTransform} must be a 2D affine transform. * * @param outLocation where to create the world file. * @param transform the transformation that we want to write out. * @throws IOException in case something bad happens. */ public WorldFileWriter(final OutputStream outLocation, final MathTransform transform) throws IOException { this(outLocation, transform, DEFAULT_BUFFER_SIZE); } /** * Constructor. * *

Note that the {@link MathTransform} must be a 2D affine transform. * * @param outLocation where to create the world file. * @param transform the transformation that we want to write out. * @param buffSize size of the buffer to use. * @throws IOException in case something bad happens. */ public WorldFileWriter( final OutputStream outLocation, final MathTransform transform, final int buffSize) throws IOException { if (outLocation == null) throw new NullPointerException( Errors.format(ErrorKeys.NULL_ARGUMENT_$1, "outLocation")); if (transform.getSourceDimensions() != 2 || transform.getTargetDimensions() != 2) throw new IllegalArgumentException( Errors.format( ErrorKeys.MISMATCHED_DIMENSION_$3, "transform", transform.getSourceDimensions(), 2)); if (buffSize <= 0) throw new IllegalArgumentException( Errors.format(ErrorKeys.ILLEGAL_ARGUMENT_$2, "buffSize", buffSize)); write(new BufferedWriter(new OutputStreamWriter(outLocation), buffSize), transform); } /** * Write the provided transformation to the provided output. * * @param writer to use for writing the transformation. * @param transform is the transformation that we want to write out. * @throws IOException in case something bad happens. */ private void write(BufferedWriter writer, MathTransform transform) { try { if ((transform instanceof IdentityTransform)) { writer.write("1"); writer.newLine(); writer.write("0"); writer.newLine(); writer.write("0"); writer.newLine(); writer.write("1"); writer.newLine(); writer.write("0"); writer.newLine(); writer.write("0"); close(writer); return; } if ((transform instanceof AffineTransform2D)) { final AffineTransform2D affine = (AffineTransform2D) transform; writer.write(Double.toString(affine.getScaleX())); writer.newLine(); writer.write(Double.toString(affine.getShearX())); writer.newLine(); writer.write(Double.toString(affine.getShearY())); writer.newLine(); writer.write(Double.toString(affine.getScaleY())); writer.newLine(); writer.write(Double.toString(affine.getTranslateX())); writer.newLine(); writer.write(Double.toString(affine.getTranslateY())); close(writer); return; } assert false : transform; } catch (IOException e) { if (LOGGER.isLoggable(Level.SEVERE)) LOGGER.log(Level.SEVERE, e.getLocalizedMessage(), e); } finally { close(writer); } } private void close(BufferedWriter writer) { try { if (writer != null) writer.close(); } catch (Throwable t) { if (LOGGER.isLoggable(Level.FINE)) LOGGER.log(Level.FINE, t.getLocalizedMessage(), t); } } /** * Constructor. * *

Note that the {@link MathTransform} must be a 2D affine transform. * * @param outLocation where to create the world file. * @param transform the transformation that we want to write out. * @param buffSize size of the buffer to use. * @throws IOException in case something bad happens. */ public WorldFileWriter(final File outLocation, final MathTransform transform, int buffSize) throws IOException { if (outLocation == null) throw new NullPointerException( Errors.format(ErrorKeys.NULL_ARGUMENT_$1, "outLocation")); checkMathTransform(transform); if (transform.getSourceDimensions() != 2 || transform.getTargetDimensions() != 2) throw new IllegalArgumentException( Errors.format( ErrorKeys.MISMATCHED_DIMENSION_$3, "transform", transform.getSourceDimensions(), 2)); if (!outLocation.exists()) if (!outLocation.createNewFile()) throw new IOException( Errors.format( ErrorKeys.ILLEGAL_ARGUMENT_$1, "Unable to create file " + outLocation)); if (!outLocation.canWrite() || !outLocation.isFile()) throw new IllegalArgumentException( Errors.format(ErrorKeys.FILE_DOES_NOT_EXIST_$1, outLocation)); // create a writer write(new BufferedWriter(new FileWriter(outLocation), buffSize), transform); } /** * Constructor. * *

Note that the {@link MathTransform} must be a 2D affine transform. * * @param outLocation where to create the world file. * @param transform the transformation that we want to write out. * @throws IOException in case something bad happens. */ public WorldFileWriter(final File outLocation, final MathTransform transform) throws IOException { this(outLocation, transform, DEFAULT_BUFFER_SIZE); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy