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