org.mapfish.print.map.tiled.TileCacheInformation Maven / Gradle / Ivy
package org.mapfish.print.map.tiled;
import com.vividsolutions.jts.geom.Coordinate;
import org.geotools.geometry.jts.ReferencedEnvelope;
import org.mapfish.print.attribute.map.MapBounds;
import org.mapfish.print.http.MfClientHttpRequestFactory;
import org.mapfish.print.map.Scale;
import org.springframework.http.client.ClientHttpRequest;
import java.awt.Dimension;
import java.awt.Rectangle;
import java.awt.image.BufferedImage;
import java.io.UnsupportedEncodingException;
import java.net.URISyntaxException;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
/**
* Encapsulates the information needed to create tile requests for a particular map bounds and display.
*
* @author Jesse on 4/3/14.
*/
public abstract class TileCacheInformation {
//CSOFF:VisibilityModifier
/**
* the map bounds.
*/
protected final MapBounds bounds;
/**
* the area to paint.
*/
protected final Rectangle paintArea;
/**
* the DPI to render at.
*/
protected final double dpi;
private final AbstractTiledLayerParams params;
//CSON:VisibilityModifier
/**
* Constructor.
*
* @param bounds the map bounds
* @param paintArea the area to paint
* @param dpi the DPI to render at
* @param params the params with the data for creating the layer.
*/
public TileCacheInformation(final MapBounds bounds, final Rectangle paintArea, final double dpi,
final AbstractTiledLayerParams params) {
this.bounds = bounds;
this.paintArea = paintArea;
this.dpi = dpi;
this.params = params;
}
/**
* Create the http request for loading the image at the indicated area and the indicated size.
*
* @param httpRequestFactory the factory to use for making http requests
* @param commonUrl the uri that is common to all tiles. See {@link #createCommonUrl()}
* @param tileBounds the bounds of the image in world coordinates
* @param tileSizeOnScreen the size of the tile on the screen or on the image.
* @param column the column index of the tile from the origin of the tile cache.
* @param row the row index of the tile from the origin of the tile cache.
*/
@Nonnull
public abstract ClientHttpRequest getTileRequest(MfClientHttpRequestFactory httpRequestFactory,
String commonUrl,
ReferencedEnvelope tileBounds,
Dimension tileSizeOnScreen,
int column,
int row)
throws Exception;
/**
* Get the scale that the layer uses for its calculations. The map isn't always at a resolution that a tiled layer
* supports so a scale is chosen for the layer that is close to the map scale. This method returns the layer's scale.
*
* This is used for calculating the bounds of tiles, the size number and indices of the tiles to be returned.
*/
public abstract Scale getScale();
/**
* Get the DPI of the layer's images. The server renders at a certain DPI that may or may not be the same DPI that the map
* requires. Depending on the server and the protocol mapfish print might be able to request a certain DPI. But since
* that might not be the case, then the layer must be able to report the correct DPI.
*/
public abstract Double getLayerDpi();
/**
* Obtain the image tile size of the tiles that will be loaded from the server.
*/
public abstract Dimension getTileSize();
/**
* Return the full bounds of the tileCache.
*/
@Nonnull
protected abstract ReferencedEnvelope getTileCacheBounds();
/**
* Calculate the minx and miny coordinate of the tile that is the minx and miny tile. It is the starting point of counting
* tiles to render.
*
* This equates to the minX and minY of the GridCoverage as well.
*
* @param envelope the area that will be displayed.
* @param geoTileSize the size of each tile in world space.
*/
// CSOFF:DesignForExtension
@Nonnull
public Coordinate getMinGeoCoordinate(final ReferencedEnvelope envelope, final Coordinate geoTileSize) {
// CSON:DesignForExtension
final ReferencedEnvelope tileCacheBounds = getTileCacheBounds();
final double tileCacheMinX = tileCacheBounds.getMinX();
double minGeoX = envelope.getMinX();
double minGeoY = envelope.getMinY();
double tileMinGeoX = (tileCacheMinX + (Math.floor((minGeoX - tileCacheMinX) / geoTileSize.x) * geoTileSize.x));
final double tileCacheMinY = tileCacheBounds.getMinY();
double tileMinGeoY = (tileCacheMinY + (Math.floor((minGeoY - tileCacheMinY) / geoTileSize.y) * geoTileSize.y));
return new Coordinate(tileMinGeoX, tileMinGeoY);
}
/**
* Create a buffered image with the correct image bands etc... for the tiles being loaded.
*
* @param imageWidth width of the image to create
* @param imageHeight height of the image to create.
*/
// CSOFF:DesignForExtension
@Nonnull
public BufferedImage createBufferedImage(final int imageWidth, final int imageHeight) {
// CSON:DesignForExtension
return new BufferedImage(imageWidth, imageHeight, BufferedImage.TYPE_4BYTE_ABGR);
}
/**
* Create a URL that is common to all tiles for this layer. It may have placeholder like ({matrixId}) if the layer desires.
* That is up to the layer implementation because the layer is responsible for taking the commonUrl and transforming it to
* a final tile URI.
*/
// CSOFF:DesignForExtension
protected String createCommonUrl() throws URISyntaxException, UnsupportedEncodingException {
// CSOFF:DesignForExtension
return this.params.createCommonUrl();
}
/**
* Return the image to draw in place of a tile that is missing.
*
* If this method returns null nothing will be drawn at the location of the missing image.
*/
@Nullable
public BufferedImage getMissingTileImage() {
return null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy