org.mapfish.print.attribute.map.MapLayer Maven / Gradle / Ivy
package org.mapfish.print.attribute.map;
import org.mapfish.print.http.HttpRequestFetcher;
import org.mapfish.print.http.MfClientHttpRequestFactory;
import org.mapfish.print.processor.Processor;
import java.awt.Graphics2D;
import java.util.Optional;
/**
* Encapsulates the data required to load map data for a layer and render it.
*/
public interface MapLayer {
/**
* Attempt to add the layer this layer so that both can be rendered as a single layer.
*
* For example: 2 WMS layers from the same WMS server can be combined into a single WMS layer and the map
* can be rendered with a single WMS request.
*
* @param newLayer the layer to combine with this layer. The new layer will be rendered
* below the current layer.
* @return If the two layers can be combined then a map layer representing the two layers will be
* returned. If the two layers cannot be combined then Option.absent() will be returned.
*/
Optional tryAddLayer(MapLayer newLayer);
/**
* Get the scale ratio between the tiles resolution and the target resolution. Used to don't scale the
* tiles on tiled layer.
*/
double getImageBufferScaling();
/**
* Render the layer to the graphics2D object.
*
* @param transformer the map transformer containing the map bounds and size.
*/
void prepareRender(MapfishMapContext transformer);
/**
* Render the layer to the graphics2D object.
*
* @param graphics2D the graphics object.
* @param clientHttpRequestFactory The factory to use for making http requests.
* @param transformer the map transformer containing the map bounds and size.
* @param context the job ID
*/
void render(
Graphics2D graphics2D,
MfClientHttpRequestFactory clientHttpRequestFactory,
MapfishMapContext transformer,
Processor.ExecutionContext context);
/**
* Indicate if the layer supports native rotation (e.g. WMS layers with the "angle" parameter).
*
* @return True if the layer itself takes care of rotating.
*/
boolean supportsNativeRotation();
/**
* The layer name.
*/
String getName();
/**
* Specify whether layer should be rendered as PNG, JPEG or SVG.
*
* @return render type
*/
RenderType getRenderType();
/**
* Cache any needed resources on disk.
*
* @param httpRequestFetcher TODO
* @param clientHttpRequestFactory client http request factory
* @param transformer transformer
* @param context the job ID
*/
void prefetchResources(
HttpRequestFetcher httpRequestFetcher,
MfClientHttpRequestFactory clientHttpRequestFactory,
MapfishMapContext transformer,
Processor.ExecutionContext context);
/**
* Gets the opacity.
*
* @return the opacity
*/
double getOpacity();
/**
* Enumerated type to specify whether layer should be rendered as PNG, JPEG or SVG.
*/
enum RenderType {
/**
* Unknown Rendering Format (let CreateMapProcessor decide).
*/
UNKNOWN,
/**
* Render as PNG.
*/
PNG,
/**
* Render as JPEG.
*/
JPEG,
/**
* Render as TIFF.
*/
TIFF,
/**
* Render as SVG.
*/
SVG;
/**
* Get RenderType from a string that represents a mime type.
*
* @param mimeType string with mime type
* @return render type
*/
public static RenderType fromMimeType(final String mimeType) {
if (mimeType.equals("image/jpeg")) {
return JPEG;
} else if (mimeType.equals("image/png")) {
return PNG;
} else if (mimeType.matches("image/tiff(-fx)?")) {
return TIFF;
} else if (mimeType.matches("image/svg(\\+xml)?")) {
return SVG;
} else {
return UNKNOWN;
}
}
/**
* Get RenderType from a string that represents a file extension.
*
* @param fileExtension string with file extension
* @return render type
*/
public static RenderType fromFileExtension(final String fileExtension) {
final String extensionOrMimeLC = fileExtension.toLowerCase();
if (extensionOrMimeLC.matches("jpe?g")) {
return JPEG;
} else if (extensionOrMimeLC.equals("png")) {
return PNG;
} else if (extensionOrMimeLC.matches("tiff?")) {
return TIFF;
} else if (extensionOrMimeLC.equals("svg")) {
return SVG;
} else {
return UNKNOWN;
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy