Builder

open class Builder(tilejson: String, tiles: List<String>)

Builder for TileSet.

Constructors

Builder
Link copied to clipboard
fun Builder(tilejson: String, tiles: List<String>)

Functions

attribution
Link copied to clipboard
fun attribution(value: String): TileSet.Builder

Default: null. Contains an attribution to be displayed when the map is shown to a user. Implementations MAY decide to treat this as HTML or literal text. For security reasons, make absolutely sure that this field can't be abused as a vector for XSS or beacon tracking. "attribution": "OSM contributors",

bounds
Link copied to clipboard
fun bounds(value: List<Double> = listOf(-180.0, -90.0, 180.0, 90.0)): TileSet.Builder

Default: -180, -90, 180, 90. The maximum extent of available map tiles. Bounds MUST define an area covered by all zoom levels. The bounds are represented in WGS:84 latitude and longitude values, in the order left, bottom, right, top. Values may be integers or floating point numbers.

build
Link copied to clipboard
fun build(): TileSet

Build the TileSet.

center
Link copied to clipboard
fun center(value: List<Double>): TileSet.Builder

The first value is the longitude, the second is latitude (both in WGS:84 values), the third value is the zoom level as an integer. Longitude and latitude MUST be within the specified bounds. The zoom level MUST be between minzoom and maxzoom. Implementations can use this value to set the default location. If the value is null, implementations may use their own algorithm for determining a default location.

data
Link copied to clipboard
fun data(value: List<String>): TileSet.Builder

An array of data files in GeoJSON format. {z}, {x} and {y}, if present, are replaced with the corresponding integers. If multiple endpoints are specified, clients may use any combination of endpoints. All endpoints MUST return the same content for the same URL. If the array doesn't contain any entries, then no data is present in the map.

description
Link copied to clipboard
fun description(value: String): TileSet.Builder

A text description of the tileset. The description can contain any legal character. Implementations SHOULD NOT interpret the description as HTML. "description": "A simple, light grey world."

grids
Link copied to clipboard
fun grids(value: List<String>): TileSet.Builder

An array of interactivity endpoints. {z}, {x} and {y}, if present, are replaced with the corresponding integers. If multiple endpoints are specified, clients may use any combination of endpoints. All endpoints MUST return the same content for the same URL. If the array doesn't contain any entries, interactivity is not supported for this tileset. See https:github.com/mapbox/utfgrid-spec/tree/master/1.2 for the interactivity specification.

legend
Link copied to clipboard
fun legend(value: String): TileSet.Builder

Contains a legend to be displayed with the map. Implementations MAY decide to treat this as HTML or literal text. For security reasons, make absolutely sure that this field can't be abused as a vector for XSS or beacon tracking. "legend": "Dangerous zones are red, safe zones are green"

maxZoom
Link copied to clipboard
fun maxZoom(value: Int = 30): TileSet.Builder

Default to 30. >= 0, <= 22. An integer specifying the maximum zoom level.

minZoom
Link copied to clipboard
fun minZoom(value: Int = 0): TileSet.Builder

Default to 0. >= 0, < 22. An integer specifying the minimum zoom level.

name
Link copied to clipboard
fun name(value: String): TileSet.Builder

A name describing the tileset. The name can contain any legal character. Implementations SHOULD NOT interpret the name as HTML. "name": "compositing",

scheme
Link copied to clipboard
fun scheme(value: Scheme): TileSet.Builder

Default: "xyz". Either "xyz" or "tms". Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed. "scheme": "xyz"

template
Link copied to clipboard
fun template(value: String): TileSet.Builder

Contains a mustache template to be used to format data from grids for interaction. See https:github.com/mapbox/utfgrid-spec/tree/master/1.2 for the interactivity specification. "template": "{{#teaser}}{{NAME}}{{/teaser}}"

version
Link copied to clipboard
fun version(value: String = "1.0.0"): TileSet.Builder

Default: "1.0.0". A semver.org style version number. When changes across tiles are introduced, the minor version MUST change. This may lead to cut off labels. Therefore, implementors can decide to clean their cache when the minor version changes. Changes to the patch level MUST only have changes to tiles that are contained within one tile. When tiles change significantly, the major version MUST be increased. Implementations MUST NOT use tiles with different major versions.

Properties

tilejson
Link copied to clipboard
val tilejson: String
tiles
Link copied to clipboard
val tiles: List<String>

Inheritors

TileSet
Link copied to clipboard