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

org.mapfish.print.attribute.map.AreaOfInterest Maven / Gradle / Ivy

package org.mapfish.print.attribute.map;

import org.geotools.data.simple.SimpleFeatureCollection;
import org.geotools.feature.DefaultFeatureCollection;
import org.geotools.feature.simple.SimpleFeatureBuilder;
import org.geotools.feature.simple.SimpleFeatureTypeBuilder;
import org.geotools.geojson.geom.GeometryJSON;
import org.locationtech.jts.geom.Geometry;
import org.locationtech.jts.util.Assert;
import org.mapfish.print.Constants;
import org.mapfish.print.parser.HasDefaultValue;
import org.opengis.feature.simple.SimpleFeature;
import org.opengis.referencing.crs.CoordinateReferenceSystem;

import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import javax.annotation.Nonnull;

/**
 * Represents an area on the map which is of particular interest for some reason.  It consists of polygon
 * geojson and a method for displaying the area the geometry intersects with.
 */
public final class AreaOfInterest {
    /**
     * A Geojson geometry (can be string or GeoJson) that indicates the area of interest.
     * 

* The geojson must be a polygon representing the area of interest. *

*/ public String area; /** * The way that the Area of Interest will be represented on the map. By default it will be drawn as a * polygon with a solid border and a translucent interior. The style can be controlled by the style * parameter. */ @HasDefaultValue public AoiDisplay display = AoiDisplay.RENDER; /** * A string representing the style. The {@link org.mapfish.print.map.style.StyleParserPlugin}s are used * to load the style. Because of this the styleRef can be JSON, SLD, URL, file path, etc... */ @HasDefaultValue public String style; /** * If true the Area of Interest will be rendered as SVG (if display == RENDER). *

* (will default to {@link org.mapfish.print.config.Configuration#defaultStyle}). */ @HasDefaultValue public Boolean renderAsSvg; private Geometry polygon; /** * Tests that the area is valid geojson, the style ref is valid or null and the display is non-null. */ public void postConstruct() { parseGeometry(); Assert.isTrue(this.polygon != null, "Polygon is null. 'area' string is: '" + this.area + "'"); Assert.isTrue(this.display != null, "'display' is null"); Assert.isTrue(this.style == null || this.display == AoiDisplay.RENDER, "'style' does not make sense unless 'display' == RENDER. In this case 'display' == " + this.display); } private void parseGeometry() { GeometryJSON json = new GeometryJSON(); byte[] bytes; try { bytes = this.area.getBytes(Constants.DEFAULT_ENCODING); final InputStream input = new ByteArrayInputStream(bytes); this.polygon = json.read(input); } catch (IOException e) { throw new RuntimeException(e); } } /** * Get the area polygon. It will parse the polygon string representation in the polygon field. */ public synchronized Geometry getArea() { if (this.polygon == null) { parseGeometry(); } return this.polygon; } /** * Return the area polygon as the only feature in the feature collection. * * @param mapAttributes the attributes that this aoi is part of. */ public SimpleFeatureCollection areaToFeatureCollection( @Nonnull final MapAttribute.MapAttributeValues mapAttributes) { Assert.isTrue(mapAttributes.areaOfInterest == this, "map attributes passed in does not contain this area of interest object"); final SimpleFeatureTypeBuilder typeBuilder = new SimpleFeatureTypeBuilder(); typeBuilder.setName("aoi"); CoordinateReferenceSystem crs = mapAttributes.getMapBounds().getProjection(); typeBuilder.add("geom", this.polygon.getClass(), crs); final SimpleFeature feature = SimpleFeatureBuilder.build(typeBuilder.buildFeatureType(), new Object[]{this.polygon}, "aoi"); final DefaultFeatureCollection features = new DefaultFeatureCollection(); features.add(feature); return features; } public void setPolygon(final Geometry polygon) { this.polygon = polygon; } /** * Make a copy of this Area of Interest. */ public AreaOfInterest copy() { AreaOfInterest aoi = new AreaOfInterest(); aoi.display = this.display; aoi.area = this.area; aoi.polygon = this.polygon; aoi.style = this.style; aoi.renderAsSvg = this.renderAsSvg; return aoi; } /** * Represents the ways that the area of interest (aoi) can be rendered on the map. */ public enum AoiDisplay { /** * Draw the entire map and render the AOI polygon on the map. This is the default. */ RENDER, /** * Set a clip for the area (IE only show the area of interest). */ CLIP, /** * Do not show the Area of interest on the map. In this case another processor will likely make use * of the AOI. */ NONE } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy