com.vaadin.flow.component.map.configuration.source.ImageWMSSource Maven / Gradle / Ivy
/**
* Copyright 2000-2024 Vaadin Ltd.
*
* This program is available under Vaadin Commercial License and Service Terms.
*
* See {@literal } for the full
* license.
*/
package com.vaadin.flow.component.map.configuration.source;
import java.util.Map;
import java.util.Objects;
import com.vaadin.flow.component.map.configuration.Constants;
/**
* Source for WMS servers providing single, untiled images
*/
public class ImageWMSSource extends ImageSource {
private String url;
private final Map params;
private final String serverType;
private final String crossOrigin;
private final double ratio;
public ImageWMSSource(Options options) {
super(options);
Objects.requireNonNull(options.params,
"WMS request parameters must not be null");
Objects.requireNonNull(options.params.get("LAYERS"),
"WMS request parameter LAYERS must not be null");
this.url = options.url;
this.params = options.params;
this.serverType = options.serverType;
this.crossOrigin = options.crossOrigin;
this.ratio = options.ratio;
}
@Override
public String getType() {
return Constants.OL_SOURCE_IMAGE_WMS;
}
/**
* The WMS service URL
*
* @return the current URL
*/
public String getUrl() {
return url;
}
/**
* Sets the WMS service URL
*
* @param url
* the new URL
*/
public void setUrl(String url) {
this.url = url;
}
/**
* The WMS request parameters for requesting images from the WMS server. At
* least the {@code LAYERS} parameter is required. By default,
* {@code VERSION} is {@code 1.3.0}, and {@code STYLES} is {@code ""}.
* {@code WIDTH}, {@code HEIGHT}, {@code BBOX}, and {@code CRS} /
* {@code SRS} will be set dynamically.
*
* For individual parameters please refer to the documentation of the WMS
* server as well as the WMS
* specification.
*
* This value can not be changed after constructing an instance, it can only
* be set initially by passing an options object to the constructor.
*
* @return the WMS parameters
*/
public Map getParams() {
return params;
}
/**
* The type of WMS server.
*
* This value can not be changed after constructing an instance, it can only
* be set initially by passing an options object to the constructor.
*
* @return the type of WMS server
*/
public String getServerType() {
return serverType;
}
/**
* The {@code crossOrigin} attribute for loaded images.
*
* This value can not be changed after constructing an instance, it can only
* be set initially by passing an options object to the constructor.
*
* @return the crossOrigin attribute used for loaded images
*/
public String getCrossOrigin() {
return crossOrigin;
}
/**
* The ratio for the size of requested images compared to the map's
* viewport. Ratio {@code 1} means image requests are the size of the
* viewport, a ratio of {@code 2} means twice the size of the viewport, and
* so on. Default is {code 1.5}.
*
* This value can not be changed after constructing an instance, it can only
* be set initially by passing an options object to the constructor.
*
* @return the ratio
*/
public double getRatio() {
return ratio;
}
public static class Options extends ImageSource.Options {
private String url;
private Map params;
private String serverType;
private String crossOrigin;
private double ratio = 1.5;
/**
* @see ImageWMSSource#getUrl()
*/
public void setUrl(String url) {
this.url = url;
}
/**
* @see ImageWMSSource#getParams()
*/
public void setParams(Map params) {
this.params = params;
}
/**
* @see ImageWMSSource#getServerType()
*/
public void setServerType(String serverType) {
this.serverType = serverType;
}
/**
* @see ImageWMSSource#getCrossOrigin()
*/
public void setCrossOrigin(String crossOrigin) {
this.crossOrigin = crossOrigin;
}
/**
* @see ImageWMSSource#getRatio()
*/
public void setRatio(double ratio) {
this.ratio = ratio;
}
}
}