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

org.mapfish.print.map.tiled.osm.OsmLayerParam Maven / Gradle / Ivy

package org.mapfish.print.map.tiled.osm;

import com.google.common.collect.HashMultimap;
import com.google.common.collect.Multimap;
import org.apache.commons.lang3.StringUtils;
import org.locationtech.jts.geom.Envelope;
import org.locationtech.jts.util.Assert;
import org.mapfish.print.map.tiled.AbstractTiledLayerParams;
import org.mapfish.print.parser.HasDefaultValue;
import org.mapfish.print.wrapper.PArray;
import org.mapfish.print.wrapper.PObject;

import java.awt.Dimension;
import java.net.URI;
import java.net.URISyntaxException;
import java.util.Arrays;
import java.util.Collections;
import java.util.Iterator;

/**
 * The parameters for configuration an OSM layer.
 */
public final class OsmLayerParam extends AbstractTiledLayerParams {
    private static final int NUMBER_OF_EXTENT_COORDS = 4;
    private static final double DEFAULT_RESOLUTION_TOLERANCE = 1.9;
    private static final int[] DEFAULT_TILE_SIZE = new int[]{256, 256};
    private static final double[] DEFAULT_MAX_EXTENT =
            new double[]{-20037508.34, -20037508.34, 20037508.34, 20037508.34};
    private static final Double[] DEFAULT_RESOLUTIONS = new Double[]{
            156543.03390625,
            78271.516953125,
            39135.7584765625,
            19567.87923828125,
            9783.939619140625,
            4891.9698095703125,
            2445.9849047851562,
            1222.9924523925781,
            611.4962261962891,
            305.74811309814453,
            152.87405654907226,
            76.43702827453613,
            38.218514137268066,
            19.109257068634033,
            9.554628534317017,
            4.777314267158508,
            2.388657133579254,
            1.194328566789627,
            0.5971642833948135
    };
    private final Multimap additionalCustomParam = HashMultimap.create();
    /**
     * The URL used for the tile requests.
     * 

Supported formats:

*
    *
  • The base part of the URL, for example 'http://tile.openstreetmap.org'. This results in an URL * like 'http://tile.openstreetmap.org/12/123/456.png'.
  • *
  • An URL template with the placeholders '{x}', '{y}' or '{-y}', and '{z}'. For example: * 'http://tile.openstreetmap.org/{z}/{x}/{y}.png'.
    The placeholder '{-y}' provides support for OSGeo * TMS tiles. *
  • *
*/ public String baseURL; /** * The maximum extent of the osm layer. Must have 4 coordinates, minX, minY, maxX, maxY *

Default: [-20037508.34, -20037508.34, 20037508.34, 20037508.34]

*/ @HasDefaultValue public double[] maxExtent = DEFAULT_MAX_EXTENT; /** * The size of each tile. Must have 2 values: width, height *

Default: [256, 256]

*/ @HasDefaultValue public int[] tileSize = DEFAULT_TILE_SIZE; /** * The allowed resolutions for this layer. */ @HasDefaultValue public Double[] resolutions = DEFAULT_RESOLUTIONS; /** * The amount of difference between a resolution and a target resolution to consider the two equal. The * value is a value from 0-1. */ @HasDefaultValue public double resolutionTolerance = DEFAULT_RESOLUTION_TOLERANCE; /** * The DPI of the OSM tiles. */ @HasDefaultValue public Double dpi = null; /** * The image extension. for example png, jpeg, etc... */ @HasDefaultValue public String imageExtension = "png"; /** * Custom query parameters to use when making http requests. {@link #customParams}. *

* The json should look something like: *

     * {
     *     "param1Name": "value",
     *     "param2Name": ["value1", "value2"]
     * }
     * 
*/ @HasDefaultValue public PObject customParams; /** * convert a param object to a multimap. * * @param objectParams the parameters to convert. * @return the corresponding Multimap. */ public static Multimap convertToMultiMap(final PObject objectParams) { Multimap params = HashMultimap.create(); if (objectParams != null) { Iterator customParamsIter = objectParams.keys(); while (customParamsIter.hasNext()) { String key = customParamsIter.next(); if (objectParams.isArray(key)) { final PArray array = objectParams.optArray(key); for (int i = 0; i < array.size(); i++) { params.put(key, array.getString(i)); } } else { params.put(key, objectParams.optString(key, "")); } } } return params; } /** * Read the {@link #customParams} into a Multimap. */ public Multimap getCustomParams() { Multimap result = convertToMultiMap(this.customParams); result.putAll(this.additionalCustomParam); return result; } /** * Set a custom parameter. * * @param name the parameter name * @param value the parameter value */ public void setCustomParam(final String name, final String value) { this.additionalCustomParam.put(name, value); } /** * Validate the properties have the correct values. */ public void postConstruct() { Assert.equals(NUMBER_OF_EXTENT_COORDS, this.maxExtent.length, "maxExtent must have exactly 4 elements to the array. Was: " + Arrays.toString(this .maxExtent)); Assert.equals(2, this.tileSize.length, "tileSize must have exactly 2 elements to the array. Was: " + Arrays.toString(this.tileSize)); Assert.isTrue(this.resolutions.length > 0, "resolutions must have at least one value"); Arrays.sort(this.resolutions, Collections.reverseOrder()); Assert.isTrue(validateBaseUrl(), "invalid baseURL"); } /** * Get the max extent as a envelop object. */ public Envelope getMaxExtent() { final int minX = 0; final int maxX = 1; final int minY = 2; final int maxY = 3; return new Envelope(this.maxExtent[minX], this.maxExtent[minY], this.maxExtent[maxX], this.maxExtent[maxY]); } @Override public String getBaseUrl() { return this.baseURL; } public Dimension getTileSize() { return new Dimension(this.tileSize[0], this.tileSize[1]); } @Override public String createCommonUrl() { return getBaseUrl(); } @Override public boolean validateBaseUrl() { String url = getBaseUrl(); if (StringUtils.isEmpty(url)) { return false; } // replace placeholders with dummy values, then check if an URI can be created url = url .replace("{z}", "0") .replace("{x}", "0") .replace("{y}", "0") .replace("{-y}", "0"); try { new URI(url); return true; } catch (URISyntaxException exc) { return false; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy