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

org.mapfish.print.map.geotools.GeotiffLayer Maven / Gradle / Ivy

There is a newer version: 3.22.0
Show newest version
package org.mapfish.print.map.geotools;

import com.google.common.base.Function;
import com.google.common.collect.Sets;
import com.google.common.io.ByteStreams;
import com.google.common.io.Closer;
import org.geotools.coverage.grid.io.AbstractGridCoverage2DReader;
import org.geotools.gce.geotiff.GeoTiffFormat;
import org.mapfish.print.Constants;
import org.mapfish.print.ExceptionUtils;
import org.mapfish.print.FileUtils;
import org.mapfish.print.config.Template;
import org.mapfish.print.http.MfClientHttpRequestFactory;
import org.mapfish.print.map.AbstractLayerParams;
import org.mapfish.print.map.MapLayerFactoryPlugin;
import org.mapfish.print.parser.HasDefaultValue;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpMethod;
import org.springframework.http.client.ClientHttpRequest;
import org.springframework.http.client.ClientHttpResponse;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.net.URL;
import java.util.Set;
import java.util.concurrent.ExecutorService;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;

/**
 * 

Reads a GeoTIFF file from an URL.

*/ public final class GeotiffLayer extends AbstractGridCoverage2DReaderLayer { /** * Constructor. * * @param reader the reader to use for reading the geotiff. * @param style style to use for rendering the data. * @param executorService the thread pool for doing the rendering. * @param params the parameters for this layer */ public GeotiffLayer( final Function reader, final StyleSupplier style, final ExecutorService executorService, final AbstractLayerParams params) { super(reader, style, executorService, params); } @Override public RenderType getRenderType() { return RenderType.TIFF; } /** *

Renders a GeoTIFF image as layer.

*

Type: geotiff

*/ public static final class Plugin extends AbstractGridCoverageLayerPlugin implements MapLayerFactoryPlugin { @Autowired private ExecutorService forkJoinPool; private Set typeNames = Sets.newHashSet("geotiff"); @Override public Set getTypeNames() { return this.typeNames; } @Override public GeotiffParam createParameter() { return new GeotiffParam(); } @Nonnull @Override public GeotiffLayer parse( @Nonnull final Template template, @Nonnull final GeotiffParam param) throws IOException { Function geotiffReader = getGeotiffReader(template, param.url); String styleRef = param.style; return new GeotiffLayer(geotiffReader, super.createStyleSupplier(template, styleRef), this.forkJoinPool, param); } private Function getGeotiffReader( final Template template, final String geotiffUrl) throws IOException { final URL url = FileUtils.testForLegalFileUrl(template.getConfiguration(), new URL(geotiffUrl)); return new Function() { @Nullable @Override public AbstractGridCoverage2DReader apply(final MfClientHttpRequestFactory requestFactory) { try { final File geotiffFile; if (url.getProtocol().equalsIgnoreCase("file")) { geotiffFile = new File(url.toURI()); } else { geotiffFile = File.createTempFile("downloadedGeotiff", ".tiff"); try (Closer closer = Closer.create()) { final ClientHttpRequest request = requestFactory.createRequest( url.toURI(), HttpMethod.GET); final ClientHttpResponse httpResponse = closer.register(request.execute()); FileOutputStream output = closer.register(new FileOutputStream(geotiffFile)); ByteStreams.copy(httpResponse.getBody(), output); } } return new GeoTiffFormat().getReader(geotiffFile); } catch (Throwable t) { throw ExceptionUtils.getRuntimeException(t); } } }; } } /** * The parameters for reading a Geotiff file, either from the server or from a URL. */ public static final class GeotiffParam extends AbstractLayerParams { /** * The url of the geotiff. It can be a file but if it is the file must be contained within the config * directory. */ public String url; /** * A string identifying a style to use when rendering the raster. */ @HasDefaultValue public String style = Constants.Style.Raster.NAME; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy