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

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

package org.mapfish.print.map.geotools;

import org.geotools.data.FeatureSource;
import org.geotools.data.collection.CollectionFeatureSource;
import org.geotools.data.simple.SimpleFeatureCollection;
import org.mapfish.print.ExceptionUtils;
import org.mapfish.print.attribute.map.MapfishMapContext;
import org.mapfish.print.config.Template;
import org.mapfish.print.http.MfClientHttpRequestFactory;
import org.mapfish.print.map.AbstractLayerParams;
import org.mapfish.print.parser.HasDefaultValue;

import java.io.IOException;
import java.util.concurrent.ExecutorService;
import javax.annotation.Nonnull;

/**
 * 

Parses GeoJSON from the request data.

*

Type: geojson

*/ public final class GeoJsonLayer extends AbstractFeatureSourceLayer { /** * Constructor. * * @param executorService the thread pool for doing the rendering. * @param featureSourceSupplier a function that creates the feature source. This will only be * called once. * @param styleSupplier a function that creates the style for styling the features. This will only * be called once. * @param renderAsSvg is the layer rendered as SVG? * @param params the parameters for this layer */ public GeoJsonLayer( final ExecutorService executorService, final FeatureSourceSupplier featureSourceSupplier, final StyleSupplier styleSupplier, final boolean renderAsSvg, final AbstractLayerParams params) { super(executorService, featureSourceSupplier, styleSupplier, renderAsSvg, params); } /** *

Renders GeoJSON layers.

*

Type: geojson

* [[examples=json_styling,datasource_multiple_maps,printwms_tyger_ny_EPSG_3857]] */ public static final class Plugin extends AbstractFeatureSourceLayerPlugin { private static final String TYPE = "geojson"; private static final String COMPATIBILITY_TYPE = "vector"; /** * Constructor. */ public Plugin() { super(TYPE, COMPATIBILITY_TYPE); } @Override public GeoJsonParam createParameter() { return new GeoJsonParam(); } @Nonnull @Override public GeoJsonLayer parse( @Nonnull final Template template, @Nonnull final GeoJsonParam param) { return new GeoJsonLayer( this.forkJoinPool, createFeatureSourceSupplier(template, param.geoJson), createStyleFunction(template, param.style), template.getConfiguration().renderAsSvg(param.renderAsSvg), param); } private FeatureSourceSupplier createFeatureSourceSupplier( final Template template, final String geoJsonString) { return new FeatureSourceSupplier() { @Nonnull @Override public FeatureSource load( @Nonnull final MfClientHttpRequestFactory requestFactory, @Nonnull final MapfishMapContext mapContext) { final FeaturesParser parser = new FeaturesParser(requestFactory, mapContext.isForceLongitudeFirst()); SimpleFeatureCollection featureCollection; try { featureCollection = parser.autoTreat(template, geoJsonString); return new CollectionFeatureSource(featureCollection); } catch (IOException e) { throw ExceptionUtils.getRuntimeException(e); } } }; } } /** * The parameters for creating a layer that renders GeoJSON formatted data. */ public static class GeoJsonParam extends AbstractVectorLayerParam { /** * A geojson formatted string or url to the geoJson or the raw GeoJSON data. *

* The url can be a file url, however if it is it must be relative to the configuration directory. */ @HasDefaultValue public String geoJson = "{\"type\": \"FeatureCollection\", \"features\": []}"; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy