38321 lines
2.1 MiB
38321 lines
2.1 MiB
!function (t, e) {
|
||
"object" == typeof exports && "object" == typeof module ? module.exports = e() : "function" == typeof define && define.amd ? define([], e) : "object" == typeof exports ? exports.FMapClient = e() : t.FMapClient = e()
|
||
}(window, function () {
|
||
return function (t) {
|
||
var e = {};
|
||
|
||
function i(r) {
|
||
if (e[r]) return e[r].exports;
|
||
var o = e[r] = {i: r, l: !1, exports: {}};
|
||
return t[r].call(o.exports, o, o.exports, i), o.l = !0, o.exports
|
||
}
|
||
|
||
return i.m = t, i.c = e, i.d = function (t, e, r) {
|
||
i.o(t, e) || Object.defineProperty(t, e, {enumerable: !0, get: r})
|
||
}, i.r = function (t) {
|
||
"undefined" != typeof Symbol && Symbol.toStringTag && Object.defineProperty(t, Symbol.toStringTag, {value: "Module"}), Object.defineProperty(t, "__esModule", {value: !0})
|
||
}, i.t = function (t, e) {
|
||
if (1 & e && (t = i(t)), 8 & e) return t;
|
||
if (4 & e && "object" == typeof t && t && t.__esModule) return t;
|
||
var r = Object.create(null);
|
||
if (i.r(r), Object.defineProperty(r, "default", {
|
||
enumerable: !0,
|
||
value: t
|
||
}), 2 & e && "string" != typeof t) for (var o in t) i.d(r, o, function (e) {
|
||
return t[e]
|
||
}.bind(null, o));
|
||
return r
|
||
}, i.n = function (t) {
|
||
var e = t && t.__esModule ? function () {
|
||
return t.default
|
||
} : function () {
|
||
return t
|
||
};
|
||
return i.d(e, "a", e), e
|
||
}, i.o = function (t, e) {
|
||
return Object.prototype.hasOwnProperty.call(t, e)
|
||
}, i.p = "", i(i.s = 21)
|
||
}([, , function (t, e, i) {
|
||
(function (t, i) {
|
||
(function (e) {
|
||
"use strict";
|
||
var r = {
|
||
$version: 8,
|
||
$root: {
|
||
version: {
|
||
required: !0,
|
||
type: "enum",
|
||
values: [8],
|
||
doc: "Style specification version number. Must be 8.",
|
||
example: 8
|
||
},
|
||
name: {type: "string", doc: "A human-readable name for the style.", example: "Bright"},
|
||
metadata: {
|
||
type: "*",
|
||
doc: "Arbitrary properties useful to track with the stylesheet, but do not influence rendering. Properties should be prefixed to avoid collisions, like 'mapbox:'."
|
||
},
|
||
center: {
|
||
type: "array",
|
||
value: "number",
|
||
doc: "Default map center in longitude and latitude. The style center will be used only if the map has not been positioned by other means (e.g. map options or user interaction).",
|
||
example: [-73.9749, 40.7736]
|
||
},
|
||
zoom: {
|
||
type: "number",
|
||
doc: "Default zoom level. The style zoom will be used only if the map has not been positioned by other means (e.g. map options or user interaction).",
|
||
example: 12.5
|
||
},
|
||
bearing: {
|
||
type: "number",
|
||
default: 0,
|
||
period: 360,
|
||
units: "degrees",
|
||
doc: 'Default bearing, in degrees. The bearing is the compass direction that is "up"; for example, a bearing of 90° orients the map so that east is up. This value will be used only if the map has not been positioned by other means (e.g. map options or user interaction).',
|
||
example: 29
|
||
},
|
||
pitch: {
|
||
type: "number",
|
||
default: 0,
|
||
units: "degrees",
|
||
doc: "Default pitch, in degrees. Zero is perpendicular to the surface, for a look straight down at the map, while a greater value like 60 looks ahead towards the horizon. The style pitch will be used only if the map has not been positioned by other means (e.g. map options or user interaction).",
|
||
example: 50
|
||
},
|
||
light: {
|
||
type: "light",
|
||
doc: "The global light source.",
|
||
example: {anchor: "viewport", color: "white", intensity: .4}
|
||
},
|
||
sources: {
|
||
required: !0,
|
||
type: "sources",
|
||
doc: "Data source specifications.",
|
||
example: {"mapbox-streets": {type: "vector", url: "mapbox://mapbox.mapbox-streets-v6"}}
|
||
},
|
||
sprite: {
|
||
type: "string",
|
||
doc: "A base URL for retrieving the sprite image and metadata. The extensions `.png`, `.json` and scale factor `@2x.png` will be automatically appended. This property is required if any layer uses the `background-pattern`, `fill-pattern`, `line-pattern`, `fill-extrusion-pattern`, or `icon-image` properties. The URL must be absolute, containing the [scheme, authority and path components](https://en.wikipedia.org/wiki/URL#Syntax).",
|
||
example: "mapbox://sprites/mapbox/bright-v8"
|
||
},
|
||
glyphs: {
|
||
type: "string",
|
||
doc: "A URL template for loading signed-distance-field glyph sets in PBF format. The URL must include `{fontstack}` and `{range}` tokens. This property is required if any layer uses the `text-field` layout property. The URL must be absolute, containing the [scheme, authority and path components](https://en.wikipedia.org/wiki/URL#Syntax).",
|
||
example: "mapbox://fonts/mapbox/{fontstack}/{range}.pbf"
|
||
},
|
||
transition: {
|
||
type: "transition",
|
||
doc: "A global transition definition to use as a default across properties, to be used for timing transitions between one value and the next when no property-specific transition is set. Collision-based symbol fading is controlled independently of the style's `transition` property.",
|
||
example: {duration: 300, delay: 0}
|
||
},
|
||
layers: {
|
||
required: !0,
|
||
type: "array",
|
||
value: "layer",
|
||
doc: "Layers will be drawn in the order of this array.",
|
||
example: [{
|
||
id: "water",
|
||
source: "mapbox-streets",
|
||
"source-layer": "water",
|
||
type: "fill",
|
||
paint: {"fill-color": "#00ffff"}
|
||
}]
|
||
}
|
||
},
|
||
sources: {
|
||
"*": {
|
||
type: "source",
|
||
doc: "Specification of a data source. For vector and raster sources, either TileJSON or a URL to a TileJSON must be provided. For image and video sources, a URL must be provided. For GeoJSON sources, a URL or inline GeoJSON must be provided."
|
||
}
|
||
},
|
||
source: ["source_vector", "source_raster", "source_raster_dem", "source_geojson", "source_video", "source_image"],
|
||
source_vector: {
|
||
type: {
|
||
required: !0,
|
||
type: "enum",
|
||
values: {vector: {doc: "A vector tile source."}},
|
||
doc: "The type of the source."
|
||
},
|
||
url: {
|
||
type: "string",
|
||
doc: "A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://<mapid>`."
|
||
},
|
||
tiles: {
|
||
type: "array",
|
||
value: "string",
|
||
doc: "An array of one or more tile source URLs, as in the TileJSON spec."
|
||
},
|
||
bounds: {
|
||
type: "array",
|
||
value: "number",
|
||
length: 4,
|
||
default: [-180, -85.051129, 180, 85.051129],
|
||
doc: "An array containing the longitude and latitude of the southwest and northeast corners of the source's bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."
|
||
},
|
||
scheme: {
|
||
type: "enum",
|
||
values: {xyz: {doc: "Slippy map tilenames scheme."}, tms: {doc: "OSGeo spec scheme."}},
|
||
default: "xyz",
|
||
doc: "Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed."
|
||
},
|
||
minzoom: {
|
||
type: "number",
|
||
default: 0,
|
||
doc: "Minimum zoom level for which tiles are available, as in the TileJSON spec."
|
||
},
|
||
maxzoom: {
|
||
type: "number",
|
||
default: 22,
|
||
doc: "Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."
|
||
},
|
||
attribution: {
|
||
type: "string",
|
||
doc: "Contains an attribution to be displayed when the map is shown to a user."
|
||
},
|
||
"*": {type: "*", doc: "Other keys to configure the data source."}
|
||
},
|
||
source_raster: {
|
||
type: {
|
||
required: !0,
|
||
type: "enum",
|
||
values: {raster: {doc: "A raster tile source."}},
|
||
doc: "The type of the source."
|
||
},
|
||
url: {
|
||
type: "string",
|
||
doc: "A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://<mapid>`."
|
||
},
|
||
tiles: {
|
||
type: "array",
|
||
value: "string",
|
||
doc: "An array of one or more tile source URLs, as in the TileJSON spec."
|
||
},
|
||
bounds: {
|
||
type: "array",
|
||
value: "number",
|
||
length: 4,
|
||
default: [-180, -85.051129, 180, 85.051129],
|
||
doc: "An array containing the longitude and latitude of the southwest and northeast corners of the source's bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."
|
||
},
|
||
minzoom: {
|
||
type: "number",
|
||
default: 0,
|
||
doc: "Minimum zoom level for which tiles are available, as in the TileJSON spec."
|
||
},
|
||
maxzoom: {
|
||
type: "number",
|
||
default: 22,
|
||
doc: "Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."
|
||
},
|
||
tileSize: {
|
||
type: "number",
|
||
default: 512,
|
||
units: "pixels",
|
||
doc: "The minimum visual size to display tiles for this layer. Only configurable for raster layers."
|
||
},
|
||
scheme: {
|
||
type: "enum",
|
||
values: {xyz: {doc: "Slippy map tilenames scheme."}, tms: {doc: "OSGeo spec scheme."}},
|
||
default: "xyz",
|
||
doc: "Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed."
|
||
},
|
||
attribution: {
|
||
type: "string",
|
||
doc: "Contains an attribution to be displayed when the map is shown to a user."
|
||
},
|
||
"*": {type: "*", doc: "Other keys to configure the data source."}
|
||
},
|
||
source_raster_dem: {
|
||
type: {
|
||
required: !0,
|
||
type: "enum",
|
||
values: {"raster-dem": {doc: "A RGB-encoded raster DEM source"}},
|
||
doc: "The type of the source."
|
||
},
|
||
url: {
|
||
type: "string",
|
||
doc: "A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://<mapid>`."
|
||
},
|
||
tiles: {
|
||
type: "array",
|
||
value: "string",
|
||
doc: "An array of one or more tile source URLs, as in the TileJSON spec."
|
||
},
|
||
bounds: {
|
||
type: "array",
|
||
value: "number",
|
||
length: 4,
|
||
default: [-180, -85.051129, 180, 85.051129],
|
||
doc: "An array containing the longitude and latitude of the southwest and northeast corners of the source's bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."
|
||
},
|
||
minzoom: {
|
||
type: "number",
|
||
default: 0,
|
||
doc: "Minimum zoom level for which tiles are available, as in the TileJSON spec."
|
||
},
|
||
maxzoom: {
|
||
type: "number",
|
||
default: 22,
|
||
doc: "Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."
|
||
},
|
||
tileSize: {
|
||
type: "number",
|
||
default: 512,
|
||
units: "pixels",
|
||
doc: "The minimum visual size to display tiles for this layer. Only configurable for raster layers."
|
||
},
|
||
attribution: {
|
||
type: "string",
|
||
doc: "Contains an attribution to be displayed when the map is shown to a user."
|
||
},
|
||
encoding: {
|
||
type: "enum",
|
||
values: {
|
||
terrarium: {doc: "Terrarium format PNG tiles. See https://aws.amazon.com/es/public-datasets/terrain/ for more info."},
|
||
mapbox: {doc: "Mapbox Terrain RGB tiles. See https://www.mapbox.com/help/access-elevation-data/#mapbox-terrain-rgb for more info."}
|
||
},
|
||
default: "mapbox",
|
||
doc: "The encoding used by this source. Mapbox Terrain RGB is used by default"
|
||
},
|
||
"*": {type: "*", doc: "Other keys to configure the data source."}
|
||
},
|
||
source_geojson: {
|
||
type: {
|
||
required: !0,
|
||
type: "enum",
|
||
values: {geojson: {doc: "A GeoJSON data source."}},
|
||
doc: "The data type of the GeoJSON source."
|
||
},
|
||
data: {type: "*", doc: "A URL to a GeoJSON file, or inline GeoJSON."},
|
||
maxzoom: {
|
||
type: "number",
|
||
default: 18,
|
||
doc: "Maximum zoom level at which to create vector tiles (higher means greater detail at high zoom levels)."
|
||
},
|
||
attribution: {
|
||
type: "string",
|
||
doc: "Contains an attribution to be displayed when the map is shown to a user."
|
||
},
|
||
buffer: {
|
||
type: "number",
|
||
default: 128,
|
||
maximum: 512,
|
||
minimum: 0,
|
||
doc: "Size of the tile buffer on each side. A value of 0 produces no buffer. A value of 512 produces a buffer as wide as the tile itself. Larger values produce fewer rendering artifacts near tile edges and slower performance."
|
||
},
|
||
tolerance: {
|
||
type: "number",
|
||
default: .375,
|
||
doc: "Douglas-Peucker simplification tolerance (higher means simpler geometries and faster performance)."
|
||
},
|
||
cluster: {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If the data is a collection of point features, setting this to true clusters the points by radius into groups. Cluster groups become new `Point` features in the source with additional properties:\n * `cluster` Is `true` if the point is a cluster \n * `cluster_id` A unqiue id for the cluster to be used in conjunction with the [cluster inspection methods](https://www.mapbox.com/mapbox-gl-js/api/#geojsonsource#getclusterexpansionzoom)\n * `point_count` Number of original points grouped into this cluster\n * `point_count_abbreviated` An abbreviated point count"
|
||
},
|
||
clusterRadius: {
|
||
type: "number",
|
||
default: 50,
|
||
minimum: 0,
|
||
doc: "Radius of each cluster if clustering is enabled. A value of 512 indicates a radius equal to the width of a tile."
|
||
},
|
||
clusterMaxZoom: {
|
||
type: "number",
|
||
doc: "Max zoom on which to cluster points if clustering is enabled. Defaults to one zoom less than maxzoom (so that last zoom features are not clustered)."
|
||
},
|
||
clusterProperties: {
|
||
type: "*",
|
||
doc: 'An object defining custom properties on the generated clusters if clustering is enabled, aggregating values from clustered points. Has the form `{"property_name": [operator, map_expression]}`. `operator` is any expression function that accepts at least 2 operands (e.g. `"+"` or `"max"`) — it accumulates the property value from clusters/points the cluster contains; `map_expression` produces the value of a single point.\n\nExample: `{"sum": ["+", ["get", "scalerank"]]}`.\n\nFor more advanced use cases, in place of `operator`, you can use a custom reduce expression that references a special `["accumulated"]` value, e.g.:\n`{"sum": [["+", ["accumulated"], ["get", "sum"]], ["get", "scalerank"]]}`'
|
||
},
|
||
lineMetrics: {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "Whether to calculate line distance metrics. This is required for line layers that specify `line-gradient` values."
|
||
},
|
||
generateId: {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "Whether to generate ids for the geojson features. When enabled, the `feature.id` property will be auto assigned based on its index in the `features` array, over-writing any previous values."
|
||
}
|
||
},
|
||
source_video: {
|
||
type: {
|
||
required: !0,
|
||
type: "enum",
|
||
values: {video: {doc: "A video data source."}},
|
||
doc: "The data type of the video source."
|
||
},
|
||
urls: {
|
||
required: !0,
|
||
type: "array",
|
||
value: "string",
|
||
doc: "URLs to video content in order of preferred format."
|
||
},
|
||
coordinates: {
|
||
required: !0,
|
||
doc: "Corners of video specified in longitude, latitude pairs.",
|
||
type: "array",
|
||
length: 4,
|
||
value: {
|
||
type: "array",
|
||
length: 2,
|
||
value: "number",
|
||
doc: "A single longitude, latitude pair."
|
||
}
|
||
}
|
||
},
|
||
source_image: {
|
||
type: {
|
||
required: !0,
|
||
type: "enum",
|
||
values: {image: {doc: "An image data source."}},
|
||
doc: "The data type of the image source."
|
||
},
|
||
url: {required: !0, type: "string", doc: "URL that points to an image."},
|
||
coordinates: {
|
||
required: !0,
|
||
doc: "Corners of image specified in longitude, latitude pairs.",
|
||
type: "array",
|
||
length: 4,
|
||
value: {
|
||
type: "array",
|
||
length: 2,
|
||
value: "number",
|
||
doc: "A single longitude, latitude pair."
|
||
}
|
||
}
|
||
},
|
||
layer: {
|
||
id: {type: "string", doc: "Unique layer name.", required: !0},
|
||
type: {
|
||
type: "enum", values: {
|
||
fill: {
|
||
doc: "A filled polygon with an optional stroked border.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
}
|
||
},
|
||
line: {
|
||
doc: "A stroked line.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
}
|
||
},
|
||
symbol: {
|
||
doc: "An icon or a text label.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
}
|
||
},
|
||
circle: {
|
||
doc: "A filled circle.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
}
|
||
},
|
||
heatmap: {
|
||
doc: "A heatmap.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"fill-extrusion": {
|
||
doc: "An extruded (3D) polygon.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}
|
||
}
|
||
},
|
||
raster: {
|
||
doc: "Raster map textures such as satellite imagery.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
}
|
||
},
|
||
hillshade: {
|
||
doc: "Client-side hillshading visualization based on DEM data. Currently, the implementation only supports Mapbox Terrain RGB and Mapzen Terrarium tiles.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
background: {
|
||
doc: "The background color or pattern of the map.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
}
|
||
}
|
||
}, doc: "Rendering type of this layer.", required: !0
|
||
},
|
||
metadata: {
|
||
type: "*",
|
||
doc: "Arbitrary properties useful to track with the layer, but do not influence rendering. Properties should be prefixed to avoid collisions, like 'mapbox:'."
|
||
},
|
||
source: {
|
||
type: "string",
|
||
doc: "Name of a source description to be used for this layer. Required for all layer types except `background`."
|
||
},
|
||
"source-layer": {
|
||
type: "string",
|
||
doc: "Layer to use from a vector tile source. Required for vector tile sources; prohibited for all other source types, including GeoJSON sources."
|
||
},
|
||
minzoom: {
|
||
type: "number",
|
||
minimum: 0,
|
||
maximum: 24,
|
||
doc: "The minimum zoom level for the layer. At zoom levels less than the minzoom, the layer will be hidden."
|
||
},
|
||
maxzoom: {
|
||
type: "number",
|
||
minimum: 0,
|
||
maximum: 24,
|
||
doc: "The maximum zoom level for the layer. At zoom levels equal to or greater than the maxzoom, the layer will be hidden."
|
||
},
|
||
filter: {
|
||
type: "filter",
|
||
doc: "A expression specifying conditions on source features. Only features that match the filter are displayed. Zoom expressions in filters are only evaluated at integer zoom levels. The `feature-state` expression is not supported in filter expressions."
|
||
},
|
||
layout: {type: "layout", doc: "Layout properties for the layer."},
|
||
paint: {type: "paint", doc: "Default paint properties for this layer."}
|
||
},
|
||
layout: ["layout_fill", "layout_line", "layout_circle", "layout_heatmap", "layout_fill-extrusion", "layout_symbol", "layout_raster", "layout_hillshade", "layout_background"],
|
||
layout_background: {
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
layout_fill: {
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
layout_circle: {
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
layout_heatmap: {
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
"layout_fill-extrusion": {
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
layout_line: {
|
||
"line-cap": {
|
||
type: "enum",
|
||
values: {
|
||
butt: {doc: "A cap with a squared-off end which is drawn to the exact endpoint of the line."},
|
||
round: {doc: "A cap with a rounded end which is drawn beyond the endpoint of the line at a radius of one-half of the line's width and centered on the endpoint of the line."},
|
||
square: {doc: "A cap with a squared-off end which is drawn beyond the endpoint of the line at a distance of one-half of the line's width."}
|
||
},
|
||
default: "butt",
|
||
doc: "The display of line endings.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"line-join": {
|
||
type: "enum",
|
||
values: {
|
||
bevel: {doc: "A join with a squared-off end which is drawn beyond the endpoint of the line at a distance of one-half of the line's width."},
|
||
round: {doc: "A join with a rounded end which is drawn beyond the endpoint of the line at a radius of one-half of the line's width and centered on the endpoint of the line."},
|
||
miter: {doc: "A join with a sharp, angled corner which is drawn with the outer sides beyond the endpoint of the path until they meet."}
|
||
},
|
||
default: "miter",
|
||
doc: "The display of lines when joining.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.40.0", android: "5.2.0", ios: "3.7.0", macos: "0.6.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"line-miter-limit": {
|
||
type: "number",
|
||
default: 2,
|
||
doc: "Used to automatically convert miter joins to bevel joins for sharp angles.",
|
||
requires: [{"line-join": "miter"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"line-round-limit": {
|
||
type: "number",
|
||
default: 1.05,
|
||
doc: "Used to automatically convert round joins to miter joins for shallow angles.",
|
||
requires: [{"line-join": "round"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
layout_symbol: {
|
||
"symbol-placement": {
|
||
type: "enum",
|
||
values: {
|
||
point: {doc: "The label is placed at the point where the geometry is located."},
|
||
line: {doc: "The label is placed along the line of the geometry. Can only be used on `LineString` and `Polygon` geometries."},
|
||
"line-center": {doc: "The label is placed at the center of the line of the geometry. Can only be used on `LineString` and `Polygon` geometries. Note that a single feature in a vector tile may contain multiple line geometries."}
|
||
},
|
||
default: "point",
|
||
doc: "Label placement relative to its geometry.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
},
|
||
"`line-center` value": {js: "0.47.0", android: "6.4.0", ios: "4.3.0", macos: "0.10.0"},
|
||
"data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"symbol-spacing": {
|
||
type: "number",
|
||
default: 250,
|
||
minimum: 1,
|
||
units: "pixels",
|
||
doc: "Distance between two symbol anchors.",
|
||
requires: [{"symbol-placement": "line"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"symbol-avoid-edges": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, the symbols will not cross tile edges to avoid mutual collisions. Recommended in layers that don't have enough padding in the vector tile to prevent collisions, or if it is a point symbol layer placed after a line symbol layer.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"symbol-sort-key": {
|
||
type: "number",
|
||
doc: "Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key when they overlap. Features with a lower sort key will have priority over other features when doing placement.",
|
||
"sdk-support": {js: "0.53.0"},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"symbol-z-order": {
|
||
type: "enum",
|
||
values: {
|
||
auto: {doc: "If `symbol-sort-key` is set, sort based on that. Otherwise sort symbols by their position relative to the viewport."},
|
||
"viewport-y": {doc: "Symbols will be sorted by their y-position relative to the viewport."},
|
||
source: {doc: "Symbols will be rendered in the same order as the source data with no sorting applied."}
|
||
},
|
||
default: "auto",
|
||
doc: "Controls the order in which overlapping symbols in the same layer are rendered",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.49.0",
|
||
android: "6.6.0",
|
||
ios: "4.5.0",
|
||
macos: "0.12.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-allow-overlap": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, the icon will be visible even if it collides with other previously drawn symbols.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-ignore-placement": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, other symbols can be visible even if they collide with the icon.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-optional": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, text will display without their corresponding icons when the icon collides with other symbols and the text does not.",
|
||
requires: ["icon-image", "text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-rotation-alignment": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "When `symbol-placement` is set to `point`, aligns icons east-west. When `symbol-placement` is set to `line` or `line-center`, aligns icon x-axes with the line."},
|
||
viewport: {doc: "Produces icons whose x-axes are aligned with the x-axis of the viewport, regardless of the value of `symbol-placement`."},
|
||
auto: {doc: "When `symbol-placement` is set to `point`, this is equivalent to `viewport`. When `symbol-placement` is set to `line` or `line-center`, this is equivalent to `map`."}
|
||
},
|
||
default: "auto",
|
||
doc: "In combination with `symbol-placement`, determines the rotation behavior of icons.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
},
|
||
"`auto` value": {js: "0.25.0", android: "4.2.0", ios: "3.4.0", macos: "0.3.0"},
|
||
"data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-size": {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
units: "factor of the original icon size",
|
||
doc: "Scales the original size of the icon by the provided factor. The new pixel size of the image will be the original pixel size multiplied by `icon-size`. 1 is the original size; 3 triples the size of the image.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.35.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-text-fit": {
|
||
type: "enum",
|
||
values: {
|
||
none: {doc: "The icon is displayed at its intrinsic aspect ratio."},
|
||
width: {doc: "The icon is scaled in the x-dimension to fit the width of the text."},
|
||
height: {doc: "The icon is scaled in the y-dimension to fit the height of the text."},
|
||
both: {doc: "The icon is scaled in both x- and y-dimensions."}
|
||
},
|
||
default: "none",
|
||
doc: "Scales the icon to fit around the associated text.",
|
||
requires: ["icon-image", "text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.21.0",
|
||
android: "4.2.0",
|
||
ios: "3.4.0",
|
||
macos: "0.2.1"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-text-fit-padding": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 4,
|
||
default: [0, 0, 0, 0],
|
||
units: "pixels",
|
||
doc: "Size of the additional area added to dimensions determined by `icon-text-fit`, in clockwise order: top, right, bottom, left.",
|
||
requires: ["icon-image", "text-field", {"icon-text-fit": ["both", "width", "height"]}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.21.0",
|
||
android: "4.2.0",
|
||
ios: "3.4.0",
|
||
macos: "0.2.1"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-image": {
|
||
type: "string",
|
||
doc: "Name of image in sprite to use for drawing an image background.",
|
||
tokens: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.35.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-rotate": {
|
||
type: "number",
|
||
default: 0,
|
||
period: 360,
|
||
units: "degrees",
|
||
doc: "Rotates the icon clockwise.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.21.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-padding": {
|
||
type: "number",
|
||
default: 2,
|
||
minimum: 0,
|
||
units: "pixels",
|
||
doc: "Size of the additional area around the icon bounding box used for detecting symbol collisions.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-keep-upright": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, the icon may be flipped to prevent it from being rendered upside-down.",
|
||
requires: ["icon-image", {"icon-rotation-alignment": "map"}, {"symbol-placement": ["line", "line-center"]}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-offset": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 2,
|
||
default: [0, 0],
|
||
doc: "Offset distance of icon from its anchor. Positive values indicate right and down, while negative values indicate left and up. Each component is multiplied by the value of `icon-size` to obtain the final offset in pixels. When combined with `icon-rotate` the offset will be as if the rotated direction was up.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
center: {doc: "The center of the icon is placed closest to the anchor."},
|
||
left: {doc: "The left side of the icon is placed closest to the anchor."},
|
||
right: {doc: "The right side of the icon is placed closest to the anchor."},
|
||
top: {doc: "The top of the icon is placed closest to the anchor."},
|
||
bottom: {doc: "The bottom of the icon is placed closest to the anchor."},
|
||
"top-left": {doc: "The top left corner of the icon is placed closest to the anchor."},
|
||
"top-right": {doc: "The top right corner of the icon is placed closest to the anchor."},
|
||
"bottom-left": {doc: "The bottom left corner of the icon is placed closest to the anchor."},
|
||
"bottom-right": {doc: "The bottom right corner of the icon is placed closest to the anchor."}
|
||
},
|
||
default: "center",
|
||
doc: "Part of the icon placed closest to the anchor.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.40.0",
|
||
android: "5.2.0",
|
||
ios: "3.7.0",
|
||
macos: "0.6.0"
|
||
}, "data-driven styling": {js: "0.40.0", android: "5.2.0", ios: "3.7.0", macos: "0.6.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-pitch-alignment": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The icon is aligned to the plane of the map."},
|
||
viewport: {doc: "The icon is aligned to the plane of the viewport."},
|
||
auto: {doc: "Automatically matches the value of `icon-rotation-alignment`."}
|
||
},
|
||
default: "auto",
|
||
doc: "Orientation of icon when map is pitched.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.39.0",
|
||
android: "5.2.0",
|
||
ios: "3.7.0",
|
||
macos: "0.6.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-pitch-alignment": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The text is aligned to the plane of the map."},
|
||
viewport: {doc: "The text is aligned to the plane of the viewport."},
|
||
auto: {doc: "Automatically matches the value of `text-rotation-alignment`."}
|
||
},
|
||
default: "auto",
|
||
doc: "Orientation of text when map is pitched.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.21.0",
|
||
android: "4.2.0",
|
||
ios: "3.4.0",
|
||
macos: "0.2.1"
|
||
},
|
||
"`auto` value": {js: "0.25.0", android: "4.2.0", ios: "3.4.0", macos: "0.3.0"},
|
||
"data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-rotation-alignment": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "When `symbol-placement` is set to `point`, aligns text east-west. When `symbol-placement` is set to `line` or `line-center`, aligns text x-axes with the line."},
|
||
viewport: {doc: "Produces glyphs whose x-axes are aligned with the x-axis of the viewport, regardless of the value of `symbol-placement`."},
|
||
auto: {doc: "When `symbol-placement` is set to `point`, this is equivalent to `viewport`. When `symbol-placement` is set to `line` or `line-center`, this is equivalent to `map`."}
|
||
},
|
||
default: "auto",
|
||
doc: "In combination with `symbol-placement`, determines the rotation behavior of the individual glyphs forming the text.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
},
|
||
"`auto` value": {js: "0.25.0", android: "4.2.0", ios: "3.4.0", macos: "0.3.0"},
|
||
"data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-field": {
|
||
type: "formatted",
|
||
default: "",
|
||
tokens: !0,
|
||
doc: "Value to use for a text label. If a plain `string` is provided, it will be treated as a `formatted` with default/inherited formatting options.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-font": {
|
||
type: "array",
|
||
value: "string",
|
||
default: ["Open Sans Regular", "Arial Unicode MS Regular"],
|
||
doc: "Font stack to use for displaying text.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.43.0", android: "6.0.0", ios: "4.0.0", macos: "0.7.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-size": {
|
||
type: "number",
|
||
default: 16,
|
||
minimum: 0,
|
||
units: "pixels",
|
||
doc: "Font size.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.35.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-max-width": {
|
||
type: "number",
|
||
default: 10,
|
||
minimum: 0,
|
||
units: "ems",
|
||
doc: "The maximum line width for text wrapping.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.40.0", android: "5.2.0", ios: "3.7.0", macos: "0.6.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-line-height": {
|
||
type: "number",
|
||
default: 1.2,
|
||
units: "ems",
|
||
doc: "Text leading value for multi-line text.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-letter-spacing": {
|
||
type: "number",
|
||
default: 0,
|
||
units: "ems",
|
||
doc: "Text tracking amount.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.40.0", android: "5.2.0", ios: "3.7.0", macos: "0.6.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-justify": {
|
||
type: "enum",
|
||
values: {
|
||
auto: {doc: "The text is aligned towards the anchor position."},
|
||
left: {doc: "The text is aligned to the left."},
|
||
center: {doc: "The text is centered."},
|
||
right: {doc: "The text is aligned to the right."}
|
||
},
|
||
default: "center",
|
||
doc: "Text justification options.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
},
|
||
"data-driven styling": {js: "0.39.0", android: "5.2.0", ios: "3.7.0", macos: "0.6.0"},
|
||
auto: {
|
||
js: "next",
|
||
android: "Not yet supported",
|
||
ios: "Not yet supported",
|
||
macos: "Not yet supported"
|
||
}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-radial-offset": {
|
||
type: "number",
|
||
units: "ems",
|
||
default: 0,
|
||
doc: "Radial offset of text, in the direction of the symbol's anchor. Useful in combination with `text-variable-anchor`, which doesn't support the two-dimensional `text-offset`.",
|
||
requires: [{"!": "text-offset"}],
|
||
"property-type": "data-driven",
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]}
|
||
},
|
||
"text-variable-anchor": {
|
||
type: "array",
|
||
value: "enum",
|
||
values: {
|
||
center: {doc: "The center of the text is placed closest to the anchor."},
|
||
left: {doc: "The left side of the text is placed closest to the anchor."},
|
||
right: {doc: "The right side of the text is placed closest to the anchor."},
|
||
top: {doc: "The top of the text is placed closest to the anchor."},
|
||
bottom: {doc: "The bottom of the text is placed closest to the anchor."},
|
||
"top-left": {doc: "The top left corner of the text is placed closest to the anchor."},
|
||
"top-right": {doc: "The top right corner of the text is placed closest to the anchor."},
|
||
"bottom-left": {doc: "The bottom left corner of the text is placed closest to the anchor."},
|
||
"bottom-right": {doc: "The bottom right corner of the text is placed closest to the anchor."}
|
||
},
|
||
requires: [{"!": "text-anchor"}, {"!": "text-offset"}, {"symbol-placement": ["point"]}],
|
||
doc: "To increase the chance of placing high-priority labels on the map, you can provide an array of `text-anchor` locations: the render will attempt to place the label at each location, in order, before moving onto the next label. Use `text-justify: auto` to choose justification based on anchor position. To apply an offset, use the `text-radial-offset` instead of the two-dimensional `text-offset`.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "next",
|
||
android: "Not yet supported",
|
||
ios: "Not yet supported",
|
||
macos: "Not yet supported"
|
||
},
|
||
"data-driven styling": {
|
||
js: "Not yet supported",
|
||
android: "Not yet supported",
|
||
ios: "Not yet supported",
|
||
macos: "Not yet supported"
|
||
}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-anchor": {
|
||
type: "enum",
|
||
requires: ["text-field"],
|
||
values: {
|
||
center: {doc: "The center of the text is placed closest to the anchor."},
|
||
left: {doc: "The left side of the text is placed closest to the anchor."},
|
||
right: {doc: "The right side of the text is placed closest to the anchor."},
|
||
top: {doc: "The top of the text is placed closest to the anchor."},
|
||
bottom: {doc: "The bottom of the text is placed closest to the anchor."},
|
||
"top-left": {doc: "The top left corner of the text is placed closest to the anchor."},
|
||
"top-right": {doc: "The top right corner of the text is placed closest to the anchor."},
|
||
"bottom-left": {doc: "The bottom left corner of the text is placed closest to the anchor."},
|
||
"bottom-right": {doc: "The bottom right corner of the text is placed closest to the anchor."}
|
||
},
|
||
default: "center",
|
||
doc: "Part of the text placed closest to the anchor.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.39.0", android: "5.2.0", ios: "3.7.0", macos: "0.6.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-max-angle": {
|
||
type: "number",
|
||
default: 45,
|
||
units: "degrees",
|
||
doc: "Maximum angle change between adjacent characters.",
|
||
requires: ["text-field", {"symbol-placement": ["line", "line-center"]}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-rotate": {
|
||
type: "number",
|
||
default: 0,
|
||
period: 360,
|
||
units: "degrees",
|
||
doc: "Rotates the text clockwise.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.35.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-padding": {
|
||
type: "number",
|
||
default: 2,
|
||
minimum: 0,
|
||
units: "pixels",
|
||
doc: "Size of the additional area around the text bounding box used for detecting symbol collisions.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-keep-upright": {
|
||
type: "boolean",
|
||
default: !0,
|
||
doc: "If true, the text may be flipped vertically to prevent it from being rendered upside-down.",
|
||
requires: ["text-field", {"text-rotation-alignment": "map"}, {"symbol-placement": ["line", "line-center"]}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-transform": {
|
||
type: "enum",
|
||
values: {
|
||
none: {doc: "The text is not altered."},
|
||
uppercase: {doc: "Forces all letters to be displayed in uppercase."},
|
||
lowercase: {doc: "Forces all letters to be displayed in lowercase."}
|
||
},
|
||
default: "none",
|
||
doc: "Specifies how to capitalize text, similar to the CSS `text-transform` property.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-offset": {
|
||
type: "array",
|
||
doc: "Offset distance of text from its anchor. Positive values indicate right and down, while negative values indicate left and up.",
|
||
value: "number",
|
||
units: "ems",
|
||
length: 2,
|
||
default: [0, 0],
|
||
requires: ["text-field", {"!": "text-radial-offset"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.35.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-allow-overlap": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, the text will be visible even if it collides with other previously drawn symbols.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-ignore-placement": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, other symbols can be visible even if they collide with the text.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-optional": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, icons will display without their corresponding text when the text collides with other symbols and the icon does not.",
|
||
requires: ["text-field", "icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
layout_raster: {
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
layout_hillshade: {
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
filter: {type: "array", value: "*", doc: "A filter selects specific features from a layer."},
|
||
filter_operator: {
|
||
type: "enum",
|
||
values: {
|
||
"==": {doc: '`["==", key, value]` equality: `feature[key] = value`'},
|
||
"!=": {doc: '`["!=", key, value]` inequality: `feature[key] ≠ value`'},
|
||
">": {doc: '`[">", key, value]` greater than: `feature[key] > value`'},
|
||
">=": {doc: '`[">=", key, value]` greater than or equal: `feature[key] ≥ value`'},
|
||
"<": {doc: '`["<", key, value]` less than: `feature[key] < value`'},
|
||
"<=": {doc: '`["<=", key, value]` less than or equal: `feature[key] ≤ value`'},
|
||
in: {doc: '`["in", key, v0, ..., vn]` set inclusion: `feature[key] ∈ {v0, ..., vn}`'},
|
||
"!in": {doc: '`["!in", key, v0, ..., vn]` set exclusion: `feature[key] ∉ {v0, ..., vn}`'},
|
||
all: {doc: '`["all", f0, ..., fn]` logical `AND`: `f0 ∧ ... ∧ fn`'},
|
||
any: {doc: '`["any", f0, ..., fn]` logical `OR`: `f0 ∨ ... ∨ fn`'},
|
||
none: {doc: '`["none", f0, ..., fn]` logical `NOR`: `¬f0 ∧ ... ∧ ¬fn`'},
|
||
has: {doc: '`["has", key]` `feature[key]` exists'},
|
||
"!has": {doc: '`["!has", key]` `feature[key]` does not exist'}
|
||
},
|
||
doc: "The filter operator."
|
||
},
|
||
geometry_type: {
|
||
type: "enum",
|
||
values: {
|
||
Point: {doc: "Filter to point geometries."},
|
||
LineString: {doc: "Filter to line geometries."},
|
||
Polygon: {doc: "Filter to polygon geometries."}
|
||
},
|
||
doc: "The geometry type for the filter to select."
|
||
},
|
||
function: {
|
||
expression: {type: "expression", doc: "An expression."},
|
||
stops: {type: "array", doc: "An array of stops.", value: "function_stop"},
|
||
base: {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
doc: "The exponential base of the interpolation curve. It controls the rate at which the result increases. Higher values make the result increase more towards the high end of the range. With `1` the stops are interpolated linearly."
|
||
},
|
||
property: {
|
||
type: "string",
|
||
doc: "The name of a feature property to use as the function input.",
|
||
default: "$zoom"
|
||
},
|
||
type: {
|
||
type: "enum",
|
||
values: {
|
||
identity: {doc: "Return the input value as the output value."},
|
||
exponential: {doc: "Generate an output by interpolating between stops just less than and just greater than the function input."},
|
||
interval: {doc: "Return the output value of the stop just less than the function input."},
|
||
categorical: {doc: "Return the output value of the stop equal to the function input."}
|
||
},
|
||
doc: "The interpolation strategy to use in function evaluation.",
|
||
default: "exponential"
|
||
},
|
||
colorSpace: {
|
||
type: "enum",
|
||
values: {
|
||
rgb: {doc: "Use the RGB color space to interpolate color values"},
|
||
lab: {doc: "Use the LAB color space to interpolate color values."},
|
||
hcl: {doc: "Use the HCL color space to interpolate color values, interpolating the Hue, Chroma, and Luminance channels individually."}
|
||
},
|
||
doc: "The color space in which colors interpolated. Interpolating colors in perceptual color spaces like LAB and HCL tend to produce color ramps that look more consistent and produce colors that can be differentiated more easily than those interpolated in RGB space.",
|
||
default: "rgb"
|
||
},
|
||
default: {
|
||
type: "*",
|
||
required: !1,
|
||
doc: "A value to serve as a fallback function result when a value isn't otherwise available. It is used in the following circumstances:\n* In categorical functions, when the feature value does not match any of the stop domain values.\n* In property and zoom-and-property functions, when a feature does not contain a value for the specified property.\n* In identity functions, when the feature value is not valid for the style property (for example, if the function is being used for a `circle-color` property but the feature property value is not a string or not a valid color).\n* In interval or exponential property and zoom-and-property functions, when the feature value is not numeric.\nIf no default is provided, the style property's default is used in these circumstances."
|
||
}
|
||
},
|
||
function_stop: {
|
||
type: "array",
|
||
minimum: 0,
|
||
maximum: 22,
|
||
value: ["number", "color"],
|
||
length: 2,
|
||
doc: "Zoom level and value pair."
|
||
},
|
||
expression: {
|
||
type: "array",
|
||
value: "*",
|
||
minimum: 1,
|
||
doc: "An expression defines a function that can be used for data-driven style properties or feature filters."
|
||
},
|
||
expression_name: {
|
||
doc: "", type: "enum", values: {
|
||
let: {
|
||
doc: 'Binds expressions to named variables, which can then be referenced in the result expression using ["var", "variable_name"].',
|
||
group: "Variable binding",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
var: {
|
||
doc: 'References variable bound using "let".',
|
||
group: "Variable binding",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
literal: {
|
||
doc: "Provides a literal array or object value.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
array: {
|
||
doc: "Asserts that the input is an array (optionally with a specific item type and length). If, when the input expression is evaluated, it is not of the asserted type, then this assertion will cause the whole expression to be aborted.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
at: {
|
||
doc: "Retrieves an item from an array.",
|
||
group: "Lookup",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
case: {
|
||
doc: "Selects the first output whose corresponding test condition evaluates to true, or the fallback value otherwise.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
match: {
|
||
doc: 'Selects the output whose label value matches the input value, or the fallback value if no match is found. The input can be any expression (e.g. `["get", "building_type"]`). Each label must be either:\n * a single literal value; or\n * an array of literal values, whose values must be all strings or all numbers (e.g. `[100, 101]` or `["c", "b"]`). The input matches if any of the values in the array matches, similar to the deprecated `"in"` operator.\n\nEach label must be unique. If the input type does not match the type of the labels, the result will be the fallback value.',
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
coalesce: {
|
||
doc: "Evaluates each expression in turn until the first non-null value is obtained, and returns that value.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
step: {
|
||
doc: 'Produces discrete, stepped results by evaluating a piecewise-constant function defined by pairs of input and output values ("stops"). The `input` may be any numeric expression (e.g., `["get", "population"]`). Stop inputs must be numeric literals in strictly ascending order. Returns the output value of the stop just less than the input, or the first input if the input is less than the first stop.',
|
||
group: "Ramps, scales, curves",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.42.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
interpolate: {
|
||
doc: 'Produces continuous, smooth results by interpolating between pairs of input and output values ("stops"). The `input` may be any numeric expression (e.g., `["get", "population"]`). Stop inputs must be numeric literals in strictly ascending order. The output type must be `number`, `array<number>`, or `color`.\n\nInterpolation types:\n- `["linear"]`: interpolates linearly between the pair of stops just less than and just greater than the input.\n- `["exponential", base]`: interpolates exponentially between the stops just less than and just greater than the input. `base` controls the rate at which the output increases: higher values make the output increase more towards the high end of the range. With values close to 1 the output increases linearly.\n- `["cubic-bezier", x1, y1, x2, y2]`: interpolates using the cubic bezier curve defined by the given control points.',
|
||
group: "Ramps, scales, curves",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.42.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"interpolate-hcl": {
|
||
doc: 'Produces continuous, smooth results by interpolating between pairs of input and output values ("stops"). Works like `interpolate`, but the output type must be `color`, and the interpolation is performed in the Hue-Chroma-Luminance color space.',
|
||
group: "Ramps, scales, curves",
|
||
"sdk-support": {"basic functionality": {js: "0.49.0"}}
|
||
},
|
||
"interpolate-lab": {
|
||
doc: 'Produces continuous, smooth results by interpolating between pairs of input and output values ("stops"). Works like `interpolate`, but the output type must be `color`, and the interpolation is performed in the CIELAB color space.',
|
||
group: "Ramps, scales, curves",
|
||
"sdk-support": {"basic functionality": {js: "0.49.0"}}
|
||
},
|
||
ln2: {
|
||
doc: "Returns mathematical constant ln(2).",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
pi: {
|
||
doc: "Returns the mathematical constant pi.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
e: {
|
||
doc: "Returns the mathematical constant e.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
typeof: {
|
||
doc: "Returns a string describing the type of the given value.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
string: {
|
||
doc: "Asserts that the input value is a string. If multiple values are provided, each one is evaluated in order until a string is obtained. If none of the inputs are strings, the expression is an error.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
number: {
|
||
doc: "Asserts that the input value is a number. If multiple values are provided, each one is evaluated in order until a number is obtained. If none of the inputs are numbers, the expression is an error.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
boolean: {
|
||
doc: "Asserts that the input value is a boolean. If multiple values are provided, each one is evaluated in order until a boolean is obtained. If none of the inputs are booleans, the expression is an error.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
object: {
|
||
doc: "Asserts that the input value is an object. If multiple values are provided, each one is evaluated in order until an object is obtained. If none of the inputs are objects, the expression is an error.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
collator: {
|
||
doc: "Returns a `collator` for use in locale-dependent comparison operations. The `case-sensitive` and `diacritic-sensitive` options default to `false`. The `locale` argument specifies the IETF language tag of the locale to use. If none is provided, the default locale is used. If the requested locale is not available, the `collator` will use a system-defined fallback locale. Use `resolved-locale` to test the results of locale fallback behavior.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.5.0",
|
||
ios: "4.2.0",
|
||
macos: "0.9.0"
|
||
}
|
||
}
|
||
},
|
||
format: {
|
||
doc: "Returns `formatted` text containing annotations for use in mixed-format `text-field` entries. If set, the `text-font` argument overrides the font specified by the root layout properties. If set, the `font-scale` argument specifies a scaling factor relative to the `text-size` specified in the root layout properties.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.48.0",
|
||
android: "6.7.0",
|
||
ios: "4.6.0",
|
||
macos: "0.12.0"
|
||
}
|
||
}
|
||
},
|
||
"number-format": {
|
||
doc: "Converts the input number into a string representation using the providing formatting rules. If set, the `locale` argument specifies the locale to use, as a BCP 47 language tag. If set, the `currency` argument specifies an ISO 4217 code to use for currency-style formatting. If set, the `min-fraction-digits` and `max-fraction-digits` arguments specify the minimum and maximum number of fractional digits to include.",
|
||
group: "Types",
|
||
"sdk-support": {"basic functionality": {js: "0.54.0"}}
|
||
},
|
||
"to-string": {
|
||
doc: 'Converts the input value to a string. If the input is `null`, the result is `""`. If the input is a boolean, the result is `"true"` or `"false"`. If the input is a number, it is converted to a string as specified by the ["NumberToString" algorithm](https://tc39.github.io/ecma262/#sec-tostring-applied-to-the-number-type) of the ECMAScript Language Specification. If the input is a color, it is converted to a string of the form `"rgba(r,g,b,a)"`, where `r`, `g`, and `b` are numerals ranging from 0 to 255, and `a` ranges from 0 to 1. Otherwise, the input is converted to a string in the format specified by the [`JSON.stringify`](https://tc39.github.io/ecma262/#sec-json.stringify) function of the ECMAScript Language Specification.',
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"to-number": {
|
||
doc: 'Converts the input value to a number, if possible. If the input is `null` or `false`, the result is 0. If the input is `true`, the result is 1. If the input is a string, it is converted to a number as specified by the ["ToNumber Applied to the String Type" algorithm](https://tc39.github.io/ecma262/#sec-tonumber-applied-to-the-string-type) of the ECMAScript Language Specification. If multiple values are provided, each one is evaluated in order until the first successful conversion is obtained. If none of the inputs can be converted, the expression is an error.',
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"to-boolean": {
|
||
doc: "Converts the input value to a boolean. The result is `false` when then input is an empty string, 0, `false`, `null`, or `NaN`; otherwise it is `true`.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"to-rgba": {
|
||
doc: "Returns a four-element array containing the input color's red, green, blue, and alpha components, in that order.",
|
||
group: "Color",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"to-color": {
|
||
doc: "Converts the input value to a color. If multiple values are provided, each one is evaluated in order until the first successful conversion is obtained. If none of the inputs can be converted, the expression is an error.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
rgb: {
|
||
doc: "Creates a color value from red, green, and blue components, which must range between 0 and 255, and an alpha component of 1. If any component is out of range, the expression is an error.",
|
||
group: "Color",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
rgba: {
|
||
doc: "Creates a color value from red, green, blue components, which must range between 0 and 255, and an alpha component which must range between 0 and 1. If any component is out of range, the expression is an error.",
|
||
group: "Color",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
get: {
|
||
doc: "Retrieves a property value from the current feature's properties, or from another object if a second argument is provided. Returns null if the requested property is missing.",
|
||
group: "Lookup",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
has: {
|
||
doc: "Tests for the presence of an property value in the current feature's properties, or from another object if a second argument is provided.",
|
||
group: "Lookup",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
length: {
|
||
doc: "Gets the length of an array or string.",
|
||
group: "Lookup",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
properties: {
|
||
doc: 'Gets the feature properties object. Note that in some cases, it may be more efficient to use ["get", "property_name"] directly.',
|
||
group: "Feature data",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"feature-state": {
|
||
doc: "Retrieves a property value from the current feature's state. Returns null if the requested property is not present on the feature's state. A feature's state is not part of the GeoJSON or vector tile data, and must be set programmatically on each feature. Note that [\"feature-state\"] can only be used with paint properties that support data-driven styling.",
|
||
group: "Feature data",
|
||
"sdk-support": {"basic functionality": {js: "0.46.0"}}
|
||
},
|
||
"geometry-type": {
|
||
doc: "Gets the feature's geometry type: Point, MultiPoint, LineString, MultiLineString, Polygon, MultiPolygon.",
|
||
group: "Feature data",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
id: {
|
||
doc: "Gets the feature's id, if it has one.",
|
||
group: "Feature data",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
zoom: {
|
||
doc: 'Gets the current zoom level. Note that in style layout and paint properties, ["zoom"] may only appear as the input to a top-level "step" or "interpolate" expression.',
|
||
group: "Zoom",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"heatmap-density": {
|
||
doc: "Gets the kernel density estimation of a pixel in a heatmap layer, which is a relative measure of how many data points are crowded around a particular pixel. Can only be used in the `heatmap-color` property.",
|
||
group: "Heatmap",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"line-progress": {
|
||
doc: "Gets the progress along a gradient line. Can only be used in the `line-gradient` property.",
|
||
group: "Feature data",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.5.0",
|
||
ios: "4.6.0",
|
||
macos: "0.12.0"
|
||
}
|
||
}
|
||
},
|
||
accumulated: {
|
||
doc: "Gets the value of a cluster property accumulated so far. Can only be used in the `clusterProperties` option of a clustered GeoJSON source.",
|
||
group: "Feature data",
|
||
"sdk-support": {"basic functionality": {js: "0.53.0"}}
|
||
},
|
||
"+": {
|
||
doc: "Returns the sum of the inputs.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"*": {
|
||
doc: "Returns the product of the inputs.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"-": {
|
||
doc: "For two inputs, returns the result of subtracting the second input from the first. For a single input, returns the result of subtracting it from 0.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"/": {
|
||
doc: "Returns the result of floating point division of the first input by the second.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"%": {
|
||
doc: "Returns the remainder after integer division of the first input by the second.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"^": {
|
||
doc: "Returns the result of raising the first input to the power specified by the second.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
sqrt: {
|
||
doc: "Returns the square root of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.42.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
log10: {
|
||
doc: "Returns the base-ten logarithm of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
ln: {
|
||
doc: "Returns the natural logarithm of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
log2: {
|
||
doc: "Returns the base-two logarithm of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
sin: {
|
||
doc: "Returns the sine of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
cos: {
|
||
doc: "Returns the cosine of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
tan: {
|
||
doc: "Returns the tangent of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
asin: {
|
||
doc: "Returns the arcsine of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
acos: {
|
||
doc: "Returns the arccosine of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
atan: {
|
||
doc: "Returns the arctangent of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
min: {
|
||
doc: "Returns the minimum value of the inputs.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
max: {
|
||
doc: "Returns the maximum value of the inputs.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
round: {
|
||
doc: 'Rounds the input to the nearest integer. Halfway values are rounded away from zero. For example, `["round", -1.5]` evaluates to -2.',
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
abs: {
|
||
doc: "Returns the absolute value of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
ceil: {
|
||
doc: "Returns the smallest integer that is greater than or equal to the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
floor: {
|
||
doc: "Returns the largest integer that is less than or equal to the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"==": {
|
||
doc: "Returns `true` if the input values are equal, `false` otherwise. The comparison is strictly typed: values of different runtime types are always considered unequal. Cases where the types are known to be different at parse time are considered invalid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, collator: {js: "0.45.0", android: "6.5.0", ios: "4.2.0", macos: "0.9.0"}
|
||
}
|
||
},
|
||
"!=": {
|
||
doc: "Returns `true` if the input values are not equal, `false` otherwise. The comparison is strictly typed: values of different runtime types are always considered unequal. Cases where the types are known to be different at parse time are considered invalid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, collator: {js: "0.45.0", android: "6.5.0", ios: "4.2.0", macos: "0.9.0"}
|
||
}
|
||
},
|
||
">": {
|
||
doc: "Returns `true` if the first input is strictly greater than the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, collator: {js: "0.45.0", android: "6.5.0", ios: "4.2.0", macos: "0.9.0"}
|
||
}
|
||
},
|
||
"<": {
|
||
doc: "Returns `true` if the first input is strictly less than the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, collator: {js: "0.45.0", android: "6.5.0", ios: "4.2.0", macos: "0.9.0"}
|
||
}
|
||
},
|
||
">=": {
|
||
doc: "Returns `true` if the first input is greater than or equal to the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, collator: {js: "0.45.0", android: "6.5.0", ios: "4.2.0", macos: "0.9.0"}
|
||
}
|
||
},
|
||
"<=": {
|
||
doc: "Returns `true` if the first input is less than or equal to the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, collator: {js: "0.45.0", android: "6.5.0", ios: "4.2.0", macos: "0.9.0"}
|
||
}
|
||
},
|
||
all: {
|
||
doc: "Returns `true` if all the inputs are `true`, `false` otherwise. The inputs are evaluated in order, and evaluation is short-circuiting: once an input expression evaluates to `false`, the result is `false` and no further input expressions are evaluated.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
any: {
|
||
doc: "Returns `true` if any of the inputs are `true`, `false` otherwise. The inputs are evaluated in order, and evaluation is short-circuiting: once an input expression evaluates to `true`, the result is `true` and no further input expressions are evaluated.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"!": {
|
||
doc: "Logical negation. Returns `true` if the input is `false`, and `false` if the input is `true`.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"is-supported-script": {
|
||
doc: "Returns `true` if the input string is expected to render legibly. Returns `false` if the input string contains sections that cannot be rendered without potential loss of meaning (e.g. Indic scripts that require complex text shaping, or right-to-left scripts if the the `mapbox-gl-rtl-text` plugin is not in use in Mapbox GL JS).",
|
||
group: "String"
|
||
},
|
||
upcase: {
|
||
doc: "Returns the input string converted to uppercase. Follows the Unicode Default Case Conversion algorithm and the locale-insensitive case mappings in the Unicode Character Database.",
|
||
group: "String",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
downcase: {
|
||
doc: "Returns the input string converted to lowercase. Follows the Unicode Default Case Conversion algorithm and the locale-insensitive case mappings in the Unicode Character Database.",
|
||
group: "String",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
concat: {
|
||
doc: "Returns a `string` consisting of the concatenation of the inputs. Each input is converted to a string as if by `to-string`.",
|
||
group: "String",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"resolved-locale": {
|
||
doc: "Returns the IETF language tag of the locale being used by the provided `collator`. This can be used to determine the default system locale, or to determine if a requested locale was successfully loaded.",
|
||
group: "String",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.5.0",
|
||
ios: "4.2.0",
|
||
macos: "0.9.0"
|
||
}
|
||
}
|
||
}
|
||
}
|
||
},
|
||
light: {
|
||
anchor: {
|
||
type: "enum",
|
||
default: "viewport",
|
||
values: {
|
||
map: {doc: "The position of the light source is aligned to the rotation of the map."},
|
||
viewport: {doc: "The position of the light source is aligned to the rotation of the viewport."}
|
||
},
|
||
"property-type": "data-constant",
|
||
transition: !1,
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
doc: "Whether extruded geometries are lit relative to the map or viewport.",
|
||
example: "map",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}
|
||
}
|
||
},
|
||
position: {
|
||
type: "array",
|
||
default: [1.15, 210, 30],
|
||
length: 3,
|
||
value: "number",
|
||
"property-type": "data-constant",
|
||
transition: !0,
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
doc: "Position of the light source relative to lit (extruded) geometries, in [r radial coordinate, a azimuthal angle, p polar angle] where r indicates the distance from the center of the base of an object to its light, a indicates the position of the light relative to 0° (0° when `light.anchor` is set to `viewport` corresponds to the top of the viewport, or 0° when `light.anchor` is set to `map` corresponds to due north, and degrees proceed clockwise), and p indicates the height of the light (from 0°, directly above, to 180°, directly below).",
|
||
example: [1.5, 90, 80],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}
|
||
}
|
||
},
|
||
color: {
|
||
type: "color",
|
||
"property-type": "data-constant",
|
||
default: "#ffffff",
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
transition: !0,
|
||
doc: "Color tint for lighting extruded geometries.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}
|
||
}
|
||
},
|
||
intensity: {
|
||
type: "number",
|
||
"property-type": "data-constant",
|
||
default: .5,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
transition: !0,
|
||
doc: "Intensity of lighting (on a scale from 0 to 1). Higher numbers will present as more extreme contrast.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}
|
||
}
|
||
}
|
||
},
|
||
paint: ["paint_fill", "paint_line", "paint_circle", "paint_heatmap", "paint_fill-extrusion", "paint_symbol", "paint_raster", "paint_hillshade", "paint_background"],
|
||
paint_fill: {
|
||
"fill-antialias": {
|
||
type: "boolean",
|
||
default: !0,
|
||
doc: "Whether or not the fill should be antialiased.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"fill-opacity": {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
doc: "The opacity of the entire fill layer. In contrast to the `fill-color`, this value will also affect the 1px stroke around the fill, if the stroke is used.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.21.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"fill-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
doc: "The color of the filled part of this layer. This color can be specified as `rgba` with an alpha component and the color's opacity will not affect the opacity of the 1px stroke, if it is used.",
|
||
transition: !0,
|
||
requires: [{"!": "fill-pattern"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.19.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"fill-outline-color": {
|
||
type: "color",
|
||
doc: "The outline color of the fill. Matches the value of `fill-color` if unspecified.",
|
||
transition: !0,
|
||
requires: [{"!": "fill-pattern"}, {"fill-antialias": !0}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.19.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"fill-translate": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 2,
|
||
default: [0, 0],
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "The geometry's offset. Values are [x, y] where negatives indicate left and up, respectively.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"fill-translate-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The fill is translated relative to the map."},
|
||
viewport: {doc: "The fill is translated relative to the viewport."}
|
||
},
|
||
doc: "Controls the frame of reference for `fill-translate`.",
|
||
default: "map",
|
||
requires: ["fill-translate"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"fill-pattern": {
|
||
type: "string",
|
||
transition: !0,
|
||
doc: "Name of image in sprite to use for drawing image fills. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
},
|
||
"data-driven styling": {js: "0.49.0", android: "6.5.0", macos: "0.11.0", ios: "4.4.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "cross-faded-data-driven"
|
||
}
|
||
},
|
||
"paint_fill-extrusion": {
|
||
"fill-extrusion-opacity": {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
doc: "The opacity of the entire fill extrusion layer. This is rendered on a per-layer, not per-feature, basis, and data-driven styling is not available.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"fill-extrusion-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
doc: "The base color of the extruded fill. The extrusion's surfaces will be shaded differently based on this color in combination with the root `light` settings. If this color is specified as `rgba` with an alpha component, the alpha component will be ignored; use `fill-extrusion-opacity` to set layer opacity.",
|
||
transition: !0,
|
||
requires: [{"!": "fill-extrusion-pattern"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}, "data-driven styling": {js: "0.27.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"fill-extrusion-translate": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 2,
|
||
default: [0, 0],
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "The geometry's offset. Values are [x, y] where negatives indicate left and up (on the flat plane), respectively.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"fill-extrusion-translate-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The fill extrusion is translated relative to the map."},
|
||
viewport: {doc: "The fill extrusion is translated relative to the viewport."}
|
||
},
|
||
doc: "Controls the frame of reference for `fill-extrusion-translate`.",
|
||
default: "map",
|
||
requires: ["fill-extrusion-translate"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"fill-extrusion-pattern": {
|
||
type: "string",
|
||
transition: !0,
|
||
doc: "Name of image in sprite to use for drawing images on extruded fills. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
},
|
||
"data-driven styling": {js: "0.49.0", android: "6.5.0", macos: "0.11.0", ios: "4.4.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "cross-faded-data-driven"
|
||
},
|
||
"fill-extrusion-height": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
units: "meters",
|
||
doc: "The height with which to extrude this layer.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}, "data-driven styling": {js: "0.27.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"fill-extrusion-base": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
units: "meters",
|
||
doc: "The height with which to extrude the base of this layer. Must be less than or equal to `fill-extrusion-height`.",
|
||
transition: !0,
|
||
requires: ["fill-extrusion-height"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}, "data-driven styling": {js: "0.27.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"fill-extrusion-vertical-gradient": {
|
||
type: "boolean",
|
||
default: !0,
|
||
doc: "Whether to apply a vertical gradient to the sides of a fill-extrusion layer. If true, sides will be shaded slightly darker farther down.",
|
||
transition: !1,
|
||
"sdk-support": {"basic functionality": {js: "0.50.0", ios: "4.7.0", macos: "0.13.0"}},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
}
|
||
},
|
||
paint_line: {
|
||
"line-opacity": {
|
||
type: "number",
|
||
doc: "The opacity at which the line will be drawn.",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"line-color": {
|
||
type: "color",
|
||
doc: "The color with which the line will be drawn.",
|
||
default: "#000000",
|
||
transition: !0,
|
||
requires: [{"!": "line-pattern"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.23.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"line-translate": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 2,
|
||
default: [0, 0],
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "The geometry's offset. Values are [x, y] where negatives indicate left and up, respectively.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"line-translate-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The line is translated relative to the map."},
|
||
viewport: {doc: "The line is translated relative to the viewport."}
|
||
},
|
||
doc: "Controls the frame of reference for `line-translate`.",
|
||
default: "map",
|
||
requires: ["line-translate"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"line-width": {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Stroke thickness.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.39.0", android: "5.2.0", ios: "3.7.0", macos: "0.6.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"line-gap-width": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
doc: "Draws a line casing outside of a line's actual path. Value indicates the width of the inner gap.",
|
||
transition: !0,
|
||
units: "pixels",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"line-offset": {
|
||
type: "number",
|
||
default: 0,
|
||
doc: "The line's offset. For linear features, a positive value offsets the line to the right, relative to the direction of the line, and a negative value to the left. For polygon features, a positive value results in an inset, and a negative value results in an outset.",
|
||
transition: !0,
|
||
units: "pixels",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.12.1",
|
||
android: "3.0.0",
|
||
ios: "3.1.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"line-blur": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Blur applied to the line, in pixels.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"line-dasharray": {
|
||
type: "array",
|
||
value: "number",
|
||
doc: "Specifies the lengths of the alternating dashes and gaps that form the dash pattern. The lengths are later scaled by the line width. To convert a dash length to pixels, multiply the length by the current line width. Note that GeoJSON sources with `lineMetrics: true` specified won't render dashed lines to the expected scale. Also note that zoom-dependent expressions will be evaluated only at integer zoom levels.",
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "line widths",
|
||
requires: [{"!": "line-pattern"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "cross-faded"
|
||
},
|
||
"line-pattern": {
|
||
type: "string",
|
||
transition: !0,
|
||
doc: "Name of image in sprite to use for drawing image lines. For seamless patterns, image width must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
},
|
||
"data-driven styling": {js: "0.49.0", android: "6.5.0", macos: "0.11.0", ios: "4.4.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "cross-faded-data-driven"
|
||
},
|
||
"line-gradient": {
|
||
type: "color",
|
||
doc: 'Defines a gradient with which to color a line feature. Can only be used with GeoJSON sources that specify `"lineMetrics": true`.',
|
||
transition: !1,
|
||
requires: [{"!": "line-dasharray"}, {"!": "line-pattern"}, {
|
||
source: "geojson",
|
||
has: {lineMetrics: !0}
|
||
}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.5.0",
|
||
ios: "4.4.0",
|
||
macos: "0.11.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["line-progress"]},
|
||
"property-type": "color-ramp"
|
||
}
|
||
},
|
||
paint_circle: {
|
||
"circle-radius": {
|
||
type: "number",
|
||
default: 5,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Circle radius.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.18.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"circle-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
doc: "The fill color of the circle.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.18.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"circle-blur": {
|
||
type: "number",
|
||
default: 0,
|
||
doc: "Amount to blur the circle. 1 blurs the circle such that only the centerpoint is full opacity.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.20.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"circle-opacity": {
|
||
type: "number",
|
||
doc: "The opacity at which the circle will be drawn.",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.20.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"circle-translate": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 2,
|
||
default: [0, 0],
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "The geometry's offset. Values are [x, y] where negatives indicate left and up, respectively.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"circle-translate-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The circle is translated relative to the map."},
|
||
viewport: {doc: "The circle is translated relative to the viewport."}
|
||
},
|
||
doc: "Controls the frame of reference for `circle-translate`.",
|
||
default: "map",
|
||
requires: ["circle-translate"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"circle-pitch-scale": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "Circles are scaled according to their apparent distance to the camera."},
|
||
viewport: {doc: "Circles are not scaled."}
|
||
},
|
||
default: "map",
|
||
doc: "Controls the scaling behavior of the circle when the map is pitched.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.21.0",
|
||
android: "4.2.0",
|
||
ios: "3.4.0",
|
||
macos: "0.2.1"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"circle-pitch-alignment": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The circle is aligned to the plane of the map."},
|
||
viewport: {doc: "The circle is aligned to the plane of the viewport."}
|
||
},
|
||
default: "viewport",
|
||
doc: "Orientation of circle when map is pitched.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.39.0",
|
||
android: "5.2.0",
|
||
ios: "3.7.0",
|
||
macos: "0.6.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"circle-stroke-width": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "The width of the circle's stroke. Strokes are placed outside of the `circle-radius`.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.29.0",
|
||
android: "5.0.0",
|
||
ios: "3.5.0",
|
||
macos: "0.4.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"circle-stroke-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
doc: "The stroke color of the circle.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.29.0",
|
||
android: "5.0.0",
|
||
ios: "3.5.0",
|
||
macos: "0.4.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"circle-stroke-opacity": {
|
||
type: "number",
|
||
doc: "The opacity of the circle's stroke.",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.29.0",
|
||
android: "5.0.0",
|
||
ios: "3.5.0",
|
||
macos: "0.4.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
}
|
||
},
|
||
paint_heatmap: {
|
||
"heatmap-radius": {
|
||
type: "number",
|
||
default: 30,
|
||
minimum: 1,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Radius of influence of one heatmap point in pixels. Increasing the value makes the heatmap smoother, but less detailed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {js: "0.43.0", android: "6.0.0", ios: "4.0.0", macos: "0.7.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"heatmap-weight": {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
transition: !1,
|
||
doc: "A measure of how much an individual point contributes to the heatmap. A value of 10 would be equivalent to having 10 points of weight 1 in the same spot. Especially useful when combined with clustering.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {js: "0.41.0", android: "6.0.0", ios: "4.0.0", macos: "0.7.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"heatmap-intensity": {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
transition: !0,
|
||
doc: "Similar to `heatmap-weight` but controls the intensity of the heatmap globally. Primarily used for adjusting the heatmap based on zoom level.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"heatmap-color": {
|
||
type: "color",
|
||
default: ["interpolate", ["linear"], ["heatmap-density"], 0, "rgba(0, 0, 255, 0)", .1, "royalblue", .3, "cyan", .5, "lime", .7, "yellow", 1, "red"],
|
||
doc: 'Defines the color of each pixel based on its density value in a heatmap. Should be an expression that uses `["heatmap-density"]` as input.',
|
||
transition: !1,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["heatmap-density"]},
|
||
"property-type": "color-ramp"
|
||
},
|
||
"heatmap-opacity": {
|
||
type: "number",
|
||
doc: "The global opacity at which the heatmap layer will be drawn.",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
}
|
||
},
|
||
paint_symbol: {
|
||
"icon-opacity": {
|
||
doc: "The opacity at which the icon will be drawn.",
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
transition: !0,
|
||
doc: "The color of the icon. This can only be used with sdf icons.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-halo-color": {
|
||
type: "color",
|
||
default: "rgba(0, 0, 0, 0)",
|
||
transition: !0,
|
||
doc: "The color of the icon's halo. Icon halos can only be used with SDF icons.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-halo-width": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Distance of halo to the icon outline.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-halo-blur": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Fade out the halo towards the outside.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-translate": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 2,
|
||
default: [0, 0],
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Distance that the icon's anchor is moved from its original placement. Positive values indicate right and down, while negative values indicate left and up.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-translate-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "Icons are translated relative to the map."},
|
||
viewport: {doc: "Icons are translated relative to the viewport."}
|
||
},
|
||
doc: "Controls the frame of reference for `icon-translate`.",
|
||
default: "map",
|
||
requires: ["icon-image", "icon-translate"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-opacity": {
|
||
type: "number",
|
||
doc: "The opacity at which the text will be drawn.",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-color": {
|
||
type: "color",
|
||
doc: "The color with which the text will be drawn.",
|
||
default: "#000000",
|
||
transition: !0,
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-halo-color": {
|
||
type: "color",
|
||
default: "rgba(0, 0, 0, 0)",
|
||
transition: !0,
|
||
doc: "The color of the text's halo, which helps it stand out from backgrounds.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-halo-width": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Distance of halo to the font outline. Max text halo width is 1/4 of the font-size.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-halo-blur": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "The halo's fadeout distance towards the outside.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-translate": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 2,
|
||
default: [0, 0],
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Distance that the text's anchor is moved from its original placement. Positive values indicate right and down, while negative values indicate left and up.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-translate-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The text is translated relative to the map."},
|
||
viewport: {doc: "The text is translated relative to the viewport."}
|
||
},
|
||
doc: "Controls the frame of reference for `text-translate`.",
|
||
default: "map",
|
||
requires: ["text-field", "text-translate"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
}
|
||
},
|
||
paint_raster: {
|
||
"raster-opacity": {
|
||
type: "number",
|
||
doc: "The opacity at which the image will be drawn.",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"raster-hue-rotate": {
|
||
type: "number",
|
||
default: 0,
|
||
period: 360,
|
||
transition: !0,
|
||
units: "degrees",
|
||
doc: "Rotates hues around the color wheel.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"raster-brightness-min": {
|
||
type: "number",
|
||
doc: "Increase or reduce the brightness of the image. The value is the minimum brightness.",
|
||
default: 0,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"raster-brightness-max": {
|
||
type: "number",
|
||
doc: "Increase or reduce the brightness of the image. The value is the maximum brightness.",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"raster-saturation": {
|
||
type: "number",
|
||
doc: "Increase or reduce the saturation of the image.",
|
||
default: 0,
|
||
minimum: -1,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"raster-contrast": {
|
||
type: "number",
|
||
doc: "Increase or reduce the contrast of the image.",
|
||
default: 0,
|
||
minimum: -1,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"raster-resampling": {
|
||
type: "enum",
|
||
doc: "The resampling/interpolation method to use for overscaling, also known as texture magnification filter",
|
||
values: {
|
||
linear: {doc: "(Bi)linear filtering interpolates pixel values using the weighted average of the four closest original source pixels creating a smooth but blurry look when overscaled"},
|
||
nearest: {doc: "Nearest neighbor filtering interpolates pixel values using the nearest original source pixel creating a sharp but pixelated look when overscaled"}
|
||
},
|
||
default: "linear",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.47.0",
|
||
android: "6.3.0",
|
||
ios: "4.2.0",
|
||
macos: "0.9.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"raster-fade-duration": {
|
||
type: "number",
|
||
default: 300,
|
||
minimum: 0,
|
||
transition: !1,
|
||
units: "milliseconds",
|
||
doc: "Fade duration when a new tile is added.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
}
|
||
},
|
||
paint_hillshade: {
|
||
"hillshade-illumination-direction": {
|
||
type: "number",
|
||
default: 335,
|
||
minimum: 0,
|
||
maximum: 359,
|
||
doc: "The direction of the light source used to generate the hillshading with 0 as the top of the viewport if `hillshade-illumination-anchor` is set to `viewport` and due north if `hillshade-illumination-anchor` is set to `map`.",
|
||
transition: !1,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"hillshade-illumination-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The hillshade illumination is relative to the north direction."},
|
||
viewport: {doc: "The hillshade illumination is relative to the top of the viewport."}
|
||
},
|
||
default: "viewport",
|
||
doc: "Direction of light source when map is rotated.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"hillshade-exaggeration": {
|
||
type: "number",
|
||
doc: "Intensity of the hillshade",
|
||
default: .5,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"hillshade-shadow-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
doc: "The shading color of areas that face away from the light source.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"hillshade-highlight-color": {
|
||
type: "color",
|
||
default: "#FFFFFF",
|
||
doc: "The shading color of areas that faces towards the light source.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"hillshade-accent-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
doc: "The shading color used to accentuate rugged terrain like sharp cliffs and gorges.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
}
|
||
},
|
||
paint_background: {
|
||
"background-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
doc: "The color with which the background will be drawn.",
|
||
transition: !0,
|
||
requires: [{"!": "background-pattern"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"background-pattern": {
|
||
type: "string",
|
||
transition: !0,
|
||
doc: "Name of image in sprite to use for drawing an image background. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "cross-faded"
|
||
},
|
||
"background-opacity": {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
doc: "The opacity at which the background will be drawn.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
}
|
||
},
|
||
transition: {
|
||
duration: {
|
||
type: "number",
|
||
default: 300,
|
||
minimum: 0,
|
||
units: "milliseconds",
|
||
doc: "Time allotted for transitions to complete."
|
||
},
|
||
delay: {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
units: "milliseconds",
|
||
doc: "Length of time before a transition begins."
|
||
}
|
||
},
|
||
"property-type": {
|
||
"data-driven": {
|
||
type: "property-type",
|
||
doc: "Property is interpolable and can be represented using a property expression."
|
||
},
|
||
"cross-faded": {
|
||
type: "property-type",
|
||
doc: "Property is non-interpolable; rather, its values will be cross-faded to smoothly transition between integer zooms."
|
||
},
|
||
"cross-faded-data-driven": {
|
||
type: "property-type",
|
||
doc: "Property is non-interpolable; rather, its values will be cross-faded to smoothly transition between integer zooms. It can be represented using a property expression."
|
||
},
|
||
"color-ramp": {
|
||
type: "property-type",
|
||
doc: "Property should be specified using a color ramp from which the output color can be sampled based on a property calculation."
|
||
},
|
||
"data-constant": {
|
||
type: "property-type",
|
||
doc: "Property is interpolable but cannot be represented using a property expression."
|
||
},
|
||
constant: {
|
||
type: "property-type",
|
||
doc: "Property is constant across all zoom levels and property values."
|
||
}
|
||
}
|
||
}, o = /("(?:[^\\"]|\\.)*")|[:,]/g, n = function (t, e) {
|
||
var i, r, n;
|
||
return e = e || {}, i = JSON.stringify([1], void 0, void 0 === e.indent ? 2 : e.indent).slice(2, -3), r = "" === i ? 1 / 0 : void 0 === e.maxLength ? 80 : e.maxLength, n = e.replacer, function t(e, s, a) {
|
||
var l, h, u, c, p, d, f, g, m, y, v, _;
|
||
if (e && "function" == typeof e.toJSON && (e = e.toJSON()), void 0 === (v = JSON.stringify(e, n))) return v;
|
||
if (f = r - s.length - a, v.length <= f && (m = v.replace(o, function (t, e) {
|
||
return e || t + " "
|
||
})).length <= f) return m;
|
||
if (null != n && (e = JSON.parse(v), n = void 0), "object" == typeof e && null !== e) {
|
||
if (g = s + i, u = [], h = 0, Array.isArray(e)) for (y = "[", l = "]", f = e.length; h < f; h++) u.push(t(e[h], g, h === f - 1 ? 0 : 1) || "null"); else for (y = "{", l = "}", f = (d = Object.keys(e)).length; h < f; h++) c = d[h], p = JSON.stringify(c) + ": ", void 0 !== (_ = t(e[c], g, p.length + (h === f - 1 ? 0 : 1))) && u.push(p + _);
|
||
if (u.length > 0) return [y, i + u.join(",\n" + g), l].join("\n" + s)
|
||
}
|
||
return v
|
||
}(t, "", 0)
|
||
};
|
||
|
||
function s(t, e) {
|
||
var i = {};
|
||
for (var r in e) void 0 !== t[r] && (i[r] = t[r]);
|
||
for (var o in t) void 0 === i[o] && (i[o] = t[o]);
|
||
return i
|
||
}
|
||
|
||
var a = "undefined" != typeof globalThis ? globalThis : "undefined" != typeof window ? window : void 0 !== t ? t : "undefined" != typeof self ? self : {};
|
||
|
||
function l(t, e) {
|
||
return t(e = {exports: {}}, e.exports), e.exports
|
||
}
|
||
|
||
var h = l(function (t, e) {
|
||
!function (i) {
|
||
var r = e && !e.nodeType && e, o = t && !t.nodeType && t, n = "object" == typeof a && a;
|
||
n.global !== n && n.window !== n && n.self !== n || (i = n);
|
||
var s, l, h = 2147483647, u = 36, c = 1, p = 26, d = 38, f = 700, g = 72, m = 128, y = "-",
|
||
v = /^xn--/, _ = /[^\x20-\x7E]/, x = /[\x2E\u3002\uFF0E\uFF61]/g, w = {
|
||
overflow: "Overflow: input needs wider integers to process",
|
||
"not-basic": "Illegal input >= 0x80 (not a basic code point)",
|
||
"invalid-input": "Invalid input"
|
||
}, b = u - c, C = Math.floor, S = String.fromCharCode;
|
||
|
||
function E(t) {
|
||
throw RangeError(w[t])
|
||
}
|
||
|
||
function T(t, e) {
|
||
for (var i = t.length, r = []; i--;) r[i] = e(t[i]);
|
||
return r
|
||
}
|
||
|
||
function R(t, e) {
|
||
var i = t.split("@"), r = "";
|
||
return i.length > 1 && (r = i[0] + "@", t = i[1]), r + T((t = t.replace(x, ".")).split("."), e).join(".")
|
||
}
|
||
|
||
function P(t) {
|
||
for (var e, i, r = [], o = 0, n = t.length; o < n;) (e = t.charCodeAt(o++)) >= 55296 && e <= 56319 && o < n ? 56320 == (64512 & (i = t.charCodeAt(o++))) ? r.push(((1023 & e) << 10) + (1023 & i) + 65536) : (r.push(e), o--) : r.push(e);
|
||
return r
|
||
}
|
||
|
||
function L(t) {
|
||
return T(t, function (t) {
|
||
var e = "";
|
||
return t > 65535 && (e += S((t -= 65536) >>> 10 & 1023 | 55296), t = 56320 | 1023 & t), e += S(t)
|
||
}).join("")
|
||
}
|
||
|
||
function I(t, e) {
|
||
return t + 22 + 75 * (t < 26) - ((0 != e) << 5)
|
||
}
|
||
|
||
function O(t, e, i) {
|
||
var r = 0;
|
||
for (t = i ? C(t / f) : t >> 1, t += C(t / e); t > b * p >> 1; r += u) t = C(t / b);
|
||
return C(r + (b + 1) * t / (t + d))
|
||
}
|
||
|
||
function M(t) {
|
||
var e, i, r, o, n, s, a, l, d, f, v, _ = [], x = t.length, w = 0, b = m, S = g;
|
||
for ((i = t.lastIndexOf(y)) < 0 && (i = 0), r = 0; r < i; ++r) t.charCodeAt(r) >= 128 && E("not-basic"), _.push(t.charCodeAt(r));
|
||
for (o = i > 0 ? i + 1 : 0; o < x;) {
|
||
for (n = w, s = 1, a = u; o >= x && E("invalid-input"), ((l = (v = t.charCodeAt(o++)) - 48 < 10 ? v - 22 : v - 65 < 26 ? v - 65 : v - 97 < 26 ? v - 97 : u) >= u || l > C((h - w) / s)) && E("overflow"), w += l * s, !(l < (d = a <= S ? c : a >= S + p ? p : a - S)); a += u) s > C(h / (f = u - d)) && E("overflow"), s *= f;
|
||
S = O(w - n, e = _.length + 1, 0 == n), C(w / e) > h - b && E("overflow"), b += C(w / e), w %= e, _.splice(w++, 0, b)
|
||
}
|
||
return L(_)
|
||
}
|
||
|
||
function A(t) {
|
||
var e, i, r, o, n, s, a, l, d, f, v, _, x, w, b, T = [];
|
||
for (_ = (t = P(t)).length, e = m, i = 0, n = g, s = 0; s < _; ++s) (v = t[s]) < 128 && T.push(S(v));
|
||
for (r = o = T.length, o && T.push(y); r < _;) {
|
||
for (a = h, s = 0; s < _; ++s) (v = t[s]) >= e && v < a && (a = v);
|
||
for (a - e > C((h - i) / (x = r + 1)) && E("overflow"), i += (a - e) * x, e = a, s = 0; s < _; ++s) if ((v = t[s]) < e && ++i > h && E("overflow"), v == e) {
|
||
for (l = i, d = u; !(l < (f = d <= n ? c : d >= n + p ? p : d - n)); d += u) b = l - f, w = u - f, T.push(S(I(f + b % w, 0))), l = C(b / w);
|
||
T.push(S(I(l, 0))), n = O(i, x, r == o), i = 0, ++r
|
||
}
|
||
++i, ++e
|
||
}
|
||
return T.join("")
|
||
}
|
||
|
||
if (s = {
|
||
version: "1.3.2",
|
||
ucs2: {decode: P, encode: L},
|
||
decode: M,
|
||
encode: A,
|
||
toASCII: function (t) {
|
||
return R(t, function (t) {
|
||
return _.test(t) ? "xn--" + A(t) : t
|
||
})
|
||
},
|
||
toUnicode: function (t) {
|
||
return R(t, function (t) {
|
||
return v.test(t) ? M(t.slice(4).toLowerCase()) : t
|
||
})
|
||
}
|
||
}, r && o) if (t.exports == r) o.exports = s; else for (l in s) s.hasOwnProperty(l) && (r[l] = s[l]); else i.punycode = s
|
||
}(a)
|
||
}), u = {
|
||
isString: function (t) {
|
||
return "string" == typeof t
|
||
}, isObject: function (t) {
|
||
return "object" == typeof t && null !== t
|
||
}, isNull: function (t) {
|
||
return null === t
|
||
}, isNullOrUndefined: function (t) {
|
||
return null == t
|
||
}
|
||
};
|
||
|
||
function c(t, e) {
|
||
return Object.prototype.hasOwnProperty.call(t, e)
|
||
}
|
||
|
||
var p = function (t, e, i, r) {
|
||
e = e || "&", i = i || "=";
|
||
var o = {};
|
||
if ("string" != typeof t || 0 === t.length) return o;
|
||
var n = /\+/g;
|
||
t = t.split(e);
|
||
var s = 1e3;
|
||
r && "number" == typeof r.maxKeys && (s = r.maxKeys);
|
||
var a = t.length;
|
||
s > 0 && a > s && (a = s);
|
||
for (var l = 0; l < a; ++l) {
|
||
var h, u, p, d, f = t[l].replace(n, "%20"), g = f.indexOf(i);
|
||
g >= 0 ? (h = f.substr(0, g), u = f.substr(g + 1)) : (h = f, u = ""), p = decodeURIComponent(h), d = decodeURIComponent(u), c(o, p) ? Array.isArray(o[p]) ? o[p].push(d) : o[p] = [o[p], d] : o[p] = d
|
||
}
|
||
return o
|
||
}, d = function (t) {
|
||
switch (typeof t) {
|
||
case"string":
|
||
return t;
|
||
case"boolean":
|
||
return t ? "true" : "false";
|
||
case"number":
|
||
return isFinite(t) ? t : "";
|
||
default:
|
||
return ""
|
||
}
|
||
}, f = function (t, e, i, r) {
|
||
return e = e || "&", i = i || "=", null === t && (t = void 0), "object" == typeof t ? Object.keys(t).map(function (r) {
|
||
var o = encodeURIComponent(d(r)) + i;
|
||
return Array.isArray(t[r]) ? t[r].map(function (t) {
|
||
return o + encodeURIComponent(d(t))
|
||
}).join(e) : o + encodeURIComponent(d(t[r]))
|
||
}).join(e) : r ? encodeURIComponent(d(r)) + i + encodeURIComponent(d(t)) : ""
|
||
}, g = l(function (t, e) {
|
||
e.decode = e.parse = p, e.encode = e.stringify = f
|
||
}), m = (g.decode, g.parse, g.encode, g.stringify, k), y = function (t, e) {
|
||
return k(t, !1, !0).resolve(e)
|
||
}, v = function (t, e) {
|
||
if (!t) return e;
|
||
return k(t, !1, !0).resolveObject(e)
|
||
}, _ = function (t) {
|
||
u.isString(t) && (t = k(t));
|
||
if (!(t instanceof w)) return w.prototype.format.call(t);
|
||
return t.format()
|
||
}, x = w;
|
||
|
||
function w() {
|
||
this.protocol = null, this.slashes = null, this.auth = null, this.host = null, this.port = null, this.hostname = null, this.hash = null, this.search = null, this.query = null, this.pathname = null, this.path = null, this.href = null
|
||
}
|
||
|
||
var b = /^([a-z0-9.+-]+:)/i, C = /:[0-9]*$/, S = /^(\/\/?(?!\/)[^\?\s]*)(\?[^\s]*)?$/,
|
||
E = ["{", "}", "|", "\\", "^", "`"].concat(["<", ">", '"', "`", " ", "\r", "\n", "\t"]),
|
||
T = ["'"].concat(E), R = ["%", "/", "?", ";", "#"].concat(T), P = ["/", "?", "#"],
|
||
L = /^[+a-z0-9A-Z_-]{0,63}$/, I = /^([+a-z0-9A-Z_-]{0,63})(.*)$/,
|
||
O = {javascript: !0, "javascript:": !0}, M = {javascript: !0, "javascript:": !0}, A = {
|
||
http: !0,
|
||
https: !0,
|
||
ftp: !0,
|
||
gopher: !0,
|
||
file: !0,
|
||
"http:": !0,
|
||
"https:": !0,
|
||
"ftp:": !0,
|
||
"gopher:": !0,
|
||
"file:": !0
|
||
};
|
||
|
||
function k(t, e, i) {
|
||
if (t && u.isObject(t) && t instanceof w) return t;
|
||
var r = new w;
|
||
return r.parse(t, e, i), r
|
||
}
|
||
|
||
w.prototype.parse = function (t, e, i) {
|
||
if (!u.isString(t)) throw new TypeError("Parameter 'url' must be a string, not " + typeof t);
|
||
var r = t.indexOf("?"), o = -1 !== r && r < t.indexOf("#") ? "?" : "#", n = t.split(o);
|
||
n[0] = n[0].replace(/\\/g, "/");
|
||
var s = t = n.join(o);
|
||
if (s = s.trim(), !i && 1 === t.split("#").length) {
|
||
var a = S.exec(s);
|
||
if (a) return this.path = s, this.href = s, this.pathname = a[1], a[2] ? (this.search = a[2], this.query = e ? g.parse(this.search.substr(1)) : this.search.substr(1)) : e && (this.search = "", this.query = {}), this
|
||
}
|
||
var l = b.exec(s);
|
||
if (l) {
|
||
var c = (l = l[0]).toLowerCase();
|
||
this.protocol = c, s = s.substr(l.length)
|
||
}
|
||
if (i || l || s.match(/^\/\/[^@\/]+@[^@\/]+/)) {
|
||
var p = "//" === s.substr(0, 2);
|
||
!p || l && M[l] || (s = s.substr(2), this.slashes = !0)
|
||
}
|
||
if (!M[l] && (p || l && !A[l])) {
|
||
for (var d, f, m = -1, y = 0; y < P.length; y++) {
|
||
-1 !== (v = s.indexOf(P[y])) && (-1 === m || v < m) && (m = v)
|
||
}
|
||
-1 !== (f = -1 === m ? s.lastIndexOf("@") : s.lastIndexOf("@", m)) && (d = s.slice(0, f), s = s.slice(f + 1), this.auth = decodeURIComponent(d)), m = -1;
|
||
for (y = 0; y < R.length; y++) {
|
||
var v;
|
||
-1 !== (v = s.indexOf(R[y])) && (-1 === m || v < m) && (m = v)
|
||
}
|
||
-1 === m && (m = s.length), this.host = s.slice(0, m), s = s.slice(m), this.parseHost(), this.hostname = this.hostname || "";
|
||
var _ = "[" === this.hostname[0] && "]" === this.hostname[this.hostname.length - 1];
|
||
if (!_) for (var x = this.hostname.split(/\./), w = (y = 0, x.length); y < w; y++) {
|
||
var C = x[y];
|
||
if (C && !C.match(L)) {
|
||
for (var E = "", k = 0, F = C.length; k < F; k++) C.charCodeAt(k) > 127 ? E += "x" : E += C[k];
|
||
if (!E.match(L)) {
|
||
var N = x.slice(0, y), D = x.slice(y + 1), G = C.match(I);
|
||
G && (N.push(G[1]), D.unshift(G[2])), D.length && (s = "/" + D.join(".") + s), this.hostname = N.join(".");
|
||
break
|
||
}
|
||
}
|
||
}
|
||
this.hostname.length > 255 ? this.hostname = "" : this.hostname = this.hostname.toLowerCase(), _ || (this.hostname = h.toASCII(this.hostname));
|
||
var j = this.port ? ":" + this.port : "", z = this.hostname || "";
|
||
this.host = z + j, this.href += this.host, _ && (this.hostname = this.hostname.substr(1, this.hostname.length - 2), "/" !== s[0] && (s = "/" + s))
|
||
}
|
||
if (!O[c]) for (y = 0, w = T.length; y < w; y++) {
|
||
var U = T[y];
|
||
if (-1 !== s.indexOf(U)) {
|
||
var B = encodeURIComponent(U);
|
||
B === U && (B = escape(U)), s = s.split(U).join(B)
|
||
}
|
||
}
|
||
var V = s.indexOf("#");
|
||
-1 !== V && (this.hash = s.substr(V), s = s.slice(0, V));
|
||
var Y = s.indexOf("?");
|
||
if (-1 !== Y ? (this.search = s.substr(Y), this.query = s.substr(Y + 1), e && (this.query = g.parse(this.query)), s = s.slice(0, Y)) : e && (this.search = "", this.query = {}), s && (this.pathname = s), A[c] && this.hostname && !this.pathname && (this.pathname = "/"), this.pathname || this.search) {
|
||
j = this.pathname || "";
|
||
var W = this.search || "";
|
||
this.path = j + W
|
||
}
|
||
return this.href = this.format(), this
|
||
}, w.prototype.format = function () {
|
||
var t = this.auth || "";
|
||
t && (t = (t = encodeURIComponent(t)).replace(/%3A/i, ":"), t += "@");
|
||
var e = this.protocol || "", i = this.pathname || "", r = this.hash || "", o = !1, n = "";
|
||
this.host ? o = t + this.host : this.hostname && (o = t + (-1 === this.hostname.indexOf(":") ? this.hostname : "[" + this.hostname + "]"), this.port && (o += ":" + this.port)), this.query && u.isObject(this.query) && Object.keys(this.query).length && (n = g.stringify(this.query));
|
||
var s = this.search || n && "?" + n || "";
|
||
return e && ":" !== e.substr(-1) && (e += ":"), this.slashes || (!e || A[e]) && !1 !== o ? (o = "//" + (o || ""), i && "/" !== i.charAt(0) && (i = "/" + i)) : o || (o = ""), r && "#" !== r.charAt(0) && (r = "#" + r), s && "?" !== s.charAt(0) && (s = "?" + s), e + o + (i = i.replace(/[?#]/g, function (t) {
|
||
return encodeURIComponent(t)
|
||
})) + (s = s.replace("#", "%23")) + r
|
||
}, w.prototype.resolve = function (t) {
|
||
return this.resolveObject(k(t, !1, !0)).format()
|
||
}, w.prototype.resolveObject = function (t) {
|
||
if (u.isString(t)) {
|
||
var e = new w;
|
||
e.parse(t, !1, !0), t = e
|
||
}
|
||
for (var i = new w, r = Object.keys(this), o = 0; o < r.length; o++) {
|
||
var n = r[o];
|
||
i[n] = this[n]
|
||
}
|
||
if (i.hash = t.hash, "" === t.href) return i.href = i.format(), i;
|
||
if (t.slashes && !t.protocol) {
|
||
for (var s = Object.keys(t), a = 0; a < s.length; a++) {
|
||
var l = s[a];
|
||
"protocol" !== l && (i[l] = t[l])
|
||
}
|
||
return A[i.protocol] && i.hostname && !i.pathname && (i.path = i.pathname = "/"), i.href = i.format(), i
|
||
}
|
||
if (t.protocol && t.protocol !== i.protocol) {
|
||
if (!A[t.protocol]) {
|
||
for (var h = Object.keys(t), c = 0; c < h.length; c++) {
|
||
var p = h[c];
|
||
i[p] = t[p]
|
||
}
|
||
return i.href = i.format(), i
|
||
}
|
||
if (i.protocol = t.protocol, t.host || M[t.protocol]) i.pathname = t.pathname; else {
|
||
for (var d = (t.pathname || "").split("/"); d.length && !(t.host = d.shift());) ;
|
||
t.host || (t.host = ""), t.hostname || (t.hostname = ""), "" !== d[0] && d.unshift(""), d.length < 2 && d.unshift(""), i.pathname = d.join("/")
|
||
}
|
||
if (i.search = t.search, i.query = t.query, i.host = t.host || "", i.auth = t.auth, i.hostname = t.hostname || t.host, i.port = t.port, i.pathname || i.search) {
|
||
var f = i.pathname || "", g = i.search || "";
|
||
i.path = f + g
|
||
}
|
||
return i.slashes = i.slashes || t.slashes, i.href = i.format(), i
|
||
}
|
||
var m = i.pathname && "/" === i.pathname.charAt(0),
|
||
y = t.host || t.pathname && "/" === t.pathname.charAt(0), v = y || m || i.host && t.pathname,
|
||
_ = v, x = i.pathname && i.pathname.split("/") || [],
|
||
b = (d = t.pathname && t.pathname.split("/") || [], i.protocol && !A[i.protocol]);
|
||
if (b && (i.hostname = "", i.port = null, i.host && ("" === x[0] ? x[0] = i.host : x.unshift(i.host)), i.host = "", t.protocol && (t.hostname = null, t.port = null, t.host && ("" === d[0] ? d[0] = t.host : d.unshift(t.host)), t.host = null), v = v && ("" === d[0] || "" === x[0])), y) i.host = t.host || "" === t.host ? t.host : i.host, i.hostname = t.hostname || "" === t.hostname ? t.hostname : i.hostname, i.search = t.search, i.query = t.query, x = d; else if (d.length) x || (x = []), x.pop(), x = x.concat(d), i.search = t.search, i.query = t.query; else if (!u.isNullOrUndefined(t.search)) {
|
||
if (b) i.hostname = i.host = x.shift(), (R = !!(i.host && i.host.indexOf("@") > 0) && i.host.split("@")) && (i.auth = R.shift(), i.host = i.hostname = R.shift());
|
||
return i.search = t.search, i.query = t.query, u.isNull(i.pathname) && u.isNull(i.search) || (i.path = (i.pathname ? i.pathname : "") + (i.search ? i.search : "")), i.href = i.format(), i
|
||
}
|
||
if (!x.length) return i.pathname = null, i.search ? i.path = "/" + i.search : i.path = null, i.href = i.format(), i;
|
||
for (var C = x.slice(-1)[0], S = (i.host || t.host || x.length > 1) && ("." === C || ".." === C) || "" === C, E = 0, T = x.length; T >= 0; T--) "." === (C = x[T]) ? x.splice(T, 1) : ".." === C ? (x.splice(T, 1), E++) : E && (x.splice(T, 1), E--);
|
||
if (!v && !_) for (; E--; E) x.unshift("..");
|
||
!v || "" === x[0] || x[0] && "/" === x[0].charAt(0) || x.unshift(""), S && "/" !== x.join("/").substr(-1) && x.push("");
|
||
var R, P = "" === x[0] || x[0] && "/" === x[0].charAt(0);
|
||
b && (i.hostname = i.host = P ? "" : x.length ? x.shift() : "", (R = !!(i.host && i.host.indexOf("@") > 0) && i.host.split("@")) && (i.auth = R.shift(), i.host = i.hostname = R.shift()));
|
||
return (v = v || i.host && x.length) && !P && x.unshift(""), x.length ? i.pathname = x.join("/") : (i.pathname = null, i.path = null), u.isNull(i.pathname) && u.isNull(i.search) || (i.path = (i.pathname ? i.pathname : "") + (i.search ? i.search : "")), i.auth = t.auth || i.auth, i.slashes = i.slashes || t.slashes, i.href = i.format(), i
|
||
}, w.prototype.parseHost = function () {
|
||
var t = this.host, e = C.exec(t);
|
||
e && (":" !== (e = e[0]) && (this.port = e.substr(1)), t = t.substr(0, t.length - e.length)), t && (this.hostname = t)
|
||
};
|
||
var F = {parse: m, resolve: y, resolveObject: v, format: _, Url: x};
|
||
|
||
function N(t) {
|
||
for (var e = 0; e < r.layout.length; e++) for (var i in r[r.layout[e]]) if (i === t) return r[r.layout[e]][i];
|
||
for (var o = 0; o < r.paint.length; o++) for (var n in r[r.paint[o]]) if (n === t) return r[r.paint[o]][n];
|
||
return null
|
||
}
|
||
|
||
function D(t, e) {
|
||
for (var i in t.sources) e(t.sources[i])
|
||
}
|
||
|
||
function G(t, e) {
|
||
for (var i = 0, r = t.layers; i < r.length; i += 1) {
|
||
e(r[i])
|
||
}
|
||
}
|
||
|
||
function j(t, e, i) {
|
||
function r(t, e) {
|
||
var r = t[e];
|
||
r && Object.keys(r).forEach(function (o) {
|
||
i({
|
||
path: [t.id, e, o], key: o, value: r[o], reference: N(o), set: function (t) {
|
||
r[o] = t
|
||
}
|
||
})
|
||
})
|
||
}
|
||
|
||
G(t, function (t) {
|
||
e.paint && r(t, "paint"), e.layout && r(t, "layout")
|
||
})
|
||
}
|
||
|
||
function z(t, e) {
|
||
for (var i in t) 0 === i.indexOf("layout") && e(t[i], i)
|
||
}
|
||
|
||
function U(t, e) {
|
||
for (var i in t) 0 === i.indexOf("paint") && e(t[i], i)
|
||
}
|
||
|
||
function B(t, e) {
|
||
return "string" == typeof e && "@" === e[0] ? B(t, t.constants[e]) : e
|
||
}
|
||
|
||
function V(t, e, i) {
|
||
t[i] = t[e], delete t[e]
|
||
}
|
||
|
||
function Y(t) {
|
||
var e, i, r;
|
||
t.version = 8, D(t, function (t) {
|
||
"video" === t.type && void 0 !== t.url && V(t, "url", "urls"), "video" === t.type && t.coordinates.forEach(function (t) {
|
||
return t.reverse()
|
||
})
|
||
}), G(t, function (t) {
|
||
z(t, function (t) {
|
||
void 0 !== t["symbol-min-distance"] && V(t, "symbol-min-distance", "symbol-spacing")
|
||
}), U(t, function (t) {
|
||
void 0 !== t["background-image"] && V(t, "background-image", "background-pattern"), void 0 !== t["line-image"] && V(t, "line-image", "line-pattern"), void 0 !== t["fill-image"] && V(t, "fill-image", "fill-pattern")
|
||
})
|
||
}), j(t, {paint: !0, layout: !0}, function (e) {
|
||
var i = B(t, e.value);
|
||
(function (t) {
|
||
return Array.isArray(t.stops)
|
||
})(i) && i.stops.forEach(function (e) {
|
||
e[1] = B(t, e[1])
|
||
}), e.set(i)
|
||
}), delete t.constants, G(t, function (t) {
|
||
z(t, function (t) {
|
||
delete t["text-max-size"], delete t["icon-max-size"]
|
||
}), U(t, function (e) {
|
||
e["text-size"] && (t.layout || (t.layout = {}), t.layout["text-size"] = e["text-size"], delete e["text-size"]), e["icon-size"] && (t.layout || (t.layout = {}), t.layout["icon-size"] = e["icon-size"], delete e["icon-size"])
|
||
})
|
||
}), t.glyphs && (t.glyphs = (e = t.glyphs, i = F.parse(e), r = i.pathname.split("/"), "mapbox:" !== i.protocol ? e : "fontstack" === i.hostname ? "mapbox://fonts/mapbox/{fontstack}/{range}.pbf" : "fonts" === i.hostname ? "mapbox://fonts/" + r[2] + "/{fontstack}/{range}.pbf" : void 0)), G(t, function (t) {
|
||
z(t, function (t) {
|
||
t["text-font"] && (t["text-font"] = function (t) {
|
||
function e(t) {
|
||
return t.split(",").map(function (t) {
|
||
return t.trim()
|
||
})
|
||
}
|
||
|
||
if (Array.isArray(t)) return t;
|
||
if ("string" == typeof t) return e(t);
|
||
if ("object" == typeof t) return t.stops.forEach(function (t) {
|
||
t[1] = e(t[1])
|
||
}), t;
|
||
throw new Error("unexpected font value")
|
||
}(t["text-font"]))
|
||
})
|
||
});
|
||
for (var o = 0, n = t.layers.length - 1; n >= 0; n--) {
|
||
if ("symbol" !== t.layers[n].type) {
|
||
o = n + 1;
|
||
break
|
||
}
|
||
}
|
||
var s = t.layers.splice(o);
|
||
return s.reverse(), t.layers = t.layers.concat(s), t
|
||
}
|
||
|
||
function W(t) {
|
||
for (var e = [], i = arguments.length - 1; i-- > 0;) e[i] = arguments[i + 1];
|
||
for (var r = 0, o = e; r < o.length; r += 1) {
|
||
var n = o[r];
|
||
for (var s in n) t[s] = n[s]
|
||
}
|
||
return t
|
||
}
|
||
|
||
var H = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, i), this.message = i, this.key = e
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(Error), X = function (t, e) {
|
||
void 0 === e && (e = []), this.parent = t, this.bindings = {};
|
||
for (var i = 0, r = e; i < r.length; i += 1) {
|
||
var o = r[i], n = o[0], s = o[1];
|
||
this.bindings[n] = s
|
||
}
|
||
};
|
||
X.prototype.concat = function (t) {
|
||
return new X(this, t)
|
||
}, X.prototype.get = function (t) {
|
||
if (this.bindings[t]) return this.bindings[t];
|
||
if (this.parent) return this.parent.get(t);
|
||
throw new Error(t + " not found in scope.")
|
||
}, X.prototype.has = function (t) {
|
||
return !!this.bindings[t] || !!this.parent && this.parent.has(t)
|
||
};
|
||
var q = {kind: "null"}, Z = {kind: "number"}, K = {kind: "string"}, J = {kind: "boolean"},
|
||
$ = {kind: "color"}, Q = {kind: "object"}, tt = {kind: "value"}, et = {kind: "collator"},
|
||
it = {kind: "formatted"};
|
||
|
||
function rt(t, e) {
|
||
return {kind: "array", itemType: t, N: e}
|
||
}
|
||
|
||
function ot(t) {
|
||
if ("array" === t.kind) {
|
||
var e = ot(t.itemType);
|
||
return "number" == typeof t.N ? "array<" + e + ", " + t.N + ">" : "value" === t.itemType.kind ? "array" : "array<" + e + ">"
|
||
}
|
||
return t.kind
|
||
}
|
||
|
||
var nt = [q, Z, K, J, $, it, Q, rt(tt)];
|
||
|
||
function st(t, e) {
|
||
if ("error" === e.kind) return null;
|
||
if ("array" === t.kind) {
|
||
if ("array" === e.kind && (0 === e.N && "value" === e.itemType.kind || !st(t.itemType, e.itemType)) && ("number" != typeof t.N || t.N === e.N)) return null
|
||
} else {
|
||
if (t.kind === e.kind) return null;
|
||
if ("value" === t.kind) for (var i = 0, r = nt; i < r.length; i += 1) {
|
||
if (!st(r[i], e)) return null
|
||
}
|
||
}
|
||
return "Expected " + ot(t) + " but found " + ot(e) + " instead."
|
||
}
|
||
|
||
var at = l(function (t, e) {
|
||
var i = {
|
||
transparent: [0, 0, 0, 0],
|
||
aliceblue: [240, 248, 255, 1],
|
||
antiquewhite: [250, 235, 215, 1],
|
||
aqua: [0, 255, 255, 1],
|
||
aquamarine: [127, 255, 212, 1],
|
||
azure: [240, 255, 255, 1],
|
||
beige: [245, 245, 220, 1],
|
||
bisque: [255, 228, 196, 1],
|
||
black: [0, 0, 0, 1],
|
||
blanchedalmond: [255, 235, 205, 1],
|
||
blue: [0, 0, 255, 1],
|
||
blueviolet: [138, 43, 226, 1],
|
||
brown: [165, 42, 42, 1],
|
||
burlywood: [222, 184, 135, 1],
|
||
cadetblue: [95, 158, 160, 1],
|
||
chartreuse: [127, 255, 0, 1],
|
||
chocolate: [210, 105, 30, 1],
|
||
coral: [255, 127, 80, 1],
|
||
cornflowerblue: [100, 149, 237, 1],
|
||
cornsilk: [255, 248, 220, 1],
|
||
crimson: [220, 20, 60, 1],
|
||
cyan: [0, 255, 255, 1],
|
||
darkblue: [0, 0, 139, 1],
|
||
darkcyan: [0, 139, 139, 1],
|
||
darkgoldenrod: [184, 134, 11, 1],
|
||
darkgray: [169, 169, 169, 1],
|
||
darkgreen: [0, 100, 0, 1],
|
||
darkgrey: [169, 169, 169, 1],
|
||
darkkhaki: [189, 183, 107, 1],
|
||
darkmagenta: [139, 0, 139, 1],
|
||
darkolivegreen: [85, 107, 47, 1],
|
||
darkorange: [255, 140, 0, 1],
|
||
darkorchid: [153, 50, 204, 1],
|
||
darkred: [139, 0, 0, 1],
|
||
darksalmon: [233, 150, 122, 1],
|
||
darkseagreen: [143, 188, 143, 1],
|
||
darkslateblue: [72, 61, 139, 1],
|
||
darkslategray: [47, 79, 79, 1],
|
||
darkslategrey: [47, 79, 79, 1],
|
||
darkturquoise: [0, 206, 209, 1],
|
||
darkviolet: [148, 0, 211, 1],
|
||
deeppink: [255, 20, 147, 1],
|
||
deepskyblue: [0, 191, 255, 1],
|
||
dimgray: [105, 105, 105, 1],
|
||
dimgrey: [105, 105, 105, 1],
|
||
dodgerblue: [30, 144, 255, 1],
|
||
firebrick: [178, 34, 34, 1],
|
||
floralwhite: [255, 250, 240, 1],
|
||
forestgreen: [34, 139, 34, 1],
|
||
fuchsia: [255, 0, 255, 1],
|
||
gainsboro: [220, 220, 220, 1],
|
||
ghostwhite: [248, 248, 255, 1],
|
||
gold: [255, 215, 0, 1],
|
||
goldenrod: [218, 165, 32, 1],
|
||
gray: [128, 128, 128, 1],
|
||
green: [0, 128, 0, 1],
|
||
greenyellow: [173, 255, 47, 1],
|
||
grey: [128, 128, 128, 1],
|
||
honeydew: [240, 255, 240, 1],
|
||
hotpink: [255, 105, 180, 1],
|
||
indianred: [205, 92, 92, 1],
|
||
indigo: [75, 0, 130, 1],
|
||
ivory: [255, 255, 240, 1],
|
||
khaki: [240, 230, 140, 1],
|
||
lavender: [230, 230, 250, 1],
|
||
lavenderblush: [255, 240, 245, 1],
|
||
lawngreen: [124, 252, 0, 1],
|
||
lemonchiffon: [255, 250, 205, 1],
|
||
lightblue: [173, 216, 230, 1],
|
||
lightcoral: [240, 128, 128, 1],
|
||
lightcyan: [224, 255, 255, 1],
|
||
lightgoldenrodyellow: [250, 250, 210, 1],
|
||
lightgray: [211, 211, 211, 1],
|
||
lightgreen: [144, 238, 144, 1],
|
||
lightgrey: [211, 211, 211, 1],
|
||
lightpink: [255, 182, 193, 1],
|
||
lightsalmon: [255, 160, 122, 1],
|
||
lightseagreen: [32, 178, 170, 1],
|
||
lightskyblue: [135, 206, 250, 1],
|
||
lightslategray: [119, 136, 153, 1],
|
||
lightslategrey: [119, 136, 153, 1],
|
||
lightsteelblue: [176, 196, 222, 1],
|
||
lightyellow: [255, 255, 224, 1],
|
||
lime: [0, 255, 0, 1],
|
||
limegreen: [50, 205, 50, 1],
|
||
linen: [250, 240, 230, 1],
|
||
magenta: [255, 0, 255, 1],
|
||
maroon: [128, 0, 0, 1],
|
||
mediumaquamarine: [102, 205, 170, 1],
|
||
mediumblue: [0, 0, 205, 1],
|
||
mediumorchid: [186, 85, 211, 1],
|
||
mediumpurple: [147, 112, 219, 1],
|
||
mediumseagreen: [60, 179, 113, 1],
|
||
mediumslateblue: [123, 104, 238, 1],
|
||
mediumspringgreen: [0, 250, 154, 1],
|
||
mediumturquoise: [72, 209, 204, 1],
|
||
mediumvioletred: [199, 21, 133, 1],
|
||
midnightblue: [25, 25, 112, 1],
|
||
mintcream: [245, 255, 250, 1],
|
||
mistyrose: [255, 228, 225, 1],
|
||
moccasin: [255, 228, 181, 1],
|
||
navajowhite: [255, 222, 173, 1],
|
||
navy: [0, 0, 128, 1],
|
||
oldlace: [253, 245, 230, 1],
|
||
olive: [128, 128, 0, 1],
|
||
olivedrab: [107, 142, 35, 1],
|
||
orange: [255, 165, 0, 1],
|
||
orangered: [255, 69, 0, 1],
|
||
orchid: [218, 112, 214, 1],
|
||
palegoldenrod: [238, 232, 170, 1],
|
||
palegreen: [152, 251, 152, 1],
|
||
paleturquoise: [175, 238, 238, 1],
|
||
palevioletred: [219, 112, 147, 1],
|
||
papayawhip: [255, 239, 213, 1],
|
||
peachpuff: [255, 218, 185, 1],
|
||
peru: [205, 133, 63, 1],
|
||
pink: [255, 192, 203, 1],
|
||
plum: [221, 160, 221, 1],
|
||
powderblue: [176, 224, 230, 1],
|
||
purple: [128, 0, 128, 1],
|
||
rebeccapurple: [102, 51, 153, 1],
|
||
red: [255, 0, 0, 1],
|
||
rosybrown: [188, 143, 143, 1],
|
||
royalblue: [65, 105, 225, 1],
|
||
saddlebrown: [139, 69, 19, 1],
|
||
salmon: [250, 128, 114, 1],
|
||
sandybrown: [244, 164, 96, 1],
|
||
seagreen: [46, 139, 87, 1],
|
||
seashell: [255, 245, 238, 1],
|
||
sienna: [160, 82, 45, 1],
|
||
silver: [192, 192, 192, 1],
|
||
skyblue: [135, 206, 235, 1],
|
||
slateblue: [106, 90, 205, 1],
|
||
slategray: [112, 128, 144, 1],
|
||
slategrey: [112, 128, 144, 1],
|
||
snow: [255, 250, 250, 1],
|
||
springgreen: [0, 255, 127, 1],
|
||
steelblue: [70, 130, 180, 1],
|
||
tan: [210, 180, 140, 1],
|
||
teal: [0, 128, 128, 1],
|
||
thistle: [216, 191, 216, 1],
|
||
tomato: [255, 99, 71, 1],
|
||
turquoise: [64, 224, 208, 1],
|
||
violet: [238, 130, 238, 1],
|
||
wheat: [245, 222, 179, 1],
|
||
white: [255, 255, 255, 1],
|
||
whitesmoke: [245, 245, 245, 1],
|
||
yellow: [255, 255, 0, 1],
|
||
yellowgreen: [154, 205, 50, 1]
|
||
};
|
||
|
||
function r(t) {
|
||
return (t = Math.round(t)) < 0 ? 0 : t > 255 ? 255 : t
|
||
}
|
||
|
||
function o(t) {
|
||
return t < 0 ? 0 : t > 1 ? 1 : t
|
||
}
|
||
|
||
function n(t) {
|
||
return "%" === t[t.length - 1] ? r(parseFloat(t) / 100 * 255) : r(parseInt(t))
|
||
}
|
||
|
||
function s(t) {
|
||
return "%" === t[t.length - 1] ? o(parseFloat(t) / 100) : o(parseFloat(t))
|
||
}
|
||
|
||
function a(t, e, i) {
|
||
return i < 0 ? i += 1 : i > 1 && (i -= 1), 6 * i < 1 ? t + (e - t) * i * 6 : 2 * i < 1 ? e : 3 * i < 2 ? t + (e - t) * (2 / 3 - i) * 6 : t
|
||
}
|
||
|
||
try {
|
||
e.parseCSSColor = function (t) {
|
||
var e, o = t.replace(/ /g, "").toLowerCase();
|
||
if (o in i) return i[o].slice();
|
||
if ("#" === o[0]) return 4 === o.length ? (e = parseInt(o.substr(1), 16)) >= 0 && e <= 4095 ? [(3840 & e) >> 4 | (3840 & e) >> 8, 240 & e | (240 & e) >> 4, 15 & e | (15 & e) << 4, 1] : null : 7 === o.length && (e = parseInt(o.substr(1), 16)) >= 0 && e <= 16777215 ? [(16711680 & e) >> 16, (65280 & e) >> 8, 255 & e, 1] : null;
|
||
var l = o.indexOf("("), h = o.indexOf(")");
|
||
if (-1 !== l && h + 1 === o.length) {
|
||
var u = o.substr(0, l), c = o.substr(l + 1, h - (l + 1)).split(","), p = 1;
|
||
switch (u) {
|
||
case"rgba":
|
||
if (4 !== c.length) return null;
|
||
p = s(c.pop());
|
||
case"rgb":
|
||
return 3 !== c.length ? null : [n(c[0]), n(c[1]), n(c[2]), p];
|
||
case"hsla":
|
||
if (4 !== c.length) return null;
|
||
p = s(c.pop());
|
||
case"hsl":
|
||
if (3 !== c.length) return null;
|
||
var d = (parseFloat(c[0]) % 360 + 360) % 360 / 360, f = s(c[1]), g = s(c[2]),
|
||
m = g <= .5 ? g * (f + 1) : g + f - g * f, y = 2 * g - m;
|
||
return [r(255 * a(y, m, d + 1 / 3)), r(255 * a(y, m, d)), r(255 * a(y, m, d - 1 / 3)), p];
|
||
default:
|
||
return null
|
||
}
|
||
}
|
||
return null
|
||
}
|
||
} catch (t) {
|
||
}
|
||
}).parseCSSColor, lt = function (t, e, i, r) {
|
||
void 0 === r && (r = 1), this.r = t, this.g = e, this.b = i, this.a = r
|
||
};
|
||
lt.parse = function (t) {
|
||
if (t) {
|
||
if (t instanceof lt) return t;
|
||
if ("string" == typeof t) {
|
||
var e = at(t);
|
||
if (e) return new lt(e[0] / 255 * e[3], e[1] / 255 * e[3], e[2] / 255 * e[3], e[3])
|
||
}
|
||
}
|
||
}, lt.prototype.toString = function () {
|
||
var t = this.toArray(), e = t[0], i = t[1], r = t[2], o = t[3];
|
||
return "rgba(" + Math.round(e) + "," + Math.round(i) + "," + Math.round(r) + "," + o + ")"
|
||
}, lt.prototype.toArray = function () {
|
||
var t = this.r, e = this.g, i = this.b, r = this.a;
|
||
return 0 === r ? [0, 0, 0, 0] : [255 * t / r, 255 * e / r, 255 * i / r, r]
|
||
}, lt.black = new lt(0, 0, 0, 1), lt.white = new lt(1, 1, 1, 1), lt.transparent = new lt(0, 0, 0, 0), lt.red = new lt(1, 0, 0, 1);
|
||
var ht = function (t, e, i) {
|
||
this.sensitivity = t ? e ? "variant" : "case" : e ? "accent" : "base", this.locale = i, this.collator = new Intl.Collator(this.locale ? this.locale : [], {
|
||
sensitivity: this.sensitivity,
|
||
usage: "search"
|
||
})
|
||
};
|
||
ht.prototype.compare = function (t, e) {
|
||
return this.collator.compare(t, e)
|
||
}, ht.prototype.resolvedLocale = function () {
|
||
return new Intl.Collator(this.locale ? this.locale : []).resolvedOptions().locale
|
||
};
|
||
var ut = function (t, e, i) {
|
||
this.text = t, this.scale = e, this.fontStack = i
|
||
}, ct = function (t) {
|
||
this.sections = t
|
||
};
|
||
|
||
function pt(t, e, i, r) {
|
||
return "number" == typeof t && t >= 0 && t <= 255 && "number" == typeof e && e >= 0 && e <= 255 && "number" == typeof i && i >= 0 && i <= 255 ? void 0 === r || "number" == typeof r && r >= 0 && r <= 1 ? null : "Invalid rgba value [" + [t, e, i, r].join(", ") + "]: 'a' must be between 0 and 1." : "Invalid rgba value [" + ("number" == typeof r ? [t, e, i, r] : [t, e, i]).join(", ") + "]: 'r', 'g', and 'b' must be between 0 and 255."
|
||
}
|
||
|
||
function dt(t) {
|
||
if (null === t) return q;
|
||
if ("string" == typeof t) return K;
|
||
if ("boolean" == typeof t) return J;
|
||
if ("number" == typeof t) return Z;
|
||
if (t instanceof lt) return $;
|
||
if (t instanceof ht) return et;
|
||
if (t instanceof ct) return it;
|
||
if (Array.isArray(t)) {
|
||
for (var e, i = t.length, r = 0, o = t; r < o.length; r += 1) {
|
||
var n = dt(o[r]);
|
||
if (e) {
|
||
if (e === n) continue;
|
||
e = tt;
|
||
break
|
||
}
|
||
e = n
|
||
}
|
||
return rt(e || tt, i)
|
||
}
|
||
return Q
|
||
}
|
||
|
||
function ft(t) {
|
||
var e = typeof t;
|
||
return null === t ? "" : "string" === e || "number" === e || "boolean" === e ? String(t) : t instanceof lt || t instanceof ct ? t.toString() : JSON.stringify(t)
|
||
}
|
||
|
||
ct.fromString = function (t) {
|
||
return new ct([new ut(t, null, null)])
|
||
}, ct.prototype.toString = function () {
|
||
return this.sections.map(function (t) {
|
||
return t.text
|
||
}).join("")
|
||
}, ct.prototype.serialize = function () {
|
||
for (var t = ["format"], e = 0, i = this.sections; e < i.length; e += 1) {
|
||
var r = i[e];
|
||
t.push(r.text);
|
||
var o = {};
|
||
r.fontStack && (o["text-font"] = ["literal", r.fontStack.split(",")]), r.scale && (o["font-scale"] = r.scale), t.push(o)
|
||
}
|
||
return t
|
||
};
|
||
var gt = function (t, e) {
|
||
this.type = t, this.value = e
|
||
};
|
||
gt.parse = function (t, e) {
|
||
if (2 !== t.length) return e.error("'literal' expression requires exactly one argument, but found " + (t.length - 1) + " instead.");
|
||
if (!function t(e) {
|
||
if (null === e) return !0;
|
||
if ("string" == typeof e) return !0;
|
||
if ("boolean" == typeof e) return !0;
|
||
if ("number" == typeof e) return !0;
|
||
if (e instanceof lt) return !0;
|
||
if (e instanceof ht) return !0;
|
||
if (e instanceof ct) return !0;
|
||
if (Array.isArray(e)) {
|
||
for (var i = 0, r = e; i < r.length; i += 1) if (!t(r[i])) return !1;
|
||
return !0
|
||
}
|
||
if ("object" == typeof e) {
|
||
for (var o in e) if (!t(e[o])) return !1;
|
||
return !0
|
||
}
|
||
return !1
|
||
}(t[1])) return e.error("invalid value");
|
||
var i = t[1], r = dt(i), o = e.expectedType;
|
||
return "array" !== r.kind || 0 !== r.N || !o || "array" !== o.kind || "number" == typeof o.N && 0 !== o.N || (r = o), new gt(r, i)
|
||
}, gt.prototype.evaluate = function () {
|
||
return this.value
|
||
}, gt.prototype.eachChild = function () {
|
||
}, gt.prototype.possibleOutputs = function () {
|
||
return [this.value]
|
||
}, gt.prototype.serialize = function () {
|
||
return "array" === this.type.kind || "object" === this.type.kind ? ["literal", this.value] : this.value instanceof lt ? ["rgba"].concat(this.value.toArray()) : this.value instanceof ct ? this.value.serialize() : this.value
|
||
};
|
||
var mt = function (t) {
|
||
this.name = "ExpressionEvaluationError", this.message = t
|
||
};
|
||
mt.prototype.toJSON = function () {
|
||
return this.message
|
||
};
|
||
var yt = {string: K, number: Z, boolean: J, object: Q}, vt = function (t, e) {
|
||
this.type = t, this.args = e
|
||
};
|
||
vt.parse = function (t, e) {
|
||
if (t.length < 2) return e.error("Expected at least one argument.");
|
||
var i, r = 1, o = t[0];
|
||
if ("array" === o) {
|
||
var n, s;
|
||
if (t.length > 2) {
|
||
var a = t[1];
|
||
if ("string" != typeof a || !(a in yt) || "object" === a) return e.error('The item type argument of "array" must be one of string, number, boolean', 1);
|
||
n = yt[a], r++
|
||
} else n = tt;
|
||
if (t.length > 3) {
|
||
if (null !== t[2] && ("number" != typeof t[2] || t[2] < 0 || t[2] !== Math.floor(t[2]))) return e.error('The length argument to "array" must be a positive integer literal', 2);
|
||
s = t[2], r++
|
||
}
|
||
i = rt(n, s)
|
||
} else i = yt[o];
|
||
for (var l = []; r < t.length; r++) {
|
||
var h = e.parse(t[r], r, tt);
|
||
if (!h) return null;
|
||
l.push(h)
|
||
}
|
||
return new vt(i, l)
|
||
}, vt.prototype.evaluate = function (t) {
|
||
for (var e = 0; e < this.args.length; e++) {
|
||
var i = this.args[e].evaluate(t);
|
||
if (!st(this.type, dt(i))) return i;
|
||
if (e === this.args.length - 1) throw new mt("Expected value to be of type " + ot(this.type) + ", but found " + ot(dt(i)) + " instead.")
|
||
}
|
||
return null
|
||
}, vt.prototype.eachChild = function (t) {
|
||
this.args.forEach(t)
|
||
}, vt.prototype.possibleOutputs = function () {
|
||
var t;
|
||
return (t = []).concat.apply(t, this.args.map(function (t) {
|
||
return t.possibleOutputs()
|
||
}))
|
||
}, vt.prototype.serialize = function () {
|
||
var t = this.type, e = [t.kind];
|
||
if ("array" === t.kind) {
|
||
var i = t.itemType;
|
||
if ("string" === i.kind || "number" === i.kind || "boolean" === i.kind) {
|
||
e.push(i.kind);
|
||
var r = t.N;
|
||
("number" == typeof r || this.args.length > 1) && e.push(r)
|
||
}
|
||
}
|
||
return e.concat(this.args.map(function (t) {
|
||
return t.serialize()
|
||
}))
|
||
};
|
||
var _t = function (t) {
|
||
this.type = it, this.sections = t
|
||
};
|
||
_t.parse = function (t, e) {
|
||
if (t.length < 3) return e.error("Expected at least two arguments.");
|
||
if ((t.length - 1) % 2 != 0) return e.error("Expected an even number of arguments.");
|
||
for (var i = [], r = 1; r < t.length - 1; r += 2) {
|
||
var o = e.parse(t[r], 1, tt);
|
||
if (!o) return null;
|
||
var n = o.type.kind;
|
||
if ("string" !== n && "value" !== n && "null" !== n) return e.error("Formatted text type must be 'string', 'value', or 'null'.");
|
||
var s = t[r + 1];
|
||
if ("object" != typeof s || Array.isArray(s)) return e.error("Format options argument must be an object.");
|
||
var a = null;
|
||
if (s["font-scale"] && !(a = e.parse(s["font-scale"], 1, Z))) return null;
|
||
var l = null;
|
||
if (s["text-font"] && !(l = e.parse(s["text-font"], 1, rt(K)))) return null;
|
||
i.push({text: o, scale: a, font: l})
|
||
}
|
||
return new _t(i)
|
||
}, _t.prototype.evaluate = function (t) {
|
||
return new ct(this.sections.map(function (e) {
|
||
return new ut(ft(e.text.evaluate(t)), e.scale ? e.scale.evaluate(t) : null, e.font ? e.font.evaluate(t).join(",") : null)
|
||
}))
|
||
}, _t.prototype.eachChild = function (t) {
|
||
for (var e = 0, i = this.sections; e < i.length; e += 1) {
|
||
var r = i[e];
|
||
t(r.text), r.scale && t(r.scale), r.font && t(r.font)
|
||
}
|
||
}, _t.prototype.possibleOutputs = function () {
|
||
return [void 0]
|
||
}, _t.prototype.serialize = function () {
|
||
for (var t = ["format"], e = 0, i = this.sections; e < i.length; e += 1) {
|
||
var r = i[e];
|
||
t.push(r.text.serialize());
|
||
var o = {};
|
||
r.scale && (o["font-scale"] = r.scale.serialize()), r.font && (o["text-font"] = r.font.serialize()), t.push(o)
|
||
}
|
||
return t
|
||
};
|
||
var xt = {"to-boolean": J, "to-color": $, "to-number": Z, "to-string": K}, wt = function (t, e) {
|
||
this.type = t, this.args = e
|
||
};
|
||
wt.parse = function (t, e) {
|
||
if (t.length < 2) return e.error("Expected at least one argument.");
|
||
var i = t[0];
|
||
if (("to-boolean" === i || "to-string" === i) && 2 !== t.length) return e.error("Expected one argument.");
|
||
for (var r = xt[i], o = [], n = 1; n < t.length; n++) {
|
||
var s = e.parse(t[n], n, tt);
|
||
if (!s) return null;
|
||
o.push(s)
|
||
}
|
||
return new wt(r, o)
|
||
}, wt.prototype.evaluate = function (t) {
|
||
if ("boolean" === this.type.kind) return Boolean(this.args[0].evaluate(t));
|
||
if ("color" === this.type.kind) {
|
||
for (var e, i, r = 0, o = this.args; r < o.length; r += 1) {
|
||
if (i = null, (e = o[r].evaluate(t)) instanceof lt) return e;
|
||
if ("string" == typeof e) {
|
||
var n = t.parseColor(e);
|
||
if (n) return n
|
||
} else if (Array.isArray(e) && !(i = e.length < 3 || e.length > 4 ? "Invalid rbga value " + JSON.stringify(e) + ": expected an array containing either three or four numeric values." : pt(e[0], e[1], e[2], e[3]))) return new lt(e[0] / 255, e[1] / 255, e[2] / 255, e[3])
|
||
}
|
||
throw new mt(i || "Could not parse color from value '" + ("string" == typeof e ? e : String(JSON.stringify(e))) + "'")
|
||
}
|
||
if ("number" === this.type.kind) {
|
||
for (var s = null, a = 0, l = this.args; a < l.length; a += 1) {
|
||
if (null === (s = l[a].evaluate(t))) return 0;
|
||
var h = Number(s);
|
||
if (!isNaN(h)) return h
|
||
}
|
||
throw new mt("Could not convert " + JSON.stringify(s) + " to number.")
|
||
}
|
||
return "formatted" === this.type.kind ? ct.fromString(ft(this.args[0].evaluate(t))) : ft(this.args[0].evaluate(t))
|
||
}, wt.prototype.eachChild = function (t) {
|
||
this.args.forEach(t)
|
||
}, wt.prototype.possibleOutputs = function () {
|
||
var t;
|
||
return (t = []).concat.apply(t, this.args.map(function (t) {
|
||
return t.possibleOutputs()
|
||
}))
|
||
}, wt.prototype.serialize = function () {
|
||
if ("formatted" === this.type.kind) return new _t([{
|
||
text: this.args[0],
|
||
scale: null,
|
||
font: null
|
||
}]).serialize();
|
||
var t = ["to-" + this.type.kind];
|
||
return this.eachChild(function (e) {
|
||
t.push(e.serialize())
|
||
}), t
|
||
};
|
||
var bt = ["Unknown", "Point", "LineString", "Polygon"], Ct = function () {
|
||
this.globals = null, this.feature = null, this.featureState = null, this._parseColorCache = {}
|
||
};
|
||
Ct.prototype.id = function () {
|
||
return this.feature && "id" in this.feature ? this.feature.id : null
|
||
}, Ct.prototype.geometryType = function () {
|
||
return this.feature ? "number" == typeof this.feature.type ? bt[this.feature.type] : this.feature.type : null
|
||
}, Ct.prototype.properties = function () {
|
||
return this.feature && this.feature.properties || {}
|
||
}, Ct.prototype.parseColor = function (t) {
|
||
var e = this._parseColorCache[t];
|
||
return e || (e = this._parseColorCache[t] = lt.parse(t)), e
|
||
};
|
||
var St = function (t, e, i, r) {
|
||
this.name = t, this.type = e, this._evaluate = i, this.args = r
|
||
};
|
||
St.prototype.evaluate = function (t) {
|
||
return this._evaluate(t, this.args)
|
||
}, St.prototype.eachChild = function (t) {
|
||
this.args.forEach(t)
|
||
}, St.prototype.possibleOutputs = function () {
|
||
return [void 0]
|
||
}, St.prototype.serialize = function () {
|
||
return [this.name].concat(this.args.map(function (t) {
|
||
return t.serialize()
|
||
}))
|
||
}, St.parse = function (t, e) {
|
||
var i, r = t[0], o = St.definitions[r];
|
||
if (!o) return e.error('Unknown expression "' + r + '". If you wanted a literal array, use ["literal", [...]].', 0);
|
||
for (var n = Array.isArray(o) ? o[0] : o.type, s = Array.isArray(o) ? [[o[1], o[2]]] : o.overloads, a = s.filter(function (e) {
|
||
var i = e[0];
|
||
return !Array.isArray(i) || i.length === t.length - 1
|
||
}), l = null, h = 0, u = a; h < u.length; h += 1) {
|
||
var c = u[h], p = c[0], d = c[1];
|
||
l = new It(e.registry, e.path, null, e.scope);
|
||
for (var f = [], g = !1, m = 1; m < t.length; m++) {
|
||
var y = t[m], v = Array.isArray(p) ? p[m - 1] : p.type, _ = l.parse(y, 1 + f.length, v);
|
||
if (!_) {
|
||
g = !0;
|
||
break
|
||
}
|
||
f.push(_)
|
||
}
|
||
if (!g) if (Array.isArray(p) && p.length !== f.length) l.error("Expected " + p.length + " arguments, but found " + f.length + " instead."); else {
|
||
for (var x = 0; x < f.length; x++) {
|
||
var w = Array.isArray(p) ? p[x] : p.type, b = f[x];
|
||
l.concat(x + 1).checkSubtype(w, b.type)
|
||
}
|
||
if (0 === l.errors.length) return new St(r, n, d, f)
|
||
}
|
||
}
|
||
if (1 === a.length) (i = e.errors).push.apply(i, l.errors); else {
|
||
for (var C = (a.length ? a : s).map(function (t) {
|
||
var e, i = t[0];
|
||
return e = i, Array.isArray(e) ? "(" + e.map(ot).join(", ") + ")" : "(" + ot(e.type) + "...)"
|
||
}).join(" | "), S = [], E = 1; E < t.length; E++) {
|
||
var T = e.parse(t[E], 1 + S.length);
|
||
if (!T) return null;
|
||
S.push(ot(T.type))
|
||
}
|
||
e.error("Expected arguments of type " + C + ", but found (" + S.join(", ") + ") instead.")
|
||
}
|
||
return null
|
||
}, St.register = function (t, e) {
|
||
for (var i in St.definitions = e, e) t[i] = St
|
||
};
|
||
var Et = function (t, e, i) {
|
||
this.type = et, this.locale = i, this.caseSensitive = t, this.diacriticSensitive = e
|
||
};
|
||
|
||
function Tt(t) {
|
||
if (t instanceof St) {
|
||
if ("get" === t.name && 1 === t.args.length) return !1;
|
||
if ("feature-state" === t.name) return !1;
|
||
if ("has" === t.name && 1 === t.args.length) return !1;
|
||
if ("properties" === t.name || "geometry-type" === t.name || "id" === t.name) return !1;
|
||
if (/^filter-/.test(t.name)) return !1
|
||
}
|
||
var e = !0;
|
||
return t.eachChild(function (t) {
|
||
e && !Tt(t) && (e = !1)
|
||
}), e
|
||
}
|
||
|
||
function Rt(t) {
|
||
if (t instanceof St && "feature-state" === t.name) return !1;
|
||
var e = !0;
|
||
return t.eachChild(function (t) {
|
||
e && !Rt(t) && (e = !1)
|
||
}), e
|
||
}
|
||
|
||
function Pt(t, e) {
|
||
if (t instanceof St && e.indexOf(t.name) >= 0) return !1;
|
||
var i = !0;
|
||
return t.eachChild(function (t) {
|
||
i && !Pt(t, e) && (i = !1)
|
||
}), i
|
||
}
|
||
|
||
Et.parse = function (t, e) {
|
||
if (2 !== t.length) return e.error("Expected one argument.");
|
||
var i = t[1];
|
||
if ("object" != typeof i || Array.isArray(i)) return e.error("Collator options argument must be an object.");
|
||
var r = e.parse(void 0 !== i["case-sensitive"] && i["case-sensitive"], 1, J);
|
||
if (!r) return null;
|
||
var o = e.parse(void 0 !== i["diacritic-sensitive"] && i["diacritic-sensitive"], 1, J);
|
||
if (!o) return null;
|
||
var n = null;
|
||
return i.locale && !(n = e.parse(i.locale, 1, K)) ? null : new Et(r, o, n)
|
||
}, Et.prototype.evaluate = function (t) {
|
||
return new ht(this.caseSensitive.evaluate(t), this.diacriticSensitive.evaluate(t), this.locale ? this.locale.evaluate(t) : null)
|
||
}, Et.prototype.eachChild = function (t) {
|
||
t(this.caseSensitive), t(this.diacriticSensitive), this.locale && t(this.locale)
|
||
}, Et.prototype.possibleOutputs = function () {
|
||
return [void 0]
|
||
}, Et.prototype.serialize = function () {
|
||
var t = {};
|
||
return t["case-sensitive"] = this.caseSensitive.serialize(), t["diacritic-sensitive"] = this.diacriticSensitive.serialize(), this.locale && (t.locale = this.locale.serialize()), ["collator", t]
|
||
};
|
||
var Lt = function (t, e) {
|
||
this.type = e.type, this.name = t, this.boundExpression = e
|
||
};
|
||
Lt.parse = function (t, e) {
|
||
if (2 !== t.length || "string" != typeof t[1]) return e.error("'var' expression requires exactly one string literal argument.");
|
||
var i = t[1];
|
||
return e.scope.has(i) ? new Lt(i, e.scope.get(i)) : e.error('Unknown variable "' + i + '". Make sure "' + i + '" has been bound in an enclosing "let" expression before using it.', 1)
|
||
}, Lt.prototype.evaluate = function (t) {
|
||
return this.boundExpression.evaluate(t)
|
||
}, Lt.prototype.eachChild = function () {
|
||
}, Lt.prototype.possibleOutputs = function () {
|
||
return [void 0]
|
||
}, Lt.prototype.serialize = function () {
|
||
return ["var", this.name]
|
||
};
|
||
var It = function (t, e, i, r, o) {
|
||
void 0 === e && (e = []), void 0 === r && (r = new X), void 0 === o && (o = []), this.registry = t, this.path = e, this.key = e.map(function (t) {
|
||
return "[" + t + "]"
|
||
}).join(""), this.scope = r, this.errors = o, this.expectedType = i
|
||
};
|
||
|
||
function Ot(t, e) {
|
||
for (var i, r, o = 0, n = t.length - 1, s = 0; o <= n;) {
|
||
if (i = t[s = Math.floor((o + n) / 2)], r = t[s + 1], e === i || e > i && e < r) return s;
|
||
if (i < e) o = s + 1; else {
|
||
if (!(i > e)) throw new mt("Input is not a number.");
|
||
n = s - 1
|
||
}
|
||
}
|
||
return Math.max(s - 1, 0)
|
||
}
|
||
|
||
It.prototype.parse = function (t, e, i, r, o) {
|
||
return void 0 === o && (o = {}), e ? this.concat(e, i, r)._parse(t, o) : this._parse(t, o)
|
||
}, It.prototype._parse = function (t, e) {
|
||
function i(t, e, i) {
|
||
return "assert" === i ? new vt(e, [t]) : "coerce" === i ? new wt(e, [t]) : t
|
||
}
|
||
|
||
if (null !== t && "string" != typeof t && "boolean" != typeof t && "number" != typeof t || (t = ["literal", t]), Array.isArray(t)) {
|
||
if (0 === t.length) return this.error('Expected an array with at least one element. If you wanted a literal array, use ["literal", []].');
|
||
var r = t[0];
|
||
if ("string" != typeof r) return this.error("Expression name must be a string, but found " + typeof r + ' instead. If you wanted a literal array, use ["literal", [...]].', 0), null;
|
||
var o = this.registry[r];
|
||
if (o) {
|
||
var n = o.parse(t, this);
|
||
if (!n) return null;
|
||
if (this.expectedType) {
|
||
var s = this.expectedType, a = n.type;
|
||
if ("string" !== s.kind && "number" !== s.kind && "boolean" !== s.kind && "object" !== s.kind && "array" !== s.kind || "value" !== a.kind) if ("color" !== s.kind && "formatted" !== s.kind || "value" !== a.kind && "string" !== a.kind) {
|
||
if (this.checkSubtype(s, a)) return null
|
||
} else n = i(n, s, e.typeAnnotation || "coerce"); else n = i(n, s, e.typeAnnotation || "assert")
|
||
}
|
||
if (!(n instanceof gt) && function t(e) {
|
||
if (e instanceof Lt) return t(e.boundExpression);
|
||
if (e instanceof St && "error" === e.name) return !1;
|
||
if (e instanceof Et) return !1;
|
||
var i = e instanceof wt || e instanceof vt;
|
||
var r = !0;
|
||
e.eachChild(function (e) {
|
||
r = i ? r && t(e) : r && e instanceof gt
|
||
});
|
||
if (!r) return !1;
|
||
return Tt(e) && Pt(e, ["zoom", "heatmap-density", "line-progress", "accumulated", "is-supported-script"])
|
||
}(n)) {
|
||
var l = new Ct;
|
||
try {
|
||
n = new gt(n.type, n.evaluate(l))
|
||
} catch (t) {
|
||
return this.error(t.message), null
|
||
}
|
||
}
|
||
return n
|
||
}
|
||
return this.error('Unknown expression "' + r + '". If you wanted a literal array, use ["literal", [...]].', 0)
|
||
}
|
||
return void 0 === t ? this.error("'undefined' value invalid. Use null instead.") : "object" == typeof t ? this.error('Bare objects invalid. Use ["literal", {...}] instead.') : this.error("Expected an array, but found " + typeof t + " instead.")
|
||
}, It.prototype.concat = function (t, e, i) {
|
||
var r = "number" == typeof t ? this.path.concat(t) : this.path,
|
||
o = i ? this.scope.concat(i) : this.scope;
|
||
return new It(this.registry, r, e || null, o, this.errors)
|
||
}, It.prototype.error = function (t) {
|
||
for (var e = [], i = arguments.length - 1; i-- > 0;) e[i] = arguments[i + 1];
|
||
var r = "" + this.key + e.map(function (t) {
|
||
return "[" + t + "]"
|
||
}).join("");
|
||
this.errors.push(new H(r, t))
|
||
}, It.prototype.checkSubtype = function (t, e) {
|
||
var i = st(t, e);
|
||
return i && this.error(i), i
|
||
};
|
||
var Mt = function (t, e, i) {
|
||
this.type = t, this.input = e, this.labels = [], this.outputs = [];
|
||
for (var r = 0, o = i; r < o.length; r += 1) {
|
||
var n = o[r], s = n[0], a = n[1];
|
||
this.labels.push(s), this.outputs.push(a)
|
||
}
|
||
};
|
||
Mt.parse = function (t, e) {
|
||
var i = t[1], r = t.slice(2);
|
||
if (t.length - 1 < 4) return e.error("Expected at least 4 arguments, but found only " + (t.length - 1) + ".");
|
||
if ((t.length - 1) % 2 != 0) return e.error("Expected an even number of arguments.");
|
||
if (!(i = e.parse(i, 1, Z))) return null;
|
||
var o = [], n = null;
|
||
e.expectedType && "value" !== e.expectedType.kind && (n = e.expectedType), r.unshift(-1 / 0);
|
||
for (var s = 0; s < r.length; s += 2) {
|
||
var a = r[s], l = r[s + 1], h = s + 1, u = s + 2;
|
||
if ("number" != typeof a) return e.error('Input/output pairs for "step" expressions must be defined using literal numeric values (not computed expressions) for the input values.', h);
|
||
if (o.length && o[o.length - 1][0] >= a) return e.error('Input/output pairs for "step" expressions must be arranged with input values in strictly ascending order.', h);
|
||
var c = e.parse(l, u, n);
|
||
if (!c) return null;
|
||
n = n || c.type, o.push([a, c])
|
||
}
|
||
return new Mt(n, i, o)
|
||
}, Mt.prototype.evaluate = function (t) {
|
||
var e = this.labels, i = this.outputs;
|
||
if (1 === e.length) return i[0].evaluate(t);
|
||
var r = this.input.evaluate(t);
|
||
if (r <= e[0]) return i[0].evaluate(t);
|
||
var o = e.length;
|
||
return r >= e[o - 1] ? i[o - 1].evaluate(t) : i[Ot(e, r)].evaluate(t)
|
||
}, Mt.prototype.eachChild = function (t) {
|
||
t(this.input);
|
||
for (var e = 0, i = this.outputs; e < i.length; e += 1) {
|
||
t(i[e])
|
||
}
|
||
}, Mt.prototype.possibleOutputs = function () {
|
||
var t;
|
||
return (t = []).concat.apply(t, this.outputs.map(function (t) {
|
||
return t.possibleOutputs()
|
||
}))
|
||
}, Mt.prototype.serialize = function () {
|
||
for (var t = ["step", this.input.serialize()], e = 0; e < this.labels.length; e++) e > 0 && t.push(this.labels[e]), t.push(this.outputs[e].serialize());
|
||
return t
|
||
};
|
||
var At = kt;
|
||
|
||
function kt(t, e, i, r) {
|
||
this.cx = 3 * t, this.bx = 3 * (i - t) - this.cx, this.ax = 1 - this.cx - this.bx, this.cy = 3 * e, this.by = 3 * (r - e) - this.cy, this.ay = 1 - this.cy - this.by, this.p1x = t, this.p1y = r, this.p2x = i, this.p2y = r
|
||
}
|
||
|
||
function Ft(t, e, i) {
|
||
return t * (1 - i) + e * i
|
||
}
|
||
|
||
kt.prototype.sampleCurveX = function (t) {
|
||
return ((this.ax * t + this.bx) * t + this.cx) * t
|
||
}, kt.prototype.sampleCurveY = function (t) {
|
||
return ((this.ay * t + this.by) * t + this.cy) * t
|
||
}, kt.prototype.sampleCurveDerivativeX = function (t) {
|
||
return (3 * this.ax * t + 2 * this.bx) * t + this.cx
|
||
}, kt.prototype.solveCurveX = function (t, e) {
|
||
var i, r, o, n, s;
|
||
for (void 0 === e && (e = 1e-6), o = t, s = 0; s < 8; s++) {
|
||
if (n = this.sampleCurveX(o) - t, Math.abs(n) < e) return o;
|
||
var a = this.sampleCurveDerivativeX(o);
|
||
if (Math.abs(a) < 1e-6) break;
|
||
o -= n / a
|
||
}
|
||
if ((o = t) < (i = 0)) return i;
|
||
if (o > (r = 1)) return r;
|
||
for (; i < r;) {
|
||
if (n = this.sampleCurveX(o), Math.abs(n - t) < e) return o;
|
||
t > n ? i = o : r = o, o = .5 * (r - i) + i
|
||
}
|
||
return o
|
||
}, kt.prototype.solve = function (t, e) {
|
||
return this.sampleCurveY(this.solveCurveX(t, e))
|
||
};
|
||
var Nt = Object.freeze({
|
||
number: Ft, color: function (t, e, i) {
|
||
return new lt(Ft(t.r, e.r, i), Ft(t.g, e.g, i), Ft(t.b, e.b, i), Ft(t.a, e.a, i))
|
||
}, array: function (t, e, i) {
|
||
return t.map(function (t, r) {
|
||
return Ft(t, e[r], i)
|
||
})
|
||
}
|
||
}), Dt = .95047, Gt = 1, jt = 1.08883, zt = 4 / 29, Ut = 6 / 29, Bt = 3 * Ut * Ut, Vt = Ut * Ut * Ut,
|
||
Yt = Math.PI / 180, Wt = 180 / Math.PI;
|
||
|
||
function Ht(t) {
|
||
return t > Vt ? Math.pow(t, 1 / 3) : t / Bt + zt
|
||
}
|
||
|
||
function Xt(t) {
|
||
return t > Ut ? t * t * t : Bt * (t - zt)
|
||
}
|
||
|
||
function qt(t) {
|
||
return 255 * (t <= .0031308 ? 12.92 * t : 1.055 * Math.pow(t, 1 / 2.4) - .055)
|
||
}
|
||
|
||
function Zt(t) {
|
||
return (t /= 255) <= .04045 ? t / 12.92 : Math.pow((t + .055) / 1.055, 2.4)
|
||
}
|
||
|
||
function Kt(t) {
|
||
var e = Zt(t.r), i = Zt(t.g), r = Zt(t.b),
|
||
o = Ht((.4124564 * e + .3575761 * i + .1804375 * r) / Dt),
|
||
n = Ht((.2126729 * e + .7151522 * i + .072175 * r) / Gt);
|
||
return {
|
||
l: 116 * n - 16,
|
||
a: 500 * (o - n),
|
||
b: 200 * (n - Ht((.0193339 * e + .119192 * i + .9503041 * r) / jt)),
|
||
alpha: t.a
|
||
}
|
||
}
|
||
|
||
function Jt(t) {
|
||
var e = (t.l + 16) / 116, i = isNaN(t.a) ? e : e + t.a / 500, r = isNaN(t.b) ? e : e - t.b / 200;
|
||
return e = Gt * Xt(e), i = Dt * Xt(i), r = jt * Xt(r), new lt(qt(3.2404542 * i - 1.5371385 * e - .4985314 * r), qt(-.969266 * i + 1.8760108 * e + .041556 * r), qt(.0556434 * i - .2040259 * e + 1.0572252 * r), t.alpha)
|
||
}
|
||
|
||
function $t(t, e, i) {
|
||
var r = e - t;
|
||
return t + i * (r > 180 || r < -180 ? r - 360 * Math.round(r / 360) : r)
|
||
}
|
||
|
||
var Qt = {
|
||
forward: Kt, reverse: Jt, interpolate: function (t, e, i) {
|
||
return {
|
||
l: Ft(t.l, e.l, i),
|
||
a: Ft(t.a, e.a, i),
|
||
b: Ft(t.b, e.b, i),
|
||
alpha: Ft(t.alpha, e.alpha, i)
|
||
}
|
||
}
|
||
}, te = {
|
||
forward: function (t) {
|
||
var e = Kt(t), i = e.l, r = e.a, o = e.b, n = Math.atan2(o, r) * Wt;
|
||
return {h: n < 0 ? n + 360 : n, c: Math.sqrt(r * r + o * o), l: i, alpha: t.a}
|
||
}, reverse: function (t) {
|
||
var e = t.h * Yt, i = t.c;
|
||
return Jt({l: t.l, a: Math.cos(e) * i, b: Math.sin(e) * i, alpha: t.alpha})
|
||
}, interpolate: function (t, e, i) {
|
||
return {
|
||
h: $t(t.h, e.h, i),
|
||
c: Ft(t.c, e.c, i),
|
||
l: Ft(t.l, e.l, i),
|
||
alpha: Ft(t.alpha, e.alpha, i)
|
||
}
|
||
}
|
||
}, ee = Object.freeze({lab: Qt, hcl: te}), ie = function (t, e, i, r, o) {
|
||
this.type = t, this.operator = e, this.interpolation = i, this.input = r, this.labels = [], this.outputs = [];
|
||
for (var n = 0, s = o; n < s.length; n += 1) {
|
||
var a = s[n], l = a[0], h = a[1];
|
||
this.labels.push(l), this.outputs.push(h)
|
||
}
|
||
};
|
||
|
||
function re(t, e, i, r) {
|
||
var o = r - i, n = t - i;
|
||
return 0 === o ? 0 : 1 === e ? n / o : (Math.pow(e, n) - 1) / (Math.pow(e, o) - 1)
|
||
}
|
||
|
||
ie.interpolationFactor = function (t, e, i, r) {
|
||
var o = 0;
|
||
if ("exponential" === t.name) o = re(e, t.base, i, r); else if ("linear" === t.name) o = re(e, 1, i, r); else if ("cubic-bezier" === t.name) {
|
||
var n = t.controlPoints;
|
||
o = new At(n[0], n[1], n[2], n[3]).solve(re(e, 1, i, r))
|
||
}
|
||
return o
|
||
}, ie.parse = function (t, e) {
|
||
var i = t[0], r = t[1], o = t[2], n = t.slice(3);
|
||
if (!Array.isArray(r) || 0 === r.length) return e.error("Expected an interpolation type expression.", 1);
|
||
if ("linear" === r[0]) r = {name: "linear"}; else if ("exponential" === r[0]) {
|
||
var s = r[1];
|
||
if ("number" != typeof s) return e.error("Exponential interpolation requires a numeric base.", 1, 1);
|
||
r = {name: "exponential", base: s}
|
||
} else {
|
||
if ("cubic-bezier" !== r[0]) return e.error("Unknown interpolation type " + String(r[0]), 1, 0);
|
||
var a = r.slice(1);
|
||
if (4 !== a.length || a.some(function (t) {
|
||
return "number" != typeof t || t < 0 || t > 1
|
||
})) return e.error("Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.", 1);
|
||
r = {name: "cubic-bezier", controlPoints: a}
|
||
}
|
||
if (t.length - 1 < 4) return e.error("Expected at least 4 arguments, but found only " + (t.length - 1) + ".");
|
||
if ((t.length - 1) % 2 != 0) return e.error("Expected an even number of arguments.");
|
||
if (!(o = e.parse(o, 2, Z))) return null;
|
||
var l = [], h = null;
|
||
"interpolate-hcl" === i || "interpolate-lab" === i ? h = $ : e.expectedType && "value" !== e.expectedType.kind && (h = e.expectedType);
|
||
for (var u = 0; u < n.length; u += 2) {
|
||
var c = n[u], p = n[u + 1], d = u + 3, f = u + 4;
|
||
if ("number" != typeof c) return e.error('Input/output pairs for "interpolate" expressions must be defined using literal numeric values (not computed expressions) for the input values.', d);
|
||
if (l.length && l[l.length - 1][0] >= c) return e.error('Input/output pairs for "interpolate" expressions must be arranged with input values in strictly ascending order.', d);
|
||
var g = e.parse(p, f, h);
|
||
if (!g) return null;
|
||
h = h || g.type, l.push([c, g])
|
||
}
|
||
return "number" === h.kind || "color" === h.kind || "array" === h.kind && "number" === h.itemType.kind && "number" == typeof h.N ? new ie(h, i, r, o, l) : e.error("Type " + ot(h) + " is not interpolatable.")
|
||
}, ie.prototype.evaluate = function (t) {
|
||
var e = this.labels, i = this.outputs;
|
||
if (1 === e.length) return i[0].evaluate(t);
|
||
var r = this.input.evaluate(t);
|
||
if (r <= e[0]) return i[0].evaluate(t);
|
||
var o = e.length;
|
||
if (r >= e[o - 1]) return i[o - 1].evaluate(t);
|
||
var n = Ot(e, r), s = e[n], a = e[n + 1], l = ie.interpolationFactor(this.interpolation, r, s, a),
|
||
h = i[n].evaluate(t), u = i[n + 1].evaluate(t);
|
||
return "interpolate" === this.operator ? Nt[this.type.kind.toLowerCase()](h, u, l) : "interpolate-hcl" === this.operator ? te.reverse(te.interpolate(te.forward(h), te.forward(u), l)) : Qt.reverse(Qt.interpolate(Qt.forward(h), Qt.forward(u), l))
|
||
}, ie.prototype.eachChild = function (t) {
|
||
t(this.input);
|
||
for (var e = 0, i = this.outputs; e < i.length; e += 1) {
|
||
t(i[e])
|
||
}
|
||
}, ie.prototype.possibleOutputs = function () {
|
||
var t;
|
||
return (t = []).concat.apply(t, this.outputs.map(function (t) {
|
||
return t.possibleOutputs()
|
||
}))
|
||
}, ie.prototype.serialize = function () {
|
||
var t;
|
||
t = "linear" === this.interpolation.name ? ["linear"] : "exponential" === this.interpolation.name ? 1 === this.interpolation.base ? ["linear"] : ["exponential", this.interpolation.base] : ["cubic-bezier"].concat(this.interpolation.controlPoints);
|
||
for (var e = [this.operator, t, this.input.serialize()], i = 0; i < this.labels.length; i++) e.push(this.labels[i], this.outputs[i].serialize());
|
||
return e
|
||
};
|
||
var oe = function (t, e) {
|
||
this.type = t, this.args = e
|
||
};
|
||
oe.parse = function (t, e) {
|
||
if (t.length < 2) return e.error("Expectected at least one argument.");
|
||
var i = null, r = e.expectedType;
|
||
r && "value" !== r.kind && (i = r);
|
||
for (var o = [], n = 0, s = t.slice(1); n < s.length; n += 1) {
|
||
var a = s[n], l = e.parse(a, 1 + o.length, i, void 0, {typeAnnotation: "omit"});
|
||
if (!l) return null;
|
||
i = i || l.type, o.push(l)
|
||
}
|
||
var h = r && o.some(function (t) {
|
||
return st(r, t.type)
|
||
});
|
||
return new oe(h ? tt : i, o)
|
||
}, oe.prototype.evaluate = function (t) {
|
||
for (var e = null, i = 0, r = this.args; i < r.length; i += 1) {
|
||
if (null !== (e = r[i].evaluate(t))) break
|
||
}
|
||
return e
|
||
}, oe.prototype.eachChild = function (t) {
|
||
this.args.forEach(t)
|
||
}, oe.prototype.possibleOutputs = function () {
|
||
var t;
|
||
return (t = []).concat.apply(t, this.args.map(function (t) {
|
||
return t.possibleOutputs()
|
||
}))
|
||
}, oe.prototype.serialize = function () {
|
||
var t = ["coalesce"];
|
||
return this.eachChild(function (e) {
|
||
t.push(e.serialize())
|
||
}), t
|
||
};
|
||
var ne = function (t, e) {
|
||
this.type = e.type, this.bindings = [].concat(t), this.result = e
|
||
};
|
||
ne.prototype.evaluate = function (t) {
|
||
return this.result.evaluate(t)
|
||
}, ne.prototype.eachChild = function (t) {
|
||
for (var e = 0, i = this.bindings; e < i.length; e += 1) {
|
||
t(i[e][1])
|
||
}
|
||
t(this.result)
|
||
}, ne.parse = function (t, e) {
|
||
if (t.length < 4) return e.error("Expected at least 3 arguments, but found " + (t.length - 1) + " instead.");
|
||
for (var i = [], r = 1; r < t.length - 1; r += 2) {
|
||
var o = t[r];
|
||
if ("string" != typeof o) return e.error("Expected string, but found " + typeof o + " instead.", r);
|
||
if (/[^a-zA-Z0-9_]/.test(o)) return e.error("Variable names must contain only alphanumeric characters or '_'.", r);
|
||
var n = e.parse(t[r + 1], r + 1);
|
||
if (!n) return null;
|
||
i.push([o, n])
|
||
}
|
||
var s = e.parse(t[t.length - 1], t.length - 1, e.expectedType, i);
|
||
return s ? new ne(i, s) : null
|
||
}, ne.prototype.possibleOutputs = function () {
|
||
return this.result.possibleOutputs()
|
||
}, ne.prototype.serialize = function () {
|
||
for (var t = ["let"], e = 0, i = this.bindings; e < i.length; e += 1) {
|
||
var r = i[e], o = r[0], n = r[1];
|
||
t.push(o, n.serialize())
|
||
}
|
||
return t.push(this.result.serialize()), t
|
||
};
|
||
var se = function (t, e, i) {
|
||
this.type = t, this.index = e, this.input = i
|
||
};
|
||
se.parse = function (t, e) {
|
||
if (3 !== t.length) return e.error("Expected 2 arguments, but found " + (t.length - 1) + " instead.");
|
||
var i = e.parse(t[1], 1, Z), r = e.parse(t[2], 2, rt(e.expectedType || tt));
|
||
if (!i || !r) return null;
|
||
var o = r.type;
|
||
return new se(o.itemType, i, r)
|
||
}, se.prototype.evaluate = function (t) {
|
||
var e = this.index.evaluate(t), i = this.input.evaluate(t);
|
||
if (e < 0) throw new mt("Array index out of bounds: " + e + " < 0.");
|
||
if (e >= i.length) throw new mt("Array index out of bounds: " + e + " > " + (i.length - 1) + ".");
|
||
if (e !== Math.floor(e)) throw new mt("Array index must be an integer, but found " + e + " instead.");
|
||
return i[e]
|
||
}, se.prototype.eachChild = function (t) {
|
||
t(this.index), t(this.input)
|
||
}, se.prototype.possibleOutputs = function () {
|
||
return [void 0]
|
||
}, se.prototype.serialize = function () {
|
||
return ["at", this.index.serialize(), this.input.serialize()]
|
||
};
|
||
var ae = function (t, e, i, r, o, n) {
|
||
this.inputType = t, this.type = e, this.input = i, this.cases = r, this.outputs = o, this.otherwise = n
|
||
};
|
||
ae.parse = function (t, e) {
|
||
if (t.length < 5) return e.error("Expected at least 4 arguments, but found only " + (t.length - 1) + ".");
|
||
if (t.length % 2 != 1) return e.error("Expected an even number of arguments.");
|
||
var i, r;
|
||
e.expectedType && "value" !== e.expectedType.kind && (r = e.expectedType);
|
||
for (var o = {}, n = [], s = 2; s < t.length - 1; s += 2) {
|
||
var a = t[s], l = t[s + 1];
|
||
Array.isArray(a) || (a = [a]);
|
||
var h = e.concat(s);
|
||
if (0 === a.length) return h.error("Expected at least one branch label.");
|
||
for (var u = 0, c = a; u < c.length; u += 1) {
|
||
var p = c[u];
|
||
if ("number" != typeof p && "string" != typeof p) return h.error("Branch labels must be numbers or strings.");
|
||
if ("number" == typeof p && Math.abs(p) > Number.MAX_SAFE_INTEGER) return h.error("Branch labels must be integers no larger than " + Number.MAX_SAFE_INTEGER + ".");
|
||
if ("number" == typeof p && Math.floor(p) !== p) return h.error("Numeric branch labels must be integer values.");
|
||
if (i) {
|
||
if (h.checkSubtype(i, dt(p))) return null
|
||
} else i = dt(p);
|
||
if (void 0 !== o[String(p)]) return h.error("Branch labels must be unique.");
|
||
o[String(p)] = n.length
|
||
}
|
||
var d = e.parse(l, s, r);
|
||
if (!d) return null;
|
||
r = r || d.type, n.push(d)
|
||
}
|
||
var f = e.parse(t[1], 1, tt);
|
||
if (!f) return null;
|
||
var g = e.parse(t[t.length - 1], t.length - 1, r);
|
||
return g ? "value" !== f.type.kind && e.concat(1).checkSubtype(i, f.type) ? null : new ae(i, r, f, o, n, g) : null
|
||
}, ae.prototype.evaluate = function (t) {
|
||
var e = this.input.evaluate(t);
|
||
return (dt(e) === this.inputType && this.outputs[this.cases[e]] || this.otherwise).evaluate(t)
|
||
}, ae.prototype.eachChild = function (t) {
|
||
t(this.input), this.outputs.forEach(t), t(this.otherwise)
|
||
}, ae.prototype.possibleOutputs = function () {
|
||
var t;
|
||
return (t = []).concat.apply(t, this.outputs.map(function (t) {
|
||
return t.possibleOutputs()
|
||
})).concat(this.otherwise.possibleOutputs())
|
||
}, ae.prototype.serialize = function () {
|
||
for (var t = this, e = ["match", this.input.serialize()], i = [], r = {}, o = 0, n = Object.keys(this.cases).sort(); o < n.length; o += 1) {
|
||
var s = n[o];
|
||
void 0 === (c = r[this.cases[s]]) ? (r[this.cases[s]] = i.length, i.push([this.cases[s], [s]])) : i[c][1].push(s)
|
||
}
|
||
for (var a = function (e) {
|
||
return "number" === t.inputType.kind ? Number(e) : e
|
||
}, l = 0, h = i; l < h.length; l += 1) {
|
||
var u = h[l], c = u[0], p = u[1];
|
||
1 === p.length ? e.push(a(p[0])) : e.push(p.map(a)), e.push(this.outputs[outputIndex$1].serialize())
|
||
}
|
||
return e.push(this.otherwise.serialize()), e
|
||
};
|
||
var le = function (t, e, i) {
|
||
this.type = t, this.branches = e, this.otherwise = i
|
||
};
|
||
|
||
function he(t, e) {
|
||
return "==" === t || "!=" === t ? "boolean" === e.kind || "string" === e.kind || "number" === e.kind || "null" === e.kind || "value" === e.kind : "string" === e.kind || "number" === e.kind || "value" === e.kind
|
||
}
|
||
|
||
function ue(t, e, i, r) {
|
||
return 0 === r.compare(e, i)
|
||
}
|
||
|
||
function ce(t, e, i) {
|
||
var r = "==" !== t && "!=" !== t;
|
||
return function () {
|
||
function o(t, e, i) {
|
||
this.type = J, this.lhs = t, this.rhs = e, this.collator = i, this.hasUntypedArgument = "value" === t.type.kind || "value" === e.type.kind
|
||
}
|
||
|
||
return o.parse = function (t, e) {
|
||
if (3 !== t.length && 4 !== t.length) return e.error("Expected two or three arguments.");
|
||
var i = t[0], n = e.parse(t[1], 1, tt);
|
||
if (!n) return null;
|
||
if (!he(i, n.type)) return e.concat(1).error('"' + i + "\" comparisons are not supported for type '" + ot(n.type) + "'.");
|
||
var s = e.parse(t[2], 2, tt);
|
||
if (!s) return null;
|
||
if (!he(i, s.type)) return e.concat(2).error('"' + i + "\" comparisons are not supported for type '" + ot(s.type) + "'.");
|
||
if (n.type.kind !== s.type.kind && "value" !== n.type.kind && "value" !== s.type.kind) return e.error("Cannot compare types '" + ot(n.type) + "' and '" + ot(s.type) + "'.");
|
||
r && ("value" === n.type.kind && "value" !== s.type.kind ? n = new vt(s.type, [n]) : "value" !== n.type.kind && "value" === s.type.kind && (s = new vt(n.type, [s])));
|
||
var a = null;
|
||
if (4 === t.length) {
|
||
if ("string" !== n.type.kind && "string" !== s.type.kind && "value" !== n.type.kind && "value" !== s.type.kind) return e.error("Cannot use collator to compare non-string types.");
|
||
if (!(a = e.parse(t[3], 3, et))) return null
|
||
}
|
||
return new o(n, s, a)
|
||
}, o.prototype.evaluate = function (o) {
|
||
var n = this.lhs.evaluate(o), s = this.rhs.evaluate(o);
|
||
if (r && this.hasUntypedArgument) {
|
||
var a = dt(n), l = dt(s);
|
||
if (a.kind !== l.kind || "string" !== a.kind && "number" !== a.kind) throw new mt('Expected arguments for "' + t + '" to be (string, string) or (number, number), but found (' + a.kind + ", " + l.kind + ") instead.")
|
||
}
|
||
if (this.collator && !r && this.hasUntypedArgument) {
|
||
var h = dt(n), u = dt(s);
|
||
if ("string" !== h.kind || "string" !== u.kind) return e(o, n, s)
|
||
}
|
||
return this.collator ? i(o, n, s, this.collator.evaluate(o)) : e(o, n, s)
|
||
}, o.prototype.eachChild = function (t) {
|
||
t(this.lhs), t(this.rhs), this.collator && t(this.collator)
|
||
}, o.prototype.possibleOutputs = function () {
|
||
return [!0, !1]
|
||
}, o.prototype.serialize = function () {
|
||
var e = [t];
|
||
return this.eachChild(function (t) {
|
||
e.push(t.serialize())
|
||
}), e
|
||
}, o
|
||
}()
|
||
}
|
||
|
||
le.parse = function (t, e) {
|
||
if (t.length < 4) return e.error("Expected at least 3 arguments, but found only " + (t.length - 1) + ".");
|
||
if (t.length % 2 != 0) return e.error("Expected an odd number of arguments.");
|
||
var i;
|
||
e.expectedType && "value" !== e.expectedType.kind && (i = e.expectedType);
|
||
for (var r = [], o = 1; o < t.length - 1; o += 2) {
|
||
var n = e.parse(t[o], o, J);
|
||
if (!n) return null;
|
||
var s = e.parse(t[o + 1], o + 1, i);
|
||
if (!s) return null;
|
||
r.push([n, s]), i = i || s.type
|
||
}
|
||
var a = e.parse(t[t.length - 1], t.length - 1, i);
|
||
return a ? new le(i, r, a) : null
|
||
}, le.prototype.evaluate = function (t) {
|
||
for (var e = 0, i = this.branches; e < i.length; e += 1) {
|
||
var r = i[e], o = r[0], n = r[1];
|
||
if (o.evaluate(t)) return n.evaluate(t)
|
||
}
|
||
return this.otherwise.evaluate(t)
|
||
}, le.prototype.eachChild = function (t) {
|
||
for (var e = 0, i = this.branches; e < i.length; e += 1) {
|
||
var r = i[e], o = r[0], n = r[1];
|
||
t(o), t(n)
|
||
}
|
||
t(this.otherwise)
|
||
}, le.prototype.possibleOutputs = function () {
|
||
var t;
|
||
return (t = []).concat.apply(t, this.branches.map(function (t) {
|
||
t[0];
|
||
return t[1].possibleOutputs()
|
||
})).concat(this.otherwise.possibleOutputs())
|
||
}, le.prototype.serialize = function () {
|
||
var t = ["case"];
|
||
return this.eachChild(function (e) {
|
||
t.push(e.serialize())
|
||
}), t
|
||
};
|
||
var pe = ce("==", function (t, e, i) {
|
||
return e === i
|
||
}, ue), de = ce("!=", function (t, e, i) {
|
||
return e !== i
|
||
}, function (t, e, i, r) {
|
||
return !ue(0, e, i, r)
|
||
}), fe = ce("<", function (t, e, i) {
|
||
return e < i
|
||
}, function (t, e, i, r) {
|
||
return r.compare(e, i) < 0
|
||
}), ge = ce(">", function (t, e, i) {
|
||
return e > i
|
||
}, function (t, e, i, r) {
|
||
return r.compare(e, i) > 0
|
||
}), me = ce("<=", function (t, e, i) {
|
||
return e <= i
|
||
}, function (t, e, i, r) {
|
||
return r.compare(e, i) <= 0
|
||
}), ye = ce(">=", function (t, e, i) {
|
||
return e >= i
|
||
}, function (t, e, i, r) {
|
||
return r.compare(e, i) >= 0
|
||
}), ve = function (t, e, i, r, o) {
|
||
this.type = K, this.number = t, this.locale = e, this.currency = i, this.minFractionDigits = r, this.maxFractionDigits = o
|
||
};
|
||
ve.parse = function (t, e) {
|
||
if (3 !== t.length) return e.error("Expected two arguments.");
|
||
var i = e.parse(t[1], 1, Z);
|
||
if (!i) return null;
|
||
var r = t[2];
|
||
if ("object" != typeof r || Array.isArray(r)) return e.error("NumberFormat options argument must be an object.");
|
||
var o = null;
|
||
if (r.locale && !(o = e.parse(r.locale, 1, K))) return null;
|
||
var n = null;
|
||
if (r.currency && !(n = e.parse(r.currency, 1, K))) return null;
|
||
var s = null;
|
||
if (r["min-fraction-digits"] && !(s = e.parse(r["min-fraction-digits"], 1, Z))) return null;
|
||
var a = null;
|
||
return r["max-fraction-digits"] && !(a = e.parse(r["max-fraction-digits"], 1, Z)) ? null : new ve(i, o, n, s, a)
|
||
}, ve.prototype.evaluate = function (t) {
|
||
return new Intl.NumberFormat(this.locale ? this.locale.evaluate(t) : [], {
|
||
style: this.currency ? "currency" : "decimal",
|
||
currency: this.currency ? this.currency.evaluate(t) : void 0,
|
||
minimumFractionDigits: this.minFractionDigits ? this.minFractionDigits.evaluate(t) : void 0,
|
||
maximumFractionDigits: this.maxFractionDigits ? this.maxFractionDigits.evaluate(t) : void 0
|
||
}).format(this.number.evaluate(t))
|
||
}, ve.prototype.eachChild = function (t) {
|
||
t(this.number), this.locale && t(this.locale), this.currency && t(this.currency), this.minFractionDigits && t(this.minFractionDigits), this.maxFractionDigits && t(this.maxFractionDigits)
|
||
}, ve.prototype.possibleOutputs = function () {
|
||
return [void 0]
|
||
}, ve.prototype.serialize = function () {
|
||
var t = {};
|
||
return this.locale && (t.locale = this.locale.serialize()), this.currency && (t.currency = this.currency.serialize()), this.minFractionDigits && (t["min-fraction-digits"] = this.minFractionDigits.serialize()), this.maxFractionDigits && (t["max-fraction-digits"] = this.maxFractionDigits.serialize()), ["number-format", this.number.serialize(), t]
|
||
};
|
||
var _e = function (t) {
|
||
this.type = Z, this.input = t
|
||
};
|
||
_e.parse = function (t, e) {
|
||
if (2 !== t.length) return e.error("Expected 1 argument, but found " + (t.length - 1) + " instead.");
|
||
var i = e.parse(t[1], 1);
|
||
return i ? "array" !== i.type.kind && "string" !== i.type.kind && "value" !== i.type.kind ? e.error("Expected argument of type string or array, but found " + ot(i.type) + " instead.") : new _e(i) : null
|
||
}, _e.prototype.evaluate = function (t) {
|
||
var e = this.input.evaluate(t);
|
||
if ("string" == typeof e) return e.length;
|
||
if (Array.isArray(e)) return e.length;
|
||
throw new mt("Expected value to be of type string or array, but found " + ot(dt(e)) + " instead.")
|
||
}, _e.prototype.eachChild = function (t) {
|
||
t(this.input)
|
||
}, _e.prototype.possibleOutputs = function () {
|
||
return [void 0]
|
||
}, _e.prototype.serialize = function () {
|
||
var t = ["length"];
|
||
return this.eachChild(function (e) {
|
||
t.push(e.serialize())
|
||
}), t
|
||
};
|
||
var xe = {
|
||
"==": pe,
|
||
"!=": de,
|
||
">": ge,
|
||
"<": fe,
|
||
">=": ye,
|
||
"<=": me,
|
||
array: vt,
|
||
at: se,
|
||
boolean: vt,
|
||
case: le,
|
||
coalesce: oe,
|
||
collator: Et,
|
||
format: _t,
|
||
interpolate: ie,
|
||
"interpolate-hcl": ie,
|
||
"interpolate-lab": ie,
|
||
length: _e,
|
||
let: ne,
|
||
literal: gt,
|
||
match: ae,
|
||
number: vt,
|
||
"number-format": ve,
|
||
object: vt,
|
||
step: Mt,
|
||
string: vt,
|
||
"to-boolean": wt,
|
||
"to-color": wt,
|
||
"to-number": wt,
|
||
"to-string": wt,
|
||
var: Lt
|
||
};
|
||
|
||
function we(t, e) {
|
||
var i = e[0], r = e[1], o = e[2], n = e[3];
|
||
i = i.evaluate(t), r = r.evaluate(t), o = o.evaluate(t);
|
||
var s = n ? n.evaluate(t) : 1, a = pt(i, r, o, s);
|
||
if (a) throw new mt(a);
|
||
return new lt(i / 255 * s, r / 255 * s, o / 255 * s, s)
|
||
}
|
||
|
||
function be(t, e) {
|
||
return t in e
|
||
}
|
||
|
||
function Ce(t, e) {
|
||
var i = e[t];
|
||
return void 0 === i ? null : i
|
||
}
|
||
|
||
function Se(t) {
|
||
return {type: t}
|
||
}
|
||
|
||
function Ee(t) {
|
||
return {result: "success", value: t}
|
||
}
|
||
|
||
function Te(t) {
|
||
return {result: "error", value: t}
|
||
}
|
||
|
||
function Re(t) {
|
||
return "data-driven" === t["property-type"] || "cross-faded-data-driven" === t["property-type"]
|
||
}
|
||
|
||
function Pe(t) {
|
||
return !!t.expression && t.expression.parameters.indexOf("zoom") > -1
|
||
}
|
||
|
||
function Le(t) {
|
||
return !!t.expression && t.expression.interpolated
|
||
}
|
||
|
||
function Ie(t) {
|
||
return t instanceof Number ? "number" : t instanceof String ? "string" : t instanceof Boolean ? "boolean" : Array.isArray(t) ? "array" : null === t ? "null" : typeof t
|
||
}
|
||
|
||
function Oe(t) {
|
||
return "object" == typeof t && null !== t && !Array.isArray(t)
|
||
}
|
||
|
||
function Me(t) {
|
||
return t
|
||
}
|
||
|
||
function Ae(t, e) {
|
||
var i, r, o, n = "color" === e.type, s = t.stops && "object" == typeof t.stops[0][0],
|
||
a = s || void 0 !== t.property, l = s || !a, h = t.type || (Le(e) ? "exponential" : "interval");
|
||
if (n && ((t = W({}, t)).stops && (t.stops = t.stops.map(function (t) {
|
||
return [t[0], lt.parse(t[1])]
|
||
})), t.default ? t.default = lt.parse(t.default) : t.default = lt.parse(e.default)), t.colorSpace && "rgb" !== t.colorSpace && !ee[t.colorSpace]) throw new Error("Unknown color space: " + t.colorSpace);
|
||
if ("exponential" === h) i = De; else if ("interval" === h) i = Ne; else if ("categorical" === h) {
|
||
i = Fe, r = Object.create(null);
|
||
for (var u = 0, c = t.stops; u < c.length; u += 1) {
|
||
var p = c[u];
|
||
r[p[0]] = p[1]
|
||
}
|
||
o = typeof t.stops[0][0]
|
||
} else {
|
||
if ("identity" !== h) throw new Error('Unknown function type "' + h + '"');
|
||
i = Ge
|
||
}
|
||
if (s) {
|
||
for (var d = {}, f = [], g = 0; g < t.stops.length; g++) {
|
||
var m = t.stops[g], y = m[0].zoom;
|
||
void 0 === d[y] && (d[y] = {
|
||
zoom: y,
|
||
type: t.type,
|
||
property: t.property,
|
||
default: t.default,
|
||
stops: []
|
||
}, f.push(y)), d[y].stops.push([m[0].value, m[1]])
|
||
}
|
||
for (var v = [], _ = 0, x = f; _ < x.length; _ += 1) {
|
||
var w = x[_];
|
||
v.push([d[w].zoom, Ae(d[w], e)])
|
||
}
|
||
return {
|
||
kind: "composite",
|
||
interpolationFactor: ie.interpolationFactor.bind(void 0, {name: "linear"}),
|
||
zoomStops: v.map(function (t) {
|
||
return t[0]
|
||
}),
|
||
evaluate: function (i, r) {
|
||
var o = i.zoom;
|
||
return De({stops: v, base: t.base}, e, o).evaluate(o, r)
|
||
}
|
||
}
|
||
}
|
||
return l ? {
|
||
kind: "camera",
|
||
interpolationFactor: "exponential" === h ? ie.interpolationFactor.bind(void 0, {
|
||
name: "exponential",
|
||
base: void 0 !== t.base ? t.base : 1
|
||
}) : function () {
|
||
return 0
|
||
},
|
||
zoomStops: t.stops.map(function (t) {
|
||
return t[0]
|
||
}),
|
||
evaluate: function (n) {
|
||
var s = n.zoom;
|
||
return i(t, e, s, r, o)
|
||
}
|
||
} : {
|
||
kind: "source", evaluate: function (n, s) {
|
||
var a = s && s.properties ? s.properties[t.property] : void 0;
|
||
return void 0 === a ? ke(t.default, e.default) : i(t, e, a, r, o)
|
||
}
|
||
}
|
||
}
|
||
|
||
function ke(t, e, i) {
|
||
return void 0 !== t ? t : void 0 !== e ? e : void 0 !== i ? i : void 0
|
||
}
|
||
|
||
function Fe(t, e, i, r, o) {
|
||
return ke(typeof i === o ? r[i] : void 0, t.default, e.default)
|
||
}
|
||
|
||
function Ne(t, e, i) {
|
||
if ("number" !== Ie(i)) return ke(t.default, e.default);
|
||
var r = t.stops.length;
|
||
if (1 === r) return t.stops[0][1];
|
||
if (i <= t.stops[0][0]) return t.stops[0][1];
|
||
if (i >= t.stops[r - 1][0]) return t.stops[r - 1][1];
|
||
var o = je(t.stops, i);
|
||
return t.stops[o][1]
|
||
}
|
||
|
||
function De(t, e, i) {
|
||
var r = void 0 !== t.base ? t.base : 1;
|
||
if ("number" !== Ie(i)) return ke(t.default, e.default);
|
||
var o = t.stops.length;
|
||
if (1 === o) return t.stops[0][1];
|
||
if (i <= t.stops[0][0]) return t.stops[0][1];
|
||
if (i >= t.stops[o - 1][0]) return t.stops[o - 1][1];
|
||
var n = je(t.stops, i), s = function (t, e, i, r) {
|
||
var o = r - i, n = t - i;
|
||
return 0 === o ? 0 : 1 === e ? n / o : (Math.pow(e, n) - 1) / (Math.pow(e, o) - 1)
|
||
}(i, r, t.stops[n][0], t.stops[n + 1][0]), a = t.stops[n][1], l = t.stops[n + 1][1],
|
||
h = Nt[e.type] || Me;
|
||
if (t.colorSpace && "rgb" !== t.colorSpace) {
|
||
var u = ee[t.colorSpace];
|
||
h = function (t, e) {
|
||
return u.reverse(u.interpolate(u.forward(t), u.forward(e), s))
|
||
}
|
||
}
|
||
return "function" == typeof a.evaluate ? {
|
||
evaluate: function () {
|
||
for (var t = [], e = arguments.length; e--;) t[e] = arguments[e];
|
||
var i = a.evaluate.apply(void 0, t), r = l.evaluate.apply(void 0, t);
|
||
if (void 0 !== i && void 0 !== r) return h(i, r, s)
|
||
}
|
||
} : h(a, l, s)
|
||
}
|
||
|
||
function Ge(t, e, i) {
|
||
return "color" === e.type ? i = lt.parse(i) : "formatted" === e.type ? i = ct.fromString(i.toString()) : Ie(i) === e.type || "enum" === e.type && e.values[i] || (i = void 0), ke(i, t.default, e.default)
|
||
}
|
||
|
||
function je(t, e) {
|
||
for (var i, r, o = 0, n = t.length - 1, s = 0; o <= n;) {
|
||
if (i = t[s = Math.floor((o + n) / 2)][0], r = t[s + 1][0], e === i || e > i && e < r) return s;
|
||
i < e ? o = s + 1 : i > e && (n = s - 1)
|
||
}
|
||
return Math.max(s - 1, 0)
|
||
}
|
||
|
||
St.register(xe, {
|
||
error: [{kind: "error"}, [K], function (t, e) {
|
||
var i = e[0];
|
||
throw new mt(i.evaluate(t))
|
||
}],
|
||
typeof: [K, [tt], function (t, e) {
|
||
return ot(dt(e[0].evaluate(t)))
|
||
}],
|
||
"to-rgba": [rt(Z, 4), [$], function (t, e) {
|
||
return e[0].evaluate(t).toArray()
|
||
}],
|
||
rgb: [$, [Z, Z, Z], we],
|
||
rgba: [$, [Z, Z, Z, Z], we],
|
||
has: {
|
||
type: J, overloads: [[[K], function (t, e) {
|
||
return be(e[0].evaluate(t), t.properties())
|
||
}], [[K, Q], function (t, e) {
|
||
var i = e[0], r = e[1];
|
||
return be(i.evaluate(t), r.evaluate(t))
|
||
}]]
|
||
},
|
||
get: {
|
||
type: tt, overloads: [[[K], function (t, e) {
|
||
return Ce(e[0].evaluate(t), t.properties())
|
||
}], [[K, Q], function (t, e) {
|
||
var i = e[0], r = e[1];
|
||
return Ce(i.evaluate(t), r.evaluate(t))
|
||
}]]
|
||
},
|
||
"feature-state": [tt, [K], function (t, e) {
|
||
return Ce(e[0].evaluate(t), t.featureState || {})
|
||
}],
|
||
properties: [Q, [], function (t) {
|
||
return t.properties()
|
||
}],
|
||
"geometry-type": [K, [], function (t) {
|
||
return t.geometryType()
|
||
}],
|
||
id: [tt, [], function (t) {
|
||
return t.id()
|
||
}],
|
||
zoom: [Z, [], function (t) {
|
||
return t.globals.zoom
|
||
}],
|
||
"heatmap-density": [Z, [], function (t) {
|
||
return t.globals.heatmapDensity || 0
|
||
}],
|
||
"line-progress": [Z, [], function (t) {
|
||
return t.globals.lineProgress || 0
|
||
}],
|
||
accumulated: [tt, [], function (t) {
|
||
return void 0 === t.globals.accumulated ? null : t.globals.accumulated
|
||
}],
|
||
"+": [Z, Se(Z), function (t, e) {
|
||
for (var i = 0, r = 0, o = e; r < o.length; r += 1) {
|
||
i += o[r].evaluate(t)
|
||
}
|
||
return i
|
||
}],
|
||
"*": [Z, Se(Z), function (t, e) {
|
||
for (var i = 1, r = 0, o = e; r < o.length; r += 1) {
|
||
i *= o[r].evaluate(t)
|
||
}
|
||
return i
|
||
}],
|
||
"-": {
|
||
type: Z, overloads: [[[Z, Z], function (t, e) {
|
||
var i = e[0], r = e[1];
|
||
return i.evaluate(t) - r.evaluate(t)
|
||
}], [[Z], function (t, e) {
|
||
return -e[0].evaluate(t)
|
||
}]]
|
||
},
|
||
"/": [Z, [Z, Z], function (t, e) {
|
||
var i = e[0], r = e[1];
|
||
return i.evaluate(t) / r.evaluate(t)
|
||
}],
|
||
"%": [Z, [Z, Z], function (t, e) {
|
||
var i = e[0], r = e[1];
|
||
return i.evaluate(t) % r.evaluate(t)
|
||
}],
|
||
ln2: [Z, [], function () {
|
||
return Math.LN2
|
||
}],
|
||
pi: [Z, [], function () {
|
||
return Math.PI
|
||
}],
|
||
e: [Z, [], function () {
|
||
return Math.E
|
||
}],
|
||
"^": [Z, [Z, Z], function (t, e) {
|
||
var i = e[0], r = e[1];
|
||
return Math.pow(i.evaluate(t), r.evaluate(t))
|
||
}],
|
||
sqrt: [Z, [Z], function (t, e) {
|
||
var i = e[0];
|
||
return Math.sqrt(i.evaluate(t))
|
||
}],
|
||
log10: [Z, [Z], function (t, e) {
|
||
var i = e[0];
|
||
return Math.log(i.evaluate(t)) / Math.LN10
|
||
}],
|
||
ln: [Z, [Z], function (t, e) {
|
||
var i = e[0];
|
||
return Math.log(i.evaluate(t))
|
||
}],
|
||
log2: [Z, [Z], function (t, e) {
|
||
var i = e[0];
|
||
return Math.log(i.evaluate(t)) / Math.LN2
|
||
}],
|
||
sin: [Z, [Z], function (t, e) {
|
||
var i = e[0];
|
||
return Math.sin(i.evaluate(t))
|
||
}],
|
||
cos: [Z, [Z], function (t, e) {
|
||
var i = e[0];
|
||
return Math.cos(i.evaluate(t))
|
||
}],
|
||
tan: [Z, [Z], function (t, e) {
|
||
var i = e[0];
|
||
return Math.tan(i.evaluate(t))
|
||
}],
|
||
asin: [Z, [Z], function (t, e) {
|
||
var i = e[0];
|
||
return Math.asin(i.evaluate(t))
|
||
}],
|
||
acos: [Z, [Z], function (t, e) {
|
||
var i = e[0];
|
||
return Math.acos(i.evaluate(t))
|
||
}],
|
||
atan: [Z, [Z], function (t, e) {
|
||
var i = e[0];
|
||
return Math.atan(i.evaluate(t))
|
||
}],
|
||
min: [Z, Se(Z), function (t, e) {
|
||
return Math.min.apply(Math, e.map(function (e) {
|
||
return e.evaluate(t)
|
||
}))
|
||
}],
|
||
max: [Z, Se(Z), function (t, e) {
|
||
return Math.max.apply(Math, e.map(function (e) {
|
||
return e.evaluate(t)
|
||
}))
|
||
}],
|
||
abs: [Z, [Z], function (t, e) {
|
||
var i = e[0];
|
||
return Math.abs(i.evaluate(t))
|
||
}],
|
||
round: [Z, [Z], function (t, e) {
|
||
var i = e[0].evaluate(t);
|
||
return i < 0 ? -Math.round(-i) : Math.round(i)
|
||
}],
|
||
floor: [Z, [Z], function (t, e) {
|
||
var i = e[0];
|
||
return Math.floor(i.evaluate(t))
|
||
}],
|
||
ceil: [Z, [Z], function (t, e) {
|
||
var i = e[0];
|
||
return Math.ceil(i.evaluate(t))
|
||
}],
|
||
"filter-==": [J, [K, tt], function (t, e) {
|
||
var i = e[0], r = e[1];
|
||
return t.properties()[i.value] === r.value
|
||
}],
|
||
"filter-id-==": [J, [tt], function (t, e) {
|
||
var i = e[0];
|
||
return t.id() === i.value
|
||
}],
|
||
"filter-type-==": [J, [K], function (t, e) {
|
||
var i = e[0];
|
||
return t.geometryType() === i.value
|
||
}],
|
||
"filter-<": [J, [K, tt], function (t, e) {
|
||
var i = e[0], r = e[1], o = t.properties()[i.value], n = r.value;
|
||
return typeof o == typeof n && o < n
|
||
}],
|
||
"filter-id-<": [J, [tt], function (t, e) {
|
||
var i = e[0], r = t.id(), o = i.value;
|
||
return typeof r == typeof o && r < o
|
||
}],
|
||
"filter->": [J, [K, tt], function (t, e) {
|
||
var i = e[0], r = e[1], o = t.properties()[i.value], n = r.value;
|
||
return typeof o == typeof n && o > n
|
||
}],
|
||
"filter-id->": [J, [tt], function (t, e) {
|
||
var i = e[0], r = t.id(), o = i.value;
|
||
return typeof r == typeof o && r > o
|
||
}],
|
||
"filter-<=": [J, [K, tt], function (t, e) {
|
||
var i = e[0], r = e[1], o = t.properties()[i.value], n = r.value;
|
||
return typeof o == typeof n && o <= n
|
||
}],
|
||
"filter-id-<=": [J, [tt], function (t, e) {
|
||
var i = e[0], r = t.id(), o = i.value;
|
||
return typeof r == typeof o && r <= o
|
||
}],
|
||
"filter->=": [J, [K, tt], function (t, e) {
|
||
var i = e[0], r = e[1], o = t.properties()[i.value], n = r.value;
|
||
return typeof o == typeof n && o >= n
|
||
}],
|
||
"filter-id->=": [J, [tt], function (t, e) {
|
||
var i = e[0], r = t.id(), o = i.value;
|
||
return typeof r == typeof o && r >= o
|
||
}],
|
||
"filter-has": [J, [tt], function (t, e) {
|
||
return e[0].value in t.properties()
|
||
}],
|
||
"filter-has-id": [J, [], function (t) {
|
||
return null !== t.id()
|
||
}],
|
||
"filter-type-in": [J, [rt(K)], function (t, e) {
|
||
return e[0].value.indexOf(t.geometryType()) >= 0
|
||
}],
|
||
"filter-id-in": [J, [rt(tt)], function (t, e) {
|
||
return e[0].value.indexOf(t.id()) >= 0
|
||
}],
|
||
"filter-in-small": [J, [K, rt(tt)], function (t, e) {
|
||
var i = e[0];
|
||
return e[1].value.indexOf(t.properties()[i.value]) >= 0
|
||
}],
|
||
"filter-in-large": [J, [K, rt(tt)], function (t, e) {
|
||
var i = e[0], r = e[1];
|
||
return function (t, e, i, r) {
|
||
for (; i <= r;) {
|
||
var o = i + r >> 1;
|
||
if (e[o] === t) return !0;
|
||
e[o] > t ? r = o - 1 : i = o + 1
|
||
}
|
||
return !1
|
||
}(t.properties()[i.value], r.value, 0, r.value.length - 1)
|
||
}],
|
||
all: {
|
||
type: J, overloads: [[[J, J], function (t, e) {
|
||
var i = e[0], r = e[1];
|
||
return i.evaluate(t) && r.evaluate(t)
|
||
}], [Se(J), function (t, e) {
|
||
for (var i = 0, r = e; i < r.length; i += 1) {
|
||
if (!r[i].evaluate(t)) return !1
|
||
}
|
||
return !0
|
||
}]]
|
||
},
|
||
any: {
|
||
type: J, overloads: [[[J, J], function (t, e) {
|
||
var i = e[0], r = e[1];
|
||
return i.evaluate(t) || r.evaluate(t)
|
||
}], [Se(J), function (t, e) {
|
||
for (var i = 0, r = e; i < r.length; i += 1) {
|
||
if (r[i].evaluate(t)) return !0
|
||
}
|
||
return !1
|
||
}]]
|
||
},
|
||
"!": [J, [J], function (t, e) {
|
||
return !e[0].evaluate(t)
|
||
}],
|
||
"is-supported-script": [J, [K], function (t, e) {
|
||
var i = e[0], r = t.globals && t.globals.isSupportedScript;
|
||
return !r || r(i.evaluate(t))
|
||
}],
|
||
upcase: [K, [K], function (t, e) {
|
||
return e[0].evaluate(t).toUpperCase()
|
||
}],
|
||
downcase: [K, [K], function (t, e) {
|
||
return e[0].evaluate(t).toLowerCase()
|
||
}],
|
||
concat: [K, Se(tt), function (t, e) {
|
||
return e.map(function (e) {
|
||
return ft(e.evaluate(t))
|
||
}).join("")
|
||
}],
|
||
"resolved-locale": [K, [et], function (t, e) {
|
||
return e[0].evaluate(t).resolvedLocale()
|
||
}]
|
||
});
|
||
var ze = function (t, e) {
|
||
var i;
|
||
this.expression = t, this._warningHistory = {}, this._evaluator = new Ct, this._defaultValue = e ? "color" === (i = e).type && Oe(i.default) ? new lt(0, 0, 0, 0) : "color" === i.type ? lt.parse(i.default) || null : void 0 === i.default ? null : i.default : null, this._enumValues = e && "enum" === e.type ? e.values : null
|
||
};
|
||
|
||
function Ue(t) {
|
||
return Array.isArray(t) && t.length > 0 && "string" == typeof t[0] && t[0] in xe
|
||
}
|
||
|
||
function Be(t, e) {
|
||
var i = new It(xe, [], e ? function (t) {
|
||
var e = {color: $, string: K, number: Z, enum: K, boolean: J, formatted: it};
|
||
if ("array" === t.type) return rt(e[t.value] || tt, t.length);
|
||
return e[t.type]
|
||
}(e) : void 0),
|
||
r = i.parse(t, void 0, void 0, void 0, e && "string" === e.type ? {typeAnnotation: "coerce"} : void 0);
|
||
return r ? Ee(new ze(r, e)) : Te(i.errors)
|
||
}
|
||
|
||
ze.prototype.evaluateWithoutErrorHandling = function (t, e, i) {
|
||
return this._evaluator.globals = t, this._evaluator.feature = e, this._evaluator.featureState = i, this.expression.evaluate(this._evaluator)
|
||
}, ze.prototype.evaluate = function (t, e, i) {
|
||
this._evaluator.globals = t, this._evaluator.feature = e || null, this._evaluator.featureState = i || null;
|
||
try {
|
||
var r = this.expression.evaluate(this._evaluator);
|
||
if (null == r) return this._defaultValue;
|
||
if (this._enumValues && !(r in this._enumValues)) throw new mt("Expected value to be one of " + Object.keys(this._enumValues).map(function (t) {
|
||
return JSON.stringify(t)
|
||
}).join(", ") + ", but found " + JSON.stringify(r) + " instead.");
|
||
return r
|
||
} catch (t) {
|
||
return this._warningHistory[t.message] || (this._warningHistory[t.message] = !0, "undefined" != typeof console && console.warn(t.message)), this._defaultValue
|
||
}
|
||
};
|
||
var Ve = function (t, e) {
|
||
this.kind = t, this._styleExpression = e, this.isStateDependent = "constant" !== t && !Rt(e.expression)
|
||
};
|
||
Ve.prototype.evaluateWithoutErrorHandling = function (t, e, i) {
|
||
return this._styleExpression.evaluateWithoutErrorHandling(t, e, i)
|
||
}, Ve.prototype.evaluate = function (t, e, i) {
|
||
return this._styleExpression.evaluate(t, e, i)
|
||
};
|
||
var Ye = function (t, e, i) {
|
||
this.kind = t, this.zoomStops = i.labels, this._styleExpression = e, this.isStateDependent = "camera" !== t && !Rt(e.expression), i instanceof ie && (this._interpolationType = i.interpolation)
|
||
};
|
||
|
||
function We(t, e) {
|
||
if ("error" === (t = Be(t, e)).result) return t;
|
||
var i = t.value.expression, r = Tt(i);
|
||
if (!r && !Re(e)) return Te([new H("", "data expressions not supported")]);
|
||
var o = Pt(i, ["zoom"]);
|
||
if (!o && !Pe(e)) return Te([new H("", "zoom expressions not supported")]);
|
||
var n = function t(e) {
|
||
var i = null;
|
||
if (e instanceof ne) i = t(e.result); else if (e instanceof oe) for (var r = 0, o = e.args; r < o.length; r += 1) {
|
||
var n = o[r];
|
||
if (i = t(n)) break
|
||
} else (e instanceof Mt || e instanceof ie) && e.input instanceof St && "zoom" === e.input.name && (i = e);
|
||
if (i instanceof H) return i;
|
||
e.eachChild(function (e) {
|
||
var r = t(e);
|
||
r instanceof H ? i = r : !i && r ? i = new H("", '"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.') : i && r && i !== r && (i = new H("", 'Only one zoom-based "step" or "interpolate" subexpression may be used in an expression.'))
|
||
});
|
||
return i
|
||
}(i);
|
||
return n || o ? n instanceof H ? Te([n]) : n instanceof ie && !Le(e) ? Te([new H("", '"interpolate" expressions cannot be used with this property')]) : Ee(n ? new Ye(r ? "camera" : "composite", t.value, n) : new Ve(r ? "constant" : "source", t.value)) : Te([new H("", '"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.')])
|
||
}
|
||
|
||
Ye.prototype.evaluateWithoutErrorHandling = function (t, e, i) {
|
||
return this._styleExpression.evaluateWithoutErrorHandling(t, e, i)
|
||
}, Ye.prototype.evaluate = function (t, e, i) {
|
||
return this._styleExpression.evaluate(t, e, i)
|
||
}, Ye.prototype.interpolationFactor = function (t, e, i) {
|
||
return this._interpolationType ? ie.interpolationFactor(this._interpolationType, t, e, i) : 0
|
||
};
|
||
var He = function (t, e) {
|
||
this._parameters = t, this._specification = e, W(this, Ae(this._parameters, this._specification))
|
||
};
|
||
|
||
function Xe(t) {
|
||
return "object" == typeof t ? ["literal", t] : t
|
||
}
|
||
|
||
function qe(t, e) {
|
||
var i = t.stops;
|
||
if (!i) return function (t, e) {
|
||
var i = ["get", t.property];
|
||
if (void 0 === t.default) return "string" === e.type ? ["string", i] : i;
|
||
if ("enum" === e.type) return ["match", i, Object.keys(e.values), i, t.default];
|
||
var r = ["color" === e.type ? "to-color" : e.type, i, Xe(t.default)];
|
||
return "array" === e.type && r.splice(1, 0, e.value, e.length || null), r
|
||
}(t, e);
|
||
var r = i && "object" == typeof i[0][0], o = r || void 0 !== t.property, n = r || !o;
|
||
return i = i.map(function (t) {
|
||
return !o && e.tokens && "string" == typeof t[1] ? [t[0], ei(t[1])] : [t[0], Xe(t[1])]
|
||
}), r ? function (t, e, i) {
|
||
for (var r = {}, o = {}, n = [], s = 0; s < i.length; s++) {
|
||
var a = i[s], l = a[0].zoom;
|
||
void 0 === r[l] && (r[l] = {
|
||
zoom: l,
|
||
type: t.type,
|
||
property: t.property,
|
||
default: t.default
|
||
}, o[l] = [], n.push(l)), o[l].push([a[0].value, a[1]])
|
||
}
|
||
if ("exponential" === ti({}, e)) {
|
||
for (var h = [Ze(t), ["linear"], ["zoom"]], u = 0, c = n; u < c.length; u += 1) {
|
||
var p = c[u], d = Je(r[p], e, o[p]);
|
||
Qe(h, p, d, !1)
|
||
}
|
||
return h
|
||
}
|
||
for (var f = ["step", ["zoom"]], g = 0, m = n; g < m.length; g += 1) {
|
||
var y = m[g], v = Je(r[y], e, o[y]);
|
||
Qe(f, y, v, !0)
|
||
}
|
||
return $e(f), f
|
||
}(t, e, i) : n ? function (t, e, i, r) {
|
||
void 0 === r && (r = ["zoom"]);
|
||
var o, n = ti(t, e), s = !1;
|
||
if ("interval" === n) o = ["step", r], s = !0; else {
|
||
if ("exponential" !== n) throw new Error('Unknown zoom function type "' + n + '"');
|
||
var a = void 0 !== t.base ? t.base : 1;
|
||
o = [Ze(t), ["exponential", a], r]
|
||
}
|
||
for (var l = 0, h = i; l < h.length; l += 1) {
|
||
var u = h[l];
|
||
Qe(o, u[0], u[1], s)
|
||
}
|
||
return $e(o), o
|
||
}(t, e, i) : Je(t, e, i)
|
||
}
|
||
|
||
function Ze(t) {
|
||
switch (t.colorSpace) {
|
||
case"hcl":
|
||
return "interpolate-hcl";
|
||
case"lab":
|
||
return "interpolate-lab";
|
||
default:
|
||
return "interpolate"
|
||
}
|
||
}
|
||
|
||
function Ke(t, e) {
|
||
return void 0 !== t ? t : void 0 !== e ? e : void 0
|
||
}
|
||
|
||
function Je(t, e, i) {
|
||
var r = ti(t, e), o = ["get", t.property];
|
||
if ("categorical" === r && "boolean" == typeof i[0][0]) {
|
||
for (var n = ["case"], s = 0, a = i; s < a.length; s += 1) {
|
||
var l = a[s];
|
||
n.push(["==", o, l[0]], l[1])
|
||
}
|
||
return n.push(Xe(Ke(t.default, e.default))), n
|
||
}
|
||
if ("categorical" === r) {
|
||
for (var h = ["match", o], u = 0, c = i; u < c.length; u += 1) {
|
||
var p = c[u];
|
||
Qe(h, p[0], p[1], !1)
|
||
}
|
||
return h.push(Xe(Ke(t.default, e.default))), h
|
||
}
|
||
if ("interval" === r) {
|
||
for (var d = ["step", ["number", o]], f = 0, g = i; f < g.length; f += 1) {
|
||
var m = g[f];
|
||
Qe(d, m[0], m[1], !0)
|
||
}
|
||
return $e(d), void 0 === t.default ? d : ["case", ["==", ["typeof", o], "number"], d, Xe(t.default)]
|
||
}
|
||
if ("exponential" === r) {
|
||
for (var y = void 0 !== t.base ? t.base : 1, v = [Ze(t), ["exponential", y], ["number", o]], _ = 0, x = i; _ < x.length; _ += 1) {
|
||
var w = x[_];
|
||
Qe(v, w[0], w[1], !1)
|
||
}
|
||
return void 0 === t.default ? v : ["case", ["==", ["typeof", o], "number"], v, Xe(t.default)]
|
||
}
|
||
throw new Error("Unknown property function type " + r)
|
||
}
|
||
|
||
function $e(t) {
|
||
"step" === t[0] && 3 === t.length && (t.push(0), t.push(t[3]))
|
||
}
|
||
|
||
function Qe(t, e, i, r) {
|
||
t.length > 3 && e === t[t.length - 2] || (r && 2 === t.length || t.push(e), t.push(i))
|
||
}
|
||
|
||
function ti(t, e) {
|
||
return t.type ? t.type : e.expression.interpolated ? "exponential" : "interval"
|
||
}
|
||
|
||
function ei(t) {
|
||
for (var e = ["concat"], i = /{([^{}]+)}/g, r = 0, o = i.exec(t); null !== o; o = i.exec(t)) {
|
||
var n = t.slice(r, i.lastIndex - o[0].length);
|
||
r = i.lastIndex, n.length > 0 && e.push(n), e.push(["get", o[1]])
|
||
}
|
||
if (1 === e.length) return t;
|
||
if (r < t.length) e.push(t.slice(r)); else if (2 === e.length) return ["to-string", e[1]];
|
||
return e
|
||
}
|
||
|
||
function ii(t) {
|
||
if (!0 === t || !1 === t) return !0;
|
||
if (!Array.isArray(t) || 0 === t.length) return !1;
|
||
switch (t[0]) {
|
||
case"has":
|
||
return t.length >= 2 && "$id" !== t[1] && "$type" !== t[1];
|
||
case"in":
|
||
case"!in":
|
||
case"!has":
|
||
case"none":
|
||
return !1;
|
||
case"==":
|
||
case"!=":
|
||
case">":
|
||
case">=":
|
||
case"<":
|
||
case"<=":
|
||
return 3 !== t.length || Array.isArray(t[1]) || Array.isArray(t[2]);
|
||
case"any":
|
||
case"all":
|
||
for (var e = 0, i = t.slice(1); e < i.length; e += 1) {
|
||
var r = i[e];
|
||
if (!ii(r) && "boolean" != typeof r) return !1
|
||
}
|
||
return !0;
|
||
default:
|
||
return !0
|
||
}
|
||
}
|
||
|
||
He.deserialize = function (t) {
|
||
return new He(t._parameters, t._specification)
|
||
}, He.serialize = function (t) {
|
||
return {_parameters: t._parameters, _specification: t._specification}
|
||
};
|
||
var ri = {
|
||
type: "boolean",
|
||
default: !1,
|
||
transition: !1,
|
||
"property-type": "data-driven",
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]}
|
||
};
|
||
|
||
function oi(t, e) {
|
||
return t < e ? -1 : t > e ? 1 : 0
|
||
}
|
||
|
||
function ni(t) {
|
||
if (!t) return !0;
|
||
var e, i = t[0];
|
||
return t.length <= 1 ? "any" !== i : "==" === i ? si(t[1], t[2], "==") : "!=" === i ? hi(si(t[1], t[2], "==")) : "<" === i || ">" === i || "<=" === i || ">=" === i ? si(t[1], t[2], i) : "any" === i ? (e = t.slice(1), ["any"].concat(e.map(ni))) : "all" === i ? ["all"].concat(t.slice(1).map(ni)) : "none" === i ? ["all"].concat(t.slice(1).map(ni).map(hi)) : "in" === i ? ai(t[1], t.slice(2)) : "!in" === i ? hi(ai(t[1], t.slice(2))) : "has" === i ? li(t[1]) : "!has" !== i || hi(li(t[1]))
|
||
}
|
||
|
||
function si(t, e, i) {
|
||
switch (t) {
|
||
case"$type":
|
||
return ["filter-type-" + i, e];
|
||
case"$id":
|
||
return ["filter-id-" + i, e];
|
||
default:
|
||
return ["filter-" + i, t, e]
|
||
}
|
||
}
|
||
|
||
function ai(t, e) {
|
||
if (0 === e.length) return !1;
|
||
switch (t) {
|
||
case"$type":
|
||
return ["filter-type-in", ["literal", e]];
|
||
case"$id":
|
||
return ["filter-id-in", ["literal", e]];
|
||
default:
|
||
return e.length > 200 && !e.some(function (t) {
|
||
return typeof t != typeof e[0]
|
||
}) ? ["filter-in-large", t, ["literal", e.sort(oi)]] : ["filter-in-small", t, ["literal", e]]
|
||
}
|
||
}
|
||
|
||
function li(t) {
|
||
switch (t) {
|
||
case"$type":
|
||
return !0;
|
||
case"$id":
|
||
return ["filter-has-id"];
|
||
default:
|
||
return ["filter-has", t]
|
||
}
|
||
}
|
||
|
||
function hi(t) {
|
||
return ["!", t]
|
||
}
|
||
|
||
function ui(t) {
|
||
return function t(e, i) {
|
||
var r;
|
||
if (ii(e)) return e;
|
||
if (!e) return !0;
|
||
var o = e[0];
|
||
if (e.length <= 1) return "any" !== o;
|
||
var n;
|
||
if ("==" === o || "!=" === o || "<" === o || ">" === o || "<=" === o || ">=" === o) {
|
||
var s = e, a = s[1], l = s[2];
|
||
n = function (t, e, i, r) {
|
||
var o;
|
||
if ("$type" === t) return [i, ["geometry-type"], e];
|
||
o = "$id" === t ? ["id"] : ["get", t];
|
||
if (r && null !== e) {
|
||
var n = typeof e;
|
||
r[t] = n
|
||
}
|
||
if ("==" === i && "$id" !== t && null === e) return ["all", ["has", t], ["==", o, null]];
|
||
if ("!=" === i && "$id" !== t && null === e) return ["any", ["!", ["has", t]], ["!=", o, null]];
|
||
return [i, o, e]
|
||
}(a, l, o, i)
|
||
} else {
|
||
if ("any" === o) {
|
||
var h = e.slice(1).map(function (e) {
|
||
var i = {}, r = t(e, i), o = function (t) {
|
||
var e = [];
|
||
for (var i in t) {
|
||
var r = "$id" === i ? ["id"] : ["get", i];
|
||
e.push(["==", ["typeof", r], t[i]])
|
||
}
|
||
if (0 === e.length) return !0;
|
||
if (1 === e.length) return e[0];
|
||
return ["all"].concat(e)
|
||
}(i);
|
||
return !0 === o ? r : ["case", o, r, !1]
|
||
});
|
||
return ["any"].concat(h)
|
||
}
|
||
if ("all" === o) {
|
||
var u = e.slice(1).map(function (e) {
|
||
return t(e, i)
|
||
});
|
||
return u.length > 1 ? ["all"].concat(u) : (r = []).concat.apply(r, u)
|
||
}
|
||
if ("none" === o) return ["!", t(["any"].concat(e.slice(1)), {})];
|
||
n = "in" === o ? ci(e[1], e.slice(2)) : "!in" === o ? ci(e[1], e.slice(2), !0) : "has" === o ? pi(e[1]) : "!has" !== o || ["!", pi(e[1])]
|
||
}
|
||
return n
|
||
}(t, {})
|
||
}
|
||
|
||
function ci(t, e, i) {
|
||
if (void 0 === i && (i = !1), 0 === e.length) return i;
|
||
var r;
|
||
r = "$type" === t ? ["geometry-type"] : "$id" === t ? ["id"] : ["get", t];
|
||
for (var o = !0, n = typeof e[0], s = 0, a = e; s < a.length; s += 1) {
|
||
if (typeof a[s] !== n) {
|
||
o = !1;
|
||
break
|
||
}
|
||
}
|
||
return !o || "string" !== n && "number" !== n ? [i ? "all" : "any"].concat(e.map(function (t) {
|
||
return [i ? "!=" : "==", r, t]
|
||
})) : ["match", r, e, !i, i]
|
||
}
|
||
|
||
function pi(t) {
|
||
return "$type" === t || ("$id" === t ? ["!=", ["id"], null] : ["has", t])
|
||
}
|
||
|
||
function di(t, e) {
|
||
if (Array.isArray(t)) {
|
||
if (!Array.isArray(e) || t.length !== e.length) return !1;
|
||
for (var i = 0; i < t.length; i++) if (!di(t[i], e[i])) return !1;
|
||
return !0
|
||
}
|
||
if ("object" == typeof t && null !== t && null !== e) {
|
||
if ("object" != typeof e) return !1;
|
||
if (Object.keys(t).length !== Object.keys(e).length) return !1;
|
||
for (var r in t) if (!di(t[r], e[r])) return !1;
|
||
return !0
|
||
}
|
||
return t === e
|
||
}
|
||
|
||
var fi = {
|
||
setStyle: "setStyle",
|
||
addLayer: "addLayer",
|
||
removeLayer: "removeLayer",
|
||
setPaintProperty: "setPaintProperty",
|
||
setLayoutProperty: "setLayoutProperty",
|
||
setFilter: "setFilter",
|
||
addSource: "addSource",
|
||
removeSource: "removeSource",
|
||
setGeoJSONSourceData: "setGeoJSONSourceData",
|
||
setLayerZoomRange: "setLayerZoomRange",
|
||
setLayerProperty: "setLayerProperty",
|
||
setCenter: "setCenter",
|
||
setZoom: "setZoom",
|
||
setBearing: "setBearing",
|
||
setPitch: "setPitch",
|
||
setSprite: "setSprite",
|
||
setGlyphs: "setGlyphs",
|
||
setTransition: "setTransition",
|
||
setLight: "setLight"
|
||
};
|
||
|
||
function gi(t, e, i) {
|
||
i.push({command: fi.addSource, args: [t, e[t]]})
|
||
}
|
||
|
||
function mi(t, e, i) {
|
||
e.push({command: fi.removeSource, args: [t]}), i[t] = !0
|
||
}
|
||
|
||
function yi(t, e, i, r) {
|
||
mi(t, i, r), gi(t, e, i)
|
||
}
|
||
|
||
function vi(t, e, i) {
|
||
var r;
|
||
for (r in t[i]) if (t[i].hasOwnProperty(r) && "data" !== r && !di(t[i][r], e[i][r])) return !1;
|
||
for (r in e[i]) if (e[i].hasOwnProperty(r) && "data" !== r && !di(t[i][r], e[i][r])) return !1;
|
||
return !0
|
||
}
|
||
|
||
function _i(t, e, i, r, o, n) {
|
||
var s;
|
||
for (s in e = e || {}, t = t || {}) t.hasOwnProperty(s) && (di(t[s], e[s]) || i.push({
|
||
command: n,
|
||
args: [r, s, e[s], o]
|
||
}));
|
||
for (s in e) e.hasOwnProperty(s) && !t.hasOwnProperty(s) && (di(t[s], e[s]) || i.push({
|
||
command: n,
|
||
args: [r, s, e[s], o]
|
||
}))
|
||
}
|
||
|
||
function xi(t) {
|
||
return t.id
|
||
}
|
||
|
||
function wi(t, e) {
|
||
return t[e.id] = e, t
|
||
}
|
||
|
||
var bi = function (t, e, i, r) {
|
||
this.message = (t ? t + ": " : "") + i, r && (this.identifier = r), null != e && e.__line__ && (this.line = e.__line__)
|
||
};
|
||
|
||
function Ci(t) {
|
||
this.error = t, this.message = t.message;
|
||
var e = t.message.match(/line (\d+)/);
|
||
this.line = e ? parseInt(e[1], 10) : 0
|
||
}
|
||
|
||
function Si(t) {
|
||
var e = t.key, i = t.value;
|
||
return i ? [new bi(e, i, "constants have been deprecated as of v8")] : []
|
||
}
|
||
|
||
function Ei(t) {
|
||
return t instanceof Number || t instanceof String || t instanceof Boolean ? t.valueOf() : t
|
||
}
|
||
|
||
function Ti(t) {
|
||
return Array.isArray(t) ? t.map(Ti) : Ei(t)
|
||
}
|
||
|
||
function Ri(t) {
|
||
var e = t.key, i = t.value, r = t.valueSpec || {}, o = t.objectElementValidators || {}, n = t.style,
|
||
s = t.styleSpec, a = [], l = Ie(i);
|
||
if ("object" !== l) return [new bi(e, i, "object expected, " + l + " found")];
|
||
for (var h in i) {
|
||
var u = h.split(".")[0], c = r[u] || r["*"], p = void 0;
|
||
if (o[u]) p = o[u]; else if (r[u]) p = Bi; else if (o["*"]) p = o["*"]; else {
|
||
if (!r["*"]) {
|
||
a.push(new bi(e, i[h], 'unknown property "' + h + '"'));
|
||
continue
|
||
}
|
||
p = Bi
|
||
}
|
||
a = a.concat(p({
|
||
key: (e ? e + "." : e) + h,
|
||
value: i[h],
|
||
valueSpec: c,
|
||
style: n,
|
||
styleSpec: s,
|
||
object: i,
|
||
objectKey: h
|
||
}, i))
|
||
}
|
||
for (var d in r) o[d] || r[d].required && void 0 === r[d].default && void 0 === i[d] && a.push(new bi(e, i, 'missing required property "' + d + '"'));
|
||
return a
|
||
}
|
||
|
||
function Pi(t) {
|
||
var e = t.value, i = t.valueSpec, r = t.style, o = t.styleSpec, n = t.key,
|
||
s = t.arrayElementValidator || Bi;
|
||
if ("array" !== Ie(e)) return [new bi(n, e, "array expected, " + Ie(e) + " found")];
|
||
if (i.length && e.length !== i.length) return [new bi(n, e, "array length " + i.length + " expected, length " + e.length + " found")];
|
||
if (i["min-length"] && e.length < i["min-length"]) return [new bi(n, e, "array length at least " + i["min-length"] + " expected, length " + e.length + " found")];
|
||
var a = {type: i.value, values: i.values};
|
||
o.$version < 7 && (a.function = i.function), "object" === Ie(i.value) && (a = i.value);
|
||
for (var l = [], h = 0; h < e.length; h++) l = l.concat(s({
|
||
array: e,
|
||
arrayIndex: h,
|
||
value: e[h],
|
||
valueSpec: a,
|
||
style: r,
|
||
styleSpec: o,
|
||
key: n + "[" + h + "]"
|
||
}));
|
||
return l
|
||
}
|
||
|
||
function Li(t) {
|
||
var e = t.key, i = t.value, r = t.valueSpec, o = Ie(i);
|
||
return "number" !== o ? [new bi(e, i, "number expected, " + o + " found")] : "minimum" in r && i < r.minimum ? [new bi(e, i, i + " is less than the minimum value " + r.minimum)] : "maximum" in r && i > r.maximum ? [new bi(e, i, i + " is greater than the maximum value " + r.maximum)] : []
|
||
}
|
||
|
||
function Ii(t) {
|
||
var e, i, r, o = t.valueSpec, n = Ei(t.value.type), s = {},
|
||
a = "categorical" !== n && void 0 === t.value.property, l = !a,
|
||
h = "array" === Ie(t.value.stops) && "array" === Ie(t.value.stops[0]) && "object" === Ie(t.value.stops[0][0]),
|
||
u = Ri({
|
||
key: t.key,
|
||
value: t.value,
|
||
valueSpec: t.styleSpec.function,
|
||
style: t.style,
|
||
styleSpec: t.styleSpec,
|
||
objectElementValidators: {
|
||
stops: function (t) {
|
||
if ("identity" === n) return [new bi(t.key, t.value, 'identity function may not have a "stops" property')];
|
||
var e = [], i = t.value;
|
||
e = e.concat(Pi({
|
||
key: t.key,
|
||
value: i,
|
||
valueSpec: t.valueSpec,
|
||
style: t.style,
|
||
styleSpec: t.styleSpec,
|
||
arrayElementValidator: c
|
||
})), "array" === Ie(i) && 0 === i.length && e.push(new bi(t.key, i, "array must have at least one stop"));
|
||
return e
|
||
}, default: function (t) {
|
||
return Bi({
|
||
key: t.key,
|
||
value: t.value,
|
||
valueSpec: o,
|
||
style: t.style,
|
||
styleSpec: t.styleSpec
|
||
})
|
||
}
|
||
}
|
||
});
|
||
return "identity" === n && a && u.push(new bi(t.key, t.value, 'missing required property "property"')), "identity" === n || t.value.stops || u.push(new bi(t.key, t.value, 'missing required property "stops"')), "exponential" === n && t.valueSpec.expression && !Le(t.valueSpec) && u.push(new bi(t.key, t.value, "exponential functions not supported")), t.styleSpec.$version >= 8 && (l && !Re(t.valueSpec) ? u.push(new bi(t.key, t.value, "property functions not supported")) : a && !Pe(t.valueSpec) && u.push(new bi(t.key, t.value, "zoom functions not supported"))), "categorical" !== n && !h || void 0 !== t.value.property || u.push(new bi(t.key, t.value, '"property" property is required')), u;
|
||
|
||
function c(t) {
|
||
var e = [], n = t.value, a = t.key;
|
||
if ("array" !== Ie(n)) return [new bi(a, n, "array expected, " + Ie(n) + " found")];
|
||
if (2 !== n.length) return [new bi(a, n, "array length 2 expected, length " + n.length + " found")];
|
||
if (h) {
|
||
if ("object" !== Ie(n[0])) return [new bi(a, n, "object expected, " + Ie(n[0]) + " found")];
|
||
if (void 0 === n[0].zoom) return [new bi(a, n, "object stop key must have zoom")];
|
||
if (void 0 === n[0].value) return [new bi(a, n, "object stop key must have value")];
|
||
if (r && r > Ei(n[0].zoom)) return [new bi(a, n[0].zoom, "stop zoom values must appear in ascending order")];
|
||
Ei(n[0].zoom) !== r && (r = Ei(n[0].zoom), i = void 0, s = {}), e = e.concat(Ri({
|
||
key: a + "[0]",
|
||
value: n[0],
|
||
valueSpec: {zoom: {}},
|
||
style: t.style,
|
||
styleSpec: t.styleSpec,
|
||
objectElementValidators: {zoom: Li, value: p}
|
||
}))
|
||
} else e = e.concat(p({
|
||
key: a + "[0]",
|
||
value: n[0],
|
||
valueSpec: {},
|
||
style: t.style,
|
||
styleSpec: t.styleSpec
|
||
}, n));
|
||
return Ue(Ti(n[1])) ? e.concat([new bi(a + "[1]", n[1], "expressions are not allowed in function stops.")]) : e.concat(Bi({
|
||
key: a + "[1]",
|
||
value: n[1],
|
||
valueSpec: o,
|
||
style: t.style,
|
||
styleSpec: t.styleSpec
|
||
}))
|
||
}
|
||
|
||
function p(t, r) {
|
||
var a = Ie(t.value), l = Ei(t.value), h = null !== t.value ? t.value : r;
|
||
if (e) {
|
||
if (a !== e) return [new bi(t.key, h, a + " stop domain type must match previous stop domain type " + e)]
|
||
} else e = a;
|
||
if ("number" !== a && "string" !== a && "boolean" !== a) return [new bi(t.key, h, "stop domain value must be a number, string, or boolean")];
|
||
if ("number" !== a && "categorical" !== n) {
|
||
var u = "number expected, " + a + " found";
|
||
return Re(o) && void 0 === n && (u += '\nIf you intended to use a categorical function, specify `"type": "categorical"`.'), [new bi(t.key, h, u)]
|
||
}
|
||
return "categorical" !== n || "number" !== a || isFinite(l) && Math.floor(l) === l ? "categorical" !== n && "number" === a && void 0 !== i && l < i ? [new bi(t.key, h, "stop domain values must appear in ascending order")] : (i = l, "categorical" === n && l in s ? [new bi(t.key, h, "stop domain values must be unique")] : (s[l] = !0, [])) : [new bi(t.key, h, "integer expected, found " + l)]
|
||
}
|
||
}
|
||
|
||
function Oi(t) {
|
||
var e = ("property" === t.expressionContext ? We : Be)(Ti(t.value), t.valueSpec);
|
||
if ("error" === e.result) return e.value.map(function (e) {
|
||
return new bi("" + t.key + e.key, t.value, e.message)
|
||
});
|
||
var i = e.value.expression || e.value._styleExpression.expression;
|
||
if ("property" === t.expressionContext && "text-font" === t.propertyKey && -1 !== i.possibleOutputs().indexOf(void 0)) return [new bi(t.key, t.value, 'Invalid data expression for "' + t.propertyKey + '". Output values must be contained as literals within the expression.')];
|
||
if ("property" === t.expressionContext && "layout" === t.propertyType && !Rt(i)) return [new bi(t.key, t.value, '"feature-state" data expressions are not supported with layout properties.')];
|
||
if ("filter" === t.expressionContext && !Rt(i)) return [new bi(t.key, t.value, '"feature-state" data expressions are not supported with filters.')];
|
||
if (t.expressionContext && 0 === t.expressionContext.indexOf("cluster")) {
|
||
if (!Pt(i, ["zoom", "feature-state"])) return [new bi(t.key, t.value, '"zoom" and "feature-state" expressions are not supported with cluster properties.')];
|
||
if ("cluster-initial" === t.expressionContext && !Tt(i)) return [new bi(t.key, t.value, "Feature data expressions are not supported with initial expression part of cluster properties.")]
|
||
}
|
||
return []
|
||
}
|
||
|
||
function Mi(t) {
|
||
var e = t.key, i = t.value, r = t.valueSpec, o = [];
|
||
return Array.isArray(r.values) ? -1 === r.values.indexOf(Ei(i)) && o.push(new bi(e, i, "expected one of [" + r.values.join(", ") + "], " + JSON.stringify(i) + " found")) : -1 === Object.keys(r.values).indexOf(Ei(i)) && o.push(new bi(e, i, "expected one of [" + Object.keys(r.values).join(", ") + "], " + JSON.stringify(i) + " found")), o
|
||
}
|
||
|
||
function Ai(t) {
|
||
return ii(Ti(t.value)) ? Oi(W({}, t, {
|
||
expressionContext: "filter",
|
||
valueSpec: {value: "boolean"}
|
||
})) : function t(e) {
|
||
var i = e.value;
|
||
var r = e.key;
|
||
if ("array" !== Ie(i)) return [new bi(r, i, "array expected, " + Ie(i) + " found")];
|
||
var o = e.styleSpec;
|
||
var n;
|
||
var s = [];
|
||
if (i.length < 1) return [new bi(r, i, "filter array must have at least 1 element")];
|
||
s = s.concat(Mi({
|
||
key: r + "[0]",
|
||
value: i[0],
|
||
valueSpec: o.filter_operator,
|
||
style: e.style,
|
||
styleSpec: e.styleSpec
|
||
}));
|
||
switch (Ei(i[0])) {
|
||
case"<":
|
||
case"<=":
|
||
case">":
|
||
case">=":
|
||
i.length >= 2 && "$type" === Ei(i[1]) && s.push(new bi(r, i, '"$type" cannot be use with operator "' + i[0] + '"'));
|
||
case"==":
|
||
case"!=":
|
||
3 !== i.length && s.push(new bi(r, i, 'filter array for operator "' + i[0] + '" must have 3 elements'));
|
||
case"in":
|
||
case"!in":
|
||
i.length >= 2 && "string" !== (n = Ie(i[1])) && s.push(new bi(r + "[1]", i[1], "string expected, " + n + " found"));
|
||
for (var a = 2; a < i.length; a++) n = Ie(i[a]), "$type" === Ei(i[1]) ? s = s.concat(Mi({
|
||
key: r + "[" + a + "]",
|
||
value: i[a],
|
||
valueSpec: o.geometry_type,
|
||
style: e.style,
|
||
styleSpec: e.styleSpec
|
||
})) : "string" !== n && "number" !== n && "boolean" !== n && s.push(new bi(r + "[" + a + "]", i[a], "string, number, or boolean expected, " + n + " found"));
|
||
break;
|
||
case"any":
|
||
case"all":
|
||
case"none":
|
||
for (var l = 1; l < i.length; l++) s = s.concat(t({
|
||
key: r + "[" + l + "]",
|
||
value: i[l],
|
||
style: e.style,
|
||
styleSpec: e.styleSpec
|
||
}));
|
||
break;
|
||
case"has":
|
||
case"!has":
|
||
n = Ie(i[1]), 2 !== i.length ? s.push(new bi(r, i, 'filter array for "' + i[0] + '" operator must have 2 elements')) : "string" !== n && s.push(new bi(r + "[1]", i[1], "string expected, " + n + " found"))
|
||
}
|
||
return s
|
||
}(t)
|
||
}
|
||
|
||
function ki(t, e) {
|
||
var i = t.key, r = t.style, o = t.styleSpec, n = t.value, s = t.objectKey,
|
||
a = o[e + "_" + t.layerType];
|
||
if (!a) return [];
|
||
var l = s.match(/^(.*)-transition$/);
|
||
if ("paint" === e && l && a[l[1]] && a[l[1]].transition) return Bi({
|
||
key: i,
|
||
value: n,
|
||
valueSpec: o.transition,
|
||
style: r,
|
||
styleSpec: o
|
||
});
|
||
var h, u = t.valueSpec || a[s];
|
||
if (!u) return [new bi(i, n, 'unknown property "' + s + '"')];
|
||
if ("string" === Ie(n) && Re(u) && !u.tokens && (h = /^{([^}]+)}$/.exec(n))) return [new bi(i, n, '"' + s + '" does not support interpolation syntax\nUse an identity property function instead: `{ "type": "identity", "property": ' + JSON.stringify(h[1]) + " }`.")];
|
||
var c = [];
|
||
return "symbol" === t.layerType && ("text-field" === s && r && !r.glyphs && c.push(new bi(i, n, 'use of "text-field" requires a style "glyphs" property')), "text-font" === s && Oe(Ti(n)) && "identity" === Ei(n.type) && c.push(new bi(i, n, '"text-font" does not support identity functions'))), c.concat(Bi({
|
||
key: t.key,
|
||
value: n,
|
||
valueSpec: u,
|
||
style: r,
|
||
styleSpec: o,
|
||
expressionContext: "property",
|
||
propertyType: e,
|
||
propertyKey: s
|
||
}))
|
||
}
|
||
|
||
function Fi(t) {
|
||
return ki(t, "paint")
|
||
}
|
||
|
||
function Ni(t) {
|
||
return ki(t, "layout")
|
||
}
|
||
|
||
function Di(t) {
|
||
var e = [], i = t.value, r = t.key, o = t.style, n = t.styleSpec;
|
||
i.type || i.ref || e.push(new bi(r, i, 'either "type" or "ref" is required'));
|
||
var s, a = Ei(i.type), l = Ei(i.ref);
|
||
if (i.id) for (var h = Ei(i.id), u = 0; u < t.arrayIndex; u++) {
|
||
var c = o.layers[u];
|
||
Ei(c.id) === h && e.push(new bi(r, i.id, 'duplicate layer id "' + i.id + '", previously used at line ' + c.id.__line__))
|
||
}
|
||
if ("ref" in i) ["type", "source", "source-layer", "filter", "layout"].forEach(function (t) {
|
||
t in i && e.push(new bi(r, i[t], '"' + t + '" is prohibited for ref layers'))
|
||
}), o.layers.forEach(function (t) {
|
||
Ei(t.id) === l && (s = t)
|
||
}), s ? s.ref ? e.push(new bi(r, i.ref, "ref cannot reference another ref layer")) : a = Ei(s.type) : e.push(new bi(r, i.ref, 'ref layer "' + l + '" not found')); else if ("background" !== a) if (i.source) {
|
||
var p = o.sources && o.sources[i.source], d = p && Ei(p.type);
|
||
p ? "vector" === d && "raster" === a ? e.push(new bi(r, i.source, 'layer "' + i.id + '" requires a raster source')) : "raster" === d && "raster" !== a ? e.push(new bi(r, i.source, 'layer "' + i.id + '" requires a vector source')) : "vector" !== d || i["source-layer"] ? "raster-dem" === d && "hillshade" !== a ? e.push(new bi(r, i.source, "raster-dem source can only be used with layer type 'hillshade'.")) : "line" !== a || !i.paint || !i.paint["line-gradient"] || "geojson" === d && p.lineMetrics || e.push(new bi(r, i, 'layer "' + i.id + '" specifies a line-gradient, which requires a GeoJSON source with `lineMetrics` enabled.')) : e.push(new bi(r, i, 'layer "' + i.id + '" must specify a "source-layer"')) : e.push(new bi(r, i.source, 'source "' + i.source + '" not found'))
|
||
} else e.push(new bi(r, i, 'missing required property "source"'));
|
||
return e = e.concat(Ri({
|
||
key: r,
|
||
value: i,
|
||
valueSpec: n.layer,
|
||
style: t.style,
|
||
styleSpec: t.styleSpec,
|
||
objectElementValidators: {
|
||
"*": function () {
|
||
return []
|
||
}, type: function () {
|
||
return Bi({
|
||
key: r + ".type",
|
||
value: i.type,
|
||
valueSpec: n.layer.type,
|
||
style: t.style,
|
||
styleSpec: t.styleSpec,
|
||
object: i,
|
||
objectKey: "type"
|
||
})
|
||
}, filter: Ai, layout: function (t) {
|
||
return Ri({
|
||
layer: i,
|
||
key: t.key,
|
||
value: t.value,
|
||
style: t.style,
|
||
styleSpec: t.styleSpec,
|
||
objectElementValidators: {
|
||
"*": function (t) {
|
||
return Ni(W({layerType: a}, t))
|
||
}
|
||
}
|
||
})
|
||
}, paint: function (t) {
|
||
return Ri({
|
||
layer: i,
|
||
key: t.key,
|
||
value: t.value,
|
||
style: t.style,
|
||
styleSpec: t.styleSpec,
|
||
objectElementValidators: {
|
||
"*": function (t) {
|
||
return Fi(W({layerType: a}, t))
|
||
}
|
||
}
|
||
})
|
||
}
|
||
}
|
||
}))
|
||
}
|
||
|
||
function Gi(t) {
|
||
var e = t.value, i = t.key, r = t.styleSpec, o = t.style;
|
||
if (!e.type) return [new bi(i, e, '"type" is required')];
|
||
var n, s = Ei(e.type);
|
||
switch (s) {
|
||
case"vector":
|
||
case"raster":
|
||
case"raster-dem":
|
||
if (n = Ri({
|
||
key: i,
|
||
value: e,
|
||
valueSpec: r["source_" + s.replace("-", "_")],
|
||
style: t.style,
|
||
styleSpec: r
|
||
}), "url" in e) for (var a in e) ["type", "url", "tileSize"].indexOf(a) < 0 && n.push(new bi(i + "." + a, e[a], 'a source with a "url" property may not include a "' + a + '" property'));
|
||
return n;
|
||
case"geojson":
|
||
if (n = Ri({
|
||
key: i,
|
||
value: e,
|
||
valueSpec: r.source_geojson,
|
||
style: o,
|
||
styleSpec: r
|
||
}), e.cluster) for (var l in e.clusterProperties) {
|
||
var h = e.clusterProperties[l], u = h[0], c = h[1],
|
||
p = "string" == typeof u ? [u, ["accumulated"], ["get", l]] : u;
|
||
n.push.apply(n, Oi({
|
||
key: i + "." + l + ".map",
|
||
value: c,
|
||
expressionContext: "cluster-map"
|
||
})), n.push.apply(n, Oi({
|
||
key: i + "." + l + ".reduce",
|
||
value: p,
|
||
expressionContext: "cluster-reduce"
|
||
}))
|
||
}
|
||
return n;
|
||
case"video":
|
||
return Ri({key: i, value: e, valueSpec: r.source_video, style: o, styleSpec: r});
|
||
case"image":
|
||
return Ri({key: i, value: e, valueSpec: r.source_image, style: o, styleSpec: r});
|
||
case"canvas":
|
||
return [new bi(i, null, "Please use runtime APIs to add canvas sources, rather than including them in stylesheets.", "source.canvas")];
|
||
default:
|
||
return Mi({
|
||
key: i + ".type",
|
||
value: e.type,
|
||
valueSpec: {values: ["vector", "raster", "raster-dem", "geojson", "video", "image"]},
|
||
style: o,
|
||
styleSpec: r
|
||
})
|
||
}
|
||
}
|
||
|
||
function ji(t) {
|
||
var e = t.value, i = t.styleSpec, r = i.light, o = t.style, n = [], s = Ie(e);
|
||
if (void 0 === e) return n;
|
||
if ("object" !== s) return n = n.concat([new bi("light", e, "object expected, " + s + " found")]);
|
||
for (var a in e) {
|
||
var l = a.match(/^(.*)-transition$/);
|
||
n = l && r[l[1]] && r[l[1]].transition ? n.concat(Bi({
|
||
key: a,
|
||
value: e[a],
|
||
valueSpec: i.transition,
|
||
style: o,
|
||
styleSpec: i
|
||
})) : r[a] ? n.concat(Bi({
|
||
key: a,
|
||
value: e[a],
|
||
valueSpec: r[a],
|
||
style: o,
|
||
styleSpec: i
|
||
})) : n.concat([new bi(a, e[a], 'unknown property "' + a + '"')])
|
||
}
|
||
return n
|
||
}
|
||
|
||
function zi(t) {
|
||
var e = t.value, i = t.key, r = Ie(e);
|
||
return "string" !== r ? [new bi(i, e, "string expected, " + r + " found")] : []
|
||
}
|
||
|
||
var Ui = {
|
||
"*": function () {
|
||
return []
|
||
},
|
||
array: Pi,
|
||
boolean: function (t) {
|
||
var e = t.value, i = t.key, r = Ie(e);
|
||
return "boolean" !== r ? [new bi(i, e, "boolean expected, " + r + " found")] : []
|
||
},
|
||
number: Li,
|
||
color: function (t) {
|
||
var e = t.key, i = t.value, r = Ie(i);
|
||
return "string" !== r ? [new bi(e, i, "color expected, " + r + " found")] : null === at(i) ? [new bi(e, i, 'color expected, "' + i + '" found')] : []
|
||
},
|
||
constants: Si,
|
||
enum: Mi,
|
||
filter: Ai,
|
||
function: Ii,
|
||
layer: Di,
|
||
object: Ri,
|
||
source: Gi,
|
||
light: ji,
|
||
string: zi,
|
||
formatted: function (t) {
|
||
return 0 === zi(t).length ? [] : Oi(t)
|
||
}
|
||
};
|
||
|
||
function Bi(t) {
|
||
var e = t.value, i = t.valueSpec, r = t.styleSpec;
|
||
return i.expression && Oe(Ei(e)) ? Ii(t) : i.expression && Ue(Ti(e)) ? Oi(t) : i.type && Ui[i.type] ? Ui[i.type](t) : Ri(W({}, t, {valueSpec: i.type ? r[i.type] : i}))
|
||
}
|
||
|
||
function Vi(t) {
|
||
var e = t.value, i = t.key, r = zi(t);
|
||
return r.length ? r : (-1 === e.indexOf("{fontstack}") && r.push(new bi(i, e, '"glyphs" url must include a "{fontstack}" token')), -1 === e.indexOf("{range}") && r.push(new bi(i, e, '"glyphs" url must include a "{range}" token')), r)
|
||
}
|
||
|
||
function Yi(t, e) {
|
||
e = e || r;
|
||
var i = [];
|
||
return i = i.concat(Bi({
|
||
key: "",
|
||
value: t,
|
||
valueSpec: e.$root,
|
||
styleSpec: e,
|
||
style: t,
|
||
objectElementValidators: {
|
||
glyphs: Vi, "*": function () {
|
||
return []
|
||
}
|
||
}
|
||
})), t.constants && (i = i.concat(Si({
|
||
key: "constants",
|
||
value: t.constants,
|
||
style: t,
|
||
styleSpec: e
|
||
}))), Wi(i)
|
||
}
|
||
|
||
function Wi(t) {
|
||
return [].concat(t).sort(function (t, e) {
|
||
return t.line - e.line
|
||
})
|
||
}
|
||
|
||
function Hi(t) {
|
||
return function () {
|
||
for (var e = [], i = arguments.length; i--;) e[i] = arguments[i];
|
||
return Wi(t.apply(this, e))
|
||
}
|
||
}
|
||
|
||
Yi.source = Hi(Gi), Yi.light = Hi(ji), Yi.layer = Hi(Di), Yi.filter = Hi(Ai), Yi.paintProperty = Hi(Fi), Yi.layoutProperty = Hi(Ni);
|
||
var Xi = l(function (t, e) {
|
||
var i = function () {
|
||
var t = function (t, e, i, r) {
|
||
for (i = i || {}, r = t.length; r--; i[t[r]] = e) ;
|
||
return i
|
||
}, e = [1, 12], i = [1, 13], r = [1, 9], o = [1, 10], n = [1, 11], s = [1, 14], a = [1, 15],
|
||
l = [14, 18, 22, 24], h = [18, 22], u = [22, 24], c = {
|
||
trace: function () {
|
||
},
|
||
yy: {},
|
||
symbols_: {
|
||
error: 2,
|
||
JSONString: 3,
|
||
STRING: 4,
|
||
JSONNumber: 5,
|
||
NUMBER: 6,
|
||
JSONNullLiteral: 7,
|
||
NULL: 8,
|
||
JSONBooleanLiteral: 9,
|
||
TRUE: 10,
|
||
FALSE: 11,
|
||
JSONText: 12,
|
||
JSONValue: 13,
|
||
EOF: 14,
|
||
JSONObject: 15,
|
||
JSONArray: 16,
|
||
"{": 17,
|
||
"}": 18,
|
||
JSONMemberList: 19,
|
||
JSONMember: 20,
|
||
":": 21,
|
||
",": 22,
|
||
"[": 23,
|
||
"]": 24,
|
||
JSONElementList: 25,
|
||
$accept: 0,
|
||
$end: 1
|
||
},
|
||
terminals_: {
|
||
2: "error",
|
||
4: "STRING",
|
||
6: "NUMBER",
|
||
8: "NULL",
|
||
10: "TRUE",
|
||
11: "FALSE",
|
||
14: "EOF",
|
||
17: "{",
|
||
18: "}",
|
||
21: ":",
|
||
22: ",",
|
||
23: "[",
|
||
24: "]"
|
||
},
|
||
productions_: [0, [3, 1], [5, 1], [7, 1], [9, 1], [9, 1], [12, 2], [13, 1], [13, 1], [13, 1], [13, 1], [13, 1], [13, 1], [15, 2], [15, 3], [20, 3], [19, 1], [19, 3], [16, 2], [16, 3], [25, 1], [25, 3]],
|
||
performAction: function (t, e, i, r, o, n, s) {
|
||
var a = n.length - 1;
|
||
switch (o) {
|
||
case 1:
|
||
this.$ = new String(t.replace(/\\(\\|")/g, "$1").replace(/\\n/g, "\n").replace(/\\r/g, "\r").replace(/\\t/g, "\t").replace(/\\v/g, "\v").replace(/\\f/g, "\f").replace(/\\b/g, "\b")), this.$.__line__ = this._$.first_line;
|
||
break;
|
||
case 2:
|
||
this.$ = new Number(t), this.$.__line__ = this._$.first_line;
|
||
break;
|
||
case 3:
|
||
this.$ = null;
|
||
break;
|
||
case 4:
|
||
this.$ = new Boolean(!0), this.$.__line__ = this._$.first_line;
|
||
break;
|
||
case 5:
|
||
this.$ = new Boolean(!1), this.$.__line__ = this._$.first_line;
|
||
break;
|
||
case 6:
|
||
return this.$ = n[a - 1];
|
||
case 13:
|
||
this.$ = {}, Object.defineProperty(this.$, "__line__", {
|
||
value: this._$.first_line,
|
||
enumerable: !1
|
||
});
|
||
break;
|
||
case 14:
|
||
case 19:
|
||
this.$ = n[a - 1], Object.defineProperty(this.$, "__line__", {
|
||
value: this._$.first_line,
|
||
enumerable: !1
|
||
});
|
||
break;
|
||
case 15:
|
||
this.$ = [n[a - 2], n[a]];
|
||
break;
|
||
case 16:
|
||
this.$ = {}, this.$[n[a][0]] = n[a][1];
|
||
break;
|
||
case 17:
|
||
this.$ = n[a - 2], n[a - 2][n[a][0]] = n[a][1];
|
||
break;
|
||
case 18:
|
||
this.$ = [], Object.defineProperty(this.$, "__line__", {
|
||
value: this._$.first_line,
|
||
enumerable: !1
|
||
});
|
||
break;
|
||
case 20:
|
||
this.$ = [n[a]];
|
||
break;
|
||
case 21:
|
||
this.$ = n[a - 2], n[a - 2].push(n[a])
|
||
}
|
||
},
|
||
table: [{
|
||
3: 5,
|
||
4: e,
|
||
5: 6,
|
||
6: i,
|
||
7: 3,
|
||
8: r,
|
||
9: 4,
|
||
10: o,
|
||
11: n,
|
||
12: 1,
|
||
13: 2,
|
||
15: 7,
|
||
16: 8,
|
||
17: s,
|
||
23: a
|
||
}, {1: [3]}, {14: [1, 16]}, t(l, [2, 7]), t(l, [2, 8]), t(l, [2, 9]), t(l, [2, 10]), t(l, [2, 11]), t(l, [2, 12]), t(l, [2, 3]), t(l, [2, 4]), t(l, [2, 5]), t([14, 18, 21, 22, 24], [2, 1]), t(l, [2, 2]), {
|
||
3: 20,
|
||
4: e,
|
||
18: [1, 17],
|
||
19: 18,
|
||
20: 19
|
||
}, {
|
||
3: 5,
|
||
4: e,
|
||
5: 6,
|
||
6: i,
|
||
7: 3,
|
||
8: r,
|
||
9: 4,
|
||
10: o,
|
||
11: n,
|
||
13: 23,
|
||
15: 7,
|
||
16: 8,
|
||
17: s,
|
||
23: a,
|
||
24: [1, 21],
|
||
25: 22
|
||
}, {1: [2, 6]}, t(l, [2, 13]), {
|
||
18: [1, 24],
|
||
22: [1, 25]
|
||
}, t(h, [2, 16]), {21: [1, 26]}, t(l, [2, 18]), {
|
||
22: [1, 28],
|
||
24: [1, 27]
|
||
}, t(u, [2, 20]), t(l, [2, 14]), {3: 20, 4: e, 20: 29}, {
|
||
3: 5,
|
||
4: e,
|
||
5: 6,
|
||
6: i,
|
||
7: 3,
|
||
8: r,
|
||
9: 4,
|
||
10: o,
|
||
11: n,
|
||
13: 30,
|
||
15: 7,
|
||
16: 8,
|
||
17: s,
|
||
23: a
|
||
}, t(l, [2, 19]), {
|
||
3: 5,
|
||
4: e,
|
||
5: 6,
|
||
6: i,
|
||
7: 3,
|
||
8: r,
|
||
9: 4,
|
||
10: o,
|
||
11: n,
|
||
13: 31,
|
||
15: 7,
|
||
16: 8,
|
||
17: s,
|
||
23: a
|
||
}, t(h, [2, 17]), t(h, [2, 15]), t(u, [2, 21])],
|
||
defaultActions: {16: [2, 6]},
|
||
parseError: function (t, e) {
|
||
if (!e.recoverable) throw new Error(t);
|
||
this.trace(t)
|
||
},
|
||
parse: function (t) {
|
||
var e = this, i = [0], r = [null], o = [], n = this.table, s = "", a = 0, l = 0, h = 1,
|
||
u = o.slice.call(arguments, 1), c = Object.create(this.lexer), p = {yy: {}};
|
||
for (var d in this.yy) Object.prototype.hasOwnProperty.call(this.yy, d) && (p.yy[d] = this.yy[d]);
|
||
c.setInput(t, p.yy), p.yy.lexer = c, p.yy.parser = this, void 0 === c.yylloc && (c.yylloc = {});
|
||
var f = c.yylloc;
|
||
o.push(f);
|
||
var g = c.options && c.options.ranges;
|
||
"function" == typeof p.yy.parseError ? this.parseError = p.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError;
|
||
for (var m, y, v, _, x, w, b, C, S, E, T = {}; ;) {
|
||
if (v = i[i.length - 1], this.defaultActions[v] ? _ = this.defaultActions[v] : (null == m && (E = void 0, "number" != typeof (E = c.lex() || h) && (E = e.symbols_[E] || E), m = E), _ = n[v] && n[v][m]), void 0 === _ || !_.length || !_[0]) {
|
||
var R = "";
|
||
for (w in S = [], n[v]) this.terminals_[w] && w > 2 && S.push("'" + this.terminals_[w] + "'");
|
||
R = c.showPosition ? "Parse error on line " + (a + 1) + ":\n" + c.showPosition() + "\nExpecting " + S.join(", ") + ", got '" + (this.terminals_[m] || m) + "'" : "Parse error on line " + (a + 1) + ": Unexpected " + (m == h ? "end of input" : "'" + (this.terminals_[m] || m) + "'"), this.parseError(R, {
|
||
text: c.match,
|
||
token: this.terminals_[m] || m,
|
||
line: c.yylineno,
|
||
loc: f,
|
||
expected: S
|
||
})
|
||
}
|
||
if (_[0] instanceof Array && _.length > 1) throw new Error("Parse Error: multiple actions possible at state: " + v + ", token: " + m);
|
||
switch (_[0]) {
|
||
case 1:
|
||
i.push(m), r.push(c.yytext), o.push(c.yylloc), i.push(_[1]), m = null, y ? (m = y, y = null) : (l = c.yyleng, s = c.yytext, a = c.yylineno, f = c.yylloc);
|
||
break;
|
||
case 2:
|
||
if (b = this.productions_[_[1]][1], T.$ = r[r.length - b], T._$ = {
|
||
first_line: o[o.length - (b || 1)].first_line,
|
||
last_line: o[o.length - 1].last_line,
|
||
first_column: o[o.length - (b || 1)].first_column,
|
||
last_column: o[o.length - 1].last_column
|
||
}, g && (T._$.range = [o[o.length - (b || 1)].range[0], o[o.length - 1].range[1]]), void 0 !== (x = this.performAction.apply(T, [s, l, a, p.yy, _[1], r, o].concat(u)))) return x;
|
||
b && (i = i.slice(0, -1 * b * 2), r = r.slice(0, -1 * b), o = o.slice(0, -1 * b)), i.push(this.productions_[_[1]][0]), r.push(T.$), o.push(T._$), C = n[i[i.length - 2]][i[i.length - 1]], i.push(C);
|
||
break;
|
||
case 3:
|
||
return !0
|
||
}
|
||
}
|
||
return !0
|
||
}
|
||
}, p = {
|
||
EOF: 1,
|
||
parseError: function (t, e) {
|
||
if (!this.yy.parser) throw new Error(t);
|
||
this.yy.parser.parseError(t, e)
|
||
},
|
||
setInput: function (t, e) {
|
||
return this.yy = e || this.yy || {}, this._input = t, this._more = this._backtrack = this.done = !1, this.yylineno = this.yyleng = 0, this.yytext = this.matched = this.match = "", this.conditionStack = ["INITIAL"], this.yylloc = {
|
||
first_line: 1,
|
||
first_column: 0,
|
||
last_line: 1,
|
||
last_column: 0
|
||
}, this.options.ranges && (this.yylloc.range = [0, 0]), this.offset = 0, this
|
||
},
|
||
input: function () {
|
||
var t = this._input[0];
|
||
return this.yytext += t, this.yyleng++, this.offset++, this.match += t, this.matched += t, t.match(/(?:\r\n?|\n).*/g) ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), t
|
||
},
|
||
unput: function (t) {
|
||
var e = t.length, i = t.split(/(?:\r\n?|\n)/g);
|
||
this._input = t + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - e), this.offset -= e;
|
||
var r = this.match.split(/(?:\r\n?|\n)/g);
|
||
this.match = this.match.substr(0, this.match.length - 1), this.matched = this.matched.substr(0, this.matched.length - 1), i.length - 1 && (this.yylineno -= i.length - 1);
|
||
var o = this.yylloc.range;
|
||
return this.yylloc = {
|
||
first_line: this.yylloc.first_line,
|
||
last_line: this.yylineno + 1,
|
||
first_column: this.yylloc.first_column,
|
||
last_column: i ? (i.length === r.length ? this.yylloc.first_column : 0) + r[r.length - i.length].length - i[0].length : this.yylloc.first_column - e
|
||
}, this.options.ranges && (this.yylloc.range = [o[0], o[0] + this.yyleng - e]), this.yyleng = this.yytext.length, this
|
||
},
|
||
more: function () {
|
||
return this._more = !0, this
|
||
},
|
||
reject: function () {
|
||
return this.options.backtrack_lexer ? (this._backtrack = !0, this) : this.parseError("Lexical error on line " + (this.yylineno + 1) + ". You can only invoke reject() in the lexer when the lexer is of the backtracking persuasion (options.backtrack_lexer = true).\n" + this.showPosition(), {
|
||
text: "",
|
||
token: null,
|
||
line: this.yylineno
|
||
})
|
||
},
|
||
less: function (t) {
|
||
this.unput(this.match.slice(t))
|
||
},
|
||
pastInput: function () {
|
||
var t = this.matched.substr(0, this.matched.length - this.match.length);
|
||
return (t.length > 20 ? "..." : "") + t.substr(-20).replace(/\n/g, "")
|
||
},
|
||
upcomingInput: function () {
|
||
var t = this.match;
|
||
return t.length < 20 && (t += this._input.substr(0, 20 - t.length)), (t.substr(0, 20) + (t.length > 20 ? "..." : "")).replace(/\n/g, "")
|
||
},
|
||
showPosition: function () {
|
||
var t = this.pastInput(), e = new Array(t.length + 1).join("-");
|
||
return t + this.upcomingInput() + "\n" + e + "^"
|
||
},
|
||
test_match: function (t, e) {
|
||
var i, r, o;
|
||
if (this.options.backtrack_lexer && (o = {
|
||
yylineno: this.yylineno,
|
||
yylloc: {
|
||
first_line: this.yylloc.first_line,
|
||
last_line: this.last_line,
|
||
first_column: this.yylloc.first_column,
|
||
last_column: this.yylloc.last_column
|
||
},
|
||
yytext: this.yytext,
|
||
match: this.match,
|
||
matches: this.matches,
|
||
matched: this.matched,
|
||
yyleng: this.yyleng,
|
||
offset: this.offset,
|
||
_more: this._more,
|
||
_input: this._input,
|
||
yy: this.yy,
|
||
conditionStack: this.conditionStack.slice(0),
|
||
done: this.done
|
||
}, this.options.ranges && (o.yylloc.range = this.yylloc.range.slice(0))), (r = t[0].match(/(?:\r\n?|\n).*/g)) && (this.yylineno += r.length), this.yylloc = {
|
||
first_line: this.yylloc.last_line,
|
||
last_line: this.yylineno + 1,
|
||
first_column: this.yylloc.last_column,
|
||
last_column: r ? r[r.length - 1].length - r[r.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + t[0].length
|
||
}, this.yytext += t[0], this.match += t[0], this.matches = t, this.yyleng = this.yytext.length, this.options.ranges && (this.yylloc.range = [this.offset, this.offset += this.yyleng]), this._more = !1, this._backtrack = !1, this._input = this._input.slice(t[0].length), this.matched += t[0], i = this.performAction.call(this, this.yy, this, e, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), i) return i;
|
||
if (this._backtrack) {
|
||
for (var n in o) this[n] = o[n];
|
||
return !1
|
||
}
|
||
return !1
|
||
},
|
||
next: function () {
|
||
if (this.done) return this.EOF;
|
||
var t, e, i, r;
|
||
this._input || (this.done = !0), this._more || (this.yytext = "", this.match = "");
|
||
for (var o = this._currentRules(), n = 0; n < o.length; n++) if ((i = this._input.match(this.rules[o[n]])) && (!e || i[0].length > e[0].length)) {
|
||
if (e = i, r = n, this.options.backtrack_lexer) {
|
||
if (!1 !== (t = this.test_match(i, o[n]))) return t;
|
||
if (this._backtrack) {
|
||
e = !1;
|
||
continue
|
||
}
|
||
return !1
|
||
}
|
||
if (!this.options.flex) break
|
||
}
|
||
return e ? !1 !== (t = this.test_match(e, o[r])) && t : "" === this._input ? this.EOF : this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), {
|
||
text: "",
|
||
token: null,
|
||
line: this.yylineno
|
||
})
|
||
},
|
||
lex: function () {
|
||
var t = this.next();
|
||
return t || this.lex()
|
||
},
|
||
begin: function (t) {
|
||
this.conditionStack.push(t)
|
||
},
|
||
popState: function () {
|
||
return this.conditionStack.length - 1 > 0 ? this.conditionStack.pop() : this.conditionStack[0]
|
||
},
|
||
_currentRules: function () {
|
||
return this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1] ? this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules : this.conditions.INITIAL.rules
|
||
},
|
||
topState: function (t) {
|
||
return (t = this.conditionStack.length - 1 - Math.abs(t || 0)) >= 0 ? this.conditionStack[t] : "INITIAL"
|
||
},
|
||
pushState: function (t) {
|
||
this.begin(t)
|
||
},
|
||
stateStackSize: function () {
|
||
return this.conditionStack.length
|
||
},
|
||
options: {},
|
||
performAction: function (t, e, i, r) {
|
||
switch (i) {
|
||
case 0:
|
||
break;
|
||
case 1:
|
||
return 6;
|
||
case 2:
|
||
return e.yytext = e.yytext.substr(1, e.yyleng - 2), 4;
|
||
case 3:
|
||
return 17;
|
||
case 4:
|
||
return 18;
|
||
case 5:
|
||
return 23;
|
||
case 6:
|
||
return 24;
|
||
case 7:
|
||
return 22;
|
||
case 8:
|
||
return 21;
|
||
case 9:
|
||
return 10;
|
||
case 10:
|
||
return 11;
|
||
case 11:
|
||
return 8;
|
||
case 12:
|
||
return 14;
|
||
case 13:
|
||
return "INVALID"
|
||
}
|
||
},
|
||
rules: [/^(?:\s+)/, /^(?:(-?([0-9]|[1-9][0-9]+))(\.[0-9]+)?([eE][-+]?[0-9]+)?\b)/, /^(?:"(?:\\[\\"bfnrt\/]|\\u[a-fA-F0-9]{4}|[^\\\0-\x09\x0a-\x1f"])*")/, /^(?:\{)/, /^(?:\})/, /^(?:\[)/, /^(?:\])/, /^(?:,)/, /^(?::)/, /^(?:true\b)/, /^(?:false\b)/, /^(?:null\b)/, /^(?:$)/, /^(?:.)/],
|
||
conditions: {
|
||
INITIAL: {
|
||
rules: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13],
|
||
inclusive: !0
|
||
}
|
||
}
|
||
};
|
||
|
||
function d() {
|
||
this.yy = {}
|
||
}
|
||
|
||
return c.lexer = p, d.prototype = c, c.Parser = d, new d
|
||
}();
|
||
e.parser = i, e.Parser = i.Parser, e.parse = function () {
|
||
return i.parse.apply(i, arguments)
|
||
}
|
||
});
|
||
|
||
function qi(t, e) {
|
||
if (t instanceof String || "string" == typeof t || t instanceof i) try {
|
||
t = Xi.parse(t.toString())
|
||
} catch (t) {
|
||
return [new Ci(t)]
|
||
}
|
||
return Yi(t, e = e || r)
|
||
}
|
||
|
||
Xi.parser, Xi.Parser, Xi.parse;
|
||
var Zi = {
|
||
StyleExpression: ze,
|
||
isExpression: Ue,
|
||
createExpression: Be,
|
||
createPropertyExpression: We,
|
||
normalizePropertyExpression: function (t, e) {
|
||
if (Oe(t)) return new He(t, e);
|
||
if (Ue(t)) {
|
||
var i = We(t, e);
|
||
if ("error" === i.result) throw new Error(i.value.map(function (t) {
|
||
return t.key + ": " + t.message
|
||
}).join(", "));
|
||
return i.value
|
||
}
|
||
var r = t;
|
||
return "string" == typeof t && "color" === e.type && (r = lt.parse(t)), {
|
||
kind: "constant",
|
||
evaluate: function () {
|
||
return r
|
||
}
|
||
}
|
||
},
|
||
ZoomConstantExpression: Ve,
|
||
ZoomDependentExpression: Ye,
|
||
StylePropertyFunction: He
|
||
}, Ki = {convertFunction: qe, createFunction: Ae, isFunction: Oe},
|
||
Ji = {eachSource: D, eachLayer: G, eachProperty: j};
|
||
qi.parsed = qi, qi.latest = qi, e.Color = lt, e.ParsingError = Ci, e.ValidationError = bi, e.composite = function (t) {
|
||
var e = [], i = [], r = [];
|
||
for (var o in t.sources) {
|
||
var n = t.sources[o];
|
||
if ("vector" === n.type) {
|
||
var s = /^mapbox:\/\/(.*)/.exec(n.url);
|
||
s && (e.push(o), i.push(s[1]))
|
||
}
|
||
}
|
||
if (e.length < 2) return t;
|
||
e.forEach(function (e) {
|
||
delete t.sources[e]
|
||
});
|
||
var a = i.join(",");
|
||
return t.sources[a] = {type: "vector", url: "mapbox://" + a}, t.layers.forEach(function (t) {
|
||
if (e.indexOf(t.source) >= 0 && (t.source = a, "source-layer" in t)) {
|
||
if (r.indexOf(t["source-layer"]) >= 0) throw new Error("Conflicting source layer names");
|
||
r.push(t["source-layer"])
|
||
}
|
||
}), t
|
||
}, e.diff = function (t, e) {
|
||
if (!t) return [{command: fi.setStyle, args: [e]}];
|
||
var i = [];
|
||
try {
|
||
if (!di(t.version, e.version)) return [{command: fi.setStyle, args: [e]}];
|
||
di(t.center, e.center) || i.push({
|
||
command: fi.setCenter,
|
||
args: [e.center]
|
||
}), di(t.zoom, e.zoom) || i.push({
|
||
command: fi.setZoom,
|
||
args: [e.zoom]
|
||
}), di(t.bearing, e.bearing) || i.push({
|
||
command: fi.setBearing,
|
||
args: [e.bearing]
|
||
}), di(t.pitch, e.pitch) || i.push({
|
||
command: fi.setPitch,
|
||
args: [e.pitch]
|
||
}), di(t.sprite, e.sprite) || i.push({
|
||
command: fi.setSprite,
|
||
args: [e.sprite]
|
||
}), di(t.glyphs, e.glyphs) || i.push({
|
||
command: fi.setGlyphs,
|
||
args: [e.glyphs]
|
||
}), di(t.transition, e.transition) || i.push({
|
||
command: fi.setTransition,
|
||
args: [e.transition]
|
||
}), di(t.light, e.light) || i.push({command: fi.setLight, args: [e.light]});
|
||
var r = {}, o = [];
|
||
!function (t, e, i, r) {
|
||
var o;
|
||
for (o in e = e || {}, t = t || {}) t.hasOwnProperty(o) && (e.hasOwnProperty(o) || mi(o, i, r));
|
||
for (o in e) e.hasOwnProperty(o) && (t.hasOwnProperty(o) ? di(t[o], e[o]) || ("geojson" === t[o].type && "geojson" === e[o].type && vi(t, e, o) ? i.push({
|
||
command: fi.setGeoJSONSourceData,
|
||
args: [o, e[o].data]
|
||
}) : yi(o, e, i, r)) : gi(o, e, i))
|
||
}(t.sources, e.sources, o, r);
|
||
var n = [];
|
||
t.layers && t.layers.forEach(function (t) {
|
||
r[t.source] ? i.push({command: fi.removeLayer, args: [t.id]}) : n.push(t)
|
||
}), i = i.concat(o), function (t, e, i) {
|
||
e = e || [];
|
||
var r, o, n, s, a, l, h, u = (t = t || []).map(xi), c = e.map(xi), p = t.reduce(wi, {}),
|
||
d = e.reduce(wi, {}), f = u.slice(), g = Object.create(null);
|
||
for (r = 0, o = 0; r < u.length; r++) n = u[r], d.hasOwnProperty(n) ? o++ : (i.push({
|
||
command: fi.removeLayer,
|
||
args: [n]
|
||
}), f.splice(f.indexOf(n, o), 1));
|
||
for (r = 0, o = 0; r < c.length; r++) n = c[c.length - 1 - r], f[f.length - 1 - r] !== n && (p.hasOwnProperty(n) ? (i.push({
|
||
command: fi.removeLayer,
|
||
args: [n]
|
||
}), f.splice(f.lastIndexOf(n, f.length - o), 1)) : o++, l = f[f.length - r], i.push({
|
||
command: fi.addLayer,
|
||
args: [d[n], l]
|
||
}), f.splice(f.length - r, 0, n), g[n] = !0);
|
||
for (r = 0; r < c.length; r++) if (s = p[n = c[r]], a = d[n], !g[n] && !di(s, a)) if (di(s.source, a.source) && di(s["source-layer"], a["source-layer"]) && di(s.type, a.type)) {
|
||
for (h in _i(s.layout, a.layout, i, n, null, fi.setLayoutProperty), _i(s.paint, a.paint, i, n, null, fi.setPaintProperty), di(s.filter, a.filter) || i.push({
|
||
command: fi.setFilter,
|
||
args: [n, a.filter]
|
||
}), di(s.minzoom, a.minzoom) && di(s.maxzoom, a.maxzoom) || i.push({
|
||
command: fi.setLayerZoomRange,
|
||
args: [n, a.minzoom, a.maxzoom]
|
||
}), s) s.hasOwnProperty(h) && "layout" !== h && "paint" !== h && "filter" !== h && "metadata" !== h && "minzoom" !== h && "maxzoom" !== h && (0 === h.indexOf("paint.") ? _i(s[h], a[h], i, n, h.slice(6), fi.setPaintProperty) : di(s[h], a[h]) || i.push({
|
||
command: fi.setLayerProperty,
|
||
args: [n, h, a[h]]
|
||
}));
|
||
for (h in a) a.hasOwnProperty(h) && !s.hasOwnProperty(h) && "layout" !== h && "paint" !== h && "filter" !== h && "metadata" !== h && "minzoom" !== h && "maxzoom" !== h && (0 === h.indexOf("paint.") ? _i(s[h], a[h], i, n, h.slice(6), fi.setPaintProperty) : di(s[h], a[h]) || i.push({
|
||
command: fi.setLayerProperty,
|
||
args: [n, h, a[h]]
|
||
}))
|
||
} else i.push({
|
||
command: fi.removeLayer,
|
||
args: [n]
|
||
}), l = f[f.lastIndexOf(n) + 1], i.push({command: fi.addLayer, args: [a, l]})
|
||
}(n, e.layers, i)
|
||
} catch (t) {
|
||
console.warn("Unable to compute style diff:", t), i = [{command: fi.setStyle, args: [e]}]
|
||
}
|
||
return i
|
||
}, e.expression = Zi, e.featureFilter = function (t) {
|
||
if (null == t) return function () {
|
||
return !0
|
||
};
|
||
ii(t) || (t = ni(t));
|
||
var e = Be(t, ri);
|
||
if ("error" === e.result) throw new Error(e.value.map(function (t) {
|
||
return t.key + ": " + t.message
|
||
}).join(", "));
|
||
return function (t, i) {
|
||
return e.value.evaluate(t, i)
|
||
}
|
||
}, e.format = function (t, e) {
|
||
return void 0 === e && (e = 2), (t = s(t, r.$root)).layers && (t.layers = t.layers.map(function (t) {
|
||
return s(t, r.layer)
|
||
})), n(t, {indent: e})
|
||
}, e.function = Ki, e.latest = r, e.migrate = function (t) {
|
||
var e = !1;
|
||
if (7 === t.version && (t = Y(t), e = !0), 8 === t.version && (e = function (t) {
|
||
var e = [];
|
||
return G(t, function (t) {
|
||
t.filter && (t.filter = ui(t.filter))
|
||
}), j(t, {paint: !0, layout: !0}, function (t) {
|
||
var i = t.path, r = t.value, o = t.reference, n = t.set;
|
||
Ue(r) || ("object" != typeof r || Array.isArray(r) ? o.tokens && "string" == typeof r && n(ei(r)) : (n(qe(r, o)), e.push(i.join("."))))
|
||
}), t
|
||
}(t), e = !0), !e) throw new Error("cannot migrate from", t.version);
|
||
return t
|
||
}, e.v8 = r, e.validate = qi, e.visit = Ji, Object.defineProperty(e, "__esModule", {value: !0})
|
||
})(e)
|
||
}).call(this, i(8), i(18).Buffer)
|
||
}, function (t, e, i) {
|
||
"use strict";
|
||
t.exports = o, t.exports.default = o;
|
||
var r = i(15);
|
||
|
||
function o(t, e) {
|
||
if (!(this instanceof o)) return new o(t, e);
|
||
this._maxEntries = Math.max(4, t || 9), this._minEntries = Math.max(2, Math.ceil(.4 * this._maxEntries)), e && this._initFormat(e), this.clear()
|
||
}
|
||
|
||
function n(t, e, i) {
|
||
if (!i) return e.indexOf(t);
|
||
for (var r = 0; r < e.length; r++) if (i(t, e[r])) return r;
|
||
return -1
|
||
}
|
||
|
||
function s(t, e) {
|
||
a(t, 0, t.children.length, e, t)
|
||
}
|
||
|
||
function a(t, e, i, r, o) {
|
||
o || (o = g(null)), o.minX = 1 / 0, o.minY = 1 / 0, o.maxX = -1 / 0, o.maxY = -1 / 0;
|
||
for (var n, s = e; s < i; s++) n = t.children[s], l(o, t.leaf ? r(n) : n);
|
||
return o
|
||
}
|
||
|
||
function l(t, e) {
|
||
return t.minX = Math.min(t.minX, e.minX), t.minY = Math.min(t.minY, e.minY), t.maxX = Math.max(t.maxX, e.maxX), t.maxY = Math.max(t.maxY, e.maxY), t
|
||
}
|
||
|
||
function h(t, e) {
|
||
return t.minX - e.minX
|
||
}
|
||
|
||
function u(t, e) {
|
||
return t.minY - e.minY
|
||
}
|
||
|
||
function c(t) {
|
||
return (t.maxX - t.minX) * (t.maxY - t.minY)
|
||
}
|
||
|
||
function p(t) {
|
||
return t.maxX - t.minX + (t.maxY - t.minY)
|
||
}
|
||
|
||
function d(t, e) {
|
||
return t.minX <= e.minX && t.minY <= e.minY && e.maxX <= t.maxX && e.maxY <= t.maxY
|
||
}
|
||
|
||
function f(t, e) {
|
||
return e.minX <= t.maxX && e.minY <= t.maxY && e.maxX >= t.minX && e.maxY >= t.minY
|
||
}
|
||
|
||
function g(t) {
|
||
return {children: t, height: 1, leaf: !0, minX: 1 / 0, minY: 1 / 0, maxX: -1 / 0, maxY: -1 / 0}
|
||
}
|
||
|
||
function m(t, e, i, o, n) {
|
||
for (var s, a = [e, i]; a.length;) (i = a.pop()) - (e = a.pop()) <= o || (s = e + Math.ceil((i - e) / o / 2) * o, r(t, s, e, i, n), a.push(e, s, s, i))
|
||
}
|
||
|
||
o.prototype = {
|
||
all: function () {
|
||
return this._all(this.data, [])
|
||
}, search: function (t) {
|
||
var e = this.data, i = [], r = this.toBBox;
|
||
if (!f(t, e)) return i;
|
||
for (var o, n, s, a, l = []; e;) {
|
||
for (o = 0, n = e.children.length; o < n; o++) s = e.children[o], f(t, a = e.leaf ? r(s) : s) && (e.leaf ? i.push(s) : d(t, a) ? this._all(s, i) : l.push(s));
|
||
e = l.pop()
|
||
}
|
||
return i
|
||
}, collides: function (t) {
|
||
var e = this.data, i = this.toBBox;
|
||
if (!f(t, e)) return !1;
|
||
for (var r, o, n, s, a = []; e;) {
|
||
for (r = 0, o = e.children.length; r < o; r++) if (n = e.children[r], f(t, s = e.leaf ? i(n) : n)) {
|
||
if (e.leaf || d(t, s)) return !0;
|
||
a.push(n)
|
||
}
|
||
e = a.pop()
|
||
}
|
||
return !1
|
||
}, load: function (t) {
|
||
if (!t || !t.length) return this;
|
||
if (t.length < this._minEntries) {
|
||
for (var e = 0, i = t.length; e < i; e++) this.insert(t[e]);
|
||
return this
|
||
}
|
||
var r = this._build(t.slice(), 0, t.length - 1, 0);
|
||
if (this.data.children.length) if (this.data.height === r.height) this._splitRoot(this.data, r); else {
|
||
if (this.data.height < r.height) {
|
||
var o = this.data;
|
||
this.data = r, r = o
|
||
}
|
||
this._insert(r, this.data.height - r.height - 1, !0)
|
||
} else this.data = r;
|
||
return this
|
||
}, insert: function (t) {
|
||
return t && this._insert(t, this.data.height - 1), this
|
||
}, clear: function () {
|
||
return this.data = g([]), this
|
||
}, remove: function (t, e) {
|
||
if (!t) return this;
|
||
for (var i, r, o, s, a = this.data, l = this.toBBox(t), h = [], u = []; a || h.length;) {
|
||
if (a || (a = h.pop(), r = h[h.length - 1], i = u.pop(), s = !0), a.leaf && -1 !== (o = n(t, a.children, e))) return a.children.splice(o, 1), h.push(a), this._condense(h), this;
|
||
s || a.leaf || !d(a, l) ? r ? (i++, a = r.children[i], s = !1) : a = null : (h.push(a), u.push(i), i = 0, r = a, a = a.children[0])
|
||
}
|
||
return this
|
||
}, toBBox: function (t) {
|
||
return t
|
||
}, compareMinX: h, compareMinY: u, toJSON: function () {
|
||
return this.data
|
||
}, fromJSON: function (t) {
|
||
return this.data = t, this
|
||
}, _all: function (t, e) {
|
||
for (var i = []; t;) t.leaf ? e.push.apply(e, t.children) : i.push.apply(i, t.children), t = i.pop();
|
||
return e
|
||
}, _build: function (t, e, i, r) {
|
||
var o, n = i - e + 1, a = this._maxEntries;
|
||
if (n <= a) return s(o = g(t.slice(e, i + 1)), this.toBBox), o;
|
||
r || (r = Math.ceil(Math.log(n) / Math.log(a)), a = Math.ceil(n / Math.pow(a, r - 1))), (o = g([])).leaf = !1, o.height = r;
|
||
var l, h, u, c, p = Math.ceil(n / a), d = p * Math.ceil(Math.sqrt(a));
|
||
for (m(t, e, i, d, this.compareMinX), l = e; l <= i; l += d) for (m(t, l, u = Math.min(l + d - 1, i), p, this.compareMinY), h = l; h <= u; h += p) c = Math.min(h + p - 1, u), o.children.push(this._build(t, h, c, r - 1));
|
||
return s(o, this.toBBox), o
|
||
}, _chooseSubtree: function (t, e, i, r) {
|
||
for (var o, n, s, a, l, h, u, p, d, f; r.push(e), !e.leaf && r.length - 1 !== i;) {
|
||
for (u = p = 1 / 0, o = 0, n = e.children.length; o < n; o++) l = c(s = e.children[o]), d = t, f = s, (h = (Math.max(f.maxX, d.maxX) - Math.min(f.minX, d.minX)) * (Math.max(f.maxY, d.maxY) - Math.min(f.minY, d.minY)) - l) < p ? (p = h, u = l < u ? l : u, a = s) : h === p && l < u && (u = l, a = s);
|
||
e = a || e.children[0]
|
||
}
|
||
return e
|
||
}, _insert: function (t, e, i) {
|
||
var r = this.toBBox, o = i ? t : r(t), n = [], s = this._chooseSubtree(o, this.data, e, n);
|
||
for (s.children.push(t), l(s, o); e >= 0 && n[e].children.length > this._maxEntries;) this._split(n, e), e--;
|
||
this._adjustParentBBoxes(o, n, e)
|
||
}, _split: function (t, e) {
|
||
var i = t[e], r = i.children.length, o = this._minEntries;
|
||
this._chooseSplitAxis(i, o, r);
|
||
var n = this._chooseSplitIndex(i, o, r), a = g(i.children.splice(n, i.children.length - n));
|
||
a.height = i.height, a.leaf = i.leaf, s(i, this.toBBox), s(a, this.toBBox), e ? t[e - 1].children.push(a) : this._splitRoot(i, a)
|
||
}, _splitRoot: function (t, e) {
|
||
this.data = g([t, e]), this.data.height = t.height + 1, this.data.leaf = !1, s(this.data, this.toBBox)
|
||
}, _chooseSplitIndex: function (t, e, i) {
|
||
var r, o, n, s, l, h, u, p, d, f, g, m, y, v;
|
||
for (h = u = 1 / 0, r = e; r <= i - e; r++) o = a(t, 0, r, this.toBBox), n = a(t, r, i, this.toBBox), d = o, f = n, g = void 0, m = void 0, y = void 0, v = void 0, g = Math.max(d.minX, f.minX), m = Math.max(d.minY, f.minY), y = Math.min(d.maxX, f.maxX), v = Math.min(d.maxY, f.maxY), s = Math.max(0, y - g) * Math.max(0, v - m), l = c(o) + c(n), s < h ? (h = s, p = r, u = l < u ? l : u) : s === h && l < u && (u = l, p = r);
|
||
return p
|
||
}, _chooseSplitAxis: function (t, e, i) {
|
||
var r = t.leaf ? this.compareMinX : h, o = t.leaf ? this.compareMinY : u;
|
||
this._allDistMargin(t, e, i, r) < this._allDistMargin(t, e, i, o) && t.children.sort(r)
|
||
}, _allDistMargin: function (t, e, i, r) {
|
||
t.children.sort(r);
|
||
var o, n, s = this.toBBox, h = a(t, 0, e, s), u = a(t, i - e, i, s), c = p(h) + p(u);
|
||
for (o = e; o < i - e; o++) n = t.children[o], l(h, t.leaf ? s(n) : n), c += p(h);
|
||
for (o = i - e - 1; o >= e; o--) n = t.children[o], l(u, t.leaf ? s(n) : n), c += p(u);
|
||
return c
|
||
}, _adjustParentBBoxes: function (t, e, i) {
|
||
for (var r = i; r >= 0; r--) l(e[r], t)
|
||
}, _condense: function (t) {
|
||
for (var e, i = t.length - 1; i >= 0; i--) 0 === t[i].children.length ? i > 0 ? (e = t[i - 1].children).splice(e.indexOf(t[i]), 1) : this.clear() : s(t[i], this.toBBox)
|
||
}, _initFormat: function (t) {
|
||
var e = ["return a", " - b", ";"];
|
||
this.compareMinX = new Function("a", "b", e.join(t[0])), this.compareMinY = new Function("a", "b", e.join(t[1])), this.toBBox = new Function("a", "return {minX: a" + t[0] + ", minY: a" + t[1] + ", maxX: a" + t[2] + ", maxY: a" + t[3] + "};")
|
||
}
|
||
}
|
||
}, function (t, e) {
|
||
var i = {
|
||
thin: 100,
|
||
hairline: 100,
|
||
"ultra-light": 100,
|
||
"extra-light": 100,
|
||
light: 200,
|
||
book: 300,
|
||
regular: 400,
|
||
normal: 400,
|
||
plain: 400,
|
||
roman: 400,
|
||
standard: 400,
|
||
medium: 500,
|
||
"semi-bold": 600,
|
||
"demi-bold": 600,
|
||
bold: 700,
|
||
heavy: 800,
|
||
black: 800,
|
||
"extra-bold": 800,
|
||
"ultra-black": 900,
|
||
"extra-black": 900,
|
||
"ultra-bold": 900,
|
||
"heavy-black": 900,
|
||
fat: 900,
|
||
poster: 900
|
||
}, r = /(italic|oblique)$/i, o = {};
|
||
t.exports = function (t, e, n) {
|
||
var s = o[t];
|
||
if (!s) {
|
||
Array.isArray(t) || (t = [t]);
|
||
for (var a = "normal", l = "normal", h = [], u = 0, c = t.length; u < c; ++u) {
|
||
var p = t[u].split(" "), d = p[p.length - 1].toLowerCase();
|
||
for (var f in "normal" == d || "italic" == d || "oblique" == d ? (l = d, p.pop(), d = p[p.length - 1].toLowerCase()) : r.test(d) && (d = d.replace(r, ""), l = p[p.length - 1].replace(d, "")), i) if (d == f || d == f.replace("-", "") || d == f.replace("-", " ")) {
|
||
a = i[f], p.pop();
|
||
break
|
||
}
|
||
"number" == typeof d && (a = d);
|
||
var g = p.join(" ").replace("Klokantech Noto Sans", "Noto Sans");
|
||
-1 !== g.indexOf(" ") && (g = '"' + g + '"'), h.push(g)
|
||
}
|
||
s = o[t] = [l, a, h]
|
||
}
|
||
return s[0] + " " + s[1] + " " + e + "px" + (n ? "/" + n : "") + " " + s[2]
|
||
}
|
||
}, , function (t, e, i) {
|
||
var r, o, n;
|
||
/*!
|
||
autosize 4.0.2
|
||
license: MIT
|
||
http://www.jacklmoore.com/autosize
|
||
*/
|
||
o = [t, e], void 0 === (n = "function" == typeof (r = function (t, e) {
|
||
"use strict";
|
||
var i, r, o = "function" == typeof Map ? new Map : (i = [], r = [], {
|
||
has: function (t) {
|
||
return i.indexOf(t) > -1
|
||
}, get: function (t) {
|
||
return r[i.indexOf(t)]
|
||
}, set: function (t, e) {
|
||
-1 === i.indexOf(t) && (i.push(t), r.push(e))
|
||
}, delete: function (t) {
|
||
var e = i.indexOf(t);
|
||
e > -1 && (i.splice(e, 1), r.splice(e, 1))
|
||
}
|
||
}), n = function (t) {
|
||
return new Event(t, {bubbles: !0})
|
||
};
|
||
try {
|
||
new Event("test")
|
||
} catch (t) {
|
||
n = function (t) {
|
||
var e = document.createEvent("Event");
|
||
return e.initEvent(t, !0, !1), e
|
||
}
|
||
}
|
||
|
||
function s(t) {
|
||
if (t && t.nodeName && "TEXTAREA" === t.nodeName && !o.has(t)) {
|
||
var e = null, i = null, r = null, s = function () {
|
||
t.clientWidth !== i && c()
|
||
}, a = function (e) {
|
||
window.removeEventListener("resize", s, !1), t.removeEventListener("input", c, !1), t.removeEventListener("keyup", c, !1), t.removeEventListener("autosize:destroy", a, !1), t.removeEventListener("autosize:update", c, !1), Object.keys(e).forEach(function (i) {
|
||
t.style[i] = e[i]
|
||
}), o.delete(t)
|
||
}.bind(t, {
|
||
height: t.style.height,
|
||
resize: t.style.resize,
|
||
overflowY: t.style.overflowY,
|
||
overflowX: t.style.overflowX,
|
||
wordWrap: t.style.wordWrap
|
||
});
|
||
t.addEventListener("autosize:destroy", a, !1), "onpropertychange" in t && "oninput" in t && t.addEventListener("keyup", c, !1), window.addEventListener("resize", s, !1), t.addEventListener("input", c, !1), t.addEventListener("autosize:update", c, !1), t.style.overflowX = "hidden", t.style.wordWrap = "break-word", o.set(t, {
|
||
destroy: a,
|
||
update: c
|
||
}), "vertical" === (l = window.getComputedStyle(t, null)).resize ? t.style.resize = "none" : "both" === l.resize && (t.style.resize = "horizontal"), e = "content-box" === l.boxSizing ? -(parseFloat(l.paddingTop) + parseFloat(l.paddingBottom)) : parseFloat(l.borderTopWidth) + parseFloat(l.borderBottomWidth), isNaN(e) && (e = 0), c()
|
||
}
|
||
var l;
|
||
|
||
function h(e) {
|
||
var i = t.style.width;
|
||
t.style.width = "0px", t.offsetWidth, t.style.width = i, t.style.overflowY = e
|
||
}
|
||
|
||
function u() {
|
||
if (0 !== t.scrollHeight) {
|
||
var r = function (t) {
|
||
for (var e = []; t && t.parentNode && t.parentNode instanceof Element;) t.parentNode.scrollTop && e.push({
|
||
node: t.parentNode,
|
||
scrollTop: t.parentNode.scrollTop
|
||
}), t = t.parentNode;
|
||
return e
|
||
}(t), o = document.documentElement && document.documentElement.scrollTop;
|
||
t.style.height = "", t.style.height = t.scrollHeight + e + "px", i = t.clientWidth, r.forEach(function (t) {
|
||
t.node.scrollTop = t.scrollTop
|
||
}), o && (document.documentElement.scrollTop = o)
|
||
}
|
||
}
|
||
|
||
function c() {
|
||
u();
|
||
var e = Math.round(parseFloat(t.style.height)), i = window.getComputedStyle(t, null),
|
||
o = "content-box" === i.boxSizing ? Math.round(parseFloat(i.height)) : t.offsetHeight;
|
||
if (o < e ? "hidden" === i.overflowY && (h("scroll"), u(), o = "content-box" === i.boxSizing ? Math.round(parseFloat(window.getComputedStyle(t, null).height)) : t.offsetHeight) : "hidden" !== i.overflowY && (h("hidden"), u(), o = "content-box" === i.boxSizing ? Math.round(parseFloat(window.getComputedStyle(t, null).height)) : t.offsetHeight), r !== o) {
|
||
r = o;
|
||
var s = n("autosize:resized");
|
||
try {
|
||
t.dispatchEvent(s)
|
||
} catch (t) {
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
function a(t) {
|
||
var e = o.get(t);
|
||
e && e.destroy()
|
||
}
|
||
|
||
function l(t) {
|
||
var e = o.get(t);
|
||
e && e.update()
|
||
}
|
||
|
||
var h = null;
|
||
"undefined" == typeof window || "function" != typeof window.getComputedStyle ? ((h = function (t) {
|
||
return t
|
||
}).destroy = function (t) {
|
||
return t
|
||
}, h.update = function (t) {
|
||
return t
|
||
}) : ((h = function (t, e) {
|
||
return t && Array.prototype.forEach.call(t.length ? t : [t], function (t) {
|
||
return s(t)
|
||
}), t
|
||
}).destroy = function (t) {
|
||
return t && Array.prototype.forEach.call(t.length ? t : [t], a), t
|
||
}, h.update = function (t) {
|
||
return t && Array.prototype.forEach.call(t.length ? t : [t], l), t
|
||
}), e.default = h, t.exports = e.default
|
||
}) ? r.apply(e, o) : r) || (t.exports = n)
|
||
}, function (t, e) {
|
||
e.read = function (t, e, i, r, o) {
|
||
var n, s, a = 8 * o - r - 1, l = (1 << a) - 1, h = l >> 1, u = -7, c = i ? o - 1 : 0, p = i ? -1 : 1,
|
||
d = t[e + c];
|
||
for (c += p, n = d & (1 << -u) - 1, d >>= -u, u += a; u > 0; n = 256 * n + t[e + c], c += p, u -= 8) ;
|
||
for (s = n & (1 << -u) - 1, n >>= -u, u += r; u > 0; s = 256 * s + t[e + c], c += p, u -= 8) ;
|
||
if (0 === n) n = 1 - h; else {
|
||
if (n === l) return s ? NaN : 1 / 0 * (d ? -1 : 1);
|
||
s += Math.pow(2, r), n -= h
|
||
}
|
||
return (d ? -1 : 1) * s * Math.pow(2, n - r)
|
||
}, e.write = function (t, e, i, r, o, n) {
|
||
var s, a, l, h = 8 * n - o - 1, u = (1 << h) - 1, c = u >> 1,
|
||
p = 23 === o ? Math.pow(2, -24) - Math.pow(2, -77) : 0, d = r ? 0 : n - 1, f = r ? 1 : -1,
|
||
g = e < 0 || 0 === e && 1 / e < 0 ? 1 : 0;
|
||
for (e = Math.abs(e), isNaN(e) || e === 1 / 0 ? (a = isNaN(e) ? 1 : 0, s = u) : (s = Math.floor(Math.log(e) / Math.LN2), e * (l = Math.pow(2, -s)) < 1 && (s--, l *= 2), (e += s + c >= 1 ? p / l : p * Math.pow(2, 1 - c)) * l >= 2 && (s++, l /= 2), s + c >= u ? (a = 0, s = u) : s + c >= 1 ? (a = (e * l - 1) * Math.pow(2, o), s += c) : (a = e * Math.pow(2, c - 1) * Math.pow(2, o), s = 0)); o >= 8; t[i + d] = 255 & a, d += f, a /= 256, o -= 8) ;
|
||
for (s = s << o | a, h += o; h > 0; t[i + d] = 255 & s, d += f, s /= 256, h -= 8) ;
|
||
t[i + d - f] |= 128 * g
|
||
}
|
||
}, function (t, e) {
|
||
var i;
|
||
i = function () {
|
||
return this
|
||
}();
|
||
try {
|
||
i = i || new Function("return this")()
|
||
} catch (t) {
|
||
"object" == typeof window && (i = window)
|
||
}
|
||
t.exports = i
|
||
}, function (t, e, i) {
|
||
"use strict";
|
||
t.exports = o;
|
||
var r = i(7);
|
||
|
||
function o(t) {
|
||
this.buf = ArrayBuffer.isView && ArrayBuffer.isView(t) ? t : new Uint8Array(t || 0), this.pos = 0, this.type = 0, this.length = this.buf.length
|
||
}
|
||
|
||
o.Varint = 0, o.Fixed64 = 1, o.Bytes = 2, o.Fixed32 = 5;
|
||
|
||
function n(t) {
|
||
return t.type === o.Bytes ? t.readVarint() + t.pos : t.pos + 1
|
||
}
|
||
|
||
function s(t, e, i) {
|
||
return i ? 4294967296 * e + (t >>> 0) : 4294967296 * (e >>> 0) + (t >>> 0)
|
||
}
|
||
|
||
function a(t, e, i) {
|
||
var r = e <= 16383 ? 1 : e <= 2097151 ? 2 : e <= 268435455 ? 3 : Math.ceil(Math.log(e) / (7 * Math.LN2));
|
||
i.realloc(r);
|
||
for (var o = i.pos - 1; o >= t; o--) i.buf[o + r] = i.buf[o]
|
||
}
|
||
|
||
function l(t, e) {
|
||
for (var i = 0; i < t.length; i++) e.writeVarint(t[i])
|
||
}
|
||
|
||
function h(t, e) {
|
||
for (var i = 0; i < t.length; i++) e.writeSVarint(t[i])
|
||
}
|
||
|
||
function u(t, e) {
|
||
for (var i = 0; i < t.length; i++) e.writeFloat(t[i])
|
||
}
|
||
|
||
function c(t, e) {
|
||
for (var i = 0; i < t.length; i++) e.writeDouble(t[i])
|
||
}
|
||
|
||
function p(t, e) {
|
||
for (var i = 0; i < t.length; i++) e.writeBoolean(t[i])
|
||
}
|
||
|
||
function d(t, e) {
|
||
for (var i = 0; i < t.length; i++) e.writeFixed32(t[i])
|
||
}
|
||
|
||
function f(t, e) {
|
||
for (var i = 0; i < t.length; i++) e.writeSFixed32(t[i])
|
||
}
|
||
|
||
function g(t, e) {
|
||
for (var i = 0; i < t.length; i++) e.writeFixed64(t[i])
|
||
}
|
||
|
||
function m(t, e) {
|
||
for (var i = 0; i < t.length; i++) e.writeSFixed64(t[i])
|
||
}
|
||
|
||
function y(t, e) {
|
||
return (t[e] | t[e + 1] << 8 | t[e + 2] << 16) + 16777216 * t[e + 3]
|
||
}
|
||
|
||
function v(t, e, i) {
|
||
t[i] = e, t[i + 1] = e >>> 8, t[i + 2] = e >>> 16, t[i + 3] = e >>> 24
|
||
}
|
||
|
||
function _(t, e) {
|
||
return (t[e] | t[e + 1] << 8 | t[e + 2] << 16) + (t[e + 3] << 24)
|
||
}
|
||
|
||
o.prototype = {
|
||
destroy: function () {
|
||
this.buf = null
|
||
}, readFields: function (t, e, i) {
|
||
for (i = i || this.length; this.pos < i;) {
|
||
var r = this.readVarint(), o = r >> 3, n = this.pos;
|
||
this.type = 7 & r, t(o, e, this), this.pos === n && this.skip(r)
|
||
}
|
||
return e
|
||
}, readMessage: function (t, e) {
|
||
return this.readFields(t, e, this.readVarint() + this.pos)
|
||
}, readFixed32: function () {
|
||
var t = y(this.buf, this.pos);
|
||
return this.pos += 4, t
|
||
}, readSFixed32: function () {
|
||
var t = _(this.buf, this.pos);
|
||
return this.pos += 4, t
|
||
}, readFixed64: function () {
|
||
var t = y(this.buf, this.pos) + 4294967296 * y(this.buf, this.pos + 4);
|
||
return this.pos += 8, t
|
||
}, readSFixed64: function () {
|
||
var t = y(this.buf, this.pos) + 4294967296 * _(this.buf, this.pos + 4);
|
||
return this.pos += 8, t
|
||
}, readFloat: function () {
|
||
var t = r.read(this.buf, this.pos, !0, 23, 4);
|
||
return this.pos += 4, t
|
||
}, readDouble: function () {
|
||
var t = r.read(this.buf, this.pos, !0, 52, 8);
|
||
return this.pos += 8, t
|
||
}, readVarint: function (t) {
|
||
var e, i, r = this.buf;
|
||
return e = 127 & (i = r[this.pos++]), i < 128 ? e : (e |= (127 & (i = r[this.pos++])) << 7, i < 128 ? e : (e |= (127 & (i = r[this.pos++])) << 14, i < 128 ? e : (e |= (127 & (i = r[this.pos++])) << 21, i < 128 ? e : function (t, e, i) {
|
||
var r, o, n = i.buf;
|
||
if (o = n[i.pos++], r = (112 & o) >> 4, o < 128) return s(t, r, e);
|
||
if (o = n[i.pos++], r |= (127 & o) << 3, o < 128) return s(t, r, e);
|
||
if (o = n[i.pos++], r |= (127 & o) << 10, o < 128) return s(t, r, e);
|
||
if (o = n[i.pos++], r |= (127 & o) << 17, o < 128) return s(t, r, e);
|
||
if (o = n[i.pos++], r |= (127 & o) << 24, o < 128) return s(t, r, e);
|
||
if (o = n[i.pos++], r |= (1 & o) << 31, o < 128) return s(t, r, e);
|
||
throw new Error("Expected varint not more than 10 bytes")
|
||
}(e |= (15 & (i = r[this.pos])) << 28, t, this))))
|
||
}, readVarint64: function () {
|
||
return this.readVarint(!0)
|
||
}, readSVarint: function () {
|
||
var t = this.readVarint();
|
||
return t % 2 == 1 ? (t + 1) / -2 : t / 2
|
||
}, readBoolean: function () {
|
||
return Boolean(this.readVarint())
|
||
}, readString: function () {
|
||
var t = this.readVarint() + this.pos, e = function (t, e, i) {
|
||
var r = "", o = e;
|
||
for (; o < i;) {
|
||
var n, s, a, l = t[o], h = null, u = l > 239 ? 4 : l > 223 ? 3 : l > 191 ? 2 : 1;
|
||
if (o + u > i) break;
|
||
1 === u ? l < 128 && (h = l) : 2 === u ? 128 == (192 & (n = t[o + 1])) && (h = (31 & l) << 6 | 63 & n) <= 127 && (h = null) : 3 === u ? (n = t[o + 1], s = t[o + 2], 128 == (192 & n) && 128 == (192 & s) && ((h = (15 & l) << 12 | (63 & n) << 6 | 63 & s) <= 2047 || h >= 55296 && h <= 57343) && (h = null)) : 4 === u && (n = t[o + 1], s = t[o + 2], a = t[o + 3], 128 == (192 & n) && 128 == (192 & s) && 128 == (192 & a) && ((h = (15 & l) << 18 | (63 & n) << 12 | (63 & s) << 6 | 63 & a) <= 65535 || h >= 1114112) && (h = null)), null === h ? (h = 65533, u = 1) : h > 65535 && (h -= 65536, r += String.fromCharCode(h >>> 10 & 1023 | 55296), h = 56320 | 1023 & h), r += String.fromCharCode(h), o += u
|
||
}
|
||
return r
|
||
}(this.buf, this.pos, t);
|
||
return this.pos = t, e
|
||
}, readBytes: function () {
|
||
var t = this.readVarint() + this.pos, e = this.buf.subarray(this.pos, t);
|
||
return this.pos = t, e
|
||
}, readPackedVarint: function (t, e) {
|
||
var i = n(this);
|
||
for (t = t || []; this.pos < i;) t.push(this.readVarint(e));
|
||
return t
|
||
}, readPackedSVarint: function (t) {
|
||
var e = n(this);
|
||
for (t = t || []; this.pos < e;) t.push(this.readSVarint());
|
||
return t
|
||
}, readPackedBoolean: function (t) {
|
||
var e = n(this);
|
||
for (t = t || []; this.pos < e;) t.push(this.readBoolean());
|
||
return t
|
||
}, readPackedFloat: function (t) {
|
||
var e = n(this);
|
||
for (t = t || []; this.pos < e;) t.push(this.readFloat());
|
||
return t
|
||
}, readPackedDouble: function (t) {
|
||
var e = n(this);
|
||
for (t = t || []; this.pos < e;) t.push(this.readDouble());
|
||
return t
|
||
}, readPackedFixed32: function (t) {
|
||
var e = n(this);
|
||
for (t = t || []; this.pos < e;) t.push(this.readFixed32());
|
||
return t
|
||
}, readPackedSFixed32: function (t) {
|
||
var e = n(this);
|
||
for (t = t || []; this.pos < e;) t.push(this.readSFixed32());
|
||
return t
|
||
}, readPackedFixed64: function (t) {
|
||
var e = n(this);
|
||
for (t = t || []; this.pos < e;) t.push(this.readFixed64());
|
||
return t
|
||
}, readPackedSFixed64: function (t) {
|
||
var e = n(this);
|
||
for (t = t || []; this.pos < e;) t.push(this.readSFixed64());
|
||
return t
|
||
}, skip: function (t) {
|
||
var e = 7 & t;
|
||
if (e === o.Varint) for (; this.buf[this.pos++] > 127;) ; else if (e === o.Bytes) this.pos = this.readVarint() + this.pos; else if (e === o.Fixed32) this.pos += 4; else {
|
||
if (e !== o.Fixed64) throw new Error("Unimplemented type: " + e);
|
||
this.pos += 8
|
||
}
|
||
}, writeTag: function (t, e) {
|
||
this.writeVarint(t << 3 | e)
|
||
}, realloc: function (t) {
|
||
for (var e = this.length || 16; e < this.pos + t;) e *= 2;
|
||
if (e !== this.length) {
|
||
var i = new Uint8Array(e);
|
||
i.set(this.buf), this.buf = i, this.length = e
|
||
}
|
||
}, finish: function () {
|
||
return this.length = this.pos, this.pos = 0, this.buf.subarray(0, this.length)
|
||
}, writeFixed32: function (t) {
|
||
this.realloc(4), v(this.buf, t, this.pos), this.pos += 4
|
||
}, writeSFixed32: function (t) {
|
||
this.realloc(4), v(this.buf, t, this.pos), this.pos += 4
|
||
}, writeFixed64: function (t) {
|
||
this.realloc(8), v(this.buf, -1 & t, this.pos), v(this.buf, Math.floor(t * (1 / 4294967296)), this.pos + 4), this.pos += 8
|
||
}, writeSFixed64: function (t) {
|
||
this.realloc(8), v(this.buf, -1 & t, this.pos), v(this.buf, Math.floor(t * (1 / 4294967296)), this.pos + 4), this.pos += 8
|
||
}, writeVarint: function (t) {
|
||
(t = +t || 0) > 268435455 || t < 0 ? function (t, e) {
|
||
var i, r;
|
||
t >= 0 ? (i = t % 4294967296 | 0, r = t / 4294967296 | 0) : (r = ~(-t / 4294967296), 4294967295 ^ (i = ~(-t % 4294967296)) ? i = i + 1 | 0 : (i = 0, r = r + 1 | 0));
|
||
if (t >= 0x10000000000000000 || t < -0x10000000000000000) throw new Error("Given varint doesn't fit into 10 bytes");
|
||
e.realloc(10), function (t, e, i) {
|
||
i.buf[i.pos++] = 127 & t | 128, t >>>= 7, i.buf[i.pos++] = 127 & t | 128, t >>>= 7, i.buf[i.pos++] = 127 & t | 128, t >>>= 7, i.buf[i.pos++] = 127 & t | 128, t >>>= 7, i.buf[i.pos] = 127 & t
|
||
}(i, 0, e), function (t, e) {
|
||
var i = (7 & t) << 4;
|
||
if (e.buf[e.pos++] |= i | ((t >>>= 3) ? 128 : 0), !t) return;
|
||
if (e.buf[e.pos++] = 127 & t | ((t >>>= 7) ? 128 : 0), !t) return;
|
||
if (e.buf[e.pos++] = 127 & t | ((t >>>= 7) ? 128 : 0), !t) return;
|
||
if (e.buf[e.pos++] = 127 & t | ((t >>>= 7) ? 128 : 0), !t) return;
|
||
if (e.buf[e.pos++] = 127 & t | ((t >>>= 7) ? 128 : 0), !t) return;
|
||
e.buf[e.pos++] = 127 & t
|
||
}(r, e)
|
||
}(t, this) : (this.realloc(4), this.buf[this.pos++] = 127 & t | (t > 127 ? 128 : 0), t <= 127 || (this.buf[this.pos++] = 127 & (t >>>= 7) | (t > 127 ? 128 : 0), t <= 127 || (this.buf[this.pos++] = 127 & (t >>>= 7) | (t > 127 ? 128 : 0), t <= 127 || (this.buf[this.pos++] = t >>> 7 & 127))))
|
||
}, writeSVarint: function (t) {
|
||
this.writeVarint(t < 0 ? 2 * -t - 1 : 2 * t)
|
||
}, writeBoolean: function (t) {
|
||
this.writeVarint(Boolean(t))
|
||
}, writeString: function (t) {
|
||
t = String(t), this.realloc(4 * t.length), this.pos++;
|
||
var e = this.pos;
|
||
this.pos = function (t, e, i) {
|
||
for (var r, o, n = 0; n < e.length; n++) {
|
||
if ((r = e.charCodeAt(n)) > 55295 && r < 57344) {
|
||
if (!o) {
|
||
r > 56319 || n + 1 === e.length ? (t[i++] = 239, t[i++] = 191, t[i++] = 189) : o = r;
|
||
continue
|
||
}
|
||
if (r < 56320) {
|
||
t[i++] = 239, t[i++] = 191, t[i++] = 189, o = r;
|
||
continue
|
||
}
|
||
r = o - 55296 << 10 | r - 56320 | 65536, o = null
|
||
} else o && (t[i++] = 239, t[i++] = 191, t[i++] = 189, o = null);
|
||
r < 128 ? t[i++] = r : (r < 2048 ? t[i++] = r >> 6 | 192 : (r < 65536 ? t[i++] = r >> 12 | 224 : (t[i++] = r >> 18 | 240, t[i++] = r >> 12 & 63 | 128), t[i++] = r >> 6 & 63 | 128), t[i++] = 63 & r | 128)
|
||
}
|
||
return i
|
||
}(this.buf, t, this.pos);
|
||
var i = this.pos - e;
|
||
i >= 128 && a(e, i, this), this.pos = e - 1, this.writeVarint(i), this.pos += i
|
||
}, writeFloat: function (t) {
|
||
this.realloc(4), r.write(this.buf, t, this.pos, !0, 23, 4), this.pos += 4
|
||
}, writeDouble: function (t) {
|
||
this.realloc(8), r.write(this.buf, t, this.pos, !0, 52, 8), this.pos += 8
|
||
}, writeBytes: function (t) {
|
||
var e = t.length;
|
||
this.writeVarint(e), this.realloc(e);
|
||
for (var i = 0; i < e; i++) this.buf[this.pos++] = t[i]
|
||
}, writeRawMessage: function (t, e) {
|
||
this.pos++;
|
||
var i = this.pos;
|
||
t(e, this);
|
||
var r = this.pos - i;
|
||
r >= 128 && a(i, r, this), this.pos = i - 1, this.writeVarint(r), this.pos += r
|
||
}, writeMessage: function (t, e, i) {
|
||
this.writeTag(t, o.Bytes), this.writeRawMessage(e, i)
|
||
}, writePackedVarint: function (t, e) {
|
||
this.writeMessage(t, l, e)
|
||
}, writePackedSVarint: function (t, e) {
|
||
this.writeMessage(t, h, e)
|
||
}, writePackedBoolean: function (t, e) {
|
||
this.writeMessage(t, p, e)
|
||
}, writePackedFloat: function (t, e) {
|
||
this.writeMessage(t, u, e)
|
||
}, writePackedDouble: function (t, e) {
|
||
this.writeMessage(t, c, e)
|
||
}, writePackedFixed32: function (t, e) {
|
||
this.writeMessage(t, d, e)
|
||
}, writePackedSFixed32: function (t, e) {
|
||
this.writeMessage(t, f, e)
|
||
}, writePackedFixed64: function (t, e) {
|
||
this.writeMessage(t, g, e)
|
||
}, writePackedSFixed64: function (t, e) {
|
||
this.writeMessage(t, m, e)
|
||
}, writeBytesField: function (t, e) {
|
||
this.writeTag(t, o.Bytes), this.writeBytes(e)
|
||
}, writeFixed32Field: function (t, e) {
|
||
this.writeTag(t, o.Fixed32), this.writeFixed32(e)
|
||
}, writeSFixed32Field: function (t, e) {
|
||
this.writeTag(t, o.Fixed32), this.writeSFixed32(e)
|
||
}, writeFixed64Field: function (t, e) {
|
||
this.writeTag(t, o.Fixed64), this.writeFixed64(e)
|
||
}, writeSFixed64Field: function (t, e) {
|
||
this.writeTag(t, o.Fixed64), this.writeSFixed64(e)
|
||
}, writeVarintField: function (t, e) {
|
||
this.writeTag(t, o.Varint), this.writeVarint(e)
|
||
}, writeSVarintField: function (t, e) {
|
||
this.writeTag(t, o.Varint), this.writeSVarint(e)
|
||
}, writeStringField: function (t, e) {
|
||
this.writeTag(t, o.Bytes), this.writeString(e)
|
||
}, writeFloatField: function (t, e) {
|
||
this.writeTag(t, o.Fixed32), this.writeFloat(e)
|
||
}, writeDoubleField: function (t, e) {
|
||
this.writeTag(t, o.Fixed64), this.writeDouble(e)
|
||
}, writeBooleanField: function (t, e) {
|
||
this.writeVarintField(t, Boolean(e))
|
||
}
|
||
}
|
||
}, function (t, e, i) {
|
||
var r = i(16);
|
||
e.Processor = r
|
||
}, function (t) {
|
||
t.exports = {
|
||
$version: 8,
|
||
$root: {
|
||
version: {
|
||
required: !0,
|
||
type: "enum",
|
||
values: [8],
|
||
doc: "Style specification version number. Must be 8.",
|
||
example: 8
|
||
},
|
||
name: {type: "string", doc: "A human-readable name for the style.", example: "Bright"},
|
||
metadata: {
|
||
type: "*",
|
||
doc: "Arbitrary properties useful to track with the stylesheet, but do not influence rendering. Properties should be prefixed to avoid collisions, like 'mapbox:'."
|
||
},
|
||
center: {
|
||
type: "array",
|
||
value: "number",
|
||
doc: "Default map center in longitude and latitude. The style center will be used only if the map has not been positioned by other means (e.g. map options or user interaction).",
|
||
example: [-73.9749, 40.7736]
|
||
},
|
||
zoom: {
|
||
type: "number",
|
||
doc: "Default zoom level. The style zoom will be used only if the map has not been positioned by other means (e.g. map options or user interaction).",
|
||
example: 12.5
|
||
},
|
||
bearing: {
|
||
type: "number",
|
||
default: 0,
|
||
period: 360,
|
||
units: "degrees",
|
||
doc: 'Default bearing, in degrees. The bearing is the compass direction that is "up"; for example, a bearing of 90° orients the map so that east is up. This value will be used only if the map has not been positioned by other means (e.g. map options or user interaction).',
|
||
example: 29
|
||
},
|
||
pitch: {
|
||
type: "number",
|
||
default: 0,
|
||
units: "degrees",
|
||
doc: "Default pitch, in degrees. Zero is perpendicular to the surface, for a look straight down at the map, while a greater value like 60 looks ahead towards the horizon. The style pitch will be used only if the map has not been positioned by other means (e.g. map options or user interaction).",
|
||
example: 50
|
||
},
|
||
light: {
|
||
type: "light",
|
||
doc: "The global light source.",
|
||
example: {anchor: "viewport", color: "white", intensity: .4}
|
||
},
|
||
sources: {
|
||
required: !0,
|
||
type: "sources",
|
||
doc: "Data source specifications.",
|
||
example: {"mapbox-streets": {type: "vector", url: "mapbox://mapbox.mapbox-streets-v6"}}
|
||
},
|
||
sprite: {
|
||
type: "string",
|
||
doc: "A base URL for retrieving the sprite image and metadata. The extensions `.png`, `.json` and scale factor `@2x.png` will be automatically appended. This property is required if any layer uses the `background-pattern`, `fill-pattern`, `line-pattern`, `fill-extrusion-pattern`, or `icon-image` properties. The URL must be absolute, containing the [scheme, authority and path components](https://en.wikipedia.org/wiki/URL#Syntax).",
|
||
example: "mapbox://sprites/mapbox/bright-v8"
|
||
},
|
||
glyphs: {
|
||
type: "string",
|
||
doc: "A URL template for loading signed-distance-field glyph sets in PBF format. The URL must include `{fontstack}` and `{range}` tokens. This property is required if any layer uses the `text-field` layout property. The URL must be absolute, containing the [scheme, authority and path components](https://en.wikipedia.org/wiki/URL#Syntax).",
|
||
example: "mapbox://fonts/mapbox/{fontstack}/{range}.pbf"
|
||
},
|
||
transition: {
|
||
type: "transition",
|
||
doc: "A global transition definition to use as a default across properties, to be used for timing transitions between one value and the next when no property-specific transition is set. Collision-based symbol fading is controlled independently of the style's `transition` property.",
|
||
example: {duration: 300, delay: 0}
|
||
},
|
||
layers: {
|
||
required: !0,
|
||
type: "array",
|
||
value: "layer",
|
||
doc: "Layers will be drawn in the order of this array.",
|
||
example: [{
|
||
id: "water",
|
||
source: "mapbox-streets",
|
||
"source-layer": "water",
|
||
type: "fill",
|
||
paint: {"fill-color": "#00ffff"}
|
||
}]
|
||
}
|
||
},
|
||
sources: {
|
||
"*": {
|
||
type: "source",
|
||
doc: "Specification of a data source. For vector and raster sources, either TileJSON or a URL to a TileJSON must be provided. For image and video sources, a URL must be provided. For GeoJSON sources, a URL or inline GeoJSON must be provided."
|
||
}
|
||
},
|
||
source: ["source_vector", "source_raster", "source_raster_dem", "source_geojson", "source_video", "source_image"],
|
||
source_vector: {
|
||
type: {
|
||
required: !0,
|
||
type: "enum",
|
||
values: {vector: {doc: "A vector tile source."}},
|
||
doc: "The type of the source."
|
||
},
|
||
url: {
|
||
type: "string",
|
||
doc: "A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://<mapid>`."
|
||
},
|
||
tiles: {
|
||
type: "array",
|
||
value: "string",
|
||
doc: "An array of one or more tile source URLs, as in the TileJSON spec."
|
||
},
|
||
bounds: {
|
||
type: "array",
|
||
value: "number",
|
||
length: 4,
|
||
default: [-180, -85.051129, 180, 85.051129],
|
||
doc: "An array containing the longitude and latitude of the southwest and northeast corners of the source's bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."
|
||
},
|
||
scheme: {
|
||
type: "enum",
|
||
values: {xyz: {doc: "Slippy map tilenames scheme."}, tms: {doc: "OSGeo spec scheme."}},
|
||
default: "xyz",
|
||
doc: "Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed."
|
||
},
|
||
minzoom: {
|
||
type: "number",
|
||
default: 0,
|
||
doc: "Minimum zoom level for which tiles are available, as in the TileJSON spec."
|
||
},
|
||
maxzoom: {
|
||
type: "number",
|
||
default: 22,
|
||
doc: "Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."
|
||
},
|
||
attribution: {
|
||
type: "string",
|
||
doc: "Contains an attribution to be displayed when the map is shown to a user."
|
||
},
|
||
"*": {type: "*", doc: "Other keys to configure the data source."}
|
||
},
|
||
source_raster: {
|
||
type: {
|
||
required: !0,
|
||
type: "enum",
|
||
values: {raster: {doc: "A raster tile source."}},
|
||
doc: "The type of the source."
|
||
},
|
||
url: {
|
||
type: "string",
|
||
doc: "A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://<mapid>`."
|
||
},
|
||
tiles: {
|
||
type: "array",
|
||
value: "string",
|
||
doc: "An array of one or more tile source URLs, as in the TileJSON spec."
|
||
},
|
||
bounds: {
|
||
type: "array",
|
||
value: "number",
|
||
length: 4,
|
||
default: [-180, -85.051129, 180, 85.051129],
|
||
doc: "An array containing the longitude and latitude of the southwest and northeast corners of the source's bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."
|
||
},
|
||
minzoom: {
|
||
type: "number",
|
||
default: 0,
|
||
doc: "Minimum zoom level for which tiles are available, as in the TileJSON spec."
|
||
},
|
||
maxzoom: {
|
||
type: "number",
|
||
default: 22,
|
||
doc: "Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."
|
||
},
|
||
tileSize: {
|
||
type: "number",
|
||
default: 512,
|
||
units: "pixels",
|
||
doc: "The minimum visual size to display tiles for this layer. Only configurable for raster layers."
|
||
},
|
||
scheme: {
|
||
type: "enum",
|
||
values: {xyz: {doc: "Slippy map tilenames scheme."}, tms: {doc: "OSGeo spec scheme."}},
|
||
default: "xyz",
|
||
doc: "Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed."
|
||
},
|
||
attribution: {
|
||
type: "string",
|
||
doc: "Contains an attribution to be displayed when the map is shown to a user."
|
||
},
|
||
"*": {type: "*", doc: "Other keys to configure the data source."}
|
||
},
|
||
source_raster_dem: {
|
||
type: {
|
||
required: !0,
|
||
type: "enum",
|
||
values: {"raster-dem": {doc: "A RGB-encoded raster DEM source"}},
|
||
doc: "The type of the source."
|
||
},
|
||
url: {
|
||
type: "string",
|
||
doc: "A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://<mapid>`."
|
||
},
|
||
tiles: {
|
||
type: "array",
|
||
value: "string",
|
||
doc: "An array of one or more tile source URLs, as in the TileJSON spec."
|
||
},
|
||
bounds: {
|
||
type: "array",
|
||
value: "number",
|
||
length: 4,
|
||
default: [-180, -85.051129, 180, 85.051129],
|
||
doc: "An array containing the longitude and latitude of the southwest and northeast corners of the source's bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."
|
||
},
|
||
minzoom: {
|
||
type: "number",
|
||
default: 0,
|
||
doc: "Minimum zoom level for which tiles are available, as in the TileJSON spec."
|
||
},
|
||
maxzoom: {
|
||
type: "number",
|
||
default: 22,
|
||
doc: "Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."
|
||
},
|
||
tileSize: {
|
||
type: "number",
|
||
default: 512,
|
||
units: "pixels",
|
||
doc: "The minimum visual size to display tiles for this layer. Only configurable for raster layers."
|
||
},
|
||
attribution: {
|
||
type: "string",
|
||
doc: "Contains an attribution to be displayed when the map is shown to a user."
|
||
},
|
||
encoding: {
|
||
type: "enum",
|
||
values: {
|
||
terrarium: {doc: "Terrarium format PNG tiles. See https://aws.amazon.com/es/public-datasets/terrain/ for more info."},
|
||
mapbox: {doc: "Mapbox Terrain RGB tiles. See https://www.mapbox.com/help/access-elevation-data/#mapbox-terrain-rgb for more info."}
|
||
},
|
||
default: "mapbox",
|
||
doc: "The encoding used by this source. Mapbox Terrain RGB is used by default"
|
||
},
|
||
"*": {type: "*", doc: "Other keys to configure the data source."}
|
||
},
|
||
source_geojson: {
|
||
type: {
|
||
required: !0,
|
||
type: "enum",
|
||
values: {geojson: {doc: "A GeoJSON data source."}},
|
||
doc: "The data type of the GeoJSON source."
|
||
},
|
||
data: {type: "*", doc: "A URL to a GeoJSON file, or inline GeoJSON."},
|
||
maxzoom: {
|
||
type: "number",
|
||
default: 18,
|
||
doc: "Maximum zoom level at which to create vector tiles (higher means greater detail at high zoom levels)."
|
||
},
|
||
attribution: {
|
||
type: "string",
|
||
doc: "Contains an attribution to be displayed when the map is shown to a user."
|
||
},
|
||
buffer: {
|
||
type: "number",
|
||
default: 128,
|
||
maximum: 512,
|
||
minimum: 0,
|
||
doc: "Size of the tile buffer on each side. A value of 0 produces no buffer. A value of 512 produces a buffer as wide as the tile itself. Larger values produce fewer rendering artifacts near tile edges and slower performance."
|
||
},
|
||
tolerance: {
|
||
type: "number",
|
||
default: .375,
|
||
doc: "Douglas-Peucker simplification tolerance (higher means simpler geometries and faster performance)."
|
||
},
|
||
cluster: {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If the data is a collection of point features, setting this to true clusters the points by radius into groups. Cluster groups become new `Point` features in the source with additional properties:\n * `cluster` Is `true` if the point is a cluster \n * `cluster_id` A unqiue id for the cluster to be used in conjunction with the [cluster inspection methods](https://www.mapbox.com/mapbox-gl-js/api/#geojsonsource#getclusterexpansionzoom)\n * `point_count` Number of original points grouped into this cluster\n * `point_count_abbreviated` An abbreviated point count"
|
||
},
|
||
clusterRadius: {
|
||
type: "number",
|
||
default: 50,
|
||
minimum: 0,
|
||
doc: "Radius of each cluster if clustering is enabled. A value of 512 indicates a radius equal to the width of a tile."
|
||
},
|
||
clusterMaxZoom: {
|
||
type: "number",
|
||
doc: "Max zoom on which to cluster points if clustering is enabled. Defaults to one zoom less than maxzoom (so that last zoom features are not clustered)."
|
||
},
|
||
clusterProperties: {
|
||
type: "*",
|
||
doc: 'An object defining custom properties on the generated clusters if clustering is enabled, aggregating values from clustered points. Has the form `{"property_name": [operator, map_expression]}`. `operator` is any expression function that accepts at least 2 operands (e.g. `"+"` or `"max"`) — it accumulates the property value from clusters/points the cluster contains; `map_expression` produces the value of a single point.\n\nExample: `{"sum": ["+", ["get", "scalerank"]]}`.\n\nFor more advanced use cases, in place of `operator`, you can use a custom reduce expression that references a special `["accumulated"]` value, e.g.:\n`{"sum": [["+", ["accumulated"], ["get", "sum"]], ["get", "scalerank"]]}`'
|
||
},
|
||
lineMetrics: {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "Whether to calculate line distance metrics. This is required for line layers that specify `line-gradient` values."
|
||
},
|
||
generateId: {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "Whether to generate ids for the geojson features. When enabled, the `feature.id` property will be auto assigned based on its index in the `features` array, over-writing any previous values."
|
||
}
|
||
},
|
||
source_video: {
|
||
type: {
|
||
required: !0,
|
||
type: "enum",
|
||
values: {video: {doc: "A video data source."}},
|
||
doc: "The data type of the video source."
|
||
},
|
||
urls: {
|
||
required: !0,
|
||
type: "array",
|
||
value: "string",
|
||
doc: "URLs to video content in order of preferred format."
|
||
},
|
||
coordinates: {
|
||
required: !0,
|
||
doc: "Corners of video specified in longitude, latitude pairs.",
|
||
type: "array",
|
||
length: 4,
|
||
value: {type: "array", length: 2, value: "number", doc: "A single longitude, latitude pair."}
|
||
}
|
||
},
|
||
source_image: {
|
||
type: {
|
||
required: !0,
|
||
type: "enum",
|
||
values: {image: {doc: "An image data source."}},
|
||
doc: "The data type of the image source."
|
||
},
|
||
url: {required: !0, type: "string", doc: "URL that points to an image."},
|
||
coordinates: {
|
||
required: !0,
|
||
doc: "Corners of image specified in longitude, latitude pairs.",
|
||
type: "array",
|
||
length: 4,
|
||
value: {type: "array", length: 2, value: "number", doc: "A single longitude, latitude pair."}
|
||
}
|
||
},
|
||
layer: {
|
||
id: {type: "string", doc: "Unique layer name.", required: !0},
|
||
type: {
|
||
type: "enum", values: {
|
||
fill: {
|
||
doc: "A filled polygon with an optional stroked border.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
}
|
||
},
|
||
line: {
|
||
doc: "A stroked line.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
}
|
||
},
|
||
symbol: {
|
||
doc: "An icon or a text label.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
}
|
||
},
|
||
circle: {
|
||
doc: "A filled circle.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
}
|
||
},
|
||
heatmap: {
|
||
doc: "A heatmap.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"fill-extrusion": {
|
||
doc: "An extruded (3D) polygon.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}
|
||
}
|
||
},
|
||
raster: {
|
||
doc: "Raster map textures such as satellite imagery.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
}
|
||
},
|
||
hillshade: {
|
||
doc: "Client-side hillshading visualization based on DEM data. Currently, the implementation only supports Mapbox Terrain RGB and Mapzen Terrarium tiles.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
background: {
|
||
doc: "The background color or pattern of the map.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
}
|
||
}
|
||
}, doc: "Rendering type of this layer.", required: !0
|
||
},
|
||
metadata: {
|
||
type: "*",
|
||
doc: "Arbitrary properties useful to track with the layer, but do not influence rendering. Properties should be prefixed to avoid collisions, like 'mapbox:'."
|
||
},
|
||
source: {
|
||
type: "string",
|
||
doc: "Name of a source description to be used for this layer. Required for all layer types except `background`."
|
||
},
|
||
"source-layer": {
|
||
type: "string",
|
||
doc: "Layer to use from a vector tile source. Required for vector tile sources; prohibited for all other source types, including GeoJSON sources."
|
||
},
|
||
minzoom: {
|
||
type: "number",
|
||
minimum: 0,
|
||
maximum: 24,
|
||
doc: "The minimum zoom level for the layer. At zoom levels less than the minzoom, the layer will be hidden."
|
||
},
|
||
maxzoom: {
|
||
type: "number",
|
||
minimum: 0,
|
||
maximum: 24,
|
||
doc: "The maximum zoom level for the layer. At zoom levels equal to or greater than the maxzoom, the layer will be hidden."
|
||
},
|
||
filter: {
|
||
type: "filter",
|
||
doc: "A expression specifying conditions on source features. Only features that match the filter are displayed. Zoom expressions in filters are only evaluated at integer zoom levels. The `feature-state` expression is not supported in filter expressions."
|
||
},
|
||
layout: {type: "layout", doc: "Layout properties for the layer."},
|
||
paint: {type: "paint", doc: "Default paint properties for this layer."}
|
||
},
|
||
layout: ["layout_fill", "layout_line", "layout_circle", "layout_heatmap", "layout_fill-extrusion", "layout_symbol", "layout_raster", "layout_hillshade", "layout_background"],
|
||
layout_background: {
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
layout_fill: {
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
layout_circle: {
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
layout_heatmap: {
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
"layout_fill-extrusion": {
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
layout_line: {
|
||
"line-cap": {
|
||
type: "enum",
|
||
values: {
|
||
butt: {doc: "A cap with a squared-off end which is drawn to the exact endpoint of the line."},
|
||
round: {doc: "A cap with a rounded end which is drawn beyond the endpoint of the line at a radius of one-half of the line's width and centered on the endpoint of the line."},
|
||
square: {doc: "A cap with a squared-off end which is drawn beyond the endpoint of the line at a distance of one-half of the line's width."}
|
||
},
|
||
default: "butt",
|
||
doc: "The display of line endings.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"line-join": {
|
||
type: "enum",
|
||
values: {
|
||
bevel: {doc: "A join with a squared-off end which is drawn beyond the endpoint of the line at a distance of one-half of the line's width."},
|
||
round: {doc: "A join with a rounded end which is drawn beyond the endpoint of the line at a radius of one-half of the line's width and centered on the endpoint of the line."},
|
||
miter: {doc: "A join with a sharp, angled corner which is drawn with the outer sides beyond the endpoint of the path until they meet."}
|
||
},
|
||
default: "miter",
|
||
doc: "The display of lines when joining.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.40.0", android: "5.2.0", ios: "3.7.0", macos: "0.6.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"line-miter-limit": {
|
||
type: "number",
|
||
default: 2,
|
||
doc: "Used to automatically convert miter joins to bevel joins for sharp angles.",
|
||
requires: [{"line-join": "miter"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"line-round-limit": {
|
||
type: "number",
|
||
default: 1.05,
|
||
doc: "Used to automatically convert round joins to miter joins for shallow angles.",
|
||
requires: [{"line-join": "round"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
layout_symbol: {
|
||
"symbol-placement": {
|
||
type: "enum",
|
||
values: {
|
||
point: {doc: "The label is placed at the point where the geometry is located."},
|
||
line: {doc: "The label is placed along the line of the geometry. Can only be used on `LineString` and `Polygon` geometries."},
|
||
"line-center": {doc: "The label is placed at the center of the line of the geometry. Can only be used on `LineString` and `Polygon` geometries. Note that a single feature in a vector tile may contain multiple line geometries."}
|
||
},
|
||
default: "point",
|
||
doc: "Label placement relative to its geometry.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
},
|
||
"`line-center` value": {js: "0.47.0", android: "6.4.0", ios: "4.3.0", macos: "0.10.0"},
|
||
"data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"symbol-spacing": {
|
||
type: "number",
|
||
default: 250,
|
||
minimum: 1,
|
||
units: "pixels",
|
||
doc: "Distance between two symbol anchors.",
|
||
requires: [{"symbol-placement": "line"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"symbol-avoid-edges": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, the symbols will not cross tile edges to avoid mutual collisions. Recommended in layers that don't have enough padding in the vector tile to prevent collisions, or if it is a point symbol layer placed after a line symbol layer.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"symbol-sort-key": {
|
||
type: "number",
|
||
doc: "Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key when they overlap. Features with a lower sort key will have priority over other features when doing placement.",
|
||
"sdk-support": {js: "0.53.0"},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"symbol-z-order": {
|
||
type: "enum",
|
||
values: {
|
||
auto: {doc: "If `symbol-sort-key` is set, sort based on that. Otherwise sort symbols by their position relative to the viewport."},
|
||
"viewport-y": {doc: "Symbols will be sorted by their y-position relative to the viewport."},
|
||
source: {doc: "Symbols will be rendered in the same order as the source data with no sorting applied."}
|
||
},
|
||
default: "auto",
|
||
doc: "Controls the order in which overlapping symbols in the same layer are rendered",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.49.0",
|
||
android: "6.6.0",
|
||
ios: "4.5.0",
|
||
macos: "0.12.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-allow-overlap": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, the icon will be visible even if it collides with other previously drawn symbols.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-ignore-placement": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, other symbols can be visible even if they collide with the icon.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-optional": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, text will display without their corresponding icons when the icon collides with other symbols and the text does not.",
|
||
requires: ["icon-image", "text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-rotation-alignment": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "When `symbol-placement` is set to `point`, aligns icons east-west. When `symbol-placement` is set to `line` or `line-center`, aligns icon x-axes with the line."},
|
||
viewport: {doc: "Produces icons whose x-axes are aligned with the x-axis of the viewport, regardless of the value of `symbol-placement`."},
|
||
auto: {doc: "When `symbol-placement` is set to `point`, this is equivalent to `viewport`. When `symbol-placement` is set to `line` or `line-center`, this is equivalent to `map`."}
|
||
},
|
||
default: "auto",
|
||
doc: "In combination with `symbol-placement`, determines the rotation behavior of icons.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
},
|
||
"`auto` value": {js: "0.25.0", android: "4.2.0", ios: "3.4.0", macos: "0.3.0"},
|
||
"data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-size": {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
units: "factor of the original icon size",
|
||
doc: "Scales the original size of the icon by the provided factor. The new pixel size of the image will be the original pixel size multiplied by `icon-size`. 1 is the original size; 3 triples the size of the image.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.35.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-text-fit": {
|
||
type: "enum",
|
||
values: {
|
||
none: {doc: "The icon is displayed at its intrinsic aspect ratio."},
|
||
width: {doc: "The icon is scaled in the x-dimension to fit the width of the text."},
|
||
height: {doc: "The icon is scaled in the y-dimension to fit the height of the text."},
|
||
both: {doc: "The icon is scaled in both x- and y-dimensions."}
|
||
},
|
||
default: "none",
|
||
doc: "Scales the icon to fit around the associated text.",
|
||
requires: ["icon-image", "text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.21.0",
|
||
android: "4.2.0",
|
||
ios: "3.4.0",
|
||
macos: "0.2.1"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-text-fit-padding": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 4,
|
||
default: [0, 0, 0, 0],
|
||
units: "pixels",
|
||
doc: "Size of the additional area added to dimensions determined by `icon-text-fit`, in clockwise order: top, right, bottom, left.",
|
||
requires: ["icon-image", "text-field", {"icon-text-fit": ["both", "width", "height"]}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.21.0",
|
||
android: "4.2.0",
|
||
ios: "3.4.0",
|
||
macos: "0.2.1"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-image": {
|
||
type: "string",
|
||
doc: "Name of image in sprite to use for drawing an image background.",
|
||
tokens: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.35.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-rotate": {
|
||
type: "number",
|
||
default: 0,
|
||
period: 360,
|
||
units: "degrees",
|
||
doc: "Rotates the icon clockwise.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.21.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-padding": {
|
||
type: "number",
|
||
default: 2,
|
||
minimum: 0,
|
||
units: "pixels",
|
||
doc: "Size of the additional area around the icon bounding box used for detecting symbol collisions.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-keep-upright": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, the icon may be flipped to prevent it from being rendered upside-down.",
|
||
requires: ["icon-image", {"icon-rotation-alignment": "map"}, {"symbol-placement": ["line", "line-center"]}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-offset": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 2,
|
||
default: [0, 0],
|
||
doc: "Offset distance of icon from its anchor. Positive values indicate right and down, while negative values indicate left and up. Each component is multiplied by the value of `icon-size` to obtain the final offset in pixels. When combined with `icon-rotate` the offset will be as if the rotated direction was up.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
center: {doc: "The center of the icon is placed closest to the anchor."},
|
||
left: {doc: "The left side of the icon is placed closest to the anchor."},
|
||
right: {doc: "The right side of the icon is placed closest to the anchor."},
|
||
top: {doc: "The top of the icon is placed closest to the anchor."},
|
||
bottom: {doc: "The bottom of the icon is placed closest to the anchor."},
|
||
"top-left": {doc: "The top left corner of the icon is placed closest to the anchor."},
|
||
"top-right": {doc: "The top right corner of the icon is placed closest to the anchor."},
|
||
"bottom-left": {doc: "The bottom left corner of the icon is placed closest to the anchor."},
|
||
"bottom-right": {doc: "The bottom right corner of the icon is placed closest to the anchor."}
|
||
},
|
||
default: "center",
|
||
doc: "Part of the icon placed closest to the anchor.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.40.0",
|
||
android: "5.2.0",
|
||
ios: "3.7.0",
|
||
macos: "0.6.0"
|
||
}, "data-driven styling": {js: "0.40.0", android: "5.2.0", ios: "3.7.0", macos: "0.6.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-pitch-alignment": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The icon is aligned to the plane of the map."},
|
||
viewport: {doc: "The icon is aligned to the plane of the viewport."},
|
||
auto: {doc: "Automatically matches the value of `icon-rotation-alignment`."}
|
||
},
|
||
default: "auto",
|
||
doc: "Orientation of icon when map is pitched.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.39.0",
|
||
android: "5.2.0",
|
||
ios: "3.7.0",
|
||
macos: "0.6.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-pitch-alignment": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The text is aligned to the plane of the map."},
|
||
viewport: {doc: "The text is aligned to the plane of the viewport."},
|
||
auto: {doc: "Automatically matches the value of `text-rotation-alignment`."}
|
||
},
|
||
default: "auto",
|
||
doc: "Orientation of text when map is pitched.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.21.0",
|
||
android: "4.2.0",
|
||
ios: "3.4.0",
|
||
macos: "0.2.1"
|
||
},
|
||
"`auto` value": {js: "0.25.0", android: "4.2.0", ios: "3.4.0", macos: "0.3.0"},
|
||
"data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-rotation-alignment": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "When `symbol-placement` is set to `point`, aligns text east-west. When `symbol-placement` is set to `line` or `line-center`, aligns text x-axes with the line."},
|
||
viewport: {doc: "Produces glyphs whose x-axes are aligned with the x-axis of the viewport, regardless of the value of `symbol-placement`."},
|
||
auto: {doc: "When `symbol-placement` is set to `point`, this is equivalent to `viewport`. When `symbol-placement` is set to `line` or `line-center`, this is equivalent to `map`."}
|
||
},
|
||
default: "auto",
|
||
doc: "In combination with `symbol-placement`, determines the rotation behavior of the individual glyphs forming the text.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
},
|
||
"`auto` value": {js: "0.25.0", android: "4.2.0", ios: "3.4.0", macos: "0.3.0"},
|
||
"data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-field": {
|
||
type: "formatted",
|
||
default: "",
|
||
tokens: !0,
|
||
doc: "Value to use for a text label. If a plain `string` is provided, it will be treated as a `formatted` with default/inherited formatting options.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-font": {
|
||
type: "array",
|
||
value: "string",
|
||
default: ["Open Sans Regular", "Arial Unicode MS Regular"],
|
||
doc: "Font stack to use for displaying text.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.43.0", android: "6.0.0", ios: "4.0.0", macos: "0.7.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-size": {
|
||
type: "number",
|
||
default: 16,
|
||
minimum: 0,
|
||
units: "pixels",
|
||
doc: "Font size.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.35.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-max-width": {
|
||
type: "number",
|
||
default: 10,
|
||
minimum: 0,
|
||
units: "ems",
|
||
doc: "The maximum line width for text wrapping.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.40.0", android: "5.2.0", ios: "3.7.0", macos: "0.6.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-line-height": {
|
||
type: "number",
|
||
default: 1.2,
|
||
units: "ems",
|
||
doc: "Text leading value for multi-line text.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-letter-spacing": {
|
||
type: "number",
|
||
default: 0,
|
||
units: "ems",
|
||
doc: "Text tracking amount.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.40.0", android: "5.2.0", ios: "3.7.0", macos: "0.6.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-justify": {
|
||
type: "enum",
|
||
values: {
|
||
auto: {doc: "The text is aligned towards the anchor position."},
|
||
left: {doc: "The text is aligned to the left."},
|
||
center: {doc: "The text is centered."},
|
||
right: {doc: "The text is aligned to the right."}
|
||
},
|
||
default: "center",
|
||
doc: "Text justification options.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
},
|
||
"data-driven styling": {js: "0.39.0", android: "5.2.0", ios: "3.7.0", macos: "0.6.0"},
|
||
auto: {
|
||
js: "next",
|
||
android: "Not yet supported",
|
||
ios: "Not yet supported",
|
||
macos: "Not yet supported"
|
||
}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-radial-offset": {
|
||
type: "number",
|
||
units: "ems",
|
||
default: 0,
|
||
doc: "Radial offset of text, in the direction of the symbol's anchor. Useful in combination with `text-variable-anchor`, which doesn't support the two-dimensional `text-offset`.",
|
||
requires: [{"!": "text-offset"}],
|
||
"property-type": "data-driven",
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]}
|
||
},
|
||
"text-variable-anchor": {
|
||
type: "array",
|
||
value: "enum",
|
||
values: {
|
||
center: {doc: "The center of the text is placed closest to the anchor."},
|
||
left: {doc: "The left side of the text is placed closest to the anchor."},
|
||
right: {doc: "The right side of the text is placed closest to the anchor."},
|
||
top: {doc: "The top of the text is placed closest to the anchor."},
|
||
bottom: {doc: "The bottom of the text is placed closest to the anchor."},
|
||
"top-left": {doc: "The top left corner of the text is placed closest to the anchor."},
|
||
"top-right": {doc: "The top right corner of the text is placed closest to the anchor."},
|
||
"bottom-left": {doc: "The bottom left corner of the text is placed closest to the anchor."},
|
||
"bottom-right": {doc: "The bottom right corner of the text is placed closest to the anchor."}
|
||
},
|
||
requires: [{"!": "text-anchor"}, {"!": "text-offset"}, {"symbol-placement": ["point"]}],
|
||
doc: "To increase the chance of placing high-priority labels on the map, you can provide an array of `text-anchor` locations: the render will attempt to place the label at each location, in order, before moving onto the next label. Use `text-justify: auto` to choose justification based on anchor position. To apply an offset, use the `text-radial-offset` instead of the two-dimensional `text-offset`.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "next",
|
||
android: "Not yet supported",
|
||
ios: "Not yet supported",
|
||
macos: "Not yet supported"
|
||
},
|
||
"data-driven styling": {
|
||
js: "Not yet supported",
|
||
android: "Not yet supported",
|
||
ios: "Not yet supported",
|
||
macos: "Not yet supported"
|
||
}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-anchor": {
|
||
type: "enum",
|
||
requires: ["text-field"],
|
||
values: {
|
||
center: {doc: "The center of the text is placed closest to the anchor."},
|
||
left: {doc: "The left side of the text is placed closest to the anchor."},
|
||
right: {doc: "The right side of the text is placed closest to the anchor."},
|
||
top: {doc: "The top of the text is placed closest to the anchor."},
|
||
bottom: {doc: "The bottom of the text is placed closest to the anchor."},
|
||
"top-left": {doc: "The top left corner of the text is placed closest to the anchor."},
|
||
"top-right": {doc: "The top right corner of the text is placed closest to the anchor."},
|
||
"bottom-left": {doc: "The bottom left corner of the text is placed closest to the anchor."},
|
||
"bottom-right": {doc: "The bottom right corner of the text is placed closest to the anchor."}
|
||
},
|
||
default: "center",
|
||
doc: "Part of the text placed closest to the anchor.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.39.0", android: "5.2.0", ios: "3.7.0", macos: "0.6.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-max-angle": {
|
||
type: "number",
|
||
default: 45,
|
||
units: "degrees",
|
||
doc: "Maximum angle change between adjacent characters.",
|
||
requires: ["text-field", {"symbol-placement": ["line", "line-center"]}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-rotate": {
|
||
type: "number",
|
||
default: 0,
|
||
period: 360,
|
||
units: "degrees",
|
||
doc: "Rotates the text clockwise.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.35.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-padding": {
|
||
type: "number",
|
||
default: 2,
|
||
minimum: 0,
|
||
units: "pixels",
|
||
doc: "Size of the additional area around the text bounding box used for detecting symbol collisions.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-keep-upright": {
|
||
type: "boolean",
|
||
default: !0,
|
||
doc: "If true, the text may be flipped vertically to prevent it from being rendered upside-down.",
|
||
requires: ["text-field", {"text-rotation-alignment": "map"}, {"symbol-placement": ["line", "line-center"]}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-transform": {
|
||
type: "enum",
|
||
values: {
|
||
none: {doc: "The text is not altered."},
|
||
uppercase: {doc: "Forces all letters to be displayed in uppercase."},
|
||
lowercase: {doc: "Forces all letters to be displayed in lowercase."}
|
||
},
|
||
default: "none",
|
||
doc: "Specifies how to capitalize text, similar to the CSS `text-transform` property.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-offset": {
|
||
type: "array",
|
||
doc: "Offset distance of text from its anchor. Positive values indicate right and down, while negative values indicate left and up.",
|
||
value: "number",
|
||
units: "ems",
|
||
length: 2,
|
||
default: [0, 0],
|
||
requires: ["text-field", {"!": "text-radial-offset"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.35.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-allow-overlap": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, the text will be visible even if it collides with other previously drawn symbols.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-ignore-placement": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, other symbols can be visible even if they collide with the text.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-optional": {
|
||
type: "boolean",
|
||
default: !1,
|
||
doc: "If true, icons will display without their corresponding text when the text collides with other symbols and the icon does not.",
|
||
requires: ["text-field", "icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
layout_raster: {
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
layout_hillshade: {
|
||
visibility: {
|
||
type: "enum",
|
||
values: {visible: {doc: "The layer is shown."}, none: {doc: "The layer is not shown."}},
|
||
default: "visible",
|
||
doc: "Whether this layer is displayed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
"property-type": "constant"
|
||
}
|
||
},
|
||
filter: {type: "array", value: "*", doc: "A filter selects specific features from a layer."},
|
||
filter_operator: {
|
||
type: "enum",
|
||
values: {
|
||
"==": {doc: '`["==", key, value]` equality: `feature[key] = value`'},
|
||
"!=": {doc: '`["!=", key, value]` inequality: `feature[key] ≠ value`'},
|
||
">": {doc: '`[">", key, value]` greater than: `feature[key] > value`'},
|
||
">=": {doc: '`[">=", key, value]` greater than or equal: `feature[key] ≥ value`'},
|
||
"<": {doc: '`["<", key, value]` less than: `feature[key] < value`'},
|
||
"<=": {doc: '`["<=", key, value]` less than or equal: `feature[key] ≤ value`'},
|
||
in: {doc: '`["in", key, v0, ..., vn]` set inclusion: `feature[key] ∈ {v0, ..., vn}`'},
|
||
"!in": {doc: '`["!in", key, v0, ..., vn]` set exclusion: `feature[key] ∉ {v0, ..., vn}`'},
|
||
all: {doc: '`["all", f0, ..., fn]` logical `AND`: `f0 ∧ ... ∧ fn`'},
|
||
any: {doc: '`["any", f0, ..., fn]` logical `OR`: `f0 ∨ ... ∨ fn`'},
|
||
none: {doc: '`["none", f0, ..., fn]` logical `NOR`: `¬f0 ∧ ... ∧ ¬fn`'},
|
||
has: {doc: '`["has", key]` `feature[key]` exists'},
|
||
"!has": {doc: '`["!has", key]` `feature[key]` does not exist'}
|
||
},
|
||
doc: "The filter operator."
|
||
},
|
||
geometry_type: {
|
||
type: "enum",
|
||
values: {
|
||
Point: {doc: "Filter to point geometries."},
|
||
LineString: {doc: "Filter to line geometries."},
|
||
Polygon: {doc: "Filter to polygon geometries."}
|
||
},
|
||
doc: "The geometry type for the filter to select."
|
||
},
|
||
function: {
|
||
expression: {type: "expression", doc: "An expression."},
|
||
stops: {type: "array", doc: "An array of stops.", value: "function_stop"},
|
||
base: {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
doc: "The exponential base of the interpolation curve. It controls the rate at which the result increases. Higher values make the result increase more towards the high end of the range. With `1` the stops are interpolated linearly."
|
||
},
|
||
property: {
|
||
type: "string",
|
||
doc: "The name of a feature property to use as the function input.",
|
||
default: "$zoom"
|
||
},
|
||
type: {
|
||
type: "enum",
|
||
values: {
|
||
identity: {doc: "Return the input value as the output value."},
|
||
exponential: {doc: "Generate an output by interpolating between stops just less than and just greater than the function input."},
|
||
interval: {doc: "Return the output value of the stop just less than the function input."},
|
||
categorical: {doc: "Return the output value of the stop equal to the function input."}
|
||
},
|
||
doc: "The interpolation strategy to use in function evaluation.",
|
||
default: "exponential"
|
||
},
|
||
colorSpace: {
|
||
type: "enum",
|
||
values: {
|
||
rgb: {doc: "Use the RGB color space to interpolate color values"},
|
||
lab: {doc: "Use the LAB color space to interpolate color values."},
|
||
hcl: {doc: "Use the HCL color space to interpolate color values, interpolating the Hue, Chroma, and Luminance channels individually."}
|
||
},
|
||
doc: "The color space in which colors interpolated. Interpolating colors in perceptual color spaces like LAB and HCL tend to produce color ramps that look more consistent and produce colors that can be differentiated more easily than those interpolated in RGB space.",
|
||
default: "rgb"
|
||
},
|
||
default: {
|
||
type: "*",
|
||
required: !1,
|
||
doc: "A value to serve as a fallback function result when a value isn't otherwise available. It is used in the following circumstances:\n* In categorical functions, when the feature value does not match any of the stop domain values.\n* In property and zoom-and-property functions, when a feature does not contain a value for the specified property.\n* In identity functions, when the feature value is not valid for the style property (for example, if the function is being used for a `circle-color` property but the feature property value is not a string or not a valid color).\n* In interval or exponential property and zoom-and-property functions, when the feature value is not numeric.\nIf no default is provided, the style property's default is used in these circumstances."
|
||
}
|
||
},
|
||
function_stop: {
|
||
type: "array",
|
||
minimum: 0,
|
||
maximum: 22,
|
||
value: ["number", "color"],
|
||
length: 2,
|
||
doc: "Zoom level and value pair."
|
||
},
|
||
expression: {
|
||
type: "array",
|
||
value: "*",
|
||
minimum: 1,
|
||
doc: "An expression defines a function that can be used for data-driven style properties or feature filters."
|
||
},
|
||
expression_name: {
|
||
doc: "", type: "enum", values: {
|
||
let: {
|
||
doc: 'Binds expressions to named variables, which can then be referenced in the result expression using ["var", "variable_name"].',
|
||
group: "Variable binding",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
var: {
|
||
doc: 'References variable bound using "let".',
|
||
group: "Variable binding",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
literal: {
|
||
doc: "Provides a literal array or object value.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
array: {
|
||
doc: "Asserts that the input is an array (optionally with a specific item type and length). If, when the input expression is evaluated, it is not of the asserted type, then this assertion will cause the whole expression to be aborted.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
at: {
|
||
doc: "Retrieves an item from an array.",
|
||
group: "Lookup",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
case: {
|
||
doc: "Selects the first output whose corresponding test condition evaluates to true, or the fallback value otherwise.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
match: {
|
||
doc: 'Selects the output whose label value matches the input value, or the fallback value if no match is found. The input can be any expression (e.g. `["get", "building_type"]`). Each label must be either:\n * a single literal value; or\n * an array of literal values, whose values must be all strings or all numbers (e.g. `[100, 101]` or `["c", "b"]`). The input matches if any of the values in the array matches, similar to the deprecated `"in"` operator.\n\nEach label must be unique. If the input type does not match the type of the labels, the result will be the fallback value.',
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
coalesce: {
|
||
doc: "Evaluates each expression in turn until the first non-null value is obtained, and returns that value.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
step: {
|
||
doc: 'Produces discrete, stepped results by evaluating a piecewise-constant function defined by pairs of input and output values ("stops"). The `input` may be any numeric expression (e.g., `["get", "population"]`). Stop inputs must be numeric literals in strictly ascending order. Returns the output value of the stop just less than the input, or the first input if the input is less than the first stop.',
|
||
group: "Ramps, scales, curves",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.42.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
interpolate: {
|
||
doc: 'Produces continuous, smooth results by interpolating between pairs of input and output values ("stops"). The `input` may be any numeric expression (e.g., `["get", "population"]`). Stop inputs must be numeric literals in strictly ascending order. The output type must be `number`, `array<number>`, or `color`.\n\nInterpolation types:\n- `["linear"]`: interpolates linearly between the pair of stops just less than and just greater than the input.\n- `["exponential", base]`: interpolates exponentially between the stops just less than and just greater than the input. `base` controls the rate at which the output increases: higher values make the output increase more towards the high end of the range. With values close to 1 the output increases linearly.\n- `["cubic-bezier", x1, y1, x2, y2]`: interpolates using the cubic bezier curve defined by the given control points.',
|
||
group: "Ramps, scales, curves",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.42.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"interpolate-hcl": {
|
||
doc: 'Produces continuous, smooth results by interpolating between pairs of input and output values ("stops"). Works like `interpolate`, but the output type must be `color`, and the interpolation is performed in the Hue-Chroma-Luminance color space.',
|
||
group: "Ramps, scales, curves",
|
||
"sdk-support": {"basic functionality": {js: "0.49.0"}}
|
||
},
|
||
"interpolate-lab": {
|
||
doc: 'Produces continuous, smooth results by interpolating between pairs of input and output values ("stops"). Works like `interpolate`, but the output type must be `color`, and the interpolation is performed in the CIELAB color space.',
|
||
group: "Ramps, scales, curves",
|
||
"sdk-support": {"basic functionality": {js: "0.49.0"}}
|
||
},
|
||
ln2: {
|
||
doc: "Returns mathematical constant ln(2).",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
pi: {
|
||
doc: "Returns the mathematical constant pi.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
e: {
|
||
doc: "Returns the mathematical constant e.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
typeof: {
|
||
doc: "Returns a string describing the type of the given value.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
string: {
|
||
doc: "Asserts that the input value is a string. If multiple values are provided, each one is evaluated in order until a string is obtained. If none of the inputs are strings, the expression is an error.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
number: {
|
||
doc: "Asserts that the input value is a number. If multiple values are provided, each one is evaluated in order until a number is obtained. If none of the inputs are numbers, the expression is an error.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
boolean: {
|
||
doc: "Asserts that the input value is a boolean. If multiple values are provided, each one is evaluated in order until a boolean is obtained. If none of the inputs are booleans, the expression is an error.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
object: {
|
||
doc: "Asserts that the input value is an object. If multiple values are provided, each one is evaluated in order until an object is obtained. If none of the inputs are objects, the expression is an error.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
collator: {
|
||
doc: "Returns a `collator` for use in locale-dependent comparison operations. The `case-sensitive` and `diacritic-sensitive` options default to `false`. The `locale` argument specifies the IETF language tag of the locale to use. If none is provided, the default locale is used. If the requested locale is not available, the `collator` will use a system-defined fallback locale. Use `resolved-locale` to test the results of locale fallback behavior.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.5.0",
|
||
ios: "4.2.0",
|
||
macos: "0.9.0"
|
||
}
|
||
}
|
||
},
|
||
format: {
|
||
doc: "Returns `formatted` text containing annotations for use in mixed-format `text-field` entries. If set, the `text-font` argument overrides the font specified by the root layout properties. If set, the `font-scale` argument specifies a scaling factor relative to the `text-size` specified in the root layout properties.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.48.0",
|
||
android: "6.7.0",
|
||
ios: "4.6.0",
|
||
macos: "0.12.0"
|
||
}
|
||
}
|
||
},
|
||
"number-format": {
|
||
doc: "Converts the input number into a string representation using the providing formatting rules. If set, the `locale` argument specifies the locale to use, as a BCP 47 language tag. If set, the `currency` argument specifies an ISO 4217 code to use for currency-style formatting. If set, the `min-fraction-digits` and `max-fraction-digits` arguments specify the minimum and maximum number of fractional digits to include.",
|
||
group: "Types",
|
||
"sdk-support": {"basic functionality": {js: "0.54.0"}}
|
||
},
|
||
"to-string": {
|
||
doc: 'Converts the input value to a string. If the input is `null`, the result is `""`. If the input is a boolean, the result is `"true"` or `"false"`. If the input is a number, it is converted to a string as specified by the ["NumberToString" algorithm](https://tc39.github.io/ecma262/#sec-tostring-applied-to-the-number-type) of the ECMAScript Language Specification. If the input is a color, it is converted to a string of the form `"rgba(r,g,b,a)"`, where `r`, `g`, and `b` are numerals ranging from 0 to 255, and `a` ranges from 0 to 1. Otherwise, the input is converted to a string in the format specified by the [`JSON.stringify`](https://tc39.github.io/ecma262/#sec-json.stringify) function of the ECMAScript Language Specification.',
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"to-number": {
|
||
doc: 'Converts the input value to a number, if possible. If the input is `null` or `false`, the result is 0. If the input is `true`, the result is 1. If the input is a string, it is converted to a number as specified by the ["ToNumber Applied to the String Type" algorithm](https://tc39.github.io/ecma262/#sec-tonumber-applied-to-the-string-type) of the ECMAScript Language Specification. If multiple values are provided, each one is evaluated in order until the first successful conversion is obtained. If none of the inputs can be converted, the expression is an error.',
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"to-boolean": {
|
||
doc: "Converts the input value to a boolean. The result is `false` when then input is an empty string, 0, `false`, `null`, or `NaN`; otherwise it is `true`.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"to-rgba": {
|
||
doc: "Returns a four-element array containing the input color's red, green, blue, and alpha components, in that order.",
|
||
group: "Color",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"to-color": {
|
||
doc: "Converts the input value to a color. If multiple values are provided, each one is evaluated in order until the first successful conversion is obtained. If none of the inputs can be converted, the expression is an error.",
|
||
group: "Types",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
rgb: {
|
||
doc: "Creates a color value from red, green, and blue components, which must range between 0 and 255, and an alpha component of 1. If any component is out of range, the expression is an error.",
|
||
group: "Color",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
rgba: {
|
||
doc: "Creates a color value from red, green, blue components, which must range between 0 and 255, and an alpha component which must range between 0 and 1. If any component is out of range, the expression is an error.",
|
||
group: "Color",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
get: {
|
||
doc: "Retrieves a property value from the current feature's properties, or from another object if a second argument is provided. Returns null if the requested property is missing.",
|
||
group: "Lookup",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
has: {
|
||
doc: "Tests for the presence of an property value in the current feature's properties, or from another object if a second argument is provided.",
|
||
group: "Lookup",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
length: {
|
||
doc: "Gets the length of an array or string.",
|
||
group: "Lookup",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
properties: {
|
||
doc: 'Gets the feature properties object. Note that in some cases, it may be more efficient to use ["get", "property_name"] directly.',
|
||
group: "Feature data",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"feature-state": {
|
||
doc: "Retrieves a property value from the current feature's state. Returns null if the requested property is not present on the feature's state. A feature's state is not part of the GeoJSON or vector tile data, and must be set programmatically on each feature. Note that [\"feature-state\"] can only be used with paint properties that support data-driven styling.",
|
||
group: "Feature data",
|
||
"sdk-support": {"basic functionality": {js: "0.46.0"}}
|
||
},
|
||
"geometry-type": {
|
||
doc: "Gets the feature's geometry type: Point, MultiPoint, LineString, MultiLineString, Polygon, MultiPolygon.",
|
||
group: "Feature data",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
id: {
|
||
doc: "Gets the feature's id, if it has one.",
|
||
group: "Feature data",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
zoom: {
|
||
doc: 'Gets the current zoom level. Note that in style layout and paint properties, ["zoom"] may only appear as the input to a top-level "step" or "interpolate" expression.',
|
||
group: "Zoom",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"heatmap-density": {
|
||
doc: "Gets the kernel density estimation of a pixel in a heatmap layer, which is a relative measure of how many data points are crowded around a particular pixel. Can only be used in the `heatmap-color` property.",
|
||
group: "Heatmap",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"line-progress": {
|
||
doc: "Gets the progress along a gradient line. Can only be used in the `line-gradient` property.",
|
||
group: "Feature data",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.5.0",
|
||
ios: "4.6.0",
|
||
macos: "0.12.0"
|
||
}
|
||
}
|
||
},
|
||
accumulated: {
|
||
doc: "Gets the value of a cluster property accumulated so far. Can only be used in the `clusterProperties` option of a clustered GeoJSON source.",
|
||
group: "Feature data",
|
||
"sdk-support": {"basic functionality": {js: "0.53.0"}}
|
||
},
|
||
"+": {
|
||
doc: "Returns the sum of the inputs.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"*": {
|
||
doc: "Returns the product of the inputs.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"-": {
|
||
doc: "For two inputs, returns the result of subtracting the second input from the first. For a single input, returns the result of subtracting it from 0.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"/": {
|
||
doc: "Returns the result of floating point division of the first input by the second.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"%": {
|
||
doc: "Returns the remainder after integer division of the first input by the second.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"^": {
|
||
doc: "Returns the result of raising the first input to the power specified by the second.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
sqrt: {
|
||
doc: "Returns the square root of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.42.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
log10: {
|
||
doc: "Returns the base-ten logarithm of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
ln: {
|
||
doc: "Returns the natural logarithm of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
log2: {
|
||
doc: "Returns the base-two logarithm of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
sin: {
|
||
doc: "Returns the sine of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
cos: {
|
||
doc: "Returns the cosine of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
tan: {
|
||
doc: "Returns the tangent of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
asin: {
|
||
doc: "Returns the arcsine of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
acos: {
|
||
doc: "Returns the arccosine of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
atan: {
|
||
doc: "Returns the arctangent of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
min: {
|
||
doc: "Returns the minimum value of the inputs.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
max: {
|
||
doc: "Returns the maximum value of the inputs.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
round: {
|
||
doc: 'Rounds the input to the nearest integer. Halfway values are rounded away from zero. For example, `["round", -1.5]` evaluates to -2.',
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
abs: {
|
||
doc: "Returns the absolute value of the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
ceil: {
|
||
doc: "Returns the smallest integer that is greater than or equal to the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
floor: {
|
||
doc: "Returns the largest integer that is less than or equal to the input.",
|
||
group: "Math",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"==": {
|
||
doc: "Returns `true` if the input values are equal, `false` otherwise. The comparison is strictly typed: values of different runtime types are always considered unequal. Cases where the types are known to be different at parse time are considered invalid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, collator: {js: "0.45.0", android: "6.5.0", ios: "4.2.0", macos: "0.9.0"}
|
||
}
|
||
},
|
||
"!=": {
|
||
doc: "Returns `true` if the input values are not equal, `false` otherwise. The comparison is strictly typed: values of different runtime types are always considered unequal. Cases where the types are known to be different at parse time are considered invalid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, collator: {js: "0.45.0", android: "6.5.0", ios: "4.2.0", macos: "0.9.0"}
|
||
}
|
||
},
|
||
">": {
|
||
doc: "Returns `true` if the first input is strictly greater than the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, collator: {js: "0.45.0", android: "6.5.0", ios: "4.2.0", macos: "0.9.0"}
|
||
}
|
||
},
|
||
"<": {
|
||
doc: "Returns `true` if the first input is strictly less than the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, collator: {js: "0.45.0", android: "6.5.0", ios: "4.2.0", macos: "0.9.0"}
|
||
}
|
||
},
|
||
">=": {
|
||
doc: "Returns `true` if the first input is greater than or equal to the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, collator: {js: "0.45.0", android: "6.5.0", ios: "4.2.0", macos: "0.9.0"}
|
||
}
|
||
},
|
||
"<=": {
|
||
doc: "Returns `true` if the first input is less than or equal to the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, collator: {js: "0.45.0", android: "6.5.0", ios: "4.2.0", macos: "0.9.0"}
|
||
}
|
||
},
|
||
all: {
|
||
doc: "Returns `true` if all the inputs are `true`, `false` otherwise. The inputs are evaluated in order, and evaluation is short-circuiting: once an input expression evaluates to `false`, the result is `false` and no further input expressions are evaluated.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
any: {
|
||
doc: "Returns `true` if any of the inputs are `true`, `false` otherwise. The inputs are evaluated in order, and evaluation is short-circuiting: once an input expression evaluates to `true`, the result is `true` and no further input expressions are evaluated.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"!": {
|
||
doc: "Logical negation. Returns `true` if the input is `false`, and `false` if the input is `true`.",
|
||
group: "Decision",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"is-supported-script": {
|
||
doc: "Returns `true` if the input string is expected to render legibly. Returns `false` if the input string contains sections that cannot be rendered without potential loss of meaning (e.g. Indic scripts that require complex text shaping, or right-to-left scripts if the the `mapbox-gl-rtl-text` plugin is not in use in Mapbox GL JS).",
|
||
group: "String"
|
||
},
|
||
upcase: {
|
||
doc: "Returns the input string converted to uppercase. Follows the Unicode Default Case Conversion algorithm and the locale-insensitive case mappings in the Unicode Character Database.",
|
||
group: "String",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
downcase: {
|
||
doc: "Returns the input string converted to lowercase. Follows the Unicode Default Case Conversion algorithm and the locale-insensitive case mappings in the Unicode Character Database.",
|
||
group: "String",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
concat: {
|
||
doc: "Returns a `string` consisting of the concatenation of the inputs. Each input is converted to a string as if by `to-string`.",
|
||
group: "String",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}
|
||
}
|
||
},
|
||
"resolved-locale": {
|
||
doc: "Returns the IETF language tag of the locale being used by the provided `collator`. This can be used to determine the default system locale, or to determine if a requested locale was successfully loaded.",
|
||
group: "String",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.5.0",
|
||
ios: "4.2.0",
|
||
macos: "0.9.0"
|
||
}
|
||
}
|
||
}
|
||
}
|
||
},
|
||
light: {
|
||
anchor: {
|
||
type: "enum",
|
||
default: "viewport",
|
||
values: {
|
||
map: {doc: "The position of the light source is aligned to the rotation of the map."},
|
||
viewport: {doc: "The position of the light source is aligned to the rotation of the viewport."}
|
||
},
|
||
"property-type": "data-constant",
|
||
transition: !1,
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
doc: "Whether extruded geometries are lit relative to the map or viewport.",
|
||
example: "map",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}
|
||
}
|
||
},
|
||
position: {
|
||
type: "array",
|
||
default: [1.15, 210, 30],
|
||
length: 3,
|
||
value: "number",
|
||
"property-type": "data-constant",
|
||
transition: !0,
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
doc: "Position of the light source relative to lit (extruded) geometries, in [r radial coordinate, a azimuthal angle, p polar angle] where r indicates the distance from the center of the base of an object to its light, a indicates the position of the light relative to 0° (0° when `light.anchor` is set to `viewport` corresponds to the top of the viewport, or 0° when `light.anchor` is set to `map` corresponds to due north, and degrees proceed clockwise), and p indicates the height of the light (from 0°, directly above, to 180°, directly below).",
|
||
example: [1.5, 90, 80],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}
|
||
}
|
||
},
|
||
color: {
|
||
type: "color",
|
||
"property-type": "data-constant",
|
||
default: "#ffffff",
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
transition: !0,
|
||
doc: "Color tint for lighting extruded geometries.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}
|
||
}
|
||
},
|
||
intensity: {
|
||
type: "number",
|
||
"property-type": "data-constant",
|
||
default: .5,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
transition: !0,
|
||
doc: "Intensity of lighting (on a scale from 0 to 1). Higher numbers will present as more extreme contrast.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}
|
||
}
|
||
}
|
||
},
|
||
paint: ["paint_fill", "paint_line", "paint_circle", "paint_heatmap", "paint_fill-extrusion", "paint_symbol", "paint_raster", "paint_hillshade", "paint_background"],
|
||
paint_fill: {
|
||
"fill-antialias": {
|
||
type: "boolean",
|
||
default: !0,
|
||
doc: "Whether or not the fill should be antialiased.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"fill-opacity": {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
doc: "The opacity of the entire fill layer. In contrast to the `fill-color`, this value will also affect the 1px stroke around the fill, if the stroke is used.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.21.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"fill-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
doc: "The color of the filled part of this layer. This color can be specified as `rgba` with an alpha component and the color's opacity will not affect the opacity of the 1px stroke, if it is used.",
|
||
transition: !0,
|
||
requires: [{"!": "fill-pattern"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.19.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"fill-outline-color": {
|
||
type: "color",
|
||
doc: "The outline color of the fill. Matches the value of `fill-color` if unspecified.",
|
||
transition: !0,
|
||
requires: [{"!": "fill-pattern"}, {"fill-antialias": !0}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.19.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"fill-translate": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 2,
|
||
default: [0, 0],
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "The geometry's offset. Values are [x, y] where negatives indicate left and up, respectively.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"fill-translate-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The fill is translated relative to the map."},
|
||
viewport: {doc: "The fill is translated relative to the viewport."}
|
||
},
|
||
doc: "Controls the frame of reference for `fill-translate`.",
|
||
default: "map",
|
||
requires: ["fill-translate"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"fill-pattern": {
|
||
type: "string",
|
||
transition: !0,
|
||
doc: "Name of image in sprite to use for drawing image fills. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.49.0", android: "6.5.0", macos: "0.11.0", ios: "4.4.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "cross-faded-data-driven"
|
||
}
|
||
},
|
||
"paint_fill-extrusion": {
|
||
"fill-extrusion-opacity": {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
doc: "The opacity of the entire fill extrusion layer. This is rendered on a per-layer, not per-feature, basis, and data-driven styling is not available.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"fill-extrusion-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
doc: "The base color of the extruded fill. The extrusion's surfaces will be shaded differently based on this color in combination with the root `light` settings. If this color is specified as `rgba` with an alpha component, the alpha component will be ignored; use `fill-extrusion-opacity` to set layer opacity.",
|
||
transition: !0,
|
||
requires: [{"!": "fill-extrusion-pattern"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}, "data-driven styling": {js: "0.27.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"fill-extrusion-translate": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 2,
|
||
default: [0, 0],
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "The geometry's offset. Values are [x, y] where negatives indicate left and up (on the flat plane), respectively.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"fill-extrusion-translate-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The fill extrusion is translated relative to the map."},
|
||
viewport: {doc: "The fill extrusion is translated relative to the viewport."}
|
||
},
|
||
doc: "Controls the frame of reference for `fill-extrusion-translate`.",
|
||
default: "map",
|
||
requires: ["fill-extrusion-translate"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"fill-extrusion-pattern": {
|
||
type: "string",
|
||
transition: !0,
|
||
doc: "Name of image in sprite to use for drawing images on extruded fills. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}, "data-driven styling": {js: "0.49.0", android: "6.5.0", macos: "0.11.0", ios: "4.4.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "cross-faded-data-driven"
|
||
},
|
||
"fill-extrusion-height": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
units: "meters",
|
||
doc: "The height with which to extrude this layer.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}, "data-driven styling": {js: "0.27.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"fill-extrusion-base": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
units: "meters",
|
||
doc: "The height with which to extrude the base of this layer. Must be less than or equal to `fill-extrusion-height`.",
|
||
transition: !0,
|
||
requires: ["fill-extrusion-height"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.27.0",
|
||
android: "5.1.0",
|
||
ios: "3.6.0",
|
||
macos: "0.5.0"
|
||
}, "data-driven styling": {js: "0.27.0", android: "5.1.0", ios: "3.6.0", macos: "0.5.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"fill-extrusion-vertical-gradient": {
|
||
type: "boolean",
|
||
default: !0,
|
||
doc: "Whether to apply a vertical gradient to the sides of a fill-extrusion layer. If true, sides will be shaded slightly darker farther down.",
|
||
transition: !1,
|
||
"sdk-support": {"basic functionality": {js: "0.50.0", ios: "4.7.0", macos: "0.13.0"}},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
}
|
||
},
|
||
paint_line: {
|
||
"line-opacity": {
|
||
type: "number",
|
||
doc: "The opacity at which the line will be drawn.",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"line-color": {
|
||
type: "color",
|
||
doc: "The color with which the line will be drawn.",
|
||
default: "#000000",
|
||
transition: !0,
|
||
requires: [{"!": "line-pattern"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.23.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"line-translate": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 2,
|
||
default: [0, 0],
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "The geometry's offset. Values are [x, y] where negatives indicate left and up, respectively.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"line-translate-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The line is translated relative to the map."},
|
||
viewport: {doc: "The line is translated relative to the viewport."}
|
||
},
|
||
doc: "Controls the frame of reference for `line-translate`.",
|
||
default: "map",
|
||
requires: ["line-translate"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"line-width": {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Stroke thickness.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.39.0", android: "5.2.0", ios: "3.7.0", macos: "0.6.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"line-gap-width": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
doc: "Draws a line casing outside of a line's actual path. Value indicates the width of the inner gap.",
|
||
transition: !0,
|
||
units: "pixels",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"line-offset": {
|
||
type: "number",
|
||
default: 0,
|
||
doc: "The line's offset. For linear features, a positive value offsets the line to the right, relative to the direction of the line, and a negative value to the left. For polygon features, a positive value results in an inset, and a negative value results in an outset.",
|
||
transition: !0,
|
||
units: "pixels",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.12.1",
|
||
android: "3.0.0",
|
||
ios: "3.1.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"line-blur": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Blur applied to the line, in pixels.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"line-dasharray": {
|
||
type: "array",
|
||
value: "number",
|
||
doc: "Specifies the lengths of the alternating dashes and gaps that form the dash pattern. The lengths are later scaled by the line width. To convert a dash length to pixels, multiply the length by the current line width. Note that GeoJSON sources with `lineMetrics: true` specified won't render dashed lines to the expected scale. Also note that zoom-dependent expressions will be evaluated only at integer zoom levels.",
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "line widths",
|
||
requires: [{"!": "line-pattern"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "cross-faded"
|
||
},
|
||
"line-pattern": {
|
||
type: "string",
|
||
transition: !0,
|
||
doc: "Name of image in sprite to use for drawing image lines. For seamless patterns, image width must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.49.0", android: "6.5.0", macos: "0.11.0", ios: "4.4.0"}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom", "feature"]},
|
||
"property-type": "cross-faded-data-driven"
|
||
},
|
||
"line-gradient": {
|
||
type: "color",
|
||
doc: 'Defines a gradient with which to color a line feature. Can only be used with GeoJSON sources that specify `"lineMetrics": true`.',
|
||
transition: !1,
|
||
requires: [{"!": "line-dasharray"}, {"!": "line-pattern"}, {
|
||
source: "geojson",
|
||
has: {lineMetrics: !0}
|
||
}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.45.0",
|
||
android: "6.5.0",
|
||
ios: "4.4.0",
|
||
macos: "0.11.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["line-progress"]},
|
||
"property-type": "color-ramp"
|
||
}
|
||
},
|
||
paint_circle: {
|
||
"circle-radius": {
|
||
type: "number",
|
||
default: 5,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Circle radius.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.18.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"circle-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
doc: "The fill color of the circle.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.18.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"circle-blur": {
|
||
type: "number",
|
||
default: 0,
|
||
doc: "Amount to blur the circle. 1 blurs the circle such that only the centerpoint is full opacity.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.20.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"circle-opacity": {
|
||
type: "number",
|
||
doc: "The opacity at which the circle will be drawn.",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.20.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"circle-translate": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 2,
|
||
default: [0, 0],
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "The geometry's offset. Values are [x, y] where negatives indicate left and up, respectively.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"circle-translate-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The circle is translated relative to the map."},
|
||
viewport: {doc: "The circle is translated relative to the viewport."}
|
||
},
|
||
doc: "Controls the frame of reference for `circle-translate`.",
|
||
default: "map",
|
||
requires: ["circle-translate"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"circle-pitch-scale": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "Circles are scaled according to their apparent distance to the camera."},
|
||
viewport: {doc: "Circles are not scaled."}
|
||
},
|
||
default: "map",
|
||
doc: "Controls the scaling behavior of the circle when the map is pitched.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.21.0",
|
||
android: "4.2.0",
|
||
ios: "3.4.0",
|
||
macos: "0.2.1"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"circle-pitch-alignment": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The circle is aligned to the plane of the map."},
|
||
viewport: {doc: "The circle is aligned to the plane of the viewport."}
|
||
},
|
||
default: "viewport",
|
||
doc: "Orientation of circle when map is pitched.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.39.0",
|
||
android: "5.2.0",
|
||
ios: "3.7.0",
|
||
macos: "0.6.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"circle-stroke-width": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "The width of the circle's stroke. Strokes are placed outside of the `circle-radius`.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.29.0",
|
||
android: "5.0.0",
|
||
ios: "3.5.0",
|
||
macos: "0.4.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"circle-stroke-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
doc: "The stroke color of the circle.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.29.0",
|
||
android: "5.0.0",
|
||
ios: "3.5.0",
|
||
macos: "0.4.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"circle-stroke-opacity": {
|
||
type: "number",
|
||
doc: "The opacity of the circle's stroke.",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.29.0",
|
||
android: "5.0.0",
|
||
ios: "3.5.0",
|
||
macos: "0.4.0"
|
||
}, "data-driven styling": {js: "0.29.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
}
|
||
},
|
||
paint_heatmap: {
|
||
"heatmap-radius": {
|
||
type: "number",
|
||
default: 30,
|
||
minimum: 1,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Radius of influence of one heatmap point in pixels. Increasing the value makes the heatmap smoother, but less detailed.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {js: "0.43.0", android: "6.0.0", ios: "4.0.0", macos: "0.7.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"heatmap-weight": {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
transition: !1,
|
||
doc: "A measure of how much an individual point contributes to the heatmap. A value of 10 would be equivalent to having 10 points of weight 1 in the same spot. Especially useful when combined with clustering.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {js: "0.41.0", android: "6.0.0", ios: "4.0.0", macos: "0.7.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"heatmap-intensity": {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
transition: !0,
|
||
doc: "Similar to `heatmap-weight` but controls the intensity of the heatmap globally. Primarily used for adjusting the heatmap based on zoom level.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"heatmap-color": {
|
||
type: "color",
|
||
default: ["interpolate", ["linear"], ["heatmap-density"], 0, "rgba(0, 0, 255, 0)", .1, "royalblue", .3, "cyan", .5, "lime", .7, "yellow", 1, "red"],
|
||
doc: 'Defines the color of each pixel based on its density value in a heatmap. Should be an expression that uses `["heatmap-density"]` as input.',
|
||
transition: !1,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["heatmap-density"]},
|
||
"property-type": "color-ramp"
|
||
},
|
||
"heatmap-opacity": {
|
||
type: "number",
|
||
doc: "The global opacity at which the heatmap layer will be drawn.",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.41.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
}
|
||
},
|
||
paint_symbol: {
|
||
"icon-opacity": {
|
||
doc: "The opacity at which the icon will be drawn.",
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
transition: !0,
|
||
doc: "The color of the icon. This can only be used with sdf icons.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-halo-color": {
|
||
type: "color",
|
||
default: "rgba(0, 0, 0, 0)",
|
||
transition: !0,
|
||
doc: "The color of the icon's halo. Icon halos can only be used with SDF icons.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-halo-width": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Distance of halo to the icon outline.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-halo-blur": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Fade out the halo towards the outside.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"icon-translate": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 2,
|
||
default: [0, 0],
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Distance that the icon's anchor is moved from its original placement. Positive values indicate right and down, while negative values indicate left and up.",
|
||
requires: ["icon-image"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"icon-translate-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "Icons are translated relative to the map."},
|
||
viewport: {doc: "Icons are translated relative to the viewport."}
|
||
},
|
||
doc: "Controls the frame of reference for `icon-translate`.",
|
||
default: "map",
|
||
requires: ["icon-image", "icon-translate"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-opacity": {
|
||
type: "number",
|
||
doc: "The opacity at which the text will be drawn.",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-color": {
|
||
type: "color",
|
||
doc: "The color with which the text will be drawn.",
|
||
default: "#000000",
|
||
transition: !0,
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-halo-color": {
|
||
type: "color",
|
||
default: "rgba(0, 0, 0, 0)",
|
||
transition: !0,
|
||
doc: "The color of the text's halo, which helps it stand out from backgrounds.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-halo-width": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Distance of halo to the font outline. Max text halo width is 1/4 of the font-size.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-halo-blur": {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "The halo's fadeout distance towards the outside.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {js: "0.33.0", android: "5.0.0", ios: "3.5.0", macos: "0.4.0"}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom", "feature", "feature-state"]},
|
||
"property-type": "data-driven"
|
||
},
|
||
"text-translate": {
|
||
type: "array",
|
||
value: "number",
|
||
length: 2,
|
||
default: [0, 0],
|
||
transition: !0,
|
||
units: "pixels",
|
||
doc: "Distance that the text's anchor is moved from its original placement. Positive values indicate right and down, while negative values indicate left and up.",
|
||
requires: ["text-field"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"text-translate-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The text is translated relative to the map."},
|
||
viewport: {doc: "The text is translated relative to the viewport."}
|
||
},
|
||
doc: "Controls the frame of reference for `text-translate`.",
|
||
default: "map",
|
||
requires: ["text-field", "text-translate"],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
}
|
||
},
|
||
paint_raster: {
|
||
"raster-opacity": {
|
||
type: "number",
|
||
doc: "The opacity at which the image will be drawn.",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"raster-hue-rotate": {
|
||
type: "number",
|
||
default: 0,
|
||
period: 360,
|
||
transition: !0,
|
||
units: "degrees",
|
||
doc: "Rotates hues around the color wheel.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"raster-brightness-min": {
|
||
type: "number",
|
||
doc: "Increase or reduce the brightness of the image. The value is the minimum brightness.",
|
||
default: 0,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"raster-brightness-max": {
|
||
type: "number",
|
||
doc: "Increase or reduce the brightness of the image. The value is the maximum brightness.",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"raster-saturation": {
|
||
type: "number",
|
||
doc: "Increase or reduce the saturation of the image.",
|
||
default: 0,
|
||
minimum: -1,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"raster-contrast": {
|
||
type: "number",
|
||
doc: "Increase or reduce the contrast of the image.",
|
||
default: 0,
|
||
minimum: -1,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"raster-resampling": {
|
||
type: "enum",
|
||
doc: "The resampling/interpolation method to use for overscaling, also known as texture magnification filter",
|
||
values: {
|
||
linear: {doc: "(Bi)linear filtering interpolates pixel values using the weighted average of the four closest original source pixels creating a smooth but blurry look when overscaled"},
|
||
nearest: {doc: "Nearest neighbor filtering interpolates pixel values using the nearest original source pixel creating a sharp but pixelated look when overscaled"}
|
||
},
|
||
default: "linear",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.47.0",
|
||
android: "6.3.0",
|
||
ios: "4.2.0",
|
||
macos: "0.9.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"raster-fade-duration": {
|
||
type: "number",
|
||
default: 300,
|
||
minimum: 0,
|
||
transition: !1,
|
||
units: "milliseconds",
|
||
doc: "Fade duration when a new tile is added.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
}
|
||
},
|
||
paint_hillshade: {
|
||
"hillshade-illumination-direction": {
|
||
type: "number",
|
||
default: 335,
|
||
minimum: 0,
|
||
maximum: 359,
|
||
doc: "The direction of the light source used to generate the hillshading with 0 as the top of the viewport if `hillshade-illumination-anchor` is set to `viewport` and due north if `hillshade-illumination-anchor` is set to `map`.",
|
||
transition: !1,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"hillshade-illumination-anchor": {
|
||
type: "enum",
|
||
values: {
|
||
map: {doc: "The hillshade illumination is relative to the north direction."},
|
||
viewport: {doc: "The hillshade illumination is relative to the top of the viewport."}
|
||
},
|
||
default: "viewport",
|
||
doc: "Direction of light source when map is rotated.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"hillshade-exaggeration": {
|
||
type: "number",
|
||
doc: "Intensity of the hillshade",
|
||
default: .5,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"hillshade-shadow-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
doc: "The shading color of areas that face away from the light source.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"hillshade-highlight-color": {
|
||
type: "color",
|
||
default: "#FFFFFF",
|
||
doc: "The shading color of areas that faces towards the light source.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"hillshade-accent-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
doc: "The shading color used to accentuate rugged terrain like sharp cliffs and gorges.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.43.0",
|
||
android: "6.0.0",
|
||
ios: "4.0.0",
|
||
macos: "0.7.0"
|
||
}, "data-driven styling": {}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
}
|
||
},
|
||
paint_background: {
|
||
"background-color": {
|
||
type: "color",
|
||
default: "#000000",
|
||
doc: "The color with which the background will be drawn.",
|
||
transition: !0,
|
||
requires: [{"!": "background-pattern"}],
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
},
|
||
"background-pattern": {
|
||
type: "string",
|
||
transition: !0,
|
||
doc: "Name of image in sprite to use for drawing an image background. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.",
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
},
|
||
expression: {interpolated: !1, parameters: ["zoom"]},
|
||
"property-type": "cross-faded"
|
||
},
|
||
"background-opacity": {
|
||
type: "number",
|
||
default: 1,
|
||
minimum: 0,
|
||
maximum: 1,
|
||
doc: "The opacity at which the background will be drawn.",
|
||
transition: !0,
|
||
"sdk-support": {
|
||
"basic functionality": {
|
||
js: "0.10.0",
|
||
android: "2.0.1",
|
||
ios: "2.0.0",
|
||
macos: "0.1.0"
|
||
}
|
||
},
|
||
expression: {interpolated: !0, parameters: ["zoom"]},
|
||
"property-type": "data-constant"
|
||
}
|
||
},
|
||
transition: {
|
||
duration: {
|
||
type: "number",
|
||
default: 300,
|
||
minimum: 0,
|
||
units: "milliseconds",
|
||
doc: "Time allotted for transitions to complete."
|
||
},
|
||
delay: {
|
||
type: "number",
|
||
default: 0,
|
||
minimum: 0,
|
||
units: "milliseconds",
|
||
doc: "Length of time before a transition begins."
|
||
}
|
||
},
|
||
"property-type": {
|
||
"data-driven": {
|
||
type: "property-type",
|
||
doc: "Property is interpolable and can be represented using a property expression."
|
||
},
|
||
"cross-faded": {
|
||
type: "property-type",
|
||
doc: "Property is non-interpolable; rather, its values will be cross-faded to smoothly transition between integer zooms."
|
||
},
|
||
"cross-faded-data-driven": {
|
||
type: "property-type",
|
||
doc: "Property is non-interpolable; rather, its values will be cross-faded to smoothly transition between integer zooms. It can be represented using a property expression."
|
||
},
|
||
"color-ramp": {
|
||
type: "property-type",
|
||
doc: "Property should be specified using a color ramp from which the output color can be sampled based on a property calculation."
|
||
},
|
||
"data-constant": {
|
||
type: "property-type",
|
||
doc: "Property is interpolable but cannot be represented using a property expression."
|
||
},
|
||
constant: {
|
||
type: "property-type",
|
||
doc: "Property is constant across all zoom levels and property values."
|
||
}
|
||
}
|
||
}
|
||
}, function (t, e) {
|
||
(function () {
|
||
var e;
|
||
t.exports = {
|
||
icon: "icons/google.svg",
|
||
name: "google",
|
||
title: "Google Fonts",
|
||
link: "google.com/fonts",
|
||
getNames: function () {
|
||
return e
|
||
},
|
||
getLink: function (t) {
|
||
return "https://fonts.google.com/specimen/" + t.replace(/( )/g, "+")
|
||
},
|
||
normalizeName: function (t) {
|
||
return t
|
||
}
|
||
}, e = ["ABeeZee", "Abel", "Abril Fatface", "Aclonica", "Acme", "Actor", "Adamina", "Advent Pro", "Aguafina Script", "Akronim", "Aladin", "Aldrich", "Alef", "Alegreya", "Alegreya SC", "Alegreya Sans", "Alegreya Sans SC", "Alex Brush", "Alfa Slab One", "Alice", "Alike", "Alike Angular", "Allan", "Allerta", "Allerta Stencil", "Allura", "Almendra", "Almendra Display", "Almendra SC", "Amarante", "Amaranth", "Amatic SC", "Amethysta", "Amiri", "Amita", "Anaheim", "Andada", "Andika", "Angkor", "Annie Use Your Telescope", "Anonymous Pro", "Antic", "Antic Didone", "Antic Slab", "Anton", "Arapey", "Arbutus", "Arbutus Slab", "Architects Daughter", "Archivo Black", "Archivo Narrow", "Arimo", "Arizonia", "Armata", "Artifika", "Arvo", "Arya", "Asap", "Asar", "Asset", "Astloch", "Asul", "Atomic Age", "Aubrey", "Audiowide", "Autour One", "Average", "Average Sans", "Averia Gruesa Libre", "Averia Libre", "Averia Sans Libre", "Averia Serif Libre", "Bad Script", "Balthazar", "Bangers", "Basic", "Battambang", "Baumans", "Bayon", "Belgrano", "Belleza", "BenchNine", "Bentham", "Berkshire Swash", "Bevan", "Bigelow Rules", "Bigshot One", "Bilbo", "Bilbo Swash Caps", "Biryani", "Bitter", "Black Ops One", "Bokor", "Bonbon", "Boogaloo", "Bowlby One", "Bowlby One SC", "Brawler", "Bree Serif", "Bubblegum Sans", "Bubbler One", "Buda", "Buenard", "Butcherman", "Butterfly Kids", "Cabin", "Cabin Condensed", "Cabin Sketch", "Caesar Dressing", "Cagliostro", "Calligraffitti", "Cambay", "Cambo", "Candal", "Cantarell", "Cantata One", "Cantora One", "Capriola", "Cardo", "Carme", "Carrois Gothic", "Carrois Gothic SC", "Carter One", "Catamaran", "Caudex", "Caveat", "Caveat Brush", "Cedarville Cursive", "Ceviche One", "Changa One", "Chango", "Chau Philomene One", "Chela One", "Chelsea Market", "Chenla", "Cherry Cream Soda", "Cherry Swash", "Chewy", "Chicle", "Chivo", "Chonburi", "Cinzel", "Cinzel Decorative", "Clicker Script", "Coda", "Coda Caption", "Codystar", "Combo", "Comfortaa", "Coming Soon", "Concert One", "Condiment", "Content", "Contrail One", "Convergence", "Cookie", "Copse", "Corben", "Courgette", "Cousine", "Coustard", "Covered By Your Grace", "Crafty Girls", "Creepster", "Crete Round", "Crimson Text", "Croissant One", "Crushed", "Cuprum", "Cutive", "Cutive Mono", "Damion", "Dancing Script", "Dangrek", "Dawning of a New Day", "Days One", "Dekko", "Delius", "Delius Swash Caps", "Delius Unicase", "Della Respira", "Denk One", "Devonshire", "Dhurjati", "Didact Gothic", "Diplomata", "Diplomata SC", "Domine", "Donegal One", "Doppio One", "Dorsa", "Dosis", "Dr Sugiyama", "Droid Sans", "Droid Sans Mono", "Droid Serif", "Duru Sans", "Dynalight", "EB Garamond", "Eagle Lake", "Eater", "Economica", "Eczar", "Ek Mukta", "Electrolize", "Elsie", "Elsie Swash Caps", "Emblema One", "Emilys Candy", "Engagement", "Englebert", "Enriqueta", "Erica One", "Esteban", "Euphoria Script", "Ewert", "Exo", "Exo 2", "Expletus Sans", "Fanwood Text", "Fascinate", "Fascinate Inline", "Faster One", "Fasthand", "Fauna One", "Federant", "Federo", "Felipa", "Fenix", "Finger Paint", "Fira Mono", "Fira Sans", "Fjalla One", "Fjord One", "Flamenco", "Flavors", "Fondamento", "Fontdiner Swanky", "Forum", "Francois One", "Freckle Face", "Fredericka the Great", "Fredoka One", "Freehand", "Fresca", "Frijole", "Fruktur", "Fugaz One", "GFS Didot", "GFS Neohellenic", "Gabriela", "Gafata", "Galdeano", "Galindo", "Gentium Basic", "Gentium Book Basic", "Geo", "Geostar", "Geostar Fill", "Germania One", "Gidugu", "Gilda Display", "Give You Glory", "Glass Antiqua", "Glegoo", "Gloria Hallelujah", "Goblin One", "Gochi Hand", "Gorditas", "Goudy Bookletter 1911", "Graduate", "Grand Hotel", "Gravitas One", "Great Vibes", "Griffy", "Gruppo", "Gudea", "Gurajada", "Habibi", "Halant", "Hammersmith One", "Hanalei", "Hanalei Fill", "Handlee", "Hanuman", "Happy Monkey", "Headland One", "Henny Penny", "Herr Von Muellerhoff", "Hind", "Hind Siliguri", "Hind Vadodara", "Holtwood One SC", "Homemade Apple", "Homenaje", "IM Fell DW Pica", "IM Fell DW Pica SC", "IM Fell Double Pica", "IM Fell Double Pica SC", "IM Fell English", "IM Fell English SC", "IM Fell French Canon", "IM Fell French Canon SC", "IM Fell Great Primer", "IM Fell Great Primer SC", "Iceberg", "Iceland", "Imprima", "Inconsolata", "Inder", "Indie Flower", "Inika", "Inknut Antiqua", "Irish Grover", "Istok Web", "Italiana", "Italianno", "Itim", "Jacques Francois", "Jacques Francois Shadow", "Jaldi", "Jim Nightshade", "Jockey One", "Jolly Lodger", "Josefin Sans", "Josefin Slab", "Joti One", "Judson", "Julee", "Julius Sans One", "Junge", "Jura", "Just Another Hand", "Just Me Again Down Here", "Kadwa", "Kalam", "Kameron", "Kantumruy", "Karla", "Karma", "Kaushan Script", "Kavoon", "Kdam Thmor", "Keania One", "Kelly Slab", "Kenia", "Khand", "Khmer", "Khula", "Kite One", "Knewave", "Kotta One", "Koulen", "Kranky", "Kreon", "Kristi", "Krona One", "Kurale", "La Belle Aurore", "Laila", "Lakki Reddy", "Lancelot", "Lateef", "Lato", "League Script", "Leckerli One", "Ledger", "Lekton", "Lemon", "Libre Baskerville", "Life Savers", "Lilita One", "Lily Script One", "Limelight", "Linden Hill", "Lobster", "Lobster Two", "Londrina Outline", "Londrina Shadow", "Londrina Sketch", "Londrina Solid", "Lora", "Love Ya Like A Sister", "Loved by the King", "Lovers Quarrel", "Luckiest Guy", "Lusitana", "Lustria", "Macondo", "Macondo Swash Caps", "Magra", "Maiden Orange", "Mako", "Mallanna", "Mandali", "Marcellus", "Marcellus SC", "Marck Script", "Margarine", "Marko One", "Marmelad", "Martel", "Martel Sans", "Marvel", "Mate", "Mate SC", "Maven Pro", "McLaren", "Meddon", "MedievalSharp", "Medula One", "Megrim", "Meie Script", "Merienda", "Merienda One", "Merriweather", "Merriweather Sans", "Metal", "Metal Mania", "Metamorphous", "Metrophobic", "Michroma", "Milonga", "Miltonian", "Miltonian Tattoo", "Miniver", "Miss Fajardose", "Modak", "Modern Antiqua", "Molengo", "Molle", "Monda", "Monofett", "Monoton", "Monsieur La Doulaise", "Montaga", "Montez", "Montserrat", "Montserrat Alternates", "Montserrat Subrayada", "Moul", "Moulpali", "Mountains of Christmas", "Mouse Memoirs", "Mr Bedfort", "Mr Dafoe", "Mr De Haviland", "Mrs Saint Delafield", "Mrs Sheppards", "Muli", "Mystery Quest", "NTR", "Neucha", "Neuton", "New Rocker", "News Cycle", "Niconne", "Nixie One", "Nobile", "Nokora", "Norican", "Nosifer", "Nothing You Could Do", "Noticia Text", "Noto Sans", "Noto Serif", "Nova Cut", "Nova Flat", "Nova Mono", "Nova Oval", "Nova Round", "Nova Script", "Nova Slim", "Nova Square", "Numans", "Nunito", "Odor Mean Chey", "Offside", "Old Standard TT", "Oldenburg", "Oleo Script", "Oleo Script Swash Caps", "Open Sans", "Open Sans Condensed", "Oranienbaum", "Orbitron", "Oregano", "Orienta", "Original Surfer", "Oswald", "Over the Rainbow", "Overlock", "Overlock SC", "Ovo", "Oxygen", "Oxygen Mono", "PT Mono", "PT Sans", "PT Sans Caption", "PT Sans Narrow", "PT Serif", "PT Serif Caption", "Pacifico", "Palanquin", "Palanquin Dark", "Paprika", "Parisienne", "Passero One", "Passion One", "Pathway Gothic One", "Patrick Hand", "Patrick Hand SC", "Patua One", "Paytone One", "Peddana", "Peralta", "Permanent Marker", "Petit Formal Script", "Petrona", "Philosopher", "Piedra", "Pinyon Script", "Pirata One", "Plaster", "Play", "Playball", "Playfair Display", "Playfair Display SC", "Podkova", "Poiret One", "Poller One", "Poly", "Pompiere", "Pontano Sans", "Poppins", "Port Lligat Sans", "Port Lligat Slab", "Pragati Narrow", "Prata", "Preahvihear", "Press Start 2P", "Princess Sofia", "Prociono", "Prosto One", "Puritan", "Purple Purse", "Quando", "Quantico", "Quattrocento", "Quattrocento Sans", "Questrial", "Quicksand", "Quintessential", "Qwigley", "Racing Sans One", "Radley", "Rajdhani", "Raleway", "Raleway Dots", "Ramabhadra", "Ramaraja", "Rambla", "Rammetto One", "Ranchers", "Rancho", "Ranga", "Rationale", "Ravi Prakash", "Redressed", "Reenie Beanie", "Revalia", "Rhodium Libre", "Ribeye", "Ribeye Marrow", "Righteous", "Risque", "Roboto", "Roboto Condensed", "Roboto Mono", "Roboto Slab", "Rochester", "Rock Salt", "Rokkitt", "Romanesco", "Ropa Sans", "Rosario", "Rosarivo", "Rouge Script", "Rozha One", "Rubik", "Rubik Mono One", "Rubik One", "Ruda", "Rufina", "Ruge Boogie", "Ruluko", "Rum Raisin", "Ruslan Display", "Russo One", "Ruthie", "Rye", "Sacramento", "Sahitya", "Sail", "Salsa", "Sanchez", "Sancreek", "Sansita One", "Sarala", "Sarina", "Sarpanch", "Satisfy", "Scada", "Scheherazade", "Schoolbell", "Seaweed Script", "Sevillana", "Seymour One", "Shadows Into Light", "Shadows Into Light Two", "Shanti", "Share", "Share Tech", "Share Tech Mono", "Shojumaru", "Short Stack", "Siemreap", "Sigmar One", "Signika", "Signika Negative", "Simonetta", "Sintony", "Sirin Stencil", "Six Caps", "Skranji", "Slabo 13px", "Slabo 27px", "Slackey", "Smokum", "Smythe", "Sniglet", "Snippet", "Snowburst One", "Sofadi One", "Sofia", "Sonsie One", "Sorts Mill Goudy", "Source Code Pro", "Source Sans Pro", "Source Serif Pro", "Special Elite", "Spicy Rice", "Spinnaker", "Spirax", "Squada One", "Sree Krushnadevaraya", "Stalemate", "Stalinist One", "Stardos Stencil", "Stint Ultra Condensed", "Stint Ultra Expanded", "Stoke", "Strait", "Sue Ellen Francisco", "Sumana", "Sunshiney", "Supermercado One", "Sura", "Suranna", "Suravaram", "Suwannaphum", "Swanky and Moo Moo", "Syncopate", "Tangerine", "Taprom", "Tauri", "Teko", "Telex", "Tenali Ramakrishna", "Tenor Sans", "Text Me One", "The Girl Next Door", "Tienne", "Tillana", "Timmana", "Tinos", "Titan One", "Titillium Web", "Trade Winds", "Trocchi", "Trochut", "Trykker", "Tulpen One", "Ubuntu", "Ubuntu Condensed", "Ubuntu Mono", "Ultra", "Uncial Antiqua", "Underdog", "Unica One", "UnifrakturCook", "UnifrakturMaguntia", "Unkempt", "Unlock", "Unna", "VT323", "Vampiro One", "Varela", "Varela Round", "Vast Shadow", "Vesper Libre", "Vibur", "Vidaloka", "Viga", "Voces", "Volkhov", "Vollkorn", "Voltaire", "Waiting for the Sunrise", "Wallpoet", "Walter Turncoat", "Warnes", "Wellfleet", "Wendy One", "Wire One", "Work Sans", "Yanone Kaffeesatz", "Yantramanav", "Yellowtail", "Yeseva One", "Yesteryear", "Zeyada"]
|
||
}).call(this)
|
||
}, , , function (t, e, i) {
|
||
t.exports = function () {
|
||
"use strict";
|
||
|
||
function t(t, e, i) {
|
||
var r = t[e];
|
||
t[e] = t[i], t[i] = r
|
||
}
|
||
|
||
function e(t, e) {
|
||
return t < e ? -1 : t > e ? 1 : 0
|
||
}
|
||
|
||
return function (i, r, o, n, s) {
|
||
!function e(i, r, o, n, s) {
|
||
for (; n > o;) {
|
||
if (n - o > 600) {
|
||
var a = n - o + 1, l = r - o + 1, h = Math.log(a), u = .5 * Math.exp(2 * h / 3),
|
||
c = .5 * Math.sqrt(h * u * (a - u) / a) * (l - a / 2 < 0 ? -1 : 1),
|
||
p = Math.max(o, Math.floor(r - l * u / a + c)),
|
||
d = Math.min(n, Math.floor(r + (a - l) * u / a + c));
|
||
e(i, r, p, d, s)
|
||
}
|
||
var f = i[r], g = o, m = n;
|
||
for (t(i, o, r), s(i[n], f) > 0 && t(i, o, n); g < m;) {
|
||
for (t(i, g, m), g++, m--; s(i[g], f) < 0;) g++;
|
||
for (; s(i[m], f) > 0;) m--
|
||
}
|
||
0 === s(i[o], f) ? t(i, o, m) : t(i, ++m, n), m <= r && (o = m + 1), r <= m && (n = m - 1)
|
||
}
|
||
}(i, r, o || 0, n || i.length - 1, s || e)
|
||
}
|
||
}()
|
||
}, function (t, e, i) {
|
||
var r = i(17).newImageData;
|
||
|
||
function o(t) {
|
||
var e = !0;
|
||
try {
|
||
new ImageData(10, 10)
|
||
} catch (t) {
|
||
e = !1
|
||
}
|
||
|
||
function i(t, i, r) {
|
||
return e ? new ImageData(t, i, r) : {data: t, width: i, height: r}
|
||
}
|
||
|
||
return function (e) {
|
||
var r, o, n = e.buffers, s = e.meta, a = e.imageOps, l = e.width, h = e.height, u = n.length,
|
||
c = n[0].byteLength;
|
||
if (a) {
|
||
var p = new Array(u);
|
||
for (o = 0; o < u; ++o) p[o] = i(new Uint8ClampedArray(n[o]), l, h);
|
||
r = t(p, s).data
|
||
} else {
|
||
r = new Uint8ClampedArray(c);
|
||
var d = new Array(u), f = new Array(u);
|
||
for (o = 0; o < u; ++o) d[o] = new Uint8ClampedArray(n[o]), f[o] = [0, 0, 0, 0];
|
||
for (var g = 0; g < c; g += 4) {
|
||
for (var m = 0; m < u; ++m) {
|
||
var y = d[m];
|
||
f[m][0] = y[g], f[m][1] = y[g + 1], f[m][2] = y[g + 2], f[m][3] = y[g + 3]
|
||
}
|
||
var v = t(f, s);
|
||
r[g] = v[0], r[g + 1] = v[1], r[g + 2] = v[2], r[g + 3] = v[3]
|
||
}
|
||
}
|
||
return r.buffer
|
||
}
|
||
}
|
||
|
||
function n(t, e) {
|
||
var i = Object.keys(t.lib || {}).map(function (e) {
|
||
return "var " + e + " = " + t.lib[e].toString() + ";"
|
||
}).concat(["var __minion__ = (" + o.toString() + ")(", t.operation.toString(), ");", 'self.addEventListener("message", function(event) {', " var buffer = __minion__(event.data);", " self.postMessage({buffer: buffer, meta: event.data.meta}, [buffer]);", "});"]),
|
||
r = new Blob(i, {type: "text/javascript"}), n = URL.createObjectURL(r), s = new Worker(n);
|
||
return s.addEventListener("message", e), s
|
||
}
|
||
|
||
function s(t) {
|
||
var e;
|
||
this._imageOps = !!t.imageOps;
|
||
var i = [];
|
||
if (e = 0 === t.threads ? 0 : this._imageOps ? 1 : t.threads || 1) for (var r = 0; r < e; ++r) i[r] = n(t, this._onWorkerMessage.bind(this, r)); else i[0] = function (t, e) {
|
||
var i = o(t.operation);
|
||
return {
|
||
postMessage: function (t) {
|
||
setTimeout(function () {
|
||
e({data: {buffer: i(t), meta: t.meta}})
|
||
}, 0)
|
||
}
|
||
}
|
||
}(t, this._onWorkerMessage.bind(this, 0));
|
||
this._workers = i, this._queue = [], this._maxQueueLength = t.queue || 1 / 0, this._running = 0, this._dataLookup = {}, this._job = null
|
||
}
|
||
|
||
s.prototype.process = function (t, e, i) {
|
||
this._enqueue({inputs: t, meta: e, callback: i}), this._dispatch()
|
||
}, s.prototype.destroy = function () {
|
||
for (var t in this) this[t] = null;
|
||
this._destroyed = !0
|
||
}, s.prototype._enqueue = function (t) {
|
||
for (this._queue.push(t); this._queue.length > this._maxQueueLength;) this._queue.shift().callback(null, null)
|
||
}, s.prototype._dispatch = function () {
|
||
if (0 === this._running && this._queue.length > 0) {
|
||
var t = this._job = this._queue.shift(), e = t.inputs[0].width, i = t.inputs[0].height,
|
||
r = t.inputs.map(function (t) {
|
||
return t.data.buffer
|
||
}), o = this._workers.length;
|
||
if (this._running = o, 1 === o) this._workers[0].postMessage({
|
||
buffers: r,
|
||
meta: t.meta,
|
||
imageOps: this._imageOps,
|
||
width: e,
|
||
height: i
|
||
}, r); else for (var n = t.inputs[0].data.length, s = 4 * Math.ceil(n / 4 / o), a = 0; a < o; ++a) {
|
||
for (var l = a * s, h = [], u = 0, c = r.length; u < c; ++u) h.push(r[a].slice(l, l + s));
|
||
this._workers[a].postMessage({
|
||
buffers: h,
|
||
meta: t.meta,
|
||
imageOps: this._imageOps,
|
||
width: e,
|
||
height: i
|
||
}, h)
|
||
}
|
||
}
|
||
}, s.prototype._onWorkerMessage = function (t, e) {
|
||
this._destroyed || (this._dataLookup[t] = e.data, --this._running, 0 === this._running && this._resolveJob())
|
||
}, s.prototype._resolveJob = function () {
|
||
var t, e, i = this._job, o = this._workers.length;
|
||
if (1 === o) t = new Uint8ClampedArray(this._dataLookup[0].buffer), e = this._dataLookup[0].meta; else {
|
||
var n = i.inputs[0].data.length;
|
||
t = new Uint8ClampedArray(n), e = new Array(n);
|
||
for (var s = 4 * Math.ceil(n / 4 / o), a = 0; a < o; ++a) {
|
||
var l = this._dataLookup[a].buffer, h = a * s;
|
||
t.set(new Uint8ClampedArray(l), h), e[a] = this._dataLookup[a].meta
|
||
}
|
||
}
|
||
this._job = null, this._dataLookup = {}, i.callback(null, r(t, i.inputs[0].width, i.inputs[0].height), e), this._dispatch()
|
||
}, t.exports = s
|
||
}, function (t, e) {
|
||
var i = !0;
|
||
try {
|
||
new ImageData(10, 10)
|
||
} catch (t) {
|
||
i = !1
|
||
}
|
||
var r = document.createElement("canvas").getContext("2d");
|
||
e.newImageData = function (t, e, o) {
|
||
if (i) return new ImageData(t, e, o);
|
||
var n = r.createImageData(e, o);
|
||
return n.data.set(t), n
|
||
}
|
||
}, function (t, e, i) {
|
||
"use strict";
|
||
(function (t) {
|
||
/*!
|
||
* The buffer module from node.js, for the browser.
|
||
*
|
||
* @author Feross Aboukhadijeh <feross@feross.org> <http://feross.org>
|
||
* @license MIT
|
||
*/
|
||
var r = i(19), o = i(7), n = i(20);
|
||
|
||
function s() {
|
||
return l.TYPED_ARRAY_SUPPORT ? 2147483647 : 1073741823
|
||
}
|
||
|
||
function a(t, e) {
|
||
if (s() < e) throw new RangeError("Invalid typed array length");
|
||
return l.TYPED_ARRAY_SUPPORT ? (t = new Uint8Array(e)).__proto__ = l.prototype : (null === t && (t = new l(e)), t.length = e), t
|
||
}
|
||
|
||
function l(t, e, i) {
|
||
if (!(l.TYPED_ARRAY_SUPPORT || this instanceof l)) return new l(t, e, i);
|
||
if ("number" == typeof t) {
|
||
if ("string" == typeof e) throw new Error("If encoding is specified then the first argument must be a string");
|
||
return c(this, t)
|
||
}
|
||
return h(this, t, e, i)
|
||
}
|
||
|
||
function h(t, e, i, r) {
|
||
if ("number" == typeof e) throw new TypeError('"value" argument must not be a number');
|
||
return "undefined" != typeof ArrayBuffer && e instanceof ArrayBuffer ? function (t, e, i, r) {
|
||
if (e.byteLength, i < 0 || e.byteLength < i) throw new RangeError("'offset' is out of bounds");
|
||
if (e.byteLength < i + (r || 0)) throw new RangeError("'length' is out of bounds");
|
||
e = void 0 === i && void 0 === r ? new Uint8Array(e) : void 0 === r ? new Uint8Array(e, i) : new Uint8Array(e, i, r);
|
||
l.TYPED_ARRAY_SUPPORT ? (t = e).__proto__ = l.prototype : t = p(t, e);
|
||
return t
|
||
}(t, e, i, r) : "string" == typeof e ? function (t, e, i) {
|
||
"string" == typeof i && "" !== i || (i = "utf8");
|
||
if (!l.isEncoding(i)) throw new TypeError('"encoding" must be a valid string encoding');
|
||
var r = 0 | f(e, i), o = (t = a(t, r)).write(e, i);
|
||
o !== r && (t = t.slice(0, o));
|
||
return t
|
||
}(t, e, i) : function (t, e) {
|
||
if (l.isBuffer(e)) {
|
||
var i = 0 | d(e.length);
|
||
return 0 === (t = a(t, i)).length ? t : (e.copy(t, 0, 0, i), t)
|
||
}
|
||
if (e) {
|
||
if ("undefined" != typeof ArrayBuffer && e.buffer instanceof ArrayBuffer || "length" in e) return "number" != typeof e.length || (r = e.length) != r ? a(t, 0) : p(t, e);
|
||
if ("Buffer" === e.type && n(e.data)) return p(t, e.data)
|
||
}
|
||
var r;
|
||
throw new TypeError("First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.")
|
||
}(t, e)
|
||
}
|
||
|
||
function u(t) {
|
||
if ("number" != typeof t) throw new TypeError('"size" argument must be a number');
|
||
if (t < 0) throw new RangeError('"size" argument must not be negative')
|
||
}
|
||
|
||
function c(t, e) {
|
||
if (u(e), t = a(t, e < 0 ? 0 : 0 | d(e)), !l.TYPED_ARRAY_SUPPORT) for (var i = 0; i < e; ++i) t[i] = 0;
|
||
return t
|
||
}
|
||
|
||
function p(t, e) {
|
||
var i = e.length < 0 ? 0 : 0 | d(e.length);
|
||
t = a(t, i);
|
||
for (var r = 0; r < i; r += 1) t[r] = 255 & e[r];
|
||
return t
|
||
}
|
||
|
||
function d(t) {
|
||
if (t >= s()) throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x" + s().toString(16) + " bytes");
|
||
return 0 | t
|
||
}
|
||
|
||
function f(t, e) {
|
||
if (l.isBuffer(t)) return t.length;
|
||
if ("undefined" != typeof ArrayBuffer && "function" == typeof ArrayBuffer.isView && (ArrayBuffer.isView(t) || t instanceof ArrayBuffer)) return t.byteLength;
|
||
"string" != typeof t && (t = "" + t);
|
||
var i = t.length;
|
||
if (0 === i) return 0;
|
||
for (var r = !1; ;) switch (e) {
|
||
case"ascii":
|
||
case"latin1":
|
||
case"binary":
|
||
return i;
|
||
case"utf8":
|
||
case"utf-8":
|
||
case void 0:
|
||
return z(t).length;
|
||
case"ucs2":
|
||
case"ucs-2":
|
||
case"utf16le":
|
||
case"utf-16le":
|
||
return 2 * i;
|
||
case"hex":
|
||
return i >>> 1;
|
||
case"base64":
|
||
return U(t).length;
|
||
default:
|
||
if (r) return z(t).length;
|
||
e = ("" + e).toLowerCase(), r = !0
|
||
}
|
||
}
|
||
|
||
function g(t, e, i) {
|
||
var r = t[e];
|
||
t[e] = t[i], t[i] = r
|
||
}
|
||
|
||
function m(t, e, i, r, o) {
|
||
if (0 === t.length) return -1;
|
||
if ("string" == typeof i ? (r = i, i = 0) : i > 2147483647 ? i = 2147483647 : i < -2147483648 && (i = -2147483648), i = +i, isNaN(i) && (i = o ? 0 : t.length - 1), i < 0 && (i = t.length + i), i >= t.length) {
|
||
if (o) return -1;
|
||
i = t.length - 1
|
||
} else if (i < 0) {
|
||
if (!o) return -1;
|
||
i = 0
|
||
}
|
||
if ("string" == typeof e && (e = l.from(e, r)), l.isBuffer(e)) return 0 === e.length ? -1 : y(t, e, i, r, o);
|
||
if ("number" == typeof e) return e &= 255, l.TYPED_ARRAY_SUPPORT && "function" == typeof Uint8Array.prototype.indexOf ? o ? Uint8Array.prototype.indexOf.call(t, e, i) : Uint8Array.prototype.lastIndexOf.call(t, e, i) : y(t, [e], i, r, o);
|
||
throw new TypeError("val must be string, number or Buffer")
|
||
}
|
||
|
||
function y(t, e, i, r, o) {
|
||
var n, s = 1, a = t.length, l = e.length;
|
||
if (void 0 !== r && ("ucs2" === (r = String(r).toLowerCase()) || "ucs-2" === r || "utf16le" === r || "utf-16le" === r)) {
|
||
if (t.length < 2 || e.length < 2) return -1;
|
||
s = 2, a /= 2, l /= 2, i /= 2
|
||
}
|
||
|
||
function h(t, e) {
|
||
return 1 === s ? t[e] : t.readUInt16BE(e * s)
|
||
}
|
||
|
||
if (o) {
|
||
var u = -1;
|
||
for (n = i; n < a; n++) if (h(t, n) === h(e, -1 === u ? 0 : n - u)) {
|
||
if (-1 === u && (u = n), n - u + 1 === l) return u * s
|
||
} else -1 !== u && (n -= n - u), u = -1
|
||
} else for (i + l > a && (i = a - l), n = i; n >= 0; n--) {
|
||
for (var c = !0, p = 0; p < l; p++) if (h(t, n + p) !== h(e, p)) {
|
||
c = !1;
|
||
break
|
||
}
|
||
if (c) return n
|
||
}
|
||
return -1
|
||
}
|
||
|
||
function v(t, e, i, r) {
|
||
i = Number(i) || 0;
|
||
var o = t.length - i;
|
||
r ? (r = Number(r)) > o && (r = o) : r = o;
|
||
var n = e.length;
|
||
if (n % 2 != 0) throw new TypeError("Invalid hex string");
|
||
r > n / 2 && (r = n / 2);
|
||
for (var s = 0; s < r; ++s) {
|
||
var a = parseInt(e.substr(2 * s, 2), 16);
|
||
if (isNaN(a)) return s;
|
||
t[i + s] = a
|
||
}
|
||
return s
|
||
}
|
||
|
||
function _(t, e, i, r) {
|
||
return B(z(e, t.length - i), t, i, r)
|
||
}
|
||
|
||
function x(t, e, i, r) {
|
||
return B(function (t) {
|
||
for (var e = [], i = 0; i < t.length; ++i) e.push(255 & t.charCodeAt(i));
|
||
return e
|
||
}(e), t, i, r)
|
||
}
|
||
|
||
function w(t, e, i, r) {
|
||
return x(t, e, i, r)
|
||
}
|
||
|
||
function b(t, e, i, r) {
|
||
return B(U(e), t, i, r)
|
||
}
|
||
|
||
function C(t, e, i, r) {
|
||
return B(function (t, e) {
|
||
for (var i, r, o, n = [], s = 0; s < t.length && !((e -= 2) < 0); ++s) i = t.charCodeAt(s), r = i >> 8, o = i % 256, n.push(o), n.push(r);
|
||
return n
|
||
}(e, t.length - i), t, i, r)
|
||
}
|
||
|
||
function S(t, e, i) {
|
||
return 0 === e && i === t.length ? r.fromByteArray(t) : r.fromByteArray(t.slice(e, i))
|
||
}
|
||
|
||
function E(t, e, i) {
|
||
i = Math.min(t.length, i);
|
||
for (var r = [], o = e; o < i;) {
|
||
var n, s, a, l, h = t[o], u = null, c = h > 239 ? 4 : h > 223 ? 3 : h > 191 ? 2 : 1;
|
||
if (o + c <= i) switch (c) {
|
||
case 1:
|
||
h < 128 && (u = h);
|
||
break;
|
||
case 2:
|
||
128 == (192 & (n = t[o + 1])) && (l = (31 & h) << 6 | 63 & n) > 127 && (u = l);
|
||
break;
|
||
case 3:
|
||
n = t[o + 1], s = t[o + 2], 128 == (192 & n) && 128 == (192 & s) && (l = (15 & h) << 12 | (63 & n) << 6 | 63 & s) > 2047 && (l < 55296 || l > 57343) && (u = l);
|
||
break;
|
||
case 4:
|
||
n = t[o + 1], s = t[o + 2], a = t[o + 3], 128 == (192 & n) && 128 == (192 & s) && 128 == (192 & a) && (l = (15 & h) << 18 | (63 & n) << 12 | (63 & s) << 6 | 63 & a) > 65535 && l < 1114112 && (u = l)
|
||
}
|
||
null === u ? (u = 65533, c = 1) : u > 65535 && (u -= 65536, r.push(u >>> 10 & 1023 | 55296), u = 56320 | 1023 & u), r.push(u), o += c
|
||
}
|
||
return function (t) {
|
||
var e = t.length;
|
||
if (e <= T) return String.fromCharCode.apply(String, t);
|
||
var i = "", r = 0;
|
||
for (; r < e;) i += String.fromCharCode.apply(String, t.slice(r, r += T));
|
||
return i
|
||
}(r)
|
||
}
|
||
|
||
e.Buffer = l, e.SlowBuffer = function (t) {
|
||
+t != t && (t = 0);
|
||
return l.alloc(+t)
|
||
}, e.INSPECT_MAX_BYTES = 50, l.TYPED_ARRAY_SUPPORT = void 0 !== t.TYPED_ARRAY_SUPPORT ? t.TYPED_ARRAY_SUPPORT : function () {
|
||
try {
|
||
var t = new Uint8Array(1);
|
||
return t.__proto__ = {
|
||
__proto__: Uint8Array.prototype, foo: function () {
|
||
return 42
|
||
}
|
||
}, 42 === t.foo() && "function" == typeof t.subarray && 0 === t.subarray(1, 1).byteLength
|
||
} catch (t) {
|
||
return !1
|
||
}
|
||
}(), e.kMaxLength = s(), l.poolSize = 8192, l._augment = function (t) {
|
||
return t.__proto__ = l.prototype, t
|
||
}, l.from = function (t, e, i) {
|
||
return h(null, t, e, i)
|
||
}, l.TYPED_ARRAY_SUPPORT && (l.prototype.__proto__ = Uint8Array.prototype, l.__proto__ = Uint8Array, "undefined" != typeof Symbol && Symbol.species && l[Symbol.species] === l && Object.defineProperty(l, Symbol.species, {
|
||
value: null,
|
||
configurable: !0
|
||
})), l.alloc = function (t, e, i) {
|
||
return function (t, e, i, r) {
|
||
return u(e), e <= 0 ? a(t, e) : void 0 !== i ? "string" == typeof r ? a(t, e).fill(i, r) : a(t, e).fill(i) : a(t, e)
|
||
}(null, t, e, i)
|
||
}, l.allocUnsafe = function (t) {
|
||
return c(null, t)
|
||
}, l.allocUnsafeSlow = function (t) {
|
||
return c(null, t)
|
||
}, l.isBuffer = function (t) {
|
||
return !(null == t || !t._isBuffer)
|
||
}, l.compare = function (t, e) {
|
||
if (!l.isBuffer(t) || !l.isBuffer(e)) throw new TypeError("Arguments must be Buffers");
|
||
if (t === e) return 0;
|
||
for (var i = t.length, r = e.length, o = 0, n = Math.min(i, r); o < n; ++o) if (t[o] !== e[o]) {
|
||
i = t[o], r = e[o];
|
||
break
|
||
}
|
||
return i < r ? -1 : r < i ? 1 : 0
|
||
}, l.isEncoding = function (t) {
|
||
switch (String(t).toLowerCase()) {
|
||
case"hex":
|
||
case"utf8":
|
||
case"utf-8":
|
||
case"ascii":
|
||
case"latin1":
|
||
case"binary":
|
||
case"base64":
|
||
case"ucs2":
|
||
case"ucs-2":
|
||
case"utf16le":
|
||
case"utf-16le":
|
||
return !0;
|
||
default:
|
||
return !1
|
||
}
|
||
}, l.concat = function (t, e) {
|
||
if (!n(t)) throw new TypeError('"list" argument must be an Array of Buffers');
|
||
if (0 === t.length) return l.alloc(0);
|
||
var i;
|
||
if (void 0 === e) for (e = 0, i = 0; i < t.length; ++i) e += t[i].length;
|
||
var r = l.allocUnsafe(e), o = 0;
|
||
for (i = 0; i < t.length; ++i) {
|
||
var s = t[i];
|
||
if (!l.isBuffer(s)) throw new TypeError('"list" argument must be an Array of Buffers');
|
||
s.copy(r, o), o += s.length
|
||
}
|
||
return r
|
||
}, l.byteLength = f, l.prototype._isBuffer = !0, l.prototype.swap16 = function () {
|
||
var t = this.length;
|
||
if (t % 2 != 0) throw new RangeError("Buffer size must be a multiple of 16-bits");
|
||
for (var e = 0; e < t; e += 2) g(this, e, e + 1);
|
||
return this
|
||
}, l.prototype.swap32 = function () {
|
||
var t = this.length;
|
||
if (t % 4 != 0) throw new RangeError("Buffer size must be a multiple of 32-bits");
|
||
for (var e = 0; e < t; e += 4) g(this, e, e + 3), g(this, e + 1, e + 2);
|
||
return this
|
||
}, l.prototype.swap64 = function () {
|
||
var t = this.length;
|
||
if (t % 8 != 0) throw new RangeError("Buffer size must be a multiple of 64-bits");
|
||
for (var e = 0; e < t; e += 8) g(this, e, e + 7), g(this, e + 1, e + 6), g(this, e + 2, e + 5), g(this, e + 3, e + 4);
|
||
return this
|
||
}, l.prototype.toString = function () {
|
||
var t = 0 | this.length;
|
||
return 0 === t ? "" : 0 === arguments.length ? E(this, 0, t) : function (t, e, i) {
|
||
var r = !1;
|
||
if ((void 0 === e || e < 0) && (e = 0), e > this.length) return "";
|
||
if ((void 0 === i || i > this.length) && (i = this.length), i <= 0) return "";
|
||
if ((i >>>= 0) <= (e >>>= 0)) return "";
|
||
for (t || (t = "utf8"); ;) switch (t) {
|
||
case"hex":
|
||
return L(this, e, i);
|
||
case"utf8":
|
||
case"utf-8":
|
||
return E(this, e, i);
|
||
case"ascii":
|
||
return R(this, e, i);
|
||
case"latin1":
|
||
case"binary":
|
||
return P(this, e, i);
|
||
case"base64":
|
||
return S(this, e, i);
|
||
case"ucs2":
|
||
case"ucs-2":
|
||
case"utf16le":
|
||
case"utf-16le":
|
||
return I(this, e, i);
|
||
default:
|
||
if (r) throw new TypeError("Unknown encoding: " + t);
|
||
t = (t + "").toLowerCase(), r = !0
|
||
}
|
||
}.apply(this, arguments)
|
||
}, l.prototype.equals = function (t) {
|
||
if (!l.isBuffer(t)) throw new TypeError("Argument must be a Buffer");
|
||
return this === t || 0 === l.compare(this, t)
|
||
}, l.prototype.inspect = function () {
|
||
var t = "", i = e.INSPECT_MAX_BYTES;
|
||
return this.length > 0 && (t = this.toString("hex", 0, i).match(/.{2}/g).join(" "), this.length > i && (t += " ... ")), "<Buffer " + t + ">"
|
||
}, l.prototype.compare = function (t, e, i, r, o) {
|
||
if (!l.isBuffer(t)) throw new TypeError("Argument must be a Buffer");
|
||
if (void 0 === e && (e = 0), void 0 === i && (i = t ? t.length : 0), void 0 === r && (r = 0), void 0 === o && (o = this.length), e < 0 || i > t.length || r < 0 || o > this.length) throw new RangeError("out of range index");
|
||
if (r >= o && e >= i) return 0;
|
||
if (r >= o) return -1;
|
||
if (e >= i) return 1;
|
||
if (this === t) return 0;
|
||
for (var n = (o >>>= 0) - (r >>>= 0), s = (i >>>= 0) - (e >>>= 0), a = Math.min(n, s), h = this.slice(r, o), u = t.slice(e, i), c = 0; c < a; ++c) if (h[c] !== u[c]) {
|
||
n = h[c], s = u[c];
|
||
break
|
||
}
|
||
return n < s ? -1 : s < n ? 1 : 0
|
||
}, l.prototype.includes = function (t, e, i) {
|
||
return -1 !== this.indexOf(t, e, i)
|
||
}, l.prototype.indexOf = function (t, e, i) {
|
||
return m(this, t, e, i, !0)
|
||
}, l.prototype.lastIndexOf = function (t, e, i) {
|
||
return m(this, t, e, i, !1)
|
||
}, l.prototype.write = function (t, e, i, r) {
|
||
if (void 0 === e) r = "utf8", i = this.length, e = 0; else if (void 0 === i && "string" == typeof e) r = e, i = this.length, e = 0; else {
|
||
if (!isFinite(e)) throw new Error("Buffer.write(string, encoding, offset[, length]) is no longer supported");
|
||
e |= 0, isFinite(i) ? (i |= 0, void 0 === r && (r = "utf8")) : (r = i, i = void 0)
|
||
}
|
||
var o = this.length - e;
|
||
if ((void 0 === i || i > o) && (i = o), t.length > 0 && (i < 0 || e < 0) || e > this.length) throw new RangeError("Attempt to write outside buffer bounds");
|
||
r || (r = "utf8");
|
||
for (var n = !1; ;) switch (r) {
|
||
case"hex":
|
||
return v(this, t, e, i);
|
||
case"utf8":
|
||
case"utf-8":
|
||
return _(this, t, e, i);
|
||
case"ascii":
|
||
return x(this, t, e, i);
|
||
case"latin1":
|
||
case"binary":
|
||
return w(this, t, e, i);
|
||
case"base64":
|
||
return b(this, t, e, i);
|
||
case"ucs2":
|
||
case"ucs-2":
|
||
case"utf16le":
|
||
case"utf-16le":
|
||
return C(this, t, e, i);
|
||
default:
|
||
if (n) throw new TypeError("Unknown encoding: " + r);
|
||
r = ("" + r).toLowerCase(), n = !0
|
||
}
|
||
}, l.prototype.toJSON = function () {
|
||
return {type: "Buffer", data: Array.prototype.slice.call(this._arr || this, 0)}
|
||
};
|
||
var T = 4096;
|
||
|
||
function R(t, e, i) {
|
||
var r = "";
|
||
i = Math.min(t.length, i);
|
||
for (var o = e; o < i; ++o) r += String.fromCharCode(127 & t[o]);
|
||
return r
|
||
}
|
||
|
||
function P(t, e, i) {
|
||
var r = "";
|
||
i = Math.min(t.length, i);
|
||
for (var o = e; o < i; ++o) r += String.fromCharCode(t[o]);
|
||
return r
|
||
}
|
||
|
||
function L(t, e, i) {
|
||
var r = t.length;
|
||
(!e || e < 0) && (e = 0), (!i || i < 0 || i > r) && (i = r);
|
||
for (var o = "", n = e; n < i; ++n) o += j(t[n]);
|
||
return o
|
||
}
|
||
|
||
function I(t, e, i) {
|
||
for (var r = t.slice(e, i), o = "", n = 0; n < r.length; n += 2) o += String.fromCharCode(r[n] + 256 * r[n + 1]);
|
||
return o
|
||
}
|
||
|
||
function O(t, e, i) {
|
||
if (t % 1 != 0 || t < 0) throw new RangeError("offset is not uint");
|
||
if (t + e > i) throw new RangeError("Trying to access beyond buffer length")
|
||
}
|
||
|
||
function M(t, e, i, r, o, n) {
|
||
if (!l.isBuffer(t)) throw new TypeError('"buffer" argument must be a Buffer instance');
|
||
if (e > o || e < n) throw new RangeError('"value" argument is out of bounds');
|
||
if (i + r > t.length) throw new RangeError("Index out of range")
|
||
}
|
||
|
||
function A(t, e, i, r) {
|
||
e < 0 && (e = 65535 + e + 1);
|
||
for (var o = 0, n = Math.min(t.length - i, 2); o < n; ++o) t[i + o] = (e & 255 << 8 * (r ? o : 1 - o)) >>> 8 * (r ? o : 1 - o)
|
||
}
|
||
|
||
function k(t, e, i, r) {
|
||
e < 0 && (e = 4294967295 + e + 1);
|
||
for (var o = 0, n = Math.min(t.length - i, 4); o < n; ++o) t[i + o] = e >>> 8 * (r ? o : 3 - o) & 255
|
||
}
|
||
|
||
function F(t, e, i, r, o, n) {
|
||
if (i + r > t.length) throw new RangeError("Index out of range");
|
||
if (i < 0) throw new RangeError("Index out of range")
|
||
}
|
||
|
||
function N(t, e, i, r, n) {
|
||
return n || F(t, 0, i, 4), o.write(t, e, i, r, 23, 4), i + 4
|
||
}
|
||
|
||
function D(t, e, i, r, n) {
|
||
return n || F(t, 0, i, 8), o.write(t, e, i, r, 52, 8), i + 8
|
||
}
|
||
|
||
l.prototype.slice = function (t, e) {
|
||
var i, r = this.length;
|
||
if ((t = ~~t) < 0 ? (t += r) < 0 && (t = 0) : t > r && (t = r), (e = void 0 === e ? r : ~~e) < 0 ? (e += r) < 0 && (e = 0) : e > r && (e = r), e < t && (e = t), l.TYPED_ARRAY_SUPPORT) (i = this.subarray(t, e)).__proto__ = l.prototype; else {
|
||
var o = e - t;
|
||
i = new l(o, void 0);
|
||
for (var n = 0; n < o; ++n) i[n] = this[n + t]
|
||
}
|
||
return i
|
||
}, l.prototype.readUIntLE = function (t, e, i) {
|
||
t |= 0, e |= 0, i || O(t, e, this.length);
|
||
for (var r = this[t], o = 1, n = 0; ++n < e && (o *= 256);) r += this[t + n] * o;
|
||
return r
|
||
}, l.prototype.readUIntBE = function (t, e, i) {
|
||
t |= 0, e |= 0, i || O(t, e, this.length);
|
||
for (var r = this[t + --e], o = 1; e > 0 && (o *= 256);) r += this[t + --e] * o;
|
||
return r
|
||
}, l.prototype.readUInt8 = function (t, e) {
|
||
return e || O(t, 1, this.length), this[t]
|
||
}, l.prototype.readUInt16LE = function (t, e) {
|
||
return e || O(t, 2, this.length), this[t] | this[t + 1] << 8
|
||
}, l.prototype.readUInt16BE = function (t, e) {
|
||
return e || O(t, 2, this.length), this[t] << 8 | this[t + 1]
|
||
}, l.prototype.readUInt32LE = function (t, e) {
|
||
return e || O(t, 4, this.length), (this[t] | this[t + 1] << 8 | this[t + 2] << 16) + 16777216 * this[t + 3]
|
||
}, l.prototype.readUInt32BE = function (t, e) {
|
||
return e || O(t, 4, this.length), 16777216 * this[t] + (this[t + 1] << 16 | this[t + 2] << 8 | this[t + 3])
|
||
}, l.prototype.readIntLE = function (t, e, i) {
|
||
t |= 0, e |= 0, i || O(t, e, this.length);
|
||
for (var r = this[t], o = 1, n = 0; ++n < e && (o *= 256);) r += this[t + n] * o;
|
||
return r >= (o *= 128) && (r -= Math.pow(2, 8 * e)), r
|
||
}, l.prototype.readIntBE = function (t, e, i) {
|
||
t |= 0, e |= 0, i || O(t, e, this.length);
|
||
for (var r = e, o = 1, n = this[t + --r]; r > 0 && (o *= 256);) n += this[t + --r] * o;
|
||
return n >= (o *= 128) && (n -= Math.pow(2, 8 * e)), n
|
||
}, l.prototype.readInt8 = function (t, e) {
|
||
return e || O(t, 1, this.length), 128 & this[t] ? -1 * (255 - this[t] + 1) : this[t]
|
||
}, l.prototype.readInt16LE = function (t, e) {
|
||
e || O(t, 2, this.length);
|
||
var i = this[t] | this[t + 1] << 8;
|
||
return 32768 & i ? 4294901760 | i : i
|
||
}, l.prototype.readInt16BE = function (t, e) {
|
||
e || O(t, 2, this.length);
|
||
var i = this[t + 1] | this[t] << 8;
|
||
return 32768 & i ? 4294901760 | i : i
|
||
}, l.prototype.readInt32LE = function (t, e) {
|
||
return e || O(t, 4, this.length), this[t] | this[t + 1] << 8 | this[t + 2] << 16 | this[t + 3] << 24
|
||
}, l.prototype.readInt32BE = function (t, e) {
|
||
return e || O(t, 4, this.length), this[t] << 24 | this[t + 1] << 16 | this[t + 2] << 8 | this[t + 3]
|
||
}, l.prototype.readFloatLE = function (t, e) {
|
||
return e || O(t, 4, this.length), o.read(this, t, !0, 23, 4)
|
||
}, l.prototype.readFloatBE = function (t, e) {
|
||
return e || O(t, 4, this.length), o.read(this, t, !1, 23, 4)
|
||
}, l.prototype.readDoubleLE = function (t, e) {
|
||
return e || O(t, 8, this.length), o.read(this, t, !0, 52, 8)
|
||
}, l.prototype.readDoubleBE = function (t, e) {
|
||
return e || O(t, 8, this.length), o.read(this, t, !1, 52, 8)
|
||
}, l.prototype.writeUIntLE = function (t, e, i, r) {
|
||
(t = +t, e |= 0, i |= 0, r) || M(this, t, e, i, Math.pow(2, 8 * i) - 1, 0);
|
||
var o = 1, n = 0;
|
||
for (this[e] = 255 & t; ++n < i && (o *= 256);) this[e + n] = t / o & 255;
|
||
return e + i
|
||
}, l.prototype.writeUIntBE = function (t, e, i, r) {
|
||
(t = +t, e |= 0, i |= 0, r) || M(this, t, e, i, Math.pow(2, 8 * i) - 1, 0);
|
||
var o = i - 1, n = 1;
|
||
for (this[e + o] = 255 & t; --o >= 0 && (n *= 256);) this[e + o] = t / n & 255;
|
||
return e + i
|
||
}, l.prototype.writeUInt8 = function (t, e, i) {
|
||
return t = +t, e |= 0, i || M(this, t, e, 1, 255, 0), l.TYPED_ARRAY_SUPPORT || (t = Math.floor(t)), this[e] = 255 & t, e + 1
|
||
}, l.prototype.writeUInt16LE = function (t, e, i) {
|
||
return t = +t, e |= 0, i || M(this, t, e, 2, 65535, 0), l.TYPED_ARRAY_SUPPORT ? (this[e] = 255 & t, this[e + 1] = t >>> 8) : A(this, t, e, !0), e + 2
|
||
}, l.prototype.writeUInt16BE = function (t, e, i) {
|
||
return t = +t, e |= 0, i || M(this, t, e, 2, 65535, 0), l.TYPED_ARRAY_SUPPORT ? (this[e] = t >>> 8, this[e + 1] = 255 & t) : A(this, t, e, !1), e + 2
|
||
}, l.prototype.writeUInt32LE = function (t, e, i) {
|
||
return t = +t, e |= 0, i || M(this, t, e, 4, 4294967295, 0), l.TYPED_ARRAY_SUPPORT ? (this[e + 3] = t >>> 24, this[e + 2] = t >>> 16, this[e + 1] = t >>> 8, this[e] = 255 & t) : k(this, t, e, !0), e + 4
|
||
}, l.prototype.writeUInt32BE = function (t, e, i) {
|
||
return t = +t, e |= 0, i || M(this, t, e, 4, 4294967295, 0), l.TYPED_ARRAY_SUPPORT ? (this[e] = t >>> 24, this[e + 1] = t >>> 16, this[e + 2] = t >>> 8, this[e + 3] = 255 & t) : k(this, t, e, !1), e + 4
|
||
}, l.prototype.writeIntLE = function (t, e, i, r) {
|
||
if (t = +t, e |= 0, !r) {
|
||
var o = Math.pow(2, 8 * i - 1);
|
||
M(this, t, e, i, o - 1, -o)
|
||
}
|
||
var n = 0, s = 1, a = 0;
|
||
for (this[e] = 255 & t; ++n < i && (s *= 256);) t < 0 && 0 === a && 0 !== this[e + n - 1] && (a = 1), this[e + n] = (t / s >> 0) - a & 255;
|
||
return e + i
|
||
}, l.prototype.writeIntBE = function (t, e, i, r) {
|
||
if (t = +t, e |= 0, !r) {
|
||
var o = Math.pow(2, 8 * i - 1);
|
||
M(this, t, e, i, o - 1, -o)
|
||
}
|
||
var n = i - 1, s = 1, a = 0;
|
||
for (this[e + n] = 255 & t; --n >= 0 && (s *= 256);) t < 0 && 0 === a && 0 !== this[e + n + 1] && (a = 1), this[e + n] = (t / s >> 0) - a & 255;
|
||
return e + i
|
||
}, l.prototype.writeInt8 = function (t, e, i) {
|
||
return t = +t, e |= 0, i || M(this, t, e, 1, 127, -128), l.TYPED_ARRAY_SUPPORT || (t = Math.floor(t)), t < 0 && (t = 255 + t + 1), this[e] = 255 & t, e + 1
|
||
}, l.prototype.writeInt16LE = function (t, e, i) {
|
||
return t = +t, e |= 0, i || M(this, t, e, 2, 32767, -32768), l.TYPED_ARRAY_SUPPORT ? (this[e] = 255 & t, this[e + 1] = t >>> 8) : A(this, t, e, !0), e + 2
|
||
}, l.prototype.writeInt16BE = function (t, e, i) {
|
||
return t = +t, e |= 0, i || M(this, t, e, 2, 32767, -32768), l.TYPED_ARRAY_SUPPORT ? (this[e] = t >>> 8, this[e + 1] = 255 & t) : A(this, t, e, !1), e + 2
|
||
}, l.prototype.writeInt32LE = function (t, e, i) {
|
||
return t = +t, e |= 0, i || M(this, t, e, 4, 2147483647, -2147483648), l.TYPED_ARRAY_SUPPORT ? (this[e] = 255 & t, this[e + 1] = t >>> 8, this[e + 2] = t >>> 16, this[e + 3] = t >>> 24) : k(this, t, e, !0), e + 4
|
||
}, l.prototype.writeInt32BE = function (t, e, i) {
|
||
return t = +t, e |= 0, i || M(this, t, e, 4, 2147483647, -2147483648), t < 0 && (t = 4294967295 + t + 1), l.TYPED_ARRAY_SUPPORT ? (this[e] = t >>> 24, this[e + 1] = t >>> 16, this[e + 2] = t >>> 8, this[e + 3] = 255 & t) : k(this, t, e, !1), e + 4
|
||
}, l.prototype.writeFloatLE = function (t, e, i) {
|
||
return N(this, t, e, !0, i)
|
||
}, l.prototype.writeFloatBE = function (t, e, i) {
|
||
return N(this, t, e, !1, i)
|
||
}, l.prototype.writeDoubleLE = function (t, e, i) {
|
||
return D(this, t, e, !0, i)
|
||
}, l.prototype.writeDoubleBE = function (t, e, i) {
|
||
return D(this, t, e, !1, i)
|
||
}, l.prototype.copy = function (t, e, i, r) {
|
||
if (i || (i = 0), r || 0 === r || (r = this.length), e >= t.length && (e = t.length), e || (e = 0), r > 0 && r < i && (r = i), r === i) return 0;
|
||
if (0 === t.length || 0 === this.length) return 0;
|
||
if (e < 0) throw new RangeError("targetStart out of bounds");
|
||
if (i < 0 || i >= this.length) throw new RangeError("sourceStart out of bounds");
|
||
if (r < 0) throw new RangeError("sourceEnd out of bounds");
|
||
r > this.length && (r = this.length), t.length - e < r - i && (r = t.length - e + i);
|
||
var o, n = r - i;
|
||
if (this === t && i < e && e < r) for (o = n - 1; o >= 0; --o) t[o + e] = this[o + i]; else if (n < 1e3 || !l.TYPED_ARRAY_SUPPORT) for (o = 0; o < n; ++o) t[o + e] = this[o + i]; else Uint8Array.prototype.set.call(t, this.subarray(i, i + n), e);
|
||
return n
|
||
}, l.prototype.fill = function (t, e, i, r) {
|
||
if ("string" == typeof t) {
|
||
if ("string" == typeof e ? (r = e, e = 0, i = this.length) : "string" == typeof i && (r = i, i = this.length), 1 === t.length) {
|
||
var o = t.charCodeAt(0);
|
||
o < 256 && (t = o)
|
||
}
|
||
if (void 0 !== r && "string" != typeof r) throw new TypeError("encoding must be a string");
|
||
if ("string" == typeof r && !l.isEncoding(r)) throw new TypeError("Unknown encoding: " + r)
|
||
} else "number" == typeof t && (t &= 255);
|
||
if (e < 0 || this.length < e || this.length < i) throw new RangeError("Out of range index");
|
||
if (i <= e) return this;
|
||
var n;
|
||
if (e >>>= 0, i = void 0 === i ? this.length : i >>> 0, t || (t = 0), "number" == typeof t) for (n = e; n < i; ++n) this[n] = t; else {
|
||
var s = l.isBuffer(t) ? t : z(new l(t, r).toString()), a = s.length;
|
||
for (n = 0; n < i - e; ++n) this[n + e] = s[n % a]
|
||
}
|
||
return this
|
||
};
|
||
var G = /[^+\/0-9A-Za-z-_]/g;
|
||
|
||
function j(t) {
|
||
return t < 16 ? "0" + t.toString(16) : t.toString(16)
|
||
}
|
||
|
||
function z(t, e) {
|
||
var i;
|
||
e = e || 1 / 0;
|
||
for (var r = t.length, o = null, n = [], s = 0; s < r; ++s) {
|
||
if ((i = t.charCodeAt(s)) > 55295 && i < 57344) {
|
||
if (!o) {
|
||
if (i > 56319) {
|
||
(e -= 3) > -1 && n.push(239, 191, 189);
|
||
continue
|
||
}
|
||
if (s + 1 === r) {
|
||
(e -= 3) > -1 && n.push(239, 191, 189);
|
||
continue
|
||
}
|
||
o = i;
|
||
continue
|
||
}
|
||
if (i < 56320) {
|
||
(e -= 3) > -1 && n.push(239, 191, 189), o = i;
|
||
continue
|
||
}
|
||
i = 65536 + (o - 55296 << 10 | i - 56320)
|
||
} else o && (e -= 3) > -1 && n.push(239, 191, 189);
|
||
if (o = null, i < 128) {
|
||
if ((e -= 1) < 0) break;
|
||
n.push(i)
|
||
} else if (i < 2048) {
|
||
if ((e -= 2) < 0) break;
|
||
n.push(i >> 6 | 192, 63 & i | 128)
|
||
} else if (i < 65536) {
|
||
if ((e -= 3) < 0) break;
|
||
n.push(i >> 12 | 224, i >> 6 & 63 | 128, 63 & i | 128)
|
||
} else {
|
||
if (!(i < 1114112)) throw new Error("Invalid code point");
|
||
if ((e -= 4) < 0) break;
|
||
n.push(i >> 18 | 240, i >> 12 & 63 | 128, i >> 6 & 63 | 128, 63 & i | 128)
|
||
}
|
||
}
|
||
return n
|
||
}
|
||
|
||
function U(t) {
|
||
return r.toByteArray(function (t) {
|
||
if ((t = function (t) {
|
||
return t.trim ? t.trim() : t.replace(/^\s+|\s+$/g, "")
|
||
}(t).replace(G, "")).length < 2) return "";
|
||
for (; t.length % 4 != 0;) t += "=";
|
||
return t
|
||
}(t))
|
||
}
|
||
|
||
function B(t, e, i, r) {
|
||
for (var o = 0; o < r && !(o + i >= e.length || o >= t.length); ++o) e[o + i] = t[o];
|
||
return o
|
||
}
|
||
}).call(this, i(8))
|
||
}, function (t, e, i) {
|
||
"use strict";
|
||
e.byteLength = function (t) {
|
||
var e = h(t), i = e[0], r = e[1];
|
||
return 3 * (i + r) / 4 - r
|
||
}, e.toByteArray = function (t) {
|
||
for (var e, i = h(t), r = i[0], s = i[1], a = new n(function (t, e, i) {
|
||
return 3 * (e + i) / 4 - i
|
||
}(0, r, s)), l = 0, u = s > 0 ? r - 4 : r, c = 0; c < u; c += 4) e = o[t.charCodeAt(c)] << 18 | o[t.charCodeAt(c + 1)] << 12 | o[t.charCodeAt(c + 2)] << 6 | o[t.charCodeAt(c + 3)], a[l++] = e >> 16 & 255, a[l++] = e >> 8 & 255, a[l++] = 255 & e;
|
||
2 === s && (e = o[t.charCodeAt(c)] << 2 | o[t.charCodeAt(c + 1)] >> 4, a[l++] = 255 & e);
|
||
1 === s && (e = o[t.charCodeAt(c)] << 10 | o[t.charCodeAt(c + 1)] << 4 | o[t.charCodeAt(c + 2)] >> 2, a[l++] = e >> 8 & 255, a[l++] = 255 & e);
|
||
return a
|
||
}, e.fromByteArray = function (t) {
|
||
for (var e, i = t.length, o = i % 3, n = [], s = 0, a = i - o; s < a; s += 16383) n.push(u(t, s, s + 16383 > a ? a : s + 16383));
|
||
1 === o ? (e = t[i - 1], n.push(r[e >> 2] + r[e << 4 & 63] + "==")) : 2 === o && (e = (t[i - 2] << 8) + t[i - 1], n.push(r[e >> 10] + r[e >> 4 & 63] + r[e << 2 & 63] + "="));
|
||
return n.join("")
|
||
};
|
||
for (var r = [], o = [], n = "undefined" != typeof Uint8Array ? Uint8Array : Array, s = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", a = 0, l = s.length; a < l; ++a) r[a] = s[a], o[s.charCodeAt(a)] = a;
|
||
|
||
function h(t) {
|
||
var e = t.length;
|
||
if (e % 4 > 0) throw new Error("Invalid string. Length must be a multiple of 4");
|
||
var i = t.indexOf("=");
|
||
return -1 === i && (i = e), [i, i === e ? 0 : 4 - i % 4]
|
||
}
|
||
|
||
function u(t, e, i) {
|
||
for (var o, n, s = [], a = e; a < i; a += 3) o = (t[a] << 16 & 16711680) + (t[a + 1] << 8 & 65280) + (255 & t[a + 2]), s.push(r[(n = o) >> 18 & 63] + r[n >> 12 & 63] + r[n >> 6 & 63] + r[63 & n]);
|
||
return s.join("")
|
||
}
|
||
|
||
o["-".charCodeAt(0)] = 62, o["_".charCodeAt(0)] = 63
|
||
}, function (t, e) {
|
||
var i = {}.toString;
|
||
t.exports = Array.isArray || function (t) {
|
||
return "[object Array]" == i.call(t)
|
||
}
|
||
}, function (t, e, i) {
|
||
"use strict";
|
||
i.r(e);
|
||
var r = {};
|
||
i.r(r), i.d(r, "TEXTAREA", function () {
|
||
return LE
|
||
}), i.d(r, "ARC", function () {
|
||
return IE
|
||
}), i.d(r, "CURVE", function () {
|
||
return OE
|
||
}), i.d(r, "GATHERING_PLACE", function () {
|
||
return ME
|
||
}), i.d(r, "POLYLINE", function () {
|
||
return AE
|
||
}), i.d(r, "FREEHANDLINE", function () {
|
||
return kE
|
||
}), i.d(r, "POINT", function () {
|
||
return FE
|
||
}), i.d(r, "PENNANT", function () {
|
||
return NE
|
||
}), i.d(r, "RECTANGLE", function () {
|
||
return DE
|
||
}), i.d(r, "CIRCLE", function () {
|
||
return GE
|
||
}), i.d(r, "ELLIPSE", function () {
|
||
return jE
|
||
}), i.d(r, "LUNE", function () {
|
||
return zE
|
||
}), i.d(r, "SECTOR", function () {
|
||
return UE
|
||
}), i.d(r, "CLOSED_CURVE", function () {
|
||
return BE
|
||
}), i.d(r, "POLYGON", function () {
|
||
return VE
|
||
}), i.d(r, "FREE_POLYGON", function () {
|
||
return YE
|
||
}), i.d(r, "ATTACK_ARROW", function () {
|
||
return WE
|
||
}), i.d(r, "DOUBLE_ARROW", function () {
|
||
return HE
|
||
}), i.d(r, "STRAIGHT_ARROW", function () {
|
||
return XE
|
||
}), i.d(r, "FINE_ARROW", function () {
|
||
return qE
|
||
}), i.d(r, "ASSAULT_DIRECTION", function () {
|
||
return ZE
|
||
}), i.d(r, "TAILED_SQUAD_COMBAT", function () {
|
||
return $E
|
||
}), i.d(r, "TAILED_ATTACK_ARROW", function () {
|
||
return KE
|
||
}), i.d(r, "SQUAD_COMBAT", function () {
|
||
return JE
|
||
}), i.d(r, "RECTFLAG", function () {
|
||
return QE
|
||
}), i.d(r, "TRIANGLEFLAG", function () {
|
||
return tT
|
||
}), i.d(r, "CURVEFLAG", function () {
|
||
return eT
|
||
});
|
||
var o = {};
|
||
|
||
function n() {
|
||
return function () {
|
||
throw new Error("Unimplemented abstract method.")
|
||
}()
|
||
}
|
||
|
||
i.r(o), i.d(o, "Point", function () {
|
||
return iT
|
||
}), i.d(o, "Pennant", function () {
|
||
return rT
|
||
}), i.d(o, "Polyline", function () {
|
||
return oT
|
||
}), i.d(o, "Arc", function () {
|
||
return nT
|
||
}), i.d(o, "Circle", function () {
|
||
return sT
|
||
}), i.d(o, "Curve", function () {
|
||
return aT
|
||
}), i.d(o, "FreeHandLine", function () {
|
||
return lT
|
||
}), i.d(o, "RectAngle", function () {
|
||
return hT
|
||
}), i.d(o, "Ellipse", function () {
|
||
return uT
|
||
}), i.d(o, "Lune", function () {
|
||
return cT
|
||
}), i.d(o, "Sector", function () {
|
||
return pT
|
||
}), i.d(o, "ClosedCurve", function () {
|
||
return dT
|
||
}), i.d(o, "Polygon", function () {
|
||
return fT
|
||
}), i.d(o, "FreePolygon", function () {
|
||
return gT
|
||
}), i.d(o, "AttackArrow", function () {
|
||
return mT
|
||
}), i.d(o, "DoubleArrow", function () {
|
||
return yT
|
||
}), i.d(o, "StraightArrow", function () {
|
||
return vT
|
||
}), i.d(o, "FineArrow", function () {
|
||
return _T
|
||
}), i.d(o, "AssaultDirection", function () {
|
||
return xT
|
||
}), i.d(o, "TailedAttackArrow", function () {
|
||
return wT
|
||
}), i.d(o, "SquadCombat", function () {
|
||
return bT
|
||
}), i.d(o, "TailedSquadCombat", function () {
|
||
return CT
|
||
}), i.d(o, "GatheringPlace", function () {
|
||
return ST
|
||
}), i.d(o, "RectFlag", function () {
|
||
return ET
|
||
}), i.d(o, "TriangleFlag", function () {
|
||
return TT
|
||
}), i.d(o, "CurveFlag", function () {
|
||
return RT
|
||
}), i.d(o, "PlotTextBox", function () {
|
||
return PE
|
||
});
|
||
var s = 0;
|
||
|
||
function a(t) {
|
||
return t.ol_uid || (t.ol_uid = String(++s))
|
||
}
|
||
|
||
var l = "5.3.2", h = function (t) {
|
||
function e(e) {
|
||
var i = "Assertion failed. See https://openlayers.org/en/" + ("latest" === l ? l : "v" + l.split("-")[0]) + "/doc/errors/#" + e + " for details.";
|
||
t.call(this, i), this.code = e, this.name = "AssertionError", this.message = i
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(Error), u = {ADD: "add", REMOVE: "remove"}, c = {PROPERTYCHANGE: "propertychange"},
|
||
p = "function" == typeof Object.assign ? Object.assign : function (t, e) {
|
||
var i = arguments;
|
||
if (null == t) throw new TypeError("Cannot convert undefined or null to object");
|
||
for (var r = Object(t), o = 1, n = arguments.length; o < n; ++o) {
|
||
var s = i[o];
|
||
if (null != s) for (var a in s) s.hasOwnProperty(a) && (r[a] = s[a])
|
||
}
|
||
return r
|
||
};
|
||
|
||
function d(t) {
|
||
for (var e in t) delete t[e]
|
||
}
|
||
|
||
function f(t) {
|
||
var e = [];
|
||
for (var i in t) e.push(t[i]);
|
||
return e
|
||
}
|
||
|
||
function g(t) {
|
||
var e;
|
||
for (e in t) return !1;
|
||
return !e
|
||
}
|
||
|
||
function m(t) {
|
||
var e = function (e) {
|
||
var i = t.listener, r = t.bindTo || t.target;
|
||
return t.callOnce && S(t), i.call(r, e)
|
||
};
|
||
return t.boundListener = e, e
|
||
}
|
||
|
||
function y(t, e, i, r) {
|
||
for (var o, n = 0, s = t.length; n < s; ++n) if ((o = t[n]).listener === e && o.bindTo === i) return r && (o.deleteIndex = n), o
|
||
}
|
||
|
||
function v(t, e) {
|
||
var i = _(t);
|
||
return i ? i[e] : void 0
|
||
}
|
||
|
||
function _(t, e) {
|
||
var i = t.ol_lm;
|
||
return !i && e && (i = t.ol_lm = {}), i
|
||
}
|
||
|
||
function x(t, e) {
|
||
var i = v(t, e);
|
||
if (i) {
|
||
for (var r = 0, o = i.length; r < o; ++r) t.removeEventListener(e, i[r].boundListener), d(i[r]);
|
||
i.length = 0;
|
||
var n = _(t);
|
||
n && (delete n[e], 0 === Object.keys(n).length && function (t) {
|
||
delete t.ol_lm
|
||
}(t))
|
||
}
|
||
}
|
||
|
||
function w(t, e, i, r, o) {
|
||
var n = _(t, !0), s = n[e];
|
||
s || (s = n[e] = []);
|
||
var a = y(s, i, r, !1);
|
||
return a ? o || (a.callOnce = !1) : (a = {
|
||
bindTo: r,
|
||
callOnce: !!o,
|
||
listener: i,
|
||
target: t,
|
||
type: e
|
||
}, t.addEventListener(e, m(a)), s.push(a)), a
|
||
}
|
||
|
||
function b(t, e, i, r) {
|
||
return w(t, e, i, r, !0)
|
||
}
|
||
|
||
function C(t, e, i, r) {
|
||
var o = v(t, e);
|
||
if (o) {
|
||
var n = y(o, i, r, !0);
|
||
n && S(n)
|
||
}
|
||
}
|
||
|
||
function S(t) {
|
||
if (t && t.target) {
|
||
t.target.removeEventListener(t.type, t.boundListener);
|
||
var e = v(t.target, t.type);
|
||
if (e) {
|
||
var i = "deleteIndex" in t ? t.deleteIndex : e.indexOf(t);
|
||
-1 !== i && e.splice(i, 1), 0 === e.length && x(t.target, t.type)
|
||
}
|
||
d(t)
|
||
}
|
||
}
|
||
|
||
function E(t) {
|
||
var e = _(t);
|
||
if (e) for (var i in e) x(t, i)
|
||
}
|
||
|
||
var T = function () {
|
||
this.disposed_ = !1
|
||
};
|
||
T.prototype.dispose = function () {
|
||
this.disposed_ || (this.disposed_ = !0, this.disposeInternal())
|
||
}, T.prototype.disposeInternal = function () {
|
||
};
|
||
var R = T;
|
||
|
||
function P() {
|
||
return !0
|
||
}
|
||
|
||
function L() {
|
||
return !1
|
||
}
|
||
|
||
function I() {
|
||
}
|
||
|
||
var O = function (t) {
|
||
this.propagationStopped, this.type = t, this.target = null
|
||
};
|
||
|
||
function M(t) {
|
||
t.stopPropagation()
|
||
}
|
||
|
||
O.prototype.preventDefault = function () {
|
||
this.propagationStopped = !0
|
||
}, O.prototype.stopPropagation = function () {
|
||
this.propagationStopped = !0
|
||
};
|
||
var A = O, k = function (t) {
|
||
function e() {
|
||
t.call(this), this.pendingRemovals_ = {}, this.dispatching_ = {}, this.listeners_ = {}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.addEventListener = function (t, e) {
|
||
var i = this.listeners_[t];
|
||
i || (i = this.listeners_[t] = []), -1 === i.indexOf(e) && i.push(e)
|
||
}, e.prototype.dispatchEvent = function (t) {
|
||
var e = "string" == typeof t ? new A(t) : t, i = e.type;
|
||
e.target = this;
|
||
var r, o = this.listeners_[i];
|
||
if (o) {
|
||
i in this.dispatching_ || (this.dispatching_[i] = 0, this.pendingRemovals_[i] = 0), ++this.dispatching_[i];
|
||
for (var n = 0, s = o.length; n < s; ++n) if (!1 === o[n].call(this, e) || e.propagationStopped) {
|
||
r = !1;
|
||
break
|
||
}
|
||
if (--this.dispatching_[i], 0 === this.dispatching_[i]) {
|
||
var a = this.pendingRemovals_[i];
|
||
for (delete this.pendingRemovals_[i]; a--;) this.removeEventListener(i, I);
|
||
delete this.dispatching_[i]
|
||
}
|
||
return r
|
||
}
|
||
}, e.prototype.disposeInternal = function () {
|
||
E(this)
|
||
}, e.prototype.getListeners = function (t) {
|
||
return this.listeners_[t]
|
||
}, e.prototype.hasListener = function (t) {
|
||
return t ? t in this.listeners_ : Object.keys(this.listeners_).length > 0
|
||
}, e.prototype.removeEventListener = function (t, e) {
|
||
var i = this.listeners_[t];
|
||
if (i) {
|
||
var r = i.indexOf(e);
|
||
t in this.pendingRemovals_ ? (i[r] = I, ++this.pendingRemovals_[t]) : (i.splice(r, 1), 0 === i.length && delete this.listeners_[t])
|
||
}
|
||
}, e
|
||
}(R), F = {
|
||
CHANGE: "change",
|
||
CLEAR: "clear",
|
||
CONTEXTMENU: "contextmenu",
|
||
CLICK: "click",
|
||
DBLCLICK: "dblclick",
|
||
DRAGENTER: "dragenter",
|
||
DRAGOVER: "dragover",
|
||
DROP: "drop",
|
||
ERROR: "error",
|
||
KEYDOWN: "keydown",
|
||
KEYPRESS: "keypress",
|
||
LOAD: "load",
|
||
MOUSEDOWN: "mousedown",
|
||
MOUSEMOVE: "mousemove",
|
||
MOUSEOUT: "mouseout",
|
||
MOUSEUP: "mouseup",
|
||
MOUSEWHEEL: "mousewheel",
|
||
MSPOINTERDOWN: "MSPointerDown",
|
||
RESIZE: "resize",
|
||
TOUCHSTART: "touchstart",
|
||
TOUCHMOVE: "touchmove",
|
||
TOUCHEND: "touchend",
|
||
WHEEL: "wheel"
|
||
};
|
||
|
||
function N(t) {
|
||
if (Array.isArray(t)) for (var e = 0, i = t.length; e < i; ++e) S(t[e]); else S(t)
|
||
}
|
||
|
||
var D = function (t) {
|
||
function e() {
|
||
t.call(this), this.revision_ = 0
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.changed = function () {
|
||
++this.revision_, this.dispatchEvent(F.CHANGE)
|
||
}, e.prototype.getRevision = function () {
|
||
return this.revision_
|
||
}, e.prototype.on = function (t, e) {
|
||
if (Array.isArray(t)) {
|
||
for (var i = t.length, r = new Array(i), o = 0; o < i; ++o) r[o] = w(this, t[o], e);
|
||
return r
|
||
}
|
||
return w(this, t, e)
|
||
}, e.prototype.once = function (t, e) {
|
||
if (Array.isArray(t)) {
|
||
for (var i = t.length, r = new Array(i), o = 0; o < i; ++o) r[o] = b(this, t[o], e);
|
||
return r
|
||
}
|
||
return b(this, t, e)
|
||
}, e.prototype.un = function (t, e) {
|
||
if (Array.isArray(t)) for (var i = 0, r = t.length; i < r; ++i) C(this, t[i], e); else C(this, t, e)
|
||
}, e
|
||
}(k), G = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, e), this.key = i, this.oldValue = r
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A), j = {};
|
||
|
||
function z(t) {
|
||
return j.hasOwnProperty(t) ? j[t] : j[t] = "change:" + t
|
||
}
|
||
|
||
var U = function (t) {
|
||
function e(e) {
|
||
t.call(this), a(this), this.values_ = {}, void 0 !== e && this.setProperties(e)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.get = function (t) {
|
||
var e;
|
||
return this.values_.hasOwnProperty(t) && (e = this.values_[t]), e
|
||
}, e.prototype.getKeys = function () {
|
||
return Object.keys(this.values_)
|
||
}, e.prototype.getProperties = function () {
|
||
return p({}, this.values_)
|
||
}, e.prototype.notify = function (t, e) {
|
||
var i;
|
||
i = z(t), this.dispatchEvent(new G(i, t, e)), i = c.PROPERTYCHANGE, this.dispatchEvent(new G(i, t, e))
|
||
}, e.prototype.set = function (t, e, i) {
|
||
if (i) this.values_[t] = e; else {
|
||
var r = this.values_[t];
|
||
this.values_[t] = e, r !== e && this.notify(t, r)
|
||
}
|
||
}, e.prototype.setProperties = function (t, e) {
|
||
for (var i in t) this.set(i, t[i], e)
|
||
}, e.prototype.unset = function (t, e) {
|
||
if (t in this.values_) {
|
||
var i = this.values_[t];
|
||
delete this.values_[t], e || this.notify(t, i)
|
||
}
|
||
}, e
|
||
}(D), B = "length", V = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e), this.element = i
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A), Y = function (t) {
|
||
function e(e, i) {
|
||
t.call(this);
|
||
var r = i || {};
|
||
if (this.unique_ = !!r.unique, this.array_ = e || [], this.unique_) for (var o = 0, n = this.array_.length; o < n; ++o) this.assertUnique_(this.array_[o], o);
|
||
this.updateLength_()
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.clear = function () {
|
||
for (; this.getLength() > 0;) this.pop()
|
||
}, e.prototype.extend = function (t) {
|
||
for (var e = 0, i = t.length; e < i; ++e) this.push(t[e]);
|
||
return this
|
||
}, e.prototype.forEach = function (t) {
|
||
for (var e = this.array_, i = 0, r = e.length; i < r; ++i) t(e[i], i, e)
|
||
}, e.prototype.getArray = function () {
|
||
return this.array_
|
||
}, e.prototype.item = function (t) {
|
||
return this.array_[t]
|
||
}, e.prototype.getLength = function () {
|
||
return this.get(B)
|
||
}, e.prototype.insertAt = function (t, e) {
|
||
this.unique_ && this.assertUnique_(e), this.array_.splice(t, 0, e), this.updateLength_(), this.dispatchEvent(new V(u.ADD, e))
|
||
}, e.prototype.pop = function () {
|
||
return this.removeAt(this.getLength() - 1)
|
||
}, e.prototype.push = function (t) {
|
||
this.unique_ && this.assertUnique_(t);
|
||
var e = this.getLength();
|
||
return this.insertAt(e, t), this.getLength()
|
||
}, e.prototype.remove = function (t) {
|
||
for (var e = this.array_, i = 0, r = e.length; i < r; ++i) if (e[i] === t) return this.removeAt(i)
|
||
}, e.prototype.removeAt = function (t) {
|
||
var e = this.array_[t];
|
||
return this.array_.splice(t, 1), this.updateLength_(), this.dispatchEvent(new V(u.REMOVE, e)), e
|
||
}, e.prototype.setAt = function (t, e) {
|
||
var i = this.getLength();
|
||
if (t < i) {
|
||
this.unique_ && this.assertUnique_(e, t);
|
||
var r = this.array_[t];
|
||
this.array_[t] = e, this.dispatchEvent(new V(u.REMOVE, r)), this.dispatchEvent(new V(u.ADD, e))
|
||
} else {
|
||
for (var o = i; o < t; ++o) this.insertAt(o, void 0);
|
||
this.insertAt(t, e)
|
||
}
|
||
}, e.prototype.updateLength_ = function () {
|
||
this.set(B, this.array_.length)
|
||
}, e.prototype.assertUnique_ = function (t, e) {
|
||
for (var i = 0, r = this.array_.length; i < r; ++i) if (this.array_[i] === t && i !== e) throw new h(58)
|
||
}, e
|
||
}(U);
|
||
|
||
function W(t, e) {
|
||
if (!t) throw new h(e)
|
||
}
|
||
|
||
function H(t) {
|
||
return "function" == typeof t ? t : (Array.isArray(t) ? e = t : (W("function" == typeof t.getZIndex, 41), e = [t]), function () {
|
||
return e
|
||
});
|
||
var e
|
||
}
|
||
|
||
var X = function (t) {
|
||
function e(e) {
|
||
if (t.call(this), this.id_ = void 0, this.geometryName_ = "geometry", this.style_ = null, this.styleFunction_ = void 0, this.geometryChangeKey_ = null, w(this, z(this.geometryName_), this.handleGeometryChanged_, this), e) if ("function" == typeof e.getSimplifiedGeometry) {
|
||
var i = e;
|
||
this.setGeometry(i)
|
||
} else {
|
||
var r = e;
|
||
this.setProperties(r)
|
||
}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.clone = function () {
|
||
var t = new e(this.getProperties());
|
||
t.setGeometryName(this.getGeometryName());
|
||
var i = this.getGeometry();
|
||
i && t.setGeometry(i.clone());
|
||
var r = this.getStyle();
|
||
return r && t.setStyle(r), t
|
||
}, e.prototype.getGeometry = function () {
|
||
return this.get(this.geometryName_)
|
||
}, e.prototype.getId = function () {
|
||
return this.id_
|
||
}, e.prototype.getGeometryName = function () {
|
||
return this.geometryName_
|
||
}, e.prototype.getStyle = function () {
|
||
return this.style_
|
||
}, e.prototype.getStyleFunction = function () {
|
||
return this.styleFunction_
|
||
}, e.prototype.handleGeometryChange_ = function () {
|
||
this.changed()
|
||
}, e.prototype.handleGeometryChanged_ = function () {
|
||
this.geometryChangeKey_ && (S(this.geometryChangeKey_), this.geometryChangeKey_ = null);
|
||
var t = this.getGeometry();
|
||
t && (this.geometryChangeKey_ = w(t, F.CHANGE, this.handleGeometryChange_, this)), this.changed()
|
||
}, e.prototype.setGeometry = function (t) {
|
||
this.set(this.geometryName_, t)
|
||
}, e.prototype.setStyle = function (t) {
|
||
this.style_ = t, this.styleFunction_ = t ? H(t) : void 0, this.changed()
|
||
}, e.prototype.setId = function (t) {
|
||
this.id_ = t, this.changed()
|
||
}, e.prototype.setGeometryName = function (t) {
|
||
C(this, z(this.geometryName_), this.handleGeometryChanged_, this), this.geometryName_ = t, w(this, z(this.geometryName_), this.handleGeometryChanged_, this), this.handleGeometryChanged_()
|
||
}, e
|
||
}(U);
|
||
|
||
function q(t, e, i) {
|
||
for (var r, o, n = i || Z, s = 0, a = t.length, l = !1; s < a;) (o = +n(t[r = s + (a - s >> 1)], e)) < 0 ? s = r + 1 : (a = r, l = !o);
|
||
return l ? s : ~s
|
||
}
|
||
|
||
function Z(t, e) {
|
||
return t > e ? 1 : t < e ? -1 : 0
|
||
}
|
||
|
||
function K(t, e) {
|
||
return t.indexOf(e) >= 0
|
||
}
|
||
|
||
function J(t, e, i) {
|
||
var r, o = t.length;
|
||
if (t[0] <= e) return 0;
|
||
if (e <= t[o - 1]) return o - 1;
|
||
if (i > 0) {
|
||
for (r = 1; r < o; ++r) if (t[r] < e) return r - 1
|
||
} else if (i < 0) {
|
||
for (r = 1; r < o; ++r) if (t[r] <= e) return r
|
||
} else for (r = 1; r < o; ++r) {
|
||
if (t[r] == e) return r;
|
||
if (t[r] < e) return t[r - 1] - e < e - t[r] ? r - 1 : r
|
||
}
|
||
return o - 1
|
||
}
|
||
|
||
function $(t, e, i) {
|
||
for (; e < i;) {
|
||
var r = t[e];
|
||
t[e] = t[i], t[i] = r, ++e, --i
|
||
}
|
||
}
|
||
|
||
function Q(t, e) {
|
||
for (var i = Array.isArray(e) ? e : [e], r = i.length, o = 0; o < r; o++) t[t.length] = i[o]
|
||
}
|
||
|
||
function tt(t, e) {
|
||
var i = t.indexOf(e), r = i > -1;
|
||
return r && t.splice(i, 1), r
|
||
}
|
||
|
||
function et(t, e) {
|
||
for (var i, r = t.length >>> 0, o = 0; o < r; o++) if (e(i = t[o], o, t)) return i;
|
||
return null
|
||
}
|
||
|
||
function it(t, e) {
|
||
var i = t.length;
|
||
if (i !== e.length) return !1;
|
||
for (var r = 0; r < i; r++) if (t[r] !== e[r]) return !1;
|
||
return !0
|
||
}
|
||
|
||
function rt(t, e) {
|
||
var i, r = t.length, o = Array(t.length);
|
||
for (i = 0; i < r; i++) o[i] = {index: i, value: t[i]};
|
||
for (o.sort(function (t, i) {
|
||
return e(t.value, i.value) || t.index - i.index
|
||
}), i = 0; i < t.length; i++) t[i] = o[i].value
|
||
}
|
||
|
||
function ot(t, e) {
|
||
var i;
|
||
return !t.every(function (r, o) {
|
||
return i = o, !e(r, o, t)
|
||
}) ? i : -1
|
||
}
|
||
|
||
function nt(t, e, i) {
|
||
var r = e || Z;
|
||
return t.every(function (e, o) {
|
||
if (0 === o) return !0;
|
||
var n = r(t[o - 1], e);
|
||
return !(n > 0 || i && 0 === n)
|
||
})
|
||
}
|
||
|
||
var st = {
|
||
BOTTOM_LEFT: "bottom-left",
|
||
BOTTOM_RIGHT: "bottom-right",
|
||
TOP_LEFT: "top-left",
|
||
TOP_RIGHT: "top-right"
|
||
}, at = {UNKNOWN: 0, INTERSECTING: 1, ABOVE: 2, RIGHT: 4, BELOW: 8, LEFT: 16};
|
||
|
||
function lt(t) {
|
||
for (var e = mt(), i = 0, r = t.length; i < r; ++i) St(e, t[i]);
|
||
return e
|
||
}
|
||
|
||
function ht(t, e, i) {
|
||
return i ? (i[0] = t[0] - e, i[1] = t[1] - e, i[2] = t[2] + e, i[3] = t[3] + e, i) : [t[0] - e, t[1] - e, t[2] + e, t[3] + e]
|
||
}
|
||
|
||
function ut(t, e) {
|
||
return e ? (e[0] = t[0], e[1] = t[1], e[2] = t[2], e[3] = t[3], e) : t.slice()
|
||
}
|
||
|
||
function ct(t, e, i) {
|
||
var r, o;
|
||
return (r = e < t[0] ? t[0] - e : t[2] < e ? e - t[2] : 0) * r + (o = i < t[1] ? t[1] - i : t[3] < i ? i - t[3] : 0) * o
|
||
}
|
||
|
||
function pt(t, e) {
|
||
return ft(t, e[0], e[1])
|
||
}
|
||
|
||
function dt(t, e) {
|
||
return t[0] <= e[0] && e[2] <= t[2] && t[1] <= e[1] && e[3] <= t[3]
|
||
}
|
||
|
||
function ft(t, e, i) {
|
||
return t[0] <= e && e <= t[2] && t[1] <= i && i <= t[3]
|
||
}
|
||
|
||
function gt(t, e) {
|
||
var i = t[0], r = t[1], o = t[2], n = t[3], s = e[0], a = e[1], l = at.UNKNOWN;
|
||
return s < i ? l |= at.LEFT : s > o && (l |= at.RIGHT), a < r ? l |= at.BELOW : a > n && (l |= at.ABOVE), l === at.UNKNOWN && (l = at.INTERSECTING), l
|
||
}
|
||
|
||
function mt() {
|
||
return [1 / 0, 1 / 0, -1 / 0, -1 / 0]
|
||
}
|
||
|
||
function yt(t, e, i, r, o) {
|
||
return o ? (o[0] = t, o[1] = e, o[2] = i, o[3] = r, o) : [t, e, i, r]
|
||
}
|
||
|
||
function vt(t) {
|
||
return yt(1 / 0, 1 / 0, -1 / 0, -1 / 0, t)
|
||
}
|
||
|
||
function _t(t, e) {
|
||
var i = t[0], r = t[1];
|
||
return yt(i, r, i, r, e)
|
||
}
|
||
|
||
function xt(t, e) {
|
||
return Et(vt(e), t)
|
||
}
|
||
|
||
function wt(t, e, i, r, o) {
|
||
return Tt(vt(o), t, e, i, r)
|
||
}
|
||
|
||
function bt(t, e) {
|
||
return t[0] == e[0] && t[2] == e[2] && t[1] == e[1] && t[3] == e[3]
|
||
}
|
||
|
||
function Ct(t, e) {
|
||
return e[0] < t[0] && (t[0] = e[0]), e[2] > t[2] && (t[2] = e[2]), e[1] < t[1] && (t[1] = e[1]), e[3] > t[3] && (t[3] = e[3]), t
|
||
}
|
||
|
||
function St(t, e) {
|
||
e[0] < t[0] && (t[0] = e[0]), e[0] > t[2] && (t[2] = e[0]), e[1] < t[1] && (t[1] = e[1]), e[1] > t[3] && (t[3] = e[1])
|
||
}
|
||
|
||
function Et(t, e) {
|
||
for (var i = 0, r = e.length; i < r; ++i) St(t, e[i]);
|
||
return t
|
||
}
|
||
|
||
function Tt(t, e, i, r, o) {
|
||
for (; i < r; i += o) Pt(t, e[i], e[i + 1]);
|
||
return t
|
||
}
|
||
|
||
function Rt(t, e) {
|
||
for (var i = 0, r = e.length; i < r; ++i) Et(t, e[i]);
|
||
return t
|
||
}
|
||
|
||
function Pt(t, e, i) {
|
||
t[0] = Math.min(t[0], e), t[1] = Math.min(t[1], i), t[2] = Math.max(t[2], e), t[3] = Math.max(t[3], i)
|
||
}
|
||
|
||
function Lt(t, e, i) {
|
||
var r;
|
||
return (r = e.call(i, Ot(t))) ? r : (r = e.call(i, Mt(t))) ? r : (r = e.call(i, zt(t))) ? r : (r = e.call(i, jt(t))) || !1
|
||
}
|
||
|
||
function It(t) {
|
||
var e = 0;
|
||
return Vt(t) || (e = Ut(t) * Nt(t)), e
|
||
}
|
||
|
||
function Ot(t) {
|
||
return [t[0], t[1]]
|
||
}
|
||
|
||
function Mt(t) {
|
||
return [t[2], t[1]]
|
||
}
|
||
|
||
function At(t) {
|
||
return [(t[0] + t[2]) / 2, (t[1] + t[3]) / 2]
|
||
}
|
||
|
||
function kt(t, e) {
|
||
var i;
|
||
return e === st.BOTTOM_LEFT ? i = Ot(t) : e === st.BOTTOM_RIGHT ? i = Mt(t) : e === st.TOP_LEFT ? i = jt(t) : e === st.TOP_RIGHT ? i = zt(t) : W(!1, 13), i
|
||
}
|
||
|
||
function Ft(t, e, i, r, o) {
|
||
var n = e * r[0] / 2, s = e * r[1] / 2, a = Math.cos(i), l = Math.sin(i), h = n * a, u = n * l, c = s * a,
|
||
p = s * l, d = t[0], f = t[1], g = d - h + p, m = d - h - p, y = d + h - p, v = d + h + p,
|
||
_ = f - u - c, x = f - u + c, w = f + u + c, b = f + u - c;
|
||
return yt(Math.min(g, m, y, v), Math.min(_, x, w, b), Math.max(g, m, y, v), Math.max(_, x, w, b), o)
|
||
}
|
||
|
||
function Nt(t) {
|
||
return t[3] - t[1]
|
||
}
|
||
|
||
function Dt(t, e, i) {
|
||
var r = i || [1 / 0, 1 / 0, -1 / 0, -1 / 0];
|
||
return Bt(t, e) ? (t[0] > e[0] ? r[0] = t[0] : r[0] = e[0], t[1] > e[1] ? r[1] = t[1] : r[1] = e[1], t[2] < e[2] ? r[2] = t[2] : r[2] = e[2], t[3] < e[3] ? r[3] = t[3] : r[3] = e[3]) : vt(r), r
|
||
}
|
||
|
||
function Gt(t) {
|
||
return [t[2] - t[0], t[3] - t[1]]
|
||
}
|
||
|
||
function jt(t) {
|
||
return [t[0], t[3]]
|
||
}
|
||
|
||
function zt(t) {
|
||
return [t[2], t[3]]
|
||
}
|
||
|
||
function Ut(t) {
|
||
return t[2] - t[0]
|
||
}
|
||
|
||
function Bt(t, e) {
|
||
return t[0] <= e[2] && t[2] >= e[0] && t[1] <= e[3] && t[3] >= e[1]
|
||
}
|
||
|
||
function Vt(t) {
|
||
return t[2] < t[0] || t[3] < t[1]
|
||
}
|
||
|
||
function Yt(t, e) {
|
||
return e ? (e[0] = t[0], e[1] = t[1], e[2] = t[2], e[3] = t[3], e) : t
|
||
}
|
||
|
||
function Wt(t, e) {
|
||
var i = (t[2] - t[0]) / 2 * (e - 1), r = (t[3] - t[1]) / 2 * (e - 1);
|
||
t[0] -= i, t[2] += i, t[1] -= r, t[3] += r
|
||
}
|
||
|
||
function Ht(t, e, i) {
|
||
var r = !1, o = gt(t, e), n = gt(t, i);
|
||
if (o === at.INTERSECTING || n === at.INTERSECTING) r = !0; else {
|
||
var s, a, l = t[0], h = t[1], u = t[2], c = t[3], p = e[0], d = e[1], f = i[0], g = i[1],
|
||
m = (g - d) / (f - p);
|
||
n & at.ABOVE && !(o & at.ABOVE) && (r = (s = f - (g - c) / m) >= l && s <= u), r || !(n & at.RIGHT) || o & at.RIGHT || (r = (a = g - (f - u) * m) >= h && a <= c), r || !(n & at.BELOW) || o & at.BELOW || (r = (s = f - (g - h) / m) >= l && s <= u), r || !(n & at.LEFT) || o & at.LEFT || (r = (a = g - (f - l) * m) >= h && a <= c)
|
||
}
|
||
return r
|
||
}
|
||
|
||
function Xt(t, e, i) {
|
||
var r = [t[0], t[1], t[0], t[3], t[2], t[1], t[2], t[3]];
|
||
return e(r, r, 2), function (t, e, i) {
|
||
return yt(Math.min.apply(null, t), Math.min.apply(null, e), Math.max.apply(null, t), Math.max.apply(null, e), i)
|
||
}([r[0], r[2], r[4], r[6]], [r[1], r[3], r[5], r[7]], i)
|
||
}
|
||
|
||
var qt = {XY: "XY", XYZ: "XYZ", XYM: "XYM", XYZM: "XYZM"}, Zt = {
|
||
POINT: "Point",
|
||
LINE_STRING: "LineString",
|
||
LINEAR_RING: "LinearRing",
|
||
POLYGON: "Polygon",
|
||
MULTI_POINT: "MultiPoint",
|
||
MULTI_LINE_STRING: "MultiLineString",
|
||
MULTI_POLYGON: "MultiPolygon",
|
||
GEOMETRY_COLLECTION: "GeometryCollection",
|
||
CIRCLE: "Circle"
|
||
};
|
||
|
||
function Kt(t, e, i, r, o, n) {
|
||
for (var s = n || [], a = 0, l = e; l < i; l += r) {
|
||
var h = t[l], u = t[l + 1];
|
||
s[a++] = o[0] * h + o[2] * u + o[4], s[a++] = o[1] * h + o[3] * u + o[5]
|
||
}
|
||
return n && s.length != a && (s.length = a), s
|
||
}
|
||
|
||
function Jt(t, e, i, r, o, n, s) {
|
||
for (var a = s || [], l = Math.cos(o), h = Math.sin(o), u = n[0], c = n[1], p = 0, d = e; d < i; d += r) {
|
||
var f = t[d] - u, g = t[d + 1] - c;
|
||
a[p++] = u + f * l - g * h, a[p++] = c + f * h + g * l;
|
||
for (var m = d + 2; m < d + r; ++m) a[p++] = t[m]
|
||
}
|
||
return s && a.length != p && (a.length = p), a
|
||
}
|
||
|
||
function $t(t, e, i, r, o, n, s, a) {
|
||
for (var l = a || [], h = s[0], u = s[1], c = 0, p = e; p < i; p += r) {
|
||
var d = t[p] - h, f = t[p + 1] - u;
|
||
l[c++] = h + o * d, l[c++] = u + n * f;
|
||
for (var g = p + 2; g < p + r; ++g) l[c++] = t[g]
|
||
}
|
||
return a && l.length != c && (l.length = c), l
|
||
}
|
||
|
||
function Qt(t, e, i, r, o, n, s) {
|
||
for (var a = s || [], l = 0, h = e; h < i; h += r) {
|
||
a[l++] = t[h] + o, a[l++] = t[h + 1] + n;
|
||
for (var u = h + 2; u < h + r; ++u) a[l++] = t[u]
|
||
}
|
||
return s && a.length != l && (a.length = l), a
|
||
}
|
||
|
||
function te(t, e, i) {
|
||
return Math.min(Math.max(t, e), i)
|
||
}
|
||
|
||
var ee = "cosh" in Math ? Math.cosh : function (t) {
|
||
var e = Math.exp(t);
|
||
return (e + 1 / e) / 2
|
||
};
|
||
|
||
function ie(t) {
|
||
return W(0 < t, 29), Math.pow(2, Math.ceil(Math.log(t) / Math.LN2))
|
||
}
|
||
|
||
function re(t, e, i, r, o, n) {
|
||
var s = o - i, a = n - r;
|
||
if (0 !== s || 0 !== a) {
|
||
var l = ((t - i) * s + (e - r) * a) / (s * s + a * a);
|
||
l > 1 ? (i = o, r = n) : l > 0 && (i += s * l, r += a * l)
|
||
}
|
||
return oe(t, e, i, r)
|
||
}
|
||
|
||
function oe(t, e, i, r) {
|
||
var o = i - t, n = r - e;
|
||
return o * o + n * n
|
||
}
|
||
|
||
function ne(t) {
|
||
for (var e = t.length, i = 0; i < e; i++) {
|
||
for (var r = i, o = Math.abs(t[i][i]), n = i + 1; n < e; n++) {
|
||
var s = Math.abs(t[n][i]);
|
||
s > o && (o = s, r = n)
|
||
}
|
||
if (0 === o) return null;
|
||
var a = t[r];
|
||
t[r] = t[i], t[i] = a;
|
||
for (var l = i + 1; l < e; l++) for (var h = -t[l][i] / t[i][i], u = i; u < e + 1; u++) i == u ? t[l][u] = 0 : t[l][u] += h * t[i][u]
|
||
}
|
||
for (var c = new Array(e), p = e - 1; p >= 0; p--) {
|
||
c[p] = t[p][e] / t[p][p];
|
||
for (var d = p - 1; d >= 0; d--) t[d][e] -= t[d][p] * c[p]
|
||
}
|
||
return c
|
||
}
|
||
|
||
function se(t) {
|
||
return 180 * t / Math.PI
|
||
}
|
||
|
||
function ae(t) {
|
||
return t * Math.PI / 180
|
||
}
|
||
|
||
function le(t, e) {
|
||
var i = t % e;
|
||
return i * e < 0 ? i + e : i
|
||
}
|
||
|
||
function he(t, e, i) {
|
||
return t + i * (e - t)
|
||
}
|
||
|
||
/**
|
||
* @license
|
||
* Latitude/longitude spherical geodesy formulae taken from
|
||
* http://www.movable-type.co.uk/scripts/latlong.html
|
||
* Licensed under CC-BY-3.0.
|
||
*/var ue = 6371008.8;
|
||
|
||
function ce(t, e, i) {
|
||
var r = i || ue, o = ae(t[1]), n = ae(e[1]), s = (n - o) / 2, a = ae(e[0] - t[0]) / 2,
|
||
l = Math.sin(s) * Math.sin(s) + Math.sin(a) * Math.sin(a) * Math.cos(o) * Math.cos(n);
|
||
return 2 * r * Math.atan2(Math.sqrt(l), Math.sqrt(1 - l))
|
||
}
|
||
|
||
function pe(t, e) {
|
||
for (var i = 0, r = 0, o = t.length; r < o - 1; ++r) i += ce(t[r], t[r + 1], e);
|
||
return i
|
||
}
|
||
|
||
function de(t, e) {
|
||
for (var i = 0, r = t.length, o = t[r - 1][0], n = t[r - 1][1], s = 0; s < r; s++) {
|
||
var a = t[s][0], l = t[s][1];
|
||
i += ae(a - o) * (2 + Math.sin(ae(n)) + Math.sin(ae(l))), o = a, n = l
|
||
}
|
||
return i * e * e / 2
|
||
}
|
||
|
||
function fe(t, e) {
|
||
var i = e || {}, r = i.radius || ue, o = i.projection || "EPSG:3857", n = t.getType();
|
||
n !== Zt.GEOMETRY_COLLECTION && (t = t.clone().transform(o, "EPSG:4326"));
|
||
var s, a, l, h, u, c, p = 0;
|
||
switch (n) {
|
||
case Zt.POINT:
|
||
case Zt.MULTI_POINT:
|
||
case Zt.LINE_STRING:
|
||
case Zt.MULTI_LINE_STRING:
|
||
case Zt.LINEAR_RING:
|
||
break;
|
||
case Zt.POLYGON:
|
||
for (s = t.getCoordinates(), p = Math.abs(de(s[0], r)), l = 1, h = s.length; l < h; ++l) p -= Math.abs(de(s[l], r));
|
||
break;
|
||
case Zt.MULTI_POLYGON:
|
||
for (l = 0, h = (s = t.getCoordinates()).length; l < h; ++l) for (a = s[l], p += Math.abs(de(a[0], r)), u = 1, c = a.length; u < c; ++u) p -= Math.abs(de(a[u], r));
|
||
break;
|
||
case Zt.GEOMETRY_COLLECTION:
|
||
var d = t.getGeometries();
|
||
for (l = 0, h = d.length; l < h; ++l) p += fe(d[l], e);
|
||
break;
|
||
default:
|
||
throw new Error("Unsupported geometry type: " + n)
|
||
}
|
||
return p
|
||
}
|
||
|
||
function ge(t, e, i, r) {
|
||
var o = r || ue, n = ae(t[1]), s = ae(t[0]), a = e / o,
|
||
l = Math.asin(Math.sin(n) * Math.cos(a) + Math.cos(n) * Math.sin(a) * Math.cos(i));
|
||
return [se(s + Math.atan2(Math.sin(i) * Math.sin(a) * Math.cos(n), Math.cos(a) - Math.sin(n) * Math.sin(l))), se(l)]
|
||
}
|
||
|
||
var me = {
|
||
DEGREES: "degrees",
|
||
FEET: "ft",
|
||
METERS: "m",
|
||
PIXELS: "pixels",
|
||
TILE_PIXELS: "tile-pixels",
|
||
USFEET: "us-ft"
|
||
}, ye = {};
|
||
ye[me.DEGREES] = 2 * Math.PI * 6370997 / 360, ye[me.FEET] = .3048, ye[me.METERS] = 1, ye[me.USFEET] = 1200 / 3937;
|
||
var ve = me, _e = function (t) {
|
||
this.code_ = t.code, this.units_ = t.units, this.extent_ = void 0 !== t.extent ? t.extent : null, this.worldExtent_ = void 0 !== t.worldExtent ? t.worldExtent : null, this.axisOrientation_ = void 0 !== t.axisOrientation ? t.axisOrientation : "enu", this.global_ = void 0 !== t.global && t.global, this.canWrapX_ = !(!this.global_ || !this.extent_), this.getPointResolutionFunc_ = t.getPointResolution, this.defaultTileGrid_ = null, this.metersPerUnit_ = t.metersPerUnit
|
||
};
|
||
_e.prototype.canWrapX = function () {
|
||
return this.canWrapX_
|
||
}, _e.prototype.getCode = function () {
|
||
return this.code_
|
||
}, _e.prototype.getExtent = function () {
|
||
return this.extent_
|
||
}, _e.prototype.getUnits = function () {
|
||
return this.units_
|
||
}, _e.prototype.getMetersPerUnit = function () {
|
||
return this.metersPerUnit_ || ye[this.units_]
|
||
}, _e.prototype.getWorldExtent = function () {
|
||
return this.worldExtent_
|
||
}, _e.prototype.getAxisOrientation = function () {
|
||
return this.axisOrientation_
|
||
}, _e.prototype.isGlobal = function () {
|
||
return this.global_
|
||
}, _e.prototype.setGlobal = function (t) {
|
||
this.global_ = t, this.canWrapX_ = !(!t || !this.extent_)
|
||
}, _e.prototype.getDefaultTileGrid = function () {
|
||
return this.defaultTileGrid_
|
||
}, _e.prototype.setDefaultTileGrid = function (t) {
|
||
this.defaultTileGrid_ = t
|
||
}, _e.prototype.setExtent = function (t) {
|
||
this.extent_ = t, this.canWrapX_ = !(!this.global_ || !t)
|
||
}, _e.prototype.setWorldExtent = function (t) {
|
||
this.worldExtent_ = t
|
||
}, _e.prototype.setGetPointResolution = function (t) {
|
||
this.getPointResolutionFunc_ = t
|
||
}, _e.prototype.getPointResolutionFunc = function () {
|
||
return this.getPointResolutionFunc_
|
||
};
|
||
var xe = _e, we = 6378137, be = Math.PI * we, Ce = [-be, -be, be, be], Se = [-180, -85, 180, 85],
|
||
Ee = function (t) {
|
||
function e(e) {
|
||
t.call(this, {
|
||
code: e,
|
||
units: ve.METERS,
|
||
extent: Ce,
|
||
global: !0,
|
||
worldExtent: Se,
|
||
getPointResolution: function (t, e) {
|
||
return t / ee(e[1] / we)
|
||
}
|
||
})
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(xe),
|
||
Te = [new Ee("EPSG:3857"), new Ee("EPSG:102100"), new Ee("EPSG:102113"), new Ee("EPSG:900913"), new Ee("urn:ogc:def:crs:EPSG:6.18:3:3857"), new Ee("urn:ogc:def:crs:EPSG::3857"), new Ee("http://www.opengis.net/gml/srs/epsg.xml#3857")];
|
||
|
||
function Re(t, e, i) {
|
||
var r = t.length, o = i > 1 ? i : 2, n = e;
|
||
void 0 === n && (n = o > 2 ? t.slice() : new Array(r));
|
||
for (var s = be, a = 0; a < r; a += o) {
|
||
n[a] = s * t[a] / 180;
|
||
var l = we * Math.log(Math.tan(Math.PI * (t[a + 1] + 90) / 360));
|
||
l > s ? l = s : l < -s && (l = -s), n[a + 1] = l
|
||
}
|
||
return n
|
||
}
|
||
|
||
function Pe(t, e, i) {
|
||
var r = t.length, o = i > 1 ? i : 2, n = e;
|
||
void 0 === n && (n = o > 2 ? t.slice() : new Array(r));
|
||
for (var s = 0; s < r; s += o) n[s] = 180 * t[s] / be, n[s + 1] = 360 * Math.atan(Math.exp(t[s + 1] / we)) / Math.PI - 90;
|
||
return n
|
||
}
|
||
|
||
var Le = [-180, -90, 180, 90], Ie = 6378137 * Math.PI / 180, Oe = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, {
|
||
code: e,
|
||
units: ve.DEGREES,
|
||
extent: Le,
|
||
axisOrientation: i,
|
||
global: !0,
|
||
metersPerUnit: Ie,
|
||
worldExtent: Le
|
||
})
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(xe),
|
||
Me = [new Oe("CRS:84"), new Oe("EPSG:4326", "neu"), new Oe("urn:ogc:def:crs:EPSG::4326", "neu"), new Oe("urn:ogc:def:crs:EPSG:6.6:4326", "neu"), new Oe("urn:ogc:def:crs:OGC:1.3:CRS84"), new Oe("urn:ogc:def:crs:OGC:2:84"), new Oe("http://www.opengis.net/gml/srs/epsg.xml#4326", "neu"), new Oe("urn:x-ogc:def:crs:EPSG:4326", "neu")],
|
||
Ae = {};
|
||
|
||
function ke() {
|
||
Ae = {}
|
||
}
|
||
|
||
function Fe(t) {
|
||
return Ae[t] || null
|
||
}
|
||
|
||
function Ne(t, e) {
|
||
Ae[t] = e
|
||
}
|
||
|
||
var De = {};
|
||
|
||
function Ge() {
|
||
De = {}
|
||
}
|
||
|
||
function je(t, e, i) {
|
||
var r = t.getCode(), o = e.getCode();
|
||
r in De || (De[r] = {}), De[r][o] = i
|
||
}
|
||
|
||
function ze(t, e) {
|
||
var i;
|
||
return t in De && e in De[t] && (i = De[t][e]), i
|
||
}
|
||
|
||
function Ue(t, e, i) {
|
||
var r;
|
||
if (void 0 !== e) {
|
||
for (var o = 0, n = t.length; o < n; ++o) e[o] = t[o];
|
||
r = e
|
||
} else r = t.slice();
|
||
return r
|
||
}
|
||
|
||
function Be(t, e, i) {
|
||
if (void 0 !== e && t !== e) {
|
||
for (var r = 0, o = t.length; r < o; ++r) e[r] = t[r];
|
||
t = e
|
||
}
|
||
return t
|
||
}
|
||
|
||
function Ve(t) {
|
||
Ne(t.getCode(), t), je(t, t, Ue)
|
||
}
|
||
|
||
function Ye(t) {
|
||
t.forEach(Ve)
|
||
}
|
||
|
||
function We(t) {
|
||
return "string" == typeof t ? Fe(t) : t || null
|
||
}
|
||
|
||
function He(t, e, i, r) {
|
||
var o, n = (t = We(t)).getPointResolutionFunc();
|
||
if (n) o = n(e, i); else if (t.getUnits() == ve.DEGREES && !r || r == ve.DEGREES) o = e; else {
|
||
var s = ti(t, We("EPSG:4326")),
|
||
a = [i[0] - e / 2, i[1], i[0] + e / 2, i[1], i[0], i[1] - e / 2, i[0], i[1] + e / 2];
|
||
o = (ce((a = s(a, a, 2)).slice(0, 2), a.slice(2, 4)) + ce(a.slice(4, 6), a.slice(6, 8))) / 2;
|
||
var l = r ? ye[r] : t.getMetersPerUnit();
|
||
void 0 !== l && (o /= l)
|
||
}
|
||
return o
|
||
}
|
||
|
||
function Xe(t) {
|
||
Ye(t), t.forEach(function (e) {
|
||
t.forEach(function (t) {
|
||
e !== t && je(e, t, Ue)
|
||
})
|
||
})
|
||
}
|
||
|
||
function qe(t, e, i, r) {
|
||
t.forEach(function (t) {
|
||
e.forEach(function (e) {
|
||
je(t, e, i), je(e, t, r)
|
||
})
|
||
})
|
||
}
|
||
|
||
function Ze(t, e) {
|
||
return t ? "string" == typeof t ? We(t) : t : We(e)
|
||
}
|
||
|
||
function Ke(t) {
|
||
return function (e, i, r) {
|
||
for (var o = e.length, n = void 0 !== r ? r : 2, s = void 0 !== i ? i : new Array(o), a = 0; a < o; a += n) {
|
||
var l = t([e[a], e[a + 1]]);
|
||
s[a] = l[0], s[a + 1] = l[1];
|
||
for (var h = n - 1; h >= 2; --h) s[a + h] = e[a + h]
|
||
}
|
||
return s
|
||
}
|
||
}
|
||
|
||
function Je(t, e, i, r) {
|
||
var o = We(t), n = We(e);
|
||
je(o, n, Ke(i)), je(n, o, Ke(r))
|
||
}
|
||
|
||
function $e(t, e) {
|
||
return ii(t, "EPSG:4326", void 0 !== e ? e : "EPSG:3857")
|
||
}
|
||
|
||
function Qe(t, e) {
|
||
if (t === e) return !0;
|
||
var i = t.getUnits() === e.getUnits();
|
||
return t.getCode() === e.getCode() ? i : ti(t, e) === Ue && i
|
||
}
|
||
|
||
function ti(t, e) {
|
||
var i = ze(t.getCode(), e.getCode());
|
||
return i || (i = Be), i
|
||
}
|
||
|
||
function ei(t, e) {
|
||
return ti(We(t), We(e))
|
||
}
|
||
|
||
function ii(t, e, i) {
|
||
return ei(e, i)(t, void 0, t.length)
|
||
}
|
||
|
||
function ri(t, e, i) {
|
||
return Xt(t, ei(e, i))
|
||
}
|
||
|
||
function oi() {
|
||
Xe(Te), Xe(Me), qe(Me, Te, Re, Pe)
|
||
}
|
||
|
||
oi();
|
||
var ni = new Array(6);
|
||
|
||
function si() {
|
||
return [1, 0, 0, 1, 0, 0]
|
||
}
|
||
|
||
function ai(t) {
|
||
return hi(t, 1, 0, 0, 1, 0, 0)
|
||
}
|
||
|
||
function li(t, e) {
|
||
var i = t[0], r = t[1], o = t[2], n = t[3], s = t[4], a = t[5], l = e[0], h = e[1], u = e[2], c = e[3],
|
||
p = e[4], d = e[5];
|
||
return t[0] = i * l + o * h, t[1] = r * l + n * h, t[2] = i * u + o * c, t[3] = r * u + n * c, t[4] = i * p + o * d + s, t[5] = r * p + n * d + a, t
|
||
}
|
||
|
||
function hi(t, e, i, r, o, n, s) {
|
||
return t[0] = e, t[1] = i, t[2] = r, t[3] = o, t[4] = n, t[5] = s, t
|
||
}
|
||
|
||
function ui(t, e) {
|
||
return t[0] = e[0], t[1] = e[1], t[2] = e[2], t[3] = e[3], t[4] = e[4], t[5] = e[5], t
|
||
}
|
||
|
||
function ci(t, e) {
|
||
var i = e[0], r = e[1];
|
||
return e[0] = t[0] * i + t[2] * r + t[4], e[1] = t[1] * i + t[3] * r + t[5], e
|
||
}
|
||
|
||
function pi(t, e) {
|
||
var i = Math.cos(e), r = Math.sin(e);
|
||
return li(t, hi(ni, i, r, -r, i, 0, 0))
|
||
}
|
||
|
||
function di(t, e, i) {
|
||
return li(t, hi(ni, e, 0, 0, i, 0, 0))
|
||
}
|
||
|
||
function fi(t, e, i) {
|
||
return li(t, hi(ni, 1, 0, 0, 1, e, i))
|
||
}
|
||
|
||
function gi(t, e, i, r, o, n, s, a) {
|
||
var l = Math.sin(n), h = Math.cos(n);
|
||
return t[0] = r * h, t[1] = o * l, t[2] = -r * l, t[3] = o * h, t[4] = s * r * h - a * r * l + e, t[5] = s * o * l + a * o * h + i, t
|
||
}
|
||
|
||
function mi(t) {
|
||
var e = yi(t);
|
||
W(0 !== e, 32);
|
||
var i = t[0], r = t[1], o = t[2], n = t[3], s = t[4], a = t[5];
|
||
return t[0] = n / e, t[1] = -r / e, t[2] = -o / e, t[3] = i / e, t[4] = (o * a - n * s) / e, t[5] = -(i * a - r * s) / e, t
|
||
}
|
||
|
||
function yi(t) {
|
||
return t[0] * t[3] - t[1] * t[2]
|
||
}
|
||
|
||
var vi = [1, 0, 0, 1, 0, 0], _i = function (t) {
|
||
function e() {
|
||
t.call(this), this.extent_ = [1 / 0, 1 / 0, -1 / 0, -1 / 0], this.extentRevision_ = -1, this.simplifiedGeometryCache = {}, this.simplifiedGeometryMaxMinSquaredTolerance = 0, this.simplifiedGeometryRevision = 0
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.clone = function () {
|
||
return n()
|
||
}, e.prototype.closestPointXY = function (t, e, i, r) {
|
||
return n()
|
||
}, e.prototype.containsXY = function (t, e) {
|
||
return !1
|
||
}, e.prototype.getClosestPoint = function (t, e) {
|
||
var i = e || [NaN, NaN];
|
||
return this.closestPointXY(t[0], t[1], i, 1 / 0), i
|
||
}, e.prototype.intersectsCoordinate = function (t) {
|
||
return this.containsXY(t[0], t[1])
|
||
}, e.prototype.computeExtent = function (t) {
|
||
return n()
|
||
}, e.prototype.getExtent = function (t) {
|
||
return this.extentRevision_ != this.getRevision() && (this.extent_ = this.computeExtent(this.extent_), this.extentRevision_ = this.getRevision()), Yt(this.extent_, t)
|
||
}, e.prototype.rotate = function (t, e) {
|
||
n()
|
||
}, e.prototype.scale = function (t, e, i) {
|
||
n()
|
||
}, e.prototype.simplify = function (t) {
|
||
return this.getSimplifiedGeometry(t * t)
|
||
}, e.prototype.getSimplifiedGeometry = function (t) {
|
||
return n()
|
||
}, e.prototype.getType = function () {
|
||
return n()
|
||
}, e.prototype.applyTransform = function (t) {
|
||
n()
|
||
}, e.prototype.intersectsExtent = function (t) {
|
||
return n()
|
||
}, e.prototype.translate = function (t, e) {
|
||
n()
|
||
}, e.prototype.transform = function (t, e) {
|
||
var i = We(t), r = i.getUnits() == ve.TILE_PIXELS ? function (t, r, o) {
|
||
var n = i.getExtent(), s = i.getWorldExtent(), a = Nt(s) / Nt(n);
|
||
return gi(vi, s[0], s[3], a, -a, 0, 0, 0), Kt(t, 0, t.length, o, vi, r), ei(i, e)(t, r, o)
|
||
} : ei(i, e);
|
||
return this.applyTransform(r), this
|
||
}, e
|
||
}(U);
|
||
|
||
function xi(t) {
|
||
var e;
|
||
return t == qt.XY ? e = 2 : t == qt.XYZ || t == qt.XYM ? e = 3 : t == qt.XYZM && (e = 4), e
|
||
}
|
||
|
||
function wi(t, e, i) {
|
||
var r = t.getFlatCoordinates();
|
||
if (r) {
|
||
var o = t.getStride();
|
||
return Kt(r, 0, r.length, o, e, i)
|
||
}
|
||
return null
|
||
}
|
||
|
||
var bi = function (t) {
|
||
function e() {
|
||
t.call(this), this.layout = qt.XY, this.stride = 2, this.flatCoordinates = null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.computeExtent = function (t) {
|
||
return wt(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, t)
|
||
}, e.prototype.getCoordinates = function () {
|
||
return n()
|
||
}, e.prototype.getFirstCoordinate = function () {
|
||
return this.flatCoordinates.slice(0, this.stride)
|
||
}, e.prototype.getFlatCoordinates = function () {
|
||
return this.flatCoordinates
|
||
}, e.prototype.getLastCoordinate = function () {
|
||
return this.flatCoordinates.slice(this.flatCoordinates.length - this.stride)
|
||
}, e.prototype.getLayout = function () {
|
||
return this.layout
|
||
}, e.prototype.getSimplifiedGeometry = function (t) {
|
||
if (this.simplifiedGeometryRevision != this.getRevision() && (d(this.simplifiedGeometryCache), this.simplifiedGeometryMaxMinSquaredTolerance = 0, this.simplifiedGeometryRevision = this.getRevision()), t < 0 || 0 !== this.simplifiedGeometryMaxMinSquaredTolerance && t <= this.simplifiedGeometryMaxMinSquaredTolerance) return this;
|
||
var e = t.toString();
|
||
if (this.simplifiedGeometryCache.hasOwnProperty(e)) return this.simplifiedGeometryCache[e];
|
||
var i = this.getSimplifiedGeometryInternal(t);
|
||
return i.getFlatCoordinates().length < this.flatCoordinates.length ? (this.simplifiedGeometryCache[e] = i, i) : (this.simplifiedGeometryMaxMinSquaredTolerance = t, this)
|
||
}, e.prototype.getSimplifiedGeometryInternal = function (t) {
|
||
return this
|
||
}, e.prototype.getStride = function () {
|
||
return this.stride
|
||
}, e.prototype.setFlatCoordinates = function (t, e) {
|
||
this.stride = xi(t), this.layout = t, this.flatCoordinates = e
|
||
}, e.prototype.setCoordinates = function (t, e) {
|
||
n()
|
||
}, e.prototype.setLayout = function (t, e, i) {
|
||
var r;
|
||
if (t) r = xi(t); else {
|
||
for (var o = 0; o < i; ++o) {
|
||
if (0 === e.length) return this.layout = qt.XY, void (this.stride = 2);
|
||
e = e[0]
|
||
}
|
||
t = function (t) {
|
||
var e;
|
||
2 == t ? e = qt.XY : 3 == t ? e = qt.XYZ : 4 == t && (e = qt.XYZM);
|
||
return e
|
||
}(r = e.length)
|
||
}
|
||
this.layout = t, this.stride = r
|
||
}, e.prototype.applyTransform = function (t) {
|
||
this.flatCoordinates && (t(this.flatCoordinates, this.flatCoordinates, this.stride), this.changed())
|
||
}, e.prototype.rotate = function (t, e) {
|
||
var i = this.getFlatCoordinates();
|
||
if (i) {
|
||
var r = this.getStride();
|
||
Jt(i, 0, i.length, r, t, e, i), this.changed()
|
||
}
|
||
}, e.prototype.scale = function (t, e, i) {
|
||
var r = e;
|
||
void 0 === r && (r = t);
|
||
var o = i;
|
||
o || (o = At(this.getExtent()));
|
||
var n = this.getFlatCoordinates();
|
||
if (n) {
|
||
var s = this.getStride();
|
||
$t(n, 0, n.length, s, t, r, o, n), this.changed()
|
||
}
|
||
}, e.prototype.translate = function (t, e) {
|
||
var i = this.getFlatCoordinates();
|
||
if (i) {
|
||
var r = this.getStride();
|
||
Qt(i, 0, i.length, r, t, e, i), this.changed()
|
||
}
|
||
}, e
|
||
}(_i);
|
||
|
||
function Ci(t, e, i, r) {
|
||
for (var o = 0, n = t[i - r], s = t[i - r + 1]; e < i; e += r) {
|
||
var a = t[e], l = t[e + 1];
|
||
o += s * a - n * l, n = a, s = l
|
||
}
|
||
return o / 2
|
||
}
|
||
|
||
function Si(t, e, i, r) {
|
||
for (var o = 0, n = 0, s = i.length; n < s; ++n) {
|
||
var a = i[n];
|
||
o += Ci(t, e, a, r), e = a
|
||
}
|
||
return o
|
||
}
|
||
|
||
function Ei(t, e, i, r) {
|
||
for (var o = 0, n = 0, s = i.length; n < s; ++n) {
|
||
var a = i[n];
|
||
o += Si(t, e, a, r), e = a[a.length - 1]
|
||
}
|
||
return o
|
||
}
|
||
|
||
function Ti(t, e, i, r, o, n, s) {
|
||
var a, l = t[e], h = t[e + 1], u = t[i] - l, c = t[i + 1] - h;
|
||
if (0 === u && 0 === c) a = e; else {
|
||
var p = ((o - l) * u + (n - h) * c) / (u * u + c * c);
|
||
if (p > 1) a = i; else {
|
||
if (p > 0) {
|
||
for (var d = 0; d < r; ++d) s[d] = he(t[e + d], t[i + d], p);
|
||
return void (s.length = r)
|
||
}
|
||
a = e
|
||
}
|
||
}
|
||
for (var f = 0; f < r; ++f) s[f] = t[a + f];
|
||
s.length = r
|
||
}
|
||
|
||
function Ri(t, e, i, r, o) {
|
||
var n = t[e], s = t[e + 1];
|
||
for (e += r; e < i; e += r) {
|
||
var a = t[e], l = t[e + 1], h = oe(n, s, a, l);
|
||
h > o && (o = h), n = a, s = l
|
||
}
|
||
return o
|
||
}
|
||
|
||
function Pi(t, e, i, r, o) {
|
||
for (var n = 0, s = i.length; n < s; ++n) {
|
||
var a = i[n];
|
||
o = Ri(t, e, a, r, o), e = a
|
||
}
|
||
return o
|
||
}
|
||
|
||
function Li(t, e, i, r, o) {
|
||
for (var n = 0, s = i.length; n < s; ++n) {
|
||
var a = i[n];
|
||
o = Pi(t, e, a, r, o), e = a[a.length - 1]
|
||
}
|
||
return o
|
||
}
|
||
|
||
function Ii(t, e, i, r, o, n, s, a, l, h, u) {
|
||
if (e == i) return h;
|
||
var c, p;
|
||
if (0 === o) {
|
||
if ((p = oe(s, a, t[e], t[e + 1])) < h) {
|
||
for (c = 0; c < r; ++c) l[c] = t[e + c];
|
||
return l.length = r, p
|
||
}
|
||
return h
|
||
}
|
||
for (var d = u || [NaN, NaN], f = e + r; f < i;) if (Ti(t, f - r, f, r, s, a, d), (p = oe(s, a, d[0], d[1])) < h) {
|
||
for (h = p, c = 0; c < r; ++c) l[c] = d[c];
|
||
l.length = r, f += r
|
||
} else f += r * Math.max((Math.sqrt(p) - Math.sqrt(h)) / o | 0, 1);
|
||
if (n && (Ti(t, i - r, e, r, s, a, d), (p = oe(s, a, d[0], d[1])) < h)) {
|
||
for (h = p, c = 0; c < r; ++c) l[c] = d[c];
|
||
l.length = r
|
||
}
|
||
return h
|
||
}
|
||
|
||
function Oi(t, e, i, r, o, n, s, a, l, h, u) {
|
||
for (var c = u || [NaN, NaN], p = 0, d = i.length; p < d; ++p) {
|
||
var f = i[p];
|
||
h = Ii(t, e, f, r, o, n, s, a, l, h, c), e = f
|
||
}
|
||
return h
|
||
}
|
||
|
||
function Mi(t, e, i, r, o, n, s, a, l, h, u) {
|
||
for (var c = u || [NaN, NaN], p = 0, d = i.length; p < d; ++p) {
|
||
var f = i[p];
|
||
h = Oi(t, e, f, r, o, n, s, a, l, h, c), e = f[f.length - 1]
|
||
}
|
||
return h
|
||
}
|
||
|
||
function Ai(t, e, i, r) {
|
||
for (var o = 0, n = i.length; o < n; ++o) t[e++] = i[o];
|
||
return e
|
||
}
|
||
|
||
function ki(t, e, i, r) {
|
||
for (var o = 0, n = i.length; o < n; ++o) for (var s = i[o], a = 0; a < r; ++a) t[e++] = s[a];
|
||
return e
|
||
}
|
||
|
||
function Fi(t, e, i, r, o) {
|
||
for (var n = o || [], s = 0, a = 0, l = i.length; a < l; ++a) {
|
||
var h = ki(t, e, i[a], r);
|
||
n[s++] = h, e = h
|
||
}
|
||
return n.length = s, n
|
||
}
|
||
|
||
function Ni(t, e, i, r, o) {
|
||
for (var n = o || [], s = 0, a = 0, l = i.length; a < l; ++a) {
|
||
var h = Fi(t, e, i[a], r, n[s]);
|
||
n[s++] = h, e = h[h.length - 1]
|
||
}
|
||
return n.length = s, n
|
||
}
|
||
|
||
function Di(t, e, i, r, o) {
|
||
for (var n = void 0 !== o ? o : [], s = 0, a = e; a < i; a += r) n[s++] = t.slice(a, a + r);
|
||
return n.length = s, n
|
||
}
|
||
|
||
function Gi(t, e, i, r, o) {
|
||
for (var n = void 0 !== o ? o : [], s = 0, a = 0, l = i.length; a < l; ++a) {
|
||
var h = i[a];
|
||
n[s++] = Di(t, e, h, r, n[s]), e = h
|
||
}
|
||
return n.length = s, n
|
||
}
|
||
|
||
function ji(t, e, i, r, o) {
|
||
for (var n = void 0 !== o ? o : [], s = 0, a = 0, l = i.length; a < l; ++a) {
|
||
var h = i[a];
|
||
n[s++] = Gi(t, e, h, r, n[s]), e = h[h.length - 1]
|
||
}
|
||
return n.length = s, n
|
||
}
|
||
|
||
function zi(t, e, i, r, o, n, s) {
|
||
var a = (i - e) / r;
|
||
if (a < 3) {
|
||
for (; e < i; e += r) n[s++] = t[e], n[s++] = t[e + 1];
|
||
return s
|
||
}
|
||
var l = new Array(a);
|
||
l[0] = 1, l[a - 1] = 1;
|
||
for (var h = [e, i - r], u = 0; h.length > 0;) {
|
||
for (var c = h.pop(), p = h.pop(), d = 0, f = t[p], g = t[p + 1], m = t[c], y = t[c + 1], v = p + r; v < c; v += r) {
|
||
var _ = re(t[v], t[v + 1], f, g, m, y);
|
||
_ > d && (u = v, d = _)
|
||
}
|
||
d > o && (l[(u - e) / r] = 1, p + r < u && h.push(p, u), u + r < c && h.push(u, c))
|
||
}
|
||
for (var x = 0; x < a; ++x) l[x] && (n[s++] = t[e + x * r], n[s++] = t[e + x * r + 1]);
|
||
return s
|
||
}
|
||
|
||
function Ui(t, e, i, r, o, n, s, a) {
|
||
for (var l = 0, h = i.length; l < h; ++l) {
|
||
var u = i[l];
|
||
s = zi(t, e, u, r, o, n, s), a.push(s), e = u
|
||
}
|
||
return s
|
||
}
|
||
|
||
function Bi(t, e, i, r, o, n, s) {
|
||
if (i <= e + r) {
|
||
for (; e < i; e += r) n[s++] = t[e], n[s++] = t[e + 1];
|
||
return s
|
||
}
|
||
var a = t[e], l = t[e + 1];
|
||
n[s++] = a, n[s++] = l;
|
||
var h = a, u = l;
|
||
for (e += r; e < i; e += r) oe(a, l, h = t[e], u = t[e + 1]) > o && (n[s++] = h, n[s++] = u, a = h, l = u);
|
||
return h == a && u == l || (n[s++] = h, n[s++] = u), s
|
||
}
|
||
|
||
function Vi(t, e) {
|
||
return e * Math.round(t / e)
|
||
}
|
||
|
||
function Yi(t, e, i, r, o, n, s) {
|
||
if (e == i) return s;
|
||
var a, l, h = Vi(t[e], o), u = Vi(t[e + 1], o);
|
||
e += r, n[s++] = h, n[s++] = u;
|
||
do {
|
||
if (a = Vi(t[e], o), l = Vi(t[e + 1], o), (e += r) == i) return n[s++] = a, n[s++] = l, s
|
||
} while (a == h && l == u);
|
||
for (; e < i;) {
|
||
var c = Vi(t[e], o), p = Vi(t[e + 1], o);
|
||
if (e += r, c != a || p != l) {
|
||
var d = a - h, f = l - u, g = c - h, m = p - u;
|
||
d * m == f * g && (d < 0 && g < d || d == g || d > 0 && g > d) && (f < 0 && m < f || f == m || f > 0 && m > f) ? (a = c, l = p) : (n[s++] = a, n[s++] = l, h = a, u = l, a = c, l = p)
|
||
}
|
||
}
|
||
return n[s++] = a, n[s++] = l, s
|
||
}
|
||
|
||
function Wi(t, e, i, r, o, n, s, a) {
|
||
for (var l = 0, h = i.length; l < h; ++l) {
|
||
var u = i[l];
|
||
s = Yi(t, e, u, r, o, n, s), a.push(s), e = u
|
||
}
|
||
return s
|
||
}
|
||
|
||
function Hi(t, e, i, r, o, n, s, a) {
|
||
for (var l = 0, h = i.length; l < h; ++l) {
|
||
var u = i[l], c = [];
|
||
s = Wi(t, e, u, r, o, n, s, c), a.push(c), e = u[u.length - 1]
|
||
}
|
||
return s
|
||
}
|
||
|
||
var Xi = function (t) {
|
||
function e(e, i) {
|
||
t.call(this), this.maxDelta_ = -1, this.maxDeltaRevision_ = -1, void 0 === i || Array.isArray(e[0]) ? this.setCoordinates(e, i) : this.setFlatCoordinates(i, e)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.clone = function () {
|
||
return new e(this.flatCoordinates.slice(), this.layout)
|
||
}, e.prototype.closestPointXY = function (t, e, i, r) {
|
||
return r < ct(this.getExtent(), t, e) ? r : (this.maxDeltaRevision_ != this.getRevision() && (this.maxDelta_ = Math.sqrt(Ri(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, 0)), this.maxDeltaRevision_ = this.getRevision()), Ii(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, this.maxDelta_, !0, t, e, i, r))
|
||
}, e.prototype.getArea = function () {
|
||
return Ci(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride)
|
||
}, e.prototype.getCoordinates = function () {
|
||
return Di(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride)
|
||
}, e.prototype.getSimplifiedGeometryInternal = function (t) {
|
||
var i = [];
|
||
return i.length = zi(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, t, i, 0), new e(i, qt.XY)
|
||
}, e.prototype.getType = function () {
|
||
return Zt.LINEAR_RING
|
||
}, e.prototype.intersectsExtent = function (t) {
|
||
return !1
|
||
}, e.prototype.setCoordinates = function (t, e) {
|
||
this.setLayout(e, t, 1), this.flatCoordinates || (this.flatCoordinates = []), this.flatCoordinates.length = ki(this.flatCoordinates, 0, t, this.stride), this.changed()
|
||
}, e
|
||
}(bi), qi = function (t) {
|
||
function e(e, i) {
|
||
t.call(this), this.setCoordinates(e, i)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.clone = function () {
|
||
return new e(this.flatCoordinates.slice(), this.layout)
|
||
}, e.prototype.closestPointXY = function (t, e, i, r) {
|
||
var o = this.flatCoordinates, n = oe(t, e, o[0], o[1]);
|
||
if (n < r) {
|
||
for (var s = this.stride, a = 0; a < s; ++a) i[a] = o[a];
|
||
return i.length = s, n
|
||
}
|
||
return r
|
||
}, e.prototype.getCoordinates = function () {
|
||
return this.flatCoordinates ? this.flatCoordinates.slice() : []
|
||
}, e.prototype.computeExtent = function (t) {
|
||
return _t(this.flatCoordinates, t)
|
||
}, e.prototype.getType = function () {
|
||
return Zt.POINT
|
||
}, e.prototype.intersectsExtent = function (t) {
|
||
return ft(t, this.flatCoordinates[0], this.flatCoordinates[1])
|
||
}, e.prototype.setCoordinates = function (t, e) {
|
||
this.setLayout(e, t, 0), this.flatCoordinates || (this.flatCoordinates = []), this.flatCoordinates.length = Ai(this.flatCoordinates, 0, t, this.stride), this.changed()
|
||
}, e
|
||
}(bi);
|
||
|
||
function Zi(t, e, i, r, o) {
|
||
return !Lt(o, function (o) {
|
||
return !Ki(t, e, i, r, o[0], o[1])
|
||
})
|
||
}
|
||
|
||
function Ki(t, e, i, r, o, n) {
|
||
for (var s = 0, a = t[i - r], l = t[i - r + 1]; e < i; e += r) {
|
||
var h = t[e], u = t[e + 1];
|
||
l <= n ? u > n && (h - a) * (n - l) - (o - a) * (u - l) > 0 && s++ : u <= n && (h - a) * (n - l) - (o - a) * (u - l) < 0 && s--, a = h, l = u
|
||
}
|
||
return 0 !== s
|
||
}
|
||
|
||
function Ji(t, e, i, r, o, n) {
|
||
if (0 === i.length) return !1;
|
||
if (!Ki(t, e, i[0], r, o, n)) return !1;
|
||
for (var s = 1, a = i.length; s < a; ++s) if (Ki(t, i[s - 1], i[s], r, o, n)) return !1;
|
||
return !0
|
||
}
|
||
|
||
function $i(t, e, i, r, o, n) {
|
||
if (0 === i.length) return !1;
|
||
for (var s = 0, a = i.length; s < a; ++s) {
|
||
var l = i[s];
|
||
if (Ji(t, e, l, r, o, n)) return !0;
|
||
e = l[l.length - 1]
|
||
}
|
||
return !1
|
||
}
|
||
|
||
function Qi(t, e, i, r, o, n, s) {
|
||
for (var a, l, h, u, c, p, d, f = o[n + 1], g = [], m = 0, y = i.length; m < y; ++m) {
|
||
var v = i[m];
|
||
for (u = t[v - r], p = t[v - r + 1], a = e; a < v; a += r) c = t[a], d = t[a + 1], (f <= p && d <= f || p <= f && f <= d) && (h = (f - p) / (d - p) * (c - u) + u, g.push(h)), u = c, p = d
|
||
}
|
||
var _ = NaN, x = -1 / 0;
|
||
for (g.sort(Z), u = g[0], a = 1, l = g.length; a < l; ++a) {
|
||
c = g[a];
|
||
var w = Math.abs(c - u);
|
||
w > x && Ji(t, e, i, r, h = (u + c) / 2, f) && (_ = h, x = w), u = c
|
||
}
|
||
return isNaN(_) && (_ = o[n]), s ? (s.push(_, f, x), s) : [_, f, x]
|
||
}
|
||
|
||
function tr(t, e, i, r, o) {
|
||
for (var n = [], s = 0, a = i.length; s < a; ++s) {
|
||
var l = i[s];
|
||
n = Qi(t, e, l, r, o, 2 * s, n), e = l[l.length - 1]
|
||
}
|
||
return n
|
||
}
|
||
|
||
function er(t, e, i, r, o, n) {
|
||
for (var s, a = [t[e], t[e + 1]], l = []; e + r < i; e += r) {
|
||
if (l[0] = t[e + r], l[1] = t[e + r + 1], s = o.call(n, a, l)) return s;
|
||
a[0] = l[0], a[1] = l[1]
|
||
}
|
||
return !1
|
||
}
|
||
|
||
function ir(t, e, i, r, o) {
|
||
var n = Tt([1 / 0, 1 / 0, -1 / 0, -1 / 0], t, e, i, r);
|
||
return !!Bt(o, n) && (!!dt(o, n) || (n[0] >= o[0] && n[2] <= o[2] || (n[1] >= o[1] && n[3] <= o[3] || er(t, e, i, r, function (t, e) {
|
||
return Ht(o, t, e)
|
||
}))))
|
||
}
|
||
|
||
function rr(t, e, i, r, o) {
|
||
for (var n = 0, s = i.length; n < s; ++n) {
|
||
if (ir(t, e, i[n], r, o)) return !0;
|
||
e = i[n]
|
||
}
|
||
return !1
|
||
}
|
||
|
||
function or(t, e, i, r, o) {
|
||
return !!ir(t, e, i, r, o) || (!!Ki(t, e, i, r, o[0], o[1]) || (!!Ki(t, e, i, r, o[0], o[3]) || (!!Ki(t, e, i, r, o[2], o[1]) || !!Ki(t, e, i, r, o[2], o[3]))))
|
||
}
|
||
|
||
function nr(t, e, i, r, o) {
|
||
if (!or(t, e, i[0], r, o)) return !1;
|
||
if (1 === i.length) return !0;
|
||
for (var n = 1, s = i.length; n < s; ++n) if (Zi(t, i[n - 1], i[n], r, o) && !ir(t, i[n - 1], i[n], r, o)) return !1;
|
||
return !0
|
||
}
|
||
|
||
function sr(t, e, i, r, o) {
|
||
for (var n = 0, s = i.length; n < s; ++n) {
|
||
var a = i[n];
|
||
if (nr(t, e, a, r, o)) return !0;
|
||
e = a[a.length - 1]
|
||
}
|
||
return !1
|
||
}
|
||
|
||
function ar(t, e, i, r) {
|
||
for (; e < i - r;) {
|
||
for (var o = 0; o < r; ++o) {
|
||
var n = t[e + o];
|
||
t[e + o] = t[i - r + o], t[i - r + o] = n
|
||
}
|
||
e += r, i -= r
|
||
}
|
||
}
|
||
|
||
function lr(t, e, i, r) {
|
||
for (var o = 0, n = t[i - r], s = t[i - r + 1]; e < i; e += r) {
|
||
var a = t[e], l = t[e + 1];
|
||
o += (a - n) * (l + s), n = a, s = l
|
||
}
|
||
return o > 0
|
||
}
|
||
|
||
function hr(t, e, i, r, o) {
|
||
for (var n = void 0 !== o && o, s = 0, a = i.length; s < a; ++s) {
|
||
var l = i[s], h = lr(t, e, l, r);
|
||
if (0 === s) {
|
||
if (n && h || !n && !h) return !1
|
||
} else if (n && !h || !n && h) return !1;
|
||
e = l
|
||
}
|
||
return !0
|
||
}
|
||
|
||
function ur(t, e, i, r, o) {
|
||
for (var n = 0, s = i.length; n < s; ++n) if (!hr(t, e, i[n], r, o)) return !1;
|
||
return !0
|
||
}
|
||
|
||
function cr(t, e, i, r, o) {
|
||
for (var n = void 0 !== o && o, s = 0, a = i.length; s < a; ++s) {
|
||
var l = i[s], h = lr(t, e, l, r);
|
||
(0 === s ? n && h || !n && !h : n && !h || !n && h) && ar(t, e, l, r), e = l
|
||
}
|
||
return e
|
||
}
|
||
|
||
function pr(t, e, i, r, o) {
|
||
for (var n = 0, s = i.length; n < s; ++n) e = cr(t, e, i[n], r, o);
|
||
return e
|
||
}
|
||
|
||
var dr = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this), this.ends_ = [], this.flatInteriorPointRevision_ = -1, this.flatInteriorPoint_ = null, this.maxDelta_ = -1, this.maxDeltaRevision_ = -1, this.orientedRevision_ = -1, this.orientedFlatCoordinates_ = null, void 0 !== i && r ? (this.setFlatCoordinates(i, e), this.ends_ = r) : this.setCoordinates(e, i)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.appendLinearRing = function (t) {
|
||
this.flatCoordinates ? Q(this.flatCoordinates, t.getFlatCoordinates()) : this.flatCoordinates = t.getFlatCoordinates().slice(), this.ends_.push(this.flatCoordinates.length), this.changed()
|
||
}, e.prototype.clone = function () {
|
||
return new e(this.flatCoordinates.slice(), this.layout, this.ends_.slice())
|
||
}, e.prototype.closestPointXY = function (t, e, i, r) {
|
||
return r < ct(this.getExtent(), t, e) ? r : (this.maxDeltaRevision_ != this.getRevision() && (this.maxDelta_ = Math.sqrt(Pi(this.flatCoordinates, 0, this.ends_, this.stride, 0)), this.maxDeltaRevision_ = this.getRevision()), Oi(this.flatCoordinates, 0, this.ends_, this.stride, this.maxDelta_, !0, t, e, i, r))
|
||
}, e.prototype.containsXY = function (t, e) {
|
||
return Ji(this.getOrientedFlatCoordinates(), 0, this.ends_, this.stride, t, e)
|
||
}, e.prototype.getArea = function () {
|
||
return Si(this.getOrientedFlatCoordinates(), 0, this.ends_, this.stride)
|
||
}, e.prototype.getCoordinates = function (t) {
|
||
var e;
|
||
return void 0 !== t ? cr(e = this.getOrientedFlatCoordinates().slice(), 0, this.ends_, this.stride, t) : e = this.flatCoordinates, Gi(e, 0, this.ends_, this.stride)
|
||
}, e.prototype.getEnds = function () {
|
||
return this.ends_
|
||
}, e.prototype.getFlatInteriorPoint = function () {
|
||
if (this.flatInteriorPointRevision_ != this.getRevision()) {
|
||
var t = At(this.getExtent());
|
||
this.flatInteriorPoint_ = Qi(this.getOrientedFlatCoordinates(), 0, this.ends_, this.stride, t, 0), this.flatInteriorPointRevision_ = this.getRevision()
|
||
}
|
||
return this.flatInteriorPoint_
|
||
}, e.prototype.getInteriorPoint = function () {
|
||
return new qi(this.getFlatInteriorPoint(), qt.XYM)
|
||
}, e.prototype.getLinearRingCount = function () {
|
||
return this.ends_.length
|
||
}, e.prototype.getLinearRing = function (t) {
|
||
return t < 0 || this.ends_.length <= t ? null : new Xi(this.flatCoordinates.slice(0 === t ? 0 : this.ends_[t - 1], this.ends_[t]), this.layout)
|
||
}, e.prototype.getLinearRings = function () {
|
||
for (var t = this.layout, e = this.flatCoordinates, i = this.ends_, r = [], o = 0, n = 0, s = i.length; n < s; ++n) {
|
||
var a = i[n], l = new Xi(e.slice(o, a), t);
|
||
r.push(l), o = a
|
||
}
|
||
return r
|
||
}, e.prototype.getOrientedFlatCoordinates = function () {
|
||
if (this.orientedRevision_ != this.getRevision()) {
|
||
var t = this.flatCoordinates;
|
||
hr(t, 0, this.ends_, this.stride) ? this.orientedFlatCoordinates_ = t : (this.orientedFlatCoordinates_ = t.slice(), this.orientedFlatCoordinates_.length = cr(this.orientedFlatCoordinates_, 0, this.ends_, this.stride)), this.orientedRevision_ = this.getRevision()
|
||
}
|
||
return this.orientedFlatCoordinates_
|
||
}, e.prototype.getSimplifiedGeometryInternal = function (t) {
|
||
var i = [], r = [];
|
||
return i.length = Wi(this.flatCoordinates, 0, this.ends_, this.stride, Math.sqrt(t), i, 0, r), new e(i, qt.XY, r)
|
||
}, e.prototype.getType = function () {
|
||
return Zt.POLYGON
|
||
}, e.prototype.intersectsExtent = function (t) {
|
||
return nr(this.getOrientedFlatCoordinates(), 0, this.ends_, this.stride, t)
|
||
}, e.prototype.setCoordinates = function (t, e) {
|
||
this.setLayout(e, t, 2), this.flatCoordinates || (this.flatCoordinates = []);
|
||
var i = Fi(this.flatCoordinates, 0, t, this.stride, this.ends_);
|
||
this.flatCoordinates.length = 0 === i.length ? 0 : i[i.length - 1], this.changed()
|
||
}, e
|
||
}(bi), fr = dr;
|
||
|
||
function gr(t, e, i, r) {
|
||
for (var o = i || 32, n = [], s = 0; s < o; ++s) Q(n, ge(t, e, 2 * Math.PI * s / o, r));
|
||
return n.push(n[0], n[1]), new dr(n, qt.XY, [n.length])
|
||
}
|
||
|
||
function mr(t) {
|
||
var e = t[0], i = t[1], r = t[2], o = t[3], n = [e, i, e, o, r, o, r, i, e, i];
|
||
return new dr(n, qt.XY, [n.length])
|
||
}
|
||
|
||
function yr(t, e, i) {
|
||
for (var r = e || 32, o = t.getStride(), n = t.getLayout(), s = t.getCenter(), a = o * (r + 1), l = new Array(a), h = 0; h < a; h += o) {
|
||
l[h] = 0, l[h + 1] = 0;
|
||
for (var u = 2; u < o; u++) l[h + u] = s[u]
|
||
}
|
||
var c = [l.length], p = new dr(l, n, c);
|
||
return vr(p, s, t.getRadius(), i), p
|
||
}
|
||
|
||
function vr(t, e, i, r) {
|
||
for (var o = t.getFlatCoordinates(), n = t.getStride(), s = o.length / n - 1, a = r || 0, l = 0; l <= s; ++l) {
|
||
var h = l * n, u = a + 2 * le(l, s) * Math.PI / s;
|
||
o[h] = e[0] + i * Math.cos(u), o[h + 1] = e[1] + i * Math.sin(u)
|
||
}
|
||
t.changed()
|
||
}
|
||
|
||
var _r = "undefined" != typeof navigator ? navigator.userAgent.toLowerCase() : "",
|
||
xr = -1 !== _r.indexOf("firefox"), wr = -1 !== _r.indexOf("safari") && -1 == _r.indexOf("chrom"),
|
||
br = -1 !== _r.indexOf("webkit") && -1 == _r.indexOf("edge"), Cr = -1 !== _r.indexOf("macintosh"),
|
||
Sr = window.devicePixelRatio || 1, Er = function () {
|
||
var t = !1;
|
||
try {
|
||
t = !!document.createElement("canvas").getContext("2d").setLineDash
|
||
} catch (t) {
|
||
}
|
||
return t
|
||
}(), Tr = "geolocation" in navigator, Rr = "ontouchstart" in window, Pr = "PointerEvent" in window,
|
||
Lr = !!navigator.msPointerEnabled, Ir = {
|
||
ACCURACY: "accuracy",
|
||
ACCURACY_GEOMETRY: "accuracyGeometry",
|
||
ALTITUDE: "altitude",
|
||
ALTITUDE_ACCURACY: "altitudeAccuracy",
|
||
HEADING: "heading",
|
||
POSITION: "position",
|
||
PROJECTION: "projection",
|
||
SPEED: "speed",
|
||
TRACKING: "tracking",
|
||
TRACKING_OPTIONS: "trackingOptions"
|
||
}, Or = function (t) {
|
||
function e(e) {
|
||
t.call(this, F.ERROR), this.code = e.code, this.message = e.message
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A), Mr = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = e || {};
|
||
this.position_ = null, this.transform_ = Be, this.watchId_ = void 0, w(this, z(Ir.PROJECTION), this.handleProjectionChanged_, this), w(this, z(Ir.TRACKING), this.handleTrackingChanged_, this), void 0 !== i.projection && this.setProjection(i.projection), void 0 !== i.trackingOptions && this.setTrackingOptions(i.trackingOptions), this.setTracking(void 0 !== i.tracking && i.tracking)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.disposeInternal = function () {
|
||
this.setTracking(!1), t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.handleProjectionChanged_ = function () {
|
||
var t = this.getProjection();
|
||
t && (this.transform_ = ti(We("EPSG:4326"), t), this.position_ && this.set(Ir.POSITION, this.transform_(this.position_)))
|
||
}, e.prototype.handleTrackingChanged_ = function () {
|
||
if (Tr) {
|
||
var t = this.getTracking();
|
||
t && void 0 === this.watchId_ ? this.watchId_ = navigator.geolocation.watchPosition(this.positionChange_.bind(this), this.positionError_.bind(this), this.getTrackingOptions()) : t || void 0 === this.watchId_ || (navigator.geolocation.clearWatch(this.watchId_), this.watchId_ = void 0)
|
||
}
|
||
}, e.prototype.positionChange_ = function (t) {
|
||
var e = t.coords;
|
||
this.set(Ir.ACCURACY, e.accuracy), this.set(Ir.ALTITUDE, null === e.altitude ? void 0 : e.altitude), this.set(Ir.ALTITUDE_ACCURACY, null === e.altitudeAccuracy ? void 0 : e.altitudeAccuracy), this.set(Ir.HEADING, null === e.heading ? void 0 : ae(e.heading)), this.position_ ? (this.position_[0] = e.longitude, this.position_[1] = e.latitude) : this.position_ = [e.longitude, e.latitude];
|
||
var i = this.transform_(this.position_);
|
||
this.set(Ir.POSITION, i), this.set(Ir.SPEED, null === e.speed ? void 0 : e.speed);
|
||
var r = gr(this.position_, e.accuracy);
|
||
r.applyTransform(this.transform_), this.set(Ir.ACCURACY_GEOMETRY, r), this.changed()
|
||
}, e.prototype.positionError_ = function (t) {
|
||
this.setTracking(!1), this.dispatchEvent(new Or(t))
|
||
}, e.prototype.getAccuracy = function () {
|
||
return this.get(Ir.ACCURACY)
|
||
}, e.prototype.getAccuracyGeometry = function () {
|
||
return this.get(Ir.ACCURACY_GEOMETRY) || null
|
||
}, e.prototype.getAltitude = function () {
|
||
return this.get(Ir.ALTITUDE)
|
||
}, e.prototype.getAltitudeAccuracy = function () {
|
||
return this.get(Ir.ALTITUDE_ACCURACY)
|
||
}, e.prototype.getHeading = function () {
|
||
return this.get(Ir.HEADING)
|
||
}, e.prototype.getPosition = function () {
|
||
return this.get(Ir.POSITION)
|
||
}, e.prototype.getProjection = function () {
|
||
return this.get(Ir.PROJECTION)
|
||
}, e.prototype.getSpeed = function () {
|
||
return this.get(Ir.SPEED)
|
||
}, e.prototype.getTracking = function () {
|
||
return this.get(Ir.TRACKING)
|
||
}, e.prototype.getTrackingOptions = function () {
|
||
return this.get(Ir.TRACKING_OPTIONS)
|
||
}, e.prototype.setProjection = function (t) {
|
||
this.set(Ir.PROJECTION, We(t))
|
||
}, e.prototype.setTracking = function (t) {
|
||
this.set(Ir.TRACKING, t)
|
||
}, e.prototype.setTrackingOptions = function (t) {
|
||
this.set(Ir.TRACKING_OPTIONS, t)
|
||
}, e
|
||
}(U);
|
||
|
||
function Ar(t, e, i) {
|
||
var r = void 0 !== i ? t.toFixed(i) : "" + t, o = r.indexOf(".");
|
||
return (o = -1 === o ? r.length : o) > e ? r : new Array(1 + e - o).join("0") + r
|
||
}
|
||
|
||
function kr(t, e) {
|
||
for (var i = ("" + t).split("."), r = ("" + e).split("."), o = 0; o < Math.max(i.length, r.length); o++) {
|
||
var n = parseInt(i[o] || "0", 10), s = parseInt(r[o] || "0", 10);
|
||
if (n > s) return 1;
|
||
if (s > n) return -1
|
||
}
|
||
return 0
|
||
}
|
||
|
||
function Fr(t, e) {
|
||
return t[0] += e[0], t[1] += e[1], t
|
||
}
|
||
|
||
function Nr(t, e) {
|
||
var i = e.getRadius(), r = e.getCenter(), o = r[0], n = r[1], s = t[0] - o, a = t[1] - n;
|
||
0 === s && 0 === a && (s = 1);
|
||
var l = Math.sqrt(s * s + a * a);
|
||
return [o + i * s / l, n + i * a / l]
|
||
}
|
||
|
||
function Dr(t, e) {
|
||
var i, r, o = t[0], n = t[1], s = e[0], a = e[1], l = s[0], h = s[1], u = a[0], c = a[1], p = u - l,
|
||
d = c - h, f = 0 === p && 0 === d ? 0 : (p * (o - l) + d * (n - h)) / (p * p + d * d || 0);
|
||
return f <= 0 ? (i = l, r = h) : f >= 1 ? (i = u, r = c) : (i = l + f * p, r = h + f * d), [i, r]
|
||
}
|
||
|
||
function Gr(t, e, i) {
|
||
var r = le(e + 180, 360) - 180, o = Math.abs(3600 * r), n = i || 0, s = Math.pow(10, n),
|
||
a = Math.floor(o / 3600), l = Math.floor((o - 3600 * a) / 60), h = o - 3600 * a - 60 * l;
|
||
return (h = Math.ceil(h * s) / s) >= 60 && (h = 0, l += 1), l >= 60 && (l = 0, a += 1), a + "° " + Ar(l, 2) + "′ " + Ar(h, 2, n) + "″" + (0 == r ? "" : " " + t.charAt(r < 0 ? 1 : 0))
|
||
}
|
||
|
||
function jr(t, e, i) {
|
||
return t ? e.replace("{x}", t[0].toFixed(i)).replace("{y}", t[1].toFixed(i)) : ""
|
||
}
|
||
|
||
function zr(t, e) {
|
||
for (var i = !0, r = t.length - 1; r >= 0; --r) if (t[r] != e[r]) {
|
||
i = !1;
|
||
break
|
||
}
|
||
return i
|
||
}
|
||
|
||
function Ur(t, e) {
|
||
var i = Math.cos(e), r = Math.sin(e), o = t[0] * i - t[1] * r, n = t[1] * i + t[0] * r;
|
||
return t[0] = o, t[1] = n, t
|
||
}
|
||
|
||
function Br(t, e) {
|
||
return t[0] *= e, t[1] *= e, t
|
||
}
|
||
|
||
function Vr(t, e) {
|
||
var i = t[0] - e[0], r = t[1] - e[1];
|
||
return i * i + r * r
|
||
}
|
||
|
||
function Yr(t, e) {
|
||
return Math.sqrt(Vr(t, e))
|
||
}
|
||
|
||
function Wr(t, e) {
|
||
return Vr(t, Dr(t, e))
|
||
}
|
||
|
||
function Hr(t, e) {
|
||
return jr(t, "{x}, {y}", e)
|
||
}
|
||
|
||
function Xr(t, e, i, r, o, n) {
|
||
var s = NaN, a = NaN, l = (i - e) / r;
|
||
if (1 === l) s = t[e], a = t[e + 1]; else if (2 == l) s = (1 - o) * t[e] + o * t[e + r], a = (1 - o) * t[e + 1] + o * t[e + r + 1]; else if (0 !== l) {
|
||
for (var h = t[e], u = t[e + 1], c = 0, p = [0], d = e + r; d < i; d += r) {
|
||
var f = t[d], g = t[d + 1];
|
||
c += Math.sqrt((f - h) * (f - h) + (g - u) * (g - u)), p.push(c), h = f, u = g
|
||
}
|
||
var m = o * c, y = q(p, m);
|
||
if (y < 0) {
|
||
var v = (m - p[-y - 2]) / (p[-y - 1] - p[-y - 2]), _ = e + (-y - 2) * r;
|
||
s = he(t[_], t[_ + r], v), a = he(t[_ + 1], t[_ + r + 1], v)
|
||
} else s = t[e + y * r], a = t[e + y * r + 1]
|
||
}
|
||
return n ? (n[0] = s, n[1] = a, n) : [s, a]
|
||
}
|
||
|
||
function qr(t, e, i, r, o, n) {
|
||
if (i == e) return null;
|
||
var s;
|
||
if (o < t[e + r - 1]) return n ? ((s = t.slice(e, e + r))[r - 1] = o, s) : null;
|
||
if (t[i - 1] < o) return n ? ((s = t.slice(i - r, i))[r - 1] = o, s) : null;
|
||
if (o == t[e + r - 1]) return t.slice(e, e + r);
|
||
for (var a = e / r, l = i / r; a < l;) {
|
||
var h = a + l >> 1;
|
||
o < t[(h + 1) * r - 1] ? l = h : a = h + 1
|
||
}
|
||
var u = t[a * r - 1];
|
||
if (o == u) return t.slice((a - 1) * r, (a - 1) * r + r);
|
||
var c = (o - u) / (t[(a + 1) * r - 1] - u);
|
||
s = [];
|
||
for (var p = 0; p < r - 1; ++p) s.push(he(t[(a - 1) * r + p], t[a * r + p], c));
|
||
return s.push(o), s
|
||
}
|
||
|
||
function Zr(t, e, i, r, o, n, s) {
|
||
if (s) return qr(t, e, i[i.length - 1], r, o, n);
|
||
var a;
|
||
if (o < t[r - 1]) return n ? ((a = t.slice(0, r))[r - 1] = o, a) : null;
|
||
if (t[t.length - 1] < o) return n ? ((a = t.slice(t.length - r))[r - 1] = o, a) : null;
|
||
for (var l = 0, h = i.length; l < h; ++l) {
|
||
var u = i[l];
|
||
if (e != u) {
|
||
if (o < t[e + r - 1]) return null;
|
||
if (o <= t[u - 1]) return qr(t, e, u, r, o, !1);
|
||
e = u
|
||
}
|
||
}
|
||
return null
|
||
}
|
||
|
||
function Kr(t, e, i, r) {
|
||
for (var o = t[e], n = t[e + 1], s = 0, a = e + r; a < i; a += r) {
|
||
var l = t[a], h = t[a + 1];
|
||
s += Math.sqrt((l - o) * (l - o) + (h - n) * (h - n)), o = l, n = h
|
||
}
|
||
return s
|
||
}
|
||
|
||
var Jr = function (t) {
|
||
function e(e, i) {
|
||
t.call(this), this.flatMidpoint_ = null, this.flatMidpointRevision_ = -1, this.maxDelta_ = -1, this.maxDeltaRevision_ = -1, void 0 === i || Array.isArray(e[0]) ? this.setCoordinates(e, i) : this.setFlatCoordinates(i, e)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.appendCoordinate = function (t) {
|
||
this.flatCoordinates ? Q(this.flatCoordinates, t) : this.flatCoordinates = t.slice(), this.changed()
|
||
}, e.prototype.clone = function () {
|
||
return new e(this.flatCoordinates.slice(), this.layout)
|
||
}, e.prototype.closestPointXY = function (t, e, i, r) {
|
||
return r < ct(this.getExtent(), t, e) ? r : (this.maxDeltaRevision_ != this.getRevision() && (this.maxDelta_ = Math.sqrt(Ri(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, 0)), this.maxDeltaRevision_ = this.getRevision()), Ii(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, this.maxDelta_, !1, t, e, i, r))
|
||
}, e.prototype.forEachSegment = function (t) {
|
||
return er(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, t)
|
||
}, e.prototype.getCoordinateAtM = function (t, e) {
|
||
if (this.layout != qt.XYM && this.layout != qt.XYZM) return null;
|
||
var i = void 0 !== e && e;
|
||
return qr(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, t, i)
|
||
}, e.prototype.getCoordinates = function () {
|
||
return Di(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride)
|
||
}, e.prototype.getCoordinateAt = function (t, e) {
|
||
return Xr(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, t, e)
|
||
}, e.prototype.getLength = function () {
|
||
return Kr(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride)
|
||
}, e.prototype.getFlatMidpoint = function () {
|
||
return this.flatMidpointRevision_ != this.getRevision() && (this.flatMidpoint_ = this.getCoordinateAt(.5, this.flatMidpoint_), this.flatMidpointRevision_ = this.getRevision()), this.flatMidpoint_
|
||
}, e.prototype.getSimplifiedGeometryInternal = function (t) {
|
||
var i = [];
|
||
return i.length = zi(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, t, i, 0), new e(i, qt.XY)
|
||
}, e.prototype.getType = function () {
|
||
return Zt.LINE_STRING
|
||
}, e.prototype.intersectsExtent = function (t) {
|
||
return ir(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, t)
|
||
}, e.prototype.setCoordinates = function (t, e) {
|
||
this.setLayout(e, t, 1), this.flatCoordinates || (this.flatCoordinates = []), this.flatCoordinates.length = ki(this.flatCoordinates, 0, t, this.stride), this.changed()
|
||
}, e
|
||
}(bi);
|
||
|
||
function $r(t, e, i) {
|
||
for (var r, o, n, s, a, l, h = [], u = t(0), c = t(1), p = e(u), d = e(c), f = [c, u], g = [d, p], m = [1, 0], y = {}, v = 1e5; --v > 0 && m.length > 0;) n = m.pop(), u = f.pop(), p = g.pop(), (l = n.toString()) in y || (h.push(p[0], p[1]), y[l] = !0), s = m.pop(), c = f.pop(), d = g.pop(), re((o = e(r = t(a = (n + s) / 2)))[0], o[1], p[0], p[1], d[0], d[1]) < i ? (h.push(d[0], d[1]), y[l = s.toString()] = !0) : (m.push(s, a, a, n), g.push(d, o, o, p), f.push(c, r, r, u));
|
||
return h
|
||
}
|
||
|
||
function Qr(t, e, i, r, o) {
|
||
return $r(function (r) {
|
||
return [t, e + (i - e) * r]
|
||
}, ei(We("EPSG:4326"), r), o)
|
||
}
|
||
|
||
function to(t, e, i, r, o) {
|
||
return $r(function (r) {
|
||
return [e + (i - e) * r, t]
|
||
}, ei(We("EPSG:4326"), r), o)
|
||
}
|
||
|
||
var eo = {
|
||
POSTCOMPOSE: "postcompose",
|
||
PRECOMPOSE: "precompose",
|
||
RENDER: "render",
|
||
RENDERCOMPLETE: "rendercomplete"
|
||
}, io = /^#([a-f0-9]{3}|[a-f0-9]{4}(?:[a-f0-9]{2}){0,2})$/i, ro = /^([a-z]*)$/i;
|
||
|
||
function oo(t) {
|
||
return "string" == typeof t ? t : uo(t)
|
||
}
|
||
|
||
var no, so, ao = (no = {}, so = 0, function (t) {
|
||
var e;
|
||
if (no.hasOwnProperty(t)) e = no[t]; else {
|
||
if (so >= 1024) {
|
||
var i = 0;
|
||
for (var r in no) 0 == (3 & i++) && (delete no[r], --so)
|
||
}
|
||
e = function (t) {
|
||
var e, i, r, o, n;
|
||
if (ro.exec(t) && (t = function (t) {
|
||
var e = document.createElement("div");
|
||
if (e.style.color = t, "" !== e.style.color) {
|
||
document.body.appendChild(e);
|
||
var i = getComputedStyle(e).color;
|
||
return document.body.removeChild(e), i
|
||
}
|
||
return ""
|
||
}(t)), io.exec(t)) {
|
||
var s, a = t.length - 1;
|
||
s = a <= 4 ? 1 : 2;
|
||
var l = 4 === a || 8 === a;
|
||
e = parseInt(t.substr(1 + 0 * s, s), 16), i = parseInt(t.substr(1 + 1 * s, s), 16), r = parseInt(t.substr(1 + 2 * s, s), 16), o = l ? parseInt(t.substr(1 + 3 * s, s), 16) : 255, 1 == s && (e = (e << 4) + e, i = (i << 4) + i, r = (r << 4) + r, l && (o = (o << 4) + o)), n = [e, i, r, o / 255]
|
||
} else 0 == t.indexOf("rgba(") ? ho(n = t.slice(5, -1).split(",").map(Number)) : 0 == t.indexOf("rgb(") ? ((n = t.slice(4, -1).split(",").map(Number)).push(1), ho(n)) : W(!1, 14);
|
||
return n
|
||
}(t), no[t] = e, ++so
|
||
}
|
||
return e
|
||
});
|
||
|
||
function lo(t) {
|
||
return Array.isArray(t) ? t : ao(t)
|
||
}
|
||
|
||
function ho(t) {
|
||
return t[0] = te(t[0] + .5 | 0, 0, 255), t[1] = te(t[1] + .5 | 0, 0, 255), t[2] = te(t[2] + .5 | 0, 0, 255), t[3] = te(t[3], 0, 1), t
|
||
}
|
||
|
||
function uo(t) {
|
||
var e = t[0];
|
||
e != (0 | e) && (e = e + .5 | 0);
|
||
var i = t[1];
|
||
i != (0 | i) && (i = i + .5 | 0);
|
||
var r = t[2];
|
||
return r != (0 | r) && (r = r + .5 | 0), "rgba(" + e + "," + i + "," + r + "," + (void 0 === t[3] ? 1 : t[3]) + ")"
|
||
}
|
||
|
||
var co = function (t) {
|
||
var e = t || {};
|
||
this.color_ = void 0 !== e.color ? e.color : null, this.checksum_ = void 0
|
||
};
|
||
co.prototype.clone = function () {
|
||
var t = this.getColor();
|
||
return new co({color: Array.isArray(t) ? t.slice() : t || void 0})
|
||
}, co.prototype.getColor = function () {
|
||
return this.color_
|
||
}, co.prototype.setColor = function (t) {
|
||
this.color_ = t, this.checksum_ = void 0
|
||
}, co.prototype.getChecksum = function () {
|
||
if (void 0 === this.checksum_) {
|
||
var t = this.color_;
|
||
t ? Array.isArray(t) || "string" == typeof t ? this.checksum_ = "f" + oo(t) : this.checksum_ = a(this.color_) : this.checksum_ = "f-"
|
||
}
|
||
return this.checksum_
|
||
};
|
||
var po = co, fo = function (t) {
|
||
var e = t || {};
|
||
this.color_ = void 0 !== e.color ? e.color : null, this.lineCap_ = e.lineCap, this.lineDash_ = void 0 !== e.lineDash ? e.lineDash : null, this.lineDashOffset_ = e.lineDashOffset, this.lineJoin_ = e.lineJoin, this.miterLimit_ = e.miterLimit, this.width_ = e.width, this.checksum_ = void 0
|
||
};
|
||
fo.prototype.clone = function () {
|
||
var t = this.getColor();
|
||
return new fo({
|
||
color: Array.isArray(t) ? t.slice() : t || void 0,
|
||
lineCap: this.getLineCap(),
|
||
lineDash: this.getLineDash() ? this.getLineDash().slice() : void 0,
|
||
lineDashOffset: this.getLineDashOffset(),
|
||
lineJoin: this.getLineJoin(),
|
||
miterLimit: this.getMiterLimit(),
|
||
width: this.getWidth()
|
||
})
|
||
}, fo.prototype.getColor = function () {
|
||
return this.color_
|
||
}, fo.prototype.getLineCap = function () {
|
||
return this.lineCap_
|
||
}, fo.prototype.getLineDash = function () {
|
||
return this.lineDash_
|
||
}, fo.prototype.getLineDashOffset = function () {
|
||
return this.lineDashOffset_
|
||
}, fo.prototype.getLineJoin = function () {
|
||
return this.lineJoin_
|
||
}, fo.prototype.getMiterLimit = function () {
|
||
return this.miterLimit_
|
||
}, fo.prototype.getWidth = function () {
|
||
return this.width_
|
||
}, fo.prototype.setColor = function (t) {
|
||
this.color_ = t, this.checksum_ = void 0
|
||
}, fo.prototype.setLineCap = function (t) {
|
||
this.lineCap_ = t, this.checksum_ = void 0
|
||
}, fo.prototype.setLineDash = function (t) {
|
||
this.lineDash_ = t, this.checksum_ = void 0
|
||
}, fo.prototype.setLineDashOffset = function (t) {
|
||
this.lineDashOffset_ = t, this.checksum_ = void 0
|
||
}, fo.prototype.setLineJoin = function (t) {
|
||
this.lineJoin_ = t, this.checksum_ = void 0
|
||
}, fo.prototype.setMiterLimit = function (t) {
|
||
this.miterLimit_ = t, this.checksum_ = void 0
|
||
}, fo.prototype.setWidth = function (t) {
|
||
this.width_ = t, this.checksum_ = void 0
|
||
}, fo.prototype.getChecksum = function () {
|
||
return void 0 === this.checksum_ && (this.checksum_ = "s", this.color_ ? "string" == typeof this.color_ ? this.checksum_ += this.color_ : this.checksum_ += a(this.color_) : this.checksum_ += "-", this.checksum_ += "," + (void 0 !== this.lineCap_ ? this.lineCap_.toString() : "-") + "," + (this.lineDash_ ? this.lineDash_.toString() : "-") + "," + (void 0 !== this.lineDashOffset_ ? this.lineDashOffset_ : "-") + "," + (void 0 !== this.lineJoin_ ? this.lineJoin_ : "-") + "," + (void 0 !== this.miterLimit_ ? this.miterLimit_.toString() : "-") + "," + (void 0 !== this.width_ ? this.width_.toString() : "-")), this.checksum_
|
||
};
|
||
var go = fo, mo = {POINT: "point", LINE: "line"}, yo = function (t) {
|
||
var e = t || {};
|
||
this.font_ = e.font, this.rotation_ = e.rotation, this.rotateWithView_ = e.rotateWithView, this.scale_ = e.scale, this.text_ = e.text, this.textAlign_ = e.textAlign, this.textBaseline_ = e.textBaseline, this.fill_ = void 0 !== e.fill ? e.fill : new po({color: "#333"}), this.maxAngle_ = void 0 !== e.maxAngle ? e.maxAngle : Math.PI / 4, this.placement_ = void 0 !== e.placement ? e.placement : mo.POINT, this.overflow_ = !!e.overflow, this.stroke_ = void 0 !== e.stroke ? e.stroke : null, this.offsetX_ = void 0 !== e.offsetX ? e.offsetX : 0, this.offsetY_ = void 0 !== e.offsetY ? e.offsetY : 0, this.backgroundFill_ = e.backgroundFill ? e.backgroundFill : null, this.backgroundStroke_ = e.backgroundStroke ? e.backgroundStroke : null, this.padding_ = void 0 === e.padding ? null : e.padding
|
||
};
|
||
yo.prototype.clone = function () {
|
||
return new yo({
|
||
font: this.getFont(),
|
||
placement: this.getPlacement(),
|
||
maxAngle: this.getMaxAngle(),
|
||
overflow: this.getOverflow(),
|
||
rotation: this.getRotation(),
|
||
rotateWithView: this.getRotateWithView(),
|
||
scale: this.getScale(),
|
||
text: this.getText(),
|
||
textAlign: this.getTextAlign(),
|
||
textBaseline: this.getTextBaseline(),
|
||
fill: this.getFill() ? this.getFill().clone() : void 0,
|
||
stroke: this.getStroke() ? this.getStroke().clone() : void 0,
|
||
offsetX: this.getOffsetX(),
|
||
offsetY: this.getOffsetY(),
|
||
backgroundFill: this.getBackgroundFill() ? this.getBackgroundFill().clone() : void 0,
|
||
backgroundStroke: this.getBackgroundStroke() ? this.getBackgroundStroke().clone() : void 0
|
||
})
|
||
}, yo.prototype.getOverflow = function () {
|
||
return this.overflow_
|
||
}, yo.prototype.getFont = function () {
|
||
return this.font_
|
||
}, yo.prototype.getMaxAngle = function () {
|
||
return this.maxAngle_
|
||
}, yo.prototype.getPlacement = function () {
|
||
return this.placement_
|
||
}, yo.prototype.getOffsetX = function () {
|
||
return this.offsetX_
|
||
}, yo.prototype.getOffsetY = function () {
|
||
return this.offsetY_
|
||
}, yo.prototype.getFill = function () {
|
||
return this.fill_
|
||
}, yo.prototype.getRotateWithView = function () {
|
||
return this.rotateWithView_
|
||
}, yo.prototype.getRotation = function () {
|
||
return this.rotation_
|
||
}, yo.prototype.getScale = function () {
|
||
return this.scale_
|
||
}, yo.prototype.getStroke = function () {
|
||
return this.stroke_
|
||
}, yo.prototype.getText = function () {
|
||
return this.text_
|
||
}, yo.prototype.getTextAlign = function () {
|
||
return this.textAlign_
|
||
}, yo.prototype.getTextBaseline = function () {
|
||
return this.textBaseline_
|
||
}, yo.prototype.getBackgroundFill = function () {
|
||
return this.backgroundFill_
|
||
}, yo.prototype.getBackgroundStroke = function () {
|
||
return this.backgroundStroke_
|
||
}, yo.prototype.getPadding = function () {
|
||
return this.padding_
|
||
}, yo.prototype.setOverflow = function (t) {
|
||
this.overflow_ = t
|
||
}, yo.prototype.setFont = function (t) {
|
||
this.font_ = t
|
||
}, yo.prototype.setMaxAngle = function (t) {
|
||
this.maxAngle_ = t
|
||
}, yo.prototype.setOffsetX = function (t) {
|
||
this.offsetX_ = t
|
||
}, yo.prototype.setOffsetY = function (t) {
|
||
this.offsetY_ = t
|
||
}, yo.prototype.setPlacement = function (t) {
|
||
this.placement_ = t
|
||
}, yo.prototype.setFill = function (t) {
|
||
this.fill_ = t
|
||
}, yo.prototype.setRotation = function (t) {
|
||
this.rotation_ = t
|
||
}, yo.prototype.setScale = function (t) {
|
||
this.scale_ = t
|
||
}, yo.prototype.setStroke = function (t) {
|
||
this.stroke_ = t
|
||
}, yo.prototype.setText = function (t) {
|
||
this.text_ = t
|
||
}, yo.prototype.setTextAlign = function (t) {
|
||
this.textAlign_ = t
|
||
}, yo.prototype.setTextBaseline = function (t) {
|
||
this.textBaseline_ = t
|
||
}, yo.prototype.setBackgroundFill = function (t) {
|
||
this.backgroundFill_ = t
|
||
}, yo.prototype.setBackgroundStroke = function (t) {
|
||
this.backgroundStroke_ = t
|
||
}, yo.prototype.setPadding = function (t) {
|
||
this.padding_ = t
|
||
};
|
||
var vo = yo, _o = new go({color: "rgba(0,0,0,0.2)"}),
|
||
xo = [90, 45, 30, 20, 10, 5, 2, 1, .5, .2, .1, .05, .01, .005, .002, .001], wo = function (t) {
|
||
var e = t || {};
|
||
this.map_ = null, this.postcomposeListenerKey_ = null, this.projection_ = null, this.maxLat_ = 1 / 0, this.maxLon_ = 1 / 0, this.minLat_ = -1 / 0, this.minLon_ = -1 / 0, this.maxLatP_ = 1 / 0, this.maxLonP_ = 1 / 0, this.minLatP_ = -1 / 0, this.minLonP_ = -1 / 0, this.targetSize_ = void 0 !== e.targetSize ? e.targetSize : 100, this.maxLines_ = void 0 !== e.maxLines ? e.maxLines : 100, this.meridians_ = [], this.parallels_ = [], this.strokeStyle_ = void 0 !== e.strokeStyle ? e.strokeStyle : _o, this.fromLonLatTransform_ = void 0, this.toLonLatTransform_ = void 0, this.projectionCenterLonLat_ = null, this.meridiansLabels_ = null, this.parallelsLabels_ = null, 1 == e.showLabels && (this.lonLabelFormatter_ = null == e.lonLabelFormatter ? Gr.bind(this, "EW") : e.lonLabelFormatter, this.latLabelFormatter_ = null == e.latLabelFormatter ? Gr.bind(this, "NS") : e.latLabelFormatter, this.lonLabelPosition_ = null == e.lonLabelPosition ? 0 : e.lonLabelPosition, this.latLabelPosition_ = null == e.latLabelPosition ? 1 : e.latLabelPosition, this.lonLabelStyle_ = void 0 !== e.lonLabelStyle ? e.lonLabelStyle : new vo({
|
||
font: "12px Calibri,sans-serif",
|
||
textBaseline: "bottom",
|
||
fill: new po({color: "rgba(0,0,0,1)"}),
|
||
stroke: new go({color: "rgba(255,255,255,1)", width: 3})
|
||
}), this.latLabelStyle_ = void 0 !== e.latLabelStyle ? e.latLabelStyle : new vo({
|
||
font: "12px Calibri,sans-serif",
|
||
textAlign: "end",
|
||
fill: new po({color: "rgba(0,0,0,1)"}),
|
||
stroke: new go({color: "rgba(255,255,255,1)", width: 3})
|
||
}), this.meridiansLabels_ = [], this.parallelsLabels_ = []), this.intervals_ = void 0 !== e.intervals ? e.intervals : xo, this.setMap(void 0 !== e.map ? e.map : null)
|
||
};
|
||
wo.prototype.addMeridian_ = function (t, e, i, r, o, n) {
|
||
var s = this.getMeridian_(t, e, i, r, n);
|
||
if (Bt(s.getExtent(), o)) {
|
||
if (this.meridiansLabels_) {
|
||
var a = this.getMeridianPoint_(s, o, n);
|
||
this.meridiansLabels_[n] = {geom: a, text: this.lonLabelFormatter_(t)}
|
||
}
|
||
this.meridians_[n++] = s
|
||
}
|
||
return n
|
||
}, wo.prototype.getMeridianPoint_ = function (t, e, i) {
|
||
var r, o = t.getFlatCoordinates(), n = Math.max(e[1], o[1]), s = Math.min(e[3], o[o.length - 1]),
|
||
a = te(e[1] + Math.abs(e[1] - e[3]) * this.lonLabelPosition_, n, s), l = [o[0], a];
|
||
return i in this.meridiansLabels_ ? (r = this.meridiansLabels_[i].geom).setCoordinates(l) : r = new qi(l), r
|
||
}, wo.prototype.addParallel_ = function (t, e, i, r, o, n) {
|
||
var s = this.getParallel_(t, e, i, r, n);
|
||
if (Bt(s.getExtent(), o)) {
|
||
if (this.parallelsLabels_) {
|
||
var a = this.getParallelPoint_(s, o, n);
|
||
this.parallelsLabels_[n] = {geom: a, text: this.latLabelFormatter_(t)}
|
||
}
|
||
this.parallels_[n++] = s
|
||
}
|
||
return n
|
||
}, wo.prototype.getParallelPoint_ = function (t, e, i) {
|
||
var r, o = t.getFlatCoordinates(), n = Math.max(e[0], o[0]), s = Math.min(e[2], o[o.length - 2]),
|
||
a = [te(e[0] + Math.abs(e[0] - e[2]) * this.latLabelPosition_, n, s), o[1]];
|
||
return i in this.parallelsLabels_ ? (r = this.parallelsLabels_[i].geom).setCoordinates(a) : r = new qi(a), r
|
||
}, wo.prototype.createGraticule_ = function (t, e, i, r) {
|
||
var o = this.getInterval_(i);
|
||
if (-1 == o) return this.meridians_.length = this.parallels_.length = 0, this.meridiansLabels_ && (this.meridiansLabels_.length = 0), void (this.parallelsLabels_ && (this.parallelsLabels_.length = 0));
|
||
var n, s, a, l, h = this.toLonLatTransform_(e), u = h[0], c = h[1], p = this.maxLines_,
|
||
d = [Math.max(t[0], this.minLonP_), Math.max(t[1], this.minLatP_), Math.min(t[2], this.maxLonP_), Math.min(t[3], this.maxLatP_)],
|
||
f = (d = ri(d, this.projection_, "EPSG:4326"))[3], g = d[2], m = d[1], y = d[0];
|
||
for (l = te(u = Math.floor(u / o) * o, this.minLon_, this.maxLon_), s = this.addMeridian_(l, m, f, r, t, 0), n = 0; l != this.minLon_ && n++ < p;) l = Math.max(l - o, this.minLon_), s = this.addMeridian_(l, m, f, r, t, s);
|
||
for (l = te(u, this.minLon_, this.maxLon_), n = 0; l != this.maxLon_ && n++ < p;) l = Math.min(l + o, this.maxLon_), s = this.addMeridian_(l, m, f, r, t, s);
|
||
for (this.meridians_.length = s, this.meridiansLabels_ && (this.meridiansLabels_.length = s), a = te(c = Math.floor(c / o) * o, this.minLat_, this.maxLat_), s = this.addParallel_(a, y, g, r, t, 0), n = 0; a != this.minLat_ && n++ < p;) a = Math.max(a - o, this.minLat_), s = this.addParallel_(a, y, g, r, t, s);
|
||
for (a = te(c, this.minLat_, this.maxLat_), n = 0; a != this.maxLat_ && n++ < p;) a = Math.min(a + o, this.maxLat_), s = this.addParallel_(a, y, g, r, t, s);
|
||
this.parallels_.length = s, this.parallelsLabels_ && (this.parallelsLabels_.length = s)
|
||
}, wo.prototype.getInterval_ = function (t) {
|
||
for (var e = this.projectionCenterLonLat_[0], i = this.projectionCenterLonLat_[1], r = -1, o = Math.pow(this.targetSize_ * t, 2), n = [], s = [], a = 0, l = this.intervals_.length; a < l; ++a) {
|
||
var h = this.intervals_[a] / 2;
|
||
if (n[0] = e - h, n[1] = i - h, s[0] = e + h, s[1] = i + h, this.fromLonLatTransform_(n, n), this.fromLonLatTransform_(s, s), Math.pow(s[0] - n[0], 2) + Math.pow(s[1] - n[1], 2) <= o) break;
|
||
r = this.intervals_[a]
|
||
}
|
||
return r
|
||
}, wo.prototype.getMap = function () {
|
||
return this.map_
|
||
}, wo.prototype.getMeridian_ = function (t, e, i, r, o) {
|
||
var n = Qr(t, e, i, this.projection_, r), s = this.meridians_[o];
|
||
return s ? (s.setFlatCoordinates(qt.XY, n), s.changed()) : s = this.meridians_[o] = new Jr(n, qt.XY), s
|
||
}, wo.prototype.getMeridians = function () {
|
||
return this.meridians_
|
||
}, wo.prototype.getParallel_ = function (t, e, i, r, o) {
|
||
var n = to(t, e, i, this.projection_, r), s = this.parallels_[o];
|
||
return s ? (s.setFlatCoordinates(qt.XY, n), s.changed()) : s = new Jr(n, qt.XY), s
|
||
}, wo.prototype.getParallels = function () {
|
||
return this.parallels_
|
||
}, wo.prototype.handlePostCompose_ = function (t) {
|
||
var e, i, r, o, n = t.vectorContext, s = t.frameState, a = s.extent, l = s.viewState, h = l.center,
|
||
u = l.projection, c = l.resolution, p = s.pixelRatio, d = c * c / (4 * p * p);
|
||
for ((!this.projection_ || !Qe(this.projection_, u)) && this.updateProjectionInfo_(u), this.createGraticule_(a, h, c, d), n.setFillStrokeStyle(null, this.strokeStyle_), e = 0, i = this.meridians_.length; e < i; ++e) r = this.meridians_[e], n.drawGeometry(r);
|
||
for (e = 0, i = this.parallels_.length; e < i; ++e) r = this.parallels_[e], n.drawGeometry(r);
|
||
if (this.meridiansLabels_) for (e = 0, i = this.meridiansLabels_.length; e < i; ++e) o = this.meridiansLabels_[e], this.lonLabelStyle_.setText(o.text), n.setTextStyle(this.lonLabelStyle_), n.drawGeometry(o.geom);
|
||
if (this.parallelsLabels_) for (e = 0, i = this.parallelsLabels_.length; e < i; ++e) o = this.parallelsLabels_[e], this.latLabelStyle_.setText(o.text), n.setTextStyle(this.latLabelStyle_), n.drawGeometry(o.geom)
|
||
}, wo.prototype.updateProjectionInfo_ = function (t) {
|
||
var e = We("EPSG:4326"), i = t.getWorldExtent(), r = ri(i, e, t);
|
||
this.maxLat_ = i[3], this.maxLon_ = i[2], this.minLat_ = i[1], this.minLon_ = i[0], this.maxLatP_ = r[3], this.maxLonP_ = r[2], this.minLatP_ = r[1], this.minLonP_ = r[0], this.fromLonLatTransform_ = ei(e, t), this.toLonLatTransform_ = ei(t, e), this.projectionCenterLonLat_ = this.toLonLatTransform_(At(t.getExtent())), this.projection_ = t
|
||
}, wo.prototype.setMap = function (t) {
|
||
this.map_ && (S(this.postcomposeListenerKey_), this.postcomposeListenerKey_ = null, this.map_.render()), t && (this.postcomposeListenerKey_ = w(t, eo.POSTCOMPOSE, this.handlePostCompose_, this), t.render()), this.map_ = t
|
||
};
|
||
var bo = wo, Co = function (t) {
|
||
function e(e, i, r, o) {
|
||
t.call(this), this.extent = e, this.pixelRatio_ = r, this.resolution = i, this.state = o
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.changed = function () {
|
||
this.dispatchEvent(F.CHANGE)
|
||
}, e.prototype.getExtent = function () {
|
||
return this.extent
|
||
}, e.prototype.getImage = function () {
|
||
return n()
|
||
}, e.prototype.getPixelRatio = function () {
|
||
return this.pixelRatio_
|
||
}, e.prototype.getResolution = function () {
|
||
return this.resolution
|
||
}, e.prototype.getState = function () {
|
||
return this.state
|
||
}, e.prototype.load = function () {
|
||
n()
|
||
}, e
|
||
}(k), So = {IDLE: 0, LOADING: 1, LOADED: 2, ERROR: 3}, Eo = function (t) {
|
||
function e(e, i, r, o, n, s) {
|
||
t.call(this, e, i, r, So.IDLE), this.src_ = o, this.image_ = new Image, null !== n && (this.image_.crossOrigin = n), this.imageListenerKeys_ = null, this.state = So.IDLE, this.imageLoadFunction_ = s
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getImage = function () {
|
||
return this.image_
|
||
}, e.prototype.handleImageError_ = function () {
|
||
this.state = So.ERROR, this.unlistenImage_(), this.changed()
|
||
}, e.prototype.handleImageLoad_ = function () {
|
||
void 0 === this.resolution && (this.resolution = Nt(this.extent) / this.image_.height), this.state = So.LOADED, this.unlistenImage_(), this.changed()
|
||
}, e.prototype.load = function () {
|
||
this.state != So.IDLE && this.state != So.ERROR || (this.state = So.LOADING, this.changed(), this.imageListenerKeys_ = [b(this.image_, F.ERROR, this.handleImageError_, this), b(this.image_, F.LOAD, this.handleImageLoad_, this)], this.imageLoadFunction_(this, this.src_))
|
||
}, e.prototype.setImage = function (t) {
|
||
this.image_ = t
|
||
}, e.prototype.unlistenImage_ = function () {
|
||
this.imageListenerKeys_.forEach(S), this.imageListenerKeys_ = null
|
||
}, e
|
||
}(Co), To = function (t) {
|
||
function e(e, i, r, o, n) {
|
||
var s = void 0 !== n ? So.IDLE : So.LOADED;
|
||
t.call(this, e, i, r, s), this.loader_ = void 0 !== n ? n : null, this.canvas_ = o, this.error_ = null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getError = function () {
|
||
return this.error_
|
||
}, e.prototype.handleLoad_ = function (t) {
|
||
t ? (this.error_ = t, this.state = So.ERROR) : this.state = So.LOADED, this.changed()
|
||
}, e.prototype.load = function () {
|
||
this.state == So.IDLE && (this.state = So.LOADING, this.changed(), this.loader_(this.handleLoad_.bind(this)))
|
||
}, e.prototype.getImage = function () {
|
||
return this.canvas_
|
||
}, e
|
||
}(Co), Ro = {IDLE: 0, LOADING: 1, LOADED: 2, ERROR: 3, EMPTY: 4, ABORT: 5};
|
||
|
||
function Po(t) {
|
||
return Math.pow(t, 3)
|
||
}
|
||
|
||
function Lo(t) {
|
||
return 1 - Po(1 - t)
|
||
}
|
||
|
||
function Io(t) {
|
||
return 3 * t * t - 2 * t * t * t
|
||
}
|
||
|
||
function Oo(t) {
|
||
return t
|
||
}
|
||
|
||
var Mo = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this);
|
||
var o = r || {};
|
||
this.tileCoord = e, this.state = i, this.interimTile = null, this.key = "", this.transition_ = void 0 === o.transition ? 250 : o.transition, this.transitionStarts_ = {}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.changed = function () {
|
||
this.dispatchEvent(F.CHANGE)
|
||
}, e.prototype.getKey = function () {
|
||
return this.key + "/" + this.tileCoord
|
||
}, e.prototype.getInterimTile = function () {
|
||
if (!this.interimTile) return this;
|
||
var t = this.interimTile;
|
||
do {
|
||
if (t.getState() == Ro.LOADED) return t;
|
||
t = t.interimTile
|
||
} while (t);
|
||
return this
|
||
}, e.prototype.refreshInterimChain = function () {
|
||
if (this.interimTile) {
|
||
var t = this.interimTile, e = this;
|
||
do {
|
||
if (t.getState() == Ro.LOADED) {
|
||
t.interimTile = null;
|
||
break
|
||
}
|
||
t.getState() == Ro.LOADING ? e = t : t.getState() == Ro.IDLE ? e.interimTile = t.interimTile : e = t, t = e.interimTile
|
||
} while (t)
|
||
}
|
||
}, e.prototype.getTileCoord = function () {
|
||
return this.tileCoord
|
||
}, e.prototype.getState = function () {
|
||
return this.state
|
||
}, e.prototype.setState = function (t) {
|
||
this.state = t, this.changed()
|
||
}, e.prototype.load = function () {
|
||
}, e.prototype.getAlpha = function (t, e) {
|
||
if (!this.transition_) return 1;
|
||
var i = this.transitionStarts_[t];
|
||
if (i) {
|
||
if (-1 === i) return 1
|
||
} else i = e, this.transitionStarts_[t] = i;
|
||
var r = e - i + 1e3 / 60;
|
||
return r >= this.transition_ ? 1 : Po(r / this.transition_)
|
||
}, e.prototype.inTransition = function (t) {
|
||
return !!this.transition_ && -1 !== this.transitionStarts_[t]
|
||
}, e.prototype.endTransition = function (t) {
|
||
this.transition_ && (this.transitionStarts_[t] = -1)
|
||
}, e
|
||
}(k);
|
||
|
||
function Ao(t, e) {
|
||
var i = document.createElement("canvas");
|
||
return t && (i.width = t), e && (i.height = e), i.getContext("2d")
|
||
}
|
||
|
||
function ko(t) {
|
||
var e = t.offsetWidth, i = getComputedStyle(t);
|
||
return e += parseInt(i.marginLeft, 10) + parseInt(i.marginRight, 10)
|
||
}
|
||
|
||
function Fo(t) {
|
||
var e = t.offsetHeight, i = getComputedStyle(t);
|
||
return e += parseInt(i.marginTop, 10) + parseInt(i.marginBottom, 10)
|
||
}
|
||
|
||
function No(t, e) {
|
||
var i = e.parentNode;
|
||
i && i.replaceChild(t, e)
|
||
}
|
||
|
||
function Do(t) {
|
||
return t && t.parentNode ? t.parentNode.removeChild(t) : null
|
||
}
|
||
|
||
function Go(t) {
|
||
for (; t.lastChild;) t.removeChild(t.lastChild)
|
||
}
|
||
|
||
function jo() {
|
||
var t = Ao(1, 1);
|
||
return t.fillStyle = "rgba(0,0,0,0)", t.fillRect(0, 0, 1, 1), t.canvas
|
||
}
|
||
|
||
var zo = function (t) {
|
||
function e(e, i, r, o, n, s) {
|
||
t.call(this, e, i, s), this.crossOrigin_ = o, this.src_ = r, this.image_ = new Image, null !== o && (this.image_.crossOrigin = o), this.imageListenerKeys_ = null, this.tileLoadFunction_ = n
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.disposeInternal = function () {
|
||
this.state == Ro.LOADING && (this.unlistenImage_(), this.image_ = jo()), this.interimTile && this.interimTile.dispose(), this.state = Ro.ABORT, this.changed(), t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.getImage = function () {
|
||
return this.image_
|
||
}, e.prototype.getKey = function () {
|
||
return this.src_
|
||
}, e.prototype.handleImageError_ = function () {
|
||
this.state = Ro.ERROR, this.unlistenImage_(), this.image_ = jo(), this.changed()
|
||
}, e.prototype.handleImageLoad_ = function () {
|
||
var t = this.image_;
|
||
t.naturalWidth && t.naturalHeight ? this.state = Ro.LOADED : this.state = Ro.EMPTY, this.unlistenImage_(), this.changed()
|
||
}, e.prototype.load = function () {
|
||
this.state == Ro.ERROR && (this.state = Ro.IDLE, this.image_ = new Image, null !== this.crossOrigin_ && (this.image_.crossOrigin = this.crossOrigin_)), this.state == Ro.IDLE && (this.state = Ro.LOADING, this.changed(), this.imageListenerKeys_ = [b(this.image_, F.ERROR, this.handleImageError_, this), b(this.image_, F.LOAD, this.handleImageLoad_, this)], this.tileLoadFunction_(this, this.src_))
|
||
}, e.prototype.unlistenImage_ = function () {
|
||
this.imageListenerKeys_.forEach(S), this.imageListenerKeys_ = null
|
||
}, e
|
||
}(Mo), Uo = function (t, e, i) {
|
||
this.decay_ = t, this.minVelocity_ = e, this.delay_ = i, this.points_ = [], this.angle_ = 0, this.initialVelocity_ = 0
|
||
};
|
||
Uo.prototype.begin = function () {
|
||
this.points_.length = 0, this.angle_ = 0, this.initialVelocity_ = 0
|
||
}, Uo.prototype.update = function (t, e) {
|
||
this.points_.push(t, e, Date.now())
|
||
}, Uo.prototype.end = function () {
|
||
if (this.points_.length < 6) return !1;
|
||
var t = Date.now() - this.delay_, e = this.points_.length - 3;
|
||
if (this.points_[e + 2] < t) return !1;
|
||
for (var i = e - 3; i > 0 && this.points_[i + 2] > t;) i -= 3;
|
||
var r = this.points_[e + 2] - this.points_[i + 2];
|
||
if (r < 1e3 / 60) return !1;
|
||
var o = this.points_[e] - this.points_[i], n = this.points_[e + 1] - this.points_[i + 1];
|
||
return this.angle_ = Math.atan2(n, o), this.initialVelocity_ = Math.sqrt(o * o + n * n) / r, this.initialVelocity_ > this.minVelocity_
|
||
}, Uo.prototype.getDistance = function () {
|
||
return (this.minVelocity_ - this.initialVelocity_) / this.decay_
|
||
}, Uo.prototype.getAngle = function () {
|
||
return this.angle_
|
||
};
|
||
var Bo = Uo, Vo = {IMAGE: "IMAGE", TILE: "TILE", VECTOR_TILE: "VECTOR_TILE", VECTOR: "VECTOR"},
|
||
Yo = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, e), this.map = i, this.frameState = void 0 !== r ? r : null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A), Wo = function (t) {
|
||
function e(e, i, r, o, n) {
|
||
t.call(this, e, i, n), this.originalEvent = r, this.pixel = i.getEventPixel(r), this.coordinate = i.getCoordinateFromPixel(this.pixel), this.dragging = void 0 !== o && o
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.preventDefault = function () {
|
||
t.prototype.preventDefault.call(this), this.originalEvent.preventDefault()
|
||
}, e.prototype.stopPropagation = function () {
|
||
t.prototype.stopPropagation.call(this), this.originalEvent.stopPropagation()
|
||
}, e
|
||
}(Yo), Ho = {
|
||
SINGLECLICK: "singleclick",
|
||
CLICK: F.CLICK,
|
||
DBLCLICK: F.DBLCLICK,
|
||
POINTERDRAG: "pointerdrag",
|
||
POINTERMOVE: "pointermove",
|
||
POINTERDOWN: "pointerdown",
|
||
POINTERUP: "pointerup",
|
||
POINTEROVER: "pointerover",
|
||
POINTEROUT: "pointerout",
|
||
POINTERENTER: "pointerenter",
|
||
POINTERLEAVE: "pointerleave",
|
||
POINTERCANCEL: "pointercancel"
|
||
}, Xo = function (t) {
|
||
function e(e, i, r, o, n) {
|
||
t.call(this, e, i, r.originalEvent, o, n), this.pointerEvent = r
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(Wo), qo = {
|
||
POINTERMOVE: "pointermove",
|
||
POINTERDOWN: "pointerdown",
|
||
POINTERUP: "pointerup",
|
||
POINTEROVER: "pointerover",
|
||
POINTEROUT: "pointerout",
|
||
POINTERENTER: "pointerenter",
|
||
POINTERLEAVE: "pointerleave",
|
||
POINTERCANCEL: "pointercancel"
|
||
}, Zo = function (t, e) {
|
||
this.dispatcher = t, this.mapping_ = e
|
||
};
|
||
Zo.prototype.getEvents = function () {
|
||
return Object.keys(this.mapping_)
|
||
}, Zo.prototype.getHandlerForEvent = function (t) {
|
||
return this.mapping_[t]
|
||
};
|
||
var Ko = Zo, Jo = 1, $o = "mouse";
|
||
|
||
function Qo(t) {
|
||
if (!this.isEventSimulatedFromTouch_(t)) {
|
||
Jo.toString() in this.pointerMap && this.cancel(t);
|
||
var e = nn(t, this.dispatcher);
|
||
this.pointerMap[Jo.toString()] = t, this.dispatcher.down(e, t)
|
||
}
|
||
}
|
||
|
||
function tn(t) {
|
||
if (!this.isEventSimulatedFromTouch_(t)) {
|
||
var e = nn(t, this.dispatcher);
|
||
this.dispatcher.move(e, t)
|
||
}
|
||
}
|
||
|
||
function en(t) {
|
||
if (!this.isEventSimulatedFromTouch_(t)) {
|
||
var e = this.pointerMap[Jo.toString()];
|
||
if (e && e.button === t.button) {
|
||
var i = nn(t, this.dispatcher);
|
||
this.dispatcher.up(i, t), this.cleanupMouse()
|
||
}
|
||
}
|
||
}
|
||
|
||
function rn(t) {
|
||
if (!this.isEventSimulatedFromTouch_(t)) {
|
||
var e = nn(t, this.dispatcher);
|
||
this.dispatcher.enterOver(e, t)
|
||
}
|
||
}
|
||
|
||
function on(t) {
|
||
if (!this.isEventSimulatedFromTouch_(t)) {
|
||
var e = nn(t, this.dispatcher);
|
||
this.dispatcher.leaveOut(e, t)
|
||
}
|
||
}
|
||
|
||
function nn(t, e) {
|
||
var i = e.cloneEvent(t, t), r = i.preventDefault;
|
||
return i.preventDefault = function () {
|
||
t.preventDefault(), r()
|
||
}, i.pointerId = Jo, i.isPrimary = !0, i.pointerType = $o, i
|
||
}
|
||
|
||
var sn = function (t) {
|
||
function e(e) {
|
||
var i = {mousedown: Qo, mousemove: tn, mouseup: en, mouseover: rn, mouseout: on};
|
||
t.call(this, e, i), this.pointerMap = e.pointerMap, this.lastTouches = []
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.isEventSimulatedFromTouch_ = function (t) {
|
||
for (var e = this.lastTouches, i = t.clientX, r = t.clientY, o = 0, n = e.length, s = void 0; o < n && (s = e[o]); o++) {
|
||
var a = Math.abs(i - s[0]), l = Math.abs(r - s[1]);
|
||
if (a <= 25 && l <= 25) return !0
|
||
}
|
||
return !1
|
||
}, e.prototype.cancel = function (t) {
|
||
var e = nn(t, this.dispatcher);
|
||
this.dispatcher.cancel(e, t), this.cleanupMouse()
|
||
}, e.prototype.cleanupMouse = function () {
|
||
delete this.pointerMap[Jo.toString()]
|
||
}, e
|
||
}(Ko), an = ["", "unavailable", "touch", "pen", "mouse"];
|
||
|
||
function ln(t) {
|
||
this.pointerMap[t.pointerId.toString()] = t;
|
||
var e = this.prepareEvent_(t);
|
||
this.dispatcher.down(e, t)
|
||
}
|
||
|
||
function hn(t) {
|
||
var e = this.prepareEvent_(t);
|
||
this.dispatcher.move(e, t)
|
||
}
|
||
|
||
function un(t) {
|
||
var e = this.prepareEvent_(t);
|
||
this.dispatcher.up(e, t), this.cleanup(t.pointerId)
|
||
}
|
||
|
||
function cn(t) {
|
||
var e = this.prepareEvent_(t);
|
||
this.dispatcher.leaveOut(e, t)
|
||
}
|
||
|
||
function pn(t) {
|
||
var e = this.prepareEvent_(t);
|
||
this.dispatcher.enterOver(e, t)
|
||
}
|
||
|
||
function dn(t) {
|
||
var e = this.prepareEvent_(t);
|
||
this.dispatcher.cancel(e, t), this.cleanup(t.pointerId)
|
||
}
|
||
|
||
function fn(t) {
|
||
var e = this.dispatcher.makeEvent("lostpointercapture", t, t);
|
||
this.dispatcher.dispatchEvent(e)
|
||
}
|
||
|
||
function gn(t) {
|
||
var e = this.dispatcher.makeEvent("gotpointercapture", t, t);
|
||
this.dispatcher.dispatchEvent(e)
|
||
}
|
||
|
||
var mn = function (t) {
|
||
function e(e) {
|
||
var i = {
|
||
MSPointerDown: ln,
|
||
MSPointerMove: hn,
|
||
MSPointerUp: un,
|
||
MSPointerOut: cn,
|
||
MSPointerOver: pn,
|
||
MSPointerCancel: dn,
|
||
MSGotPointerCapture: gn,
|
||
MSLostPointerCapture: fn
|
||
};
|
||
t.call(this, e, i), this.pointerMap = e.pointerMap
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.prepareEvent_ = function (t) {
|
||
var e = t;
|
||
return "number" == typeof t.pointerType && ((e = this.dispatcher.cloneEvent(t, t)).pointerType = an[t.pointerType]), e
|
||
}, e.prototype.cleanup = function (t) {
|
||
delete this.pointerMap[t.toString()]
|
||
}, e
|
||
}(Ko);
|
||
|
||
function yn(t) {
|
||
this.dispatcher.fireNativeEvent(t)
|
||
}
|
||
|
||
function vn(t) {
|
||
this.dispatcher.fireNativeEvent(t)
|
||
}
|
||
|
||
function _n(t) {
|
||
this.dispatcher.fireNativeEvent(t)
|
||
}
|
||
|
||
function xn(t) {
|
||
this.dispatcher.fireNativeEvent(t)
|
||
}
|
||
|
||
function wn(t) {
|
||
this.dispatcher.fireNativeEvent(t)
|
||
}
|
||
|
||
function bn(t) {
|
||
this.dispatcher.fireNativeEvent(t)
|
||
}
|
||
|
||
function Cn(t) {
|
||
this.dispatcher.fireNativeEvent(t)
|
||
}
|
||
|
||
function Sn(t) {
|
||
this.dispatcher.fireNativeEvent(t)
|
||
}
|
||
|
||
var En = function (t) {
|
||
function e(e) {
|
||
var i = {
|
||
pointerdown: yn,
|
||
pointermove: vn,
|
||
pointerup: _n,
|
||
pointerout: xn,
|
||
pointerover: wn,
|
||
pointercancel: bn,
|
||
gotpointercapture: Sn,
|
||
lostpointercapture: Cn
|
||
};
|
||
t.call(this, e, i)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(Ko), Tn = !1, Rn = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, e), this.originalEvent = i;
|
||
var o = r || {};
|
||
this.buttons = function (t) {
|
||
var e;
|
||
if (t.buttons || Tn) e = t.buttons; else switch (t.which) {
|
||
case 1:
|
||
e = 1;
|
||
break;
|
||
case 2:
|
||
e = 4;
|
||
break;
|
||
case 3:
|
||
e = 2;
|
||
break;
|
||
default:
|
||
e = 0
|
||
}
|
||
return e
|
||
}(o), this.pressure = function (t, e) {
|
||
var i = 0;
|
||
i = t.pressure ? t.pressure : e ? .5 : 0;
|
||
return i
|
||
}(o, this.buttons), this.bubbles = "bubbles" in o && o.bubbles, this.cancelable = "cancelable" in o && o.cancelable, this.view = "view" in o ? o.view : null, this.detail = "detail" in o ? o.detail : null, this.screenX = "screenX" in o ? o.screenX : 0, this.screenY = "screenY" in o ? o.screenY : 0, this.clientX = "clientX" in o ? o.clientX : 0, this.clientY = "clientY" in o ? o.clientY : 0, this.ctrlKey = "ctrlKey" in o && o.ctrlKey, this.altKey = "altKey" in o && o.altKey, this.shiftKey = "shiftKey" in o && o.shiftKey, this.metaKey = "metaKey" in o && o.metaKey, this.button = "button" in o ? o.button : 0, this.relatedTarget = "relatedTarget" in o ? o.relatedTarget : null, this.pointerId = "pointerId" in o ? o.pointerId : 0, this.width = "width" in o ? o.width : 0, this.height = "height" in o ? o.height : 0, this.tiltX = "tiltX" in o ? o.tiltX : 0, this.tiltY = "tiltY" in o ? o.tiltY : 0, this.pointerType = "pointerType" in o ? o.pointerType : "", this.hwTimestamp = "hwTimestamp" in o ? o.hwTimestamp : 0, this.isPrimary = "isPrimary" in o && o.isPrimary, i.preventDefault && (this.preventDefault = function () {
|
||
i.preventDefault()
|
||
})
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A);
|
||
!function () {
|
||
try {
|
||
var t = new MouseEvent("click", {buttons: 1});
|
||
Tn = 1 === t.buttons
|
||
} catch (t) {
|
||
}
|
||
}();
|
||
var Pn = Rn;
|
||
|
||
function Ln(t) {
|
||
this.vacuumTouches_(t), this.setPrimaryTouch_(t.changedTouches[0]), this.dedupSynthMouse_(t), this.clickCount_++, this.processTouches_(t, this.overDown_)
|
||
}
|
||
|
||
function In(t) {
|
||
this.processTouches_(t, this.moveOverOut_)
|
||
}
|
||
|
||
function On(t) {
|
||
this.dedupSynthMouse_(t), this.processTouches_(t, this.upOut_)
|
||
}
|
||
|
||
function Mn(t) {
|
||
this.processTouches_(t, this.cancelOut_)
|
||
}
|
||
|
||
var An = function (t) {
|
||
function e(e, i) {
|
||
var r = {touchstart: Ln, touchmove: In, touchend: On, touchcancel: Mn};
|
||
t.call(this, e, r), this.pointerMap = e.pointerMap, this.mouseSource = i, this.firstTouchId_ = void 0, this.clickCount_ = 0, this.resetId_, this.dedupTimeout_ = 2500
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.isPrimaryTouch_ = function (t) {
|
||
return this.firstTouchId_ === t.identifier
|
||
}, e.prototype.setPrimaryTouch_ = function (t) {
|
||
var e = Object.keys(this.pointerMap).length;
|
||
(0 === e || 1 === e && Jo.toString() in this.pointerMap) && (this.firstTouchId_ = t.identifier, this.cancelResetClickCount_())
|
||
}, e.prototype.removePrimaryPointer_ = function (t) {
|
||
t.isPrimary && (this.firstTouchId_ = void 0, this.resetClickCount_())
|
||
}, e.prototype.resetClickCount_ = function () {
|
||
this.resetId_ = setTimeout(this.resetClickCountHandler_.bind(this), 200)
|
||
}, e.prototype.resetClickCountHandler_ = function () {
|
||
this.clickCount_ = 0, this.resetId_ = void 0
|
||
}, e.prototype.cancelResetClickCount_ = function () {
|
||
void 0 !== this.resetId_ && clearTimeout(this.resetId_)
|
||
}, e.prototype.touchToPointer_ = function (t, e) {
|
||
var i = this.dispatcher.cloneEvent(t, e);
|
||
return i.pointerId = e.identifier + 2, i.bubbles = !0, i.cancelable = !0, i.detail = this.clickCount_, i.button = 0, i.buttons = 1, i.width = e.radiusX || 0, i.height = e.radiusY || 0, i.pressure = e.force || .5, i.isPrimary = this.isPrimaryTouch_(e), i.pointerType = "touch", i.clientX = e.clientX, i.clientY = e.clientY, i.screenX = e.screenX, i.screenY = e.screenY, i
|
||
}, e.prototype.processTouches_ = function (t, e) {
|
||
var i = Array.prototype.slice.call(t.changedTouches), r = i.length;
|
||
|
||
function o() {
|
||
t.preventDefault()
|
||
}
|
||
|
||
for (var n = 0; n < r; ++n) {
|
||
var s = this.touchToPointer_(t, i[n]);
|
||
s.preventDefault = o, e.call(this, t, s)
|
||
}
|
||
}, e.prototype.findTouch_ = function (t, e) {
|
||
for (var i = t.length, r = 0; r < i; r++) {
|
||
if (t[r].identifier === e) return !0
|
||
}
|
||
return !1
|
||
}, e.prototype.vacuumTouches_ = function (t) {
|
||
var e = t.touches, i = Object.keys(this.pointerMap), r = i.length;
|
||
if (r >= e.length) {
|
||
for (var o = [], n = 0; n < r; ++n) {
|
||
var s = Number(i[n]), a = this.pointerMap[s];
|
||
s == Jo || this.findTouch_(e, s - 2) || o.push(a.out)
|
||
}
|
||
for (var l = 0; l < o.length; ++l) this.cancelOut_(t, o[l])
|
||
}
|
||
}, e.prototype.overDown_ = function (t, e) {
|
||
this.pointerMap[e.pointerId] = {
|
||
target: e.target,
|
||
out: e,
|
||
outTarget: e.target
|
||
}, this.dispatcher.over(e, t), this.dispatcher.enter(e, t), this.dispatcher.down(e, t)
|
||
}, e.prototype.moveOverOut_ = function (t, e) {
|
||
var i = e, r = this.pointerMap[i.pointerId];
|
||
if (r) {
|
||
var o = r.out, n = r.outTarget;
|
||
this.dispatcher.move(i, t), o && n !== i.target && (o.relatedTarget = i.target, i.relatedTarget = n, o.target = n, i.target ? (this.dispatcher.leaveOut(o, t), this.dispatcher.enterOver(i, t)) : (i.target = n, i.relatedTarget = null, this.cancelOut_(t, i))), r.out = i, r.outTarget = i.target
|
||
}
|
||
}, e.prototype.upOut_ = function (t, e) {
|
||
this.dispatcher.up(e, t), this.dispatcher.out(e, t), this.dispatcher.leave(e, t), this.cleanUpPointer_(e)
|
||
}, e.prototype.cancelOut_ = function (t, e) {
|
||
this.dispatcher.cancel(e, t), this.dispatcher.out(e, t), this.dispatcher.leave(e, t), this.cleanUpPointer_(e)
|
||
}, e.prototype.cleanUpPointer_ = function (t) {
|
||
delete this.pointerMap[t.pointerId], this.removePrimaryPointer_(t)
|
||
}, e.prototype.dedupSynthMouse_ = function (t) {
|
||
var e = this.mouseSource.lastTouches, i = t.changedTouches[0];
|
||
if (this.isPrimaryTouch_(i)) {
|
||
var r = [i.clientX, i.clientY];
|
||
e.push(r), setTimeout(function () {
|
||
tt(e, r)
|
||
}, this.dedupTimeout_)
|
||
}
|
||
}, e
|
||
}(Ko),
|
||
kn = [["bubbles", !1], ["cancelable", !1], ["view", null], ["detail", null], ["screenX", 0], ["screenY", 0], ["clientX", 0], ["clientY", 0], ["ctrlKey", !1], ["altKey", !1], ["shiftKey", !1], ["metaKey", !1], ["button", 0], ["relatedTarget", null], ["buttons", 0], ["pointerId", 0], ["width", 0], ["height", 0], ["pressure", 0], ["tiltX", 0], ["tiltY", 0], ["pointerType", ""], ["hwTimestamp", 0], ["isPrimary", !1], ["type", ""], ["target", null], ["currentTarget", null], ["which", 0]],
|
||
Fn = function (t) {
|
||
function e(e) {
|
||
t.call(this), this.element_ = e, this.pointerMap = {}, this.eventMap_ = {}, this.eventSourceList_ = [], this.registerSources()
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.registerSources = function () {
|
||
if (Pr) this.registerSource("native", new En(this)); else if (Lr) this.registerSource("ms", new mn(this)); else {
|
||
var t = new sn(this);
|
||
this.registerSource("mouse", t), Rr && this.registerSource("touch", new An(this, t))
|
||
}
|
||
this.register_()
|
||
}, e.prototype.registerSource = function (t, e) {
|
||
var i = e, r = i.getEvents();
|
||
r && (r.forEach(function (t) {
|
||
var e = i.getHandlerForEvent(t);
|
||
e && (this.eventMap_[t] = e.bind(i))
|
||
}.bind(this)), this.eventSourceList_.push(i))
|
||
}, e.prototype.register_ = function () {
|
||
for (var t = this.eventSourceList_.length, e = 0; e < t; e++) {
|
||
var i = this.eventSourceList_[e];
|
||
this.addEvents_(i.getEvents())
|
||
}
|
||
}, e.prototype.unregister_ = function () {
|
||
for (var t = this.eventSourceList_.length, e = 0; e < t; e++) {
|
||
var i = this.eventSourceList_[e];
|
||
this.removeEvents_(i.getEvents())
|
||
}
|
||
}, e.prototype.eventHandler_ = function (t) {
|
||
var e = t.type, i = this.eventMap_[e];
|
||
i && i(t)
|
||
}, e.prototype.addEvents_ = function (t) {
|
||
t.forEach(function (t) {
|
||
w(this.element_, t, this.eventHandler_, this)
|
||
}.bind(this))
|
||
}, e.prototype.removeEvents_ = function (t) {
|
||
t.forEach(function (t) {
|
||
C(this.element_, t, this.eventHandler_, this)
|
||
}.bind(this))
|
||
}, e.prototype.cloneEvent = function (t, e) {
|
||
for (var i = {}, r = 0, o = kn.length; r < o; r++) {
|
||
var n = kn[r][0];
|
||
i[n] = t[n] || e[n] || kn[r][1]
|
||
}
|
||
return i
|
||
}, e.prototype.down = function (t, e) {
|
||
this.fireEvent(qo.POINTERDOWN, t, e)
|
||
}, e.prototype.move = function (t, e) {
|
||
this.fireEvent(qo.POINTERMOVE, t, e)
|
||
}, e.prototype.up = function (t, e) {
|
||
this.fireEvent(qo.POINTERUP, t, e)
|
||
}, e.prototype.enter = function (t, e) {
|
||
t.bubbles = !1, this.fireEvent(qo.POINTERENTER, t, e)
|
||
}, e.prototype.leave = function (t, e) {
|
||
t.bubbles = !1, this.fireEvent(qo.POINTERLEAVE, t, e)
|
||
}, e.prototype.over = function (t, e) {
|
||
t.bubbles = !0, this.fireEvent(qo.POINTEROVER, t, e)
|
||
}, e.prototype.out = function (t, e) {
|
||
t.bubbles = !0, this.fireEvent(qo.POINTEROUT, t, e)
|
||
}, e.prototype.cancel = function (t, e) {
|
||
this.fireEvent(qo.POINTERCANCEL, t, e)
|
||
}, e.prototype.leaveOut = function (t, e) {
|
||
this.out(t, e), this.contains_(t.target, t.relatedTarget) || this.leave(t, e)
|
||
}, e.prototype.enterOver = function (t, e) {
|
||
this.over(t, e), this.contains_(t.target, t.relatedTarget) || this.enter(t, e)
|
||
}, e.prototype.contains_ = function (t, e) {
|
||
return !(!t || !e) && t.contains(e)
|
||
}, e.prototype.makeEvent = function (t, e, i) {
|
||
return new Pn(t, i, e)
|
||
}, e.prototype.fireEvent = function (t, e, i) {
|
||
var r = this.makeEvent(t, e, i);
|
||
this.dispatchEvent(r)
|
||
}, e.prototype.fireNativeEvent = function (t) {
|
||
var e = this.makeEvent(t.type, t, t);
|
||
this.dispatchEvent(e)
|
||
}, e.prototype.wrapMouseEvent = function (t, e) {
|
||
return this.makeEvent(t, nn(e, this), e)
|
||
}, e.prototype.disposeInternal = function () {
|
||
this.unregister_(), t.prototype.disposeInternal.call(this)
|
||
}, e
|
||
}(k), Nn = function (t) {
|
||
function e(e, i) {
|
||
t.call(this), this.map_ = e, this.clickTimeoutId_, this.dragging_ = !1, this.dragListenerKeys_ = [], this.moveTolerance_ = i ? i * Sr : Sr, this.down_ = null;
|
||
var r = this.map_.getViewport();
|
||
this.activePointers_ = 0, this.trackedTouches_ = {}, this.pointerEventHandler_ = new Fn(r), this.documentPointerEventHandler_ = null, this.pointerdownListenerKey_ = w(this.pointerEventHandler_, qo.POINTERDOWN, this.handlePointerDown_, this), this.relayedListenerKey_ = w(this.pointerEventHandler_, qo.POINTERMOVE, this.relayEvent_, this)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.emulateClick_ = function (t) {
|
||
var e = new Xo(Ho.CLICK, this.map_, t);
|
||
this.dispatchEvent(e), void 0 !== this.clickTimeoutId_ ? (clearTimeout(this.clickTimeoutId_), this.clickTimeoutId_ = void 0, e = new Xo(Ho.DBLCLICK, this.map_, t), this.dispatchEvent(e)) : this.clickTimeoutId_ = setTimeout(function () {
|
||
this.clickTimeoutId_ = void 0;
|
||
var e = new Xo(Ho.SINGLECLICK, this.map_, t);
|
||
this.dispatchEvent(e)
|
||
}.bind(this), 250)
|
||
}, e.prototype.updateActivePointers_ = function (t) {
|
||
var e = t;
|
||
e.type == Ho.POINTERUP || e.type == Ho.POINTERCANCEL ? delete this.trackedTouches_[e.pointerId] : e.type == Ho.POINTERDOWN && (this.trackedTouches_[e.pointerId] = !0), this.activePointers_ = Object.keys(this.trackedTouches_).length
|
||
}, e.prototype.handlePointerUp_ = function (t) {
|
||
this.updateActivePointers_(t);
|
||
var e = new Xo(Ho.POINTERUP, this.map_, t);
|
||
this.dispatchEvent(e), e.propagationStopped || this.dragging_ || !this.isMouseActionButton_(t) || this.emulateClick_(this.down_), 0 === this.activePointers_ && (this.dragListenerKeys_.forEach(S), this.dragListenerKeys_.length = 0, this.dragging_ = !1, this.down_ = null, this.documentPointerEventHandler_.dispose(), this.documentPointerEventHandler_ = null)
|
||
}, e.prototype.isMouseActionButton_ = function (t) {
|
||
return 0 === t.button
|
||
}, e.prototype.handlePointerDown_ = function (t) {
|
||
this.updateActivePointers_(t);
|
||
var e = new Xo(Ho.POINTERDOWN, this.map_, t);
|
||
this.dispatchEvent(e), this.down_ = t, 0 === this.dragListenerKeys_.length && (this.documentPointerEventHandler_ = new Fn(document), this.dragListenerKeys_.push(w(this.documentPointerEventHandler_, Ho.POINTERMOVE, this.handlePointerMove_, this), w(this.documentPointerEventHandler_, Ho.POINTERUP, this.handlePointerUp_, this), w(this.pointerEventHandler_, Ho.POINTERCANCEL, this.handlePointerUp_, this)))
|
||
}, e.prototype.handlePointerMove_ = function (t) {
|
||
if (this.isMoving_(t)) {
|
||
this.dragging_ = !0;
|
||
var e = new Xo(Ho.POINTERDRAG, this.map_, t, this.dragging_);
|
||
this.dispatchEvent(e)
|
||
}
|
||
t.preventDefault()
|
||
}, e.prototype.relayEvent_ = function (t) {
|
||
var e = !(!this.down_ || !this.isMoving_(t));
|
||
this.dispatchEvent(new Xo(t.type, this.map_, t, e))
|
||
}, e.prototype.isMoving_ = function (t) {
|
||
return this.dragging_ || Math.abs(t.clientX - this.down_.clientX) > this.moveTolerance_ || Math.abs(t.clientY - this.down_.clientY) > this.moveTolerance_
|
||
}, e.prototype.disposeInternal = function () {
|
||
this.relayedListenerKey_ && (S(this.relayedListenerKey_), this.relayedListenerKey_ = null), this.pointerdownListenerKey_ && (S(this.pointerdownListenerKey_), this.pointerdownListenerKey_ = null), this.dragListenerKeys_.forEach(S), this.dragListenerKeys_.length = 0, this.documentPointerEventHandler_ && (this.documentPointerEventHandler_.dispose(), this.documentPointerEventHandler_ = null), this.pointerEventHandler_ && (this.pointerEventHandler_.dispose(), this.pointerEventHandler_ = null), t.prototype.disposeInternal.call(this)
|
||
}, e
|
||
}(k), Dn = {POSTRENDER: "postrender", MOVESTART: "movestart", MOVEEND: "moveend"},
|
||
Gn = {LAYERGROUP: "layergroup", SIZE: "size", TARGET: "target", VIEW: "view"}, jn = function (t, e) {
|
||
this.priorityFunction_ = t, this.keyFunction_ = e, this.elements_ = [], this.priorities_ = [], this.queuedElements_ = {}
|
||
};
|
||
jn.prototype.clear = function () {
|
||
this.elements_.length = 0, this.priorities_.length = 0, d(this.queuedElements_)
|
||
}, jn.prototype.dequeue = function () {
|
||
var t = this.elements_, e = this.priorities_, i = t[0];
|
||
1 == t.length ? (t.length = 0, e.length = 0) : (t[0] = t.pop(), e[0] = e.pop(), this.siftUp_(0));
|
||
var r = this.keyFunction_(i);
|
||
return delete this.queuedElements_[r], i
|
||
}, jn.prototype.enqueue = function (t) {
|
||
W(!(this.keyFunction_(t) in this.queuedElements_), 31);
|
||
var e = this.priorityFunction_(t);
|
||
return e != 1 / 0 && (this.elements_.push(t), this.priorities_.push(e), this.queuedElements_[this.keyFunction_(t)] = !0, this.siftDown_(0, this.elements_.length - 1), !0)
|
||
}, jn.prototype.getCount = function () {
|
||
return this.elements_.length
|
||
}, jn.prototype.getLeftChildIndex_ = function (t) {
|
||
return 2 * t + 1
|
||
}, jn.prototype.getRightChildIndex_ = function (t) {
|
||
return 2 * t + 2
|
||
}, jn.prototype.getParentIndex_ = function (t) {
|
||
return t - 1 >> 1
|
||
}, jn.prototype.heapify_ = function () {
|
||
var t;
|
||
for (t = (this.elements_.length >> 1) - 1; t >= 0; t--) this.siftUp_(t)
|
||
}, jn.prototype.isEmpty = function () {
|
||
return 0 === this.elements_.length
|
||
}, jn.prototype.isKeyQueued = function (t) {
|
||
return t in this.queuedElements_
|
||
}, jn.prototype.isQueued = function (t) {
|
||
return this.isKeyQueued(this.keyFunction_(t))
|
||
}, jn.prototype.siftUp_ = function (t) {
|
||
for (var e = this.elements_, i = this.priorities_, r = e.length, o = e[t], n = i[t], s = t; t < r >> 1;) {
|
||
var a = this.getLeftChildIndex_(t), l = this.getRightChildIndex_(t), h = l < r && i[l] < i[a] ? l : a;
|
||
e[t] = e[h], i[t] = i[h], t = h
|
||
}
|
||
e[t] = o, i[t] = n, this.siftDown_(s, t)
|
||
}, jn.prototype.siftDown_ = function (t, e) {
|
||
for (var i = this.elements_, r = this.priorities_, o = i[e], n = r[e]; e > t;) {
|
||
var s = this.getParentIndex_(e);
|
||
if (!(r[s] > n)) break;
|
||
i[e] = i[s], r[e] = r[s], e = s
|
||
}
|
||
i[e] = o, r[e] = n
|
||
}, jn.prototype.reprioritize = function () {
|
||
var t, e, i, r = this.priorityFunction_, o = this.elements_, n = this.priorities_, s = 0, a = o.length;
|
||
for (e = 0; e < a; ++e) (i = r(t = o[e])) == 1 / 0 ? delete this.queuedElements_[this.keyFunction_(t)] : (n[s] = i, o[s++] = t);
|
||
o.length = s, n.length = s, this.heapify_()
|
||
};
|
||
var zn = jn, Un = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, function (t) {
|
||
return e.apply(null, t)
|
||
}, function (t) {
|
||
return t[0].getKey()
|
||
}), this.tileChangeCallback_ = i, this.tilesLoading_ = 0, this.tilesLoadingKeys_ = {}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.enqueue = function (e) {
|
||
var i = t.prototype.enqueue.call(this, e);
|
||
i && w(e[0], F.CHANGE, this.handleTileChange, this);
|
||
return i
|
||
}, e.prototype.getTilesLoading = function () {
|
||
return this.tilesLoading_
|
||
}, e.prototype.handleTileChange = function (t) {
|
||
var e = t.target, i = e.getState();
|
||
if (i === Ro.LOADED || i === Ro.ERROR || i === Ro.EMPTY || i === Ro.ABORT) {
|
||
C(e, F.CHANGE, this.handleTileChange, this);
|
||
var r = e.getKey();
|
||
r in this.tilesLoadingKeys_ && (delete this.tilesLoadingKeys_[r], --this.tilesLoading_), this.tileChangeCallback_()
|
||
}
|
||
}, e.prototype.loadMoreTiles = function (t, e) {
|
||
for (var i, r, o, n = 0, s = !1; this.tilesLoading_ < t && n < e && this.getCount() > 0;) o = (r = this.dequeue()[0]).getKey(), (i = r.getState()) === Ro.ABORT ? s = !0 : i !== Ro.IDLE || o in this.tilesLoadingKeys_ || (this.tilesLoadingKeys_[o] = !0, ++this.tilesLoading_, ++n, r.load());
|
||
0 === n && s && this.tileChangeCallback_()
|
||
}, e
|
||
}(zn), Bn = 42, Vn = 256;
|
||
|
||
function Yn(t) {
|
||
return function (e) {
|
||
return e ? [te(e[0], t[0], t[2]), te(e[1], t[1], t[3])] : void 0
|
||
}
|
||
}
|
||
|
||
function Wn(t) {
|
||
return t
|
||
}
|
||
|
||
function Hn(t) {
|
||
return function (e, i, r) {
|
||
if (void 0 !== e) {
|
||
var o = J(t, e, r);
|
||
o = te(o + i, 0, t.length - 1);
|
||
var n = Math.floor(o);
|
||
if (o != n && n < t.length - 1) {
|
||
var s = t[n] / t[n + 1];
|
||
return t[n] / Math.pow(s, o - n)
|
||
}
|
||
return t[n]
|
||
}
|
||
}
|
||
}
|
||
|
||
function Xn(t, e, i) {
|
||
return function (r, o, n) {
|
||
if (void 0 !== r) {
|
||
var s = -n / 2 + .5, a = Math.floor(Math.log(e / r) / Math.log(t) + s), l = Math.max(a + o, 0);
|
||
return void 0 !== i && (l = Math.min(l, i)), e / Math.pow(t, l)
|
||
}
|
||
}
|
||
}
|
||
|
||
function qn(t, e) {
|
||
return void 0 !== t ? 0 : void 0
|
||
}
|
||
|
||
function Zn(t, e) {
|
||
return void 0 !== t ? t + e : void 0
|
||
}
|
||
|
||
function Kn(t) {
|
||
var e = 2 * Math.PI / t;
|
||
return function (t, i) {
|
||
return void 0 !== t ? t = Math.floor((t + i) / e + .5) * e : void 0
|
||
}
|
||
}
|
||
|
||
function Jn(t) {
|
||
var e = t || ae(5);
|
||
return function (t, i) {
|
||
return void 0 !== t ? Math.abs(t + i) <= e ? 0 : t + i : void 0
|
||
}
|
||
}
|
||
|
||
var $n = {ANIMATING: 0, INTERACTING: 1},
|
||
Qn = {CENTER: "center", RESOLUTION: "resolution", ROTATION: "rotation"}, ts = 0;
|
||
|
||
function es(t, e) {
|
||
setTimeout(function () {
|
||
t(e)
|
||
}, 0)
|
||
}
|
||
|
||
function is(t) {
|
||
return void 0 !== t.extent ? Yn(t.extent) : Wn
|
||
}
|
||
|
||
function rs(t) {
|
||
var e, i, r, o = void 0 !== t.minZoom ? t.minZoom : ts, n = void 0 !== t.maxZoom ? t.maxZoom : 28,
|
||
s = void 0 !== t.zoomFactor ? t.zoomFactor : 2;
|
||
if (void 0 !== t.resolutions) {
|
||
var a = t.resolutions;
|
||
i = a[o], r = void 0 !== a[n] ? a[n] : a[a.length - 1], e = Hn(a)
|
||
} else {
|
||
var l = Ze(t.projection, "EPSG:3857"), h = l.getExtent(),
|
||
u = (h ? Math.max(Ut(h), Nt(h)) : 360 * ye[ve.DEGREES] / l.getMetersPerUnit()) / Vn / Math.pow(2, ts),
|
||
c = u / Math.pow(2, 28 - ts);
|
||
void 0 !== (i = t.maxResolution) ? o = 0 : i = u / Math.pow(s, o), void 0 === (r = t.minResolution) && (r = void 0 !== t.maxZoom ? void 0 !== t.maxResolution ? i / Math.pow(s, n) : u / Math.pow(s, n) : c), n = o + Math.floor(Math.log(i / r) / Math.log(s)), r = i / Math.pow(s, n - o), e = Xn(s, i, n - o)
|
||
}
|
||
return {constraint: e, maxResolution: i, minResolution: r, minZoom: o, zoomFactor: s}
|
||
}
|
||
|
||
function os(t) {
|
||
if (void 0 === t.enableRotation || t.enableRotation) {
|
||
var e = t.constrainRotation;
|
||
return void 0 === e || !0 === e ? Jn() : !1 === e ? Zn : "number" == typeof e ? Kn(e) : Zn
|
||
}
|
||
return qn
|
||
}
|
||
|
||
function ns(t) {
|
||
return !(t.sourceCenter && t.targetCenter && !zr(t.sourceCenter, t.targetCenter)) && (t.sourceResolution === t.targetResolution && t.sourceRotation === t.targetRotation)
|
||
}
|
||
|
||
var ss = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = p({}, e);
|
||
this.hints_ = [0, 0], this.animations_ = [], this.updateAnimationKey_, this.updateAnimations_ = this.updateAnimations_.bind(this), this.projection_ = Ze(i.projection, "EPSG:3857"), this.applyOptions_(i)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.applyOptions_ = function (t) {
|
||
var e = {};
|
||
e[Qn.CENTER] = void 0 !== t.center ? t.center : null;
|
||
var i = rs(t);
|
||
this.maxResolution_ = i.maxResolution, this.minResolution_ = i.minResolution, this.zoomFactor_ = i.zoomFactor, this.resolutions_ = t.resolutions, this.minZoom_ = i.minZoom;
|
||
var r = is(t), o = i.constraint, n = os(t);
|
||
this.constraints_ = {
|
||
center: r,
|
||
resolution: o,
|
||
rotation: n
|
||
}, void 0 !== t.resolution ? e[Qn.RESOLUTION] = t.resolution : void 0 !== t.zoom && (e[Qn.RESOLUTION] = this.constrainResolution(this.maxResolution_, t.zoom - this.minZoom_), this.resolutions_ && (e[Qn.RESOLUTION] = te(Number(this.getResolution() || e[Qn.RESOLUTION]), this.minResolution_, this.maxResolution_))), e[Qn.ROTATION] = void 0 !== t.rotation ? t.rotation : 0, this.setProperties(e), this.options_ = t
|
||
}, e.prototype.getUpdatedOptions_ = function (t) {
|
||
var e = p({}, this.options_);
|
||
return void 0 !== e.resolution ? e.resolution = this.getResolution() : e.zoom = this.getZoom(), e.center = this.getCenter(), e.rotation = this.getRotation(), p({}, e, t)
|
||
}, e.prototype.animate = function (t) {
|
||
var e, i = arguments, r = arguments.length;
|
||
if (r > 1 && "function" == typeof arguments[r - 1] && (e = arguments[r - 1], --r), !this.isDef()) {
|
||
var o = arguments[r - 1];
|
||
return o.center && this.setCenter(o.center), void 0 !== o.zoom && this.setZoom(o.zoom), void 0 !== o.rotation && this.setRotation(o.rotation), void (e && es(e, !0))
|
||
}
|
||
for (var n = Date.now(), s = this.getCenter().slice(), a = this.getResolution(), l = this.getRotation(), h = [], u = 0; u < r; ++u) {
|
||
var c = i[u], p = {
|
||
start: n,
|
||
complete: !1,
|
||
anchor: c.anchor,
|
||
duration: void 0 !== c.duration ? c.duration : 1e3,
|
||
easing: c.easing || Io
|
||
};
|
||
if (c.center && (p.sourceCenter = s, p.targetCenter = c.center, s = p.targetCenter), void 0 !== c.zoom ? (p.sourceResolution = a, p.targetResolution = this.constrainResolution(this.maxResolution_, c.zoom - this.minZoom_, 0), a = p.targetResolution) : c.resolution && (p.sourceResolution = a, p.targetResolution = c.resolution, a = p.targetResolution), void 0 !== c.rotation) {
|
||
p.sourceRotation = l;
|
||
var d = le(c.rotation - l + Math.PI, 2 * Math.PI) - Math.PI;
|
||
p.targetRotation = l + d, l = p.targetRotation
|
||
}
|
||
p.callback = e, ns(p) ? p.complete = !0 : n += p.duration, h.push(p)
|
||
}
|
||
this.animations_.push(h), this.setHint($n.ANIMATING, 1), this.updateAnimations_()
|
||
}, e.prototype.getAnimating = function () {
|
||
return this.hints_[$n.ANIMATING] > 0
|
||
}, e.prototype.getInteracting = function () {
|
||
return this.hints_[$n.INTERACTING] > 0
|
||
}, e.prototype.cancelAnimations = function () {
|
||
this.setHint($n.ANIMATING, -this.hints_[$n.ANIMATING]);
|
||
for (var t = 0, e = this.animations_.length; t < e; ++t) {
|
||
var i = this.animations_[t];
|
||
i[0].callback && es(i[0].callback, !1)
|
||
}
|
||
this.animations_.length = 0
|
||
}, e.prototype.updateAnimations_ = function () {
|
||
if (void 0 !== this.updateAnimationKey_ && (cancelAnimationFrame(this.updateAnimationKey_), this.updateAnimationKey_ = void 0), this.getAnimating()) {
|
||
for (var t = Date.now(), e = !1, i = this.animations_.length - 1; i >= 0; --i) {
|
||
for (var r = this.animations_[i], o = !0, n = 0, s = r.length; n < s; ++n) {
|
||
var a = r[n];
|
||
if (!a.complete) {
|
||
var l = t - a.start, h = a.duration > 0 ? l / a.duration : 1;
|
||
h >= 1 ? (a.complete = !0, h = 1) : o = !1;
|
||
var u = a.easing(h);
|
||
if (a.sourceCenter) {
|
||
var c = a.sourceCenter[0], p = a.sourceCenter[1],
|
||
d = c + u * (a.targetCenter[0] - c), f = p + u * (a.targetCenter[1] - p);
|
||
this.set(Qn.CENTER, [d, f])
|
||
}
|
||
if (a.sourceResolution && a.targetResolution) {
|
||
var g = 1 === u ? a.targetResolution : a.sourceResolution + u * (a.targetResolution - a.sourceResolution);
|
||
a.anchor && this.set(Qn.CENTER, this.calculateCenterZoom(g, a.anchor)), this.set(Qn.RESOLUTION, g)
|
||
}
|
||
if (void 0 !== a.sourceRotation && void 0 !== a.targetRotation) {
|
||
var m = 1 === u ? le(a.targetRotation + Math.PI, 2 * Math.PI) - Math.PI : a.sourceRotation + u * (a.targetRotation - a.sourceRotation);
|
||
a.anchor && this.set(Qn.CENTER, this.calculateCenterRotate(m, a.anchor)), this.set(Qn.ROTATION, m)
|
||
}
|
||
if (e = !0, !a.complete) break
|
||
}
|
||
}
|
||
if (o) {
|
||
this.animations_[i] = null, this.setHint($n.ANIMATING, -1);
|
||
var y = r[0].callback;
|
||
y && es(y, !0)
|
||
}
|
||
}
|
||
this.animations_ = this.animations_.filter(Boolean), e && void 0 === this.updateAnimationKey_ && (this.updateAnimationKey_ = requestAnimationFrame(this.updateAnimations_))
|
||
}
|
||
}, e.prototype.calculateCenterRotate = function (t, e) {
|
||
var i, r = this.getCenter();
|
||
return void 0 !== r && (Ur(i = [r[0] - e[0], r[1] - e[1]], t - this.getRotation()), Fr(i, e)), i
|
||
}, e.prototype.calculateCenterZoom = function (t, e) {
|
||
var i, r = this.getCenter(), o = this.getResolution();
|
||
void 0 !== r && void 0 !== o && (i = [e[0] - t * (e[0] - r[0]) / o, e[1] - t * (e[1] - r[1]) / o]);
|
||
return i
|
||
}, e.prototype.getSizeFromViewport_ = function () {
|
||
var t = [100, 100], e = '.ol-viewport[data-view="' + a(this) + '"]', i = document.querySelector(e);
|
||
if (i) {
|
||
var r = getComputedStyle(i);
|
||
t[0] = parseInt(r.width, 10), t[1] = parseInt(r.height, 10)
|
||
}
|
||
return t
|
||
}, e.prototype.constrainCenter = function (t) {
|
||
return this.constraints_.center(t)
|
||
}, e.prototype.constrainResolution = function (t, e, i) {
|
||
var r = e || 0, o = i || 0;
|
||
return this.constraints_.resolution(t, r, o)
|
||
}, e.prototype.constrainRotation = function (t, e) {
|
||
var i = e || 0;
|
||
return this.constraints_.rotation(t, i)
|
||
}, e.prototype.getCenter = function () {
|
||
return this.get(Qn.CENTER)
|
||
}, e.prototype.getConstraints = function () {
|
||
return this.constraints_
|
||
}, e.prototype.getHints = function (t) {
|
||
return void 0 !== t ? (t[0] = this.hints_[0], t[1] = this.hints_[1], t) : this.hints_.slice()
|
||
}, e.prototype.calculateExtent = function (t) {
|
||
var e = t || this.getSizeFromViewport_(), i = this.getCenter();
|
||
W(i, 1);
|
||
var r = this.getResolution();
|
||
W(void 0 !== r, 2);
|
||
var o = this.getRotation();
|
||
return W(void 0 !== o, 3), Ft(i, r, o, e)
|
||
}, e.prototype.getMaxResolution = function () {
|
||
return this.maxResolution_
|
||
}, e.prototype.getMinResolution = function () {
|
||
return this.minResolution_
|
||
}, e.prototype.getMaxZoom = function () {
|
||
return this.getZoomForResolution(this.minResolution_)
|
||
}, e.prototype.setMaxZoom = function (t) {
|
||
this.applyOptions_(this.getUpdatedOptions_({maxZoom: t}))
|
||
}, e.prototype.getMinZoom = function () {
|
||
return this.getZoomForResolution(this.maxResolution_)
|
||
}, e.prototype.setMinZoom = function (t) {
|
||
this.applyOptions_(this.getUpdatedOptions_({minZoom: t}))
|
||
}, e.prototype.getProjection = function () {
|
||
return this.projection_
|
||
}, e.prototype.getResolution = function () {
|
||
return this.get(Qn.RESOLUTION)
|
||
}, e.prototype.getResolutions = function () {
|
||
return this.resolutions_
|
||
}, e.prototype.getResolutionForExtent = function (t, e) {
|
||
var i = e || this.getSizeFromViewport_(), r = Ut(t) / i[0], o = Nt(t) / i[1];
|
||
return Math.max(r, o)
|
||
}, e.prototype.getResolutionForValueFunction = function (t) {
|
||
var e = t || 2, i = this.maxResolution_, r = this.minResolution_, o = Math.log(i / r) / Math.log(e);
|
||
return function (t) {
|
||
return i / Math.pow(e, t * o)
|
||
}
|
||
}, e.prototype.getRotation = function () {
|
||
return this.get(Qn.ROTATION)
|
||
}, e.prototype.getValueForResolutionFunction = function (t) {
|
||
var e = t || 2, i = this.maxResolution_, r = this.minResolution_, o = Math.log(i / r) / Math.log(e);
|
||
return function (t) {
|
||
return Math.log(i / t) / Math.log(e) / o
|
||
}
|
||
}, e.prototype.getState = function (t) {
|
||
var e = this.getCenter(), i = this.getProjection(), r = this.getResolution(), o = r / t,
|
||
n = this.getRotation();
|
||
return {
|
||
center: [Math.round(e[0] / o) * o, Math.round(e[1] / o) * o],
|
||
projection: void 0 !== i ? i : null,
|
||
resolution: r,
|
||
rotation: n,
|
||
zoom: this.getZoom()
|
||
}
|
||
}, e.prototype.getZoom = function () {
|
||
var t, e = this.getResolution();
|
||
return void 0 !== e && (t = this.getZoomForResolution(e)), t
|
||
}, e.prototype.getZoomForResolution = function (t) {
|
||
var e, i, r = this.minZoom_ || 0;
|
||
if (this.resolutions_) {
|
||
var o = J(this.resolutions_, t, 1);
|
||
r = o, e = this.resolutions_[o], i = o == this.resolutions_.length - 1 ? 2 : e / this.resolutions_[o + 1]
|
||
} else e = this.maxResolution_, i = this.zoomFactor_;
|
||
return r + Math.log(e / t) / Math.log(i)
|
||
}, e.prototype.getResolutionForZoom = function (t) {
|
||
return this.constrainResolution(this.maxResolution_, t - this.minZoom_, 0)
|
||
}, e.prototype.fit = function (t, e) {
|
||
var i, r = e || {}, o = r.size;
|
||
o || (o = this.getSizeFromViewport_()), W(Array.isArray(t) || "function" == typeof t.getSimplifiedGeometry, 24), Array.isArray(t) ? (W(!Vt(t), 25), i = mr(t)) : t.getType() === Zt.CIRCLE ? (i = mr(t = t.getExtent())).rotate(this.getRotation(), At(t)) : i = t;
|
||
var n, s = void 0 !== r.padding ? r.padding : [0, 0, 0, 0],
|
||
a = void 0 === r.constrainResolution || r.constrainResolution,
|
||
l = void 0 !== r.nearest && r.nearest;
|
||
n = void 0 !== r.minResolution ? r.minResolution : void 0 !== r.maxZoom ? this.constrainResolution(this.maxResolution_, r.maxZoom - this.minZoom_, 0) : 0;
|
||
for (var h = i.getFlatCoordinates(), u = this.getRotation(), c = Math.cos(-u), p = Math.sin(-u), d = 1 / 0, f = 1 / 0, g = -1 / 0, m = -1 / 0, y = i.getStride(), v = 0, _ = h.length; v < _; v += y) {
|
||
var x = h[v] * c - h[v + 1] * p, w = h[v] * p + h[v + 1] * c;
|
||
d = Math.min(d, x), f = Math.min(f, w), g = Math.max(g, x), m = Math.max(m, w)
|
||
}
|
||
var b = this.getResolutionForExtent([d, f, g, m], [o[0] - s[1] - s[3], o[1] - s[0] - s[2]]);
|
||
if (b = isNaN(b) ? n : Math.max(b, n), a) {
|
||
var C = this.constrainResolution(b, 0, 0);
|
||
!l && C < b && (C = this.constrainResolution(C, -1, 0)), b = C
|
||
}
|
||
p = -p;
|
||
var S = (d + g) / 2, E = (f + m) / 2,
|
||
T = [(S += (s[1] - s[3]) / 2 * b) * c - (E += (s[0] - s[2]) / 2 * b) * p, E * c + S * p],
|
||
R = r.callback ? r.callback : I;
|
||
void 0 !== r.duration ? this.animate({
|
||
resolution: b,
|
||
center: T,
|
||
duration: r.duration,
|
||
easing: r.easing
|
||
}, R) : (this.setResolution(b), this.setCenter(T), es(R, !0))
|
||
}, e.prototype.centerOn = function (t, e, i) {
|
||
var r = this.getRotation(), o = Math.cos(-r), n = Math.sin(-r), s = t[0] * o - t[1] * n,
|
||
a = t[1] * o + t[0] * n, l = this.getResolution(),
|
||
h = (s += (e[0] / 2 - i[0]) * l) * o - (a += (i[1] - e[1] / 2) * l) * (n = -n), u = a * o + s * n;
|
||
this.setCenter([h, u])
|
||
}, e.prototype.isDef = function () {
|
||
return !!this.getCenter() && void 0 !== this.getResolution()
|
||
}, e.prototype.rotate = function (t, e) {
|
||
if (void 0 !== e) {
|
||
var i = this.calculateCenterRotate(t, e);
|
||
this.setCenter(i)
|
||
}
|
||
this.setRotation(t)
|
||
}, e.prototype.setCenter = function (t) {
|
||
this.set(Qn.CENTER, t), this.getAnimating() && this.cancelAnimations()
|
||
}, e.prototype.setHint = function (t, e) {
|
||
return this.hints_[t] += e, this.changed(), this.hints_[t]
|
||
}, e.prototype.setResolution = function (t) {
|
||
this.set(Qn.RESOLUTION, t), this.getAnimating() && this.cancelAnimations()
|
||
}, e.prototype.setRotation = function (t) {
|
||
this.set(Qn.ROTATION, t), this.getAnimating() && this.cancelAnimations()
|
||
}, e.prototype.setZoom = function (t) {
|
||
this.setResolution(this.getResolutionForZoom(t))
|
||
}, e
|
||
}(U), as = {
|
||
OPACITY: "opacity",
|
||
VISIBLE: "visible",
|
||
EXTENT: "extent",
|
||
Z_INDEX: "zIndex",
|
||
MAX_RESOLUTION: "maxResolution",
|
||
MIN_RESOLUTION: "minResolution",
|
||
SOURCE: "source"
|
||
}, ls = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = p({}, e);
|
||
i[as.OPACITY] = void 0 !== e.opacity ? e.opacity : 1, i[as.VISIBLE] = void 0 === e.visible || e.visible, i[as.Z_INDEX] = e.zIndex, i[as.MAX_RESOLUTION] = void 0 !== e.maxResolution ? e.maxResolution : 1 / 0, i[as.MIN_RESOLUTION] = void 0 !== e.minResolution ? e.minResolution : 0, this.setProperties(i), this.state_ = null, this.type
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getType = function () {
|
||
return this.type
|
||
}, e.prototype.getLayerState = function () {
|
||
var t = this.state_ || {layer: this, managed: !0};
|
||
return t.opacity = te(this.getOpacity(), 0, 1), t.sourceState = this.getSourceState(), t.visible = this.getVisible(), t.extent = this.getExtent(), t.zIndex = this.getZIndex() || 0, t.maxResolution = this.getMaxResolution(), t.minResolution = Math.max(this.getMinResolution(), 0), this.state_ = t, t
|
||
}, e.prototype.getLayersArray = function (t) {
|
||
return n()
|
||
}, e.prototype.getLayerStatesArray = function (t) {
|
||
return n()
|
||
}, e.prototype.getExtent = function () {
|
||
return this.get(as.EXTENT)
|
||
}, e.prototype.getMaxResolution = function () {
|
||
return this.get(as.MAX_RESOLUTION)
|
||
}, e.prototype.getMinResolution = function () {
|
||
return this.get(as.MIN_RESOLUTION)
|
||
}, e.prototype.getOpacity = function () {
|
||
return this.get(as.OPACITY)
|
||
}, e.prototype.getSourceState = function () {
|
||
return n()
|
||
}, e.prototype.getVisible = function () {
|
||
return this.get(as.VISIBLE)
|
||
}, e.prototype.getZIndex = function () {
|
||
return this.get(as.Z_INDEX)
|
||
}, e.prototype.setExtent = function (t) {
|
||
this.set(as.EXTENT, t)
|
||
}, e.prototype.setMaxResolution = function (t) {
|
||
this.set(as.MAX_RESOLUTION, t)
|
||
}, e.prototype.setMinResolution = function (t) {
|
||
this.set(as.MIN_RESOLUTION, t)
|
||
}, e.prototype.setOpacity = function (t) {
|
||
this.set(as.OPACITY, t)
|
||
}, e.prototype.setVisible = function (t) {
|
||
this.set(as.VISIBLE, t)
|
||
}, e.prototype.setZIndex = function (t) {
|
||
this.set(as.Z_INDEX, t)
|
||
}, e
|
||
}(U), hs = {UNDEFINED: "undefined", LOADING: "loading", READY: "ready", ERROR: "error"},
|
||
us = {LAYERS: "layers"}, cs = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = p({}, i);
|
||
delete r.layers;
|
||
var o = i.layers;
|
||
t.call(this, r), this.layersListenerKeys_ = [], this.listenerKeys_ = {}, w(this, z(us.LAYERS), this.handleLayersChanged_, this), o ? Array.isArray(o) ? o = new Y(o.slice(), {unique: !0}) : W("function" == typeof o.getArray, 43) : o = new Y(void 0, {unique: !0}), this.setLayers(o)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleLayerChange_ = function () {
|
||
this.changed()
|
||
}, e.prototype.handleLayersChanged_ = function () {
|
||
this.layersListenerKeys_.forEach(S), this.layersListenerKeys_.length = 0;
|
||
var t = this.getLayers();
|
||
for (var e in this.layersListenerKeys_.push(w(t, u.ADD, this.handleLayersAdd_, this), w(t, u.REMOVE, this.handleLayersRemove_, this)), this.listenerKeys_) this.listenerKeys_[e].forEach(S);
|
||
d(this.listenerKeys_);
|
||
for (var i = t.getArray(), r = 0, o = i.length; r < o; r++) {
|
||
var n = i[r];
|
||
this.listenerKeys_[a(n)] = [w(n, c.PROPERTYCHANGE, this.handleLayerChange_, this), w(n, F.CHANGE, this.handleLayerChange_, this)]
|
||
}
|
||
this.changed()
|
||
}, e.prototype.handleLayersAdd_ = function (t) {
|
||
var e = t.element;
|
||
this.listenerKeys_[a(e)] = [w(e, c.PROPERTYCHANGE, this.handleLayerChange_, this), w(e, F.CHANGE, this.handleLayerChange_, this)], this.changed()
|
||
}, e.prototype.handleLayersRemove_ = function (t) {
|
||
var e = a(t.element);
|
||
this.listenerKeys_[e].forEach(S), delete this.listenerKeys_[e], this.changed()
|
||
}, e.prototype.getLayers = function () {
|
||
return this.get(us.LAYERS)
|
||
}, e.prototype.setLayers = function (t) {
|
||
this.set(us.LAYERS, t)
|
||
}, e.prototype.getLayersArray = function (t) {
|
||
var e = void 0 !== t ? t : [];
|
||
return this.getLayers().forEach(function (t) {
|
||
t.getLayersArray(e)
|
||
}), e
|
||
}, e.prototype.getLayerStatesArray = function (t) {
|
||
var e = void 0 !== t ? t : [], i = e.length;
|
||
this.getLayers().forEach(function (t) {
|
||
t.getLayerStatesArray(e)
|
||
});
|
||
for (var r = this.getLayerState(), o = i, n = e.length; o < n; o++) {
|
||
var s = e[o];
|
||
s.opacity *= r.opacity, s.visible = s.visible && r.visible, s.maxResolution = Math.min(s.maxResolution, r.maxResolution), s.minResolution = Math.max(s.minResolution, r.minResolution), void 0 !== r.extent && (void 0 !== s.extent ? s.extent = Dt(s.extent, r.extent) : s.extent = r.extent)
|
||
}
|
||
return e
|
||
}, e.prototype.getSourceState = function () {
|
||
return hs.READY
|
||
}, e
|
||
}(ls);
|
||
|
||
function ps(t, e, i) {
|
||
return void 0 === i && (i = [0, 0]), i[0] = t[0] + 2 * e, i[1] = t[1] + 2 * e, i
|
||
}
|
||
|
||
function ds(t) {
|
||
return t[0] > 0 && t[1] > 0
|
||
}
|
||
|
||
function fs(t, e, i) {
|
||
return void 0 === i && (i = [0, 0]), i[0] = t[0] * e + .5 | 0, i[1] = t[1] * e + .5 | 0, i
|
||
}
|
||
|
||
function gs(t, e) {
|
||
return Array.isArray(t) ? t : (void 0 === e ? e = [t, t] : e[0] = e[1] = t, e)
|
||
}
|
||
|
||
var ms = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = function (t) {
|
||
var e = null;
|
||
void 0 !== t.keyboardEventTarget && (e = "string" == typeof t.keyboardEventTarget ? document.getElementById(t.keyboardEventTarget) : t.keyboardEventTarget);
|
||
var i, r, o, n = {},
|
||
s = t.layers && "function" == typeof t.layers.getLayers ? t.layers : new cs({layers: t.layers});
|
||
n[Gn.LAYERGROUP] = s, n[Gn.TARGET] = t.target, n[Gn.VIEW] = void 0 !== t.view ? t.view : new ss, void 0 !== t.controls && (Array.isArray(t.controls) ? i = new Y(t.controls.slice()) : (W("function" == typeof t.controls.getArray, 47), i = t.controls));
|
||
void 0 !== t.interactions && (Array.isArray(t.interactions) ? r = new Y(t.interactions.slice()) : (W("function" == typeof t.interactions.getArray, 48), r = t.interactions));
|
||
void 0 !== t.overlays ? Array.isArray(t.overlays) ? o = new Y(t.overlays.slice()) : (W("function" == typeof t.overlays.getArray, 49), o = t.overlays) : o = new Y;
|
||
return {controls: i, interactions: r, keyboardEventTarget: e, overlays: o, values: n}
|
||
}(e);
|
||
this.maxTilesLoading_ = void 0 !== e.maxTilesLoading ? e.maxTilesLoading : 16, this.loadTilesWhileAnimating_ = void 0 !== e.loadTilesWhileAnimating && e.loadTilesWhileAnimating, this.loadTilesWhileInteracting_ = void 0 !== e.loadTilesWhileInteracting && e.loadTilesWhileInteracting, this.pixelRatio_ = void 0 !== e.pixelRatio ? e.pixelRatio : Sr, this.animationDelayKey_, this.animationDelay_ = function () {
|
||
this.animationDelayKey_ = void 0, this.renderFrame_.call(this, Date.now())
|
||
}.bind(this), this.coordinateToPixelTransform_ = [1, 0, 0, 1, 0, 0], this.pixelToCoordinateTransform_ = [1, 0, 0, 1, 0, 0], this.frameIndex_ = 0, this.frameState_ = null, this.previousExtent_ = null, this.viewPropertyListenerKey_ = null, this.viewChangeListenerKey_ = null, this.layerGroupPropertyListenerKeys_ = null, this.viewport_ = document.createElement("div"), this.viewport_.className = "ol-viewport" + (Rr ? " ol-touch" : ""), this.viewport_.style.position = "relative", this.viewport_.style.overflow = "hidden", this.viewport_.style.width = "100%", this.viewport_.style.height = "100%", this.viewport_.style.msTouchAction = "none", this.viewport_.style.touchAction = "none", this.overlayContainer_ = document.createElement("div"), this.overlayContainer_.className = "ol-overlaycontainer", this.viewport_.appendChild(this.overlayContainer_), this.overlayContainerStopEvent_ = document.createElement("div"), this.overlayContainerStopEvent_.className = "ol-overlaycontainer-stopevent";
|
||
for (var r = [F.CLICK, F.DBLCLICK, F.MOUSEDOWN, F.TOUCHSTART, F.MSPOINTERDOWN, Ho.POINTERDOWN, F.MOUSEWHEEL, F.WHEEL], o = 0, n = r.length; o < n; ++o) w(this.overlayContainerStopEvent_, r[o], M);
|
||
for (var s in this.viewport_.appendChild(this.overlayContainerStopEvent_), this.mapBrowserEventHandler_ = new Nn(this, e.moveTolerance), Ho) w(this.mapBrowserEventHandler_, Ho[s], this.handleMapBrowserEvent, this);
|
||
this.keyboardEventTarget_ = i.keyboardEventTarget, this.keyHandlerKeys_ = null, w(this.viewport_, F.CONTEXTMENU, this.handleBrowserEvent, this), w(this.viewport_, F.WHEEL, this.handleBrowserEvent, this), w(this.viewport_, F.MOUSEWHEEL, this.handleBrowserEvent, this), this.controls = i.controls || new Y, this.interactions = i.interactions || new Y, this.overlays_ = i.overlays, this.overlayIdIndex_ = {}, this.renderer_ = this.createRenderer(), this.handleResize_, this.focus_ = null, this.postRenderFunctions_ = [], this.tileQueue_ = new Un(this.getTilePriority.bind(this), this.handleTileChange_.bind(this)), this.skippedFeatureUids_ = {}, w(this, z(Gn.LAYERGROUP), this.handleLayerGroupChanged_, this), w(this, z(Gn.VIEW), this.handleViewChanged_, this), w(this, z(Gn.SIZE), this.handleSizeChanged_, this), w(this, z(Gn.TARGET), this.handleTargetChanged_, this), this.setProperties(i.values), this.controls.forEach(function (t) {
|
||
t.setMap(this)
|
||
}.bind(this)), w(this.controls, u.ADD, function (t) {
|
||
t.element.setMap(this)
|
||
}, this), w(this.controls, u.REMOVE, function (t) {
|
||
t.element.setMap(null)
|
||
}, this), this.interactions.forEach(function (t) {
|
||
t.setMap(this)
|
||
}.bind(this)), w(this.interactions, u.ADD, function (t) {
|
||
t.element.setMap(this)
|
||
}, this), w(this.interactions, u.REMOVE, function (t) {
|
||
t.element.setMap(null)
|
||
}, this), this.overlays_.forEach(this.addOverlayInternal_.bind(this)), w(this.overlays_, u.ADD, function (t) {
|
||
this.addOverlayInternal_(t.element)
|
||
}, this), w(this.overlays_, u.REMOVE, function (t) {
|
||
var e = t.element.getId();
|
||
void 0 !== e && delete this.overlayIdIndex_[e.toString()], t.element.setMap(null)
|
||
}, this)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.createRenderer = function () {
|
||
throw new Error("Use a map type that has a createRenderer method")
|
||
}, e.prototype.addControl = function (t) {
|
||
this.getControls().push(t)
|
||
}, e.prototype.addInteraction = function (t) {
|
||
this.getInteractions().push(t)
|
||
}, e.prototype.addLayer = function (t) {
|
||
this.getLayerGroup().getLayers().push(t)
|
||
}, e.prototype.addOverlay = function (t) {
|
||
this.getOverlays().push(t)
|
||
}, e.prototype.addOverlayInternal_ = function (t) {
|
||
var e = t.getId();
|
||
void 0 !== e && (this.overlayIdIndex_[e.toString()] = t), t.setMap(this)
|
||
}, e.prototype.disposeInternal = function () {
|
||
this.mapBrowserEventHandler_.dispose(), C(this.viewport_, F.CONTEXTMENU, this.handleBrowserEvent, this), C(this.viewport_, F.WHEEL, this.handleBrowserEvent, this), C(this.viewport_, F.MOUSEWHEEL, this.handleBrowserEvent, this), void 0 !== this.handleResize_ && (removeEventListener(F.RESIZE, this.handleResize_, !1), this.handleResize_ = void 0), this.animationDelayKey_ && (cancelAnimationFrame(this.animationDelayKey_), this.animationDelayKey_ = void 0), this.setTarget(null), t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.forEachFeatureAtPixel = function (t, e, i) {
|
||
if (this.frameState_) {
|
||
var r = this.getCoordinateFromPixel(t),
|
||
o = void 0 !== (i = void 0 !== i ? i : {}).hitTolerance ? i.hitTolerance * this.frameState_.pixelRatio : 0,
|
||
n = void 0 !== i.layerFilter ? i.layerFilter : P;
|
||
return this.renderer_.forEachFeatureAtCoordinate(r, this.frameState_, o, e, null, n, null)
|
||
}
|
||
}, e.prototype.getFeaturesAtPixel = function (t, e) {
|
||
var i = null;
|
||
return this.forEachFeatureAtPixel(t, function (t) {
|
||
i || (i = []), i.push(t)
|
||
}, e), i
|
||
}, e.prototype.forEachLayerAtPixel = function (t, e, i) {
|
||
if (this.frameState_) {
|
||
var r = i || {}, o = void 0 !== r.hitTolerance ? i.hitTolerance * this.frameState_.pixelRatio : 0,
|
||
n = r.layerFilter || P;
|
||
return this.renderer_.forEachLayerAtPixel(t, this.frameState_, o, e, null, n, null)
|
||
}
|
||
}, e.prototype.hasFeatureAtPixel = function (t, e) {
|
||
if (!this.frameState_) return !1;
|
||
var i = this.getCoordinateFromPixel(t),
|
||
r = void 0 !== (e = void 0 !== e ? e : {}).layerFilter ? e.layerFilter : P,
|
||
o = void 0 !== e.hitTolerance ? e.hitTolerance * this.frameState_.pixelRatio : 0;
|
||
return this.renderer_.hasFeatureAtCoordinate(i, this.frameState_, o, r, null)
|
||
}, e.prototype.getEventCoordinate = function (t) {
|
||
return this.getCoordinateFromPixel(this.getEventPixel(t))
|
||
}, e.prototype.getEventPixel = function (t) {
|
||
var e = this.viewport_.getBoundingClientRect(), i = "changedTouches" in t ? t.changedTouches[0] : t;
|
||
return [i.clientX - e.left, i.clientY - e.top]
|
||
}, e.prototype.getTarget = function () {
|
||
return this.get(Gn.TARGET)
|
||
}, e.prototype.getTargetElement = function () {
|
||
var t = this.getTarget();
|
||
return void 0 !== t ? "string" == typeof t ? document.getElementById(t) : t : null
|
||
}, e.prototype.getCoordinateFromPixel = function (t) {
|
||
var e = this.frameState_;
|
||
return e ? ci(e.pixelToCoordinateTransform, t.slice()) : null
|
||
}, e.prototype.getControls = function () {
|
||
return this.controls
|
||
}, e.prototype.getOverlays = function () {
|
||
return this.overlays_
|
||
}, e.prototype.getOverlayById = function (t) {
|
||
var e = this.overlayIdIndex_[t.toString()];
|
||
return void 0 !== e ? e : null
|
||
}, e.prototype.getInteractions = function () {
|
||
return this.interactions
|
||
}, e.prototype.getLayerGroup = function () {
|
||
return this.get(Gn.LAYERGROUP)
|
||
}, e.prototype.getLayers = function () {
|
||
return this.getLayerGroup().getLayers()
|
||
}, e.prototype.getPixelFromCoordinate = function (t) {
|
||
var e = this.frameState_;
|
||
return e ? ci(e.coordinateToPixelTransform, t.slice(0, 2)) : null
|
||
}, e.prototype.getRenderer = function () {
|
||
return this.renderer_
|
||
}, e.prototype.getSize = function () {
|
||
return this.get(Gn.SIZE)
|
||
}, e.prototype.getView = function () {
|
||
return this.get(Gn.VIEW)
|
||
}, e.prototype.getViewport = function () {
|
||
return this.viewport_
|
||
}, e.prototype.getOverlayContainer = function () {
|
||
return this.overlayContainer_
|
||
}, e.prototype.getOverlayContainerStopEvent = function () {
|
||
return this.overlayContainerStopEvent_
|
||
}, e.prototype.getTilePriority = function (t, e, i, r) {
|
||
var o = this.frameState_;
|
||
if (!(o && e in o.wantedTiles)) return 1 / 0;
|
||
if (!o.wantedTiles[e][t.getKey()]) return 1 / 0;
|
||
var n = i[0] - o.focus[0], s = i[1] - o.focus[1];
|
||
return 65536 * Math.log(r) + Math.sqrt(n * n + s * s) / r
|
||
}, e.prototype.handleBrowserEvent = function (t, e) {
|
||
var i = e || t.type, r = new Wo(i, this, t);
|
||
this.handleMapBrowserEvent(r)
|
||
}, e.prototype.handleMapBrowserEvent = function (t) {
|
||
if (this.frameState_) {
|
||
this.focus_ = t.coordinate, t.frameState = this.frameState_;
|
||
var e = this.getInteractions().getArray();
|
||
if (!1 !== this.dispatchEvent(t)) for (var i = e.length - 1; i >= 0; i--) {
|
||
var r = e[i];
|
||
if (r.getActive()) if (!r.handleEvent(t)) break
|
||
}
|
||
}
|
||
}, e.prototype.handlePostRender = function () {
|
||
var t = this.frameState_, e = this.tileQueue_;
|
||
if (!e.isEmpty()) {
|
||
var i = this.maxTilesLoading_, r = i;
|
||
if (t) {
|
||
var o = t.viewHints;
|
||
o[$n.ANIMATING] && (i = this.loadTilesWhileAnimating_ ? 8 : 0, r = 2), o[$n.INTERACTING] && (i = this.loadTilesWhileInteracting_ ? 8 : 0, r = 2)
|
||
}
|
||
e.getTilesLoading() < i && (e.reprioritize(), e.loadMoreTiles(i, r))
|
||
}
|
||
!t || !this.hasListener(eo.RENDERCOMPLETE) || t.animate || this.tileQueue_.getTilesLoading() || function t(e) {
|
||
for (var i = 0, r = e.length; i < r; ++i) {
|
||
var o = e[i];
|
||
if ("function" == typeof o.getLayers) return t(o.getLayers().getArray());
|
||
var n = o.getSource();
|
||
if (n && n.loading) return !0
|
||
}
|
||
return !1
|
||
}(this.getLayers().getArray()) || this.renderer_.dispatchRenderEvent(eo.RENDERCOMPLETE, t);
|
||
for (var n = this.postRenderFunctions_, s = 0, a = n.length; s < a; ++s) n[s](this, t);
|
||
n.length = 0
|
||
}, e.prototype.handleSizeChanged_ = function () {
|
||
this.render()
|
||
}, e.prototype.handleTargetChanged_ = function () {
|
||
var t;
|
||
if (this.getTarget() && (t = this.getTargetElement()), this.keyHandlerKeys_) {
|
||
for (var e = 0, i = this.keyHandlerKeys_.length; e < i; ++e) S(this.keyHandlerKeys_[e]);
|
||
this.keyHandlerKeys_ = null
|
||
}
|
||
if (t) {
|
||
t.appendChild(this.viewport_);
|
||
var r = this.keyboardEventTarget_ ? this.keyboardEventTarget_ : t;
|
||
this.keyHandlerKeys_ = [w(r, F.KEYDOWN, this.handleBrowserEvent, this), w(r, F.KEYPRESS, this.handleBrowserEvent, this)], this.handleResize_ || (this.handleResize_ = this.updateSize.bind(this), addEventListener(F.RESIZE, this.handleResize_, !1))
|
||
} else this.renderer_.removeLayerRenderers(), Do(this.viewport_), void 0 !== this.handleResize_ && (removeEventListener(F.RESIZE, this.handleResize_, !1), this.handleResize_ = void 0);
|
||
this.updateSize()
|
||
}, e.prototype.handleTileChange_ = function () {
|
||
this.render()
|
||
}, e.prototype.handleViewPropertyChanged_ = function () {
|
||
this.render()
|
||
}, e.prototype.handleViewChanged_ = function () {
|
||
this.viewPropertyListenerKey_ && (S(this.viewPropertyListenerKey_), this.viewPropertyListenerKey_ = null), this.viewChangeListenerKey_ && (S(this.viewChangeListenerKey_), this.viewChangeListenerKey_ = null);
|
||
var t = this.getView();
|
||
t && (this.viewport_.setAttribute("data-view", a(t)), this.viewPropertyListenerKey_ = w(t, c.PROPERTYCHANGE, this.handleViewPropertyChanged_, this), this.viewChangeListenerKey_ = w(t, F.CHANGE, this.handleViewPropertyChanged_, this)), this.render()
|
||
}, e.prototype.handleLayerGroupChanged_ = function () {
|
||
this.layerGroupPropertyListenerKeys_ && (this.layerGroupPropertyListenerKeys_.forEach(S), this.layerGroupPropertyListenerKeys_ = null);
|
||
var t = this.getLayerGroup();
|
||
t && (this.layerGroupPropertyListenerKeys_ = [w(t, c.PROPERTYCHANGE, this.render, this), w(t, F.CHANGE, this.render, this)]), this.render()
|
||
}, e.prototype.isRendered = function () {
|
||
return !!this.frameState_
|
||
}, e.prototype.renderSync = function () {
|
||
this.animationDelayKey_ && cancelAnimationFrame(this.animationDelayKey_), this.animationDelay_()
|
||
}, e.prototype.render = function () {
|
||
void 0 === this.animationDelayKey_ && (this.animationDelayKey_ = requestAnimationFrame(this.animationDelay_))
|
||
}, e.prototype.removeControl = function (t) {
|
||
return this.getControls().remove(t)
|
||
}, e.prototype.removeInteraction = function (t) {
|
||
return this.getInteractions().remove(t)
|
||
}, e.prototype.removeLayer = function (t) {
|
||
return this.getLayerGroup().getLayers().remove(t)
|
||
}, e.prototype.removeOverlay = function (t) {
|
||
return this.getOverlays().remove(t)
|
||
}, e.prototype.renderFrame_ = function (t) {
|
||
var e, i = this.getSize(), r = this.getView(), o = [1 / 0, 1 / 0, -1 / 0, -1 / 0], n = this.frameState_,
|
||
s = null;
|
||
if (void 0 !== i && ds(i) && r && r.isDef()) {
|
||
for (var l = r.getHints(this.frameState_ ? this.frameState_.viewHints : void 0), h = this.getLayerGroup().getLayerStatesArray(), u = {}, c = 0, p = h.length; c < p; ++c) u[a(h[c].layer)] = h[c];
|
||
e = r.getState(this.pixelRatio_), s = {
|
||
animate: !1,
|
||
coordinateToPixelTransform: this.coordinateToPixelTransform_,
|
||
extent: o,
|
||
focus: this.focus_ ? this.focus_ : e.center,
|
||
index: this.frameIndex_++,
|
||
layerStates: u,
|
||
layerStatesArray: h,
|
||
pixelRatio: this.pixelRatio_,
|
||
pixelToCoordinateTransform: this.pixelToCoordinateTransform_,
|
||
postRenderFunctions: [],
|
||
size: i,
|
||
skippedFeatureUids: this.skippedFeatureUids_,
|
||
tileQueue: this.tileQueue_,
|
||
time: t,
|
||
usedTiles: {},
|
||
viewState: e,
|
||
viewHints: l,
|
||
wantedTiles: {}
|
||
}
|
||
}
|
||
if (s && (s.extent = Ft(e.center, e.resolution, e.rotation, s.size, o)), this.frameState_ = s, this.renderer_.renderFrame(s), s) {
|
||
if (s.animate && this.render(), Array.prototype.push.apply(this.postRenderFunctions_, s.postRenderFunctions), n) (!this.previousExtent_ || !Vt(this.previousExtent_) && !bt(s.extent, this.previousExtent_)) && (this.dispatchEvent(new Yo(Dn.MOVESTART, this, n)), this.previousExtent_ = vt(this.previousExtent_));
|
||
this.previousExtent_ && !s.viewHints[$n.ANIMATING] && !s.viewHints[$n.INTERACTING] && !bt(s.extent, this.previousExtent_) && (this.dispatchEvent(new Yo(Dn.MOVEEND, this, s)), ut(s.extent, this.previousExtent_))
|
||
}
|
||
this.dispatchEvent(new Yo(Dn.POSTRENDER, this, s)), setTimeout(this.handlePostRender.bind(this), 0)
|
||
}, e.prototype.setLayerGroup = function (t) {
|
||
this.set(Gn.LAYERGROUP, t)
|
||
}, e.prototype.setSize = function (t) {
|
||
this.set(Gn.SIZE, t)
|
||
}, e.prototype.setTarget = function (t) {
|
||
this.set(Gn.TARGET, t)
|
||
}, e.prototype.setView = function (t) {
|
||
this.set(Gn.VIEW, t)
|
||
}, e.prototype.skipFeature = function (t) {
|
||
this.skippedFeatureUids_[a(t)] = !0, this.render()
|
||
}, e.prototype.updateSize = function () {
|
||
var t = this.getTargetElement();
|
||
if (t) {
|
||
var e = getComputedStyle(t);
|
||
this.setSize([t.offsetWidth - parseFloat(e.borderLeftWidth) - parseFloat(e.paddingLeft) - parseFloat(e.paddingRight) - parseFloat(e.borderRightWidth), t.offsetHeight - parseFloat(e.borderTopWidth) - parseFloat(e.paddingTop) - parseFloat(e.paddingBottom) - parseFloat(e.borderBottomWidth)])
|
||
} else this.setSize(void 0)
|
||
}, e.prototype.unskipFeature = function (t) {
|
||
delete this.skippedFeatureUids_[a(t)], this.render()
|
||
}, e
|
||
}(U);
|
||
var ys = function (t) {
|
||
function e(e) {
|
||
t.call(this), this.element = e.element ? e.element : null, this.target_ = null, this.map_ = null, this.listenerKeys = [], this.render = e.render ? e.render : I, e.target && this.setTarget(e.target)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.disposeInternal = function () {
|
||
Do(this.element), t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.getMap = function () {
|
||
return this.map_
|
||
}, e.prototype.setMap = function (t) {
|
||
this.map_ && Do(this.element);
|
||
for (var e = 0, i = this.listenerKeys.length; e < i; ++e) S(this.listenerKeys[e]);
|
||
(this.listenerKeys.length = 0, this.map_ = t, this.map_) && ((this.target_ ? this.target_ : t.getOverlayContainerStopEvent()).appendChild(this.element), this.render !== I && this.listenerKeys.push(w(t, Dn.POSTRENDER, this.render, this)), t.render())
|
||
}, e.prototype.setTarget = function (t) {
|
||
this.target_ = "string" == typeof t ? document.getElementById(t) : t
|
||
}, e
|
||
}(U), vs = "ol-hidden", _s = "ol-selectable", xs = "ol-unselectable", ws = "ol-unsupported", bs = "ol-control",
|
||
Cs = "ol-collapsed", Ss = function () {
|
||
var t, e = {};
|
||
return function (i) {
|
||
if (t || (t = document.createElement("div").style), !(i in e)) {
|
||
t.font = i;
|
||
var r = t.fontFamily;
|
||
if (t.font = "", !r) return null;
|
||
e[i] = r.split(/,\s?/)
|
||
}
|
||
return e[i]
|
||
}
|
||
}();
|
||
|
||
function Es(t, e) {
|
||
return t.visible && e >= t.minResolution && e < t.maxResolution
|
||
}
|
||
|
||
var Ts = function (t) {
|
||
function e(e) {
|
||
var i = p({}, e);
|
||
delete i.source, t.call(this, i), this.mapPrecomposeKey_ = null, this.mapRenderKey_ = null, this.sourceChangeKey_ = null, e.map && this.setMap(e.map), w(this, z(as.SOURCE), this.handleSourcePropertyChange_, this);
|
||
var r = e.source ? e.source : null;
|
||
this.setSource(r)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getLayersArray = function (t) {
|
||
var e = t || [];
|
||
return e.push(this), e
|
||
}, e.prototype.getLayerStatesArray = function (t) {
|
||
var e = t || [];
|
||
return e.push(this.getLayerState()), e
|
||
}, e.prototype.getSource = function () {
|
||
return this.get(as.SOURCE) || null
|
||
}, e.prototype.getSourceState = function () {
|
||
var t = this.getSource();
|
||
return t ? t.getState() : hs.UNDEFINED
|
||
}, e.prototype.handleSourceChange_ = function () {
|
||
this.changed()
|
||
}, e.prototype.handleSourcePropertyChange_ = function () {
|
||
this.sourceChangeKey_ && (S(this.sourceChangeKey_), this.sourceChangeKey_ = null);
|
||
var t = this.getSource();
|
||
t && (this.sourceChangeKey_ = w(t, F.CHANGE, this.handleSourceChange_, this)), this.changed()
|
||
}, e.prototype.setMap = function (t) {
|
||
this.mapPrecomposeKey_ && (S(this.mapPrecomposeKey_), this.mapPrecomposeKey_ = null), t || this.changed(), this.mapRenderKey_ && (S(this.mapRenderKey_), this.mapRenderKey_ = null), t && (this.mapPrecomposeKey_ = w(t, eo.PRECOMPOSE, function (t) {
|
||
var e = t, i = this.getLayerState();
|
||
i.managed = !1, void 0 === this.getZIndex() && (i.zIndex = 1 / 0), e.frameState.layerStatesArray.push(i), e.frameState.layerStates[a(this)] = i
|
||
}, this), this.mapRenderKey_ = w(this, F.CHANGE, t.render, t), this.changed())
|
||
}, e.prototype.setSource = function (t) {
|
||
this.set(as.SOURCE, t)
|
||
}, e
|
||
}(ls);
|
||
|
||
function Rs(t) {
|
||
this.updateElement_(t.frameState)
|
||
}
|
||
|
||
var Ps = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {
|
||
element: document.createElement("div"),
|
||
render: i.render || Rs,
|
||
target: i.target
|
||
}), this.ulElement_ = document.createElement("ul"), this.collapsed_ = void 0 === i.collapsed || i.collapsed, this.overrideCollapsible_ = void 0 !== i.collapsible, this.collapsible_ = void 0 === i.collapsible || i.collapsible, this.collapsible_ || (this.collapsed_ = !1);
|
||
var r = void 0 !== i.className ? i.className : "ol-attribution",
|
||
o = void 0 !== i.tipLabel ? i.tipLabel : "Attributions",
|
||
n = void 0 !== i.collapseLabel ? i.collapseLabel : "»";
|
||
"string" == typeof n ? (this.collapseLabel_ = document.createElement("span"), this.collapseLabel_.textContent = n) : this.collapseLabel_ = n;
|
||
var s = void 0 !== i.label ? i.label : "i";
|
||
"string" == typeof s ? (this.label_ = document.createElement("span"), this.label_.textContent = s) : this.label_ = s;
|
||
var a = this.collapsible_ && !this.collapsed_ ? this.collapseLabel_ : this.label_,
|
||
l = document.createElement("button");
|
||
l.setAttribute("type", "button"), l.title = o, l.appendChild(a), w(l, F.CLICK, this.handleClick_, this);
|
||
var h = r + " " + xs + " " + bs + (this.collapsed_ && this.collapsible_ ? " " + Cs : "") + (this.collapsible_ ? "" : " ol-uncollapsible"),
|
||
u = this.element;
|
||
u.className = h, u.appendChild(this.ulElement_), u.appendChild(l), this.renderedAttributions_ = [], this.renderedVisible_ = !0
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.collectSourceAttributions_ = function (t) {
|
||
for (var e = {}, i = [], r = t.layerStatesArray, o = t.viewState.resolution, n = 0, s = r.length; n < s; ++n) {
|
||
var a = r[n];
|
||
if (Es(a, o)) {
|
||
var l = a.layer.getSource();
|
||
if (l) {
|
||
var h = l.getAttributions();
|
||
if (h) {
|
||
var u = h(t);
|
||
if (u) if (this.overrideCollapsible_ || !1 !== l.getAttributionsCollapsible() || this.setCollapsible(!1), Array.isArray(u)) for (var c = 0, p = u.length; c < p; ++c) u[c] in e || (i.push(u[c]), e[u[c]] = !0); else u in e || (i.push(u), e[u] = !0)
|
||
}
|
||
}
|
||
}
|
||
}
|
||
return i
|
||
}, e.prototype.updateElement_ = function (t) {
|
||
if (t) {
|
||
var e = this.collectSourceAttributions_(t), i = e.length > 0;
|
||
if (this.renderedVisible_ != i && (this.element.style.display = i ? "" : "none", this.renderedVisible_ = i), !it(e, this.renderedAttributions_)) {
|
||
Go(this.ulElement_);
|
||
for (var r = 0, o = e.length; r < o; ++r) {
|
||
var n = document.createElement("li");
|
||
n.innerHTML = e[r], this.ulElement_.appendChild(n)
|
||
}
|
||
this.renderedAttributions_ = e
|
||
}
|
||
} else this.renderedVisible_ && (this.element.style.display = "none", this.renderedVisible_ = !1)
|
||
}, e.prototype.handleClick_ = function (t) {
|
||
t.preventDefault(), this.handleToggle_()
|
||
}, e.prototype.handleToggle_ = function () {
|
||
this.element.classList.toggle(Cs), this.collapsed_ ? No(this.collapseLabel_, this.label_) : No(this.label_, this.collapseLabel_), this.collapsed_ = !this.collapsed_
|
||
}, e.prototype.getCollapsible = function () {
|
||
return this.collapsible_
|
||
}, e.prototype.setCollapsible = function (t) {
|
||
this.collapsible_ !== t && (this.collapsible_ = t, this.element.classList.toggle("ol-uncollapsible"), !t && this.collapsed_ && this.handleToggle_())
|
||
}, e.prototype.setCollapsed = function (t) {
|
||
this.collapsible_ && this.collapsed_ !== t && this.handleToggle_()
|
||
}, e.prototype.getCollapsed = function () {
|
||
return this.collapsed_
|
||
}, e
|
||
}(ys);
|
||
|
||
function Ls(t) {
|
||
var e = t.frameState;
|
||
if (e) {
|
||
var i = e.viewState.rotation;
|
||
if (i != this.rotation_) {
|
||
var r = "rotate(" + i + "rad)";
|
||
if (this.autoHide_) {
|
||
var o = this.element.classList.contains(vs);
|
||
o || 0 !== i ? o && 0 !== i && this.element.classList.remove(vs) : this.element.classList.add(vs)
|
||
}
|
||
this.label_.style.msTransform = r, this.label_.style.webkitTransform = r, this.label_.style.transform = r
|
||
}
|
||
this.rotation_ = i
|
||
}
|
||
}
|
||
|
||
var Is = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {element: document.createElement("div"), render: i.render || Ls, target: i.target});
|
||
var r = void 0 !== i.className ? i.className : "ol-rotate", o = void 0 !== i.label ? i.label : "⇧";
|
||
this.label_ = null, "string" == typeof o ? (this.label_ = document.createElement("span"), this.label_.className = "ol-compass", this.label_.textContent = o) : (this.label_ = o, this.label_.classList.add("ol-compass"));
|
||
var n = i.tipLabel ? i.tipLabel : "Reset rotation", s = document.createElement("button");
|
||
s.className = r + "-reset", s.setAttribute("type", "button"), s.title = n, s.appendChild(this.label_), w(s, F.CLICK, this.handleClick_, this);
|
||
var a = r + " " + xs + " " + bs, l = this.element;
|
||
l.className = a, l.appendChild(s), this.callResetNorth_ = i.resetNorth ? i.resetNorth : void 0, this.duration_ = void 0 !== i.duration ? i.duration : 250, this.autoHide_ = void 0 === i.autoHide || i.autoHide, this.rotation_ = void 0, this.autoHide_ && this.element.classList.add(vs)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleClick_ = function (t) {
|
||
t.preventDefault(), void 0 !== this.callResetNorth_ ? this.callResetNorth_() : this.resetNorth_()
|
||
}, e.prototype.resetNorth_ = function () {
|
||
var t = this.getMap().getView();
|
||
t && void 0 !== t.getRotation() && (this.duration_ > 0 ? t.animate({
|
||
rotation: 0,
|
||
duration: this.duration_,
|
||
easing: Lo
|
||
}) : t.setRotation(0))
|
||
}, e
|
||
}(ys), Os = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {element: document.createElement("div"), target: i.target});
|
||
var r = void 0 !== i.className ? i.className : "ol-zoom", o = void 0 !== i.delta ? i.delta : 1,
|
||
n = void 0 !== i.zoomInLabel ? i.zoomInLabel : "+",
|
||
s = void 0 !== i.zoomOutLabel ? i.zoomOutLabel : "−",
|
||
a = void 0 !== i.zoomInTipLabel ? i.zoomInTipLabel : "Zoom in",
|
||
l = void 0 !== i.zoomOutTipLabel ? i.zoomOutTipLabel : "Zoom out",
|
||
h = document.createElement("button");
|
||
h.className = r + "-in", h.setAttribute("type", "button"), h.title = a, h.appendChild("string" == typeof n ? document.createTextNode(n) : n), w(h, F.CLICK, this.handleClick_.bind(this, o));
|
||
var u = document.createElement("button");
|
||
u.className = r + "-out", u.setAttribute("type", "button"), u.title = l, u.appendChild("string" == typeof s ? document.createTextNode(s) : s), w(u, F.CLICK, this.handleClick_.bind(this, -o));
|
||
var c = r + " " + xs + " " + bs, p = this.element;
|
||
p.className = c, p.appendChild(h), p.appendChild(u), this.duration_ = void 0 !== i.duration ? i.duration : 250
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleClick_ = function (t, e) {
|
||
e.preventDefault(), this.zoomByDelta_(t)
|
||
}, e.prototype.zoomByDelta_ = function (t) {
|
||
var e = this.getMap().getView();
|
||
if (e) {
|
||
var i = e.getResolution();
|
||
if (i) {
|
||
var r = e.constrainResolution(i, t);
|
||
this.duration_ > 0 ? (e.getAnimating() && e.cancelAnimations(), e.animate({
|
||
resolution: r,
|
||
duration: this.duration_,
|
||
easing: Lo
|
||
})) : e.setResolution(r)
|
||
}
|
||
}
|
||
}, e
|
||
}(ys);
|
||
|
||
function Ms(t) {
|
||
var e = t || {}, i = new Y;
|
||
return (void 0 === e.zoom || e.zoom) && i.push(new Os(e.zoomOptions)), (void 0 === e.rotate || e.rotate) && i.push(new Is(e.rotateOptions)), (void 0 === e.attribution || e.attribution) && i.push(new Ps(e.attributionOptions)), i
|
||
}
|
||
|
||
var As = {ACTIVE: "active"};
|
||
|
||
function ks(t, e, i) {
|
||
var r = t.getCenter();
|
||
if (r) {
|
||
var o = t.constrainCenter([r[0] + e[0], r[1] + e[1]]);
|
||
i ? t.animate({duration: i, easing: Oo, center: o}) : t.setCenter(o)
|
||
}
|
||
}
|
||
|
||
function Fs(t, e, i, r) {
|
||
e = t.constrainRotation(e, 0), Ns(t, e, i, r)
|
||
}
|
||
|
||
function Ns(t, e, i, r) {
|
||
if (void 0 !== e) {
|
||
var o = t.getRotation(), n = t.getCenter();
|
||
void 0 !== o && n && r > 0 ? t.animate({
|
||
rotation: e,
|
||
anchor: i,
|
||
duration: r,
|
||
easing: Lo
|
||
}) : t.rotate(e, i)
|
||
}
|
||
}
|
||
|
||
function Ds(t, e, i, r, o) {
|
||
e = t.constrainResolution(e, 0, o), js(t, e, i, r)
|
||
}
|
||
|
||
function Gs(t, e, i, r) {
|
||
var o = t.getResolution(), n = t.constrainResolution(o, e, 0);
|
||
if (void 0 !== n) {
|
||
var s = t.getResolutions();
|
||
n = te(n, t.getMinResolution() || s[s.length - 1], t.getMaxResolution() || s[0])
|
||
}
|
||
if (i && void 0 !== n && n !== o) {
|
||
var a = t.getCenter(), l = t.calculateCenterZoom(n, i);
|
||
l = t.constrainCenter(l), i = [(n * a[0] - o * l[0]) / (n - o), (n * a[1] - o * l[1]) / (n - o)]
|
||
}
|
||
js(t, n, i, r)
|
||
}
|
||
|
||
function js(t, e, i, r) {
|
||
if (e) {
|
||
var o = t.getResolution(), n = t.getCenter();
|
||
if (void 0 !== o && n && e !== o && r) t.animate({
|
||
resolution: e,
|
||
anchor: i,
|
||
duration: r,
|
||
easing: Lo
|
||
}); else {
|
||
if (i) {
|
||
var s = t.calculateCenterZoom(e, i);
|
||
t.setCenter(s)
|
||
}
|
||
t.setResolution(e)
|
||
}
|
||
}
|
||
}
|
||
|
||
var zs = function (t) {
|
||
function e(e) {
|
||
t.call(this), e.handleEvent && (this.handleEvent = e.handleEvent), this.map_ = null, this.setActive(!0)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getActive = function () {
|
||
return this.get(As.ACTIVE)
|
||
}, e.prototype.getMap = function () {
|
||
return this.map_
|
||
}, e.prototype.handleEvent = function (t) {
|
||
return !0
|
||
}, e.prototype.setActive = function (t) {
|
||
this.set(As.ACTIVE, t)
|
||
}, e.prototype.setMap = function (t) {
|
||
this.map_ = t
|
||
}, e
|
||
}(U);
|
||
|
||
function Us(t) {
|
||
var e = !1;
|
||
if (t.type == Ho.DBLCLICK) {
|
||
var i = t.originalEvent, r = t.map, o = t.coordinate, n = i.shiftKey ? -this.delta_ : this.delta_;
|
||
Gs(r.getView(), n, o, this.duration_), t.preventDefault(), e = !0
|
||
}
|
||
return !e
|
||
}
|
||
|
||
var Bs = function (t) {
|
||
function e(e) {
|
||
t.call(this, {handleEvent: Us});
|
||
var i = e || {};
|
||
this.delta_ = i.delta ? i.delta : 1, this.duration_ = void 0 !== i.duration ? i.duration : 250
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(zs), Vs = function (t) {
|
||
var e = t.originalEvent;
|
||
return e.altKey && !(e.metaKey || e.ctrlKey) && !e.shiftKey
|
||
}, Ys = function (t) {
|
||
var e = t.originalEvent;
|
||
return e.altKey && !(e.metaKey || e.ctrlKey) && e.shiftKey
|
||
}, Ws = function (t) {
|
||
return t.target.getTargetElement() === document.activeElement
|
||
}, Hs = P, Xs = function (t) {
|
||
var e = t.originalEvent;
|
||
return 0 == e.button && !(br && Cr && e.ctrlKey)
|
||
}, qs = L, Zs = function (t) {
|
||
return "pointermove" == t.type
|
||
}, Ks = function (t) {
|
||
return t.type == Ho.SINGLECLICK
|
||
}, Js = function (t) {
|
||
var e = t.originalEvent;
|
||
return !e.altKey && !(e.metaKey || e.ctrlKey) && !e.shiftKey
|
||
}, $s = function (t) {
|
||
var e = t.originalEvent;
|
||
return !e.altKey && !(e.metaKey || e.ctrlKey) && e.shiftKey
|
||
}, Qs = function (t) {
|
||
var e = t.originalEvent.target.tagName;
|
||
return "INPUT" !== e && "SELECT" !== e && "TEXTAREA" !== e
|
||
}, ta = function (t) {
|
||
var e = t.pointerEvent;
|
||
return W(void 0 !== e, 56), "mouse" == e.pointerType
|
||
}, ea = function (t) {
|
||
var e = t.pointerEvent;
|
||
return W(void 0 !== e, 56), e.isPrimary && 0 === e.button
|
||
};
|
||
|
||
function ia(t) {
|
||
for (var e = t.length, i = 0, r = 0, o = 0; o < e; o++) i += t[o].clientX, r += t[o].clientY;
|
||
return [i / e, r / e]
|
||
}
|
||
|
||
var ra = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, i), i.handleDownEvent && (this.handleDownEvent = i.handleDownEvent), i.handleDragEvent && (this.handleDragEvent = i.handleDragEvent), i.handleMoveEvent && (this.handleMoveEvent = i.handleMoveEvent), i.handleUpEvent && (this.handleUpEvent = i.handleUpEvent), i.stopDown && (this.stopDown = i.stopDown), this.handlingDownUpSequence = !1, this.trackedPointers_ = {}, this.targetPointers = []
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleDownEvent = function (t) {
|
||
return !1
|
||
}, e.prototype.handleDragEvent = function (t) {
|
||
}, e.prototype.handleEvent = function (t) {
|
||
if (!t.pointerEvent) return !0;
|
||
var e = !1;
|
||
if (this.updateTrackedPointers_(t), this.handlingDownUpSequence) {
|
||
if (t.type == Ho.POINTERDRAG) this.handleDragEvent(t); else if (t.type == Ho.POINTERUP) {
|
||
var i = this.handleUpEvent(t);
|
||
this.handlingDownUpSequence = i && this.targetPointers.length > 0
|
||
}
|
||
} else if (t.type == Ho.POINTERDOWN) {
|
||
var r = this.handleDownEvent(t);
|
||
r && t.preventDefault(), this.handlingDownUpSequence = r, e = this.stopDown(r)
|
||
} else t.type == Ho.POINTERMOVE && this.handleMoveEvent(t);
|
||
return !e
|
||
}, e.prototype.handleMoveEvent = function (t) {
|
||
}, e.prototype.handleUpEvent = function (t) {
|
||
return !1
|
||
}, e.prototype.stopDown = function (t) {
|
||
return t
|
||
}, e.prototype.updateTrackedPointers_ = function (t) {
|
||
if (function (t) {
|
||
var e = t.type;
|
||
return e === Ho.POINTERDOWN || e === Ho.POINTERDRAG || e === Ho.POINTERUP
|
||
}(t)) {
|
||
var e = t.pointerEvent, i = e.pointerId.toString();
|
||
t.type == Ho.POINTERUP ? delete this.trackedPointers_[i] : t.type == Ho.POINTERDOWN ? this.trackedPointers_[i] = e : i in this.trackedPointers_ && (this.trackedPointers_[i] = e), this.targetPointers = f(this.trackedPointers_)
|
||
}
|
||
}, e
|
||
}(zs), oa = function (t) {
|
||
function e(e) {
|
||
t.call(this, {stopDown: L});
|
||
var i = e || {};
|
||
this.kinetic_ = i.kinetic, this.lastCentroid = null, this.lastPointersCount_, this.panning_ = !1, this.condition_ = i.condition ? i.condition : Js, this.noKinetic_ = !1
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleDragEvent = function (t) {
|
||
this.panning_ || (this.panning_ = !0, this.getMap().getView().setHint($n.INTERACTING, 1));
|
||
var e = this.targetPointers, i = ia(e);
|
||
if (e.length == this.lastPointersCount_) {
|
||
if (this.kinetic_ && this.kinetic_.update(i[0], i[1]), this.lastCentroid) {
|
||
var r = this.lastCentroid[0] - i[0], o = i[1] - this.lastCentroid[1], n = t.map.getView(),
|
||
s = [r, o];
|
||
Br(s, n.getResolution()), Ur(s, n.getRotation()), Fr(s, n.getCenter()), s = n.constrainCenter(s), n.setCenter(s)
|
||
}
|
||
} else this.kinetic_ && this.kinetic_.begin();
|
||
this.lastCentroid = i, this.lastPointersCount_ = e.length
|
||
}, e.prototype.handleUpEvent = function (t) {
|
||
var e = t.map, i = e.getView();
|
||
if (0 === this.targetPointers.length) {
|
||
if (!this.noKinetic_ && this.kinetic_ && this.kinetic_.end()) {
|
||
var r = this.kinetic_.getDistance(), o = this.kinetic_.getAngle(), n = i.getCenter(),
|
||
s = e.getPixelFromCoordinate(n),
|
||
a = e.getCoordinateFromPixel([s[0] - r * Math.cos(o), s[1] - r * Math.sin(o)]);
|
||
i.animate({center: i.constrainCenter(a), duration: 500, easing: Lo})
|
||
}
|
||
return this.panning_ && (this.panning_ = !1, i.setHint($n.INTERACTING, -1)), !1
|
||
}
|
||
return this.kinetic_ && this.kinetic_.begin(), this.lastCentroid = null, !0
|
||
}, e.prototype.handleDownEvent = function (t) {
|
||
if (this.targetPointers.length > 0 && this.condition_(t)) {
|
||
var e = t.map.getView();
|
||
return this.lastCentroid = null, e.getAnimating() && e.setCenter(t.frameState.viewState.center), this.kinetic_ && this.kinetic_.begin(), this.noKinetic_ = this.targetPointers.length > 1, !0
|
||
}
|
||
return !1
|
||
}, e
|
||
}(ra), na = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {stopDown: L}), this.condition_ = i.condition ? i.condition : Ys, this.lastAngle_ = void 0, this.duration_ = void 0 !== i.duration ? i.duration : 250
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleDragEvent = function (t) {
|
||
if (ta(t)) {
|
||
var e = t.map, i = e.getView();
|
||
if (i.getConstraints().rotation !== qn) {
|
||
var r = e.getSize(), o = t.pixel, n = Math.atan2(r[1] / 2 - o[1], o[0] - r[0] / 2);
|
||
if (void 0 !== this.lastAngle_) {
|
||
var s = n - this.lastAngle_, a = i.getRotation();
|
||
Ns(i, a - s)
|
||
}
|
||
this.lastAngle_ = n
|
||
}
|
||
}
|
||
}, e.prototype.handleUpEvent = function (t) {
|
||
if (!ta(t)) return !0;
|
||
var e = t.map.getView();
|
||
e.setHint($n.INTERACTING, -1);
|
||
var i = e.getRotation();
|
||
return Fs(e, i, void 0, this.duration_), !1
|
||
}, e.prototype.handleDownEvent = function (t) {
|
||
return !!ta(t) && (!(!Xs(t) || !this.condition_(t)) && (t.map.getView().setHint($n.INTERACTING, 1), this.lastAngle_ = void 0, !0))
|
||
}, e
|
||
}(ra), sa = function (t) {
|
||
function e(e) {
|
||
t.call(this), this.geometry_ = null, this.element_ = document.createElement("div"), this.element_.style.position = "absolute", this.element_.className = "ol-box " + e, this.map_ = null, this.startPixel_ = null, this.endPixel_ = null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.disposeInternal = function () {
|
||
this.setMap(null)
|
||
}, e.prototype.render_ = function () {
|
||
var t = this.startPixel_, e = this.endPixel_, i = this.element_.style;
|
||
i.left = Math.min(t[0], e[0]) + "px", i.top = Math.min(t[1], e[1]) + "px", i.width = Math.abs(e[0] - t[0]) + "px", i.height = Math.abs(e[1] - t[1]) + "px"
|
||
}, e.prototype.setMap = function (t) {
|
||
if (this.map_) {
|
||
this.map_.getOverlayContainer().removeChild(this.element_);
|
||
var e = this.element_.style;
|
||
e.left = e.top = e.width = e.height = "inherit"
|
||
}
|
||
this.map_ = t, this.map_ && this.map_.getOverlayContainer().appendChild(this.element_)
|
||
}, e.prototype.setPixels = function (t, e) {
|
||
this.startPixel_ = t, this.endPixel_ = e, this.createOrUpdateGeometry(), this.render_()
|
||
}, e.prototype.createOrUpdateGeometry = function () {
|
||
var t = this.startPixel_, e = this.endPixel_,
|
||
i = [t, [t[0], e[1]], e, [e[0], t[1]]].map(this.map_.getCoordinateFromPixel, this.map_);
|
||
i[4] = i[0].slice(), this.geometry_ ? this.geometry_.setCoordinates([i]) : this.geometry_ = new fr([i])
|
||
}, e.prototype.getGeometry = function () {
|
||
return this.geometry_
|
||
}, e
|
||
}(R), aa = "boxstart", la = "boxdrag", ha = "boxend", ua = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, e), this.coordinate = i, this.mapBrowserEvent = r
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A), ca = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = e || {};
|
||
this.box_ = new sa(i.className || "ol-dragbox"), this.minArea_ = void 0 !== i.minArea ? i.minArea : 64, this.onBoxEnd_ = i.onBoxEnd ? i.onBoxEnd : I, this.startPixel_ = null, this.condition_ = i.condition ? i.condition : Hs, this.boxEndCondition_ = i.boxEndCondition ? i.boxEndCondition : this.defaultBoxEndCondition
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.defaultBoxEndCondition = function (t, e, i) {
|
||
var r = i[0] - e[0], o = i[1] - e[1];
|
||
return r * r + o * o >= this.minArea_
|
||
}, e.prototype.getGeometry = function () {
|
||
return this.box_.getGeometry()
|
||
}, e.prototype.handleDragEvent = function (t) {
|
||
ta(t) && (this.box_.setPixels(this.startPixel_, t.pixel), this.dispatchEvent(new ua(la, t.coordinate, t)))
|
||
}, e.prototype.handleUpEvent = function (t) {
|
||
return !ta(t) || (this.box_.setMap(null), this.boxEndCondition_(t, this.startPixel_, t.pixel) && (this.onBoxEnd_(t), this.dispatchEvent(new ua(ha, t.coordinate, t))), !1)
|
||
}, e.prototype.handleDownEvent = function (t) {
|
||
return !!ta(t) && (!(!Xs(t) || !this.condition_(t)) && (this.startPixel_ = t.pixel, this.box_.setMap(t.map), this.box_.setPixels(this.startPixel_, this.startPixel_), this.dispatchEvent(new ua(aa, t.coordinate, t)), !0))
|
||
}, e
|
||
}(ra);
|
||
|
||
function pa() {
|
||
var t = this.getMap(), e = t.getView(), i = t.getSize(), r = this.getGeometry().getExtent();
|
||
if (this.out_) {
|
||
var o = e.calculateExtent(i),
|
||
n = xt([t.getPixelFromCoordinate(Ot(r)), t.getPixelFromCoordinate(zt(r))]);
|
||
Wt(o, 1 / e.getResolutionForExtent(n, i)), r = o
|
||
}
|
||
var s = e.constrainResolution(e.getResolutionForExtent(r, i)), a = At(r);
|
||
a = e.constrainCenter(a), e.animate({resolution: s, center: a, duration: this.duration_, easing: Lo})
|
||
}
|
||
|
||
var da = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = i.condition ? i.condition : $s;
|
||
t.call(this, {
|
||
condition: r,
|
||
className: i.className || "ol-dragzoom",
|
||
onBoxEnd: pa
|
||
}), this.duration_ = void 0 !== i.duration ? i.duration : 200, this.out_ = void 0 !== i.out && i.out
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(ca), fa = {LEFT: 37, UP: 38, RIGHT: 39, DOWN: 40};
|
||
|
||
function ga(t) {
|
||
var e = !1;
|
||
if (t.type == F.KEYDOWN) {
|
||
var i = t.originalEvent.keyCode;
|
||
if (this.condition_(t) && (i == fa.DOWN || i == fa.LEFT || i == fa.RIGHT || i == fa.UP)) {
|
||
var r = t.map.getView(), o = r.getResolution() * this.pixelDelta_, n = 0, s = 0;
|
||
i == fa.DOWN ? s = -o : i == fa.LEFT ? n = -o : i == fa.RIGHT ? n = o : s = o;
|
||
var a = [n, s];
|
||
Ur(a, r.getRotation()), ks(r, a, this.duration_), t.preventDefault(), e = !0
|
||
}
|
||
}
|
||
return !e
|
||
}
|
||
|
||
var ma = function (t) {
|
||
function e(e) {
|
||
t.call(this, {handleEvent: ga});
|
||
var i = e || {};
|
||
this.defaultCondition_ = function (t) {
|
||
return Js(t) && Qs(t)
|
||
}, this.condition_ = void 0 !== i.condition ? i.condition : this.defaultCondition_, this.duration_ = void 0 !== i.duration ? i.duration : 100, this.pixelDelta_ = void 0 !== i.pixelDelta ? i.pixelDelta : 128
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(zs);
|
||
|
||
function ya(t) {
|
||
var e = !1;
|
||
if (t.type == F.KEYDOWN || t.type == F.KEYPRESS) {
|
||
var i = t.originalEvent.charCode;
|
||
if (this.condition_(t) && (i == "+".charCodeAt(0) || i == "-".charCodeAt(0))) {
|
||
var r = t.map, o = i == "+".charCodeAt(0) ? this.delta_ : -this.delta_;
|
||
Gs(r.getView(), o, void 0, this.duration_), t.preventDefault(), e = !0
|
||
}
|
||
}
|
||
return !e
|
||
}
|
||
|
||
var va = function (t) {
|
||
function e(e) {
|
||
t.call(this, {handleEvent: ya});
|
||
var i = e || {};
|
||
this.condition_ = i.condition ? i.condition : Qs, this.delta_ = i.delta ? i.delta : 1, this.duration_ = void 0 !== i.duration ? i.duration : 100
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(zs), _a = {TRACKPAD: "trackpad", WHEEL: "wheel"}, xa = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, i), this.delta_ = 0, this.duration_ = void 0 !== i.duration ? i.duration : 250, this.timeout_ = void 0 !== i.timeout ? i.timeout : 80, this.useAnchor_ = void 0 === i.useAnchor || i.useAnchor, this.constrainResolution_ = i.constrainResolution || !1, this.condition_ = i.condition ? i.condition : Hs, this.lastAnchor_ = null, this.startTime_ = void 0, this.timeoutId_, this.mode_ = void 0, this.trackpadEventGap_ = 400, this.trackpadTimeoutId_, this.trackpadDeltaPerZoom_ = 300, this.trackpadZoomBuffer_ = 1.5
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.decrementInteractingHint_ = function () {
|
||
this.trackpadTimeoutId_ = void 0, this.getMap().getView().setHint($n.INTERACTING, -1)
|
||
}, e.prototype.handleEvent = function (t) {
|
||
if (!this.condition_(t)) return !0;
|
||
var e = t.type;
|
||
if (e !== F.WHEEL && e !== F.MOUSEWHEEL) return !0;
|
||
t.preventDefault();
|
||
var i, r = t.map, o = t.originalEvent;
|
||
if (this.useAnchor_ && (this.lastAnchor_ = t.coordinate), t.type == F.WHEEL ? (i = o.deltaY, xr && o.deltaMode === WheelEvent.DOM_DELTA_PIXEL && (i /= Sr), o.deltaMode === WheelEvent.DOM_DELTA_LINE && (i *= 40)) : t.type == F.MOUSEWHEEL && (i = -o.wheelDeltaY, wr && (i /= 3)), 0 === i) return !1;
|
||
var n = Date.now();
|
||
if (void 0 === this.startTime_ && (this.startTime_ = n), (!this.mode_ || n - this.startTime_ > this.trackpadEventGap_) && (this.mode_ = Math.abs(i) < 4 ? _a.TRACKPAD : _a.WHEEL), this.mode_ === _a.TRACKPAD) {
|
||
var s = r.getView();
|
||
this.trackpadTimeoutId_ ? clearTimeout(this.trackpadTimeoutId_) : s.setHint($n.INTERACTING, 1), this.trackpadTimeoutId_ = setTimeout(this.decrementInteractingHint_.bind(this), this.trackpadEventGap_);
|
||
var a = s.getResolution() * Math.pow(2, i / this.trackpadDeltaPerZoom_), l = s.getMinResolution(),
|
||
h = s.getMaxResolution(), u = 0;
|
||
if (a < l ? (a = Math.max(a, l / this.trackpadZoomBuffer_), u = 1) : a > h && (a = Math.min(a, h * this.trackpadZoomBuffer_), u = -1), this.lastAnchor_) {
|
||
var c = s.calculateCenterZoom(a, this.lastAnchor_);
|
||
s.setCenter(s.constrainCenter(c))
|
||
}
|
||
return s.setResolution(a), 0 === u && this.constrainResolution_ && s.animate({
|
||
resolution: s.constrainResolution(a, i > 0 ? -1 : 1),
|
||
easing: Lo,
|
||
anchor: this.lastAnchor_,
|
||
duration: this.duration_
|
||
}), u > 0 ? s.animate({
|
||
resolution: l,
|
||
easing: Lo,
|
||
anchor: this.lastAnchor_,
|
||
duration: 500
|
||
}) : u < 0 && s.animate({
|
||
resolution: h,
|
||
easing: Lo,
|
||
anchor: this.lastAnchor_,
|
||
duration: 500
|
||
}), this.startTime_ = n, !1
|
||
}
|
||
this.delta_ += i;
|
||
var p = Math.max(this.timeout_ - (n - this.startTime_), 0);
|
||
return clearTimeout(this.timeoutId_), this.timeoutId_ = setTimeout(this.handleWheelZoom_.bind(this, r), p), !1
|
||
}, e.prototype.handleWheelZoom_ = function (t) {
|
||
var e = t.getView();
|
||
e.getAnimating() && e.cancelAnimations();
|
||
Gs(e, -te(this.delta_, -1, 1), this.lastAnchor_, this.duration_), this.mode_ = void 0, this.delta_ = 0, this.lastAnchor_ = null, this.startTime_ = void 0, this.timeoutId_ = void 0
|
||
}, e.prototype.setMouseAnchor = function (t) {
|
||
this.useAnchor_ = t, t || (this.lastAnchor_ = null)
|
||
}, e
|
||
}(zs), wa = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = i;
|
||
r.stopDown || (r.stopDown = L), t.call(this, r), this.anchor_ = null, this.lastAngle_ = void 0, this.rotating_ = !1, this.rotationDelta_ = 0, this.threshold_ = void 0 !== i.threshold ? i.threshold : .3, this.duration_ = void 0 !== i.duration ? i.duration : 250
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleDragEvent = function (t) {
|
||
var e = 0, i = this.targetPointers[0], r = this.targetPointers[1],
|
||
o = Math.atan2(r.clientY - i.clientY, r.clientX - i.clientX);
|
||
if (void 0 !== this.lastAngle_) {
|
||
var n = o - this.lastAngle_;
|
||
this.rotationDelta_ += n, !this.rotating_ && Math.abs(this.rotationDelta_) > this.threshold_ && (this.rotating_ = !0), e = n
|
||
}
|
||
this.lastAngle_ = o;
|
||
var s = t.map, a = s.getView();
|
||
if (a.getConstraints().rotation !== qn) {
|
||
var l = s.getViewport().getBoundingClientRect(), h = ia(this.targetPointers);
|
||
if (h[0] -= l.left, h[1] -= l.top, this.anchor_ = s.getCoordinateFromPixel(h), this.rotating_) {
|
||
var u = a.getRotation();
|
||
s.render(), Ns(a, u + e, this.anchor_)
|
||
}
|
||
}
|
||
}, e.prototype.handleUpEvent = function (t) {
|
||
if (this.targetPointers.length < 2) {
|
||
var e = t.map.getView();
|
||
if (e.setHint($n.INTERACTING, -1), this.rotating_) {
|
||
var i = e.getRotation();
|
||
Fs(e, i, this.anchor_, this.duration_)
|
||
}
|
||
return !1
|
||
}
|
||
return !0
|
||
}, e.prototype.handleDownEvent = function (t) {
|
||
if (this.targetPointers.length >= 2) {
|
||
var e = t.map;
|
||
return this.anchor_ = null, this.lastAngle_ = void 0, this.rotating_ = !1, this.rotationDelta_ = 0, this.handlingDownUpSequence || e.getView().setHint($n.INTERACTING, 1), !0
|
||
}
|
||
return !1
|
||
}, e
|
||
}(ra), ba = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = i;
|
||
r.stopDown || (r.stopDown = L), t.call(this, r), this.constrainResolution_ = i.constrainResolution || !1, this.anchor_ = null, this.duration_ = void 0 !== i.duration ? i.duration : 400, this.lastDistance_ = void 0, this.lastScaleDelta_ = 1
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleDragEvent = function (t) {
|
||
var e = 1, i = this.targetPointers[0], r = this.targetPointers[1], o = i.clientX - r.clientX,
|
||
n = i.clientY - r.clientY, s = Math.sqrt(o * o + n * n);
|
||
void 0 !== this.lastDistance_ && (e = this.lastDistance_ / s), this.lastDistance_ = s;
|
||
var a = t.map, l = a.getView(), h = l.getResolution(), u = l.getMaxResolution(),
|
||
c = l.getMinResolution(), p = h * e;
|
||
p > u ? (e = u / h, p = u) : p < c && (e = c / h, p = c), 1 != e && (this.lastScaleDelta_ = e);
|
||
var d = a.getViewport().getBoundingClientRect(), f = ia(this.targetPointers);
|
||
f[0] -= d.left, f[1] -= d.top, this.anchor_ = a.getCoordinateFromPixel(f), a.render(), js(l, p, this.anchor_)
|
||
}, e.prototype.handleUpEvent = function (t) {
|
||
if (this.targetPointers.length < 2) {
|
||
var e = t.map.getView();
|
||
e.setHint($n.INTERACTING, -1);
|
||
var i = e.getResolution();
|
||
if (this.constrainResolution_ || i < e.getMinResolution() || i > e.getMaxResolution()) {
|
||
var r = this.lastScaleDelta_ - 1;
|
||
Ds(e, i, this.anchor_, this.duration_, r)
|
||
}
|
||
return !1
|
||
}
|
||
return !0
|
||
}, e.prototype.handleDownEvent = function (t) {
|
||
if (this.targetPointers.length >= 2) {
|
||
var e = t.map;
|
||
return this.anchor_ = null, this.lastDistance_ = void 0, this.lastScaleDelta_ = 1, this.handlingDownUpSequence || e.getView().setHint($n.INTERACTING, 1), !0
|
||
}
|
||
return !1
|
||
}, e
|
||
}(ra);
|
||
|
||
function Ca(t) {
|
||
var e = t || {}, i = new Y, r = new Bo(-.005, .05, 100);
|
||
return (void 0 === e.altShiftDragRotate || e.altShiftDragRotate) && i.push(new na), (void 0 === e.doubleClickZoom || e.doubleClickZoom) && i.push(new Bs({
|
||
delta: e.zoomDelta,
|
||
duration: e.zoomDuration
|
||
})), (void 0 === e.dragPan || e.dragPan) && i.push(new oa({
|
||
condition: e.onFocusOnly ? Ws : void 0,
|
||
kinetic: r
|
||
})), (void 0 === e.pinchRotate || e.pinchRotate) && i.push(new wa), (void 0 === e.pinchZoom || e.pinchZoom) && i.push(new ba({
|
||
constrainResolution: e.constrainResolution,
|
||
duration: e.zoomDuration
|
||
})), (void 0 === e.keyboard || e.keyboard) && (i.push(new ma), i.push(new va({
|
||
delta: e.zoomDelta,
|
||
duration: e.zoomDuration
|
||
}))), (void 0 === e.mouseWheelZoom || e.mouseWheelZoom) && i.push(new xa({
|
||
condition: e.onFocusOnly ? Ws : void 0,
|
||
constrainResolution: e.constrainResolution,
|
||
duration: e.zoomDuration
|
||
})), (void 0 === e.shiftDragZoom || e.shiftDragZoom) && i.push(new da({duration: e.zoomDuration})), i
|
||
}
|
||
|
||
var Sa = .5, Ea = {IMAGE: "image", VECTOR: "vector"}, Ta = function (t) {
|
||
function e(e, i, r, o, n) {
|
||
t.call(this, e), this.vectorContext = i, this.frameState = r, this.context = o, this.glContext = n
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A), Ra = function (t) {
|
||
function e(e) {
|
||
t.call(this), this.highWaterMark = void 0 !== e ? e : 2048, this.count_ = 0, this.entries_ = {}, this.oldest_ = null, this.newest_ = null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.canExpireCache = function () {
|
||
return this.getCount() > this.highWaterMark
|
||
}, e.prototype.clear = function () {
|
||
this.count_ = 0, this.entries_ = {}, this.oldest_ = null, this.newest_ = null, this.dispatchEvent(F.CLEAR)
|
||
}, e.prototype.containsKey = function (t) {
|
||
return this.entries_.hasOwnProperty(t)
|
||
}, e.prototype.forEach = function (t, e) {
|
||
for (var i = this.oldest_; i;) t.call(e, i.value_, i.key_, this), i = i.newer
|
||
}, e.prototype.get = function (t) {
|
||
var e = this.entries_[t];
|
||
return W(void 0 !== e, 15), e === this.newest_ ? e.value_ : (e === this.oldest_ ? (this.oldest_ = this.oldest_.newer, this.oldest_.older = null) : (e.newer.older = e.older, e.older.newer = e.newer), e.newer = null, e.older = this.newest_, this.newest_.newer = e, this.newest_ = e, e.value_)
|
||
}, e.prototype.remove = function (t) {
|
||
var e = this.entries_[t];
|
||
return W(void 0 !== e, 15), e === this.newest_ ? (this.newest_ = e.older, this.newest_ && (this.newest_.newer = null)) : e === this.oldest_ ? (this.oldest_ = e.newer, this.oldest_ && (this.oldest_.older = null)) : (e.newer.older = e.older, e.older.newer = e.newer), delete this.entries_[t], --this.count_, e.value_
|
||
}, e.prototype.getCount = function () {
|
||
return this.count_
|
||
}, e.prototype.getKeys = function () {
|
||
var t, e = new Array(this.count_), i = 0;
|
||
for (t = this.newest_; t; t = t.older) e[i++] = t.key_;
|
||
return e
|
||
}, e.prototype.getValues = function () {
|
||
var t, e = new Array(this.count_), i = 0;
|
||
for (t = this.newest_; t; t = t.older) e[i++] = t.value_;
|
||
return e
|
||
}, e.prototype.peekLast = function () {
|
||
return this.oldest_.value_
|
||
}, e.prototype.peekLastKey = function () {
|
||
return this.oldest_.key_
|
||
}, e.prototype.peekFirstKey = function () {
|
||
return this.newest_.key_
|
||
}, e.prototype.pop = function () {
|
||
var t = this.oldest_;
|
||
return delete this.entries_[t.key_], t.newer && (t.newer.older = null), this.oldest_ = t.newer, this.oldest_ || (this.newest_ = null), --this.count_, t.value_
|
||
}, e.prototype.replace = function (t, e) {
|
||
this.get(t), this.entries_[t].value_ = e
|
||
}, e.prototype.set = function (t, e) {
|
||
W(!(t in this.entries_), 16);
|
||
var i = {key_: t, newer: null, older: this.newest_, value_: e};
|
||
this.newest_ ? this.newest_.newer = i : this.oldest_ = i, this.newest_ = i, this.entries_[t] = i, ++this.count_
|
||
}, e.prototype.setSize = function (t) {
|
||
this.highWaterMark = t
|
||
}, e.prototype.prune = function () {
|
||
for (; this.canExpireCache();) this.pop()
|
||
}, e
|
||
}(k), Pa = [0, 0, 0, 1], La = [], Ia = [0, 0, 0, 1], Oa = [0, 0, 0, 0], Ma = new Ra, Aa = {}, ka = null,
|
||
Fa = {}, Na = function () {
|
||
var t, e, i = 60, r = Aa, o = "32px ", n = ["monospace", "serif"], s = n.length,
|
||
a = "wmytzilWMYTZIL@#/&?$%10";
|
||
|
||
function l(t) {
|
||
for (var i = Da(), r = 100; r <= 700; r += 300) {
|
||
for (var l = r + " ", h = !0, u = 0; u < s; ++u) {
|
||
var c = n[u];
|
||
if (i.font = l + o + c, e = i.measureText(a).width, t != c) {
|
||
i.font = l + o + t + "," + c;
|
||
var p = i.measureText(a).width;
|
||
h = h && p != e
|
||
}
|
||
}
|
||
if (h) return !0
|
||
}
|
||
return !1
|
||
}
|
||
|
||
function h() {
|
||
var e = !0;
|
||
for (var o in r) r[o] < i && (l(o) ? (r[o] = i, d(Fa), ka = null, Ma.clear()) : (++r[o], e = !1));
|
||
e && (clearInterval(t), t = void 0)
|
||
}
|
||
|
||
return function (e) {
|
||
var o = Ss(e);
|
||
if (o) for (var n = 0, s = o.length; n < s; ++n) {
|
||
var a = o[n];
|
||
a in r || (r[a] = i, l(a) || (r[a] = 0, void 0 === t && (t = setInterval(h, 32))))
|
||
}
|
||
}
|
||
}();
|
||
|
||
function Da() {
|
||
return ka || (ka = Ao(1, 1)), ka
|
||
}
|
||
|
||
var Ga, ja, za = (ja = Fa, function (t) {
|
||
var e = ja[t];
|
||
return null == e && (Ga || ((Ga = document.createElement("span")).textContent = "M", Ga.style.margin = Ga.style.padding = "0 !important", Ga.style.position = "absolute !important", Ga.style.left = "-99999px !important"), Ga.style.font = t, document.body.appendChild(Ga), e = ja[t] = Ga.offsetHeight, document.body.removeChild(Ga)), e
|
||
});
|
||
|
||
function Ua(t, e) {
|
||
var i = Da();
|
||
return t != i.font && (i.font = t), i.measureText(e).width
|
||
}
|
||
|
||
function Ba(t, e, i, r) {
|
||
0 !== e && (t.translate(i, r), t.rotate(e), t.translate(-i, -r))
|
||
}
|
||
|
||
var Va = [1, 0, 0, 1, 0, 0];
|
||
|
||
function Ya(t, e, i, r, o, n, s, a, l, h, u) {
|
||
var c;
|
||
1 != i && (c = t.globalAlpha, t.globalAlpha = c * i), e && t.setTransform.apply(t, e), t.drawImage(r, o, n, s, a, l, h, s * u, a * u), c && (t.globalAlpha = c), e && t.setTransform.apply(t, Va)
|
||
}
|
||
|
||
function Wa(t) {
|
||
return Array.isArray(t) ? uo(t) : t
|
||
}
|
||
|
||
var Ha = function () {
|
||
};
|
||
Ha.prototype.drawCustom = function (t, e, i) {
|
||
}, Ha.prototype.drawGeometry = function (t) {
|
||
}, Ha.prototype.setStyle = function (t) {
|
||
}, Ha.prototype.drawCircle = function (t, e) {
|
||
}, Ha.prototype.drawFeature = function (t, e) {
|
||
}, Ha.prototype.drawGeometryCollection = function (t, e) {
|
||
}, Ha.prototype.drawLineString = function (t, e) {
|
||
}, Ha.prototype.drawMultiLineString = function (t, e) {
|
||
}, Ha.prototype.drawMultiPoint = function (t, e) {
|
||
}, Ha.prototype.drawMultiPolygon = function (t, e) {
|
||
}, Ha.prototype.drawPoint = function (t, e) {
|
||
}, Ha.prototype.drawPolygon = function (t, e) {
|
||
}, Ha.prototype.drawText = function (t, e) {
|
||
}, Ha.prototype.setFillStrokeStyle = function (t, e) {
|
||
}, Ha.prototype.setImageStyle = function (t, e) {
|
||
}, Ha.prototype.setTextStyle = function (t, e) {
|
||
};
|
||
var Xa = Ha, qa = function (t) {
|
||
function e(e, i, r, o, n) {
|
||
t.call(this), this.context_ = e, this.pixelRatio_ = i, this.extent_ = r, this.transform_ = o, this.viewRotation_ = n, this.contextFillState_ = null, this.contextStrokeState_ = null, this.contextTextState_ = null, this.fillState_ = null, this.strokeState_ = null, this.image_ = null, this.imageAnchorX_ = 0, this.imageAnchorY_ = 0, this.imageHeight_ = 0, this.imageOpacity_ = 0, this.imageOriginX_ = 0, this.imageOriginY_ = 0, this.imageRotateWithView_ = !1, this.imageRotation_ = 0, this.imageScale_ = 0, this.imageWidth_ = 0, this.text_ = "", this.textOffsetX_ = 0, this.textOffsetY_ = 0, this.textRotateWithView_ = !1, this.textRotation_ = 0, this.textScale_ = 0, this.textFillState_ = null, this.textStrokeState_ = null, this.textState_ = null, this.pixelCoordinates_ = [], this.tmpLocalTransform_ = [1, 0, 0, 1, 0, 0]
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.drawImages_ = function (t, e, i, r) {
|
||
if (this.image_) {
|
||
var o = Kt(t, e, i, 2, this.transform_, this.pixelCoordinates_), n = this.context_,
|
||
s = this.tmpLocalTransform_, a = n.globalAlpha;
|
||
1 != this.imageOpacity_ && (n.globalAlpha = a * this.imageOpacity_);
|
||
var l = this.imageRotation_;
|
||
this.imageRotateWithView_ && (l += this.viewRotation_);
|
||
for (var h = 0, u = o.length; h < u; h += 2) {
|
||
var c = o[h] - this.imageAnchorX_, p = o[h + 1] - this.imageAnchorY_;
|
||
if (0 !== l || 1 != this.imageScale_) {
|
||
var d = c + this.imageAnchorX_, f = p + this.imageAnchorY_;
|
||
gi(s, d, f, this.imageScale_, this.imageScale_, l, -d, -f), n.setTransform.apply(n, s)
|
||
}
|
||
n.drawImage(this.image_, this.imageOriginX_, this.imageOriginY_, this.imageWidth_, this.imageHeight_, c, p, this.imageWidth_, this.imageHeight_)
|
||
}
|
||
0 === l && 1 == this.imageScale_ || n.setTransform(1, 0, 0, 1, 0, 0), 1 != this.imageOpacity_ && (n.globalAlpha = a)
|
||
}
|
||
}, e.prototype.drawText_ = function (t, e, i, r) {
|
||
if (this.textState_ && "" !== this.text_) {
|
||
this.textFillState_ && this.setContextFillState_(this.textFillState_), this.textStrokeState_ && this.setContextStrokeState_(this.textStrokeState_), this.setContextTextState_(this.textState_);
|
||
var o = Kt(t, e, i, r, this.transform_, this.pixelCoordinates_), n = this.context_,
|
||
s = this.textRotation_;
|
||
for (this.textRotateWithView_ && (s += this.viewRotation_); e < i; e += r) {
|
||
var a = o[e] + this.textOffsetX_, l = o[e + 1] + this.textOffsetY_;
|
||
if (0 !== s || 1 != this.textScale_) {
|
||
var h = gi(this.tmpLocalTransform_, a, l, this.textScale_, this.textScale_, s, -a, -l);
|
||
n.setTransform.apply(n, h)
|
||
}
|
||
this.textStrokeState_ && n.strokeText(this.text_, a, l), this.textFillState_ && n.fillText(this.text_, a, l)
|
||
}
|
||
0 === s && 1 == this.textScale_ || n.setTransform(1, 0, 0, 1, 0, 0)
|
||
}
|
||
}, e.prototype.moveToLineTo_ = function (t, e, i, r, o) {
|
||
var n = this.context_, s = Kt(t, e, i, r, this.transform_, this.pixelCoordinates_);
|
||
n.moveTo(s[0], s[1]);
|
||
var a = s.length;
|
||
o && (a -= 2);
|
||
for (var l = 2; l < a; l += 2) n.lineTo(s[l], s[l + 1]);
|
||
return o && n.closePath(), i
|
||
}, e.prototype.drawRings_ = function (t, e, i, r) {
|
||
for (var o = 0, n = i.length; o < n; ++o) e = this.moveToLineTo_(t, e, i[o], r, !0);
|
||
return e
|
||
}, e.prototype.drawCircle = function (t) {
|
||
if (Bt(this.extent_, t.getExtent())) {
|
||
if (this.fillState_ || this.strokeState_) {
|
||
this.fillState_ && this.setContextFillState_(this.fillState_), this.strokeState_ && this.setContextStrokeState_(this.strokeState_);
|
||
var e = wi(t, this.transform_, this.pixelCoordinates_), i = e[2] - e[0], r = e[3] - e[1],
|
||
o = Math.sqrt(i * i + r * r), n = this.context_;
|
||
n.beginPath(), n.arc(e[0], e[1], o, 0, 2 * Math.PI), this.fillState_ && n.fill(), this.strokeState_ && n.stroke()
|
||
}
|
||
"" !== this.text_ && this.drawText_(t.getCenter(), 0, 2, 2)
|
||
}
|
||
}, e.prototype.setStyle = function (t) {
|
||
this.setFillStrokeStyle(t.getFill(), t.getStroke()), this.setImageStyle(t.getImage()), this.setTextStyle(t.getText())
|
||
}, e.prototype.drawGeometry = function (t) {
|
||
switch (t.getType()) {
|
||
case Zt.POINT:
|
||
this.drawPoint(t);
|
||
break;
|
||
case Zt.LINE_STRING:
|
||
this.drawLineString(t);
|
||
break;
|
||
case Zt.POLYGON:
|
||
this.drawPolygon(t);
|
||
break;
|
||
case Zt.MULTI_POINT:
|
||
this.drawMultiPoint(t);
|
||
break;
|
||
case Zt.MULTI_LINE_STRING:
|
||
this.drawMultiLineString(t);
|
||
break;
|
||
case Zt.MULTI_POLYGON:
|
||
this.drawMultiPolygon(t);
|
||
break;
|
||
case Zt.GEOMETRY_COLLECTION:
|
||
this.drawGeometryCollection(t);
|
||
break;
|
||
case Zt.CIRCLE:
|
||
this.drawCircle(t)
|
||
}
|
||
}, e.prototype.drawFeature = function (t, e) {
|
||
var i = e.getGeometryFunction()(t);
|
||
i && Bt(this.extent_, i.getExtent()) && (this.setStyle(e), this.drawGeometry(i))
|
||
}, e.prototype.drawGeometryCollection = function (t) {
|
||
for (var e = t.getGeometriesArray(), i = 0, r = e.length; i < r; ++i) this.drawGeometry(e[i])
|
||
}, e.prototype.drawPoint = function (t) {
|
||
var e = t.getFlatCoordinates(), i = t.getStride();
|
||
this.image_ && this.drawImages_(e, 0, e.length, i), "" !== this.text_ && this.drawText_(e, 0, e.length, i)
|
||
}, e.prototype.drawMultiPoint = function (t) {
|
||
var e = t.getFlatCoordinates(), i = t.getStride();
|
||
this.image_ && this.drawImages_(e, 0, e.length, i), "" !== this.text_ && this.drawText_(e, 0, e.length, i)
|
||
}, e.prototype.drawLineString = function (t) {
|
||
if (Bt(this.extent_, t.getExtent())) {
|
||
if (this.strokeState_) {
|
||
this.setContextStrokeState_(this.strokeState_);
|
||
var e = this.context_, i = t.getFlatCoordinates();
|
||
e.beginPath(), this.moveToLineTo_(i, 0, i.length, t.getStride(), !1), e.stroke()
|
||
}
|
||
if ("" !== this.text_) {
|
||
var r = t.getFlatMidpoint();
|
||
this.drawText_(r, 0, 2, 2)
|
||
}
|
||
}
|
||
}, e.prototype.drawMultiLineString = function (t) {
|
||
var e = t.getExtent();
|
||
if (Bt(this.extent_, e)) {
|
||
if (this.strokeState_) {
|
||
this.setContextStrokeState_(this.strokeState_);
|
||
var i = this.context_, r = t.getFlatCoordinates(), o = 0, n = t.getEnds(), s = t.getStride();
|
||
i.beginPath();
|
||
for (var a = 0, l = n.length; a < l; ++a) o = this.moveToLineTo_(r, o, n[a], s, !1);
|
||
i.stroke()
|
||
}
|
||
if ("" !== this.text_) {
|
||
var h = t.getFlatMidpoints();
|
||
this.drawText_(h, 0, h.length, 2)
|
||
}
|
||
}
|
||
}, e.prototype.drawPolygon = function (t) {
|
||
if (Bt(this.extent_, t.getExtent())) {
|
||
if (this.strokeState_ || this.fillState_) {
|
||
this.fillState_ && this.setContextFillState_(this.fillState_), this.strokeState_ && this.setContextStrokeState_(this.strokeState_);
|
||
var e = this.context_;
|
||
e.beginPath(), this.drawRings_(t.getOrientedFlatCoordinates(), 0, t.getEnds(), t.getStride()), this.fillState_ && e.fill(), this.strokeState_ && e.stroke()
|
||
}
|
||
if ("" !== this.text_) {
|
||
var i = t.getFlatInteriorPoint();
|
||
this.drawText_(i, 0, 2, 2)
|
||
}
|
||
}
|
||
}, e.prototype.drawMultiPolygon = function (t) {
|
||
if (Bt(this.extent_, t.getExtent())) {
|
||
if (this.strokeState_ || this.fillState_) {
|
||
this.fillState_ && this.setContextFillState_(this.fillState_), this.strokeState_ && this.setContextStrokeState_(this.strokeState_);
|
||
var e = this.context_, i = t.getOrientedFlatCoordinates(), r = 0, o = t.getEndss(),
|
||
n = t.getStride();
|
||
e.beginPath();
|
||
for (var s = 0, a = o.length; s < a; ++s) {
|
||
var l = o[s];
|
||
r = this.drawRings_(i, r, l, n)
|
||
}
|
||
this.fillState_ && e.fill(), this.strokeState_ && e.stroke()
|
||
}
|
||
if ("" !== this.text_) {
|
||
var h = t.getFlatInteriorPoints();
|
||
this.drawText_(h, 0, h.length, 2)
|
||
}
|
||
}
|
||
}, e.prototype.setContextFillState_ = function (t) {
|
||
var e = this.context_, i = this.contextFillState_;
|
||
i ? i.fillStyle != t.fillStyle && (i.fillStyle = e.fillStyle = t.fillStyle) : (e.fillStyle = t.fillStyle, this.contextFillState_ = {fillStyle: t.fillStyle})
|
||
}, e.prototype.setContextStrokeState_ = function (t) {
|
||
var e = this.context_, i = this.contextStrokeState_;
|
||
i ? (i.lineCap != t.lineCap && (i.lineCap = e.lineCap = t.lineCap), Er && (it(i.lineDash, t.lineDash) || e.setLineDash(i.lineDash = t.lineDash), i.lineDashOffset != t.lineDashOffset && (i.lineDashOffset = e.lineDashOffset = t.lineDashOffset)), i.lineJoin != t.lineJoin && (i.lineJoin = e.lineJoin = t.lineJoin), i.lineWidth != t.lineWidth && (i.lineWidth = e.lineWidth = t.lineWidth), i.miterLimit != t.miterLimit && (i.miterLimit = e.miterLimit = t.miterLimit), i.strokeStyle != t.strokeStyle && (i.strokeStyle = e.strokeStyle = t.strokeStyle)) : (e.lineCap = t.lineCap, Er && (e.setLineDash(t.lineDash), e.lineDashOffset = t.lineDashOffset), e.lineJoin = t.lineJoin, e.lineWidth = t.lineWidth, e.miterLimit = t.miterLimit, e.strokeStyle = t.strokeStyle, this.contextStrokeState_ = {
|
||
lineCap: t.lineCap,
|
||
lineDash: t.lineDash,
|
||
lineDashOffset: t.lineDashOffset,
|
||
lineJoin: t.lineJoin,
|
||
lineWidth: t.lineWidth,
|
||
miterLimit: t.miterLimit,
|
||
strokeStyle: t.strokeStyle
|
||
})
|
||
}, e.prototype.setContextTextState_ = function (t) {
|
||
var e = this.context_, i = this.contextTextState_, r = t.textAlign ? t.textAlign : "center";
|
||
i ? (i.font != t.font && (i.font = e.font = t.font), i.textAlign != r && (i.textAlign = e.textAlign = r), i.textBaseline != t.textBaseline && (i.textBaseline = e.textBaseline = t.textBaseline)) : (e.font = t.font, e.textAlign = r, e.textBaseline = t.textBaseline, this.contextTextState_ = {
|
||
font: t.font,
|
||
textAlign: r,
|
||
textBaseline: t.textBaseline
|
||
})
|
||
}, e.prototype.setFillStrokeStyle = function (t, e) {
|
||
if (t) {
|
||
var i = t.getColor();
|
||
this.fillState_ = {fillStyle: Wa(i || Pa)}
|
||
} else this.fillState_ = null;
|
||
if (e) {
|
||
var r = e.getColor(), o = e.getLineCap(), n = e.getLineDash(), s = e.getLineDashOffset(),
|
||
a = e.getLineJoin(), l = e.getWidth(), h = e.getMiterLimit();
|
||
this.strokeState_ = {
|
||
lineCap: void 0 !== o ? o : "round",
|
||
lineDash: n || La,
|
||
lineDashOffset: s || 0,
|
||
lineJoin: void 0 !== a ? a : "round",
|
||
lineWidth: this.pixelRatio_ * (void 0 !== l ? l : 1),
|
||
miterLimit: void 0 !== h ? h : 10,
|
||
strokeStyle: Wa(r || Ia)
|
||
}
|
||
} else this.strokeState_ = null
|
||
}, e.prototype.setImageStyle = function (t) {
|
||
if (t) {
|
||
var e = t.getAnchor(), i = t.getImage(1), r = t.getOrigin(), o = t.getSize();
|
||
this.imageAnchorX_ = e[0], this.imageAnchorY_ = e[1], this.imageHeight_ = o[1], this.image_ = i, this.imageOpacity_ = t.getOpacity(), this.imageOriginX_ = r[0], this.imageOriginY_ = r[1], this.imageRotateWithView_ = t.getRotateWithView(), this.imageRotation_ = t.getRotation(), this.imageScale_ = t.getScale() * this.pixelRatio_, this.imageWidth_ = o[0]
|
||
} else this.image_ = null
|
||
}, e.prototype.setTextStyle = function (t) {
|
||
if (t) {
|
||
var e = t.getFill();
|
||
if (e) {
|
||
var i = e.getColor();
|
||
this.textFillState_ = {fillStyle: Wa(i || Pa)}
|
||
} else this.textFillState_ = null;
|
||
var r = t.getStroke();
|
||
if (r) {
|
||
var o = r.getColor(), n = r.getLineCap(), s = r.getLineDash(), a = r.getLineDashOffset(),
|
||
l = r.getLineJoin(), h = r.getWidth(), u = r.getMiterLimit();
|
||
this.textStrokeState_ = {
|
||
lineCap: void 0 !== n ? n : "round",
|
||
lineDash: s || La,
|
||
lineDashOffset: a || 0,
|
||
lineJoin: void 0 !== l ? l : "round",
|
||
lineWidth: void 0 !== h ? h : 1,
|
||
miterLimit: void 0 !== u ? u : 10,
|
||
strokeStyle: Wa(o || Ia)
|
||
}
|
||
} else this.textStrokeState_ = null;
|
||
var c = t.getFont(), p = t.getOffsetX(), d = t.getOffsetY(), f = t.getRotateWithView(),
|
||
g = t.getRotation(), m = t.getScale(), y = t.getText(), v = t.getTextAlign(),
|
||
_ = t.getTextBaseline();
|
||
this.textState_ = {
|
||
font: void 0 !== c ? c : "10px sans-serif",
|
||
textAlign: void 0 !== v ? v : "center",
|
||
textBaseline: void 0 !== _ ? _ : "middle"
|
||
}, this.text_ = void 0 !== y ? y : "", this.textOffsetX_ = void 0 !== p ? this.pixelRatio_ * p : 0, this.textOffsetY_ = void 0 !== d ? this.pixelRatio_ * d : 0, this.textRotateWithView_ = void 0 !== f && f, this.textRotation_ = void 0 !== g ? g : 0, this.textScale_ = this.pixelRatio_ * (void 0 !== m ? m : 1)
|
||
} else this.text_ = ""
|
||
}, e
|
||
}(Xa), Za = function () {
|
||
this.cache_ = {}, this.cacheSize_ = 0, this.maxCacheSize_ = 32
|
||
};
|
||
|
||
function Ka(t, e, i) {
|
||
return e + ":" + t + ":" + (i ? oo(i) : "null")
|
||
}
|
||
|
||
Za.prototype.clear = function () {
|
||
this.cache_ = {}, this.cacheSize_ = 0
|
||
}, Za.prototype.expire = function () {
|
||
if (this.cacheSize_ > this.maxCacheSize_) {
|
||
var t = 0;
|
||
for (var e in this.cache_) {
|
||
var i = this.cache_[e];
|
||
0 != (3 & t++) || i.hasListener() || (delete this.cache_[e], --this.cacheSize_)
|
||
}
|
||
}
|
||
}, Za.prototype.get = function (t, e, i) {
|
||
var r = Ka(t, e, i);
|
||
return r in this.cache_ ? this.cache_[r] : null
|
||
}, Za.prototype.set = function (t, e, i, r) {
|
||
var o = Ka(t, e, i);
|
||
this.cache_[o] = r, ++this.cacheSize_
|
||
}, Za.prototype.setSize = function (t) {
|
||
this.maxCacheSize_ = t, this.expire()
|
||
};
|
||
var Ja = Za, $a = new Za;
|
||
|
||
function Qa(t, e) {
|
||
$a.expire()
|
||
}
|
||
|
||
function tl(t, e) {
|
||
return t.zIndex - e.zIndex
|
||
}
|
||
|
||
var el = function (t) {
|
||
function e(e) {
|
||
t.call(this), this.map_ = e, this.layerRenderers_ = {}, this.layerRendererListeners_ = {}, this.layerRendererConstructors_ = []
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.dispatchRenderEvent = function (t, e) {
|
||
n()
|
||
}, e.prototype.registerLayerRenderers = function (t) {
|
||
this.layerRendererConstructors_.push.apply(this.layerRendererConstructors_, t)
|
||
}, e.prototype.calculateMatrices2D = function (t) {
|
||
var e = t.viewState, i = t.coordinateToPixelTransform, r = t.pixelToCoordinateTransform;
|
||
gi(i, t.size[0] / 2, t.size[1] / 2, 1 / e.resolution, -1 / e.resolution, -e.rotation, -e.center[0], -e.center[1]), mi(ui(r, i))
|
||
}, e.prototype.removeLayerRenderers = function () {
|
||
for (var t in this.layerRenderers_) this.removeLayerRendererByKey_(t).dispose()
|
||
}, e.prototype.forEachFeatureAtCoordinate = function (t, e, i, r, o, n, s) {
|
||
var l, h = e.viewState, u = h.resolution;
|
||
|
||
function c(t, i) {
|
||
var n = e.layerStates[a(i)].managed;
|
||
if (!(a(t) in e.skippedFeatureUids) || n) return r.call(o, t, n ? i : null)
|
||
}
|
||
|
||
var p = h.projection, d = t;
|
||
if (p.canWrapX()) {
|
||
var f = p.getExtent(), g = Ut(f), m = t[0];
|
||
if (m < f[0] || m > f[2]) d = [m + g * Math.ceil((f[0] - m) / g), t[1]]
|
||
}
|
||
var y, v = e.layerStatesArray;
|
||
for (y = v.length - 1; y >= 0; --y) {
|
||
var _ = v[y], x = _.layer;
|
||
if (Es(_, u) && n.call(s, x)) {
|
||
var w = this.getLayerRenderer(x), b = x.getSource();
|
||
if (b && (l = w.forEachFeatureAtCoordinate(b.getWrapX() ? d : t, e, i, c)), l) return l
|
||
}
|
||
}
|
||
}, e.prototype.forEachLayerAtPixel = function (t, e, i, r, o, s, a) {
|
||
return n()
|
||
}, e.prototype.hasFeatureAtCoordinate = function (t, e, i, r, o) {
|
||
return void 0 !== this.forEachFeatureAtCoordinate(t, e, i, P, this, r, o)
|
||
}, e.prototype.getLayerRenderer = function (t) {
|
||
var e = a(t);
|
||
if (e in this.layerRenderers_) return this.layerRenderers_[e];
|
||
for (var i, r = 0, o = this.layerRendererConstructors_.length; r < o; ++r) {
|
||
var n = this.layerRendererConstructors_[r];
|
||
if (n.handles(t)) {
|
||
i = n.create(this, t);
|
||
break
|
||
}
|
||
}
|
||
if (!i) throw new Error("Unable to create renderer for layer: " + t.getType());
|
||
return this.layerRenderers_[e] = i, this.layerRendererListeners_[e] = w(i, F.CHANGE, this.handleLayerRendererChange_, this), i
|
||
}, e.prototype.getLayerRendererByKey = function (t) {
|
||
return this.layerRenderers_[t]
|
||
}, e.prototype.getLayerRenderers = function () {
|
||
return this.layerRenderers_
|
||
}, e.prototype.getMap = function () {
|
||
return this.map_
|
||
}, e.prototype.handleLayerRendererChange_ = function () {
|
||
this.map_.render()
|
||
}, e.prototype.removeLayerRendererByKey_ = function (t) {
|
||
var e = this.layerRenderers_[t];
|
||
return delete this.layerRenderers_[t], S(this.layerRendererListeners_[t]), delete this.layerRendererListeners_[t], e
|
||
}, e.prototype.removeUnusedLayerRenderers_ = function (t, e) {
|
||
for (var i in this.layerRenderers_) e && i in e.layerStates || this.removeLayerRendererByKey_(i).dispose()
|
||
}, e.prototype.renderFrame = function (t) {
|
||
n()
|
||
}, e.prototype.scheduleExpireIconCache = function (t) {
|
||
t.postRenderFunctions.push(Qa)
|
||
}, e.prototype.scheduleRemoveUnusedLayerRenderers = function (t) {
|
||
for (var e in this.layerRenderers_) if (!(e in t.layerStates)) return void t.postRenderFunctions.push(this.removeUnusedLayerRenderers_.bind(this))
|
||
}, e
|
||
}(R), il = [], rl = function (t) {
|
||
function e(e) {
|
||
t.call(this, e);
|
||
var i = e.getViewport();
|
||
this.context_ = Ao(), this.canvas_ = this.context_.canvas, this.canvas_.style.width = "100%", this.canvas_.style.height = "100%", this.canvas_.style.display = "block", this.canvas_.className = xs, i.insertBefore(this.canvas_, i.childNodes[0] || null), this.renderedVisible_ = !0, this.transform_ = [1, 0, 0, 1, 0, 0]
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.dispatchRenderEvent = function (t, e) {
|
||
var i = this.getMap(), r = this.context_;
|
||
if (i.hasListener(t)) {
|
||
var o = e.extent, n = e.pixelRatio, s = e.viewState.rotation, a = this.getTransform(e),
|
||
l = new qa(r, n, o, a, s), h = new Ta(t, l, e, r, null);
|
||
i.dispatchEvent(h)
|
||
}
|
||
}, e.prototype.getTransform = function (t) {
|
||
var e = t.viewState, i = this.canvas_.width / 2, r = this.canvas_.height / 2,
|
||
o = t.pixelRatio / e.resolution, n = -o, s = -e.rotation, a = -e.center[0], l = -e.center[1];
|
||
return gi(this.transform_, i, r, o, n, s, a, l)
|
||
}, e.prototype.renderFrame = function (t) {
|
||
if (t) {
|
||
var e = this.context_, i = t.pixelRatio, r = Math.round(t.size[0] * i),
|
||
o = Math.round(t.size[1] * i);
|
||
this.canvas_.width != r || this.canvas_.height != o ? (this.canvas_.width = r, this.canvas_.height = o) : e.clearRect(0, 0, r, o);
|
||
var n = t.viewState.rotation;
|
||
this.calculateMatrices2D(t), this.dispatchRenderEvent(eo.PRECOMPOSE, t);
|
||
var s = t.layerStatesArray;
|
||
rt(s, tl), n && (e.save(), Ba(e, n, r / 2, o / 2));
|
||
var a, l, h = t.viewState.resolution;
|
||
for (a = 0, l = s.length; a < l; ++a) {
|
||
var u = s[a], c = u.layer, p = this.getLayerRenderer(c);
|
||
Es(u, h) && u.sourceState == hs.READY && (p.prepareFrame(t, u) && p.composeFrame(t, u, e))
|
||
}
|
||
n && e.restore(), this.dispatchRenderEvent(eo.POSTCOMPOSE, t), this.renderedVisible_ || (this.canvas_.style.display = "", this.renderedVisible_ = !0), this.scheduleRemoveUnusedLayerRenderers(t), this.scheduleExpireIconCache(t)
|
||
} else this.renderedVisible_ && (this.canvas_.style.display = "none", this.renderedVisible_ = !1)
|
||
}, e.prototype.forEachLayerAtPixel = function (t, e, i, r, o, n, s) {
|
||
var a, l, h = e.viewState.resolution, u = e.layerStatesArray, c = u.length,
|
||
p = ci(e.pixelToCoordinateTransform, t.slice());
|
||
for (l = c - 1; l >= 0; --l) {
|
||
var d = u[l], f = d.layer;
|
||
if (Es(d, h) && n.call(s, f)) if (a = this.getLayerRenderer(f).forEachLayerAtCoordinate(p, e, i, r, o)) return a
|
||
}
|
||
}, e.prototype.registerLayerRenderers = function (e) {
|
||
t.prototype.registerLayerRenderers.call(this, e);
|
||
for (var i = 0, r = e.length; i < r; ++i) {
|
||
var o = e[i];
|
||
K(il, o) || il.push(o)
|
||
}
|
||
}, e
|
||
}(el), nl = function (t) {
|
||
function e(e) {
|
||
t.call(this), this.layer_ = e
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.createLoadedTileFinder = function (t, e, i) {
|
||
return function (r, o) {
|
||
return t.forEachLoadedTile(e, r, o, function (t) {
|
||
i[r] || (i[r] = {}), i[r][t.tileCoord.toString()] = t
|
||
})
|
||
}
|
||
}, e.prototype.forEachFeatureAtCoordinate = function (t, e, i, r) {
|
||
}, e.prototype.getLayer = function () {
|
||
return this.layer_
|
||
}, e.prototype.handleImageChange_ = function (t) {
|
||
t.target.getState() === So.LOADED && this.renderIfReadyAndVisible()
|
||
}, e.prototype.hasFeatureAtCoordinate = function (t, e) {
|
||
return !1
|
||
}, e.prototype.loadImage = function (t) {
|
||
var e = t.getState();
|
||
return e != So.LOADED && e != So.ERROR && w(t, F.CHANGE, this.handleImageChange_, this), e == So.IDLE && (t.load(), e = t.getState()), e == So.LOADED
|
||
}, e.prototype.renderIfReadyAndVisible = function () {
|
||
var t = this.getLayer();
|
||
t.getVisible() && t.getSourceState() == hs.READY && this.changed()
|
||
}, e.prototype.scheduleExpireCache = function (t, e) {
|
||
if (e.canExpireCache()) {
|
||
var i = function (t, e, i) {
|
||
var r = a(t);
|
||
r in i.usedTiles && t.expireCache(i.viewState.projection, i.usedTiles[r])
|
||
}.bind(null, e);
|
||
t.postRenderFunctions.push(i)
|
||
}
|
||
}, e.prototype.updateUsedTiles = function (t, e, i, r) {
|
||
var o = a(e), n = i.toString();
|
||
o in t ? n in t[o] ? t[o][n].extend(r) : t[o][n] = r : (t[o] = {}, t[o][n] = r)
|
||
}, e.prototype.manageTilePyramid = function (t, e, i, r, o, n, s, l, h, u) {
|
||
var c = a(e);
|
||
c in t.wantedTiles || (t.wantedTiles[c] = {});
|
||
var p, d, f, g, m, y, v = t.wantedTiles[c], _ = t.tileQueue;
|
||
for (y = i.getMinZoom(); y <= s; ++y) for (d = i.getTileRangeForExtentAndZ(n, y, d), f = i.getResolution(y), g = d.minX; g <= d.maxX; ++g) for (m = d.minY; m <= d.maxY; ++m) s - y <= l ? ((p = e.getTile(y, g, m, r, o)).getState() == Ro.IDLE && (v[p.getKey()] = !0, _.isKeyQueued(p.getKey()) || _.enqueue([p, c, i.getTileCoordCenter(p.tileCoord), f])), void 0 !== h && h.call(u, p)) : e.useTile(y, g, m, o)
|
||
}, e
|
||
}(D), sl = function (t) {
|
||
function e(e) {
|
||
t.call(this, e), this.renderedResolution, this.transform_ = [1, 0, 0, 1, 0, 0]
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.clip = function (t, e, i) {
|
||
var r = e.pixelRatio, o = e.size[0] * r, n = e.size[1] * r, s = e.viewState.rotation, a = jt(i),
|
||
l = zt(i), h = Mt(i), u = Ot(i);
|
||
ci(e.coordinateToPixelTransform, a), ci(e.coordinateToPixelTransform, l), ci(e.coordinateToPixelTransform, h), ci(e.coordinateToPixelTransform, u), t.save(), Ba(t, -s, o / 2, n / 2), t.beginPath(), t.moveTo(a[0] * r, a[1] * r), t.lineTo(l[0] * r, l[1] * r), t.lineTo(h[0] * r, h[1] * r), t.lineTo(u[0] * r, u[1] * r), t.clip(), Ba(t, s, o / 2, n / 2)
|
||
}, e.prototype.dispatchComposeEvent_ = function (t, e, i, r) {
|
||
var o = this.getLayer();
|
||
if (o.hasListener(t)) {
|
||
var n = i.size[0] * i.pixelRatio, s = i.size[1] * i.pixelRatio, a = i.viewState.rotation;
|
||
Ba(e, -a, n / 2, s / 2);
|
||
var l = void 0 !== r ? r : this.getTransform(i, 0),
|
||
h = new qa(e, i.pixelRatio, i.extent, l, i.viewState.rotation), u = new Ta(t, h, i, e, null);
|
||
o.dispatchEvent(u), Ba(e, a, n / 2, s / 2)
|
||
}
|
||
}, e.prototype.forEachLayerAtCoordinate = function (t, e, i, r, o) {
|
||
return this.forEachFeatureAtCoordinate(t, e, i, P) ? r.call(o, this.getLayer(), null) : void 0
|
||
}, e.prototype.postCompose = function (t, e, i, r) {
|
||
this.dispatchComposeEvent_(eo.POSTCOMPOSE, t, e, r)
|
||
}, e.prototype.preCompose = function (t, e, i) {
|
||
this.dispatchComposeEvent_(eo.PRECOMPOSE, t, e, i)
|
||
}, e.prototype.dispatchRenderEvent = function (t, e, i) {
|
||
this.dispatchComposeEvent_(eo.RENDER, t, e, i)
|
||
}, e.prototype.getTransform = function (t, e) {
|
||
var i = t.viewState, r = t.pixelRatio, o = r * t.size[0] / 2, n = r * t.size[1] / 2,
|
||
s = r / i.resolution, a = -s, l = -i.rotation, h = -i.center[0] + e, u = -i.center[1];
|
||
return gi(this.transform_, o, n, s, a, l, h, u)
|
||
}, e.prototype.composeFrame = function (t, e, i) {
|
||
n()
|
||
}, e.prototype.prepareFrame = function (t, e) {
|
||
return n()
|
||
}, e
|
||
}(nl), al = function (t) {
|
||
function e(e) {
|
||
t.call(this, e), this.coordinateToCanvasPixelTransform = [1, 0, 0, 1, 0, 0], this.hitCanvasContext_ = null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.composeFrame = function (t, e, i) {
|
||
this.preCompose(i, t);
|
||
var r = this.getImage();
|
||
if (r) {
|
||
var o = e.extent, n = void 0 !== o && !dt(o, t.extent) && Bt(o, t.extent);
|
||
n && this.clip(i, t, o);
|
||
var s = this.getImageTransform(), a = i.globalAlpha;
|
||
i.globalAlpha = e.opacity;
|
||
var l = s[4], h = s[5], u = r.width * s[0], c = r.height * s[3];
|
||
u >= .5 && c >= .5 && i.drawImage(r, 0, 0, +r.width, +r.height, Math.round(l), Math.round(h), Math.round(u), Math.round(c)), i.globalAlpha = a, n && i.restore()
|
||
}
|
||
this.postCompose(i, t, e)
|
||
}, e.prototype.getImage = function () {
|
||
return n()
|
||
}, e.prototype.getImageTransform = function () {
|
||
return n()
|
||
}, e.prototype.forEachLayerAtCoordinate = function (t, e, i, r, o) {
|
||
if (this.getImage()) {
|
||
var n = ci(this.coordinateToCanvasPixelTransform, t.slice());
|
||
Br(n, e.viewState.resolution / this.renderedResolution), this.hitCanvasContext_ || (this.hitCanvasContext_ = Ao(1, 1)), this.hitCanvasContext_.clearRect(0, 0, 1, 1), this.hitCanvasContext_.drawImage(this.getImage(), n[0], n[1], 1, 1, 0, 0, 1, 1);
|
||
var s = this.hitCanvasContext_.getImageData(0, 0, 1, 1).data;
|
||
return s[3] > 0 ? r.call(o, this.getLayer(), s) : void 0
|
||
}
|
||
}, e
|
||
}(sl), ll = function (t) {
|
||
function e(i) {
|
||
if (t.call(this, i), this.image_ = null, this.imageTransform_ = [1, 0, 0, 1, 0, 0], this.skippedFeatures_ = [], this.vectorRenderer_ = null, i.getType() === Vo.VECTOR) for (var r = 0, o = il.length; r < o; ++r) {
|
||
var n = il[r];
|
||
if (n !== e && n.handles(i)) {
|
||
this.vectorRenderer_ = new n(i);
|
||
break
|
||
}
|
||
}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.disposeInternal = function () {
|
||
this.vectorRenderer_ && this.vectorRenderer_.dispose(), t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.getImage = function () {
|
||
return this.image_ ? this.image_.getImage() : null
|
||
}, e.prototype.getImageTransform = function () {
|
||
return this.imageTransform_
|
||
}, e.prototype.prepareFrame = function (t, e) {
|
||
var i, r = t.pixelRatio, o = t.size, n = t.viewState, s = n.center, a = n.resolution,
|
||
l = this.getLayer().getSource(), h = t.viewHints, u = this.vectorRenderer_, c = t.extent;
|
||
if (u || void 0 === e.extent || (c = Dt(c, e.extent)), !h[$n.ANIMATING] && !h[$n.INTERACTING] && !Vt(c)) {
|
||
var d = n.projection, f = this.skippedFeatures_;
|
||
if (u) {
|
||
var g = u.context,
|
||
m = p({}, t, {size: [Ut(c) / a, Nt(c) / a], viewState: p({}, t.viewState, {rotation: 0})}),
|
||
y = Object.keys(m.skippedFeatureUids).sort();
|
||
i = new To(c, a, r, g.canvas, function (t) {
|
||
!u.prepareFrame(m, e) || !u.replayGroupChanged && it(f, y) || (g.canvas.width = m.size[0] * r, g.canvas.height = m.size[1] * r, u.compose(g, m, e), f = y, t())
|
||
})
|
||
} else i = l.getImage(c, a, r, d);
|
||
i && this.loadImage(i) && (this.image_ = i, this.skippedFeatures_ = f)
|
||
}
|
||
if (this.image_) {
|
||
var v = (i = this.image_).getExtent(), _ = i.getResolution(), x = i.getPixelRatio(),
|
||
w = r * _ / (a * x),
|
||
b = gi(this.imageTransform_, r * o[0] / 2, r * o[1] / 2, w, w, 0, x * (v[0] - s[0]) / _, x * (s[1] - v[3]) / _);
|
||
gi(this.coordinateToCanvasPixelTransform, r * o[0] / 2 - b[4], r * o[1] / 2 - b[5], r / a, -r / a, 0, -s[0], -s[1]), this.renderedResolution = _ * r / x
|
||
}
|
||
return !!this.image_
|
||
}, e.prototype.forEachFeatureAtCoordinate = function (e, i, r, o) {
|
||
return this.vectorRenderer_ ? this.vectorRenderer_.forEachFeatureAtCoordinate(e, i, r, o) : t.prototype.forEachFeatureAtCoordinate.call(this, e, i, r, o)
|
||
}, e
|
||
}(al);
|
||
ll.handles = function (t) {
|
||
return t.getType() === Vo.IMAGE || t.getType() === Vo.VECTOR && t.getRenderMode() === Ea.IMAGE
|
||
}, ll.create = function (t, e) {
|
||
return new ll(e)
|
||
};
|
||
var hl = ll, ul = function (t, e, i, r) {
|
||
this.minX = t, this.maxX = e, this.minY = i, this.maxY = r
|
||
};
|
||
|
||
function cl(t, e, i, r, o) {
|
||
return void 0 !== o ? (o.minX = t, o.maxX = e, o.minY = i, o.maxY = r, o) : new ul(t, e, i, r)
|
||
}
|
||
|
||
ul.prototype.contains = function (t) {
|
||
return this.containsXY(t[1], t[2])
|
||
}, ul.prototype.containsTileRange = function (t) {
|
||
return this.minX <= t.minX && t.maxX <= this.maxX && this.minY <= t.minY && t.maxY <= this.maxY
|
||
}, ul.prototype.containsXY = function (t, e) {
|
||
return this.minX <= t && t <= this.maxX && this.minY <= e && e <= this.maxY
|
||
}, ul.prototype.equals = function (t) {
|
||
return this.minX == t.minX && this.minY == t.minY && this.maxX == t.maxX && this.maxY == t.maxY
|
||
}, ul.prototype.extend = function (t) {
|
||
t.minX < this.minX && (this.minX = t.minX), t.maxX > this.maxX && (this.maxX = t.maxX), t.minY < this.minY && (this.minY = t.minY), t.maxY > this.maxY && (this.maxY = t.maxY)
|
||
}, ul.prototype.getHeight = function () {
|
||
return this.maxY - this.minY + 1
|
||
}, ul.prototype.getSize = function () {
|
||
return [this.getWidth(), this.getHeight()]
|
||
}, ul.prototype.getWidth = function () {
|
||
return this.maxX - this.minX + 1
|
||
}, ul.prototype.intersects = function (t) {
|
||
return this.minX <= t.maxX && this.maxX >= t.minX && this.minY <= t.maxY && this.maxY >= t.minY
|
||
};
|
||
var pl = ul, dl = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e), this.context = i ? null : Ao(), this.oversampling_, this.renderedExtent_ = null, this.renderedRevision, this.renderedTiles = [], this.newTiles_ = !1, this.tmpExtent = [1 / 0, 1 / 0, -1 / 0, -1 / 0], this.tmpTileRange_ = new pl(0, 0, 0, 0), this.imageTransform_ = [1, 0, 0, 1, 0, 0], this.zDirection = 0
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.isDrawableTile_ = function (t) {
|
||
var e = this.getLayer(), i = t.getState(), r = e.getUseInterimTilesOnError();
|
||
return i == Ro.LOADED || i == Ro.EMPTY || i == Ro.ERROR && !r
|
||
}, e.prototype.getTile = function (t, e, i, r, o) {
|
||
var n = this.getLayer(), s = n.getSource().getTile(t, e, i, r, o);
|
||
return s.getState() == Ro.ERROR && (n.getUseInterimTilesOnError() ? n.getPreload() > 0 && (this.newTiles_ = !0) : s.setState(Ro.LOADED)), this.isDrawableTile_(s) || (s = s.getInterimTile()), s
|
||
}, e.prototype.prepareFrame = function (t, e) {
|
||
var i = t.pixelRatio, r = t.size, o = t.viewState, n = o.projection, s = o.resolution, l = o.center,
|
||
h = this.getLayer(), u = h.getSource(), c = u.getRevision(), p = u.getTileGridForProjection(n),
|
||
d = p.getZForResolution(s, this.zDirection), f = p.getResolution(d), g = Math.round(s / f) || 1,
|
||
m = t.extent;
|
||
if (void 0 !== e.extent && (m = Dt(m, e.extent)), Vt(m)) return !1;
|
||
var y = p.getTileRangeForExtentAndZ(m, d), v = p.getTileRangeExtent(d, y), _ = u.getTilePixelRatio(i),
|
||
x = {};
|
||
x[d] = {};
|
||
var w, b, C, S = this.createLoadedTileFinder(u, n, x), E = t.viewHints,
|
||
T = E[$n.ANIMATING] || E[$n.INTERACTING], R = this.tmpExtent, P = this.tmpTileRange_;
|
||
for (this.newTiles_ = !1, b = y.minX; b <= y.maxX; ++b) for (C = y.minY; C <= y.maxY; ++C) if (!(Date.now() - t.time > 16 && T)) {
|
||
if (w = this.getTile(d, b, C, i, n), this.isDrawableTile_(w)) {
|
||
var L = a(this);
|
||
if (w.getState() == Ro.LOADED) {
|
||
x[d][w.tileCoord.toString()] = w;
|
||
var I = w.inTransition(L);
|
||
this.newTiles_ || !I && -1 !== this.renderedTiles.indexOf(w) || (this.newTiles_ = !0)
|
||
}
|
||
if (1 === w.getAlpha(L, t.time)) continue
|
||
}
|
||
var O = p.getTileCoordChildTileRange(w.tileCoord, P, R), M = !1;
|
||
O && (M = S(d + 1, O)), M || p.forEachTileCoordParentTileRange(w.tileCoord, S, null, P, R)
|
||
}
|
||
var A = f * i / _ * g;
|
||
if (!(this.renderedResolution && Date.now() - t.time > 16 && T) && (this.newTiles_ || !this.renderedExtent_ || !dt(this.renderedExtent_, m) || this.renderedRevision != c || g != this.oversampling_ || !T && A != this.renderedResolution)) {
|
||
var k = this.context;
|
||
if (k) {
|
||
var F = u.getTilePixelSize(d, i, n), N = Math.round(y.getWidth() * F[0] / g),
|
||
D = Math.round(y.getHeight() * F[1] / g), G = k.canvas;
|
||
G.width != N || G.height != D ? (this.oversampling_ = g, G.width = N, G.height = D) : ((this.renderedExtent_ && !bt(v, this.renderedExtent_) || this.renderedRevision != c) && k.clearRect(0, 0, N, D), g = this.oversampling_)
|
||
}
|
||
this.renderedTiles.length = 0;
|
||
var j, z, U, B, V, Y, W, H, X, q, Z = Object.keys(x).map(Number);
|
||
for (Z.sort(function (t, e) {
|
||
return t === d ? 1 : e === d ? -1 : t > e ? 1 : t < e ? -1 : 0
|
||
}), B = 0, V = Z.length; B < V; ++B) for (var K in U = Z[B], z = u.getTilePixelSize(U, i, n), j = p.getResolution(U) / f, W = _ * u.getGutterForProjection(n), H = x[U]) w = H[K], b = ((Y = p.getTileCoordExtent(w.getTileCoord(), R))[0] - v[0]) / f * _ / g, C = (v[3] - Y[3]) / f * _ / g, X = z[0] * j / g, q = z[1] * j / g, this.drawTileImage(w, t, e, b, C, X, q, W, d === U), this.renderedTiles.push(w);
|
||
this.renderedRevision = c, this.renderedResolution = f * i / _ * g, this.renderedExtent_ = v
|
||
}
|
||
var J = this.renderedResolution / s,
|
||
$ = gi(this.imageTransform_, i * r[0] / 2, i * r[1] / 2, J, J, 0, (this.renderedExtent_[0] - l[0]) / this.renderedResolution * i, (l[1] - this.renderedExtent_[3]) / this.renderedResolution * i);
|
||
return gi(this.coordinateToCanvasPixelTransform, i * r[0] / 2 - $[4], i * r[1] / 2 - $[5], i / s, -i / s, 0, -l[0], -l[1]), this.updateUsedTiles(t.usedTiles, u, d, y), this.manageTilePyramid(t, u, p, i, n, m, d, h.getPreload()), this.scheduleExpireCache(t, u), this.renderedTiles.length > 0
|
||
}, e.prototype.drawTileImage = function (t, e, i, r, o, n, s, l, h) {
|
||
var u = this.getTileImage(t);
|
||
if (u) {
|
||
var c = a(this), p = h ? t.getAlpha(c, e.time) : 1, d = this.getLayer().getSource();
|
||
1 !== p || d.getOpaque(e.viewState.projection) || this.context.clearRect(r, o, n, s);
|
||
var f = p !== this.context.globalAlpha;
|
||
f && (this.context.save(), this.context.globalAlpha = p), this.context.drawImage(u, l, l, u.width - 2 * l, u.height - 2 * l, r, o, n, s), f && this.context.restore(), 1 !== p ? e.animate = !0 : h && t.endTransition(c)
|
||
}
|
||
}, e.prototype.getImage = function () {
|
||
var t = this.context;
|
||
return t ? t.canvas : null
|
||
}, e.prototype.getImageTransform = function () {
|
||
return this.imageTransform_
|
||
}, e.prototype.getTileImage = function (t) {
|
||
return t.getImage()
|
||
}, e
|
||
}(al);
|
||
dl.handles = function (t) {
|
||
return t.getType() === Vo.TILE
|
||
}, dl.create = function (t, e) {
|
||
return new dl(e)
|
||
}, dl.prototype.getLayer;
|
||
var fl = dl, gl = i(3), ml = i.n(gl), yl = function () {
|
||
};
|
||
yl.prototype.getReplay = function (t, e) {
|
||
return n()
|
||
}, yl.prototype.isEmpty = function () {
|
||
return n()
|
||
}, yl.prototype.addDeclutter = function (t) {
|
||
return n()
|
||
};
|
||
var vl = yl, _l = {
|
||
CIRCLE: "Circle",
|
||
DEFAULT: "Default",
|
||
IMAGE: "Image",
|
||
LINE_STRING: "LineString",
|
||
POLYGON: "Polygon",
|
||
TEXT: "Text"
|
||
};
|
||
|
||
function xl(t, e, i, r, o, n, s, a) {
|
||
for (var l, h, u, c = [], p = t[e] > t[i - r], d = o.length, f = t[e], g = t[e + 1], m = t[e += r], y = t[e + 1], v = 0, _ = Math.sqrt(Math.pow(m - f, 2) + Math.pow(y - g, 2)), x = "", w = 0, b = 0; b < d; ++b) {
|
||
h = p ? d - b - 1 : b;
|
||
var C = o.charAt(h), S = n(x = p ? C + x : x + C) - w;
|
||
w += S;
|
||
for (var E = s + S / 2; e < i - r && v + _ < E;) f = m, g = y, m = t[e += r], y = t[e + 1], v += _, _ = Math.sqrt(Math.pow(m - f, 2) + Math.pow(y - g, 2));
|
||
var T = E - v, R = Math.atan2(y - g, m - f);
|
||
if (p && (R += R > 0 ? -Math.PI : Math.PI), void 0 !== u) {
|
||
var P = R - u;
|
||
if (P += P > Math.PI ? -2 * Math.PI : P < -Math.PI ? 2 * Math.PI : 0, Math.abs(P) > a) return null
|
||
}
|
||
var L = T / _, I = he(f, m, L), O = he(g, y, L);
|
||
u == R ? (p && (l[0] = I, l[1] = O, l[2] = S / 2), l[4] = x) : (w = S, l = [I, O, S / 2, R, x = C], p ? c.unshift(l) : c.push(l), u = R), s += S
|
||
}
|
||
return c
|
||
}
|
||
|
||
var wl = {
|
||
BEGIN_GEOMETRY: 0,
|
||
BEGIN_PATH: 1,
|
||
CIRCLE: 2,
|
||
CLOSE_PATH: 3,
|
||
CUSTOM: 4,
|
||
DRAW_CHARS: 5,
|
||
DRAW_IMAGE: 6,
|
||
END_GEOMETRY: 7,
|
||
FILL: 8,
|
||
MOVE_TO_LINE_TO: 9,
|
||
SET_FILL_STYLE: 10,
|
||
SET_STROKE_STYLE: 11,
|
||
STROKE: 12
|
||
}, bl = [wl.FILL], Cl = [wl.STROKE], Sl = [wl.BEGIN_PATH], El = [wl.CLOSE_PATH], Tl = wl,
|
||
Rl = [_l.POLYGON, _l.CIRCLE, _l.LINE_STRING, _l.IMAGE, _l.TEXT, _l.DEFAULT], Pl = {
|
||
left: 0,
|
||
end: 0,
|
||
center: .5,
|
||
right: 1,
|
||
start: 1,
|
||
top: 0,
|
||
middle: .5,
|
||
hanging: .2,
|
||
alphabetic: .8,
|
||
ideographic: .8,
|
||
bottom: 1
|
||
}, Ll = [1 / 0, 1 / 0, -1 / 0, -1 / 0], Il = [1, 0, 0, 1, 0, 0], Ol = function (t) {
|
||
function e(e, i, r, o, n, s) {
|
||
t.call(this), this.declutterTree = s, this.tolerance = e, this.maxExtent = i, this.overlaps = n, this.pixelRatio = o, this.maxLineWidth = 0, this.resolution = r, this.alignFill_, this.beginGeometryInstruction1_ = null, this.beginGeometryInstruction2_ = null, this.bufferedMaxExtent_ = null, this.instructions = [], this.coordinates = [], this.coordinateCache_ = {}, this.renderedTransform_ = [1, 0, 0, 1, 0, 0], this.hitDetectionInstructions = [], this.pixelCoordinates_ = null, this.state = {}, this.viewRotation_ = 0
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.replayTextBackground_ = function (t, e, i, r, o, n, s) {
|
||
t.beginPath(), t.moveTo.apply(t, e), t.lineTo.apply(t, i), t.lineTo.apply(t, r), t.lineTo.apply(t, o), t.lineTo.apply(t, e), n && (this.alignFill_ = n[2], this.fill_(t)), s && (this.setStrokeStyle_(t, s), t.stroke())
|
||
}, e.prototype.replayImage_ = function (t, e, i, r, o, n, s, a, l, h, u, c, p, d, f, g, m, y) {
|
||
var v = m || y;
|
||
e -= o *= p, i -= n *= p;
|
||
var _, x, w, b, C = f + h > r.width ? r.width - h : f, S = a + u > r.height ? r.height - u : a,
|
||
E = g[3] + C * p + g[1], T = g[0] + S * p + g[2], R = e - g[3], P = i - g[0];
|
||
(v || 0 !== c) && (_ = [R, P], x = [R + E, P], w = [R + E, P + T], b = [R, P + T]);
|
||
var L = null;
|
||
if (0 !== c) {
|
||
var I = e + o, O = i + n;
|
||
L = gi(Il, I, O, 1, 1, c, -I, -O), vt(Ll), St(Ll, ci(Il, _)), St(Ll, ci(Il, x)), St(Ll, ci(Il, w)), St(Ll, ci(Il, b))
|
||
} else yt(R, P, R + E, P + T, Ll);
|
||
var M = t.canvas, A = y ? y[2] * p / 2 : 0,
|
||
k = Ll[0] - A <= M.width && Ll[2] + A >= 0 && Ll[1] - A <= M.height && Ll[3] + A >= 0;
|
||
if (d && (e = Math.round(e), i = Math.round(i)), s) {
|
||
if (!k && 1 == s[4]) return;
|
||
Ct(s, Ll);
|
||
var F = k ? [t, L ? L.slice(0) : null, l, r, h, u, C, S, e, i, p] : null;
|
||
F && v && F.push(m, y, _, x, w, b), s.push(F)
|
||
} else k && (v && this.replayTextBackground_(t, _, x, w, b, m, y), Ya(t, L, l, r, h, u, C, S, e, i, p))
|
||
}, e.prototype.applyPixelRatio = function (t) {
|
||
var e = this.pixelRatio;
|
||
return 1 == e ? t : t.map(function (t) {
|
||
return t * e
|
||
})
|
||
}, e.prototype.appendFlatCoordinates = function (t, e, i, r, o, n) {
|
||
var s = this.coordinates.length, a = this.getBufferedMaxExtent();
|
||
n && (e += r);
|
||
var l, h, u, c = [t[e], t[e + 1]], p = [NaN, NaN], d = !0;
|
||
for (l = e + r; l < i; l += r) p[0] = t[l], p[1] = t[l + 1], (u = gt(a, p)) !== h ? (d && (this.coordinates[s++] = c[0], this.coordinates[s++] = c[1]), this.coordinates[s++] = p[0], this.coordinates[s++] = p[1], d = !1) : u === at.INTERSECTING ? (this.coordinates[s++] = p[0], this.coordinates[s++] = p[1], d = !1) : d = !0, c[0] = p[0], c[1] = p[1], h = u;
|
||
return (o && d || l === e + r) && (this.coordinates[s++] = c[0], this.coordinates[s++] = c[1]), s
|
||
}, e.prototype.drawCustomCoordinates_ = function (t, e, i, r, o) {
|
||
for (var n = 0, s = i.length; n < s; ++n) {
|
||
var a = i[n], l = this.appendFlatCoordinates(t, e, a, r, !1, !1);
|
||
o.push(l), e = a
|
||
}
|
||
return e
|
||
}, e.prototype.drawCustom = function (t, e, i) {
|
||
this.beginGeometry(t, e);
|
||
var r, o, n, s, a, l = t.getType(), h = t.getStride(), u = this.coordinates.length;
|
||
if (l == Zt.MULTI_POLYGON) {
|
||
r = (t = t).getOrientedFlatCoordinates(), s = [];
|
||
var c = t.getEndss();
|
||
a = 0;
|
||
for (var p = 0, d = c.length; p < d; ++p) {
|
||
var f = [];
|
||
a = this.drawCustomCoordinates_(r, a, c[p], h, f), s.push(f)
|
||
}
|
||
this.instructions.push([Tl.CUSTOM, u, s, t, i, ji])
|
||
} else l == Zt.POLYGON || l == Zt.MULTI_LINE_STRING ? (n = [], r = l == Zt.POLYGON ? t.getOrientedFlatCoordinates() : t.getFlatCoordinates(), a = this.drawCustomCoordinates_(r, 0, t.getEnds(), h, n), this.instructions.push([Tl.CUSTOM, u, n, t, i, Gi])) : l == Zt.LINE_STRING || l == Zt.MULTI_POINT ? (r = t.getFlatCoordinates(), o = this.appendFlatCoordinates(r, 0, r.length, h, !1, !1), this.instructions.push([Tl.CUSTOM, u, o, t, i, Di])) : l == Zt.POINT && (r = t.getFlatCoordinates(), this.coordinates.push(r[0], r[1]), o = this.coordinates.length, this.instructions.push([Tl.CUSTOM, u, o, t, i]));
|
||
this.endGeometry(t, e)
|
||
}, e.prototype.beginGeometry = function (t, e) {
|
||
this.beginGeometryInstruction1_ = [Tl.BEGIN_GEOMETRY, e, 0], this.instructions.push(this.beginGeometryInstruction1_), this.beginGeometryInstruction2_ = [Tl.BEGIN_GEOMETRY, e, 0], this.hitDetectionInstructions.push(this.beginGeometryInstruction2_)
|
||
}, e.prototype.finish = function () {
|
||
}, e.prototype.fill_ = function (t) {
|
||
if (this.alignFill_) {
|
||
var e = ci(this.renderedTransform_, [0, 0]), i = 512 * this.pixelRatio;
|
||
t.translate(e[0] % i, e[1] % i), t.rotate(this.viewRotation_)
|
||
}
|
||
t.fill(), this.alignFill_ && t.setTransform.apply(t, Va)
|
||
}, e.prototype.setStrokeStyle_ = function (t, e) {
|
||
t.strokeStyle = e[1], t.lineWidth = e[2], t.lineCap = e[3], t.lineJoin = e[4], t.miterLimit = e[5], Er && (t.lineDashOffset = e[7], t.setLineDash(e[6]))
|
||
}, e.prototype.renderDeclutter_ = function (t, e) {
|
||
if (t && t.length > 5) {
|
||
var i = t[4];
|
||
if (1 == i || i == t.length - 5) {
|
||
var r = {minX: t[0], minY: t[1], maxX: t[2], maxY: t[3], value: e};
|
||
if (!this.declutterTree.collides(r)) {
|
||
this.declutterTree.insert(r);
|
||
for (var o = 5, n = t.length; o < n; ++o) {
|
||
var s = t[o];
|
||
s && (s.length > 11 && this.replayTextBackground_(s[0], s[13], s[14], s[15], s[16], s[11], s[12]), Ya.apply(void 0, s))
|
||
}
|
||
}
|
||
t.length = 5, vt(t)
|
||
}
|
||
}
|
||
}, e.prototype.replay_ = function (t, e, i, r, o, n, s) {
|
||
var l;
|
||
this.pixelCoordinates_ && it(e, this.renderedTransform_) ? l = this.pixelCoordinates_ : (this.pixelCoordinates_ || (this.pixelCoordinates_ = []), l = Kt(this.coordinates, 0, this.coordinates.length, 2, e, this.pixelCoordinates_), ui(this.renderedTransform_, e));
|
||
for (var h, u, c, p, d, f, m, y, v, _, x, w, b = !g(i), C = 0, S = r.length, E = 0, T = 0, R = 0, P = null, L = null, I = this.coordinateCache_, O = this.viewRotation_, M = {
|
||
context: t,
|
||
pixelRatio: this.pixelRatio,
|
||
resolution: this.resolution,
|
||
rotation: O
|
||
}, A = this.instructions != r || this.overlaps ? 0 : 200; C < S;) {
|
||
var k = r[C];
|
||
switch (k[0]) {
|
||
case Tl.BEGIN_GEOMETRY:
|
||
_ = k[1], b && i[a(_)] || !_.getGeometry() ? C = k[2] : void 0 === s || Bt(s, _.getGeometry().getExtent()) ? ++C : C = k[2] + 1;
|
||
break;
|
||
case Tl.BEGIN_PATH:
|
||
T > A && (this.fill_(t), T = 0), R > A && (t.stroke(), R = 0), T || R || (t.beginPath(), p = d = NaN), ++C;
|
||
break;
|
||
case Tl.CIRCLE:
|
||
var F = l[E = k[1]], N = l[E + 1], D = l[E + 2] - F, G = l[E + 3] - N,
|
||
j = Math.sqrt(D * D + G * G);
|
||
t.moveTo(F + j, N), t.arc(F, N, j, 0, 2 * Math.PI, !0), ++C;
|
||
break;
|
||
case Tl.CLOSE_PATH:
|
||
t.closePath(), ++C;
|
||
break;
|
||
case Tl.CUSTOM:
|
||
E = k[1], h = k[2];
|
||
var z = k[3], U = k[4], B = 6 == k.length ? k[5] : void 0;
|
||
M.geometry = z, M.feature = _, C in I || (I[C] = []);
|
||
var V = I[C];
|
||
B ? B(l, E, h, 2, V) : (V[0] = l[E], V[1] = l[E + 1], V.length = 2), U(V, M), ++C;
|
||
break;
|
||
case Tl.DRAW_IMAGE:
|
||
E = k[1], h = k[2], v = k[3], u = k[4], c = k[5], y = n ? null : k[6];
|
||
var Y = k[7], W = k[8], H = k[9], X = k[10], q = k[11], Z = k[12], K = k[13], J = k[14],
|
||
$ = void 0, Q = void 0, tt = void 0;
|
||
for (k.length > 16 ? ($ = k[15], Q = k[16], tt = k[17]) : ($ = Oa, Q = tt = !1), q && (Z += O); E < h; E += 2) this.replayImage_(t, l[E], l[E + 1], v, u, c, y, Y, W, H, X, Z, K, o, J, $, Q ? P : null, tt ? L : null);
|
||
this.renderDeclutter_(y, _), ++C;
|
||
break;
|
||
case Tl.DRAW_CHARS:
|
||
var et = k[1], rt = k[2], ot = k[3];
|
||
y = n ? null : k[4];
|
||
var nt = k[5], st = k[6], at = k[7], lt = k[8], ht = k[9], ut = k[10], ct = k[11],
|
||
pt = k[12], dt = k[13], ft = k[14], gt = Kr(l, et, rt, 2), mt = lt(pt);
|
||
if (nt || mt <= gt) {
|
||
var yt = this.textStates[dt].textAlign,
|
||
vt = xl(l, et, rt, 2, pt, lt, (gt - mt) * Pl[yt], at);
|
||
if (vt) {
|
||
var _t = void 0, xt = void 0, wt = void 0, bt = void 0, Ct = void 0;
|
||
if (ut) for (_t = 0, xt = vt.length; _t < xt; ++_t) wt = (Ct = vt[_t])[4], bt = this.getImage(wt, dt, "", ut), u = Ct[2] + ct, c = ot * bt.height + 2 * (.5 - ot) * ct - ht, this.replayImage_(t, Ct[0], Ct[1], bt, u, c, y, bt.height, 1, 0, 0, Ct[3], ft, !1, bt.width, Oa, null, null);
|
||
if (st) for (_t = 0, xt = vt.length; _t < xt; ++_t) wt = (Ct = vt[_t])[4], bt = this.getImage(wt, dt, st, ""), u = Ct[2], c = ot * bt.height - ht, this.replayImage_(t, Ct[0], Ct[1], bt, u, c, y, bt.height, 1, 0, 0, Ct[3], ft, !1, bt.width, Oa, null, null)
|
||
}
|
||
}
|
||
this.renderDeclutter_(y, _), ++C;
|
||
break;
|
||
case Tl.END_GEOMETRY:
|
||
if (void 0 !== n) {
|
||
var St = n(_ = k[1]);
|
||
if (St) return St
|
||
}
|
||
++C;
|
||
break;
|
||
case Tl.FILL:
|
||
A ? T++ : this.fill_(t), ++C;
|
||
break;
|
||
case Tl.MOVE_TO_LINE_TO:
|
||
for (E = k[1], h = k[2], x = l[E], m = (w = l[E + 1]) + .5 | 0, (f = x + .5 | 0) === p && m === d || (t.moveTo(x, w), p = f, d = m), E += 2; E < h; E += 2) f = (x = l[E]) + .5 | 0, m = (w = l[E + 1]) + .5 | 0, E != h - 2 && f === p && m === d || (t.lineTo(x, w), p = f, d = m);
|
||
++C;
|
||
break;
|
||
case Tl.SET_FILL_STYLE:
|
||
P = k, this.alignFill_ = k[2], T && (this.fill_(t), T = 0, R && (t.stroke(), R = 0)), t.fillStyle = k[1], ++C;
|
||
break;
|
||
case Tl.SET_STROKE_STYLE:
|
||
L = k, R && (t.stroke(), R = 0), this.setStrokeStyle_(t, k), ++C;
|
||
break;
|
||
case Tl.STROKE:
|
||
A ? R++ : t.stroke(), ++C;
|
||
break;
|
||
default:
|
||
++C
|
||
}
|
||
}
|
||
T && this.fill_(t), R && t.stroke()
|
||
}, e.prototype.replay = function (t, e, i, r, o) {
|
||
this.viewRotation_ = i, this.replay_(t, e, r, this.instructions, o, void 0, void 0)
|
||
}, e.prototype.replayHitDetection = function (t, e, i, r, o, n) {
|
||
return this.viewRotation_ = i, this.replay_(t, e, r, this.hitDetectionInstructions, !0, o, n)
|
||
}, e.prototype.reverseHitDetectionInstructions = function () {
|
||
var t, e = this.hitDetectionInstructions;
|
||
e.reverse();
|
||
var i, r, o = e.length, n = -1;
|
||
for (t = 0; t < o; ++t) (r = (i = e[t])[0]) == Tl.END_GEOMETRY ? n = t : r == Tl.BEGIN_GEOMETRY && (i[2] = t, $(this.hitDetectionInstructions, n, t), n = -1)
|
||
}, e.prototype.setFillStrokeStyle = function (t, e) {
|
||
var i = this.state;
|
||
if (t) {
|
||
var r = t.getColor();
|
||
i.fillStyle = Wa(r || Pa)
|
||
} else i.fillStyle = void 0;
|
||
if (e) {
|
||
var o = e.getColor();
|
||
i.strokeStyle = Wa(o || Ia);
|
||
var n = e.getLineCap();
|
||
i.lineCap = void 0 !== n ? n : "round";
|
||
var s = e.getLineDash();
|
||
i.lineDash = s ? s.slice() : La;
|
||
var a = e.getLineDashOffset();
|
||
i.lineDashOffset = a || 0;
|
||
var l = e.getLineJoin();
|
||
i.lineJoin = void 0 !== l ? l : "round";
|
||
var h = e.getWidth();
|
||
i.lineWidth = void 0 !== h ? h : 1;
|
||
var u = e.getMiterLimit();
|
||
i.miterLimit = void 0 !== u ? u : 10, i.lineWidth > this.maxLineWidth && (this.maxLineWidth = i.lineWidth, this.bufferedMaxExtent_ = null)
|
||
} else i.strokeStyle = void 0, i.lineCap = void 0, i.lineDash = null, i.lineDashOffset = void 0, i.lineJoin = void 0, i.lineWidth = void 0, i.miterLimit = void 0
|
||
}, e.prototype.createFill = function (t, e) {
|
||
var i = t.fillStyle, r = [Tl.SET_FILL_STYLE, i];
|
||
return "string" != typeof i && r.push(!0), r
|
||
}, e.prototype.applyStroke = function (t) {
|
||
this.instructions.push(this.createStroke(t))
|
||
}, e.prototype.createStroke = function (t) {
|
||
return [Tl.SET_STROKE_STYLE, t.strokeStyle, t.lineWidth * this.pixelRatio, t.lineCap, t.lineJoin, t.miterLimit, this.applyPixelRatio(t.lineDash), t.lineDashOffset * this.pixelRatio]
|
||
}, e.prototype.updateFillStyle = function (t, e, i) {
|
||
var r = t.fillStyle;
|
||
"string" == typeof r && t.currentFillStyle == r || (void 0 !== r && this.instructions.push(e.call(this, t, i)), t.currentFillStyle = r)
|
||
}, e.prototype.updateStrokeStyle = function (t, e) {
|
||
var i = t.strokeStyle, r = t.lineCap, o = t.lineDash, n = t.lineDashOffset, s = t.lineJoin,
|
||
a = t.lineWidth, l = t.miterLimit;
|
||
(t.currentStrokeStyle != i || t.currentLineCap != r || o != t.currentLineDash && !it(t.currentLineDash, o) || t.currentLineDashOffset != n || t.currentLineJoin != s || t.currentLineWidth != a || t.currentMiterLimit != l) && (void 0 !== i && e.call(this, t), t.currentStrokeStyle = i, t.currentLineCap = r, t.currentLineDash = o, t.currentLineDashOffset = n, t.currentLineJoin = s, t.currentLineWidth = a, t.currentMiterLimit = l)
|
||
}, e.prototype.endGeometry = function (t, e) {
|
||
this.beginGeometryInstruction1_[2] = this.instructions.length, this.beginGeometryInstruction1_ = null, this.beginGeometryInstruction2_[2] = this.hitDetectionInstructions.length, this.beginGeometryInstruction2_ = null;
|
||
var i = [Tl.END_GEOMETRY, e];
|
||
this.instructions.push(i), this.hitDetectionInstructions.push(i)
|
||
}, e.prototype.getBufferedMaxExtent = function () {
|
||
if (!this.bufferedMaxExtent_ && (this.bufferedMaxExtent_ = ut(this.maxExtent), this.maxLineWidth > 0)) {
|
||
var t = this.resolution * (this.maxLineWidth + 1) / 2;
|
||
ht(this.bufferedMaxExtent_, t, this.bufferedMaxExtent_)
|
||
}
|
||
return this.bufferedMaxExtent_
|
||
}, e
|
||
}(Xa), Ml = function (t) {
|
||
function e(e, i, r, o, n, s) {
|
||
t.call(this, e, i, r, o, n, s), this.declutterGroup_ = null, this.hitDetectionImage_ = null, this.image_ = null, this.anchorX_ = void 0, this.anchorY_ = void 0, this.height_ = void 0, this.opacity_ = void 0, this.originX_ = void 0, this.originY_ = void 0, this.rotateWithView_ = void 0, this.rotation_ = void 0, this.scale_ = void 0, this.width_ = void 0
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.drawCoordinates_ = function (t, e, i, r) {
|
||
return this.appendFlatCoordinates(t, e, i, r, !1, !1)
|
||
}, e.prototype.drawPoint = function (t, e) {
|
||
if (this.image_) {
|
||
this.beginGeometry(t, e);
|
||
var i = t.getFlatCoordinates(), r = t.getStride(), o = this.coordinates.length,
|
||
n = this.drawCoordinates_(i, 0, i.length, r);
|
||
this.instructions.push([Tl.DRAW_IMAGE, o, n, this.image_, this.anchorX_, this.anchorY_, this.declutterGroup_, this.height_, this.opacity_, this.originX_, this.originY_, this.rotateWithView_, this.rotation_, this.scale_ * this.pixelRatio, this.width_]), this.hitDetectionInstructions.push([Tl.DRAW_IMAGE, o, n, this.hitDetectionImage_, this.anchorX_, this.anchorY_, this.declutterGroup_, this.height_, this.opacity_, this.originX_, this.originY_, this.rotateWithView_, this.rotation_, this.scale_, this.width_]), this.endGeometry(t, e)
|
||
}
|
||
}, e.prototype.drawMultiPoint = function (t, e) {
|
||
if (this.image_) {
|
||
this.beginGeometry(t, e);
|
||
var i = t.getFlatCoordinates(), r = t.getStride(), o = this.coordinates.length,
|
||
n = this.drawCoordinates_(i, 0, i.length, r);
|
||
this.instructions.push([Tl.DRAW_IMAGE, o, n, this.image_, this.anchorX_, this.anchorY_, this.declutterGroup_, this.height_, this.opacity_, this.originX_, this.originY_, this.rotateWithView_, this.rotation_, this.scale_ * this.pixelRatio, this.width_]), this.hitDetectionInstructions.push([Tl.DRAW_IMAGE, o, n, this.hitDetectionImage_, this.anchorX_, this.anchorY_, this.declutterGroup_, this.height_, this.opacity_, this.originX_, this.originY_, this.rotateWithView_, this.rotation_, this.scale_, this.width_]), this.endGeometry(t, e)
|
||
}
|
||
}, e.prototype.finish = function () {
|
||
this.reverseHitDetectionInstructions(), this.anchorX_ = void 0, this.anchorY_ = void 0, this.hitDetectionImage_ = null, this.image_ = null, this.height_ = void 0, this.scale_ = void 0, this.opacity_ = void 0, this.originX_ = void 0, this.originY_ = void 0, this.rotateWithView_ = void 0, this.rotation_ = void 0, this.width_ = void 0
|
||
}, e.prototype.setImageStyle = function (t, e) {
|
||
var i = t.getAnchor(), r = t.getSize(), o = t.getHitDetectionImage(1), n = t.getImage(1),
|
||
s = t.getOrigin();
|
||
this.anchorX_ = i[0], this.anchorY_ = i[1], this.declutterGroup_ = e, this.hitDetectionImage_ = o, this.image_ = n, this.height_ = r[1], this.opacity_ = t.getOpacity(), this.originX_ = s[0], this.originY_ = s[1], this.rotateWithView_ = t.getRotateWithView(), this.rotation_ = t.getRotation(), this.scale_ = t.getScale(), this.width_ = r[0]
|
||
}, e
|
||
}(Ol), Al = function (t) {
|
||
function e(e, i, r, o, n, s) {
|
||
t.call(this, e, i, r, o, n, s)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.drawFlatCoordinates_ = function (t, e, i, r) {
|
||
var o = this.coordinates.length, n = this.appendFlatCoordinates(t, e, i, r, !1, !1),
|
||
s = [Tl.MOVE_TO_LINE_TO, o, n];
|
||
return this.instructions.push(s), this.hitDetectionInstructions.push(s), i
|
||
}, e.prototype.drawLineString = function (t, e) {
|
||
var i = this.state, r = i.strokeStyle, o = i.lineWidth;
|
||
if (void 0 !== r && void 0 !== o) {
|
||
this.updateStrokeStyle(i, this.applyStroke), this.beginGeometry(t, e), this.hitDetectionInstructions.push([Tl.SET_STROKE_STYLE, i.strokeStyle, i.lineWidth, i.lineCap, i.lineJoin, i.miterLimit, i.lineDash, i.lineDashOffset], Sl);
|
||
var n = t.getFlatCoordinates(), s = t.getStride();
|
||
this.drawFlatCoordinates_(n, 0, n.length, s), this.hitDetectionInstructions.push(Cl), this.endGeometry(t, e)
|
||
}
|
||
}, e.prototype.drawMultiLineString = function (t, e) {
|
||
var i = this.state, r = i.strokeStyle, o = i.lineWidth;
|
||
if (void 0 !== r && void 0 !== o) {
|
||
this.updateStrokeStyle(i, this.applyStroke), this.beginGeometry(t, e), this.hitDetectionInstructions.push([Tl.SET_STROKE_STYLE, i.strokeStyle, i.lineWidth, i.lineCap, i.lineJoin, i.miterLimit, i.lineDash, i.lineDashOffset], Sl);
|
||
for (var n = t.getEnds(), s = t.getFlatCoordinates(), a = t.getStride(), l = 0, h = 0, u = n.length; h < u; ++h) l = this.drawFlatCoordinates_(s, l, n[h], a);
|
||
this.hitDetectionInstructions.push(Cl), this.endGeometry(t, e)
|
||
}
|
||
}, e.prototype.finish = function () {
|
||
var t = this.state;
|
||
null != t.lastStroke && t.lastStroke != this.coordinates.length && this.instructions.push(Cl), this.reverseHitDetectionInstructions(), this.state = null
|
||
}, e.prototype.applyStroke = function (e) {
|
||
null != e.lastStroke && e.lastStroke != this.coordinates.length && (this.instructions.push(Cl), e.lastStroke = this.coordinates.length), e.lastStroke = 0, t.prototype.applyStroke.call(this, e), this.instructions.push(Sl)
|
||
}, e
|
||
}(Ol), kl = function (t) {
|
||
function e(e, i, r, o, n, s) {
|
||
t.call(this, e, i, r, o, n, s)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.drawFlatCoordinatess_ = function (t, e, i, r) {
|
||
var o = this.state, n = void 0 !== o.fillStyle, s = null != o.strokeStyle, a = i.length;
|
||
this.instructions.push(Sl), this.hitDetectionInstructions.push(Sl);
|
||
for (var l = 0; l < a; ++l) {
|
||
var h = i[l], u = this.coordinates.length, c = this.appendFlatCoordinates(t, e, h, r, !0, !s),
|
||
p = [Tl.MOVE_TO_LINE_TO, u, c];
|
||
this.instructions.push(p), this.hitDetectionInstructions.push(p), s && (this.instructions.push(El), this.hitDetectionInstructions.push(El)), e = h
|
||
}
|
||
return n && (this.instructions.push(bl), this.hitDetectionInstructions.push(bl)), s && (this.instructions.push(Cl), this.hitDetectionInstructions.push(Cl)), e
|
||
}, e.prototype.drawCircle = function (t, e) {
|
||
var i = this.state, r = i.fillStyle, o = i.strokeStyle;
|
||
if (void 0 !== r || void 0 !== o) {
|
||
this.setFillStrokeStyles_(t), this.beginGeometry(t, e), void 0 !== i.fillStyle && this.hitDetectionInstructions.push([Tl.SET_FILL_STYLE, oo(Pa)]), void 0 !== i.strokeStyle && this.hitDetectionInstructions.push([Tl.SET_STROKE_STYLE, i.strokeStyle, i.lineWidth, i.lineCap, i.lineJoin, i.miterLimit, i.lineDash, i.lineDashOffset]);
|
||
var n = t.getFlatCoordinates(), s = t.getStride(), a = this.coordinates.length;
|
||
this.appendFlatCoordinates(n, 0, n.length, s, !1, !1);
|
||
var l = [Tl.CIRCLE, a];
|
||
this.instructions.push(Sl, l), this.hitDetectionInstructions.push(Sl, l), this.hitDetectionInstructions.push(bl), void 0 !== i.fillStyle && this.instructions.push(bl), void 0 !== i.strokeStyle && (this.instructions.push(Cl), this.hitDetectionInstructions.push(Cl)), this.endGeometry(t, e)
|
||
}
|
||
}, e.prototype.drawPolygon = function (t, e) {
|
||
var i = this.state, r = i.fillStyle, o = i.strokeStyle;
|
||
if (void 0 !== r || void 0 !== o) {
|
||
this.setFillStrokeStyles_(t), this.beginGeometry(t, e), void 0 !== i.fillStyle && this.hitDetectionInstructions.push([Tl.SET_FILL_STYLE, oo(Pa)]), void 0 !== i.strokeStyle && this.hitDetectionInstructions.push([Tl.SET_STROKE_STYLE, i.strokeStyle, i.lineWidth, i.lineCap, i.lineJoin, i.miterLimit, i.lineDash, i.lineDashOffset]);
|
||
var n = t.getEnds(), s = t.getOrientedFlatCoordinates(), a = t.getStride();
|
||
this.drawFlatCoordinatess_(s, 0, n, a), this.endGeometry(t, e)
|
||
}
|
||
}, e.prototype.drawMultiPolygon = function (t, e) {
|
||
var i = this.state, r = i.fillStyle, o = i.strokeStyle;
|
||
if (void 0 !== r || void 0 !== o) {
|
||
this.setFillStrokeStyles_(t), this.beginGeometry(t, e), void 0 !== i.fillStyle && this.hitDetectionInstructions.push([Tl.SET_FILL_STYLE, oo(Pa)]), void 0 !== i.strokeStyle && this.hitDetectionInstructions.push([Tl.SET_STROKE_STYLE, i.strokeStyle, i.lineWidth, i.lineCap, i.lineJoin, i.miterLimit, i.lineDash, i.lineDashOffset]);
|
||
for (var n = t.getEndss(), s = t.getOrientedFlatCoordinates(), a = t.getStride(), l = 0, h = 0, u = n.length; h < u; ++h) l = this.drawFlatCoordinatess_(s, l, n[h], a);
|
||
this.endGeometry(t, e)
|
||
}
|
||
}, e.prototype.finish = function () {
|
||
this.reverseHitDetectionInstructions(), this.state = null;
|
||
var t = this.tolerance;
|
||
if (0 !== t) for (var e = this.coordinates, i = 0, r = e.length; i < r; ++i) e[i] = Vi(e[i], t)
|
||
}, e.prototype.setFillStrokeStyles_ = function (t) {
|
||
var e = this.state;
|
||
void 0 !== e.fillStyle && this.updateFillStyle(e, this.createFill, t), void 0 !== e.strokeStyle && this.updateStrokeStyle(e, this.applyStroke)
|
||
}, e
|
||
}(Ol);
|
||
|
||
function Fl(t, e, i, r, o) {
|
||
var n, s, a, l, h, u, c, p, d, f = i, g = i, m = 0, y = 0, v = i;
|
||
for (n = i; n < r; n += o) {
|
||
var _ = e[n], x = e[n + 1];
|
||
void 0 !== l && (p = _ - l, d = x - h, a = Math.sqrt(p * p + d * d), void 0 !== u && (y += s, Math.acos((u * p + c * d) / (s * a)) > t && (y > m && (m = y, f = v, g = n), y = 0, v = n - o)), s = a, u = p, c = d), l = _, h = x
|
||
}
|
||
return (y += a) > m ? [v, n] : [f, g]
|
||
}
|
||
|
||
function Nl(t, e, i) {
|
||
for (var r = e.length, o = 0, n = 0; n < r; ++n) {
|
||
var s = Ua(t, e[n]);
|
||
o = Math.max(o, s), i.push(s)
|
||
}
|
||
return o
|
||
}
|
||
|
||
var Dl = function (t) {
|
||
function e(e, i, r, o, n, s) {
|
||
t.call(this, e, i, r, o, n, s), this.declutterGroup_, this.labels_ = null, this.text_ = "", this.textOffsetX_ = 0, this.textOffsetY_ = 0, this.textRotateWithView_ = void 0, this.textRotation_ = 0, this.textFillState_ = null, this.fillStates = {}, this.textStrokeState_ = null, this.strokeStates = {}, this.textState_ = {}, this.textStates = {}, this.textKey_ = "", this.fillKey_ = "", this.strokeKey_ = "", this.widths_ = {}, Ma.prune()
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.drawText = function (t, e) {
|
||
var i = this.textFillState_, r = this.textStrokeState_, o = this.textState_;
|
||
if ("" !== this.text_ && o && (i || r)) {
|
||
var n, s, a = this.coordinates.length, l = t.getType(), h = null, u = 2, c = 2;
|
||
if (o.placement === mo.LINE) {
|
||
if (!Bt(this.getBufferedMaxExtent(), t.getExtent())) return;
|
||
var p;
|
||
if (h = t.getFlatCoordinates(), c = t.getStride(), l == Zt.LINE_STRING) p = [h.length]; else if (l == Zt.MULTI_LINE_STRING) p = t.getEnds(); else if (l == Zt.POLYGON) p = t.getEnds().slice(0, 1); else if (l == Zt.MULTI_POLYGON) {
|
||
var d = t.getEndss();
|
||
for (p = [], n = 0, s = d.length; n < s; ++n) p.push(d[n][0])
|
||
}
|
||
this.beginGeometry(t, e);
|
||
for (var f, g = o.textAlign, m = 0, y = 0, v = p.length; y < v; ++y) {
|
||
if (null == g) {
|
||
var _ = Fl(o.maxAngle, h, m, p[y], c);
|
||
m = _[0], f = _[1]
|
||
} else f = p[y];
|
||
for (n = m; n < f; n += c) this.coordinates.push(h[n], h[n + 1]);
|
||
u = this.coordinates.length, m = p[y], this.drawChars_(a, u, this.declutterGroup_), a = u
|
||
}
|
||
this.endGeometry(t, e)
|
||
} else {
|
||
var x = this.getImage(this.text_, this.textKey_, this.fillKey_, this.strokeKey_),
|
||
w = x.width / this.pixelRatio;
|
||
switch (l) {
|
||
case Zt.POINT:
|
||
case Zt.MULTI_POINT:
|
||
u = (h = t.getFlatCoordinates()).length;
|
||
break;
|
||
case Zt.LINE_STRING:
|
||
h = t.getFlatMidpoint();
|
||
break;
|
||
case Zt.CIRCLE:
|
||
h = t.getCenter();
|
||
break;
|
||
case Zt.MULTI_LINE_STRING:
|
||
u = (h = t.getFlatMidpoints()).length;
|
||
break;
|
||
case Zt.POLYGON:
|
||
if (h = t.getFlatInteriorPoint(), !o.overflow && h[2] / this.resolution < w) return;
|
||
c = 3;
|
||
break;
|
||
case Zt.MULTI_POLYGON:
|
||
var b = t.getFlatInteriorPoints();
|
||
for (h = [], n = 0, s = b.length; n < s; n += 3) (o.overflow || b[n + 2] / this.resolution >= w) && h.push(b[n], b[n + 1]);
|
||
if (0 == (u = h.length)) return
|
||
}
|
||
u = this.appendFlatCoordinates(h, 0, u, c, !1, !1), (o.backgroundFill || o.backgroundStroke) && (this.setFillStrokeStyle(o.backgroundFill, o.backgroundStroke), o.backgroundFill && (this.updateFillStyle(this.state, this.createFill, t), this.hitDetectionInstructions.push(this.createFill(this.state, t))), o.backgroundStroke && (this.updateStrokeStyle(this.state, this.applyStroke), this.hitDetectionInstructions.push(this.createStroke(this.state)))), this.beginGeometry(t, e), this.drawTextImage_(x, a, u), this.endGeometry(t, e)
|
||
}
|
||
}
|
||
}, e.prototype.getImage = function (t, e, i, r) {
|
||
var o, n = r + e + t + i + this.pixelRatio;
|
||
if (!Ma.containsKey(n)) {
|
||
var s = r ? this.strokeStates[r] || this.textStrokeState_ : null,
|
||
a = i ? this.fillStates[i] || this.textFillState_ : null,
|
||
l = this.textStates[e] || this.textState_, h = this.pixelRatio, u = l.scale * h,
|
||
c = Pl[l.textAlign || "center"], p = r && s.lineWidth ? s.lineWidth : 0, d = t.split("\n"),
|
||
f = d.length, g = [], m = Nl(l.font, d, g), y = za(l.font), v = y * f, _ = m + p,
|
||
x = Ao(Math.ceil(_ * u), Math.ceil((v + p) * u));
|
||
o = x.canvas, Ma.set(n, o), 1 != u && x.scale(u, u), x.font = l.font, r && (x.strokeStyle = s.strokeStyle, x.lineWidth = p, x.lineCap = s.lineCap, x.lineJoin = s.lineJoin, x.miterLimit = s.miterLimit, Er && s.lineDash.length && (x.setLineDash(s.lineDash), x.lineDashOffset = s.lineDashOffset)), i && (x.fillStyle = a.fillStyle), x.textBaseline = "middle", x.textAlign = "center";
|
||
var w, b = .5 - c, C = c * o.width / u + b * p;
|
||
if (r) for (w = 0; w < f; ++w) x.strokeText(d[w], C + b * g[w], .5 * (p + y) + w * y);
|
||
if (i) for (w = 0; w < f; ++w) x.fillText(d[w], C + b * g[w], .5 * (p + y) + w * y)
|
||
}
|
||
return Ma.get(n)
|
||
}, e.prototype.drawTextImage_ = function (t, e, i) {
|
||
var r = this.textState_, o = this.textStrokeState_, n = this.pixelRatio,
|
||
s = Pl[r.textAlign || "center"], a = Pl[r.textBaseline], l = o && o.lineWidth ? o.lineWidth : 0,
|
||
h = s * t.width / n + 2 * (.5 - s) * l, u = a * t.height / n + 2 * (.5 - a) * l;
|
||
this.instructions.push([Tl.DRAW_IMAGE, e, i, t, (h - this.textOffsetX_) * n, (u - this.textOffsetY_) * n, this.declutterGroup_, t.height, 1, 0, 0, this.textRotateWithView_, this.textRotation_, 1, t.width, r.padding == Oa ? Oa : r.padding.map(function (t) {
|
||
return t * n
|
||
}), !!r.backgroundFill, !!r.backgroundStroke]), this.hitDetectionInstructions.push([Tl.DRAW_IMAGE, e, i, t, (h - this.textOffsetX_) * n, (u - this.textOffsetY_) * n, this.declutterGroup_, t.height, 1, 0, 0, this.textRotateWithView_, this.textRotation_, 1 / n, t.width, r.padding, !!r.backgroundFill, !!r.backgroundStroke])
|
||
}, e.prototype.drawChars_ = function (t, e, i) {
|
||
var r = this.textStrokeState_, o = this.textState_, n = this.textFillState_, s = this.strokeKey_;
|
||
r && (s in this.strokeStates || (this.strokeStates[s] = {
|
||
strokeStyle: r.strokeStyle,
|
||
lineCap: r.lineCap,
|
||
lineDashOffset: r.lineDashOffset,
|
||
lineWidth: r.lineWidth,
|
||
lineJoin: r.lineJoin,
|
||
miterLimit: r.miterLimit,
|
||
lineDash: r.lineDash
|
||
}));
|
||
var a = this.textKey_;
|
||
this.textKey_ in this.textStates || (this.textStates[this.textKey_] = {
|
||
font: o.font,
|
||
textAlign: o.textAlign || "center",
|
||
scale: o.scale
|
||
});
|
||
var l = this.fillKey_;
|
||
n && (l in this.fillStates || (this.fillStates[l] = {fillStyle: n.fillStyle}));
|
||
var h = this.pixelRatio, u = Pl[o.textBaseline], c = this.textOffsetY_ * h, p = this.text_, d = o.font,
|
||
f = o.scale, g = r ? r.lineWidth * f / 2 : 0, m = this.widths_[d];
|
||
m || (this.widths_[d] = m = {}), this.instructions.push([Tl.DRAW_CHARS, t, e, u, i, o.overflow, l, o.maxAngle, function (t) {
|
||
var e = m[t];
|
||
return e || (e = m[t] = Ua(d, t)), e * f * h
|
||
}, c, s, g * h, p, a, 1]), this.hitDetectionInstructions.push([Tl.DRAW_CHARS, t, e, u, i, o.overflow, l, o.maxAngle, function (t) {
|
||
var e = m[t];
|
||
return e || (e = m[t] = Ua(d, t)), e * f
|
||
}, c, s, g, p, a, 1 / h])
|
||
}, e.prototype.setTextStyle = function (t, e) {
|
||
var i, r, o;
|
||
if (t) {
|
||
this.declutterGroup_ = e;
|
||
var n = t.getFill();
|
||
n ? ((r = this.textFillState_) || (r = this.textFillState_ = {}), r.fillStyle = Wa(n.getColor() || Pa)) : r = this.textFillState_ = null;
|
||
var s = t.getStroke();
|
||
if (s) {
|
||
(o = this.textStrokeState_) || (o = this.textStrokeState_ = {});
|
||
var l = s.getLineDash(), h = s.getLineDashOffset(), u = s.getWidth(), c = s.getMiterLimit();
|
||
o.lineCap = s.getLineCap() || "round", o.lineDash = l ? l.slice() : La, o.lineDashOffset = void 0 === h ? 0 : h, o.lineJoin = s.getLineJoin() || "round", o.lineWidth = void 0 === u ? 1 : u, o.miterLimit = void 0 === c ? 10 : c, o.strokeStyle = Wa(s.getColor() || Ia)
|
||
} else o = this.textStrokeState_ = null;
|
||
i = this.textState_;
|
||
var p = t.getFont() || "10px sans-serif";
|
||
Na(p);
|
||
var d = t.getScale();
|
||
i.overflow = t.getOverflow(), i.font = p, i.maxAngle = t.getMaxAngle(), i.placement = t.getPlacement(), i.textAlign = t.getTextAlign(), i.textBaseline = t.getTextBaseline() || "middle", i.backgroundFill = t.getBackgroundFill(), i.backgroundStroke = t.getBackgroundStroke(), i.padding = t.getPadding() || Oa, i.scale = void 0 === d ? 1 : d;
|
||
var f = t.getOffsetX(), g = t.getOffsetY(), m = t.getRotateWithView(), y = t.getRotation();
|
||
this.text_ = t.getText() || "", this.textOffsetX_ = void 0 === f ? 0 : f, this.textOffsetY_ = void 0 === g ? 0 : g, this.textRotateWithView_ = void 0 !== m && m, this.textRotation_ = void 0 === y ? 0 : y, this.strokeKey_ = o ? ("string" == typeof o.strokeStyle ? o.strokeStyle : a(o.strokeStyle)) + o.lineCap + o.lineDashOffset + "|" + o.lineWidth + o.lineJoin + o.miterLimit + "[" + o.lineDash.join() + "]" : "", this.textKey_ = i.font + i.scale + (i.textAlign || "?"), this.fillKey_ = r ? "string" == typeof r.fillStyle ? r.fillStyle : "|" + a(r.fillStyle) : ""
|
||
} else this.text_ = ""
|
||
}, e
|
||
}(Ol), Gl = {Circle: kl, Default: Ol, Image: Ml, LineString: Al, Polygon: kl, Text: Dl}, jl = {0: [[!0]]};
|
||
|
||
function zl(t, e, i) {
|
||
var r, o = Math.floor(t.length / 2);
|
||
if (e >= o) for (r = o; r < e; r++) t[r][i] = !0; else if (e < o) for (r = e + 1; r < o; r++) t[r][i] = !0
|
||
}
|
||
|
||
function Ul(t) {
|
||
if (void 0 !== jl[t]) return jl[t];
|
||
for (var e = 2 * t + 1, i = new Array(e), r = 0; r < e; r++) i[r] = new Array(e);
|
||
for (var o = t, n = 0, s = 0; o >= n;) zl(i, t + o, t + n), zl(i, t + n, t + o), zl(i, t - n, t + o), zl(i, t - o, t + n), zl(i, t - o, t - n), zl(i, t - n, t - o), zl(i, t + n, t - o), zl(i, t + o, t - n), 2 * ((s += 1 + 2 * ++n) - o) + 1 > 0 && (s += 1 - 2 * (o -= 1));
|
||
return jl[t] = i, i
|
||
}
|
||
|
||
function Bl(t, e, i, r) {
|
||
for (var o = Object.keys(t).map(Number).sort(Z), n = {}, s = 0, a = o.length; s < a; ++s) for (var l = t[o[s].toString()], h = 0, u = l.length; h < u;) {
|
||
var c = l[h++], p = l[h++];
|
||
c.replay(e, p, i, n, r)
|
||
}
|
||
}
|
||
|
||
var Vl = function (t) {
|
||
function e(e, i, r, o, n, s, a) {
|
||
t.call(this), this.declutterTree_ = s, this.declutterGroup_ = null, this.tolerance_ = e, this.maxExtent_ = i, this.overlaps_ = n, this.pixelRatio_ = o, this.resolution_ = r, this.renderBuffer_ = a, this.replaysByZIndex_ = {}, this.hitDetectionContext_ = Ao(1, 1), this.hitDetectionTransform_ = [1, 0, 0, 1, 0, 0]
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.addDeclutter = function (t) {
|
||
var e = null;
|
||
return this.declutterTree_ && (t ? (e = this.declutterGroup_)[4]++ : (e = this.declutterGroup_ = [1 / 0, 1 / 0, -1 / 0, -1 / 0]).push(1)), e
|
||
}, e.prototype.clip = function (t, e) {
|
||
var i = this.getClipCoords(e);
|
||
t.beginPath(), t.moveTo(i[0], i[1]), t.lineTo(i[2], i[3]), t.lineTo(i[4], i[5]), t.lineTo(i[6], i[7]), t.clip()
|
||
}, e.prototype.hasReplays = function (t) {
|
||
for (var e in this.replaysByZIndex_) for (var i = this.replaysByZIndex_[e], r = 0, o = t.length; r < o; ++r) if (t[r] in i) return !0;
|
||
return !1
|
||
}, e.prototype.finish = function () {
|
||
for (var t in this.replaysByZIndex_) {
|
||
var e = this.replaysByZIndex_[t];
|
||
for (var i in e) e[i].finish()
|
||
}
|
||
}, e.prototype.forEachFeatureAtCoordinate = function (t, e, i, r, o, n, s) {
|
||
var a, l = 2 * (r = Math.round(r)) + 1,
|
||
h = gi(this.hitDetectionTransform_, r + .5, r + .5, 1 / e, -1 / e, -i, -t[0], -t[1]),
|
||
u = this.hitDetectionContext_;
|
||
u.canvas.width !== l || u.canvas.height !== l ? (u.canvas.width = l, u.canvas.height = l) : u.clearRect(0, 0, l, l), void 0 !== this.renderBuffer_ && (St(a = [1 / 0, 1 / 0, -1 / 0, -1 / 0], t), ht(a, e * (this.renderBuffer_ + r), a));
|
||
var c, p, d = Ul(r);
|
||
|
||
function f(t) {
|
||
for (var e = u.getImageData(0, 0, l, l).data, i = 0; i < l; i++) for (var r = 0; r < l; r++) if (d[i][r] && e[4 * (r * l + i) + 3] > 0) {
|
||
var o = void 0;
|
||
return (!c || p != _l.IMAGE && p != _l.TEXT || -1 !== c.indexOf(t)) && (o = n(t)), o || void u.clearRect(0, 0, l, l)
|
||
}
|
||
}
|
||
|
||
this.declutterTree_ && (c = this.declutterTree_.all().map(function (t) {
|
||
return t.value
|
||
}));
|
||
var g, m, y, v, _, x = Object.keys(this.replaysByZIndex_).map(Number);
|
||
for (x.sort(Z), g = x.length - 1; g >= 0; --g) {
|
||
var w = x[g].toString();
|
||
for (y = this.replaysByZIndex_[w], m = Rl.length - 1; m >= 0; --m) if (void 0 !== (v = y[p = Rl[m]])) if (!s || p != _l.IMAGE && p != _l.TEXT) {
|
||
if (_ = v.replayHitDetection(u, h, i, o, f, a)) return _
|
||
} else {
|
||
var b = s[w];
|
||
b ? b.push(v, h.slice(0)) : s[w] = [v, h.slice(0)]
|
||
}
|
||
}
|
||
}, e.prototype.getClipCoords = function (t) {
|
||
var e = this.maxExtent_, i = e[0], r = e[1], o = e[2], n = e[3], s = [i, r, i, n, o, n, o, r];
|
||
return Kt(s, 0, 8, 2, t, s), s
|
||
}, e.prototype.getReplay = function (t, e) {
|
||
var i = void 0 !== t ? t.toString() : "0", r = this.replaysByZIndex_[i];
|
||
void 0 === r && (r = {}, this.replaysByZIndex_[i] = r);
|
||
var o = r[e];
|
||
void 0 === o && (o = new (0, Gl[e])(this.tolerance_, this.maxExtent_, this.resolution_, this.pixelRatio_, this.overlaps_, this.declutterTree_), r[e] = o);
|
||
return o
|
||
}, e.prototype.getReplays = function () {
|
||
return this.replaysByZIndex_
|
||
}, e.prototype.isEmpty = function () {
|
||
return g(this.replaysByZIndex_)
|
||
}, e.prototype.replay = function (t, e, i, r, o, n, s) {
|
||
var a = Object.keys(this.replaysByZIndex_).map(Number);
|
||
a.sort(Z), t.save(), this.clip(t, e);
|
||
var l, h, u, c, p, d, f = n || Rl;
|
||
for (l = 0, h = a.length; l < h; ++l) {
|
||
var g = a[l].toString();
|
||
for (p = this.replaysByZIndex_[g], u = 0, c = f.length; u < c; ++u) {
|
||
var m = f[u];
|
||
if (d = p[m], void 0 !== d) if (!s || m != _l.IMAGE && m != _l.TEXT) d.replay(t, e, i, r, o); else {
|
||
var y = s[g];
|
||
y ? y.push(d, e.slice(0)) : s[g] = [d, e.slice(0)]
|
||
}
|
||
}
|
||
}
|
||
t.restore()
|
||
}, e
|
||
}(vl), Yl = .5, Wl = {
|
||
Point: function (t, e, i, r) {
|
||
var o = i.getImage();
|
||
if (o) {
|
||
if (o.getImageState() != So.LOADED) return;
|
||
var n = t.getReplay(i.getZIndex(), _l.IMAGE);
|
||
n.setImageStyle(o, t.addDeclutter(!1)), n.drawPoint(e, r)
|
||
}
|
||
var s = i.getText();
|
||
if (s) {
|
||
var a = t.getReplay(i.getZIndex(), _l.TEXT);
|
||
a.setTextStyle(s, t.addDeclutter(!!o)), a.drawText(e, r)
|
||
}
|
||
}, LineString: function (t, e, i, r) {
|
||
var o = i.getStroke();
|
||
if (o) {
|
||
var n = t.getReplay(i.getZIndex(), _l.LINE_STRING);
|
||
n.setFillStrokeStyle(null, o), n.drawLineString(e, r)
|
||
}
|
||
var s = i.getText();
|
||
if (s) {
|
||
var a = t.getReplay(i.getZIndex(), _l.TEXT);
|
||
a.setTextStyle(s, t.addDeclutter(!1)), a.drawText(e, r)
|
||
}
|
||
}, Polygon: function (t, e, i, r) {
|
||
var o = i.getFill(), n = i.getStroke();
|
||
if (o || n) {
|
||
var s = t.getReplay(i.getZIndex(), _l.POLYGON);
|
||
s.setFillStrokeStyle(o, n), s.drawPolygon(e, r)
|
||
}
|
||
var a = i.getText();
|
||
if (a) {
|
||
var l = t.getReplay(i.getZIndex(), _l.TEXT);
|
||
l.setTextStyle(a, t.addDeclutter(!1)), l.drawText(e, r)
|
||
}
|
||
}, MultiPoint: function (t, e, i, r) {
|
||
var o = i.getImage();
|
||
if (o) {
|
||
if (o.getImageState() != So.LOADED) return;
|
||
var n = t.getReplay(i.getZIndex(), _l.IMAGE);
|
||
n.setImageStyle(o, t.addDeclutter(!1)), n.drawMultiPoint(e, r)
|
||
}
|
||
var s = i.getText();
|
||
if (s) {
|
||
var a = t.getReplay(i.getZIndex(), _l.TEXT);
|
||
a.setTextStyle(s, t.addDeclutter(!!o)), a.drawText(e, r)
|
||
}
|
||
}, MultiLineString: function (t, e, i, r) {
|
||
var o = i.getStroke();
|
||
if (o) {
|
||
var n = t.getReplay(i.getZIndex(), _l.LINE_STRING);
|
||
n.setFillStrokeStyle(null, o), n.drawMultiLineString(e, r)
|
||
}
|
||
var s = i.getText();
|
||
if (s) {
|
||
var a = t.getReplay(i.getZIndex(), _l.TEXT);
|
||
a.setTextStyle(s, t.addDeclutter(!1)), a.drawText(e, r)
|
||
}
|
||
}, MultiPolygon: function (t, e, i, r) {
|
||
var o = i.getFill(), n = i.getStroke();
|
||
if (n || o) {
|
||
var s = t.getReplay(i.getZIndex(), _l.POLYGON);
|
||
s.setFillStrokeStyle(o, n), s.drawMultiPolygon(e, r)
|
||
}
|
||
var a = i.getText();
|
||
if (a) {
|
||
var l = t.getReplay(i.getZIndex(), _l.TEXT);
|
||
l.setTextStyle(a, t.addDeclutter(!1)), l.drawText(e, r)
|
||
}
|
||
}, GeometryCollection: function (t, e, i, r) {
|
||
var o, n, s = e.getGeometriesArray();
|
||
for (o = 0, n = s.length; o < n; ++o) {
|
||
var a = Wl[s[o].getType()];
|
||
a(t, s[o], i, r)
|
||
}
|
||
}, Circle: function (t, e, i, r) {
|
||
var o = i.getFill(), n = i.getStroke();
|
||
if (o || n) {
|
||
var s = t.getReplay(i.getZIndex(), _l.CIRCLE);
|
||
s.setFillStrokeStyle(o, n), s.drawCircle(e, r)
|
||
}
|
||
var a = i.getText();
|
||
if (a) {
|
||
var l = t.getReplay(i.getZIndex(), _l.TEXT);
|
||
l.setTextStyle(a, t.addDeclutter(!1)), l.drawText(e, r)
|
||
}
|
||
}
|
||
};
|
||
|
||
function Hl(t, e) {
|
||
return parseInt(a(t), 10) - parseInt(a(e), 10)
|
||
}
|
||
|
||
function Xl(t, e) {
|
||
var i = ql(t, e);
|
||
return i * i
|
||
}
|
||
|
||
function ql(t, e) {
|
||
return Yl * t / e
|
||
}
|
||
|
||
function Zl(t, e, i, r, o, n) {
|
||
var s = !1, a = i.getImage();
|
||
if (a) {
|
||
var l = a.getImageState();
|
||
l == So.LOADED || l == So.ERROR ? a.unlistenImageChange(o, n) : (l == So.IDLE && a.load(), l = a.getImageState(), a.listenImageChange(o, n), s = !0)
|
||
}
|
||
return function (t, e, i, r) {
|
||
var o = i.getGeometryFunction()(e);
|
||
if (!o) return;
|
||
var n = o.getSimplifiedGeometry(r);
|
||
if (i.getRenderer()) !function t(e, i, r, o) {
|
||
if (i.getType() == Zt.GEOMETRY_COLLECTION) {
|
||
for (var n = i.getGeometries(), s = 0, a = n.length; s < a; ++s) t(e, n[s], r, o);
|
||
return
|
||
}
|
||
var l = e.getReplay(r.getZIndex(), _l.DEFAULT);
|
||
l.drawCustom(i, o, r.getRenderer())
|
||
}(t, n, i, e); else {
|
||
var s = Wl[n.getType()];
|
||
s(t, n, i, e)
|
||
}
|
||
}(t, e, i, r), s
|
||
}
|
||
|
||
var Kl = function (t) {
|
||
function e(e) {
|
||
t.call(this, e), this.declutterTree_ = e.getDeclutter() ? ml()(9, void 0) : null, this.dirty_ = !1, this.renderedRevision_ = -1, this.renderedResolution_ = NaN, this.renderedExtent_ = [1 / 0, 1 / 0, -1 / 0, -1 / 0], this.renderedRenderOrder_ = null, this.replayGroup_ = null, this.replayGroupChanged = !0, this.context = Ao(), w(Ma, F.CLEAR, this.handleFontsChanged_, this)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.disposeInternal = function () {
|
||
C(Ma, F.CLEAR, this.handleFontsChanged_, this), t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.compose = function (t, e, i) {
|
||
var r = e.extent, o = e.pixelRatio, n = i.managed ? e.skippedFeatureUids : {}, s = e.viewState,
|
||
a = s.projection, l = s.rotation, h = a.getExtent(), u = this.getLayer().getSource(),
|
||
c = this.getTransform(e, 0), p = i.extent, d = void 0 !== p;
|
||
d && this.clip(t, e, p);
|
||
var f = this.replayGroup_;
|
||
if (f && !f.isEmpty()) {
|
||
this.declutterTree_ && this.declutterTree_.clear();
|
||
var g, m = this.getLayer(), y = 0, v = 0, _ = 1 !== i.opacity, x = m.hasListener(eo.RENDER);
|
||
if (_ || x) {
|
||
var w = t.canvas.width, b = t.canvas.height;
|
||
if (l) {
|
||
var C = Math.round(Math.sqrt(w * w + b * b));
|
||
y = (C - w) / 2, v = (C - b) / 2, w = b = C
|
||
}
|
||
this.context.canvas.width = w, this.context.canvas.height = b, g = this.context
|
||
} else g = t;
|
||
var S = g.globalAlpha;
|
||
_ || (g.globalAlpha = i.opacity), g != t && g.translate(y, v);
|
||
var E = e.viewHints, T = !(E[$n.ANIMATING] || E[$n.INTERACTING]), R = e.size[0] * o,
|
||
P = e.size[1] * o;
|
||
if (Ba(g, -l, R / 2, P / 2), f.replay(g, c, l, n, T), u.getWrapX() && a.canWrapX() && !dt(h, r)) {
|
||
for (var L, I = r[0], O = Ut(h), M = 0; I < h[0];) L = O * --M, c = this.getTransform(e, L), f.replay(g, c, l, n, T), I += O;
|
||
for (M = 0, I = r[2]; I > h[2];) L = O * ++M, c = this.getTransform(e, L), f.replay(g, c, l, n, T), I -= O
|
||
}
|
||
if (Ba(g, l, R / 2, P / 2), x && this.dispatchRenderEvent(g, e, c), g != t) {
|
||
if (_) {
|
||
var A = t.globalAlpha;
|
||
t.globalAlpha = i.opacity, t.drawImage(g.canvas, -y, -v), t.globalAlpha = A
|
||
} else t.drawImage(g.canvas, -y, -v);
|
||
g.translate(-y, -v)
|
||
}
|
||
_ || (g.globalAlpha = S)
|
||
}
|
||
d && t.restore()
|
||
}, e.prototype.composeFrame = function (t, e, i) {
|
||
var r = this.getTransform(t, 0);
|
||
this.preCompose(i, t, r), this.compose(i, t, e), this.postCompose(i, t, e, r)
|
||
}, e.prototype.forEachFeatureAtCoordinate = function (t, e, i, r, o) {
|
||
if (this.replayGroup_) {
|
||
var n = e.viewState.resolution, s = e.viewState.rotation, l = this.getLayer(), h = {};
|
||
return this.replayGroup_.forEachFeatureAtCoordinate(t, n, s, i, {}, function (t) {
|
||
var e = a(t);
|
||
if (!(e in h)) return h[e] = !0, r.call(o, t, l)
|
||
}, null)
|
||
}
|
||
}, e.prototype.handleFontsChanged_ = function (t) {
|
||
var e = this.getLayer();
|
||
e.getVisible() && this.replayGroup_ && e.changed()
|
||
}, e.prototype.handleStyleImageChange_ = function (t) {
|
||
this.renderIfReadyAndVisible()
|
||
}, e.prototype.prepareFrame = function (t, e) {
|
||
var i = this.getLayer(), r = i.getSource(), o = t.viewHints[$n.ANIMATING],
|
||
n = t.viewHints[$n.INTERACTING], s = i.getUpdateWhileAnimating(), a = i.getUpdateWhileInteracting();
|
||
if (!this.dirty_ && !s && o || !a && n) return !0;
|
||
var l = t.extent, h = t.viewState, u = h.projection, c = h.resolution, p = t.pixelRatio,
|
||
d = i.getRevision(), f = i.getRenderBuffer(), g = i.getRenderOrder();
|
||
void 0 === g && (g = Hl);
|
||
var m = ht(l, f * c), y = h.projection.getExtent();
|
||
if (r.getWrapX() && h.projection.canWrapX() && !dt(y, t.extent)) {
|
||
var v = Ut(y), _ = Math.max(Ut(m) / 2, v);
|
||
m[0] = y[0] - _, m[2] = y[2] + _
|
||
}
|
||
if (!this.dirty_ && this.renderedResolution_ == c && this.renderedRevision_ == d && this.renderedRenderOrder_ == g && dt(this.renderedExtent_, m)) return this.replayGroupChanged = !1, !0;
|
||
this.replayGroup_ = null, this.dirty_ = !1;
|
||
var x = new Vl(ql(c, p), m, c, p, r.getOverlaps(), this.declutterTree_, i.getRenderBuffer());
|
||
r.loadFeatures(m, c, u);
|
||
var w = function (t) {
|
||
var e, r = t.getStyleFunction() || i.getStyleFunction();
|
||
if (r && (e = r(t, c)), e) {
|
||
var o = this.renderFeature(t, c, p, e, x);
|
||
this.dirty_ = this.dirty_ || o
|
||
}
|
||
}.bind(this);
|
||
if (g) {
|
||
var b = [];
|
||
r.forEachFeatureInExtent(m, function (t) {
|
||
b.push(t)
|
||
}), b.sort(g);
|
||
for (var C = 0, S = b.length; C < S; ++C) w(b[C])
|
||
} else r.forEachFeatureInExtent(m, w);
|
||
return x.finish(), this.renderedResolution_ = c, this.renderedRevision_ = d, this.renderedRenderOrder_ = g, this.renderedExtent_ = m, this.replayGroup_ = x, this.replayGroupChanged = !0, !0
|
||
}, e.prototype.renderFeature = function (t, e, i, r, o) {
|
||
if (!r) return !1;
|
||
var n = !1;
|
||
if (Array.isArray(r)) for (var s = 0, a = r.length; s < a; ++s) n = Zl(o, t, r[s], Xl(e, i), this.handleStyleImageChange_, this) || n; else n = Zl(o, t, r, Xl(e, i), this.handleStyleImageChange_, this);
|
||
return n
|
||
}, e
|
||
}(sl);
|
||
Kl.handles = function (t) {
|
||
return t.getType() === Vo.VECTOR
|
||
}, Kl.create = function (t, e) {
|
||
return new Kl(e)
|
||
};
|
||
var Jl = Kl, $l = {IMAGE: "image", HYBRID: "hybrid", VECTOR: "vector"}, Ql = {
|
||
image: [_l.POLYGON, _l.CIRCLE, _l.LINE_STRING, _l.IMAGE, _l.TEXT],
|
||
hybrid: [_l.POLYGON, _l.LINE_STRING]
|
||
}, th = {image: [_l.DEFAULT], hybrid: [_l.IMAGE, _l.TEXT, _l.DEFAULT], vector: Rl}, eh = function (t) {
|
||
function e(e) {
|
||
t.call(this, e, !0), this.declutterTree_ = e.getDeclutter() ? ml()(9, void 0) : null, this.dirty_ = !1, this.renderedLayerRevision_, this.tmpTransform_ = [1, 0, 0, 1, 0, 0];
|
||
var i = e.getRenderMode();
|
||
this.zDirection = i === $l.VECTOR ? 1 : 0, i !== $l.VECTOR && (this.context = Ao()), w(Ma, F.CLEAR, this.handleFontsChanged_, this)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.disposeInternal = function () {
|
||
C(Ma, F.CLEAR, this.handleFontsChanged_, this), t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.getTile = function (e, i, r, o, n) {
|
||
var s = t.prototype.getTile.call(this, e, i, r, o, n);
|
||
return s.getState() === Ro.LOADED && (this.createReplayGroup_(s, o, n), this.context && this.renderTileImage_(s, o, n)), s
|
||
}, e.prototype.getTileImage = function (t) {
|
||
var e = this.getLayer();
|
||
return t.getImage(e)
|
||
}, e.prototype.prepareFrame = function (e, i) {
|
||
var r = this.getLayer().getRevision();
|
||
return this.renderedLayerRevision_ != r && (this.renderedTiles.length = 0), this.renderedLayerRevision_ = r, t.prototype.prepareFrame.call(this, e, i)
|
||
}, e.prototype.createReplayGroup_ = function (t, e, i) {
|
||
var r = this, o = this.getLayer(), n = o.getRevision(), s = o.getRenderOrder() || null,
|
||
a = t.getReplayState(o);
|
||
if (a.dirty || a.renderedRevision != n || a.renderedRenderOrder != s) {
|
||
for (var l = o.getSource(), h = l.getTileGrid(), u = l.getTileGridForProjection(i).getResolution(t.tileCoord[0]), c = t.extent, p = function (n, p) {
|
||
var d = t.getTile(t.tileKeys[n]);
|
||
if (d.getState() == Ro.LOADED) {
|
||
var f = d.tileCoord, g = h.getTileCoordExtent(f), m = Dt(c, g),
|
||
y = bt(g, m) ? null : ht(m, o.getRenderBuffer() * u, r.tmpExtent),
|
||
v = d.getProjection(), _ = !1;
|
||
Qe(i, v) || (_ = !0, d.setProjection(i)), a.dirty = !1;
|
||
var x = new Vl(0, m, u, e, l.getOverlaps(), r.declutterTree_, o.getRenderBuffer()),
|
||
w = Xl(u, e), b = function (t) {
|
||
var e, i = t.getStyleFunction() || o.getStyleFunction();
|
||
if (i && (e = i(t, u)), e) {
|
||
var r = this.renderFeature(t, w, e, x);
|
||
this.dirty_ = this.dirty_ || r, a.dirty = a.dirty || r
|
||
}
|
||
}, C = d.getFeatures();
|
||
s && s !== a.renderedRenderOrder && C.sort(s);
|
||
for (var S = 0, E = C.length; S < E; ++S) {
|
||
var T = C[S];
|
||
_ && (v.getUnits() == ve.TILE_PIXELS && (v.setWorldExtent(g), v.setExtent(d.getExtent())), T.getGeometry().transform(v, i)), y && !Bt(y, T.getGeometry().getExtent()) || b.call(r, T)
|
||
}
|
||
x.finish(), d.setReplayGroup(o, t.tileCoord.toString(), x)
|
||
}
|
||
}, d = 0, f = t.tileKeys.length; d < f; ++d) p(d);
|
||
a.renderedRevision = n, a.renderedRenderOrder = s
|
||
}
|
||
}, e.prototype.forEachFeatureAtCoordinate = function (t, e, i, r, o) {
|
||
var n = e.viewState.resolution, s = e.viewState.rotation;
|
||
i = null == i ? 0 : i;
|
||
var l, h, u, c, p = this.getLayer(), d = {}, f = this.renderedTiles;
|
||
for (u = 0, c = f.length; u < c; ++u) {
|
||
var g = f[u];
|
||
if (pt(l = ht(g.extent, i * n, l), t)) for (var m = 0, y = g.tileKeys.length; m < y; ++m) {
|
||
var v = g.getTile(g.tileKeys[m]);
|
||
if (v.getState() == Ro.LOADED) {
|
||
var _ = v.getReplayGroup(p, g.tileCoord.toString());
|
||
h = h || _.forEachFeatureAtCoordinate(t, n, s, i, {}, function (t) {
|
||
var e = a(t);
|
||
if (!(e in d)) return d[e] = !0, r.call(o, t, p)
|
||
}, null)
|
||
}
|
||
}
|
||
}
|
||
return h
|
||
}, e.prototype.getReplayTransform_ = function (t, e) {
|
||
var i = this.getLayer().getSource().getTileGrid(), r = t.tileCoord, o = i.getResolution(r[0]),
|
||
n = e.viewState, s = e.pixelRatio, a = n.resolution / s,
|
||
l = i.getTileCoordExtent(r, this.tmpExtent), h = n.center, u = jt(l), c = e.size,
|
||
p = Math.round(s * c[0] / 2), d = Math.round(s * c[1] / 2);
|
||
return gi(this.tmpTransform_, p, d, o / a, o / a, n.rotation, (u[0] - h[0]) / o, (h[1] - u[1]) / o)
|
||
}, e.prototype.handleFontsChanged_ = function (t) {
|
||
var e = this.getLayer();
|
||
e.getVisible() && void 0 !== this.renderedLayerRevision_ && e.changed()
|
||
}, e.prototype.handleStyleImageChange_ = function (t) {
|
||
this.renderIfReadyAndVisible()
|
||
}, e.prototype.postCompose = function (e, i, r) {
|
||
var o = this.getLayer(), n = o.getRenderMode();
|
||
if (n != $l.IMAGE) {
|
||
var s, a, l = o.getDeclutter() ? {} : null, h = o.getSource(), u = th[n], c = i.pixelRatio,
|
||
p = i.viewState.rotation, d = i.size;
|
||
p && Ba(e, -p, s = Math.round(c * d[0] / 2), a = Math.round(c * d[1] / 2)), l && this.declutterTree_.clear();
|
||
for (var f = i.viewHints, g = !(f[$n.ANIMATING] || f[$n.INTERACTING]), m = this.renderedTiles, y = h.getTileGridForProjection(i.viewState.projection), v = [], _ = [], x = m.length - 1; x >= 0; --x) {
|
||
var w = m[x];
|
||
if (w.getState() != Ro.ABORT) for (var b = w.tileCoord, C = y.getTileCoordExtent(b, this.tmpExtent)[0] - w.extent[0], S = void 0, E = 0, T = w.tileKeys.length; E < T; ++E) {
|
||
var R = w.getTile(w.tileKeys[E]);
|
||
if (R.getState() == Ro.LOADED) {
|
||
var P = R.getReplayGroup(o, b.toString());
|
||
if (P && P.hasReplays(u)) {
|
||
S || (S = this.getTransform(i, C));
|
||
var L = R.tileCoord[0], I = P.getClipCoords(S);
|
||
e.save(), e.globalAlpha = r.opacity;
|
||
for (var O = 0, M = v.length; O < M; ++O) {
|
||
var A = v[O];
|
||
L < _[O] && (e.beginPath(), e.moveTo(I[0], I[1]), e.lineTo(I[2], I[3]), e.lineTo(I[4], I[5]), e.lineTo(I[6], I[7]), e.moveTo(A[6], A[7]), e.lineTo(A[4], A[5]), e.lineTo(A[2], A[3]), e.lineTo(A[0], A[1]), e.clip())
|
||
}
|
||
P.replay(e, S, p, {}, g, u, l), e.restore(), v.push(I), _.push(L)
|
||
}
|
||
}
|
||
}
|
||
}
|
||
l && Bl(l, e, p, g), p && Ba(e, p, s, a)
|
||
}
|
||
t.prototype.postCompose.call(this, e, i, r)
|
||
}, e.prototype.renderFeature = function (t, e, i, r) {
|
||
if (!i) return !1;
|
||
var o = !1;
|
||
if (Array.isArray(i)) for (var n = 0, s = i.length; n < s; ++n) o = Zl(r, t, i[n], e, this.handleStyleImageChange_, this) || o; else o = Zl(r, t, i, e, this.handleStyleImageChange_, this);
|
||
return o
|
||
}, e.prototype.renderTileImage_ = function (t, e, i) {
|
||
var r = this.getLayer(), o = t.getReplayState(r), n = r.getRevision(), s = Ql[r.getRenderMode()];
|
||
if (s && o.renderedTileRevision !== n) {
|
||
o.renderedTileRevision = n;
|
||
var a = t.wrappedTileCoord, l = a[0], h = r.getSource(), u = h.getTileGridForProjection(i),
|
||
c = u.getResolution(l), p = t.getContext(r), d = h.getTilePixelSize(l, e, i);
|
||
p.canvas.width = d[0], p.canvas.height = d[1];
|
||
for (var f = u.getTileCoordExtent(a, this.tmpExtent), g = 0, m = t.tileKeys.length; g < m; ++g) {
|
||
var y = t.getTile(t.tileKeys[g]);
|
||
if (y.getState() == Ro.LOADED) {
|
||
var v = e / c, _ = ai(this.tmpTransform_);
|
||
di(_, v, -v), fi(_, -f[0], -f[3]), y.getReplayGroup(r, t.tileCoord.toString()).replay(p, _, 0, {}, !0, s)
|
||
}
|
||
}
|
||
}
|
||
}, e
|
||
}(fl);
|
||
eh.handles = function (t) {
|
||
return t.getType() === Vo.VECTOR_TILE
|
||
}, eh.create = function (t, e) {
|
||
return new eh(e)
|
||
};
|
||
var ih = eh, rh = function (t) {
|
||
function e(e) {
|
||
(e = p({}, e)).controls || (e.controls = Ms()), e.interactions || (e.interactions = Ca()), t.call(this, e)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.createRenderer = function () {
|
||
var t = new rl(this);
|
||
return t.registerLayerRenderers([hl, fl, Jl, ih]), t
|
||
}, e
|
||
}(ms), oh = {
|
||
BOTTOM_LEFT: "bottom-left",
|
||
BOTTOM_CENTER: "bottom-center",
|
||
BOTTOM_RIGHT: "bottom-right",
|
||
CENTER_LEFT: "center-left",
|
||
CENTER_CENTER: "center-center",
|
||
CENTER_RIGHT: "center-right",
|
||
TOP_LEFT: "top-left",
|
||
TOP_CENTER: "top-center",
|
||
TOP_RIGHT: "top-right"
|
||
}, nh = {ELEMENT: "element", MAP: "map", OFFSET: "offset", POSITION: "position", POSITIONING: "positioning"},
|
||
sh = function (t) {
|
||
function e(e) {
|
||
t.call(this), this.options = e, this.id = e.id, this.insertFirst = void 0 === e.insertFirst || e.insertFirst, this.stopEvent = void 0 === e.stopEvent || e.stopEvent, this.element = document.createElement("div"), this.element.className = void 0 !== e.className ? e.className : "ol-overlay-container " + _s, this.element.style.position = "absolute", this.autoPan = void 0 !== e.autoPan && e.autoPan, this.autoPanAnimation = e.autoPanAnimation || {}, this.autoPanMargin = void 0 !== e.autoPanMargin ? e.autoPanMargin : 20, this.rendered = {
|
||
bottom_: "",
|
||
left_: "",
|
||
right_: "",
|
||
top_: "",
|
||
visible: !0
|
||
}, this.mapPostrenderListenerKey = null, w(this, z(nh.ELEMENT), this.handleElementChanged, this), w(this, z(nh.MAP), this.handleMapChanged, this), w(this, z(nh.OFFSET), this.handleOffsetChanged, this), w(this, z(nh.POSITION), this.handlePositionChanged, this), w(this, z(nh.POSITIONING), this.handlePositioningChanged, this), void 0 !== e.element && this.setElement(e.element), this.setOffset(void 0 !== e.offset ? e.offset : [0, 0]), this.setPositioning(void 0 !== e.positioning ? e.positioning : oh.TOP_LEFT), void 0 !== e.position && this.setPosition(e.position)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getElement = function () {
|
||
return this.get(nh.ELEMENT)
|
||
}, e.prototype.getId = function () {
|
||
return this.id
|
||
}, e.prototype.getMap = function () {
|
||
return this.get(nh.MAP)
|
||
}, e.prototype.getOffset = function () {
|
||
return this.get(nh.OFFSET)
|
||
}, e.prototype.getPosition = function () {
|
||
return this.get(nh.POSITION)
|
||
}, e.prototype.getPositioning = function () {
|
||
return this.get(nh.POSITIONING)
|
||
}, e.prototype.handleElementChanged = function () {
|
||
Go(this.element);
|
||
var t = this.getElement();
|
||
t && this.element.appendChild(t)
|
||
}, e.prototype.handleMapChanged = function () {
|
||
this.mapPostrenderListenerKey && (Do(this.element), S(this.mapPostrenderListenerKey), this.mapPostrenderListenerKey = null);
|
||
var t = this.getMap();
|
||
if (t) {
|
||
this.mapPostrenderListenerKey = w(t, Dn.POSTRENDER, this.render, this), this.updatePixelPosition();
|
||
var e = this.stopEvent ? t.getOverlayContainerStopEvent() : t.getOverlayContainer();
|
||
this.insertFirst ? e.insertBefore(this.element, e.childNodes[0] || null) : e.appendChild(this.element)
|
||
}
|
||
}, e.prototype.render = function () {
|
||
this.updatePixelPosition()
|
||
}, e.prototype.handleOffsetChanged = function () {
|
||
this.updatePixelPosition()
|
||
}, e.prototype.handlePositionChanged = function () {
|
||
this.updatePixelPosition(), this.get(nh.POSITION) && this.autoPan && this.panIntoView()
|
||
}, e.prototype.handlePositioningChanged = function () {
|
||
this.updatePixelPosition()
|
||
}, e.prototype.setElement = function (t) {
|
||
this.set(nh.ELEMENT, t)
|
||
}, e.prototype.setMap = function (t) {
|
||
this.set(nh.MAP, t)
|
||
}, e.prototype.setOffset = function (t) {
|
||
this.set(nh.OFFSET, t)
|
||
}, e.prototype.setPosition = function (t) {
|
||
this.set(nh.POSITION, t)
|
||
}, e.prototype.panIntoView = function () {
|
||
var t = this.getMap();
|
||
if (t && t.getTargetElement()) {
|
||
var e = this.getRect(t.getTargetElement(), t.getSize()), i = this.getElement(),
|
||
r = this.getRect(i, [ko(i), Fo(i)]), o = this.autoPanMargin;
|
||
if (!dt(e, r)) {
|
||
var n = r[0] - e[0], s = e[2] - r[2], a = r[1] - e[1], l = e[3] - r[3], h = [0, 0];
|
||
if (n < 0 ? h[0] = n - o : s < 0 && (h[0] = Math.abs(s) + o), a < 0 ? h[1] = a - o : l < 0 && (h[1] = Math.abs(l) + o), 0 !== h[0] || 0 !== h[1]) {
|
||
var u = t.getView().getCenter(), c = t.getPixelFromCoordinate(u),
|
||
p = [c[0] + h[0], c[1] + h[1]];
|
||
t.getView().animate({
|
||
center: t.getCoordinateFromPixel(p),
|
||
duration: this.autoPanAnimation.duration,
|
||
easing: this.autoPanAnimation.easing
|
||
})
|
||
}
|
||
}
|
||
}
|
||
}, e.prototype.getRect = function (t, e) {
|
||
var i = t.getBoundingClientRect(), r = i.left + window.pageXOffset, o = i.top + window.pageYOffset;
|
||
return [r, o, r + e[0], o + e[1]]
|
||
}, e.prototype.setPositioning = function (t) {
|
||
this.set(nh.POSITIONING, t)
|
||
}, e.prototype.setVisible = function (t) {
|
||
this.rendered.visible !== t && (this.element.style.display = t ? "" : "none", this.rendered.visible = t)
|
||
}, e.prototype.updatePixelPosition = function () {
|
||
var t = this.getMap(), e = this.getPosition();
|
||
if (t && t.isRendered() && e) {
|
||
var i = t.getPixelFromCoordinate(e), r = t.getSize();
|
||
this.updateRenderedPosition(i, r)
|
||
} else this.setVisible(!1)
|
||
}, e.prototype.updateRenderedPosition = function (t, e) {
|
||
var i = this.element.style, r = this.getOffset(), o = this.getPositioning();
|
||
this.setVisible(!0);
|
||
var n = r[0], s = r[1];
|
||
if (o == oh.BOTTOM_RIGHT || o == oh.CENTER_RIGHT || o == oh.TOP_RIGHT) {
|
||
"" !== this.rendered.left_ && (this.rendered.left_ = i.left = "");
|
||
var a = Math.round(e[0] - t[0] - n) + "px";
|
||
this.rendered.right_ != a && (this.rendered.right_ = i.right = a)
|
||
} else {
|
||
"" !== this.rendered.right_ && (this.rendered.right_ = i.right = ""), o != oh.BOTTOM_CENTER && o != oh.CENTER_CENTER && o != oh.TOP_CENTER || (n -= this.element.offsetWidth / 2);
|
||
var l = Math.round(t[0] + n) + "px";
|
||
this.rendered.left_ != l && (this.rendered.left_ = i.left = l)
|
||
}
|
||
if (o == oh.BOTTOM_LEFT || o == oh.BOTTOM_CENTER || o == oh.BOTTOM_RIGHT) {
|
||
"" !== this.rendered.top_ && (this.rendered.top_ = i.top = "");
|
||
var h = Math.round(e[1] - t[1] - s) + "px";
|
||
this.rendered.bottom_ != h && (this.rendered.bottom_ = i.bottom = h)
|
||
} else {
|
||
"" !== this.rendered.bottom_ && (this.rendered.bottom_ = i.bottom = ""), o != oh.CENTER_LEFT && o != oh.CENTER_CENTER && o != oh.CENTER_RIGHT || (s -= this.element.offsetHeight / 2);
|
||
var u = Math.round(t[1] + s) + "px";
|
||
this.rendered.top_ != u && (this.rendered.top_ = i.top = u)
|
||
}
|
||
}, e.prototype.getOptions = function () {
|
||
return this.options
|
||
}, e
|
||
}(U);
|
||
|
||
function ah(t, e, i, r) {
|
||
return void 0 !== r ? (r[0] = t, r[1] = e, r[2] = i, r) : [t, e, i]
|
||
}
|
||
|
||
function lh(t, e, i) {
|
||
return t + "/" + e + "/" + i
|
||
}
|
||
|
||
function hh(t) {
|
||
return lh(t[0], t[1], t[2])
|
||
}
|
||
|
||
function uh(t) {
|
||
return t.split("/").map(Number)
|
||
}
|
||
|
||
function ch(t) {
|
||
return (t[1] << t[0]) + t[2]
|
||
}
|
||
|
||
function ph(t) {
|
||
var e, i, r = t[0], o = new Array(r), n = 1 << r - 1;
|
||
for (e = 0; e < r; ++e) i = 48, t[1] & n && (i += 1), t[2] & n && (i += 2), o[e] = String.fromCharCode(i), n >>= 1;
|
||
return o.join("")
|
||
}
|
||
|
||
function dh(t, e) {
|
||
var i = t[0], r = t[1], o = t[2];
|
||
if (e.getMinZoom() > i || i > e.getMaxZoom()) return !1;
|
||
var n, s = e.getExtent();
|
||
return !(n = s ? e.getTileRangeForExtentAndZ(s, i) : e.getFullTileRange(i)) || n.containsXY(r, o)
|
||
}
|
||
|
||
var fh = function (t) {
|
||
function e(e) {
|
||
t.call(this, e)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.expireCache = function (t) {
|
||
for (; this.canExpireCache();) {
|
||
var e = this.peekLast(), i = e.tileCoord[0].toString();
|
||
if (i in t && t[i].contains(e.tileCoord)) break;
|
||
this.pop().dispose()
|
||
}
|
||
}, e.prototype.pruneExceptNewestZ = function () {
|
||
if (0 !== this.getCount()) {
|
||
var t = uh(this.peekFirstKey())[0];
|
||
this.forEach(function (e) {
|
||
e.tileCoord[0] !== t && (this.remove(hh(e.tileCoord)), e.dispose())
|
||
}, this)
|
||
}
|
||
}, e
|
||
}(Ra), gh = {ARRAY_BUFFER: "arraybuffer", JSON: "json", TEXT: "text", XML: "xml"};
|
||
|
||
function mh(t, e, i, r) {
|
||
return function (o, n, s) {
|
||
var a = new XMLHttpRequest;
|
||
a.open("GET", "function" == typeof t ? t(o, n, s) : t, !0), e.getType() == gh.ARRAY_BUFFER && (a.responseType = "arraybuffer"), a.onload = function (t) {
|
||
if (!a.status || a.status >= 200 && a.status < 300) {
|
||
var o, n = e.getType();
|
||
n == gh.JSON || n == gh.TEXT ? o = a.responseText : n == gh.XML ? (o = a.responseXML) || (o = (new DOMParser).parseFromString(a.responseText, "application/xml")) : n == gh.ARRAY_BUFFER && (o = a.response), o ? i.call(this, e.readFeatures(o, {featureProjection: s}), e.readProjection(o), e.getLastExtent()) : r.call(this)
|
||
} else r.call(this)
|
||
}.bind(this), a.onerror = function () {
|
||
r.call(this)
|
||
}.bind(this), a.send()
|
||
}
|
||
}
|
||
|
||
function yh(t, e) {
|
||
return mh(t, e, function (t, e) {
|
||
"function" == typeof this.addFeatures && this.addFeatures(t)
|
||
}, I)
|
||
}
|
||
|
||
var vh = function (t) {
|
||
function e(i, r, o, n, s, a, l, h, u, c, p, d, f, g, m) {
|
||
if (t.call(this, i, r, {transition: 0}), this.context_ = {}, this.loader_, this.replayState_ = {}, this.sourceTiles_ = c, this.tileKeys = [], this.extent = null, this.sourceRevision_ = o, this.wrappedTileCoord = a, this.loadListenerKeys_ = [], this.sourceTileListenerKeys_ = [], a) {
|
||
var y = this.extent = u.getTileCoordExtent(a), v = u.getResolution(m), _ = h.getZForResolution(v),
|
||
x = m != i[0], b = 0;
|
||
if (h.forEachTileCoord(y, _, function (t) {
|
||
var e = Dt(y, h.getTileCoordExtent(t)), i = h.getExtent();
|
||
if (i && (e = Dt(e, i, e)), Ut(e) / v >= .5 && Nt(e) / v >= .5) {
|
||
++b;
|
||
var r = t.toString(), o = c[r];
|
||
if (!o && !x) {
|
||
var a = l(t, p, d);
|
||
o = c[r] = new f(t, null == a ? Ro.EMPTY : Ro.IDLE, null == a ? "" : a, n, s), this.sourceTileListenerKeys_.push(w(o, F.CHANGE, g))
|
||
}
|
||
!o || x && o.getState() != Ro.LOADED || (o.consumers++, this.tileKeys.push(r))
|
||
}
|
||
}.bind(this)), x && b == this.tileKeys.length && this.finishLoading_(), m <= i[0] && this.state != Ro.LOADED) for (; m > u.getMinZoom();) {
|
||
var C = new e(i, r, o, n, s, a, l, h, u, c, p, d, f, I, --m);
|
||
if (C.state == Ro.LOADED) {
|
||
this.interimTile = C;
|
||
break
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.disposeInternal = function () {
|
||
this.state = Ro.ABORT, this.changed(), this.interimTile && this.interimTile.dispose();
|
||
for (var e = 0, i = this.tileKeys.length; e < i; ++e) {
|
||
var r = this.tileKeys[e], o = this.getTile(r);
|
||
o.consumers--, 0 == o.consumers && (delete this.sourceTiles_[r], o.dispose())
|
||
}
|
||
this.tileKeys.length = 0, this.sourceTiles_ = null, this.loadListenerKeys_.forEach(S), this.loadListenerKeys_.length = 0, this.sourceTileListenerKeys_.forEach(S), this.sourceTileListenerKeys_.length = 0, t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.getContext = function (t) {
|
||
var e = a(t);
|
||
return e in this.context_ || (this.context_[e] = Ao()), this.context_[e]
|
||
}, e.prototype.getImage = function (t) {
|
||
return -1 == this.getReplayState(t).renderedTileRevision ? null : this.getContext(t).canvas
|
||
}, e.prototype.getReplayState = function (t) {
|
||
var e = a(t);
|
||
return e in this.replayState_ || (this.replayState_[e] = {
|
||
dirty: !1,
|
||
renderedRenderOrder: null,
|
||
renderedRevision: -1,
|
||
renderedTileRevision: -1
|
||
}), this.replayState_[e]
|
||
}, e.prototype.getKey = function () {
|
||
return this.tileKeys.join("/") + "-" + this.sourceRevision_
|
||
}, e.prototype.getTile = function (t) {
|
||
return this.sourceTiles_[t]
|
||
}, e.prototype.load = function () {
|
||
var t = 0, e = {};
|
||
this.state == Ro.IDLE && this.setState(Ro.LOADING), this.state == Ro.LOADING && this.tileKeys.forEach(function (i) {
|
||
var r = this.getTile(i);
|
||
if (r.state == Ro.IDLE && (r.setLoader(this.loader_), r.load()), r.state == Ro.LOADING) {
|
||
var o = w(r, F.CHANGE, function (i) {
|
||
var o = r.getState();
|
||
if (o == Ro.LOADED || o == Ro.ERROR) {
|
||
var n = a(r);
|
||
o == Ro.ERROR ? e[n] = !0 : (--t, delete e[n]), t - Object.keys(e).length == 0 && this.finishLoading_()
|
||
}
|
||
}.bind(this));
|
||
this.loadListenerKeys_.push(o), ++t
|
||
}
|
||
}.bind(this)), t - Object.keys(e).length == 0 && setTimeout(this.finishLoading_.bind(this), 0)
|
||
}, e.prototype.finishLoading_ = function () {
|
||
for (var t = this.tileKeys.length, e = 0, i = t - 1; i >= 0; --i) {
|
||
var r = this.getTile(this.tileKeys[i]).getState();
|
||
r != Ro.LOADED && --t, r == Ro.EMPTY && ++e
|
||
}
|
||
t == this.tileKeys.length ? (this.loadListenerKeys_.forEach(S), this.loadListenerKeys_.length = 0, this.setState(Ro.LOADED)) : this.setState(e == this.tileKeys.length ? Ro.EMPTY : Ro.ERROR)
|
||
}, e
|
||
}(Mo);
|
||
|
||
function _h(t, e) {
|
||
var i = mh(e, t.getFormat(), t.onLoad.bind(t), t.onError.bind(t));
|
||
t.setLoader(i)
|
||
}
|
||
|
||
var xh = [0, 0, 4096, 4096], wh = function (t) {
|
||
function e(e, i, r, o, n, s) {
|
||
t.call(this, e, i, s), this.consumers = 0, this.extent_ = null, this.format_ = o, this.features_ = null, this.loader_, this.projection_ = null, this.replayGroups_ = {}, this.tileLoadFunction_ = n, this.url_ = r
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.disposeInternal = function () {
|
||
this.features_ = null, this.replayGroups_ = {}, this.state = Ro.ABORT, this.changed(), t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.getExtent = function () {
|
||
return this.extent_ || xh
|
||
}, e.prototype.getFormat = function () {
|
||
return this.format_
|
||
}, e.prototype.getFeatures = function () {
|
||
return this.features_
|
||
}, e.prototype.getKey = function () {
|
||
return this.url_
|
||
}, e.prototype.getProjection = function () {
|
||
return this.projection_
|
||
}, e.prototype.getReplayGroup = function (t, e) {
|
||
return this.replayGroups_[a(t) + "," + e]
|
||
}, e.prototype.load = function () {
|
||
this.state == Ro.IDLE && (this.setState(Ro.LOADING), this.tileLoadFunction_(this, this.url_), this.loader_(null, NaN, null))
|
||
}, e.prototype.onLoad = function (t, e, i) {
|
||
this.setProjection(e), this.setFeatures(t), this.setExtent(i)
|
||
}, e.prototype.onError = function () {
|
||
this.setState(Ro.ERROR)
|
||
}, e.prototype.setExtent = function (t) {
|
||
this.extent_ = t
|
||
}, e.prototype.setFeatures = function (t) {
|
||
this.features_ = t, this.setState(Ro.LOADED)
|
||
}, e.prototype.setProjection = function (t) {
|
||
this.projection_ = t
|
||
}, e.prototype.setReplayGroup = function (t, e, i) {
|
||
this.replayGroups_[a(t) + "," + e] = i
|
||
}, e.prototype.setLoader = function (t) {
|
||
this.loader_ = t
|
||
}, e
|
||
}(Mo), bh = 9729, Ch = 10242, Sh = 10243, Eh = 3553,
|
||
Th = ["experimental-webgl", "webgl", "webkit-3d", "moz-webgl"];
|
||
|
||
function Rh(t, e) {
|
||
for (var i = Th.length, r = 0; r < i; ++r) try {
|
||
var o = t.getContext(Th[r], e);
|
||
if (o) return o
|
||
} catch (t) {
|
||
}
|
||
return null
|
||
}
|
||
|
||
var Ph, Lh;
|
||
if ("undefined" != typeof window && "WebGLRenderingContext" in window) try {
|
||
var Ih = Rh(document.createElement("canvas"), {failIfMajorPerformanceCaveat: !0});
|
||
Ih && (!0, Ph = Ih.getParameter(Ih.MAX_TEXTURE_SIZE), Lh = Ih.getSupportedExtensions())
|
||
} catch (t) {
|
||
}
|
||
var Oh = function (t) {
|
||
this.source_ = t
|
||
};
|
||
Oh.prototype.isAnimated = function () {
|
||
return !1
|
||
}, Oh.prototype.getType = function () {
|
||
return n()
|
||
}, Oh.prototype.getSource = function () {
|
||
return this.source_
|
||
};
|
||
var Mh = Oh, Ah = function (t) {
|
||
function e(e) {
|
||
t.call(this, e)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getType = function () {
|
||
return 35632
|
||
}, e
|
||
}(Mh), kh = function (t) {
|
||
function e(e) {
|
||
t.call(this, e)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getType = function () {
|
||
return 35633
|
||
}, e
|
||
}(Mh),
|
||
Fh = new Ah("precision mediump float;\nvarying vec2 v_center;\nvarying vec2 v_offset;\nvarying float v_halfWidth;\nvarying float v_pixelRatio;\n\n\n\nuniform float u_opacity;\nuniform vec4 u_fillColor;\nuniform vec4 u_strokeColor;\nuniform vec2 u_size;\n\nvoid main(void) {\n vec2 windowCenter = vec2((v_center.x + 1.0) / 2.0 * u_size.x * v_pixelRatio,\n (v_center.y + 1.0) / 2.0 * u_size.y * v_pixelRatio);\n vec2 windowOffset = vec2((v_offset.x + 1.0) / 2.0 * u_size.x * v_pixelRatio,\n (v_offset.y + 1.0) / 2.0 * u_size.y * v_pixelRatio);\n float radius = length(windowCenter - windowOffset);\n float dist = length(windowCenter - gl_FragCoord.xy);\n if (dist > radius + v_halfWidth) {\n if (u_strokeColor.a == 0.0) {\n gl_FragColor = u_fillColor;\n } else {\n gl_FragColor = u_strokeColor;\n }\n gl_FragColor.a = gl_FragColor.a - (dist - (radius + v_halfWidth));\n } else if (u_fillColor.a == 0.0) {\n // Hooray, no fill, just stroke. We can use real antialiasing.\n gl_FragColor = u_strokeColor;\n if (dist < radius - v_halfWidth) {\n gl_FragColor.a = gl_FragColor.a - (radius - v_halfWidth - dist);\n }\n } else {\n gl_FragColor = u_fillColor;\n float strokeDist = radius - v_halfWidth;\n float antialias = 2.0 * v_pixelRatio;\n if (dist > strokeDist) {\n gl_FragColor = u_strokeColor;\n } else if (dist >= strokeDist - antialias) {\n float step = smoothstep(strokeDist - antialias, strokeDist, dist);\n gl_FragColor = mix(u_fillColor, u_strokeColor, step);\n }\n }\n gl_FragColor.a = gl_FragColor.a * u_opacity;\n if (gl_FragColor.a <= 0.0) {\n discard;\n }\n}\n"),
|
||
Nh = new kh("varying vec2 v_center;\nvarying vec2 v_offset;\nvarying float v_halfWidth;\nvarying float v_pixelRatio;\n\n\nattribute vec2 a_position;\nattribute float a_instruction;\nattribute float a_radius;\n\nuniform mat4 u_projectionMatrix;\nuniform mat4 u_offsetScaleMatrix;\nuniform mat4 u_offsetRotateMatrix;\nuniform float u_lineWidth;\nuniform float u_pixelRatio;\n\nvoid main(void) {\n mat4 offsetMatrix = u_offsetScaleMatrix * u_offsetRotateMatrix;\n v_center = vec4(u_projectionMatrix * vec4(a_position, 0.0, 1.0)).xy;\n v_pixelRatio = u_pixelRatio;\n float lineWidth = u_lineWidth * u_pixelRatio;\n v_halfWidth = lineWidth / 2.0;\n if (lineWidth == 0.0) {\n lineWidth = 2.0 * u_pixelRatio;\n }\n vec2 offset;\n // Radius with anitaliasing (roughly).\n float radius = a_radius + 3.0 * u_pixelRatio;\n // Until we get gl_VertexID in WebGL, we store an instruction.\n if (a_instruction == 0.0) {\n // Offsetting the edges of the triangle by lineWidth / 2 is necessary, however\n // we should also leave some space for the antialiasing, thus we offset by lineWidth.\n offset = vec2(-1.0, 1.0);\n } else if (a_instruction == 1.0) {\n offset = vec2(-1.0, -1.0);\n } else if (a_instruction == 2.0) {\n offset = vec2(1.0, -1.0);\n } else {\n offset = vec2(1.0, 1.0);\n }\n\n gl_Position = u_projectionMatrix * vec4(a_position + offset * radius, 0.0, 1.0) +\n offsetMatrix * vec4(offset * lineWidth, 0.0, 0.0);\n v_offset = vec4(u_projectionMatrix * vec4(a_position.x + a_radius, a_position.y,\n 0.0, 1.0)).xy;\n\n if (distance(v_center, v_offset) > 20000.0) {\n gl_Position = vec4(v_center, 0.0, 1.0);\n }\n}\n\n\n"),
|
||
Dh = function (t, e) {
|
||
this.u_projectionMatrix = t.getUniformLocation(e, "u_projectionMatrix"), this.u_offsetScaleMatrix = t.getUniformLocation(e, "u_offsetScaleMatrix"), this.u_offsetRotateMatrix = t.getUniformLocation(e, "u_offsetRotateMatrix"), this.u_lineWidth = t.getUniformLocation(e, "u_lineWidth"), this.u_pixelRatio = t.getUniformLocation(e, "u_pixelRatio"), this.u_opacity = t.getUniformLocation(e, "u_opacity"), this.u_fillColor = t.getUniformLocation(e, "u_fillColor"), this.u_strokeColor = t.getUniformLocation(e, "u_strokeColor"), this.u_size = t.getUniformLocation(e, "u_size"), this.a_position = t.getAttribLocation(e, "a_position"), this.a_instruction = t.getAttribLocation(e, "a_instruction"), this.a_radius = t.getAttribLocation(e, "a_radius")
|
||
};
|
||
|
||
function Gh() {
|
||
return [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]
|
||
}
|
||
|
||
function jh(t, e) {
|
||
return t[0] = e[0], t[1] = e[1], t[4] = e[2], t[5] = e[3], t[12] = e[4], t[13] = e[5], t
|
||
}
|
||
|
||
var zh = function (t) {
|
||
function e(e, i) {
|
||
t.call(this), this.tolerance = e, this.maxExtent = i, this.origin = At(i), this.projectionMatrix_ = [1, 0, 0, 1, 0, 0], this.offsetRotateMatrix_ = [1, 0, 0, 1, 0, 0], this.offsetScaleMatrix_ = [1, 0, 0, 1, 0, 0], this.tmpMat4_ = [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1], this.indices = [], this.indicesBuffer = null, this.startIndices = [], this.startIndicesFeature = [], this.vertices = [], this.verticesBuffer = null, this.lineStringReplay = void 0
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getDeleteResourcesFunction = function (t) {
|
||
return n()
|
||
}, e.prototype.finish = function (t) {
|
||
n()
|
||
}, e.prototype.setUpProgram = function (t, e, i, r) {
|
||
return n()
|
||
}, e.prototype.shutDownProgram = function (t, e) {
|
||
n()
|
||
}, e.prototype.drawReplay = function (t, e, i, r) {
|
||
n()
|
||
}, e.prototype.drawHitDetectionReplayOneByOne = function (t, e, i, r, o) {
|
||
return n()
|
||
}, e.prototype.drawHitDetectionReplay = function (t, e, i, r, o, n) {
|
||
return o ? this.drawHitDetectionReplayOneByOne(t, e, i, r, n) : this.drawHitDetectionReplayAll(t, e, i, r)
|
||
}, e.prototype.drawHitDetectionReplayAll = function (t, e, i, r) {
|
||
t.clear(t.COLOR_BUFFER_BIT | t.DEPTH_BUFFER_BIT), this.drawReplay(t, e, i, !0);
|
||
var o = r(null);
|
||
return o || void 0
|
||
}, e.prototype.replay = function (t, e, i, r, o, n, s, a, l, h, u) {
|
||
var c, p, d, f, g, m, y, v, _ = t.getGL();
|
||
this.lineStringReplay && (c = _.isEnabled(_.STENCIL_TEST), p = _.getParameter(_.STENCIL_FUNC), d = _.getParameter(_.STENCIL_VALUE_MASK), f = _.getParameter(_.STENCIL_REF), g = _.getParameter(_.STENCIL_WRITEMASK), m = _.getParameter(_.STENCIL_FAIL), y = _.getParameter(_.STENCIL_PASS_DEPTH_PASS), v = _.getParameter(_.STENCIL_PASS_DEPTH_FAIL), _.enable(_.STENCIL_TEST), _.clear(_.STENCIL_BUFFER_BIT), _.stencilMask(255), _.stencilFunc(_.ALWAYS, 1, 255), _.stencilOp(_.KEEP, _.KEEP, _.REPLACE), this.lineStringReplay.replay(t, e, i, r, o, n, s, a, l, h, u), _.stencilMask(0), _.stencilFunc(_.NOTEQUAL, 1, 255)), t.bindBuffer(34962, this.verticesBuffer), t.bindBuffer(34963, this.indicesBuffer);
|
||
var x = this.setUpProgram(_, t, o, n), w = ai(this.projectionMatrix_);
|
||
di(w, 2 / (i * o[0]), 2 / (i * o[1])), pi(w, -r), fi(w, -(e[0] - this.origin[0]), -(e[1] - this.origin[1]));
|
||
var b = ai(this.offsetScaleMatrix_);
|
||
di(b, 2 / o[0], 2 / o[1]);
|
||
var C, S = ai(this.offsetRotateMatrix_);
|
||
return 0 !== r && pi(S, -r), _.uniformMatrix4fv(x.u_projectionMatrix, !1, jh(this.tmpMat4_, w)), _.uniformMatrix4fv(x.u_offsetScaleMatrix, !1, jh(this.tmpMat4_, b)), _.uniformMatrix4fv(x.u_offsetRotateMatrix, !1, jh(this.tmpMat4_, S)), _.uniform1f(x.u_opacity, s), void 0 === l ? this.drawReplay(_, t, a, !1) : C = this.drawHitDetectionReplay(_, t, a, l, h, u), this.shutDownProgram(_, x), this.lineStringReplay && (c || _.disable(_.STENCIL_TEST), _.clear(_.STENCIL_BUFFER_BIT), _.stencilFunc(p, f, d), _.stencilMask(g), _.stencilOp(m, v, y)), C
|
||
}, e.prototype.drawElements = function (t, e, i, r) {
|
||
var o = e.hasOESElementIndexUint ? 5125 : 5123, n = r - i, s = i * (e.hasOESElementIndexUint ? 4 : 2);
|
||
t.drawElements(4, n, o, s)
|
||
}, e
|
||
}(Xa), Uh = [0, 0, 0, 1], Bh = [], Vh = [0, 0, 0, 1], Yh = Number.EPSILON || 2.220446049250313e-16,
|
||
Wh = function (t, e, i, r, o, n) {
|
||
var s = (i - t) * (n - e) - (o - t) * (r - e);
|
||
return s <= Yh && s >= -Yh ? void 0 : s > 0
|
||
}, Hh = 35044, Xh = function (t, e) {
|
||
this.arr_ = void 0 !== t ? t : [], this.usage_ = void 0 !== e ? e : Hh
|
||
};
|
||
Xh.prototype.getArray = function () {
|
||
return this.arr_
|
||
}, Xh.prototype.getUsage = function () {
|
||
return this.usage_
|
||
};
|
||
var qh = Xh, Zh = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e, i), this.defaultLocations_ = null, this.styles_ = [], this.styleIndices_ = [], this.radius_ = 0, this.state_ = {
|
||
fillColor: null,
|
||
strokeColor: null,
|
||
lineDash: null,
|
||
lineDashOffset: void 0,
|
||
lineWidth: void 0,
|
||
changed: !1
|
||
}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.drawCoordinates_ = function (t, e, i, r) {
|
||
var o, n, s = this.vertices.length, a = this.indices.length, l = s / 4;
|
||
for (o = e, n = i; o < n; o += r) this.vertices[s++] = t[o], this.vertices[s++] = t[o + 1], this.vertices[s++] = 0, this.vertices[s++] = this.radius_, this.vertices[s++] = t[o], this.vertices[s++] = t[o + 1], this.vertices[s++] = 1, this.vertices[s++] = this.radius_, this.vertices[s++] = t[o], this.vertices[s++] = t[o + 1], this.vertices[s++] = 2, this.vertices[s++] = this.radius_, this.vertices[s++] = t[o], this.vertices[s++] = t[o + 1], this.vertices[s++] = 3, this.vertices[s++] = this.radius_, this.indices[a++] = l, this.indices[a++] = l + 1, this.indices[a++] = l + 2, this.indices[a++] = l + 2, this.indices[a++] = l + 3, this.indices[a++] = l, l += 4
|
||
}, e.prototype.drawCircle = function (t, e) {
|
||
var i = t.getRadius(), r = t.getStride();
|
||
if (i) {
|
||
this.startIndices.push(this.indices.length), this.startIndicesFeature.push(e), this.state_.changed && (this.styleIndices_.push(this.indices.length), this.state_.changed = !1), this.radius_ = i;
|
||
var o = t.getFlatCoordinates();
|
||
o = Qt(o, 0, 2, r, -this.origin[0], -this.origin[1]), this.drawCoordinates_(o, 0, 2, r)
|
||
} else if (this.state_.changed && (this.styles_.pop(), this.styles_.length)) {
|
||
var n = this.styles_[this.styles_.length - 1];
|
||
this.state_.fillColor = n[0], this.state_.strokeColor = n[1], this.state_.lineWidth = n[2], this.state_.changed = !1
|
||
}
|
||
}, e.prototype.finish = function (t) {
|
||
this.verticesBuffer = new qh(this.vertices), this.indicesBuffer = new qh(this.indices), this.startIndices.push(this.indices.length), 0 === this.styleIndices_.length && this.styles_.length > 0 && (this.styles_ = []), this.vertices = null, this.indices = null
|
||
}, e.prototype.getDeleteResourcesFunction = function (t) {
|
||
var e = this.verticesBuffer, i = this.indicesBuffer;
|
||
return function () {
|
||
t.deleteBuffer(e), t.deleteBuffer(i)
|
||
}
|
||
}, e.prototype.setUpProgram = function (t, e, i, r) {
|
||
var o, n = e.getProgram(Fh, Nh);
|
||
return this.defaultLocations_ ? o = this.defaultLocations_ : (o = new Dh(t, n), this.defaultLocations_ = o), e.useProgram(n), t.enableVertexAttribArray(o.a_position), t.vertexAttribPointer(o.a_position, 2, 5126, !1, 16, 0), t.enableVertexAttribArray(o.a_instruction), t.vertexAttribPointer(o.a_instruction, 1, 5126, !1, 16, 8), t.enableVertexAttribArray(o.a_radius), t.vertexAttribPointer(o.a_radius, 1, 5126, !1, 16, 12), t.uniform2fv(o.u_size, i), t.uniform1f(o.u_pixelRatio, r), o
|
||
}, e.prototype.shutDownProgram = function (t, e) {
|
||
t.disableVertexAttribArray(e.a_position), t.disableVertexAttribArray(e.a_instruction), t.disableVertexAttribArray(e.a_radius)
|
||
}, e.prototype.drawReplay = function (t, e, i, r) {
|
||
var o, n, s, a;
|
||
if (g(i)) for (s = this.startIndices[this.startIndices.length - 1], o = this.styleIndices_.length - 1; o >= 0; --o) n = this.styleIndices_[o], a = this.styles_[o], this.setFillStyle_(t, a[0]), this.setStrokeStyle_(t, a[1], a[2]), this.drawElements(t, e, n, s), s = n; else this.drawReplaySkipping_(t, e, i)
|
||
}, e.prototype.drawHitDetectionReplayOneByOne = function (t, e, i, r, o) {
|
||
var n, s, l, h, u, c, p;
|
||
for (p = this.startIndices.length - 2, l = this.startIndices[p + 1], n = this.styleIndices_.length - 1; n >= 0; --n) for (h = this.styles_[n], this.setFillStyle_(t, h[0]), this.setStrokeStyle_(t, h[1], h[2]), u = this.styleIndices_[n]; p >= 0 && this.startIndices[p] >= u;) {
|
||
if (s = this.startIndices[p], void 0 === i[a(c = this.startIndicesFeature[p])] && c.getGeometry() && (void 0 === o || Bt(o, c.getGeometry().getExtent()))) {
|
||
t.clear(t.COLOR_BUFFER_BIT | t.DEPTH_BUFFER_BIT), this.drawElements(t, e, s, l);
|
||
var d = r(c);
|
||
if (d) return d
|
||
}
|
||
p--, l = s
|
||
}
|
||
}, e.prototype.drawReplaySkipping_ = function (t, e, i) {
|
||
var r, o, n, s, l, h, u;
|
||
for (h = this.startIndices.length - 2, n = o = this.startIndices[h + 1], r = this.styleIndices_.length - 1; r >= 0; --r) {
|
||
for (s = this.styles_[r], this.setFillStyle_(t, s[0]), this.setStrokeStyle_(t, s[1], s[2]), l = this.styleIndices_[r]; h >= 0 && this.startIndices[h] >= l;) u = this.startIndices[h], i[a(this.startIndicesFeature[h])] && (o !== n && this.drawElements(t, e, o, n), n = u), h--, o = u;
|
||
o !== n && this.drawElements(t, e, o, n), o = n = l
|
||
}
|
||
}, e.prototype.setFillStyle_ = function (t, e) {
|
||
t.uniform4fv(this.defaultLocations_.u_fillColor, e)
|
||
}, e.prototype.setStrokeStyle_ = function (t, e, i) {
|
||
t.uniform4fv(this.defaultLocations_.u_strokeColor, e), t.uniform1f(this.defaultLocations_.u_lineWidth, i)
|
||
}, e.prototype.setFillStrokeStyle = function (t, e) {
|
||
var i, r;
|
||
if (e) {
|
||
var o = e.getLineDash();
|
||
this.state_.lineDash = o || Bh;
|
||
var n = e.getLineDashOffset();
|
||
this.state_.lineDashOffset = n || 0, i = (i = e.getColor()) instanceof CanvasGradient || i instanceof CanvasPattern ? Vh : lo(i).map(function (t, e) {
|
||
return 3 != e ? t / 255 : t
|
||
}) || Vh, r = void 0 !== (r = e.getWidth()) ? r : 1
|
||
} else i = [0, 0, 0, 0], r = 0;
|
||
var s = t ? t.getColor() : [0, 0, 0, 0];
|
||
s = s instanceof CanvasGradient || s instanceof CanvasPattern ? Uh : lo(s).map(function (t, e) {
|
||
return 3 != e ? t / 255 : t
|
||
}) || Uh, this.state_.strokeColor && it(this.state_.strokeColor, i) && this.state_.fillColor && it(this.state_.fillColor, s) && this.state_.lineWidth === r || (this.state_.changed = !0, this.state_.fillColor = s, this.state_.strokeColor = i, this.state_.lineWidth = r, this.styles_.push([s, i, r]))
|
||
}, e
|
||
}(zh),
|
||
Kh = new Ah("precision mediump float;\nvarying vec2 v_texCoord;\nvarying float v_opacity;\n\nuniform float u_opacity;\nuniform sampler2D u_image;\n\nvoid main(void) {\n vec4 texColor = texture2D(u_image, v_texCoord);\n gl_FragColor.rgb = texColor.rgb;\n float alpha = texColor.a * v_opacity * u_opacity;\n if (alpha == 0.0) {\n discard;\n }\n gl_FragColor.a = alpha;\n}\n"),
|
||
Jh = new kh("varying vec2 v_texCoord;\nvarying float v_opacity;\n\nattribute vec2 a_position;\nattribute vec2 a_texCoord;\nattribute vec2 a_offsets;\nattribute float a_opacity;\nattribute float a_rotateWithView;\n\nuniform mat4 u_projectionMatrix;\nuniform mat4 u_offsetScaleMatrix;\nuniform mat4 u_offsetRotateMatrix;\n\nvoid main(void) {\n mat4 offsetMatrix = u_offsetScaleMatrix;\n if (a_rotateWithView == 1.0) {\n offsetMatrix = u_offsetScaleMatrix * u_offsetRotateMatrix;\n }\n vec4 offsets = offsetMatrix * vec4(a_offsets, 0.0, 0.0);\n gl_Position = u_projectionMatrix * vec4(a_position, 0.0, 1.0) + offsets;\n v_texCoord = a_texCoord;\n v_opacity = a_opacity;\n}\n\n\n"),
|
||
$h = function (t, e) {
|
||
this.u_projectionMatrix = t.getUniformLocation(e, "u_projectionMatrix"), this.u_offsetScaleMatrix = t.getUniformLocation(e, "u_offsetScaleMatrix"), this.u_offsetRotateMatrix = t.getUniformLocation(e, "u_offsetRotateMatrix"), this.u_opacity = t.getUniformLocation(e, "u_opacity"), this.u_image = t.getUniformLocation(e, "u_image"), this.a_position = t.getAttribLocation(e, "a_position"), this.a_texCoord = t.getAttribLocation(e, "a_texCoord"), this.a_offsets = t.getAttribLocation(e, "a_offsets"), this.a_opacity = t.getAttribLocation(e, "a_opacity"), this.a_rotateWithView = t.getAttribLocation(e, "a_rotateWithView")
|
||
}, Qh = {LOST: "webglcontextlost", RESTORED: "webglcontextrestored"};
|
||
|
||
function tu(t, e, i) {
|
||
var r = t.createTexture();
|
||
return t.bindTexture(t.TEXTURE_2D, r), t.texParameteri(t.TEXTURE_2D, t.TEXTURE_MAG_FILTER, t.LINEAR), t.texParameteri(t.TEXTURE_2D, t.TEXTURE_MIN_FILTER, t.LINEAR), void 0 !== e && t.texParameteri(Eh, Ch, e), void 0 !== i && t.texParameteri(Eh, Sh, i), r
|
||
}
|
||
|
||
function eu(t, e, i, r, o) {
|
||
var n = tu(t, r, o);
|
||
return t.texImage2D(t.TEXTURE_2D, 0, t.RGBA, e, i, 0, t.RGBA, t.UNSIGNED_BYTE, null), n
|
||
}
|
||
|
||
function iu(t, e, i, r) {
|
||
var o = tu(t, i, r);
|
||
return t.texImage2D(t.TEXTURE_2D, 0, t.RGBA, t.RGBA, t.UNSIGNED_BYTE, e), o
|
||
}
|
||
|
||
var ru = function (t) {
|
||
function e(e, i) {
|
||
t.call(this), this.canvas_ = e, this.gl_ = i, this.bufferCache_ = {}, this.shaderCache_ = {}, this.programCache_ = {}, this.currentProgram_ = null, this.hitDetectionFramebuffer_ = null, this.hitDetectionTexture_ = null, this.hitDetectionRenderbuffer_ = null, this.hasOESElementIndexUint = K(Lh, "OES_element_index_uint"), this.hasOESElementIndexUint && i.getExtension("OES_element_index_uint"), w(this.canvas_, Qh.LOST, this.handleWebGLContextLost, this), w(this.canvas_, Qh.RESTORED, this.handleWebGLContextRestored, this)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.bindBuffer = function (t, e) {
|
||
var i = this.getGL(), r = e.getArray(), o = a(e);
|
||
if (o in this.bufferCache_) {
|
||
var n = this.bufferCache_[o];
|
||
i.bindBuffer(t, n.buffer)
|
||
} else {
|
||
var s, l = i.createBuffer();
|
||
i.bindBuffer(t, l), 34962 == t ? s = new Float32Array(r) : 34963 == t && (s = this.hasOESElementIndexUint ? new Uint32Array(r) : new Uint16Array(r)), i.bufferData(t, s, e.getUsage()), this.bufferCache_[o] = {
|
||
buf: e,
|
||
buffer: l
|
||
}
|
||
}
|
||
}, e.prototype.deleteBuffer = function (t) {
|
||
var e = this.getGL(), i = a(t), r = this.bufferCache_[i];
|
||
e.isContextLost() || e.deleteBuffer(r.buffer), delete this.bufferCache_[i]
|
||
}, e.prototype.disposeInternal = function () {
|
||
E(this.canvas_);
|
||
var t = this.getGL();
|
||
if (!t.isContextLost()) {
|
||
for (var e in this.bufferCache_) t.deleteBuffer(this.bufferCache_[e].buffer);
|
||
for (var i in this.programCache_) t.deleteProgram(this.programCache_[i]);
|
||
for (var r in this.shaderCache_) t.deleteShader(this.shaderCache_[r]);
|
||
t.deleteFramebuffer(this.hitDetectionFramebuffer_), t.deleteRenderbuffer(this.hitDetectionRenderbuffer_), t.deleteTexture(this.hitDetectionTexture_)
|
||
}
|
||
}, e.prototype.getCanvas = function () {
|
||
return this.canvas_
|
||
}, e.prototype.getGL = function () {
|
||
return this.gl_
|
||
}, e.prototype.getHitDetectionFramebuffer = function () {
|
||
return this.hitDetectionFramebuffer_ || this.initHitDetectionFramebuffer_(), this.hitDetectionFramebuffer_
|
||
}, e.prototype.getShader = function (t) {
|
||
var e = a(t);
|
||
if (e in this.shaderCache_) return this.shaderCache_[e];
|
||
var i = this.getGL(), r = i.createShader(t.getType());
|
||
return i.shaderSource(r, t.getSource()), i.compileShader(r), this.shaderCache_[e] = r, r
|
||
}, e.prototype.getProgram = function (t, e) {
|
||
var i = a(t) + "/" + a(e);
|
||
if (i in this.programCache_) return this.programCache_[i];
|
||
var r = this.getGL(), o = r.createProgram();
|
||
return r.attachShader(o, this.getShader(t)), r.attachShader(o, this.getShader(e)), r.linkProgram(o), this.programCache_[i] = o, o
|
||
}, e.prototype.handleWebGLContextLost = function () {
|
||
d(this.bufferCache_), d(this.shaderCache_), d(this.programCache_), this.currentProgram_ = null, this.hitDetectionFramebuffer_ = null, this.hitDetectionTexture_ = null, this.hitDetectionRenderbuffer_ = null
|
||
}, e.prototype.handleWebGLContextRestored = function () {
|
||
}, e.prototype.initHitDetectionFramebuffer_ = function () {
|
||
var t = this.gl_, e = t.createFramebuffer();
|
||
t.bindFramebuffer(t.FRAMEBUFFER, e);
|
||
var i = eu(t, 1, 1), r = t.createRenderbuffer();
|
||
t.bindRenderbuffer(t.RENDERBUFFER, r), t.renderbufferStorage(t.RENDERBUFFER, t.DEPTH_COMPONENT16, 1, 1), t.framebufferTexture2D(t.FRAMEBUFFER, t.COLOR_ATTACHMENT0, t.TEXTURE_2D, i, 0), t.framebufferRenderbuffer(t.FRAMEBUFFER, t.DEPTH_ATTACHMENT, t.RENDERBUFFER, r), t.bindTexture(t.TEXTURE_2D, null), t.bindRenderbuffer(t.RENDERBUFFER, null), t.bindFramebuffer(t.FRAMEBUFFER, null), this.hitDetectionFramebuffer_ = e, this.hitDetectionTexture_ = i, this.hitDetectionRenderbuffer_ = r
|
||
}, e.prototype.useProgram = function (t) {
|
||
return t != this.currentProgram_ && (this.getGL().useProgram(t), this.currentProgram_ = t, !0)
|
||
}, e
|
||
}(R), ou = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e, i), this.anchorX = void 0, this.anchorY = void 0, this.groupIndices = [], this.hitDetectionGroupIndices = [], this.height = void 0, this.imageHeight = void 0, this.imageWidth = void 0, this.defaultLocations = null, this.opacity = void 0, this.originX = void 0, this.originY = void 0, this.rotateWithView = void 0, this.rotation = void 0, this.scale = void 0, this.width = void 0
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getDeleteResourcesFunction = function (t) {
|
||
var e = this.verticesBuffer, i = this.indicesBuffer, r = this.getTextures(!0), o = t.getGL();
|
||
return function () {
|
||
var n, s;
|
||
if (!o.isContextLost()) for (n = 0, s = r.length; n < s; ++n) o.deleteTexture(r[n]);
|
||
t.deleteBuffer(e), t.deleteBuffer(i)
|
||
}
|
||
}, e.prototype.drawCoordinates = function (t, e, i, r) {
|
||
var o, n, s, a, l, h, u = this.anchorX, c = this.anchorY, p = this.height, d = this.imageHeight,
|
||
f = this.imageWidth, g = this.opacity, m = this.originX, y = this.originY,
|
||
v = this.rotateWithView ? 1 : 0, _ = -this.rotation, x = this.scale, w = this.width,
|
||
b = Math.cos(_), C = Math.sin(_), S = this.indices.length, E = this.vertices.length;
|
||
for (o = e; o < i; o += r) l = t[o] - this.origin[0], h = t[o + 1] - this.origin[1], n = E / 8, s = -x * u, a = -x * (p - c), this.vertices[E++] = l, this.vertices[E++] = h, this.vertices[E++] = s * b - a * C, this.vertices[E++] = s * C + a * b, this.vertices[E++] = m / f, this.vertices[E++] = (y + p) / d, this.vertices[E++] = g, this.vertices[E++] = v, s = x * (w - u), a = -x * (p - c), this.vertices[E++] = l, this.vertices[E++] = h, this.vertices[E++] = s * b - a * C, this.vertices[E++] = s * C + a * b, this.vertices[E++] = (m + w) / f, this.vertices[E++] = (y + p) / d, this.vertices[E++] = g, this.vertices[E++] = v, s = x * (w - u), a = x * c, this.vertices[E++] = l, this.vertices[E++] = h, this.vertices[E++] = s * b - a * C, this.vertices[E++] = s * C + a * b, this.vertices[E++] = (m + w) / f, this.vertices[E++] = y / d, this.vertices[E++] = g, this.vertices[E++] = v, s = -x * u, a = x * c, this.vertices[E++] = l, this.vertices[E++] = h, this.vertices[E++] = s * b - a * C, this.vertices[E++] = s * C + a * b, this.vertices[E++] = m / f, this.vertices[E++] = y / d, this.vertices[E++] = g, this.vertices[E++] = v, this.indices[S++] = n, this.indices[S++] = n + 1, this.indices[S++] = n + 2, this.indices[S++] = n, this.indices[S++] = n + 2, this.indices[S++] = n + 3;
|
||
return E
|
||
}, e.prototype.createTextures = function (t, e, i, r) {
|
||
var o, n, s, l, h = e.length;
|
||
for (l = 0; l < h; ++l) (s = a(n = e[l])) in i ? o = i[s] : (o = iu(r, n, 33071, 33071), i[s] = o), t[l] = o
|
||
}, e.prototype.setUpProgram = function (t, e, i, r) {
|
||
var o, n = e.getProgram(Kh, Jh);
|
||
return this.defaultLocations ? o = this.defaultLocations : (o = new $h(t, n), this.defaultLocations = o), e.useProgram(n), t.enableVertexAttribArray(o.a_position), t.vertexAttribPointer(o.a_position, 2, 5126, !1, 32, 0), t.enableVertexAttribArray(o.a_offsets), t.vertexAttribPointer(o.a_offsets, 2, 5126, !1, 32, 8), t.enableVertexAttribArray(o.a_texCoord), t.vertexAttribPointer(o.a_texCoord, 2, 5126, !1, 32, 16), t.enableVertexAttribArray(o.a_opacity), t.vertexAttribPointer(o.a_opacity, 1, 5126, !1, 32, 24), t.enableVertexAttribArray(o.a_rotateWithView), t.vertexAttribPointer(o.a_rotateWithView, 1, 5126, !1, 32, 28), o
|
||
}, e.prototype.shutDownProgram = function (t, e) {
|
||
t.disableVertexAttribArray(e.a_position), t.disableVertexAttribArray(e.a_offsets), t.disableVertexAttribArray(e.a_texCoord), t.disableVertexAttribArray(e.a_opacity), t.disableVertexAttribArray(e.a_rotateWithView)
|
||
}, e.prototype.drawReplay = function (t, e, i, r) {
|
||
var o, n, s, a = r ? this.getHitDetectionTextures() : this.getTextures(),
|
||
l = r ? this.hitDetectionGroupIndices : this.groupIndices;
|
||
if (g(i)) for (o = 0, n = a.length, s = 0; o < n; ++o) {
|
||
t.bindTexture(Eh, a[o]);
|
||
var h = l[o];
|
||
this.drawElements(t, e, s, h), s = h
|
||
} else this.drawReplaySkipping(t, e, i, a, l)
|
||
}, e.prototype.drawReplaySkipping = function (t, e, i, r, o) {
|
||
var n, s, l = 0;
|
||
for (n = 0, s = r.length; n < s; ++n) {
|
||
t.bindTexture(Eh, r[n]);
|
||
for (var h = n > 0 ? o[n - 1] : 0, u = o[n], c = h, p = h; l < this.startIndices.length && this.startIndices[l] <= u;) {
|
||
void 0 !== i[a(this.startIndicesFeature[l])] ? (c !== p && this.drawElements(t, e, c, p), p = c = l === this.startIndices.length - 1 ? u : this.startIndices[l + 1]) : p = l === this.startIndices.length - 1 ? u : this.startIndices[l + 1], l++
|
||
}
|
||
c !== p && this.drawElements(t, e, c, p)
|
||
}
|
||
}, e.prototype.drawHitDetectionReplayOneByOne = function (t, e, i, r, o) {
|
||
var n, s, l, h, u, c = this.startIndices.length - 1, p = this.getHitDetectionTextures();
|
||
for (n = p.length - 1; n >= 0; --n) for (t.bindTexture(Eh, p[n]), s = n > 0 ? this.hitDetectionGroupIndices[n - 1] : 0, h = this.hitDetectionGroupIndices[n]; c >= 0 && this.startIndices[c] >= s;) {
|
||
if (l = this.startIndices[c], void 0 === i[a(u = this.startIndicesFeature[c])] && u.getGeometry() && (void 0 === o || Bt(o, u.getGeometry().getExtent()))) {
|
||
t.clear(t.COLOR_BUFFER_BIT | t.DEPTH_BUFFER_BIT), this.drawElements(t, e, l, h);
|
||
var d = r(u);
|
||
if (d) return d
|
||
}
|
||
h = l, c--
|
||
}
|
||
}, e.prototype.finish = function (t) {
|
||
this.anchorX = void 0, this.anchorY = void 0, this.height = void 0, this.imageHeight = void 0, this.imageWidth = void 0, this.indices = null, this.opacity = void 0, this.originX = void 0, this.originY = void 0, this.rotateWithView = void 0, this.rotation = void 0, this.scale = void 0, this.vertices = null, this.width = void 0
|
||
}, e.prototype.getTextures = function (t) {
|
||
return n()
|
||
}, e.prototype.getHitDetectionTextures = function () {
|
||
return n()
|
||
}, e
|
||
}(zh), nu = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e, i), this.images_ = [], this.hitDetectionImages_ = [], this.textures_ = [], this.hitDetectionTextures_ = []
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.drawMultiPoint = function (t, e) {
|
||
this.startIndices.push(this.indices.length), this.startIndicesFeature.push(e);
|
||
var i = t.getFlatCoordinates(), r = t.getStride();
|
||
this.drawCoordinates(i, 0, i.length, r)
|
||
}, e.prototype.drawPoint = function (t, e) {
|
||
this.startIndices.push(this.indices.length), this.startIndicesFeature.push(e);
|
||
var i = t.getFlatCoordinates(), r = t.getStride();
|
||
this.drawCoordinates(i, 0, i.length, r)
|
||
}, e.prototype.finish = function (e) {
|
||
var i = e.getGL();
|
||
this.groupIndices.push(this.indices.length), this.hitDetectionGroupIndices.push(this.indices.length), this.verticesBuffer = new qh(this.vertices);
|
||
var r = this.indices;
|
||
this.indicesBuffer = new qh(r);
|
||
var o = {};
|
||
this.createTextures(this.textures_, this.images_, o, i), this.createTextures(this.hitDetectionTextures_, this.hitDetectionImages_, o, i), this.images_ = null, this.hitDetectionImages_ = null, t.prototype.finish.call(this, e)
|
||
}, e.prototype.setImageStyle = function (t) {
|
||
var e = t.getAnchor(), i = t.getImage(1), r = t.getImageSize(), o = t.getHitDetectionImage(1),
|
||
n = t.getOpacity(), s = t.getOrigin(), l = t.getRotateWithView(), h = t.getRotation(),
|
||
u = t.getSize(), c = t.getScale();
|
||
0 === this.images_.length ? this.images_.push(i) : a(this.images_[this.images_.length - 1]) != a(i) && (this.groupIndices.push(this.indices.length), this.images_.push(i)), 0 === this.hitDetectionImages_.length ? this.hitDetectionImages_.push(o) : a(this.hitDetectionImages_[this.hitDetectionImages_.length - 1]) != a(o) && (this.hitDetectionGroupIndices.push(this.indices.length), this.hitDetectionImages_.push(o)), this.anchorX = e[0], this.anchorY = e[1], this.height = u[1], this.imageHeight = r[1], this.imageWidth = r[0], this.opacity = n, this.originX = s[0], this.originY = s[1], this.rotation = h, this.rotateWithView = l, this.scale = c, this.width = u[0]
|
||
}, e.prototype.getTextures = function (t) {
|
||
return t ? this.textures_.concat(this.hitDetectionTextures_) : this.textures_
|
||
}, e.prototype.getHitDetectionTextures = function () {
|
||
return this.hitDetectionTextures_
|
||
}, e
|
||
}(ou);
|
||
|
||
function su(t, e, i, r) {
|
||
var o = i - r;
|
||
return t[e] === t[o] && t[e + 1] === t[o + 1] && (i - e) / r > 3 && !!Ci(t, e, i, r)
|
||
}
|
||
|
||
var au = new Ah("precision mediump float;\nvarying float v_round;\nvarying vec2 v_roundVertex;\nvarying float v_halfWidth;\n\n\n\nuniform float u_opacity;\nuniform vec4 u_color;\nuniform vec2 u_size;\nuniform float u_pixelRatio;\n\nvoid main(void) {\n if (v_round > 0.0) {\n vec2 windowCoords = vec2((v_roundVertex.x + 1.0) / 2.0 * u_size.x * u_pixelRatio,\n (v_roundVertex.y + 1.0) / 2.0 * u_size.y * u_pixelRatio);\n if (length(windowCoords - gl_FragCoord.xy) > v_halfWidth * u_pixelRatio) {\n discard;\n }\n }\n gl_FragColor = u_color;\n float alpha = u_color.a * u_opacity;\n if (alpha == 0.0) {\n discard;\n }\n gl_FragColor.a = alpha;\n}\n"),
|
||
lu = new kh("varying float v_round;\nvarying vec2 v_roundVertex;\nvarying float v_halfWidth;\n\n\nattribute vec2 a_lastPos;\nattribute vec2 a_position;\nattribute vec2 a_nextPos;\nattribute float a_direction;\n\nuniform mat4 u_projectionMatrix;\nuniform mat4 u_offsetScaleMatrix;\nuniform mat4 u_offsetRotateMatrix;\nuniform float u_lineWidth;\nuniform float u_miterLimit;\n\nbool nearlyEquals(in float value, in float ref) {\n float epsilon = 0.000000000001;\n return value >= ref - epsilon && value <= ref + epsilon;\n}\n\nvoid alongNormal(out vec2 offset, in vec2 nextP, in float turnDir, in float direction) {\n vec2 dirVect = nextP - a_position;\n vec2 normal = normalize(vec2(-turnDir * dirVect.y, turnDir * dirVect.x));\n offset = u_lineWidth / 2.0 * normal * direction;\n}\n\nvoid miterUp(out vec2 offset, out float round, in bool isRound, in float direction) {\n float halfWidth = u_lineWidth / 2.0;\n vec2 tangent = normalize(normalize(a_nextPos - a_position) + normalize(a_position - a_lastPos));\n vec2 normal = vec2(-tangent.y, tangent.x);\n vec2 dirVect = a_nextPos - a_position;\n vec2 tmpNormal = normalize(vec2(-dirVect.y, dirVect.x));\n float miterLength = abs(halfWidth / dot(normal, tmpNormal));\n offset = normal * direction * miterLength;\n round = 0.0;\n if (isRound) {\n round = 1.0;\n } else if (miterLength > u_miterLimit + u_lineWidth) {\n offset = halfWidth * tmpNormal * direction;\n }\n}\n\nbool miterDown(out vec2 offset, in vec4 projPos, in mat4 offsetMatrix, in float direction) {\n bool degenerate = false;\n vec2 tangent = normalize(normalize(a_nextPos - a_position) + normalize(a_position - a_lastPos));\n vec2 normal = vec2(-tangent.y, tangent.x);\n vec2 dirVect = a_lastPos - a_position;\n vec2 tmpNormal = normalize(vec2(-dirVect.y, dirVect.x));\n vec2 longOffset, shortOffset, longVertex;\n vec4 shortProjVertex;\n float halfWidth = u_lineWidth / 2.0;\n if (length(a_nextPos - a_position) > length(a_lastPos - a_position)) {\n longOffset = tmpNormal * direction * halfWidth;\n shortOffset = normalize(vec2(dirVect.y, -dirVect.x)) * direction * halfWidth;\n longVertex = a_nextPos;\n shortProjVertex = u_projectionMatrix * vec4(a_lastPos, 0.0, 1.0);\n } else {\n shortOffset = tmpNormal * direction * halfWidth;\n longOffset = normalize(vec2(dirVect.y, -dirVect.x)) * direction * halfWidth;\n longVertex = a_lastPos;\n shortProjVertex = u_projectionMatrix * vec4(a_nextPos, 0.0, 1.0);\n }\n //Intersection algorithm based on theory by Paul Bourke (http://paulbourke.net/geometry/pointlineplane/).\n vec4 p1 = u_projectionMatrix * vec4(longVertex, 0.0, 1.0) + offsetMatrix * vec4(longOffset, 0.0, 0.0);\n vec4 p2 = projPos + offsetMatrix * vec4(longOffset, 0.0, 0.0);\n vec4 p3 = shortProjVertex + offsetMatrix * vec4(-shortOffset, 0.0, 0.0);\n vec4 p4 = shortProjVertex + offsetMatrix * vec4(shortOffset, 0.0, 0.0);\n float denom = (p4.y - p3.y) * (p2.x - p1.x) - (p4.x - p3.x) * (p2.y - p1.y);\n float firstU = ((p4.x - p3.x) * (p1.y - p3.y) - (p4.y - p3.y) * (p1.x - p3.x)) / denom;\n float secondU = ((p2.x - p1.x) * (p1.y - p3.y) - (p2.y - p1.y) * (p1.x - p3.x)) / denom;\n float epsilon = 0.000000000001;\n if (firstU > epsilon && firstU < 1.0 - epsilon && secondU > epsilon && secondU < 1.0 - epsilon) {\n shortProjVertex.x = p1.x + firstU * (p2.x - p1.x);\n shortProjVertex.y = p1.y + firstU * (p2.y - p1.y);\n offset = shortProjVertex.xy;\n degenerate = true;\n } else {\n float miterLength = abs(halfWidth / dot(normal, tmpNormal));\n offset = normal * direction * miterLength;\n }\n return degenerate;\n}\n\nvoid squareCap(out vec2 offset, out float round, in bool isRound, in vec2 nextP,\n in float turnDir, in float direction) {\n round = 0.0;\n vec2 dirVect = a_position - nextP;\n vec2 firstNormal = normalize(dirVect);\n vec2 secondNormal = vec2(turnDir * firstNormal.y * direction, -turnDir * firstNormal.x * direction);\n vec2 hypotenuse = normalize(firstNormal - secondNormal);\n vec2 normal = vec2(turnDir * hypotenuse.y * direction, -turnDir * hypotenuse.x * direction);\n float length = sqrt(v_halfWidth * v_halfWidth * 2.0);\n offset = normal * length;\n if (isRound) {\n round = 1.0;\n }\n}\n\nvoid main(void) {\n bool degenerate = false;\n float direction = float(sign(a_direction));\n mat4 offsetMatrix = u_offsetScaleMatrix * u_offsetRotateMatrix;\n vec2 offset;\n vec4 projPos = u_projectionMatrix * vec4(a_position, 0.0, 1.0);\n bool round = nearlyEquals(mod(a_direction, 2.0), 0.0);\n\n v_round = 0.0;\n v_halfWidth = u_lineWidth / 2.0;\n v_roundVertex = projPos.xy;\n\n if (nearlyEquals(mod(a_direction, 3.0), 0.0) || nearlyEquals(mod(a_direction, 17.0), 0.0)) {\n alongNormal(offset, a_nextPos, 1.0, direction);\n } else if (nearlyEquals(mod(a_direction, 5.0), 0.0) || nearlyEquals(mod(a_direction, 13.0), 0.0)) {\n alongNormal(offset, a_lastPos, -1.0, direction);\n } else if (nearlyEquals(mod(a_direction, 23.0), 0.0)) {\n miterUp(offset, v_round, round, direction);\n } else if (nearlyEquals(mod(a_direction, 19.0), 0.0)) {\n degenerate = miterDown(offset, projPos, offsetMatrix, direction);\n } else if (nearlyEquals(mod(a_direction, 7.0), 0.0)) {\n squareCap(offset, v_round, round, a_nextPos, 1.0, direction);\n } else if (nearlyEquals(mod(a_direction, 11.0), 0.0)) {\n squareCap(offset, v_round, round, a_lastPos, -1.0, direction);\n }\n if (!degenerate) {\n vec4 offsets = offsetMatrix * vec4(offset, 0.0, 0.0);\n gl_Position = projPos + offsets;\n } else {\n gl_Position = vec4(offset, 0.0, 1.0);\n }\n}\n\n\n"),
|
||
hu = function (t, e) {
|
||
this.u_projectionMatrix = t.getUniformLocation(e, "u_projectionMatrix"), this.u_offsetScaleMatrix = t.getUniformLocation(e, "u_offsetScaleMatrix"), this.u_offsetRotateMatrix = t.getUniformLocation(e, "u_offsetRotateMatrix"), this.u_lineWidth = t.getUniformLocation(e, "u_lineWidth"), this.u_miterLimit = t.getUniformLocation(e, "u_miterLimit"), this.u_opacity = t.getUniformLocation(e, "u_opacity"), this.u_color = t.getUniformLocation(e, "u_color"), this.u_size = t.getUniformLocation(e, "u_size"), this.u_pixelRatio = t.getUniformLocation(e, "u_pixelRatio"), this.a_lastPos = t.getAttribLocation(e, "a_lastPos"), this.a_position = t.getAttribLocation(e, "a_position"), this.a_nextPos = t.getAttribLocation(e, "a_nextPos"), this.a_direction = t.getAttribLocation(e, "a_direction")
|
||
}, uu = 3, cu = 5, pu = 7, du = 11, fu = 13, gu = 17, mu = 19, yu = 23, vu = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e, i), this.defaultLocations_ = null, this.styles_ = [], this.styleIndices_ = [], this.state_ = {
|
||
strokeColor: null,
|
||
lineCap: void 0,
|
||
lineDash: null,
|
||
lineDashOffset: void 0,
|
||
lineJoin: void 0,
|
||
lineWidth: void 0,
|
||
miterLimit: void 0,
|
||
changed: !1
|
||
}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.drawCoordinates_ = function (t, e, i, r) {
|
||
var o, n, s, a, l, h, u, c, p = this.vertices.length, d = this.indices.length,
|
||
f = "bevel" === this.state_.lineJoin ? 0 : "miter" === this.state_.lineJoin ? 1 : 2,
|
||
g = "butt" === this.state_.lineCap ? 0 : "square" === this.state_.lineCap ? 1 : 2,
|
||
m = su(t, e, i, r), y = d, v = 1;
|
||
for (o = e, n = i; o < n; o += r) {
|
||
if (l = p / 7, h = u, u = c || [t[o], t[o + 1]], o === e) {
|
||
if (c = [t[o + r], t[o + r + 1]], i - e == 2 * r && it(u, c)) break;
|
||
if (!m) {
|
||
g && (p = this.addVertices_([0, 0], u, c, v * pu * g, p), p = this.addVertices_([0, 0], u, c, -v * pu * g, p), this.indices[d++] = l + 2, this.indices[d++] = l, this.indices[d++] = l + 1, this.indices[d++] = l + 1, this.indices[d++] = l + 3, this.indices[d++] = l + 2), p = this.addVertices_([0, 0], u, c, v * uu * (g || 1), p), y = (p = this.addVertices_([0, 0], u, c, -v * uu * (g || 1), p)) / 7 - 1;
|
||
continue
|
||
}
|
||
h = [t[i - 2 * r], t[i - 2 * r + 1]], s = c
|
||
} else {
|
||
if (o === i - r) {
|
||
if (m) {
|
||
c = s;
|
||
break
|
||
}
|
||
h = h || [0, 0], p = this.addVertices_(h, u, [0, 0], v * cu * (g || 1), p), p = this.addVertices_(h, u, [0, 0], -v * cu * (g || 1), p), this.indices[d++] = l, this.indices[d++] = y - 1, this.indices[d++] = y, this.indices[d++] = y, this.indices[d++] = l + 1, this.indices[d++] = l, g && (p = this.addVertices_(h, u, [0, 0], v * du * g, p), p = this.addVertices_(h, u, [0, 0], -v * du * g, p), this.indices[d++] = l + 2, this.indices[d++] = l, this.indices[d++] = l + 1, this.indices[d++] = l + 1, this.indices[d++] = l + 3, this.indices[d++] = l + 2);
|
||
break
|
||
}
|
||
c = [t[o + r], t[o + r + 1]]
|
||
}
|
||
a = Wh(h[0], h[1], u[0], u[1], c[0], c[1]) ? -1 : 1, p = this.addVertices_(h, u, c, a * fu * (f || 1), p), p = this.addVertices_(h, u, c, a * gu * (f || 1), p), p = this.addVertices_(h, u, c, -a * mu * (f || 1), p), o > e && (this.indices[d++] = l, this.indices[d++] = y - 1, this.indices[d++] = y, this.indices[d++] = l + 2, this.indices[d++] = l, this.indices[d++] = v * a > 0 ? y : y - 1), this.indices[d++] = l, this.indices[d++] = l + 2, this.indices[d++] = l + 1, y = l + 2, v = a, f && (p = this.addVertices_(h, u, c, a * yu * f, p), this.indices[d++] = l + 1, this.indices[d++] = l + 3, this.indices[d++] = l)
|
||
}
|
||
m && (l = l || p / 7, a = lr([h[0], h[1], u[0], u[1], c[0], c[1]], 0, 6, 2) ? 1 : -1, p = this.addVertices_(h, u, c, a * fu * (f || 1), p), p = this.addVertices_(h, u, c, -a * mu * (f || 1), p), this.indices[d++] = l, this.indices[d++] = y - 1, this.indices[d++] = y, this.indices[d++] = l + 1, this.indices[d++] = l, this.indices[d++] = v * a > 0 ? y : y - 1)
|
||
}, e.prototype.addVertices_ = function (t, e, i, r, o) {
|
||
return this.vertices[o++] = t[0], this.vertices[o++] = t[1], this.vertices[o++] = e[0], this.vertices[o++] = e[1], this.vertices[o++] = i[0], this.vertices[o++] = i[1], this.vertices[o++] = r, o
|
||
}, e.prototype.isValid_ = function (t, e, i, r) {
|
||
var o = i - e;
|
||
return !(o < 2 * r) && (o !== 2 * r || !it([t[e], t[e + 1]], [t[e + r], t[e + r + 1]]))
|
||
}, e.prototype.drawLineString = function (t, e) {
|
||
var i = t.getFlatCoordinates(), r = t.getStride();
|
||
this.isValid_(i, 0, i.length, r) && (i = Qt(i, 0, i.length, r, -this.origin[0], -this.origin[1]), this.state_.changed && (this.styleIndices_.push(this.indices.length), this.state_.changed = !1), this.startIndices.push(this.indices.length), this.startIndicesFeature.push(e), this.drawCoordinates_(i, 0, i.length, r))
|
||
}, e.prototype.drawMultiLineString = function (t, e) {
|
||
var i = this.indices.length, r = t.getEnds();
|
||
r.unshift(0);
|
||
var o, n, s = t.getFlatCoordinates(), a = t.getStride();
|
||
if (r.length > 1) for (o = 1, n = r.length; o < n; ++o) if (this.isValid_(s, r[o - 1], r[o], a)) {
|
||
var l = Qt(s, r[o - 1], r[o], a, -this.origin[0], -this.origin[1]);
|
||
this.drawCoordinates_(l, 0, l.length, a)
|
||
}
|
||
this.indices.length > i && (this.startIndices.push(i), this.startIndicesFeature.push(e), this.state_.changed && (this.styleIndices_.push(i), this.state_.changed = !1))
|
||
}, e.prototype.drawPolygonCoordinates = function (t, e, i) {
|
||
var r, o;
|
||
if (su(t, 0, t.length, i) || (t.push(t[0]), t.push(t[1])), this.drawCoordinates_(t, 0, t.length, i), e.length) for (r = 0, o = e.length; r < o; ++r) su(e[r], 0, e[r].length, i) || (e[r].push(e[r][0]), e[r].push(e[r][1])), this.drawCoordinates_(e[r], 0, e[r].length, i)
|
||
}, e.prototype.setPolygonStyle = function (t, e) {
|
||
var i = void 0 === e ? this.indices.length : e;
|
||
this.startIndices.push(i), this.startIndicesFeature.push(t), this.state_.changed && (this.styleIndices_.push(i), this.state_.changed = !1)
|
||
}, e.prototype.getCurrentIndex = function () {
|
||
return this.indices.length
|
||
}, e.prototype.finish = function (t) {
|
||
this.verticesBuffer = new qh(this.vertices), this.indicesBuffer = new qh(this.indices), this.startIndices.push(this.indices.length), 0 === this.styleIndices_.length && this.styles_.length > 0 && (this.styles_ = []), this.vertices = null, this.indices = null
|
||
}, e.prototype.getDeleteResourcesFunction = function (t) {
|
||
var e = this.verticesBuffer, i = this.indicesBuffer;
|
||
return function () {
|
||
t.deleteBuffer(e), t.deleteBuffer(i)
|
||
}
|
||
}, e.prototype.setUpProgram = function (t, e, i, r) {
|
||
var o, n = e.getProgram(au, lu);
|
||
return this.defaultLocations_ ? o = this.defaultLocations_ : (o = new hu(t, n), this.defaultLocations_ = o), e.useProgram(n), t.enableVertexAttribArray(o.a_lastPos), t.vertexAttribPointer(o.a_lastPos, 2, 5126, !1, 28, 0), t.enableVertexAttribArray(o.a_position), t.vertexAttribPointer(o.a_position, 2, 5126, !1, 28, 8), t.enableVertexAttribArray(o.a_nextPos), t.vertexAttribPointer(o.a_nextPos, 2, 5126, !1, 28, 16), t.enableVertexAttribArray(o.a_direction), t.vertexAttribPointer(o.a_direction, 1, 5126, !1, 28, 24), t.uniform2fv(o.u_size, i), t.uniform1f(o.u_pixelRatio, r), o
|
||
}, e.prototype.shutDownProgram = function (t, e) {
|
||
t.disableVertexAttribArray(e.a_lastPos), t.disableVertexAttribArray(e.a_position), t.disableVertexAttribArray(e.a_nextPos), t.disableVertexAttribArray(e.a_direction)
|
||
}, e.prototype.drawReplay = function (t, e, i, r) {
|
||
var o, n, s, a, l = t.getParameter(t.DEPTH_FUNC), h = t.getParameter(t.DEPTH_WRITEMASK);
|
||
if (r || (t.enable(t.DEPTH_TEST), t.depthMask(!0), t.depthFunc(t.NOTEQUAL)), g(i)) for (s = this.startIndices[this.startIndices.length - 1], o = this.styleIndices_.length - 1; o >= 0; --o) n = this.styleIndices_[o], a = this.styles_[o], this.setStrokeStyle_(t, a[0], a[1], a[2]), this.drawElements(t, e, n, s), t.clear(t.DEPTH_BUFFER_BIT), s = n; else this.drawReplaySkipping_(t, e, i);
|
||
r || (t.disable(t.DEPTH_TEST), t.clear(t.DEPTH_BUFFER_BIT), t.depthMask(h), t.depthFunc(l))
|
||
}, e.prototype.drawReplaySkipping_ = function (t, e, i) {
|
||
var r, o, n, s, l, h, u;
|
||
for (h = this.startIndices.length - 2, n = o = this.startIndices[h + 1], r = this.styleIndices_.length - 1; r >= 0; --r) {
|
||
for (s = this.styles_[r], this.setStrokeStyle_(t, s[0], s[1], s[2]), l = this.styleIndices_[r]; h >= 0 && this.startIndices[h] >= l;) u = this.startIndices[h], i[a(this.startIndicesFeature[h])] && (o !== n && (this.drawElements(t, e, o, n), t.clear(t.DEPTH_BUFFER_BIT)), n = u), h--, o = u;
|
||
o !== n && (this.drawElements(t, e, o, n), t.clear(t.DEPTH_BUFFER_BIT)), o = n = l
|
||
}
|
||
}, e.prototype.drawHitDetectionReplayOneByOne = function (t, e, i, r, o) {
|
||
var n, s, l, h, u, c, p;
|
||
for (p = this.startIndices.length - 2, l = this.startIndices[p + 1], n = this.styleIndices_.length - 1; n >= 0; --n) for (h = this.styles_[n], this.setStrokeStyle_(t, h[0], h[1], h[2]), u = this.styleIndices_[n]; p >= 0 && this.startIndices[p] >= u;) {
|
||
if (s = this.startIndices[p], void 0 === i[a(c = this.startIndicesFeature[p])] && c.getGeometry() && (void 0 === o || Bt(o, c.getGeometry().getExtent()))) {
|
||
t.clear(t.COLOR_BUFFER_BIT | t.DEPTH_BUFFER_BIT), this.drawElements(t, e, s, l);
|
||
var d = r(c);
|
||
if (d) return d
|
||
}
|
||
p--, l = s
|
||
}
|
||
}, e.prototype.setStrokeStyle_ = function (t, e, i, r) {
|
||
t.uniform4fv(this.defaultLocations_.u_color, e), t.uniform1f(this.defaultLocations_.u_lineWidth, i), t.uniform1f(this.defaultLocations_.u_miterLimit, r)
|
||
}, e.prototype.setFillStrokeStyle = function (t, e) {
|
||
var i = e.getLineCap();
|
||
this.state_.lineCap = void 0 !== i ? i : "round";
|
||
var r = e.getLineDash();
|
||
this.state_.lineDash = r || Bh;
|
||
var o = e.getLineDashOffset();
|
||
this.state_.lineDashOffset = o || 0;
|
||
var n = e.getLineJoin();
|
||
this.state_.lineJoin = void 0 !== n ? n : "round";
|
||
var s = e.getColor();
|
||
s = s instanceof CanvasGradient || s instanceof CanvasPattern ? Vh : lo(s).map(function (t, e) {
|
||
return 3 != e ? t / 255 : t
|
||
}) || Vh;
|
||
var a = e.getWidth();
|
||
a = void 0 !== a ? a : 1;
|
||
var l = e.getMiterLimit();
|
||
l = void 0 !== l ? l : 10, this.state_.strokeColor && it(this.state_.strokeColor, s) && this.state_.lineWidth === a && this.state_.miterLimit === l || (this.state_.changed = !0, this.state_.strokeColor = s, this.state_.lineWidth = a, this.state_.miterLimit = l, this.styles_.push([s, a, l]))
|
||
}, e
|
||
}(zh),
|
||
_u = new Ah("precision mediump float;\n\n\n\nuniform vec4 u_color;\nuniform float u_opacity;\n\nvoid main(void) {\n gl_FragColor = u_color;\n float alpha = u_color.a * u_opacity;\n if (alpha == 0.0) {\n discard;\n }\n gl_FragColor.a = alpha;\n}\n"),
|
||
xu = new kh("\n\nattribute vec2 a_position;\n\nuniform mat4 u_projectionMatrix;\nuniform mat4 u_offsetScaleMatrix;\nuniform mat4 u_offsetRotateMatrix;\n\nvoid main(void) {\n gl_Position = u_projectionMatrix * vec4(a_position, 0.0, 1.0);\n}\n\n\n"),
|
||
wu = function (t, e) {
|
||
this.u_projectionMatrix = t.getUniformLocation(e, "u_projectionMatrix"), this.u_offsetScaleMatrix = t.getUniformLocation(e, "u_offsetScaleMatrix"), this.u_offsetRotateMatrix = t.getUniformLocation(e, "u_offsetRotateMatrix"), this.u_color = t.getUniformLocation(e, "u_color"), this.u_opacity = t.getUniformLocation(e, "u_opacity"), this.a_position = t.getAttribLocation(e, "a_position")
|
||
}, bu = function (t) {
|
||
this.first_, this.last_, this.head_, this.circular_ = void 0 === t || t, this.length_ = 0
|
||
};
|
||
bu.prototype.insertItem = function (t) {
|
||
var e = {prev: void 0, next: void 0, data: t}, i = this.head_;
|
||
if (i) {
|
||
var r = i.next;
|
||
e.prev = i, e.next = r, i.next = e, r && (r.prev = e), i === this.last_ && (this.last_ = e)
|
||
} else this.first_ = e, this.last_ = e, this.circular_ && (e.next = e, e.prev = e);
|
||
this.head_ = e, this.length_++
|
||
}, bu.prototype.removeItem = function () {
|
||
var t = this.head_;
|
||
if (t) {
|
||
var e = t.next, i = t.prev;
|
||
e && (e.prev = i), i && (i.next = e), this.head_ = e || i, this.first_ === this.last_ ? (this.head_ = void 0, this.first_ = void 0, this.last_ = void 0) : this.first_ === t ? this.first_ = this.head_ : this.last_ === t && (this.last_ = i ? this.head_.prev : this.head_), this.length_--
|
||
}
|
||
}, bu.prototype.firstItem = function () {
|
||
if (this.head_ = this.first_, this.head_) return this.head_.data
|
||
}, bu.prototype.lastItem = function () {
|
||
if (this.head_ = this.last_, this.head_) return this.head_.data
|
||
}, bu.prototype.nextItem = function () {
|
||
if (this.head_ && this.head_.next) return this.head_ = this.head_.next, this.head_.data
|
||
}, bu.prototype.getNextItem = function () {
|
||
if (this.head_ && this.head_.next) return this.head_.next.data
|
||
}, bu.prototype.prevItem = function () {
|
||
if (this.head_ && this.head_.prev) return this.head_ = this.head_.prev, this.head_.data
|
||
}, bu.prototype.getPrevItem = function () {
|
||
if (this.head_ && this.head_.prev) return this.head_.prev.data
|
||
}, bu.prototype.getCurrItem = function () {
|
||
if (this.head_) return this.head_.data
|
||
}, bu.prototype.setFirstItem = function () {
|
||
this.circular_ && this.head_ && (this.first_ = this.head_, this.last_ = this.head_.prev)
|
||
}, bu.prototype.concat = function (t) {
|
||
if (t.head_) {
|
||
if (this.head_) {
|
||
var e = this.head_.next;
|
||
this.head_.next = t.first_, t.first_.prev = this.head_, e.prev = t.last_, t.last_.next = e, this.length_ += t.length_
|
||
} else this.head_ = t.head_, this.first_ = t.first_, this.last_ = t.last_, this.length_ = t.length_;
|
||
t.head_ = void 0, t.first_ = void 0, t.last_ = void 0, t.length_ = 0
|
||
}
|
||
}, bu.prototype.getLength = function () {
|
||
return this.length_
|
||
};
|
||
var Cu = bu, Su = function (t) {
|
||
this.rbush_ = ml()(t, void 0), this.items_ = {}
|
||
};
|
||
Su.prototype.insert = function (t, e) {
|
||
var i = {minX: t[0], minY: t[1], maxX: t[2], maxY: t[3], value: e};
|
||
this.rbush_.insert(i), this.items_[a(e)] = i
|
||
}, Su.prototype.load = function (t, e) {
|
||
for (var i = new Array(e.length), r = 0, o = e.length; r < o; r++) {
|
||
var n = t[r], s = e[r], l = {minX: n[0], minY: n[1], maxX: n[2], maxY: n[3], value: s};
|
||
i[r] = l, this.items_[a(s)] = l
|
||
}
|
||
this.rbush_.load(i)
|
||
}, Su.prototype.remove = function (t) {
|
||
var e = a(t), i = this.items_[e];
|
||
return delete this.items_[e], null !== this.rbush_.remove(i)
|
||
}, Su.prototype.update = function (t, e) {
|
||
var i = this.items_[a(e)];
|
||
bt([i.minX, i.minY, i.maxX, i.maxY], t) || (this.remove(e), this.insert(t, e))
|
||
}, Su.prototype.getAll = function () {
|
||
return this.rbush_.all().map(function (t) {
|
||
return t.value
|
||
})
|
||
}, Su.prototype.getInExtent = function (t) {
|
||
var e = {minX: t[0], minY: t[1], maxX: t[2], maxY: t[3]};
|
||
return this.rbush_.search(e).map(function (t) {
|
||
return t.value
|
||
})
|
||
}, Su.prototype.forEach = function (t, e) {
|
||
return this.forEach_(this.getAll(), t, e)
|
||
}, Su.prototype.forEachInExtent = function (t, e, i) {
|
||
return this.forEach_(this.getInExtent(t), e, i)
|
||
}, Su.prototype.forEach_ = function (t, e, i) {
|
||
for (var r, o = 0, n = t.length; o < n; o++) if (r = e.call(i, t[o])) return r;
|
||
return r
|
||
}, Su.prototype.isEmpty = function () {
|
||
return g(this.items_)
|
||
}, Su.prototype.clear = function () {
|
||
this.rbush_.clear(), this.items_ = {}
|
||
}, Su.prototype.getExtent = function (t) {
|
||
var e = this.rbush_.toJSON();
|
||
return yt(e.minX, e.minY, e.maxX, e.maxY, t)
|
||
}, Su.prototype.concat = function (t) {
|
||
for (var e in this.rbush_.load(t.rbush_.all()), t.items_) this.items_[e] = t.items_[e]
|
||
};
|
||
var Eu = Su, Tu = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e, i), this.lineStringReplay = new vu(e, i), this.defaultLocations_ = null, this.styles_ = [], this.styleIndices_ = [], this.state_ = {
|
||
fillColor: null,
|
||
changed: !1
|
||
}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.drawCoordinates_ = function (t, e, i) {
|
||
var r = new Cu, o = new Eu;
|
||
this.processFlatCoordinates_(t, i, r, o, !0);
|
||
var n = this.getMaxCoords_(r);
|
||
if (e.length) {
|
||
var s, a, l = [];
|
||
for (s = 0, a = e.length; s < a; ++s) {
|
||
var h = {list: new Cu, maxCoords: void 0, rtree: new Eu};
|
||
l.push(h), this.processFlatCoordinates_(e[s], i, h.list, h.rtree, !1), this.classifyPoints_(h.list, h.rtree, !0), h.maxCoords = this.getMaxCoords_(h.list)
|
||
}
|
||
for (l.sort(function (t, e) {
|
||
return e.maxCoords[0] === t.maxCoords[0] ? t.maxCoords[1] - e.maxCoords[1] : e.maxCoords[0] - t.maxCoords[0]
|
||
}), s = 0; s < l.length; ++s) {
|
||
var u = l[s].list, c = u.firstItem(), p = c, d = void 0;
|
||
do {
|
||
if (this.getIntersections_(p, o).length) {
|
||
d = !0;
|
||
break
|
||
}
|
||
p = u.nextItem()
|
||
} while (c !== p);
|
||
d || this.bridgeHole_(u, l[s].maxCoords[0], r, n[0], o) && (o.concat(l[s].rtree), this.classifyPoints_(r, o, !1))
|
||
}
|
||
} else this.classifyPoints_(r, o, !1);
|
||
this.triangulate_(r, o)
|
||
}, e.prototype.processFlatCoordinates_ = function (t, e, i, r, o) {
|
||
var n, s, a, l, h, u = lr(t, 0, t.length, e), c = this.vertices.length / 2, p = [], d = [];
|
||
if (o === u) {
|
||
for (l = a = this.createPoint_(t[0], t[1], c++), n = e, s = t.length; n < s; n += e) h = this.createPoint_(t[n], t[n + 1], c++), d.push(this.insertItem_(l, h, i)), p.push([Math.min(l.x, h.x), Math.min(l.y, h.y), Math.max(l.x, h.x), Math.max(l.y, h.y)]), l = h;
|
||
d.push(this.insertItem_(h, a, i)), p.push([Math.min(l.x, h.x), Math.min(l.y, h.y), Math.max(l.x, h.x), Math.max(l.y, h.y)])
|
||
} else {
|
||
var f = t.length - e;
|
||
for (l = a = this.createPoint_(t[f], t[f + 1], c++), n = f - e, s = 0; n >= s; n -= e) h = this.createPoint_(t[n], t[n + 1], c++), d.push(this.insertItem_(l, h, i)), p.push([Math.min(l.x, h.x), Math.min(l.y, h.y), Math.max(l.x, h.x), Math.max(l.y, h.y)]), l = h;
|
||
d.push(this.insertItem_(h, a, i)), p.push([Math.min(l.x, h.x), Math.min(l.y, h.y), Math.max(l.x, h.x), Math.max(l.y, h.y)])
|
||
}
|
||
r.load(p, d)
|
||
}, e.prototype.getMaxCoords_ = function (t) {
|
||
var e = t.firstItem(), i = e, r = [i.p0.x, i.p0.y];
|
||
do {
|
||
(i = t.nextItem()).p0.x > r[0] && (r = [i.p0.x, i.p0.y])
|
||
} while (i !== e);
|
||
return r
|
||
}, e.prototype.classifyPoints_ = function (t, e, i) {
|
||
var r = t.firstItem(), o = r, n = t.nextItem(), s = !1;
|
||
do {
|
||
var a = i ? Wh(n.p1.x, n.p1.y, o.p1.x, o.p1.y, o.p0.x, o.p0.y) : Wh(o.p0.x, o.p0.y, o.p1.x, o.p1.y, n.p1.x, n.p1.y);
|
||
void 0 === a ? (this.removeItem_(o, n, t, e), s = !0, n === r && (r = t.getNextItem()), n = o, t.prevItem()) : o.p1.reflex !== a && (o.p1.reflex = a, s = !0), o = n, n = t.nextItem()
|
||
} while (o !== r);
|
||
return s
|
||
}, e.prototype.bridgeHole_ = function (t, e, i, r, o) {
|
||
for (var n = t.firstItem(); n.p1.x !== e;) n = t.nextItem();
|
||
var s, a, l, h, u = n.p1, c = {x: r, y: u.y, i: -1}, p = 1 / 0,
|
||
d = this.getIntersections_({p0: u, p1: c}, o, !0);
|
||
for (s = 0, a = d.length; s < a; ++s) {
|
||
var f = d[s], g = this.calculateIntersection_(u, c, f.p0, f.p1, !0), m = Math.abs(u.x - g[0]);
|
||
m < p && void 0 !== Wh(u.x, u.y, f.p0.x, f.p0.y, f.p1.x, f.p1.y) && (p = m, h = {
|
||
x: g[0],
|
||
y: g[1],
|
||
i: -1
|
||
}, n = f)
|
||
}
|
||
if (p === 1 / 0) return !1;
|
||
if (l = n.p1, p > 0) {
|
||
var y = this.getPointsInTriangle_(u, h, n.p1, o);
|
||
if (y.length) {
|
||
var v = 1 / 0;
|
||
for (s = 0, a = y.length; s < a; ++s) {
|
||
var _ = y[s], x = Math.atan2(u.y - _.y, c.x - _.x);
|
||
(x < v || x === v && _.x < l.x) && (v = x, l = _)
|
||
}
|
||
}
|
||
}
|
||
for (n = i.firstItem(); n.p1.x !== l.x || n.p1.y !== l.y;) n = i.nextItem();
|
||
var w = {x: u.x, y: u.y, i: u.i, reflex: void 0}, b = {x: n.p1.x, y: n.p1.y, i: n.p1.i, reflex: void 0};
|
||
return t.getNextItem().p0 = w, this.insertItem_(u, n.p1, t, o), this.insertItem_(b, w, t, o), n.p1 = b, t.setFirstItem(), i.concat(t), !0
|
||
}, e.prototype.triangulate_ = function (t, e) {
|
||
for (var i = !1, r = this.isSimple_(t, e); t.getLength() > 3;) if (r) {
|
||
if (!this.clipEars_(t, e, r, i) && !this.classifyPoints_(t, e, i) && !this.resolveSelfIntersections_(t, e, !0)) break
|
||
} else if (!this.clipEars_(t, e, r, i) && !this.classifyPoints_(t, e, i) && !this.resolveSelfIntersections_(t, e)) {
|
||
if (!(r = this.isSimple_(t, e))) {
|
||
this.splitPolygon_(t, e);
|
||
break
|
||
}
|
||
i = !this.isClockwise_(t), this.classifyPoints_(t, e, i)
|
||
}
|
||
if (3 === t.getLength()) {
|
||
var o = this.indices.length;
|
||
this.indices[o++] = t.getPrevItem().p0.i, this.indices[o++] = t.getCurrItem().p0.i, this.indices[o++] = t.getNextItem().p0.i
|
||
}
|
||
}, e.prototype.clipEars_ = function (t, e, i, r) {
|
||
var o, n, s, a = this.indices.length, l = t.firstItem(), h = t.getPrevItem(), u = l, c = t.nextItem(),
|
||
p = t.getNextItem(), d = !1;
|
||
do {
|
||
if (o = u.p0, n = u.p1, s = c.p1, !1 === n.reflex) {
|
||
var f = void 0;
|
||
f = i ? 0 === this.getPointsInTriangle_(o, n, s, e, !0).length : r ? this.diagonalIsInside_(p.p1, s, n, o, h.p0) : this.diagonalIsInside_(h.p0, o, n, s, p.p1), (i || 0 === this.getIntersections_({
|
||
p0: o,
|
||
p1: s
|
||
}, e).length) && f && (i || !1 === o.reflex || !1 === s.reflex || lr([h.p0.x, h.p0.y, o.x, o.y, n.x, n.y, s.x, s.y, p.p1.x, p.p1.y], 0, 10, 2) === !r) && (this.indices[a++] = o.i, this.indices[a++] = n.i, this.indices[a++] = s.i, this.removeItem_(u, c, t, e), c === l && (l = p), d = !0)
|
||
}
|
||
h = t.getPrevItem(), u = t.getCurrItem(), c = t.nextItem(), p = t.getNextItem()
|
||
} while (u !== l && t.getLength() > 3);
|
||
return d
|
||
}, e.prototype.resolveSelfIntersections_ = function (t, e, i) {
|
||
var r = t.firstItem();
|
||
t.nextItem();
|
||
var o = r, n = t.nextItem(), s = !1;
|
||
do {
|
||
var a = this.calculateIntersection_(o.p0, o.p1, n.p0, n.p1, i);
|
||
if (a) {
|
||
var l = !1, h = this.vertices.length, u = this.indices.length, c = h / 2, p = t.prevItem();
|
||
t.removeItem(), e.remove(p), l = p === r;
|
||
var d = void 0;
|
||
if (i ? (a[0] === o.p0.x && a[1] === o.p0.y ? (t.prevItem(), d = o.p0, n.p0 = d, e.remove(o), l = l || o === r) : (d = n.p1, o.p1 = d, e.remove(n), l = l || n === r), t.removeItem()) : (d = this.createPoint_(a[0], a[1], c), o.p1 = d, n.p0 = d, e.update([Math.min(o.p0.x, o.p1.x), Math.min(o.p0.y, o.p1.y), Math.max(o.p0.x, o.p1.x), Math.max(o.p0.y, o.p1.y)], o), e.update([Math.min(n.p0.x, n.p1.x), Math.min(n.p0.y, n.p1.y), Math.max(n.p0.x, n.p1.x), Math.max(n.p0.y, n.p1.y)], n)), this.indices[u++] = p.p0.i, this.indices[u++] = p.p1.i, this.indices[u++] = d.i, s = !0, l) break
|
||
}
|
||
o = t.getPrevItem(), n = t.nextItem()
|
||
} while (o !== r);
|
||
return s
|
||
}, e.prototype.isSimple_ = function (t, e) {
|
||
var i = t.firstItem(), r = i;
|
||
do {
|
||
if (this.getIntersections_(r, e).length) return !1;
|
||
r = t.nextItem()
|
||
} while (r !== i);
|
||
return !0
|
||
}, e.prototype.isClockwise_ = function (t) {
|
||
var e = 2 * t.getLength(), i = new Array(e), r = t.firstItem(), o = r, n = 0;
|
||
do {
|
||
i[n++] = o.p0.x, i[n++] = o.p0.y, o = t.nextItem()
|
||
} while (o !== r);
|
||
return lr(i, 0, e, 2)
|
||
}, e.prototype.splitPolygon_ = function (t, e) {
|
||
var i = t.firstItem(), r = i;
|
||
do {
|
||
var o = this.getIntersections_(r, e);
|
||
if (o.length) {
|
||
var n = o[0], s = this.vertices.length / 2,
|
||
a = this.calculateIntersection_(r.p0, r.p1, n.p0, n.p1),
|
||
l = this.createPoint_(a[0], a[1], s), h = new Cu, u = new Eu;
|
||
this.insertItem_(l, r.p1, h, u), r.p1 = l, e.update([Math.min(r.p0.x, l.x), Math.min(r.p0.y, l.y), Math.max(r.p0.x, l.x), Math.max(r.p0.y, l.y)], r);
|
||
for (var c = t.nextItem(); c !== n;) this.insertItem_(c.p0, c.p1, h, u), e.remove(c), t.removeItem(), c = t.getCurrItem();
|
||
this.insertItem_(n.p0, l, h, u), n.p0 = l, e.update([Math.min(n.p1.x, l.x), Math.min(n.p1.y, l.y), Math.max(n.p1.x, l.x), Math.max(n.p1.y, l.y)], n), this.classifyPoints_(t, e, !1), this.triangulate_(t, e), this.classifyPoints_(h, u, !1), this.triangulate_(h, u);
|
||
break
|
||
}
|
||
r = t.nextItem()
|
||
} while (r !== i)
|
||
}, e.prototype.createPoint_ = function (t, e, i) {
|
||
var r = this.vertices.length;
|
||
return this.vertices[r++] = t, this.vertices[r++] = e, {x: t, y: e, i: i, reflex: void 0}
|
||
}, e.prototype.insertItem_ = function (t, e, i, r) {
|
||
var o = {p0: t, p1: e};
|
||
return i.insertItem(o), r && r.insert([Math.min(t.x, e.x), Math.min(t.y, e.y), Math.max(t.x, e.x), Math.max(t.y, e.y)], o), o
|
||
}, e.prototype.removeItem_ = function (t, e, i, r) {
|
||
i.getCurrItem() === e && (i.removeItem(), t.p1 = e.p1, r.remove(e), r.update([Math.min(t.p0.x, t.p1.x), Math.min(t.p0.y, t.p1.y), Math.max(t.p0.x, t.p1.x), Math.max(t.p0.y, t.p1.y)], t))
|
||
}, e.prototype.getPointsInTriangle_ = function (t, e, i, r, o) {
|
||
for (var n = [], s = r.getInExtent([Math.min(t.x, e.x, i.x), Math.min(t.y, e.y, i.y), Math.max(t.x, e.x, i.x), Math.max(t.y, e.y, i.y)]), a = 0, l = s.length; a < l; ++a) for (var h in s[a]) {
|
||
var u = s[a][h];
|
||
"object" != typeof u || o && !u.reflex || u.x === t.x && u.y === t.y || u.x === e.x && u.y === e.y || u.x === i.x && u.y === i.y || -1 !== n.indexOf(u) || !Ki([t.x, t.y, e.x, e.y, i.x, i.y], 0, 6, 2, u.x, u.y) || n.push(u)
|
||
}
|
||
return n
|
||
}, e.prototype.getIntersections_ = function (t, e, i) {
|
||
for (var r = t.p0, o = t.p1, n = e.getInExtent([Math.min(r.x, o.x), Math.min(r.y, o.y), Math.max(r.x, o.x), Math.max(r.y, o.y)]), s = [], a = 0, l = n.length; a < l; ++a) {
|
||
var h = n[a];
|
||
t !== h && (i || h.p0 !== o || h.p1 !== r) && this.calculateIntersection_(r, o, h.p0, h.p1, i) && s.push(h)
|
||
}
|
||
return s
|
||
}, e.prototype.calculateIntersection_ = function (t, e, i, r, o) {
|
||
var n = (r.y - i.y) * (e.x - t.x) - (r.x - i.x) * (e.y - t.y);
|
||
if (0 !== n) {
|
||
var s = ((r.x - i.x) * (t.y - i.y) - (r.y - i.y) * (t.x - i.x)) / n,
|
||
a = ((e.x - t.x) * (t.y - i.y) - (e.y - t.y) * (t.x - i.x)) / n;
|
||
if (!o && s > Yh && s < 1 - Yh && a > Yh && a < 1 - Yh || o && s >= 0 && s <= 1 && a >= 0 && a <= 1) return [t.x + s * (e.x - t.x), t.y + s * (e.y - t.y)]
|
||
}
|
||
}, e.prototype.diagonalIsInside_ = function (t, e, i, r, o) {
|
||
if (void 0 === e.reflex || void 0 === r.reflex) return !1;
|
||
var n = (i.x - r.x) * (e.y - r.y) > (i.y - r.y) * (e.x - r.x),
|
||
s = (o.x - r.x) * (e.y - r.y) < (o.y - r.y) * (e.x - r.x),
|
||
a = (t.x - e.x) * (r.y - e.y) > (t.y - e.y) * (r.x - e.x),
|
||
l = (i.x - e.x) * (r.y - e.y) < (i.y - e.y) * (r.x - e.x), h = r.reflex ? s || n : s && n,
|
||
u = e.reflex ? l || a : l && a;
|
||
return h && u
|
||
}, e.prototype.drawMultiPolygon = function (t, e) {
|
||
var i, r, o, n, s = t.getEndss(), a = t.getStride(), l = this.indices.length,
|
||
h = this.lineStringReplay.getCurrentIndex(), u = t.getFlatCoordinates(), c = 0;
|
||
for (i = 0, r = s.length; i < r; ++i) {
|
||
var p = s[i];
|
||
if (p.length > 0) {
|
||
var d = Qt(u, c, p[0], a, -this.origin[0], -this.origin[1]);
|
||
if (d.length) {
|
||
var f = [], g = void 0;
|
||
for (o = 1, n = p.length; o < n; ++o) p[o] !== p[o - 1] && (g = Qt(u, p[o - 1], p[o], a, -this.origin[0], -this.origin[1]), f.push(g));
|
||
this.lineStringReplay.drawPolygonCoordinates(d, f, a), this.drawCoordinates_(d, f, a)
|
||
}
|
||
}
|
||
c = p[p.length - 1]
|
||
}
|
||
this.indices.length > l && (this.startIndices.push(l), this.startIndicesFeature.push(e), this.state_.changed && (this.styleIndices_.push(l), this.state_.changed = !1)), this.lineStringReplay.getCurrentIndex() > h && this.lineStringReplay.setPolygonStyle(e, h)
|
||
}, e.prototype.drawPolygon = function (t, e) {
|
||
var i = t.getEnds(), r = t.getStride();
|
||
if (i.length > 0) {
|
||
var o = t.getFlatCoordinates().map(Number), n = Qt(o, 0, i[0], r, -this.origin[0], -this.origin[1]);
|
||
if (n.length) {
|
||
var s, a, l, h = [];
|
||
for (s = 1, a = i.length; s < a; ++s) i[s] !== i[s - 1] && (l = Qt(o, i[s - 1], i[s], r, -this.origin[0], -this.origin[1]), h.push(l));
|
||
this.startIndices.push(this.indices.length), this.startIndicesFeature.push(e), this.state_.changed && (this.styleIndices_.push(this.indices.length), this.state_.changed = !1), this.lineStringReplay.setPolygonStyle(e), this.lineStringReplay.drawPolygonCoordinates(n, h, r), this.drawCoordinates_(n, h, r)
|
||
}
|
||
}
|
||
}, e.prototype.finish = function (t) {
|
||
this.verticesBuffer = new qh(this.vertices), this.indicesBuffer = new qh(this.indices), this.startIndices.push(this.indices.length), this.lineStringReplay.finish(t), 0 === this.styleIndices_.length && this.styles_.length > 0 && (this.styles_ = []), this.vertices = null, this.indices = null
|
||
}, e.prototype.getDeleteResourcesFunction = function (t) {
|
||
var e = this.verticesBuffer, i = this.indicesBuffer,
|
||
r = this.lineStringReplay.getDeleteResourcesFunction(t);
|
||
return function () {
|
||
t.deleteBuffer(e), t.deleteBuffer(i), r()
|
||
}
|
||
}, e.prototype.setUpProgram = function (t, e, i, r) {
|
||
var o, n = e.getProgram(_u, xu);
|
||
return this.defaultLocations_ ? o = this.defaultLocations_ : (o = new wu(t, n), this.defaultLocations_ = o), e.useProgram(n), t.enableVertexAttribArray(o.a_position), t.vertexAttribPointer(o.a_position, 2, 5126, !1, 8, 0), o
|
||
}, e.prototype.shutDownProgram = function (t, e) {
|
||
t.disableVertexAttribArray(e.a_position)
|
||
}, e.prototype.drawReplay = function (t, e, i, r) {
|
||
var o, n, s, a, l = t.getParameter(t.DEPTH_FUNC), h = t.getParameter(t.DEPTH_WRITEMASK);
|
||
if (r || (t.enable(t.DEPTH_TEST), t.depthMask(!0), t.depthFunc(t.NOTEQUAL)), g(i)) for (s = this.startIndices[this.startIndices.length - 1], o = this.styleIndices_.length - 1; o >= 0; --o) n = this.styleIndices_[o], a = this.styles_[o], this.setFillStyle_(t, a), this.drawElements(t, e, n, s), s = n; else this.drawReplaySkipping_(t, e, i);
|
||
r || (t.disable(t.DEPTH_TEST), t.clear(t.DEPTH_BUFFER_BIT), t.depthMask(h), t.depthFunc(l))
|
||
}, e.prototype.drawHitDetectionReplayOneByOne = function (t, e, i, r, o) {
|
||
var n, s, l, h, u, c, p;
|
||
for (p = this.startIndices.length - 2, l = this.startIndices[p + 1], n = this.styleIndices_.length - 1; n >= 0; --n) for (h = this.styles_[n], this.setFillStyle_(t, h), u = this.styleIndices_[n]; p >= 0 && this.startIndices[p] >= u;) {
|
||
if (s = this.startIndices[p], void 0 === i[a(c = this.startIndicesFeature[p])] && c.getGeometry() && (void 0 === o || Bt(o, c.getGeometry().getExtent()))) {
|
||
t.clear(t.COLOR_BUFFER_BIT | t.DEPTH_BUFFER_BIT), this.drawElements(t, e, s, l);
|
||
var d = r(c);
|
||
if (d) return d
|
||
}
|
||
p--, l = s
|
||
}
|
||
}, e.prototype.drawReplaySkipping_ = function (t, e, i) {
|
||
var r, o, n, s, l, h, u;
|
||
for (h = this.startIndices.length - 2, n = o = this.startIndices[h + 1], r = this.styleIndices_.length - 1; r >= 0; --r) {
|
||
for (s = this.styles_[r], this.setFillStyle_(t, s), l = this.styleIndices_[r]; h >= 0 && this.startIndices[h] >= l;) u = this.startIndices[h], i[a(this.startIndicesFeature[h])] && (o !== n && (this.drawElements(t, e, o, n), t.clear(t.DEPTH_BUFFER_BIT)), n = u), h--, o = u;
|
||
o !== n && (this.drawElements(t, e, o, n), t.clear(t.DEPTH_BUFFER_BIT)), o = n = l
|
||
}
|
||
}, e.prototype.setFillStyle_ = function (t, e) {
|
||
t.uniform4fv(this.defaultLocations_.u_color, e)
|
||
}, e.prototype.setFillStrokeStyle = function (t, e) {
|
||
var i = t ? t.getColor() : [0, 0, 0, 0];
|
||
if (i = i instanceof CanvasGradient || i instanceof CanvasPattern ? Uh : lo(i).map(function (t, e) {
|
||
return 3 != e ? t / 255 : t
|
||
}) || Uh, this.state_.fillColor && it(i, this.state_.fillColor) || (this.state_.fillColor = i, this.state_.changed = !0, this.styles_.push(i)), e) this.lineStringReplay.setFillStrokeStyle(null, e); else {
|
||
var r = new go({color: [0, 0, 0, 0], width: 0});
|
||
this.lineStringReplay.setFillStrokeStyle(null, r)
|
||
}
|
||
}, e
|
||
}(zh), Ru = function (t, e) {
|
||
this.space_ = e, this.emptyBlocks_ = [{
|
||
x: 0,
|
||
y: 0,
|
||
width: t,
|
||
height: t
|
||
}], this.entries_ = {}, this.context_ = Ao(t, t), this.canvas_ = this.context_.canvas
|
||
};
|
||
Ru.prototype.get = function (t) {
|
||
return this.entries_[t] || null
|
||
}, Ru.prototype.add = function (t, e, i, r, o) {
|
||
for (var n = 0, s = this.emptyBlocks_.length; n < s; ++n) {
|
||
var a = this.emptyBlocks_[n];
|
||
if (a.width >= e + this.space_ && a.height >= i + this.space_) {
|
||
var l = {offsetX: a.x + this.space_, offsetY: a.y + this.space_, image: this.canvas_};
|
||
return this.entries_[t] = l, r.call(o, this.context_, a.x + this.space_, a.y + this.space_), this.split_(n, a, e + this.space_, i + this.space_), l
|
||
}
|
||
}
|
||
return null
|
||
}, Ru.prototype.split_ = function (t, e, i, r) {
|
||
var o, n;
|
||
e.width - i > e.height - r ? (o = {x: e.x + i, y: e.y, width: e.width - i, height: e.height}, n = {
|
||
x: e.x,
|
||
y: e.y + r,
|
||
width: i,
|
||
height: e.height - r
|
||
}, this.updateBlocks_(t, o, n)) : (o = {x: e.x + i, y: e.y, width: e.width - i, height: r}, n = {
|
||
x: e.x,
|
||
y: e.y + r,
|
||
width: e.width,
|
||
height: e.height - r
|
||
}, this.updateBlocks_(t, o, n))
|
||
}, Ru.prototype.updateBlocks_ = function (t, e, i) {
|
||
var r = [t, 1];
|
||
e.width > 0 && e.height > 0 && r.push(e), i.width > 0 && i.height > 0 && r.push(i), this.emptyBlocks_.splice.apply(this.emptyBlocks_, r)
|
||
};
|
||
var Pu = Ru, Lu = function (t) {
|
||
var e = t || {};
|
||
this.currentSize_ = void 0 !== e.initialSize ? e.initialSize : 256, this.maxSize_ = void 0 !== e.maxSize ? e.maxSize : void 0 !== Ph ? Ph : 2048, this.space_ = void 0 !== e.space ? e.space : 1, this.atlases_ = [new Pu(this.currentSize_, this.space_)], this.currentHitSize_ = this.currentSize_, this.hitAtlases_ = [new Pu(this.currentHitSize_, this.space_)]
|
||
};
|
||
Lu.prototype.getInfo = function (t) {
|
||
var e = this.getInfo_(this.atlases_, t);
|
||
if (!e) return null;
|
||
var i = this.getInfo_(this.hitAtlases_, t);
|
||
return this.mergeInfos_(e, i)
|
||
}, Lu.prototype.getInfo_ = function (t, e) {
|
||
for (var i = 0, r = t.length; i < r; ++i) {
|
||
var o = t[i].get(e);
|
||
if (o) return o
|
||
}
|
||
return null
|
||
}, Lu.prototype.mergeInfos_ = function (t, e) {
|
||
return {offsetX: t.offsetX, offsetY: t.offsetY, image: t.image, hitImage: e.image}
|
||
}, Lu.prototype.add = function (t, e, i, r, o, n) {
|
||
if (e + this.space_ > this.maxSize_ || i + this.space_ > this.maxSize_) return null;
|
||
var s = this.add_(!1, t, e, i, r, n);
|
||
if (!s) return null;
|
||
var a = void 0 !== o ? o : I, l = this.add_(!0, t, e, i, a, n);
|
||
return this.mergeInfos_(s, l)
|
||
}, Lu.prototype.add_ = function (t, e, i, r, o, n) {
|
||
var s, a, l, h, u = t ? this.hitAtlases_ : this.atlases_;
|
||
for (l = 0, h = u.length; l < h; ++l) {
|
||
if (a = (s = u[l]).add(e, i, r, o, n)) return a;
|
||
if (!a && l === h - 1) {
|
||
var c = void 0;
|
||
t ? (c = Math.min(2 * this.currentHitSize_, this.maxSize_), this.currentHitSize_ = c) : (c = Math.min(2 * this.currentSize_, this.maxSize_), this.currentSize_ = c), s = new Pu(c, this.space_), u.push(s), ++h
|
||
}
|
||
}
|
||
return null
|
||
};
|
||
var Iu = Lu, Ou = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e, i), this.images_ = [], this.textures_ = [], this.measureCanvas_ = Ao(0, 0).canvas, this.state_ = {
|
||
strokeColor: null,
|
||
lineCap: void 0,
|
||
lineDash: null,
|
||
lineDashOffset: void 0,
|
||
lineJoin: void 0,
|
||
lineWidth: 0,
|
||
miterLimit: void 0,
|
||
fillColor: null,
|
||
font: void 0,
|
||
scale: void 0
|
||
}, this.text_ = "", this.textAlign_ = void 0, this.textBaseline_ = void 0, this.offsetX_ = void 0, this.offsetY_ = void 0, this.atlases_ = {}, this.currAtlas_ = void 0, this.scale = 1, this.opacity = 1
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.drawText = function (t, e) {
|
||
if (this.text_) {
|
||
var i = null, r = 2, o = 2;
|
||
switch (t.getType()) {
|
||
case Zt.POINT:
|
||
case Zt.MULTI_POINT:
|
||
r = (i = t.getFlatCoordinates()).length, o = t.getStride();
|
||
break;
|
||
case Zt.CIRCLE:
|
||
i = t.getCenter();
|
||
break;
|
||
case Zt.LINE_STRING:
|
||
i = t.getFlatMidpoint();
|
||
break;
|
||
case Zt.MULTI_LINE_STRING:
|
||
r = (i = t.getFlatMidpoints()).length;
|
||
break;
|
||
case Zt.POLYGON:
|
||
i = t.getFlatInteriorPoint();
|
||
break;
|
||
case Zt.MULTI_POLYGON:
|
||
r = (i = t.getFlatInteriorPoints()).length
|
||
}
|
||
this.startIndices.push(this.indices.length), this.startIndicesFeature.push(e);
|
||
var n, s, l, h, u, c, p, d, f = this.currAtlas_, g = this.text_.split("\n"),
|
||
m = this.getTextSize_(g), y = Math.round(m[0] * this.textAlign_ - this.offsetX_),
|
||
v = Math.round(m[1] * this.textBaseline_ - this.offsetY_),
|
||
_ = this.state_.lineWidth / 2 * this.state_.scale;
|
||
for (n = 0, s = g.length; n < s; ++n) for (u = 0, c = f.height * n, l = 0, h = (p = g[n].split("")).length; l < h; ++l) {
|
||
if (d = f.atlas.getInfo(p[l])) {
|
||
var x = d.image;
|
||
if (this.anchorX = y - u, this.anchorY = v - c, this.originX = 0 === l ? d.offsetX - _ : d.offsetX, this.originY = d.offsetY, this.height = f.height, this.width = 0 === l || l === p.length - 1 ? f.width[p[l]] + _ : f.width[p[l]], this.imageHeight = x.height, this.imageWidth = x.width, 0 === this.images_.length) this.images_.push(x); else a(this.images_[this.images_.length - 1]) != a(x) && (this.groupIndices.push(this.indices.length), this.images_.push(x));
|
||
this.drawText_(i, 0, r, o)
|
||
}
|
||
u += this.width
|
||
}
|
||
}
|
||
}, e.prototype.getTextSize_ = function (t) {
|
||
var e = this, i = this.currAtlas_, r = t.length * i.height;
|
||
return [t.map(function (t) {
|
||
for (var r = 0, o = 0, n = t.length; o < n; ++o) {
|
||
var s = t[o];
|
||
i.width[s] || e.addCharToAtlas_(s), r += i.width[s] ? i.width[s] : 0
|
||
}
|
||
return r
|
||
}).reduce(function (t, e) {
|
||
return Math.max(t, e)
|
||
}), r]
|
||
}, e.prototype.drawText_ = function (t, e, i, r) {
|
||
for (var o = e, n = i; o < n; o += r) this.drawCoordinates(t, e, i, r)
|
||
}, e.prototype.addCharToAtlas_ = function (t) {
|
||
if (1 === t.length) {
|
||
var e = this.currAtlas_, i = this.state_, r = this.measureCanvas_.getContext("2d");
|
||
r.font = i.font;
|
||
var o = Math.ceil(r.measureText(t).width * i.scale);
|
||
e.atlas.add(t, o, e.height, function (e, r, o) {
|
||
e.font = i.font, e.fillStyle = i.fillColor, e.strokeStyle = i.strokeColor, e.lineWidth = i.lineWidth, e.lineCap = i.lineCap, e.lineJoin = i.lineJoin, e.miterLimit = i.miterLimit, e.textAlign = "left", e.textBaseline = "top", Er && i.lineDash && (e.setLineDash(i.lineDash), e.lineDashOffset = i.lineDashOffset), 1 !== i.scale && e.setTransform(i.scale, 0, 0, i.scale, 0, 0), i.strokeColor && e.strokeText(t, r, o), i.fillColor && e.fillText(t, r, o)
|
||
}) && (e.width[t] = o)
|
||
}
|
||
}, e.prototype.finish = function (e) {
|
||
var i = e.getGL();
|
||
this.groupIndices.push(this.indices.length), this.hitDetectionGroupIndices = this.groupIndices, this.verticesBuffer = new qh(this.vertices), this.indicesBuffer = new qh(this.indices);
|
||
this.createTextures(this.textures_, this.images_, {}, i), this.state_ = {
|
||
strokeColor: null,
|
||
lineCap: void 0,
|
||
lineDash: null,
|
||
lineDashOffset: void 0,
|
||
lineJoin: void 0,
|
||
lineWidth: 0,
|
||
miterLimit: void 0,
|
||
fillColor: null,
|
||
font: void 0,
|
||
scale: void 0
|
||
}, this.text_ = "", this.textAlign_ = void 0, this.textBaseline_ = void 0, this.offsetX_ = void 0, this.offsetY_ = void 0, this.images_ = null, this.atlases_ = {}, this.currAtlas_ = void 0, t.prototype.finish.call(this, e)
|
||
}, e.prototype.setTextStyle = function (t) {
|
||
var e = this.state_, i = t.getFill(), r = t.getStroke();
|
||
if (t && t.getText() && (i || r)) {
|
||
if (i) {
|
||
var o = i.getColor();
|
||
e.fillColor = Wa(o || Uh)
|
||
} else e.fillColor = null;
|
||
if (r) {
|
||
var n = r.getColor();
|
||
e.strokeColor = Wa(n || Vh), e.lineWidth = r.getWidth() || 1, e.lineCap = r.getLineCap() || "round", e.lineDashOffset = r.getLineDashOffset() || 0, e.lineJoin = r.getLineJoin() || "round", e.miterLimit = r.getMiterLimit() || 10;
|
||
var s = r.getLineDash();
|
||
e.lineDash = s ? s.slice() : Bh
|
||
} else e.strokeColor = null, e.lineWidth = 0;
|
||
e.font = t.getFont() || "10px sans-serif", e.scale = t.getScale() || 1, this.text_ = t.getText();
|
||
var a = Pl[t.getTextAlign()], l = Pl[t.getTextBaseline()];
|
||
this.textAlign_ = void 0 === a ? .5 : a, this.textBaseline_ = void 0 === l ? .5 : l, this.offsetX_ = t.getOffsetX() || 0, this.offsetY_ = t.getOffsetY() || 0, this.rotateWithView = !!t.getRotateWithView(), this.rotation = t.getRotation() || 0, this.currAtlas_ = this.getAtlas_(e)
|
||
} else this.text_ = ""
|
||
}, e.prototype.getAtlas_ = function (t) {
|
||
var e = [];
|
||
for (var i in t) (t[i] || 0 === t[i]) && (Array.isArray(t[i]) ? e = e.concat(t[i]) : e.push(t[i]));
|
||
var r = this.calculateHash_(e);
|
||
if (!this.atlases_[r]) {
|
||
var o = this.measureCanvas_.getContext("2d");
|
||
o.font = t.font;
|
||
var n = Math.ceil((1.5 * o.measureText("M").width + t.lineWidth / 2) * t.scale);
|
||
this.atlases_[r] = {atlas: new Iu({space: t.lineWidth + 1}), width: {}, height: n}
|
||
}
|
||
return this.atlases_[r]
|
||
}, e.prototype.calculateHash_ = function (t) {
|
||
for (var e = "", i = 0, r = t.length; i < r; ++i) e += t[i];
|
||
return e
|
||
}, e.prototype.getTextures = function (t) {
|
||
return this.textures_
|
||
}, e.prototype.getHitDetectionTextures = function () {
|
||
return this.textures_
|
||
}, e
|
||
}(ou), Mu = [1, 1], Au = {Circle: Zh, Image: nu, LineString: vu, Polygon: Tu, Text: Ou}, ku = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this), this.maxExtent_ = i, this.tolerance_ = e, this.renderBuffer_ = r, this.replaysByZIndex_ = {}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.addDeclutter = function (t) {
|
||
return []
|
||
}, e.prototype.getDeleteResourcesFunction = function (t) {
|
||
var e, i = [];
|
||
for (e in this.replaysByZIndex_) {
|
||
var r = this.replaysByZIndex_[e];
|
||
for (var o in r) i.push(r[o].getDeleteResourcesFunction(t))
|
||
}
|
||
return function () {
|
||
for (var t, e = arguments, r = i.length, o = 0; o < r; o++) t = i[o].apply(this, e);
|
||
return t
|
||
}
|
||
}, e.prototype.finish = function (t) {
|
||
var e;
|
||
for (e in this.replaysByZIndex_) {
|
||
var i = this.replaysByZIndex_[e];
|
||
for (var r in i) i[r].finish(t)
|
||
}
|
||
}, e.prototype.getReplay = function (t, e) {
|
||
var i = void 0 !== t ? t.toString() : "0", r = this.replaysByZIndex_[i];
|
||
void 0 === r && (r = {}, this.replaysByZIndex_[i] = r);
|
||
var o = r[e];
|
||
void 0 === o && (o = new (0, Au[e])(this.tolerance_, this.maxExtent_), r[e] = o);
|
||
return o
|
||
}, e.prototype.isEmpty = function () {
|
||
return g(this.replaysByZIndex_)
|
||
}, e.prototype.replay = function (t, e, i, r, o, n, s, a) {
|
||
var l, h, u, c, p, d, f = Object.keys(this.replaysByZIndex_).map(Number);
|
||
for (f.sort(Z), l = 0, h = f.length; l < h; ++l) for (p = this.replaysByZIndex_[f[l].toString()], u = 0, c = Rl.length; u < c; ++u) d = p[Rl[u]], void 0 !== d && d.replay(t, e, i, r, o, n, s, a, void 0, !1)
|
||
}, e.prototype.replayHitDetection_ = function (t, e, i, r, o, n, s, a, l, h, u) {
|
||
var c, p, d, f, g, m, y = Object.keys(this.replaysByZIndex_).map(Number);
|
||
for (y.sort(function (t, e) {
|
||
return e - t
|
||
}), c = 0, p = y.length; c < p; ++c) for (f = this.replaysByZIndex_[y[c].toString()], d = Rl.length - 1; d >= 0; --d) if (void 0 !== (g = f[Rl[d]]) && (m = g.replay(t, e, i, r, o, n, s, a, l, h, u))) return m
|
||
}, e.prototype.forEachFeatureAtCoordinate = function (t, e, i, r, o, n, s, a, l, h) {
|
||
var u, c = e.getGL();
|
||
return c.bindFramebuffer(c.FRAMEBUFFER, e.getHitDetectionFramebuffer()), void 0 !== this.renderBuffer_ && (u = ht(_t(t), r * this.renderBuffer_)), this.replayHitDetection_(e, t, r, o, Mu, s, a, l, function (t) {
|
||
var e = new Uint8Array(4);
|
||
if (c.readPixels(0, 0, 1, 1, c.RGBA, c.UNSIGNED_BYTE, e), e[3] > 0) {
|
||
var i = h(t);
|
||
if (i) return i
|
||
}
|
||
}, !0, u)
|
||
}, e.prototype.hasFeatureAtCoordinate = function (t, e, i, r, o, n, s, a, l) {
|
||
var h = e.getGL();
|
||
return h.bindFramebuffer(h.FRAMEBUFFER, e.getHitDetectionFramebuffer()), void 0 !== this.replayHitDetection_(e, t, r, o, Mu, s, a, l, function (t) {
|
||
var e = new Uint8Array(4);
|
||
return h.readPixels(0, 0, 1, 1, h.RGBA, h.UNSIGNED_BYTE, e), e[3] > 0
|
||
}, !1)
|
||
}, e
|
||
}(vl), Fu = function (t) {
|
||
function e(e, i, r, o, n, s, a) {
|
||
t.call(this), this.context_ = e, this.center_ = i, this.extent_ = s, this.pixelRatio_ = a, this.size_ = n, this.rotation_ = o, this.resolution_ = r, this.imageStyle_ = null, this.fillStyle_ = null, this.strokeStyle_ = null, this.textStyle_ = null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.drawText_ = function (t, e) {
|
||
var i = this.context_, r = t.getReplay(0, _l.TEXT);
|
||
r.setTextStyle(this.textStyle_), r.drawText(e, null), r.finish(i);
|
||
r.replay(this.context_, this.center_, this.resolution_, this.rotation_, this.size_, this.pixelRatio_, 1, {}, void 0, !1), r.getDeleteResourcesFunction(i)()
|
||
}, e.prototype.setStyle = function (t) {
|
||
this.setFillStrokeStyle(t.getFill(), t.getStroke()), this.setImageStyle(t.getImage()), this.setTextStyle(t.getText())
|
||
}, e.prototype.drawGeometry = function (t) {
|
||
switch (t.getType()) {
|
||
case Zt.POINT:
|
||
this.drawPoint(t, null);
|
||
break;
|
||
case Zt.LINE_STRING:
|
||
this.drawLineString(t, null);
|
||
break;
|
||
case Zt.POLYGON:
|
||
this.drawPolygon(t, null);
|
||
break;
|
||
case Zt.MULTI_POINT:
|
||
this.drawMultiPoint(t, null);
|
||
break;
|
||
case Zt.MULTI_LINE_STRING:
|
||
this.drawMultiLineString(t, null);
|
||
break;
|
||
case Zt.MULTI_POLYGON:
|
||
this.drawMultiPolygon(t, null);
|
||
break;
|
||
case Zt.GEOMETRY_COLLECTION:
|
||
this.drawGeometryCollection(t, null);
|
||
break;
|
||
case Zt.CIRCLE:
|
||
this.drawCircle(t, null)
|
||
}
|
||
}, e.prototype.drawFeature = function (t, e) {
|
||
var i = e.getGeometryFunction()(t);
|
||
i && Bt(this.extent_, i.getExtent()) && (this.setStyle(e), this.drawGeometry(i))
|
||
}, e.prototype.drawGeometryCollection = function (t, e) {
|
||
var i, r, o = t.getGeometriesArray();
|
||
for (i = 0, r = o.length; i < r; ++i) this.drawGeometry(o[i])
|
||
}, e.prototype.drawPoint = function (t, e) {
|
||
var i = this.context_, r = new ku(1, this.extent_), o = r.getReplay(0, _l.IMAGE);
|
||
o.setImageStyle(this.imageStyle_), o.drawPoint(t, e), o.finish(i);
|
||
o.replay(this.context_, this.center_, this.resolution_, this.rotation_, this.size_, this.pixelRatio_, 1, {}, void 0, !1), o.getDeleteResourcesFunction(i)(), this.textStyle_ && this.drawText_(r, t)
|
||
}, e.prototype.drawMultiPoint = function (t, e) {
|
||
var i = this.context_, r = new ku(1, this.extent_), o = r.getReplay(0, _l.IMAGE);
|
||
o.setImageStyle(this.imageStyle_), o.drawMultiPoint(t, e), o.finish(i);
|
||
o.replay(this.context_, this.center_, this.resolution_, this.rotation_, this.size_, this.pixelRatio_, 1, {}, void 0, !1), o.getDeleteResourcesFunction(i)(), this.textStyle_ && this.drawText_(r, t)
|
||
}, e.prototype.drawLineString = function (t, e) {
|
||
var i = this.context_, r = new ku(1, this.extent_), o = r.getReplay(0, _l.LINE_STRING);
|
||
o.setFillStrokeStyle(null, this.strokeStyle_), o.drawLineString(t, e), o.finish(i);
|
||
o.replay(this.context_, this.center_, this.resolution_, this.rotation_, this.size_, this.pixelRatio_, 1, {}, void 0, !1), o.getDeleteResourcesFunction(i)(), this.textStyle_ && this.drawText_(r, t)
|
||
}, e.prototype.drawMultiLineString = function (t, e) {
|
||
var i = this.context_, r = new ku(1, this.extent_), o = r.getReplay(0, _l.LINE_STRING);
|
||
o.setFillStrokeStyle(null, this.strokeStyle_), o.drawMultiLineString(t, e), o.finish(i);
|
||
o.replay(this.context_, this.center_, this.resolution_, this.rotation_, this.size_, this.pixelRatio_, 1, {}, void 0, !1), o.getDeleteResourcesFunction(i)(), this.textStyle_ && this.drawText_(r, t)
|
||
}, e.prototype.drawPolygon = function (t, e) {
|
||
var i = this.context_, r = new ku(1, this.extent_), o = r.getReplay(0, _l.POLYGON);
|
||
o.setFillStrokeStyle(this.fillStyle_, this.strokeStyle_), o.drawPolygon(t, e), o.finish(i);
|
||
o.replay(this.context_, this.center_, this.resolution_, this.rotation_, this.size_, this.pixelRatio_, 1, {}, void 0, !1), o.getDeleteResourcesFunction(i)(), this.textStyle_ && this.drawText_(r, t)
|
||
}, e.prototype.drawMultiPolygon = function (t, e) {
|
||
var i = this.context_, r = new ku(1, this.extent_), o = r.getReplay(0, _l.POLYGON);
|
||
o.setFillStrokeStyle(this.fillStyle_, this.strokeStyle_), o.drawMultiPolygon(t, e), o.finish(i);
|
||
o.replay(this.context_, this.center_, this.resolution_, this.rotation_, this.size_, this.pixelRatio_, 1, {}, void 0, !1), o.getDeleteResourcesFunction(i)(), this.textStyle_ && this.drawText_(r, t)
|
||
}, e.prototype.drawCircle = function (t, e) {
|
||
var i = this.context_, r = new ku(1, this.extent_), o = r.getReplay(0, _l.CIRCLE);
|
||
o.setFillStrokeStyle(this.fillStyle_, this.strokeStyle_), o.drawCircle(t, e), o.finish(i);
|
||
o.replay(this.context_, this.center_, this.resolution_, this.rotation_, this.size_, this.pixelRatio_, 1, {}, void 0, !1), o.getDeleteResourcesFunction(i)(), this.textStyle_ && this.drawText_(r, t)
|
||
}, e.prototype.setImageStyle = function (t) {
|
||
this.imageStyle_ = t
|
||
}, e.prototype.setFillStrokeStyle = function (t, e) {
|
||
this.fillStyle_ = t, this.strokeStyle_ = e
|
||
}, e.prototype.setTextStyle = function (t) {
|
||
this.textStyle_ = t
|
||
}, e
|
||
}(Xa),
|
||
Nu = new Ah("precision mediump float;\nvarying vec2 v_texCoord;\n\n\nuniform float u_opacity;\nuniform sampler2D u_texture;\n\nvoid main(void) {\n vec4 texColor = texture2D(u_texture, v_texCoord);\n gl_FragColor.rgb = texColor.rgb;\n gl_FragColor.a = texColor.a * u_opacity;\n}\n"),
|
||
Du = new kh("varying vec2 v_texCoord;\n\n\nattribute vec2 a_position;\nattribute vec2 a_texCoord;\n\nuniform mat4 u_texCoordMatrix;\nuniform mat4 u_projectionMatrix;\n\nvoid main(void) {\n gl_Position = u_projectionMatrix * vec4(a_position, 0., 1.);\n v_texCoord = (u_texCoordMatrix * vec4(a_texCoord, 0., 1.)).st;\n}\n\n\n"),
|
||
Gu = function (t, e) {
|
||
this.u_texCoordMatrix = t.getUniformLocation(e, "u_texCoordMatrix"), this.u_projectionMatrix = t.getUniformLocation(e, "u_projectionMatrix"), this.u_opacity = t.getUniformLocation(e, "u_opacity"), this.u_texture = t.getUniformLocation(e, "u_texture"), this.a_position = t.getAttribLocation(e, "a_position"), this.a_texCoord = t.getAttribLocation(e, "a_texCoord")
|
||
}, ju = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, i), this.mapRenderer = e, this.arrayBuffer_ = new qh([-1, -1, 0, 0, 1, -1, 1, 0, -1, 1, 0, 1, 1, 1, 1, 1]), this.texture = null, this.framebuffer = null, this.framebufferDimension = void 0, this.texCoordMatrix = [1, 0, 0, 1, 0, 0], this.projectionMatrix = [1, 0, 0, 1, 0, 0], this.tmpMat4_ = [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1], this.defaultLocations_ = null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.bindFramebuffer = function (t, e) {
|
||
var i = this.mapRenderer.getGL();
|
||
if (void 0 === this.framebufferDimension || this.framebufferDimension != e) {
|
||
var r = function (t, e, i) {
|
||
t.isContextLost() || (t.deleteFramebuffer(e), t.deleteTexture(i))
|
||
}.bind(null, i, this.framebuffer, this.texture);
|
||
t.postRenderFunctions.push(r);
|
||
var o = eu(i, e, e), n = i.createFramebuffer();
|
||
i.bindFramebuffer(36160, n), i.framebufferTexture2D(36160, 36064, Eh, o, 0), this.texture = o, this.framebuffer = n, this.framebufferDimension = e
|
||
} else i.bindFramebuffer(36160, this.framebuffer)
|
||
}, e.prototype.composeFrame = function (t, e, i) {
|
||
this.dispatchComposeEvent_(eo.PRECOMPOSE, i, t), i.bindBuffer(34962, this.arrayBuffer_);
|
||
var r, o = i.getGL(), n = i.getProgram(Nu, Du);
|
||
this.defaultLocations_ ? r = this.defaultLocations_ : (r = new Gu(o, n), this.defaultLocations_ = r), i.useProgram(n) && (o.enableVertexAttribArray(r.a_position), o.vertexAttribPointer(r.a_position, 2, 5126, !1, 16, 0), o.enableVertexAttribArray(r.a_texCoord), o.vertexAttribPointer(r.a_texCoord, 2, 5126, !1, 16, 8), o.uniform1i(r.u_texture, 0)), o.uniformMatrix4fv(r.u_texCoordMatrix, !1, jh(this.tmpMat4_, this.getTexCoordMatrix())), o.uniformMatrix4fv(r.u_projectionMatrix, !1, jh(this.tmpMat4_, this.getProjectionMatrix())), o.uniform1f(r.u_opacity, e.opacity), o.bindTexture(Eh, this.getTexture()), o.drawArrays(5, 0, 4), this.dispatchComposeEvent_(eo.POSTCOMPOSE, i, t)
|
||
}, e.prototype.dispatchComposeEvent_ = function (t, e, i) {
|
||
var r = this.getLayer();
|
||
if (r.hasListener(t)) {
|
||
var o = i.viewState, n = o.resolution, s = i.pixelRatio, a = i.extent, l = o.center, h = o.rotation,
|
||
u = i.size, c = new Fu(e, l, n, h, u, a, s), p = new Ta(t, c, i, null, e);
|
||
r.dispatchEvent(p)
|
||
}
|
||
}, e.prototype.getTexCoordMatrix = function () {
|
||
return this.texCoordMatrix
|
||
}, e.prototype.getTexture = function () {
|
||
return this.texture
|
||
}, e.prototype.getProjectionMatrix = function () {
|
||
return this.projectionMatrix
|
||
}, e.prototype.handleWebGLContextLost = function () {
|
||
this.texture = null, this.framebuffer = null, this.framebufferDimension = void 0
|
||
}, e.prototype.prepareFrame = function (t, e, i) {
|
||
return n()
|
||
}, e.prototype.forEachLayerAtPixel = function (t, e, i, r) {
|
||
return n()
|
||
}, e
|
||
}(nl), zu = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e, i), this.image_ = null, this.hitCanvasContext_ = null, this.hitTransformationMatrix_ = null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.createTexture_ = function (t) {
|
||
var e = t.getImage();
|
||
return iu(this.mapRenderer.getGL(), e, 33071, 33071)
|
||
}, e.prototype.prepareFrame = function (t, e, i) {
|
||
var r = this.mapRenderer.getGL(), o = t.pixelRatio, n = t.viewState, s = n.center, a = n.resolution,
|
||
l = n.rotation, h = this.image_, u = this.texture, c = this.getLayer().getSource(), p = t.viewHints,
|
||
d = t.extent;
|
||
if (void 0 !== e.extent && (d = Dt(d, e.extent)), !p[$n.ANIMATING] && !p[$n.INTERACTING] && !Vt(d)) {
|
||
var f = n.projection, g = c.getImage(d, a, o, f);
|
||
if (g) if (this.loadImage(g) && (h = g, u = this.createTexture_(g), this.texture)) {
|
||
var m = function (t, e) {
|
||
t.isContextLost() || t.deleteTexture(e)
|
||
}.bind(null, r, this.texture);
|
||
t.postRenderFunctions.push(m)
|
||
}
|
||
}
|
||
if (h) {
|
||
var y = this.mapRenderer.getContext().getCanvas();
|
||
this.updateProjectionMatrix_(y.width, y.height, o, s, a, l, h.getExtent()), this.hitTransformationMatrix_ = null;
|
||
var v = this.texCoordMatrix;
|
||
ai(v), di(v, 1, -1), fi(v, 0, -1), this.image_ = h, this.texture = u
|
||
}
|
||
return !!h
|
||
}, e.prototype.updateProjectionMatrix_ = function (t, e, i, r, o, n, s) {
|
||
var a = t * o, l = e * o, h = this.projectionMatrix;
|
||
ai(h), di(h, 2 * i / a, 2 * i / l), pi(h, -n), fi(h, s[0] - r[0], s[1] - r[1]), di(h, (s[2] - s[0]) / 2, (s[3] - s[1]) / 2), fi(h, 1, 1)
|
||
}, e.prototype.forEachLayerAtPixel = function (t, e, i, r) {
|
||
if (this.image_ && this.image_.getImage()) {
|
||
var o = [this.image_.getImage().width, this.image_.getImage().height];
|
||
this.hitTransformationMatrix_ || (this.hitTransformationMatrix_ = this.getHitTransformationMatrix_(e.size, o));
|
||
var n = ci(this.hitTransformationMatrix_, t.slice());
|
||
if (!(n[0] < 0 || n[0] > o[0] || n[1] < 0 || n[1] > o[1])) {
|
||
this.hitCanvasContext_ || (this.hitCanvasContext_ = Ao(1, 1)), this.hitCanvasContext_.clearRect(0, 0, 1, 1), this.hitCanvasContext_.drawImage(this.image_.getImage(), n[0], n[1], 1, 1, 0, 0, 1, 1);
|
||
var s = this.hitCanvasContext_.getImageData(0, 0, 1, 1).data;
|
||
return s[3] > 0 ? i.call(r, this.getLayer(), s) : void 0
|
||
}
|
||
}
|
||
}, e.prototype.getHitTransformationMatrix_ = function (t, e) {
|
||
var i = [1, 0, 0, 1, 0, 0];
|
||
fi(i, -1, -1), di(i, 2 / t[0], 2 / t[1]), fi(i, 0, t[1]), di(i, 1, -1);
|
||
var r = mi(this.projectionMatrix.slice()), o = [1, 0, 0, 1, 0, 0];
|
||
return fi(o, 0, e[1]), di(o, 1, -1), di(o, e[0] / 2, e[1] / 2), fi(o, 1, 1), li(o, r), li(o, i), o
|
||
}, e
|
||
}(ju);
|
||
zu.handles = function (t) {
|
||
return t.getType() === Vo.IMAGE
|
||
}, zu.create = function (t, e) {
|
||
return new zu(t, e)
|
||
};
|
||
var Uu = zu, Bu = function (t) {
|
||
function e(e) {
|
||
t.call(this, e);
|
||
var i = e.getViewport();
|
||
this.canvas_ = document.createElement("canvas"), this.canvas_.style.width = "100%", this.canvas_.style.height = "100%", this.canvas_.style.display = "block", this.canvas_.className = xs, i.insertBefore(this.canvas_, i.childNodes[0] || null), this.clipTileCanvasWidth_ = 0, this.clipTileCanvasHeight_ = 0, this.clipTileContext_ = Ao(), this.renderedVisible_ = !0, this.gl_ = Rh(this.canvas_, {
|
||
antialias: !0,
|
||
depth: !0,
|
||
failIfMajorPerformanceCaveat: !0,
|
||
preserveDrawingBuffer: !1,
|
||
stencil: !0
|
||
}), this.context_ = new ru(this.canvas_, this.gl_), w(this.canvas_, Qh.LOST, this.handleWebGLContextLost, this), w(this.canvas_, Qh.RESTORED, this.handleWebGLContextRestored, this), this.textureCache_ = new Ra, this.focus_ = null, this.tileTextureQueue_ = new zn(function (t) {
|
||
var e = t[1], i = t[2], r = e[0] - this.focus_[0], o = e[1] - this.focus_[1];
|
||
return 65536 * Math.log(i) + Math.sqrt(r * r + o * o) / i
|
||
}.bind(this), function (t) {
|
||
return t[0].getKey()
|
||
}), this.loadNextTileTexture_ = function (t, e) {
|
||
if (!this.tileTextureQueue_.isEmpty()) {
|
||
this.tileTextureQueue_.reprioritize();
|
||
var i = this.tileTextureQueue_.dequeue(), r = i[0], o = i[3], n = i[4];
|
||
this.bindTileTexture(r, o, n, bh, bh)
|
||
}
|
||
return !1
|
||
}.bind(this), this.textureCacheFrameMarkerCount_ = 0, this.initializeGL_()
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.bindTileTexture = function (t, e, i, r, o) {
|
||
var n = this.getGL(), s = t.getKey();
|
||
if (this.textureCache_.containsKey(s)) {
|
||
var a = this.textureCache_.get(s);
|
||
n.bindTexture(Eh, a.texture), a.magFilter != r && (n.texParameteri(Eh, 10240, r), a.magFilter = r), a.minFilter != o && (n.texParameteri(Eh, 10241, o), a.minFilter = o)
|
||
} else {
|
||
var l = n.createTexture(), h = t;
|
||
if (n.bindTexture(Eh, l), i > 0) {
|
||
var u = this.clipTileContext_.canvas, c = this.clipTileContext_;
|
||
this.clipTileCanvasWidth_ !== e[0] || this.clipTileCanvasHeight_ !== e[1] ? (u.width = e[0], u.height = e[1], this.clipTileCanvasWidth_ = e[0], this.clipTileCanvasHeight_ = e[1]) : c.clearRect(0, 0, e[0], e[1]), c.drawImage(h.getImage(), i, i, e[0], e[1], 0, 0, e[0], e[1]), n.texImage2D(Eh, 0, 6408, 6408, 5121, u)
|
||
} else n.texImage2D(Eh, 0, 6408, 6408, 5121, h.getImage());
|
||
n.texParameteri(Eh, 10240, r), n.texParameteri(Eh, 10241, o), n.texParameteri(Eh, Ch, 33071), n.texParameteri(Eh, Sh, 33071), this.textureCache_.set(s, {
|
||
texture: l,
|
||
magFilter: r,
|
||
minFilter: o
|
||
})
|
||
}
|
||
}, e.prototype.dispatchRenderEvent = function (t, e) {
|
||
var i = this.getMap();
|
||
if (i.hasListener(t)) {
|
||
var r = this.context_, o = e.extent, n = e.size, s = e.viewState, a = e.pixelRatio,
|
||
l = s.resolution, h = s.center, u = s.rotation, c = new Fu(r, h, l, u, n, o, a),
|
||
p = new Ta(t, c, e, null, r);
|
||
i.dispatchEvent(p)
|
||
}
|
||
}, e.prototype.disposeInternal = function () {
|
||
var e = this.getGL();
|
||
e.isContextLost() || this.textureCache_.forEach(function (t) {
|
||
t && e.deleteTexture(t.texture)
|
||
}), this.context_.dispose(), t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.expireCache_ = function (t, e) {
|
||
for (var i, r = this.getGL(); this.textureCache_.getCount() - this.textureCacheFrameMarkerCount_ > 1024;) {
|
||
if (i = this.textureCache_.peekLast()) r.deleteTexture(i.texture); else {
|
||
if (+this.textureCache_.peekLastKey() == e.index) break;
|
||
--this.textureCacheFrameMarkerCount_
|
||
}
|
||
this.textureCache_.pop()
|
||
}
|
||
}, e.prototype.getContext = function () {
|
||
return this.context_
|
||
}, e.prototype.getGL = function () {
|
||
return this.gl_
|
||
}, e.prototype.getTileTextureQueue = function () {
|
||
return this.tileTextureQueue_
|
||
}, e.prototype.handleWebGLContextLost = function (t) {
|
||
t.preventDefault(), this.textureCache_.clear(), this.textureCacheFrameMarkerCount_ = 0;
|
||
var e = this.getLayerRenderers();
|
||
for (var i in e) {
|
||
e[i].handleWebGLContextLost()
|
||
}
|
||
}, e.prototype.handleWebGLContextRestored = function () {
|
||
this.initializeGL_(), this.getMap().render()
|
||
}, e.prototype.initializeGL_ = function () {
|
||
var t = this.gl_;
|
||
t.activeTexture(33984), t.blendFuncSeparate(770, 771, 1, 771), t.disable(2884), t.disable(2929), t.disable(3089), t.disable(2960)
|
||
}, e.prototype.isTileTextureLoaded = function (t) {
|
||
return this.textureCache_.containsKey(t.getKey())
|
||
}, e.prototype.renderFrame = function (t) {
|
||
var e = this.getContext(), i = this.getGL();
|
||
if (i.isContextLost()) return !1;
|
||
if (!t) return this.renderedVisible_ && (this.canvas_.style.display = "none", this.renderedVisible_ = !1), !1;
|
||
this.focus_ = t.focus, this.textureCache_.set((-t.index).toString(), null), ++this.textureCacheFrameMarkerCount_, this.dispatchRenderEvent(eo.PRECOMPOSE, t);
|
||
var r = [], o = t.layerStatesArray;
|
||
rt(o, tl);
|
||
var n, s, a = t.viewState.resolution;
|
||
for (n = 0, s = o.length; n < s; ++n) {
|
||
var l = o[n];
|
||
if (Es(l, a) && l.sourceState == hs.READY) this.getLayerRenderer(l.layer).prepareFrame(t, l, e) && r.push(l)
|
||
}
|
||
var h = t.size[0] * t.pixelRatio, u = t.size[1] * t.pixelRatio;
|
||
for (this.canvas_.width == h && this.canvas_.height == u || (this.canvas_.width = h, this.canvas_.height = u), i.bindFramebuffer(36160, null), i.clearColor(0, 0, 0, 0), i.clear(16384), i.enable(3042), i.viewport(0, 0, this.canvas_.width, this.canvas_.height), n = 0, s = r.length; n < s; ++n) {
|
||
var c = r[n];
|
||
this.getLayerRenderer(c.layer).composeFrame(t, c, e)
|
||
}
|
||
this.renderedVisible_ || (this.canvas_.style.display = "", this.renderedVisible_ = !0), this.calculateMatrices2D(t), this.textureCache_.getCount() - this.textureCacheFrameMarkerCount_ > 1024 && t.postRenderFunctions.push(this.expireCache_.bind(this)), this.tileTextureQueue_.isEmpty() || (t.postRenderFunctions.push(this.loadNextTileTexture_), t.animate = !0), this.dispatchRenderEvent(eo.POSTCOMPOSE, t), this.scheduleRemoveUnusedLayerRenderers(t), this.scheduleExpireIconCache(t)
|
||
}, e.prototype.forEachFeatureAtCoordinate = function (t, e, i, r, o, n, s) {
|
||
var a;
|
||
if (this.getGL().isContextLost()) return !1;
|
||
var l, h = e.viewState, u = e.layerStatesArray;
|
||
for (l = u.length - 1; l >= 0; --l) {
|
||
var c = u[l], p = c.layer;
|
||
if (Es(c, h.resolution) && n.call(s, p)) if (a = this.getLayerRenderer(p).forEachFeatureAtCoordinate(t, e, i, r)) return a
|
||
}
|
||
}, e.prototype.hasFeatureAtCoordinate = function (t, e, i, r, o) {
|
||
var n = !1;
|
||
if (this.getGL().isContextLost()) return !1;
|
||
var s, a = e.viewState, l = e.layerStatesArray;
|
||
for (s = l.length - 1; s >= 0; --s) {
|
||
var h = l[s], u = h.layer;
|
||
if (Es(h, a.resolution) && r.call(o, u)) if (n = this.getLayerRenderer(u).hasFeatureAtCoordinate(t, e)) return !0
|
||
}
|
||
return n
|
||
}, e.prototype.forEachLayerAtPixel = function (t, e, i, r, o, n, s) {
|
||
if (this.getGL().isContextLost()) return !1;
|
||
var a, l, h = e.viewState, u = e.layerStatesArray;
|
||
for (l = u.length - 1; l >= 0; --l) {
|
||
var c = u[l], p = c.layer;
|
||
if (Es(c, h.resolution) && n.call(o, p)) if (a = this.getLayerRenderer(p).forEachLayerAtPixel(t, e, r, o)) return a
|
||
}
|
||
}, e
|
||
}(el);
|
||
|
||
function Vu(t) {
|
||
return t ? Array.isArray(t) ? function (e) {
|
||
return t
|
||
} : "function" == typeof t ? t : function (e) {
|
||
return [t]
|
||
} : null
|
||
}
|
||
|
||
var Yu = function (t) {
|
||
function e(e) {
|
||
t.call(this), this.projection_ = We(e.projection), this.attributions_ = Vu(e.attributions), this.attributionsCollapsible_ = void 0 === e.attributionsCollapsible || e.attributionsCollapsible, this.loading = !1, this.state_ = void 0 !== e.state ? e.state : hs.READY, this.wrapX_ = void 0 !== e.wrapX && e.wrapX
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getAttributions = function () {
|
||
return this.attributions_
|
||
}, e.prototype.getAttributionsCollapsible = function () {
|
||
return this.attributionsCollapsible_
|
||
}, e.prototype.getProjection = function () {
|
||
return this.projection_
|
||
}, e.prototype.getResolutions = function () {
|
||
return n()
|
||
}, e.prototype.getState = function () {
|
||
return this.state_
|
||
}, e.prototype.getWrapX = function () {
|
||
return this.wrapX_
|
||
}, e.prototype.refresh = function () {
|
||
this.changed()
|
||
}, e.prototype.setAttributions = function (t) {
|
||
this.attributions_ = Vu(t), this.changed()
|
||
}, e.prototype.setState = function (t) {
|
||
this.state_ = t, this.changed()
|
||
}, e
|
||
}(U), Wu = [0, 0, 0], Hu = function (t) {
|
||
var e;
|
||
if (this.minZoom = void 0 !== t.minZoom ? t.minZoom : 0, this.resolutions_ = t.resolutions, W(nt(this.resolutions_, function (t, e) {
|
||
return e - t
|
||
}, !0), 17), !t.origins) for (var i = 0, r = this.resolutions_.length - 1; i < r; ++i) if (e) {
|
||
if (this.resolutions_[i] / this.resolutions_[i + 1] !== e) {
|
||
e = void 0;
|
||
break
|
||
}
|
||
} else e = this.resolutions_[i] / this.resolutions_[i + 1];
|
||
this.zoomFactor_ = e, this.maxZoom = this.resolutions_.length - 1, this.origin_ = void 0 !== t.origin ? t.origin : null, this.origins_ = null, void 0 !== t.origins && (this.origins_ = t.origins, W(this.origins_.length == this.resolutions_.length, 20));
|
||
var o = t.extent;
|
||
void 0 === o || this.origin_ || this.origins_ || (this.origin_ = jt(o)), W(!this.origin_ && this.origins_ || this.origin_ && !this.origins_, 18), this.tileSizes_ = null, void 0 !== t.tileSizes && (this.tileSizes_ = t.tileSizes, W(this.tileSizes_.length == this.resolutions_.length, 19)), this.tileSize_ = void 0 !== t.tileSize ? t.tileSize : this.tileSizes_ ? null : Vn, W(!this.tileSize_ && this.tileSizes_ || this.tileSize_ && !this.tileSizes_, 22), this.extent_ = void 0 !== o ? o : null, this.fullTileRanges_ = null, this.tmpSize_ = [0, 0], void 0 !== t.sizes ? this.fullTileRanges_ = t.sizes.map(function (t, e) {
|
||
return new pl(Math.min(0, t[0]), Math.max(t[0] - 1, -1), Math.min(0, t[1]), Math.max(t[1] - 1, -1))
|
||
}, this) : o && this.calculateTileRanges_(o)
|
||
};
|
||
Hu.prototype.forEachTileCoord = function (t, e, i) {
|
||
for (var r = this.getTileRangeForExtentAndZ(t, e), o = r.minX, n = r.maxX; o <= n; ++o) for (var s = r.minY, a = r.maxY; s <= a; ++s) i([e, o, s])
|
||
}, Hu.prototype.forEachTileCoordParentTileRange = function (t, e, i, r, o) {
|
||
var n, s, a, l = null, h = t[0] - 1;
|
||
for (2 === this.zoomFactor_ ? (s = t[1], a = t[2]) : l = this.getTileCoordExtent(t, o); h >= this.minZoom;) {
|
||
if (n = 2 === this.zoomFactor_ ? cl(s = Math.floor(s / 2), s, a = Math.floor(a / 2), a, r) : this.getTileRangeForExtentAndZ(l, h, r), e.call(i, h, n)) return !0;
|
||
--h
|
||
}
|
||
return !1
|
||
}, Hu.prototype.getExtent = function () {
|
||
return this.extent_
|
||
}, Hu.prototype.getMaxZoom = function () {
|
||
return this.maxZoom
|
||
}, Hu.prototype.getMinZoom = function () {
|
||
return this.minZoom
|
||
}, Hu.prototype.getOrigin = function (t) {
|
||
return this.origin_ ? this.origin_ : this.origins_[t]
|
||
}, Hu.prototype.getResolution = function (t) {
|
||
return this.resolutions_[t]
|
||
}, Hu.prototype.getResolutions = function () {
|
||
return this.resolutions_
|
||
}, Hu.prototype.getTileCoordChildTileRange = function (t, e, i) {
|
||
if (t[0] < this.maxZoom) {
|
||
if (2 === this.zoomFactor_) {
|
||
var r = 2 * t[1], o = 2 * t[2];
|
||
return cl(r, r + 1, o, o + 1, e)
|
||
}
|
||
var n = this.getTileCoordExtent(t, i);
|
||
return this.getTileRangeForExtentAndZ(n, t[0] + 1, e)
|
||
}
|
||
return null
|
||
}, Hu.prototype.getTileRangeExtent = function (t, e, i) {
|
||
var r = this.getOrigin(t), o = this.getResolution(t), n = gs(this.getTileSize(t), this.tmpSize_),
|
||
s = r[0] + e.minX * n[0] * o, a = r[0] + (e.maxX + 1) * n[0] * o;
|
||
return yt(s, r[1] + e.minY * n[1] * o, a, r[1] + (e.maxY + 1) * n[1] * o, i)
|
||
}, Hu.prototype.getTileRangeForExtentAndZ = function (t, e, i) {
|
||
var r = Wu;
|
||
this.getTileCoordForXYAndZ_(t[0], t[1], e, !1, r);
|
||
var o = r[1], n = r[2];
|
||
return this.getTileCoordForXYAndZ_(t[2], t[3], e, !0, r), cl(o, r[1], n, r[2], i)
|
||
}, Hu.prototype.getTileCoordCenter = function (t) {
|
||
var e = this.getOrigin(t[0]), i = this.getResolution(t[0]), r = gs(this.getTileSize(t[0]), this.tmpSize_);
|
||
return [e[0] + (t[1] + .5) * r[0] * i, e[1] + (t[2] + .5) * r[1] * i]
|
||
}, Hu.prototype.getTileCoordExtent = function (t, e) {
|
||
var i = this.getOrigin(t[0]), r = this.getResolution(t[0]), o = gs(this.getTileSize(t[0]), this.tmpSize_),
|
||
n = i[0] + t[1] * o[0] * r, s = i[1] + t[2] * o[1] * r;
|
||
return yt(n, s, n + o[0] * r, s + o[1] * r, e)
|
||
}, Hu.prototype.getTileCoordForCoordAndResolution = function (t, e, i) {
|
||
return this.getTileCoordForXYAndResolution_(t[0], t[1], e, !1, i)
|
||
}, Hu.prototype.getTileCoordForXYAndResolution_ = function (t, e, i, r, o) {
|
||
var n = this.getZForResolution(i), s = i / this.getResolution(n), a = this.getOrigin(n),
|
||
l = gs(this.getTileSize(n), this.tmpSize_), h = r ? .5 : 0, u = r ? 0 : .5,
|
||
c = Math.floor((t - a[0]) / i + h), p = Math.floor((e - a[1]) / i + u), d = s * c / l[0],
|
||
f = s * p / l[1];
|
||
return r ? (d = Math.ceil(d) - 1, f = Math.ceil(f) - 1) : (d = Math.floor(d), f = Math.floor(f)), ah(n, d, f, o)
|
||
}, Hu.prototype.getTileCoordForXYAndZ_ = function (t, e, i, r, o) {
|
||
var n = this.getOrigin(i), s = this.getResolution(i), a = gs(this.getTileSize(i), this.tmpSize_),
|
||
l = r ? .5 : 0, h = r ? 0 : .5, u = Math.floor((t - n[0]) / s + l), c = Math.floor((e - n[1]) / s + h),
|
||
p = u / a[0], d = c / a[1];
|
||
return r ? (p = Math.ceil(p) - 1, d = Math.ceil(d) - 1) : (p = Math.floor(p), d = Math.floor(d)), ah(i, p, d, o)
|
||
}, Hu.prototype.getTileCoordForCoordAndZ = function (t, e, i) {
|
||
return this.getTileCoordForXYAndZ_(t[0], t[1], e, !1, i)
|
||
}, Hu.prototype.getTileCoordResolution = function (t) {
|
||
return this.resolutions_[t[0]]
|
||
}, Hu.prototype.getTileSize = function (t) {
|
||
return this.tileSize_ ? this.tileSize_ : this.tileSizes_[t]
|
||
}, Hu.prototype.getFullTileRange = function (t) {
|
||
return this.fullTileRanges_ ? this.fullTileRanges_[t] : null
|
||
}, Hu.prototype.getZForResolution = function (t, e) {
|
||
return te(J(this.resolutions_, t, e || 0), this.minZoom, this.maxZoom)
|
||
}, Hu.prototype.calculateTileRanges_ = function (t) {
|
||
for (var e = this.resolutions_.length, i = new Array(e), r = this.minZoom; r < e; ++r) i[r] = this.getTileRangeForExtentAndZ(t, r);
|
||
this.fullTileRanges_ = i
|
||
};
|
||
var Xu = Hu;
|
||
|
||
function qu(t) {
|
||
var e = t.getDefaultTileGrid();
|
||
return e || (e = Qu(t), t.setDefaultTileGrid(e)), e
|
||
}
|
||
|
||
function Zu(t, e, i) {
|
||
var r = e[0], o = t.getTileCoordCenter(e), n = tc(i);
|
||
if (pt(n, o)) return e;
|
||
var s = Ut(n), a = Math.ceil((n[0] - o[0]) / s);
|
||
return o[0] += s * a, t.getTileCoordForCoordAndZ(o, r)
|
||
}
|
||
|
||
function Ku(t, e, i, r) {
|
||
var o = void 0 !== r ? r : st.TOP_LEFT, n = $u(t, e, i);
|
||
return new Xu({extent: t, origin: kt(t, o), resolutions: n, tileSize: i})
|
||
}
|
||
|
||
function Ju(t) {
|
||
var e = t || {}, i = e.extent || We("EPSG:3857").getExtent(),
|
||
r = {extent: i, minZoom: e.minZoom, tileSize: e.tileSize, resolutions: $u(i, e.maxZoom, e.tileSize)};
|
||
return new Xu(r)
|
||
}
|
||
|
||
function $u(t, e, i) {
|
||
for (var r = void 0 !== e ? e : Bn, o = Nt(t), n = Ut(t), s = gs(void 0 !== i ? i : Vn), a = Math.max(n / s[0], o / s[1]), l = r + 1, h = new Array(l), u = 0; u < l; ++u) h[u] = a / Math.pow(2, u);
|
||
return h
|
||
}
|
||
|
||
function Qu(t, e, i, r) {
|
||
return Ku(tc(t), e, i, r)
|
||
}
|
||
|
||
function tc(t) {
|
||
var e = (t = We(t)).getExtent();
|
||
if (!e) {
|
||
var i = 180 * ye[ve.DEGREES] / t.getMetersPerUnit();
|
||
e = yt(-i, -i, i, i)
|
||
}
|
||
return e
|
||
}
|
||
|
||
var ec = function (t) {
|
||
function e(e) {
|
||
t.call(this, {
|
||
attributions: e.attributions,
|
||
attributionsCollapsible: e.attributionsCollapsible,
|
||
projection: e.projection,
|
||
state: e.state,
|
||
wrapX: e.wrapX
|
||
}), this.opaque_ = void 0 !== e.opaque && e.opaque, this.tilePixelRatio_ = void 0 !== e.tilePixelRatio ? e.tilePixelRatio : 1, this.tileGrid = void 0 !== e.tileGrid ? e.tileGrid : null, this.tileCache = new fh(e.cacheSize), this.tmpSize = [0, 0], this.key_ = e.key || "", this.tileOptions = {transition: e.transition}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.canExpireCache = function () {
|
||
return this.tileCache.canExpireCache()
|
||
}, e.prototype.expireCache = function (t, e) {
|
||
var i = this.getTileCacheForProjection(t);
|
||
i && i.expireCache(e)
|
||
}, e.prototype.forEachLoadedTile = function (t, e, i, r) {
|
||
var o = this.getTileCacheForProjection(t);
|
||
if (!o) return !1;
|
||
for (var n, s, a, l = !0, h = i.minX; h <= i.maxX; ++h) for (var u = i.minY; u <= i.maxY; ++u) s = lh(e, h, u), a = !1, o.containsKey(s) && (a = (n = o.get(s)).getState() === Ro.LOADED) && (a = !1 !== r(n)), a || (l = !1);
|
||
return l
|
||
}, e.prototype.getGutterForProjection = function (t) {
|
||
return 0
|
||
}, e.prototype.getKey = function () {
|
||
return this.key_
|
||
}, e.prototype.setKey = function (t) {
|
||
this.key_ !== t && (this.key_ = t, this.changed())
|
||
}, e.prototype.getOpaque = function (t) {
|
||
return this.opaque_
|
||
}, e.prototype.getResolutions = function () {
|
||
return this.tileGrid.getResolutions()
|
||
}, e.prototype.getTile = function (t, e, i, r, o) {
|
||
return n()
|
||
}, e.prototype.getTileGrid = function () {
|
||
return this.tileGrid
|
||
}, e.prototype.getTileGridForProjection = function (t) {
|
||
return this.tileGrid ? this.tileGrid : qu(t)
|
||
}, e.prototype.getTileCacheForProjection = function (t) {
|
||
var e = this.getProjection();
|
||
return e && !Qe(e, t) ? null : this.tileCache
|
||
}, e.prototype.getTilePixelRatio = function (t) {
|
||
return this.tilePixelRatio_
|
||
}, e.prototype.getTilePixelSize = function (t, e, i) {
|
||
var r = this.getTileGridForProjection(i), o = this.getTilePixelRatio(e),
|
||
n = gs(r.getTileSize(t), this.tmpSize);
|
||
return 1 == o ? n : fs(n, o, this.tmpSize)
|
||
}, e.prototype.getTileCoordForTileUrlFunction = function (t, e) {
|
||
var i = void 0 !== e ? e : this.getProjection(), r = this.getTileGridForProjection(i);
|
||
return this.getWrapX() && i.isGlobal() && (t = Zu(r, t, i)), dh(t, r) ? t : null
|
||
}, e.prototype.refresh = function () {
|
||
this.tileCache.clear(), this.changed()
|
||
}, e.prototype.useTile = function (t, e, i, r) {
|
||
}, e
|
||
}(Yu), ic = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e), this.tile = i
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A), rc = ec,
|
||
oc = new Ah("precision mediump float;\nvarying vec2 v_texCoord;\n\n\nuniform sampler2D u_texture;\n\nvoid main(void) {\n gl_FragColor = texture2D(u_texture, v_texCoord);\n}\n"),
|
||
nc = new kh("varying vec2 v_texCoord;\n\n\nattribute vec2 a_position;\nattribute vec2 a_texCoord;\nuniform vec4 u_tileOffset;\n\nvoid main(void) {\n gl_Position = vec4(a_position * u_tileOffset.xy + u_tileOffset.zw, 0., 1.);\n v_texCoord = a_texCoord;\n}\n\n\n"),
|
||
sc = function (t, e) {
|
||
this.u_tileOffset = t.getUniformLocation(e, "u_tileOffset"), this.u_texture = t.getUniformLocation(e, "u_texture"), this.a_position = t.getAttribLocation(e, "a_position"), this.a_texCoord = t.getAttribLocation(e, "a_texCoord")
|
||
}, ac = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e, i), this.fragmentShader_ = oc, this.vertexShader_ = nc, this.locations_ = null, this.renderArrayBuffer_ = new qh([0, 0, 0, 1, 1, 0, 1, 1, 0, 1, 0, 0, 1, 1, 1, 0]), this.renderedTileRange_ = null, this.renderedFramebufferExtent_ = null, this.renderedRevision_ = -1, this.tmpSize_ = [0, 0]
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.disposeInternal = function () {
|
||
this.mapRenderer.getContext().deleteBuffer(this.renderArrayBuffer_), t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.createLoadedTileFinder = function (t, e, i) {
|
||
var r = this.mapRenderer;
|
||
return function (o, n) {
|
||
return t.forEachLoadedTile(e, o, n, function (t) {
|
||
var e = r.isTileTextureLoaded(t);
|
||
return e && (i[o] || (i[o] = {}), i[o][t.tileCoord.toString()] = t), e
|
||
})
|
||
}
|
||
}, e.prototype.handleWebGLContextLost = function () {
|
||
t.prototype.handleWebGLContextLost.call(this), this.locations_ = null
|
||
}, e.prototype.prepareFrame = function (t, e, i) {
|
||
var r = this.mapRenderer, o = i.getGL(), n = t.viewState, s = n.projection, a = this.getLayer(),
|
||
l = a.getSource();
|
||
if (!(l instanceof rc)) return !0;
|
||
var h, u = l.getTileGridForProjection(s), c = u.getZForResolution(n.resolution), p = u.getResolution(c),
|
||
d = l.getTilePixelSize(c, t.pixelRatio, s), f = d[0] / gs(u.getTileSize(c), this.tmpSize_)[0],
|
||
g = p / f, m = l.getTilePixelRatio(f) * l.getGutterForProjection(s), y = n.center, v = t.extent,
|
||
_ = u.getTileRangeForExtentAndZ(v, c);
|
||
if (this.renderedTileRange_ && this.renderedTileRange_.equals(_) && this.renderedRevision_ == l.getRevision()) h = this.renderedFramebufferExtent_; else {
|
||
var x = _.getSize(), w = ie(Math.max(x[0] * d[0], x[1] * d[1])), b = g * w, C = u.getOrigin(c),
|
||
S = C[0] + _.minX * d[0] * g, E = C[1] + _.minY * d[1] * g;
|
||
h = [S, E, S + b, E + b], this.bindFramebuffer(t, w), o.viewport(0, 0, w, w), o.clearColor(0, 0, 0, 0), o.clear(16384), o.disable(3042);
|
||
var T = i.getProgram(this.fragmentShader_, this.vertexShader_);
|
||
i.useProgram(T), this.locations_ || (this.locations_ = new sc(o, T)), i.bindBuffer(34962, this.renderArrayBuffer_), o.enableVertexAttribArray(this.locations_.a_position), o.vertexAttribPointer(this.locations_.a_position, 2, 5126, !1, 16, 0), o.enableVertexAttribArray(this.locations_.a_texCoord), o.vertexAttribPointer(this.locations_.a_texCoord, 2, 5126, !1, 16, 8), o.uniform1i(this.locations_.u_texture, 0);
|
||
var R = {};
|
||
R[c] = {};
|
||
var P, L, I, O, M, A, k = this.createLoadedTileFinder(l, s, R), F = a.getUseInterimTilesOnError(),
|
||
N = !0, D = [1 / 0, 1 / 0, -1 / 0, -1 / 0], G = new pl(0, 0, 0, 0);
|
||
for (O = _.minX; O <= _.maxX; ++O) for (M = _.minY; M <= _.maxY; ++M) if (L = l.getTile(c, O, M, f, s), void 0 === e.extent || Bt(A = u.getTileCoordExtent(L.tileCoord, D), e.extent)) {
|
||
if ((I = L.getState()) == Ro.LOADED || I == Ro.EMPTY || I == Ro.ERROR && !F || (L = L.getInterimTile()), (I = L.getState()) == Ro.LOADED) {
|
||
if (r.isTileTextureLoaded(L)) {
|
||
R[c][L.tileCoord.toString()] = L;
|
||
continue
|
||
}
|
||
} else if (I == Ro.EMPTY || I == Ro.ERROR && !F) continue;
|
||
N = !1, u.forEachTileCoordParentTileRange(L.tileCoord, k, null, G, D) || (P = u.getTileCoordChildTileRange(L.tileCoord, G, D)) && k(c + 1, P)
|
||
}
|
||
var j = Object.keys(R).map(Number);
|
||
j.sort(Z);
|
||
for (var z = new Float32Array(4), U = 0, B = j.length; U < B; ++U) {
|
||
var V = R[j[U]];
|
||
for (var Y in V) (L = V[Y]) instanceof zo && (A = u.getTileCoordExtent(L.tileCoord, D), z[0] = 2 * (A[2] - A[0]) / b, z[1] = 2 * (A[3] - A[1]) / b, z[2] = 2 * (A[0] - h[0]) / b - 1, z[3] = 2 * (A[1] - h[1]) / b - 1, o.uniform4fv(this.locations_.u_tileOffset, z), r.bindTileTexture(L, d, m * f, bh, bh), o.drawArrays(5, 0, 4))
|
||
}
|
||
N ? (this.renderedTileRange_ = _, this.renderedFramebufferExtent_ = h, this.renderedRevision_ = l.getRevision()) : (this.renderedTileRange_ = null, this.renderedFramebufferExtent_ = null, this.renderedRevision_ = -1, t.animate = !0)
|
||
}
|
||
this.updateUsedTiles(t.usedTiles, l, c, _);
|
||
var W = r.getTileTextureQueue();
|
||
this.manageTilePyramid(t, l, u, f, s, v, c, a.getPreload(), function (t) {
|
||
t.getState() != Ro.LOADED || r.isTileTextureLoaded(t) || W.isKeyQueued(t.getKey()) || W.enqueue([t, u.getTileCoordCenter(t.tileCoord), u.getResolution(t.tileCoord[0]), d, m * f])
|
||
}, this), this.scheduleExpireCache(t, l);
|
||
var H = this.texCoordMatrix;
|
||
return ai(H), fi(H, (Math.round(y[0] / p) * p - h[0]) / (h[2] - h[0]), (Math.round(y[1] / p) * p - h[1]) / (h[3] - h[1])), 0 !== n.rotation && pi(H, n.rotation), di(H, t.size[0] * n.resolution / (h[2] - h[0]), t.size[1] * n.resolution / (h[3] - h[1])), fi(H, -.5, -.5), !0
|
||
}, e.prototype.forEachLayerAtPixel = function (t, e, i, r) {
|
||
if (this.framebuffer) {
|
||
var o = [t[0] / e.size[0], (e.size[1] - t[1]) / e.size[1]], n = ci(this.texCoordMatrix, o.slice()),
|
||
s = [n[0] * this.framebufferDimension, n[1] * this.framebufferDimension],
|
||
a = this.mapRenderer.getContext().getGL();
|
||
a.bindFramebuffer(a.FRAMEBUFFER, this.framebuffer);
|
||
var l = new Uint8Array(4);
|
||
return a.readPixels(s[0], s[1], 1, 1, a.RGBA, a.UNSIGNED_BYTE, l), l[3] > 0 ? i.call(r, this.getLayer(), l) : void 0
|
||
}
|
||
}, e
|
||
}(ju);
|
||
ac.handles = function (t) {
|
||
return t.getType() === Vo.TILE
|
||
}, ac.create = function (t, e) {
|
||
return new ac(t, e)
|
||
};
|
||
var lc = ac, hc = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e, i), this.dirty_ = !1, this.renderedRevision_ = -1, this.renderedResolution_ = NaN, this.renderedExtent_ = [1 / 0, 1 / 0, -1 / 0, -1 / 0], this.renderedRenderOrder_ = null, this.replayGroup_ = null, this.layerState_ = null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.composeFrame = function (t, e, i) {
|
||
this.layerState_ = e;
|
||
var r = t.viewState, o = this.replayGroup_, n = t.size, s = t.pixelRatio, a = this.mapRenderer.getGL();
|
||
o && !o.isEmpty() && (a.enable(a.SCISSOR_TEST), a.scissor(0, 0, n[0] * s, n[1] * s), o.replay(i, r.center, r.resolution, r.rotation, n, s, e.opacity, e.managed ? t.skippedFeatureUids : {}), a.disable(a.SCISSOR_TEST))
|
||
}, e.prototype.disposeInternal = function () {
|
||
var e = this.replayGroup_;
|
||
if (e) {
|
||
var i = this.mapRenderer.getContext();
|
||
e.getDeleteResourcesFunction(i)(), this.replayGroup_ = null
|
||
}
|
||
t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.forEachFeatureAtCoordinate = function (t, e, i, r, o) {
|
||
if (this.replayGroup_ && this.layerState_) {
|
||
var n = this.mapRenderer.getContext(), s = e.viewState, l = this.getLayer(), h = this.layerState_,
|
||
u = {};
|
||
return this.replayGroup_.forEachFeatureAtCoordinate(t, n, s.center, s.resolution, s.rotation, e.size, e.pixelRatio, h.opacity, {}, function (t) {
|
||
var e = a(t);
|
||
if (!(e in u)) return u[e] = !0, r.call(o, t, l)
|
||
})
|
||
}
|
||
}, e.prototype.hasFeatureAtCoordinate = function (t, e) {
|
||
if (this.replayGroup_ && this.layerState_) {
|
||
var i = this.mapRenderer.getContext(), r = e.viewState, o = this.layerState_;
|
||
return this.replayGroup_.hasFeatureAtCoordinate(t, i, r.center, r.resolution, r.rotation, e.size, e.pixelRatio, o.opacity, e.skippedFeatureUids)
|
||
}
|
||
return !1
|
||
}, e.prototype.forEachLayerAtPixel = function (t, e, i, r) {
|
||
var o = ci(e.pixelToCoordinateTransform, t.slice());
|
||
return this.hasFeatureAtCoordinate(o, e) ? i.call(r, this.getLayer(), null) : void 0
|
||
}, e.prototype.handleStyleImageChange_ = function (t) {
|
||
this.renderIfReadyAndVisible()
|
||
}, e.prototype.prepareFrame = function (t, e, i) {
|
||
var r = this.getLayer(), o = r.getSource(), n = t.viewHints[$n.ANIMATING],
|
||
s = t.viewHints[$n.INTERACTING], a = r.getUpdateWhileAnimating(), l = r.getUpdateWhileInteracting();
|
||
if (!this.dirty_ && !a && n || !l && s) return !0;
|
||
var h = t.extent, u = t.viewState, c = u.projection, p = u.resolution, d = t.pixelRatio,
|
||
f = r.getRevision(), g = r.getRenderBuffer(), m = r.getRenderOrder();
|
||
void 0 === m && (m = Hl);
|
||
var y = ht(h, g * p);
|
||
if (!this.dirty_ && this.renderedResolution_ == p && this.renderedRevision_ == f && this.renderedRenderOrder_ == m && dt(this.renderedExtent_, y)) return !0;
|
||
this.replayGroup_ && t.postRenderFunctions.push(this.replayGroup_.getDeleteResourcesFunction(i)), this.dirty_ = !1;
|
||
var v = new ku(ql(p, d), y, r.getRenderBuffer());
|
||
o.loadFeatures(y, p, c);
|
||
var _ = function (t) {
|
||
var e, i = t.getStyleFunction() || r.getStyleFunction();
|
||
if (i && (e = i(t, p)), e) {
|
||
var o = this.renderFeature(t, p, d, e, v);
|
||
this.dirty_ = this.dirty_ || o
|
||
}
|
||
}.bind(this);
|
||
if (m) {
|
||
var x = [];
|
||
o.forEachFeatureInExtent(y, function (t) {
|
||
x.push(t)
|
||
}), x.sort(m), x.forEach(_.bind(this))
|
||
} else o.forEachFeatureInExtent(y, _);
|
||
return v.finish(i), this.renderedResolution_ = p, this.renderedRevision_ = f, this.renderedRenderOrder_ = m, this.renderedExtent_ = y, this.replayGroup_ = v, !0
|
||
}, e.prototype.renderFeature = function (t, e, i, r, o) {
|
||
if (!r) return !1;
|
||
var n = !1;
|
||
if (Array.isArray(r)) for (var s = r.length - 1; s >= 0; --s) n = Zl(o, t, r[s], Xl(e, i), this.handleStyleImageChange_, this) || n; else n = Zl(o, t, r, Xl(e, i), this.handleStyleImageChange_, this) || n;
|
||
return n
|
||
}, e
|
||
}(ju);
|
||
hc.handles = function (t) {
|
||
return t.getType() === Vo.VECTOR
|
||
}, hc.create = function (t, e) {
|
||
return new hc(t, e)
|
||
};
|
||
var uc, cc = hc, pc = function (t) {
|
||
function e(e) {
|
||
(e = p({}, e)).controls || (e.controls = Ms()), e.interactions || (e.interactions = Ca()), t.call(this, e)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.createRenderer = function () {
|
||
var t = new Bu(this);
|
||
return t.registerLayerRenderers([Uu, lc, cc]), t
|
||
}, e
|
||
}(ms), dc = function () {
|
||
if (!uc) {
|
||
var t = document.body;
|
||
t.webkitRequestFullscreen ? uc = "webkitfullscreenchange" : t.mozRequestFullScreen ? uc = "mozfullscreenchange" : t.msRequestFullscreen ? uc = "MSFullscreenChange" : t.requestFullscreen && (uc = "fullscreenchange")
|
||
}
|
||
return uc
|
||
};
|
||
|
||
function fc() {
|
||
var t = document.body;
|
||
return !!(t.webkitRequestFullscreen || t.mozRequestFullScreen && document.mozFullScreenEnabled || t.msRequestFullscreen && document.msFullscreenEnabled || t.requestFullscreen && document.fullscreenEnabled)
|
||
}
|
||
|
||
function gc() {
|
||
return !!(document.webkitIsFullScreen || document.mozFullScreen || document.msFullscreenElement || document.fullscreenElement)
|
||
}
|
||
|
||
function mc(t) {
|
||
t.requestFullscreen ? t.requestFullscreen() : t.msRequestFullscreen ? t.msRequestFullscreen() : t.mozRequestFullScreen ? t.mozRequestFullScreen() : t.webkitRequestFullscreen && t.webkitRequestFullscreen()
|
||
}
|
||
|
||
var yc = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {
|
||
element: document.createElement("div"),
|
||
target: i.target
|
||
}), this.cssClassName_ = void 0 !== i.className ? i.className : "ol-full-screen";
|
||
var r = void 0 !== i.label ? i.label : "⤢";
|
||
this.labelNode_ = "string" == typeof r ? document.createTextNode(r) : r;
|
||
var o = void 0 !== i.labelActive ? i.labelActive : "×";
|
||
this.labelActiveNode_ = "string" == typeof o ? document.createTextNode(o) : o, this.button_ = document.createElement("button");
|
||
var n = i.tipLabel ? i.tipLabel : "Toggle full-screen";
|
||
this.setClassName_(this.button_, gc()), this.button_.setAttribute("type", "button"), this.button_.title = n, this.button_.appendChild(this.labelNode_), w(this.button_, F.CLICK, this.handleClick_, this);
|
||
var s = this.cssClassName_ + " " + xs + " " + bs + " " + (fc() ? "" : ws), a = this.element;
|
||
a.className = s, a.appendChild(this.button_), this.keys_ = void 0 !== i.keys && i.keys, this.source_ = i.source
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleClick_ = function (t) {
|
||
t.preventDefault(), this.handleFullScreen_()
|
||
}, e.prototype.handleFullScreen_ = function () {
|
||
if (fc()) {
|
||
var t, e = this.getMap();
|
||
if (e) if (gc()) document.exitFullscreen ? document.exitFullscreen() : document.msExitFullscreen ? document.msExitFullscreen() : document.mozCancelFullScreen ? document.mozCancelFullScreen() : document.webkitExitFullscreen && document.webkitExitFullscreen(); else t = this.source_ ? "string" == typeof this.source_ ? document.getElementById(this.source_) : this.source_ : e.getTargetElement(), this.keys_ ? function (t) {
|
||
t.mozRequestFullScreenWithKeys ? t.mozRequestFullScreenWithKeys() : t.webkitRequestFullscreen ? t.webkitRequestFullscreen() : mc(t)
|
||
}(t) : mc(t)
|
||
}
|
||
}, e.prototype.handleFullScreenChange_ = function () {
|
||
var t = this.getMap();
|
||
gc() ? (this.setClassName_(this.button_, !0), No(this.labelActiveNode_, this.labelNode_)) : (this.setClassName_(this.button_, !1), No(this.labelNode_, this.labelActiveNode_)), t && t.updateSize()
|
||
}, e.prototype.setClassName_ = function (t, e) {
|
||
var i = this.cssClassName_ + "-true", r = this.cssClassName_ + "-false", o = e ? i : r;
|
||
t.classList.remove(i), t.classList.remove(r), t.classList.add(o)
|
||
}, e.prototype.setMap = function (e) {
|
||
t.prototype.setMap.call(this, e), e && this.listenerKeys.push(w(document, dc(), this.handleFullScreenChange_, this))
|
||
}, e
|
||
}(ys), vc = "projection";
|
||
|
||
function _c(t) {
|
||
var e = t.frameState;
|
||
e ? this.mapProjection_ != e.viewState.projection && (this.mapProjection_ = e.viewState.projection, this.transform_ = null) : this.mapProjection_ = null
|
||
}
|
||
|
||
var xc = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = document.createElement("div");
|
||
r.className = void 0 !== i.className ? i.className : "ol-mouse-position", t.call(this, {
|
||
element: r,
|
||
render: i.render || _c,
|
||
target: i.target
|
||
}), w(this, z(vc), this.handleProjectionChanged_, this), i.coordinateFormat && this.setCoordinateFormat(i.coordinateFormat), i.projection && this.setProjection(i.projection), this.undefinedHTML_ = void 0 !== i.undefinedHTML ? i.undefinedHTML : " ", this.renderOnMouseOut_ = !!this.undefinedHTML_, this.renderedHTML_ = r.innerHTML, this.mapProjection_ = null, this.transform_ = null, this.lastMouseMovePixel_ = null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleProjectionChanged_ = function () {
|
||
this.transform_ = null
|
||
}, e.prototype.getCoordinateFormat = function () {
|
||
return this.get("coordinateFormat")
|
||
}, e.prototype.getProjection = function () {
|
||
return this.get(vc)
|
||
}, e.prototype.handleMouseMove = function (t) {
|
||
var e = this.getMap();
|
||
this.lastMouseMovePixel_ = e.getEventPixel(t), this.updateHTML_(this.lastMouseMovePixel_)
|
||
}, e.prototype.handleMouseOut = function (t) {
|
||
this.updateHTML_(null), this.lastMouseMovePixel_ = null
|
||
}, e.prototype.setMap = function (e) {
|
||
if (t.prototype.setMap.call(this, e), e) {
|
||
var i = e.getViewport();
|
||
this.listenerKeys.push(w(i, F.MOUSEMOVE, this.handleMouseMove, this), w(i, F.TOUCHSTART, this.handleMouseMove, this)), this.renderOnMouseOut_ && this.listenerKeys.push(w(i, F.MOUSEOUT, this.handleMouseOut, this), w(i, F.TOUCHEND, this.handleMouseOut, this))
|
||
}
|
||
}, e.prototype.setCoordinateFormat = function (t) {
|
||
this.set("coordinateFormat", t)
|
||
}, e.prototype.setProjection = function (t) {
|
||
this.set(vc, We(t))
|
||
}, e.prototype.updateHTML_ = function (t) {
|
||
var e = this.undefinedHTML_;
|
||
if (t && this.mapProjection_) {
|
||
if (!this.transform_) {
|
||
var i = this.getProjection();
|
||
this.transform_ = i ? ti(this.mapProjection_, i) : Be
|
||
}
|
||
var r = this.getMap().getCoordinateFromPixel(t);
|
||
if (r) {
|
||
this.transform_(r, r);
|
||
var o = this.getCoordinateFormat();
|
||
e = o ? o(r) : r.toString()
|
||
}
|
||
}
|
||
this.renderedHTML_ && e === this.renderedHTML_ || (this.element.innerHTML = e, this.renderedHTML_ = e)
|
||
}, e
|
||
}(ys);
|
||
|
||
function wc(t) {
|
||
this.validateExtent_(), this.updateBox_()
|
||
}
|
||
|
||
var bc = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {
|
||
element: document.createElement("div"),
|
||
render: i.render || wc,
|
||
target: i.target
|
||
}), this.collapsed_ = void 0 === i.collapsed || i.collapsed, this.collapsible_ = void 0 === i.collapsible || i.collapsible, this.collapsible_ || (this.collapsed_ = !1);
|
||
var r = void 0 !== i.className ? i.className : "ol-overviewmap",
|
||
o = void 0 !== i.tipLabel ? i.tipLabel : "Overview map",
|
||
n = void 0 !== i.collapseLabel ? i.collapseLabel : "«";
|
||
"string" == typeof n ? (this.collapseLabel_ = document.createElement("span"), this.collapseLabel_.textContent = n) : this.collapseLabel_ = n;
|
||
var s = void 0 !== i.label ? i.label : "»";
|
||
"string" == typeof s ? (this.label_ = document.createElement("span"), this.label_.textContent = s) : this.label_ = s;
|
||
var a = this.collapsible_ && !this.collapsed_ ? this.collapseLabel_ : this.label_,
|
||
l = document.createElement("button");
|
||
l.setAttribute("type", "button"), l.title = o, l.appendChild(a), w(l, F.CLICK, this.handleClick_, this), this.ovmapDiv_ = document.createElement("div"), this.ovmapDiv_.className = "ol-overviewmap-map", this.ovmap_ = new rh({
|
||
controls: new Y,
|
||
interactions: new Y,
|
||
view: i.view
|
||
});
|
||
var h = this.ovmap_;
|
||
i.layers && i.layers.forEach(function (t) {
|
||
h.addLayer(t)
|
||
}.bind(this));
|
||
var u = document.createElement("div");
|
||
u.className = "ol-overviewmap-box", u.style.boxSizing = "border-box", this.boxOverlay_ = new sh({
|
||
position: [0, 0],
|
||
positioning: oh.BOTTOM_LEFT,
|
||
element: u
|
||
}), this.ovmap_.addOverlay(this.boxOverlay_);
|
||
var c = r + " " + xs + " " + bs + (this.collapsed_ && this.collapsible_ ? " " + Cs : "") + (this.collapsible_ ? "" : " ol-uncollapsible"),
|
||
p = this.element;
|
||
p.className = c, p.appendChild(this.ovmapDiv_), p.appendChild(l);
|
||
var d = this, f = this.boxOverlay_, g = this.boxOverlay_.getElement(), m = function (t) {
|
||
var e, i = {clientX: (e = t).clientX - g.offsetWidth / 2, clientY: e.clientY + g.offsetHeight / 2},
|
||
r = h.getEventCoordinate(i);
|
||
f.setPosition(r)
|
||
}, y = function (t) {
|
||
var e = h.getEventCoordinate(t);
|
||
d.getMap().getView().setCenter(e), window.removeEventListener("mousemove", m), window.removeEventListener("mouseup", y)
|
||
};
|
||
g.addEventListener("mousedown", function () {
|
||
window.addEventListener("mousemove", m), window.addEventListener("mouseup", y)
|
||
})
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.setMap = function (e) {
|
||
var i = this.getMap();
|
||
if (e !== i) {
|
||
if (i) {
|
||
var r = i.getView();
|
||
r && this.unbindView_(r), this.ovmap_.setTarget(null)
|
||
}
|
||
if (t.prototype.setMap.call(this, e), e) {
|
||
this.ovmap_.setTarget(this.ovmapDiv_), this.listenerKeys.push(w(e, c.PROPERTYCHANGE, this.handleMapPropertyChange_, this)), 0 === this.ovmap_.getLayers().getLength() && this.ovmap_.setLayerGroup(e.getLayerGroup());
|
||
var o = e.getView();
|
||
o && (this.bindView_(o), o.isDef() && (this.ovmap_.updateSize(), this.resetExtent_()))
|
||
}
|
||
}
|
||
}, e.prototype.handleMapPropertyChange_ = function (t) {
|
||
if (t.key === Gn.VIEW) {
|
||
var e = t.oldValue;
|
||
e && this.unbindView_(e);
|
||
var i = this.getMap().getView();
|
||
this.bindView_(i)
|
||
}
|
||
}, e.prototype.bindView_ = function (t) {
|
||
w(t, z(Qn.ROTATION), this.handleRotationChanged_, this)
|
||
}, e.prototype.unbindView_ = function (t) {
|
||
C(t, z(Qn.ROTATION), this.handleRotationChanged_, this)
|
||
}, e.prototype.handleRotationChanged_ = function () {
|
||
this.ovmap_.getView().setRotation(this.getMap().getView().getRotation())
|
||
}, e.prototype.validateExtent_ = function () {
|
||
var t = this.getMap(), e = this.ovmap_;
|
||
if (t.isRendered() && e.isRendered()) {
|
||
var i = t.getSize(), r = t.getView().calculateExtent(i), o = e.getSize(),
|
||
n = e.getView().calculateExtent(o), s = e.getPixelFromCoordinate(jt(r)),
|
||
a = e.getPixelFromCoordinate(Mt(r)), l = Math.abs(s[0] - a[0]), h = Math.abs(s[1] - a[1]),
|
||
u = o[0], c = o[1];
|
||
l < .1 * u || h < .1 * c || l > .75 * u || h > .75 * c ? this.resetExtent_() : dt(n, r) || this.recenter_()
|
||
}
|
||
}, e.prototype.resetExtent_ = function () {
|
||
var t = this.getMap(), e = this.ovmap_, i = t.getSize(), r = t.getView().calculateExtent(i),
|
||
o = e.getView(), n = Math.log(7.5) / Math.LN2;
|
||
Wt(r, 1 / (.1 * Math.pow(2, n / 2))), o.fit(r)
|
||
}, e.prototype.recenter_ = function () {
|
||
var t = this.getMap(), e = this.ovmap_, i = t.getView();
|
||
e.getView().setCenter(i.getCenter())
|
||
}, e.prototype.updateBox_ = function () {
|
||
var t = this.getMap(), e = this.ovmap_;
|
||
if (t.isRendered() && e.isRendered()) {
|
||
var i = t.getSize(), r = t.getView(), o = e.getView(), n = r.getRotation(), s = this.boxOverlay_,
|
||
a = this.boxOverlay_.getElement(), l = r.calculateExtent(i), h = o.getResolution(), u = Ot(l),
|
||
c = zt(l), p = this.calculateCoordinateRotate_(n, u);
|
||
s.setPosition(p), a && (a.style.width = Math.abs((u[0] - c[0]) / h) + "px", a.style.height = Math.abs((c[1] - u[1]) / h) + "px")
|
||
}
|
||
}, e.prototype.calculateCoordinateRotate_ = function (t, e) {
|
||
var i, r = this.getMap().getView().getCenter();
|
||
return r && (Ur(i = [e[0] - r[0], e[1] - r[1]], t), Fr(i, r)), i
|
||
}, e.prototype.handleClick_ = function (t) {
|
||
t.preventDefault(), this.handleToggle_()
|
||
}, e.prototype.handleToggle_ = function () {
|
||
this.element.classList.toggle(Cs), this.collapsed_ ? No(this.collapseLabel_, this.label_) : No(this.label_, this.collapseLabel_), this.collapsed_ = !this.collapsed_;
|
||
var t = this.ovmap_;
|
||
this.collapsed_ || t.isRendered() || (t.updateSize(), this.resetExtent_(), b(t, Dn.POSTRENDER, function (t) {
|
||
this.updateBox_()
|
||
}, this))
|
||
}, e.prototype.getCollapsible = function () {
|
||
return this.collapsible_
|
||
}, e.prototype.setCollapsible = function (t) {
|
||
this.collapsible_ !== t && (this.collapsible_ = t, this.element.classList.toggle("ol-uncollapsible"), !t && this.collapsed_ && this.handleToggle_())
|
||
}, e.prototype.setCollapsed = function (t) {
|
||
this.collapsible_ && this.collapsed_ !== t && this.handleToggle_()
|
||
}, e.prototype.getCollapsed = function () {
|
||
return this.collapsed_
|
||
}, e.prototype.getOverviewMap = function () {
|
||
return this.ovmap_
|
||
}, e
|
||
}(ys), Cc = "units",
|
||
Sc = {DEGREES: "degrees", IMPERIAL: "imperial", NAUTICAL: "nautical", METRIC: "metric", US: "us"},
|
||
Ec = [1, 2, 5];
|
||
|
||
function Tc(t) {
|
||
var e = t.frameState;
|
||
this.viewState_ = e ? e.viewState : null, this.updateElement_()
|
||
}
|
||
|
||
var Rc = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = void 0 !== i.className ? i.className : "ol-scale-line";
|
||
t.call(this, {
|
||
element: document.createElement("div"),
|
||
render: i.render || Tc,
|
||
target: i.target
|
||
}), this.innerElement_ = document.createElement("div"), this.innerElement_.className = r + "-inner", this.element.className = r + " " + xs, this.element.appendChild(this.innerElement_), this.viewState_ = null, this.minWidth_ = void 0 !== i.minWidth ? i.minWidth : 64, this.renderedVisible_ = !1, this.renderedWidth_ = void 0, this.renderedHTML_ = "", w(this, z(Cc), this.handleUnitsChanged_, this), this.setUnits(i.units || Sc.METRIC)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getUnits = function () {
|
||
return this.get(Cc)
|
||
}, e.prototype.handleUnitsChanged_ = function () {
|
||
this.updateElement_()
|
||
}, e.prototype.setUnits = function (t) {
|
||
this.set(Cc, t)
|
||
}, e.prototype.updateElement_ = function () {
|
||
var t = this.viewState_;
|
||
if (t) {
|
||
var e = t.center, i = t.projection, r = this.getUnits(),
|
||
o = r == Sc.DEGREES ? ve.DEGREES : ve.METERS, n = He(i, t.resolution, e, o);
|
||
i.getUnits() != ve.DEGREES && i.getMetersPerUnit() && o == ve.METERS && (n *= i.getMetersPerUnit());
|
||
var s = this.minWidth_ * n, a = "";
|
||
if (r == Sc.DEGREES) {
|
||
var l = ye[ve.DEGREES];
|
||
i.getUnits() == ve.DEGREES ? s *= l : n /= l, s < l / 60 ? (a = "″", n *= 3600) : s < l ? (a = "′", n *= 60) : a = "°"
|
||
} else r == Sc.IMPERIAL ? s < .9144 ? (a = "in", n /= .0254) : s < 1609.344 ? (a = "ft", n /= .3048) : (a = "mi", n /= 1609.344) : r == Sc.NAUTICAL ? (n /= 1852, a = "nm") : r == Sc.METRIC ? s < .001 ? (a = "μm", n *= 1e6) : s < 1 ? (a = "mm", n *= 1e3) : s < 1e3 ? a = "m" : (a = "km", n /= 1e3) : r == Sc.US ? s < .9144 ? (a = "in", n *= 39.37) : s < 1609.344 ? (a = "ft", n /= .30480061) : (a = "mi", n /= 1609.3472) : W(!1, 33);
|
||
for (var h, u, c = 3 * Math.floor(Math.log(this.minWidth_ * n) / Math.log(10)); ;) {
|
||
if (h = Ec[(c % 3 + 3) % 3] * Math.pow(10, Math.floor(c / 3)), u = Math.round(h / n), isNaN(u)) return this.element.style.display = "none", void (this.renderedVisible_ = !1);
|
||
if (u >= this.minWidth_) break;
|
||
++c
|
||
}
|
||
var p = h + " " + a;
|
||
this.renderedHTML_ != p && (this.innerElement_.innerHTML = p, this.renderedHTML_ = p), this.renderedWidth_ != u && (this.innerElement_.style.width = u + "px", this.renderedWidth_ = u), this.renderedVisible_ || (this.element.style.display = "", this.renderedVisible_ = !0)
|
||
} else this.renderedVisible_ && (this.element.style.display = "none", this.renderedVisible_ = !1)
|
||
}, e
|
||
}(ys), Pc = {VERTICAL: 0, HORIZONTAL: 1};
|
||
|
||
function Lc(t) {
|
||
if (t.frameState) {
|
||
this.sliderInitialized_ || this.initSlider_();
|
||
var e = t.frameState.viewState.resolution;
|
||
e !== this.currentResolution_ && (this.currentResolution_ = e, this.setThumbPosition_(e))
|
||
}
|
||
}
|
||
|
||
var Ic = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {
|
||
element: document.createElement("div"),
|
||
render: i.render || Lc
|
||
}), this.dragListenerKeys_ = [], this.currentResolution_ = void 0, this.direction_ = Pc.VERTICAL, this.dragging_, this.heightLimit_ = 0, this.widthLimit_ = 0, this.previousX_, this.previousY_, this.thumbSize_ = null, this.sliderInitialized_ = !1, this.duration_ = void 0 !== i.duration ? i.duration : 200;
|
||
var r = void 0 !== i.className ? i.className : "ol-zoomslider", o = document.createElement("button");
|
||
o.setAttribute("type", "button"), o.className = r + "-thumb " + xs;
|
||
var n = this.element;
|
||
n.className = r + " " + xs + " " + bs, n.appendChild(o), this.dragger_ = new Fn(n), w(this.dragger_, qo.POINTERDOWN, this.handleDraggerStart_, this), w(this.dragger_, qo.POINTERMOVE, this.handleDraggerDrag_, this), w(this.dragger_, qo.POINTERUP, this.handleDraggerEnd_, this), w(n, F.CLICK, this.handleContainerClick_, this), w(o, F.CLICK, M)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.disposeInternal = function () {
|
||
this.dragger_.dispose(), t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.setMap = function (e) {
|
||
t.prototype.setMap.call(this, e), e && e.render()
|
||
}, e.prototype.initSlider_ = function () {
|
||
var t = this.element, e = t.offsetWidth, i = t.offsetHeight, r = t.firstElementChild,
|
||
o = getComputedStyle(r), n = r.offsetWidth + parseFloat(o.marginRight) + parseFloat(o.marginLeft),
|
||
s = r.offsetHeight + parseFloat(o.marginTop) + parseFloat(o.marginBottom);
|
||
this.thumbSize_ = [n, s], e > i ? (this.direction_ = Pc.HORIZONTAL, this.widthLimit_ = e - n) : (this.direction_ = Pc.VERTICAL, this.heightLimit_ = i - s), this.sliderInitialized_ = !0
|
||
}, e.prototype.handleContainerClick_ = function (t) {
|
||
var e = this.getMap().getView(),
|
||
i = this.getRelativePosition_(t.offsetX - this.thumbSize_[0] / 2, t.offsetY - this.thumbSize_[1] / 2),
|
||
r = this.getResolutionForPosition_(i);
|
||
e.animate({resolution: e.constrainResolution(r), duration: this.duration_, easing: Lo})
|
||
}, e.prototype.handleDraggerStart_ = function (t) {
|
||
if (!this.dragging_ && t.originalEvent.target === this.element.firstElementChild && (this.getMap().getView().setHint($n.INTERACTING, 1), this.previousX_ = t.clientX, this.previousY_ = t.clientY, this.dragging_ = !0, 0 === this.dragListenerKeys_.length)) {
|
||
var e = this.handleDraggerDrag_, i = this.handleDraggerEnd_;
|
||
this.dragListenerKeys_.push(w(document, F.MOUSEMOVE, e, this), w(document, qo.POINTERMOVE, e, this), w(document, F.MOUSEUP, i, this), w(document, qo.POINTERUP, i, this))
|
||
}
|
||
}, e.prototype.handleDraggerDrag_ = function (t) {
|
||
if (this.dragging_) {
|
||
var e = this.element.firstElementChild, i = t.clientX - this.previousX_ + parseFloat(e.style.left),
|
||
r = t.clientY - this.previousY_ + parseFloat(e.style.top), o = this.getRelativePosition_(i, r);
|
||
this.currentResolution_ = this.getResolutionForPosition_(o), this.getMap().getView().setResolution(this.currentResolution_), this.setThumbPosition_(this.currentResolution_), this.previousX_ = t.clientX, this.previousY_ = t.clientY
|
||
}
|
||
}, e.prototype.handleDraggerEnd_ = function (t) {
|
||
if (this.dragging_) {
|
||
var e = this.getMap().getView();
|
||
e.setHint($n.INTERACTING, -1), e.animate({
|
||
resolution: e.constrainResolution(this.currentResolution_),
|
||
duration: this.duration_,
|
||
easing: Lo
|
||
}), this.dragging_ = !1, this.previousX_ = void 0, this.previousY_ = void 0, this.dragListenerKeys_.forEach(S), this.dragListenerKeys_.length = 0
|
||
}
|
||
}, e.prototype.setThumbPosition_ = function (t) {
|
||
var e = this.getPositionForResolution_(t), i = this.element.firstElementChild;
|
||
this.direction_ == Pc.HORIZONTAL ? i.style.left = this.widthLimit_ * e + "px" : i.style.top = this.heightLimit_ * e + "px"
|
||
}, e.prototype.getRelativePosition_ = function (t, e) {
|
||
return te(this.direction_ === Pc.HORIZONTAL ? t / this.widthLimit_ : e / this.heightLimit_, 0, 1)
|
||
}, e.prototype.getResolutionForPosition_ = function (t) {
|
||
return this.getMap().getView().getResolutionForValueFunction()(1 - t)
|
||
}, e.prototype.getPositionForResolution_ = function (t) {
|
||
return 1 - this.getMap().getView().getValueForResolutionFunction()(t)
|
||
}, e
|
||
}(ys), Oc = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {
|
||
element: document.createElement("div"),
|
||
target: i.target
|
||
}), this.extent = i.extent ? i.extent : null;
|
||
var r = void 0 !== i.className ? i.className : "ol-zoom-extent", o = void 0 !== i.label ? i.label : "E",
|
||
n = void 0 !== i.tipLabel ? i.tipLabel : "Fit to extent", s = document.createElement("button");
|
||
s.setAttribute("type", "button"), s.title = n, s.appendChild("string" == typeof o ? document.createTextNode(o) : o), w(s, F.CLICK, this.handleClick_, this);
|
||
var a = r + " " + xs + " " + bs, l = this.element;
|
||
l.className = a, l.appendChild(s)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleClick_ = function (t) {
|
||
t.preventDefault(), this.handleZoomToExtent()
|
||
}, e.prototype.handleZoomToExtent = function () {
|
||
var t = this.getMap().getView(), e = this.extent ? this.extent : t.getProjection().getExtent();
|
||
t.fit(e)
|
||
}, e
|
||
}(ys), Mc = function () {
|
||
this.dataProjection = null, this.defaultFeatureProjection = null
|
||
};
|
||
Mc.prototype.getReadOptions = function (t, e) {
|
||
var i;
|
||
return e && (i = {
|
||
dataProjection: e.dataProjection ? e.dataProjection : this.readProjection(t),
|
||
featureProjection: e.featureProjection
|
||
}), this.adaptOptions(i)
|
||
}, Mc.prototype.adaptOptions = function (t) {
|
||
return p({dataProjection: this.dataProjection, featureProjection: this.defaultFeatureProjection}, t)
|
||
}, Mc.prototype.getLastExtent = function () {
|
||
return null
|
||
}, Mc.prototype.getType = function () {
|
||
return n()
|
||
}, Mc.prototype.readFeature = function (t, e) {
|
||
return n()
|
||
}, Mc.prototype.readFeatures = function (t, e) {
|
||
return n()
|
||
}, Mc.prototype.readGeometry = function (t, e) {
|
||
return n()
|
||
}, Mc.prototype.readProjection = function (t) {
|
||
return n()
|
||
}, Mc.prototype.writeFeature = function (t, e) {
|
||
return n()
|
||
}, Mc.prototype.writeFeatures = function (t, e) {
|
||
return n()
|
||
}, Mc.prototype.writeGeometry = function (t, e) {
|
||
return n()
|
||
};
|
||
var Ac = Mc;
|
||
|
||
function kc(t, e, i) {
|
||
var r, o = i ? We(i.featureProjection) : null, n = i ? We(i.dataProjection) : null;
|
||
if (r = o && n && !Qe(o, n) ? Array.isArray(t) ? ri(t, n, o) : (e ? t.clone() : t).transform(e ? o : n, e ? n : o) : t, e && i && void 0 !== i.decimals && !Array.isArray(r)) {
|
||
var s = Math.pow(10, i.decimals);
|
||
r === t && (r = t.clone()), r.applyTransform(function (t) {
|
||
for (var e = 0, i = t.length; e < i; ++e) t[e] = Math.round(t[e] * s) / s;
|
||
return t
|
||
})
|
||
}
|
||
return r
|
||
}
|
||
|
||
function Fc(t) {
|
||
if ("string" == typeof t) {
|
||
var e = JSON.parse(t);
|
||
return e || null
|
||
}
|
||
return null !== t ? t : null
|
||
}
|
||
|
||
var Nc = function (t) {
|
||
function e() {
|
||
t.call(this)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getType = function () {
|
||
return gh.JSON
|
||
}, e.prototype.readFeature = function (t, e) {
|
||
return this.readFeatureFromObject(Fc(t), this.getReadOptions(t, e))
|
||
}, e.prototype.readFeatures = function (t, e) {
|
||
return this.readFeaturesFromObject(Fc(t), this.getReadOptions(t, e))
|
||
}, e.prototype.readFeatureFromObject = function (t, e) {
|
||
return n()
|
||
}, e.prototype.readFeaturesFromObject = function (t, e) {
|
||
return n()
|
||
}, e.prototype.readGeometry = function (t, e) {
|
||
return this.readGeometryFromObject(Fc(t), this.getReadOptions(t, e))
|
||
}, e.prototype.readGeometryFromObject = function (t, e) {
|
||
return n()
|
||
}, e.prototype.readProjection = function (t) {
|
||
return this.readProjectionFromObject(Fc(t))
|
||
}, e.prototype.readProjectionFromObject = function (t) {
|
||
return n()
|
||
}, e.prototype.writeFeature = function (t, e) {
|
||
return JSON.stringify(this.writeFeatureObject(t, e))
|
||
}, e.prototype.writeFeatureObject = function (t, e) {
|
||
return n()
|
||
}, e.prototype.writeFeatures = function (t, e) {
|
||
return JSON.stringify(this.writeFeaturesObject(t, e))
|
||
}, e.prototype.writeFeaturesObject = function (t, e) {
|
||
return n()
|
||
}, e.prototype.writeGeometry = function (t, e) {
|
||
return JSON.stringify(this.writeGeometryObject(t, e))
|
||
}, e.prototype.writeGeometryObject = function (t, e) {
|
||
return n()
|
||
}, e
|
||
}(Ac), Dc = function (t) {
|
||
function e(e, i, r) {
|
||
if (t.call(this), this.ends_ = [], this.maxDelta_ = -1, this.maxDeltaRevision_ = -1, Array.isArray(e[0])) this.setCoordinates(e, i); else if (void 0 !== i && r) this.setFlatCoordinates(i, e), this.ends_ = r; else {
|
||
for (var o = this.getLayout(), n = e, s = [], a = [], l = 0, h = n.length; l < h; ++l) {
|
||
var u = n[l];
|
||
0 === l && (o = u.getLayout()), Q(s, u.getFlatCoordinates()), a.push(s.length)
|
||
}
|
||
this.setFlatCoordinates(o, s), this.ends_ = a
|
||
}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.appendLineString = function (t) {
|
||
this.flatCoordinates ? Q(this.flatCoordinates, t.getFlatCoordinates().slice()) : this.flatCoordinates = t.getFlatCoordinates().slice(), this.ends_.push(this.flatCoordinates.length), this.changed()
|
||
}, e.prototype.clone = function () {
|
||
return new e(this.flatCoordinates.slice(), this.layout, this.ends_.slice())
|
||
}, e.prototype.closestPointXY = function (t, e, i, r) {
|
||
return r < ct(this.getExtent(), t, e) ? r : (this.maxDeltaRevision_ != this.getRevision() && (this.maxDelta_ = Math.sqrt(Pi(this.flatCoordinates, 0, this.ends_, this.stride, 0)), this.maxDeltaRevision_ = this.getRevision()), Oi(this.flatCoordinates, 0, this.ends_, this.stride, this.maxDelta_, !1, t, e, i, r))
|
||
}, e.prototype.getCoordinateAtM = function (t, e, i) {
|
||
if (this.layout != qt.XYM && this.layout != qt.XYZM || 0 === this.flatCoordinates.length) return null;
|
||
var r = void 0 !== e && e, o = void 0 !== i && i;
|
||
return Zr(this.flatCoordinates, 0, this.ends_, this.stride, t, r, o)
|
||
}, e.prototype.getCoordinates = function () {
|
||
return Gi(this.flatCoordinates, 0, this.ends_, this.stride)
|
||
}, e.prototype.getEnds = function () {
|
||
return this.ends_
|
||
}, e.prototype.getLineString = function (t) {
|
||
return t < 0 || this.ends_.length <= t ? null : new Jr(this.flatCoordinates.slice(0 === t ? 0 : this.ends_[t - 1], this.ends_[t]), this.layout)
|
||
}, e.prototype.getLineStrings = function () {
|
||
for (var t = this.flatCoordinates, e = this.ends_, i = this.layout, r = [], o = 0, n = 0, s = e.length; n < s; ++n) {
|
||
var a = e[n], l = new Jr(t.slice(o, a), i);
|
||
r.push(l), o = a
|
||
}
|
||
return r
|
||
}, e.prototype.getFlatMidpoints = function () {
|
||
for (var t = [], e = this.flatCoordinates, i = 0, r = this.ends_, o = this.stride, n = 0, s = r.length; n < s; ++n) {
|
||
var a = r[n];
|
||
Q(t, Xr(e, i, a, o, .5)), i = a
|
||
}
|
||
return t
|
||
}, e.prototype.getSimplifiedGeometryInternal = function (t) {
|
||
var i = [], r = [];
|
||
return i.length = Ui(this.flatCoordinates, 0, this.ends_, this.stride, t, i, 0, r), new e(i, qt.XY, r)
|
||
}, e.prototype.getType = function () {
|
||
return Zt.MULTI_LINE_STRING
|
||
}, e.prototype.intersectsExtent = function (t) {
|
||
return rr(this.flatCoordinates, 0, this.ends_, this.stride, t)
|
||
}, e.prototype.setCoordinates = function (t, e) {
|
||
this.setLayout(e, t, 2), this.flatCoordinates || (this.flatCoordinates = []);
|
||
var i = Fi(this.flatCoordinates, 0, t, this.stride, this.ends_);
|
||
this.flatCoordinates.length = 0 === i.length ? 0 : i[i.length - 1], this.changed()
|
||
}, e
|
||
}(bi), Gc = function (t) {
|
||
function e(e, i) {
|
||
t.call(this), i && !Array.isArray(e[0]) ? this.setFlatCoordinates(i, e) : this.setCoordinates(e, i)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.appendPoint = function (t) {
|
||
this.flatCoordinates ? Q(this.flatCoordinates, t.getFlatCoordinates()) : this.flatCoordinates = t.getFlatCoordinates().slice(), this.changed()
|
||
}, e.prototype.clone = function () {
|
||
return new e(this.flatCoordinates.slice(), this.layout)
|
||
}, e.prototype.closestPointXY = function (t, e, i, r) {
|
||
if (r < ct(this.getExtent(), t, e)) return r;
|
||
for (var o = this.flatCoordinates, n = this.stride, s = 0, a = o.length; s < a; s += n) {
|
||
var l = oe(t, e, o[s], o[s + 1]);
|
||
if (l < r) {
|
||
r = l;
|
||
for (var h = 0; h < n; ++h) i[h] = o[s + h];
|
||
i.length = n
|
||
}
|
||
}
|
||
return r
|
||
}, e.prototype.getCoordinates = function () {
|
||
return Di(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride)
|
||
}, e.prototype.getPoint = function (t) {
|
||
var e = this.flatCoordinates ? this.flatCoordinates.length / this.stride : 0;
|
||
return t < 0 || e <= t ? null : new qi(this.flatCoordinates.slice(t * this.stride, (t + 1) * this.stride), this.layout)
|
||
}, e.prototype.getPoints = function () {
|
||
for (var t = this.flatCoordinates, e = this.layout, i = this.stride, r = [], o = 0, n = t.length; o < n; o += i) {
|
||
var s = new qi(t.slice(o, o + i), e);
|
||
r.push(s)
|
||
}
|
||
return r
|
||
}, e.prototype.getType = function () {
|
||
return Zt.MULTI_POINT
|
||
}, e.prototype.intersectsExtent = function (t) {
|
||
for (var e = this.flatCoordinates, i = this.stride, r = 0, o = e.length; r < o; r += i) {
|
||
if (ft(t, e[r], e[r + 1])) return !0
|
||
}
|
||
return !1
|
||
}, e.prototype.setCoordinates = function (t, e) {
|
||
this.setLayout(e, t, 1), this.flatCoordinates || (this.flatCoordinates = []), this.flatCoordinates.length = ki(this.flatCoordinates, 0, t, this.stride), this.changed()
|
||
}, e
|
||
}(bi);
|
||
|
||
function jc(t, e, i, r) {
|
||
for (var o = [], n = [1 / 0, 1 / 0, -1 / 0, -1 / 0], s = 0, a = i.length; s < a; ++s) {
|
||
var l = i[s];
|
||
n = wt(t, e, l[0], r), o.push((n[0] + n[2]) / 2, (n[1] + n[3]) / 2), e = l[l.length - 1]
|
||
}
|
||
return o
|
||
}
|
||
|
||
var zc = function (t) {
|
||
function e(e, i, r) {
|
||
if (t.call(this), this.endss_ = [], this.flatInteriorPointsRevision_ = -1, this.flatInteriorPoints_ = null, this.maxDelta_ = -1, this.maxDeltaRevision_ = -1, this.orientedRevision_ = -1, this.orientedFlatCoordinates_ = null, !r && !Array.isArray(e[0])) {
|
||
for (var o = this.getLayout(), n = e, s = [], a = [], l = 0, h = n.length; l < h; ++l) {
|
||
var u = n[l];
|
||
0 === l && (o = u.getLayout());
|
||
for (var c = s.length, p = u.getEnds(), d = 0, f = p.length; d < f; ++d) p[d] += c;
|
||
Q(s, u.getFlatCoordinates()), a.push(p)
|
||
}
|
||
i = o, e = s, r = a
|
||
}
|
||
void 0 !== i && r ? (this.setFlatCoordinates(i, e), this.endss_ = r) : this.setCoordinates(e, i)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.appendPolygon = function (t) {
|
||
var e;
|
||
if (this.flatCoordinates) {
|
||
var i = this.flatCoordinates.length;
|
||
Q(this.flatCoordinates, t.getFlatCoordinates());
|
||
for (var r = 0, o = (e = t.getEnds().slice()).length; r < o; ++r) e[r] += i
|
||
} else this.flatCoordinates = t.getFlatCoordinates().slice(), e = t.getEnds().slice(), this.endss_.push();
|
||
this.endss_.push(e), this.changed()
|
||
}, e.prototype.clone = function () {
|
||
for (var t = this.endss_.length, i = new Array(t), r = 0; r < t; ++r) i[r] = this.endss_[r].slice();
|
||
return new e(this.flatCoordinates.slice(), this.layout, i)
|
||
}, e.prototype.closestPointXY = function (t, e, i, r) {
|
||
return r < ct(this.getExtent(), t, e) ? r : (this.maxDeltaRevision_ != this.getRevision() && (this.maxDelta_ = Math.sqrt(Li(this.flatCoordinates, 0, this.endss_, this.stride, 0)), this.maxDeltaRevision_ = this.getRevision()), Mi(this.getOrientedFlatCoordinates(), 0, this.endss_, this.stride, this.maxDelta_, !0, t, e, i, r))
|
||
}, e.prototype.containsXY = function (t, e) {
|
||
return $i(this.getOrientedFlatCoordinates(), 0, this.endss_, this.stride, t, e)
|
||
}, e.prototype.getArea = function () {
|
||
return Ei(this.getOrientedFlatCoordinates(), 0, this.endss_, this.stride)
|
||
}, e.prototype.getCoordinates = function (t) {
|
||
var e;
|
||
return void 0 !== t ? pr(e = this.getOrientedFlatCoordinates().slice(), 0, this.endss_, this.stride, t) : e = this.flatCoordinates, ji(e, 0, this.endss_, this.stride)
|
||
}, e.prototype.getEndss = function () {
|
||
return this.endss_
|
||
}, e.prototype.getFlatInteriorPoints = function () {
|
||
if (this.flatInteriorPointsRevision_ != this.getRevision()) {
|
||
var t = jc(this.flatCoordinates, 0, this.endss_, this.stride);
|
||
this.flatInteriorPoints_ = tr(this.getOrientedFlatCoordinates(), 0, this.endss_, this.stride, t), this.flatInteriorPointsRevision_ = this.getRevision()
|
||
}
|
||
return this.flatInteriorPoints_
|
||
}, e.prototype.getInteriorPoints = function () {
|
||
return new Gc(this.getFlatInteriorPoints().slice(), qt.XYM)
|
||
}, e.prototype.getOrientedFlatCoordinates = function () {
|
||
if (this.orientedRevision_ != this.getRevision()) {
|
||
var t = this.flatCoordinates;
|
||
ur(t, 0, this.endss_, this.stride) ? this.orientedFlatCoordinates_ = t : (this.orientedFlatCoordinates_ = t.slice(), this.orientedFlatCoordinates_.length = pr(this.orientedFlatCoordinates_, 0, this.endss_, this.stride)), this.orientedRevision_ = this.getRevision()
|
||
}
|
||
return this.orientedFlatCoordinates_
|
||
}, e.prototype.getSimplifiedGeometryInternal = function (t) {
|
||
var i = [], r = [];
|
||
return i.length = Hi(this.flatCoordinates, 0, this.endss_, this.stride, Math.sqrt(t), i, 0, r), new e(i, qt.XY, r)
|
||
}, e.prototype.getPolygon = function (t) {
|
||
if (t < 0 || this.endss_.length <= t) return null;
|
||
var e;
|
||
if (0 === t) e = 0; else {
|
||
var i = this.endss_[t - 1];
|
||
e = i[i.length - 1]
|
||
}
|
||
var r = this.endss_[t].slice(), o = r[r.length - 1];
|
||
if (0 !== e) for (var n = 0, s = r.length; n < s; ++n) r[n] -= e;
|
||
return new fr(this.flatCoordinates.slice(e, o), this.layout, r)
|
||
}, e.prototype.getPolygons = function () {
|
||
for (var t = this.layout, e = this.flatCoordinates, i = this.endss_, r = [], o = 0, n = 0, s = i.length; n < s; ++n) {
|
||
var a = i[n].slice(), l = a[a.length - 1];
|
||
if (0 !== o) for (var h = 0, u = a.length; h < u; ++h) a[h] -= o;
|
||
var c = new fr(e.slice(o, l), t, a);
|
||
r.push(c), o = l
|
||
}
|
||
return r
|
||
}, e.prototype.getType = function () {
|
||
return Zt.MULTI_POLYGON
|
||
}, e.prototype.intersectsExtent = function (t) {
|
||
return sr(this.getOrientedFlatCoordinates(), 0, this.endss_, this.stride, t)
|
||
}, e.prototype.setCoordinates = function (t, e) {
|
||
this.setLayout(e, t, 3), this.flatCoordinates || (this.flatCoordinates = []);
|
||
var i = Ni(this.flatCoordinates, 0, t, this.stride, this.endss_);
|
||
if (0 === i.length) this.flatCoordinates.length = 0; else {
|
||
var r = i[i.length - 1];
|
||
this.flatCoordinates.length = 0 === r.length ? 0 : r[r.length - 1]
|
||
}
|
||
this.changed()
|
||
}, e
|
||
}(bi), Uc = {};
|
||
Uc[Zt.POINT] = function (t) {
|
||
var e;
|
||
e = void 0 !== t.m && void 0 !== t.z ? new qi([t.x, t.y, t.z, t.m], qt.XYZM) : void 0 !== t.z ? new qi([t.x, t.y, t.z], qt.XYZ) : void 0 !== t.m ? new qi([t.x, t.y, t.m], qt.XYM) : new qi([t.x, t.y]);
|
||
return e
|
||
}, Uc[Zt.LINE_STRING] = function (t) {
|
||
var e = Yc(t);
|
||
return new Jr(t.paths[0], e)
|
||
}, Uc[Zt.POLYGON] = function (t) {
|
||
var e = Yc(t);
|
||
return new fr(t.rings, e)
|
||
}, Uc[Zt.MULTI_POINT] = function (t) {
|
||
var e = Yc(t);
|
||
return new Gc(t.points, e)
|
||
}, Uc[Zt.MULTI_LINE_STRING] = function (t) {
|
||
var e = Yc(t);
|
||
return new Dc(t.paths, e)
|
||
}, Uc[Zt.MULTI_POLYGON] = function (t) {
|
||
var e = Yc(t);
|
||
return new zc(t.rings, e)
|
||
};
|
||
var Bc = {};
|
||
|
||
function Vc(t, e) {
|
||
if (!t) return null;
|
||
var i;
|
||
if ("number" == typeof t.x && "number" == typeof t.y) i = Zt.POINT; else if (t.points) i = Zt.MULTI_POINT; else if (t.paths) {
|
||
i = 1 === t.paths.length ? Zt.LINE_STRING : Zt.MULTI_LINE_STRING
|
||
} else if (t.rings) {
|
||
var r = t, o = Yc(r), n = function (t, e) {
|
||
var i, r, o = [], n = [], s = [];
|
||
for (i = 0, r = t.length; i < r; ++i) {
|
||
o.length = 0, ki(o, 0, t[i], e.length);
|
||
var a = lr(o, 0, o.length, e.length);
|
||
a ? n.push([t[i]]) : s.push(t[i])
|
||
}
|
||
for (; s.length;) {
|
||
var l = s.shift(), h = !1;
|
||
for (i = n.length - 1; i >= 0; i--) {
|
||
var u = n[i][0], c = dt(new Xi(u).getExtent(), new Xi(l).getExtent());
|
||
if (c) {
|
||
n[i].push(l), h = !0;
|
||
break
|
||
}
|
||
}
|
||
h || n.push([l.reverse()])
|
||
}
|
||
return n
|
||
}(r.rings, o);
|
||
1 === n.length ? (i = Zt.POLYGON, t.rings = n[0]) : (i = Zt.MULTI_POLYGON, t.rings = n)
|
||
}
|
||
return kc((0, Uc[i])(t), !1, e)
|
||
}
|
||
|
||
function Yc(t) {
|
||
var e = qt.XY;
|
||
return !0 === t.hasZ && !0 === t.hasM ? e = qt.XYZM : !0 === t.hasZ ? e = qt.XYZ : !0 === t.hasM && (e = qt.XYM), e
|
||
}
|
||
|
||
function Wc(t) {
|
||
var e = t.getLayout();
|
||
return {hasZ: e === qt.XYZ || e === qt.XYZM, hasM: e === qt.XYM || e === qt.XYZM}
|
||
}
|
||
|
||
function Hc(t, e) {
|
||
return (0, Bc[t.getType()])(kc(t, !0, e), e)
|
||
}
|
||
|
||
Bc[Zt.POINT] = function (t, e) {
|
||
var i, r = t.getCoordinates(), o = t.getLayout();
|
||
o === qt.XYZ ? i = {x: r[0], y: r[1], z: r[2]} : o === qt.XYM ? i = {
|
||
x: r[0],
|
||
y: r[1],
|
||
m: r[2]
|
||
} : o === qt.XYZM ? i = {x: r[0], y: r[1], z: r[2], m: r[3]} : o === qt.XY ? i = {
|
||
x: r[0],
|
||
y: r[1]
|
||
} : W(!1, 34);
|
||
return i
|
||
}, Bc[Zt.LINE_STRING] = function (t, e) {
|
||
var i = t, r = Wc(i);
|
||
return {hasZ: r.hasZ, hasM: r.hasM, paths: [i.getCoordinates()]}
|
||
}, Bc[Zt.POLYGON] = function (t, e) {
|
||
var i = t, r = Wc(i);
|
||
return {hasZ: r.hasZ, hasM: r.hasM, rings: i.getCoordinates(!1)}
|
||
}, Bc[Zt.MULTI_POINT] = function (t, e) {
|
||
var i = t, r = Wc(i);
|
||
return {hasZ: r.hasZ, hasM: r.hasM, points: i.getCoordinates()}
|
||
}, Bc[Zt.MULTI_LINE_STRING] = function (t, e) {
|
||
var i = t, r = Wc(i);
|
||
return {hasZ: r.hasZ, hasM: r.hasM, paths: i.getCoordinates()}
|
||
}, Bc[Zt.MULTI_POLYGON] = function (t, e) {
|
||
for (var i = Wc(t), r = t.getCoordinates(!1), o = [], n = 0; n < r.length; n++) for (var s = r[n].length - 1; s >= 0; s--) o.push(r[n][s]);
|
||
return {hasZ: i.hasZ, hasM: i.hasM, rings: o}
|
||
};
|
||
var Xc = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this), this.geometryName_ = i.geometryName
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.readFeatureFromObject = function (t, e) {
|
||
var i = t, r = Vc(i.geometry, e), o = new X;
|
||
return this.geometryName_ && o.setGeometryName(this.geometryName_), o.setGeometry(r), e && e.idField && i.attributes[e.idField] && o.setId(i.attributes[e.idField]), i.attributes && o.setProperties(i.attributes), o
|
||
}, e.prototype.readFeaturesFromObject = function (t, e) {
|
||
var i = e || {};
|
||
if (t.features) {
|
||
var r = [], o = t.features;
|
||
i.idField = t.objectIdFieldName;
|
||
for (var n = 0, s = o.length; n < s; ++n) r.push(this.readFeatureFromObject(o[n], i));
|
||
return r
|
||
}
|
||
return [this.readFeatureFromObject(t, i)]
|
||
}, e.prototype.readGeometryFromObject = function (t, e) {
|
||
return Vc(t, e)
|
||
}, e.prototype.readProjectionFromObject = function (t) {
|
||
return t.spatialReference && void 0 !== t.spatialReference.wkid ? We("EPSG:" + t.spatialReference.wkid) : null
|
||
}, e.prototype.writeGeometryObject = function (t, e) {
|
||
return Hc(t, this.adaptOptions(e))
|
||
}, e.prototype.writeFeatureObject = function (t, e) {
|
||
e = this.adaptOptions(e);
|
||
var i = {}, r = t.getGeometry();
|
||
r && (i.geometry = Hc(r, e), e && e.featureProjection && (i.geometry.spatialReference = {wkid: Number(We(e.featureProjection).getCode().split(":").pop())}));
|
||
var o = t.getProperties();
|
||
return delete o[t.getGeometryName()], g(o) ? i.attributes = {} : i.attributes = o, i
|
||
}, e.prototype.writeFeaturesObject = function (t, e) {
|
||
e = this.adaptOptions(e);
|
||
for (var i = [], r = 0, o = t.length; r < o; ++r) i.push(this.writeFeatureObject(t[r], e));
|
||
return {features: i}
|
||
}, e
|
||
}(Nc), qc = document.implementation.createDocument("", "", null),
|
||
Zc = "http://www.w3.org/2001/XMLSchema-instance";
|
||
|
||
function Kc(t, e) {
|
||
return qc.createElementNS(t, e)
|
||
}
|
||
|
||
function Jc(t, e) {
|
||
return $c(t, e, []).join("")
|
||
}
|
||
|
||
function $c(t, e, i) {
|
||
var r;
|
||
if (t.nodeType == Node.CDATA_SECTION_NODE || t.nodeType == Node.TEXT_NODE) e ? i.push(String(t.nodeValue).replace(/(\r\n|\r|\n)/g, "")) : i.push(t.nodeValue); else for (r = t.firstChild; r; r = r.nextSibling) $c(r, e, i);
|
||
return i
|
||
}
|
||
|
||
function Qc(t) {
|
||
return "documentElement" in t
|
||
}
|
||
|
||
function tp(t, e, i) {
|
||
return t.getAttributeNS(e, i) || ""
|
||
}
|
||
|
||
function ep(t) {
|
||
return (new DOMParser).parseFromString(t, "application/xml")
|
||
}
|
||
|
||
function ip(t, e) {
|
||
return function (i, r) {
|
||
var o = t.call(void 0 !== e ? e : this, i, r);
|
||
void 0 !== o && Q(r[r.length - 1], o)
|
||
}
|
||
}
|
||
|
||
function rp(t, e) {
|
||
return function (i, r) {
|
||
var o = t.call(void 0 !== e ? e : this, i, r);
|
||
void 0 !== o && r[r.length - 1].push(o)
|
||
}
|
||
}
|
||
|
||
function op(t, e) {
|
||
return function (i, r) {
|
||
var o = t.call(void 0 !== e ? e : this, i, r);
|
||
void 0 !== o && (r[r.length - 1] = o)
|
||
}
|
||
}
|
||
|
||
function np(t, e, i) {
|
||
return function (r, o) {
|
||
var n = t.call(void 0 !== i ? i : this, r, o);
|
||
if (void 0 !== n) {
|
||
var s = o[o.length - 1], a = void 0 !== e ? e : r.localName;
|
||
(a in s ? s[a] : s[a] = []).push(n)
|
||
}
|
||
}
|
||
}
|
||
|
||
function sp(t, e, i) {
|
||
return function (r, o) {
|
||
var n = t.call(void 0 !== i ? i : this, r, o);
|
||
void 0 !== n && (o[o.length - 1][void 0 !== e ? e : r.localName] = n)
|
||
}
|
||
}
|
||
|
||
function ap(t, e) {
|
||
return function (i, r, o) {
|
||
t.call(void 0 !== e ? e : this, i, r, o), o[o.length - 1].node.appendChild(i)
|
||
}
|
||
}
|
||
|
||
function lp(t, e) {
|
||
var i, r;
|
||
return function (e, o, n) {
|
||
if (void 0 === i) {
|
||
i = {};
|
||
var s = {};
|
||
s[e.localName] = t, i[e.namespaceURI] = s, r = hp(e.localName)
|
||
}
|
||
gp(i, r, o, n)
|
||
}
|
||
}
|
||
|
||
function hp(t, e) {
|
||
var i = t;
|
||
return function (t, r, o) {
|
||
var n = r[r.length - 1].node, s = i;
|
||
return void 0 === s && (s = o), Kc(void 0 !== e ? e : n.namespaceURI, s)
|
||
}
|
||
}
|
||
|
||
var up = hp();
|
||
|
||
function cp(t, e) {
|
||
for (var i = e.length, r = new Array(i), o = 0; o < i; ++o) r[o] = t[e[o]];
|
||
return r
|
||
}
|
||
|
||
function pp(t, e, i) {
|
||
var r, o, n = void 0 !== i ? i : {};
|
||
for (r = 0, o = t.length; r < o; ++r) n[t[r]] = e;
|
||
return n
|
||
}
|
||
|
||
function dp(t, e, i, r) {
|
||
var o;
|
||
for (o = e.firstElementChild; o; o = o.nextElementSibling) {
|
||
var n = t[o.namespaceURI];
|
||
if (void 0 !== n) {
|
||
var s = n[o.localName];
|
||
void 0 !== s && s.call(r, o, i)
|
||
}
|
||
}
|
||
}
|
||
|
||
function fp(t, e, i, r, o) {
|
||
return r.push(t), dp(e, i, r, o), r.pop()
|
||
}
|
||
|
||
function gp(t, e, i, r, o, n) {
|
||
for (var s, a, l = (void 0 !== o ? o : i).length, h = 0; h < l; ++h) void 0 !== (s = i[h]) && void 0 !== (a = e.call(void 0 !== n ? n : this, s, r, void 0 !== o ? o[h] : void 0)) && t[a.namespaceURI][a.localName].call(n, a, s, r)
|
||
}
|
||
|
||
function mp(t, e, i, r, o, n, s) {
|
||
return o.push(t), gp(e, i, r, o, n, s), o.pop()
|
||
}
|
||
|
||
var yp = function (t) {
|
||
function e() {
|
||
t.call(this), this.xmlSerializer_ = new XMLSerializer
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getType = function () {
|
||
return gh.XML
|
||
}, e.prototype.readFeature = function (t, e) {
|
||
if (t) {
|
||
if ("string" == typeof t) {
|
||
var i = ep(t);
|
||
return this.readFeatureFromDocument(i, e)
|
||
}
|
||
return Qc(t) ? this.readFeatureFromDocument(t, e) : this.readFeatureFromNode(t, e)
|
||
}
|
||
return null
|
||
}, e.prototype.readFeatureFromDocument = function (t, e) {
|
||
var i = this.readFeaturesFromDocument(t, e);
|
||
return i.length > 0 ? i[0] : null
|
||
}, e.prototype.readFeatureFromNode = function (t, e) {
|
||
return null
|
||
}, e.prototype.readFeatures = function (t, e) {
|
||
if (t) {
|
||
if ("string" == typeof t) {
|
||
var i = ep(t);
|
||
return this.readFeaturesFromDocument(i, e)
|
||
}
|
||
return Qc(t) ? this.readFeaturesFromDocument(t, e) : this.readFeaturesFromNode(t, e)
|
||
}
|
||
return []
|
||
}, e.prototype.readFeaturesFromDocument = function (t, e) {
|
||
for (var i = [], r = t.firstChild; r; r = r.nextSibling) r.nodeType == Node.ELEMENT_NODE && Q(i, this.readFeaturesFromNode(r, e));
|
||
return i
|
||
}, e.prototype.readFeaturesFromNode = function (t, e) {
|
||
return n()
|
||
}, e.prototype.readGeometry = function (t, e) {
|
||
if (t) {
|
||
if ("string" == typeof t) {
|
||
var i = ep(t);
|
||
return this.readGeometryFromDocument(i, e)
|
||
}
|
||
return Qc(t) ? this.readGeometryFromDocument(t, e) : this.readGeometryFromNode(t, e)
|
||
}
|
||
return null
|
||
}, e.prototype.readGeometryFromDocument = function (t, e) {
|
||
return null
|
||
}, e.prototype.readGeometryFromNode = function (t, e) {
|
||
return null
|
||
}, e.prototype.readProjection = function (t) {
|
||
if (t) {
|
||
if ("string" == typeof t) {
|
||
var e = ep(t);
|
||
return this.readProjectionFromDocument(e)
|
||
}
|
||
return Qc(t) ? this.readProjectionFromDocument(t) : this.readProjectionFromNode(t)
|
||
}
|
||
return null
|
||
}, e.prototype.readProjectionFromDocument = function (t) {
|
||
return this.dataProjection
|
||
}, e.prototype.readProjectionFromNode = function (t) {
|
||
return this.dataProjection
|
||
}, e.prototype.writeFeature = function (t, e) {
|
||
var i = this.writeFeatureNode(t, e);
|
||
return this.xmlSerializer_.serializeToString(i)
|
||
}, e.prototype.writeFeatureNode = function (t, e) {
|
||
return null
|
||
}, e.prototype.writeFeatures = function (t, e) {
|
||
var i = this.writeFeaturesNode(t, e);
|
||
return this.xmlSerializer_.serializeToString(i)
|
||
}, e.prototype.writeFeaturesNode = function (t, e) {
|
||
return null
|
||
}, e.prototype.writeGeometry = function (t, e) {
|
||
var i = this.writeGeometryNode(t, e);
|
||
return this.xmlSerializer_.serializeToString(i)
|
||
}, e.prototype.writeGeometryNode = function (t, e) {
|
||
return null
|
||
}, e
|
||
}(Ac), vp = "http://www.opengis.net/gml", _p = /^[\s\xa0]*$/, xp = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = e || {};
|
||
this.featureType = i.featureType, this.featureNS = i.featureNS, this.srsName = i.srsName, this.schemaLocation = "", this.FEATURE_COLLECTION_PARSERS = {}, this.FEATURE_COLLECTION_PARSERS[this.namespace] = {
|
||
featureMember: rp(this.readFeaturesInternal),
|
||
featureMembers: op(this.readFeaturesInternal)
|
||
}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.readFeaturesInternal = function (t, e) {
|
||
var i = t.localName, r = null;
|
||
if ("FeatureCollection" == i) r = fp([], this.FEATURE_COLLECTION_PARSERS, t, e, this); else if ("featureMembers" == i || "featureMember" == i) {
|
||
var o = e[0], n = o.featureType, s = o.featureNS;
|
||
if (!n && t.childNodes) {
|
||
n = [], s = {};
|
||
for (var a = 0, l = t.childNodes.length; a < l; ++a) {
|
||
var h = t.childNodes[a];
|
||
if (1 === h.nodeType) {
|
||
var u = h.nodeName.split(":").pop();
|
||
if (-1 === n.indexOf(u)) {
|
||
var c = "", p = 0, d = h.namespaceURI;
|
||
for (var f in s) {
|
||
if (s[f] === d) {
|
||
c = f;
|
||
break
|
||
}
|
||
++p
|
||
}
|
||
c || (s[c = "p" + p] = d), n.push(c + ":" + u)
|
||
}
|
||
}
|
||
}
|
||
"featureMember" != i && (o.featureType = n, o.featureNS = s)
|
||
}
|
||
if ("string" == typeof s) {
|
||
var g = s;
|
||
(s = {}).p0 = g
|
||
}
|
||
var m = {}, y = Array.isArray(n) ? n : [n];
|
||
for (var v in s) {
|
||
for (var _ = {}, x = 0, w = y.length; x < w; ++x) {
|
||
(-1 === y[x].indexOf(":") ? "p0" : y[x].split(":")[0]) === v && (_[y[x].split(":").pop()] = "featureMembers" == i ? rp(this.readFeatureElement, this) : op(this.readFeatureElement, this))
|
||
}
|
||
m[s[v]] = _
|
||
}
|
||
r = fp("featureMember" == i ? void 0 : [], m, t, e)
|
||
}
|
||
return null === r && (r = []), r
|
||
}, e.prototype.readGeometryElement = function (t, e) {
|
||
var i = e[0];
|
||
i.srsName = t.firstElementChild.getAttribute("srsName"), i.srsDimension = t.firstElementChild.getAttribute("srsDimension");
|
||
var r = fp(null, this.GEOMETRY_PARSERS, t, e, this);
|
||
return r ? kc(r, !1, i) : void 0
|
||
}, e.prototype.readFeatureElementInternal = function (t, e, i) {
|
||
for (var r, o = {}, n = t.firstElementChild; n; n = n.nextElementSibling) {
|
||
var s = void 0, a = n.localName;
|
||
0 === n.childNodes.length || 1 === n.childNodes.length && (3 === n.firstChild.nodeType || 4 === n.firstChild.nodeType) ? (s = Jc(n, !1), _p.test(s) && (s = void 0)) : (i && (s = this.readGeometryElement(n, e)), s ? "boundedBy" !== a && (r = a) : s = this.readFeatureElementInternal(n, e, !1)), o[a] ? (o[a] instanceof Array || (o[a] = [o[a]]), o[a].push(s)) : o[a] = s;
|
||
var l = n.attributes.length;
|
||
if (l > 0) {
|
||
o[a] = {_content_: o[a]};
|
||
for (var h = 0; h < l; h++) {
|
||
var u = n.attributes[h].name;
|
||
o[a][u] = n.attributes[h].value
|
||
}
|
||
}
|
||
}
|
||
if (i) {
|
||
var c = new X(o);
|
||
r && c.setGeometryName(r);
|
||
var p = t.getAttribute("fid") || tp(t, this.namespace, "id");
|
||
return p && c.setId(p), c
|
||
}
|
||
return o
|
||
}, e.prototype.readFeatureElement = function (t, e) {
|
||
return this.readFeatureElementInternal(t, e, !0)
|
||
}, e.prototype.readPoint = function (t, e) {
|
||
var i = this.readFlatCoordinatesFromNode_(t, e);
|
||
if (i) return new qi(i, qt.XYZ)
|
||
}, e.prototype.readMultiPoint = function (t, e) {
|
||
var i = fp([], this.MULTIPOINT_PARSERS_, t, e, this);
|
||
return i ? new Gc(i) : void 0
|
||
}, e.prototype.readMultiLineString = function (t, e) {
|
||
var i = fp([], this.MULTILINESTRING_PARSERS_, t, e, this);
|
||
if (i) return new Dc(i)
|
||
}, e.prototype.readMultiPolygon = function (t, e) {
|
||
var i = fp([], this.MULTIPOLYGON_PARSERS_, t, e, this);
|
||
if (i) return new zc(i)
|
||
}, e.prototype.pointMemberParser_ = function (t, e) {
|
||
dp(this.POINTMEMBER_PARSERS_, t, e, this)
|
||
}, e.prototype.lineStringMemberParser_ = function (t, e) {
|
||
dp(this.LINESTRINGMEMBER_PARSERS_, t, e, this)
|
||
}, e.prototype.polygonMemberParser_ = function (t, e) {
|
||
dp(this.POLYGONMEMBER_PARSERS_, t, e, this)
|
||
}, e.prototype.readLineString = function (t, e) {
|
||
var i = this.readFlatCoordinatesFromNode_(t, e);
|
||
return i ? new Jr(i, qt.XYZ) : void 0
|
||
}, e.prototype.readFlatLinearRing_ = function (t, e) {
|
||
var i = fp(null, this.GEOMETRY_FLAT_COORDINATES_PARSERS, t, e, this);
|
||
return i || void 0
|
||
}, e.prototype.readLinearRing = function (t, e) {
|
||
var i = this.readFlatCoordinatesFromNode_(t, e);
|
||
if (i) return new Xi(i, qt.XYZ)
|
||
}, e.prototype.readPolygon = function (t, e) {
|
||
var i = fp([null], this.FLAT_LINEAR_RINGS_PARSERS, t, e, this);
|
||
if (i && i[0]) {
|
||
var r, o, n = i[0], s = [n.length];
|
||
for (r = 1, o = i.length; r < o; ++r) Q(n, i[r]), s.push(n.length);
|
||
return new fr(n, qt.XYZ, s)
|
||
}
|
||
}, e.prototype.readFlatCoordinatesFromNode_ = function (t, e) {
|
||
return fp(null, this.GEOMETRY_FLAT_COORDINATES_PARSERS, t, e, this)
|
||
}, e.prototype.readGeometryFromNode = function (t, e) {
|
||
var i = this.readGeometryElement(t, [this.getReadOptions(t, e || {})]);
|
||
return i || null
|
||
}, e.prototype.readFeaturesFromNode = function (t, e) {
|
||
var i = {featureType: this.featureType, featureNS: this.featureNS};
|
||
return e && p(i, this.getReadOptions(t, e)), this.readFeaturesInternal(t, [i]) || []
|
||
}, e.prototype.readProjectionFromNode = function (t) {
|
||
return We(this.srsName ? this.srsName : t.firstElementChild.getAttribute("srsName"))
|
||
}, e
|
||
}(yp);
|
||
xp.prototype.namespace = vp, xp.prototype.FLAT_LINEAR_RINGS_PARSERS = {"http://www.opengis.net/gml": {}}, xp.prototype.GEOMETRY_FLAT_COORDINATES_PARSERS = {"http://www.opengis.net/gml": {}}, xp.prototype.GEOMETRY_PARSERS = {"http://www.opengis.net/gml": {}}, xp.prototype.MULTIPOINT_PARSERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
pointMember: rp(xp.prototype.pointMemberParser_),
|
||
pointMembers: rp(xp.prototype.pointMemberParser_)
|
||
}
|
||
}, xp.prototype.MULTILINESTRING_PARSERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
lineStringMember: rp(xp.prototype.lineStringMemberParser_),
|
||
lineStringMembers: rp(xp.prototype.lineStringMemberParser_)
|
||
}
|
||
}, xp.prototype.MULTIPOLYGON_PARSERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
polygonMember: rp(xp.prototype.polygonMemberParser_),
|
||
polygonMembers: rp(xp.prototype.polygonMemberParser_)
|
||
}
|
||
}, xp.prototype.POINTMEMBER_PARSERS_ = {"http://www.opengis.net/gml": {Point: rp(xp.prototype.readFlatCoordinatesFromNode_)}}, xp.prototype.LINESTRINGMEMBER_PARSERS_ = {"http://www.opengis.net/gml": {LineString: rp(xp.prototype.readLineString)}}, xp.prototype.POLYGONMEMBER_PARSERS_ = {"http://www.opengis.net/gml": {Polygon: rp(xp.prototype.readPolygon)}}, xp.prototype.RING_PARSERS = {"http://www.opengis.net/gml": {LinearRing: op(xp.prototype.readFlatLinearRing_)}};
|
||
var wp = xp;
|
||
|
||
function bp(t) {
|
||
return Cp(Jc(t, !1))
|
||
}
|
||
|
||
function Cp(t) {
|
||
var e = /^\s*(true|1)|(false|0)\s*$/.exec(t);
|
||
return e ? void 0 !== e[1] || !1 : void 0
|
||
}
|
||
|
||
function Sp(t) {
|
||
var e = Jc(t, !1), i = Date.parse(e);
|
||
return isNaN(i) ? void 0 : i / 1e3
|
||
}
|
||
|
||
function Ep(t) {
|
||
return Tp(Jc(t, !1))
|
||
}
|
||
|
||
function Tp(t) {
|
||
var e = /^\s*([+\-]?\d*\.?\d+(?:e[+\-]?\d+)?)\s*$/i.exec(t);
|
||
return e ? parseFloat(e[1]) : void 0
|
||
}
|
||
|
||
function Rp(t) {
|
||
return Pp(Jc(t, !1))
|
||
}
|
||
|
||
function Pp(t) {
|
||
var e = /^\s*(\d+)\s*$/.exec(t);
|
||
return e ? parseInt(e[1], 10) : void 0
|
||
}
|
||
|
||
function Lp(t) {
|
||
return Jc(t, !1).trim()
|
||
}
|
||
|
||
function Ip(t, e) {
|
||
Fp(t, e ? "1" : "0")
|
||
}
|
||
|
||
function Op(t, e) {
|
||
t.appendChild(qc.createCDATASection(e))
|
||
}
|
||
|
||
function Mp(t, e) {
|
||
var i = new Date(1e3 * e),
|
||
r = i.getUTCFullYear() + "-" + Ar(i.getUTCMonth() + 1, 2) + "-" + Ar(i.getUTCDate(), 2) + "T" + Ar(i.getUTCHours(), 2) + ":" + Ar(i.getUTCMinutes(), 2) + ":" + Ar(i.getUTCSeconds(), 2) + "Z";
|
||
t.appendChild(qc.createTextNode(r))
|
||
}
|
||
|
||
function Ap(t, e) {
|
||
var i = e.toPrecision();
|
||
t.appendChild(qc.createTextNode(i))
|
||
}
|
||
|
||
function kp(t, e) {
|
||
var i = e.toString();
|
||
t.appendChild(qc.createTextNode(i))
|
||
}
|
||
|
||
function Fp(t, e) {
|
||
t.appendChild(qc.createTextNode(e))
|
||
}
|
||
|
||
var Np = vp + " http://schemas.opengis.net/gml/3.1.1/profiles/gmlsfProfile/1.0.0/gmlsf.xsd", Dp = {
|
||
MultiLineString: "lineStringMember",
|
||
MultiCurve: "curveMember",
|
||
MultiPolygon: "polygonMember",
|
||
MultiSurface: "surfaceMember"
|
||
}, Gp = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, i), this.surface_ = void 0 !== i.surface && i.surface, this.curve_ = void 0 !== i.curve && i.curve, this.multiCurve_ = void 0 === i.multiCurve || i.multiCurve, this.multiSurface_ = void 0 === i.multiSurface || i.multiSurface, this.schemaLocation = i.schemaLocation ? i.schemaLocation : Np, this.hasZ = void 0 !== i.hasZ && i.hasZ
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.readMultiCurve_ = function (t, e) {
|
||
var i = fp([], this.MULTICURVE_PARSERS_, t, e, this);
|
||
return i ? new Dc(i) : void 0
|
||
}, e.prototype.readMultiSurface_ = function (t, e) {
|
||
var i = fp([], this.MULTISURFACE_PARSERS_, t, e, this);
|
||
if (i) return new zc(i)
|
||
}, e.prototype.curveMemberParser_ = function (t, e) {
|
||
dp(this.CURVEMEMBER_PARSERS_, t, e, this)
|
||
}, e.prototype.surfaceMemberParser_ = function (t, e) {
|
||
dp(this.SURFACEMEMBER_PARSERS_, t, e, this)
|
||
}, e.prototype.readPatch_ = function (t, e) {
|
||
return fp([null], this.PATCHES_PARSERS_, t, e, this)
|
||
}, e.prototype.readSegment_ = function (t, e) {
|
||
return fp([null], this.SEGMENTS_PARSERS_, t, e, this)
|
||
}, e.prototype.readPolygonPatch_ = function (t, e) {
|
||
return fp([null], this.FLAT_LINEAR_RINGS_PARSERS, t, e, this)
|
||
}, e.prototype.readLineStringSegment_ = function (t, e) {
|
||
return fp([null], this.GEOMETRY_FLAT_COORDINATES_PARSERS, t, e, this)
|
||
}, e.prototype.interiorParser_ = function (t, e) {
|
||
var i = fp(void 0, this.RING_PARSERS, t, e, this);
|
||
i && e[e.length - 1].push(i)
|
||
}, e.prototype.exteriorParser_ = function (t, e) {
|
||
var i = fp(void 0, this.RING_PARSERS, t, e, this);
|
||
i && (e[e.length - 1][0] = i)
|
||
}, e.prototype.readSurface_ = function (t, e) {
|
||
var i = fp([null], this.SURFACE_PARSERS_, t, e, this);
|
||
if (i && i[0]) {
|
||
var r, o, n = i[0], s = [n.length];
|
||
for (r = 1, o = i.length; r < o; ++r) Q(n, i[r]), s.push(n.length);
|
||
return new fr(n, qt.XYZ, s)
|
||
}
|
||
}, e.prototype.readCurve_ = function (t, e) {
|
||
var i = fp([null], this.CURVE_PARSERS_, t, e, this);
|
||
return i ? new Jr(i, qt.XYZ) : void 0
|
||
}, e.prototype.readEnvelope_ = function (t, e) {
|
||
var i = fp([null], this.ENVELOPE_PARSERS_, t, e, this);
|
||
return yt(i[1][0], i[1][1], i[2][0], i[2][1])
|
||
}, e.prototype.readFlatPos_ = function (t, e) {
|
||
for (var i, r = Jc(t, !1), o = /^\s*([+\-]?\d*\.?\d+(?:[eE][+\-]?\d+)?)\s*/, n = []; i = o.exec(r);) n.push(parseFloat(i[1])), r = r.substr(i[0].length);
|
||
if ("" === r) {
|
||
var s, a, l = e[0].srsName, h = "enu";
|
||
if (l) h = We(l).getAxisOrientation();
|
||
if ("neu" === h) for (s = 0, a = n.length; s < a; s += 3) {
|
||
var u = n[s], c = n[s + 1];
|
||
n[s] = c, n[s + 1] = u
|
||
}
|
||
var p = n.length;
|
||
if (2 == p && n.push(0), 0 !== p) return n
|
||
}
|
||
}, e.prototype.readFlatPosList_ = function (t, e) {
|
||
var i = Jc(t, !1).replace(/^\s*|\s*$/g, ""), r = e[0], o = r.srsName, n = r.srsDimension, s = "enu";
|
||
o && (s = We(o).getAxisOrientation());
|
||
var a, l, h, u = i.split(/\s+/), c = 2;
|
||
t.getAttribute("srsDimension") ? c = Pp(t.getAttribute("srsDimension")) : t.getAttribute("dimension") ? c = Pp(t.getAttribute("dimension")) : t.parentNode.getAttribute("srsDimension") ? c = Pp(t.parentNode.getAttribute("srsDimension")) : n && (c = Pp(n));
|
||
for (var p = [], d = 0, f = u.length; d < f; d += c) a = parseFloat(u[d]), l = parseFloat(u[d + 1]), h = 3 === c ? parseFloat(u[d + 2]) : 0, "en" === s.substr(0, 2) ? p.push(a, l, h) : p.push(l, a, h);
|
||
return p
|
||
}, e.prototype.writePos_ = function (t, e, i) {
|
||
var r = i[i.length - 1], o = r.hasZ, n = o ? "3" : "2";
|
||
t.setAttribute("srsDimension", n);
|
||
var s = r.srsName, a = "enu";
|
||
s && (a = We(s).getAxisOrientation());
|
||
var l, h = e.getCoordinates();
|
||
(l = "en" === a.substr(0, 2) ? h[0] + " " + h[1] : h[1] + " " + h[0], o) && (l += " " + (h[2] || 0));
|
||
Fp(t, l)
|
||
}, e.prototype.getCoords_ = function (t, e, i) {
|
||
var r = "enu";
|
||
e && (r = We(e).getAxisOrientation());
|
||
var o = "en" === r.substr(0, 2) ? t[0] + " " + t[1] : t[1] + " " + t[0];
|
||
i && (o += " " + (t[2] || 0));
|
||
return o
|
||
}, e.prototype.writePosList_ = function (t, e, i) {
|
||
var r = i[i.length - 1], o = r.hasZ, n = o ? "3" : "2";
|
||
t.setAttribute("srsDimension", n);
|
||
for (var s, a = r.srsName, l = e.getCoordinates(), h = l.length, u = new Array(h), c = 0; c < h; ++c) s = l[c], u[c] = this.getCoords_(s, a, o);
|
||
Fp(t, u.join(" "))
|
||
}, e.prototype.writePoint_ = function (t, e, i) {
|
||
var r = i[i.length - 1].srsName;
|
||
r && t.setAttribute("srsName", r);
|
||
var o = Kc(t.namespaceURI, "pos");
|
||
t.appendChild(o), this.writePos_(o, e, i)
|
||
}, e.prototype.writeEnvelope = function (t, e, i) {
|
||
var r = i[i.length - 1].srsName;
|
||
r && t.setAttribute("srsName", r);
|
||
var o = [e[0] + " " + e[1], e[2] + " " + e[3]];
|
||
mp({node: t}, this.ENVELOPE_SERIALIZERS_, up, o, i, ["lowerCorner", "upperCorner"], this)
|
||
}, e.prototype.writeLinearRing_ = function (t, e, i) {
|
||
var r = i[i.length - 1].srsName;
|
||
r && t.setAttribute("srsName", r);
|
||
var o = Kc(t.namespaceURI, "posList");
|
||
t.appendChild(o), this.writePosList_(o, e, i)
|
||
}, e.prototype.RING_NODE_FACTORY_ = function (t, e, i) {
|
||
var r = e[e.length - 1], o = r.node, n = r.exteriorWritten;
|
||
return void 0 === n && (r.exteriorWritten = !0), Kc(o.namespaceURI, void 0 !== n ? "interior" : "exterior")
|
||
}, e.prototype.writeSurfaceOrPolygon_ = function (t, e, i) {
|
||
var r = i[i.length - 1], o = r.hasZ, n = r.srsName;
|
||
if ("PolygonPatch" !== t.nodeName && n && t.setAttribute("srsName", n), "Polygon" === t.nodeName || "PolygonPatch" === t.nodeName) {
|
||
var s = e.getLinearRings();
|
||
mp({
|
||
node: t,
|
||
hasZ: o,
|
||
srsName: n
|
||
}, this.RING_SERIALIZERS_, this.RING_NODE_FACTORY_, s, i, void 0, this)
|
||
} else if ("Surface" === t.nodeName) {
|
||
var a = Kc(t.namespaceURI, "patches");
|
||
t.appendChild(a), this.writeSurfacePatches_(a, e, i)
|
||
}
|
||
}, e.prototype.writeCurveOrLineString_ = function (t, e, i) {
|
||
var r = i[i.length - 1].srsName;
|
||
if ("LineStringSegment" !== t.nodeName && r && t.setAttribute("srsName", r), "LineString" === t.nodeName || "LineStringSegment" === t.nodeName) {
|
||
var o = Kc(t.namespaceURI, "posList");
|
||
t.appendChild(o), this.writePosList_(o, e, i)
|
||
} else if ("Curve" === t.nodeName) {
|
||
var n = Kc(t.namespaceURI, "segments");
|
||
t.appendChild(n), this.writeCurveSegments_(n, e, i)
|
||
}
|
||
}, e.prototype.writeMultiSurfaceOrPolygon_ = function (t, e, i) {
|
||
var r = i[i.length - 1], o = r.hasZ, n = r.srsName, s = r.surface;
|
||
n && t.setAttribute("srsName", n);
|
||
var a = e.getPolygons();
|
||
mp({
|
||
node: t,
|
||
hasZ: o,
|
||
srsName: n,
|
||
surface: s
|
||
}, this.SURFACEORPOLYGONMEMBER_SERIALIZERS_, this.MULTIGEOMETRY_MEMBER_NODE_FACTORY_, a, i, void 0, this)
|
||
}, e.prototype.writeMultiPoint_ = function (t, e, i) {
|
||
var r = i[i.length - 1], o = r.srsName, n = r.hasZ;
|
||
o && t.setAttribute("srsName", o);
|
||
var s = e.getPoints();
|
||
mp({node: t, hasZ: n, srsName: o}, this.POINTMEMBER_SERIALIZERS_, hp("pointMember"), s, i, void 0, this)
|
||
}, e.prototype.writeMultiCurveOrLineString_ = function (t, e, i) {
|
||
var r = i[i.length - 1], o = r.hasZ, n = r.srsName, s = r.curve;
|
||
n && t.setAttribute("srsName", n);
|
||
var a = e.getLineStrings();
|
||
mp({
|
||
node: t,
|
||
hasZ: o,
|
||
srsName: n,
|
||
curve: s
|
||
}, this.LINESTRINGORCURVEMEMBER_SERIALIZERS_, this.MULTIGEOMETRY_MEMBER_NODE_FACTORY_, a, i, void 0, this)
|
||
}, e.prototype.writeRing_ = function (t, e, i) {
|
||
var r = Kc(t.namespaceURI, "LinearRing");
|
||
t.appendChild(r), this.writeLinearRing_(r, e, i)
|
||
}, e.prototype.writeSurfaceOrPolygonMember_ = function (t, e, i) {
|
||
var r = this.GEOMETRY_NODE_FACTORY_(e, i);
|
||
r && (t.appendChild(r), this.writeSurfaceOrPolygon_(r, e, i))
|
||
}, e.prototype.writePointMember_ = function (t, e, i) {
|
||
var r = Kc(t.namespaceURI, "Point");
|
||
t.appendChild(r), this.writePoint_(r, e, i)
|
||
}, e.prototype.writeLineStringOrCurveMember_ = function (t, e, i) {
|
||
var r = this.GEOMETRY_NODE_FACTORY_(e, i);
|
||
r && (t.appendChild(r), this.writeCurveOrLineString_(r, e, i))
|
||
}, e.prototype.writeSurfacePatches_ = function (t, e, i) {
|
||
var r = Kc(t.namespaceURI, "PolygonPatch");
|
||
t.appendChild(r), this.writeSurfaceOrPolygon_(r, e, i)
|
||
}, e.prototype.writeCurveSegments_ = function (t, e, i) {
|
||
var r = Kc(t.namespaceURI, "LineStringSegment");
|
||
t.appendChild(r), this.writeCurveOrLineString_(r, e, i)
|
||
}, e.prototype.writeGeometryElement = function (t, e, i) {
|
||
var r, o = i[i.length - 1], n = p({}, o);
|
||
n.node = t, r = Array.isArray(e) ? o.dataProjection ? ri(e, o.featureProjection, o.dataProjection) : e : kc(e, !0, o), mp(n, this.GEOMETRY_SERIALIZERS_, this.GEOMETRY_NODE_FACTORY_, [r], i, void 0, this)
|
||
}, e.prototype.writeFeatureElement = function (t, e, i) {
|
||
var r = e.getId();
|
||
r && t.setAttribute("fid", r);
|
||
var o = i[i.length - 1], n = o.featureNS, s = e.getGeometryName();
|
||
o.serializers || (o.serializers = {}, o.serializers[n] = {});
|
||
var a = e.getProperties(), l = [], h = [];
|
||
for (var u in a) {
|
||
var c = a[u];
|
||
null !== c && (l.push(u), h.push(c), u == s || "function" == typeof c.getSimplifiedGeometry ? u in o.serializers[n] || (o.serializers[n][u] = ap(this.writeGeometryElement, this)) : u in o.serializers[n] || (o.serializers[n][u] = ap(Fp)))
|
||
}
|
||
var d = p({}, o);
|
||
d.node = t, mp(d, o.serializers, hp(void 0, n), h, i, l)
|
||
}, e.prototype.writeFeatureMembers_ = function (t, e, i) {
|
||
var r = i[i.length - 1], o = r.featureType, n = r.featureNS, s = {};
|
||
s[n] = {}, s[n][o] = ap(this.writeFeatureElement, this);
|
||
var a = p({}, r);
|
||
a.node = t, mp(a, s, hp(o, n), e, i)
|
||
}, e.prototype.MULTIGEOMETRY_MEMBER_NODE_FACTORY_ = function (t, e, i) {
|
||
var r = e[e.length - 1].node;
|
||
return Kc(this.namespace, Dp[r.nodeName])
|
||
}, e.prototype.GEOMETRY_NODE_FACTORY_ = function (t, e, i) {
|
||
var r, o = e[e.length - 1], n = o.multiSurface, s = o.surface, a = o.curve, l = o.multiCurve;
|
||
return Array.isArray(t) ? r = "Envelope" : "MultiPolygon" === (r = t.getType()) && !0 === n ? r = "MultiSurface" : "Polygon" === r && !0 === s ? r = "Surface" : "LineString" === r && !0 === a ? r = "Curve" : "MultiLineString" === r && !0 === l && (r = "MultiCurve"), Kc(this.namespace, r)
|
||
}, e.prototype.writeGeometryNode = function (t, e) {
|
||
e = this.adaptOptions(e);
|
||
var i = Kc(this.namespace, "geom"), r = {
|
||
node: i,
|
||
hasZ: this.hasZ,
|
||
srsName: this.srsName,
|
||
curve: this.curve_,
|
||
surface: this.surface_,
|
||
multiSurface: this.multiSurface_,
|
||
multiCurve: this.multiCurve_
|
||
};
|
||
return e && p(r, e), this.writeGeometryElement(i, t, [r]), i
|
||
}, e.prototype.writeFeaturesNode = function (t, e) {
|
||
e = this.adaptOptions(e);
|
||
var i = Kc(this.namespace, "featureMembers");
|
||
i.setAttributeNS(Zc, "xsi:schemaLocation", this.schemaLocation);
|
||
var r = {
|
||
srsName: this.srsName,
|
||
hasZ: this.hasZ,
|
||
curve: this.curve_,
|
||
surface: this.surface_,
|
||
multiSurface: this.multiSurface_,
|
||
multiCurve: this.multiCurve_,
|
||
featureNS: this.featureNS,
|
||
featureType: this.featureType
|
||
};
|
||
return e && p(r, e), this.writeFeatureMembers_(i, t, [r]), i
|
||
}, e
|
||
}(wp);
|
||
Gp.prototype.GEOMETRY_FLAT_COORDINATES_PARSERS = {
|
||
"http://www.opengis.net/gml": {
|
||
pos: op(Gp.prototype.readFlatPos_),
|
||
posList: op(Gp.prototype.readFlatPosList_)
|
||
}
|
||
}, Gp.prototype.FLAT_LINEAR_RINGS_PARSERS = {
|
||
"http://www.opengis.net/gml": {
|
||
interior: Gp.prototype.interiorParser_,
|
||
exterior: Gp.prototype.exteriorParser_
|
||
}
|
||
}, Gp.prototype.GEOMETRY_PARSERS = {
|
||
"http://www.opengis.net/gml": {
|
||
Point: op(wp.prototype.readPoint),
|
||
MultiPoint: op(wp.prototype.readMultiPoint),
|
||
LineString: op(wp.prototype.readLineString),
|
||
MultiLineString: op(wp.prototype.readMultiLineString),
|
||
LinearRing: op(wp.prototype.readLinearRing),
|
||
Polygon: op(wp.prototype.readPolygon),
|
||
MultiPolygon: op(wp.prototype.readMultiPolygon),
|
||
Surface: op(Gp.prototype.readSurface_),
|
||
MultiSurface: op(Gp.prototype.readMultiSurface_),
|
||
Curve: op(Gp.prototype.readCurve_),
|
||
MultiCurve: op(Gp.prototype.readMultiCurve_),
|
||
Envelope: op(Gp.prototype.readEnvelope_)
|
||
}
|
||
}, Gp.prototype.MULTICURVE_PARSERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
curveMember: rp(Gp.prototype.curveMemberParser_),
|
||
curveMembers: rp(Gp.prototype.curveMemberParser_)
|
||
}
|
||
}, Gp.prototype.MULTISURFACE_PARSERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
surfaceMember: rp(Gp.prototype.surfaceMemberParser_),
|
||
surfaceMembers: rp(Gp.prototype.surfaceMemberParser_)
|
||
}
|
||
}, Gp.prototype.CURVEMEMBER_PARSERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
LineString: rp(wp.prototype.readLineString),
|
||
Curve: rp(Gp.prototype.readCurve_)
|
||
}
|
||
}, Gp.prototype.SURFACEMEMBER_PARSERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
Polygon: rp(wp.prototype.readPolygon),
|
||
Surface: rp(Gp.prototype.readSurface_)
|
||
}
|
||
}, Gp.prototype.SURFACE_PARSERS_ = {"http://www.opengis.net/gml": {patches: op(Gp.prototype.readPatch_)}}, Gp.prototype.CURVE_PARSERS_ = {"http://www.opengis.net/gml": {segments: op(Gp.prototype.readSegment_)}}, Gp.prototype.ENVELOPE_PARSERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
lowerCorner: rp(Gp.prototype.readFlatPosList_),
|
||
upperCorner: rp(Gp.prototype.readFlatPosList_)
|
||
}
|
||
}, Gp.prototype.PATCHES_PARSERS_ = {"http://www.opengis.net/gml": {PolygonPatch: op(Gp.prototype.readPolygonPatch_)}}, Gp.prototype.SEGMENTS_PARSERS_ = {"http://www.opengis.net/gml": {LineStringSegment: op(Gp.prototype.readLineStringSegment_)}}, Gp.prototype.writeFeatures, Gp.prototype.RING_SERIALIZERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
exterior: ap(Gp.prototype.writeRing_),
|
||
interior: ap(Gp.prototype.writeRing_)
|
||
}
|
||
}, Gp.prototype.ENVELOPE_SERIALIZERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
lowerCorner: ap(Fp),
|
||
upperCorner: ap(Fp)
|
||
}
|
||
}, Gp.prototype.SURFACEORPOLYGONMEMBER_SERIALIZERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
surfaceMember: ap(Gp.prototype.writeSurfaceOrPolygonMember_),
|
||
polygonMember: ap(Gp.prototype.writeSurfaceOrPolygonMember_)
|
||
}
|
||
}, Gp.prototype.POINTMEMBER_SERIALIZERS_ = {"http://www.opengis.net/gml": {pointMember: ap(Gp.prototype.writePointMember_)}}, Gp.prototype.LINESTRINGORCURVEMEMBER_SERIALIZERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
lineStringMember: ap(Gp.prototype.writeLineStringOrCurveMember_),
|
||
curveMember: ap(Gp.prototype.writeLineStringOrCurveMember_)
|
||
}
|
||
}, Gp.prototype.GEOMETRY_SERIALIZERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
Curve: ap(Gp.prototype.writeCurveOrLineString_),
|
||
MultiCurve: ap(Gp.prototype.writeMultiCurveOrLineString_),
|
||
Point: ap(Gp.prototype.writePoint_),
|
||
MultiPoint: ap(Gp.prototype.writeMultiPoint_),
|
||
LineString: ap(Gp.prototype.writeCurveOrLineString_),
|
||
MultiLineString: ap(Gp.prototype.writeMultiCurveOrLineString_),
|
||
LinearRing: ap(Gp.prototype.writeLinearRing_),
|
||
Polygon: ap(Gp.prototype.writeSurfaceOrPolygon_),
|
||
MultiPolygon: ap(Gp.prototype.writeMultiSurfaceOrPolygon_),
|
||
Surface: ap(Gp.prototype.writeSurfaceOrPolygon_),
|
||
MultiSurface: ap(Gp.prototype.writeMultiSurfaceOrPolygon_),
|
||
Envelope: ap(Gp.prototype.writeEnvelope)
|
||
}
|
||
};
|
||
var jp = Gp, zp = jp;
|
||
zp.prototype.writeFeatures, zp.prototype.writeFeaturesNode;
|
||
var Up = zp, Bp = vp + " http://schemas.opengis.net/gml/2.1.2/feature.xsd", Vp = {
|
||
MultiLineString: "lineStringMember",
|
||
MultiCurve: "curveMember",
|
||
MultiPolygon: "polygonMember",
|
||
MultiSurface: "surfaceMember"
|
||
}, Yp = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, i), this.FEATURE_COLLECTION_PARSERS[vp].featureMember = rp(this.readFeaturesInternal), this.schemaLocation = i.schemaLocation ? i.schemaLocation : Bp
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.readFlatCoordinates_ = function (t, e) {
|
||
var i = Jc(t, !1).replace(/^\s*|\s*$/g, ""), r = e[0].srsName, o = "enu";
|
||
if (r) {
|
||
var n = We(r);
|
||
n && (o = n.getAxisOrientation())
|
||
}
|
||
for (var s = i.trim().split(/\s+/), a = [], l = 0, h = s.length; l < h; l++) {
|
||
var u = s[l].split(/,+/), c = parseFloat(u[0]), p = parseFloat(u[1]),
|
||
d = 3 === u.length ? parseFloat(u[2]) : 0;
|
||
"en" === o.substr(0, 2) ? a.push(c, p, d) : a.push(p, c, d)
|
||
}
|
||
return a
|
||
}, e.prototype.readBox_ = function (t, e) {
|
||
var i = fp([null], this.BOX_PARSERS_, t, e, this);
|
||
return yt(i[1][0], i[1][1], i[1][3], i[1][4])
|
||
}, e.prototype.innerBoundaryIsParser_ = function (t, e) {
|
||
var i = fp(void 0, this.RING_PARSERS, t, e, this);
|
||
i && e[e.length - 1].push(i)
|
||
}, e.prototype.outerBoundaryIsParser_ = function (t, e) {
|
||
var i = fp(void 0, this.RING_PARSERS, t, e, this);
|
||
i && (e[e.length - 1][0] = i)
|
||
}, e.prototype.GEOMETRY_NODE_FACTORY_ = function (t, e, i) {
|
||
var r, o = e[e.length - 1], n = o.multiSurface, s = o.surface, a = o.multiCurve;
|
||
return Array.isArray(t) ? r = "Envelope" : "MultiPolygon" === (r = t.getType()) && !0 === n ? r = "MultiSurface" : "Polygon" === r && !0 === s ? r = "Surface" : "MultiLineString" === r && !0 === a && (r = "MultiCurve"), Kc("http://www.opengis.net/gml", r)
|
||
}, e.prototype.writeFeatureElement = function (t, e, i) {
|
||
var r = e.getId();
|
||
r && t.setAttribute("fid", r);
|
||
var o = i[i.length - 1], n = o.featureNS, s = e.getGeometryName();
|
||
o.serializers || (o.serializers = {}, o.serializers[n] = {});
|
||
var a = e.getProperties(), l = [], h = [];
|
||
for (var u in a) {
|
||
var c = a[u];
|
||
null !== c && (l.push(u), h.push(c), u == s || "function" == typeof c.getSimplifiedGeometry ? u in o.serializers[n] || (o.serializers[n][u] = ap(this.writeGeometryElement, this)) : u in o.serializers[n] || (o.serializers[n][u] = ap(Fp)))
|
||
}
|
||
var d = p({}, o);
|
||
d.node = t, mp(d, o.serializers, hp(void 0, n), h, i, l)
|
||
}, e.prototype.writeCurveOrLineString_ = function (t, e, i) {
|
||
var r = i[i.length - 1].srsName;
|
||
if ("LineStringSegment" !== t.nodeName && r && t.setAttribute("srsName", r), "LineString" === t.nodeName || "LineStringSegment" === t.nodeName) {
|
||
var o = this.createCoordinatesNode_(t.namespaceURI);
|
||
t.appendChild(o), this.writeCoordinates_(o, e, i)
|
||
} else if ("Curve" === t.nodeName) {
|
||
var n = Kc(t.namespaceURI, "segments");
|
||
t.appendChild(n), this.writeCurveSegments_(n, e, i)
|
||
}
|
||
}, e.prototype.writeLineStringOrCurveMember_ = function (t, e, i) {
|
||
var r = this.GEOMETRY_NODE_FACTORY_(e, i);
|
||
r && (t.appendChild(r), this.writeCurveOrLineString_(r, e, i))
|
||
}, e.prototype.writeMultiCurveOrLineString_ = function (t, e, i) {
|
||
var r = i[i.length - 1], o = r.hasZ, n = r.srsName, s = r.curve;
|
||
n && t.setAttribute("srsName", n);
|
||
var a = e.getLineStrings();
|
||
mp({
|
||
node: t,
|
||
hasZ: o,
|
||
srsName: n,
|
||
curve: s
|
||
}, this.LINESTRINGORCURVEMEMBER_SERIALIZERS_, this.MULTIGEOMETRY_MEMBER_NODE_FACTORY_, a, i, void 0, this)
|
||
}, e.prototype.writeGeometryElement = function (t, e, i) {
|
||
var r, o = i[i.length - 1], n = p({}, o);
|
||
n.node = t, r = Array.isArray(e) ? o.dataProjection ? ri(e, o.featureProjection, o.dataProjection) : e : kc(e, !0, o), mp(n, this.GEOMETRY_SERIALIZERS_, this.GEOMETRY_NODE_FACTORY_, [r], i, void 0, this)
|
||
}, e.prototype.createCoordinatesNode_ = function (t) {
|
||
var e = Kc(t, "coordinates");
|
||
return e.setAttribute("decimal", "."), e.setAttribute("cs", ","), e.setAttribute("ts", " "), e
|
||
}, e.prototype.writeCoordinates_ = function (t, e, i) {
|
||
for (var r = i[i.length - 1], o = r.hasZ, n = r.srsName, s = e.getCoordinates(), a = s.length, l = new Array(a), h = 0; h < a; ++h) {
|
||
var u = s[h];
|
||
l[h] = this.getCoords_(u, n, o)
|
||
}
|
||
Fp(t, l.join(" "))
|
||
}, e.prototype.writeCurveSegments_ = function (t, e, i) {
|
||
var r = Kc(t.namespaceURI, "LineStringSegment");
|
||
t.appendChild(r), this.writeCurveOrLineString_(r, e, i)
|
||
}, e.prototype.writeSurfaceOrPolygon_ = function (t, e, i) {
|
||
var r = i[i.length - 1], o = r.hasZ, n = r.srsName;
|
||
if ("PolygonPatch" !== t.nodeName && n && t.setAttribute("srsName", n), "Polygon" === t.nodeName || "PolygonPatch" === t.nodeName) {
|
||
var s = e.getLinearRings();
|
||
mp({
|
||
node: t,
|
||
hasZ: o,
|
||
srsName: n
|
||
}, this.RING_SERIALIZERS_, this.RING_NODE_FACTORY_, s, i, void 0, this)
|
||
} else if ("Surface" === t.nodeName) {
|
||
var a = Kc(t.namespaceURI, "patches");
|
||
t.appendChild(a), this.writeSurfacePatches_(a, e, i)
|
||
}
|
||
}, e.prototype.RING_NODE_FACTORY_ = function (t, e, i) {
|
||
var r = e[e.length - 1], o = r.node, n = r.exteriorWritten;
|
||
return void 0 === n && (r.exteriorWritten = !0), Kc(o.namespaceURI, void 0 !== n ? "innerBoundaryIs" : "outerBoundaryIs")
|
||
}, e.prototype.writeSurfacePatches_ = function (t, e, i) {
|
||
var r = Kc(t.namespaceURI, "PolygonPatch");
|
||
t.appendChild(r), this.writeSurfaceOrPolygon_(r, e, i)
|
||
}, e.prototype.writeRing_ = function (t, e, i) {
|
||
var r = Kc(t.namespaceURI, "LinearRing");
|
||
t.appendChild(r), this.writeLinearRing_(r, e, i)
|
||
}, e.prototype.getCoords_ = function (t, e, i) {
|
||
var r = "enu";
|
||
e && (r = We(e).getAxisOrientation());
|
||
var o = "en" === r.substr(0, 2) ? t[0] + "," + t[1] : t[1] + "," + t[0];
|
||
i && (o += "," + (t[2] || 0));
|
||
return o
|
||
}, e.prototype.writePoint_ = function (t, e, i) {
|
||
var r = i[i.length - 1], o = r.hasZ, n = r.srsName;
|
||
n && t.setAttribute("srsName", n);
|
||
var s = this.createCoordinatesNode_(t.namespaceURI);
|
||
t.appendChild(s);
|
||
var a = e.getCoordinates();
|
||
Fp(s, this.getCoords_(a, n, o))
|
||
}, e.prototype.writeMultiPoint_ = function (t, e, i) {
|
||
var r = i[i.length - 1], o = r.hasZ, n = r.srsName;
|
||
n && t.setAttribute("srsName", n);
|
||
var s = e.getPoints();
|
||
mp({node: t, hasZ: o, srsName: n}, this.POINTMEMBER_SERIALIZERS_, hp("pointMember"), s, i, void 0, this)
|
||
}, e.prototype.writePointMember_ = function (t, e, i) {
|
||
var r = Kc(t.namespaceURI, "Point");
|
||
t.appendChild(r), this.writePoint_(r, e, i)
|
||
}, e.prototype.writeLinearRing_ = function (t, e, i) {
|
||
var r = i[i.length - 1].srsName;
|
||
r && t.setAttribute("srsName", r);
|
||
var o = this.createCoordinatesNode_(t.namespaceURI);
|
||
t.appendChild(o), this.writeCoordinates_(o, e, i)
|
||
}, e.prototype.writeMultiSurfaceOrPolygon_ = function (t, e, i) {
|
||
var r = i[i.length - 1], o = r.hasZ, n = r.srsName, s = r.surface;
|
||
n && t.setAttribute("srsName", n);
|
||
var a = e.getPolygons();
|
||
mp({
|
||
node: t,
|
||
hasZ: o,
|
||
srsName: n,
|
||
surface: s
|
||
}, this.SURFACEORPOLYGONMEMBER_SERIALIZERS_, this.MULTIGEOMETRY_MEMBER_NODE_FACTORY_, a, i, void 0, this)
|
||
}, e.prototype.writeSurfaceOrPolygonMember_ = function (t, e, i) {
|
||
var r = this.GEOMETRY_NODE_FACTORY_(e, i);
|
||
r && (t.appendChild(r), this.writeSurfaceOrPolygon_(r, e, i))
|
||
}, e.prototype.writeEnvelope = function (t, e, i) {
|
||
var r = i[i.length - 1].srsName;
|
||
r && t.setAttribute("srsName", r);
|
||
var o = [e[0] + " " + e[1], e[2] + " " + e[3]];
|
||
mp({node: t}, this.ENVELOPE_SERIALIZERS_, up, o, i, ["lowerCorner", "upperCorner"], this)
|
||
}, e.prototype.MULTIGEOMETRY_MEMBER_NODE_FACTORY_ = function (t, e, i) {
|
||
var r = e[e.length - 1].node;
|
||
return Kc("http://www.opengis.net/gml", Vp[r.nodeName])
|
||
}, e
|
||
}(wp);
|
||
Yp.prototype.GEOMETRY_FLAT_COORDINATES_PARSERS = {"http://www.opengis.net/gml": {coordinates: op(Yp.prototype.readFlatCoordinates_)}}, Yp.prototype.FLAT_LINEAR_RINGS_PARSERS = {
|
||
"http://www.opengis.net/gml": {
|
||
innerBoundaryIs: Yp.prototype.innerBoundaryIsParser_,
|
||
outerBoundaryIs: Yp.prototype.outerBoundaryIsParser_
|
||
}
|
||
}, Yp.prototype.BOX_PARSERS_ = {"http://www.opengis.net/gml": {coordinates: rp(Yp.prototype.readFlatCoordinates_)}}, Yp.prototype.GEOMETRY_PARSERS = {
|
||
"http://www.opengis.net/gml": {
|
||
Point: op(wp.prototype.readPoint),
|
||
MultiPoint: op(wp.prototype.readMultiPoint),
|
||
LineString: op(wp.prototype.readLineString),
|
||
MultiLineString: op(wp.prototype.readMultiLineString),
|
||
LinearRing: op(wp.prototype.readLinearRing),
|
||
Polygon: op(wp.prototype.readPolygon),
|
||
MultiPolygon: op(wp.prototype.readMultiPolygon),
|
||
Box: op(Yp.prototype.readBox_)
|
||
}
|
||
}, Yp.prototype.GEOMETRY_SERIALIZERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
Curve: ap(Yp.prototype.writeCurveOrLineString_),
|
||
MultiCurve: ap(Yp.prototype.writeMultiCurveOrLineString_),
|
||
Point: ap(Yp.prototype.writePoint_),
|
||
MultiPoint: ap(Yp.prototype.writeMultiPoint_),
|
||
LineString: ap(Yp.prototype.writeCurveOrLineString_),
|
||
MultiLineString: ap(Yp.prototype.writeMultiCurveOrLineString_),
|
||
LinearRing: ap(Yp.prototype.writeLinearRing_),
|
||
Polygon: ap(Yp.prototype.writeSurfaceOrPolygon_),
|
||
MultiPolygon: ap(Yp.prototype.writeMultiSurfaceOrPolygon_),
|
||
Surface: ap(Yp.prototype.writeSurfaceOrPolygon_),
|
||
MultiSurface: ap(Yp.prototype.writeMultiSurfaceOrPolygon_),
|
||
Envelope: ap(Yp.prototype.writeEnvelope)
|
||
}
|
||
}, Yp.prototype.LINESTRINGORCURVEMEMBER_SERIALIZERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
lineStringMember: ap(Yp.prototype.writeLineStringOrCurveMember_),
|
||
curveMember: ap(Yp.prototype.writeLineStringOrCurveMember_)
|
||
}
|
||
}, Yp.prototype.RING_SERIALIZERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
outerBoundaryIs: ap(Yp.prototype.writeRing_),
|
||
innerBoundaryIs: ap(Yp.prototype.writeRing_)
|
||
}
|
||
}, Yp.prototype.POINTMEMBER_SERIALIZERS_ = {"http://www.opengis.net/gml": {pointMember: ap(Yp.prototype.writePointMember_)}}, Yp.prototype.SURFACEORPOLYGONMEMBER_SERIALIZERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
surfaceMember: ap(Yp.prototype.writeSurfaceOrPolygonMember_),
|
||
polygonMember: ap(Yp.prototype.writeSurfaceOrPolygonMember_)
|
||
}
|
||
}, Yp.prototype.ENVELOPE_SERIALIZERS_ = {
|
||
"http://www.opengis.net/gml": {
|
||
lowerCorner: ap(Fp),
|
||
upperCorner: ap(Fp)
|
||
}
|
||
};
|
||
var Wp = Yp, Hp = [null, "http://www.topografix.com/GPX/1/0", "http://www.topografix.com/GPX/1/1"],
|
||
Xp = {rte: wd, trk: bd, wpt: Cd}, qp = pp(Hp, {rte: rp(wd), trk: rp(bd), wpt: rp(Cd)}),
|
||
Zp = pp(Hp, {text: sp(Lp, "linkText"), type: sp(Lp, "linkType")}), Kp = pp(Hp, {
|
||
rte: ap(function (t, e, i) {
|
||
var r = i[0], o = e.getProperties(), n = {node: t};
|
||
n.properties = o;
|
||
var s = e.getGeometry();
|
||
if (s.getType() == Zt.LINE_STRING) {
|
||
var a = kc(s, !0, r);
|
||
n.geometryLayout = a.getLayout(), o.rtept = a.getCoordinates()
|
||
}
|
||
var l = i[i.length - 1].node, h = sd[l.namespaceURI], u = cp(o, h);
|
||
mp(n, ad, up, u, i, h)
|
||
}), trk: ap(function (t, e, i) {
|
||
var r = i[0], o = e.getProperties(), n = {node: t};
|
||
n.properties = o;
|
||
var s = e.getGeometry();
|
||
if (s.getType() == Zt.MULTI_LINE_STRING) {
|
||
var a = kc(s, !0, r);
|
||
o.trkseg = a.getLineStrings()
|
||
}
|
||
var l = i[i.length - 1].node, h = hd[l.namespaceURI], u = cp(o, h);
|
||
mp(n, ud, up, u, i, h)
|
||
}), wpt: ap(function (t, e, i) {
|
||
var r = i[0], o = i[i.length - 1];
|
||
o.properties = e.getProperties();
|
||
var n = e.getGeometry();
|
||
if (n.getType() == Zt.POINT) {
|
||
var s = kc(n, !0, r);
|
||
o.geometryLayout = s.getLayout(), Ed(t, s.getCoordinates(), i)
|
||
}
|
||
})
|
||
}), Jp = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = e || {};
|
||
this.dataProjection = We("EPSG:4326"), this.readExtensions_ = i.readExtensions
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleReadExtensions_ = function (t) {
|
||
t || (t = []);
|
||
for (var e = 0, i = t.length; e < i; ++e) {
|
||
var r = t[e];
|
||
if (this.readExtensions_) {
|
||
var o = r.get("extensionsNode_") || null;
|
||
this.readExtensions_(r, o)
|
||
}
|
||
r.set("extensionsNode_", void 0)
|
||
}
|
||
}, e.prototype.readFeatureFromNode = function (t, e) {
|
||
if (!K(Hp, t.namespaceURI)) return null;
|
||
var i = Xp[t.localName];
|
||
if (!i) return null;
|
||
var r = i(t, [this.getReadOptions(t, e)]);
|
||
return r ? (this.handleReadExtensions_([r]), r) : null
|
||
}, e.prototype.readFeaturesFromNode = function (t, e) {
|
||
if (!K(Hp, t.namespaceURI)) return [];
|
||
if ("gpx" == t.localName) {
|
||
var i = fp([], qp, t, [this.getReadOptions(t, e)]);
|
||
return i ? (this.handleReadExtensions_(i), i) : []
|
||
}
|
||
return []
|
||
}, e.prototype.writeFeaturesNode = function (t, e) {
|
||
e = this.adaptOptions(e);
|
||
var i = Kc("http://www.topografix.com/GPX/1/1", "gpx");
|
||
return i.setAttributeNS("http://www.w3.org/2000/xmlns/", "xmlns:xsi", Zc), i.setAttributeNS(Zc, "xsi:schemaLocation", "http://www.topografix.com/GPX/1/1 http://www.topografix.com/GPX/1/1/gpx.xsd"), i.setAttribute("version", "1.1"), i.setAttribute("creator", "OpenLayers"), mp({node: i}, Kp, md, t, [e]), i
|
||
}, e
|
||
}(yp), $p = pp(Hp, {
|
||
name: sp(Lp),
|
||
cmt: sp(Lp),
|
||
desc: sp(Lp),
|
||
src: sp(Lp),
|
||
link: _d,
|
||
number: sp(Rp),
|
||
extensions: xd,
|
||
type: sp(Lp),
|
||
rtept: function (t, e) {
|
||
var i = fp({}, Qp, t, e);
|
||
if (i) {
|
||
var r = e[e.length - 1], o = r.flatCoordinates, n = r.layoutOptions;
|
||
yd(o, n, t, i)
|
||
}
|
||
}
|
||
}), Qp = pp(Hp, {ele: sp(Ep), time: sp(Sp)}), td = pp(Hp, {
|
||
name: sp(Lp),
|
||
cmt: sp(Lp),
|
||
desc: sp(Lp),
|
||
src: sp(Lp),
|
||
link: _d,
|
||
number: sp(Rp),
|
||
type: sp(Lp),
|
||
extensions: xd,
|
||
trkseg: function (t, e) {
|
||
var i = e[e.length - 1];
|
||
dp(ed, t, e);
|
||
var r = i.flatCoordinates;
|
||
i.ends.push(r.length)
|
||
}
|
||
}), ed = pp(Hp, {
|
||
trkpt: function (t, e) {
|
||
var i = fp({}, id, t, e);
|
||
if (i) {
|
||
var r = e[e.length - 1], o = r.flatCoordinates, n = r.layoutOptions;
|
||
yd(o, n, t, i)
|
||
}
|
||
}
|
||
}), id = pp(Hp, {ele: sp(Ep), time: sp(Sp)}), rd = pp(Hp, {
|
||
ele: sp(Ep),
|
||
time: sp(Sp),
|
||
magvar: sp(Ep),
|
||
geoidheight: sp(Ep),
|
||
name: sp(Lp),
|
||
cmt: sp(Lp),
|
||
desc: sp(Lp),
|
||
src: sp(Lp),
|
||
link: _d,
|
||
sym: sp(Lp),
|
||
type: sp(Lp),
|
||
fix: sp(Lp),
|
||
sat: sp(Rp),
|
||
hdop: sp(Ep),
|
||
vdop: sp(Ep),
|
||
pdop: sp(Ep),
|
||
ageofdgpsdata: sp(Ep),
|
||
dgpsid: sp(Rp),
|
||
extensions: xd
|
||
}), od = ["text", "type"], nd = pp(Hp, {text: ap(Fp), type: ap(Fp)}),
|
||
sd = pp(Hp, ["name", "cmt", "desc", "src", "link", "number", "type", "rtept"]), ad = pp(Hp, {
|
||
name: ap(Fp),
|
||
cmt: ap(Fp),
|
||
desc: ap(Fp),
|
||
src: ap(Fp),
|
||
link: ap(Sd),
|
||
number: ap(kp),
|
||
type: ap(Fp),
|
||
rtept: lp(ap(Ed))
|
||
}), ld = pp(Hp, ["ele", "time"]),
|
||
hd = pp(Hp, ["name", "cmt", "desc", "src", "link", "number", "type", "trkseg"]), ud = pp(Hp, {
|
||
name: ap(Fp),
|
||
cmt: ap(Fp),
|
||
desc: ap(Fp),
|
||
src: ap(Fp),
|
||
link: ap(Sd),
|
||
number: ap(kp),
|
||
type: ap(Fp),
|
||
trkseg: lp(ap(function (t, e, i) {
|
||
var r = {node: t};
|
||
r.geometryLayout = e.getLayout(), r.properties = {}, mp(r, pd, cd, e.getCoordinates(), i)
|
||
}))
|
||
}), cd = hp("trkpt"), pd = pp(Hp, {trkpt: ap(Ed)}),
|
||
dd = pp(Hp, ["ele", "time", "magvar", "geoidheight", "name", "cmt", "desc", "src", "link", "sym", "type", "fix", "sat", "hdop", "vdop", "pdop", "ageofdgpsdata", "dgpsid"]),
|
||
fd = pp(Hp, {
|
||
ele: ap(Ap),
|
||
time: ap(Mp),
|
||
magvar: ap(Ap),
|
||
geoidheight: ap(Ap),
|
||
name: ap(Fp),
|
||
cmt: ap(Fp),
|
||
desc: ap(Fp),
|
||
src: ap(Fp),
|
||
link: ap(Sd),
|
||
sym: ap(Fp),
|
||
type: ap(Fp),
|
||
fix: ap(Fp),
|
||
sat: ap(kp),
|
||
hdop: ap(Ap),
|
||
vdop: ap(Ap),
|
||
pdop: ap(Ap),
|
||
ageofdgpsdata: ap(Ap),
|
||
dgpsid: ap(kp)
|
||
}), gd = {Point: "wpt", LineString: "rte", MultiLineString: "trk"};
|
||
|
||
function md(t, e, i) {
|
||
var r = t.getGeometry();
|
||
if (r) {
|
||
var o = gd[r.getType()];
|
||
if (o) return Kc(e[e.length - 1].node.namespaceURI, o)
|
||
}
|
||
}
|
||
|
||
function yd(t, e, i, r) {
|
||
return t.push(parseFloat(i.getAttribute("lon")), parseFloat(i.getAttribute("lat"))), "ele" in r ? (t.push(r.ele), delete r.ele, e.hasZ = !0) : t.push(0), "time" in r ? (t.push(r.time), delete r.time, e.hasM = !0) : t.push(0), t
|
||
}
|
||
|
||
function vd(t, e, i) {
|
||
var r = qt.XY, o = 2;
|
||
if (t.hasZ && t.hasM ? (r = qt.XYZM, o = 4) : t.hasZ ? (r = qt.XYZ, o = 3) : t.hasM && (r = qt.XYM, o = 3), 4 !== o) {
|
||
for (var n = 0, s = e.length / 4; n < s; n++) e[n * o] = e[4 * n], e[n * o + 1] = e[4 * n + 1], t.hasZ && (e[n * o + 2] = e[4 * n + 2]), t.hasM && (e[n * o + 2] = e[4 * n + 3]);
|
||
if (e.length = e.length / 4 * o, i) for (var a = 0, l = i.length; a < l; a++) i[a] = i[a] / 4 * o
|
||
}
|
||
return r
|
||
}
|
||
|
||
function _d(t, e) {
|
||
var i = e[e.length - 1], r = t.getAttribute("href");
|
||
null !== r && (i.link = r), dp(Zp, t, e)
|
||
}
|
||
|
||
function xd(t, e) {
|
||
e[e.length - 1].extensionsNode_ = t
|
||
}
|
||
|
||
function wd(t, e) {
|
||
var i = e[0], r = fp({flatCoordinates: [], layoutOptions: {}}, $p, t, e);
|
||
if (r) {
|
||
var o = r.flatCoordinates;
|
||
delete r.flatCoordinates;
|
||
var n = r.layoutOptions;
|
||
delete r.layoutOptions;
|
||
var s = vd(n, o), a = new Jr(o, s);
|
||
kc(a, !1, i);
|
||
var l = new X(a);
|
||
return l.setProperties(r), l
|
||
}
|
||
}
|
||
|
||
function bd(t, e) {
|
||
var i = e[0], r = fp({flatCoordinates: [], ends: [], layoutOptions: {}}, td, t, e);
|
||
if (r) {
|
||
var o = r.flatCoordinates;
|
||
delete r.flatCoordinates;
|
||
var n = r.ends;
|
||
delete r.ends;
|
||
var s = r.layoutOptions;
|
||
delete r.layoutOptions;
|
||
var a = vd(s, o, n), l = new Dc(o, a, n);
|
||
kc(l, !1, i);
|
||
var h = new X(l);
|
||
return h.setProperties(r), h
|
||
}
|
||
}
|
||
|
||
function Cd(t, e) {
|
||
var i = e[0], r = fp({}, rd, t, e);
|
||
if (r) {
|
||
var o = {}, n = yd([], o, t, r), s = vd(o, n), a = new qi(n, s);
|
||
kc(a, !1, i);
|
||
var l = new X(a);
|
||
return l.setProperties(r), l
|
||
}
|
||
}
|
||
|
||
function Sd(t, e, i) {
|
||
t.setAttribute("href", e);
|
||
var r = i[i.length - 1].properties, o = [r.linkText, r.linkType];
|
||
mp({node: t}, nd, up, o, i, od)
|
||
}
|
||
|
||
function Ed(t, e, i) {
|
||
var r = i[i.length - 1], o = r.node.namespaceURI, n = r.properties;
|
||
switch (t.setAttributeNS(null, "lat", String(e[1])), t.setAttributeNS(null, "lon", String(e[0])), r.geometryLayout) {
|
||
case qt.XYZM:
|
||
0 !== e[3] && (n.time = e[3]);
|
||
case qt.XYZ:
|
||
0 !== e[2] && (n.ele = e[2]);
|
||
break;
|
||
case qt.XYM:
|
||
0 !== e[2] && (n.time = e[2])
|
||
}
|
||
var s = "rtept" == t.nodeName ? ld[o] : dd[o], a = cp(n, s);
|
||
mp({node: t, properties: n}, fd, up, a, i, s)
|
||
}
|
||
|
||
var Td = Jp;
|
||
|
||
function Rd(t) {
|
||
for (var e = [], i = 0, r = t.length; i < r; ++i) e.push(t[i].clone());
|
||
return e
|
||
}
|
||
|
||
var Pd = function (t) {
|
||
function e(e) {
|
||
t.call(this), this.geometries_ = e || null, this.listenGeometriesChange_()
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.unlistenGeometriesChange_ = function () {
|
||
if (this.geometries_) for (var t = 0, e = this.geometries_.length; t < e; ++t) C(this.geometries_[t], F.CHANGE, this.changed, this)
|
||
}, e.prototype.listenGeometriesChange_ = function () {
|
||
if (this.geometries_) for (var t = 0, e = this.geometries_.length; t < e; ++t) w(this.geometries_[t], F.CHANGE, this.changed, this)
|
||
}, e.prototype.clone = function () {
|
||
var t = new e(null);
|
||
return t.setGeometries(this.geometries_), t
|
||
}, e.prototype.closestPointXY = function (t, e, i, r) {
|
||
if (r < ct(this.getExtent(), t, e)) return r;
|
||
for (var o = this.geometries_, n = 0, s = o.length; n < s; ++n) r = o[n].closestPointXY(t, e, i, r);
|
||
return r
|
||
}, e.prototype.containsXY = function (t, e) {
|
||
for (var i = this.geometries_, r = 0, o = i.length; r < o; ++r) if (i[r].containsXY(t, e)) return !0;
|
||
return !1
|
||
}, e.prototype.computeExtent = function (t) {
|
||
vt(t);
|
||
for (var e = this.geometries_, i = 0, r = e.length; i < r; ++i) Ct(t, e[i].getExtent());
|
||
return t
|
||
}, e.prototype.getGeometries = function () {
|
||
return Rd(this.geometries_)
|
||
}, e.prototype.getGeometriesArray = function () {
|
||
return this.geometries_
|
||
}, e.prototype.getSimplifiedGeometry = function (t) {
|
||
if (this.simplifiedGeometryRevision != this.getRevision() && (d(this.simplifiedGeometryCache), this.simplifiedGeometryMaxMinSquaredTolerance = 0, this.simplifiedGeometryRevision = this.getRevision()), t < 0 || 0 !== this.simplifiedGeometryMaxMinSquaredTolerance && t < this.simplifiedGeometryMaxMinSquaredTolerance) return this;
|
||
var i = t.toString();
|
||
if (this.simplifiedGeometryCache.hasOwnProperty(i)) return this.simplifiedGeometryCache[i];
|
||
for (var r = [], o = this.geometries_, n = !1, s = 0, a = o.length; s < a; ++s) {
|
||
var l = o[s], h = l.getSimplifiedGeometry(t);
|
||
r.push(h), h !== l && (n = !0)
|
||
}
|
||
if (n) {
|
||
var u = new e(null);
|
||
return u.setGeometriesArray(r), this.simplifiedGeometryCache[i] = u, u
|
||
}
|
||
return this.simplifiedGeometryMaxMinSquaredTolerance = t, this
|
||
}, e.prototype.getType = function () {
|
||
return Zt.GEOMETRY_COLLECTION
|
||
}, e.prototype.intersectsExtent = function (t) {
|
||
for (var e = this.geometries_, i = 0, r = e.length; i < r; ++i) if (e[i].intersectsExtent(t)) return !0;
|
||
return !1
|
||
}, e.prototype.isEmpty = function () {
|
||
return 0 === this.geometries_.length
|
||
}, e.prototype.rotate = function (t, e) {
|
||
for (var i = this.geometries_, r = 0, o = i.length; r < o; ++r) i[r].rotate(t, e);
|
||
this.changed()
|
||
}, e.prototype.scale = function (t, e, i) {
|
||
var r = i;
|
||
r || (r = At(this.getExtent()));
|
||
for (var o = this.geometries_, n = 0, s = o.length; n < s; ++n) o[n].scale(t, e, r);
|
||
this.changed()
|
||
}, e.prototype.setGeometries = function (t) {
|
||
this.setGeometriesArray(Rd(t))
|
||
}, e.prototype.setGeometriesArray = function (t) {
|
||
this.unlistenGeometriesChange_(), this.geometries_ = t, this.listenGeometriesChange_(), this.changed()
|
||
}, e.prototype.applyTransform = function (t) {
|
||
for (var e = this.geometries_, i = 0, r = e.length; i < r; ++i) e[i].applyTransform(t);
|
||
this.changed()
|
||
}, e.prototype.translate = function (t, e) {
|
||
for (var i = this.geometries_, r = 0, o = i.length; r < o; ++r) i[r].translate(t, e);
|
||
this.changed()
|
||
}, e.prototype.disposeInternal = function () {
|
||
this.unlistenGeometriesChange_(), t.prototype.disposeInternal.call(this)
|
||
}, e
|
||
}(_i);
|
||
|
||
function Ld(t, e) {
|
||
if (!t) return null;
|
||
var i;
|
||
switch (t.type) {
|
||
case Zt.POINT:
|
||
i = function (t) {
|
||
return new qi(t.coordinates)
|
||
}(t);
|
||
break;
|
||
case Zt.LINE_STRING:
|
||
i = function (t) {
|
||
return new Jr(t.coordinates)
|
||
}(t);
|
||
break;
|
||
case Zt.POLYGON:
|
||
i = function (t) {
|
||
return new fr(t.coordinates)
|
||
}(t);
|
||
break;
|
||
case Zt.MULTI_POINT:
|
||
i = function (t) {
|
||
return new Gc(t.coordinates)
|
||
}(t);
|
||
break;
|
||
case Zt.MULTI_LINE_STRING:
|
||
i = function (t) {
|
||
return new Dc(t.coordinates)
|
||
}(t);
|
||
break;
|
||
case Zt.MULTI_POLYGON:
|
||
i = function (t) {
|
||
return new zc(t.coordinates)
|
||
}(t);
|
||
break;
|
||
case Zt.GEOMETRY_COLLECTION:
|
||
i = function (t, e) {
|
||
var i = t.geometries.map(function (t) {
|
||
return Ld(t, e)
|
||
});
|
||
return new Pd(i)
|
||
}(t);
|
||
break;
|
||
default:
|
||
throw new Error("Unsupported GeoJSON type: " + t.type)
|
||
}
|
||
return kc(i, !1, e)
|
||
}
|
||
|
||
function Id(t, e) {
|
||
var i, r = (t = kc(t, !0, e)).getType();
|
||
switch (r) {
|
||
case Zt.POINT:
|
||
i = function (t, e) {
|
||
return {type: "Point", coordinates: t.getCoordinates()}
|
||
}(t);
|
||
break;
|
||
case Zt.LINE_STRING:
|
||
i = function (t, e) {
|
||
return {type: "LineString", coordinates: t.getCoordinates()}
|
||
}(t);
|
||
break;
|
||
case Zt.POLYGON:
|
||
i = function (t, e) {
|
||
var i;
|
||
e && (i = e.rightHanded);
|
||
return {type: "Polygon", coordinates: t.getCoordinates(i)}
|
||
}(t, e);
|
||
break;
|
||
case Zt.MULTI_POINT:
|
||
i = function (t, e) {
|
||
return {type: "MultiPoint", coordinates: t.getCoordinates()}
|
||
}(t);
|
||
break;
|
||
case Zt.MULTI_LINE_STRING:
|
||
i = function (t, e) {
|
||
return {type: "MultiLineString", coordinates: t.getCoordinates()}
|
||
}(t);
|
||
break;
|
||
case Zt.MULTI_POLYGON:
|
||
i = function (t, e) {
|
||
var i;
|
||
e && (i = e.rightHanded);
|
||
return {type: "MultiPolygon", coordinates: t.getCoordinates(i)}
|
||
}(t, e);
|
||
break;
|
||
case Zt.GEOMETRY_COLLECTION:
|
||
i = function (t, e) {
|
||
return {
|
||
type: "GeometryCollection", geometries: t.getGeometriesArray().map(function (t) {
|
||
var i = p({}, e);
|
||
return delete i.featureProjection, Id(t, i)
|
||
})
|
||
}
|
||
}(t, e);
|
||
break;
|
||
case Zt.CIRCLE:
|
||
i = {type: "GeometryCollection", geometries: []};
|
||
break;
|
||
default:
|
||
throw new Error("Unsupported geometry type: " + r)
|
||
}
|
||
return i
|
||
}
|
||
|
||
var Od = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this), this.dataProjection = We(i.dataProjection ? i.dataProjection : "EPSG:4326"), i.featureProjection && (this.defaultFeatureProjection = We(i.featureProjection)), this.geometryName_ = i.geometryName, this.extractGeometryName_ = i.extractGeometryName
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.readFeatureFromObject = function (t, e) {
|
||
var i = null, r = Ld((i = "Feature" === t.type ? t : {
|
||
type: "Feature",
|
||
geometry: t,
|
||
properties: null
|
||
}).geometry, e), o = new X;
|
||
return this.geometryName_ ? o.setGeometryName(this.geometryName_) : this.extractGeometryName_ && "geometry_name" in i !== void 0 && o.setGeometryName(i.geometry_name), o.setGeometry(r), "id" in i && o.setId(i.id), i.properties && o.setProperties(i.properties), o
|
||
}, e.prototype.readFeaturesFromObject = function (t, e) {
|
||
var i = null;
|
||
if ("FeatureCollection" === t.type) {
|
||
i = [];
|
||
for (var r = t.features, o = 0, n = r.length; o < n; ++o) i.push(this.readFeatureFromObject(r[o], e))
|
||
} else i = [this.readFeatureFromObject(t, e)];
|
||
return i
|
||
}, e.prototype.readGeometryFromObject = function (t, e) {
|
||
return Ld(t, e)
|
||
}, e.prototype.readProjectionFromObject = function (t) {
|
||
var e, i = t.crs;
|
||
return i ? "name" == i.type ? e = We(i.properties.name) : W(!1, 36) : e = this.dataProjection, e
|
||
}, e.prototype.writeFeatureObject = function (t, e) {
|
||
e = this.adaptOptions(e);
|
||
var i = {type: "Feature", geometry: null, properties: null}, r = t.getId();
|
||
void 0 !== r && (i.id = r);
|
||
var o = t.getGeometry();
|
||
o && (i.geometry = Id(o, e));
|
||
var n = t.getProperties();
|
||
return delete n[t.getGeometryName()], g(n) || (i.properties = n), i
|
||
}, e.prototype.writeFeaturesObject = function (t, e) {
|
||
e = this.adaptOptions(e);
|
||
for (var i = [], r = 0, o = t.length; r < o; ++r) i.push(this.writeFeatureObject(t[r], e));
|
||
return {type: "FeatureCollection", features: i}
|
||
}, e.prototype.writeGeometryObject = function (t, e) {
|
||
return Id(t, this.adaptOptions(e))
|
||
}, e
|
||
}(Nc);
|
||
|
||
function Md(t) {
|
||
return "string" == typeof t ? t : ""
|
||
}
|
||
|
||
var Ad = function (t) {
|
||
function e() {
|
||
t.call(this)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getType = function () {
|
||
return gh.TEXT
|
||
}, e.prototype.readFeature = function (t, e) {
|
||
return this.readFeatureFromText(Md(t), this.adaptOptions(e))
|
||
}, e.prototype.readFeatureFromText = function (t, e) {
|
||
return n()
|
||
}, e.prototype.readFeatures = function (t, e) {
|
||
return this.readFeaturesFromText(Md(t), this.adaptOptions(e))
|
||
}, e.prototype.readFeaturesFromText = function (t, e) {
|
||
return n()
|
||
}, e.prototype.readGeometry = function (t, e) {
|
||
return this.readGeometryFromText(Md(t), this.adaptOptions(e))
|
||
}, e.prototype.readGeometryFromText = function (t, e) {
|
||
return n()
|
||
}, e.prototype.readProjection = function (t) {
|
||
return this.readProjectionFromText(Md(t))
|
||
}, e.prototype.readProjectionFromText = function (t) {
|
||
return this.dataProjection
|
||
}, e.prototype.writeFeature = function (t, e) {
|
||
return this.writeFeatureText(t, this.adaptOptions(e))
|
||
}, e.prototype.writeFeatureText = function (t, e) {
|
||
return n()
|
||
}, e.prototype.writeFeatures = function (t, e) {
|
||
return this.writeFeaturesText(t, this.adaptOptions(e))
|
||
}, e.prototype.writeFeaturesText = function (t, e) {
|
||
return n()
|
||
}, e.prototype.writeGeometry = function (t, e) {
|
||
return this.writeGeometryText(t, this.adaptOptions(e))
|
||
}, e.prototype.writeGeometryText = function (t, e) {
|
||
return n()
|
||
}, e
|
||
}(Ac), kd = {BAROMETRIC: "barometric", GPS: "gps", NONE: "none"},
|
||
Fd = /^B(\d{2})(\d{2})(\d{2})(\d{2})(\d{5})([NS])(\d{3})(\d{5})([EW])([AV])(\d{5})(\d{5})/,
|
||
Nd = /^H.([A-Z]{3}).*?:(.*)/, Dd = /^HFDTE(\d{2})(\d{2})(\d{2})/, Gd = /\r\n|\r|\n/, jd = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = e || {};
|
||
this.dataProjection = We("EPSG:4326"), this.altitudeMode_ = i.altitudeMode ? i.altitudeMode : kd.NONE
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.readFeatureFromText = function (t, e) {
|
||
var i, r, o = this.altitudeMode_, n = t.split(Gd), s = {}, a = [], l = 2e3, h = 0, u = 1, c = -1;
|
||
for (i = 0, r = n.length; i < r; ++i) {
|
||
var p = n[i], d = void 0;
|
||
if ("B" == p.charAt(0)) {
|
||
if (d = Fd.exec(p)) {
|
||
var f = parseInt(d[1], 10), g = parseInt(d[2], 10), m = parseInt(d[3], 10),
|
||
y = parseInt(d[4], 10) + parseInt(d[5], 10) / 6e4;
|
||
"S" == d[6] && (y = -y);
|
||
var v = parseInt(d[7], 10) + parseInt(d[8], 10) / 6e4;
|
||
if ("W" == d[9] && (v = -v), a.push(v, y), o != kd.NONE) {
|
||
var _ = void 0;
|
||
_ = o == kd.GPS ? parseInt(d[11], 10) : o == kd.BAROMETRIC ? parseInt(d[12], 10) : 0, a.push(_)
|
||
}
|
||
var x = Date.UTC(l, h, u, f, g, m);
|
||
x < c && (x = Date.UTC(l, h, u + 1, f, g, m)), a.push(x / 1e3), c = x
|
||
}
|
||
} else "H" == p.charAt(0) && ((d = Dd.exec(p)) ? (u = parseInt(d[1], 10), h = parseInt(d[2], 10) - 1, l = 2e3 + parseInt(d[3], 10)) : (d = Nd.exec(p)) && (s[d[1]] = d[2].trim()))
|
||
}
|
||
if (0 === a.length) return null;
|
||
var w = o == kd.NONE ? qt.XYM : qt.XYZM, b = new Jr(a, w), C = new X(kc(b, !1, e));
|
||
return C.setProperties(s), C
|
||
}, e.prototype.readFeaturesFromText = function (t, e) {
|
||
var i = this.readFeatureFromText(t, e);
|
||
return i ? [i] : []
|
||
}, e
|
||
}(Ad), zd = {FRACTION: "fraction", PIXELS: "pixels"}, Ud = function (t) {
|
||
function e(e, i, r, o, n, s) {
|
||
t.call(this), this.hitDetectionImage_ = null, this.image_ = e || new Image, null !== o && (this.image_.crossOrigin = o), this.canvas_ = s ? document.createElement("canvas") : null, this.color_ = s, this.imageListenerKeys_ = null, this.imageState_ = n, this.size_ = r, this.src_ = i, this.tainted_
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.isTainted_ = function () {
|
||
if (void 0 === this.tainted_ && this.imageState_ === So.LOADED) {
|
||
this.tainted_ = !1;
|
||
var t = Ao(1, 1);
|
||
try {
|
||
t.drawImage(this.image_, 0, 0), t.getImageData(0, 0, 1, 1)
|
||
} catch (t) {
|
||
this.tainted_ = !0
|
||
}
|
||
}
|
||
return !0 === this.tainted_
|
||
}, e.prototype.dispatchChangeEvent_ = function () {
|
||
this.dispatchEvent(F.CHANGE)
|
||
}, e.prototype.handleImageError_ = function () {
|
||
this.imageState_ = So.ERROR, this.unlistenImage_(), this.dispatchChangeEvent_()
|
||
}, e.prototype.handleImageLoad_ = function () {
|
||
this.imageState_ = So.LOADED, this.size_ && (this.image_.width = this.size_[0], this.image_.height = this.size_[1]), this.size_ = [this.image_.width, this.image_.height], this.unlistenImage_(), this.replaceColor_(), this.dispatchChangeEvent_()
|
||
}, e.prototype.getImage = function (t) {
|
||
return this.canvas_ ? this.canvas_ : this.image_
|
||
}, e.prototype.getImageState = function () {
|
||
return this.imageState_
|
||
}, e.prototype.getHitDetectionImage = function (t) {
|
||
if (!this.hitDetectionImage_) if (this.isTainted_()) {
|
||
var e = this.size_[0], i = this.size_[1], r = Ao(e, i);
|
||
r.fillRect(0, 0, e, i), this.hitDetectionImage_ = r.canvas
|
||
} else this.hitDetectionImage_ = this.image_;
|
||
return this.hitDetectionImage_
|
||
}, e.prototype.getSize = function () {
|
||
return this.size_
|
||
}, e.prototype.getSrc = function () {
|
||
return this.src_
|
||
}, e.prototype.load = function () {
|
||
if (this.imageState_ == So.IDLE) {
|
||
this.imageState_ = So.LOADING, this.imageListenerKeys_ = [b(this.image_, F.ERROR, this.handleImageError_, this), b(this.image_, F.LOAD, this.handleImageLoad_, this)];
|
||
try {
|
||
this.image_.src = this.src_
|
||
} catch (t) {
|
||
this.handleImageError_()
|
||
}
|
||
}
|
||
}, e.prototype.replaceColor_ = function () {
|
||
if (this.color_ && !this.isTainted_()) {
|
||
this.canvas_.width = this.image_.width, this.canvas_.height = this.image_.height;
|
||
var t = this.canvas_.getContext("2d");
|
||
t.drawImage(this.image_, 0, 0);
|
||
for (var e = t.getImageData(0, 0, this.image_.width, this.image_.height), i = e.data, r = this.color_[0] / 255, o = this.color_[1] / 255, n = this.color_[2] / 255, s = 0, a = i.length; s < a; s += 4) i[s] *= r, i[s + 1] *= o, i[s + 2] *= n;
|
||
t.putImageData(e, 0, 0)
|
||
}
|
||
}, e.prototype.unlistenImage_ = function () {
|
||
this.imageListenerKeys_.forEach(S), this.imageListenerKeys_ = null
|
||
}, e
|
||
}(k);
|
||
|
||
function Bd(t, e, i, r, o, n) {
|
||
var s = $a.get(e, r, n);
|
||
return s || (s = new Ud(t, e, i, r, o, n), $a.set(e, r, n, s)), s
|
||
}
|
||
|
||
var Vd = Ud, Yd = {
|
||
BOTTOM_LEFT: "bottom-left",
|
||
BOTTOM_RIGHT: "bottom-right",
|
||
TOP_LEFT: "top-left",
|
||
TOP_RIGHT: "top-right"
|
||
}, Wd = function (t) {
|
||
this.opacity_ = t.opacity, this.rotateWithView_ = t.rotateWithView, this.rotation_ = t.rotation, this.scale_ = t.scale
|
||
};
|
||
Wd.prototype.clone = function () {
|
||
return new Wd({
|
||
opacity: this.getOpacity(),
|
||
scale: this.getScale(),
|
||
rotation: this.getRotation(),
|
||
rotateWithView: this.getRotateWithView()
|
||
})
|
||
}, Wd.prototype.getOpacity = function () {
|
||
return this.opacity_
|
||
}, Wd.prototype.getRotateWithView = function () {
|
||
return this.rotateWithView_
|
||
}, Wd.prototype.getRotation = function () {
|
||
return this.rotation_
|
||
}, Wd.prototype.getScale = function () {
|
||
return this.scale_
|
||
}, Wd.prototype.getSnapToPixel = function () {
|
||
return !1
|
||
}, Wd.prototype.getAnchor = function () {
|
||
return n()
|
||
}, Wd.prototype.getImage = function (t) {
|
||
return n()
|
||
}, Wd.prototype.getHitDetectionImage = function (t) {
|
||
return n()
|
||
}, Wd.prototype.getImageState = function () {
|
||
return n()
|
||
}, Wd.prototype.getImageSize = function () {
|
||
return n()
|
||
}, Wd.prototype.getHitDetectionImageSize = function () {
|
||
return n()
|
||
}, Wd.prototype.getOrigin = function () {
|
||
return n()
|
||
}, Wd.prototype.getSize = function () {
|
||
return n()
|
||
}, Wd.prototype.setOpacity = function (t) {
|
||
this.opacity_ = t
|
||
}, Wd.prototype.setRotateWithView = function (t) {
|
||
this.rotateWithView_ = t
|
||
}, Wd.prototype.setRotation = function (t) {
|
||
this.rotation_ = t
|
||
}, Wd.prototype.setScale = function (t) {
|
||
this.scale_ = t
|
||
}, Wd.prototype.setSnapToPixel = function (t) {
|
||
}, Wd.prototype.listenImageChange = function (t, e) {
|
||
return n()
|
||
}, Wd.prototype.load = function () {
|
||
n()
|
||
}, Wd.prototype.unlistenImageChange = function (t, e) {
|
||
n()
|
||
};
|
||
var Hd = Wd, Xd = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = void 0 !== i.opacity ? i.opacity : 1, o = void 0 !== i.rotation ? i.rotation : 0,
|
||
n = void 0 !== i.scale ? i.scale : 1, s = void 0 !== i.rotateWithView && i.rotateWithView;
|
||
t.call(this, {
|
||
opacity: r,
|
||
rotation: o,
|
||
scale: n,
|
||
rotateWithView: s
|
||
}), this.anchor_ = void 0 !== i.anchor ? i.anchor : [.5, .5], this.normalizedAnchor_ = null, this.anchorOrigin_ = void 0 !== i.anchorOrigin ? i.anchorOrigin : Yd.TOP_LEFT, this.anchorXUnits_ = void 0 !== i.anchorXUnits ? i.anchorXUnits : zd.FRACTION, this.anchorYUnits_ = void 0 !== i.anchorYUnits ? i.anchorYUnits : zd.FRACTION, this.crossOrigin_ = void 0 !== i.crossOrigin ? i.crossOrigin : null;
|
||
var l = void 0 !== i.img ? i.img : null, h = void 0 !== i.imgSize ? i.imgSize : null, u = i.src;
|
||
W(!(void 0 !== u && l), 4), W(!l || l && h, 5), void 0 !== u && 0 !== u.length || !l || (u = l.src || a(l)), W(void 0 !== u && u.length > 0, 6);
|
||
var c = void 0 !== i.src ? So.IDLE : So.LOADED;
|
||
this.color_ = void 0 !== i.color ? lo(i.color) : null, this.iconImage_ = Bd(l, u, h, this.crossOrigin_, c, this.color_), this.offset_ = void 0 !== i.offset ? i.offset : [0, 0], this.offsetOrigin_ = void 0 !== i.offsetOrigin ? i.offsetOrigin : Yd.TOP_LEFT, this.origin_ = null, this.size_ = void 0 !== i.size ? i.size : null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.clone = function () {
|
||
return new e({
|
||
anchor: this.anchor_.slice(),
|
||
anchorOrigin: this.anchorOrigin_,
|
||
anchorXUnits: this.anchorXUnits_,
|
||
anchorYUnits: this.anchorYUnits_,
|
||
crossOrigin: this.crossOrigin_,
|
||
color: this.color_ && this.color_.slice ? this.color_.slice() : this.color_ || void 0,
|
||
src: this.getSrc(),
|
||
offset: this.offset_.slice(),
|
||
offsetOrigin: this.offsetOrigin_,
|
||
size: null !== this.size_ ? this.size_.slice() : void 0,
|
||
opacity: this.getOpacity(),
|
||
scale: this.getScale(),
|
||
rotation: this.getRotation(),
|
||
rotateWithView: this.getRotateWithView()
|
||
})
|
||
}, e.prototype.getAnchor = function () {
|
||
if (this.normalizedAnchor_) return this.normalizedAnchor_;
|
||
var t = this.anchor_, e = this.getSize();
|
||
if (this.anchorXUnits_ == zd.FRACTION || this.anchorYUnits_ == zd.FRACTION) {
|
||
if (!e) return null;
|
||
t = this.anchor_.slice(), this.anchorXUnits_ == zd.FRACTION && (t[0] *= e[0]), this.anchorYUnits_ == zd.FRACTION && (t[1] *= e[1])
|
||
}
|
||
if (this.anchorOrigin_ != Yd.TOP_LEFT) {
|
||
if (!e) return null;
|
||
t === this.anchor_ && (t = this.anchor_.slice()), this.anchorOrigin_ != Yd.TOP_RIGHT && this.anchorOrigin_ != Yd.BOTTOM_RIGHT || (t[0] = -t[0] + e[0]), this.anchorOrigin_ != Yd.BOTTOM_LEFT && this.anchorOrigin_ != Yd.BOTTOM_RIGHT || (t[1] = -t[1] + e[1])
|
||
}
|
||
return this.normalizedAnchor_ = t, this.normalizedAnchor_
|
||
}, e.prototype.setAnchor = function (t) {
|
||
this.anchor_ = t, this.normalizedAnchor_ = null
|
||
}, e.prototype.getColor = function () {
|
||
return this.color_
|
||
}, e.prototype.getImage = function (t) {
|
||
return this.iconImage_.getImage(t)
|
||
}, e.prototype.getImageSize = function () {
|
||
return this.iconImage_.getSize()
|
||
}, e.prototype.getHitDetectionImageSize = function () {
|
||
return this.getImageSize()
|
||
}, e.prototype.getImageState = function () {
|
||
return this.iconImage_.getImageState()
|
||
}, e.prototype.getHitDetectionImage = function (t) {
|
||
return this.iconImage_.getHitDetectionImage(t)
|
||
}, e.prototype.getOrigin = function () {
|
||
if (this.origin_) return this.origin_;
|
||
var t = this.offset_;
|
||
if (this.offsetOrigin_ != Yd.TOP_LEFT) {
|
||
var e = this.getSize(), i = this.iconImage_.getSize();
|
||
if (!e || !i) return null;
|
||
t = t.slice(), this.offsetOrigin_ != Yd.TOP_RIGHT && this.offsetOrigin_ != Yd.BOTTOM_RIGHT || (t[0] = i[0] - e[0] - t[0]), this.offsetOrigin_ != Yd.BOTTOM_LEFT && this.offsetOrigin_ != Yd.BOTTOM_RIGHT || (t[1] = i[1] - e[1] - t[1])
|
||
}
|
||
return this.origin_ = t, this.origin_
|
||
}, e.prototype.getSrc = function () {
|
||
return this.iconImage_.getSrc()
|
||
}, e.prototype.getSize = function () {
|
||
return this.size_ ? this.size_ : this.iconImage_.getSize()
|
||
}, e.prototype.listenImageChange = function (t, e) {
|
||
return w(this.iconImage_, F.CHANGE, t, e)
|
||
}, e.prototype.load = function () {
|
||
this.iconImage_.load()
|
||
}, e.prototype.unlistenImageChange = function (t, e) {
|
||
C(this.iconImage_, F.CHANGE, t, e)
|
||
}, e
|
||
}(Hd), qd = function (t) {
|
||
function e(e) {
|
||
var i = void 0 !== e.rotateWithView && e.rotateWithView;
|
||
t.call(this, {
|
||
opacity: 1,
|
||
rotateWithView: i,
|
||
rotation: void 0 !== e.rotation ? e.rotation : 0,
|
||
scale: 1
|
||
}), this.checksums_ = null, this.canvas_ = null, this.hitDetectionCanvas_ = null, this.fill_ = void 0 !== e.fill ? e.fill : null, this.origin_ = [0, 0], this.points_ = e.points, this.radius_ = void 0 !== e.radius ? e.radius : e.radius1, this.radius2_ = e.radius2, this.angle_ = void 0 !== e.angle ? e.angle : 0, this.stroke_ = void 0 !== e.stroke ? e.stroke : null, this.anchor_ = null, this.size_ = null, this.imageSize_ = null, this.hitDetectionImageSize_ = null, this.atlasManager_ = e.atlasManager, this.render_(this.atlasManager_)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.clone = function () {
|
||
var t = new e({
|
||
fill: this.getFill() ? this.getFill().clone() : void 0,
|
||
points: this.getPoints(),
|
||
radius: this.getRadius(),
|
||
radius2: this.getRadius2(),
|
||
angle: this.getAngle(),
|
||
stroke: this.getStroke() ? this.getStroke().clone() : void 0,
|
||
rotation: this.getRotation(),
|
||
rotateWithView: this.getRotateWithView(),
|
||
atlasManager: this.atlasManager_
|
||
});
|
||
return t.setOpacity(this.getOpacity()), t.setScale(this.getScale()), t
|
||
}, e.prototype.getAnchor = function () {
|
||
return this.anchor_
|
||
}, e.prototype.getAngle = function () {
|
||
return this.angle_
|
||
}, e.prototype.getFill = function () {
|
||
return this.fill_
|
||
}, e.prototype.getHitDetectionImage = function (t) {
|
||
return this.hitDetectionCanvas_
|
||
}, e.prototype.getImage = function (t) {
|
||
return this.canvas_
|
||
}, e.prototype.getImageSize = function () {
|
||
return this.imageSize_
|
||
}, e.prototype.getHitDetectionImageSize = function () {
|
||
return this.hitDetectionImageSize_
|
||
}, e.prototype.getImageState = function () {
|
||
return So.LOADED
|
||
}, e.prototype.getOrigin = function () {
|
||
return this.origin_
|
||
}, e.prototype.getPoints = function () {
|
||
return this.points_
|
||
}, e.prototype.getRadius = function () {
|
||
return this.radius_
|
||
}, e.prototype.getRadius2 = function () {
|
||
return this.radius2_
|
||
}, e.prototype.getSize = function () {
|
||
return this.size_
|
||
}, e.prototype.getStroke = function () {
|
||
return this.stroke_
|
||
}, e.prototype.listenImageChange = function (t, e) {
|
||
}, e.prototype.load = function () {
|
||
}, e.prototype.unlistenImageChange = function (t, e) {
|
||
}, e.prototype.render_ = function (t) {
|
||
var e, i, r = "", o = "", n = 0, s = null, a = 0, l = 0;
|
||
this.stroke_ && (null === (i = this.stroke_.getColor()) && (i = Ia), i = Wa(i), void 0 === (l = this.stroke_.getWidth()) && (l = 1), s = this.stroke_.getLineDash(), a = this.stroke_.getLineDashOffset(), Er || (s = null, a = 0), void 0 === (o = this.stroke_.getLineJoin()) && (o = "round"), void 0 === (r = this.stroke_.getLineCap()) && (r = "round"), void 0 === (n = this.stroke_.getMiterLimit()) && (n = 10));
|
||
var h = 2 * (this.radius_ + l) + 1, u = {
|
||
strokeStyle: i,
|
||
strokeWidth: l,
|
||
size: h,
|
||
lineCap: r,
|
||
lineDash: s,
|
||
lineDashOffset: a,
|
||
lineJoin: o,
|
||
miterLimit: n
|
||
};
|
||
if (void 0 === t) {
|
||
var c = Ao(h, h);
|
||
this.canvas_ = c.canvas, e = h = this.canvas_.width, this.draw_(u, c, 0, 0), this.createHitDetectionCanvas_(u)
|
||
} else {
|
||
h = Math.round(h);
|
||
var p, d = !this.fill_;
|
||
d && (p = this.drawHitDetectionCanvas_.bind(this, u));
|
||
var f = this.getChecksum(), g = t.add(f, h, h, this.draw_.bind(this, u), p);
|
||
this.canvas_ = g.image, this.origin_ = [g.offsetX, g.offsetY], e = g.image.width, d ? (this.hitDetectionCanvas_ = g.hitImage, this.hitDetectionImageSize_ = [g.hitImage.width, g.hitImage.height]) : (this.hitDetectionCanvas_ = this.canvas_, this.hitDetectionImageSize_ = [e, e])
|
||
}
|
||
this.anchor_ = [h / 2, h / 2], this.size_ = [h, h], this.imageSize_ = [e, e]
|
||
}, e.prototype.draw_ = function (t, e, i, r) {
|
||
var o, n, s;
|
||
e.setTransform(1, 0, 0, 1, 0, 0), e.translate(i, r), e.beginPath();
|
||
var a = this.points_;
|
||
if (a === 1 / 0) e.arc(t.size / 2, t.size / 2, this.radius_, 0, 2 * Math.PI, !0); else {
|
||
var l = void 0 !== this.radius2_ ? this.radius2_ : this.radius_;
|
||
for (l !== this.radius_ && (a *= 2), o = 0; o <= a; o++) n = 2 * o * Math.PI / a - Math.PI / 2 + this.angle_, s = o % 2 == 0 ? this.radius_ : l, e.lineTo(t.size / 2 + s * Math.cos(n), t.size / 2 + s * Math.sin(n))
|
||
}
|
||
if (this.fill_) {
|
||
var h = this.fill_.getColor();
|
||
null === h && (h = Pa), e.fillStyle = Wa(h), e.fill()
|
||
}
|
||
this.stroke_ && (e.strokeStyle = t.strokeStyle, e.lineWidth = t.strokeWidth, t.lineDash && (e.setLineDash(t.lineDash), e.lineDashOffset = t.lineDashOffset), e.lineCap = t.lineCap, e.lineJoin = t.lineJoin, e.miterLimit = t.miterLimit, e.stroke()), e.closePath()
|
||
}, e.prototype.createHitDetectionCanvas_ = function (t) {
|
||
if (this.hitDetectionImageSize_ = [t.size, t.size], this.fill_) this.hitDetectionCanvas_ = this.canvas_; else {
|
||
var e = Ao(t.size, t.size);
|
||
this.hitDetectionCanvas_ = e.canvas, this.drawHitDetectionCanvas_(t, e, 0, 0)
|
||
}
|
||
}, e.prototype.drawHitDetectionCanvas_ = function (t, e, i, r) {
|
||
e.setTransform(1, 0, 0, 1, 0, 0), e.translate(i, r), e.beginPath();
|
||
var o = this.points_;
|
||
if (o === 1 / 0) e.arc(t.size / 2, t.size / 2, this.radius_, 0, 2 * Math.PI, !0); else {
|
||
var n, s, a, l = void 0 !== this.radius2_ ? this.radius2_ : this.radius_;
|
||
for (l !== this.radius_ && (o *= 2), n = 0; n <= o; n++) a = 2 * n * Math.PI / o - Math.PI / 2 + this.angle_, s = n % 2 == 0 ? this.radius_ : l, e.lineTo(t.size / 2 + s * Math.cos(a), t.size / 2 + s * Math.sin(a))
|
||
}
|
||
e.fillStyle = oo(Pa), e.fill(), this.stroke_ && (e.strokeStyle = t.strokeStyle, e.lineWidth = t.strokeWidth, t.lineDash && (e.setLineDash(t.lineDash), e.lineDashOffset = t.lineDashOffset), e.stroke()), e.closePath()
|
||
}, e.prototype.getChecksum = function () {
|
||
var t = this.stroke_ ? this.stroke_.getChecksum() : "-",
|
||
e = this.fill_ ? this.fill_.getChecksum() : "-";
|
||
if (!this.checksums_ || t != this.checksums_[1] || e != this.checksums_[2] || this.radius_ != this.checksums_[3] || this.radius2_ != this.checksums_[4] || this.angle_ != this.checksums_[5] || this.points_ != this.checksums_[6]) {
|
||
var i = "r" + t + e + (void 0 !== this.radius_ ? this.radius_.toString() : "-") + (void 0 !== this.radius2_ ? this.radius2_.toString() : "-") + (void 0 !== this.angle_ ? this.angle_.toString() : "-") + (void 0 !== this.points_ ? this.points_.toString() : "-");
|
||
this.checksums_ = [i, t, e, this.radius_, this.radius2_, this.angle_, this.points_]
|
||
}
|
||
return this.checksums_[0]
|
||
}, e
|
||
}(Hd), Zd = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {
|
||
points: 1 / 0,
|
||
fill: i.fill,
|
||
radius: i.radius,
|
||
stroke: i.stroke,
|
||
atlasManager: i.atlasManager
|
||
})
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.clone = function () {
|
||
var t = new e({
|
||
fill: this.getFill() ? this.getFill().clone() : void 0,
|
||
stroke: this.getStroke() ? this.getStroke().clone() : void 0,
|
||
radius: this.getRadius(),
|
||
atlasManager: this.atlasManager_
|
||
});
|
||
return t.setOpacity(this.getOpacity()), t.setScale(this.getScale()), t
|
||
}, e.prototype.setRadius = function (t) {
|
||
this.radius_ = t, this.render_(this.atlasManager_)
|
||
}, e
|
||
}(qd), Kd = function (t) {
|
||
var e = t || {};
|
||
this.geometry_ = null, this.geometryFunction_ = ef, void 0 !== e.geometry && this.setGeometry(e.geometry), this.fill_ = void 0 !== e.fill ? e.fill : null, this.image_ = void 0 !== e.image ? e.image : null, this.renderer_ = void 0 !== e.renderer ? e.renderer : null, this.stroke_ = void 0 !== e.stroke ? e.stroke : null, this.text_ = void 0 !== e.text ? e.text : null, this.zIndex_ = e.zIndex
|
||
};
|
||
|
||
function Jd(t) {
|
||
var e;
|
||
if ("function" == typeof t) e = t; else {
|
||
var i;
|
||
if (Array.isArray(t)) i = t; else W("function" == typeof t.getZIndex, 41), i = [t];
|
||
e = function () {
|
||
return i
|
||
}
|
||
}
|
||
return e
|
||
}
|
||
|
||
Kd.prototype.clone = function () {
|
||
var t = this.getGeometry();
|
||
return t && "object" == typeof t && (t = t.clone()), new Kd({
|
||
geometry: t,
|
||
fill: this.getFill() ? this.getFill().clone() : void 0,
|
||
image: this.getImage() ? this.getImage().clone() : void 0,
|
||
stroke: this.getStroke() ? this.getStroke().clone() : void 0,
|
||
text: this.getText() ? this.getText().clone() : void 0,
|
||
zIndex: this.getZIndex()
|
||
})
|
||
}, Kd.prototype.getRenderer = function () {
|
||
return this.renderer_
|
||
}, Kd.prototype.setRenderer = function (t) {
|
||
this.renderer_ = t
|
||
}, Kd.prototype.getGeometry = function () {
|
||
return this.geometry_
|
||
}, Kd.prototype.getGeometryFunction = function () {
|
||
return this.geometryFunction_
|
||
}, Kd.prototype.getFill = function () {
|
||
return this.fill_
|
||
}, Kd.prototype.setFill = function (t) {
|
||
this.fill_ = t
|
||
}, Kd.prototype.getImage = function () {
|
||
return this.image_
|
||
}, Kd.prototype.setImage = function (t) {
|
||
this.image_ = t
|
||
}, Kd.prototype.getStroke = function () {
|
||
return this.stroke_
|
||
}, Kd.prototype.setStroke = function (t) {
|
||
this.stroke_ = t
|
||
}, Kd.prototype.getText = function () {
|
||
return this.text_
|
||
}, Kd.prototype.setText = function (t) {
|
||
this.text_ = t
|
||
}, Kd.prototype.getZIndex = function () {
|
||
return this.zIndex_
|
||
}, Kd.prototype.setGeometry = function (t) {
|
||
"function" == typeof t ? this.geometryFunction_ = t : "string" == typeof t ? this.geometryFunction_ = function (e) {
|
||
return e.get(t)
|
||
} : t ? void 0 !== t && (this.geometryFunction_ = function () {
|
||
return t
|
||
}) : this.geometryFunction_ = ef, this.geometry_ = t
|
||
}, Kd.prototype.setZIndex = function (t) {
|
||
this.zIndex_ = t
|
||
};
|
||
var $d = null;
|
||
|
||
function Qd(t, e) {
|
||
if (!$d) {
|
||
var i = new po({color: "rgba(255,255,255,0.4)"}), r = new go({color: "#3399CC", width: 1.25});
|
||
$d = [new Kd({image: new Zd({fill: i, stroke: r, radius: 5}), fill: i, stroke: r})]
|
||
}
|
||
return $d
|
||
}
|
||
|
||
function tf() {
|
||
var t = {}, e = [255, 255, 255, 1], i = [0, 153, 255, 1];
|
||
return t[Zt.POLYGON] = [new Kd({fill: new po({color: [255, 255, 255, .5]})})], t[Zt.MULTI_POLYGON] = t[Zt.POLYGON], t[Zt.LINE_STRING] = [new Kd({
|
||
stroke: new go({
|
||
color: e,
|
||
width: 5
|
||
})
|
||
}), new Kd({
|
||
stroke: new go({
|
||
color: i,
|
||
width: 3
|
||
})
|
||
})], t[Zt.MULTI_LINE_STRING] = t[Zt.LINE_STRING], t[Zt.CIRCLE] = t[Zt.POLYGON].concat(t[Zt.LINE_STRING]), t[Zt.POINT] = [new Kd({
|
||
image: new Zd({
|
||
radius: 6,
|
||
fill: new po({color: i}),
|
||
stroke: new go({color: e, width: 1.5})
|
||
}), zIndex: 1 / 0
|
||
})], t[Zt.MULTI_POINT] = t[Zt.POINT], t[Zt.GEOMETRY_COLLECTION] = t[Zt.POLYGON].concat(t[Zt.LINE_STRING], t[Zt.POINT]), t
|
||
}
|
||
|
||
function ef(t) {
|
||
return t.getGeometry()
|
||
}
|
||
|
||
var rf, of, nf, sf, af, lf, hf, uf = Kd, cf = ["http://www.google.com/kml/ext/2.2"],
|
||
pf = [null, "http://earth.google.com/kml/2.0", "http://earth.google.com/kml/2.1", "http://earth.google.com/kml/2.2", "http://www.opengis.net/kml/2.2"],
|
||
df = {fraction: zd.FRACTION, pixels: zd.PIXELS, insetPixels: zd.PIXELS}, ff = pp(pf, {
|
||
ExtendedData: ag,
|
||
Region: lg,
|
||
MultiGeometry: sp($f, "geometry"),
|
||
LineString: sp(Zf, "geometry"),
|
||
LinearRing: sp(Kf, "geometry"),
|
||
Point: sp(Qf, "geometry"),
|
||
Polygon: sp(eg, "geometry"),
|
||
Style: sp(rg),
|
||
StyleMap: function (t, e) {
|
||
var i = Ff(t, e);
|
||
if (!i) return;
|
||
var r = e[e.length - 1];
|
||
Array.isArray(i) ? r.Style = i : "string" == typeof i ? r.styleUrl = i : W(!1, 38)
|
||
},
|
||
address: sp(Lp),
|
||
description: sp(Lp),
|
||
name: sp(Lp),
|
||
open: sp(bp),
|
||
phoneNumber: sp(Lp),
|
||
styleUrl: sp(Mf),
|
||
visibility: sp(bp)
|
||
}, pp(cf, {
|
||
MultiTrack: sp(function (t, e) {
|
||
var i = fp([], Bf, t, e);
|
||
if (!i) return;
|
||
return new Dc(i)
|
||
}, "geometry"), Track: sp(Yf, "geometry")
|
||
})), gf = pp(pf, {
|
||
ExtendedData: ag, Region: lg, Link: function (t, e) {
|
||
dp(mf, t, e)
|
||
}, address: sp(Lp), description: sp(Lp), name: sp(Lp), open: sp(bp), phoneNumber: sp(Lp), visibility: sp(bp)
|
||
}), mf = pp(pf, {href: sp(Mf)}), yf = pp(pf, {
|
||
LatLonAltBox: function (t, e) {
|
||
var i = fp({}, cg, t, e);
|
||
if (!i) return;
|
||
var r = e[e.length - 1],
|
||
o = [parseFloat(i.west), parseFloat(i.south), parseFloat(i.east), parseFloat(i.north)];
|
||
r.extent = o, r.altitudeMode = i.altitudeMode, r.minAltitude = parseFloat(i.minAltitude), r.maxAltitude = parseFloat(i.maxAltitude)
|
||
}, Lod: function (t, e) {
|
||
var i = fp({}, pg, t, e);
|
||
if (!i) return;
|
||
var r = e[e.length - 1];
|
||
r.minLodPixels = parseFloat(i.minLodPixels), r.maxLodPixels = parseFloat(i.maxLodPixels), r.minFadeExtent = parseFloat(i.minFadeExtent), r.maxFadeExtent = parseFloat(i.maxFadeExtent)
|
||
}
|
||
}), vf = pp(pf, ["Document", "Placemark"]), _f = pp(pf, {
|
||
Document: ap(function (t, e, i) {
|
||
mp({node: t}, yg, vg, e, i, void 0, this)
|
||
}), Placemark: ap(Bg)
|
||
}), xf = null;
|
||
var wf, bf = null;
|
||
var Cf, Sf = null;
|
||
var Ef = null;
|
||
var Tf = null;
|
||
var Rf = null;
|
||
var Pf = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = e || {};
|
||
Rf || (xf = new po({color: rf = [255, 255, 255, 1]}), of = [20, 2], nf = zd.PIXELS, sf = zd.PIXELS, af = [64, 64], lf = "https://maps.google.com/mapfiles/kml/pushpin/ylw-pushpin.png", hf = .5, bf = new Xd({
|
||
anchor: of,
|
||
anchorOrigin: Yd.BOTTOM_LEFT,
|
||
anchorXUnits: nf,
|
||
anchorYUnits: sf,
|
||
crossOrigin: "anonymous",
|
||
rotation: 0,
|
||
scale: hf,
|
||
size: af,
|
||
src: lf
|
||
}), wf = "NO_IMAGE", Sf = new go({color: rf, width: 1}), Cf = new go({
|
||
color: [51, 51, 51, 1],
|
||
width: 2
|
||
}), Ef = new vo({font: "bold 16px Helvetica", fill: xf, stroke: Cf, scale: .8}), Tf = new uf({
|
||
fill: xf,
|
||
image: bf,
|
||
text: Ef,
|
||
stroke: Sf,
|
||
zIndex: 0
|
||
}), Rf = [Tf]), this.dataProjection = We("EPSG:4326"), this.defaultStyle_ = i.defaultStyle ? i.defaultStyle : Rf, this.extractStyles_ = void 0 === i.extractStyles || i.extractStyles, this.writeStyles_ = void 0 === i.writeStyles || i.writeStyles, this.sharedStyles_ = {}, this.showPointNames_ = void 0 === i.showPointNames || i.showPointNames
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.readDocumentOrFolder_ = function (t, e) {
|
||
var i = fp([], pp(pf, {
|
||
Document: ip(this.readDocumentOrFolder_, this),
|
||
Folder: ip(this.readDocumentOrFolder_, this),
|
||
Placemark: rp(this.readPlacemark_, this),
|
||
Style: this.readSharedStyle_.bind(this),
|
||
StyleMap: this.readSharedStyleMap_.bind(this)
|
||
}), t, e, this);
|
||
return i || void 0
|
||
}, e.prototype.readPlacemark_ = function (t, e) {
|
||
var i = fp({geometry: null}, ff, t, e);
|
||
if (i) {
|
||
var r = new X, o = t.getAttribute("id");
|
||
null !== o && r.setId(o);
|
||
var n = e[0], s = i.geometry;
|
||
if (s && kc(s, !1, n), r.setGeometry(s), delete i.geometry, this.extractStyles_) {
|
||
var a = function (t, e, i, r, o) {
|
||
return function (n, s) {
|
||
var a, l = o, h = "";
|
||
if (l) {
|
||
var u = n.getGeometry();
|
||
u && (l = u.getType() === Zt.POINT)
|
||
}
|
||
if (l && (h = n.get("name"), l = l && !!h), t) return l ? (a = Lf(t[0], h), t.concat(a)) : t;
|
||
if (e) {
|
||
var c = function t(e, i, r) {
|
||
return Array.isArray(e) ? e : "string" == typeof e ? (!(e in r) && "#" + e in r && (e = "#" + e), t(r[e], i, r)) : i
|
||
}(e, i, r);
|
||
return l ? (a = Lf(c[0], h), c.concat(a)) : c
|
||
}
|
||
return l ? (a = Lf(i[0], h), i.concat(a)) : i
|
||
}
|
||
}(i.Style, i.styleUrl, this.defaultStyle_, this.sharedStyles_, this.showPointNames_);
|
||
r.setStyle(a)
|
||
}
|
||
return delete i.Style, r.setProperties(i), r
|
||
}
|
||
}, e.prototype.readSharedStyle_ = function (t, e) {
|
||
var i = t.getAttribute("id");
|
||
if (null !== i) {
|
||
var r = rg(t, e);
|
||
if (r) {
|
||
var o, n = t.baseURI;
|
||
if (n && "about:blank" != n || (n = window.location.href), n) o = new URL("#" + i, n).href; else o = "#" + i;
|
||
this.sharedStyles_[o] = r
|
||
}
|
||
}
|
||
}, e.prototype.readSharedStyleMap_ = function (t, e) {
|
||
var i = t.getAttribute("id");
|
||
if (null !== i) {
|
||
var r = Ff(t, e);
|
||
if (r) {
|
||
var o, n = t.baseURI;
|
||
if (n && "about:blank" != n || (n = window.location.href), n) o = new URL("#" + i, n).href; else o = "#" + i;
|
||
this.sharedStyles_[o] = r
|
||
}
|
||
}
|
||
}, e.prototype.readFeatureFromNode = function (t, e) {
|
||
if (!K(pf, t.namespaceURI)) return null;
|
||
var i = this.readPlacemark_(t, [this.getReadOptions(t, e)]);
|
||
return i || null
|
||
}, e.prototype.readFeaturesFromNode = function (t, e) {
|
||
if (!K(pf, t.namespaceURI)) return [];
|
||
var i, r = t.localName;
|
||
if ("Document" == r || "Folder" == r) return (i = this.readDocumentOrFolder_(t, [this.getReadOptions(t, e)])) || [];
|
||
if ("Placemark" == r) {
|
||
var o = this.readPlacemark_(t, [this.getReadOptions(t, e)]);
|
||
return o ? [o] : []
|
||
}
|
||
if ("kml" == r) {
|
||
i = [];
|
||
for (var n = t.firstElementChild; n; n = n.nextElementSibling) {
|
||
var s = this.readFeaturesFromNode(n, e);
|
||
s && Q(i, s)
|
||
}
|
||
return i
|
||
}
|
||
return []
|
||
}, e.prototype.readName = function (t) {
|
||
if (t) {
|
||
if ("string" == typeof t) {
|
||
var e = ep(t);
|
||
return this.readNameFromDocument(e)
|
||
}
|
||
return Qc(t) ? this.readNameFromDocument(t) : this.readNameFromNode(t)
|
||
}
|
||
}, e.prototype.readNameFromDocument = function (t) {
|
||
for (var e = t.firstChild; e; e = e.nextSibling) if (e.nodeType == Node.ELEMENT_NODE) {
|
||
var i = this.readNameFromNode(e);
|
||
if (i) return i
|
||
}
|
||
}, e.prototype.readNameFromNode = function (t) {
|
||
for (var e = t.firstElementChild; e; e = e.nextElementSibling) if (K(pf, e.namespaceURI) && "name" == e.localName) return Lp(e);
|
||
for (var i = t.firstElementChild; i; i = i.nextElementSibling) {
|
||
var r = i.localName;
|
||
if (K(pf, i.namespaceURI) && ("Document" == r || "Folder" == r || "Placemark" == r || "kml" == r)) {
|
||
var o = this.readNameFromNode(i);
|
||
if (o) return o
|
||
}
|
||
}
|
||
}, e.prototype.readNetworkLinks = function (t) {
|
||
var e = [];
|
||
if ("string" == typeof t) {
|
||
var i = ep(t);
|
||
Q(e, this.readNetworkLinksFromDocument(i))
|
||
} else Qc(t) ? Q(e, this.readNetworkLinksFromDocument(t)) : Q(e, this.readNetworkLinksFromNode(t));
|
||
return e
|
||
}, e.prototype.readNetworkLinksFromDocument = function (t) {
|
||
for (var e = [], i = t.firstChild; i; i = i.nextSibling) i.nodeType == Node.ELEMENT_NODE && Q(e, this.readNetworkLinksFromNode(i));
|
||
return e
|
||
}, e.prototype.readNetworkLinksFromNode = function (t) {
|
||
for (var e = [], i = t.firstElementChild; i; i = i.nextElementSibling) if (K(pf, i.namespaceURI) && "NetworkLink" == i.localName) {
|
||
var r = fp({}, gf, i, []);
|
||
e.push(r)
|
||
}
|
||
for (var o = t.firstElementChild; o; o = o.nextElementSibling) {
|
||
var n = o.localName;
|
||
!K(pf, o.namespaceURI) || "Document" != n && "Folder" != n && "kml" != n || Q(e, this.readNetworkLinksFromNode(o))
|
||
}
|
||
return e
|
||
}, e.prototype.readRegion = function (t) {
|
||
var e = [];
|
||
if ("string" == typeof t) {
|
||
var i = ep(t);
|
||
Q(e, this.readRegionFromDocument(i))
|
||
} else Qc(t) ? Q(e, this.readRegionFromDocument(t)) : Q(e, this.readRegionFromNode(t));
|
||
return e
|
||
}, e.prototype.readRegionFromDocument = function (t) {
|
||
for (var e = [], i = t.firstChild; i; i = i.nextSibling) i.nodeType == Node.ELEMENT_NODE && Q(e, this.readRegionFromNode(i));
|
||
return e
|
||
}, e.prototype.readRegionFromNode = function (t) {
|
||
for (var e = [], i = t.firstElementChild; i; i = i.nextElementSibling) if (K(pf, i.namespaceURI) && "Region" == i.localName) {
|
||
var r = fp({}, yf, i, []);
|
||
e.push(r)
|
||
}
|
||
for (var o = t.firstElementChild; o; o = o.nextElementSibling) {
|
||
var n = o.localName;
|
||
!K(pf, o.namespaceURI) || "Document" != n && "Folder" != n && "kml" != n || Q(e, this.readRegionFromNode(o))
|
||
}
|
||
return e
|
||
}, e.prototype.writeFeaturesNode = function (t, e) {
|
||
e = this.adaptOptions(e);
|
||
var i = Kc(pf[4], "kml"), r = "http://www.w3.org/2000/xmlns/";
|
||
i.setAttributeNS(r, "xmlns:gx", cf[0]), i.setAttributeNS(r, "xmlns:xsi", Zc), i.setAttributeNS(Zc, "xsi:schemaLocation", "http://www.opengis.net/kml/2.2 https://developers.google.com/kml/schema/kml22gx.xsd");
|
||
var o = {node: i}, n = {};
|
||
t.length > 1 ? n.Document = t : 1 == t.length && (n.Placemark = t[0]);
|
||
var s = vf[i.namespaceURI], a = cp(n, s);
|
||
return mp(o, _f, up, a, [e], s, this), i
|
||
}, e
|
||
}(yp);
|
||
|
||
function Lf(t, e) {
|
||
var i = null, r = [0, 0], o = "start";
|
||
if (t.getImage()) {
|
||
var n = t.getImage().getImageSize();
|
||
if (null === n && (n = af), 2 == n.length) {
|
||
var s = t.getImage().getScale();
|
||
r[0] = s * n[0] / 2, r[1] = -s * n[1] / 2, o = "left"
|
||
}
|
||
}
|
||
if (null !== t.getText()) {
|
||
var a = t.getText();
|
||
(i = a.clone()).setFont(a.getFont() || Ef.getFont()), i.setScale(a.getScale() || Ef.getScale()), i.setFill(a.getFill() || Ef.getFill()), i.setStroke(a.getStroke() || Cf)
|
||
} else i = Ef.clone();
|
||
return i.setText(e), i.setOffsetX(r[0]), i.setOffsetY(r[1]), i.setTextAlign(o), new uf({text: i})
|
||
}
|
||
|
||
function If(t) {
|
||
var e = Jc(t, !1), i = /^\s*#?\s*([0-9A-Fa-f]{8})\s*$/.exec(e);
|
||
if (i) {
|
||
var r = i[1];
|
||
return [parseInt(r.substr(6, 2), 16), parseInt(r.substr(4, 2), 16), parseInt(r.substr(2, 2), 16), parseInt(r.substr(0, 2), 16) / 255]
|
||
}
|
||
}
|
||
|
||
function Of(t) {
|
||
for (var e, i = Jc(t, !1), r = [], o = /^\s*([+\-]?\d*\.?\d+(?:e[+\-]?\d+)?)\s*,\s*([+\-]?\d*\.?\d+(?:e[+\-]?\d+)?)(?:\s*,\s*([+\-]?\d*\.?\d+(?:e[+\-]?\d+)?))?\s*/i; e = o.exec(i);) {
|
||
var n = parseFloat(e[1]), s = parseFloat(e[2]), a = e[3] ? parseFloat(e[3]) : 0;
|
||
r.push(n, s, a), i = i.substr(e[0].length)
|
||
}
|
||
if ("" === i) return r
|
||
}
|
||
|
||
function Mf(t) {
|
||
var e = Jc(t, !1).trim(), i = t.baseURI;
|
||
return i && "about:blank" != i || (i = window.location.href), i ? new URL(e, i).href : e
|
||
}
|
||
|
||
function Af(t) {
|
||
return Ep(t)
|
||
}
|
||
|
||
var kf = pp(pf, {
|
||
Pair: function (t, e) {
|
||
var i = fp({}, hg, t, e);
|
||
if (!i) return;
|
||
var r = i.key;
|
||
if (r && "normal" == r) {
|
||
var o = i.styleUrl;
|
||
o && (e[e.length - 1] = o);
|
||
var n = i.Style;
|
||
n && (e[e.length - 1] = n)
|
||
}
|
||
}
|
||
});
|
||
|
||
function Ff(t, e) {
|
||
return fp(void 0, kf, t, e)
|
||
}
|
||
|
||
var Nf = pp(pf, {
|
||
Icon: sp(function (t, e) {
|
||
var i = fp({}, Wf, t, e);
|
||
return i || null
|
||
}), heading: sp(Ep), hotSpot: sp(function (t) {
|
||
var e, i = t.getAttribute("xunits"), r = t.getAttribute("yunits");
|
||
return e = "insetPixels" !== i ? "insetPixels" !== r ? Yd.BOTTOM_LEFT : Yd.TOP_LEFT : "insetPixels" !== r ? Yd.BOTTOM_RIGHT : Yd.TOP_RIGHT, {
|
||
x: parseFloat(t.getAttribute("x")),
|
||
xunits: df[i],
|
||
y: parseFloat(t.getAttribute("y")),
|
||
yunits: df[r],
|
||
origin: e
|
||
}
|
||
}), scale: sp(Af)
|
||
});
|
||
var Df = pp(pf, {color: sp(If), scale: sp(Af)});
|
||
var Gf = pp(pf, {color: sp(If), width: sp(Ep)});
|
||
var jf = pp(pf, {color: sp(If), fill: sp(bp), outline: sp(bp)});
|
||
var zf = pp(pf, {coordinates: op(Of)});
|
||
|
||
function Uf(t, e) {
|
||
return fp(null, zf, t, e)
|
||
}
|
||
|
||
var Bf = pp(cf, {Track: rp(Yf)});
|
||
var Vf = pp(pf, {
|
||
when: function (t, e) {
|
||
var i = e[e.length - 1].whens, r = Jc(t, !1), o = Date.parse(r);
|
||
i.push(isNaN(o) ? 0 : o)
|
||
}
|
||
}, pp(cf, {
|
||
coord: function (t, e) {
|
||
var i = e[e.length - 1].flatCoordinates, r = Jc(t, !1),
|
||
o = /^\s*([+\-]?\d+(?:\.\d*)?(?:e[+\-]?\d*)?)\s+([+\-]?\d+(?:\.\d*)?(?:e[+\-]?\d*)?)\s+([+\-]?\d+(?:\.\d*)?(?:e[+\-]?\d*)?)\s*$/i.exec(r);
|
||
if (o) {
|
||
var n = parseFloat(o[1]), s = parseFloat(o[2]), a = parseFloat(o[3]);
|
||
i.push(n, s, a, 0)
|
||
} else i.push(0, 0, 0, 0)
|
||
}
|
||
}));
|
||
|
||
function Yf(t, e) {
|
||
var i = fp({flatCoordinates: [], whens: []}, Vf, t, e);
|
||
if (i) {
|
||
for (var r = i.flatCoordinates, o = i.whens, n = 0, s = Math.min(r.length, o.length); n < s; ++n) r[4 * n + 3] = o[n];
|
||
return new Jr(r, qt.XYZM)
|
||
}
|
||
}
|
||
|
||
var Wf = pp(pf, {href: sp(Mf)}, pp(cf, {x: sp(Ep), y: sp(Ep), w: sp(Ep), h: sp(Ep)}));
|
||
var Hf = pp(pf, {coordinates: op(Of)});
|
||
|
||
function Xf(t, e) {
|
||
return fp(null, Hf, t, e)
|
||
}
|
||
|
||
var qf = pp(pf, {extrude: sp(bp), tessellate: sp(bp), altitudeMode: sp(Lp)});
|
||
|
||
function Zf(t, e) {
|
||
var i = fp({}, qf, t, e), r = Xf(t, e);
|
||
if (r) {
|
||
var o = new Jr(r, qt.XYZ);
|
||
return o.setProperties(i), o
|
||
}
|
||
}
|
||
|
||
function Kf(t, e) {
|
||
var i = fp({}, qf, t, e), r = Xf(t, e);
|
||
if (r) {
|
||
var o = new fr(r, qt.XYZ, [r.length]);
|
||
return o.setProperties(i), o
|
||
}
|
||
}
|
||
|
||
var Jf = pp(pf, {
|
||
LineString: rp(Zf),
|
||
LinearRing: rp(Kf),
|
||
MultiGeometry: rp($f),
|
||
Point: rp(Qf),
|
||
Polygon: rp(eg)
|
||
});
|
||
|
||
function $f(t, e) {
|
||
var i, r = fp([], Jf, t, e);
|
||
if (!r) return null;
|
||
if (0 === r.length) return new Pd(r);
|
||
for (var o, n, s = !0, a = r[0].getType(), l = 1, h = r.length; l < h; ++l) if (r[l].getType() != a) {
|
||
s = !1;
|
||
break
|
||
}
|
||
if (s) if (a == Zt.POINT) {
|
||
var u = r[0];
|
||
o = u.getLayout(), n = u.getFlatCoordinates();
|
||
for (var c = 1, p = r.length; c < p; ++c) Q(n, r[c].getFlatCoordinates());
|
||
og(i = new Gc(n, o), r)
|
||
} else a == Zt.LINE_STRING ? og(i = new Dc(r), r) : a == Zt.POLYGON ? og(i = new zc(r), r) : a == Zt.GEOMETRY_COLLECTION ? i = new Pd(r) : W(!1, 37); else i = new Pd(r);
|
||
return i
|
||
}
|
||
|
||
function Qf(t, e) {
|
||
var i = fp({}, qf, t, e), r = Xf(t, e);
|
||
if (r) {
|
||
var o = new qi(r, qt.XYZ);
|
||
return o.setProperties(i), o
|
||
}
|
||
}
|
||
|
||
var tg = pp(pf, {
|
||
innerBoundaryIs: function (t, e) {
|
||
var i = fp(void 0, dg, t, e);
|
||
if (i) {
|
||
var r = e[e.length - 1];
|
||
r.push(i)
|
||
}
|
||
}, outerBoundaryIs: function (t, e) {
|
||
var i = fp(void 0, fg, t, e);
|
||
if (i) {
|
||
var r = e[e.length - 1];
|
||
r[0] = i
|
||
}
|
||
}
|
||
});
|
||
|
||
function eg(t, e) {
|
||
var i = fp({}, qf, t, e), r = fp([null], tg, t, e);
|
||
if (r && r[0]) {
|
||
for (var o = r[0], n = [o.length], s = 1, a = r.length; s < a; ++s) Q(o, r[s]), n.push(o.length);
|
||
var l = new fr(o, qt.XYZ, n);
|
||
return l.setProperties(i), l
|
||
}
|
||
}
|
||
|
||
var ig = pp(pf, {
|
||
IconStyle: function (t, e) {
|
||
var i = fp({}, Nf, t, e);
|
||
if (i) {
|
||
var r, o, n, s, a = e[e.length - 1], l = "Icon" in i ? i.Icon : {},
|
||
h = !("Icon" in i) || Object.keys(l).length > 0, u = l.href;
|
||
u ? r = u : h && (r = lf);
|
||
var c, p = Yd.BOTTOM_LEFT, d = i.hotSpot;
|
||
d ? (o = [d.x, d.y], n = d.xunits, s = d.yunits, p = d.origin) : r === lf ? (o = of, n = nf, s = sf) : /^http:\/\/maps\.(?:google|gstatic)\.com\//.test(r) && (o = [.5, 0], n = zd.FRACTION, s = zd.FRACTION);
|
||
var f, g = l.x, m = l.y;
|
||
void 0 !== g && void 0 !== m && (c = [g, m]);
|
||
var y, v = l.w, _ = l.h;
|
||
void 0 !== v && void 0 !== _ && (f = [v, _]);
|
||
var x = i.heading;
|
||
void 0 !== x && (y = ae(x));
|
||
var w = i.scale;
|
||
if (h) {
|
||
r == lf && (f = af, void 0 === w && (w = hf));
|
||
var b = new Xd({
|
||
anchor: o,
|
||
anchorOrigin: p,
|
||
anchorXUnits: n,
|
||
anchorYUnits: s,
|
||
crossOrigin: "anonymous",
|
||
offset: c,
|
||
offsetOrigin: Yd.BOTTOM_LEFT,
|
||
rotation: y,
|
||
scale: w,
|
||
size: f,
|
||
src: r
|
||
});
|
||
a.imageStyle = b
|
||
} else a.imageStyle = wf
|
||
}
|
||
}, LabelStyle: function (t, e) {
|
||
var i = fp({}, Df, t, e);
|
||
if (i) {
|
||
var r = e[e.length - 1],
|
||
o = new vo({fill: new po({color: "color" in i ? i.color : rf}), scale: i.scale});
|
||
r.textStyle = o
|
||
}
|
||
}, LineStyle: function (t, e) {
|
||
var i = fp({}, Gf, t, e);
|
||
if (i) {
|
||
var r = e[e.length - 1],
|
||
o = new go({color: "color" in i ? i.color : rf, width: "width" in i ? i.width : 1});
|
||
r.strokeStyle = o
|
||
}
|
||
}, PolyStyle: function (t, e) {
|
||
var i = fp({}, jf, t, e);
|
||
if (i) {
|
||
var r = e[e.length - 1], o = new po({color: "color" in i ? i.color : rf});
|
||
r.fillStyle = o;
|
||
var n = i.fill;
|
||
void 0 !== n && (r.fill = n);
|
||
var s = i.outline;
|
||
void 0 !== s && (r.outline = s)
|
||
}
|
||
}
|
||
});
|
||
|
||
function rg(t, e) {
|
||
var i = fp({}, ig, t, e);
|
||
if (!i) return null;
|
||
var r, o = "fillStyle" in i ? i.fillStyle : xf, n = i.fill;
|
||
void 0 === n || n || (o = null), "imageStyle" in i ? i.imageStyle != wf && (r = i.imageStyle) : r = bf;
|
||
var s = "textStyle" in i ? i.textStyle : Ef, a = "strokeStyle" in i ? i.strokeStyle : Sf, l = i.outline;
|
||
return void 0 === l || l || (a = null), [new uf({fill: o, image: r, stroke: a, text: s, zIndex: void 0})]
|
||
}
|
||
|
||
function og(t, e) {
|
||
var i, r, o, n = e.length, s = new Array(e.length), a = new Array(e.length), l = new Array(e.length);
|
||
i = r = o = !1;
|
||
for (var h = 0; h < n; ++h) {
|
||
var u = e[h];
|
||
s[h] = u.get("extrude"), a[h] = u.get("tessellate"), l[h] = u.get("altitudeMode"), i = i || void 0 !== s[h], r = r || void 0 !== a[h], o = o || l[h]
|
||
}
|
||
i && t.set("extrude", s), r && t.set("tessellate", a), o && t.set("altitudeMode", l)
|
||
}
|
||
|
||
var ng = pp(pf, {displayName: sp(Lp), value: sp(Lp)});
|
||
var sg = pp(pf, {
|
||
Data: function (t, e) {
|
||
var i = t.getAttribute("name");
|
||
dp(ng, t, e);
|
||
var r = e[e.length - 1];
|
||
null !== i ? r[i] = r.value : null !== r.displayName && (r[r.displayName] = r.value), delete r.value
|
||
}, SchemaData: function (t, e) {
|
||
dp(ug, t, e)
|
||
}
|
||
});
|
||
|
||
function ag(t, e) {
|
||
dp(sg, t, e)
|
||
}
|
||
|
||
function lg(t, e) {
|
||
dp(yf, t, e)
|
||
}
|
||
|
||
var hg = pp(pf, {Style: sp(rg), key: sp(Lp), styleUrl: sp(Mf)});
|
||
var ug = pp(pf, {
|
||
SimpleData: function (t, e) {
|
||
var i = t.getAttribute("name");
|
||
if (null !== i) {
|
||
var r = Lp(t), o = e[e.length - 1];
|
||
o[i] = r
|
||
}
|
||
}
|
||
});
|
||
var cg = pp(pf, {
|
||
altitudeMode: sp(Lp),
|
||
minAltitude: sp(Ep),
|
||
maxAltitude: sp(Ep),
|
||
north: sp(Ep),
|
||
south: sp(Ep),
|
||
east: sp(Ep),
|
||
west: sp(Ep)
|
||
});
|
||
var pg = pp(pf, {minLodPixels: sp(Ep), maxLodPixels: sp(Ep), minFadeExtent: sp(Ep), maxFadeExtent: sp(Ep)});
|
||
var dg = pp(pf, {LinearRing: op(Uf)});
|
||
var fg = pp(pf, {LinearRing: op(Uf)});
|
||
|
||
function gg(t, e) {
|
||
for (var i = lo(e), r = [255 * (4 == i.length ? i[3] : 1), i[2], i[1], i[0]], o = 0; o < 4; ++o) {
|
||
var n = Math.floor(r[o]).toString(16);
|
||
r[o] = 1 == n.length ? "0" + n : n
|
||
}
|
||
Fp(t, r.join(""))
|
||
}
|
||
|
||
var mg = pp(pf, {
|
||
Data: ap(function (t, e, i) {
|
||
t.setAttribute("name", e.name);
|
||
var r = {node: t}, o = e.value;
|
||
"object" == typeof o ? (null !== o && o.displayName && mp(r, mg, up, [o.displayName], i, ["displayName"]), null !== o && o.value && mp(r, mg, up, [o.value], i, ["value"])) : mp(r, mg, up, [o], i, ["value"])
|
||
}), value: ap(function (t, e) {
|
||
Fp(t, e)
|
||
}), displayName: ap(function (t, e) {
|
||
Op(t, e)
|
||
})
|
||
});
|
||
var yg = pp(pf, {Placemark: ap(Bg)}), vg = function (t, e, i) {
|
||
return Kc(e[e.length - 1].node.namespaceURI, "Placemark")
|
||
};
|
||
var _g = hp("Data");
|
||
var xg = pp(pf, ["href"], pp(cf, ["x", "y", "w", "h"])),
|
||
wg = pp(pf, {href: ap(Fp)}, pp(cf, {x: ap(Ap), y: ap(Ap), w: ap(Ap), h: ap(Ap)})), bg = function (t, e, i) {
|
||
return Kc(cf[0], "gx:" + i)
|
||
};
|
||
var Cg = pp(pf, ["scale", "heading", "Icon", "hotSpot"]), Sg = pp(pf, {
|
||
Icon: ap(function (t, e, i) {
|
||
var r = {node: t}, o = i[i.length - 1].node, n = xg[o.namespaceURI], s = cp(e, n);
|
||
mp(r, wg, up, s, i, n), s = cp(e, n = xg[cf[0]]), mp(r, wg, bg, s, i, n)
|
||
}), heading: ap(Ap), hotSpot: ap(function (t, e) {
|
||
t.setAttribute("x", String(e.x)), t.setAttribute("y", String(e.y)), t.setAttribute("xunits", e.xunits), t.setAttribute("yunits", e.yunits)
|
||
}), scale: ap($g)
|
||
});
|
||
var Eg = pp(pf, ["color", "scale"]), Tg = pp(pf, {color: ap(gg), scale: ap($g)});
|
||
var Rg = pp(pf, ["color", "width"]), Pg = pp(pf, {color: ap(gg), width: ap(Ap)});
|
||
var Lg = {
|
||
Point: "Point",
|
||
LineString: "LineString",
|
||
LinearRing: "LinearRing",
|
||
Polygon: "Polygon",
|
||
MultiPoint: "MultiGeometry",
|
||
MultiLineString: "MultiGeometry",
|
||
MultiPolygon: "MultiGeometry",
|
||
GeometryCollection: "MultiGeometry"
|
||
}, Ig = function (t, e, i) {
|
||
if (t) return Kc(e[e.length - 1].node.namespaceURI, Lg[t.getType()])
|
||
}, Og = hp("Point"), Mg = hp("LineString"), Ag = hp("LinearRing"), kg = hp("Polygon"),
|
||
Fg = pp(pf, {LineString: ap(Wg), Point: ap(Wg), Polygon: ap(Zg), GeometryCollection: ap(Ng)});
|
||
|
||
function Ng(t, e, i) {
|
||
var r, o, n = {node: t}, s = e.getType();
|
||
s == Zt.GEOMETRY_COLLECTION ? (r = e.getGeometries(), o = Ig) : s == Zt.MULTI_POINT ? (r = e.getPoints(), o = Og) : s == Zt.MULTI_LINE_STRING ? (r = e.getLineStrings(), o = Mg) : s == Zt.MULTI_POLYGON ? (r = e.getPolygons(), o = kg) : W(!1, 39), mp(n, Fg, o, r, i)
|
||
}
|
||
|
||
var Dg = pp(pf, {LinearRing: ap(Wg)});
|
||
|
||
function Gg(t, e, i) {
|
||
mp({node: t}, Dg, Ag, [e], i)
|
||
}
|
||
|
||
var jg = pp(pf, {
|
||
ExtendedData: ap(function (t, e, i) {
|
||
for (var r = {node: t}, o = e.names, n = e.values, s = o.length, a = 0; a < s; a++) mp(r, mg, _g, [{
|
||
name: o[a],
|
||
value: n[a]
|
||
}], i)
|
||
}),
|
||
MultiGeometry: ap(Ng),
|
||
LineString: ap(Wg),
|
||
LinearRing: ap(Wg),
|
||
Point: ap(Wg),
|
||
Polygon: ap(Zg),
|
||
Style: ap(function (t, e, i) {
|
||
var r = {node: t}, o = {}, n = e.getFill(), s = e.getStroke(), a = e.getImage(), l = e.getText();
|
||
a && "function" == typeof a.getSrc && (o.IconStyle = a);
|
||
l && (o.LabelStyle = l);
|
||
s && (o.LineStyle = s);
|
||
n && (o.PolyStyle = n);
|
||
var h = i[i.length - 1].node, u = Qg[h.namespaceURI], c = cp(o, u);
|
||
mp(r, tm, up, c, i, u)
|
||
}),
|
||
address: ap(Fp),
|
||
description: ap(Fp),
|
||
name: ap(Fp),
|
||
open: ap(Ip),
|
||
phoneNumber: ap(Fp),
|
||
styleUrl: ap(Fp),
|
||
visibility: ap(Ip)
|
||
}), zg = pp(pf, ["name", "open", "visibility", "address", "phoneNumber", "description", "styleUrl", "Style"]),
|
||
Ug = hp("ExtendedData");
|
||
|
||
function Bg(t, e, i) {
|
||
var r = {node: t};
|
||
e.getId() && t.setAttribute("id", e.getId());
|
||
var o = e.getProperties(),
|
||
n = {address: 1, description: 1, name: 1, open: 1, phoneNumber: 1, styleUrl: 1, visibility: 1};
|
||
n[e.getGeometryName()] = 1;
|
||
var s = Object.keys(o || {}).sort().filter(function (t) {
|
||
return !n[t]
|
||
});
|
||
if (s.length > 0) {
|
||
var a = cp(o, s);
|
||
mp(r, jg, Ug, [{names: s, values: a}], i)
|
||
}
|
||
var l = e.getStyleFunction();
|
||
if (l) {
|
||
var h = l(e, 0);
|
||
if (h) {
|
||
var u = Array.isArray(h) ? h[0] : h;
|
||
this.writeStyles_ && (o.Style = u);
|
||
var c = u.getText();
|
||
c && (o.name = c.getText())
|
||
}
|
||
}
|
||
var p = i[i.length - 1].node, d = zg[p.namespaceURI], f = cp(o, d);
|
||
mp(r, jg, up, f, i, d);
|
||
var g = i[0], m = e.getGeometry();
|
||
m && (m = kc(m, !0, g)), mp(r, jg, Ig, [m], i)
|
||
}
|
||
|
||
var Vg = pp(pf, ["extrude", "tessellate", "altitudeMode", "coordinates"]), Yg = pp(pf, {
|
||
extrude: ap(Ip), tessellate: ap(Ip), altitudeMode: ap(Fp), coordinates: ap(function (t, e, i) {
|
||
var r, o = i[i.length - 1], n = o.layout, s = o.stride;
|
||
n == qt.XY || n == qt.XYM ? r = 2 : n == qt.XYZ || n == qt.XYZM ? r = 3 : W(!1, 34);
|
||
var a = e.length, l = "";
|
||
if (a > 0) {
|
||
l += e[0];
|
||
for (var h = 1; h < r; ++h) l += "," + e[h];
|
||
for (var u = s; u < a; u += s) {
|
||
l += " " + e[u];
|
||
for (var c = 1; c < r; ++c) l += "," + e[u + c]
|
||
}
|
||
}
|
||
Fp(t, l)
|
||
})
|
||
});
|
||
|
||
function Wg(t, e, i) {
|
||
var r = e.getFlatCoordinates(), o = {node: t};
|
||
o.layout = e.getLayout(), o.stride = e.getStride();
|
||
var n = e.getProperties();
|
||
n.coordinates = r;
|
||
var s = i[i.length - 1].node, a = Vg[s.namespaceURI], l = cp(n, a);
|
||
mp(o, Yg, up, l, i, a)
|
||
}
|
||
|
||
var Hg = pp(pf, {outerBoundaryIs: ap(Gg), innerBoundaryIs: ap(Gg)}), Xg = hp("innerBoundaryIs"),
|
||
qg = hp("outerBoundaryIs");
|
||
|
||
function Zg(t, e, i) {
|
||
var r = e.getLinearRings(), o = r.shift(), n = {node: t};
|
||
mp(n, Hg, Xg, r, i), mp(n, Hg, qg, [o], i)
|
||
}
|
||
|
||
var Kg = pp(pf, {color: ap(gg)}), Jg = hp("color");
|
||
|
||
function $g(t, e) {
|
||
Ap(t, Math.round(1e6 * e) / 1e6)
|
||
}
|
||
|
||
var Qg = pp(pf, ["IconStyle", "LabelStyle", "LineStyle", "PolyStyle"]), tm = pp(pf, {
|
||
IconStyle: ap(function (t, e, i) {
|
||
var r = {node: t}, o = {}, n = e.getSrc(), s = e.getSize(), a = e.getImageSize(), l = {href: n};
|
||
if (s) {
|
||
l.w = s[0], l.h = s[1];
|
||
var h = e.getAnchor(), u = e.getOrigin();
|
||
if (u && a && 0 !== u[0] && u[1] !== s[1] && (l.x = u[0], l.y = a[1] - (u[1] + s[1])), h && (h[0] !== s[0] / 2 || h[1] !== s[1] / 2)) {
|
||
var c = {x: h[0], xunits: zd.PIXELS, y: s[1] - h[1], yunits: zd.PIXELS};
|
||
o.hotSpot = c
|
||
}
|
||
}
|
||
o.Icon = l;
|
||
var p = e.getScale();
|
||
1 !== p && (o.scale = p);
|
||
var d = e.getRotation();
|
||
0 !== d && (o.heading = d);
|
||
var f = i[i.length - 1].node, g = Cg[f.namespaceURI], m = cp(o, g);
|
||
mp(r, Sg, up, m, i, g)
|
||
}), LabelStyle: ap(function (t, e, i) {
|
||
var r = {node: t}, o = {}, n = e.getFill();
|
||
n && (o.color = n.getColor());
|
||
var s = e.getScale();
|
||
s && 1 !== s && (o.scale = s);
|
||
var a = i[i.length - 1].node, l = Eg[a.namespaceURI], h = cp(o, l);
|
||
mp(r, Tg, up, h, i, l)
|
||
}), LineStyle: ap(function (t, e, i) {
|
||
var r = {node: t}, o = {color: e.getColor(), width: e.getWidth()}, n = i[i.length - 1].node,
|
||
s = Rg[n.namespaceURI], a = cp(o, s);
|
||
mp(r, Pg, up, a, i, s)
|
||
}), PolyStyle: ap(function (t, e, i) {
|
||
mp({node: t}, Kg, Jg, [e.getColor()], i)
|
||
})
|
||
});
|
||
var em = Pf, im = i(9), rm = i.n(im), om = [1, 0, 0, 1, 0, 0], nm = function (t, e, i, r, o) {
|
||
this.extent_, this.id_ = o, this.type_ = t, this.flatCoordinates_ = e, this.flatInteriorPoints_ = null, this.flatMidpoints_ = null, this.ends_ = i, this.properties_ = r
|
||
};
|
||
nm.prototype.get = function (t) {
|
||
return this.properties_[t]
|
||
}, nm.prototype.getExtent = function () {
|
||
return this.extent_ || (this.extent_ = this.type_ === Zt.POINT ? _t(this.flatCoordinates_) : wt(this.flatCoordinates_, 0, this.flatCoordinates_.length, 2)), this.extent_
|
||
}, nm.prototype.getFlatInteriorPoint = function () {
|
||
if (!this.flatInteriorPoints_) {
|
||
var t = At(this.getExtent());
|
||
this.flatInteriorPoints_ = Qi(this.flatCoordinates_, 0, this.ends_, 2, t, 0)
|
||
}
|
||
return this.flatInteriorPoints_
|
||
}, nm.prototype.getFlatInteriorPoints = function () {
|
||
if (!this.flatInteriorPoints_) {
|
||
var t = jc(this.flatCoordinates_, 0, this.ends_, 2);
|
||
this.flatInteriorPoints_ = tr(this.flatCoordinates_, 0, this.ends_, 2, t)
|
||
}
|
||
return this.flatInteriorPoints_
|
||
}, nm.prototype.getFlatMidpoint = function () {
|
||
return this.flatMidpoints_ || (this.flatMidpoints_ = Xr(this.flatCoordinates_, 0, this.flatCoordinates_.length, 2, .5)), this.flatMidpoints_
|
||
}, nm.prototype.getFlatMidpoints = function () {
|
||
if (!this.flatMidpoints_) {
|
||
this.flatMidpoints_ = [];
|
||
for (var t = this.flatCoordinates_, e = 0, i = this.ends_, r = 0, o = i.length; r < o; ++r) {
|
||
var n = i[r], s = Xr(t, e, n, 2, .5);
|
||
Q(this.flatMidpoints_, s), e = n
|
||
}
|
||
}
|
||
return this.flatMidpoints_
|
||
}, nm.prototype.getId = function () {
|
||
return this.id_
|
||
}, nm.prototype.getOrientedFlatCoordinates = function () {
|
||
return this.flatCoordinates_
|
||
}, nm.prototype.getGeometry = function () {
|
||
return this
|
||
}, nm.prototype.getSimplifiedGeometry = function (t) {
|
||
return this
|
||
}, nm.prototype.getProperties = function () {
|
||
return this.properties_
|
||
}, nm.prototype.getStride = function () {
|
||
return 2
|
||
}, nm.prototype.getStyleFunction = function () {
|
||
}, nm.prototype.getType = function () {
|
||
return this.type_
|
||
}, nm.prototype.transform = function (t, e) {
|
||
var i = (t = We(t)).getExtent(), r = t.getWorldExtent(), o = Nt(r) / Nt(i);
|
||
gi(om, r[0], r[3], o, -o, 0, 0, 0), Kt(this.flatCoordinates_, 0, this.flatCoordinates_.length, 2, om, this.flatCoordinates_)
|
||
}, nm.prototype.getEnds = nm.prototype.getEndss = function () {
|
||
return this.ends_
|
||
}, nm.prototype.getFlatCoordinates = nm.prototype.getOrientedFlatCoordinates;
|
||
var sm = nm;
|
||
|
||
function am(t, e, i) {
|
||
if (3 === t) {
|
||
var r = {keys: [], values: [], features: []}, o = i.readVarint() + i.pos;
|
||
i.readFields(lm, r, o), r.length = r.features.length, r.length && (e[r.name] = r)
|
||
}
|
||
}
|
||
|
||
function lm(t, e, i) {
|
||
if (15 === t) e.version = i.readVarint(); else if (1 === t) e.name = i.readString(); else if (5 === t) e.extent = i.readVarint(); else if (2 === t) e.features.push(i.pos); else if (3 === t) e.keys.push(i.readString()); else if (4 === t) {
|
||
for (var r = null, o = i.readVarint() + i.pos; i.pos < o;) r = 1 === (t = i.readVarint() >> 3) ? i.readString() : 2 === t ? i.readFloat() : 3 === t ? i.readDouble() : 4 === t ? i.readVarint64() : 5 === t ? i.readVarint() : 6 === t ? i.readSVarint() : 7 === t ? i.readBoolean() : null;
|
||
e.values.push(r)
|
||
}
|
||
}
|
||
|
||
function hm(t, e, i) {
|
||
if (1 == t) e.id = i.readVarint(); else if (2 == t) for (var r = i.readVarint() + i.pos; i.pos < r;) {
|
||
var o = e.layer.keys[i.readVarint()], n = e.layer.values[i.readVarint()];
|
||
e.properties[o] = n
|
||
} else 3 == t ? e.type = i.readVarint() : 4 == t && (e.geometry = i.pos)
|
||
}
|
||
|
||
function um(t, e, i) {
|
||
t.pos = e.features[i];
|
||
var r = t.readVarint() + t.pos, o = {layer: e, type: 0, properties: {}};
|
||
return t.readFields(hm, o, r), o
|
||
}
|
||
|
||
var cm = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = e || {};
|
||
this.dataProjection = new xe({
|
||
code: "",
|
||
units: ve.TILE_PIXELS
|
||
}), this.featureClass_ = i.featureClass ? i.featureClass : sm, this.geometryName_ = i.geometryName, this.layerName_ = i.layerName ? i.layerName : "layer", this.layers_ = i.layers ? i.layers : null, this.extent_ = null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.readRawGeometry_ = function (t, e, i, r) {
|
||
t.pos = e.geometry;
|
||
for (var o = t.readVarint() + t.pos, n = 1, s = 0, a = 0, l = 0, h = 0, u = 0; t.pos < o;) {
|
||
if (!s) {
|
||
var c = t.readVarint();
|
||
n = 7 & c, s = c >> 3
|
||
}
|
||
s--, 1 === n || 2 === n ? (a += t.readSVarint(), l += t.readSVarint(), 1 === n && h > u && (r.push(h), u = h), i.push(a, l), h += 2) : 7 === n ? h > u && (i.push(i[u], i[u + 1]), h += 2) : W(!1, 59)
|
||
}
|
||
h > u && (r.push(h), u = h)
|
||
}, e.prototype.createFeature_ = function (t, e, i) {
|
||
var r, o = e.type;
|
||
if (0 === o) return null;
|
||
var n = e.id, s = e.properties;
|
||
s[this.layerName_] = e.layer.name;
|
||
var a = [], l = [];
|
||
this.readRawGeometry_(t, e, a, l);
|
||
var h = function (t, e) {
|
||
var i;
|
||
1 === t ? i = 1 === e ? Zt.POINT : Zt.MULTI_POINT : 2 === t ? i = 1 === e ? Zt.LINE_STRING : Zt.MULTI_LINE_STRING : 3 === t && (i = Zt.POLYGON);
|
||
return i
|
||
}(o, l.length);
|
||
if (this.featureClass_ === sm) r = new this.featureClass_(h, a, l, s, n); else {
|
||
var u;
|
||
if (h == Zt.POLYGON) {
|
||
for (var c = [], p = 0, d = 0, f = 0, g = l.length; f < g; ++f) {
|
||
var m = l[f];
|
||
lr(a, p, m, 2) || (c.push(l.slice(d, f)), d = f), p = m
|
||
}
|
||
u = c.length > 1 ? new zc(a, qt.XY, c) : new fr(a, qt.XY, l)
|
||
} else u = h === Zt.POINT ? new qi(a, qt.XY) : h === Zt.LINE_STRING ? new Jr(a, qt.XY) : h === Zt.POLYGON ? new fr(a, qt.XY, l) : h === Zt.MULTI_POINT ? new Gc(a, qt.XY) : h === Zt.MULTI_LINE_STRING ? new Dc(a, qt.XY, l) : null;
|
||
r = new (0, this.featureClass_), this.geometryName_ && r.setGeometryName(this.geometryName_);
|
||
var y = kc(u, !1, this.adaptOptions(i));
|
||
r.setGeometry(y), r.setId(n), r.setProperties(s)
|
||
}
|
||
return r
|
||
}, e.prototype.getLastExtent = function () {
|
||
return this.extent_
|
||
}, e.prototype.getType = function () {
|
||
return gh.ARRAY_BUFFER
|
||
}, e.prototype.readFeatures = function (t, e) {
|
||
var i = this.layers_, r = new rm.a(t), o = r.readFields(am, {}), n = [];
|
||
for (var s in o) if (!i || -1 != i.indexOf(s)) {
|
||
for (var a = o[s], l = 0, h = a.length; l < h; ++l) {
|
||
var u = um(r, a, l);
|
||
n.push(this.createFeature_(r, u))
|
||
}
|
||
this.extent_ = a ? [0, 0, a.extent, a.extent] : null
|
||
}
|
||
return n
|
||
}, e.prototype.readProjection = function (t) {
|
||
return this.dataProjection
|
||
}, e.prototype.setLayers = function (t) {
|
||
this.layers_ = t
|
||
}, e
|
||
}(Ac), pm = [null], dm = pp(pm, {
|
||
nd: function (t, e) {
|
||
e[e.length - 1].ndrefs.push(t.getAttribute("ref"))
|
||
}, tag: ym
|
||
}), fm = pp(pm, {
|
||
node: function (t, e) {
|
||
var i = e[0], r = e[e.length - 1], o = t.getAttribute("id"),
|
||
n = [parseFloat(t.getAttribute("lon")), parseFloat(t.getAttribute("lat"))];
|
||
r.nodes[o] = n;
|
||
var s = fp({tags: {}}, mm, t, e);
|
||
if (!g(s.tags)) {
|
||
var a = new qi(n);
|
||
kc(a, !1, i);
|
||
var l = new X(a);
|
||
l.setId(o), l.setProperties(s.tags), r.features.push(l)
|
||
}
|
||
}, way: function (t, e) {
|
||
var i = fp({id: t.getAttribute("id"), ndrefs: [], tags: {}}, dm, t, e);
|
||
e[e.length - 1].ways.push(i)
|
||
}
|
||
}), gm = function (t) {
|
||
function e() {
|
||
t.call(this), this.dataProjection = We("EPSG:4326")
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.readFeaturesFromNode = function (t, e) {
|
||
var i = this.getReadOptions(t, e);
|
||
if ("osm" == t.localName) {
|
||
for (var r = fp({nodes: {}, ways: [], features: []}, fm, t, [i]), o = 0; o < r.ways.length; o++) {
|
||
for (var n = r.ways[o], s = [], a = 0, l = n.ndrefs.length; a < l; a++) {
|
||
Q(s, r.nodes[n.ndrefs[a]])
|
||
}
|
||
var h = void 0;
|
||
kc(h = n.ndrefs[0] == n.ndrefs[n.ndrefs.length - 1] ? new fr(s, qt.XY, [s.length]) : new Jr(s, qt.XY), !1, i);
|
||
var u = new X(h);
|
||
u.setId(n.id), u.setProperties(n.tags), r.features.push(u)
|
||
}
|
||
if (r.features) return r.features
|
||
}
|
||
return []
|
||
}, e
|
||
}(yp), mm = pp(pm, {tag: ym});
|
||
|
||
function ym(t, e) {
|
||
e[e.length - 1].tags[t.getAttribute("k")] = t.getAttribute("v")
|
||
}
|
||
|
||
var vm = gm, _m = "http://www.w3.org/1999/xlink";
|
||
|
||
function xm(t) {
|
||
return t.getAttributeNS(_m, "href")
|
||
}
|
||
|
||
var wm = function () {
|
||
};
|
||
wm.prototype.read = function (t) {
|
||
if (t) {
|
||
if ("string" == typeof t) {
|
||
var e = ep(t);
|
||
return this.readFromDocument(e)
|
||
}
|
||
return Qc(t) ? this.readFromDocument(t) : this.readFromNode(t)
|
||
}
|
||
return null
|
||
}, wm.prototype.readFromDocument = function (t) {
|
||
}, wm.prototype.readFromNode = function (t) {
|
||
};
|
||
var bm = wm, Cm = [null, "http://www.opengis.net/ows/1.1"], Sm = pp(Cm, {
|
||
ServiceIdentification: sp(function (t, e) {
|
||
return fp({}, Dm, t, e)
|
||
}), ServiceProvider: sp(function (t, e) {
|
||
return fp({}, Gm, t, e)
|
||
}), OperationsMetadata: sp(function (t, e) {
|
||
return fp({}, Am, t, e)
|
||
})
|
||
}), Em = function (t) {
|
||
function e() {
|
||
t.call(this)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.readFromDocument = function (t) {
|
||
for (var e = t.firstChild; e; e = e.nextSibling) if (e.nodeType == Node.ELEMENT_NODE) return this.readFromNode(e);
|
||
return null
|
||
}, e.prototype.readFromNode = function (t) {
|
||
var e = fp({}, Sm, t, []);
|
||
return e || null
|
||
}, e
|
||
}(bm), Tm = pp(Cm, {
|
||
DeliveryPoint: sp(Lp),
|
||
City: sp(Lp),
|
||
AdministrativeArea: sp(Lp),
|
||
PostalCode: sp(Lp),
|
||
Country: sp(Lp),
|
||
ElectronicMailAddress: sp(Lp)
|
||
}), Rm = pp(Cm, {
|
||
Value: np(function (t, e) {
|
||
return Lp(t)
|
||
})
|
||
}), Pm = pp(Cm, {
|
||
AllowedValues: sp(function (t, e) {
|
||
return fp({}, Rm, t, e)
|
||
})
|
||
}), Lm = pp(Cm, {
|
||
Phone: sp(function (t, e) {
|
||
return fp({}, km, t, e)
|
||
}), Address: sp(function (t, e) {
|
||
return fp({}, Tm, t, e)
|
||
})
|
||
}), Im = pp(Cm, {
|
||
HTTP: sp(function (t, e) {
|
||
return fp({}, Om, t, e)
|
||
})
|
||
}), Om = pp(Cm, {
|
||
Get: np(function (t, e) {
|
||
var i = xm(t);
|
||
if (!i) return;
|
||
return fp({href: i}, Fm, t, e)
|
||
}), Post: void 0
|
||
}), Mm = pp(Cm, {
|
||
DCP: sp(function (t, e) {
|
||
return fp({}, Im, t, e)
|
||
})
|
||
}), Am = pp(Cm, {
|
||
Operation: function (t, e) {
|
||
var i = t.getAttribute("name"), r = fp({}, Mm, t, e);
|
||
if (!r) return;
|
||
e[e.length - 1][i] = r
|
||
}
|
||
}), km = pp(Cm, {Voice: sp(Lp), Facsimile: sp(Lp)}), Fm = pp(Cm, {
|
||
Constraint: np(function (t, e) {
|
||
var i = t.getAttribute("name");
|
||
if (!i) return;
|
||
return fp({name: i}, Pm, t, e)
|
||
})
|
||
}), Nm = pp(Cm, {
|
||
IndividualName: sp(Lp), PositionName: sp(Lp), ContactInfo: sp(function (t, e) {
|
||
return fp({}, Lm, t, e)
|
||
})
|
||
}), Dm = pp(Cm, {
|
||
Abstract: sp(Lp),
|
||
AccessConstraints: sp(Lp),
|
||
Fees: sp(Lp),
|
||
Title: sp(Lp),
|
||
ServiceTypeVersion: sp(Lp),
|
||
ServiceType: sp(Lp)
|
||
}), Gm = pp(Cm, {
|
||
ProviderName: sp(Lp), ProviderSite: sp(xm), ServiceContact: sp(function (t, e) {
|
||
return fp({}, Nm, t, e)
|
||
})
|
||
});
|
||
var jm = Em;
|
||
|
||
function zm(t, e, i, r, o, n) {
|
||
var s, a;
|
||
void 0 !== o ? (s = o, a = void 0 !== n ? n : 0) : (s = [], a = 0);
|
||
for (var l = e; l < i;) {
|
||
var h = t[l++];
|
||
s[a++] = t[l++], s[a++] = h;
|
||
for (var u = 2; u < r; ++u) s[a++] = t[l++]
|
||
}
|
||
return s.length = a, s
|
||
}
|
||
|
||
function Um(t, e, i) {
|
||
var r, o = i || 1e5, n = new Array(e);
|
||
for (r = 0; r < e; ++r) n[r] = 0;
|
||
for (var s = 0, a = t.length; s < a;) for (r = 0; r < e; ++r, ++s) {
|
||
var l = t[s], h = l - n[r];
|
||
n[r] = l, t[s] = h
|
||
}
|
||
return Vm(t, o)
|
||
}
|
||
|
||
function Bm(t, e, i) {
|
||
var r, o = i || 1e5, n = new Array(e);
|
||
for (r = 0; r < e; ++r) n[r] = 0;
|
||
for (var s = Ym(t, o), a = 0, l = s.length; a < l;) for (r = 0; r < e; ++r, ++a) n[r] += s[a], s[a] = n[r];
|
||
return s
|
||
}
|
||
|
||
function Vm(t, e) {
|
||
for (var i = e || 1e5, r = 0, o = t.length; r < o; ++r) t[r] = Math.round(t[r] * i);
|
||
return Wm(t)
|
||
}
|
||
|
||
function Ym(t, e) {
|
||
for (var i = e || 1e5, r = Hm(t), o = 0, n = r.length; o < n; ++o) r[o] /= i;
|
||
return r
|
||
}
|
||
|
||
function Wm(t) {
|
||
for (var e = 0, i = t.length; e < i; ++e) {
|
||
var r = t[e];
|
||
t[e] = r < 0 ? ~(r << 1) : r << 1
|
||
}
|
||
return Xm(t)
|
||
}
|
||
|
||
function Hm(t) {
|
||
for (var e = qm(t), i = 0, r = e.length; i < r; ++i) {
|
||
var o = e[i];
|
||
e[i] = 1 & o ? ~(o >> 1) : o >> 1
|
||
}
|
||
return e
|
||
}
|
||
|
||
function Xm(t) {
|
||
for (var e = "", i = 0, r = t.length; i < r; ++i) e += Zm(t[i]);
|
||
return e
|
||
}
|
||
|
||
function qm(t) {
|
||
for (var e = [], i = 0, r = 0, o = 0, n = t.length; o < n; ++o) {
|
||
var s = t.charCodeAt(o) - 63;
|
||
i |= (31 & s) << r, s < 32 ? (e.push(i), i = 0, r = 0) : r += 5
|
||
}
|
||
return e
|
||
}
|
||
|
||
function Zm(t) {
|
||
for (var e, i = ""; t >= 32;) e = 63 + (32 | 31 & t), i += String.fromCharCode(e), t >>= 5;
|
||
return e = t + 63, i += String.fromCharCode(e)
|
||
}
|
||
|
||
var Km = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = e || {};
|
||
this.dataProjection = We("EPSG:4326"), this.factor_ = i.factor ? i.factor : 1e5, this.geometryLayout_ = i.geometryLayout ? i.geometryLayout : qt.XY
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.readFeatureFromText = function (t, e) {
|
||
var i = this.readGeometryFromText(t, e);
|
||
return new X(i)
|
||
}, e.prototype.readFeaturesFromText = function (t, e) {
|
||
return [this.readFeatureFromText(t, e)]
|
||
}, e.prototype.readGeometryFromText = function (t, e) {
|
||
var i = xi(this.geometryLayout_), r = Bm(t, i, this.factor_);
|
||
zm(r, 0, r.length, i, r);
|
||
var o = Di(r, 0, r.length, i);
|
||
return kc(new Jr(o, this.geometryLayout_), !1, this.adaptOptions(e))
|
||
}, e.prototype.writeFeatureText = function (t, e) {
|
||
var i = t.getGeometry();
|
||
return i ? this.writeGeometryText(i, e) : (W(!1, 40), "")
|
||
}, e.prototype.writeFeaturesText = function (t, e) {
|
||
return this.writeFeatureText(t[0], e)
|
||
}, e.prototype.writeGeometryText = function (t, e) {
|
||
var i = (t = kc(t, !0, this.adaptOptions(e))).getFlatCoordinates(), r = t.getStride();
|
||
return zm(i, 0, i.length, r, i), Um(i, r, this.factor_)
|
||
}, e
|
||
}(Ad), Jm = {
|
||
Point: function (t, e, i) {
|
||
var r = t.coordinates;
|
||
e && i && iy(r, e, i);
|
||
return new qi(r)
|
||
}, LineString: function (t, e) {
|
||
var i = $m(t.arcs, e);
|
||
return new Jr(i)
|
||
}, Polygon: function (t, e) {
|
||
for (var i = [], r = 0, o = t.arcs.length; r < o; ++r) i[r] = $m(t.arcs[r], e);
|
||
return new fr(i)
|
||
}, MultiPoint: function (t, e, i) {
|
||
var r = t.coordinates;
|
||
if (e && i) for (var o = 0, n = r.length; o < n; ++o) iy(r[o], e, i);
|
||
return new Gc(r)
|
||
}, MultiLineString: function (t, e) {
|
||
for (var i = [], r = 0, o = t.arcs.length; r < o; ++r) i[r] = $m(t.arcs[r], e);
|
||
return new Dc(i)
|
||
}, MultiPolygon: function (t, e) {
|
||
for (var i = [], r = 0, o = t.arcs.length; r < o; ++r) {
|
||
for (var n = t.arcs[r], s = [], a = 0, l = n.length; a < l; ++a) s[a] = $m(n[a], e);
|
||
i[r] = s
|
||
}
|
||
return new zc(i)
|
||
}
|
||
};
|
||
|
||
function $m(t, e) {
|
||
for (var i, r, o = [], n = 0, s = t.length; n < s; ++n) i = t[n], n > 0 && o.pop(), r = i >= 0 ? e[i] : e[~i].slice().reverse(), o.push.apply(o, r);
|
||
for (var a = 0, l = o.length; a < l; ++a) o[a] = o[a].slice();
|
||
return o
|
||
}
|
||
|
||
function Qm(t, e, i, r, o, n, s) {
|
||
for (var a = t.geometries, l = [], h = 0, u = a.length; h < u; ++h) l[h] = ty(a[h], e, i, r, o, n, s);
|
||
return l
|
||
}
|
||
|
||
function ty(t, e, i, r, o, n, s) {
|
||
var a, l = t.type, h = Jm[l];
|
||
a = "Point" === l || "MultiPoint" === l ? h(t, i, r) : h(t, e);
|
||
var u = new X;
|
||
u.setGeometry(kc(a, !1, s)), void 0 !== t.id && u.setId(t.id);
|
||
var c = t.properties;
|
||
return o && (c || (c = {}), c[o] = n), c && u.setProperties(c), u
|
||
}
|
||
|
||
function ey(t, e, i) {
|
||
for (var r = 0, o = 0, n = 0, s = t.length; n < s; ++n) {
|
||
var a = t[n];
|
||
r += a[0], o += a[1], a[0] = r, a[1] = o, iy(a, e, i)
|
||
}
|
||
}
|
||
|
||
function iy(t, e, i) {
|
||
t[0] = t[0] * e[0] + i[0], t[1] = t[1] * e[1] + i[1]
|
||
}
|
||
|
||
var ry = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = e || {};
|
||
this.layerName_ = i.layerName, this.layers_ = i.layers ? i.layers : null, this.dataProjection = We(i.dataProjection ? i.dataProjection : "EPSG:4326")
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.readFeaturesFromObject = function (t, e) {
|
||
if ("Topology" == t.type) {
|
||
var i, r = t, o = null, n = null;
|
||
r.transform && (o = (i = r.transform).scale, n = i.translate);
|
||
var s = r.arcs;
|
||
i && function (t, e, i) {
|
||
for (var r = 0, o = t.length; r < o; ++r) ey(t[r], e, i)
|
||
}(s, o, n);
|
||
var a, l = [], h = r.objects, u = this.layerName_;
|
||
for (var c in h) this.layers_ && -1 == this.layers_.indexOf(c) || ("GeometryCollection" === h[c].type ? (a = h[c], l.push.apply(l, Qm(a, s, o, n, u, c, e))) : (a = h[c], l.push(ty(a, s, o, n, u, c, e))));
|
||
return l
|
||
}
|
||
return []
|
||
}, e.prototype.readProjectionFromObject = function (t) {
|
||
return this.dataProjection
|
||
}, e
|
||
}(Nc), oy = function (t) {
|
||
this.tagName_ = t
|
||
};
|
||
oy.prototype.getTagName = function () {
|
||
return this.tagName_
|
||
};
|
||
var ny = oy, sy = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e), this.conditions = i, W(this.conditions.length >= 2, 57)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(ny), ay = function (t) {
|
||
function e(e) {
|
||
t.call(this, "And", Array.prototype.slice.call(arguments))
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(sy), ly = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, "BBOX"), this.geometryName = e, this.extent = i, this.srsName = r
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(ny), hy = function (t) {
|
||
function e(e, i, r, o) {
|
||
t.call(this, e), this.geometryName = i || "the_geom", this.geometry = r, this.srsName = o
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(ny), uy = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, "Contains", e, i, r)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(hy), cy = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e), this.propertyName = i
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(ny), py = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, "During", e), this.begin = i, this.end = r
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(cy), dy = function (t) {
|
||
function e(e, i, r, o) {
|
||
t.call(this, e, i), this.expression = r, this.matchCase = o
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(cy), fy = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, "PropertyIsEqualTo", e, i, r)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(dy), gy = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, "PropertyIsGreaterThan", e, i)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(dy), my = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, "PropertyIsGreaterThanOrEqualTo", e, i)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(dy), yy = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, "Intersects", e, i, r)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(hy), vy = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, "PropertyIsBetween", e), this.lowerBoundary = i, this.upperBoundary = r
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(cy), _y = function (t) {
|
||
function e(e, i, r, o, n, s) {
|
||
t.call(this, "PropertyIsLike", e), this.pattern = i, this.wildCard = void 0 !== r ? r : "*", this.singleChar = void 0 !== o ? o : ".", this.escapeChar = void 0 !== n ? n : "!", this.matchCase = s
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(cy), xy = function (t) {
|
||
function e(e) {
|
||
t.call(this, "PropertyIsNull", e)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(cy), wy = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, "PropertyIsLessThan", e, i)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(dy), by = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, "PropertyIsLessThanOrEqualTo", e, i)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(dy), Cy = function (t) {
|
||
function e(e) {
|
||
t.call(this, "Not"), this.condition = e
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(ny), Sy = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, "PropertyIsNotEqualTo", e, i, r)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(dy), Ey = function (t) {
|
||
function e(e) {
|
||
t.call(this, "Or", Array.prototype.slice.call(arguments))
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(sy), Ty = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, "Within", e, i, r)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(hy);
|
||
|
||
function Ry(t) {
|
||
var e = [null].concat(Array.prototype.slice.call(arguments));
|
||
return new (Function.prototype.bind.apply(ay, e))
|
||
}
|
||
|
||
function Py(t, e, i) {
|
||
return new ly(t, e, i)
|
||
}
|
||
|
||
var Ly = {"http://www.opengis.net/gml": {boundedBy: sp(wp.prototype.readGeometryElement, "bounds")}},
|
||
Iy = {"http://www.opengis.net/wfs": {totalInserted: sp(Rp), totalUpdated: sp(Rp), totalDeleted: sp(Rp)}},
|
||
Oy = {
|
||
"http://www.opengis.net/wfs": {
|
||
TransactionSummary: sp(function (t, e) {
|
||
return fp({}, Iy, t, e)
|
||
}, "transactionSummary"), InsertResults: sp(function (t, e) {
|
||
return fp([], Vy, t, e)
|
||
}, "insertIds")
|
||
}
|
||
}, My = {"http://www.opengis.net/wfs": {PropertyName: ap(Fp)}}, Ay = {
|
||
"http://www.opengis.net/wfs": {
|
||
Insert: ap(function (t, e, i) {
|
||
var r = i[i.length - 1], o = r.featureType, n = r.featureNS, s = r.gmlVersion, a = Kc(n, o);
|
||
t.appendChild(a), 2 === s ? Wp.prototype.writeFeatureElement(a, e, i) : jp.prototype.writeFeatureElement(a, e, i)
|
||
}), Update: ap(function (t, e, i) {
|
||
var r = i[i.length - 1];
|
||
W(void 0 !== e.getId(), 27);
|
||
var o = r.featureType, n = r.featurePrefix, s = r.featureNS, a = Wy(n, o), l = e.getGeometryName();
|
||
t.setAttribute("typeName", a), t.setAttributeNS(Fy, "xmlns:" + n, s);
|
||
var h = e.getId();
|
||
if (void 0 !== h) {
|
||
for (var u = e.getKeys(), c = [], p = 0, d = u.length; p < d; p++) {
|
||
var f = e.get(u[p]);
|
||
if (void 0 !== f) {
|
||
var g = u[p];
|
||
f && "function" == typeof f.getSimplifiedGeometry && (g = l), c.push({
|
||
name: g,
|
||
value: f
|
||
})
|
||
}
|
||
}
|
||
mp({
|
||
gmlVersion: r.gmlVersion,
|
||
node: t,
|
||
hasZ: r.hasZ,
|
||
srsName: r.srsName
|
||
}, Ay, hp("Property"), c, i), Yy(t, h, i)
|
||
}
|
||
}), Delete: ap(function (t, e, i) {
|
||
var r = i[i.length - 1];
|
||
W(void 0 !== e.getId(), 26);
|
||
var o = r.featureType, n = r.featurePrefix, s = r.featureNS, a = Wy(n, o);
|
||
t.setAttribute("typeName", a), t.setAttributeNS(Fy, "xmlns:" + n, s);
|
||
var l = e.getId();
|
||
void 0 !== l && Yy(t, l, i)
|
||
}), Property: ap(function (t, e, i) {
|
||
var r = Kc(Dy, "Name"), o = i[i.length - 1].gmlVersion;
|
||
if (t.appendChild(r), Fp(r, e.name), void 0 !== e.value && null !== e.value) {
|
||
var n = Kc(Dy, "Value");
|
||
t.appendChild(n), e.value && "function" == typeof e.value.getSimplifiedGeometry ? 2 === o ? Wp.prototype.writeGeometryElement(n, e.value, i) : jp.prototype.writeGeometryElement(n, e.value, i) : Fp(n, e.value)
|
||
}
|
||
}), Native: ap(function (t, e, i) {
|
||
e.vendorId && t.setAttribute("vendorId", e.vendorId);
|
||
void 0 !== e.safeToIgnore && t.setAttribute("safeToIgnore", String(e.safeToIgnore));
|
||
void 0 !== e.value && Fp(t, e.value)
|
||
})
|
||
}
|
||
}, ky = "feature", Fy = "http://www.w3.org/2000/xmlns/", Ny = "http://www.opengis.net/ogc",
|
||
Dy = "http://www.opengis.net/wfs", Gy = "http://www.opengis.net/fes", jy = {
|
||
"1.1.0": "http://www.opengis.net/wfs http://schemas.opengis.net/wfs/1.1.0/wfs.xsd",
|
||
"1.0.0": "http://www.opengis.net/wfs http://schemas.opengis.net/wfs/1.0.0/wfs.xsd"
|
||
}, zy = "1.1.0", Uy = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = e || {};
|
||
this.featureType_ = i.featureType, this.featureNS_ = i.featureNS, this.gmlFormat_ = i.gmlFormat ? i.gmlFormat : new jp, this.schemaLocation_ = i.schemaLocation ? i.schemaLocation : jy[zy]
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getFeatureType = function () {
|
||
return this.featureType_
|
||
}, e.prototype.setFeatureType = function (t) {
|
||
this.featureType_ = t
|
||
}, e.prototype.readFeaturesFromNode = function (t, e) {
|
||
var i = {node: t};
|
||
p(i, {
|
||
featureType: this.featureType_,
|
||
featureNS: this.featureNS_
|
||
}), p(i, this.getReadOptions(t, e || {}));
|
||
var r = [i];
|
||
this.gmlFormat_.FEATURE_COLLECTION_PARSERS[vp].featureMember = rp(wp.prototype.readFeaturesInternal);
|
||
var o = fp([], this.gmlFormat_.FEATURE_COLLECTION_PARSERS, t, r, this.gmlFormat_);
|
||
return o || (o = []), o
|
||
}, e.prototype.readTransactionResponse = function (t) {
|
||
if (t) {
|
||
if ("string" == typeof t) {
|
||
var e = ep(t);
|
||
return this.readTransactionResponseFromDocument(e)
|
||
}
|
||
return Qc(t) ? this.readTransactionResponseFromDocument(t) : this.readTransactionResponseFromNode(t)
|
||
}
|
||
}, e.prototype.readFeatureCollectionMetadata = function (t) {
|
||
if (t) {
|
||
if ("string" == typeof t) {
|
||
var e = ep(t);
|
||
return this.readFeatureCollectionMetadataFromDocument(e)
|
||
}
|
||
return Qc(t) ? this.readFeatureCollectionMetadataFromDocument(t) : this.readFeatureCollectionMetadataFromNode(t)
|
||
}
|
||
}, e.prototype.readFeatureCollectionMetadataFromDocument = function (t) {
|
||
for (var e = t.firstChild; e; e = e.nextSibling) if (e.nodeType == Node.ELEMENT_NODE) return this.readFeatureCollectionMetadataFromNode(e)
|
||
}, e.prototype.readFeatureCollectionMetadataFromNode = function (t) {
|
||
var e = {}, i = Pp(t.getAttribute("numberOfFeatures"));
|
||
return e.numberOfFeatures = i, fp(e, Ly, t, [], this.gmlFormat_)
|
||
}, e.prototype.readTransactionResponseFromDocument = function (t) {
|
||
for (var e = t.firstChild; e; e = e.nextSibling) if (e.nodeType == Node.ELEMENT_NODE) return this.readTransactionResponseFromNode(e)
|
||
}, e.prototype.readTransactionResponseFromNode = function (t) {
|
||
return fp({}, Oy, t, [])
|
||
}, e.prototype.writeGetFeature = function (t) {
|
||
var e, i = Kc(Dy, "GetFeature");
|
||
if (i.setAttribute("service", "WFS"), i.setAttribute("version", "1.1.0"), t && (t.handle && i.setAttribute("handle", t.handle), t.outputFormat && i.setAttribute("outputFormat", t.outputFormat), void 0 !== t.maxFeatures && i.setAttribute("maxFeatures", String(t.maxFeatures)), t.resultType && i.setAttribute("resultType", t.resultType), void 0 !== t.startIndex && i.setAttribute("startIndex", String(t.startIndex)), void 0 !== t.count && i.setAttribute("count", String(t.count)), void 0 !== t.viewParams && i.setAttribute("viewParams ", t.viewParams), e = t.filter, t.bbox)) {
|
||
W(t.geometryName, 12);
|
||
var r = Py(t.geometryName, t.bbox, t.srsName);
|
||
e = e ? Ry(e, r) : r
|
||
}
|
||
i.setAttributeNS(Zc, "xsi:schemaLocation", this.schemaLocation_);
|
||
var o = {node: i};
|
||
return p(o, {
|
||
srsName: t.srsName,
|
||
featureNS: t.featureNS ? t.featureNS : this.featureNS_,
|
||
featurePrefix: t.featurePrefix,
|
||
geometryName: t.geometryName,
|
||
filter: e,
|
||
propertyNames: t.propertyNames ? t.propertyNames : []
|
||
}), W(Array.isArray(t.featureTypes), 11), function (t, e, i) {
|
||
var r = i[i.length - 1], o = p({}, r);
|
||
o.node = t, mp(o, Hy, hp("Query"), e, i)
|
||
}(i, t.featureTypes, [o]), i
|
||
}, e.prototype.writeTransaction = function (t, e, i, r) {
|
||
var o, n, s = [], a = Kc(Dy, "Transaction"), l = r.version ? r.version : zy, h = "1.0.0" === l ? 2 : 3;
|
||
a.setAttribute("service", "WFS"), a.setAttribute("version", l), r && (o = r.gmlOptions ? r.gmlOptions : {}, r.handle && a.setAttribute("handle", r.handle));
|
||
var u = jy[l];
|
||
a.setAttributeNS(Zc, "xsi:schemaLocation", u);
|
||
var c = r.featurePrefix ? r.featurePrefix : ky;
|
||
return t && (n = p({node: a}, {
|
||
featureNS: r.featureNS,
|
||
featureType: r.featureType,
|
||
featurePrefix: c,
|
||
gmlVersion: h,
|
||
hasZ: r.hasZ,
|
||
srsName: r.srsName
|
||
}), p(n, o), mp(n, Ay, hp("Insert"), t, s)), e && (n = p({node: a}, {
|
||
featureNS: r.featureNS,
|
||
featureType: r.featureType,
|
||
featurePrefix: c,
|
||
gmlVersion: h,
|
||
hasZ: r.hasZ,
|
||
srsName: r.srsName
|
||
}), p(n, o), mp(n, Ay, hp("Update"), e, s)), i && mp({
|
||
node: a,
|
||
featureNS: r.featureNS,
|
||
featureType: r.featureType,
|
||
featurePrefix: c,
|
||
gmlVersion: h,
|
||
srsName: r.srsName
|
||
}, Ay, hp("Delete"), i, s), r.nativeElements && mp({
|
||
node: a,
|
||
featureNS: r.featureNS,
|
||
featureType: r.featureType,
|
||
featurePrefix: c,
|
||
gmlVersion: h,
|
||
srsName: r.srsName
|
||
}, Ay, hp("Native"), r.nativeElements, s), a
|
||
}, e.prototype.readProjectionFromDocument = function (t) {
|
||
for (var e = t.firstChild; e; e = e.nextSibling) if (e.nodeType == Node.ELEMENT_NODE) return this.readProjectionFromNode(e);
|
||
return null
|
||
}, e.prototype.readProjectionFromNode = function (t) {
|
||
if (t.firstElementChild && t.firstElementChild.firstElementChild) for (var e = (t = t.firstElementChild.firstElementChild).firstElementChild; e; e = e.nextElementSibling) if (0 !== e.childNodes.length && (1 !== e.childNodes.length || 3 !== e.firstChild.nodeType)) {
|
||
var i = [{}];
|
||
return this.gmlFormat_.readGeometryElement(e, i), We(i.pop().srsName)
|
||
}
|
||
return null
|
||
}, e
|
||
}(yp);
|
||
var By = {
|
||
"http://www.opengis.net/ogc": {
|
||
FeatureId: rp(function (t, e) {
|
||
return t.getAttribute("fid")
|
||
})
|
||
}
|
||
};
|
||
var Vy = {
|
||
"http://www.opengis.net/wfs": {
|
||
Feature: function (t, e) {
|
||
dp(By, t, e)
|
||
}
|
||
}
|
||
};
|
||
|
||
function Yy(t, e, i) {
|
||
var r = Kc(Ny, "Filter"), o = Kc(Ny, "FeatureId");
|
||
r.appendChild(o), o.setAttribute("fid", e), t.appendChild(r)
|
||
}
|
||
|
||
function Wy(t, e) {
|
||
var i = (t = t || ky) + ":";
|
||
return 0 === e.indexOf(i) ? e : i + e
|
||
}
|
||
|
||
var Hy = {
|
||
"http://www.opengis.net/wfs": {
|
||
Query: ap(function (t, e, i) {
|
||
var r, o = i[i.length - 1], n = o.featurePrefix, s = o.featureNS, a = o.propertyNames,
|
||
l = o.srsName;
|
||
r = n ? Wy(n, e) : e;
|
||
t.setAttribute("typeName", r), l && t.setAttribute("srsName", l);
|
||
s && t.setAttributeNS(Fy, "xmlns:" + n, s);
|
||
var h = p({}, o);
|
||
h.node = t, mp(h, My, hp("PropertyName"), a, i);
|
||
var u = o.filter;
|
||
if (u) {
|
||
var c = Kc(Ny, "Filter");
|
||
t.appendChild(c), Xy(c, u, i)
|
||
}
|
||
})
|
||
}, "http://www.opengis.net/ogc": {
|
||
During: ap(function (t, e, i) {
|
||
var r = Kc(Gy, "ValueReference");
|
||
Fp(r, e.propertyName), t.appendChild(r);
|
||
var o = Kc(vp, "TimePeriod");
|
||
t.appendChild(o);
|
||
var n = Kc(vp, "begin");
|
||
o.appendChild(n), Qy(n, e.begin);
|
||
var s = Kc(vp, "end");
|
||
o.appendChild(s), Qy(s, e.end)
|
||
}),
|
||
And: ap(qy),
|
||
Or: ap(qy),
|
||
Not: ap(function (t, e, i) {
|
||
var r = {node: t}, o = e.condition;
|
||
mp(r, Hy, hp(o.getTagName()), [o], i)
|
||
}),
|
||
BBOX: ap(function (t, e, i) {
|
||
i[i.length - 1].srsName = e.srsName, Jy(t, e.geometryName), jp.prototype.writeGeometryElement(t, e.extent, i)
|
||
}),
|
||
Contains: ap(function (t, e, i) {
|
||
i[i.length - 1].srsName = e.srsName, Jy(t, e.geometryName), jp.prototype.writeGeometryElement(t, e.geometry, i)
|
||
}),
|
||
Intersects: ap(function (t, e, i) {
|
||
i[i.length - 1].srsName = e.srsName, Jy(t, e.geometryName), jp.prototype.writeGeometryElement(t, e.geometry, i)
|
||
}),
|
||
Within: ap(function (t, e, i) {
|
||
i[i.length - 1].srsName = e.srsName, Jy(t, e.geometryName), jp.prototype.writeGeometryElement(t, e.geometry, i)
|
||
}),
|
||
PropertyIsEqualTo: ap(Zy),
|
||
PropertyIsNotEqualTo: ap(Zy),
|
||
PropertyIsLessThan: ap(Zy),
|
||
PropertyIsLessThanOrEqualTo: ap(Zy),
|
||
PropertyIsGreaterThan: ap(Zy),
|
||
PropertyIsGreaterThanOrEqualTo: ap(Zy),
|
||
PropertyIsNull: ap(function (t, e, i) {
|
||
Jy(t, e.propertyName)
|
||
}),
|
||
PropertyIsBetween: ap(function (t, e, i) {
|
||
Jy(t, e.propertyName);
|
||
var r = Kc(Ny, "LowerBoundary");
|
||
t.appendChild(r), $y(r, "" + e.lowerBoundary);
|
||
var o = Kc(Ny, "UpperBoundary");
|
||
t.appendChild(o), $y(o, "" + e.upperBoundary)
|
||
}),
|
||
PropertyIsLike: ap(function (t, e, i) {
|
||
t.setAttribute("wildCard", e.wildCard), t.setAttribute("singleChar", e.singleChar), t.setAttribute("escapeChar", e.escapeChar), void 0 !== e.matchCase && t.setAttribute("matchCase", e.matchCase.toString());
|
||
Jy(t, e.propertyName), $y(t, "" + e.pattern)
|
||
})
|
||
}
|
||
};
|
||
|
||
function Xy(t, e, i) {
|
||
mp({node: t}, Hy, hp(e.getTagName()), [e], i)
|
||
}
|
||
|
||
function qy(t, e, i) {
|
||
for (var r = {node: t}, o = e.conditions, n = 0, s = o.length; n < s; ++n) {
|
||
var a = o[n];
|
||
mp(r, Hy, hp(a.getTagName()), [a], i)
|
||
}
|
||
}
|
||
|
||
function Zy(t, e, i) {
|
||
void 0 !== e.matchCase && t.setAttribute("matchCase", e.matchCase.toString()), Jy(t, e.propertyName), $y(t, "" + e.expression)
|
||
}
|
||
|
||
function Ky(t, e, i) {
|
||
var r = Kc(Ny, t);
|
||
Fp(r, i), e.appendChild(r)
|
||
}
|
||
|
||
function Jy(t, e) {
|
||
Ky("PropertyName", t, e)
|
||
}
|
||
|
||
function $y(t, e) {
|
||
Ky("Literal", t, e)
|
||
}
|
||
|
||
function Qy(t, e) {
|
||
var i = Kc(vp, "TimeInstant");
|
||
t.appendChild(i);
|
||
var r = Kc(vp, "timePosition");
|
||
i.appendChild(r), Fp(r, e)
|
||
}
|
||
|
||
var tv = Uy,
|
||
ev = {POINT: qi, LINESTRING: Jr, POLYGON: fr, MULTIPOINT: Gc, MULTILINESTRING: Dc, MULTIPOLYGON: zc},
|
||
iv = "EMPTY", rv = "Z", ov = "M", nv = 1, sv = 2, av = 3, lv = 4, hv = 5, uv = 6, cv = {};
|
||
for (var pv in Zt) cv[pv] = Zt[pv].toUpperCase();
|
||
var dv = function (t) {
|
||
this.wkt = t, this.index_ = -1
|
||
};
|
||
dv.prototype.isAlpha_ = function (t) {
|
||
return t >= "a" && t <= "z" || t >= "A" && t <= "Z"
|
||
}, dv.prototype.isNumeric_ = function (t, e) {
|
||
return t >= "0" && t <= "9" || "." == t && !(void 0 !== e && e)
|
||
}, dv.prototype.isWhiteSpace_ = function (t) {
|
||
return " " == t || "\t" == t || "\r" == t || "\n" == t
|
||
}, dv.prototype.nextChar_ = function () {
|
||
return this.wkt.charAt(++this.index_)
|
||
}, dv.prototype.nextToken = function () {
|
||
var t, e = this.nextChar_(), i = this.index_, r = e;
|
||
if ("(" == e) t = sv; else if ("," == e) t = hv; else if (")" == e) t = av; else if (this.isNumeric_(e) || "-" == e) t = lv, r = this.readNumber_(); else if (this.isAlpha_(e)) t = nv, r = this.readText_(); else {
|
||
if (this.isWhiteSpace_(e)) return this.nextToken();
|
||
if ("" !== e) throw new Error("Unexpected character: " + e);
|
||
t = uv
|
||
}
|
||
return {position: i, value: r, type: t}
|
||
}, dv.prototype.readNumber_ = function () {
|
||
var t, e = this.index_, i = !1, r = !1;
|
||
do {
|
||
"." == t ? i = !0 : "e" != t && "E" != t || (r = !0), t = this.nextChar_()
|
||
} while (this.isNumeric_(t, i) || !r && ("e" == t || "E" == t) || r && ("-" == t || "+" == t));
|
||
return parseFloat(this.wkt.substring(e, this.index_--))
|
||
}, dv.prototype.readText_ = function () {
|
||
var t, e = this.index_;
|
||
do {
|
||
t = this.nextChar_()
|
||
} while (this.isAlpha_(t));
|
||
return this.wkt.substring(e, this.index_--).toUpperCase()
|
||
};
|
||
var fv = function (t) {
|
||
this.lexer_ = t, this.token_, this.layout_ = qt.XY
|
||
};
|
||
|
||
function gv(t) {
|
||
var e = t.getCoordinates();
|
||
return 0 === e.length ? "" : e.join(" ")
|
||
}
|
||
|
||
function mv(t) {
|
||
for (var e = t.getCoordinates(), i = [], r = 0, o = e.length; r < o; ++r) i.push(e[r].join(" "));
|
||
return i.join(",")
|
||
}
|
||
|
||
function yv(t) {
|
||
for (var e = [], i = t.getLinearRings(), r = 0, o = i.length; r < o; ++r) e.push("(" + mv(i[r]) + ")");
|
||
return e.join(",")
|
||
}
|
||
|
||
fv.prototype.consume_ = function () {
|
||
this.token_ = this.lexer_.nextToken()
|
||
}, fv.prototype.isTokenType = function (t) {
|
||
return this.token_.type == t
|
||
}, fv.prototype.match = function (t) {
|
||
var e = this.isTokenType(t);
|
||
return e && this.consume_(), e
|
||
}, fv.prototype.parse = function () {
|
||
return this.consume_(), this.parseGeometry_()
|
||
}, fv.prototype.parseGeometryLayout_ = function () {
|
||
var t = qt.XY, e = this.token_;
|
||
if (this.isTokenType(nv)) {
|
||
var i = e.value;
|
||
i === rv ? t = qt.XYZ : i === ov ? t = qt.XYM : "ZM" === i && (t = qt.XYZM), t !== qt.XY && this.consume_()
|
||
}
|
||
return t
|
||
}, fv.prototype.parseGeometryCollectionText_ = function () {
|
||
if (this.match(sv)) {
|
||
var t = [];
|
||
do {
|
||
t.push(this.parseGeometry_())
|
||
} while (this.match(hv));
|
||
if (this.match(av)) return t
|
||
} else if (this.isEmptyGeometry_()) return [];
|
||
throw new Error(this.formatErrorMessage_())
|
||
}, fv.prototype.parsePointText_ = function () {
|
||
if (this.match(sv)) {
|
||
var t = this.parsePoint_();
|
||
if (this.match(av)) return t
|
||
} else if (this.isEmptyGeometry_()) return null;
|
||
throw new Error(this.formatErrorMessage_())
|
||
}, fv.prototype.parseLineStringText_ = function () {
|
||
if (this.match(sv)) {
|
||
var t = this.parsePointList_();
|
||
if (this.match(av)) return t
|
||
} else if (this.isEmptyGeometry_()) return [];
|
||
throw new Error(this.formatErrorMessage_())
|
||
}, fv.prototype.parsePolygonText_ = function () {
|
||
if (this.match(sv)) {
|
||
var t = this.parseLineStringTextList_();
|
||
if (this.match(av)) return t
|
||
} else if (this.isEmptyGeometry_()) return [];
|
||
throw new Error(this.formatErrorMessage_())
|
||
}, fv.prototype.parseMultiPointText_ = function () {
|
||
var t;
|
||
if (this.match(sv)) {
|
||
if (t = this.token_.type == sv ? this.parsePointTextList_() : this.parsePointList_(), this.match(av)) return t
|
||
} else if (this.isEmptyGeometry_()) return [];
|
||
throw new Error(this.formatErrorMessage_())
|
||
}, fv.prototype.parseMultiLineStringText_ = function () {
|
||
if (this.match(sv)) {
|
||
var t = this.parseLineStringTextList_();
|
||
if (this.match(av)) return t
|
||
} else if (this.isEmptyGeometry_()) return [];
|
||
throw new Error(this.formatErrorMessage_())
|
||
}, fv.prototype.parseMultiPolygonText_ = function () {
|
||
if (this.match(sv)) {
|
||
var t = this.parsePolygonTextList_();
|
||
if (this.match(av)) return t
|
||
} else if (this.isEmptyGeometry_()) return [];
|
||
throw new Error(this.formatErrorMessage_())
|
||
}, fv.prototype.parsePoint_ = function () {
|
||
for (var t = [], e = this.layout_.length, i = 0; i < e; ++i) {
|
||
var r = this.token_;
|
||
if (!this.match(lv)) break;
|
||
t.push(r.value)
|
||
}
|
||
if (t.length == e) return t;
|
||
throw new Error(this.formatErrorMessage_())
|
||
}, fv.prototype.parsePointList_ = function () {
|
||
for (var t = [this.parsePoint_()]; this.match(hv);) t.push(this.parsePoint_());
|
||
return t
|
||
}, fv.prototype.parsePointTextList_ = function () {
|
||
for (var t = [this.parsePointText_()]; this.match(hv);) t.push(this.parsePointText_());
|
||
return t
|
||
}, fv.prototype.parseLineStringTextList_ = function () {
|
||
for (var t = [this.parseLineStringText_()]; this.match(hv);) t.push(this.parseLineStringText_());
|
||
return t
|
||
}, fv.prototype.parsePolygonTextList_ = function () {
|
||
for (var t = [this.parsePolygonText_()]; this.match(hv);) t.push(this.parsePolygonText_());
|
||
return t
|
||
}, fv.prototype.isEmptyGeometry_ = function () {
|
||
var t = this.isTokenType(nv) && this.token_.value == iv;
|
||
return t && this.consume_(), t
|
||
}, fv.prototype.formatErrorMessage_ = function () {
|
||
return "Unexpected `" + this.token_.value + "` at position " + this.token_.position + " in `" + this.lexer_.wkt + "`"
|
||
}, fv.prototype.parseGeometry_ = function () {
|
||
var t = this.token_;
|
||
if (this.match(nv)) {
|
||
var e = t.value;
|
||
if (this.layout_ = this.parseGeometryLayout_(), "GEOMETRYCOLLECTION" == e) {
|
||
var i = this.parseGeometryCollectionText_();
|
||
return new Pd(i)
|
||
}
|
||
var r, o = ev[e];
|
||
if (!o) throw new Error("Invalid geometry type: " + e);
|
||
switch (e) {
|
||
case"POINT":
|
||
r = this.parsePointText_();
|
||
break;
|
||
case"LINESTRING":
|
||
r = this.parseLineStringText_();
|
||
break;
|
||
case"POLYGON":
|
||
r = this.parsePolygonText_();
|
||
break;
|
||
case"MULTIPOINT":
|
||
r = this.parseMultiPointText_();
|
||
break;
|
||
case"MULTILINESTRING":
|
||
r = this.parseMultiLineStringText_();
|
||
break;
|
||
case"MULTIPOLYGON":
|
||
r = this.parseMultiPolygonText_();
|
||
break;
|
||
default:
|
||
throw new Error("Invalid geometry type: " + e)
|
||
}
|
||
return r || (r = o === ev.POINT ? [NaN, NaN] : []), new o(r, this.layout_)
|
||
}
|
||
throw new Error(this.formatErrorMessage_())
|
||
};
|
||
var vv = {
|
||
Point: gv, LineString: mv, Polygon: yv, MultiPoint: function (t) {
|
||
for (var e = [], i = t.getPoints(), r = 0, o = i.length; r < o; ++r) e.push("(" + gv(i[r]) + ")");
|
||
return e.join(",")
|
||
}, MultiLineString: function (t) {
|
||
for (var e = [], i = t.getLineStrings(), r = 0, o = i.length; r < o; ++r) e.push("(" + mv(i[r]) + ")");
|
||
return e.join(",")
|
||
}, MultiPolygon: function (t) {
|
||
for (var e = [], i = t.getPolygons(), r = 0, o = i.length; r < o; ++r) e.push("(" + yv(i[r]) + ")");
|
||
return e.join(",")
|
||
}, GeometryCollection: function (t) {
|
||
for (var e = [], i = t.getGeometries(), r = 0, o = i.length; r < o; ++r) e.push(_v(i[r]));
|
||
return e.join(",")
|
||
}
|
||
};
|
||
|
||
function _v(t) {
|
||
var e = t.getType(), i = (0, vv[e])(t);
|
||
if (e = e.toUpperCase(), "function" == typeof t.getFlatCoordinates) {
|
||
var r = function (t) {
|
||
var e = t.getLayout(), i = "";
|
||
return e !== qt.XYZ && e !== qt.XYZM || (i += rv), e !== qt.XYM && e !== qt.XYZM || (i += ov), i
|
||
}(t);
|
||
r.length > 0 && (e += " " + r)
|
||
}
|
||
return 0 === i.length ? e + " " + iv : e + "(" + i + ")"
|
||
}
|
||
|
||
var xv = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = e || {};
|
||
this.splitCollection_ = void 0 !== i.splitCollection && i.splitCollection
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.parse_ = function (t) {
|
||
var e = new dv(t);
|
||
return new fv(e).parse()
|
||
}, e.prototype.readFeatureFromText = function (t, e) {
|
||
var i = this.readGeometryFromText(t, e);
|
||
if (i) {
|
||
var r = new X;
|
||
return r.setGeometry(i), r
|
||
}
|
||
return null
|
||
}, e.prototype.readFeaturesFromText = function (t, e) {
|
||
for (var i = [], r = this.readGeometryFromText(t, e), o = [], n = 0, s = (i = this.splitCollection_ && r.getType() == Zt.GEOMETRY_COLLECTION ? r.getGeometriesArray() : [r]).length; n < s; ++n) {
|
||
var a = new X;
|
||
a.setGeometry(i[n]), o.push(a)
|
||
}
|
||
return o
|
||
}, e.prototype.readGeometryFromText = function (t, e) {
|
||
var i = this.parse_(t);
|
||
return i ? kc(i, !1, e) : null
|
||
}, e.prototype.writeFeatureText = function (t, e) {
|
||
var i = t.getGeometry();
|
||
return i ? this.writeGeometryText(i, e) : ""
|
||
}, e.prototype.writeFeaturesText = function (t, e) {
|
||
if (1 == t.length) return this.writeFeatureText(t[0], e);
|
||
for (var i = [], r = 0, o = t.length; r < o; ++r) i.push(t[r].getGeometry());
|
||
var n = new Pd(i);
|
||
return this.writeGeometryText(n, e)
|
||
}, e.prototype.writeGeometryText = function (t, e) {
|
||
return _v(kc(t, !0, e))
|
||
}, e
|
||
}(Ad), wv = [null, "http://www.opengis.net/wms"], bv = pp(wv, {
|
||
Service: sp(function (t, e) {
|
||
return fp({}, Ev, t, e)
|
||
}), Capability: sp(function (t, e) {
|
||
return fp({}, Cv, t, e)
|
||
})
|
||
}), Cv = pp(wv, {
|
||
Request: sp(function (t, e) {
|
||
return fp({}, Av, t, e)
|
||
}), Exception: sp(function (t, e) {
|
||
return fp([], Lv, t, e)
|
||
}), Layer: sp(function (t, e) {
|
||
return fp({}, Iv, t, e)
|
||
})
|
||
}), Sv = function (t) {
|
||
function e() {
|
||
t.call(this), this.version = void 0
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.readFromDocument = function (t) {
|
||
for (var e = t.firstChild; e; e = e.nextSibling) if (e.nodeType == Node.ELEMENT_NODE) return this.readFromNode(e);
|
||
return null
|
||
}, e.prototype.readFromNode = function (t) {
|
||
this.version = t.getAttribute("version").trim();
|
||
var e = fp({version: this.version}, bv, t, []);
|
||
return e || null
|
||
}, e
|
||
}(bm), Ev = pp(wv, {
|
||
Name: sp(Lp),
|
||
Title: sp(Lp),
|
||
Abstract: sp(Lp),
|
||
KeywordList: sp(Vv),
|
||
OnlineResource: sp(xm),
|
||
ContactInformation: sp(function (t, e) {
|
||
return fp({}, Tv, t, e)
|
||
}),
|
||
Fees: sp(Lp),
|
||
AccessConstraints: sp(Lp),
|
||
LayerLimit: sp(Rp),
|
||
MaxWidth: sp(Rp),
|
||
MaxHeight: sp(Rp)
|
||
}), Tv = pp(wv, {
|
||
ContactPersonPrimary: sp(function (t, e) {
|
||
return fp({}, Rv, t, e)
|
||
}), ContactPosition: sp(Lp), ContactAddress: sp(function (t, e) {
|
||
return fp({}, Pv, t, e)
|
||
}), ContactVoiceTelephone: sp(Lp), ContactFacsimileTelephone: sp(Lp), ContactElectronicMailAddress: sp(Lp)
|
||
}), Rv = pp(wv, {ContactPerson: sp(Lp), ContactOrganization: sp(Lp)}), Pv = pp(wv, {
|
||
AddressType: sp(Lp),
|
||
Address: sp(Lp),
|
||
City: sp(Lp),
|
||
StateOrProvince: sp(Lp),
|
||
PostCode: sp(Lp),
|
||
Country: sp(Lp)
|
||
}), Lv = pp(wv, {Format: rp(Lp)}), Iv = pp(wv, {
|
||
Name: sp(Lp),
|
||
Title: sp(Lp),
|
||
Abstract: sp(Lp),
|
||
KeywordList: sp(Vv),
|
||
CRS: np(Lp),
|
||
EX_GeographicBoundingBox: sp(function (t, e) {
|
||
var i = fp({}, Mv, t, e);
|
||
if (!i) return;
|
||
var r = i.westBoundLongitude, o = i.southBoundLatitude, n = i.eastBoundLongitude,
|
||
s = i.northBoundLatitude;
|
||
if (void 0 === r || void 0 === o || void 0 === n || void 0 === s) return;
|
||
return [r, o, n, s]
|
||
}),
|
||
BoundingBox: np(function (t, e) {
|
||
var i = [Tp(t.getAttribute("minx")), Tp(t.getAttribute("miny")), Tp(t.getAttribute("maxx")), Tp(t.getAttribute("maxy"))],
|
||
r = [Tp(t.getAttribute("resx")), Tp(t.getAttribute("resy"))];
|
||
return {crs: t.getAttribute("CRS"), extent: i, res: r}
|
||
}),
|
||
Dimension: np(function (t, e) {
|
||
return {
|
||
name: t.getAttribute("name"),
|
||
units: t.getAttribute("units"),
|
||
unitSymbol: t.getAttribute("unitSymbol"),
|
||
default: t.getAttribute("default"),
|
||
multipleValues: Cp(t.getAttribute("multipleValues")),
|
||
nearestValue: Cp(t.getAttribute("nearestValue")),
|
||
current: Cp(t.getAttribute("current")),
|
||
values: Lp(t)
|
||
}
|
||
}),
|
||
Attribution: sp(function (t, e) {
|
||
return fp({}, Ov, t, e)
|
||
}),
|
||
AuthorityURL: np(function (t, e) {
|
||
var i = zv(t, e);
|
||
if (i) return i.name = t.getAttribute("name"), i;
|
||
return
|
||
}),
|
||
Identifier: np(Lp),
|
||
MetadataURL: np(function (t, e) {
|
||
var i = zv(t, e);
|
||
if (i) return i.type = t.getAttribute("type"), i;
|
||
return
|
||
}),
|
||
DataURL: np(zv),
|
||
FeatureListURL: np(zv),
|
||
Style: np(function (t, e) {
|
||
return fp({}, Dv, t, e)
|
||
}),
|
||
MinScaleDenominator: sp(Ep),
|
||
MaxScaleDenominator: sp(Ep),
|
||
Layer: np(function (t, e) {
|
||
var i = e[e.length - 1], r = fp({}, Iv, t, e);
|
||
if (!r) return;
|
||
var o = Cp(t.getAttribute("queryable"));
|
||
void 0 === o && (o = i.queryable);
|
||
r.queryable = void 0 !== o && o;
|
||
var n = Pp(t.getAttribute("cascaded"));
|
||
void 0 === n && (n = i.cascaded);
|
||
r.cascaded = n;
|
||
var s = Cp(t.getAttribute("opaque"));
|
||
void 0 === s && (s = i.opaque);
|
||
r.opaque = void 0 !== s && s;
|
||
var a = Cp(t.getAttribute("noSubsets"));
|
||
void 0 === a && (a = i.noSubsets);
|
||
r.noSubsets = void 0 !== a && a;
|
||
var l = Tp(t.getAttribute("fixedWidth"));
|
||
l || (l = i.fixedWidth);
|
||
r.fixedWidth = l;
|
||
var h = Tp(t.getAttribute("fixedHeight"));
|
||
h || (h = i.fixedHeight);
|
||
r.fixedHeight = h, ["Style", "CRS", "AuthorityURL"].forEach(function (t) {
|
||
if (t in i) {
|
||
var e = r[t] || [];
|
||
r[t] = e.concat(i[t])
|
||
}
|
||
});
|
||
return ["EX_GeographicBoundingBox", "BoundingBox", "Dimension", "Attribution", "MinScaleDenominator", "MaxScaleDenominator"].forEach(function (t) {
|
||
if (!(t in r)) {
|
||
var e = i[t];
|
||
r[t] = e
|
||
}
|
||
}), r
|
||
})
|
||
}), Ov = pp(wv, {Title: sp(Lp), OnlineResource: sp(xm), LogoURL: sp(Bv)}), Mv = pp(wv, {
|
||
westBoundLongitude: sp(Ep),
|
||
eastBoundLongitude: sp(Ep),
|
||
southBoundLatitude: sp(Ep),
|
||
northBoundLatitude: sp(Ep)
|
||
}), Av = pp(wv, {GetCapabilities: sp(Uv), GetMap: sp(Uv), GetFeatureInfo: sp(Uv)}), kv = pp(wv, {
|
||
Format: np(Lp), DCPType: np(function (t, e) {
|
||
return fp({}, Fv, t, e)
|
||
})
|
||
}), Fv = pp(wv, {
|
||
HTTP: sp(function (t, e) {
|
||
return fp({}, Nv, t, e)
|
||
})
|
||
}), Nv = pp(wv, {Get: sp(zv), Post: sp(zv)}), Dv = pp(wv, {
|
||
Name: sp(Lp),
|
||
Title: sp(Lp),
|
||
Abstract: sp(Lp),
|
||
LegendURL: np(Bv),
|
||
StyleSheetURL: sp(zv),
|
||
StyleURL: sp(zv)
|
||
}), Gv = pp(wv, {Format: sp(Lp), OnlineResource: sp(xm)}), jv = pp(wv, {Keyword: rp(Lp)});
|
||
|
||
function zv(t, e) {
|
||
return fp({}, Gv, t, e)
|
||
}
|
||
|
||
function Uv(t, e) {
|
||
return fp({}, kv, t, e)
|
||
}
|
||
|
||
function Bv(t, e) {
|
||
var i = zv(t, e);
|
||
if (i) {
|
||
var r = [Pp(t.getAttribute("width")), Pp(t.getAttribute("height"))];
|
||
return i.size = r, i
|
||
}
|
||
}
|
||
|
||
function Vv(t, e) {
|
||
return fp([], jv, t, e)
|
||
}
|
||
|
||
var Yv = Sv, Wv = function (t) {
|
||
function e(e) {
|
||
t.call(this);
|
||
var i = e || {};
|
||
this.featureNS_ = "http://mapserver.gis.umn.edu/mapserver", this.gmlFormat_ = new Wp, this.layers_ = i.layers ? i.layers : null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getLayers = function () {
|
||
return this.layers_
|
||
}, e.prototype.setLayers = function (t) {
|
||
this.layers_ = t
|
||
}, e.prototype.readFeatures_ = function (t, e) {
|
||
t.setAttribute("namespaceURI", this.featureNS_);
|
||
var i = t.localName, r = [];
|
||
if (0 === t.childNodes.length) return r;
|
||
if ("msGMLOutput" == i) for (var o = 0, n = t.childNodes.length; o < n; o++) {
|
||
var s = t.childNodes[o];
|
||
if (s.nodeType === Node.ELEMENT_NODE) {
|
||
var a = s, l = e[0], h = a.localName.replace("_layer", "");
|
||
if (!this.layers_ || K(this.layers_, h)) {
|
||
var u = h + "_feature";
|
||
l.featureType = u, l.featureNS = this.featureNS_;
|
||
var c = {};
|
||
c[u] = rp(this.gmlFormat_.readFeatureElement, this.gmlFormat_);
|
||
var p = pp([l.featureNS, null], c);
|
||
a.setAttribute("namespaceURI", this.featureNS_);
|
||
var d = fp([], p, a, e, this.gmlFormat_);
|
||
d && Q(r, d)
|
||
}
|
||
}
|
||
}
|
||
if ("FeatureCollection" == i) {
|
||
var f = fp([], this.gmlFormat_.FEATURE_COLLECTION_PARSERS, t, [{}], this.gmlFormat_);
|
||
f && (r = f)
|
||
}
|
||
return r
|
||
}, e.prototype.readFeaturesFromNode = function (t, e) {
|
||
var i = {};
|
||
return e && p(i, this.getReadOptions(t, e)), this.readFeatures_(t, [i])
|
||
}, e
|
||
}(yp), Hv = [null, "http://www.opengis.net/wmts/1.0"], Xv = [null, "http://www.opengis.net/ows/1.1"],
|
||
qv = pp(Hv, {
|
||
Contents: sp(function (t, e) {
|
||
return fp({}, Kv, t, e)
|
||
})
|
||
}), Zv = function (t) {
|
||
function e() {
|
||
t.call(this), this.owsParser_ = new jm
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.readFromDocument = function (t) {
|
||
for (var e = t.firstChild; e; e = e.nextSibling) if (e.nodeType == Node.ELEMENT_NODE) return this.readFromNode(e);
|
||
return null
|
||
}, e.prototype.readFromNode = function (t) {
|
||
var e = t.getAttribute("version").trim(), i = this.owsParser_.readFromNode(t);
|
||
return i ? (i.version = e, (i = fp(i, qv, t, [])) || null) : null
|
||
}, e
|
||
}(bm), Kv = pp(Hv, {
|
||
Layer: np(function (t, e) {
|
||
return fp({}, Jv, t, e)
|
||
}), TileMatrixSet: np(function (t, e) {
|
||
return fp({}, o_, t, e)
|
||
})
|
||
}), Jv = pp(Hv, {
|
||
Style: np(function (t, e) {
|
||
var i = fp({}, $v, t, e);
|
||
if (!i) return;
|
||
var r = "true" === t.getAttribute("isDefault");
|
||
return i.isDefault = r, i
|
||
}), Format: np(Lp), TileMatrixSetLink: np(function (t, e) {
|
||
return fp({}, Qv, t, e)
|
||
}), Dimension: np(function (t, e) {
|
||
return fp({}, i_, t, e)
|
||
}), ResourceURL: np(function (t, e) {
|
||
var i = t.getAttribute("format"), r = t.getAttribute("template"), o = t.getAttribute("resourceType"),
|
||
n = {};
|
||
i && (n.format = i);
|
||
r && (n.template = r);
|
||
o && (n.resourceType = o);
|
||
return n
|
||
})
|
||
}, pp(Xv, {
|
||
Title: sp(Lp), Abstract: sp(Lp), WGS84BoundingBox: sp(function (t, e) {
|
||
var i = fp([], r_, t, e);
|
||
if (2 != i.length) return;
|
||
return lt(i)
|
||
}), Identifier: sp(Lp)
|
||
})), $v = pp(Hv, {
|
||
LegendURL: np(function (t, e) {
|
||
var i = {};
|
||
return i.format = t.getAttribute("format"), i.href = xm(t), i
|
||
})
|
||
}, pp(Xv, {Title: sp(Lp), Identifier: sp(Lp)})), Qv = pp(Hv, {
|
||
TileMatrixSet: sp(Lp), TileMatrixSetLimits: sp(function (t, e) {
|
||
return fp([], t_, t, e)
|
||
})
|
||
}), t_ = pp(Hv, {
|
||
TileMatrixLimits: rp(function (t, e) {
|
||
return fp({}, e_, t, e)
|
||
})
|
||
}), e_ = pp(Hv, {
|
||
TileMatrix: sp(Lp),
|
||
MinTileRow: sp(Rp),
|
||
MaxTileRow: sp(Rp),
|
||
MinTileCol: sp(Rp),
|
||
MaxTileCol: sp(Rp)
|
||
}), i_ = pp(Hv, {Default: sp(Lp), Value: np(Lp)}, pp(Xv, {Identifier: sp(Lp)})),
|
||
r_ = pp(Xv, {LowerCorner: rp(s_), UpperCorner: rp(s_)}), o_ = pp(Hv, {
|
||
WellKnownScaleSet: sp(Lp), TileMatrix: np(function (t, e) {
|
||
return fp({}, n_, t, e)
|
||
})
|
||
}, pp(Xv, {SupportedCRS: sp(Lp), Identifier: sp(Lp)})), n_ = pp(Hv, {
|
||
TopLeftCorner: sp(s_),
|
||
ScaleDenominator: sp(Ep),
|
||
TileWidth: sp(Rp),
|
||
TileHeight: sp(Rp),
|
||
MatrixWidth: sp(Rp),
|
||
MatrixHeight: sp(Rp)
|
||
}, pp(Xv, {Identifier: sp(Lp)}));
|
||
|
||
function s_(t, e) {
|
||
var i = Lp(t).split(/\s+/);
|
||
if (i && 2 == i.length) {
|
||
var r = +i[0], o = +i[1];
|
||
if (!isNaN(r) && !isNaN(o)) return [r, o]
|
||
}
|
||
}
|
||
|
||
var a_ = Zv, l_ = function (t) {
|
||
function e(e, i, r) {
|
||
if (t.call(this), void 0 !== r && void 0 === i) this.setFlatCoordinates(r, e); else {
|
||
var o = i || 0;
|
||
this.setCenterAndRadius(e, o, r)
|
||
}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.clone = function () {
|
||
return new e(this.flatCoordinates.slice(), void 0, this.layout)
|
||
}, e.prototype.closestPointXY = function (t, e, i, r) {
|
||
var o = this.flatCoordinates, n = t - o[0], s = e - o[1], a = n * n + s * s;
|
||
if (a < r) {
|
||
if (0 === a) for (var l = 0; l < this.stride; ++l) i[l] = o[l]; else {
|
||
var h = this.getRadius() / Math.sqrt(a);
|
||
i[0] = o[0] + h * n, i[1] = o[1] + h * s;
|
||
for (var u = 2; u < this.stride; ++u) i[u] = o[u]
|
||
}
|
||
return i.length = this.stride, a
|
||
}
|
||
return r
|
||
}, e.prototype.containsXY = function (t, e) {
|
||
var i = this.flatCoordinates, r = t - i[0], o = e - i[1];
|
||
return r * r + o * o <= this.getRadiusSquared_()
|
||
}, e.prototype.getCenter = function () {
|
||
return this.flatCoordinates.slice(0, this.stride)
|
||
}, e.prototype.computeExtent = function (t) {
|
||
var e = this.flatCoordinates, i = e[this.stride] - e[0];
|
||
return yt(e[0] - i, e[1] - i, e[0] + i, e[1] + i, t)
|
||
}, e.prototype.getRadius = function () {
|
||
return Math.sqrt(this.getRadiusSquared_())
|
||
}, e.prototype.getRadiusSquared_ = function () {
|
||
var t = this.flatCoordinates[this.stride] - this.flatCoordinates[0],
|
||
e = this.flatCoordinates[this.stride + 1] - this.flatCoordinates[1];
|
||
return t * t + e * e
|
||
}, e.prototype.getType = function () {
|
||
return Zt.CIRCLE
|
||
}, e.prototype.intersectsExtent = function (t) {
|
||
if (Bt(t, this.getExtent())) {
|
||
var e = this.getCenter();
|
||
return t[0] <= e[0] && t[2] >= e[0] || (t[1] <= e[1] && t[3] >= e[1] || Lt(t, this.intersectsCoordinate, this))
|
||
}
|
||
return !1
|
||
}, e.prototype.setCenter = function (t) {
|
||
var e = this.stride, i = this.flatCoordinates[e] - this.flatCoordinates[0], r = t.slice();
|
||
r[e] = r[0] + i;
|
||
for (var o = 1; o < e; ++o) r[e + o] = t[o];
|
||
this.setFlatCoordinates(this.layout, r), this.changed()
|
||
}, e.prototype.setCenterAndRadius = function (t, e, i) {
|
||
this.setLayout(i, t, 0), this.flatCoordinates || (this.flatCoordinates = []);
|
||
var r = this.flatCoordinates, o = Ai(r, 0, t, this.stride);
|
||
r[o++] = r[0] + e;
|
||
for (var n = 1, s = this.stride; n < s; ++n) r[o++] = r[n];
|
||
r.length = o, this.changed()
|
||
}, e.prototype.getCoordinates = function () {
|
||
return null
|
||
}, e.prototype.setCoordinates = function (t, e) {
|
||
}, e.prototype.setRadius = function (t) {
|
||
this.flatCoordinates[this.stride] = this.flatCoordinates[0] + t, this.changed()
|
||
}, e
|
||
}(bi);
|
||
l_.prototype.transform;
|
||
var h_ = l_, u_ = "addfeatures", c_ = function (t) {
|
||
function e(e, i, r, o) {
|
||
t.call(this, e), this.features = r, this.file = i, this.projection = o
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A);
|
||
|
||
function p_(t) {
|
||
for (var e = t.dataTransfer.files, i = 0, r = e.length; i < r; ++i) {
|
||
var o = e.item(i), n = new FileReader;
|
||
n.addEventListener(F.LOAD, this.handleResult_.bind(this, o)), n.readAsText(o)
|
||
}
|
||
}
|
||
|
||
function d_(t) {
|
||
t.stopPropagation(), t.preventDefault(), t.dataTransfer.dropEffect = "copy"
|
||
}
|
||
|
||
var f_ = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {handleEvent: P}), this.formatConstructors_ = i.formatConstructors ? i.formatConstructors : [], this.projection_ = i.projection ? We(i.projection) : null, this.dropListenKeys_ = null, this.source_ = i.source || null, this.target = i.target ? i.target : null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleResult_ = function (t, e) {
|
||
var i = e.target.result, r = this.getMap(), o = this.projection_;
|
||
o || (o = r.getView().getProjection());
|
||
for (var n = this.formatConstructors_, s = [], a = 0, l = n.length; a < l; ++a) {
|
||
var h = new n[a];
|
||
if ((s = this.tryReadFeatures_(h, i, {featureProjection: o})) && s.length > 0) break
|
||
}
|
||
this.source_ && (this.source_.clear(), this.source_.addFeatures(s)), this.dispatchEvent(new c_(u_, t, s, o))
|
||
}, e.prototype.registerListeners_ = function () {
|
||
var t = this.getMap();
|
||
if (t) {
|
||
var e = this.target ? this.target : t.getViewport();
|
||
this.dropListenKeys_ = [w(e, F.DROP, p_, this), w(e, F.DRAGENTER, d_, this), w(e, F.DRAGOVER, d_, this), w(e, F.DROP, d_, this)]
|
||
}
|
||
}, e.prototype.setActive = function (e) {
|
||
t.prototype.setActive.call(this, e), e ? this.registerListeners_() : this.unregisterListeners_()
|
||
}, e.prototype.setMap = function (e) {
|
||
this.unregisterListeners_(), t.prototype.setMap.call(this, e), this.getActive() && this.registerListeners_()
|
||
}, e.prototype.tryReadFeatures_ = function (t, e, i) {
|
||
try {
|
||
return t.readFeatures(e, i)
|
||
} catch (t) {
|
||
return null
|
||
}
|
||
}, e.prototype.unregisterListeners_ = function () {
|
||
this.dropListenKeys_ && (this.dropListenKeys_.forEach(S), this.dropListenKeys_ = null)
|
||
}, e
|
||
}(zs), g_ = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, i), this.condition_ = i.condition ? i.condition : $s, this.lastAngle_ = void 0, this.lastMagnitude_ = void 0, this.lastScaleDelta_ = 0, this.duration_ = void 0 !== i.duration ? i.duration : 400
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleDragEvent = function (t) {
|
||
if (ta(t)) {
|
||
var e = t.map, i = e.getSize(), r = t.pixel, o = r[0] - i[0] / 2, n = i[1] / 2 - r[1],
|
||
s = Math.atan2(n, o), a = Math.sqrt(o * o + n * n), l = e.getView();
|
||
if (l.getConstraints().rotation !== qn && void 0 !== this.lastAngle_) {
|
||
var h = s - this.lastAngle_;
|
||
Ns(l, l.getRotation() - h)
|
||
}
|
||
if (this.lastAngle_ = s, void 0 !== this.lastMagnitude_) {
|
||
var u = this.lastMagnitude_ * (l.getResolution() / a);
|
||
js(l, u)
|
||
}
|
||
void 0 !== this.lastMagnitude_ && (this.lastScaleDelta_ = this.lastMagnitude_ / a), this.lastMagnitude_ = a
|
||
}
|
||
}, e.prototype.handleUpEvent = function (t) {
|
||
if (!ta(t)) return !0;
|
||
var e = t.map.getView();
|
||
e.setHint($n.INTERACTING, -1);
|
||
var i = this.lastScaleDelta_ - 1;
|
||
return Fs(e, e.getRotation()), Ds(e, e.getResolution(), void 0, this.duration_, i), this.lastScaleDelta_ = 0, !1
|
||
}, e.prototype.handleDownEvent = function (t) {
|
||
return !!ta(t) && (!!this.condition_(t) && (t.map.getView().setHint($n.INTERACTING, 1), this.lastAngle_ = void 0, this.lastMagnitude_ = void 0, !0))
|
||
}, e
|
||
}(ra), m_ = "renderOrder", y_ = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = p({}, i);
|
||
delete r.style, delete r.renderBuffer, delete r.updateWhileAnimating, delete r.updateWhileInteracting, t.call(this, r), this.declutter_ = void 0 !== i.declutter && i.declutter, this.renderBuffer_ = void 0 !== i.renderBuffer ? i.renderBuffer : 100, this.style_ = null, this.styleFunction_ = void 0, this.setStyle(i.style), this.updateWhileAnimating_ = void 0 !== i.updateWhileAnimating && i.updateWhileAnimating, this.updateWhileInteracting_ = void 0 !== i.updateWhileInteracting && i.updateWhileInteracting, this.renderMode_ = i.renderMode || Ea.VECTOR, this.type = Vo.VECTOR
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getDeclutter = function () {
|
||
return this.declutter_
|
||
}, e.prototype.setDeclutter = function (t) {
|
||
this.declutter_ = t
|
||
}, e.prototype.getRenderBuffer = function () {
|
||
return this.renderBuffer_
|
||
}, e.prototype.getRenderOrder = function () {
|
||
return this.get(m_)
|
||
}, e.prototype.getStyle = function () {
|
||
return this.style_
|
||
}, e.prototype.getStyleFunction = function () {
|
||
return this.styleFunction_
|
||
}, e.prototype.getUpdateWhileAnimating = function () {
|
||
return this.updateWhileAnimating_
|
||
}, e.prototype.getUpdateWhileInteracting = function () {
|
||
return this.updateWhileInteracting_
|
||
}, e.prototype.setRenderOrder = function (t) {
|
||
this.set(m_, t)
|
||
}, e.prototype.setStyle = function (t) {
|
||
this.style_ = void 0 !== t ? t : Qd, this.styleFunction_ = null === t ? void 0 : Jd(this.style_), this.changed()
|
||
}, e.prototype.getRenderMode = function () {
|
||
return this.renderMode_
|
||
}, e
|
||
}(Ts);
|
||
y_.prototype.getSource;
|
||
var v_ = y_;
|
||
|
||
function __(t, e) {
|
||
return [[-1 / 0, -1 / 0, 1 / 0, 1 / 0]]
|
||
}
|
||
|
||
var x_ = {
|
||
ADDFEATURE: "addfeature",
|
||
CHANGEFEATURE: "changefeature",
|
||
CLEAR: "clear",
|
||
REMOVEFEATURE: "removefeature"
|
||
}, w_ = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e), this.feature = i
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A), b_ = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {
|
||
attributions: i.attributions,
|
||
projection: void 0,
|
||
state: hs.READY,
|
||
wrapX: void 0 === i.wrapX || i.wrapX
|
||
}), this.loader_ = I, this.format_ = i.format, this.overlaps_ = null == i.overlaps || i.overlaps, this.url_ = i.url, void 0 !== i.loader ? this.loader_ = i.loader : void 0 !== this.url_ && (W(this.format_, 7), this.loader_ = yh(this.url_, this.format_)), this.strategy_ = void 0 !== i.strategy ? i.strategy : __;
|
||
var r, o, n = void 0 === i.useSpatialIndex || i.useSpatialIndex;
|
||
this.featuresRtree_ = n ? new Eu : null, this.loadedExtentsRtree_ = new Eu, this.nullGeometryFeatures_ = {}, this.idIndex_ = {}, this.undefIdIndex_ = {}, this.featureChangeKeys_ = {}, this.featuresCollection_ = null, Array.isArray(i.features) ? o = i.features : i.features && (o = (r = i.features).getArray()), n || void 0 !== r || (r = new Y(o)), void 0 !== o && this.addFeaturesInternal(o), void 0 !== r && this.bindFeaturesCollection_(r)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.addFeature = function (t) {
|
||
this.addFeatureInternal(t), this.changed()
|
||
}, e.prototype.addFeatureInternal = function (t) {
|
||
var e = a(t);
|
||
if (this.addToIndex_(e, t)) {
|
||
this.setupChangeEvents_(e, t);
|
||
var i = t.getGeometry();
|
||
if (i) {
|
||
var r = i.getExtent();
|
||
this.featuresRtree_ && this.featuresRtree_.insert(r, t)
|
||
} else this.nullGeometryFeatures_[e] = t;
|
||
this.dispatchEvent(new w_(x_.ADDFEATURE, t))
|
||
}
|
||
}, e.prototype.setupChangeEvents_ = function (t, e) {
|
||
this.featureChangeKeys_[t] = [w(e, F.CHANGE, this.handleFeatureChange_, this), w(e, c.PROPERTYCHANGE, this.handleFeatureChange_, this)]
|
||
}, e.prototype.addToIndex_ = function (t, e) {
|
||
var i = !0, r = e.getId();
|
||
return void 0 !== r ? r.toString() in this.idIndex_ ? i = !1 : this.idIndex_[r.toString()] = e : (W(!(t in this.undefIdIndex_), 30), this.undefIdIndex_[t] = e), i
|
||
}, e.prototype.addFeatures = function (t) {
|
||
this.addFeaturesInternal(t), this.changed()
|
||
}, e.prototype.addFeaturesInternal = function (t) {
|
||
for (var e = [], i = [], r = [], o = 0, n = t.length; o < n; o++) {
|
||
var s = t[o], l = a(s);
|
||
this.addToIndex_(l, s) && i.push(s)
|
||
}
|
||
for (var h = 0, u = i.length; h < u; h++) {
|
||
var c = i[h], p = a(c);
|
||
this.setupChangeEvents_(p, c);
|
||
var d = c.getGeometry();
|
||
if (d) {
|
||
var f = d.getExtent();
|
||
e.push(f), r.push(c)
|
||
} else this.nullGeometryFeatures_[p] = c
|
||
}
|
||
this.featuresRtree_ && this.featuresRtree_.load(e, r);
|
||
for (var g = 0, m = i.length; g < m; g++) this.dispatchEvent(new w_(x_.ADDFEATURE, i[g]))
|
||
}, e.prototype.bindFeaturesCollection_ = function (t) {
|
||
var e = !1;
|
||
w(this, x_.ADDFEATURE, function (i) {
|
||
e || (e = !0, t.push(i.feature), e = !1)
|
||
}), w(this, x_.REMOVEFEATURE, function (i) {
|
||
e || (e = !0, t.remove(i.feature), e = !1)
|
||
}), w(t, u.ADD, function (t) {
|
||
e || (e = !0, this.addFeature(t.element), e = !1)
|
||
}, this), w(t, u.REMOVE, function (t) {
|
||
e || (e = !0, this.removeFeature(t.element), e = !1)
|
||
}, this), this.featuresCollection_ = t
|
||
}, e.prototype.clear = function (t) {
|
||
if (t) {
|
||
for (var e in this.featureChangeKeys_) {
|
||
this.featureChangeKeys_[e].forEach(S)
|
||
}
|
||
this.featuresCollection_ || (this.featureChangeKeys_ = {}, this.idIndex_ = {}, this.undefIdIndex_ = {})
|
||
} else if (this.featuresRtree_) for (var i in this.featuresRtree_.forEach(this.removeFeatureInternal, this), this.nullGeometryFeatures_) this.removeFeatureInternal(this.nullGeometryFeatures_[i]);
|
||
this.featuresCollection_ && this.featuresCollection_.clear(), this.featuresRtree_ && this.featuresRtree_.clear(), this.loadedExtentsRtree_.clear(), this.nullGeometryFeatures_ = {};
|
||
var r = new w_(x_.CLEAR);
|
||
this.dispatchEvent(r), this.changed()
|
||
}, e.prototype.forEachFeature = function (t) {
|
||
if (this.featuresRtree_) return this.featuresRtree_.forEach(t);
|
||
this.featuresCollection_ && this.featuresCollection_.forEach(t)
|
||
}, e.prototype.forEachFeatureAtCoordinateDirect = function (t, e) {
|
||
var i = [t[0], t[1], t[0], t[1]];
|
||
return this.forEachFeatureInExtent(i, function (i) {
|
||
return i.getGeometry().intersectsCoordinate(t) ? e(i) : void 0
|
||
})
|
||
}, e.prototype.forEachFeatureInExtent = function (t, e) {
|
||
if (this.featuresRtree_) return this.featuresRtree_.forEachInExtent(t, e);
|
||
this.featuresCollection_ && this.featuresCollection_.forEach(e)
|
||
}, e.prototype.forEachFeatureIntersectingExtent = function (t, e) {
|
||
return this.forEachFeatureInExtent(t, function (i) {
|
||
if (i.getGeometry().intersectsExtent(t)) {
|
||
var r = e(i);
|
||
if (r) return r
|
||
}
|
||
})
|
||
}, e.prototype.getFeaturesCollection = function () {
|
||
return this.featuresCollection_
|
||
}, e.prototype.getFeatures = function () {
|
||
var t;
|
||
return this.featuresCollection_ ? t = this.featuresCollection_.getArray() : this.featuresRtree_ && (t = this.featuresRtree_.getAll(), g(this.nullGeometryFeatures_) || Q(t, f(this.nullGeometryFeatures_))), t
|
||
}, e.prototype.getFeaturesAtCoordinate = function (t) {
|
||
var e = [];
|
||
return this.forEachFeatureAtCoordinateDirect(t, function (t) {
|
||
e.push(t)
|
||
}), e
|
||
}, e.prototype.getFeaturesInExtent = function (t) {
|
||
return this.featuresRtree_.getInExtent(t)
|
||
}, e.prototype.getClosestFeatureToCoordinate = function (t, e) {
|
||
var i = t[0], r = t[1], o = null, n = [NaN, NaN], s = 1 / 0, a = [-1 / 0, -1 / 0, 1 / 0, 1 / 0],
|
||
l = e || P;
|
||
return this.featuresRtree_.forEachInExtent(a, function (t) {
|
||
if (l(t)) {
|
||
var e = t.getGeometry(), h = s;
|
||
if ((s = e.closestPointXY(i, r, n, s)) < h) {
|
||
o = t;
|
||
var u = Math.sqrt(s);
|
||
a[0] = i - u, a[1] = r - u, a[2] = i + u, a[3] = r + u
|
||
}
|
||
}
|
||
}), o
|
||
}, e.prototype.getExtent = function (t) {
|
||
return this.featuresRtree_.getExtent(t)
|
||
}, e.prototype.getFeatureById = function (t) {
|
||
var e = this.idIndex_[t.toString()];
|
||
return void 0 !== e ? e : null
|
||
}, e.prototype.getFormat = function () {
|
||
return this.format_
|
||
}, e.prototype.getOverlaps = function () {
|
||
return this.overlaps_
|
||
}, e.prototype.getUrl = function () {
|
||
return this.url_
|
||
}, e.prototype.handleFeatureChange_ = function (t) {
|
||
var e = t.target, i = a(e), r = e.getGeometry();
|
||
if (r) {
|
||
var o = r.getExtent();
|
||
i in this.nullGeometryFeatures_ ? (delete this.nullGeometryFeatures_[i], this.featuresRtree_ && this.featuresRtree_.insert(o, e)) : this.featuresRtree_ && this.featuresRtree_.update(o, e)
|
||
} else i in this.nullGeometryFeatures_ || (this.featuresRtree_ && this.featuresRtree_.remove(e), this.nullGeometryFeatures_[i] = e);
|
||
var n = e.getId();
|
||
if (void 0 !== n) {
|
||
var s = n.toString();
|
||
i in this.undefIdIndex_ ? (delete this.undefIdIndex_[i], this.idIndex_[s] = e) : this.idIndex_[s] !== e && (this.removeFromIdIndex_(e), this.idIndex_[s] = e)
|
||
} else i in this.undefIdIndex_ || (this.removeFromIdIndex_(e), this.undefIdIndex_[i] = e);
|
||
this.changed(), this.dispatchEvent(new w_(x_.CHANGEFEATURE, e))
|
||
}, e.prototype.hasFeature = function (t) {
|
||
var e = t.getId();
|
||
return void 0 !== e ? e in this.idIndex_ : a(t) in this.undefIdIndex_
|
||
}, e.prototype.isEmpty = function () {
|
||
return this.featuresRtree_.isEmpty() && g(this.nullGeometryFeatures_)
|
||
}, e.prototype.loadFeatures = function (t, e, i) {
|
||
var r = this, o = this.loadedExtentsRtree_, n = this.strategy_(t, e);
|
||
this.loading = !1;
|
||
for (var s = function (t, s) {
|
||
var a = n[t];
|
||
o.forEachInExtent(a, function (t) {
|
||
return dt(t.extent, a)
|
||
}) || (r.loader_.call(r, a, e, i), o.insert(a, {extent: a.slice()}), r.loading = r.loader_ !== I)
|
||
}, a = 0, l = n.length; a < l; ++a) s(a)
|
||
}, e.prototype.removeLoadedExtent = function (t) {
|
||
var e, i = this.loadedExtentsRtree_;
|
||
i.forEachInExtent(t, function (i) {
|
||
if (bt(i.extent, t)) return e = i, !0
|
||
}), e && i.remove(e)
|
||
}, e.prototype.removeFeature = function (t) {
|
||
var e = a(t);
|
||
e in this.nullGeometryFeatures_ ? delete this.nullGeometryFeatures_[e] : this.featuresRtree_ && this.featuresRtree_.remove(t), this.removeFeatureInternal(t), this.changed()
|
||
}, e.prototype.removeFeatureInternal = function (t) {
|
||
var e = a(t);
|
||
this.featureChangeKeys_[e].forEach(S), delete this.featureChangeKeys_[e];
|
||
var i = t.getId();
|
||
void 0 !== i ? delete this.idIndex_[i.toString()] : delete this.undefIdIndex_[e], this.dispatchEvent(new w_(x_.REMOVEFEATURE, t))
|
||
}, e.prototype.removeFromIdIndex_ = function (t) {
|
||
var e = !1;
|
||
for (var i in this.idIndex_) if (this.idIndex_[i] === t) {
|
||
delete this.idIndex_[i], e = !0;
|
||
break
|
||
}
|
||
return e
|
||
}, e.prototype.setLoader = function (t) {
|
||
this.loader_ = t
|
||
}, e
|
||
}(Yu), C_ = {POINT: "Point", LINE_STRING: "LineString", POLYGON: "Polygon", CIRCLE: "Circle"}, S_ = "drawstart",
|
||
E_ = "drawend", T_ = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e), this.feature = i
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A);
|
||
|
||
function R_() {
|
||
return function (t, e) {
|
||
var i = lt(t), r = [[Ot(i), Mt(i), zt(i), jt(i), Ot(i)]], o = e;
|
||
return o ? o.setCoordinates(r) : o = new fr(r), o
|
||
}
|
||
}
|
||
|
||
var P_ = function (t) {
|
||
function e(e) {
|
||
var i = e;
|
||
i.stopDown || (i.stopDown = L), t.call(this, i), this.shouldHandle_ = !1, this.downPx_ = null, this.downTimeout_, this.lastDragTime_, this.freehand_ = !1, this.source_ = e.source ? e.source : null, this.features_ = e.features ? e.features : null, this.snapTolerance_ = e.snapTolerance ? e.snapTolerance : 12, this.type_ = e.type, this.mode_ = function (t) {
|
||
var e;
|
||
t === Zt.POINT || t === Zt.MULTI_POINT ? e = C_.POINT : t === Zt.LINE_STRING || t === Zt.MULTI_LINE_STRING ? e = C_.LINE_STRING : t === Zt.POLYGON || t === Zt.MULTI_POLYGON ? e = C_.POLYGON : t === Zt.CIRCLE && (e = C_.CIRCLE);
|
||
return e
|
||
}(this.type_), this.stopClick_ = !!e.stopClick, this.minPoints_ = e.minPoints ? e.minPoints : this.mode_ === C_.POLYGON ? 3 : 2, this.maxPoints_ = e.maxPoints ? e.maxPoints : 1 / 0, this.finishCondition_ = e.finishCondition ? e.finishCondition : P;
|
||
var r, o = e.geometryFunction;
|
||
if (!o) if (this.type_ === Zt.CIRCLE) o = function (t, e) {
|
||
var i = e || new h_([NaN, NaN]), r = Vr(t[0], t[1]);
|
||
return i.setCenterAndRadius(t[0], Math.sqrt(r)), i
|
||
}; else {
|
||
var n, s = this.mode_;
|
||
s === C_.POINT ? n = qi : s === C_.LINE_STRING ? n = Jr : s === C_.POLYGON && (n = fr), o = function (t, e) {
|
||
var i = e;
|
||
return i ? s === C_.POLYGON ? t[0].length ? i.setCoordinates([t[0].concat([t[0][0]])]) : i.setCoordinates([]) : i.setCoordinates(t) : i = new n(t), i
|
||
}
|
||
}
|
||
this.geometryFunction_ = o, this.dragVertexDelay_ = void 0 !== e.dragVertexDelay ? e.dragVertexDelay : 500, this.finishCoordinate_ = null, this.sketchFeature_ = null, this.sketchPoint_ = null, this.sketchCoords_ = null, this.sketchLine_ = null, this.sketchLineCoords_ = null, this.squaredClickTolerance_ = e.clickTolerance ? e.clickTolerance * e.clickTolerance : 36, this.overlay_ = new v_({
|
||
source: new b_({
|
||
useSpatialIndex: !1,
|
||
wrapX: !!e.wrapX && e.wrapX
|
||
}), style: e.style ? e.style : (r = tf(), function (t, e) {
|
||
return r[t.getGeometry().getType()]
|
||
}), updateWhileInteracting: !0
|
||
}), this.geometryName_ = e.geometryName, this.condition_ = e.condition ? e.condition : Js, this.freehandCondition_, e.freehand ? this.freehandCondition_ = Hs : this.freehandCondition_ = e.freehandCondition ? e.freehandCondition : $s, w(this, z(As.ACTIVE), this.updateState_, this)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.setMap = function (e) {
|
||
t.prototype.setMap.call(this, e), this.updateState_()
|
||
}, e.prototype.getOverlay = function () {
|
||
return this.overlay_
|
||
}, e.prototype.handleEvent = function (e) {
|
||
e.originalEvent.type === F.CONTEXTMENU && e.preventDefault(), this.freehand_ = this.mode_ !== C_.POINT && this.freehandCondition_(e);
|
||
var i = e.type === Ho.POINTERMOVE, r = !0;
|
||
!this.freehand_ && this.lastDragTime_ && e.type === Ho.POINTERDRAG && (Date.now() - this.lastDragTime_ >= this.dragVertexDelay_ ? (this.downPx_ = e.pixel, this.shouldHandle_ = !this.freehand_, i = !0) : this.lastDragTime_ = void 0, this.shouldHandle_ && void 0 !== this.downTimeout_ && (clearTimeout(this.downTimeout_), this.downTimeout_ = void 0));
|
||
return this.freehand_ && e.type === Ho.POINTERDRAG && null !== this.sketchFeature_ ? (this.addToDrawing_(e), r = !1) : this.freehand_ && e.type === Ho.POINTERDOWN ? r = !1 : i ? (r = e.type === Ho.POINTERMOVE) && this.freehand_ ? r = this.handlePointerMove_(e) : (e.pointerEvent.pointerType == $o || e.type === Ho.POINTERDRAG && void 0 === this.downTimeout_) && this.handlePointerMove_(e) : e.type === Ho.DBLCLICK && (r = !1), t.prototype.handleEvent.call(this, e) && r
|
||
}, e.prototype.handleDownEvent = function (t) {
|
||
return this.shouldHandle_ = !this.freehand_, this.freehand_ ? (this.downPx_ = t.pixel, this.finishCoordinate_ || this.startDrawing_(t), !0) : !!this.condition_(t) && (this.lastDragTime_ = Date.now(), this.downTimeout_ = setTimeout(function () {
|
||
this.handlePointerMove_(new Xo(Ho.POINTERMOVE, t.map, t.pointerEvent, !1, t.frameState))
|
||
}.bind(this), this.dragVertexDelay_), this.downPx_ = t.pixel, !0)
|
||
}, e.prototype.handleUpEvent = function (t) {
|
||
var e = !0;
|
||
this.downTimeout_ && (clearTimeout(this.downTimeout_), this.downTimeout_ = void 0), this.handlePointerMove_(t);
|
||
var i = this.mode_ === C_.CIRCLE;
|
||
return this.shouldHandle_ ? (this.finishCoordinate_ ? this.freehand_ || i ? this.finishDrawing() : this.atFinish_(t) ? this.finishCondition_(t) && this.finishDrawing() : this.addToDrawing_(t) : (this.startDrawing_(t), this.mode_ === C_.POINT && this.finishDrawing()), e = !1) : this.freehand_ && (this.finishCoordinate_ = null, this.abortDrawing_()), !e && this.stopClick_ && t.stopPropagation(), e
|
||
}, e.prototype.handlePointerMove_ = function (t) {
|
||
if (this.downPx_ && (!this.freehand_ && this.shouldHandle_ || this.freehand_ && !this.shouldHandle_)) {
|
||
var e = this.downPx_, i = t.pixel, r = e[0] - i[0], o = e[1] - i[1], n = r * r + o * o;
|
||
if (this.shouldHandle_ = this.freehand_ ? n > this.squaredClickTolerance_ : n <= this.squaredClickTolerance_, !this.shouldHandle_) return !0
|
||
}
|
||
return this.finishCoordinate_ ? this.modifyDrawing_(t) : this.createOrUpdateSketchPoint_(t), !0
|
||
}, e.prototype.atFinish_ = function (t) {
|
||
var e = !1;
|
||
if (this.sketchFeature_) {
|
||
var i = !1, r = [this.finishCoordinate_];
|
||
if (this.mode_ === C_.LINE_STRING) i = this.sketchCoords_.length > this.minPoints_; else if (this.mode_ === C_.POLYGON) {
|
||
var o = this.sketchCoords_;
|
||
i = o[0].length > this.minPoints_, r = [o[0][0], o[0][o[0].length - 2]]
|
||
}
|
||
if (i) for (var n = t.map, s = 0, a = r.length; s < a; s++) {
|
||
var l = r[s], h = n.getPixelFromCoordinate(l), u = t.pixel, c = u[0] - h[0], p = u[1] - h[1],
|
||
d = this.freehand_ ? 1 : this.snapTolerance_;
|
||
if (e = Math.sqrt(c * c + p * p) <= d) {
|
||
this.finishCoordinate_ = l;
|
||
break
|
||
}
|
||
}
|
||
}
|
||
return e
|
||
}, e.prototype.createOrUpdateSketchPoint_ = function (t) {
|
||
var e = t.coordinate.slice();
|
||
this.sketchPoint_ ? this.sketchPoint_.getGeometry().setCoordinates(e) : (this.sketchPoint_ = new X(new qi(e)), this.updateSketchFeatures_())
|
||
}, e.prototype.startDrawing_ = function (t) {
|
||
var e = t.coordinate;
|
||
this.finishCoordinate_ = e, this.mode_ === C_.POINT ? this.sketchCoords_ = e.slice() : this.mode_ === C_.POLYGON ? (this.sketchCoords_ = [[e.slice(), e.slice()]], this.sketchLineCoords_ = this.sketchCoords_[0]) : this.sketchCoords_ = [e.slice(), e.slice()], this.sketchLineCoords_ && (this.sketchLine_ = new X(new Jr(this.sketchLineCoords_)));
|
||
var i = this.geometryFunction_(this.sketchCoords_);
|
||
this.sketchFeature_ = new X, this.geometryName_ && this.sketchFeature_.setGeometryName(this.geometryName_), this.sketchFeature_.setGeometry(i), this.updateSketchFeatures_(), this.dispatchEvent(new T_(S_, this.sketchFeature_))
|
||
}, e.prototype.modifyDrawing_ = function (t) {
|
||
var e, i, r, o = t.coordinate, n = this.sketchFeature_.getGeometry();
|
||
(this.mode_ === C_.POINT ? i = this.sketchCoords_ : this.mode_ === C_.POLYGON ? (i = (e = this.sketchCoords_[0])[e.length - 1], this.atFinish_(t) && (o = this.finishCoordinate_.slice())) : i = (e = this.sketchCoords_)[e.length - 1], i[0] = o[0], i[1] = o[1], this.geometryFunction_(this.sketchCoords_, n), this.sketchPoint_) && this.sketchPoint_.getGeometry().setCoordinates(o);
|
||
if (n.getType() == Zt.POLYGON && this.mode_ !== C_.POLYGON) {
|
||
this.sketchLine_ || (this.sketchLine_ = new X);
|
||
var s = n.getLinearRing(0);
|
||
(r = this.sketchLine_.getGeometry()) ? (r.setFlatCoordinates(s.getLayout(), s.getFlatCoordinates()), r.changed()) : (r = new Jr(s.getFlatCoordinates(), s.getLayout()), this.sketchLine_.setGeometry(r))
|
||
} else this.sketchLineCoords_ && (r = this.sketchLine_.getGeometry()).setCoordinates(this.sketchLineCoords_);
|
||
this.updateSketchFeatures_()
|
||
}, e.prototype.addToDrawing_ = function (t) {
|
||
var e, i, r = t.coordinate, o = this.sketchFeature_.getGeometry();
|
||
this.mode_ === C_.LINE_STRING ? (this.finishCoordinate_ = r.slice(), (i = this.sketchCoords_).length >= this.maxPoints_ && (this.freehand_ ? i.pop() : e = !0), i.push(r.slice()), this.geometryFunction_(i, o)) : this.mode_ === C_.POLYGON && ((i = this.sketchCoords_[0]).length >= this.maxPoints_ && (this.freehand_ ? i.pop() : e = !0), i.push(r.slice()), e && (this.finishCoordinate_ = i[0]), this.geometryFunction_(this.sketchCoords_, o)), this.updateSketchFeatures_(), e && this.finishDrawing()
|
||
}, e.prototype.removeLastPoint = function () {
|
||
if (this.sketchFeature_) {
|
||
var t, e = this.sketchFeature_.getGeometry();
|
||
this.mode_ === C_.LINE_STRING ? ((t = this.sketchCoords_).splice(-2, 1), this.geometryFunction_(t, e), t.length >= 2 && (this.finishCoordinate_ = t[t.length - 2].slice())) : this.mode_ === C_.POLYGON && ((t = this.sketchCoords_[0]).splice(-2, 1), this.sketchLine_.getGeometry().setCoordinates(t), this.geometryFunction_(this.sketchCoords_, e)), 0 === t.length && (this.finishCoordinate_ = null), this.updateSketchFeatures_()
|
||
}
|
||
}, e.prototype.finishDrawing = function () {
|
||
var t = this.abortDrawing_();
|
||
if (t) {
|
||
var e = this.sketchCoords_, i = t.getGeometry();
|
||
this.mode_ === C_.LINE_STRING ? (e.pop(), this.geometryFunction_(e, i)) : this.mode_ === C_.POLYGON && (e[0].pop(), this.geometryFunction_(e, i), e = i.getCoordinates()), this.type_ === Zt.MULTI_POINT ? t.setGeometry(new Gc([e])) : this.type_ === Zt.MULTI_LINE_STRING ? t.setGeometry(new Dc([e])) : this.type_ === Zt.MULTI_POLYGON && t.setGeometry(new zc([e])), this.dispatchEvent(new T_(E_, t)), this.features_ && this.features_.push(t), this.source_ && this.source_.addFeature(t)
|
||
}
|
||
}, e.prototype.abortDrawing_ = function () {
|
||
this.finishCoordinate_ = null;
|
||
var t = this.sketchFeature_;
|
||
return t && (this.sketchFeature_ = null, this.sketchPoint_ = null, this.sketchLine_ = null, this.overlay_.getSource().clear(!0)), t
|
||
}, e.prototype.extend = function (t) {
|
||
var e = t.getGeometry();
|
||
this.sketchFeature_ = t, this.sketchCoords_ = e.getCoordinates();
|
||
var i = this.sketchCoords_[this.sketchCoords_.length - 1];
|
||
this.finishCoordinate_ = i.slice(), this.sketchCoords_.push(i.slice()), this.updateSketchFeatures_(), this.dispatchEvent(new T_(S_, this.sketchFeature_))
|
||
}, e.prototype.updateSketchFeatures_ = function () {
|
||
var t = [];
|
||
this.sketchFeature_ && t.push(this.sketchFeature_), this.sketchLine_ && t.push(this.sketchLine_), this.sketchPoint_ && t.push(this.sketchPoint_);
|
||
var e = this.overlay_.getSource();
|
||
e.clear(!0), e.addFeatures(t)
|
||
}, e.prototype.updateState_ = function () {
|
||
var t = this.getMap(), e = this.getActive();
|
||
t && e || this.abortDrawing_(), this.overlay_.setMap(e ? t : null)
|
||
}, e
|
||
}(ra), L_ = {EXTENTCHANGED: "extentchanged"}, I_ = function (t) {
|
||
function e(e) {
|
||
t.call(this, L_.EXTENTCHANGED), this.extent = e
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A);
|
||
|
||
function O_() {
|
||
var t = tf();
|
||
return function (e, i) {
|
||
return t[Zt.POINT]
|
||
}
|
||
}
|
||
|
||
function M_(t) {
|
||
return function (e) {
|
||
return lt([t, e])
|
||
}
|
||
}
|
||
|
||
function A_(t, e) {
|
||
return t[0] == e[0] ? function (i) {
|
||
return lt([t, [i[0], e[1]]])
|
||
} : t[1] == e[1] ? function (i) {
|
||
return lt([t, [e[0], i[1]]])
|
||
} : null
|
||
}
|
||
|
||
var k_ = function (t) {
|
||
function e(e) {
|
||
var i, r = e || {};
|
||
t.call(this, r), this.extent_ = null, this.pointerHandler_ = null, this.pixelTolerance_ = void 0 !== r.pixelTolerance ? r.pixelTolerance : 10, this.snappedToVertex_ = !1, this.extentFeature_ = null, this.vertexFeature_ = null, e || (e = {}), this.extentOverlay_ = new v_({
|
||
source: new b_({
|
||
useSpatialIndex: !1,
|
||
wrapX: !!e.wrapX
|
||
}), style: e.boxStyle ? e.boxStyle : (i = tf(), function (t, e) {
|
||
return i[Zt.POLYGON]
|
||
}), updateWhileAnimating: !0, updateWhileInteracting: !0
|
||
}), this.vertexOverlay_ = new v_({
|
||
source: new b_({useSpatialIndex: !1, wrapX: !!e.wrapX}),
|
||
style: e.pointerStyle ? e.pointerStyle : O_(),
|
||
updateWhileAnimating: !0,
|
||
updateWhileInteracting: !0
|
||
}), e.extent && this.setExtent(e.extent)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.snapToVertex_ = function (t, e) {
|
||
var i = e.getCoordinateFromPixel(t), r = this.getExtent();
|
||
if (r) {
|
||
var o = function (t) {
|
||
return [[[t[0], t[1]], [t[0], t[3]]], [[t[0], t[3]], [t[2], t[3]]], [[t[2], t[3]], [t[2], t[1]]], [[t[2], t[1]], [t[0], t[1]]]]
|
||
}(r);
|
||
o.sort(function (t, e) {
|
||
return Wr(i, t) - Wr(i, e)
|
||
});
|
||
var n = o[0], s = Dr(i, n), a = e.getPixelFromCoordinate(s);
|
||
if (Yr(t, a) <= this.pixelTolerance_) {
|
||
var l = e.getPixelFromCoordinate(n[0]), h = e.getPixelFromCoordinate(n[1]), u = Vr(a, l),
|
||
c = Vr(a, h), p = Math.sqrt(Math.min(u, c));
|
||
return this.snappedToVertex_ = p <= this.pixelTolerance_, this.snappedToVertex_ && (s = u > c ? n[1] : n[0]), s
|
||
}
|
||
}
|
||
return null
|
||
}, e.prototype.handlePointerMove_ = function (t) {
|
||
var e = t.pixel, i = t.map, r = this.snapToVertex_(e, i);
|
||
r || (r = i.getCoordinateFromPixel(e)), this.createOrUpdatePointerFeature_(r)
|
||
}, e.prototype.createOrUpdateExtentFeature_ = function (t) {
|
||
var e = this.extentFeature_;
|
||
return e ? t ? e.setGeometry(mr(t)) : e.setGeometry(void 0) : (e = new X(t ? mr(t) : {}), this.extentFeature_ = e, this.extentOverlay_.getSource().addFeature(e)), e
|
||
}, e.prototype.createOrUpdatePointerFeature_ = function (t) {
|
||
var e = this.vertexFeature_;
|
||
e ? e.getGeometry().setCoordinates(t) : (e = new X(new qi(t)), this.vertexFeature_ = e, this.vertexOverlay_.getSource().addFeature(e));
|
||
return e
|
||
}, e.prototype.handleEvent = function (e) {
|
||
return !e.pointerEvent || (e.type != Ho.POINTERMOVE || this.handlingDownUpSequence || this.handlePointerMove_(e), t.prototype.handleEvent.call(this, e), !1)
|
||
}, e.prototype.handleDownEvent = function (t) {
|
||
var e = t.pixel, i = t.map, r = this.getExtent(), o = this.snapToVertex_(e, i), n = function (t) {
|
||
var e = null, i = null;
|
||
return t[0] == r[0] ? e = r[2] : t[0] == r[2] && (e = r[0]), t[1] == r[1] ? i = r[3] : t[1] == r[3] && (i = r[1]), null !== e && null !== i ? [e, i] : null
|
||
};
|
||
if (o && r) {
|
||
var s = o[0] == r[0] || o[0] == r[2] ? o[0] : null, a = o[1] == r[1] || o[1] == r[3] ? o[1] : null;
|
||
null !== s && null !== a ? this.pointerHandler_ = M_(n(o)) : null !== s ? this.pointerHandler_ = A_(n([s, r[1]]), n([s, r[3]])) : null !== a && (this.pointerHandler_ = A_(n([r[0], a]), n([r[2], a])))
|
||
} else o = i.getCoordinateFromPixel(e), this.setExtent([o[0], o[1], o[0], o[1]]), this.pointerHandler_ = M_(o);
|
||
return !0
|
||
}, e.prototype.handleDragEvent = function (t) {
|
||
if (this.pointerHandler_) {
|
||
var e = t.coordinate;
|
||
this.setExtent(this.pointerHandler_(e)), this.createOrUpdatePointerFeature_(e)
|
||
}
|
||
return !0
|
||
}, e.prototype.handleUpEvent = function (t) {
|
||
this.pointerHandler_ = null;
|
||
var e = this.getExtent();
|
||
return e && 0 !== It(e) || this.setExtent(null), !1
|
||
}, e.prototype.setMap = function (e) {
|
||
this.extentOverlay_.setMap(e), this.vertexOverlay_.setMap(e), t.prototype.setMap.call(this, e)
|
||
}, e.prototype.getExtent = function () {
|
||
return this.extent_
|
||
}, e.prototype.setExtent = function (t) {
|
||
this.extent_ = t || null, this.createOrUpdateExtentFeature_(t), this.dispatchEvent(new I_(this.extent_))
|
||
}, e
|
||
}(ra), F_ = 1, N_ = "modifystart", D_ = "modifyend", G_ = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, e), this.features = i, this.mapBrowserEvent = r
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A);
|
||
|
||
function j_(t, e) {
|
||
return t.index - e.index
|
||
}
|
||
|
||
function z_(t, e) {
|
||
var i = e.geometry;
|
||
if (i.getType() === Zt.CIRCLE) {
|
||
var r = i;
|
||
if (e.index === F_) {
|
||
var o = Vr(r.getCenter(), t), n = Math.sqrt(o) - r.getRadius();
|
||
return n * n
|
||
}
|
||
}
|
||
return Wr(t, e.segment)
|
||
}
|
||
|
||
function U_(t, e) {
|
||
var i = e.geometry;
|
||
return i.getType() === Zt.CIRCLE && e.index === F_ ? i.getClosestPoint(t) : Dr(t, e.segment)
|
||
}
|
||
|
||
var B_ = function (t) {
|
||
function e(e) {
|
||
var i, r;
|
||
if (t.call(this, e), this.condition_ = e.condition ? e.condition : ea, this.defaultDeleteCondition_ = function (t) {
|
||
return Vs(t) && Ks(t)
|
||
}, this.deleteCondition_ = e.deleteCondition ? e.deleteCondition : this.defaultDeleteCondition_, this.insertVertexCondition_ = e.insertVertexCondition ? e.insertVertexCondition : Hs, this.vertexFeature_ = null, this.vertexSegments_ = null, this.lastPixel_ = [0, 0], this.ignoreNextSingleClick_ = !1, this.modified_ = !1, this.rBush_ = new Eu, this.pixelTolerance_ = void 0 !== e.pixelTolerance ? e.pixelTolerance : 10, this.snappedToVertex_ = !1, this.changingFeature_ = !1, this.dragSegments_ = [], this.overlay_ = new v_({
|
||
source: new b_({
|
||
useSpatialIndex: !1,
|
||
wrapX: !!e.wrapX
|
||
}), style: e.style ? e.style : (i = tf(), function (t, e) {
|
||
return i[Zt.POINT]
|
||
}), updateWhileAnimating: !0, updateWhileInteracting: !0
|
||
}), this.SEGMENT_WRITERS_ = {
|
||
Point: this.writePointGeometry_,
|
||
LineString: this.writeLineStringGeometry_,
|
||
LinearRing: this.writeLineStringGeometry_,
|
||
Polygon: this.writePolygonGeometry_,
|
||
MultiPoint: this.writeMultiPointGeometry_,
|
||
MultiLineString: this.writeMultiLineStringGeometry_,
|
||
MultiPolygon: this.writeMultiPolygonGeometry_,
|
||
Circle: this.writeCircleGeometry_,
|
||
GeometryCollection: this.writeGeometryCollectionGeometry_
|
||
}, this.source_ = null, e.source ? (this.source_ = e.source, r = new Y(this.source_.getFeatures()), w(this.source_, x_.ADDFEATURE, this.handleSourceAdd_, this), w(this.source_, x_.REMOVEFEATURE, this.handleSourceRemove_, this)) : r = e.features, !r) throw new Error("The modify interaction requires features or a source");
|
||
this.features_ = r, this.features_.forEach(this.addFeature_.bind(this)), w(this.features_, u.ADD, this.handleFeatureAdd_, this), w(this.features_, u.REMOVE, this.handleFeatureRemove_, this), this.lastPointerEvent_ = null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.addFeature_ = function (t) {
|
||
var e = t.getGeometry();
|
||
e && e.getType() in this.SEGMENT_WRITERS_ && this.SEGMENT_WRITERS_[e.getType()].call(this, t, e);
|
||
var i = this.getMap();
|
||
i && i.isRendered() && this.getActive() && this.handlePointerAtPixel_(this.lastPixel_, i), w(t, F.CHANGE, this.handleFeatureChange_, this)
|
||
}, e.prototype.willModifyFeatures_ = function (t) {
|
||
this.modified_ || (this.modified_ = !0, this.dispatchEvent(new G_(N_, this.features_, t)))
|
||
}, e.prototype.removeFeature_ = function (t) {
|
||
this.removeFeatureSegmentData_(t), this.vertexFeature_ && 0 === this.features_.getLength() && (this.overlay_.getSource().removeFeature(this.vertexFeature_), this.vertexFeature_ = null), C(t, F.CHANGE, this.handleFeatureChange_, this)
|
||
}, e.prototype.removeFeatureSegmentData_ = function (t) {
|
||
var e = this.rBush_, i = [];
|
||
e.forEach(function (e) {
|
||
t === e.feature && i.push(e)
|
||
});
|
||
for (var r = i.length - 1; r >= 0; --r) e.remove(i[r])
|
||
}, e.prototype.setActive = function (e) {
|
||
this.vertexFeature_ && !e && (this.overlay_.getSource().removeFeature(this.vertexFeature_), this.vertexFeature_ = null), t.prototype.setActive.call(this, e)
|
||
}, e.prototype.setMap = function (e) {
|
||
this.overlay_.setMap(e), t.prototype.setMap.call(this, e)
|
||
}, e.prototype.getOverlay = function () {
|
||
return this.overlay_
|
||
}, e.prototype.handleSourceAdd_ = function (t) {
|
||
t.feature && this.features_.push(t.feature)
|
||
}, e.prototype.handleSourceRemove_ = function (t) {
|
||
t.feature && this.features_.remove(t.feature)
|
||
}, e.prototype.handleFeatureAdd_ = function (t) {
|
||
this.addFeature_(t.element)
|
||
}, e.prototype.handleFeatureChange_ = function (t) {
|
||
if (!this.changingFeature_) {
|
||
var e = t.target;
|
||
this.removeFeature_(e), this.addFeature_(e)
|
||
}
|
||
}, e.prototype.handleFeatureRemove_ = function (t) {
|
||
var e = t.element;
|
||
this.removeFeature_(e)
|
||
}, e.prototype.writePointGeometry_ = function (t, e) {
|
||
var i = e.getCoordinates(), r = {feature: t, geometry: e, segment: [i, i]};
|
||
this.rBush_.insert(e.getExtent(), r)
|
||
}, e.prototype.writeMultiPointGeometry_ = function (t, e) {
|
||
for (var i = e.getCoordinates(), r = 0, o = i.length; r < o; ++r) {
|
||
var n = i[r], s = {feature: t, geometry: e, depth: [r], index: r, segment: [n, n]};
|
||
this.rBush_.insert(e.getExtent(), s)
|
||
}
|
||
}, e.prototype.writeLineStringGeometry_ = function (t, e) {
|
||
for (var i = e.getCoordinates(), r = 0, o = i.length - 1; r < o; ++r) {
|
||
var n = i.slice(r, r + 2), s = {feature: t, geometry: e, index: r, segment: n};
|
||
this.rBush_.insert(lt(n), s)
|
||
}
|
||
}, e.prototype.writeMultiLineStringGeometry_ = function (t, e) {
|
||
for (var i = e.getCoordinates(), r = 0, o = i.length; r < o; ++r) for (var n = i[r], s = 0, a = n.length - 1; s < a; ++s) {
|
||
var l = n.slice(s, s + 2), h = {feature: t, geometry: e, depth: [r], index: s, segment: l};
|
||
this.rBush_.insert(lt(l), h)
|
||
}
|
||
}, e.prototype.writePolygonGeometry_ = function (t, e) {
|
||
for (var i = e.getCoordinates(), r = 0, o = i.length; r < o; ++r) for (var n = i[r], s = 0, a = n.length - 1; s < a; ++s) {
|
||
var l = n.slice(s, s + 2), h = {feature: t, geometry: e, depth: [r], index: s, segment: l};
|
||
this.rBush_.insert(lt(l), h)
|
||
}
|
||
}, e.prototype.writeMultiPolygonGeometry_ = function (t, e) {
|
||
for (var i = e.getCoordinates(), r = 0, o = i.length; r < o; ++r) for (var n = i[r], s = 0, a = n.length; s < a; ++s) for (var l = n[s], h = 0, u = l.length - 1; h < u; ++h) {
|
||
var c = l.slice(h, h + 2), p = {feature: t, geometry: e, depth: [s, r], index: h, segment: c};
|
||
this.rBush_.insert(lt(c), p)
|
||
}
|
||
}, e.prototype.writeCircleGeometry_ = function (t, e) {
|
||
var i = e.getCenter(), r = {feature: t, geometry: e, index: 0, segment: [i, i]},
|
||
o = {feature: t, geometry: e, index: F_, segment: [i, i]}, n = [r, o];
|
||
r.featureSegments = o.featureSegments = n, this.rBush_.insert(_t(i), r), this.rBush_.insert(e.getExtent(), o)
|
||
}, e.prototype.writeGeometryCollectionGeometry_ = function (t, e) {
|
||
for (var i = e.getGeometriesArray(), r = 0; r < i.length; ++r) this.SEGMENT_WRITERS_[i[r].getType()].call(this, t, i[r])
|
||
}, e.prototype.createOrUpdateVertexFeature_ = function (t) {
|
||
var e = this.vertexFeature_;
|
||
e ? e.getGeometry().setCoordinates(t) : (e = new X(new qi(t)), this.vertexFeature_ = e, this.overlay_.getSource().addFeature(e));
|
||
return e
|
||
}, e.prototype.handleEvent = function (e) {
|
||
return !e.pointerEvent || (this.lastPointerEvent_ = e, e.map.getView().getInteracting() || e.type != Ho.POINTERMOVE || this.handlingDownUpSequence || this.handlePointerMove_(e), this.vertexFeature_ && this.deleteCondition_(e) && (i = !(e.type != Ho.SINGLECLICK || !this.ignoreNextSingleClick_) || this.removePoint()), e.type == Ho.SINGLECLICK && (this.ignoreNextSingleClick_ = !1), t.prototype.handleEvent.call(this, e) && !i);
|
||
var i
|
||
}, e.prototype.handleDragEvent = function (t) {
|
||
this.ignoreNextSingleClick_ = !1, this.willModifyFeatures_(t);
|
||
for (var e = t.coordinate, i = 0, r = this.dragSegments_.length; i < r; ++i) {
|
||
for (var o = this.dragSegments_[i], n = o[0], s = n.depth, a = n.geometry, l = void 0, h = n.segment, u = o[1]; e.length < a.getStride();) e.push(h[u][e.length]);
|
||
switch (a.getType()) {
|
||
case Zt.POINT:
|
||
l = e, h[0] = h[1] = e;
|
||
break;
|
||
case Zt.MULTI_POINT:
|
||
(l = a.getCoordinates())[n.index] = e, h[0] = h[1] = e;
|
||
break;
|
||
case Zt.LINE_STRING:
|
||
(l = a.getCoordinates())[n.index + u] = e, h[u] = e;
|
||
break;
|
||
case Zt.MULTI_LINE_STRING:
|
||
case Zt.POLYGON:
|
||
(l = a.getCoordinates())[s[0]][n.index + u] = e, h[u] = e;
|
||
break;
|
||
case Zt.MULTI_POLYGON:
|
||
(l = a.getCoordinates())[s[1]][s[0]][n.index + u] = e, h[u] = e;
|
||
break;
|
||
case Zt.CIRCLE:
|
||
h[0] = h[1] = e, 0 === n.index ? (this.changingFeature_ = !0, a.setCenter(e), this.changingFeature_ = !1) : (this.changingFeature_ = !0, a.setRadius(Yr(a.getCenter(), e)), this.changingFeature_ = !1)
|
||
}
|
||
l && this.setGeometryCoordinates_(a, l)
|
||
}
|
||
this.createOrUpdateVertexFeature_(e)
|
||
}, e.prototype.handleDownEvent = function (t) {
|
||
if (!this.condition_(t)) return !1;
|
||
this.handlePointerAtPixel_(t.pixel, t.map);
|
||
var e = t.map.getCoordinateFromPixel(t.pixel);
|
||
this.dragSegments_.length = 0, this.modified_ = !1;
|
||
var i = this.vertexFeature_;
|
||
if (i) {
|
||
var r = [], o = i.getGeometry().getCoordinates(), n = lt([o]), s = this.rBush_.getInExtent(n),
|
||
l = {};
|
||
s.sort(j_);
|
||
for (var h = 0, u = s.length; h < u; ++h) {
|
||
var c = s[h], p = c.segment, d = a(c.feature), f = c.depth;
|
||
if (f && (d += "-" + f.join("-")), l[d] || (l[d] = new Array(2)), c.geometry.getType() === Zt.CIRCLE && c.index === F_) zr(U_(e, c), o) && !l[d][0] && (this.dragSegments_.push([c, 0]), l[d][0] = c); else if (zr(p[0], o) && !l[d][0]) this.dragSegments_.push([c, 0]), l[d][0] = c; else if (zr(p[1], o) && !l[d][1]) {
|
||
if ((c.geometry.getType() === Zt.LINE_STRING || c.geometry.getType() === Zt.MULTI_LINE_STRING) && l[d][0] && 0 === l[d][0].index) continue;
|
||
this.dragSegments_.push([c, 1]), l[d][1] = c
|
||
} else this.insertVertexCondition_(t) && a(p) in this.vertexSegments_ && !l[d][0] && !l[d][1] && r.push([c, o])
|
||
}
|
||
r.length && this.willModifyFeatures_(t);
|
||
for (var g = r.length - 1; g >= 0; --g) this.insertVertex_.apply(this, r[g])
|
||
}
|
||
return !!this.vertexFeature_
|
||
}, e.prototype.handleUpEvent = function (t) {
|
||
for (var e = this.dragSegments_.length - 1; e >= 0; --e) {
|
||
var i = this.dragSegments_[e][0], r = i.geometry;
|
||
if (r.getType() === Zt.CIRCLE) {
|
||
var o = r.getCenter(), n = i.featureSegments[0], s = i.featureSegments[1];
|
||
n.segment[0] = n.segment[1] = o, s.segment[0] = s.segment[1] = o, this.rBush_.update(_t(o), n), this.rBush_.update(r.getExtent(), s)
|
||
} else this.rBush_.update(lt(i.segment), i)
|
||
}
|
||
return this.modified_ && (this.dispatchEvent(new G_(D_, this.features_, t)), this.modified_ = !1), !1
|
||
}, e.prototype.handlePointerMove_ = function (t) {
|
||
this.lastPixel_ = t.pixel, this.handlePointerAtPixel_(t.pixel, t.map)
|
||
}, e.prototype.handlePointerAtPixel_ = function (t, e) {
|
||
var i = e.getCoordinateFromPixel(t), r = ht(_t(i), e.getView().getResolution() * this.pixelTolerance_),
|
||
o = this.rBush_.getInExtent(r);
|
||
if (o.length > 0) {
|
||
o.sort(function (t, e) {
|
||
return z_(i, t) - z_(i, e)
|
||
});
|
||
var n = o[0], s = n.segment, l = U_(i, n), h = e.getPixelFromCoordinate(l), u = Yr(t, h);
|
||
if (u <= this.pixelTolerance_) {
|
||
var c = {};
|
||
if (n.geometry.getType() === Zt.CIRCLE && n.index === F_) this.snappedToVertex_ = !0, this.createOrUpdateVertexFeature_(l); else {
|
||
var p = e.getPixelFromCoordinate(s[0]), d = e.getPixelFromCoordinate(s[1]), f = Vr(h, p),
|
||
g = Vr(h, d);
|
||
u = Math.sqrt(Math.min(f, g)), this.snappedToVertex_ = u <= this.pixelTolerance_, this.snappedToVertex_ && (l = f > g ? s[1] : s[0]), this.createOrUpdateVertexFeature_(l);
|
||
for (var m = 1, y = o.length; m < y; ++m) {
|
||
var v = o[m].segment;
|
||
if (!(zr(s[0], v[0]) && zr(s[1], v[1]) || zr(s[0], v[1]) && zr(s[1], v[0]))) break;
|
||
c[a(v)] = !0
|
||
}
|
||
}
|
||
return c[a(s)] = !0, void (this.vertexSegments_ = c)
|
||
}
|
||
}
|
||
this.vertexFeature_ && (this.overlay_.getSource().removeFeature(this.vertexFeature_), this.vertexFeature_ = null)
|
||
}, e.prototype.insertVertex_ = function (t, e) {
|
||
for (var i, r = t.segment, o = t.feature, n = t.geometry, s = t.depth, a = t.index; e.length < n.getStride();) e.push(0);
|
||
switch (n.getType()) {
|
||
case Zt.MULTI_LINE_STRING:
|
||
case Zt.POLYGON:
|
||
(i = n.getCoordinates())[s[0]].splice(a + 1, 0, e);
|
||
break;
|
||
case Zt.MULTI_POLYGON:
|
||
(i = n.getCoordinates())[s[1]][s[0]].splice(a + 1, 0, e);
|
||
break;
|
||
case Zt.LINE_STRING:
|
||
(i = n.getCoordinates()).splice(a + 1, 0, e);
|
||
break;
|
||
default:
|
||
return
|
||
}
|
||
this.setGeometryCoordinates_(n, i);
|
||
var l = this.rBush_;
|
||
l.remove(t), this.updateSegmentIndices_(n, a, s, 1);
|
||
var h = {segment: [r[0], e], feature: o, geometry: n, depth: s, index: a};
|
||
l.insert(lt(h.segment), h), this.dragSegments_.push([h, 1]);
|
||
var u = {segment: [e, r[1]], feature: o, geometry: n, depth: s, index: a + 1};
|
||
l.insert(lt(u.segment), u), this.dragSegments_.push([u, 0]), this.ignoreNextSingleClick_ = !0
|
||
}, e.prototype.removePoint = function () {
|
||
if (this.lastPointerEvent_ && this.lastPointerEvent_.type != Ho.POINTERDRAG) {
|
||
var t = this.lastPointerEvent_;
|
||
return this.willModifyFeatures_(t), this.removeVertex_(), this.dispatchEvent(new G_(D_, this.features_, t)), this.modified_ = !1, !0
|
||
}
|
||
return !1
|
||
}, e.prototype.removeVertex_ = function () {
|
||
var t, e, i, r, o, n, s, l, h, u, c, p = this.dragSegments_, d = {}, f = !1;
|
||
for (o = p.length - 1; o >= 0; --o) c = a((u = (i = p[o])[0]).feature), u.depth && (c += "-" + u.depth.join("-")), c in d || (d[c] = {}), 0 === i[1] ? (d[c].right = u, d[c].index = u.index) : 1 == i[1] && (d[c].left = u, d[c].index = u.index + 1);
|
||
for (c in d) {
|
||
switch (h = d[c].right, s = d[c].left, (l = (n = d[c].index) - 1) < 0 && (l = 0), t = e = (r = (u = void 0 !== s ? s : h).geometry).getCoordinates(), f = !1, r.getType()) {
|
||
case Zt.MULTI_LINE_STRING:
|
||
e[u.depth[0]].length > 2 && (e[u.depth[0]].splice(n, 1), f = !0);
|
||
break;
|
||
case Zt.LINE_STRING:
|
||
e.length > 2 && (e.splice(n, 1), f = !0);
|
||
break;
|
||
case Zt.MULTI_POLYGON:
|
||
t = t[u.depth[1]];
|
||
case Zt.POLYGON:
|
||
(t = t[u.depth[0]]).length > 4 && (n == t.length - 1 && (n = 0), t.splice(n, 1), f = !0, 0 === n && (t.pop(), t.push(t[0]), l = t.length - 1))
|
||
}
|
||
if (f) {
|
||
this.setGeometryCoordinates_(r, e);
|
||
var g = [];
|
||
if (void 0 !== s && (this.rBush_.remove(s), g.push(s.segment[0])), void 0 !== h && (this.rBush_.remove(h), g.push(h.segment[1])), void 0 !== s && void 0 !== h) {
|
||
var m = {depth: u.depth, feature: u.feature, geometry: u.geometry, index: l, segment: g};
|
||
this.rBush_.insert(lt(m.segment), m)
|
||
}
|
||
this.updateSegmentIndices_(r, n, u.depth, -1), this.vertexFeature_ && (this.overlay_.getSource().removeFeature(this.vertexFeature_), this.vertexFeature_ = null), p.length = 0
|
||
}
|
||
}
|
||
return f
|
||
}, e.prototype.setGeometryCoordinates_ = function (t, e) {
|
||
this.changingFeature_ = !0, t.setCoordinates(e), this.changingFeature_ = !1
|
||
}, e.prototype.updateSegmentIndices_ = function (t, e, i, r) {
|
||
this.rBush_.forEachInExtent(t.getExtent(), function (o) {
|
||
o.geometry === t && (void 0 === i || void 0 === o.depth || it(o.depth, i)) && o.index > e && (o.index += r)
|
||
})
|
||
}, e
|
||
}(ra), V_ = {SELECT: "select"}, Y_ = function (t) {
|
||
function e(e, i, r, o) {
|
||
t.call(this, e), this.selected = i, this.deselected = r, this.mapBrowserEvent = o
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A);
|
||
|
||
function W_(t) {
|
||
if (!this.condition_(t)) return !0;
|
||
var e = this.addCondition_(t), i = this.removeCondition_(t), r = this.toggleCondition_(t),
|
||
o = !e && !i && !r, n = t.map, s = this.getFeatures(), a = [], l = [];
|
||
if (o) {
|
||
d(this.featureLayerAssociation_), n.forEachFeatureAtPixel(t.pixel, function (t, e) {
|
||
if (this.filter_(t, e)) return l.push(t), this.addFeatureLayerAssociation_(t, e), !this.multi_
|
||
}.bind(this), {layerFilter: this.layerFilter_, hitTolerance: this.hitTolerance_});
|
||
for (var h = s.getLength() - 1; h >= 0; --h) {
|
||
var u = s.item(h), c = l.indexOf(u);
|
||
c > -1 ? l.splice(c, 1) : (s.remove(u), a.push(u))
|
||
}
|
||
0 !== l.length && s.extend(l)
|
||
} else {
|
||
n.forEachFeatureAtPixel(t.pixel, function (t, o) {
|
||
if (this.filter_(t, o)) return !e && !r || K(s.getArray(), t) ? (i || r) && K(s.getArray(), t) && (a.push(t), this.removeFeatureLayerAssociation_(t)) : (l.push(t), this.addFeatureLayerAssociation_(t, o)), !this.multi_
|
||
}.bind(this), {layerFilter: this.layerFilter_, hitTolerance: this.hitTolerance_});
|
||
for (var p = a.length - 1; p >= 0; --p) s.remove(a[p]);
|
||
s.extend(l)
|
||
}
|
||
return (l.length > 0 || a.length > 0) && this.dispatchEvent(new Y_(V_.SELECT, l, a, t)), Zs(t)
|
||
}
|
||
|
||
function H_() {
|
||
var t = tf();
|
||
return Q(t[Zt.POLYGON], t[Zt.LINE_STRING]), Q(t[Zt.GEOMETRY_COLLECTION], t[Zt.LINE_STRING]), function (e, i) {
|
||
return e.getGeometry() ? t[e.getGeometry().getType()] : null
|
||
}
|
||
}
|
||
|
||
var X_ = function (t) {
|
||
function e(e) {
|
||
t.call(this, {handleEvent: W_});
|
||
var i = e || {};
|
||
this.condition_ = i.condition ? i.condition : Ks, this.addCondition_ = i.addCondition ? i.addCondition : qs, this.removeCondition_ = i.removeCondition ? i.removeCondition : qs, this.toggleCondition_ = i.toggleCondition ? i.toggleCondition : $s, this.multi_ = !!i.multi && i.multi, this.filter_ = i.filter ? i.filter : P, this.hitTolerance_ = i.hitTolerance ? i.hitTolerance : 0;
|
||
var r, o = new v_({
|
||
source: new b_({useSpatialIndex: !1, features: i.features, wrapX: i.wrapX}),
|
||
style: i.style ? i.style : H_(),
|
||
updateWhileAnimating: !0,
|
||
updateWhileInteracting: !0
|
||
});
|
||
if (this.featureOverlay_ = o, i.layers) if ("function" == typeof i.layers) r = i.layers; else {
|
||
var n = i.layers;
|
||
r = function (t) {
|
||
return K(n, t)
|
||
}
|
||
} else r = P;
|
||
this.layerFilter_ = r, this.featureLayerAssociation_ = {};
|
||
var s = this.getFeatures();
|
||
w(s, u.ADD, this.addFeature_, this), w(s, u.REMOVE, this.removeFeature_, this)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.addFeatureLayerAssociation_ = function (t, e) {
|
||
this.featureLayerAssociation_[a(t)] = e
|
||
}, e.prototype.getFeatures = function () {
|
||
return this.featureOverlay_.getSource().getFeaturesCollection()
|
||
}, e.prototype.getHitTolerance = function () {
|
||
return this.hitTolerance_
|
||
}, e.prototype.getLayer = function (t) {
|
||
return this.featureLayerAssociation_[a(t)]
|
||
}, e.prototype.getOverlay = function () {
|
||
return this.featureOverlay_
|
||
}, e.prototype.setHitTolerance = function (t) {
|
||
this.hitTolerance_ = t
|
||
}, e.prototype.setMap = function (e) {
|
||
var i = this.getMap(), r = this.getFeatures();
|
||
i && r.forEach(i.unskipFeature.bind(i)), t.prototype.setMap.call(this, e), this.featureOverlay_.setMap(e), e && r.forEach(e.skipFeature.bind(e))
|
||
}, e.prototype.addFeature_ = function (t) {
|
||
var e = this.getMap();
|
||
e && e.skipFeature(t.element)
|
||
}, e.prototype.removeFeature_ = function (t) {
|
||
var e = this.getMap();
|
||
e && e.unskipFeature(t.element)
|
||
}, e.prototype.removeFeatureLayerAssociation_ = function (t) {
|
||
delete this.featureLayerAssociation_[a(t)]
|
||
}, e
|
||
}(zs);
|
||
|
||
function q_(t) {
|
||
return t.feature ? t.feature : t.element ? t.element : void 0
|
||
}
|
||
|
||
var Z_ = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = i;
|
||
r.handleDownEvent || (r.handleDownEvent = P), r.stopDown || (r.stopDown = L), t.call(this, r), this.source_ = i.source ? i.source : null, this.vertex_ = void 0 === i.vertex || i.vertex, this.edge_ = void 0 === i.edge || i.edge, this.features_ = i.features ? i.features : null, this.featuresListenerKeys_ = [], this.featureChangeListenerKeys_ = {}, this.indexedFeaturesExtents_ = {}, this.pendingFeatures_ = {}, this.pixelCoordinate_ = null, this.pixelTolerance_ = void 0 !== i.pixelTolerance ? i.pixelTolerance : 10, this.sortByDistance_ = function (t, e) {
|
||
var i = Wr(this.pixelCoordinate_, t.segment), r = Wr(this.pixelCoordinate_, e.segment);
|
||
return i - r
|
||
}.bind(this), this.rBush_ = new Eu, this.SEGMENT_WRITERS_ = {
|
||
Point: this.writePointGeometry_,
|
||
LineString: this.writeLineStringGeometry_,
|
||
LinearRing: this.writeLineStringGeometry_,
|
||
Polygon: this.writePolygonGeometry_,
|
||
MultiPoint: this.writeMultiPointGeometry_,
|
||
MultiLineString: this.writeMultiLineStringGeometry_,
|
||
MultiPolygon: this.writeMultiPolygonGeometry_,
|
||
GeometryCollection: this.writeGeometryCollectionGeometry_,
|
||
Circle: this.writeCircleGeometry_
|
||
}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.addFeature = function (t, e) {
|
||
var i = void 0 === e || e, r = a(t), o = t.getGeometry();
|
||
if (o) {
|
||
var n = this.SEGMENT_WRITERS_[o.getType()];
|
||
n && (this.indexedFeaturesExtents_[r] = o.getExtent([1 / 0, 1 / 0, -1 / 0, -1 / 0]), n.call(this, t, o))
|
||
}
|
||
i && (this.featureChangeListenerKeys_[r] = w(t, F.CHANGE, this.handleFeatureChange_, this))
|
||
}, e.prototype.forEachFeatureAdd_ = function (t) {
|
||
this.addFeature(t)
|
||
}, e.prototype.forEachFeatureRemove_ = function (t) {
|
||
this.removeFeature(t)
|
||
}, e.prototype.getFeatures_ = function () {
|
||
var t;
|
||
return this.features_ ? t = this.features_ : this.source_ && (t = this.source_.getFeatures()), t
|
||
}, e.prototype.handleEvent = function (e) {
|
||
var i = this.snapTo(e.pixel, e.coordinate, e.map);
|
||
return i.snapped && (e.coordinate = i.vertex.slice(0, 2), e.pixel = i.vertexPixel), t.prototype.handleEvent.call(this, e)
|
||
}, e.prototype.handleFeatureAdd_ = function (t) {
|
||
var e = q_(t);
|
||
this.addFeature(e)
|
||
}, e.prototype.handleFeatureRemove_ = function (t) {
|
||
var e = q_(t);
|
||
this.removeFeature(e)
|
||
}, e.prototype.handleFeatureChange_ = function (t) {
|
||
var e = t.target;
|
||
if (this.handlingDownUpSequence) {
|
||
var i = a(e);
|
||
i in this.pendingFeatures_ || (this.pendingFeatures_[i] = e)
|
||
} else this.updateFeature_(e)
|
||
}, e.prototype.handleUpEvent = function (t) {
|
||
var e = f(this.pendingFeatures_);
|
||
return e.length && (e.forEach(this.updateFeature_.bind(this)), this.pendingFeatures_ = {}), !1
|
||
}, e.prototype.removeFeature = function (t, e) {
|
||
var i = void 0 === e || e, r = a(t), o = this.indexedFeaturesExtents_[r];
|
||
if (o) {
|
||
var n = this.rBush_, s = [];
|
||
n.forEachInExtent(o, function (e) {
|
||
t === e.feature && s.push(e)
|
||
});
|
||
for (var l = s.length - 1; l >= 0; --l) n.remove(s[l])
|
||
}
|
||
i && (S(this.featureChangeListenerKeys_[r]), delete this.featureChangeListenerKeys_[r])
|
||
}, e.prototype.setMap = function (e) {
|
||
var i = this.getMap(), r = this.featuresListenerKeys_, o = this.getFeatures_();
|
||
i && (r.forEach(S), r.length = 0, o.forEach(this.forEachFeatureRemove_.bind(this))), t.prototype.setMap.call(this, e), e && (this.features_ ? r.push(w(this.features_, u.ADD, this.handleFeatureAdd_, this), w(this.features_, u.REMOVE, this.handleFeatureRemove_, this)) : this.source_ && r.push(w(this.source_, x_.ADDFEATURE, this.handleFeatureAdd_, this), w(this.source_, x_.REMOVEFEATURE, this.handleFeatureRemove_, this)), o.forEach(this.forEachFeatureAdd_.bind(this)))
|
||
}, e.prototype.snapTo = function (t, e, i) {
|
||
var r = lt([i.getCoordinateFromPixel([t[0] - this.pixelTolerance_, t[1] + this.pixelTolerance_]), i.getCoordinateFromPixel([t[0] + this.pixelTolerance_, t[1] - this.pixelTolerance_])]),
|
||
o = this.rBush_.getInExtent(r);
|
||
this.vertex_ && !this.edge_ && (o = o.filter(function (t) {
|
||
return t.feature.getGeometry().getType() !== Zt.CIRCLE
|
||
}));
|
||
var n, s, a, l, h = !1, u = null, c = null;
|
||
if (o.length > 0) {
|
||
this.pixelCoordinate_ = e, o.sort(this.sortByDistance_);
|
||
var p = o[0].segment, d = o[0].feature.getGeometry().getType() === Zt.CIRCLE;
|
||
this.vertex_ && !this.edge_ ? (n = i.getPixelFromCoordinate(p[0]), s = i.getPixelFromCoordinate(p[1]), a = Vr(t, n), l = Vr(t, s), Math.sqrt(Math.min(a, l)) <= this.pixelTolerance_ && (h = !0, u = a > l ? p[1] : p[0], c = i.getPixelFromCoordinate(u))) : this.edge_ && (u = d ? Nr(e, o[0].feature.getGeometry()) : Dr(e, p), Yr(t, c = i.getPixelFromCoordinate(u)) <= this.pixelTolerance_ && (h = !0, this.vertex_ && !d && (n = i.getPixelFromCoordinate(p[0]), s = i.getPixelFromCoordinate(p[1]), a = Vr(c, n), l = Vr(c, s), Math.sqrt(Math.min(a, l)) <= this.pixelTolerance_ && (u = a > l ? p[1] : p[0], c = i.getPixelFromCoordinate(u))))), h && (c = [Math.round(c[0]), Math.round(c[1])])
|
||
}
|
||
return {snapped: h, vertex: u, vertexPixel: c}
|
||
}, e.prototype.updateFeature_ = function (t) {
|
||
this.removeFeature(t, !1), this.addFeature(t, !1)
|
||
}, e.prototype.writeCircleGeometry_ = function (t, e) {
|
||
for (var i = yr(e).getCoordinates()[0], r = 0, o = i.length - 1; r < o; ++r) {
|
||
var n = i.slice(r, r + 2), s = {feature: t, segment: n};
|
||
this.rBush_.insert(lt(n), s)
|
||
}
|
||
}, e.prototype.writeGeometryCollectionGeometry_ = function (t, e) {
|
||
for (var i = e.getGeometriesArray(), r = 0; r < i.length; ++r) {
|
||
var o = this.SEGMENT_WRITERS_[i[r].getType()];
|
||
o && o.call(this, t, i[r])
|
||
}
|
||
}, e.prototype.writeLineStringGeometry_ = function (t, e) {
|
||
for (var i = e.getCoordinates(), r = 0, o = i.length - 1; r < o; ++r) {
|
||
var n = i.slice(r, r + 2), s = {feature: t, segment: n};
|
||
this.rBush_.insert(lt(n), s)
|
||
}
|
||
}, e.prototype.writeMultiLineStringGeometry_ = function (t, e) {
|
||
for (var i = e.getCoordinates(), r = 0, o = i.length; r < o; ++r) for (var n = i[r], s = 0, a = n.length - 1; s < a; ++s) {
|
||
var l = n.slice(s, s + 2), h = {feature: t, segment: l};
|
||
this.rBush_.insert(lt(l), h)
|
||
}
|
||
}, e.prototype.writeMultiPointGeometry_ = function (t, e) {
|
||
for (var i = e.getCoordinates(), r = 0, o = i.length; r < o; ++r) {
|
||
var n = i[r], s = {feature: t, segment: [n, n]};
|
||
this.rBush_.insert(e.getExtent(), s)
|
||
}
|
||
}, e.prototype.writeMultiPolygonGeometry_ = function (t, e) {
|
||
for (var i = e.getCoordinates(), r = 0, o = i.length; r < o; ++r) for (var n = i[r], s = 0, a = n.length; s < a; ++s) for (var l = n[s], h = 0, u = l.length - 1; h < u; ++h) {
|
||
var c = l.slice(h, h + 2), p = {feature: t, segment: c};
|
||
this.rBush_.insert(lt(c), p)
|
||
}
|
||
}, e.prototype.writePointGeometry_ = function (t, e) {
|
||
var i = e.getCoordinates(), r = {feature: t, segment: [i, i]};
|
||
this.rBush_.insert(e.getExtent(), r)
|
||
}, e.prototype.writePolygonGeometry_ = function (t, e) {
|
||
for (var i = e.getCoordinates(), r = 0, o = i.length; r < o; ++r) for (var n = i[r], s = 0, a = n.length - 1; s < a; ++s) {
|
||
var l = n.slice(s, s + 2), h = {feature: t, segment: l};
|
||
this.rBush_.insert(lt(l), h)
|
||
}
|
||
}, e
|
||
}(ra), K_ = "translatestart", J_ = "translating", $_ = "translateend", Q_ = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, e), this.features = i, this.coordinate = r
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A), tx = function (t) {
|
||
function e(e) {
|
||
var i, r = e || {};
|
||
if (t.call(this, r), this.lastCoordinate_ = null, this.features_ = void 0 !== r.features ? r.features : null, r.layers) if ("function" == typeof r.layers) i = r.layers; else {
|
||
var o = r.layers;
|
||
i = function (t) {
|
||
return K(o, t)
|
||
}
|
||
} else i = P;
|
||
this.layerFilter_ = i, this.hitTolerance_ = r.hitTolerance ? r.hitTolerance : 0, this.lastFeature_ = null, w(this, z(As.ACTIVE), this.handleActiveChanged_, this)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.handleDownEvent = function (t) {
|
||
if (this.lastFeature_ = this.featuresAtPixel_(t.pixel, t.map), !this.lastCoordinate_ && this.lastFeature_) {
|
||
this.lastCoordinate_ = t.coordinate, this.handleMoveEvent(t);
|
||
var e = this.features_ || new Y([this.lastFeature_]);
|
||
return this.dispatchEvent(new Q_(K_, e, t.coordinate)), !0
|
||
}
|
||
return !1
|
||
}, e.prototype.handleUpEvent = function (t) {
|
||
if (this.lastCoordinate_) {
|
||
this.lastCoordinate_ = null, this.handleMoveEvent(t);
|
||
var e = this.features_ || new Y([this.lastFeature_]);
|
||
return this.dispatchEvent(new Q_($_, e, t.coordinate)), !0
|
||
}
|
||
return !1
|
||
}, e.prototype.handleDragEvent = function (t) {
|
||
if (this.lastCoordinate_) {
|
||
var e = t.coordinate, i = e[0] - this.lastCoordinate_[0], r = e[1] - this.lastCoordinate_[1],
|
||
o = this.features_ || new Y([this.lastFeature_]);
|
||
o.forEach(function (t) {
|
||
var e = t.getGeometry();
|
||
e.translate(i, r), t.setGeometry(e)
|
||
}), this.lastCoordinate_ = e, this.dispatchEvent(new Q_(J_, o, e))
|
||
}
|
||
}, e.prototype.handleMoveEvent = function (t) {
|
||
var e = t.map.getViewport();
|
||
this.featuresAtPixel_(t.pixel, t.map) ? (e.classList.remove(this.lastCoordinate_ ? "ol-grab" : "ol-grabbing"), e.classList.add(this.lastCoordinate_ ? "ol-grabbing" : "ol-grab")) : e.classList.remove("ol-grab", "ol-grabbing")
|
||
}, e.prototype.featuresAtPixel_ = function (t, e) {
|
||
return e.forEachFeatureAtPixel(t, function (t) {
|
||
if (!this.features_ || K(this.features_.getArray(), t)) return t
|
||
}.bind(this), {layerFilter: this.layerFilter_, hitTolerance: this.hitTolerance_})
|
||
}, e.prototype.getHitTolerance = function () {
|
||
return this.hitTolerance_
|
||
}, e.prototype.setHitTolerance = function (t) {
|
||
this.hitTolerance_ = t
|
||
}, e.prototype.setMap = function (e) {
|
||
var i = this.getMap();
|
||
t.prototype.setMap.call(this, e), this.updateState_(i)
|
||
}, e.prototype.handleActiveChanged_ = function () {
|
||
this.updateState_(null)
|
||
}, e.prototype.updateState_ = function (t) {
|
||
var e = this.getMap(), i = this.getActive();
|
||
e && i || (e = e || t) && e.getViewport().classList.remove("ol-grab", "ol-grabbing")
|
||
}, e
|
||
}(ra), ex = {BLUR: "blur", GRADIENT: "gradient", RADIUS: "radius"},
|
||
ix = ["#00f", "#0ff", "#0f0", "#ff0", "#f00"];
|
||
var rx = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = p({}, i);
|
||
delete r.gradient, delete r.radius, delete r.blur, delete r.shadow, delete r.weight, t.call(this, r), this.gradient_ = null, this.shadow_ = void 0 !== i.shadow ? i.shadow : 250, this.circleImage_ = void 0, this.styleCache_ = null, w(this, z(ex.GRADIENT), this.handleGradientChanged_, this), this.setGradient(i.gradient ? i.gradient : ix), this.setBlur(void 0 !== i.blur ? i.blur : 15), this.setRadius(void 0 !== i.radius ? i.radius : 8), w(this, z(ex.BLUR), this.handleStyleChanged_, this), w(this, z(ex.RADIUS), this.handleStyleChanged_, this), this.handleStyleChanged_();
|
||
var o, n = i.weight ? i.weight : "weight";
|
||
o = "string" == typeof n ? function (t) {
|
||
return t.get(n)
|
||
} : n, this.setStyle(function (t, e) {
|
||
var i = o(t), r = void 0 !== i ? te(i, 0, 1) : 1, n = 255 * r | 0, s = this.styleCache_[n];
|
||
return s || (s = [new uf({
|
||
image: new Xd({
|
||
opacity: r,
|
||
src: this.circleImage_
|
||
})
|
||
})], this.styleCache_[n] = s), s
|
||
}.bind(this)), this.setRenderOrder(null), w(this, eo.RENDER, this.handleRender_, this)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.createCircle_ = function () {
|
||
var t = this.getRadius(), e = this.getBlur(), i = t + e + 1, r = 2 * i, o = Ao(r, r);
|
||
o.shadowOffsetX = o.shadowOffsetY = this.shadow_, o.shadowBlur = e, o.shadowColor = "#000", o.beginPath();
|
||
var n = i - this.shadow_;
|
||
return o.arc(n, n, t, 0, 2 * Math.PI, !0), o.fill(), o.canvas.toDataURL()
|
||
}, e.prototype.getBlur = function () {
|
||
return this.get(ex.BLUR)
|
||
}, e.prototype.getGradient = function () {
|
||
return this.get(ex.GRADIENT)
|
||
}, e.prototype.getRadius = function () {
|
||
return this.get(ex.RADIUS)
|
||
}, e.prototype.handleGradientChanged_ = function () {
|
||
this.gradient_ = function (t) {
|
||
for (var e = Ao(1, 256), i = e.createLinearGradient(0, 0, 1, 256), r = 1 / (t.length - 1), o = 0, n = t.length; o < n; ++o) i.addColorStop(o * r, t[o]);
|
||
return e.fillStyle = i, e.fillRect(0, 0, 1, 256), e.getImageData(0, 0, 1, 256).data
|
||
}(this.getGradient())
|
||
}, e.prototype.handleStyleChanged_ = function () {
|
||
this.circleImage_ = this.createCircle_(), this.styleCache_ = new Array(256), this.changed()
|
||
}, e.prototype.handleRender_ = function (t) {
|
||
for (var e = t.context, i = e.canvas, r = e.getImageData(0, 0, i.width, i.height), o = r.data, n = 0, s = o.length; n < s; n += 4) {
|
||
var a = 4 * o[n + 3];
|
||
a && (o[n] = this.gradient_[a], o[n + 1] = this.gradient_[a + 1], o[n + 2] = this.gradient_[a + 2])
|
||
}
|
||
e.putImageData(r, 0, 0)
|
||
}, e.prototype.setBlur = function (t) {
|
||
this.set(ex.BLUR, t)
|
||
}, e.prototype.setGradient = function (t) {
|
||
this.set(ex.GRADIENT, t)
|
||
}, e.prototype.setRadius = function (t) {
|
||
this.set(ex.RADIUS, t)
|
||
}, e
|
||
}(v_), ox = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, i), this.type = Vo.IMAGE
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(Ts);
|
||
ox.prototype.getSource;
|
||
var nx = ox, sx = {PRELOAD: "preload", USE_INTERIM_TILES_ON_ERROR: "useInterimTilesOnError"},
|
||
ax = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = p({}, i);
|
||
delete r.preload, delete r.useInterimTilesOnError, t.call(this, r), this.setPreload(void 0 !== i.preload ? i.preload : 0), this.setUseInterimTilesOnError(void 0 === i.useInterimTilesOnError || i.useInterimTilesOnError), this.type = Vo.TILE
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getPreload = function () {
|
||
return this.get(sx.PRELOAD)
|
||
}, e.prototype.setPreload = function (t) {
|
||
this.set(sx.PRELOAD, t)
|
||
}, e.prototype.getUseInterimTilesOnError = function () {
|
||
return this.get(sx.USE_INTERIM_TILES_ON_ERROR)
|
||
}, e.prototype.setUseInterimTilesOnError = function (t) {
|
||
this.set(sx.USE_INTERIM_TILES_ON_ERROR, t)
|
||
}, e
|
||
}(Ts);
|
||
ax.prototype.getSource;
|
||
var lx = ax, hx = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = i.renderMode || $l.HYBRID;
|
||
W(null == r || r == $l.IMAGE || r == $l.HYBRID || r == $l.VECTOR, 28), i.declutter && r == $l.IMAGE && (r = $l.HYBRID), i.renderMode = r;
|
||
var o = p({}, i);
|
||
delete o.preload, delete o.useInterimTilesOnError, t.call(this, o), this.setPreload(i.preload ? i.preload : 0), this.setUseInterimTilesOnError(void 0 === i.useInterimTilesOnError || i.useInterimTilesOnError), this.type = Vo.VECTOR_TILE
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getPreload = function () {
|
||
return this.get(sx.PRELOAD)
|
||
}, e.prototype.getUseInterimTilesOnError = function () {
|
||
return this.get(sx.USE_INTERIM_TILES_ON_ERROR)
|
||
}, e.prototype.setPreload = function (t) {
|
||
this.set(sx.PRELOAD, t)
|
||
}, e.prototype.setUseInterimTilesOnError = function (t) {
|
||
this.set(sx.USE_INTERIM_TILES_ON_ERROR, t)
|
||
}, e
|
||
}(v_);
|
||
hx.prototype.getSource;
|
||
var ux = hx;
|
||
|
||
function cx(t, e, i, r) {
|
||
var o = ii(i, e, t), n = He(e, r, i), s = e.getMetersPerUnit();
|
||
void 0 !== s && (n *= s);
|
||
var a = t.getMetersPerUnit();
|
||
void 0 !== a && (n /= a);
|
||
var l = t.getExtent();
|
||
if (!l || pt(l, o)) {
|
||
var h = He(t, n, o) / n;
|
||
isFinite(h) && h > 0 && (n /= h)
|
||
}
|
||
return n
|
||
}
|
||
|
||
function px(t, e, i, r) {
|
||
var o = i - t, n = r - e, s = Math.sqrt(o * o + n * n);
|
||
return [Math.round(i + o / s), Math.round(r + n / s)]
|
||
}
|
||
|
||
function dx(t, e, i, r, o, n, s, a, l, h, u) {
|
||
var c = Ao(Math.round(i * t), Math.round(i * e));
|
||
if (0 === l.length) return c.canvas;
|
||
c.scale(i, i);
|
||
var p = [1 / 0, 1 / 0, -1 / 0, -1 / 0];
|
||
l.forEach(function (t, e, i) {
|
||
Ct(p, t.extent)
|
||
});
|
||
var d = Ut(p), f = Nt(p), g = Ao(Math.round(i * d / r), Math.round(i * f / r)), m = i / r;
|
||
l.forEach(function (t, e, i) {
|
||
var r = t.extent[0] - p[0], o = -(t.extent[3] - p[3]), n = Ut(t.extent), s = Nt(t.extent);
|
||
g.drawImage(t.image, h, h, t.image.width - 2 * h, t.image.height - 2 * h, r * m, o * m, n * m, s * m)
|
||
});
|
||
var y = jt(s);
|
||
return a.getTriangles().forEach(function (t, e, o) {
|
||
var s = t.source, a = t.target, l = s[0][0], h = s[0][1], u = s[1][0], d = s[1][1], f = s[2][0],
|
||
m = s[2][1], v = (a[0][0] - y[0]) / n, _ = -(a[0][1] - y[1]) / n, x = (a[1][0] - y[0]) / n,
|
||
w = -(a[1][1] - y[1]) / n, b = (a[2][0] - y[0]) / n, C = -(a[2][1] - y[1]) / n, S = l, E = h;
|
||
l = 0, h = 0;
|
||
var T = ne([[u -= S, d -= E, 0, 0, x - v], [f -= S, m -= E, 0, 0, b - v], [0, 0, u, d, w - _], [0, 0, f, m, C - _]]);
|
||
if (T) {
|
||
c.save(), c.beginPath();
|
||
var R = (v + x + b) / 3, P = (_ + w + C) / 3, L = px(R, P, v, _), I = px(R, P, x, w),
|
||
O = px(R, P, b, C);
|
||
c.moveTo(I[0], I[1]), c.lineTo(L[0], L[1]), c.lineTo(O[0], O[1]), c.clip(), c.transform(T[0], T[2], T[1], T[3], v, _), c.translate(p[0] - S, p[3] - E), c.scale(r / i, -r / i), c.drawImage(g.canvas, 0, 0), c.restore()
|
||
}
|
||
}), u && (c.save(), c.strokeStyle = "black", c.lineWidth = 1, a.getTriangles().forEach(function (t, e, i) {
|
||
var r = t.target, o = (r[0][0] - y[0]) / n, s = -(r[0][1] - y[1]) / n, a = (r[1][0] - y[0]) / n,
|
||
l = -(r[1][1] - y[1]) / n, h = (r[2][0] - y[0]) / n, u = -(r[2][1] - y[1]) / n;
|
||
c.beginPath(), c.moveTo(a, l), c.lineTo(o, s), c.lineTo(h, u), c.closePath(), c.stroke()
|
||
}), c.restore()), c.canvas
|
||
}
|
||
|
||
var fx = function (t, e, i, r, o) {
|
||
this.sourceProj_ = t, this.targetProj_ = e;
|
||
var n = {}, s = ei(this.targetProj_, this.sourceProj_);
|
||
this.transformInv_ = function (t) {
|
||
var e = t[0] + "/" + t[1];
|
||
return n[e] || (n[e] = s(t)), n[e]
|
||
}, this.maxSourceExtent_ = r, this.errorThresholdSquared_ = o * o, this.triangles_ = [], this.wrapsXInSource_ = !1, this.canWrapXInSource_ = this.sourceProj_.canWrapX() && !!r && !!this.sourceProj_.getExtent() && Ut(r) == Ut(this.sourceProj_.getExtent()), this.sourceWorldWidth_ = this.sourceProj_.getExtent() ? Ut(this.sourceProj_.getExtent()) : null, this.targetWorldWidth_ = this.targetProj_.getExtent() ? Ut(this.targetProj_.getExtent()) : null;
|
||
var a = jt(i), l = zt(i), h = Mt(i), u = Ot(i), c = this.transformInv_(a), p = this.transformInv_(l),
|
||
d = this.transformInv_(h), f = this.transformInv_(u);
|
||
if (this.addQuad_(a, l, h, u, c, p, d, f, 10), this.wrapsXInSource_) {
|
||
var g = 1 / 0;
|
||
this.triangles_.forEach(function (t, e, i) {
|
||
g = Math.min(g, t.source[0][0], t.source[1][0], t.source[2][0])
|
||
}), this.triangles_.forEach(function (t) {
|
||
if (Math.max(t.source[0][0], t.source[1][0], t.source[2][0]) - g > this.sourceWorldWidth_ / 2) {
|
||
var e = [[t.source[0][0], t.source[0][1]], [t.source[1][0], t.source[1][1]], [t.source[2][0], t.source[2][1]]];
|
||
e[0][0] - g > this.sourceWorldWidth_ / 2 && (e[0][0] -= this.sourceWorldWidth_), e[1][0] - g > this.sourceWorldWidth_ / 2 && (e[1][0] -= this.sourceWorldWidth_), e[2][0] - g > this.sourceWorldWidth_ / 2 && (e[2][0] -= this.sourceWorldWidth_);
|
||
var i = Math.min(e[0][0], e[1][0], e[2][0]);
|
||
Math.max(e[0][0], e[1][0], e[2][0]) - i < this.sourceWorldWidth_ / 2 && (t.source = e)
|
||
}
|
||
}.bind(this))
|
||
}
|
||
n = {}
|
||
};
|
||
fx.prototype.addTriangle_ = function (t, e, i, r, o, n) {
|
||
this.triangles_.push({source: [r, o, n], target: [t, e, i]})
|
||
}, fx.prototype.addQuad_ = function (t, e, i, r, o, n, s, a, l) {
|
||
var h = lt([o, n, s, a]), u = this.sourceWorldWidth_ ? Ut(h) / this.sourceWorldWidth_ : null,
|
||
c = this.sourceWorldWidth_, p = this.sourceProj_.canWrapX() && u > .5 && u < 1, d = !1;
|
||
if (l > 0) {
|
||
if (this.targetProj_.isGlobal() && this.targetWorldWidth_) d = Ut(lt([t, e, i, r])) / this.targetWorldWidth_ > .25 || d;
|
||
!p && this.sourceProj_.isGlobal() && u && (d = u > .25 || d)
|
||
}
|
||
if (d || !this.maxSourceExtent_ || Bt(h, this.maxSourceExtent_)) {
|
||
if (!(d || isFinite(o[0]) && isFinite(o[1]) && isFinite(n[0]) && isFinite(n[1]) && isFinite(s[0]) && isFinite(s[1]) && isFinite(a[0]) && isFinite(a[1]))) {
|
||
if (!(l > 0)) return;
|
||
d = !0
|
||
}
|
||
if (l > 0) {
|
||
if (!d) {
|
||
var f, g = [(t[0] + i[0]) / 2, (t[1] + i[1]) / 2], m = this.transformInv_(g);
|
||
if (p) f = (le(o[0], c) + le(s[0], c)) / 2 - le(m[0], c); else f = (o[0] + s[0]) / 2 - m[0];
|
||
var y = (o[1] + s[1]) / 2 - m[1];
|
||
d = f * f + y * y > this.errorThresholdSquared_
|
||
}
|
||
if (d) {
|
||
if (Math.abs(t[0] - i[0]) <= Math.abs(t[1] - i[1])) {
|
||
var v = [(e[0] + i[0]) / 2, (e[1] + i[1]) / 2], _ = this.transformInv_(v),
|
||
x = [(r[0] + t[0]) / 2, (r[1] + t[1]) / 2], w = this.transformInv_(x);
|
||
this.addQuad_(t, e, v, x, o, n, _, w, l - 1), this.addQuad_(x, v, i, r, w, _, s, a, l - 1)
|
||
} else {
|
||
var b = [(t[0] + e[0]) / 2, (t[1] + e[1]) / 2], C = this.transformInv_(b),
|
||
S = [(i[0] + r[0]) / 2, (i[1] + r[1]) / 2], E = this.transformInv_(S);
|
||
this.addQuad_(t, b, S, r, o, C, E, a, l - 1), this.addQuad_(b, e, i, S, C, n, s, E, l - 1)
|
||
}
|
||
return
|
||
}
|
||
}
|
||
if (p) {
|
||
if (!this.canWrapXInSource_) return;
|
||
this.wrapsXInSource_ = !0
|
||
}
|
||
this.addTriangle_(t, i, r, o, s, a), this.addTriangle_(t, e, i, o, n, s)
|
||
}
|
||
}, fx.prototype.calculateSourceExtent = function () {
|
||
var t = [1 / 0, 1 / 0, -1 / 0, -1 / 0];
|
||
return this.triangles_.forEach(function (e, i, r) {
|
||
var o = e.source;
|
||
St(t, o[0]), St(t, o[1]), St(t, o[2])
|
||
}), t
|
||
}, fx.prototype.getTriangles = function () {
|
||
return this.triangles_
|
||
};
|
||
var gx = fx, mx = function (t) {
|
||
function e(e, i, r, o, n, s) {
|
||
var a = e.getExtent(), l = i.getExtent(), h = l ? Dt(r, l) : r, u = cx(e, i, At(h), o),
|
||
c = new gx(e, i, h, a, u * Sa), p = s(c.calculateSourceExtent(), u, n), d = So.LOADED;
|
||
p && (d = So.IDLE);
|
||
var f = p ? p.getPixelRatio() : 1;
|
||
t.call(this, r, o, f, d), this.targetProj_ = i, this.maxSourceExtent_ = a, this.triangulation_ = c, this.targetResolution_ = o, this.targetExtent_ = r, this.sourceImage_ = p, this.sourcePixelRatio_ = f, this.canvas_ = null, this.sourceListenerKey_ = null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.disposeInternal = function () {
|
||
this.state == So.LOADING && this.unlistenSource_(), t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.getImage = function () {
|
||
return this.canvas_
|
||
}, e.prototype.getProjection = function () {
|
||
return this.targetProj_
|
||
}, e.prototype.reproject_ = function () {
|
||
var t = this.sourceImage_.getState();
|
||
if (t == So.LOADED) {
|
||
var e = Ut(this.targetExtent_) / this.targetResolution_,
|
||
i = Nt(this.targetExtent_) / this.targetResolution_;
|
||
this.canvas_ = dx(e, i, this.sourcePixelRatio_, this.sourceImage_.getResolution(), this.maxSourceExtent_, this.targetResolution_, this.targetExtent_, this.triangulation_, [{
|
||
extent: this.sourceImage_.getExtent(),
|
||
image: this.sourceImage_.getImage()
|
||
}], 0)
|
||
}
|
||
this.state = t, this.changed()
|
||
}, e.prototype.load = function () {
|
||
if (this.state == So.IDLE) {
|
||
this.state = So.LOADING, this.changed();
|
||
var t = this.sourceImage_.getState();
|
||
t == So.LOADED || t == So.ERROR ? this.reproject_() : (this.sourceListenerKey_ = w(this.sourceImage_, F.CHANGE, function (t) {
|
||
var e = this.sourceImage_.getState();
|
||
e != So.LOADED && e != So.ERROR || (this.unlistenSource_(), this.reproject_())
|
||
}, this), this.sourceImage_.load())
|
||
}
|
||
}, e.prototype.unlistenSource_ = function () {
|
||
S(this.sourceListenerKey_), this.sourceListenerKey_ = null
|
||
}, e
|
||
}(Co), yx = function (t) {
|
||
function e(e, i, r, o, n, s, a, l, h, u, c) {
|
||
t.call(this, n, Ro.IDLE), this.renderEdges_ = void 0 !== c && c, this.pixelRatio_ = a, this.gutter_ = l, this.canvas_ = null, this.sourceTileGrid_ = i, this.targetTileGrid_ = o, this.wrappedTileCoord_ = s || n, this.sourceTiles_ = [], this.sourcesListenerKeys_ = null, this.sourceZ_ = 0;
|
||
var p = o.getTileCoordExtent(this.wrappedTileCoord_), d = this.targetTileGrid_.getExtent(),
|
||
f = this.sourceTileGrid_.getExtent(), g = d ? Dt(p, d) : p;
|
||
if (0 !== It(g)) {
|
||
var m = e.getExtent();
|
||
m && (f = f ? Dt(f, m) : m);
|
||
var y = o.getResolution(this.wrappedTileCoord_[0]), v = cx(e, r, At(g), y);
|
||
if (!isFinite(v) || v <= 0) this.state = Ro.EMPTY; else {
|
||
var _ = void 0 !== u ? u : Sa;
|
||
if (this.triangulation_ = new gx(e, r, g, f, v * _), 0 !== this.triangulation_.getTriangles().length) {
|
||
this.sourceZ_ = i.getZForResolution(v);
|
||
var x = this.triangulation_.calculateSourceExtent();
|
||
if (f && (e.canWrapX() ? (x[1] = te(x[1], f[1], f[3]), x[3] = te(x[3], f[1], f[3])) : x = Dt(x, f)), It(x)) {
|
||
for (var w = i.getTileRangeForExtentAndZ(x, this.sourceZ_), b = w.minX; b <= w.maxX; b++) for (var C = w.minY; C <= w.maxY; C++) {
|
||
var S = h(this.sourceZ_, b, C, a);
|
||
S && this.sourceTiles_.push(S)
|
||
}
|
||
0 === this.sourceTiles_.length && (this.state = Ro.EMPTY)
|
||
} else this.state = Ro.EMPTY
|
||
} else this.state = Ro.EMPTY
|
||
}
|
||
} else this.state = Ro.EMPTY
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.disposeInternal = function () {
|
||
this.state == Ro.LOADING && this.unlistenSources_(), t.prototype.disposeInternal.call(this)
|
||
}, e.prototype.getImage = function () {
|
||
return this.canvas_
|
||
}, e.prototype.reproject_ = function () {
|
||
var t = [];
|
||
if (this.sourceTiles_.forEach(function (e, i, r) {
|
||
e && e.getState() == Ro.LOADED && t.push({
|
||
extent: this.sourceTileGrid_.getTileCoordExtent(e.tileCoord),
|
||
image: e.getImage()
|
||
})
|
||
}.bind(this)), this.sourceTiles_.length = 0, 0 === t.length) this.state = Ro.ERROR; else {
|
||
var e = this.wrappedTileCoord_[0], i = this.targetTileGrid_.getTileSize(e),
|
||
r = "number" == typeof i ? i : i[0], o = "number" == typeof i ? i : i[1],
|
||
n = this.targetTileGrid_.getResolution(e),
|
||
s = this.sourceTileGrid_.getResolution(this.sourceZ_),
|
||
a = this.targetTileGrid_.getTileCoordExtent(this.wrappedTileCoord_);
|
||
this.canvas_ = dx(r, o, this.pixelRatio_, s, this.sourceTileGrid_.getExtent(), n, a, this.triangulation_, t, this.gutter_, this.renderEdges_), this.state = Ro.LOADED
|
||
}
|
||
this.changed()
|
||
}, e.prototype.load = function () {
|
||
if (this.state == Ro.IDLE) {
|
||
this.state = Ro.LOADING, this.changed();
|
||
var t = 0;
|
||
this.sourcesListenerKeys_ = [], this.sourceTiles_.forEach(function (e, i, r) {
|
||
var o = e.getState();
|
||
if (o == Ro.IDLE || o == Ro.LOADING) {
|
||
t++;
|
||
var n = w(e, F.CHANGE, function (i) {
|
||
var r = e.getState();
|
||
r != Ro.LOADED && r != Ro.ERROR && r != Ro.EMPTY || (S(n), 0 === --t && (this.unlistenSources_(), this.reproject_()))
|
||
}, this);
|
||
this.sourcesListenerKeys_.push(n)
|
||
}
|
||
}.bind(this)), this.sourceTiles_.forEach(function (t, e, i) {
|
||
t.getState() == Ro.IDLE && t.load()
|
||
}), 0 === t && setTimeout(this.reproject_.bind(this), 0)
|
||
}
|
||
}, e.prototype.unlistenSources_ = function () {
|
||
this.sourcesListenerKeys_.forEach(S), this.sourcesListenerKeys_ = null
|
||
}, e
|
||
}(Mo);
|
||
|
||
function vx(t, e) {
|
||
var i = /\{z\}/g, r = /\{x\}/g, o = /\{y\}/g, n = /\{-y\}/g;
|
||
return function (s, a, l) {
|
||
return s ? t.replace(i, s[0].toString()).replace(r, s[1].toString()).replace(o, function () {
|
||
return (-s[2] - 1).toString()
|
||
}).replace(n, function () {
|
||
var t = s[0], i = e.getFullTileRange(t);
|
||
return W(i, 55), (i.getHeight() + s[2]).toString()
|
||
}) : void 0
|
||
}
|
||
}
|
||
|
||
function _x(t, e) {
|
||
for (var i = t.length, r = new Array(i), o = 0; o < i; ++o) r[o] = vx(t[o], e);
|
||
return xx(r)
|
||
}
|
||
|
||
function xx(t) {
|
||
return 1 === t.length ? t[0] : function (e, i, r) {
|
||
if (e) {
|
||
var o = le(ch(e), t.length);
|
||
return t[o](e, i, r)
|
||
}
|
||
}
|
||
}
|
||
|
||
function wx(t, e, i) {
|
||
}
|
||
|
||
function bx(t) {
|
||
var e = [], i = /\{([a-z])-([a-z])\}/.exec(t);
|
||
if (i) {
|
||
var r, o = i[1].charCodeAt(0), n = i[2].charCodeAt(0);
|
||
for (r = o; r <= n; ++r) e.push(t.replace(i[0], String.fromCharCode(r)));
|
||
return e
|
||
}
|
||
if (i = i = /\{(\d+)-(\d+)\}/.exec(t)) {
|
||
for (var s = parseInt(i[2], 10), a = parseInt(i[1], 10); a <= s; a++) e.push(t.replace(i[0], a.toString()));
|
||
return e
|
||
}
|
||
return e.push(t), e
|
||
}
|
||
|
||
function Cx(t, e, i, r) {
|
||
var o = document.createElement("script"), n = "olc_" + a(e);
|
||
|
||
function s() {
|
||
delete window[n], o.parentNode.removeChild(o)
|
||
}
|
||
|
||
o.async = !0, o.src = t + (-1 == t.indexOf("?") ? "?" : "&") + (r || "callback") + "=" + n;
|
||
var l = setTimeout(function () {
|
||
s(), i && i()
|
||
}, 1e4);
|
||
window[n] = function (t) {
|
||
clearTimeout(l), s(), e(t)
|
||
}, document.getElementsByTagName("head")[0].appendChild(o)
|
||
}
|
||
|
||
var Sx = {TILELOADSTART: "tileloadstart", TILELOADEND: "tileloadend", TILELOADERROR: "tileloaderror"},
|
||
Ex = function (t) {
|
||
function e(e) {
|
||
t.call(this, {
|
||
attributions: e.attributions,
|
||
cacheSize: e.cacheSize,
|
||
opaque: e.opaque,
|
||
projection: e.projection,
|
||
state: e.state,
|
||
tileGrid: e.tileGrid,
|
||
tilePixelRatio: e.tilePixelRatio,
|
||
wrapX: e.wrapX,
|
||
transition: e.transition,
|
||
key: e.key,
|
||
attributionsCollapsible: e.attributionsCollapsible
|
||
}), this.generateTileUrlFunction_ = !e.tileUrlFunction, this.tileLoadFunction = e.tileLoadFunction, this.tileUrlFunction = e.tileUrlFunction ? e.tileUrlFunction.bind(this) : wx, this.urls = null, e.urls ? this.setUrls(e.urls) : e.url && this.setUrl(e.url), e.tileUrlFunction && this.setTileUrlFunction(e.tileUrlFunction, this.key_), this.tileLoadingKeys_ = {}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getTileLoadFunction = function () {
|
||
return this.tileLoadFunction
|
||
}, e.prototype.getTileUrlFunction = function () {
|
||
return this.tileUrlFunction
|
||
}, e.prototype.getUrls = function () {
|
||
return this.urls
|
||
}, e.prototype.handleTileChange = function (t) {
|
||
var e, i = t.target, r = a(i), o = i.getState();
|
||
o == Ro.LOADING ? (this.tileLoadingKeys_[r] = !0, e = Sx.TILELOADSTART) : r in this.tileLoadingKeys_ && (delete this.tileLoadingKeys_[r], e = o == Ro.ERROR ? Sx.TILELOADERROR : o == Ro.LOADED || o == Ro.ABORT ? Sx.TILELOADEND : void 0), null != e && this.dispatchEvent(new ic(e, i))
|
||
}, e.prototype.setTileLoadFunction = function (t) {
|
||
this.tileCache.clear(), this.tileLoadFunction = t, this.changed()
|
||
}, e.prototype.setTileUrlFunction = function (t, e) {
|
||
this.tileUrlFunction = t, this.tileCache.pruneExceptNewestZ(), void 0 !== e ? this.setKey(e) : this.changed()
|
||
}, e.prototype.setUrl = function (t) {
|
||
var e = this.urls = bx(t);
|
||
this.setUrls(e)
|
||
}, e.prototype.setUrls = function (t) {
|
||
this.urls = t;
|
||
var e = t.join("\n");
|
||
this.generateTileUrlFunction_ ? this.setTileUrlFunction(_x(t, this.tileGrid), e) : this.setKey(e)
|
||
}, e.prototype.useTile = function (t, e, i) {
|
||
var r = lh(t, e, i);
|
||
this.tileCache.containsKey(r) && this.tileCache.get(r)
|
||
}, e
|
||
}(rc);
|
||
|
||
function Tx(t, e) {
|
||
t.getImage().src = e
|
||
}
|
||
|
||
var Rx = function (t) {
|
||
function e(e) {
|
||
t.call(this, {
|
||
attributions: e.attributions,
|
||
cacheSize: e.cacheSize,
|
||
opaque: e.opaque,
|
||
projection: e.projection,
|
||
state: e.state,
|
||
tileGrid: e.tileGrid,
|
||
tileLoadFunction: e.tileLoadFunction ? e.tileLoadFunction : Tx,
|
||
tilePixelRatio: e.tilePixelRatio,
|
||
tileUrlFunction: e.tileUrlFunction,
|
||
url: e.url,
|
||
urls: e.urls,
|
||
wrapX: e.wrapX,
|
||
transition: e.transition,
|
||
key: e.key,
|
||
attributionsCollapsible: e.attributionsCollapsible
|
||
}), this.crossOrigin = void 0 !== e.crossOrigin ? e.crossOrigin : null, this.tileClass = void 0 !== e.tileClass ? e.tileClass : zo, this.tileCacheForProjection = {}, this.tileGridForProjection = {}, this.reprojectionErrorThreshold_ = e.reprojectionErrorThreshold, this.renderReprojectionEdges_ = !1
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.canExpireCache = function () {
|
||
if (this.tileCache.canExpireCache()) return !0;
|
||
for (var t in this.tileCacheForProjection) if (this.tileCacheForProjection[t].canExpireCache()) return !0;
|
||
return !1
|
||
}, e.prototype.expireCache = function (t, e) {
|
||
var i = this.getTileCacheForProjection(t);
|
||
for (var r in this.tileCache.expireCache(this.tileCache == i ? e : {}), this.tileCacheForProjection) {
|
||
var o = this.tileCacheForProjection[r];
|
||
o.expireCache(o == i ? e : {})
|
||
}
|
||
}, e.prototype.getGutterForProjection = function (t) {
|
||
return this.getProjection() && t && !Qe(this.getProjection(), t) ? 0 : this.getGutter()
|
||
}, e.prototype.getGutter = function () {
|
||
return 0
|
||
}, e.prototype.getOpaque = function (e) {
|
||
return !(this.getProjection() && e && !Qe(this.getProjection(), e)) && t.prototype.getOpaque.call(this, e)
|
||
}, e.prototype.getTileGridForProjection = function (t) {
|
||
var e = this.getProjection();
|
||
if (!this.tileGrid || e && !Qe(e, t)) {
|
||
var i = a(t);
|
||
return i in this.tileGridForProjection || (this.tileGridForProjection[i] = qu(t)), this.tileGridForProjection[i]
|
||
}
|
||
return this.tileGrid
|
||
}, e.prototype.getTileCacheForProjection = function (t) {
|
||
var e = this.getProjection();
|
||
if (!e || Qe(e, t)) return this.tileCache;
|
||
var i = a(t);
|
||
return i in this.tileCacheForProjection || (this.tileCacheForProjection[i] = new fh(this.tileCache.highWaterMark)), this.tileCacheForProjection[i]
|
||
}, e.prototype.createTile_ = function (t, e, i, r, o, n) {
|
||
var s = [t, e, i], a = this.getTileCoordForTileUrlFunction(s, o),
|
||
l = a ? this.tileUrlFunction(a, r, o) : void 0,
|
||
h = new this.tileClass(s, void 0 !== l ? Ro.IDLE : Ro.EMPTY, void 0 !== l ? l : "", this.crossOrigin, this.tileLoadFunction, this.tileOptions);
|
||
return h.key = n, w(h, F.CHANGE, this.handleTileChange, this), h
|
||
}, e.prototype.getTile = function (t, e, i, r, o) {
|
||
var n = this.getProjection();
|
||
if (n && o && !Qe(n, o)) {
|
||
var s, a = this.getTileCacheForProjection(o), l = [t, e, i], h = hh(l);
|
||
a.containsKey(h) && (s = a.get(h));
|
||
var u = this.getKey();
|
||
if (s && s.key == u) return s;
|
||
var c = this.getTileGridForProjection(n), p = this.getTileGridForProjection(o),
|
||
d = this.getTileCoordForTileUrlFunction(l, o),
|
||
f = new yx(n, c, o, p, l, d, this.getTilePixelRatio(r), this.getGutter(), function (t, e, i, r) {
|
||
return this.getTileInternal(t, e, i, r, n)
|
||
}.bind(this), this.reprojectionErrorThreshold_, this.renderReprojectionEdges_);
|
||
return f.key = u, s ? (f.interimTile = s, f.refreshInterimChain(), a.replace(h, f)) : a.set(h, f), f
|
||
}
|
||
return this.getTileInternal(t, e, i, r, n || o)
|
||
}, e.prototype.getTileInternal = function (t, e, i, r, o) {
|
||
var n = null, s = lh(t, e, i), a = this.getKey();
|
||
if (this.tileCache.containsKey(s)) {
|
||
if ((n = this.tileCache.get(s)).key != a) {
|
||
var l = n;
|
||
n = this.createTile_(t, e, i, r, o, a), l.getState() == Ro.IDLE ? n.interimTile = l.interimTile : n.interimTile = l, n.refreshInterimChain(), this.tileCache.replace(s, n)
|
||
}
|
||
} else n = this.createTile_(t, e, i, r, o, a), this.tileCache.set(s, n);
|
||
return n
|
||
}, e.prototype.setRenderReprojectionEdges = function (t) {
|
||
if (this.renderReprojectionEdges_ != t) {
|
||
for (var e in this.renderReprojectionEdges_ = t, this.tileCacheForProjection) this.tileCacheForProjection[e].clear();
|
||
this.changed()
|
||
}
|
||
}, e.prototype.setTileGridForProjection = function (t, e) {
|
||
var i = We(t);
|
||
if (i) {
|
||
var r = a(i);
|
||
r in this.tileGridForProjection || (this.tileGridForProjection[r] = e)
|
||
}
|
||
}, e
|
||
}(Ex), Px = function (t) {
|
||
function e(e) {
|
||
var i = void 0 !== e.hidpi && e.hidpi;
|
||
t.call(this, {
|
||
cacheSize: e.cacheSize,
|
||
crossOrigin: "anonymous",
|
||
opaque: !0,
|
||
projection: We("EPSG:3857"),
|
||
reprojectionErrorThreshold: e.reprojectionErrorThreshold,
|
||
state: hs.LOADING,
|
||
tileLoadFunction: e.tileLoadFunction,
|
||
tilePixelRatio: i ? 2 : 1,
|
||
wrapX: void 0 === e.wrapX || e.wrapX,
|
||
transition: e.transition
|
||
}), this.hidpi_ = i, this.culture_ = void 0 !== e.culture ? e.culture : "en-us", this.maxZoom_ = void 0 !== e.maxZoom ? e.maxZoom : -1, this.apiKey_ = e.key, this.imagerySet_ = e.imagerySet, Cx("https://dev.virtualearth.net/REST/v1/Imagery/Metadata/" + this.imagerySet_ + "?uriScheme=https&include=ImageryProviders&key=" + this.apiKey_ + "&c=" + this.culture_, this.handleImageryMetadataResponse.bind(this), void 0, "jsonp")
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getApiKey = function () {
|
||
return this.apiKey_
|
||
}, e.prototype.getImagerySet = function () {
|
||
return this.imagerySet_
|
||
}, e.prototype.handleImageryMetadataResponse = function (t) {
|
||
if (200 == t.statusCode && "OK" == t.statusDescription && "ValidCredentials" == t.authenticationResultCode && 1 == t.resourceSets.length && 1 == t.resourceSets[0].resources.length) {
|
||
var e = t.resourceSets[0].resources[0], i = -1 == this.maxZoom_ ? e.zoomMax : this.maxZoom_,
|
||
r = tc(this.getProjection()), o = this.hidpi_ ? 2 : 1,
|
||
n = e.imageWidth == e.imageHeight ? e.imageWidth / o : [e.imageWidth / o, e.imageHeight / o],
|
||
s = Ju({extent: r, minZoom: e.zoomMin, maxZoom: i, tileSize: n});
|
||
this.tileGrid = s;
|
||
var a = this.culture_, l = this.hidpi_;
|
||
if (this.tileUrlFunction = xx(e.imageUrlSubdomains.map(function (t) {
|
||
var i = [0, 0, 0], r = e.imageUrl.replace("{subdomain}", t).replace("{culture}", a);
|
||
return function (t, e, o) {
|
||
if (t) {
|
||
ah(t[0], t[1], -t[2] - 1, i);
|
||
var n = r;
|
||
return l && (n += "&dpi=d1&device=mobile"), n.replace("{quadkey}", ph(i))
|
||
}
|
||
}
|
||
})), e.imageryProviders) {
|
||
var h = ti(We("EPSG:4326"), this.getProjection());
|
||
this.setAttributions(function (t) {
|
||
var i = [], r = t.viewState,
|
||
o = this.getTileGrid().getTileCoordForCoordAndResolution(r.center, r.resolution)[0];
|
||
return e.imageryProviders.map(function (e) {
|
||
for (var r = !1, n = e.coverageAreas, s = 0, a = n.length; s < a; ++s) {
|
||
var l = n[s];
|
||
if (o >= l.zoomMin && o <= l.zoomMax) {
|
||
var u = l.bbox;
|
||
if (Bt(Xt([u[1], u[0], u[3], u[2]], h), t.extent)) {
|
||
r = !0;
|
||
break
|
||
}
|
||
}
|
||
}
|
||
r && i.push(e.attribution)
|
||
}), i.push('<a class="ol-attribution-bing-tos" href="https://www.microsoft.com/maps/product/terms.html">Terms of Use</a>'), i
|
||
}.bind(this))
|
||
}
|
||
this.setState(hs.READY)
|
||
} else this.setState(hs.ERROR)
|
||
}, e
|
||
}(Rx), Lx = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = void 0 !== i.projection ? i.projection : "EPSG:3857",
|
||
o = void 0 !== i.tileGrid ? i.tileGrid : Ju({
|
||
extent: tc(r),
|
||
maxZoom: i.maxZoom,
|
||
minZoom: i.minZoom,
|
||
tileSize: i.tileSize
|
||
});
|
||
t.call(this, {
|
||
attributions: i.attributions,
|
||
cacheSize: i.cacheSize,
|
||
crossOrigin: i.crossOrigin,
|
||
opaque: i.opaque,
|
||
projection: r,
|
||
reprojectionErrorThreshold: i.reprojectionErrorThreshold,
|
||
tileGrid: o,
|
||
tileLoadFunction: i.tileLoadFunction,
|
||
tilePixelRatio: i.tilePixelRatio,
|
||
tileUrlFunction: i.tileUrlFunction,
|
||
url: i.url,
|
||
urls: i.urls,
|
||
wrapX: void 0 === i.wrapX || i.wrapX,
|
||
transition: i.transition,
|
||
attributionsCollapsible: i.attributionsCollapsible
|
||
})
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(Rx), Ix = function (t) {
|
||
function e(e) {
|
||
t.call(this, {
|
||
attributions: e.attributions,
|
||
cacheSize: e.cacheSize,
|
||
crossOrigin: e.crossOrigin,
|
||
maxZoom: void 0 !== e.maxZoom ? e.maxZoom : 18,
|
||
minZoom: e.minZoom,
|
||
projection: e.projection,
|
||
wrapX: e.wrapX
|
||
}), this.account_ = e.account, this.mapId_ = e.map || "", this.config_ = e.config || {}, this.templateCache_ = {}, this.initializeMap_()
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getConfig = function () {
|
||
return this.config_
|
||
}, e.prototype.updateConfig = function (t) {
|
||
p(this.config_, t), this.initializeMap_()
|
||
}, e.prototype.setConfig = function (t) {
|
||
this.config_ = t || {}, this.initializeMap_()
|
||
}, e.prototype.initializeMap_ = function () {
|
||
var t = JSON.stringify(this.config_);
|
||
if (this.templateCache_[t]) this.applyTemplate_(this.templateCache_[t]); else {
|
||
var e = "https://" + this.account_ + ".carto.com/api/v1/map";
|
||
this.mapId_ && (e += "/named/" + this.mapId_);
|
||
var i = new XMLHttpRequest;
|
||
i.addEventListener("load", this.handleInitResponse_.bind(this, t)), i.addEventListener("error", this.handleInitError_.bind(this)), i.open("POST", e), i.setRequestHeader("Content-type", "application/json"), i.send(JSON.stringify(this.config_))
|
||
}
|
||
}, e.prototype.handleInitResponse_ = function (t, e) {
|
||
var i = e.target;
|
||
if (!i.status || i.status >= 200 && i.status < 300) {
|
||
var r;
|
||
try {
|
||
r = JSON.parse(i.responseText)
|
||
} catch (t) {
|
||
return void this.setState(hs.ERROR)
|
||
}
|
||
this.applyTemplate_(r), this.templateCache_[t] = r, this.setState(hs.READY)
|
||
} else this.setState(hs.ERROR)
|
||
}, e.prototype.handleInitError_ = function (t) {
|
||
this.setState(hs.ERROR)
|
||
}, e.prototype.applyTemplate_ = function (t) {
|
||
var e = "https://" + t.cdn_url.https + "/" + this.account_ + "/api/v1/map/" + t.layergroupid + "/{z}/{x}/{y}.png";
|
||
this.setUrl(e)
|
||
}, e
|
||
}(Lx), Ox = function (t) {
|
||
function e(e) {
|
||
t.call(this, {
|
||
attributions: e.attributions,
|
||
wrapX: e.wrapX
|
||
}), this.resolution = void 0, this.distance = void 0 !== e.distance ? e.distance : 20, this.features = [], this.geometryFunction = e.geometryFunction || function (t) {
|
||
var e = t.getGeometry();
|
||
return W(e.getType() == Zt.POINT, 10), e
|
||
}, this.source = e.source, w(this.source, F.CHANGE, this.refresh, this)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getDistance = function () {
|
||
return this.distance
|
||
}, e.prototype.getSource = function () {
|
||
return this.source
|
||
}, e.prototype.loadFeatures = function (t, e, i) {
|
||
this.source.loadFeatures(t, e, i), e !== this.resolution && (this.clear(), this.resolution = e, this.cluster(), this.addFeatures(this.features))
|
||
}, e.prototype.setDistance = function (t) {
|
||
this.distance = t, this.refresh()
|
||
}, e.prototype.refresh = function () {
|
||
this.clear(), this.cluster(), this.addFeatures(this.features), t.prototype.refresh.call(this)
|
||
}, e.prototype.cluster = function () {
|
||
if (void 0 !== this.resolution) {
|
||
this.features.length = 0;
|
||
for (var t = [1 / 0, 1 / 0, -1 / 0, -1 / 0], e = this.distance * this.resolution, i = this.source.getFeatures(), r = {}, o = 0, n = i.length; o < n; o++) {
|
||
var s = i[o];
|
||
if (!(a(s) in r)) {
|
||
var l = this.geometryFunction(s);
|
||
if (l) {
|
||
_t(l.getCoordinates(), t), ht(t, e, t);
|
||
var h = this.source.getFeaturesInExtent(t);
|
||
h = h.filter(function (t) {
|
||
var e = a(t);
|
||
return !(e in r) && (r[e] = !0, !0)
|
||
}), this.features.push(this.createCluster(h))
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}, e.prototype.createCluster = function (t) {
|
||
for (var e = [0, 0], i = t.length - 1; i >= 0; --i) {
|
||
var r = this.geometryFunction(t[i]);
|
||
r ? Fr(e, r.getCoordinates()) : t.splice(i, 1)
|
||
}
|
||
Br(e, 1 / t.length);
|
||
var o = new X(new qi(e));
|
||
return o.set("features", t), o
|
||
}, e
|
||
}(b_), Mx = "imageloadstart", Ax = "imageloadend", kx = "imageloaderror", Fx = function (t) {
|
||
function e(e, i) {
|
||
t.call(this, e), this.image = i
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A);
|
||
|
||
function Nx(t, e) {
|
||
t.getImage().src = e
|
||
}
|
||
|
||
var Dx = function (t) {
|
||
function e(e) {
|
||
t.call(this, {
|
||
attributions: e.attributions,
|
||
projection: e.projection,
|
||
state: e.state
|
||
}), this.resolutions_ = void 0 !== e.resolutions ? e.resolutions : null, this.reprojectedImage_ = null, this.reprojectedRevision_ = 0
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getResolutions = function () {
|
||
return this.resolutions_
|
||
}, e.prototype.findNearestResolution = function (t) {
|
||
if (this.resolutions_) {
|
||
var e = J(this.resolutions_, t, 0);
|
||
t = this.resolutions_[e]
|
||
}
|
||
return t
|
||
}, e.prototype.getImage = function (t, e, i, r) {
|
||
var o = this.getProjection();
|
||
if (o && r && !Qe(o, r)) {
|
||
if (this.reprojectedImage_) {
|
||
if (this.reprojectedRevision_ == this.getRevision() && Qe(this.reprojectedImage_.getProjection(), r) && this.reprojectedImage_.getResolution() == e && bt(this.reprojectedImage_.getExtent(), t)) return this.reprojectedImage_;
|
||
this.reprojectedImage_.dispose(), this.reprojectedImage_ = null
|
||
}
|
||
return this.reprojectedImage_ = new mx(o, r, t, e, i, function (t, e, i) {
|
||
return this.getImageInternal(t, e, i, o)
|
||
}.bind(this)), this.reprojectedRevision_ = this.getRevision(), this.reprojectedImage_
|
||
}
|
||
return o && (r = o), this.getImageInternal(t, e, i, r)
|
||
}, e.prototype.getImageInternal = function (t, e, i, r) {
|
||
return n()
|
||
}, e.prototype.handleImageChange = function (t) {
|
||
var e = t.target;
|
||
switch (e.getState()) {
|
||
case So.LOADING:
|
||
this.loading = !0, this.dispatchEvent(new Fx(Mx, e));
|
||
break;
|
||
case So.LOADED:
|
||
this.loading = !1, this.dispatchEvent(new Fx(Ax, e));
|
||
break;
|
||
case So.ERROR:
|
||
this.loading = !1, this.dispatchEvent(new Fx(kx, e))
|
||
}
|
||
}, e
|
||
}(Yu);
|
||
|
||
function Gx(t, e) {
|
||
var i = [];
|
||
Object.keys(e).forEach(function (t) {
|
||
null !== e[t] && void 0 !== e[t] && i.push(t + "=" + encodeURIComponent(e[t]))
|
||
});
|
||
var r = i.join("&");
|
||
return (t = -1 === (t = t.replace(/[?&]$/, "")).indexOf("?") ? t + "?" : t + "&") + r
|
||
}
|
||
|
||
var jx = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {
|
||
attributions: i.attributions,
|
||
projection: i.projection,
|
||
resolutions: i.resolutions
|
||
}), this.crossOrigin_ = void 0 !== i.crossOrigin ? i.crossOrigin : null, this.hidpi_ = void 0 === i.hidpi || i.hidpi, this.url_ = i.url, this.imageLoadFunction_ = void 0 !== i.imageLoadFunction ? i.imageLoadFunction : Nx, this.params_ = i.params || {}, this.image_ = null, this.imageSize_ = [0, 0], this.renderedRevision_ = 0, this.ratio_ = void 0 !== i.ratio ? i.ratio : 1.5
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getParams = function () {
|
||
return this.params_
|
||
}, e.prototype.getImageInternal = function (t, e, i, r) {
|
||
if (void 0 === this.url_) return null;
|
||
e = this.findNearestResolution(e), i = this.hidpi_ ? i : 1;
|
||
var o = this.image_;
|
||
if (o && this.renderedRevision_ == this.getRevision() && o.getResolution() == e && o.getPixelRatio() == i && dt(o.getExtent(), t)) return o;
|
||
var n = {F: "image", FORMAT: "PNG32", TRANSPARENT: !0};
|
||
p(n, this.params_);
|
||
var s = ((t = t.slice())[0] + t[2]) / 2, a = (t[1] + t[3]) / 2;
|
||
if (1 != this.ratio_) {
|
||
var l = this.ratio_ * Ut(t) / 2, h = this.ratio_ * Nt(t) / 2;
|
||
t[0] = s - l, t[1] = a - h, t[2] = s + l, t[3] = a + h
|
||
}
|
||
var u = e / i, c = Math.ceil(Ut(t) / u), d = Math.ceil(Nt(t) / u);
|
||
t[0] = s - u * c / 2, t[2] = s + u * c / 2, t[1] = a - u * d / 2, t[3] = a + u * d / 2, this.imageSize_[0] = c, this.imageSize_[1] = d;
|
||
var f = this.getRequestUrl_(t, this.imageSize_, i, r, n);
|
||
return this.image_ = new Eo(t, e, i, f, this.crossOrigin_, this.imageLoadFunction_), this.renderedRevision_ = this.getRevision(), w(this.image_, F.CHANGE, this.handleImageChange, this), this.image_
|
||
}, e.prototype.getImageLoadFunction = function () {
|
||
return this.imageLoadFunction_
|
||
}, e.prototype.getRequestUrl_ = function (t, e, i, r, o) {
|
||
var n = r.getCode().split(":").pop();
|
||
o.SIZE = e[0] + "," + e[1], o.BBOX = t.join(","), o.BBOXSR = n, o.IMAGESR = n, o.DPI = Math.round(90 * i);
|
||
var s = this.url_,
|
||
a = s.replace(/MapServer\/?$/, "MapServer/export").replace(/ImageServer\/?$/, "ImageServer/exportImage");
|
||
return a == s && W(!1, 50), Gx(a, o)
|
||
}, e.prototype.getUrl = function () {
|
||
return this.url_
|
||
}, e.prototype.setImageLoadFunction = function (t) {
|
||
this.image_ = null, this.imageLoadFunction_ = t, this.changed()
|
||
}, e.prototype.setUrl = function (t) {
|
||
t != this.url_ && (this.url_ = t, this.image_ = null, this.changed())
|
||
}, e.prototype.updateParams = function (t) {
|
||
p(this.params_, t), this.image_ = null, this.changed()
|
||
}, e
|
||
}(Dx), zx = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {
|
||
attributions: i.attributions,
|
||
projection: i.projection,
|
||
resolutions: i.resolutions,
|
||
state: i.state
|
||
}), this.canvasFunction_ = i.canvasFunction, this.canvas_ = null, this.renderedRevision_ = 0, this.ratio_ = void 0 !== i.ratio ? i.ratio : 1.5
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getImageInternal = function (t, e, i, r) {
|
||
e = this.findNearestResolution(e);
|
||
var o = this.canvas_;
|
||
if (o && this.renderedRevision_ == this.getRevision() && o.getResolution() == e && o.getPixelRatio() == i && dt(o.getExtent(), t)) return o;
|
||
Wt(t = t.slice(), this.ratio_);
|
||
var n = [Ut(t) / e * i, Nt(t) / e * i], s = this.canvasFunction_.call(this, t, e, i, n, r);
|
||
return s && (o = new To(t, e, i, s)), this.canvas_ = o, this.renderedRevision_ = this.getRevision(), o
|
||
}, e
|
||
}(Dx);
|
||
var Ux = function (t) {
|
||
function e(e) {
|
||
t.call(this, {
|
||
projection: e.projection,
|
||
resolutions: e.resolutions
|
||
}), this.crossOrigin_ = void 0 !== e.crossOrigin ? e.crossOrigin : null, this.displayDpi_ = void 0 !== e.displayDpi ? e.displayDpi : 96, this.params_ = e.params || {}, this.url_ = e.url, this.imageLoadFunction_ = void 0 !== e.imageLoadFunction ? e.imageLoadFunction : Nx, this.hidpi_ = void 0 === e.hidpi || e.hidpi, this.metersPerUnit_ = void 0 !== e.metersPerUnit ? e.metersPerUnit : 1, this.ratio_ = void 0 !== e.ratio ? e.ratio : 1, this.useOverlay_ = void 0 !== e.useOverlay && e.useOverlay, this.image_ = null, this.renderedRevision_ = 0
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getParams = function () {
|
||
return this.params_
|
||
}, e.prototype.getImageInternal = function (t, e, i, r) {
|
||
e = this.findNearestResolution(e), i = this.hidpi_ ? i : 1;
|
||
var o = this.image_;
|
||
if (o && this.renderedRevision_ == this.getRevision() && o.getResolution() == e && o.getPixelRatio() == i && dt(o.getExtent(), t)) return o;
|
||
1 != this.ratio_ && Wt(t = t.slice(), this.ratio_);
|
||
var n = [Ut(t) / e * i, Nt(t) / e * i];
|
||
if (void 0 !== this.url_) {
|
||
var s = this.getUrl(this.url_, this.params_, t, n, r);
|
||
w(o = new Eo(t, e, i, s, this.crossOrigin_, this.imageLoadFunction_), F.CHANGE, this.handleImageChange, this)
|
||
} else o = null;
|
||
return this.image_ = o, this.renderedRevision_ = this.getRevision(), o
|
||
}, e.prototype.getImageLoadFunction = function () {
|
||
return this.imageLoadFunction_
|
||
}, e.prototype.updateParams = function (t) {
|
||
p(this.params_, t), this.changed()
|
||
}, e.prototype.getUrl = function (t, e, i, r, o) {
|
||
var n = function (t, e, i, r) {
|
||
var o = Ut(t), n = Nt(t), s = e[0], a = e[1], l = .0254 / r;
|
||
return a * o > s * n ? o * i / (s * l) : n * i / (a * l)
|
||
}(i, r, this.metersPerUnit_, this.displayDpi_), s = At(i), a = {
|
||
OPERATION: this.useOverlay_ ? "GETDYNAMICMAPOVERLAYIMAGE" : "GETMAPIMAGE",
|
||
VERSION: "2.0.0",
|
||
LOCALE: "en",
|
||
CLIENTAGENT: "ol/source/ImageMapGuide source",
|
||
CLIP: "1",
|
||
SETDISPLAYDPI: this.displayDpi_,
|
||
SETDISPLAYWIDTH: Math.round(r[0]),
|
||
SETDISPLAYHEIGHT: Math.round(r[1]),
|
||
SETVIEWSCALE: n,
|
||
SETVIEWCENTERX: s[0],
|
||
SETVIEWCENTERY: s[1]
|
||
};
|
||
return p(a, e), Gx(t, a)
|
||
}, e.prototype.setImageLoadFunction = function (t) {
|
||
this.image_ = null, this.imageLoadFunction_ = t, this.changed()
|
||
}, e
|
||
}(Dx), Bx = function (t) {
|
||
function e(e) {
|
||
var i = void 0 !== e.crossOrigin ? e.crossOrigin : null,
|
||
r = void 0 !== e.imageLoadFunction ? e.imageLoadFunction : Nx;
|
||
t.call(this, {
|
||
attributions: e.attributions,
|
||
projection: We(e.projection)
|
||
}), this.url_ = e.url, this.imageExtent_ = e.imageExtent, this.image_ = new Eo(this.imageExtent_, void 0, 1, this.url_, i, r), this.imageSize_ = e.imageSize ? e.imageSize : null, w(this.image_, F.CHANGE, this.handleImageChange, this)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getImageExtent = function () {
|
||
return this.imageExtent_
|
||
}, e.prototype.getImageInternal = function (t, e, i, r) {
|
||
return Bt(t, this.image_.getExtent()) ? this.image_ : null
|
||
}, e.prototype.getUrl = function () {
|
||
return this.url_
|
||
}, e.prototype.handleImageChange = function (e) {
|
||
if (this.image_.getState() == So.LOADED) {
|
||
var i, r, o = this.image_.getExtent(), n = this.image_.getImage();
|
||
this.imageSize_ ? (i = this.imageSize_[0], r = this.imageSize_[1]) : (i = n.width, r = n.height);
|
||
var s = Nt(o) / r, a = Math.ceil(Ut(o) / s);
|
||
if (a != i) {
|
||
var l = Ao(a, r), h = l.canvas;
|
||
l.drawImage(n, 0, 0, i, r, 0, 0, h.width, h.height), this.image_.setImage(h)
|
||
}
|
||
}
|
||
t.prototype.handleImageChange.call(this, e)
|
||
}, e
|
||
}(Dx), Vx = "1.3.0",
|
||
Yx = {CARMENTA_SERVER: "carmentaserver", GEOSERVER: "geoserver", MAPSERVER: "mapserver", QGIS: "qgis"},
|
||
Wx = [101, 101], Hx = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {
|
||
attributions: i.attributions,
|
||
projection: i.projection,
|
||
resolutions: i.resolutions
|
||
}), this.crossOrigin_ = void 0 !== i.crossOrigin ? i.crossOrigin : null, this.url_ = i.url, this.imageLoadFunction_ = void 0 !== i.imageLoadFunction ? i.imageLoadFunction : Nx, this.params_ = i.params || {}, this.v13_ = !0, this.updateV13_(), this.serverType_ = i.serverType, this.hidpi_ = void 0 === i.hidpi || i.hidpi, this.image_ = null, this.imageSize_ = [0, 0], this.renderedRevision_ = 0, this.ratio_ = void 0 !== i.ratio ? i.ratio : 1.5
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getGetFeatureInfoUrl = function (t, e, i, r) {
|
||
if (void 0 !== this.url_) {
|
||
var o = We(i), n = this.getProjection();
|
||
n && n !== o && (e = cx(n, o, t, e), t = ii(t, o, n));
|
||
var s = Ft(t, e, 0, Wx), a = {
|
||
SERVICE: "WMS",
|
||
VERSION: Vx,
|
||
REQUEST: "GetFeatureInfo",
|
||
FORMAT: "image/png",
|
||
TRANSPARENT: !0,
|
||
QUERY_LAYERS: this.params_.LAYERS
|
||
};
|
||
p(a, this.params_, r);
|
||
var l = Math.floor((t[0] - s[0]) / e), h = Math.floor((s[3] - t[1]) / e);
|
||
return a[this.v13_ ? "I" : "X"] = l, a[this.v13_ ? "J" : "Y"] = h, this.getRequestUrl_(s, Wx, 1, n || o, a)
|
||
}
|
||
}, e.prototype.getParams = function () {
|
||
return this.params_
|
||
}, e.prototype.getImageInternal = function (t, e, i, r) {
|
||
if (void 0 === this.url_) return null;
|
||
e = this.findNearestResolution(e), 1 == i || this.hidpi_ && void 0 !== this.serverType_ || (i = 1);
|
||
var o = e / i, n = At(t), s = Ft(n, o, 0, [Math.ceil(Ut(t) / o), Math.ceil(Nt(t) / o)]),
|
||
a = Ft(n, o, 0, [Math.ceil(this.ratio_ * Ut(t) / o), Math.ceil(this.ratio_ * Nt(t) / o)]),
|
||
l = this.image_;
|
||
if (l && this.renderedRevision_ == this.getRevision() && l.getResolution() == e && l.getPixelRatio() == i && dt(l.getExtent(), s)) return l;
|
||
var h = {SERVICE: "WMS", VERSION: Vx, REQUEST: "GetMap", FORMAT: "image/png", TRANSPARENT: !0};
|
||
p(h, this.params_), this.imageSize_[0] = Math.round(Ut(a) / o), this.imageSize_[1] = Math.round(Nt(a) / o);
|
||
var u = this.getRequestUrl_(a, this.imageSize_, i, r, h);
|
||
return this.image_ = new Eo(a, e, i, u, this.crossOrigin_, this.imageLoadFunction_), this.renderedRevision_ = this.getRevision(), w(this.image_, F.CHANGE, this.handleImageChange, this), this.image_
|
||
}, e.prototype.getImageLoadFunction = function () {
|
||
return this.imageLoadFunction_
|
||
}, e.prototype.getRequestUrl_ = function (t, e, i, r, o) {
|
||
if (W(void 0 !== this.url_, 9), o[this.v13_ ? "CRS" : "SRS"] = r.getCode(), "STYLES" in this.params_ || (o.STYLES = ""), 1 != i) switch (this.serverType_) {
|
||
case Yx.GEOSERVER:
|
||
var n = 90 * i + .5 | 0;
|
||
"FORMAT_OPTIONS" in o ? o.FORMAT_OPTIONS += ";dpi:" + n : o.FORMAT_OPTIONS = "dpi:" + n;
|
||
break;
|
||
case Yx.MAPSERVER:
|
||
o.MAP_RESOLUTION = 90 * i;
|
||
break;
|
||
case Yx.CARMENTA_SERVER:
|
||
case Yx.QGIS:
|
||
o.DPI = 90 * i;
|
||
break;
|
||
default:
|
||
W(!1, 8)
|
||
}
|
||
o.WIDTH = e[0], o.HEIGHT = e[1];
|
||
var s, a = r.getAxisOrientation();
|
||
return s = this.v13_ && "ne" == a.substr(0, 2) ? [t[1], t[0], t[3], t[2]] : t, o.BBOX = s.join(","), Gx(this.url_, o)
|
||
}, e.prototype.getUrl = function () {
|
||
return this.url_
|
||
}, e.prototype.setImageLoadFunction = function (t) {
|
||
this.image_ = null, this.imageLoadFunction_ = t, this.changed()
|
||
}, e.prototype.setUrl = function (t) {
|
||
t != this.url_ && (this.url_ = t, this.image_ = null, this.changed())
|
||
}, e.prototype.updateParams = function (t) {
|
||
p(this.params_, t), this.updateV13_(), this.image_ = null, this.changed()
|
||
}, e.prototype.updateV13_ = function () {
|
||
var t = this.params_.VERSION || Vx;
|
||
this.v13_ = kr(t, "1.3") >= 0
|
||
}, e
|
||
}(Dx), Xx = '© <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors.',
|
||
qx = function (t) {
|
||
function e(e) {
|
||
var i, r = e || {};
|
||
i = void 0 !== r.attributions ? r.attributions : [Xx];
|
||
var o = void 0 !== r.crossOrigin ? r.crossOrigin : "anonymous",
|
||
n = void 0 !== r.url ? r.url : "https://{a-c}.tile.openstreetmap.org/{z}/{x}/{y}.png";
|
||
t.call(this, {
|
||
attributions: i,
|
||
cacheSize: r.cacheSize,
|
||
crossOrigin: o,
|
||
opaque: void 0 === r.opaque || r.opaque,
|
||
maxZoom: void 0 !== r.maxZoom ? r.maxZoom : 19,
|
||
reprojectionErrorThreshold: r.reprojectionErrorThreshold,
|
||
tileLoadFunction: r.tileLoadFunction,
|
||
url: n,
|
||
wrapX: r.wrapX,
|
||
attributionsCollapsible: !1
|
||
})
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(Lx), Zx = i(10), Kx = "beforeoperations", Jx = "afteroperations", $x = {PIXEL: "pixel", IMAGE: "image"},
|
||
Qx = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, e), this.extent = i.extent, this.resolution = i.viewState.resolution / i.pixelRatio, this.data = r
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(A), tw = null;
|
||
|
||
function ew(t, e, i) {
|
||
if (!t.prepareFrame(e, i)) return null;
|
||
var r = e.size[0], o = e.size[1];
|
||
if (tw) {
|
||
var n = tw.canvas;
|
||
n.width !== r || n.height !== o ? tw = Ao(r, o) : tw.clearRect(0, 0, r, o)
|
||
} else tw = Ao(r, o);
|
||
return t.composeFrame(e, i, tw), tw.getImageData(0, 0, r, o)
|
||
}
|
||
|
||
function iw(t) {
|
||
var e = t, i = t, r = t, o = null;
|
||
return "function" == typeof e.getTile ? o = function (t) {
|
||
var e = new lx({source: t});
|
||
return new fl(e)
|
||
}(e) : "function" == typeof i.getImage ? o = function (t) {
|
||
var e = new nx({source: t});
|
||
return new hl(e)
|
||
}(i) : r.getType() === Vo.TILE ? o = new fl(r) : r.getType() != Vo.IMAGE && r.getType() != Vo.VECTOR || (o = new hl(r)), o
|
||
}
|
||
|
||
var rw = function (t) {
|
||
function e(e) {
|
||
t.call(this, {projection: null}), this.worker_ = null, this.operationType_ = void 0 !== e.operationType ? e.operationType : $x.PIXEL, this.threads_ = void 0 !== e.threads ? e.threads : 1, this.renderers_ = function (t) {
|
||
for (var e = t.length, i = new Array(e), r = 0; r < e; ++r) i[r] = iw(t[r]);
|
||
return i
|
||
}(e.sources);
|
||
for (var i = 0, r = this.renderers_.length; i < r; ++i) w(this.renderers_[i], F.CHANGE, this.changed, this);
|
||
this.tileQueue_ = new Un(function () {
|
||
return 1
|
||
}, this.changed.bind(this));
|
||
for (var o = this.renderers_.map(function (t) {
|
||
return t.getLayer().getLayerState()
|
||
}), n = {}, s = 0, l = o.length; s < l; ++s) n[a(o[s].layer)] = o[s];
|
||
this.requestedFrameState_, this.renderedImageCanvas_ = null, this.renderedRevision_, this.frameState_ = {
|
||
animate: !1,
|
||
coordinateToPixelTransform: [1, 0, 0, 1, 0, 0],
|
||
extent: null,
|
||
focus: null,
|
||
index: 0,
|
||
layerStates: n,
|
||
layerStatesArray: o,
|
||
pixelRatio: 1,
|
||
pixelToCoordinateTransform: [1, 0, 0, 1, 0, 0],
|
||
postRenderFunctions: [],
|
||
size: [0, 0],
|
||
skippedFeatureUids: {},
|
||
tileQueue: this.tileQueue_,
|
||
time: Date.now(),
|
||
usedTiles: {},
|
||
viewState: {rotation: 0},
|
||
viewHints: [],
|
||
wantedTiles: {}
|
||
}, void 0 !== e.operation && this.setOperation(e.operation, e.lib)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.setOperation = function (t, e) {
|
||
this.worker_ = new Zx.Processor({
|
||
operation: t,
|
||
imageOps: this.operationType_ === $x.IMAGE,
|
||
queue: 1,
|
||
lib: e,
|
||
threads: this.threads_
|
||
}), this.changed()
|
||
}, e.prototype.updateFrameState_ = function (t, e, i) {
|
||
var r = p({}, this.frameState_);
|
||
r.viewState = p({}, r.viewState);
|
||
var o = At(t);
|
||
r.extent = t.slice(), r.focus = o, r.size[0] = Math.round(Ut(t) / e), r.size[1] = Math.round(Nt(t) / e), r.time = Date.now(), r.animate = !1;
|
||
var n = r.viewState;
|
||
return n.center = o, n.projection = i, n.resolution = e, r
|
||
}, e.prototype.allSourcesReady_ = function () {
|
||
for (var t = !0, e = 0, i = this.renderers_.length; e < i; ++e) if (this.renderers_[e].getLayer().getSource().getState() !== hs.READY) {
|
||
t = !1;
|
||
break
|
||
}
|
||
return t
|
||
}, e.prototype.getImage = function (t, e, i, r) {
|
||
if (!this.allSourcesReady_()) return null;
|
||
var o = this.updateFrameState_(t, e, r);
|
||
if (this.requestedFrameState_ = o, this.renderedImageCanvas_) {
|
||
var n = this.renderedImageCanvas_.getResolution(), s = this.renderedImageCanvas_.getExtent();
|
||
e === n && bt(t, s) || (this.renderedImageCanvas_ = null)
|
||
}
|
||
return this.renderedImageCanvas_ && this.getRevision() === this.renderedRevision_ || this.processSources_(), o.tileQueue.loadMoreTiles(16, 16), o.animate && requestAnimationFrame(this.changed.bind(this)), this.renderedImageCanvas_
|
||
}, e.prototype.processSources_ = function () {
|
||
for (var t = this.requestedFrameState_, e = this.renderers_.length, i = new Array(e), r = 0; r < e; ++r) {
|
||
var o = ew(this.renderers_[r], t, t.layerStatesArray[r]);
|
||
if (!o) return;
|
||
i[r] = o
|
||
}
|
||
var n = {};
|
||
this.dispatchEvent(new Qx(Kx, t, n)), this.worker_.process(i, n, this.onWorkerComplete_.bind(this, t))
|
||
}, e.prototype.onWorkerComplete_ = function (t, e, i, r) {
|
||
if (!e && i) {
|
||
var o = t.extent, n = t.viewState.resolution;
|
||
if (n === this.requestedFrameState_.viewState.resolution && bt(o, this.requestedFrameState_.extent)) {
|
||
var s;
|
||
if (this.renderedImageCanvas_) s = this.renderedImageCanvas_.getImage().getContext("2d"); else s = Ao(Math.round(Ut(o) / n), Math.round(Nt(o) / n)), this.renderedImageCanvas_ = new To(o, n, 1, s.canvas);
|
||
s.putImageData(i, 0, 0), this.changed(), this.renderedRevision_ = this.getRevision(), this.dispatchEvent(new Qx(Jx, t, r))
|
||
}
|
||
}
|
||
}, e.prototype.getImageInternal = function () {
|
||
return null
|
||
}, e
|
||
}(Dx),
|
||
ow = ['Map tiles by <a href="https://stamen.com/">Stamen Design</a>, under <a href="https://creativecommons.org/licenses/by/3.0/">CC BY 3.0</a>.', Xx],
|
||
nw = {
|
||
terrain: {extension: "jpg", opaque: !0},
|
||
"terrain-background": {extension: "jpg", opaque: !0},
|
||
"terrain-labels": {extension: "png", opaque: !1},
|
||
"terrain-lines": {extension: "png", opaque: !1},
|
||
"toner-background": {extension: "png", opaque: !0},
|
||
toner: {extension: "png", opaque: !0},
|
||
"toner-hybrid": {extension: "png", opaque: !1},
|
||
"toner-labels": {extension: "png", opaque: !1},
|
||
"toner-lines": {extension: "png", opaque: !1},
|
||
"toner-lite": {extension: "png", opaque: !0},
|
||
watercolor: {extension: "jpg", opaque: !0}
|
||
}, sw = {
|
||
terrain: {minZoom: 4, maxZoom: 18},
|
||
toner: {minZoom: 0, maxZoom: 20},
|
||
watercolor: {minZoom: 1, maxZoom: 16}
|
||
}, aw = function (t) {
|
||
function e(e) {
|
||
var i = e.layer.indexOf("-"), r = -1 == i ? e.layer : e.layer.slice(0, i), o = sw[r], n = nw[e.layer],
|
||
s = void 0 !== e.url ? e.url : "https://stamen-tiles-{a-d}.a.ssl.fastly.net/" + e.layer + "/{z}/{x}/{y}." + n.extension;
|
||
t.call(this, {
|
||
attributions: ow,
|
||
cacheSize: e.cacheSize,
|
||
crossOrigin: "anonymous",
|
||
maxZoom: null != e.maxZoom ? e.maxZoom : o.maxZoom,
|
||
minZoom: null != e.minZoom ? e.minZoom : o.minZoom,
|
||
opaque: n.opaque,
|
||
reprojectionErrorThreshold: e.reprojectionErrorThreshold,
|
||
tileLoadFunction: e.tileLoadFunction,
|
||
url: s,
|
||
wrapX: e.wrapX
|
||
})
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(Lx);
|
||
|
||
function lw(t, e, i) {
|
||
var r = this.getTileGrid();
|
||
if (r || (r = this.getTileGridForProjection(i)), !(r.getResolutions().length <= t[0])) {
|
||
var o = r.getTileCoordExtent(t, this.tmpExtent_), n = gs(r.getTileSize(t[0]), this.tmpSize);
|
||
1 != e && (n = fs(n, e, this.tmpSize));
|
||
var s = {F: "image", FORMAT: "PNG32", TRANSPARENT: !0};
|
||
return p(s, this.params_), this.getRequestUrl_(t, n, o, e, i, s)
|
||
}
|
||
}
|
||
|
||
var hw = function (t) {
|
||
function e(e) {
|
||
var i = e || {};
|
||
t.call(this, {
|
||
attributions: i.attributions,
|
||
cacheSize: i.cacheSize,
|
||
crossOrigin: i.crossOrigin,
|
||
projection: i.projection,
|
||
reprojectionErrorThreshold: i.reprojectionErrorThreshold,
|
||
tileGrid: i.tileGrid,
|
||
tileLoadFunction: i.tileLoadFunction,
|
||
tileUrlFunction: lw,
|
||
url: i.url,
|
||
urls: i.urls,
|
||
wrapX: void 0 === i.wrapX || i.wrapX,
|
||
transition: i.transition
|
||
}), this.params_ = i.params || {}, this.tmpExtent_ = [1 / 0, 1 / 0, -1 / 0, -1 / 0], this.setKey(this.getKeyForParams_())
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getKeyForParams_ = function () {
|
||
var t = 0, e = [];
|
||
for (var i in this.params_) e[t++] = i + "-" + this.params_[i];
|
||
return e.join("/")
|
||
}, e.prototype.getParams = function () {
|
||
return this.params_
|
||
}, e.prototype.getRequestUrl_ = function (t, e, i, r, o, n) {
|
||
var s = this.urls;
|
||
if (s) {
|
||
var a, l = o.getCode().split(":").pop();
|
||
if (n.SIZE = e[0] + "," + e[1], n.BBOX = i.join(","), n.BBOXSR = l, n.IMAGESR = l, n.DPI = Math.round(n.DPI ? n.DPI * r : 90 * r), 1 == s.length) a = s[0]; else a = s[le(ch(t), s.length)];
|
||
return Gx(a.replace(/MapServer\/?$/, "MapServer/export").replace(/ImageServer\/?$/, "ImageServer/exportImage"), n)
|
||
}
|
||
}, e.prototype.getTilePixelRatio = function (t) {
|
||
return t
|
||
}, e.prototype.updateParams = function (t) {
|
||
p(this.params_, t), this.setKey(this.getKeyForParams_())
|
||
}, e
|
||
}(Rx), uw = function (t) {
|
||
function e(e, i, r) {
|
||
t.call(this, e, Ro.LOADED), this.tileSize_ = i, this.text_ = r, this.canvas_ = null
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getImage = function () {
|
||
if (this.canvas_) return this.canvas_;
|
||
var t = this.tileSize_, e = Ao(t[0], t[1]);
|
||
return e.strokeStyle = "black", e.strokeRect(.5, .5, t[0] + .5, t[1] + .5), e.fillStyle = "black", e.textAlign = "center", e.textBaseline = "middle", e.font = "24px sans-serif", e.fillText(this.text_, t[0] / 2, t[1] / 2), this.canvas_ = e.canvas, e.canvas
|
||
}, e.prototype.load = function () {
|
||
}, e
|
||
}(Mo), cw = function (t) {
|
||
function e(e) {
|
||
t.call(this, {
|
||
opaque: !1,
|
||
projection: e.projection,
|
||
tileGrid: e.tileGrid,
|
||
wrapX: void 0 === e.wrapX || e.wrapX
|
||
})
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getTile = function (t, e, i) {
|
||
var r = lh(t, e, i);
|
||
if (this.tileCache.containsKey(r)) return this.tileCache.get(r);
|
||
var o = gs(this.tileGrid.getTileSize(t)), n = [t, e, i], s = this.getTileCoordForTileUrlFunction(n),
|
||
a = s ? this.getTileCoordForTileUrlFunction(s).toString() : "", l = new uw(n, o, a);
|
||
return this.tileCache.set(r, l), l
|
||
}, e
|
||
}(rc), pw = function (t) {
|
||
function e(e) {
|
||
if (t.call(this, {
|
||
attributions: e.attributions,
|
||
cacheSize: e.cacheSize,
|
||
crossOrigin: e.crossOrigin,
|
||
projection: We("EPSG:3857"),
|
||
reprojectionErrorThreshold: e.reprojectionErrorThreshold,
|
||
state: hs.LOADING,
|
||
tileLoadFunction: e.tileLoadFunction,
|
||
wrapX: void 0 === e.wrapX || e.wrapX,
|
||
transition: e.transition
|
||
}), this.tileJSON_ = null, e.url) if (e.jsonp) Cx(e.url, this.handleTileJSONResponse.bind(this), this.handleTileJSONError.bind(this)); else {
|
||
var i = new XMLHttpRequest;
|
||
i.addEventListener("load", this.onXHRLoad_.bind(this)), i.addEventListener("error", this.onXHRError_.bind(this)), i.open("GET", e.url), i.send()
|
||
} else e.tileJSON ? this.handleTileJSONResponse(e.tileJSON) : W(!1, 51)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.onXHRLoad_ = function (t) {
|
||
var e = t.target;
|
||
if (!e.status || e.status >= 200 && e.status < 300) {
|
||
var i;
|
||
try {
|
||
i = JSON.parse(e.responseText)
|
||
} catch (t) {
|
||
return void this.handleTileJSONError()
|
||
}
|
||
this.handleTileJSONResponse(i)
|
||
} else this.handleTileJSONError()
|
||
}, e.prototype.onXHRError_ = function (t) {
|
||
this.handleTileJSONError()
|
||
}, e.prototype.getTileJSON = function () {
|
||
return this.tileJSON_
|
||
}, e.prototype.handleTileJSONResponse = function (t) {
|
||
var e, i = We("EPSG:4326"), r = this.getProjection();
|
||
if (void 0 !== t.bounds) {
|
||
var o = ti(i, r);
|
||
e = Xt(t.bounds, o)
|
||
}
|
||
var n = t.minzoom || 0, s = t.maxzoom || 22, a = Ju({extent: tc(r), maxZoom: s, minZoom: n});
|
||
if (this.tileGrid = a, this.tileUrlFunction = _x(t.tiles, a), void 0 !== t.attribution && !this.getAttributions()) {
|
||
var l = void 0 !== e ? e : i.getExtent();
|
||
this.setAttributions(function (e) {
|
||
return Bt(l, e.extent) ? [t.attribution] : null
|
||
})
|
||
}
|
||
this.tileJSON_ = t, this.setState(hs.READY)
|
||
}, e.prototype.handleTileJSONError = function () {
|
||
this.setState(hs.ERROR)
|
||
}, e
|
||
}(Rx);
|
||
|
||
function dw(t, e, i) {
|
||
var r = this.getTileGrid();
|
||
if (r || (r = this.getTileGridForProjection(i)), !(r.getResolutions().length <= t[0])) {
|
||
1 == e || this.hidpi_ && void 0 !== this.serverType_ || (e = 1);
|
||
var o = r.getResolution(t[0]), n = r.getTileCoordExtent(t, this.tmpExtent_),
|
||
s = gs(r.getTileSize(t[0]), this.tmpSize), a = this.gutter_;
|
||
0 !== a && (s = ps(s, a, this.tmpSize), n = ht(n, o * a, n)), 1 != e && (s = fs(s, e, this.tmpSize));
|
||
var l = {SERVICE: "WMS", VERSION: Vx, REQUEST: "GetMap", FORMAT: "image/png", TRANSPARENT: !0};
|
||
return p(l, this.params_), this.getRequestUrl_(t, s, n, e, i, l)
|
||
}
|
||
}
|
||
|
||
var fw = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = i.params || {}, o = !("TRANSPARENT" in r) || r.TRANSPARENT;
|
||
t.call(this, {
|
||
attributions: i.attributions,
|
||
cacheSize: i.cacheSize,
|
||
crossOrigin: i.crossOrigin,
|
||
opaque: !o,
|
||
projection: i.projection,
|
||
reprojectionErrorThreshold: i.reprojectionErrorThreshold,
|
||
tileClass: i.tileClass,
|
||
tileGrid: i.tileGrid,
|
||
tileLoadFunction: i.tileLoadFunction,
|
||
tileUrlFunction: dw,
|
||
url: i.url,
|
||
urls: i.urls,
|
||
wrapX: void 0 === i.wrapX || i.wrapX,
|
||
transition: i.transition
|
||
}), this.gutter_ = void 0 !== i.gutter ? i.gutter : 0, this.params_ = r, this.v13_ = !0, this.serverType_ = i.serverType, this.hidpi_ = void 0 === i.hidpi || i.hidpi, this.tmpExtent_ = [1 / 0, 1 / 0, -1 / 0, -1 / 0], this.updateV13_(), this.setKey(this.getKeyForParams_())
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getGetFeatureInfoUrl = function (t, e, i, r) {
|
||
var o = We(i), n = this.getProjection(), s = this.getTileGrid();
|
||
s || (s = this.getTileGridForProjection(o));
|
||
var a = s.getTileCoordForCoordAndResolution(t, e);
|
||
if (!(s.getResolutions().length <= a[0])) {
|
||
var l = s.getResolution(a[0]), h = s.getTileCoordExtent(a, this.tmpExtent_),
|
||
u = gs(s.getTileSize(a[0]), this.tmpSize), c = this.gutter_;
|
||
0 !== c && (u = ps(u, c, this.tmpSize), h = ht(h, l * c, h)), n && n !== o && (l = cx(n, o, t, l), h = ri(h, o, n), t = ii(t, o, n));
|
||
var d = {
|
||
SERVICE: "WMS",
|
||
VERSION: Vx,
|
||
REQUEST: "GetFeatureInfo",
|
||
FORMAT: "image/png",
|
||
TRANSPARENT: !0,
|
||
QUERY_LAYERS: this.params_.LAYERS
|
||
};
|
||
p(d, this.params_, r);
|
||
var f = Math.floor((t[0] - h[0]) / l), g = Math.floor((h[3] - t[1]) / l);
|
||
return d[this.v13_ ? "I" : "X"] = f, d[this.v13_ ? "J" : "Y"] = g, this.getRequestUrl_(a, u, h, 1, n || o, d)
|
||
}
|
||
}, e.prototype.getGutter = function () {
|
||
return this.gutter_
|
||
}, e.prototype.getParams = function () {
|
||
return this.params_
|
||
}, e.prototype.getRequestUrl_ = function (t, e, i, r, o, n) {
|
||
var s = this.urls;
|
||
if (s) {
|
||
if (n.WIDTH = e[0], n.HEIGHT = e[1], n[this.v13_ ? "CRS" : "SRS"] = o.getCode(), "STYLES" in this.params_ || (n.STYLES = ""), 1 != r) switch (this.serverType_) {
|
||
case Yx.GEOSERVER:
|
||
var a = 90 * r + .5 | 0;
|
||
"FORMAT_OPTIONS" in n ? n.FORMAT_OPTIONS += ";dpi:" + a : n.FORMAT_OPTIONS = "dpi:" + a;
|
||
break;
|
||
case Yx.MAPSERVER:
|
||
n.MAP_RESOLUTION = 90 * r;
|
||
break;
|
||
case Yx.CARMENTA_SERVER:
|
||
case Yx.QGIS:
|
||
n.DPI = 90 * r;
|
||
break;
|
||
default:
|
||
W(!1, 52)
|
||
}
|
||
var l, h, u = o.getAxisOrientation(), c = i;
|
||
if (this.v13_ && "ne" == u.substr(0, 2)) l = i[0], c[0] = i[1], c[1] = l, l = i[2], c[2] = i[3], c[3] = l;
|
||
if (n.BBOX = c.join(","), 1 == s.length) h = s[0]; else h = s[le(ch(t), s.length)];
|
||
return Gx(h, n)
|
||
}
|
||
}, e.prototype.getTilePixelRatio = function (t) {
|
||
return this.hidpi_ && void 0 !== this.serverType_ ? t : 1
|
||
}, e.prototype.getKeyForParams_ = function () {
|
||
var t = 0, e = [];
|
||
for (var i in this.params_) e[t++] = i + "-" + this.params_[i];
|
||
return e.join("/")
|
||
}, e.prototype.updateParams = function (t) {
|
||
p(this.params_, t), this.updateV13_(), this.setKey(this.getKeyForParams_())
|
||
}, e.prototype.updateV13_ = function () {
|
||
var t = this.params_.VERSION || Vx;
|
||
this.v13_ = kr(t, "1.3") >= 0
|
||
}, e
|
||
}(Rx), gw = function (t) {
|
||
function e(e, i, r, o, n, s) {
|
||
t.call(this, e, i), this.src_ = r, this.extent_ = o, this.preemptive_ = n, this.grid_ = null, this.keys_ = null, this.data_ = null, this.jsonp_ = s
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getImage = function () {
|
||
return null
|
||
}, e.prototype.getData = function (t) {
|
||
if (!this.grid_ || !this.keys_) return null;
|
||
var e = (t[0] - this.extent_[0]) / (this.extent_[2] - this.extent_[0]),
|
||
i = (t[1] - this.extent_[1]) / (this.extent_[3] - this.extent_[1]),
|
||
r = this.grid_[Math.floor((1 - i) * this.grid_.length)];
|
||
if ("string" != typeof r) return null;
|
||
var o = r.charCodeAt(Math.floor(e * r.length));
|
||
o >= 93 && o--, o >= 35 && o--;
|
||
var n = null;
|
||
if ((o -= 32) in this.keys_) {
|
||
var s = this.keys_[o];
|
||
n = this.data_ && s in this.data_ ? this.data_[s] : s
|
||
}
|
||
return n
|
||
}, e.prototype.forDataAtCoordinate = function (t, e, i, r) {
|
||
this.state == Ro.IDLE && !0 === r ? (b(this, F.CHANGE, function (r) {
|
||
e.call(i, this.getData(t))
|
||
}, this), this.loadInternal_()) : !0 === r ? setTimeout(function () {
|
||
e.call(i, this.getData(t))
|
||
}.bind(this), 0) : e.call(i, this.getData(t))
|
||
}, e.prototype.getKey = function () {
|
||
return this.src_
|
||
}, e.prototype.handleError_ = function () {
|
||
this.state = Ro.ERROR, this.changed()
|
||
}, e.prototype.handleLoad_ = function (t) {
|
||
this.grid_ = t.grid, this.keys_ = t.keys, this.data_ = t.data, this.state = Ro.EMPTY, this.changed()
|
||
}, e.prototype.loadInternal_ = function () {
|
||
if (this.state == Ro.IDLE) if (this.state = Ro.LOADING, this.jsonp_) Cx(this.src_, this.handleLoad_.bind(this), this.handleError_.bind(this)); else {
|
||
var t = new XMLHttpRequest;
|
||
t.addEventListener("load", this.onXHRLoad_.bind(this)), t.addEventListener("error", this.onXHRError_.bind(this)), t.open("GET", this.src_), t.send()
|
||
}
|
||
}, e.prototype.onXHRLoad_ = function (t) {
|
||
var e = t.target;
|
||
if (!e.status || e.status >= 200 && e.status < 300) {
|
||
var i;
|
||
try {
|
||
i = JSON.parse(e.responseText)
|
||
} catch (t) {
|
||
return void this.handleError_()
|
||
}
|
||
this.handleLoad_(i)
|
||
} else this.handleError_()
|
||
}, e.prototype.onXHRError_ = function (t) {
|
||
this.handleError_()
|
||
}, e.prototype.load = function () {
|
||
this.preemptive_ && this.loadInternal_()
|
||
}, e
|
||
}(Mo), mw = function (t) {
|
||
function e(e) {
|
||
if (t.call(this, {
|
||
projection: We("EPSG:3857"),
|
||
state: hs.LOADING
|
||
}), this.preemptive_ = void 0 === e.preemptive || e.preemptive, this.tileUrlFunction_ = wx, this.template_ = void 0, this.jsonp_ = e.jsonp || !1, e.url) if (this.jsonp_) Cx(e.url, this.handleTileJSONResponse.bind(this), this.handleTileJSONError.bind(this)); else {
|
||
var i = new XMLHttpRequest;
|
||
i.addEventListener("load", this.onXHRLoad_.bind(this)), i.addEventListener("error", this.onXHRError_.bind(this)), i.open("GET", e.url), i.send()
|
||
} else e.tileJSON ? this.handleTileJSONResponse(e.tileJSON) : W(!1, 51)
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.onXHRLoad_ = function (t) {
|
||
var e = t.target;
|
||
if (!e.status || e.status >= 200 && e.status < 300) {
|
||
var i;
|
||
try {
|
||
i = JSON.parse(e.responseText)
|
||
} catch (t) {
|
||
return void this.handleTileJSONError()
|
||
}
|
||
this.handleTileJSONResponse(i)
|
||
} else this.handleTileJSONError()
|
||
}, e.prototype.onXHRError_ = function (t) {
|
||
this.handleTileJSONError()
|
||
}, e.prototype.getTemplate = function () {
|
||
return this.template_
|
||
}, e.prototype.forDataAtCoordinateAndResolution = function (t, e, i, r) {
|
||
if (this.tileGrid) {
|
||
var o = this.tileGrid.getTileCoordForCoordAndResolution(t, e);
|
||
this.getTile(o[0], o[1], o[2], 1, this.getProjection()).forDataAtCoordinate(t, i, null, r)
|
||
} else !0 === r ? setTimeout(function () {
|
||
i(null)
|
||
}, 0) : i(null)
|
||
}, e.prototype.handleTileJSONError = function () {
|
||
this.setState(hs.ERROR)
|
||
}, e.prototype.handleTileJSONResponse = function (t) {
|
||
var e, i = We("EPSG:4326"), r = this.getProjection();
|
||
if (void 0 !== t.bounds) {
|
||
var o = ti(i, r);
|
||
e = Xt(t.bounds, o)
|
||
}
|
||
var n = t.minzoom || 0, s = t.maxzoom || 22, a = Ju({extent: tc(r), maxZoom: s, minZoom: n});
|
||
this.tileGrid = a, this.template_ = t.template;
|
||
var l = t.grids;
|
||
if (l) {
|
||
if (this.tileUrlFunction_ = _x(l, a), void 0 !== t.attribution) {
|
||
var h = void 0 !== e ? e : i.getExtent();
|
||
this.setAttributions(function (e) {
|
||
return Bt(h, e.extent) ? [t.attribution] : null
|
||
})
|
||
}
|
||
this.setState(hs.READY)
|
||
} else this.setState(hs.ERROR)
|
||
}, e.prototype.getTile = function (t, e, i, r, o) {
|
||
var n = lh(t, e, i);
|
||
if (this.tileCache.containsKey(n)) return this.tileCache.get(n);
|
||
var s = [t, e, i], a = this.getTileCoordForTileUrlFunction(s, o), l = this.tileUrlFunction_(a, r, o),
|
||
h = new gw(s, void 0 !== l ? Ro.IDLE : Ro.EMPTY, void 0 !== l ? l : "", this.tileGrid.getTileCoordExtent(s), this.preemptive_, this.jsonp_);
|
||
return this.tileCache.set(n, h), h
|
||
}, e.prototype.useTile = function (t, e, i) {
|
||
var r = lh(t, e, i);
|
||
this.tileCache.containsKey(r) && this.tileCache.get(r)
|
||
}, e
|
||
}(rc), yw = function (t) {
|
||
function e(e) {
|
||
var i = e.projection || "EPSG:3857", r = e.extent || tc(i), o = e.tileGrid || Ju({
|
||
extent: r,
|
||
maxZoom: e.maxZoom || 22,
|
||
minZoom: e.minZoom,
|
||
tileSize: e.tileSize || 512
|
||
});
|
||
t.call(this, {
|
||
attributions: e.attributions,
|
||
cacheSize: void 0 !== e.cacheSize ? e.cacheSize : 128,
|
||
opaque: !1,
|
||
projection: i,
|
||
state: e.state,
|
||
tileGrid: o,
|
||
tileLoadFunction: e.tileLoadFunction ? e.tileLoadFunction : _h,
|
||
tileUrlFunction: e.tileUrlFunction,
|
||
url: e.url,
|
||
urls: e.urls,
|
||
wrapX: void 0 === e.wrapX || e.wrapX,
|
||
transition: e.transition
|
||
}), this.format_ = e.format ? e.format : null, this.sourceTiles_ = {}, this.overlaps_ = null == e.overlaps || e.overlaps, this.tileClass = e.tileClass ? e.tileClass : wh, this.tileGrids_ = {}
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getOverlaps = function () {
|
||
return this.overlaps_
|
||
}, e.prototype.clear = function () {
|
||
this.tileCache.clear(), this.sourceTiles_ = {}
|
||
}, e.prototype.getTile = function (t, e, i, r, o) {
|
||
var n = lh(t, e, i);
|
||
if (this.tileCache.containsKey(n)) return this.tileCache.get(n);
|
||
var s = [t, e, i], a = this.getTileCoordForTileUrlFunction(s, o),
|
||
l = new vh(s, null !== a ? Ro.IDLE : Ro.EMPTY, this.getRevision(), this.format_, this.tileLoadFunction, a, this.tileUrlFunction, this.tileGrid, this.getTileGridForProjection(o), this.sourceTiles_, r, o, this.tileClass, this.handleTileChange.bind(this), s[0]);
|
||
return this.tileCache.set(n, l), l
|
||
}, e.prototype.getTileGridForProjection = function (t) {
|
||
var e = t.getCode(), i = this.tileGrids_[e];
|
||
if (!i) {
|
||
var r = this.tileGrid;
|
||
i = this.tileGrids_[e] = Qu(t, void 0, r ? r.getTileSize(r.getMinZoom()) : void 0)
|
||
}
|
||
return i
|
||
}, e.prototype.getTilePixelRatio = function (t) {
|
||
return t
|
||
}, e.prototype.getTilePixelSize = function (t, e, i) {
|
||
var r = gs(this.getTileGridForProjection(i).getTileSize(t), this.tmpSize);
|
||
return [Math.round(r[0] * e), Math.round(r[1] * e)]
|
||
}, e
|
||
}(Ex), vw = {KVP: "KVP", REST: "REST"}, _w = function (t) {
|
||
function e(e) {
|
||
t.call(this, {
|
||
extent: e.extent,
|
||
origin: e.origin,
|
||
origins: e.origins,
|
||
resolutions: e.resolutions,
|
||
tileSize: e.tileSize,
|
||
tileSizes: e.tileSizes,
|
||
sizes: e.sizes
|
||
}), this.matrixIds_ = e.matrixIds
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getMatrixId = function (t) {
|
||
return this.matrixIds_[t]
|
||
}, e.prototype.getMatrixIds = function () {
|
||
return this.matrixIds_
|
||
}, e
|
||
}(Xu), xw = _w;
|
||
|
||
function ww(t, e, i) {
|
||
var r = [], o = [], n = [], s = [], a = [], l = void 0 !== i ? i : [], h = t.SupportedCRS,
|
||
u = We(h.replace(/urn:ogc:def:crs:(\w+):(.*:)?(\w+)$/, "$1:$3")) || We(h), c = u.getMetersPerUnit(),
|
||
p = "ne" == u.getAxisOrientation().substr(0, 2);
|
||
return t.TileMatrix.sort(function (t, e) {
|
||
return e.ScaleDenominator - t.ScaleDenominator
|
||
}), t.TileMatrix.forEach(function (e) {
|
||
if (!(l.length > 0) || et(l, function (i) {
|
||
return e.Identifier == i.TileMatrix || -1 === e.Identifier.indexOf(":") && t.Identifier + ":" + e.Identifier === i.TileMatrix
|
||
})) {
|
||
o.push(e.Identifier);
|
||
var i = 28e-5 * e.ScaleDenominator / c, h = e.TileWidth, u = e.TileHeight;
|
||
p ? n.push([e.TopLeftCorner[1], e.TopLeftCorner[0]]) : n.push(e.TopLeftCorner), r.push(i), s.push(h == u ? h : [h, u]), a.push([e.MatrixWidth, -e.MatrixHeight])
|
||
}
|
||
}), new _w({extent: e, origins: n, resolutions: r, matrixIds: o, tileSizes: s, sizes: a})
|
||
}
|
||
|
||
var bw = function (t) {
|
||
function e(e) {
|
||
var i = void 0 !== e.requestEncoding ? e.requestEncoding : vw.KVP, r = e.tileGrid, o = e.urls;
|
||
void 0 === o && void 0 !== e.url && (o = bx(e.url)), t.call(this, {
|
||
attributions: e.attributions,
|
||
cacheSize: e.cacheSize,
|
||
crossOrigin: e.crossOrigin,
|
||
projection: e.projection,
|
||
reprojectionErrorThreshold: e.reprojectionErrorThreshold,
|
||
tileClass: e.tileClass,
|
||
tileGrid: r,
|
||
tileLoadFunction: e.tileLoadFunction,
|
||
tilePixelRatio: e.tilePixelRatio,
|
||
tileUrlFunction: wx,
|
||
urls: o,
|
||
wrapX: void 0 !== e.wrapX && e.wrapX,
|
||
transition: e.transition
|
||
}), this.version_ = void 0 !== e.version ? e.version : "1.0.0", this.format_ = void 0 !== e.format ? e.format : "image/jpeg", this.dimensions_ = void 0 !== e.dimensions ? e.dimensions : {}, this.layer_ = e.layer, this.matrixSet_ = e.matrixSet, this.style_ = e.style, this.requestEncoding_ = i, this.setKey(this.getKeyForDimensions_()), o && o.length > 0 && (this.tileUrlFunction = xx(o.map(Cw.bind(this))))
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.setUrls = function (t) {
|
||
this.urls = t;
|
||
var e = t.join("\n");
|
||
this.setTileUrlFunction(xx(t.map(Cw.bind(this))), e)
|
||
}, e.prototype.getDimensions = function () {
|
||
return this.dimensions_
|
||
}, e.prototype.getFormat = function () {
|
||
return this.format_
|
||
}, e.prototype.getLayer = function () {
|
||
return this.layer_
|
||
}, e.prototype.getMatrixSet = function () {
|
||
return this.matrixSet_
|
||
}, e.prototype.getRequestEncoding = function () {
|
||
return this.requestEncoding_
|
||
}, e.prototype.getStyle = function () {
|
||
return this.style_
|
||
}, e.prototype.getVersion = function () {
|
||
return this.version_
|
||
}, e.prototype.getKeyForDimensions_ = function () {
|
||
var t = 0, e = [];
|
||
for (var i in this.dimensions_) e[t++] = i + "-" + this.dimensions_[i];
|
||
return e.join("/")
|
||
}, e.prototype.updateDimensions = function (t) {
|
||
p(this.dimensions_, t), this.setKey(this.getKeyForDimensions_())
|
||
}, e
|
||
}(Rx);
|
||
|
||
function Cw(t) {
|
||
var e = this.requestEncoding_, i = {layer: this.layer_, style: this.style_, tilematrixset: this.matrixSet_};
|
||
e == vw.KVP && p(i, {
|
||
Service: "WMTS",
|
||
Request: "GetTile",
|
||
Version: this.version_,
|
||
Format: this.format_
|
||
}), t = e == vw.KVP ? Gx(t, i) : t.replace(/\{(\w+?)\}/g, function (t, e) {
|
||
return e.toLowerCase() in i ? i[e.toLowerCase()] : t
|
||
});
|
||
var r = this.tileGrid, o = this.dimensions_;
|
||
return function (i, n, s) {
|
||
if (i) {
|
||
var a = {TileMatrix: r.getMatrixId(i[0]), TileCol: i[1], TileRow: -i[2] - 1};
|
||
p(a, o);
|
||
var l = t;
|
||
return l = e == vw.KVP ? Gx(l, a) : l.replace(/\{(\w+?)\}/g, function (t, e) {
|
||
return a[e]
|
||
})
|
||
}
|
||
}
|
||
}
|
||
|
||
var Sw = {DEFAULT: "default", TRUNCATED: "truncated"}, Ew = function (t) {
|
||
function e(e, i, r, o, n, s, a) {
|
||
t.call(this, i, r, o, n, s, a), this.zoomifyImage_ = null, this.tileSize_ = gs(e.getTileSize(i[0]))
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e.prototype.getImage = function () {
|
||
if (this.zoomifyImage_) return this.zoomifyImage_;
|
||
var e = t.prototype.getImage.call(this);
|
||
if (this.state == Ro.LOADED) {
|
||
var i = this.tileSize_;
|
||
if (e.width == i[0] && e.height == i[1]) return this.zoomifyImage_ = e, e;
|
||
var r = Ao(i[0], i[1]);
|
||
return r.drawImage(e, 0, 0), this.zoomifyImage_ = r.canvas, r.canvas
|
||
}
|
||
return e
|
||
}, e
|
||
}(zo), Tw = function (t) {
|
||
function e(e) {
|
||
var i = e || {}, r = i.size, o = void 0 !== i.tierSizeCalculation ? i.tierSizeCalculation : Sw.DEFAULT,
|
||
n = r[0], s = r[1], a = i.extent || [0, -r[1], r[0], 0], l = [], h = i.tileSize || Vn, u = h;
|
||
switch (o) {
|
||
case Sw.DEFAULT:
|
||
for (; n > u || s > u;) l.push([Math.ceil(n / u), Math.ceil(s / u)]), u += u;
|
||
break;
|
||
case Sw.TRUNCATED:
|
||
for (var c = n, p = s; c > u || p > u;) l.push([Math.ceil(c / u), Math.ceil(p / u)]), c >>= 1, p >>= 1;
|
||
break;
|
||
default:
|
||
W(!1, 53)
|
||
}
|
||
l.push([1, 1]), l.reverse();
|
||
for (var d = [1], f = [0], g = 1, m = l.length; g < m; g++) d.push(1 << g), f.push(l[g - 1][0] * l[g - 1][1] + f[g - 1]);
|
||
d.reverse();
|
||
var y = new Xu({tileSize: h, extent: a, origin: jt(a), resolutions: d}), v = i.url;
|
||
v && -1 == v.indexOf("{TileGroup}") && -1 == v.indexOf("{tileIndex}") && (v += "{TileGroup}/{z}-{x}-{y}.jpg");
|
||
var _ = xx(bx(v).map(function (t) {
|
||
return function (e, i, r) {
|
||
if (e) {
|
||
var o = e[0], n = e[1], s = -e[2] - 1, a = n + s * l[o][0], h = y.getTileSize(o),
|
||
u = Array.isArray(h) ? h[0] : h,
|
||
c = {z: o, x: n, y: s, tileIndex: a, TileGroup: "TileGroup" + ((a + f[o]) / u | 0)};
|
||
return t.replace(/\{(\w+?)\}/g, function (t, e) {
|
||
return c[e]
|
||
})
|
||
}
|
||
}
|
||
})), x = Ew.bind(null, y);
|
||
t.call(this, {
|
||
attributions: i.attributions,
|
||
cacheSize: i.cacheSize,
|
||
crossOrigin: i.crossOrigin,
|
||
projection: i.projection,
|
||
reprojectionErrorThreshold: i.reprojectionErrorThreshold,
|
||
tileClass: x,
|
||
tileGrid: y,
|
||
tileUrlFunction: _,
|
||
transition: i.transition
|
||
})
|
||
}
|
||
|
||
return t && (e.__proto__ = t), e.prototype = Object.create(t && t.prototype), e.prototype.constructor = e, e
|
||
}(Rx);
|
||
var Rw = window.ol = {};
|
||
Rw.AssertionError = h, Rw.Collection = Y, Rw.Collection.CollectionEvent = V, Rw.CollectionEventType = u, Rw.Disposable = R, Rw.Feature = X, Rw.Feature.createStyleFunction = H, Rw.Geolocation = Mr, Rw.Graticule = bo, Rw.Image = Eo, Rw.ImageBase = Co, Rw.ImageCanvas = To, Rw.ImageState = So, Rw.ImageTile = zo, Rw.Kinetic = Bo, Rw.LayerType = Vo, Rw.Map = rh, Rw.MapBrowserEvent = Wo, Rw.MapBrowserEventHandler = Nn, Rw.MapBrowserEventType = Ho, Rw.MapBrowserPointerEvent = Xo, Rw.MapEvent = Yo, Rw.MapEventType = Dn, Rw.MapProperty = Gn, Rw.Object = U, Rw.Object.ObjectEvent = G, Rw.Object.getChangeEventType = z, Rw.ObjectEventType = c, Rw.Observable = D, Rw.Observable.unByKey = N, Rw.Overlay = sh, Rw.OverlayPositioning = oh, Rw.PluggableMap = ms, Rw.Tile = Mo, Rw.TileCache = fh, Rw.TileQueue = Un, Rw.TileRange = pl, Rw.TileRange.createOrUpdate = cl, Rw.TileState = Ro, Rw.VectorImageTile = vh, Rw.VectorImageTile.defaultLoadFunction = _h, Rw.VectorTile = wh, Rw.View = ss, Rw.View.createCenterConstraint = is, Rw.View.createResolutionConstraint = rs, Rw.View.createRotationConstraint = os, Rw.View.isNoopAnimation = ns, Rw.ViewHint = $n, Rw.ViewProperty = Qn, Rw.WebGLMap = pc, Rw.array = {}, Rw.array.binarySearch = q, Rw.array.equals = it, Rw.array.extend = Q, Rw.array.find = et, Rw.array.findIndex = ot, Rw.array.includes = K, Rw.array.isSorted = nt, Rw.array.linearFindNearest = J, Rw.array.numberSafeCompareFunction = Z, Rw.array.remove = tt, Rw.array.reverseSubArray = $, Rw.array.stableSort = rt, Rw.asserts = {}, Rw.asserts.assert = W, Rw.centerconstraint = {}, Rw.centerconstraint.createExtent = Yn, Rw.centerconstraint.none = Wn, Rw.color = {}, Rw.color.asArray = lo, Rw.color.asString = oo, Rw.color.fromString = ao, Rw.color.normalize = ho, Rw.color.toString = uo, Rw.colorlike = {}, Rw.colorlike.asColorLike = Wa, Rw.colorlike.isColorLike = void 0, Rw.control = {}, Rw.control.Attribution = Ps, Rw.control.Attribution.render = Rs, Rw.control.Control = ys, Rw.control.FullScreen = yc, Rw.control.MousePosition = xc, Rw.control.MousePosition.render = _c, Rw.control.OverviewMap = bc, Rw.control.OverviewMap.render = wc, Rw.control.Rotate = Is, Rw.control.Rotate.render = Ls, Rw.control.ScaleLine = Rc, Rw.control.ScaleLine.Units = Sc, Rw.control.ScaleLine.render = Tc, Rw.control.Zoom = Os, Rw.control.ZoomSlider = Ic, Rw.control.ZoomSlider.render = Lc, Rw.control.ZoomToExtent = Oc, Rw.control.util = {}, Rw.control.util.defaults = Ms, Rw.coordinate = {}, Rw.coordinate.add = Fr, Rw.coordinate.closestOnCircle = Nr, Rw.coordinate.closestOnSegment = Dr,Rw.coordinate.createStringXY = function (t) {
|
||
return function (e) {
|
||
return Hr(e, t)
|
||
}
|
||
},Rw.coordinate.degreesToStringHDMS = Gr,Rw.coordinate.distance = Yr,Rw.coordinate.equals = zr,Rw.coordinate.format = jr,Rw.coordinate.rotate = Ur,Rw.coordinate.scale = Br,Rw.coordinate.squaredDistance = Vr,Rw.coordinate.squaredDistanceToSegment = Wr,Rw.coordinate.toStringHDMS = function (t, e) {
|
||
return t ? Gr("NS", t[1], e) + " " + Gr("EW", t[0], e) : ""
|
||
},Rw.coordinate.toStringXY = Hr,Rw.css = {},Rw.css.CLASS_COLLAPSED = Cs,Rw.css.CLASS_CONTROL = bs,Rw.css.CLASS_HIDDEN = vs,Rw.css.CLASS_SELECTABLE = _s,Rw.css.CLASS_UNSELECTABLE = xs,Rw.css.CLASS_UNSUPPORTED = ws,Rw.css.getFontFamilies = Ss,Rw.dom = {},Rw.dom.createCanvasContext2D = Ao,Rw.dom.outerHeight = Fo,Rw.dom.outerWidth = ko,Rw.dom.removeChildren = Go,Rw.dom.removeNode = Do,Rw.dom.replaceNode = No,Rw.easing = {},Rw.easing.easeIn = Po,Rw.easing.easeOut = Lo,Rw.easing.inAndOut = Io,Rw.easing.linear = Oo,Rw.easing.upAndDown = function (t) {
|
||
return t < .5 ? Io(2 * t) : 1 - Io(2 * (t - .5))
|
||
},Rw.events = {},Rw.events.Event = A,Rw.events.Event.preventDefault = function (t) {
|
||
t.preventDefault()
|
||
},Rw.events.Event.stopPropagation = M,Rw.events.EventType = F,Rw.events.KeyCode = fa,Rw.events.Target = k,Rw.events.bindListener = m,Rw.events.condition = {},Rw.events.condition.altKeyOnly = Vs,Rw.events.condition.altShiftKeysOnly = Ys,Rw.events.condition.always = Hs,Rw.events.condition.click = function (t) {
|
||
return t.type == Ho.CLICK
|
||
},Rw.events.condition.doubleClick = function (t) {
|
||
return t.type == Ho.DBLCLICK
|
||
},Rw.events.condition.focus = Ws,Rw.events.condition.mouseActionButton = Xs,Rw.events.condition.mouseOnly = ta,Rw.events.condition.never = qs,Rw.events.condition.noModifierKeys = Js,Rw.events.condition.platformModifierKeyOnly = function (t) {
|
||
var e = t.originalEvent;
|
||
return !e.altKey && (Cr ? e.metaKey : e.ctrlKey) && !e.shiftKey
|
||
},Rw.events.condition.pointerMove = Zs,Rw.events.condition.primaryAction = ea,Rw.events.condition.shiftKeyOnly = $s,Rw.events.condition.singleClick = Ks,Rw.events.condition.targetNotEditable = Qs,Rw.events.findListener = y,Rw.events.getListeners = v,Rw.events.listen = w,Rw.events.listenOnce = b,Rw.events.unlisten = C,Rw.events.unlistenAll = E,Rw.events.unlistenByKey = S,Rw.extent = {},Rw.extent.Corner = st,Rw.extent.Relationship = at,Rw.extent.applyTransform = Xt,Rw.extent.boundingExtent = lt,Rw.extent.buffer = ht,Rw.extent.clone = ut,Rw.extent.closestSquaredDistanceXY = ct,Rw.extent.containsCoordinate = pt,Rw.extent.containsExtent = dt,Rw.extent.containsXY = ft,Rw.extent.coordinateRelationship = gt,Rw.extent.createEmpty = mt,Rw.extent.createOrUpdate = yt,Rw.extent.createOrUpdateEmpty = vt,Rw.extent.createOrUpdateFromCoordinate = _t,Rw.extent.createOrUpdateFromCoordinates = xt,Rw.extent.createOrUpdateFromFlatCoordinates = wt,Rw.extent.createOrUpdateFromRings = function (t, e) {
|
||
return Rt(vt(e), t)
|
||
},Rw.extent.equals = bt,Rw.extent.extend = Ct,Rw.extent.extendCoordinate = St,Rw.extent.extendCoordinates = Et,Rw.extent.extendFlatCoordinates = Tt,Rw.extent.extendRings = Rt,Rw.extent.extendXY = Pt,Rw.extent.forEachCorner = Lt,Rw.extent.getArea = It,Rw.extent.getBottomLeft = Ot,Rw.extent.getBottomRight = Mt,Rw.extent.getCenter = At,Rw.extent.getCorner = kt,Rw.extent.getEnlargedArea = function (t, e) {
|
||
var i = Math.min(t[0], e[0]), r = Math.min(t[1], e[1]);
|
||
return (Math.max(t[2], e[2]) - i) * (Math.max(t[3], e[3]) - r)
|
||
},Rw.extent.getForViewAndSize = Ft,Rw.extent.getHeight = Nt,Rw.extent.getIntersection = Dt,Rw.extent.getIntersectionArea = function (t, e) {
|
||
return It(Dt(t, e))
|
||
},Rw.extent.getMargin = function (t) {
|
||
return Ut(t) + Nt(t)
|
||
},Rw.extent.getSize = Gt,Rw.extent.getTopLeft = jt,Rw.extent.getTopRight = zt,Rw.extent.getWidth = Ut,Rw.extent.intersects = Bt,Rw.extent.intersectsSegment = Ht,Rw.extent.isEmpty = Vt,Rw.extent.returnOrUpdate = Yt,Rw.extent.scaleFromCenter = Wt,Rw.featureloader = {},Rw.featureloader.loadFeaturesXhr = mh,Rw.featureloader.xhr = yh,Rw.format = {},Rw.format.EsriJSON = Xc,Rw.format.Feature = Ac,Rw.format.Feature.transformWithOptions = kc,Rw.format.FormatType = gh,Rw.format.GML = Up,Rw.format.GML2 = Wp,Rw.format.GML3 = jp,Rw.format.GMLBase = wp,Rw.format.GMLBase.GMLNS = vp,Rw.format.GPX = Td,Rw.format.GeoJSON = Od,Rw.format.IGC = jd,Rw.format.JSONFeature = Nc,Rw.format.KML = em,Rw.format.KML.getDefaultFillStyle = function () {
|
||
return xf
|
||
},Rw.format.KML.getDefaultImageStyle = function () {
|
||
return bf
|
||
},Rw.format.KML.getDefaultStrokeStyle = function () {
|
||
return Sf
|
||
},Rw.format.KML.getDefaultStyle = function () {
|
||
return Tf
|
||
},Rw.format.KML.getDefaultStyleArray = function () {
|
||
return Rf
|
||
},Rw.format.KML.getDefaultTextStyle = function () {
|
||
return Ef
|
||
},Rw.format.KML.readFlatCoordinates = Of,Rw.format.MVT = cm,Rw.format.OSMXML = vm,Rw.format.OWS = jm,Rw.format.Polyline = Km,Rw.format.Polyline.decodeDeltas = Bm,Rw.format.Polyline.decodeFloats = Ym,Rw.format.Polyline.decodeSignedIntegers = Hm,Rw.format.Polyline.decodeUnsignedIntegers = qm,Rw.format.Polyline.encodeDeltas = Um,Rw.format.Polyline.encodeFloats = Vm,Rw.format.Polyline.encodeSignedIntegers = Wm,Rw.format.Polyline.encodeUnsignedInteger = Zm,Rw.format.Polyline.encodeUnsignedIntegers = Xm,Rw.format.TextFeature = Ad,Rw.format.TopoJSON = ry,Rw.format.WFS = tv,Rw.format.WFS.writeFilter = function (t) {
|
||
var e = Kc(Ny, "Filter");
|
||
return Xy(e, t, []), e
|
||
},Rw.format.WKT = xv,Rw.format.WMSCapabilities = Yv,Rw.format.WMSGetFeatureInfo = Wv,Rw.format.WMTSCapabilities = a_,Rw.format.XLink = {},Rw.format.XLink.readHref = xm,Rw.format.XML = bm,Rw.format.XMLFeature = yp,Rw.format.filter = {},Rw.format.filter.And = ay,Rw.format.filter.Bbox = ly,Rw.format.filter.Comparison = cy,Rw.format.filter.ComparisonBinary = dy,Rw.format.filter.Contains = uy,Rw.format.filter.During = py,Rw.format.filter.EqualTo = fy,Rw.format.filter.Filter = ny,Rw.format.filter.GreaterThan = gy,Rw.format.filter.GreaterThanOrEqualTo = my,Rw.format.filter.Intersects = yy,Rw.format.filter.IsBetween = vy,Rw.format.filter.IsLike = _y,Rw.format.filter.IsNull = xy,Rw.format.filter.LessThan = wy,Rw.format.filter.LessThanOrEqualTo = by,Rw.format.filter.LogicalNary = sy,Rw.format.filter.Not = Cy,Rw.format.filter.NotEqualTo = Sy,Rw.format.filter.Or = Ey,Rw.format.filter.Spatial = hy,Rw.format.filter.Within = Ty,Rw.format.filter.and = Ry,Rw.format.filter.bbox = Py,Rw.format.filter.between = function (t, e, i) {
|
||
return new vy(t, e, i)
|
||
},Rw.format.filter.contains = function (t, e, i) {
|
||
return new uy(t, e, i)
|
||
},Rw.format.filter.during = function (t, e, i) {
|
||
return new py(t, e, i)
|
||
},Rw.format.filter.equalTo = function (t, e, i) {
|
||
return new fy(t, e, i)
|
||
},Rw.format.filter.greaterThan = function (t, e) {
|
||
return new gy(t, e)
|
||
},Rw.format.filter.greaterThanOrEqualTo = function (t, e) {
|
||
return new my(t, e)
|
||
},Rw.format.filter.intersects = function (t, e, i) {
|
||
return new yy(t, e, i)
|
||
},Rw.format.filter.isNull = function (t) {
|
||
return new xy(t)
|
||
},Rw.format.filter.lessThan = function (t, e) {
|
||
return new wy(t, e)
|
||
},Rw.format.filter.lessThanOrEqualTo = function (t, e) {
|
||
return new by(t, e)
|
||
},Rw.format.filter.like = function (t, e, i, r, o, n) {
|
||
return new _y(t, e, i, r, o, n)
|
||
},Rw.format.filter.not = function (t) {
|
||
return new Cy(t)
|
||
},Rw.format.filter.notEqualTo = function (t, e, i) {
|
||
return new Sy(t, e, i)
|
||
},Rw.format.filter.or = function (t) {
|
||
var e = [null].concat(Array.prototype.slice.call(arguments));
|
||
return new (Function.prototype.bind.apply(Ey, e))
|
||
},Rw.format.filter.within = function (t, e, i) {
|
||
return new Ty(t, e, i)
|
||
},Rw.format.xsd = {},Rw.format.xsd.readBoolean = bp,Rw.format.xsd.readBooleanString = Cp,Rw.format.xsd.readDateTime = Sp,Rw.format.xsd.readDecimal = Ep,Rw.format.xsd.readDecimalString = Tp,Rw.format.xsd.readNonNegativeInteger = Rp,Rw.format.xsd.readNonNegativeIntegerString = Pp,Rw.format.xsd.readString = Lp,Rw.format.xsd.writeBooleanTextNode = Ip,Rw.format.xsd.writeCDATASection = Op,Rw.format.xsd.writeDateTimeTextNode = Mp,Rw.format.xsd.writeDecimalTextNode = Ap,Rw.format.xsd.writeNonNegativeIntegerTextNode = kp,Rw.format.xsd.writeStringTextNode = Fp,Rw.functions = {},Rw.functions.FALSE = L,Rw.functions.TRUE = P,Rw.functions.VOID = I,Rw.geom = {},Rw.geom.Circle = h_,Rw.geom.Geometry = _i,Rw.geom.GeometryCollection = Pd,Rw.geom.GeometryLayout = qt,Rw.geom.GeometryType = Zt,Rw.geom.LineString = Jr,Rw.geom.LinearRing = Xi,Rw.geom.MultiLineString = Dc,Rw.geom.MultiPoint = Gc,Rw.geom.MultiPolygon = zc,Rw.geom.Point = qi,Rw.geom.Polygon = fr,Rw.geom.Polygon.circular = gr,Rw.geom.Polygon.fromCircle = yr,Rw.geom.Polygon.fromExtent = mr,Rw.geom.Polygon.makeRegular = vr,Rw.geom.SimpleGeometry = bi,Rw.geom.SimpleGeometry.getStrideForLayout = xi,Rw.geom.SimpleGeometry.transformGeom2D = wi,Rw.geom.flat = {},Rw.geom.flat.area = {},Rw.geom.flat.area.linearRing = Ci,Rw.geom.flat.area.linearRings = Si,Rw.geom.flat.area.linearRingss = Ei,Rw.geom.flat.center = {},Rw.geom.flat.center.linearRingss = jc,Rw.geom.flat.closest = {},Rw.geom.flat.closest.arrayMaxSquaredDelta = Pi,Rw.geom.flat.closest.assignClosestArrayPoint = Oi,Rw.geom.flat.closest.assignClosestMultiArrayPoint = Mi,Rw.geom.flat.closest.assignClosestPoint = Ii,Rw.geom.flat.closest.maxSquaredDelta = Ri,Rw.geom.flat.closest.multiArrayMaxSquaredDelta = Li,Rw.geom.flat.contains = {},Rw.geom.flat.contains.linearRingContainsExtent = Zi,Rw.geom.flat.contains.linearRingContainsXY = Ki,Rw.geom.flat.contains.linearRingsContainsXY = Ji,Rw.geom.flat.contains.linearRingssContainsXY = $i,Rw.geom.flat.deflate = {},Rw.geom.flat.deflate.deflateCoordinate = Ai,Rw.geom.flat.deflate.deflateCoordinates = ki,Rw.geom.flat.deflate.deflateCoordinatesArray = Fi,Rw.geom.flat.deflate.deflateMultiCoordinatesArray = Ni,Rw.geom.flat.flip = {},Rw.geom.flat.flip.flipXY = zm,Rw.geom.flat.geodesic = {},Rw.geom.flat.geodesic.greatCircleArc = function (t, e, i, r, o, n) {
|
||
var s = We("EPSG:4326"), a = Math.cos(ae(e)), l = Math.sin(ae(e)), h = Math.cos(ae(r)), u = Math.sin(ae(r)),
|
||
c = Math.cos(ae(i - t)), p = Math.sin(ae(i - t)), d = l * u + a * h * c;
|
||
return $r(function (e) {
|
||
if (1 <= d) return [i, r];
|
||
var o = e * Math.acos(d), n = Math.cos(o), s = Math.sin(o), f = p * h, g = a * u - l * h * c,
|
||
m = Math.atan2(f, g), y = Math.asin(l * n + a * s * Math.cos(m));
|
||
return [se(ae(t) + Math.atan2(Math.sin(m) * s * a, n - l * Math.sin(y))), se(y)]
|
||
}, ei(s, o), n)
|
||
},Rw.geom.flat.geodesic.meridian = Qr,Rw.geom.flat.geodesic.parallel = to,Rw.geom.flat.inflate = {},Rw.geom.flat.inflate.inflateCoordinates = Di,Rw.geom.flat.inflate.inflateCoordinatesArray = Gi,Rw.geom.flat.inflate.inflateMultiCoordinatesArray = ji,Rw.geom.flat.interiorpoint = {},Rw.geom.flat.interiorpoint.getInteriorPointOfArray = Qi,Rw.geom.flat.interiorpoint.getInteriorPointsOfMultiArray = tr,Rw.geom.flat.interpolate = {},Rw.geom.flat.interpolate.interpolatePoint = Xr,Rw.geom.flat.interpolate.lineStringCoordinateAtM = qr,Rw.geom.flat.interpolate.lineStringsCoordinateAtM = Zr,Rw.geom.flat.intersectsextent = {},Rw.geom.flat.intersectsextent.intersectsLineString = ir,Rw.geom.flat.intersectsextent.intersectsLineStringArray = rr,Rw.geom.flat.intersectsextent.intersectsLinearRing = or,Rw.geom.flat.intersectsextent.intersectsLinearRingArray = nr,Rw.geom.flat.intersectsextent.intersectsLinearRingMultiArray = sr,Rw.geom.flat.length = {},Rw.geom.flat.length.lineStringLength = Kr,Rw.geom.flat.length.linearRingLength = function (t, e, i, r) {
|
||
var o = Kr(t, e, i, r), n = t[i - r] - t[e], s = t[i - r + 1] - t[e + 1];
|
||
return o += Math.sqrt(n * n + s * s)
|
||
},Rw.geom.flat.orient = {},Rw.geom.flat.orient.linearRingIsClockwise = lr,Rw.geom.flat.orient.linearRingIsOriented = hr,Rw.geom.flat.orient.linearRingsAreOriented = ur,Rw.geom.flat.orient.orientLinearRings = cr,Rw.geom.flat.orient.orientLinearRingsArray = pr,Rw.geom.flat.reverse = {},Rw.geom.flat.reverse.coordinates = ar,Rw.geom.flat.segments = {},Rw.geom.flat.segments.forEach = er,Rw.geom.flat.simplify = {},Rw.geom.flat.simplify.douglasPeucker = zi,Rw.geom.flat.simplify.douglasPeuckerArray = Ui,Rw.geom.flat.simplify.douglasPeuckerMultiArray = function (t, e, i, r, o, n, s, a) {
|
||
for (var l = 0, h = i.length; l < h; ++l) {
|
||
var u = i[l], c = [];
|
||
s = Ui(t, e, u, r, o, n, s, c), a.push(c), e = u[u.length - 1]
|
||
}
|
||
return s
|
||
},Rw.geom.flat.simplify.quantize = Yi,Rw.geom.flat.simplify.quantizeArray = Wi,Rw.geom.flat.simplify.quantizeMultiArray = Hi,Rw.geom.flat.simplify.radialDistance = Bi,Rw.geom.flat.simplify.simplifyLineString = function (t, e, i, r, o, n, s) {
|
||
var a = void 0 !== s ? s : [];
|
||
return n || (i = Bi(t, e, i, r, o, a, 0), t = a, e = 0, r = 2), a.length = zi(t, e, i, r, o, a, 0), a
|
||
},Rw.geom.flat.simplify.snap = Vi,Rw.geom.flat.straightchunk = {},Rw.geom.flat.straightchunk.matchingChunk = Fl,Rw.geom.flat.textpath = {},Rw.geom.flat.textpath.drawTextOnPath = xl,Rw.geom.flat.topology = {},Rw.geom.flat.topology.lineStringIsClosed = su,Rw.geom.flat.transform = {},Rw.geom.flat.transform.rotate = Jt,Rw.geom.flat.transform.scale = $t,Rw.geom.flat.transform.transform2D = Kt,Rw.geom.flat.transform.translate = Qt,Rw.has = {},Rw.has.CANVAS_LINE_DASH = Er,Rw.has.DEVICE_PIXEL_RATIO = Sr,Rw.has.FIREFOX = xr,Rw.has.GEOLOCATION = Tr,Rw.has.MAC = Cr,Rw.has.MSPOINTER = Lr,Rw.has.POINTER = Pr,Rw.has.SAFARI = wr,Rw.has.TOUCH = Rr,Rw.has.WEBKIT = br,Rw.interaction = {},Rw.interaction.DoubleClickZoom = Bs,Rw.interaction.DragAndDrop = f_,Rw.interaction.DragBox = ca,Rw.interaction.DragPan = oa,Rw.interaction.DragRotate = na,Rw.interaction.DragRotateAndZoom = g_,Rw.interaction.DragZoom = da,Rw.interaction.Draw = P_,Rw.interaction.Draw.createBox = R_,Rw.interaction.Draw.createRegularPolygon = function (t, e) {
|
||
return function (i, r) {
|
||
var o = i[0], n = i[1], s = Math.sqrt(Vr(o, n)), a = r || yr(new h_(o), t), l = e;
|
||
if (!e) {
|
||
var h = n[0] - o[0], u = n[1] - o[1];
|
||
l = Math.atan(u / h) - (h < 0 ? Math.PI : 0)
|
||
}
|
||
return vr(a, o, s, l), a
|
||
}
|
||
},Rw.interaction.Draw.handleEvent = void 0,Rw.interaction.Extent = k_,Rw.interaction.Interaction = zs,Rw.interaction.Interaction.pan = ks,Rw.interaction.Interaction.rotate = Fs,Rw.interaction.Interaction.rotateWithoutConstraints = Ns,Rw.interaction.Interaction.zoom = Ds,Rw.interaction.Interaction.zoomByDelta = Gs,Rw.interaction.Interaction.zoomWithoutConstraints = js,Rw.interaction.KeyboardPan = ma,Rw.interaction.KeyboardZoom = va,Rw.interaction.Modify = B_,Rw.interaction.Modify.ModifyEvent = G_,Rw.interaction.MouseWheelZoom = xa,Rw.interaction.MouseWheelZoom.Mode = _a,Rw.interaction.PinchRotate = wa,Rw.interaction.PinchZoom = ba,Rw.interaction.Pointer = ra,Rw.interaction.Pointer.centroid = ia,Rw.interaction.Pointer.handleEvent = void 0,Rw.interaction.Property = As,Rw.interaction.Select = X_,Rw.interaction.Snap = Z_,Rw.interaction.Snap.handleEvent = void 0,Rw.interaction.Translate = tx,Rw.interaction.Translate.TranslateEvent = Q_,Rw.interaction.defaults = Ca,Rw.layer = {},Rw.layer.Base = ls,Rw.layer.Group = cs,Rw.layer.Heatmap = rx,Rw.layer.Image = nx,Rw.layer.Layer = Ts,Rw.layer.Layer.visibleAtResolution = Es,Rw.layer.Property = as,Rw.layer.Tile = lx,Rw.layer.TileProperty = sx,Rw.layer.Vector = v_,Rw.layer.Vector.RenderType = void 0,Rw.layer.VectorRenderType = Ea,Rw.layer.VectorTile = ux,Rw.layer.VectorTile.RenderType = void 0,Rw.layer.VectorTileRenderType = $l,Rw.loadingstrategy = {},Rw.loadingstrategy.all = __,Rw.loadingstrategy.bbox = function (t, e) {
|
||
return [t]
|
||
},Rw.loadingstrategy.tile = function (t) {
|
||
return function (e, i) {
|
||
var r = t.getZForResolution(i), o = t.getTileRangeForExtentAndZ(e, r), n = [], s = [r, 0, 0];
|
||
for (s[1] = o.minX; s[1] <= o.maxX; ++s[1]) for (s[2] = o.minY; s[2] <= o.maxY; ++s[2]) n.push(t.getTileCoordExtent(s));
|
||
return n
|
||
}
|
||
},Rw.math = {},Rw.math.clamp = te,Rw.math.cosh = ee,Rw.math.lerp = he,Rw.math.modulo = le,Rw.math.roundUpToPowerOfTwo = ie,Rw.math.solveLinearSystem = ne,Rw.math.squaredDistance = oe,Rw.math.squaredSegmentDistance = re,Rw.math.toDegrees = se,Rw.math.toRadians = ae,Rw.net = {},Rw.net.jsonp = Cx,Rw.obj = {},Rw.obj.assign = p,Rw.obj.clear = d,Rw.obj.getValues = f,Rw.obj.isEmpty = g,Rw.pointer = {},Rw.pointer.EventSource = Ko,Rw.pointer.EventType = qo,Rw.pointer.MouseSource = sn,Rw.pointer.MouseSource.POINTER_ID = Jo,Rw.pointer.MouseSource.POINTER_TYPE = $o,Rw.pointer.MsSource = mn,Rw.pointer.NativeSource = En,Rw.pointer.PointerEvent = Pn,Rw.pointer.PointerEventHandler = Fn,Rw.pointer.TouchSource = An,Rw.proj = {},Rw.proj.Projection = xe,Rw.proj.Units = ve,Rw.proj.Units.METERS_PER_UNIT = ye,Rw.proj.addCommon = oi,Rw.proj.addCoordinateTransforms = Je,Rw.proj.addEquivalentProjections = Xe,Rw.proj.addEquivalentTransforms = qe,Rw.proj.addProjection = Ve,Rw.proj.addProjections = Ye,Rw.proj.clearAllProjections = function () {
|
||
ke(), Ge()
|
||
},Rw.proj.cloneTransform = Ue,Rw.proj.createProjection = Ze,Rw.proj.createTransformFromCoordinateTransform = Ke,Rw.proj.epsg3857 = {},Rw.proj.epsg3857.EXTENT = Ce,Rw.proj.epsg3857.HALF_SIZE = be,Rw.proj.epsg3857.PROJECTIONS = Te,Rw.proj.epsg3857.RADIUS = we,Rw.proj.epsg3857.WORLD_EXTENT = Se,Rw.proj.epsg3857.fromEPSG4326 = Re,Rw.proj.epsg3857.toEPSG4326 = Pe,Rw.proj.epsg4326 = {},Rw.proj.epsg4326.EXTENT = Le,Rw.proj.epsg4326.METERS_PER_UNIT = Ie,Rw.proj.epsg4326.PROJECTIONS = Me,Rw.proj.epsg4326.RADIUS = 6378137,Rw.proj.equivalent = Qe,Rw.proj.fromLonLat = $e,Rw.proj.get = We,Rw.proj.getPointResolution = He,Rw.proj.getTransform = ei,Rw.proj.getTransformFromProjections = ti,Rw.proj.identityTransform = Be,Rw.proj.proj4 = {},Rw.proj.proj4.register = function (t) {
|
||
var e, i, r = Object.keys(t.defs), o = r.length;
|
||
for (e = 0; e < o; ++e) {
|
||
var n = r[e];
|
||
if (!We(n)) {
|
||
var s = t.defs(n);
|
||
Ve(new xe({code: n, axisOrientation: s.axis, metersPerUnit: s.to_meter, units: s.units}))
|
||
}
|
||
}
|
||
for (e = 0; e < o; ++e) {
|
||
var a = r[e], l = We(a);
|
||
for (i = 0; i < o; ++i) {
|
||
var h = r[i], u = We(h);
|
||
if (!ze(a, h)) if (t.defs[a] === t.defs[h]) Xe([l, u]); else {
|
||
var c = t(a, h);
|
||
Je(l, u, c.forward, c.inverse)
|
||
}
|
||
}
|
||
}
|
||
},Rw.proj.projections = {},Rw.proj.projections.add = Ne,Rw.proj.projections.clear = ke,Rw.proj.projections.get = Fe,Rw.proj.toLonLat = function (t, e) {
|
||
var i = ii(t, void 0 !== e ? e : "EPSG:3857", "EPSG:4326"), r = i[0];
|
||
return (r < -180 || r > 180) && (i[0] = le(r + 180, 360) - 180), i
|
||
},Rw.proj.transform = ii,Rw.proj.transformExtent = ri,Rw.proj.transformWithProjections = function (t, e, i) {
|
||
return ti(e, i)(t)
|
||
},Rw.proj.transforms = {},Rw.proj.transforms.add = je,Rw.proj.transforms.clear = Ge,Rw.proj.transforms.get = ze,Rw.proj.transforms.remove = function (t, e) {
|
||
var i = t.getCode(), r = e.getCode(), o = De[i][r];
|
||
return delete De[i][r], g(De[i]) && delete De[i], o
|
||
},Rw.render = {},Rw.render.Box = sa,Rw.render.Event = Ta,Rw.render.EventType = eo,Rw.render.Feature = sm,Rw.render.ReplayGroup = vl,Rw.render.ReplayType = _l,Rw.render.VectorContext = Xa,Rw.render.canvas = {},Rw.render.canvas.ImageReplay = Ml,Rw.render.canvas.Immediate = qa,Rw.render.canvas.Instruction = Tl,Rw.render.canvas.Instruction.beginPathInstruction = Sl,Rw.render.canvas.Instruction.closePathInstruction = El,Rw.render.canvas.Instruction.fillInstruction = bl,Rw.render.canvas.Instruction.strokeInstruction = Cl,Rw.render.canvas.LineStringReplay = Al,Rw.render.canvas.PolygonReplay = kl,Rw.render.canvas.Replay = Ol,Rw.render.canvas.ReplayGroup = Vl,Rw.render.canvas.ReplayGroup.getCircleArray = Ul,Rw.render.canvas.ReplayGroup.replayDeclutter = Bl,Rw.render.canvas.TextReplay = Dl,Rw.render.canvas.TextReplay.measureTextWidths = Nl,Rw.render.canvas.checkFont = Na,Rw.render.canvas.checkedFonts = Aa,Rw.render.canvas.defaultFillStyle = Pa,Rw.render.canvas.defaultFont = "10px sans-serif",Rw.render.canvas.defaultLineCap = "round",Rw.render.canvas.defaultLineDash = La,Rw.render.canvas.defaultLineDashOffset = 0,Rw.render.canvas.defaultLineJoin = "round",Rw.render.canvas.defaultLineWidth = 1,Rw.render.canvas.defaultMiterLimit = 10,Rw.render.canvas.defaultPadding = Oa,Rw.render.canvas.defaultStrokeStyle = Ia,Rw.render.canvas.defaultTextAlign = "center",Rw.render.canvas.defaultTextBaseline = "middle",Rw.render.canvas.drawImage = Ya,Rw.render.canvas.labelCache = Ma,Rw.render.canvas.measureTextHeight = za,Rw.render.canvas.measureTextWidth = Ua,Rw.render.canvas.resetTransform = Va,Rw.render.canvas.rotateAtOffset = Ba,Rw.render.canvas.textHeights = Fa,Rw.render.replay = {},Rw.render.replay.ORDER = Rl,Rw.render.replay.TEXT_ALIGN = Pl,Rw.render.toContext = function (t, e) {
|
||
var i = t.canvas, r = e || {}, o = r.pixelRatio || Sr, n = r.size;
|
||
n && (i.width = n[0] * o, i.height = n[1] * o, i.style.width = n[0] + "px", i.style.height = n[1] + "px");
|
||
var s = [0, 0, i.width, i.height], a = di([1, 0, 0, 1, 0, 0], o, o);
|
||
return new qa(t, o, s, a, 0)
|
||
},Rw.render.webgl = {},Rw.render.webgl.CircleReplay = Zh,Rw.render.webgl.DEFAULT_FILLSTYLE = Uh,Rw.render.webgl.DEFAULT_FONT = "10px sans-serif",Rw.render.webgl.DEFAULT_LINECAP = "round",Rw.render.webgl.DEFAULT_LINEDASH = Bh,Rw.render.webgl.DEFAULT_LINEDASHOFFSET = 0,Rw.render.webgl.DEFAULT_LINEJOIN = "round",Rw.render.webgl.DEFAULT_LINEWIDTH = 1,Rw.render.webgl.DEFAULT_MITERLIMIT = 10,Rw.render.webgl.DEFAULT_STROKESTYLE = Vh,Rw.render.webgl.DEFAULT_TEXTALIGN = .5,Rw.render.webgl.DEFAULT_TEXTBASELINE = .5,Rw.render.webgl.EPSILON = Yh,Rw.render.webgl.ImageReplay = nu,Rw.render.webgl.Immediate = Fu,Rw.render.webgl.LineStringReplay = vu,Rw.render.webgl.PolygonReplay = Tu,Rw.render.webgl.Replay = zh,Rw.render.webgl.ReplayGroup = ku,Rw.render.webgl.TextReplay = Ou,Rw.render.webgl.TextureReplay = ou,Rw.render.webgl.circlereplay = {},Rw.render.webgl.circlereplay.defaultshader = {},Rw.render.webgl.circlereplay.defaultshader.Locations = Dh,Rw.render.webgl.circlereplay.defaultshader.fragment = Fh,Rw.render.webgl.circlereplay.defaultshader.vertex = Nh,Rw.render.webgl.linestringreplay = {},Rw.render.webgl.linestringreplay.defaultshader = {},Rw.render.webgl.linestringreplay.defaultshader.Locations = hu,Rw.render.webgl.linestringreplay.defaultshader.fragment = au,Rw.render.webgl.linestringreplay.defaultshader.vertex = lu,Rw.render.webgl.polygonreplay = {},Rw.render.webgl.polygonreplay.defaultshader = {},Rw.render.webgl.polygonreplay.defaultshader.Locations = wu,Rw.render.webgl.polygonreplay.defaultshader.fragment = _u,Rw.render.webgl.polygonreplay.defaultshader.vertex = xu,Rw.render.webgl.texturereplay = {},Rw.render.webgl.texturereplay.defaultshader = {},Rw.render.webgl.texturereplay.defaultshader.Locations = $h,Rw.render.webgl.texturereplay.defaultshader.fragment = Kh,Rw.render.webgl.texturereplay.defaultshader.vertex = Jh,Rw.render.webgl.triangleIsCounterClockwise = Wh,Rw.renderer = {},Rw.renderer.Layer = nl,Rw.renderer.Map = el,Rw.renderer.Map.sortByZIndex = tl,Rw.renderer.canvas = {},Rw.renderer.canvas.ImageLayer = hl,Rw.renderer.canvas.IntermediateCanvas = al,Rw.renderer.canvas.Layer = sl,Rw.renderer.canvas.Map = rl,Rw.renderer.canvas.Map.layerRendererConstructors = il,Rw.renderer.canvas.TileLayer = fl,Rw.renderer.canvas.VectorLayer = Jl,Rw.renderer.canvas.VectorTileLayer = ih,Rw.renderer.vector = {},Rw.renderer.vector.defaultOrder = Hl,Rw.renderer.vector.getSquaredTolerance = Xl,Rw.renderer.vector.getTolerance = ql,Rw.renderer.vector.renderFeature = Zl,Rw.renderer.webgl = {},Rw.renderer.webgl.ImageLayer = Uu,Rw.renderer.webgl.Layer = ju,Rw.renderer.webgl.Map = Bu,Rw.renderer.webgl.TileLayer = lc,Rw.renderer.webgl.VectorLayer = cc,Rw.renderer.webgl.defaultmapshader = {},Rw.renderer.webgl.defaultmapshader.Locations = Gu,Rw.renderer.webgl.defaultmapshader.fragment = Nu,Rw.renderer.webgl.defaultmapshader.vertex = Du,Rw.renderer.webgl.tilelayershader = {},Rw.renderer.webgl.tilelayershader.Locations = sc,Rw.renderer.webgl.tilelayershader.fragment = oc,Rw.renderer.webgl.tilelayershader.vertex = nc,Rw.reproj = {},Rw.reproj.Image = mx,Rw.reproj.Tile = yx,Rw.reproj.Triangulation = gx,Rw.reproj.calculateSourceResolution = cx,Rw.reproj.common = {},Rw.reproj.common.ENABLE_RASTER_REPROJECTION = !0,Rw.reproj.common.ERROR_THRESHOLD = Sa,Rw.reproj.render = dx,Rw.resolutionconstraint = {},Rw.resolutionconstraint.createSnapToPower = Xn,Rw.resolutionconstraint.createSnapToResolutions = Hn,Rw.rotationconstraint = {},Rw.rotationconstraint.createSnapToN = Kn,Rw.rotationconstraint.createSnapToZero = Jn,Rw.rotationconstraint.disable = qn,Rw.rotationconstraint.none = Zn,Rw.size = {},Rw.size.buffer = ps,Rw.size.hasArea = ds,Rw.size.scale = fs,Rw.size.toSize = gs,Rw.source = {},Rw.source.BingMaps = Px,Rw.source.CartoDB = Ix,Rw.source.Cluster = Ox,Rw.source.Image = Dx,Rw.source.Image.defaultImageLoadFunction = Nx,Rw.source.ImageArcGISRest = jx,Rw.source.ImageCanvas = zx,Rw.source.ImageMapGuide = Ux,Rw.source.ImageStatic = Bx,Rw.source.ImageWMS = Hx,Rw.source.OSM = qx,Rw.source.OSM.ATTRIBUTION = Xx,Rw.source.Raster = rw,Rw.source.Source = Yu,Rw.source.Stamen = aw,Rw.source.State = hs,Rw.source.Tile = rc,Rw.source.Tile.TileSourceEvent = ic,Rw.source.TileArcGISRest = hw,Rw.source.TileDebug = cw,Rw.source.TileEventType = Sx,Rw.source.TileImage = Rx,Rw.source.TileJSON = pw,Rw.source.TileWMS = fw,Rw.source.UTFGrid = mw,Rw.source.UTFGrid.CustomTile = gw,Rw.source.UrlTile = Ex,Rw.source.Vector = b_,Rw.source.Vector.VectorSourceEvent = w_,Rw.source.VectorEventType = x_,Rw.source.VectorTile = yw,Rw.source.WMSServerType = Yx,Rw.source.WMTS = bw,Rw.source.WMTS.optionsFromCapabilities = function (t, e) {
|
||
var i = et(t.Contents.Layer, function (t, i, r) {
|
||
return t.Identifier == e.layer
|
||
});
|
||
if (null === i) return null;
|
||
var r, o = t.Contents.TileMatrixSet;
|
||
(r = i.TileMatrixSetLink.length > 1 ? ot(i.TileMatrixSetLink, "projection" in e ? function (t, i, r) {
|
||
var n = et(o, function (e) {
|
||
return e.Identifier == t.TileMatrixSet
|
||
}).SupportedCRS, s = We(n.replace(/urn:ogc:def:crs:(\w+):(.*:)?(\w+)$/, "$1:$3")) || We(n),
|
||
a = We(e.projection);
|
||
return s && a ? Qe(s, a) : n == e.projection
|
||
} : function (t, i, r) {
|
||
return t.TileMatrixSet == e.matrixSet
|
||
}) : 0) < 0 && (r = 0);
|
||
var n = i.TileMatrixSetLink[r].TileMatrixSet, s = i.TileMatrixSetLink[r].TileMatrixSetLimits,
|
||
a = i.Format[0];
|
||
"format" in e && (a = e.format), (r = ot(i.Style, function (t, i, r) {
|
||
return "style" in e ? t.Title == e.style : t.isDefault
|
||
})) < 0 && (r = 0);
|
||
var l = i.Style[r].Identifier, h = {};
|
||
"Dimension" in i && i.Dimension.forEach(function (t, e, i) {
|
||
var r = t.Identifier, o = t.Default;
|
||
void 0 === o && (o = t.Value[0]), h[r] = o
|
||
});
|
||
var u, c = et(t.Contents.TileMatrixSet, function (t, e, i) {
|
||
return t.Identifier == n
|
||
}), p = c.SupportedCRS;
|
||
if (p && (u = We(p.replace(/urn:ogc:def:crs:(\w+):(.*:)?(\w+)$/, "$1:$3")) || We(p)), "projection" in e) {
|
||
var d = We(e.projection);
|
||
d && (u && !Qe(d, u) || (u = d))
|
||
}
|
||
var f, g, m = i.WGS84BoundingBox;
|
||
if (void 0 !== m) {
|
||
var y = We("EPSG:4326").getExtent();
|
||
g = m[0] == y[0] && m[2] == y[2], f = ri(m, "EPSG:4326", u);
|
||
var v = u.getExtent();
|
||
v && (dt(v, f) || (f = void 0))
|
||
}
|
||
var _ = ww(c, f, s), x = [], w = e.requestEncoding;
|
||
if (w = void 0 !== w ? w : "", "OperationsMetadata" in t && "GetTile" in t.OperationsMetadata) for (var b = t.OperationsMetadata.GetTile.DCP.HTTP.Get, C = 0, S = b.length; C < S; ++C) if (b[C].Constraint) {
|
||
var E = et(b[C].Constraint, function (t) {
|
||
return "GetEncoding" == t.name
|
||
}).AllowedValues.Value;
|
||
if ("" === w && (w = E[0]), w !== vw.KVP) break;
|
||
K(E, vw.KVP) && x.push(b[C].href)
|
||
} else b[C].href && (w = vw.KVP, x.push(b[C].href));
|
||
return 0 === x.length && (w = vw.REST, i.ResourceURL.forEach(function (t) {
|
||
"tile" === t.resourceType && (a = t.format, x.push(t.template))
|
||
})), {
|
||
urls: x,
|
||
layer: e.layer,
|
||
matrixSet: n,
|
||
format: a,
|
||
projection: u,
|
||
requestEncoding: w,
|
||
tileGrid: _,
|
||
style: l,
|
||
dimensions: h,
|
||
wrapX: g,
|
||
crossOrigin: e.crossOrigin
|
||
}
|
||
},Rw.source.WMTSRequestEncoding = vw,Rw.source.XYZ = Lx,Rw.source.Zoomify = Tw,Rw.source.Zoomify.CustomTile = Ew,Rw.source.common = {},Rw.source.common.DEFAULT_WMS_VERSION = Vx,Rw.sphere = {},Rw.sphere.DEFAULT_RADIUS = ue,Rw.sphere.getArea = fe,Rw.sphere.getDistance = ce,Rw.sphere.getLength = function t(e, i) {
|
||
var r = i || {}, o = r.radius || ue, n = r.projection || "EPSG:3857", s = e.getType();
|
||
s !== Zt.GEOMETRY_COLLECTION && (e = e.clone().transform(n, "EPSG:4326"));
|
||
var a, l, h, u, c, p, d = 0;
|
||
switch (s) {
|
||
case Zt.POINT:
|
||
case Zt.MULTI_POINT:
|
||
break;
|
||
case Zt.LINE_STRING:
|
||
case Zt.LINEAR_RING:
|
||
d = pe(a = e.getCoordinates(), o);
|
||
break;
|
||
case Zt.MULTI_LINE_STRING:
|
||
case Zt.POLYGON:
|
||
for (h = 0, u = (a = e.getCoordinates()).length; h < u; ++h) d += pe(a[h], o);
|
||
break;
|
||
case Zt.MULTI_POLYGON:
|
||
for (h = 0, u = (a = e.getCoordinates()).length; h < u; ++h) for (c = 0, p = (l = a[h]).length; c < p; ++c) d += pe(l[c], o);
|
||
break;
|
||
case Zt.GEOMETRY_COLLECTION:
|
||
var f = e.getGeometries();
|
||
for (h = 0, u = f.length; h < u; ++h) d += t(f[h], i);
|
||
break;
|
||
default:
|
||
throw new Error("Unsupported geometry type: " + s)
|
||
}
|
||
return d
|
||
},Rw.sphere.offset = ge,Rw.string = {},Rw.string.compareVersions = kr,Rw.string.padNumber = Ar,Rw.structs = {},Rw.structs.LRUCache = Ra,Rw.structs.LinkedList = Cu,Rw.structs.PriorityQueue = zn,Rw.structs.PriorityQueue.DROP = 1 / 0,Rw.structs.RBush = Eu,Rw.style = {},Rw.style.Atlas = Pu,Rw.style.AtlasManager = Iu,Rw.style.Circle = Zd,Rw.style.Fill = po,Rw.style.Icon = Xd,Rw.style.IconAnchorUnits = zd,Rw.style.IconImage = Vd,Rw.style.IconImage.get = Bd,Rw.style.IconImageCache = Ja,Rw.style.IconImageCache.shared = $a,Rw.style.IconOrigin = Yd,Rw.style.Image = Hd,Rw.style.RegularShape = qd,Rw.style.Stroke = go,Rw.style.Style = uf,Rw.style.Style.createDefaultStyle = Qd,Rw.style.Style.createEditingStyle = tf,Rw.style.Style.toFunction = Jd,Rw.style.Text = vo,Rw.style.TextPlacement = mo,Rw.tilecoord = {},Rw.tilecoord.createOrUpdate = ah,Rw.tilecoord.fromKey = uh,Rw.tilecoord.getKey = hh,Rw.tilecoord.getKeyZXY = lh,Rw.tilecoord.hash = ch,Rw.tilecoord.quadKey = ph,Rw.tilecoord.withinExtentAndZ = dh;
|
||
Rw.tilegrid = {}, Rw.tilegrid.TileGrid = Xu, Rw.tilegrid.WMTS = xw, Rw.tilegrid.WMTS.createFromCapabilitiesMatrixSet = ww, Rw.tilegrid.common = {}, Rw.tilegrid.common.DEFAULT_MAX_ZOOM = Bn, Rw.tilegrid.common.DEFAULT_TILE_SIZE = Vn, Rw.tilegrid.createForExtent = Ku, Rw.tilegrid.createForProjection = Qu, Rw.tilegrid.createXYZ = Ju, Rw.tilegrid.extentFromProjection = tc, Rw.tilegrid.getForProjection = qu, Rw.tilegrid.wrapX = Zu, Rw.tilegrid.resolutionsFromExtent = $u, Rw.tileurlfunction = {}, Rw.tileurlfunction.createFromTemplate = vx, Rw.tileurlfunction.createFromTemplates = _x, Rw.tileurlfunction.createFromTileUrlFunctions = xx, Rw.tileurlfunction.expandUrl = bx, Rw.tileurlfunction.nullTileUrlFunction = wx, Rw.transform = {}, Rw.transform.apply = ci, Rw.transform.compose = gi, Rw.transform.create = si, Rw.transform.determinant = yi, Rw.transform.invert = mi, Rw.transform.multiply = li, Rw.transform.reset = ai, Rw.transform.rotate = pi, Rw.transform.scale = di, Rw.transform.set = hi, Rw.transform.setFromArray = ui, Rw.transform.translate = fi, Rw.uri = {}, Rw.uri.appendParams = Gx, Rw.util = {}, Rw.util.VERSION = l, Rw.util.getUid = a, Rw.util.inherits = function (t, e) {
|
||
t.prototype = Object.create(e.prototype), t.prototype.constructor = t
|
||
}, Rw.vec = {}, Rw.vec.mat4 = {}, Rw.vec.mat4.create = Gh, Rw.vec.mat4.fromTransform = jh, Rw.webgl = {}, Rw.webgl.ARRAY_BUFFER = 34962, Rw.webgl.BLEND = 3042, Rw.webgl.Buffer = qh, Rw.webgl.CLAMP_TO_EDGE = 33071, Rw.webgl.COLOR_ATTACHMENT0 = 36064, Rw.webgl.COLOR_BUFFER_BIT = 16384, Rw.webgl.COMPILE_STATUS = 35713, Rw.webgl.CULL_FACE = 2884, Rw.webgl.Context = ru, Rw.webgl.Context.createEmptyTexture = eu, Rw.webgl.Context.createTexture = iu, Rw.webgl.ContextEventType = Qh, Rw.webgl.DEBUG = !0, Rw.webgl.DEPTH_TEST = 2929, Rw.webgl.DYNAMIC_DRAW = 35048, Rw.webgl.ELEMENT_ARRAY_BUFFER = 34963, Rw.webgl.FLOAT = 5126, Rw.webgl.FRAGMENT_SHADER = 35632, Rw.webgl.FRAMEBUFFER = 36160, Rw.webgl.Fragment = Ah, Rw.webgl.LINEAR = bh, Rw.webgl.LINK_STATUS = 35714, Rw.webgl.ONE = 1, Rw.webgl.ONE_MINUS_SRC_ALPHA = 771, Rw.webgl.RGBA = 6408, Rw.webgl.SCISSOR_TEST = 3089, Rw.webgl.SRC_ALPHA = 770, Rw.webgl.STATIC_DRAW = 35044, Rw.webgl.STENCIL_TEST = 2960, Rw.webgl.STREAM_DRAW = 35040, Rw.webgl.Shader = Mh, Rw.webgl.TEXTURE0 = 33984, Rw.webgl.TEXTURE_2D = Eh, Rw.webgl.TEXTURE_MAG_FILTER = 10240, Rw.webgl.TEXTURE_MIN_FILTER = 10241, Rw.webgl.TEXTURE_WRAP_S = Ch, Rw.webgl.TEXTURE_WRAP_T = Sh, Rw.webgl.TRIANGLES = 4, Rw.webgl.TRIANGLE_STRIP = 5, Rw.webgl.UNSIGNED_BYTE = 5121, Rw.webgl.UNSIGNED_INT = 5125, Rw.webgl.UNSIGNED_SHORT = 5123, Rw.webgl.VERTEX_SHADER = 35633, Rw.webgl.Vertex = kh, Rw.webgl.getContext = Rh, Rw.xml = {}, Rw.xml.DOCUMENT = qc, Rw.xml.OBJECT_PROPERTY_NODE_FACTORY = up, Rw.xml.XML_SCHEMA_INSTANCE_URI = Zc, Rw.xml.createElementNS = Kc, Rw.xml.getAllTextContent = Jc, Rw.xml.getAllTextContent_ = $c, Rw.xml.getAttributeNS = tp, Rw.xml.isDocument = Qc, Rw.xml.isNode = void 0, Rw.xml.makeArrayExtender = ip, Rw.xml.makeArrayPusher = rp,Rw.xml.makeArraySerializer = lp,Rw.xml.makeChildAppender = ap,Rw.xml.makeObjectPropertyPusher = np,Rw.xml.makeObjectPropertySetter = sp,Rw.xml.makeReplacer = op,Rw.xml.makeSequence = cp,Rw.xml.makeSimpleNodeFactory = hp,Rw.xml.makeStructureNS = pp,Rw.xml.parse = ep,Rw.xml.parseNode = dp,Rw.xml.pushParseAndPop = fp,Rw.xml.pushSerializeAndPop = mp,Rw.xml.serialize = gp;
|
||
const Pw = {};
|
||
|
||
function Lw(t, e, i) {
|
||
return t.on(e, i)
|
||
}
|
||
|
||
Pw.obj = function (t) {
|
||
return t
|
||
}, Pw.supportsImageRenderingPixelatedResult_ = void 0, Pw.imageRenderingValueResult_ = void 0, Pw.supportsImageRenderingPixelated = function () {
|
||
if (void 0 === Pw.supportsImageRenderingPixelatedResult_) {
|
||
const t = document.createElement("canvas");
|
||
t.setAttribute("style", "image-rendering: -moz-crisp-edges; image-rendering: pixelated;");
|
||
const e = t.style.imageRendering;
|
||
Pw.supportsImageRenderingPixelatedResult_ = !!e, Pw.supportsImageRenderingPixelatedResult_ && (Pw.imageRenderingValueResult_ = e)
|
||
}
|
||
return Pw.supportsImageRenderingPixelatedResult_
|
||
}, Pw.imageRenderingValue = function () {
|
||
return Pw.supportsImageRenderingPixelated(), Pw.imageRenderingValueResult_ || ""
|
||
}, Pw.getSourceProjection = function (t) {
|
||
return t.get("olcs.projection") || t.getProjection()
|
||
};
|
||
let Iw = 0;
|
||
|
||
function Ow(t) {
|
||
return t.olcs_uid || (t.olcs_uid = ++Iw)
|
||
}
|
||
|
||
function Mw(t) {
|
||
const e = Cesium.GroundPolylinePrimitive;
|
||
return e && e.isSupported(t)
|
||
}
|
||
|
||
var Aw = Pw;
|
||
|
||
class kw {
|
||
constructor(t, e, i) {
|
||
this.source_ = e, this.projection_ = null, this.fallbackProj_ = i || null, this.ready_ = !1, this.tilingScheme_ = null, this.rectangle_ = null, this.map_ = t;
|
||
const r = this.source_.get("olcs.proxy");
|
||
r && ("function" == typeof r ? this.proxy_ = {getURL: r} : "string" == typeof r && (this.proxy_ = new Cesium.DefaultProxy(r))), this.errorEvent_ = new Cesium.Event, this.emptyCanvas_ = document.createElement("canvas"), this.emptyCanvas_.width = 1, this.emptyCanvas_.height = 1, this.source_.on("change", t => {
|
||
this.handleSourceChanged_()
|
||
}), this.handleSourceChanged_()
|
||
}
|
||
|
||
handleSourceChanged_(t) {
|
||
if (!this.ready_ && "ready" == this.source_.getState()) {
|
||
if (this.projection_ = Aw.getSourceProjection(this.source_) || this.fallbackProj_, this.projection_ == We("EPSG:4326")) this.tilingScheme_ = new Cesium.GeographicTilingScheme; else {
|
||
if (this.projection_ != We("EPSG:3857")) return;
|
||
this.tilingScheme_ = new Cesium.WebMercatorTilingScheme
|
||
}
|
||
this.rectangle_ = this.tilingScheme_.rectangle, this.ready_ = !0
|
||
}
|
||
}
|
||
|
||
getTileCredits(t, e, i) {
|
||
const r = this.map_.getView().calculateExtent(this.map_.getSize()), o = this.map_.getView().getCenter(),
|
||
n = {
|
||
viewState: {
|
||
zoom: this.tilingScheme_ instanceof Cesium.GeographicTilingScheme ? i + 1 : i,
|
||
center: o
|
||
}, extent: r
|
||
}, s = this.source_.getAttributions();
|
||
if (!s) return [];
|
||
let a = s(n);
|
||
return Array.isArray(a) || (a = [a]), a.map(t => new Cesium.Credit(t, !0))
|
||
}
|
||
|
||
requestImage(t, e, i) {
|
||
const r = this.source_.getTileUrlFunction();
|
||
if (r && this.projection_) {
|
||
const o = this.tilingScheme_ instanceof Cesium.GeographicTilingScheme ? i + 1 : i, n = -e - 1;
|
||
let s = r.call(this.source_, [o, t, n], 1, this.projection_);
|
||
return this.proxy_ && (s = this.proxy_.getURL(s)), s ? Cesium.ImageryProvider.loadImage(this, s) : this.emptyCanvas_
|
||
}
|
||
return this.emptyCanvas_
|
||
}
|
||
}
|
||
|
||
Object.defineProperties(kw.prototype, {
|
||
ready: {
|
||
get: function () {
|
||
return this.ready_
|
||
}
|
||
}, rectangle: {
|
||
get: function () {
|
||
return this.rectangle_
|
||
}
|
||
}, tileWidth: {
|
||
get: function () {
|
||
const t = this.source_.getTileGrid();
|
||
return t ? Array.isArray(t.getTileSize(0)) ? t.getTileSize(0)[0] : t.getTileSize(0) : 256
|
||
}
|
||
}, tileHeight: {
|
||
get: function () {
|
||
const t = this.source_.getTileGrid();
|
||
return t ? Array.isArray(t.getTileSize(0)) ? t.getTileSize(0)[1] : t.getTileSize(0) : 256
|
||
}
|
||
}, maximumLevel: {
|
||
get: function () {
|
||
const t = this.source_.getTileGrid();
|
||
return t ? t.getMaxZoom() : 18
|
||
}
|
||
}, minimumLevel: {
|
||
get: function () {
|
||
return 0
|
||
}
|
||
}, tilingScheme: {
|
||
get: function () {
|
||
return this.tilingScheme_
|
||
}
|
||
}, tileDiscardPolicy: {
|
||
get: function () {
|
||
}
|
||
}, errorEvent: {
|
||
get: function () {
|
||
return this.errorEvent_
|
||
}
|
||
}, proxy: {
|
||
get: function () {
|
||
return this.proxy_
|
||
}
|
||
}, hasAlphaChannel: {
|
||
get: function () {
|
||
return !0
|
||
}
|
||
}, pickFeatures: {
|
||
get: function () {
|
||
}
|
||
}
|
||
});
|
||
var Fw = kw;
|
||
const Nw = {
|
||
computePixelSizeAtCoordinate: function (t, e) {
|
||
const i = t.camera, r = t.canvas, o = i.frustum,
|
||
n = Cesium.Cartesian3.magnitude(Cesium.Cartesian3.subtract(i.position, e, new Cesium.Cartesian3)),
|
||
s = new Cesium.Cartesian2;
|
||
return o.getPixelDimensions(r.clientWidth, r.clientHeight, n, s)
|
||
},
|
||
computeBoundingBoxAtTarget: function (t, e, i) {
|
||
const r = Nw.computePixelSizeAtCoordinate(t, e), o = Cesium.Transforms.eastNorthUpToFixedFrame(e),
|
||
n = Cesium.Matrix4.multiplyByPoint(o, new Cesium.Cartesian3(-r.x * i, -r.y * i, 0), new Cesium.Cartesian3),
|
||
s = Cesium.Matrix4.multiplyByPoint(o, new Cesium.Cartesian3(r.x * i, r.y * i, 0), new Cesium.Cartesian3);
|
||
return Cesium.Ellipsoid.WGS84.cartesianArrayToCartographicArray([n, s])
|
||
},
|
||
applyHeightOffsetToGeometry: function (t, e) {
|
||
t.applyTransform((t, i, r) => {
|
||
if (console.assert(t === i), void 0 !== r && r >= 3) for (let t = 0; t < i.length; t += r) i[t + 2] = i[t + 2] + e;
|
||
return i
|
||
})
|
||
},
|
||
createMatrixAtCoordinates: function (t, e = 0, i = Cesium.Cartesian3.ZERO, r = new Cesium.Cartesian3(1, 1, 1)) {
|
||
const o = Nw.ol4326CoordinateToCesiumCartesian(t), n = Cesium.Transforms.eastNorthUpToFixedFrame(o),
|
||
s = Cesium.Quaternion.fromAxisAngle(Cesium.Cartesian3.UNIT_Z, -e),
|
||
a = Cesium.Matrix4.fromTranslationQuaternionRotationScale(i, s, r);
|
||
return Cesium.Matrix4.multiply(n, a, new Cesium.Matrix4)
|
||
},
|
||
rotateAroundAxis: function (t, e, i, r, o) {
|
||
const n = Cesium.Math.clamp, s = Cesium.defaultValue, a = o || {}, l = s(a.duration, 500),
|
||
h = s(a.easing, Oo), u = a.callback;
|
||
let c = 0;
|
||
const p = new Cesium.Matrix4, d = Date.now(), f = function () {
|
||
const o = Date.now(), s = h(n((o - d) / l, 0, 1));
|
||
console.assert(s >= c), t.transform.clone(p);
|
||
const a = (s - c) * e;
|
||
c = s, t.lookAtTransform(r), t.rotate(i, a), t.lookAtTransform(p), s < 1 ? window.requestAnimationFrame(f) : u && u()
|
||
};
|
||
window.requestAnimationFrame(f)
|
||
},
|
||
setHeadingUsingBottomCenter: function (t, e, i, r) {
|
||
const o = t.camera, n = Nw.computeAngleToZenith(t, i), s = o.right,
|
||
a = Cesium.Quaternion.fromAxisAngle(s, n), l = Cesium.Matrix3.fromQuaternion(a),
|
||
h = new Cesium.Cartesian3;
|
||
Cesium.Cartesian3.subtract(o.position, i, h);
|
||
const u = new Cesium.Cartesian3;
|
||
Cesium.Matrix3.multiplyByVector(l, h, u), Cesium.Cartesian3.add(u, i, u);
|
||
const c = Cesium.Matrix4.fromTranslation(u);
|
||
(0, Nw.rotateAroundAxis)(o, e, u, c, r)
|
||
},
|
||
pickOnTerrainOrEllipsoid: function (t, e) {
|
||
const i = t.camera.getPickRay(e);
|
||
return t.globe.pick(i, t) || t.camera.pickEllipsoid(e)
|
||
},
|
||
pickBottomPoint: function (t) {
|
||
const e = t.canvas, i = new Cesium.Cartesian2(e.clientWidth / 2, e.clientHeight);
|
||
return Nw.pickOnTerrainOrEllipsoid(t, i)
|
||
},
|
||
pickCenterPoint: function (t) {
|
||
const e = t.canvas, i = new Cesium.Cartesian2(e.clientWidth / 2, e.clientHeight / 2);
|
||
return Nw.pickOnTerrainOrEllipsoid(t, i)
|
||
},
|
||
computeSignedTiltAngleOnGlobe: function (t) {
|
||
const e = t.camera, i = new Cesium.Ray(e.position, e.direction);
|
||
let r = t.globe.pick(i, t);
|
||
if (!r) {
|
||
const t = Cesium.Ellipsoid.WGS84, e = Cesium.IntersectionTests.rayEllipsoid(i, t);
|
||
e && (r = Cesium.Ray.getPoint(i, e.start))
|
||
}
|
||
if (!r) return;
|
||
const o = new Cesium.Cartesian3;
|
||
Cesium.Ellipsoid.WGS84.geocentricSurfaceNormal(r, o);
|
||
const n = (0, Nw.signedAngleBetween)(e.direction, o, e.right) - Math.PI;
|
||
return Cesium.Math.convertLongitudeRange(n)
|
||
},
|
||
bottomFovRay: function (t) {
|
||
const e = t.camera, i = e.frustum.fovy / 2, r = e.direction,
|
||
o = Cesium.Quaternion.fromAxisAngle(e.right, i), n = Cesium.Matrix3.fromQuaternion(o),
|
||
s = new Cesium.Cartesian3;
|
||
return Cesium.Matrix3.multiplyByVector(n, r, s), new Cesium.Ray(e.position, s)
|
||
},
|
||
signedAngleBetween: function (t, e, i) {
|
||
const r = new Cesium.Cartesian3, o = new Cesium.Cartesian3, n = new Cesium.Cartesian3;
|
||
Cesium.Cartesian3.normalize(t, r), Cesium.Cartesian3.normalize(e, o), Cesium.Cartesian3.cross(r, o, n);
|
||
const s = Cesium.Cartesian3.dot(r, o), a = Cesium.Cartesian3.magnitude(n),
|
||
l = Cesium.Cartesian3.dot(i, n), h = Math.atan2(a, s);
|
||
return l >= 0 ? h : -h
|
||
},
|
||
computeAngleToZenith: function (t, e) {
|
||
const i = t.camera, r = i.frustum.fovy / 2, o = Nw.bottomFovRay(t),
|
||
n = Cesium.Cartesian3.clone(o.direction);
|
||
Cesium.Cartesian3.negate(n, n);
|
||
const s = new Cesium.Cartesian3;
|
||
Cesium.Ellipsoid.WGS84.geocentricSurfaceNormal(e, s);
|
||
const a = new Cesium.Cartesian3;
|
||
return Cesium.Cartesian3.negate(i.right, a), Nw.signedAngleBetween(s, n, a) + r
|
||
},
|
||
extentToRectangle: function (t, e) {
|
||
if (t && e) {
|
||
const i = ri(t, e, "EPSG:4326");
|
||
return Cesium.Rectangle.fromDegrees(i[0], i[1], i[2], i[3])
|
||
}
|
||
return null
|
||
},
|
||
tileLayerToImageryLayer: function (t, e, i) {
|
||
if (!(e instanceof lx || e instanceof nx)) return null;
|
||
let r = null, o = e.getSource();
|
||
if (o instanceof Hx && o.getUrl() && o.getImageLoadFunction() === Nx) {
|
||
const t = {
|
||
"olcs.proxy": o.get("olcs.proxy"),
|
||
"olcs.extent": o.get("olcs.extent"),
|
||
"olcs.projection": o.get("olcs.projection"),
|
||
"olcs.imagesource": o
|
||
};
|
||
(o = new fw({
|
||
url: o.getUrl(),
|
||
attributions: o.getAttributions(),
|
||
projection: o.getProjection(),
|
||
params: o.getParams()
|
||
})).setProperties(t)
|
||
}
|
||
if (o instanceof Rx) {
|
||
let e = Aw.getSourceProjection(o);
|
||
if (e || (e = i), !Nw.isCesiumProjection(e)) return null;
|
||
r = new Fw(t, o, i)
|
||
} else {
|
||
if (!(o instanceof Bx)) return null;
|
||
{
|
||
let t = Aw.getSourceProjection(o);
|
||
if (t || (t = i), !Nw.isCesiumProjection(t)) return null;
|
||
r = new Cesium.SingleTileImageryProvider({
|
||
url: o.getUrl(),
|
||
rectangle: new Cesium.Rectangle.fromDegrees(o.getImageExtent()[0], o.getImageExtent()[1], o.getImageExtent()[2], o.getImageExtent()[3])
|
||
})
|
||
}
|
||
}
|
||
const n = {}, s = e.get("olcs.extent") || e.getExtent();
|
||
return s && (n.rectangle = Nw.extentToRectangle(s, i)), new Cesium.ImageryLayer(r, n)
|
||
},
|
||
updateCesiumLayerProperties: function (t, e) {
|
||
let i = 1, r = !0;
|
||
[t.layer].concat(t.parents).forEach(t => {
|
||
const e = t.getOpacity();
|
||
void 0 !== e && (i *= e);
|
||
const o = t.getVisible();
|
||
void 0 !== o && (r &= o)
|
||
}), e.alpha = i, e.show = r
|
||
},
|
||
ol4326CoordinateToCesiumCartesian: function (t) {
|
||
const e = t;
|
||
return e.length > 2 ? Cesium.Cartesian3.fromDegrees(e[0], e[1], e[2]) : Cesium.Cartesian3.fromDegrees(e[0], e[1])
|
||
},
|
||
ol4326CoordinateArrayToCsCartesians: function (t) {
|
||
console.assert(null !== t);
|
||
const e = Nw.ol4326CoordinateToCesiumCartesian, i = [];
|
||
for (let r = 0; r < t.length; ++r) i.push(e(t[r]));
|
||
return i
|
||
},
|
||
olGeometryCloneTo4326: function (t, e) {
|
||
console.assert(e);
|
||
const i = We("EPSG:4326"), r = We(e);
|
||
if (r !== i) {
|
||
const e = t.getProperties();
|
||
(t = t.clone()).transform(r, i), t.setProperties(e)
|
||
}
|
||
return t
|
||
},
|
||
convertColorToCesium: function (t) {
|
||
if (t = t || "black", Array.isArray(t)) return new Cesium.Color(Cesium.Color.byteToFloat(t[0]), Cesium.Color.byteToFloat(t[1]), Cesium.Color.byteToFloat(t[2]), t[3]);
|
||
if ("string" == typeof t) return Cesium.Color.fromCssColorString(t);
|
||
if (t instanceof CanvasPattern || t instanceof CanvasGradient) {
|
||
const e = document.createElement("canvas"), i = e.getContext("2d");
|
||
return e.width = e.height = 256, i.fillStyle = t, i.fillRect(0, 0, e.width, e.height), new Cesium.ImageMaterialProperty({image: e})
|
||
}
|
||
console.assert(!1, "impossible")
|
||
},
|
||
convertUrlToCesium: function (t) {
|
||
let e = "";
|
||
const i = /\{(\d|[a-z])-(\d|[a-z])\}/, r = i.exec(t);
|
||
if (r) {
|
||
t = t.replace(i, "{s}");
|
||
const o = r[1].charCodeAt(0), n = r[2].charCodeAt(0);
|
||
let s;
|
||
for (s = o; s <= n; ++s) e += String.fromCharCode(s)
|
||
}
|
||
return {url: t, subdomains: e}
|
||
},
|
||
resetToNorthZenith: function (t, e) {
|
||
return new Promise((i, r) => {
|
||
const o = e.camera, n = Nw.pickBottomPoint(e);
|
||
if (!n) return void r("Could not get bottom pivot");
|
||
const s = t.getView().getRotation();
|
||
if (void 0 === s) return void r("The view is not initialized");
|
||
const a = Nw.computeAngleToZenith(e, n);
|
||
Nw.setHeadingUsingBottomCenter(e, s, n);
|
||
const l = Cesium.Matrix4.fromTranslation(n), h = o.right, u = {
|
||
callback: () => {
|
||
const e = t.getView();
|
||
Nw.normalizeView(e), i()
|
||
}
|
||
};
|
||
Nw.rotateAroundAxis(o, -a, h, l, u)
|
||
})
|
||
},
|
||
rotateAroundBottomCenter: function (t, e) {
|
||
return new Promise((i, r) => {
|
||
const o = t.camera, n = Nw.pickBottomPoint(t);
|
||
if (!n) return void r("could not get bottom pivot");
|
||
const s = {callback: i}, a = Cesium.Matrix4.fromTranslation(n), l = o.right;
|
||
(0, Nw.rotateAroundAxis)(o, -e, l, a, s)
|
||
})
|
||
},
|
||
normalizeView: function (t, e = 0) {
|
||
const i = t.getResolution();
|
||
t.setRotation(e), t.setResolution(t.constrainResolution(i))
|
||
},
|
||
isCesiumProjection: function (t) {
|
||
const e = t === We("EPSG:3857"), i = t === We("EPSG:4326");
|
||
return e || i
|
||
}
|
||
};
|
||
var Dw = Nw;
|
||
var Gw = class {
|
||
constructor(t) {
|
||
this.ol3d = t, this.scene_ = t.getCesiumScene(), this.canvas_ = this.scene_.canvas, this._boundNotifyRepaintRequired = this.notifyRepaintRequired.bind(this), this.repaintEventNames_ = ["mousemove", "mousedown", "mouseup", "touchstart", "touchend", "touchmove", "pointerdown", "pointerup", "pointermove", "wheel"], this.enable()
|
||
}
|
||
|
||
enable() {
|
||
this.scene_.requestRenderMode = !0, this.scene_.maximumRenderTimeChange = 1e3;
|
||
for (const t of this.repaintEventNames_) this.canvas_.addEventListener(t, this._boundNotifyRepaintRequired, !1);
|
||
window.addEventListener("resize", this._boundNotifyRepaintRequired, !1), this.ol3d.getOlMap().getLayerGroup().on("change", this._boundNotifyRepaintRequired)
|
||
}
|
||
|
||
disable() {
|
||
for (const t of this.repaintEventNames_) this.canvas_.removeEventListener(t, this._boundNotifyRepaintRequired, !1);
|
||
window.removeEventListener("resize", this._boundNotifyRepaintRequired, !1), this.ol3d.getOlMap().getLayerGroup().un("change", this._boundNotifyRepaintRequired), this.scene_.requestRenderMode = !1
|
||
}
|
||
|
||
restartRenderLoop() {
|
||
this.notifyRepaintRequired()
|
||
}
|
||
|
||
notifyRepaintRequired() {
|
||
this.scene_.requestRender()
|
||
}
|
||
};
|
||
|
||
function jw(t) {
|
||
return 180 * t / Math.PI
|
||
}
|
||
|
||
function zw(t) {
|
||
return t * Math.PI / 180
|
||
}
|
||
|
||
class Uw {
|
||
constructor(t, e) {
|
||
this.scene_ = t, this.cam_ = t.camera, this.map_ = e, this.view_ = null, this.viewListenKey_ = null, this.toLonLat_ = Uw.identityProjection, this.fromLonLat_ = Uw.identityProjection, this.tilt_ = 0, this.distance_ = 0, this.lastCameraViewMatrix_ = null, this.viewUpdateInProgress_ = !1, this.map_.on("change:view", t => {
|
||
this.setView_(this.map_.getView())
|
||
}), this.setView_(this.map_.getView())
|
||
}
|
||
|
||
static identityProjection(t, e, i) {
|
||
const r = i || t.length;
|
||
if (e) for (let i = 0; i < r; ++i) e[i] = t[i];
|
||
return t
|
||
}
|
||
|
||
setView_(t) {
|
||
if (this.view_ && (N(this.viewListenKey_), this.viewListenKey_ = null), this.view_ = t, t) {
|
||
const e = ei(t.getProjection(), "EPSG:4326"), i = ei("EPSG:4326", t.getProjection());
|
||
console.assert(e && i), this.toLonLat_ = e, this.fromLonLat_ = i, this.viewListenKey_ = t.on("propertychange", t => this.handleViewEvent_(t)), this.readFromView()
|
||
} else this.toLonLat_ = Uw.identityProjection, this.fromLonLat_ = Uw.identityProjection
|
||
}
|
||
|
||
handleViewEvent_(t) {
|
||
this.viewUpdateInProgress_ || this.readFromView()
|
||
}
|
||
|
||
setHeading(t) {
|
||
this.view_ && this.view_.setRotation(t)
|
||
}
|
||
|
||
getHeading() {
|
||
if (!this.view_) return;
|
||
return this.view_.getRotation() || 0
|
||
}
|
||
|
||
setTilt(t) {
|
||
this.tilt_ = t, this.updateCamera_()
|
||
}
|
||
|
||
getTilt() {
|
||
return this.tilt_
|
||
}
|
||
|
||
setDistance(t) {
|
||
this.distance_ = t, this.updateCamera_(), this.updateView()
|
||
}
|
||
|
||
getDistance() {
|
||
return this.distance_
|
||
}
|
||
|
||
setCenter(t) {
|
||
this.view_ && this.view_.setCenter(t)
|
||
}
|
||
|
||
getCenter() {
|
||
if (this.view_) return this.view_.getCenter()
|
||
}
|
||
|
||
setPosition(t) {
|
||
if (!this.toLonLat_) return;
|
||
const e = this.toLonLat_(t);
|
||
console.assert(e);
|
||
const i = new Cesium.Cartographic(zw(e[0]), zw(e[1]), this.getAltitude());
|
||
this.cam_.setView({destination: Cesium.Ellipsoid.WGS84.cartographicToCartesian(i)}), this.updateView()
|
||
}
|
||
|
||
getPosition() {
|
||
if (!this.fromLonLat_) return;
|
||
const t = Cesium.Ellipsoid.WGS84.cartesianToCartographic(this.cam_.position),
|
||
e = this.fromLonLat_([jw(t.longitude), jw(t.latitude)]);
|
||
return console.assert(e), e
|
||
}
|
||
|
||
setAltitude(t) {
|
||
const e = Cesium.Ellipsoid.WGS84.cartesianToCartographic(this.cam_.position);
|
||
e.height = t, this.cam_.position = Cesium.Ellipsoid.WGS84.cartographicToCartesian(e), this.updateView()
|
||
}
|
||
|
||
getAltitude() {
|
||
return Cesium.Ellipsoid.WGS84.cartesianToCartographic(this.cam_.position).height
|
||
}
|
||
|
||
updateCamera_() {
|
||
if (!this.view_ || !this.toLonLat_) return;
|
||
const t = this.view_.getCenter();
|
||
if (!t) return;
|
||
const e = this.toLonLat_(t);
|
||
console.assert(e);
|
||
const i = new Cesium.Cartographic(zw(e[0]), zw(e[1]));
|
||
if (this.scene_.globe) {
|
||
const t = this.scene_.globe.getHeight(i);
|
||
i.height = t || 0
|
||
}
|
||
const r = Cesium.Ellipsoid.WGS84.cartographicToCartesian(i),
|
||
o = {pitch: this.tilt_ - Cesium.Math.PI_OVER_TWO, heading: -this.view_.getRotation(), roll: void 0};
|
||
this.cam_.setView({
|
||
destination: r,
|
||
orientation: o
|
||
}), this.cam_.moveBackward(this.distance_), this.checkCameraChange(!0)
|
||
}
|
||
|
||
readFromView() {
|
||
if (!this.view_ || !this.toLonLat_) return;
|
||
const t = this.view_.getCenter();
|
||
if (null == t) return;
|
||
const e = this.toLonLat_(t);
|
||
console.assert(e);
|
||
const i = this.view_.getResolution();
|
||
this.distance_ = this.calcDistanceForResolution(i || 0, zw(e[1])), this.updateCamera_()
|
||
}
|
||
|
||
updateView() {
|
||
if (!this.view_ || !this.fromLonLat_) return;
|
||
this.viewUpdateInProgress_ = !0;
|
||
const t = Cesium.Ellipsoid.WGS84, e = this.scene_, i = Dw.pickCenterPoint(e);
|
||
let r = i;
|
||
if (!r) {
|
||
const t = e.globe, i = this.cam_.positionCartographic.clone(), o = t.getHeight(i);
|
||
i.height = o || 0, r = Cesium.Ellipsoid.WGS84.cartographicToCartesian(i)
|
||
}
|
||
this.distance_ = Cesium.Cartesian3.distance(r, this.cam_.position);
|
||
const o = t.cartesianToCartographic(r);
|
||
if (this.view_.setCenter(this.fromLonLat_([jw(o.longitude), jw(o.latitude)])), this.view_.setResolution(this.calcResolutionForDistance(this.distance_, o ? o.latitude : 0)), i) {
|
||
const e = this.cam_.position, r = new Cesium.Cartesian3;
|
||
t.geocentricSurfaceNormal(i, r);
|
||
const o = new Cesium.Cartesian3;
|
||
Cesium.Cartesian3.subtract(e, i, o), Cesium.Cartesian3.normalize(o, o);
|
||
const n = this.cam_.up, s = this.cam_.right, a = new Cesium.Cartesian3(-i.y, i.x, 0),
|
||
l = Cesium.Cartesian3.angleBetween(s, a),
|
||
h = Cesium.Cartesian3.cross(i, n, new Cesium.Cartesian3).z;
|
||
this.view_.setRotation(h < 0 ? l : -l);
|
||
const u = Math.acos(Cesium.Cartesian3.dot(r, o));
|
||
this.tilt_ = isNaN(u) ? 0 : u
|
||
} else this.view_.setRotation(this.cam_.heading), this.tilt_ = -this.cam_.pitch + Math.PI / 2;
|
||
this.viewUpdateInProgress_ = !1
|
||
}
|
||
|
||
checkCameraChange(t) {
|
||
const e = this.lastCameraViewMatrix_, i = this.cam_.viewMatrix;
|
||
e && Cesium.Matrix4.equalsEpsilon(e, i, 1e-5) || (this.lastCameraViewMatrix_ = i.clone(), !0 !== t && this.updateView())
|
||
}
|
||
|
||
calcDistanceForResolution(t, e) {
|
||
const i = this.scene_.canvas, r = this.cam_.frustum.fovy;
|
||
console.assert(!isNaN(r));
|
||
const o = this.view_.getProjection().getMetersPerUnit();
|
||
return t * i.clientHeight * o * Math.cos(Math.abs(e)) / 2 / Math.tan(r / 2)
|
||
}
|
||
|
||
calcResolutionForDistance(t, e) {
|
||
const i = this.scene_.canvas, r = this.cam_.frustum.fovy,
|
||
o = this.view_.getProjection().getMetersPerUnit();
|
||
return 2 * t * Math.tan(r / 2) / o / Math.cos(Math.abs(e)) / i.clientHeight
|
||
}
|
||
}
|
||
|
||
var Bw = Uw;
|
||
var Vw = class {
|
||
constructor(t, e) {
|
||
this.map = t, this.view = t.getView(), this.scene = e, this.olLayers = t.getLayerGroup().getLayers(), this.mapLayerGroup = t.getLayerGroup(), this.layerMap = {}, this.olLayerListenKeys = {}, this.olGroupListenKeys_ = {}
|
||
}
|
||
|
||
synchronize() {
|
||
this.destroyAll(), this.addLayers_(this.mapLayerGroup)
|
||
}
|
||
|
||
orderLayers() {
|
||
}
|
||
|
||
addLayers_(t) {
|
||
const e = [{layer: t, parents: []}];
|
||
for (; e.length > 0;) {
|
||
const t = e.splice(0, 1)[0], i = t.layer, r = Ow(i).toString();
|
||
this.olLayerListenKeys[r] = [], console.assert(!this.layerMap[r]);
|
||
let o = null;
|
||
if (i instanceof cs) this.listenForGroupChanges_(i), i !== this.mapLayerGroup && (o = this.createSingleLayerCounterparts(t)), o || i.getLayers().forEach(r => {
|
||
if (r) {
|
||
const o = {layer: r, parents: i === this.mapLayerGroup ? [] : [t.layer].concat(t.parents)};
|
||
e.push(o)
|
||
}
|
||
}); else if (!(o = this.createSingleLayerCounterparts(t))) {
|
||
const e = r, i = t, o = t => {
|
||
const r = this.createSingleLayerCounterparts(i);
|
||
r && (i.layer.un("change", o), this.addCesiumObjects_(r, e, i.layer), this.orderLayers())
|
||
};
|
||
this.olLayerListenKeys[r].push(Lw(i.layer, "change", o))
|
||
}
|
||
o && this.addCesiumObjects_(o, r, i)
|
||
}
|
||
this.orderLayers()
|
||
}
|
||
|
||
addCesiumObjects_(t, e, i) {
|
||
this.layerMap[e] = t, this.olLayerListenKeys[e].push(Lw(i, "change:zIndex", () => this.orderLayers())), t.forEach(t => {
|
||
this.addCesiumObject(t)
|
||
})
|
||
}
|
||
|
||
removeAndDestroySingleLayer_(t) {
|
||
const e = Ow(t).toString(), i = this.layerMap[e];
|
||
return i && (i.forEach(t => {
|
||
this.removeSingleCesiumObject(t, !1), this.destroyCesiumObject(t)
|
||
}), this.olLayerListenKeys[e].forEach(N), delete this.olLayerListenKeys[e]), delete this.layerMap[e], !!i
|
||
}
|
||
|
||
unlistenSingleGroup_(t) {
|
||
if (t === this.mapLayerGroup) return;
|
||
const e = Ow(t).toString();
|
||
this.olGroupListenKeys_[e].forEach(t => {
|
||
N(t)
|
||
}), delete this.olGroupListenKeys_[e], delete this.layerMap[e]
|
||
}
|
||
|
||
removeLayer_(t) {
|
||
if (t) {
|
||
const e = [t];
|
||
for (; e.length > 0;) {
|
||
const t = e.splice(0, 1)[0], i = this.removeAndDestroySingleLayer_(t);
|
||
t instanceof cs && (this.unlistenSingleGroup_(t), i || t.getLayers().forEach(t => {
|
||
e.push(t)
|
||
}))
|
||
}
|
||
}
|
||
}
|
||
|
||
listenForGroupChanges_(t) {
|
||
const e = Ow(t).toString();
|
||
console.assert(void 0 === this.olGroupListenKeys_[e]);
|
||
const i = [];
|
||
this.olGroupListenKeys_[e] = i;
|
||
let r = [];
|
||
const o = function () {
|
||
const e = t.getLayers();
|
||
e && (r = [e.on("add", t => {
|
||
this.addLayers_(t.element)
|
||
}), e.on("remove", t => {
|
||
this.removeLayer_(t.element)
|
||
})], i.push(...r))
|
||
}.bind(this);
|
||
o(), i.push(t.on("change:layers", t => {
|
||
r.forEach(t => {
|
||
const e = i.indexOf(t);
|
||
e >= 0 && i.splice(e, 1), N(t)
|
||
}), o()
|
||
}))
|
||
}
|
||
|
||
destroyAll() {
|
||
let t;
|
||
for (t in this.removeAllCesiumObjects(!0), this.olGroupListenKeys_) this.olGroupListenKeys_[t].forEach(N);
|
||
for (t in this.olLayerListenKeys) this.olLayerListenKeys[t].forEach(N);
|
||
this.olGroupListenKeys_ = {}, this.olLayerListenKeys = {}, this.layerMap = {}
|
||
}
|
||
|
||
addCesiumObject(t) {
|
||
}
|
||
|
||
destroyCesiumObject(t) {
|
||
}
|
||
|
||
removeSingleCesiumObject(t, e) {
|
||
}
|
||
|
||
removeAllCesiumObjects(t) {
|
||
}
|
||
|
||
createSingleLayerCounterparts(t) {
|
||
}
|
||
};
|
||
var Yw = class extends Vw {
|
||
constructor(t, e) {
|
||
super(t, e), this.cesiumLayers_ = e.imageryLayers, this.ourLayers_ = new Cesium.ImageryLayerCollection
|
||
}
|
||
|
||
addCesiumObject(t) {
|
||
this.cesiumLayers_.add(t), this.ourLayers_.add(t)
|
||
}
|
||
|
||
destroyCesiumObject(t) {
|
||
t.destroy()
|
||
}
|
||
|
||
removeSingleCesiumObject(t, e) {
|
||
this.cesiumLayers_.remove(t, e), this.ourLayers_.remove(t, !1)
|
||
}
|
||
|
||
removeAllCesiumObjects(t) {
|
||
for (let e = 0; e < this.ourLayers_.length; ++e) this.cesiumLayers_.remove(this.ourLayers_.get(e), t);
|
||
this.ourLayers_.removeAll(!1)
|
||
}
|
||
|
||
convertLayerToCesiumImageries(t, e) {
|
||
const i = Dw.tileLayerToImageryLayer(this.map, t, e);
|
||
return i ? [i] : null
|
||
}
|
||
|
||
createSingleLayerCounterparts(t) {
|
||
const e = t.layer, i = Ow(e).toString(), r = this.view.getProjection();
|
||
console.assert(r);
|
||
const o = this.convertLayerToCesiumImageries(e, r);
|
||
if (o) {
|
||
const r = [];
|
||
[t.layer].concat(t.parents).forEach(e => {
|
||
r.push(e.on(["change:opacity", "change:visible"], () => {
|
||
console.assert(o);
|
||
for (let e = 0; e < o.length; ++e) Dw.updateCesiumLayerProperties(t, o[e])
|
||
}))
|
||
});
|
||
for (let e = 0; e < o.length; ++e) Dw.updateCesiumLayerProperties(t, o[e]);
|
||
r.push(e.on("change:extent", t => {
|
||
for (let t = 0; t < o.length; ++t) this.cesiumLayers_.remove(o[t], !0), this.ourLayers_.remove(o[t], !1);
|
||
delete this.layerMap[Ow(e)], this.synchronize()
|
||
})), r.push(e.on("change", t => {
|
||
for (let t = 0; t < o.length; ++t) {
|
||
const e = this.cesiumLayers_.indexOf(o[t]);
|
||
e >= 0 && (this.cesiumLayers_.remove(o[t], !1), this.cesiumLayers_.add(o[t], e))
|
||
}
|
||
})), this.olLayerListenKeys[i].push(...r)
|
||
}
|
||
return Array.isArray(o) ? o : null
|
||
}
|
||
|
||
orderLayers() {
|
||
const t = [], e = {}, i = [this.mapLayerGroup];
|
||
for (; i.length > 0;) {
|
||
const r = i.splice(0, 1)[0];
|
||
if (t.push(r), e[Ow(r)] = r.getZIndex(), r instanceof cs) {
|
||
const t = r.getLayers();
|
||
t && i.unshift(...t.getArray())
|
||
}
|
||
}
|
||
!function (t, e) {
|
||
const i = t.length, r = Array(t.length);
|
||
for (let e = 0; e < i; e++) r[e] = {index: e, value: t[e]};
|
||
r.sort((t, i) => e(t.value, i.value) || t.index - i.index);
|
||
for (let e = 0; e < t.length; e++) t[e] = r[e].value
|
||
}(t, (t, i) => e[Ow(t)] - e[Ow(i)]), t.forEach(t => {
|
||
const e = Ow(t).toString(), i = this.layerMap[e];
|
||
i && i.forEach(t => {
|
||
this.raiseToTop(t)
|
||
})
|
||
})
|
||
}
|
||
|
||
raiseToTop(t) {
|
||
this.cesiumLayers_.raiseToTop(t)
|
||
}
|
||
};
|
||
var Ww = class {
|
||
constructor(t, e) {
|
||
const i = new Cesium.BillboardCollection({scene: e}), r = new Cesium.PrimitiveCollection;
|
||
this.olListenKeys = [], this.rootCollection_ = new Cesium.PrimitiveCollection, this.context = {
|
||
projection: t,
|
||
billboards: i,
|
||
featureToCesiumMap: {},
|
||
primitives: r
|
||
}, this.rootCollection_.add(i), this.rootCollection_.add(r)
|
||
}
|
||
|
||
destroy() {
|
||
this.olListenKeys.forEach(N), this.olListenKeys.length = 0
|
||
}
|
||
|
||
getRootPrimitive() {
|
||
return this.rootCollection_
|
||
}
|
||
};
|
||
var Hw = class {
|
||
constructor(t) {
|
||
this.scene = t, this.boundOnRemoveOrClearFeatureListener_ = this.onRemoveOrClearFeature_.bind(this), this.defaultBillboardEyeOffset_ = new Cesium.Cartesian3(0, 0, 10)
|
||
}
|
||
|
||
onRemoveOrClearFeature_(t) {
|
||
const e = t.target;
|
||
console.assert(e instanceof b_);
|
||
const i = Aw.obj(e).olcs_cancellers;
|
||
if (i) {
|
||
const r = t.feature;
|
||
if (r) {
|
||
const t = Ow(r), e = i[t];
|
||
e && (e(), delete i[t])
|
||
} else {
|
||
for (const t in i) i.hasOwnProperty(t) && i[t]();
|
||
Aw.obj(e).olcs_cancellers = {}
|
||
}
|
||
}
|
||
}
|
||
|
||
setReferenceForPicking(t, e, i) {
|
||
i.olLayer = t, i.olFeature = e
|
||
}
|
||
|
||
createColoredPrimitive(t, e, i, r, o, n) {
|
||
const s = {flat: !0, renderState: {depthTest: {enabled: !0}}};
|
||
void 0 !== n && (s.renderState || (s.renderState = {}), s.renderState.lineWidth = n);
|
||
const a = function (t, e) {
|
||
const i = new Cesium.GeometryInstance({geometry: t});
|
||
return !e || e instanceof Cesium.ImageMaterialProperty || (i.attributes = {color: Cesium.ColorGeometryInstanceAttribute.fromColor(e)}), i
|
||
}(r, o);
|
||
let l;
|
||
if (this.getHeightReference(t, e, i) === Cesium.HeightReference.CLAMP_TO_GROUND) {
|
||
const t = a.geometry.constructor;
|
||
if (t && !t.createShadowVolume) return null;
|
||
l = new Cesium.GroundPrimitive({geometryInstances: a})
|
||
} else l = new Cesium.Primitive({geometryInstances: a});
|
||
if (o instanceof Cesium.ImageMaterialProperty) {
|
||
const t = o.image.getValue().toDataURL();
|
||
l.appearance = new Cesium.MaterialAppearance({
|
||
flat: !0,
|
||
renderState: {depthTest: {enabled: !0}},
|
||
material: new Cesium.Material({fabric: {type: "Image", uniforms: {image: t}}})
|
||
})
|
||
} else l.appearance = new Cesium.PerInstanceColorAppearance(s);
|
||
return this.setReferenceForPicking(t, e, l), l
|
||
}
|
||
|
||
extractColorFromOlStyle(t, e) {
|
||
const i = t.getFill() ? t.getFill().getColor() : null,
|
||
r = t.getStroke() ? t.getStroke().getColor() : null;
|
||
let o = "black";
|
||
return r && e ? o = r : i && (o = i), Dw.convertColorToCesium(o)
|
||
}
|
||
|
||
extractLineWidthFromOlStyle(t) {
|
||
const e = t.getStroke() ? t.getStroke().getWidth() : void 0;
|
||
return void 0 !== e ? e : 1
|
||
}
|
||
|
||
wrapFillAndOutlineGeometries(t, e, i, r, o, n) {
|
||
const s = this.extractColorFromOlStyle(n, !1), a = this.extractColorFromOlStyle(n, !0),
|
||
l = new Cesium.PrimitiveCollection;
|
||
if (n.getFill()) {
|
||
const o = this.createColoredPrimitive(t, e, i, r, s);
|
||
console.assert(!!o), l.add(o)
|
||
}
|
||
if (n.getStroke() && o) {
|
||
const r = this.extractLineWidthFromOlStyle(n), s = this.createColoredPrimitive(t, e, i, o, a, r);
|
||
s && l.add(s)
|
||
}
|
||
return l
|
||
}
|
||
|
||
addTextStyle(t, e, i, r, o) {
|
||
let n;
|
||
if (o instanceof Cesium.PrimitiveCollection ? n = o : (n = new Cesium.PrimitiveCollection).add(o), !r.getText()) return n;
|
||
const s = r.getText(), a = this.olGeometry4326TextPartToCesium(t, e, i, s);
|
||
return a && n.add(a), n
|
||
}
|
||
|
||
csAddBillboard(t, e, i, r, o, n) {
|
||
e.eyeOffset || (e.eyeOffset = this.defaultBillboardEyeOffset_);
|
||
const s = t.add(e);
|
||
return this.setReferenceForPicking(i, r, s), s
|
||
}
|
||
|
||
olCircleGeometryToCesium(t, e, i, r, o) {
|
||
i = Dw.olGeometryCloneTo4326(i, r), console.assert("Circle" == i.getType());
|
||
let n = i.getCenter();
|
||
const s = 3 == n.length ? n[2] : 0;
|
||
let a = n.slice();
|
||
a[0] += i.getRadius(), n = Dw.ol4326CoordinateToCesiumCartesian(n), a = Dw.ol4326CoordinateToCesiumCartesian(a);
|
||
const l = Cesium.Cartesian3.distance(n, a),
|
||
h = new Cesium.CircleGeometry({center: n, radius: l, height: s});
|
||
let u, c;
|
||
if (this.getHeightReference(t, e, i) === Cesium.HeightReference.CLAMP_TO_GROUND) {
|
||
const r = this.extractLineWidthFromOlStyle(o);
|
||
if (r) {
|
||
const n = gr(i.getCenter(), l),
|
||
s = Dw.ol4326CoordinateArrayToCsCartesians(n.getLinearRing(0).getCoordinates());
|
||
if (Mw(this.scene)) (u = new Cesium.GroundPolylinePrimitive({
|
||
geometryInstances: new Cesium.GeometryInstance({
|
||
geometry: new Cesium.GroundPolylineGeometry({
|
||
positions: s,
|
||
width: r
|
||
})
|
||
}),
|
||
appearance: new Cesium.PolylineMaterialAppearance({material: this.olStyleToCesium(e, o, !0)}),
|
||
classificationType: Cesium.ClassificationType.TERRAIN
|
||
})).readyPromise.then(() => {
|
||
this.setReferenceForPicking(t, e, u._primitive)
|
||
}); else {
|
||
const i = this.extractColorFromOlStyle(o, !0);
|
||
u = this.createStackedGroundCorridors(t, e, r, i, s)
|
||
}
|
||
}
|
||
} else c = new Cesium.CircleOutlineGeometry({center: n, radius: l, extrudedHeight: s, height: s});
|
||
const p = this.wrapFillAndOutlineGeometries(t, e, i, h, c, o);
|
||
return u && p.add(u), this.addTextStyle(t, e, i, o, p)
|
||
}
|
||
|
||
createStackedGroundCorridors(t, e, i, r, o) {
|
||
Array.isArray(o[0]) || (o = [o]), i = Math.max(3, i);
|
||
const n = [];
|
||
let s = 0;
|
||
for (const t of [1e3, 4e3, 16e3, 64e3, 254e3, 1e6, 1e7]) {
|
||
const e = {width: i *= 2.14, vertexFormat: Cesium.VertexFormat.POSITION_ONLY};
|
||
for (const i of o) e.positions = i, n.push(new Cesium.GeometryInstance({
|
||
geometry: new Cesium.CorridorGeometry(e),
|
||
attributes: {
|
||
color: Cesium.ColorGeometryInstanceAttribute.fromColor(r),
|
||
distanceDisplayCondition: new Cesium.DistanceDisplayConditionGeometryInstanceAttribute(s, t - 1)
|
||
}
|
||
}));
|
||
s = t
|
||
}
|
||
return new Cesium.GroundPrimitive({geometryInstances: n})
|
||
}
|
||
|
||
olLineStringGeometryToCesium(t, e, i, r, o) {
|
||
i = Dw.olGeometryCloneTo4326(i, r), console.assert("LineString" == i.getType());
|
||
const n = Dw.ol4326CoordinateArrayToCsCartesians(i.getCoordinates()),
|
||
s = this.extractLineWidthFromOlStyle(o);
|
||
let a;
|
||
const l = this.getHeightReference(t, e, i);
|
||
if (l !== Cesium.HeightReference.CLAMP_TO_GROUND || Mw(this.scene)) {
|
||
const i = new Cesium.PolylineMaterialAppearance({material: this.olStyleToCesium(e, o, !0)}),
|
||
r = {positions: n, width: s}, h = {appearance: i};
|
||
if (l === Cesium.HeightReference.CLAMP_TO_GROUND) {
|
||
const i = new Cesium.GroundPolylineGeometry(r);
|
||
h.geometryInstances = new Cesium.GeometryInstance({geometry: i}), (a = new Cesium.GroundPolylinePrimitive(h)).readyPromise.then(() => {
|
||
this.setReferenceForPicking(t, e, a._primitive)
|
||
})
|
||
} else {
|
||
r.vertexFormat = i.vertexFormat;
|
||
const t = new Cesium.PolylineGeometry(r);
|
||
h.geometryInstances = new Cesium.GeometryInstance({geometry: t}), a = new Cesium.Primitive(h)
|
||
}
|
||
} else {
|
||
const i = this.extractColorFromOlStyle(o, !0);
|
||
a = this.createStackedGroundCorridors(t, e, s, i, n)
|
||
}
|
||
return this.setReferenceForPicking(t, e, a), this.addTextStyle(t, e, i, o, a)
|
||
}
|
||
|
||
olPolygonGeometryToCesium(t, e, i, r, o) {
|
||
i = Dw.olGeometryCloneTo4326(i, r), console.assert("Polygon" == i.getType());
|
||
const n = this.getHeightReference(t, e, i);
|
||
let s, a, l;
|
||
if (5 == i.getCoordinates()[0].length && "rectangle" === e.getGeometry().get("olcs.polygon_kind")) {
|
||
const t = i.getCoordinates()[0], e = lt(t),
|
||
r = Cesium.Rectangle.fromDegrees(e[0], e[1], e[2], e[3]);
|
||
let o = 0;
|
||
if (3 == t[0].length) for (let e = 0; e < t.length; e++) o = Math.max(o, t[e][2]);
|
||
s = new Cesium.RectangleGeometry({
|
||
ellipsoid: Cesium.Ellipsoid.WGS84,
|
||
rectangle: r,
|
||
height: o
|
||
}), a = new Cesium.RectangleOutlineGeometry({
|
||
ellipsoid: Cesium.Ellipsoid.WGS84,
|
||
rectangle: r,
|
||
height: o
|
||
})
|
||
} else {
|
||
const r = i.getLinearRings(), h = {}, u = h;
|
||
console.assert(r.length > 0);
|
||
for (let t = 0; t < r.length; ++t) {
|
||
const e = r[t].getCoordinates(), i = Dw.ol4326CoordinateArrayToCsCartesians(e);
|
||
console.assert(i && i.length > 0), 0 == t ? h.positions = i : (h.holes || (h.holes = []), h.holes.push({positions: i}))
|
||
}
|
||
if (s = new Cesium.PolygonGeometry({
|
||
polygonHierarchy: u,
|
||
perPositionHeight: !0
|
||
}), n === Cesium.HeightReference.CLAMP_TO_GROUND) {
|
||
const i = this.extractLineWidthFromOlStyle(o);
|
||
if (i > 0) {
|
||
const r = [h.positions];
|
||
if (h.holes) for (let t = 0; t < h.holes.length; ++t) r.push(h.holes[t].positions);
|
||
if (Mw(this.scene)) {
|
||
const n = new Cesium.PolylineMaterialAppearance({material: this.olStyleToCesium(e, o, !0)}),
|
||
s = [];
|
||
for (const t of r) {
|
||
const e = new Cesium.GroundPolylineGeometry({positions: t, width: i});
|
||
s.push(new Cesium.GeometryInstance({geometry: e}))
|
||
}
|
||
const a = {appearance: n, geometryInstances: s};
|
||
(l = new Cesium.GroundPolylinePrimitive(a)).readyPromise.then(() => {
|
||
this.setReferenceForPicking(t, e, l._primitive)
|
||
})
|
||
} else {
|
||
const n = this.extractColorFromOlStyle(o, !0);
|
||
l = this.createStackedGroundCorridors(t, e, i, n, r)
|
||
}
|
||
}
|
||
} else a = new Cesium.PolygonOutlineGeometry({polygonHierarchy: h, perPositionHeight: !0})
|
||
}
|
||
const h = this.wrapFillAndOutlineGeometries(t, e, i, s, a, o);
|
||
return l && h.add(l), this.addTextStyle(t, e, i, o, h)
|
||
}
|
||
|
||
getHeightReference(t, e, i) {
|
||
let r = i.get("altitudeMode");
|
||
void 0 === r && (r = e.get("altitudeMode")), void 0 === r && (r = t.get("altitudeMode"));
|
||
let o = Cesium.HeightReference.NONE;
|
||
return "clampToGround" === r ? o = Cesium.HeightReference.CLAMP_TO_GROUND : "relativeToGround" === r && (o = Cesium.HeightReference.RELATIVE_TO_GROUND), o
|
||
}
|
||
|
||
createBillboardFromImage(t, e, i, r, o, n, s, a) {
|
||
n instanceof Xd && n.load();
|
||
const l = n.getImage(1), h = function () {
|
||
if (!l) return;
|
||
if (!(l instanceof HTMLCanvasElement || l instanceof Image || l instanceof HTMLImageElement)) return;
|
||
const r = i.getCoordinates(), h = Dw.ol4326CoordinateToCesiumCartesian(r);
|
||
let u;
|
||
const c = n.getOpacity();
|
||
void 0 !== c && (u = new Cesium.Color(1, 1, 1, c));
|
||
const p = this.getHeightReference(t, e, i),
|
||
d = {image: l, color: u, scale: n.getScale(), heightReference: p, position: h};
|
||
if (n instanceof Xd) {
|
||
const t = n.getAnchor();
|
||
t && (d.pixelOffset = new Cesium.Cartesian2(l.width / 2 - t[0], l.height / 2 - t[1]))
|
||
}
|
||
const f = this.csAddBillboard(s, d, t, e, i, o);
|
||
a && a(f)
|
||
}.bind(this);
|
||
if (l instanceof Image && !function (t) {
|
||
return "" != t.src && 0 != t.naturalHeight && 0 != t.naturalWidth && t.complete
|
||
}(l)) {
|
||
let i = !1;
|
||
const r = t.getSource(), o = function () {
|
||
i = !0
|
||
};
|
||
r.on(["removefeature", "clear"], this.boundOnRemoveOrClearFeatureListener_);
|
||
let n = Aw.obj(r).olcs_cancellers;
|
||
n || (n = Aw.obj(r).olcs_cancellers = {});
|
||
const a = Ow(e);
|
||
n[a] && n[a](), n[a] = o;
|
||
const u = function () {
|
||
l.removeEventListener("load", u), s.isDestroyed() || i || h()
|
||
};
|
||
l.addEventListener("load", u)
|
||
} else h()
|
||
}
|
||
|
||
olPointGeometryToCesium(t, e, i, r, o, n, s) {
|
||
console.assert("Point" == i.getType()), i = Dw.olGeometryCloneTo4326(i, r);
|
||
let a = null;
|
||
const l = o.getImage();
|
||
if (l) {
|
||
const h = i.get("olcs_model") || e.get("olcs_model");
|
||
if (h) {
|
||
const t = h(), e = Object.assign({}, {scene: this.scene}, t.cesiumOptions),
|
||
i = Cesium.Model.fromGltf(e);
|
||
(a = new Cesium.PrimitiveCollection).add(i), t.debugModelMatrix && a.add(new Cesium.DebugModelMatrixPrimitive({modelMatrix: t.debugModelMatrix}))
|
||
} else this.createBillboardFromImage(t, e, i, r, o, l, n, s)
|
||
}
|
||
return o.getText() ? this.addTextStyle(t, e, i, o, a || new Cesium.Primitive) : a
|
||
}
|
||
|
||
olMultiGeometryToCesium(t, e, i, r, o, n, s) {
|
||
const a = function (i, n) {
|
||
const s = new Cesium.PrimitiveCollection;
|
||
return i.forEach(i => {
|
||
s.add(n(t, e, i, r, o))
|
||
}), s
|
||
};
|
||
let l;
|
||
switch (i.getType()) {
|
||
case"MultiPoint":
|
||
if (l = (i = i).getPoints(), o.getText()) {
|
||
const i = new Cesium.PrimitiveCollection;
|
||
return l.forEach(a => {
|
||
console.assert(a);
|
||
const l = this.olPointGeometryToCesium(t, e, a, r, o, n, s);
|
||
l && i.add(l)
|
||
}), i
|
||
}
|
||
return l.forEach(i => {
|
||
console.assert(i), this.olPointGeometryToCesium(t, e, i, r, o, n, s)
|
||
}), null;
|
||
case"MultiLineString":
|
||
return a(l = (i = i).getLineStrings(), this.olLineStringGeometryToCesium.bind(this));
|
||
case"MultiPolygon":
|
||
return a(l = (i = i).getPolygons(), this.olPolygonGeometryToCesium.bind(this));
|
||
default:
|
||
console.assert(!1, `Unhandled multi geometry type${i.getType()}`)
|
||
}
|
||
}
|
||
|
||
olGeometry4326TextPartToCesium(t, e, i, r) {
|
||
const o = r.getText();
|
||
if (!o) return null;
|
||
const n = new Cesium.LabelCollection({scene: this.scene}), s = At(i.getExtent());
|
||
if (i instanceof bi) {
|
||
const t = i.getFirstCoordinate();
|
||
s[2] = 3 == t.length ? t[2] : 0
|
||
}
|
||
const a = {};
|
||
a.position = Dw.ol4326CoordinateToCesiumCartesian(s), a.text = o, a.heightReference = this.getHeightReference(t, e, i);
|
||
const l = r.getOffsetX(), h = r.getOffsetY();
|
||
if (0 != l && 0 != h) {
|
||
const t = new Cesium.Cartesian2(l, h);
|
||
a.pixelOffset = t
|
||
}
|
||
a.font = r.getFont() || "10px sans-serif";
|
||
let u, c = void 0;
|
||
switch (r.getFill() && (a.fillColor = this.extractColorFromOlStyle(r, !1), c = Cesium.LabelStyle.FILL), r.getStroke() && (a.outlineWidth = this.extractLineWidthFromOlStyle(r), a.outlineColor = this.extractColorFromOlStyle(r, !0), c = Cesium.LabelStyle.OUTLINE), r.getFill() && r.getStroke() && (c = Cesium.LabelStyle.FILL_AND_OUTLINE), a.style = c, r.getTextAlign()) {
|
||
case"left":
|
||
u = Cesium.HorizontalOrigin.LEFT;
|
||
break;
|
||
case"right":
|
||
u = Cesium.HorizontalOrigin.RIGHT;
|
||
break;
|
||
case"center":
|
||
default:
|
||
u = Cesium.HorizontalOrigin.CENTER
|
||
}
|
||
if (a.horizontalOrigin = u, r.getTextBaseline()) {
|
||
let t;
|
||
switch (r.getTextBaseline()) {
|
||
case"top":
|
||
t = Cesium.VerticalOrigin.TOP;
|
||
break;
|
||
case"middle":
|
||
t = Cesium.VerticalOrigin.CENTER;
|
||
break;
|
||
case"bottom":
|
||
t = Cesium.VerticalOrigin.BOTTOM;
|
||
break;
|
||
case"alphabetic":
|
||
t = Cesium.VerticalOrigin.TOP;
|
||
break;
|
||
case"hanging":
|
||
t = Cesium.VerticalOrigin.BOTTOM;
|
||
break;
|
||
default:
|
||
console.assert(!1, `unhandled baseline ${r.getTextBaseline()}`)
|
||
}
|
||
a.verticalOrigin = t
|
||
}
|
||
const p = n.add(a);
|
||
return this.setReferenceForPicking(t, e, p), n
|
||
}
|
||
|
||
olStyleToCesium(t, e, i) {
|
||
const r = e.getFill(), o = e.getStroke();
|
||
if (i && !o || !i && !r) return null;
|
||
let n = i ? o.getColor() : r.getColor();
|
||
return n = Dw.convertColorToCesium(n), i && o.getLineDash() ? Cesium.Material.fromType("Stripe", {
|
||
horizontal: !1,
|
||
repeat: 500,
|
||
evenColor: n,
|
||
oddColor: new Cesium.Color(0, 0, 0, 0)
|
||
}) : Cesium.Material.fromType("Color", {color: n})
|
||
}
|
||
|
||
computePlainStyle(t, e, i, r) {
|
||
const o = e.getStyleFunction();
|
||
let n = null;
|
||
return o && (n = o(e, r)), !n && i && (n = i(e, r)), n ? Array.isArray(n) ? n : [n] : null
|
||
}
|
||
|
||
getGeometryFromFeature(t, e, i) {
|
||
if (i) return i;
|
||
const r = t.get("olcs.3d_geometry");
|
||
if (r && r instanceof _i) return r;
|
||
if (e) {
|
||
const i = e.getGeometryFunction()(t);
|
||
if (i instanceof _i) return i
|
||
}
|
||
return t.getGeometry()
|
||
}
|
||
|
||
olFeatureToCesium(t, e, i, r, o) {
|
||
let n = this.getGeometryFromFeature(e, i, o);
|
||
if (!n) return null;
|
||
const s = r.projection, a = function (t) {
|
||
const i = r.featureToCesiumMap[Ow(e)];
|
||
i instanceof Array ? i.push(t) : r.featureToCesiumMap[Ow(e)] = [t]
|
||
};
|
||
switch (n.getType()) {
|
||
case"GeometryCollection":
|
||
const o = new Cesium.PrimitiveCollection;
|
||
return n.getGeometries().forEach(n => {
|
||
if (n) {
|
||
const s = this.olFeatureToCesium(t, e, i, r, n);
|
||
s && o.add(s)
|
||
}
|
||
}), o;
|
||
case"Point":
|
||
n = n;
|
||
const l = r.billboards, h = this.olPointGeometryToCesium(t, e, n, s, i, l, a);
|
||
return h || null;
|
||
case"Circle":
|
||
return n = n, this.olCircleGeometryToCesium(t, e, n, s, i);
|
||
case"LineString":
|
||
return n = n, this.olLineStringGeometryToCesium(t, e, n, s, i);
|
||
case"Polygon":
|
||
return n = n, this.olPolygonGeometryToCesium(t, e, n, s, i);
|
||
case"MultiPoint":
|
||
case"MultiLineString":
|
||
case"MultiPolygon":
|
||
const u = this.olMultiGeometryToCesium(t, e, n, s, i, r.billboards, a);
|
||
return u || null;
|
||
case"LinearRing":
|
||
throw new Error("LinearRing should only be part of polygon.");
|
||
default:
|
||
throw new Error(`Ol geom type not handled : ${n.getType()}`)
|
||
}
|
||
}
|
||
|
||
olVectorLayerToCesium(t, e, i) {
|
||
const r = e.getProjection(), o = e.getResolution();
|
||
if (void 0 === o || !r) throw console.assert(!1, "View not ready"), new Error("View not ready");
|
||
let n = t.getSource();
|
||
n instanceof Ox && (n = n.getSource()), console.assert(n instanceof b_);
|
||
const s = n.getFeatures(), a = new Ww(r, this.scene), l = a.context;
|
||
for (let e = 0; e < s.length; ++e) {
|
||
const r = s[e];
|
||
if (!r) continue;
|
||
const n = t.getStyleFunction(), h = this.computePlainStyle(t, r, n, o);
|
||
if (!h || !h.length) continue;
|
||
let u = null;
|
||
for (let e = 0; e < h.length; e++) {
|
||
const i = this.olFeatureToCesium(t, r, h[e], l);
|
||
if (i) if (u) {
|
||
if (i) {
|
||
let t, e = 0;
|
||
for (; t = i.get(e);) u.add(t), e++
|
||
}
|
||
} else u = i
|
||
}
|
||
u && (i[Ow(r)] = u, a.getRootPrimitive().add(u))
|
||
}
|
||
return a
|
||
}
|
||
|
||
convert(t, e, i, r) {
|
||
const o = e.getProjection(), n = e.getResolution();
|
||
if (null == n || !o) return null;
|
||
const s = t.getStyleFunction(), a = this.computePlainStyle(t, i, s, n);
|
||
if (!a.length) return null;
|
||
r.projection = o;
|
||
let l = null;
|
||
for (let e = 0; e < a.length; e++) {
|
||
const o = this.olFeatureToCesium(t, i, a[e], r);
|
||
if (l) {
|
||
if (o) {
|
||
let t, e = 0;
|
||
for (; t = o.get(e);) l.add(t), e++
|
||
}
|
||
} else l = o
|
||
}
|
||
return l
|
||
}
|
||
};
|
||
var Xw = class extends Vw {
|
||
constructor(t, e, i) {
|
||
super(t, e), this.converter = i || new Hw(e), this.csAllPrimitives_ = new Cesium.PrimitiveCollection, e.primitives.add(this.csAllPrimitives_), this.csAllPrimitives_.destroyPrimitives = !1
|
||
}
|
||
|
||
addCesiumObject(t) {
|
||
console.assert(t), t.getRootPrimitive().counterpart = t, this.csAllPrimitives_.add(t.getRootPrimitive())
|
||
}
|
||
|
||
destroyCesiumObject(t) {
|
||
t.getRootPrimitive().destroy()
|
||
}
|
||
|
||
removeSingleCesiumObject(t, e) {
|
||
t.destroy(), this.csAllPrimitives_.destroyPrimitives = e, this.csAllPrimitives_.remove(t.getRootPrimitive()), this.csAllPrimitives_.destroyPrimitives = !1
|
||
}
|
||
|
||
removeAllCesiumObjects(t) {
|
||
if (this.csAllPrimitives_.destroyPrimitives = t, t) for (let t = 0; t < this.csAllPrimitives_.length; ++t) this.csAllPrimitives_.get(t).counterpart.destroy();
|
||
this.csAllPrimitives_.removeAll(), this.csAllPrimitives_.destroyPrimitives = !1
|
||
}
|
||
|
||
updateLayerVisibility(t, e) {
|
||
let i = !0;
|
||
[t.layer].concat(t.parents).forEach(t => {
|
||
const e = t.getVisible();
|
||
void 0 !== e ? i &= e : i = !1
|
||
}), e.show = i
|
||
}
|
||
|
||
createSingleLayerCounterparts(t) {
|
||
const e = t.layer;
|
||
if (!(e instanceof v_)) return null;
|
||
console.assert(e instanceof Ts);
|
||
let i = e.getSource();
|
||
if (i instanceof Ox && (i = i.getSource()), !i) return null;
|
||
console.assert(i instanceof b_), console.assert(this.view);
|
||
const r = this.view, o = {}, n = this.converter.olVectorLayerToCesium(e, r, o),
|
||
s = n.getRootPrimitive(), a = n.olListenKeys;
|
||
[t.layer].concat(t.parents).forEach(e => {
|
||
a.push(Lw(e, "change:visible", () => {
|
||
this.updateLayerVisibility(t, s)
|
||
}))
|
||
}), this.updateLayerVisibility(t, s);
|
||
const l = function (t) {
|
||
console.assert(e instanceof v_ || e instanceof nx);
|
||
const i = n.context, a = this.converter.convert(e, r, t, i);
|
||
a && (o[Ow(t)] = a, s.add(a))
|
||
}.bind(this), h = function (t) {
|
||
const e = Ow(t), i = n.context, r = i.featureToCesiumMap[e];
|
||
r && (delete i.featureToCesiumMap[e], r.forEach(t => {
|
||
t instanceof Cesium.Billboard && i.billboards.remove(t)
|
||
}));
|
||
const a = o[e];
|
||
delete o[e], a && s.remove(a)
|
||
}.bind(this);
|
||
return a.push(Lw(i, "addfeature", t => {
|
||
console.assert(t.feature), l(t.feature)
|
||
})), a.push(Lw(i, "removefeature", t => {
|
||
console.assert(t.feature), h(t.feature)
|
||
})), a.push(Lw(i, "changefeature", t => {
|
||
const e = t.feature;
|
||
console.assert(e), h(e), l(e)
|
||
})), n ? [n] : null
|
||
}
|
||
};
|
||
var qw = class extends sh {
|
||
constructor(t) {
|
||
const e = t.parent;
|
||
super(e.getOptions()), this.scenePostRenderListenerRemover_ = null, this.scene_ = t.scene, this.synchronizer_ = t.synchronizer, this.parent_ = e, this.positionWGS84_ = void 0, this.observer_ = new MutationObserver(this.handleElementChanged.bind(this)), this.attributeObserver_ = [], this.listenerKeys_ = [];
|
||
const i = t => this.setPropertyFromEvent_(t);
|
||
this.listenerKeys_.push(this.parent_.on("change:position", i)), this.listenerKeys_.push(this.parent_.on("change:element", i)), this.listenerKeys_.push(this.parent_.on("change:offset", i)), this.listenerKeys_.push(this.parent_.on("change:position", i)), this.listenerKeys_.push(this.parent_.on("change:positioning", i)), this.setProperties(this.parent_.getProperties()), this.handleMapChanged(), this.handleElementChanged()
|
||
}
|
||
|
||
observeTarget_(t) {
|
||
if (this.observer_) {
|
||
this.observer_.disconnect(), this.observer_.observe(t, {
|
||
attributes: !1,
|
||
childList: !0,
|
||
characterData: !0,
|
||
subtree: !0
|
||
}), this.attributeObserver_.forEach(t => {
|
||
t.disconnect()
|
||
}), this.attributeObserver_.length = 0;
|
||
for (let e = 0; e < t.childNodes.length; e++) {
|
||
const i = t.childNodes[e];
|
||
if (1 === i.nodeType) {
|
||
const t = new MutationObserver(this.handleElementChanged.bind(this));
|
||
t.observe(i, {attributes: !0, subtree: !0}), this.attributeObserver_.push(t)
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
setPropertyFromEvent_(t) {
|
||
t.target && t.key && this.set(t.key, t.target.get(t.key))
|
||
}
|
||
|
||
getScene() {
|
||
return this.scene_
|
||
}
|
||
|
||
handleMapChanged() {
|
||
var t;
|
||
this.scenePostRenderListenerRemover_ && (this.scenePostRenderListenerRemover_(), (t = this.element) && t.parentNode && t.parentNode.removeChild(t)), this.scenePostRenderListenerRemover_ = null;
|
||
const e = this.getScene();
|
||
if (e) {
|
||
this.scenePostRenderListenerRemover_ = e.postRender.addEventListener(this.updatePixelPosition.bind(this)), this.updatePixelPosition();
|
||
const t = this.stopEvent ? this.synchronizer_.getOverlayContainerStopEvent() : this.synchronizer_.getOverlayContainer();
|
||
this.insertFirst ? t.insertBefore(this.element, t.childNodes[0] || null) : t.appendChild(this.element)
|
||
}
|
||
}
|
||
|
||
handlePositionChanged() {
|
||
const t = this.getPosition();
|
||
if (t) {
|
||
const e = this.parent_.getMap().getView().getProjection();
|
||
this.positionWGS84_ = ii(t, e, "EPSG:4326")
|
||
} else this.positionWGS84_ = void 0;
|
||
this.updatePixelPosition()
|
||
}
|
||
|
||
handleElementChanged() {
|
||
function t(e, i) {
|
||
const r = e.cloneNode();
|
||
i && i.appendChild(r), e.nodeType != Node.TEXT_NODE && r.addEventListener("click", t => {
|
||
e.dispatchEvent(new MouseEvent("click", t)), t.stopPropagation()
|
||
});
|
||
const o = e.childNodes;
|
||
for (let e = 0; e < o.length; e++) o[e] && t(o[e], r);
|
||
return r
|
||
}
|
||
|
||
!function (t) {
|
||
for (; t.lastChild;) t.removeChild(t.lastChild)
|
||
}(this.element);
|
||
const e = this.getElement();
|
||
if (e && e.parentNode && e.parentNode.childNodes) for (const i of e.parentNode.childNodes) {
|
||
const e = t(i, null);
|
||
this.element.appendChild(e)
|
||
}
|
||
e.parentNode && this.observeTarget_(e.parentNode)
|
||
}
|
||
|
||
updatePixelPosition() {
|
||
const t = this.positionWGS84_;
|
||
if (!this.scene_ || !t) return void this.setVisible(!1);
|
||
let e = 0;
|
||
if (2 === t.length) {
|
||
const i = this.scene_.globe.getHeight(Cesium.Cartographic.fromDegrees(t[0], t[1]));
|
||
i && this.scene_.globe.tilesLoaded && (t[2] = i), i && (e = i)
|
||
} else e = t[2];
|
||
const i = Cesium.Cartesian3.fromDegrees(t[0], t[1], e), r = this.scene_.camera,
|
||
o = new Cesium.BoundingSphere(new Cesium.Cartesian3, 6356752);
|
||
if (!new Cesium.Occluder(o, r.position).isPointVisible(i)) return void this.setVisible(!1);
|
||
if (1 !== r.frustum.computeCullingVolume(r.position, r.direction, r.up).computeVisibility(new Cesium.BoundingSphere(i))) return void this.setVisible(!1);
|
||
this.setVisible(!0);
|
||
const n = this.scene_.cartesianToCanvasCoordinates(i), s = [n.x, n.y],
|
||
a = [this.scene_.canvas.width, this.scene_.canvas.height];
|
||
this.updateRenderedPosition(s, a)
|
||
}
|
||
|
||
destroy() {
|
||
this.scenePostRenderListenerRemover_ && this.scenePostRenderListenerRemover_(), this.observer_ && this.observer_.disconnect(), N(this.listenerKeys_), this.listenerKeys_.splice(0), this.element.removeNode ? this.element.removeNode(!0) : this.element.remove(), this.element = null
|
||
}
|
||
};
|
||
var Zw = class {
|
||
constructor(t, e) {
|
||
this.map = t, this.overlays_ = this.map.getOverlays(), this.scene = e, this.overlayContainerStopEvent_ = document.createElement("DIV"), this.overlayContainerStopEvent_.className = "ol-overlaycontainer-stopevent", ["click", "dblclick", "mousedown", "touchstart", "MSPointerDown", "pointerdown", "mousewheel", "wheel"].forEach(t => {
|
||
this.overlayContainerStopEvent_.addEventListener(t, t => t.stopPropagation())
|
||
}), this.scene.canvas.parentElement.appendChild(this.overlayContainerStopEvent_), this.overlayContainer_ = document.createElement("DIV"), this.overlayContainer_.className = "ol-overlaycontainer", this.scene.canvas.parentElement.appendChild(this.overlayContainer_), this.overlayMap_ = {}
|
||
}
|
||
|
||
getOverlayContainerStopEvent() {
|
||
return this.overlayContainerStopEvent_
|
||
}
|
||
|
||
getOverlayContainer() {
|
||
return this.overlayContainer_
|
||
}
|
||
|
||
synchronize() {
|
||
this.destroyAll(), this.addOverlays(), this.overlays_.on("add", this.addOverlayFromEvent_.bind(this)), this.overlays_.on("remove", this.removeOverlayFromEvent_.bind(this))
|
||
}
|
||
|
||
addOverlayFromEvent_(t) {
|
||
const e = t.element;
|
||
this.addOverlay(e)
|
||
}
|
||
|
||
addOverlays() {
|
||
this.overlays_.forEach(t => {
|
||
this.addOverlay()
|
||
})
|
||
}
|
||
|
||
addOverlay(t) {
|
||
if (!t) return;
|
||
const e = new qw({scene: this.scene, synchronizer: this, parent: t}), i = Ow(t).toString();
|
||
this.overlayMap_[i] = e
|
||
}
|
||
|
||
removeOverlayFromEvent_(t) {
|
||
const e = t.element;
|
||
this.removeOverlay(e)
|
||
}
|
||
|
||
removeOverlay(t) {
|
||
const e = Ow(t).toString(), i = this.overlayMap_[e];
|
||
i && (i.destroy(), delete this.overlayMap_[e])
|
||
}
|
||
|
||
destroyAll() {
|
||
Object.keys(this.overlayMap_).forEach(t => {
|
||
this.overlayMap_[t].destroy(), delete this.overlayMap_[t]
|
||
})
|
||
}
|
||
};
|
||
|
||
class Kw {
|
||
constructor(t) {
|
||
this.autoRenderLoop_ = null, this.map_ = t.map, this.time_ = t.time || function () {
|
||
return Cesium.JulianDate.now()
|
||
}, this.to4326Transform_ = ei(this.map_.getView().getProjection(), "EPSG:4326"), this.resolutionScale_ = 1, this.canvasClientWidth_ = 0, this.canvasClientHeight_ = 0, this.resolutionScaleChanged_ = !0;
|
||
const e = "position:absolute;top:0;left:0;width:100%;height:100%;";
|
||
this.container_ = document.createElement("DIV");
|
||
const i = document.createAttribute("style");
|
||
i.value = `${e}visibility:hidden;`, this.container_.setAttributeNode(i);
|
||
let r = t.target || null;
|
||
if (r) "string" == typeof r && (r = document.getElementById(r)), r.appendChild(this.container_); else {
|
||
const t = this.map_.getViewport().querySelector(".ol-overlaycontainer");
|
||
t && t.parentNode && t.parentNode.insertBefore(this.container_, t)
|
||
}
|
||
if (this.isOverMap_ = !r, this.isOverMap_ && t.stopOpenLayersEventsPropagation) {
|
||
const t = ["click", "dblclick", "mousedown", "touchstart", "MSPointerDown", "pointerdown", "mousewheel", "wheel"];
|
||
for (let e = 0, i = t.length; e < i; ++e) this.container_.addEventListener(t[e], t => t.stopPropagation())
|
||
}
|
||
this.canvas_ = document.createElement("CANVAS");
|
||
const o = document.createAttribute("style");
|
||
o.value = e, this.canvas_.setAttributeNode(o), Aw.supportsImageRenderingPixelated() && (this.canvas_.style.imageRendering = Aw.imageRenderingValue()), this.canvas_.oncontextmenu = function () {
|
||
return !1
|
||
}, this.canvas_.onselectstart = function () {
|
||
return !1
|
||
}, this.container_.appendChild(this.canvas_), this.enabled_ = !1, this.pausedInteractions_ = [], this.hiddenRootGroup_ = null;
|
||
const n = void 0 !== t.sceneOptions ? t.sceneOptions : {};
|
||
n.canvas = this.canvas_, n.scene3DOnly = !0, this.scene_ = new Cesium.Scene(n);
|
||
const s = this.scene_.screenSpaceCameraController;
|
||
s.tiltEventTypes.push({
|
||
eventType: Cesium.CameraEventType.LEFT_DRAG,
|
||
modifier: Cesium.KeyboardEventModifier.SHIFT
|
||
}), s.tiltEventTypes.push({
|
||
eventType: Cesium.CameraEventType.LEFT_DRAG,
|
||
modifier: Cesium.KeyboardEventModifier.ALT
|
||
}), s.enableLook = !1, this.scene_.camera.constrainedAxis = Cesium.Cartesian3.UNIT_Z, this.camera_ = new Bw(this.scene_, this.map_), this.globe_ = new Cesium.Globe(Cesium.Ellipsoid.WGS84), this.globe_.baseColor = Cesium.Color.WHITE, this.scene_.globe = this.globe_, this.scene_.skyAtmosphere = new Cesium.SkyAtmosphere;
|
||
const a = new Cesium.SingleTileImageryProvider({
|
||
url: "",
|
||
rectangle: Cesium.Rectangle.fromDegrees(0, 0, 1, 1)
|
||
});
|
||
this.globe_.imageryLayers.addImageryProvider(a, 0), this.dataSourceCollection_ = new Cesium.DataSourceCollection, this.dataSourceDisplay_ = new Cesium.DataSourceDisplay({
|
||
scene: this.scene_,
|
||
dataSourceCollection: this.dataSourceCollection_
|
||
});
|
||
const l = t.createSynchronizers ? t.createSynchronizers(this.map_, this.scene_, this.dataSourceCollection_) : [new Yw(this.map_, this.scene_), new Xw(this.map_, this.scene_), new Zw(this.map_, this.scene_)];
|
||
this.handleResize_();
|
||
for (let t = l.length - 1; t >= 0; --t) l[t].synchronize();
|
||
this.lastFrameTime_ = 0, this.renderId_ = void 0, this.targetFrameRate_ = Number.POSITIVE_INFINITY, this.blockCesiumRendering_ = !1, this.warmingUp_ = !1, this.trackedFeature_ = null, this.trackedEntity_ = null, this.entityView_ = null, this.needTrackedEntityUpdate_ = !1, this.boundingSphereScratch_ = new Cesium.BoundingSphere, (new Cesium.EventHelper).add(this.scene_.postRender, Kw.prototype.updateTrackedEntity_, this), Cesium.Camera.enableSuspendTerrainAdjustment = !1
|
||
}
|
||
|
||
render_() {
|
||
void 0 !== this.renderId_ && (cancelAnimationFrame(this.renderId_), this.renderId_ = void 0), !this.enabled_ && !this.warmingUp_ || this.blockCesiumRendering_ || (this.renderId_ = requestAnimationFrame(this.onAnimationFrame_.bind(this)))
|
||
}
|
||
|
||
onAnimationFrame_(t) {
|
||
this.renderId_ = void 0;
|
||
const e = 1e3 / this.targetFrameRate_;
|
||
if (t - this.lastFrameTime_ < e) return void this.render_();
|
||
this.lastFrameTime_ = t;
|
||
const i = this.time_();
|
||
if (this.scene_.initializeFrame(), this.handleResize_(), this.dataSourceDisplay_.update(i), this.entityView_) {
|
||
const t = this.trackedEntity_;
|
||
this.dataSourceDisplay_.getBoundingSphere(t, !1, this.boundingSphereScratch_) === Cesium.BoundingSphereState.DONE && (this.boundingSphereScratch_.radius = 1, this.entityView_.update(i, this.boundingSphereScratch_))
|
||
}
|
||
this.scene_.render(i), this.camera_.checkCameraChange(), this.render_()
|
||
}
|
||
|
||
updateTrackedEntity_() {
|
||
if (!this.needTrackedEntityUpdate_) return;
|
||
const t = this.trackedEntity_, e = this.scene_,
|
||
i = this.dataSourceDisplay_.getBoundingSphere(t, !1, this.boundingSphereScratch_);
|
||
if (i === Cesium.BoundingSphereState.PENDING) return;
|
||
e.screenSpaceCameraController.enableTilt = !1;
|
||
const r = i !== Cesium.BoundingSphereState.FAILED ? this.boundingSphereScratch_ : void 0;
|
||
r && (r.radius = 1), this.entityView_ = new Cesium.EntityView(t, e, e.mapProjection.ellipsoid), this.entityView_.update(this.time_(), r), this.needTrackedEntityUpdate_ = !1
|
||
}
|
||
|
||
handleResize_() {
|
||
let t = this.canvas_.clientWidth, e = this.canvas_.clientHeight;
|
||
if (0 === t | 0 === e) return;
|
||
if (t === this.canvasClientWidth_ && e === this.canvasClientHeight_ && !this.resolutionScaleChanged_) return;
|
||
let i = this.resolutionScale_;
|
||
Aw.supportsImageRenderingPixelated() || (i *= window.devicePixelRatio || 1), this.resolutionScaleChanged_ = !1, this.canvasClientWidth_ = t, this.canvasClientHeight_ = e, t *= i, e *= i, this.canvas_.width = t, this.canvas_.height = e, this.scene_.camera.frustum.aspectRatio = t / e
|
||
}
|
||
|
||
getCamera() {
|
||
return this.camera_
|
||
}
|
||
|
||
getOlMap() {
|
||
return this.map_
|
||
}
|
||
|
||
getOlView() {
|
||
const t = this.map_.getView();
|
||
return console.assert(t), t
|
||
}
|
||
|
||
getCesiumScene() {
|
||
return this.scene_
|
||
}
|
||
|
||
getDataSources() {
|
||
return this.dataSourceCollection_
|
||
}
|
||
|
||
getDataSourceDisplay() {
|
||
return this.dataSourceDisplay_
|
||
}
|
||
|
||
getEnabled() {
|
||
return this.enabled_
|
||
}
|
||
|
||
setEnabled(t) {
|
||
if (this.enabled_ === t) return;
|
||
let e;
|
||
if (this.enabled_ = t, this.container_.style.visibility = this.enabled_ ? "visible" : "hidden", this.enabled_) {
|
||
if (this.throwOnUnitializedMap_(), this.isOverMap_) {
|
||
(e = this.map_.getInteractions()).forEach((t, e, i) => {
|
||
this.pausedInteractions_.push(t)
|
||
}), e.clear();
|
||
const t = this.map_.getLayerGroup();
|
||
t.getVisible() && (this.hiddenRootGroup_ = t, this.hiddenRootGroup_.setVisible(!1)), this.map_.getOverlayContainer().classList.add("olcs-hideoverlay"), this.map_.getOverlayContainerStopEvent().classList.add("olcs-hideoverlay")
|
||
}
|
||
this.camera_.readFromView(), this.render_()
|
||
} else this.isOverMap_ && (e = this.map_.getInteractions(), this.pausedInteractions_.forEach(t => {
|
||
e.push(t)
|
||
}), this.pausedInteractions_.length = 0, this.map_.getOverlayContainer().classList.remove("olcs-hideoverlay"), this.map_.getOverlayContainerStopEvent().classList.remove("olcs-hideoverlay"), this.hiddenRootGroup_ && (this.hiddenRootGroup_.setVisible(!0), this.hiddenRootGroup_ = null)), this.camera_.updateView()
|
||
}
|
||
|
||
warmUp(t, e) {
|
||
if (this.enabled_) return;
|
||
this.throwOnUnitializedMap_(), this.camera_.readFromView();
|
||
const i = this.globe_.ellipsoid, r = this.scene_.camera, o = i.cartesianToCartographic(r.position);
|
||
o.height < t && (o.height = t, r.position = i.cartographicToCartesian(o)), this.warmingUp_ = !0, this.render_(), setTimeout(() => {
|
||
this.warmingUp_ = !1
|
||
}, e)
|
||
}
|
||
|
||
setBlockCesiumRendering(t) {
|
||
this.blockCesiumRendering_ !== t && (this.blockCesiumRendering_ = t, this.render_())
|
||
}
|
||
|
||
enableAutoRenderLoop() {
|
||
this.autoRenderLoop_ || (this.autoRenderLoop_ = new Gw(this))
|
||
}
|
||
|
||
getAutoRenderLoop() {
|
||
return this.autoRenderLoop_
|
||
}
|
||
|
||
setResolutionScale(t) {
|
||
(t = Math.max(0, t)) !== this.resolutionScale_ && (this.resolutionScale_ = Math.max(0, t), this.resolutionScaleChanged_ = !0, this.autoRenderLoop_ && this.autoRenderLoop_.restartRenderLoop())
|
||
}
|
||
|
||
setTargetFrameRate(t) {
|
||
this.targetFrameRate_ !== t && (this.targetFrameRate_ = t, this.render_())
|
||
}
|
||
|
||
throwOnUnitializedMap_() {
|
||
const t = this.map_.getView(), e = t.getCenter();
|
||
if (!t.isDef() || isNaN(e[0]) || isNaN(e[1])) throw new Error(`The OpenLayers map is not properly initialized: ${e} / ${t.getResolution()}`)
|
||
}
|
||
}
|
||
|
||
Object.defineProperties(Kw.prototype, {
|
||
trackedFeature: {
|
||
get: function () {
|
||
return this.trackedFeature_
|
||
}, set: function (t) {
|
||
if (this.trackedFeature_ !== t) {
|
||
const e = this.scene_;
|
||
if (!t || !t.getGeometry()) return this.needTrackedEntityUpdate_ = !1, e.screenSpaceCameraController.enableTilt = !0, this.trackedEntity_ && this.dataSourceDisplay_.defaultDataSource.entities.remove(this.trackedEntity_), this.trackedEntity_ = null, this.trackedFeature_ = null, this.entityView_ = null, void e.camera.lookAtTransform(Cesium.Matrix4.IDENTITY);
|
||
this.trackedFeature_ = t, this.needTrackedEntityUpdate_ = !0;
|
||
const i = this.to4326Transform_, r = function () {
|
||
const e = t.getGeometry();
|
||
console.assert(e instanceof qi);
|
||
const r = e.getCoordinates(), o = i(r, void 0, r.length);
|
||
return Dw.ol4326CoordinateToCesiumCartesian(o)
|
||
}, o = {
|
||
position: new Cesium.CallbackProperty((t, e) => r(), !1),
|
||
point: {pixelSize: 1, color: Cesium.Color.TRANSPARENT}
|
||
};
|
||
this.trackedEntity_ = this.dataSourceDisplay_.defaultDataSource.entities.add(o)
|
||
}
|
||
}
|
||
}
|
||
});
|
||
var Jw = Kw;
|
||
var $w = class {
|
||
constructor(t) {
|
||
this.promise, this.url_ = t
|
||
}
|
||
|
||
load() {
|
||
return this.promise || (this.promise = new Promise((t, e) => {
|
||
const i = document.createElement("script");
|
||
i.onload = (() => t()), i.onerror = (() => e()), document.head.appendChild(i), i.src = this.url_
|
||
})), this.promise
|
||
}
|
||
};
|
||
var Qw = class extends D {
|
||
constructor(t, {map: e, cameraExtentInRadians: i} = {}) {
|
||
super(), this.cesiumUrl_ = t, this.map = e, this.cameraExtentInRadians = i || null, this.boundingSphere_, this.blockLimiter_ = !1, this.promise_, this.ol3d, this.cesiumInitialTilt_ = zw(50), this.fogDensity = 1e-4, this.fogSSEFactor = 25, this.minimumZoomDistance = 2, this.maximumZoomDistance = 1e7, this.limitCameraToBoundingSphereRatio = (t => t > 3e3 ? 9 : 3)
|
||
}
|
||
|
||
load() {
|
||
if (!this.promise_) {
|
||
const t = new $w(this.cesiumUrl_);
|
||
this.promise_ = t.load().then(() => this.onCesiumLoaded())
|
||
}
|
||
return this.promise_
|
||
}
|
||
|
||
onCesiumLoaded() {
|
||
if (this.cameraExtentInRadians) {
|
||
const t = new Cesium.Rectangle(...this.cameraExtentInRadians);
|
||
Cesium.Camera.DEFAULT_VIEW_RECTANGLE = t, this.boundingSphere_ = Cesium.BoundingSphere.fromRectangle3D(t, Cesium.Ellipsoid.WGS84, 300)
|
||
}
|
||
this.ol3d = this.instantiateOLCesium();
|
||
const t = this.ol3d.getCesiumScene();
|
||
return this.configureForUsability(t), this.configureForPerformance(t), this.dispatchEvent("load"), this.ol3d
|
||
}
|
||
|
||
instantiateOLCesium() {
|
||
console.assert(this.map);
|
||
const t = new Jw({map: this.map}), e = t.getCesiumScene(), i = Cesium.createWorldTerrain();
|
||
return e.terrainProvider = i, t
|
||
}
|
||
|
||
configureForPerformance(t) {
|
||
const e = t.fog;
|
||
e.enabled = !0, e.density = this.fogDensity, e.screenSpaceErrorFactor = this.fogSSEFactor
|
||
}
|
||
|
||
configureForUsability(t) {
|
||
const e = t.screenSpaceCameraController;
|
||
e.minimumZoomDistance = this.minimumZoomDistance, e.maximumZoomDistance = this.maximumZoomDistance, t.globe.depthTestAgainstTerrain = !0, t.globe.baseColor = Cesium.Color.WHITE, t.backgroundColor = Cesium.Color.WHITE, this.boundingSphere_ && t.postRender.addEventListener(this.limitCameraToBoundingSphere.bind(this), t), this.ol3d.enableAutoRenderLoop()
|
||
}
|
||
|
||
limitCameraToBoundingSphere() {
|
||
if (this.boundingSphere_ && !this.blockLimiter_) {
|
||
const t = this.ol3d.getCesiumScene().camera, e = t.position,
|
||
i = Cesium.Cartographic.fromCartesian(e), r = this.limitCameraToBoundingSphereRatio(i.height);
|
||
if (Cesium.Cartesian3.distance(this.boundingSphere_.center, e) > this.boundingSphere_.radius * r) {
|
||
if (!0 === t.flying) return;
|
||
{
|
||
this.blockLimiter_ = !0;
|
||
const e = () => this.blockLimiter_ = !1;
|
||
t.flyToBoundingSphere(this.boundingSphere_, {complete: e, cancel: e})
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
toggle3d() {
|
||
return this.load().then(t => {
|
||
const e = t.getEnabled(), i = t.getCesiumScene();
|
||
return e ? (console.assert(this.map), Dw.resetToNorthZenith(this.map, i).then(() => {
|
||
t.setEnabled(!1), this.dispatchEvent("toggle")
|
||
})) : (t.setEnabled(!0), this.dispatchEvent("toggle"), Dw.rotateAroundBottomCenter(i, this.cesiumInitialTilt_))
|
||
})
|
||
}
|
||
|
||
set3dWithView(t, e, i, r, o) {
|
||
return this.load().then(n => {
|
||
const s = n.getEnabled(), a = n.getCesiumScene().camera, l = Cesium.Cartesian3.fromDegrees(t, e, i),
|
||
h = {heading: Cesium.Math.toRadians(r), pitch: Cesium.Math.toRadians(o), roll: 0};
|
||
s || (n.setEnabled(!0), this.dispatchEvent("toggle")), a.setView({destination: l, orientation: h})
|
||
})
|
||
}
|
||
|
||
is3dEnabled() {
|
||
return !!this.ol3d && this.ol3d.getEnabled()
|
||
}
|
||
|
||
getHeading() {
|
||
return this.map && this.map.getView().getRotation() || 0
|
||
}
|
||
|
||
getTiltOnGlobe() {
|
||
const t = this.ol3d.getCesiumScene();
|
||
return -Dw.computeSignedTiltAngleOnGlobe(t)
|
||
}
|
||
|
||
setHeading(t) {
|
||
const e = this.ol3d.getCesiumScene(), i = Dw.pickBottomPoint(e);
|
||
i && Dw.setHeadingUsingBottomCenter(e, t, i)
|
||
}
|
||
|
||
getOl3d() {
|
||
return this.ol3d
|
||
}
|
||
|
||
getOlView() {
|
||
const t = this.map.getView();
|
||
return console.assert(t), t
|
||
}
|
||
|
||
getCesiumViewMatrix() {
|
||
return this.ol3d.getCesiumScene().camera.viewMatrix
|
||
}
|
||
|
||
getCesiumScene() {
|
||
return this.ol3d.getCesiumScene()
|
||
}
|
||
|
||
flyToRectangle(t, e = 0) {
|
||
const i = this.getCesiumScene().camera, r = i.getRectangleCameraCoordinates(t),
|
||
o = Cesium.Cartesian3.magnitude(r) + e;
|
||
return Cesium.Cartesian3.normalize(r, r), Cesium.Cartesian3.multiplyByScalar(r, o, r), new Promise((t, e) => {
|
||
this.cameraExtentInRadians ? i.flyTo({
|
||
destination: r,
|
||
complete: () => t(),
|
||
cancel: () => e(),
|
||
endTransform: Cesium.Matrix4.IDENTITY
|
||
}) : e()
|
||
})
|
||
}
|
||
|
||
getCameraExtentRectangle() {
|
||
if (this.cameraExtentInRadians) return new Cesium.Rectangle(...this.cameraExtentInRadians)
|
||
}
|
||
}, tb = window.olcs = {};
|
||
tb.OLCesium = Jw, tb.AbstractSynchronizer = Vw, tb.RasterSynchronizer = Yw, tb.VectorSynchronizer = Xw, tb.core = Dw, tb.core.OLImageryProvider = Fw, tb.core.VectorLayerCounterpart = Ww, tb.contrib = {}, tb.contrib.LazyLoader = $w, tb.contrib.Manager = Qw;
|
||
var eb = i(4), ib = i.n(eb), rb = ["type", "source", "source-layer", "minzoom", "maxzoom", "filter", "layout"];
|
||
|
||
function ob(t, e) {
|
||
const i = {};
|
||
for (const e in t) "ref" !== e && (i[e] = t[e]);
|
||
return rb.forEach(t => {
|
||
t in e && (i[t] = e[t])
|
||
}), i
|
||
}
|
||
|
||
var nb = function (t) {
|
||
t = t.slice();
|
||
const e = Object.create(null);
|
||
for (let i = 0; i < t.length; i++) e[t[i].id] = t[i];
|
||
for (let i = 0; i < t.length; i++) "ref" in t[i] && (t[i] = ob(t[i], e[t[i].ref]));
|
||
return t
|
||
};
|
||
var sb = i(11), ab = i(2);
|
||
|
||
function lb(t) {
|
||
return t * Math.PI / 180
|
||
}
|
||
|
||
const hb = function () {
|
||
const t = [];
|
||
for (let e = 78271.51696402048; t.length <= 24; e /= 2) t.push(e);
|
||
return t
|
||
}();
|
||
const ub = Array(256).join(" ");
|
||
|
||
function cb(t, e) {
|
||
if (e >= .05) {
|
||
let i = "";
|
||
const r = t.split("\n"), o = ub.slice(0, Math.round(e / .1));
|
||
for (let t = 0, e = r.length; t < e; ++t) t > 0 && (i += "\n"), i += r[t].split("").join(o);
|
||
return i
|
||
}
|
||
return t
|
||
}
|
||
|
||
const pb = document.createElement("CANVAS").getContext("2d");
|
||
|
||
function db(t, e) {
|
||
return pb.measureText(t).width + (t.length - 1) * e
|
||
}
|
||
|
||
let fb = {};
|
||
|
||
function gb(t, e, i, r) {
|
||
const o = i + "," + e + "," + t + "," + r;
|
||
let n = fb[o];
|
||
if (!n) {
|
||
const s = t.split(" ");
|
||
if (s.length > 1) {
|
||
pb.font = e;
|
||
const t = pb.measureText("M").width * i;
|
||
let o = "";
|
||
const a = [];
|
||
for (let e = 0, i = s.length; e < i; ++e) {
|
||
const i = s[e], n = o + (o ? " " : "") + i;
|
||
db(n, r) <= t ? o = n : (o && a.push(o), o = i)
|
||
}
|
||
o && a.push(o);
|
||
for (let e = 0, i = a.length; e < i; ++e) {
|
||
const o = a[e];
|
||
if (db(o, r) < .35 * t) {
|
||
const t = e > 0 ? db(a[e - 1], r) : 1 / 0, n = e < i - 1 ? db(a[e + 1], r) : 1 / 0;
|
||
a.splice(e, 1), t < n ? (a[e - 1] += " " + o, e -= 1) : a[e] = o + " " + a[e], i -= 1
|
||
}
|
||
}
|
||
for (let e = 0, i = a.length - 1; e < i; ++e) {
|
||
const o = a[e], n = a[e + 1];
|
||
if (db(o, r) > .7 * t && db(n, r) < .6 * t) {
|
||
const s = o.split(" "), l = s.pop();
|
||
db(l, r) < .2 * t && (a[e] = s.join(" "), a[e + 1] = l + " " + n), i -= 1
|
||
}
|
||
}
|
||
n = a.join("\n")
|
||
} else n = t;
|
||
n = cb(n, r), fb[o] = n
|
||
}
|
||
return n
|
||
}
|
||
|
||
Ma && w(Ma, F.CLEAR, function () {
|
||
fb = {}
|
||
});
|
||
const mb = ab.function.isFunction, yb = ab.function.convertFunction, vb = ab.expression.isExpression,
|
||
_b = ab.expression.createPropertyExpression,
|
||
xb = {Point: 1, MultiPoint: 1, LineString: 2, MultiLineString: 2, Polygon: 3, MultiPolygon: 3},
|
||
wb = function (t, e) {
|
||
const i = _b(t, e);
|
||
if ("error" === i.result) throw new Error(i.value.map(t => `${t.key}: ${t.message}`).join(", "));
|
||
return i.value
|
||
}, bb = {}, Cb = {zoom: 0}, Sb = {};
|
||
|
||
function Eb(t, e, i, r, o) {
|
||
const n = t.id;
|
||
Sb[n] || (Sb[n] = {});
|
||
const s = Sb[n];
|
||
if (!s[i]) {
|
||
let r = (t[e] || bb)[i];
|
||
const o = sb[`${e}_${t.type}`][i];
|
||
void 0 === r && (r = o.default);
|
||
let n = vb(r);
|
||
if (!n && mb(r) && (r = yb(r, o), n = !0), n) {
|
||
const t = wb(r, o);
|
||
s[i] = t.evaluate.bind(t)
|
||
} else "color" == o.type && (r = ab.Color.parse(r)), s[i] = function () {
|
||
return r
|
||
}
|
||
}
|
||
return Cb.zoom = r, s[i](Cb, o)
|
||
}
|
||
|
||
const Tb = {};
|
||
|
||
function Rb(t, e, i, r) {
|
||
return t in Tb || (Tb[t] = Object(ab.featureFilter)(e)), Cb.zoom = r, Tb[t](Cb, i)
|
||
}
|
||
|
||
function Pb(t, e) {
|
||
if (t) {
|
||
if (0 === t.a || 0 === e) return;
|
||
const i = t.a;
|
||
return e = void 0 === e ? 1 : e, "rgba(" + Math.round(255 * t.r / i) + "," + Math.round(255 * t.g / i) + "," + Math.round(255 * t.b / i) + "," + i * e + ")"
|
||
}
|
||
return t
|
||
}
|
||
|
||
const Lb = /^([^]*)\{(.*)\}([^]*)$/;
|
||
|
||
function Ib(t, e) {
|
||
let i;
|
||
do {
|
||
if (i = t.match(Lb)) {
|
||
const r = e[i[2]] || "";
|
||
t = i[1] + r + i[3]
|
||
}
|
||
} while (i);
|
||
return t
|
||
}
|
||
|
||
var Ob = function (t, e, i, r = hb, o, n, s) {
|
||
if ("string" == typeof e && (e = JSON.parse(e)), 8 != e.version) throw new Error("glStyle version 8 required.");
|
||
let a, l;
|
||
if (n) {
|
||
const e = new Image;
|
||
e.crossOrigin = "anonymous", e.onload = function () {
|
||
a = e, l = [e.width, e.height], t.changed(), e.onload = null
|
||
}, e.src = n
|
||
}
|
||
const h = nb(e.layers), u = {}, c = [];
|
||
let p;
|
||
for (let t = 0, r = h.length; t < r; ++t) {
|
||
const r = h[t], o = r.id;
|
||
if ("string" == typeof i && r.source == i || -1 !== i.indexOf(o)) {
|
||
const i = r["source-layer"];
|
||
if (!p) {
|
||
p = r.source;
|
||
const t = e.sources[p];
|
||
if (!t) throw new Error(`Source "${p}" is not defined`);
|
||
const i = t.type;
|
||
if ("vector" !== i && "geojson" !== i) throw new Error(`Source "${p}" is not of type "vector" or "geojson", but "${i}"`)
|
||
}
|
||
let n = u[i];
|
||
n || (n = u[i] = []), n.push({layer: r, index: t}), c.push(o)
|
||
}
|
||
delete Sb[o], delete Tb[o]
|
||
}
|
||
const d = new go, f = new po, g = {}, m = {}, y = [], v = function (t, e) {
|
||
const i = t.getProperties(), n = u[i.layer];
|
||
if (!n) return;
|
||
let h = r.indexOf(e);
|
||
-1 == h && (h = function (t, e) {
|
||
let i = 0;
|
||
const r = e.length;
|
||
for (; i < r; ++i) if (e[i] < t && i + 1 < r) {
|
||
const r = e[i] / e[i + 1];
|
||
return i + Math.log(e[i] / t) / Math.log(r)
|
||
}
|
||
return r - 1
|
||
}(e, r));
|
||
const c = xb[t.getGeometry().getType()], p = {properties: i, type: c};
|
||
let v = -1;
|
||
for (let r = 0, u = n.length; r < u; ++r) {
|
||
const u = n[r], _ = u.layer, x = _.id, w = _.layout || bb, b = _.paint || bb;
|
||
if ("none" === w.visibility || "minzoom" in _ && h < _.minzoom || "maxzoom" in _ && h >= _.maxzoom) continue;
|
||
const C = _.filter;
|
||
if (!C || Rb(x, C, p, h)) {
|
||
let r, n, x, C, S, E;
|
||
const T = u.index;
|
||
if (3 == c && "fill" == _.type) if (n = Eb(_, "paint", "fill-opacity", h, p), "fill-pattern" in b) {
|
||
const t = Eb(_, "paint", "fill-pattern", h, p);
|
||
if (t) {
|
||
const e = Ib(t, i);
|
||
if (a && o && o[e]) {
|
||
(E = y[++v]) && E.getFill() && !E.getStroke() && !E.getText() || (E = y[v] = new uf({fill: new po})), x = E.getFill(), E.setZIndex(T);
|
||
const t = e + "." + n;
|
||
let i = m[t];
|
||
if (!i) {
|
||
const r = o[e], s = document.createElement("canvas");
|
||
s.width = r.width, s.height = r.height;
|
||
const l = s.getContext("2d");
|
||
l.globalAlpha = n, l.drawImage(a, r.x, r.y, r.width, r.height, 0, 0, r.width, r.height), i = l.createPattern(s, "repeat"), m[t] = i
|
||
}
|
||
x.setColor(i)
|
||
}
|
||
}
|
||
} else (r = Pb(Eb(_, "paint", "fill-color", h, p), n)) && ("fill-outline-color" in b && (S = Pb(Eb(_, "paint", "fill-outline-color", h, p), n)), S || (S = r), (E = y[++v]) && E.getFill() && E.getStroke() && !E.getText() || (E = y[v] = new uf({
|
||
fill: new po,
|
||
stroke: new go
|
||
})), (x = E.getFill()).setColor(r), (C = E.getStroke()).setColor(S), C.setWidth(1), E.setZIndex(T));
|
||
if (1 != c && "line" == _.type) {
|
||
r = !("line-pattern" in b) && "line-color" in b ? Pb(Eb(_, "paint", "line-color", h, p), Eb(_, "paint", "line-opacity", h, p)) : void 0;
|
||
const t = Eb(_, "paint", "line-width", h, p);
|
||
r && t > 0 && ((E = y[++v]) && E.getStroke() && !E.getFill() && !E.getText() || (E = y[v] = new uf({stroke: new go})), (C = E.getStroke()).setLineCap(Eb(_, "layout", "line-cap", h, p)), C.setLineJoin(Eb(_, "layout", "line-join", h, p)), C.setMiterLimit(Eb(_, "layout", "line-miter-limit", h, p)), C.setColor(r), C.setWidth(t), C.setLineDash(b["line-dasharray"] ? Eb(_, "paint", "line-dasharray", h, p).map(function (e) {
|
||
return e * t
|
||
}) : null), E.setZIndex(T))
|
||
}
|
||
let R, P, L, I, O = !1, M = null, A = 0;
|
||
if ((1 == c || 2 == c) && "icon-image" in w) {
|
||
const n = Eb(_, "layout", "icon-image", h, p);
|
||
if (n) {
|
||
R = Ib(n, i);
|
||
let s = void 0;
|
||
if (a && o && o[R]) {
|
||
const i = Eb(_, "layout", "icon-rotation-alignment", h, p);
|
||
if (2 == c) {
|
||
const r = t.getGeometry();
|
||
if (r.getFlatMidpoint) {
|
||
const t = r.getExtent();
|
||
if (Math.sqrt(Math.max(Math.pow((t[2] - t[0]) / e, 2), Math.pow((t[3] - t[1]) / e, 2))) > 150) {
|
||
const t = r.getFlatMidpoint();
|
||
if (s = new qi(t), "line" === Eb(_, "layout", "symbol-placement", h, p) && "map" === i) {
|
||
const e = r.getStride(), i = r.getFlatCoordinates();
|
||
for (let r = 0, o = i.length - e; r < o; r += e) {
|
||
const o = i[r], n = i[r + 1], s = i[r + e], a = i[r + e + 1],
|
||
l = Math.min(o, s), h = Math.min(n, a), u = Math.max(o, s),
|
||
c = Math.max(n, a);
|
||
if (t[0] >= l && t[0] <= u && t[1] >= h && t[1] <= c) {
|
||
A = Math.atan2(n - a, s - o);
|
||
break
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
if (2 !== c || s) {
|
||
(E = y[++v]) && E.getImage() && !E.getFill() && !E.getStroke() || (E = y[v] = new uf), E.setGeometry(s);
|
||
const t = Eb(_, "layout", "icon-size", h, p),
|
||
e = void 0 !== b["icon-color"] ? Eb(_, "paint", "icon-color", h, p) : null;
|
||
let n = R + "." + t;
|
||
if (null !== e && (n += "." + e), !(P = g[n])) {
|
||
const s = o[R];
|
||
if (null !== e) {
|
||
r = Pb(e, 1);
|
||
const i = document.createElement("canvas");
|
||
i.width = s.width, i.height = s.height;
|
||
const o = i.getContext("2d");
|
||
o.drawImage(a, s.x, s.y, s.width, s.height, 0, 0, s.width, s.height);
|
||
const l = o.getImageData(0, 0, i.width, i.height);
|
||
for (let t = 0, e = l.data.length; t < e; t += 4) l.data[t] = r[0], l.data[t + 1] = r[1], l.data[t + 2] = r[2];
|
||
o.putImageData(l, 0, 0), P = g[n] = new Xd({
|
||
img: i,
|
||
imgSize: [i.width, i.height],
|
||
scale: t / s.pixelRatio
|
||
})
|
||
} else P = g[n] = new Xd({
|
||
img: a,
|
||
imgSize: l,
|
||
size: [s.width, s.height],
|
||
offset: [s.x, s.y],
|
||
rotateWithView: "map" === i,
|
||
scale: t / s.pixelRatio
|
||
})
|
||
}
|
||
P.setRotation(A + lb(Eb(_, "layout", "icon-rotate", h, p))), P.setOpacity(Eb(_, "paint", "icon-opacity", h, p)), E.setImage(P), M = E.getText(), E.setText(void 0), E.setZIndex(99999 - T), O = !0, L = !1
|
||
} else L = !0
|
||
}
|
||
}
|
||
}
|
||
if (1 == c && "circle-radius" in b) {
|
||
(E = y[++v]) && E.getImage() && !E.getFill() && !E.getStroke() || (E = y[v] = new uf);
|
||
const t = Eb(_, "paint", "circle-radius", h, p),
|
||
e = Pb(Eb(_, "paint", "circle-stroke-color", h, p), Eb(_, "paint", "circle-stroke-opacity", h, p)),
|
||
i = Pb(Eb(_, "paint", "circle-color", h, p), Eb(_, "paint", "circle-opacity", h, p)),
|
||
r = Eb(_, "paint", "circle-stroke-width", h, p), o = t + "." + e + "." + i + "." + r;
|
||
(P = g[o]) || (P = g[o] = new Zd({
|
||
radius: t,
|
||
stroke: e && r > 0 ? new go({width: r, color: e}) : void 0,
|
||
fill: i ? new po({color: i}) : void 0
|
||
})), E.setImage(P), M = E.getText(), E.setText(void 0), E.setGeometry(void 0), E.setZIndex(99999 - T), O = !0
|
||
}
|
||
if ("text-field" in w) {
|
||
I = Ib(Eb(_, "layout", "text-field", h, p).toString(), i), n = Eb(_, "paint", "text-opacity", h, p)
|
||
}
|
||
if (I && n && !L) {
|
||
O || ((E = y[++v]) && E.getText() && !E.getFill() && !E.getStroke() || (E = y[v] = new uf), E.setImage(void 0), E.setGeometry(void 0)), E.getText() || E.setText(M || new vo({padding: [2, 2, 2, 2]})), M = E.getText();
|
||
const t = Eb(_, "layout", "text-size", h, p), e = Eb(_, "layout", "text-font", h, p),
|
||
i = Eb(_, "layout", "text-line-height", h, p), r = ib()(s ? s(e) : e, t, i),
|
||
o = w["text-transform"];
|
||
"uppercase" == o ? I = I.toUpperCase() : "lowercase" == o && (I = I.toLowerCase());
|
||
const a = Eb(_, "layout", "text-max-width", h, p),
|
||
l = Eb(_, "layout", "text-letter-spacing", h, p),
|
||
u = 2 == c ? cb(I, l) : gb(I, r, a, l);
|
||
M.setText(u), M.setFont(r), M.setRotation(lb(Eb(_, "layout", "text-rotate", h, p)));
|
||
const g = Eb(_, "layout", "text-anchor", h, p),
|
||
m = O || 1 == c ? "point" : Eb(_, "layout", "symbol-placement", h, p);
|
||
M.setPlacement(m);
|
||
let x = Eb(_, "paint", "text-halo-width", h, p);
|
||
const b = Eb(_, "layout", "text-offset", h, p), C = Eb(_, "paint", "text-translate", h, p);
|
||
let S = 0, R = 0;
|
||
if ("point" == m) {
|
||
let t = "center";
|
||
-1 !== g.indexOf("left") ? (t = "left", R = x) : -1 !== g.indexOf("right") && (t = "right", R = -x), M.setTextAlign(t)
|
||
} else M.setMaxAngle(lb(Eb(_, "layout", "text-max-angle", h, p))), M.setTextAlign();
|
||
let P = "middle";
|
||
0 == g.indexOf("bottom") ? (P = "bottom", S = -x - .5 * (i - 1) * t) : 0 == g.indexOf("top") && (P = "top", S = x + .5 * (i - 1) * t), M.setTextBaseline(P), M.setOffsetX(b[0] * t + R + C[0]), M.setOffsetY(b[1] * t + S + C[1]), f.setColor(Pb(Eb(_, "paint", "text-color", h, p), n)), M.setFill(f);
|
||
const L = Pb(Eb(_, "paint", "text-halo-color", h, p), n);
|
||
if (L) {
|
||
d.setColor(L), x *= 2;
|
||
const e = .5 * t;
|
||
d.setWidth(x <= e ? x : e), M.setStroke(d)
|
||
} else M.setStroke(void 0);
|
||
const A = Eb(_, "layout", "text-padding", h, p), k = M.getPadding();
|
||
A !== k[0] && (k[0] = k[1] = k[2] = k[3] = A), E.setZIndex(99999 - T)
|
||
}
|
||
}
|
||
}
|
||
return v > -1 ? (y.length = v + 1, y) : void 0
|
||
};
|
||
return t.setStyle(v), t.set("mapbox-source", p), t.set("mapbox-layers", c), v
|
||
}, Mb = i(12);
|
||
const Ab = /font-family: ?([^;]*);/, kb = /("|')/g;
|
||
let Fb;
|
||
|
||
function Nb(t) {
|
||
if (!Fb) {
|
||
Fb = {};
|
||
const t = document.styleSheets;
|
||
for (let e = 0, i = t.length; e < i; ++e) {
|
||
const i = t[e];
|
||
try {
|
||
const t = i.rules || i.cssRules;
|
||
if (t) for (let e = 0, i = t.length; e < i; ++e) {
|
||
const i = t[e];
|
||
if (5 == i.type) {
|
||
const t = i.cssText.match(Ab);
|
||
Fb[t[1].replace(kb, "")] = !0
|
||
}
|
||
}
|
||
} catch (t) {
|
||
}
|
||
}
|
||
}
|
||
return t in Fb
|
||
}
|
||
|
||
const Db = {}, Gb = i.n(Mb).a.getNames();
|
||
|
||
function jb(t) {
|
||
const e = t.toString();
|
||
if (e in Db) return t;
|
||
const i = t.map(function (t) {
|
||
const e = ib()(t, 1).split(" ");
|
||
return [e.slice(3, 5).join(" ").replace(/"/g, ""), e[1] + e[0]]
|
||
});
|
||
for (let t = 0, e = i.length; t < e; ++t) {
|
||
const e = i[t], r = e[0];
|
||
if (!Nb(r) && -1 !== Gb.indexOf(r)) {
|
||
const t = "https://fonts.googleapis.com/css?family=" + r.replace(/ /g, "+") + ":" + e[1];
|
||
if (!document.querySelector('link[href="' + t + '"]')) {
|
||
const e = document.createElement("link");
|
||
e.href = t, e.rel = "stylesheet", document.head.appendChild(e)
|
||
}
|
||
}
|
||
}
|
||
return Db[e] = !0, t
|
||
}
|
||
|
||
const zb = /^(.*)(\?.*)$/;
|
||
|
||
function Ub(t, e) {
|
||
return e && t.startsWith(".") && (t = e + t), t
|
||
}
|
||
|
||
function Bb(t, e, i) {
|
||
const r = (t = Ub(t, e)).match(zb);
|
||
return r ? r[1] + i + (r.length > 2 ? r[2] : "") : t + i
|
||
}
|
||
|
||
function Vb(t, e, i, r, o) {
|
||
return new Promise(function (n, s) {
|
||
if ("object" != typeof e && (e = JSON.parse(e)), 8 != e.version) return s(new Error("glStyle version 8 required."));
|
||
if (!(t instanceof v_ || t instanceof ux)) return s(new Error("Can only apply to VectorLayer or VectorTileLayer"));
|
||
let a, l, h, u;
|
||
|
||
function c() {
|
||
u || e.sprite && !l ? u ? (t.setStyle(u), n()) : s(new Error("Something went wrong trying to apply style.")) : (u = Ob(t, e, i, o, l, h, jb), t.getStyle() ? n() : s(new Error(`Nothing to show for source [${i}]`)))
|
||
}
|
||
|
||
if (e.sprite) {
|
||
const t = .5 == (a = window.devicePixelRatio >= 1.5 ? .5 : 1) ? "@2x" : "";
|
||
let i = Bb(e.sprite, r, t + ".json");
|
||
fetch(i, {credentials: "same-origin"}).then(function (o) {
|
||
return o.ok || "" === t ? o : (i = Bb(e.sprite, r, ".json"), fetch(i, {credentials: "same-origin"}))
|
||
}).then(function (t) {
|
||
if (t.ok) return t.json();
|
||
s(new Error(`Problem fetching sprite from ${i}: ${t.statusText}`))
|
||
}).then(function (i) {
|
||
if (void 0 === i || 0 === Object.keys(i).length) return s(new Error("No sprites found."));
|
||
l = i, h = Bb(e.sprite, r, t + ".png"), c()
|
||
}).catch(function (t) {
|
||
s(new Error(`Sprites cannot be loaded: ${i}: ${t.message}`))
|
||
})
|
||
} else c()
|
||
})
|
||
}
|
||
|
||
const Yb = {};
|
||
|
||
function Wb(t, e) {
|
||
const i = {type: e.type};
|
||
|
||
function r() {
|
||
const r = t.getTargetElement();
|
||
if (!r) return;
|
||
const o = e.layout || {}, n = e.paint || {};
|
||
i.paint = n, i.id = "olms-bg-" + n["background-opacity"] + n["background-color"];
|
||
const s = t.getView().getZoom();
|
||
if (void 0 !== n["background-color"]) {
|
||
const t = Eb(i, "paint", "background-color", s, Yb);
|
||
r.style.backgroundColor = ab.Color.parse(t).toString()
|
||
}
|
||
void 0 !== n["background-opacity"] && (r.style.opacity = Eb(i, "paint", "background-opacity", s, Yb)), "none" == o.visibility && (r.style.backgroundColor = "", r.style.opacity = "")
|
||
}
|
||
|
||
t.getTargetElement() && r(), t.on(["change:resolution", "change:target"], r)
|
||
}
|
||
|
||
function Hb(t, e) {
|
||
let i;
|
||
return t.some(function (t) {
|
||
if (t.id == e) return i = t.source, !0
|
||
}), i
|
||
}
|
||
|
||
function Xb(t) {
|
||
const e = t.bounds;
|
||
if (e) {
|
||
const t = $e([e[0], e[1]]), i = $e([e[2], e[3]]);
|
||
return [t[0], t[1], i[0], i[1]]
|
||
}
|
||
}
|
||
|
||
function qb(t, e, i) {
|
||
if (t = Object.assign({}, t), i && 0 == i.indexOf("mapbox://")) {
|
||
const r = i.replace("mapbox://", "");
|
||
t.tiles = ["a", "b", "c", "d"].map(function (i) {
|
||
return "https://" + i + ".tiles.mapbox.com/v4/" + r + "/{z}/{x}/{y}." + ("vector" == t.type ? "vector.pbf" : "png") + e
|
||
})
|
||
}
|
||
const r = new ux({declutter: !0, visible: !1}),
|
||
o = new pw({url: t.tiles ? void 0 : i, tileJSON: t.tiles ? t : void 0}),
|
||
n = o.on("change", function () {
|
||
const e = o.getState();
|
||
if ("ready" === e) {
|
||
const e = o.getTileJSON(), i = Array.isArray(e.tiles) ? e.tiles : [e.tiles];
|
||
if (t.url) for (let e = 0, r = i.length; e < r; ++e) {
|
||
const r = i[e];
|
||
0 != r.indexOf("http") && (i[e] = t.url + r)
|
||
}
|
||
const s = o.getTileGrid(), a = Xb(e), l = e.minzoom || 0, h = e.maxzoom || 22, u = new yw({
|
||
attributions: o.getAttributions(),
|
||
format: new cm,
|
||
tileGrid: new Xu({
|
||
origin: s.getOrigin(),
|
||
extent: a || s.getExtent(),
|
||
minZoom: l,
|
||
resolutions: hb.slice(0, h + 1),
|
||
tileSize: 512
|
||
}),
|
||
urls: i
|
||
});
|
||
N(n), r.setSource(u)
|
||
} else "error" === e && (N(n), r.setSource(void 0))
|
||
});
|
||
return t.tiles && o.changed(), r
|
||
}
|
||
|
||
function Zb(t, e) {
|
||
const i = new lx, r = new pw({
|
||
transition: 0,
|
||
url: t.tiles ? void 0 : e,
|
||
tileJSON: t.tiles ? t : void 0,
|
||
crossOrigin: "anonymous"
|
||
}), o = r.on("change", function () {
|
||
const e = r.getState();
|
||
if ("ready" === e) {
|
||
N(o);
|
||
const e = r.getTileJSON(), n = Xb(e), s = r.getTileGrid(), a = t.tileSize || e.tileSize || 512,
|
||
l = e.minzoom || 0, h = e.maxzoom || 22;
|
||
r.tileGrid = new Xu({
|
||
origin: s.getOrigin(),
|
||
extent: n || s.getExtent(),
|
||
minZoom: l,
|
||
resolutions: Ju({maxZoom: h, tileSize: a}).getResolutions(),
|
||
tileSize: a
|
||
}), i.setSource(r)
|
||
} else "error" === e && (N(o), i.setSource(void 0))
|
||
});
|
||
return r.setTileLoadFunction(function (t, e) {
|
||
if (-1 != e.indexOf("{bbox-epsg-3857}")) {
|
||
const i = r.getTileGrid().getTileCoordExtent(t.getTileCoord());
|
||
e = e.replace("{bbox-epsg-3857}", i.toString())
|
||
}
|
||
t.getImage().src = e
|
||
}), i
|
||
}
|
||
|
||
const Kb = new Od;
|
||
|
||
function Jb(t, e) {
|
||
const i = t.data;
|
||
let r, o;
|
||
return "string" == typeof i ? o = Ub(i, e) : r = Kb.readFeatures(i, {featureProjection: "EPSG:3857"}), new v_({
|
||
source: new b_({
|
||
attributions: t.attribution,
|
||
features: r,
|
||
format: Kb,
|
||
url: o
|
||
}), visible: !1
|
||
})
|
||
}
|
||
|
||
function $b(t, e, i) {
|
||
const r = Eb(t, "paint", "raster-opacity", i.getZoom(), Yb);
|
||
e.setOpacity(r)
|
||
}
|
||
|
||
function Qb(t, e, i, r, o, n) {
|
||
const s = [];
|
||
let a = e.getView();
|
||
a.isDef() || a.getRotation() || a.getResolutions() || (a = new ss({resolutions: hb}), e.setView(a)), "center" in t && !a.getCenter() && a.setCenter($e(t.center)), "zoom" in t && void 0 === a.getZoom() && a.setResolution(hb[0] / Math.pow(2, t.zoom)), a.getCenter() && void 0 !== a.getZoom() || a.fit(a.getProjection().getExtent(), {
|
||
nearest: !0,
|
||
size: e.getSize()
|
||
}), t.sprite && (0 == t.sprite.indexOf("mapbox://") ? t.sprite = i + "/sprite" + n : 0 != t.sprite.indexOf("http") && (t.sprite = (r ? r + o : "") + t.sprite + n));
|
||
const l = t.layers;
|
||
let h, u, c, p, d, f, g = [];
|
||
for (let i = 0, r = l.length; i < r; ++i) {
|
||
const r = (h = l[i]).type;
|
||
"heatmap" == r || "fill-extrusion" == r || "hillshade" == r || ("background" == r ? Wb(e, h) : ((p = h.source || Hb(l, h.ref)) != c && (g.length && (s.push(eC(d, g, t, o, e)), g = []), (f = (u = t.sources[p]).url) && o && f.startsWith(".") && (f = o + f), "vector" == u.type ? d = qb(u, n, f) : "raster" == u.type ? ((d = Zb(u, f)).setVisible(!h.layout || "none" !== h.layout.visibility), a.on("change:resolution", $b.bind(this, h, d, a)), $b(h, d, a)) : "geojson" == u.type && (d = Jb(u, o)), c = p, d && d.set("mapbox-source", c)), g.push(h.id)))
|
||
}
|
||
return s.push(eC(d, g, t, o, e)), e.set("mapbox-style", t), Promise.all(s)
|
||
}
|
||
|
||
function tC(t, e) {
|
||
let i, r, o, n, s;
|
||
if (i = r = o = n = "", t instanceof rh || (t = new rh({target: t})), "string" == typeof e) {
|
||
const a = e.match(zb);
|
||
a && (r = a[1], i = a.length > 2 ? a[2] : ""), s = new Promise(function (s, a) {
|
||
fetch(e, {credentials: "same-origin"}).then(function (t) {
|
||
return t.json()
|
||
}).then(function (l) {
|
||
const h = document.createElement("A");
|
||
h.href = e;
|
||
const u = h.href;
|
||
n = h.pathname.split("/").slice(0, -1).join("/") + "/", o = u.substr(0, u.indexOf(n)), Qb(l, t, r, o, n, i).then(function () {
|
||
s(t)
|
||
}).catch(a)
|
||
}).catch(function (t) {
|
||
a(new Error(`Could not load ${e}: ${t.message}`))
|
||
})
|
||
})
|
||
} else s = new Promise(function (i, r) {
|
||
Qb(e, t).then(function () {
|
||
i(t)
|
||
}).catch(r)
|
||
});
|
||
return s
|
||
}
|
||
|
||
function eC(t, e, i, r, o) {
|
||
let n = 24, s = 0;
|
||
const a = i.layers;
|
||
for (let t = 0, i = a.length; t < i; ++t) {
|
||
const i = a[t];
|
||
-1 !== e.indexOf(i.id) && (n = Math.min("minzoom" in i ? i.minzoom : 0, n), s = Math.max("maxzoom" in i ? i.maxzoom : 24, s))
|
||
}
|
||
return new Promise(function (a, l) {
|
||
const h = function () {
|
||
const o = t.getSource();
|
||
if (o && "error" !== o.getState()) {
|
||
if ("function" == typeof o.getTileGrid) {
|
||
const e = o.getTileGrid();
|
||
if (e) {
|
||
const i = e.getMinZoom();
|
||
(n > 0 || i > 0) && t.setMaxResolution(Math.min(hb[n], e.getResolution(i)) + 1e-9), s < 24 && t.setMinResolution(hb[s] + 1e-9)
|
||
}
|
||
}
|
||
o instanceof b_ || o instanceof yw ? Vb(t, i, e, r).then(function () {
|
||
t.setVisible(!0), a()
|
||
}, function (t) {
|
||
l(t)
|
||
}) : a()
|
||
} else l(new Error("Error accessing data for source " + t.get("mapbox-source")))
|
||
};
|
||
t.set("mapbox-layers", e), -1 === o.getLayers().getArray().indexOf(t) && o.addLayer(t, !0), t.getSource() ? h() : t.once("change:source", h)
|
||
})
|
||
}
|
||
|
||
tC.apply = function (t, e) {
|
||
return t instanceof rh || (t = new rh({target: t})), setTimeout(function () {
|
||
tC(t, e)
|
||
}, 0), t
|
||
}, tC.applyBackground = function (t, e) {
|
||
e.layers.some(function (e) {
|
||
if ("background" == e.type) return Wb(t, e), !0
|
||
})
|
||
}, tC.applyStyle = Vb, tC.stylefunction = Ob;
|
||
var iC = tC;
|
||
window.olms = iC;
|
||
var rC = class {
|
||
constructor(t, e) {
|
||
W(void 0 !== t, "经度坐标不能为空"), W(void 0 !== e, "纬度坐标不能为空"), this.coordinate_ = [parseFloat(t), parseFloat(e)]
|
||
}
|
||
|
||
getCoordinate() {
|
||
return this.coordinate_
|
||
}
|
||
|
||
toStringXY() {
|
||
var t = this.coordinate_;
|
||
return t[0] + "," + t[1]
|
||
}
|
||
|
||
distanceTo(t) {
|
||
return ce(this.getCoordinate(), t.getCoordinate())
|
||
}
|
||
};
|
||
var oC = class extends X {
|
||
constructor(t) {
|
||
super(t), this.layer_ = null, this.set("isAddToMap", !1)
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t;
|
||
var e = t.getVectorLayers(), i = this;
|
||
e.getLayers().forEach(function (t, e, r) {
|
||
if ("vector_default" === t.get("name")) {
|
||
var o = t;
|
||
o.getSource().addFeature(i), i.layer_ = o
|
||
}
|
||
}), this.set("isAddToMap", !0)
|
||
}
|
||
|
||
onRemove(t) {
|
||
if (this.get("isAddToMap")) {
|
||
this.popup_ && (this.map_.removeOverlay(this.popup_), this.popup_ = null), this.map_ = null;
|
||
var e = t.getVectorLayers(), i = this;
|
||
e.getLayers().forEach(function (t, e, r) {
|
||
"vector_default" === t.get("name") && t.getSource().removeFeature(i)
|
||
}), this.set("isAddToMap", !1)
|
||
}
|
||
}
|
||
|
||
getMBR() {
|
||
var t = this.getGeometry().getExtent();
|
||
return new Ez.MBR(t[0], t[1], t[2], t[3])
|
||
}
|
||
|
||
readGeoJSON(t) {
|
||
return (new ol.format.GeoJSON).readFeature(t)
|
||
}
|
||
|
||
toGeoJSON() {
|
||
var t = new ol.format.GeoJSON;
|
||
return JSON.parse(t.writeFeature(this))
|
||
}
|
||
|
||
getFillStyle_() {
|
||
return this.getStyle().getFill()
|
||
}
|
||
|
||
getStrokeStyle_() {
|
||
return this.getStyle().getStroke()
|
||
}
|
||
|
||
getFillColor() {
|
||
var t = this.getFillStyle_(), e = ol.color.asArray(t.getColor());
|
||
return ol.color.asString(e)
|
||
}
|
||
|
||
getFillOpacity() {
|
||
var t = this.getFillStyle_(), e = ol.color.asArray(t.getColor());
|
||
return parseFloat(e[3])
|
||
}
|
||
|
||
setFillColor(t) {
|
||
var e = this.getStyle(), i = this.getFillStyle_(), r = ol.color.asArray(i.getColor())[3],
|
||
o = ol.color.asArray(t);
|
||
o[3] = r, i.setColor(o), this.setStyle(e)
|
||
}
|
||
|
||
setFillOpacity(t) {
|
||
W(t >= 0 && t <= 1, "设置的透明度必须在[0,1]范围内");
|
||
var e = this.getStyle(), i = this.getFillStyle_(), r = ol.color.asArray(i.getColor());
|
||
r[3] = t, i.setColor(r), this.setStyle(e)
|
||
}
|
||
|
||
getStrokeColor() {
|
||
var t = this.getStrokeStyle_(), e = ol.color.asArray(t.getColor());
|
||
return ol.color.asString(e)
|
||
}
|
||
|
||
getStrokeWidth() {
|
||
return this.getStrokeStyle_().getWidth()
|
||
}
|
||
|
||
getStrokeOpacity() {
|
||
var t = this.getStrokeStyle_(), e = ol.color.asArray(t.getColor());
|
||
return parseFloat(e[3])
|
||
}
|
||
|
||
setStrokeColor(t) {
|
||
var e = this.getStyle(), i = this.getStrokeStyle_(), r = ol.color.asArray(i.getColor())[3],
|
||
o = ol.color.asArray(t);
|
||
o[3] = r, i.setColor(o), this.setStyle(e)
|
||
}
|
||
|
||
setStrokeWidth(t) {
|
||
var e = this.getStyle();
|
||
this.getStrokeStyle_().setWidth(t), this.setStyle(e)
|
||
}
|
||
|
||
setStrokeOpacity(t) {
|
||
W(t >= 0 && t <= 1, "设置的透明度必须在[0,1]范围内");
|
||
var e = this.getStyle(), i = this.getStrokeStyle_(), r = ol.color.asArray(i.getColor());
|
||
r[3] = t, i.setColor(r), this.setStyle(e)
|
||
}
|
||
|
||
show() {
|
||
if (!this.get("isAddToMap")) {
|
||
var t = this.map_.getVectorLayers(), e = this;
|
||
t.getLayers().forEach(function (t, i, r) {
|
||
"vector_default" === t.get("name") && t.getSource().addFeature(e)
|
||
}), this.set("isAddToMap", !0)
|
||
}
|
||
}
|
||
|
||
hide() {
|
||
if (this.get("isAddToMap")) {
|
||
var t = this.map_.getVectorLayers(), e = this;
|
||
t.getLayers().forEach(function (t, i, r) {
|
||
"vector_default" === t.get("name") && t.getSource().removeFeature(e)
|
||
}), this.set("isAddToMap", !1)
|
||
}
|
||
}
|
||
|
||
addTitle(t) {
|
||
t || W(!1, "EzTitle对象不能为空"), this.title_ = t, this.isTitleOnMap = !1, this.isTitleInited = !1
|
||
}
|
||
|
||
showTitle() {
|
||
this.map_ && this.title_ && (this.map_, this.isTitleInited || this.handleTitleInit_(), this.title_.show(), this.isTitleOnMap = !0)
|
||
}
|
||
|
||
handleTitleInit_() {
|
||
var t, e = this.getGeometry().getType();
|
||
t = e === ol.geom.GeometryType.CIRCLE ? this.getCenter() : e === ol.geom.GeometryType.POINT ? this.getCenter() : e === ol.geom.GeometryType.LINE_STRING ? this.getCenter() : e === ol.geom.GeometryType.POLYGON ? this.getCenter() : this.getPoint(), this.title_.setPosition(t), this.map_.addOverlay(this.title_), this.isTitleInited = !0
|
||
}
|
||
|
||
hideTitle() {
|
||
this.title_.hide(), this.isTitleOnMap = !1, this.title_.hide()
|
||
}
|
||
|
||
openInfoWindow(t, e, i) {
|
||
var r;
|
||
e instanceof Ez.Coordinate ? r = e.getCoordinate() : Array.isArray(e) ? r = e : W(!1, "请传入坐标数组或者EzCoord对象"), this.popup_ && (this.map_.removeOverlay(this.popup_), this.popup_ = null), this.popup_ = new Ez.Popup(i), this.map_.addOverlay(this.popup_), this.popup_.show(t, r)
|
||
}
|
||
|
||
closeInfoWindow() {
|
||
this.popup_ && (this.map_.removeOverlay(this.popup_), this.popup_ = null)
|
||
}
|
||
|
||
getBounds() {
|
||
var t = this.getGeometry().getExtent();
|
||
return new Ez.MBR(t[0], t[1], t[2], t[3])
|
||
}
|
||
|
||
flash(t) {
|
||
var e = t || {}, i = e.duration ? e.duration : 3e3, r = e.times ? e.times : 3;
|
||
if (this.hide(), this.getFillOpacity(), this.getStrokeOpacity(), this.map_) {
|
||
var o, n = (new Date).getTime(), s = new Date(n), a = this;
|
||
o = map.on("postcompose", function (t) {
|
||
var e = t.vectorContext, l = t.frameState, h = (l.time - n) / (i / r * 1.25),
|
||
u = new ol.style.Style({fill: new ol.style.Fill({color: "rgba(76,140,88," + h + ")"})});
|
||
if (e.drawFeature(a.clone(), u), h >= .8 && (n = l.time, h = 0), l.time - s > i) return ol.Observable.unByKey(o), map.render(), void a.show();
|
||
map.render()
|
||
}), map.render()
|
||
}
|
||
}
|
||
|
||
hexToRgb_(t) {
|
||
var e = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(t);
|
||
return e ? [parseInt(e[1], 16), parseInt(e[2], 16), parseInt(e[3], 16)] : null
|
||
}
|
||
};
|
||
var nC = class extends Xd {
|
||
constructor(t) {
|
||
var e = t || {};
|
||
super(e), this.iconOpts = e
|
||
}
|
||
|
||
getOptions() {
|
||
return this.iconOpts
|
||
}
|
||
};
|
||
var sC = class {
|
||
constructor(t, e, i, r) {
|
||
this.minX = t, this.minY = e, this.maxX = i, this.maxY = r, this.value_ = [t, e, i, r]
|
||
}
|
||
|
||
centerPoint(t) {
|
||
var e = At(this.value_);
|
||
return t ? new rC(e[0], e[1]) : e
|
||
}
|
||
|
||
containsBounds(t) {
|
||
return dt(this.value_, t.value_)
|
||
}
|
||
|
||
containsPoint(t) {
|
||
var e;
|
||
return e = t instanceof rC ? t.getCoordinate() : t, pt(this.value_, e)
|
||
}
|
||
|
||
getExtent() {
|
||
return this.value_
|
||
}
|
||
|
||
toBBoxString() {
|
||
return this.minX + "," + this.minY + "," + this.maxX + "," + this.maxY
|
||
}
|
||
}, aC = {
|
||
MAP_CLICK: "click",
|
||
MAP_DBLCLICK: "dblclick",
|
||
MAP_MOUSEDOWN: "pointerdown",
|
||
MAP_MOUSEMOVE: "pointermove",
|
||
MAP_MOUSEUP: "pointerup",
|
||
MAP_MOUSEOVER: "pointerover",
|
||
MAP_MOUSEOUT: "pointerout",
|
||
MAP_PANEND: "moveend",
|
||
MAP_PAN: "pointerdrag",
|
||
MAP_ZOOMCHANGE: "change:resolution",
|
||
POPUP_OPEN: "popup:open",
|
||
POPUP_CLOSE: "popup:close"
|
||
};
|
||
var lC = class extends lx {
|
||
constructor(t, e) {
|
||
var i = e || {}, r = {}, o = i.customOpts ? i.customOpts : null;
|
||
for (var n in i) "customOpts" !== i[n] && (r[n] = i[n]);
|
||
super(r), this.key_ = i.key, this.set("ezname", t), this.set("isAddToMap", !1), o && this.set("customOpts", o)
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t, t.getTileLayers().getLayers().push(this), this.set("isAddToMap", !0)
|
||
}
|
||
|
||
onRemove(t) {
|
||
this.get("isAddToMap") && (this.map_ = null, t.getTileLayers().getLayers().remove(this), this.set("isAddToMap", !1))
|
||
}
|
||
|
||
getResolutions() {
|
||
return this.getSource().getTileGrid().getResolutions()
|
||
}
|
||
};
|
||
var hC = class extends Rx {
|
||
constructor(t) {
|
||
for (var e = t.projection || "EPSG:4326", i = new Array(30), r = 0; r <= 30; ++r) i[r] = Math.pow(2, 1 - r);
|
||
var o = {};
|
||
o.tileGrid = new ol.tilegrid.TileGrid({
|
||
origin: [0, 0],
|
||
resolutions: t.resolutions || i,
|
||
tileSize: 256
|
||
}), o.projection = e, o.tileUrlFunction = function (e, i, r) {
|
||
var o = e[0], n = e[1], s = e[2];
|
||
return t.url.replace("{z}", o.toString()).replace("{y}", s.toString()).replace("{x}", n.toString())
|
||
}, W(t.url && "" != t.url, "瓦片URL模板不能为空"), super(o), this.urlTemplate_ = t.url
|
||
}
|
||
|
||
urlCallbackFunction_(t, e, i) {
|
||
var r = t[0], o = t[1], n = t[2];
|
||
return this.urlTemplate_.replace("{z}", r.toString()).replace("{y}", n.toString()).replace("{x}", o.toString())
|
||
}
|
||
};
|
||
var uC = class extends lC {
|
||
constructor(t, e, i) {
|
||
for (var r = i || {}, o = new Array(30), n = 0; n <= 30; ++n) o[n] = Math.pow(2, 1 - n);
|
||
// var s = e + "/EzMap?Service=getImage&Type=RGB&ZoomOffset=0&Col={x}&Row={y}&Zoom={z}&V=0.3&key=" + r.key,
|
||
var s = e;
|
||
a = new hC({
|
||
url: s,
|
||
crossOrigin: r.crossOrigin,
|
||
wrapX: !r.wrapX || r.wrapX,
|
||
cacheSize: r.cacheSize ? r.cacheSize : 2048,
|
||
resolutions: o
|
||
});
|
||
super(t, Object.assign({}, r, {source: a})), this.url_ = e
|
||
}
|
||
|
||
getUrl() {
|
||
return this.url_
|
||
}
|
||
|
||
getResolutions(t, e) {
|
||
for (var i = new Array(30), r = 0; r <= 30; ++r) i[r] = Math.pow(2, 1 - r);
|
||
return i.slice(t, e + 1)
|
||
}
|
||
};
|
||
var cC = class extends lC {
|
||
constructor(t, e, i) {
|
||
for (var r = i || {}, o = new Array(30), n = 9; n >= 0; --n) o[n] = Math.pow(2, 9 - n) / 256 * 114699;
|
||
for (n = 10; n <= 30; ++n) o[n] = 1 / Math.pow(2, n - 9) / 256 * 114699;
|
||
// var s = e + "/EzMap?Service=getImage&Type=RGB&ZoomOffset=0&Col={x}&Row={y}&Zoom={z}&V=0.3&key=" + r.key,
|
||
var s = e ;
|
||
a = new hC({
|
||
url: s,
|
||
crossOrigin: r.crossOrigin,
|
||
resolutions: o,
|
||
wrapX: !r.wrapX || r.wrapX,
|
||
projection: "EPSG:3857"
|
||
});
|
||
super(t, Object.assign({}, r, {source: a})), this.url_ = e
|
||
}
|
||
|
||
getUrl() {
|
||
return this.url_
|
||
}
|
||
};
|
||
var pC = class extends lC {
|
||
constructor(t, e, i) {
|
||
for (var r = i || {}, o = new Array(30), n = new Array(30), s = 0; s < 30; ++s) o[s] = 360 / (256 * Math.pow(2, s)), n[s] = s;
|
||
var a = new ol.tilegrid.WMTS({
|
||
origin: r.origin || [-180, 90],
|
||
resolutions: r.resolutions || o,
|
||
matrixIds: r.matrixIds || n
|
||
});
|
||
r.token && (e = e + "&token=" + r.token);
|
||
var l = new ol.source.WMTS({
|
||
url: e,
|
||
crossOrigin: r.crossOrigin,
|
||
wrapX: null == r.wrapX || r.wrapX,
|
||
projection: r.projection || "EPSG:4326",
|
||
layer: r.layer,
|
||
requestEncoding: r.requestEncoding || "KVP",
|
||
tileGrid: a,
|
||
matrixSet: r.matrixSet,
|
||
format: r.format,
|
||
maxZoom: r.maxZoom,
|
||
minZoom: r.minZoom,
|
||
tileSize: r.tileSize,
|
||
attributions: r.attributions,
|
||
style: r.style
|
||
});
|
||
super(t, Object.assign({}, r, {source: l})), this.url_ = e
|
||
}
|
||
|
||
getUrl() {
|
||
return this.url_
|
||
}
|
||
};
|
||
var dC = class extends lC {
|
||
constructor(t, e, i) {
|
||
var r = i || {}, o = e + "&x={x}&y={y}&z={z}", n = new ol.source.XYZ({
|
||
url: o,
|
||
crossOrigin: r.crossOrigin,
|
||
wrapX: !r.wrapX || r.wrapX,
|
||
cacheSize: r.cacheSize ? r.cacheSize : 2048,
|
||
tileLoadFunction: r.tileLoadFunction ? r.tileLoadFunction : void 0,
|
||
projection: "EPSG:3857"
|
||
});
|
||
super(t, Object.assign({}, r, {source: n})), this.url_ = e
|
||
}
|
||
|
||
getUrl() {
|
||
return this.url_
|
||
}
|
||
};
|
||
var fC = class extends lC {
|
||
constructor(t, e, i) {
|
||
var r = i || {},
|
||
// o = e + "/EzMap?Service=getImage&Type=RGB&ZoomOffset=0&Col={x}&Row={y}&Zoom={z}&V=0.3&key=" + r.key;
|
||
o = e
|
||
r.token && (o = o + "&token=" + r.token);
|
||
var n = new Lx({
|
||
url: o,
|
||
crossOrigin: r.crossOrigin,
|
||
wrapX: null == r.wrapX || r.wrapX,
|
||
cacheSize: r.cacheSize ? r.cacheSize : 2048,
|
||
tileLoadFunction: r.tileLoadFunction ? r.tileLoadFunction : void 0,
|
||
projection: "EPSG:4326"
|
||
});
|
||
super(t, Object.assign({}, r, {source: n})), this.url_ = e
|
||
}
|
||
|
||
getUrl() {
|
||
return this.url_
|
||
}
|
||
};
|
||
var gC = class extends k {
|
||
constructor(t, e) {
|
||
var i = function (t, r, o, n) {
|
||
var s;
|
||
if ("EzMap2010" === t) s = new uC(r, o, n); else if ("EzMap2010Local" === t) s = new cC(r, o, n); else if ("wmts_sl" === t) if (s = new Ez.VectorLayer.WMTS_SL(r, o, n), "openlayers" == n.styleType) {
|
||
var a = new Ez.Json2Style(e, n.styleUrl);
|
||
s.setJson2Style(a)
|
||
} else "mapbox" == n.styleType && (a = new Ez.Json2StyleMapbox(s, n.styleUrl, n.styleSource)); else if ("wmts" === t) s = new pC(r, o, n); else if ("gd" === t) s = new dC(r, o, n); else if ("group" === t) c = Object.assign({}, n.subLayer[1], {projection: n.projection}, {key: n.key}), l = i(n.subType, r, o, n), p = i(n.subType, r, n.subLayer[0], c), (s = new Ez.Layer.Group({layers: [l, p]})).set("ezname", r), s.set("imageSRC", n.imageSRC); else if ("groups" === t) {
|
||
for (var l, h = [l = i(n.subType, r, o, n)], u = 0; u < n.groups.length; u++) {
|
||
var c = Object.assign({}, n.groups[u], {projection: n.projection}, {key: n.key}),
|
||
p = i(n.groups[u].subType, r, n.groups[u].url, c);
|
||
h.push(p)
|
||
}
|
||
(s = new Ez.Layer.Group({layers: h})).set("ezname", r), s.set("imageSRC", n.imageSRC)
|
||
} else s = new fC(r, o, n);
|
||
return s
|
||
}, r = null != t ? t : {};
|
||
super(), this.map_ = e, this.opts_ = r;
|
||
var o = r.MapSrcURL;
|
||
this.layersInfoArray_ = [], this.layers_ = [];
|
||
for (var n = o.length - 1; n >= 0; n--) {
|
||
var s = o[n][0], a = o[n][1], l = o[n][2], h = {};
|
||
for (var u in l) "crs" === u ? h.projection = this.crs2Projection(l[u]) : h[u] = l[u];
|
||
h.key || (h.key = r.AuthorKey ? r.AuthorKey : "");
|
||
var c = i(h.type, s, a, h);
|
||
0 === n && e.addLayer(c), this.layers_.push(c);
|
||
var p = {};
|
||
p.title = c.get("ezname"), p.layer = c, p.imageSRC = c.get("imageSRC"), this.layersInfoArray_.push(p)
|
||
}
|
||
}
|
||
|
||
initialize() {
|
||
}
|
||
|
||
getGlobalOptions() {
|
||
return this.opts_
|
||
}
|
||
|
||
crs2Projection(t) {
|
||
return "EPSG:" + (null != t ? t : "4326")
|
||
}
|
||
|
||
getLayers() {
|
||
return this.layers_
|
||
}
|
||
|
||
getLayersInfo() {
|
||
return this.layersInfoArray_
|
||
}
|
||
};
|
||
var mC = class extends sh {
|
||
constructor(t, e, i, r, o, n) {
|
||
var s, a = document.createElement("div");
|
||
a.id = t, a.innerHTML = i, e instanceof rC ? s = e.getCoordinate() : Array.isArray(e) ? s = e : W(!1, "请传入坐标数组或者EzCoord对象"), super({
|
||
stopEvent: n = null == n || n,
|
||
element: a,
|
||
offset: null != r ? r : [0, 0],
|
||
positioning: null != o ? o : "top-left",
|
||
position: s
|
||
}), this.htmlelementoverlayFlag = !0
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t
|
||
}
|
||
|
||
onRemove(t) {
|
||
this.map_ = null
|
||
}
|
||
|
||
show() {
|
||
this.getElement().style.display = "block"
|
||
}
|
||
|
||
hide() {
|
||
this.getElement().style.display = "none"
|
||
}
|
||
|
||
setPos(t) {
|
||
var e;
|
||
t instanceof rC ? e = t.getCoordinate() : goog.isArray(t) ? e = t : W(!1, "请传入坐标数组或者EzCoord对象"), this.setPosition(e)
|
||
}
|
||
|
||
getPos(t) {
|
||
var e = this.getPosition();
|
||
return null != t && t ? e : new rC(e[0], e[1])
|
||
}
|
||
|
||
openInfoWindow(t, e, i) {
|
||
var r;
|
||
e instanceof rC ? r = e.getCoordinate() : Array.isArray(e) ? r = e : W(!1, "请传入坐标数组或者EzCoord对象"), this.popup_ || (t instanceof Ez.Popup ? this.popup_ = t : this.popup_ = new Ez.Popup(i), this.map_.addOverlay(this.popup_)), this.popup_.show(r, t)
|
||
}
|
||
|
||
closeInfoWindow() {
|
||
this.popup_ && (this.map_.removeOverlay(this.popup_), this.popup_ = null)
|
||
}
|
||
};
|
||
var yC = class {
|
||
constructor() {
|
||
this.flag = !1
|
||
}
|
||
|
||
init(t) {
|
||
if (!this.flag) {
|
||
var e = new XMLHttpRequest;
|
||
e.open("GET", serviceUrl + "/BasicsServlet", !1), e.onload = function (i) {
|
||
e.status >= 200 && e.status < 300 && (200 == JSON.parse(e.response).code ? (this.flag = !0, console.log("地图客户端已启动!"), t && t()) : console.log("请检查许可证书!"))
|
||
}.bind(this), e.send()
|
||
}
|
||
}
|
||
};
|
||
var vC = class {
|
||
constructor() {
|
||
}
|
||
|
||
static isDef(t) {
|
||
return void 0 !== t
|
||
}
|
||
|
||
static isNull(t) {
|
||
return null === t
|
||
}
|
||
|
||
static isString(t) {
|
||
return "string" == typeof t
|
||
}
|
||
|
||
static isNumber(t) {
|
||
return "number" == typeof t
|
||
}
|
||
|
||
static isDefAndNotNull(t) {
|
||
return null != t
|
||
}
|
||
};
|
||
|
||
class _C extends A {
|
||
constructor(t) {
|
||
super(t)
|
||
}
|
||
}
|
||
|
||
class xC extends oC {
|
||
constructor(t, e, i, r) {
|
||
var o;
|
||
o = vC.isDef(e) ? new uf({image: e}) : new uf({
|
||
image: new Xd({
|
||
src: "../images/marker-icon.png",
|
||
anchor: [.5, 1],
|
||
anchorXUnits: ol.style.IconAnchorUnits.FRACTION,
|
||
anchorYUnits: ol.style.IconAnchorUnits.FRACTION,
|
||
size: [25, 41],
|
||
opacity: 1
|
||
})
|
||
}), super({geometry: new qi(t.getCoordinate())}), this.coordinatesOfEz_ = t, this.coordinatesOfOl_ = t.getCoordinate(), this.map_ = null, this.title_ = null != i ? i : null, this.isTitleOnMap = !1, this.isTitleInited = !1, this.anchorImg_ = this.set("coordinate", this.coordinatesOfOl_), this.set("markerStyle", o), this.setStyle(o), this.markerFlag = !0;
|
||
var n = r || {};
|
||
n.draggable && this.set("draggable", n.draggable)
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t;
|
||
var e = t.getMarkerLayers(), i = this;
|
||
e.getLayers().forEach(function (t, e, r) {
|
||
"marker_default" === t.get("name") && t.getSource().addFeature(i)
|
||
}), this.set("isAddToMap", !0)
|
||
}
|
||
|
||
onRemove(t) {
|
||
if (this.get("isAddToMap")) {
|
||
this.title_ && this.isTitleOnMap && this.hideTitle(), this.map_ = null;
|
||
var e = t.getMarkerLayers(), i = this;
|
||
e.getLayers().forEach(function (t, e, r) {
|
||
"marker_default" === t.get("name") && t.getSource().removeFeature(i)
|
||
}), this.set("isAddToMap", !1)
|
||
}
|
||
}
|
||
|
||
show() {
|
||
this.setOpacity(this.opac_ ? this.opac_ : this.getOpacity()), delete this.opac_, this.isTitleOnMap && (this.title_.isShow || this.title_.show())
|
||
}
|
||
|
||
hide() {
|
||
this.opac_ = this.getOpacity(), this.setOpacity(0), this.isTitleOnMap && this.title_.hide()
|
||
}
|
||
|
||
getPoint() {
|
||
var t = this.getGeometry().getCoordinates();
|
||
return new rC(t[0], t[1])
|
||
}
|
||
|
||
setPoint(t) {
|
||
this.coordinatesOfEz_ = t;
|
||
var e = t.getCoordinate();
|
||
return this.coordinatesOfOl_ = e, this.getGeometry().setCoordinates(e), this.set("coordinate", e), this
|
||
}
|
||
|
||
setOpacity(t) {
|
||
var e = this.getStyle();
|
||
e.getImage().setOpacity(t), this.setStyle(e)
|
||
}
|
||
|
||
getOpacity() {
|
||
return this.getStyle().getImage().getOpacity()
|
||
}
|
||
|
||
getRotate() {
|
||
return this.getStyle().getImage().getRotation()
|
||
}
|
||
|
||
openInfoWindow(t, e) {
|
||
var i = this.getGeometry().getCoordinates(), r = e || {}, o = {};
|
||
for (var n in r) o[n] = r[n];
|
||
var s = this.getStyle().getImage().getSize();
|
||
s = s || [25, 41];
|
||
var a = this.getStyle().getImage().getScale();
|
||
a = a || 1, o.offsetX = 0, o.offsetY = -(s[1] * a + 5), this.popup_ && (this.map_.removeOverlay(this.popup_), this.popup_ = null), this.popup_ = new Ez.Popup(o), this.map_.addOverlay(this.popup_), this.popup_.show(t, i)
|
||
}
|
||
|
||
closeInfoWindow() {
|
||
this.popup_ && (this.map_.removeoverlay(this.popup_), this.popup_ = null)
|
||
}
|
||
|
||
handleChange_() {
|
||
var t = this.getGeometry().getCoordinates();
|
||
this.title_.setPosition(t)
|
||
}
|
||
|
||
handleOnLoad_() {
|
||
this.handleChange_(), this.map_.addOverlay(this.title_)
|
||
}
|
||
|
||
handleTitleInit_() {
|
||
var t = this.getPoint();
|
||
this.title_.setPosition(t), this.map_.addOverlay(this.title_), this.isTitleInited = !0
|
||
}
|
||
|
||
getImage() {
|
||
return this.getStyle().getImage().getImage()
|
||
}
|
||
|
||
getIcon() {
|
||
return this.getStyle().getImage()
|
||
}
|
||
|
||
setIcon(t, e) {
|
||
this.getStyle();
|
||
var i = new ol.style.Style({image: t});
|
||
this.setStyle(i), e || this.changed()
|
||
}
|
||
|
||
flash(t) {
|
||
var e = t || {}, i = e.duration ? e.duration : 3e3, r = e.times ? e.times : 3;
|
||
this.hide();
|
||
var o = this.getIcon();
|
||
if (this.map_) {
|
||
var n, s = (new Date).getTime(), a = (new Date(s), this);
|
||
n = map.on("postcompose", function (t) {
|
||
var e = t.vectorContext, l = (t.frameState.time - s) / parseFloat(i / r),
|
||
h = new ol.style.Style({image: o}), u = l % 1;
|
||
if (u < .3 || u > .6 ? o.setOpacity(1) : o.setOpacity(0), e.drawFeature(a.clone(), h), l > r) return ol.Observable.unByKey(n), map.render(), void a.show();
|
||
map.render()
|
||
}), map.render()
|
||
}
|
||
}
|
||
}
|
||
|
||
class wC extends ol.events.Event {
|
||
constructor(t) {
|
||
super(t)
|
||
}
|
||
}
|
||
|
||
class bC extends ol.Overlay {
|
||
constructor(t) {
|
||
var e = t || {}, i = null != e.customStyle ? e.customStyle : "ez-popup", r = e.offsetY || 0,
|
||
o = e.offsetX || 0, n = i, s = document.createElement("div");
|
||
s.className = i;
|
||
var a = null;
|
||
if (super({
|
||
element: s,
|
||
autoPan: !1,
|
||
stopEvent: !!e.stopEvent && e.stopEvent,
|
||
insertFirst: !e.hasOwnProperty("insertFirst") || e.insertFirst,
|
||
positioning: "bottom-center",
|
||
offset: [o, r]
|
||
}), n) {
|
||
var l = document.createElement("span");
|
||
l.className = "ez-popup-closer", s.appendChild(l);
|
||
var h = this;
|
||
l.addEventListener("click", function (t) {
|
||
t.stopPropagation(), h.close(), this.blur()
|
||
});
|
||
var u = document.createElement("div");
|
||
u.className = "ez-popup-content", s.appendChild(u), a = u
|
||
} else a = s;
|
||
this.container = s, this.appendContent = a, this.isDefaultStyle = n, this.panMapIfOutOfView = e.panMapIfOutOfView, void 0 === this.panMapIfOutOfView && (this.panMapIfOutOfView = !0), (this.fn_ = e.fn ? e.fn : null) && this.appendContent.addEventListener("click", this.delegate_.bind(this))
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t
|
||
}
|
||
|
||
onRemove(t) {
|
||
this.map_ = null
|
||
}
|
||
|
||
delegate_(t) {
|
||
if (this.fn_) return this.fn_(t), !1
|
||
}
|
||
|
||
close() {
|
||
this.map_.dispatchEvent(new Ez.PopupTargetMoveEvent("popup:close")), this.dispatchEvent(new wC("CLOSE")), this.map_.removeOverlay(this), this.map_ && this.map_.popup_ && (this.map_.popup_ = null)
|
||
}
|
||
|
||
show(t, e) {
|
||
return this.appendContent.innerHTML = t, e instanceof rC ? this.setPosition(e.getCoordinate()) : this.setPosition(e), this.container.style.display = "block", this.getMap().dispatchEvent(new Ez.PopupTargetMoveEvent("popup:open")), this.updatePixelPosition(), this.panMapIfOutOfView && this.map_.frameState_ && this.panIntoView_(e), this
|
||
}
|
||
|
||
setContent(t) {
|
||
this.appendContent.innerHTML = t
|
||
}
|
||
|
||
panIntoView_() {
|
||
var t = this.getMap();
|
||
if (void 0 !== t && t.getTargetElement()) {
|
||
var e = this.getRect(t.getTargetElement(), t.getSize()), i = this.getElement();
|
||
ol.asserts.assert(i, "element should be defined");
|
||
var r = this.getRect(i, [ol.dom.outerWidth(i), ol.dom.outerHeight(i)]), o = this.autoPanMargin_;
|
||
if (!ol.extent.containsExtent(e, r)) {
|
||
var n = r[0] - e[0], s = e[2] - r[2], a = r[1] - e[1], l = e[3] - r[3], h = [0, 0];
|
||
if (n < 0 ? h[0] = n - o : s < 0 && (h[0] = Math.abs(s) + o), a < 0 ? h[1] = a - o : l < 0 && (h[1] = Math.abs(l) + o), 0 !== h[0] || 0 !== h[1]) {
|
||
var u = t.getView().getCenter();
|
||
ol.asserts.assert(void 0 !== u, "center should be defined");
|
||
var c = t.getPixelFromCoordinate(u), p = [c[0] + h[0], c[1] + h[1]];
|
||
t.getView().animate({center: t.getCoordinateFromPixel(p), duration: 250})
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
isTouchDevice_() {
|
||
try {
|
||
return document.createEvent("TouchEvent"), !0
|
||
} catch (t) {
|
||
return !1
|
||
}
|
||
}
|
||
|
||
enableTouchScroll_(t) {
|
||
if (bC.isTouchDevice_()) {
|
||
var e = 0;
|
||
t.addEventListener("touchstart", function (t) {
|
||
e = this.scrollTop + t.touches[0].pageY
|
||
}, !1), t.addEventListener("touchmove", function (t) {
|
||
this.scrollTop = e - t.touches[0].pageY
|
||
}, !1)
|
||
}
|
||
}
|
||
|
||
hide() {
|
||
return this.container.style.display = "none", this
|
||
}
|
||
}
|
||
|
||
var CC = class extends ol.Feature {
|
||
constructor(t, e) {
|
||
super({geometry: new ol.geom.Point([0, 0])}), ol.asserts.assert(null != t, "Title对象构造时name参数不能为空"), this.title_ = t;
|
||
var i = null != e ? e : {}, r = this.defaultStyle_ = {
|
||
font: null != i.font ? i.font : "微软雅黑,宋体",
|
||
fontSize: null != i.fontSize ? parseInt(i.fontSize) : 12,
|
||
fontColor: null != i.fontColor ? i.fontColor : "#000000",
|
||
fillColor: null != i.fillColor ? i.fillColor : "#FFFFFF",
|
||
strokeColor: null != i.strokeColor ? i.strokeColor : "#000000",
|
||
isStroke: null != i.isStroke && i.isStroke,
|
||
strokeWidth: null != i.strokeWidth ? parseInt(i.strokeWidth) : 1,
|
||
strokeStyle: null != i.strokeStyle ? i.strokeStyle : void 0,
|
||
textAlign: null != i.textAlign ? i.textAlign : "center",
|
||
textBaseline: null != i.textBaseline ? i.textBaseline : "middle",
|
||
paddingV: null != i.paddingV ? parseInt(i.paddingV) : 1,
|
||
lineHeight: null != i.lineHeight ? parseInt(i.lineHeight) : 1,
|
||
paddingH: null != i.paddingH ? parseInt(i.paddingH) : 2,
|
||
positioning: null != i.positioning ? i.positioning : "top-left",
|
||
anchor: null != i.anchor ? i.anchor : [.5, 1],
|
||
offset: null != i.offset ? i.offset : [0, 0],
|
||
gap: null != i.gap ? i.gap : 2
|
||
};
|
||
this.map_ = null, this.position_ = [0, 0], this.positioning_ = r.positioning, this.offset_ = r.offset, this.isShow = !0, this.setStyle(this.styleFunction.bind(this)), i.draggable && this.set("draggable", i.draggable)
|
||
}
|
||
|
||
formatFont(t, e) {
|
||
return t + "px " + e
|
||
}
|
||
|
||
styleFunction(t, e) {
|
||
if (!this.isShow) return null;
|
||
var i, r = this.getDefaultStyle_(), o = this.calcWidthOfTitle(this.getTitle()), n = this.offset_[0],
|
||
s = this.offset_[1], a = o + Number(r.paddingH) + Math.abs(n),
|
||
l = Math.ceil(parseFloat(r.fontSize) * parseFloat(r.lineHeight)) + Math.abs(s),
|
||
h = document.createElement("canvas"), u = ol.render.toContext(h.getContext("2d"), {size: [a, l]}),
|
||
c = new ol.style.Fill({color: r.fillColor});
|
||
i = r.isStroke ? new ol.style.Stroke({
|
||
color: r.strokeColor,
|
||
width: r.strokeWidth,
|
||
lineDash: r.strokeStyle
|
||
}) : new ol.style.Stroke({
|
||
color: r.fillColor,
|
||
width: 1,
|
||
lineDash: void 0
|
||
}), u.setFillStrokeStyle(c, i), u.setTextStyle(null);
|
||
var p = n > 0 ? n : 0, d = s > 0 ? s : 0, f = o + Number(r.paddingH) + p,
|
||
g = Math.ceil(parseFloat(r.fontSize) * parseFloat(r.lineHeight));
|
||
return u.drawPolygon(new ol.geom.Polygon([[[p, d], [f, d], [f, g], [p, g], [p, d]]])), u.setTextStyle(new ol.style.Text({
|
||
text: this.getTitle().trim(),
|
||
font: this.formatFont(r.fontSize, r.font),
|
||
textAlign: "center",
|
||
textBaseline: "middle",
|
||
fill: new ol.style.Fill({color: r.fontColor})
|
||
})), u.drawPoint(new ol.geom.Point([p + Math.ceil((o + Number(r.paddingH)) / 2), d + Math.ceil(g / 2)])), new ol.style.Style({
|
||
image: new ol.style.Icon({
|
||
img: h,
|
||
imgSize: [h.width, h.height],
|
||
anchor: r.anchor
|
||
})
|
||
})
|
||
}
|
||
|
||
getDefaultStyle_() {
|
||
return this.defaultStyle_
|
||
}
|
||
|
||
calcWidthOfTitle(t) {
|
||
var e = t.trim(), i = this.getDefaultStyle_(), r = document.createElement("canvas").getContext("2d");
|
||
return r.font = this.formatFont(i.fontSize, i.font), r.measureText(e).width
|
||
}
|
||
|
||
getTitle() {
|
||
return this.title_
|
||
}
|
||
|
||
show() {
|
||
this.isShow = !0, this.map_.getMarkerLayers().getLayers().forEach(function (t, e, i) {
|
||
"marker_default" === t.get("name") && t.getSource().refresh()
|
||
})
|
||
}
|
||
|
||
hide() {
|
||
this.isShow = !1, this.map_.getMarkerLayers().getLayers().forEach(function (t, e, i) {
|
||
"marker_default" === t.get("name") && t.getSource().refresh()
|
||
})
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t;
|
||
var e = t.getMarkerLayers(), i = this;
|
||
e.getLayers().forEach(function (t, e, r) {
|
||
"marker_default" === t.get("name") && t.getSource().addFeature(i)
|
||
})
|
||
}
|
||
|
||
onRemove(t) {
|
||
this.map_ = null;
|
||
var e = t.getMarkerLayers(), i = this;
|
||
e.getLayers().forEach(function (t, e, r) {
|
||
"marker_default" === t.get("name") && t.getSource().removeFeature(i)
|
||
})
|
||
}
|
||
|
||
setPosition(t) {
|
||
this.position_ = t instanceof rC ? t.getCoordinate() : t, this.getGeometry().setCoordinates(this.position_)
|
||
}
|
||
|
||
setOffset(t) {
|
||
this.offset_ = t, this.changed()
|
||
}
|
||
};
|
||
var SC = class extends ol.Object {
|
||
constructor(t, e, i) {
|
||
super(), this.type = t, this.map_ = e, this.fn_ = i, this.callbackData = null, this.sketch = null, this.sketchStyle = new ol.style.Style({
|
||
fill: new ol.style.Fill({color: "rgba(67, 78, 255, 0.3)"}),
|
||
stroke: new ol.style.Stroke({color: "rgba(67, 78, 255, 0.8)", width: 2})
|
||
}), this.helpTooltipElement = null, this.helpTooltip = null, this.measureTooltipElement = null, this.measureTooltip = null, this.continuePolygonMsg = "点击右键结束测量", this.continueLineMsg = "点击右键结束测量", this.vectorLayer = null, this.draw = null, this.listener = null, this.wgs84radius = 6378137, this.closeBtn = null, this.init()
|
||
}
|
||
|
||
init() {
|
||
var t, e = this.map_;
|
||
if (e.getMarkerLayers().getLayers().forEach(function (e, i, r) {
|
||
"marker_default" === e.get("name") && (t = e)
|
||
}), !t) throw new Error("不能获取到默认的marker图层");
|
||
this.vectorLayer = t, this.draw = this.createInteraction(this.type), e.addInteraction(this.draw), this.createHelpTooltip(), this.createMeasureTooltip(), this.draw.once("drawstart", this.onStartDraw.bind(this), this), this.draw.once("drawend", this.onEndDraw.bind(this), this), e.on("pointermove", this.handlePointerMove.bind(this), this), e.getViewport().addEventListener("mouseout", function (t) {
|
||
this.addClass(this.helpTooltipElement, "hidden")
|
||
}.bind(this))
|
||
}
|
||
|
||
de_init() {
|
||
var t = this.map_;
|
||
t.removeInteraction(this.draw), t.removeOverlay(this.helpTooltip, !0), t.removeOverlay(this.measureTooltip, !0), this.draw.un("drawstart", this.onStartDraw.bind(this), this), this.draw.un("drawend", this.onEndDraw.bind(this), this), t.un("pointermove", this.handlePointerMove, this), t.getViewport().removeEventListener("mouseout", function (t) {
|
||
this.addClass(this.helpTooltipElement, "hidden")
|
||
}.bind(this))
|
||
}
|
||
|
||
disposeAll() {
|
||
var t = this.vectorLayer.getSource();
|
||
this.waitSketch && (t.removeFeature(this.waitSketch), this.waitSketch = null);
|
||
var e = this.map_;
|
||
e.removeOverlay(this.measureTooltip, !0), e.removeOverlay(this.HelpTooltip, !0), e.removeOverlay(this.closeBtn, !0)
|
||
}
|
||
|
||
handlePointerMove(t) {
|
||
if (!t.dragging) {
|
||
var e = "点击开始绘制与测量";
|
||
if (this.sketch) {
|
||
var i = this.sketch.getGeometry();
|
||
i instanceof ol.geom.Polygon ? e = this.continuePolygonMsg : i instanceof ol.geom.LineString && (e = this.continueLineMsg)
|
||
}
|
||
this.helpTooltipElement.innerHTML = e, this.helpTooltip.setPosition(t.coordinate), this.addClass(this.helpTooltipElement, "hidden")
|
||
}
|
||
}
|
||
|
||
createInteraction(t) {
|
||
return new ol.interaction.Draw2({
|
||
source: this.vectorLayer.getSource(),
|
||
type: t,
|
||
style: new ol.style.Style({
|
||
fill: new ol.style.Fill({color: "rgba(67, 78, 255, 0.3)"}),
|
||
stroke: new ol.style.Stroke({color: "rgba(67, 78, 255, 0.8)", width: 2})
|
||
}),
|
||
tip: !1
|
||
})
|
||
}
|
||
|
||
onStartDraw(t) {
|
||
var e = this.sketch = t.feature, i = t.coordinate;
|
||
this.listener = e.getGeometry().on("change", function (t) {
|
||
var e, r = t.target;
|
||
r instanceof ol.geom.Polygon ? (e = this.formatArea(r), i = r.getInteriorPoint().getCoordinates()) : r instanceof ol.geom.LineString && (e = this.formatLength(r), i = r.getLastCoordinate()), this.measureTooltipElement.innerHTML = e, this.measureTooltip.setPosition(i)
|
||
}.bind(this))
|
||
}
|
||
|
||
onEndDraw(t) {
|
||
this.measureTooltipElement.className = "tooltip tooltip-static", this.measureTooltip.setOffset([0, -7]), this.sketch.setStyle(this.sketchStyle), this.measureTooltipElement = null, this.fn_(this.callbackData), this.createCloseBtn();
|
||
var e = t.feature;
|
||
this.vectorLayer.getSource().addFeature(e), this.waitSketch = this.sketch, this.sketch = null, this.deleteHandleOfMeasure()
|
||
}
|
||
|
||
createCloseBtn() {
|
||
var t = document.createElement("div");
|
||
t.className = "close", this.closeBtn = new ol.Overlay({
|
||
element: t,
|
||
offset: [0, 5],
|
||
positioning: "top-center"
|
||
}), this.map_.addOverlay(this.closeBtn, !0);
|
||
var e, i = this.sketch.getGeometry();
|
||
i instanceof ol.geom.LineString ? e = i.getLastCoordinate() : i instanceof ol.geom.Polygon && (e = i.getInteriorPoint().getCoordinates()), this.closeBtn.setPosition(e), t.addEventListener("click", function () {
|
||
this.disposeAll()
|
||
}.bind(this))
|
||
}
|
||
|
||
deleteHandleOfMeasure() {
|
||
var t = this.map_;
|
||
t.removeOverlay(this.helpTooltip, !0), N(this.listener), t.removeInteraction(this.draw), this.draw = null, t.un("pointermove", this.handlePointerMove, this), t.getViewport().removeEventListener("mouseout", function (t) {
|
||
Ez.utility.Measure.addClass(this.helpTooltipElement, "hidden")
|
||
}.bind(this))
|
||
}
|
||
|
||
createMeasureTooltip() {
|
||
this.measureTooltipElement && this.measureTooltipElement.parentNode.removeChild(this.measureTooltipElement), this.measureTooltipElement = document.createElement("div"), this.measureTooltipElement.className = "tooltip tooltip-measure", this.measureTooltip = new ol.Overlay({
|
||
element: this.measureTooltipElement,
|
||
offset: [0, -15],
|
||
positioning: "bottom-center"
|
||
}), this.map_.addOverlay(this.measureTooltip, !0)
|
||
}
|
||
|
||
createHelpTooltip() {
|
||
this.helpTooltipElement && this.helpTooltipElement.parentNode.removeChild(this.helpTooltipElement), this.helpTooltipElement = document.createElement("div"), this.helpTooltipElement.className = "tooltip hidden", this.helpTooltip = new ol.Overlay({
|
||
element: this.helpTooltipElement,
|
||
offset: [15, 0],
|
||
positioning: "center-left"
|
||
}), this.map_.addOverlay(this.helpTooltip, !0)
|
||
}
|
||
|
||
formatArea(t) {
|
||
var e, i, r = this.map_.getView().getProjection();
|
||
return t.clone().transform(r, "EPSG:4326").getLinearRing(0).getCoordinates(), e = Math.abs(fe(t, {radius: this.wgs84radius})), i = Math.round(1e4 * e) + " km<sup>2</sup>", this.callbackData = {
|
||
value: e,
|
||
pretty: i
|
||
}, i
|
||
}
|
||
|
||
formatLength(t) {
|
||
var e, i = t.getCoordinates();
|
||
e = 0;
|
||
for (var r, o = this.map_.getView().getProjection(), n = 0, s = i.length - 1; n < s; ++n) e += ce(ol.proj.transform(i[n], o, "EPSG:4326"), ol.proj.transform(i[n + 1], o, "EPSG:4326"), this.wgs84radius);
|
||
return r = e > 100 ? Math.round(e / 1e3 * 100) / 100 + " km" : Math.round(100 * e) / 100 + " m", this.callbackData = {
|
||
value: e,
|
||
pretty: r
|
||
}, r
|
||
}
|
||
|
||
addClass(t, e) {
|
||
var i = " " + e.trim();
|
||
t.className += i
|
||
}
|
||
|
||
removeClass(t, e) {
|
||
for (var i = t.className.split(" "), r = 0; r < i.length; r++) if (i[r] === e) {
|
||
i[r] = "";
|
||
break
|
||
}
|
||
var o = i.join(" ");
|
||
t.className = o
|
||
}
|
||
};
|
||
var EC = {
|
||
mapCenter: !0,
|
||
mapInitLevel: !0,
|
||
constrainRotation: !0,
|
||
enableRotation: !0,
|
||
extent: !0,
|
||
minResolution: !0,
|
||
maxResolution: !0,
|
||
mapMinLevel: !0,
|
||
mapMaxLevel: !0,
|
||
projection: !0,
|
||
resolution: !0,
|
||
resolutions: !0,
|
||
rotation: !0,
|
||
zoomFactor: !0
|
||
};
|
||
|
||
class TC extends ol.Map {
|
||
constructor(t, e) {
|
||
var i = {}, r = {};
|
||
for (var o in e) o in EC ? "mapCenter" === o ? e[o] instanceof rC ? i.center = [e[o].x, e[o].y] : i.center = e[o] : "mapInitLevel" === o ? i.zoom = e[o] : "mapMinLevel" === o ? i.minZoom = e[o] : "mapMaxLevel" === o ? i.maxZoom = e[o] : i[o] = e[o] : r[o] = e[o];
|
||
var n = window.ezMap;
|
||
null != n && (null != e && null != e.indoor && e.indoor || (i.minZoom = n.MapMinLevel, i.maxZoom = n.MapMaxLevel, i.zoom = n.MapInitLevel, i.center = n.CenterPoint, i.extent = n.MapFullExtent, i.projection = "EPSG:" + n.MapSrcURL[0][2].crs, "EzMap2010" !== n.MapSrcURL[0][2].type && "EzMap2010Local" !== n.MapSrcURL[0][2].type || (i.resolutions = EzMap2010.getResolutions(n.MapMinLevel, n.MapMaxLevel))));
|
||
var s = new ol.View(i), a = null != t ? t : void 0, l = new ol.layer.Group({layers: []});
|
||
l.set("title", "baseLayers");
|
||
var h = new ol.layer.Group({layers: []});
|
||
h.set("title", "markerLayers");
|
||
var u = new ol.layer.Vector({source: new ol.source.Vector({wrapX: !1}), projection: s.getProjection()});
|
||
u.set("name", "marker_default"), h.getLayers().push(u);
|
||
var c = new ol.layer.Group({layers: []});
|
||
c.set("title", "vectorLayers");
|
||
var p = new ol.layer.Vector({source: new ol.source.Vector({wrapX: !1}), projection: s.getProjection()});
|
||
p.set("name", "vector_default"), c.getLayers().push(p);
|
||
var d = new ol.layer.Group({layers: []});
|
||
d.set("title", "customLayers");
|
||
var f = new ol.layer.Group({layers: []});
|
||
f.set("title", "tileOverlayLayers");
|
||
var g = [l, f, c, d, h];
|
||
null == r.logo && (r.logo = !1), r.layers = g, r.target = a, r.view = s, r.controls = ol.control.util.defaults({
|
||
attribution: !1,
|
||
rotate: !1,
|
||
zoom: !1
|
||
}), null != n && (null != e && null != e.indoor && e.indoor || (r.loadTilesWhileAnimating = null != n.loadTilesWhileAnimating && n.loadTilesWhileAnimating)), super(r), this.defaultMarkerLayer_ = u, this.defaultVectorLayer_ = p, this.tileLayerOverlayGroup_ = f, this.customLayerGroup_ = d, this.vectorLayerGroup_ = c, this.tileLayerGroup_ = l, this.markerLayerGroup_ = h, this.viewOfEz_ = s, this.elementOfEz_ = a, this.maxZoom_ = i.maxZoom, this.minZoom_ = i.minZoom;
|
||
var m = e || {};
|
||
if (null != m.appkeys) for (var y = m.appkeys, v = 0; v < y.length; v++) {
|
||
var _ = y[v];
|
||
_ && (n.MapSrcURL[v][2].appkey = _)
|
||
}
|
||
null != n && (this.global_ = new Ez.Global(n, this))
|
||
}
|
||
|
||
getTileLayers() {
|
||
return this.tileLayerGroup_
|
||
}
|
||
|
||
getTileLayerOverlayLayers() {
|
||
return this.tileLayerOverlayGroup_
|
||
}
|
||
|
||
getMarkerLayers() {
|
||
return this.markerLayerGroup_
|
||
}
|
||
|
||
getVectorLayers() {
|
||
return this.vectorLayerGroup_
|
||
}
|
||
|
||
getCustomLayers() {
|
||
return this.customLayerGroup_
|
||
}
|
||
|
||
getDegree(t, e) {
|
||
var i = t.getCoordinate();
|
||
return 1 * e / ce(i, [parseFloat(i[0]) + 1, i[1]], 6378137)
|
||
}
|
||
|
||
pixeldistance2KMdistance(t) {
|
||
return t * this.viewOfEz_.getResolution()
|
||
}
|
||
|
||
addLayer(t, e) {
|
||
e ? super.addLayer(t) : t.onAdd(this)
|
||
}
|
||
|
||
addlayer(t, e) {
|
||
e ? super.addLayer(t) : t.onAdd(this)
|
||
}
|
||
|
||
removeLayer(t, e) {
|
||
e ? super.removeLayer(t) : t.onRemove(this)
|
||
}
|
||
|
||
removelayer(t, e) {
|
||
e ? super.removeLayer(t) : t.onRemove(this)
|
||
}
|
||
|
||
addOverlay(t, e) {
|
||
e ? super.addOverlay(t) : (t.onAdd(this), t instanceof bC ? super.addOverlay(t) : t instanceof mC && super.addOverlay(t))
|
||
}
|
||
|
||
addoverlay(t, e) {
|
||
e ? super.addOverlay(t) : (t.onAdd(this), t instanceof bC ? super.addOverlay(t) : t instanceof mC && super.addOverlay(t))
|
||
}
|
||
|
||
removeOverlay(t, e) {
|
||
e ? super.removeOverlay(t) : (t.onRemove(this), t instanceof bC ? super.removeOverlay(t) : t instanceof mC && super.removeOverlay(t))
|
||
}
|
||
|
||
removeoverlay(t, e) {
|
||
e ? super.removeOverlay(t) : (t.onRemove(this), t instanceof bC ? super.removeOverlay(t) : t instanceof mC && super.removeOverlay(t))
|
||
}
|
||
|
||
getCenter() {
|
||
var t = this.viewOfEz_.getCenter();
|
||
return new rC(t[0], t[1])
|
||
}
|
||
|
||
zoomIn() {
|
||
this.viewOfEz_.getResolution() <= this.viewOfEz_.minResolution_ || this.doZoom(this.viewOfEz_.getZoom() + 1)
|
||
}
|
||
|
||
zoomOut() {
|
||
this.viewOfEz_.getResolution() >= this.viewOfEz_.maxResolution_ || this.doZoom(this.viewOfEz_.getZoom() - 1)
|
||
}
|
||
|
||
getZoom() {
|
||
return this.viewOfEz_.getZoom()
|
||
}
|
||
|
||
doZoom(t) {
|
||
this.viewOfEz_.animate({zoom: t, duration: 250})
|
||
}
|
||
|
||
showStandMapControl(t) {
|
||
if (!this.zoomslider_) {
|
||
var e = this.global_.getGlobalOptions(), i = vC.isDef(e) ? e : {};
|
||
t = vC.isDef(t) ? t : {};
|
||
var r = vC.isDef(i.MapMaxLevel) ? i.MapMaxLevel : vC.isDef(t.maxZoom) ? t.maxZoom : 18,
|
||
o = vC.isDef(i.MapMinLevel) ? i.MapMinLevel : vC.isDef(t.minZoom) ? t.minZoom : 0,
|
||
n = vC.isDef(i.isTitleArea) ? i.isTitleArea : !!vC.isDef(t.isTitleArea) && t.isTitleArea,
|
||
s = vC.isDef(i.flag2level) ? i.flag2level : vC.isDef(t.flag2level) ? t.flag2level : void 0;
|
||
this.zoomslider_ = new Ez.controls.ZoomSlider({
|
||
maxZoom: r,
|
||
minZoom: o,
|
||
isTitleArea: n,
|
||
flag2level: s
|
||
}), this.addControl(this.zoomslider_)
|
||
}
|
||
}
|
||
|
||
showMapControl(t) {
|
||
if (!this.navi_ && !this.zoomslider_) {
|
||
var e = this.global_.getGlobalOptions(), i = null != e ? e : {};
|
||
t = null != t ? t : {};
|
||
var r = null != i.MapMaxLevel ? i.MapMaxLevel : null != t.maxZoom ? t.maxZoom : 18,
|
||
o = null != i.MapMinLevel ? i.MapMinLevel : null != t.minZoom ? t.minZoom : 0,
|
||
n = null != i.isTitleArea ? i.isTitleArea : null != t.isTitleArea && t.isTitleArea,
|
||
s = null != i.flag2level ? i.flag2level : null != t.flag2level ? t.flag2level : void 0;
|
||
this.zoomslider_ = new Ez.controls.ZoomSlider({
|
||
maxZoom: r,
|
||
minZoom: o,
|
||
isTitleArea: n,
|
||
flag2level: s
|
||
}), this.addControl(this.zoomslider_), this.navi_ = new Ez.controls.NavBar, this.addControl(this.navi_)
|
||
}
|
||
}
|
||
|
||
hideMapControl() {
|
||
this.navi_ && (this.removeControl(this.navi_), this.navi_ = null), this.zoomslider_ && (this.removeControl(this.zoomslider_), this.zoomslider_ = null)
|
||
}
|
||
|
||
showSimpleZoomControl() {
|
||
this.simplezoom_ || (this.simplezoom_ = new Ez.controls.SimpleZoom, this.addControl(this.simplezoom_))
|
||
}
|
||
|
||
hideSimpleZoomControl() {
|
||
this.simplezoom_ && (this.removeControl(this.simplezoom_), delete this.simplezoom_)
|
||
}
|
||
|
||
initLayersControl() {
|
||
var t = this.getConfig().getLayersInfo(), e = new Ez.controls.SimpleLayers(t);
|
||
this.layersControl_ = e, this.addControl(e), e.changed(), document.getElementById("ez_simple_layers").style.display = "none"
|
||
}
|
||
|
||
showLayersControl(t) {
|
||
var e, i, r = this.getConfig().getLayersInfo(), o = "default";
|
||
switch (t && (r = (e = t(r, o)).layerInfo, o = e.type), o) {
|
||
case"default":
|
||
i = new Ez.controls.Layers(r);
|
||
break;
|
||
case"simple":
|
||
i = new Ez.controls.SimpleLayers(r)
|
||
}
|
||
this.addControl(i), this.layersControl_ = i, "default" === o ? i.refesh() : i.changed()
|
||
}
|
||
|
||
hideLayersControl() {
|
||
this.removeControl(this.layersControl_), delete this.layersControl_
|
||
}
|
||
|
||
getConfig() {
|
||
return this.global_
|
||
}
|
||
|
||
addMapEventListener(t, e, i) {
|
||
return aC.MAP_ZOOMCHANGE === t ? this.viewOfEz_.on(t, e, i) : this.on(t, e, i)
|
||
}
|
||
|
||
addMapEventListenerOnce(t, e, i) {
|
||
return aC.MAP_ZOOMCHANGE === t ? this.viewOfEz_.once(t, e, i) : this.once(t, e, i)
|
||
}
|
||
|
||
removeMapEventListener(t) {
|
||
this.unByKey(t)
|
||
}
|
||
|
||
centerAtLatlng(t, e) {
|
||
var i;
|
||
t instanceof rC && (i = t.getCoordinate()), vC.isDef(e) && ("number" != typeof t && "string" != typeof t || (i = [parseFloat(t), parseFloat(e)])), i || ol.asserts.assert(!1, "参数类型不正确或者输入格式有误"), this.viewOfEz_.setCenter(i)
|
||
}
|
||
|
||
showScaleControl() {
|
||
this.scale_ || (this.scale_ = new Ez.controls.ScaleLine, this.addControl(this.scale_))
|
||
}
|
||
|
||
hideScaleControl() {
|
||
this.removeControl(this.scale_), delete this.scale_
|
||
}
|
||
|
||
showOverviewControl() {
|
||
this.overview_ || (this.overview_ = new Ez.controls.Overview, this.addControl(this.overview_))
|
||
}
|
||
|
||
hideOverviewControl() {
|
||
this.removeControl(this.overview_), delete this.overview_
|
||
}
|
||
|
||
centerAndZoom(t, e) {
|
||
ol.asserts.assert(null != t, "缩放级别不能为undefined"), ol.asserts.assert(t instanceof rC, "point 参数必须为EzCoord类型");
|
||
var i = t.getCoordinate();
|
||
ol.asserts.assert(null != e, "缩放级别不能为undefined"), ol.asserts.assert("number" == typeof e, "缩放级别必须为数值类型"), this.viewOfEz_.setCenter(i), this.viewOfEz_.setZoom(e)
|
||
}
|
||
|
||
centerAtMBR(t) {
|
||
if (t instanceof EzMBR) var e = t.value_; else {
|
||
ol.asserts.assert(Array.isArray(t), "目标包络框类型错误");
|
||
e = t
|
||
}
|
||
var i = this.getSize();
|
||
this.viewOfEz_.fit(e, i)
|
||
}
|
||
|
||
zoomTo(t) {
|
||
ol.asserts.assert(null != t, "缩放级别不能为undefined"), ol.asserts.assert("number" == typeof t, "缩放级别必须为数值类型"), this.viewOfEz_.setZoom(t)
|
||
}
|
||
|
||
measureLine(t, e) {
|
||
var i = [];
|
||
if (t instanceof Array) i = t; else for (var r = (t = t.replace(/,$/, "")).split(","), o = 0; o < r.length / 2; o++) {
|
||
var n = [r[2 * o], r[2 * o + 1]];
|
||
i[o] = n
|
||
}
|
||
for (var s = 0, a = (new ol.Sphere(6378137), this.getView().getProjection()), l = (o = 0, i.length - 1); o < l; ++o) {
|
||
s += ce(ol.proj.transform(i[o], a, "EPSG:4326"), ol.proj.transform(i[o + 1], a, "EPSG:4326"), 6378137)
|
||
}
|
||
return e ? Math.round(100 * s) / 100 : s > 100 ? Math.round(s / 1e3 * 100) / 100 + " km" : Math.round(100 * s) / 100 + " m"
|
||
}
|
||
|
||
changeDragMode(t, e, i, r, o) {
|
||
var n;
|
||
switch (t) {
|
||
case"drawPoint":
|
||
this.drawType_("Point"), n = Ez.g.Point;
|
||
break;
|
||
case"drawPolyline":
|
||
this.drawType_("LineString"), n = Ez.g.Polyline;
|
||
break;
|
||
case"drawPolygon":
|
||
this.drawType_("Polygon"), n = Ez.g.Polygon;
|
||
break;
|
||
case"drawCircle":
|
||
this.drawType_("Circle"), n = Ez.g.Circle;
|
||
break;
|
||
case"drawRect":
|
||
this.drawType_("Rect"), n = Ez.g.Rectangle;
|
||
break;
|
||
case"measureLine":
|
||
return void (null == this.draw_ ? this.draw_ = new SC("LineString", this, e) : this.draw_ instanceof ol.interaction.Draw2 ? (this.removeInteraction(this.draw_), this.draw_ = new SC("LineString", this, e)) : (this.draw_.draw && this.draw_.de_init(), this.draw_ = new SC("LineString", this, e)));
|
||
case"measureArea":
|
||
return void (null == this.draw_ ? this.draw_ = new SC("Polygon", this, e) : this.draw_ instanceof ol.interaction.Draw2 ? (this.removeInteraction(this.draw_), this.draw_ = new SC("Polygon", this, e)) : (this.draw_.draw && this.draw_.de_init(), this.draw_ = new SC("Polygon", this, e)));
|
||
case"editGeometry":
|
||
if ("on" === r) {
|
||
if (!i) return;
|
||
this.draw_ = new ol.interaction.Modify({features: new ol.Collection([i])}), this.addInteraction(this.draw_);
|
||
break
|
||
}
|
||
var s = i.getGeometry().getCoordinates().map(function (t) {
|
||
return t.join(",")
|
||
});
|
||
i.coordString = s.join(","), e(i), this.removeInteraction(this.draw_), this.draw_ = void 0;
|
||
break;
|
||
case"editCircle":
|
||
if ("on" === r) {
|
||
if (!i) return;
|
||
this.draw_ = new ol.interaction.EditCircle(i, e, o), this.addInteraction(this.draw_);
|
||
break
|
||
}
|
||
this.draw_.disposeAll(e), this.removeInteraction(this.draw_), this.draw_ = void 0
|
||
}
|
||
var a = this;
|
||
null != e && "editGeometry" !== t && "editCircle" !== t && this.draw_.on("drawend", function (t) {
|
||
var i = t.feature.getGeometry();
|
||
if ("Circle" === i.getType()) {
|
||
var r = i.getCenter(), o = i.getRadius(), s = r;
|
||
o *= ce(s, [s[0] + 1, s[1]]);
|
||
var l = new n(new rC(r[0], r[1]), o)
|
||
} else if ("Point" === i.getType()) r = i.getCoordinates(), l = new n(new rC(r[0], r[1])); else r = i.getCoordinates(), l = new n(r);
|
||
e(l), a.removeInteraction(a.draw_), a.draw_ = void 0
|
||
})
|
||
}
|
||
|
||
clearDragMode() {
|
||
this.draw_ && (this.draw_ instanceof ol.interaction.Draw2 ? (this.removeInteraction(this.draw_), delete this.draw_) : this.draw_.draw && (this.draw_.de_init(), delete this.draw_))
|
||
}
|
||
|
||
drawType_(t) {
|
||
var e = {};
|
||
"Rect" === t ? (e.type = "LineString", e.source = this.defaultVectorLayer_.getSource(), e.maxPoints = 2, e.geometryFunction = function (t, e) {
|
||
var i = t[0], r = t[1];
|
||
return e || (e = new ol.geom.Polygon([[i, [i[0], r[1]], r, [r[0], i[1]], i]])), e.setCoordinates([[i, [i[0], r[1]], r, [r[0], i[1]], i]]), e
|
||
}) : (e.type = t, e.source = this.defaultVectorLayer_.getSource()), null == this.draw_ ? (this.draw_ = new ol.interaction.Draw2(e), this.addInteraction(this.draw_)) : this.draw_ instanceof ol.interaction.Draw2 ? (this.removeInteraction(this.draw_), this.draw_ = new ol.interaction.Draw2(e), this.addInteraction(this.draw_)) : (this.draw_.draw && this.draw_.de_init(), this.draw_ = new ol.interaction.Draw2(e), this.addInteraction(this.draw_))
|
||
}
|
||
|
||
animationTo(t, e, i) {
|
||
var r = this.viewOfEz_, o = vC.isDef(i) && vC.isDef(i.duration) ? i.duration : 2e3;
|
||
r.getCenter();
|
||
if ("fly" === e) {
|
||
var n = r.getZoom();
|
||
r.animate({center: t.getCoordinate(), duration: o}), r.animate({
|
||
zoom: n - 1,
|
||
duration: o / 2
|
||
}, {zoom: n, duration: o / 2})
|
||
} else if ("spiral" === e) {
|
||
var s = r.getCenter();
|
||
r.animate({
|
||
center: [s[0] + (t.getCoordinate()[0] - s[0]) / 2, s[1] + (t.getCoordinate()[1] - s[1]) / 2],
|
||
rotation: Math.PI,
|
||
easing: Po
|
||
}, {center: t.getCoordinate(), rotation: 2 * Math.PI, easing: Lo})
|
||
} else r.animate({center: t.getCoordinate(), duration: o})
|
||
}
|
||
|
||
zoomAnimationTo(t, e) {
|
||
var i = vC.isDef(e) ? e : {};
|
||
this.viewOfEz_.animate({
|
||
zoom: t,
|
||
duration: null != i.duration ? i.duration : 2e3,
|
||
easing: null != i.easing ? i.easing : ol.easing.inAndOut
|
||
})
|
||
}
|
||
|
||
openInfoWindow(t, e, i) {
|
||
var r;
|
||
e instanceof rC ? r = e.getCoordinate() : Array.isArray(e) ? r = e : ol.asserts.assert(!1, "参数类型不正确或者输入格式有误"), this.popup_ && (this.removeOverlay(this.popup_), this.popup_ = null), this.popup_ = new bC(i), this.popup_.on("CLOSE", this.assignPopup2null_.bind(this)), this.addOverlay(this.popup_), this.popup_.show(t, r)
|
||
}
|
||
|
||
assignPopup2null_() {
|
||
this.popup_ = null
|
||
}
|
||
|
||
closeInfoWindow() {
|
||
this.popup_ && this.popup_.close()
|
||
}
|
||
|
||
getBoundsLatLng() {
|
||
var t = this.viewOfEz_.calculateExtent(this.getSize());
|
||
return new EzMBR(t[0], t[1], t[2], t[3])
|
||
}
|
||
|
||
clear() {
|
||
var t = this.getLayers(), e = this;
|
||
t.forEach(function (t, i, r) {
|
||
"baseLayers" !== t.get("title") && (t instanceof ol.layer.Group ? t.getLayers().forEach(function (t) {
|
||
t instanceof Ez.TileLayer.SingleHotSpot ? t.onRemove ? e.removeLayer(t) : e.removeLayer(t, !0) : t.getSource().clear()
|
||
}) : t.getSource().clear())
|
||
});
|
||
var i = this.getOverlays();
|
||
0 !== i.getLength() && i.clear()
|
||
}
|
||
|
||
draggable() {
|
||
this.dragfeatureinteraction = new ol.interaction.DragFeature, this.addInteraction(this.dragfeatureinteraction)
|
||
}
|
||
|
||
disdraggable() {
|
||
this.removeInteraction(this.dragfeatureinteraction), delete this.dragfeatureinteraction
|
||
}
|
||
|
||
enabledblZoom() {
|
||
this.dblzoominteraction && !this.dblzoominteraction.isOnMap && this.dblzoominteraction.interaction && (this.addInteraction(this.dblzoominteraction.interaction), this.dblzoominteraction.isOnMap = !0)
|
||
}
|
||
|
||
disabledblZoom() {
|
||
if (!this.dblzoominteraction) {
|
||
var t = this.getInteractions();
|
||
this.dblzoominteraction = {interaction: null, isOnMap: null};
|
||
var e = this;
|
||
t.forEach(function (t) {
|
||
t instanceof ol.interaction.DoubleClickZoom && (e.dblzoominteraction.interaction = t)
|
||
})
|
||
}
|
||
this.removeInteraction(this.dblzoominteraction.interaction), this.dblzoominteraction.isOnMap = !1
|
||
}
|
||
|
||
getAllFeaturesFromMap() {
|
||
var t = [], e = [];
|
||
t = t.concat(this.getOverlays().getArray()), this.getMarkerLayers().getLayers().getArray().forEach(function (e) {
|
||
t = t.concat(e.getSource().getFeatures())
|
||
}), this.getVectorLayers().getLayers().getArray().forEach(function (e) {
|
||
t = t.concat(e.getSource().getFeatures())
|
||
});
|
||
var i = this.getTileLayers().getLayers().getArray();
|
||
return e = e.concat(i), {features: t, tile: e}
|
||
}
|
||
|
||
addLayerToContainer(t, e) {
|
||
e.getLayers().push(t)
|
||
}
|
||
|
||
removeFromContainer(t, e) {
|
||
e.getLayers().remove(t)
|
||
}
|
||
|
||
addScaleLineControl(t) {
|
||
this.scaleline_ = new Ez.controls.ScaleLine(t), map.addControl(this.scaleline_)
|
||
}
|
||
|
||
removeScaleLineControl() {
|
||
this.scaleline_ && (map.removeControl(this.scaleline_), delete this.scaleline_)
|
||
}
|
||
|
||
addOverviewControl(t) {
|
||
this.overview_ = new Ez.controls.Overview(t), map.addControl(this.overview_)
|
||
}
|
||
|
||
removeOverviewControl() {
|
||
this.overview_ && (map.removeControl(this.overview_), delete this.overview_)
|
||
}
|
||
|
||
calculateTileCount(t, e, i) {
|
||
for (var r = i || !0, o = t.getExtent(), n = new Array(22), s = 0; s <= 22; ++s) n[s] = 1.40625 / Math.pow(2, s);
|
||
var a = new ol.tilegrid.TileGrid({
|
||
resolutions: n,
|
||
origin: r ? [-180, 90] : [0, 0]
|
||
}).getTileRangeForExtentAndZ(o, e);
|
||
return (a.maxX - a.minX + 1) * (a.maxY - a.minY + 1)
|
||
}
|
||
|
||
getMaxZoom() {
|
||
return this.maxZoom_
|
||
}
|
||
|
||
getMinZoom() {
|
||
return this.minZoom_
|
||
}
|
||
|
||
getVersion() {
|
||
return "EzServerClient 8.0.0"
|
||
}
|
||
}
|
||
|
||
var RC = class {
|
||
constructor(t, e) {
|
||
this.map = t, this.loadJS(e, function () {
|
||
this.styleMap = Ez_style_styleJson
|
||
}.bind(this))
|
||
}
|
||
|
||
getStyles(t) {
|
||
var e = t.get("layer");
|
||
if (null == this.styleMap || null == e) return this.getDefaultStyles();
|
||
var i = this.styleMap[e];
|
||
if (i || (i = this.styleMap[e.toUpperCase()]), i) {
|
||
for (var r = [], o = this.map.getZoom(), n = 0, s = i.length; n < s; n++) {
|
||
var a = i[n];
|
||
if (!(a.minZoom > o || a.maxZoom < o)) {
|
||
var l = !1;
|
||
if ("" == a.ruleName) l = !0; else {
|
||
var h = t.get(a.ruleName);
|
||
h || (h = t.get(a.ruleName.toLowerCase())), h || (h = t.get(a.ruleName.toUpperCase())), a.ruleValue.split(",").forEach(function (t, e) {
|
||
t == h && (l = !0)
|
||
})
|
||
}
|
||
if (0 != l) {
|
||
var u = {}, c = a.zIndex;
|
||
c && (u.zIndex = c);
|
||
var p = a.fill;
|
||
p && (u.fill = new ol.style.Fill(this.getFillJson(p)));
|
||
var d = a.stroke;
|
||
d && (u.stroke = new ol.style.Stroke(this.getStrokeJson(d)));
|
||
var f = a.text;
|
||
f && (u.text = new ol.style.Text(this.getLabelJson(f, t)));
|
||
var g = a.image;
|
||
g && ("Circle" == g.type && (u.image = new ol.style.Circle(this.getCircleJson(g))), "Icon" == g.type && (u.image = new ol.style.Icon(this.getIconJson(g))), "RegularShape" == g.type && (u.image = new ol.style.RegularShape(this.getRegularShapeJson(g)))), r.push(new ol.style.Style(u))
|
||
}
|
||
}
|
||
}
|
||
return r
|
||
}
|
||
return this.getDefaultStyles()
|
||
}
|
||
|
||
getLabelStyles(t) {
|
||
var e = t.get("layer");
|
||
if (null == this.styleMap || null == e) return [];
|
||
var i = this.styleMap[e];
|
||
if (i || (i = this.styleMap[e.toUpperCase()]), i) {
|
||
for (var r = [], o = this.map.getZoom(), n = 0, s = i.length; n < s; n++) {
|
||
var a = i[n];
|
||
if (!(a.minZoom > o || a.maxZoom < o)) {
|
||
var l = !1;
|
||
if ("" == a.ruleName) l = !0; else {
|
||
var h = t.get(a.ruleName);
|
||
h || (h = t.get(a.ruleName.toLowerCase())), h || (h = t.get(a.ruleName.toUpperCase())), a.ruleValue.split(",").forEach(function (t, e) {
|
||
t == h && (l = !0)
|
||
})
|
||
}
|
||
if (0 != l) {
|
||
a.zIndex;
|
||
var u = a.text;
|
||
if (u) {
|
||
var c = new ol.style.Style({text: new ol.style.Text(this.getLabelJson(u, t))});
|
||
r.push(c)
|
||
}
|
||
}
|
||
}
|
||
}
|
||
return r
|
||
}
|
||
return []
|
||
}
|
||
|
||
getDefaultStyles() {
|
||
var t = new ol.style.Fill({color: "rgba(255,255,255,0.4)"}),
|
||
e = new ol.style.Stroke({color: "#3399CC", width: 1.25});
|
||
return [new ol.style.Style({
|
||
image: new ol.style.Circle({fill: t, stroke: e, radius: 5}),
|
||
fill: t,
|
||
stroke: e
|
||
})]
|
||
}
|
||
|
||
getFillJson(t) {
|
||
var e = {};
|
||
return t.color && (e.color = t.color), e
|
||
}
|
||
|
||
getStrokeJson(t) {
|
||
var e = {};
|
||
return t.color && (e.color = t.color), t.lineCap && (e.lineCap = t.lineCap), t.lineJoin && (e.lineJoin = t.lineJoin), t.lineDash && (e.lineDash = t.lineDash), t.miterLimit && (e.miterLimit = t.miterLimit), t.width && (e.width = t.width), e
|
||
}
|
||
|
||
getLabelJson(t, e) {
|
||
var i = {};
|
||
|
||
function r(t) {
|
||
return t * (Math.PI / 180)
|
||
}
|
||
|
||
if (t.font && (i.font = t.font), t.font && (i.font = t.font), t.offsetX && (i.offsetX = t.offsetX), t.offsetY && (i.offsetY = t.offsetY), t.scale && (i.scale = t.scale), t.rotateWithView && (i.rotateWithView = t.rotateWithView), t.placement && (i.placement = t.placement), e && e.flatCoordinates_ && "LineString" == e.type_ && (null == i.placement || null != i.placement && "line" != i.placement)) {
|
||
for (var o = e.flatCoordinates_, n = [], s = 0; s < o.length; s++) s % 2 == 0 && n.push([o[s], o[s + 1]]);
|
||
var a = map.getCoordinateFromPixel(n[0]), l = map.getCoordinateFromPixel(n[n.length - 1]);
|
||
i.rotation = -function (t, e, i) {
|
||
var o = t[0] > e[0] ? Math.PI : 0;
|
||
return function (t) {
|
||
return r((450 - t) % 360)
|
||
}(i) + o
|
||
}(a, l, function (t, e, i, o) {
|
||
t = r(t), e = r(e), i = r(i);
|
||
var n = (o = r(o)) - e,
|
||
s = Math.log(Math.tan(i / 2 + Math.PI / 4) / Math.tan(t / 2 + Math.PI / 4));
|
||
return Math.abs(n) > Math.PI && (n = n > 0 ? -(2 * Math.PI - n) : 2 * Math.PI + n), (Math.atan2(n, s) * (180 / Math.PI) + 360) % 360
|
||
}(a[1], a[0], l[1], l[0]))
|
||
} else t.rotation && (i.rotation = t.rotation);
|
||
return t.text && e && (e.get(t.text) || e.get(t.text.toLowerCase()) || e.get(t.text.toUpperCase())) && (i.text = e.get(t.text), i.text || (i.text = e.get(t.text.toLowerCase())), i.text || (i.text = e.get(t.text.toUpperCase()))), t.textAlign && (i.textAlign = t.textAlign), t.textBaseline && (i.textBaseline = t.textBaseline), t.fill && (i.fill = new ol.style.Fill(this.getFillJson(t.fill))), t.stroke && (i.stroke = new ol.style.Stroke(this.getStrokeJson(t.stroke))), t.backgroundFill && (i.backgroundFill = new ol.style.Fill(this.getFillJson(t.backgroundFill))), t.backgroundStroke && (i.backgroundStroke = new ol.style.Stroke(this.getStrokeJson(t.backgroundStroke))), i
|
||
}
|
||
|
||
getCircleJson(t) {
|
||
var e = {};
|
||
return t.fill && (e.fill = new ol.style.Fill(this.getFillJson(t.fill))), t.radius && (e.radius = t.radius), t.snapToPixel && (e.snapToPixel = t.snapToPixel), t.stroke && (e.stroke = new ol.style.Stroke(this.getStrokeJson(t.stroke))), t.atlasManager && (e.atlasManager = t.atlasManager), e
|
||
}
|
||
|
||
getIconJson(t) {
|
||
var e = {};
|
||
return t.anchor && (e.anchor = t.anchor), t.anchorOrigin && (e.anchorOrigin = t.anchorOrigin), t.anchorXUnits && (e.anchorXUnits = t.anchorXUnits), t.anchorYUnits && (e.anchorYUnits = t.anchorYUnits), t.crossOrigin && (e.crossOrigin = t.crossOrigin), t.img && (e.img = t.img), t.offset && (e.offset = t.offset), t.offsetOrigin && (e.offsetOrigin = t.offsetOrigin), t.opacity && (e.opacity = t.opacity), t.scale && (e.scale = t.scale), t.snapToPixel && (e.snapToPixel = t.snapToPixel), t.rotateWithView && (e.rotateWithView = t.rotateWithView), t.rotation && (e.rotation = t.rotation), t.size && (e.size = t.size), t.src && (e.src = t.src), e
|
||
}
|
||
|
||
getRegularShapeJson(t) {
|
||
var e = {};
|
||
return t.fill && (e.fill = new ol.style.Fill(this.getFillJson(t.fill))), t.points && (e.points = t.points), t.radius && (e.radius = t.radius), t.radius1 && (e.radius1 = t.radius1), t.radius2 && (e.radius2 = t.radius2), t.angle && (e.angle = t.angle), t.snapToPixel && (e.snapToPixel = t.snapToPixel), t.stroke && (e.stroke = new ol.style.Stroke(this.getStrokeJson(t.stroke))), t.rotation && (e.rotation = t.rotation), t.rotateWithView && (e.rotateWithView = t.rotateWithView), t.atlasManager && (e.atlasManager = t.atlasManager), e
|
||
}
|
||
|
||
changeSkill(t) {
|
||
if ("" != t) this.loadJS(t, function () {
|
||
this.styleMap = Ez_style_styleJson;
|
||
var t = map.tileLayerGroup_.values_.layers.array_;
|
||
for (var e in t) t[e] instanceof Ez.VectorLayer.WMTS_SL && (t[e].setJson2Style(this), t[e].setStyle(function (t) {
|
||
return this.getStyles(t)
|
||
}.bind(this)), t[e].changeSkill(!0))
|
||
}.bind(this)); else {
|
||
this.styleMap = [];
|
||
var e = map.tileLayerGroup_.values_.layers.array_;
|
||
for (var i in e) e[i] instanceof Ez.VectorLayer.WMTS_SL && (e[i].setJson2Style(this), e[i].setStyle(), e[i].changeSkill(!1))
|
||
}
|
||
}
|
||
|
||
loadJS(t, e) {
|
||
var i = document.createElement("script"), r = e || function () {
|
||
};
|
||
i.type = "text/javascript", i.readyState ? i.onreadystatechange = function () {
|
||
"loaded" != i.readyState && "complete" != i.readyState || (i.onreadystatechange = null, r())
|
||
} : i.onload = function () {
|
||
r()
|
||
}, i.src = t, document.getElementsByTagName("head")[0].appendChild(i)
|
||
}
|
||
};
|
||
var PC = class {
|
||
constructor(t, e, i) {
|
||
this.layer = t, this.sourceName = i, this.loadJSON(e)
|
||
}
|
||
|
||
loadJSON(t) {
|
||
var e = this, i = new XMLHttpRequest;
|
||
i.open("get", t), i.send(null), i.onload = function () {
|
||
if (200 == i.status) {
|
||
var t = JSON.parse(i.responseText);
|
||
console.log(t), olms.applyStyle(e.layer, t, e.sourceName, null, e.layer.getSource().getTileGrid().getResolutions())
|
||
}
|
||
}
|
||
}
|
||
|
||
changeSkill(t) {
|
||
this.loadJSON(t)
|
||
}
|
||
};
|
||
var LC = class extends ux {
|
||
constructor(t, e) {
|
||
var i = e || {}, r = {}, o = i.customOpts ? i.customOpts : null;
|
||
for (var n in i) "customOpts" !== i[n] && (r[n] = i[n]);
|
||
super(r), this.key_ = i.key, this.set("ezname", t), this.set("isAddToMap", !1), o && this.set("customOpts", o)
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t, t.getTileLayers().getLayers().push(this), this.set("isAddToMap", !0)
|
||
}
|
||
|
||
onRemove(t) {
|
||
this.get("isAddToMap") && (this.map_ = null, t.getTileLayers().getLayers().remove(this), this.set("isAddToMap", !1))
|
||
}
|
||
|
||
getResolutions() {
|
||
return this.getSource().getTileGrid().getResolutions()
|
||
}
|
||
};
|
||
var IC = class extends LC {
|
||
constructor(t, e, i) {
|
||
for (var r = i || {}, o = new Array(30), n = new Array(30), s = 0; s < 30; ++s) o[s] = 360 / (256 * Math.pow(2, s + 1)), n[s] = s;
|
||
var a = new ol.tilegrid.WMTS({
|
||
origin: r.origin || [-180, 90],
|
||
resolutions: r.resolutions || o,
|
||
matrixIds: r.matrixIds || n
|
||
}), l = e;
|
||
if (-1 === e.indexOf("?")) {
|
||
var h = {
|
||
REQUEST: r.request || "GetTile",
|
||
SERVICE: r.service || "WMTS",
|
||
VERSION: r.version || "1.0.0",
|
||
LAYER: r.layer,
|
||
TILEMATRIX: r.tilematrix || r.projection + ":{z}",
|
||
TILEMATRIXSET: r.tilematrixset || r.projection,
|
||
FORMAT: r.format || "application/x-protobuf;type=mapbox-vector",
|
||
TILECOL: "{x}",
|
||
TILEROW: "{y}"
|
||
};
|
||
for (var u in l = e + "?", h) l = l + u + "=" + h[u] + "&";
|
||
l = l.slice(0, -1)
|
||
}
|
||
var c = new ol.source.VectorTile({
|
||
url: l,
|
||
format: new ol.format.MVT({}),
|
||
projection: r.projection,
|
||
wrapX: !vC.isDef(r.wrapX) || r.wrapX,
|
||
tileGrid: a
|
||
});
|
||
r.declutter = !0, super(t, Object.assign({}, r, {source: c})), this.tileGrid = a, this.url_ = l
|
||
}
|
||
|
||
getTileExtent(t) {
|
||
var e = t[0], i = t[1], r = t[2], o = this.tileGrid.getOrigin(e),
|
||
n = this.tileGrid.getTileSize(e) * this.tileGrid.getResolution(e);
|
||
return [o[0] + n * i, o[1] + n * (r + 1)]
|
||
}
|
||
|
||
changeSkill(t) {
|
||
for (var e in this.labelLayerArray) this.labelLayerArray[e].getSource().clear(), map.removeLayer(this.labelLayerArray[e]);
|
||
if (this.labelLayerArray = [], t) {
|
||
var i = this.getSource();
|
||
i.tileCache.expireCache({}), i.tileCache.clear()
|
||
}
|
||
}
|
||
|
||
setJson2Style(t) {
|
||
this.json2Style = t, this.setStyle(function (e) {
|
||
return t.getStyles(e)
|
||
})
|
||
}
|
||
|
||
getUrl() {
|
||
return this.url_
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t, t.getView().on("change:resolution", function (e) {
|
||
var i = t.getZoom() - 1;
|
||
for (var r in this.labelLayerArray) this.labelLayerArray[r].get("name") == "labelLayer_" + i ? this.labelLayerArray[r].setVisible(!0) : this.labelLayerArray[r].setVisible(!1)
|
||
}.bind(this)), t.getTileLayers().getLayers().push(this), this.set("isAddToMap", !0)
|
||
}
|
||
};
|
||
var OC = class extends lC {
|
||
constructor(t, e, i) {
|
||
var r = i || {}, o = new ol.source.XYZ({
|
||
url: e,
|
||
crossOrigin: r.crossOrigin,
|
||
projection: r.projection,
|
||
tileGrid: r.tileGrid,
|
||
maxZoom: r.maxZoom,
|
||
minZoom: r.minZoom,
|
||
tileSize: r.tileSize,
|
||
wrapX: !r.wrapX || r.wrapX,
|
||
attributions: r.attributions
|
||
});
|
||
super(t, Object.assign({}, r, {source: o})), this.url_ = e
|
||
}
|
||
|
||
getUrl() {
|
||
return this.url_
|
||
}
|
||
};
|
||
|
||
class MC extends ol.layer.Tile {
|
||
constructor(t) {
|
||
var e, i = {}, r = {};
|
||
for (var o in t) "icon" === o ? e = t[o] : i[o] = t[o];
|
||
super({source: new ol.source.EzHotspot(i)}), this.set("layerType", "hotspotLayer"), this.markerOpacity_ = vC.isDef(r.opacity) ? r.opacity : 1, r.opacity = 0, this.popupAnchor_ = vC.isDef(t.popupAnchor) ? t.popupAnchor : [0, 0], this.marker_ = new Ez.Marker(new Ez.Coordinate(0, 0), e)
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t, t.addOverlay(this.marker_), t.getLayers().insertAt(1, this)
|
||
}
|
||
|
||
onRemove(t) {
|
||
this.map_ = null;
|
||
t.removeLayer(this, !0), t.removeOverlay(this.marker_)
|
||
}
|
||
|
||
onMouseMove_(t) {
|
||
var e, i, r, o = t.coordinate, n = t.frameState, s = n.viewState.resolution, a = 8 * s,
|
||
l = n.viewState.projection, h = t.map.getView().getZoom();
|
||
t.map.getLayers().forEach(function (t) {
|
||
t instanceof MC && (e = t, i = t.getSource(), r = i.getTileGridForProjection(l))
|
||
});
|
||
var u = n.extent, c = ol.extent.getTopLeft(u);
|
||
ol.extent.createOrUpdate(c[0], c[1], o[0], o[1], u);
|
||
var p = r.getTileRangeForExtentAndResolution(u, s), d = p.maxX + ":" + (-p.maxY - 1),
|
||
f = i.getMarkerData();
|
||
if (h in f && d in f[h]) for (var g = f[h][d], m = g.length, y = 0; y < m; y++) {
|
||
var v = new Ez.Coordinate(parseFloat(g[y].X), parseFloat(g[y].Y)),
|
||
_ = new Ez.MBR(v.coordinate_[0] - a, v.coordinate_[1] - a, v.coordinate_[0] + a, v.coordinate_[1] + a),
|
||
x = {ID: g[y].ID, LABEL: g[y].LABEL, X: g[y].X, Y: g[y].Y};
|
||
if (_.containsPoint(o)) {
|
||
t.map.getViewport().style.cursor = "pointer", e.marker_.setPoint(v), e.marker_.set("hotspotdata", x), e.marker_.setOpacity(e.markerOpacity_);
|
||
break
|
||
}
|
||
t.map.getViewport().style.cursor = "", e.marker_.setOpacity(0)
|
||
}
|
||
}
|
||
|
||
onClick_(t) {
|
||
if (t) {
|
||
var e = "LABLE : " + t.get("data").LABEL;
|
||
t.popupOpenFlag_ ? t.closeInfoWindowHtml() : t.openInfoWindowHtml(e, {positioning: "bottom-left"})
|
||
}
|
||
}
|
||
}
|
||
|
||
var AC = MC;
|
||
var kC = class extends ol.layer.Group {
|
||
constructor(t) {
|
||
super(t), this.currentId = null, this.duration = t.duration ? t.duration : 500
|
||
}
|
||
|
||
addSingleLayer(t) {
|
||
this.getLayers().push(t)
|
||
}
|
||
|
||
deleteSingleLayer(t) {
|
||
var e = this.getLayers();
|
||
e.forEach(function (i) {
|
||
t !== i || e.remove(i)
|
||
})
|
||
}
|
||
|
||
handleTileData_() {
|
||
var t = this.getLayers();
|
||
t.forEach(function (t) {
|
||
t.getSource().clear(), t.updateSopurceState && t.updateSopurceState(!0, !1)
|
||
}), window.clearTimeout(this.currentId), this.currentId = window.setTimeout(function () {
|
||
t.forEach(function (t) {
|
||
t.updateSopurceState && t.updateSopurceState(!1, !0), t.getSource().changed()
|
||
})
|
||
}.bind(this), this.duration)
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t, t.getView().on("change:resolution", this.handleTileData_.bind(this)), t.getCustomLayers().getLayers().push(this), this.set("isAddToMap", !0)
|
||
}
|
||
|
||
onRemove(t) {
|
||
if (this.get("isAddToMap")) {
|
||
this.map_ = null, t.getView().off("change:resolution", this.handleTileData_.bind(this));
|
||
var e = t.getCustomLayers().getLayers(), i = this;
|
||
e.forEach(function (t) {
|
||
i === t && e.remove(t)
|
||
}), this.set("isAddToMap", !1)
|
||
}
|
||
}
|
||
};
|
||
var FC = class extends ol.layer.Vector {
|
||
constructor(t) {
|
||
var e = t || {}, i = new ol.source.SingleHotSpot(e);
|
||
super({source: i}), this.singleSource = i, this.set("isAddToMap", !1), this.currentId = null, this.clusterStyleCache_ = {}, this.duration = t.duration ? t.duration : 500
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t, t.getView().on("change:resolution", this.handleTileData_.bind(this)), t.getCustomLayers().getLayers().push(this), this.set("isAddToMap", !0)
|
||
}
|
||
|
||
onRemove(t) {
|
||
if (this.get("isAddToMap")) {
|
||
this.map_ = null, t.getView().off("change:resolution", this.handleTileData_.bind(this));
|
||
var e = t.getCustomLayers().getLayers(), i = this;
|
||
e.forEach(function (t) {
|
||
i === t && e.remove(t)
|
||
}), this.set("isAddToMap", !1)
|
||
}
|
||
}
|
||
|
||
updateSourceState(t, e) {
|
||
var i = this.getSource();
|
||
i.setLoadingState(t), i.setLoadendState(e)
|
||
}
|
||
|
||
handleTileData_(t) {
|
||
var e = this.getSource();
|
||
e.clear(!0), this.updateSourceState(!0, !1), window.clearTimeout(this.currentId), this.currentId = window.setTimeout(function () {
|
||
this.updateSourceState(!1, !0), e.changed()
|
||
}.bind(this), this.duration)
|
||
}
|
||
};
|
||
|
||
class NC extends ol.events.Event {
|
||
constructor(t, e) {
|
||
super(t), this.time = e
|
||
}
|
||
}
|
||
|
||
class DC extends ol.Object {
|
||
constructor(t, e) {
|
||
super(), this.feature_ = t, this.transitions_ = e, this.map_ = null, this.now_ = null, this.status_ = "STOP", this.transition_ = null, this.animationTimer_ = 0
|
||
}
|
||
|
||
setRefreshController(t) {
|
||
this.map_ = t
|
||
}
|
||
|
||
play() {
|
||
if ("PLAY" !== this.status_) {
|
||
var t = this.feature_, e = this.map_;
|
||
if ("PAUSE" === this.status_) {
|
||
var i = this.transitions_[0], r = t.getPoint(),
|
||
o = i.getDuration() - ((new Date).getTime() - this.now_ - this.animationTimer_);
|
||
this.transitions_[0].setDuration(o), this.transitions_[0].setStartState(r)
|
||
}
|
||
this.status_ = "PLAY";
|
||
var n = this.now_ = (new Date).getTime(), s = this.generateTransition(t, n);
|
||
this.on("animation:end", function () {
|
||
e.un("postcompose", s)
|
||
}), this.on("animation:control:pause", function () {
|
||
e.un("postcompose", s)
|
||
}), e.on("postcompose", s), this.dispatchEvent(new NC("animation:start", (new Date).getTime())), e.render()
|
||
}
|
||
}
|
||
|
||
pause() {
|
||
this.status_ = "PAUSE", this.dispatchEvent(new NC("animation:control:pause"))
|
||
}
|
||
}
|
||
|
||
var GC = {
|
||
linear: jC, radius: function () {
|
||
}
|
||
};
|
||
|
||
function jC(t, e, i, r) {
|
||
var o = (r - e) / (i - t), n = (i * e - t * r) / (i - t);
|
||
return Math.abs(o) === 1 / 0 ? 1 / 0 : function (t) {
|
||
return o * t + n
|
||
}
|
||
}
|
||
|
||
var zC = class extends DC {
|
||
constructor(t, e) {
|
||
super(t, e)
|
||
}
|
||
|
||
generateTransition(t, e) {
|
||
var i, r = this.transitions_;
|
||
r.forEach(function (t, e) {
|
||
0 === e && (i = t.getDuration()), i < t.getDuration() && (i = t.getDuration())
|
||
});
|
||
var o = r.map(function (i) {
|
||
return i.generateTransition(t, e)
|
||
}), n = 0, s = this;
|
||
return function (t) {
|
||
var r = t.frameState.time - e;
|
||
o.forEach(function (e, o, a) {
|
||
e(t) && n++, n === a.length && r >= i && (s.status_ = !1, s.dispatchEvent(new Ez.animation.ComposeEvent("animation:end")))
|
||
})
|
||
}
|
||
}
|
||
};
|
||
var UC = class extends ol.Object {
|
||
constructor(t, e, i, r, o) {
|
||
super();
|
||
var n = o || {};
|
||
this.duration_ = t || 0, this.atttibute_ = e || null, this.stateOfStart_ = i || null, this.stateOfEnd_ = r || null;
|
||
var s = n.interoptype ? n.interoptype : "linear";
|
||
this.interopFn_ = n.interopfn ? n.interopfn : GC[s], this.fps_ = n.fps ? n.fps : 60
|
||
}
|
||
|
||
generateInteropfn() {
|
||
var t = this.interopFn_, e = this.stateOfStart_.getCoordinate(), i = this.stateOfEnd_.getCoordinate();
|
||
return t(e[0], e[1], i[0], i[1])
|
||
}
|
||
|
||
getDuration() {
|
||
return this.duration_
|
||
}
|
||
|
||
setDuration(t) {
|
||
t && (this.duration_ = t)
|
||
}
|
||
|
||
getFPS() {
|
||
return this.fps_
|
||
}
|
||
|
||
setStartState(t) {
|
||
t && (this.stateOfStart_ = t)
|
||
}
|
||
};
|
||
var BC = class extends DC {
|
||
constructor(t, e) {
|
||
super(t, e)
|
||
}
|
||
|
||
calcSumDur(t, e, i) {
|
||
return i < 0 ? t : e[i].getDuration() + this.calcSumDur(t, e, i - 1)
|
||
}
|
||
|
||
generateTransition(t, e) {
|
||
var i = this.transitions_, r = this, o = i.map(function (i, o, n) {
|
||
var s = r.calcSumDur(e, n, o - 1);
|
||
return i.generateTransition(t, s)
|
||
});
|
||
return function (t) {
|
||
if (o[0](t)) {
|
||
o.splice(0, 1);
|
||
var e = i.splice(0, 1);
|
||
r.animationTimer_ += e[0].getDuration(), t.target.render()
|
||
}
|
||
0 === o.length && (this.status_ = "STOP", r.dispatchEvent(new NC("animation:end", t.frameState.time)))
|
||
}
|
||
}
|
||
};
|
||
var VC = class extends UC {
|
||
constructor(t, e, i, r, o) {
|
||
var n = o || {}, s = n.type ? n.type : "linear";
|
||
super(t, e, i, r, Object.assign({}, n, {type: s}))
|
||
}
|
||
|
||
generateTransition(t, e) {
|
||
var i = e,
|
||
r = (this.stateOfStart_.getCoordinate()[0], this.stateOfEnd_.getCoordinate()[0], this.getDuration()),
|
||
o = this.getFPS(), n = this.generateInteropfn(),
|
||
s = this.generateLine(this.stateOfStart_.getCoordinate(), this.stateOfEnd_.getCoordinate(), r, this.getFPS(), n);
|
||
return function (e) {
|
||
var r = e.frameState, n = e.target, a = r.time - i, l = Math.round(a / (1e3 / o));
|
||
if (l >= 1) {
|
||
if (l >= s.length) return !0;
|
||
t.getGeometry().setCoordinates(s[l]), n.render()
|
||
}
|
||
}
|
||
}
|
||
|
||
generateLine(t, e, i, r, o) {
|
||
var n, s = i / (1e3 / r);
|
||
n = o === 1 / 0 ? (e[1] - t[1]) / (s > 0 ? s : 0) : (e[0] - t[0]) / (s > 0 ? s : 0);
|
||
var a, l, h = [];
|
||
h.push(t);
|
||
for (var u = 1; u < s + 1; u++) o === 1 / 0 ? (a = t[0], l = t[1] + n * u) : l = o(a = t[0] + n * u), h.push([a, l]);
|
||
return h.push(e), h
|
||
}
|
||
};
|
||
var YC = class extends UC {
|
||
constructor(t, e, i, r, o, n) {
|
||
var s = n || {}, a = s.type ? s.type : "radius";
|
||
super(t, e, i, r, Object.assign({}, s, {type: a})), this.isRight_ = !vC.isDef(o) || o
|
||
}
|
||
|
||
generateTransition(t, e) {
|
||
var i = e, r = this.stateOfStart_, o = this.stateOfEnd_, n = this.getDuration(), s = this.getFPS(),
|
||
a = this.generateRad(r, o, n, s);
|
||
return function (e) {
|
||
var r = e.frameState, o = (e.target, r.time - i), n = Math.round(o / (1e3 / s));
|
||
if (n >= 1) {
|
||
if (n >= a.length) return !0;
|
||
var l = t.getStyle();
|
||
l.getImage().setRotation(a[n]), t.setStyle(l)
|
||
}
|
||
}
|
||
}
|
||
|
||
generateRad(t, e, i, r) {
|
||
var o = i / (1e3 / r);
|
||
if (this.isRight_) {
|
||
var n = this.radianClockwise_(t, e);
|
||
t = n.start, e = n.end
|
||
} else {
|
||
var s = this.radianUnClockwise_(t, e);
|
||
t = s.start, e = s.end
|
||
}
|
||
var a = (e - t) / (o > 0 ? o : 0), l = [];
|
||
l.push(t);
|
||
for (var h = 1; h < o + 1; h++) {
|
||
var u;
|
||
u = t + a * h, l.push(u)
|
||
}
|
||
return l.push(e), l
|
||
}
|
||
|
||
radianClockwise_(t, e) {
|
||
return e - t >= 0 ? {start: t, end: e} : {start: t, end: 2 * Math.PI + e}
|
||
}
|
||
|
||
radianUnClockwise_(t, e) {
|
||
return e - t >= 0 ? {start: t, end: -2 * Math.PI + e} : {start: t, end: e}
|
||
}
|
||
};
|
||
var WC = class extends ol.control.Control {
|
||
constructor(t) {
|
||
t.className += " ol-unselectable ol-control", super({element: t})
|
||
}
|
||
};
|
||
|
||
class HC extends ol.control.Control {
|
||
constructor(t) {
|
||
var e = {}, i = document.createElement("div"), r = document.createElement("div");
|
||
i.className = "ez-layers ol-unselectable ol-control", r.className = "ez-layers-showLayers";
|
||
for (var o = {}, n = 0; n < t.length; n++) {
|
||
var s = t[n], a = HC.generateLayerFrame(s);
|
||
e[s.title] = a, e[s.title + "_layer"] = s.layer, o[s.title] = s.layer
|
||
}
|
||
super({element: i}), i.addEventListener("mouseover", this.onMouseOver_.bind(this), !1), i.addEventListener("mouseout", this.onMouseOut_.bind(this), !1), i.addEventListener("click", this.onClick_.bind(this), !1), this.baseLayers_ = e, this.eleContainer = i, this.showContainer = r, this.layers_ = o
|
||
}
|
||
|
||
static generateLayerFrame(t) {
|
||
ol.asserts.assert(vC.isDef(t.title), "图层缺少title信息"), ol.asserts.assert(vC.isDef(t.layer), "图层缺少layer对象"), ol.asserts.assert(vC.isDef(t.imageSRC), "图层缺少image图标");
|
||
var e = document.createElement("div");
|
||
e.className = "ez-layers-div ez-layers-hidden", e.id = "ezLayer", e.addEventListener("mouseover", function (t) {
|
||
this.children[1].style.backgroundColor = "#989CFC"
|
||
}, !1), e.addEventListener("mouseout", function (t) {
|
||
this.children[1].style.backgroundColor = ""
|
||
}, !1);
|
||
var i = document.createElement("img");
|
||
i.src = t.imageSRC;
|
||
var r = document.createElement("div");
|
||
return r.innerHTML = t.title, r.className = "ez-layers-title", e.appendChild(i), e.appendChild(r), e
|
||
}
|
||
|
||
refesh() {
|
||
var t = this.getMap().getTileLayers().getLayers(), e = /_layer/, i = t.item(t.getLength() - 1);
|
||
for (var r in this.baseLayers_) r !== i.get("ezname") ? e.test(r) || this.showContainer.appendChild(this.baseLayers_[r]) : (this.eleContainer.appendChild(this.baseLayers_[r]), this.topElement_ = this.baseLayers_[r], this.removeCss(this.topElement_, "ez-layers-hidden"));
|
||
this.eleContainer.appendChild(this.showContainer)
|
||
}
|
||
|
||
onMouseOver_(t) {
|
||
t.stopPropagation(), this.expand()
|
||
}
|
||
|
||
onMouseOut_(t) {
|
||
t.stopPropagation(), this.collapse()
|
||
}
|
||
|
||
onClick_(t) {
|
||
t.stopPropagation();
|
||
var e, i = t.target;
|
||
for (e = i.lastChild ? i.lastChild.textContent : i.nextSibling.lastChild.textContent, this.swapTo(e), this.eleContainer.removeChild(this.showContainer); this.showContainer.hasChildNodes();) this.showContainer.removeChild(this.showContainer.lastChild);
|
||
this.refesh()
|
||
}
|
||
|
||
expand() {
|
||
for (var t = this.showContainer.childNodes, e = 0; e < t.length; e++) this.removeCss(t[e], "ez-layers-hidden")
|
||
}
|
||
|
||
collapse() {
|
||
for (var t = this.showContainer.childNodes, e = 0; e < t.length; e++) this.addCss(t[e], "ez-layers-hidden")
|
||
}
|
||
|
||
removeCss(t, e) {
|
||
for (var i = this.getClass(t), r = e, o = [], n = 0; n < i.length; n++) -1 == r.indexOf(i[n]) && o.push(i[n]);
|
||
t.className = o.join(" ")
|
||
}
|
||
|
||
addCss(t, e) {
|
||
var i = this.getClass(t), r = e;
|
||
-1 == i.indexOf(r) && i.push(r), t.className = i.join(" ")
|
||
}
|
||
|
||
getClass(t) {
|
||
var e = t.className;
|
||
return e && "function" == typeof e.split ? e.split(" ") : []
|
||
}
|
||
|
||
swapTo(t) {
|
||
var e = this.getMap();
|
||
if (vC.isDef(t)) {
|
||
var i = this.getCurrentTileLayer();
|
||
if (t !== i.get("ezname")) {
|
||
var r, o = this.layers_[t], n = e.getView().getProjection();
|
||
o instanceof Ez.Layer.Group ? (r = o.getLayers().getArray()[0].getSource().getProjection(), o.getLayers().getArray()[0].getResolutions()) : (o.getResolutions(), r = o.getSource().getProjection());
|
||
var s = e.getView().getCenter();
|
||
e.getView().getZoom(), e.getView().getState(), ol.proj.transform(s, n, r);
|
||
e.removeLayer(i), e.addLayer(o)
|
||
}
|
||
}
|
||
}
|
||
|
||
getCurrentTileLayer() {
|
||
var t = this.map_.tileLayerGroup_.getLayers();
|
||
return t.item(t.getLength() - 1)
|
||
}
|
||
}
|
||
|
||
var XC = HC;
|
||
var qC = class extends ol.control.Control {
|
||
constructor(t) {
|
||
var e = document.createElement("div");
|
||
e.className = "ez-navigation ol-unselectable ol-control";
|
||
var i = document.createElement("div");
|
||
i.className = "ez-navigation-top ez-navigation-pan", i.setAttribute("data-orientation", "NORTH"), e.appendChild(i);
|
||
var r = document.createElement("div");
|
||
r.className = "ez-navigation-left ez-navigation-pan", r.setAttribute("data-orientation", "WEST"), e.appendChild(r);
|
||
var o = document.createElement("div");
|
||
o.className = "ez-navigation-bottom ez-navigation-pan", o.setAttribute("data-orientation", "SOUTH"), e.appendChild(o);
|
||
var n = document.createElement("div");
|
||
n.className = "ez-navigation-right ez-navigation-pan", n.setAttribute("data-orientation", "EAST"), e.appendChild(n), super({element: e}), ol.events.listen(i, ol.events.EventType.CLICK, this.handleClick_, this), ol.events.listen(r, ol.events.EventType.CLICK, this.handleClick_, this), ol.events.listen(o, ol.events.EventType.CLICK, this.handleClick_, this), ol.events.listen(n, ol.events.EventType.CLICK, this.handleClick_, this)
|
||
}
|
||
|
||
handleClick_(t) {
|
||
var e = t.target.getAttribute("data-orientation"), i = this.getMap().viewOfEz_, r = i.getState(),
|
||
o = 128 * r.resolution, n = 0, s = 0;
|
||
"SOUTH" === e ? s = -o : "WEST" === e ? n = -o : "EAST" === e ? n = o : s = o;
|
||
var a = [n, s];
|
||
ol.coordinate.rotate(a, r.rotation), ol.interaction.Interaction.pan(i, a, 100), t.preventDefault()
|
||
}
|
||
};
|
||
var ZC = class extends ol.control.OverviewMap {
|
||
constructor(t) {
|
||
var e = t || {}, i = e.className ? e.className : "ol-overviewmap ez-custom-overview",
|
||
r = e.collapseLabel ? e.collapseLabel : "»", o = e.label ? e.label : "«",
|
||
n = !e.collapsed || e.collapsed, s = e.projection ? e.projection : "EPSG:4326";
|
||
super({className: i, collapseLabel: r, label: o, view: new ol.View({projection: s}), collapsed: n})
|
||
}
|
||
};
|
||
var KC = class extends ol.control.ScaleLine {
|
||
constructor(t) {
|
||
var e = t || {};
|
||
super({
|
||
className: e.className ? e.className : "ez-scale-line",
|
||
minWidth: e.minWidth ? e.minWidth : 64,
|
||
units: e.units ? e.units : "metric"
|
||
})
|
||
}
|
||
};
|
||
var JC = class extends ol.control.Control {
|
||
constructor(t) {
|
||
var e = document.createElement("div");
|
||
e.className = "ez-simple-layers ol-unselectable ol-control", e.id = "ez_simple_layers", super({element: e});
|
||
for (var i = {}, r = t.length - 1; r >= 0; r--) {
|
||
var o;
|
||
o = 0 === r ? this.createLayerCard(t[r]) : this.createLayerCard(t[r], !0), e.appendChild(o), i[t[r].title] = t[r].layer
|
||
}
|
||
e.addEventListener("mouseover", this.onMouseOver.bind(this)), e.addEventListener("mouseout", this.onMouseOut.bind(this)), this.element = e, this.layers_ = i
|
||
}
|
||
|
||
createLayerCard(t, e) {
|
||
var i = t.title, r = (t.layer, t.imageSRC), o = document.createElement("div");
|
||
o.className = e ? "ez-simple-card hide" : "ez-simple-card";
|
||
var n = document.createElement("img");
|
||
n.src = r;
|
||
var s = document.createElement("span");
|
||
return s.innerHTML = i, o.addEventListener("mouseover", this.oncardmouseover.bind(o, this)), o.addEventListener("mouseout", this.oncardmouseout.bind(o, this)), o.addEventListener("click", this.oncardclick.bind(o, this)), o.appendChild(n), o.appendChild(s), o
|
||
}
|
||
|
||
onMouseOver(t) {
|
||
var e = this.element, i = e.children;
|
||
this.addClass(e, "ez-simple-layers--onfocus");
|
||
for (var r = 0; r < i.length - 1; r++) this.removeClass(i[r], "hide")
|
||
}
|
||
|
||
onMouseOut(t) {
|
||
var e = this.element, i = e.children;
|
||
this.removeClass(e, "ez-simple-layers--onfocus");
|
||
for (var r = 0; r < i.length - 1; r++) this.addClass(i[r], "hide")
|
||
}
|
||
|
||
oncardmouseover(t) {
|
||
var e = this.children[1];
|
||
t.addClass(this, "ez-simple-card--onfocus"), t.addClass(e, "ez-simple-card-title--onfocus")
|
||
}
|
||
|
||
oncardmouseout(t) {
|
||
var e = this.children[1];
|
||
t.removeClass(this, "ez-simple-card--onfocus"), t.removeClass(e, "ez-simple-card-title--onfocus")
|
||
}
|
||
|
||
oncardclick(t) {
|
||
var e = this.children[1].textContent;
|
||
t.swapTo(e)
|
||
}
|
||
|
||
addClass(t, e) {
|
||
this.removeClass(t, e), t.className += " " + e
|
||
}
|
||
|
||
removeClass(t, e) {
|
||
for (var i = t.className.split(" "), r = 0; r < i.length; r++) if (i[r] === e) {
|
||
i.splice(r, 1);
|
||
break
|
||
}
|
||
t.className = i.join(" ")
|
||
}
|
||
|
||
swapTo(t) {
|
||
var e = this.getMap();
|
||
if (vC.isDef(t)) {
|
||
var i = this.getCurrentTileLayer();
|
||
if (t !== i.get("ezname")) {
|
||
var r, o = this.layers_[t], n = e.getView().getProjection();
|
||
if (o instanceof Ez.Layer.Group) r = o.getLayers().getArray()[0].getSource().getProjection(), o.getLayers().getArray()[0].getResolutions(); else {
|
||
if ("function" == typeof o) return void (o() && e.removeLayer(i));
|
||
o.getResolutions(), r = o.getSource().getProjection()
|
||
}
|
||
var s = e.getView().getCenter();
|
||
e.getView().getZoom(), e.getView().getState(), ol.proj.transform(s, n, r), e.removeLayer(i), e.addLayer(o)
|
||
}
|
||
}
|
||
}
|
||
|
||
getCurrentTileLayer() {
|
||
var t = this.map_.tileLayerGroup_.getLayers();
|
||
return t.item(t.getLength() - 1)
|
||
}
|
||
};
|
||
|
||
class $C extends ol.control.Control {
|
||
constructor() {
|
||
var t = $C.createDom("div", "ez-simple-zoom ol-unselectable ol-control"),
|
||
e = $C.createDom("div", "ez-simple-btn");
|
||
e.title = "放大一级";
|
||
var i = $C.createDom("div", "ez-simple-zoomview ez-simple-zoomin");
|
||
e.appendChild(i);
|
||
var r = $C.createDom("div", "ez-simple-btn");
|
||
r.title = "当前级别";
|
||
var o = $C.createDom("div", "ez-simple-zoomview ez-simple-status");
|
||
r.appendChild(o);
|
||
var n = $C.createDom("div", "ez-simple-btn");
|
||
n.title = "缩小一级";
|
||
var s = $C.createDom("div", "ez-simple-zoomview ez-simple-zoomout");
|
||
n.appendChild(s), t.appendChild(e), t.appendChild(r), t.appendChild(n), super({element: t}), e.addEventListener("click", this.handleZoomIn.bind(this)), n.addEventListener("click", this.handleZoomOut.bind(this)), this.view = o, window.setTimeout(this.initView.bind(this), 300)
|
||
}
|
||
|
||
initView() {
|
||
var t = this.getMap(), e = t.getZoom();
|
||
this.view.innerHTML = e, t.getView().on("change:resolution", function (e) {
|
||
this.view.innerHTML = t.getZoom()
|
||
}.bind(this))
|
||
}
|
||
|
||
static createDom(t, e) {
|
||
var i = document.createElement(t);
|
||
return i.className = e, i
|
||
}
|
||
|
||
handleZoomIn() {
|
||
this.getMap().zoomIn()
|
||
}
|
||
|
||
handleZoomOut() {
|
||
this.getMap().zoomOut()
|
||
}
|
||
}
|
||
|
||
var QC = $C;
|
||
|
||
class tS extends ol.control.Control {
|
||
constructor(t) {
|
||
var e = vC.isDef(t) ? t : {}, i = vC.isDef(e.maxZoom) ? e.maxZoom : 18,
|
||
r = vC.isDef(e.minZoom) ? e.minZoom : 2, o = !!vC.isDef(e.isTitleArea) && e.isTitleArea,
|
||
n = document.createElement("div");
|
||
n.className = "ez-zoomslider ol-unselectable ol-control";
|
||
var s = document.createElement("div");
|
||
s.className = "ez-zoomslider-zoomin ez-zoomslider-btn", s.title = "放大一级";
|
||
var a = document.createElement("div");
|
||
a.className = "ez-zoomslider-zoomcontent", a.title = "放置到此级别";
|
||
var l = document.createElement("div");
|
||
l.className = "ez-zoomslider-zoomout ez-zoomslider-btn", l.title = "缩小一级";
|
||
var h = null;
|
||
o && (h = tS.initFlagArea(e.flag2level, i, r), a.appendChild(h));
|
||
var u = 10 * (i - r - 1) + 15 + 14;
|
||
a.style.height = u + "px", o && (h.style.height = u + "px");
|
||
var c = document.createElement("div");
|
||
c.className = "ez-zoomslider-zoomcontent-top", a.appendChild(c);
|
||
var p = document.createElement("div");
|
||
p.className = "ez-zoomslider-zoomcontent-bottom", a.appendChild(p);
|
||
var d = document.createElement("div");
|
||
d.className = "ez-zoomslider-zoomcontent-body", a.appendChild(d), d.style.height = 10 * (i - r - 1) + "px";
|
||
var f = document.createElement("div");
|
||
f.className = "ez-zoomslider-zoomcontentrender", a.appendChild(f);
|
||
var g = document.createElement("div");
|
||
if (g.className = "ez-zoomslider-thumb", g.title = "拖拽", a.appendChild(g), n.appendChild(s), n.appendChild(a), n.appendChild(l), super({
|
||
element: n,
|
||
render: function (t) {
|
||
if (!vC.isNull(t.frameState)) {
|
||
ol.asserts.assert(vC.isDefAndNotNull(t.frameState.viewState), "viewState should be defined");
|
||
var e = t.frameState.viewState.resolution;
|
||
if (e !== this.currentResolution_) {
|
||
this.currentResolution_ = e, this.setThumbPosition_(e);
|
||
var i = this.thumbElement.style.top, r = this.dragger_.limits.height - parseInt(i) + 4;
|
||
r < 0 && (r = 0), this.zoomcontentrender_.style.height = r + "px"
|
||
}
|
||
}
|
||
}
|
||
}), o) {
|
||
a.addEventListener("mouseover", this.handleTagContainerMouseover_.bind(this), !1), a.addEventListener("mouseout", this.handleTagContainerMouseout_.bind(this), !1);
|
||
for (var m = h.children, y = 0; y < m.length; y++) m[y].addEventListener("click", this.locationZoom_.bind(this), !1)
|
||
}
|
||
this.tagContainer = h, this.eleContainer = n, this.zoomcontentrender_ = f, this.thumbElement = g, this.dragger_ = new ol.pointer.PointerEventHandler(a), this.dragger_.limits = {
|
||
left: 2,
|
||
top: 5,
|
||
width: 0,
|
||
height: u - 18 - 4
|
||
}, ol.events.listen(this.dragger_, ol.pointer.EventType.POINTERDOWN, this.handleDraggerStart_, this), ol.events.listen(this.dragger_, ol.pointer.EventType.POINTERMOVE, this.handleDraggerDrag_, this), ol.events.listen(this.dragger_, ol.pointer.EventType.POINTERUP, this.handleDraggerEnd_, this), ol.events.listen(d, ol.events.EventType.CLICK, this.handleContainerClick_, this), ol.events.listen(f, ol.events.EventType.CLICK, this.handleContainerrenderClick_, this), ol.events.listen(c, ol.events.EventType.CLICK, this.handleTopClick_, this), ol.events.listen(p, ol.events.EventType.CLICK, this.handleBottomClick_, this), ol.events.listen(this.thumbElement, ol.events.EventType.CLICK, ol.events.Event.stopPropagation), ol.events.listen(s, "click", this.zoomin_, this), ol.events.listen(l, "click", this.zoomout_, this), this.dragging_, this.dragListenerKeys_, this.currentResolution_ = void 0
|
||
}
|
||
|
||
render(t) {
|
||
if (!vC.isNull(t.frameState)) {
|
||
ol.asserts.assert(vC.isDefAndNotNull(t.frameState.viewState), "viewState should be defined");
|
||
var e = t.frameState.viewState.resolution;
|
||
if (e !== this.currentResolution_) {
|
||
this.currentResolution_ = e, this.setThumbPosition_(e);
|
||
var i = this.thumbElement.style.top, r = this.dragger_.limits.height - parseInt(i) + 4;
|
||
r < 0 && (r = 0), this.zoomcontentrender_.style.height = r + "px"
|
||
}
|
||
}
|
||
}
|
||
|
||
static initFlagArea(t, e, i) {
|
||
var r = vC.isDef(t) ? t : {},
|
||
o = [vC.isDef(r.country) ? r.country : 2, vC.isDef(r.province) ? r.province : 7, vC.isDef(r.city) ? r.city : 11, vC.isDef(r.street) ? r.street : 17],
|
||
n = document.createElement("div");
|
||
n.className = "ez-zoomslider-tagArea ez-zoomslider-tagArea-hidden";
|
||
for (var s = 0; s < o.length; s++) if (o[s] <= e && o[s] >= i) if (0 === s) {
|
||
var a = document.createElement("div");
|
||
a.className = "ez-zoomslider-tag ez-zoomslider-tag-country", a.id = "country", a.setAttribute("data-zoom", o[s]), a.style.top = 10 * (e - o[s] - 1) + 15 + 5 - 10 + "px", n.appendChild(a)
|
||
} else if (1 === s) {
|
||
var l = document.createElement("div");
|
||
l.className = "ez-zoomslider-tag ez-zoomslider-tag-province", l.style.top = 10 * (e - o[s] - 1) + 15 + 5 - 10 + "px", l.id = "province", l.setAttribute("data-zoom", o[s]), n.appendChild(l)
|
||
} else if (2 === s) {
|
||
var h = document.createElement("div");
|
||
h.className = "ez-zoomslider-tag ez-zoomslider-tag-city", h.style.top = 10 * (e - o[s] - 1) + 15 + 5 - 10 + "px", h.id = "city", h.setAttribute("data-zoom", o[s]), n.appendChild(h)
|
||
} else if (3 === s) {
|
||
var u = document.createElement("div");
|
||
u.className = "ez-zoomslider-tag ez-zoomslider-tag-street", u.style.top = 10 * (e - o[s] - 1) + 15 + 5 - 10 + "px", u.id = "street", u.setAttribute("data-zoom", o[s]), n.appendChild(u)
|
||
}
|
||
return n
|
||
}
|
||
|
||
handleTagContainerMouseover_(t) {
|
||
this.tagContainer.className = "ez-zoomslider-tagArea"
|
||
}
|
||
|
||
handleTagContainerMouseout_(t) {
|
||
this.tagContainer.className = "ez-zoomslider-tagArea ez-zoomslider-tagArea-hidden"
|
||
}
|
||
|
||
setThumbPosition_(t) {
|
||
var e = this.getPositionForResolution_(t), i = this.dragger_, r = this.thumbElement,
|
||
o = i.limits.top + i.limits.height * e;
|
||
this.setPosition(r, i.limits.left, o)
|
||
}
|
||
|
||
setPosition(t, e, i) {
|
||
var r, o;
|
||
r = e, o = i, t.style.left = r + "px", t.style.top = o + "px"
|
||
}
|
||
|
||
handleDraggerStart_(t) {
|
||
if (!this.dragging_ && t.originalEvent.target === this.thumbElement && (this.getMap().getView().setHint(ol.ViewHint.INTERACTING, 1), this.previousX_ = t.clientX, this.previousY_ = t.clientY, this.dragging_ = !0, !this.dragListenerKeys_)) {
|
||
var e = this.handleDraggerDrag_, i = this.handleDraggerEnd_;
|
||
this.dragListenerKeys_ = [ol.events.listen(document, ol.events.EventType.MOUSEMOVE, e, this), ol.events.listen(document, ol.events.EventType.MOUSEUP, i, this)]
|
||
}
|
||
}
|
||
|
||
handleDraggerDrag_(t) {
|
||
if (this.dragging_) {
|
||
var e = this.thumbElement, i = t.clientX - this.previousX_ + parseInt(e.style.left, 10),
|
||
r = t.clientY - this.previousY_ + parseInt(e.style.top, 10),
|
||
o = parseInt(this.dragger_.limits.height) - parseInt(e.style.top) + 4;
|
||
this.zoomcontentrender_.style.height = o + "px";
|
||
var n = this.getRelativePosition_(i, r);
|
||
this.currentResolution_ = this.getResolutionForPosition_(n), this.getMap().getView().setResolution(this.currentResolution_), this.setThumbPosition_(this.currentResolution_), this.previousX_ = t.clientX, this.previousY_ = t.clientY
|
||
}
|
||
}
|
||
|
||
handleDraggerEnd_(t) {
|
||
if (this.dragging_) {
|
||
var e = this.getMap().getView();
|
||
e.setHint(ol.ViewHint.INTERACTING, -1), ol.asserts.assert(this.currentResolution_, "this.currentResolution_ should be defined");
|
||
var i = e.constrainResolution(this.currentResolution_);
|
||
e.setResolution(i), this.dragging_ = !1, this.previousX_ = void 0, this.previousY_ = void 0, this.dragListenerKeys_.forEach(ol.events.unlistenByKey), this.dragListenerKeys_ = null
|
||
}
|
||
}
|
||
|
||
locationZoom_(t) {
|
||
var e = this.getMap().getView(), i = parseInt(t.target.getAttribute("data-zoom"));
|
||
e.setZoom(i)
|
||
}
|
||
|
||
handleContainerClick_(t) {
|
||
var e = this.getMap().getView(), i = e.getResolution();
|
||
ol.asserts.assert(vC.isDef(i), "currentResolution should be defined");
|
||
var r = this.getRelativePosition_(t.offsetX - 9, t.offsetY - 4.5 + 11),
|
||
o = this.getResolutionForPosition_(r);
|
||
e.setResolution(e.constrainResolution(o)), this.thumbElement.title = e.getZoom()
|
||
}
|
||
|
||
handleContainerrenderClick_(t) {
|
||
var e = this.getMap().getView(), i = this.thumbElement, r = e.getResolution();
|
||
ol.asserts.assert(vC.isDef(r), "currentResolution should be defined");
|
||
var o = this.getRelativePosition_(t.offsetX - 9, t.offsetY + parseFloat(i.style.top)),
|
||
n = this.getResolutionForPosition_(o);
|
||
e.setResolution(e.constrainResolution(n)), i.title = e.getZoom()
|
||
}
|
||
|
||
handleTopClick_(t) {
|
||
var e = this.getMap().getView(), i = e.getResolution();
|
||
ol.asserts.assert(vC.isDef(i), "currentResolution should be defined");
|
||
var r = this.getRelativePosition_(0, 5), o = this.getResolutionForPosition_(r);
|
||
e.setResolution(e.constrainResolution(o)), this.thumbElement.title = e.getZoom()
|
||
}
|
||
|
||
handleBottomClick_(t) {
|
||
var e = this.getMap().getView(), i = e.getResolution();
|
||
ol.asserts.assert(vC.isDef(i), "currentResolution should be defined");
|
||
var r = this.getRelativePosition_(0, 151), o = this.getResolutionForPosition_(r);
|
||
e.setResolution(e.constrainResolution(o)), this.thumbElement.title = e.getZoom()
|
||
}
|
||
|
||
zoomin_() {
|
||
var t = this.getMap().getView(), e = t.getZoom();
|
||
t.setZoom(e + 1)
|
||
}
|
||
|
||
zoomout_() {
|
||
var t = this.getMap().getView(), e = t.getZoom();
|
||
t.setZoom(e - 1)
|
||
}
|
||
|
||
getRelativePosition_(t, e) {
|
||
var i, r = this.dragger_.limits;
|
||
return i = 1 === this.direction_ ? (t - r.left) / r.width : (e - r.top) / r.height, ol.math.clamp(i, 0, 1)
|
||
}
|
||
|
||
getResolutionForPosition_(t) {
|
||
return this.getMap().getView().getResolutionForValueFunction()(1 - t)
|
||
}
|
||
|
||
getPositionForResolution_(t) {
|
||
return 1 - this.getMap().getView().getValueForResolutionFunction()(t)
|
||
}
|
||
}
|
||
|
||
var eS = tS;
|
||
var iS = class extends oC {
|
||
constructor(t, e, i, r) {
|
||
var o, n, s = "";
|
||
vC.isString(t) ? (n = t.split(","), s = t) : t instanceof rC ? (n = t.getCoordinate(), s = t.toStringXY()) : ol.asserts.assert(!1, "坐标点必须是EzCoord对象"), e = parseFloat(e);
|
||
var a = i || {};
|
||
if (!a.isMeter) {
|
||
var l = n;
|
||
e = 1 * e / ce(l, [l[0] + 1, l[1]], 6378137)
|
||
}
|
||
if (vC.isNumber(e) || ol.asserts.assert(!1, "圆形半径必须为数值型"), super({geometry: new ol.geom.Circle(n, e)}), vC.isDef(i)) {
|
||
var h = vC.isDef(a.fillColor) ? a.fillColor : "#FFFFFF", u = super.hexToRgb_(h);
|
||
u[3] = vC.isDef(a.fillOpacity) ? a.fillOpacity : .5;
|
||
var c = ol.color.asArray(vC.isDef(a.strokeColor) ? a.strokeColor : "#FFCC33");
|
||
c[3] = vC.isDef(a.strokeOpacity) ? a.strokeOpacity : 1;
|
||
var p = vC.isDef(a.strokeLineDash) ? a.strokeLineDash : void 0;
|
||
o = new ol.style.Style({
|
||
fill: new ol.style.Fill({color: u}),
|
||
stroke: new ol.style.Stroke({
|
||
color: c,
|
||
width: vC.isDef(a.strokeWidth) ? parseInt(a.strokeWidth) : 2,
|
||
lineDash: p
|
||
})
|
||
})
|
||
} else o = new ol.style.Style({
|
||
fill: new ol.style.Fill({color: [255, 255, 255, .5]}),
|
||
stroke: new ol.style.Stroke({color: [255, 204, 51, 1], width: 2})
|
||
});
|
||
this.coordString = s, this.circleFlag = !0, this.setStyle(o);
|
||
var d = r || {};
|
||
d.draggable && this.set("draggable", d.draggable)
|
||
}
|
||
|
||
getCenter() {
|
||
var t = this.getGeometry().getCenter();
|
||
return new rC(t[0], t[1])
|
||
}
|
||
|
||
setCenter(t) {
|
||
this.getGeometry().setCenter(t.getCoordinate())
|
||
}
|
||
|
||
getRadius() {
|
||
var t = this.getGeometry().getCenter(), e = ce(t, [t[0] + 1, t[1]], 6378137);
|
||
return this.getGeometry().getRadius() * e
|
||
}
|
||
|
||
setRadius(t) {
|
||
var e = this.getGeometry().getCenter(), i = ce(e, [e[0] + 1, e[1]], 6378137);
|
||
this.getGeometry().setRadius(t / i)
|
||
}
|
||
|
||
isPointInCircle(t) {
|
||
var e = this.getGeometry().getCenter(), i = this.getGeometry().getRadius(), r = t.getCoordinate();
|
||
return !((e[0] - r[0]) * (e[0] - r[0]) + (e[1] - r[1]) * (e[1] - r[1]) > i * i)
|
||
}
|
||
};
|
||
var rS = class extends oC {
|
||
constructor(t, e, i) {
|
||
var r, o, n = "";
|
||
if (vC.isString(t) ? (o = t.split(","), n = t) : t instanceof rC ? (o = t.getCoordinate(), n = t.toStringXY()) : ol.asserts.assert(!1, "坐标点必须是EzCoord对象"), super({
|
||
geometry: new ol.geom.Point(o),
|
||
otherOptions: i
|
||
}), vC.isDef(e)) {
|
||
var s = vC.isDef(e.fillColor) ? e.fillColor : "#FFFFFF", a = super.hexToRgb_(s);
|
||
a[3] = vC.isDef(e.fillOpacity) ? e.fillOpacity : 1;
|
||
var l = ol.color.asArray(vC.isDef(e.strokeColor) ? e.strokeColor : "#FFCC33");
|
||
l[3] = vC.isDef(e.strokeOpacity) ? e.strokeOpacity : 1, r = new ol.style.Style({
|
||
image: new ol.style.Circle({
|
||
radius: vC.isDef(e.radius) ? e.radius : 7,
|
||
fill: new ol.style.Fill({color: a}),
|
||
stroke: new ol.style.Stroke({
|
||
color: l,
|
||
width: vC.isDef(e.strokeWidth) ? parseInt(e.strokeWidth) : 2
|
||
})
|
||
})
|
||
})
|
||
} else r = new ol.style.Style({
|
||
image: new ol.style.Circle({
|
||
radius: 5,
|
||
fill: new ol.style.Fill({color: [255, 255, 255, 1]}),
|
||
stroke: new ol.style.Stroke({color: [255, 204, 51, 1], width: 2})
|
||
})
|
||
});
|
||
this.coordString = n, this.setStyle(r);
|
||
var h = i || {};
|
||
h.draggable && this.set("draggable", h.draggable)
|
||
}
|
||
|
||
getCenter() {
|
||
var t = this.getGeometry().getCoordinates();
|
||
return new rC(t[0], t[1])
|
||
}
|
||
|
||
setCenter(t) {
|
||
if (!t) throw new Error("坐标对象不能为空!");
|
||
var e = t.getCoordinate();
|
||
this.getGeometry().setCoordinates(e)
|
||
}
|
||
|
||
getFillColor() {
|
||
var t = this.getStyle().getImage().getFill(), e = ol.color.asArray(t.getColor());
|
||
return ol.color.asString(e)
|
||
}
|
||
|
||
getFillOpacity() {
|
||
var t = this.getStyle().getImage().getFill(), e = ol.color.asArray(t.getColor());
|
||
return parseFloat(e[3])
|
||
}
|
||
|
||
getRadius() {
|
||
return this.getStyle().getImage().getRadius()
|
||
}
|
||
|
||
setRadius(t) {
|
||
if (!t) throw new Error("像素半径不能为空!");
|
||
var e = this.getStyle().getImage(), i = e.getFill(), r = e.getStroke(), o = new ol.style.Style({
|
||
image: new ol.style.Circle({
|
||
radius: t,
|
||
fill: new ol.style.Fill({color: i.getColor()}),
|
||
stroke: new ol.style.Stroke({color: r.getColor(), width: r.getWidth()})
|
||
})
|
||
});
|
||
this.setStyle(o)
|
||
}
|
||
|
||
setFillColor(t) {
|
||
var e = this.getStyle(), i = e.getImage().getFill(), r = ol.color.asArray(i.getColor())[3],
|
||
o = ol.color.asArray(t);
|
||
o[3] = r, i.setColor(o), this.setStyle(e)
|
||
}
|
||
|
||
setFillOpacity(t) {
|
||
ol.asserts.assert(t >= 0 && t <= 1, "设置的透明度必须在[0,1]范围内");
|
||
var e = this.getStyle(), i = e.getImage().getFill(), r = ol.color.asArray(i.getColor());
|
||
r[3] = t, i.setColor(r), this.setStyle(e)
|
||
}
|
||
|
||
getStrokeColor() {
|
||
var t = this.getStyle().getImage().getStroke(), e = ol.color.asArray(t.getColor());
|
||
return ol.color.asString(e)
|
||
}
|
||
|
||
getStrokeWidth() {
|
||
return this.getStyle().getImage().getStroke().getWidth()
|
||
}
|
||
|
||
getStrokeOpacity() {
|
||
var t = this.getStyle().getImage().getStroke(), e = ol.color.asArray(t.getColor());
|
||
return parseFloat(e[3])
|
||
}
|
||
|
||
setStrokeColor(t) {
|
||
var e = this.getStyle(), i = e.getImage().getStroke(), r = ol.color.asArray(i.getColor())[3],
|
||
o = ol.color.asArray(t);
|
||
o[3] = r, i.setColor(o), this.setStyle(e)
|
||
}
|
||
|
||
setStrokeWidth(t) {
|
||
var e = this.getStyle();
|
||
e.getImage().getStroke().setWidth(t), this.setStyle(e)
|
||
}
|
||
|
||
setStrokeOpacity(t) {
|
||
ol.asserts.assert(t >= 0 && t <= 1, "设置的透明度必须在[0,1]范围内");
|
||
var e = this.getStyle(), i = e.getImage().getStroke(), r = ol.color.asArray(i.getColor());
|
||
r[3] = t, i.setColor(r), this.setStyle(e)
|
||
}
|
||
};
|
||
|
||
class oS extends oC {
|
||
constructor(t, e, i) {
|
||
var r, o, n = "";
|
||
if (vC.isString(t)) {
|
||
var s = t.split(";");
|
||
o = [];
|
||
for (var a = 0; a < s.length; a++) {
|
||
for (var l = s[a].split(","), h = [], u = 0; u < l.length - 1; u++) h.push([parseFloat(l[u]), parseFloat(l[u + 1])]), u++;
|
||
o.push(h)
|
||
}
|
||
n = t
|
||
} else if (Array.isArray(t)) {
|
||
o = [];
|
||
for (a = 0; a < t.length; a++) {
|
||
for (h = [], u = 0; u < t[a].length; u++) t[a][u] instanceof rC ? (n += t[a][u].toStringXY(), h.push(t[a][u].getCoordinate())) : (n += t[a][u][0] + "," + t[a][u][1], h.push(t[a][u])), u !== t[a].length - 1 && (n += ",");
|
||
o.push(h), a !== t.length - 1 && (n += ";")
|
||
}
|
||
} else ol.asserts.assert(!1, "坐标格式不对");
|
||
var c = e || {};
|
||
if (super({geometry: new ol.geom.Polygon(o)}), vC.isDef(e)) {
|
||
var p = vC.isDef(c.fillColor) ? c.fillColor : "#FFFFFF", d = super.hexToRgb_(p);
|
||
d[3] = vC.isDef(c.fillOpacity) ? c.fillOpacity : .5;
|
||
var f = ol.color.asArray(vC.isDef(c.strokeColor) ? c.strokeColor : "#FFCC33");
|
||
f[3] = vC.isDef(c.strokeOpacity) ? c.strokeOpacity : 1;
|
||
var g = vC.isDef(c.strokeLineDash) ? c.strokeLineDash : void 0;
|
||
r = new ol.style.Style({
|
||
fill: new ol.style.Fill({color: d}),
|
||
stroke: new ol.style.Stroke({
|
||
color: f,
|
||
width: vC.isDef(c.strokeWidth) ? parseInt(c.strokeWidth) : 2,
|
||
lineDash: g
|
||
})
|
||
})
|
||
} else r = new ol.style.Style({
|
||
fill: new ol.style.Fill({color: [255, 255, 255, .5]}),
|
||
stroke: new ol.style.Stroke({color: [255, 204, 51, 1], width: 2})
|
||
});
|
||
this.coordString = n, this.polygonFlag = !0, this.setStyle(r);
|
||
var m = i || {};
|
||
m.draggable && this.set("draggable", m.draggable)
|
||
}
|
||
|
||
readGeoJSON(t, e) {
|
||
var i = super.readGeoJSON(t).getGeometry().getCoordinates();
|
||
return new oS(i, e)
|
||
}
|
||
|
||
getCenter() {
|
||
var t = this.getGeometry().getInteriorPoint().getCoordinates();
|
||
return new rC(t[0], t[1])
|
||
}
|
||
|
||
getPoints() {
|
||
var t = this.getGeometry().getCoordinates();
|
||
return t.map(function (t) {
|
||
t.pop()
|
||
}), t
|
||
}
|
||
|
||
getArea() {
|
||
for (var t = [], e = this.coordString.split(","), i = 0; i < e.length / 2; i++) {
|
||
var r = [e[2 * i], e[2 * i + 1]];
|
||
t[i] = r
|
||
}
|
||
var o = new ol.geom.Polygon([t]), n = Math.abs(fe(o, {radius: 6378137}));
|
||
return Math.round(1e4 * n) + " km<sup>2</sup>"
|
||
}
|
||
}
|
||
|
||
var nS = oS;
|
||
var sS = class extends oC {
|
||
constructor(t, e, i) {
|
||
var r, o, n = "";
|
||
if (vC.isString(t)) {
|
||
var s = t.split(",");
|
||
r = [];
|
||
for (var a = 0; a < s.length - 1; a++) r.push([parseFloat(s[a]), parseFloat(s[a + 1])]), a++;
|
||
n = t
|
||
} else if (Array.isArray(t)) {
|
||
r = [];
|
||
for (var l = 0; l < t.length; l++) t[l] instanceof rC ? (n += t[l].toStringXY(), r.push(t[l].getCoordinate())) : (n += t[l][0] + "," + t[l][1], r.push(t[l])), l !== t.length - 1 && (n += ",")
|
||
} else ol.asserts.assert(!1, "坐标格式不对");
|
||
var h = e || {};
|
||
if (super({geometry: new ol.geom.LineString(r)}), vC.isDef(e)) {
|
||
var u = vC.isDef(h.strokeColor) ? h.strokeColor : "#FFCC33", c = super.hexToRgb_(u);
|
||
c[3] = vC.isDef(h.strokeOpacity) ? h.strokeOpacity : 1;
|
||
var p = vC.isDef(h.strokeLineDash) ? h.strokeLineDash : void 0;
|
||
o = new ol.style.Style({
|
||
stroke: new ol.style.Stroke({
|
||
color: c,
|
||
width: vC.isDef(h.strokeWidth) ? parseInt(h.strokeWidth) : 2,
|
||
lineDash: p
|
||
})
|
||
})
|
||
} else o = new ol.style.Style({stroke: new ol.style.Stroke({color: [255, 204, 51, 1], width: 2})});
|
||
this.coordString = n, this.polylineFlag = !0, this.setStyle(o);
|
||
var d = i || {};
|
||
d.draggable && this.set("draggable", d.draggable), this.onHandleChange = this.onHandleChange.bind(this)
|
||
}
|
||
|
||
onHandleChange(t) {
|
||
var e = this.getGeometry().getLastCoordinate(), i = this.pointFeature_.getGeometry(),
|
||
r = i.getCoordinates();
|
||
e[0] !== r[0] && e[1] !== r[1] && i.setCoordinates(e)
|
||
}
|
||
|
||
onRemove(t) {
|
||
this.map_ = null;
|
||
var e = t.getVectorLayers(), i = this;
|
||
e.getLayers().forEach(function (t, e, r) {
|
||
if ("vector_default" === t.get("name")) {
|
||
var o = t;
|
||
i.pointFeature_ && (o.getSource().removeFeature(i.pointFeature_), i.un("change", i.onHandleChange), delete i.pointFeature_), o.getSource().removeFeature(i)
|
||
}
|
||
})
|
||
}
|
||
|
||
show() {
|
||
if (!this.get("isAddToMap")) {
|
||
var t = this.map_.getVectorLayers(), e = this;
|
||
t.getLayers().forEach(function (t, i, r) {
|
||
if ("vector_default" === t.get("name")) {
|
||
var o = t;
|
||
e.pointFeature_ && o.getSource().addFeature(e.pointFeature_), o.getSource().addFeature(e)
|
||
}
|
||
}), this.set("isAddToMap", !0)
|
||
}
|
||
}
|
||
|
||
hide() {
|
||
if (this.get("isAddToMap")) {
|
||
var t = this.map_.getVectorLayers(), e = this;
|
||
t.getLayers().forEach(function (t, i, r) {
|
||
if ("vector_default" === t.get("name")) {
|
||
var o = t;
|
||
e.pointFeature_ && o.getSource().removeFeature(e.pointFeature_), o.getSource().removeFeature(e)
|
||
}
|
||
}), this.set("isAddToMap", !1)
|
||
}
|
||
}
|
||
|
||
getFirstPoint() {
|
||
var t = this.getPoints();
|
||
return new rC(t[0][0], t[0][1])
|
||
}
|
||
|
||
getCenter() {
|
||
var t = this.getGeometry().getCoordinates(), e = t.length, i = e % 2;
|
||
if (1 === i) {
|
||
var r = t[Math.floor(e / 2)];
|
||
return new rC(r[0], r[1])
|
||
}
|
||
if (0 === i) {
|
||
var o = t[e / 2 - 1], n = t[e / 2];
|
||
return r = [(o[0] + n[0]) / 2, (o[1] + n[1]) / 2], new rC(r[0], r[1])
|
||
}
|
||
ol.asserts.assert(!1, "线段的长度存在异常值")
|
||
}
|
||
|
||
getFillColor() {
|
||
}
|
||
|
||
getFillOpacity() {
|
||
}
|
||
|
||
setFillColor(t) {
|
||
}
|
||
|
||
setFillOpacity(t) {
|
||
}
|
||
|
||
setStrokeColor(t) {
|
||
var e = this.getStyle(), i = this.getStrokeStyle_(), r = ol.color.asArray(i.getColor())[3],
|
||
o = ol.color.asArray(t);
|
||
if (o[3] = r, i.setColor(o), this.setStyle(e), this.pointFeature_) {
|
||
var n = this.pointFeature_.getStyle().getImage(), s = new ol.style.Style({
|
||
image: new ol.style.RegularShape({
|
||
fill: new ol.style.Fill({color: o}),
|
||
stroke: new ol.style.Stroke({color: o, width: 1}),
|
||
points: 3,
|
||
radius: n.getRadius(),
|
||
rotation: n.getRotation(),
|
||
angle: Math.PI / 2
|
||
})
|
||
});
|
||
this.pointFeature_.setStyle(s)
|
||
}
|
||
}
|
||
|
||
setStrokeOpacity(t) {
|
||
vC.asserts.assert(t >= 0 && t <= 1, "设置的透明度必须在[0,1]范围内");
|
||
var e = this.getStyle(), i = this.getStrokeStyle_(), r = ol.color.asArray(i.getColor());
|
||
if (r[3] = t, i.setColor(r), this.setStyle(e), this.pointFeature_) {
|
||
var o = this.pointFeature_.getStyle().getImage(), n = new ol.style.Style({
|
||
image: new ol.style.RegularShape({
|
||
fill: new ol.style.Fill({color: r}),
|
||
stroke: new ol.style.Stroke({color: r, width: 1}),
|
||
points: 3,
|
||
radius: o.getRadius(),
|
||
rotation: o.getRotation(),
|
||
angle: Math.PI / 2
|
||
})
|
||
});
|
||
this.pointFeature_.setStyle(n)
|
||
}
|
||
}
|
||
|
||
getPoints() {
|
||
return this.getGeometry().getCoordinates()
|
||
}
|
||
|
||
addArrowHead(t) {
|
||
var e = t || {};
|
||
if (!this.get("isArrowHead")) {
|
||
var i = this.getGeometry().getCoordinates(), r = this.map_, o = i.length, n = i[o - 2],
|
||
s = i[o - 1], a = s[0] - n[0], l = s[1] - n[1], h = Math.atan2(l, a);
|
||
h = h > 0 ? (360 - 180 * parseFloat(h) / Math.PI) * Math.PI / 180 : Math.abs(Number(h));
|
||
var u = this.getStyle().getStroke().getColor(), c = new ol.style.Fill({color: u}),
|
||
p = new ol.style.Stroke({color: u, width: 1}), d = new ol.style.Style({
|
||
image: new ol.style.RegularShape({
|
||
fill: c,
|
||
stroke: p,
|
||
points: 3,
|
||
radius: e.radius || 10,
|
||
rotation: h,
|
||
angle: Math.PI / 2
|
||
})
|
||
}), f = new ol.geom.Point(s), g = new ol.Feature({geometry: f});
|
||
g.setStyle(d), r.getVectorLayers().getLayers().forEach(function (t, e, i) {
|
||
"vector_default" === t.get("name") && t.getSource().addFeature(g)
|
||
}), this.pointFeature_ = g, this.set("isArrowHead", !0), this.on("change", this.onHandleChange)
|
||
}
|
||
}
|
||
|
||
removeArrowHead() {
|
||
if (this.pointFeature_) {
|
||
this.un("change", this.onHandleChange);
|
||
var t = this.map_.getVectorLayers(), e = this;
|
||
t.getLayers().forEach(function (t, i, r) {
|
||
if ("vector_default" === t.get("name")) {
|
||
var o = t;
|
||
e.pointFeature_ && (o.getSource().removeFeature(e.pointFeature_), delete e.pointFeature_)
|
||
}
|
||
})
|
||
}
|
||
}
|
||
|
||
getArrowHeadPositions(t) {
|
||
if (this.get("isArrowHead")) {
|
||
var e = this.pointFeature_, i = e.getStyle().getImage(), r = e.getGeometry().getCoordinates(),
|
||
o = i.getRotation(), n = i.getRadius(), s = this.map_, a = s.getZoom(), l = a - (t = t || a);
|
||
l > 0 ? n = Math.pow(2, l) * n : l < 0 && (n = 1 / Math.pow(2, -l) * n);
|
||
var h = s.getPixelFromCoordinate(r);
|
||
if (h) return this.batchPixelsToCoordinates_(s, this.calcVertexs_(h, n, o))
|
||
}
|
||
}
|
||
|
||
calcVertexs_(t, e, i) {
|
||
var r = t[0], o = t[1];
|
||
return [[r + e * Math.cos(i), o + e * Math.sin(i)], [r - e * Math.cos(Math.PI / 3 - i), o + e * Math.sin(Math.PI / 3 - i)], [r + e * Math.cos(Math.PI / 3 * 2 - i), o - e * Math.sin(Math.PI / 3 * 2 - i)]]
|
||
}
|
||
|
||
batchPixelsToCoordinates_(t, e) {
|
||
for (var i = [], r = 0; r < e.length; r++) {
|
||
var o = t.getCoordinateFromPixel(e[r]);
|
||
i.push(o[0]), i.push(o[1])
|
||
}
|
||
return i.join(",")
|
||
}
|
||
};
|
||
var aS = class extends oC {
|
||
constructor(t, e, i) {
|
||
var r, o = [], n = "";
|
||
if (vC.isString(t)) {
|
||
var s = t.split(",");
|
||
4 === s.length ? (n += t, o.push([parseFloat(s[0]), parseFloat(s[1])]), o.push([parseFloat(s[0]), parseFloat(s[3])]), o.push([parseFloat(s[2]), parseFloat(s[3])]), o.push([parseFloat(s[2]), parseFloat(s[1])]), o.push([parseFloat(s[0]), parseFloat(s[1])])) : (n += t, o.push([parseFloat(s[0]), parseFloat(s[1])]), o.push([parseFloat(s[2]), parseFloat(s[3])]), o.push([parseFloat(s[4]), parseFloat(s[5])]), o.push([parseFloat(s[6]), parseFloat(s[7])]), o.push([parseFloat(s[0]), parseFloat(s[1])]))
|
||
} else Array.isArray(t) ? t[0] instanceof rC ? (o.push(t[0].getCoordinate()), n += t[0].getCoordinate(), o.push(t[1].getCoordinate()), n += ",", o.push(t[2].getCoordinate()), n += t[2].getCoordinate(), o.push(t[3].getCoordinate()), o.push(t[0].getCoordinate())) : (t = t[0], o.push(t[0]), n += t[0][0] + "," + t[2][1] + ",", o.push(t[1]), o.push(t[2]), n += t[2][0] + "," + t[0][1], o.push(t[3]), o.push(t[0])) : ol.asserts.assert(!1, "坐标格式不对");
|
||
var a = e || {};
|
||
if (o = [o], super({geometry: new ol.geom.Polygon(o)}), vC.isDef(e)) {
|
||
var l = vC.isDef(a.fillColor) ? a.fillColor : "#FFFFFF", h = super.hexToRgb_(l);
|
||
h[3] = vC.isDef(a.fillOpacity) ? a.fillOpacity : .5;
|
||
var u = vC.isDef(a.strokeColor) ? a.strokeColor : "#FFCC33", c = super.hexToRgb_(u);
|
||
c[3] = vC.isDef(a.strokeOpacity) ? a.strokeOpacity : 1;
|
||
var p = vC.isDef(a.strokeLineDash) ? a.strokeLineDash : void 0;
|
||
r = new ol.style.Style({
|
||
fill: new ol.style.Fill({color: h}),
|
||
stroke: new ol.style.Stroke({
|
||
color: c,
|
||
width: vC.isDef(a.strokeWidth) ? parseInt(a.strokeWidth) : 2,
|
||
lineDash: p
|
||
})
|
||
})
|
||
} else r = new ol.style.Style({
|
||
fill: new ol.style.Fill({color: [255, 255, 255, .5]}),
|
||
stroke: new ol.style.Stroke({color: [255, 204, 51, 1], width: 2})
|
||
});
|
||
this.coordString = n, this.rectFlag = !0, this.setStyle(r);
|
||
var d = i || {};
|
||
d.draggable && this.set("draggable", d.draggable)
|
||
}
|
||
|
||
getCenter() {
|
||
var t = this.getGeometry().getExtent(), e = ol.extent.getCenter(t);
|
||
return new rC(e[0], e[1])
|
||
}
|
||
|
||
getPoints() {
|
||
var t = this.getGeometry().getCoordinates();
|
||
return t.map(function (t) {
|
||
t.pop()
|
||
}), t
|
||
}
|
||
};
|
||
var lS = class extends ol.layer.Vector {
|
||
constructor(t) {
|
||
var e = t || {}, i = e.projection ? e.projection : "EPSG:4326", r = e.opacity ? e.opacity : 1,
|
||
o = Ez.Layer.Cluster.getResolution(e.maxZoom ? e.maxZoom : 18),
|
||
n = Ez.Layer.Cluster.getResolution(e.minZoom ? e.minZoom : 0), s = e.cluster ? e.cluster : {},
|
||
a = new ol.source.Vector;
|
||
super({
|
||
projection: i,
|
||
opacity: r,
|
||
minResolution: o,
|
||
maxResolution: n,
|
||
source: new ol.source.Cluster2({
|
||
geometryFunction: s.geometryFunction,
|
||
distance: s.distance ? s.distance : 40,
|
||
source: a,
|
||
minClusterNum: e.minClusterNum ? e.minClusterNum : 1
|
||
})
|
||
});
|
||
var l = e.type ? e.type : "default", h = {
|
||
default: this.styleFunctionDefault.bind(this),
|
||
scale: this.styleFunctionScale.bind(this),
|
||
nomarker: this.styleFunctionNoMarker.bind(this)
|
||
}, u = e.styleFunction ? e.styleFunction : h[l];
|
||
super.setStyle(u), this.minClusterNum = e.minClusterNum ? e.minClusterNum : 1, this.icon = e.icon ? e.icon : null, this.styleCache = {}, this.currentResolution_, this.maxFeatureCount_
|
||
}
|
||
|
||
styleFunctionDefault(t) {
|
||
var e = t.get("features").length, i = this.styleCache[e], r = new ol.style.Circle({
|
||
radius: 15,
|
||
stroke: new ol.style.Stroke({color: "#fff"}),
|
||
fill: new ol.style.Fill({color: "#3399CC"})
|
||
});
|
||
return i || (i = new ol.style.Style({
|
||
image: this.icon ? this.icon : r,
|
||
text: new ol.style.Text({text: e.toString(), fill: new ol.style.Fill({color: "#fff"})})
|
||
}), this.styleCache[e] = i), e > this.minClusterNum ? i : t.get("features")[0].getStyle()
|
||
}
|
||
|
||
styleFunctionNoMarker(t) {
|
||
var e = t.get("features").length, i = this.styleCache[e], r = new ol.style.Circle({
|
||
radius: 15,
|
||
stroke: new ol.style.Stroke({color: "#fff"}),
|
||
fill: new ol.style.Fill({color: "#F15D2D"})
|
||
});
|
||
return i || (i = new ol.style.Style({
|
||
image: this.icon ? this.icon : r,
|
||
text: new ol.style.Text({text: e.toString(), fill: new ol.style.Fill({color: "#fff"})})
|
||
}), this.styleCache[e] = i), i
|
||
}
|
||
|
||
styleFunctionScale(t, e) {
|
||
var i = new ol.style.Fill({color: "#fff"}),
|
||
r = new ol.style.Stroke({color: "rgba(0, 0, 0, 0.6)", width: 3});
|
||
e != this.currentResolution_ && (this.calculateClusterInfo_(e), this.currentResolution_ = e);
|
||
var o = t.get("features").length, n = new ol.style.Circle({
|
||
radius: t.get("radius"),
|
||
fill: new ol.style.Fill({color: [255, 153, 0, Math.min(.8, .4 + o / this.maxFeatureCount_)]})
|
||
});
|
||
return this.icon && (this.icon.scale_ = .5 + o / this.maxFeatureCount_ * .5), o > this.minClusterNum ? new ol.style.Style({
|
||
image: this.icon ? this.icon : n,
|
||
text: new ol.style.Text({text: o.toString(), fill: i, stroke: r})
|
||
}) : t.get("features")[0].getStyle()
|
||
}
|
||
|
||
calculateClusterInfo_(t) {
|
||
this.maxFeatureCount_ = 0;
|
||
for (var e, i, r = this.getSource().getFeatures(), o = r.length - 1; o >= 0; --o) {
|
||
var n = (e = r[o]).get("features");
|
||
if (null != n && null != n.length) {
|
||
var s, a, l = ol.extent.createEmpty();
|
||
for (s = 0, a = n.length; s < a; ++s) ol.extent.extend(l, n[s].getGeometry().getExtent());
|
||
this.maxFeatureCount_ = Math.max(this.maxFeatureCount_, a), i = .25 * (ol.extent.getWidth(l) + ol.extent.getHeight(l)) / t, e.set("radius", i)
|
||
}
|
||
}
|
||
}
|
||
|
||
static getResolution(t) {
|
||
return ol.tilegrid.createXYZ({
|
||
extent: ol.tilegrid.extentFromProjection("EPSG:4326"),
|
||
tileSize: 256
|
||
}).getResolution(t)
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t, t.getTileLayerOverlayLayers().getLayers().push(this)
|
||
}
|
||
|
||
onRemove(t) {
|
||
this.map_ = null, t.getTileLayerOverlayLayers().getLayers().remove(this)
|
||
}
|
||
|
||
addData(t) {
|
||
this.getSource().getSource().addFeatures(t)
|
||
}
|
||
};
|
||
var hS = class extends ol.layer.Group {
|
||
constructor(t) {
|
||
super(t), this.set("isAddToMap", !1)
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t, t.getTileLayers().getLayers().push(this), this.set("isAddToMap", !0)
|
||
}
|
||
|
||
onRemove(t) {
|
||
this.get("isAddToMap") && (this.map_ = null, t.getTileLayers().getLayers().remove(this), this.set("isAddToMap", !1))
|
||
}
|
||
|
||
push(t) {
|
||
this.getLayers().push(t)
|
||
}
|
||
|
||
remove(t) {
|
||
this.getLayers().remove(t)
|
||
}
|
||
|
||
clear() {
|
||
this.getLayers().clear()
|
||
}
|
||
|
||
show() {
|
||
this.setVisible(!0)
|
||
}
|
||
|
||
hide() {
|
||
this.setVisible(!1)
|
||
}
|
||
};
|
||
var uS = class extends ol.layer.Heatmap {
|
||
constructor(t) {
|
||
ol.asserts.assert(vC.isDef(t), "config参数不能为空");
|
||
var e = t.radius || 8, i = t.blur || 15, r = t.shadow || 250, o = t.weight, n = t.opacity || 1,
|
||
s = t.extent || void 0, a = t.gradient || void 0, l = t.isProj_ || !1,
|
||
h = t.source || new ol.source.Vector;
|
||
super({
|
||
source: h,
|
||
radius: e,
|
||
blur: i,
|
||
projection: l ? "EPSG:3857" : "EPSG:4326",
|
||
weight: o,
|
||
shadow: r,
|
||
opacity: n,
|
||
extent: s,
|
||
gradient: a
|
||
}), this.blur_ = i, this.radius_ = e, this.shadow_ = r, this.weight_ = o, this.opacity_ = n, this.extent_ = s, this.source_ = h, this.isProj_ = l, this.set("name", "heatmap"), this.set("isAddToMap", !1), this.xField_ = t.xField || null, this.yField_ = t.yField || null, this.valueField_ = t.valueField || null, this.map_ = null
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t, t.getVectorLayers().getLayers().push(this), this.set("isAddToMap", !0)
|
||
}
|
||
|
||
onRemove(t) {
|
||
if (this.get("isAddToMap")) {
|
||
this.map_ = null;
|
||
var e = t.getVectorLayers().getLayers(), i = this;
|
||
e.forEach(function (t) {
|
||
i === t && e.remove(t)
|
||
}), this.set("isAddToMap", !1)
|
||
}
|
||
}
|
||
|
||
show() {
|
||
this.setVisible(!0)
|
||
}
|
||
|
||
hide() {
|
||
this.setVisible(!1)
|
||
}
|
||
|
||
addData(t) {
|
||
var e = this.xField_, i = this.yField_, r = this.valueField_, o = new ol.source.Vector;
|
||
for (var n in ol.asserts.assert(!vC.isNull(e), "xField值必须指定"), ol.asserts.assert(!vC.isNull(i), "yField值必须指定"), ol.asserts.assert(!vC.isNull(r), "valueField值必须指定"), t) {
|
||
var s = t[n], a = new ol.geom.Point([s[e], s[i]]), l = new ol.Feature({geometry: a});
|
||
l.set("weight", s[r]), o.addFeature(l)
|
||
}
|
||
this.setSource(o)
|
||
}
|
||
};
|
||
var cS = class extends ol.layer.Image {
|
||
constructor(t) {
|
||
var e = t || {}, i = {
|
||
url: e.url,
|
||
serverType: e.serverType ? e.serverType : "mapserver",
|
||
params: e.params ? e.params : void 0,
|
||
imageLoadFunction: e.imageLoadFunction ? e.imageLoadFunction : void 0,
|
||
ratio: e.ratio ? e.ratio : void 0,
|
||
projection: e.projection ? e.projection : "EPSG:4326"
|
||
};
|
||
super({
|
||
source: new ol.source.ImageWMS(i),
|
||
extent: e.mbr ? e.mbr : void 0,
|
||
opacity: e.opacity ? e.opacity : 1
|
||
})
|
||
}
|
||
|
||
onAdd(t) {
|
||
this.map_ = t, t.getTileLayerOverlayLayers().getLayers().push(this)
|
||
}
|
||
|
||
onRemove(t) {
|
||
this.map_ = null, t.getTileLayerOverlayLayers().getLayers().remove(this)
|
||
}
|
||
};
|
||
var pS = class extends ol.style.Circle {
|
||
constructor(t) {
|
||
super(t)
|
||
}
|
||
};
|
||
var dS = class extends ol.style.Fill {
|
||
constructor(t) {
|
||
super(t)
|
||
}
|
||
};
|
||
var fS = class extends ol.style.Icon {
|
||
constructor(t) {
|
||
super(t)
|
||
}
|
||
};
|
||
var gS = class extends ol.style.Stroke {
|
||
constructor(t) {
|
||
super(t)
|
||
}
|
||
};
|
||
var mS = class extends ol.style.Style {
|
||
constructor(t) {
|
||
super(t)
|
||
}
|
||
};
|
||
var yS = class extends ol.style.Text {
|
||
constructor(t) {
|
||
super(t)
|
||
}
|
||
};
|
||
var vS = class extends ol.format.TextFeature {
|
||
constructor(t, e, i, r, o) {
|
||
super(), this.type_ = t, this.icon_ = e, this.clusterstyle_ = i, this.icongroup = r, this.clusterKeyName = o
|
||
}
|
||
|
||
readFeatureFromText(t) {
|
||
return []
|
||
}
|
||
|
||
readFeaturesFromText(t) {
|
||
var e, i, r, o = [], n = t.split("\r\n");
|
||
this.icon_ && (r = this.icon_);
|
||
for (var s = this.type_.trim(), a = 0; a < n.length; a++) if (n[a] && n[a].length > 0) {
|
||
i = JSON.parse(n[a]), e = new rC(i.X, i.Y);
|
||
var l = this.matchType(s, i);
|
||
null === l && new Error("输入的数据格式不正确!无法解析");
|
||
var h = new EzMarker(e, r, l.title);
|
||
for (var u in l.weight > 1 ? h.setStyle(this.calStyle(l.weight)) : l.videoDire && l.videoType && l.status && h.setIcon(this.getMarkerStyle(l.videoType, l.videoDire, l.status)), h.setId(i.ID), h.set("type_name", "hotspot"), h.set("nativeObject", i), l) "title" !== u && h.set(u, l[u]);
|
||
o.push(h)
|
||
}
|
||
return o
|
||
}
|
||
|
||
getMarkerStyle(t, e, i) {
|
||
var r = this.icongroup, o = {"东": 0, "南": 90, "西": 180, "北": 270}[e], n = r[t];
|
||
n || new Error("该类型不在你定义的图标集合中");
|
||
var s = n.getOptions(), a = s.src, l = a;
|
||
0 === parseInt(i) && (l = a.substring(0, a.lastIndexOf(".")) + "_no" + a.substring(a.lastIndexOf(".")));
|
||
var h = Object.assign({}, s, {src: l, rotation: o});
|
||
return new EzIcon(h)
|
||
}
|
||
|
||
calStyle(t) {
|
||
for (var e = this.clusterstyle_, i = e.threshold, r = e.thresholdColor, o = i.length - 1; o >= 0; o--) if (t >= i[o]) return this.calClusterStyle(t, r[o]);
|
||
return this.calClusterStyle(t)
|
||
}
|
||
|
||
calClusterStyle(t, e) {
|
||
var i = this.clusterstyle_, r = vC.isDef(i.fill) ? i.fill : "#7A9DF6",
|
||
o = vC.isDef(i.stroke) ? i.stroke : "#fff", n = vC.isDef(i.textFill) ? i.textFill : "#fff",
|
||
s = vC.isDef(i.radius) ? i.radius : 15;
|
||
return new ol.style.Style({
|
||
image: new ol.style.Circle({
|
||
fill: new ol.style.Fill({color: e || r}),
|
||
stroke: new ol.style.Stroke({color: o}),
|
||
radius: s
|
||
}), text: new ol.style.Text({fill: new ol.style.Fill({color: n}), text: t.toString()})
|
||
})
|
||
}
|
||
|
||
readProjection() {
|
||
return new ol.proj.get("EPSG:4326")
|
||
}
|
||
|
||
matchType(t, e) {
|
||
var i = this.clusterKeyName;
|
||
switch (t) {
|
||
case"jsonv1":
|
||
return {
|
||
title: e.LABEL,
|
||
weight: e.WEIGHT,
|
||
bbox: e.BBOX,
|
||
videoType: e.customs[i],
|
||
status: e.customs.STATUS,
|
||
videoDire: e.customs.VIDEO_DIRE,
|
||
customs: e.customs
|
||
};
|
||
case"jsonv1s":
|
||
return {
|
||
title: e.LABEL,
|
||
weight: e.WEIGHT,
|
||
bbox: e.BBOX,
|
||
videoType: e.customs[i],
|
||
status: e.customs.STATUS,
|
||
videoDire: e.customs.VIDEO_DIRE
|
||
};
|
||
case"jsonv2":
|
||
return {
|
||
title: e.name,
|
||
weight: e.weight,
|
||
bbox: e.bbox,
|
||
address: e.address,
|
||
layer: e.layer,
|
||
customs: e.customs
|
||
};
|
||
case"jsonv2s":
|
||
return {title: e.name, weight: e.weight, bbox: e.bbox, address: e.address, layer: e.layer}
|
||
}
|
||
return null
|
||
}
|
||
};
|
||
var _S = class extends ol.format.TextFeature {
|
||
constructor(t, e, i, r) {
|
||
super(), this.type_ = t, this.icon_ = e, this.scaleFactor_ = r || 1, this.scale_ = i || !1
|
||
}
|
||
|
||
readFeatureFromText(t) {
|
||
return []
|
||
}
|
||
|
||
readFeaturesFromText(t) {
|
||
var e, i, r, o = [], n = t.split("\r\n");
|
||
this.icon_ && (r = this.icon_);
|
||
for (var s = this.type_.trim(), a = 0; a < n.length; a++) if (n[a] && n[a].length > 0) {
|
||
i = JSON.parse(n[a]), e = new rC(i.X, i.Y);
|
||
var l = this.matchType(s, i);
|
||
if (null === l && new Error("输入的数据格式不正确!无法解析"), this.scale_) {
|
||
var h = r.getOptions(),
|
||
u = Object.assign({}, h, {scale: Math.pow(l.weight, .1) * this.scaleFactor_});
|
||
r = new EzIcon(u)
|
||
}
|
||
var c = new EzMarker(e, r, l.title);
|
||
for (var p in c.setId(i.ID), c.set("type_name", "hotspot"), c.set("nativeObject", i), l) "title" !== p && c.set(p, l[p]);
|
||
o.push(c)
|
||
}
|
||
return o
|
||
}
|
||
|
||
readProjection() {
|
||
return new ol.proj.get("EPSG:4326")
|
||
}
|
||
|
||
matchType(t, e) {
|
||
switch (t) {
|
||
case"jsonv1":
|
||
return {title: e.LABEL, weight: e.WEIGHT, bbox: e.BBOX, customs: e.customs};
|
||
case"jsonv1s":
|
||
return {title: e.LABEL, weight: e.WEIGHT, bbox: e.BBOX};
|
||
case"jsonv2":
|
||
return {
|
||
title: e.name,
|
||
weight: e.weight,
|
||
bbox: e.bbox,
|
||
address: e.address,
|
||
layer: e.layer,
|
||
customs: e.customs
|
||
};
|
||
case"jsonv2s":
|
||
return {title: e.name, weight: e.weight, bbox: e.bbox, address: e.address, layer: e.layer}
|
||
}
|
||
return null
|
||
}
|
||
};
|
||
|
||
class xS extends ol.interaction.Pointer {
|
||
constructor(t) {
|
||
super({handleDownEvent: xS.handleDownEvent_});
|
||
var e = vC.isDef(t) ? t : {}, i = document.createElement("div"), r = document.createTextNode("test");
|
||
i.appendChild(r), i.style.marginLeft = -5, i.style.marginTop = -3, this.overlay_ = vC.isDef(e.overlay) ? e.overlay : new ol.Overlay({element: i})
|
||
}
|
||
|
||
handleDownEvent_(t) {
|
||
if (t.browserEvent.isMouseActionButton()) {
|
||
var e = t.coordinate, i = t.map;
|
||
return this.overlay_.setPosition(e), i.addOverlay(this.overlay_), !0
|
||
}
|
||
return !1
|
||
}
|
||
}
|
||
|
||
var wS = xS;
|
||
|
||
class bS extends ol.interaction.Pointer {
|
||
constructor() {
|
||
super({
|
||
handleDownEvent: bS.handleDownEvent,
|
||
handleDragEvent: bS.handleDragEvent,
|
||
handleMoveEvent: bS.handleMoveEvent,
|
||
handleUpEvent: bS.handleUpEvent
|
||
}), this.coordinate_ = null, this.cursor_ = "pointer", this.feature_ = null, this.previousCursor_ = void 0
|
||
}
|
||
|
||
handleDownEvent(t) {
|
||
var e = t.map.forEachFeatureAtPixel(t.pixel, function (t) {
|
||
return t
|
||
});
|
||
return !(!e || !e.get("draggable")) && (this.coordinate_ = t.coordinate, this.feature_ = e, this.feature_ instanceof EzMarker && this.feature_.dispatchEvent(new _C("dragstart")), !0)
|
||
}
|
||
|
||
handleDragEvent(t) {
|
||
var e = t.coordinate[0] - this.coordinate_[0], i = t.coordinate[1] - this.coordinate_[1];
|
||
this.feature_.getGeometry().translate(e, i), this.coordinate_[0] = t.coordinate[0], this.coordinate_[1] = t.coordinate[1]
|
||
}
|
||
|
||
handleMoveEvent(t) {
|
||
if (this.cursor_) {
|
||
var e = t.map.forEachFeatureAtPixel(t.pixel, function (t) {
|
||
return t
|
||
}), i = t.map.getTargetElement();
|
||
e ? i.style.cursor != this.cursor_ && (this.previousCursor_ = i.style.cursor, i.style.cursor = this.cursor_) : void 0 !== this.previousCursor_ && (i.style.cursor = this.previousCursor_, this.previousCursor_ = void 0)
|
||
}
|
||
}
|
||
|
||
handleUpEvent() {
|
||
return this.feature_ instanceof EzMarker && this.feature_.dispatchEvent(new _C("dragend")), this.coordinate_ = null, this.feature_ = null, !1
|
||
}
|
||
}
|
||
|
||
var CS = bS;
|
||
|
||
class SS extends ol.interaction.Pointer {
|
||
constructor(t, e, i) {
|
||
t || new Error("圆编辑必须指定featue对象"), super({
|
||
handleDownEvent: SS.handleDownEvent_,
|
||
handleEvent: SS.handleEvent,
|
||
handleUpEvent: SS.handleUpEvent_
|
||
}), this.target_ = t, this.overlay_ = new ol.layer.Vector({
|
||
source: new ol.source.Vector({useSpatialIndex: !1}),
|
||
style: t.getStyle()
|
||
}), this.center_ = this.target_.getCenter().getCoordinate(), this.radius_ = this.target_.getGeometry().getRadius(), this.cb_ = e || function () {
|
||
}, this.cb2_ = i || function () {
|
||
}, this.controlBtn_ = new ol.Overlay({element: this.initElement()}), this.editing = !1, this.mousedown_ = !1, this.upfn_ = this.handleUpEvent_.bind(this), this.mapport
|
||
}
|
||
|
||
initSketch() {
|
||
this.getMap().removeOverlay(this.target_);
|
||
var t = this.target_.getGeometry(), e = new ol.Feature({geometry: t});
|
||
e.setId("skectchId"), this.overlay_.getSource().addFeature(e), this.controlBtn_.setPosition([this.center_[0] + this.radius_, this.center_[1]])
|
||
}
|
||
|
||
setMap(t) {
|
||
super.setMap(t), this.updateState_()
|
||
}
|
||
|
||
updateState_() {
|
||
var t = this.getMap();
|
||
vC.isNull(t) || (t.getVectorLayers().getLayers().push(this.overlay_), t.addOverlay(this.controlBtn_, !0), this.initSketch(), this.mapport = this.getMap().getViewport(), this.mapport.addEventListener("mouseup", this.upfn_))
|
||
}
|
||
|
||
initElement() {
|
||
var t = document.createElement("div");
|
||
return t.className = "ez-editCircle-btn", t.id = "ez_editCicle_btn", t.addEventListener("mousedown", this.handleDownEvent_.bind(this)), t
|
||
}
|
||
|
||
handleEvent(t) {
|
||
if (t.type === ol.MapBrowserEventType.POINTERMOVE && this.editing) {
|
||
this.getMap();
|
||
var e = this.overlay_.getSource().getFeatureById("skectchId"), i = e.getGeometry();
|
||
this.handleDragGeom_(i, t);
|
||
var r = e.getGeometry().getCenter(), o = new Ez.Coordinate(r[0], r[1]),
|
||
n = new Ez.g.Circle(o, e.getGeometry().getRadius(), {isMeter: !0});
|
||
this.cb2_(n)
|
||
}
|
||
return !1
|
||
}
|
||
|
||
handleDragGeom_(t, e) {
|
||
var i = e.coordinate, r = this.center_;
|
||
this.controlBtn_.setPosition([i[0], r[1]]);
|
||
var o = Math.abs(i[0] - r[0]);
|
||
t.setRadius(o)
|
||
}
|
||
|
||
handleDownEvent_(t) {
|
||
this.editing = !0, this.mousedown_ = !0
|
||
}
|
||
|
||
handleUpEvent_(t) {
|
||
this.editing = !1;
|
||
var e = this.overlay_.getSource().getFeatureById("skectchId"), i = e.getGeometry().getCenter(),
|
||
r = new Ez.Coordinate(i[0], i[1]),
|
||
o = new Ez.g.Circle(r, e.getGeometry().getRadius(), {isMeter: !0});
|
||
this.cb_(o)
|
||
}
|
||
|
||
disposeAll(t) {
|
||
var e = this.getMap(), i = this.overlay_.getSource().getFeatureById("skectchId").getGeometry();
|
||
e.getViewport();
|
||
this.mapport.removeEventListener("mouseup", this.upfn_);
|
||
var r = i.getCenter(), o = new Ez.Coordinate(r[0], r[1]),
|
||
n = new Ez.g.Circle(o, i.getRadius(), {isMeter: !0});
|
||
e.removeOverlay(this.controlBtn_, !0);
|
||
var s = e.getVectorLayers().getLayers(), a = this.overlay_;
|
||
s.forEach(function (t) {
|
||
a !== t || s.remove(t)
|
||
}), this.target_.getGeometry().setRadius(n.getGeometry().getRadius()), e.addOverlay(this.target_), t(this.target_)
|
||
}
|
||
}
|
||
|
||
var ES = SS;
|
||
const TS = {POINT: "Point", LINE_STRING: "LineString", POLYGON: "Polygon", CIRCLE: "Circle"},
|
||
RS = {DRAWSTART: "drawstart", DRAWEND: "drawend"};
|
||
|
||
class PS extends A {
|
||
constructor(t, e) {
|
||
super(t), this.feature = e
|
||
}
|
||
}
|
||
|
||
var LS = class extends ol.interaction.Pointer {
|
||
constructor(t) {
|
||
super({
|
||
handleDownEvent: function (t) {
|
||
return this.condition_(t) ? (this.downPx_ = t.pixel, !0) : !(this.mode_ !== TS.LINE_STRING && this.mode_ !== TS.POLYGON || !this.freehandCondition_(t) || (this.downPx_ = t.pixel, this.freehand_ = !0, vC.isNull(this.finishCoordinate_) && this.startDrawing_(t), 0))
|
||
}, handleUpEvent: function (t) {
|
||
var e = 2 === t.pointerEvent.button;
|
||
this.freehand_ = !1;
|
||
var i = this.downPx_, r = t.pixel, o = i[0] - r[0], n = i[1] - r[1], s = !0;
|
||
return o * o + n * n <= this.squaredClickTolerance_ && (this.handlePointerMove_(t), vC.isNull(this.finishCoordinate_) ? (this.startDrawing_(t), this.mode_ === TS.POINT && this.finishDrawing()) : this.mode_ === TS.CIRCLE ? this.finishDrawing() : this.addToDrawing_(t), s = !1), e && this.atFinish_(t) && this.finishDrawing(e), s
|
||
}
|
||
});
|
||
var e = vC.isDef(t) ? t : {};
|
||
this.downPx_ = null, this.source_ = vC.isDef(e.source) ? e.source : null, this.features_ = vC.isDef(e.features) ? e.features : null, this.snapTolerance_ = vC.isDef(e.snapTolerance) ? e.snapTolerance : 12, this.type_ = e.type, this.mode_ = this.getMode_(this.type_), this.minPoints_ = vC.isDef(e.minPoints) ? e.minPoints : this.mode_ === TS.POLYGON ? 3 : 2, this.maxPoints_ = vC.isDef(e.maxPoints) ? e.maxPoints : 1 / 0, this.helpTooltipElement = null, this.helpTooltip = null, this.tip_ = !vC.isDef(e.tip) || e.tip;
|
||
var i = e.geometryFunction;
|
||
if (!vC.isDef(i)) if (this.type_ === ol.geom.GeometryType.CIRCLE) i = function (t, e) {
|
||
var i = vC.isDef(e) ? e : new ol.geom.Circle([NaN, NaN]);
|
||
i instanceof ol.geom.Circle || ol.asserts.assert(!1, "初始化geometryFunction中opt_geometry必须是一个ol.geom.Circle");
|
||
var r = ol.coordinate.squaredDistance(t[0], t[1]);
|
||
return i.setCenterAndRadius(t[0], Math.sqrt(r)), i
|
||
}; else {
|
||
var r, o = this.mode_;
|
||
o === TS.POINT ? r = ol.geom.Point : o === TS.LINE_STRING ? r = ol.geom.LineString : o === TS.POLYGON && (r = ol.geom.Polygon), i = function (t, e) {
|
||
var i = e;
|
||
return vC.isDef(i) ? i.setCoordinates(t) : i = new r(t), i
|
||
}
|
||
}
|
||
this.geometryFunction_ = i, this.finishCoordinate_ = null, this.sketchFeature_ = null, this.sketchPoint_ = null, this.sketchCoords_ = null, this.sketchLine_ = null, this.sketchLineCoords_ = null, this.squaredClickTolerance_ = vC.isDef(e.clickTolerance) ? e.clickTolerance * e.clickTolerance : 36, this.overlay_ = new ol.layer.Vector({
|
||
source: new ol.source.Vector({
|
||
useSpatialIndex: !1,
|
||
wrapX: !!vC.isDef(e.wrapX) && e.wrapX
|
||
}), style: vC.isDef(e.style) ? e.style : this.getDefaultStyleFunction()
|
||
}), this.geometryName_ = e.geometryName, this.condition_ = vC.isDef(e.condition) ? e.condition : ol.events.condition.noModifierKeys, this.freehandCondition_ = vC.isDef(e.freehandCondition) ? e.freehandCondition : ol.events.condition.shiftKeyOnly, ol.events.listen(this, ol.Object.getChangeEventType(As.ACTIVE), this.updateState_, !1, this), this.shouldStopEvent = !1
|
||
}
|
||
|
||
changeStyle_(t) {
|
||
this.addClass(this.helpTooltipElement, "hidden")
|
||
}
|
||
|
||
createHelpTooltip() {
|
||
this.helpTooltipElement && this.helpTooltipElement.parentNode.removeChild(this.helpTooltipElement), this.helpTooltipElement = document.createElement("div"), this.helpTooltipElement.className = "tooltip hidden", this.helpTooltip = new ol.Overlay({
|
||
element: this.helpTooltipElement,
|
||
offset: [15, 0],
|
||
positioning: "center-left"
|
||
}), this.getMap().addOverlay(this.helpTooltip, !0)
|
||
}
|
||
|
||
getDefaultStyleFunction() {
|
||
var t = ol.style.Style.createEditingStyle();
|
||
return function (e, i) {
|
||
return t[e.getGeometry().getType()]
|
||
}
|
||
}
|
||
|
||
setMap(t) {
|
||
super.setMap(t);
|
||
var e = this.map;
|
||
this.updateState_(), t ? (this.map = t, !1 !== this.tip_ && (this.createHelpTooltip(), this.changeStyle_ = this.changeStyle_.bind(this), t.getViewport().addEventListener("mouseout", this.changeStyle_))) : !1 !== this.tip_ && (e.removeOverlay(this.helpTooltip, !0), e.getViewport().removeEventListener("mouseout", this.changeStyle_))
|
||
}
|
||
|
||
handleEvent(t) {
|
||
var e = !this.freehand_;
|
||
return this.freehand_ && t.type === ol.MapBrowserEventType.POINTERDRAG ? (this.addToDrawing_(t), e = !1) : t.type === ol.MapBrowserEventType.POINTERMOVE ? e = this.handlePointerMove_(t) : t.type === ol.MapBrowserEventType.DBLCLICK && (e = !1), super.handleEvent(t) && e
|
||
}
|
||
|
||
handleDownEvent_(t) {
|
||
return this.condition_(t) ? (this.downPx_ = t.pixel, !0) : !(this.mode_ !== TS.LINE_STRING && this.mode_ !== TS.POLYGON || !this.freehandCondition_(t) || (this.downPx_ = t.pixel, this.freehand_ = !0, vC.isNull(this.finishCoordinate_) && this.startDrawing_(t), 0))
|
||
}
|
||
|
||
handleUpEvent_(t) {
|
||
var e = 2 === t.pointerEvent.button;
|
||
this.freehand_ = !1;
|
||
var i = this.downPx_, r = t.pixel, o = i[0] - r[0], n = i[1] - r[1], s = !0;
|
||
return o * o + n * n <= this.squaredClickTolerance_ && (this.handlePointerMove_(t), vC.isNull(this.finishCoordinate_) ? (this.startDrawing_(t), this.mode_ === TS.POINT && this.finishDrawing()) : this.mode_ === TS.CIRCLE ? this.finishDrawing() : this.addToDrawing_(t), s = !1), e && this.atFinish_(t) && this.finishDrawing(e), s
|
||
}
|
||
|
||
handlePointerMove_(t) {
|
||
return vC.isNull(this.finishCoordinate_) ? this.createOrUpdateSketchPoint_(t) : this.modifyDrawing_(t), this.updateTipTool(t, this.startDrawingFlag), !0
|
||
}
|
||
|
||
updateTipTool(t, e) {
|
||
var i = "点击开始绘制";
|
||
if (e && this.type_) {
|
||
var r = this.type_;
|
||
r === ol.geom.GeometryType.CIRCLE ? i = "移动确定半径,单击完成绘制" : r === ol.geom.GeometryType.LINE_STRING && 2 === this.maxPoints_ ? i = "移动确定长度,单击完成绘制" : r === ol.geom.GeometryType.LINE_STRING ? i = "单击确定节点,右击完成绘制" : r === ol.geom.GeometryType.POLYGON && (i = "单击确定节点,右击完成绘制")
|
||
}
|
||
this.tip_ && (this.helpTooltipElement.innerHTML = i, this.helpTooltip.setPosition(t.coordinate), this.addClass(this.helpTooltipElement, "hidden"))
|
||
}
|
||
|
||
atFinish_(t) {
|
||
var e = !1;
|
||
if (!vC.isNull(this.sketchFeature_)) {
|
||
var i = !1, r = [this.finishCoordinate_];
|
||
if (this.mode_ === TS.LINE_STRING ? i = this.sketchCoords_.length > this.minPoints_ : this.mode_ === TS.POLYGON && (i = this.sketchCoords_[0].length > this.minPoints_, r = [this.sketchCoords_[0][0], this.sketchCoords_[0][this.sketchCoords_[0].length - 2]]), i) for (var o = t.map, n = 0, s = r.length; n < s; n++) {
|
||
var a = r[n], l = o.getPixelFromCoordinate(a), h = t.pixel, u = h[0] - l[0], c = h[1] - l[1],
|
||
p = this.freehand_ && this.freehandCondition_(t) ? 1 : this.snapTolerance_;
|
||
if (e = Math.sqrt(u * u + c * c) <= p) {
|
||
this.finishCoordinate_ = a;
|
||
break
|
||
}
|
||
}
|
||
}
|
||
return e
|
||
}
|
||
|
||
createOrUpdateSketchPoint_(t) {
|
||
var e = t.coordinate.slice();
|
||
if (vC.isNull(this.sketchPoint_)) this.sketchPoint_ = new ol.Feature(new ol.geom.Point(e)), this.updateSketchFeatures_(); else {
|
||
var i = this.sketchPoint_.getGeometry();
|
||
i instanceof ol.geom.Point && i.setCoordinates(e)
|
||
}
|
||
}
|
||
|
||
startDrawing_(t) {
|
||
var e = this.getMap();
|
||
if (e) {
|
||
e.getViewport().addEventListener("contextmenu", function (t) {
|
||
return t.preventDefault(), t.stopPropagation(), !1
|
||
});
|
||
var i = t.coordinate;
|
||
this.finishCoordinate_ = i, this.mode_ === TS.POINT ? this.sketchCoords_ = i.slice() : this.mode_ === TS.POLYGON ? (this.sketchCoords_ = [[i.slice(), i.slice()]], this.sketchLineCoords_ = this.sketchCoords_[0]) : (this.sketchCoords_ = [i.slice(), i.slice()], this.mode_ === TS.CIRCLE && (this.sketchLineCoords_ = this.sketchCoords_)), vC.isNull(this.sketchLineCoords_) || (this.sketchLine_ = new ol.Feature(new ol.geom.LineString(this.sketchLineCoords_)));
|
||
var r = this.geometryFunction_(this.sketchCoords_);
|
||
ol.asserts.assert(vC.isDef(r), "geometry should be defined"), this.sketchFeature_ = new ol.Feature, vC.isDef(this.geometryName_) && this.sketchFeature_.setGeometryName(this.geometryName_), this.sketchFeature_.setGeometry(r), this.updateSketchFeatures_(), this.dispatchEvent(new PS(RS.DRAWSTART, this.sketchFeature_))
|
||
}
|
||
}
|
||
|
||
modifyDrawing_(t) {
|
||
var e, i, r, o = t.coordinate, n = this.sketchFeature_.getGeometry();
|
||
if (this.mode_ === TS.POINT ? i = this.sketchCoords_ : this.mode_ === TS.POLYGON ? (i = (e = this.sketchCoords_[0])[e.length - 1], this.atFinish_(t) && (o = this.finishCoordinate_.slice())) : i = (e = this.sketchCoords_)[e.length - 1], i[0] = o[0], i[1] = o[1], this.geometryFunction_(this.sketchCoords_, n), !vC.isNull(this.sketchPoint_)) {
|
||
var s = this.sketchPoint_.getGeometry();
|
||
s instanceof ol.geom.Point && s.setCoordinates(o)
|
||
}
|
||
if (n instanceof ol.geom.Polygon && this.mode_ !== TS.POLYGON) {
|
||
var a = n.getLinearRing(0);
|
||
vC.isNull(this.sketchLine_) && (this.sketchLine_ = new ol.Feature(new ol.geom.LineString(a.getFlatCoordinates()))), (r = this.sketchLine_.getGeometry()) instanceof ol.geom.LineString && r.setFlatCoordinates(a.getLayout(), a.getFlatCoordinates())
|
||
} else vC.isNull(this.sketchLineCoords_) || (r = this.sketchLine_.getGeometry()) instanceof ol.geom.LineString && r.setCoordinates(this.sketchLineCoords_);
|
||
this.updateSketchFeatures_(), this.startDrawingFlag = !0
|
||
}
|
||
|
||
addToDrawing_(t) {
|
||
var e, i, r = t.coordinate, o = this.sketchFeature_.getGeometry();
|
||
this.mode_ === TS.LINE_STRING ? (this.finishCoordinate_ = r.slice(), (i = this.sketchCoords_).push(r.slice()), e = i.length > this.maxPoints_, this.geometryFunction_(i, o)) : this.mode_ === TS.POLYGON && ((i = this.sketchCoords_[0]).push(r.slice()), (e = i.length > this.maxPoints_) && (this.finishCoordinate_ = i[0]), this.geometryFunction_(this.sketchCoords_, o)), this.updateSketchFeatures_(), e && this.finishDrawing()
|
||
}
|
||
|
||
finishDrawing(t) {
|
||
var e = this.abortDrawing_();
|
||
ol.asserts.assert(!vC.isNull(e), "sketchFeature should not be null");
|
||
var i = this.sketchCoords_, r = e.getGeometry();
|
||
this.mode_ === TS.LINE_STRING ? (i.pop(), t && i.pop(), this.geometryFunction_(i, r)) : this.mode_ === TS.POLYGON && (i[0].pop(), t && i[0].pop(), i[0].push(i[0][0]), this.geometryFunction_(i, r)), this.type_ === ol.geom.GeometryType.MULTI_POINT ? e.setGeometry(new ol.geom.MultiPoint([i])) : this.type_ === ol.geom.GeometryType.MULTI_LINE_STRING ? e.setGeometry(new ol.geom.MultiLineString([i])) : this.type_ === ol.geom.GeometryType.MULTI_POLYGON && e.setGeometry(new ol.geom.MultiPolygon([i])), this.dispatchEvent(new PS(RS.DRAWEND, e)), vC.isNull(this.features_) || this.features_.push(e), vC.isNull(this.source_);
|
||
var o = this.map;
|
||
!1 !== this.tip_ && (o.removeOverlay(this.helpTooltip, !0), this.helpTooltip = null), o.getViewport().removeEventListener("mouseout", this.changeStyle_), delete this.map
|
||
}
|
||
|
||
abortDrawing_() {
|
||
this.finishCoordinate_ = null;
|
||
var t = this.sketchFeature_;
|
||
return vC.isNull(t) || (this.sketchFeature_ = null, this.sketchPoint_ = null, this.sketchLine_ = null, this.overlay_.getSource().clear(!0)), t
|
||
}
|
||
|
||
updateSketchFeatures_() {
|
||
var t = [];
|
||
vC.isNull(this.sketchFeature_) || t.push(this.sketchFeature_), vC.isNull(this.sketchLine_) || t.push(this.sketchLine_), vC.isNull(this.sketchPoint_) || t.push(this.sketchPoint_);
|
||
var e = this.overlay_.getSource();
|
||
e.clear(!0), e.addFeatures(t)
|
||
}
|
||
|
||
updateState_() {
|
||
var t = this.getMap(), e = this.getActive();
|
||
!vC.isNull(t) && e || this.abortDrawing_(), this.overlay_.setMap(e ? t : null)
|
||
}
|
||
|
||
createRegularPolygon(t, e) {
|
||
return function (i, r) {
|
||
var o = i[0], n = i[1], s = Math.sqrt(ol.coordinate.squaredDistance(o, n)),
|
||
a = vC.isDef(r) ? r : ol.geom.Polygon.fromCircle(new ol.geom.Circle(o), t),
|
||
l = vC.isDef(e) ? e : Math.atan((n[1] - o[1]) / (n[0] - o[0]));
|
||
return ol.geom.Polygon.makeRegular(a, o, s, l), a
|
||
}
|
||
}
|
||
|
||
getMode_(t) {
|
||
var e;
|
||
return t === ol.geom.GeometryType.POINT || t === ol.geom.GeometryType.MULTI_POINT ? e = TS.POINT : t === ol.geom.GeometryType.LINE_STRING || t === ol.geom.GeometryType.MULTI_LINE_STRING ? e = TS.LINE_STRING : t === ol.geom.GeometryType.POLYGON || t === ol.geom.GeometryType.MULTI_POLYGON ? e = TS.POLYGON : t === ol.geom.GeometryType.CIRCLE && (e = TS.CIRCLE), ol.asserts.assert(vC.isDef(e), "mode should be defined"), e
|
||
}
|
||
|
||
addClass(t, e) {
|
||
for (var i = t.className.split(" "), r = 0; r < i.length; r++) if (i[r] === e.trim()) return;
|
||
i.push(e.trim()), t.className = i.join(" ")
|
||
}
|
||
|
||
removeClass(t, e) {
|
||
for (var i = t.className.split(" "), r = 0; r < i.length; r++) if (i[r] === e) {
|
||
i[r] = "";
|
||
break
|
||
}
|
||
var o = i.join(" ");
|
||
t.className = o
|
||
}
|
||
};
|
||
var IS = class extends ol.source.Vector {
|
||
constructor(t) {
|
||
super({
|
||
attributions: t.attributions,
|
||
extent: t.extent,
|
||
logo: t.logo,
|
||
projection: t.projection,
|
||
wrapX: t.wrapX
|
||
}), this.minClusterNum = t.minClusterNum ? t.minClusterNum : 1, this.resolution_ = void 0, this.distance_ = void 0 !== t.distance ? t.distance : 20, this.features_ = [], this.geometryFunction_ = t.geometryFunction || function (t) {
|
||
var e = t.getGeometry();
|
||
return ol.asserts.assert(e instanceof ol.geom.Point, "feature geometry is a ol.geom.Point instance"), e
|
||
}, this.source_ = t.source, this.source_.on(ol.events.EventType.CHANGE, this.onSourceChange_.bind(this), this)
|
||
}
|
||
|
||
getSource() {
|
||
return this.source_
|
||
}
|
||
|
||
loadFeatures(t, e, i) {
|
||
this.source_.loadFeatures(t, e, i), e !== this.resolution_ && (super.clear(), this.resolution_ = e, this.cluster_(), super.addFeatures(this.features_))
|
||
}
|
||
|
||
onSourceChange_() {
|
||
super.clear(), this.cluster_(), super.addFeatures(this.features_), super.changed()
|
||
}
|
||
|
||
cluster_() {
|
||
if (void 0 !== this.resolution_) {
|
||
this.features_.length = 0;
|
||
for (var t = ol.extent.createEmpty(), e = this.distance_ * this.resolution_, i = this.source_.getFeatures(), r = {}, o = 0, n = i.length; o < n; o++) {
|
||
var s = i[o];
|
||
if (!(ol.util.getUid(s).toString() in r)) {
|
||
var a = this.geometryFunction_(s);
|
||
if (a) {
|
||
var l = a.getCoordinates();
|
||
ol.extent.createOrUpdateFromCoordinate(l, t), ol.extent.buffer(t, e, t);
|
||
var h = this.source_.getFeaturesInExtent(t);
|
||
ol.asserts.assert(h.length >= 1, "at least one neighbor found");
|
||
var u = {};
|
||
if ((h = h.filter(function (t) {
|
||
var e = ol.util.getUid(t).toString();
|
||
return !(e in r || (r[e] = !0, u[e] = !0, 0))
|
||
})).length > this.minClusterNum) this.features_.push(this.createCluster_(h)); else {
|
||
for (var c in this.features_.push(s), u) delete r[c];
|
||
var p = ol.util.getUid(s).toString();
|
||
r[p] = !0
|
||
}
|
||
u = null
|
||
}
|
||
}
|
||
}
|
||
ol.asserts.assert(Object.keys(r).length == this.source_.getFeatures().length, "number of clustered equals number of features in the source")
|
||
}
|
||
}
|
||
|
||
createCluster_(t) {
|
||
for (var e, i = [0, 0], r = t.length - 1; r >= 0; --r) {
|
||
var o = this.geometryFunction_(t[r]);
|
||
o ? ol.coordinate.add(i, o.getCoordinates()) : t.splice(r, 1)
|
||
}
|
||
return ol.coordinate.scale(i, 1 / t.length), t.length > this.minClusterNum ? (e = new ol.Feature(new ol.geom.Point(i))).set("features", t) : e = t[0], e
|
||
}
|
||
};
|
||
var OS = class extends ol.source.TileImage {
|
||
constructor(t) {
|
||
for (var e = vC.isDef(t.projection) ? t.projection : "EPSG:4326", i = ol.proj.get(e).getExtent(), r = vC.isDef(t.tileSize) ? t.tileSize : 256, o = 360 / r, n = new Array(18), s = 0; s < 18; ++s) n[s] = o / Math.pow(2, s);
|
||
var a = vC.isDef(t.resolutions) ? t.resolutions : n;
|
||
super({
|
||
projection: e,
|
||
tileUrlFunction: function (t, e, i) {
|
||
var r = t[0], o = t[1], n = -t[2] - 1, s = this.hotspotUrlTemplate_, a = this.tileUrlTemplate_,
|
||
l = (s = s.replace(/{z}/g, r.toString()).replace(/{y}/g, n.toString()).replace(/{x}/g, o.toString()), this.markerData_),
|
||
h = this.createXHR();
|
||
return h.onreadystatechange = function (t) {
|
||
if (!(h.readyState < 4) && 200 === h.status && 4 === h.readyState) {
|
||
var e = h.responseText.replace(/((\r\n)+)$/, "").replace(/\r\n/g, ",").replace(/(.\d+)$/, "");
|
||
e = "[" + e + "]", r in l ? l[r][o + ":" + n] = JSON.parse(e) : (l[r] = {}, l[r][o + ":" + n] = JSON.parse(e))
|
||
}
|
||
}, h.open("GET", this.proxyUrl_ + encodeURIComponent(s), !0), h.send(null), a.replace("{z}", r.toString()).replace("{y}", n.toString()).replace("{x}", o.toString())
|
||
},
|
||
tileGrid: new ol.tilegrid.TileGrid({origin: ol.extent.getTopLeft(i), resolutions: a, tileSize: r})
|
||
}), ol.asserts.assert(vC.isDef(t.hotspotUrlTemplate), "热点数据URL模板不能为空"), this.hotspotUrlTemplate_ = t.hotspotUrlTemplate, ol.asserts.assert(vC.isDef(t.tileUrlTemplate), "热点数据URL模板不能为空"), this.tileUrlTemplate_ = t.tileUrlTemplate, this.markerData_ = {}, this.proxyUrl_ = vC.isDef(t.proxyUrl) ? t.proxyUrl + "?request=gotourl&url=" : ""
|
||
}
|
||
|
||
urlCallbackFunction_(t, e, i) {
|
||
var r = t[0], o = t[1], n = -t[2] - 1, s = this.hotspotUrlTemplate_, a = this.tileUrlTemplate_,
|
||
l = (s = s.replace(/{z}/g, r.toString()).replace(/{y}/g, n.toString()).replace(/{x}/g, o.toString()), this.markerData_),
|
||
h = this.createXHR();
|
||
return h.onreadystatechange = function (t) {
|
||
if (!(h.readyState < 4) && 200 === h.status && 4 === h.readyState) {
|
||
var e = h.responseText.replace(/((\r\n)+)$/, "").replace(/\r\n/g, ",").replace(/(.\d+)$/, "");
|
||
e = "[" + e + "]", r in l ? l[r][o + ":" + n] = JSON.parse(e) : (l[r] = {}, l[r][o + ":" + n] = JSON.parse(e))
|
||
}
|
||
}, h.open("GET", this.proxyUrl_ + encodeURIComponent(s), !0), h.send(null), a.replace("{z}", r.toString()).replace("{y}", n.toString()).replace("{x}", o.toString())
|
||
}
|
||
|
||
createXHR() {
|
||
var t;
|
||
if ("undefined" != typeof XMLHttpRequest) t = new XMLHttpRequest; else for (var e = ["MSXML2.XmlHttp.5.0", "MSXML2.XmlHttp.4.0", "MSXML2.XmlHttp.3.0", "MSXML2.XmlHttp.2.0", "Microsoft.XmlHttp"], i = 0, r = e.length; i < r; i++) try {
|
||
t = new ActiveXObject(e[i]);
|
||
break
|
||
} catch (t) {
|
||
new Error("查看浏览器版本")
|
||
}
|
||
return t
|
||
}
|
||
|
||
getMarkerData() {
|
||
return this.markerData_
|
||
}
|
||
};
|
||
var MS = class extends ol.source.Vector {
|
||
constructor(t) {
|
||
if (t.url) {
|
||
var e = t.type, i = t.icon, r = t.isScale, o = t.scaleFactor, n = t.format || "scale";
|
||
if ("cluster" === n) {
|
||
var s = t.clusterStyle, a = t.clusterIconGroup, l = t.clusterKeyName;
|
||
n = new ol.format.HotSpotCluster(e, i, s, a, l)
|
||
} else n = new ol.format.HotSpot(e, i, r, o);
|
||
for (var h = new Array(22), u = 0; u <= 22; ++u) h[u] = 1.40625 / Math.pow(2, u);
|
||
var c = new ol.tilegrid.TileGrid({
|
||
origin: t.origin || [-180, 90],
|
||
resolutions: t.resolutions || h,
|
||
tileSize: t.tileSize || 256
|
||
});
|
||
super({
|
||
projection: t.projection || "EPSG:4326", tileGrid: c, url: function (e, i) {
|
||
var r = c.getTileCoordForCoordAndResolution(ol.extent.getCenter(e), i), o = r[0], n = r[1],
|
||
s = -r[2] - 1,
|
||
a = t.url.replace("{z}", o.toString()).replace("{y}", s.toString()).replace("{x}", n.toString());
|
||
if ("POST" == t.proxyType) {
|
||
var l = a.split("?"), h = {url: l[0]};
|
||
return h.content = l[1], h.proxyurl = t.proxyurl, h.proxyType = t.proxyType, h
|
||
}
|
||
var u = t.proxyJoin || "?toUrl=";
|
||
return t.proxyurl + u + encodeURIComponent(a + "&appkey=" + t.appkey)
|
||
}, strategy: ol.loadingstrategy.tile(c), format: n
|
||
}), this.format = n, this.tilegrid = c, this.proxyType = t.proxyType, this.url_ = t.url, this.proxyurl = t.proxyurl, this.appkey = t.appkey, this.proxyurlJoin = t.proxyJoin || "?toUrl=", this.lasttime_ = null, this.loading_ = !1, this.loadend_ = !0
|
||
}
|
||
}
|
||
|
||
setLoadingState(t) {
|
||
this.loading_ = t
|
||
}
|
||
|
||
setLoadendState(t) {
|
||
this.loadend_ = t
|
||
}
|
||
|
||
tileurlfunc(t, e) {
|
||
var i = this.tilegrid.getTileCoordForCoordAndResolution(ol.extent.getCenter(t), e), r = i[0], o = i[1],
|
||
n = -i[2] - 1,
|
||
s = this.url_.replace("{z}", r.toString()).replace("{y}", n.toString()).replace("{x}", o.toString());
|
||
if ("POST" == this.proxyType) {
|
||
var a = s.split("?"), l = {url: a[0]};
|
||
return l.content = a[1], l.proxyurl = this.proxyurl, l.proxyType = this.proxyType, l
|
||
}
|
||
return this.proxyurl + this.proxyurlJoin + encodeURIComponent(s + "&appkey=" + this.appkey)
|
||
}
|
||
|
||
loadFeatures(t, e, i) {
|
||
var r, o, n = this.loadedExtentsRtree_, s = this.strategy_(t, e);
|
||
for (r = 0, o = s.length; r < o; ++r) {
|
||
var a = s[r];
|
||
n.forEachInExtent(a, function (t) {
|
||
return ol.extent.containsExtent(t.extent, a)
|
||
}) || !this.loading_ && this.loadend_ && (this.loader_.call(this, a, e, i), n.insert(a, {extent: a.slice()}))
|
||
}
|
||
}
|
||
};
|
||
const AS = function () {
|
||
this.Events = {}, this.__cnt = 0
|
||
};
|
||
AS.hasOwnKey = Function.call.bind(Object.hasOwnProperty), AS.slice = Function.call.bind(Array.prototype.slice), AS.prototype.on = function (t, e, i) {
|
||
return this.bindEvent(t, e, 0, i)
|
||
}, AS.prototype.un = function (t) {
|
||
var e = "", i = "", r = !1, o = typeof t, n = this;
|
||
return "string" === o ? !!AS.hasOwnKey(this.Events, t) && (delete this.Events[t], !0) : "object" === o ? (e = t[0], i = t[1], !(!AS.hasOwnKey(this.Events, e) || !AS.hasOwnKey(this.Events[e], i)) && (delete this.Events[e][i], !0)) : "function" !== o || (n.eachEvent(n.Events, function (e, i) {
|
||
n.eachEvent(i, function (i, o) {
|
||
o[0] === t && (delete n.Events[e][i], r = !0)
|
||
})
|
||
}), r)
|
||
}, AS.prototype.once = function (t, e, i) {
|
||
return this.bindEvent(t, e, 1, i)
|
||
}, AS.prototype.action = function (t, e) {
|
||
AS.hasOwnKey(this.Events, t) && this.eachEvent(this.Events[t], function (i, r) {
|
||
r[0].apply(r[2], e), r[1] && delete this.Events[t][i]
|
||
})
|
||
}, AS.prototype.dispatch = function (t) {
|
||
var e = this, i = AS.slice(arguments, 1);
|
||
setTimeout(function () {
|
||
e.action(t, i)
|
||
})
|
||
}, AS.prototype.dispatchSync = function (t) {
|
||
this.action(t, AS.slice(arguments, 1))
|
||
}, AS.prototype.clear = function () {
|
||
this.Events = {}
|
||
}, AS.prototype.bindEvent = function (t, e, i, r) {
|
||
if ("string" != typeof t || "function" != typeof e) throw new Error("传入的事件名称和回调函数有误!");
|
||
return AS.hasOwnKey(this.Events, t) || (this.Events[t] = {}), this.Events[t][++this.__cnt] = [e, i, r], [t, this.__cnt]
|
||
}, AS.prototype.eachEvent = function (t, e) {
|
||
for (var i in t) AS.hasOwnKey(t, i) && e(i, t[i])
|
||
};
|
||
var kS = AS;
|
||
const FS = 100, NS = Math.PI / 2, DS = (Math.PI, "ol-plot-vector-layer"), GS = "plot-helper-control-point-div",
|
||
jS = "plot-helper-hidden-div", zS = {
|
||
borderRadius: "2px",
|
||
fontSize: "12px",
|
||
outline: 0,
|
||
overflow: "hidden",
|
||
boxSizing: "border-box",
|
||
border: "1px solid #eeeeee",
|
||
fontFamily: "Helvetica Neue,Helvetica,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Noto Sans CJK SC,WenQuanYi Micro Hei,Arial,sans-serif",
|
||
color: "#010500",
|
||
fontWeight: 400,
|
||
padding: "3px",
|
||
fontStretch: "normal",
|
||
lineHeight: "normal",
|
||
textAlign: "left",
|
||
marginLeft: "auto",
|
||
marginRight: "auto",
|
||
width: "auto",
|
||
height: "auto",
|
||
background: "rgb(255, 255, 255)",
|
||
fontStyle: "",
|
||
fontVariant: ""
|
||
}, US = (t, e) => Math.sqrt(Math.pow(t[0] - e[0], 2) + Math.pow(t[1] - e[1], 2)), BS = t => {
|
||
let e = 0;
|
||
return t && Array.isArray(t) && t.length > 0 && t.forEach((i, r) => {
|
||
r < t.length - 1 && (e += US(i, t[r + 1]))
|
||
}), e
|
||
}, VS = t => Math.pow(BS(t), .99), YS = (t, e) => [(t[0] + e[0]) / 2, (t[1] + e[1]) / 2], WS = (t, e, i) => {
|
||
let r = [(t[0] + e[0]) / 2, (t[1] + e[1]) / 2], o = [r[0] - t[1] + e[1], r[1] + t[0] - e[0]],
|
||
n = [(t[0] + i[0]) / 2, (t[1] + i[1]) / 2], s = [n[0] - t[1] + i[1], n[1] + t[0] - i[0]];
|
||
return HS(r, o, n, s)
|
||
}, HS = (t, e, i, r) => {
|
||
if (t[1] === e[1]) {
|
||
return [(r[0] - i[0]) / (r[1] - i[1]) * (t[1] - i[1]) + i[0], t[1]]
|
||
}
|
||
if (i[1] === r[1]) {
|
||
return [(e[0] - t[0]) / (e[1] - t[1]) * (i[1] - t[1]) + t[0], i[1]]
|
||
}
|
||
let o = (e[0] - t[0]) / (e[1] - t[1]), n = (r[0] - i[0]) / (r[1] - i[1]),
|
||
s = (o * t[1] - t[0] - n * i[1] + i[0]) / (o - n);
|
||
return [o * s - o * t[1] + t[0], s]
|
||
}, XS = (t, e) => {
|
||
let i, r = Math.asin(Math.abs(e[1] - t[1]) / US(t, e));
|
||
return e[1] >= t[1] && e[0] >= t[0] ? i = r + Math.PI : e[1] >= t[1] && e[0] < t[0] ? i = 2 * Math.PI - r : e[1] < t[1] && e[0] < t[0] ? i = r : e[1] < t[1] && e[0] >= t[0] && (i = Math.PI - r), i
|
||
}, qS = (t, e, i) => {
|
||
let r = XS(e, t) - XS(e, i);
|
||
return r < 0 ? r + 2 * Math.PI : r
|
||
}, ZS = (t, e, i) => (i[1] - t[1]) * (e[0] - t[0]) > (e[1] - t[1]) * (i[0] - t[0]), KS = (t, e, i, r, o) => {
|
||
t = Math.max(Math.min(t, 1), 0);
|
||
let [n, s] = [1 - t, t * t], a = s * t, l = n * n, h = l * n;
|
||
return [h * e[0] + 3 * l * t * i[0] + 3 * n * s * r[0] + a * o[0], h * e[1] + 3 * l * t * i[1] + 3 * n * s * r[1] + a * o[1]]
|
||
}, JS = (t, e, i, r, o) => {
|
||
let n = XS(t, e), s = o ? n + i : n - i, a = r * Math.cos(s), l = r * Math.sin(s);
|
||
return [e[0] + a, e[1] + l]
|
||
}, $S = (t, e, i, r) => {
|
||
let [o, n, s, a] = [null, null, [], r - i];
|
||
a = a < 0 ? a + 2 * Math.PI : a;
|
||
for (let r = 0; r <= 100; r++) {
|
||
let l = i + a * r / 100;
|
||
o = t[0] + e * Math.cos(l), n = t[1] + e * Math.sin(l), s.push([o, n])
|
||
}
|
||
return s
|
||
}, QS = (t, e, i, r) => {
|
||
let o = tE(e, i, r), [n, s, a, l, h] = [null, null, null, null, null],
|
||
u = Math.sqrt(o[0] * o[0] + o[1] * o[1]), c = o[0] / u, p = o[1] / u, d = US(e, i), f = US(i, r);
|
||
return u > 1e-4 ? ZS(e, i, r) ? (a = t * d, n = [l = i[0] - a * p, h = i[1] + a * c], a = t * f, s = [l = i[0] + a * p, h = i[1] - a * c]) : (a = t * d, n = [l = i[0] + a * p, h = i[1] - a * c], a = t * f, s = [l = i[0] - a * p, h = i[1] + a * c]) : (n = [l = i[0] + t * (e[0] - i[0]), h = i[1] + t * (e[1] - i[1])], s = [l = i[0] + t * (r[0] - i[0]), h = i[1] + t * (r[1] - i[1])]), [n, s]
|
||
}, tE = (t, e, i) => {
|
||
let r = t[0] - e[0], o = t[1] - e[1], n = Math.sqrt(r * r + o * o);
|
||
r /= n, o /= n;
|
||
let s = i[0] - e[0], a = i[1] - e[1], l = Math.sqrt(s * s + a * a);
|
||
return [r + (s /= l), o + (a /= l)]
|
||
}, eE = (t, e) => {
|
||
let i = ((t, e) => {
|
||
let [i, r, o, n, s] = [t[0], t[1], t[2], null, null], a = QS(0, i, r, o)[0], l = tE(i, r, o);
|
||
if (Math.sqrt(l[0] * l[0] + l[1] * l[1]) > 1e-4) {
|
||
let t = YS(i, r), e = i[0] - t[0], o = i[1] - t[1], l = 2 / US(i, r), h = -l * o, u = l * e,
|
||
c = h * h - u * u, p = 2 * h * u, d = u * u - h * h, f = a[0] - t[0], g = a[1] - t[1];
|
||
n = t[0] + c * f + p * g, s = t[1] + p * f + d * g
|
||
} else n = i[0] + e * (r[0] - i[0]), s = i[1] + e * (r[1] - i[1]);
|
||
return [n, s]
|
||
})(e, t), [r, o, n, s, a] = [null, null, null, [i], []];
|
||
for (let i = 0; i < e.length - 2; i++) {
|
||
[r, o, n] = [e[i], e[i + 1], e[i + 2]];
|
||
let a = QS(t, r, o, n);
|
||
s = s.concat(a)
|
||
}
|
||
let l = ((t, e) => {
|
||
let i = t.length, r = t[i - 3], o = t[i - 2], n = t[i - 1], s = QS(0, r, o, n)[1], a = tE(r, o, n),
|
||
l = Math.sqrt(a[0] * a[0] + a[1] * a[1]), [h, u] = [null, null];
|
||
if (l > 1e-4) {
|
||
let t = YS(o, n), e = n[0] - t[0], i = n[1] - t[1], r = 2 / US(o, n), a = -r * i, l = r * e,
|
||
c = a * a - l * l, p = 2 * a * l, d = l * l - a * a, f = s[0] - t[0], g = s[1] - t[1];
|
||
h = t[0] + c * f + p * g, u = t[1] + p * f + d * g
|
||
} else h = n[0] + e * (o[0] - n[0]), u = n[1] + e * (o[1] - n[1]);
|
||
return [h, u]
|
||
})(e, t);
|
||
l && s.push(l);
|
||
for (let t = 0; t < e.length - 1; t++) {
|
||
r = e[t], o = e[t + 1], a.push(r);
|
||
for (let e = 0; e < FS; e++) {
|
||
let i = KS(e / FS, r, s[2 * t], s[2 * t + 1], o);
|
||
a.push(i)
|
||
}
|
||
a.push(o)
|
||
}
|
||
return a
|
||
}, iE = function (t) {
|
||
if (t.length <= 2) return t;
|
||
{
|
||
let e = [], i = t.length - 1;
|
||
for (let r = 0; r <= 1; r += .01) {
|
||
let [o, n] = [0, 0];
|
||
for (let e = 0; e <= i; e++) {
|
||
let s = oE(i, e), a = Math.pow(r, e), l = Math.pow(1 - r, i - e);
|
||
o += s * a * l * t[e][0], n += s * a * l * t[e][1]
|
||
}
|
||
e.push([o, n])
|
||
}
|
||
return e.push(t[i]), e
|
||
}
|
||
}, rE = t => {
|
||
let e = 1;
|
||
switch (t) {
|
||
case t <= 1:
|
||
e = 1;
|
||
break;
|
||
case 2 === t:
|
||
e = 2;
|
||
break;
|
||
case 3 === t:
|
||
e = 6;
|
||
break;
|
||
case 24 === t:
|
||
e = 24;
|
||
break;
|
||
case 5 === t:
|
||
e = 120;
|
||
break;
|
||
default:
|
||
for (let i = 1; i <= t; i++) e *= i
|
||
}
|
||
return e
|
||
}, oE = (t, e) => rE(t) / (rE(e) * rE(t - e)), nE = t => {
|
||
if (t.length <= 2) return t;
|
||
{
|
||
let [e, i] = [2, []], r = t.length - e - 1;
|
||
i.push(t[0]);
|
||
for (let o = 0; o <= r; o++) for (let r = 0; r <= 1; r += .05) {
|
||
let [n, s] = [0, 0];
|
||
for (let i = 0; i <= e; i++) {
|
||
let e = sE(i, r);
|
||
n += e * t[o + i][0], s += e * t[o + i][1]
|
||
}
|
||
i.push([n, s])
|
||
}
|
||
return i.push(t[t.length - 1]), i
|
||
}
|
||
}, sE = (t, e) => {
|
||
let i = 0;
|
||
return 0 === t ? i = Math.pow(e - 1, 2) / 2 : 1 === t ? i = (-2 * Math.pow(e, 2) + 2 * e + 1) / 2 : 2 === t && (i = Math.pow(e, 2) / 2), i
|
||
}, aE = () => {
|
||
let [t, e] = [[], "0123456789abcdef"];
|
||
for (let i = 0; i < 36; i++) t[i] = e.substr(Math.floor(16 * Math.random()), 1);
|
||
return t[14] = "4", t[19] = e.substr(3 & t[19] | 8, 1), t[8] = t[13] = t[18] = t[23] = "-", t.join("")
|
||
}, lE = t => {
|
||
const e = typeof t;
|
||
return null !== t && ("object" === e || "function" === e)
|
||
}, hE = (t, e) => {
|
||
for (const i in e) lE(e[i]) && lE(t[i]) ? hE(t[i], e[i]) : t[i] = e[i];
|
||
return t
|
||
};
|
||
|
||
function uE(t, e) {
|
||
t.forEach(t => {
|
||
e[t] && (e[t] = e[t].bind(e))
|
||
})
|
||
}
|
||
|
||
const cE = function (t, e) {
|
||
try {
|
||
let i = null;
|
||
if (t) {
|
||
let r = t.getLayers().getArray();
|
||
i = pE(r, "layerName", e)
|
||
}
|
||
return i
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}, pE = function (t, e, i) {
|
||
let r = null;
|
||
return t.length > 0 && t.every(t => {
|
||
if (t instanceof cs) {
|
||
let o = t.getLayers().getArray();
|
||
return !(r = pE(o, e, i))
|
||
}
|
||
return t.get(e) !== i || (r = t, !1)
|
||
}), r
|
||
}, dE = function (t, e, i) {
|
||
try {
|
||
if (t) {
|
||
let r = cE(t, e);
|
||
if (r instanceof v_ || (r = null), r || i && i.create && (r = new v_({
|
||
layerName: e,
|
||
params: i,
|
||
layerType: "vector",
|
||
source: new b_({wrapX: !1}),
|
||
style: new uf({
|
||
fill: new po({color: "rgba(67, 110, 238, 0.4)"}),
|
||
stroke: new go({color: "#4781d9", width: 2}),
|
||
image: new Zd({radius: 7, fill: new po({color: "#ffcc33"})})
|
||
})
|
||
})), t && r) {
|
||
i && i.hasOwnProperty("selectable") && r.set("selectable", i.selectable);
|
||
let o = cE(t, e);
|
||
o && o instanceof v_ || t.addLayer(r, !0)
|
||
}
|
||
return r
|
||
}
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
};
|
||
var fE = i(6), gE = i.n(fE);
|
||
const mE = /([\:\-\_]+(.))/g, yE = /^moz([A-Z])/, vE = function (t, e, i, r) {
|
||
let o = document.createElement(t);
|
||
return o.className = e || "", r && (o.id = r), i && i.appendChild(o), o
|
||
}, _E = function (t) {
|
||
return "string" == typeof t ? document.getElementById(t) : t
|
||
}, xE = function (t) {
|
||
let e = t.parentNode;
|
||
e && e.removeChild(t)
|
||
}, wE = function (t, e, i) {
|
||
let r = document.createElement(t);
|
||
return r.style.display = "none", i && (r.id = i), e && e.appendChild(r), r
|
||
}, bE = function (t) {
|
||
return t.replace(mE, function (t, e, i, r) {
|
||
return r ? i.toUpperCase() : i
|
||
}).replace(yE, "Moz$1")
|
||
}, CE = function () {
|
||
if (document.addEventListener) return function (t, e, i) {
|
||
t && e && i && t.addEventListener(e, i, !1)
|
||
}
|
||
}(), SE = function () {
|
||
if (document.removeEventListener) return function (t, e, i) {
|
||
t && e && t.removeEventListener(e, i, !1)
|
||
}
|
||
}();
|
||
|
||
function EE(t, e) {
|
||
if (!t || !e) return !1;
|
||
if (-1 !== e.indexOf(" ")) throw new Error("className should not contain space.");
|
||
return t.classList ? t.classList.contains(e) : (" " + t.className + " ").indexOf(" " + e + " ") > -1
|
||
}
|
||
|
||
function TE(t, e) {
|
||
if (!t || !e) return null;
|
||
"float" === (e = bE(e)) && (e = "cssFloat");
|
||
try {
|
||
const i = document.defaultView.getComputedStyle(t, "");
|
||
return t.style[e] || i ? i[e] : null
|
||
} catch (i) {
|
||
return t.style[e]
|
||
}
|
||
}
|
||
|
||
function RE(t, e, i) {
|
||
if (t && e) if ("object" == typeof e) for (var r in e) e.hasOwnProperty(r) && RE(t, r, e[r]); else "opacity" === (e = bE(e)) ? t.style.filter = isNaN(i) ? "" : "alpha(opacity=" + 100 * i + ")" : t.style[e] = i
|
||
}
|
||
|
||
var PE = class extends sh {
|
||
constructor(t = {}) {
|
||
const [e, i, r, o, n, s, a, l, h, u] = [t.id, t.element, t.offset, t.stopEvent, t.positioning, t.insertFirst, t.autoPan, t.autoPanAnimation, t.autoPanMargin, t.className ? t.className : "ol-plot-text-editor"];
|
||
super({
|
||
id: e,
|
||
element: i,
|
||
stopEvent: o,
|
||
insertFirst: s,
|
||
autoPan: a,
|
||
autoPanAnimation: l,
|
||
autoPanMargin: h,
|
||
className: u
|
||
}), this.setOffset(void 0 !== r ? r : [0, 0]), this.setPositioning(void 0 !== n ? n : "center-center"), this.mapDragPan = void 0, this.isClick_ = !1, this.dragging_ = !1, this.isFocus_ = !1, this.options_ = t, this._position = t.position && t.position.length > 0 ? t.position : [], this.handleTimer_ = null, this.currentPixel_ = [], uE(["handleFocus_", "handleBlur_", "handleClick_", "handleDragStart_", "handleDragEnd_", "handleDragDrag_", "closeCurrentPlotText", "handleResizeMouseDown_", "handleResizeMouseMove_", "handleResizeMouseUp_", "resizeButtonMoveHandler_"], this), this.createTextContent(t)
|
||
}
|
||
|
||
createTextContent(t) {
|
||
const e = t.className || "ol-plot-text-editor", i = document.createElement("textarea");
|
||
i.className = e, i.style.width = t.width + "px", i.style.height = t.height + "px", i.style.minHeight = t.minHeight + "px", i.setAttribute("id", t.id), i.setAttribute("autofocus", !0), gE()(i), CE(i, "focus", this.handleFocus_), CE(i, "blur", this.handleBlur_), CE(i, "click", this.handleClick_), CE(i, "mousedown", this.handleDragStart_), CE(window, "mouseup", this.handleDragEnd_), this.set("isPlotText", !0), this.setElement(i), this.createCloseButton(t), this.createResizeButton(t), this.setPosition(this._position), this.dispatchEvent("textBoxDrawEnd", {
|
||
overlay: this,
|
||
element: i,
|
||
uuid: t.id
|
||
})
|
||
}
|
||
|
||
getTextAreaFromContent_() {
|
||
let t = "";
|
||
const e = Array.prototype.slice.call(this.element && this.element.children, 0);
|
||
return e.length > 0 && e.every(e => 1 !== e.nodeType || "textarea" !== e.nodeName.toLowerCase() || (t = e, !1)), t
|
||
}
|
||
|
||
createCloseButton(t) {
|
||
const e = document.createElement("span");
|
||
e.className = "ol-plot-text-editor-close", e.setAttribute("data-id", t.id), SE(e, "click", this.closeCurrentPlotText), CE(e, "click", this.closeCurrentPlotText), this.element.appendChild(e)
|
||
}
|
||
|
||
createResizeButton(t) {
|
||
const e = document.createElement("span");
|
||
e.className = "ol-plot-text-editor-resize", e.setAttribute("data-id", t.id), SE(e, "mousedown", this.handleResizeMouseDown_), SE(e, "mousemove", this.handleResizeMouseMove_), CE(e, "mousedown", this.handleResizeMouseDown_), CE(e, "mousemove", this.handleResizeMouseMove_), this.element.appendChild(e)
|
||
}
|
||
|
||
resizeButtonMoveHandler_(t) {
|
||
const e = t.pixel, i = this.getTextAreaFromContent_();
|
||
if (e.length < 1 || this.currentPixel_.length < 1 || !i) return;
|
||
const r = [e[0] - this.currentPixel_[0], e[1] - this.currentPixel_[1]],
|
||
o = [i.offsetWidth, i.offsetHeight], n = o[1] + 2 * r[1];
|
||
RE(i, "width", o[0] + 2 * r[0] + "px"), RE(i, "height", n + "px"), this.currentPixel_ = e, this.getMap().render()
|
||
}
|
||
|
||
handleResizeMouseMove_(t) {
|
||
t.stopImmediatePropagation()
|
||
}
|
||
|
||
handleResizeMouseDown_(t) {
|
||
this.getMap() && (this.currentPixel_ = [t.x, t.y], this.getMap().on("pointermove", this.resizeButtonMoveHandler_), CE(this.getMap().getViewport(), "mouseup", this.handleResizeMouseUp_))
|
||
}
|
||
|
||
handleResizeMouseUp_(t) {
|
||
this.getMap() && (this.getMap().un("pointermove", this.resizeButtonMoveHandler_), SE(this.getMap().getViewport(), "mouseup", this.handleResizeMouseUp_), this.currentPixel_ = [])
|
||
}
|
||
|
||
closeCurrentPlotText(t) {
|
||
if (this.getMap() && t && EE(t.target, "ol-plot-text-editor-close")) {
|
||
let e = t.target.getAttribute("data-id");
|
||
if (e) {
|
||
const t = this.getMap().getOverlayById(e);
|
||
t && this.getMap().removeOverlay(t)
|
||
}
|
||
}
|
||
}
|
||
|
||
handleFocus_() {
|
||
this.isFocus_ = !0, this.getMap() && (this.getMap().set("activeTextArea", this), this.getMap().dispatchEvent("activeTextArea"))
|
||
}
|
||
|
||
handleBlur_() {
|
||
this.isFocus_ = !1, this.getMap() && (this.getMap().set("activeTextArea", null), this.getMap().set("disActiveTextArea", this), this.getMap().dispatchEvent("disActiveTextArea"))
|
||
}
|
||
|
||
handleDragStart_(t) {
|
||
this.getMap() && !this.dragging_ && this.isMoveModel() && this.isFocus_ && (this.handleTimer_ = window.setTimeout(() => {
|
||
window.clearTimeout(this.handleTimer_), this.handleTimer_ = null, this.isClick_ || (this.dragging_ = !0, this.disableMapDragPan(), this.preCursor_ = this.element.style.cursor, CE(this.getMap().getViewport(), "mousemove", this.handleDragDrag_), CE(this.element, "mouseup", this.handleDragEnd_))
|
||
}, 300))
|
||
}
|
||
|
||
handleDragDrag_(t) {
|
||
this.dragging_ && (this.element.style.cursor = "move", this._position = this.getMap().getCoordinateFromPixel([t.clientX, t.clientY]), this.setPosition(this._position))
|
||
}
|
||
|
||
handleDragEnd_(t) {
|
||
this.isClick_ = !1, window.clearTimeout(this.handleTimer_), this.handleTimer_ = null, this.dragging_ && this.isFocus_ && (this.dragging_ = !1, this.enableMapDragPan(), this.element.style.cursor = this.preCursor_, SE(this.getMap().getViewport(), "mousemove", this.handleDragDrag_), SE(this.element, "mouseup", this.handleDragEnd_))
|
||
}
|
||
|
||
handleClick_(t) {
|
||
t.target === this.element ? this.isClick_ = !0 : this.isClick_ = !1
|
||
}
|
||
|
||
isMoveModel() {
|
||
return window.getSelection().getRangeAt(0).collapsed
|
||
}
|
||
|
||
setStyle(t = {}) {
|
||
const e = this.getTextAreaFromContent_();
|
||
if (e) for (let i in t) t[i] && RE(e, i, t[i])
|
||
}
|
||
|
||
getStyle() {
|
||
const t = {}, e = this.getTextAreaFromContent_();
|
||
if (e) for (let i in zS) t[i] = TE(e, i);
|
||
return t
|
||
}
|
||
|
||
setValue(t) {
|
||
const e = this.getTextAreaFromContent_();
|
||
e && (e.value = t, t && gE.a.update(e), this.getMap().render())
|
||
}
|
||
|
||
getValue() {
|
||
const t = this.getTextAreaFromContent_();
|
||
return t ? t.value : ""
|
||
}
|
||
|
||
getWidth() {
|
||
const t = this.getTextAreaFromContent_();
|
||
return t && t.offsetWidth ? t.offsetWidth : 0
|
||
}
|
||
|
||
getHeight() {
|
||
const t = this.getTextAreaFromContent_();
|
||
return t && t.offsetHeight ? t.offsetHeight : 0
|
||
}
|
||
|
||
enableMapDragPan() {
|
||
const t = this.getMap();
|
||
t && this.mapDragPan && this.mapDragPan instanceof oa && (t.addInteraction(this.mapDragPan), delete this.mapDragPan)
|
||
}
|
||
|
||
disableMapDragPan() {
|
||
const t = this.getMap();
|
||
t && t.getInteractions().getArray().every(e => !(e instanceof oa && (this.mapDragPan = e, t.removeInteraction(e), 1)))
|
||
}
|
||
|
||
setMap(t) {
|
||
super.setMap(t), t && t instanceof rh && (this.setStyle(hE(zS, this.options_.style)), this.setValue(this.options_.value))
|
||
}
|
||
};
|
||
const LE = "TextArea", IE = "Arc", OE = "Curve", ME = "GatheringPlace", AE = "Polyline", kE = "FreeHandLine",
|
||
FE = "Point", NE = "Pennant", DE = "RectAngle", GE = "Circle", jE = "Ellipse", zE = "Lune", UE = "Sector",
|
||
BE = "ClosedCurve", VE = "Polygon", YE = "FreePolygon", WE = "AttackArrow", HE = "DoubleArrow",
|
||
XE = "StraightArrow", qE = "FineArrow", ZE = "AssaultDirection", KE = "TailedAttackArrow",
|
||
JE = "SquadCombat", $E = "TailedSquadCombat", QE = "RectFlag", tT = "TriangleFlag", eT = "CurveFlag";
|
||
var iT = class extends qi {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = FE, this.options = i || {}, this.set("params", this.options), this.fixPointCount = 1, e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
let t = this.points[0];
|
||
this.setCoordinates(t)
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var rT = class extends qi {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = NE, this.options = i || {}, this.set("params", this.options), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
this.setCoordinates(this.points)
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var oT = class extends Jr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = AE, this.freehand = !1, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
this.setCoordinates(this.points)
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var nT = class extends Jr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = IE, this.fixPointCount = 3, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
let t = this.getPointCount();
|
||
if (!(t < 2)) if (2 === t) this.setCoordinates(this.points); else {
|
||
let [t, e, i, r, o] = [this.points[0], this.points[1], this.points[2], null, null], n = WS(t, e, i),
|
||
s = US(t, n), a = XS(t, n), l = XS(e, n);
|
||
ZS(t, e, i) ? (r = l, o = a) : (r = a, o = l), this.setCoordinates($S(n, s, r, o))
|
||
}
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var sT = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = GE, this.fixPointCount = 2, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
if (this.getPointCount() < 2) return !1;
|
||
{
|
||
let t = this.points[0], e = US(t, this.points[1]);
|
||
this.setCoordinates([this.generatePoints(t, e)])
|
||
}
|
||
}
|
||
|
||
generatePoints(t, e) {
|
||
let [i, r, o, n] = [null, null, null, []];
|
||
for (let s = 0; s <= 100; s++) o = 2 * Math.PI * s / 100, i = t[0] + e * Math.cos(o), r = t[1] + e * Math.sin(o), n.push([i, r]);
|
||
return n
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var aT = class extends Jr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = OE, this.t = .3, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
let t = this.getPointCount();
|
||
if (t < 2) return !1;
|
||
if (2 === t) this.setCoordinates(this.points); else {
|
||
let t = eE(this.t, this.points);
|
||
this.setCoordinates(t)
|
||
}
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var lT = class extends Jr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = kE, this.freehand = !0, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
this.setCoordinates(this.points)
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var hT = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = DE, this.fixPointCount = 2, this.set("params", i), this.isFill = !1 !== i.isFill || i.isFill, e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
if (2 === this.points.length) {
|
||
let t = [];
|
||
if (this.isFill) t = mr(lt(this.points)).getCoordinates(); else {
|
||
let e = this.points[0], i = this.points[1];
|
||
t = [e, [e[0], i[1]], i, [i[0], e[1]], e]
|
||
}
|
||
this.setCoordinates(t)
|
||
}
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var uT = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = jE, this.fixPointCount = 2, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
if (this.getPointCount() < 2) return !1;
|
||
{
|
||
let [t, e] = [this.points[0], this.points[1]], i = YS(t, e), r = Math.abs((t[0] - e[0]) / 2),
|
||
o = Math.abs((t[1] - e[1]) / 2), n = this.generatePoints(i, r, o);
|
||
this.setCoordinates([n])
|
||
}
|
||
}
|
||
|
||
generatePoints(t, e, i) {
|
||
let [r, o, n, s] = [null, null, null, []];
|
||
for (let a = 0; a <= FS; a++) n = 2 * Math.PI * a / FS, r = t[0] + e * Math.cos(n), o = t[1] + i * Math.sin(n), s.push([r, o]);
|
||
return s
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var cT = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = zE, this.fixPointCount = 3, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
if (this.getPointCount() < 2) return !1;
|
||
{
|
||
let t = this.getPoints();
|
||
if (2 === this.getPointCount()) {
|
||
let e = YS(t[0], t[1]), i = US(t[0], e), r = JS(t[0], e, NS, i);
|
||
t.push(r)
|
||
}
|
||
let [e, i, r, o, n] = [t[0], t[1], t[2], void 0, void 0], s = WS(e, i, r), a = US(e, s),
|
||
l = XS(e, s), h = XS(i, s);
|
||
ZS(e, i, r) ? (o = h, n = l) : (o = l, n = h), (t = $S(s, a, o, n)).push(t[0]), this.setCoordinates([t])
|
||
}
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var pT = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = UE, this.fixPointCount = 3, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
let t = this.getPointCount();
|
||
if (t < 2) return !1;
|
||
if (2 === t) this.setCoordinates([this.points]); else {
|
||
let t = this.getPoints(), [e, i, r] = [t[0], t[1], t[2]], o = US(i, e), n = XS(i, e), s = XS(r, e),
|
||
a = $S(e, o, n, s);
|
||
a.push(e, a[0]), this.setCoordinates([a])
|
||
}
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var dT = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = BE, this.t = .3, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
let t = this.getPointCount();
|
||
if (t < 2) return !1;
|
||
if (2 === t) this.setCoordinates([this.points]); else {
|
||
let t = this.getPoints();
|
||
t.push(t[0], t[1]);
|
||
let [e, i] = [[], []];
|
||
for (let i = 0; i < t.length - 2; i++) {
|
||
let r = QS(this.t, t[i], t[i + 1], t[i + 2]);
|
||
e = e.concat(r)
|
||
}
|
||
let r = e.length;
|
||
e = [e[r - 1]].concat(e.slice(0, r - 1));
|
||
for (let r = 0; r < t.length - 2; r++) {
|
||
let o = t[r], n = t[r + 1];
|
||
i.push(o);
|
||
for (let t = 0; t <= FS; t++) {
|
||
let s = KS(t / FS, o, e[2 * r], e[2 * r + 1], n);
|
||
i.push(s)
|
||
}
|
||
i.push(n)
|
||
}
|
||
this.setCoordinates([i])
|
||
}
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var fT = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = VE, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
if (this.getPointCount() < 2) return !1;
|
||
this.setCoordinates([this.points])
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var gT = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = YE, this.freehand = !0, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
this.setCoordinates([this.points])
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var mT = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = WE, this.headHeightFactor = .18, this.headWidthFactor = .3, this.neckHeightFactor = .85, this.neckWidthFactor = .15, this.headTailFactor = .8, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
try {
|
||
let t = this.getPointCount();
|
||
if (t < 2) return !1;
|
||
if (2 === t) this.setCoordinates([this.points]); else {
|
||
let t = this.getPoints(), [e, i] = [t[0], t[1]];
|
||
ZS(t[0], t[1], t[2]) && (e = t[1], i = t[0]);
|
||
let r = [YS(e, i)].concat(t.slice(2)),
|
||
o = this.getArrowHeadPoints(r, e, i), [n, s] = [o[0], o[4]], a = US(e, i) / VS(r),
|
||
l = this.getArrowBodyPoints(r, n, s, a), h = l.length, u = [e].concat(l.slice(0, h / 2));
|
||
u.push(n);
|
||
let c = [i].concat(l.slice(h / 2, h));
|
||
c.push(s), u = nE(u), c = nE(c), this.setCoordinates([u.concat(o, c.reverse())])
|
||
}
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}
|
||
|
||
getArrowPoints(t, e, i, r) {
|
||
let o = YS(t, e), n = US(o, i), s = JS(i, o, 0, .3 * n, !0), a = JS(i, o, 0, .5 * n, !0),
|
||
l = [o, s = JS(o, s, NS, n / 5, r), a = JS(o, a, NS, n / 4, r), i], h = this.getArrowHeadPoints(l);
|
||
if (!(h && Array.isArray(h) && h.length > 0)) throw new Error("插值出错");
|
||
{
|
||
let [i, r] = [h[0], h[4]], o = US(t, e) / VS(l) / 2, n = this.getArrowBodyPoints(l, i, r, o);
|
||
if (n) {
|
||
let o = n.length, s = n.slice(0, o / 2), a = n.slice(o / 2, o);
|
||
return s.push(i), a.push(r), (s = s.reverse()).push(e), (a = a.reverse()).push(t), s.reverse().concat(h, a)
|
||
}
|
||
}
|
||
}
|
||
|
||
getArrowHeadPoints(t, e, i) {
|
||
try {
|
||
let r = VS(t), o = r * this.headHeightFactor, n = t[t.length - 1];
|
||
r = US(n, t[t.length - 2]);
|
||
let s = US(e, i);
|
||
o > s * this.headTailFactor && (o = s * this.headTailFactor);
|
||
let a = o * this.headWidthFactor, l = o * this.neckWidthFactor,
|
||
h = (o = o > r ? r : o) * this.neckHeightFactor, u = JS(t[t.length - 2], n, 0, o, !0),
|
||
c = JS(t[t.length - 2], n, 0, h, !0), p = JS(n, u, NS, a, !1), d = JS(n, u, NS, a, !0);
|
||
return [JS(n, c, NS, l, !1), p, n, d, JS(n, c, NS, l, !0)]
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}
|
||
|
||
getArrowBodyPoints(t, e, i, r) {
|
||
let o = BS(t), n = VS(t) * r, s = (n - US(e, i)) / 2, [a, l, h] = [0, [], []];
|
||
for (let e = 1; e < t.length - 1; e++) {
|
||
let i = qS(t[e - 1], t[e], t[e + 1]) / 2,
|
||
r = (n / 2 - (a += US(t[e - 1], t[e])) / o * s) / Math.sin(i),
|
||
u = JS(t[e - 1], t[e], Math.PI - i, r, !0), c = JS(t[e - 1], t[e], i, r, !1);
|
||
l.push(u), h.push(c)
|
||
}
|
||
return l.concat(h)
|
||
}
|
||
|
||
getTempPoint4(t, e, i) {
|
||
try {
|
||
let r = YS(t, e), o = US(r, i), n = qS(t, r, i), [s, a, l, h] = [void 0, void 0, void 0, void 0];
|
||
return n < NS ? (a = o * Math.sin(n), l = o * Math.cos(n), h = JS(t, r, NS, a, !1), s = JS(r, h, NS, l, !0)) : n >= NS && n < Math.PI ? (a = o * Math.sin(Math.PI - n), l = o * Math.cos(Math.PI - n), h = JS(t, r, NS, a, !1), s = JS(r, h, NS, l, !1)) : n >= Math.PI && n < 1.5 * Math.PI ? (a = o * Math.sin(n - Math.PI), l = o * Math.cos(n - Math.PI), h = JS(t, r, NS, a, !0), s = JS(r, h, NS, l, !0)) : (a = o * Math.sin(2 * Math.PI - n), l = o * Math.cos(2 * Math.PI - n), h = JS(t, r, NS, a, !0), s = JS(r, h, NS, l, !1)), s
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var yT = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = HE, this.headHeightFactor = .25, this.headWidthFactor = .3, this.neckHeightFactor = .85, this.neckWidthFactor = .15, this.connPoint = null, this.tempPoint4 = null, this.fixPointCount = 4, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
try {
|
||
let t = this.getPointCount();
|
||
if (t < 2) return !1;
|
||
if (2 === t) return this.setCoordinates([this.points]), !1;
|
||
if (t > 2) {
|
||
let [e, i, r] = [this.points[0], this.points[1], this.points[2]];
|
||
3 === t ? (this.tempPoint4 = this.getTempPoint4(e, i, r), this.connPoint = YS(e, i)) : 4 === t ? (this.tempPoint4 = this.points[3], this.connPoint = YS(e, i)) : (this.tempPoint4 = this.points[3], this.connPoint = this.points[4]);
|
||
let [o, n] = [void 0, void 0];
|
||
ZS(e, i, r) ? (o = this.getArrowPoints(e, this.connPoint, this.tempPoint4, !1), n = this.getArrowPoints(this.connPoint, i, r, !0)) : (o = this.getArrowPoints(i, this.connPoint, r, !1), n = this.getArrowPoints(this.connPoint, e, this.tempPoint4, !0));
|
||
let s = o.length, a = (s - 5) / 2, l = o.slice(0, a), h = o.slice(a, a + 5),
|
||
u = o.slice(a + 5, s), c = n.slice(0, a), p = n.slice(a, a + 5), d = n.slice(a + 5, s);
|
||
c = iE(c);
|
||
let f = iE(d.concat(l.slice(1)));
|
||
u = iE(u);
|
||
let g = c.concat(p, f, h, u);
|
||
this.setCoordinates([g])
|
||
}
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}
|
||
|
||
getArrowPoints(t, e, i, r) {
|
||
let o = YS(t, e), n = US(o, i), s = JS(i, o, 0, .3 * n, !0), a = JS(i, o, 0, .5 * n, !0),
|
||
l = [o, s = JS(o, s, NS, n / 5, r), a = JS(o, a, NS, n / 4, r), i], h = this.getArrowHeadPoints(l);
|
||
if (!(h && Array.isArray(h) && h.length > 0)) throw new Error("插值出错");
|
||
{
|
||
let [i, r] = [h[0], h[4]], o = US(t, e) / VS(l) / 2, n = this.getArrowBodyPoints(l, i, r, o);
|
||
if (n) {
|
||
let o = n.length, s = n.slice(0, o / 2), a = n.slice(o / 2, o);
|
||
return s.push(i), a.push(r), (s = s.reverse()).push(e), (a = a.reverse()).push(t), s.reverse().concat(h, a)
|
||
}
|
||
}
|
||
}
|
||
|
||
getArrowHeadPoints(t) {
|
||
try {
|
||
let e = VS(t) * this.headHeightFactor, i = t[t.length - 1], r = e * this.headWidthFactor,
|
||
o = e * this.neckWidthFactor, n = e * this.neckHeightFactor,
|
||
s = JS(t[t.length - 2], i, 0, e, !0), a = JS(t[t.length - 2], i, 0, n, !0),
|
||
l = JS(i, s, NS, r, !1), h = JS(i, s, NS, r, !0);
|
||
return [JS(i, a, NS, o, !1), l, i, h, JS(i, a, NS, o, !0)]
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}
|
||
|
||
getArrowBodyPoints(t, e, i, r) {
|
||
let o = BS(t), n = VS(t) * r, s = (n - US(e, i)) / 2, [a, l, h] = [0, [], []];
|
||
for (let e = 1; e < t.length - 1; e++) {
|
||
let i = qS(t[e - 1], t[e], t[e + 1]) / 2,
|
||
r = (n / 2 - (a += US(t[e - 1], t[e])) / o * s) / Math.sin(i),
|
||
u = JS(t[e - 1], t[e], Math.PI - i, r, !0), c = JS(t[e - 1], t[e], i, r, !1);
|
||
l.push(u), h.push(c)
|
||
}
|
||
return l.concat(h)
|
||
}
|
||
|
||
getTempPoint4(t, e, i) {
|
||
try {
|
||
let r = YS(t, e), o = US(r, i), n = qS(t, r, i), [s, a, l, h] = [void 0, void 0, void 0, void 0];
|
||
return n < NS ? (a = o * Math.sin(n), l = o * Math.cos(n), h = JS(t, r, NS, a, !1), s = JS(r, h, NS, l, !0)) : n >= NS && n < Math.PI ? (a = o * Math.sin(Math.PI - n), l = o * Math.cos(Math.PI - n), h = JS(t, r, NS, a, !1), s = JS(r, h, NS, l, !1)) : n >= Math.PI && n < 1.5 * Math.PI ? (a = o * Math.sin(n - Math.PI), l = o * Math.cos(n - Math.PI), h = JS(t, r, NS, a, !0), s = JS(r, h, NS, l, !0)) : (a = o * Math.sin(2 * Math.PI - n), l = o * Math.cos(2 * Math.PI - n), h = JS(t, r, NS, a, !0), s = JS(r, h, NS, l, !1)), s
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
3 === this.getPointCount() && null !== this.tempPoint4 && this.points.push(this.tempPoint4), null !== this.connPoint && this.points.push(this.connPoint)
|
||
}
|
||
};
|
||
var vT = class extends Jr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = XE, this.fixPointCount = 2, this.maxArrowLength = 3e6, this.arrowLengthScale = 5, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
try {
|
||
if (this.getPointCount() < 2) return !1;
|
||
{
|
||
let t = this.getPoints(), [e, i] = [t[0], t[1]], r = US(e, i) / this.arrowLengthScale;
|
||
r = r > this.maxArrowLength ? this.maxArrowLength : r;
|
||
let o = JS(e, i, Math.PI / 6, r, !1), n = JS(e, i, Math.PI / 6, r, !0);
|
||
this.setCoordinates([e, i, o, i, n])
|
||
}
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var _T = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = qE, this.tailWidthFactor = .1, this.neckWidthFactor = .2, this.headWidthFactor = .25, this.headAngle = Math.PI / 8.5, this.neckAngle = Math.PI / 13, this.fixPointCount = 2, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
try {
|
||
if (this.getPointCount() < 2) return !1;
|
||
{
|
||
let t = this.getPoints(), [e, i] = [t[0], t[1]], r = VS(t), o = r * this.tailWidthFactor,
|
||
n = r * this.neckWidthFactor, s = r * this.headWidthFactor, a = JS(i, e, NS, o, !0),
|
||
l = JS(i, e, NS, o, !1), h = JS(e, i, this.headAngle, s, !1),
|
||
u = JS(e, i, this.headAngle, s, !0),
|
||
c = [a, JS(e, i, this.neckAngle, n, !1), h, i, u, JS(e, i, this.neckAngle, n, !0), l];
|
||
this.setCoordinates([c])
|
||
}
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var xT = class extends _T {
|
||
constructor(t, e, i) {
|
||
super(t, e, i), this.tailWidthFactor = .05, this.neckWidthFactor = .1, this.headWidthFactor = .15, this.type = ZE, this.headAngle = Math.PI / 4, this.neckAngle = .17741 * Math.PI, e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t), this.set("params", i)
|
||
}
|
||
};
|
||
var wT = class extends mT {
|
||
constructor(t, e, i) {
|
||
super(t, e, i), this.type = KE, this.headHeightFactor = .18, this.headWidthFactor = .3, this.neckHeightFactor = .85, this.neckWidthFactor = .15, this.tailWidthFactor = .1, this.headTailFactor = .8, this.swallowTailFactor = 1, this.swallowTailPnt = null, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
generate() {
|
||
try {
|
||
let t = this.getPointCount();
|
||
if (t < 2) return !1;
|
||
if (2 === t) return this.setCoordinates([this.points]), !1;
|
||
{
|
||
let t = this.getPoints(), [e, i] = [t[0], t[1]];
|
||
ZS(t[0], t[1], t[2]) && (e = t[1], i = t[0]);
|
||
let r = [YS(e, i)].concat(t.slice(2)),
|
||
o = this.getArrowHeadPoints(r, e, i), [n, s] = [o[0], o[4]], a = US(e, i), l = VS(r),
|
||
h = l * this.tailWidthFactor * this.swallowTailFactor;
|
||
this.swallowTailPnt = JS(r[1], r[0], 0, h, !0);
|
||
let u = a / l, c = this.getArrowBodyPoints(r, n, s, u), p = c.length,
|
||
d = [e].concat(c.slice(0, p / 2));
|
||
d.push(n);
|
||
let f = [i].concat(c.slice(p / 2, p));
|
||
f.push(s), d = nE(d), f = nE(f), this.setCoordinates([d.concat(o, f.reverse(), [this.swallowTailPnt, d[0]])])
|
||
}
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}
|
||
};
|
||
var bT = class extends mT {
|
||
constructor(t, e, i) {
|
||
super(t, e, i), this.type = JE, this.headHeightFactor = .18, this.headWidthFactor = .3, this.neckHeightFactor = .85, this.neckWidthFactor = .15, this.tailWidthFactor = .1, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
generate() {
|
||
try {
|
||
if (this.getPointCount() < 2) return !1;
|
||
{
|
||
let t = this.getPoints(), e = this.getTailPoints(t), i = this.getArrowHeadPoints(t, e[0], e[1]),
|
||
r = i[0], o = i[4], n = this.getArrowBodyPoints(t, r, o, this.tailWidthFactor),
|
||
s = n.length, a = [e[0]].concat(n.slice(0, s / 2));
|
||
a.push(r);
|
||
let l = [e[1]].concat(n.slice(s / 2, s));
|
||
l.push(o), a = nE(a), l = nE(l), this.setCoordinates([a.concat(i, l.reverse())])
|
||
}
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}
|
||
|
||
getTailPoints(t) {
|
||
let e = VS(t) * this.tailWidthFactor;
|
||
return [JS(t[1], t[0], NS, e, !1), JS(t[1], t[0], NS, e, !0)]
|
||
}
|
||
};
|
||
var CT = class extends mT {
|
||
constructor(t, e, i) {
|
||
super(t, e, i), this.type = $E, this.headHeightFactor = .18, this.headWidthFactor = .3, this.neckHeightFactor = .85, this.neckWidthFactor = .15, this.tailWidthFactor = .1, this.swallowTailFactor = 1, this.swallowTailPnt = null, this.fixPointCount = 2, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
generate() {
|
||
try {
|
||
if (this.getPointCount() < 2) return !1;
|
||
{
|
||
let t = this.getPoints(), e = this.getTailPoints(t), i = this.getArrowHeadPoints(t, e[0], e[2]),
|
||
r = i[0], o = i[4], n = this.getArrowBodyPoints(t, r, o, this.tailWidthFactor),
|
||
s = n.length, a = [e[0]].concat(n.slice(0, s / 2));
|
||
a.push(r);
|
||
let l = [e[2]].concat(n.slice(s / 2, s));
|
||
l.push(o), a = nE(a), l = nE(l), this.setCoordinates([a.concat(i, l.reverse(), [e[1], a[0]])])
|
||
}
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}
|
||
|
||
getTailPoints(t) {
|
||
let e = VS(t) * this.tailWidthFactor, i = JS(t[1], t[0], NS, e, !1), r = JS(t[1], t[0], NS, e, !0),
|
||
o = e * this.swallowTailFactor;
|
||
return [i, JS(t[1], t[0], 0, o, !0), r]
|
||
}
|
||
};
|
||
var ST = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = ME, this.t = .4, this.fixPointCount = 3, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
let t = this.getPoints(), e = this.getPointCount();
|
||
if (t.length < 2) return !1;
|
||
{
|
||
if (2 === e) {
|
||
let e = YS(t[0], t[1]), i = US(t[0], e) / .9, r = JS(t[0], e, NS, i, !0);
|
||
t = [t[0], r, t[1]]
|
||
}
|
||
let i = YS(t[0], t[2]);
|
||
t.push(i, t[0], t[1]);
|
||
let [r, o, n, s, a] = [[], void 0, void 0, void 0, []];
|
||
for (let e = 0; e < t.length - 2; e++) {
|
||
o = t[e], n = t[e + 1], s = t[e + 2];
|
||
let i = QS(this.t, o, n, s);
|
||
r = r.concat(i)
|
||
}
|
||
let l = r.length;
|
||
r = [r[l - 1]].concat(r.slice(0, l - 1));
|
||
for (let e = 0; e < t.length - 2; e++) {
|
||
o = t[e], n = t[e + 1], a.push(o);
|
||
for (let t = 0; t <= FS; t++) {
|
||
let i = KS(t / FS, o, r[2 * e], r[2 * e + 1], n);
|
||
a.push(i)
|
||
}
|
||
a.push(n)
|
||
}
|
||
this.setCoordinates([a])
|
||
}
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var ET = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = QE, this.fixPointCount = 2, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
if (this.getPointCount() < 2) return !1;
|
||
this.setCoordinates([this.calculatePonits(this.points)])
|
||
}
|
||
|
||
calculatePonits(t) {
|
||
let e = [];
|
||
if (t.length > 1) {
|
||
let i = t[0], r = t[t.length - 1];
|
||
e = [i, [r[0], i[1]], [r[0], (i[1] + r[1]) / 2], [i[0], (i[1] + r[1]) / 2], [i[0], r[1]]]
|
||
}
|
||
return e
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var TT = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = tT, this.fixPointCount = 2, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
if (this.getPointCount() < 2) return !1;
|
||
this.setCoordinates([this.calculatePonits(this.points)])
|
||
}
|
||
|
||
calculatePonits(t) {
|
||
let e = [];
|
||
if (t.length > 1) {
|
||
let i = t[0], r = t[t.length - 1];
|
||
e = [i, [r[0], (i[1] + r[1]) / 2], [i[0], (i[1] + r[1]) / 2], [i[0], r[1]]]
|
||
}
|
||
return e
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var RT = class extends fr {
|
||
constructor(t, e, i) {
|
||
super([]), this.type = eT, this.fixPointCount = 2, this.set("params", i), e && e.length > 0 ? this.setPoints(e) : t && t.length > 0 && this.setCoordinates(t)
|
||
}
|
||
|
||
getPlotType() {
|
||
return this.type
|
||
}
|
||
|
||
generate() {
|
||
if (this.getPointCount() < 2) return !1;
|
||
this.setCoordinates([this.calculatePonits(this.points)])
|
||
}
|
||
|
||
calculatePonits(t) {
|
||
let e = [];
|
||
if (t.length > 1) {
|
||
let i = t[0], r = t[t.length - 1], o = i, n = [(r[0] - i[0]) / 4 + i[0], (r[1] - i[1]) / 8 + i[1]],
|
||
s = [(i[0] + r[0]) / 2, i[1]], a = [3 * (r[0] - i[0]) / 4 + i[0], -(r[1] - i[1]) / 8 + i[1]],
|
||
l = [r[0], i[1]], h = [r[0], (i[1] + r[1]) / 2],
|
||
u = [3 * (r[0] - i[0]) / 4 + i[0], 3 * (r[1] - i[1]) / 8 + i[1]],
|
||
c = [(i[0] + r[0]) / 2, (i[1] + r[1]) / 2],
|
||
p = [(r[0] - i[0]) / 4 + i[0], 5 * (r[1] - i[1]) / 8 + i[1]], d = [i[0], (i[1] + r[1]) / 2],
|
||
f = [i[0], r[1]], g = iE([o, n, s, a, l]), m = iE([h, u, c, p, d]);
|
||
(e = g.concat(m)).push(f)
|
||
}
|
||
return e
|
||
}
|
||
|
||
setMap(t) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t
|
||
}
|
||
|
||
getMap() {
|
||
return this.map
|
||
}
|
||
|
||
isPlot() {
|
||
return !0
|
||
}
|
||
|
||
setPoints(t) {
|
||
this.points = t || [], this.points.length >= 1 && this.generate()
|
||
}
|
||
|
||
getPoints() {
|
||
return this.points.slice(0)
|
||
}
|
||
|
||
getPointCount() {
|
||
return this.points.length
|
||
}
|
||
|
||
updatePoint(t, e) {
|
||
e >= 0 && e < this.points.length && (this.points[e] = t, this.generate())
|
||
}
|
||
|
||
updateLastPoint(t) {
|
||
this.updatePoint(t, this.points.length - 1)
|
||
}
|
||
|
||
finishDrawing() {
|
||
}
|
||
};
|
||
var PT = class extends kS {
|
||
constructor(t, e) {
|
||
if (super(), !(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t, this.options = e || {}, this.points = null, this.plot = null, this.feature = null, this.plotType = null, this.plotParams = null, this.mapViewport = this.map.getViewport(), this.dblClickZoomInteraction = null, this.drawInteraction_ = null, this.layerName = this.options && this.options.layerName ? this.options.layerName : DS, uE(["textAreaDrawEnd", "mapFirstClickHandler", "mapNextClickHandler", "mapDoubleClickHandler", "mapMouseMoveHandler"], this), this.drawLayer = dE(this.map, this.layerName, {create: !0}), this.drawLayer.setZIndex(this.options.zIndex || 99)
|
||
}
|
||
|
||
createPlot(t, e, i) {
|
||
let r = i || {};
|
||
switch (t) {
|
||
case LE:
|
||
return "TextArea";
|
||
case FE:
|
||
return new iT([], e, r);
|
||
case NE:
|
||
return new rT([], e, r);
|
||
case AE:
|
||
return new oT([], e, r);
|
||
case IE:
|
||
return new nT([], e, r);
|
||
case GE:
|
||
return new sT([], e, r);
|
||
case OE:
|
||
return new aT([], e, r);
|
||
case kE:
|
||
return new lT([], e, r);
|
||
case DE:
|
||
return new hT([], e, r);
|
||
case jE:
|
||
return new uT([], e, r);
|
||
case zE:
|
||
return new cT([], e, r);
|
||
case UE:
|
||
return new pT([], e, r);
|
||
case BE:
|
||
return new dT([], e, r);
|
||
case VE:
|
||
return new fT([], e, r);
|
||
case WE:
|
||
return new mT([], e, r);
|
||
case YE:
|
||
return new gT([], e, r);
|
||
case HE:
|
||
return new yT([], e, r);
|
||
case XE:
|
||
return new vT([], e, r);
|
||
case qE:
|
||
return new _T([], e, r);
|
||
case ZE:
|
||
return new xT([], e, r);
|
||
case KE:
|
||
return new wT([], e, r);
|
||
case JE:
|
||
return new bT([], e, r);
|
||
case $E:
|
||
return new CT([], e, r);
|
||
case ME:
|
||
return new ST([], e, r);
|
||
case QE:
|
||
return new ET([], e, r);
|
||
case tT:
|
||
return new TT([], e, r);
|
||
case eT:
|
||
return new RT([], e, r)
|
||
}
|
||
return null
|
||
}
|
||
|
||
active(t, e = {}) {
|
||
this.disActive(), this.deactiveMapTools(), this.plotType = t, this.plotParams = e, t === LE ? this.activeInteraction() : Object.keys(r).some(e => r[e] === t) ? this.map.on("click", this.mapFirstClickHandler) : console.warn("不存在的标绘类型!")
|
||
}
|
||
|
||
activeInteraction() {
|
||
this.drawInteraction_ = new P_({
|
||
style: new uf({
|
||
fill: new po({color: "rgba(255, 255, 255, 0.7)"}),
|
||
stroke: new go({color: "rgba(0, 0, 0, 0.15)", width: 2}),
|
||
image: new Xd({
|
||
anchor: [1, 1],
|
||
anchorXUnits: "fraction",
|
||
anchorYUnits: "fraction",
|
||
opacity: .75,
|
||
src: ""
|
||
})
|
||
}), type: "Circle", geometryFunction: R_()
|
||
}), this.map.addInteraction(this.drawInteraction_), this.drawInteraction_.on("drawend", this.textAreaDrawEnd)
|
||
}
|
||
|
||
textAreaDrawEnd(t) {
|
||
if (t && t.feature) {
|
||
this.map.removeInteraction(this.drawInteraction_);
|
||
const e = t.feature.getGeometry().getExtent(), i = [(e[0] + e[2]) / 2, (e[1] + e[3]) / 2],
|
||
r = this.map.getPixelFromCoordinate([e[0], e[1]]),
|
||
o = this.map.getPixelFromCoordinate([e[2], e[3]]), [n, s] = [Math.abs(r[0] - o[0]), Math.abs(r[1] - o[1])],
|
||
a = new PE({
|
||
id: aE(),
|
||
position: i,
|
||
value: "",
|
||
width: n,
|
||
height: s,
|
||
style: {width: n + "px", height: s + "px"}
|
||
});
|
||
this.map && this.map instanceof rh && a ? this.map.addOverlay(a) : console.warn("未传入地图对象或者plotText创建失败!")
|
||
} else console.info("未获取到要素!")
|
||
}
|
||
|
||
disActive() {
|
||
this.removeEventHandlers(), this.drawInteraction_ && (this.map.removeInteraction(this.drawInteraction_), this.drawInteraction_ = null), this.points = [], this.plot = null, this.feature = null, this.plotType = null, this.plotParams = null, this.activateMapTools()
|
||
}
|
||
|
||
isDrawing() {
|
||
return !!this.plotType
|
||
}
|
||
|
||
mapFirstClickHandler(t) {
|
||
this.map.un("click", this.mapFirstClickHandler), this.points.push(t.coordinate), this.plot = this.createPlot(this.plotType, this.points, this.plotParams), this.feature = new X(this.plot), this.feature.set("isPlot", !0), this.drawLayer.getSource().addFeature(this.feature), this.plotType === FE || this.plotType === NE ? (this.plot.finishDrawing(), this.drawEnd(t)) : (this.map.on("click", this.mapNextClickHandler), this.plot.freehand || this.map.on("dblclick", this.mapDoubleClickHandler), this.map.un("pointermove", this.mapMouseMoveHandler), this.map.on("pointermove", this.mapMouseMoveHandler)), this.plotType && this.feature && (this.plotParams.plotType = this.plotType, this.feature.setProperties(this.plotParams))
|
||
}
|
||
|
||
mapNextClickHandler(t) {
|
||
if (!this.plot.freehand && US(t.coordinate, this.points[this.points.length - 1]) < 1e-4) return !1;
|
||
this.points.push(t.coordinate), this.plot.setPoints(this.points), this.plot.fixPointCount === this.plot.getPointCount() && this.mapDoubleClickHandler(t), this.plot && this.plot.freehand && this.mapDoubleClickHandler(t)
|
||
}
|
||
|
||
mapDoubleClickHandler(t) {
|
||
t.preventDefault(), this.plot.finishDrawing(), this.drawEnd(t)
|
||
}
|
||
|
||
mapMouseMoveHandler(t) {
|
||
let e = t.coordinate;
|
||
if (US(e, this.points[this.points.length - 1]) < 1e-4) return !1;
|
||
if (this.plot.freehand) this.points.push(e), this.plot.setPoints(this.points); else {
|
||
let t = this.points.concat([e]);
|
||
this.plot.setPoints(t)
|
||
}
|
||
}
|
||
|
||
removeEventHandlers() {
|
||
this.map.un("click", this.mapFirstClickHandler), this.map.un("click", this.mapNextClickHandler), this.map.un("pointermove", this.mapMouseMoveHandler), this.map.un("dblclick", this.mapDoubleClickHandler)
|
||
}
|
||
|
||
drawEnd(t) {
|
||
this.dispatchSync("drawEnd", {
|
||
type: "drawEnd",
|
||
originalEvent: t,
|
||
feature: this.feature
|
||
}), this.feature && this.options.isClear && this.drawLayer.getSource().removeFeature(this.feature), this.disActive()
|
||
}
|
||
|
||
addFeature() {
|
||
this.feature = new X(this.plot), this.feature && this.drawLayer && this.drawLayer.getSource().addFeature(this.feature)
|
||
}
|
||
|
||
deactiveMapTools() {
|
||
this.map.getInteractions().getArray().every(t => !(t instanceof Bs && (this.dblClickZoomInteraction = t, this.map.removeInteraction(t), 1)))
|
||
}
|
||
|
||
activateMapTools() {
|
||
this.dblClickZoomInteraction && this.dblClickZoomInteraction instanceof Bs && (this.map.addInteraction(this.dblClickZoomInteraction), this.dblClickZoomInteraction = null)
|
||
}
|
||
};
|
||
var LT = class extends kS {
|
||
constructor(t) {
|
||
if (super(), !(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t, this.mapViewport = this.map.getViewport(), this.activePlot = null, this.startPoint = null, this.ghostControlPoints = null, this.controlPoints = null, this.mouseOver = !1, this.elementTable = {}, this.activeControlPointId = null, this.mapDragPan = null, this.previousCursor_ = null, uE(["controlPointMouseDownHandler", "controlPointMouseMoveHandler2", "controlPointMouseUpHandler", "controlPointMouseMoveHandler", "plotMouseOverOutHandler", "plotMouseDownHandler", "plotMouseUpHandler", "plotMouseMoveHandler"], this)
|
||
}
|
||
|
||
initHelperDom() {
|
||
if (!this.map || !this.activePlot) return !1;
|
||
let t = this.getMapParentElement();
|
||
if (!t) return !1;
|
||
{
|
||
let e = wE("div", t, jS), i = this.getControlPoints();
|
||
i && Array.isArray(i) && i.length > 0 && i.forEach((t, i) => {
|
||
let r = GS + "-" + i;
|
||
vE("div", GS, e, r), this.elementTable[r] = i
|
||
})
|
||
}
|
||
}
|
||
|
||
getMapParentElement() {
|
||
let t = this.map.getTargetElement();
|
||
return !!t && t.parentNode
|
||
}
|
||
|
||
destroyHelperDom() {
|
||
this.controlPoints && Array.isArray(this.controlPoints) && this.controlPoints.length > 0 && (this.controlPoints.forEach((t, e) => {
|
||
t && t instanceof sh && this.map.removeOverlay(t);
|
||
let i = _E(GS + "-" + e);
|
||
i && (SE(i, "mousedown", this.controlPointMouseDownHandler.bind(this)), SE(i, "mousemove", this.controlPointMouseMoveHandler2.bind(this)))
|
||
}), this.controlPoints = []);
|
||
let t = this.getMapParentElement(), e = _E(jS);
|
||
e && t && xE(e, t)
|
||
}
|
||
|
||
initControlPoints() {
|
||
this.controlPoints = [];
|
||
let t = this.getControlPoints();
|
||
t && Array.isArray(t) && t.length > 0 && t.forEach((e, i) => {
|
||
let r = GS + "-" + i;
|
||
this.elementTable[r] = i;
|
||
let o = _E(r), n = new sh({id: r, position: t[i], positioning: "center-center", element: o});
|
||
this.controlPoints.push(n), this.map.addOverlay(n, !0), this.map.render(), CE(o, "mousedown", this.controlPointMouseDownHandler), CE(o, "mousemove", this.controlPointMouseMoveHandler2)
|
||
})
|
||
}
|
||
|
||
controlPointMouseMoveHandler2(t) {
|
||
t.stopImmediatePropagation()
|
||
}
|
||
|
||
controlPointMouseDownHandler(t) {
|
||
this.activeControlPointId = t.target.id, this.map.on("pointermove", this.controlPointMouseMoveHandler), CE(this.mapViewport, "mouseup", this.controlPointMouseUpHandler)
|
||
}
|
||
|
||
controlPointMouseMoveHandler(t) {
|
||
let e = t.coordinate;
|
||
if (this.activeControlPointId) {
|
||
let t = this.activePlot.getGeometry(), i = this.elementTable[this.activeControlPointId];
|
||
t.updatePoint(e, i);
|
||
let r = this.map.getOverlayById(this.activeControlPointId);
|
||
r && r.setPosition(e)
|
||
}
|
||
}
|
||
|
||
controlPointMouseUpHandler(t) {
|
||
this.map.un("pointermove", this.controlPointMouseMoveHandler), SE(this.mapViewport, "mouseup", this.controlPointMouseUpHandler)
|
||
}
|
||
|
||
activate(t) {
|
||
t && t instanceof X && t.get("isPlot") && t.getGeometry().isPlot && t !== this.activePlot && (this.deactivate(), this.activePlot = t, this.previousCursor_ = this.map.getTargetElement().style.cursor, window.setTimeout(() => {
|
||
this.dispatch("active_plot_change", this.activePlot)
|
||
}, 500), this.map.on("pointermove", this.plotMouseOverOutHandler), this.initHelperDom(), this.initControlPoints())
|
||
}
|
||
|
||
getControlPoints() {
|
||
let t = [];
|
||
if (this.activePlot) {
|
||
let e = this.activePlot.getGeometry();
|
||
e && (t = e.getPoints())
|
||
}
|
||
return t
|
||
}
|
||
|
||
plotMouseOverOutHandler(t) {
|
||
let e = this.map.forEachFeatureAtPixel(t.pixel, function (t) {
|
||
return t
|
||
});
|
||
return e && e === this.activePlot ? this.mouseOver || (this.mouseOver = !0, this.map.getTargetElement().style.cursor = "move", this.map.on("pointerdown", this.plotMouseDownHandler)) : this.mouseOver && (this.mouseOver = !1, this.map.getTargetElement().style.cursor = "default", this.map.un("pointerdown", this.plotMouseDownHandler)), e
|
||
}
|
||
|
||
plotMouseDownHandler(t) {
|
||
this.ghostControlPoints = this.getControlPoints(), this.startPoint = t.coordinate, this.disableMapDragPan(), this.map.on("pointerup", this.plotMouseUpHandler), this.map.on("pointerdrag", this.plotMouseMoveHandler)
|
||
}
|
||
|
||
plotMouseMoveHandler(t) {
|
||
let [e, i, r] = [t.coordinate[0] - this.startPoint[0], t.coordinate[1] - this.startPoint[1], []];
|
||
if (this.ghostControlPoints && Array.isArray(this.ghostControlPoints) && this.ghostControlPoints.length > 0) for (let t = 0; t < this.ghostControlPoints.length; t++) {
|
||
let o = [this.ghostControlPoints[t][0] + e, this.ghostControlPoints[t][1] + i];
|
||
r.push(o);
|
||
let n = GS + "-" + t, s = this.map.getOverlayById(n);
|
||
s && (s.setPosition(o), s.setPositioning("center-center"))
|
||
}
|
||
this.activePlot.getGeometry().setPoints(r)
|
||
}
|
||
|
||
plotMouseUpHandler(t) {
|
||
this.enableMapDragPan(), this.map.un("pointerup", this.plotMouseUpHandler), this.map.un("pointerdrag", this.plotMouseMoveHandler)
|
||
}
|
||
|
||
disconnectEventHandlers() {
|
||
this.map.un("pointermove", this.plotMouseOverOutHandler), this.map.un("pointermove", this.controlPointMouseMoveHandler), SE(this.mapViewport, "mouseup", this.controlPointMouseUpHandler), this.map.un("pointerdown", this.plotMouseDownHandler), this.map.un("pointerup", this.plotMouseUpHandler), this.map.un("pointerdrag", this.plotMouseMoveHandler)
|
||
}
|
||
|
||
deactivate() {
|
||
this.activePlot = null, this.mouseOver = !1, this.map.getTargetElement().style.cursor = this.previousCursor_, this.previousCursor_ = null, this.destroyHelperDom(), this.disconnectEventHandlers(), this.enableMapDragPan(), this.elementTable = {}, this.activeControlPointId = null, this.startPoint = null
|
||
}
|
||
|
||
disableMapDragPan() {
|
||
this.map.getInteractions().getArray().every(t => !(t instanceof oa && (this.mapDragPan = t, this.map.removeInteraction(t), 1)))
|
||
}
|
||
|
||
enableMapDragPan() {
|
||
this.mapDragPan && this.mapDragPan instanceof oa && (this.map.addInteraction(this.mapDragPan), this.mapDragPan = null)
|
||
}
|
||
};
|
||
const IT = function (t) {
|
||
let e = t && "object" == typeof t ? t : {}, i = new uf({});
|
||
return e.geometry && e.geometry instanceof _i && i.setGeometry(e.geometry), e.zIndex && "number" == typeof e.zIndex && i.setZIndex(e.zIndex), e.fill && "object" == typeof e.fill && i.setFill(this._getFill(e.fill)), e.image && "object" == typeof e.image && i.setImage(this._getImage(e.image)), e.stroke && "object" == typeof e.stroke && i.setStroke(this._getStroke(e.stroke)), e.text && "object" == typeof e.text && i.setText(this._getText(e.text)), i
|
||
};
|
||
IT.prototype._getRegularShape = function (t) {
|
||
try {
|
||
return new qd({
|
||
fill: this._getFill(t.fill) || void 0,
|
||
points: "number" == typeof t.points ? t.points : 1,
|
||
radius: "number" == typeof t.radius ? t.radius : void 0,
|
||
radius1: "number" == typeof t.radius1 ? t.radius1 : void 0,
|
||
radius2: "number" == typeof t.radius2 ? t.radius2 : void 0,
|
||
angle: "number" == typeof t.angle ? t.angle : 0,
|
||
snapToPixel: "boolean" != typeof t.snapToPixel || t.snapToPixel,
|
||
stroke: this._getStroke(t.stroke) || void 0,
|
||
rotation: "number" == typeof t.rotation ? t.rotation : 0,
|
||
rotateWithView: "boolean" == typeof t.rotateWithView && t.rotateWithView,
|
||
atlasManager: t.atlasManager ? t.atlasManager : void 0
|
||
})
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}, IT.prototype._getImage = function (t) {
|
||
try {
|
||
let e;
|
||
return e = "icon" === (t = t || {}).type ? this._getIcon(t.image) : this._getRegularShape(t.image)
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}, IT.prototype._getIcon = function (t) {
|
||
try {
|
||
return new Xd({
|
||
anchor: (t = t || {}).imageAnchor ? t.imageAnchor : [.5, .5],
|
||
anchorXUnits: t.imageAnchorXUnits ? t.imageAnchorXUnits : "fraction",
|
||
anchorYUnits: t.imageAnchorYUnits ? t.imageAnchorYUnits : "fraction",
|
||
anchorOrigin: t.imageAnchorOrigin ? t.imageAnchorYUnits : "top-left",
|
||
color: t.imageColor ? t.imageColor : void 0,
|
||
crossOrigin: t.crossOrigin ? t.crossOrigin : void 0,
|
||
img: t.img ? t.img : void 0,
|
||
offset: t.offset && Array.isArray(t.offset) && 2 === t.offset.length ? t.offset : [0, 0],
|
||
offsetOrigin: t.offsetOrigin ? t.offsetOrigin : "top-left",
|
||
scale: "number" == typeof t.scale ? t.scale : 1,
|
||
snapToPixel: "boolean" != typeof t.snapToPixel || t.snapToPixel,
|
||
rotateWithView: "boolean" == typeof t.rotateWithView && t.rotateWithView,
|
||
opacity: "number" == typeof t.imageOpacity ? t.imageOpacity : 1,
|
||
rotation: "number" == typeof t.imageRotation ? t.imageRotation : 0,
|
||
size: t.size && Array.isArray(t.size) && 2 === t.size.length ? t.size : void 0,
|
||
imgSize: t.imgSize && Array.isArray(t.imgSize) && 2 === t.imgSize.length ? t.imgSize : void 0,
|
||
src: t.imageSrc ? t.imageSrc : void 0
|
||
})
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}, IT.prototype._getStroke = function (t) {
|
||
try {
|
||
return new go({
|
||
color: (t = t || {}).strokeColor ? t.strokeColor : void 0,
|
||
lineCap: t.strokeLineCap && "string" == typeof t.strokeLineCap ? t.strokeLineCap : "round",
|
||
lineJoin: t.strokeLineJoin && "string" == typeof t.strokeLineJoin ? t.strokeLineJoin : "round",
|
||
lineDash: t.strokeLineDash ? t.strokeLineDash : void 0,
|
||
lineDashOffset: "number" == typeof t.strokeLineDashOffset ? t.strokeLineDashOffset : "0",
|
||
miterLimit: "number" == typeof t.strokeMiterLimit ? t.strokeMiterLimit : 10,
|
||
width: "number" == typeof t.strokeWidth ? t.strokeWidth : void 0
|
||
})
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}, IT.prototype._getText = function (t) {
|
||
try {
|
||
return new vo({
|
||
font: t.textFont && "string" == typeof t.textFont ? t.textFont : "10px sans-serif",
|
||
offsetX: "number" == typeof t.textOffsetX ? t.textOffsetX : 0,
|
||
offsetY: "number" == typeof t.textOffsetY ? t.textOffsetY : 0,
|
||
scale: "number" == typeof t.textScale ? t.textScale : void 0,
|
||
rotation: "number" == typeof t.textRotation ? t.textRotation : 0,
|
||
text: t.text && "string" == typeof t.text ? t.text : void 0,
|
||
textAlign: t.textAlign && "string" == typeof t.textAlign ? t.textAlign : "start",
|
||
textBaseline: t.textBaseline && "string" == typeof t.textBaseline ? t.textBaseline : "alphabetic",
|
||
rotateWithView: "boolean" == typeof t.rotateWithView && t.rotateWithView,
|
||
fill: this._getFill(t.textFill),
|
||
stroke: this._getStroke(t.textStroke)
|
||
})
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
}, IT.prototype._getFill = function (t) {
|
||
try {
|
||
return new po({color: (t = t || {}).fillColor ? t.fillColor : void 0})
|
||
} catch (t) {
|
||
console.log(t)
|
||
}
|
||
};
|
||
var OT = IT;
|
||
var MT = class {
|
||
constructor(t, e) {
|
||
if (!(t && t instanceof rh)) throw new Error("传入的不是地图对象!");
|
||
this.map = t, this.options = e, this.layerName = this.options && this.options.layerName ? this.options.layerName : DS
|
||
}
|
||
|
||
getBaseStyle(t) {
|
||
let e = t.getStyle();
|
||
if (!e) {
|
||
let t = cE(this.map, this.layerName);
|
||
if (!(t && t instanceof v_)) return !1;
|
||
e = t.getStyle()
|
||
}
|
||
return e
|
||
}
|
||
|
||
setIcon(t, e) {
|
||
try {
|
||
if (t && t instanceof X) {
|
||
let i = this.getBaseStyle(t).clone(), r = this._getImage(e);
|
||
r && (i.setImage(r), t.setStyle(i))
|
||
}
|
||
} catch (t) {
|
||
console.warn(t)
|
||
}
|
||
}
|
||
|
||
setBackgroundColor(t, e) {
|
||
try {
|
||
if (t && t instanceof X) {
|
||
let i = this.getBaseStyle(t).clone(), r = i.getFill(), o = r.getColor();
|
||
if (o) {
|
||
let n = lo(o), s = lo(e), a = this.handleBackgroundColor(s, n[3]);
|
||
r.setColor(a), t.setStyle(i)
|
||
}
|
||
}
|
||
} catch (t) {
|
||
console.warn(t)
|
||
}
|
||
}
|
||
|
||
setOpacity(t, e) {
|
||
try {
|
||
if (t && t instanceof X) {
|
||
let i = this.getBaseStyle(t);
|
||
if (i) {
|
||
let r = i.clone(), o = r.getFill(), n = o.getColor();
|
||
if (n) {
|
||
let i = lo(n);
|
||
i[3] = e;
|
||
let s = "rgba(" + i.join(",") + ")";
|
||
o.setColor(s), t.setStyle(r)
|
||
}
|
||
}
|
||
}
|
||
} catch (t) {
|
||
console.warn(t)
|
||
}
|
||
}
|
||
|
||
setBorderColor(t, e) {
|
||
try {
|
||
if (t && t instanceof X) {
|
||
let i = this.getBaseStyle(t).clone();
|
||
i.getStroke().setColor(e), t.setStyle(i)
|
||
}
|
||
} catch (t) {
|
||
console.warn(t)
|
||
}
|
||
}
|
||
|
||
setBorderWidth(t, e) {
|
||
try {
|
||
if (t && t instanceof X) {
|
||
let i = this.getBaseStyle(t).clone();
|
||
i.getStroke().setWidth(e), t.setStyle(i)
|
||
}
|
||
} catch (t) {
|
||
console.warn(t)
|
||
}
|
||
}
|
||
|
||
handleBackgroundColor(t, e) {
|
||
try {
|
||
e || (e = 1);
|
||
let i = lo(t);
|
||
return i[3] = e, "rgba(" + i.join(",") + ")"
|
||
} catch (t) {
|
||
console.warn(t)
|
||
}
|
||
}
|
||
|
||
getColor(t) {
|
||
try {
|
||
return oo(lo(t))
|
||
} catch (t) {
|
||
console.warn(t)
|
||
}
|
||
}
|
||
|
||
fixObject(t) {
|
||
if (t && "object" == typeof t) for (let e in t) e && void 0 === t[e] && delete t[e];
|
||
return t
|
||
}
|
||
|
||
getStroke_(t) {
|
||
let e = null;
|
||
if (t) {
|
||
let i = t.getStroke();
|
||
i && ((e = {}).strokeColor = this.getColor(i.getColor()), e.strokeWidth = i.getWidth(), e.strokeLineDash = i.getLineDash(), e.lineDashOffset = i.getLineDashOffset(), e.strokeLineCap = i.getLineCap(), e.strokeLineJoin = i.getLineJoin(), e.strokeMiterLimit = i.getMiterLimit())
|
||
}
|
||
return this.fixObject(e)
|
||
}
|
||
|
||
getFill_(t) {
|
||
let e = null;
|
||
if (t) {
|
||
let i = t.getFill();
|
||
if (i) {
|
||
e = {};
|
||
let t = i.getColor();
|
||
e.fillColor = this.getColor(t)
|
||
}
|
||
}
|
||
return this.fixObject(e)
|
||
}
|
||
|
||
getText_(t) {
|
||
let e = null;
|
||
if (t) {
|
||
let i = t.getText();
|
||
i && ((e = {}).textFont = i.getFont(), e.textOffsetX = i.getOffsetX(), e.textOffsetY = i.getOffsetY(), e.textScale = i.getScale(), e.textRotation = i.getRotation(), e.text = i.getText(), e.textAlign = i.getTextAlign(), e.textBaseline = i.getTextBaseline(), e.rotateWithView = i.getRotateWithView(), e.textFill = this.getFill_(i), e.textStroke = this.getStroke_(i))
|
||
}
|
||
return this.fixObject(e)
|
||
}
|
||
|
||
getImage_(t) {
|
||
let e = null;
|
||
if (t) {
|
||
let i = t.getImage();
|
||
i && (e = {}, i instanceof Xd ? (e.type = "icon", e.image = {}, e.image.imageAnchor = i.getAnchor(), e.image.imageColor = i.getColor(), e.image.imageSrc = i.getSrc(), e.image.imgSize = i.getSize(), e.image.scale = i.getScale(), e.image.imageRotation = i.getRotation(), e.image.rotateWithView = i.getRotateWithView(), e.image.imageOpacity = i.getOpacity(), e.image.snapToPixel = i.getSnapToPixel(), e.image.offset = i.getOrigin()) : i instanceof qd && (e.type = "", e.image = {}, e.image.fill = this.getFill_(i), e.image.points = i.getPoints(), e.image.radius = i.getRadius(), e.image.radius2 = i.getRadius2(), e.image.angle = i.getAngle(), e.image.stroke = this.getStroke_(i), e.image.rotateWithView = i.getRotateWithView(), e.image.snapToPixel = i.getSnapToPixel()))
|
||
}
|
||
return this.fixObject(e)
|
||
}
|
||
|
||
getStyleCode(t) {
|
||
try {
|
||
if (t && t instanceof X) {
|
||
let e = this.getBaseStyle(t);
|
||
if (e && e instanceof uf) {
|
||
let t = this.getFill_(e), [i, r, o] = [1, null];
|
||
t && t.fillColor && (r = lo(t.fillColor), i = parseFloat(r[3]), r && "number" == typeof i && (o = this.handleBackgroundColor(oo(r), i)));
|
||
let n = this.getStroke_(e), s = this.getText_(e);
|
||
return {fill: {fillColor: o, opacity: i}, stroke: n, image: this.getImage_(e), text: s}
|
||
}
|
||
}
|
||
} catch (t) {
|
||
console.warn(t)
|
||
}
|
||
}
|
||
|
||
removeAllFeatures() {
|
||
const t = cE(this.map, this.layerName), e = this.map.getOverlays().getArray();
|
||
if (t && t.getSource().clear(), e && e.length > 0) {
|
||
let t = e.length;
|
||
for (let i = 0; i < t; i++) e[i] && e[i].get("isPlotText") && (this.map.removeOverlay(e[i]), i--)
|
||
}
|
||
}
|
||
|
||
getFeatures() {
|
||
let t = [], e = cE(this.map, this.layerName);
|
||
if (e) {
|
||
let i = e.getSource();
|
||
if (i && i instanceof b_) {
|
||
let e = i.getFeatures();
|
||
e && e.length > 0 && e.forEach((e, i) => {
|
||
if (e && e.getGeometry) {
|
||
let i = e.getGeometry();
|
||
if (i && i.getCoordinates) {
|
||
let r = i.getType(), o = i.getCoordinates();
|
||
t.push({
|
||
type: "Feature",
|
||
geometry: {type: r, coordinates: o},
|
||
properties: {
|
||
type: e.getGeometry().getPlotType(),
|
||
style: this.getStyleCode(e),
|
||
points: e.getGeometry().getPoints()
|
||
}
|
||
})
|
||
}
|
||
}
|
||
})
|
||
}
|
||
}
|
||
return this.map.getOverlays().getArray().forEach(e => {
|
||
if (e.get("isPlotText")) {
|
||
const i = e.getStyle();
|
||
i.width = e.getWidth() + "px", i.height = e.getHeight() + "px", t.push({
|
||
type: "Feature",
|
||
geometry: {type: "PlotText", coordinates: e.getPosition()},
|
||
properties: {
|
||
id: e.getId(),
|
||
width: e.getWidth(),
|
||
height: e.getHeight(),
|
||
style: i,
|
||
value: e.getValue()
|
||
}
|
||
})
|
||
}
|
||
}), t
|
||
}
|
||
|
||
addFeatures(t) {
|
||
if (t && Array.isArray(t) && t.length > 0) {
|
||
let e = cE(this.map, this.layerName);
|
||
if (e || (e = dE(this.map, this.layerName, {create: !0})).setZIndex(this.options.zIndex || 99), e) {
|
||
let i = e.getSource();
|
||
if (i && i instanceof b_) {
|
||
const e = [];
|
||
if (t.forEach(t => {
|
||
if (t && t.geometry && "PlotText" !== t.geometry.type) if (t.properties.type && o[t.properties.type]) {
|
||
let r = new X({geometry: new o[t.properties.type]([], t.properties.points, t.properties)});
|
||
if (r.set("isPlot", !0), e.push(r.getGeometry().getExtent()), t.properties.style) {
|
||
let e = new OT(t.properties.style);
|
||
e && r.setStyle(e)
|
||
}
|
||
i.addFeature(r)
|
||
} else console.warn("不存在的标绘类型!"); else if (t && t.geometry && "PlotText" === t.geometry.type) {
|
||
e.push(new qi(t.geometry.coordinates).getExtent());
|
||
const i = new PE({
|
||
id: t.properties.id,
|
||
position: t.geometry.coordinates,
|
||
width: t.properties.width,
|
||
height: t.properties.height,
|
||
value: t.properties.value,
|
||
style: t.properties.style
|
||
});
|
||
this.map && this.map instanceof rh && i ? this.map.addOverlay(i) : console.warn("未传入地图对象或者plotText创建失败!")
|
||
}
|
||
}), this.options.zoomToExtent && e && e.length > 0) {
|
||
const t = this._getExtent(e), i = this.map.getSize(), r = this.map.getView();
|
||
r.fit(t, {size: i, duration: 800, maxZoom: r.getMaxZoom() || void 0})
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
_getExtent(t, e = {}) {
|
||
const i = [Number.POSITIVE_INFINITY, Number.POSITIVE_INFINITY, Number.NEGATIVE_INFINITY, Number.NEGATIVE_INFINITY];
|
||
let r = t.reduce(function (t, e) {
|
||
return [Math.min(e[0], t[0]), Math.min(e[1], t[1]), Math.max(e[2], t[2]), Math.max(e[3], t[3])]
|
||
}, i), o = Gt(r), n = "number" == typeof e.adjust ? e.adjust : .2,
|
||
s = "number" == typeof e.minWidth ? e.minWidth : .05,
|
||
a = "number" == typeof e.minHeight ? e.minHeight : .05;
|
||
if (o[0] <= s || o[1] <= a) {
|
||
let t = Ot(r), e = zt(r);
|
||
r = ht([t[0] - n, t[1] - n, e[0] + n, e[1] + n], n)
|
||
}
|
||
return r
|
||
}
|
||
};
|
||
var AT = class {
|
||
constructor(t, e) {
|
||
this.plotDraw = new PT(t, e), this.plotEdit = new LT(t, e), this.plotUtils = new MT(t, e)
|
||
}
|
||
}, kT = window.Ez = {};
|
||
kT.Coordinate = rC, window.EzCoord = rC, kT.Overlay = oC, window.EzOverlay = oC, kT.Icon = nC, window.EzIcon = nC, kT.MBR = sC, window.EzMBR = sC, kT.Event = aC, kT.Global = gC, window.EzGlobal = gC, kT.HTMLElementOverLay = mC, window.HTMLElementOverLay = mC, kT.License = yC, kT.MarkerDragEvent = _C, kT.Marker = xC, window.EzMarker = xC, kT.PopupEvent = wC, kT.Popup = bC, window.EzPopup = bC, kT.Title = CC, window.EzTitle = CC, kT.Map = TC, window.EzMap = TC, kT.PopupTargetMoveEvent = class extends ol.events.Event {
|
||
constructor(t) {
|
||
super(t)
|
||
}
|
||
}, kT.ViewOptions = EC, kT.Json2Style = RC, window.EzJson2Style = RC, kT.Json2StyleMapbox = PC, window.EzJson2StyleMapbox = PC, kT.utility = {}, kT.utility.Measure = SC, kT.VectorLayer = {}, kT.VectorLayer.Base = LC, window.EzVectorLayerBase = LC, kT.VectorLayer.WMTS_SL = IC, window.EzVectorLayerWMTS_SL = IC, kT.TileLayer = {}, kT.TileLayer.Base = lC, window.EzTileLayerBase = lC, kT.TileLayer.GD = dC, window.EzTileLayerGD = dC, kT.TileLayer.XYZ = OC, window.EzTileLayerXYZ = OC, kT.TileLayer.EzMap2010Proj = cC, window.EzTileLayerEzMap2010Proj = cC, kT.TileLayer.EzMap2010 = uC, window.EzTileLayerEzMap2010 = uC, kT.TileLayer.TDT = fC, window.EzTileLayerTDT = fC, kT.TileLayer.WMTS = pC, window.EzTileLayerWMTS = pC, kT.TileLayer.HotSpot = AC, window.EzTileLayerHotSpot = AC, kT.TileLayer.MultiHotSpot = kC, window.EzTileLayerMultiHotSpot = kC, kT.TileLayer.SingleHotSpot = FC, window.EzTileLayerSingleHotSpot = FC, kT.animation = {}, kT.animation.Compose = DC, kT.animation.ComposeEvent = NC, kT.animation.InteropFn = GC, kT.animation.linear = jC, kT.animation.Parallel = zC, kT.animation.Transition = UC, kT.animation.Sequence = BC, kT.animation.Translate = VC, kT.animation.Rotate = YC, kT.controls = {}, kT.controls.Attr = WC, kT.controls.Layers = XC, kT.control = {}, kT.controls.NavBar = qC, kT.controls.Overview = ZC, kT.controls.ScaleLine = KC, kT.controls.SimpleLayers = JC, kT.controls.SimpleZoom = QC, kT.controls.ZoomSlider = eS, kT.g = {}, kT.g.Circle = iS, window.Circle = iS, kT.g.Point = rS, window.Point = rS, kT.g.Polygon = nS, window.Polygon = nS, kT.g.Polyline = sS, window.Polyline = sS, kT.g.Rectangle = aS, window.Rectangle = aS, kT.Layer = {}, kT.Layer.Cluster = lS, window.EzLayerCluster = lS, kT.Layer.Group = hS, window.EzLayerGroup = hS, kT.Layer.HeatMap = uS, window.EzLayerHeatMap = uS, kT.Layer.ImageWMS = cS, kT.style = {}, kT.style.Circle = pS, kT.style.Fill = dS, kT.style.Icon = fS,kT.style.Stroke = gS,kT.style.Style = mS,kT.style.Text = yS,ol.format.HotSpotCluster = vS,ol.format.HotSpot = _S,ol.interaction.AddDOMForClick = wS,ol.interaction.DragFeature = CS,ol.interaction.EditCircle = ES,ol.interaction.Draw2 = LS,ol.source.Cluster2 = IS,ol.source.EzMap2010 = hC,ol.source.EzHotspot = OS,ol.source.SingleHotSpot = MS,kT.olPlot = AT
|
||
}])
|
||
});
|
||
//# sourceMappingURL=FMapClient.js.map |