Server IP : 15.235.198.142 / Your IP : 216.73.216.190 Web Server : Apache/2.4.58 (Ubuntu) System : Linux ballsack 6.8.0-45-generic #45-Ubuntu SMP PREEMPT_DYNAMIC Fri Aug 30 12:02:04 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 8.3.6 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : OFF Directory : /usr/share/phpmyadmin/js/vendor/openlayers/ |
Upload File : |
{"version":3,"file":"OpenLayers.js","mappings":"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","sources":["webpack://ol/webpack/universalModuleDefinition","webpack://ol/webpack/bootstrap","webpack://ol/webpack/runtime/define property getters","webpack://ol/webpack/runtime/hasOwnProperty shorthand","webpack://ol/./debian/missing-sources/ol/events/Event.js","webpack://ol/./debian/missing-sources/ol/ObjectEventType.js","webpack://ol/./debian/missing-sources/ol/Disposable.js","webpack://ol/./debian/missing-sources/ol/array.js","webpack://ol/./debian/missing-sources/ol/functions.js","webpack://ol/./debian/missing-sources/ol/obj.js","webpack://ol/./debian/missing-sources/ol/events/Target.js","webpack://ol/./debian/missing-sources/ol/events/EventType.js","webpack://ol/./debian/missing-sources/ol/events.js","webpack://ol/./debian/missing-sources/ol/Observable.js","webpack://ol/./debian/missing-sources/ol/util.js","webpack://ol/./debian/missing-sources/ol/Object.js","webpack://ol/./debian/missing-sources/ol/MapEventType.js","webpack://ol/./debian/missing-sources/ol/has.js","webpack://ol/./debian/missing-sources/ol/dom.js","webpack://ol/./debian/missing-sources/ol/control/Control.js","webpack://ol/./debian/missing-sources/ol/css.js","webpack://ol/./debian/missing-sources/ol/layer/Property.js","webpack://ol/./debian/missing-sources/ol/AssertionError.js","webpack://ol/./debian/missing-sources/ol/asserts.js","webpack://ol/./debian/missing-sources/ol/math.js","webpack://ol/./debian/missing-sources/ol/layer/Base.js","webpack://ol/./debian/missing-sources/ol/render/EventType.js","webpack://ol/./debian/missing-sources/ol/source/State.js","webpack://ol/./debian/missing-sources/ol/layer/Layer.js","webpack://ol/./debian/missing-sources/ol/control/Attribution.js","webpack://ol/./debian/missing-sources/ol/pointer/EventType.js","webpack://ol/./debian/missing-sources/ol/proj/Units.js","webpack://ol/./debian/missing-sources/ol/proj/Projection.js","webpack://ol/./debian/missing-sources/ol/proj/epsg3857.js","webpack://ol/./debian/missing-sources/ol/proj/epsg4326.js","webpack://ol/./debian/missing-sources/ol/proj/projections.js","webpack://ol/./debian/missing-sources/ol/proj/transforms.js","webpack://ol/./debian/missing-sources/ol/extent/Corner.js","webpack://ol/./debian/missing-sources/ol/extent/Relationship.js","webpack://ol/./debian/missing-sources/ol/extent.js","webpack://ol/./debian/missing-sources/ol/sphere.js","webpack://ol/./debian/missing-sources/ol/proj.js","webpack://ol/./debian/missing-sources/ol/control/MousePosition.js","webpack://ol/./debian/missing-sources/ol/easing.js","webpack://ol/./debian/missing-sources/ol/control/Zoom.js","webpack://ol/./debian/missing-sources/ol/coordinate.js","webpack://ol/./debian/missing-sources/ol/geom/GeometryLayout.js","webpack://ol/./debian/missing-sources/ol/transform.js","webpack://ol/./debian/missing-sources/ol/geom/GeometryType.js","webpack://ol/./debian/missing-sources/ol/geom/flat/transform.js","webpack://ol/./debian/missing-sources/ol/geom/Geometry.js","webpack://ol/./debian/missing-sources/ol/geom/SimpleGeometry.js","webpack://ol/./debian/missing-sources/ol/geom/flat/closest.js","webpack://ol/./debian/missing-sources/ol/geom/flat/deflate.js","webpack://ol/./debian/missing-sources/ol/geom/flat/simplify.js","webpack://ol/./debian/missing-sources/ol/geom/flat/segments.js","webpack://ol/./debian/missing-sources/ol/geom/flat/inflate.js","webpack://ol/./debian/missing-sources/ol/geom/flat/interpolate.js","webpack://ol/./debian/missing-sources/ol/geom/flat/contains.js","webpack://ol/./debian/missing-sources/ol/geom/flat/intersectsextent.js","webpack://ol/./debian/missing-sources/ol/geom/flat/length.js","webpack://ol/./debian/missing-sources/ol/geom/LineString.js","webpack://ol/./debian/missing-sources/ol/geom/flat/area.js","webpack://ol/./debian/missing-sources/ol/geom/LinearRing.js","webpack://ol/./debian/missing-sources/ol/geom/MultiLineString.js","webpack://ol/./debian/missing-sources/ol/geom/Point.js","webpack://ol/./debian/missing-sources/ol/geom/MultiPoint.js","webpack://ol/./debian/missing-sources/ol/geom/flat/interiorpoint.js","webpack://ol/./debian/missing-sources/ol/geom/flat/reverse.js","webpack://ol/./debian/missing-sources/ol/geom/flat/orient.js","webpack://ol/./debian/missing-sources/ol/geom/Polygon.js","webpack://ol/./debian/missing-sources/ol/geom/MultiPolygon.js","webpack://ol/./debian/missing-sources/ol/geom/flat/center.js","webpack://ol/./debian/missing-sources/ol/layer/TileProperty.js","webpack://ol/./debian/missing-sources/ol/layer/BaseTile.js","webpack://ol/./debian/missing-sources/ol/renderer/Layer.js","webpack://ol/./debian/missing-sources/ol/ImageState.js","webpack://ol/./debian/missing-sources/ol/render/Event.js","webpack://ol/./debian/missing-sources/ol/renderer/canvas/Layer.js","webpack://ol/./debian/missing-sources/ol/TileRange.js","webpack://ol/./debian/missing-sources/ol/renderer/canvas/TileLayer.js","webpack://ol/./debian/missing-sources/ol/TileState.js","webpack://ol/./debian/missing-sources/ol/layer/Tile.js","webpack://ol/./debian/missing-sources/quickselect/index.js","webpack://ol/./debian/missing-sources/rbush/rbush.js","webpack://ol/./debian/missing-sources/ol/size.js","webpack://ol/./debian/missing-sources/ol/style/Image.js","webpack://ol/./debian/missing-sources/ol/color.js","webpack://ol/./debian/missing-sources/ol/colorlike.js","webpack://ol/./debian/missing-sources/ol/render/canvas.js","webpack://ol/./debian/missing-sources/ol/style/RegularShape.js","webpack://ol/./debian/missing-sources/ol/style/Circle.js","webpack://ol/./debian/missing-sources/ol/style/Fill.js","webpack://ol/./debian/missing-sources/ol/style/Stroke.js","webpack://ol/./debian/missing-sources/ol/style/Style.js","webpack://ol/./debian/missing-sources/ol/layer/BaseVector.js","webpack://ol/./debian/missing-sources/ol/render/canvas/Instruction.js","webpack://ol/./debian/missing-sources/ol/render/VectorContext.js","webpack://ol/./debian/missing-sources/ol/render/canvas/Builder.js","webpack://ol/./debian/missing-sources/ol/render/canvas/ImageBuilder.js","webpack://ol/./debian/missing-sources/ol/render/canvas/LineStringBuilder.js","webpack://ol/./debian/missing-sources/ol/render/canvas/PolygonBuilder.js","webpack://ol/./debian/missing-sources/ol/geom/flat/straightchunk.js","webpack://ol/./debian/missing-sources/ol/render/canvas/TextBuilder.js","webpack://ol/./debian/missing-sources/ol/style/TextPlacement.js","webpack://ol/./debian/missing-sources/ol/render/canvas/BuilderGroup.js","webpack://ol/./debian/missing-sources/ol/render/canvas/BuilderType.js","webpack://ol/./debian/missing-sources/ol/geom/flat/textpath.js","webpack://ol/./debian/missing-sources/ol/render/canvas/Executor.js","webpack://ol/./debian/missing-sources/ol/render/canvas/ExecutorGroup.js","webpack://ol/./debian/missing-sources/ol/render/canvas/Immediate.js","webpack://ol/./debian/missing-sources/ol/style/IconAnchorUnits.js","webpack://ol/./debian/missing-sources/ol/style/IconOrigin.js","webpack://ol/./debian/missing-sources/ol/style/IconImageCache.js","webpack://ol/./debian/missing-sources/ol/ImageBase.js","webpack://ol/./debian/missing-sources/ol/Image.js","webpack://ol/./debian/missing-sources/ol/style/IconImage.js","webpack://ol/./debian/missing-sources/ol/style/Icon.js","webpack://ol/./debian/missing-sources/ol/render/canvas/hitdetect.js","webpack://ol/./debian/missing-sources/ol/renderer/vector.js","webpack://ol/./debian/missing-sources/ol/renderer/canvas/VectorLayer.js","webpack://ol/./debian/missing-sources/ol/reproj.js","webpack://ol/./debian/missing-sources/ol/ViewHint.js","webpack://ol/./debian/missing-sources/ol/layer/Vector.js","webpack://ol/./debian/missing-sources/ol/Tile.js","webpack://ol/./debian/missing-sources/ol/ImageTile.js","webpack://ol/./debian/missing-sources/ol/reproj/Triangulation.js","webpack://ol/./debian/missing-sources/ol/source/common.js","webpack://ol/./debian/missing-sources/ol/reproj/Tile.js","webpack://ol/./debian/missing-sources/ol/reproj/common.js","webpack://ol/./debian/missing-sources/ol/structs/LRUCache.js","webpack://ol/./debian/missing-sources/ol/tilecoord.js","webpack://ol/./debian/missing-sources/ol/TileCache.js","webpack://ol/./debian/missing-sources/ol/source/Source.js","webpack://ol/./debian/missing-sources/ol/tilegrid/common.js","webpack://ol/./debian/missing-sources/ol/tilegrid/TileGrid.js","webpack://ol/./debian/missing-sources/ol/tilegrid.js","webpack://ol/./debian/missing-sources/ol/source/Tile.js","webpack://ol/./debian/missing-sources/ol/tileurlfunction.js","webpack://ol/./debian/missing-sources/ol/source/UrlTile.js","webpack://ol/./debian/missing-sources/ol/source/TileEventType.js","webpack://ol/./debian/missing-sources/ol/source/TileImage.js","webpack://ol/./debian/missing-sources/ol/source/XYZ.js","webpack://ol/./debian/missing-sources/ol/source/OSM.js","webpack://ol/./debian/missing-sources/ol/CollectionEventType.js","webpack://ol/./debian/missing-sources/ol/Collection.js","webpack://ol/./debian/missing-sources/ol/structs/RBush.js","webpack://ol/./debian/missing-sources/ol/source/VectorEventType.js","webpack://ol/./debian/missing-sources/ol/loadingstrategy.js","webpack://ol/./debian/missing-sources/ol/format/FormatType.js","webpack://ol/./debian/missing-sources/ol/featureloader.js","webpack://ol/./debian/missing-sources/ol/source/Vector.js","webpack://ol/./debian/missing-sources/ol/style/Text.js","webpack://ol/./debian/missing-sources/ol/Feature.js","webpack://ol/./debian/missing-sources/ol/renderer/Map.js","webpack://ol/./debian/missing-sources/ol/renderer/Composite.js","webpack://ol/./debian/missing-sources/ol/layer/Group.js","webpack://ol/./debian/missing-sources/ol/MapEvent.js","webpack://ol/./debian/missing-sources/ol/MapBrowserEvent.js","webpack://ol/./debian/missing-sources/ol/MapBrowserEventType.js","webpack://ol/./debian/missing-sources/ol/MapBrowserEventHandler.js","webpack://ol/./debian/missing-sources/ol/MapProperty.js","webpack://ol/./debian/missing-sources/ol/structs/PriorityQueue.js","webpack://ol/./debian/missing-sources/ol/TileQueue.js","webpack://ol/./debian/missing-sources/ol/ViewProperty.js","webpack://ol/./debian/missing-sources/ol/centerconstraint.js","webpack://ol/./debian/missing-sources/ol/resolutionconstraint.js","webpack://ol/./debian/missing-sources/ol/rotationconstraint.js","webpack://ol/./debian/missing-sources/ol/View.js","webpack://ol/./debian/missing-sources/ol/PluggableMap.js","webpack://ol/./debian/missing-sources/ol/control/Rotate.js","webpack://ol/./debian/missing-sources/ol/interaction/Property.js","webpack://ol/./debian/missing-sources/ol/interaction/Interaction.js","webpack://ol/./debian/missing-sources/ol/interaction/DoubleClickZoom.js","webpack://ol/./debian/missing-sources/ol/interaction/Pointer.js","webpack://ol/./debian/missing-sources/ol/events/condition.js","webpack://ol/./debian/missing-sources/ol/interaction/DragPan.js","webpack://ol/./debian/missing-sources/ol/interaction/DragRotate.js","webpack://ol/./debian/missing-sources/ol/render/Box.js","webpack://ol/./debian/missing-sources/ol/interaction/DragBox.js","webpack://ol/./debian/missing-sources/ol/interaction/DragZoom.js","webpack://ol/./debian/missing-sources/ol/interaction/KeyboardPan.js","webpack://ol/./debian/missing-sources/ol/events/KeyCode.js","webpack://ol/./debian/missing-sources/ol/interaction/KeyboardZoom.js","webpack://ol/./debian/missing-sources/ol/Kinetic.js","webpack://ol/./debian/missing-sources/ol/interaction/MouseWheelZoom.js","webpack://ol/./debian/missing-sources/ol/interaction/PinchRotate.js","webpack://ol/./debian/missing-sources/ol/interaction/PinchZoom.js","webpack://ol/./debian/missing-sources/ol/Map.js","webpack://ol/./debian/missing-sources/ol/control.js","webpack://ol/./debian/missing-sources/ol/interaction.js","webpack://ol/./js/src/ol.mjs"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"ol\"] = factory();\n\telse\n\t\troot[\"ol\"] = factory();\n})(self, function() {\nreturn ","// The require scope\nvar __webpack_require__ = {};\n\n","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","/**\n * @module ol/events/Event\n */\n/**\n * @classdesc\n * Stripped down implementation of the W3C DOM Level 2 Event interface.\n * See https://www.w3.org/TR/DOM-Level-2-Events/events.html#Events-interface.\n *\n * This implementation only provides `type` and `target` properties, and\n * `stopPropagation` and `preventDefault` methods. It is meant as base class\n * for higher level events defined in the library, and works with\n * {@link module:ol/events/Target~Target}.\n */\nvar BaseEvent = /** @class */ (function () {\n /**\n * @param {string} type Type.\n */\n function BaseEvent(type) {\n /**\n * @type {boolean}\n */\n this.propagationStopped;\n /**\n * @type {boolean}\n */\n this.defaultPrevented;\n /**\n * The event type.\n * @type {string}\n * @api\n */\n this.type = type;\n /**\n * The event target.\n * @type {Object}\n * @api\n */\n this.target = null;\n }\n /**\n * Prevent default. This means that no emulated `click`, `singleclick` or `doubleclick` events\n * will be fired.\n * @api\n */\n BaseEvent.prototype.preventDefault = function () {\n this.defaultPrevented = true;\n };\n /**\n * Stop event propagation.\n * @api\n */\n BaseEvent.prototype.stopPropagation = function () {\n this.propagationStopped = true;\n };\n return BaseEvent;\n}());\n/**\n * @param {Event|import(\"./Event.js\").default} evt Event\n */\nexport function stopPropagation(evt) {\n evt.stopPropagation();\n}\n/**\n * @param {Event|import(\"./Event.js\").default} evt Event\n */\nexport function preventDefault(evt) {\n evt.preventDefault();\n}\nexport default BaseEvent;\n//# sourceMappingURL=Event.js.map","/**\n * @module ol/ObjectEventType\n */\n/**\n * @enum {string}\n */\nexport default {\n /**\n * Triggered when a property is changed.\n * @event module:ol/Object.ObjectEvent#propertychange\n * @api\n */\n PROPERTYCHANGE: 'propertychange',\n};\n/**\n * @typedef {'propertychange'} Types\n */\n//# sourceMappingURL=ObjectEventType.js.map","/**\n * @module ol/Disposable\n */\n/**\n * @classdesc\n * Objects that need to clean up after themselves.\n */\nvar Disposable = /** @class */ (function () {\n function Disposable() {\n /**\n * The object has already been disposed.\n * @type {boolean}\n * @protected\n */\n this.disposed = false;\n }\n /**\n * Clean up.\n */\n Disposable.prototype.dispose = function () {\n if (!this.disposed) {\n this.disposed = true;\n this.disposeInternal();\n }\n };\n /**\n * Extension point for disposable objects.\n * @protected\n */\n Disposable.prototype.disposeInternal = function () { };\n return Disposable;\n}());\nexport default Disposable;\n//# sourceMappingURL=Disposable.js.map","/**\n * @module ol/array\n */\n/**\n * Performs a binary search on the provided sorted list and returns the index of the item if found. If it can't be found it'll return -1.\n * https://github.com/darkskyapp/binary-search\n *\n * @param {Array<*>} haystack Items to search through.\n * @param {*} needle The item to look for.\n * @param {Function} [opt_comparator] Comparator function.\n * @return {number} The index of the item if found, -1 if not.\n */\nexport function binarySearch(haystack, needle, opt_comparator) {\n var mid, cmp;\n var comparator = opt_comparator || numberSafeCompareFunction;\n var low = 0;\n var high = haystack.length;\n var found = false;\n while (low < high) {\n /* Note that \"(low + high) >>> 1\" may overflow, and results in a typecast\n * to double (which gives the wrong results). */\n mid = low + ((high - low) >> 1);\n cmp = +comparator(haystack[mid], needle);\n if (cmp < 0.0) {\n /* Too low. */\n low = mid + 1;\n }\n else {\n /* Key found or too high */\n high = mid;\n found = !cmp;\n }\n }\n /* Key not found. */\n return found ? low : ~low;\n}\n/**\n * Compare function for array sort that is safe for numbers.\n * @param {*} a The first object to be compared.\n * @param {*} b The second object to be compared.\n * @return {number} A negative number, zero, or a positive number as the first\n * argument is less than, equal to, or greater than the second.\n */\nexport function numberSafeCompareFunction(a, b) {\n return a > b ? 1 : a < b ? -1 : 0;\n}\n/**\n * Whether the array contains the given object.\n * @param {Array<*>} arr The array to test for the presence of the element.\n * @param {*} obj The object for which to test.\n * @return {boolean} The object is in the array.\n */\nexport function includes(arr, obj) {\n return arr.indexOf(obj) >= 0;\n}\n/**\n * {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution} can use a function\n * of this type to determine which nearest resolution to use.\n *\n * This function takes a `{number}` representing a value between two array entries,\n * a `{number}` representing the value of the nearest higher entry and\n * a `{number}` representing the value of the nearest lower entry\n * as arguments and returns a `{number}`. If a negative number or zero is returned\n * the lower value will be used, if a positive number is returned the higher value\n * will be used.\n * @typedef {function(number, number, number): number} NearestDirectionFunction\n * @api\n */\n/**\n * @param {Array<number>} arr Array in descending order.\n * @param {number} target Target.\n * @param {number|NearestDirectionFunction} direction\n * 0 means return the nearest,\n * > 0 means return the largest nearest,\n * < 0 means return the smallest nearest.\n * @return {number} Index.\n */\nexport function linearFindNearest(arr, target, direction) {\n var n = arr.length;\n if (arr[0] <= target) {\n return 0;\n }\n else if (target <= arr[n - 1]) {\n return n - 1;\n }\n else {\n var i = void 0;\n if (direction > 0) {\n for (i = 1; i < n; ++i) {\n if (arr[i] < target) {\n return i - 1;\n }\n }\n }\n else if (direction < 0) {\n for (i = 1; i < n; ++i) {\n if (arr[i] <= target) {\n return i;\n }\n }\n }\n else {\n for (i = 1; i < n; ++i) {\n if (arr[i] == target) {\n return i;\n }\n else if (arr[i] < target) {\n if (typeof direction === 'function') {\n if (direction(target, arr[i - 1], arr[i]) > 0) {\n return i - 1;\n }\n else {\n return i;\n }\n }\n else if (arr[i - 1] - target < target - arr[i]) {\n return i - 1;\n }\n else {\n return i;\n }\n }\n }\n }\n return n - 1;\n }\n}\n/**\n * @param {Array<*>} arr Array.\n * @param {number} begin Begin index.\n * @param {number} end End index.\n */\nexport function reverseSubArray(arr, begin, end) {\n while (begin < end) {\n var tmp = arr[begin];\n arr[begin] = arr[end];\n arr[end] = tmp;\n ++begin;\n --end;\n }\n}\n/**\n * @param {Array<VALUE>} arr The array to modify.\n * @param {!Array<VALUE>|VALUE} data The elements or arrays of elements to add to arr.\n * @template VALUE\n */\nexport function extend(arr, data) {\n var extension = Array.isArray(data) ? data : [data];\n var length = extension.length;\n for (var i = 0; i < length; i++) {\n arr[arr.length] = extension[i];\n }\n}\n/**\n * @param {Array<VALUE>} arr The array to modify.\n * @param {VALUE} obj The element to remove.\n * @template VALUE\n * @return {boolean} If the element was removed.\n */\nexport function remove(arr, obj) {\n var i = arr.indexOf(obj);\n var found = i > -1;\n if (found) {\n arr.splice(i, 1);\n }\n return found;\n}\n/**\n * @param {Array<VALUE>} arr The array to search in.\n * @param {function(VALUE, number, ?) : boolean} func The function to compare.\n * @template VALUE\n * @return {VALUE|null} The element found or null.\n */\nexport function find(arr, func) {\n var length = arr.length >>> 0;\n var value;\n for (var i = 0; i < length; i++) {\n value = arr[i];\n if (func(value, i, arr)) {\n return value;\n }\n }\n return null;\n}\n/**\n * @param {Array|Uint8ClampedArray} arr1 The first array to compare.\n * @param {Array|Uint8ClampedArray} arr2 The second array to compare.\n * @return {boolean} Whether the two arrays are equal.\n */\nexport function equals(arr1, arr2) {\n var len1 = arr1.length;\n if (len1 !== arr2.length) {\n return false;\n }\n for (var i = 0; i < len1; i++) {\n if (arr1[i] !== arr2[i]) {\n return false;\n }\n }\n return true;\n}\n/**\n * Sort the passed array such that the relative order of equal elements is preserved.\n * See https://en.wikipedia.org/wiki/Sorting_algorithm#Stability for details.\n * @param {Array<*>} arr The array to sort (modifies original).\n * @param {!function(*, *): number} compareFnc Comparison function.\n * @api\n */\nexport function stableSort(arr, compareFnc) {\n var length = arr.length;\n var tmp = Array(arr.length);\n var i;\n for (i = 0; i < length; i++) {\n tmp[i] = { index: i, value: arr[i] };\n }\n tmp.sort(function (a, b) {\n return compareFnc(a.value, b.value) || a.index - b.index;\n });\n for (i = 0; i < arr.length; i++) {\n arr[i] = tmp[i].value;\n }\n}\n/**\n * @param {Array<*>} arr The array to search in.\n * @param {Function} func Comparison function.\n * @return {number} Return index.\n */\nexport function findIndex(arr, func) {\n var index;\n var found = !arr.every(function (el, idx) {\n index = idx;\n return !func(el, idx, arr);\n });\n return found ? index : -1;\n}\n/**\n * @param {Array<*>} arr The array to test.\n * @param {Function} [opt_func] Comparison function.\n * @param {boolean} [opt_strict] Strictly sorted (default false).\n * @return {boolean} Return index.\n */\nexport function isSorted(arr, opt_func, opt_strict) {\n var compare = opt_func || numberSafeCompareFunction;\n return arr.every(function (currentVal, index) {\n if (index === 0) {\n return true;\n }\n var res = compare(arr[index - 1], currentVal);\n return !(res > 0 || (opt_strict && res === 0));\n });\n}\n//# sourceMappingURL=array.js.map","/**\n * @module ol/functions\n */\nimport { equals as arrayEquals } from './array.js';\n/**\n * Always returns true.\n * @return {boolean} true.\n */\nexport function TRUE() {\n return true;\n}\n/**\n * Always returns false.\n * @return {boolean} false.\n */\nexport function FALSE() {\n return false;\n}\n/**\n * A reusable function, used e.g. as a default for callbacks.\n *\n * @return {void} Nothing.\n */\nexport function VOID() { }\n/**\n * Wrap a function in another function that remembers the last return. If the\n * returned function is called twice in a row with the same arguments and the same\n * this object, it will return the value from the first call in the second call.\n *\n * @param {function(...any): ReturnType} fn The function to memoize.\n * @return {function(...any): ReturnType} The memoized function.\n * @template ReturnType\n */\nexport function memoizeOne(fn) {\n var called = false;\n /** @type {ReturnType} */\n var lastResult;\n /** @type {Array<any>} */\n var lastArgs;\n var lastThis;\n return function () {\n var nextArgs = Array.prototype.slice.call(arguments);\n if (!called || this !== lastThis || !arrayEquals(nextArgs, lastArgs)) {\n called = true;\n lastThis = this;\n lastArgs = nextArgs;\n lastResult = fn.apply(this, arguments);\n }\n return lastResult;\n };\n}\n//# sourceMappingURL=functions.js.map","/**\n * @module ol/obj\n */\n/**\n * Polyfill for Object.assign(). Assigns enumerable and own properties from\n * one or more source objects to a target object.\n * See https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Object/assign.\n *\n * @param {!Object} target The target object.\n * @param {...Object} var_sources The source object(s).\n * @return {!Object} The modified target object.\n */\nexport var assign = typeof Object.assign === 'function'\n ? Object.assign\n : function (target, var_sources) {\n if (target === undefined || target === null) {\n throw new TypeError('Cannot convert undefined or null to object');\n }\n var output = Object(target);\n for (var i = 1, ii = arguments.length; i < ii; ++i) {\n var source = arguments[i];\n if (source !== undefined && source !== null) {\n for (var key in source) {\n if (source.hasOwnProperty(key)) {\n output[key] = source[key];\n }\n }\n }\n }\n return output;\n };\n/**\n * Removes all properties from an object.\n * @param {Object} object The object to clear.\n */\nexport function clear(object) {\n for (var property in object) {\n delete object[property];\n }\n}\n/**\n * Polyfill for Object.values(). Get an array of property values from an object.\n * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/values\n *\n * @param {!Object<K,V>} object The object from which to get the values.\n * @return {!Array<V>} The property values.\n * @template K,V\n */\nexport var getValues = typeof Object.values === 'function'\n ? Object.values\n : function (object) {\n var values = [];\n for (var property in object) {\n values.push(object[property]);\n }\n return values;\n };\n/**\n * Determine if an object has any properties.\n * @param {Object} object The object to check.\n * @return {boolean} The object is empty.\n */\nexport function isEmpty(object) {\n var property;\n for (property in object) {\n return false;\n }\n return !property;\n}\n//# sourceMappingURL=obj.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/events/Target\n */\nimport Disposable from '../Disposable.js';\nimport Event from './Event.js';\nimport { VOID } from '../functions.js';\nimport { clear } from '../obj.js';\n/**\n * @typedef {EventTarget|Target} EventTargetLike\n */\n/**\n * @classdesc\n * A simplified implementation of the W3C DOM Level 2 EventTarget interface.\n * See https://www.w3.org/TR/2000/REC-DOM-Level-2-Events-20001113/events.html#Events-EventTarget.\n *\n * There are two important simplifications compared to the specification:\n *\n * 1. The handling of `useCapture` in `addEventListener` and\n * `removeEventListener`. There is no real capture model.\n * 2. The handling of `stopPropagation` and `preventDefault` on `dispatchEvent`.\n * There is no event target hierarchy. When a listener calls\n * `stopPropagation` or `preventDefault` on an event object, it means that no\n * more listeners after this one will be called. Same as when the listener\n * returns false.\n */\nvar Target = /** @class */ (function (_super) {\n __extends(Target, _super);\n /**\n * @param {*} [opt_target] Default event target for dispatched events.\n */\n function Target(opt_target) {\n var _this = _super.call(this) || this;\n /**\n * @private\n * @type {*}\n */\n _this.eventTarget_ = opt_target;\n /**\n * @private\n * @type {Object<string, number>}\n */\n _this.pendingRemovals_ = null;\n /**\n * @private\n * @type {Object<string, number>}\n */\n _this.dispatching_ = null;\n /**\n * @private\n * @type {Object<string, Array<import(\"../events.js\").Listener>>}\n */\n _this.listeners_ = null;\n return _this;\n }\n /**\n * @param {string} type Type.\n * @param {import(\"../events.js\").Listener} listener Listener.\n */\n Target.prototype.addEventListener = function (type, listener) {\n if (!type || !listener) {\n return;\n }\n var listeners = this.listeners_ || (this.listeners_ = {});\n var listenersForType = listeners[type] || (listeners[type] = []);\n if (listenersForType.indexOf(listener) === -1) {\n listenersForType.push(listener);\n }\n };\n /**\n * Dispatches an event and calls all listeners listening for events\n * of this type. The event parameter can either be a string or an\n * Object with a `type` property.\n *\n * @param {import(\"./Event.js\").default|string} event Event object.\n * @return {boolean|undefined} `false` if anyone called preventDefault on the\n * event object or if any of the listeners returned false.\n * @api\n */\n Target.prototype.dispatchEvent = function (event) {\n /** @type {import(\"./Event.js\").default|Event} */\n var evt = typeof event === 'string' ? new Event(event) : event;\n var type = evt.type;\n if (!evt.target) {\n evt.target = this.eventTarget_ || this;\n }\n var listeners = this.listeners_ && this.listeners_[type];\n var propagate;\n if (listeners) {\n var dispatching = this.dispatching_ || (this.dispatching_ = {});\n var pendingRemovals = this.pendingRemovals_ || (this.pendingRemovals_ = {});\n if (!(type in dispatching)) {\n dispatching[type] = 0;\n pendingRemovals[type] = 0;\n }\n ++dispatching[type];\n for (var i = 0, ii = listeners.length; i < ii; ++i) {\n if ('handleEvent' in listeners[i]) {\n propagate = /** @type {import(\"../events.js\").ListenerObject} */ (listeners[i]).handleEvent(evt);\n }\n else {\n propagate = /** @type {import(\"../events.js\").ListenerFunction} */ (listeners[i]).call(this, evt);\n }\n if (propagate === false || evt.propagationStopped) {\n propagate = false;\n break;\n }\n }\n --dispatching[type];\n if (dispatching[type] === 0) {\n var pr = pendingRemovals[type];\n delete pendingRemovals[type];\n while (pr--) {\n this.removeEventListener(type, VOID);\n }\n delete dispatching[type];\n }\n return propagate;\n }\n };\n /**\n * Clean up.\n */\n Target.prototype.disposeInternal = function () {\n this.listeners_ && clear(this.listeners_);\n };\n /**\n * Get the listeners for a specified event type. Listeners are returned in the\n * order that they will be called in.\n *\n * @param {string} type Type.\n * @return {Array<import(\"../events.js\").Listener>|undefined} Listeners.\n */\n Target.prototype.getListeners = function (type) {\n return (this.listeners_ && this.listeners_[type]) || undefined;\n };\n /**\n * @param {string} [opt_type] Type. If not provided,\n * `true` will be returned if this event target has any listeners.\n * @return {boolean} Has listeners.\n */\n Target.prototype.hasListener = function (opt_type) {\n if (!this.listeners_) {\n return false;\n }\n return opt_type\n ? opt_type in this.listeners_\n : Object.keys(this.listeners_).length > 0;\n };\n /**\n * @param {string} type Type.\n * @param {import(\"../events.js\").Listener} listener Listener.\n */\n Target.prototype.removeEventListener = function (type, listener) {\n var listeners = this.listeners_ && this.listeners_[type];\n if (listeners) {\n var index = listeners.indexOf(listener);\n if (index !== -1) {\n if (this.pendingRemovals_ && type in this.pendingRemovals_) {\n // make listener a no-op, and remove later in #dispatchEvent()\n listeners[index] = VOID;\n ++this.pendingRemovals_[type];\n }\n else {\n listeners.splice(index, 1);\n if (listeners.length === 0) {\n delete this.listeners_[type];\n }\n }\n }\n }\n };\n return Target;\n}(Disposable));\nexport default Target;\n//# sourceMappingURL=Target.js.map","/**\n * @module ol/events/EventType\n */\n/**\n * @enum {string}\n * @const\n */\nexport default {\n /**\n * Generic change event. Triggered when the revision counter is increased.\n * @event module:ol/events/Event~BaseEvent#change\n * @api\n */\n CHANGE: 'change',\n /**\n * Generic error event. Triggered when an error occurs.\n * @event module:ol/events/Event~BaseEvent#error\n * @api\n */\n ERROR: 'error',\n BLUR: 'blur',\n CLEAR: 'clear',\n CONTEXTMENU: 'contextmenu',\n CLICK: 'click',\n DBLCLICK: 'dblclick',\n DRAGENTER: 'dragenter',\n DRAGOVER: 'dragover',\n DROP: 'drop',\n FOCUS: 'focus',\n KEYDOWN: 'keydown',\n KEYPRESS: 'keypress',\n LOAD: 'load',\n RESIZE: 'resize',\n TOUCHMOVE: 'touchmove',\n WHEEL: 'wheel',\n};\n//# sourceMappingURL=EventType.js.map","/**\n * @module ol/events\n */\nimport { clear } from './obj.js';\n/**\n * Key to use with {@link module:ol/Observable~Observable#unByKey}.\n * @typedef {Object} EventsKey\n * @property {ListenerFunction} listener Listener.\n * @property {import(\"./events/Target.js\").EventTargetLike} target Target.\n * @property {string} type Type.\n * @api\n */\n/**\n * Listener function. This function is called with an event object as argument.\n * When the function returns `false`, event propagation will stop.\n *\n * @typedef {function((Event|import(\"./events/Event.js\").default)): (void|boolean)} ListenerFunction\n * @api\n */\n/**\n * @typedef {Object} ListenerObject\n * @property {ListenerFunction} handleEvent HandleEvent listener function.\n */\n/**\n * @typedef {ListenerFunction|ListenerObject} Listener\n */\n/**\n * Registers an event listener on an event target. Inspired by\n * https://google.github.io/closure-library/api/source/closure/goog/events/events.js.src.html\n *\n * This function efficiently binds a `listener` to a `this` object, and returns\n * a key for use with {@link module:ol/events.unlistenByKey}.\n *\n * @param {import(\"./events/Target.js\").EventTargetLike} target Event target.\n * @param {string} type Event type.\n * @param {ListenerFunction} listener Listener.\n * @param {Object} [opt_this] Object referenced by the `this` keyword in the\n * listener. Default is the `target`.\n * @param {boolean} [opt_once] If true, add the listener as one-off listener.\n * @return {EventsKey} Unique key for the listener.\n */\nexport function listen(target, type, listener, opt_this, opt_once) {\n if (opt_this && opt_this !== target) {\n listener = listener.bind(opt_this);\n }\n if (opt_once) {\n var originalListener_1 = listener;\n listener = function () {\n target.removeEventListener(type, listener);\n originalListener_1.apply(this, arguments);\n };\n }\n var eventsKey = {\n target: target,\n type: type,\n listener: listener,\n };\n target.addEventListener(type, listener);\n return eventsKey;\n}\n/**\n * Registers a one-off event listener on an event target. Inspired by\n * https://google.github.io/closure-library/api/source/closure/goog/events/events.js.src.html\n *\n * This function efficiently binds a `listener` as self-unregistering listener\n * to a `this` object, and returns a key for use with\n * {@link module:ol/events.unlistenByKey} in case the listener needs to be\n * unregistered before it is called.\n *\n * When {@link module:ol/events.listen} is called with the same arguments after this\n * function, the self-unregistering listener will be turned into a permanent\n * listener.\n *\n * @param {import(\"./events/Target.js\").EventTargetLike} target Event target.\n * @param {string} type Event type.\n * @param {ListenerFunction} listener Listener.\n * @param {Object} [opt_this] Object referenced by the `this` keyword in the\n * listener. Default is the `target`.\n * @return {EventsKey} Key for unlistenByKey.\n */\nexport function listenOnce(target, type, listener, opt_this) {\n return listen(target, type, listener, opt_this, true);\n}\n/**\n * Unregisters event listeners on an event target. Inspired by\n * https://google.github.io/closure-library/api/source/closure/goog/events/events.js.src.html\n *\n * The argument passed to this function is the key returned from\n * {@link module:ol/events.listen} or {@link module:ol/events.listenOnce}.\n *\n * @param {EventsKey} key The key.\n */\nexport function unlistenByKey(key) {\n if (key && key.target) {\n key.target.removeEventListener(key.type, key.listener);\n clear(key);\n }\n}\n//# sourceMappingURL=events.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/Observable\n */\nimport EventTarget from './events/Target.js';\nimport EventType from './events/EventType.js';\nimport { listen, listenOnce, unlistenByKey } from './events.js';\n/***\n * @template {string} Type\n * @template {Event|import(\"./events/Event.js\").default} EventClass\n * @template Return\n * @typedef {(type: Type, listener: (event: EventClass) => ?) => Return} OnSignature\n */\n/***\n * @template {string} Type\n * @template Return\n * @typedef {(type: Type[], listener: (event: Event|import(\"./events/Event\").default) => ?) => Return extends void ? void : Return[]} CombinedOnSignature\n */\n/**\n * @typedef {'change'|'error'} EventTypes\n */\n/***\n * @template Return\n * @typedef {OnSignature<EventTypes, import(\"./events/Event.js\").default, Return> & CombinedOnSignature<EventTypes, Return>} ObservableOnSignature\n */\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * An event target providing convenient methods for listener registration\n * and unregistration. A generic `change` event is always available through\n * {@link module:ol/Observable~Observable#changed}.\n *\n * @fires import(\"./events/Event.js\").default\n * @api\n */\nvar Observable = /** @class */ (function (_super) {\n __extends(Observable, _super);\n function Observable() {\n var _this = _super.call(this) || this;\n _this.on =\n /** @type {ObservableOnSignature<import(\"./events\").EventsKey>} */ (_this.onInternal);\n _this.once =\n /** @type {ObservableOnSignature<import(\"./events\").EventsKey>} */ (_this.onceInternal);\n _this.un = /** @type {ObservableOnSignature<void>} */ (_this.unInternal);\n /**\n * @private\n * @type {number}\n */\n _this.revision_ = 0;\n return _this;\n }\n /**\n * Increases the revision counter and dispatches a 'change' event.\n * @api\n */\n Observable.prototype.changed = function () {\n ++this.revision_;\n this.dispatchEvent(EventType.CHANGE);\n };\n /**\n * Get the version number for this object. Each time the object is modified,\n * its version number will be incremented.\n * @return {number} Revision.\n * @api\n */\n Observable.prototype.getRevision = function () {\n return this.revision_;\n };\n /**\n * @param {string|Array<string>} type Type.\n * @param {function((Event|import(\"./events/Event\").default)): ?} listener Listener.\n * @return {import(\"./events.js\").EventsKey|Array<import(\"./events.js\").EventsKey>} Event key.\n * @protected\n */\n Observable.prototype.onInternal = function (type, listener) {\n if (Array.isArray(type)) {\n var len = type.length;\n var keys = new Array(len);\n for (var i = 0; i < len; ++i) {\n keys[i] = listen(this, type[i], listener);\n }\n return keys;\n }\n else {\n return listen(this, /** @type {string} */ (type), listener);\n }\n };\n /**\n * @param {string|Array<string>} type Type.\n * @param {function((Event|import(\"./events/Event\").default)): ?} listener Listener.\n * @return {import(\"./events.js\").EventsKey|Array<import(\"./events.js\").EventsKey>} Event key.\n * @protected\n */\n Observable.prototype.onceInternal = function (type, listener) {\n var key;\n if (Array.isArray(type)) {\n var len = type.length;\n key = new Array(len);\n for (var i = 0; i < len; ++i) {\n key[i] = listenOnce(this, type[i], listener);\n }\n }\n else {\n key = listenOnce(this, /** @type {string} */ (type), listener);\n }\n /** @type {Object} */ (listener).ol_key = key;\n return key;\n };\n /**\n * Unlisten for a certain type of event.\n * @param {string|Array<string>} type Type.\n * @param {function((Event|import(\"./events/Event\").default)): ?} listener Listener.\n * @protected\n */\n Observable.prototype.unInternal = function (type, listener) {\n var key = /** @type {Object} */ (listener).ol_key;\n if (key) {\n unByKey(key);\n }\n else if (Array.isArray(type)) {\n for (var i = 0, ii = type.length; i < ii; ++i) {\n this.removeEventListener(type[i], listener);\n }\n }\n else {\n this.removeEventListener(type, listener);\n }\n };\n return Observable;\n}(EventTarget));\n/**\n * Listen for a certain type of event.\n * @function\n * @param {string|Array<string>} type The event type or array of event types.\n * @param {function((Event|import(\"./events/Event\").default)): ?} listener The listener function.\n * @return {import(\"./events.js\").EventsKey|Array<import(\"./events.js\").EventsKey>} Unique key for the listener. If\n * called with an array of event types as the first argument, the return\n * will be an array of keys.\n * @api\n */\nObservable.prototype.on;\n/**\n * Listen once for a certain type of event.\n * @function\n * @param {string|Array<string>} type The event type or array of event types.\n * @param {function((Event|import(\"./events/Event\").default)): ?} listener The listener function.\n * @return {import(\"./events.js\").EventsKey|Array<import(\"./events.js\").EventsKey>} Unique key for the listener. If\n * called with an array of event types as the first argument, the return\n * will be an array of keys.\n * @api\n */\nObservable.prototype.once;\n/**\n * Unlisten for a certain type of event.\n * @function\n * @param {string|Array<string>} type The event type or array of event types.\n * @param {function((Event|import(\"./events/Event\").default)): ?} listener The listener function.\n * @api\n */\nObservable.prototype.un;\n/**\n * Removes an event listener using the key returned by `on()` or `once()`.\n * @param {import(\"./events.js\").EventsKey|Array<import(\"./events.js\").EventsKey>} key The key returned by `on()`\n * or `once()` (or an array of keys).\n * @api\n */\nexport function unByKey(key) {\n if (Array.isArray(key)) {\n for (var i = 0, ii = key.length; i < ii; ++i) {\n unlistenByKey(key[i]);\n }\n }\n else {\n unlistenByKey(/** @type {import(\"./events.js\").EventsKey} */ (key));\n }\n}\nexport default Observable;\n//# sourceMappingURL=Observable.js.map","/**\n * @module ol/util\n */\n/**\n * @return {?} Any return.\n */\nexport function abstract() {\n return /** @type {?} */ ((function () {\n throw new Error('Unimplemented abstract method.');\n })());\n}\n/**\n * Counter for getUid.\n * @type {number}\n * @private\n */\nvar uidCounter_ = 0;\n/**\n * Gets a unique ID for an object. This mutates the object so that further calls\n * with the same object as a parameter returns the same value. Unique IDs are generated\n * as a strictly increasing sequence. Adapted from goog.getUid.\n *\n * @param {Object} obj The object to get the unique ID for.\n * @return {string} The unique ID for the object.\n * @api\n */\nexport function getUid(obj) {\n return obj.ol_uid || (obj.ol_uid = String(++uidCounter_));\n}\n/**\n * OpenLayers version.\n * @type {string}\n */\nexport var VERSION = '6.9.0';\n//# sourceMappingURL=util.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/Object\n */\nimport Event from './events/Event.js';\nimport ObjectEventType from './ObjectEventType.js';\nimport Observable from './Observable.js';\nimport { assign, isEmpty } from './obj.js';\nimport { getUid } from './util.js';\n/**\n * @classdesc\n * Events emitted by {@link module:ol/Object~BaseObject} instances are instances of this type.\n */\nvar ObjectEvent = /** @class */ (function (_super) {\n __extends(ObjectEvent, _super);\n /**\n * @param {string} type The event type.\n * @param {string} key The property name.\n * @param {*} oldValue The old value for `key`.\n */\n function ObjectEvent(type, key, oldValue) {\n var _this = _super.call(this, type) || this;\n /**\n * The name of the property whose value is changing.\n * @type {string}\n * @api\n */\n _this.key = key;\n /**\n * The old value. To get the new value use `e.target.get(e.key)` where\n * `e` is the event object.\n * @type {*}\n * @api\n */\n _this.oldValue = oldValue;\n return _this;\n }\n return ObjectEvent;\n}(Event));\nexport { ObjectEvent };\n/***\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature<import(\"./Observable\").EventTypes, import(\"./events/Event.js\").default, Return> &\n * import(\"./Observable\").OnSignature<import(\"./ObjectEventType\").Types, ObjectEvent, Return> &\n * import(\"./Observable\").CombinedOnSignature<import(\"./Observable\").EventTypes|import(\"./ObjectEventType\").Types, Return>} ObjectOnSignature\n */\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * Most non-trivial classes inherit from this.\n *\n * This extends {@link module:ol/Observable} with observable\n * properties, where each property is observable as well as the object as a\n * whole.\n *\n * Classes that inherit from this have pre-defined properties, to which you can\n * add your owns. The pre-defined properties are listed in this documentation as\n * 'Observable Properties', and have their own accessors; for example,\n * {@link module:ol/Map~Map} has a `target` property, accessed with\n * `getTarget()` and changed with `setTarget()`. Not all properties are however\n * settable. There are also general-purpose accessors `get()` and `set()`. For\n * example, `get('target')` is equivalent to `getTarget()`.\n *\n * The `set` accessors trigger a change event, and you can monitor this by\n * registering a listener. For example, {@link module:ol/View~View} has a\n * `center` property, so `view.on('change:center', function(evt) {...});` would\n * call the function whenever the value of the center property changes. Within\n * the function, `evt.target` would be the view, so `evt.target.getCenter()`\n * would return the new center.\n *\n * You can add your own observable properties with\n * `object.set('prop', 'value')`, and retrieve that with `object.get('prop')`.\n * You can listen for changes on that property value with\n * `object.on('change:prop', listener)`. You can get a list of all\n * properties with {@link module:ol/Object~BaseObject#getProperties}.\n *\n * Note that the observable properties are separate from standard JS properties.\n * You can, for example, give your map object a title with\n * `map.title='New title'` and with `map.set('title', 'Another title')`. The\n * first will be a `hasOwnProperty`; the second will appear in\n * `getProperties()`. Only the second is observable.\n *\n * Properties can be deleted by using the unset method. E.g.\n * object.unset('foo').\n *\n * @fires ObjectEvent\n * @api\n */\nvar BaseObject = /** @class */ (function (_super) {\n __extends(BaseObject, _super);\n /**\n * @param {Object<string, *>} [opt_values] An object with key-value pairs.\n */\n function BaseObject(opt_values) {\n var _this = _super.call(this) || this;\n /***\n * @type {ObjectOnSignature<import(\"./events\").EventsKey>}\n */\n _this.on;\n /***\n * @type {ObjectOnSignature<import(\"./events\").EventsKey>}\n */\n _this.once;\n /***\n * @type {ObjectOnSignature<void>}\n */\n _this.un;\n // Call {@link module:ol/util.getUid} to ensure that the order of objects' ids is\n // the same as the order in which they were created. This also helps to\n // ensure that object properties are always added in the same order, which\n // helps many JavaScript engines generate faster code.\n getUid(_this);\n /**\n * @private\n * @type {Object<string, *>}\n */\n _this.values_ = null;\n if (opt_values !== undefined) {\n _this.setProperties(opt_values);\n }\n return _this;\n }\n /**\n * Gets a value.\n * @param {string} key Key name.\n * @return {*} Value.\n * @api\n */\n BaseObject.prototype.get = function (key) {\n var value;\n if (this.values_ && this.values_.hasOwnProperty(key)) {\n value = this.values_[key];\n }\n return value;\n };\n /**\n * Get a list of object property names.\n * @return {Array<string>} List of property names.\n * @api\n */\n BaseObject.prototype.getKeys = function () {\n return (this.values_ && Object.keys(this.values_)) || [];\n };\n /**\n * Get an object of all property names and values.\n * @return {Object<string, *>} Object.\n * @api\n */\n BaseObject.prototype.getProperties = function () {\n return (this.values_ && assign({}, this.values_)) || {};\n };\n /**\n * @return {boolean} The object has properties.\n */\n BaseObject.prototype.hasProperties = function () {\n return !!this.values_;\n };\n /**\n * @param {string} key Key name.\n * @param {*} oldValue Old value.\n */\n BaseObject.prototype.notify = function (key, oldValue) {\n var eventType;\n eventType = \"change:\" + key;\n this.dispatchEvent(new ObjectEvent(eventType, key, oldValue));\n eventType = ObjectEventType.PROPERTYCHANGE;\n this.dispatchEvent(new ObjectEvent(eventType, key, oldValue));\n };\n /**\n * @param {string} key Key name.\n * @param {import(\"./events.js\").Listener} listener Listener.\n */\n BaseObject.prototype.addChangeListener = function (key, listener) {\n this.addEventListener(\"change:\" + key, listener);\n };\n /**\n * @param {string} key Key name.\n * @param {import(\"./events.js\").Listener} listener Listener.\n */\n BaseObject.prototype.removeChangeListener = function (key, listener) {\n this.removeEventListener(\"change:\" + key, listener);\n };\n /**\n * Sets a value.\n * @param {string} key Key name.\n * @param {*} value Value.\n * @param {boolean} [opt_silent] Update without triggering an event.\n * @api\n */\n BaseObject.prototype.set = function (key, value, opt_silent) {\n var values = this.values_ || (this.values_ = {});\n if (opt_silent) {\n values[key] = value;\n }\n else {\n var oldValue = values[key];\n values[key] = value;\n if (oldValue !== value) {\n this.notify(key, oldValue);\n }\n }\n };\n /**\n * Sets a collection of key-value pairs. Note that this changes any existing\n * properties and adds new ones (it does not remove any existing properties).\n * @param {Object<string, *>} values Values.\n * @param {boolean} [opt_silent] Update without triggering an event.\n * @api\n */\n BaseObject.prototype.setProperties = function (values, opt_silent) {\n for (var key in values) {\n this.set(key, values[key], opt_silent);\n }\n };\n /**\n * Apply any properties from another object without triggering events.\n * @param {BaseObject} source The source object.\n * @protected\n */\n BaseObject.prototype.applyProperties = function (source) {\n if (!source.values_) {\n return;\n }\n assign(this.values_ || (this.values_ = {}), source.values_);\n };\n /**\n * Unsets a property.\n * @param {string} key Key name.\n * @param {boolean} [opt_silent] Unset without triggering an event.\n * @api\n */\n BaseObject.prototype.unset = function (key, opt_silent) {\n if (this.values_ && key in this.values_) {\n var oldValue = this.values_[key];\n delete this.values_[key];\n if (isEmpty(this.values_)) {\n this.values_ = null;\n }\n if (!opt_silent) {\n this.notify(key, oldValue);\n }\n }\n };\n return BaseObject;\n}(Observable));\nexport default BaseObject;\n//# sourceMappingURL=Object.js.map","/**\n * @module ol/MapEventType\n */\n/**\n * @enum {string}\n */\nexport default {\n /**\n * Triggered after a map frame is rendered.\n * @event module:ol/MapEvent~MapEvent#postrender\n * @api\n */\n POSTRENDER: 'postrender',\n /**\n * Triggered when the map starts moving.\n * @event module:ol/MapEvent~MapEvent#movestart\n * @api\n */\n MOVESTART: 'movestart',\n /**\n * Triggered after the map is moved.\n * @event module:ol/MapEvent~MapEvent#moveend\n * @api\n */\n MOVEEND: 'moveend',\n};\n/***\n * @typedef {'postrender'|'movestart'|'moveend'} Types\n */\n//# sourceMappingURL=MapEventType.js.map","/**\n * @module ol/has\n */\nvar ua = typeof navigator !== 'undefined' && typeof navigator.userAgent !== 'undefined'\n ? navigator.userAgent.toLowerCase()\n : '';\n/**\n * User agent string says we are dealing with Firefox as browser.\n * @type {boolean}\n */\nexport var FIREFOX = ua.indexOf('firefox') !== -1;\n/**\n * User agent string says we are dealing with Safari as browser.\n * @type {boolean}\n */\nexport var SAFARI = ua.indexOf('safari') !== -1 && ua.indexOf('chrom') == -1;\n/**\n * User agent string says we are dealing with a WebKit engine.\n * @type {boolean}\n */\nexport var WEBKIT = ua.indexOf('webkit') !== -1 && ua.indexOf('edge') == -1;\n/**\n * User agent string says we are dealing with a Mac as platform.\n * @type {boolean}\n */\nexport var MAC = ua.indexOf('macintosh') !== -1;\n/**\n * The ratio between physical pixels and device-independent pixels\n * (dips) on the device (`window.devicePixelRatio`).\n * @const\n * @type {number}\n * @api\n */\nexport var DEVICE_PIXEL_RATIO = typeof devicePixelRatio !== 'undefined' ? devicePixelRatio : 1;\n/**\n * The execution context is a worker with OffscreenCanvas available.\n * @const\n * @type {boolean}\n */\nexport var WORKER_OFFSCREEN_CANVAS = typeof WorkerGlobalScope !== 'undefined' &&\n typeof OffscreenCanvas !== 'undefined' &&\n self instanceof WorkerGlobalScope; //eslint-disable-line\n/**\n * Image.prototype.decode() is supported.\n * @type {boolean}\n */\nexport var IMAGE_DECODE = typeof Image !== 'undefined' && Image.prototype.decode;\n/**\n * @type {boolean}\n */\nexport var PASSIVE_EVENT_LISTENERS = (function () {\n var passive = false;\n try {\n var options = Object.defineProperty({}, 'passive', {\n get: function () {\n passive = true;\n },\n });\n window.addEventListener('_', null, options);\n window.removeEventListener('_', null, options);\n }\n catch (error) {\n // passive not supported\n }\n return passive;\n})();\n//# sourceMappingURL=has.js.map","import { WORKER_OFFSCREEN_CANVAS } from './has.js';\n/**\n * @module ol/dom\n */\n//FIXME Move this function to the canvas module\n/**\n * Create an html canvas element and returns its 2d context.\n * @param {number} [opt_width] Canvas width.\n * @param {number} [opt_height] Canvas height.\n * @param {Array<HTMLCanvasElement>} [opt_canvasPool] Canvas pool to take existing canvas from.\n * @param {CanvasRenderingContext2DSettings} [opt_Context2DSettings] CanvasRenderingContext2DSettings\n * @return {CanvasRenderingContext2D} The context.\n */\nexport function createCanvasContext2D(opt_width, opt_height, opt_canvasPool, opt_Context2DSettings) {\n /** @type {HTMLCanvasElement|OffscreenCanvas} */\n var canvas;\n if (opt_canvasPool && opt_canvasPool.length) {\n canvas = opt_canvasPool.shift();\n }\n else if (WORKER_OFFSCREEN_CANVAS) {\n canvas = new OffscreenCanvas(opt_width || 300, opt_height || 300);\n }\n else {\n canvas = document.createElement('canvas');\n canvas.style.all = 'unset';\n }\n if (opt_width) {\n canvas.width = opt_width;\n }\n if (opt_height) {\n canvas.height = opt_height;\n }\n //FIXME Allow OffscreenCanvasRenderingContext2D as return type\n return /** @type {CanvasRenderingContext2D} */ (canvas.getContext('2d', opt_Context2DSettings));\n}\n/**\n * Get the current computed width for the given element including margin,\n * padding and border.\n * Equivalent to jQuery's `$(el).outerWidth(true)`.\n * @param {!HTMLElement} element Element.\n * @return {number} The width.\n */\nexport function outerWidth(element) {\n var width = element.offsetWidth;\n var style = getComputedStyle(element);\n width += parseInt(style.marginLeft, 10) + parseInt(style.marginRight, 10);\n return width;\n}\n/**\n * Get the current computed height for the given element including margin,\n * padding and border.\n * Equivalent to jQuery's `$(el).outerHeight(true)`.\n * @param {!HTMLElement} element Element.\n * @return {number} The height.\n */\nexport function outerHeight(element) {\n var height = element.offsetHeight;\n var style = getComputedStyle(element);\n height += parseInt(style.marginTop, 10) + parseInt(style.marginBottom, 10);\n return height;\n}\n/**\n * @param {Node} newNode Node to replace old node\n * @param {Node} oldNode The node to be replaced\n */\nexport function replaceNode(newNode, oldNode) {\n var parent = oldNode.parentNode;\n if (parent) {\n parent.replaceChild(newNode, oldNode);\n }\n}\n/**\n * @param {Node} node The node to remove.\n * @return {Node} The node that was removed or null.\n */\nexport function removeNode(node) {\n return node && node.parentNode ? node.parentNode.removeChild(node) : null;\n}\n/**\n * @param {Node} node The node to remove the children from.\n */\nexport function removeChildren(node) {\n while (node.lastChild) {\n node.removeChild(node.lastChild);\n }\n}\n/**\n * Transform the children of a parent node so they match the\n * provided list of children. This function aims to efficiently\n * remove, add, and reorder child nodes while maintaining a simple\n * implementation (it is not guaranteed to minimize DOM operations).\n * @param {Node} node The parent node whose children need reworking.\n * @param {Array<Node>} children The desired children.\n */\nexport function replaceChildren(node, children) {\n var oldChildren = node.childNodes;\n for (var i = 0; true; ++i) {\n var oldChild = oldChildren[i];\n var newChild = children[i];\n // check if our work is done\n if (!oldChild && !newChild) {\n break;\n }\n // check if children match\n if (oldChild === newChild) {\n continue;\n }\n // check if a new child needs to be added\n if (!oldChild) {\n node.appendChild(newChild);\n continue;\n }\n // check if an old child needs to be removed\n if (!newChild) {\n node.removeChild(oldChild);\n --i;\n continue;\n }\n // reorder\n node.insertBefore(newChild, oldChild);\n }\n}\n//# sourceMappingURL=dom.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/control/Control\n */\nimport BaseObject from '../Object.js';\nimport MapEventType from '../MapEventType.js';\nimport { VOID } from '../functions.js';\nimport { listen, unlistenByKey } from '../events.js';\nimport { removeNode } from '../dom.js';\n/**\n * @typedef {Object} Options\n * @property {HTMLElement} [element] The element is the control's\n * container element. This only needs to be specified if you're developing\n * a custom control.\n * @property {function(import(\"../MapEvent.js\").default):void} [render] Function called when\n * the control should be re-rendered. This is called in a `requestAnimationFrame`\n * callback.\n * @property {HTMLElement|string} [target] Specify a target if you want\n * the control to be rendered outside of the map's viewport.\n */\n/**\n * @classdesc\n * A control is a visible widget with a DOM element in a fixed position on the\n * screen. They can involve user input (buttons), or be informational only;\n * the position is determined using CSS. By default these are placed in the\n * container with CSS class name `ol-overlaycontainer-stopevent`, but can use\n * any outside DOM element.\n *\n * This is the base class for controls. You can use it for simple custom\n * controls by creating the element with listeners, creating an instance:\n * ```js\n * var myControl = new Control({element: myElement});\n * ```\n * and then adding this to the map.\n *\n * The main advantage of having this as a control rather than a simple separate\n * DOM element is that preventing propagation is handled for you. Controls\n * will also be objects in a {@link module:ol/Collection~Collection}, so you can use their methods.\n *\n * You can also extend this base for your own control class. See\n * examples/custom-controls for an example of how to do this.\n *\n * @api\n */\nvar Control = /** @class */ (function (_super) {\n __extends(Control, _super);\n /**\n * @param {Options} options Control options.\n */\n function Control(options) {\n var _this = _super.call(this) || this;\n var element = options.element;\n if (element && !options.target && !element.style.pointerEvents) {\n element.style.pointerEvents = 'auto';\n }\n /**\n * @protected\n * @type {HTMLElement}\n */\n _this.element = element ? element : null;\n /**\n * @private\n * @type {HTMLElement}\n */\n _this.target_ = null;\n /**\n * @private\n * @type {import(\"../PluggableMap.js\").default}\n */\n _this.map_ = null;\n /**\n * @protected\n * @type {!Array<import(\"../events.js\").EventsKey>}\n */\n _this.listenerKeys = [];\n if (options.render) {\n _this.render = options.render;\n }\n if (options.target) {\n _this.setTarget(options.target);\n }\n return _this;\n }\n /**\n * Clean up.\n */\n Control.prototype.disposeInternal = function () {\n removeNode(this.element);\n _super.prototype.disposeInternal.call(this);\n };\n /**\n * Get the map associated with this control.\n * @return {import(\"../PluggableMap.js\").default|undefined} Map.\n * @api\n */\n Control.prototype.getMap = function () {\n return this.map_;\n };\n /**\n * Remove the control from its current map and attach it to the new map.\n * Subclasses may set up event handlers to get notified about changes to\n * the map here.\n * @param {import(\"../PluggableMap.js\").default} [map] Map.\n * @api\n */\n Control.prototype.setMap = function (map) {\n if (this.map_) {\n removeNode(this.element);\n }\n for (var i = 0, ii = this.listenerKeys.length; i < ii; ++i) {\n unlistenByKey(this.listenerKeys[i]);\n }\n this.listenerKeys.length = 0;\n this.map_ = map;\n if (this.map_) {\n var target = this.target_\n ? this.target_\n : map.getOverlayContainerStopEvent();\n target.appendChild(this.element);\n if (this.render !== VOID) {\n this.listenerKeys.push(listen(map, MapEventType.POSTRENDER, this.render, this));\n }\n map.render();\n }\n };\n /**\n * Renders the control.\n * @param {import(\"../MapEvent.js\").default} mapEvent Map event.\n * @api\n */\n Control.prototype.render = function (mapEvent) { };\n /**\n * This function is used to set a target element for the control. It has no\n * effect if it is called after the control has been added to the map (i.e.\n * after `setMap` is called on the control). If no `target` is set in the\n * options passed to the control constructor and if `setTarget` is not called\n * then the control is added to the map's overlay container.\n * @param {HTMLElement|string} target Target.\n * @api\n */\n Control.prototype.setTarget = function (target) {\n this.target_ =\n typeof target === 'string' ? document.getElementById(target) : target;\n };\n return Control;\n}(BaseObject));\nexport default Control;\n//# sourceMappingURL=Control.js.map","/**\n * @module ol/css\n */\n/**\n * @typedef {Object} FontParameters\n * @property {string} style Style.\n * @property {string} variant Variant.\n * @property {string} weight Weight.\n * @property {string} size Size.\n * @property {string} lineHeight LineHeight.\n * @property {string} family Family.\n * @property {Array<string>} families Families.\n */\n/**\n * The CSS class for hidden feature.\n *\n * @const\n * @type {string}\n */\nexport var CLASS_HIDDEN = 'ol-hidden';\n/**\n * The CSS class that we'll give the DOM elements to have them selectable.\n *\n * @const\n * @type {string}\n */\nexport var CLASS_SELECTABLE = 'ol-selectable';\n/**\n * The CSS class that we'll give the DOM elements to have them unselectable.\n *\n * @const\n * @type {string}\n */\nexport var CLASS_UNSELECTABLE = 'ol-unselectable';\n/**\n * The CSS class for unsupported feature.\n *\n * @const\n * @type {string}\n */\nexport var CLASS_UNSUPPORTED = 'ol-unsupported';\n/**\n * The CSS class for controls.\n *\n * @const\n * @type {string}\n */\nexport var CLASS_CONTROL = 'ol-control';\n/**\n * The CSS class that we'll give the DOM elements that are collapsed, i.e.\n * to those elements which usually can be expanded.\n *\n * @const\n * @type {string}\n */\nexport var CLASS_COLLAPSED = 'ol-collapsed';\n/**\n * From https://stackoverflow.com/questions/10135697/regex-to-parse-any-css-font\n * @type {RegExp}\n */\nvar fontRegEx = new RegExp([\n '^\\\\s*(?=(?:(?:[-a-z]+\\\\s*){0,2}(italic|oblique))?)',\n '(?=(?:(?:[-a-z]+\\\\s*){0,2}(small-caps))?)',\n '(?=(?:(?:[-a-z]+\\\\s*){0,2}(bold(?:er)?|lighter|[1-9]00 ))?)',\n '(?:(?:normal|\\\\1|\\\\2|\\\\3)\\\\s*){0,3}((?:xx?-)?',\n '(?:small|large)|medium|smaller|larger|[\\\\.\\\\d]+(?:\\\\%|in|[cem]m|ex|p[ctx]))',\n '(?:\\\\s*\\\\/\\\\s*(normal|[\\\\.\\\\d]+(?:\\\\%|in|[cem]m|ex|p[ctx])?))',\n '?\\\\s*([-,\\\\\"\\\\\\'\\\\sa-z]+?)\\\\s*$',\n].join(''), 'i');\nvar fontRegExMatchIndex = [\n 'style',\n 'variant',\n 'weight',\n 'size',\n 'lineHeight',\n 'family',\n];\n/**\n * Get the list of font families from a font spec. Note that this doesn't work\n * for font families that have commas in them.\n * @param {string} fontSpec The CSS font property.\n * @return {FontParameters} The font parameters (or null if the input spec is invalid).\n */\nexport var getFontParameters = function (fontSpec) {\n var match = fontSpec.match(fontRegEx);\n if (!match) {\n return null;\n }\n var style = /** @type {FontParameters} */ ({\n lineHeight: 'normal',\n size: '1.2em',\n style: 'normal',\n weight: 'normal',\n variant: 'normal',\n });\n for (var i = 0, ii = fontRegExMatchIndex.length; i < ii; ++i) {\n var value = match[i + 1];\n if (value !== undefined) {\n style[fontRegExMatchIndex[i]] = value;\n }\n }\n style.families = style.family.split(/,\\s?/);\n return style;\n};\n/**\n * @param {number} opacity Opacity (0..1).\n * @return {string} CSS opacity.\n */\nexport function cssOpacity(opacity) {\n return opacity === 1 ? '' : String(Math.round(opacity * 100) / 100);\n}\n//# sourceMappingURL=css.js.map","/**\n * @module ol/layer/Property\n */\n/**\n * @enum {string}\n */\nexport default {\n OPACITY: 'opacity',\n VISIBLE: 'visible',\n EXTENT: 'extent',\n Z_INDEX: 'zIndex',\n MAX_RESOLUTION: 'maxResolution',\n MIN_RESOLUTION: 'minResolution',\n MAX_ZOOM: 'maxZoom',\n MIN_ZOOM: 'minZoom',\n SOURCE: 'source',\n};\n//# sourceMappingURL=Property.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/AssertionError\n */\nimport { VERSION } from './util.js';\n/**\n * Error object thrown when an assertion failed. This is an ECMA-262 Error,\n * extended with a `code` property.\n * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Error.\n */\nvar AssertionError = /** @class */ (function (_super) {\n __extends(AssertionError, _super);\n /**\n * @param {number} code Error code.\n */\n function AssertionError(code) {\n var _this = this;\n var path = VERSION === 'latest' ? VERSION : 'v' + VERSION.split('-')[0];\n var message = 'Assertion failed. See https://openlayers.org/en/' +\n path +\n '/doc/errors/#' +\n code +\n ' for details.';\n _this = _super.call(this, message) || this;\n /**\n * Error code. The meaning of the code can be found on\n * https://openlayers.org/en/latest/doc/errors/ (replace `latest` with\n * the version found in the OpenLayers script's header comment if a version\n * other than the latest is used).\n * @type {number}\n * @api\n */\n _this.code = code;\n /**\n * @type {string}\n */\n _this.name = 'AssertionError';\n // Re-assign message, see https://github.com/Rich-Harris/buble/issues/40\n _this.message = message;\n return _this;\n }\n return AssertionError;\n}(Error));\nexport default AssertionError;\n//# sourceMappingURL=AssertionError.js.map","/**\n * @module ol/asserts\n */\nimport AssertionError from './AssertionError.js';\n/**\n * @param {*} assertion Assertion we expected to be truthy.\n * @param {number} errorCode Error code.\n */\nexport function assert(assertion, errorCode) {\n if (!assertion) {\n throw new AssertionError(errorCode);\n }\n}\n//# sourceMappingURL=asserts.js.map","/**\n * @module ol/math\n */\n/**\n * Takes a number and clamps it to within the provided bounds.\n * @param {number} value The input number.\n * @param {number} min The minimum value to return.\n * @param {number} max The maximum value to return.\n * @return {number} The input number if it is within bounds, or the nearest\n * number within the bounds.\n */\nexport function clamp(value, min, max) {\n return Math.min(Math.max(value, min), max);\n}\n/**\n * Return the hyperbolic cosine of a given number. The method will use the\n * native `Math.cosh` function if it is available, otherwise the hyperbolic\n * cosine will be calculated via the reference implementation of the Mozilla\n * developer network.\n *\n * @param {number} x X.\n * @return {number} Hyperbolic cosine of x.\n */\nexport var cosh = (function () {\n // Wrapped in a iife, to save the overhead of checking for the native\n // implementation on every invocation.\n var cosh;\n if ('cosh' in Math) {\n // The environment supports the native Math.cosh function, use it…\n cosh = Math.cosh;\n }\n else {\n // … else, use the reference implementation of MDN:\n cosh = function (x) {\n var y = /** @type {Math} */ (Math).exp(x);\n return (y + 1 / y) / 2;\n };\n }\n return cosh;\n})();\n/**\n * Return the base 2 logarithm of a given number. The method will use the\n * native `Math.log2` function if it is available, otherwise the base 2\n * logarithm will be calculated via the reference implementation of the\n * Mozilla developer network.\n *\n * @param {number} x X.\n * @return {number} Base 2 logarithm of x.\n */\nexport var log2 = (function () {\n // Wrapped in a iife, to save the overhead of checking for the native\n // implementation on every invocation.\n var log2;\n if ('log2' in Math) {\n // The environment supports the native Math.log2 function, use it…\n log2 = Math.log2;\n }\n else {\n // … else, use the reference implementation of MDN:\n log2 = function (x) {\n return Math.log(x) * Math.LOG2E;\n };\n }\n return log2;\n})();\n/**\n * Returns the square of the closest distance between the point (x, y) and the\n * line segment (x1, y1) to (x2, y2).\n * @param {number} x X.\n * @param {number} y Y.\n * @param {number} x1 X1.\n * @param {number} y1 Y1.\n * @param {number} x2 X2.\n * @param {number} y2 Y2.\n * @return {number} Squared distance.\n */\nexport function squaredSegmentDistance(x, y, x1, y1, x2, y2) {\n var dx = x2 - x1;\n var dy = y2 - y1;\n if (dx !== 0 || dy !== 0) {\n var t = ((x - x1) * dx + (y - y1) * dy) / (dx * dx + dy * dy);\n if (t > 1) {\n x1 = x2;\n y1 = y2;\n }\n else if (t > 0) {\n x1 += dx * t;\n y1 += dy * t;\n }\n }\n return squaredDistance(x, y, x1, y1);\n}\n/**\n * Returns the square of the distance between the points (x1, y1) and (x2, y2).\n * @param {number} x1 X1.\n * @param {number} y1 Y1.\n * @param {number} x2 X2.\n * @param {number} y2 Y2.\n * @return {number} Squared distance.\n */\nexport function squaredDistance(x1, y1, x2, y2) {\n var dx = x2 - x1;\n var dy = y2 - y1;\n return dx * dx + dy * dy;\n}\n/**\n * Solves system of linear equations using Gaussian elimination method.\n *\n * @param {Array<Array<number>>} mat Augmented matrix (n x n + 1 column)\n * in row-major order.\n * @return {Array<number>} The resulting vector.\n */\nexport function solveLinearSystem(mat) {\n var n = mat.length;\n for (var i = 0; i < n; i++) {\n // Find max in the i-th column (ignoring i - 1 first rows)\n var maxRow = i;\n var maxEl = Math.abs(mat[i][i]);\n for (var r = i + 1; r < n; r++) {\n var absValue = Math.abs(mat[r][i]);\n if (absValue > maxEl) {\n maxEl = absValue;\n maxRow = r;\n }\n }\n if (maxEl === 0) {\n return null; // matrix is singular\n }\n // Swap max row with i-th (current) row\n var tmp = mat[maxRow];\n mat[maxRow] = mat[i];\n mat[i] = tmp;\n // Subtract the i-th row to make all the remaining rows 0 in the i-th column\n for (var j = i + 1; j < n; j++) {\n var coef = -mat[j][i] / mat[i][i];\n for (var k = i; k < n + 1; k++) {\n if (i == k) {\n mat[j][k] = 0;\n }\n else {\n mat[j][k] += coef * mat[i][k];\n }\n }\n }\n }\n // Solve Ax=b for upper triangular matrix A (mat)\n var x = new Array(n);\n for (var l = n - 1; l >= 0; l--) {\n x[l] = mat[l][n] / mat[l][l];\n for (var m = l - 1; m >= 0; m--) {\n mat[m][n] -= mat[m][l] * x[l];\n }\n }\n return x;\n}\n/**\n * Converts radians to to degrees.\n *\n * @param {number} angleInRadians Angle in radians.\n * @return {number} Angle in degrees.\n */\nexport function toDegrees(angleInRadians) {\n return (angleInRadians * 180) / Math.PI;\n}\n/**\n * Converts degrees to radians.\n *\n * @param {number} angleInDegrees Angle in degrees.\n * @return {number} Angle in radians.\n */\nexport function toRadians(angleInDegrees) {\n return (angleInDegrees * Math.PI) / 180;\n}\n/**\n * Returns the modulo of a / b, depending on the sign of b.\n *\n * @param {number} a Dividend.\n * @param {number} b Divisor.\n * @return {number} Modulo.\n */\nexport function modulo(a, b) {\n var r = a % b;\n return r * b < 0 ? r + b : r;\n}\n/**\n * Calculates the linearly interpolated value of x between a and b.\n *\n * @param {number} a Number\n * @param {number} b Number\n * @param {number} x Value to be interpolated.\n * @return {number} Interpolated value.\n */\nexport function lerp(a, b, x) {\n return a + x * (b - a);\n}\n//# sourceMappingURL=math.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/layer/Base\n */\nimport BaseObject from '../Object.js';\nimport LayerProperty from './Property.js';\nimport { abstract } from '../util.js';\nimport { assert } from '../asserts.js';\nimport { assign } from '../obj.js';\nimport { clamp } from '../math.js';\n/**\n * @typedef {import(\"../ObjectEventType\").Types|'change:extent'|'change:maxResolution'|'change:maxZoom'|\n * 'change:minResolution'|'change:minZoom'|'change:opacity'|'change:visible'|'change:zIndex'} BaseLayerObjectEventTypes\n */\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n * import(\"../Observable\").OnSignature<BaseLayerObjectEventTypes, import(\"../Object\").ObjectEvent, Return> &\n * import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|BaseLayerObjectEventTypes, Return>} BaseLayerOnSignature\n */\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-layer'] A CSS class name to set to the layer element.\n * @property {number} [opacity=1] Opacity (0, 1).\n * @property {boolean} [visible=true] Visibility.\n * @property {import(\"../extent.js\").Extent} [extent] The bounding extent for layer rendering. The layer will not be\n * rendered outside of this extent.\n * @property {number} [zIndex] The z-index for layer rendering. At rendering time, the layers\n * will be ordered, first by Z-index and then by position. When `undefined`, a `zIndex` of 0 is assumed\n * for layers that are added to the map's `layers` collection, or `Infinity` when the layer's `setMap()`\n * method was used.\n * @property {number} [minResolution] The minimum resolution (inclusive) at which this layer will be\n * visible.\n * @property {number} [maxResolution] The maximum resolution (exclusive) below which this layer will\n * be visible.\n * @property {number} [minZoom] The minimum view zoom level (exclusive) above which this layer will be\n * visible.\n * @property {number} [maxZoom] The maximum view zoom level (inclusive) at which this layer will\n * be visible.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * Note that with {@link module:ol/layer/Base} and all its subclasses, any property set in\n * the options is set as a {@link module:ol/Object} property on the layer object, so\n * is observable, and has get/set accessors.\n *\n * @api\n */\nvar BaseLayer = /** @class */ (function (_super) {\n __extends(BaseLayer, _super);\n /**\n * @param {Options} options Layer options.\n */\n function BaseLayer(options) {\n var _this = _super.call(this) || this;\n /***\n * @type {BaseLayerOnSignature<import(\"../events\").EventsKey>}\n */\n _this.on;\n /***\n * @type {BaseLayerOnSignature<import(\"../events\").EventsKey>}\n */\n _this.once;\n /***\n * @type {BaseLayerOnSignature<void>}\n */\n _this.un;\n /**\n * @type {Object<string, *>}\n */\n var properties = assign({}, options);\n if (typeof options.properties === 'object') {\n delete properties.properties;\n assign(properties, options.properties);\n }\n properties[LayerProperty.OPACITY] =\n options.opacity !== undefined ? options.opacity : 1;\n assert(typeof properties[LayerProperty.OPACITY] === 'number', 64); // Layer opacity must be a number\n properties[LayerProperty.VISIBLE] =\n options.visible !== undefined ? options.visible : true;\n properties[LayerProperty.Z_INDEX] = options.zIndex;\n properties[LayerProperty.MAX_RESOLUTION] =\n options.maxResolution !== undefined ? options.maxResolution : Infinity;\n properties[LayerProperty.MIN_RESOLUTION] =\n options.minResolution !== undefined ? options.minResolution : 0;\n properties[LayerProperty.MIN_ZOOM] =\n options.minZoom !== undefined ? options.minZoom : -Infinity;\n properties[LayerProperty.MAX_ZOOM] =\n options.maxZoom !== undefined ? options.maxZoom : Infinity;\n /**\n * @type {string}\n * @private\n */\n _this.className_ =\n properties.className !== undefined ? options.className : 'ol-layer';\n delete properties.className;\n _this.setProperties(properties);\n /**\n * @type {import(\"./Layer.js\").State}\n * @private\n */\n _this.state_ = null;\n return _this;\n }\n /**\n * @return {string} CSS class name.\n */\n BaseLayer.prototype.getClassName = function () {\n return this.className_;\n };\n /**\n * This method is not meant to be called by layers or layer renderers because the state\n * is incorrect if the layer is included in a layer group.\n *\n * @param {boolean} [opt_managed] Layer is managed.\n * @return {import(\"./Layer.js\").State} Layer state.\n */\n BaseLayer.prototype.getLayerState = function (opt_managed) {\n /** @type {import(\"./Layer.js\").State} */\n var state = this.state_ ||\n /** @type {?} */ ({\n layer: this,\n managed: opt_managed === undefined ? true : opt_managed,\n });\n var zIndex = this.getZIndex();\n state.opacity = clamp(Math.round(this.getOpacity() * 100) / 100, 0, 1);\n state.sourceState = this.getSourceState();\n state.visible = this.getVisible();\n state.extent = this.getExtent();\n state.zIndex = zIndex === undefined && !state.managed ? Infinity : zIndex;\n state.maxResolution = this.getMaxResolution();\n state.minResolution = Math.max(this.getMinResolution(), 0);\n state.minZoom = this.getMinZoom();\n state.maxZoom = this.getMaxZoom();\n this.state_ = state;\n return state;\n };\n /**\n * @abstract\n * @param {Array<import(\"./Layer.js\").default>} [opt_array] Array of layers (to be\n * modified in place).\n * @return {Array<import(\"./Layer.js\").default>} Array of layers.\n */\n BaseLayer.prototype.getLayersArray = function (opt_array) {\n return abstract();\n };\n /**\n * @abstract\n * @param {Array<import(\"./Layer.js\").State>} [opt_states] Optional list of layer\n * states (to be modified in place).\n * @return {Array<import(\"./Layer.js\").State>} List of layer states.\n */\n BaseLayer.prototype.getLayerStatesArray = function (opt_states) {\n return abstract();\n };\n /**\n * Return the {@link module:ol/extent~Extent extent} of the layer or `undefined` if it\n * will be visible regardless of extent.\n * @return {import(\"../extent.js\").Extent|undefined} The layer extent.\n * @observable\n * @api\n */\n BaseLayer.prototype.getExtent = function () {\n return /** @type {import(\"../extent.js\").Extent|undefined} */ (this.get(LayerProperty.EXTENT));\n };\n /**\n * Return the maximum resolution of the layer.\n * @return {number} The maximum resolution of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.getMaxResolution = function () {\n return /** @type {number} */ (this.get(LayerProperty.MAX_RESOLUTION));\n };\n /**\n * Return the minimum resolution of the layer.\n * @return {number} The minimum resolution of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.getMinResolution = function () {\n return /** @type {number} */ (this.get(LayerProperty.MIN_RESOLUTION));\n };\n /**\n * Return the minimum zoom level of the layer.\n * @return {number} The minimum zoom level of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.getMinZoom = function () {\n return /** @type {number} */ (this.get(LayerProperty.MIN_ZOOM));\n };\n /**\n * Return the maximum zoom level of the layer.\n * @return {number} The maximum zoom level of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.getMaxZoom = function () {\n return /** @type {number} */ (this.get(LayerProperty.MAX_ZOOM));\n };\n /**\n * Return the opacity of the layer (between 0 and 1).\n * @return {number} The opacity of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.getOpacity = function () {\n return /** @type {number} */ (this.get(LayerProperty.OPACITY));\n };\n /**\n * @abstract\n * @return {import(\"../source/State.js\").default} Source state.\n */\n BaseLayer.prototype.getSourceState = function () {\n return abstract();\n };\n /**\n * Return the visibility of the layer (`true` or `false`).\n * @return {boolean} The visibility of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.getVisible = function () {\n return /** @type {boolean} */ (this.get(LayerProperty.VISIBLE));\n };\n /**\n * Return the Z-index of the layer, which is used to order layers before\n * rendering. The default Z-index is 0.\n * @return {number} The Z-index of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.getZIndex = function () {\n return /** @type {number} */ (this.get(LayerProperty.Z_INDEX));\n };\n /**\n * Set the extent at which the layer is visible. If `undefined`, the layer\n * will be visible at all extents.\n * @param {import(\"../extent.js\").Extent|undefined} extent The extent of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.setExtent = function (extent) {\n this.set(LayerProperty.EXTENT, extent);\n };\n /**\n * Set the maximum resolution at which the layer is visible.\n * @param {number} maxResolution The maximum resolution of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.setMaxResolution = function (maxResolution) {\n this.set(LayerProperty.MAX_RESOLUTION, maxResolution);\n };\n /**\n * Set the minimum resolution at which the layer is visible.\n * @param {number} minResolution The minimum resolution of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.setMinResolution = function (minResolution) {\n this.set(LayerProperty.MIN_RESOLUTION, minResolution);\n };\n /**\n * Set the maximum zoom (exclusive) at which the layer is visible.\n * Note that the zoom levels for layer visibility are based on the\n * view zoom level, which may be different from a tile source zoom level.\n * @param {number} maxZoom The maximum zoom of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.setMaxZoom = function (maxZoom) {\n this.set(LayerProperty.MAX_ZOOM, maxZoom);\n };\n /**\n * Set the minimum zoom (inclusive) at which the layer is visible.\n * Note that the zoom levels for layer visibility are based on the\n * view zoom level, which may be different from a tile source zoom level.\n * @param {number} minZoom The minimum zoom of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.setMinZoom = function (minZoom) {\n this.set(LayerProperty.MIN_ZOOM, minZoom);\n };\n /**\n * Set the opacity of the layer, allowed values range from 0 to 1.\n * @param {number} opacity The opacity of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.setOpacity = function (opacity) {\n assert(typeof opacity === 'number', 64); // Layer opacity must be a number\n this.set(LayerProperty.OPACITY, opacity);\n };\n /**\n * Set the visibility of the layer (`true` or `false`).\n * @param {boolean} visible The visibility of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.setVisible = function (visible) {\n this.set(LayerProperty.VISIBLE, visible);\n };\n /**\n * Set Z-index of the layer, which is used to order layers before rendering.\n * The default Z-index is 0.\n * @param {number} zindex The z-index of the layer.\n * @observable\n * @api\n */\n BaseLayer.prototype.setZIndex = function (zindex) {\n this.set(LayerProperty.Z_INDEX, zindex);\n };\n /**\n * Clean up.\n */\n BaseLayer.prototype.disposeInternal = function () {\n if (this.state_) {\n this.state_.layer = null;\n this.state_ = null;\n }\n _super.prototype.disposeInternal.call(this);\n };\n return BaseLayer;\n}(BaseObject));\nexport default BaseLayer;\n//# sourceMappingURL=Base.js.map","/**\n * @module ol/render/EventType\n */\n/**\n * @enum {string}\n */\nexport default {\n /**\n * Triggered before a layer is rendered.\n * @event module:ol/render/Event~RenderEvent#prerender\n * @api\n */\n PRERENDER: 'prerender',\n /**\n * Triggered after a layer is rendered.\n * @event module:ol/render/Event~RenderEvent#postrender\n * @api\n */\n POSTRENDER: 'postrender',\n /**\n * Triggered before layers are rendered.\n * The event object will not have a `context` set.\n * @event module:ol/render/Event~RenderEvent#precompose\n * @api\n */\n PRECOMPOSE: 'precompose',\n /**\n * Triggered after all layers are rendered.\n * The event object will not have a `context` set.\n * @event module:ol/render/Event~RenderEvent#postcompose\n * @api\n */\n POSTCOMPOSE: 'postcompose',\n /**\n * Triggered when rendering is complete, i.e. all sources and tiles have\n * finished loading for the current viewport, and all tiles are faded in.\n * The event object will not have a `context` set.\n * @event module:ol/render/Event~RenderEvent#rendercomplete\n * @api\n */\n RENDERCOMPLETE: 'rendercomplete',\n};\n/**\n * @typedef {'postrender'|'precompose'|'postcompose'|'rendercomplete'} MapRenderEventTypes\n */\n/**\n * @typedef {'postrender'|'prerender'} LayerRenderEventTypes\n */\n//# sourceMappingURL=EventType.js.map","/**\n * @module ol/source/State\n */\n/**\n * @enum {string}\n * State of the source, one of 'undefined', 'loading', 'ready' or 'error'.\n */\nexport default {\n UNDEFINED: 'undefined',\n LOADING: 'loading',\n READY: 'ready',\n ERROR: 'error',\n};\n//# sourceMappingURL=State.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/layer/Layer\n */\nimport BaseLayer from './Base.js';\nimport EventType from '../events/EventType.js';\nimport LayerProperty from './Property.js';\nimport RenderEventType from '../render/EventType.js';\nimport SourceState from '../source/State.js';\nimport { assert } from '../asserts.js';\nimport { assign } from '../obj.js';\nimport { listen, unlistenByKey } from '../events.js';\n/**\n * @typedef {function(import(\"../PluggableMap.js\").FrameState):HTMLElement} RenderFunction\n */\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n * import(\"../Observable\").OnSignature<import(\"./Base\").BaseLayerObjectEventTypes|\n * 'change:source', import(\"../Object\").ObjectEvent, Return> &\n * import(\"../Observable\").OnSignature<import(\"../render/EventType\").LayerRenderEventTypes, import(\"../render/Event\").default, Return> &\n * import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"./Base\").BaseLayerObjectEventTypes|'change:source'|\n * import(\"../render/EventType\").LayerRenderEventTypes, Return>} LayerOnSignature\n */\n/**\n * @template {import(\"../source/Source.js\").default} SourceType\n * @typedef {Object} Options\n * @property {string} [className='ol-layer'] A CSS class name to set to the layer element.\n * @property {number} [opacity=1] Opacity (0, 1).\n * @property {boolean} [visible=true] Visibility.\n * @property {import(\"../extent.js\").Extent} [extent] The bounding extent for layer rendering. The layer will not be\n * rendered outside of this extent.\n * @property {number} [zIndex] The z-index for layer rendering. At rendering time, the layers\n * will be ordered, first by Z-index and then by position. When `undefined`, a `zIndex` of 0 is assumed\n * for layers that are added to the map's `layers` collection, or `Infinity` when the layer's `setMap()`\n * method was used.\n * @property {number} [minResolution] The minimum resolution (inclusive) at which this layer will be\n * visible.\n * @property {number} [maxResolution] The maximum resolution (exclusive) below which this layer will\n * be visible.\n * @property {number} [minZoom] The minimum view zoom level (exclusive) above which this layer will be\n * visible.\n * @property {number} [maxZoom] The maximum view zoom level (inclusive) at which this layer will\n * be visible.\n * @property {SourceType} [source] Source for this layer. If not provided to the constructor,\n * the source can be set by calling {@link module:ol/layer/Layer~Layer#setSource layer.setSource(source)} after\n * construction.\n * @property {import(\"../PluggableMap.js\").default} [map] Map.\n * @property {RenderFunction} [render] Render function. Takes the frame state as input and is expected to return an\n * HTML element. Will overwrite the default rendering for the layer.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n/**\n * @typedef {Object} State\n * @property {import(\"./Layer.js\").default} layer Layer.\n * @property {number} opacity Opacity, the value is rounded to two digits to appear after the decimal point.\n * @property {import(\"../source/State.js\").default} sourceState SourceState.\n * @property {boolean} visible Visible.\n * @property {boolean} managed Managed.\n * @property {import(\"../extent.js\").Extent} [extent] Extent.\n * @property {number} zIndex ZIndex.\n * @property {number} maxResolution Maximum resolution.\n * @property {number} minResolution Minimum resolution.\n * @property {number} minZoom Minimum zoom.\n * @property {number} maxZoom Maximum zoom.\n */\n/**\n * @classdesc\n * Base class from which all layer types are derived. This should only be instantiated\n * in the case where a custom layer is be added to the map with a custom `render` function.\n * Such a function can be specified in the `options` object, and is expected to return an HTML element.\n *\n * A visual representation of raster or vector map data.\n * Layers group together those properties that pertain to how the data is to be\n * displayed, irrespective of the source of that data.\n *\n * Layers are usually added to a map with {@link import(\"../PluggableMap.js\").default#addLayer map.addLayer()}. Components\n * like {@link module:ol/interaction/Draw~Draw} use unmanaged layers\n * internally. These unmanaged layers are associated with the map using\n * {@link module:ol/layer/Layer~Layer#setMap} instead.\n *\n * A generic `change` event is fired when the state of the source changes.\n *\n * Please note that for performance reasons several layers might get rendered to\n * the same HTML element, which will cause {@link import(\"../PluggableMap.js\").default#forEachLayerAtPixel map.forEachLayerAtPixel()} to\n * give false positives. To avoid this, apply different `className` properties to the\n * layers at creation time.\n *\n * @fires import(\"../render/Event.js\").RenderEvent#prerender\n * @fires import(\"../render/Event.js\").RenderEvent#postrender\n *\n * @template {import(\"../source/Source.js\").default} SourceType\n * @api\n */\nvar Layer = /** @class */ (function (_super) {\n __extends(Layer, _super);\n /**\n * @param {Options<SourceType>} options Layer options.\n */\n function Layer(options) {\n var _this = this;\n var baseOptions = assign({}, options);\n delete baseOptions.source;\n _this = _super.call(this, baseOptions) || this;\n /***\n * @type {LayerOnSignature<import(\"../events\").EventsKey>}\n */\n _this.on;\n /***\n * @type {LayerOnSignature<import(\"../events\").EventsKey>}\n */\n _this.once;\n /***\n * @type {LayerOnSignature<void>}\n */\n _this.un;\n /**\n * @private\n * @type {?import(\"../events.js\").EventsKey}\n */\n _this.mapPrecomposeKey_ = null;\n /**\n * @private\n * @type {?import(\"../events.js\").EventsKey}\n */\n _this.mapRenderKey_ = null;\n /**\n * @private\n * @type {?import(\"../events.js\").EventsKey}\n */\n _this.sourceChangeKey_ = null;\n /**\n * @private\n * @type {import(\"../renderer/Layer.js\").default}\n */\n _this.renderer_ = null;\n // Overwrite default render method with a custom one\n if (options.render) {\n _this.render = options.render;\n }\n if (options.map) {\n _this.setMap(options.map);\n }\n _this.addChangeListener(LayerProperty.SOURCE, _this.handleSourcePropertyChange_);\n var source = options.source\n ? /** @type {SourceType} */ (options.source)\n : null;\n _this.setSource(source);\n return _this;\n }\n /**\n * @param {Array<import(\"./Layer.js\").default>} [opt_array] Array of layers (to be modified in place).\n * @return {Array<import(\"./Layer.js\").default>} Array of layers.\n */\n Layer.prototype.getLayersArray = function (opt_array) {\n var array = opt_array ? opt_array : [];\n array.push(this);\n return array;\n };\n /**\n * @param {Array<import(\"./Layer.js\").State>} [opt_states] Optional list of layer states (to be modified in place).\n * @return {Array<import(\"./Layer.js\").State>} List of layer states.\n */\n Layer.prototype.getLayerStatesArray = function (opt_states) {\n var states = opt_states ? opt_states : [];\n states.push(this.getLayerState());\n return states;\n };\n /**\n * Get the layer source.\n * @return {SourceType} The layer source (or `null` if not yet set).\n * @observable\n * @api\n */\n Layer.prototype.getSource = function () {\n return /** @type {SourceType} */ (this.get(LayerProperty.SOURCE)) || null;\n };\n /**\n * @return {import(\"../source/State.js\").default} Source state.\n */\n Layer.prototype.getSourceState = function () {\n var source = this.getSource();\n return !source ? SourceState.UNDEFINED : source.getState();\n };\n /**\n * @private\n */\n Layer.prototype.handleSourceChange_ = function () {\n this.changed();\n };\n /**\n * @private\n */\n Layer.prototype.handleSourcePropertyChange_ = function () {\n if (this.sourceChangeKey_) {\n unlistenByKey(this.sourceChangeKey_);\n this.sourceChangeKey_ = null;\n }\n var source = this.getSource();\n if (source) {\n this.sourceChangeKey_ = listen(source, EventType.CHANGE, this.handleSourceChange_, this);\n }\n this.changed();\n };\n /**\n * @param {import(\"../pixel\").Pixel} pixel Pixel.\n * @return {Promise<Array<import(\"../Feature\").default>>} Promise that resolves with\n * an array of features.\n */\n Layer.prototype.getFeatures = function (pixel) {\n if (!this.renderer_) {\n return new Promise(function (resolve) { return resolve([]); });\n }\n return this.renderer_.getFeatures(pixel);\n };\n /**\n * In charge to manage the rendering of the layer. One layer type is\n * bounded with one layer renderer.\n * @param {?import(\"../PluggableMap.js\").FrameState} frameState Frame state.\n * @param {HTMLElement} target Target which the renderer may (but need not) use\n * for rendering its content.\n * @return {HTMLElement} The rendered element.\n */\n Layer.prototype.render = function (frameState, target) {\n var layerRenderer = this.getRenderer();\n if (layerRenderer.prepareFrame(frameState)) {\n return layerRenderer.renderFrame(frameState, target);\n }\n };\n /**\n * Sets the layer to be rendered on top of other layers on a map. The map will\n * not manage this layer in its layers collection, and the callback in\n * {@link module:ol/Map~Map#forEachLayerAtPixel} will receive `null` as layer. This\n * is useful for temporary layers. To remove an unmanaged layer from the map,\n * use `#setMap(null)`.\n *\n * To add the layer to a map and have it managed by the map, use\n * {@link module:ol/Map~Map#addLayer} instead.\n * @param {import(\"../PluggableMap.js\").default} map Map.\n * @api\n */\n Layer.prototype.setMap = function (map) {\n if (this.mapPrecomposeKey_) {\n unlistenByKey(this.mapPrecomposeKey_);\n this.mapPrecomposeKey_ = null;\n }\n if (!map) {\n this.changed();\n }\n if (this.mapRenderKey_) {\n unlistenByKey(this.mapRenderKey_);\n this.mapRenderKey_ = null;\n }\n if (map) {\n this.mapPrecomposeKey_ = listen(map, RenderEventType.PRECOMPOSE, function (evt) {\n var renderEvent = \n /** @type {import(\"../render/Event.js\").default} */ (evt);\n var layerStatesArray = renderEvent.frameState.layerStatesArray;\n var layerState = this.getLayerState(false);\n // A layer can only be added to the map once. Use either `layer.setMap()` or `map.addLayer()`, not both.\n assert(!layerStatesArray.some(function (arrayLayerState) {\n return arrayLayerState.layer === layerState.layer;\n }), 67);\n layerStatesArray.push(layerState);\n }, this);\n this.mapRenderKey_ = listen(this, EventType.CHANGE, map.render, map);\n this.changed();\n }\n };\n /**\n * Set the layer source.\n * @param {SourceType} source The layer source.\n * @observable\n * @api\n */\n Layer.prototype.setSource = function (source) {\n this.set(LayerProperty.SOURCE, source);\n };\n /**\n * Get the renderer for this layer.\n * @return {import(\"../renderer/Layer.js\").default} The layer renderer.\n */\n Layer.prototype.getRenderer = function () {\n if (!this.renderer_) {\n this.renderer_ = this.createRenderer();\n }\n return this.renderer_;\n };\n /**\n * @return {boolean} The layer has a renderer.\n */\n Layer.prototype.hasRenderer = function () {\n return !!this.renderer_;\n };\n /**\n * Create a renderer for this layer.\n * @return {import(\"../renderer/Layer.js\").default} A layer renderer.\n * @protected\n */\n Layer.prototype.createRenderer = function () {\n return null;\n };\n /**\n * Clean up.\n */\n Layer.prototype.disposeInternal = function () {\n if (this.renderer_) {\n this.renderer_.dispose();\n delete this.renderer_;\n }\n this.setSource(null);\n _super.prototype.disposeInternal.call(this);\n };\n return Layer;\n}(BaseLayer));\n/**\n * Return `true` if the layer is visible and if the provided view state\n * has resolution and zoom levels that are in range of the layer's min/max.\n * @param {State} layerState Layer state.\n * @param {import(\"../View.js\").State} viewState View state.\n * @return {boolean} The layer is visible at the given view state.\n */\nexport function inView(layerState, viewState) {\n if (!layerState.visible) {\n return false;\n }\n var resolution = viewState.resolution;\n if (resolution < layerState.minResolution ||\n resolution >= layerState.maxResolution) {\n return false;\n }\n var zoom = viewState.zoom;\n return zoom > layerState.minZoom && zoom <= layerState.maxZoom;\n}\nexport default Layer;\n//# sourceMappingURL=Layer.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/control/Attribution\n */\nimport Control from './Control.js';\nimport EventType from '../events/EventType.js';\nimport { CLASS_COLLAPSED, CLASS_CONTROL, CLASS_UNSELECTABLE } from '../css.js';\nimport { equals } from '../array.js';\nimport { inView } from '../layer/Layer.js';\nimport { removeChildren, replaceNode } from '../dom.js';\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-attribution'] CSS class name.\n * @property {HTMLElement|string} [target] Specify a target if you\n * want the control to be rendered outside of the map's\n * viewport.\n * @property {boolean} [collapsible] Specify if attributions can\n * be collapsed. If not specified, sources control this behavior with their\n * `attributionsCollapsible` setting.\n * @property {boolean} [collapsed=true] Specify if attributions should\n * be collapsed at startup.\n * @property {string} [tipLabel='Attributions'] Text label to use for the button tip.\n * @property {string|HTMLElement} [label='i'] Text label to use for the\n * collapsed attributions button.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string} [expandClassName=className + '-expand'] CSS class name for the\n * collapsed attributions button.\n * @property {string|HTMLElement} [collapseLabel='›'] Text label to use\n * for the expanded attributions button.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string} [collapseClassName=className + '-collapse'] CSS class name for the\n * expanded attributions button.\n * @property {function(import(\"../MapEvent.js\").default):void} [render] Function called when\n * the control should be re-rendered. This is called in a `requestAnimationFrame`\n * callback.\n */\n/**\n * @classdesc\n * Control to show all the attributions associated with the layer sources\n * in the map. This control is one of the default controls included in maps.\n * By default it will show in the bottom right portion of the map, but this can\n * be changed by using a css selector for `.ol-attribution`.\n *\n * @api\n */\nvar Attribution = /** @class */ (function (_super) {\n __extends(Attribution, _super);\n /**\n * @param {Options} [opt_options] Attribution options.\n */\n function Attribution(opt_options) {\n var _this = this;\n var options = opt_options ? opt_options : {};\n _this = _super.call(this, {\n element: document.createElement('div'),\n render: options.render,\n target: options.target,\n }) || this;\n /**\n * @private\n * @type {HTMLElement}\n */\n _this.ulElement_ = document.createElement('ul');\n /**\n * @private\n * @type {boolean}\n */\n _this.collapsed_ =\n options.collapsed !== undefined ? options.collapsed : true;\n /**\n * @private\n * @type {boolean}\n */\n _this.userCollapsed_ = _this.collapsed_;\n /**\n * @private\n * @type {boolean}\n */\n _this.overrideCollapsible_ = options.collapsible !== undefined;\n /**\n * @private\n * @type {boolean}\n */\n _this.collapsible_ =\n options.collapsible !== undefined ? options.collapsible : true;\n if (!_this.collapsible_) {\n _this.collapsed_ = false;\n }\n var className = options.className !== undefined ? options.className : 'ol-attribution';\n var tipLabel = options.tipLabel !== undefined ? options.tipLabel : 'Attributions';\n var expandClassName = options.expandClassName !== undefined\n ? options.expandClassName\n : className + '-expand';\n var collapseLabel = options.collapseLabel !== undefined ? options.collapseLabel : '\\u203A';\n var collapseClassName = options.collapseClassName !== undefined\n ? options.collapseClassName\n : className + '-collpase';\n if (typeof collapseLabel === 'string') {\n /**\n * @private\n * @type {HTMLElement}\n */\n _this.collapseLabel_ = document.createElement('span');\n _this.collapseLabel_.textContent = collapseLabel;\n _this.collapseLabel_.className = collapseClassName;\n }\n else {\n _this.collapseLabel_ = collapseLabel;\n }\n var label = options.label !== undefined ? options.label : 'i';\n if (typeof label === 'string') {\n /**\n * @private\n * @type {HTMLElement}\n */\n _this.label_ = document.createElement('span');\n _this.label_.textContent = label;\n _this.label_.className = expandClassName;\n }\n else {\n _this.label_ = label;\n }\n var activeLabel = _this.collapsible_ && !_this.collapsed_ ? _this.collapseLabel_ : _this.label_;\n /**\n * @private\n * @type {HTMLElement}\n */\n _this.toggleButton_ = document.createElement('button');\n _this.toggleButton_.setAttribute('type', 'button');\n _this.toggleButton_.setAttribute('aria-expanded', String(!_this.collapsed_));\n _this.toggleButton_.title = tipLabel;\n _this.toggleButton_.appendChild(activeLabel);\n _this.toggleButton_.addEventListener(EventType.CLICK, _this.handleClick_.bind(_this), false);\n var cssClasses = className +\n ' ' +\n CLASS_UNSELECTABLE +\n ' ' +\n CLASS_CONTROL +\n (_this.collapsed_ && _this.collapsible_ ? ' ' + CLASS_COLLAPSED : '') +\n (_this.collapsible_ ? '' : ' ol-uncollapsible');\n var element = _this.element;\n element.className = cssClasses;\n element.appendChild(_this.toggleButton_);\n element.appendChild(_this.ulElement_);\n /**\n * A list of currently rendered resolutions.\n * @type {Array<string>}\n * @private\n */\n _this.renderedAttributions_ = [];\n /**\n * @private\n * @type {boolean}\n */\n _this.renderedVisible_ = true;\n return _this;\n }\n /**\n * Collect a list of visible attributions and set the collapsible state.\n * @param {import(\"../PluggableMap.js\").FrameState} frameState Frame state.\n * @return {Array<string>} Attributions.\n * @private\n */\n Attribution.prototype.collectSourceAttributions_ = function (frameState) {\n /**\n * Used to determine if an attribution already exists.\n * @type {!Object<string, boolean>}\n */\n var lookup = {};\n /**\n * A list of visible attributions.\n * @type {Array<string>}\n */\n var visibleAttributions = [];\n var collapsible = true;\n var layerStatesArray = frameState.layerStatesArray;\n for (var i = 0, ii = layerStatesArray.length; i < ii; ++i) {\n var layerState = layerStatesArray[i];\n if (!inView(layerState, frameState.viewState)) {\n continue;\n }\n var source = /** @type {import(\"../layer/Layer.js\").default} */ (layerState.layer).getSource();\n if (!source) {\n continue;\n }\n var attributionGetter = source.getAttributions();\n if (!attributionGetter) {\n continue;\n }\n var attributions = attributionGetter(frameState);\n if (!attributions) {\n continue;\n }\n collapsible =\n collapsible && source.getAttributionsCollapsible() !== false;\n if (Array.isArray(attributions)) {\n for (var j = 0, jj = attributions.length; j < jj; ++j) {\n if (!(attributions[j] in lookup)) {\n visibleAttributions.push(attributions[j]);\n lookup[attributions[j]] = true;\n }\n }\n }\n else {\n if (!(attributions in lookup)) {\n visibleAttributions.push(attributions);\n lookup[attributions] = true;\n }\n }\n }\n if (!this.overrideCollapsible_) {\n this.setCollapsible(collapsible);\n }\n return visibleAttributions;\n };\n /**\n * @private\n * @param {?import(\"../PluggableMap.js\").FrameState} frameState Frame state.\n */\n Attribution.prototype.updateElement_ = function (frameState) {\n if (!frameState) {\n if (this.renderedVisible_) {\n this.element.style.display = 'none';\n this.renderedVisible_ = false;\n }\n return;\n }\n var attributions = this.collectSourceAttributions_(frameState);\n var visible = attributions.length > 0;\n if (this.renderedVisible_ != visible) {\n this.element.style.display = visible ? '' : 'none';\n this.renderedVisible_ = visible;\n }\n if (equals(attributions, this.renderedAttributions_)) {\n return;\n }\n removeChildren(this.ulElement_);\n // append the attributions\n for (var i = 0, ii = attributions.length; i < ii; ++i) {\n var element = document.createElement('li');\n element.innerHTML = attributions[i];\n this.ulElement_.appendChild(element);\n }\n this.renderedAttributions_ = attributions;\n };\n /**\n * @param {MouseEvent} event The event to handle\n * @private\n */\n Attribution.prototype.handleClick_ = function (event) {\n event.preventDefault();\n this.handleToggle_();\n this.userCollapsed_ = this.collapsed_;\n };\n /**\n * @private\n */\n Attribution.prototype.handleToggle_ = function () {\n this.element.classList.toggle(CLASS_COLLAPSED);\n if (this.collapsed_) {\n replaceNode(this.collapseLabel_, this.label_);\n }\n else {\n replaceNode(this.label_, this.collapseLabel_);\n }\n this.collapsed_ = !this.collapsed_;\n this.toggleButton_.setAttribute('aria-expanded', String(!this.collapsed_));\n };\n /**\n * Return `true` if the attribution is collapsible, `false` otherwise.\n * @return {boolean} True if the widget is collapsible.\n * @api\n */\n Attribution.prototype.getCollapsible = function () {\n return this.collapsible_;\n };\n /**\n * Set whether the attribution should be collapsible.\n * @param {boolean} collapsible True if the widget is collapsible.\n * @api\n */\n Attribution.prototype.setCollapsible = function (collapsible) {\n if (this.collapsible_ === collapsible) {\n return;\n }\n this.collapsible_ = collapsible;\n this.element.classList.toggle('ol-uncollapsible');\n if (this.userCollapsed_) {\n this.handleToggle_();\n }\n };\n /**\n * Collapse or expand the attribution according to the passed parameter. Will\n * not do anything if the attribution isn't collapsible or if the current\n * collapsed state is already the one requested.\n * @param {boolean} collapsed True if the widget is collapsed.\n * @api\n */\n Attribution.prototype.setCollapsed = function (collapsed) {\n this.userCollapsed_ = collapsed;\n if (!this.collapsible_ || this.collapsed_ === collapsed) {\n return;\n }\n this.handleToggle_();\n };\n /**\n * Return `true` when the attribution is currently collapsed or `false`\n * otherwise.\n * @return {boolean} True if the widget is collapsed.\n * @api\n */\n Attribution.prototype.getCollapsed = function () {\n return this.collapsed_;\n };\n /**\n * Update the attribution element.\n * @param {import(\"../MapEvent.js\").default} mapEvent Map event.\n * @override\n */\n Attribution.prototype.render = function (mapEvent) {\n this.updateElement_(mapEvent.frameState);\n };\n return Attribution;\n}(Control));\nexport default Attribution;\n//# sourceMappingURL=Attribution.js.map","/**\n * @module ol/pointer/EventType\n */\n/**\n * Constants for event names.\n * @enum {string}\n */\nexport default {\n POINTERMOVE: 'pointermove',\n POINTERDOWN: 'pointerdown',\n POINTERUP: 'pointerup',\n POINTEROVER: 'pointerover',\n POINTEROUT: 'pointerout',\n POINTERENTER: 'pointerenter',\n POINTERLEAVE: 'pointerleave',\n POINTERCANCEL: 'pointercancel',\n};\n//# sourceMappingURL=EventType.js.map","/**\n * @module ol/proj/Units\n */\n/**\n * Projection units: `'degrees'`, `'ft'`, `'m'`, `'pixels'`, `'tile-pixels'` or\n * `'us-ft'`.\n * @enum {string}\n */\nvar Units = {\n /**\n * Radians\n * @api\n */\n RADIANS: 'radians',\n /**\n * Degrees\n * @api\n */\n DEGREES: 'degrees',\n /**\n * Feet\n * @api\n */\n FEET: 'ft',\n /**\n * Meters\n * @api\n */\n METERS: 'm',\n /**\n * Pixels\n * @api\n */\n PIXELS: 'pixels',\n /**\n * Tile Pixels\n * @api\n */\n TILE_PIXELS: 'tile-pixels',\n /**\n * US Feet\n * @api\n */\n USFEET: 'us-ft',\n};\n/**\n * See http://duff.ess.washington.edu/data/raster/drg/docs/geotiff.txt\n * @type {Object<number, Units>}\n */\nvar unitByCode = {\n '9001': Units.METERS,\n '9002': Units.FEET,\n '9003': Units.USFEET,\n '9101': Units.RADIANS,\n '9102': Units.DEGREES,\n};\n/**\n * @param {number} code Unit code.\n * @return {Units} Units.\n */\nexport function fromCode(code) {\n return unitByCode[code];\n}\n/**\n * Meters per unit lookup table.\n * @const\n * @type {Object<Units, number>}\n * @api\n */\nexport var METERS_PER_UNIT = {};\n// use the radius of the Normal sphere\nMETERS_PER_UNIT[Units.RADIANS] = 6370997 / (2 * Math.PI);\nMETERS_PER_UNIT[Units.DEGREES] = (2 * Math.PI * 6370997) / 360;\nMETERS_PER_UNIT[Units.FEET] = 0.3048;\nMETERS_PER_UNIT[Units.METERS] = 1;\nMETERS_PER_UNIT[Units.USFEET] = 1200 / 3937;\nexport default Units;\n//# sourceMappingURL=Units.js.map","/**\n * @module ol/proj/Projection\n */\nimport { METERS_PER_UNIT } from './Units.js';\n/**\n * @typedef {Object} Options\n * @property {string} code The SRS identifier code, e.g. `EPSG:4326`.\n * @property {import(\"./Units.js\").default|string} [units] Units. Required unless a\n * proj4 projection is defined for `code`.\n * @property {import(\"../extent.js\").Extent} [extent] The validity extent for the SRS.\n * @property {string} [axisOrientation='enu'] The axis orientation as specified in Proj4.\n * @property {boolean} [global=false] Whether the projection is valid for the whole globe.\n * @property {number} [metersPerUnit] The meters per unit for the SRS.\n * If not provided, the `units` are used to get the meters per unit from the {@link module:ol/proj/Units~METERS_PER_UNIT}\n * lookup table.\n * @property {import(\"../extent.js\").Extent} [worldExtent] The world extent for the SRS.\n * @property {function(number, import(\"../coordinate.js\").Coordinate):number} [getPointResolution]\n * Function to determine resolution at a point. The function is called with a\n * `number` view resolution and a {@link module:ol/coordinate~Coordinate Coordinate} as arguments, and returns\n * the `number` resolution in projection units at the passed coordinate. If this is `undefined`,\n * the default {@link module:ol/proj.getPointResolution getPointResolution()} function will be used.\n */\n/**\n * @classdesc\n * Projection definition class. One of these is created for each projection\n * supported in the application and stored in the {@link module:ol/proj} namespace.\n * You can use these in applications, but this is not required, as API params\n * and options use {@link module:ol/proj~ProjectionLike} which means the simple string\n * code will suffice.\n *\n * You can use {@link module:ol/proj.get} to retrieve the object for a particular\n * projection.\n *\n * The library includes definitions for `EPSG:4326` and `EPSG:3857`, together\n * with the following aliases:\n * * `EPSG:4326`: CRS:84, urn:ogc:def:crs:EPSG:6.6:4326,\n * urn:ogc:def:crs:OGC:1.3:CRS84, urn:ogc:def:crs:OGC:2:84,\n * http://www.opengis.net/gml/srs/epsg.xml#4326,\n * urn:x-ogc:def:crs:EPSG:4326\n * * `EPSG:3857`: EPSG:102100, EPSG:102113, EPSG:900913,\n * urn:ogc:def:crs:EPSG:6.18:3:3857,\n * http://www.opengis.net/gml/srs/epsg.xml#3857\n *\n * If you use [proj4js](https://github.com/proj4js/proj4js), aliases can\n * be added using `proj4.defs()`. After all required projection definitions are\n * added, call the {@link module:ol/proj/proj4.register} function.\n *\n * @api\n */\nvar Projection = /** @class */ (function () {\n /**\n * @param {Options} options Projection options.\n */\n function Projection(options) {\n /**\n * @private\n * @type {string}\n */\n this.code_ = options.code;\n /**\n * Units of projected coordinates. When set to `TILE_PIXELS`, a\n * `this.extent_` and `this.worldExtent_` must be configured properly for each\n * tile.\n * @private\n * @type {import(\"./Units.js\").default}\n */\n this.units_ = /** @type {import(\"./Units.js\").default} */ (options.units);\n /**\n * Validity extent of the projection in projected coordinates. For projections\n * with `TILE_PIXELS` units, this is the extent of the tile in\n * tile pixel space.\n * @private\n * @type {import(\"../extent.js\").Extent}\n */\n this.extent_ = options.extent !== undefined ? options.extent : null;\n /**\n * Extent of the world in EPSG:4326. For projections with\n * `TILE_PIXELS` units, this is the extent of the tile in\n * projected coordinate space.\n * @private\n * @type {import(\"../extent.js\").Extent}\n */\n this.worldExtent_ =\n options.worldExtent !== undefined ? options.worldExtent : null;\n /**\n * @private\n * @type {string}\n */\n this.axisOrientation_ =\n options.axisOrientation !== undefined ? options.axisOrientation : 'enu';\n /**\n * @private\n * @type {boolean}\n */\n this.global_ = options.global !== undefined ? options.global : false;\n /**\n * @private\n * @type {boolean}\n */\n this.canWrapX_ = !!(this.global_ && this.extent_);\n /**\n * @private\n * @type {function(number, import(\"../coordinate.js\").Coordinate):number|undefined}\n */\n this.getPointResolutionFunc_ = options.getPointResolution;\n /**\n * @private\n * @type {import(\"../tilegrid/TileGrid.js\").default}\n */\n this.defaultTileGrid_ = null;\n /**\n * @private\n * @type {number|undefined}\n */\n this.metersPerUnit_ = options.metersPerUnit;\n }\n /**\n * @return {boolean} The projection is suitable for wrapping the x-axis\n */\n Projection.prototype.canWrapX = function () {\n return this.canWrapX_;\n };\n /**\n * Get the code for this projection, e.g. 'EPSG:4326'.\n * @return {string} Code.\n * @api\n */\n Projection.prototype.getCode = function () {\n return this.code_;\n };\n /**\n * Get the validity extent for this projection.\n * @return {import(\"../extent.js\").Extent} Extent.\n * @api\n */\n Projection.prototype.getExtent = function () {\n return this.extent_;\n };\n /**\n * Get the units of this projection.\n * @return {import(\"./Units.js\").default} Units.\n * @api\n */\n Projection.prototype.getUnits = function () {\n return this.units_;\n };\n /**\n * Get the amount of meters per unit of this projection. If the projection is\n * not configured with `metersPerUnit` or a units identifier, the return is\n * `undefined`.\n * @return {number|undefined} Meters.\n * @api\n */\n Projection.prototype.getMetersPerUnit = function () {\n return this.metersPerUnit_ || METERS_PER_UNIT[this.units_];\n };\n /**\n * Get the world extent for this projection.\n * @return {import(\"../extent.js\").Extent} Extent.\n * @api\n */\n Projection.prototype.getWorldExtent = function () {\n return this.worldExtent_;\n };\n /**\n * Get the axis orientation of this projection.\n * Example values are:\n * enu - the default easting, northing, elevation.\n * neu - northing, easting, up - useful for \"lat/long\" geographic coordinates,\n * or south orientated transverse mercator.\n * wnu - westing, northing, up - some planetary coordinate systems have\n * \"west positive\" coordinate systems\n * @return {string} Axis orientation.\n * @api\n */\n Projection.prototype.getAxisOrientation = function () {\n return this.axisOrientation_;\n };\n /**\n * Is this projection a global projection which spans the whole world?\n * @return {boolean} Whether the projection is global.\n * @api\n */\n Projection.prototype.isGlobal = function () {\n return this.global_;\n };\n /**\n * Set if the projection is a global projection which spans the whole world\n * @param {boolean} global Whether the projection is global.\n * @api\n */\n Projection.prototype.setGlobal = function (global) {\n this.global_ = global;\n this.canWrapX_ = !!(global && this.extent_);\n };\n /**\n * @return {import(\"../tilegrid/TileGrid.js\").default} The default tile grid.\n */\n Projection.prototype.getDefaultTileGrid = function () {\n return this.defaultTileGrid_;\n };\n /**\n * @param {import(\"../tilegrid/TileGrid.js\").default} tileGrid The default tile grid.\n */\n Projection.prototype.setDefaultTileGrid = function (tileGrid) {\n this.defaultTileGrid_ = tileGrid;\n };\n /**\n * Set the validity extent for this projection.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @api\n */\n Projection.prototype.setExtent = function (extent) {\n this.extent_ = extent;\n this.canWrapX_ = !!(this.global_ && extent);\n };\n /**\n * Set the world extent for this projection.\n * @param {import(\"../extent.js\").Extent} worldExtent World extent\n * [minlon, minlat, maxlon, maxlat].\n * @api\n */\n Projection.prototype.setWorldExtent = function (worldExtent) {\n this.worldExtent_ = worldExtent;\n };\n /**\n * Set the getPointResolution function (see {@link module:ol/proj.getPointResolution}\n * for this projection.\n * @param {function(number, import(\"../coordinate.js\").Coordinate):number} func Function\n * @api\n */\n Projection.prototype.setGetPointResolution = function (func) {\n this.getPointResolutionFunc_ = func;\n };\n /**\n * Get the custom point resolution function for this projection (if set).\n * @return {function(number, import(\"../coordinate.js\").Coordinate):number|undefined} The custom point\n * resolution function (if set).\n */\n Projection.prototype.getPointResolutionFunc = function () {\n return this.getPointResolutionFunc_;\n };\n return Projection;\n}());\nexport default Projection;\n//# sourceMappingURL=Projection.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/proj/epsg3857\n */\nimport Projection from './Projection.js';\nimport Units from './Units.js';\nimport { cosh } from '../math.js';\n/**\n * Radius of WGS84 sphere\n *\n * @const\n * @type {number}\n */\nexport var RADIUS = 6378137;\n/**\n * @const\n * @type {number}\n */\nexport var HALF_SIZE = Math.PI * RADIUS;\n/**\n * @const\n * @type {import(\"../extent.js\").Extent}\n */\nexport var EXTENT = [-HALF_SIZE, -HALF_SIZE, HALF_SIZE, HALF_SIZE];\n/**\n * @const\n * @type {import(\"../extent.js\").Extent}\n */\nexport var WORLD_EXTENT = [-180, -85, 180, 85];\n/**\n * Maximum safe value in y direction\n * @const\n * @type {number}\n */\nexport var MAX_SAFE_Y = RADIUS * Math.log(Math.tan(Math.PI / 2));\n/**\n * @classdesc\n * Projection object for web/spherical Mercator (EPSG:3857).\n */\nvar EPSG3857Projection = /** @class */ (function (_super) {\n __extends(EPSG3857Projection, _super);\n /**\n * @param {string} code Code.\n */\n function EPSG3857Projection(code) {\n return _super.call(this, {\n code: code,\n units: Units.METERS,\n extent: EXTENT,\n global: true,\n worldExtent: WORLD_EXTENT,\n getPointResolution: function (resolution, point) {\n return resolution / cosh(point[1] / RADIUS);\n },\n }) || this;\n }\n return EPSG3857Projection;\n}(Projection));\n/**\n * Projections equal to EPSG:3857.\n *\n * @const\n * @type {Array<import(\"./Projection.js\").default>}\n */\nexport var PROJECTIONS = [\n new EPSG3857Projection('EPSG:3857'),\n new EPSG3857Projection('EPSG:102100'),\n new EPSG3857Projection('EPSG:102113'),\n new EPSG3857Projection('EPSG:900913'),\n new EPSG3857Projection('http://www.opengis.net/def/crs/EPSG/0/3857'),\n new EPSG3857Projection('http://www.opengis.net/gml/srs/epsg.xml#3857'),\n];\n/**\n * Transformation from EPSG:4326 to EPSG:3857.\n *\n * @param {Array<number>} input Input array of coordinate values.\n * @param {Array<number>} [opt_output] Output array of coordinate values.\n * @param {number} [opt_dimension] Dimension (default is `2`).\n * @return {Array<number>} Output array of coordinate values.\n */\nexport function fromEPSG4326(input, opt_output, opt_dimension) {\n var length = input.length;\n var dimension = opt_dimension > 1 ? opt_dimension : 2;\n var output = opt_output;\n if (output === undefined) {\n if (dimension > 2) {\n // preserve values beyond second dimension\n output = input.slice();\n }\n else {\n output = new Array(length);\n }\n }\n for (var i = 0; i < length; i += dimension) {\n output[i] = (HALF_SIZE * input[i]) / 180;\n var y = RADIUS * Math.log(Math.tan((Math.PI * (+input[i + 1] + 90)) / 360));\n if (y > MAX_SAFE_Y) {\n y = MAX_SAFE_Y;\n }\n else if (y < -MAX_SAFE_Y) {\n y = -MAX_SAFE_Y;\n }\n output[i + 1] = y;\n }\n return output;\n}\n/**\n * Transformation from EPSG:3857 to EPSG:4326.\n *\n * @param {Array<number>} input Input array of coordinate values.\n * @param {Array<number>} [opt_output] Output array of coordinate values.\n * @param {number} [opt_dimension] Dimension (default is `2`).\n * @return {Array<number>} Output array of coordinate values.\n */\nexport function toEPSG4326(input, opt_output, opt_dimension) {\n var length = input.length;\n var dimension = opt_dimension > 1 ? opt_dimension : 2;\n var output = opt_output;\n if (output === undefined) {\n if (dimension > 2) {\n // preserve values beyond second dimension\n output = input.slice();\n }\n else {\n output = new Array(length);\n }\n }\n for (var i = 0; i < length; i += dimension) {\n output[i] = (180 * input[i]) / HALF_SIZE;\n output[i + 1] =\n (360 * Math.atan(Math.exp(input[i + 1] / RADIUS))) / Math.PI - 90;\n }\n return output;\n}\n//# sourceMappingURL=epsg3857.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/proj/epsg4326\n */\nimport Projection from './Projection.js';\nimport Units from './Units.js';\n/**\n * Semi-major radius of the WGS84 ellipsoid.\n *\n * @const\n * @type {number}\n */\nexport var RADIUS = 6378137;\n/**\n * Extent of the EPSG:4326 projection which is the whole world.\n *\n * @const\n * @type {import(\"../extent.js\").Extent}\n */\nexport var EXTENT = [-180, -90, 180, 90];\n/**\n * @const\n * @type {number}\n */\nexport var METERS_PER_UNIT = (Math.PI * RADIUS) / 180;\n/**\n * @classdesc\n * Projection object for WGS84 geographic coordinates (EPSG:4326).\n *\n * Note that OpenLayers does not strictly comply with the EPSG definition.\n * The EPSG registry defines 4326 as a CRS for Latitude,Longitude (y,x).\n * OpenLayers treats EPSG:4326 as a pseudo-projection, with x,y coordinates.\n */\nvar EPSG4326Projection = /** @class */ (function (_super) {\n __extends(EPSG4326Projection, _super);\n /**\n * @param {string} code Code.\n * @param {string} [opt_axisOrientation] Axis orientation.\n */\n function EPSG4326Projection(code, opt_axisOrientation) {\n return _super.call(this, {\n code: code,\n units: Units.DEGREES,\n extent: EXTENT,\n axisOrientation: opt_axisOrientation,\n global: true,\n metersPerUnit: METERS_PER_UNIT,\n worldExtent: EXTENT,\n }) || this;\n }\n return EPSG4326Projection;\n}(Projection));\n/**\n * Projections equal to EPSG:4326.\n *\n * @const\n * @type {Array<import(\"./Projection.js\").default>}\n */\nexport var PROJECTIONS = [\n new EPSG4326Projection('CRS:84'),\n new EPSG4326Projection('EPSG:4326', 'neu'),\n new EPSG4326Projection('urn:ogc:def:crs:OGC:1.3:CRS84'),\n new EPSG4326Projection('urn:ogc:def:crs:OGC:2:84'),\n new EPSG4326Projection('http://www.opengis.net/def/crs/OGC/1.3/CRS84', 'neu'),\n new EPSG4326Projection('http://www.opengis.net/gml/srs/epsg.xml#4326', 'neu'),\n new EPSG4326Projection('http://www.opengis.net/def/crs/EPSG/0/4326', 'neu'),\n];\n//# sourceMappingURL=epsg4326.js.map","/**\n * @module ol/proj/projections\n */\n/**\n * @type {Object<string, import(\"./Projection.js\").default>}\n */\nvar cache = {};\n/**\n * Clear the projections cache.\n */\nexport function clear() {\n cache = {};\n}\n/**\n * Get a cached projection by code.\n * @param {string} code The code for the projection.\n * @return {import(\"./Projection.js\").default} The projection (if cached).\n */\nexport function get(code) {\n return (cache[code] ||\n cache[code.replace(/urn:(x-)?ogc:def:crs:EPSG:(.*:)?(\\w+)$/, 'EPSG:$3')] ||\n null);\n}\n/**\n * Add a projection to the cache.\n * @param {string} code The projection code.\n * @param {import(\"./Projection.js\").default} projection The projection to cache.\n */\nexport function add(code, projection) {\n cache[code] = projection;\n}\n//# sourceMappingURL=projections.js.map","/**\n * @module ol/proj/transforms\n */\nimport { isEmpty } from '../obj.js';\n/**\n * @private\n * @type {!Object<string, Object<string, import(\"../proj.js\").TransformFunction>>}\n */\nvar transforms = {};\n/**\n * Clear the transform cache.\n */\nexport function clear() {\n transforms = {};\n}\n/**\n * Registers a conversion function to convert coordinates from the source\n * projection to the destination projection.\n *\n * @param {import(\"./Projection.js\").default} source Source.\n * @param {import(\"./Projection.js\").default} destination Destination.\n * @param {import(\"../proj.js\").TransformFunction} transformFn Transform.\n */\nexport function add(source, destination, transformFn) {\n var sourceCode = source.getCode();\n var destinationCode = destination.getCode();\n if (!(sourceCode in transforms)) {\n transforms[sourceCode] = {};\n }\n transforms[sourceCode][destinationCode] = transformFn;\n}\n/**\n * Unregisters the conversion function to convert coordinates from the source\n * projection to the destination projection. This method is used to clean up\n * cached transforms during testing.\n *\n * @param {import(\"./Projection.js\").default} source Source projection.\n * @param {import(\"./Projection.js\").default} destination Destination projection.\n * @return {import(\"../proj.js\").TransformFunction} transformFn The unregistered transform.\n */\nexport function remove(source, destination) {\n var sourceCode = source.getCode();\n var destinationCode = destination.getCode();\n var transform = transforms[sourceCode][destinationCode];\n delete transforms[sourceCode][destinationCode];\n if (isEmpty(transforms[sourceCode])) {\n delete transforms[sourceCode];\n }\n return transform;\n}\n/**\n * Get a transform given a source code and a destination code.\n * @param {string} sourceCode The code for the source projection.\n * @param {string} destinationCode The code for the destination projection.\n * @return {import(\"../proj.js\").TransformFunction|undefined} The transform function (if found).\n */\nexport function get(sourceCode, destinationCode) {\n var transform;\n if (sourceCode in transforms && destinationCode in transforms[sourceCode]) {\n transform = transforms[sourceCode][destinationCode];\n }\n return transform;\n}\n//# sourceMappingURL=transforms.js.map","/**\n * @module ol/extent/Corner\n */\n/**\n * Extent corner.\n * @enum {string}\n */\nexport default {\n BOTTOM_LEFT: 'bottom-left',\n BOTTOM_RIGHT: 'bottom-right',\n TOP_LEFT: 'top-left',\n TOP_RIGHT: 'top-right',\n};\n//# sourceMappingURL=Corner.js.map","/**\n * @module ol/extent/Relationship\n */\n/**\n * Relationship to an extent.\n * @enum {number}\n */\nexport default {\n UNKNOWN: 0,\n INTERSECTING: 1,\n ABOVE: 2,\n RIGHT: 4,\n BELOW: 8,\n LEFT: 16,\n};\n//# sourceMappingURL=Relationship.js.map","/**\n * @module ol/extent\n */\nimport Corner from './extent/Corner.js';\nimport Relationship from './extent/Relationship.js';\nimport { assert } from './asserts.js';\n/**\n * An array of numbers representing an extent: `[minx, miny, maxx, maxy]`.\n * @typedef {Array<number>} Extent\n * @api\n */\n/**\n * Build an extent that includes all given coordinates.\n *\n * @param {Array<import(\"./coordinate.js\").Coordinate>} coordinates Coordinates.\n * @return {Extent} Bounding extent.\n * @api\n */\nexport function boundingExtent(coordinates) {\n var extent = createEmpty();\n for (var i = 0, ii = coordinates.length; i < ii; ++i) {\n extendCoordinate(extent, coordinates[i]);\n }\n return extent;\n}\n/**\n * @param {Array<number>} xs Xs.\n * @param {Array<number>} ys Ys.\n * @param {Extent} [opt_extent] Destination extent.\n * @private\n * @return {Extent} Extent.\n */\nfunction _boundingExtentXYs(xs, ys, opt_extent) {\n var minX = Math.min.apply(null, xs);\n var minY = Math.min.apply(null, ys);\n var maxX = Math.max.apply(null, xs);\n var maxY = Math.max.apply(null, ys);\n return createOrUpdate(minX, minY, maxX, maxY, opt_extent);\n}\n/**\n * Return extent increased by the provided value.\n * @param {Extent} extent Extent.\n * @param {number} value The amount by which the extent should be buffered.\n * @param {Extent} [opt_extent] Extent.\n * @return {Extent} Extent.\n * @api\n */\nexport function buffer(extent, value, opt_extent) {\n if (opt_extent) {\n opt_extent[0] = extent[0] - value;\n opt_extent[1] = extent[1] - value;\n opt_extent[2] = extent[2] + value;\n opt_extent[3] = extent[3] + value;\n return opt_extent;\n }\n else {\n return [\n extent[0] - value,\n extent[1] - value,\n extent[2] + value,\n extent[3] + value,\n ];\n }\n}\n/**\n * Creates a clone of an extent.\n *\n * @param {Extent} extent Extent to clone.\n * @param {Extent} [opt_extent] Extent.\n * @return {Extent} The clone.\n */\nexport function clone(extent, opt_extent) {\n if (opt_extent) {\n opt_extent[0] = extent[0];\n opt_extent[1] = extent[1];\n opt_extent[2] = extent[2];\n opt_extent[3] = extent[3];\n return opt_extent;\n }\n else {\n return extent.slice();\n }\n}\n/**\n * @param {Extent} extent Extent.\n * @param {number} x X.\n * @param {number} y Y.\n * @return {number} Closest squared distance.\n */\nexport function closestSquaredDistanceXY(extent, x, y) {\n var dx, dy;\n if (x < extent[0]) {\n dx = extent[0] - x;\n }\n else if (extent[2] < x) {\n dx = x - extent[2];\n }\n else {\n dx = 0;\n }\n if (y < extent[1]) {\n dy = extent[1] - y;\n }\n else if (extent[3] < y) {\n dy = y - extent[3];\n }\n else {\n dy = 0;\n }\n return dx * dx + dy * dy;\n}\n/**\n * Check if the passed coordinate is contained or on the edge of the extent.\n *\n * @param {Extent} extent Extent.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n * @return {boolean} The coordinate is contained in the extent.\n * @api\n */\nexport function containsCoordinate(extent, coordinate) {\n return containsXY(extent, coordinate[0], coordinate[1]);\n}\n/**\n * Check if one extent contains another.\n *\n * An extent is deemed contained if it lies completely within the other extent,\n * including if they share one or more edges.\n *\n * @param {Extent} extent1 Extent 1.\n * @param {Extent} extent2 Extent 2.\n * @return {boolean} The second extent is contained by or on the edge of the\n * first.\n * @api\n */\nexport function containsExtent(extent1, extent2) {\n return (extent1[0] <= extent2[0] &&\n extent2[2] <= extent1[2] &&\n extent1[1] <= extent2[1] &&\n extent2[3] <= extent1[3]);\n}\n/**\n * Check if the passed coordinate is contained or on the edge of the extent.\n *\n * @param {Extent} extent Extent.\n * @param {number} x X coordinate.\n * @param {number} y Y coordinate.\n * @return {boolean} The x, y values are contained in the extent.\n * @api\n */\nexport function containsXY(extent, x, y) {\n return extent[0] <= x && x <= extent[2] && extent[1] <= y && y <= extent[3];\n}\n/**\n * Get the relationship between a coordinate and extent.\n * @param {Extent} extent The extent.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate The coordinate.\n * @return {import(\"./extent/Relationship.js\").default} The relationship (bitwise compare with\n * import(\"./extent/Relationship.js\").Relationship).\n */\nexport function coordinateRelationship(extent, coordinate) {\n var minX = extent[0];\n var minY = extent[1];\n var maxX = extent[2];\n var maxY = extent[3];\n var x = coordinate[0];\n var y = coordinate[1];\n var relationship = Relationship.UNKNOWN;\n if (x < minX) {\n relationship = relationship | Relationship.LEFT;\n }\n else if (x > maxX) {\n relationship = relationship | Relationship.RIGHT;\n }\n if (y < minY) {\n relationship = relationship | Relationship.BELOW;\n }\n else if (y > maxY) {\n relationship = relationship | Relationship.ABOVE;\n }\n if (relationship === Relationship.UNKNOWN) {\n relationship = Relationship.INTERSECTING;\n }\n return relationship;\n}\n/**\n * Create an empty extent.\n * @return {Extent} Empty extent.\n * @api\n */\nexport function createEmpty() {\n return [Infinity, Infinity, -Infinity, -Infinity];\n}\n/**\n * Create a new extent or update the provided extent.\n * @param {number} minX Minimum X.\n * @param {number} minY Minimum Y.\n * @param {number} maxX Maximum X.\n * @param {number} maxY Maximum Y.\n * @param {Extent} [opt_extent] Destination extent.\n * @return {Extent} Extent.\n */\nexport function createOrUpdate(minX, minY, maxX, maxY, opt_extent) {\n if (opt_extent) {\n opt_extent[0] = minX;\n opt_extent[1] = minY;\n opt_extent[2] = maxX;\n opt_extent[3] = maxY;\n return opt_extent;\n }\n else {\n return [minX, minY, maxX, maxY];\n }\n}\n/**\n * Create a new empty extent or make the provided one empty.\n * @param {Extent} [opt_extent] Extent.\n * @return {Extent} Extent.\n */\nexport function createOrUpdateEmpty(opt_extent) {\n return createOrUpdate(Infinity, Infinity, -Infinity, -Infinity, opt_extent);\n}\n/**\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {Extent} [opt_extent] Extent.\n * @return {Extent} Extent.\n */\nexport function createOrUpdateFromCoordinate(coordinate, opt_extent) {\n var x = coordinate[0];\n var y = coordinate[1];\n return createOrUpdate(x, y, x, y, opt_extent);\n}\n/**\n * @param {Array<import(\"./coordinate.js\").Coordinate>} coordinates Coordinates.\n * @param {Extent} [opt_extent] Extent.\n * @return {Extent} Extent.\n */\nexport function createOrUpdateFromCoordinates(coordinates, opt_extent) {\n var extent = createOrUpdateEmpty(opt_extent);\n return extendCoordinates(extent, coordinates);\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {Extent} [opt_extent] Extent.\n * @return {Extent} Extent.\n */\nexport function createOrUpdateFromFlatCoordinates(flatCoordinates, offset, end, stride, opt_extent) {\n var extent = createOrUpdateEmpty(opt_extent);\n return extendFlatCoordinates(extent, flatCoordinates, offset, end, stride);\n}\n/**\n * @param {Array<Array<import(\"./coordinate.js\").Coordinate>>} rings Rings.\n * @param {Extent} [opt_extent] Extent.\n * @return {Extent} Extent.\n */\nexport function createOrUpdateFromRings(rings, opt_extent) {\n var extent = createOrUpdateEmpty(opt_extent);\n return extendRings(extent, rings);\n}\n/**\n * Determine if two extents are equivalent.\n * @param {Extent} extent1 Extent 1.\n * @param {Extent} extent2 Extent 2.\n * @return {boolean} The two extents are equivalent.\n * @api\n */\nexport function equals(extent1, extent2) {\n return (extent1[0] == extent2[0] &&\n extent1[2] == extent2[2] &&\n extent1[1] == extent2[1] &&\n extent1[3] == extent2[3]);\n}\n/**\n * Determine if two extents are approximately equivalent.\n * @param {Extent} extent1 Extent 1.\n * @param {Extent} extent2 Extent 2.\n * @param {number} tolerance Tolerance in extent coordinate units.\n * @return {boolean} The two extents differ by less than the tolerance.\n */\nexport function approximatelyEquals(extent1, extent2, tolerance) {\n return (Math.abs(extent1[0] - extent2[0]) < tolerance &&\n Math.abs(extent1[2] - extent2[2]) < tolerance &&\n Math.abs(extent1[1] - extent2[1]) < tolerance &&\n Math.abs(extent1[3] - extent2[3]) < tolerance);\n}\n/**\n * Modify an extent to include another extent.\n * @param {Extent} extent1 The extent to be modified.\n * @param {Extent} extent2 The extent that will be included in the first.\n * @return {Extent} A reference to the first (extended) extent.\n * @api\n */\nexport function extend(extent1, extent2) {\n if (extent2[0] < extent1[0]) {\n extent1[0] = extent2[0];\n }\n if (extent2[2] > extent1[2]) {\n extent1[2] = extent2[2];\n }\n if (extent2[1] < extent1[1]) {\n extent1[1] = extent2[1];\n }\n if (extent2[3] > extent1[3]) {\n extent1[3] = extent2[3];\n }\n return extent1;\n}\n/**\n * @param {Extent} extent Extent.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n */\nexport function extendCoordinate(extent, coordinate) {\n if (coordinate[0] < extent[0]) {\n extent[0] = coordinate[0];\n }\n if (coordinate[0] > extent[2]) {\n extent[2] = coordinate[0];\n }\n if (coordinate[1] < extent[1]) {\n extent[1] = coordinate[1];\n }\n if (coordinate[1] > extent[3]) {\n extent[3] = coordinate[1];\n }\n}\n/**\n * @param {Extent} extent Extent.\n * @param {Array<import(\"./coordinate.js\").Coordinate>} coordinates Coordinates.\n * @return {Extent} Extent.\n */\nexport function extendCoordinates(extent, coordinates) {\n for (var i = 0, ii = coordinates.length; i < ii; ++i) {\n extendCoordinate(extent, coordinates[i]);\n }\n return extent;\n}\n/**\n * @param {Extent} extent Extent.\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @return {Extent} Extent.\n */\nexport function extendFlatCoordinates(extent, flatCoordinates, offset, end, stride) {\n for (; offset < end; offset += stride) {\n extendXY(extent, flatCoordinates[offset], flatCoordinates[offset + 1]);\n }\n return extent;\n}\n/**\n * @param {Extent} extent Extent.\n * @param {Array<Array<import(\"./coordinate.js\").Coordinate>>} rings Rings.\n * @return {Extent} Extent.\n */\nexport function extendRings(extent, rings) {\n for (var i = 0, ii = rings.length; i < ii; ++i) {\n extendCoordinates(extent, rings[i]);\n }\n return extent;\n}\n/**\n * @param {Extent} extent Extent.\n * @param {number} x X.\n * @param {number} y Y.\n */\nexport function extendXY(extent, x, y) {\n extent[0] = Math.min(extent[0], x);\n extent[1] = Math.min(extent[1], y);\n extent[2] = Math.max(extent[2], x);\n extent[3] = Math.max(extent[3], y);\n}\n/**\n * This function calls `callback` for each corner of the extent. If the\n * callback returns a truthy value the function returns that value\n * immediately. Otherwise the function returns `false`.\n * @param {Extent} extent Extent.\n * @param {function(import(\"./coordinate.js\").Coordinate): S} callback Callback.\n * @return {S|boolean} Value.\n * @template S\n */\nexport function forEachCorner(extent, callback) {\n var val;\n val = callback(getBottomLeft(extent));\n if (val) {\n return val;\n }\n val = callback(getBottomRight(extent));\n if (val) {\n return val;\n }\n val = callback(getTopRight(extent));\n if (val) {\n return val;\n }\n val = callback(getTopLeft(extent));\n if (val) {\n return val;\n }\n return false;\n}\n/**\n * Get the size of an extent.\n * @param {Extent} extent Extent.\n * @return {number} Area.\n * @api\n */\nexport function getArea(extent) {\n var area = 0;\n if (!isEmpty(extent)) {\n area = getWidth(extent) * getHeight(extent);\n }\n return area;\n}\n/**\n * Get the bottom left coordinate of an extent.\n * @param {Extent} extent Extent.\n * @return {import(\"./coordinate.js\").Coordinate} Bottom left coordinate.\n * @api\n */\nexport function getBottomLeft(extent) {\n return [extent[0], extent[1]];\n}\n/**\n * Get the bottom right coordinate of an extent.\n * @param {Extent} extent Extent.\n * @return {import(\"./coordinate.js\").Coordinate} Bottom right coordinate.\n * @api\n */\nexport function getBottomRight(extent) {\n return [extent[2], extent[1]];\n}\n/**\n * Get the center coordinate of an extent.\n * @param {Extent} extent Extent.\n * @return {import(\"./coordinate.js\").Coordinate} Center.\n * @api\n */\nexport function getCenter(extent) {\n return [(extent[0] + extent[2]) / 2, (extent[1] + extent[3]) / 2];\n}\n/**\n * Get a corner coordinate of an extent.\n * @param {Extent} extent Extent.\n * @param {import(\"./extent/Corner.js\").default} corner Corner.\n * @return {import(\"./coordinate.js\").Coordinate} Corner coordinate.\n */\nexport function getCorner(extent, corner) {\n var coordinate;\n if (corner === Corner.BOTTOM_LEFT) {\n coordinate = getBottomLeft(extent);\n }\n else if (corner === Corner.BOTTOM_RIGHT) {\n coordinate = getBottomRight(extent);\n }\n else if (corner === Corner.TOP_LEFT) {\n coordinate = getTopLeft(extent);\n }\n else if (corner === Corner.TOP_RIGHT) {\n coordinate = getTopRight(extent);\n }\n else {\n assert(false, 13); // Invalid corner\n }\n return coordinate;\n}\n/**\n * @param {Extent} extent1 Extent 1.\n * @param {Extent} extent2 Extent 2.\n * @return {number} Enlarged area.\n */\nexport function getEnlargedArea(extent1, extent2) {\n var minX = Math.min(extent1[0], extent2[0]);\n var minY = Math.min(extent1[1], extent2[1]);\n var maxX = Math.max(extent1[2], extent2[2]);\n var maxY = Math.max(extent1[3], extent2[3]);\n return (maxX - minX) * (maxY - minY);\n}\n/**\n * @param {import(\"./coordinate.js\").Coordinate} center Center.\n * @param {number} resolution Resolution.\n * @param {number} rotation Rotation.\n * @param {import(\"./size.js\").Size} size Size.\n * @param {Extent} [opt_extent] Destination extent.\n * @return {Extent} Extent.\n */\nexport function getForViewAndSize(center, resolution, rotation, size, opt_extent) {\n var dx = (resolution * size[0]) / 2;\n var dy = (resolution * size[1]) / 2;\n var cosRotation = Math.cos(rotation);\n var sinRotation = Math.sin(rotation);\n var xCos = dx * cosRotation;\n var xSin = dx * sinRotation;\n var yCos = dy * cosRotation;\n var ySin = dy * sinRotation;\n var x = center[0];\n var y = center[1];\n var x0 = x - xCos + ySin;\n var x1 = x - xCos - ySin;\n var x2 = x + xCos - ySin;\n var x3 = x + xCos + ySin;\n var y0 = y - xSin - yCos;\n var y1 = y - xSin + yCos;\n var y2 = y + xSin + yCos;\n var y3 = y + xSin - yCos;\n return createOrUpdate(Math.min(x0, x1, x2, x3), Math.min(y0, y1, y2, y3), Math.max(x0, x1, x2, x3), Math.max(y0, y1, y2, y3), opt_extent);\n}\n/**\n * Get the height of an extent.\n * @param {Extent} extent Extent.\n * @return {number} Height.\n * @api\n */\nexport function getHeight(extent) {\n return extent[3] - extent[1];\n}\n/**\n * @param {Extent} extent1 Extent 1.\n * @param {Extent} extent2 Extent 2.\n * @return {number} Intersection area.\n */\nexport function getIntersectionArea(extent1, extent2) {\n var intersection = getIntersection(extent1, extent2);\n return getArea(intersection);\n}\n/**\n * Get the intersection of two extents.\n * @param {Extent} extent1 Extent 1.\n * @param {Extent} extent2 Extent 2.\n * @param {Extent} [opt_extent] Optional extent to populate with intersection.\n * @return {Extent} Intersecting extent.\n * @api\n */\nexport function getIntersection(extent1, extent2, opt_extent) {\n var intersection = opt_extent ? opt_extent : createEmpty();\n if (intersects(extent1, extent2)) {\n if (extent1[0] > extent2[0]) {\n intersection[0] = extent1[0];\n }\n else {\n intersection[0] = extent2[0];\n }\n if (extent1[1] > extent2[1]) {\n intersection[1] = extent1[1];\n }\n else {\n intersection[1] = extent2[1];\n }\n if (extent1[2] < extent2[2]) {\n intersection[2] = extent1[2];\n }\n else {\n intersection[2] = extent2[2];\n }\n if (extent1[3] < extent2[3]) {\n intersection[3] = extent1[3];\n }\n else {\n intersection[3] = extent2[3];\n }\n }\n else {\n createOrUpdateEmpty(intersection);\n }\n return intersection;\n}\n/**\n * @param {Extent} extent Extent.\n * @return {number} Margin.\n */\nexport function getMargin(extent) {\n return getWidth(extent) + getHeight(extent);\n}\n/**\n * Get the size (width, height) of an extent.\n * @param {Extent} extent The extent.\n * @return {import(\"./size.js\").Size} The extent size.\n * @api\n */\nexport function getSize(extent) {\n return [extent[2] - extent[0], extent[3] - extent[1]];\n}\n/**\n * Get the top left coordinate of an extent.\n * @param {Extent} extent Extent.\n * @return {import(\"./coordinate.js\").Coordinate} Top left coordinate.\n * @api\n */\nexport function getTopLeft(extent) {\n return [extent[0], extent[3]];\n}\n/**\n * Get the top right coordinate of an extent.\n * @param {Extent} extent Extent.\n * @return {import(\"./coordinate.js\").Coordinate} Top right coordinate.\n * @api\n */\nexport function getTopRight(extent) {\n return [extent[2], extent[3]];\n}\n/**\n * Get the width of an extent.\n * @param {Extent} extent Extent.\n * @return {number} Width.\n * @api\n */\nexport function getWidth(extent) {\n return extent[2] - extent[0];\n}\n/**\n * Determine if one extent intersects another.\n * @param {Extent} extent1 Extent 1.\n * @param {Extent} extent2 Extent.\n * @return {boolean} The two extents intersect.\n * @api\n */\nexport function intersects(extent1, extent2) {\n return (extent1[0] <= extent2[2] &&\n extent1[2] >= extent2[0] &&\n extent1[1] <= extent2[3] &&\n extent1[3] >= extent2[1]);\n}\n/**\n * Determine if an extent is empty.\n * @param {Extent} extent Extent.\n * @return {boolean} Is empty.\n * @api\n */\nexport function isEmpty(extent) {\n return extent[2] < extent[0] || extent[3] < extent[1];\n}\n/**\n * @param {Extent} extent Extent.\n * @param {Extent} [opt_extent] Extent.\n * @return {Extent} Extent.\n */\nexport function returnOrUpdate(extent, opt_extent) {\n if (opt_extent) {\n opt_extent[0] = extent[0];\n opt_extent[1] = extent[1];\n opt_extent[2] = extent[2];\n opt_extent[3] = extent[3];\n return opt_extent;\n }\n else {\n return extent;\n }\n}\n/**\n * @param {Extent} extent Extent.\n * @param {number} value Value.\n */\nexport function scaleFromCenter(extent, value) {\n var deltaX = ((extent[2] - extent[0]) / 2) * (value - 1);\n var deltaY = ((extent[3] - extent[1]) / 2) * (value - 1);\n extent[0] -= deltaX;\n extent[2] += deltaX;\n extent[1] -= deltaY;\n extent[3] += deltaY;\n}\n/**\n * Determine if the segment between two coordinates intersects (crosses,\n * touches, or is contained by) the provided extent.\n * @param {Extent} extent The extent.\n * @param {import(\"./coordinate.js\").Coordinate} start Segment start coordinate.\n * @param {import(\"./coordinate.js\").Coordinate} end Segment end coordinate.\n * @return {boolean} The segment intersects the extent.\n */\nexport function intersectsSegment(extent, start, end) {\n var intersects = false;\n var startRel = coordinateRelationship(extent, start);\n var endRel = coordinateRelationship(extent, end);\n if (startRel === Relationship.INTERSECTING ||\n endRel === Relationship.INTERSECTING) {\n intersects = true;\n }\n else {\n var minX = extent[0];\n var minY = extent[1];\n var maxX = extent[2];\n var maxY = extent[3];\n var startX = start[0];\n var startY = start[1];\n var endX = end[0];\n var endY = end[1];\n var slope = (endY - startY) / (endX - startX);\n var x = void 0, y = void 0;\n if (!!(endRel & Relationship.ABOVE) && !(startRel & Relationship.ABOVE)) {\n // potentially intersects top\n x = endX - (endY - maxY) / slope;\n intersects = x >= minX && x <= maxX;\n }\n if (!intersects &&\n !!(endRel & Relationship.RIGHT) &&\n !(startRel & Relationship.RIGHT)) {\n // potentially intersects right\n y = endY - (endX - maxX) * slope;\n intersects = y >= minY && y <= maxY;\n }\n if (!intersects &&\n !!(endRel & Relationship.BELOW) &&\n !(startRel & Relationship.BELOW)) {\n // potentially intersects bottom\n x = endX - (endY - minY) / slope;\n intersects = x >= minX && x <= maxX;\n }\n if (!intersects &&\n !!(endRel & Relationship.LEFT) &&\n !(startRel & Relationship.LEFT)) {\n // potentially intersects left\n y = endY - (endX - minX) * slope;\n intersects = y >= minY && y <= maxY;\n }\n }\n return intersects;\n}\n/**\n * Apply a transform function to the extent.\n * @param {Extent} extent Extent.\n * @param {import(\"./proj.js\").TransformFunction} transformFn Transform function.\n * Called with `[minX, minY, maxX, maxY]` extent coordinates.\n * @param {Extent} [opt_extent] Destination extent.\n * @param {number} [opt_stops] Number of stops per side used for the transform.\n * By default only the corners are used.\n * @return {Extent} Extent.\n * @api\n */\nexport function applyTransform(extent, transformFn, opt_extent, opt_stops) {\n var coordinates = [];\n if (opt_stops > 1) {\n var width = extent[2] - extent[0];\n var height = extent[3] - extent[1];\n for (var i = 0; i < opt_stops; ++i) {\n coordinates.push(extent[0] + (width * i) / opt_stops, extent[1], extent[2], extent[1] + (height * i) / opt_stops, extent[2] - (width * i) / opt_stops, extent[3], extent[0], extent[3] - (height * i) / opt_stops);\n }\n }\n else {\n coordinates = [\n extent[0],\n extent[1],\n extent[2],\n extent[1],\n extent[2],\n extent[3],\n extent[0],\n extent[3],\n ];\n }\n transformFn(coordinates, coordinates, 2);\n var xs = [];\n var ys = [];\n for (var i = 0, l = coordinates.length; i < l; i += 2) {\n xs.push(coordinates[i]);\n ys.push(coordinates[i + 1]);\n }\n return _boundingExtentXYs(xs, ys, opt_extent);\n}\n/**\n * Modifies the provided extent in-place to be within the real world\n * extent.\n *\n * @param {Extent} extent Extent.\n * @param {import(\"./proj/Projection.js\").default} projection Projection\n * @return {Extent} The extent within the real world extent.\n */\nexport function wrapX(extent, projection) {\n var projectionExtent = projection.getExtent();\n var center = getCenter(extent);\n if (projection.canWrapX() &&\n (center[0] < projectionExtent[0] || center[0] >= projectionExtent[2])) {\n var worldWidth = getWidth(projectionExtent);\n var worldsAway = Math.floor((center[0] - projectionExtent[0]) / worldWidth);\n var offset = worldsAway * worldWidth;\n extent[0] -= offset;\n extent[2] -= offset;\n }\n return extent;\n}\n//# sourceMappingURL=extent.js.map","/**\n * @module ol/sphere\n */\nimport GeometryType from './geom/GeometryType.js';\nimport { toDegrees, toRadians } from './math.js';\n/**\n * Object literal with options for the {@link getLength} or {@link getArea}\n * functions.\n * @typedef {Object} SphereMetricOptions\n * @property {import(\"./proj.js\").ProjectionLike} [projection='EPSG:3857']\n * Projection of the geometry. By default, the geometry is assumed to be in\n * Web Mercator.\n * @property {number} [radius=6371008.8] Sphere radius. By default, the\n * [mean Earth radius](https://en.wikipedia.org/wiki/Earth_radius#Mean_radius)\n * for the WGS84 ellipsoid is used.\n */\n/**\n * The mean Earth radius (1/3 * (2a + b)) for the WGS84 ellipsoid.\n * https://en.wikipedia.org/wiki/Earth_radius#Mean_radius\n * @type {number}\n */\nexport var DEFAULT_RADIUS = 6371008.8;\n/**\n * Get the great circle distance (in meters) between two geographic coordinates.\n * @param {Array} c1 Starting coordinate.\n * @param {Array} c2 Ending coordinate.\n * @param {number} [opt_radius] The sphere radius to use. Defaults to the Earth's\n * mean radius using the WGS84 ellipsoid.\n * @return {number} The great circle distance between the points (in meters).\n * @api\n */\nexport function getDistance(c1, c2, opt_radius) {\n var radius = opt_radius || DEFAULT_RADIUS;\n var lat1 = toRadians(c1[1]);\n var lat2 = toRadians(c2[1]);\n var deltaLatBy2 = (lat2 - lat1) / 2;\n var deltaLonBy2 = toRadians(c2[0] - c1[0]) / 2;\n var a = Math.sin(deltaLatBy2) * Math.sin(deltaLatBy2) +\n Math.sin(deltaLonBy2) *\n Math.sin(deltaLonBy2) *\n Math.cos(lat1) *\n Math.cos(lat2);\n return 2 * radius * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));\n}\n/**\n * Get the cumulative great circle length of linestring coordinates (geographic).\n * @param {Array} coordinates Linestring coordinates.\n * @param {number} radius The sphere radius to use.\n * @return {number} The length (in meters).\n */\nfunction getLengthInternal(coordinates, radius) {\n var length = 0;\n for (var i = 0, ii = coordinates.length; i < ii - 1; ++i) {\n length += getDistance(coordinates[i], coordinates[i + 1], radius);\n }\n return length;\n}\n/**\n * Get the spherical length of a geometry. This length is the sum of the\n * great circle distances between coordinates. For polygons, the length is\n * the sum of all rings. For points, the length is zero. For multi-part\n * geometries, the length is the sum of the length of each part.\n * @param {import(\"./geom/Geometry.js\").default} geometry A geometry.\n * @param {SphereMetricOptions} [opt_options] Options for the\n * length calculation. By default, geometries are assumed to be in 'EPSG:3857'.\n * You can change this by providing a `projection` option.\n * @return {number} The spherical length (in meters).\n * @api\n */\nexport function getLength(geometry, opt_options) {\n var options = opt_options || {};\n var radius = options.radius || DEFAULT_RADIUS;\n var projection = options.projection || 'EPSG:3857';\n var type = geometry.getType();\n if (type !== GeometryType.GEOMETRY_COLLECTION) {\n geometry = geometry.clone().transform(projection, 'EPSG:4326');\n }\n var length = 0;\n var coordinates, coords, i, ii, j, jj;\n switch (type) {\n case GeometryType.POINT:\n case GeometryType.MULTI_POINT: {\n break;\n }\n case GeometryType.LINE_STRING:\n case GeometryType.LINEAR_RING: {\n coordinates = /** @type {import(\"./geom/SimpleGeometry.js\").default} */ (geometry).getCoordinates();\n length = getLengthInternal(coordinates, radius);\n break;\n }\n case GeometryType.MULTI_LINE_STRING:\n case GeometryType.POLYGON: {\n coordinates = /** @type {import(\"./geom/SimpleGeometry.js\").default} */ (geometry).getCoordinates();\n for (i = 0, ii = coordinates.length; i < ii; ++i) {\n length += getLengthInternal(coordinates[i], radius);\n }\n break;\n }\n case GeometryType.MULTI_POLYGON: {\n coordinates = /** @type {import(\"./geom/SimpleGeometry.js\").default} */ (geometry).getCoordinates();\n for (i = 0, ii = coordinates.length; i < ii; ++i) {\n coords = coordinates[i];\n for (j = 0, jj = coords.length; j < jj; ++j) {\n length += getLengthInternal(coords[j], radius);\n }\n }\n break;\n }\n case GeometryType.GEOMETRY_COLLECTION: {\n var geometries = \n /** @type {import(\"./geom/GeometryCollection.js\").default} */ (geometry).getGeometries();\n for (i = 0, ii = geometries.length; i < ii; ++i) {\n length += getLength(geometries[i], opt_options);\n }\n break;\n }\n default: {\n throw new Error('Unsupported geometry type: ' + type);\n }\n }\n return length;\n}\n/**\n * Returns the spherical area for a list of coordinates.\n *\n * [Reference](https://trs.jpl.nasa.gov/handle/2014/40409)\n * Robert. G. Chamberlain and William H. Duquette, \"Some Algorithms for\n * Polygons on a Sphere\", JPL Publication 07-03, Jet Propulsion\n * Laboratory, Pasadena, CA, June 2007\n *\n * @param {Array<import(\"./coordinate.js\").Coordinate>} coordinates List of coordinates of a linear\n * ring. If the ring is oriented clockwise, the area will be positive,\n * otherwise it will be negative.\n * @param {number} radius The sphere radius.\n * @return {number} Area (in square meters).\n */\nfunction getAreaInternal(coordinates, radius) {\n var area = 0;\n var len = coordinates.length;\n var x1 = coordinates[len - 1][0];\n var y1 = coordinates[len - 1][1];\n for (var i = 0; i < len; i++) {\n var x2 = coordinates[i][0];\n var y2 = coordinates[i][1];\n area +=\n toRadians(x2 - x1) *\n (2 + Math.sin(toRadians(y1)) + Math.sin(toRadians(y2)));\n x1 = x2;\n y1 = y2;\n }\n return (area * radius * radius) / 2.0;\n}\n/**\n * Get the spherical area of a geometry. This is the area (in meters) assuming\n * that polygon edges are segments of great circles on a sphere.\n * @param {import(\"./geom/Geometry.js\").default} geometry A geometry.\n * @param {SphereMetricOptions} [opt_options] Options for the area\n * calculation. By default, geometries are assumed to be in 'EPSG:3857'.\n * You can change this by providing a `projection` option.\n * @return {number} The spherical area (in square meters).\n * @api\n */\nexport function getArea(geometry, opt_options) {\n var options = opt_options || {};\n var radius = options.radius || DEFAULT_RADIUS;\n var projection = options.projection || 'EPSG:3857';\n var type = geometry.getType();\n if (type !== GeometryType.GEOMETRY_COLLECTION) {\n geometry = geometry.clone().transform(projection, 'EPSG:4326');\n }\n var area = 0;\n var coordinates, coords, i, ii, j, jj;\n switch (type) {\n case GeometryType.POINT:\n case GeometryType.MULTI_POINT:\n case GeometryType.LINE_STRING:\n case GeometryType.MULTI_LINE_STRING:\n case GeometryType.LINEAR_RING: {\n break;\n }\n case GeometryType.POLYGON: {\n coordinates = /** @type {import(\"./geom/Polygon.js\").default} */ (geometry).getCoordinates();\n area = Math.abs(getAreaInternal(coordinates[0], radius));\n for (i = 1, ii = coordinates.length; i < ii; ++i) {\n area -= Math.abs(getAreaInternal(coordinates[i], radius));\n }\n break;\n }\n case GeometryType.MULTI_POLYGON: {\n coordinates = /** @type {import(\"./geom/SimpleGeometry.js\").default} */ (geometry).getCoordinates();\n for (i = 0, ii = coordinates.length; i < ii; ++i) {\n coords = coordinates[i];\n area += Math.abs(getAreaInternal(coords[0], radius));\n for (j = 1, jj = coords.length; j < jj; ++j) {\n area -= Math.abs(getAreaInternal(coords[j], radius));\n }\n }\n break;\n }\n case GeometryType.GEOMETRY_COLLECTION: {\n var geometries = \n /** @type {import(\"./geom/GeometryCollection.js\").default} */ (geometry).getGeometries();\n for (i = 0, ii = geometries.length; i < ii; ++i) {\n area += getArea(geometries[i], opt_options);\n }\n break;\n }\n default: {\n throw new Error('Unsupported geometry type: ' + type);\n }\n }\n return area;\n}\n/**\n * Returns the coordinate at the given distance and bearing from `c1`.\n *\n * @param {import(\"./coordinate.js\").Coordinate} c1 The origin point (`[lon, lat]` in degrees).\n * @param {number} distance The great-circle distance between the origin\n * point and the target point.\n * @param {number} bearing The bearing (in radians).\n * @param {number} [opt_radius] The sphere radius to use. Defaults to the Earth's\n * mean radius using the WGS84 ellipsoid.\n * @return {import(\"./coordinate.js\").Coordinate} The target point.\n */\nexport function offset(c1, distance, bearing, opt_radius) {\n var radius = opt_radius || DEFAULT_RADIUS;\n var lat1 = toRadians(c1[1]);\n var lon1 = toRadians(c1[0]);\n var dByR = distance / radius;\n var lat = Math.asin(Math.sin(lat1) * Math.cos(dByR) +\n Math.cos(lat1) * Math.sin(dByR) * Math.cos(bearing));\n var lon = lon1 +\n Math.atan2(Math.sin(bearing) * Math.sin(dByR) * Math.cos(lat1), Math.cos(dByR) - Math.sin(lat1) * Math.sin(lat));\n return [toDegrees(lon), toDegrees(lat)];\n}\n//# sourceMappingURL=sphere.js.map","/**\n * @module ol/proj\n */\n/**\n * The ol/proj module stores:\n * * a list of {@link module:ol/proj/Projection}\n * objects, one for each projection supported by the application\n * * a list of transform functions needed to convert coordinates in one projection\n * into another.\n *\n * The static functions are the methods used to maintain these.\n * Each transform function can handle not only simple coordinate pairs, but also\n * large arrays of coordinates such as vector geometries.\n *\n * When loaded, the library adds projection objects for EPSG:4326 (WGS84\n * geographic coordinates) and EPSG:3857 (Web or Spherical Mercator, as used\n * for example by Bing Maps or OpenStreetMap), together with the relevant\n * transform functions.\n *\n * Additional transforms may be added by using the http://proj4js.org/\n * library (version 2.2 or later). You can use the full build supplied by\n * Proj4js, or create a custom build to support those projections you need; see\n * the Proj4js website for how to do this. You also need the Proj4js definitions\n * for the required projections. These definitions can be obtained from\n * https://epsg.io/, and are a JS function, so can be loaded in a script\n * tag (as in the examples) or pasted into your application.\n *\n * After all required projection definitions are added to proj4's registry (by\n * using `proj4.defs()`), simply call `register(proj4)` from the `ol/proj/proj4`\n * package. Existing transforms are not changed by this function. See\n * examples/wms-image-custom-proj for an example of this.\n *\n * Additional projection definitions can be registered with `proj4.defs()` any\n * time. Just make sure to call `register(proj4)` again; for example, with user-supplied data where you don't\n * know in advance what projections are needed, you can initially load minimal\n * support and then load whichever are requested.\n *\n * Note that Proj4js does not support projection extents. If you want to add\n * one for creating default tile grids, you can add it after the Projection\n * object has been created with `setExtent`, for example,\n * `get('EPSG:1234').setExtent(extent)`.\n *\n * In addition to Proj4js support, any transform functions can be added with\n * {@link module:ol/proj.addCoordinateTransforms}. To use this, you must first create\n * a {@link module:ol/proj/Projection} object for the new projection and add it with\n * {@link module:ol/proj.addProjection}. You can then add the forward and inverse\n * functions with {@link module:ol/proj.addCoordinateTransforms}. See\n * examples/wms-custom-proj for an example of this.\n *\n * Note that if no transforms are needed and you only need to define the\n * projection, just add a {@link module:ol/proj/Projection} with\n * {@link module:ol/proj.addProjection}. See examples/wms-no-proj for an example of\n * this.\n */\nimport Projection from './proj/Projection.js';\nimport Units, { METERS_PER_UNIT } from './proj/Units.js';\nimport { PROJECTIONS as EPSG3857_PROJECTIONS, fromEPSG4326, toEPSG4326, } from './proj/epsg3857.js';\nimport { PROJECTIONS as EPSG4326_PROJECTIONS } from './proj/epsg4326.js';\nimport { add as addProj, clear as clearProj, get as getProj, } from './proj/projections.js';\nimport { add as addTransformFunc, clear as clearTransformFuncs, get as getTransformFunc, } from './proj/transforms.js';\nimport { applyTransform, getWidth } from './extent.js';\nimport { clamp, modulo } from './math.js';\nimport { getDistance } from './sphere.js';\nimport { getWorldsAway } from './coordinate.js';\n/**\n * A projection as {@link module:ol/proj/Projection}, SRS identifier\n * string or undefined.\n * @typedef {Projection|string|undefined} ProjectionLike\n * @api\n */\n/**\n * A transform function accepts an array of input coordinate values, an optional\n * output array, and an optional dimension (default should be 2). The function\n * transforms the input coordinate values, populates the output array, and\n * returns the output array.\n *\n * @typedef {function(Array<number>, Array<number>=, number=): Array<number>} TransformFunction\n * @api\n */\nexport { METERS_PER_UNIT };\nexport { Projection };\n/**\n * @param {Array<number>} input Input coordinate array.\n * @param {Array<number>} [opt_output] Output array of coordinate values.\n * @param {number} [opt_dimension] Dimension.\n * @return {Array<number>} Output coordinate array (new array, same coordinate\n * values).\n */\nexport function cloneTransform(input, opt_output, opt_dimension) {\n var output;\n if (opt_output !== undefined) {\n for (var i = 0, ii = input.length; i < ii; ++i) {\n opt_output[i] = input[i];\n }\n output = opt_output;\n }\n else {\n output = input.slice();\n }\n return output;\n}\n/**\n * @param {Array<number>} input Input coordinate array.\n * @param {Array<number>} [opt_output] Output array of coordinate values.\n * @param {number} [opt_dimension] Dimension.\n * @return {Array<number>} Input coordinate array (same array as input).\n */\nexport function identityTransform(input, opt_output, opt_dimension) {\n if (opt_output !== undefined && input !== opt_output) {\n for (var i = 0, ii = input.length; i < ii; ++i) {\n opt_output[i] = input[i];\n }\n input = opt_output;\n }\n return input;\n}\n/**\n * Add a Projection object to the list of supported projections that can be\n * looked up by their code.\n *\n * @param {Projection} projection Projection instance.\n * @api\n */\nexport function addProjection(projection) {\n addProj(projection.getCode(), projection);\n addTransformFunc(projection, projection, cloneTransform);\n}\n/**\n * @param {Array<Projection>} projections Projections.\n */\nexport function addProjections(projections) {\n projections.forEach(addProjection);\n}\n/**\n * Fetches a Projection object for the code specified.\n *\n * @param {ProjectionLike} projectionLike Either a code string which is\n * a combination of authority and identifier such as \"EPSG:4326\", or an\n * existing projection object, or undefined.\n * @return {Projection} Projection object, or null if not in list.\n * @api\n */\nexport function get(projectionLike) {\n return typeof projectionLike === 'string'\n ? getProj(/** @type {string} */ (projectionLike))\n : /** @type {Projection} */ (projectionLike) || null;\n}\n/**\n * Get the resolution of the point in degrees or distance units.\n * For projections with degrees as the unit this will simply return the\n * provided resolution. For other projections the point resolution is\n * by default estimated by transforming the 'point' pixel to EPSG:4326,\n * measuring its width and height on the normal sphere,\n * and taking the average of the width and height.\n * A custom function can be provided for a specific projection, either\n * by setting the `getPointResolution` option in the\n * {@link module:ol/proj/Projection~Projection} constructor or by using\n * {@link module:ol/proj/Projection~Projection#setGetPointResolution} to change an existing\n * projection object.\n * @param {ProjectionLike} projection The projection.\n * @param {number} resolution Nominal resolution in projection units.\n * @param {import(\"./coordinate.js\").Coordinate} point Point to find adjusted resolution at.\n * @param {import(\"./proj/Units.js\").default} [opt_units] Units to get the point resolution in.\n * Default is the projection's units.\n * @return {number} Point resolution.\n * @api\n */\nexport function getPointResolution(projection, resolution, point, opt_units) {\n projection = get(projection);\n var pointResolution;\n var getter = projection.getPointResolutionFunc();\n if (getter) {\n pointResolution = getter(resolution, point);\n if (opt_units && opt_units !== projection.getUnits()) {\n var metersPerUnit = projection.getMetersPerUnit();\n if (metersPerUnit) {\n pointResolution =\n (pointResolution * metersPerUnit) / METERS_PER_UNIT[opt_units];\n }\n }\n }\n else {\n var units = projection.getUnits();\n if ((units == Units.DEGREES && !opt_units) || opt_units == Units.DEGREES) {\n pointResolution = resolution;\n }\n else {\n // Estimate point resolution by transforming the center pixel to EPSG:4326,\n // measuring its width and height on the normal sphere, and taking the\n // average of the width and height.\n var toEPSG4326_1 = getTransformFromProjections(projection, get('EPSG:4326'));\n if (toEPSG4326_1 === identityTransform && units !== Units.DEGREES) {\n // no transform is available\n pointResolution = resolution * projection.getMetersPerUnit();\n }\n else {\n var vertices = [\n point[0] - resolution / 2,\n point[1],\n point[0] + resolution / 2,\n point[1],\n point[0],\n point[1] - resolution / 2,\n point[0],\n point[1] + resolution / 2,\n ];\n vertices = toEPSG4326_1(vertices, vertices, 2);\n var width = getDistance(vertices.slice(0, 2), vertices.slice(2, 4));\n var height = getDistance(vertices.slice(4, 6), vertices.slice(6, 8));\n pointResolution = (width + height) / 2;\n }\n var metersPerUnit = opt_units\n ? METERS_PER_UNIT[opt_units]\n : projection.getMetersPerUnit();\n if (metersPerUnit !== undefined) {\n pointResolution /= metersPerUnit;\n }\n }\n }\n return pointResolution;\n}\n/**\n * Registers transformation functions that don't alter coordinates. Those allow\n * to transform between projections with equal meaning.\n *\n * @param {Array<Projection>} projections Projections.\n * @api\n */\nexport function addEquivalentProjections(projections) {\n addProjections(projections);\n projections.forEach(function (source) {\n projections.forEach(function (destination) {\n if (source !== destination) {\n addTransformFunc(source, destination, cloneTransform);\n }\n });\n });\n}\n/**\n * Registers transformation functions to convert coordinates in any projection\n * in projection1 to any projection in projection2.\n *\n * @param {Array<Projection>} projections1 Projections with equal\n * meaning.\n * @param {Array<Projection>} projections2 Projections with equal\n * meaning.\n * @param {TransformFunction} forwardTransform Transformation from any\n * projection in projection1 to any projection in projection2.\n * @param {TransformFunction} inverseTransform Transform from any projection\n * in projection2 to any projection in projection1..\n */\nexport function addEquivalentTransforms(projections1, projections2, forwardTransform, inverseTransform) {\n projections1.forEach(function (projection1) {\n projections2.forEach(function (projection2) {\n addTransformFunc(projection1, projection2, forwardTransform);\n addTransformFunc(projection2, projection1, inverseTransform);\n });\n });\n}\n/**\n * Clear all cached projections and transforms.\n */\nexport function clearAllProjections() {\n clearProj();\n clearTransformFuncs();\n}\n/**\n * @param {Projection|string|undefined} projection Projection.\n * @param {string} defaultCode Default code.\n * @return {Projection} Projection.\n */\nexport function createProjection(projection, defaultCode) {\n if (!projection) {\n return get(defaultCode);\n }\n else if (typeof projection === 'string') {\n return get(projection);\n }\n else {\n return /** @type {Projection} */ (projection);\n }\n}\n/**\n * Creates a {@link module:ol/proj~TransformFunction} from a simple 2D coordinate transform\n * function.\n * @param {function(import(\"./coordinate.js\").Coordinate): import(\"./coordinate.js\").Coordinate} coordTransform Coordinate\n * transform.\n * @return {TransformFunction} Transform function.\n */\nexport function createTransformFromCoordinateTransform(coordTransform) {\n return (\n /**\n * @param {Array<number>} input Input.\n * @param {Array<number>} [opt_output] Output.\n * @param {number} [opt_dimension] Dimension.\n * @return {Array<number>} Output.\n */\n function (input, opt_output, opt_dimension) {\n var length = input.length;\n var dimension = opt_dimension !== undefined ? opt_dimension : 2;\n var output = opt_output !== undefined ? opt_output : new Array(length);\n for (var i = 0; i < length; i += dimension) {\n var point = coordTransform([input[i], input[i + 1]]);\n output[i] = point[0];\n output[i + 1] = point[1];\n for (var j = dimension - 1; j >= 2; --j) {\n output[i + j] = input[i + j];\n }\n }\n return output;\n });\n}\n/**\n * Registers coordinate transform functions to convert coordinates between the\n * source projection and the destination projection.\n * The forward and inverse functions convert coordinate pairs; this function\n * converts these into the functions used internally which also handle\n * extents and coordinate arrays.\n *\n * @param {ProjectionLike} source Source projection.\n * @param {ProjectionLike} destination Destination projection.\n * @param {function(import(\"./coordinate.js\").Coordinate): import(\"./coordinate.js\").Coordinate} forward The forward transform\n * function (that is, from the source projection to the destination\n * projection) that takes a {@link module:ol/coordinate~Coordinate} as argument and returns\n * the transformed {@link module:ol/coordinate~Coordinate}.\n * @param {function(import(\"./coordinate.js\").Coordinate): import(\"./coordinate.js\").Coordinate} inverse The inverse transform\n * function (that is, from the destination projection to the source\n * projection) that takes a {@link module:ol/coordinate~Coordinate} as argument and returns\n * the transformed {@link module:ol/coordinate~Coordinate}.\n * @api\n */\nexport function addCoordinateTransforms(source, destination, forward, inverse) {\n var sourceProj = get(source);\n var destProj = get(destination);\n addTransformFunc(sourceProj, destProj, createTransformFromCoordinateTransform(forward));\n addTransformFunc(destProj, sourceProj, createTransformFromCoordinateTransform(inverse));\n}\n/**\n * Transforms a coordinate from longitude/latitude to a different projection.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate as longitude and latitude, i.e.\n * an array with longitude as 1st and latitude as 2nd element.\n * @param {ProjectionLike} [opt_projection] Target projection. The\n * default is Web Mercator, i.e. 'EPSG:3857'.\n * @return {import(\"./coordinate.js\").Coordinate} Coordinate projected to the target projection.\n * @api\n */\nexport function fromLonLat(coordinate, opt_projection) {\n return transform(coordinate, 'EPSG:4326', opt_projection !== undefined ? opt_projection : 'EPSG:3857');\n}\n/**\n * Transforms a coordinate to longitude/latitude.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Projected coordinate.\n * @param {ProjectionLike} [opt_projection] Projection of the coordinate.\n * The default is Web Mercator, i.e. 'EPSG:3857'.\n * @return {import(\"./coordinate.js\").Coordinate} Coordinate as longitude and latitude, i.e. an array\n * with longitude as 1st and latitude as 2nd element.\n * @api\n */\nexport function toLonLat(coordinate, opt_projection) {\n var lonLat = transform(coordinate, opt_projection !== undefined ? opt_projection : 'EPSG:3857', 'EPSG:4326');\n var lon = lonLat[0];\n if (lon < -180 || lon > 180) {\n lonLat[0] = modulo(lon + 180, 360) - 180;\n }\n return lonLat;\n}\n/**\n * Checks if two projections are the same, that is every coordinate in one\n * projection does represent the same geographic point as the same coordinate in\n * the other projection.\n *\n * @param {Projection} projection1 Projection 1.\n * @param {Projection} projection2 Projection 2.\n * @return {boolean} Equivalent.\n * @api\n */\nexport function equivalent(projection1, projection2) {\n if (projection1 === projection2) {\n return true;\n }\n var equalUnits = projection1.getUnits() === projection2.getUnits();\n if (projection1.getCode() === projection2.getCode()) {\n return equalUnits;\n }\n else {\n var transformFunc = getTransformFromProjections(projection1, projection2);\n return transformFunc === cloneTransform && equalUnits;\n }\n}\n/**\n * Searches in the list of transform functions for the function for converting\n * coordinates from the source projection to the destination projection.\n *\n * @param {Projection} sourceProjection Source Projection object.\n * @param {Projection} destinationProjection Destination Projection\n * object.\n * @return {TransformFunction} Transform function.\n */\nexport function getTransformFromProjections(sourceProjection, destinationProjection) {\n var sourceCode = sourceProjection.getCode();\n var destinationCode = destinationProjection.getCode();\n var transformFunc = getTransformFunc(sourceCode, destinationCode);\n if (!transformFunc) {\n transformFunc = identityTransform;\n }\n return transformFunc;\n}\n/**\n * Given the projection-like objects, searches for a transformation\n * function to convert a coordinates array from the source projection to the\n * destination projection.\n *\n * @param {ProjectionLike} source Source.\n * @param {ProjectionLike} destination Destination.\n * @return {TransformFunction} Transform function.\n * @api\n */\nexport function getTransform(source, destination) {\n var sourceProjection = get(source);\n var destinationProjection = get(destination);\n return getTransformFromProjections(sourceProjection, destinationProjection);\n}\n/**\n * Transforms a coordinate from source projection to destination projection.\n * This returns a new coordinate (and does not modify the original).\n *\n * See {@link module:ol/proj.transformExtent} for extent transformation.\n * See the transform method of {@link module:ol/geom/Geometry~Geometry} and its\n * subclasses for geometry transforms.\n *\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {ProjectionLike} source Source projection-like.\n * @param {ProjectionLike} destination Destination projection-like.\n * @return {import(\"./coordinate.js\").Coordinate} Coordinate.\n * @api\n */\nexport function transform(coordinate, source, destination) {\n var transformFunc = getTransform(source, destination);\n return transformFunc(coordinate, undefined, coordinate.length);\n}\n/**\n * Transforms an extent from source projection to destination projection. This\n * returns a new extent (and does not modify the original).\n *\n * @param {import(\"./extent.js\").Extent} extent The extent to transform.\n * @param {ProjectionLike} source Source projection-like.\n * @param {ProjectionLike} destination Destination projection-like.\n * @param {number} [opt_stops] Number of stops per side used for the transform.\n * By default only the corners are used.\n * @return {import(\"./extent.js\").Extent} The transformed extent.\n * @api\n */\nexport function transformExtent(extent, source, destination, opt_stops) {\n var transformFunc = getTransform(source, destination);\n return applyTransform(extent, transformFunc, undefined, opt_stops);\n}\n/**\n * Transforms the given point to the destination projection.\n *\n * @param {import(\"./coordinate.js\").Coordinate} point Point.\n * @param {Projection} sourceProjection Source projection.\n * @param {Projection} destinationProjection Destination projection.\n * @return {import(\"./coordinate.js\").Coordinate} Point.\n */\nexport function transformWithProjections(point, sourceProjection, destinationProjection) {\n var transformFunc = getTransformFromProjections(sourceProjection, destinationProjection);\n return transformFunc(point);\n}\n/**\n * @type {?Projection}\n */\nvar userProjection = null;\n/**\n * Set the projection for coordinates supplied from and returned by API methods.\n * Note that this method is not yet a part of the stable API. Support for user\n * projections is not yet complete and should be considered experimental.\n * @param {ProjectionLike} projection The user projection.\n */\nexport function setUserProjection(projection) {\n userProjection = get(projection);\n}\n/**\n * Clear the user projection if set. Note that this method is not yet a part of\n * the stable API. Support for user projections is not yet complete and should\n * be considered experimental.\n */\nexport function clearUserProjection() {\n userProjection = null;\n}\n/**\n * Get the projection for coordinates supplied from and returned by API methods.\n * Note that this method is not yet a part of the stable API. Support for user\n * projections is not yet complete and should be considered experimental.\n * @return {?Projection} The user projection (or null if not set).\n */\nexport function getUserProjection() {\n return userProjection;\n}\n/**\n * Use geographic coordinates (WGS-84 datum) in API methods. Note that this\n * method is not yet a part of the stable API. Support for user projections is\n * not yet complete and should be considered experimental.\n */\nexport function useGeographic() {\n setUserProjection('EPSG:4326');\n}\n/**\n * Return a coordinate transformed into the user projection. If no user projection\n * is set, the original coordinate is returned.\n * @param {Array<number>} coordinate Input coordinate.\n * @param {ProjectionLike} sourceProjection The input coordinate projection.\n * @return {Array<number>} The input coordinate in the user projection.\n */\nexport function toUserCoordinate(coordinate, sourceProjection) {\n if (!userProjection) {\n return coordinate;\n }\n return transform(coordinate, sourceProjection, userProjection);\n}\n/**\n * Return a coordinate transformed from the user projection. If no user projection\n * is set, the original coordinate is returned.\n * @param {Array<number>} coordinate Input coordinate.\n * @param {ProjectionLike} destProjection The destination projection.\n * @return {Array<number>} The input coordinate transformed.\n */\nexport function fromUserCoordinate(coordinate, destProjection) {\n if (!userProjection) {\n return coordinate;\n }\n return transform(coordinate, userProjection, destProjection);\n}\n/**\n * Return an extent transformed into the user projection. If no user projection\n * is set, the original extent is returned.\n * @param {import(\"./extent.js\").Extent} extent Input extent.\n * @param {ProjectionLike} sourceProjection The input extent projection.\n * @return {import(\"./extent.js\").Extent} The input extent in the user projection.\n */\nexport function toUserExtent(extent, sourceProjection) {\n if (!userProjection) {\n return extent;\n }\n return transformExtent(extent, sourceProjection, userProjection);\n}\n/**\n * Return an extent transformed from the user projection. If no user projection\n * is set, the original extent is returned.\n * @param {import(\"./extent.js\").Extent} extent Input extent.\n * @param {ProjectionLike} destProjection The destination projection.\n * @return {import(\"./extent.js\").Extent} The input extent transformed.\n */\nexport function fromUserExtent(extent, destProjection) {\n if (!userProjection) {\n return extent;\n }\n return transformExtent(extent, userProjection, destProjection);\n}\n/**\n * Return the resolution in user projection units per pixel. If no user projection\n * is set, or source or user projection are missing units, the original resolution\n * is returned.\n * @param {number} resolution Resolution in input projection units per pixel.\n * @param {ProjectionLike} sourceProjection The input projection.\n * @return {number} Resolution in user projection units per pixel.\n */\nexport function toUserResolution(resolution, sourceProjection) {\n if (!userProjection) {\n return resolution;\n }\n var sourceUnits = get(sourceProjection).getUnits();\n var userUnits = userProjection.getUnits();\n return sourceUnits && userUnits\n ? (resolution * METERS_PER_UNIT[sourceUnits]) / METERS_PER_UNIT[userUnits]\n : resolution;\n}\n/**\n * Return the resolution in user projection units per pixel. If no user projection\n * is set, or source or user projection are missing units, the original resolution\n * is returned.\n * @param {number} resolution Resolution in user projection units per pixel.\n * @param {ProjectionLike} destProjection The destination projection.\n * @return {number} Resolution in destination projection units per pixel.\n */\nexport function fromUserResolution(resolution, destProjection) {\n if (!userProjection) {\n return resolution;\n }\n var sourceUnits = get(destProjection).getUnits();\n var userUnits = userProjection.getUnits();\n return sourceUnits && userUnits\n ? (resolution * METERS_PER_UNIT[userUnits]) / METERS_PER_UNIT[sourceUnits]\n : resolution;\n}\n/**\n * Creates a safe coordinate transform function from a coordinate transform function.\n * \"Safe\" means that it can handle wrapping of x-coordinates for global projections,\n * and that coordinates exceeding the source projection validity extent's range will be\n * clamped to the validity range.\n * @param {Projection} sourceProj Source projection.\n * @param {Projection} destProj Destination projection.\n * @param {function(import(\"./coordinate.js\").Coordinate): import(\"./coordinate.js\").Coordinate} transform Transform function (source to destiation).\n * @return {function(import(\"./coordinate.js\").Coordinate): import(\"./coordinate.js\").Coordinate} Safe transform function (source to destiation).\n */\nexport function createSafeCoordinateTransform(sourceProj, destProj, transform) {\n return function (coord) {\n var sourceX = coord[0];\n var sourceY = coord[1];\n var transformed, worldsAway;\n if (sourceProj.canWrapX()) {\n var sourceExtent = sourceProj.getExtent();\n var sourceExtentWidth = getWidth(sourceExtent);\n worldsAway = getWorldsAway(coord, sourceProj, sourceExtentWidth);\n if (worldsAway) {\n // Move x to the real world\n sourceX = sourceX - worldsAway * sourceExtentWidth;\n }\n sourceX = clamp(sourceX, sourceExtent[0], sourceExtent[2]);\n sourceY = clamp(sourceY, sourceExtent[1], sourceExtent[3]);\n transformed = transform([sourceX, sourceY]);\n }\n else {\n transformed = transform(coord);\n }\n if (worldsAway && destProj.canWrapX()) {\n // Move transformed coordinate back to the offset world\n transformed[0] += worldsAway * getWidth(destProj.getExtent());\n }\n return transformed;\n };\n}\n/**\n * Add transforms to and from EPSG:4326 and EPSG:3857. This function is called\n * by when this module is executed and should only need to be called again after\n * `clearAllProjections()` is called (e.g. in tests).\n */\nexport function addCommon() {\n // Add transformations that don't alter coordinates to convert within set of\n // projections with equal meaning.\n addEquivalentProjections(EPSG3857_PROJECTIONS);\n addEquivalentProjections(EPSG4326_PROJECTIONS);\n // Add transformations to convert EPSG:4326 like coordinates to EPSG:3857 like\n // coordinates and back.\n addEquivalentTransforms(EPSG4326_PROJECTIONS, EPSG3857_PROJECTIONS, fromEPSG4326, toEPSG4326);\n}\naddCommon();\n//# sourceMappingURL=proj.js.map","/**\n * @module ol/control/MousePosition\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport Control from './Control.js';\nimport EventType from '../pointer/EventType.js';\nimport { get as getProjection, getTransformFromProjections, getUserProjection, identityTransform, } from '../proj.js';\nimport { listen } from '../events.js';\n/**\n * @type {string}\n */\nvar PROJECTION = 'projection';\n/**\n * @type {string}\n */\nvar COORDINATE_FORMAT = 'coordinateFormat';\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n * import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types|\n * 'change:coordinateFormat'|'change:projection', import(\"../Object\").ObjectEvent, Return> &\n * import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").Types|\n * 'change:coordinateFormat'|'change:projection', Return>} MousePositionOnSignature\n */\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-mouse-position'] CSS class name.\n * @property {import(\"../coordinate.js\").CoordinateFormat} [coordinateFormat] Coordinate format.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is the view projection.\n * @property {function(import(\"../MapEvent.js\").default):void} [render] Function called when the\n * control should be re-rendered. This is called in a `requestAnimationFrame`\n * callback.\n * @property {HTMLElement|string} [target] Specify a target if you want the\n * control to be rendered outside of the map's viewport.\n * @property {string|boolean} [placeholder] Markup to show when the mouse position is not\n * available (e.g. when the pointer leaves the map viewport). By default, a non-breaking space\n * is rendered when the mouse leaves the viewport. To render something else, provide a string\n * to be used as the text content (e.g. 'no position' or '' for an empty string). Set the placeholder\n * to `false` to retain the last position when the mouse leaves the viewport. In a future release, this\n * will be the default behavior.\n * @property {string} [undefinedHTML=' '] This option is deprecated. Use the `placeholder` option instead.\n */\n/**\n * @classdesc\n * A control to show the 2D coordinates of the mouse cursor. By default, these\n * are in the view projection, but can be in any supported projection.\n * By default the control is shown in the top right corner of the map, but this\n * can be changed by using the css selector `.ol-mouse-position`.\n *\n * On touch devices, which usually do not have a mouse cursor, the coordinates\n * of the currently touched position are shown.\n *\n * @api\n */\nvar MousePosition = /** @class */ (function (_super) {\n __extends(MousePosition, _super);\n /**\n * @param {Options} [opt_options] Mouse position options.\n */\n function MousePosition(opt_options) {\n var _this = this;\n var options = opt_options ? opt_options : {};\n var element = document.createElement('div');\n element.className =\n options.className !== undefined ? options.className : 'ol-mouse-position';\n _this = _super.call(this, {\n element: element,\n render: options.render,\n target: options.target,\n }) || this;\n /***\n * @type {MousePositionOnSignature<import(\"../events\").EventsKey>}\n */\n _this.on;\n /***\n * @type {MousePositionOnSignature<import(\"../events\").EventsKey>}\n */\n _this.once;\n /***\n * @type {MousePositionOnSignature<void>}\n */\n _this.un;\n _this.addChangeListener(PROJECTION, _this.handleProjectionChanged_);\n if (options.coordinateFormat) {\n _this.setCoordinateFormat(options.coordinateFormat);\n }\n if (options.projection) {\n _this.setProjection(options.projection);\n }\n /**\n * Change this to `false` when removing the deprecated `undefinedHTML` option.\n * @type {boolean}\n */\n var renderOnMouseOut = true;\n /**\n * @type {string}\n */\n var placeholder = ' ';\n if ('undefinedHTML' in options) {\n // deprecated behavior\n if (options.undefinedHTML !== undefined) {\n placeholder = options.undefinedHTML;\n }\n renderOnMouseOut = !!placeholder;\n }\n else if ('placeholder' in options) {\n if (options.placeholder === false) {\n renderOnMouseOut = false;\n }\n else {\n placeholder = String(options.placeholder);\n }\n }\n /**\n * @private\n * @type {string}\n */\n _this.placeholder_ = placeholder;\n /**\n * @private\n * @type {boolean}\n */\n _this.renderOnMouseOut_ = renderOnMouseOut;\n /**\n * @private\n * @type {string}\n */\n _this.renderedHTML_ = element.innerHTML;\n /**\n * @private\n * @type {?import(\"../proj/Projection.js\").default}\n */\n _this.mapProjection_ = null;\n /**\n * @private\n * @type {?import(\"../proj.js\").TransformFunction}\n */\n _this.transform_ = null;\n return _this;\n }\n /**\n * @private\n */\n MousePosition.prototype.handleProjectionChanged_ = function () {\n this.transform_ = null;\n };\n /**\n * Return the coordinate format type used to render the current position or\n * undefined.\n * @return {import(\"../coordinate.js\").CoordinateFormat|undefined} The format to render the current\n * position in.\n * @observable\n * @api\n */\n MousePosition.prototype.getCoordinateFormat = function () {\n return /** @type {import(\"../coordinate.js\").CoordinateFormat|undefined} */ (this.get(COORDINATE_FORMAT));\n };\n /**\n * Return the projection that is used to report the mouse position.\n * @return {import(\"../proj/Projection.js\").default|undefined} The projection to report mouse\n * position in.\n * @observable\n * @api\n */\n MousePosition.prototype.getProjection = function () {\n return /** @type {import(\"../proj/Projection.js\").default|undefined} */ (this.get(PROJECTION));\n };\n /**\n * @param {MouseEvent} event Browser event.\n * @protected\n */\n MousePosition.prototype.handleMouseMove = function (event) {\n var map = this.getMap();\n this.updateHTML_(map.getEventPixel(event));\n };\n /**\n * @param {Event} event Browser event.\n * @protected\n */\n MousePosition.prototype.handleMouseOut = function (event) {\n this.updateHTML_(null);\n };\n /**\n * Remove the control from its current map and attach it to the new map.\n * Subclasses may set up event handlers to get notified about changes to\n * the map here.\n * @param {import(\"../PluggableMap.js\").default} map Map.\n * @api\n */\n MousePosition.prototype.setMap = function (map) {\n _super.prototype.setMap.call(this, map);\n if (map) {\n var viewport = map.getViewport();\n this.listenerKeys.push(listen(viewport, EventType.POINTERMOVE, this.handleMouseMove, this));\n if (this.renderOnMouseOut_) {\n this.listenerKeys.push(listen(viewport, EventType.POINTEROUT, this.handleMouseOut, this));\n }\n this.updateHTML_(null);\n }\n };\n /**\n * Set the coordinate format type used to render the current position.\n * @param {import(\"../coordinate.js\").CoordinateFormat} format The format to render the current\n * position in.\n * @observable\n * @api\n */\n MousePosition.prototype.setCoordinateFormat = function (format) {\n this.set(COORDINATE_FORMAT, format);\n };\n /**\n * Set the projection that is used to report the mouse position.\n * @param {import(\"../proj.js\").ProjectionLike} projection The projection to report mouse\n * position in.\n * @observable\n * @api\n */\n MousePosition.prototype.setProjection = function (projection) {\n this.set(PROJECTION, getProjection(projection));\n };\n /**\n * @param {?import(\"../pixel.js\").Pixel} pixel Pixel.\n * @private\n */\n MousePosition.prototype.updateHTML_ = function (pixel) {\n var html = this.placeholder_;\n if (pixel && this.mapProjection_) {\n if (!this.transform_) {\n var projection = this.getProjection();\n if (projection) {\n this.transform_ = getTransformFromProjections(this.mapProjection_, projection);\n }\n else {\n this.transform_ = identityTransform;\n }\n }\n var map = this.getMap();\n var coordinate = map.getCoordinateFromPixelInternal(pixel);\n if (coordinate) {\n var userProjection = getUserProjection();\n if (userProjection) {\n this.transform_ = getTransformFromProjections(this.mapProjection_, userProjection);\n }\n this.transform_(coordinate, coordinate);\n var coordinateFormat = this.getCoordinateFormat();\n if (coordinateFormat) {\n html = coordinateFormat(coordinate);\n }\n else {\n html = coordinate.toString();\n }\n }\n }\n if (!this.renderedHTML_ || html !== this.renderedHTML_) {\n this.element.innerHTML = html;\n this.renderedHTML_ = html;\n }\n };\n /**\n * Update the projection. Rendering of the coordinates is done in\n * `handleMouseMove` and `handleMouseUp`.\n * @param {import(\"../MapEvent.js\").default} mapEvent Map event.\n * @override\n */\n MousePosition.prototype.render = function (mapEvent) {\n var frameState = mapEvent.frameState;\n if (!frameState) {\n this.mapProjection_ = null;\n }\n else {\n if (this.mapProjection_ != frameState.viewState.projection) {\n this.mapProjection_ = frameState.viewState.projection;\n this.transform_ = null;\n }\n }\n };\n return MousePosition;\n}(Control));\nexport default MousePosition;\n//# sourceMappingURL=MousePosition.js.map","/**\n * @module ol/easing\n */\n/**\n * Start slow and speed up.\n * @param {number} t Input between 0 and 1.\n * @return {number} Output between 0 and 1.\n * @api\n */\nexport function easeIn(t) {\n return Math.pow(t, 3);\n}\n/**\n * Start fast and slow down.\n * @param {number} t Input between 0 and 1.\n * @return {number} Output between 0 and 1.\n * @api\n */\nexport function easeOut(t) {\n return 1 - easeIn(1 - t);\n}\n/**\n * Start slow, speed up, and then slow down again.\n * @param {number} t Input between 0 and 1.\n * @return {number} Output between 0 and 1.\n * @api\n */\nexport function inAndOut(t) {\n return 3 * t * t - 2 * t * t * t;\n}\n/**\n * Maintain a constant speed over time.\n * @param {number} t Input between 0 and 1.\n * @return {number} Output between 0 and 1.\n * @api\n */\nexport function linear(t) {\n return t;\n}\n/**\n * Start slow, speed up, and at the very end slow down again. This has the\n * same general behavior as {@link module:ol/easing.inAndOut}, but the final\n * slowdown is delayed.\n * @param {number} t Input between 0 and 1.\n * @return {number} Output between 0 and 1.\n * @api\n */\nexport function upAndDown(t) {\n if (t < 0.5) {\n return inAndOut(2 * t);\n }\n else {\n return 1 - inAndOut(2 * (t - 0.5));\n }\n}\n//# sourceMappingURL=easing.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/control/Zoom\n */\nimport Control from './Control.js';\nimport EventType from '../events/EventType.js';\nimport { CLASS_CONTROL, CLASS_UNSELECTABLE } from '../css.js';\nimport { easeOut } from '../easing.js';\n/**\n * @typedef {Object} Options\n * @property {number} [duration=250] Animation duration in milliseconds.\n * @property {string} [className='ol-zoom'] CSS class name.\n * @property {string} [zoomInClassName=className + '-in'] CSS class name for the zoom-in button.\n * @property {string} [zoomOutClassName=className + '-out'] CSS class name for the zoom-out button.\n * @property {string|HTMLElement} [zoomInLabel='+'] Text label to use for the zoom-in\n * button. Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string|HTMLElement} [zoomOutLabel='–'] Text label to use for the zoom-out button.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string} [zoomInTipLabel='Zoom in'] Text label to use for the button tip.\n * @property {string} [zoomOutTipLabel='Zoom out'] Text label to use for the button tip.\n * @property {number} [delta=1] The zoom delta applied on each click.\n * @property {HTMLElement|string} [target] Specify a target if you want the control to be\n * rendered outside of the map's viewport.\n */\n/**\n * @classdesc\n * A control with 2 buttons, one for zoom in and one for zoom out.\n * This control is one of the default controls of a map. To style this control\n * use css selectors `.ol-zoom-in` and `.ol-zoom-out`.\n *\n * @api\n */\nvar Zoom = /** @class */ (function (_super) {\n __extends(Zoom, _super);\n /**\n * @param {Options} [opt_options] Zoom options.\n */\n function Zoom(opt_options) {\n var _this = this;\n var options = opt_options ? opt_options : {};\n _this = _super.call(this, {\n element: document.createElement('div'),\n target: options.target,\n }) || this;\n var className = options.className !== undefined ? options.className : 'ol-zoom';\n var delta = options.delta !== undefined ? options.delta : 1;\n var zoomInClassName = options.zoomInClassName !== undefined\n ? options.zoomInClassName\n : className + '-in';\n var zoomOutClassName = options.zoomOutClassName !== undefined\n ? options.zoomOutClassName\n : className + '-out';\n var zoomInLabel = options.zoomInLabel !== undefined ? options.zoomInLabel : '+';\n var zoomOutLabel = options.zoomOutLabel !== undefined ? options.zoomOutLabel : '\\u2013';\n var zoomInTipLabel = options.zoomInTipLabel !== undefined ? options.zoomInTipLabel : 'Zoom in';\n var zoomOutTipLabel = options.zoomOutTipLabel !== undefined\n ? options.zoomOutTipLabel\n : 'Zoom out';\n var inElement = document.createElement('button');\n inElement.className = zoomInClassName;\n inElement.setAttribute('type', 'button');\n inElement.title = zoomInTipLabel;\n inElement.appendChild(typeof zoomInLabel === 'string'\n ? document.createTextNode(zoomInLabel)\n : zoomInLabel);\n inElement.addEventListener(EventType.CLICK, _this.handleClick_.bind(_this, delta), false);\n var outElement = document.createElement('button');\n outElement.className = zoomOutClassName;\n outElement.setAttribute('type', 'button');\n outElement.title = zoomOutTipLabel;\n outElement.appendChild(typeof zoomOutLabel === 'string'\n ? document.createTextNode(zoomOutLabel)\n : zoomOutLabel);\n outElement.addEventListener(EventType.CLICK, _this.handleClick_.bind(_this, -delta), false);\n var cssClasses = className + ' ' + CLASS_UNSELECTABLE + ' ' + CLASS_CONTROL;\n var element = _this.element;\n element.className = cssClasses;\n element.appendChild(inElement);\n element.appendChild(outElement);\n /**\n * @type {number}\n * @private\n */\n _this.duration_ = options.duration !== undefined ? options.duration : 250;\n return _this;\n }\n /**\n * @param {number} delta Zoom delta.\n * @param {MouseEvent} event The event to handle\n * @private\n */\n Zoom.prototype.handleClick_ = function (delta, event) {\n event.preventDefault();\n this.zoomByDelta_(delta);\n };\n /**\n * @param {number} delta Zoom delta.\n * @private\n */\n Zoom.prototype.zoomByDelta_ = function (delta) {\n var map = this.getMap();\n var view = map.getView();\n if (!view) {\n // the map does not have a view, so we can't act\n // upon it\n return;\n }\n var currentZoom = view.getZoom();\n if (currentZoom !== undefined) {\n var newZoom = view.getConstrainedZoom(currentZoom + delta);\n if (this.duration_ > 0) {\n if (view.getAnimating()) {\n view.cancelAnimations();\n }\n view.animate({\n zoom: newZoom,\n duration: this.duration_,\n easing: easeOut,\n });\n }\n else {\n view.setZoom(newZoom);\n }\n }\n };\n return Zoom;\n}(Control));\nexport default Zoom;\n//# sourceMappingURL=Zoom.js.map","/**\n * @module ol/coordinate\n */\nimport { getWidth } from './extent.js';\nimport { modulo } from './math.js';\nimport { padNumber } from './string.js';\n/**\n * An array of numbers representing an xy coordinate. Example: `[16, 48]`.\n * @typedef {Array<number>} Coordinate\n * @api\n */\n/**\n * A function that takes a {@link module:ol/coordinate~Coordinate} and\n * transforms it into a `{string}`.\n *\n * @typedef {function((Coordinate|undefined)): string} CoordinateFormat\n * @api\n */\n/**\n * Add `delta` to `coordinate`. `coordinate` is modified in place and returned\n * by the function.\n *\n * Example:\n *\n * import {add} from 'ol/coordinate';\n *\n * var coord = [7.85, 47.983333];\n * add(coord, [-2, 4]);\n * // coord is now [5.85, 51.983333]\n *\n * @param {Coordinate} coordinate Coordinate.\n * @param {Coordinate} delta Delta.\n * @return {Coordinate} The input coordinate adjusted by\n * the given delta.\n * @api\n */\nexport function add(coordinate, delta) {\n coordinate[0] += +delta[0];\n coordinate[1] += +delta[1];\n return coordinate;\n}\n/**\n * Calculates the point closest to the passed coordinate on the passed circle.\n *\n * @param {Coordinate} coordinate The coordinate.\n * @param {import(\"./geom/Circle.js\").default} circle The circle.\n * @return {Coordinate} Closest point on the circumference.\n */\nexport function closestOnCircle(coordinate, circle) {\n var r = circle.getRadius();\n var center = circle.getCenter();\n var x0 = center[0];\n var y0 = center[1];\n var x1 = coordinate[0];\n var y1 = coordinate[1];\n var dx = x1 - x0;\n var dy = y1 - y0;\n if (dx === 0 && dy === 0) {\n dx = 1;\n }\n var d = Math.sqrt(dx * dx + dy * dy);\n var x = x0 + (r * dx) / d;\n var y = y0 + (r * dy) / d;\n return [x, y];\n}\n/**\n * Calculates the point closest to the passed coordinate on the passed segment.\n * This is the foot of the perpendicular of the coordinate to the segment when\n * the foot is on the segment, or the closest segment coordinate when the foot\n * is outside the segment.\n *\n * @param {Coordinate} coordinate The coordinate.\n * @param {Array<Coordinate>} segment The two coordinates\n * of the segment.\n * @return {Coordinate} The foot of the perpendicular of\n * the coordinate to the segment.\n */\nexport function closestOnSegment(coordinate, segment) {\n var x0 = coordinate[0];\n var y0 = coordinate[1];\n var start = segment[0];\n var end = segment[1];\n var x1 = start[0];\n var y1 = start[1];\n var x2 = end[0];\n var y2 = end[1];\n var dx = x2 - x1;\n var dy = y2 - y1;\n var along = dx === 0 && dy === 0\n ? 0\n : (dx * (x0 - x1) + dy * (y0 - y1)) / (dx * dx + dy * dy || 0);\n var x, y;\n if (along <= 0) {\n x = x1;\n y = y1;\n }\n else if (along >= 1) {\n x = x2;\n y = y2;\n }\n else {\n x = x1 + along * dx;\n y = y1 + along * dy;\n }\n return [x, y];\n}\n/**\n * Returns a {@link module:ol/coordinate~CoordinateFormat} function that can be\n * used to format\n * a {Coordinate} to a string.\n *\n * Example without specifying the fractional digits:\n *\n * import {createStringXY} from 'ol/coordinate';\n *\n * var coord = [7.85, 47.983333];\n * var stringifyFunc = createStringXY();\n * var out = stringifyFunc(coord);\n * // out is now '8, 48'\n *\n * Example with explicitly specifying 2 fractional digits:\n *\n * import {createStringXY} from 'ol/coordinate';\n *\n * var coord = [7.85, 47.983333];\n * var stringifyFunc = createStringXY(2);\n * var out = stringifyFunc(coord);\n * // out is now '7.85, 47.98'\n *\n * @param {number} [opt_fractionDigits] The number of digits to include\n * after the decimal point. Default is `0`.\n * @return {CoordinateFormat} Coordinate format.\n * @api\n */\nexport function createStringXY(opt_fractionDigits) {\n return (\n /**\n * @param {Coordinate} coordinate Coordinate.\n * @return {string} String XY.\n */\n function (coordinate) {\n return toStringXY(coordinate, opt_fractionDigits);\n });\n}\n/**\n * @param {string} hemispheres Hemispheres.\n * @param {number} degrees Degrees.\n * @param {number} [opt_fractionDigits] The number of digits to include\n * after the decimal point. Default is `0`.\n * @return {string} String.\n */\nexport function degreesToStringHDMS(hemispheres, degrees, opt_fractionDigits) {\n var normalizedDegrees = modulo(degrees + 180, 360) - 180;\n var x = Math.abs(3600 * normalizedDegrees);\n var dflPrecision = opt_fractionDigits || 0;\n var precision = Math.pow(10, dflPrecision);\n var deg = Math.floor(x / 3600);\n var min = Math.floor((x - deg * 3600) / 60);\n var sec = x - deg * 3600 - min * 60;\n sec = Math.ceil(sec * precision) / precision;\n if (sec >= 60) {\n sec = 0;\n min += 1;\n }\n if (min >= 60) {\n min = 0;\n deg += 1;\n }\n return (deg +\n '\\u00b0 ' +\n padNumber(min, 2) +\n '\\u2032 ' +\n padNumber(sec, 2, dflPrecision) +\n '\\u2033' +\n (normalizedDegrees == 0\n ? ''\n : ' ' + hemispheres.charAt(normalizedDegrees < 0 ? 1 : 0)));\n}\n/**\n * Transforms the given {@link module:ol/coordinate~Coordinate} to a string\n * using the given string template. The strings `{x}` and `{y}` in the template\n * will be replaced with the first and second coordinate values respectively.\n *\n * Example without specifying the fractional digits:\n *\n * import {format} from 'ol/coordinate';\n *\n * var coord = [7.85, 47.983333];\n * var template = 'Coordinate is ({x}|{y}).';\n * var out = format(coord, template);\n * // out is now 'Coordinate is (8|48).'\n *\n * Example explicitly specifying the fractional digits:\n *\n * import {format} from 'ol/coordinate';\n *\n * var coord = [7.85, 47.983333];\n * var template = 'Coordinate is ({x}|{y}).';\n * var out = format(coord, template, 2);\n * // out is now 'Coordinate is (7.85|47.98).'\n *\n * @param {Coordinate} coordinate Coordinate.\n * @param {string} template A template string with `{x}` and `{y}` placeholders\n * that will be replaced by first and second coordinate values.\n * @param {number} [opt_fractionDigits] The number of digits to include\n * after the decimal point. Default is `0`.\n * @return {string} Formatted coordinate.\n * @api\n */\nexport function format(coordinate, template, opt_fractionDigits) {\n if (coordinate) {\n return template\n .replace('{x}', coordinate[0].toFixed(opt_fractionDigits))\n .replace('{y}', coordinate[1].toFixed(opt_fractionDigits));\n }\n else {\n return '';\n }\n}\n/**\n * @param {Coordinate} coordinate1 First coordinate.\n * @param {Coordinate} coordinate2 Second coordinate.\n * @return {boolean} The two coordinates are equal.\n */\nexport function equals(coordinate1, coordinate2) {\n var equals = true;\n for (var i = coordinate1.length - 1; i >= 0; --i) {\n if (coordinate1[i] != coordinate2[i]) {\n equals = false;\n break;\n }\n }\n return equals;\n}\n/**\n * Rotate `coordinate` by `angle`. `coordinate` is modified in place and\n * returned by the function.\n *\n * Example:\n *\n * import {rotate} from 'ol/coordinate';\n *\n * var coord = [7.85, 47.983333];\n * var rotateRadians = Math.PI / 2; // 90 degrees\n * rotate(coord, rotateRadians);\n * // coord is now [-47.983333, 7.85]\n *\n * @param {Coordinate} coordinate Coordinate.\n * @param {number} angle Angle in radian.\n * @return {Coordinate} Coordinate.\n * @api\n */\nexport function rotate(coordinate, angle) {\n var cosAngle = Math.cos(angle);\n var sinAngle = Math.sin(angle);\n var x = coordinate[0] * cosAngle - coordinate[1] * sinAngle;\n var y = coordinate[1] * cosAngle + coordinate[0] * sinAngle;\n coordinate[0] = x;\n coordinate[1] = y;\n return coordinate;\n}\n/**\n * Scale `coordinate` by `scale`. `coordinate` is modified in place and returned\n * by the function.\n *\n * Example:\n *\n * import {scale as scaleCoordinate} from 'ol/coordinate';\n *\n * var coord = [7.85, 47.983333];\n * var scale = 1.2;\n * scaleCoordinate(coord, scale);\n * // coord is now [9.42, 57.5799996]\n *\n * @param {Coordinate} coordinate Coordinate.\n * @param {number} scale Scale factor.\n * @return {Coordinate} Coordinate.\n */\nexport function scale(coordinate, scale) {\n coordinate[0] *= scale;\n coordinate[1] *= scale;\n return coordinate;\n}\n/**\n * @param {Coordinate} coord1 First coordinate.\n * @param {Coordinate} coord2 Second coordinate.\n * @return {number} Squared distance between coord1 and coord2.\n */\nexport function squaredDistance(coord1, coord2) {\n var dx = coord1[0] - coord2[0];\n var dy = coord1[1] - coord2[1];\n return dx * dx + dy * dy;\n}\n/**\n * @param {Coordinate} coord1 First coordinate.\n * @param {Coordinate} coord2 Second coordinate.\n * @return {number} Distance between coord1 and coord2.\n */\nexport function distance(coord1, coord2) {\n return Math.sqrt(squaredDistance(coord1, coord2));\n}\n/**\n * Calculate the squared distance from a coordinate to a line segment.\n *\n * @param {Coordinate} coordinate Coordinate of the point.\n * @param {Array<Coordinate>} segment Line segment (2\n * coordinates).\n * @return {number} Squared distance from the point to the line segment.\n */\nexport function squaredDistanceToSegment(coordinate, segment) {\n return squaredDistance(coordinate, closestOnSegment(coordinate, segment));\n}\n/**\n * Format a geographic coordinate with the hemisphere, degrees, minutes, and\n * seconds.\n *\n * Example without specifying fractional digits:\n *\n * import {toStringHDMS} from 'ol/coordinate';\n *\n * var coord = [7.85, 47.983333];\n * var out = toStringHDMS(coord);\n * // out is now '47° 58′ 60″ N 7° 50′ 60″ E'\n *\n * Example explicitly specifying 1 fractional digit:\n *\n * import {toStringHDMS} from 'ol/coordinate';\n *\n * var coord = [7.85, 47.983333];\n * var out = toStringHDMS(coord, 1);\n * // out is now '47° 58′ 60.0″ N 7° 50′ 60.0″ E'\n *\n * @param {Coordinate} coordinate Coordinate.\n * @param {number} [opt_fractionDigits] The number of digits to include\n * after the decimal point. Default is `0`.\n * @return {string} Hemisphere, degrees, minutes and seconds.\n * @api\n */\nexport function toStringHDMS(coordinate, opt_fractionDigits) {\n if (coordinate) {\n return (degreesToStringHDMS('NS', coordinate[1], opt_fractionDigits) +\n ' ' +\n degreesToStringHDMS('EW', coordinate[0], opt_fractionDigits));\n }\n else {\n return '';\n }\n}\n/**\n * Format a coordinate as a comma delimited string.\n *\n * Example without specifying fractional digits:\n *\n * import {toStringXY} from 'ol/coordinate';\n *\n * var coord = [7.85, 47.983333];\n * var out = toStringXY(coord);\n * // out is now '8, 48'\n *\n * Example explicitly specifying 1 fractional digit:\n *\n * import {toStringXY} from 'ol/coordinate';\n *\n * var coord = [7.85, 47.983333];\n * var out = toStringXY(coord, 1);\n * // out is now '7.8, 48.0'\n *\n * @param {Coordinate} coordinate Coordinate.\n * @param {number} [opt_fractionDigits] The number of digits to include\n * after the decimal point. Default is `0`.\n * @return {string} XY.\n * @api\n */\nexport function toStringXY(coordinate, opt_fractionDigits) {\n return format(coordinate, '{x}, {y}', opt_fractionDigits);\n}\n/**\n * Modifies the provided coordinate in-place to be within the real world\n * extent. The lower projection extent boundary is inclusive, the upper one\n * exclusive.\n *\n * @param {Coordinate} coordinate Coordinate.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @return {Coordinate} The coordinate within the real world extent.\n */\nexport function wrapX(coordinate, projection) {\n if (projection.canWrapX()) {\n var worldWidth = getWidth(projection.getExtent());\n var worldsAway = getWorldsAway(coordinate, projection, worldWidth);\n if (worldsAway) {\n coordinate[0] -= worldsAway * worldWidth;\n }\n }\n return coordinate;\n}\n/**\n * @param {Coordinate} coordinate Coordinate.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @param {number} [opt_sourceExtentWidth] Width of the source extent.\n * @return {number} Offset in world widths.\n */\nexport function getWorldsAway(coordinate, projection, opt_sourceExtentWidth) {\n var projectionExtent = projection.getExtent();\n var worldsAway = 0;\n if (projection.canWrapX() &&\n (coordinate[0] < projectionExtent[0] || coordinate[0] > projectionExtent[2])) {\n var sourceExtentWidth = opt_sourceExtentWidth || getWidth(projectionExtent);\n worldsAway = Math.floor((coordinate[0] - projectionExtent[0]) / sourceExtentWidth);\n }\n return worldsAway;\n}\n//# sourceMappingURL=coordinate.js.map","/**\n * @module ol/geom/GeometryLayout\n */\n/**\n * The coordinate layout for geometries, indicating whether a 3rd or 4th z ('Z')\n * or measure ('M') coordinate is available. Supported values are `'XY'`,\n * `'XYZ'`, `'XYM'`, `'XYZM'`.\n * @enum {string}\n */\nexport default {\n XY: 'XY',\n XYZ: 'XYZ',\n XYM: 'XYM',\n XYZM: 'XYZM',\n};\n//# sourceMappingURL=GeometryLayout.js.map","/**\n * @module ol/transform\n */\nimport { WORKER_OFFSCREEN_CANVAS } from './has.js';\nimport { assert } from './asserts.js';\n/**\n * An array representing an affine 2d transformation for use with\n * {@link module:ol/transform} functions. The array has 6 elements.\n * @typedef {!Array<number>} Transform\n * @api\n */\n/**\n * Collection of affine 2d transformation functions. The functions work on an\n * array of 6 elements. The element order is compatible with the [SVGMatrix\n * interface](https://developer.mozilla.org/en-US/docs/Web/API/SVGMatrix) and is\n * a subset (elements a to f) of a 3×3 matrix:\n * ```\n * [ a c e ]\n * [ b d f ]\n * [ 0 0 1 ]\n * ```\n */\n/**\n * @private\n * @type {Transform}\n */\nvar tmp_ = new Array(6);\n/**\n * Create an identity transform.\n * @return {!Transform} Identity transform.\n */\nexport function create() {\n return [1, 0, 0, 1, 0, 0];\n}\n/**\n * Resets the given transform to an identity transform.\n * @param {!Transform} transform Transform.\n * @return {!Transform} Transform.\n */\nexport function reset(transform) {\n return set(transform, 1, 0, 0, 1, 0, 0);\n}\n/**\n * Multiply the underlying matrices of two transforms and return the result in\n * the first transform.\n * @param {!Transform} transform1 Transform parameters of matrix 1.\n * @param {!Transform} transform2 Transform parameters of matrix 2.\n * @return {!Transform} transform1 multiplied with transform2.\n */\nexport function multiply(transform1, transform2) {\n var a1 = transform1[0];\n var b1 = transform1[1];\n var c1 = transform1[2];\n var d1 = transform1[3];\n var e1 = transform1[4];\n var f1 = transform1[5];\n var a2 = transform2[0];\n var b2 = transform2[1];\n var c2 = transform2[2];\n var d2 = transform2[3];\n var e2 = transform2[4];\n var f2 = transform2[5];\n transform1[0] = a1 * a2 + c1 * b2;\n transform1[1] = b1 * a2 + d1 * b2;\n transform1[2] = a1 * c2 + c1 * d2;\n transform1[3] = b1 * c2 + d1 * d2;\n transform1[4] = a1 * e2 + c1 * f2 + e1;\n transform1[5] = b1 * e2 + d1 * f2 + f1;\n return transform1;\n}\n/**\n * Set the transform components a-f on a given transform.\n * @param {!Transform} transform Transform.\n * @param {number} a The a component of the transform.\n * @param {number} b The b component of the transform.\n * @param {number} c The c component of the transform.\n * @param {number} d The d component of the transform.\n * @param {number} e The e component of the transform.\n * @param {number} f The f component of the transform.\n * @return {!Transform} Matrix with transform applied.\n */\nexport function set(transform, a, b, c, d, e, f) {\n transform[0] = a;\n transform[1] = b;\n transform[2] = c;\n transform[3] = d;\n transform[4] = e;\n transform[5] = f;\n return transform;\n}\n/**\n * Set transform on one matrix from another matrix.\n * @param {!Transform} transform1 Matrix to set transform to.\n * @param {!Transform} transform2 Matrix to set transform from.\n * @return {!Transform} transform1 with transform from transform2 applied.\n */\nexport function setFromArray(transform1, transform2) {\n transform1[0] = transform2[0];\n transform1[1] = transform2[1];\n transform1[2] = transform2[2];\n transform1[3] = transform2[3];\n transform1[4] = transform2[4];\n transform1[5] = transform2[5];\n return transform1;\n}\n/**\n * Transforms the given coordinate with the given transform returning the\n * resulting, transformed coordinate. The coordinate will be modified in-place.\n *\n * @param {Transform} transform The transformation.\n * @param {import(\"./coordinate.js\").Coordinate|import(\"./pixel.js\").Pixel} coordinate The coordinate to transform.\n * @return {import(\"./coordinate.js\").Coordinate|import(\"./pixel.js\").Pixel} return coordinate so that operations can be\n * chained together.\n */\nexport function apply(transform, coordinate) {\n var x = coordinate[0];\n var y = coordinate[1];\n coordinate[0] = transform[0] * x + transform[2] * y + transform[4];\n coordinate[1] = transform[1] * x + transform[3] * y + transform[5];\n return coordinate;\n}\n/**\n * Applies rotation to the given transform.\n * @param {!Transform} transform Transform.\n * @param {number} angle Angle in radians.\n * @return {!Transform} The rotated transform.\n */\nexport function rotate(transform, angle) {\n var cos = Math.cos(angle);\n var sin = Math.sin(angle);\n return multiply(transform, set(tmp_, cos, sin, -sin, cos, 0, 0));\n}\n/**\n * Applies scale to a given transform.\n * @param {!Transform} transform Transform.\n * @param {number} x Scale factor x.\n * @param {number} y Scale factor y.\n * @return {!Transform} The scaled transform.\n */\nexport function scale(transform, x, y) {\n return multiply(transform, set(tmp_, x, 0, 0, y, 0, 0));\n}\n/**\n * Creates a scale transform.\n * @param {!Transform} target Transform to overwrite.\n * @param {number} x Scale factor x.\n * @param {number} y Scale factor y.\n * @return {!Transform} The scale transform.\n */\nexport function makeScale(target, x, y) {\n return set(target, x, 0, 0, y, 0, 0);\n}\n/**\n * Applies translation to the given transform.\n * @param {!Transform} transform Transform.\n * @param {number} dx Translation x.\n * @param {number} dy Translation y.\n * @return {!Transform} The translated transform.\n */\nexport function translate(transform, dx, dy) {\n return multiply(transform, set(tmp_, 1, 0, 0, 1, dx, dy));\n}\n/**\n * Creates a composite transform given an initial translation, scale, rotation, and\n * final translation (in that order only, not commutative).\n * @param {!Transform} transform The transform (will be modified in place).\n * @param {number} dx1 Initial translation x.\n * @param {number} dy1 Initial translation y.\n * @param {number} sx Scale factor x.\n * @param {number} sy Scale factor y.\n * @param {number} angle Rotation (in counter-clockwise radians).\n * @param {number} dx2 Final translation x.\n * @param {number} dy2 Final translation y.\n * @return {!Transform} The composite transform.\n */\nexport function compose(transform, dx1, dy1, sx, sy, angle, dx2, dy2) {\n var sin = Math.sin(angle);\n var cos = Math.cos(angle);\n transform[0] = sx * cos;\n transform[1] = sy * sin;\n transform[2] = -sx * sin;\n transform[3] = sy * cos;\n transform[4] = dx2 * sx * cos - dy2 * sx * sin + dx1;\n transform[5] = dx2 * sy * sin + dy2 * sy * cos + dy1;\n return transform;\n}\n/**\n * Creates a composite transform given an initial translation, scale, rotation, and\n * final translation (in that order only, not commutative). The resulting transform\n * string can be applied as `transform` property of an HTMLElement's style.\n * @param {number} dx1 Initial translation x.\n * @param {number} dy1 Initial translation y.\n * @param {number} sx Scale factor x.\n * @param {number} sy Scale factor y.\n * @param {number} angle Rotation (in counter-clockwise radians).\n * @param {number} dx2 Final translation x.\n * @param {number} dy2 Final translation y.\n * @return {string} The composite css transform.\n * @api\n */\nexport function composeCssTransform(dx1, dy1, sx, sy, angle, dx2, dy2) {\n return toString(compose(create(), dx1, dy1, sx, sy, angle, dx2, dy2));\n}\n/**\n * Invert the given transform.\n * @param {!Transform} source The source transform to invert.\n * @return {!Transform} The inverted (source) transform.\n */\nexport function invert(source) {\n return makeInverse(source, source);\n}\n/**\n * Invert the given transform.\n * @param {!Transform} target Transform to be set as the inverse of\n * the source transform.\n * @param {!Transform} source The source transform to invert.\n * @return {!Transform} The inverted (target) transform.\n */\nexport function makeInverse(target, source) {\n var det = determinant(source);\n assert(det !== 0, 32); // Transformation matrix cannot be inverted\n var a = source[0];\n var b = source[1];\n var c = source[2];\n var d = source[3];\n var e = source[4];\n var f = source[5];\n target[0] = d / det;\n target[1] = -b / det;\n target[2] = -c / det;\n target[3] = a / det;\n target[4] = (c * f - d * e) / det;\n target[5] = -(a * f - b * e) / det;\n return target;\n}\n/**\n * Returns the determinant of the given matrix.\n * @param {!Transform} mat Matrix.\n * @return {number} Determinant.\n */\nexport function determinant(mat) {\n return mat[0] * mat[3] - mat[1] * mat[2];\n}\n/**\n * @type {HTMLElement}\n * @private\n */\nvar transformStringDiv;\n/**\n * A rounded string version of the transform. This can be used\n * for CSS transforms.\n * @param {!Transform} mat Matrix.\n * @return {string} The transform as a string.\n */\nexport function toString(mat) {\n var transformString = 'matrix(' + mat.join(', ') + ')';\n if (WORKER_OFFSCREEN_CANVAS) {\n return transformString;\n }\n var node = transformStringDiv || (transformStringDiv = document.createElement('div'));\n node.style.transform = transformString;\n return node.style.transform;\n}\n//# sourceMappingURL=transform.js.map","/**\n * @module ol/geom/GeometryType\n */\n/**\n * The geometry type. One of `'Point'`, `'LineString'`, `'LinearRing'`,\n * `'Polygon'`, `'MultiPoint'`, `'MultiLineString'`, `'MultiPolygon'`,\n * `'GeometryCollection'`, `'Circle'`.\n * @enum {string}\n */\nexport default {\n POINT: 'Point',\n LINE_STRING: 'LineString',\n LINEAR_RING: 'LinearRing',\n POLYGON: 'Polygon',\n MULTI_POINT: 'MultiPoint',\n MULTI_LINE_STRING: 'MultiLineString',\n MULTI_POLYGON: 'MultiPolygon',\n GEOMETRY_COLLECTION: 'GeometryCollection',\n CIRCLE: 'Circle',\n};\n//# sourceMappingURL=GeometryType.js.map","/**\n * @module ol/geom/flat/transform\n */\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {import(\"../../transform.js\").Transform} transform Transform.\n * @param {Array<number>} [opt_dest] Destination.\n * @return {Array<number>} Transformed coordinates.\n */\nexport function transform2D(flatCoordinates, offset, end, stride, transform, opt_dest) {\n var dest = opt_dest ? opt_dest : [];\n var i = 0;\n for (var j = offset; j < end; j += stride) {\n var x = flatCoordinates[j];\n var y = flatCoordinates[j + 1];\n dest[i++] = transform[0] * x + transform[2] * y + transform[4];\n dest[i++] = transform[1] * x + transform[3] * y + transform[5];\n }\n if (opt_dest && dest.length != i) {\n dest.length = i;\n }\n return dest;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} angle Angle.\n * @param {Array<number>} anchor Rotation anchor point.\n * @param {Array<number>} [opt_dest] Destination.\n * @return {Array<number>} Transformed coordinates.\n */\nexport function rotate(flatCoordinates, offset, end, stride, angle, anchor, opt_dest) {\n var dest = opt_dest ? opt_dest : [];\n var cos = Math.cos(angle);\n var sin = Math.sin(angle);\n var anchorX = anchor[0];\n var anchorY = anchor[1];\n var i = 0;\n for (var j = offset; j < end; j += stride) {\n var deltaX = flatCoordinates[j] - anchorX;\n var deltaY = flatCoordinates[j + 1] - anchorY;\n dest[i++] = anchorX + deltaX * cos - deltaY * sin;\n dest[i++] = anchorY + deltaX * sin + deltaY * cos;\n for (var k = j + 2; k < j + stride; ++k) {\n dest[i++] = flatCoordinates[k];\n }\n }\n if (opt_dest && dest.length != i) {\n dest.length = i;\n }\n return dest;\n}\n/**\n * Scale the coordinates.\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} sx Scale factor in the x-direction.\n * @param {number} sy Scale factor in the y-direction.\n * @param {Array<number>} anchor Scale anchor point.\n * @param {Array<number>} [opt_dest] Destination.\n * @return {Array<number>} Transformed coordinates.\n */\nexport function scale(flatCoordinates, offset, end, stride, sx, sy, anchor, opt_dest) {\n var dest = opt_dest ? opt_dest : [];\n var anchorX = anchor[0];\n var anchorY = anchor[1];\n var i = 0;\n for (var j = offset; j < end; j += stride) {\n var deltaX = flatCoordinates[j] - anchorX;\n var deltaY = flatCoordinates[j + 1] - anchorY;\n dest[i++] = anchorX + sx * deltaX;\n dest[i++] = anchorY + sy * deltaY;\n for (var k = j + 2; k < j + stride; ++k) {\n dest[i++] = flatCoordinates[k];\n }\n }\n if (opt_dest && dest.length != i) {\n dest.length = i;\n }\n return dest;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} deltaX Delta X.\n * @param {number} deltaY Delta Y.\n * @param {Array<number>} [opt_dest] Destination.\n * @return {Array<number>} Transformed coordinates.\n */\nexport function translate(flatCoordinates, offset, end, stride, deltaX, deltaY, opt_dest) {\n var dest = opt_dest ? opt_dest : [];\n var i = 0;\n for (var j = offset; j < end; j += stride) {\n dest[i++] = flatCoordinates[j] + deltaX;\n dest[i++] = flatCoordinates[j + 1] + deltaY;\n for (var k = j + 2; k < j + stride; ++k) {\n dest[i++] = flatCoordinates[k];\n }\n }\n if (opt_dest && dest.length != i) {\n dest.length = i;\n }\n return dest;\n}\n//# sourceMappingURL=transform.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/geom/Geometry\n */\nimport BaseObject from '../Object.js';\nimport Units from '../proj/Units.js';\nimport { abstract } from '../util.js';\nimport { compose as composeTransform, create as createTransform, } from '../transform.js';\nimport { createEmpty, createOrUpdateEmpty, getHeight, returnOrUpdate, } from '../extent.js';\nimport { get as getProjection, getTransform } from '../proj.js';\nimport { memoizeOne } from '../functions.js';\nimport { transform2D } from './flat/transform.js';\n/**\n * @type {import(\"../transform.js\").Transform}\n */\nvar tmpTransform = createTransform();\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * Base class for vector geometries.\n *\n * To get notified of changes to the geometry, register a listener for the\n * generic `change` event on your geometry instance.\n *\n * @abstract\n * @api\n */\nvar Geometry = /** @class */ (function (_super) {\n __extends(Geometry, _super);\n function Geometry() {\n var _this = _super.call(this) || this;\n /**\n * @private\n * @type {import(\"../extent.js\").Extent}\n */\n _this.extent_ = createEmpty();\n /**\n * @private\n * @type {number}\n */\n _this.extentRevision_ = -1;\n /**\n * @protected\n * @type {number}\n */\n _this.simplifiedGeometryMaxMinSquaredTolerance = 0;\n /**\n * @protected\n * @type {number}\n */\n _this.simplifiedGeometryRevision = 0;\n /**\n * Get a transformed and simplified version of the geometry.\n * @abstract\n * @param {number} revision The geometry revision.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {import(\"../proj.js\").TransformFunction} [opt_transform] Optional transform function.\n * @return {Geometry} Simplified geometry.\n */\n _this.simplifyTransformedInternal = memoizeOne(function (revision, squaredTolerance, opt_transform) {\n if (!opt_transform) {\n return this.getSimplifiedGeometry(squaredTolerance);\n }\n var clone = this.clone();\n clone.applyTransform(opt_transform);\n return clone.getSimplifiedGeometry(squaredTolerance);\n });\n return _this;\n }\n /**\n * Get a transformed and simplified version of the geometry.\n * @abstract\n * @param {number} squaredTolerance Squared tolerance.\n * @param {import(\"../proj.js\").TransformFunction} [opt_transform] Optional transform function.\n * @return {Geometry} Simplified geometry.\n */\n Geometry.prototype.simplifyTransformed = function (squaredTolerance, opt_transform) {\n return this.simplifyTransformedInternal(this.getRevision(), squaredTolerance, opt_transform);\n };\n /**\n * Make a complete copy of the geometry.\n * @abstract\n * @return {!Geometry} Clone.\n */\n Geometry.prototype.clone = function () {\n return abstract();\n };\n /**\n * @abstract\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n */\n Geometry.prototype.closestPointXY = function (x, y, closestPoint, minSquaredDistance) {\n return abstract();\n };\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @return {boolean} Contains (x, y).\n */\n Geometry.prototype.containsXY = function (x, y) {\n var coord = this.getClosestPoint([x, y]);\n return coord[0] === x && coord[1] === y;\n };\n /**\n * Return the closest point of the geometry to the passed point as\n * {@link module:ol/coordinate~Coordinate coordinate}.\n * @param {import(\"../coordinate.js\").Coordinate} point Point.\n * @param {import(\"../coordinate.js\").Coordinate} [opt_closestPoint] Closest point.\n * @return {import(\"../coordinate.js\").Coordinate} Closest point.\n * @api\n */\n Geometry.prototype.getClosestPoint = function (point, opt_closestPoint) {\n var closestPoint = opt_closestPoint ? opt_closestPoint : [NaN, NaN];\n this.closestPointXY(point[0], point[1], closestPoint, Infinity);\n return closestPoint;\n };\n /**\n * Returns true if this geometry includes the specified coordinate. If the\n * coordinate is on the boundary of the geometry, returns false.\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @return {boolean} Contains coordinate.\n * @api\n */\n Geometry.prototype.intersectsCoordinate = function (coordinate) {\n return this.containsXY(coordinate[0], coordinate[1]);\n };\n /**\n * @abstract\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @protected\n * @return {import(\"../extent.js\").Extent} extent Extent.\n */\n Geometry.prototype.computeExtent = function (extent) {\n return abstract();\n };\n /**\n * Get the extent of the geometry.\n * @param {import(\"../extent.js\").Extent} [opt_extent] Extent.\n * @return {import(\"../extent.js\").Extent} extent Extent.\n * @api\n */\n Geometry.prototype.getExtent = function (opt_extent) {\n if (this.extentRevision_ != this.getRevision()) {\n var extent = this.computeExtent(this.extent_);\n if (isNaN(extent[0]) || isNaN(extent[1])) {\n createOrUpdateEmpty(extent);\n }\n this.extentRevision_ = this.getRevision();\n }\n return returnOrUpdate(this.extent_, opt_extent);\n };\n /**\n * Rotate the geometry around a given coordinate. This modifies the geometry\n * coordinates in place.\n * @abstract\n * @param {number} angle Rotation angle in radians.\n * @param {import(\"../coordinate.js\").Coordinate} anchor The rotation center.\n * @api\n */\n Geometry.prototype.rotate = function (angle, anchor) {\n abstract();\n };\n /**\n * Scale the geometry (with an optional origin). This modifies the geometry\n * coordinates in place.\n * @abstract\n * @param {number} sx The scaling factor in the x-direction.\n * @param {number} [opt_sy] The scaling factor in the y-direction (defaults to sx).\n * @param {import(\"../coordinate.js\").Coordinate} [opt_anchor] The scale origin (defaults to the center\n * of the geometry extent).\n * @api\n */\n Geometry.prototype.scale = function (sx, opt_sy, opt_anchor) {\n abstract();\n };\n /**\n * Create a simplified version of this geometry. For linestrings, this uses\n * the [Douglas Peucker](https://en.wikipedia.org/wiki/Ramer-Douglas-Peucker_algorithm)\n * algorithm. For polygons, a quantization-based\n * simplification is used to preserve topology.\n * @param {number} tolerance The tolerance distance for simplification.\n * @return {Geometry} A new, simplified version of the original geometry.\n * @api\n */\n Geometry.prototype.simplify = function (tolerance) {\n return this.getSimplifiedGeometry(tolerance * tolerance);\n };\n /**\n * Create a simplified version of this geometry using the Douglas Peucker\n * algorithm.\n * See https://en.wikipedia.org/wiki/Ramer-Douglas-Peucker_algorithm.\n * @abstract\n * @param {number} squaredTolerance Squared tolerance.\n * @return {Geometry} Simplified geometry.\n */\n Geometry.prototype.getSimplifiedGeometry = function (squaredTolerance) {\n return abstract();\n };\n /**\n * Get the type of this geometry.\n * @abstract\n * @return {import(\"./GeometryType.js\").default} Geometry type.\n */\n Geometry.prototype.getType = function () {\n return abstract();\n };\n /**\n * Apply a transform function to the coordinates of the geometry.\n * The geometry is modified in place.\n * If you do not want the geometry modified in place, first `clone()` it and\n * then use this function on the clone.\n * @abstract\n * @param {import(\"../proj.js\").TransformFunction} transformFn Transform function.\n * Called with a flat array of geometry coordinates.\n */\n Geometry.prototype.applyTransform = function (transformFn) {\n abstract();\n };\n /**\n * Test if the geometry and the passed extent intersect.\n * @abstract\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n */\n Geometry.prototype.intersectsExtent = function (extent) {\n return abstract();\n };\n /**\n * Translate the geometry. This modifies the geometry coordinates in place. If\n * instead you want a new geometry, first `clone()` this geometry.\n * @abstract\n * @param {number} deltaX Delta X.\n * @param {number} deltaY Delta Y.\n * @api\n */\n Geometry.prototype.translate = function (deltaX, deltaY) {\n abstract();\n };\n /**\n * Transform each coordinate of the geometry from one coordinate reference\n * system to another. The geometry is modified in place.\n * For example, a line will be transformed to a line and a circle to a circle.\n * If you do not want the geometry modified in place, first `clone()` it and\n * then use this function on the clone.\n *\n * @param {import(\"../proj.js\").ProjectionLike} source The current projection. Can be a\n * string identifier or a {@link module:ol/proj/Projection~Projection} object.\n * @param {import(\"../proj.js\").ProjectionLike} destination The desired projection. Can be a\n * string identifier or a {@link module:ol/proj/Projection~Projection} object.\n * @return {Geometry} This geometry. Note that original geometry is\n * modified in place.\n * @api\n */\n Geometry.prototype.transform = function (source, destination) {\n /** @type {import(\"../proj/Projection.js\").default} */\n var sourceProj = getProjection(source);\n var transformFn = sourceProj.getUnits() == Units.TILE_PIXELS\n ? function (inCoordinates, outCoordinates, stride) {\n var pixelExtent = sourceProj.getExtent();\n var projectedExtent = sourceProj.getWorldExtent();\n var scale = getHeight(projectedExtent) / getHeight(pixelExtent);\n composeTransform(tmpTransform, projectedExtent[0], projectedExtent[3], scale, -scale, 0, 0, 0);\n transform2D(inCoordinates, 0, inCoordinates.length, stride, tmpTransform, outCoordinates);\n return getTransform(sourceProj, destination)(inCoordinates, outCoordinates, stride);\n }\n : getTransform(sourceProj, destination);\n this.applyTransform(transformFn);\n return this;\n };\n return Geometry;\n}(BaseObject));\nexport default Geometry;\n//# sourceMappingURL=Geometry.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/geom/SimpleGeometry\n */\nimport Geometry from './Geometry.js';\nimport GeometryLayout from './GeometryLayout.js';\nimport { abstract } from '../util.js';\nimport { createOrUpdateFromFlatCoordinates, getCenter } from '../extent.js';\nimport { rotate, scale, transform2D, translate } from './flat/transform.js';\n/**\n * @classdesc\n * Abstract base class; only used for creating subclasses; do not instantiate\n * in apps, as cannot be rendered.\n *\n * @abstract\n * @api\n */\nvar SimpleGeometry = /** @class */ (function (_super) {\n __extends(SimpleGeometry, _super);\n function SimpleGeometry() {\n var _this = _super.call(this) || this;\n /**\n * @protected\n * @type {import(\"./GeometryLayout.js\").default}\n */\n _this.layout = GeometryLayout.XY;\n /**\n * @protected\n * @type {number}\n */\n _this.stride = 2;\n /**\n * @protected\n * @type {Array<number>}\n */\n _this.flatCoordinates = null;\n return _this;\n }\n /**\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @protected\n * @return {import(\"../extent.js\").Extent} extent Extent.\n */\n SimpleGeometry.prototype.computeExtent = function (extent) {\n return createOrUpdateFromFlatCoordinates(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, extent);\n };\n /**\n * @abstract\n * @return {Array<*>} Coordinates.\n */\n SimpleGeometry.prototype.getCoordinates = function () {\n return abstract();\n };\n /**\n * Return the first coordinate of the geometry.\n * @return {import(\"../coordinate.js\").Coordinate} First coordinate.\n * @api\n */\n SimpleGeometry.prototype.getFirstCoordinate = function () {\n return this.flatCoordinates.slice(0, this.stride);\n };\n /**\n * @return {Array<number>} Flat coordinates.\n */\n SimpleGeometry.prototype.getFlatCoordinates = function () {\n return this.flatCoordinates;\n };\n /**\n * Return the last coordinate of the geometry.\n * @return {import(\"../coordinate.js\").Coordinate} Last point.\n * @api\n */\n SimpleGeometry.prototype.getLastCoordinate = function () {\n return this.flatCoordinates.slice(this.flatCoordinates.length - this.stride);\n };\n /**\n * Return the {@link module:ol/geom/GeometryLayout layout} of the geometry.\n * @return {import(\"./GeometryLayout.js\").default} Layout.\n * @api\n */\n SimpleGeometry.prototype.getLayout = function () {\n return this.layout;\n };\n /**\n * Create a simplified version of this geometry using the Douglas Peucker algorithm.\n * @param {number} squaredTolerance Squared tolerance.\n * @return {SimpleGeometry} Simplified geometry.\n */\n SimpleGeometry.prototype.getSimplifiedGeometry = function (squaredTolerance) {\n if (this.simplifiedGeometryRevision !== this.getRevision()) {\n this.simplifiedGeometryMaxMinSquaredTolerance = 0;\n this.simplifiedGeometryRevision = this.getRevision();\n }\n // If squaredTolerance is negative or if we know that simplification will not\n // have any effect then just return this.\n if (squaredTolerance < 0 ||\n (this.simplifiedGeometryMaxMinSquaredTolerance !== 0 &&\n squaredTolerance <= this.simplifiedGeometryMaxMinSquaredTolerance)) {\n return this;\n }\n var simplifiedGeometry = this.getSimplifiedGeometryInternal(squaredTolerance);\n var simplifiedFlatCoordinates = simplifiedGeometry.getFlatCoordinates();\n if (simplifiedFlatCoordinates.length < this.flatCoordinates.length) {\n return simplifiedGeometry;\n }\n else {\n // Simplification did not actually remove any coordinates. We now know\n // that any calls to getSimplifiedGeometry with a squaredTolerance less\n // than or equal to the current squaredTolerance will also not have any\n // effect. This allows us to short circuit simplification (saving CPU\n // cycles) and prevents the cache of simplified geometries from filling\n // up with useless identical copies of this geometry (saving memory).\n this.simplifiedGeometryMaxMinSquaredTolerance = squaredTolerance;\n return this;\n }\n };\n /**\n * @param {number} squaredTolerance Squared tolerance.\n * @return {SimpleGeometry} Simplified geometry.\n * @protected\n */\n SimpleGeometry.prototype.getSimplifiedGeometryInternal = function (squaredTolerance) {\n return this;\n };\n /**\n * @return {number} Stride.\n */\n SimpleGeometry.prototype.getStride = function () {\n return this.stride;\n };\n /**\n * @param {import(\"./GeometryLayout.js\").default} layout Layout.\n * @param {Array<number>} flatCoordinates Flat coordinates.\n */\n SimpleGeometry.prototype.setFlatCoordinates = function (layout, flatCoordinates) {\n this.stride = getStrideForLayout(layout);\n this.layout = layout;\n this.flatCoordinates = flatCoordinates;\n };\n /**\n * @abstract\n * @param {!Array<*>} coordinates Coordinates.\n * @param {import(\"./GeometryLayout.js\").default} [opt_layout] Layout.\n */\n SimpleGeometry.prototype.setCoordinates = function (coordinates, opt_layout) {\n abstract();\n };\n /**\n * @param {import(\"./GeometryLayout.js\").default|undefined} layout Layout.\n * @param {Array<*>} coordinates Coordinates.\n * @param {number} nesting Nesting.\n * @protected\n */\n SimpleGeometry.prototype.setLayout = function (layout, coordinates, nesting) {\n /** @type {number} */\n var stride;\n if (layout) {\n stride = getStrideForLayout(layout);\n }\n else {\n for (var i = 0; i < nesting; ++i) {\n if (coordinates.length === 0) {\n this.layout = GeometryLayout.XY;\n this.stride = 2;\n return;\n }\n else {\n coordinates = /** @type {Array} */ (coordinates[0]);\n }\n }\n stride = coordinates.length;\n layout = getLayoutForStride(stride);\n }\n this.layout = layout;\n this.stride = stride;\n };\n /**\n * Apply a transform function to the coordinates of the geometry.\n * The geometry is modified in place.\n * If you do not want the geometry modified in place, first `clone()` it and\n * then use this function on the clone.\n * @param {import(\"../proj.js\").TransformFunction} transformFn Transform function.\n * Called with a flat array of geometry coordinates.\n * @api\n */\n SimpleGeometry.prototype.applyTransform = function (transformFn) {\n if (this.flatCoordinates) {\n transformFn(this.flatCoordinates, this.flatCoordinates, this.stride);\n this.changed();\n }\n };\n /**\n * Rotate the geometry around a given coordinate. This modifies the geometry\n * coordinates in place.\n * @param {number} angle Rotation angle in counter-clockwise radians.\n * @param {import(\"../coordinate.js\").Coordinate} anchor The rotation center.\n * @api\n */\n SimpleGeometry.prototype.rotate = function (angle, anchor) {\n var flatCoordinates = this.getFlatCoordinates();\n if (flatCoordinates) {\n var stride = this.getStride();\n rotate(flatCoordinates, 0, flatCoordinates.length, stride, angle, anchor, flatCoordinates);\n this.changed();\n }\n };\n /**\n * Scale the geometry (with an optional origin). This modifies the geometry\n * coordinates in place.\n * @param {number} sx The scaling factor in the x-direction.\n * @param {number} [opt_sy] The scaling factor in the y-direction (defaults to sx).\n * @param {import(\"../coordinate.js\").Coordinate} [opt_anchor] The scale origin (defaults to the center\n * of the geometry extent).\n * @api\n */\n SimpleGeometry.prototype.scale = function (sx, opt_sy, opt_anchor) {\n var sy = opt_sy;\n if (sy === undefined) {\n sy = sx;\n }\n var anchor = opt_anchor;\n if (!anchor) {\n anchor = getCenter(this.getExtent());\n }\n var flatCoordinates = this.getFlatCoordinates();\n if (flatCoordinates) {\n var stride = this.getStride();\n scale(flatCoordinates, 0, flatCoordinates.length, stride, sx, sy, anchor, flatCoordinates);\n this.changed();\n }\n };\n /**\n * Translate the geometry. This modifies the geometry coordinates in place. If\n * instead you want a new geometry, first `clone()` this geometry.\n * @param {number} deltaX Delta X.\n * @param {number} deltaY Delta Y.\n * @api\n */\n SimpleGeometry.prototype.translate = function (deltaX, deltaY) {\n var flatCoordinates = this.getFlatCoordinates();\n if (flatCoordinates) {\n var stride = this.getStride();\n translate(flatCoordinates, 0, flatCoordinates.length, stride, deltaX, deltaY, flatCoordinates);\n this.changed();\n }\n };\n return SimpleGeometry;\n}(Geometry));\n/**\n * @param {number} stride Stride.\n * @return {import(\"./GeometryLayout.js\").default} layout Layout.\n */\nfunction getLayoutForStride(stride) {\n var layout;\n if (stride == 2) {\n layout = GeometryLayout.XY;\n }\n else if (stride == 3) {\n layout = GeometryLayout.XYZ;\n }\n else if (stride == 4) {\n layout = GeometryLayout.XYZM;\n }\n return /** @type {import(\"./GeometryLayout.js\").default} */ (layout);\n}\n/**\n * @param {import(\"./GeometryLayout.js\").default} layout Layout.\n * @return {number} Stride.\n */\nexport function getStrideForLayout(layout) {\n var stride;\n if (layout == GeometryLayout.XY) {\n stride = 2;\n }\n else if (layout == GeometryLayout.XYZ || layout == GeometryLayout.XYM) {\n stride = 3;\n }\n else if (layout == GeometryLayout.XYZM) {\n stride = 4;\n }\n return /** @type {number} */ (stride);\n}\n/**\n * @param {SimpleGeometry} simpleGeometry Simple geometry.\n * @param {import(\"../transform.js\").Transform} transform Transform.\n * @param {Array<number>} [opt_dest] Destination.\n * @return {Array<number>} Transformed flat coordinates.\n */\nexport function transformGeom2D(simpleGeometry, transform, opt_dest) {\n var flatCoordinates = simpleGeometry.getFlatCoordinates();\n if (!flatCoordinates) {\n return null;\n }\n else {\n var stride = simpleGeometry.getStride();\n return transform2D(flatCoordinates, 0, flatCoordinates.length, stride, transform, opt_dest);\n }\n}\nexport default SimpleGeometry;\n//# sourceMappingURL=SimpleGeometry.js.map","/**\n * @module ol/geom/flat/closest\n */\nimport { lerp, squaredDistance as squaredDx } from '../../math.js';\n/**\n * Returns the point on the 2D line segment flatCoordinates[offset1] to\n * flatCoordinates[offset2] that is closest to the point (x, y). Extra\n * dimensions are linearly interpolated.\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset1 Offset 1.\n * @param {number} offset2 Offset 2.\n * @param {number} stride Stride.\n * @param {number} x X.\n * @param {number} y Y.\n * @param {Array<number>} closestPoint Closest point.\n */\nfunction assignClosest(flatCoordinates, offset1, offset2, stride, x, y, closestPoint) {\n var x1 = flatCoordinates[offset1];\n var y1 = flatCoordinates[offset1 + 1];\n var dx = flatCoordinates[offset2] - x1;\n var dy = flatCoordinates[offset2 + 1] - y1;\n var offset;\n if (dx === 0 && dy === 0) {\n offset = offset1;\n }\n else {\n var t = ((x - x1) * dx + (y - y1) * dy) / (dx * dx + dy * dy);\n if (t > 1) {\n offset = offset2;\n }\n else if (t > 0) {\n for (var i = 0; i < stride; ++i) {\n closestPoint[i] = lerp(flatCoordinates[offset1 + i], flatCoordinates[offset2 + i], t);\n }\n closestPoint.length = stride;\n return;\n }\n else {\n offset = offset1;\n }\n }\n for (var i = 0; i < stride; ++i) {\n closestPoint[i] = flatCoordinates[offset + i];\n }\n closestPoint.length = stride;\n}\n/**\n * Return the squared of the largest distance between any pair of consecutive\n * coordinates.\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} max Max squared delta.\n * @return {number} Max squared delta.\n */\nexport function maxSquaredDelta(flatCoordinates, offset, end, stride, max) {\n var x1 = flatCoordinates[offset];\n var y1 = flatCoordinates[offset + 1];\n for (offset += stride; offset < end; offset += stride) {\n var x2 = flatCoordinates[offset];\n var y2 = flatCoordinates[offset + 1];\n var squaredDelta = squaredDx(x1, y1, x2, y2);\n if (squaredDelta > max) {\n max = squaredDelta;\n }\n x1 = x2;\n y1 = y2;\n }\n return max;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {number} max Max squared delta.\n * @return {number} Max squared delta.\n */\nexport function arrayMaxSquaredDelta(flatCoordinates, offset, ends, stride, max) {\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n var end = ends[i];\n max = maxSquaredDelta(flatCoordinates, offset, end, stride, max);\n offset = end;\n }\n return max;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @param {number} max Max squared delta.\n * @return {number} Max squared delta.\n */\nexport function multiArrayMaxSquaredDelta(flatCoordinates, offset, endss, stride, max) {\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n var ends = endss[i];\n max = arrayMaxSquaredDelta(flatCoordinates, offset, ends, stride, max);\n offset = ends[ends.length - 1];\n }\n return max;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} maxDelta Max delta.\n * @param {boolean} isRing Is ring.\n * @param {number} x X.\n * @param {number} y Y.\n * @param {Array<number>} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @param {Array<number>} [opt_tmpPoint] Temporary point object.\n * @return {number} Minimum squared distance.\n */\nexport function assignClosestPoint(flatCoordinates, offset, end, stride, maxDelta, isRing, x, y, closestPoint, minSquaredDistance, opt_tmpPoint) {\n if (offset == end) {\n return minSquaredDistance;\n }\n var i, squaredDistance;\n if (maxDelta === 0) {\n // All points are identical, so just test the first point.\n squaredDistance = squaredDx(x, y, flatCoordinates[offset], flatCoordinates[offset + 1]);\n if (squaredDistance < minSquaredDistance) {\n for (i = 0; i < stride; ++i) {\n closestPoint[i] = flatCoordinates[offset + i];\n }\n closestPoint.length = stride;\n return squaredDistance;\n }\n else {\n return minSquaredDistance;\n }\n }\n var tmpPoint = opt_tmpPoint ? opt_tmpPoint : [NaN, NaN];\n var index = offset + stride;\n while (index < end) {\n assignClosest(flatCoordinates, index - stride, index, stride, x, y, tmpPoint);\n squaredDistance = squaredDx(x, y, tmpPoint[0], tmpPoint[1]);\n if (squaredDistance < minSquaredDistance) {\n minSquaredDistance = squaredDistance;\n for (i = 0; i < stride; ++i) {\n closestPoint[i] = tmpPoint[i];\n }\n closestPoint.length = stride;\n index += stride;\n }\n else {\n // Skip ahead multiple points, because we know that all the skipped\n // points cannot be any closer than the closest point we have found so\n // far. We know this because we know how close the current point is, how\n // close the closest point we have found so far is, and the maximum\n // distance between consecutive points. For example, if we're currently\n // at distance 10, the best we've found so far is 3, and that the maximum\n // distance between consecutive points is 2, then we'll need to skip at\n // least (10 - 3) / 2 == 3 (rounded down) points to have any chance of\n // finding a closer point. We use Math.max(..., 1) to ensure that we\n // always advance at least one point, to avoid an infinite loop.\n index +=\n stride *\n Math.max(((Math.sqrt(squaredDistance) - Math.sqrt(minSquaredDistance)) /\n maxDelta) |\n 0, 1);\n }\n }\n if (isRing) {\n // Check the closing segment.\n assignClosest(flatCoordinates, end - stride, offset, stride, x, y, tmpPoint);\n squaredDistance = squaredDx(x, y, tmpPoint[0], tmpPoint[1]);\n if (squaredDistance < minSquaredDistance) {\n minSquaredDistance = squaredDistance;\n for (i = 0; i < stride; ++i) {\n closestPoint[i] = tmpPoint[i];\n }\n closestPoint.length = stride;\n }\n }\n return minSquaredDistance;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {number} maxDelta Max delta.\n * @param {boolean} isRing Is ring.\n * @param {number} x X.\n * @param {number} y Y.\n * @param {Array<number>} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @param {Array<number>} [opt_tmpPoint] Temporary point object.\n * @return {number} Minimum squared distance.\n */\nexport function assignClosestArrayPoint(flatCoordinates, offset, ends, stride, maxDelta, isRing, x, y, closestPoint, minSquaredDistance, opt_tmpPoint) {\n var tmpPoint = opt_tmpPoint ? opt_tmpPoint : [NaN, NaN];\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n var end = ends[i];\n minSquaredDistance = assignClosestPoint(flatCoordinates, offset, end, stride, maxDelta, isRing, x, y, closestPoint, minSquaredDistance, tmpPoint);\n offset = end;\n }\n return minSquaredDistance;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @param {number} maxDelta Max delta.\n * @param {boolean} isRing Is ring.\n * @param {number} x X.\n * @param {number} y Y.\n * @param {Array<number>} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @param {Array<number>} [opt_tmpPoint] Temporary point object.\n * @return {number} Minimum squared distance.\n */\nexport function assignClosestMultiArrayPoint(flatCoordinates, offset, endss, stride, maxDelta, isRing, x, y, closestPoint, minSquaredDistance, opt_tmpPoint) {\n var tmpPoint = opt_tmpPoint ? opt_tmpPoint : [NaN, NaN];\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n var ends = endss[i];\n minSquaredDistance = assignClosestArrayPoint(flatCoordinates, offset, ends, stride, maxDelta, isRing, x, y, closestPoint, minSquaredDistance, tmpPoint);\n offset = ends[ends.length - 1];\n }\n return minSquaredDistance;\n}\n//# sourceMappingURL=closest.js.map","/**\n * @module ol/geom/flat/deflate\n */\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {import(\"../../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {number} stride Stride.\n * @return {number} offset Offset.\n */\nexport function deflateCoordinate(flatCoordinates, offset, coordinate, stride) {\n for (var i = 0, ii = coordinate.length; i < ii; ++i) {\n flatCoordinates[offset++] = coordinate[i];\n }\n return offset;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<import(\"../../coordinate.js\").Coordinate>} coordinates Coordinates.\n * @param {number} stride Stride.\n * @return {number} offset Offset.\n */\nexport function deflateCoordinates(flatCoordinates, offset, coordinates, stride) {\n for (var i = 0, ii = coordinates.length; i < ii; ++i) {\n var coordinate = coordinates[i];\n for (var j = 0; j < stride; ++j) {\n flatCoordinates[offset++] = coordinate[j];\n }\n }\n return offset;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<import(\"../../coordinate.js\").Coordinate>>} coordinatess Coordinatess.\n * @param {number} stride Stride.\n * @param {Array<number>} [opt_ends] Ends.\n * @return {Array<number>} Ends.\n */\nexport function deflateCoordinatesArray(flatCoordinates, offset, coordinatess, stride, opt_ends) {\n var ends = opt_ends ? opt_ends : [];\n var i = 0;\n for (var j = 0, jj = coordinatess.length; j < jj; ++j) {\n var end = deflateCoordinates(flatCoordinates, offset, coordinatess[j], stride);\n ends[i++] = end;\n offset = end;\n }\n ends.length = i;\n return ends;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<Array<import(\"../../coordinate.js\").Coordinate>>>} coordinatesss Coordinatesss.\n * @param {number} stride Stride.\n * @param {Array<Array<number>>} [opt_endss] Endss.\n * @return {Array<Array<number>>} Endss.\n */\nexport function deflateMultiCoordinatesArray(flatCoordinates, offset, coordinatesss, stride, opt_endss) {\n var endss = opt_endss ? opt_endss : [];\n var i = 0;\n for (var j = 0, jj = coordinatesss.length; j < jj; ++j) {\n var ends = deflateCoordinatesArray(flatCoordinates, offset, coordinatesss[j], stride, endss[i]);\n endss[i++] = ends;\n offset = ends[ends.length - 1];\n }\n endss.length = i;\n return endss;\n}\n//# sourceMappingURL=deflate.js.map","/**\n * @module ol/geom/flat/simplify\n */\n// Based on simplify-js https://github.com/mourner/simplify-js\n// Copyright (c) 2012, Vladimir Agafonkin\n// All rights reserved.\n//\n// Redistribution and use in source and binary forms, with or without\n// modification, are permitted provided that the following conditions are met:\n//\n// 1. Redistributions of source code must retain the above copyright notice,\n// this list of conditions and the following disclaimer.\n//\n// 2. Redistributions in binary form must reproduce the above copyright\n// notice, this list of conditions and the following disclaimer in the\n// documentation and/or other materials provided with the distribution.\n//\n// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\n// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE\n// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR\n// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF\n// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS\n// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN\n// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\n// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\n// POSSIBILITY OF SUCH DAMAGE.\nimport { squaredDistance, squaredSegmentDistance } from '../../math.js';\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {boolean} highQuality Highest quality.\n * @param {Array<number>} [opt_simplifiedFlatCoordinates] Simplified flat\n * coordinates.\n * @return {Array<number>} Simplified line string.\n */\nexport function simplifyLineString(flatCoordinates, offset, end, stride, squaredTolerance, highQuality, opt_simplifiedFlatCoordinates) {\n var simplifiedFlatCoordinates = opt_simplifiedFlatCoordinates !== undefined\n ? opt_simplifiedFlatCoordinates\n : [];\n if (!highQuality) {\n end = radialDistance(flatCoordinates, offset, end, stride, squaredTolerance, simplifiedFlatCoordinates, 0);\n flatCoordinates = simplifiedFlatCoordinates;\n offset = 0;\n stride = 2;\n }\n simplifiedFlatCoordinates.length = douglasPeucker(flatCoordinates, offset, end, stride, squaredTolerance, simplifiedFlatCoordinates, 0);\n return simplifiedFlatCoordinates;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {Array<number>} simplifiedFlatCoordinates Simplified flat\n * coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @return {number} Simplified offset.\n */\nexport function douglasPeucker(flatCoordinates, offset, end, stride, squaredTolerance, simplifiedFlatCoordinates, simplifiedOffset) {\n var n = (end - offset) / stride;\n if (n < 3) {\n for (; offset < end; offset += stride) {\n simplifiedFlatCoordinates[simplifiedOffset++] = flatCoordinates[offset];\n simplifiedFlatCoordinates[simplifiedOffset++] =\n flatCoordinates[offset + 1];\n }\n return simplifiedOffset;\n }\n /** @type {Array<number>} */\n var markers = new Array(n);\n markers[0] = 1;\n markers[n - 1] = 1;\n /** @type {Array<number>} */\n var stack = [offset, end - stride];\n var index = 0;\n while (stack.length > 0) {\n var last = stack.pop();\n var first = stack.pop();\n var maxSquaredDistance = 0;\n var x1 = flatCoordinates[first];\n var y1 = flatCoordinates[first + 1];\n var x2 = flatCoordinates[last];\n var y2 = flatCoordinates[last + 1];\n for (var i = first + stride; i < last; i += stride) {\n var x = flatCoordinates[i];\n var y = flatCoordinates[i + 1];\n var squaredDistance_1 = squaredSegmentDistance(x, y, x1, y1, x2, y2);\n if (squaredDistance_1 > maxSquaredDistance) {\n index = i;\n maxSquaredDistance = squaredDistance_1;\n }\n }\n if (maxSquaredDistance > squaredTolerance) {\n markers[(index - offset) / stride] = 1;\n if (first + stride < index) {\n stack.push(first, index);\n }\n if (index + stride < last) {\n stack.push(index, last);\n }\n }\n }\n for (var i = 0; i < n; ++i) {\n if (markers[i]) {\n simplifiedFlatCoordinates[simplifiedOffset++] =\n flatCoordinates[offset + i * stride];\n simplifiedFlatCoordinates[simplifiedOffset++] =\n flatCoordinates[offset + i * stride + 1];\n }\n }\n return simplifiedOffset;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {Array<number>} simplifiedFlatCoordinates Simplified flat\n * coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @param {Array<number>} simplifiedEnds Simplified ends.\n * @return {number} Simplified offset.\n */\nexport function douglasPeuckerArray(flatCoordinates, offset, ends, stride, squaredTolerance, simplifiedFlatCoordinates, simplifiedOffset, simplifiedEnds) {\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n var end = ends[i];\n simplifiedOffset = douglasPeucker(flatCoordinates, offset, end, stride, squaredTolerance, simplifiedFlatCoordinates, simplifiedOffset);\n simplifiedEnds.push(simplifiedOffset);\n offset = end;\n }\n return simplifiedOffset;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {Array<number>} simplifiedFlatCoordinates Simplified flat\n * coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @param {Array<Array<number>>} simplifiedEndss Simplified endss.\n * @return {number} Simplified offset.\n */\nexport function douglasPeuckerMultiArray(flatCoordinates, offset, endss, stride, squaredTolerance, simplifiedFlatCoordinates, simplifiedOffset, simplifiedEndss) {\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n var ends = endss[i];\n var simplifiedEnds = [];\n simplifiedOffset = douglasPeuckerArray(flatCoordinates, offset, ends, stride, squaredTolerance, simplifiedFlatCoordinates, simplifiedOffset, simplifiedEnds);\n simplifiedEndss.push(simplifiedEnds);\n offset = ends[ends.length - 1];\n }\n return simplifiedOffset;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {Array<number>} simplifiedFlatCoordinates Simplified flat\n * coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @return {number} Simplified offset.\n */\nexport function radialDistance(flatCoordinates, offset, end, stride, squaredTolerance, simplifiedFlatCoordinates, simplifiedOffset) {\n if (end <= offset + stride) {\n // zero or one point, no simplification possible, so copy and return\n for (; offset < end; offset += stride) {\n simplifiedFlatCoordinates[simplifiedOffset++] = flatCoordinates[offset];\n simplifiedFlatCoordinates[simplifiedOffset++] =\n flatCoordinates[offset + 1];\n }\n return simplifiedOffset;\n }\n var x1 = flatCoordinates[offset];\n var y1 = flatCoordinates[offset + 1];\n // copy first point\n simplifiedFlatCoordinates[simplifiedOffset++] = x1;\n simplifiedFlatCoordinates[simplifiedOffset++] = y1;\n var x2 = x1;\n var y2 = y1;\n for (offset += stride; offset < end; offset += stride) {\n x2 = flatCoordinates[offset];\n y2 = flatCoordinates[offset + 1];\n if (squaredDistance(x1, y1, x2, y2) > squaredTolerance) {\n // copy point at offset\n simplifiedFlatCoordinates[simplifiedOffset++] = x2;\n simplifiedFlatCoordinates[simplifiedOffset++] = y2;\n x1 = x2;\n y1 = y2;\n }\n }\n if (x2 != x1 || y2 != y1) {\n // copy last point\n simplifiedFlatCoordinates[simplifiedOffset++] = x2;\n simplifiedFlatCoordinates[simplifiedOffset++] = y2;\n }\n return simplifiedOffset;\n}\n/**\n * @param {number} value Value.\n * @param {number} tolerance Tolerance.\n * @return {number} Rounded value.\n */\nexport function snap(value, tolerance) {\n return tolerance * Math.round(value / tolerance);\n}\n/**\n * Simplifies a line string using an algorithm designed by Tim Schaub.\n * Coordinates are snapped to the nearest value in a virtual grid and\n * consecutive duplicate coordinates are discarded. This effectively preserves\n * topology as the simplification of any subsection of a line string is\n * independent of the rest of the line string. This means that, for examples,\n * the common edge between two polygons will be simplified to the same line\n * string independently in both polygons. This implementation uses a single\n * pass over the coordinates and eliminates intermediate collinear points.\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} tolerance Tolerance.\n * @param {Array<number>} simplifiedFlatCoordinates Simplified flat\n * coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @return {number} Simplified offset.\n */\nexport function quantize(flatCoordinates, offset, end, stride, tolerance, simplifiedFlatCoordinates, simplifiedOffset) {\n // do nothing if the line is empty\n if (offset == end) {\n return simplifiedOffset;\n }\n // snap the first coordinate (P1)\n var x1 = snap(flatCoordinates[offset], tolerance);\n var y1 = snap(flatCoordinates[offset + 1], tolerance);\n offset += stride;\n // add the first coordinate to the output\n simplifiedFlatCoordinates[simplifiedOffset++] = x1;\n simplifiedFlatCoordinates[simplifiedOffset++] = y1;\n // find the next coordinate that does not snap to the same value as the first\n // coordinate (P2)\n var x2, y2;\n do {\n x2 = snap(flatCoordinates[offset], tolerance);\n y2 = snap(flatCoordinates[offset + 1], tolerance);\n offset += stride;\n if (offset == end) {\n // all coordinates snap to the same value, the line collapses to a point\n // push the last snapped value anyway to ensure that the output contains\n // at least two points\n // FIXME should we really return at least two points anyway?\n simplifiedFlatCoordinates[simplifiedOffset++] = x2;\n simplifiedFlatCoordinates[simplifiedOffset++] = y2;\n return simplifiedOffset;\n }\n } while (x2 == x1 && y2 == y1);\n while (offset < end) {\n // snap the next coordinate (P3)\n var x3 = snap(flatCoordinates[offset], tolerance);\n var y3 = snap(flatCoordinates[offset + 1], tolerance);\n offset += stride;\n // skip P3 if it is equal to P2\n if (x3 == x2 && y3 == y2) {\n continue;\n }\n // calculate the delta between P1 and P2\n var dx1 = x2 - x1;\n var dy1 = y2 - y1;\n // calculate the delta between P3 and P1\n var dx2 = x3 - x1;\n var dy2 = y3 - y1;\n // if P1, P2, and P3 are colinear and P3 is further from P1 than P2 is from\n // P1 in the same direction then P2 is on the straight line between P1 and\n // P3\n if (dx1 * dy2 == dy1 * dx2 &&\n ((dx1 < 0 && dx2 < dx1) || dx1 == dx2 || (dx1 > 0 && dx2 > dx1)) &&\n ((dy1 < 0 && dy2 < dy1) || dy1 == dy2 || (dy1 > 0 && dy2 > dy1))) {\n // discard P2 and set P2 = P3\n x2 = x3;\n y2 = y3;\n continue;\n }\n // either P1, P2, and P3 are not colinear, or they are colinear but P3 is\n // between P3 and P1 or on the opposite half of the line to P2. add P2,\n // and continue with P1 = P2 and P2 = P3\n simplifiedFlatCoordinates[simplifiedOffset++] = x2;\n simplifiedFlatCoordinates[simplifiedOffset++] = y2;\n x1 = x2;\n y1 = y2;\n x2 = x3;\n y2 = y3;\n }\n // add the last point (P2)\n simplifiedFlatCoordinates[simplifiedOffset++] = x2;\n simplifiedFlatCoordinates[simplifiedOffset++] = y2;\n return simplifiedOffset;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {number} tolerance Tolerance.\n * @param {Array<number>} simplifiedFlatCoordinates Simplified flat\n * coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @param {Array<number>} simplifiedEnds Simplified ends.\n * @return {number} Simplified offset.\n */\nexport function quantizeArray(flatCoordinates, offset, ends, stride, tolerance, simplifiedFlatCoordinates, simplifiedOffset, simplifiedEnds) {\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n var end = ends[i];\n simplifiedOffset = quantize(flatCoordinates, offset, end, stride, tolerance, simplifiedFlatCoordinates, simplifiedOffset);\n simplifiedEnds.push(simplifiedOffset);\n offset = end;\n }\n return simplifiedOffset;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @param {number} tolerance Tolerance.\n * @param {Array<number>} simplifiedFlatCoordinates Simplified flat\n * coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @param {Array<Array<number>>} simplifiedEndss Simplified endss.\n * @return {number} Simplified offset.\n */\nexport function quantizeMultiArray(flatCoordinates, offset, endss, stride, tolerance, simplifiedFlatCoordinates, simplifiedOffset, simplifiedEndss) {\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n var ends = endss[i];\n var simplifiedEnds = [];\n simplifiedOffset = quantizeArray(flatCoordinates, offset, ends, stride, tolerance, simplifiedFlatCoordinates, simplifiedOffset, simplifiedEnds);\n simplifiedEndss.push(simplifiedEnds);\n offset = ends[ends.length - 1];\n }\n return simplifiedOffset;\n}\n//# sourceMappingURL=simplify.js.map","/**\n * @module ol/geom/flat/segments\n */\n/**\n * This function calls `callback` for each segment of the flat coordinates\n * array. If the callback returns a truthy value the function returns that\n * value immediately. Otherwise the function returns `false`.\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {function(import(\"../../coordinate.js\").Coordinate, import(\"../../coordinate.js\").Coordinate): T} callback Function\n * called for each segment.\n * @return {T|boolean} Value.\n * @template T\n */\nexport function forEach(flatCoordinates, offset, end, stride, callback) {\n var ret;\n offset += stride;\n for (; offset < end; offset += stride) {\n ret = callback(flatCoordinates.slice(offset - stride, offset), flatCoordinates.slice(offset, offset + stride));\n if (ret) {\n return ret;\n }\n }\n return false;\n}\n//# sourceMappingURL=segments.js.map","/**\n * @module ol/geom/flat/inflate\n */\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {Array<import(\"../../coordinate.js\").Coordinate>} [opt_coordinates] Coordinates.\n * @return {Array<import(\"../../coordinate.js\").Coordinate>} Coordinates.\n */\nexport function inflateCoordinates(flatCoordinates, offset, end, stride, opt_coordinates) {\n var coordinates = opt_coordinates !== undefined ? opt_coordinates : [];\n var i = 0;\n for (var j = offset; j < end; j += stride) {\n coordinates[i++] = flatCoordinates.slice(j, j + stride);\n }\n coordinates.length = i;\n return coordinates;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {Array<Array<import(\"../../coordinate.js\").Coordinate>>} [opt_coordinatess] Coordinatess.\n * @return {Array<Array<import(\"../../coordinate.js\").Coordinate>>} Coordinatess.\n */\nexport function inflateCoordinatesArray(flatCoordinates, offset, ends, stride, opt_coordinatess) {\n var coordinatess = opt_coordinatess !== undefined ? opt_coordinatess : [];\n var i = 0;\n for (var j = 0, jj = ends.length; j < jj; ++j) {\n var end = ends[j];\n coordinatess[i++] = inflateCoordinates(flatCoordinates, offset, end, stride, coordinatess[i]);\n offset = end;\n }\n coordinatess.length = i;\n return coordinatess;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @param {Array<Array<Array<import(\"../../coordinate.js\").Coordinate>>>} [opt_coordinatesss]\n * Coordinatesss.\n * @return {Array<Array<Array<import(\"../../coordinate.js\").Coordinate>>>} Coordinatesss.\n */\nexport function inflateMultiCoordinatesArray(flatCoordinates, offset, endss, stride, opt_coordinatesss) {\n var coordinatesss = opt_coordinatesss !== undefined ? opt_coordinatesss : [];\n var i = 0;\n for (var j = 0, jj = endss.length; j < jj; ++j) {\n var ends = endss[j];\n coordinatesss[i++] = inflateCoordinatesArray(flatCoordinates, offset, ends, stride, coordinatesss[i]);\n offset = ends[ends.length - 1];\n }\n coordinatesss.length = i;\n return coordinatesss;\n}\n//# sourceMappingURL=inflate.js.map","/**\n * @module ol/geom/flat/interpolate\n */\nimport { binarySearch } from '../../array.js';\nimport { lerp } from '../../math.js';\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} fraction Fraction.\n * @param {Array<number>} [opt_dest] Destination.\n * @param {number} [opt_dimension] Destination dimension (default is `2`)\n * @return {Array<number>} Destination.\n */\nexport function interpolatePoint(flatCoordinates, offset, end, stride, fraction, opt_dest, opt_dimension) {\n var o, t;\n var n = (end - offset) / stride;\n if (n === 1) {\n o = offset;\n }\n else if (n === 2) {\n o = offset;\n t = fraction;\n }\n else if (n !== 0) {\n var x1 = flatCoordinates[offset];\n var y1 = flatCoordinates[offset + 1];\n var length_1 = 0;\n var cumulativeLengths = [0];\n for (var i = offset + stride; i < end; i += stride) {\n var x2 = flatCoordinates[i];\n var y2 = flatCoordinates[i + 1];\n length_1 += Math.sqrt((x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1));\n cumulativeLengths.push(length_1);\n x1 = x2;\n y1 = y2;\n }\n var target = fraction * length_1;\n var index = binarySearch(cumulativeLengths, target);\n if (index < 0) {\n t =\n (target - cumulativeLengths[-index - 2]) /\n (cumulativeLengths[-index - 1] - cumulativeLengths[-index - 2]);\n o = offset + (-index - 2) * stride;\n }\n else {\n o = offset + index * stride;\n }\n }\n var dimension = opt_dimension > 1 ? opt_dimension : 2;\n var dest = opt_dest ? opt_dest : new Array(dimension);\n for (var i = 0; i < dimension; ++i) {\n dest[i] =\n o === undefined\n ? NaN\n : t === undefined\n ? flatCoordinates[o + i]\n : lerp(flatCoordinates[o + i], flatCoordinates[o + stride + i], t);\n }\n return dest;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} m M.\n * @param {boolean} extrapolate Extrapolate.\n * @return {import(\"../../coordinate.js\").Coordinate} Coordinate.\n */\nexport function lineStringCoordinateAtM(flatCoordinates, offset, end, stride, m, extrapolate) {\n if (end == offset) {\n return null;\n }\n var coordinate;\n if (m < flatCoordinates[offset + stride - 1]) {\n if (extrapolate) {\n coordinate = flatCoordinates.slice(offset, offset + stride);\n coordinate[stride - 1] = m;\n return coordinate;\n }\n else {\n return null;\n }\n }\n else if (flatCoordinates[end - 1] < m) {\n if (extrapolate) {\n coordinate = flatCoordinates.slice(end - stride, end);\n coordinate[stride - 1] = m;\n return coordinate;\n }\n else {\n return null;\n }\n }\n // FIXME use O(1) search\n if (m == flatCoordinates[offset + stride - 1]) {\n return flatCoordinates.slice(offset, offset + stride);\n }\n var lo = offset / stride;\n var hi = end / stride;\n while (lo < hi) {\n var mid = (lo + hi) >> 1;\n if (m < flatCoordinates[(mid + 1) * stride - 1]) {\n hi = mid;\n }\n else {\n lo = mid + 1;\n }\n }\n var m0 = flatCoordinates[lo * stride - 1];\n if (m == m0) {\n return flatCoordinates.slice((lo - 1) * stride, (lo - 1) * stride + stride);\n }\n var m1 = flatCoordinates[(lo + 1) * stride - 1];\n var t = (m - m0) / (m1 - m0);\n coordinate = [];\n for (var i = 0; i < stride - 1; ++i) {\n coordinate.push(lerp(flatCoordinates[(lo - 1) * stride + i], flatCoordinates[lo * stride + i], t));\n }\n coordinate.push(m);\n return coordinate;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {number} m M.\n * @param {boolean} extrapolate Extrapolate.\n * @param {boolean} interpolate Interpolate.\n * @return {import(\"../../coordinate.js\").Coordinate} Coordinate.\n */\nexport function lineStringsCoordinateAtM(flatCoordinates, offset, ends, stride, m, extrapolate, interpolate) {\n if (interpolate) {\n return lineStringCoordinateAtM(flatCoordinates, offset, ends[ends.length - 1], stride, m, extrapolate);\n }\n var coordinate;\n if (m < flatCoordinates[stride - 1]) {\n if (extrapolate) {\n coordinate = flatCoordinates.slice(0, stride);\n coordinate[stride - 1] = m;\n return coordinate;\n }\n else {\n return null;\n }\n }\n if (flatCoordinates[flatCoordinates.length - 1] < m) {\n if (extrapolate) {\n coordinate = flatCoordinates.slice(flatCoordinates.length - stride);\n coordinate[stride - 1] = m;\n return coordinate;\n }\n else {\n return null;\n }\n }\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n var end = ends[i];\n if (offset == end) {\n continue;\n }\n if (m < flatCoordinates[offset + stride - 1]) {\n return null;\n }\n else if (m <= flatCoordinates[end - 1]) {\n return lineStringCoordinateAtM(flatCoordinates, offset, end, stride, m, false);\n }\n offset = end;\n }\n return null;\n}\n//# sourceMappingURL=interpolate.js.map","/**\n * @module ol/geom/flat/contains\n */\nimport { forEachCorner } from '../../extent.js';\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @return {boolean} Contains extent.\n */\nexport function linearRingContainsExtent(flatCoordinates, offset, end, stride, extent) {\n var outside = forEachCorner(extent, \n /**\n * @param {import(\"../../coordinate.js\").Coordinate} coordinate Coordinate.\n * @return {boolean} Contains (x, y).\n */\n function (coordinate) {\n return !linearRingContainsXY(flatCoordinates, offset, end, stride, coordinate[0], coordinate[1]);\n });\n return !outside;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} x X.\n * @param {number} y Y.\n * @return {boolean} Contains (x, y).\n */\nexport function linearRingContainsXY(flatCoordinates, offset, end, stride, x, y) {\n // https://geomalgorithms.com/a03-_inclusion.html\n // Copyright 2000 softSurfer, 2012 Dan Sunday\n // This code may be freely used and modified for any purpose\n // providing that this copyright notice is included with it.\n // SoftSurfer makes no warranty for this code, and cannot be held\n // liable for any real or imagined damage resulting from its use.\n // Users of this code must verify correctness for their application.\n var wn = 0;\n var x1 = flatCoordinates[end - stride];\n var y1 = flatCoordinates[end - stride + 1];\n for (; offset < end; offset += stride) {\n var x2 = flatCoordinates[offset];\n var y2 = flatCoordinates[offset + 1];\n if (y1 <= y) {\n if (y2 > y && (x2 - x1) * (y - y1) - (x - x1) * (y2 - y1) > 0) {\n wn++;\n }\n }\n else if (y2 <= y && (x2 - x1) * (y - y1) - (x - x1) * (y2 - y1) < 0) {\n wn--;\n }\n x1 = x2;\n y1 = y2;\n }\n return wn !== 0;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {number} x X.\n * @param {number} y Y.\n * @return {boolean} Contains (x, y).\n */\nexport function linearRingsContainsXY(flatCoordinates, offset, ends, stride, x, y) {\n if (ends.length === 0) {\n return false;\n }\n if (!linearRingContainsXY(flatCoordinates, offset, ends[0], stride, x, y)) {\n return false;\n }\n for (var i = 1, ii = ends.length; i < ii; ++i) {\n if (linearRingContainsXY(flatCoordinates, ends[i - 1], ends[i], stride, x, y)) {\n return false;\n }\n }\n return true;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @param {number} x X.\n * @param {number} y Y.\n * @return {boolean} Contains (x, y).\n */\nexport function linearRingssContainsXY(flatCoordinates, offset, endss, stride, x, y) {\n if (endss.length === 0) {\n return false;\n }\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n var ends = endss[i];\n if (linearRingsContainsXY(flatCoordinates, offset, ends, stride, x, y)) {\n return true;\n }\n offset = ends[ends.length - 1];\n }\n return false;\n}\n//# sourceMappingURL=contains.js.map","/**\n * @module ol/geom/flat/intersectsextent\n */\nimport { containsExtent, createEmpty, extendFlatCoordinates, intersects, intersectsSegment, } from '../../extent.js';\nimport { forEach as forEachSegment } from './segments.js';\nimport { linearRingContainsExtent, linearRingContainsXY } from './contains.js';\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @return {boolean} True if the geometry and the extent intersect.\n */\nexport function intersectsLineString(flatCoordinates, offset, end, stride, extent) {\n var coordinatesExtent = extendFlatCoordinates(createEmpty(), flatCoordinates, offset, end, stride);\n if (!intersects(extent, coordinatesExtent)) {\n return false;\n }\n if (containsExtent(extent, coordinatesExtent)) {\n return true;\n }\n if (coordinatesExtent[0] >= extent[0] && coordinatesExtent[2] <= extent[2]) {\n return true;\n }\n if (coordinatesExtent[1] >= extent[1] && coordinatesExtent[3] <= extent[3]) {\n return true;\n }\n return forEachSegment(flatCoordinates, offset, end, stride, \n /**\n * @param {import(\"../../coordinate.js\").Coordinate} point1 Start point.\n * @param {import(\"../../coordinate.js\").Coordinate} point2 End point.\n * @return {boolean} `true` if the segment and the extent intersect,\n * `false` otherwise.\n */\n function (point1, point2) {\n return intersectsSegment(extent, point1, point2);\n });\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @return {boolean} True if the geometry and the extent intersect.\n */\nexport function intersectsLineStringArray(flatCoordinates, offset, ends, stride, extent) {\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n if (intersectsLineString(flatCoordinates, offset, ends[i], stride, extent)) {\n return true;\n }\n offset = ends[i];\n }\n return false;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @return {boolean} True if the geometry and the extent intersect.\n */\nexport function intersectsLinearRing(flatCoordinates, offset, end, stride, extent) {\n if (intersectsLineString(flatCoordinates, offset, end, stride, extent)) {\n return true;\n }\n if (linearRingContainsXY(flatCoordinates, offset, end, stride, extent[0], extent[1])) {\n return true;\n }\n if (linearRingContainsXY(flatCoordinates, offset, end, stride, extent[0], extent[3])) {\n return true;\n }\n if (linearRingContainsXY(flatCoordinates, offset, end, stride, extent[2], extent[1])) {\n return true;\n }\n if (linearRingContainsXY(flatCoordinates, offset, end, stride, extent[2], extent[3])) {\n return true;\n }\n return false;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @return {boolean} True if the geometry and the extent intersect.\n */\nexport function intersectsLinearRingArray(flatCoordinates, offset, ends, stride, extent) {\n if (!intersectsLinearRing(flatCoordinates, offset, ends[0], stride, extent)) {\n return false;\n }\n if (ends.length === 1) {\n return true;\n }\n for (var i = 1, ii = ends.length; i < ii; ++i) {\n if (linearRingContainsExtent(flatCoordinates, ends[i - 1], ends[i], stride, extent)) {\n if (!intersectsLineString(flatCoordinates, ends[i - 1], ends[i], stride, extent)) {\n return false;\n }\n }\n }\n return true;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @return {boolean} True if the geometry and the extent intersect.\n */\nexport function intersectsLinearRingMultiArray(flatCoordinates, offset, endss, stride, extent) {\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n var ends = endss[i];\n if (intersectsLinearRingArray(flatCoordinates, offset, ends, stride, extent)) {\n return true;\n }\n offset = ends[ends.length - 1];\n }\n return false;\n}\n//# sourceMappingURL=intersectsextent.js.map","/**\n * @module ol/geom/flat/length\n */\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @return {number} Length.\n */\nexport function lineStringLength(flatCoordinates, offset, end, stride) {\n var x1 = flatCoordinates[offset];\n var y1 = flatCoordinates[offset + 1];\n var length = 0;\n for (var i = offset + stride; i < end; i += stride) {\n var x2 = flatCoordinates[i];\n var y2 = flatCoordinates[i + 1];\n length += Math.sqrt((x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1));\n x1 = x2;\n y1 = y2;\n }\n return length;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @return {number} Perimeter.\n */\nexport function linearRingLength(flatCoordinates, offset, end, stride) {\n var perimeter = lineStringLength(flatCoordinates, offset, end, stride);\n var dx = flatCoordinates[end - stride] - flatCoordinates[offset];\n var dy = flatCoordinates[end - stride + 1] - flatCoordinates[offset + 1];\n perimeter += Math.sqrt(dx * dx + dy * dy);\n return perimeter;\n}\n//# sourceMappingURL=length.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/geom/LineString\n */\nimport GeometryLayout from './GeometryLayout.js';\nimport GeometryType from './GeometryType.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport { assignClosestPoint, maxSquaredDelta } from './flat/closest.js';\nimport { closestSquaredDistanceXY } from '../extent.js';\nimport { deflateCoordinates } from './flat/deflate.js';\nimport { douglasPeucker } from './flat/simplify.js';\nimport { extend } from '../array.js';\nimport { forEach as forEachSegment } from './flat/segments.js';\nimport { inflateCoordinates } from './flat/inflate.js';\nimport { interpolatePoint, lineStringCoordinateAtM } from './flat/interpolate.js';\nimport { intersectsLineString } from './flat/intersectsextent.js';\nimport { lineStringLength } from './flat/length.js';\n/**\n * @classdesc\n * Linestring geometry.\n *\n * @api\n */\nvar LineString = /** @class */ (function (_super) {\n __extends(LineString, _super);\n /**\n * @param {Array<import(\"../coordinate.js\").Coordinate>|Array<number>} coordinates Coordinates.\n * For internal use, flat coordinates in combination with `opt_layout` are also accepted.\n * @param {import(\"./GeometryLayout.js\").default} [opt_layout] Layout.\n */\n function LineString(coordinates, opt_layout) {\n var _this = _super.call(this) || this;\n /**\n * @private\n * @type {import(\"../coordinate.js\").Coordinate}\n */\n _this.flatMidpoint_ = null;\n /**\n * @private\n * @type {number}\n */\n _this.flatMidpointRevision_ = -1;\n /**\n * @private\n * @type {number}\n */\n _this.maxDelta_ = -1;\n /**\n * @private\n * @type {number}\n */\n _this.maxDeltaRevision_ = -1;\n if (opt_layout !== undefined && !Array.isArray(coordinates[0])) {\n _this.setFlatCoordinates(opt_layout, \n /** @type {Array<number>} */ (coordinates));\n }\n else {\n _this.setCoordinates(\n /** @type {Array<import(\"../coordinate.js\").Coordinate>} */ (coordinates), opt_layout);\n }\n return _this;\n }\n /**\n * Append the passed coordinate to the coordinates of the linestring.\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @api\n */\n LineString.prototype.appendCoordinate = function (coordinate) {\n if (!this.flatCoordinates) {\n this.flatCoordinates = coordinate.slice();\n }\n else {\n extend(this.flatCoordinates, coordinate);\n }\n this.changed();\n };\n /**\n * Make a complete copy of the geometry.\n * @return {!LineString} Clone.\n * @api\n */\n LineString.prototype.clone = function () {\n var lineString = new LineString(this.flatCoordinates.slice(), this.layout);\n lineString.applyProperties(this);\n return lineString;\n };\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n */\n LineString.prototype.closestPointXY = function (x, y, closestPoint, minSquaredDistance) {\n if (minSquaredDistance < closestSquaredDistanceXY(this.getExtent(), x, y)) {\n return minSquaredDistance;\n }\n if (this.maxDeltaRevision_ != this.getRevision()) {\n this.maxDelta_ = Math.sqrt(maxSquaredDelta(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, 0));\n this.maxDeltaRevision_ = this.getRevision();\n }\n return assignClosestPoint(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, this.maxDelta_, false, x, y, closestPoint, minSquaredDistance);\n };\n /**\n * Iterate over each segment, calling the provided callback.\n * If the callback returns a truthy value the function returns that\n * value immediately. Otherwise the function returns `false`.\n *\n * @param {function(this: S, import(\"../coordinate.js\").Coordinate, import(\"../coordinate.js\").Coordinate): T} callback Function\n * called for each segment. The function will receive two arguments, the start and end coordinates of the segment.\n * @return {T|boolean} Value.\n * @template T,S\n * @api\n */\n LineString.prototype.forEachSegment = function (callback) {\n return forEachSegment(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, callback);\n };\n /**\n * Returns the coordinate at `m` using linear interpolation, or `null` if no\n * such coordinate exists.\n *\n * `opt_extrapolate` controls extrapolation beyond the range of Ms in the\n * MultiLineString. If `opt_extrapolate` is `true` then Ms less than the first\n * M will return the first coordinate and Ms greater than the last M will\n * return the last coordinate.\n *\n * @param {number} m M.\n * @param {boolean} [opt_extrapolate] Extrapolate. Default is `false`.\n * @return {import(\"../coordinate.js\").Coordinate} Coordinate.\n * @api\n */\n LineString.prototype.getCoordinateAtM = function (m, opt_extrapolate) {\n if (this.layout != GeometryLayout.XYM &&\n this.layout != GeometryLayout.XYZM) {\n return null;\n }\n var extrapolate = opt_extrapolate !== undefined ? opt_extrapolate : false;\n return lineStringCoordinateAtM(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, m, extrapolate);\n };\n /**\n * Return the coordinates of the linestring.\n * @return {Array<import(\"../coordinate.js\").Coordinate>} Coordinates.\n * @api\n */\n LineString.prototype.getCoordinates = function () {\n return inflateCoordinates(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride);\n };\n /**\n * Return the coordinate at the provided fraction along the linestring.\n * The `fraction` is a number between 0 and 1, where 0 is the start of the\n * linestring and 1 is the end.\n * @param {number} fraction Fraction.\n * @param {import(\"../coordinate.js\").Coordinate} [opt_dest] Optional coordinate whose values will\n * be modified. If not provided, a new coordinate will be returned.\n * @return {import(\"../coordinate.js\").Coordinate} Coordinate of the interpolated point.\n * @api\n */\n LineString.prototype.getCoordinateAt = function (fraction, opt_dest) {\n return interpolatePoint(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, fraction, opt_dest, this.stride);\n };\n /**\n * Return the length of the linestring on projected plane.\n * @return {number} Length (on projected plane).\n * @api\n */\n LineString.prototype.getLength = function () {\n return lineStringLength(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride);\n };\n /**\n * @return {Array<number>} Flat midpoint.\n */\n LineString.prototype.getFlatMidpoint = function () {\n if (this.flatMidpointRevision_ != this.getRevision()) {\n this.flatMidpoint_ = this.getCoordinateAt(0.5, this.flatMidpoint_);\n this.flatMidpointRevision_ = this.getRevision();\n }\n return this.flatMidpoint_;\n };\n /**\n * @param {number} squaredTolerance Squared tolerance.\n * @return {LineString} Simplified LineString.\n * @protected\n */\n LineString.prototype.getSimplifiedGeometryInternal = function (squaredTolerance) {\n var simplifiedFlatCoordinates = [];\n simplifiedFlatCoordinates.length = douglasPeucker(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, squaredTolerance, simplifiedFlatCoordinates, 0);\n return new LineString(simplifiedFlatCoordinates, GeometryLayout.XY);\n };\n /**\n * Get the type of this geometry.\n * @return {import(\"./GeometryType.js\").default} Geometry type.\n * @api\n */\n LineString.prototype.getType = function () {\n return GeometryType.LINE_STRING;\n };\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n */\n LineString.prototype.intersectsExtent = function (extent) {\n return intersectsLineString(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, extent);\n };\n /**\n * Set the coordinates of the linestring.\n * @param {!Array<import(\"../coordinate.js\").Coordinate>} coordinates Coordinates.\n * @param {import(\"./GeometryLayout.js\").default} [opt_layout] Layout.\n * @api\n */\n LineString.prototype.setCoordinates = function (coordinates, opt_layout) {\n this.setLayout(opt_layout, coordinates, 1);\n if (!this.flatCoordinates) {\n this.flatCoordinates = [];\n }\n this.flatCoordinates.length = deflateCoordinates(this.flatCoordinates, 0, coordinates, this.stride);\n this.changed();\n };\n return LineString;\n}(SimpleGeometry));\nexport default LineString;\n//# sourceMappingURL=LineString.js.map","/**\n * @module ol/geom/flat/area\n */\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @return {number} Area.\n */\nexport function linearRing(flatCoordinates, offset, end, stride) {\n var twiceArea = 0;\n var x1 = flatCoordinates[end - stride];\n var y1 = flatCoordinates[end - stride + 1];\n for (; offset < end; offset += stride) {\n var x2 = flatCoordinates[offset];\n var y2 = flatCoordinates[offset + 1];\n twiceArea += y1 * x2 - x1 * y2;\n x1 = x2;\n y1 = y2;\n }\n return twiceArea / 2;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @return {number} Area.\n */\nexport function linearRings(flatCoordinates, offset, ends, stride) {\n var area = 0;\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n var end = ends[i];\n area += linearRing(flatCoordinates, offset, end, stride);\n offset = end;\n }\n return area;\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @return {number} Area.\n */\nexport function linearRingss(flatCoordinates, offset, endss, stride) {\n var area = 0;\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n var ends = endss[i];\n area += linearRings(flatCoordinates, offset, ends, stride);\n offset = ends[ends.length - 1];\n }\n return area;\n}\n//# sourceMappingURL=area.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/geom/LinearRing\n */\nimport GeometryLayout from './GeometryLayout.js';\nimport GeometryType from './GeometryType.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport { assignClosestPoint, maxSquaredDelta } from './flat/closest.js';\nimport { closestSquaredDistanceXY } from '../extent.js';\nimport { deflateCoordinates } from './flat/deflate.js';\nimport { douglasPeucker } from './flat/simplify.js';\nimport { inflateCoordinates } from './flat/inflate.js';\nimport { linearRing as linearRingArea } from './flat/area.js';\n/**\n * @classdesc\n * Linear ring geometry. Only used as part of polygon; cannot be rendered\n * on its own.\n *\n * @api\n */\nvar LinearRing = /** @class */ (function (_super) {\n __extends(LinearRing, _super);\n /**\n * @param {Array<import(\"../coordinate.js\").Coordinate>|Array<number>} coordinates Coordinates.\n * For internal use, flat coordinates in combination with `opt_layout` are also accepted.\n * @param {import(\"./GeometryLayout.js\").default} [opt_layout] Layout.\n */\n function LinearRing(coordinates, opt_layout) {\n var _this = _super.call(this) || this;\n /**\n * @private\n * @type {number}\n */\n _this.maxDelta_ = -1;\n /**\n * @private\n * @type {number}\n */\n _this.maxDeltaRevision_ = -1;\n if (opt_layout !== undefined && !Array.isArray(coordinates[0])) {\n _this.setFlatCoordinates(opt_layout, \n /** @type {Array<number>} */ (coordinates));\n }\n else {\n _this.setCoordinates(\n /** @type {Array<import(\"../coordinate.js\").Coordinate>} */ (coordinates), opt_layout);\n }\n return _this;\n }\n /**\n * Make a complete copy of the geometry.\n * @return {!LinearRing} Clone.\n * @api\n */\n LinearRing.prototype.clone = function () {\n return new LinearRing(this.flatCoordinates.slice(), this.layout);\n };\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n */\n LinearRing.prototype.closestPointXY = function (x, y, closestPoint, minSquaredDistance) {\n if (minSquaredDistance < closestSquaredDistanceXY(this.getExtent(), x, y)) {\n return minSquaredDistance;\n }\n if (this.maxDeltaRevision_ != this.getRevision()) {\n this.maxDelta_ = Math.sqrt(maxSquaredDelta(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, 0));\n this.maxDeltaRevision_ = this.getRevision();\n }\n return assignClosestPoint(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, this.maxDelta_, true, x, y, closestPoint, minSquaredDistance);\n };\n /**\n * Return the area of the linear ring on projected plane.\n * @return {number} Area (on projected plane).\n * @api\n */\n LinearRing.prototype.getArea = function () {\n return linearRingArea(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride);\n };\n /**\n * Return the coordinates of the linear ring.\n * @return {Array<import(\"../coordinate.js\").Coordinate>} Coordinates.\n * @api\n */\n LinearRing.prototype.getCoordinates = function () {\n return inflateCoordinates(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride);\n };\n /**\n * @param {number} squaredTolerance Squared tolerance.\n * @return {LinearRing} Simplified LinearRing.\n * @protected\n */\n LinearRing.prototype.getSimplifiedGeometryInternal = function (squaredTolerance) {\n var simplifiedFlatCoordinates = [];\n simplifiedFlatCoordinates.length = douglasPeucker(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride, squaredTolerance, simplifiedFlatCoordinates, 0);\n return new LinearRing(simplifiedFlatCoordinates, GeometryLayout.XY);\n };\n /**\n * Get the type of this geometry.\n * @return {import(\"./GeometryType.js\").default} Geometry type.\n * @api\n */\n LinearRing.prototype.getType = function () {\n return GeometryType.LINEAR_RING;\n };\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n */\n LinearRing.prototype.intersectsExtent = function (extent) {\n return false;\n };\n /**\n * Set the coordinates of the linear ring.\n * @param {!Array<import(\"../coordinate.js\").Coordinate>} coordinates Coordinates.\n * @param {import(\"./GeometryLayout.js\").default} [opt_layout] Layout.\n * @api\n */\n LinearRing.prototype.setCoordinates = function (coordinates, opt_layout) {\n this.setLayout(opt_layout, coordinates, 1);\n if (!this.flatCoordinates) {\n this.flatCoordinates = [];\n }\n this.flatCoordinates.length = deflateCoordinates(this.flatCoordinates, 0, coordinates, this.stride);\n this.changed();\n };\n return LinearRing;\n}(SimpleGeometry));\nexport default LinearRing;\n//# sourceMappingURL=LinearRing.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/geom/MultiLineString\n */\nimport GeometryLayout from './GeometryLayout.js';\nimport GeometryType from './GeometryType.js';\nimport LineString from './LineString.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport { arrayMaxSquaredDelta, assignClosestArrayPoint } from './flat/closest.js';\nimport { closestSquaredDistanceXY } from '../extent.js';\nimport { deflateCoordinatesArray } from './flat/deflate.js';\nimport { douglasPeuckerArray } from './flat/simplify.js';\nimport { extend } from '../array.js';\nimport { inflateCoordinatesArray } from './flat/inflate.js';\nimport { interpolatePoint, lineStringsCoordinateAtM, } from './flat/interpolate.js';\nimport { intersectsLineStringArray } from './flat/intersectsextent.js';\n/**\n * @classdesc\n * Multi-linestring geometry.\n *\n * @api\n */\nvar MultiLineString = /** @class */ (function (_super) {\n __extends(MultiLineString, _super);\n /**\n * @param {Array<Array<import(\"../coordinate.js\").Coordinate>|LineString>|Array<number>} coordinates\n * Coordinates or LineString geometries. (For internal use, flat coordinates in\n * combination with `opt_layout` and `opt_ends` are also accepted.)\n * @param {import(\"./GeometryLayout.js\").default} [opt_layout] Layout.\n * @param {Array<number>} [opt_ends] Flat coordinate ends for internal use.\n */\n function MultiLineString(coordinates, opt_layout, opt_ends) {\n var _this = _super.call(this) || this;\n /**\n * @type {Array<number>}\n * @private\n */\n _this.ends_ = [];\n /**\n * @private\n * @type {number}\n */\n _this.maxDelta_ = -1;\n /**\n * @private\n * @type {number}\n */\n _this.maxDeltaRevision_ = -1;\n if (Array.isArray(coordinates[0])) {\n _this.setCoordinates(\n /** @type {Array<Array<import(\"../coordinate.js\").Coordinate>>} */ (coordinates), opt_layout);\n }\n else if (opt_layout !== undefined && opt_ends) {\n _this.setFlatCoordinates(opt_layout, \n /** @type {Array<number>} */ (coordinates));\n _this.ends_ = opt_ends;\n }\n else {\n var layout = _this.getLayout();\n var lineStrings = /** @type {Array<LineString>} */ (coordinates);\n var flatCoordinates = [];\n var ends = [];\n for (var i = 0, ii = lineStrings.length; i < ii; ++i) {\n var lineString = lineStrings[i];\n if (i === 0) {\n layout = lineString.getLayout();\n }\n extend(flatCoordinates, lineString.getFlatCoordinates());\n ends.push(flatCoordinates.length);\n }\n _this.setFlatCoordinates(layout, flatCoordinates);\n _this.ends_ = ends;\n }\n return _this;\n }\n /**\n * Append the passed linestring to the multilinestring.\n * @param {LineString} lineString LineString.\n * @api\n */\n MultiLineString.prototype.appendLineString = function (lineString) {\n if (!this.flatCoordinates) {\n this.flatCoordinates = lineString.getFlatCoordinates().slice();\n }\n else {\n extend(this.flatCoordinates, lineString.getFlatCoordinates().slice());\n }\n this.ends_.push(this.flatCoordinates.length);\n this.changed();\n };\n /**\n * Make a complete copy of the geometry.\n * @return {!MultiLineString} Clone.\n * @api\n */\n MultiLineString.prototype.clone = function () {\n var multiLineString = new MultiLineString(this.flatCoordinates.slice(), this.layout, this.ends_.slice());\n multiLineString.applyProperties(this);\n return multiLineString;\n };\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n */\n MultiLineString.prototype.closestPointXY = function (x, y, closestPoint, minSquaredDistance) {\n if (minSquaredDistance < closestSquaredDistanceXY(this.getExtent(), x, y)) {\n return minSquaredDistance;\n }\n if (this.maxDeltaRevision_ != this.getRevision()) {\n this.maxDelta_ = Math.sqrt(arrayMaxSquaredDelta(this.flatCoordinates, 0, this.ends_, this.stride, 0));\n this.maxDeltaRevision_ = this.getRevision();\n }\n return assignClosestArrayPoint(this.flatCoordinates, 0, this.ends_, this.stride, this.maxDelta_, false, x, y, closestPoint, minSquaredDistance);\n };\n /**\n * Returns the coordinate at `m` using linear interpolation, or `null` if no\n * such coordinate exists.\n *\n * `opt_extrapolate` controls extrapolation beyond the range of Ms in the\n * MultiLineString. If `opt_extrapolate` is `true` then Ms less than the first\n * M will return the first coordinate and Ms greater than the last M will\n * return the last coordinate.\n *\n * `opt_interpolate` controls interpolation between consecutive LineStrings\n * within the MultiLineString. If `opt_interpolate` is `true` the coordinates\n * will be linearly interpolated between the last coordinate of one LineString\n * and the first coordinate of the next LineString. If `opt_interpolate` is\n * `false` then the function will return `null` for Ms falling between\n * LineStrings.\n *\n * @param {number} m M.\n * @param {boolean} [opt_extrapolate] Extrapolate. Default is `false`.\n * @param {boolean} [opt_interpolate] Interpolate. Default is `false`.\n * @return {import(\"../coordinate.js\").Coordinate} Coordinate.\n * @api\n */\n MultiLineString.prototype.getCoordinateAtM = function (m, opt_extrapolate, opt_interpolate) {\n if ((this.layout != GeometryLayout.XYM &&\n this.layout != GeometryLayout.XYZM) ||\n this.flatCoordinates.length === 0) {\n return null;\n }\n var extrapolate = opt_extrapolate !== undefined ? opt_extrapolate : false;\n var interpolate = opt_interpolate !== undefined ? opt_interpolate : false;\n return lineStringsCoordinateAtM(this.flatCoordinates, 0, this.ends_, this.stride, m, extrapolate, interpolate);\n };\n /**\n * Return the coordinates of the multilinestring.\n * @return {Array<Array<import(\"../coordinate.js\").Coordinate>>} Coordinates.\n * @api\n */\n MultiLineString.prototype.getCoordinates = function () {\n return inflateCoordinatesArray(this.flatCoordinates, 0, this.ends_, this.stride);\n };\n /**\n * @return {Array<number>} Ends.\n */\n MultiLineString.prototype.getEnds = function () {\n return this.ends_;\n };\n /**\n * Return the linestring at the specified index.\n * @param {number} index Index.\n * @return {LineString} LineString.\n * @api\n */\n MultiLineString.prototype.getLineString = function (index) {\n if (index < 0 || this.ends_.length <= index) {\n return null;\n }\n return new LineString(this.flatCoordinates.slice(index === 0 ? 0 : this.ends_[index - 1], this.ends_[index]), this.layout);\n };\n /**\n * Return the linestrings of this multilinestring.\n * @return {Array<LineString>} LineStrings.\n * @api\n */\n MultiLineString.prototype.getLineStrings = function () {\n var flatCoordinates = this.flatCoordinates;\n var ends = this.ends_;\n var layout = this.layout;\n /** @type {Array<LineString>} */\n var lineStrings = [];\n var offset = 0;\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n var end = ends[i];\n var lineString = new LineString(flatCoordinates.slice(offset, end), layout);\n lineStrings.push(lineString);\n offset = end;\n }\n return lineStrings;\n };\n /**\n * @return {Array<number>} Flat midpoints.\n */\n MultiLineString.prototype.getFlatMidpoints = function () {\n var midpoints = [];\n var flatCoordinates = this.flatCoordinates;\n var offset = 0;\n var ends = this.ends_;\n var stride = this.stride;\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n var end = ends[i];\n var midpoint = interpolatePoint(flatCoordinates, offset, end, stride, 0.5);\n extend(midpoints, midpoint);\n offset = end;\n }\n return midpoints;\n };\n /**\n * @param {number} squaredTolerance Squared tolerance.\n * @return {MultiLineString} Simplified MultiLineString.\n * @protected\n */\n MultiLineString.prototype.getSimplifiedGeometryInternal = function (squaredTolerance) {\n var simplifiedFlatCoordinates = [];\n var simplifiedEnds = [];\n simplifiedFlatCoordinates.length = douglasPeuckerArray(this.flatCoordinates, 0, this.ends_, this.stride, squaredTolerance, simplifiedFlatCoordinates, 0, simplifiedEnds);\n return new MultiLineString(simplifiedFlatCoordinates, GeometryLayout.XY, simplifiedEnds);\n };\n /**\n * Get the type of this geometry.\n * @return {import(\"./GeometryType.js\").default} Geometry type.\n * @api\n */\n MultiLineString.prototype.getType = function () {\n return GeometryType.MULTI_LINE_STRING;\n };\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n */\n MultiLineString.prototype.intersectsExtent = function (extent) {\n return intersectsLineStringArray(this.flatCoordinates, 0, this.ends_, this.stride, extent);\n };\n /**\n * Set the coordinates of the multilinestring.\n * @param {!Array<Array<import(\"../coordinate.js\").Coordinate>>} coordinates Coordinates.\n * @param {GeometryLayout} [opt_layout] Layout.\n * @api\n */\n MultiLineString.prototype.setCoordinates = function (coordinates, opt_layout) {\n this.setLayout(opt_layout, coordinates, 2);\n if (!this.flatCoordinates) {\n this.flatCoordinates = [];\n }\n var ends = deflateCoordinatesArray(this.flatCoordinates, 0, coordinates, this.stride, this.ends_);\n this.flatCoordinates.length = ends.length === 0 ? 0 : ends[ends.length - 1];\n this.changed();\n };\n return MultiLineString;\n}(SimpleGeometry));\nexport default MultiLineString;\n//# sourceMappingURL=MultiLineString.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/geom/Point\n */\nimport GeometryType from './GeometryType.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport { containsXY, createOrUpdateFromCoordinate } from '../extent.js';\nimport { deflateCoordinate } from './flat/deflate.js';\nimport { squaredDistance as squaredDx } from '../math.js';\n/**\n * @classdesc\n * Point geometry.\n *\n * @api\n */\nvar Point = /** @class */ (function (_super) {\n __extends(Point, _super);\n /**\n * @param {import(\"../coordinate.js\").Coordinate} coordinates Coordinates.\n * @param {import(\"./GeometryLayout.js\").default} [opt_layout] Layout.\n */\n function Point(coordinates, opt_layout) {\n var _this = _super.call(this) || this;\n _this.setCoordinates(coordinates, opt_layout);\n return _this;\n }\n /**\n * Make a complete copy of the geometry.\n * @return {!Point} Clone.\n * @api\n */\n Point.prototype.clone = function () {\n var point = new Point(this.flatCoordinates.slice(), this.layout);\n point.applyProperties(this);\n return point;\n };\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n */\n Point.prototype.closestPointXY = function (x, y, closestPoint, minSquaredDistance) {\n var flatCoordinates = this.flatCoordinates;\n var squaredDistance = squaredDx(x, y, flatCoordinates[0], flatCoordinates[1]);\n if (squaredDistance < minSquaredDistance) {\n var stride = this.stride;\n for (var i = 0; i < stride; ++i) {\n closestPoint[i] = flatCoordinates[i];\n }\n closestPoint.length = stride;\n return squaredDistance;\n }\n else {\n return minSquaredDistance;\n }\n };\n /**\n * Return the coordinate of the point.\n * @return {import(\"../coordinate.js\").Coordinate} Coordinates.\n * @api\n */\n Point.prototype.getCoordinates = function () {\n return !this.flatCoordinates ? [] : this.flatCoordinates.slice();\n };\n /**\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @protected\n * @return {import(\"../extent.js\").Extent} extent Extent.\n */\n Point.prototype.computeExtent = function (extent) {\n return createOrUpdateFromCoordinate(this.flatCoordinates, extent);\n };\n /**\n * Get the type of this geometry.\n * @return {import(\"./GeometryType.js\").default} Geometry type.\n * @api\n */\n Point.prototype.getType = function () {\n return GeometryType.POINT;\n };\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n */\n Point.prototype.intersectsExtent = function (extent) {\n return containsXY(extent, this.flatCoordinates[0], this.flatCoordinates[1]);\n };\n /**\n * @param {!Array<*>} coordinates Coordinates.\n * @param {import(\"./GeometryLayout.js\").default} [opt_layout] Layout.\n * @api\n */\n Point.prototype.setCoordinates = function (coordinates, opt_layout) {\n this.setLayout(opt_layout, coordinates, 0);\n if (!this.flatCoordinates) {\n this.flatCoordinates = [];\n }\n this.flatCoordinates.length = deflateCoordinate(this.flatCoordinates, 0, coordinates, this.stride);\n this.changed();\n };\n return Point;\n}(SimpleGeometry));\nexport default Point;\n//# sourceMappingURL=Point.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/geom/MultiPoint\n */\nimport GeometryType from './GeometryType.js';\nimport Point from './Point.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport { closestSquaredDistanceXY, containsXY } from '../extent.js';\nimport { deflateCoordinates } from './flat/deflate.js';\nimport { extend } from '../array.js';\nimport { inflateCoordinates } from './flat/inflate.js';\nimport { squaredDistance as squaredDx } from '../math.js';\n/**\n * @classdesc\n * Multi-point geometry.\n *\n * @api\n */\nvar MultiPoint = /** @class */ (function (_super) {\n __extends(MultiPoint, _super);\n /**\n * @param {Array<import(\"../coordinate.js\").Coordinate>|Array<number>} coordinates Coordinates.\n * For internal use, flat coordinates in combination with `opt_layout` are also accepted.\n * @param {import(\"./GeometryLayout.js\").default} [opt_layout] Layout.\n */\n function MultiPoint(coordinates, opt_layout) {\n var _this = _super.call(this) || this;\n if (opt_layout && !Array.isArray(coordinates[0])) {\n _this.setFlatCoordinates(opt_layout, \n /** @type {Array<number>} */ (coordinates));\n }\n else {\n _this.setCoordinates(\n /** @type {Array<import(\"../coordinate.js\").Coordinate>} */ (coordinates), opt_layout);\n }\n return _this;\n }\n /**\n * Append the passed point to this multipoint.\n * @param {Point} point Point.\n * @api\n */\n MultiPoint.prototype.appendPoint = function (point) {\n if (!this.flatCoordinates) {\n this.flatCoordinates = point.getFlatCoordinates().slice();\n }\n else {\n extend(this.flatCoordinates, point.getFlatCoordinates());\n }\n this.changed();\n };\n /**\n * Make a complete copy of the geometry.\n * @return {!MultiPoint} Clone.\n * @api\n */\n MultiPoint.prototype.clone = function () {\n var multiPoint = new MultiPoint(this.flatCoordinates.slice(), this.layout);\n multiPoint.applyProperties(this);\n return multiPoint;\n };\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n */\n MultiPoint.prototype.closestPointXY = function (x, y, closestPoint, minSquaredDistance) {\n if (minSquaredDistance < closestSquaredDistanceXY(this.getExtent(), x, y)) {\n return minSquaredDistance;\n }\n var flatCoordinates = this.flatCoordinates;\n var stride = this.stride;\n for (var i = 0, ii = flatCoordinates.length; i < ii; i += stride) {\n var squaredDistance = squaredDx(x, y, flatCoordinates[i], flatCoordinates[i + 1]);\n if (squaredDistance < minSquaredDistance) {\n minSquaredDistance = squaredDistance;\n for (var j = 0; j < stride; ++j) {\n closestPoint[j] = flatCoordinates[i + j];\n }\n closestPoint.length = stride;\n }\n }\n return minSquaredDistance;\n };\n /**\n * Return the coordinates of the multipoint.\n * @return {Array<import(\"../coordinate.js\").Coordinate>} Coordinates.\n * @api\n */\n MultiPoint.prototype.getCoordinates = function () {\n return inflateCoordinates(this.flatCoordinates, 0, this.flatCoordinates.length, this.stride);\n };\n /**\n * Return the point at the specified index.\n * @param {number} index Index.\n * @return {Point} Point.\n * @api\n */\n MultiPoint.prototype.getPoint = function (index) {\n var n = !this.flatCoordinates\n ? 0\n : this.flatCoordinates.length / this.stride;\n if (index < 0 || n <= index) {\n return null;\n }\n return new Point(this.flatCoordinates.slice(index * this.stride, (index + 1) * this.stride), this.layout);\n };\n /**\n * Return the points of this multipoint.\n * @return {Array<Point>} Points.\n * @api\n */\n MultiPoint.prototype.getPoints = function () {\n var flatCoordinates = this.flatCoordinates;\n var layout = this.layout;\n var stride = this.stride;\n /** @type {Array<Point>} */\n var points = [];\n for (var i = 0, ii = flatCoordinates.length; i < ii; i += stride) {\n var point = new Point(flatCoordinates.slice(i, i + stride), layout);\n points.push(point);\n }\n return points;\n };\n /**\n * Get the type of this geometry.\n * @return {import(\"./GeometryType.js\").default} Geometry type.\n * @api\n */\n MultiPoint.prototype.getType = function () {\n return GeometryType.MULTI_POINT;\n };\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n */\n MultiPoint.prototype.intersectsExtent = function (extent) {\n var flatCoordinates = this.flatCoordinates;\n var stride = this.stride;\n for (var i = 0, ii = flatCoordinates.length; i < ii; i += stride) {\n var x = flatCoordinates[i];\n var y = flatCoordinates[i + 1];\n if (containsXY(extent, x, y)) {\n return true;\n }\n }\n return false;\n };\n /**\n * Set the coordinates of the multipoint.\n * @param {!Array<import(\"../coordinate.js\").Coordinate>} coordinates Coordinates.\n * @param {import(\"./GeometryLayout.js\").default} [opt_layout] Layout.\n * @api\n */\n MultiPoint.prototype.setCoordinates = function (coordinates, opt_layout) {\n this.setLayout(opt_layout, coordinates, 1);\n if (!this.flatCoordinates) {\n this.flatCoordinates = [];\n }\n this.flatCoordinates.length = deflateCoordinates(this.flatCoordinates, 0, coordinates, this.stride);\n this.changed();\n };\n return MultiPoint;\n}(SimpleGeometry));\nexport default MultiPoint;\n//# sourceMappingURL=MultiPoint.js.map","/**\n * @module ol/geom/flat/interiorpoint\n */\nimport { linearRingsContainsXY } from './contains.js';\nimport { numberSafeCompareFunction } from '../../array.js';\n/**\n * Calculates a point that is likely to lie in the interior of the linear rings.\n * Inspired by JTS's com.vividsolutions.jts.geom.Geometry#getInteriorPoint.\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {Array<number>} flatCenters Flat centers.\n * @param {number} flatCentersOffset Flat center offset.\n * @param {Array<number>} [opt_dest] Destination.\n * @return {Array<number>} Destination point as XYM coordinate, where M is the\n * length of the horizontal intersection that the point belongs to.\n */\nexport function getInteriorPointOfArray(flatCoordinates, offset, ends, stride, flatCenters, flatCentersOffset, opt_dest) {\n var i, ii, x, x1, x2, y1, y2;\n var y = flatCenters[flatCentersOffset + 1];\n /** @type {Array<number>} */\n var intersections = [];\n // Calculate intersections with the horizontal line\n for (var r = 0, rr = ends.length; r < rr; ++r) {\n var end = ends[r];\n x1 = flatCoordinates[end - stride];\n y1 = flatCoordinates[end - stride + 1];\n for (i = offset; i < end; i += stride) {\n x2 = flatCoordinates[i];\n y2 = flatCoordinates[i + 1];\n if ((y <= y1 && y2 <= y) || (y1 <= y && y <= y2)) {\n x = ((y - y1) / (y2 - y1)) * (x2 - x1) + x1;\n intersections.push(x);\n }\n x1 = x2;\n y1 = y2;\n }\n }\n // Find the longest segment of the horizontal line that has its center point\n // inside the linear ring.\n var pointX = NaN;\n var maxSegmentLength = -Infinity;\n intersections.sort(numberSafeCompareFunction);\n x1 = intersections[0];\n for (i = 1, ii = intersections.length; i < ii; ++i) {\n x2 = intersections[i];\n var segmentLength = Math.abs(x2 - x1);\n if (segmentLength > maxSegmentLength) {\n x = (x1 + x2) / 2;\n if (linearRingsContainsXY(flatCoordinates, offset, ends, stride, x, y)) {\n pointX = x;\n maxSegmentLength = segmentLength;\n }\n }\n x1 = x2;\n }\n if (isNaN(pointX)) {\n // There is no horizontal line that has its center point inside the linear\n // ring. Use the center of the the linear ring's extent.\n pointX = flatCenters[flatCentersOffset];\n }\n if (opt_dest) {\n opt_dest.push(pointX, y, maxSegmentLength);\n return opt_dest;\n }\n else {\n return [pointX, y, maxSegmentLength];\n }\n}\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @param {Array<number>} flatCenters Flat centers.\n * @return {Array<number>} Interior points as XYM coordinates, where M is the\n * length of the horizontal intersection that the point belongs to.\n */\nexport function getInteriorPointsOfMultiArray(flatCoordinates, offset, endss, stride, flatCenters) {\n var interiorPoints = [];\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n var ends = endss[i];\n interiorPoints = getInteriorPointOfArray(flatCoordinates, offset, ends, stride, flatCenters, 2 * i, interiorPoints);\n offset = ends[ends.length - 1];\n }\n return interiorPoints;\n}\n//# sourceMappingURL=interiorpoint.js.map","/**\n * @module ol/geom/flat/reverse\n */\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n */\nexport function coordinates(flatCoordinates, offset, end, stride) {\n while (offset < end - stride) {\n for (var i = 0; i < stride; ++i) {\n var tmp = flatCoordinates[offset + i];\n flatCoordinates[offset + i] = flatCoordinates[end - stride + i];\n flatCoordinates[end - stride + i] = tmp;\n }\n offset += stride;\n end -= stride;\n }\n}\n//# sourceMappingURL=reverse.js.map","/**\n * @module ol/geom/flat/orient\n */\nimport { coordinates as reverseCoordinates } from './reverse.js';\n/**\n * Is the linear ring oriented clockwise in a coordinate system with a bottom-left\n * coordinate origin? For a coordinate system with a top-left coordinate origin,\n * the ring's orientation is clockwise when this function returns false.\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @return {boolean} Is clockwise.\n */\nexport function linearRingIsClockwise(flatCoordinates, offset, end, stride) {\n // https://stackoverflow.com/q/1165647/clockwise-method#1165943\n // https://github.com/OSGeo/gdal/blob/master/gdal/ogr/ogrlinearring.cpp\n var edge = 0;\n var x1 = flatCoordinates[end - stride];\n var y1 = flatCoordinates[end - stride + 1];\n for (; offset < end; offset += stride) {\n var x2 = flatCoordinates[offset];\n var y2 = flatCoordinates[offset + 1];\n edge += (x2 - x1) * (y2 + y1);\n x1 = x2;\n y1 = y2;\n }\n return edge === 0 ? undefined : edge > 0;\n}\n/**\n * Determines if linear rings are oriented. By default, left-hand orientation\n * is tested (first ring must be clockwise, remaining rings counter-clockwise).\n * To test for right-hand orientation, use the `opt_right` argument.\n *\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Array of end indexes.\n * @param {number} stride Stride.\n * @param {boolean} [opt_right] Test for right-hand orientation\n * (counter-clockwise exterior ring and clockwise interior rings).\n * @return {boolean} Rings are correctly oriented.\n */\nexport function linearRingsAreOriented(flatCoordinates, offset, ends, stride, opt_right) {\n var right = opt_right !== undefined ? opt_right : false;\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n var end = ends[i];\n var isClockwise = linearRingIsClockwise(flatCoordinates, offset, end, stride);\n if (i === 0) {\n if ((right && isClockwise) || (!right && !isClockwise)) {\n return false;\n }\n }\n else {\n if ((right && !isClockwise) || (!right && isClockwise)) {\n return false;\n }\n }\n offset = end;\n }\n return true;\n}\n/**\n * Determines if linear rings are oriented. By default, left-hand orientation\n * is tested (first ring must be clockwise, remaining rings counter-clockwise).\n * To test for right-hand orientation, use the `opt_right` argument.\n *\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Array of array of end indexes.\n * @param {number} stride Stride.\n * @param {boolean} [opt_right] Test for right-hand orientation\n * (counter-clockwise exterior ring and clockwise interior rings).\n * @return {boolean} Rings are correctly oriented.\n */\nexport function linearRingssAreOriented(flatCoordinates, offset, endss, stride, opt_right) {\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n var ends = endss[i];\n if (!linearRingsAreOriented(flatCoordinates, offset, ends, stride, opt_right)) {\n return false;\n }\n if (ends.length) {\n offset = ends[ends.length - 1];\n }\n }\n return true;\n}\n/**\n * Orient coordinates in a flat array of linear rings. By default, rings\n * are oriented following the left-hand rule (clockwise for exterior and\n * counter-clockwise for interior rings). To orient according to the\n * right-hand rule, use the `opt_right` argument.\n *\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {boolean} [opt_right] Follow the right-hand rule for orientation.\n * @return {number} End.\n */\nexport function orientLinearRings(flatCoordinates, offset, ends, stride, opt_right) {\n var right = opt_right !== undefined ? opt_right : false;\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n var end = ends[i];\n var isClockwise = linearRingIsClockwise(flatCoordinates, offset, end, stride);\n var reverse = i === 0\n ? (right && isClockwise) || (!right && !isClockwise)\n : (right && !isClockwise) || (!right && isClockwise);\n if (reverse) {\n reverseCoordinates(flatCoordinates, offset, end, stride);\n }\n offset = end;\n }\n return offset;\n}\n/**\n * Orient coordinates in a flat array of linear rings. By default, rings\n * are oriented following the left-hand rule (clockwise for exterior and\n * counter-clockwise for interior rings). To orient according to the\n * right-hand rule, use the `opt_right` argument.\n *\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Array of array of end indexes.\n * @param {number} stride Stride.\n * @param {boolean} [opt_right] Follow the right-hand rule for orientation.\n * @return {number} End.\n */\nexport function orientLinearRingsArray(flatCoordinates, offset, endss, stride, opt_right) {\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n offset = orientLinearRings(flatCoordinates, offset, endss[i], stride, opt_right);\n }\n return offset;\n}\n//# sourceMappingURL=orient.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/geom/Polygon\n */\nimport GeometryLayout from './GeometryLayout.js';\nimport GeometryType from './GeometryType.js';\nimport LinearRing from './LinearRing.js';\nimport Point from './Point.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport { arrayMaxSquaredDelta, assignClosestArrayPoint } from './flat/closest.js';\nimport { closestSquaredDistanceXY, getCenter } from '../extent.js';\nimport { deflateCoordinatesArray } from './flat/deflate.js';\nimport { extend } from '../array.js';\nimport { getInteriorPointOfArray } from './flat/interiorpoint.js';\nimport { inflateCoordinatesArray } from './flat/inflate.js';\nimport { intersectsLinearRingArray } from './flat/intersectsextent.js';\nimport { linearRingsAreOriented, orientLinearRings } from './flat/orient.js';\nimport { linearRings as linearRingsArea } from './flat/area.js';\nimport { linearRingsContainsXY } from './flat/contains.js';\nimport { modulo } from '../math.js';\nimport { quantizeArray } from './flat/simplify.js';\nimport { offset as sphereOffset } from '../sphere.js';\n/**\n * @classdesc\n * Polygon geometry.\n *\n * @api\n */\nvar Polygon = /** @class */ (function (_super) {\n __extends(Polygon, _super);\n /**\n * @param {!Array<Array<import(\"../coordinate.js\").Coordinate>>|!Array<number>} coordinates\n * Array of linear rings that define the polygon. The first linear ring of the\n * array defines the outer-boundary or surface of the polygon. Each subsequent\n * linear ring defines a hole in the surface of the polygon. A linear ring is\n * an array of vertices' coordinates where the first coordinate and the last are\n * equivalent. (For internal use, flat coordinates in combination with\n * `opt_layout` and `opt_ends` are also accepted.)\n * @param {import(\"./GeometryLayout.js\").default} [opt_layout] Layout.\n * @param {Array<number>} [opt_ends] Ends (for internal use with flat coordinates).\n */\n function Polygon(coordinates, opt_layout, opt_ends) {\n var _this = _super.call(this) || this;\n /**\n * @type {Array<number>}\n * @private\n */\n _this.ends_ = [];\n /**\n * @private\n * @type {number}\n */\n _this.flatInteriorPointRevision_ = -1;\n /**\n * @private\n * @type {import(\"../coordinate.js\").Coordinate}\n */\n _this.flatInteriorPoint_ = null;\n /**\n * @private\n * @type {number}\n */\n _this.maxDelta_ = -1;\n /**\n * @private\n * @type {number}\n */\n _this.maxDeltaRevision_ = -1;\n /**\n * @private\n * @type {number}\n */\n _this.orientedRevision_ = -1;\n /**\n * @private\n * @type {Array<number>}\n */\n _this.orientedFlatCoordinates_ = null;\n if (opt_layout !== undefined && opt_ends) {\n _this.setFlatCoordinates(opt_layout, \n /** @type {Array<number>} */ (coordinates));\n _this.ends_ = opt_ends;\n }\n else {\n _this.setCoordinates(\n /** @type {Array<Array<import(\"../coordinate.js\").Coordinate>>} */ (coordinates), opt_layout);\n }\n return _this;\n }\n /**\n * Append the passed linear ring to this polygon.\n * @param {LinearRing} linearRing Linear ring.\n * @api\n */\n Polygon.prototype.appendLinearRing = function (linearRing) {\n if (!this.flatCoordinates) {\n this.flatCoordinates = linearRing.getFlatCoordinates().slice();\n }\n else {\n extend(this.flatCoordinates, linearRing.getFlatCoordinates());\n }\n this.ends_.push(this.flatCoordinates.length);\n this.changed();\n };\n /**\n * Make a complete copy of the geometry.\n * @return {!Polygon} Clone.\n * @api\n */\n Polygon.prototype.clone = function () {\n var polygon = new Polygon(this.flatCoordinates.slice(), this.layout, this.ends_.slice());\n polygon.applyProperties(this);\n return polygon;\n };\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n */\n Polygon.prototype.closestPointXY = function (x, y, closestPoint, minSquaredDistance) {\n if (minSquaredDistance < closestSquaredDistanceXY(this.getExtent(), x, y)) {\n return minSquaredDistance;\n }\n if (this.maxDeltaRevision_ != this.getRevision()) {\n this.maxDelta_ = Math.sqrt(arrayMaxSquaredDelta(this.flatCoordinates, 0, this.ends_, this.stride, 0));\n this.maxDeltaRevision_ = this.getRevision();\n }\n return assignClosestArrayPoint(this.flatCoordinates, 0, this.ends_, this.stride, this.maxDelta_, true, x, y, closestPoint, minSquaredDistance);\n };\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @return {boolean} Contains (x, y).\n */\n Polygon.prototype.containsXY = function (x, y) {\n return linearRingsContainsXY(this.getOrientedFlatCoordinates(), 0, this.ends_, this.stride, x, y);\n };\n /**\n * Return the area of the polygon on projected plane.\n * @return {number} Area (on projected plane).\n * @api\n */\n Polygon.prototype.getArea = function () {\n return linearRingsArea(this.getOrientedFlatCoordinates(), 0, this.ends_, this.stride);\n };\n /**\n * Get the coordinate array for this geometry. This array has the structure\n * of a GeoJSON coordinate array for polygons.\n *\n * @param {boolean} [opt_right] Orient coordinates according to the right-hand\n * rule (counter-clockwise for exterior and clockwise for interior rings).\n * If `false`, coordinates will be oriented according to the left-hand rule\n * (clockwise for exterior and counter-clockwise for interior rings).\n * By default, coordinate orientation will depend on how the geometry was\n * constructed.\n * @return {Array<Array<import(\"../coordinate.js\").Coordinate>>} Coordinates.\n * @api\n */\n Polygon.prototype.getCoordinates = function (opt_right) {\n var flatCoordinates;\n if (opt_right !== undefined) {\n flatCoordinates = this.getOrientedFlatCoordinates().slice();\n orientLinearRings(flatCoordinates, 0, this.ends_, this.stride, opt_right);\n }\n else {\n flatCoordinates = this.flatCoordinates;\n }\n return inflateCoordinatesArray(flatCoordinates, 0, this.ends_, this.stride);\n };\n /**\n * @return {Array<number>} Ends.\n */\n Polygon.prototype.getEnds = function () {\n return this.ends_;\n };\n /**\n * @return {Array<number>} Interior point.\n */\n Polygon.prototype.getFlatInteriorPoint = function () {\n if (this.flatInteriorPointRevision_ != this.getRevision()) {\n var flatCenter = getCenter(this.getExtent());\n this.flatInteriorPoint_ = getInteriorPointOfArray(this.getOrientedFlatCoordinates(), 0, this.ends_, this.stride, flatCenter, 0);\n this.flatInteriorPointRevision_ = this.getRevision();\n }\n return this.flatInteriorPoint_;\n };\n /**\n * Return an interior point of the polygon.\n * @return {Point} Interior point as XYM coordinate, where M is the\n * length of the horizontal intersection that the point belongs to.\n * @api\n */\n Polygon.prototype.getInteriorPoint = function () {\n return new Point(this.getFlatInteriorPoint(), GeometryLayout.XYM);\n };\n /**\n * Return the number of rings of the polygon, this includes the exterior\n * ring and any interior rings.\n *\n * @return {number} Number of rings.\n * @api\n */\n Polygon.prototype.getLinearRingCount = function () {\n return this.ends_.length;\n };\n /**\n * Return the Nth linear ring of the polygon geometry. Return `null` if the\n * given index is out of range.\n * The exterior linear ring is available at index `0` and the interior rings\n * at index `1` and beyond.\n *\n * @param {number} index Index.\n * @return {LinearRing} Linear ring.\n * @api\n */\n Polygon.prototype.getLinearRing = function (index) {\n if (index < 0 || this.ends_.length <= index) {\n return null;\n }\n return new LinearRing(this.flatCoordinates.slice(index === 0 ? 0 : this.ends_[index - 1], this.ends_[index]), this.layout);\n };\n /**\n * Return the linear rings of the polygon.\n * @return {Array<LinearRing>} Linear rings.\n * @api\n */\n Polygon.prototype.getLinearRings = function () {\n var layout = this.layout;\n var flatCoordinates = this.flatCoordinates;\n var ends = this.ends_;\n var linearRings = [];\n var offset = 0;\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n var end = ends[i];\n var linearRing = new LinearRing(flatCoordinates.slice(offset, end), layout);\n linearRings.push(linearRing);\n offset = end;\n }\n return linearRings;\n };\n /**\n * @return {Array<number>} Oriented flat coordinates.\n */\n Polygon.prototype.getOrientedFlatCoordinates = function () {\n if (this.orientedRevision_ != this.getRevision()) {\n var flatCoordinates = this.flatCoordinates;\n if (linearRingsAreOriented(flatCoordinates, 0, this.ends_, this.stride)) {\n this.orientedFlatCoordinates_ = flatCoordinates;\n }\n else {\n this.orientedFlatCoordinates_ = flatCoordinates.slice();\n this.orientedFlatCoordinates_.length = orientLinearRings(this.orientedFlatCoordinates_, 0, this.ends_, this.stride);\n }\n this.orientedRevision_ = this.getRevision();\n }\n return this.orientedFlatCoordinates_;\n };\n /**\n * @param {number} squaredTolerance Squared tolerance.\n * @return {Polygon} Simplified Polygon.\n * @protected\n */\n Polygon.prototype.getSimplifiedGeometryInternal = function (squaredTolerance) {\n var simplifiedFlatCoordinates = [];\n var simplifiedEnds = [];\n simplifiedFlatCoordinates.length = quantizeArray(this.flatCoordinates, 0, this.ends_, this.stride, Math.sqrt(squaredTolerance), simplifiedFlatCoordinates, 0, simplifiedEnds);\n return new Polygon(simplifiedFlatCoordinates, GeometryLayout.XY, simplifiedEnds);\n };\n /**\n * Get the type of this geometry.\n * @return {import(\"./GeometryType.js\").default} Geometry type.\n * @api\n */\n Polygon.prototype.getType = function () {\n return GeometryType.POLYGON;\n };\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n */\n Polygon.prototype.intersectsExtent = function (extent) {\n return intersectsLinearRingArray(this.getOrientedFlatCoordinates(), 0, this.ends_, this.stride, extent);\n };\n /**\n * Set the coordinates of the polygon.\n * @param {!Array<Array<import(\"../coordinate.js\").Coordinate>>} coordinates Coordinates.\n * @param {import(\"./GeometryLayout.js\").default} [opt_layout] Layout.\n * @api\n */\n Polygon.prototype.setCoordinates = function (coordinates, opt_layout) {\n this.setLayout(opt_layout, coordinates, 2);\n if (!this.flatCoordinates) {\n this.flatCoordinates = [];\n }\n var ends = deflateCoordinatesArray(this.flatCoordinates, 0, coordinates, this.stride, this.ends_);\n this.flatCoordinates.length = ends.length === 0 ? 0 : ends[ends.length - 1];\n this.changed();\n };\n return Polygon;\n}(SimpleGeometry));\nexport default Polygon;\n/**\n * Create an approximation of a circle on the surface of a sphere.\n * @param {import(\"../coordinate.js\").Coordinate} center Center (`[lon, lat]` in degrees).\n * @param {number} radius The great-circle distance from the center to\n * the polygon vertices in meters.\n * @param {number} [opt_n] Optional number of vertices for the resulting\n * polygon. Default is `32`.\n * @param {number} [opt_sphereRadius] Optional radius for the sphere (defaults to\n * the Earth's mean radius using the WGS84 ellipsoid).\n * @return {Polygon} The \"circular\" polygon.\n * @api\n */\nexport function circular(center, radius, opt_n, opt_sphereRadius) {\n var n = opt_n ? opt_n : 32;\n /** @type {Array<number>} */\n var flatCoordinates = [];\n for (var i = 0; i < n; ++i) {\n extend(flatCoordinates, sphereOffset(center, radius, (2 * Math.PI * i) / n, opt_sphereRadius));\n }\n flatCoordinates.push(flatCoordinates[0], flatCoordinates[1]);\n return new Polygon(flatCoordinates, GeometryLayout.XY, [\n flatCoordinates.length,\n ]);\n}\n/**\n * Create a polygon from an extent. The layout used is `XY`.\n * @param {import(\"../extent.js\").Extent} extent The extent.\n * @return {Polygon} The polygon.\n * @api\n */\nexport function fromExtent(extent) {\n var minX = extent[0];\n var minY = extent[1];\n var maxX = extent[2];\n var maxY = extent[3];\n var flatCoordinates = [\n minX,\n minY,\n minX,\n maxY,\n maxX,\n maxY,\n maxX,\n minY,\n minX,\n minY,\n ];\n return new Polygon(flatCoordinates, GeometryLayout.XY, [\n flatCoordinates.length,\n ]);\n}\n/**\n * Create a regular polygon from a circle.\n * @param {import(\"./Circle.js\").default} circle Circle geometry.\n * @param {number} [opt_sides] Number of sides of the polygon. Default is 32.\n * @param {number} [opt_angle] Start angle for the first vertex of the polygon in\n * counter-clockwise radians. 0 means East. Default is 0.\n * @return {Polygon} Polygon geometry.\n * @api\n */\nexport function fromCircle(circle, opt_sides, opt_angle) {\n var sides = opt_sides ? opt_sides : 32;\n var stride = circle.getStride();\n var layout = circle.getLayout();\n var center = circle.getCenter();\n var arrayLength = stride * (sides + 1);\n var flatCoordinates = new Array(arrayLength);\n for (var i = 0; i < arrayLength; i += stride) {\n flatCoordinates[i] = 0;\n flatCoordinates[i + 1] = 0;\n for (var j = 2; j < stride; j++) {\n flatCoordinates[i + j] = center[j];\n }\n }\n var ends = [flatCoordinates.length];\n var polygon = new Polygon(flatCoordinates, layout, ends);\n makeRegular(polygon, center, circle.getRadius(), opt_angle);\n return polygon;\n}\n/**\n * Modify the coordinates of a polygon to make it a regular polygon.\n * @param {Polygon} polygon Polygon geometry.\n * @param {import(\"../coordinate.js\").Coordinate} center Center of the regular polygon.\n * @param {number} radius Radius of the regular polygon.\n * @param {number} [opt_angle] Start angle for the first vertex of the polygon in\n * counter-clockwise radians. 0 means East. Default is 0.\n */\nexport function makeRegular(polygon, center, radius, opt_angle) {\n var flatCoordinates = polygon.getFlatCoordinates();\n var stride = polygon.getStride();\n var sides = flatCoordinates.length / stride - 1;\n var startAngle = opt_angle ? opt_angle : 0;\n for (var i = 0; i <= sides; ++i) {\n var offset = i * stride;\n var angle = startAngle + (modulo(i, sides) * 2 * Math.PI) / sides;\n flatCoordinates[offset] = center[0] + radius * Math.cos(angle);\n flatCoordinates[offset + 1] = center[1] + radius * Math.sin(angle);\n }\n polygon.changed();\n}\n//# sourceMappingURL=Polygon.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/geom/MultiPolygon\n */\nimport GeometryLayout from './GeometryLayout.js';\nimport GeometryType from './GeometryType.js';\nimport MultiPoint from './MultiPoint.js';\nimport Polygon from './Polygon.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport { assignClosestMultiArrayPoint, multiArrayMaxSquaredDelta, } from './flat/closest.js';\nimport { closestSquaredDistanceXY } from '../extent.js';\nimport { deflateMultiCoordinatesArray } from './flat/deflate.js';\nimport { extend } from '../array.js';\nimport { getInteriorPointsOfMultiArray } from './flat/interiorpoint.js';\nimport { inflateMultiCoordinatesArray } from './flat/inflate.js';\nimport { intersectsLinearRingMultiArray } from './flat/intersectsextent.js';\nimport { linearRingssAreOriented, orientLinearRingsArray, } from './flat/orient.js';\nimport { linearRingss as linearRingssArea } from './flat/area.js';\nimport { linearRingss as linearRingssCenter } from './flat/center.js';\nimport { linearRingssContainsXY } from './flat/contains.js';\nimport { quantizeMultiArray } from './flat/simplify.js';\n/**\n * @classdesc\n * Multi-polygon geometry.\n *\n * @api\n */\nvar MultiPolygon = /** @class */ (function (_super) {\n __extends(MultiPolygon, _super);\n /**\n * @param {Array<Array<Array<import(\"../coordinate.js\").Coordinate>>|Polygon>|Array<number>} coordinates Coordinates.\n * For internal use, flat coordinates in combination with `opt_layout` and `opt_endss` are also accepted.\n * @param {import(\"./GeometryLayout.js\").default} [opt_layout] Layout.\n * @param {Array<Array<number>>} [opt_endss] Array of ends for internal use with flat coordinates.\n */\n function MultiPolygon(coordinates, opt_layout, opt_endss) {\n var _this = _super.call(this) || this;\n /**\n * @type {Array<Array<number>>}\n * @private\n */\n _this.endss_ = [];\n /**\n * @private\n * @type {number}\n */\n _this.flatInteriorPointsRevision_ = -1;\n /**\n * @private\n * @type {Array<number>}\n */\n _this.flatInteriorPoints_ = null;\n /**\n * @private\n * @type {number}\n */\n _this.maxDelta_ = -1;\n /**\n * @private\n * @type {number}\n */\n _this.maxDeltaRevision_ = -1;\n /**\n * @private\n * @type {number}\n */\n _this.orientedRevision_ = -1;\n /**\n * @private\n * @type {Array<number>}\n */\n _this.orientedFlatCoordinates_ = null;\n if (!opt_endss && !Array.isArray(coordinates[0])) {\n var layout = _this.getLayout();\n var polygons = /** @type {Array<Polygon>} */ (coordinates);\n var flatCoordinates = [];\n var endss = [];\n for (var i = 0, ii = polygons.length; i < ii; ++i) {\n var polygon = polygons[i];\n if (i === 0) {\n layout = polygon.getLayout();\n }\n var offset = flatCoordinates.length;\n var ends = polygon.getEnds();\n for (var j = 0, jj = ends.length; j < jj; ++j) {\n ends[j] += offset;\n }\n extend(flatCoordinates, polygon.getFlatCoordinates());\n endss.push(ends);\n }\n opt_layout = layout;\n coordinates = flatCoordinates;\n opt_endss = endss;\n }\n if (opt_layout !== undefined && opt_endss) {\n _this.setFlatCoordinates(opt_layout, \n /** @type {Array<number>} */ (coordinates));\n _this.endss_ = opt_endss;\n }\n else {\n _this.setCoordinates(\n /** @type {Array<Array<Array<import(\"../coordinate.js\").Coordinate>>>} */ (coordinates), opt_layout);\n }\n return _this;\n }\n /**\n * Append the passed polygon to this multipolygon.\n * @param {Polygon} polygon Polygon.\n * @api\n */\n MultiPolygon.prototype.appendPolygon = function (polygon) {\n /** @type {Array<number>} */\n var ends;\n if (!this.flatCoordinates) {\n this.flatCoordinates = polygon.getFlatCoordinates().slice();\n ends = polygon.getEnds().slice();\n this.endss_.push();\n }\n else {\n var offset = this.flatCoordinates.length;\n extend(this.flatCoordinates, polygon.getFlatCoordinates());\n ends = polygon.getEnds().slice();\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n ends[i] += offset;\n }\n }\n this.endss_.push(ends);\n this.changed();\n };\n /**\n * Make a complete copy of the geometry.\n * @return {!MultiPolygon} Clone.\n * @api\n */\n MultiPolygon.prototype.clone = function () {\n var len = this.endss_.length;\n var newEndss = new Array(len);\n for (var i = 0; i < len; ++i) {\n newEndss[i] = this.endss_[i].slice();\n }\n var multiPolygon = new MultiPolygon(this.flatCoordinates.slice(), this.layout, newEndss);\n multiPolygon.applyProperties(this);\n return multiPolygon;\n };\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n */\n MultiPolygon.prototype.closestPointXY = function (x, y, closestPoint, minSquaredDistance) {\n if (minSquaredDistance < closestSquaredDistanceXY(this.getExtent(), x, y)) {\n return minSquaredDistance;\n }\n if (this.maxDeltaRevision_ != this.getRevision()) {\n this.maxDelta_ = Math.sqrt(multiArrayMaxSquaredDelta(this.flatCoordinates, 0, this.endss_, this.stride, 0));\n this.maxDeltaRevision_ = this.getRevision();\n }\n return assignClosestMultiArrayPoint(this.getOrientedFlatCoordinates(), 0, this.endss_, this.stride, this.maxDelta_, true, x, y, closestPoint, minSquaredDistance);\n };\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @return {boolean} Contains (x, y).\n */\n MultiPolygon.prototype.containsXY = function (x, y) {\n return linearRingssContainsXY(this.getOrientedFlatCoordinates(), 0, this.endss_, this.stride, x, y);\n };\n /**\n * Return the area of the multipolygon on projected plane.\n * @return {number} Area (on projected plane).\n * @api\n */\n MultiPolygon.prototype.getArea = function () {\n return linearRingssArea(this.getOrientedFlatCoordinates(), 0, this.endss_, this.stride);\n };\n /**\n * Get the coordinate array for this geometry. This array has the structure\n * of a GeoJSON coordinate array for multi-polygons.\n *\n * @param {boolean} [opt_right] Orient coordinates according to the right-hand\n * rule (counter-clockwise for exterior and clockwise for interior rings).\n * If `false`, coordinates will be oriented according to the left-hand rule\n * (clockwise for exterior and counter-clockwise for interior rings).\n * By default, coordinate orientation will depend on how the geometry was\n * constructed.\n * @return {Array<Array<Array<import(\"../coordinate.js\").Coordinate>>>} Coordinates.\n * @api\n */\n MultiPolygon.prototype.getCoordinates = function (opt_right) {\n var flatCoordinates;\n if (opt_right !== undefined) {\n flatCoordinates = this.getOrientedFlatCoordinates().slice();\n orientLinearRingsArray(flatCoordinates, 0, this.endss_, this.stride, opt_right);\n }\n else {\n flatCoordinates = this.flatCoordinates;\n }\n return inflateMultiCoordinatesArray(flatCoordinates, 0, this.endss_, this.stride);\n };\n /**\n * @return {Array<Array<number>>} Endss.\n */\n MultiPolygon.prototype.getEndss = function () {\n return this.endss_;\n };\n /**\n * @return {Array<number>} Flat interior points.\n */\n MultiPolygon.prototype.getFlatInteriorPoints = function () {\n if (this.flatInteriorPointsRevision_ != this.getRevision()) {\n var flatCenters = linearRingssCenter(this.flatCoordinates, 0, this.endss_, this.stride);\n this.flatInteriorPoints_ = getInteriorPointsOfMultiArray(this.getOrientedFlatCoordinates(), 0, this.endss_, this.stride, flatCenters);\n this.flatInteriorPointsRevision_ = this.getRevision();\n }\n return this.flatInteriorPoints_;\n };\n /**\n * Return the interior points as {@link module:ol/geom/MultiPoint multipoint}.\n * @return {MultiPoint} Interior points as XYM coordinates, where M is\n * the length of the horizontal intersection that the point belongs to.\n * @api\n */\n MultiPolygon.prototype.getInteriorPoints = function () {\n return new MultiPoint(this.getFlatInteriorPoints().slice(), GeometryLayout.XYM);\n };\n /**\n * @return {Array<number>} Oriented flat coordinates.\n */\n MultiPolygon.prototype.getOrientedFlatCoordinates = function () {\n if (this.orientedRevision_ != this.getRevision()) {\n var flatCoordinates = this.flatCoordinates;\n if (linearRingssAreOriented(flatCoordinates, 0, this.endss_, this.stride)) {\n this.orientedFlatCoordinates_ = flatCoordinates;\n }\n else {\n this.orientedFlatCoordinates_ = flatCoordinates.slice();\n this.orientedFlatCoordinates_.length = orientLinearRingsArray(this.orientedFlatCoordinates_, 0, this.endss_, this.stride);\n }\n this.orientedRevision_ = this.getRevision();\n }\n return this.orientedFlatCoordinates_;\n };\n /**\n * @param {number} squaredTolerance Squared tolerance.\n * @return {MultiPolygon} Simplified MultiPolygon.\n * @protected\n */\n MultiPolygon.prototype.getSimplifiedGeometryInternal = function (squaredTolerance) {\n var simplifiedFlatCoordinates = [];\n var simplifiedEndss = [];\n simplifiedFlatCoordinates.length = quantizeMultiArray(this.flatCoordinates, 0, this.endss_, this.stride, Math.sqrt(squaredTolerance), simplifiedFlatCoordinates, 0, simplifiedEndss);\n return new MultiPolygon(simplifiedFlatCoordinates, GeometryLayout.XY, simplifiedEndss);\n };\n /**\n * Return the polygon at the specified index.\n * @param {number} index Index.\n * @return {Polygon} Polygon.\n * @api\n */\n MultiPolygon.prototype.getPolygon = function (index) {\n if (index < 0 || this.endss_.length <= index) {\n return null;\n }\n var offset;\n if (index === 0) {\n offset = 0;\n }\n else {\n var prevEnds = this.endss_[index - 1];\n offset = prevEnds[prevEnds.length - 1];\n }\n var ends = this.endss_[index].slice();\n var end = ends[ends.length - 1];\n if (offset !== 0) {\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n ends[i] -= offset;\n }\n }\n return new Polygon(this.flatCoordinates.slice(offset, end), this.layout, ends);\n };\n /**\n * Return the polygons of this multipolygon.\n * @return {Array<Polygon>} Polygons.\n * @api\n */\n MultiPolygon.prototype.getPolygons = function () {\n var layout = this.layout;\n var flatCoordinates = this.flatCoordinates;\n var endss = this.endss_;\n var polygons = [];\n var offset = 0;\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n var ends = endss[i].slice();\n var end = ends[ends.length - 1];\n if (offset !== 0) {\n for (var j = 0, jj = ends.length; j < jj; ++j) {\n ends[j] -= offset;\n }\n }\n var polygon = new Polygon(flatCoordinates.slice(offset, end), layout, ends);\n polygons.push(polygon);\n offset = end;\n }\n return polygons;\n };\n /**\n * Get the type of this geometry.\n * @return {import(\"./GeometryType.js\").default} Geometry type.\n * @api\n */\n MultiPolygon.prototype.getType = function () {\n return GeometryType.MULTI_POLYGON;\n };\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n */\n MultiPolygon.prototype.intersectsExtent = function (extent) {\n return intersectsLinearRingMultiArray(this.getOrientedFlatCoordinates(), 0, this.endss_, this.stride, extent);\n };\n /**\n * Set the coordinates of the multipolygon.\n * @param {!Array<Array<Array<import(\"../coordinate.js\").Coordinate>>>} coordinates Coordinates.\n * @param {import(\"./GeometryLayout.js\").default} [opt_layout] Layout.\n * @api\n */\n MultiPolygon.prototype.setCoordinates = function (coordinates, opt_layout) {\n this.setLayout(opt_layout, coordinates, 3);\n if (!this.flatCoordinates) {\n this.flatCoordinates = [];\n }\n var endss = deflateMultiCoordinatesArray(this.flatCoordinates, 0, coordinates, this.stride, this.endss_);\n if (endss.length === 0) {\n this.flatCoordinates.length = 0;\n }\n else {\n var lastEnds = endss[endss.length - 1];\n this.flatCoordinates.length =\n lastEnds.length === 0 ? 0 : lastEnds[lastEnds.length - 1];\n }\n this.changed();\n };\n return MultiPolygon;\n}(SimpleGeometry));\nexport default MultiPolygon;\n//# sourceMappingURL=MultiPolygon.js.map","/**\n * @module ol/geom/flat/center\n */\nimport { createEmpty, createOrUpdateFromFlatCoordinates } from '../../extent.js';\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @return {Array<number>} Flat centers.\n */\nexport function linearRingss(flatCoordinates, offset, endss, stride) {\n var flatCenters = [];\n var extent = createEmpty();\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n var ends = endss[i];\n extent = createOrUpdateFromFlatCoordinates(flatCoordinates, offset, ends[0], stride);\n flatCenters.push((extent[0] + extent[2]) / 2, (extent[1] + extent[3]) / 2);\n offset = ends[ends.length - 1];\n }\n return flatCenters;\n}\n//# sourceMappingURL=center.js.map","/**\n * @module ol/layer/TileProperty\n */\n/**\n * @enum {string}\n */\nexport default {\n PRELOAD: 'preload',\n USE_INTERIM_TILES_ON_ERROR: 'useInterimTilesOnError',\n};\n//# sourceMappingURL=TileProperty.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/layer/BaseTile\n */\nimport Layer from './Layer.js';\nimport TileProperty from './TileProperty.js';\nimport { assign } from '../obj.js';\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n * import(\"../Observable\").OnSignature<import(\"./Base\").BaseLayerObjectEventTypes|\n * 'change:source'|'change:preload'|'change:useInterimTilesOnError', import(\"../Object\").ObjectEvent, Return> &\n * import(\"../Observable\").OnSignature<import(\"../render/EventType\").LayerRenderEventTypes, import(\"../render/Event\").default, Return> &\n * import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"./Base\").BaseLayerObjectEventTypes|\n * 'change:source'|'change:preload'|'change:useInterimTilesOnError'|import(\"../render/EventType\").LayerRenderEventTypes, Return>} BaseTileLayerOnSignature\n */\n/**\n * @template {import(\"../source/Tile.js\").default} TileSourceType\n * @typedef {Object} Options\n * @property {string} [className='ol-layer'] A CSS class name to set to the layer element.\n * @property {number} [opacity=1] Opacity (0, 1).\n * @property {boolean} [visible=true] Visibility.\n * @property {import(\"../extent.js\").Extent} [extent] The bounding extent for layer rendering. The layer will not be\n * rendered outside of this extent.\n * @property {number} [zIndex] The z-index for layer rendering. At rendering time, the layers\n * will be ordered, first by Z-index and then by position. When `undefined`, a `zIndex` of 0 is assumed\n * for layers that are added to the map's `layers` collection, or `Infinity` when the layer's `setMap()`\n * method was used.\n * @property {number} [minResolution] The minimum resolution (inclusive) at which this layer will be\n * visible.\n * @property {number} [maxResolution] The maximum resolution (exclusive) below which this layer will\n * be visible.\n * @property {number} [minZoom] The minimum view zoom level (exclusive) above which this layer will be\n * visible.\n * @property {number} [maxZoom] The maximum view zoom level (inclusive) at which this layer will\n * be visible.\n * @property {number} [preload=0] Preload. Load low-resolution tiles up to `preload` levels. `0`\n * means no preloading.\n * @property {TileSourceType} [source] Source for this layer.\n * @property {import(\"../PluggableMap.js\").default} [map] Sets the layer as overlay on a map. The map will not manage\n * this layer in its layers collection, and the layer will be rendered on top. This is useful for\n * temporary layers. The standard way to add a layer to a map and have it managed by the map is to\n * use {@link import(\"../PluggableMap.js\").default#addLayer map.addLayer()}.\n * @property {boolean} [useInterimTilesOnError=true] Use interim tiles on error.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n/**\n * @classdesc\n * For layer sources that provide pre-rendered, tiled images in grids that are\n * organized by zoom levels for specific resolutions.\n * Note that any property set in the options is set as a {@link module:ol/Object~BaseObject}\n * property on the layer object; for example, setting `title: 'My Title'` in the\n * options means that `title` is observable, and has get/set accessors.\n *\n * @template {import(\"../source/Tile.js\").default} TileSourceType\n * @extends {Layer<TileSourceType>}\n * @api\n */\nvar BaseTileLayer = /** @class */ (function (_super) {\n __extends(BaseTileLayer, _super);\n /**\n * @param {Options<TileSourceType>} [opt_options] Tile layer options.\n */\n function BaseTileLayer(opt_options) {\n var _this = this;\n var options = opt_options ? opt_options : {};\n var baseOptions = assign({}, options);\n delete baseOptions.preload;\n delete baseOptions.useInterimTilesOnError;\n _this = _super.call(this, baseOptions) || this;\n /***\n * @type {BaseTileLayerOnSignature<import(\"../events\").EventsKey>}\n */\n _this.on;\n /***\n * @type {BaseTileLayerOnSignature<import(\"../events\").EventsKey>}\n */\n _this.once;\n /***\n * @type {BaseTileLayerOnSignature<void>}\n */\n _this.un;\n _this.setPreload(options.preload !== undefined ? options.preload : 0);\n _this.setUseInterimTilesOnError(options.useInterimTilesOnError !== undefined\n ? options.useInterimTilesOnError\n : true);\n return _this;\n }\n /**\n * Return the level as number to which we will preload tiles up to.\n * @return {number} The level to preload tiles up to.\n * @observable\n * @api\n */\n BaseTileLayer.prototype.getPreload = function () {\n return /** @type {number} */ (this.get(TileProperty.PRELOAD));\n };\n /**\n * Set the level as number to which we will preload tiles up to.\n * @param {number} preload The level to preload tiles up to.\n * @observable\n * @api\n */\n BaseTileLayer.prototype.setPreload = function (preload) {\n this.set(TileProperty.PRELOAD, preload);\n };\n /**\n * Whether we use interim tiles on error.\n * @return {boolean} Use interim tiles on error.\n * @observable\n * @api\n */\n BaseTileLayer.prototype.getUseInterimTilesOnError = function () {\n return /** @type {boolean} */ (this.get(TileProperty.USE_INTERIM_TILES_ON_ERROR));\n };\n /**\n * Set whether we use interim tiles on error.\n * @param {boolean} useInterimTilesOnError Use interim tiles on error.\n * @observable\n * @api\n */\n BaseTileLayer.prototype.setUseInterimTilesOnError = function (useInterimTilesOnError) {\n this.set(TileProperty.USE_INTERIM_TILES_ON_ERROR, useInterimTilesOnError);\n };\n return BaseTileLayer;\n}(Layer));\nexport default BaseTileLayer;\n//# sourceMappingURL=BaseTile.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/renderer/Layer\n */\nimport EventType from '../events/EventType.js';\nimport ImageState from '../ImageState.js';\nimport Observable from '../Observable.js';\nimport SourceState from '../source/State.js';\nimport { abstract } from '../util.js';\n/**\n * @template {import(\"../layer/Layer.js\").default} LayerType\n */\nvar LayerRenderer = /** @class */ (function (_super) {\n __extends(LayerRenderer, _super);\n /**\n * @param {LayerType} layer Layer.\n */\n function LayerRenderer(layer) {\n var _this = _super.call(this) || this;\n /** @private */\n _this.boundHandleImageChange_ = _this.handleImageChange_.bind(_this);\n /**\n * @protected\n * @type {LayerType}\n */\n _this.layer_ = layer;\n /**\n * @type {import(\"../render/canvas/ExecutorGroup\").default}\n */\n _this.declutterExecutorGroup = null;\n return _this;\n }\n /**\n * Asynchronous layer level hit detection.\n * @param {import(\"../pixel.js\").Pixel} pixel Pixel.\n * @return {Promise<Array<import(\"../Feature\").default>>} Promise that resolves with\n * an array of features.\n */\n LayerRenderer.prototype.getFeatures = function (pixel) {\n return abstract();\n };\n /**\n * Determine whether render should be called.\n * @abstract\n * @param {import(\"../PluggableMap.js\").FrameState} frameState Frame state.\n * @return {boolean} Layer is ready to be rendered.\n */\n LayerRenderer.prototype.prepareFrame = function (frameState) {\n return abstract();\n };\n /**\n * Render the layer.\n * @abstract\n * @param {import(\"../PluggableMap.js\").FrameState} frameState Frame state.\n * @param {HTMLElement} target Target that may be used to render content to.\n * @return {HTMLElement} The rendered element.\n */\n LayerRenderer.prototype.renderFrame = function (frameState, target) {\n return abstract();\n };\n /**\n * @param {Object<number, Object<string, import(\"../Tile.js\").default>>} tiles Lookup of loaded tiles by zoom level.\n * @param {number} zoom Zoom level.\n * @param {import(\"../Tile.js\").default} tile Tile.\n * @return {boolean|void} If `false`, the tile will not be considered loaded.\n */\n LayerRenderer.prototype.loadedTileCallback = function (tiles, zoom, tile) {\n if (!tiles[zoom]) {\n tiles[zoom] = {};\n }\n tiles[zoom][tile.tileCoord.toString()] = tile;\n return undefined;\n };\n /**\n * Create a function that adds loaded tiles to the tile lookup.\n * @param {import(\"../source/Tile.js\").default} source Tile source.\n * @param {import(\"../proj/Projection.js\").default} projection Projection of the tiles.\n * @param {Object<number, Object<string, import(\"../Tile.js\").default>>} tiles Lookup of loaded tiles by zoom level.\n * @return {function(number, import(\"../TileRange.js\").default):boolean} A function that can be\n * called with a zoom level and a tile range to add loaded tiles to the lookup.\n * @protected\n */\n LayerRenderer.prototype.createLoadedTileFinder = function (source, projection, tiles) {\n return (\n /**\n * @param {number} zoom Zoom level.\n * @param {import(\"../TileRange.js\").default} tileRange Tile range.\n * @return {boolean} The tile range is fully loaded.\n * @this {LayerRenderer}\n */\n function (zoom, tileRange) {\n var callback = this.loadedTileCallback.bind(this, tiles, zoom);\n return source.forEachLoadedTile(projection, zoom, tileRange, callback);\n }.bind(this));\n };\n /**\n * @abstract\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {import(\"../PluggableMap.js\").FrameState} frameState Frame state.\n * @param {number} hitTolerance Hit tolerance in pixels.\n * @param {import(\"./vector.js\").FeatureCallback<T>} callback Feature callback.\n * @param {Array<import(\"./Map.js\").HitMatch<T>>} matches The hit detected matches with tolerance.\n * @return {T|undefined} Callback result.\n * @template T\n */\n LayerRenderer.prototype.forEachFeatureAtCoordinate = function (coordinate, frameState, hitTolerance, callback, matches) {\n return undefined;\n };\n /**\n * @abstract\n * @param {import(\"../pixel.js\").Pixel} pixel Pixel.\n * @param {import(\"../PluggableMap.js\").FrameState} frameState FrameState.\n * @param {number} hitTolerance Hit tolerance in pixels.\n * @return {Uint8ClampedArray|Uint8Array} The result. If there is no data at the pixel\n * location, null will be returned. If there is data, but pixel values cannot be\n * returned, and empty array will be returned.\n */\n LayerRenderer.prototype.getDataAtPixel = function (pixel, frameState, hitTolerance) {\n return null;\n };\n /**\n * @return {LayerType} Layer.\n */\n LayerRenderer.prototype.getLayer = function () {\n return this.layer_;\n };\n /**\n * Perform action necessary to get the layer rendered after new fonts have loaded\n * @abstract\n */\n LayerRenderer.prototype.handleFontsChanged = function () { };\n /**\n * Handle changes in image state.\n * @param {import(\"../events/Event.js\").default} event Image change event.\n * @private\n */\n LayerRenderer.prototype.handleImageChange_ = function (event) {\n var image = /** @type {import(\"../Image.js\").default} */ (event.target);\n if (image.getState() === ImageState.LOADED) {\n this.renderIfReadyAndVisible();\n }\n };\n /**\n * Load the image if not already loaded, and register the image change\n * listener if needed.\n * @param {import(\"../ImageBase.js\").default} image Image.\n * @return {boolean} `true` if the image is already loaded, `false` otherwise.\n * @protected\n */\n LayerRenderer.prototype.loadImage = function (image) {\n var imageState = image.getState();\n if (imageState != ImageState.LOADED && imageState != ImageState.ERROR) {\n image.addEventListener(EventType.CHANGE, this.boundHandleImageChange_);\n }\n if (imageState == ImageState.IDLE) {\n image.load();\n imageState = image.getState();\n }\n return imageState == ImageState.LOADED;\n };\n /**\n * @protected\n */\n LayerRenderer.prototype.renderIfReadyAndVisible = function () {\n var layer = this.getLayer();\n if (layer.getVisible() && layer.getSourceState() == SourceState.READY) {\n layer.changed();\n }\n };\n return LayerRenderer;\n}(Observable));\nexport default LayerRenderer;\n//# sourceMappingURL=Layer.js.map","/**\n * @module ol/ImageState\n */\n/**\n * @enum {number}\n */\nexport default {\n IDLE: 0,\n LOADING: 1,\n LOADED: 2,\n ERROR: 3,\n EMPTY: 4,\n};\n//# sourceMappingURL=ImageState.js.map","/**\n * @module ol/render/Event\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport Event from '../events/Event.js';\nvar RenderEvent = /** @class */ (function (_super) {\n __extends(RenderEvent, _super);\n /**\n * @param {import(\"./EventType.js\").default} type Type.\n * @param {import(\"../transform.js\").Transform} [opt_inversePixelTransform] Transform for\n * CSS pixels to rendered pixels.\n * @param {import(\"../PluggableMap.js\").FrameState} [opt_frameState] Frame state.\n * @param {?CanvasRenderingContext2D} [opt_context] Context.\n */\n function RenderEvent(type, opt_inversePixelTransform, opt_frameState, opt_context) {\n var _this = _super.call(this, type) || this;\n /**\n * Transform from CSS pixels (relative to the top-left corner of the map viewport)\n * to rendered pixels on this event's `context`. Only available when a Canvas renderer is used, null otherwise.\n * @type {import(\"../transform.js\").Transform|undefined}\n * @api\n */\n _this.inversePixelTransform = opt_inversePixelTransform;\n /**\n * An object representing the current render frame state.\n * @type {import(\"../PluggableMap.js\").FrameState|undefined}\n * @api\n */\n _this.frameState = opt_frameState;\n /**\n * Canvas context. Not available when the event is dispatched by the map. Only available\n * when a Canvas renderer is used, null otherwise.\n * @type {CanvasRenderingContext2D|null|undefined}\n * @api\n */\n _this.context = opt_context;\n return _this;\n }\n return RenderEvent;\n}(Event));\nexport default RenderEvent;\n//# sourceMappingURL=Event.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/renderer/canvas/Layer\n */\nimport LayerRenderer from '../Layer.js';\nimport RenderEvent from '../../render/Event.js';\nimport RenderEventType from '../../render/EventType.js';\nimport { apply as applyTransform, compose as composeTransform, create as createTransform, } from '../../transform.js';\nimport { containsCoordinate, getBottomLeft, getBottomRight, getTopLeft, getTopRight, } from '../../extent.js';\nimport { createCanvasContext2D } from '../../dom.js';\nimport { cssOpacity } from '../../css.js';\n/**\n * @abstract\n * @template {import(\"../../layer/Layer.js\").default} LayerType\n * @extends {LayerRenderer<LayerType>}\n */\nvar CanvasLayerRenderer = /** @class */ (function (_super) {\n __extends(CanvasLayerRenderer, _super);\n /**\n * @param {LayerType} layer Layer.\n */\n function CanvasLayerRenderer(layer) {\n var _this = _super.call(this, layer) || this;\n /**\n * @protected\n * @type {HTMLElement}\n */\n _this.container = null;\n /**\n * @protected\n * @type {number}\n */\n _this.renderedResolution;\n /**\n * A temporary transform. The values in this transform should only be used in a\n * function that sets the values.\n * @protected\n * @type {import(\"../../transform.js\").Transform}\n */\n _this.tempTransform = createTransform();\n /**\n * The transform for rendered pixels to viewport CSS pixels. This transform must\n * be set when rendering a frame and may be used by other functions after rendering.\n * @protected\n * @type {import(\"../../transform.js\").Transform}\n */\n _this.pixelTransform = createTransform();\n /**\n * The transform for viewport CSS pixels to rendered pixels. This transform must\n * be set when rendering a frame and may be used by other functions after rendering.\n * @protected\n * @type {import(\"../../transform.js\").Transform}\n */\n _this.inversePixelTransform = createTransform();\n /**\n * @type {CanvasRenderingContext2D}\n */\n _this.context = null;\n /**\n * @type {boolean}\n */\n _this.containerReused = false;\n return _this;\n }\n /**\n * Get a rendering container from an existing target, if compatible.\n * @param {HTMLElement} target Potential render target.\n * @param {string} transform CSS Transform.\n * @param {number} opacity Opacity.\n */\n CanvasLayerRenderer.prototype.useContainer = function (target, transform, opacity) {\n var layerClassName = this.getLayer().getClassName();\n var container, context;\n if (target &&\n target.style.opacity === cssOpacity(opacity) &&\n target.className === layerClassName) {\n var canvas = target.firstElementChild;\n if (canvas instanceof HTMLCanvasElement) {\n context = canvas.getContext('2d');\n }\n }\n if (context && context.canvas.style.transform === transform) {\n // Container of the previous layer renderer can be used.\n this.container = target;\n this.context = context;\n this.containerReused = true;\n }\n else if (this.containerReused) {\n // Previously reused container cannot be used any more.\n this.container = null;\n this.context = null;\n this.containerReused = false;\n }\n if (!this.container) {\n container = document.createElement('div');\n container.className = layerClassName;\n var style = container.style;\n style.position = 'absolute';\n style.width = '100%';\n style.height = '100%';\n context = createCanvasContext2D();\n var canvas = context.canvas;\n container.appendChild(canvas);\n style = canvas.style;\n style.position = 'absolute';\n style.left = '0';\n style.transformOrigin = 'top left';\n this.container = container;\n this.context = context;\n }\n };\n /**\n * @param {CanvasRenderingContext2D} context Context.\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n * @param {import(\"../../extent.js\").Extent} extent Clip extent.\n * @protected\n */\n CanvasLayerRenderer.prototype.clipUnrotated = function (context, frameState, extent) {\n var topLeft = getTopLeft(extent);\n var topRight = getTopRight(extent);\n var bottomRight = getBottomRight(extent);\n var bottomLeft = getBottomLeft(extent);\n applyTransform(frameState.coordinateToPixelTransform, topLeft);\n applyTransform(frameState.coordinateToPixelTransform, topRight);\n applyTransform(frameState.coordinateToPixelTransform, bottomRight);\n applyTransform(frameState.coordinateToPixelTransform, bottomLeft);\n var inverted = this.inversePixelTransform;\n applyTransform(inverted, topLeft);\n applyTransform(inverted, topRight);\n applyTransform(inverted, bottomRight);\n applyTransform(inverted, bottomLeft);\n context.save();\n context.beginPath();\n context.moveTo(Math.round(topLeft[0]), Math.round(topLeft[1]));\n context.lineTo(Math.round(topRight[0]), Math.round(topRight[1]));\n context.lineTo(Math.round(bottomRight[0]), Math.round(bottomRight[1]));\n context.lineTo(Math.round(bottomLeft[0]), Math.round(bottomLeft[1]));\n context.clip();\n };\n /**\n * @param {import(\"../../render/EventType.js\").default} type Event type.\n * @param {CanvasRenderingContext2D} context Context.\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n * @private\n */\n CanvasLayerRenderer.prototype.dispatchRenderEvent_ = function (type, context, frameState) {\n var layer = this.getLayer();\n if (layer.hasListener(type)) {\n var event_1 = new RenderEvent(type, this.inversePixelTransform, frameState, context);\n layer.dispatchEvent(event_1);\n }\n };\n /**\n * @param {CanvasRenderingContext2D} context Context.\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n * @protected\n */\n CanvasLayerRenderer.prototype.preRender = function (context, frameState) {\n this.dispatchRenderEvent_(RenderEventType.PRERENDER, context, frameState);\n };\n /**\n * @param {CanvasRenderingContext2D} context Context.\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n * @protected\n */\n CanvasLayerRenderer.prototype.postRender = function (context, frameState) {\n this.dispatchRenderEvent_(RenderEventType.POSTRENDER, context, frameState);\n };\n /**\n * Creates a transform for rendering to an element that will be rotated after rendering.\n * @param {import(\"../../coordinate.js\").Coordinate} center Center.\n * @param {number} resolution Resolution.\n * @param {number} rotation Rotation.\n * @param {number} pixelRatio Pixel ratio.\n * @param {number} width Width of the rendered element (in pixels).\n * @param {number} height Height of the rendered element (in pixels).\n * @param {number} offsetX Offset on the x-axis in view coordinates.\n * @protected\n * @return {!import(\"../../transform.js\").Transform} Transform.\n */\n CanvasLayerRenderer.prototype.getRenderTransform = function (center, resolution, rotation, pixelRatio, width, height, offsetX) {\n var dx1 = width / 2;\n var dy1 = height / 2;\n var sx = pixelRatio / resolution;\n var sy = -sx;\n var dx2 = -center[0] + offsetX;\n var dy2 = -center[1];\n return composeTransform(this.tempTransform, dx1, dy1, sx, sy, -rotation, dx2, dy2);\n };\n /**\n * @param {import(\"../../pixel.js\").Pixel} pixel Pixel.\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState FrameState.\n * @param {number} hitTolerance Hit tolerance in pixels.\n * @return {Uint8ClampedArray|Uint8Array} The result. If there is no data at the pixel\n * location, null will be returned. If there is data, but pixel values cannot be\n * returned, and empty array will be returned.\n */\n CanvasLayerRenderer.prototype.getDataAtPixel = function (pixel, frameState, hitTolerance) {\n var renderPixel = applyTransform(this.inversePixelTransform, pixel.slice());\n var context = this.context;\n var layer = this.getLayer();\n var layerExtent = layer.getExtent();\n if (layerExtent) {\n var renderCoordinate = applyTransform(frameState.pixelToCoordinateTransform, pixel.slice());\n /** get only data inside of the layer extent */\n if (!containsCoordinate(layerExtent, renderCoordinate)) {\n return null;\n }\n }\n var data;\n try {\n var x = Math.round(renderPixel[0]);\n var y = Math.round(renderPixel[1]);\n var newCanvas = document.createElement('canvas');\n var newContext = newCanvas.getContext('2d');\n newCanvas.width = 1;\n newCanvas.height = 1;\n newContext.clearRect(0, 0, 1, 1);\n newContext.drawImage(context.canvas, x, y, 1, 1, 0, 0, 1, 1);\n data = newContext.getImageData(0, 0, 1, 1).data;\n }\n catch (err) {\n if (err.name === 'SecurityError') {\n // tainted canvas, we assume there is data at the given pixel (although there might not be)\n return new Uint8Array();\n }\n return data;\n }\n if (data[3] === 0) {\n return null;\n }\n return data;\n };\n return CanvasLayerRenderer;\n}(LayerRenderer));\nexport default CanvasLayerRenderer;\n//# sourceMappingURL=Layer.js.map","/**\n * @module ol/TileRange\n */\n/**\n * A representation of a contiguous block of tiles. A tile range is specified\n * by its min/max tile coordinates and is inclusive of coordinates.\n */\nvar TileRange = /** @class */ (function () {\n /**\n * @param {number} minX Minimum X.\n * @param {number} maxX Maximum X.\n * @param {number} minY Minimum Y.\n * @param {number} maxY Maximum Y.\n */\n function TileRange(minX, maxX, minY, maxY) {\n /**\n * @type {number}\n */\n this.minX = minX;\n /**\n * @type {number}\n */\n this.maxX = maxX;\n /**\n * @type {number}\n */\n this.minY = minY;\n /**\n * @type {number}\n */\n this.maxY = maxY;\n }\n /**\n * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @return {boolean} Contains tile coordinate.\n */\n TileRange.prototype.contains = function (tileCoord) {\n return this.containsXY(tileCoord[1], tileCoord[2]);\n };\n /**\n * @param {TileRange} tileRange Tile range.\n * @return {boolean} Contains.\n */\n TileRange.prototype.containsTileRange = function (tileRange) {\n return (this.minX <= tileRange.minX &&\n tileRange.maxX <= this.maxX &&\n this.minY <= tileRange.minY &&\n tileRange.maxY <= this.maxY);\n };\n /**\n * @param {number} x Tile coordinate x.\n * @param {number} y Tile coordinate y.\n * @return {boolean} Contains coordinate.\n */\n TileRange.prototype.containsXY = function (x, y) {\n return this.minX <= x && x <= this.maxX && this.minY <= y && y <= this.maxY;\n };\n /**\n * @param {TileRange} tileRange Tile range.\n * @return {boolean} Equals.\n */\n TileRange.prototype.equals = function (tileRange) {\n return (this.minX == tileRange.minX &&\n this.minY == tileRange.minY &&\n this.maxX == tileRange.maxX &&\n this.maxY == tileRange.maxY);\n };\n /**\n * @param {TileRange} tileRange Tile range.\n */\n TileRange.prototype.extend = function (tileRange) {\n if (tileRange.minX < this.minX) {\n this.minX = tileRange.minX;\n }\n if (tileRange.maxX > this.maxX) {\n this.maxX = tileRange.maxX;\n }\n if (tileRange.minY < this.minY) {\n this.minY = tileRange.minY;\n }\n if (tileRange.maxY > this.maxY) {\n this.maxY = tileRange.maxY;\n }\n };\n /**\n * @return {number} Height.\n */\n TileRange.prototype.getHeight = function () {\n return this.maxY - this.minY + 1;\n };\n /**\n * @return {import(\"./size.js\").Size} Size.\n */\n TileRange.prototype.getSize = function () {\n return [this.getWidth(), this.getHeight()];\n };\n /**\n * @return {number} Width.\n */\n TileRange.prototype.getWidth = function () {\n return this.maxX - this.minX + 1;\n };\n /**\n * @param {TileRange} tileRange Tile range.\n * @return {boolean} Intersects.\n */\n TileRange.prototype.intersects = function (tileRange) {\n return (this.minX <= tileRange.maxX &&\n this.maxX >= tileRange.minX &&\n this.minY <= tileRange.maxY &&\n this.maxY >= tileRange.minY);\n };\n return TileRange;\n}());\n/**\n * @param {number} minX Minimum X.\n * @param {number} maxX Maximum X.\n * @param {number} minY Minimum Y.\n * @param {number} maxY Maximum Y.\n * @param {TileRange} [tileRange] TileRange.\n * @return {TileRange} Tile range.\n */\nexport function createOrUpdate(minX, maxX, minY, maxY, tileRange) {\n if (tileRange !== undefined) {\n tileRange.minX = minX;\n tileRange.maxX = maxX;\n tileRange.minY = minY;\n tileRange.maxY = maxY;\n return tileRange;\n }\n else {\n return new TileRange(minX, maxX, minY, maxY);\n }\n}\nexport default TileRange;\n//# sourceMappingURL=TileRange.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/renderer/canvas/TileLayer\n */\nimport CanvasLayerRenderer from './Layer.js';\nimport TileRange from '../../TileRange.js';\nimport TileState from '../../TileState.js';\nimport { apply as applyTransform, compose as composeTransform, makeInverse, } from '../../transform.js';\nimport { assign } from '../../obj.js';\nimport { createEmpty, equals, getIntersection, getTopLeft, } from '../../extent.js';\nimport { cssOpacity } from '../../css.js';\nimport { fromUserExtent } from '../../proj.js';\nimport { getUid } from '../../util.js';\nimport { numberSafeCompareFunction } from '../../array.js';\nimport { toString as toTransformString } from '../../transform.js';\n/**\n * @classdesc\n * Canvas renderer for tile layers.\n * @api\n */\nvar CanvasTileLayerRenderer = /** @class */ (function (_super) {\n __extends(CanvasTileLayerRenderer, _super);\n /**\n * @param {import(\"../../layer/Tile.js\").default|import(\"../../layer/VectorTile.js\").default} tileLayer Tile layer.\n */\n function CanvasTileLayerRenderer(tileLayer) {\n var _this = _super.call(this, tileLayer) || this;\n /**\n * Rendered extent has changed since the previous `renderFrame()` call\n * @type {boolean}\n */\n _this.extentChanged = true;\n /**\n * @private\n * @type {?import(\"../../extent.js\").Extent}\n */\n _this.renderedExtent_ = null;\n /**\n * @protected\n * @type {number}\n */\n _this.renderedPixelRatio;\n /**\n * @protected\n * @type {import(\"../../proj/Projection.js\").default}\n */\n _this.renderedProjection = null;\n /**\n * @protected\n * @type {number}\n */\n _this.renderedRevision;\n /**\n * @protected\n * @type {!Array<import(\"../../Tile.js\").default>}\n */\n _this.renderedTiles = [];\n /**\n * @private\n * @type {boolean}\n */\n _this.newTiles_ = false;\n /**\n * @protected\n * @type {import(\"../../extent.js\").Extent}\n */\n _this.tmpExtent = createEmpty();\n /**\n * @private\n * @type {import(\"../../TileRange.js\").default}\n */\n _this.tmpTileRange_ = new TileRange(0, 0, 0, 0);\n return _this;\n }\n /**\n * @protected\n * @param {import(\"../../Tile.js\").default} tile Tile.\n * @return {boolean} Tile is drawable.\n */\n CanvasTileLayerRenderer.prototype.isDrawableTile = function (tile) {\n var tileLayer = this.getLayer();\n var tileState = tile.getState();\n var useInterimTilesOnError = tileLayer.getUseInterimTilesOnError();\n return (tileState == TileState.LOADED ||\n tileState == TileState.EMPTY ||\n (tileState == TileState.ERROR && !useInterimTilesOnError));\n };\n /**\n * @param {number} z Tile coordinate z.\n * @param {number} x Tile coordinate x.\n * @param {number} y Tile coordinate y.\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n * @return {!import(\"../../Tile.js\").default} Tile.\n */\n CanvasTileLayerRenderer.prototype.getTile = function (z, x, y, frameState) {\n var pixelRatio = frameState.pixelRatio;\n var projection = frameState.viewState.projection;\n var tileLayer = this.getLayer();\n var tileSource = tileLayer.getSource();\n var tile = tileSource.getTile(z, x, y, pixelRatio, projection);\n if (tile.getState() == TileState.ERROR) {\n if (!tileLayer.getUseInterimTilesOnError()) {\n // When useInterimTilesOnError is false, we consider the error tile as loaded.\n tile.setState(TileState.LOADED);\n }\n else if (tileLayer.getPreload() > 0) {\n // Preloaded tiles for lower resolutions might have finished loading.\n this.newTiles_ = true;\n }\n }\n if (!this.isDrawableTile(tile)) {\n tile = tile.getInterimTile();\n }\n return tile;\n };\n /**\n * @param {Object<number, Object<string, import(\"../../Tile.js\").default>>} tiles Lookup of loaded tiles by zoom level.\n * @param {number} zoom Zoom level.\n * @param {import(\"../../Tile.js\").default} tile Tile.\n * @return {boolean|void} If `false`, the tile will not be considered loaded.\n */\n CanvasTileLayerRenderer.prototype.loadedTileCallback = function (tiles, zoom, tile) {\n if (this.isDrawableTile(tile)) {\n return _super.prototype.loadedTileCallback.call(this, tiles, zoom, tile);\n }\n return false;\n };\n /**\n * Determine whether render should be called.\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n * @return {boolean} Layer is ready to be rendered.\n */\n CanvasTileLayerRenderer.prototype.prepareFrame = function (frameState) {\n return !!this.getLayer().getSource();\n };\n /**\n * Render the layer.\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n * @param {HTMLElement} target Target that may be used to render content to.\n * @return {HTMLElement} The rendered element.\n */\n CanvasTileLayerRenderer.prototype.renderFrame = function (frameState, target) {\n var layerState = frameState.layerStatesArray[frameState.layerIndex];\n var viewState = frameState.viewState;\n var projection = viewState.projection;\n var viewResolution = viewState.resolution;\n var viewCenter = viewState.center;\n var rotation = viewState.rotation;\n var pixelRatio = frameState.pixelRatio;\n var tileLayer = this.getLayer();\n var tileSource = tileLayer.getSource();\n var sourceRevision = tileSource.getRevision();\n var tileGrid = tileSource.getTileGridForProjection(projection);\n var z = tileGrid.getZForResolution(viewResolution, tileSource.zDirection);\n var tileResolution = tileGrid.getResolution(z);\n var extent = frameState.extent;\n var layerExtent = layerState.extent && fromUserExtent(layerState.extent, projection);\n if (layerExtent) {\n extent = getIntersection(extent, fromUserExtent(layerState.extent, projection));\n }\n var tilePixelRatio = tileSource.getTilePixelRatio(pixelRatio);\n // desired dimensions of the canvas in pixels\n var width = Math.round(frameState.size[0] * tilePixelRatio);\n var height = Math.round(frameState.size[1] * tilePixelRatio);\n if (rotation) {\n var size = Math.round(Math.sqrt(width * width + height * height));\n width = size;\n height = size;\n }\n var dx = (tileResolution * width) / 2 / tilePixelRatio;\n var dy = (tileResolution * height) / 2 / tilePixelRatio;\n var canvasExtent = [\n viewCenter[0] - dx,\n viewCenter[1] - dy,\n viewCenter[0] + dx,\n viewCenter[1] + dy,\n ];\n var tileRange = tileGrid.getTileRangeForExtentAndZ(extent, z);\n /**\n * @type {Object<number, Object<string, import(\"../../Tile.js\").default>>}\n */\n var tilesToDrawByZ = {};\n tilesToDrawByZ[z] = {};\n var findLoadedTiles = this.createLoadedTileFinder(tileSource, projection, tilesToDrawByZ);\n var tmpExtent = this.tmpExtent;\n var tmpTileRange = this.tmpTileRange_;\n this.newTiles_ = false;\n for (var x = tileRange.minX; x <= tileRange.maxX; ++x) {\n for (var y = tileRange.minY; y <= tileRange.maxY; ++y) {\n var tile = this.getTile(z, x, y, frameState);\n if (this.isDrawableTile(tile)) {\n var uid = getUid(this);\n if (tile.getState() == TileState.LOADED) {\n tilesToDrawByZ[z][tile.tileCoord.toString()] = tile;\n var inTransition = tile.inTransition(uid);\n if (!this.newTiles_ &&\n (inTransition || this.renderedTiles.indexOf(tile) === -1)) {\n this.newTiles_ = true;\n }\n }\n if (tile.getAlpha(uid, frameState.time) === 1) {\n // don't look for alt tiles if alpha is 1\n continue;\n }\n }\n var childTileRange = tileGrid.getTileCoordChildTileRange(tile.tileCoord, tmpTileRange, tmpExtent);\n var covered = false;\n if (childTileRange) {\n covered = findLoadedTiles(z + 1, childTileRange);\n }\n if (!covered) {\n tileGrid.forEachTileCoordParentTileRange(tile.tileCoord, findLoadedTiles, tmpTileRange, tmpExtent);\n }\n }\n }\n var canvasScale = tileResolution / viewResolution;\n // set forward and inverse pixel transforms\n composeTransform(this.pixelTransform, frameState.size[0] / 2, frameState.size[1] / 2, 1 / tilePixelRatio, 1 / tilePixelRatio, rotation, -width / 2, -height / 2);\n var canvasTransform = toTransformString(this.pixelTransform);\n this.useContainer(target, canvasTransform, layerState.opacity);\n var context = this.context;\n var canvas = context.canvas;\n makeInverse(this.inversePixelTransform, this.pixelTransform);\n // set scale transform for calculating tile positions on the canvas\n composeTransform(this.tempTransform, width / 2, height / 2, canvasScale, canvasScale, 0, -width / 2, -height / 2);\n if (canvas.width != width || canvas.height != height) {\n canvas.width = width;\n canvas.height = height;\n }\n else if (!this.containerReused) {\n context.clearRect(0, 0, width, height);\n }\n if (layerExtent) {\n this.clipUnrotated(context, frameState, layerExtent);\n }\n assign(context, tileSource.getContextOptions());\n this.preRender(context, frameState);\n this.renderedTiles.length = 0;\n /** @type {Array<number>} */\n var zs = Object.keys(tilesToDrawByZ).map(Number);\n zs.sort(numberSafeCompareFunction);\n var clips, clipZs, currentClip;\n if (layerState.opacity === 1 &&\n (!this.containerReused ||\n tileSource.getOpaque(frameState.viewState.projection))) {\n zs = zs.reverse();\n }\n else {\n clips = [];\n clipZs = [];\n }\n for (var i = zs.length - 1; i >= 0; --i) {\n var currentZ = zs[i];\n var currentTilePixelSize = tileSource.getTilePixelSize(currentZ, pixelRatio, projection);\n var currentResolution = tileGrid.getResolution(currentZ);\n var currentScale = currentResolution / tileResolution;\n var dx_1 = currentTilePixelSize[0] * currentScale * canvasScale;\n var dy_1 = currentTilePixelSize[1] * currentScale * canvasScale;\n var originTileCoord = tileGrid.getTileCoordForCoordAndZ(getTopLeft(canvasExtent), currentZ);\n var originTileExtent = tileGrid.getTileCoordExtent(originTileCoord);\n var origin_1 = applyTransform(this.tempTransform, [\n (tilePixelRatio * (originTileExtent[0] - canvasExtent[0])) /\n tileResolution,\n (tilePixelRatio * (canvasExtent[3] - originTileExtent[3])) /\n tileResolution,\n ]);\n var tileGutter = tilePixelRatio * tileSource.getGutterForProjection(projection);\n var tilesToDraw = tilesToDrawByZ[currentZ];\n for (var tileCoordKey in tilesToDraw) {\n var tile = /** @type {import(\"../../ImageTile.js\").default} */ (tilesToDraw[tileCoordKey]);\n var tileCoord = tile.tileCoord;\n // Calculate integer positions and sizes so that tiles align\n var xIndex = originTileCoord[1] - tileCoord[1];\n var nextX = Math.round(origin_1[0] - (xIndex - 1) * dx_1);\n var yIndex = originTileCoord[2] - tileCoord[2];\n var nextY = Math.round(origin_1[1] - (yIndex - 1) * dy_1);\n var x = Math.round(origin_1[0] - xIndex * dx_1);\n var y = Math.round(origin_1[1] - yIndex * dy_1);\n var w = nextX - x;\n var h = nextY - y;\n var transition = z === currentZ;\n var inTransition = transition && tile.getAlpha(getUid(this), frameState.time) !== 1;\n if (!inTransition) {\n if (clips) {\n // Clip mask for regions in this tile that already filled by a higher z tile\n context.save();\n currentClip = [x, y, x + w, y, x + w, y + h, x, y + h];\n for (var i_1 = 0, ii = clips.length; i_1 < ii; ++i_1) {\n if (z !== currentZ && currentZ < clipZs[i_1]) {\n var clip = clips[i_1];\n context.beginPath();\n // counter-clockwise (outer ring) for current tile\n context.moveTo(currentClip[0], currentClip[1]);\n context.lineTo(currentClip[2], currentClip[3]);\n context.lineTo(currentClip[4], currentClip[5]);\n context.lineTo(currentClip[6], currentClip[7]);\n // clockwise (inner ring) for higher z tile\n context.moveTo(clip[6], clip[7]);\n context.lineTo(clip[4], clip[5]);\n context.lineTo(clip[2], clip[3]);\n context.lineTo(clip[0], clip[1]);\n context.clip();\n }\n }\n clips.push(currentClip);\n clipZs.push(currentZ);\n }\n else {\n context.clearRect(x, y, w, h);\n }\n }\n this.drawTileImage(tile, frameState, x, y, w, h, tileGutter, transition);\n if (clips && !inTransition) {\n context.restore();\n this.renderedTiles.unshift(tile);\n }\n else {\n this.renderedTiles.push(tile);\n }\n this.updateUsedTiles(frameState.usedTiles, tileSource, tile);\n }\n }\n this.renderedRevision = sourceRevision;\n this.renderedResolution = tileResolution;\n this.extentChanged =\n !this.renderedExtent_ || !equals(this.renderedExtent_, canvasExtent);\n this.renderedExtent_ = canvasExtent;\n this.renderedPixelRatio = pixelRatio;\n this.renderedProjection = projection;\n this.manageTilePyramid(frameState, tileSource, tileGrid, pixelRatio, projection, extent, z, tileLayer.getPreload());\n this.scheduleExpireCache(frameState, tileSource);\n this.postRender(context, frameState);\n if (layerState.extent) {\n context.restore();\n }\n if (canvasTransform !== canvas.style.transform) {\n canvas.style.transform = canvasTransform;\n }\n var opacity = cssOpacity(layerState.opacity);\n var container = this.container;\n if (opacity !== container.style.opacity) {\n container.style.opacity = opacity;\n }\n return this.container;\n };\n /**\n * @param {import(\"../../ImageTile.js\").default} tile Tile.\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n * @param {number} x Left of the tile.\n * @param {number} y Top of the tile.\n * @param {number} w Width of the tile.\n * @param {number} h Height of the tile.\n * @param {number} gutter Tile gutter.\n * @param {boolean} transition Apply an alpha transition.\n */\n CanvasTileLayerRenderer.prototype.drawTileImage = function (tile, frameState, x, y, w, h, gutter, transition) {\n var image = this.getTileImage(tile);\n if (!image) {\n return;\n }\n var uid = getUid(this);\n var alpha = transition ? tile.getAlpha(uid, frameState.time) : 1;\n var alphaChanged = alpha !== this.context.globalAlpha;\n if (alphaChanged) {\n this.context.save();\n this.context.globalAlpha = alpha;\n }\n this.context.drawImage(image, gutter, gutter, image.width - 2 * gutter, image.height - 2 * gutter, x, y, w, h);\n if (alphaChanged) {\n this.context.restore();\n }\n if (alpha !== 1) {\n frameState.animate = true;\n }\n else if (transition) {\n tile.endTransition(uid);\n }\n };\n /**\n * @return {HTMLCanvasElement} Image\n */\n CanvasTileLayerRenderer.prototype.getImage = function () {\n var context = this.context;\n return context ? context.canvas : null;\n };\n /**\n * Get the image from a tile.\n * @param {import(\"../../ImageTile.js\").default} tile Tile.\n * @return {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} Image.\n * @protected\n */\n CanvasTileLayerRenderer.prototype.getTileImage = function (tile) {\n return tile.getImage();\n };\n /**\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n * @param {import(\"../../source/Tile.js\").default} tileSource Tile source.\n * @protected\n */\n CanvasTileLayerRenderer.prototype.scheduleExpireCache = function (frameState, tileSource) {\n if (tileSource.canExpireCache()) {\n /**\n * @param {import(\"../../source/Tile.js\").default} tileSource Tile source.\n * @param {import(\"../../PluggableMap.js\").default} map Map.\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n */\n var postRenderFunction = function (tileSource, map, frameState) {\n var tileSourceKey = getUid(tileSource);\n if (tileSourceKey in frameState.usedTiles) {\n tileSource.expireCache(frameState.viewState.projection, frameState.usedTiles[tileSourceKey]);\n }\n }.bind(null, tileSource);\n frameState.postRenderFunctions.push(\n /** @type {import(\"../../PluggableMap.js\").PostRenderFunction} */ (postRenderFunction));\n }\n };\n /**\n * @param {!Object<string, !Object<string, boolean>>} usedTiles Used tiles.\n * @param {import(\"../../source/Tile.js\").default} tileSource Tile source.\n * @param {import('../../Tile.js').default} tile Tile.\n * @protected\n */\n CanvasTileLayerRenderer.prototype.updateUsedTiles = function (usedTiles, tileSource, tile) {\n // FIXME should we use tilesToDrawByZ instead?\n var tileSourceKey = getUid(tileSource);\n if (!(tileSourceKey in usedTiles)) {\n usedTiles[tileSourceKey] = {};\n }\n usedTiles[tileSourceKey][tile.getKey()] = true;\n };\n /**\n * Manage tile pyramid.\n * This function performs a number of functions related to the tiles at the\n * current zoom and lower zoom levels:\n * - registers idle tiles in frameState.wantedTiles so that they are not\n * discarded by the tile queue\n * - enqueues missing tiles\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n * @param {import(\"../../source/Tile.js\").default} tileSource Tile source.\n * @param {import(\"../../tilegrid/TileGrid.js\").default} tileGrid Tile grid.\n * @param {number} pixelRatio Pixel ratio.\n * @param {import(\"../../proj/Projection.js\").default} projection Projection.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @param {number} currentZ Current Z.\n * @param {number} preload Load low resolution tiles up to 'preload' levels.\n * @param {function(import(\"../../Tile.js\").default):void} [opt_tileCallback] Tile callback.\n * @protected\n */\n CanvasTileLayerRenderer.prototype.manageTilePyramid = function (frameState, tileSource, tileGrid, pixelRatio, projection, extent, currentZ, preload, opt_tileCallback) {\n var tileSourceKey = getUid(tileSource);\n if (!(tileSourceKey in frameState.wantedTiles)) {\n frameState.wantedTiles[tileSourceKey] = {};\n }\n var wantedTiles = frameState.wantedTiles[tileSourceKey];\n var tileQueue = frameState.tileQueue;\n var minZoom = tileGrid.getMinZoom();\n var tileCount = 0;\n var tile, tileRange, tileResolution, x, y, z;\n for (z = minZoom; z <= currentZ; ++z) {\n tileRange = tileGrid.getTileRangeForExtentAndZ(extent, z, tileRange);\n tileResolution = tileGrid.getResolution(z);\n for (x = tileRange.minX; x <= tileRange.maxX; ++x) {\n for (y = tileRange.minY; y <= tileRange.maxY; ++y) {\n if (currentZ - z <= preload) {\n ++tileCount;\n tile = tileSource.getTile(z, x, y, pixelRatio, projection);\n if (tile.getState() == TileState.IDLE) {\n wantedTiles[tile.getKey()] = true;\n if (!tileQueue.isKeyQueued(tile.getKey())) {\n tileQueue.enqueue([\n tile,\n tileSourceKey,\n tileGrid.getTileCoordCenter(tile.tileCoord),\n tileResolution,\n ]);\n }\n }\n if (opt_tileCallback !== undefined) {\n opt_tileCallback(tile);\n }\n }\n else {\n tileSource.useTile(z, x, y, projection);\n }\n }\n }\n }\n tileSource.updateCacheSize(tileCount, projection);\n };\n return CanvasTileLayerRenderer;\n}(CanvasLayerRenderer));\n/**\n * @function\n * @return {import(\"../../layer/Tile.js\").default|import(\"../../layer/VectorTile.js\").default}\n */\nCanvasTileLayerRenderer.prototype.getLayer;\nexport default CanvasTileLayerRenderer;\n//# sourceMappingURL=TileLayer.js.map","/**\n * @module ol/TileState\n */\n/**\n * @enum {number}\n */\nexport default {\n IDLE: 0,\n LOADING: 1,\n LOADED: 2,\n /**\n * Indicates that tile loading failed\n * @type {number}\n */\n ERROR: 3,\n EMPTY: 4,\n};\n//# sourceMappingURL=TileState.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/layer/Tile\n */\nimport BaseTileLayer from './BaseTile.js';\nimport CanvasTileLayerRenderer from '../renderer/canvas/TileLayer.js';\n/**\n * @classdesc\n * For layer sources that provide pre-rendered, tiled images in grids that are\n * organized by zoom levels for specific resolutions.\n * Note that any property set in the options is set as a {@link module:ol/Object~BaseObject}\n * property on the layer object; for example, setting `title: 'My Title'` in the\n * options means that `title` is observable, and has get/set accessors.\n *\n * @template {import(\"../source/Tile.js\").default} TileSourceType\n * @extends {BaseTileLayer<TileSourceType>}\n * @api\n */\nvar TileLayer = /** @class */ (function (_super) {\n __extends(TileLayer, _super);\n /**\n * @param {import(\"./BaseTile.js\").Options<TileSourceType>} [opt_options] Tile layer options.\n */\n function TileLayer(opt_options) {\n return _super.call(this, opt_options) || this;\n }\n /**\n * Create a renderer for this layer.\n * @return {import(\"../renderer/Layer.js\").default} A layer renderer.\n * @protected\n */\n TileLayer.prototype.createRenderer = function () {\n return new CanvasTileLayerRenderer(this);\n };\n return TileLayer;\n}(BaseTileLayer));\nexport default TileLayer;\n//# sourceMappingURL=Tile.js.map","\nexport default function quickselect(arr, k, left, right, compare) {\n quickselectStep(arr, k, left || 0, right || (arr.length - 1), compare || defaultCompare);\n}\n\nfunction quickselectStep(arr, k, left, right, compare) {\n\n while (right > left) {\n if (right - left > 600) {\n var n = right - left + 1;\n var m = k - left + 1;\n var z = Math.log(n);\n var s = 0.5 * Math.exp(2 * z / 3);\n var sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n var newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n var newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n quickselectStep(arr, k, newLeft, newRight, compare);\n }\n\n var t = arr[k];\n var i = left;\n var j = right;\n\n swap(arr, left, k);\n if (compare(arr[right], t) > 0) swap(arr, left, right);\n\n while (i < j) {\n swap(arr, i, j);\n i++;\n j--;\n while (compare(arr[i], t) < 0) i++;\n while (compare(arr[j], t) > 0) j--;\n }\n\n if (compare(arr[left], t) === 0) swap(arr, left, j);\n else {\n j++;\n swap(arr, j, right);\n }\n\n if (j <= k) left = j + 1;\n if (k <= j) right = j - 1;\n }\n}\n\nfunction swap(arr, i, j) {\n var tmp = arr[i];\n arr[i] = arr[j];\n arr[j] = tmp;\n}\n\nfunction defaultCompare(a, b) {\n return a < b ? -1 : a > b ? 1 : 0;\n}\n","import quickselect from 'quickselect';\n\nexport default class RBush {\n constructor(maxEntries = 9) {\n // max entries in a node is 9 by default; min node fill is 40% for best performance\n this._maxEntries = Math.max(4, maxEntries);\n this._minEntries = Math.max(2, Math.ceil(this._maxEntries * 0.4));\n this.clear();\n }\n\n all() {\n return this._all(this.data, []);\n }\n\n search(bbox) {\n let node = this.data;\n const result = [];\n\n if (!intersects(bbox, node)) return result;\n\n const toBBox = this.toBBox;\n const nodesToSearch = [];\n\n while (node) {\n for (let i = 0; i < node.children.length; i++) {\n const child = node.children[i];\n const childBBox = node.leaf ? toBBox(child) : child;\n\n if (intersects(bbox, childBBox)) {\n if (node.leaf) result.push(child);\n else if (contains(bbox, childBBox)) this._all(child, result);\n else nodesToSearch.push(child);\n }\n }\n node = nodesToSearch.pop();\n }\n\n return result;\n }\n\n collides(bbox) {\n let node = this.data;\n\n if (!intersects(bbox, node)) return false;\n\n const nodesToSearch = [];\n while (node) {\n for (let i = 0; i < node.children.length; i++) {\n const child = node.children[i];\n const childBBox = node.leaf ? this.toBBox(child) : child;\n\n if (intersects(bbox, childBBox)) {\n if (node.leaf || contains(bbox, childBBox)) return true;\n nodesToSearch.push(child);\n }\n }\n node = nodesToSearch.pop();\n }\n\n return false;\n }\n\n load(data) {\n if (!(data && data.length)) return this;\n\n if (data.length < this._minEntries) {\n for (let i = 0; i < data.length; i++) {\n this.insert(data[i]);\n }\n return this;\n }\n\n // recursively build the tree with the given data from scratch using OMT algorithm\n let node = this._build(data.slice(), 0, data.length - 1, 0);\n\n if (!this.data.children.length) {\n // save as is if tree is empty\n this.data = node;\n\n } else if (this.data.height === node.height) {\n // split root if trees have the same height\n this._splitRoot(this.data, node);\n\n } else {\n if (this.data.height < node.height) {\n // swap trees if inserted one is bigger\n const tmpNode = this.data;\n this.data = node;\n node = tmpNode;\n }\n\n // insert the small tree into the large tree at appropriate level\n this._insert(node, this.data.height - node.height - 1, true);\n }\n\n return this;\n }\n\n insert(item) {\n if (item) this._insert(item, this.data.height - 1);\n return this;\n }\n\n clear() {\n this.data = createNode([]);\n return this;\n }\n\n remove(item, equalsFn) {\n if (!item) return this;\n\n let node = this.data;\n const bbox = this.toBBox(item);\n const path = [];\n const indexes = [];\n let i, parent, goingUp;\n\n // depth-first iterative tree traversal\n while (node || path.length) {\n\n if (!node) { // go up\n node = path.pop();\n parent = path[path.length - 1];\n i = indexes.pop();\n goingUp = true;\n }\n\n if (node.leaf) { // check current node\n const index = findItem(item, node.children, equalsFn);\n\n if (index !== -1) {\n // item found, remove the item and condense tree upwards\n node.children.splice(index, 1);\n path.push(node);\n this._condense(path);\n return this;\n }\n }\n\n if (!goingUp && !node.leaf && contains(node, bbox)) { // go down\n path.push(node);\n indexes.push(i);\n i = 0;\n parent = node;\n node = node.children[0];\n\n } else if (parent) { // go right\n i++;\n node = parent.children[i];\n goingUp = false;\n\n } else node = null; // nothing found\n }\n\n return this;\n }\n\n toBBox(item) { return item; }\n\n compareMinX(a, b) { return a.minX - b.minX; }\n compareMinY(a, b) { return a.minY - b.minY; }\n\n toJSON() { return this.data; }\n\n fromJSON(data) {\n this.data = data;\n return this;\n }\n\n _all(node, result) {\n const nodesToSearch = [];\n while (node) {\n if (node.leaf) result.push(...node.children);\n else nodesToSearch.push(...node.children);\n\n node = nodesToSearch.pop();\n }\n return result;\n }\n\n _build(items, left, right, height) {\n\n const N = right - left + 1;\n let M = this._maxEntries;\n let node;\n\n if (N <= M) {\n // reached leaf level; return leaf\n node = createNode(items.slice(left, right + 1));\n calcBBox(node, this.toBBox);\n return node;\n }\n\n if (!height) {\n // target height of the bulk-loaded tree\n height = Math.ceil(Math.log(N) / Math.log(M));\n\n // target number of root entries to maximize storage utilization\n M = Math.ceil(N / Math.pow(M, height - 1));\n }\n\n node = createNode([]);\n node.leaf = false;\n node.height = height;\n\n // split the items into M mostly square tiles\n\n const N2 = Math.ceil(N / M);\n const N1 = N2 * Math.ceil(Math.sqrt(M));\n\n multiSelect(items, left, right, N1, this.compareMinX);\n\n for (let i = left; i <= right; i += N1) {\n\n const right2 = Math.min(i + N1 - 1, right);\n\n multiSelect(items, i, right2, N2, this.compareMinY);\n\n for (let j = i; j <= right2; j += N2) {\n\n const right3 = Math.min(j + N2 - 1, right2);\n\n // pack each entry recursively\n node.children.push(this._build(items, j, right3, height - 1));\n }\n }\n\n calcBBox(node, this.toBBox);\n\n return node;\n }\n\n _chooseSubtree(bbox, node, level, path) {\n while (true) {\n path.push(node);\n\n if (node.leaf || path.length - 1 === level) break;\n\n let minArea = Infinity;\n let minEnlargement = Infinity;\n let targetNode;\n\n for (let i = 0; i < node.children.length; i++) {\n const child = node.children[i];\n const area = bboxArea(child);\n const enlargement = enlargedArea(bbox, child) - area;\n\n // choose entry with the least area enlargement\n if (enlargement < minEnlargement) {\n minEnlargement = enlargement;\n minArea = area < minArea ? area : minArea;\n targetNode = child;\n\n } else if (enlargement === minEnlargement) {\n // otherwise choose one with the smallest area\n if (area < minArea) {\n minArea = area;\n targetNode = child;\n }\n }\n }\n\n node = targetNode || node.children[0];\n }\n\n return node;\n }\n\n _insert(item, level, isNode) {\n const bbox = isNode ? item : this.toBBox(item);\n const insertPath = [];\n\n // find the best node for accommodating the item, saving all nodes along the path too\n const node = this._chooseSubtree(bbox, this.data, level, insertPath);\n\n // put the item into the node\n node.children.push(item);\n extend(node, bbox);\n\n // split on node overflow; propagate upwards if necessary\n while (level >= 0) {\n if (insertPath[level].children.length > this._maxEntries) {\n this._split(insertPath, level);\n level--;\n } else break;\n }\n\n // adjust bboxes along the insertion path\n this._adjustParentBBoxes(bbox, insertPath, level);\n }\n\n // split overflowed node into two\n _split(insertPath, level) {\n const node = insertPath[level];\n const M = node.children.length;\n const m = this._minEntries;\n\n this._chooseSplitAxis(node, m, M);\n\n const splitIndex = this._chooseSplitIndex(node, m, M);\n\n const newNode = createNode(node.children.splice(splitIndex, node.children.length - splitIndex));\n newNode.height = node.height;\n newNode.leaf = node.leaf;\n\n calcBBox(node, this.toBBox);\n calcBBox(newNode, this.toBBox);\n\n if (level) insertPath[level - 1].children.push(newNode);\n else this._splitRoot(node, newNode);\n }\n\n _splitRoot(node, newNode) {\n // split root node\n this.data = createNode([node, newNode]);\n this.data.height = node.height + 1;\n this.data.leaf = false;\n calcBBox(this.data, this.toBBox);\n }\n\n _chooseSplitIndex(node, m, M) {\n let index;\n let minOverlap = Infinity;\n let minArea = Infinity;\n\n for (let i = m; i <= M - m; i++) {\n const bbox1 = distBBox(node, 0, i, this.toBBox);\n const bbox2 = distBBox(node, i, M, this.toBBox);\n\n const overlap = intersectionArea(bbox1, bbox2);\n const area = bboxArea(bbox1) + bboxArea(bbox2);\n\n // choose distribution with minimum overlap\n if (overlap < minOverlap) {\n minOverlap = overlap;\n index = i;\n\n minArea = area < minArea ? area : minArea;\n\n } else if (overlap === minOverlap) {\n // otherwise choose distribution with minimum area\n if (area < minArea) {\n minArea = area;\n index = i;\n }\n }\n }\n\n return index || M - m;\n }\n\n // sorts node children by the best axis for split\n _chooseSplitAxis(node, m, M) {\n const compareMinX = node.leaf ? this.compareMinX : compareNodeMinX;\n const compareMinY = node.leaf ? this.compareMinY : compareNodeMinY;\n const xMargin = this._allDistMargin(node, m, M, compareMinX);\n const yMargin = this._allDistMargin(node, m, M, compareMinY);\n\n // if total distributions margin value is minimal for x, sort by minX,\n // otherwise it's already sorted by minY\n if (xMargin < yMargin) node.children.sort(compareMinX);\n }\n\n // total margin of all possible split distributions where each node is at least m full\n _allDistMargin(node, m, M, compare) {\n node.children.sort(compare);\n\n const toBBox = this.toBBox;\n const leftBBox = distBBox(node, 0, m, toBBox);\n const rightBBox = distBBox(node, M - m, M, toBBox);\n let margin = bboxMargin(leftBBox) + bboxMargin(rightBBox);\n\n for (let i = m; i < M - m; i++) {\n const child = node.children[i];\n extend(leftBBox, node.leaf ? toBBox(child) : child);\n margin += bboxMargin(leftBBox);\n }\n\n for (let i = M - m - 1; i >= m; i--) {\n const child = node.children[i];\n extend(rightBBox, node.leaf ? toBBox(child) : child);\n margin += bboxMargin(rightBBox);\n }\n\n return margin;\n }\n\n _adjustParentBBoxes(bbox, path, level) {\n // adjust bboxes along the given tree path\n for (let i = level; i >= 0; i--) {\n extend(path[i], bbox);\n }\n }\n\n _condense(path) {\n // go through the path, removing empty nodes and updating bboxes\n for (let i = path.length - 1, siblings; i >= 0; i--) {\n if (path[i].children.length === 0) {\n if (i > 0) {\n siblings = path[i - 1].children;\n siblings.splice(siblings.indexOf(path[i]), 1);\n\n } else this.clear();\n\n } else calcBBox(path[i], this.toBBox);\n }\n }\n}\n\nfunction findItem(item, items, equalsFn) {\n if (!equalsFn) return items.indexOf(item);\n\n for (let i = 0; i < items.length; i++) {\n if (equalsFn(item, items[i])) return i;\n }\n return -1;\n}\n\n// calculate node's bbox from bboxes of its children\nfunction calcBBox(node, toBBox) {\n distBBox(node, 0, node.children.length, toBBox, node);\n}\n\n// min bounding rectangle of node children from k to p-1\nfunction distBBox(node, k, p, toBBox, destNode) {\n if (!destNode) destNode = createNode(null);\n destNode.minX = Infinity;\n destNode.minY = Infinity;\n destNode.maxX = -Infinity;\n destNode.maxY = -Infinity;\n\n for (let i = k; i < p; i++) {\n const child = node.children[i];\n extend(destNode, node.leaf ? toBBox(child) : child);\n }\n\n return destNode;\n}\n\nfunction extend(a, b) {\n a.minX = Math.min(a.minX, b.minX);\n a.minY = Math.min(a.minY, b.minY);\n a.maxX = Math.max(a.maxX, b.maxX);\n a.maxY = Math.max(a.maxY, b.maxY);\n return a;\n}\n\nfunction compareNodeMinX(a, b) { return a.minX - b.minX; }\nfunction compareNodeMinY(a, b) { return a.minY - b.minY; }\n\nfunction bboxArea(a) { return (a.maxX - a.minX) * (a.maxY - a.minY); }\nfunction bboxMargin(a) { return (a.maxX - a.minX) + (a.maxY - a.minY); }\n\nfunction enlargedArea(a, b) {\n return (Math.max(b.maxX, a.maxX) - Math.min(b.minX, a.minX)) *\n (Math.max(b.maxY, a.maxY) - Math.min(b.minY, a.minY));\n}\n\nfunction intersectionArea(a, b) {\n const minX = Math.max(a.minX, b.minX);\n const minY = Math.max(a.minY, b.minY);\n const maxX = Math.min(a.maxX, b.maxX);\n const maxY = Math.min(a.maxY, b.maxY);\n\n return Math.max(0, maxX - minX) *\n Math.max(0, maxY - minY);\n}\n\nfunction contains(a, b) {\n return a.minX <= b.minX &&\n a.minY <= b.minY &&\n b.maxX <= a.maxX &&\n b.maxY <= a.maxY;\n}\n\nfunction intersects(a, b) {\n return b.minX <= a.maxX &&\n b.minY <= a.maxY &&\n b.maxX >= a.minX &&\n b.maxY >= a.minY;\n}\n\nfunction createNode(children) {\n return {\n children,\n height: 1,\n leaf: true,\n minX: Infinity,\n minY: Infinity,\n maxX: -Infinity,\n maxY: -Infinity\n };\n}\n\n// sort an array so that items come in groups of n unsorted items, with groups sorted between each other;\n// combines selection algorithm with binary divide & conquer approach\n\nfunction multiSelect(arr, left, right, n, compare) {\n const stack = [left, right];\n\n while (stack.length) {\n right = stack.pop();\n left = stack.pop();\n\n if (right - left <= n) continue;\n\n const mid = left + Math.ceil((right - left) / n / 2) * n;\n quickselect(arr, mid, left, right, compare);\n\n stack.push(left, mid, mid, right);\n }\n}\n","/**\n * @module ol/size\n */\n/**\n * An array of numbers representing a size: `[width, height]`.\n * @typedef {Array<number>} Size\n * @api\n */\n/**\n * Returns a buffered size.\n * @param {Size} size Size.\n * @param {number} num The amount by which to buffer.\n * @param {Size} [opt_size] Optional reusable size array.\n * @return {Size} The buffered size.\n */\nexport function buffer(size, num, opt_size) {\n if (opt_size === undefined) {\n opt_size = [0, 0];\n }\n opt_size[0] = size[0] + 2 * num;\n opt_size[1] = size[1] + 2 * num;\n return opt_size;\n}\n/**\n * Determines if a size has a positive area.\n * @param {Size} size The size to test.\n * @return {boolean} The size has a positive area.\n */\nexport function hasArea(size) {\n return size[0] > 0 && size[1] > 0;\n}\n/**\n * Returns a size scaled by a ratio. The result will be an array of integers.\n * @param {Size} size Size.\n * @param {number} ratio Ratio.\n * @param {Size} [opt_size] Optional reusable size array.\n * @return {Size} The scaled size.\n */\nexport function scale(size, ratio, opt_size) {\n if (opt_size === undefined) {\n opt_size = [0, 0];\n }\n opt_size[0] = (size[0] * ratio + 0.5) | 0;\n opt_size[1] = (size[1] * ratio + 0.5) | 0;\n return opt_size;\n}\n/**\n * Returns an `Size` array for the passed in number (meaning: square) or\n * `Size` array.\n * (meaning: non-square),\n * @param {number|Size} size Width and height.\n * @param {Size} [opt_size] Optional reusable size array.\n * @return {Size} Size.\n * @api\n */\nexport function toSize(size, opt_size) {\n if (Array.isArray(size)) {\n return size;\n }\n else {\n if (opt_size === undefined) {\n opt_size = [size, size];\n }\n else {\n opt_size[0] = size;\n opt_size[1] = size;\n }\n return opt_size;\n }\n}\n//# sourceMappingURL=size.js.map","/**\n * @module ol/style/Image\n */\nimport { abstract } from '../util.js';\nimport { toSize } from '../size.js';\n/**\n * @typedef {Object} Options\n * @property {number} opacity Opacity.\n * @property {boolean} rotateWithView If the image should get rotated with the view.\n * @property {number} rotation Rotation.\n * @property {number|import(\"../size.js\").Size} scale Scale.\n * @property {Array<number>} displacement Displacement.\n */\n/**\n * @classdesc\n * A base class used for creating subclasses and not instantiated in\n * apps. Base class for {@link module:ol/style/Icon~Icon}, {@link module:ol/style/Circle~CircleStyle} and\n * {@link module:ol/style/RegularShape~RegularShape}.\n * @abstract\n * @api\n */\nvar ImageStyle = /** @class */ (function () {\n /**\n * @param {Options} options Options.\n */\n function ImageStyle(options) {\n /**\n * @private\n * @type {number}\n */\n this.opacity_ = options.opacity;\n /**\n * @private\n * @type {boolean}\n */\n this.rotateWithView_ = options.rotateWithView;\n /**\n * @private\n * @type {number}\n */\n this.rotation_ = options.rotation;\n /**\n * @private\n * @type {number|import(\"../size.js\").Size}\n */\n this.scale_ = options.scale;\n /**\n * @private\n * @type {import(\"../size.js\").Size}\n */\n this.scaleArray_ = toSize(options.scale);\n /**\n * @private\n * @type {Array<number>}\n */\n this.displacement_ = options.displacement;\n }\n /**\n * Clones the style.\n * @return {ImageStyle} The cloned style.\n * @api\n */\n ImageStyle.prototype.clone = function () {\n var scale = this.getScale();\n return new ImageStyle({\n opacity: this.getOpacity(),\n scale: Array.isArray(scale) ? scale.slice() : scale,\n rotation: this.getRotation(),\n rotateWithView: this.getRotateWithView(),\n displacement: this.getDisplacement().slice(),\n });\n };\n /**\n * Get the symbolizer opacity.\n * @return {number} Opacity.\n * @api\n */\n ImageStyle.prototype.getOpacity = function () {\n return this.opacity_;\n };\n /**\n * Determine whether the symbolizer rotates with the map.\n * @return {boolean} Rotate with map.\n * @api\n */\n ImageStyle.prototype.getRotateWithView = function () {\n return this.rotateWithView_;\n };\n /**\n * Get the symoblizer rotation.\n * @return {number} Rotation.\n * @api\n */\n ImageStyle.prototype.getRotation = function () {\n return this.rotation_;\n };\n /**\n * Get the symbolizer scale.\n * @return {number|import(\"../size.js\").Size} Scale.\n * @api\n */\n ImageStyle.prototype.getScale = function () {\n return this.scale_;\n };\n /**\n * Get the symbolizer scale array.\n * @return {import(\"../size.js\").Size} Scale array.\n */\n ImageStyle.prototype.getScaleArray = function () {\n return this.scaleArray_;\n };\n /**\n * Get the displacement of the shape\n * @return {Array<number>} Shape's center displacement\n * @api\n */\n ImageStyle.prototype.getDisplacement = function () {\n return this.displacement_;\n };\n /**\n * Get the anchor point in pixels. The anchor determines the center point for the\n * symbolizer.\n * @abstract\n * @return {Array<number>} Anchor.\n */\n ImageStyle.prototype.getAnchor = function () {\n return abstract();\n };\n /**\n * Get the image element for the symbolizer.\n * @abstract\n * @param {number} pixelRatio Pixel ratio.\n * @return {HTMLCanvasElement|HTMLVideoElement|HTMLImageElement} Image element.\n */\n ImageStyle.prototype.getImage = function (pixelRatio) {\n return abstract();\n };\n /**\n * @abstract\n * @return {HTMLCanvasElement|HTMLVideoElement|HTMLImageElement} Image element.\n */\n ImageStyle.prototype.getHitDetectionImage = function () {\n return abstract();\n };\n /**\n * Get the image pixel ratio.\n * @param {number} pixelRatio Pixel ratio.\n * @return {number} Pixel ratio.\n */\n ImageStyle.prototype.getPixelRatio = function (pixelRatio) {\n return 1;\n };\n /**\n * @abstract\n * @return {import(\"../ImageState.js\").default} Image state.\n */\n ImageStyle.prototype.getImageState = function () {\n return abstract();\n };\n /**\n * @abstract\n * @return {import(\"../size.js\").Size} Image size.\n */\n ImageStyle.prototype.getImageSize = function () {\n return abstract();\n };\n /**\n * Get the origin of the symbolizer.\n * @abstract\n * @return {Array<number>} Origin.\n */\n ImageStyle.prototype.getOrigin = function () {\n return abstract();\n };\n /**\n * Get the size of the symbolizer (in pixels).\n * @abstract\n * @return {import(\"../size.js\").Size} Size.\n */\n ImageStyle.prototype.getSize = function () {\n return abstract();\n };\n /**\n * Set the opacity.\n *\n * @param {number} opacity Opacity.\n * @api\n */\n ImageStyle.prototype.setOpacity = function (opacity) {\n this.opacity_ = opacity;\n };\n /**\n * Set whether to rotate the style with the view.\n *\n * @param {boolean} rotateWithView Rotate with map.\n * @api\n */\n ImageStyle.prototype.setRotateWithView = function (rotateWithView) {\n this.rotateWithView_ = rotateWithView;\n };\n /**\n * Set the rotation.\n *\n * @param {number} rotation Rotation.\n * @api\n */\n ImageStyle.prototype.setRotation = function (rotation) {\n this.rotation_ = rotation;\n };\n /**\n * Set the scale.\n *\n * @param {number|import(\"../size.js\").Size} scale Scale.\n * @api\n */\n ImageStyle.prototype.setScale = function (scale) {\n this.scale_ = scale;\n this.scaleArray_ = toSize(scale);\n };\n /**\n * @abstract\n * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n */\n ImageStyle.prototype.listenImageChange = function (listener) {\n abstract();\n };\n /**\n * Load not yet loaded URI.\n * @abstract\n */\n ImageStyle.prototype.load = function () {\n abstract();\n };\n /**\n * @abstract\n * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n */\n ImageStyle.prototype.unlistenImageChange = function (listener) {\n abstract();\n };\n return ImageStyle;\n}());\nexport default ImageStyle;\n//# sourceMappingURL=Image.js.map","/**\n * @module ol/color\n */\nimport { assert } from './asserts.js';\nimport { clamp } from './math.js';\n/**\n * A color represented as a short array [red, green, blue, alpha].\n * red, green, and blue should be integers in the range 0..255 inclusive.\n * alpha should be a float in the range 0..1 inclusive. If no alpha value is\n * given then `1` will be used.\n * @typedef {Array<number>} Color\n * @api\n */\n/**\n * This RegExp matches # followed by 3, 4, 6, or 8 hex digits.\n * @const\n * @type {RegExp}\n * @private\n */\nvar HEX_COLOR_RE_ = /^#([a-f0-9]{3}|[a-f0-9]{4}(?:[a-f0-9]{2}){0,2})$/i;\n/**\n * Regular expression for matching potential named color style strings.\n * @const\n * @type {RegExp}\n * @private\n */\nvar NAMED_COLOR_RE_ = /^([a-z]*)$|^hsla?\\(.*\\)$/i;\n/**\n * Return the color as an rgba string.\n * @param {Color|string} color Color.\n * @return {string} Rgba string.\n * @api\n */\nexport function asString(color) {\n if (typeof color === 'string') {\n return color;\n }\n else {\n return toString(color);\n }\n}\n/**\n * Return named color as an rgba string.\n * @param {string} color Named color.\n * @return {string} Rgb string.\n */\nfunction fromNamed(color) {\n var el = document.createElement('div');\n el.style.color = color;\n if (el.style.color !== '') {\n document.body.appendChild(el);\n var rgb = getComputedStyle(el).color;\n document.body.removeChild(el);\n return rgb;\n }\n else {\n return '';\n }\n}\n/**\n * @param {string} s String.\n * @return {Color} Color.\n */\nexport var fromString = (function () {\n // We maintain a small cache of parsed strings. To provide cheap LRU-like\n // semantics, whenever the cache grows too large we simply delete an\n // arbitrary 25% of the entries.\n /**\n * @const\n * @type {number}\n */\n var MAX_CACHE_SIZE = 1024;\n /**\n * @type {Object<string, Color>}\n */\n var cache = {};\n /**\n * @type {number}\n */\n var cacheSize = 0;\n return (\n /**\n * @param {string} s String.\n * @return {Color} Color.\n */\n function (s) {\n var color;\n if (cache.hasOwnProperty(s)) {\n color = cache[s];\n }\n else {\n if (cacheSize >= MAX_CACHE_SIZE) {\n var i = 0;\n for (var key in cache) {\n if ((i++ & 3) === 0) {\n delete cache[key];\n --cacheSize;\n }\n }\n }\n color = fromStringInternal_(s);\n cache[s] = color;\n ++cacheSize;\n }\n return color;\n });\n})();\n/**\n * Return the color as an array. This function maintains a cache of calculated\n * arrays which means the result should not be modified.\n * @param {Color|string} color Color.\n * @return {Color} Color.\n * @api\n */\nexport function asArray(color) {\n if (Array.isArray(color)) {\n return color;\n }\n else {\n return fromString(color);\n }\n}\n/**\n * @param {string} s String.\n * @private\n * @return {Color} Color.\n */\nfunction fromStringInternal_(s) {\n var r, g, b, a, color;\n if (NAMED_COLOR_RE_.exec(s)) {\n s = fromNamed(s);\n }\n if (HEX_COLOR_RE_.exec(s)) {\n // hex\n var n = s.length - 1; // number of hex digits\n var d = // number of digits per channel\n void 0; // number of digits per channel\n if (n <= 4) {\n d = 1;\n }\n else {\n d = 2;\n }\n var hasAlpha = n === 4 || n === 8;\n r = parseInt(s.substr(1 + 0 * d, d), 16);\n g = parseInt(s.substr(1 + 1 * d, d), 16);\n b = parseInt(s.substr(1 + 2 * d, d), 16);\n if (hasAlpha) {\n a = parseInt(s.substr(1 + 3 * d, d), 16);\n }\n else {\n a = 255;\n }\n if (d == 1) {\n r = (r << 4) + r;\n g = (g << 4) + g;\n b = (b << 4) + b;\n if (hasAlpha) {\n a = (a << 4) + a;\n }\n }\n color = [r, g, b, a / 255];\n }\n else if (s.indexOf('rgba(') == 0) {\n // rgba()\n color = s.slice(5, -1).split(',').map(Number);\n normalize(color);\n }\n else if (s.indexOf('rgb(') == 0) {\n // rgb()\n color = s.slice(4, -1).split(',').map(Number);\n color.push(1);\n normalize(color);\n }\n else {\n assert(false, 14); // Invalid color\n }\n return color;\n}\n/**\n * TODO this function is only used in the test, we probably shouldn't export it\n * @param {Color} color Color.\n * @return {Color} Clamped color.\n */\nexport function normalize(color) {\n color[0] = clamp((color[0] + 0.5) | 0, 0, 255);\n color[1] = clamp((color[1] + 0.5) | 0, 0, 255);\n color[2] = clamp((color[2] + 0.5) | 0, 0, 255);\n color[3] = clamp(color[3], 0, 1);\n return color;\n}\n/**\n * @param {Color} color Color.\n * @return {string} String.\n */\nexport function toString(color) {\n var r = color[0];\n if (r != (r | 0)) {\n r = (r + 0.5) | 0;\n }\n var g = color[1];\n if (g != (g | 0)) {\n g = (g + 0.5) | 0;\n }\n var b = color[2];\n if (b != (b | 0)) {\n b = (b + 0.5) | 0;\n }\n var a = color[3] === undefined ? 1 : color[3];\n return 'rgba(' + r + ',' + g + ',' + b + ',' + a + ')';\n}\n/**\n * @param {string} s String.\n * @return {boolean} Whether the string is actually a valid color\n */\nexport function isStringColor(s) {\n if (NAMED_COLOR_RE_.test(s)) {\n s = fromNamed(s);\n }\n return (HEX_COLOR_RE_.test(s) || s.indexOf('rgba(') === 0 || s.indexOf('rgb(') === 0);\n}\n//# sourceMappingURL=color.js.map","/**\n * @module ol/colorlike\n */\nimport { toString } from './color.js';\n/**\n * A type accepted by CanvasRenderingContext2D.fillStyle\n * or CanvasRenderingContext2D.strokeStyle.\n * Represents a color, pattern, or gradient. The origin for patterns and\n * gradients as fill style is an increment of 512 css pixels from map coordinate\n * `[0, 0]`. For seamless repeat patterns, width and height of the pattern image\n * must be a factor of two (2, 4, 8, ..., 512).\n *\n * @typedef {string|CanvasPattern|CanvasGradient} ColorLike\n * @api\n */\n/**\n * @param {import(\"./color.js\").Color|ColorLike} color Color.\n * @return {ColorLike} The color as an {@link ol/colorlike~ColorLike}.\n * @api\n */\nexport function asColorLike(color) {\n if (Array.isArray(color)) {\n return toString(color);\n }\n else {\n return color;\n }\n}\n//# sourceMappingURL=colorlike.js.map","/**\n * @module ol/render/canvas\n */\nimport BaseObject from '../Object.js';\nimport EventTarget from '../events/Target.js';\nimport { WORKER_OFFSCREEN_CANVAS } from '../has.js';\nimport { clear } from '../obj.js';\nimport { createCanvasContext2D } from '../dom.js';\nimport { getFontParameters } from '../css.js';\n/**\n * @typedef {Object} FillState\n * @property {import(\"../colorlike.js\").ColorLike} fillStyle FillStyle.\n */\n/**\n * @typedef Label\n * @property {number} width Width.\n * @property {number} height Height.\n * @property {Array<string|number>} contextInstructions ContextInstructions.\n */\n/**\n * @typedef {Object} FillStrokeState\n * @property {import(\"../colorlike.js\").ColorLike} [currentFillStyle] Current FillStyle.\n * @property {import(\"../colorlike.js\").ColorLike} [currentStrokeStyle] Current StrokeStyle.\n * @property {CanvasLineCap} [currentLineCap] Current LineCap.\n * @property {Array<number>} currentLineDash Current LineDash.\n * @property {number} [currentLineDashOffset] Current LineDashOffset.\n * @property {CanvasLineJoin} [currentLineJoin] Current LineJoin.\n * @property {number} [currentLineWidth] Current LineWidth.\n * @property {number} [currentMiterLimit] Current MiterLimit.\n * @property {number} [lastStroke] Last stroke.\n * @property {import(\"../colorlike.js\").ColorLike} [fillStyle] FillStyle.\n * @property {import(\"../colorlike.js\").ColorLike} [strokeStyle] StrokeStyle.\n * @property {CanvasLineCap} [lineCap] LineCap.\n * @property {Array<number>} lineDash LineDash.\n * @property {number} [lineDashOffset] LineDashOffset.\n * @property {CanvasLineJoin} [lineJoin] LineJoin.\n * @property {number} [lineWidth] LineWidth.\n * @property {number} [miterLimit] MiterLimit.\n */\n/**\n * @typedef {Object} StrokeState\n * @property {CanvasLineCap} lineCap LineCap.\n * @property {Array<number>} lineDash LineDash.\n * @property {number} lineDashOffset LineDashOffset.\n * @property {CanvasLineJoin} lineJoin LineJoin.\n * @property {number} lineWidth LineWidth.\n * @property {number} miterLimit MiterLimit.\n * @property {import(\"../colorlike.js\").ColorLike} strokeStyle StrokeStyle.\n */\n/**\n * @typedef {Object} TextState\n * @property {string} font Font.\n * @property {string} [textAlign] TextAlign.\n * @property {string} textBaseline TextBaseline.\n * @property {string} [placement] Placement.\n * @property {number} [maxAngle] MaxAngle.\n * @property {boolean} [overflow] Overflow.\n * @property {import(\"../style/Fill.js\").default} [backgroundFill] BackgroundFill.\n * @property {import(\"../style/Stroke.js\").default} [backgroundStroke] BackgroundStroke.\n * @property {import(\"../size.js\").Size} [scale] Scale.\n * @property {Array<number>} [padding] Padding.\n */\n/**\n * @typedef {Object} SerializableInstructions\n * @property {Array<*>} instructions The rendering instructions.\n * @property {Array<*>} hitDetectionInstructions The rendering hit detection instructions.\n * @property {Array<number>} coordinates The array of all coordinates.\n * @property {!Object<string, TextState>} [textStates] The text states (decluttering).\n * @property {!Object<string, FillState>} [fillStates] The fill states (decluttering).\n * @property {!Object<string, StrokeState>} [strokeStates] The stroke states (decluttering).\n */\n/**\n * @typedef {Object<number, import(\"./canvas/Executor.js\").ReplayImageOrLabelArgs>} DeclutterImageWithText\n */\n/**\n * @const\n * @type {string}\n */\nexport var defaultFont = '10px sans-serif';\n/**\n * @const\n * @type {import(\"../colorlike.js\").ColorLike}\n */\nexport var defaultFillStyle = '#000';\n/**\n * @const\n * @type {CanvasLineCap}\n */\nexport var defaultLineCap = 'round';\n/**\n * @const\n * @type {Array<number>}\n */\nexport var defaultLineDash = [];\n/**\n * @const\n * @type {number}\n */\nexport var defaultLineDashOffset = 0;\n/**\n * @const\n * @type {CanvasLineJoin}\n */\nexport var defaultLineJoin = 'round';\n/**\n * @const\n * @type {number}\n */\nexport var defaultMiterLimit = 10;\n/**\n * @const\n * @type {import(\"../colorlike.js\").ColorLike}\n */\nexport var defaultStrokeStyle = '#000';\n/**\n * @const\n * @type {string}\n */\nexport var defaultTextAlign = 'center';\n/**\n * @const\n * @type {string}\n */\nexport var defaultTextBaseline = 'middle';\n/**\n * @const\n * @type {Array<number>}\n */\nexport var defaultPadding = [0, 0, 0, 0];\n/**\n * @const\n * @type {number}\n */\nexport var defaultLineWidth = 1;\n/**\n * @type {BaseObject}\n */\nexport var checkedFonts = new BaseObject();\n/**\n * The label cache for text rendering. To change the default cache size of 2048\n * entries, use {@link module:ol/structs/LRUCache~LRUCache#setSize cache.setSize()}.\n * Deprecated - there is no label cache any more.\n * @type {?}\n * @api\n * @deprecated\n */\nexport var labelCache = new EventTarget();\nlabelCache.setSize = function () {\n console.warn('labelCache is deprecated.'); //eslint-disable-line\n};\n/**\n * @type {CanvasRenderingContext2D}\n */\nvar measureContext = null;\n/**\n * @type {string}\n */\nvar measureFont;\n/**\n * @type {!Object<string, number>}\n */\nexport var textHeights = {};\n/**\n * Clears the label cache when a font becomes available.\n * @param {string} fontSpec CSS font spec.\n */\nexport var registerFont = (function () {\n var retries = 100;\n var size = '32px ';\n var referenceFonts = ['monospace', 'serif'];\n var len = referenceFonts.length;\n var text = 'wmytzilWMYTZIL@#/&?$%10\\uF013';\n var interval, referenceWidth;\n /**\n * @param {string} fontStyle Css font-style\n * @param {string} fontWeight Css font-weight\n * @param {*} fontFamily Css font-family\n * @return {boolean} Font with style and weight is available\n */\n function isAvailable(fontStyle, fontWeight, fontFamily) {\n var available = true;\n for (var i = 0; i < len; ++i) {\n var referenceFont = referenceFonts[i];\n referenceWidth = measureTextWidth(fontStyle + ' ' + fontWeight + ' ' + size + referenceFont, text);\n if (fontFamily != referenceFont) {\n var width = measureTextWidth(fontStyle +\n ' ' +\n fontWeight +\n ' ' +\n size +\n fontFamily +\n ',' +\n referenceFont, text);\n // If width and referenceWidth are the same, then the fallback was used\n // instead of the font we wanted, so the font is not available.\n available = available && width != referenceWidth;\n }\n }\n if (available) {\n return true;\n }\n return false;\n }\n function check() {\n var done = true;\n var fonts = checkedFonts.getKeys();\n for (var i = 0, ii = fonts.length; i < ii; ++i) {\n var font = fonts[i];\n if (checkedFonts.get(font) < retries) {\n if (isAvailable.apply(this, font.split('\\n'))) {\n clear(textHeights);\n // Make sure that loaded fonts are picked up by Safari\n measureContext = null;\n measureFont = undefined;\n checkedFonts.set(font, retries);\n }\n else {\n checkedFonts.set(font, checkedFonts.get(font) + 1, true);\n done = false;\n }\n }\n }\n if (done) {\n clearInterval(interval);\n interval = undefined;\n }\n }\n return function (fontSpec) {\n var font = getFontParameters(fontSpec);\n if (!font) {\n return;\n }\n var families = font.families;\n for (var i = 0, ii = families.length; i < ii; ++i) {\n var family = families[i];\n var key = font.style + '\\n' + font.weight + '\\n' + family;\n if (checkedFonts.get(key) === undefined) {\n checkedFonts.set(key, retries, true);\n if (!isAvailable(font.style, font.weight, family)) {\n checkedFonts.set(key, 0, true);\n if (interval === undefined) {\n interval = setInterval(check, 32);\n }\n }\n }\n }\n };\n})();\n/**\n * @param {string} font Font to use for measuring.\n * @return {import(\"../size.js\").Size} Measurement.\n */\nexport var measureTextHeight = (function () {\n /**\n * @type {HTMLDivElement}\n */\n var measureElement;\n return function (fontSpec) {\n var height = textHeights[fontSpec];\n if (height == undefined) {\n if (WORKER_OFFSCREEN_CANVAS) {\n var font = getFontParameters(fontSpec);\n var metrics = measureText(fontSpec, 'Žg');\n var lineHeight = isNaN(Number(font.lineHeight))\n ? 1.2\n : Number(font.lineHeight);\n height =\n lineHeight *\n (metrics.actualBoundingBoxAscent + metrics.actualBoundingBoxDescent);\n }\n else {\n if (!measureElement) {\n measureElement = document.createElement('div');\n measureElement.innerHTML = 'M';\n measureElement.style.minHeight = '0';\n measureElement.style.maxHeight = 'none';\n measureElement.style.height = 'auto';\n measureElement.style.padding = '0';\n measureElement.style.border = 'none';\n measureElement.style.position = 'absolute';\n measureElement.style.display = 'block';\n measureElement.style.left = '-99999px';\n }\n measureElement.style.font = fontSpec;\n document.body.appendChild(measureElement);\n height = measureElement.offsetHeight;\n document.body.removeChild(measureElement);\n }\n textHeights[fontSpec] = height;\n }\n return height;\n };\n})();\n/**\n * @param {string} font Font.\n * @param {string} text Text.\n * @return {TextMetrics} Text metrics.\n */\nfunction measureText(font, text) {\n if (!measureContext) {\n measureContext = createCanvasContext2D(1, 1);\n }\n if (font != measureFont) {\n measureContext.font = font;\n measureFont = measureContext.font;\n }\n return measureContext.measureText(text);\n}\n/**\n * @param {string} font Font.\n * @param {string} text Text.\n * @return {number} Width.\n */\nexport function measureTextWidth(font, text) {\n return measureText(font, text).width;\n}\n/**\n * Measure text width using a cache.\n * @param {string} font The font.\n * @param {string} text The text to measure.\n * @param {Object<string, number>} cache A lookup of cached widths by text.\n * @return {number} The text width.\n */\nexport function measureAndCacheTextWidth(font, text, cache) {\n if (text in cache) {\n return cache[text];\n }\n var width = measureTextWidth(font, text);\n cache[text] = width;\n return width;\n}\n/**\n * @param {string} font Font to use for measuring.\n * @param {Array<string>} lines Lines to measure.\n * @param {Array<number>} widths Array will be populated with the widths of\n * each line.\n * @return {number} Width of the whole text.\n */\nexport function measureTextWidths(font, lines, widths) {\n var numLines = lines.length;\n var width = 0;\n for (var i = 0; i < numLines; ++i) {\n var currentWidth = measureTextWidth(font, lines[i]);\n width = Math.max(width, currentWidth);\n widths.push(currentWidth);\n }\n return width;\n}\n/**\n * @param {CanvasRenderingContext2D} context Context.\n * @param {number} rotation Rotation.\n * @param {number} offsetX X offset.\n * @param {number} offsetY Y offset.\n */\nexport function rotateAtOffset(context, rotation, offsetX, offsetY) {\n if (rotation !== 0) {\n context.translate(offsetX, offsetY);\n context.rotate(rotation);\n context.translate(-offsetX, -offsetY);\n }\n}\n/**\n * @param {CanvasRenderingContext2D} context Context.\n * @param {import(\"../transform.js\").Transform|null} transform Transform.\n * @param {number} opacity Opacity.\n * @param {Label|HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} labelOrImage Label.\n * @param {number} originX Origin X.\n * @param {number} originY Origin Y.\n * @param {number} w Width.\n * @param {number} h Height.\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../size.js\").Size} scale Scale.\n */\nexport function drawImageOrLabel(context, transform, opacity, labelOrImage, originX, originY, w, h, x, y, scale) {\n context.save();\n if (opacity !== 1) {\n context.globalAlpha *= opacity;\n }\n if (transform) {\n context.setTransform.apply(context, transform);\n }\n if ( /** @type {*} */(labelOrImage).contextInstructions) {\n // label\n context.translate(x, y);\n context.scale(scale[0], scale[1]);\n executeLabelInstructions(/** @type {Label} */ (labelOrImage), context);\n }\n else if (scale[0] < 0 || scale[1] < 0) {\n // flipped image\n context.translate(x, y);\n context.scale(scale[0], scale[1]);\n context.drawImage(\n /** @type {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} */ (labelOrImage), originX, originY, w, h, 0, 0, w, h);\n }\n else {\n // if image not flipped translate and scale can be avoided\n context.drawImage(\n /** @type {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} */ (labelOrImage), originX, originY, w, h, x, y, w * scale[0], h * scale[1]);\n }\n context.restore();\n}\n/**\n * @param {Label} label Label.\n * @param {CanvasRenderingContext2D} context Context.\n */\nfunction executeLabelInstructions(label, context) {\n var contextInstructions = label.contextInstructions;\n for (var i = 0, ii = contextInstructions.length; i < ii; i += 2) {\n if (Array.isArray(contextInstructions[i + 1])) {\n context[contextInstructions[i]].apply(context, contextInstructions[i + 1]);\n }\n else {\n context[contextInstructions[i]] = contextInstructions[i + 1];\n }\n }\n}\n//# sourceMappingURL=canvas.js.map","/**\n * @module ol/style/RegularShape\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport ImageState from '../ImageState.js';\nimport ImageStyle from './Image.js';\nimport { asArray } from '../color.js';\nimport { asColorLike } from '../colorlike.js';\nimport { createCanvasContext2D } from '../dom.js';\nimport { defaultFillStyle, defaultLineJoin, defaultLineWidth, defaultMiterLimit, defaultStrokeStyle, } from '../render/canvas.js';\n/**\n * Specify radius for regular polygons, or radius1 and radius2 for stars.\n * @typedef {Object} Options\n * @property {import(\"./Fill.js\").default} [fill] Fill style.\n * @property {number} points Number of points for stars and regular polygons. In case of a polygon, the number of points\n * is the number of sides.\n * @property {number} [radius] Radius of a regular polygon.\n * @property {number} [radius1] First radius of a star. Ignored if radius is set.\n * @property {number} [radius2] Second radius of a star.\n * @property {number} [angle=0] Shape's angle in radians. A value of 0 will have one of the shape's point facing up.\n * @property {Array<number>} [displacement=[0,0]] Displacement of the shape\n * @property {import(\"./Stroke.js\").default} [stroke] Stroke style.\n * @property {number} [rotation=0] Rotation in radians (positive rotation clockwise).\n * @property {boolean} [rotateWithView=false] Whether to rotate the shape with the view.\n * @property {number|import(\"../size.js\").Size} [scale=1] Scale. Unless two dimensional scaling is required a better\n * result may be obtained with appropriate settings for `radius`, `radius1` and `radius2`.\n */\n/**\n * @typedef {Object} RenderOptions\n * @property {import(\"../colorlike.js\").ColorLike} [strokeStyle] StrokeStyle.\n * @property {number} strokeWidth StrokeWidth.\n * @property {number} size Size.\n * @property {Array<number>} lineDash LineDash.\n * @property {number} lineDashOffset LineDashOffset.\n * @property {CanvasLineJoin} lineJoin LineJoin.\n * @property {number} miterLimit MiterLimit.\n */\n/**\n * @classdesc\n * Set regular shape style for vector features. The resulting shape will be\n * a regular polygon when `radius` is provided, or a star when `radius1` and\n * `radius2` are provided.\n * @api\n */\nvar RegularShape = /** @class */ (function (_super) {\n __extends(RegularShape, _super);\n /**\n * @param {Options} options Options.\n */\n function RegularShape(options) {\n var _this = this;\n /**\n * @type {boolean}\n */\n var rotateWithView = options.rotateWithView !== undefined ? options.rotateWithView : false;\n _this = _super.call(this, {\n opacity: 1,\n rotateWithView: rotateWithView,\n rotation: options.rotation !== undefined ? options.rotation : 0,\n scale: options.scale !== undefined ? options.scale : 1,\n displacement: options.displacement !== undefined ? options.displacement : [0, 0],\n }) || this;\n /**\n * @private\n * @type {Object<number, HTMLCanvasElement>}\n */\n _this.canvas_ = undefined;\n /**\n * @private\n * @type {HTMLCanvasElement}\n */\n _this.hitDetectionCanvas_ = null;\n /**\n * @private\n * @type {import(\"./Fill.js\").default}\n */\n _this.fill_ = options.fill !== undefined ? options.fill : null;\n /**\n * @private\n * @type {Array<number>}\n */\n _this.origin_ = [0, 0];\n /**\n * @private\n * @type {number}\n */\n _this.points_ = options.points;\n /**\n * @protected\n * @type {number}\n */\n _this.radius_ =\n options.radius !== undefined ? options.radius : options.radius1;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.radius2_ = options.radius2;\n /**\n * @private\n * @type {number}\n */\n _this.angle_ = options.angle !== undefined ? options.angle : 0;\n /**\n * @private\n * @type {import(\"./Stroke.js\").default}\n */\n _this.stroke_ = options.stroke !== undefined ? options.stroke : null;\n /**\n * @private\n * @type {Array<number>}\n */\n _this.anchor_ = null;\n /**\n * @private\n * @type {import(\"../size.js\").Size}\n */\n _this.size_ = null;\n /**\n * @private\n * @type {RenderOptions}\n */\n _this.renderOptions_ = null;\n _this.render();\n return _this;\n }\n /**\n * Clones the style.\n * @return {RegularShape} The cloned style.\n * @api\n */\n RegularShape.prototype.clone = function () {\n var scale = this.getScale();\n var style = new RegularShape({\n fill: this.getFill() ? this.getFill().clone() : undefined,\n points: this.getPoints(),\n radius: this.getRadius(),\n radius2: this.getRadius2(),\n angle: this.getAngle(),\n stroke: this.getStroke() ? this.getStroke().clone() : undefined,\n rotation: this.getRotation(),\n rotateWithView: this.getRotateWithView(),\n scale: Array.isArray(scale) ? scale.slice() : scale,\n displacement: this.getDisplacement().slice(),\n });\n style.setOpacity(this.getOpacity());\n return style;\n };\n /**\n * Get the anchor point in pixels. The anchor determines the center point for the\n * symbolizer.\n * @return {Array<number>} Anchor.\n * @api\n */\n RegularShape.prototype.getAnchor = function () {\n return this.anchor_;\n };\n /**\n * Get the angle used in generating the shape.\n * @return {number} Shape's rotation in radians.\n * @api\n */\n RegularShape.prototype.getAngle = function () {\n return this.angle_;\n };\n /**\n * Get the fill style for the shape.\n * @return {import(\"./Fill.js\").default} Fill style.\n * @api\n */\n RegularShape.prototype.getFill = function () {\n return this.fill_;\n };\n /**\n * @return {HTMLCanvasElement} Image element.\n */\n RegularShape.prototype.getHitDetectionImage = function () {\n if (!this.hitDetectionCanvas_) {\n this.createHitDetectionCanvas_(this.renderOptions_);\n }\n return this.hitDetectionCanvas_;\n };\n /**\n * Get the image icon.\n * @param {number} pixelRatio Pixel ratio.\n * @return {HTMLCanvasElement} Image or Canvas element.\n * @api\n */\n RegularShape.prototype.getImage = function (pixelRatio) {\n var image = this.canvas_[pixelRatio];\n if (!image) {\n var renderOptions = this.renderOptions_;\n var context = createCanvasContext2D(renderOptions.size * pixelRatio, renderOptions.size * pixelRatio);\n this.draw_(renderOptions, context, pixelRatio);\n image = context.canvas;\n this.canvas_[pixelRatio] = image;\n }\n return image;\n };\n /**\n * Get the image pixel ratio.\n * @param {number} pixelRatio Pixel ratio.\n * @return {number} Pixel ratio.\n */\n RegularShape.prototype.getPixelRatio = function (pixelRatio) {\n return pixelRatio;\n };\n /**\n * @return {import(\"../size.js\").Size} Image size.\n */\n RegularShape.prototype.getImageSize = function () {\n return this.size_;\n };\n /**\n * @return {import(\"../ImageState.js\").default} Image state.\n */\n RegularShape.prototype.getImageState = function () {\n return ImageState.LOADED;\n };\n /**\n * Get the origin of the symbolizer.\n * @return {Array<number>} Origin.\n * @api\n */\n RegularShape.prototype.getOrigin = function () {\n return this.origin_;\n };\n /**\n * Get the number of points for generating the shape.\n * @return {number} Number of points for stars and regular polygons.\n * @api\n */\n RegularShape.prototype.getPoints = function () {\n return this.points_;\n };\n /**\n * Get the (primary) radius for the shape.\n * @return {number} Radius.\n * @api\n */\n RegularShape.prototype.getRadius = function () {\n return this.radius_;\n };\n /**\n * Get the secondary radius for the shape.\n * @return {number|undefined} Radius2.\n * @api\n */\n RegularShape.prototype.getRadius2 = function () {\n return this.radius2_;\n };\n /**\n * Get the size of the symbolizer (in pixels).\n * @return {import(\"../size.js\").Size} Size.\n * @api\n */\n RegularShape.prototype.getSize = function () {\n return this.size_;\n };\n /**\n * Get the stroke style for the shape.\n * @return {import(\"./Stroke.js\").default} Stroke style.\n * @api\n */\n RegularShape.prototype.getStroke = function () {\n return this.stroke_;\n };\n /**\n * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n */\n RegularShape.prototype.listenImageChange = function (listener) { };\n /**\n * Load not yet loaded URI.\n */\n RegularShape.prototype.load = function () { };\n /**\n * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n */\n RegularShape.prototype.unlistenImageChange = function (listener) { };\n /**\n * Calculate additional canvas size needed for the miter.\n * @param {string} lineJoin Line join\n * @param {number} strokeWidth Stroke width\n * @param {number} miterLimit Miter limit\n * @return {number} Additional canvas size needed\n * @private\n */\n RegularShape.prototype.calculateLineJoinSize_ = function (lineJoin, strokeWidth, miterLimit) {\n if (strokeWidth === 0 ||\n this.points_ === Infinity ||\n (lineJoin !== 'bevel' && lineJoin !== 'miter')) {\n return strokeWidth;\n }\n // m | ^\n // i | |\\ .\n // t >| #\\\n // e | |\\ \\ .\n // r \\s\\\n // | \\t\\ . .\n // \\r\\ . .\n // | \\o\\ . . . . .\n // e \\k\\ . . . .\n // | \\e\\ . . . . .\n // d \\ \\ . . . .\n // | _ _a_ _\\# . . .\n // r1 / ` . .\n // | . .\n // b / . .\n // | . .\n // / r2 . .\n // | . .\n // / . .\n // |α . .\n // / . .\n // ° center\n var r1 = this.radius_;\n var r2 = this.radius2_ === undefined ? r1 : this.radius2_;\n if (r1 < r2) {\n var tmp = r1;\n r1 = r2;\n r2 = tmp;\n }\n var points = this.radius2_ === undefined ? this.points_ : this.points_ * 2;\n var alpha = (2 * Math.PI) / points;\n var a = r2 * Math.sin(alpha);\n var b = Math.sqrt(r2 * r2 - a * a);\n var d = r1 - b;\n var e = Math.sqrt(a * a + d * d);\n var miterRatio = e / a;\n if (lineJoin === 'miter' && miterRatio <= miterLimit) {\n return miterRatio * strokeWidth;\n }\n // Calculate the distnce from center to the stroke corner where\n // it was cut short because of the miter limit.\n // l\n // ----+---- <= distance from center to here is maxr\n // /####|k ##\\\n // /#####^#####\\\n // /#### /+\\# s #\\\n // /### h/+++\\# t #\\\n // /### t/+++++\\# r #\\\n // /### a/+++++++\\# o #\\\n // /### p/++ fill +\\# k #\\\n ///#### /+++++^+++++\\# e #\\\n //#####/+++++/+\\+++++\\#####\\\n var k = strokeWidth / 2 / miterRatio;\n var l = (strokeWidth / 2) * (d / e);\n var maxr = Math.sqrt((r1 + k) * (r1 + k) + l * l);\n var bevelAdd = maxr - r1;\n if (this.radius2_ === undefined || lineJoin === 'bevel') {\n return bevelAdd * 2;\n }\n // If outer miter is over the miter limit the inner miter may reach through the\n // center and be longer than the bevel, same calculation as above but swap r1 / r2.\n var aa = r1 * Math.sin(alpha);\n var bb = Math.sqrt(r1 * r1 - aa * aa);\n var dd = r2 - bb;\n var ee = Math.sqrt(aa * aa + dd * dd);\n var innerMiterRatio = ee / aa;\n if (innerMiterRatio <= miterLimit) {\n var innerLength = (innerMiterRatio * strokeWidth) / 2 - r2 - r1;\n return 2 * Math.max(bevelAdd, innerLength);\n }\n return bevelAdd * 2;\n };\n /**\n * @return {RenderOptions} The render options\n * @protected\n */\n RegularShape.prototype.createRenderOptions = function () {\n var lineJoin = defaultLineJoin;\n var miterLimit = 0;\n var lineDash = null;\n var lineDashOffset = 0;\n var strokeStyle;\n var strokeWidth = 0;\n if (this.stroke_) {\n strokeStyle = this.stroke_.getColor();\n if (strokeStyle === null) {\n strokeStyle = defaultStrokeStyle;\n }\n strokeStyle = asColorLike(strokeStyle);\n strokeWidth = this.stroke_.getWidth();\n if (strokeWidth === undefined) {\n strokeWidth = defaultLineWidth;\n }\n lineDash = this.stroke_.getLineDash();\n lineDashOffset = this.stroke_.getLineDashOffset();\n lineJoin = this.stroke_.getLineJoin();\n if (lineJoin === undefined) {\n lineJoin = defaultLineJoin;\n }\n miterLimit = this.stroke_.getMiterLimit();\n if (miterLimit === undefined) {\n miterLimit = defaultMiterLimit;\n }\n }\n var add = this.calculateLineJoinSize_(lineJoin, strokeWidth, miterLimit);\n var maxRadius = Math.max(this.radius_, this.radius2_ || 0);\n var size = Math.ceil(2 * maxRadius + add);\n return {\n strokeStyle: strokeStyle,\n strokeWidth: strokeWidth,\n size: size,\n lineDash: lineDash,\n lineDashOffset: lineDashOffset,\n lineJoin: lineJoin,\n miterLimit: miterLimit,\n };\n };\n /**\n * @protected\n */\n RegularShape.prototype.render = function () {\n this.renderOptions_ = this.createRenderOptions();\n var size = this.renderOptions_.size;\n var displacement = this.getDisplacement();\n this.canvas_ = {};\n this.anchor_ = [size / 2 - displacement[0], size / 2 + displacement[1]];\n this.size_ = [size, size];\n };\n /**\n * @private\n * @param {RenderOptions} renderOptions Render options.\n * @param {CanvasRenderingContext2D} context The rendering context.\n * @param {number} pixelRatio The pixel ratio.\n */\n RegularShape.prototype.draw_ = function (renderOptions, context, pixelRatio) {\n context.scale(pixelRatio, pixelRatio);\n // set origin to canvas center\n context.translate(renderOptions.size / 2, renderOptions.size / 2);\n this.createPath_(context);\n if (this.fill_) {\n var color = this.fill_.getColor();\n if (color === null) {\n color = defaultFillStyle;\n }\n context.fillStyle = asColorLike(color);\n context.fill();\n }\n if (this.stroke_) {\n context.strokeStyle = renderOptions.strokeStyle;\n context.lineWidth = renderOptions.strokeWidth;\n if (context.setLineDash && renderOptions.lineDash) {\n context.setLineDash(renderOptions.lineDash);\n context.lineDashOffset = renderOptions.lineDashOffset;\n }\n context.lineJoin = renderOptions.lineJoin;\n context.miterLimit = renderOptions.miterLimit;\n context.stroke();\n }\n };\n /**\n * @private\n * @param {RenderOptions} renderOptions Render options.\n */\n RegularShape.prototype.createHitDetectionCanvas_ = function (renderOptions) {\n if (this.fill_) {\n var color = this.fill_.getColor();\n // determine if fill is transparent (or pattern or gradient)\n var opacity = 0;\n if (typeof color === 'string') {\n color = asArray(color);\n }\n if (color === null) {\n opacity = 1;\n }\n else if (Array.isArray(color)) {\n opacity = color.length === 4 ? color[3] : 1;\n }\n if (opacity === 0) {\n // if a transparent fill style is set, create an extra hit-detection image\n // with a default fill style\n var context = createCanvasContext2D(renderOptions.size, renderOptions.size);\n this.hitDetectionCanvas_ = context.canvas;\n this.drawHitDetectionCanvas_(renderOptions, context);\n }\n }\n if (!this.hitDetectionCanvas_) {\n this.hitDetectionCanvas_ = this.getImage(1);\n }\n };\n /**\n * @private\n * @param {CanvasRenderingContext2D} context The context to draw in.\n */\n RegularShape.prototype.createPath_ = function (context) {\n var points = this.points_;\n var radius = this.radius_;\n if (points === Infinity) {\n context.arc(0, 0, radius, 0, 2 * Math.PI);\n }\n else {\n var radius2 = this.radius2_ === undefined ? radius : this.radius2_;\n if (this.radius2_ !== undefined) {\n points *= 2;\n }\n var startAngle = this.angle_ - Math.PI / 2;\n var step = (2 * Math.PI) / points;\n for (var i = 0; i < points; i++) {\n var angle0 = startAngle + i * step;\n var radiusC = i % 2 === 0 ? radius : radius2;\n context.lineTo(radiusC * Math.cos(angle0), radiusC * Math.sin(angle0));\n }\n context.closePath();\n }\n };\n /**\n * @private\n * @param {RenderOptions} renderOptions Render options.\n * @param {CanvasRenderingContext2D} context The context.\n */\n RegularShape.prototype.drawHitDetectionCanvas_ = function (renderOptions, context) {\n // set origin to canvas center\n context.translate(renderOptions.size / 2, renderOptions.size / 2);\n this.createPath_(context);\n context.fillStyle = defaultFillStyle;\n context.fill();\n if (this.stroke_) {\n context.strokeStyle = renderOptions.strokeStyle;\n context.lineWidth = renderOptions.strokeWidth;\n if (renderOptions.lineDash) {\n context.setLineDash(renderOptions.lineDash);\n context.lineDashOffset = renderOptions.lineDashOffset;\n }\n context.lineJoin = renderOptions.lineJoin;\n context.miterLimit = renderOptions.miterLimit;\n context.stroke();\n }\n };\n return RegularShape;\n}(ImageStyle));\nexport default RegularShape;\n//# sourceMappingURL=RegularShape.js.map","/**\n * @module ol/style/Circle\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport RegularShape from './RegularShape.js';\n/**\n * @typedef {Object} Options\n * @property {import(\"./Fill.js\").default} [fill] Fill style.\n * @property {number} radius Circle radius.\n * @property {import(\"./Stroke.js\").default} [stroke] Stroke style.\n * @property {Array<number>} [displacement=[0,0]] displacement\n * @property {number|import(\"../size.js\").Size} [scale=1] Scale. A two dimensional scale will produce an ellipse.\n * Unless two dimensional scaling is required a better result may be obtained with an appropriate setting for `radius`.\n * @property {number} [rotation=0] Rotation in radians\n * (positive rotation clockwise, meaningful only when used in conjunction with a two dimensional scale).\n * @property {boolean} [rotateWithView=false] Whether to rotate the shape with the view\n * (meaningful only when used in conjunction with a two dimensional scale).\n */\n/**\n * @classdesc\n * Set circle style for vector features.\n * @api\n */\nvar CircleStyle = /** @class */ (function (_super) {\n __extends(CircleStyle, _super);\n /**\n * @param {Options} [opt_options] Options.\n */\n function CircleStyle(opt_options) {\n var _this = this;\n var options = opt_options ? opt_options : {};\n _this = _super.call(this, {\n points: Infinity,\n fill: options.fill,\n radius: options.radius,\n stroke: options.stroke,\n scale: options.scale !== undefined ? options.scale : 1,\n rotation: options.rotation !== undefined ? options.rotation : 0,\n rotateWithView: options.rotateWithView !== undefined ? options.rotateWithView : false,\n displacement: options.displacement !== undefined ? options.displacement : [0, 0],\n }) || this;\n return _this;\n }\n /**\n * Clones the style.\n * @return {CircleStyle} The cloned style.\n * @api\n */\n CircleStyle.prototype.clone = function () {\n var scale = this.getScale();\n var style = new CircleStyle({\n fill: this.getFill() ? this.getFill().clone() : undefined,\n stroke: this.getStroke() ? this.getStroke().clone() : undefined,\n radius: this.getRadius(),\n scale: Array.isArray(scale) ? scale.slice() : scale,\n rotation: this.getRotation(),\n rotateWithView: this.getRotateWithView(),\n displacement: this.getDisplacement().slice(),\n });\n style.setOpacity(this.getOpacity());\n return style;\n };\n /**\n * Set the circle radius.\n *\n * @param {number} radius Circle radius.\n * @api\n */\n CircleStyle.prototype.setRadius = function (radius) {\n this.radius_ = radius;\n this.render();\n };\n return CircleStyle;\n}(RegularShape));\nexport default CircleStyle;\n//# sourceMappingURL=Circle.js.map","/**\n * @module ol/style/Fill\n */\n/**\n * @typedef {Object} Options\n * @property {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike} [color=null] A color, gradient or pattern.\n * See {@link module:ol/color~Color} and {@link module:ol/colorlike~ColorLike} for possible formats.\n * Default null; if null, the Canvas/renderer default black will be used.\n */\n/**\n * @classdesc\n * Set fill style for vector features.\n * @api\n */\nvar Fill = /** @class */ (function () {\n /**\n * @param {Options} [opt_options] Options.\n */\n function Fill(opt_options) {\n var options = opt_options || {};\n /**\n * @private\n * @type {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike}\n */\n this.color_ = options.color !== undefined ? options.color : null;\n }\n /**\n * Clones the style. The color is not cloned if it is an {@link module:ol/colorlike~ColorLike}.\n * @return {Fill} The cloned style.\n * @api\n */\n Fill.prototype.clone = function () {\n var color = this.getColor();\n return new Fill({\n color: Array.isArray(color) ? color.slice() : color || undefined,\n });\n };\n /**\n * Get the fill color.\n * @return {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike} Color.\n * @api\n */\n Fill.prototype.getColor = function () {\n return this.color_;\n };\n /**\n * Set the color.\n *\n * @param {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike} color Color.\n * @api\n */\n Fill.prototype.setColor = function (color) {\n this.color_ = color;\n };\n return Fill;\n}());\nexport default Fill;\n//# sourceMappingURL=Fill.js.map","/**\n * @module ol/style/Stroke\n */\n/**\n * @typedef {Object} Options\n * @property {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike} [color] A color, gradient or pattern.\n * See {@link module:ol/color~Color} and {@link module:ol/colorlike~ColorLike} for possible formats.\n * Default null; if null, the Canvas/renderer default black will be used.\n * @property {CanvasLineCap} [lineCap='round'] Line cap style: `butt`, `round`, or `square`.\n * @property {CanvasLineJoin} [lineJoin='round'] Line join style: `bevel`, `round`, or `miter`.\n * @property {Array<number>} [lineDash] Line dash pattern. Default is `null` (no dash).\n * Please note that Internet Explorer 10 and lower do not support the `setLineDash` method on\n * the `CanvasRenderingContext2D` and therefore this option will have no visual effect in these browsers.\n * @property {number} [lineDashOffset=0] Line dash offset.\n * @property {number} [miterLimit=10] Miter limit.\n * @property {number} [width] Width.\n */\n/**\n * @classdesc\n * Set stroke style for vector features.\n * Note that the defaults given are the Canvas defaults, which will be used if\n * option is not defined. The `get` functions return whatever was entered in\n * the options; they will not return the default.\n * @api\n */\nvar Stroke = /** @class */ (function () {\n /**\n * @param {Options} [opt_options] Options.\n */\n function Stroke(opt_options) {\n var options = opt_options || {};\n /**\n * @private\n * @type {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike}\n */\n this.color_ = options.color !== undefined ? options.color : null;\n /**\n * @private\n * @type {CanvasLineCap|undefined}\n */\n this.lineCap_ = options.lineCap;\n /**\n * @private\n * @type {Array<number>}\n */\n this.lineDash_ = options.lineDash !== undefined ? options.lineDash : null;\n /**\n * @private\n * @type {number|undefined}\n */\n this.lineDashOffset_ = options.lineDashOffset;\n /**\n * @private\n * @type {CanvasLineJoin|undefined}\n */\n this.lineJoin_ = options.lineJoin;\n /**\n * @private\n * @type {number|undefined}\n */\n this.miterLimit_ = options.miterLimit;\n /**\n * @private\n * @type {number|undefined}\n */\n this.width_ = options.width;\n }\n /**\n * Clones the style.\n * @return {Stroke} The cloned style.\n * @api\n */\n Stroke.prototype.clone = function () {\n var color = this.getColor();\n return new Stroke({\n color: Array.isArray(color) ? color.slice() : color || undefined,\n lineCap: this.getLineCap(),\n lineDash: this.getLineDash() ? this.getLineDash().slice() : undefined,\n lineDashOffset: this.getLineDashOffset(),\n lineJoin: this.getLineJoin(),\n miterLimit: this.getMiterLimit(),\n width: this.getWidth(),\n });\n };\n /**\n * Get the stroke color.\n * @return {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike} Color.\n * @api\n */\n Stroke.prototype.getColor = function () {\n return this.color_;\n };\n /**\n * Get the line cap type for the stroke.\n * @return {CanvasLineCap|undefined} Line cap.\n * @api\n */\n Stroke.prototype.getLineCap = function () {\n return this.lineCap_;\n };\n /**\n * Get the line dash style for the stroke.\n * @return {Array<number>} Line dash.\n * @api\n */\n Stroke.prototype.getLineDash = function () {\n return this.lineDash_;\n };\n /**\n * Get the line dash offset for the stroke.\n * @return {number|undefined} Line dash offset.\n * @api\n */\n Stroke.prototype.getLineDashOffset = function () {\n return this.lineDashOffset_;\n };\n /**\n * Get the line join type for the stroke.\n * @return {CanvasLineJoin|undefined} Line join.\n * @api\n */\n Stroke.prototype.getLineJoin = function () {\n return this.lineJoin_;\n };\n /**\n * Get the miter limit for the stroke.\n * @return {number|undefined} Miter limit.\n * @api\n */\n Stroke.prototype.getMiterLimit = function () {\n return this.miterLimit_;\n };\n /**\n * Get the stroke width.\n * @return {number|undefined} Width.\n * @api\n */\n Stroke.prototype.getWidth = function () {\n return this.width_;\n };\n /**\n * Set the color.\n *\n * @param {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike} color Color.\n * @api\n */\n Stroke.prototype.setColor = function (color) {\n this.color_ = color;\n };\n /**\n * Set the line cap.\n *\n * @param {CanvasLineCap|undefined} lineCap Line cap.\n * @api\n */\n Stroke.prototype.setLineCap = function (lineCap) {\n this.lineCap_ = lineCap;\n };\n /**\n * Set the line dash.\n *\n * Please note that Internet Explorer 10 and lower [do not support][mdn] the\n * `setLineDash` method on the `CanvasRenderingContext2D` and therefore this\n * property will have no visual effect in these browsers.\n *\n * [mdn]: https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/setLineDash#Browser_compatibility\n *\n * @param {Array<number>} lineDash Line dash.\n * @api\n */\n Stroke.prototype.setLineDash = function (lineDash) {\n this.lineDash_ = lineDash;\n };\n /**\n * Set the line dash offset.\n *\n * @param {number|undefined} lineDashOffset Line dash offset.\n * @api\n */\n Stroke.prototype.setLineDashOffset = function (lineDashOffset) {\n this.lineDashOffset_ = lineDashOffset;\n };\n /**\n * Set the line join.\n *\n * @param {CanvasLineJoin|undefined} lineJoin Line join.\n * @api\n */\n Stroke.prototype.setLineJoin = function (lineJoin) {\n this.lineJoin_ = lineJoin;\n };\n /**\n * Set the miter limit.\n *\n * @param {number|undefined} miterLimit Miter limit.\n * @api\n */\n Stroke.prototype.setMiterLimit = function (miterLimit) {\n this.miterLimit_ = miterLimit;\n };\n /**\n * Set the width.\n *\n * @param {number|undefined} width Width.\n * @api\n */\n Stroke.prototype.setWidth = function (width) {\n this.width_ = width;\n };\n return Stroke;\n}());\nexport default Stroke;\n//# sourceMappingURL=Stroke.js.map","/**\n * @module ol/style/Style\n */\nimport CircleStyle from './Circle.js';\nimport Fill from './Fill.js';\nimport GeometryType from '../geom/GeometryType.js';\nimport Stroke from './Stroke.js';\nimport { assert } from '../asserts.js';\n/**\n * A function that takes an {@link module:ol/Feature} and a `{number}`\n * representing the view's resolution. The function should return a\n * {@link module:ol/style/Style} or an array of them. This way e.g. a\n * vector layer can be styled. If the function returns `undefined`, the\n * feature will not be rendered.\n *\n * @typedef {function(import(\"../Feature.js\").FeatureLike, number):(Style|Array<Style>|void)} StyleFunction\n */\n/**\n * A {@link Style}, an array of {@link Style}, or a {@link StyleFunction}.\n * @typedef {Style|Array<Style>|StyleFunction} StyleLike\n */\n/**\n * A function that takes an {@link module:ol/Feature} as argument and returns an\n * {@link module:ol/geom/Geometry} that will be rendered and styled for the feature.\n *\n * @typedef {function(import(\"../Feature.js\").FeatureLike):\n * (import(\"../geom/Geometry.js\").default|import(\"../render/Feature.js\").default|undefined)} GeometryFunction\n */\n/**\n * Custom renderer function. Takes two arguments:\n *\n * 1. The pixel coordinates of the geometry in GeoJSON notation.\n * 2. The {@link module:ol/render~State} of the layer renderer.\n *\n * @typedef {function((import(\"../coordinate.js\").Coordinate|Array<import(\"../coordinate.js\").Coordinate>|Array<Array<import(\"../coordinate.js\").Coordinate>>),import(\"../render.js\").State): void}\n * RenderFunction\n */\n/**\n * @typedef {Object} Options\n * @property {string|import(\"../geom/Geometry.js\").default|GeometryFunction} [geometry] Feature property or geometry\n * or function returning a geometry to render for this style.\n * @property {import(\"./Fill.js\").default} [fill] Fill style.\n * @property {import(\"./Image.js\").default} [image] Image style.\n * @property {RenderFunction} [renderer] Custom renderer. When configured, `fill`, `stroke` and `image` will be\n * ignored, and the provided function will be called with each render frame for each geometry.\n * @property {RenderFunction} [hitDetectionRenderer] Custom renderer for hit detection. If provided will be used\n * in hit detection rendering.\n * @property {import(\"./Stroke.js\").default} [stroke] Stroke style.\n * @property {import(\"./Text.js\").default} [text] Text style.\n * @property {number} [zIndex] Z index.\n */\n/**\n * @classdesc\n * Container for vector feature rendering styles. Any changes made to the style\n * or its children through `set*()` methods will not take effect until the\n * feature or layer that uses the style is re-rendered.\n *\n * ## Feature styles\n *\n * If no style is defined, the following default style is used:\n * ```js\n * import {Fill, Stroke, Circle, Style} from 'ol/style';\n *\n * var fill = new Fill({\n * color: 'rgba(255,255,255,0.4)'\n * });\n * var stroke = new Stroke({\n * color: '#3399CC',\n * width: 1.25\n * });\n * var styles = [\n * new Style({\n * image: new Circle({\n * fill: fill,\n * stroke: stroke,\n * radius: 5\n * }),\n * fill: fill,\n * stroke: stroke\n * })\n * ];\n * ```\n *\n * A separate editing style has the following defaults:\n * ```js\n * import {Fill, Stroke, Circle, Style} from 'ol/style';\n * import GeometryType from 'ol/geom/GeometryType';\n *\n * var white = [255, 255, 255, 1];\n * var blue = [0, 153, 255, 1];\n * var width = 3;\n * styles[GeometryType.POLYGON] = [\n * new Style({\n * fill: new Fill({\n * color: [255, 255, 255, 0.5]\n * })\n * })\n * ];\n * styles[GeometryType.MULTI_POLYGON] =\n * styles[GeometryType.POLYGON];\n * styles[GeometryType.LINE_STRING] = [\n * new Style({\n * stroke: new Stroke({\n * color: white,\n * width: width + 2\n * })\n * }),\n * new Style({\n * stroke: new Stroke({\n * color: blue,\n * width: width\n * })\n * })\n * ];\n * styles[GeometryType.MULTI_LINE_STRING] =\n * styles[GeometryType.LINE_STRING];\n * styles[GeometryType.POINT] = [\n * new Style({\n * image: new Circle({\n * radius: width * 2,\n * fill: new Fill({\n * color: blue\n * }),\n * stroke: new Stroke({\n * color: white,\n * width: width / 2\n * })\n * }),\n * zIndex: Infinity\n * })\n * ];\n * styles[GeometryType.MULTI_POINT] =\n * styles[GeometryType.POINT];\n * styles[GeometryType.GEOMETRY_COLLECTION] =\n * styles[GeometryType.POLYGON].concat(\n * styles[GeometryType.LINE_STRING],\n * styles[GeometryType.POINT]\n * );\n * ```\n *\n * @api\n */\nvar Style = /** @class */ (function () {\n /**\n * @param {Options} [opt_options] Style options.\n */\n function Style(opt_options) {\n var options = opt_options || {};\n /**\n * @private\n * @type {string|import(\"../geom/Geometry.js\").default|GeometryFunction}\n */\n this.geometry_ = null;\n /**\n * @private\n * @type {!GeometryFunction}\n */\n this.geometryFunction_ = defaultGeometryFunction;\n if (options.geometry !== undefined) {\n this.setGeometry(options.geometry);\n }\n /**\n * @private\n * @type {import(\"./Fill.js\").default}\n */\n this.fill_ = options.fill !== undefined ? options.fill : null;\n /**\n * @private\n * @type {import(\"./Image.js\").default}\n */\n this.image_ = options.image !== undefined ? options.image : null;\n /**\n * @private\n * @type {RenderFunction|null}\n */\n this.renderer_ = options.renderer !== undefined ? options.renderer : null;\n /**\n * @private\n * @type {RenderFunction|null}\n */\n this.hitDetectionRenderer_ =\n options.hitDetectionRenderer !== undefined\n ? options.hitDetectionRenderer\n : null;\n /**\n * @private\n * @type {import(\"./Stroke.js\").default}\n */\n this.stroke_ = options.stroke !== undefined ? options.stroke : null;\n /**\n * @private\n * @type {import(\"./Text.js\").default}\n */\n this.text_ = options.text !== undefined ? options.text : null;\n /**\n * @private\n * @type {number|undefined}\n */\n this.zIndex_ = options.zIndex;\n }\n /**\n * Clones the style.\n * @return {Style} The cloned style.\n * @api\n */\n Style.prototype.clone = function () {\n var geometry = this.getGeometry();\n if (geometry && typeof geometry === 'object') {\n geometry = /** @type {import(\"../geom/Geometry.js\").default} */ (geometry).clone();\n }\n return new Style({\n geometry: geometry,\n fill: this.getFill() ? this.getFill().clone() : undefined,\n image: this.getImage() ? this.getImage().clone() : undefined,\n renderer: this.getRenderer(),\n stroke: this.getStroke() ? this.getStroke().clone() : undefined,\n text: this.getText() ? this.getText().clone() : undefined,\n zIndex: this.getZIndex(),\n });\n };\n /**\n * Get the custom renderer function that was configured with\n * {@link #setRenderer} or the `renderer` constructor option.\n * @return {RenderFunction|null} Custom renderer function.\n * @api\n */\n Style.prototype.getRenderer = function () {\n return this.renderer_;\n };\n /**\n * Sets a custom renderer function for this style. When set, `fill`, `stroke`\n * and `image` options of the style will be ignored.\n * @param {RenderFunction|null} renderer Custom renderer function.\n * @api\n */\n Style.prototype.setRenderer = function (renderer) {\n this.renderer_ = renderer;\n };\n /**\n * Sets a custom renderer function for this style used\n * in hit detection.\n * @param {RenderFunction|null} renderer Custom renderer function.\n * @api\n */\n Style.prototype.setHitDetectionRenderer = function (renderer) {\n this.hitDetectionRenderer_ = renderer;\n };\n /**\n * Get the custom renderer function that was configured with\n * {@link #setHitDetectionRenderer} or the `hitDetectionRenderer` constructor option.\n * @return {RenderFunction|null} Custom renderer function.\n * @api\n */\n Style.prototype.getHitDetectionRenderer = function () {\n return this.hitDetectionRenderer_;\n };\n /**\n * Get the geometry to be rendered.\n * @return {string|import(\"../geom/Geometry.js\").default|GeometryFunction}\n * Feature property or geometry or function that returns the geometry that will\n * be rendered with this style.\n * @api\n */\n Style.prototype.getGeometry = function () {\n return this.geometry_;\n };\n /**\n * Get the function used to generate a geometry for rendering.\n * @return {!GeometryFunction} Function that is called with a feature\n * and returns the geometry to render instead of the feature's geometry.\n * @api\n */\n Style.prototype.getGeometryFunction = function () {\n return this.geometryFunction_;\n };\n /**\n * Get the fill style.\n * @return {import(\"./Fill.js\").default} Fill style.\n * @api\n */\n Style.prototype.getFill = function () {\n return this.fill_;\n };\n /**\n * Set the fill style.\n * @param {import(\"./Fill.js\").default} fill Fill style.\n * @api\n */\n Style.prototype.setFill = function (fill) {\n this.fill_ = fill;\n };\n /**\n * Get the image style.\n * @return {import(\"./Image.js\").default} Image style.\n * @api\n */\n Style.prototype.getImage = function () {\n return this.image_;\n };\n /**\n * Set the image style.\n * @param {import(\"./Image.js\").default} image Image style.\n * @api\n */\n Style.prototype.setImage = function (image) {\n this.image_ = image;\n };\n /**\n * Get the stroke style.\n * @return {import(\"./Stroke.js\").default} Stroke style.\n * @api\n */\n Style.prototype.getStroke = function () {\n return this.stroke_;\n };\n /**\n * Set the stroke style.\n * @param {import(\"./Stroke.js\").default} stroke Stroke style.\n * @api\n */\n Style.prototype.setStroke = function (stroke) {\n this.stroke_ = stroke;\n };\n /**\n * Get the text style.\n * @return {import(\"./Text.js\").default} Text style.\n * @api\n */\n Style.prototype.getText = function () {\n return this.text_;\n };\n /**\n * Set the text style.\n * @param {import(\"./Text.js\").default} text Text style.\n * @api\n */\n Style.prototype.setText = function (text) {\n this.text_ = text;\n };\n /**\n * Get the z-index for the style.\n * @return {number|undefined} ZIndex.\n * @api\n */\n Style.prototype.getZIndex = function () {\n return this.zIndex_;\n };\n /**\n * Set a geometry that is rendered instead of the feature's geometry.\n *\n * @param {string|import(\"../geom/Geometry.js\").default|GeometryFunction} geometry\n * Feature property or geometry or function returning a geometry to render\n * for this style.\n * @api\n */\n Style.prototype.setGeometry = function (geometry) {\n if (typeof geometry === 'function') {\n this.geometryFunction_ = geometry;\n }\n else if (typeof geometry === 'string') {\n this.geometryFunction_ = function (feature) {\n return /** @type {import(\"../geom/Geometry.js\").default} */ (feature.get(geometry));\n };\n }\n else if (!geometry) {\n this.geometryFunction_ = defaultGeometryFunction;\n }\n else if (geometry !== undefined) {\n this.geometryFunction_ = function () {\n return /** @type {import(\"../geom/Geometry.js\").default} */ (geometry);\n };\n }\n this.geometry_ = geometry;\n };\n /**\n * Set the z-index.\n *\n * @param {number|undefined} zIndex ZIndex.\n * @api\n */\n Style.prototype.setZIndex = function (zIndex) {\n this.zIndex_ = zIndex;\n };\n return Style;\n}());\n/**\n * Convert the provided object into a style function. Functions passed through\n * unchanged. Arrays of Style or single style objects wrapped in a\n * new style function.\n * @param {StyleFunction|Array<Style>|Style} obj\n * A style function, a single style, or an array of styles.\n * @return {StyleFunction} A style function.\n */\nexport function toFunction(obj) {\n var styleFunction;\n if (typeof obj === 'function') {\n styleFunction = obj;\n }\n else {\n /**\n * @type {Array<Style>}\n */\n var styles_1;\n if (Array.isArray(obj)) {\n styles_1 = obj;\n }\n else {\n assert(typeof ( /** @type {?} */(obj).getZIndex) === 'function', 41); // Expected an `Style` or an array of `Style`\n var style = /** @type {Style} */ (obj);\n styles_1 = [style];\n }\n styleFunction = function () {\n return styles_1;\n };\n }\n return styleFunction;\n}\n/**\n * @type {Array<Style>}\n */\nvar defaultStyles = null;\n/**\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {number} resolution Resolution.\n * @return {Array<Style>} Style.\n */\nexport function createDefaultStyle(feature, resolution) {\n // We don't use an immediately-invoked function\n // and a closure so we don't get an error at script evaluation time in\n // browsers that do not support Canvas. (import(\"./Circle.js\").CircleStyle does\n // canvas.getContext('2d') at construction time, which will cause an.error\n // in such browsers.)\n if (!defaultStyles) {\n var fill = new Fill({\n color: 'rgba(255,255,255,0.4)',\n });\n var stroke = new Stroke({\n color: '#3399CC',\n width: 1.25,\n });\n defaultStyles = [\n new Style({\n image: new CircleStyle({\n fill: fill,\n stroke: stroke,\n radius: 5,\n }),\n fill: fill,\n stroke: stroke,\n }),\n ];\n }\n return defaultStyles;\n}\n/**\n * Default styles for editing features.\n * @return {Object<import(\"../geom/GeometryType.js\").default, Array<Style>>} Styles\n */\nexport function createEditingStyle() {\n /** @type {Object<import(\"../geom/GeometryType.js\").default, Array<Style>>} */\n var styles = {};\n var white = [255, 255, 255, 1];\n var blue = [0, 153, 255, 1];\n var width = 3;\n styles[GeometryType.POLYGON] = [\n new Style({\n fill: new Fill({\n color: [255, 255, 255, 0.5],\n }),\n }),\n ];\n styles[GeometryType.MULTI_POLYGON] = styles[GeometryType.POLYGON];\n styles[GeometryType.LINE_STRING] = [\n new Style({\n stroke: new Stroke({\n color: white,\n width: width + 2,\n }),\n }),\n new Style({\n stroke: new Stroke({\n color: blue,\n width: width,\n }),\n }),\n ];\n styles[GeometryType.MULTI_LINE_STRING] = styles[GeometryType.LINE_STRING];\n styles[GeometryType.CIRCLE] = styles[GeometryType.POLYGON].concat(styles[GeometryType.LINE_STRING]);\n styles[GeometryType.POINT] = [\n new Style({\n image: new CircleStyle({\n radius: width * 2,\n fill: new Fill({\n color: blue,\n }),\n stroke: new Stroke({\n color: white,\n width: width / 2,\n }),\n }),\n zIndex: Infinity,\n }),\n ];\n styles[GeometryType.MULTI_POINT] = styles[GeometryType.POINT];\n styles[GeometryType.GEOMETRY_COLLECTION] = styles[GeometryType.POLYGON].concat(styles[GeometryType.LINE_STRING], styles[GeometryType.POINT]);\n return styles;\n}\n/**\n * Function that is called with a feature and returns its default geometry.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature to get the geometry for.\n * @return {import(\"../geom/Geometry.js\").default|import(\"../render/Feature.js\").default|undefined} Geometry to render.\n */\nfunction defaultGeometryFunction(feature) {\n return feature.getGeometry();\n}\nexport default Style;\n//# sourceMappingURL=Style.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/layer/BaseVector\n */\nimport Layer from './Layer.js';\nimport RBush from 'rbush/rbush.js';\nimport { assign } from '../obj.js';\nimport { createDefaultStyle, toFunction as toStyleFunction, } from '../style/Style.js';\n/**\n * @template {import(\"../source/Vector.js\").default|import(\"../source/VectorTile.js\").default} VectorSourceType\n * @typedef {Object} Options\n * @property {string} [className='ol-layer'] A CSS class name to set to the layer element.\n * @property {number} [opacity=1] Opacity (0, 1).\n * @property {boolean} [visible=true] Visibility.\n * @property {import(\"../extent.js\").Extent} [extent] The bounding extent for layer rendering. The layer will not be\n * rendered outside of this extent.\n * @property {number} [zIndex] The z-index for layer rendering. At rendering time, the layers\n * will be ordered, first by Z-index and then by position. When `undefined`, a `zIndex` of 0 is assumed\n * for layers that are added to the map's `layers` collection, or `Infinity` when the layer's `setMap()`\n * method was used.\n * @property {number} [minResolution] The minimum resolution (inclusive) at which this layer will be\n * visible.\n * @property {number} [maxResolution] The maximum resolution (exclusive) below which this layer will\n * be visible.\n * @property {number} [minZoom] The minimum view zoom level (exclusive) above which this layer will be\n * visible.\n * @property {number} [maxZoom] The maximum view zoom level (inclusive) at which this layer will\n * be visible.\n * @property {import(\"../render.js\").OrderFunction} [renderOrder] Render order. Function to be used when sorting\n * features before rendering. By default features are drawn in the order that they are created. Use\n * `null` to avoid the sort, but get an undefined draw order.\n * @property {number} [renderBuffer=100] The buffer in pixels around the viewport extent used by the\n * renderer when getting features from the vector source for the rendering or hit-detection.\n * Recommended value: the size of the largest symbol, line width or label.\n * @property {VectorSourceType} [source] Source.\n * @property {import(\"../PluggableMap.js\").default} [map] Sets the layer as overlay on a map. The map will not manage\n * this layer in its layers collection, and the layer will be rendered on top. This is useful for\n * temporary layers. The standard way to add a layer to a map and have it managed by the map is to\n * use {@link import(\"../PluggableMap.js\").default#addLayer map.addLayer()}.\n * @property {boolean} [declutter=false] Declutter images and text. Decluttering is applied to all\n * image and text styles of all Vector and VectorTile layers that have set this to `true`. The priority\n * is defined by the z-index of the layer, the `zIndex` of the style and the render order of features.\n * Higher z-index means higher priority. Within the same z-index, a feature rendered before another has\n * higher priority.\n * @property {import(\"../style/Style.js\").StyleLike|null} [style] Layer style. When set to `null`, only\n * features that have their own style will be rendered. See {@link module:ol/style} for default style\n * which will be used if this is not set.\n * @property {boolean} [updateWhileAnimating=false] When set to `true`, feature batches will\n * be recreated during animations. This means that no vectors will be shown clipped, but the\n * setting will have a performance impact for large amounts of vector data. When set to `false`,\n * batches will be recreated when no animation is active.\n * @property {boolean} [updateWhileInteracting=false] When set to `true`, feature batches will\n * be recreated during interactions. See also `updateWhileAnimating`.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n/**\n * @enum {string}\n * @private\n */\nvar Property = {\n RENDER_ORDER: 'renderOrder',\n};\n/**\n * @classdesc\n * Vector data that is rendered client-side.\n * Note that any property set in the options is set as a {@link module:ol/Object~BaseObject}\n * property on the layer object; for example, setting `title: 'My Title'` in the\n * options means that `title` is observable, and has get/set accessors.\n *\n * @template {import(\"../source/Vector.js\").default|import(\"../source/VectorTile.js\").default} VectorSourceType\n * @extends {Layer<VectorSourceType>}\n * @api\n */\nvar BaseVectorLayer = /** @class */ (function (_super) {\n __extends(BaseVectorLayer, _super);\n /**\n * @param {Options<VectorSourceType>} [opt_options] Options.\n */\n function BaseVectorLayer(opt_options) {\n var _this = this;\n var options = opt_options ? opt_options : {};\n var baseOptions = assign({}, options);\n delete baseOptions.style;\n delete baseOptions.renderBuffer;\n delete baseOptions.updateWhileAnimating;\n delete baseOptions.updateWhileInteracting;\n _this = _super.call(this, baseOptions) || this;\n /**\n * @private\n * @type {boolean}\n */\n _this.declutter_ =\n options.declutter !== undefined ? options.declutter : false;\n /**\n * @type {number}\n * @private\n */\n _this.renderBuffer_ =\n options.renderBuffer !== undefined ? options.renderBuffer : 100;\n /**\n * User provided style.\n * @type {import(\"../style/Style.js\").StyleLike}\n * @private\n */\n _this.style_ = null;\n /**\n * Style function for use within the library.\n * @type {import(\"../style/Style.js\").StyleFunction|undefined}\n * @private\n */\n _this.styleFunction_ = undefined;\n _this.setStyle(options.style);\n /**\n * @type {boolean}\n * @private\n */\n _this.updateWhileAnimating_ =\n options.updateWhileAnimating !== undefined\n ? options.updateWhileAnimating\n : false;\n /**\n * @type {boolean}\n * @private\n */\n _this.updateWhileInteracting_ =\n options.updateWhileInteracting !== undefined\n ? options.updateWhileInteracting\n : false;\n return _this;\n }\n /**\n * @return {boolean} Declutter.\n */\n BaseVectorLayer.prototype.getDeclutter = function () {\n return this.declutter_;\n };\n /**\n * Get the topmost feature that intersects the given pixel on the viewport. Returns a promise\n * that resolves with an array of features. The array will either contain the topmost feature\n * when a hit was detected, or it will be empty.\n *\n * The hit detection algorithm used for this method is optimized for performance, but is less\n * accurate than the one used in {@link import(\"../PluggableMap.js\").default#getFeaturesAtPixel}: Text\n * is not considered, and icons are only represented by their bounding box instead of the exact\n * image.\n *\n * @param {import(\"../pixel.js\").Pixel} pixel Pixel.\n * @return {Promise<Array<import(\"../Feature\").default>>} Promise that resolves with an array of features.\n * @api\n */\n BaseVectorLayer.prototype.getFeatures = function (pixel) {\n return _super.prototype.getFeatures.call(this, pixel);\n };\n /**\n * @return {number|undefined} Render buffer.\n */\n BaseVectorLayer.prototype.getRenderBuffer = function () {\n return this.renderBuffer_;\n };\n /**\n * @return {function(import(\"../Feature.js\").default, import(\"../Feature.js\").default): number|null|undefined} Render\n * order.\n */\n BaseVectorLayer.prototype.getRenderOrder = function () {\n return /** @type {import(\"../render.js\").OrderFunction|null|undefined} */ (this.get(Property.RENDER_ORDER));\n };\n /**\n * Get the style for features. This returns whatever was passed to the `style`\n * option at construction or to the `setStyle` method.\n * @return {import(\"../style/Style.js\").StyleLike|null|undefined} Layer style.\n * @api\n */\n BaseVectorLayer.prototype.getStyle = function () {\n return this.style_;\n };\n /**\n * Get the style function.\n * @return {import(\"../style/Style.js\").StyleFunction|undefined} Layer style function.\n * @api\n */\n BaseVectorLayer.prototype.getStyleFunction = function () {\n return this.styleFunction_;\n };\n /**\n * @return {boolean} Whether the rendered layer should be updated while\n * animating.\n */\n BaseVectorLayer.prototype.getUpdateWhileAnimating = function () {\n return this.updateWhileAnimating_;\n };\n /**\n * @return {boolean} Whether the rendered layer should be updated while\n * interacting.\n */\n BaseVectorLayer.prototype.getUpdateWhileInteracting = function () {\n return this.updateWhileInteracting_;\n };\n /**\n * Render declutter items for this layer\n * @param {import(\"../PluggableMap.js\").FrameState} frameState Frame state.\n */\n BaseVectorLayer.prototype.renderDeclutter = function (frameState) {\n if (!frameState.declutterTree) {\n frameState.declutterTree = new RBush(9);\n }\n /** @type {*} */ (this.getRenderer()).renderDeclutter(frameState);\n };\n /**\n * @param {import(\"../render.js\").OrderFunction|null|undefined} renderOrder\n * Render order.\n */\n BaseVectorLayer.prototype.setRenderOrder = function (renderOrder) {\n this.set(Property.RENDER_ORDER, renderOrder);\n };\n /**\n * Set the style for features. This can be a single style object, an array\n * of styles, or a function that takes a feature and resolution and returns\n * an array of styles. If set to `null`, the layer has no style (a `null` style),\n * so only features that have their own styles will be rendered in the layer. Call\n * `setStyle()` without arguments to reset to the default style. See\n * {@link module:ol/style} for information on the default style.\n * @param {import(\"../style/Style.js\").StyleLike|null} [opt_style] Layer style.\n * @api\n */\n BaseVectorLayer.prototype.setStyle = function (opt_style) {\n this.style_ = opt_style !== undefined ? opt_style : createDefaultStyle;\n this.styleFunction_ =\n opt_style === null ? undefined : toStyleFunction(this.style_);\n this.changed();\n };\n return BaseVectorLayer;\n}(Layer));\nexport default BaseVectorLayer;\n//# sourceMappingURL=BaseVector.js.map\n","/**\n * @module ol/render/canvas/Instruction\n */\n/**\n * @enum {number}\n */\nvar Instruction = {\n BEGIN_GEOMETRY: 0,\n BEGIN_PATH: 1,\n CIRCLE: 2,\n CLOSE_PATH: 3,\n CUSTOM: 4,\n DRAW_CHARS: 5,\n DRAW_IMAGE: 6,\n END_GEOMETRY: 7,\n FILL: 8,\n MOVE_TO_LINE_TO: 9,\n SET_FILL_STYLE: 10,\n SET_STROKE_STYLE: 11,\n STROKE: 12,\n};\n/**\n * @type {Array<Instruction>}\n */\nexport var fillInstruction = [Instruction.FILL];\n/**\n * @type {Array<Instruction>}\n */\nexport var strokeInstruction = [Instruction.STROKE];\n/**\n * @type {Array<Instruction>}\n */\nexport var beginPathInstruction = [Instruction.BEGIN_PATH];\n/**\n * @type {Array<Instruction>}\n */\nexport var closePathInstruction = [Instruction.CLOSE_PATH];\nexport default Instruction;\n//# sourceMappingURL=Instruction.js.map","/**\n * @module ol/render/VectorContext\n */\n/**\n * @classdesc\n * Context for drawing geometries. A vector context is available on render\n * events and does not need to be constructed directly.\n * @api\n */\nvar VectorContext = /** @class */ (function () {\n function VectorContext() {\n }\n /**\n * Render a geometry with a custom renderer.\n *\n * @param {import(\"../geom/SimpleGeometry.js\").default} geometry Geometry.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {Function} renderer Renderer.\n * @param {Function} hitDetectionRenderer Renderer.\n */\n VectorContext.prototype.drawCustom = function (geometry, feature, renderer, hitDetectionRenderer) { };\n /**\n * Render a geometry.\n *\n * @param {import(\"../geom/Geometry.js\").default} geometry The geometry to render.\n */\n VectorContext.prototype.drawGeometry = function (geometry) { };\n /**\n * Set the rendering style.\n *\n * @param {import(\"../style/Style.js\").default} style The rendering style.\n */\n VectorContext.prototype.setStyle = function (style) { };\n /**\n * @param {import(\"../geom/Circle.js\").default} circleGeometry Circle geometry.\n * @param {import(\"../Feature.js\").default} feature Feature.\n */\n VectorContext.prototype.drawCircle = function (circleGeometry, feature) { };\n /**\n * @param {import(\"../Feature.js\").default} feature Feature.\n * @param {import(\"../style/Style.js\").default} style Style.\n */\n VectorContext.prototype.drawFeature = function (feature, style) { };\n /**\n * @param {import(\"../geom/GeometryCollection.js\").default} geometryCollectionGeometry Geometry collection.\n * @param {import(\"../Feature.js\").default} feature Feature.\n */\n VectorContext.prototype.drawGeometryCollection = function (geometryCollectionGeometry, feature) { };\n /**\n * @param {import(\"../geom/LineString.js\").default|import(\"./Feature.js\").default} lineStringGeometry Line string geometry.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n */\n VectorContext.prototype.drawLineString = function (lineStringGeometry, feature) { };\n /**\n * @param {import(\"../geom/MultiLineString.js\").default|import(\"./Feature.js\").default} multiLineStringGeometry MultiLineString geometry.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n */\n VectorContext.prototype.drawMultiLineString = function (multiLineStringGeometry, feature) { };\n /**\n * @param {import(\"../geom/MultiPoint.js\").default|import(\"./Feature.js\").default} multiPointGeometry MultiPoint geometry.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n */\n VectorContext.prototype.drawMultiPoint = function (multiPointGeometry, feature) { };\n /**\n * @param {import(\"../geom/MultiPolygon.js\").default} multiPolygonGeometry MultiPolygon geometry.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n */\n VectorContext.prototype.drawMultiPolygon = function (multiPolygonGeometry, feature) { };\n /**\n * @param {import(\"../geom/Point.js\").default|import(\"./Feature.js\").default} pointGeometry Point geometry.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n */\n VectorContext.prototype.drawPoint = function (pointGeometry, feature) { };\n /**\n * @param {import(\"../geom/Polygon.js\").default|import(\"./Feature.js\").default} polygonGeometry Polygon geometry.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n */\n VectorContext.prototype.drawPolygon = function (polygonGeometry, feature) { };\n /**\n * @param {import(\"../geom/SimpleGeometry.js\").default|import(\"./Feature.js\").default} geometry Geometry.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n */\n VectorContext.prototype.drawText = function (geometry, feature) { };\n /**\n * @param {import(\"../style/Fill.js\").default} fillStyle Fill style.\n * @param {import(\"../style/Stroke.js\").default} strokeStyle Stroke style.\n */\n VectorContext.prototype.setFillStrokeStyle = function (fillStyle, strokeStyle) { };\n /**\n * @param {import(\"../style/Image.js\").default} imageStyle Image style.\n * @param {import(\"../render/canvas.js\").DeclutterImageWithText} [opt_declutterImageWithText] Shared data for combined decluttering with a text style.\n */\n VectorContext.prototype.setImageStyle = function (imageStyle, opt_declutterImageWithText) { };\n /**\n * @param {import(\"../style/Text.js\").default} textStyle Text style.\n * @param {import(\"../render/canvas.js\").DeclutterImageWithText} [opt_declutterImageWithText] Shared data for combined decluttering with an image style.\n */\n VectorContext.prototype.setTextStyle = function (textStyle, opt_declutterImageWithText) { };\n return VectorContext;\n}());\nexport default VectorContext;\n//# sourceMappingURL=VectorContext.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/render/canvas/Builder\n */\nimport CanvasInstruction from './Instruction.js';\nimport GeometryType from '../../geom/GeometryType.js';\nimport Relationship from '../../extent/Relationship.js';\nimport VectorContext from '../VectorContext.js';\nimport { asColorLike } from '../../colorlike.js';\nimport { buffer, clone, containsCoordinate, coordinateRelationship, } from '../../extent.js';\nimport { defaultFillStyle, defaultLineCap, defaultLineDash, defaultLineDashOffset, defaultLineJoin, defaultLineWidth, defaultMiterLimit, defaultStrokeStyle, } from '../canvas.js';\nimport { equals, reverseSubArray } from '../../array.js';\nimport { inflateCoordinates, inflateCoordinatesArray, inflateMultiCoordinatesArray, } from '../../geom/flat/inflate.js';\nvar CanvasBuilder = /** @class */ (function (_super) {\n __extends(CanvasBuilder, _super);\n /**\n * @param {number} tolerance Tolerance.\n * @param {import(\"../../extent.js\").Extent} maxExtent Maximum extent.\n * @param {number} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n */\n function CanvasBuilder(tolerance, maxExtent, resolution, pixelRatio) {\n var _this = _super.call(this) || this;\n /**\n * @protected\n * @type {number}\n */\n _this.tolerance = tolerance;\n /**\n * @protected\n * @const\n * @type {import(\"../../extent.js\").Extent}\n */\n _this.maxExtent = maxExtent;\n /**\n * @protected\n * @type {number}\n */\n _this.pixelRatio = pixelRatio;\n /**\n * @protected\n * @type {number}\n */\n _this.maxLineWidth = 0;\n /**\n * @protected\n * @const\n * @type {number}\n */\n _this.resolution = resolution;\n /**\n * @private\n * @type {Array<*>}\n */\n _this.beginGeometryInstruction1_ = null;\n /**\n * @private\n * @type {Array<*>}\n */\n _this.beginGeometryInstruction2_ = null;\n /**\n * @private\n * @type {import(\"../../extent.js\").Extent}\n */\n _this.bufferedMaxExtent_ = null;\n /**\n * @protected\n * @type {Array<*>}\n */\n _this.instructions = [];\n /**\n * @protected\n * @type {Array<number>}\n */\n _this.coordinates = [];\n /**\n * @private\n * @type {import(\"../../coordinate.js\").Coordinate}\n */\n _this.tmpCoordinate_ = [];\n /**\n * @protected\n * @type {Array<*>}\n */\n _this.hitDetectionInstructions = [];\n /**\n * @protected\n * @type {import(\"../canvas.js\").FillStrokeState}\n */\n _this.state = /** @type {import(\"../canvas.js\").FillStrokeState} */ ({});\n return _this;\n }\n /**\n * @protected\n * @param {Array<number>} dashArray Dash array.\n * @return {Array<number>} Dash array with pixel ratio applied\n */\n CanvasBuilder.prototype.applyPixelRatio = function (dashArray) {\n var pixelRatio = this.pixelRatio;\n return pixelRatio == 1\n ? dashArray\n : dashArray.map(function (dash) {\n return dash * pixelRatio;\n });\n };\n /**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} stride Stride.\n * @protected\n * @return {number} My end\n */\n CanvasBuilder.prototype.appendFlatPointCoordinates = function (flatCoordinates, stride) {\n var extent = this.getBufferedMaxExtent();\n var tmpCoord = this.tmpCoordinate_;\n var coordinates = this.coordinates;\n var myEnd = coordinates.length;\n for (var i = 0, ii = flatCoordinates.length; i < ii; i += stride) {\n tmpCoord[0] = flatCoordinates[i];\n tmpCoord[1] = flatCoordinates[i + 1];\n if (containsCoordinate(extent, tmpCoord)) {\n coordinates[myEnd++] = tmpCoord[0];\n coordinates[myEnd++] = tmpCoord[1];\n }\n }\n return myEnd;\n };\n /**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {boolean} closed Last input coordinate equals first.\n * @param {boolean} skipFirst Skip first coordinate.\n * @protected\n * @return {number} My end.\n */\n CanvasBuilder.prototype.appendFlatLineCoordinates = function (flatCoordinates, offset, end, stride, closed, skipFirst) {\n var coordinates = this.coordinates;\n var myEnd = coordinates.length;\n var extent = this.getBufferedMaxExtent();\n if (skipFirst) {\n offset += stride;\n }\n var lastXCoord = flatCoordinates[offset];\n var lastYCoord = flatCoordinates[offset + 1];\n var nextCoord = this.tmpCoordinate_;\n var skipped = true;\n var i, lastRel, nextRel;\n for (i = offset + stride; i < end; i += stride) {\n nextCoord[0] = flatCoordinates[i];\n nextCoord[1] = flatCoordinates[i + 1];\n nextRel = coordinateRelationship(extent, nextCoord);\n if (nextRel !== lastRel) {\n if (skipped) {\n coordinates[myEnd++] = lastXCoord;\n coordinates[myEnd++] = lastYCoord;\n skipped = false;\n }\n coordinates[myEnd++] = nextCoord[0];\n coordinates[myEnd++] = nextCoord[1];\n }\n else if (nextRel === Relationship.INTERSECTING) {\n coordinates[myEnd++] = nextCoord[0];\n coordinates[myEnd++] = nextCoord[1];\n skipped = false;\n }\n else {\n skipped = true;\n }\n lastXCoord = nextCoord[0];\n lastYCoord = nextCoord[1];\n lastRel = nextRel;\n }\n // Last coordinate equals first or only one point to append:\n if ((closed && skipped) || i === offset + stride) {\n coordinates[myEnd++] = lastXCoord;\n coordinates[myEnd++] = lastYCoord;\n }\n return myEnd;\n };\n /**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {Array<number>} builderEnds Builder ends.\n * @return {number} Offset.\n */\n CanvasBuilder.prototype.drawCustomCoordinates_ = function (flatCoordinates, offset, ends, stride, builderEnds) {\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n var end = ends[i];\n var builderEnd = this.appendFlatLineCoordinates(flatCoordinates, offset, end, stride, false, false);\n builderEnds.push(builderEnd);\n offset = end;\n }\n return offset;\n };\n /**\n * @param {import(\"../../geom/SimpleGeometry.js\").default} geometry Geometry.\n * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n * @param {Function} renderer Renderer.\n * @param {Function} hitDetectionRenderer Renderer.\n */\n CanvasBuilder.prototype.drawCustom = function (geometry, feature, renderer, hitDetectionRenderer) {\n this.beginGeometry(geometry, feature);\n var type = geometry.getType();\n var stride = geometry.getStride();\n var builderBegin = this.coordinates.length;\n var flatCoordinates, builderEnd, builderEnds, builderEndss;\n var offset;\n switch (type) {\n case GeometryType.MULTI_POLYGON:\n flatCoordinates =\n /** @type {import(\"../../geom/MultiPolygon.js\").default} */ (geometry).getOrientedFlatCoordinates();\n builderEndss = [];\n var endss = \n /** @type {import(\"../../geom/MultiPolygon.js\").default} */ (geometry).getEndss();\n offset = 0;\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n var myEnds = [];\n offset = this.drawCustomCoordinates_(flatCoordinates, offset, endss[i], stride, myEnds);\n builderEndss.push(myEnds);\n }\n this.instructions.push([\n CanvasInstruction.CUSTOM,\n builderBegin,\n builderEndss,\n geometry,\n renderer,\n inflateMultiCoordinatesArray,\n ]);\n this.hitDetectionInstructions.push([\n CanvasInstruction.CUSTOM,\n builderBegin,\n builderEndss,\n geometry,\n hitDetectionRenderer || renderer,\n inflateMultiCoordinatesArray,\n ]);\n break;\n case GeometryType.POLYGON:\n case GeometryType.MULTI_LINE_STRING:\n builderEnds = [];\n flatCoordinates =\n type == GeometryType.POLYGON\n ? /** @type {import(\"../../geom/Polygon.js\").default} */ (geometry).getOrientedFlatCoordinates()\n : geometry.getFlatCoordinates();\n offset = this.drawCustomCoordinates_(flatCoordinates, 0, \n /** @type {import(\"../../geom/Polygon.js\").default|import(\"../../geom/MultiLineString.js\").default} */ (geometry).getEnds(), stride, builderEnds);\n this.instructions.push([\n CanvasInstruction.CUSTOM,\n builderBegin,\n builderEnds,\n geometry,\n renderer,\n inflateCoordinatesArray,\n ]);\n this.hitDetectionInstructions.push([\n CanvasInstruction.CUSTOM,\n builderBegin,\n builderEnds,\n geometry,\n hitDetectionRenderer || renderer,\n inflateCoordinatesArray,\n ]);\n break;\n case GeometryType.LINE_STRING:\n case GeometryType.CIRCLE:\n flatCoordinates = geometry.getFlatCoordinates();\n builderEnd = this.appendFlatLineCoordinates(flatCoordinates, 0, flatCoordinates.length, stride, false, false);\n this.instructions.push([\n CanvasInstruction.CUSTOM,\n builderBegin,\n builderEnd,\n geometry,\n renderer,\n inflateCoordinates,\n ]);\n this.hitDetectionInstructions.push([\n CanvasInstruction.CUSTOM,\n builderBegin,\n builderEnd,\n geometry,\n hitDetectionRenderer || renderer,\n inflateCoordinates,\n ]);\n break;\n case GeometryType.MULTI_POINT:\n flatCoordinates = geometry.getFlatCoordinates();\n builderEnd = this.appendFlatPointCoordinates(flatCoordinates, stride);\n if (builderEnd > builderBegin) {\n this.instructions.push([\n CanvasInstruction.CUSTOM,\n builderBegin,\n builderEnd,\n geometry,\n renderer,\n inflateCoordinates,\n ]);\n this.hitDetectionInstructions.push([\n CanvasInstruction.CUSTOM,\n builderBegin,\n builderEnd,\n geometry,\n hitDetectionRenderer || renderer,\n inflateCoordinates,\n ]);\n }\n break;\n case GeometryType.POINT:\n flatCoordinates = geometry.getFlatCoordinates();\n this.coordinates.push(flatCoordinates[0], flatCoordinates[1]);\n builderEnd = this.coordinates.length;\n this.instructions.push([\n CanvasInstruction.CUSTOM,\n builderBegin,\n builderEnd,\n geometry,\n renderer,\n ]);\n this.hitDetectionInstructions.push([\n CanvasInstruction.CUSTOM,\n builderBegin,\n builderEnd,\n geometry,\n hitDetectionRenderer || renderer,\n ]);\n break;\n default:\n }\n this.endGeometry(feature);\n };\n /**\n * @protected\n * @param {import(\"../../geom/Geometry\").default|import(\"../Feature.js\").default} geometry The geometry.\n * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n */\n CanvasBuilder.prototype.beginGeometry = function (geometry, feature) {\n this.beginGeometryInstruction1_ = [\n CanvasInstruction.BEGIN_GEOMETRY,\n feature,\n 0,\n geometry,\n ];\n this.instructions.push(this.beginGeometryInstruction1_);\n this.beginGeometryInstruction2_ = [\n CanvasInstruction.BEGIN_GEOMETRY,\n feature,\n 0,\n geometry,\n ];\n this.hitDetectionInstructions.push(this.beginGeometryInstruction2_);\n };\n /**\n * @return {import(\"../canvas.js\").SerializableInstructions} the serializable instructions.\n */\n CanvasBuilder.prototype.finish = function () {\n return {\n instructions: this.instructions,\n hitDetectionInstructions: this.hitDetectionInstructions,\n coordinates: this.coordinates,\n };\n };\n /**\n * Reverse the hit detection instructions.\n */\n CanvasBuilder.prototype.reverseHitDetectionInstructions = function () {\n var hitDetectionInstructions = this.hitDetectionInstructions;\n // step 1 - reverse array\n hitDetectionInstructions.reverse();\n // step 2 - reverse instructions within geometry blocks\n var i;\n var n = hitDetectionInstructions.length;\n var instruction;\n var type;\n var begin = -1;\n for (i = 0; i < n; ++i) {\n instruction = hitDetectionInstructions[i];\n type = /** @type {import(\"./Instruction.js\").default} */ (instruction[0]);\n if (type == CanvasInstruction.END_GEOMETRY) {\n begin = i;\n }\n else if (type == CanvasInstruction.BEGIN_GEOMETRY) {\n instruction[2] = i;\n reverseSubArray(this.hitDetectionInstructions, begin, i);\n begin = -1;\n }\n }\n };\n /**\n * @param {import(\"../../style/Fill.js\").default} fillStyle Fill style.\n * @param {import(\"../../style/Stroke.js\").default} strokeStyle Stroke style.\n */\n CanvasBuilder.prototype.setFillStrokeStyle = function (fillStyle, strokeStyle) {\n var state = this.state;\n if (fillStyle) {\n var fillStyleColor = fillStyle.getColor();\n state.fillStyle = asColorLike(fillStyleColor ? fillStyleColor : defaultFillStyle);\n }\n else {\n state.fillStyle = undefined;\n }\n if (strokeStyle) {\n var strokeStyleColor = strokeStyle.getColor();\n state.strokeStyle = asColorLike(strokeStyleColor ? strokeStyleColor : defaultStrokeStyle);\n var strokeStyleLineCap = strokeStyle.getLineCap();\n state.lineCap =\n strokeStyleLineCap !== undefined ? strokeStyleLineCap : defaultLineCap;\n var strokeStyleLineDash = strokeStyle.getLineDash();\n state.lineDash = strokeStyleLineDash\n ? strokeStyleLineDash.slice()\n : defaultLineDash;\n var strokeStyleLineDashOffset = strokeStyle.getLineDashOffset();\n state.lineDashOffset = strokeStyleLineDashOffset\n ? strokeStyleLineDashOffset\n : defaultLineDashOffset;\n var strokeStyleLineJoin = strokeStyle.getLineJoin();\n state.lineJoin =\n strokeStyleLineJoin !== undefined\n ? strokeStyleLineJoin\n : defaultLineJoin;\n var strokeStyleWidth = strokeStyle.getWidth();\n state.lineWidth =\n strokeStyleWidth !== undefined ? strokeStyleWidth : defaultLineWidth;\n var strokeStyleMiterLimit = strokeStyle.getMiterLimit();\n state.miterLimit =\n strokeStyleMiterLimit !== undefined\n ? strokeStyleMiterLimit\n : defaultMiterLimit;\n if (state.lineWidth > this.maxLineWidth) {\n this.maxLineWidth = state.lineWidth;\n // invalidate the buffered max extent cache\n this.bufferedMaxExtent_ = null;\n }\n }\n else {\n state.strokeStyle = undefined;\n state.lineCap = undefined;\n state.lineDash = null;\n state.lineDashOffset = undefined;\n state.lineJoin = undefined;\n state.lineWidth = undefined;\n state.miterLimit = undefined;\n }\n };\n /**\n * @param {import(\"../canvas.js\").FillStrokeState} state State.\n * @return {Array<*>} Fill instruction.\n */\n CanvasBuilder.prototype.createFill = function (state) {\n var fillStyle = state.fillStyle;\n /** @type {Array<*>} */\n var fillInstruction = [CanvasInstruction.SET_FILL_STYLE, fillStyle];\n if (typeof fillStyle !== 'string') {\n // Fill is a pattern or gradient - align it!\n fillInstruction.push(true);\n }\n return fillInstruction;\n };\n /**\n * @param {import(\"../canvas.js\").FillStrokeState} state State.\n */\n CanvasBuilder.prototype.applyStroke = function (state) {\n this.instructions.push(this.createStroke(state));\n };\n /**\n * @param {import(\"../canvas.js\").FillStrokeState} state State.\n * @return {Array<*>} Stroke instruction.\n */\n CanvasBuilder.prototype.createStroke = function (state) {\n return [\n CanvasInstruction.SET_STROKE_STYLE,\n state.strokeStyle,\n state.lineWidth * this.pixelRatio,\n state.lineCap,\n state.lineJoin,\n state.miterLimit,\n this.applyPixelRatio(state.lineDash),\n state.lineDashOffset * this.pixelRatio,\n ];\n };\n /**\n * @param {import(\"../canvas.js\").FillStrokeState} state State.\n * @param {function(this:CanvasBuilder, import(\"../canvas.js\").FillStrokeState):Array<*>} createFill Create fill.\n */\n CanvasBuilder.prototype.updateFillStyle = function (state, createFill) {\n var fillStyle = state.fillStyle;\n if (typeof fillStyle !== 'string' || state.currentFillStyle != fillStyle) {\n if (fillStyle !== undefined) {\n this.instructions.push(createFill.call(this, state));\n }\n state.currentFillStyle = fillStyle;\n }\n };\n /**\n * @param {import(\"../canvas.js\").FillStrokeState} state State.\n * @param {function(this:CanvasBuilder, import(\"../canvas.js\").FillStrokeState): void} applyStroke Apply stroke.\n */\n CanvasBuilder.prototype.updateStrokeStyle = function (state, applyStroke) {\n var strokeStyle = state.strokeStyle;\n var lineCap = state.lineCap;\n var lineDash = state.lineDash;\n var lineDashOffset = state.lineDashOffset;\n var lineJoin = state.lineJoin;\n var lineWidth = state.lineWidth;\n var miterLimit = state.miterLimit;\n if (state.currentStrokeStyle != strokeStyle ||\n state.currentLineCap != lineCap ||\n (lineDash != state.currentLineDash &&\n !equals(state.currentLineDash, lineDash)) ||\n state.currentLineDashOffset != lineDashOffset ||\n state.currentLineJoin != lineJoin ||\n state.currentLineWidth != lineWidth ||\n state.currentMiterLimit != miterLimit) {\n if (strokeStyle !== undefined) {\n applyStroke.call(this, state);\n }\n state.currentStrokeStyle = strokeStyle;\n state.currentLineCap = lineCap;\n state.currentLineDash = lineDash;\n state.currentLineDashOffset = lineDashOffset;\n state.currentLineJoin = lineJoin;\n state.currentLineWidth = lineWidth;\n state.currentMiterLimit = miterLimit;\n }\n };\n /**\n * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n */\n CanvasBuilder.prototype.endGeometry = function (feature) {\n this.beginGeometryInstruction1_[2] = this.instructions.length;\n this.beginGeometryInstruction1_ = null;\n this.beginGeometryInstruction2_[2] = this.hitDetectionInstructions.length;\n this.beginGeometryInstruction2_ = null;\n var endGeometryInstruction = [CanvasInstruction.END_GEOMETRY, feature];\n this.instructions.push(endGeometryInstruction);\n this.hitDetectionInstructions.push(endGeometryInstruction);\n };\n /**\n * Get the buffered rendering extent. Rendering will be clipped to the extent\n * provided to the constructor. To account for symbolizers that may intersect\n * this extent, we calculate a buffered extent (e.g. based on stroke width).\n * @return {import(\"../../extent.js\").Extent} The buffered rendering extent.\n * @protected\n */\n CanvasBuilder.prototype.getBufferedMaxExtent = function () {\n if (!this.bufferedMaxExtent_) {\n this.bufferedMaxExtent_ = clone(this.maxExtent);\n if (this.maxLineWidth > 0) {\n var width = (this.resolution * (this.maxLineWidth + 1)) / 2;\n buffer(this.bufferedMaxExtent_, width, this.bufferedMaxExtent_);\n }\n }\n return this.bufferedMaxExtent_;\n };\n return CanvasBuilder;\n}(VectorContext));\nexport default CanvasBuilder;\n//# sourceMappingURL=Builder.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/render/canvas/ImageBuilder\n */\nimport CanvasBuilder from './Builder.js';\nimport CanvasInstruction from './Instruction.js';\nvar CanvasImageBuilder = /** @class */ (function (_super) {\n __extends(CanvasImageBuilder, _super);\n /**\n * @param {number} tolerance Tolerance.\n * @param {import(\"../../extent.js\").Extent} maxExtent Maximum extent.\n * @param {number} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n */\n function CanvasImageBuilder(tolerance, maxExtent, resolution, pixelRatio) {\n var _this = _super.call(this, tolerance, maxExtent, resolution, pixelRatio) || this;\n /**\n * @private\n * @type {HTMLCanvasElement|HTMLVideoElement|HTMLImageElement}\n */\n _this.hitDetectionImage_ = null;\n /**\n * @private\n * @type {HTMLCanvasElement|HTMLVideoElement|HTMLImageElement}\n */\n _this.image_ = null;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.imagePixelRatio_ = undefined;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.anchorX_ = undefined;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.anchorY_ = undefined;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.height_ = undefined;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.opacity_ = undefined;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.originX_ = undefined;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.originY_ = undefined;\n /**\n * @private\n * @type {boolean|undefined}\n */\n _this.rotateWithView_ = undefined;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.rotation_ = undefined;\n /**\n * @private\n * @type {import(\"../../size.js\").Size|undefined}\n */\n _this.scale_ = undefined;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.width_ = undefined;\n /**\n * Data shared with a text builder for combined decluttering.\n * @private\n * @type {import(\"../canvas.js\").DeclutterImageWithText}\n */\n _this.declutterImageWithText_ = undefined;\n return _this;\n }\n /**\n * @param {import(\"../../geom/Point.js\").default|import(\"../Feature.js\").default} pointGeometry Point geometry.\n * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n */\n CanvasImageBuilder.prototype.drawPoint = function (pointGeometry, feature) {\n if (!this.image_) {\n return;\n }\n this.beginGeometry(pointGeometry, feature);\n var flatCoordinates = pointGeometry.getFlatCoordinates();\n var stride = pointGeometry.getStride();\n var myBegin = this.coordinates.length;\n var myEnd = this.appendFlatPointCoordinates(flatCoordinates, stride);\n this.instructions.push([\n CanvasInstruction.DRAW_IMAGE,\n myBegin,\n myEnd,\n this.image_,\n // Remaining arguments to DRAW_IMAGE are in alphabetical order\n this.anchorX_ * this.imagePixelRatio_,\n this.anchorY_ * this.imagePixelRatio_,\n Math.ceil(this.height_ * this.imagePixelRatio_),\n this.opacity_,\n this.originX_,\n this.originY_,\n this.rotateWithView_,\n this.rotation_,\n [\n (this.scale_[0] * this.pixelRatio) / this.imagePixelRatio_,\n (this.scale_[1] * this.pixelRatio) / this.imagePixelRatio_,\n ],\n Math.ceil(this.width_ * this.imagePixelRatio_),\n this.declutterImageWithText_,\n ]);\n this.hitDetectionInstructions.push([\n CanvasInstruction.DRAW_IMAGE,\n myBegin,\n myEnd,\n this.hitDetectionImage_,\n // Remaining arguments to DRAW_IMAGE are in alphabetical order\n this.anchorX_,\n this.anchorY_,\n this.height_,\n this.opacity_,\n this.originX_,\n this.originY_,\n this.rotateWithView_,\n this.rotation_,\n this.scale_,\n this.width_,\n this.declutterImageWithText_,\n ]);\n this.endGeometry(feature);\n };\n /**\n * @param {import(\"../../geom/MultiPoint.js\").default|import(\"../Feature.js\").default} multiPointGeometry MultiPoint geometry.\n * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n */\n CanvasImageBuilder.prototype.drawMultiPoint = function (multiPointGeometry, feature) {\n if (!this.image_) {\n return;\n }\n this.beginGeometry(multiPointGeometry, feature);\n var flatCoordinates = multiPointGeometry.getFlatCoordinates();\n var stride = multiPointGeometry.getStride();\n var myBegin = this.coordinates.length;\n var myEnd = this.appendFlatPointCoordinates(flatCoordinates, stride);\n this.instructions.push([\n CanvasInstruction.DRAW_IMAGE,\n myBegin,\n myEnd,\n this.image_,\n // Remaining arguments to DRAW_IMAGE are in alphabetical order\n this.anchorX_ * this.imagePixelRatio_,\n this.anchorY_ * this.imagePixelRatio_,\n Math.ceil(this.height_ * this.imagePixelRatio_),\n this.opacity_,\n this.originX_,\n this.originY_,\n this.rotateWithView_,\n this.rotation_,\n [\n (this.scale_[0] * this.pixelRatio) / this.imagePixelRatio_,\n (this.scale_[1] * this.pixelRatio) / this.imagePixelRatio_,\n ],\n Math.ceil(this.width_ * this.imagePixelRatio_),\n this.declutterImageWithText_,\n ]);\n this.hitDetectionInstructions.push([\n CanvasInstruction.DRAW_IMAGE,\n myBegin,\n myEnd,\n this.hitDetectionImage_,\n // Remaining arguments to DRAW_IMAGE are in alphabetical order\n this.anchorX_,\n this.anchorY_,\n this.height_,\n this.opacity_,\n this.originX_,\n this.originY_,\n this.rotateWithView_,\n this.rotation_,\n this.scale_,\n this.width_,\n this.declutterImageWithText_,\n ]);\n this.endGeometry(feature);\n };\n /**\n * @return {import(\"../canvas.js\").SerializableInstructions} the serializable instructions.\n */\n CanvasImageBuilder.prototype.finish = function () {\n this.reverseHitDetectionInstructions();\n // FIXME this doesn't really protect us against further calls to draw*Geometry\n this.anchorX_ = undefined;\n this.anchorY_ = undefined;\n this.hitDetectionImage_ = null;\n this.image_ = null;\n this.imagePixelRatio_ = undefined;\n this.height_ = undefined;\n this.scale_ = undefined;\n this.opacity_ = undefined;\n this.originX_ = undefined;\n this.originY_ = undefined;\n this.rotateWithView_ = undefined;\n this.rotation_ = undefined;\n this.width_ = undefined;\n return _super.prototype.finish.call(this);\n };\n /**\n * @param {import(\"../../style/Image.js\").default} imageStyle Image style.\n * @param {Object} [opt_sharedData] Shared data.\n */\n CanvasImageBuilder.prototype.setImageStyle = function (imageStyle, opt_sharedData) {\n var anchor = imageStyle.getAnchor();\n var size = imageStyle.getSize();\n var hitDetectionImage = imageStyle.getHitDetectionImage();\n var image = imageStyle.getImage(this.pixelRatio);\n var origin = imageStyle.getOrigin();\n this.imagePixelRatio_ = imageStyle.getPixelRatio(this.pixelRatio);\n this.anchorX_ = anchor[0];\n this.anchorY_ = anchor[1];\n this.hitDetectionImage_ = hitDetectionImage;\n this.image_ = image;\n this.height_ = size[1];\n this.opacity_ = imageStyle.getOpacity();\n this.originX_ = origin[0] * this.imagePixelRatio_;\n this.originY_ = origin[1] * this.imagePixelRatio_;\n this.rotateWithView_ = imageStyle.getRotateWithView();\n this.rotation_ = imageStyle.getRotation();\n this.scale_ = imageStyle.getScaleArray();\n this.width_ = size[0];\n this.declutterImageWithText_ = opt_sharedData;\n };\n return CanvasImageBuilder;\n}(CanvasBuilder));\nexport default CanvasImageBuilder;\n//# sourceMappingURL=ImageBuilder.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/render/canvas/LineStringBuilder\n */\nimport CanvasBuilder from './Builder.js';\nimport CanvasInstruction, { beginPathInstruction, strokeInstruction, } from './Instruction.js';\nimport { defaultLineDash, defaultLineDashOffset } from '../canvas.js';\nvar CanvasLineStringBuilder = /** @class */ (function (_super) {\n __extends(CanvasLineStringBuilder, _super);\n /**\n * @param {number} tolerance Tolerance.\n * @param {import(\"../../extent.js\").Extent} maxExtent Maximum extent.\n * @param {number} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n */\n function CanvasLineStringBuilder(tolerance, maxExtent, resolution, pixelRatio) {\n return _super.call(this, tolerance, maxExtent, resolution, pixelRatio) || this;\n }\n /**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @private\n * @return {number} end.\n */\n CanvasLineStringBuilder.prototype.drawFlatCoordinates_ = function (flatCoordinates, offset, end, stride) {\n var myBegin = this.coordinates.length;\n var myEnd = this.appendFlatLineCoordinates(flatCoordinates, offset, end, stride, false, false);\n var moveToLineToInstruction = [\n CanvasInstruction.MOVE_TO_LINE_TO,\n myBegin,\n myEnd,\n ];\n this.instructions.push(moveToLineToInstruction);\n this.hitDetectionInstructions.push(moveToLineToInstruction);\n return end;\n };\n /**\n * @param {import(\"../../geom/LineString.js\").default|import(\"../Feature.js\").default} lineStringGeometry Line string geometry.\n * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n */\n CanvasLineStringBuilder.prototype.drawLineString = function (lineStringGeometry, feature) {\n var state = this.state;\n var strokeStyle = state.strokeStyle;\n var lineWidth = state.lineWidth;\n if (strokeStyle === undefined || lineWidth === undefined) {\n return;\n }\n this.updateStrokeStyle(state, this.applyStroke);\n this.beginGeometry(lineStringGeometry, feature);\n this.hitDetectionInstructions.push([\n CanvasInstruction.SET_STROKE_STYLE,\n state.strokeStyle,\n state.lineWidth,\n state.lineCap,\n state.lineJoin,\n state.miterLimit,\n defaultLineDash,\n defaultLineDashOffset,\n ], beginPathInstruction);\n var flatCoordinates = lineStringGeometry.getFlatCoordinates();\n var stride = lineStringGeometry.getStride();\n this.drawFlatCoordinates_(flatCoordinates, 0, flatCoordinates.length, stride);\n this.hitDetectionInstructions.push(strokeInstruction);\n this.endGeometry(feature);\n };\n /**\n * @param {import(\"../../geom/MultiLineString.js\").default|import(\"../Feature.js\").default} multiLineStringGeometry MultiLineString geometry.\n * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n */\n CanvasLineStringBuilder.prototype.drawMultiLineString = function (multiLineStringGeometry, feature) {\n var state = this.state;\n var strokeStyle = state.strokeStyle;\n var lineWidth = state.lineWidth;\n if (strokeStyle === undefined || lineWidth === undefined) {\n return;\n }\n this.updateStrokeStyle(state, this.applyStroke);\n this.beginGeometry(multiLineStringGeometry, feature);\n this.hitDetectionInstructions.push([\n CanvasInstruction.SET_STROKE_STYLE,\n state.strokeStyle,\n state.lineWidth,\n state.lineCap,\n state.lineJoin,\n state.miterLimit,\n state.lineDash,\n state.lineDashOffset,\n ], beginPathInstruction);\n var ends = multiLineStringGeometry.getEnds();\n var flatCoordinates = multiLineStringGeometry.getFlatCoordinates();\n var stride = multiLineStringGeometry.getStride();\n var offset = 0;\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n offset = this.drawFlatCoordinates_(flatCoordinates, offset, \n /** @type {number} */ (ends[i]), stride);\n }\n this.hitDetectionInstructions.push(strokeInstruction);\n this.endGeometry(feature);\n };\n /**\n * @return {import(\"../canvas.js\").SerializableInstructions} the serializable instructions.\n */\n CanvasLineStringBuilder.prototype.finish = function () {\n var state = this.state;\n if (state.lastStroke != undefined &&\n state.lastStroke != this.coordinates.length) {\n this.instructions.push(strokeInstruction);\n }\n this.reverseHitDetectionInstructions();\n this.state = null;\n return _super.prototype.finish.call(this);\n };\n /**\n * @param {import(\"../canvas.js\").FillStrokeState} state State.\n */\n CanvasLineStringBuilder.prototype.applyStroke = function (state) {\n if (state.lastStroke != undefined &&\n state.lastStroke != this.coordinates.length) {\n this.instructions.push(strokeInstruction);\n state.lastStroke = this.coordinates.length;\n }\n state.lastStroke = 0;\n _super.prototype.applyStroke.call(this, state);\n this.instructions.push(beginPathInstruction);\n };\n return CanvasLineStringBuilder;\n}(CanvasBuilder));\nexport default CanvasLineStringBuilder;\n//# sourceMappingURL=LineStringBuilder.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/render/canvas/PolygonBuilder\n */\nimport CanvasBuilder from './Builder.js';\nimport CanvasInstruction, { beginPathInstruction, closePathInstruction, fillInstruction, strokeInstruction, } from './Instruction.js';\nimport { defaultFillStyle } from '../canvas.js';\nimport { snap } from '../../geom/flat/simplify.js';\nvar CanvasPolygonBuilder = /** @class */ (function (_super) {\n __extends(CanvasPolygonBuilder, _super);\n /**\n * @param {number} tolerance Tolerance.\n * @param {import(\"../../extent.js\").Extent} maxExtent Maximum extent.\n * @param {number} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n */\n function CanvasPolygonBuilder(tolerance, maxExtent, resolution, pixelRatio) {\n return _super.call(this, tolerance, maxExtent, resolution, pixelRatio) || this;\n }\n /**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @private\n * @return {number} End.\n */\n CanvasPolygonBuilder.prototype.drawFlatCoordinatess_ = function (flatCoordinates, offset, ends, stride) {\n var state = this.state;\n var fill = state.fillStyle !== undefined;\n var stroke = state.strokeStyle !== undefined;\n var numEnds = ends.length;\n this.instructions.push(beginPathInstruction);\n this.hitDetectionInstructions.push(beginPathInstruction);\n for (var i = 0; i < numEnds; ++i) {\n var end = ends[i];\n var myBegin = this.coordinates.length;\n var myEnd = this.appendFlatLineCoordinates(flatCoordinates, offset, end, stride, true, !stroke);\n var moveToLineToInstruction = [\n CanvasInstruction.MOVE_TO_LINE_TO,\n myBegin,\n myEnd,\n ];\n this.instructions.push(moveToLineToInstruction);\n this.hitDetectionInstructions.push(moveToLineToInstruction);\n if (stroke) {\n // Performance optimization: only call closePath() when we have a stroke.\n // Otherwise the ring is closed already (see appendFlatLineCoordinates above).\n this.instructions.push(closePathInstruction);\n this.hitDetectionInstructions.push(closePathInstruction);\n }\n offset = end;\n }\n if (fill) {\n this.instructions.push(fillInstruction);\n this.hitDetectionInstructions.push(fillInstruction);\n }\n if (stroke) {\n this.instructions.push(strokeInstruction);\n this.hitDetectionInstructions.push(strokeInstruction);\n }\n return offset;\n };\n /**\n * @param {import(\"../../geom/Circle.js\").default} circleGeometry Circle geometry.\n * @param {import(\"../../Feature.js\").default} feature Feature.\n */\n CanvasPolygonBuilder.prototype.drawCircle = function (circleGeometry, feature) {\n var state = this.state;\n var fillStyle = state.fillStyle;\n var strokeStyle = state.strokeStyle;\n if (fillStyle === undefined && strokeStyle === undefined) {\n return;\n }\n this.setFillStrokeStyles_();\n this.beginGeometry(circleGeometry, feature);\n if (state.fillStyle !== undefined) {\n this.hitDetectionInstructions.push([\n CanvasInstruction.SET_FILL_STYLE,\n defaultFillStyle,\n ]);\n }\n if (state.strokeStyle !== undefined) {\n this.hitDetectionInstructions.push([\n CanvasInstruction.SET_STROKE_STYLE,\n state.strokeStyle,\n state.lineWidth,\n state.lineCap,\n state.lineJoin,\n state.miterLimit,\n state.lineDash,\n state.lineDashOffset,\n ]);\n }\n var flatCoordinates = circleGeometry.getFlatCoordinates();\n var stride = circleGeometry.getStride();\n var myBegin = this.coordinates.length;\n this.appendFlatLineCoordinates(flatCoordinates, 0, flatCoordinates.length, stride, false, false);\n var circleInstruction = [CanvasInstruction.CIRCLE, myBegin];\n this.instructions.push(beginPathInstruction, circleInstruction);\n this.hitDetectionInstructions.push(beginPathInstruction, circleInstruction);\n if (state.fillStyle !== undefined) {\n this.instructions.push(fillInstruction);\n this.hitDetectionInstructions.push(fillInstruction);\n }\n if (state.strokeStyle !== undefined) {\n this.instructions.push(strokeInstruction);\n this.hitDetectionInstructions.push(strokeInstruction);\n }\n this.endGeometry(feature);\n };\n /**\n * @param {import(\"../../geom/Polygon.js\").default|import(\"../Feature.js\").default} polygonGeometry Polygon geometry.\n * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n */\n CanvasPolygonBuilder.prototype.drawPolygon = function (polygonGeometry, feature) {\n var state = this.state;\n var fillStyle = state.fillStyle;\n var strokeStyle = state.strokeStyle;\n if (fillStyle === undefined && strokeStyle === undefined) {\n return;\n }\n this.setFillStrokeStyles_();\n this.beginGeometry(polygonGeometry, feature);\n if (state.fillStyle !== undefined) {\n this.hitDetectionInstructions.push([\n CanvasInstruction.SET_FILL_STYLE,\n defaultFillStyle,\n ]);\n }\n if (state.strokeStyle !== undefined) {\n this.hitDetectionInstructions.push([\n CanvasInstruction.SET_STROKE_STYLE,\n state.strokeStyle,\n state.lineWidth,\n state.lineCap,\n state.lineJoin,\n state.miterLimit,\n state.lineDash,\n state.lineDashOffset,\n ]);\n }\n var ends = polygonGeometry.getEnds();\n var flatCoordinates = polygonGeometry.getOrientedFlatCoordinates();\n var stride = polygonGeometry.getStride();\n this.drawFlatCoordinatess_(flatCoordinates, 0, \n /** @type {Array<number>} */ (ends), stride);\n this.endGeometry(feature);\n };\n /**\n * @param {import(\"../../geom/MultiPolygon.js\").default} multiPolygonGeometry MultiPolygon geometry.\n * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n */\n CanvasPolygonBuilder.prototype.drawMultiPolygon = function (multiPolygonGeometry, feature) {\n var state = this.state;\n var fillStyle = state.fillStyle;\n var strokeStyle = state.strokeStyle;\n if (fillStyle === undefined && strokeStyle === undefined) {\n return;\n }\n this.setFillStrokeStyles_();\n this.beginGeometry(multiPolygonGeometry, feature);\n if (state.fillStyle !== undefined) {\n this.hitDetectionInstructions.push([\n CanvasInstruction.SET_FILL_STYLE,\n defaultFillStyle,\n ]);\n }\n if (state.strokeStyle !== undefined) {\n this.hitDetectionInstructions.push([\n CanvasInstruction.SET_STROKE_STYLE,\n state.strokeStyle,\n state.lineWidth,\n state.lineCap,\n state.lineJoin,\n state.miterLimit,\n state.lineDash,\n state.lineDashOffset,\n ]);\n }\n var endss = multiPolygonGeometry.getEndss();\n var flatCoordinates = multiPolygonGeometry.getOrientedFlatCoordinates();\n var stride = multiPolygonGeometry.getStride();\n var offset = 0;\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n offset = this.drawFlatCoordinatess_(flatCoordinates, offset, endss[i], stride);\n }\n this.endGeometry(feature);\n };\n /**\n * @return {import(\"../canvas.js\").SerializableInstructions} the serializable instructions.\n */\n CanvasPolygonBuilder.prototype.finish = function () {\n this.reverseHitDetectionInstructions();\n this.state = null;\n // We want to preserve topology when drawing polygons. Polygons are\n // simplified using quantization and point elimination. However, we might\n // have received a mix of quantized and non-quantized geometries, so ensure\n // that all are quantized by quantizing all coordinates in the batch.\n var tolerance = this.tolerance;\n if (tolerance !== 0) {\n var coordinates = this.coordinates;\n for (var i = 0, ii = coordinates.length; i < ii; ++i) {\n coordinates[i] = snap(coordinates[i], tolerance);\n }\n }\n return _super.prototype.finish.call(this);\n };\n /**\n * @private\n */\n CanvasPolygonBuilder.prototype.setFillStrokeStyles_ = function () {\n var state = this.state;\n var fillStyle = state.fillStyle;\n if (fillStyle !== undefined) {\n this.updateFillStyle(state, this.createFill);\n }\n if (state.strokeStyle !== undefined) {\n this.updateStrokeStyle(state, this.applyStroke);\n }\n };\n return CanvasPolygonBuilder;\n}(CanvasBuilder));\nexport default CanvasPolygonBuilder;\n//# sourceMappingURL=PolygonBuilder.js.map","/**\n * @module ol/geom/flat/straightchunk\n */\n/**\n * @param {number} maxAngle Maximum acceptable angle delta between segments.\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @return {Array<number>} Start and end of the first suitable chunk of the\n * given `flatCoordinates`.\n */\nexport function matchingChunk(maxAngle, flatCoordinates, offset, end, stride) {\n var chunkStart = offset;\n var chunkEnd = offset;\n var chunkM = 0;\n var m = 0;\n var start = offset;\n var acos, i, m12, m23, x1, y1, x12, y12, x23, y23;\n for (i = offset; i < end; i += stride) {\n var x2 = flatCoordinates[i];\n var y2 = flatCoordinates[i + 1];\n if (x1 !== undefined) {\n x23 = x2 - x1;\n y23 = y2 - y1;\n m23 = Math.sqrt(x23 * x23 + y23 * y23);\n if (x12 !== undefined) {\n m += m12;\n acos = Math.acos((x12 * x23 + y12 * y23) / (m12 * m23));\n if (acos > maxAngle) {\n if (m > chunkM) {\n chunkM = m;\n chunkStart = start;\n chunkEnd = i;\n }\n m = 0;\n start = i - stride;\n }\n }\n m12 = m23;\n x12 = x23;\n y12 = y23;\n }\n x1 = x2;\n y1 = y2;\n }\n m += m23;\n return m > chunkM ? [start, i] : [chunkStart, chunkEnd];\n}\n//# sourceMappingURL=straightchunk.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/render/canvas/TextBuilder\n */\nimport CanvasBuilder from './Builder.js';\nimport CanvasInstruction from './Instruction.js';\nimport GeometryType from '../../geom/GeometryType.js';\nimport TextPlacement from '../../style/TextPlacement.js';\nimport { asColorLike } from '../../colorlike.js';\nimport { defaultFillStyle, defaultFont, defaultLineCap, defaultLineDash, defaultLineDashOffset, defaultLineJoin, defaultLineWidth, defaultMiterLimit, defaultPadding, defaultStrokeStyle, defaultTextAlign, defaultTextBaseline, registerFont, } from '../canvas.js';\nimport { getUid } from '../../util.js';\nimport { intersects } from '../../extent.js';\nimport { matchingChunk } from '../../geom/flat/straightchunk.js';\n/**\n * @const\n * @enum {number}\n */\nexport var TEXT_ALIGN = {\n 'left': 0,\n 'end': 0,\n 'center': 0.5,\n 'right': 1,\n 'start': 1,\n 'top': 0,\n 'middle': 0.5,\n 'hanging': 0.2,\n 'alphabetic': 0.8,\n 'ideographic': 0.8,\n 'bottom': 1,\n};\nvar CanvasTextBuilder = /** @class */ (function (_super) {\n __extends(CanvasTextBuilder, _super);\n /**\n * @param {number} tolerance Tolerance.\n * @param {import(\"../../extent.js\").Extent} maxExtent Maximum extent.\n * @param {number} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n */\n function CanvasTextBuilder(tolerance, maxExtent, resolution, pixelRatio) {\n var _this = _super.call(this, tolerance, maxExtent, resolution, pixelRatio) || this;\n /**\n * @private\n * @type {Array<HTMLCanvasElement>}\n */\n _this.labels_ = null;\n /**\n * @private\n * @type {string}\n */\n _this.text_ = '';\n /**\n * @private\n * @type {number}\n */\n _this.textOffsetX_ = 0;\n /**\n * @private\n * @type {number}\n */\n _this.textOffsetY_ = 0;\n /**\n * @private\n * @type {boolean|undefined}\n */\n _this.textRotateWithView_ = undefined;\n /**\n * @private\n * @type {number}\n */\n _this.textRotation_ = 0;\n /**\n * @private\n * @type {?import(\"../canvas.js\").FillState}\n */\n _this.textFillState_ = null;\n /**\n * @type {!Object<string, import(\"../canvas.js\").FillState>}\n */\n _this.fillStates = {};\n /**\n * @private\n * @type {?import(\"../canvas.js\").StrokeState}\n */\n _this.textStrokeState_ = null;\n /**\n * @type {!Object<string, import(\"../canvas.js\").StrokeState>}\n */\n _this.strokeStates = {};\n /**\n * @private\n * @type {import(\"../canvas.js\").TextState}\n */\n _this.textState_ = /** @type {import(\"../canvas.js\").TextState} */ ({});\n /**\n * @type {!Object<string, import(\"../canvas.js\").TextState>}\n */\n _this.textStates = {};\n /**\n * @private\n * @type {string}\n */\n _this.textKey_ = '';\n /**\n * @private\n * @type {string}\n */\n _this.fillKey_ = '';\n /**\n * @private\n * @type {string}\n */\n _this.strokeKey_ = '';\n /**\n * Data shared with an image builder for combined decluttering.\n * @private\n * @type {import(\"../canvas.js\").DeclutterImageWithText}\n */\n _this.declutterImageWithText_ = undefined;\n return _this;\n }\n /**\n * @return {import(\"../canvas.js\").SerializableInstructions} the serializable instructions.\n */\n CanvasTextBuilder.prototype.finish = function () {\n var instructions = _super.prototype.finish.call(this);\n instructions.textStates = this.textStates;\n instructions.fillStates = this.fillStates;\n instructions.strokeStates = this.strokeStates;\n return instructions;\n };\n /**\n * @param {import(\"../../geom/SimpleGeometry.js\").default|import(\"../Feature.js\").default} geometry Geometry.\n * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n */\n CanvasTextBuilder.prototype.drawText = function (geometry, feature) {\n var fillState = this.textFillState_;\n var strokeState = this.textStrokeState_;\n var textState = this.textState_;\n if (this.text_ === '' || !textState || (!fillState && !strokeState)) {\n return;\n }\n var coordinates = this.coordinates;\n var begin = coordinates.length;\n var geometryType = geometry.getType();\n var flatCoordinates = null;\n var stride = geometry.getStride();\n if (textState.placement === TextPlacement.LINE &&\n (geometryType == GeometryType.LINE_STRING ||\n geometryType == GeometryType.MULTI_LINE_STRING ||\n geometryType == GeometryType.POLYGON ||\n geometryType == GeometryType.MULTI_POLYGON)) {\n if (!intersects(this.getBufferedMaxExtent(), geometry.getExtent())) {\n return;\n }\n var ends = void 0;\n flatCoordinates = geometry.getFlatCoordinates();\n if (geometryType == GeometryType.LINE_STRING) {\n ends = [flatCoordinates.length];\n }\n else if (geometryType == GeometryType.MULTI_LINE_STRING) {\n ends = /** @type {import(\"../../geom/MultiLineString.js\").default} */ (geometry).getEnds();\n }\n else if (geometryType == GeometryType.POLYGON) {\n ends = /** @type {import(\"../../geom/Polygon.js\").default} */ (geometry)\n .getEnds()\n .slice(0, 1);\n }\n else if (geometryType == GeometryType.MULTI_POLYGON) {\n var endss = \n /** @type {import(\"../../geom/MultiPolygon.js\").default} */ (geometry).getEndss();\n ends = [];\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n ends.push(endss[i][0]);\n }\n }\n this.beginGeometry(geometry, feature);\n var textAlign = textState.textAlign;\n var flatOffset = 0;\n var flatEnd = void 0;\n for (var o = 0, oo = ends.length; o < oo; ++o) {\n if (textAlign == undefined) {\n var range = matchingChunk(textState.maxAngle, flatCoordinates, flatOffset, ends[o], stride);\n flatOffset = range[0];\n flatEnd = range[1];\n }\n else {\n flatEnd = ends[o];\n }\n for (var i = flatOffset; i < flatEnd; i += stride) {\n coordinates.push(flatCoordinates[i], flatCoordinates[i + 1]);\n }\n var end = coordinates.length;\n flatOffset = ends[o];\n this.drawChars_(begin, end);\n begin = end;\n }\n this.endGeometry(feature);\n }\n else {\n var geometryWidths = textState.overflow ? null : [];\n switch (geometryType) {\n case GeometryType.POINT:\n case GeometryType.MULTI_POINT:\n flatCoordinates =\n /** @type {import(\"../../geom/MultiPoint.js\").default} */ (geometry).getFlatCoordinates();\n break;\n case GeometryType.LINE_STRING:\n flatCoordinates =\n /** @type {import(\"../../geom/LineString.js\").default} */ (geometry).getFlatMidpoint();\n break;\n case GeometryType.CIRCLE:\n flatCoordinates =\n /** @type {import(\"../../geom/Circle.js\").default} */ (geometry).getCenter();\n break;\n case GeometryType.MULTI_LINE_STRING:\n flatCoordinates =\n /** @type {import(\"../../geom/MultiLineString.js\").default} */ (geometry).getFlatMidpoints();\n stride = 2;\n break;\n case GeometryType.POLYGON:\n flatCoordinates =\n /** @type {import(\"../../geom/Polygon.js\").default} */ (geometry).getFlatInteriorPoint();\n if (!textState.overflow) {\n geometryWidths.push(flatCoordinates[2] / this.resolution);\n }\n stride = 3;\n break;\n case GeometryType.MULTI_POLYGON:\n var interiorPoints = \n /** @type {import(\"../../geom/MultiPolygon.js\").default} */ (geometry).getFlatInteriorPoints();\n flatCoordinates = [];\n for (var i = 0, ii = interiorPoints.length; i < ii; i += 3) {\n if (!textState.overflow) {\n geometryWidths.push(interiorPoints[i + 2] / this.resolution);\n }\n flatCoordinates.push(interiorPoints[i], interiorPoints[i + 1]);\n }\n if (flatCoordinates.length === 0) {\n return;\n }\n stride = 2;\n break;\n default:\n }\n var end = this.appendFlatPointCoordinates(flatCoordinates, stride);\n if (end === begin) {\n return;\n }\n if (geometryWidths &&\n (end - begin) / 2 !== flatCoordinates.length / stride) {\n var beg_1 = begin / 2;\n geometryWidths = geometryWidths.filter(function (w, i) {\n var keep = coordinates[(beg_1 + i) * 2] === flatCoordinates[i * stride] &&\n coordinates[(beg_1 + i) * 2 + 1] === flatCoordinates[i * stride + 1];\n if (!keep) {\n --beg_1;\n }\n return keep;\n });\n }\n this.saveTextStates_();\n if (textState.backgroundFill || textState.backgroundStroke) {\n this.setFillStrokeStyle(textState.backgroundFill, textState.backgroundStroke);\n if (textState.backgroundFill) {\n this.updateFillStyle(this.state, this.createFill);\n this.hitDetectionInstructions.push(this.createFill(this.state));\n }\n if (textState.backgroundStroke) {\n this.updateStrokeStyle(this.state, this.applyStroke);\n this.hitDetectionInstructions.push(this.createStroke(this.state));\n }\n }\n this.beginGeometry(geometry, feature);\n // adjust padding for negative scale\n var padding = textState.padding;\n if (padding != defaultPadding &&\n (textState.scale[0] < 0 || textState.scale[1] < 0)) {\n var p0 = textState.padding[0];\n var p1 = textState.padding[1];\n var p2 = textState.padding[2];\n var p3 = textState.padding[3];\n if (textState.scale[0] < 0) {\n p1 = -p1;\n p3 = -p3;\n }\n if (textState.scale[1] < 0) {\n p0 = -p0;\n p2 = -p2;\n }\n padding = [p0, p1, p2, p3];\n }\n // The image is unknown at this stage so we pass null; it will be computed at render time.\n // For clarity, we pass NaN for offsetX, offsetY, width and height, which will be computed at\n // render time.\n var pixelRatio_1 = this.pixelRatio;\n this.instructions.push([\n CanvasInstruction.DRAW_IMAGE,\n begin,\n end,\n null,\n NaN,\n NaN,\n NaN,\n 1,\n 0,\n 0,\n this.textRotateWithView_,\n this.textRotation_,\n [1, 1],\n NaN,\n this.declutterImageWithText_,\n padding == defaultPadding\n ? defaultPadding\n : padding.map(function (p) {\n return p * pixelRatio_1;\n }),\n !!textState.backgroundFill,\n !!textState.backgroundStroke,\n this.text_,\n this.textKey_,\n this.strokeKey_,\n this.fillKey_,\n this.textOffsetX_,\n this.textOffsetY_,\n geometryWidths,\n ]);\n var scale = 1 / pixelRatio_1;\n this.hitDetectionInstructions.push([\n CanvasInstruction.DRAW_IMAGE,\n begin,\n end,\n null,\n NaN,\n NaN,\n NaN,\n 1,\n 0,\n 0,\n this.textRotateWithView_,\n this.textRotation_,\n [scale, scale],\n NaN,\n this.declutterImageWithText_,\n padding,\n !!textState.backgroundFill,\n !!textState.backgroundStroke,\n this.text_,\n this.textKey_,\n this.strokeKey_,\n this.fillKey_,\n this.textOffsetX_,\n this.textOffsetY_,\n geometryWidths,\n ]);\n this.endGeometry(feature);\n }\n };\n /**\n * @private\n */\n CanvasTextBuilder.prototype.saveTextStates_ = function () {\n var strokeState = this.textStrokeState_;\n var textState = this.textState_;\n var fillState = this.textFillState_;\n var strokeKey = this.strokeKey_;\n if (strokeState) {\n if (!(strokeKey in this.strokeStates)) {\n this.strokeStates[strokeKey] = {\n strokeStyle: strokeState.strokeStyle,\n lineCap: strokeState.lineCap,\n lineDashOffset: strokeState.lineDashOffset,\n lineWidth: strokeState.lineWidth,\n lineJoin: strokeState.lineJoin,\n miterLimit: strokeState.miterLimit,\n lineDash: strokeState.lineDash,\n };\n }\n }\n var textKey = this.textKey_;\n if (!(textKey in this.textStates)) {\n this.textStates[textKey] = {\n font: textState.font,\n textAlign: textState.textAlign || defaultTextAlign,\n textBaseline: textState.textBaseline || defaultTextBaseline,\n scale: textState.scale,\n };\n }\n var fillKey = this.fillKey_;\n if (fillState) {\n if (!(fillKey in this.fillStates)) {\n this.fillStates[fillKey] = {\n fillStyle: fillState.fillStyle,\n };\n }\n }\n };\n /**\n * @private\n * @param {number} begin Begin.\n * @param {number} end End.\n */\n CanvasTextBuilder.prototype.drawChars_ = function (begin, end) {\n var strokeState = this.textStrokeState_;\n var textState = this.textState_;\n var strokeKey = this.strokeKey_;\n var textKey = this.textKey_;\n var fillKey = this.fillKey_;\n this.saveTextStates_();\n var pixelRatio = this.pixelRatio;\n var baseline = TEXT_ALIGN[textState.textBaseline];\n var offsetY = this.textOffsetY_ * pixelRatio;\n var text = this.text_;\n var strokeWidth = strokeState\n ? (strokeState.lineWidth * Math.abs(textState.scale[0])) / 2\n : 0;\n this.instructions.push([\n CanvasInstruction.DRAW_CHARS,\n begin,\n end,\n baseline,\n textState.overflow,\n fillKey,\n textState.maxAngle,\n pixelRatio,\n offsetY,\n strokeKey,\n strokeWidth * pixelRatio,\n text,\n textKey,\n 1,\n ]);\n this.hitDetectionInstructions.push([\n CanvasInstruction.DRAW_CHARS,\n begin,\n end,\n baseline,\n textState.overflow,\n fillKey,\n textState.maxAngle,\n 1,\n offsetY,\n strokeKey,\n strokeWidth,\n text,\n textKey,\n 1 / pixelRatio,\n ]);\n };\n /**\n * @param {import(\"../../style/Text.js\").default} textStyle Text style.\n * @param {Object} [opt_sharedData] Shared data.\n */\n CanvasTextBuilder.prototype.setTextStyle = function (textStyle, opt_sharedData) {\n var textState, fillState, strokeState;\n if (!textStyle) {\n this.text_ = '';\n }\n else {\n var textFillStyle = textStyle.getFill();\n if (!textFillStyle) {\n fillState = null;\n this.textFillState_ = fillState;\n }\n else {\n fillState = this.textFillState_;\n if (!fillState) {\n fillState = /** @type {import(\"../canvas.js\").FillState} */ ({});\n this.textFillState_ = fillState;\n }\n fillState.fillStyle = asColorLike(textFillStyle.getColor() || defaultFillStyle);\n }\n var textStrokeStyle = textStyle.getStroke();\n if (!textStrokeStyle) {\n strokeState = null;\n this.textStrokeState_ = strokeState;\n }\n else {\n strokeState = this.textStrokeState_;\n if (!strokeState) {\n strokeState = /** @type {import(\"../canvas.js\").StrokeState} */ ({});\n this.textStrokeState_ = strokeState;\n }\n var lineDash = textStrokeStyle.getLineDash();\n var lineDashOffset = textStrokeStyle.getLineDashOffset();\n var lineWidth = textStrokeStyle.getWidth();\n var miterLimit = textStrokeStyle.getMiterLimit();\n strokeState.lineCap = textStrokeStyle.getLineCap() || defaultLineCap;\n strokeState.lineDash = lineDash ? lineDash.slice() : defaultLineDash;\n strokeState.lineDashOffset =\n lineDashOffset === undefined ? defaultLineDashOffset : lineDashOffset;\n strokeState.lineJoin = textStrokeStyle.getLineJoin() || defaultLineJoin;\n strokeState.lineWidth =\n lineWidth === undefined ? defaultLineWidth : lineWidth;\n strokeState.miterLimit =\n miterLimit === undefined ? defaultMiterLimit : miterLimit;\n strokeState.strokeStyle = asColorLike(textStrokeStyle.getColor() || defaultStrokeStyle);\n }\n textState = this.textState_;\n var font = textStyle.getFont() || defaultFont;\n registerFont(font);\n var textScale = textStyle.getScaleArray();\n textState.overflow = textStyle.getOverflow();\n textState.font = font;\n textState.maxAngle = textStyle.getMaxAngle();\n textState.placement = textStyle.getPlacement();\n textState.textAlign = textStyle.getTextAlign();\n textState.textBaseline =\n textStyle.getTextBaseline() || defaultTextBaseline;\n textState.backgroundFill = textStyle.getBackgroundFill();\n textState.backgroundStroke = textStyle.getBackgroundStroke();\n textState.padding = textStyle.getPadding() || defaultPadding;\n textState.scale = textScale === undefined ? [1, 1] : textScale;\n var textOffsetX = textStyle.getOffsetX();\n var textOffsetY = textStyle.getOffsetY();\n var textRotateWithView = textStyle.getRotateWithView();\n var textRotation = textStyle.getRotation();\n this.text_ = textStyle.getText() || '';\n this.textOffsetX_ = textOffsetX === undefined ? 0 : textOffsetX;\n this.textOffsetY_ = textOffsetY === undefined ? 0 : textOffsetY;\n this.textRotateWithView_ =\n textRotateWithView === undefined ? false : textRotateWithView;\n this.textRotation_ = textRotation === undefined ? 0 : textRotation;\n this.strokeKey_ = strokeState\n ? (typeof strokeState.strokeStyle == 'string'\n ? strokeState.strokeStyle\n : getUid(strokeState.strokeStyle)) +\n strokeState.lineCap +\n strokeState.lineDashOffset +\n '|' +\n strokeState.lineWidth +\n strokeState.lineJoin +\n strokeState.miterLimit +\n '[' +\n strokeState.lineDash.join() +\n ']'\n : '';\n this.textKey_ =\n textState.font +\n textState.scale +\n (textState.textAlign || '?') +\n (textState.textBaseline || '?');\n this.fillKey_ = fillState\n ? typeof fillState.fillStyle == 'string'\n ? fillState.fillStyle\n : '|' + getUid(fillState.fillStyle)\n : '';\n }\n this.declutterImageWithText_ = opt_sharedData;\n };\n return CanvasTextBuilder;\n}(CanvasBuilder));\nexport default CanvasTextBuilder;\n//# sourceMappingURL=TextBuilder.js.map","/**\n * @module ol/style/TextPlacement\n */\n/**\n * Text placement. One of `'point'`, `'line'`. Default is `'point'`. Note that\n * `'line'` requires the underlying geometry to be a {@link module:ol/geom/LineString~LineString},\n * {@link module:ol/geom/Polygon~Polygon}, {@link module:ol/geom/MultiLineString~MultiLineString} or\n * {@link module:ol/geom/MultiPolygon~MultiPolygon}.\n * @enum {string}\n */\nexport default {\n POINT: 'point',\n LINE: 'line',\n};\n//# sourceMappingURL=TextPlacement.js.map","/**\n * @module ol/render/canvas/BuilderGroup\n */\nimport Builder from './Builder.js';\nimport ImageBuilder from './ImageBuilder.js';\nimport LineStringBuilder from './LineStringBuilder.js';\nimport PolygonBuilder from './PolygonBuilder.js';\nimport TextBuilder from './TextBuilder.js';\n/**\n * @type {Object<import(\"./BuilderType\").default, typeof Builder>}\n */\nvar BATCH_CONSTRUCTORS = {\n 'Circle': PolygonBuilder,\n 'Default': Builder,\n 'Image': ImageBuilder,\n 'LineString': LineStringBuilder,\n 'Polygon': PolygonBuilder,\n 'Text': TextBuilder,\n};\nvar BuilderGroup = /** @class */ (function () {\n /**\n * @param {number} tolerance Tolerance.\n * @param {import(\"../../extent.js\").Extent} maxExtent Max extent.\n * @param {number} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n */\n function BuilderGroup(tolerance, maxExtent, resolution, pixelRatio) {\n /**\n * @private\n * @type {number}\n */\n this.tolerance_ = tolerance;\n /**\n * @private\n * @type {import(\"../../extent.js\").Extent}\n */\n this.maxExtent_ = maxExtent;\n /**\n * @private\n * @type {number}\n */\n this.pixelRatio_ = pixelRatio;\n /**\n * @private\n * @type {number}\n */\n this.resolution_ = resolution;\n /**\n * @private\n * @type {!Object<string, !Object<import(\"./BuilderType\").default, Builder>>}\n */\n this.buildersByZIndex_ = {};\n }\n /**\n * @return {!Object<string, !Object<import(\"./BuilderType\").default, import(\"./Builder.js\").SerializableInstructions>>} The serializable instructions\n */\n BuilderGroup.prototype.finish = function () {\n var builderInstructions = {};\n for (var zKey in this.buildersByZIndex_) {\n builderInstructions[zKey] = builderInstructions[zKey] || {};\n var builders = this.buildersByZIndex_[zKey];\n for (var builderKey in builders) {\n var builderInstruction = builders[builderKey].finish();\n builderInstructions[zKey][builderKey] = builderInstruction;\n }\n }\n return builderInstructions;\n };\n /**\n * @param {number|undefined} zIndex Z index.\n * @param {import(\"./BuilderType.js\").default} builderType Replay type.\n * @return {import(\"../VectorContext.js\").default} Replay.\n */\n BuilderGroup.prototype.getBuilder = function (zIndex, builderType) {\n var zIndexKey = zIndex !== undefined ? zIndex.toString() : '0';\n var replays = this.buildersByZIndex_[zIndexKey];\n if (replays === undefined) {\n replays = {};\n this.buildersByZIndex_[zIndexKey] = replays;\n }\n var replay = replays[builderType];\n if (replay === undefined) {\n var Constructor = BATCH_CONSTRUCTORS[builderType];\n replay = new Constructor(this.tolerance_, this.maxExtent_, this.resolution_, this.pixelRatio_);\n replays[builderType] = replay;\n }\n return replay;\n };\n return BuilderGroup;\n}());\nexport default BuilderGroup;\n//# sourceMappingURL=BuilderGroup.js.map","/**\n * @module ol/render/canvas/BuilderType\n */\n/**\n * @enum {string}\n */\nexport default {\n CIRCLE: 'Circle',\n DEFAULT: 'Default',\n IMAGE: 'Image',\n LINE_STRING: 'LineString',\n POLYGON: 'Polygon',\n TEXT: 'Text',\n};\n//# sourceMappingURL=BuilderType.js.map","/**\n * @module ol/geom/flat/textpath\n */\nimport { lerp } from '../../math.js';\nimport { rotate } from './transform.js';\n/**\n * @param {Array<number>} flatCoordinates Path to put text on.\n * @param {number} offset Start offset of the `flatCoordinates`.\n * @param {number} end End offset of the `flatCoordinates`.\n * @param {number} stride Stride.\n * @param {string} text Text to place on the path.\n * @param {number} startM m along the path where the text starts.\n * @param {number} maxAngle Max angle between adjacent chars in radians.\n * @param {number} scale The product of the text scale and the device pixel ratio.\n * @param {function(string, string, Object<string, number>):number} measureAndCacheTextWidth Measure and cache text width.\n * @param {string} font The font.\n * @param {Object<string, number>} cache A cache of measured widths.\n * @param {number} rotation Rotation to apply to the flatCoordinates to determine whether text needs to be reversed.\n * @return {Array<Array<*>>} The result array (or null if `maxAngle` was\n * exceeded). Entries of the array are x, y, anchorX, angle, chunk.\n */\nexport function drawTextOnPath(flatCoordinates, offset, end, stride, text, startM, maxAngle, scale, measureAndCacheTextWidth, font, cache, rotation) {\n var x2 = flatCoordinates[offset];\n var y2 = flatCoordinates[offset + 1];\n var x1 = 0;\n var y1 = 0;\n var segmentLength = 0;\n var segmentM = 0;\n function advance() {\n x1 = x2;\n y1 = y2;\n offset += stride;\n x2 = flatCoordinates[offset];\n y2 = flatCoordinates[offset + 1];\n segmentM += segmentLength;\n segmentLength = Math.sqrt((x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1));\n }\n do {\n advance();\n } while (offset < end - stride && segmentM + segmentLength < startM);\n var interpolate = segmentLength === 0 ? 0 : (startM - segmentM) / segmentLength;\n var beginX = lerp(x1, x2, interpolate);\n var beginY = lerp(y1, y2, interpolate);\n var startOffset = offset - stride;\n var startLength = segmentM;\n var endM = startM + scale * measureAndCacheTextWidth(font, text, cache);\n while (offset < end - stride && segmentM + segmentLength < endM) {\n advance();\n }\n interpolate = segmentLength === 0 ? 0 : (endM - segmentM) / segmentLength;\n var endX = lerp(x1, x2, interpolate);\n var endY = lerp(y1, y2, interpolate);\n // Keep text upright\n var reverse;\n if (rotation) {\n var flat = [beginX, beginY, endX, endY];\n rotate(flat, 0, 4, 2, rotation, flat, flat);\n reverse = flat[0] > flat[2];\n }\n else {\n reverse = beginX > endX;\n }\n var PI = Math.PI;\n var result = [];\n var singleSegment = startOffset + stride === offset;\n offset = startOffset;\n segmentLength = 0;\n segmentM = startLength;\n x2 = flatCoordinates[offset];\n y2 = flatCoordinates[offset + 1];\n var previousAngle;\n // All on the same segment\n if (singleSegment) {\n advance();\n previousAngle = Math.atan2(y2 - y1, x2 - x1);\n if (reverse) {\n previousAngle += previousAngle > 0 ? -PI : PI;\n }\n var x = (endX + beginX) / 2;\n var y = (endY + beginY) / 2;\n result[0] = [x, y, (endM - startM) / 2, previousAngle, text];\n return result;\n }\n for (var i = 0, ii = text.length; i < ii;) {\n advance();\n var angle = Math.atan2(y2 - y1, x2 - x1);\n if (reverse) {\n angle += angle > 0 ? -PI : PI;\n }\n if (previousAngle !== undefined) {\n var delta = angle - previousAngle;\n delta += delta > PI ? -2 * PI : delta < -PI ? 2 * PI : 0;\n if (Math.abs(delta) > maxAngle) {\n return null;\n }\n }\n previousAngle = angle;\n var iStart = i;\n var charLength = 0;\n for (; i < ii; ++i) {\n var index = reverse ? ii - i - 1 : i;\n var len = scale * measureAndCacheTextWidth(font, text[index], cache);\n if (offset + stride < end &&\n segmentM + segmentLength < startM + charLength + len / 2) {\n break;\n }\n charLength += len;\n }\n if (i === iStart) {\n continue;\n }\n var chars = reverse\n ? text.substring(ii - iStart, ii - i)\n : text.substring(iStart, i);\n interpolate =\n segmentLength === 0\n ? 0\n : (startM + charLength / 2 - segmentM) / segmentLength;\n var x = lerp(x1, x2, interpolate);\n var y = lerp(y1, y2, interpolate);\n result.push([x, y, charLength / 2, angle, chars]);\n startM += charLength;\n }\n return result;\n}\n//# sourceMappingURL=textpath.js.map","/**\n * @module ol/render/canvas/Executor\n */\nimport CanvasInstruction from './Instruction.js';\nimport { TEXT_ALIGN } from './TextBuilder.js';\nimport { WORKER_OFFSCREEN_CANVAS } from '../../has.js';\nimport { apply as applyTransform, compose as composeTransform, create as createTransform, setFromArray as transformSetFromArray, } from '../../transform.js';\nimport { createEmpty, createOrUpdate, intersects } from '../../extent.js';\nimport { defaultPadding, defaultTextBaseline, drawImageOrLabel, } from '../canvas.js';\nimport { defaultTextAlign, measureAndCacheTextWidth, measureTextHeight, measureTextWidths, } from '../canvas.js';\nimport { drawTextOnPath } from '../../geom/flat/textpath.js';\nimport { equals } from '../../array.js';\nimport { lineStringLength } from '../../geom/flat/length.js';\nimport { transform2D } from '../../geom/flat/transform.js';\n/**\n * @typedef {Object} BBox\n * @property {number} minX Minimal x.\n * @property {number} minY Minimal y.\n * @property {number} maxX Maximal x.\n * @property {number} maxY Maximal y\n * @property {*} value Value.\n */\n/**\n * @typedef {Object} ImageOrLabelDimensions\n * @property {number} drawImageX DrawImageX.\n * @property {number} drawImageY DrawImageY.\n * @property {number} drawImageW DrawImageW.\n * @property {number} drawImageH DrawImageH.\n * @property {number} originX OriginX.\n * @property {number} originY OriginY.\n * @property {Array<number>} scale Scale.\n * @property {BBox} declutterBox DeclutterBox.\n * @property {import(\"../../transform.js\").Transform} canvasTransform CanvasTransform.\n */\n/**\n * @typedef {{0: CanvasRenderingContext2D, 1: number, 2: import(\"../canvas.js\").Label|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement, 3: ImageOrLabelDimensions, 4: number, 5: Array<*>, 6: Array<*>}} ReplayImageOrLabelArgs\n */\n/**\n * @template T\n * @typedef {function(import(\"../../Feature.js\").FeatureLike, import(\"../../geom/SimpleGeometry.js\").default): T} FeatureCallback\n */\n/**\n * @type {import(\"../../extent.js\").Extent}\n */\nvar tmpExtent = createEmpty();\n/** @type {import(\"../../coordinate.js\").Coordinate} */\nvar p1 = [];\n/** @type {import(\"../../coordinate.js\").Coordinate} */\nvar p2 = [];\n/** @type {import(\"../../coordinate.js\").Coordinate} */\nvar p3 = [];\n/** @type {import(\"../../coordinate.js\").Coordinate} */\nvar p4 = [];\n/**\n * @param {ReplayImageOrLabelArgs} replayImageOrLabelArgs Arguments to replayImageOrLabel\n * @return {BBox} Declutter bbox.\n */\nfunction getDeclutterBox(replayImageOrLabelArgs) {\n return replayImageOrLabelArgs[3].declutterBox;\n}\nvar rtlRegEx = new RegExp(\n/* eslint-disable prettier/prettier */\n'[' +\n String.fromCharCode(0x00591) + '-' + String.fromCharCode(0x008ff) +\n String.fromCharCode(0x0fb1d) + '-' + String.fromCharCode(0x0fdff) +\n String.fromCharCode(0x0fe70) + '-' + String.fromCharCode(0x0fefc) +\n String.fromCharCode(0x10800) + '-' + String.fromCharCode(0x10fff) +\n String.fromCharCode(0x1e800) + '-' + String.fromCharCode(0x1efff) +\n ']'\n/* eslint-enable prettier/prettier */\n);\n/**\n * @param {string} text Text.\n * @param {string} align Alignment.\n * @return {number} Text alignment.\n */\nfunction horizontalTextAlign(text, align) {\n if ((align === 'start' || align === 'end') && !rtlRegEx.test(text)) {\n align = align === 'start' ? 'left' : 'right';\n }\n return TEXT_ALIGN[align];\n}\nvar Executor = /** @class */ (function () {\n /**\n * @param {number} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n * @param {boolean} overlaps The replay can have overlapping geometries.\n * @param {import(\"../canvas.js\").SerializableInstructions} instructions The serializable instructions\n */\n function Executor(resolution, pixelRatio, overlaps, instructions) {\n /**\n * @protected\n * @type {boolean}\n */\n this.overlaps = overlaps;\n /**\n * @protected\n * @type {number}\n */\n this.pixelRatio = pixelRatio;\n /**\n * @protected\n * @const\n * @type {number}\n */\n this.resolution = resolution;\n /**\n * @private\n * @type {boolean}\n */\n this.alignFill_;\n /**\n * @protected\n * @type {Array<*>}\n */\n this.instructions = instructions.instructions;\n /**\n * @protected\n * @type {Array<number>}\n */\n this.coordinates = instructions.coordinates;\n /**\n * @private\n * @type {!Object<number,import(\"../../coordinate.js\").Coordinate|Array<import(\"../../coordinate.js\").Coordinate>|Array<Array<import(\"../../coordinate.js\").Coordinate>>>}\n */\n this.coordinateCache_ = {};\n /**\n * @private\n * @type {!import(\"../../transform.js\").Transform}\n */\n this.renderedTransform_ = createTransform();\n /**\n * @protected\n * @type {Array<*>}\n */\n this.hitDetectionInstructions = instructions.hitDetectionInstructions;\n /**\n * @private\n * @type {Array<number>}\n */\n this.pixelCoordinates_ = null;\n /**\n * @private\n * @type {number}\n */\n this.viewRotation_ = 0;\n /**\n * @type {!Object<string, import(\"../canvas.js\").FillState>}\n */\n this.fillStates = instructions.fillStates || {};\n /**\n * @type {!Object<string, import(\"../canvas.js\").StrokeState>}\n */\n this.strokeStates = instructions.strokeStates || {};\n /**\n * @type {!Object<string, import(\"../canvas.js\").TextState>}\n */\n this.textStates = instructions.textStates || {};\n /**\n * @private\n * @type {Object<string, Object<string, number>>}\n */\n this.widths_ = {};\n /**\n * @private\n * @type {Object<string, import(\"../canvas.js\").Label>}\n */\n this.labels_ = {};\n }\n /**\n * @param {string} text Text.\n * @param {string} textKey Text style key.\n * @param {string} fillKey Fill style key.\n * @param {string} strokeKey Stroke style key.\n * @return {import(\"../canvas.js\").Label} Label.\n */\n Executor.prototype.createLabel = function (text, textKey, fillKey, strokeKey) {\n var key = text + textKey + fillKey + strokeKey;\n if (this.labels_[key]) {\n return this.labels_[key];\n }\n var strokeState = strokeKey ? this.strokeStates[strokeKey] : null;\n var fillState = fillKey ? this.fillStates[fillKey] : null;\n var textState = this.textStates[textKey];\n var pixelRatio = this.pixelRatio;\n var scale = [\n textState.scale[0] * pixelRatio,\n textState.scale[1] * pixelRatio,\n ];\n var align = horizontalTextAlign(text, textState.textAlign || defaultTextAlign);\n var strokeWidth = strokeKey && strokeState.lineWidth ? strokeState.lineWidth : 0;\n var lines = text.split('\\n');\n var numLines = lines.length;\n var widths = [];\n var width = measureTextWidths(textState.font, lines, widths);\n var lineHeight = measureTextHeight(textState.font);\n var height = lineHeight * numLines;\n var renderWidth = width + strokeWidth;\n var contextInstructions = [];\n // make canvas 2 pixels wider to account for italic text width measurement errors\n var w = (renderWidth + 2) * scale[0];\n var h = (height + strokeWidth) * scale[1];\n /** @type {import(\"../canvas.js\").Label} */\n var label = {\n width: w < 0 ? Math.floor(w) : Math.ceil(w),\n height: h < 0 ? Math.floor(h) : Math.ceil(h),\n contextInstructions: contextInstructions,\n };\n if (scale[0] != 1 || scale[1] != 1) {\n contextInstructions.push('scale', scale);\n }\n contextInstructions.push('font', textState.font);\n if (strokeKey) {\n contextInstructions.push('strokeStyle', strokeState.strokeStyle);\n contextInstructions.push('lineWidth', strokeWidth);\n contextInstructions.push('lineCap', strokeState.lineCap);\n contextInstructions.push('lineJoin', strokeState.lineJoin);\n contextInstructions.push('miterLimit', strokeState.miterLimit);\n // eslint-disable-next-line\n var Context = WORKER_OFFSCREEN_CANVAS ? OffscreenCanvasRenderingContext2D : CanvasRenderingContext2D;\n if (Context.prototype.setLineDash) {\n contextInstructions.push('setLineDash', [strokeState.lineDash]);\n contextInstructions.push('lineDashOffset', strokeState.lineDashOffset);\n }\n }\n if (fillKey) {\n contextInstructions.push('fillStyle', fillState.fillStyle);\n }\n contextInstructions.push('textBaseline', 'middle');\n contextInstructions.push('textAlign', 'center');\n var leftRight = 0.5 - align;\n var x = align * renderWidth + leftRight * strokeWidth;\n var i;\n if (strokeKey) {\n for (i = 0; i < numLines; ++i) {\n contextInstructions.push('strokeText', [\n lines[i],\n x + leftRight * widths[i],\n 0.5 * (strokeWidth + lineHeight) + i * lineHeight,\n ]);\n }\n }\n if (fillKey) {\n for (i = 0; i < numLines; ++i) {\n contextInstructions.push('fillText', [\n lines[i],\n x + leftRight * widths[i],\n 0.5 * (strokeWidth + lineHeight) + i * lineHeight,\n ]);\n }\n }\n this.labels_[key] = label;\n return label;\n };\n /**\n * @param {CanvasRenderingContext2D} context Context.\n * @param {import(\"../../coordinate.js\").Coordinate} p1 1st point of the background box.\n * @param {import(\"../../coordinate.js\").Coordinate} p2 2nd point of the background box.\n * @param {import(\"../../coordinate.js\").Coordinate} p3 3rd point of the background box.\n * @param {import(\"../../coordinate.js\").Coordinate} p4 4th point of the background box.\n * @param {Array<*>} fillInstruction Fill instruction.\n * @param {Array<*>} strokeInstruction Stroke instruction.\n */\n Executor.prototype.replayTextBackground_ = function (context, p1, p2, p3, p4, fillInstruction, strokeInstruction) {\n context.beginPath();\n context.moveTo.apply(context, p1);\n context.lineTo.apply(context, p2);\n context.lineTo.apply(context, p3);\n context.lineTo.apply(context, p4);\n context.lineTo.apply(context, p1);\n if (fillInstruction) {\n this.alignFill_ = /** @type {boolean} */ (fillInstruction[2]);\n this.fill_(context);\n }\n if (strokeInstruction) {\n this.setStrokeStyle_(context, \n /** @type {Array<*>} */ (strokeInstruction));\n context.stroke();\n }\n };\n /**\n * @private\n * @param {number} sheetWidth Width of the sprite sheet.\n * @param {number} sheetHeight Height of the sprite sheet.\n * @param {number} centerX X.\n * @param {number} centerY Y.\n * @param {number} width Width.\n * @param {number} height Height.\n * @param {number} anchorX Anchor X.\n * @param {number} anchorY Anchor Y.\n * @param {number} originX Origin X.\n * @param {number} originY Origin Y.\n * @param {number} rotation Rotation.\n * @param {import(\"../../size.js\").Size} scale Scale.\n * @param {boolean} snapToPixel Snap to pixel.\n * @param {Array<number>} padding Padding.\n * @param {boolean} fillStroke Background fill or stroke.\n * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n * @return {ImageOrLabelDimensions} Dimensions for positioning and decluttering the image or label.\n */\n Executor.prototype.calculateImageOrLabelDimensions_ = function (sheetWidth, sheetHeight, centerX, centerY, width, height, anchorX, anchorY, originX, originY, rotation, scale, snapToPixel, padding, fillStroke, feature) {\n anchorX *= scale[0];\n anchorY *= scale[1];\n var x = centerX - anchorX;\n var y = centerY - anchorY;\n var w = width + originX > sheetWidth ? sheetWidth - originX : width;\n var h = height + originY > sheetHeight ? sheetHeight - originY : height;\n var boxW = padding[3] + w * scale[0] + padding[1];\n var boxH = padding[0] + h * scale[1] + padding[2];\n var boxX = x - padding[3];\n var boxY = y - padding[0];\n if (fillStroke || rotation !== 0) {\n p1[0] = boxX;\n p4[0] = boxX;\n p1[1] = boxY;\n p2[1] = boxY;\n p2[0] = boxX + boxW;\n p3[0] = p2[0];\n p3[1] = boxY + boxH;\n p4[1] = p3[1];\n }\n var transform;\n if (rotation !== 0) {\n transform = composeTransform(createTransform(), centerX, centerY, 1, 1, rotation, -centerX, -centerY);\n applyTransform(transform, p1);\n applyTransform(transform, p2);\n applyTransform(transform, p3);\n applyTransform(transform, p4);\n createOrUpdate(Math.min(p1[0], p2[0], p3[0], p4[0]), Math.min(p1[1], p2[1], p3[1], p4[1]), Math.max(p1[0], p2[0], p3[0], p4[0]), Math.max(p1[1], p2[1], p3[1], p4[1]), tmpExtent);\n }\n else {\n createOrUpdate(Math.min(boxX, boxX + boxW), Math.min(boxY, boxY + boxH), Math.max(boxX, boxX + boxW), Math.max(boxY, boxY + boxH), tmpExtent);\n }\n if (snapToPixel) {\n x = Math.round(x);\n y = Math.round(y);\n }\n return {\n drawImageX: x,\n drawImageY: y,\n drawImageW: w,\n drawImageH: h,\n originX: originX,\n originY: originY,\n declutterBox: {\n minX: tmpExtent[0],\n minY: tmpExtent[1],\n maxX: tmpExtent[2],\n maxY: tmpExtent[3],\n value: feature,\n },\n canvasTransform: transform,\n scale: scale,\n };\n };\n /**\n * @private\n * @param {CanvasRenderingContext2D} context Context.\n * @param {number} contextScale Scale of the context.\n * @param {import(\"../canvas.js\").Label|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement} imageOrLabel Image.\n * @param {ImageOrLabelDimensions} dimensions Dimensions.\n * @param {number} opacity Opacity.\n * @param {Array<*>} fillInstruction Fill instruction.\n * @param {Array<*>} strokeInstruction Stroke instruction.\n * @return {boolean} The image or label was rendered.\n */\n Executor.prototype.replayImageOrLabel_ = function (context, contextScale, imageOrLabel, dimensions, opacity, fillInstruction, strokeInstruction) {\n var fillStroke = !!(fillInstruction || strokeInstruction);\n var box = dimensions.declutterBox;\n var canvas = context.canvas;\n var strokePadding = strokeInstruction\n ? (strokeInstruction[2] * dimensions.scale[0]) / 2\n : 0;\n var intersects = box.minX - strokePadding <= canvas.width / contextScale &&\n box.maxX + strokePadding >= 0 &&\n box.minY - strokePadding <= canvas.height / contextScale &&\n box.maxY + strokePadding >= 0;\n if (intersects) {\n if (fillStroke) {\n this.replayTextBackground_(context, p1, p2, p3, p4, \n /** @type {Array<*>} */ (fillInstruction), \n /** @type {Array<*>} */ (strokeInstruction));\n }\n drawImageOrLabel(context, dimensions.canvasTransform, opacity, imageOrLabel, dimensions.originX, dimensions.originY, dimensions.drawImageW, dimensions.drawImageH, dimensions.drawImageX, dimensions.drawImageY, dimensions.scale);\n }\n return true;\n };\n /**\n * @private\n * @param {CanvasRenderingContext2D} context Context.\n */\n Executor.prototype.fill_ = function (context) {\n if (this.alignFill_) {\n var origin_1 = applyTransform(this.renderedTransform_, [0, 0]);\n var repeatSize = 512 * this.pixelRatio;\n context.save();\n context.translate(origin_1[0] % repeatSize, origin_1[1] % repeatSize);\n context.rotate(this.viewRotation_);\n }\n context.fill();\n if (this.alignFill_) {\n context.restore();\n }\n };\n /**\n * @private\n * @param {CanvasRenderingContext2D} context Context.\n * @param {Array<*>} instruction Instruction.\n */\n Executor.prototype.setStrokeStyle_ = function (context, instruction) {\n context['strokeStyle'] =\n /** @type {import(\"../../colorlike.js\").ColorLike} */ (instruction[1]);\n context.lineWidth = /** @type {number} */ (instruction[2]);\n context.lineCap = /** @type {CanvasLineCap} */ (instruction[3]);\n context.lineJoin = /** @type {CanvasLineJoin} */ (instruction[4]);\n context.miterLimit = /** @type {number} */ (instruction[5]);\n if (context.setLineDash) {\n context.lineDashOffset = /** @type {number} */ (instruction[7]);\n context.setLineDash(/** @type {Array<number>} */ (instruction[6]));\n }\n };\n /**\n * @private\n * @param {string} text The text to draw.\n * @param {string} textKey The key of the text state.\n * @param {string} strokeKey The key for the stroke state.\n * @param {string} fillKey The key for the fill state.\n * @return {{label: import(\"../canvas.js\").Label, anchorX: number, anchorY: number}} The text image and its anchor.\n */\n Executor.prototype.drawLabelWithPointPlacement_ = function (text, textKey, strokeKey, fillKey) {\n var textState = this.textStates[textKey];\n var label = this.createLabel(text, textKey, fillKey, strokeKey);\n var strokeState = this.strokeStates[strokeKey];\n var pixelRatio = this.pixelRatio;\n var align = horizontalTextAlign(text, textState.textAlign || defaultTextAlign);\n var baseline = TEXT_ALIGN[textState.textBaseline || defaultTextBaseline];\n var strokeWidth = strokeState && strokeState.lineWidth ? strokeState.lineWidth : 0;\n // Remove the 2 pixels we added in createLabel() for the anchor\n var width = label.width / pixelRatio - 2 * textState.scale[0];\n var anchorX = align * width + 2 * (0.5 - align) * strokeWidth;\n var anchorY = (baseline * label.height) / pixelRatio +\n 2 * (0.5 - baseline) * strokeWidth;\n return {\n label: label,\n anchorX: anchorX,\n anchorY: anchorY,\n };\n };\n /**\n * @private\n * @param {CanvasRenderingContext2D} context Context.\n * @param {number} contextScale Scale of the context.\n * @param {import(\"../../transform.js\").Transform} transform Transform.\n * @param {Array<*>} instructions Instructions array.\n * @param {boolean} snapToPixel Snap point symbols and text to integer pixels.\n * @param {FeatureCallback<T>} [opt_featureCallback] Feature callback.\n * @param {import(\"../../extent.js\").Extent} [opt_hitExtent] Only check\n * features that intersect this extent.\n * @param {import(\"rbush\").default} [opt_declutterTree] Declutter tree.\n * @return {T|undefined} Callback result.\n * @template T\n */\n Executor.prototype.execute_ = function (context, contextScale, transform, instructions, snapToPixel, opt_featureCallback, opt_hitExtent, opt_declutterTree) {\n /** @type {Array<number>} */\n var pixelCoordinates;\n if (this.pixelCoordinates_ && equals(transform, this.renderedTransform_)) {\n pixelCoordinates = this.pixelCoordinates_;\n }\n else {\n if (!this.pixelCoordinates_) {\n this.pixelCoordinates_ = [];\n }\n pixelCoordinates = transform2D(this.coordinates, 0, this.coordinates.length, 2, transform, this.pixelCoordinates_);\n transformSetFromArray(this.renderedTransform_, transform);\n }\n var i = 0; // instruction index\n var ii = instructions.length; // end of instructions\n var d = 0; // data index\n var dd; // end of per-instruction data\n var anchorX, anchorY, prevX, prevY, roundX, roundY, image, text, textKey, strokeKey, fillKey;\n var pendingFill = 0;\n var pendingStroke = 0;\n var lastFillInstruction = null;\n var lastStrokeInstruction = null;\n var coordinateCache = this.coordinateCache_;\n var viewRotation = this.viewRotation_;\n var viewRotationFromTransform = Math.round(Math.atan2(-transform[1], transform[0]) * 1e12) / 1e12;\n var state = /** @type {import(\"../../render.js\").State} */ ({\n context: context,\n pixelRatio: this.pixelRatio,\n resolution: this.resolution,\n rotation: viewRotation,\n });\n // When the batch size gets too big, performance decreases. 200 is a good\n // balance between batch size and number of fill/stroke instructions.\n var batchSize = this.instructions != instructions || this.overlaps ? 0 : 200;\n var /** @type {import(\"../../Feature.js\").FeatureLike} */ feature;\n var x, y, currentGeometry;\n while (i < ii) {\n var instruction = instructions[i];\n var type = /** @type {import(\"./Instruction.js\").default} */ (instruction[0]);\n switch (type) {\n case CanvasInstruction.BEGIN_GEOMETRY:\n feature = /** @type {import(\"../../Feature.js\").FeatureLike} */ (instruction[1]);\n currentGeometry = instruction[3];\n if (!feature.getGeometry()) {\n i = /** @type {number} */ (instruction[2]);\n }\n else if (opt_hitExtent !== undefined &&\n !intersects(opt_hitExtent, currentGeometry.getExtent())) {\n i = /** @type {number} */ (instruction[2]) + 1;\n }\n else {\n ++i;\n }\n break;\n case CanvasInstruction.BEGIN_PATH:\n if (pendingFill > batchSize) {\n this.fill_(context);\n pendingFill = 0;\n }\n if (pendingStroke > batchSize) {\n context.stroke();\n pendingStroke = 0;\n }\n if (!pendingFill && !pendingStroke) {\n context.beginPath();\n prevX = NaN;\n prevY = NaN;\n }\n ++i;\n break;\n case CanvasInstruction.CIRCLE:\n d = /** @type {number} */ (instruction[1]);\n var x1 = pixelCoordinates[d];\n var y1 = pixelCoordinates[d + 1];\n var x2 = pixelCoordinates[d + 2];\n var y2 = pixelCoordinates[d + 3];\n var dx = x2 - x1;\n var dy = y2 - y1;\n var r = Math.sqrt(dx * dx + dy * dy);\n context.moveTo(x1 + r, y1);\n context.arc(x1, y1, r, 0, 2 * Math.PI, true);\n ++i;\n break;\n case CanvasInstruction.CLOSE_PATH:\n context.closePath();\n ++i;\n break;\n case CanvasInstruction.CUSTOM:\n d = /** @type {number} */ (instruction[1]);\n dd = instruction[2];\n var geometry = \n /** @type {import(\"../../geom/SimpleGeometry.js\").default} */ (instruction[3]);\n var renderer = instruction[4];\n var fn = instruction.length == 6 ? instruction[5] : undefined;\n state.geometry = geometry;\n state.feature = feature;\n if (!(i in coordinateCache)) {\n coordinateCache[i] = [];\n }\n var coords = coordinateCache[i];\n if (fn) {\n fn(pixelCoordinates, d, dd, 2, coords);\n }\n else {\n coords[0] = pixelCoordinates[d];\n coords[1] = pixelCoordinates[d + 1];\n coords.length = 2;\n }\n renderer(coords, state);\n ++i;\n break;\n case CanvasInstruction.DRAW_IMAGE:\n d = /** @type {number} */ (instruction[1]);\n dd = /** @type {number} */ (instruction[2]);\n image =\n /** @type {HTMLCanvasElement|HTMLVideoElement|HTMLImageElement} */ (instruction[3]);\n // Remaining arguments in DRAW_IMAGE are in alphabetical order\n anchorX = /** @type {number} */ (instruction[4]);\n anchorY = /** @type {number} */ (instruction[5]);\n var height = /** @type {number} */ (instruction[6]);\n var opacity = /** @type {number} */ (instruction[7]);\n var originX = /** @type {number} */ (instruction[8]);\n var originY = /** @type {number} */ (instruction[9]);\n var rotateWithView = /** @type {boolean} */ (instruction[10]);\n var rotation = /** @type {number} */ (instruction[11]);\n var scale = /** @type {import(\"../../size.js\").Size} */ (instruction[12]);\n var width = /** @type {number} */ (instruction[13]);\n var declutterImageWithText = \n /** @type {import(\"../canvas.js\").DeclutterImageWithText} */ (instruction[14]);\n if (!image && instruction.length >= 19) {\n // create label images\n text = /** @type {string} */ (instruction[18]);\n textKey = /** @type {string} */ (instruction[19]);\n strokeKey = /** @type {string} */ (instruction[20]);\n fillKey = /** @type {string} */ (instruction[21]);\n var labelWithAnchor = this.drawLabelWithPointPlacement_(text, textKey, strokeKey, fillKey);\n image = labelWithAnchor.label;\n instruction[3] = image;\n var textOffsetX = /** @type {number} */ (instruction[22]);\n anchorX = (labelWithAnchor.anchorX - textOffsetX) * this.pixelRatio;\n instruction[4] = anchorX;\n var textOffsetY = /** @type {number} */ (instruction[23]);\n anchorY = (labelWithAnchor.anchorY - textOffsetY) * this.pixelRatio;\n instruction[5] = anchorY;\n height = image.height;\n instruction[6] = height;\n width = image.width;\n instruction[13] = width;\n }\n var geometryWidths = void 0;\n if (instruction.length > 24) {\n geometryWidths = /** @type {number} */ (instruction[24]);\n }\n var padding = void 0, backgroundFill = void 0, backgroundStroke = void 0;\n if (instruction.length > 16) {\n padding = /** @type {Array<number>} */ (instruction[15]);\n backgroundFill = /** @type {boolean} */ (instruction[16]);\n backgroundStroke = /** @type {boolean} */ (instruction[17]);\n }\n else {\n padding = defaultPadding;\n backgroundFill = false;\n backgroundStroke = false;\n }\n if (rotateWithView && viewRotationFromTransform) {\n // Canvas is expected to be rotated to reverse view rotation.\n rotation += viewRotation;\n }\n else if (!rotateWithView && !viewRotationFromTransform) {\n // Canvas is not rotated, images need to be rotated back to be north-up.\n rotation -= viewRotation;\n }\n var widthIndex = 0;\n for (; d < dd; d += 2) {\n if (geometryWidths &&\n geometryWidths[widthIndex++] < width / this.pixelRatio) {\n continue;\n }\n var dimensions = this.calculateImageOrLabelDimensions_(image.width, image.height, pixelCoordinates[d], pixelCoordinates[d + 1], width, height, anchorX, anchorY, originX, originY, rotation, scale, snapToPixel, padding, backgroundFill || backgroundStroke, feature);\n /** @type {ReplayImageOrLabelArgs} */\n var args = [\n context,\n contextScale,\n image,\n dimensions,\n opacity,\n backgroundFill\n ? /** @type {Array<*>} */ (lastFillInstruction)\n : null,\n backgroundStroke\n ? /** @type {Array<*>} */ (lastStrokeInstruction)\n : null,\n ];\n var imageArgs = void 0;\n var imageDeclutterBox = void 0;\n if (opt_declutterTree && declutterImageWithText) {\n var index = dd - d;\n if (!declutterImageWithText[index]) {\n // We now have the image for an image+text combination.\n declutterImageWithText[index] = args;\n // Don't render anything for now, wait for the text.\n continue;\n }\n imageArgs = declutterImageWithText[index];\n delete declutterImageWithText[index];\n imageDeclutterBox = getDeclutterBox(imageArgs);\n if (opt_declutterTree.collides(imageDeclutterBox)) {\n continue;\n }\n }\n if (opt_declutterTree &&\n opt_declutterTree.collides(dimensions.declutterBox)) {\n continue;\n }\n if (imageArgs) {\n // We now have image and text for an image+text combination.\n if (opt_declutterTree) {\n opt_declutterTree.insert(imageDeclutterBox);\n }\n // Render the image before we render the text.\n this.replayImageOrLabel_.apply(this, imageArgs);\n }\n if (opt_declutterTree) {\n opt_declutterTree.insert(dimensions.declutterBox);\n }\n this.replayImageOrLabel_.apply(this, args);\n }\n ++i;\n break;\n case CanvasInstruction.DRAW_CHARS:\n var begin = /** @type {number} */ (instruction[1]);\n var end = /** @type {number} */ (instruction[2]);\n var baseline = /** @type {number} */ (instruction[3]);\n var overflow = /** @type {number} */ (instruction[4]);\n fillKey = /** @type {string} */ (instruction[5]);\n var maxAngle = /** @type {number} */ (instruction[6]);\n var measurePixelRatio = /** @type {number} */ (instruction[7]);\n var offsetY = /** @type {number} */ (instruction[8]);\n strokeKey = /** @type {string} */ (instruction[9]);\n var strokeWidth = /** @type {number} */ (instruction[10]);\n text = /** @type {string} */ (instruction[11]);\n textKey = /** @type {string} */ (instruction[12]);\n var pixelRatioScale = [\n /** @type {number} */ (instruction[13]),\n /** @type {number} */ (instruction[13]),\n ];\n var textState = this.textStates[textKey];\n var font = textState.font;\n var textScale = [\n textState.scale[0] * measurePixelRatio,\n textState.scale[1] * measurePixelRatio,\n ];\n var cachedWidths = void 0;\n if (font in this.widths_) {\n cachedWidths = this.widths_[font];\n }\n else {\n cachedWidths = {};\n this.widths_[font] = cachedWidths;\n }\n var pathLength = lineStringLength(pixelCoordinates, begin, end, 2);\n var textLength = Math.abs(textScale[0]) *\n measureAndCacheTextWidth(font, text, cachedWidths);\n if (overflow || textLength <= pathLength) {\n var textAlign = this.textStates[textKey].textAlign;\n var startM = (pathLength - textLength) * TEXT_ALIGN[textAlign];\n var parts = drawTextOnPath(pixelCoordinates, begin, end, 2, text, startM, maxAngle, Math.abs(textScale[0]), measureAndCacheTextWidth, font, cachedWidths, viewRotationFromTransform ? 0 : this.viewRotation_);\n drawChars: if (parts) {\n /** @type {Array<ReplayImageOrLabelArgs>} */\n var replayImageOrLabelArgs = [];\n var c = void 0, cc = void 0, chars = void 0, label = void 0, part = void 0;\n if (strokeKey) {\n for (c = 0, cc = parts.length; c < cc; ++c) {\n part = parts[c]; // x, y, anchorX, rotation, chunk\n chars = /** @type {string} */ (part[4]);\n label = this.createLabel(chars, textKey, '', strokeKey);\n anchorX =\n /** @type {number} */ (part[2]) +\n (textScale[0] < 0 ? -strokeWidth : strokeWidth);\n anchorY =\n baseline * label.height +\n ((0.5 - baseline) * 2 * strokeWidth * textScale[1]) /\n textScale[0] -\n offsetY;\n var dimensions = this.calculateImageOrLabelDimensions_(label.width, label.height, part[0], part[1], label.width, label.height, anchorX, anchorY, 0, 0, part[3], pixelRatioScale, false, defaultPadding, false, feature);\n if (opt_declutterTree &&\n opt_declutterTree.collides(dimensions.declutterBox)) {\n break drawChars;\n }\n replayImageOrLabelArgs.push([\n context,\n contextScale,\n label,\n dimensions,\n 1,\n null,\n null,\n ]);\n }\n }\n if (fillKey) {\n for (c = 0, cc = parts.length; c < cc; ++c) {\n part = parts[c]; // x, y, anchorX, rotation, chunk\n chars = /** @type {string} */ (part[4]);\n label = this.createLabel(chars, textKey, fillKey, '');\n anchorX = /** @type {number} */ (part[2]);\n anchorY = baseline * label.height - offsetY;\n var dimensions = this.calculateImageOrLabelDimensions_(label.width, label.height, part[0], part[1], label.width, label.height, anchorX, anchorY, 0, 0, part[3], pixelRatioScale, false, defaultPadding, false, feature);\n if (opt_declutterTree &&\n opt_declutterTree.collides(dimensions.declutterBox)) {\n break drawChars;\n }\n replayImageOrLabelArgs.push([\n context,\n contextScale,\n label,\n dimensions,\n 1,\n null,\n null,\n ]);\n }\n }\n if (opt_declutterTree) {\n opt_declutterTree.load(replayImageOrLabelArgs.map(getDeclutterBox));\n }\n for (var i_1 = 0, ii_1 = replayImageOrLabelArgs.length; i_1 < ii_1; ++i_1) {\n this.replayImageOrLabel_.apply(this, replayImageOrLabelArgs[i_1]);\n }\n }\n }\n ++i;\n break;\n case CanvasInstruction.END_GEOMETRY:\n if (opt_featureCallback !== undefined) {\n feature = /** @type {import(\"../../Feature.js\").FeatureLike} */ (instruction[1]);\n var result = opt_featureCallback(feature, currentGeometry);\n if (result) {\n return result;\n }\n }\n ++i;\n break;\n case CanvasInstruction.FILL:\n if (batchSize) {\n pendingFill++;\n }\n else {\n this.fill_(context);\n }\n ++i;\n break;\n case CanvasInstruction.MOVE_TO_LINE_TO:\n d = /** @type {number} */ (instruction[1]);\n dd = /** @type {number} */ (instruction[2]);\n x = pixelCoordinates[d];\n y = pixelCoordinates[d + 1];\n roundX = (x + 0.5) | 0;\n roundY = (y + 0.5) | 0;\n if (roundX !== prevX || roundY !== prevY) {\n context.moveTo(x, y);\n prevX = roundX;\n prevY = roundY;\n }\n for (d += 2; d < dd; d += 2) {\n x = pixelCoordinates[d];\n y = pixelCoordinates[d + 1];\n roundX = (x + 0.5) | 0;\n roundY = (y + 0.5) | 0;\n if (d == dd - 2 || roundX !== prevX || roundY !== prevY) {\n context.lineTo(x, y);\n prevX = roundX;\n prevY = roundY;\n }\n }\n ++i;\n break;\n case CanvasInstruction.SET_FILL_STYLE:\n lastFillInstruction = instruction;\n this.alignFill_ = instruction[2];\n if (pendingFill) {\n this.fill_(context);\n pendingFill = 0;\n if (pendingStroke) {\n context.stroke();\n pendingStroke = 0;\n }\n }\n context.fillStyle =\n /** @type {import(\"../../colorlike.js\").ColorLike} */ (instruction[1]);\n ++i;\n break;\n case CanvasInstruction.SET_STROKE_STYLE:\n lastStrokeInstruction = instruction;\n if (pendingStroke) {\n context.stroke();\n pendingStroke = 0;\n }\n this.setStrokeStyle_(context, /** @type {Array<*>} */ (instruction));\n ++i;\n break;\n case CanvasInstruction.STROKE:\n if (batchSize) {\n pendingStroke++;\n }\n else {\n context.stroke();\n }\n ++i;\n break;\n default:\n ++i; // consume the instruction anyway, to avoid an infinite loop\n break;\n }\n }\n if (pendingFill) {\n this.fill_(context);\n }\n if (pendingStroke) {\n context.stroke();\n }\n return undefined;\n };\n /**\n * @param {CanvasRenderingContext2D} context Context.\n * @param {number} contextScale Scale of the context.\n * @param {import(\"../../transform.js\").Transform} transform Transform.\n * @param {number} viewRotation View rotation.\n * @param {boolean} snapToPixel Snap point symbols and text to integer pixels.\n * @param {import(\"rbush\").default} [opt_declutterTree] Declutter tree.\n */\n Executor.prototype.execute = function (context, contextScale, transform, viewRotation, snapToPixel, opt_declutterTree) {\n this.viewRotation_ = viewRotation;\n this.execute_(context, contextScale, transform, this.instructions, snapToPixel, undefined, undefined, opt_declutterTree);\n };\n /**\n * @param {CanvasRenderingContext2D} context Context.\n * @param {import(\"../../transform.js\").Transform} transform Transform.\n * @param {number} viewRotation View rotation.\n * @param {FeatureCallback<T>} [opt_featureCallback] Feature callback.\n * @param {import(\"../../extent.js\").Extent} [opt_hitExtent] Only check\n * features that intersect this extent.\n * @return {T|undefined} Callback result.\n * @template T\n */\n Executor.prototype.executeHitDetection = function (context, transform, viewRotation, opt_featureCallback, opt_hitExtent) {\n this.viewRotation_ = viewRotation;\n return this.execute_(context, 1, transform, this.hitDetectionInstructions, true, opt_featureCallback, opt_hitExtent);\n };\n return Executor;\n}());\nexport default Executor;\n//# sourceMappingURL=Executor.js.map","/**\n * @module ol/render/canvas/ExecutorGroup\n */\nimport BuilderType from './BuilderType.js';\nimport Executor from './Executor.js';\nimport { buffer, createEmpty, extendCoordinate } from '../../extent.js';\nimport { compose as composeTransform, create as createTransform, } from '../../transform.js';\nimport { createCanvasContext2D } from '../../dom.js';\nimport { isEmpty } from '../../obj.js';\nimport { numberSafeCompareFunction } from '../../array.js';\nimport { transform2D } from '../../geom/flat/transform.js';\n/**\n * @const\n * @type {Array<import(\"./BuilderType.js\").default>}\n */\nvar ORDER = [\n BuilderType.POLYGON,\n BuilderType.CIRCLE,\n BuilderType.LINE_STRING,\n BuilderType.IMAGE,\n BuilderType.TEXT,\n BuilderType.DEFAULT,\n];\nvar ExecutorGroup = /** @class */ (function () {\n /**\n * @param {import(\"../../extent.js\").Extent} maxExtent Max extent for clipping. When a\n * `maxExtent` was set on the Builder for this executor group, the same `maxExtent`\n * should be set here, unless the target context does not exceed that extent (which\n * can be the case when rendering to tiles).\n * @param {number} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n * @param {boolean} overlaps The executor group can have overlapping geometries.\n * @param {!Object<string, !Object<import(\"./BuilderType.js\").default, import(\"../canvas.js\").SerializableInstructions>>} allInstructions\n * The serializable instructions.\n * @param {number} [opt_renderBuffer] Optional rendering buffer.\n */\n function ExecutorGroup(maxExtent, resolution, pixelRatio, overlaps, allInstructions, opt_renderBuffer) {\n /**\n * @private\n * @type {import(\"../../extent.js\").Extent}\n */\n this.maxExtent_ = maxExtent;\n /**\n * @private\n * @type {boolean}\n */\n this.overlaps_ = overlaps;\n /**\n * @private\n * @type {number}\n */\n this.pixelRatio_ = pixelRatio;\n /**\n * @private\n * @type {number}\n */\n this.resolution_ = resolution;\n /**\n * @private\n * @type {number|undefined}\n */\n this.renderBuffer_ = opt_renderBuffer;\n /**\n * @private\n * @type {!Object<string, !Object<import(\"./BuilderType.js\").default, import(\"./Executor\").default>>}\n */\n this.executorsByZIndex_ = {};\n /**\n * @private\n * @type {CanvasRenderingContext2D}\n */\n this.hitDetectionContext_ = null;\n /**\n * @private\n * @type {import(\"../../transform.js\").Transform}\n */\n this.hitDetectionTransform_ = createTransform();\n this.createExecutors_(allInstructions);\n }\n /**\n * @param {CanvasRenderingContext2D} context Context.\n * @param {import(\"../../transform.js\").Transform} transform Transform.\n */\n ExecutorGroup.prototype.clip = function (context, transform) {\n var flatClipCoords = this.getClipCoords(transform);\n context.beginPath();\n context.moveTo(flatClipCoords[0], flatClipCoords[1]);\n context.lineTo(flatClipCoords[2], flatClipCoords[3]);\n context.lineTo(flatClipCoords[4], flatClipCoords[5]);\n context.lineTo(flatClipCoords[6], flatClipCoords[7]);\n context.clip();\n };\n /**\n * Create executors and populate them using the provided instructions.\n * @private\n * @param {!Object<string, !Object<import(\"./BuilderType.js\").default, import(\"../canvas.js\").SerializableInstructions>>} allInstructions The serializable instructions\n */\n ExecutorGroup.prototype.createExecutors_ = function (allInstructions) {\n for (var zIndex in allInstructions) {\n var executors = this.executorsByZIndex_[zIndex];\n if (executors === undefined) {\n executors = {};\n this.executorsByZIndex_[zIndex] = executors;\n }\n var instructionByZindex = allInstructions[zIndex];\n for (var builderType in instructionByZindex) {\n var instructions = instructionByZindex[builderType];\n executors[builderType] = new Executor(this.resolution_, this.pixelRatio_, this.overlaps_, instructions);\n }\n }\n };\n /**\n * @param {Array<import(\"./BuilderType.js\").default>} executors Executors.\n * @return {boolean} Has executors of the provided types.\n */\n ExecutorGroup.prototype.hasExecutors = function (executors) {\n for (var zIndex in this.executorsByZIndex_) {\n var candidates = this.executorsByZIndex_[zIndex];\n for (var i = 0, ii = executors.length; i < ii; ++i) {\n if (executors[i] in candidates) {\n return true;\n }\n }\n }\n return false;\n };\n /**\n * @param {import(\"../../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {number} resolution Resolution.\n * @param {number} rotation Rotation.\n * @param {number} hitTolerance Hit tolerance in pixels.\n * @param {function(import(\"../../Feature.js\").FeatureLike, import(\"../../geom/SimpleGeometry.js\").default, number): T} callback Feature callback.\n * @param {Array<import(\"../../Feature.js\").FeatureLike>} declutteredFeatures Decluttered features.\n * @return {T|undefined} Callback result.\n * @template T\n */\n ExecutorGroup.prototype.forEachFeatureAtCoordinate = function (coordinate, resolution, rotation, hitTolerance, callback, declutteredFeatures) {\n hitTolerance = Math.round(hitTolerance);\n var contextSize = hitTolerance * 2 + 1;\n var transform = composeTransform(this.hitDetectionTransform_, hitTolerance + 0.5, hitTolerance + 0.5, 1 / resolution, -1 / resolution, -rotation, -coordinate[0], -coordinate[1]);\n var newContext = !this.hitDetectionContext_;\n if (newContext) {\n this.hitDetectionContext_ = createCanvasContext2D(contextSize, contextSize);\n }\n var context = this.hitDetectionContext_;\n if (context.canvas.width !== contextSize ||\n context.canvas.height !== contextSize) {\n context.canvas.width = contextSize;\n context.canvas.height = contextSize;\n }\n else if (!newContext) {\n context.clearRect(0, 0, contextSize, contextSize);\n }\n /**\n * @type {import(\"../../extent.js\").Extent}\n */\n var hitExtent;\n if (this.renderBuffer_ !== undefined) {\n hitExtent = createEmpty();\n extendCoordinate(hitExtent, coordinate);\n buffer(hitExtent, resolution * (this.renderBuffer_ + hitTolerance), hitExtent);\n }\n var indexes = getPixelIndexArray(hitTolerance);\n var builderType;\n /**\n * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n * @param {import(\"../../geom/SimpleGeometry.js\").default} geometry Geometry.\n * @return {T|undefined} Callback result.\n */\n function featureCallback(feature, geometry) {\n var imageData = context.getImageData(0, 0, contextSize, contextSize).data;\n for (var i_1 = 0, ii = indexes.length; i_1 < ii; i_1++) {\n if (imageData[indexes[i_1]] > 0) {\n if (!declutteredFeatures ||\n (builderType !== BuilderType.IMAGE &&\n builderType !== BuilderType.TEXT) ||\n declutteredFeatures.indexOf(feature) !== -1) {\n var idx = (indexes[i_1] - 3) / 4;\n var x = hitTolerance - (idx % contextSize);\n var y = hitTolerance - ((idx / contextSize) | 0);\n var result_1 = callback(feature, geometry, x * x + y * y);\n if (result_1) {\n return result_1;\n }\n }\n context.clearRect(0, 0, contextSize, contextSize);\n break;\n }\n }\n return undefined;\n }\n /** @type {Array<number>} */\n var zs = Object.keys(this.executorsByZIndex_).map(Number);\n zs.sort(numberSafeCompareFunction);\n var i, j, executors, executor, result;\n for (i = zs.length - 1; i >= 0; --i) {\n var zIndexKey = zs[i].toString();\n executors = this.executorsByZIndex_[zIndexKey];\n for (j = ORDER.length - 1; j >= 0; --j) {\n builderType = ORDER[j];\n executor = executors[builderType];\n if (executor !== undefined) {\n result = executor.executeHitDetection(context, transform, rotation, featureCallback, hitExtent);\n if (result) {\n return result;\n }\n }\n }\n }\n return undefined;\n };\n /**\n * @param {import(\"../../transform.js\").Transform} transform Transform.\n * @return {Array<number>} Clip coordinates.\n */\n ExecutorGroup.prototype.getClipCoords = function (transform) {\n var maxExtent = this.maxExtent_;\n if (!maxExtent) {\n return null;\n }\n var minX = maxExtent[0];\n var minY = maxExtent[1];\n var maxX = maxExtent[2];\n var maxY = maxExtent[3];\n var flatClipCoords = [minX, minY, minX, maxY, maxX, maxY, maxX, minY];\n transform2D(flatClipCoords, 0, 8, 2, transform, flatClipCoords);\n return flatClipCoords;\n };\n /**\n * @return {boolean} Is empty.\n */\n ExecutorGroup.prototype.isEmpty = function () {\n return isEmpty(this.executorsByZIndex_);\n };\n /**\n * @param {CanvasRenderingContext2D} context Context.\n * @param {number} contextScale Scale of the context.\n * @param {import(\"../../transform.js\").Transform} transform Transform.\n * @param {number} viewRotation View rotation.\n * @param {boolean} snapToPixel Snap point symbols and test to integer pixel.\n * @param {Array<import(\"./BuilderType.js\").default>} [opt_builderTypes] Ordered replay types to replay.\n * Default is {@link module:ol/render/replay~ORDER}\n * @param {import(\"rbush\").default} [opt_declutterTree] Declutter tree.\n */\n ExecutorGroup.prototype.execute = function (context, contextScale, transform, viewRotation, snapToPixel, opt_builderTypes, opt_declutterTree) {\n /** @type {Array<number>} */\n var zs = Object.keys(this.executorsByZIndex_).map(Number);\n zs.sort(numberSafeCompareFunction);\n // setup clipping so that the parts of over-simplified geometries are not\n // visible outside the current extent when panning\n if (this.maxExtent_) {\n context.save();\n this.clip(context, transform);\n }\n var builderTypes = opt_builderTypes ? opt_builderTypes : ORDER;\n var i, ii, j, jj, replays, replay;\n if (opt_declutterTree) {\n zs.reverse();\n }\n for (i = 0, ii = zs.length; i < ii; ++i) {\n var zIndexKey = zs[i].toString();\n replays = this.executorsByZIndex_[zIndexKey];\n for (j = 0, jj = builderTypes.length; j < jj; ++j) {\n var builderType = builderTypes[j];\n replay = replays[builderType];\n if (replay !== undefined) {\n replay.execute(context, contextScale, transform, viewRotation, snapToPixel, opt_declutterTree);\n }\n }\n }\n if (this.maxExtent_) {\n context.restore();\n }\n };\n return ExecutorGroup;\n}());\n/**\n * This cache is used to store arrays of indexes for calculated pixel circles\n * to increase performance.\n * It is a static property to allow each Replaygroup to access it.\n * @type {Object<number, Array<number>>}\n */\nvar circlePixelIndexArrayCache = {};\n/**\n * This methods creates an array with indexes of all pixels within a circle,\n * ordered by how close they are to the center.\n * A cache is used to increase performance.\n * @param {number} radius Radius.\n * @return {Array<number>} An array with indexes within a circle.\n */\nexport function getPixelIndexArray(radius) {\n if (circlePixelIndexArrayCache[radius] !== undefined) {\n return circlePixelIndexArrayCache[radius];\n }\n var size = radius * 2 + 1;\n var maxDistanceSq = radius * radius;\n var distances = new Array(maxDistanceSq + 1);\n for (var i = 0; i <= radius; ++i) {\n for (var j = 0; j <= radius; ++j) {\n var distanceSq = i * i + j * j;\n if (distanceSq > maxDistanceSq) {\n break;\n }\n var distance = distances[distanceSq];\n if (!distance) {\n distance = [];\n distances[distanceSq] = distance;\n }\n distance.push(((radius + i) * size + (radius + j)) * 4 + 3);\n if (i > 0) {\n distance.push(((radius - i) * size + (radius + j)) * 4 + 3);\n }\n if (j > 0) {\n distance.push(((radius + i) * size + (radius - j)) * 4 + 3);\n if (i > 0) {\n distance.push(((radius - i) * size + (radius - j)) * 4 + 3);\n }\n }\n }\n }\n var pixelIndex = [];\n for (var i = 0, ii = distances.length; i < ii; ++i) {\n if (distances[i]) {\n pixelIndex.push.apply(pixelIndex, distances[i]);\n }\n }\n circlePixelIndexArrayCache[radius] = pixelIndex;\n return pixelIndex;\n}\nexport default ExecutorGroup;\n//# sourceMappingURL=ExecutorGroup.js.map","/**\n * @module ol/render/canvas/Immediate\n */\n// FIXME test, especially polygons with holes and multipolygons\n// FIXME need to handle large thick features (where pixel size matters)\n// FIXME add offset and end to ol/geom/flat/transform~transform2D?\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport GeometryType from '../../geom/GeometryType.js';\nimport VectorContext from '../VectorContext.js';\nimport { asColorLike } from '../../colorlike.js';\nimport { compose as composeTransform, create as createTransform, } from '../../transform.js';\nimport { defaultFillStyle, defaultFont, defaultLineCap, defaultLineDash, defaultLineDashOffset, defaultLineJoin, defaultLineWidth, defaultMiterLimit, defaultStrokeStyle, defaultTextAlign, defaultTextBaseline, } from '../canvas.js';\nimport { equals } from '../../array.js';\nimport { intersects } from '../../extent.js';\nimport { transform2D } from '../../geom/flat/transform.js';\nimport { transformGeom2D } from '../../geom/SimpleGeometry.js';\n/**\n * @classdesc\n * A concrete subclass of {@link module:ol/render/VectorContext VectorContext} that implements\n * direct rendering of features and geometries to an HTML5 Canvas context.\n * Instances of this class are created internally by the library and\n * provided to application code as vectorContext member of the\n * {@link module:ol/render/Event~RenderEvent RenderEvent} object associated with postcompose, precompose and\n * render events emitted by layers and maps.\n */\nvar CanvasImmediateRenderer = /** @class */ (function (_super) {\n __extends(CanvasImmediateRenderer, _super);\n /**\n * @param {CanvasRenderingContext2D} context Context.\n * @param {number} pixelRatio Pixel ratio.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @param {import(\"../../transform.js\").Transform} transform Transform.\n * @param {number} viewRotation View rotation.\n * @param {number} [opt_squaredTolerance] Optional squared tolerance for simplification.\n * @param {import(\"../../proj.js\").TransformFunction} [opt_userTransform] Transform from user to view projection.\n */\n function CanvasImmediateRenderer(context, pixelRatio, extent, transform, viewRotation, opt_squaredTolerance, opt_userTransform) {\n var _this = _super.call(this) || this;\n /**\n * @private\n * @type {CanvasRenderingContext2D}\n */\n _this.context_ = context;\n /**\n * @private\n * @type {number}\n */\n _this.pixelRatio_ = pixelRatio;\n /**\n * @private\n * @type {import(\"../../extent.js\").Extent}\n */\n _this.extent_ = extent;\n /**\n * @private\n * @type {import(\"../../transform.js\").Transform}\n */\n _this.transform_ = transform;\n /**\n * @private\n * @type {number}\n */\n _this.viewRotation_ = viewRotation;\n /**\n * @private\n * @type {number}\n */\n _this.squaredTolerance_ = opt_squaredTolerance;\n /**\n * @private\n * @type {import(\"../../proj.js\").TransformFunction}\n */\n _this.userTransform_ = opt_userTransform;\n /**\n * @private\n * @type {?import(\"../canvas.js\").FillState}\n */\n _this.contextFillState_ = null;\n /**\n * @private\n * @type {?import(\"../canvas.js\").StrokeState}\n */\n _this.contextStrokeState_ = null;\n /**\n * @private\n * @type {?import(\"../canvas.js\").TextState}\n */\n _this.contextTextState_ = null;\n /**\n * @private\n * @type {?import(\"../canvas.js\").FillState}\n */\n _this.fillState_ = null;\n /**\n * @private\n * @type {?import(\"../canvas.js\").StrokeState}\n */\n _this.strokeState_ = null;\n /**\n * @private\n * @type {HTMLCanvasElement|HTMLVideoElement|HTMLImageElement}\n */\n _this.image_ = null;\n /**\n * @private\n * @type {number}\n */\n _this.imageAnchorX_ = 0;\n /**\n * @private\n * @type {number}\n */\n _this.imageAnchorY_ = 0;\n /**\n * @private\n * @type {number}\n */\n _this.imageHeight_ = 0;\n /**\n * @private\n * @type {number}\n */\n _this.imageOpacity_ = 0;\n /**\n * @private\n * @type {number}\n */\n _this.imageOriginX_ = 0;\n /**\n * @private\n * @type {number}\n */\n _this.imageOriginY_ = 0;\n /**\n * @private\n * @type {boolean}\n */\n _this.imageRotateWithView_ = false;\n /**\n * @private\n * @type {number}\n */\n _this.imageRotation_ = 0;\n /**\n * @private\n * @type {import(\"../../size.js\").Size}\n */\n _this.imageScale_ = [0, 0];\n /**\n * @private\n * @type {number}\n */\n _this.imageWidth_ = 0;\n /**\n * @private\n * @type {string}\n */\n _this.text_ = '';\n /**\n * @private\n * @type {number}\n */\n _this.textOffsetX_ = 0;\n /**\n * @private\n * @type {number}\n */\n _this.textOffsetY_ = 0;\n /**\n * @private\n * @type {boolean}\n */\n _this.textRotateWithView_ = false;\n /**\n * @private\n * @type {number}\n */\n _this.textRotation_ = 0;\n /**\n * @private\n * @type {import(\"../../size.js\").Size}\n */\n _this.textScale_ = [0, 0];\n /**\n * @private\n * @type {?import(\"../canvas.js\").FillState}\n */\n _this.textFillState_ = null;\n /**\n * @private\n * @type {?import(\"../canvas.js\").StrokeState}\n */\n _this.textStrokeState_ = null;\n /**\n * @private\n * @type {?import(\"../canvas.js\").TextState}\n */\n _this.textState_ = null;\n /**\n * @private\n * @type {Array<number>}\n */\n _this.pixelCoordinates_ = [];\n /**\n * @private\n * @type {import(\"../../transform.js\").Transform}\n */\n _this.tmpLocalTransform_ = createTransform();\n return _this;\n }\n /**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @private\n */\n CanvasImmediateRenderer.prototype.drawImages_ = function (flatCoordinates, offset, end, stride) {\n if (!this.image_) {\n return;\n }\n var pixelCoordinates = transform2D(flatCoordinates, offset, end, stride, this.transform_, this.pixelCoordinates_);\n var context = this.context_;\n var localTransform = this.tmpLocalTransform_;\n var alpha = context.globalAlpha;\n if (this.imageOpacity_ != 1) {\n context.globalAlpha = alpha * this.imageOpacity_;\n }\n var rotation = this.imageRotation_;\n if (this.imageRotateWithView_) {\n rotation += this.viewRotation_;\n }\n for (var i = 0, ii = pixelCoordinates.length; i < ii; i += 2) {\n var x = pixelCoordinates[i] - this.imageAnchorX_;\n var y = pixelCoordinates[i + 1] - this.imageAnchorY_;\n if (rotation !== 0 ||\n this.imageScale_[0] != 1 ||\n this.imageScale_[1] != 1) {\n var centerX = x + this.imageAnchorX_;\n var centerY = y + this.imageAnchorY_;\n composeTransform(localTransform, centerX, centerY, 1, 1, rotation, -centerX, -centerY);\n context.setTransform.apply(context, localTransform);\n context.translate(centerX, centerY);\n context.scale(this.imageScale_[0], this.imageScale_[1]);\n context.drawImage(this.image_, this.imageOriginX_, this.imageOriginY_, this.imageWidth_, this.imageHeight_, -this.imageAnchorX_, -this.imageAnchorY_, this.imageWidth_, this.imageHeight_);\n context.setTransform(1, 0, 0, 1, 0, 0);\n }\n else {\n context.drawImage(this.image_, this.imageOriginX_, this.imageOriginY_, this.imageWidth_, this.imageHeight_, x, y, this.imageWidth_, this.imageHeight_);\n }\n }\n if (this.imageOpacity_ != 1) {\n context.globalAlpha = alpha;\n }\n };\n /**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @private\n */\n CanvasImmediateRenderer.prototype.drawText_ = function (flatCoordinates, offset, end, stride) {\n if (!this.textState_ || this.text_ === '') {\n return;\n }\n if (this.textFillState_) {\n this.setContextFillState_(this.textFillState_);\n }\n if (this.textStrokeState_) {\n this.setContextStrokeState_(this.textStrokeState_);\n }\n this.setContextTextState_(this.textState_);\n var pixelCoordinates = transform2D(flatCoordinates, offset, end, stride, this.transform_, this.pixelCoordinates_);\n var context = this.context_;\n var rotation = this.textRotation_;\n if (this.textRotateWithView_) {\n rotation += this.viewRotation_;\n }\n for (; offset < end; offset += stride) {\n var x = pixelCoordinates[offset] + this.textOffsetX_;\n var y = pixelCoordinates[offset + 1] + this.textOffsetY_;\n if (rotation !== 0 ||\n this.textScale_[0] != 1 ||\n this.textScale_[1] != 1) {\n var localTransform = composeTransform(this.tmpLocalTransform_, x, y, 1, 1, rotation, -x, -y);\n context.setTransform.apply(context, localTransform);\n context.translate(x, y);\n context.scale(this.textScale_[0], this.textScale_[1]);\n if (this.textStrokeState_) {\n context.strokeText(this.text_, 0, 0);\n }\n if (this.textFillState_) {\n context.fillText(this.text_, 0, 0);\n }\n context.setTransform(1, 0, 0, 1, 0, 0);\n }\n else {\n if (this.textStrokeState_) {\n context.strokeText(this.text_, x, y);\n }\n if (this.textFillState_) {\n context.fillText(this.text_, x, y);\n }\n }\n }\n };\n /**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {boolean} close Close.\n * @private\n * @return {number} end End.\n */\n CanvasImmediateRenderer.prototype.moveToLineTo_ = function (flatCoordinates, offset, end, stride, close) {\n var context = this.context_;\n var pixelCoordinates = transform2D(flatCoordinates, offset, end, stride, this.transform_, this.pixelCoordinates_);\n context.moveTo(pixelCoordinates[0], pixelCoordinates[1]);\n var length = pixelCoordinates.length;\n if (close) {\n length -= 2;\n }\n for (var i = 2; i < length; i += 2) {\n context.lineTo(pixelCoordinates[i], pixelCoordinates[i + 1]);\n }\n if (close) {\n context.closePath();\n }\n return end;\n };\n /**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @private\n * @return {number} End.\n */\n CanvasImmediateRenderer.prototype.drawRings_ = function (flatCoordinates, offset, ends, stride) {\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n offset = this.moveToLineTo_(flatCoordinates, offset, ends[i], stride, true);\n }\n return offset;\n };\n /**\n * Render a circle geometry into the canvas. Rendering is immediate and uses\n * the current fill and stroke styles.\n *\n * @param {import(\"../../geom/Circle.js\").default} geometry Circle geometry.\n * @api\n */\n CanvasImmediateRenderer.prototype.drawCircle = function (geometry) {\n if (!intersects(this.extent_, geometry.getExtent())) {\n return;\n }\n if (this.fillState_ || this.strokeState_) {\n if (this.fillState_) {\n this.setContextFillState_(this.fillState_);\n }\n if (this.strokeState_) {\n this.setContextStrokeState_(this.strokeState_);\n }\n var pixelCoordinates = transformGeom2D(geometry, this.transform_, this.pixelCoordinates_);\n var dx = pixelCoordinates[2] - pixelCoordinates[0];\n var dy = pixelCoordinates[3] - pixelCoordinates[1];\n var radius = Math.sqrt(dx * dx + dy * dy);\n var context = this.context_;\n context.beginPath();\n context.arc(pixelCoordinates[0], pixelCoordinates[1], radius, 0, 2 * Math.PI);\n if (this.fillState_) {\n context.fill();\n }\n if (this.strokeState_) {\n context.stroke();\n }\n }\n if (this.text_ !== '') {\n this.drawText_(geometry.getCenter(), 0, 2, 2);\n }\n };\n /**\n * Set the rendering style. Note that since this is an immediate rendering API,\n * any `zIndex` on the provided style will be ignored.\n *\n * @param {import(\"../../style/Style.js\").default} style The rendering style.\n * @api\n */\n CanvasImmediateRenderer.prototype.setStyle = function (style) {\n this.setFillStrokeStyle(style.getFill(), style.getStroke());\n this.setImageStyle(style.getImage());\n this.setTextStyle(style.getText());\n };\n /**\n * @param {import(\"../../transform.js\").Transform} transform Transform.\n */\n CanvasImmediateRenderer.prototype.setTransform = function (transform) {\n this.transform_ = transform;\n };\n /**\n * Render a geometry into the canvas. Call\n * {@link module:ol/render/canvas/Immediate~CanvasImmediateRenderer#setStyle renderer.setStyle()} first to set the rendering style.\n *\n * @param {import(\"../../geom/Geometry.js\").default|import(\"../Feature.js\").default} geometry The geometry to render.\n * @api\n */\n CanvasImmediateRenderer.prototype.drawGeometry = function (geometry) {\n var type = geometry.getType();\n switch (type) {\n case GeometryType.POINT:\n this.drawPoint(\n /** @type {import(\"../../geom/Point.js\").default} */ (geometry));\n break;\n case GeometryType.LINE_STRING:\n this.drawLineString(\n /** @type {import(\"../../geom/LineString.js\").default} */ (geometry));\n break;\n case GeometryType.POLYGON:\n this.drawPolygon(\n /** @type {import(\"../../geom/Polygon.js\").default} */ (geometry));\n break;\n case GeometryType.MULTI_POINT:\n this.drawMultiPoint(\n /** @type {import(\"../../geom/MultiPoint.js\").default} */ (geometry));\n break;\n case GeometryType.MULTI_LINE_STRING:\n this.drawMultiLineString(\n /** @type {import(\"../../geom/MultiLineString.js\").default} */ (geometry));\n break;\n case GeometryType.MULTI_POLYGON:\n this.drawMultiPolygon(\n /** @type {import(\"../../geom/MultiPolygon.js\").default} */ (geometry));\n break;\n case GeometryType.GEOMETRY_COLLECTION:\n this.drawGeometryCollection(\n /** @type {import(\"../../geom/GeometryCollection.js\").default} */ (geometry));\n break;\n case GeometryType.CIRCLE:\n this.drawCircle(\n /** @type {import(\"../../geom/Circle.js\").default} */ (geometry));\n break;\n default:\n }\n };\n /**\n * Render a feature into the canvas. Note that any `zIndex` on the provided\n * style will be ignored - features are rendered immediately in the order that\n * this method is called. If you need `zIndex` support, you should be using an\n * {@link module:ol/layer/Vector~VectorLayer VectorLayer} instead.\n *\n * @param {import(\"../../Feature.js\").default} feature Feature.\n * @param {import(\"../../style/Style.js\").default} style Style.\n * @api\n */\n CanvasImmediateRenderer.prototype.drawFeature = function (feature, style) {\n var geometry = style.getGeometryFunction()(feature);\n if (!geometry || !intersects(this.extent_, geometry.getExtent())) {\n return;\n }\n this.setStyle(style);\n this.drawGeometry(geometry);\n };\n /**\n * Render a GeometryCollection to the canvas. Rendering is immediate and\n * uses the current styles appropriate for each geometry in the collection.\n *\n * @param {import(\"../../geom/GeometryCollection.js\").default} geometry Geometry collection.\n */\n CanvasImmediateRenderer.prototype.drawGeometryCollection = function (geometry) {\n var geometries = geometry.getGeometriesArray();\n for (var i = 0, ii = geometries.length; i < ii; ++i) {\n this.drawGeometry(geometries[i]);\n }\n };\n /**\n * Render a Point geometry into the canvas. Rendering is immediate and uses\n * the current style.\n *\n * @param {import(\"../../geom/Point.js\").default|import(\"../Feature.js\").default} geometry Point geometry.\n */\n CanvasImmediateRenderer.prototype.drawPoint = function (geometry) {\n if (this.squaredTolerance_) {\n geometry = /** @type {import(\"../../geom/Point.js\").default} */ (geometry.simplifyTransformed(this.squaredTolerance_, this.userTransform_));\n }\n var flatCoordinates = geometry.getFlatCoordinates();\n var stride = geometry.getStride();\n if (this.image_) {\n this.drawImages_(flatCoordinates, 0, flatCoordinates.length, stride);\n }\n if (this.text_ !== '') {\n this.drawText_(flatCoordinates, 0, flatCoordinates.length, stride);\n }\n };\n /**\n * Render a MultiPoint geometry into the canvas. Rendering is immediate and\n * uses the current style.\n *\n * @param {import(\"../../geom/MultiPoint.js\").default|import(\"../Feature.js\").default} geometry MultiPoint geometry.\n */\n CanvasImmediateRenderer.prototype.drawMultiPoint = function (geometry) {\n if (this.squaredTolerance_) {\n geometry = /** @type {import(\"../../geom/MultiPoint.js\").default} */ (geometry.simplifyTransformed(this.squaredTolerance_, this.userTransform_));\n }\n var flatCoordinates = geometry.getFlatCoordinates();\n var stride = geometry.getStride();\n if (this.image_) {\n this.drawImages_(flatCoordinates, 0, flatCoordinates.length, stride);\n }\n if (this.text_ !== '') {\n this.drawText_(flatCoordinates, 0, flatCoordinates.length, stride);\n }\n };\n /**\n * Render a LineString into the canvas. Rendering is immediate and uses\n * the current style.\n *\n * @param {import(\"../../geom/LineString.js\").default|import(\"../Feature.js\").default} geometry LineString geometry.\n */\n CanvasImmediateRenderer.prototype.drawLineString = function (geometry) {\n if (this.squaredTolerance_) {\n geometry = /** @type {import(\"../../geom/LineString.js\").default} */ (geometry.simplifyTransformed(this.squaredTolerance_, this.userTransform_));\n }\n if (!intersects(this.extent_, geometry.getExtent())) {\n return;\n }\n if (this.strokeState_) {\n this.setContextStrokeState_(this.strokeState_);\n var context = this.context_;\n var flatCoordinates = geometry.getFlatCoordinates();\n context.beginPath();\n this.moveToLineTo_(flatCoordinates, 0, flatCoordinates.length, geometry.getStride(), false);\n context.stroke();\n }\n if (this.text_ !== '') {\n var flatMidpoint = geometry.getFlatMidpoint();\n this.drawText_(flatMidpoint, 0, 2, 2);\n }\n };\n /**\n * Render a MultiLineString geometry into the canvas. Rendering is immediate\n * and uses the current style.\n *\n * @param {import(\"../../geom/MultiLineString.js\").default|import(\"../Feature.js\").default} geometry MultiLineString geometry.\n */\n CanvasImmediateRenderer.prototype.drawMultiLineString = function (geometry) {\n if (this.squaredTolerance_) {\n geometry =\n /** @type {import(\"../../geom/MultiLineString.js\").default} */ (geometry.simplifyTransformed(this.squaredTolerance_, this.userTransform_));\n }\n var geometryExtent = geometry.getExtent();\n if (!intersects(this.extent_, geometryExtent)) {\n return;\n }\n if (this.strokeState_) {\n this.setContextStrokeState_(this.strokeState_);\n var context = this.context_;\n var flatCoordinates = geometry.getFlatCoordinates();\n var offset = 0;\n var ends = /** @type {Array<number>} */ (geometry.getEnds());\n var stride = geometry.getStride();\n context.beginPath();\n for (var i = 0, ii = ends.length; i < ii; ++i) {\n offset = this.moveToLineTo_(flatCoordinates, offset, ends[i], stride, false);\n }\n context.stroke();\n }\n if (this.text_ !== '') {\n var flatMidpoints = geometry.getFlatMidpoints();\n this.drawText_(flatMidpoints, 0, flatMidpoints.length, 2);\n }\n };\n /**\n * Render a Polygon geometry into the canvas. Rendering is immediate and uses\n * the current style.\n *\n * @param {import(\"../../geom/Polygon.js\").default|import(\"../Feature.js\").default} geometry Polygon geometry.\n */\n CanvasImmediateRenderer.prototype.drawPolygon = function (geometry) {\n if (this.squaredTolerance_) {\n geometry = /** @type {import(\"../../geom/Polygon.js\").default} */ (geometry.simplifyTransformed(this.squaredTolerance_, this.userTransform_));\n }\n if (!intersects(this.extent_, geometry.getExtent())) {\n return;\n }\n if (this.strokeState_ || this.fillState_) {\n if (this.fillState_) {\n this.setContextFillState_(this.fillState_);\n }\n if (this.strokeState_) {\n this.setContextStrokeState_(this.strokeState_);\n }\n var context = this.context_;\n context.beginPath();\n this.drawRings_(geometry.getOrientedFlatCoordinates(), 0, \n /** @type {Array<number>} */ (geometry.getEnds()), geometry.getStride());\n if (this.fillState_) {\n context.fill();\n }\n if (this.strokeState_) {\n context.stroke();\n }\n }\n if (this.text_ !== '') {\n var flatInteriorPoint = geometry.getFlatInteriorPoint();\n this.drawText_(flatInteriorPoint, 0, 2, 2);\n }\n };\n /**\n * Render MultiPolygon geometry into the canvas. Rendering is immediate and\n * uses the current style.\n * @param {import(\"../../geom/MultiPolygon.js\").default} geometry MultiPolygon geometry.\n */\n CanvasImmediateRenderer.prototype.drawMultiPolygon = function (geometry) {\n if (this.squaredTolerance_) {\n geometry = /** @type {import(\"../../geom/MultiPolygon.js\").default} */ (geometry.simplifyTransformed(this.squaredTolerance_, this.userTransform_));\n }\n if (!intersects(this.extent_, geometry.getExtent())) {\n return;\n }\n if (this.strokeState_ || this.fillState_) {\n if (this.fillState_) {\n this.setContextFillState_(this.fillState_);\n }\n if (this.strokeState_) {\n this.setContextStrokeState_(this.strokeState_);\n }\n var context = this.context_;\n var flatCoordinates = geometry.getOrientedFlatCoordinates();\n var offset = 0;\n var endss = geometry.getEndss();\n var stride = geometry.getStride();\n context.beginPath();\n for (var i = 0, ii = endss.length; i < ii; ++i) {\n var ends = endss[i];\n offset = this.drawRings_(flatCoordinates, offset, ends, stride);\n }\n if (this.fillState_) {\n context.fill();\n }\n if (this.strokeState_) {\n context.stroke();\n }\n }\n if (this.text_ !== '') {\n var flatInteriorPoints = geometry.getFlatInteriorPoints();\n this.drawText_(flatInteriorPoints, 0, flatInteriorPoints.length, 2);\n }\n };\n /**\n * @param {import(\"../canvas.js\").FillState} fillState Fill state.\n * @private\n */\n CanvasImmediateRenderer.prototype.setContextFillState_ = function (fillState) {\n var context = this.context_;\n var contextFillState = this.contextFillState_;\n if (!contextFillState) {\n context.fillStyle = fillState.fillStyle;\n this.contextFillState_ = {\n fillStyle: fillState.fillStyle,\n };\n }\n else {\n if (contextFillState.fillStyle != fillState.fillStyle) {\n contextFillState.fillStyle = fillState.fillStyle;\n context.fillStyle = fillState.fillStyle;\n }\n }\n };\n /**\n * @param {import(\"../canvas.js\").StrokeState} strokeState Stroke state.\n * @private\n */\n CanvasImmediateRenderer.prototype.setContextStrokeState_ = function (strokeState) {\n var context = this.context_;\n var contextStrokeState = this.contextStrokeState_;\n if (!contextStrokeState) {\n context.lineCap = strokeState.lineCap;\n if (context.setLineDash) {\n context.setLineDash(strokeState.lineDash);\n context.lineDashOffset = strokeState.lineDashOffset;\n }\n context.lineJoin = strokeState.lineJoin;\n context.lineWidth = strokeState.lineWidth;\n context.miterLimit = strokeState.miterLimit;\n context.strokeStyle = strokeState.strokeStyle;\n this.contextStrokeState_ = {\n lineCap: strokeState.lineCap,\n lineDash: strokeState.lineDash,\n lineDashOffset: strokeState.lineDashOffset,\n lineJoin: strokeState.lineJoin,\n lineWidth: strokeState.lineWidth,\n miterLimit: strokeState.miterLimit,\n strokeStyle: strokeState.strokeStyle,\n };\n }\n else {\n if (contextStrokeState.lineCap != strokeState.lineCap) {\n contextStrokeState.lineCap = strokeState.lineCap;\n context.lineCap = strokeState.lineCap;\n }\n if (context.setLineDash) {\n if (!equals(contextStrokeState.lineDash, strokeState.lineDash)) {\n context.setLineDash((contextStrokeState.lineDash = strokeState.lineDash));\n }\n if (contextStrokeState.lineDashOffset != strokeState.lineDashOffset) {\n contextStrokeState.lineDashOffset = strokeState.lineDashOffset;\n context.lineDashOffset = strokeState.lineDashOffset;\n }\n }\n if (contextStrokeState.lineJoin != strokeState.lineJoin) {\n contextStrokeState.lineJoin = strokeState.lineJoin;\n context.lineJoin = strokeState.lineJoin;\n }\n if (contextStrokeState.lineWidth != strokeState.lineWidth) {\n contextStrokeState.lineWidth = strokeState.lineWidth;\n context.lineWidth = strokeState.lineWidth;\n }\n if (contextStrokeState.miterLimit != strokeState.miterLimit) {\n contextStrokeState.miterLimit = strokeState.miterLimit;\n context.miterLimit = strokeState.miterLimit;\n }\n if (contextStrokeState.strokeStyle != strokeState.strokeStyle) {\n contextStrokeState.strokeStyle = strokeState.strokeStyle;\n context.strokeStyle = strokeState.strokeStyle;\n }\n }\n };\n /**\n * @param {import(\"../canvas.js\").TextState} textState Text state.\n * @private\n */\n CanvasImmediateRenderer.prototype.setContextTextState_ = function (textState) {\n var context = this.context_;\n var contextTextState = this.contextTextState_;\n var textAlign = textState.textAlign\n ? textState.textAlign\n : defaultTextAlign;\n if (!contextTextState) {\n context.font = textState.font;\n context.textAlign = /** @type {CanvasTextAlign} */ (textAlign);\n context.textBaseline = /** @type {CanvasTextBaseline} */ (textState.textBaseline);\n this.contextTextState_ = {\n font: textState.font,\n textAlign: textAlign,\n textBaseline: textState.textBaseline,\n };\n }\n else {\n if (contextTextState.font != textState.font) {\n contextTextState.font = textState.font;\n context.font = textState.font;\n }\n if (contextTextState.textAlign != textAlign) {\n contextTextState.textAlign = /** @type {CanvasTextAlign} */ (textAlign);\n context.textAlign = /** @type {CanvasTextAlign} */ (textAlign);\n }\n if (contextTextState.textBaseline != textState.textBaseline) {\n contextTextState.textBaseline = /** @type {CanvasTextBaseline} */ (textState.textBaseline);\n context.textBaseline = /** @type {CanvasTextBaseline} */ (textState.textBaseline);\n }\n }\n };\n /**\n * Set the fill and stroke style for subsequent draw operations. To clear\n * either fill or stroke styles, pass null for the appropriate parameter.\n *\n * @param {import(\"../../style/Fill.js\").default} fillStyle Fill style.\n * @param {import(\"../../style/Stroke.js\").default} strokeStyle Stroke style.\n */\n CanvasImmediateRenderer.prototype.setFillStrokeStyle = function (fillStyle, strokeStyle) {\n var _this = this;\n if (!fillStyle) {\n this.fillState_ = null;\n }\n else {\n var fillStyleColor = fillStyle.getColor();\n this.fillState_ = {\n fillStyle: asColorLike(fillStyleColor ? fillStyleColor : defaultFillStyle),\n };\n }\n if (!strokeStyle) {\n this.strokeState_ = null;\n }\n else {\n var strokeStyleColor = strokeStyle.getColor();\n var strokeStyleLineCap = strokeStyle.getLineCap();\n var strokeStyleLineDash = strokeStyle.getLineDash();\n var strokeStyleLineDashOffset = strokeStyle.getLineDashOffset();\n var strokeStyleLineJoin = strokeStyle.getLineJoin();\n var strokeStyleWidth = strokeStyle.getWidth();\n var strokeStyleMiterLimit = strokeStyle.getMiterLimit();\n var lineDash = strokeStyleLineDash\n ? strokeStyleLineDash\n : defaultLineDash;\n this.strokeState_ = {\n lineCap: strokeStyleLineCap !== undefined\n ? strokeStyleLineCap\n : defaultLineCap,\n lineDash: this.pixelRatio_ === 1\n ? lineDash\n : lineDash.map(function (n) { return n * _this.pixelRatio_; }),\n lineDashOffset: (strokeStyleLineDashOffset\n ? strokeStyleLineDashOffset\n : defaultLineDashOffset) * this.pixelRatio_,\n lineJoin: strokeStyleLineJoin !== undefined\n ? strokeStyleLineJoin\n : defaultLineJoin,\n lineWidth: (strokeStyleWidth !== undefined\n ? strokeStyleWidth\n : defaultLineWidth) * this.pixelRatio_,\n miterLimit: strokeStyleMiterLimit !== undefined\n ? strokeStyleMiterLimit\n : defaultMiterLimit,\n strokeStyle: asColorLike(strokeStyleColor ? strokeStyleColor : defaultStrokeStyle),\n };\n }\n };\n /**\n * Set the image style for subsequent draw operations. Pass null to remove\n * the image style.\n *\n * @param {import(\"../../style/Image.js\").default} imageStyle Image style.\n */\n CanvasImmediateRenderer.prototype.setImageStyle = function (imageStyle) {\n var imageSize;\n if (!imageStyle || !(imageSize = imageStyle.getSize())) {\n this.image_ = null;\n return;\n }\n var imageAnchor = imageStyle.getAnchor();\n var imageOrigin = imageStyle.getOrigin();\n this.image_ = imageStyle.getImage(this.pixelRatio_);\n this.imageAnchorX_ = imageAnchor[0] * this.pixelRatio_;\n this.imageAnchorY_ = imageAnchor[1] * this.pixelRatio_;\n this.imageHeight_ = imageSize[1] * this.pixelRatio_;\n this.imageOpacity_ = imageStyle.getOpacity();\n this.imageOriginX_ = imageOrigin[0];\n this.imageOriginY_ = imageOrigin[1];\n this.imageRotateWithView_ = imageStyle.getRotateWithView();\n this.imageRotation_ = imageStyle.getRotation();\n this.imageScale_ = imageStyle.getScaleArray();\n this.imageWidth_ = imageSize[0] * this.pixelRatio_;\n };\n /**\n * Set the text style for subsequent draw operations. Pass null to\n * remove the text style.\n *\n * @param {import(\"../../style/Text.js\").default} textStyle Text style.\n */\n CanvasImmediateRenderer.prototype.setTextStyle = function (textStyle) {\n if (!textStyle) {\n this.text_ = '';\n }\n else {\n var textFillStyle = textStyle.getFill();\n if (!textFillStyle) {\n this.textFillState_ = null;\n }\n else {\n var textFillStyleColor = textFillStyle.getColor();\n this.textFillState_ = {\n fillStyle: asColorLike(textFillStyleColor ? textFillStyleColor : defaultFillStyle),\n };\n }\n var textStrokeStyle = textStyle.getStroke();\n if (!textStrokeStyle) {\n this.textStrokeState_ = null;\n }\n else {\n var textStrokeStyleColor = textStrokeStyle.getColor();\n var textStrokeStyleLineCap = textStrokeStyle.getLineCap();\n var textStrokeStyleLineDash = textStrokeStyle.getLineDash();\n var textStrokeStyleLineDashOffset = textStrokeStyle.getLineDashOffset();\n var textStrokeStyleLineJoin = textStrokeStyle.getLineJoin();\n var textStrokeStyleWidth = textStrokeStyle.getWidth();\n var textStrokeStyleMiterLimit = textStrokeStyle.getMiterLimit();\n this.textStrokeState_ = {\n lineCap: textStrokeStyleLineCap !== undefined\n ? textStrokeStyleLineCap\n : defaultLineCap,\n lineDash: textStrokeStyleLineDash\n ? textStrokeStyleLineDash\n : defaultLineDash,\n lineDashOffset: textStrokeStyleLineDashOffset\n ? textStrokeStyleLineDashOffset\n : defaultLineDashOffset,\n lineJoin: textStrokeStyleLineJoin !== undefined\n ? textStrokeStyleLineJoin\n : defaultLineJoin,\n lineWidth: textStrokeStyleWidth !== undefined\n ? textStrokeStyleWidth\n : defaultLineWidth,\n miterLimit: textStrokeStyleMiterLimit !== undefined\n ? textStrokeStyleMiterLimit\n : defaultMiterLimit,\n strokeStyle: asColorLike(textStrokeStyleColor ? textStrokeStyleColor : defaultStrokeStyle),\n };\n }\n var textFont = textStyle.getFont();\n var textOffsetX = textStyle.getOffsetX();\n var textOffsetY = textStyle.getOffsetY();\n var textRotateWithView = textStyle.getRotateWithView();\n var textRotation = textStyle.getRotation();\n var textScale = textStyle.getScaleArray();\n var textText = textStyle.getText();\n var textTextAlign = textStyle.getTextAlign();\n var textTextBaseline = textStyle.getTextBaseline();\n this.textState_ = {\n font: textFont !== undefined ? textFont : defaultFont,\n textAlign: textTextAlign !== undefined ? textTextAlign : defaultTextAlign,\n textBaseline: textTextBaseline !== undefined\n ? textTextBaseline\n : defaultTextBaseline,\n };\n this.text_ = textText !== undefined ? textText : '';\n this.textOffsetX_ =\n textOffsetX !== undefined ? this.pixelRatio_ * textOffsetX : 0;\n this.textOffsetY_ =\n textOffsetY !== undefined ? this.pixelRatio_ * textOffsetY : 0;\n this.textRotateWithView_ =\n textRotateWithView !== undefined ? textRotateWithView : false;\n this.textRotation_ = textRotation !== undefined ? textRotation : 0;\n this.textScale_ = [\n this.pixelRatio_ * textScale[0],\n this.pixelRatio_ * textScale[1],\n ];\n }\n };\n return CanvasImmediateRenderer;\n}(VectorContext));\nexport default CanvasImmediateRenderer;\n//# sourceMappingURL=Immediate.js.map","/**\n * @module ol/style/IconAnchorUnits\n */\n/**\n * Icon anchor units. One of 'fraction', 'pixels'.\n * @enum {string}\n */\nexport default {\n /**\n * Anchor is a fraction\n * @api\n */\n FRACTION: 'fraction',\n /**\n * Anchor is in pixels\n * @api\n */\n PIXELS: 'pixels',\n};\n//# sourceMappingURL=IconAnchorUnits.js.map","/**\n * @module ol/style/IconOrigin\n */\n/**\n * Icon origin. One of 'bottom-left', 'bottom-right', 'top-left', 'top-right'.\n * @enum {string}\n */\nexport default {\n /**\n * Origin is at bottom left\n * @api\n */\n BOTTOM_LEFT: 'bottom-left',\n /**\n * Origin is at bottom right\n * @api\n */\n BOTTOM_RIGHT: 'bottom-right',\n /**\n * Origin is at top left\n * @api\n */\n TOP_LEFT: 'top-left',\n /**\n * Origin is at top right\n * @api\n */\n TOP_RIGHT: 'top-right',\n};\n//# sourceMappingURL=IconOrigin.js.map","/**\n * @module ol/style/IconImageCache\n */\nimport { asString } from '../color.js';\n/**\n * @classdesc\n * Singleton class. Available through {@link module:ol/style/IconImageCache~shared}.\n */\nvar IconImageCache = /** @class */ (function () {\n function IconImageCache() {\n /**\n * @type {!Object<string, import(\"./IconImage.js\").default>}\n * @private\n */\n this.cache_ = {};\n /**\n * @type {number}\n * @private\n */\n this.cacheSize_ = 0;\n /**\n * @type {number}\n * @private\n */\n this.maxCacheSize_ = 32;\n }\n /**\n * FIXME empty description for jsdoc\n */\n IconImageCache.prototype.clear = function () {\n this.cache_ = {};\n this.cacheSize_ = 0;\n };\n /**\n * @return {boolean} Can expire cache.\n */\n IconImageCache.prototype.canExpireCache = function () {\n return this.cacheSize_ > this.maxCacheSize_;\n };\n /**\n * FIXME empty description for jsdoc\n */\n IconImageCache.prototype.expire = function () {\n if (this.canExpireCache()) {\n var i = 0;\n for (var key in this.cache_) {\n var iconImage = this.cache_[key];\n if ((i++ & 3) === 0 && !iconImage.hasListener()) {\n delete this.cache_[key];\n --this.cacheSize_;\n }\n }\n }\n };\n /**\n * @param {string} src Src.\n * @param {?string} crossOrigin Cross origin.\n * @param {import(\"../color.js\").Color} color Color.\n * @return {import(\"./IconImage.js\").default} Icon image.\n */\n IconImageCache.prototype.get = function (src, crossOrigin, color) {\n var key = getKey(src, crossOrigin, color);\n return key in this.cache_ ? this.cache_[key] : null;\n };\n /**\n * @param {string} src Src.\n * @param {?string} crossOrigin Cross origin.\n * @param {import(\"../color.js\").Color} color Color.\n * @param {import(\"./IconImage.js\").default} iconImage Icon image.\n */\n IconImageCache.prototype.set = function (src, crossOrigin, color, iconImage) {\n var key = getKey(src, crossOrigin, color);\n this.cache_[key] = iconImage;\n ++this.cacheSize_;\n };\n /**\n * Set the cache size of the icon cache. Default is `32`. Change this value when\n * your map uses more than 32 different icon images and you are not caching icon\n * styles on the application level.\n * @param {number} maxCacheSize Cache max size.\n * @api\n */\n IconImageCache.prototype.setSize = function (maxCacheSize) {\n this.maxCacheSize_ = maxCacheSize;\n this.expire();\n };\n return IconImageCache;\n}());\n/**\n * @param {string} src Src.\n * @param {?string} crossOrigin Cross origin.\n * @param {import(\"../color.js\").Color} color Color.\n * @return {string} Cache key.\n */\nfunction getKey(src, crossOrigin, color) {\n var colorString = color ? asString(color) : 'null';\n return crossOrigin + ':' + src + ':' + colorString;\n}\nexport default IconImageCache;\n/**\n * The {@link module:ol/style/IconImageCache~IconImageCache} for\n * {@link module:ol/style/Icon~Icon} images.\n * @api\n */\nexport var shared = new IconImageCache();\n//# sourceMappingURL=IconImageCache.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/ImageBase\n */\nimport EventTarget from './events/Target.js';\nimport EventType from './events/EventType.js';\nimport { abstract } from './util.js';\n/**\n * @abstract\n */\nvar ImageBase = /** @class */ (function (_super) {\n __extends(ImageBase, _super);\n /**\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number|undefined} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n * @param {import(\"./ImageState.js\").default} state State.\n */\n function ImageBase(extent, resolution, pixelRatio, state) {\n var _this = _super.call(this) || this;\n /**\n * @protected\n * @type {import(\"./extent.js\").Extent}\n */\n _this.extent = extent;\n /**\n * @private\n * @type {number}\n */\n _this.pixelRatio_ = pixelRatio;\n /**\n * @protected\n * @type {number|undefined}\n */\n _this.resolution = resolution;\n /**\n * @protected\n * @type {import(\"./ImageState.js\").default}\n */\n _this.state = state;\n return _this;\n }\n /**\n * @protected\n */\n ImageBase.prototype.changed = function () {\n this.dispatchEvent(EventType.CHANGE);\n };\n /**\n * @return {import(\"./extent.js\").Extent} Extent.\n */\n ImageBase.prototype.getExtent = function () {\n return this.extent;\n };\n /**\n * @abstract\n * @return {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} Image.\n */\n ImageBase.prototype.getImage = function () {\n return abstract();\n };\n /**\n * @return {number} PixelRatio.\n */\n ImageBase.prototype.getPixelRatio = function () {\n return this.pixelRatio_;\n };\n /**\n * @return {number} Resolution.\n */\n ImageBase.prototype.getResolution = function () {\n return /** @type {number} */ (this.resolution);\n };\n /**\n * @return {import(\"./ImageState.js\").default} State.\n */\n ImageBase.prototype.getState = function () {\n return this.state;\n };\n /**\n * Load not yet loaded URI.\n * @abstract\n */\n ImageBase.prototype.load = function () {\n abstract();\n };\n return ImageBase;\n}(EventTarget));\nexport default ImageBase;\n//# sourceMappingURL=ImageBase.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/Image\n */\nimport EventType from './events/EventType.js';\nimport ImageBase from './ImageBase.js';\nimport ImageState from './ImageState.js';\nimport { IMAGE_DECODE } from './has.js';\nimport { getHeight } from './extent.js';\nimport { listenOnce, unlistenByKey } from './events.js';\n/**\n * A function that takes an {@link module:ol/Image~Image} for the image and a\n * `{string}` for the src as arguments. It is supposed to make it so the\n * underlying image {@link module:ol/Image~Image#getImage} is assigned the\n * content specified by the src. If not specified, the default is\n *\n * function(image, src) {\n * image.getImage().src = src;\n * }\n *\n * Providing a custom `imageLoadFunction` can be useful to load images with\n * post requests or - in general - through XHR requests, where the src of the\n * image element would be set to a data URI when the content is loaded.\n *\n * @typedef {function(ImageWrapper, string): void} LoadFunction\n * @api\n */\nvar ImageWrapper = /** @class */ (function (_super) {\n __extends(ImageWrapper, _super);\n /**\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number|undefined} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n * @param {string} src Image source URI.\n * @param {?string} crossOrigin Cross origin.\n * @param {LoadFunction} imageLoadFunction Image load function.\n */\n function ImageWrapper(extent, resolution, pixelRatio, src, crossOrigin, imageLoadFunction) {\n var _this = _super.call(this, extent, resolution, pixelRatio, ImageState.IDLE) || this;\n /**\n * @private\n * @type {string}\n */\n _this.src_ = src;\n /**\n * @private\n * @type {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement}\n */\n _this.image_ = new Image();\n if (crossOrigin !== null) {\n _this.image_.crossOrigin = crossOrigin;\n }\n /**\n * @private\n * @type {?function():void}\n */\n _this.unlisten_ = null;\n /**\n * @protected\n * @type {import(\"./ImageState.js\").default}\n */\n _this.state = ImageState.IDLE;\n /**\n * @private\n * @type {LoadFunction}\n */\n _this.imageLoadFunction_ = imageLoadFunction;\n return _this;\n }\n /**\n * @return {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} Image.\n * @api\n */\n ImageWrapper.prototype.getImage = function () {\n return this.image_;\n };\n /**\n * Tracks loading or read errors.\n *\n * @private\n */\n ImageWrapper.prototype.handleImageError_ = function () {\n this.state = ImageState.ERROR;\n this.unlistenImage_();\n this.changed();\n };\n /**\n * Tracks successful image load.\n *\n * @private\n */\n ImageWrapper.prototype.handleImageLoad_ = function () {\n if (this.resolution === undefined) {\n this.resolution = getHeight(this.extent) / this.image_.height;\n }\n this.state = ImageState.LOADED;\n this.unlistenImage_();\n this.changed();\n };\n /**\n * Load the image or retry if loading previously failed.\n * Loading is taken care of by the tile queue, and calling this method is\n * only needed for preloading or for reloading in case of an error.\n * @api\n */\n ImageWrapper.prototype.load = function () {\n if (this.state == ImageState.IDLE || this.state == ImageState.ERROR) {\n this.state = ImageState.LOADING;\n this.changed();\n this.imageLoadFunction_(this, this.src_);\n this.unlisten_ = listenImage(this.image_, this.handleImageLoad_.bind(this), this.handleImageError_.bind(this));\n }\n };\n /**\n * @param {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} image Image.\n */\n ImageWrapper.prototype.setImage = function (image) {\n this.image_ = image;\n this.resolution = getHeight(this.extent) / this.image_.height;\n };\n /**\n * Discards event handlers which listen for load completion or errors.\n *\n * @private\n */\n ImageWrapper.prototype.unlistenImage_ = function () {\n if (this.unlisten_) {\n this.unlisten_();\n this.unlisten_ = null;\n }\n };\n return ImageWrapper;\n}(ImageBase));\n/**\n * @param {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} image Image element.\n * @param {function():any} loadHandler Load callback function.\n * @param {function():any} errorHandler Error callback function.\n * @return {function():void} Callback to stop listening.\n */\nexport function listenImage(image, loadHandler, errorHandler) {\n var img = /** @type {HTMLImageElement} */ (image);\n if (img.src && IMAGE_DECODE) {\n var promise = img.decode();\n var listening_1 = true;\n var unlisten = function () {\n listening_1 = false;\n };\n promise\n .then(function () {\n if (listening_1) {\n loadHandler();\n }\n })\n .catch(function (error) {\n if (listening_1) {\n // FIXME: Unconditionally call errorHandler() when this bug is fixed upstream:\n // https://bugs.webkit.org/show_bug.cgi?id=198527\n if (error.name === 'EncodingError' &&\n error.message === 'Invalid image type.') {\n loadHandler();\n }\n else {\n errorHandler();\n }\n }\n });\n return unlisten;\n }\n var listenerKeys = [\n listenOnce(img, EventType.LOAD, loadHandler),\n listenOnce(img, EventType.ERROR, errorHandler),\n ];\n return function unlisten() {\n listenerKeys.forEach(unlistenByKey);\n };\n}\nexport default ImageWrapper;\n//# sourceMappingURL=Image.js.map","/**\n * @module ol/style/IconImage\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport EventTarget from '../events/Target.js';\nimport EventType from '../events/EventType.js';\nimport ImageState from '../ImageState.js';\nimport { asString } from '../color.js';\nimport { createCanvasContext2D } from '../dom.js';\nimport { shared as iconImageCache } from './IconImageCache.js';\nimport { listenImage } from '../Image.js';\n/**\n * @type {CanvasRenderingContext2D}\n */\nvar taintedTestContext = null;\nvar IconImage = /** @class */ (function (_super) {\n __extends(IconImage, _super);\n /**\n * @param {HTMLImageElement|HTMLCanvasElement} image Image.\n * @param {string|undefined} src Src.\n * @param {import(\"../size.js\").Size} size Size.\n * @param {?string} crossOrigin Cross origin.\n * @param {import(\"../ImageState.js\").default} imageState Image state.\n * @param {import(\"../color.js\").Color} color Color.\n */\n function IconImage(image, src, size, crossOrigin, imageState, color) {\n var _this = _super.call(this) || this;\n /**\n * @private\n * @type {HTMLImageElement|HTMLCanvasElement}\n */\n _this.hitDetectionImage_ = null;\n /**\n * @private\n * @type {HTMLImageElement|HTMLCanvasElement}\n */\n _this.image_ = !image ? new Image() : image;\n if (crossOrigin !== null) {\n /** @type {HTMLImageElement} */ (_this.image_).crossOrigin = crossOrigin;\n }\n /**\n * @private\n * @type {Object<number, HTMLCanvasElement>}\n */\n _this.canvas_ = {};\n /**\n * @private\n * @type {import(\"../color.js\").Color}\n */\n _this.color_ = color;\n /**\n * @private\n * @type {?function():void}\n */\n _this.unlisten_ = null;\n /**\n * @private\n * @type {import(\"../ImageState.js\").default}\n */\n _this.imageState_ = imageState;\n /**\n * @private\n * @type {import(\"../size.js\").Size}\n */\n _this.size_ = size;\n /**\n * @private\n * @type {string|undefined}\n */\n _this.src_ = src;\n /**\n * @private\n */\n _this.tainted_;\n return _this;\n }\n /**\n * @private\n * @return {boolean} The image canvas is tainted.\n */\n IconImage.prototype.isTainted_ = function () {\n if (this.tainted_ === undefined && this.imageState_ === ImageState.LOADED) {\n if (!taintedTestContext) {\n taintedTestContext = createCanvasContext2D(1, 1);\n }\n taintedTestContext.drawImage(this.image_, 0, 0);\n try {\n taintedTestContext.getImageData(0, 0, 1, 1);\n this.tainted_ = false;\n }\n catch (e) {\n taintedTestContext = null;\n this.tainted_ = true;\n }\n }\n return this.tainted_ === true;\n };\n /**\n * @private\n */\n IconImage.prototype.dispatchChangeEvent_ = function () {\n this.dispatchEvent(EventType.CHANGE);\n };\n /**\n * @private\n */\n IconImage.prototype.handleImageError_ = function () {\n this.imageState_ = ImageState.ERROR;\n this.unlistenImage_();\n this.dispatchChangeEvent_();\n };\n /**\n * @private\n */\n IconImage.prototype.handleImageLoad_ = function () {\n this.imageState_ = ImageState.LOADED;\n if (this.size_) {\n this.image_.width = this.size_[0];\n this.image_.height = this.size_[1];\n }\n else {\n this.size_ = [this.image_.width, this.image_.height];\n }\n this.unlistenImage_();\n this.dispatchChangeEvent_();\n };\n /**\n * @param {number} pixelRatio Pixel ratio.\n * @return {HTMLImageElement|HTMLCanvasElement} Image or Canvas element.\n */\n IconImage.prototype.getImage = function (pixelRatio) {\n this.replaceColor_(pixelRatio);\n return this.canvas_[pixelRatio] ? this.canvas_[pixelRatio] : this.image_;\n };\n /**\n * @param {number} pixelRatio Pixel ratio.\n * @return {number} Image or Canvas element.\n */\n IconImage.prototype.getPixelRatio = function (pixelRatio) {\n this.replaceColor_(pixelRatio);\n return this.canvas_[pixelRatio] ? pixelRatio : 1;\n };\n /**\n * @return {import(\"../ImageState.js\").default} Image state.\n */\n IconImage.prototype.getImageState = function () {\n return this.imageState_;\n };\n /**\n * @return {HTMLImageElement|HTMLCanvasElement} Image element.\n */\n IconImage.prototype.getHitDetectionImage = function () {\n if (!this.hitDetectionImage_) {\n if (this.isTainted_()) {\n var width = this.size_[0];\n var height = this.size_[1];\n var context = createCanvasContext2D(width, height);\n context.fillRect(0, 0, width, height);\n this.hitDetectionImage_ = context.canvas;\n }\n else {\n this.hitDetectionImage_ = this.image_;\n }\n }\n return this.hitDetectionImage_;\n };\n /**\n * Get the size of the icon (in pixels).\n * @return {import(\"../size.js\").Size} Image size.\n */\n IconImage.prototype.getSize = function () {\n return this.size_;\n };\n /**\n * @return {string|undefined} Image src.\n */\n IconImage.prototype.getSrc = function () {\n return this.src_;\n };\n /**\n * Load not yet loaded URI.\n */\n IconImage.prototype.load = function () {\n if (this.imageState_ == ImageState.IDLE) {\n this.imageState_ = ImageState.LOADING;\n try {\n /** @type {HTMLImageElement} */ (this.image_).src = this.src_;\n }\n catch (e) {\n this.handleImageError_();\n }\n this.unlisten_ = listenImage(this.image_, this.handleImageLoad_.bind(this), this.handleImageError_.bind(this));\n }\n };\n /**\n * @param {number} pixelRatio Pixel ratio.\n * @private\n */\n IconImage.prototype.replaceColor_ = function (pixelRatio) {\n if (!this.color_ ||\n this.canvas_[pixelRatio] ||\n this.imageState_ !== ImageState.LOADED) {\n return;\n }\n var canvas = document.createElement('canvas');\n this.canvas_[pixelRatio] = canvas;\n canvas.width = Math.ceil(this.image_.width * pixelRatio);\n canvas.height = Math.ceil(this.image_.height * pixelRatio);\n var ctx = canvas.getContext('2d');\n ctx.scale(pixelRatio, pixelRatio);\n ctx.drawImage(this.image_, 0, 0);\n ctx.globalCompositeOperation = 'multiply';\n // Internet Explorer 11 does not support the multiply operation.\n // If the canvas is tainted in Internet Explorer this still produces\n // a solid color image with the shape of the icon.\n if (ctx.globalCompositeOperation === 'multiply' || this.isTainted_()) {\n ctx.fillStyle = asString(this.color_);\n ctx.fillRect(0, 0, canvas.width / pixelRatio, canvas.height / pixelRatio);\n ctx.globalCompositeOperation = 'destination-in';\n ctx.drawImage(this.image_, 0, 0);\n }\n else {\n var imgData = ctx.getImageData(0, 0, canvas.width, canvas.height);\n var data = imgData.data;\n var r = this.color_[0] / 255.0;\n var g = this.color_[1] / 255.0;\n var b = this.color_[2] / 255.0;\n var a = this.color_[3];\n for (var i = 0, ii = data.length; i < ii; i += 4) {\n data[i] *= r;\n data[i + 1] *= g;\n data[i + 2] *= b;\n data[i + 3] *= a;\n }\n ctx.putImageData(imgData, 0, 0);\n }\n };\n /**\n * Discards event handlers which listen for load completion or errors.\n *\n * @private\n */\n IconImage.prototype.unlistenImage_ = function () {\n if (this.unlisten_) {\n this.unlisten_();\n this.unlisten_ = null;\n }\n };\n return IconImage;\n}(EventTarget));\n/**\n * @param {HTMLImageElement|HTMLCanvasElement} image Image.\n * @param {string} src Src.\n * @param {import(\"../size.js\").Size} size Size.\n * @param {?string} crossOrigin Cross origin.\n * @param {import(\"../ImageState.js\").default} imageState Image state.\n * @param {import(\"../color.js\").Color} color Color.\n * @return {IconImage} Icon image.\n */\nexport function get(image, src, size, crossOrigin, imageState, color) {\n var iconImage = iconImageCache.get(src, crossOrigin, color);\n if (!iconImage) {\n iconImage = new IconImage(image, src, size, crossOrigin, imageState, color);\n iconImageCache.set(src, crossOrigin, color, iconImage);\n }\n return iconImage;\n}\nexport default IconImage;\n//# sourceMappingURL=IconImage.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/style/Icon\n */\nimport EventType from '../events/EventType.js';\nimport IconAnchorUnits from './IconAnchorUnits.js';\nimport IconOrigin from './IconOrigin.js';\nimport ImageState from '../ImageState.js';\nimport ImageStyle from './Image.js';\nimport { asArray } from '../color.js';\nimport { assert } from '../asserts.js';\nimport { get as getIconImage } from './IconImage.js';\nimport { getUid } from '../util.js';\n/**\n * @typedef {Object} Options\n * @property {Array<number>} [anchor=[0.5, 0.5]] Anchor. Default value is the icon center.\n * @property {import(\"./IconOrigin.js\").default} [anchorOrigin='top-left'] Origin of the anchor: `bottom-left`, `bottom-right`,\n * `top-left` or `top-right`.\n * @property {import(\"./IconAnchorUnits.js\").default} [anchorXUnits='fraction'] Units in which the anchor x value is\n * specified. A value of `'fraction'` indicates the x value is a fraction of the icon. A value of `'pixels'` indicates\n * the x value in pixels.\n * @property {import(\"./IconAnchorUnits.js\").default} [anchorYUnits='fraction'] Units in which the anchor y value is\n * specified. A value of `'fraction'` indicates the y value is a fraction of the icon. A value of `'pixels'` indicates\n * the y value in pixels.\n * @property {import(\"../color.js\").Color|string} [color] Color to tint the icon. If not specified,\n * the icon will be left as is.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images. Note that you must provide a\n * `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {HTMLImageElement|HTMLCanvasElement} [img] Image object for the icon. If the `src` option is not provided then the\n * provided image must already be loaded. And in that case, it is required\n * to provide the size of the image, with the `imgSize` option.\n * @property {Array<number>} [offset=[0, 0]] Offset, which, together with the size and the offset origin, define the\n * sub-rectangle to use from the original icon image.\n * @property {Array<number>} [displacement=[0,0]] Displacement the icon\n * @property {import(\"./IconOrigin.js\").default} [offsetOrigin='top-left'] Origin of the offset: `bottom-left`, `bottom-right`,\n * `top-left` or `top-right`.\n * @property {number} [opacity=1] Opacity of the icon.\n * @property {number|import(\"../size.js\").Size} [scale=1] Scale.\n * @property {boolean} [rotateWithView=false] Whether to rotate the icon with the view.\n * @property {number} [rotation=0] Rotation in radians (positive rotation clockwise).\n * @property {import(\"../size.js\").Size} [size] Icon size in pixel. Can be used together with `offset` to define the\n * sub-rectangle to use from the origin (sprite) icon image.\n * @property {import(\"../size.js\").Size} [imgSize] Image size in pixels. Only required if `img` is set and `src` is not, and\n * for SVG images in Internet Explorer 11. The provided `imgSize` needs to match the actual size of the image.\n * @property {string} [src] Image source URI.\n */\n/**\n * @classdesc\n * Set icon style for vector features.\n * @api\n */\nvar Icon = /** @class */ (function (_super) {\n __extends(Icon, _super);\n /**\n * @param {Options} [opt_options] Options.\n */\n function Icon(opt_options) {\n var _this = this;\n var options = opt_options || {};\n /**\n * @type {number}\n */\n var opacity = options.opacity !== undefined ? options.opacity : 1;\n /**\n * @type {number}\n */\n var rotation = options.rotation !== undefined ? options.rotation : 0;\n /**\n * @type {number|import(\"../size.js\").Size}\n */\n var scale = options.scale !== undefined ? options.scale : 1;\n /**\n * @type {boolean}\n */\n var rotateWithView = options.rotateWithView !== undefined ? options.rotateWithView : false;\n _this = _super.call(this, {\n opacity: opacity,\n rotation: rotation,\n scale: scale,\n displacement: options.displacement !== undefined ? options.displacement : [0, 0],\n rotateWithView: rotateWithView,\n }) || this;\n /**\n * @private\n * @type {Array<number>}\n */\n _this.anchor_ = options.anchor !== undefined ? options.anchor : [0.5, 0.5];\n /**\n * @private\n * @type {Array<number>}\n */\n _this.normalizedAnchor_ = null;\n /**\n * @private\n * @type {import(\"./IconOrigin.js\").default}\n */\n _this.anchorOrigin_ =\n options.anchorOrigin !== undefined\n ? options.anchorOrigin\n : IconOrigin.TOP_LEFT;\n /**\n * @private\n * @type {import(\"./IconAnchorUnits.js\").default}\n */\n _this.anchorXUnits_ =\n options.anchorXUnits !== undefined\n ? options.anchorXUnits\n : IconAnchorUnits.FRACTION;\n /**\n * @private\n * @type {import(\"./IconAnchorUnits.js\").default}\n */\n _this.anchorYUnits_ =\n options.anchorYUnits !== undefined\n ? options.anchorYUnits\n : IconAnchorUnits.FRACTION;\n /**\n * @private\n * @type {?string}\n */\n _this.crossOrigin_ =\n options.crossOrigin !== undefined ? options.crossOrigin : null;\n /**\n * @type {HTMLImageElement|HTMLCanvasElement}\n */\n var image = options.img !== undefined ? options.img : null;\n /**\n * @type {import(\"../size.js\").Size}\n */\n var imgSize = options.imgSize !== undefined ? options.imgSize : null;\n /**\n * @type {string|undefined}\n */\n var src = options.src;\n assert(!(src !== undefined && image), 4); // `image` and `src` cannot be provided at the same time\n assert(!image || (image && imgSize), 5); // `imgSize` must be set when `image` is provided\n if ((src === undefined || src.length === 0) && image) {\n src = /** @type {HTMLImageElement} */ (image).src || getUid(image);\n }\n assert(src !== undefined && src.length > 0, 6); // A defined and non-empty `src` or `image` must be provided\n /**\n * @type {import(\"../ImageState.js\").default}\n */\n var imageState = options.src !== undefined ? ImageState.IDLE : ImageState.LOADED;\n /**\n * @private\n * @type {import(\"../color.js\").Color}\n */\n _this.color_ = options.color !== undefined ? asArray(options.color) : null;\n /**\n * @private\n * @type {import(\"./IconImage.js\").default}\n */\n _this.iconImage_ = getIconImage(image, \n /** @type {string} */ (src), imgSize, _this.crossOrigin_, imageState, _this.color_);\n /**\n * @private\n * @type {Array<number>}\n */\n _this.offset_ = options.offset !== undefined ? options.offset : [0, 0];\n /**\n * @private\n * @type {import(\"./IconOrigin.js\").default}\n */\n _this.offsetOrigin_ =\n options.offsetOrigin !== undefined\n ? options.offsetOrigin\n : IconOrigin.TOP_LEFT;\n /**\n * @private\n * @type {Array<number>}\n */\n _this.origin_ = null;\n /**\n * @private\n * @type {import(\"../size.js\").Size}\n */\n _this.size_ = options.size !== undefined ? options.size : null;\n return _this;\n }\n /**\n * Clones the style. The underlying Image/HTMLCanvasElement is not cloned.\n * @return {Icon} The cloned style.\n * @api\n */\n Icon.prototype.clone = function () {\n var scale = this.getScale();\n return new Icon({\n anchor: this.anchor_.slice(),\n anchorOrigin: this.anchorOrigin_,\n anchorXUnits: this.anchorXUnits_,\n anchorYUnits: this.anchorYUnits_,\n crossOrigin: this.crossOrigin_,\n color: this.color_ && this.color_.slice\n ? this.color_.slice()\n : this.color_ || undefined,\n src: this.getSrc(),\n offset: this.offset_.slice(),\n offsetOrigin: this.offsetOrigin_,\n size: this.size_ !== null ? this.size_.slice() : undefined,\n opacity: this.getOpacity(),\n scale: Array.isArray(scale) ? scale.slice() : scale,\n rotation: this.getRotation(),\n rotateWithView: this.getRotateWithView(),\n });\n };\n /**\n * Get the anchor point in pixels. The anchor determines the center point for the\n * symbolizer.\n * @return {Array<number>} Anchor.\n * @api\n */\n Icon.prototype.getAnchor = function () {\n if (this.normalizedAnchor_) {\n return this.normalizedAnchor_;\n }\n var anchor = this.anchor_;\n var size = this.getSize();\n if (this.anchorXUnits_ == IconAnchorUnits.FRACTION ||\n this.anchorYUnits_ == IconAnchorUnits.FRACTION) {\n if (!size) {\n return null;\n }\n anchor = this.anchor_.slice();\n if (this.anchorXUnits_ == IconAnchorUnits.FRACTION) {\n anchor[0] *= size[0];\n }\n if (this.anchorYUnits_ == IconAnchorUnits.FRACTION) {\n anchor[1] *= size[1];\n }\n }\n if (this.anchorOrigin_ != IconOrigin.TOP_LEFT) {\n if (!size) {\n return null;\n }\n if (anchor === this.anchor_) {\n anchor = this.anchor_.slice();\n }\n if (this.anchorOrigin_ == IconOrigin.TOP_RIGHT ||\n this.anchorOrigin_ == IconOrigin.BOTTOM_RIGHT) {\n anchor[0] = -anchor[0] + size[0];\n }\n if (this.anchorOrigin_ == IconOrigin.BOTTOM_LEFT ||\n this.anchorOrigin_ == IconOrigin.BOTTOM_RIGHT) {\n anchor[1] = -anchor[1] + size[1];\n }\n }\n var displacement = this.getDisplacement();\n anchor[0] -= displacement[0];\n anchor[1] += displacement[1];\n this.normalizedAnchor_ = anchor;\n return this.normalizedAnchor_;\n };\n /**\n * Set the anchor point. The anchor determines the center point for the\n * symbolizer.\n *\n * @param {Array<number>} anchor Anchor.\n * @api\n */\n Icon.prototype.setAnchor = function (anchor) {\n this.anchor_ = anchor;\n this.normalizedAnchor_ = null;\n };\n /**\n * Get the icon color.\n * @return {import(\"../color.js\").Color} Color.\n * @api\n */\n Icon.prototype.getColor = function () {\n return this.color_;\n };\n /**\n * Get the image icon.\n * @param {number} pixelRatio Pixel ratio.\n * @return {HTMLImageElement|HTMLCanvasElement} Image or Canvas element.\n * @api\n */\n Icon.prototype.getImage = function (pixelRatio) {\n return this.iconImage_.getImage(pixelRatio);\n };\n /**\n * Get the pixel ratio.\n * @param {number} pixelRatio Pixel ratio.\n * @return {number} The pixel ratio of the image.\n * @api\n */\n Icon.prototype.getPixelRatio = function (pixelRatio) {\n return this.iconImage_.getPixelRatio(pixelRatio);\n };\n /**\n * @return {import(\"../size.js\").Size} Image size.\n */\n Icon.prototype.getImageSize = function () {\n return this.iconImage_.getSize();\n };\n /**\n * @return {import(\"../ImageState.js\").default} Image state.\n */\n Icon.prototype.getImageState = function () {\n return this.iconImage_.getImageState();\n };\n /**\n * @return {HTMLImageElement|HTMLCanvasElement} Image element.\n */\n Icon.prototype.getHitDetectionImage = function () {\n return this.iconImage_.getHitDetectionImage();\n };\n /**\n * Get the origin of the symbolizer.\n * @return {Array<number>} Origin.\n * @api\n */\n Icon.prototype.getOrigin = function () {\n if (this.origin_) {\n return this.origin_;\n }\n var offset = this.offset_;\n if (this.offsetOrigin_ != IconOrigin.TOP_LEFT) {\n var size = this.getSize();\n var iconImageSize = this.iconImage_.getSize();\n if (!size || !iconImageSize) {\n return null;\n }\n offset = offset.slice();\n if (this.offsetOrigin_ == IconOrigin.TOP_RIGHT ||\n this.offsetOrigin_ == IconOrigin.BOTTOM_RIGHT) {\n offset[0] = iconImageSize[0] - size[0] - offset[0];\n }\n if (this.offsetOrigin_ == IconOrigin.BOTTOM_LEFT ||\n this.offsetOrigin_ == IconOrigin.BOTTOM_RIGHT) {\n offset[1] = iconImageSize[1] - size[1] - offset[1];\n }\n }\n this.origin_ = offset;\n return this.origin_;\n };\n /**\n * Get the image URL.\n * @return {string|undefined} Image src.\n * @api\n */\n Icon.prototype.getSrc = function () {\n return this.iconImage_.getSrc();\n };\n /**\n * Get the size of the icon (in pixels).\n * @return {import(\"../size.js\").Size} Image size.\n * @api\n */\n Icon.prototype.getSize = function () {\n return !this.size_ ? this.iconImage_.getSize() : this.size_;\n };\n /**\n * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n */\n Icon.prototype.listenImageChange = function (listener) {\n this.iconImage_.addEventListener(EventType.CHANGE, listener);\n };\n /**\n * Load not yet loaded URI.\n * When rendering a feature with an icon style, the vector renderer will\n * automatically call this method. However, you might want to call this\n * method yourself for preloading or other purposes.\n * @api\n */\n Icon.prototype.load = function () {\n this.iconImage_.load();\n };\n /**\n * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n */\n Icon.prototype.unlistenImageChange = function (listener) {\n this.iconImage_.removeEventListener(EventType.CHANGE, listener);\n };\n return Icon;\n}(ImageStyle));\nexport default Icon;\n//# sourceMappingURL=Icon.js.map","/**\n * @module ol/render/canvas/hitdetect\n */\nimport CanvasImmediateRenderer from './Immediate.js';\nimport GeometryType from '../../geom/GeometryType.js';\nimport IconAnchorUnits from '../../style/IconAnchorUnits.js';\nimport { Icon } from '../../style.js';\nimport { clamp } from '../../math.js';\nimport { createCanvasContext2D } from '../../dom.js';\nimport { intersects } from '../../extent.js';\nimport { numberSafeCompareFunction } from '../../array.js';\nexport var HIT_DETECT_RESOLUTION = 0.5;\n/**\n * @param {import(\"../../size.js\").Size} size Canvas size in css pixels.\n * @param {Array<import(\"../../transform.js\").Transform>} transforms Transforms\n * for rendering features to all worlds of the viewport, from coordinates to css\n * pixels.\n * @param {Array<import(\"../../Feature.js\").FeatureLike>} features\n * Features to consider for hit detection.\n * @param {import(\"../../style/Style.js\").StyleFunction|undefined} styleFunction\n * Layer style function.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @param {number} resolution Resolution.\n * @param {number} rotation Rotation.\n * @return {ImageData} Hit detection image data.\n */\nexport function createHitDetectionImageData(size, transforms, features, styleFunction, extent, resolution, rotation) {\n var width = size[0] * HIT_DETECT_RESOLUTION;\n var height = size[1] * HIT_DETECT_RESOLUTION;\n var context = createCanvasContext2D(width, height);\n context.imageSmoothingEnabled = false;\n var canvas = context.canvas;\n var renderer = new CanvasImmediateRenderer(context, HIT_DETECT_RESOLUTION, extent, null, rotation);\n var featureCount = features.length;\n // Stretch hit detection index to use the whole available color range\n var indexFactor = Math.floor((256 * 256 * 256 - 1) / featureCount);\n var featuresByZIndex = {};\n for (var i = 1; i <= featureCount; ++i) {\n var feature = features[i - 1];\n var featureStyleFunction = feature.getStyleFunction() || styleFunction;\n if (!styleFunction) {\n continue;\n }\n var styles = featureStyleFunction(feature, resolution);\n if (!styles) {\n continue;\n }\n if (!Array.isArray(styles)) {\n styles = [styles];\n }\n var index = i * indexFactor;\n var color = '#' + ('000000' + index.toString(16)).slice(-6);\n for (var j = 0, jj = styles.length; j < jj; ++j) {\n var originalStyle = styles[j];\n var geometry = originalStyle.getGeometryFunction()(feature);\n if (!geometry || !intersects(extent, geometry.getExtent())) {\n continue;\n }\n var style = originalStyle.clone();\n var fill = style.getFill();\n if (fill) {\n fill.setColor(color);\n }\n var stroke = style.getStroke();\n if (stroke) {\n stroke.setColor(color);\n stroke.setLineDash(null);\n }\n style.setText(undefined);\n var image = originalStyle.getImage();\n if (image && image.getOpacity() !== 0) {\n var imgSize = image.getImageSize();\n if (!imgSize) {\n continue;\n }\n var imgContext = createCanvasContext2D(imgSize[0], imgSize[1], undefined, { alpha: false });\n var img = imgContext.canvas;\n imgContext.fillStyle = color;\n imgContext.fillRect(0, 0, img.width, img.height);\n style.setImage(new Icon({\n img: img,\n imgSize: imgSize,\n anchor: image.getAnchor(),\n anchorXUnits: IconAnchorUnits.PIXELS,\n anchorYUnits: IconAnchorUnits.PIXELS,\n offset: image.getOrigin(),\n opacity: 1,\n size: image.getSize(),\n scale: image.getScale(),\n rotation: image.getRotation(),\n rotateWithView: image.getRotateWithView(),\n }));\n }\n var zIndex = style.getZIndex() || 0;\n var byGeometryType = featuresByZIndex[zIndex];\n if (!byGeometryType) {\n byGeometryType = {};\n featuresByZIndex[zIndex] = byGeometryType;\n byGeometryType[GeometryType.POLYGON] = [];\n byGeometryType[GeometryType.CIRCLE] = [];\n byGeometryType[GeometryType.LINE_STRING] = [];\n byGeometryType[GeometryType.POINT] = [];\n }\n byGeometryType[geometry.getType().replace('Multi', '')].push(geometry, style);\n }\n }\n var zIndexKeys = Object.keys(featuresByZIndex)\n .map(Number)\n .sort(numberSafeCompareFunction);\n for (var i = 0, ii = zIndexKeys.length; i < ii; ++i) {\n var byGeometryType = featuresByZIndex[zIndexKeys[i]];\n for (var type in byGeometryType) {\n var geomAndStyle = byGeometryType[type];\n for (var j = 0, jj = geomAndStyle.length; j < jj; j += 2) {\n renderer.setStyle(geomAndStyle[j + 1]);\n for (var k = 0, kk = transforms.length; k < kk; ++k) {\n renderer.setTransform(transforms[k]);\n renderer.drawGeometry(geomAndStyle[j]);\n }\n }\n }\n }\n return context.getImageData(0, 0, canvas.width, canvas.height);\n}\n/**\n * @param {import(\"../../pixel\").Pixel} pixel Pixel coordinate on the hit\n * detection canvas in css pixels.\n * @param {Array<import(\"../../Feature\").FeatureLike>} features Features. Has to\n * match the `features` array that was passed to `createHitDetectionImageData()`.\n * @param {ImageData} imageData Hit detection image data generated by\n * `createHitDetectionImageData()`.\n * @return {Array<import(\"../../Feature\").FeatureLike>} features Features.\n */\nexport function hitDetect(pixel, features, imageData) {\n var resultFeatures = [];\n if (imageData) {\n var x = Math.floor(Math.round(pixel[0]) * HIT_DETECT_RESOLUTION);\n var y = Math.floor(Math.round(pixel[1]) * HIT_DETECT_RESOLUTION);\n // The pixel coordinate is clamped down to the hit-detect canvas' size to account\n // for browsers returning coordinates slightly larger than the actual canvas size\n // due to a non-integer pixel ratio.\n var index = (clamp(x, 0, imageData.width - 1) +\n clamp(y, 0, imageData.height - 1) * imageData.width) *\n 4;\n var r = imageData.data[index];\n var g = imageData.data[index + 1];\n var b = imageData.data[index + 2];\n var i = b + 256 * (g + 256 * r);\n var indexFactor = Math.floor((256 * 256 * 256 - 1) / features.length);\n if (i && i % indexFactor === 0) {\n resultFeatures.push(features[i / indexFactor - 1]);\n }\n }\n return resultFeatures;\n}\n//# sourceMappingURL=hitdetect.js.map","/**\n * @module ol/renderer/vector\n */\nimport BuilderType from '../render/canvas/BuilderType.js';\nimport GeometryType from '../geom/GeometryType.js';\nimport ImageState from '../ImageState.js';\nimport { getUid } from '../util.js';\n/**\n * Feature callback. The callback will be called with three arguments. The first\n * argument is one {@link module:ol/Feature feature} or {@link module:ol/render/Feature render feature}\n * at the pixel, the second is the {@link module:ol/layer/Layer layer} of the feature and will be null for\n * unmanaged layers. The third is the {@link module:ol/geom/SimpleGeometry} of the feature. For features\n * with a GeometryCollection geometry, it will be the first detected geometry from the collection.\n * @template T\n * @typedef {function(import(\"../Feature.js\").FeatureLike, import(\"../layer/Layer.js\").default<import(\"../source/Source\").default>, import(\"../geom/SimpleGeometry.js\").default): T} FeatureCallback\n */\n/**\n * Tolerance for geometry simplification in device pixels.\n * @type {number}\n */\nvar SIMPLIFY_TOLERANCE = 0.5;\n/**\n * @const\n * @type {Object<import(\"../geom/GeometryType.js\").default,\n * function(import(\"../render/canvas/BuilderGroup.js\").default, import(\"../geom/Geometry.js\").default,\n * import(\"../style/Style.js\").default, Object): void>}\n */\nvar GEOMETRY_RENDERERS = {\n 'Point': renderPointGeometry,\n 'LineString': renderLineStringGeometry,\n 'Polygon': renderPolygonGeometry,\n 'MultiPoint': renderMultiPointGeometry,\n 'MultiLineString': renderMultiLineStringGeometry,\n 'MultiPolygon': renderMultiPolygonGeometry,\n 'GeometryCollection': renderGeometryCollectionGeometry,\n 'Circle': renderCircleGeometry,\n};\n/**\n * @param {import(\"../Feature.js\").FeatureLike} feature1 Feature 1.\n * @param {import(\"../Feature.js\").FeatureLike} feature2 Feature 2.\n * @return {number} Order.\n */\nexport function defaultOrder(feature1, feature2) {\n return parseInt(getUid(feature1), 10) - parseInt(getUid(feature2), 10);\n}\n/**\n * @param {number} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n * @return {number} Squared pixel tolerance.\n */\nexport function getSquaredTolerance(resolution, pixelRatio) {\n var tolerance = getTolerance(resolution, pixelRatio);\n return tolerance * tolerance;\n}\n/**\n * @param {number} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n * @return {number} Pixel tolerance.\n */\nexport function getTolerance(resolution, pixelRatio) {\n return (SIMPLIFY_TOLERANCE * resolution) / pixelRatio;\n}\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} builderGroup Builder group.\n * @param {import(\"../geom/Circle.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").default} feature Feature.\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} [opt_declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderCircleGeometry(builderGroup, geometry, style, feature, opt_declutterBuilderGroup) {\n var fillStyle = style.getFill();\n var strokeStyle = style.getStroke();\n if (fillStyle || strokeStyle) {\n var circleReplay = builderGroup.getBuilder(style.getZIndex(), BuilderType.CIRCLE);\n circleReplay.setFillStrokeStyle(fillStyle, strokeStyle);\n circleReplay.drawCircle(geometry, feature);\n }\n var textStyle = style.getText();\n if (textStyle && textStyle.getText()) {\n var textReplay = (opt_declutterBuilderGroup || builderGroup).getBuilder(style.getZIndex(), BuilderType.TEXT);\n textReplay.setTextStyle(textStyle);\n textReplay.drawText(geometry, feature);\n }\n}\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} replayGroup Replay group.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n * @param {import(\"../proj.js\").TransformFunction} [opt_transform] Transform from user to view projection.\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} [opt_declutterBuilderGroup] Builder for decluttering.\n * @return {boolean} `true` if style is loading.\n */\nexport function renderFeature(replayGroup, feature, style, squaredTolerance, listener, opt_transform, opt_declutterBuilderGroup) {\n var loading = false;\n var imageStyle = style.getImage();\n if (imageStyle) {\n var imageState = imageStyle.getImageState();\n if (imageState == ImageState.LOADED || imageState == ImageState.ERROR) {\n imageStyle.unlistenImageChange(listener);\n }\n else {\n if (imageState == ImageState.IDLE) {\n imageStyle.load();\n }\n imageState = imageStyle.getImageState();\n imageStyle.listenImageChange(listener);\n loading = true;\n }\n }\n renderFeatureInternal(replayGroup, feature, style, squaredTolerance, opt_transform, opt_declutterBuilderGroup);\n return loading;\n}\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} replayGroup Replay group.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {import(\"../proj.js\").TransformFunction} [opt_transform] Optional transform function.\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} [opt_declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderFeatureInternal(replayGroup, feature, style, squaredTolerance, opt_transform, opt_declutterBuilderGroup) {\n var geometry = style.getGeometryFunction()(feature);\n if (!geometry) {\n return;\n }\n var simplifiedGeometry = geometry.simplifyTransformed(squaredTolerance, opt_transform);\n var renderer = style.getRenderer();\n if (renderer) {\n renderGeometry(replayGroup, simplifiedGeometry, style, feature);\n }\n else {\n var geometryRenderer = GEOMETRY_RENDERERS[simplifiedGeometry.getType()];\n geometryRenderer(replayGroup, simplifiedGeometry, style, feature, opt_declutterBuilderGroup);\n }\n}\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} replayGroup Replay group.\n * @param {import(\"../geom/Geometry.js\").default|import(\"../render/Feature.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n */\nfunction renderGeometry(replayGroup, geometry, style, feature) {\n if (geometry.getType() == GeometryType.GEOMETRY_COLLECTION) {\n var geometries = \n /** @type {import(\"../geom/GeometryCollection.js\").default} */ (geometry).getGeometries();\n for (var i = 0, ii = geometries.length; i < ii; ++i) {\n renderGeometry(replayGroup, geometries[i], style, feature);\n }\n return;\n }\n var replay = replayGroup.getBuilder(style.getZIndex(), BuilderType.DEFAULT);\n replay.drawCustom(\n /** @type {import(\"../geom/SimpleGeometry.js\").default} */ (geometry), feature, style.getRenderer(), style.getHitDetectionRenderer());\n}\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} replayGroup Replay group.\n * @param {import(\"../geom/GeometryCollection.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").default} feature Feature.\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} [opt_declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderGeometryCollectionGeometry(replayGroup, geometry, style, feature, opt_declutterBuilderGroup) {\n var geometries = geometry.getGeometriesArray();\n var i, ii;\n for (i = 0, ii = geometries.length; i < ii; ++i) {\n var geometryRenderer = GEOMETRY_RENDERERS[geometries[i].getType()];\n geometryRenderer(replayGroup, geometries[i], style, feature, opt_declutterBuilderGroup);\n }\n}\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} builderGroup Replay group.\n * @param {import(\"../geom/LineString.js\").default|import(\"../render/Feature.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} [opt_declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderLineStringGeometry(builderGroup, geometry, style, feature, opt_declutterBuilderGroup) {\n var strokeStyle = style.getStroke();\n if (strokeStyle) {\n var lineStringReplay = builderGroup.getBuilder(style.getZIndex(), BuilderType.LINE_STRING);\n lineStringReplay.setFillStrokeStyle(null, strokeStyle);\n lineStringReplay.drawLineString(geometry, feature);\n }\n var textStyle = style.getText();\n if (textStyle && textStyle.getText()) {\n var textReplay = (opt_declutterBuilderGroup || builderGroup).getBuilder(style.getZIndex(), BuilderType.TEXT);\n textReplay.setTextStyle(textStyle);\n textReplay.drawText(geometry, feature);\n }\n}\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} builderGroup Replay group.\n * @param {import(\"../geom/MultiLineString.js\").default|import(\"../render/Feature.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} [opt_declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderMultiLineStringGeometry(builderGroup, geometry, style, feature, opt_declutterBuilderGroup) {\n var strokeStyle = style.getStroke();\n if (strokeStyle) {\n var lineStringReplay = builderGroup.getBuilder(style.getZIndex(), BuilderType.LINE_STRING);\n lineStringReplay.setFillStrokeStyle(null, strokeStyle);\n lineStringReplay.drawMultiLineString(geometry, feature);\n }\n var textStyle = style.getText();\n if (textStyle && textStyle.getText()) {\n var textReplay = (opt_declutterBuilderGroup || builderGroup).getBuilder(style.getZIndex(), BuilderType.TEXT);\n textReplay.setTextStyle(textStyle);\n textReplay.drawText(geometry, feature);\n }\n}\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} builderGroup Replay group.\n * @param {import(\"../geom/MultiPolygon.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").default} feature Feature.\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} [opt_declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderMultiPolygonGeometry(builderGroup, geometry, style, feature, opt_declutterBuilderGroup) {\n var fillStyle = style.getFill();\n var strokeStyle = style.getStroke();\n if (strokeStyle || fillStyle) {\n var polygonReplay = builderGroup.getBuilder(style.getZIndex(), BuilderType.POLYGON);\n polygonReplay.setFillStrokeStyle(fillStyle, strokeStyle);\n polygonReplay.drawMultiPolygon(geometry, feature);\n }\n var textStyle = style.getText();\n if (textStyle && textStyle.getText()) {\n var textReplay = (opt_declutterBuilderGroup || builderGroup).getBuilder(style.getZIndex(), BuilderType.TEXT);\n textReplay.setTextStyle(textStyle);\n textReplay.drawText(geometry, feature);\n }\n}\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} builderGroup Replay group.\n * @param {import(\"../geom/Point.js\").default|import(\"../render/Feature.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} [opt_declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderPointGeometry(builderGroup, geometry, style, feature, opt_declutterBuilderGroup) {\n var imageStyle = style.getImage();\n var textStyle = style.getText();\n /** @type {import(\"../render/canvas.js\").DeclutterImageWithText} */\n var declutterImageWithText;\n if (opt_declutterBuilderGroup) {\n builderGroup = opt_declutterBuilderGroup;\n declutterImageWithText =\n imageStyle && textStyle && textStyle.getText() ? {} : undefined;\n }\n if (imageStyle) {\n if (imageStyle.getImageState() != ImageState.LOADED) {\n return;\n }\n var imageReplay = builderGroup.getBuilder(style.getZIndex(), BuilderType.IMAGE);\n imageReplay.setImageStyle(imageStyle, declutterImageWithText);\n imageReplay.drawPoint(geometry, feature);\n }\n if (textStyle && textStyle.getText()) {\n var textReplay = builderGroup.getBuilder(style.getZIndex(), BuilderType.TEXT);\n textReplay.setTextStyle(textStyle, declutterImageWithText);\n textReplay.drawText(geometry, feature);\n }\n}\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} builderGroup Replay group.\n * @param {import(\"../geom/MultiPoint.js\").default|import(\"../render/Feature.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} [opt_declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderMultiPointGeometry(builderGroup, geometry, style, feature, opt_declutterBuilderGroup) {\n var imageStyle = style.getImage();\n var textStyle = style.getText();\n /** @type {import(\"../render/canvas.js\").DeclutterImageWithText} */\n var declutterImageWithText;\n if (opt_declutterBuilderGroup) {\n builderGroup = opt_declutterBuilderGroup;\n declutterImageWithText =\n imageStyle && textStyle && textStyle.getText() ? {} : undefined;\n }\n if (imageStyle) {\n if (imageStyle.getImageState() != ImageState.LOADED) {\n return;\n }\n var imageReplay = builderGroup.getBuilder(style.getZIndex(), BuilderType.IMAGE);\n imageReplay.setImageStyle(imageStyle, declutterImageWithText);\n imageReplay.drawMultiPoint(geometry, feature);\n }\n if (textStyle && textStyle.getText()) {\n var textReplay = (opt_declutterBuilderGroup || builderGroup).getBuilder(style.getZIndex(), BuilderType.TEXT);\n textReplay.setTextStyle(textStyle, declutterImageWithText);\n textReplay.drawText(geometry, feature);\n }\n}\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} builderGroup Replay group.\n * @param {import(\"../geom/Polygon.js\").default|import(\"../render/Feature.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} [opt_declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderPolygonGeometry(builderGroup, geometry, style, feature, opt_declutterBuilderGroup) {\n var fillStyle = style.getFill();\n var strokeStyle = style.getStroke();\n if (fillStyle || strokeStyle) {\n var polygonReplay = builderGroup.getBuilder(style.getZIndex(), BuilderType.POLYGON);\n polygonReplay.setFillStrokeStyle(fillStyle, strokeStyle);\n polygonReplay.drawPolygon(geometry, feature);\n }\n var textStyle = style.getText();\n if (textStyle && textStyle.getText()) {\n var textReplay = (opt_declutterBuilderGroup || builderGroup).getBuilder(style.getZIndex(), BuilderType.TEXT);\n textReplay.setTextStyle(textStyle);\n textReplay.drawText(geometry, feature);\n }\n}\n//# sourceMappingURL=vector.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/renderer/canvas/VectorLayer\n */\nimport CanvasBuilderGroup from '../../render/canvas/BuilderGroup.js';\nimport CanvasLayerRenderer from './Layer.js';\nimport ExecutorGroup from '../../render/canvas/ExecutorGroup.js';\nimport ViewHint from '../../ViewHint.js';\nimport { HIT_DETECT_RESOLUTION, createHitDetectionImageData, hitDetect, } from '../../render/canvas/hitdetect.js';\nimport { apply, makeInverse, makeScale, toString as transformToString, } from '../../transform.js';\nimport { buffer, containsExtent, createEmpty, getWidth, intersects as intersectsExtent, wrapX as wrapExtentX, } from '../../extent.js';\nimport { cssOpacity } from '../../css.js';\nimport { defaultOrder as defaultRenderOrder, getTolerance as getRenderTolerance, getSquaredTolerance as getSquaredRenderTolerance, renderFeature, } from '../vector.js';\nimport { equals } from '../../array.js';\nimport { fromUserExtent, getTransformFromProjections, getUserProjection, toUserExtent, toUserResolution, } from '../../proj.js';\nimport { getUid } from '../../util.js';\nimport { wrapX as wrapCoordinateX } from '../../coordinate.js';\n/**\n * @classdesc\n * Canvas renderer for vector layers.\n * @api\n */\nvar CanvasVectorLayerRenderer = /** @class */ (function (_super) {\n __extends(CanvasVectorLayerRenderer, _super);\n /**\n * @param {import(\"../../layer/Vector.js\").default} vectorLayer Vector layer.\n */\n function CanvasVectorLayerRenderer(vectorLayer) {\n var _this = _super.call(this, vectorLayer) || this;\n /** @private */\n _this.boundHandleStyleImageChange_ = _this.handleStyleImageChange_.bind(_this);\n /**\n * @type {boolean}\n */\n _this.animatingOrInteracting_;\n /**\n * @private\n * @type {boolean}\n */\n _this.dirty_ = false;\n /**\n * @type {ImageData}\n */\n _this.hitDetectionImageData_ = null;\n /**\n * @type {Array<import(\"../../Feature.js\").default>}\n */\n _this.renderedFeatures_ = null;\n /**\n * @private\n * @type {number}\n */\n _this.renderedRevision_ = -1;\n /**\n * @private\n * @type {number}\n */\n _this.renderedResolution_ = NaN;\n /**\n * @private\n * @type {import(\"../../extent.js\").Extent}\n */\n _this.renderedExtent_ = createEmpty();\n /**\n * @private\n * @type {import(\"../../extent.js\").Extent}\n */\n _this.wrappedRenderedExtent_ = createEmpty();\n /**\n * @private\n * @type {number}\n */\n _this.renderedRotation_;\n /**\n * @private\n * @type {import(\"../../coordinate\").Coordinate}\n */\n _this.renderedCenter_ = null;\n /**\n * @private\n * @type {import(\"../../proj/Projection\").default}\n */\n _this.renderedProjection_ = null;\n /**\n * @private\n * @type {function(import(\"../../Feature.js\").default, import(\"../../Feature.js\").default): number|null}\n */\n _this.renderedRenderOrder_ = null;\n /**\n * @private\n * @type {import(\"../../render/canvas/ExecutorGroup\").default}\n */\n _this.replayGroup_ = null;\n /**\n * A new replay group had to be created by `prepareFrame()`\n * @type {boolean}\n */\n _this.replayGroupChanged = true;\n /**\n * @type {import(\"../../render/canvas/ExecutorGroup\").default}\n */\n _this.declutterExecutorGroup = null;\n /**\n * Clipping to be performed by `renderFrame()`\n * @type {boolean}\n */\n _this.clipping = true;\n return _this;\n }\n /**\n * Get a rendering container from an existing target, if compatible.\n * @param {HTMLElement} target Potential render target.\n * @param {string} transform CSS Transform.\n * @param {number} opacity Opacity.\n */\n CanvasVectorLayerRenderer.prototype.useContainer = function (target, transform, opacity) {\n if (opacity < 1) {\n target = null;\n }\n _super.prototype.useContainer.call(this, target, transform, opacity);\n };\n /**\n * @param {ExecutorGroup} executorGroup Executor group.\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n * @param {import(\"rbush\").default} [opt_declutterTree] Declutter tree.\n */\n CanvasVectorLayerRenderer.prototype.renderWorlds = function (executorGroup, frameState, opt_declutterTree) {\n var extent = frameState.extent;\n var viewState = frameState.viewState;\n var center = viewState.center;\n var resolution = viewState.resolution;\n var projection = viewState.projection;\n var rotation = viewState.rotation;\n var projectionExtent = projection.getExtent();\n var vectorSource = this.getLayer().getSource();\n var pixelRatio = frameState.pixelRatio;\n var viewHints = frameState.viewHints;\n var snapToPixel = !(viewHints[ViewHint.ANIMATING] || viewHints[ViewHint.INTERACTING]);\n var context = this.context;\n var width = Math.round(frameState.size[0] * pixelRatio);\n var height = Math.round(frameState.size[1] * pixelRatio);\n var multiWorld = vectorSource.getWrapX() && projection.canWrapX();\n var worldWidth = multiWorld ? getWidth(projectionExtent) : null;\n var endWorld = multiWorld\n ? Math.ceil((extent[2] - projectionExtent[2]) / worldWidth) + 1\n : 1;\n var world = multiWorld\n ? Math.floor((extent[0] - projectionExtent[0]) / worldWidth)\n : 0;\n do {\n var transform = this.getRenderTransform(center, resolution, rotation, pixelRatio, width, height, world * worldWidth);\n executorGroup.execute(context, 1, transform, rotation, snapToPixel, undefined, opt_declutterTree);\n } while (++world < endWorld);\n };\n /**\n * Render declutter items for this layer\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n */\n CanvasVectorLayerRenderer.prototype.renderDeclutter = function (frameState) {\n if (this.declutterExecutorGroup) {\n this.renderWorlds(this.declutterExecutorGroup, frameState, frameState.declutterTree);\n }\n };\n /**\n * Render the layer.\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n * @param {HTMLElement} target Target that may be used to render content to.\n * @return {HTMLElement} The rendered element.\n */\n CanvasVectorLayerRenderer.prototype.renderFrame = function (frameState, target) {\n var pixelRatio = frameState.pixelRatio;\n var layerState = frameState.layerStatesArray[frameState.layerIndex];\n // set forward and inverse pixel transforms\n makeScale(this.pixelTransform, 1 / pixelRatio, 1 / pixelRatio);\n makeInverse(this.inversePixelTransform, this.pixelTransform);\n var canvasTransform = transformToString(this.pixelTransform);\n this.useContainer(target, canvasTransform, layerState.opacity);\n var context = this.context;\n var canvas = context.canvas;\n var replayGroup = this.replayGroup_;\n var declutterExecutorGroup = this.declutterExecutorGroup;\n if ((!replayGroup || replayGroup.isEmpty()) &&\n (!declutterExecutorGroup || declutterExecutorGroup.isEmpty())) {\n return null;\n }\n // resize and clear\n var width = Math.round(frameState.size[0] * pixelRatio);\n var height = Math.round(frameState.size[1] * pixelRatio);\n if (canvas.width != width || canvas.height != height) {\n canvas.width = width;\n canvas.height = height;\n if (canvas.style.transform !== canvasTransform) {\n canvas.style.transform = canvasTransform;\n }\n }\n else if (!this.containerReused) {\n context.clearRect(0, 0, width, height);\n }\n this.preRender(context, frameState);\n var viewState = frameState.viewState;\n var projection = viewState.projection;\n // clipped rendering if layer extent is set\n var clipped = false;\n var render = true;\n if (layerState.extent && this.clipping) {\n var layerExtent = fromUserExtent(layerState.extent, projection);\n render = intersectsExtent(layerExtent, frameState.extent);\n clipped = render && !containsExtent(layerExtent, frameState.extent);\n if (clipped) {\n this.clipUnrotated(context, frameState, layerExtent);\n }\n }\n if (render) {\n this.renderWorlds(replayGroup, frameState);\n }\n if (clipped) {\n context.restore();\n }\n this.postRender(context, frameState);\n var opacity = cssOpacity(layerState.opacity);\n var container = this.container;\n if (opacity !== container.style.opacity) {\n container.style.opacity = opacity;\n }\n if (this.renderedRotation_ !== viewState.rotation) {\n this.renderedRotation_ = viewState.rotation;\n this.hitDetectionImageData_ = null;\n }\n return this.container;\n };\n /**\n * Asynchronous layer level hit detection.\n * @param {import(\"../../pixel.js\").Pixel} pixel Pixel.\n * @return {Promise<Array<import(\"../../Feature\").default>>} Promise that resolves with an array of features.\n */\n CanvasVectorLayerRenderer.prototype.getFeatures = function (pixel) {\n return new Promise(\n /**\n * @param {function(Array<import(\"../../Feature\").default|import(\"../../render/Feature\").default>): void} resolve Resolver function.\n * @this {CanvasVectorLayerRenderer}\n */\n function (resolve) {\n if (!this.hitDetectionImageData_ && !this.animatingOrInteracting_) {\n var size = [this.context.canvas.width, this.context.canvas.height];\n apply(this.pixelTransform, size);\n var center = this.renderedCenter_;\n var resolution = this.renderedResolution_;\n var rotation = this.renderedRotation_;\n var projection = this.renderedProjection_;\n var extent = this.wrappedRenderedExtent_;\n var layer = this.getLayer();\n var transforms = [];\n var width = size[0] * HIT_DETECT_RESOLUTION;\n var height = size[1] * HIT_DETECT_RESOLUTION;\n transforms.push(this.getRenderTransform(center, resolution, rotation, HIT_DETECT_RESOLUTION, width, height, 0).slice());\n var source = layer.getSource();\n var projectionExtent = projection.getExtent();\n if (source.getWrapX() &&\n projection.canWrapX() &&\n !containsExtent(projectionExtent, extent)) {\n var startX = extent[0];\n var worldWidth = getWidth(projectionExtent);\n var world = 0;\n var offsetX = void 0;\n while (startX < projectionExtent[0]) {\n --world;\n offsetX = worldWidth * world;\n transforms.push(this.getRenderTransform(center, resolution, rotation, HIT_DETECT_RESOLUTION, width, height, offsetX).slice());\n startX += worldWidth;\n }\n world = 0;\n startX = extent[2];\n while (startX > projectionExtent[2]) {\n ++world;\n offsetX = worldWidth * world;\n transforms.push(this.getRenderTransform(center, resolution, rotation, HIT_DETECT_RESOLUTION, width, height, offsetX).slice());\n startX -= worldWidth;\n }\n }\n this.hitDetectionImageData_ = createHitDetectionImageData(size, transforms, this.renderedFeatures_, layer.getStyleFunction(), extent, resolution, rotation);\n }\n resolve(hitDetect(pixel, this.renderedFeatures_, this.hitDetectionImageData_));\n }.bind(this));\n };\n /**\n * @param {import(\"../../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n * @param {number} hitTolerance Hit tolerance in pixels.\n * @param {import(\"../vector.js\").FeatureCallback<T>} callback Feature callback.\n * @param {Array<import(\"../Map.js\").HitMatch<T>>} matches The hit detected matches with tolerance.\n * @return {T|undefined} Callback result.\n * @template T\n */\n CanvasVectorLayerRenderer.prototype.forEachFeatureAtCoordinate = function (coordinate, frameState, hitTolerance, callback, matches) {\n var _this = this;\n if (!this.replayGroup_) {\n return undefined;\n }\n var resolution = frameState.viewState.resolution;\n var rotation = frameState.viewState.rotation;\n var layer = this.getLayer();\n /** @type {!Object<string, import(\"../Map.js\").HitMatch<T>|true>} */\n var features = {};\n /**\n * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n * @param {import(\"../../geom/SimpleGeometry.js\").default} geometry Geometry.\n * @param {number} distanceSq The squared distance to the click position\n * @return {T|undefined} Callback result.\n */\n var featureCallback = function (feature, geometry, distanceSq) {\n var key = getUid(feature);\n var match = features[key];\n if (!match) {\n if (distanceSq === 0) {\n features[key] = true;\n return callback(feature, layer, geometry);\n }\n matches.push((features[key] = {\n feature: feature,\n layer: layer,\n geometry: geometry,\n distanceSq: distanceSq,\n callback: callback,\n }));\n }\n else if (match !== true && distanceSq < match.distanceSq) {\n if (distanceSq === 0) {\n features[key] = true;\n matches.splice(matches.lastIndexOf(match), 1);\n return callback(feature, layer, geometry);\n }\n match.geometry = geometry;\n match.distanceSq = distanceSq;\n }\n return undefined;\n };\n var result;\n var executorGroups = [this.replayGroup_];\n if (this.declutterExecutorGroup) {\n executorGroups.push(this.declutterExecutorGroup);\n }\n executorGroups.some(function (executorGroup) {\n return (result = executorGroup.forEachFeatureAtCoordinate(coordinate, resolution, rotation, hitTolerance, featureCallback, executorGroup === _this.declutterExecutorGroup\n ? frameState.declutterTree.all().map(function (item) { return item.value; })\n : null));\n });\n return result;\n };\n /**\n * Perform action necessary to get the layer rendered after new fonts have loaded\n */\n CanvasVectorLayerRenderer.prototype.handleFontsChanged = function () {\n var layer = this.getLayer();\n if (layer.getVisible() && this.replayGroup_) {\n layer.changed();\n }\n };\n /**\n * Handle changes in image style state.\n * @param {import(\"../../events/Event.js\").default} event Image style change event.\n * @private\n */\n CanvasVectorLayerRenderer.prototype.handleStyleImageChange_ = function (event) {\n this.renderIfReadyAndVisible();\n };\n /**\n * Determine whether render should be called.\n * @param {import(\"../../PluggableMap.js\").FrameState} frameState Frame state.\n * @return {boolean} Layer is ready to be rendered.\n */\n CanvasVectorLayerRenderer.prototype.prepareFrame = function (frameState) {\n var vectorLayer = this.getLayer();\n var vectorSource = vectorLayer.getSource();\n if (!vectorSource) {\n return false;\n }\n var animating = frameState.viewHints[ViewHint.ANIMATING];\n var interacting = frameState.viewHints[ViewHint.INTERACTING];\n var updateWhileAnimating = vectorLayer.getUpdateWhileAnimating();\n var updateWhileInteracting = vectorLayer.getUpdateWhileInteracting();\n if ((!this.dirty_ && !updateWhileAnimating && animating) ||\n (!updateWhileInteracting && interacting)) {\n this.animatingOrInteracting_ = true;\n return true;\n }\n this.animatingOrInteracting_ = false;\n var frameStateExtent = frameState.extent;\n var viewState = frameState.viewState;\n var projection = viewState.projection;\n var resolution = viewState.resolution;\n var pixelRatio = frameState.pixelRatio;\n var vectorLayerRevision = vectorLayer.getRevision();\n var vectorLayerRenderBuffer = vectorLayer.getRenderBuffer();\n var vectorLayerRenderOrder = vectorLayer.getRenderOrder();\n if (vectorLayerRenderOrder === undefined) {\n vectorLayerRenderOrder = defaultRenderOrder;\n }\n var center = viewState.center.slice();\n var extent = buffer(frameStateExtent, vectorLayerRenderBuffer * resolution);\n var renderedExtent = extent.slice();\n var loadExtents = [extent.slice()];\n var projectionExtent = projection.getExtent();\n if (vectorSource.getWrapX() &&\n projection.canWrapX() &&\n !containsExtent(projectionExtent, frameState.extent)) {\n // For the replay group, we need an extent that intersects the real world\n // (-180° to +180°). To support geometries in a coordinate range from -540°\n // to +540°, we add at least 1 world width on each side of the projection\n // extent. If the viewport is wider than the world, we need to add half of\n // the viewport width to make sure we cover the whole viewport.\n var worldWidth = getWidth(projectionExtent);\n var gutter = Math.max(getWidth(extent) / 2, worldWidth);\n extent[0] = projectionExtent[0] - gutter;\n extent[2] = projectionExtent[2] + gutter;\n wrapCoordinateX(center, projection);\n var loadExtent = wrapExtentX(loadExtents[0], projection);\n // If the extent crosses the date line, we load data for both edges of the worlds\n if (loadExtent[0] < projectionExtent[0] &&\n loadExtent[2] < projectionExtent[2]) {\n loadExtents.push([\n loadExtent[0] + worldWidth,\n loadExtent[1],\n loadExtent[2] + worldWidth,\n loadExtent[3],\n ]);\n }\n else if (loadExtent[0] > projectionExtent[0] &&\n loadExtent[2] > projectionExtent[2]) {\n loadExtents.push([\n loadExtent[0] - worldWidth,\n loadExtent[1],\n loadExtent[2] - worldWidth,\n loadExtent[3],\n ]);\n }\n }\n if (!this.dirty_ &&\n this.renderedResolution_ == resolution &&\n this.renderedRevision_ == vectorLayerRevision &&\n this.renderedRenderOrder_ == vectorLayerRenderOrder &&\n containsExtent(this.wrappedRenderedExtent_, extent)) {\n if (!equals(this.renderedExtent_, renderedExtent)) {\n this.hitDetectionImageData_ = null;\n this.renderedExtent_ = renderedExtent;\n }\n this.renderedCenter_ = center;\n this.replayGroupChanged = false;\n return true;\n }\n this.replayGroup_ = null;\n this.dirty_ = false;\n var replayGroup = new CanvasBuilderGroup(getRenderTolerance(resolution, pixelRatio), extent, resolution, pixelRatio);\n var declutterBuilderGroup;\n if (this.getLayer().getDeclutter()) {\n declutterBuilderGroup = new CanvasBuilderGroup(getRenderTolerance(resolution, pixelRatio), extent, resolution, pixelRatio);\n }\n var userProjection = getUserProjection();\n var userTransform;\n if (userProjection) {\n for (var i = 0, ii = loadExtents.length; i < ii; ++i) {\n var extent_1 = loadExtents[i];\n var userExtent_1 = toUserExtent(extent_1, projection);\n vectorSource.loadFeatures(userExtent_1, toUserResolution(resolution, projection), userProjection);\n }\n userTransform = getTransformFromProjections(userProjection, projection);\n }\n else {\n for (var i = 0, ii = loadExtents.length; i < ii; ++i) {\n vectorSource.loadFeatures(loadExtents[i], resolution, projection);\n }\n }\n var squaredTolerance = getSquaredRenderTolerance(resolution, pixelRatio);\n var render = \n /**\n * @param {import(\"../../Feature.js\").default} feature Feature.\n * @this {CanvasVectorLayerRenderer}\n */\n function (feature) {\n var styles;\n var styleFunction = feature.getStyleFunction() || vectorLayer.getStyleFunction();\n if (styleFunction) {\n styles = styleFunction(feature, resolution);\n }\n if (styles) {\n var dirty = this.renderFeature(feature, squaredTolerance, styles, replayGroup, userTransform, declutterBuilderGroup);\n this.dirty_ = this.dirty_ || dirty;\n }\n }.bind(this);\n var userExtent = toUserExtent(extent, projection);\n /** @type {Array<import(\"../../Feature.js\").default>} */\n var features = vectorSource.getFeaturesInExtent(userExtent);\n if (vectorLayerRenderOrder) {\n features.sort(vectorLayerRenderOrder);\n }\n for (var i = 0, ii = features.length; i < ii; ++i) {\n render(features[i]);\n }\n this.renderedFeatures_ = features;\n var replayGroupInstructions = replayGroup.finish();\n var executorGroup = new ExecutorGroup(extent, resolution, pixelRatio, vectorSource.getOverlaps(), replayGroupInstructions, vectorLayer.getRenderBuffer());\n if (declutterBuilderGroup) {\n this.declutterExecutorGroup = new ExecutorGroup(extent, resolution, pixelRatio, vectorSource.getOverlaps(), declutterBuilderGroup.finish(), vectorLayer.getRenderBuffer());\n }\n this.renderedResolution_ = resolution;\n this.renderedRevision_ = vectorLayerRevision;\n this.renderedRenderOrder_ = vectorLayerRenderOrder;\n this.renderedExtent_ = renderedExtent;\n this.wrappedRenderedExtent_ = extent;\n this.renderedCenter_ = center;\n this.renderedProjection_ = projection;\n this.replayGroup_ = executorGroup;\n this.hitDetectionImageData_ = null;\n this.replayGroupChanged = true;\n return true;\n };\n /**\n * @param {import(\"../../Feature.js\").default} feature Feature.\n * @param {number} squaredTolerance Squared render tolerance.\n * @param {import(\"../../style/Style.js\").default|Array<import(\"../../style/Style.js\").default>} styles The style or array of styles.\n * @param {import(\"../../render/canvas/BuilderGroup.js\").default} builderGroup Builder group.\n * @param {import(\"../../proj.js\").TransformFunction} [opt_transform] Transform from user to view projection.\n * @param {import(\"../../render/canvas/BuilderGroup.js\").default} [opt_declutterBuilderGroup] Builder for decluttering.\n * @return {boolean} `true` if an image is loading.\n */\n CanvasVectorLayerRenderer.prototype.renderFeature = function (feature, squaredTolerance, styles, builderGroup, opt_transform, opt_declutterBuilderGroup) {\n if (!styles) {\n return false;\n }\n var loading = false;\n if (Array.isArray(styles)) {\n for (var i = 0, ii = styles.length; i < ii; ++i) {\n loading =\n renderFeature(builderGroup, feature, styles[i], squaredTolerance, this.boundHandleStyleImageChange_, opt_transform, opt_declutterBuilderGroup) || loading;\n }\n }\n else {\n loading = renderFeature(builderGroup, feature, styles, squaredTolerance, this.boundHandleStyleImageChange_, opt_transform, opt_declutterBuilderGroup);\n }\n return loading;\n };\n return CanvasVectorLayerRenderer;\n}(CanvasLayerRenderer));\nexport default CanvasVectorLayerRenderer;\n//# sourceMappingURL=VectorLayer.js.map","/**\n * @module ol/reproj\n */\nimport { IMAGE_SMOOTHING_DISABLED } from './source/common.js';\nimport { assign } from './obj.js';\nimport { containsCoordinate, createEmpty, extend, forEachCorner, getCenter, getHeight, getTopLeft, getWidth, } from './extent.js';\nimport { createCanvasContext2D } from './dom.js';\nimport { getPointResolution, transform } from './proj.js';\nimport { solveLinearSystem } from './math.js';\nvar brokenDiagonalRendering_;\n/**\n * This draws a small triangle into a canvas by setting the triangle as the clip region\n * and then drawing a (too large) rectangle\n *\n * @param {CanvasRenderingContext2D} ctx The context in which to draw the triangle\n * @param {number} u1 The x-coordinate of the second point. The first point is 0,0.\n * @param {number} v1 The y-coordinate of the second point.\n * @param {number} u2 The x-coordinate of the third point.\n * @param {number} v2 The y-coordinate of the third point.\n */\nfunction drawTestTriangle(ctx, u1, v1, u2, v2) {\n ctx.beginPath();\n ctx.moveTo(0, 0);\n ctx.lineTo(u1, v1);\n ctx.lineTo(u2, v2);\n ctx.closePath();\n ctx.save();\n ctx.clip();\n ctx.fillRect(0, 0, Math.max(u1, u2) + 1, Math.max(v1, v2));\n ctx.restore();\n}\n/**\n * Given the data from getImageData, see if the right values appear at the provided offset.\n * Returns true if either the color or transparency is off\n *\n * @param {Uint8ClampedArray} data The data returned from getImageData\n * @param {number} offset The pixel offset from the start of data.\n * @return {boolean} true if the diagonal rendering is broken\n */\nfunction verifyBrokenDiagonalRendering(data, offset) {\n // the values ought to be close to the rgba(210, 0, 0, 0.75)\n return (Math.abs(data[offset * 4] - 210) > 2 ||\n Math.abs(data[offset * 4 + 3] - 0.75 * 255) > 2);\n}\n/**\n * Determines if the current browser configuration can render triangular clip regions correctly.\n * This value is cached so the function is only expensive the first time called.\n * Firefox on Windows (as of now) does not if HWA is enabled. See https://bugzilla.mozilla.org/show_bug.cgi?id=1606976\n * IE also doesn't. Chrome works, and everything seems to work on OSX and Android. This function caches the\n * result. I suppose that it is conceivably possible that a browser might flip modes while the app is\n * running, but lets hope not.\n *\n * @return {boolean} true if the Diagonal Rendering is broken.\n */\nfunction isBrokenDiagonalRendering() {\n if (brokenDiagonalRendering_ === undefined) {\n var ctx = document.createElement('canvas').getContext('2d');\n ctx.globalCompositeOperation = 'lighter';\n ctx.fillStyle = 'rgba(210, 0, 0, 0.75)';\n drawTestTriangle(ctx, 4, 5, 4, 0);\n drawTestTriangle(ctx, 4, 5, 0, 5);\n var data = ctx.getImageData(0, 0, 3, 3).data;\n brokenDiagonalRendering_ =\n verifyBrokenDiagonalRendering(data, 0) ||\n verifyBrokenDiagonalRendering(data, 4) ||\n verifyBrokenDiagonalRendering(data, 8);\n }\n return brokenDiagonalRendering_;\n}\n/**\n * Calculates ideal resolution to use from the source in order to achieve\n * pixel mapping as close as possible to 1:1 during reprojection.\n * The resolution is calculated regardless of what resolutions\n * are actually available in the dataset (TileGrid, Image, ...).\n *\n * @param {import(\"./proj/Projection.js\").default} sourceProj Source projection.\n * @param {import(\"./proj/Projection.js\").default} targetProj Target projection.\n * @param {import(\"./coordinate.js\").Coordinate} targetCenter Target center.\n * @param {number} targetResolution Target resolution.\n * @return {number} The best resolution to use. Can be +-Infinity, NaN or 0.\n */\nexport function calculateSourceResolution(sourceProj, targetProj, targetCenter, targetResolution) {\n var sourceCenter = transform(targetCenter, targetProj, sourceProj);\n // calculate the ideal resolution of the source data\n var sourceResolution = getPointResolution(targetProj, targetResolution, targetCenter);\n var targetMetersPerUnit = targetProj.getMetersPerUnit();\n if (targetMetersPerUnit !== undefined) {\n sourceResolution *= targetMetersPerUnit;\n }\n var sourceMetersPerUnit = sourceProj.getMetersPerUnit();\n if (sourceMetersPerUnit !== undefined) {\n sourceResolution /= sourceMetersPerUnit;\n }\n // Based on the projection properties, the point resolution at the specified\n // coordinates may be slightly different. We need to reverse-compensate this\n // in order to achieve optimal results.\n var sourceExtent = sourceProj.getExtent();\n if (!sourceExtent || containsCoordinate(sourceExtent, sourceCenter)) {\n var compensationFactor = getPointResolution(sourceProj, sourceResolution, sourceCenter) /\n sourceResolution;\n if (isFinite(compensationFactor) && compensationFactor > 0) {\n sourceResolution /= compensationFactor;\n }\n }\n return sourceResolution;\n}\n/**\n * Calculates ideal resolution to use from the source in order to achieve\n * pixel mapping as close as possible to 1:1 during reprojection.\n * The resolution is calculated regardless of what resolutions\n * are actually available in the dataset (TileGrid, Image, ...).\n *\n * @param {import(\"./proj/Projection.js\").default} sourceProj Source projection.\n * @param {import(\"./proj/Projection.js\").default} targetProj Target projection.\n * @param {import(\"./extent.js\").Extent} targetExtent Target extent\n * @param {number} targetResolution Target resolution.\n * @return {number} The best resolution to use. Can be +-Infinity, NaN or 0.\n */\nexport function calculateSourceExtentResolution(sourceProj, targetProj, targetExtent, targetResolution) {\n var targetCenter = getCenter(targetExtent);\n var sourceResolution = calculateSourceResolution(sourceProj, targetProj, targetCenter, targetResolution);\n if (!isFinite(sourceResolution) || sourceResolution <= 0) {\n forEachCorner(targetExtent, function (corner) {\n sourceResolution = calculateSourceResolution(sourceProj, targetProj, corner, targetResolution);\n return isFinite(sourceResolution) && sourceResolution > 0;\n });\n }\n return sourceResolution;\n}\n/**\n * @typedef {Object} ImageExtent\n * @property {import(\"./extent.js\").Extent} extent Extent.\n * @property {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} image Image.\n */\n/**\n * Renders the source data into new canvas based on the triangulation.\n *\n * @param {number} width Width of the canvas.\n * @param {number} height Height of the canvas.\n * @param {number} pixelRatio Pixel ratio.\n * @param {number} sourceResolution Source resolution.\n * @param {import(\"./extent.js\").Extent} sourceExtent Extent of the data source.\n * @param {number} targetResolution Target resolution.\n * @param {import(\"./extent.js\").Extent} targetExtent Target extent.\n * @param {import(\"./reproj/Triangulation.js\").default} triangulation Calculated triangulation.\n * @param {Array<ImageExtent>} sources Array of sources.\n * @param {number} gutter Gutter of the sources.\n * @param {boolean} [opt_renderEdges] Render reprojection edges.\n * @param {object} [opt_contextOptions] Properties to set on the canvas context.\n * @return {HTMLCanvasElement} Canvas with reprojected data.\n */\nexport function render(width, height, pixelRatio, sourceResolution, sourceExtent, targetResolution, targetExtent, triangulation, sources, gutter, opt_renderEdges, opt_contextOptions) {\n var context = createCanvasContext2D(Math.round(pixelRatio * width), Math.round(pixelRatio * height));\n assign(context, opt_contextOptions);\n if (sources.length === 0) {\n return context.canvas;\n }\n context.scale(pixelRatio, pixelRatio);\n function pixelRound(value) {\n return Math.round(value * pixelRatio) / pixelRatio;\n }\n context.globalCompositeOperation = 'lighter';\n var sourceDataExtent = createEmpty();\n sources.forEach(function (src, i, arr) {\n extend(sourceDataExtent, src.extent);\n });\n var canvasWidthInUnits = getWidth(sourceDataExtent);\n var canvasHeightInUnits = getHeight(sourceDataExtent);\n var stitchContext = createCanvasContext2D(Math.round((pixelRatio * canvasWidthInUnits) / sourceResolution), Math.round((pixelRatio * canvasHeightInUnits) / sourceResolution));\n assign(stitchContext, opt_contextOptions);\n var stitchScale = pixelRatio / sourceResolution;\n sources.forEach(function (src, i, arr) {\n var xPos = src.extent[0] - sourceDataExtent[0];\n var yPos = -(src.extent[3] - sourceDataExtent[3]);\n var srcWidth = getWidth(src.extent);\n var srcHeight = getHeight(src.extent);\n // This test should never fail -- but it does. Need to find a fix the upstream condition\n if (src.image.width > 0 && src.image.height > 0) {\n stitchContext.drawImage(src.image, gutter, gutter, src.image.width - 2 * gutter, src.image.height - 2 * gutter, xPos * stitchScale, yPos * stitchScale, srcWidth * stitchScale, srcHeight * stitchScale);\n }\n });\n var targetTopLeft = getTopLeft(targetExtent);\n triangulation.getTriangles().forEach(function (triangle, i, arr) {\n /* Calculate affine transform (src -> dst)\n * Resulting matrix can be used to transform coordinate\n * from `sourceProjection` to destination pixels.\n *\n * To optimize number of context calls and increase numerical stability,\n * we also do the following operations:\n * trans(-topLeftExtentCorner), scale(1 / targetResolution), scale(1, -1)\n * here before solving the linear system so [ui, vi] are pixel coordinates.\n *\n * Src points: xi, yi\n * Dst points: ui, vi\n * Affine coefficients: aij\n *\n * | x0 y0 1 0 0 0 | |a00| |u0|\n * | x1 y1 1 0 0 0 | |a01| |u1|\n * | x2 y2 1 0 0 0 | x |a02| = |u2|\n * | 0 0 0 x0 y0 1 | |a10| |v0|\n * | 0 0 0 x1 y1 1 | |a11| |v1|\n * | 0 0 0 x2 y2 1 | |a12| |v2|\n */\n var source = triangle.source;\n var target = triangle.target;\n var x0 = source[0][0], y0 = source[0][1];\n var x1 = source[1][0], y1 = source[1][1];\n var x2 = source[2][0], y2 = source[2][1];\n // Make sure that everything is on pixel boundaries\n var u0 = pixelRound((target[0][0] - targetTopLeft[0]) / targetResolution);\n var v0 = pixelRound(-(target[0][1] - targetTopLeft[1]) / targetResolution);\n var u1 = pixelRound((target[1][0] - targetTopLeft[0]) / targetResolution);\n var v1 = pixelRound(-(target[1][1] - targetTopLeft[1]) / targetResolution);\n var u2 = pixelRound((target[2][0] - targetTopLeft[0]) / targetResolution);\n var v2 = pixelRound(-(target[2][1] - targetTopLeft[1]) / targetResolution);\n // Shift all the source points to improve numerical stability\n // of all the subsequent calculations. The [x0, y0] is used here.\n // This is also used to simplify the linear system.\n var sourceNumericalShiftX = x0;\n var sourceNumericalShiftY = y0;\n x0 = 0;\n y0 = 0;\n x1 -= sourceNumericalShiftX;\n y1 -= sourceNumericalShiftY;\n x2 -= sourceNumericalShiftX;\n y2 -= sourceNumericalShiftY;\n var augmentedMatrix = [\n [x1, y1, 0, 0, u1 - u0],\n [x2, y2, 0, 0, u2 - u0],\n [0, 0, x1, y1, v1 - v0],\n [0, 0, x2, y2, v2 - v0],\n ];\n var affineCoefs = solveLinearSystem(augmentedMatrix);\n if (!affineCoefs) {\n return;\n }\n context.save();\n context.beginPath();\n if (isBrokenDiagonalRendering() ||\n opt_contextOptions === IMAGE_SMOOTHING_DISABLED) {\n // Make sure that all lines are horizontal or vertical\n context.moveTo(u1, v1);\n // This is the diagonal line. Do it in 4 steps\n var steps = 4;\n var ud = u0 - u1;\n var vd = v0 - v1;\n for (var step = 0; step < steps; step++) {\n // Go horizontally\n context.lineTo(u1 + pixelRound(((step + 1) * ud) / steps), v1 + pixelRound((step * vd) / (steps - 1)));\n // Go vertically\n if (step != steps - 1) {\n context.lineTo(u1 + pixelRound(((step + 1) * ud) / steps), v1 + pixelRound(((step + 1) * vd) / (steps - 1)));\n }\n }\n // We are almost at u0r, v0r\n context.lineTo(u2, v2);\n }\n else {\n context.moveTo(u1, v1);\n context.lineTo(u0, v0);\n context.lineTo(u2, v2);\n }\n context.clip();\n context.transform(affineCoefs[0], affineCoefs[2], affineCoefs[1], affineCoefs[3], u0, v0);\n context.translate(sourceDataExtent[0] - sourceNumericalShiftX, sourceDataExtent[3] - sourceNumericalShiftY);\n context.scale(sourceResolution / pixelRatio, -sourceResolution / pixelRatio);\n context.drawImage(stitchContext.canvas, 0, 0);\n context.restore();\n });\n if (opt_renderEdges) {\n context.save();\n context.globalCompositeOperation = 'source-over';\n context.strokeStyle = 'black';\n context.lineWidth = 1;\n triangulation.getTriangles().forEach(function (triangle, i, arr) {\n var target = triangle.target;\n var u0 = (target[0][0] - targetTopLeft[0]) / targetResolution;\n var v0 = -(target[0][1] - targetTopLeft[1]) / targetResolution;\n var u1 = (target[1][0] - targetTopLeft[0]) / targetResolution;\n var v1 = -(target[1][1] - targetTopLeft[1]) / targetResolution;\n var u2 = (target[2][0] - targetTopLeft[0]) / targetResolution;\n var v2 = -(target[2][1] - targetTopLeft[1]) / targetResolution;\n context.beginPath();\n context.moveTo(u1, v1);\n context.lineTo(u0, v0);\n context.lineTo(u2, v2);\n context.closePath();\n context.stroke();\n });\n context.restore();\n }\n return context.canvas;\n}\n//# sourceMappingURL=reproj.js.map","/**\n * @module ol/ViewHint\n */\n/**\n * @enum {number}\n */\nexport default {\n ANIMATING: 0,\n INTERACTING: 1,\n};\n//# sourceMappingURL=ViewHint.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/layer/Vector\n */\nimport BaseVectorLayer from './BaseVector.js';\nimport CanvasVectorLayerRenderer from '../renderer/canvas/VectorLayer.js';\n/**\n * @classdesc\n * Vector data that is rendered client-side.\n * Note that any property set in the options is set as a {@link module:ol/Object~BaseObject}\n * property on the layer object; for example, setting `title: 'My Title'` in the\n * options means that `title` is observable, and has get/set accessors.\n *\n * @template {import(\"../source/Vector.js\").default} VectorSourceType\n * @extends {BaseVectorLayer<VectorSourceType>}\n * @api\n */\nvar VectorLayer = /** @class */ (function (_super) {\n __extends(VectorLayer, _super);\n /**\n * @param {import(\"./BaseVector.js\").Options<VectorSourceType>} [opt_options] Options.\n */\n function VectorLayer(opt_options) {\n return _super.call(this, opt_options) || this;\n }\n /**\n * Create a renderer for this layer.\n * @return {import(\"../renderer/Layer.js\").default} A layer renderer.\n */\n VectorLayer.prototype.createRenderer = function () {\n return new CanvasVectorLayerRenderer(this);\n };\n return VectorLayer;\n}(BaseVectorLayer));\nexport default VectorLayer;\n//# sourceMappingURL=Vector.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/Tile\n */\nimport EventTarget from './events/Target.js';\nimport EventType from './events/EventType.js';\nimport TileState from './TileState.js';\nimport { abstract } from './util.js';\nimport { easeIn } from './easing.js';\n/**\n * A function that takes an {@link module:ol/Tile} for the tile and a\n * `{string}` for the url as arguments. The default is\n * ```js\n * source.setTileLoadFunction(function(tile, src) {\n * tile.getImage().src = src;\n * });\n * ```\n * For more fine grained control, the load function can use fetch or XMLHttpRequest and involve\n * error handling:\n *\n * ```js\n * import TileState from 'ol/TileState';\n *\n * source.setTileLoadFunction(function(tile, src) {\n * var xhr = new XMLHttpRequest();\n * xhr.responseType = 'blob';\n * xhr.addEventListener('loadend', function (evt) {\n * var data = this.response;\n * if (data !== undefined) {\n * tile.getImage().src = URL.createObjectURL(data);\n * } else {\n * tile.setState(TileState.ERROR);\n * }\n * });\n * xhr.addEventListener('error', function () {\n * tile.setState(TileState.ERROR);\n * });\n * xhr.open('GET', src);\n * xhr.send();\n * });\n * ```\n *\n * @typedef {function(Tile, string): void} LoadFunction\n * @api\n */\n/**\n * {@link module:ol/source/Tile~Tile} sources use a function of this type to get\n * the url that provides a tile for a given tile coordinate.\n *\n * This function takes an {@link module:ol/tilecoord~TileCoord} for the tile\n * coordinate, a `{number}` representing the pixel ratio and a\n * {@link module:ol/proj/Projection} for the projection as arguments\n * and returns a `{string}` representing the tile URL, or undefined if no tile\n * should be requested for the passed tile coordinate.\n *\n * @typedef {function(import(\"./tilecoord.js\").TileCoord, number,\n * import(\"./proj/Projection.js\").default): (string|undefined)} UrlFunction\n * @api\n */\n/**\n * @typedef {Object} Options\n * @property {number} [transition=250] A duration for tile opacity\n * transitions in milliseconds. A duration of 0 disables the opacity transition.\n * @api\n */\n/**\n * @classdesc\n * Base class for tiles.\n *\n * @abstract\n */\nvar Tile = /** @class */ (function (_super) {\n __extends(Tile, _super);\n /**\n * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @param {import(\"./TileState.js\").default} state State.\n * @param {Options} [opt_options] Tile options.\n */\n function Tile(tileCoord, state, opt_options) {\n var _this = _super.call(this) || this;\n var options = opt_options ? opt_options : {};\n /**\n * @type {import(\"./tilecoord.js\").TileCoord}\n */\n _this.tileCoord = tileCoord;\n /**\n * @protected\n * @type {import(\"./TileState.js\").default}\n */\n _this.state = state;\n /**\n * An \"interim\" tile for this tile. The interim tile may be used while this\n * one is loading, for \"smooth\" transitions when changing params/dimensions\n * on the source.\n * @type {Tile}\n */\n _this.interimTile = null;\n /**\n * A key assigned to the tile. This is used by the tile source to determine\n * if this tile can effectively be used, or if a new tile should be created\n * and this one be used as an interim tile for this new tile.\n * @type {string}\n */\n _this.key = '';\n /**\n * The duration for the opacity transition.\n * @type {number}\n */\n _this.transition_ =\n options.transition === undefined ? 250 : options.transition;\n /**\n * Lookup of start times for rendering transitions. If the start time is\n * equal to -1, the transition is complete.\n * @type {Object<string, number>}\n */\n _this.transitionStarts_ = {};\n return _this;\n }\n /**\n * @protected\n */\n Tile.prototype.changed = function () {\n this.dispatchEvent(EventType.CHANGE);\n };\n /**\n * Called by the tile cache when the tile is removed from the cache due to expiry\n */\n Tile.prototype.release = function () { };\n /**\n * @return {string} Key.\n */\n Tile.prototype.getKey = function () {\n return this.key + '/' + this.tileCoord;\n };\n /**\n * Get the interim tile most suitable for rendering using the chain of interim\n * tiles. This corresponds to the most recent tile that has been loaded, if no\n * such tile exists, the original tile is returned.\n * @return {!Tile} Best tile for rendering.\n */\n Tile.prototype.getInterimTile = function () {\n if (!this.interimTile) {\n //empty chain\n return this;\n }\n var tile = this.interimTile;\n // find the first loaded tile and return it. Since the chain is sorted in\n // decreasing order of creation time, there is no need to search the remainder\n // of the list (all those tiles correspond to older requests and will be\n // cleaned up by refreshInterimChain)\n do {\n if (tile.getState() == TileState.LOADED) {\n // Show tile immediately instead of fading it in after loading, because\n // the interim tile is in place already\n this.transition_ = 0;\n return tile;\n }\n tile = tile.interimTile;\n } while (tile);\n // we can not find a better tile\n return this;\n };\n /**\n * Goes through the chain of interim tiles and discards sections of the chain\n * that are no longer relevant.\n */\n Tile.prototype.refreshInterimChain = function () {\n if (!this.interimTile) {\n return;\n }\n var tile = this.interimTile;\n var prev = /** @type {Tile} */ (this);\n do {\n if (tile.getState() == TileState.LOADED) {\n //we have a loaded tile, we can discard the rest of the list\n //we would could abort any LOADING tile request\n //older than this tile (i.e. any LOADING tile following this entry in the chain)\n tile.interimTile = null;\n break;\n }\n else if (tile.getState() == TileState.LOADING) {\n //keep this LOADING tile any loaded tiles later in the chain are\n //older than this tile, so we're still interested in the request\n prev = tile;\n }\n else if (tile.getState() == TileState.IDLE) {\n //the head of the list is the most current tile, we don't need\n //to start any other requests for this chain\n prev.interimTile = tile.interimTile;\n }\n else {\n prev = tile;\n }\n tile = prev.interimTile;\n } while (tile);\n };\n /**\n * Get the tile coordinate for this tile.\n * @return {import(\"./tilecoord.js\").TileCoord} The tile coordinate.\n * @api\n */\n Tile.prototype.getTileCoord = function () {\n return this.tileCoord;\n };\n /**\n * @return {import(\"./TileState.js\").default} State.\n */\n Tile.prototype.getState = function () {\n return this.state;\n };\n /**\n * Sets the state of this tile. If you write your own {@link module:ol/Tile~LoadFunction tileLoadFunction} ,\n * it is important to set the state correctly to {@link module:ol/TileState~ERROR}\n * when the tile cannot be loaded. Otherwise the tile cannot be removed from\n * the tile queue and will block other requests.\n * @param {import(\"./TileState.js\").default} state State.\n * @api\n */\n Tile.prototype.setState = function (state) {\n if (this.state !== TileState.ERROR && this.state > state) {\n throw new Error('Tile load sequence violation');\n }\n this.state = state;\n this.changed();\n };\n /**\n * Load the image or retry if loading previously failed.\n * Loading is taken care of by the tile queue, and calling this method is\n * only needed for preloading or for reloading in case of an error.\n * @abstract\n * @api\n */\n Tile.prototype.load = function () {\n abstract();\n };\n /**\n * Get the alpha value for rendering.\n * @param {string} id An id for the renderer.\n * @param {number} time The render frame time.\n * @return {number} A number between 0 and 1.\n */\n Tile.prototype.getAlpha = function (id, time) {\n if (!this.transition_) {\n return 1;\n }\n var start = this.transitionStarts_[id];\n if (!start) {\n start = time;\n this.transitionStarts_[id] = start;\n }\n else if (start === -1) {\n return 1;\n }\n var delta = time - start + 1000 / 60; // avoid rendering at 0\n if (delta >= this.transition_) {\n return 1;\n }\n return easeIn(delta / this.transition_);\n };\n /**\n * Determine if a tile is in an alpha transition. A tile is considered in\n * transition if tile.getAlpha() has not yet been called or has been called\n * and returned 1.\n * @param {string} id An id for the renderer.\n * @return {boolean} The tile is in transition.\n */\n Tile.prototype.inTransition = function (id) {\n if (!this.transition_) {\n return false;\n }\n return this.transitionStarts_[id] !== -1;\n };\n /**\n * Mark a transition as complete.\n * @param {string} id An id for the renderer.\n */\n Tile.prototype.endTransition = function (id) {\n if (this.transition_) {\n this.transitionStarts_[id] = -1;\n }\n };\n return Tile;\n}(EventTarget));\nexport default Tile;\n//# sourceMappingURL=Tile.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/ImageTile\n */\nimport Tile from './Tile.js';\nimport TileState from './TileState.js';\nimport { createCanvasContext2D } from './dom.js';\nimport { listenImage } from './Image.js';\nvar ImageTile = /** @class */ (function (_super) {\n __extends(ImageTile, _super);\n /**\n * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @param {import(\"./TileState.js\").default} state State.\n * @param {string} src Image source URI.\n * @param {?string} crossOrigin Cross origin.\n * @param {import(\"./Tile.js\").LoadFunction} tileLoadFunction Tile load function.\n * @param {import(\"./Tile.js\").Options} [opt_options] Tile options.\n */\n function ImageTile(tileCoord, state, src, crossOrigin, tileLoadFunction, opt_options) {\n var _this = _super.call(this, tileCoord, state, opt_options) || this;\n /**\n * @private\n * @type {?string}\n */\n _this.crossOrigin_ = crossOrigin;\n /**\n * Image URI\n *\n * @private\n * @type {string}\n */\n _this.src_ = src;\n _this.key = src;\n /**\n * @private\n * @type {HTMLImageElement|HTMLCanvasElement}\n */\n _this.image_ = new Image();\n if (crossOrigin !== null) {\n _this.image_.crossOrigin = crossOrigin;\n }\n /**\n * @private\n * @type {?function():void}\n */\n _this.unlisten_ = null;\n /**\n * @private\n * @type {import(\"./Tile.js\").LoadFunction}\n */\n _this.tileLoadFunction_ = tileLoadFunction;\n return _this;\n }\n /**\n * Get the HTML image element for this tile (may be a Canvas, Image, or Video).\n * @return {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} Image.\n * @api\n */\n ImageTile.prototype.getImage = function () {\n return this.image_;\n };\n /**\n * Sets an HTML image element for this tile (may be a Canvas or preloaded Image).\n * @param {HTMLCanvasElement|HTMLImageElement} element Element.\n */\n ImageTile.prototype.setImage = function (element) {\n this.image_ = element;\n this.state = TileState.LOADED;\n this.unlistenImage_();\n this.changed();\n };\n /**\n * Tracks loading or read errors.\n *\n * @private\n */\n ImageTile.prototype.handleImageError_ = function () {\n this.state = TileState.ERROR;\n this.unlistenImage_();\n this.image_ = getBlankImage();\n this.changed();\n };\n /**\n * Tracks successful image load.\n *\n * @private\n */\n ImageTile.prototype.handleImageLoad_ = function () {\n var image = /** @type {HTMLImageElement} */ (this.image_);\n if (image.naturalWidth && image.naturalHeight) {\n this.state = TileState.LOADED;\n }\n else {\n this.state = TileState.EMPTY;\n }\n this.unlistenImage_();\n this.changed();\n };\n /**\n * Load not yet loaded URI.\n * @api\n */\n ImageTile.prototype.load = function () {\n if (this.state == TileState.ERROR) {\n this.state = TileState.IDLE;\n this.image_ = new Image();\n if (this.crossOrigin_ !== null) {\n this.image_.crossOrigin = this.crossOrigin_;\n }\n }\n if (this.state == TileState.IDLE) {\n this.state = TileState.LOADING;\n this.changed();\n this.tileLoadFunction_(this, this.src_);\n this.unlisten_ = listenImage(this.image_, this.handleImageLoad_.bind(this), this.handleImageError_.bind(this));\n }\n };\n /**\n * Discards event handlers which listen for load completion or errors.\n *\n * @private\n */\n ImageTile.prototype.unlistenImage_ = function () {\n if (this.unlisten_) {\n this.unlisten_();\n this.unlisten_ = null;\n }\n };\n return ImageTile;\n}(Tile));\n/**\n * Get a 1-pixel blank image.\n * @return {HTMLCanvasElement} Blank image.\n */\nfunction getBlankImage() {\n var ctx = createCanvasContext2D(1, 1);\n ctx.fillStyle = 'rgba(0,0,0,0)';\n ctx.fillRect(0, 0, 1, 1);\n return ctx.canvas;\n}\nexport default ImageTile;\n//# sourceMappingURL=ImageTile.js.map","/**\n * @module ol/reproj/Triangulation\n */\nimport { boundingExtent, createEmpty, extendCoordinate, getArea, getBottomLeft, getBottomRight, getTopLeft, getTopRight, getWidth, intersects, } from '../extent.js';\nimport { getTransform } from '../proj.js';\nimport { log2, modulo } from '../math.js';\n/**\n * Single triangle; consists of 3 source points and 3 target points.\n * @typedef {Object} Triangle\n * @property {Array<import(\"../coordinate.js\").Coordinate>} source Source.\n * @property {Array<import(\"../coordinate.js\").Coordinate>} target Target.\n */\n/**\n * Maximum number of subdivision steps during raster reprojection triangulation.\n * Prevents high memory usage and large number of proj4 calls (for certain\n * transformations and areas). At most `2*(2^this)` triangles are created for\n * each triangulated extent (tile/image).\n * @type {number}\n */\nvar MAX_SUBDIVISION = 10;\n/**\n * Maximum allowed size of triangle relative to world width. When transforming\n * corners of world extent between certain projections, the resulting\n * triangulation seems to have zero error and no subdivision is performed. If\n * the triangle width is more than this (relative to world width; 0-1),\n * subdivison is forced (up to `MAX_SUBDIVISION`). Default is `0.25`.\n * @type {number}\n */\nvar MAX_TRIANGLE_WIDTH = 0.25;\n/**\n * @classdesc\n * Class containing triangulation of the given target extent.\n * Used for determining source data and the reprojection itself.\n */\nvar Triangulation = /** @class */ (function () {\n /**\n * @param {import(\"../proj/Projection.js\").default} sourceProj Source projection.\n * @param {import(\"../proj/Projection.js\").default} targetProj Target projection.\n * @param {import(\"../extent.js\").Extent} targetExtent Target extent to triangulate.\n * @param {import(\"../extent.js\").Extent} maxSourceExtent Maximal source extent that can be used.\n * @param {number} errorThreshold Acceptable error (in source units).\n * @param {?number} opt_destinationResolution The (optional) resolution of the destination.\n */\n function Triangulation(sourceProj, targetProj, targetExtent, maxSourceExtent, errorThreshold, opt_destinationResolution) {\n /**\n * @type {import(\"../proj/Projection.js\").default}\n * @private\n */\n this.sourceProj_ = sourceProj;\n /**\n * @type {import(\"../proj/Projection.js\").default}\n * @private\n */\n this.targetProj_ = targetProj;\n /** @type {!Object<string, import(\"../coordinate.js\").Coordinate>} */\n var transformInvCache = {};\n var transformInv = getTransform(this.targetProj_, this.sourceProj_);\n /**\n * @param {import(\"../coordinate.js\").Coordinate} c A coordinate.\n * @return {import(\"../coordinate.js\").Coordinate} Transformed coordinate.\n * @private\n */\n this.transformInv_ = function (c) {\n var key = c[0] + '/' + c[1];\n if (!transformInvCache[key]) {\n transformInvCache[key] = transformInv(c);\n }\n return transformInvCache[key];\n };\n /**\n * @type {import(\"../extent.js\").Extent}\n * @private\n */\n this.maxSourceExtent_ = maxSourceExtent;\n /**\n * @type {number}\n * @private\n */\n this.errorThresholdSquared_ = errorThreshold * errorThreshold;\n /**\n * @type {Array<Triangle>}\n * @private\n */\n this.triangles_ = [];\n /**\n * Indicates that the triangulation crosses edge of the source projection.\n * @type {boolean}\n * @private\n */\n this.wrapsXInSource_ = false;\n /**\n * @type {boolean}\n * @private\n */\n this.canWrapXInSource_ =\n this.sourceProj_.canWrapX() &&\n !!maxSourceExtent &&\n !!this.sourceProj_.getExtent() &&\n getWidth(maxSourceExtent) == getWidth(this.sourceProj_.getExtent());\n /**\n * @type {?number}\n * @private\n */\n this.sourceWorldWidth_ = this.sourceProj_.getExtent()\n ? getWidth(this.sourceProj_.getExtent())\n : null;\n /**\n * @type {?number}\n * @private\n */\n this.targetWorldWidth_ = this.targetProj_.getExtent()\n ? getWidth(this.targetProj_.getExtent())\n : null;\n var destinationTopLeft = getTopLeft(targetExtent);\n var destinationTopRight = getTopRight(targetExtent);\n var destinationBottomRight = getBottomRight(targetExtent);\n var destinationBottomLeft = getBottomLeft(targetExtent);\n var sourceTopLeft = this.transformInv_(destinationTopLeft);\n var sourceTopRight = this.transformInv_(destinationTopRight);\n var sourceBottomRight = this.transformInv_(destinationBottomRight);\n var sourceBottomLeft = this.transformInv_(destinationBottomLeft);\n /*\n * The maxSubdivision controls how many splittings of the target area can\n * be done. The idea here is to do a linear mapping of the target areas\n * but the actual overal reprojection (can be) extremely non-linear. The\n * default value of MAX_SUBDIVISION was chosen based on mapping a 256x256\n * tile size. However this function is also called to remap canvas rendered\n * layers which can be much larger. This calculation increases the maxSubdivision\n * value by the right factor so that each 256x256 pixel area has\n * MAX_SUBDIVISION divisions.\n */\n var maxSubdivision = MAX_SUBDIVISION +\n (opt_destinationResolution\n ? Math.max(0, Math.ceil(log2(getArea(targetExtent) /\n (opt_destinationResolution *\n opt_destinationResolution *\n 256 *\n 256))))\n : 0);\n this.addQuad_(destinationTopLeft, destinationTopRight, destinationBottomRight, destinationBottomLeft, sourceTopLeft, sourceTopRight, sourceBottomRight, sourceBottomLeft, maxSubdivision);\n if (this.wrapsXInSource_) {\n var leftBound_1 = Infinity;\n this.triangles_.forEach(function (triangle, i, arr) {\n leftBound_1 = Math.min(leftBound_1, triangle.source[0][0], triangle.source[1][0], triangle.source[2][0]);\n });\n // Shift triangles to be as close to `leftBound` as possible\n // (if the distance is more than `worldWidth / 2` it can be closer.\n this.triangles_.forEach(function (triangle) {\n if (Math.max(triangle.source[0][0], triangle.source[1][0], triangle.source[2][0]) -\n leftBound_1 >\n this.sourceWorldWidth_ / 2) {\n var newTriangle = [\n [triangle.source[0][0], triangle.source[0][1]],\n [triangle.source[1][0], triangle.source[1][1]],\n [triangle.source[2][0], triangle.source[2][1]],\n ];\n if (newTriangle[0][0] - leftBound_1 > this.sourceWorldWidth_ / 2) {\n newTriangle[0][0] -= this.sourceWorldWidth_;\n }\n if (newTriangle[1][0] - leftBound_1 > this.sourceWorldWidth_ / 2) {\n newTriangle[1][0] -= this.sourceWorldWidth_;\n }\n if (newTriangle[2][0] - leftBound_1 > this.sourceWorldWidth_ / 2) {\n newTriangle[2][0] -= this.sourceWorldWidth_;\n }\n // Rarely (if the extent contains both the dateline and prime meridian)\n // the shift can in turn break some triangles.\n // Detect this here and don't shift in such cases.\n var minX = Math.min(newTriangle[0][0], newTriangle[1][0], newTriangle[2][0]);\n var maxX = Math.max(newTriangle[0][0], newTriangle[1][0], newTriangle[2][0]);\n if (maxX - minX < this.sourceWorldWidth_ / 2) {\n triangle.source = newTriangle;\n }\n }\n }.bind(this));\n }\n transformInvCache = {};\n }\n /**\n * Adds triangle to the triangulation.\n * @param {import(\"../coordinate.js\").Coordinate} a The target a coordinate.\n * @param {import(\"../coordinate.js\").Coordinate} b The target b coordinate.\n * @param {import(\"../coordinate.js\").Coordinate} c The target c coordinate.\n * @param {import(\"../coordinate.js\").Coordinate} aSrc The source a coordinate.\n * @param {import(\"../coordinate.js\").Coordinate} bSrc The source b coordinate.\n * @param {import(\"../coordinate.js\").Coordinate} cSrc The source c coordinate.\n * @private\n */\n Triangulation.prototype.addTriangle_ = function (a, b, c, aSrc, bSrc, cSrc) {\n this.triangles_.push({\n source: [aSrc, bSrc, cSrc],\n target: [a, b, c],\n });\n };\n /**\n * Adds quad (points in clock-wise order) to the triangulation\n * (and reprojects the vertices) if valid.\n * Performs quad subdivision if needed to increase precision.\n *\n * @param {import(\"../coordinate.js\").Coordinate} a The target a coordinate.\n * @param {import(\"../coordinate.js\").Coordinate} b The target b coordinate.\n * @param {import(\"../coordinate.js\").Coordinate} c The target c coordinate.\n * @param {import(\"../coordinate.js\").Coordinate} d The target d coordinate.\n * @param {import(\"../coordinate.js\").Coordinate} aSrc The source a coordinate.\n * @param {import(\"../coordinate.js\").Coordinate} bSrc The source b coordinate.\n * @param {import(\"../coordinate.js\").Coordinate} cSrc The source c coordinate.\n * @param {import(\"../coordinate.js\").Coordinate} dSrc The source d coordinate.\n * @param {number} maxSubdivision Maximal allowed subdivision of the quad.\n * @private\n */\n Triangulation.prototype.addQuad_ = function (a, b, c, d, aSrc, bSrc, cSrc, dSrc, maxSubdivision) {\n var sourceQuadExtent = boundingExtent([aSrc, bSrc, cSrc, dSrc]);\n var sourceCoverageX = this.sourceWorldWidth_\n ? getWidth(sourceQuadExtent) / this.sourceWorldWidth_\n : null;\n var sourceWorldWidth = /** @type {number} */ (this.sourceWorldWidth_);\n // when the quad is wrapped in the source projection\n // it covers most of the projection extent, but not fully\n var wrapsX = this.sourceProj_.canWrapX() &&\n sourceCoverageX > 0.5 &&\n sourceCoverageX < 1;\n var needsSubdivision = false;\n if (maxSubdivision > 0) {\n if (this.targetProj_.isGlobal() && this.targetWorldWidth_) {\n var targetQuadExtent = boundingExtent([a, b, c, d]);\n var targetCoverageX = getWidth(targetQuadExtent) / this.targetWorldWidth_;\n needsSubdivision =\n targetCoverageX > MAX_TRIANGLE_WIDTH || needsSubdivision;\n }\n if (!wrapsX && this.sourceProj_.isGlobal() && sourceCoverageX) {\n needsSubdivision =\n sourceCoverageX > MAX_TRIANGLE_WIDTH || needsSubdivision;\n }\n }\n if (!needsSubdivision && this.maxSourceExtent_) {\n if (isFinite(sourceQuadExtent[0]) &&\n isFinite(sourceQuadExtent[1]) &&\n isFinite(sourceQuadExtent[2]) &&\n isFinite(sourceQuadExtent[3])) {\n if (!intersects(sourceQuadExtent, this.maxSourceExtent_)) {\n // whole quad outside source projection extent -> ignore\n return;\n }\n }\n }\n var isNotFinite = 0;\n if (!needsSubdivision) {\n if (!isFinite(aSrc[0]) ||\n !isFinite(aSrc[1]) ||\n !isFinite(bSrc[0]) ||\n !isFinite(bSrc[1]) ||\n !isFinite(cSrc[0]) ||\n !isFinite(cSrc[1]) ||\n !isFinite(dSrc[0]) ||\n !isFinite(dSrc[1])) {\n if (maxSubdivision > 0) {\n needsSubdivision = true;\n }\n else {\n // It might be the case that only 1 of the points is infinite. In this case\n // we can draw a single triangle with the other three points\n isNotFinite =\n (!isFinite(aSrc[0]) || !isFinite(aSrc[1]) ? 8 : 0) +\n (!isFinite(bSrc[0]) || !isFinite(bSrc[1]) ? 4 : 0) +\n (!isFinite(cSrc[0]) || !isFinite(cSrc[1]) ? 2 : 0) +\n (!isFinite(dSrc[0]) || !isFinite(dSrc[1]) ? 1 : 0);\n if (isNotFinite != 1 &&\n isNotFinite != 2 &&\n isNotFinite != 4 &&\n isNotFinite != 8) {\n return;\n }\n }\n }\n }\n if (maxSubdivision > 0) {\n if (!needsSubdivision) {\n var center = [(a[0] + c[0]) / 2, (a[1] + c[1]) / 2];\n var centerSrc = this.transformInv_(center);\n var dx = void 0;\n if (wrapsX) {\n var centerSrcEstimX = (modulo(aSrc[0], sourceWorldWidth) +\n modulo(cSrc[0], sourceWorldWidth)) /\n 2;\n dx = centerSrcEstimX - modulo(centerSrc[0], sourceWorldWidth);\n }\n else {\n dx = (aSrc[0] + cSrc[0]) / 2 - centerSrc[0];\n }\n var dy = (aSrc[1] + cSrc[1]) / 2 - centerSrc[1];\n var centerSrcErrorSquared = dx * dx + dy * dy;\n needsSubdivision = centerSrcErrorSquared > this.errorThresholdSquared_;\n }\n if (needsSubdivision) {\n if (Math.abs(a[0] - c[0]) <= Math.abs(a[1] - c[1])) {\n // split horizontally (top & bottom)\n var bc = [(b[0] + c[0]) / 2, (b[1] + c[1]) / 2];\n var bcSrc = this.transformInv_(bc);\n var da = [(d[0] + a[0]) / 2, (d[1] + a[1]) / 2];\n var daSrc = this.transformInv_(da);\n this.addQuad_(a, b, bc, da, aSrc, bSrc, bcSrc, daSrc, maxSubdivision - 1);\n this.addQuad_(da, bc, c, d, daSrc, bcSrc, cSrc, dSrc, maxSubdivision - 1);\n }\n else {\n // split vertically (left & right)\n var ab = [(a[0] + b[0]) / 2, (a[1] + b[1]) / 2];\n var abSrc = this.transformInv_(ab);\n var cd = [(c[0] + d[0]) / 2, (c[1] + d[1]) / 2];\n var cdSrc = this.transformInv_(cd);\n this.addQuad_(a, ab, cd, d, aSrc, abSrc, cdSrc, dSrc, maxSubdivision - 1);\n this.addQuad_(ab, b, c, cd, abSrc, bSrc, cSrc, cdSrc, maxSubdivision - 1);\n }\n return;\n }\n }\n if (wrapsX) {\n if (!this.canWrapXInSource_) {\n return;\n }\n this.wrapsXInSource_ = true;\n }\n // Exactly zero or one of *Src is not finite\n // The triangles must have the diagonal line as the first side\n // This is to allow easy code in reproj.s to make it straight for broken\n // browsers that can't handle diagonal clipping\n if ((isNotFinite & 0xb) == 0) {\n this.addTriangle_(a, c, d, aSrc, cSrc, dSrc);\n }\n if ((isNotFinite & 0xe) == 0) {\n this.addTriangle_(a, c, b, aSrc, cSrc, bSrc);\n }\n if (isNotFinite) {\n // Try the other two triangles\n if ((isNotFinite & 0xd) == 0) {\n this.addTriangle_(b, d, a, bSrc, dSrc, aSrc);\n }\n if ((isNotFinite & 0x7) == 0) {\n this.addTriangle_(b, d, c, bSrc, dSrc, cSrc);\n }\n }\n };\n /**\n * Calculates extent of the 'source' coordinates from all the triangles.\n *\n * @return {import(\"../extent.js\").Extent} Calculated extent.\n */\n Triangulation.prototype.calculateSourceExtent = function () {\n var extent = createEmpty();\n this.triangles_.forEach(function (triangle, i, arr) {\n var src = triangle.source;\n extendCoordinate(extent, src[0]);\n extendCoordinate(extent, src[1]);\n extendCoordinate(extent, src[2]);\n });\n return extent;\n };\n /**\n * @return {Array<Triangle>} Array of the calculated triangles.\n */\n Triangulation.prototype.getTriangles = function () {\n return this.triangles_;\n };\n return Triangulation;\n}());\nexport default Triangulation;\n//# sourceMappingURL=Triangulation.js.map","/**\n * @module ol/source/common\n */\n/**\n * Default WMS version.\n * @type {string}\n */\nexport var DEFAULT_WMS_VERSION = '1.3.0';\n/**\n * Context options to disable image smoothing.\n * @type {Object}\n */\nexport var IMAGE_SMOOTHING_DISABLED = {\n imageSmoothingEnabled: false,\n msImageSmoothingEnabled: false,\n};\n//# sourceMappingURL=common.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/reproj/Tile\n */\nimport { ERROR_THRESHOLD } from './common.js';\nimport EventType from '../events/EventType.js';\nimport Tile from '../Tile.js';\nimport TileState from '../TileState.js';\nimport Triangulation from './Triangulation.js';\nimport { calculateSourceExtentResolution, render as renderReprojected, } from '../reproj.js';\nimport { clamp } from '../math.js';\nimport { getArea, getIntersection } from '../extent.js';\nimport { listen, unlistenByKey } from '../events.js';\n/**\n * @typedef {function(number, number, number, number) : import(\"../Tile.js\").default} FunctionType\n */\n/**\n * @classdesc\n * Class encapsulating single reprojected tile.\n * See {@link module:ol/source/TileImage~TileImage}.\n *\n */\nvar ReprojTile = /** @class */ (function (_super) {\n __extends(ReprojTile, _super);\n /**\n * @param {import(\"../proj/Projection.js\").default} sourceProj Source projection.\n * @param {import(\"../tilegrid/TileGrid.js\").default} sourceTileGrid Source tile grid.\n * @param {import(\"../proj/Projection.js\").default} targetProj Target projection.\n * @param {import(\"../tilegrid/TileGrid.js\").default} targetTileGrid Target tile grid.\n * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Coordinate of the tile.\n * @param {import(\"../tilecoord.js\").TileCoord} wrappedTileCoord Coordinate of the tile wrapped in X.\n * @param {number} pixelRatio Pixel ratio.\n * @param {number} gutter Gutter of the source tiles.\n * @param {FunctionType} getTileFunction\n * Function returning source tiles (z, x, y, pixelRatio).\n * @param {number} [opt_errorThreshold] Acceptable reprojection error (in px).\n * @param {boolean} [opt_renderEdges] Render reprojection edges.\n * @param {object} [opt_contextOptions] Properties to set on the canvas context.\n */\n function ReprojTile(sourceProj, sourceTileGrid, targetProj, targetTileGrid, tileCoord, wrappedTileCoord, pixelRatio, gutter, getTileFunction, opt_errorThreshold, opt_renderEdges, opt_contextOptions) {\n var _this = _super.call(this, tileCoord, TileState.IDLE) || this;\n /**\n * @private\n * @type {boolean}\n */\n _this.renderEdges_ = opt_renderEdges !== undefined ? opt_renderEdges : false;\n /**\n * @private\n * @type {object}\n */\n _this.contextOptions_ = opt_contextOptions;\n /**\n * @private\n * @type {number}\n */\n _this.pixelRatio_ = pixelRatio;\n /**\n * @private\n * @type {number}\n */\n _this.gutter_ = gutter;\n /**\n * @private\n * @type {HTMLCanvasElement}\n */\n _this.canvas_ = null;\n /**\n * @private\n * @type {import(\"../tilegrid/TileGrid.js\").default}\n */\n _this.sourceTileGrid_ = sourceTileGrid;\n /**\n * @private\n * @type {import(\"../tilegrid/TileGrid.js\").default}\n */\n _this.targetTileGrid_ = targetTileGrid;\n /**\n * @private\n * @type {import(\"../tilecoord.js\").TileCoord}\n */\n _this.wrappedTileCoord_ = wrappedTileCoord ? wrappedTileCoord : tileCoord;\n /**\n * @private\n * @type {!Array<import(\"../Tile.js\").default>}\n */\n _this.sourceTiles_ = [];\n /**\n * @private\n * @type {?Array<import(\"../events.js\").EventsKey>}\n */\n _this.sourcesListenerKeys_ = null;\n /**\n * @private\n * @type {number}\n */\n _this.sourceZ_ = 0;\n var targetExtent = targetTileGrid.getTileCoordExtent(_this.wrappedTileCoord_);\n var maxTargetExtent = _this.targetTileGrid_.getExtent();\n var maxSourceExtent = _this.sourceTileGrid_.getExtent();\n var limitedTargetExtent = maxTargetExtent\n ? getIntersection(targetExtent, maxTargetExtent)\n : targetExtent;\n if (getArea(limitedTargetExtent) === 0) {\n // Tile is completely outside range -> EMPTY\n // TODO: is it actually correct that the source even creates the tile ?\n _this.state = TileState.EMPTY;\n return _this;\n }\n var sourceProjExtent = sourceProj.getExtent();\n if (sourceProjExtent) {\n if (!maxSourceExtent) {\n maxSourceExtent = sourceProjExtent;\n }\n else {\n maxSourceExtent = getIntersection(maxSourceExtent, sourceProjExtent);\n }\n }\n var targetResolution = targetTileGrid.getResolution(_this.wrappedTileCoord_[0]);\n var sourceResolution = calculateSourceExtentResolution(sourceProj, targetProj, limitedTargetExtent, targetResolution);\n if (!isFinite(sourceResolution) || sourceResolution <= 0) {\n // invalid sourceResolution -> EMPTY\n // probably edges of the projections when no extent is defined\n _this.state = TileState.EMPTY;\n return _this;\n }\n var errorThresholdInPixels = opt_errorThreshold !== undefined ? opt_errorThreshold : ERROR_THRESHOLD;\n /**\n * @private\n * @type {!import(\"./Triangulation.js\").default}\n */\n _this.triangulation_ = new Triangulation(sourceProj, targetProj, limitedTargetExtent, maxSourceExtent, sourceResolution * errorThresholdInPixels, targetResolution);\n if (_this.triangulation_.getTriangles().length === 0) {\n // no valid triangles -> EMPTY\n _this.state = TileState.EMPTY;\n return _this;\n }\n _this.sourceZ_ = sourceTileGrid.getZForResolution(sourceResolution);\n var sourceExtent = _this.triangulation_.calculateSourceExtent();\n if (maxSourceExtent) {\n if (sourceProj.canWrapX()) {\n sourceExtent[1] = clamp(sourceExtent[1], maxSourceExtent[1], maxSourceExtent[3]);\n sourceExtent[3] = clamp(sourceExtent[3], maxSourceExtent[1], maxSourceExtent[3]);\n }\n else {\n sourceExtent = getIntersection(sourceExtent, maxSourceExtent);\n }\n }\n if (!getArea(sourceExtent)) {\n _this.state = TileState.EMPTY;\n }\n else {\n var sourceRange = sourceTileGrid.getTileRangeForExtentAndZ(sourceExtent, _this.sourceZ_);\n for (var srcX = sourceRange.minX; srcX <= sourceRange.maxX; srcX++) {\n for (var srcY = sourceRange.minY; srcY <= sourceRange.maxY; srcY++) {\n var tile = getTileFunction(_this.sourceZ_, srcX, srcY, pixelRatio);\n if (tile) {\n _this.sourceTiles_.push(tile);\n }\n }\n }\n if (_this.sourceTiles_.length === 0) {\n _this.state = TileState.EMPTY;\n }\n }\n return _this;\n }\n /**\n * Get the HTML Canvas element for this tile.\n * @return {HTMLCanvasElement} Canvas.\n */\n ReprojTile.prototype.getImage = function () {\n return this.canvas_;\n };\n /**\n * @private\n */\n ReprojTile.prototype.reproject_ = function () {\n var sources = [];\n this.sourceTiles_.forEach(function (tile, i, arr) {\n if (tile && tile.getState() == TileState.LOADED) {\n sources.push({\n extent: this.sourceTileGrid_.getTileCoordExtent(tile.tileCoord),\n image: tile.getImage(),\n });\n }\n }.bind(this));\n this.sourceTiles_.length = 0;\n if (sources.length === 0) {\n this.state = TileState.ERROR;\n }\n else {\n var z = this.wrappedTileCoord_[0];\n var size = this.targetTileGrid_.getTileSize(z);\n var width = typeof size === 'number' ? size : size[0];\n var height = typeof size === 'number' ? size : size[1];\n var targetResolution = this.targetTileGrid_.getResolution(z);\n var sourceResolution = this.sourceTileGrid_.getResolution(this.sourceZ_);\n var targetExtent = this.targetTileGrid_.getTileCoordExtent(this.wrappedTileCoord_);\n this.canvas_ = renderReprojected(width, height, this.pixelRatio_, sourceResolution, this.sourceTileGrid_.getExtent(), targetResolution, targetExtent, this.triangulation_, sources, this.gutter_, this.renderEdges_, this.contextOptions_);\n this.state = TileState.LOADED;\n }\n this.changed();\n };\n /**\n * Load not yet loaded URI.\n */\n ReprojTile.prototype.load = function () {\n if (this.state == TileState.IDLE) {\n this.state = TileState.LOADING;\n this.changed();\n var leftToLoad_1 = 0;\n this.sourcesListenerKeys_ = [];\n this.sourceTiles_.forEach(function (tile, i, arr) {\n var state = tile.getState();\n if (state == TileState.IDLE || state == TileState.LOADING) {\n leftToLoad_1++;\n var sourceListenKey_1 = listen(tile, EventType.CHANGE, function (e) {\n var state = tile.getState();\n if (state == TileState.LOADED ||\n state == TileState.ERROR ||\n state == TileState.EMPTY) {\n unlistenByKey(sourceListenKey_1);\n leftToLoad_1--;\n if (leftToLoad_1 === 0) {\n this.unlistenSources_();\n this.reproject_();\n }\n }\n }, this);\n this.sourcesListenerKeys_.push(sourceListenKey_1);\n }\n }.bind(this));\n if (leftToLoad_1 === 0) {\n setTimeout(this.reproject_.bind(this), 0);\n }\n else {\n this.sourceTiles_.forEach(function (tile, i, arr) {\n var state = tile.getState();\n if (state == TileState.IDLE) {\n tile.load();\n }\n });\n }\n }\n };\n /**\n * @private\n */\n ReprojTile.prototype.unlistenSources_ = function () {\n this.sourcesListenerKeys_.forEach(unlistenByKey);\n this.sourcesListenerKeys_ = null;\n };\n return ReprojTile;\n}(Tile));\nexport default ReprojTile;\n//# sourceMappingURL=Tile.js.map","/**\n * @module ol/reproj/common\n */\n/**\n * Default maximum allowed threshold (in pixels) for reprojection\n * triangulation.\n * @type {number}\n */\nexport var ERROR_THRESHOLD = 0.5;\n/**\n * Enable automatic reprojection of raster sources. Default is `true`.\n * TODO: decide if we want to expose this as a build flag or remove it\n * @type {boolean}\n */\nexport var ENABLE_RASTER_REPROJECTION = true;\n//# sourceMappingURL=common.js.map","/**\n * @module ol/structs/LRUCache\n */\nimport { assert } from '../asserts.js';\n/**\n * @typedef {Object} Entry\n * @property {string} key_ Key.\n * @property {Object} newer Newer.\n * @property {Object} older Older.\n * @property {*} value_ Value.\n */\n/**\n * @classdesc\n * Implements a Least-Recently-Used cache where the keys do not conflict with\n * Object's properties (e.g. 'hasOwnProperty' is not allowed as a key). Expiring\n * items from the cache is the responsibility of the user.\n *\n * @fires import(\"../events/Event.js\").default\n * @template T\n */\nvar LRUCache = /** @class */ (function () {\n /**\n * @param {number} [opt_highWaterMark] High water mark.\n */\n function LRUCache(opt_highWaterMark) {\n /**\n * Desired max cache size after expireCache(). If set to 0, no cache entries\n * will be pruned at all.\n * @type {number}\n */\n this.highWaterMark =\n opt_highWaterMark !== undefined ? opt_highWaterMark : 2048;\n /**\n * @private\n * @type {number}\n */\n this.count_ = 0;\n /**\n * @private\n * @type {!Object<string, Entry>}\n */\n this.entries_ = {};\n /**\n * @private\n * @type {?Entry}\n */\n this.oldest_ = null;\n /**\n * @private\n * @type {?Entry}\n */\n this.newest_ = null;\n }\n /**\n * @return {boolean} Can expire cache.\n */\n LRUCache.prototype.canExpireCache = function () {\n return this.highWaterMark > 0 && this.getCount() > this.highWaterMark;\n };\n /**\n * FIXME empty description for jsdoc\n */\n LRUCache.prototype.clear = function () {\n this.count_ = 0;\n this.entries_ = {};\n this.oldest_ = null;\n this.newest_ = null;\n };\n /**\n * @param {string} key Key.\n * @return {boolean} Contains key.\n */\n LRUCache.prototype.containsKey = function (key) {\n return this.entries_.hasOwnProperty(key);\n };\n /**\n * @param {function(T, string, LRUCache<T>): ?} f The function\n * to call for every entry from the oldest to the newer. This function takes\n * 3 arguments (the entry value, the entry key and the LRUCache object).\n * The return value is ignored.\n */\n LRUCache.prototype.forEach = function (f) {\n var entry = this.oldest_;\n while (entry) {\n f(entry.value_, entry.key_, this);\n entry = entry.newer;\n }\n };\n /**\n * @param {string} key Key.\n * @param {*} [opt_options] Options (reserved for subclasses).\n * @return {T} Value.\n */\n LRUCache.prototype.get = function (key, opt_options) {\n var entry = this.entries_[key];\n assert(entry !== undefined, 15); // Tried to get a value for a key that does not exist in the cache\n if (entry === this.newest_) {\n return entry.value_;\n }\n else if (entry === this.oldest_) {\n this.oldest_ = /** @type {Entry} */ (this.oldest_.newer);\n this.oldest_.older = null;\n }\n else {\n entry.newer.older = entry.older;\n entry.older.newer = entry.newer;\n }\n entry.newer = null;\n entry.older = this.newest_;\n this.newest_.newer = entry;\n this.newest_ = entry;\n return entry.value_;\n };\n /**\n * Remove an entry from the cache.\n * @param {string} key The entry key.\n * @return {T} The removed entry.\n */\n LRUCache.prototype.remove = function (key) {\n var entry = this.entries_[key];\n assert(entry !== undefined, 15); // Tried to get a value for a key that does not exist in the cache\n if (entry === this.newest_) {\n this.newest_ = /** @type {Entry} */ (entry.older);\n if (this.newest_) {\n this.newest_.newer = null;\n }\n }\n else if (entry === this.oldest_) {\n this.oldest_ = /** @type {Entry} */ (entry.newer);\n if (this.oldest_) {\n this.oldest_.older = null;\n }\n }\n else {\n entry.newer.older = entry.older;\n entry.older.newer = entry.newer;\n }\n delete this.entries_[key];\n --this.count_;\n return entry.value_;\n };\n /**\n * @return {number} Count.\n */\n LRUCache.prototype.getCount = function () {\n return this.count_;\n };\n /**\n * @return {Array<string>} Keys.\n */\n LRUCache.prototype.getKeys = function () {\n var keys = new Array(this.count_);\n var i = 0;\n var entry;\n for (entry = this.newest_; entry; entry = entry.older) {\n keys[i++] = entry.key_;\n }\n return keys;\n };\n /**\n * @return {Array<T>} Values.\n */\n LRUCache.prototype.getValues = function () {\n var values = new Array(this.count_);\n var i = 0;\n var entry;\n for (entry = this.newest_; entry; entry = entry.older) {\n values[i++] = entry.value_;\n }\n return values;\n };\n /**\n * @return {T} Last value.\n */\n LRUCache.prototype.peekLast = function () {\n return this.oldest_.value_;\n };\n /**\n * @return {string} Last key.\n */\n LRUCache.prototype.peekLastKey = function () {\n return this.oldest_.key_;\n };\n /**\n * Get the key of the newest item in the cache. Throws if the cache is empty.\n * @return {string} The newest key.\n */\n LRUCache.prototype.peekFirstKey = function () {\n return this.newest_.key_;\n };\n /**\n * @return {T} value Value.\n */\n LRUCache.prototype.pop = function () {\n var entry = this.oldest_;\n delete this.entries_[entry.key_];\n if (entry.newer) {\n entry.newer.older = null;\n }\n this.oldest_ = /** @type {Entry} */ (entry.newer);\n if (!this.oldest_) {\n this.newest_ = null;\n }\n --this.count_;\n return entry.value_;\n };\n /**\n * @param {string} key Key.\n * @param {T} value Value.\n */\n LRUCache.prototype.replace = function (key, value) {\n this.get(key); // update `newest_`\n this.entries_[key].value_ = value;\n };\n /**\n * @param {string} key Key.\n * @param {T} value Value.\n */\n LRUCache.prototype.set = function (key, value) {\n assert(!(key in this.entries_), 16); // Tried to set a value for a key that is used already\n var entry = {\n key_: key,\n newer: null,\n older: this.newest_,\n value_: value,\n };\n if (!this.newest_) {\n this.oldest_ = entry;\n }\n else {\n this.newest_.newer = entry;\n }\n this.newest_ = entry;\n this.entries_[key] = entry;\n ++this.count_;\n };\n /**\n * Set a maximum number of entries for the cache.\n * @param {number} size Cache size.\n * @api\n */\n LRUCache.prototype.setSize = function (size) {\n this.highWaterMark = size;\n };\n return LRUCache;\n}());\nexport default LRUCache;\n//# sourceMappingURL=LRUCache.js.map","/**\n * @module ol/tilecoord\n */\n/**\n * An array of three numbers representing the location of a tile in a tile\n * grid. The order is `z` (zoom level), `x` (column), and `y` (row).\n * @typedef {Array<number>} TileCoord\n * @api\n */\n/**\n * @param {number} z Z.\n * @param {number} x X.\n * @param {number} y Y.\n * @param {TileCoord} [opt_tileCoord] Tile coordinate.\n * @return {TileCoord} Tile coordinate.\n */\nexport function createOrUpdate(z, x, y, opt_tileCoord) {\n if (opt_tileCoord !== undefined) {\n opt_tileCoord[0] = z;\n opt_tileCoord[1] = x;\n opt_tileCoord[2] = y;\n return opt_tileCoord;\n }\n else {\n return [z, x, y];\n }\n}\n/**\n * @param {number} z Z.\n * @param {number} x X.\n * @param {number} y Y.\n * @return {string} Key.\n */\nexport function getKeyZXY(z, x, y) {\n return z + '/' + x + '/' + y;\n}\n/**\n * Get the key for a tile coord.\n * @param {TileCoord} tileCoord The tile coord.\n * @return {string} Key.\n */\nexport function getKey(tileCoord) {\n return getKeyZXY(tileCoord[0], tileCoord[1], tileCoord[2]);\n}\n/**\n * Get the tile cache key for a tile key obtained through `tile.getKey()`.\n * @param {string} tileKey The tile key.\n * @return {string} The cache key.\n */\nexport function getCacheKeyForTileKey(tileKey) {\n var _a = tileKey\n .substring(tileKey.lastIndexOf('/') + 1, tileKey.length)\n .split(',')\n .map(Number), z = _a[0], x = _a[1], y = _a[2];\n return getKeyZXY(z, x, y);\n}\n/**\n * Get a tile coord given a key.\n * @param {string} key The tile coord key.\n * @return {TileCoord} The tile coord.\n */\nexport function fromKey(key) {\n return key.split('/').map(Number);\n}\n/**\n * @param {TileCoord} tileCoord Tile coord.\n * @return {number} Hash.\n */\nexport function hash(tileCoord) {\n return (tileCoord[1] << tileCoord[0]) + tileCoord[2];\n}\n/**\n * @param {TileCoord} tileCoord Tile coordinate.\n * @param {!import(\"./tilegrid/TileGrid.js\").default} tileGrid Tile grid.\n * @return {boolean} Tile coordinate is within extent and zoom level range.\n */\nexport function withinExtentAndZ(tileCoord, tileGrid) {\n var z = tileCoord[0];\n var x = tileCoord[1];\n var y = tileCoord[2];\n if (tileGrid.getMinZoom() > z || z > tileGrid.getMaxZoom()) {\n return false;\n }\n var tileRange = tileGrid.getFullTileRange(z);\n if (!tileRange) {\n return true;\n }\n else {\n return tileRange.containsXY(x, y);\n }\n}\n//# sourceMappingURL=tilecoord.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/TileCache\n */\nimport LRUCache from './structs/LRUCache.js';\nimport { fromKey, getKey } from './tilecoord.js';\nvar TileCache = /** @class */ (function (_super) {\n __extends(TileCache, _super);\n function TileCache() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n /**\n * @param {!Object<string, boolean>} usedTiles Used tiles.\n */\n TileCache.prototype.expireCache = function (usedTiles) {\n while (this.canExpireCache()) {\n var tile = this.peekLast();\n if (tile.getKey() in usedTiles) {\n break;\n }\n else {\n this.pop().release();\n }\n }\n };\n /**\n * Prune all tiles from the cache that don't have the same z as the newest tile.\n */\n TileCache.prototype.pruneExceptNewestZ = function () {\n if (this.getCount() === 0) {\n return;\n }\n var key = this.peekFirstKey();\n var tileCoord = fromKey(key);\n var z = tileCoord[0];\n this.forEach(function (tile) {\n if (tile.tileCoord[0] !== z) {\n this.remove(getKey(tile.tileCoord));\n tile.release();\n }\n }.bind(this));\n };\n return TileCache;\n}(LRUCache));\nexport default TileCache;\n//# sourceMappingURL=TileCache.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/source/Source\n */\nimport BaseObject from '../Object.js';\nimport SourceState from './State.js';\nimport { abstract } from '../util.js';\nimport { get as getProjection } from '../proj.js';\n/**\n * A function that takes a {@link module:ol/PluggableMap~FrameState} and returns a string or\n * an array of strings representing source attributions.\n *\n * @typedef {function(import(\"../PluggableMap.js\").FrameState): (string|Array<string>)} Attribution\n */\n/**\n * A type that can be used to provide attribution information for data sources.\n *\n * It represents either\n * * a simple string (e.g. `'© Acme Inc.'`)\n * * an array of simple strings (e.g. `['© Acme Inc.', '© Bacme Inc.']`)\n * * a function that returns a string or array of strings ({@link module:ol/source/Source~Attribution})\n *\n * @typedef {string|Array<string>|Attribution} AttributionLike\n */\n/**\n * @typedef {Object} Options\n * @property {AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is the view projection.\n * @property {import(\"./State.js\").default} [state='ready'] State.\n * @property {boolean} [wrapX=false] WrapX.\n */\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * Base class for {@link module:ol/layer/Layer~Layer} sources.\n *\n * A generic `change` event is triggered when the state of the source changes.\n * @abstract\n * @api\n */\nvar Source = /** @class */ (function (_super) {\n __extends(Source, _super);\n /**\n * @param {Options} options Source options.\n */\n function Source(options) {\n var _this = _super.call(this) || this;\n /**\n * @protected\n * @type {import(\"../proj/Projection.js\").default}\n */\n _this.projection = getProjection(options.projection);\n /**\n * @private\n * @type {?Attribution}\n */\n _this.attributions_ = adaptAttributions(options.attributions);\n /**\n * @private\n * @type {boolean}\n */\n _this.attributionsCollapsible_ =\n options.attributionsCollapsible !== undefined\n ? options.attributionsCollapsible\n : true;\n /**\n * This source is currently loading data. Sources that defer loading to the\n * map's tile queue never set this to `true`.\n * @type {boolean}\n */\n _this.loading = false;\n /**\n * @private\n * @type {import(\"./State.js\").default}\n */\n _this.state_ =\n options.state !== undefined ? options.state : SourceState.READY;\n /**\n * @private\n * @type {boolean}\n */\n _this.wrapX_ = options.wrapX !== undefined ? options.wrapX : false;\n /**\n * @protected\n * @type {function(import(\"../View.js\").ViewOptions):void}\n */\n _this.viewResolver = null;\n /**\n * @protected\n * @type {function(Error):void}\n */\n _this.viewRejector = null;\n var self = _this;\n /**\n * @private\n * @type {Promise<import(\"../View.js\").ViewOptions>}\n */\n _this.viewPromise_ = new Promise(function (resolve, reject) {\n self.viewResolver = resolve;\n self.viewRejector = reject;\n });\n return _this;\n }\n /**\n * Get the attribution function for the source.\n * @return {?Attribution} Attribution function.\n * @api\n */\n Source.prototype.getAttributions = function () {\n return this.attributions_;\n };\n /**\n * @return {boolean} Attributions are collapsible.\n * @api\n */\n Source.prototype.getAttributionsCollapsible = function () {\n return this.attributionsCollapsible_;\n };\n /**\n * Get the projection of the source.\n * @return {import(\"../proj/Projection.js\").default} Projection.\n * @api\n */\n Source.prototype.getProjection = function () {\n return this.projection;\n };\n /**\n * @abstract\n * @return {Array<number>|undefined} Resolutions.\n */\n Source.prototype.getResolutions = function () {\n return abstract();\n };\n /**\n * @return {Promise<import(\"../View.js\").ViewOptions>} A promise for view-related properties.\n */\n Source.prototype.getView = function () {\n return this.viewPromise_;\n };\n /**\n * Get the state of the source, see {@link module:ol/source/State~State} for possible states.\n * @return {import(\"./State.js\").default} State.\n * @api\n */\n Source.prototype.getState = function () {\n return this.state_;\n };\n /**\n * @return {boolean|undefined} Wrap X.\n */\n Source.prototype.getWrapX = function () {\n return this.wrapX_;\n };\n /**\n * @return {Object|undefined} Context options.\n */\n Source.prototype.getContextOptions = function () {\n return undefined;\n };\n /**\n * Refreshes the source. The source will be cleared, and data from the server will be reloaded.\n * @api\n */\n Source.prototype.refresh = function () {\n this.changed();\n };\n /**\n * Set the attributions of the source.\n * @param {AttributionLike|undefined} attributions Attributions.\n * Can be passed as `string`, `Array<string>`, {@link module:ol/source/Source~Attribution},\n * or `undefined`.\n * @api\n */\n Source.prototype.setAttributions = function (attributions) {\n this.attributions_ = adaptAttributions(attributions);\n this.changed();\n };\n /**\n * Set the state of the source.\n * @param {import(\"./State.js\").default} state State.\n */\n Source.prototype.setState = function (state) {\n this.state_ = state;\n this.changed();\n };\n return Source;\n}(BaseObject));\n/**\n * Turns the attributions option into an attributions function.\n * @param {AttributionLike|undefined} attributionLike The attribution option.\n * @return {?Attribution} An attribution function (or null).\n */\nfunction adaptAttributions(attributionLike) {\n if (!attributionLike) {\n return null;\n }\n if (Array.isArray(attributionLike)) {\n return function (frameState) {\n return attributionLike;\n };\n }\n if (typeof attributionLike === 'function') {\n return attributionLike;\n }\n return function (frameState) {\n return [attributionLike];\n };\n}\nexport default Source;\n//# sourceMappingURL=Source.js.map","/**\n * @module ol/tilegrid/common\n */\n/**\n * Default maximum zoom for default tile grids.\n * @type {number}\n */\nexport var DEFAULT_MAX_ZOOM = 42;\n/**\n * Default tile size.\n * @type {number}\n */\nexport var DEFAULT_TILE_SIZE = 256;\n//# sourceMappingURL=common.js.map","/**\n * @module ol/tilegrid/TileGrid\n */\nimport TileRange, { createOrUpdate as createOrUpdateTileRange, } from '../TileRange.js';\nimport { DEFAULT_TILE_SIZE } from './common.js';\nimport { assert } from '../asserts.js';\nimport { clamp } from '../math.js';\nimport { createOrUpdate, getTopLeft } from '../extent.js';\nimport { createOrUpdate as createOrUpdateTileCoord } from '../tilecoord.js';\nimport { isSorted, linearFindNearest } from '../array.js';\nimport { toSize } from '../size.js';\n/**\n * @private\n * @type {import(\"../tilecoord.js\").TileCoord}\n */\nvar tmpTileCoord = [0, 0, 0];\n/**\n * @typedef {Object} Options\n * @property {import(\"../extent.js\").Extent} [extent] Extent for the tile grid. No tiles outside this\n * extent will be requested by {@link module:ol/source/Tile} sources. When no `origin` or\n * `origins` are configured, the `origin` will be set to the top-left corner of the extent.\n * @property {number} [minZoom=0] Minimum zoom.\n * @property {import(\"../coordinate.js\").Coordinate} [origin] The tile grid origin, i.e. where the `x`\n * and `y` axes meet (`[z, 0, 0]`). Tile coordinates increase left to right and downwards. If not\n * specified, `extent` or `origins` must be provided.\n * @property {Array<import(\"../coordinate.js\").Coordinate>} [origins] Tile grid origins, i.e. where\n * the `x` and `y` axes meet (`[z, 0, 0]`), for each zoom level. If given, the array length\n * should match the length of the `resolutions` array, i.e. each resolution can have a different\n * origin. Tile coordinates increase left to right and downwards. If not specified, `extent` or\n * `origin` must be provided.\n * @property {!Array<number>} resolutions Resolutions. The array index of each resolution needs\n * to match the zoom level. This means that even if a `minZoom` is configured, the resolutions\n * array will have a length of `maxZoom + 1`.\n * @property {Array<import(\"../size.js\").Size>} [sizes] Number of tile rows and columns\n * of the grid for each zoom level. If specified the values\n * define each zoom level's extent together with the `origin` or `origins`.\n * A grid `extent` can be configured in addition, and will further limit the extent\n * for which tile requests are made by sources. If the bottom-left corner of\n * an extent is used as `origin` or `origins`, then the `y` value must be\n * negative because OpenLayers tile coordinates use the top left as the origin.\n * @property {number|import(\"../size.js\").Size} [tileSize] Tile size.\n * Default is `[256, 256]`.\n * @property {Array<import(\"../size.js\").Size>} [tileSizes] Tile sizes. If given, the array length\n * should match the length of the `resolutions` array, i.e. each resolution can have a different\n * tile size.\n */\n/**\n * @classdesc\n * Base class for setting the grid pattern for sources accessing tiled-image\n * servers.\n * @api\n */\nvar TileGrid = /** @class */ (function () {\n /**\n * @param {Options} options Tile grid options.\n */\n function TileGrid(options) {\n /**\n * @protected\n * @type {number}\n */\n this.minZoom = options.minZoom !== undefined ? options.minZoom : 0;\n /**\n * @private\n * @type {!Array<number>}\n */\n this.resolutions_ = options.resolutions;\n assert(isSorted(this.resolutions_, function (a, b) {\n return b - a;\n }, true), 17); // `resolutions` must be sorted in descending order\n // check if we've got a consistent zoom factor and origin\n var zoomFactor;\n if (!options.origins) {\n for (var i = 0, ii = this.resolutions_.length - 1; i < ii; ++i) {\n if (!zoomFactor) {\n zoomFactor = this.resolutions_[i] / this.resolutions_[i + 1];\n }\n else {\n if (this.resolutions_[i] / this.resolutions_[i + 1] !== zoomFactor) {\n zoomFactor = undefined;\n break;\n }\n }\n }\n }\n /**\n * @private\n * @type {number|undefined}\n */\n this.zoomFactor_ = zoomFactor;\n /**\n * @protected\n * @type {number}\n */\n this.maxZoom = this.resolutions_.length - 1;\n /**\n * @private\n * @type {import(\"../coordinate.js\").Coordinate}\n */\n this.origin_ = options.origin !== undefined ? options.origin : null;\n /**\n * @private\n * @type {Array<import(\"../coordinate.js\").Coordinate>}\n */\n this.origins_ = null;\n if (options.origins !== undefined) {\n this.origins_ = options.origins;\n assert(this.origins_.length == this.resolutions_.length, 20); // Number of `origins` and `resolutions` must be equal\n }\n var extent = options.extent;\n if (extent !== undefined && !this.origin_ && !this.origins_) {\n this.origin_ = getTopLeft(extent);\n }\n assert((!this.origin_ && this.origins_) || (this.origin_ && !this.origins_), 18); // Either `origin` or `origins` must be configured, never both\n /**\n * @private\n * @type {Array<number|import(\"../size.js\").Size>}\n */\n this.tileSizes_ = null;\n if (options.tileSizes !== undefined) {\n this.tileSizes_ = options.tileSizes;\n assert(this.tileSizes_.length == this.resolutions_.length, 19); // Number of `tileSizes` and `resolutions` must be equal\n }\n /**\n * @private\n * @type {number|import(\"../size.js\").Size}\n */\n this.tileSize_ =\n options.tileSize !== undefined\n ? options.tileSize\n : !this.tileSizes_\n ? DEFAULT_TILE_SIZE\n : null;\n assert((!this.tileSize_ && this.tileSizes_) ||\n (this.tileSize_ && !this.tileSizes_), 22); // Either `tileSize` or `tileSizes` must be configured, never both\n /**\n * @private\n * @type {import(\"../extent.js\").Extent}\n */\n this.extent_ = extent !== undefined ? extent : null;\n /**\n * @private\n * @type {Array<import(\"../TileRange.js\").default>}\n */\n this.fullTileRanges_ = null;\n /**\n * @private\n * @type {import(\"../size.js\").Size}\n */\n this.tmpSize_ = [0, 0];\n /**\n * @private\n * @type {import(\"../extent.js\").Extent}\n */\n this.tmpExtent_ = [0, 0, 0, 0];\n if (options.sizes !== undefined) {\n this.fullTileRanges_ = options.sizes.map(function (size, z) {\n var tileRange = new TileRange(Math.min(0, size[0]), Math.max(size[0] - 1, -1), Math.min(0, size[1]), Math.max(size[1] - 1, -1));\n if (extent) {\n var restrictedTileRange = this.getTileRangeForExtentAndZ(extent, z);\n tileRange.minX = Math.max(restrictedTileRange.minX, tileRange.minX);\n tileRange.maxX = Math.min(restrictedTileRange.maxX, tileRange.maxX);\n tileRange.minY = Math.max(restrictedTileRange.minY, tileRange.minY);\n tileRange.maxY = Math.min(restrictedTileRange.maxY, tileRange.maxY);\n }\n return tileRange;\n }, this);\n }\n else if (extent) {\n this.calculateTileRanges_(extent);\n }\n }\n /**\n * Call a function with each tile coordinate for a given extent and zoom level.\n *\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @param {number} zoom Integer zoom level.\n * @param {function(import(\"../tilecoord.js\").TileCoord): void} callback Function called with each tile coordinate.\n * @api\n */\n TileGrid.prototype.forEachTileCoord = function (extent, zoom, callback) {\n var tileRange = this.getTileRangeForExtentAndZ(extent, zoom);\n for (var i = tileRange.minX, ii = tileRange.maxX; i <= ii; ++i) {\n for (var j = tileRange.minY, jj = tileRange.maxY; j <= jj; ++j) {\n callback([zoom, i, j]);\n }\n }\n };\n /**\n * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @param {function(number, import(\"../TileRange.js\").default): boolean} callback Callback.\n * @param {import(\"../TileRange.js\").default} [opt_tileRange] Temporary import(\"../TileRange.js\").default object.\n * @param {import(\"../extent.js\").Extent} [opt_extent] Temporary import(\"../extent.js\").Extent object.\n * @return {boolean} Callback succeeded.\n */\n TileGrid.prototype.forEachTileCoordParentTileRange = function (tileCoord, callback, opt_tileRange, opt_extent) {\n var tileRange, x, y;\n var tileCoordExtent = null;\n var z = tileCoord[0] - 1;\n if (this.zoomFactor_ === 2) {\n x = tileCoord[1];\n y = tileCoord[2];\n }\n else {\n tileCoordExtent = this.getTileCoordExtent(tileCoord, opt_extent);\n }\n while (z >= this.minZoom) {\n if (this.zoomFactor_ === 2) {\n x = Math.floor(x / 2);\n y = Math.floor(y / 2);\n tileRange = createOrUpdateTileRange(x, x, y, y, opt_tileRange);\n }\n else {\n tileRange = this.getTileRangeForExtentAndZ(tileCoordExtent, z, opt_tileRange);\n }\n if (callback(z, tileRange)) {\n return true;\n }\n --z;\n }\n return false;\n };\n /**\n * Get the extent for this tile grid, if it was configured.\n * @return {import(\"../extent.js\").Extent} Extent.\n * @api\n */\n TileGrid.prototype.getExtent = function () {\n return this.extent_;\n };\n /**\n * Get the maximum zoom level for the grid.\n * @return {number} Max zoom.\n * @api\n */\n TileGrid.prototype.getMaxZoom = function () {\n return this.maxZoom;\n };\n /**\n * Get the minimum zoom level for the grid.\n * @return {number} Min zoom.\n * @api\n */\n TileGrid.prototype.getMinZoom = function () {\n return this.minZoom;\n };\n /**\n * Get the origin for the grid at the given zoom level.\n * @param {number} z Integer zoom level.\n * @return {import(\"../coordinate.js\").Coordinate} Origin.\n * @api\n */\n TileGrid.prototype.getOrigin = function (z) {\n if (this.origin_) {\n return this.origin_;\n }\n else {\n return this.origins_[z];\n }\n };\n /**\n * Get the resolution for the given zoom level.\n * @param {number} z Integer zoom level.\n * @return {number} Resolution.\n * @api\n */\n TileGrid.prototype.getResolution = function (z) {\n return this.resolutions_[z];\n };\n /**\n * Get the list of resolutions for the tile grid.\n * @return {Array<number>} Resolutions.\n * @api\n */\n TileGrid.prototype.getResolutions = function () {\n return this.resolutions_;\n };\n /**\n * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @param {import(\"../TileRange.js\").default} [opt_tileRange] Temporary import(\"../TileRange.js\").default object.\n * @param {import(\"../extent.js\").Extent} [opt_extent] Temporary import(\"../extent.js\").Extent object.\n * @return {import(\"../TileRange.js\").default} Tile range.\n */\n TileGrid.prototype.getTileCoordChildTileRange = function (tileCoord, opt_tileRange, opt_extent) {\n if (tileCoord[0] < this.maxZoom) {\n if (this.zoomFactor_ === 2) {\n var minX = tileCoord[1] * 2;\n var minY = tileCoord[2] * 2;\n return createOrUpdateTileRange(minX, minX + 1, minY, minY + 1, opt_tileRange);\n }\n var tileCoordExtent = this.getTileCoordExtent(tileCoord, opt_extent || this.tmpExtent_);\n return this.getTileRangeForExtentAndZ(tileCoordExtent, tileCoord[0] + 1, opt_tileRange);\n }\n return null;\n };\n /**\n * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @param {number} z Integer zoom level.\n * @param {import(\"../TileRange.js\").default} [opt_tileRange] Temporary import(\"../TileRange.js\").default object.\n * @return {import(\"../TileRange.js\").default} Tile range.\n */\n TileGrid.prototype.getTileRangeForTileCoordAndZ = function (tileCoord, z, opt_tileRange) {\n if (z > this.maxZoom || z < this.minZoom) {\n return null;\n }\n var tileCoordZ = tileCoord[0];\n var tileCoordX = tileCoord[1];\n var tileCoordY = tileCoord[2];\n if (z === tileCoordZ) {\n return createOrUpdateTileRange(tileCoordX, tileCoordY, tileCoordX, tileCoordY, opt_tileRange);\n }\n if (this.zoomFactor_) {\n var factor = Math.pow(this.zoomFactor_, z - tileCoordZ);\n var minX = Math.floor(tileCoordX * factor);\n var minY = Math.floor(tileCoordY * factor);\n if (z < tileCoordZ) {\n return createOrUpdateTileRange(minX, minX, minY, minY, opt_tileRange);\n }\n var maxX = Math.floor(factor * (tileCoordX + 1)) - 1;\n var maxY = Math.floor(factor * (tileCoordY + 1)) - 1;\n return createOrUpdateTileRange(minX, maxX, minY, maxY, opt_tileRange);\n }\n var tileCoordExtent = this.getTileCoordExtent(tileCoord, this.tmpExtent_);\n return this.getTileRangeForExtentAndZ(tileCoordExtent, z, opt_tileRange);\n };\n /**\n * Get the extent for a tile range.\n * @param {number} z Integer zoom level.\n * @param {import(\"../TileRange.js\").default} tileRange Tile range.\n * @param {import(\"../extent.js\").Extent} [opt_extent] Temporary import(\"../extent.js\").Extent object.\n * @return {import(\"../extent.js\").Extent} Extent.\n */\n TileGrid.prototype.getTileRangeExtent = function (z, tileRange, opt_extent) {\n var origin = this.getOrigin(z);\n var resolution = this.getResolution(z);\n var tileSize = toSize(this.getTileSize(z), this.tmpSize_);\n var minX = origin[0] + tileRange.minX * tileSize[0] * resolution;\n var maxX = origin[0] + (tileRange.maxX + 1) * tileSize[0] * resolution;\n var minY = origin[1] + tileRange.minY * tileSize[1] * resolution;\n var maxY = origin[1] + (tileRange.maxY + 1) * tileSize[1] * resolution;\n return createOrUpdate(minX, minY, maxX, maxY, opt_extent);\n };\n /**\n * Get a tile range for the given extent and integer zoom level.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @param {number} z Integer zoom level.\n * @param {import(\"../TileRange.js\").default} [opt_tileRange] Temporary tile range object.\n * @return {import(\"../TileRange.js\").default} Tile range.\n */\n TileGrid.prototype.getTileRangeForExtentAndZ = function (extent, z, opt_tileRange) {\n var tileCoord = tmpTileCoord;\n this.getTileCoordForXYAndZ_(extent[0], extent[3], z, false, tileCoord);\n var minX = tileCoord[1];\n var minY = tileCoord[2];\n this.getTileCoordForXYAndZ_(extent[2], extent[1], z, true, tileCoord);\n return createOrUpdateTileRange(minX, tileCoord[1], minY, tileCoord[2], opt_tileRange);\n };\n /**\n * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @return {import(\"../coordinate.js\").Coordinate} Tile center.\n */\n TileGrid.prototype.getTileCoordCenter = function (tileCoord) {\n var origin = this.getOrigin(tileCoord[0]);\n var resolution = this.getResolution(tileCoord[0]);\n var tileSize = toSize(this.getTileSize(tileCoord[0]), this.tmpSize_);\n return [\n origin[0] + (tileCoord[1] + 0.5) * tileSize[0] * resolution,\n origin[1] - (tileCoord[2] + 0.5) * tileSize[1] * resolution,\n ];\n };\n /**\n * Get the extent of a tile coordinate.\n *\n * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @param {import(\"../extent.js\").Extent} [opt_extent] Temporary extent object.\n * @return {import(\"../extent.js\").Extent} Extent.\n * @api\n */\n TileGrid.prototype.getTileCoordExtent = function (tileCoord, opt_extent) {\n var origin = this.getOrigin(tileCoord[0]);\n var resolution = this.getResolution(tileCoord[0]);\n var tileSize = toSize(this.getTileSize(tileCoord[0]), this.tmpSize_);\n var minX = origin[0] + tileCoord[1] * tileSize[0] * resolution;\n var minY = origin[1] - (tileCoord[2] + 1) * tileSize[1] * resolution;\n var maxX = minX + tileSize[0] * resolution;\n var maxY = minY + tileSize[1] * resolution;\n return createOrUpdate(minX, minY, maxX, maxY, opt_extent);\n };\n /**\n * Get the tile coordinate for the given map coordinate and resolution. This\n * method considers that coordinates that intersect tile boundaries should be\n * assigned the higher tile coordinate.\n *\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {number} resolution Resolution.\n * @param {import(\"../tilecoord.js\").TileCoord} [opt_tileCoord] Destination import(\"../tilecoord.js\").TileCoord object.\n * @return {import(\"../tilecoord.js\").TileCoord} Tile coordinate.\n * @api\n */\n TileGrid.prototype.getTileCoordForCoordAndResolution = function (coordinate, resolution, opt_tileCoord) {\n return this.getTileCoordForXYAndResolution_(coordinate[0], coordinate[1], resolution, false, opt_tileCoord);\n };\n /**\n * Note that this method should not be called for resolutions that correspond\n * to an integer zoom level. Instead call the `getTileCoordForXYAndZ_` method.\n * @param {number} x X.\n * @param {number} y Y.\n * @param {number} resolution Resolution (for a non-integer zoom level).\n * @param {boolean} reverseIntersectionPolicy Instead of letting edge\n * intersections go to the higher tile coordinate, let edge intersections\n * go to the lower tile coordinate.\n * @param {import(\"../tilecoord.js\").TileCoord} [opt_tileCoord] Temporary import(\"../tilecoord.js\").TileCoord object.\n * @return {import(\"../tilecoord.js\").TileCoord} Tile coordinate.\n * @private\n */\n TileGrid.prototype.getTileCoordForXYAndResolution_ = function (x, y, resolution, reverseIntersectionPolicy, opt_tileCoord) {\n var z = this.getZForResolution(resolution);\n var scale = resolution / this.getResolution(z);\n var origin = this.getOrigin(z);\n var tileSize = toSize(this.getTileSize(z), this.tmpSize_);\n var adjustX = reverseIntersectionPolicy ? 0.5 : 0;\n var adjustY = reverseIntersectionPolicy ? 0.5 : 0;\n var xFromOrigin = Math.floor((x - origin[0]) / resolution + adjustX);\n var yFromOrigin = Math.floor((origin[1] - y) / resolution + adjustY);\n var tileCoordX = (scale * xFromOrigin) / tileSize[0];\n var tileCoordY = (scale * yFromOrigin) / tileSize[1];\n if (reverseIntersectionPolicy) {\n tileCoordX = Math.ceil(tileCoordX) - 1;\n tileCoordY = Math.ceil(tileCoordY) - 1;\n }\n else {\n tileCoordX = Math.floor(tileCoordX);\n tileCoordY = Math.floor(tileCoordY);\n }\n return createOrUpdateTileCoord(z, tileCoordX, tileCoordY, opt_tileCoord);\n };\n /**\n * Although there is repetition between this method and `getTileCoordForXYAndResolution_`,\n * they should have separate implementations. This method is for integer zoom\n * levels. The other method should only be called for resolutions corresponding\n * to non-integer zoom levels.\n * @param {number} x Map x coordinate.\n * @param {number} y Map y coordinate.\n * @param {number} z Integer zoom level.\n * @param {boolean} reverseIntersectionPolicy Instead of letting edge\n * intersections go to the higher tile coordinate, let edge intersections\n * go to the lower tile coordinate.\n * @param {import(\"../tilecoord.js\").TileCoord} [opt_tileCoord] Temporary import(\"../tilecoord.js\").TileCoord object.\n * @return {import(\"../tilecoord.js\").TileCoord} Tile coordinate.\n * @private\n */\n TileGrid.prototype.getTileCoordForXYAndZ_ = function (x, y, z, reverseIntersectionPolicy, opt_tileCoord) {\n var origin = this.getOrigin(z);\n var resolution = this.getResolution(z);\n var tileSize = toSize(this.getTileSize(z), this.tmpSize_);\n var adjustX = reverseIntersectionPolicy ? 0.5 : 0;\n var adjustY = reverseIntersectionPolicy ? 0.5 : 0;\n var xFromOrigin = Math.floor((x - origin[0]) / resolution + adjustX);\n var yFromOrigin = Math.floor((origin[1] - y) / resolution + adjustY);\n var tileCoordX = xFromOrigin / tileSize[0];\n var tileCoordY = yFromOrigin / tileSize[1];\n if (reverseIntersectionPolicy) {\n tileCoordX = Math.ceil(tileCoordX) - 1;\n tileCoordY = Math.ceil(tileCoordY) - 1;\n }\n else {\n tileCoordX = Math.floor(tileCoordX);\n tileCoordY = Math.floor(tileCoordY);\n }\n return createOrUpdateTileCoord(z, tileCoordX, tileCoordY, opt_tileCoord);\n };\n /**\n * Get a tile coordinate given a map coordinate and zoom level.\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {number} z Zoom level.\n * @param {import(\"../tilecoord.js\").TileCoord} [opt_tileCoord] Destination import(\"../tilecoord.js\").TileCoord object.\n * @return {import(\"../tilecoord.js\").TileCoord} Tile coordinate.\n * @api\n */\n TileGrid.prototype.getTileCoordForCoordAndZ = function (coordinate, z, opt_tileCoord) {\n return this.getTileCoordForXYAndZ_(coordinate[0], coordinate[1], z, false, opt_tileCoord);\n };\n /**\n * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @return {number} Tile resolution.\n */\n TileGrid.prototype.getTileCoordResolution = function (tileCoord) {\n return this.resolutions_[tileCoord[0]];\n };\n /**\n * Get the tile size for a zoom level. The type of the return value matches the\n * `tileSize` or `tileSizes` that the tile grid was configured with. To always\n * get an `import(\"../size.js\").Size`, run the result through `import(\"../size.js\").Size.toSize()`.\n * @param {number} z Z.\n * @return {number|import(\"../size.js\").Size} Tile size.\n * @api\n */\n TileGrid.prototype.getTileSize = function (z) {\n if (this.tileSize_) {\n return this.tileSize_;\n }\n else {\n return this.tileSizes_[z];\n }\n };\n /**\n * @param {number} z Zoom level.\n * @return {import(\"../TileRange.js\").default} Extent tile range for the specified zoom level.\n */\n TileGrid.prototype.getFullTileRange = function (z) {\n if (!this.fullTileRanges_) {\n return this.extent_\n ? this.getTileRangeForExtentAndZ(this.extent_, z)\n : null;\n }\n else {\n return this.fullTileRanges_[z];\n }\n };\n /**\n * @param {number} resolution Resolution.\n * @param {number|import(\"../array.js\").NearestDirectionFunction} [opt_direction]\n * If 0, the nearest resolution will be used.\n * If 1, the nearest higher resolution (lower Z) will be used. If -1, the\n * nearest lower resolution (higher Z) will be used. Default is 0.\n * Use a {@link module:ol/array~NearestDirectionFunction} for more precise control.\n *\n * For example to change tile Z at the midpoint of zoom levels\n * ```js\n * function(value, high, low) {\n * return value - low * Math.sqrt(high / low);\n * }\n * ```\n * @return {number} Z.\n * @api\n */\n TileGrid.prototype.getZForResolution = function (resolution, opt_direction) {\n var z = linearFindNearest(this.resolutions_, resolution, opt_direction || 0);\n return clamp(z, this.minZoom, this.maxZoom);\n };\n /**\n * @param {!import(\"../extent.js\").Extent} extent Extent for this tile grid.\n * @private\n */\n TileGrid.prototype.calculateTileRanges_ = function (extent) {\n var length = this.resolutions_.length;\n var fullTileRanges = new Array(length);\n for (var z = this.minZoom; z < length; ++z) {\n fullTileRanges[z] = this.getTileRangeForExtentAndZ(extent, z);\n }\n this.fullTileRanges_ = fullTileRanges;\n };\n return TileGrid;\n}());\nexport default TileGrid;\n//# sourceMappingURL=TileGrid.js.map","/**\n * @module ol/tilegrid\n */\nimport Corner from './extent/Corner.js';\nimport TileGrid from './tilegrid/TileGrid.js';\nimport Units from './proj/Units.js';\nimport { DEFAULT_MAX_ZOOM, DEFAULT_TILE_SIZE } from './tilegrid/common.js';\nimport { METERS_PER_UNIT, get as getProjection } from './proj.js';\nimport { containsCoordinate, createOrUpdate, getCorner, getHeight, getWidth, } from './extent.js';\nimport { toSize } from './size.js';\n/**\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @return {!TileGrid} Default tile grid for the\n * passed projection.\n */\nexport function getForProjection(projection) {\n var tileGrid = projection.getDefaultTileGrid();\n if (!tileGrid) {\n tileGrid = createForProjection(projection);\n projection.setDefaultTileGrid(tileGrid);\n }\n return tileGrid;\n}\n/**\n * @param {TileGrid} tileGrid Tile grid.\n * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @return {import(\"./tilecoord.js\").TileCoord} Tile coordinate.\n */\nexport function wrapX(tileGrid, tileCoord, projection) {\n var z = tileCoord[0];\n var center = tileGrid.getTileCoordCenter(tileCoord);\n var projectionExtent = extentFromProjection(projection);\n if (!containsCoordinate(projectionExtent, center)) {\n var worldWidth = getWidth(projectionExtent);\n var worldsAway = Math.ceil((projectionExtent[0] - center[0]) / worldWidth);\n center[0] += worldWidth * worldsAway;\n return tileGrid.getTileCoordForCoordAndZ(center, z);\n }\n else {\n return tileCoord;\n }\n}\n/**\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number} [opt_maxZoom] Maximum zoom level (default is\n * DEFAULT_MAX_ZOOM).\n * @param {number|import(\"./size.js\").Size} [opt_tileSize] Tile size (default uses\n * DEFAULT_TILE_SIZE).\n * @param {import(\"./extent/Corner.js\").default} [opt_corner] Extent corner (default is `'top-left'`).\n * @return {!TileGrid} TileGrid instance.\n */\nexport function createForExtent(extent, opt_maxZoom, opt_tileSize, opt_corner) {\n var corner = opt_corner !== undefined ? opt_corner : Corner.TOP_LEFT;\n var resolutions = resolutionsFromExtent(extent, opt_maxZoom, opt_tileSize);\n return new TileGrid({\n extent: extent,\n origin: getCorner(extent, corner),\n resolutions: resolutions,\n tileSize: opt_tileSize,\n });\n}\n/**\n * @typedef {Object} XYZOptions\n * @property {import(\"./extent.js\").Extent} [extent] Extent for the tile grid. The origin for an XYZ tile grid is the\n * top-left corner of the extent. If `maxResolution` is not provided the zero level of the grid is defined by the resolution\n * at which one tile fits in the provided extent. If not provided, the extent of the EPSG:3857 projection is used.\n * @property {number} [maxResolution] Resolution at level zero.\n * @property {number} [maxZoom] Maximum zoom. The default is `42`. This determines the number of levels\n * in the grid set. For example, a `maxZoom` of 21 means there are 22 levels in the grid set.\n * @property {number} [minZoom=0] Minimum zoom.\n * @property {number|import(\"./size.js\").Size} [tileSize=[256, 256]] Tile size in pixels.\n */\n/**\n * Creates a tile grid with a standard XYZ tiling scheme.\n * @param {XYZOptions} [opt_options] Tile grid options.\n * @return {!TileGrid} Tile grid instance.\n * @api\n */\nexport function createXYZ(opt_options) {\n var xyzOptions = opt_options || {};\n var extent = xyzOptions.extent || getProjection('EPSG:3857').getExtent();\n var gridOptions = {\n extent: extent,\n minZoom: xyzOptions.minZoom,\n tileSize: xyzOptions.tileSize,\n resolutions: resolutionsFromExtent(extent, xyzOptions.maxZoom, xyzOptions.tileSize, xyzOptions.maxResolution),\n };\n return new TileGrid(gridOptions);\n}\n/**\n * Create a resolutions array from an extent. A zoom factor of 2 is assumed.\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number} [opt_maxZoom] Maximum zoom level (default is\n * DEFAULT_MAX_ZOOM).\n * @param {number|import(\"./size.js\").Size} [opt_tileSize] Tile size (default uses\n * DEFAULT_TILE_SIZE).\n * @param {number} [opt_maxResolution] Resolution at level zero.\n * @return {!Array<number>} Resolutions array.\n */\nfunction resolutionsFromExtent(extent, opt_maxZoom, opt_tileSize, opt_maxResolution) {\n var maxZoom = opt_maxZoom !== undefined ? opt_maxZoom : DEFAULT_MAX_ZOOM;\n var height = getHeight(extent);\n var width = getWidth(extent);\n var tileSize = toSize(opt_tileSize !== undefined ? opt_tileSize : DEFAULT_TILE_SIZE);\n var maxResolution = opt_maxResolution > 0\n ? opt_maxResolution\n : Math.max(width / tileSize[0], height / tileSize[1]);\n var length = maxZoom + 1;\n var resolutions = new Array(length);\n for (var z = 0; z < length; ++z) {\n resolutions[z] = maxResolution / Math.pow(2, z);\n }\n return resolutions;\n}\n/**\n * @param {import(\"./proj.js\").ProjectionLike} projection Projection.\n * @param {number} [opt_maxZoom] Maximum zoom level (default is\n * DEFAULT_MAX_ZOOM).\n * @param {number|import(\"./size.js\").Size} [opt_tileSize] Tile size (default uses\n * DEFAULT_TILE_SIZE).\n * @param {import(\"./extent/Corner.js\").default} [opt_corner] Extent corner (default is `'top-left'`).\n * @return {!TileGrid} TileGrid instance.\n */\nexport function createForProjection(projection, opt_maxZoom, opt_tileSize, opt_corner) {\n var extent = extentFromProjection(projection);\n return createForExtent(extent, opt_maxZoom, opt_tileSize, opt_corner);\n}\n/**\n * Generate a tile grid extent from a projection. If the projection has an\n * extent, it is used. If not, a global extent is assumed.\n * @param {import(\"./proj.js\").ProjectionLike} projection Projection.\n * @return {import(\"./extent.js\").Extent} Extent.\n */\nexport function extentFromProjection(projection) {\n projection = getProjection(projection);\n var extent = projection.getExtent();\n if (!extent) {\n var half = (180 * METERS_PER_UNIT[Units.DEGREES]) / projection.getMetersPerUnit();\n extent = createOrUpdate(-half, -half, half, half);\n }\n return extent;\n}\n//# sourceMappingURL=tilegrid.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/source/Tile\n */\nimport Event from '../events/Event.js';\nimport Source from './Source.js';\nimport TileCache from '../TileCache.js';\nimport TileState from '../TileState.js';\nimport { abstract } from '../util.js';\nimport { assert } from '../asserts.js';\nimport { equivalent } from '../proj.js';\nimport { getKeyZXY, withinExtentAndZ } from '../tilecoord.js';\nimport { getForProjection as getTileGridForProjection, wrapX, } from '../tilegrid.js';\nimport { scale as scaleSize, toSize } from '../size.js';\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n * import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types, import(\"../Object\").ObjectEvent, Return> &\n * import(\"../Observable\").OnSignature<import(\"./TileEventType\").TileSourceEventTypes, TileSourceEvent, Return> &\n * import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").Types|\n * import(\"./TileEventType\").TileSourceEventTypes, Return>} TileSourceOnSignature\n */\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {number} [cacheSize] CacheSize.\n * @property {boolean} [opaque=false] Whether the layer is opaque.\n * @property {number} [tilePixelRatio] TilePixelRatio.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection.\n * @property {import(\"./State.js\").default} [state] State.\n * @property {import(\"../tilegrid/TileGrid.js\").default} [tileGrid] TileGrid.\n * @property {boolean} [wrapX=true] WrapX.\n * @property {number} [transition] Transition.\n * @property {string} [key] Key.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0] ZDirection.\n */\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * Base class for sources providing images divided into a tile grid.\n * @abstract\n * @api\n */\nvar TileSource = /** @class */ (function (_super) {\n __extends(TileSource, _super);\n /**\n * @param {Options} options SourceTile source options.\n */\n function TileSource(options) {\n var _this = _super.call(this, {\n attributions: options.attributions,\n attributionsCollapsible: options.attributionsCollapsible,\n projection: options.projection,\n state: options.state,\n wrapX: options.wrapX,\n }) || this;\n /***\n * @type {TileSourceOnSignature<import(\"../events\").EventsKey>}\n */\n _this.on;\n /***\n * @type {TileSourceOnSignature<import(\"../events\").EventsKey>}\n */\n _this.once;\n /***\n * @type {TileSourceOnSignature<void>}\n */\n _this.un;\n /**\n * @private\n * @type {boolean}\n */\n _this.opaque_ = options.opaque !== undefined ? options.opaque : false;\n /**\n * @private\n * @type {number}\n */\n _this.tilePixelRatio_ =\n options.tilePixelRatio !== undefined ? options.tilePixelRatio : 1;\n /**\n * @protected\n * @type {import(\"../tilegrid/TileGrid.js\").default}\n */\n _this.tileGrid = options.tileGrid !== undefined ? options.tileGrid : null;\n var tileSize = [256, 256];\n var tileGrid = options.tileGrid;\n if (tileGrid) {\n toSize(tileGrid.getTileSize(tileGrid.getMinZoom()), tileSize);\n }\n /**\n * @protected\n * @type {import(\"../TileCache.js\").default}\n */\n _this.tileCache = new TileCache(options.cacheSize || 0);\n /**\n * @protected\n * @type {import(\"../size.js\").Size}\n */\n _this.tmpSize = [0, 0];\n /**\n * @private\n * @type {string}\n */\n _this.key_ = options.key || '';\n /**\n * @protected\n * @type {import(\"../Tile.js\").Options}\n */\n _this.tileOptions = { transition: options.transition };\n /**\n * zDirection hint, read by the renderer. Indicates which resolution should be used\n * by a renderer if the views resolution does not match any resolution of the tile source.\n * If 0, the nearest resolution will be used. If 1, the nearest lower resolution\n * will be used. If -1, the nearest higher resolution will be used.\n * @type {number|import(\"../array.js\").NearestDirectionFunction}\n */\n _this.zDirection = options.zDirection ? options.zDirection : 0;\n return _this;\n }\n /**\n * @return {boolean} Can expire cache.\n */\n TileSource.prototype.canExpireCache = function () {\n return this.tileCache.canExpireCache();\n };\n /**\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @param {!Object<string, boolean>} usedTiles Used tiles.\n */\n TileSource.prototype.expireCache = function (projection, usedTiles) {\n var tileCache = this.getTileCacheForProjection(projection);\n if (tileCache) {\n tileCache.expireCache(usedTiles);\n }\n };\n /**\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @param {number} z Zoom level.\n * @param {import(\"../TileRange.js\").default} tileRange Tile range.\n * @param {function(import(\"../Tile.js\").default):(boolean|void)} callback Called with each\n * loaded tile. If the callback returns `false`, the tile will not be\n * considered loaded.\n * @return {boolean} The tile range is fully covered with loaded tiles.\n */\n TileSource.prototype.forEachLoadedTile = function (projection, z, tileRange, callback) {\n var tileCache = this.getTileCacheForProjection(projection);\n if (!tileCache) {\n return false;\n }\n var covered = true;\n var tile, tileCoordKey, loaded;\n for (var x = tileRange.minX; x <= tileRange.maxX; ++x) {\n for (var y = tileRange.minY; y <= tileRange.maxY; ++y) {\n tileCoordKey = getKeyZXY(z, x, y);\n loaded = false;\n if (tileCache.containsKey(tileCoordKey)) {\n tile = /** @type {!import(\"../Tile.js\").default} */ (tileCache.get(tileCoordKey));\n loaded = tile.getState() === TileState.LOADED;\n if (loaded) {\n loaded = callback(tile) !== false;\n }\n }\n if (!loaded) {\n covered = false;\n }\n }\n }\n return covered;\n };\n /**\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @return {number} Gutter.\n */\n TileSource.prototype.getGutterForProjection = function (projection) {\n return 0;\n };\n /**\n * Return the key to be used for all tiles in the source.\n * @return {string} The key for all tiles.\n * @protected\n */\n TileSource.prototype.getKey = function () {\n return this.key_;\n };\n /**\n * Set the value to be used as the key for all tiles in the source.\n * @param {string} key The key for tiles.\n * @protected\n */\n TileSource.prototype.setKey = function (key) {\n if (this.key_ !== key) {\n this.key_ = key;\n this.changed();\n }\n };\n /**\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @return {boolean} Opaque.\n */\n TileSource.prototype.getOpaque = function (projection) {\n return this.opaque_;\n };\n /**\n * @return {Array<number>} Resolutions.\n */\n TileSource.prototype.getResolutions = function () {\n return this.tileGrid.getResolutions();\n };\n /**\n * @abstract\n * @param {number} z Tile coordinate z.\n * @param {number} x Tile coordinate x.\n * @param {number} y Tile coordinate y.\n * @param {number} pixelRatio Pixel ratio.\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @return {!import(\"../Tile.js\").default} Tile.\n */\n TileSource.prototype.getTile = function (z, x, y, pixelRatio, projection) {\n return abstract();\n };\n /**\n * Return the tile grid of the tile source.\n * @return {import(\"../tilegrid/TileGrid.js\").default} Tile grid.\n * @api\n */\n TileSource.prototype.getTileGrid = function () {\n return this.tileGrid;\n };\n /**\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @return {!import(\"../tilegrid/TileGrid.js\").default} Tile grid.\n */\n TileSource.prototype.getTileGridForProjection = function (projection) {\n if (!this.tileGrid) {\n return getTileGridForProjection(projection);\n }\n else {\n return this.tileGrid;\n }\n };\n /**\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @return {import(\"../TileCache.js\").default} Tile cache.\n * @protected\n */\n TileSource.prototype.getTileCacheForProjection = function (projection) {\n assert(equivalent(this.getProjection(), projection), 68 // A VectorTile source can only be rendered if it has a projection compatible with the view projection.\n );\n return this.tileCache;\n };\n /**\n * Get the tile pixel ratio for this source. Subclasses may override this\n * method, which is meant to return a supported pixel ratio that matches the\n * provided `pixelRatio` as close as possible.\n * @param {number} pixelRatio Pixel ratio.\n * @return {number} Tile pixel ratio.\n */\n TileSource.prototype.getTilePixelRatio = function (pixelRatio) {\n return this.tilePixelRatio_;\n };\n /**\n * @param {number} z Z.\n * @param {number} pixelRatio Pixel ratio.\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @return {import(\"../size.js\").Size} Tile size.\n */\n TileSource.prototype.getTilePixelSize = function (z, pixelRatio, projection) {\n var tileGrid = this.getTileGridForProjection(projection);\n var tilePixelRatio = this.getTilePixelRatio(pixelRatio);\n var tileSize = toSize(tileGrid.getTileSize(z), this.tmpSize);\n if (tilePixelRatio == 1) {\n return tileSize;\n }\n else {\n return scaleSize(tileSize, tilePixelRatio, this.tmpSize);\n }\n };\n /**\n * Returns a tile coordinate wrapped around the x-axis. When the tile coordinate\n * is outside the resolution and extent range of the tile grid, `null` will be\n * returned.\n * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @param {import(\"../proj/Projection.js\").default} [opt_projection] Projection.\n * @return {import(\"../tilecoord.js\").TileCoord} Tile coordinate to be passed to the tileUrlFunction or\n * null if no tile URL should be created for the passed `tileCoord`.\n */\n TileSource.prototype.getTileCoordForTileUrlFunction = function (tileCoord, opt_projection) {\n var projection = opt_projection !== undefined ? opt_projection : this.getProjection();\n var tileGrid = this.getTileGridForProjection(projection);\n if (this.getWrapX() && projection.isGlobal()) {\n tileCoord = wrapX(tileGrid, tileCoord, projection);\n }\n return withinExtentAndZ(tileCoord, tileGrid) ? tileCoord : null;\n };\n /**\n * Remove all cached tiles from the source. The next render cycle will fetch new tiles.\n * @api\n */\n TileSource.prototype.clear = function () {\n this.tileCache.clear();\n };\n TileSource.prototype.refresh = function () {\n this.clear();\n _super.prototype.refresh.call(this);\n };\n /**\n * Increases the cache size if needed\n * @param {number} tileCount Minimum number of tiles needed.\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n */\n TileSource.prototype.updateCacheSize = function (tileCount, projection) {\n var tileCache = this.getTileCacheForProjection(projection);\n if (tileCount > tileCache.highWaterMark) {\n tileCache.highWaterMark = tileCount;\n }\n };\n /**\n * Marks a tile coord as being used, without triggering a load.\n * @abstract\n * @param {number} z Tile coordinate z.\n * @param {number} x Tile coordinate x.\n * @param {number} y Tile coordinate y.\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n */\n TileSource.prototype.useTile = function (z, x, y, projection) { };\n return TileSource;\n}(Source));\n/**\n * @classdesc\n * Events emitted by {@link module:ol/source/Tile~TileSource} instances are instances of this\n * type.\n */\nvar TileSourceEvent = /** @class */ (function (_super) {\n __extends(TileSourceEvent, _super);\n /**\n * @param {string} type Type.\n * @param {import(\"../Tile.js\").default} tile The tile.\n */\n function TileSourceEvent(type, tile) {\n var _this = _super.call(this, type) || this;\n /**\n * The tile related to the event.\n * @type {import(\"../Tile.js\").default}\n * @api\n */\n _this.tile = tile;\n return _this;\n }\n return TileSourceEvent;\n}(Event));\nexport { TileSourceEvent };\nexport default TileSource;\n//# sourceMappingURL=Tile.js.map","/**\n * @module ol/tileurlfunction\n */\nimport { assert } from './asserts.js';\nimport { modulo } from './math.js';\nimport { hash as tileCoordHash } from './tilecoord.js';\n/**\n * @param {string} template Template.\n * @param {import(\"./tilegrid/TileGrid.js\").default} tileGrid Tile grid.\n * @return {import(\"./Tile.js\").UrlFunction} Tile URL function.\n */\nexport function createFromTemplate(template, tileGrid) {\n var zRegEx = /\\{z\\}/g;\n var xRegEx = /\\{x\\}/g;\n var yRegEx = /\\{y\\}/g;\n var dashYRegEx = /\\{-y\\}/g;\n return (\n /**\n * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile Coordinate.\n * @param {number} pixelRatio Pixel ratio.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @return {string|undefined} Tile URL.\n */\n function (tileCoord, pixelRatio, projection) {\n if (!tileCoord) {\n return undefined;\n }\n else {\n return template\n .replace(zRegEx, tileCoord[0].toString())\n .replace(xRegEx, tileCoord[1].toString())\n .replace(yRegEx, tileCoord[2].toString())\n .replace(dashYRegEx, function () {\n var z = tileCoord[0];\n var range = tileGrid.getFullTileRange(z);\n assert(range, 55); // The {-y} placeholder requires a tile grid with extent\n var y = range.getHeight() - tileCoord[2] - 1;\n return y.toString();\n });\n }\n });\n}\n/**\n * @param {Array<string>} templates Templates.\n * @param {import(\"./tilegrid/TileGrid.js\").default} tileGrid Tile grid.\n * @return {import(\"./Tile.js\").UrlFunction} Tile URL function.\n */\nexport function createFromTemplates(templates, tileGrid) {\n var len = templates.length;\n var tileUrlFunctions = new Array(len);\n for (var i = 0; i < len; ++i) {\n tileUrlFunctions[i] = createFromTemplate(templates[i], tileGrid);\n }\n return createFromTileUrlFunctions(tileUrlFunctions);\n}\n/**\n * @param {Array<import(\"./Tile.js\").UrlFunction>} tileUrlFunctions Tile URL Functions.\n * @return {import(\"./Tile.js\").UrlFunction} Tile URL function.\n */\nexport function createFromTileUrlFunctions(tileUrlFunctions) {\n if (tileUrlFunctions.length === 1) {\n return tileUrlFunctions[0];\n }\n return (\n /**\n * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile Coordinate.\n * @param {number} pixelRatio Pixel ratio.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @return {string|undefined} Tile URL.\n */\n function (tileCoord, pixelRatio, projection) {\n if (!tileCoord) {\n return undefined;\n }\n else {\n var h = tileCoordHash(tileCoord);\n var index = modulo(h, tileUrlFunctions.length);\n return tileUrlFunctions[index](tileCoord, pixelRatio, projection);\n }\n });\n}\n/**\n * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @param {number} pixelRatio Pixel ratio.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @return {string|undefined} Tile URL.\n */\nexport function nullTileUrlFunction(tileCoord, pixelRatio, projection) {\n return undefined;\n}\n/**\n * @param {string} url URL.\n * @return {Array<string>} Array of urls.\n */\nexport function expandUrl(url) {\n var urls = [];\n var match = /\\{([a-z])-([a-z])\\}/.exec(url);\n if (match) {\n // char range\n var startCharCode = match[1].charCodeAt(0);\n var stopCharCode = match[2].charCodeAt(0);\n var charCode = void 0;\n for (charCode = startCharCode; charCode <= stopCharCode; ++charCode) {\n urls.push(url.replace(match[0], String.fromCharCode(charCode)));\n }\n return urls;\n }\n match = /\\{(\\d+)-(\\d+)\\}/.exec(url);\n if (match) {\n // number range\n var stop_1 = parseInt(match[2], 10);\n for (var i = parseInt(match[1], 10); i <= stop_1; i++) {\n urls.push(url.replace(match[0], i.toString()));\n }\n return urls;\n }\n urls.push(url);\n return urls;\n}\n//# sourceMappingURL=tileurlfunction.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/source/UrlTile\n */\nimport TileEventType from './TileEventType.js';\nimport TileSource, { TileSourceEvent } from './Tile.js';\nimport TileState from '../TileState.js';\nimport { createFromTemplates, expandUrl } from '../tileurlfunction.js';\nimport { getKeyZXY } from '../tilecoord.js';\nimport { getUid } from '../util.js';\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {number} [cacheSize] Cache size.\n * @property {boolean} [opaque=false] Whether the layer is opaque.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection.\n * @property {import(\"./State.js\").default} [state] State.\n * @property {import(\"../tilegrid/TileGrid.js\").default} [tileGrid] TileGrid.\n * @property {import(\"../Tile.js\").LoadFunction} tileLoadFunction TileLoadFunction.\n * @property {number} [tilePixelRatio] TilePixelRatio.\n * @property {import(\"../Tile.js\").UrlFunction} [tileUrlFunction] TileUrlFunction.\n * @property {string} [url] Url.\n * @property {Array<string>} [urls] Urls.\n * @property {boolean} [wrapX=true] WrapX.\n * @property {number} [transition] Transition.\n * @property {string} [key] Key.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0] ZDirection.\n */\n/**\n * @classdesc\n * Base class for sources providing tiles divided into a tile grid over http.\n *\n * @fires import(\"./Tile.js\").TileSourceEvent\n */\nvar UrlTile = /** @class */ (function (_super) {\n __extends(UrlTile, _super);\n /**\n * @param {Options} options Image tile options.\n */\n function UrlTile(options) {\n var _this = _super.call(this, {\n attributions: options.attributions,\n cacheSize: options.cacheSize,\n opaque: options.opaque,\n projection: options.projection,\n state: options.state,\n tileGrid: options.tileGrid,\n tilePixelRatio: options.tilePixelRatio,\n wrapX: options.wrapX,\n transition: options.transition,\n key: options.key,\n attributionsCollapsible: options.attributionsCollapsible,\n zDirection: options.zDirection,\n }) || this;\n /**\n * @private\n * @type {boolean}\n */\n _this.generateTileUrlFunction_ =\n _this.tileUrlFunction === UrlTile.prototype.tileUrlFunction;\n /**\n * @protected\n * @type {import(\"../Tile.js\").LoadFunction}\n */\n _this.tileLoadFunction = options.tileLoadFunction;\n if (options.tileUrlFunction) {\n _this.tileUrlFunction = options.tileUrlFunction;\n }\n /**\n * @protected\n * @type {!Array<string>|null}\n */\n _this.urls = null;\n if (options.urls) {\n _this.setUrls(options.urls);\n }\n else if (options.url) {\n _this.setUrl(options.url);\n }\n /**\n * @private\n * @type {!Object<string, boolean>}\n */\n _this.tileLoadingKeys_ = {};\n return _this;\n }\n /**\n * Return the tile load function of the source.\n * @return {import(\"../Tile.js\").LoadFunction} TileLoadFunction\n * @api\n */\n UrlTile.prototype.getTileLoadFunction = function () {\n return this.tileLoadFunction;\n };\n /**\n * Return the tile URL function of the source.\n * @return {import(\"../Tile.js\").UrlFunction} TileUrlFunction\n * @api\n */\n UrlTile.prototype.getTileUrlFunction = function () {\n return Object.getPrototypeOf(this).tileUrlFunction === this.tileUrlFunction\n ? this.tileUrlFunction.bind(this)\n : this.tileUrlFunction;\n };\n /**\n * Return the URLs used for this source.\n * When a tileUrlFunction is used instead of url or urls,\n * null will be returned.\n * @return {!Array<string>|null} URLs.\n * @api\n */\n UrlTile.prototype.getUrls = function () {\n return this.urls;\n };\n /**\n * Handle tile change events.\n * @param {import(\"../events/Event.js\").default} event Event.\n * @protected\n */\n UrlTile.prototype.handleTileChange = function (event) {\n var tile = /** @type {import(\"../Tile.js\").default} */ (event.target);\n var uid = getUid(tile);\n var tileState = tile.getState();\n var type;\n if (tileState == TileState.LOADING) {\n this.tileLoadingKeys_[uid] = true;\n type = TileEventType.TILELOADSTART;\n }\n else if (uid in this.tileLoadingKeys_) {\n delete this.tileLoadingKeys_[uid];\n type =\n tileState == TileState.ERROR\n ? TileEventType.TILELOADERROR\n : tileState == TileState.LOADED\n ? TileEventType.TILELOADEND\n : undefined;\n }\n if (type != undefined) {\n this.dispatchEvent(new TileSourceEvent(type, tile));\n }\n };\n /**\n * Set the tile load function of the source.\n * @param {import(\"../Tile.js\").LoadFunction} tileLoadFunction Tile load function.\n * @api\n */\n UrlTile.prototype.setTileLoadFunction = function (tileLoadFunction) {\n this.tileCache.clear();\n this.tileLoadFunction = tileLoadFunction;\n this.changed();\n };\n /**\n * Set the tile URL function of the source.\n * @param {import(\"../Tile.js\").UrlFunction} tileUrlFunction Tile URL function.\n * @param {string} [key] Optional new tile key for the source.\n * @api\n */\n UrlTile.prototype.setTileUrlFunction = function (tileUrlFunction, key) {\n this.tileUrlFunction = tileUrlFunction;\n this.tileCache.pruneExceptNewestZ();\n if (typeof key !== 'undefined') {\n this.setKey(key);\n }\n else {\n this.changed();\n }\n };\n /**\n * Set the URL to use for requests.\n * @param {string} url URL.\n * @api\n */\n UrlTile.prototype.setUrl = function (url) {\n var urls = expandUrl(url);\n this.urls = urls;\n this.setUrls(urls);\n };\n /**\n * Set the URLs to use for requests.\n * @param {Array<string>} urls URLs.\n * @api\n */\n UrlTile.prototype.setUrls = function (urls) {\n this.urls = urls;\n var key = urls.join('\\n');\n if (this.generateTileUrlFunction_) {\n this.setTileUrlFunction(createFromTemplates(urls, this.tileGrid), key);\n }\n else {\n this.setKey(key);\n }\n };\n /**\n * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @param {number} pixelRatio Pixel ratio.\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @return {string|undefined} Tile URL.\n */\n UrlTile.prototype.tileUrlFunction = function (tileCoord, pixelRatio, projection) {\n return undefined;\n };\n /**\n * Marks a tile coord as being used, without triggering a load.\n * @param {number} z Tile coordinate z.\n * @param {number} x Tile coordinate x.\n * @param {number} y Tile coordinate y.\n */\n UrlTile.prototype.useTile = function (z, x, y) {\n var tileCoordKey = getKeyZXY(z, x, y);\n if (this.tileCache.containsKey(tileCoordKey)) {\n this.tileCache.get(tileCoordKey);\n }\n };\n return UrlTile;\n}(TileSource));\nexport default UrlTile;\n//# sourceMappingURL=UrlTile.js.map","/**\n * @module ol/source/TileEventType\n */\n/**\n * @enum {string}\n */\nexport default {\n /**\n * Triggered when a tile starts loading.\n * @event module:ol/source/Tile.TileSourceEvent#tileloadstart\n * @api\n */\n TILELOADSTART: 'tileloadstart',\n /**\n * Triggered when a tile finishes loading, either when its data is loaded,\n * or when loading was aborted because the tile is no longer needed.\n * @event module:ol/source/Tile.TileSourceEvent#tileloadend\n * @api\n */\n TILELOADEND: 'tileloadend',\n /**\n * Triggered if tile loading results in an error.\n * @event module:ol/source/Tile.TileSourceEvent#tileloaderror\n * @api\n */\n TILELOADERROR: 'tileloaderror',\n};\n/**\n * @typedef {'tileloadstart'|'tileloadend'|'tileloaderror'} TileSourceEventTypes\n */\n//# sourceMappingURL=TileEventType.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/source/TileImage\n */\nimport EventType from '../events/EventType.js';\nimport ImageTile from '../ImageTile.js';\nimport ReprojTile from '../reproj/Tile.js';\nimport TileCache from '../TileCache.js';\nimport TileState from '../TileState.js';\nimport UrlTile from './UrlTile.js';\nimport { ENABLE_RASTER_REPROJECTION } from '../reproj/common.js';\nimport { IMAGE_SMOOTHING_DISABLED } from './common.js';\nimport { equivalent, get as getProjection } from '../proj.js';\nimport { getKey, getKeyZXY } from '../tilecoord.js';\nimport { getForProjection as getTileGridForProjection } from '../tilegrid.js';\nimport { getUid } from '../util.js';\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {number} [cacheSize] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images. Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {boolean} [imageSmoothing=true] Enable image smoothing.\n * @property {boolean} [opaque=false] Whether the layer is opaque.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is the view projection.\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {import(\"./State.js\").default} [state] Source state.\n * @property {typeof import(\"../ImageTile.js\").default} [tileClass] Class used to instantiate image tiles.\n * Default is {@link module:ol/ImageTile~ImageTile}.\n * @property {import(\"../tilegrid/TileGrid.js\").default} [tileGrid] Tile grid.\n * @property {import(\"../Tile.js\").LoadFunction} [tileLoadFunction] Optional function to load a tile given a URL. The default is\n * ```js\n * function(imageTile, src) {\n * imageTile.getImage().src = src;\n * };\n * ```\n * @property {number} [tilePixelRatio=1] The pixel ratio used by the tile service. For example, if the tile\n * service advertizes 256px by 256px tiles but actually sends 512px\n * by 512px images (for retina/hidpi devices) then `tilePixelRatio`\n * should be set to `2`.\n * @property {import(\"../Tile.js\").UrlFunction} [tileUrlFunction] Optional function to get tile URL given a tile coordinate and the projection.\n * @property {string} [url] URL template. Must include `{x}`, `{y}` or `{-y}`, and `{z}` placeholders.\n * A `{?-?}` template pattern, for example `subdomain{a-f}.domain.com`, may be\n * used instead of defining each one separately in the `urls` option.\n * @property {Array<string>} [urls] An array of URL templates.\n * @property {boolean} [wrapX] Whether to wrap the world horizontally. The default, is to\n * request out-of-bounds tiles from the server. When set to `false`, only one\n * world will be rendered. When set to `true`, tiles will be requested for one\n * world only, but they will be wrapped horizontally to render multiple worlds.\n * @property {number} [transition] Duration of the opacity transition for rendering.\n * To disable the opacity transition, pass `transition: 0`.\n * @property {string} [key] Optional tile key for proper cache fetching\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n */\n/**\n * @classdesc\n * Base class for sources providing images divided into a tile grid.\n *\n * @fires import(\"./Tile.js\").TileSourceEvent\n * @api\n */\nvar TileImage = /** @class */ (function (_super) {\n __extends(TileImage, _super);\n /**\n * @param {!Options} options Image tile options.\n */\n function TileImage(options) {\n var _this = _super.call(this, {\n attributions: options.attributions,\n cacheSize: options.cacheSize,\n opaque: options.opaque,\n projection: options.projection,\n state: options.state,\n tileGrid: options.tileGrid,\n tileLoadFunction: options.tileLoadFunction\n ? options.tileLoadFunction\n : defaultTileLoadFunction,\n tilePixelRatio: options.tilePixelRatio,\n tileUrlFunction: options.tileUrlFunction,\n url: options.url,\n urls: options.urls,\n wrapX: options.wrapX,\n transition: options.transition,\n key: options.key,\n attributionsCollapsible: options.attributionsCollapsible,\n zDirection: options.zDirection,\n }) || this;\n /**\n * @protected\n * @type {?string}\n */\n _this.crossOrigin =\n options.crossOrigin !== undefined ? options.crossOrigin : null;\n /**\n * @protected\n * @type {typeof ImageTile}\n */\n _this.tileClass =\n options.tileClass !== undefined ? options.tileClass : ImageTile;\n /**\n * @protected\n * @type {!Object<string, TileCache>}\n */\n _this.tileCacheForProjection = {};\n /**\n * @protected\n * @type {!Object<string, import(\"../tilegrid/TileGrid.js\").default>}\n */\n _this.tileGridForProjection = {};\n /**\n * @private\n * @type {number|undefined}\n */\n _this.reprojectionErrorThreshold_ = options.reprojectionErrorThreshold;\n /**\n * @private\n * @type {object|undefined}\n */\n _this.contextOptions_ =\n options.imageSmoothing === false ? IMAGE_SMOOTHING_DISABLED : undefined;\n /**\n * @private\n * @type {boolean}\n */\n _this.renderReprojectionEdges_ = false;\n return _this;\n }\n /**\n * @return {boolean} Can expire cache.\n */\n TileImage.prototype.canExpireCache = function () {\n if (!ENABLE_RASTER_REPROJECTION) {\n return _super.prototype.canExpireCache.call(this);\n }\n if (this.tileCache.canExpireCache()) {\n return true;\n }\n else {\n for (var key in this.tileCacheForProjection) {\n if (this.tileCacheForProjection[key].canExpireCache()) {\n return true;\n }\n }\n }\n return false;\n };\n /**\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @param {!Object<string, boolean>} usedTiles Used tiles.\n */\n TileImage.prototype.expireCache = function (projection, usedTiles) {\n if (!ENABLE_RASTER_REPROJECTION) {\n _super.prototype.expireCache.call(this, projection, usedTiles);\n return;\n }\n var usedTileCache = this.getTileCacheForProjection(projection);\n this.tileCache.expireCache(this.tileCache == usedTileCache ? usedTiles : {});\n for (var id in this.tileCacheForProjection) {\n var tileCache = this.tileCacheForProjection[id];\n tileCache.expireCache(tileCache == usedTileCache ? usedTiles : {});\n }\n };\n /**\n * @return {Object|undefined} Context options.\n */\n TileImage.prototype.getContextOptions = function () {\n return this.contextOptions_;\n };\n /**\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @return {number} Gutter.\n */\n TileImage.prototype.getGutterForProjection = function (projection) {\n if (ENABLE_RASTER_REPROJECTION &&\n this.getProjection() &&\n projection &&\n !equivalent(this.getProjection(), projection)) {\n return 0;\n }\n else {\n return this.getGutter();\n }\n };\n /**\n * @return {number} Gutter.\n */\n TileImage.prototype.getGutter = function () {\n return 0;\n };\n /**\n * Return the key to be used for all tiles in the source.\n * @return {string} The key for all tiles.\n * @protected\n */\n TileImage.prototype.getKey = function () {\n return (_super.prototype.getKey.call(this) +\n (this.contextOptions_ ? '\\n' + JSON.stringify(this.contextOptions_) : ''));\n };\n /**\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @return {boolean} Opaque.\n */\n TileImage.prototype.getOpaque = function (projection) {\n if (ENABLE_RASTER_REPROJECTION &&\n this.getProjection() &&\n projection &&\n !equivalent(this.getProjection(), projection)) {\n return false;\n }\n else {\n return _super.prototype.getOpaque.call(this, projection);\n }\n };\n /**\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @return {!import(\"../tilegrid/TileGrid.js\").default} Tile grid.\n */\n TileImage.prototype.getTileGridForProjection = function (projection) {\n if (!ENABLE_RASTER_REPROJECTION) {\n return _super.prototype.getTileGridForProjection.call(this, projection);\n }\n var thisProj = this.getProjection();\n if (this.tileGrid && (!thisProj || equivalent(thisProj, projection))) {\n return this.tileGrid;\n }\n else {\n var projKey = getUid(projection);\n if (!(projKey in this.tileGridForProjection)) {\n this.tileGridForProjection[projKey] =\n getTileGridForProjection(projection);\n }\n return this.tileGridForProjection[projKey];\n }\n };\n /**\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @return {import(\"../TileCache.js\").default} Tile cache.\n */\n TileImage.prototype.getTileCacheForProjection = function (projection) {\n if (!ENABLE_RASTER_REPROJECTION) {\n return _super.prototype.getTileCacheForProjection.call(this, projection);\n }\n var thisProj = this.getProjection();\n if (!thisProj || equivalent(thisProj, projection)) {\n return this.tileCache;\n }\n else {\n var projKey = getUid(projection);\n if (!(projKey in this.tileCacheForProjection)) {\n this.tileCacheForProjection[projKey] = new TileCache(this.tileCache.highWaterMark);\n }\n return this.tileCacheForProjection[projKey];\n }\n };\n /**\n * @param {number} z Tile coordinate z.\n * @param {number} x Tile coordinate x.\n * @param {number} y Tile coordinate y.\n * @param {number} pixelRatio Pixel ratio.\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @param {string} key The key set on the tile.\n * @return {!import(\"../Tile.js\").default} Tile.\n * @private\n */\n TileImage.prototype.createTile_ = function (z, x, y, pixelRatio, projection, key) {\n var tileCoord = [z, x, y];\n var urlTileCoord = this.getTileCoordForTileUrlFunction(tileCoord, projection);\n var tileUrl = urlTileCoord\n ? this.tileUrlFunction(urlTileCoord, pixelRatio, projection)\n : undefined;\n var tile = new this.tileClass(tileCoord, tileUrl !== undefined ? TileState.IDLE : TileState.EMPTY, tileUrl !== undefined ? tileUrl : '', this.crossOrigin, this.tileLoadFunction, this.tileOptions);\n tile.key = key;\n tile.addEventListener(EventType.CHANGE, this.handleTileChange.bind(this));\n return tile;\n };\n /**\n * @param {number} z Tile coordinate z.\n * @param {number} x Tile coordinate x.\n * @param {number} y Tile coordinate y.\n * @param {number} pixelRatio Pixel ratio.\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @return {!import(\"../Tile.js\").default} Tile.\n */\n TileImage.prototype.getTile = function (z, x, y, pixelRatio, projection) {\n var sourceProjection = this.getProjection();\n if (!ENABLE_RASTER_REPROJECTION ||\n !sourceProjection ||\n !projection ||\n equivalent(sourceProjection, projection)) {\n return this.getTileInternal(z, x, y, pixelRatio, sourceProjection || projection);\n }\n else {\n var cache = this.getTileCacheForProjection(projection);\n var tileCoord = [z, x, y];\n var tile = void 0;\n var tileCoordKey = getKey(tileCoord);\n if (cache.containsKey(tileCoordKey)) {\n tile = cache.get(tileCoordKey);\n }\n var key = this.getKey();\n if (tile && tile.key == key) {\n return tile;\n }\n else {\n var sourceTileGrid = this.getTileGridForProjection(sourceProjection);\n var targetTileGrid = this.getTileGridForProjection(projection);\n var wrappedTileCoord = this.getTileCoordForTileUrlFunction(tileCoord, projection);\n var newTile = new ReprojTile(sourceProjection, sourceTileGrid, projection, targetTileGrid, tileCoord, wrappedTileCoord, this.getTilePixelRatio(pixelRatio), this.getGutter(), function (z, x, y, pixelRatio) {\n return this.getTileInternal(z, x, y, pixelRatio, sourceProjection);\n }.bind(this), this.reprojectionErrorThreshold_, this.renderReprojectionEdges_, this.contextOptions_);\n newTile.key = key;\n if (tile) {\n newTile.interimTile = tile;\n newTile.refreshInterimChain();\n cache.replace(tileCoordKey, newTile);\n }\n else {\n cache.set(tileCoordKey, newTile);\n }\n return newTile;\n }\n }\n };\n /**\n * @param {number} z Tile coordinate z.\n * @param {number} x Tile coordinate x.\n * @param {number} y Tile coordinate y.\n * @param {number} pixelRatio Pixel ratio.\n * @param {!import(\"../proj/Projection.js\").default} projection Projection.\n * @return {!import(\"../Tile.js\").default} Tile.\n * @protected\n */\n TileImage.prototype.getTileInternal = function (z, x, y, pixelRatio, projection) {\n var tile = null;\n var tileCoordKey = getKeyZXY(z, x, y);\n var key = this.getKey();\n if (!this.tileCache.containsKey(tileCoordKey)) {\n tile = this.createTile_(z, x, y, pixelRatio, projection, key);\n this.tileCache.set(tileCoordKey, tile);\n }\n else {\n tile = this.tileCache.get(tileCoordKey);\n if (tile.key != key) {\n // The source's params changed. If the tile has an interim tile and if we\n // can use it then we use it. Otherwise we create a new tile. In both\n // cases we attempt to assign an interim tile to the new tile.\n var interimTile = tile;\n tile = this.createTile_(z, x, y, pixelRatio, projection, key);\n //make the new tile the head of the list,\n if (interimTile.getState() == TileState.IDLE) {\n //the old tile hasn't begun loading yet, and is now outdated, so we can simply discard it\n tile.interimTile = interimTile.interimTile;\n }\n else {\n tile.interimTile = interimTile;\n }\n tile.refreshInterimChain();\n this.tileCache.replace(tileCoordKey, tile);\n }\n }\n return tile;\n };\n /**\n * Sets whether to render reprojection edges or not (usually for debugging).\n * @param {boolean} render Render the edges.\n * @api\n */\n TileImage.prototype.setRenderReprojectionEdges = function (render) {\n if (!ENABLE_RASTER_REPROJECTION ||\n this.renderReprojectionEdges_ == render) {\n return;\n }\n this.renderReprojectionEdges_ = render;\n for (var id in this.tileCacheForProjection) {\n this.tileCacheForProjection[id].clear();\n }\n this.changed();\n };\n /**\n * Sets the tile grid to use when reprojecting the tiles to the given\n * projection instead of the default tile grid for the projection.\n *\n * This can be useful when the default tile grid cannot be created\n * (e.g. projection has no extent defined) or\n * for optimization reasons (custom tile size, resolutions, ...).\n *\n * @param {import(\"../proj.js\").ProjectionLike} projection Projection.\n * @param {import(\"../tilegrid/TileGrid.js\").default} tilegrid Tile grid to use for the projection.\n * @api\n */\n TileImage.prototype.setTileGridForProjection = function (projection, tilegrid) {\n if (ENABLE_RASTER_REPROJECTION) {\n var proj = getProjection(projection);\n if (proj) {\n var projKey = getUid(proj);\n if (!(projKey in this.tileGridForProjection)) {\n this.tileGridForProjection[projKey] = tilegrid;\n }\n }\n }\n };\n return TileImage;\n}(UrlTile));\n/**\n * @param {ImageTile} imageTile Image tile.\n * @param {string} src Source.\n */\nfunction defaultTileLoadFunction(imageTile, src) {\n /** @type {HTMLImageElement|HTMLVideoElement} */ (imageTile.getImage()).src =\n src;\n}\nexport default TileImage;\n//# sourceMappingURL=TileImage.js.map","/**\n * @module ol/source/XYZ\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport TileImage from './TileImage.js';\nimport { createXYZ, extentFromProjection } from '../tilegrid.js';\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {number} [cacheSize] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images. Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {boolean} [imageSmoothing=true] Enable image smoothing.\n * @property {boolean} [opaque=false] Whether the layer is opaque.\n * @property {import(\"../proj.js\").ProjectionLike} [projection='EPSG:3857'] Projection.\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {number} [maxZoom=42] Optional max zoom level. Not used if `tileGrid` is provided.\n * @property {number} [minZoom=0] Optional min zoom level. Not used if `tileGrid` is provided.\n * @property {number} [maxResolution] Optional tile grid resolution at level zero. Not used if `tileGrid` is provided.\n * @property {import(\"../tilegrid/TileGrid.js\").default} [tileGrid] Tile grid.\n * @property {import(\"../Tile.js\").LoadFunction} [tileLoadFunction] Optional function to load a tile given a URL. The default is\n * ```js\n * function(imageTile, src) {\n * imageTile.getImage().src = src;\n * };\n * ```\n * @property {number} [tilePixelRatio=1] The pixel ratio used by the tile service.\n * For example, if the tile service advertizes 256px by 256px tiles but actually sends 512px\n * by 512px images (for retina/hidpi devices) then `tilePixelRatio`\n * should be set to `2`.\n * @property {number|import(\"../size.js\").Size} [tileSize=[256, 256]] The tile size used by the tile service.\n * Not used if `tileGrid` is provided.\n * @property {import(\"../Tile.js\").UrlFunction} [tileUrlFunction] Optional function to get\n * tile URL given a tile coordinate and the projection.\n * Required if `url` or `urls` are not provided.\n * @property {string} [url] URL template. Must include `{x}`, `{y}` or `{-y}`,\n * and `{z}` placeholders. A `{?-?}` template pattern, for example `subdomain{a-f}.domain.com`,\n * may be used instead of defining each one separately in the `urls` option.\n * @property {Array<string>} [urls] An array of URL templates.\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n * @property {number} [transition=250] Duration of the opacity transition for rendering.\n * To disable the opacity transition, pass `transition: 0`.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n */\n/**\n * @classdesc\n * Layer source for tile data with URLs in a set XYZ format that are\n * defined in a URL template. By default, this follows the widely-used\n * Google grid where `x` 0 and `y` 0 are in the top left. Grids like\n * TMS where `x` 0 and `y` 0 are in the bottom left can be used by\n * using the `{-y}` placeholder in the URL template, so long as the\n * source does not have a custom tile grid. In this case\n * a `tileUrlFunction` can be used, such as:\n * ```js\n * tileUrlFunction: function(coordinate) {\n * return 'http://mapserver.com/' + coordinate[0] + '/' +\n * coordinate[1] + '/' + (-coordinate[2] - 1) + '.png';\n * }\n * ```\n * @api\n */\nvar XYZ = /** @class */ (function (_super) {\n __extends(XYZ, _super);\n /**\n * @param {Options} [opt_options] XYZ options.\n */\n function XYZ(opt_options) {\n var _this = this;\n var options = opt_options || {};\n var projection = options.projection !== undefined ? options.projection : 'EPSG:3857';\n var tileGrid = options.tileGrid !== undefined\n ? options.tileGrid\n : createXYZ({\n extent: extentFromProjection(projection),\n maxResolution: options.maxResolution,\n maxZoom: options.maxZoom,\n minZoom: options.minZoom,\n tileSize: options.tileSize,\n });\n _this = _super.call(this, {\n attributions: options.attributions,\n cacheSize: options.cacheSize,\n crossOrigin: options.crossOrigin,\n imageSmoothing: options.imageSmoothing,\n opaque: options.opaque,\n projection: projection,\n reprojectionErrorThreshold: options.reprojectionErrorThreshold,\n tileGrid: tileGrid,\n tileLoadFunction: options.tileLoadFunction,\n tilePixelRatio: options.tilePixelRatio,\n tileUrlFunction: options.tileUrlFunction,\n url: options.url,\n urls: options.urls,\n wrapX: options.wrapX !== undefined ? options.wrapX : true,\n transition: options.transition,\n attributionsCollapsible: options.attributionsCollapsible,\n zDirection: options.zDirection,\n }) || this;\n return _this;\n }\n return XYZ;\n}(TileImage));\nexport default XYZ;\n//# sourceMappingURL=XYZ.js.map","/**\n * @module ol/source/OSM\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport XYZ from './XYZ.js';\n/**\n * The attribution containing a link to the OpenStreetMap Copyright and License\n * page.\n * @const\n * @type {string}\n * @api\n */\nexport var ATTRIBUTION = '© ' +\n '<a href=\"https://www.openstreetmap.org/copyright\" target=\"_blank\">OpenStreetMap</a> ' +\n 'contributors.';\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {number} [cacheSize] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\n * @property {null|string} [crossOrigin='anonymous'] The `crossOrigin` attribute for loaded images. Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {boolean} [imageSmoothing=true] Enable image smoothing.\n * @property {number} [maxZoom=19] Max zoom.\n * @property {boolean} [opaque=true] Whether the layer is opaque.\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {import(\"../Tile.js\").LoadFunction} [tileLoadFunction] Optional function to load a tile given a URL. The default is\n * ```js\n * function(imageTile, src) {\n * imageTile.getImage().src = src;\n * };\n * ```\n * @property {number} [transition=250] Duration of the opacity transition for rendering.\n * To disable the opacity transition, pass `transition: 0`.\n * @property {string} [url='https://{a-c}.tile.openstreetmap.org/{z}/{x}/{y}.png'] URL template.\n * Must include `{x}`, `{y}` or `{-y}`, and `{z}` placeholders.\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n */\n/**\n * @classdesc\n * Layer source for the OpenStreetMap tile server.\n * @api\n */\nvar OSM = /** @class */ (function (_super) {\n __extends(OSM, _super);\n /**\n * @param {Options} [opt_options] Open Street Map options.\n */\n function OSM(opt_options) {\n var _this = this;\n var options = opt_options || {};\n var attributions;\n if (options.attributions !== undefined) {\n attributions = options.attributions;\n }\n else {\n attributions = [ATTRIBUTION];\n }\n var crossOrigin = options.crossOrigin !== undefined ? options.crossOrigin : 'anonymous';\n var url = options.url !== undefined\n ? options.url\n : 'https://{a-c}.tile.openstreetmap.org/{z}/{x}/{y}.png';\n _this = _super.call(this, {\n attributions: attributions,\n attributionsCollapsible: false,\n cacheSize: options.cacheSize,\n crossOrigin: crossOrigin,\n imageSmoothing: options.imageSmoothing,\n maxZoom: options.maxZoom !== undefined ? options.maxZoom : 19,\n opaque: options.opaque !== undefined ? options.opaque : true,\n reprojectionErrorThreshold: options.reprojectionErrorThreshold,\n tileLoadFunction: options.tileLoadFunction,\n transition: options.transition,\n url: url,\n wrapX: options.wrapX,\n zDirection: options.zDirection,\n }) || this;\n return _this;\n }\n return OSM;\n}(XYZ));\nexport default OSM;\n//# sourceMappingURL=OSM.js.map","/**\n * @module ol/CollectionEventType\n */\n/**\n * @enum {string}\n */\nexport default {\n /**\n * Triggered when an item is added to the collection.\n * @event module:ol/Collection.CollectionEvent#add\n * @api\n */\n ADD: 'add',\n /**\n * Triggered when an item is removed from the collection.\n * @event module:ol/Collection.CollectionEvent#remove\n * @api\n */\n REMOVE: 'remove',\n};\n//# sourceMappingURL=CollectionEventType.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/Collection\n */\nimport AssertionError from './AssertionError.js';\nimport BaseObject from './Object.js';\nimport CollectionEventType from './CollectionEventType.js';\nimport Event from './events/Event.js';\n/**\n * @enum {string}\n * @private\n */\nvar Property = {\n LENGTH: 'length',\n};\n/**\n * @classdesc\n * Events emitted by {@link module:ol/Collection~Collection} instances are instances of this\n * type.\n */\nvar CollectionEvent = /** @class */ (function (_super) {\n __extends(CollectionEvent, _super);\n /**\n * @param {import(\"./CollectionEventType.js\").default} type Type.\n * @param {*} [opt_element] Element.\n * @param {number} [opt_index] The index of the added or removed element.\n */\n function CollectionEvent(type, opt_element, opt_index) {\n var _this = _super.call(this, type) || this;\n /**\n * The element that is added to or removed from the collection.\n * @type {*}\n * @api\n */\n _this.element = opt_element;\n /**\n * The index of the added or removed element.\n * @type {number}\n * @api\n */\n _this.index = opt_index;\n return _this;\n }\n return CollectionEvent;\n}(Event));\nexport { CollectionEvent };\n/***\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature<import(\"./Observable\").EventTypes, import(\"./events/Event.js\").default, Return> &\n * import(\"./Observable\").OnSignature<import(\"./ObjectEventType\").Types|'change:length', import(\"./Object\").ObjectEvent, Return> &\n * import(\"./Observable\").OnSignature<'add'|'remove', CollectionEvent, Return> &\n * import(\"./Observable\").CombinedOnSignature<import(\"./Observable\").EventTypes|import(\"./ObjectEventType\").Types|\n * 'change:length'|'add'|'remove',Return>} CollectionOnSignature\n */\n/**\n * @typedef {Object} Options\n * @property {boolean} [unique=false] Disallow the same item from being added to\n * the collection twice.\n */\n/**\n * @classdesc\n * An expanded version of standard JS Array, adding convenience methods for\n * manipulation. Add and remove changes to the Collection trigger a Collection\n * event. Note that this does not cover changes to the objects _within_ the\n * Collection; they trigger events on the appropriate object, not on the\n * Collection as a whole.\n *\n * @fires CollectionEvent\n *\n * @template T\n * @api\n */\nvar Collection = /** @class */ (function (_super) {\n __extends(Collection, _super);\n /**\n * @param {Array<T>} [opt_array] Array.\n * @param {Options} [opt_options] Collection options.\n */\n function Collection(opt_array, opt_options) {\n var _this = _super.call(this) || this;\n /***\n * @type {CollectionOnSignature<import(\"./events\").EventsKey>}\n */\n _this.on;\n /***\n * @type {CollectionOnSignature<import(\"./events\").EventsKey>}\n */\n _this.once;\n /***\n * @type {CollectionOnSignature<void>}\n */\n _this.un;\n var options = opt_options || {};\n /**\n * @private\n * @type {boolean}\n */\n _this.unique_ = !!options.unique;\n /**\n * @private\n * @type {!Array<T>}\n */\n _this.array_ = opt_array ? opt_array : [];\n if (_this.unique_) {\n for (var i = 0, ii = _this.array_.length; i < ii; ++i) {\n _this.assertUnique_(_this.array_[i], i);\n }\n }\n _this.updateLength_();\n return _this;\n }\n /**\n * Remove all elements from the collection.\n * @api\n */\n Collection.prototype.clear = function () {\n while (this.getLength() > 0) {\n this.pop();\n }\n };\n /**\n * Add elements to the collection. This pushes each item in the provided array\n * to the end of the collection.\n * @param {!Array<T>} arr Array.\n * @return {Collection<T>} This collection.\n * @api\n */\n Collection.prototype.extend = function (arr) {\n for (var i = 0, ii = arr.length; i < ii; ++i) {\n this.push(arr[i]);\n }\n return this;\n };\n /**\n * Iterate over each element, calling the provided callback.\n * @param {function(T, number, Array<T>): *} f The function to call\n * for every element. This function takes 3 arguments (the element, the\n * index and the array). The return value is ignored.\n * @api\n */\n Collection.prototype.forEach = function (f) {\n var array = this.array_;\n for (var i = 0, ii = array.length; i < ii; ++i) {\n f(array[i], i, array);\n }\n };\n /**\n * Get a reference to the underlying Array object. Warning: if the array\n * is mutated, no events will be dispatched by the collection, and the\n * collection's \"length\" property won't be in sync with the actual length\n * of the array.\n * @return {!Array<T>} Array.\n * @api\n */\n Collection.prototype.getArray = function () {\n return this.array_;\n };\n /**\n * Get the element at the provided index.\n * @param {number} index Index.\n * @return {T} Element.\n * @api\n */\n Collection.prototype.item = function (index) {\n return this.array_[index];\n };\n /**\n * Get the length of this collection.\n * @return {number} The length of the array.\n * @observable\n * @api\n */\n Collection.prototype.getLength = function () {\n return this.get(Property.LENGTH);\n };\n /**\n * Insert an element at the provided index.\n * @param {number} index Index.\n * @param {T} elem Element.\n * @api\n */\n Collection.prototype.insertAt = function (index, elem) {\n if (this.unique_) {\n this.assertUnique_(elem);\n }\n this.array_.splice(index, 0, elem);\n this.updateLength_();\n this.dispatchEvent(new CollectionEvent(CollectionEventType.ADD, elem, index));\n };\n /**\n * Remove the last element of the collection and return it.\n * Return `undefined` if the collection is empty.\n * @return {T|undefined} Element.\n * @api\n */\n Collection.prototype.pop = function () {\n return this.removeAt(this.getLength() - 1);\n };\n /**\n * Insert the provided element at the end of the collection.\n * @param {T} elem Element.\n * @return {number} New length of the collection.\n * @api\n */\n Collection.prototype.push = function (elem) {\n if (this.unique_) {\n this.assertUnique_(elem);\n }\n var n = this.getLength();\n this.insertAt(n, elem);\n return this.getLength();\n };\n /**\n * Remove the first occurrence of an element from the collection.\n * @param {T} elem Element.\n * @return {T|undefined} The removed element or undefined if none found.\n * @api\n */\n Collection.prototype.remove = function (elem) {\n var arr = this.array_;\n for (var i = 0, ii = arr.length; i < ii; ++i) {\n if (arr[i] === elem) {\n return this.removeAt(i);\n }\n }\n return undefined;\n };\n /**\n * Remove the element at the provided index and return it.\n * Return `undefined` if the collection does not contain this index.\n * @param {number} index Index.\n * @return {T|undefined} Value.\n * @api\n */\n Collection.prototype.removeAt = function (index) {\n var prev = this.array_[index];\n this.array_.splice(index, 1);\n this.updateLength_();\n this.dispatchEvent(new CollectionEvent(CollectionEventType.REMOVE, prev, index));\n return prev;\n };\n /**\n * Set the element at the provided index.\n * @param {number} index Index.\n * @param {T} elem Element.\n * @api\n */\n Collection.prototype.setAt = function (index, elem) {\n var n = this.getLength();\n if (index < n) {\n if (this.unique_) {\n this.assertUnique_(elem, index);\n }\n var prev = this.array_[index];\n this.array_[index] = elem;\n this.dispatchEvent(new CollectionEvent(CollectionEventType.REMOVE, prev, index));\n this.dispatchEvent(new CollectionEvent(CollectionEventType.ADD, elem, index));\n }\n else {\n for (var j = n; j < index; ++j) {\n this.insertAt(j, undefined);\n }\n this.insertAt(index, elem);\n }\n };\n /**\n * @private\n */\n Collection.prototype.updateLength_ = function () {\n this.set(Property.LENGTH, this.array_.length);\n };\n /**\n * @private\n * @param {T} elem Element.\n * @param {number} [opt_except] Optional index to ignore.\n */\n Collection.prototype.assertUnique_ = function (elem, opt_except) {\n for (var i = 0, ii = this.array_.length; i < ii; ++i) {\n if (this.array_[i] === elem && i !== opt_except) {\n throw new AssertionError(58);\n }\n }\n };\n return Collection;\n}(BaseObject));\nexport default Collection;\n//# sourceMappingURL=Collection.js.map","/**\n * @module ol/structs/RBush\n */\nimport RBush_ from 'rbush/rbush.js';\nimport { createOrUpdate, equals } from '../extent.js';\nimport { getUid } from '../util.js';\nimport { isEmpty } from '../obj.js';\n/**\n * @typedef {Object} Entry\n * @property {number} minX MinX.\n * @property {number} minY MinY.\n * @property {number} maxX MaxX.\n * @property {number} maxY MaxY.\n * @property {Object} [value] Value.\n */\n/**\n * @classdesc\n * Wrapper around the RBush by Vladimir Agafonkin.\n * See https://github.com/mourner/rbush.\n *\n * @template T\n */\nvar RBush = /** @class */ (function () {\n /**\n * @param {number} [opt_maxEntries] Max entries.\n */\n function RBush(opt_maxEntries) {\n /**\n * @private\n */\n this.rbush_ = new RBush_(opt_maxEntries);\n /**\n * A mapping between the objects added to this rbush wrapper\n * and the objects that are actually added to the internal rbush.\n * @private\n * @type {Object<string, Entry>}\n */\n this.items_ = {};\n }\n /**\n * Insert a value into the RBush.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @param {T} value Value.\n */\n RBush.prototype.insert = function (extent, value) {\n /** @type {Entry} */\n var item = {\n minX: extent[0],\n minY: extent[1],\n maxX: extent[2],\n maxY: extent[3],\n value: value,\n };\n this.rbush_.insert(item);\n this.items_[getUid(value)] = item;\n };\n /**\n * Bulk-insert values into the RBush.\n * @param {Array<import(\"../extent.js\").Extent>} extents Extents.\n * @param {Array<T>} values Values.\n */\n RBush.prototype.load = function (extents, values) {\n var items = new Array(values.length);\n for (var i = 0, l = values.length; i < l; i++) {\n var extent = extents[i];\n var value = values[i];\n /** @type {Entry} */\n var item = {\n minX: extent[0],\n minY: extent[1],\n maxX: extent[2],\n maxY: extent[3],\n value: value,\n };\n items[i] = item;\n this.items_[getUid(value)] = item;\n }\n this.rbush_.load(items);\n };\n /**\n * Remove a value from the RBush.\n * @param {T} value Value.\n * @return {boolean} Removed.\n */\n RBush.prototype.remove = function (value) {\n var uid = getUid(value);\n // get the object in which the value was wrapped when adding to the\n // internal rbush. then use that object to do the removal.\n var item = this.items_[uid];\n delete this.items_[uid];\n return this.rbush_.remove(item) !== null;\n };\n /**\n * Update the extent of a value in the RBush.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @param {T} value Value.\n */\n RBush.prototype.update = function (extent, value) {\n var item = this.items_[getUid(value)];\n var bbox = [item.minX, item.minY, item.maxX, item.maxY];\n if (!equals(bbox, extent)) {\n this.remove(value);\n this.insert(extent, value);\n }\n };\n /**\n * Return all values in the RBush.\n * @return {Array<T>} All.\n */\n RBush.prototype.getAll = function () {\n var items = this.rbush_.all();\n return items.map(function (item) {\n return item.value;\n });\n };\n /**\n * Return all values in the given extent.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {Array<T>} All in extent.\n */\n RBush.prototype.getInExtent = function (extent) {\n /** @type {Entry} */\n var bbox = {\n minX: extent[0],\n minY: extent[1],\n maxX: extent[2],\n maxY: extent[3],\n };\n var items = this.rbush_.search(bbox);\n return items.map(function (item) {\n return item.value;\n });\n };\n /**\n * Calls a callback function with each value in the tree.\n * If the callback returns a truthy value, this value is returned without\n * checking the rest of the tree.\n * @param {function(T): *} callback Callback.\n * @return {*} Callback return value.\n */\n RBush.prototype.forEach = function (callback) {\n return this.forEach_(this.getAll(), callback);\n };\n /**\n * Calls a callback function with each value in the provided extent.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @param {function(T): *} callback Callback.\n * @return {*} Callback return value.\n */\n RBush.prototype.forEachInExtent = function (extent, callback) {\n return this.forEach_(this.getInExtent(extent), callback);\n };\n /**\n * @param {Array<T>} values Values.\n * @param {function(T): *} callback Callback.\n * @private\n * @return {*} Callback return value.\n */\n RBush.prototype.forEach_ = function (values, callback) {\n var result;\n for (var i = 0, l = values.length; i < l; i++) {\n result = callback(values[i]);\n if (result) {\n return result;\n }\n }\n return result;\n };\n /**\n * @return {boolean} Is empty.\n */\n RBush.prototype.isEmpty = function () {\n return isEmpty(this.items_);\n };\n /**\n * Remove all values from the RBush.\n */\n RBush.prototype.clear = function () {\n this.rbush_.clear();\n this.items_ = {};\n };\n /**\n * @param {import(\"../extent.js\").Extent} [opt_extent] Extent.\n * @return {import(\"../extent.js\").Extent} Extent.\n */\n RBush.prototype.getExtent = function (opt_extent) {\n var data = this.rbush_.toJSON();\n return createOrUpdate(data.minX, data.minY, data.maxX, data.maxY, opt_extent);\n };\n /**\n * @param {RBush} rbush R-Tree.\n */\n RBush.prototype.concat = function (rbush) {\n this.rbush_.load(rbush.rbush_.all());\n for (var i in rbush.items_) {\n this.items_[i] = rbush.items_[i];\n }\n };\n return RBush;\n}());\nexport default RBush;\n//# sourceMappingURL=RBush.js.map\n","/**\n * @module ol/source/VectorEventType\n */\n/**\n * @enum {string}\n */\nexport default {\n /**\n * Triggered when a feature is added to the source.\n * @event module:ol/source/Vector.VectorSourceEvent#addfeature\n * @api\n */\n ADDFEATURE: 'addfeature',\n /**\n * Triggered when a feature is updated.\n * @event module:ol/source/Vector.VectorSourceEvent#changefeature\n * @api\n */\n CHANGEFEATURE: 'changefeature',\n /**\n * Triggered when the clear method is called on the source.\n * @event module:ol/source/Vector.VectorSourceEvent#clear\n * @api\n */\n CLEAR: 'clear',\n /**\n * Triggered when a feature is removed from the source.\n * See {@link module:ol/source/Vector~VectorSource#clear source.clear()} for exceptions.\n * @event module:ol/source/Vector.VectorSourceEvent#removefeature\n * @api\n */\n REMOVEFEATURE: 'removefeature',\n /**\n * Triggered when features starts loading.\n * @event module:ol/source/Vector.VectorSourceEvent#featuresloadstart\n * @api\n */\n FEATURESLOADSTART: 'featuresloadstart',\n /**\n * Triggered when features finishes loading.\n * @event module:ol/source/Vector.VectorSourceEvent#featuresloadend\n * @api\n */\n FEATURESLOADEND: 'featuresloadend',\n /**\n * Triggered if feature loading results in an error.\n * @event module:ol/source/Vector.VectorSourceEvent#featuresloaderror\n * @api\n */\n FEATURESLOADERROR: 'featuresloaderror',\n};\n/**\n * @typedef {'addfeature'|'changefeature'|'clear'|'removefeature'|'featuresloadstart'|'featuresloadend'|'featuresloaderror'} VectorSourceEventTypes\n */\n//# sourceMappingURL=VectorEventType.js.map","/**\n * @module ol/loadingstrategy\n */\nimport { fromUserExtent, fromUserResolution, toUserExtent } from './proj.js';\n/**\n * Strategy function for loading all features with a single request.\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number} resolution Resolution.\n * @return {Array<import(\"./extent.js\").Extent>} Extents.\n * @api\n */\nexport function all(extent, resolution) {\n return [[-Infinity, -Infinity, Infinity, Infinity]];\n}\n/**\n * Strategy function for loading features based on the view's extent and\n * resolution.\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number} resolution Resolution.\n * @return {Array<import(\"./extent.js\").Extent>} Extents.\n * @api\n */\nexport function bbox(extent, resolution) {\n return [extent];\n}\n/**\n * Creates a strategy function for loading features based on a tile grid.\n * @param {import(\"./tilegrid/TileGrid.js\").default} tileGrid Tile grid.\n * @return {function(import(\"./extent.js\").Extent, number, import(\"./proj.js\").Projection): Array<import(\"./extent.js\").Extent>} Loading strategy.\n * @api\n */\nexport function tile(tileGrid) {\n return (\n /**\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number} resolution Resolution.\n * @param {import(\"./proj.js\").Projection} projection Projection.\n * @return {Array<import(\"./extent.js\").Extent>} Extents.\n */\n function (extent, resolution, projection) {\n var z = tileGrid.getZForResolution(fromUserResolution(resolution, projection));\n var tileRange = tileGrid.getTileRangeForExtentAndZ(fromUserExtent(extent, projection), z);\n /** @type {Array<import(\"./extent.js\").Extent>} */\n var extents = [];\n /** @type {import(\"./tilecoord.js\").TileCoord} */\n var tileCoord = [z, 0, 0];\n for (tileCoord[1] = tileRange.minX; tileCoord[1] <= tileRange.maxX; ++tileCoord[1]) {\n for (tileCoord[2] = tileRange.minY; tileCoord[2] <= tileRange.maxY; ++tileCoord[2]) {\n extents.push(toUserExtent(tileGrid.getTileCoordExtent(tileCoord), projection));\n }\n }\n return extents;\n });\n}\n//# sourceMappingURL=loadingstrategy.js.map","/**\n * @module ol/format/FormatType\n */\n/**\n * @enum {string}\n */\nexport default {\n ARRAY_BUFFER: 'arraybuffer',\n JSON: 'json',\n TEXT: 'text',\n XML: 'xml',\n};\n//# sourceMappingURL=FormatType.js.map","/**\n * @module ol/featureloader\n */\nimport FormatType from './format/FormatType.js';\nimport { VOID } from './functions.js';\n/**\n *\n * @type {boolean}\n * @private\n */\nvar withCredentials = false;\n/**\n * {@link module:ol/source/Vector} sources use a function of this type to\n * load features.\n *\n * This function takes up to 5 arguments. These are an {@link module:ol/extent~Extent} representing\n * the area to be loaded, a `{number}` representing the resolution (map units per pixel), an\n * {@link module:ol/proj/Projection} for the projection, an optional success callback that should get\n * the loaded features passed as an argument and an optional failure callback with no arguments. If\n * the callbacks are not used, the corresponding vector source will not fire `'featuresloadend'` and\n * `'featuresloaderror'` events. `this` within the function is bound to the\n * {@link module:ol/source/Vector} it's called from.\n *\n * The function is responsible for loading the features and adding them to the\n * source.\n * @typedef {function(this:(import(\"./source/Vector\").default|import(\"./VectorTile.js\").default),\n * import(\"./extent.js\").Extent,\n * number,\n * import(\"./proj/Projection.js\").default,\n * function(Array<import(\"./Feature.js\").default>): void=,\n * function(): void=): void} FeatureLoader\n * @api\n */\n/**\n * {@link module:ol/source/Vector} sources use a function of this type to\n * get the url to load features from.\n *\n * This function takes an {@link module:ol/extent~Extent} representing the area\n * to be loaded, a `{number}` representing the resolution (map units per pixel)\n * and an {@link module:ol/proj/Projection} for the projection as\n * arguments and returns a `{string}` representing the URL.\n * @typedef {function(import(\"./extent.js\").Extent, number, import(\"./proj/Projection.js\").default): string} FeatureUrlFunction\n * @api\n */\n/**\n * @param {string|FeatureUrlFunction} url Feature URL service.\n * @param {import(\"./format/Feature.js\").default} format Feature format.\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number} resolution Resolution.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @param {function(Array<import(\"./Feature.js\").default>, import(\"./proj/Projection.js\").default): void} success Success\n * Function called with the loaded features and optionally with the data projection.\n * @param {function(): void} failure Failure\n * Function called when loading failed.\n */\nexport function loadFeaturesXhr(url, format, extent, resolution, projection, success, failure) {\n var xhr = new XMLHttpRequest();\n xhr.open('GET', typeof url === 'function' ? url(extent, resolution, projection) : url, true);\n if (format.getType() == FormatType.ARRAY_BUFFER) {\n xhr.responseType = 'arraybuffer';\n }\n xhr.withCredentials = withCredentials;\n /**\n * @param {Event} event Event.\n * @private\n */\n xhr.onload = function (event) {\n // status will be 0 for file:// urls\n if (!xhr.status || (xhr.status >= 200 && xhr.status < 300)) {\n var type = format.getType();\n /** @type {Document|Node|Object|string|undefined} */\n var source = void 0;\n if (type == FormatType.JSON || type == FormatType.TEXT) {\n source = xhr.responseText;\n }\n else if (type == FormatType.XML) {\n source = xhr.responseXML;\n if (!source) {\n source = new DOMParser().parseFromString(xhr.responseText, 'application/xml');\n }\n }\n else if (type == FormatType.ARRAY_BUFFER) {\n source = /** @type {ArrayBuffer} */ (xhr.response);\n }\n if (source) {\n success(\n /** @type {Array<import(\"./Feature.js\").default>} */\n (format.readFeatures(source, {\n extent: extent,\n featureProjection: projection,\n })), format.readProjection(source));\n }\n else {\n failure();\n }\n }\n else {\n failure();\n }\n };\n /**\n * @private\n */\n xhr.onerror = failure;\n xhr.send();\n}\n/**\n * Create an XHR feature loader for a `url` and `format`. The feature loader\n * loads features (with XHR), parses the features, and adds them to the\n * vector source.\n * @param {string|FeatureUrlFunction} url Feature URL service.\n * @param {import(\"./format/Feature.js\").default} format Feature format.\n * @return {FeatureLoader} The feature loader.\n * @api\n */\nexport function xhr(url, format) {\n /**\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number} resolution Resolution.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @param {function(Array<import(\"./Feature.js\").default>): void} [success] Success\n * Function called when loading succeeded.\n * @param {function(): void} [failure] Failure\n * Function called when loading failed.\n * @this {import(\"./source/Vector\").default}\n */\n return function (extent, resolution, projection, success, failure) {\n var source = /** @type {import(\"./source/Vector\").default} */ (this);\n loadFeaturesXhr(url, format, extent, resolution, projection, \n /**\n * @param {Array<import(\"./Feature.js\").default>} features The loaded features.\n * @param {import(\"./proj/Projection.js\").default} dataProjection Data\n * projection.\n */\n function (features, dataProjection) {\n source.addFeatures(features);\n if (success !== undefined) {\n success(features);\n }\n }, \n /* FIXME handle error */ failure ? failure : VOID);\n };\n}\n/**\n * Setter for the withCredentials configuration for the XHR.\n *\n * @param {boolean} xhrWithCredentials The value of withCredentials to set.\n * Compare https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/\n * @api\n */\nexport function setWithCredentials(xhrWithCredentials) {\n withCredentials = xhrWithCredentials;\n}\n//# sourceMappingURL=featureloader.js.map","/**\n * @module ol/source/Vector\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport Collection from '../Collection.js';\nimport CollectionEventType from '../CollectionEventType.js';\nimport Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport ObjectEventType from '../ObjectEventType.js';\nimport RBush from '../structs/RBush.js';\nimport Source from './Source.js';\nimport SourceState from './State.js';\nimport VectorEventType from './VectorEventType.js';\nimport { TRUE, VOID } from '../functions.js';\nimport { all as allStrategy } from '../loadingstrategy.js';\nimport { assert } from '../asserts.js';\nimport { containsExtent, equals } from '../extent.js';\nimport { extend } from '../array.js';\nimport { getUid } from '../util.js';\nimport { getValues, isEmpty } from '../obj.js';\nimport { listen, unlistenByKey } from '../events.js';\nimport { xhr } from '../featureloader.js';\n/**\n * A function that takes an {@link module:ol/extent~Extent} and a resolution as arguments, and\n * returns an array of {@link module:ol/extent~Extent} with the extents to load. Usually this\n * is one of the standard {@link module:ol/loadingstrategy} strategies.\n *\n * @typedef {function(import(\"../extent.js\").Extent, number, import(\"../proj/Projection.js\").default): Array<import(\"../extent.js\").Extent>} LoadingStrategy\n * @api\n */\n/**\n * @classdesc\n * Events emitted by {@link module:ol/source/Vector} instances are instances of this\n * type.\n * @template {import(\"../geom/Geometry.js\").default} Geometry\n */\nvar VectorSourceEvent = /** @class */ (function (_super) {\n __extends(VectorSourceEvent, _super);\n /**\n * @param {string} type Type.\n * @param {import(\"../Feature.js\").default<Geometry>} [opt_feature] Feature.\n * @param {Array<import(\"../Feature.js\").default<Geometry>>} [opt_features] Features.\n */\n function VectorSourceEvent(type, opt_feature, opt_features) {\n var _this = _super.call(this, type) || this;\n /**\n * The added or removed feature for the `ADDFEATURE` and `REMOVEFEATURE` events, `undefined` otherwise.\n * @type {import(\"../Feature.js\").default<Geometry>|undefined}\n * @api\n */\n _this.feature = opt_feature;\n /**\n * The loaded features for the `FEATURESLOADED` event, `undefined` otherwise.\n * @type {Array<import(\"../Feature.js\").default<Geometry>>|undefined}\n * @api\n */\n _this.features = opt_features;\n return _this;\n }\n return VectorSourceEvent;\n}(Event));\nexport { VectorSourceEvent };\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n * import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types, import(\"../Object\").ObjectEvent, Return> &\n * import(\"../Observable\").OnSignature<import(\"./VectorEventType\").VectorSourceEventTypes, VectorSourceEvent, Return> &\n * import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").Types|\n * import(\"./VectorEventType\").VectorSourceEventTypes, Return>} VectorSourceOnSignature\n */\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {Array<import(\"../Feature.js\").default>|Collection<import(\"../Feature.js\").default>} [features]\n * Features. If provided as {@link module:ol/Collection}, the features in the source\n * and the collection will stay in sync.\n * @property {import(\"../format/Feature.js\").default} [format] The feature format used by the XHR\n * feature loader when `url` is set. Required if `url` is set, otherwise ignored.\n * @property {import(\"../featureloader.js\").FeatureLoader} [loader]\n * The loader function used to load features, from a remote source for example.\n * If this is not set and `url` is set, the source will create and use an XHR\n * feature loader. The `'featuresloadend'` and `'featuresloaderror'` events\n * will only fire if the `success` and `failure` callbacks are used.\n *\n * Example:\n *\n * ```js\n * import {Vector} from 'ol/source';\n * import {GeoJSON} from 'ol/format';\n * import {bbox} from 'ol/loadingstrategy';\n *\n * var vectorSource = new Vector({\n * format: new GeoJSON(),\n * loader: function(extent, resolution, projection, success, failure) {\n * var proj = projection.getCode();\n * var url = 'https://ahocevar.com/geoserver/wfs?service=WFS&' +\n * 'version=1.1.0&request=GetFeature&typename=osm:water_areas&' +\n * 'outputFormat=application/json&srsname=' + proj + '&' +\n * 'bbox=' + extent.join(',') + ',' + proj;\n * var xhr = new XMLHttpRequest();\n * xhr.open('GET', url);\n * var onError = function() {\n * vectorSource.removeLoadedExtent(extent);\n * failure();\n * }\n * xhr.onerror = onError;\n * xhr.onload = function() {\n * if (xhr.status == 200) {\n * var features = vectorSource.getFormat().readFeatures(xhr.responseText);\n * vectorSource.addFeatures(features);\n * success(features);\n * } else {\n * onError();\n * }\n * }\n * xhr.send();\n * },\n * strategy: bbox\n * });\n * ```\n * @property {boolean} [overlaps=true] This source may have overlapping geometries.\n * Setting this to `false` (e.g. for sources with polygons that represent administrative\n * boundaries or TopoJSON sources) allows the renderer to optimise fill and\n * stroke operations.\n * @property {LoadingStrategy} [strategy] The loading strategy to use.\n * By default an {@link module:ol/loadingstrategy.all}\n * strategy is used, a one-off strategy which loads all features at once.\n * @property {string|import(\"../featureloader.js\").FeatureUrlFunction} [url]\n * Setting this option instructs the source to load features using an XHR loader\n * (see {@link module:ol/featureloader.xhr}). Use a `string` and an\n * {@link module:ol/loadingstrategy.all} for a one-off download of all features from\n * the given URL. Use a {@link module:ol/featureloader~FeatureUrlFunction} to generate the url with\n * other loading strategies.\n * Requires `format` to be set as well.\n * When default XHR feature loader is provided, the features will\n * be transformed from the data projection to the view projection\n * during parsing. If your remote data source does not advertise its projection\n * properly, this transformation will be incorrect. For some formats, the\n * default projection (usually EPSG:4326) can be overridden by setting the\n * dataProjection constructor option on the format.\n * Note that if a source contains non-feature data, such as a GeoJSON geometry\n * or a KML NetworkLink, these will be ignored. Use a custom loader to load these.\n * @property {boolean} [useSpatialIndex=true]\n * By default, an RTree is used as spatial index. When features are removed and\n * added frequently, and the total number of features is low, setting this to\n * `false` may improve performance.\n *\n * Note that\n * {@link module:ol/source/Vector~VectorSource#getFeaturesInExtent},\n * {@link module:ol/source/Vector~VectorSource#getClosestFeatureToCoordinate} and\n * {@link module:ol/source/Vector~VectorSource#getExtent} cannot be used when `useSpatialIndex` is\n * set to `false`, and {@link module:ol/source/Vector~VectorSource#forEachFeatureInExtent} will loop\n * through all features.\n *\n * When set to `false`, the features will be maintained in an\n * {@link module:ol/Collection}, which can be retrieved through\n * {@link module:ol/source/Vector~VectorSource#getFeaturesCollection}.\n * @property {boolean} [wrapX=true] Wrap the world horizontally. For vector editing across the\n * -180° and 180° meridians to work properly, this should be set to `false`. The\n * resulting geometry coordinates will then exceed the world bounds.\n */\n/**\n * @classdesc\n * Provides a source of features for vector layers. Vector features provided\n * by this source are suitable for editing. See {@link module:ol/source/VectorTile~VectorTile} for\n * vector data that is optimized for rendering.\n *\n * @fires VectorSourceEvent\n * @api\n * @template {import(\"../geom/Geometry.js\").default} Geometry\n */\nvar VectorSource = /** @class */ (function (_super) {\n __extends(VectorSource, _super);\n /**\n * @param {Options} [opt_options] Vector source options.\n */\n function VectorSource(opt_options) {\n var _this = this;\n var options = opt_options || {};\n _this = _super.call(this, {\n attributions: options.attributions,\n projection: undefined,\n state: SourceState.READY,\n wrapX: options.wrapX !== undefined ? options.wrapX : true,\n }) || this;\n /***\n * @type {VectorSourceOnSignature<import(\"../events\").EventsKey>}\n */\n _this.on;\n /***\n * @type {VectorSourceOnSignature<import(\"../events\").EventsKey>}\n */\n _this.once;\n /***\n * @type {VectorSourceOnSignature<void>}\n */\n _this.un;\n /**\n * @private\n * @type {import(\"../featureloader.js\").FeatureLoader}\n */\n _this.loader_ = VOID;\n /**\n * @private\n * @type {import(\"../format/Feature.js\").default|undefined}\n */\n _this.format_ = options.format;\n /**\n * @private\n * @type {boolean}\n */\n _this.overlaps_ = options.overlaps === undefined ? true : options.overlaps;\n /**\n * @private\n * @type {string|import(\"../featureloader.js\").FeatureUrlFunction|undefined}\n */\n _this.url_ = options.url;\n if (options.loader !== undefined) {\n _this.loader_ = options.loader;\n }\n else if (_this.url_ !== undefined) {\n assert(_this.format_, 7); // `format` must be set when `url` is set\n // create a XHR feature loader for \"url\" and \"format\"\n _this.loader_ = xhr(_this.url_, \n /** @type {import(\"../format/Feature.js\").default} */ (_this.format_));\n }\n /**\n * @private\n * @type {LoadingStrategy}\n */\n _this.strategy_ =\n options.strategy !== undefined ? options.strategy : allStrategy;\n var useSpatialIndex = options.useSpatialIndex !== undefined ? options.useSpatialIndex : true;\n /**\n * @private\n * @type {RBush<import(\"../Feature.js\").default<Geometry>>}\n */\n _this.featuresRtree_ = useSpatialIndex ? new RBush() : null;\n /**\n * @private\n * @type {RBush<{extent: import(\"../extent.js\").Extent}>}\n */\n _this.loadedExtentsRtree_ = new RBush();\n /**\n * @type {number}\n * @private\n */\n _this.loadingExtentsCount_ = 0;\n /**\n * @private\n * @type {!Object<string, import(\"../Feature.js\").default<Geometry>>}\n */\n _this.nullGeometryFeatures_ = {};\n /**\n * A lookup of features by id (the return from feature.getId()).\n * @private\n * @type {!Object<string, import(\"../Feature.js\").default<Geometry>>}\n */\n _this.idIndex_ = {};\n /**\n * A lookup of features by uid (using getUid(feature)).\n * @private\n * @type {!Object<string, import(\"../Feature.js\").default<Geometry>>}\n */\n _this.uidIndex_ = {};\n /**\n * @private\n * @type {Object<string, Array<import(\"../events.js\").EventsKey>>}\n */\n _this.featureChangeKeys_ = {};\n /**\n * @private\n * @type {Collection<import(\"../Feature.js\").default<Geometry>>}\n */\n _this.featuresCollection_ = null;\n var collection, features;\n if (Array.isArray(options.features)) {\n features = options.features;\n }\n else if (options.features) {\n collection = options.features;\n features = collection.getArray();\n }\n if (!useSpatialIndex && collection === undefined) {\n collection = new Collection(features);\n }\n if (features !== undefined) {\n _this.addFeaturesInternal(features);\n }\n if (collection !== undefined) {\n _this.bindFeaturesCollection_(collection);\n }\n return _this;\n }\n /**\n * Add a single feature to the source. If you want to add a batch of features\n * at once, call {@link module:ol/source/Vector~VectorSource#addFeatures #addFeatures()}\n * instead. A feature will not be added to the source if feature with\n * the same id is already there. The reason for this behavior is to avoid\n * feature duplication when using bbox or tile loading strategies.\n * Note: this also applies if an {@link module:ol/Collection} is used for features,\n * meaning that if a feature with a duplicate id is added in the collection, it will\n * be removed from it right away.\n * @param {import(\"../Feature.js\").default<Geometry>} feature Feature to add.\n * @api\n */\n VectorSource.prototype.addFeature = function (feature) {\n this.addFeatureInternal(feature);\n this.changed();\n };\n /**\n * Add a feature without firing a `change` event.\n * @param {import(\"../Feature.js\").default<Geometry>} feature Feature.\n * @protected\n */\n VectorSource.prototype.addFeatureInternal = function (feature) {\n var featureKey = getUid(feature);\n if (!this.addToIndex_(featureKey, feature)) {\n if (this.featuresCollection_) {\n this.featuresCollection_.remove(feature);\n }\n return;\n }\n this.setupChangeEvents_(featureKey, feature);\n var geometry = feature.getGeometry();\n if (geometry) {\n var extent = geometry.getExtent();\n if (this.featuresRtree_) {\n this.featuresRtree_.insert(extent, feature);\n }\n }\n else {\n this.nullGeometryFeatures_[featureKey] = feature;\n }\n this.dispatchEvent(new VectorSourceEvent(VectorEventType.ADDFEATURE, feature));\n };\n /**\n * @param {string} featureKey Unique identifier for the feature.\n * @param {import(\"../Feature.js\").default<Geometry>} feature The feature.\n * @private\n */\n VectorSource.prototype.setupChangeEvents_ = function (featureKey, feature) {\n this.featureChangeKeys_[featureKey] = [\n listen(feature, EventType.CHANGE, this.handleFeatureChange_, this),\n listen(feature, ObjectEventType.PROPERTYCHANGE, this.handleFeatureChange_, this),\n ];\n };\n /**\n * @param {string} featureKey Unique identifier for the feature.\n * @param {import(\"../Feature.js\").default<Geometry>} feature The feature.\n * @return {boolean} The feature is \"valid\", in the sense that it is also a\n * candidate for insertion into the Rtree.\n * @private\n */\n VectorSource.prototype.addToIndex_ = function (featureKey, feature) {\n var valid = true;\n var id = feature.getId();\n if (id !== undefined) {\n if (!(id.toString() in this.idIndex_)) {\n this.idIndex_[id.toString()] = feature;\n }\n else {\n valid = false;\n }\n }\n if (valid) {\n assert(!(featureKey in this.uidIndex_), 30); // The passed `feature` was already added to the source\n this.uidIndex_[featureKey] = feature;\n }\n return valid;\n };\n /**\n * Add a batch of features to the source.\n * @param {Array<import(\"../Feature.js\").default<Geometry>>} features Features to add.\n * @api\n */\n VectorSource.prototype.addFeatures = function (features) {\n this.addFeaturesInternal(features);\n this.changed();\n };\n /**\n * Add features without firing a `change` event.\n * @param {Array<import(\"../Feature.js\").default<Geometry>>} features Features.\n * @protected\n */\n VectorSource.prototype.addFeaturesInternal = function (features) {\n var extents = [];\n var newFeatures = [];\n var geometryFeatures = [];\n for (var i = 0, length_1 = features.length; i < length_1; i++) {\n var feature = features[i];\n var featureKey = getUid(feature);\n if (this.addToIndex_(featureKey, feature)) {\n newFeatures.push(feature);\n }\n }\n for (var i = 0, length_2 = newFeatures.length; i < length_2; i++) {\n var feature = newFeatures[i];\n var featureKey = getUid(feature);\n this.setupChangeEvents_(featureKey, feature);\n var geometry = feature.getGeometry();\n if (geometry) {\n var extent = geometry.getExtent();\n extents.push(extent);\n geometryFeatures.push(feature);\n }\n else {\n this.nullGeometryFeatures_[featureKey] = feature;\n }\n }\n if (this.featuresRtree_) {\n this.featuresRtree_.load(extents, geometryFeatures);\n }\n for (var i = 0, length_3 = newFeatures.length; i < length_3; i++) {\n this.dispatchEvent(new VectorSourceEvent(VectorEventType.ADDFEATURE, newFeatures[i]));\n }\n };\n /**\n * @param {!Collection<import(\"../Feature.js\").default<Geometry>>} collection Collection.\n * @private\n */\n VectorSource.prototype.bindFeaturesCollection_ = function (collection) {\n var modifyingCollection = false;\n this.addEventListener(VectorEventType.ADDFEATURE, \n /**\n * @param {VectorSourceEvent<Geometry>} evt The vector source event\n */\n function (evt) {\n if (!modifyingCollection) {\n modifyingCollection = true;\n collection.push(evt.feature);\n modifyingCollection = false;\n }\n });\n this.addEventListener(VectorEventType.REMOVEFEATURE, \n /**\n * @param {VectorSourceEvent<Geometry>} evt The vector source event\n */\n function (evt) {\n if (!modifyingCollection) {\n modifyingCollection = true;\n collection.remove(evt.feature);\n modifyingCollection = false;\n }\n });\n collection.addEventListener(CollectionEventType.ADD, \n /**\n * @param {import(\"../Collection.js\").CollectionEvent} evt The collection event\n */\n function (evt) {\n if (!modifyingCollection) {\n modifyingCollection = true;\n this.addFeature(\n /** @type {import(\"../Feature.js\").default<Geometry>} */ (evt.element));\n modifyingCollection = false;\n }\n }.bind(this));\n collection.addEventListener(CollectionEventType.REMOVE, \n /**\n * @param {import(\"../Collection.js\").CollectionEvent} evt The collection event\n */\n function (evt) {\n if (!modifyingCollection) {\n modifyingCollection = true;\n this.removeFeature(\n /** @type {import(\"../Feature.js\").default<Geometry>} */ (evt.element));\n modifyingCollection = false;\n }\n }.bind(this));\n this.featuresCollection_ = collection;\n };\n /**\n * Remove all features from the source.\n * @param {boolean} [opt_fast] Skip dispatching of {@link module:ol/source/Vector.VectorSourceEvent#event:removefeature removefeature} events.\n * @api\n */\n VectorSource.prototype.clear = function (opt_fast) {\n if (opt_fast) {\n for (var featureId in this.featureChangeKeys_) {\n var keys = this.featureChangeKeys_[featureId];\n keys.forEach(unlistenByKey);\n }\n if (!this.featuresCollection_) {\n this.featureChangeKeys_ = {};\n this.idIndex_ = {};\n this.uidIndex_ = {};\n }\n }\n else {\n if (this.featuresRtree_) {\n this.featuresRtree_.forEach(this.removeFeatureInternal.bind(this));\n for (var id in this.nullGeometryFeatures_) {\n this.removeFeatureInternal(this.nullGeometryFeatures_[id]);\n }\n }\n }\n if (this.featuresCollection_) {\n this.featuresCollection_.clear();\n }\n if (this.featuresRtree_) {\n this.featuresRtree_.clear();\n }\n this.nullGeometryFeatures_ = {};\n var clearEvent = new VectorSourceEvent(VectorEventType.CLEAR);\n this.dispatchEvent(clearEvent);\n this.changed();\n };\n /**\n * Iterate through all features on the source, calling the provided callback\n * with each one. If the callback returns any \"truthy\" value, iteration will\n * stop and the function will return the same value.\n * Note: this function only iterate through the feature that have a defined geometry.\n *\n * @param {function(import(\"../Feature.js\").default<Geometry>): T} callback Called with each feature\n * on the source. Return a truthy value to stop iteration.\n * @return {T|undefined} The return value from the last call to the callback.\n * @template T\n * @api\n */\n VectorSource.prototype.forEachFeature = function (callback) {\n if (this.featuresRtree_) {\n return this.featuresRtree_.forEach(callback);\n }\n else if (this.featuresCollection_) {\n this.featuresCollection_.forEach(callback);\n }\n };\n /**\n * Iterate through all features whose geometries contain the provided\n * coordinate, calling the callback with each feature. If the callback returns\n * a \"truthy\" value, iteration will stop and the function will return the same\n * value.\n *\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {function(import(\"../Feature.js\").default<Geometry>): T} callback Called with each feature\n * whose goemetry contains the provided coordinate.\n * @return {T|undefined} The return value from the last call to the callback.\n * @template T\n */\n VectorSource.prototype.forEachFeatureAtCoordinateDirect = function (coordinate, callback) {\n var extent = [coordinate[0], coordinate[1], coordinate[0], coordinate[1]];\n return this.forEachFeatureInExtent(extent, function (feature) {\n var geometry = feature.getGeometry();\n if (geometry.intersectsCoordinate(coordinate)) {\n return callback(feature);\n }\n else {\n return undefined;\n }\n });\n };\n /**\n * Iterate through all features whose bounding box intersects the provided\n * extent (note that the feature's geometry may not intersect the extent),\n * calling the callback with each feature. If the callback returns a \"truthy\"\n * value, iteration will stop and the function will return the same value.\n *\n * If you are interested in features whose geometry intersects an extent, call\n * the {@link module:ol/source/Vector~VectorSource#forEachFeatureIntersectingExtent #forEachFeatureIntersectingExtent()} method instead.\n *\n * When `useSpatialIndex` is set to false, this method will loop through all\n * features, equivalent to {@link module:ol/source/Vector~VectorSource#forEachFeature #forEachFeature()}.\n *\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @param {function(import(\"../Feature.js\").default<Geometry>): T} callback Called with each feature\n * whose bounding box intersects the provided extent.\n * @return {T|undefined} The return value from the last call to the callback.\n * @template T\n * @api\n */\n VectorSource.prototype.forEachFeatureInExtent = function (extent, callback) {\n if (this.featuresRtree_) {\n return this.featuresRtree_.forEachInExtent(extent, callback);\n }\n else if (this.featuresCollection_) {\n this.featuresCollection_.forEach(callback);\n }\n };\n /**\n * Iterate through all features whose geometry intersects the provided extent,\n * calling the callback with each feature. If the callback returns a \"truthy\"\n * value, iteration will stop and the function will return the same value.\n *\n * If you only want to test for bounding box intersection, call the\n * {@link module:ol/source/Vector~VectorSource#forEachFeatureInExtent #forEachFeatureInExtent()} method instead.\n *\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @param {function(import(\"../Feature.js\").default<Geometry>): T} callback Called with each feature\n * whose geometry intersects the provided extent.\n * @return {T|undefined} The return value from the last call to the callback.\n * @template T\n * @api\n */\n VectorSource.prototype.forEachFeatureIntersectingExtent = function (extent, callback) {\n return this.forEachFeatureInExtent(extent, \n /**\n * @param {import(\"../Feature.js\").default<Geometry>} feature Feature.\n * @return {T|undefined} The return value from the last call to the callback.\n */\n function (feature) {\n var geometry = feature.getGeometry();\n if (geometry.intersectsExtent(extent)) {\n var result = callback(feature);\n if (result) {\n return result;\n }\n }\n });\n };\n /**\n * Get the features collection associated with this source. Will be `null`\n * unless the source was configured with `useSpatialIndex` set to `false`, or\n * with an {@link module:ol/Collection} as `features`.\n * @return {Collection<import(\"../Feature.js\").default<Geometry>>} The collection of features.\n * @api\n */\n VectorSource.prototype.getFeaturesCollection = function () {\n return this.featuresCollection_;\n };\n /**\n * Get a snapshot of the features currently on the source in random order. The returned array\n * is a copy, the features are references to the features in the source.\n * @return {Array<import(\"../Feature.js\").default<Geometry>>} Features.\n * @api\n */\n VectorSource.prototype.getFeatures = function () {\n var features;\n if (this.featuresCollection_) {\n features = this.featuresCollection_.getArray().slice(0);\n }\n else if (this.featuresRtree_) {\n features = this.featuresRtree_.getAll();\n if (!isEmpty(this.nullGeometryFeatures_)) {\n extend(features, getValues(this.nullGeometryFeatures_));\n }\n }\n return /** @type {Array<import(\"../Feature.js\").default<Geometry>>} */ (features);\n };\n /**\n * Get all features whose geometry intersects the provided coordinate.\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @return {Array<import(\"../Feature.js\").default<Geometry>>} Features.\n * @api\n */\n VectorSource.prototype.getFeaturesAtCoordinate = function (coordinate) {\n var features = [];\n this.forEachFeatureAtCoordinateDirect(coordinate, function (feature) {\n features.push(feature);\n });\n return features;\n };\n /**\n * Get all features whose bounding box intersects the provided extent. Note that this returns an array of\n * all features intersecting the given extent in random order (so it may include\n * features whose geometries do not intersect the extent).\n *\n * When `useSpatialIndex` is set to false, this method will return all\n * features.\n *\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {Array<import(\"../Feature.js\").default<Geometry>>} Features.\n * @api\n */\n VectorSource.prototype.getFeaturesInExtent = function (extent) {\n if (this.featuresRtree_) {\n return this.featuresRtree_.getInExtent(extent);\n }\n else if (this.featuresCollection_) {\n return this.featuresCollection_.getArray().slice(0);\n }\n else {\n return [];\n }\n };\n /**\n * Get the closest feature to the provided coordinate.\n *\n * This method is not available when the source is configured with\n * `useSpatialIndex` set to `false`.\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {function(import(\"../Feature.js\").default<Geometry>):boolean} [opt_filter] Feature filter function.\n * The filter function will receive one argument, the {@link module:ol/Feature feature}\n * and it should return a boolean value. By default, no filtering is made.\n * @return {import(\"../Feature.js\").default<Geometry>} Closest feature.\n * @api\n */\n VectorSource.prototype.getClosestFeatureToCoordinate = function (coordinate, opt_filter) {\n // Find the closest feature using branch and bound. We start searching an\n // infinite extent, and find the distance from the first feature found. This\n // becomes the closest feature. We then compute a smaller extent which any\n // closer feature must intersect. We continue searching with this smaller\n // extent, trying to find a closer feature. Every time we find a closer\n // feature, we update the extent being searched so that any even closer\n // feature must intersect it. We continue until we run out of features.\n var x = coordinate[0];\n var y = coordinate[1];\n var closestFeature = null;\n var closestPoint = [NaN, NaN];\n var minSquaredDistance = Infinity;\n var extent = [-Infinity, -Infinity, Infinity, Infinity];\n var filter = opt_filter ? opt_filter : TRUE;\n this.featuresRtree_.forEachInExtent(extent, \n /**\n * @param {import(\"../Feature.js\").default<Geometry>} feature Feature.\n */\n function (feature) {\n if (filter(feature)) {\n var geometry = feature.getGeometry();\n var previousMinSquaredDistance = minSquaredDistance;\n minSquaredDistance = geometry.closestPointXY(x, y, closestPoint, minSquaredDistance);\n if (minSquaredDistance < previousMinSquaredDistance) {\n closestFeature = feature;\n // This is sneaky. Reduce the extent that it is currently being\n // searched while the R-Tree traversal using this same extent object\n // is still in progress. This is safe because the new extent is\n // strictly contained by the old extent.\n var minDistance = Math.sqrt(minSquaredDistance);\n extent[0] = x - minDistance;\n extent[1] = y - minDistance;\n extent[2] = x + minDistance;\n extent[3] = y + minDistance;\n }\n }\n });\n return closestFeature;\n };\n /**\n * Get the extent of the features currently in the source.\n *\n * This method is not available when the source is configured with\n * `useSpatialIndex` set to `false`.\n * @param {import(\"../extent.js\").Extent} [opt_extent] Destination extent. If provided, no new extent\n * will be created. Instead, that extent's coordinates will be overwritten.\n * @return {import(\"../extent.js\").Extent} Extent.\n * @api\n */\n VectorSource.prototype.getExtent = function (opt_extent) {\n return this.featuresRtree_.getExtent(opt_extent);\n };\n /**\n * Get a feature by its identifier (the value returned by feature.getId()).\n * Note that the index treats string and numeric identifiers as the same. So\n * `source.getFeatureById(2)` will return a feature with id `'2'` or `2`.\n *\n * @param {string|number} id Feature identifier.\n * @return {import(\"../Feature.js\").default<Geometry>} The feature (or `null` if not found).\n * @api\n */\n VectorSource.prototype.getFeatureById = function (id) {\n var feature = this.idIndex_[id.toString()];\n return feature !== undefined ? feature : null;\n };\n /**\n * Get a feature by its internal unique identifier (using `getUid`).\n *\n * @param {string} uid Feature identifier.\n * @return {import(\"../Feature.js\").default<Geometry>} The feature (or `null` if not found).\n */\n VectorSource.prototype.getFeatureByUid = function (uid) {\n var feature = this.uidIndex_[uid];\n return feature !== undefined ? feature : null;\n };\n /**\n * Get the format associated with this source.\n *\n * @return {import(\"../format/Feature.js\").default|undefined} The feature format.\n * @api\n */\n VectorSource.prototype.getFormat = function () {\n return this.format_;\n };\n /**\n * @return {boolean} The source can have overlapping geometries.\n */\n VectorSource.prototype.getOverlaps = function () {\n return this.overlaps_;\n };\n /**\n * Get the url associated with this source.\n *\n * @return {string|import(\"../featureloader.js\").FeatureUrlFunction|undefined} The url.\n * @api\n */\n VectorSource.prototype.getUrl = function () {\n return this.url_;\n };\n /**\n * @param {Event} event Event.\n * @private\n */\n VectorSource.prototype.handleFeatureChange_ = function (event) {\n var feature = /** @type {import(\"../Feature.js\").default<Geometry>} */ (event.target);\n var featureKey = getUid(feature);\n var geometry = feature.getGeometry();\n if (!geometry) {\n if (!(featureKey in this.nullGeometryFeatures_)) {\n if (this.featuresRtree_) {\n this.featuresRtree_.remove(feature);\n }\n this.nullGeometryFeatures_[featureKey] = feature;\n }\n }\n else {\n var extent = geometry.getExtent();\n if (featureKey in this.nullGeometryFeatures_) {\n delete this.nullGeometryFeatures_[featureKey];\n if (this.featuresRtree_) {\n this.featuresRtree_.insert(extent, feature);\n }\n }\n else {\n if (this.featuresRtree_) {\n this.featuresRtree_.update(extent, feature);\n }\n }\n }\n var id = feature.getId();\n if (id !== undefined) {\n var sid = id.toString();\n if (this.idIndex_[sid] !== feature) {\n this.removeFromIdIndex_(feature);\n this.idIndex_[sid] = feature;\n }\n }\n else {\n this.removeFromIdIndex_(feature);\n this.uidIndex_[featureKey] = feature;\n }\n this.changed();\n this.dispatchEvent(new VectorSourceEvent(VectorEventType.CHANGEFEATURE, feature));\n };\n /**\n * Returns true if the feature is contained within the source.\n * @param {import(\"../Feature.js\").default<Geometry>} feature Feature.\n * @return {boolean} Has feature.\n * @api\n */\n VectorSource.prototype.hasFeature = function (feature) {\n var id = feature.getId();\n if (id !== undefined) {\n return id in this.idIndex_;\n }\n else {\n return getUid(feature) in this.uidIndex_;\n }\n };\n /**\n * @return {boolean} Is empty.\n */\n VectorSource.prototype.isEmpty = function () {\n return this.featuresRtree_.isEmpty() && isEmpty(this.nullGeometryFeatures_);\n };\n /**\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @param {number} resolution Resolution.\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n */\n VectorSource.prototype.loadFeatures = function (extent, resolution, projection) {\n var loadedExtentsRtree = this.loadedExtentsRtree_;\n var extentsToLoad = this.strategy_(extent, resolution, projection);\n var _loop_1 = function (i, ii) {\n var extentToLoad = extentsToLoad[i];\n var alreadyLoaded = loadedExtentsRtree.forEachInExtent(extentToLoad, \n /**\n * @param {{extent: import(\"../extent.js\").Extent}} object Object.\n * @return {boolean} Contains.\n */\n function (object) {\n return containsExtent(object.extent, extentToLoad);\n });\n if (!alreadyLoaded) {\n ++this_1.loadingExtentsCount_;\n this_1.dispatchEvent(new VectorSourceEvent(VectorEventType.FEATURESLOADSTART));\n this_1.loader_.call(this_1, extentToLoad, resolution, projection, function (features) {\n --this.loadingExtentsCount_;\n this.dispatchEvent(new VectorSourceEvent(VectorEventType.FEATURESLOADEND, undefined, features));\n }.bind(this_1), function () {\n --this.loadingExtentsCount_;\n this.dispatchEvent(new VectorSourceEvent(VectorEventType.FEATURESLOADERROR));\n }.bind(this_1));\n loadedExtentsRtree.insert(extentToLoad, { extent: extentToLoad.slice() });\n }\n };\n var this_1 = this;\n for (var i = 0, ii = extentsToLoad.length; i < ii; ++i) {\n _loop_1(i, ii);\n }\n this.loading =\n this.loader_.length < 4 ? false : this.loadingExtentsCount_ > 0;\n };\n VectorSource.prototype.refresh = function () {\n this.clear(true);\n this.loadedExtentsRtree_.clear();\n _super.prototype.refresh.call(this);\n };\n /**\n * Remove an extent from the list of loaded extents.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @api\n */\n VectorSource.prototype.removeLoadedExtent = function (extent) {\n var loadedExtentsRtree = this.loadedExtentsRtree_;\n var obj;\n loadedExtentsRtree.forEachInExtent(extent, function (object) {\n if (equals(object.extent, extent)) {\n obj = object;\n return true;\n }\n });\n if (obj) {\n loadedExtentsRtree.remove(obj);\n }\n };\n /**\n * Remove a single feature from the source. If you want to remove all features\n * at once, use the {@link module:ol/source/Vector~VectorSource#clear #clear()} method\n * instead.\n * @param {import(\"../Feature.js\").default<Geometry>} feature Feature to remove.\n * @api\n */\n VectorSource.prototype.removeFeature = function (feature) {\n var featureKey = getUid(feature);\n if (featureKey in this.nullGeometryFeatures_) {\n delete this.nullGeometryFeatures_[featureKey];\n }\n else {\n if (this.featuresRtree_) {\n this.featuresRtree_.remove(feature);\n }\n }\n this.removeFeatureInternal(feature);\n this.changed();\n };\n /**\n * Remove feature without firing a `change` event.\n * @param {import(\"../Feature.js\").default<Geometry>} feature Feature.\n * @protected\n */\n VectorSource.prototype.removeFeatureInternal = function (feature) {\n var featureKey = getUid(feature);\n this.featureChangeKeys_[featureKey].forEach(unlistenByKey);\n delete this.featureChangeKeys_[featureKey];\n var id = feature.getId();\n if (id !== undefined) {\n delete this.idIndex_[id.toString()];\n }\n delete this.uidIndex_[featureKey];\n this.dispatchEvent(new VectorSourceEvent(VectorEventType.REMOVEFEATURE, feature));\n };\n /**\n * Remove a feature from the id index. Called internally when the feature id\n * may have changed.\n * @param {import(\"../Feature.js\").default<Geometry>} feature The feature.\n * @return {boolean} Removed the feature from the index.\n * @private\n */\n VectorSource.prototype.removeFromIdIndex_ = function (feature) {\n var removed = false;\n for (var id in this.idIndex_) {\n if (this.idIndex_[id] === feature) {\n delete this.idIndex_[id];\n removed = true;\n break;\n }\n }\n return removed;\n };\n /**\n * Set the new loader of the source. The next render cycle will use the\n * new loader.\n * @param {import(\"../featureloader.js\").FeatureLoader} loader The loader to set.\n * @api\n */\n VectorSource.prototype.setLoader = function (loader) {\n this.loader_ = loader;\n };\n /**\n * Points the source to a new url. The next render cycle will use the new url.\n * @param {string|import(\"../featureloader.js\").FeatureUrlFunction} url Url.\n * @api\n */\n VectorSource.prototype.setUrl = function (url) {\n assert(this.format_, 7); // `format` must be set when `url` is set\n this.url_ = url;\n this.setLoader(xhr(url, this.format_));\n };\n return VectorSource;\n}(Source));\nexport default VectorSource;\n//# sourceMappingURL=Vector.js.map","/**\n * @module ol/style/Text\n */\nimport Fill from './Fill.js';\nimport TextPlacement from './TextPlacement.js';\nimport { toSize } from '../size.js';\n/**\n * The default fill color to use if no fill was set at construction time; a\n * blackish `#333`.\n *\n * @const {string}\n */\nvar DEFAULT_FILL_COLOR = '#333';\n/**\n * @typedef {Object} Options\n * @property {string} [font] Font style as CSS 'font' value, see:\n * https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/font. Default is '10px sans-serif'\n * @property {number} [maxAngle=Math.PI/4] When `placement` is set to `'line'`, allow a maximum angle between adjacent characters.\n * The expected value is in radians, and the default is 45° (`Math.PI / 4`).\n * @property {number} [offsetX=0] Horizontal text offset in pixels. A positive will shift the text right.\n * @property {number} [offsetY=0] Vertical text offset in pixels. A positive will shift the text down.\n * @property {boolean} [overflow=false] For polygon labels or when `placement` is set to `'line'`, allow text to exceed\n * the width of the polygon at the label position or the length of the path that it follows.\n * @property {import(\"./TextPlacement.js\").default|string} [placement='point'] Text placement.\n * @property {number|import(\"../size.js\").Size} [scale] Scale.\n * @property {boolean} [rotateWithView=false] Whether to rotate the text with the view.\n * @property {number} [rotation=0] Rotation in radians (positive rotation clockwise).\n * @property {string} [text] Text content.\n * @property {string} [textAlign] Text alignment. Possible values: 'left', 'right', 'center', 'end' or 'start'.\n * Default is 'center' for `placement: 'point'`. For `placement: 'line'`, the default is to let the renderer choose a\n * placement where `maxAngle` is not exceeded.\n * @property {string} [textBaseline='middle'] Text base line. Possible values: 'bottom', 'top', 'middle', 'alphabetic',\n * 'hanging', 'ideographic'.\n * @property {import(\"./Fill.js\").default} [fill] Fill style. If none is provided, we'll use a dark fill-style (#333).\n * @property {import(\"./Stroke.js\").default} [stroke] Stroke style.\n * @property {import(\"./Fill.js\").default} [backgroundFill] Fill style for the text background when `placement` is\n * `'point'`. Default is no fill.\n * @property {import(\"./Stroke.js\").default} [backgroundStroke] Stroke style for the text background when `placement`\n * is `'point'`. Default is no stroke.\n * @property {Array<number>} [padding=[0, 0, 0, 0]] Padding in pixels around the text for decluttering and background. The order of\n * values in the array is `[top, right, bottom, left]`.\n */\n/**\n * @classdesc\n * Set text style for vector features.\n * @api\n */\nvar Text = /** @class */ (function () {\n /**\n * @param {Options} [opt_options] Options.\n */\n function Text(opt_options) {\n var options = opt_options || {};\n /**\n * @private\n * @type {string|undefined}\n */\n this.font_ = options.font;\n /**\n * @private\n * @type {number|undefined}\n */\n this.rotation_ = options.rotation;\n /**\n * @private\n * @type {boolean|undefined}\n */\n this.rotateWithView_ = options.rotateWithView;\n /**\n * @private\n * @type {number|import(\"../size.js\").Size|undefined}\n */\n this.scale_ = options.scale;\n /**\n * @private\n * @type {import(\"../size.js\").Size}\n */\n this.scaleArray_ = toSize(options.scale !== undefined ? options.scale : 1);\n /**\n * @private\n * @type {string|undefined}\n */\n this.text_ = options.text;\n /**\n * @private\n * @type {string|undefined}\n */\n this.textAlign_ = options.textAlign;\n /**\n * @private\n * @type {string|undefined}\n */\n this.textBaseline_ = options.textBaseline;\n /**\n * @private\n * @type {import(\"./Fill.js\").default}\n */\n this.fill_ =\n options.fill !== undefined\n ? options.fill\n : new Fill({ color: DEFAULT_FILL_COLOR });\n /**\n * @private\n * @type {number}\n */\n this.maxAngle_ =\n options.maxAngle !== undefined ? options.maxAngle : Math.PI / 4;\n /**\n * @private\n * @type {import(\"./TextPlacement.js\").default|string}\n */\n this.placement_ =\n options.placement !== undefined ? options.placement : TextPlacement.POINT;\n /**\n * @private\n * @type {boolean}\n */\n this.overflow_ = !!options.overflow;\n /**\n * @private\n * @type {import(\"./Stroke.js\").default}\n */\n this.stroke_ = options.stroke !== undefined ? options.stroke : null;\n /**\n * @private\n * @type {number}\n */\n this.offsetX_ = options.offsetX !== undefined ? options.offsetX : 0;\n /**\n * @private\n * @type {number}\n */\n this.offsetY_ = options.offsetY !== undefined ? options.offsetY : 0;\n /**\n * @private\n * @type {import(\"./Fill.js\").default}\n */\n this.backgroundFill_ = options.backgroundFill\n ? options.backgroundFill\n : null;\n /**\n * @private\n * @type {import(\"./Stroke.js\").default}\n */\n this.backgroundStroke_ = options.backgroundStroke\n ? options.backgroundStroke\n : null;\n /**\n * @private\n * @type {Array<number>}\n */\n this.padding_ = options.padding === undefined ? null : options.padding;\n }\n /**\n * Clones the style.\n * @return {Text} The cloned style.\n * @api\n */\n Text.prototype.clone = function () {\n var scale = this.getScale();\n return new Text({\n font: this.getFont(),\n placement: this.getPlacement(),\n maxAngle: this.getMaxAngle(),\n overflow: this.getOverflow(),\n rotation: this.getRotation(),\n rotateWithView: this.getRotateWithView(),\n scale: Array.isArray(scale) ? scale.slice() : scale,\n text: this.getText(),\n textAlign: this.getTextAlign(),\n textBaseline: this.getTextBaseline(),\n fill: this.getFill() ? this.getFill().clone() : undefined,\n stroke: this.getStroke() ? this.getStroke().clone() : undefined,\n offsetX: this.getOffsetX(),\n offsetY: this.getOffsetY(),\n backgroundFill: this.getBackgroundFill()\n ? this.getBackgroundFill().clone()\n : undefined,\n backgroundStroke: this.getBackgroundStroke()\n ? this.getBackgroundStroke().clone()\n : undefined,\n padding: this.getPadding(),\n });\n };\n /**\n * Get the `overflow` configuration.\n * @return {boolean} Let text overflow the length of the path they follow.\n * @api\n */\n Text.prototype.getOverflow = function () {\n return this.overflow_;\n };\n /**\n * Get the font name.\n * @return {string|undefined} Font.\n * @api\n */\n Text.prototype.getFont = function () {\n return this.font_;\n };\n /**\n * Get the maximum angle between adjacent characters.\n * @return {number} Angle in radians.\n * @api\n */\n Text.prototype.getMaxAngle = function () {\n return this.maxAngle_;\n };\n /**\n * Get the label placement.\n * @return {import(\"./TextPlacement.js\").default|string} Text placement.\n * @api\n */\n Text.prototype.getPlacement = function () {\n return this.placement_;\n };\n /**\n * Get the x-offset for the text.\n * @return {number} Horizontal text offset.\n * @api\n */\n Text.prototype.getOffsetX = function () {\n return this.offsetX_;\n };\n /**\n * Get the y-offset for the text.\n * @return {number} Vertical text offset.\n * @api\n */\n Text.prototype.getOffsetY = function () {\n return this.offsetY_;\n };\n /**\n * Get the fill style for the text.\n * @return {import(\"./Fill.js\").default} Fill style.\n * @api\n */\n Text.prototype.getFill = function () {\n return this.fill_;\n };\n /**\n * Determine whether the text rotates with the map.\n * @return {boolean|undefined} Rotate with map.\n * @api\n */\n Text.prototype.getRotateWithView = function () {\n return this.rotateWithView_;\n };\n /**\n * Get the text rotation.\n * @return {number|undefined} Rotation.\n * @api\n */\n Text.prototype.getRotation = function () {\n return this.rotation_;\n };\n /**\n * Get the text scale.\n * @return {number|import(\"../size.js\").Size|undefined} Scale.\n * @api\n */\n Text.prototype.getScale = function () {\n return this.scale_;\n };\n /**\n * Get the symbolizer scale array.\n * @return {import(\"../size.js\").Size} Scale array.\n */\n Text.prototype.getScaleArray = function () {\n return this.scaleArray_;\n };\n /**\n * Get the stroke style for the text.\n * @return {import(\"./Stroke.js\").default} Stroke style.\n * @api\n */\n Text.prototype.getStroke = function () {\n return this.stroke_;\n };\n /**\n * Get the text to be rendered.\n * @return {string|undefined} Text.\n * @api\n */\n Text.prototype.getText = function () {\n return this.text_;\n };\n /**\n * Get the text alignment.\n * @return {string|undefined} Text align.\n * @api\n */\n Text.prototype.getTextAlign = function () {\n return this.textAlign_;\n };\n /**\n * Get the text baseline.\n * @return {string|undefined} Text baseline.\n * @api\n */\n Text.prototype.getTextBaseline = function () {\n return this.textBaseline_;\n };\n /**\n * Get the background fill style for the text.\n * @return {import(\"./Fill.js\").default} Fill style.\n * @api\n */\n Text.prototype.getBackgroundFill = function () {\n return this.backgroundFill_;\n };\n /**\n * Get the background stroke style for the text.\n * @return {import(\"./Stroke.js\").default} Stroke style.\n * @api\n */\n Text.prototype.getBackgroundStroke = function () {\n return this.backgroundStroke_;\n };\n /**\n * Get the padding for the text.\n * @return {Array<number>} Padding.\n * @api\n */\n Text.prototype.getPadding = function () {\n return this.padding_;\n };\n /**\n * Set the `overflow` property.\n *\n * @param {boolean} overflow Let text overflow the path that it follows.\n * @api\n */\n Text.prototype.setOverflow = function (overflow) {\n this.overflow_ = overflow;\n };\n /**\n * Set the font.\n *\n * @param {string|undefined} font Font.\n * @api\n */\n Text.prototype.setFont = function (font) {\n this.font_ = font;\n };\n /**\n * Set the maximum angle between adjacent characters.\n *\n * @param {number} maxAngle Angle in radians.\n * @api\n */\n Text.prototype.setMaxAngle = function (maxAngle) {\n this.maxAngle_ = maxAngle;\n };\n /**\n * Set the x offset.\n *\n * @param {number} offsetX Horizontal text offset.\n * @api\n */\n Text.prototype.setOffsetX = function (offsetX) {\n this.offsetX_ = offsetX;\n };\n /**\n * Set the y offset.\n *\n * @param {number} offsetY Vertical text offset.\n * @api\n */\n Text.prototype.setOffsetY = function (offsetY) {\n this.offsetY_ = offsetY;\n };\n /**\n * Set the text placement.\n *\n * @param {import(\"./TextPlacement.js\").default|string} placement Placement.\n * @api\n */\n Text.prototype.setPlacement = function (placement) {\n this.placement_ = placement;\n };\n /**\n * Set whether to rotate the text with the view.\n *\n * @param {boolean} rotateWithView Rotate with map.\n * @api\n */\n Text.prototype.setRotateWithView = function (rotateWithView) {\n this.rotateWithView_ = rotateWithView;\n };\n /**\n * Set the fill.\n *\n * @param {import(\"./Fill.js\").default} fill Fill style.\n * @api\n */\n Text.prototype.setFill = function (fill) {\n this.fill_ = fill;\n };\n /**\n * Set the rotation.\n *\n * @param {number|undefined} rotation Rotation.\n * @api\n */\n Text.prototype.setRotation = function (rotation) {\n this.rotation_ = rotation;\n };\n /**\n * Set the scale.\n *\n * @param {number|import(\"../size.js\").Size|undefined} scale Scale.\n * @api\n */\n Text.prototype.setScale = function (scale) {\n this.scale_ = scale;\n this.scaleArray_ = toSize(scale !== undefined ? scale : 1);\n };\n /**\n * Set the stroke.\n *\n * @param {import(\"./Stroke.js\").default} stroke Stroke style.\n * @api\n */\n Text.prototype.setStroke = function (stroke) {\n this.stroke_ = stroke;\n };\n /**\n * Set the text.\n *\n * @param {string|undefined} text Text.\n * @api\n */\n Text.prototype.setText = function (text) {\n this.text_ = text;\n };\n /**\n * Set the text alignment.\n *\n * @param {string|undefined} textAlign Text align.\n * @api\n */\n Text.prototype.setTextAlign = function (textAlign) {\n this.textAlign_ = textAlign;\n };\n /**\n * Set the text baseline.\n *\n * @param {string|undefined} textBaseline Text baseline.\n * @api\n */\n Text.prototype.setTextBaseline = function (textBaseline) {\n this.textBaseline_ = textBaseline;\n };\n /**\n * Set the background fill.\n *\n * @param {import(\"./Fill.js\").default} fill Fill style.\n * @api\n */\n Text.prototype.setBackgroundFill = function (fill) {\n this.backgroundFill_ = fill;\n };\n /**\n * Set the background stroke.\n *\n * @param {import(\"./Stroke.js\").default} stroke Stroke style.\n * @api\n */\n Text.prototype.setBackgroundStroke = function (stroke) {\n this.backgroundStroke_ = stroke;\n };\n /**\n * Set the padding (`[top, right, bottom, left]`).\n *\n * @param {!Array<number>} padding Padding.\n * @api\n */\n Text.prototype.setPadding = function (padding) {\n this.padding_ = padding;\n };\n return Text;\n}());\nexport default Text;\n//# sourceMappingURL=Text.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/Feature\n */\nimport BaseObject from './Object.js';\nimport EventType from './events/EventType.js';\nimport { assert } from './asserts.js';\nimport { listen, unlistenByKey } from './events.js';\n/**\n * @typedef {typeof Feature|typeof import(\"./render/Feature.js\").default} FeatureClass\n */\n/**\n * @typedef {Feature<import(\"./geom/Geometry.js\").default>|import(\"./render/Feature.js\").default} FeatureLike\n */\n/***\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature<import(\"./Observable\").EventTypes, import(\"./events/Event.js\").default, Return> &\n * import(\"./Observable\").OnSignature<import(\"./ObjectEventType\").Types|'change:geometry', import(\"./Object\").ObjectEvent, Return> &\n * import(\"./Observable\").CombinedOnSignature<import(\"./Observable\").EventTypes|import(\"./ObjectEventType\").Types\n * |'change:geometry', Return>} FeatureOnSignature\n */\n/***\n * @template Geometry\n * @typedef {Object<string, *> & { geometry?: Geometry }} ObjectWithGeometry\n */\n/**\n * @classdesc\n * A vector object for geographic features with a geometry and other\n * attribute properties, similar to the features in vector file formats like\n * GeoJSON.\n *\n * Features can be styled individually with `setStyle`; otherwise they use the\n * style of their vector layer.\n *\n * Note that attribute properties are set as {@link module:ol/Object} properties on\n * the feature object, so they are observable, and have get/set accessors.\n *\n * Typically, a feature has a single geometry property. You can set the\n * geometry using the `setGeometry` method and get it with `getGeometry`.\n * It is possible to store more than one geometry on a feature using attribute\n * properties. By default, the geometry used for rendering is identified by\n * the property name `geometry`. If you want to use another geometry property\n * for rendering, use the `setGeometryName` method to change the attribute\n * property associated with the geometry for the feature. For example:\n *\n * ```js\n *\n * import Feature from 'ol/Feature';\n * import Polygon from 'ol/geom/Polygon';\n * import Point from 'ol/geom/Point';\n *\n * var feature = new Feature({\n * geometry: new Polygon(polyCoords),\n * labelPoint: new Point(labelCoords),\n * name: 'My Polygon'\n * });\n *\n * // get the polygon geometry\n * var poly = feature.getGeometry();\n *\n * // Render the feature as a point using the coordinates from labelPoint\n * feature.setGeometryName('labelPoint');\n *\n * // get the point geometry\n * var point = feature.getGeometry();\n * ```\n *\n * @api\n * @template {import(\"./geom/Geometry.js\").default} Geometry\n */\nvar Feature = /** @class */ (function (_super) {\n __extends(Feature, _super);\n /**\n * @param {Geometry|ObjectWithGeometry<Geometry>} [opt_geometryOrProperties]\n * You may pass a Geometry object directly, or an object literal containing\n * properties. If you pass an object literal, you may include a Geometry\n * associated with a `geometry` key.\n */\n function Feature(opt_geometryOrProperties) {\n var _this = _super.call(this) || this;\n /***\n * @type {FeatureOnSignature<import(\"./events\").EventsKey>}\n */\n _this.on;\n /***\n * @type {FeatureOnSignature<import(\"./events\").EventsKey>}\n */\n _this.once;\n /***\n * @type {FeatureOnSignature<void>}\n */\n _this.un;\n /**\n * @private\n * @type {number|string|undefined}\n */\n _this.id_ = undefined;\n /**\n * @type {string}\n * @private\n */\n _this.geometryName_ = 'geometry';\n /**\n * User provided style.\n * @private\n * @type {import(\"./style/Style.js\").StyleLike}\n */\n _this.style_ = null;\n /**\n * @private\n * @type {import(\"./style/Style.js\").StyleFunction|undefined}\n */\n _this.styleFunction_ = undefined;\n /**\n * @private\n * @type {?import(\"./events.js\").EventsKey}\n */\n _this.geometryChangeKey_ = null;\n _this.addChangeListener(_this.geometryName_, _this.handleGeometryChanged_);\n if (opt_geometryOrProperties) {\n if (typeof (\n /** @type {?} */ (opt_geometryOrProperties).getSimplifiedGeometry) === 'function') {\n var geometry = /** @type {Geometry} */ (opt_geometryOrProperties);\n _this.setGeometry(geometry);\n }\n else {\n /** @type {Object<string, *>} */\n var properties = opt_geometryOrProperties;\n _this.setProperties(properties);\n }\n }\n return _this;\n }\n /**\n * Clone this feature. If the original feature has a geometry it\n * is also cloned. The feature id is not set in the clone.\n * @return {Feature<Geometry>} The clone.\n * @api\n */\n Feature.prototype.clone = function () {\n var clone = /** @type {Feature<Geometry>} */ (new Feature(this.hasProperties() ? this.getProperties() : null));\n clone.setGeometryName(this.getGeometryName());\n var geometry = this.getGeometry();\n if (geometry) {\n clone.setGeometry(/** @type {Geometry} */ (geometry.clone()));\n }\n var style = this.getStyle();\n if (style) {\n clone.setStyle(style);\n }\n return clone;\n };\n /**\n * Get the feature's default geometry. A feature may have any number of named\n * geometries. The \"default\" geometry (the one that is rendered by default) is\n * set when calling {@link module:ol/Feature~Feature#setGeometry}.\n * @return {Geometry|undefined} The default geometry for the feature.\n * @api\n * @observable\n */\n Feature.prototype.getGeometry = function () {\n return /** @type {Geometry|undefined} */ (this.get(this.geometryName_));\n };\n /**\n * Get the feature identifier. This is a stable identifier for the feature and\n * is either set when reading data from a remote source or set explicitly by\n * calling {@link module:ol/Feature~Feature#setId}.\n * @return {number|string|undefined} Id.\n * @api\n */\n Feature.prototype.getId = function () {\n return this.id_;\n };\n /**\n * Get the name of the feature's default geometry. By default, the default\n * geometry is named `geometry`.\n * @return {string} Get the property name associated with the default geometry\n * for this feature.\n * @api\n */\n Feature.prototype.getGeometryName = function () {\n return this.geometryName_;\n };\n /**\n * Get the feature's style. Will return what was provided to the\n * {@link module:ol/Feature~Feature#setStyle} method.\n * @return {import(\"./style/Style.js\").StyleLike|undefined} The feature style.\n * @api\n */\n Feature.prototype.getStyle = function () {\n return this.style_;\n };\n /**\n * Get the feature's style function.\n * @return {import(\"./style/Style.js\").StyleFunction|undefined} Return a function\n * representing the current style of this feature.\n * @api\n */\n Feature.prototype.getStyleFunction = function () {\n return this.styleFunction_;\n };\n /**\n * @private\n */\n Feature.prototype.handleGeometryChange_ = function () {\n this.changed();\n };\n /**\n * @private\n */\n Feature.prototype.handleGeometryChanged_ = function () {\n if (this.geometryChangeKey_) {\n unlistenByKey(this.geometryChangeKey_);\n this.geometryChangeKey_ = null;\n }\n var geometry = this.getGeometry();\n if (geometry) {\n this.geometryChangeKey_ = listen(geometry, EventType.CHANGE, this.handleGeometryChange_, this);\n }\n this.changed();\n };\n /**\n * Set the default geometry for the feature. This will update the property\n * with the name returned by {@link module:ol/Feature~Feature#getGeometryName}.\n * @param {Geometry|undefined} geometry The new geometry.\n * @api\n * @observable\n */\n Feature.prototype.setGeometry = function (geometry) {\n this.set(this.geometryName_, geometry);\n };\n /**\n * Set the style for the feature to override the layer style. This can be a\n * single style object, an array of styles, or a function that takes a\n * resolution and returns an array of styles. To unset the feature style, call\n * `setStyle()` without arguments or a falsey value.\n * @param {import(\"./style/Style.js\").StyleLike} [opt_style] Style for this feature.\n * @api\n * @fires module:ol/events/Event~BaseEvent#event:change\n */\n Feature.prototype.setStyle = function (opt_style) {\n this.style_ = opt_style;\n this.styleFunction_ = !opt_style\n ? undefined\n : createStyleFunction(opt_style);\n this.changed();\n };\n /**\n * Set the feature id. The feature id is considered stable and may be used when\n * requesting features or comparing identifiers returned from a remote source.\n * The feature id can be used with the\n * {@link module:ol/source/Vector~VectorSource#getFeatureById} method.\n * @param {number|string|undefined} id The feature id.\n * @api\n * @fires module:ol/events/Event~BaseEvent#event:change\n */\n Feature.prototype.setId = function (id) {\n this.id_ = id;\n this.changed();\n };\n /**\n * Set the property name to be used when getting the feature's default geometry.\n * When calling {@link module:ol/Feature~Feature#getGeometry}, the value of the property with\n * this name will be returned.\n * @param {string} name The property name of the default geometry.\n * @api\n */\n Feature.prototype.setGeometryName = function (name) {\n this.removeChangeListener(this.geometryName_, this.handleGeometryChanged_);\n this.geometryName_ = name;\n this.addChangeListener(this.geometryName_, this.handleGeometryChanged_);\n this.handleGeometryChanged_();\n };\n return Feature;\n}(BaseObject));\n/**\n * Convert the provided object into a feature style function. Functions passed\n * through unchanged. Arrays of Style or single style objects wrapped\n * in a new feature style function.\n * @param {!import(\"./style/Style.js\").StyleFunction|!Array<import(\"./style/Style.js\").default>|!import(\"./style/Style.js\").default} obj\n * A feature style function, a single style, or an array of styles.\n * @return {import(\"./style/Style.js\").StyleFunction} A style function.\n */\nexport function createStyleFunction(obj) {\n if (typeof obj === 'function') {\n return obj;\n }\n else {\n /**\n * @type {Array<import(\"./style/Style.js\").default>}\n */\n var styles_1;\n if (Array.isArray(obj)) {\n styles_1 = obj;\n }\n else {\n assert(typeof ( /** @type {?} */(obj).getZIndex) === 'function', 41); // Expected an `import(\"./style/Style.js\").Style` or an array of `import(\"./style/Style.js\").Style`\n var style = /** @type {import(\"./style/Style.js\").default} */ (obj);\n styles_1 = [style];\n }\n return function () {\n return styles_1;\n };\n }\n}\nexport default Feature;\n//# sourceMappingURL=Feature.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/renderer/Map\n */\nimport Disposable from '../Disposable.js';\nimport { TRUE } from '../functions.js';\nimport { abstract } from '../util.js';\nimport { compose as composeTransform, makeInverse } from '../transform.js';\nimport { getWidth } from '../extent.js';\nimport { shared as iconImageCache } from '../style/IconImageCache.js';\nimport { inView } from '../layer/Layer.js';\nimport { wrapX } from '../coordinate.js';\n/**\n * @typedef HitMatch\n * @property {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @property {import(\"../layer/Layer.js\").default} layer Layer.\n * @property {import(\"../geom/SimpleGeometry.js\").default} geometry Geometry.\n * @property {number} distanceSq Squared distance.\n * @property {import(\"./vector.js\").FeatureCallback<T>} callback Callback.\n * @template T\n */\n/**\n * @abstract\n */\nvar MapRenderer = /** @class */ (function (_super) {\n __extends(MapRenderer, _super);\n /**\n * @param {import(\"../PluggableMap.js\").default} map Map.\n */\n function MapRenderer(map) {\n var _this = _super.call(this) || this;\n /**\n * @private\n * @type {import(\"../PluggableMap.js\").default}\n */\n _this.map_ = map;\n return _this;\n }\n /**\n * @abstract\n * @param {import(\"../render/EventType.js\").default} type Event type.\n * @param {import(\"../PluggableMap.js\").FrameState} frameState Frame state.\n */\n MapRenderer.prototype.dispatchRenderEvent = function (type, frameState) {\n abstract();\n };\n /**\n * @param {import(\"../PluggableMap.js\").FrameState} frameState FrameState.\n * @protected\n */\n MapRenderer.prototype.calculateMatrices2D = function (frameState) {\n var viewState = frameState.viewState;\n var coordinateToPixelTransform = frameState.coordinateToPixelTransform;\n var pixelToCoordinateTransform = frameState.pixelToCoordinateTransform;\n composeTransform(coordinateToPixelTransform, frameState.size[0] / 2, frameState.size[1] / 2, 1 / viewState.resolution, -1 / viewState.resolution, -viewState.rotation, -viewState.center[0], -viewState.center[1]);\n makeInverse(pixelToCoordinateTransform, coordinateToPixelTransform);\n };\n /**\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {import(\"../PluggableMap.js\").FrameState} frameState FrameState.\n * @param {number} hitTolerance Hit tolerance in pixels.\n * @param {boolean} checkWrapped Check for wrapped geometries.\n * @param {import(\"./vector.js\").FeatureCallback<T>} callback Feature callback.\n * @param {S} thisArg Value to use as `this` when executing `callback`.\n * @param {function(this: U, import(\"../layer/Layer.js\").default): boolean} layerFilter Layer filter\n * function, only layers which are visible and for which this function\n * returns `true` will be tested for features. By default, all visible\n * layers will be tested.\n * @param {U} thisArg2 Value to use as `this` when executing `layerFilter`.\n * @return {T|undefined} Callback result.\n * @template S,T,U\n */\n MapRenderer.prototype.forEachFeatureAtCoordinate = function (coordinate, frameState, hitTolerance, checkWrapped, callback, thisArg, layerFilter, thisArg2) {\n var result;\n var viewState = frameState.viewState;\n /**\n * @param {boolean} managed Managed layer.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {import(\"../layer/Layer.js\").default} layer Layer.\n * @param {import(\"../geom/Geometry.js\").default} geometry Geometry.\n * @return {T|undefined} Callback result.\n */\n function forEachFeatureAtCoordinate(managed, feature, layer, geometry) {\n return callback.call(thisArg, feature, managed ? layer : null, geometry);\n }\n var projection = viewState.projection;\n var translatedCoordinate = wrapX(coordinate.slice(), projection);\n var offsets = [[0, 0]];\n if (projection.canWrapX() && checkWrapped) {\n var projectionExtent = projection.getExtent();\n var worldWidth = getWidth(projectionExtent);\n offsets.push([-worldWidth, 0], [worldWidth, 0]);\n }\n var layerStates = frameState.layerStatesArray;\n var numLayers = layerStates.length;\n var matches = /** @type {Array<HitMatch<T>>} */ ([]);\n var tmpCoord = [];\n for (var i = 0; i < offsets.length; i++) {\n for (var j = numLayers - 1; j >= 0; --j) {\n var layerState = layerStates[j];\n var layer = layerState.layer;\n if (layer.hasRenderer() &&\n inView(layerState, viewState) &&\n layerFilter.call(thisArg2, layer)) {\n var layerRenderer = layer.getRenderer();\n var source = layer.getSource();\n if (layerRenderer && source) {\n var coordinates = source.getWrapX()\n ? translatedCoordinate\n : coordinate;\n var callback_1 = forEachFeatureAtCoordinate.bind(null, layerState.managed);\n tmpCoord[0] = coordinates[0] + offsets[i][0];\n tmpCoord[1] = coordinates[1] + offsets[i][1];\n result = layerRenderer.forEachFeatureAtCoordinate(tmpCoord, frameState, hitTolerance, callback_1, matches);\n }\n if (result) {\n return result;\n }\n }\n }\n }\n if (matches.length === 0) {\n return undefined;\n }\n var order = 1 / matches.length;\n matches.forEach(function (m, i) { return (m.distanceSq += i * order); });\n matches.sort(function (a, b) { return a.distanceSq - b.distanceSq; });\n matches.some(function (m) {\n return (result = m.callback(m.feature, m.layer, m.geometry));\n });\n return result;\n };\n /**\n * @abstract\n * @param {import(\"../pixel.js\").Pixel} pixel Pixel.\n * @param {import(\"../PluggableMap.js\").FrameState} frameState FrameState.\n * @param {number} hitTolerance Hit tolerance in pixels.\n * @param {function(import(\"../layer/Layer.js\").default<import(\"../source/Source\").default>, (Uint8ClampedArray|Uint8Array)): T} callback Layer\n * callback.\n * @param {function(import(\"../layer/Layer.js\").default<import(\"../source/Source\").default>): boolean} layerFilter Layer filter\n * function, only layers which are visible and for which this function\n * returns `true` will be tested for features. By default, all visible\n * layers will be tested.\n * @return {T|undefined} Callback result.\n * @template T\n */\n MapRenderer.prototype.forEachLayerAtPixel = function (pixel, frameState, hitTolerance, callback, layerFilter) {\n return abstract();\n };\n /**\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {import(\"../PluggableMap.js\").FrameState} frameState FrameState.\n * @param {number} hitTolerance Hit tolerance in pixels.\n * @param {boolean} checkWrapped Check for wrapped geometries.\n * @param {function(this: U, import(\"../layer/Layer.js\").default): boolean} layerFilter Layer filter\n * function, only layers which are visible and for which this function\n * returns `true` will be tested for features. By default, all visible\n * layers will be tested.\n * @param {U} thisArg Value to use as `this` when executing `layerFilter`.\n * @return {boolean} Is there a feature at the given coordinate?\n * @template U\n */\n MapRenderer.prototype.hasFeatureAtCoordinate = function (coordinate, frameState, hitTolerance, checkWrapped, layerFilter, thisArg) {\n var hasFeature = this.forEachFeatureAtCoordinate(coordinate, frameState, hitTolerance, checkWrapped, TRUE, this, layerFilter, thisArg);\n return hasFeature !== undefined;\n };\n /**\n * @return {import(\"../PluggableMap.js\").default} Map.\n */\n MapRenderer.prototype.getMap = function () {\n return this.map_;\n };\n /**\n * Render.\n * @abstract\n * @param {?import(\"../PluggableMap.js\").FrameState} frameState Frame state.\n */\n MapRenderer.prototype.renderFrame = function (frameState) {\n abstract();\n };\n /**\n * @param {import(\"../PluggableMap.js\").FrameState} frameState Frame state.\n * @protected\n */\n MapRenderer.prototype.scheduleExpireIconCache = function (frameState) {\n if (iconImageCache.canExpireCache()) {\n frameState.postRenderFunctions.push(expireIconCache);\n }\n };\n return MapRenderer;\n}(Disposable));\n/**\n * @param {import(\"../PluggableMap.js\").default} map Map.\n * @param {import(\"../PluggableMap.js\").FrameState} frameState Frame state.\n */\nfunction expireIconCache(map, frameState) {\n iconImageCache.expire();\n}\nexport default MapRenderer;\n//# sourceMappingURL=Map.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/renderer/Composite\n */\nimport MapRenderer from './Map.js';\nimport ObjectEventType from '../ObjectEventType.js';\nimport RenderEvent from '../render/Event.js';\nimport RenderEventType from '../render/EventType.js';\nimport SourceState from '../source/State.js';\nimport { CLASS_UNSELECTABLE } from '../css.js';\nimport { checkedFonts } from '../render/canvas.js';\nimport { inView } from '../layer/Layer.js';\nimport { listen, unlistenByKey } from '../events.js';\nimport { replaceChildren } from '../dom.js';\n/**\n * @classdesc\n * Canvas map renderer.\n * @api\n */\nvar CompositeMapRenderer = /** @class */ (function (_super) {\n __extends(CompositeMapRenderer, _super);\n /**\n * @param {import(\"../PluggableMap.js\").default} map Map.\n */\n function CompositeMapRenderer(map) {\n var _this = _super.call(this, map) || this;\n /**\n * @type {import(\"../events.js\").EventsKey}\n */\n _this.fontChangeListenerKey_ = listen(checkedFonts, ObjectEventType.PROPERTYCHANGE, map.redrawText.bind(map));\n /**\n * @private\n * @type {HTMLDivElement}\n */\n _this.element_ = document.createElement('div');\n var style = _this.element_.style;\n style.position = 'absolute';\n style.width = '100%';\n style.height = '100%';\n style.zIndex = '0';\n _this.element_.className = CLASS_UNSELECTABLE + ' ol-layers';\n var container = map.getViewport();\n container.insertBefore(_this.element_, container.firstChild || null);\n /**\n * @private\n * @type {Array<HTMLElement>}\n */\n _this.children_ = [];\n /**\n * @private\n * @type {boolean}\n */\n _this.renderedVisible_ = true;\n return _this;\n }\n /**\n * @param {import(\"../render/EventType.js\").default} type Event type.\n * @param {import(\"../PluggableMap.js\").FrameState} frameState Frame state.\n */\n CompositeMapRenderer.prototype.dispatchRenderEvent = function (type, frameState) {\n var map = this.getMap();\n if (map.hasListener(type)) {\n var event_1 = new RenderEvent(type, undefined, frameState);\n map.dispatchEvent(event_1);\n }\n };\n CompositeMapRenderer.prototype.disposeInternal = function () {\n unlistenByKey(this.fontChangeListenerKey_);\n this.element_.parentNode.removeChild(this.element_);\n _super.prototype.disposeInternal.call(this);\n };\n /**\n * Render.\n * @param {?import(\"../PluggableMap.js\").FrameState} frameState Frame state.\n */\n CompositeMapRenderer.prototype.renderFrame = function (frameState) {\n if (!frameState) {\n if (this.renderedVisible_) {\n this.element_.style.display = 'none';\n this.renderedVisible_ = false;\n }\n return;\n }\n this.calculateMatrices2D(frameState);\n this.dispatchRenderEvent(RenderEventType.PRECOMPOSE, frameState);\n var layerStatesArray = frameState.layerStatesArray.sort(function (a, b) {\n return a.zIndex - b.zIndex;\n });\n var viewState = frameState.viewState;\n this.children_.length = 0;\n /**\n * @type {Array<import(\"../layer/BaseVector.js\").default>}\n */\n var declutterLayers = [];\n var previousElement = null;\n for (var i = 0, ii = layerStatesArray.length; i < ii; ++i) {\n var layerState = layerStatesArray[i];\n frameState.layerIndex = i;\n if (!inView(layerState, viewState) ||\n (layerState.sourceState != SourceState.READY &&\n layerState.sourceState != SourceState.UNDEFINED)) {\n continue;\n }\n var layer = layerState.layer;\n var element = layer.render(frameState, previousElement);\n if (!element) {\n continue;\n }\n if (element !== previousElement) {\n this.children_.push(element);\n previousElement = element;\n }\n if ('getDeclutter' in layer) {\n declutterLayers.push(\n /** @type {import(\"../layer/BaseVector.js\").default} */ (layer));\n }\n }\n for (var i = declutterLayers.length - 1; i >= 0; --i) {\n declutterLayers[i].renderDeclutter(frameState);\n }\n replaceChildren(this.element_, this.children_);\n this.dispatchRenderEvent(RenderEventType.POSTCOMPOSE, frameState);\n if (!this.renderedVisible_) {\n this.element_.style.display = '';\n this.renderedVisible_ = true;\n }\n this.scheduleExpireIconCache(frameState);\n };\n /**\n * @param {import(\"../pixel.js\").Pixel} pixel Pixel.\n * @param {import(\"../PluggableMap.js\").FrameState} frameState FrameState.\n * @param {number} hitTolerance Hit tolerance in pixels.\n * @param {function(import(\"../layer/Layer.js\").default<import(\"../source/Source\").default>, (Uint8ClampedArray|Uint8Array)): T} callback Layer\n * callback.\n * @param {function(import(\"../layer/Layer.js\").default<import(\"../source/Source\").default>): boolean} layerFilter Layer filter\n * function, only layers which are visible and for which this function\n * returns `true` will be tested for features. By default, all visible\n * layers will be tested.\n * @return {T|undefined} Callback result.\n * @template T\n */\n CompositeMapRenderer.prototype.forEachLayerAtPixel = function (pixel, frameState, hitTolerance, callback, layerFilter) {\n var viewState = frameState.viewState;\n var layerStates = frameState.layerStatesArray;\n var numLayers = layerStates.length;\n for (var i = numLayers - 1; i >= 0; --i) {\n var layerState = layerStates[i];\n var layer = layerState.layer;\n if (layer.hasRenderer() &&\n inView(layerState, viewState) &&\n layerFilter(layer)) {\n var layerRenderer = layer.getRenderer();\n var data = layerRenderer.getDataAtPixel(pixel, frameState, hitTolerance);\n if (data) {\n var result = callback(layer, data);\n if (result) {\n return result;\n }\n }\n }\n }\n return undefined;\n };\n return CompositeMapRenderer;\n}(MapRenderer));\nexport default CompositeMapRenderer;\n//# sourceMappingURL=Composite.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/layer/Group\n */\nimport BaseLayer from './Base.js';\nimport Collection from '../Collection.js';\nimport CollectionEventType from '../CollectionEventType.js';\nimport EventType from '../events/EventType.js';\nimport ObjectEventType from '../ObjectEventType.js';\nimport SourceState from '../source/State.js';\nimport { assert } from '../asserts.js';\nimport { assign, clear } from '../obj.js';\nimport { getIntersection } from '../extent.js';\nimport { getUid } from '../util.js';\nimport { listen, unlistenByKey } from '../events.js';\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n * import(\"../Observable\").OnSignature<import(\"./Base\").BaseLayerObjectEventTypes|\n * 'change:layers', import(\"../Object\").ObjectEvent, Return> &\n * import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"./Base\").BaseLayerObjectEventTypes|'change:layers', Return>} GroupOnSignature\n */\n/**\n * @typedef {Object} Options\n * @property {number} [opacity=1] Opacity (0, 1).\n * @property {boolean} [visible=true] Visibility.\n * @property {import(\"../extent.js\").Extent} [extent] The bounding extent for layer rendering. The layer will not be\n * rendered outside of this extent.\n * @property {number} [zIndex] The z-index for layer rendering. At rendering time, the layers\n * will be ordered, first by Z-index and then by position. When `undefined`, a `zIndex` of 0 is assumed\n * for layers that are added to the map's `layers` collection, or `Infinity` when the layer's `setMap()`\n * method was used.\n * @property {number} [minResolution] The minimum resolution (inclusive) at which this layer will be\n * visible.\n * @property {number} [maxResolution] The maximum resolution (exclusive) below which this layer will\n * be visible.\n * @property {number} [minZoom] The minimum view zoom level (exclusive) above which this layer will be\n * visible.\n * @property {number} [maxZoom] The maximum view zoom level (inclusive) at which this layer will\n * be visible.\n * @property {Array<import(\"./Base.js\").default>|import(\"../Collection.js\").default<import(\"./Base.js\").default>} [layers] Child layers.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n/**\n * @enum {string}\n * @private\n */\nvar Property = {\n LAYERS: 'layers',\n};\n/**\n * @classdesc\n * A {@link module:ol/Collection~Collection} of layers that are handled together.\n *\n * A generic `change` event is triggered when the group/Collection changes.\n *\n * @api\n */\nvar LayerGroup = /** @class */ (function (_super) {\n __extends(LayerGroup, _super);\n /**\n * @param {Options} [opt_options] Layer options.\n */\n function LayerGroup(opt_options) {\n var _this = this;\n var options = opt_options || {};\n var baseOptions = /** @type {Options} */ (assign({}, options));\n delete baseOptions.layers;\n var layers = options.layers;\n _this = _super.call(this, baseOptions) || this;\n /***\n * @type {GroupOnSignature<import(\"../events\").EventsKey>}\n */\n _this.on;\n /***\n * @type {GroupOnSignature<import(\"../events\").EventsKey>}\n */\n _this.once;\n /***\n * @type {GroupOnSignature<void>}\n */\n _this.un;\n /**\n * @private\n * @type {Array<import(\"../events.js\").EventsKey>}\n */\n _this.layersListenerKeys_ = [];\n /**\n * @private\n * @type {Object<string, Array<import(\"../events.js\").EventsKey>>}\n */\n _this.listenerKeys_ = {};\n _this.addChangeListener(Property.LAYERS, _this.handleLayersChanged_);\n if (layers) {\n if (Array.isArray(layers)) {\n layers = new Collection(layers.slice(), { unique: true });\n }\n else {\n assert(typeof ( /** @type {?} */(layers).getArray) === 'function', 43); // Expected `layers` to be an array or a `Collection`\n }\n }\n else {\n layers = new Collection(undefined, { unique: true });\n }\n _this.setLayers(layers);\n return _this;\n }\n /**\n * @private\n */\n LayerGroup.prototype.handleLayerChange_ = function () {\n this.changed();\n };\n /**\n * @private\n */\n LayerGroup.prototype.handleLayersChanged_ = function () {\n this.layersListenerKeys_.forEach(unlistenByKey);\n this.layersListenerKeys_.length = 0;\n var layers = this.getLayers();\n this.layersListenerKeys_.push(listen(layers, CollectionEventType.ADD, this.handleLayersAdd_, this), listen(layers, CollectionEventType.REMOVE, this.handleLayersRemove_, this));\n for (var id in this.listenerKeys_) {\n this.listenerKeys_[id].forEach(unlistenByKey);\n }\n clear(this.listenerKeys_);\n var layersArray = layers.getArray();\n for (var i = 0, ii = layersArray.length; i < ii; i++) {\n var layer = layersArray[i];\n this.listenerKeys_[getUid(layer)] = [\n listen(layer, ObjectEventType.PROPERTYCHANGE, this.handleLayerChange_, this),\n listen(layer, EventType.CHANGE, this.handleLayerChange_, this),\n ];\n }\n this.changed();\n };\n /**\n * @param {import(\"../Collection.js\").CollectionEvent} collectionEvent CollectionEvent.\n * @private\n */\n LayerGroup.prototype.handleLayersAdd_ = function (collectionEvent) {\n var layer = /** @type {import(\"./Base.js\").default} */ (collectionEvent.element);\n this.listenerKeys_[getUid(layer)] = [\n listen(layer, ObjectEventType.PROPERTYCHANGE, this.handleLayerChange_, this),\n listen(layer, EventType.CHANGE, this.handleLayerChange_, this),\n ];\n this.changed();\n };\n /**\n * @param {import(\"../Collection.js\").CollectionEvent} collectionEvent CollectionEvent.\n * @private\n */\n LayerGroup.prototype.handleLayersRemove_ = function (collectionEvent) {\n var layer = /** @type {import(\"./Base.js\").default} */ (collectionEvent.element);\n var key = getUid(layer);\n this.listenerKeys_[key].forEach(unlistenByKey);\n delete this.listenerKeys_[key];\n this.changed();\n };\n /**\n * Returns the {@link module:ol/Collection collection} of {@link module:ol/layer/Layer~Layer layers}\n * in this group.\n * @return {!import(\"../Collection.js\").default<import(\"./Base.js\").default>} Collection of\n * {@link module:ol/layer/Base layers} that are part of this group.\n * @observable\n * @api\n */\n LayerGroup.prototype.getLayers = function () {\n return /** @type {!import(\"../Collection.js\").default<import(\"./Base.js\").default>} */ (this.get(Property.LAYERS));\n };\n /**\n * Set the {@link module:ol/Collection collection} of {@link module:ol/layer/Layer~Layer layers}\n * in this group.\n * @param {!import(\"../Collection.js\").default<import(\"./Base.js\").default>} layers Collection of\n * {@link module:ol/layer/Base layers} that are part of this group.\n * @observable\n * @api\n */\n LayerGroup.prototype.setLayers = function (layers) {\n this.set(Property.LAYERS, layers);\n };\n /**\n * @param {Array<import(\"./Layer.js\").default>} [opt_array] Array of layers (to be modified in place).\n * @return {Array<import(\"./Layer.js\").default>} Array of layers.\n */\n LayerGroup.prototype.getLayersArray = function (opt_array) {\n var array = opt_array !== undefined ? opt_array : [];\n this.getLayers().forEach(function (layer) {\n layer.getLayersArray(array);\n });\n return array;\n };\n /**\n * Get the layer states list and use this groups z-index as the default\n * for all layers in this and nested groups, if it is unset at this point.\n * If opt_states is not provided and this group's z-index is undefined\n * 0 is used a the default z-index.\n * @param {Array<import(\"./Layer.js\").State>} [opt_states] Optional list\n * of layer states (to be modified in place).\n * @return {Array<import(\"./Layer.js\").State>} List of layer states.\n */\n LayerGroup.prototype.getLayerStatesArray = function (opt_states) {\n var states = opt_states !== undefined ? opt_states : [];\n var pos = states.length;\n this.getLayers().forEach(function (layer) {\n layer.getLayerStatesArray(states);\n });\n var ownLayerState = this.getLayerState();\n var defaultZIndex = ownLayerState.zIndex;\n if (!opt_states && ownLayerState.zIndex === undefined) {\n defaultZIndex = 0;\n }\n for (var i = pos, ii = states.length; i < ii; i++) {\n var layerState = states[i];\n layerState.opacity *= ownLayerState.opacity;\n layerState.visible = layerState.visible && ownLayerState.visible;\n layerState.maxResolution = Math.min(layerState.maxResolution, ownLayerState.maxResolution);\n layerState.minResolution = Math.max(layerState.minResolution, ownLayerState.minResolution);\n layerState.minZoom = Math.max(layerState.minZoom, ownLayerState.minZoom);\n layerState.maxZoom = Math.min(layerState.maxZoom, ownLayerState.maxZoom);\n if (ownLayerState.extent !== undefined) {\n if (layerState.extent !== undefined) {\n layerState.extent = getIntersection(layerState.extent, ownLayerState.extent);\n }\n else {\n layerState.extent = ownLayerState.extent;\n }\n }\n if (layerState.zIndex === undefined) {\n layerState.zIndex = defaultZIndex;\n }\n }\n return states;\n };\n /**\n * @return {import(\"../source/State.js\").default} Source state.\n */\n LayerGroup.prototype.getSourceState = function () {\n return SourceState.READY;\n };\n return LayerGroup;\n}(BaseLayer));\nexport default LayerGroup;\n//# sourceMappingURL=Group.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/MapEvent\n */\nimport Event from './events/Event.js';\n/**\n * @classdesc\n * Events emitted as map events are instances of this type.\n * See {@link module:ol/PluggableMap~PluggableMap} for which events trigger a map event.\n */\nvar MapEvent = /** @class */ (function (_super) {\n __extends(MapEvent, _super);\n /**\n * @param {string} type Event type.\n * @param {import(\"./PluggableMap.js\").default} map Map.\n * @param {?import(\"./PluggableMap.js\").FrameState} [opt_frameState] Frame state.\n */\n function MapEvent(type, map, opt_frameState) {\n var _this = _super.call(this, type) || this;\n /**\n * The map where the event occurred.\n * @type {import(\"./PluggableMap.js\").default}\n * @api\n */\n _this.map = map;\n /**\n * The frame state at the time of the event.\n * @type {?import(\"./PluggableMap.js\").FrameState}\n * @api\n */\n _this.frameState = opt_frameState !== undefined ? opt_frameState : null;\n return _this;\n }\n return MapEvent;\n}(Event));\nexport default MapEvent;\n//# sourceMappingURL=MapEvent.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/MapBrowserEvent\n */\nimport MapEvent from './MapEvent.js';\n/**\n * @classdesc\n * Events emitted as map browser events are instances of this type.\n * See {@link module:ol/PluggableMap~PluggableMap} for which events trigger a map browser event.\n * @template {UIEvent} EVENT\n */\nvar MapBrowserEvent = /** @class */ (function (_super) {\n __extends(MapBrowserEvent, _super);\n /**\n * @param {string} type Event type.\n * @param {import(\"./PluggableMap.js\").default} map Map.\n * @param {EVENT} originalEvent Original event.\n * @param {boolean} [opt_dragging] Is the map currently being dragged?\n * @param {?import(\"./PluggableMap.js\").FrameState} [opt_frameState] Frame state.\n */\n function MapBrowserEvent(type, map, originalEvent, opt_dragging, opt_frameState) {\n var _this = _super.call(this, type, map, opt_frameState) || this;\n /**\n * The original browser event.\n * @const\n * @type {EVENT}\n * @api\n */\n _this.originalEvent = originalEvent;\n /**\n * The map pixel relative to the viewport corresponding to the original browser event.\n * @type {?import(\"./pixel.js\").Pixel}\n */\n _this.pixel_ = null;\n /**\n * The coordinate in the user projection corresponding to the original browser event.\n * @type {?import(\"./coordinate.js\").Coordinate}\n */\n _this.coordinate_ = null;\n /**\n * Indicates if the map is currently being dragged. Only set for\n * `POINTERDRAG` and `POINTERMOVE` events. Default is `false`.\n *\n * @type {boolean}\n * @api\n */\n _this.dragging = opt_dragging !== undefined ? opt_dragging : false;\n return _this;\n }\n Object.defineProperty(MapBrowserEvent.prototype, \"pixel\", {\n /**\n * The map pixel relative to the viewport corresponding to the original event.\n * @type {import(\"./pixel.js\").Pixel}\n * @api\n */\n get: function () {\n if (!this.pixel_) {\n this.pixel_ = this.map.getEventPixel(this.originalEvent);\n }\n return this.pixel_;\n },\n set: function (pixel) {\n this.pixel_ = pixel;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(MapBrowserEvent.prototype, \"coordinate\", {\n /**\n * The coordinate corresponding to the original browser event. This will be in the user\n * projection if one is set. Otherwise it will be in the view projection.\n * @type {import(\"./coordinate.js\").Coordinate}\n * @api\n */\n get: function () {\n if (!this.coordinate_) {\n this.coordinate_ = this.map.getCoordinateFromPixel(this.pixel);\n }\n return this.coordinate_;\n },\n set: function (coordinate) {\n this.coordinate_ = coordinate;\n },\n enumerable: false,\n configurable: true\n });\n /**\n * Prevents the default browser action.\n * See https://developer.mozilla.org/en-US/docs/Web/API/event.preventDefault.\n * @api\n */\n MapBrowserEvent.prototype.preventDefault = function () {\n _super.prototype.preventDefault.call(this);\n if ('preventDefault' in this.originalEvent) {\n /** @type {UIEvent} */ (this.originalEvent).preventDefault();\n }\n };\n /**\n * Prevents further propagation of the current event.\n * See https://developer.mozilla.org/en-US/docs/Web/API/event.stopPropagation.\n * @api\n */\n MapBrowserEvent.prototype.stopPropagation = function () {\n _super.prototype.stopPropagation.call(this);\n if ('stopPropagation' in this.originalEvent) {\n /** @type {UIEvent} */ (this.originalEvent).stopPropagation();\n }\n };\n return MapBrowserEvent;\n}(MapEvent));\nexport default MapBrowserEvent;\n//# sourceMappingURL=MapBrowserEvent.js.map","/**\n * @module ol/MapBrowserEventType\n */\nimport EventType from './events/EventType.js';\n/**\n * Constants for event names.\n * @enum {string}\n */\nexport default {\n /**\n * A true single click with no dragging and no double click. Note that this\n * event is delayed by 250 ms to ensure that it is not a double click.\n * @event module:ol/MapBrowserEvent~MapBrowserEvent#singleclick\n * @api\n */\n SINGLECLICK: 'singleclick',\n /**\n * A click with no dragging. A double click will fire two of this.\n * @event module:ol/MapBrowserEvent~MapBrowserEvent#click\n * @api\n */\n CLICK: EventType.CLICK,\n /**\n * A true double click, with no dragging.\n * @event module:ol/MapBrowserEvent~MapBrowserEvent#dblclick\n * @api\n */\n DBLCLICK: EventType.DBLCLICK,\n /**\n * Triggered when a pointer is dragged.\n * @event module:ol/MapBrowserEvent~MapBrowserEvent#pointerdrag\n * @api\n */\n POINTERDRAG: 'pointerdrag',\n /**\n * Triggered when a pointer is moved. Note that on touch devices this is\n * triggered when the map is panned, so is not the same as mousemove.\n * @event module:ol/MapBrowserEvent~MapBrowserEvent#pointermove\n * @api\n */\n POINTERMOVE: 'pointermove',\n POINTERDOWN: 'pointerdown',\n POINTERUP: 'pointerup',\n POINTEROVER: 'pointerover',\n POINTEROUT: 'pointerout',\n POINTERENTER: 'pointerenter',\n POINTERLEAVE: 'pointerleave',\n POINTERCANCEL: 'pointercancel',\n};\n/***\n * @typedef {'singleclick'|'click'|'dblclick'|'pointerdrag'|'pointermove'} Types\n */\n//# sourceMappingURL=MapBrowserEventType.js.map","/**\n * @module ol/MapBrowserEventHandler\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport EventType from './events/EventType.js';\nimport MapBrowserEvent from './MapBrowserEvent.js';\nimport MapBrowserEventType from './MapBrowserEventType.js';\nimport PointerEventType from './pointer/EventType.js';\nimport Target from './events/Target.js';\nimport { PASSIVE_EVENT_LISTENERS } from './has.js';\nimport { VOID } from './functions.js';\nimport { listen, unlistenByKey } from './events.js';\nvar MapBrowserEventHandler = /** @class */ (function (_super) {\n __extends(MapBrowserEventHandler, _super);\n /**\n * @param {import(\"./PluggableMap.js\").default} map The map with the viewport to listen to events on.\n * @param {number} [moveTolerance] The minimal distance the pointer must travel to trigger a move.\n */\n function MapBrowserEventHandler(map, moveTolerance) {\n var _this = _super.call(this, map) || this;\n /**\n * This is the element that we will listen to the real events on.\n * @type {import(\"./PluggableMap.js\").default}\n * @private\n */\n _this.map_ = map;\n /**\n * @type {any}\n * @private\n */\n _this.clickTimeoutId_;\n /**\n * Emulate dblclick and singleclick. Will be true when only one pointer is active.\n * @type {boolean}\n */\n _this.emulateClicks_ = false;\n /**\n * @type {boolean}\n * @private\n */\n _this.dragging_ = false;\n /**\n * @type {!Array<import(\"./events.js\").EventsKey>}\n * @private\n */\n _this.dragListenerKeys_ = [];\n /**\n * @type {number}\n * @private\n */\n _this.moveTolerance_ = moveTolerance === undefined ? 1 : moveTolerance;\n /**\n * The most recent \"down\" type event (or null if none have occurred).\n * Set on pointerdown.\n * @type {PointerEvent}\n * @private\n */\n _this.down_ = null;\n var element = _this.map_.getViewport();\n /**\n * @type {number}\n * @private\n */\n _this.activePointers_ = 0;\n /**\n * @type {!Object<number, boolean>}\n * @private\n */\n _this.trackedTouches_ = {};\n _this.element_ = element;\n /**\n * @type {?import(\"./events.js\").EventsKey}\n * @private\n */\n _this.pointerdownListenerKey_ = listen(element, PointerEventType.POINTERDOWN, _this.handlePointerDown_, _this);\n /**\n * @type {PointerEvent}\n * @private\n */\n _this.originalPointerMoveEvent_;\n /**\n * @type {?import(\"./events.js\").EventsKey}\n * @private\n */\n _this.relayedListenerKey_ = listen(element, PointerEventType.POINTERMOVE, _this.relayEvent_, _this);\n /**\n * @private\n */\n _this.boundHandleTouchMove_ = _this.handleTouchMove_.bind(_this);\n _this.element_.addEventListener(EventType.TOUCHMOVE, _this.boundHandleTouchMove_, PASSIVE_EVENT_LISTENERS ? { passive: false } : false);\n return _this;\n }\n /**\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @private\n */\n MapBrowserEventHandler.prototype.emulateClick_ = function (pointerEvent) {\n var newEvent = new MapBrowserEvent(MapBrowserEventType.CLICK, this.map_, pointerEvent);\n this.dispatchEvent(newEvent);\n if (this.clickTimeoutId_ !== undefined) {\n // double-click\n clearTimeout(this.clickTimeoutId_);\n this.clickTimeoutId_ = undefined;\n newEvent = new MapBrowserEvent(MapBrowserEventType.DBLCLICK, this.map_, pointerEvent);\n this.dispatchEvent(newEvent);\n }\n else {\n // click\n this.clickTimeoutId_ = setTimeout(\n /** @this {MapBrowserEventHandler} */\n function () {\n this.clickTimeoutId_ = undefined;\n var newEvent = new MapBrowserEvent(MapBrowserEventType.SINGLECLICK, this.map_, pointerEvent);\n this.dispatchEvent(newEvent);\n }.bind(this), 250);\n }\n };\n /**\n * Keeps track on how many pointers are currently active.\n *\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @private\n */\n MapBrowserEventHandler.prototype.updateActivePointers_ = function (pointerEvent) {\n var event = pointerEvent;\n if (event.type == MapBrowserEventType.POINTERUP ||\n event.type == MapBrowserEventType.POINTERCANCEL) {\n delete this.trackedTouches_[event.pointerId];\n }\n else if (event.type == MapBrowserEventType.POINTERDOWN) {\n this.trackedTouches_[event.pointerId] = true;\n }\n this.activePointers_ = Object.keys(this.trackedTouches_).length;\n };\n /**\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @private\n */\n MapBrowserEventHandler.prototype.handlePointerUp_ = function (pointerEvent) {\n this.updateActivePointers_(pointerEvent);\n var newEvent = new MapBrowserEvent(MapBrowserEventType.POINTERUP, this.map_, pointerEvent);\n this.dispatchEvent(newEvent);\n // We emulate click events on left mouse button click, touch contact, and pen\n // contact. isMouseActionButton returns true in these cases (evt.button is set\n // to 0).\n // See http://www.w3.org/TR/pointerevents/#button-states\n // We only fire click, singleclick, and doubleclick if nobody has called\n // event.preventDefault().\n if (this.emulateClicks_ &&\n !newEvent.defaultPrevented &&\n !this.dragging_ &&\n this.isMouseActionButton_(pointerEvent)) {\n this.emulateClick_(this.down_);\n }\n if (this.activePointers_ === 0) {\n this.dragListenerKeys_.forEach(unlistenByKey);\n this.dragListenerKeys_.length = 0;\n this.dragging_ = false;\n this.down_ = null;\n }\n };\n /**\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @return {boolean} If the left mouse button was pressed.\n * @private\n */\n MapBrowserEventHandler.prototype.isMouseActionButton_ = function (pointerEvent) {\n return pointerEvent.button === 0;\n };\n /**\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @private\n */\n MapBrowserEventHandler.prototype.handlePointerDown_ = function (pointerEvent) {\n this.emulateClicks_ = this.activePointers_ === 0;\n this.updateActivePointers_(pointerEvent);\n var newEvent = new MapBrowserEvent(MapBrowserEventType.POINTERDOWN, this.map_, pointerEvent);\n this.dispatchEvent(newEvent);\n // Store a copy of the down event\n this.down_ = /** @type {PointerEvent} */ ({});\n for (var property in pointerEvent) {\n var value = pointerEvent[property];\n this.down_[property] = typeof value === 'function' ? VOID : value;\n }\n if (this.dragListenerKeys_.length === 0) {\n var doc = this.map_.getOwnerDocument();\n this.dragListenerKeys_.push(listen(doc, MapBrowserEventType.POINTERMOVE, this.handlePointerMove_, this), listen(doc, MapBrowserEventType.POINTERUP, this.handlePointerUp_, this), \n /* Note that the listener for `pointercancel is set up on\n * `pointerEventHandler_` and not `documentPointerEventHandler_` like\n * the `pointerup` and `pointermove` listeners.\n *\n * The reason for this is the following: `TouchSource.vacuumTouches_()`\n * issues `pointercancel` events, when there was no `touchend` for a\n * `touchstart`. Now, let's say a first `touchstart` is registered on\n * `pointerEventHandler_`. The `documentPointerEventHandler_` is set up.\n * But `documentPointerEventHandler_` doesn't know about the first\n * `touchstart`. If there is no `touchend` for the `touchstart`, we can\n * only receive a `touchcancel` from `pointerEventHandler_`, because it is\n * only registered there.\n */\n listen(this.element_, MapBrowserEventType.POINTERCANCEL, this.handlePointerUp_, this));\n if (this.element_.getRootNode && this.element_.getRootNode() !== doc) {\n this.dragListenerKeys_.push(listen(this.element_.getRootNode(), MapBrowserEventType.POINTERUP, this.handlePointerUp_, this));\n }\n }\n };\n /**\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @private\n */\n MapBrowserEventHandler.prototype.handlePointerMove_ = function (pointerEvent) {\n // Between pointerdown and pointerup, pointermove events are triggered.\n // To avoid a 'false' touchmove event to be dispatched, we test if the pointer\n // moved a significant distance.\n if (this.isMoving_(pointerEvent)) {\n this.dragging_ = true;\n var newEvent = new MapBrowserEvent(MapBrowserEventType.POINTERDRAG, this.map_, pointerEvent, this.dragging_);\n this.dispatchEvent(newEvent);\n }\n };\n /**\n * Wrap and relay a pointer event. Note that this requires that the type\n * string for the MapBrowserEvent matches the PointerEvent type.\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @private\n */\n MapBrowserEventHandler.prototype.relayEvent_ = function (pointerEvent) {\n this.originalPointerMoveEvent_ = pointerEvent;\n var dragging = !!(this.down_ && this.isMoving_(pointerEvent));\n this.dispatchEvent(new MapBrowserEvent(pointerEvent.type, this.map_, pointerEvent, dragging));\n };\n /**\n * Flexible handling of a `touch-action: none` css equivalent: because calling\n * `preventDefault()` on a `pointermove` event does not stop native page scrolling\n * and zooming, we also listen for `touchmove` and call `preventDefault()` on it\n * when an interaction (currently `DragPan` handles the event.\n * @param {TouchEvent} event Event.\n * @private\n */\n MapBrowserEventHandler.prototype.handleTouchMove_ = function (event) {\n // Due to https://github.com/mpizenberg/elm-pep/issues/2, `this.originalPointerMoveEvent_`\n // may not be initialized yet when we get here on a platform without native pointer events.\n var originalEvent = this.originalPointerMoveEvent_;\n if ((!originalEvent || originalEvent.defaultPrevented) &&\n (typeof event.cancelable !== 'boolean' || event.cancelable === true)) {\n event.preventDefault();\n }\n };\n /**\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @return {boolean} Is moving.\n * @private\n */\n MapBrowserEventHandler.prototype.isMoving_ = function (pointerEvent) {\n return (this.dragging_ ||\n Math.abs(pointerEvent.clientX - this.down_.clientX) >\n this.moveTolerance_ ||\n Math.abs(pointerEvent.clientY - this.down_.clientY) > this.moveTolerance_);\n };\n /**\n * Clean up.\n */\n MapBrowserEventHandler.prototype.disposeInternal = function () {\n if (this.relayedListenerKey_) {\n unlistenByKey(this.relayedListenerKey_);\n this.relayedListenerKey_ = null;\n }\n this.element_.removeEventListener(EventType.TOUCHMOVE, this.boundHandleTouchMove_);\n if (this.pointerdownListenerKey_) {\n unlistenByKey(this.pointerdownListenerKey_);\n this.pointerdownListenerKey_ = null;\n }\n this.dragListenerKeys_.forEach(unlistenByKey);\n this.dragListenerKeys_.length = 0;\n this.element_ = null;\n _super.prototype.disposeInternal.call(this);\n };\n return MapBrowserEventHandler;\n}(Target));\nexport default MapBrowserEventHandler;\n//# sourceMappingURL=MapBrowserEventHandler.js.map","/**\n * @module ol/MapProperty\n */\n/**\n * @enum {string}\n */\nexport default {\n LAYERGROUP: 'layergroup',\n SIZE: 'size',\n TARGET: 'target',\n VIEW: 'view',\n};\n//# sourceMappingURL=MapProperty.js.map","/**\n * @module ol/structs/PriorityQueue\n */\nimport { assert } from '../asserts.js';\nimport { clear } from '../obj.js';\n/**\n * @type {number}\n */\nexport var DROP = Infinity;\n/**\n * @classdesc\n * Priority queue.\n *\n * The implementation is inspired from the Closure Library's Heap class and\n * Python's heapq module.\n *\n * See https://github.com/google/closure-library/blob/master/closure/goog/structs/heap.js\n * and https://hg.python.org/cpython/file/2.7/Lib/heapq.py.\n *\n * @template T\n */\nvar PriorityQueue = /** @class */ (function () {\n /**\n * @param {function(T): number} priorityFunction Priority function.\n * @param {function(T): string} keyFunction Key function.\n */\n function PriorityQueue(priorityFunction, keyFunction) {\n /**\n * @type {function(T): number}\n * @private\n */\n this.priorityFunction_ = priorityFunction;\n /**\n * @type {function(T): string}\n * @private\n */\n this.keyFunction_ = keyFunction;\n /**\n * @type {Array<T>}\n * @private\n */\n this.elements_ = [];\n /**\n * @type {Array<number>}\n * @private\n */\n this.priorities_ = [];\n /**\n * @type {!Object<string, boolean>}\n * @private\n */\n this.queuedElements_ = {};\n }\n /**\n * FIXME empty description for jsdoc\n */\n PriorityQueue.prototype.clear = function () {\n this.elements_.length = 0;\n this.priorities_.length = 0;\n clear(this.queuedElements_);\n };\n /**\n * Remove and return the highest-priority element. O(log N).\n * @return {T} Element.\n */\n PriorityQueue.prototype.dequeue = function () {\n var elements = this.elements_;\n var priorities = this.priorities_;\n var element = elements[0];\n if (elements.length == 1) {\n elements.length = 0;\n priorities.length = 0;\n }\n else {\n elements[0] = elements.pop();\n priorities[0] = priorities.pop();\n this.siftUp_(0);\n }\n var elementKey = this.keyFunction_(element);\n delete this.queuedElements_[elementKey];\n return element;\n };\n /**\n * Enqueue an element. O(log N).\n * @param {T} element Element.\n * @return {boolean} The element was added to the queue.\n */\n PriorityQueue.prototype.enqueue = function (element) {\n assert(!(this.keyFunction_(element) in this.queuedElements_), 31); // Tried to enqueue an `element` that was already added to the queue\n var priority = this.priorityFunction_(element);\n if (priority != DROP) {\n this.elements_.push(element);\n this.priorities_.push(priority);\n this.queuedElements_[this.keyFunction_(element)] = true;\n this.siftDown_(0, this.elements_.length - 1);\n return true;\n }\n return false;\n };\n /**\n * @return {number} Count.\n */\n PriorityQueue.prototype.getCount = function () {\n return this.elements_.length;\n };\n /**\n * Gets the index of the left child of the node at the given index.\n * @param {number} index The index of the node to get the left child for.\n * @return {number} The index of the left child.\n * @private\n */\n PriorityQueue.prototype.getLeftChildIndex_ = function (index) {\n return index * 2 + 1;\n };\n /**\n * Gets the index of the right child of the node at the given index.\n * @param {number} index The index of the node to get the right child for.\n * @return {number} The index of the right child.\n * @private\n */\n PriorityQueue.prototype.getRightChildIndex_ = function (index) {\n return index * 2 + 2;\n };\n /**\n * Gets the index of the parent of the node at the given index.\n * @param {number} index The index of the node to get the parent for.\n * @return {number} The index of the parent.\n * @private\n */\n PriorityQueue.prototype.getParentIndex_ = function (index) {\n return (index - 1) >> 1;\n };\n /**\n * Make this a heap. O(N).\n * @private\n */\n PriorityQueue.prototype.heapify_ = function () {\n var i;\n for (i = (this.elements_.length >> 1) - 1; i >= 0; i--) {\n this.siftUp_(i);\n }\n };\n /**\n * @return {boolean} Is empty.\n */\n PriorityQueue.prototype.isEmpty = function () {\n return this.elements_.length === 0;\n };\n /**\n * @param {string} key Key.\n * @return {boolean} Is key queued.\n */\n PriorityQueue.prototype.isKeyQueued = function (key) {\n return key in this.queuedElements_;\n };\n /**\n * @param {T} element Element.\n * @return {boolean} Is queued.\n */\n PriorityQueue.prototype.isQueued = function (element) {\n return this.isKeyQueued(this.keyFunction_(element));\n };\n /**\n * @param {number} index The index of the node to move down.\n * @private\n */\n PriorityQueue.prototype.siftUp_ = function (index) {\n var elements = this.elements_;\n var priorities = this.priorities_;\n var count = elements.length;\n var element = elements[index];\n var priority = priorities[index];\n var startIndex = index;\n while (index < count >> 1) {\n var lIndex = this.getLeftChildIndex_(index);\n var rIndex = this.getRightChildIndex_(index);\n var smallerChildIndex = rIndex < count && priorities[rIndex] < priorities[lIndex]\n ? rIndex\n : lIndex;\n elements[index] = elements[smallerChildIndex];\n priorities[index] = priorities[smallerChildIndex];\n index = smallerChildIndex;\n }\n elements[index] = element;\n priorities[index] = priority;\n this.siftDown_(startIndex, index);\n };\n /**\n * @param {number} startIndex The index of the root.\n * @param {number} index The index of the node to move up.\n * @private\n */\n PriorityQueue.prototype.siftDown_ = function (startIndex, index) {\n var elements = this.elements_;\n var priorities = this.priorities_;\n var element = elements[index];\n var priority = priorities[index];\n while (index > startIndex) {\n var parentIndex = this.getParentIndex_(index);\n if (priorities[parentIndex] > priority) {\n elements[index] = elements[parentIndex];\n priorities[index] = priorities[parentIndex];\n index = parentIndex;\n }\n else {\n break;\n }\n }\n elements[index] = element;\n priorities[index] = priority;\n };\n /**\n * FIXME empty description for jsdoc\n */\n PriorityQueue.prototype.reprioritize = function () {\n var priorityFunction = this.priorityFunction_;\n var elements = this.elements_;\n var priorities = this.priorities_;\n var index = 0;\n var n = elements.length;\n var element, i, priority;\n for (i = 0; i < n; ++i) {\n element = elements[i];\n priority = priorityFunction(element);\n if (priority == DROP) {\n delete this.queuedElements_[this.keyFunction_(element)];\n }\n else {\n priorities[index] = priority;\n elements[index++] = element;\n }\n }\n elements.length = index;\n priorities.length = index;\n this.heapify_();\n };\n return PriorityQueue;\n}());\nexport default PriorityQueue;\n//# sourceMappingURL=PriorityQueue.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/TileQueue\n */\nimport EventType from './events/EventType.js';\nimport PriorityQueue, { DROP } from './structs/PriorityQueue.js';\nimport TileState from './TileState.js';\n/**\n * @typedef {function(import(\"./Tile.js\").default, string, import(\"./coordinate.js\").Coordinate, number): number} PriorityFunction\n */\nvar TileQueue = /** @class */ (function (_super) {\n __extends(TileQueue, _super);\n /**\n * @param {PriorityFunction} tilePriorityFunction Tile priority function.\n * @param {function(): ?} tileChangeCallback Function called on each tile change event.\n */\n function TileQueue(tilePriorityFunction, tileChangeCallback) {\n var _this = _super.call(this, \n /**\n * @param {Array} element Element.\n * @return {number} Priority.\n */\n function (element) {\n return tilePriorityFunction.apply(null, element);\n }, \n /**\n * @param {Array} element Element.\n * @return {string} Key.\n */\n function (element) {\n return /** @type {import(\"./Tile.js\").default} */ (element[0]).getKey();\n }) || this;\n /** @private */\n _this.boundHandleTileChange_ = _this.handleTileChange.bind(_this);\n /**\n * @private\n * @type {function(): ?}\n */\n _this.tileChangeCallback_ = tileChangeCallback;\n /**\n * @private\n * @type {number}\n */\n _this.tilesLoading_ = 0;\n /**\n * @private\n * @type {!Object<string,boolean>}\n */\n _this.tilesLoadingKeys_ = {};\n return _this;\n }\n /**\n * @param {Array} element Element.\n * @return {boolean} The element was added to the queue.\n */\n TileQueue.prototype.enqueue = function (element) {\n var added = _super.prototype.enqueue.call(this, element);\n if (added) {\n var tile = element[0];\n tile.addEventListener(EventType.CHANGE, this.boundHandleTileChange_);\n }\n return added;\n };\n /**\n * @return {number} Number of tiles loading.\n */\n TileQueue.prototype.getTilesLoading = function () {\n return this.tilesLoading_;\n };\n /**\n * @param {import(\"./events/Event.js\").default} event Event.\n * @protected\n */\n TileQueue.prototype.handleTileChange = function (event) {\n var tile = /** @type {import(\"./Tile.js\").default} */ (event.target);\n var state = tile.getState();\n if (state === TileState.LOADED ||\n state === TileState.ERROR ||\n state === TileState.EMPTY) {\n tile.removeEventListener(EventType.CHANGE, this.boundHandleTileChange_);\n var tileKey = tile.getKey();\n if (tileKey in this.tilesLoadingKeys_) {\n delete this.tilesLoadingKeys_[tileKey];\n --this.tilesLoading_;\n }\n this.tileChangeCallback_();\n }\n };\n /**\n * @param {number} maxTotalLoading Maximum number tiles to load simultaneously.\n * @param {number} maxNewLoads Maximum number of new tiles to load.\n */\n TileQueue.prototype.loadMoreTiles = function (maxTotalLoading, maxNewLoads) {\n var newLoads = 0;\n var state, tile, tileKey;\n while (this.tilesLoading_ < maxTotalLoading &&\n newLoads < maxNewLoads &&\n this.getCount() > 0) {\n tile = /** @type {import(\"./Tile.js\").default} */ (this.dequeue()[0]);\n tileKey = tile.getKey();\n state = tile.getState();\n if (state === TileState.IDLE && !(tileKey in this.tilesLoadingKeys_)) {\n this.tilesLoadingKeys_[tileKey] = true;\n ++this.tilesLoading_;\n ++newLoads;\n tile.load();\n }\n }\n };\n return TileQueue;\n}(PriorityQueue));\nexport default TileQueue;\n/**\n * @param {import('./PluggableMap.js').FrameState} frameState Frame state.\n * @param {import(\"./Tile.js\").default} tile Tile.\n * @param {string} tileSourceKey Tile source key.\n * @param {import(\"./coordinate.js\").Coordinate} tileCenter Tile center.\n * @param {number} tileResolution Tile resolution.\n * @return {number} Tile priority.\n */\nexport function getTilePriority(frameState, tile, tileSourceKey, tileCenter, tileResolution) {\n // Filter out tiles at higher zoom levels than the current zoom level, or that\n // are outside the visible extent.\n if (!frameState || !(tileSourceKey in frameState.wantedTiles)) {\n return DROP;\n }\n if (!frameState.wantedTiles[tileSourceKey][tile.getKey()]) {\n return DROP;\n }\n // Prioritize the highest zoom level tiles closest to the focus.\n // Tiles at higher zoom levels are prioritized using Math.log(tileResolution).\n // Within a zoom level, tiles are prioritized by the distance in pixels between\n // the center of the tile and the center of the viewport. The factor of 65536\n // means that the prioritization should behave as desired for tiles up to\n // 65536 * Math.log(2) = 45426 pixels from the focus.\n var center = frameState.viewState.center;\n var deltaX = tileCenter[0] - center[0];\n var deltaY = tileCenter[1] - center[1];\n return (65536 * Math.log(tileResolution) +\n Math.sqrt(deltaX * deltaX + deltaY * deltaY) / tileResolution);\n}\n//# sourceMappingURL=TileQueue.js.map","/**\n * @module ol/ViewProperty\n */\n/**\n * @enum {string}\n */\nexport default {\n CENTER: 'center',\n RESOLUTION: 'resolution',\n ROTATION: 'rotation',\n};\n//# sourceMappingURL=ViewProperty.js.map","/**\n * @module ol/centerconstraint\n */\nimport { clamp } from './math.js';\n/**\n * @typedef {function((import(\"./coordinate.js\").Coordinate|undefined), number, import(\"./size.js\").Size, boolean=, Array<number>=): (import(\"./coordinate.js\").Coordinate|undefined)} Type\n */\n/**\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {boolean} onlyCenter If true, the constraint will only apply to the view center.\n * @param {boolean} smooth If true, the view will be able to go slightly out of the given extent\n * (only during interaction and animation).\n * @return {Type} The constraint.\n */\nexport function createExtent(extent, onlyCenter, smooth) {\n return (\n /**\n * @param {import(\"./coordinate.js\").Coordinate|undefined} center Center.\n * @param {number} resolution Resolution.\n * @param {import(\"./size.js\").Size} size Viewport size; unused if `onlyCenter` was specified.\n * @param {boolean} [opt_isMoving] True if an interaction or animation is in progress.\n * @param {Array<number>} [opt_centerShift] Shift between map center and viewport center.\n * @return {import(\"./coordinate.js\").Coordinate|undefined} Center.\n */\n function (center, resolution, size, opt_isMoving, opt_centerShift) {\n if (center) {\n var viewWidth = onlyCenter ? 0 : size[0] * resolution;\n var viewHeight = onlyCenter ? 0 : size[1] * resolution;\n var shiftX = opt_centerShift ? opt_centerShift[0] : 0;\n var shiftY = opt_centerShift ? opt_centerShift[1] : 0;\n var minX = extent[0] + viewWidth / 2 + shiftX;\n var maxX = extent[2] - viewWidth / 2 + shiftX;\n var minY = extent[1] + viewHeight / 2 + shiftY;\n var maxY = extent[3] - viewHeight / 2 + shiftY;\n // note: when zooming out of bounds, min and max values for x and y may\n // end up inverted (min > max); this has to be accounted for\n if (minX > maxX) {\n minX = (maxX + minX) / 2;\n maxX = minX;\n }\n if (minY > maxY) {\n minY = (maxY + minY) / 2;\n maxY = minY;\n }\n var x = clamp(center[0], minX, maxX);\n var y = clamp(center[1], minY, maxY);\n var ratio = 30 * resolution;\n // during an interaction, allow some overscroll\n if (opt_isMoving && smooth) {\n x +=\n -ratio * Math.log(1 + Math.max(0, minX - center[0]) / ratio) +\n ratio * Math.log(1 + Math.max(0, center[0] - maxX) / ratio);\n y +=\n -ratio * Math.log(1 + Math.max(0, minY - center[1]) / ratio) +\n ratio * Math.log(1 + Math.max(0, center[1] - maxY) / ratio);\n }\n return [x, y];\n }\n else {\n return undefined;\n }\n });\n}\n/**\n * @param {import(\"./coordinate.js\").Coordinate} [center] Center.\n * @return {import(\"./coordinate.js\").Coordinate|undefined} Center.\n */\nexport function none(center) {\n return center;\n}\n//# sourceMappingURL=centerconstraint.js.map","/**\n * @module ol/resolutionconstraint\n */\nimport { clamp } from './math.js';\nimport { getHeight, getWidth } from './extent.js';\nimport { linearFindNearest } from './array.js';\n/**\n * @typedef {function((number|undefined), number, import(\"./size.js\").Size, boolean=): (number|undefined)} Type\n */\n/**\n * Returns a modified resolution taking into account the viewport size and maximum\n * allowed extent.\n * @param {number} resolution Resolution\n * @param {import(\"./extent.js\").Extent} maxExtent Maximum allowed extent.\n * @param {import(\"./size.js\").Size} viewportSize Viewport size.\n * @param {boolean} showFullExtent Whether to show the full extent.\n * @return {number} Capped resolution.\n */\nfunction getViewportClampedResolution(resolution, maxExtent, viewportSize, showFullExtent) {\n var xResolution = getWidth(maxExtent) / viewportSize[0];\n var yResolution = getHeight(maxExtent) / viewportSize[1];\n if (showFullExtent) {\n return Math.min(resolution, Math.max(xResolution, yResolution));\n }\n return Math.min(resolution, Math.min(xResolution, yResolution));\n}\n/**\n * Returns a modified resolution to be between maxResolution and minResolution while\n * still allowing the value to be slightly out of bounds.\n * Note: the computation is based on the logarithm function (ln):\n * - at 1, ln(x) is 0\n * - above 1, ln(x) keeps increasing but at a much slower pace than x\n * The final result is clamped to prevent getting too far away from bounds.\n * @param {number} resolution Resolution.\n * @param {number} maxResolution Max resolution.\n * @param {number} minResolution Min resolution.\n * @return {number} Smoothed resolution.\n */\nfunction getSmoothClampedResolution(resolution, maxResolution, minResolution) {\n var result = Math.min(resolution, maxResolution);\n var ratio = 50;\n result *=\n Math.log(1 + ratio * Math.max(0, resolution / maxResolution - 1)) / ratio +\n 1;\n if (minResolution) {\n result = Math.max(result, minResolution);\n result /=\n Math.log(1 + ratio * Math.max(0, minResolution / resolution - 1)) /\n ratio +\n 1;\n }\n return clamp(result, minResolution / 2, maxResolution * 2);\n}\n/**\n * @param {Array<number>} resolutions Resolutions.\n * @param {boolean} [opt_smooth] If true, the view will be able to slightly exceed resolution limits. Default: true.\n * @param {import(\"./extent.js\").Extent} [opt_maxExtent] Maximum allowed extent.\n * @param {boolean} [opt_showFullExtent] If true, allows us to show the full extent. Default: false.\n * @return {Type} Zoom function.\n */\nexport function createSnapToResolutions(resolutions, opt_smooth, opt_maxExtent, opt_showFullExtent) {\n return (\n /**\n * @param {number|undefined} resolution Resolution.\n * @param {number} direction Direction.\n * @param {import(\"./size.js\").Size} size Viewport size.\n * @param {boolean} [opt_isMoving] True if an interaction or animation is in progress.\n * @return {number|undefined} Resolution.\n */\n function (resolution, direction, size, opt_isMoving) {\n if (resolution !== undefined) {\n var maxResolution = resolutions[0];\n var minResolution = resolutions[resolutions.length - 1];\n var cappedMaxRes = opt_maxExtent\n ? getViewportClampedResolution(maxResolution, opt_maxExtent, size, opt_showFullExtent)\n : maxResolution;\n // during interacting or animating, allow intermediary values\n if (opt_isMoving) {\n var smooth = opt_smooth !== undefined ? opt_smooth : true;\n if (!smooth) {\n return clamp(resolution, minResolution, cappedMaxRes);\n }\n return getSmoothClampedResolution(resolution, cappedMaxRes, minResolution);\n }\n var capped = Math.min(cappedMaxRes, resolution);\n var z = Math.floor(linearFindNearest(resolutions, capped, direction));\n if (resolutions[z] > cappedMaxRes && z < resolutions.length - 1) {\n return resolutions[z + 1];\n }\n return resolutions[z];\n }\n else {\n return undefined;\n }\n });\n}\n/**\n * @param {number} power Power.\n * @param {number} maxResolution Maximum resolution.\n * @param {number} [opt_minResolution] Minimum resolution.\n * @param {boolean} [opt_smooth] If true, the view will be able to slightly exceed resolution limits. Default: true.\n * @param {import(\"./extent.js\").Extent} [opt_maxExtent] Maximum allowed extent.\n * @param {boolean} [opt_showFullExtent] If true, allows us to show the full extent. Default: false.\n * @return {Type} Zoom function.\n */\nexport function createSnapToPower(power, maxResolution, opt_minResolution, opt_smooth, opt_maxExtent, opt_showFullExtent) {\n return (\n /**\n * @param {number|undefined} resolution Resolution.\n * @param {number} direction Direction.\n * @param {import(\"./size.js\").Size} size Viewport size.\n * @param {boolean} [opt_isMoving] True if an interaction or animation is in progress.\n * @return {number|undefined} Resolution.\n */\n function (resolution, direction, size, opt_isMoving) {\n if (resolution !== undefined) {\n var cappedMaxRes = opt_maxExtent\n ? getViewportClampedResolution(maxResolution, opt_maxExtent, size, opt_showFullExtent)\n : maxResolution;\n var minResolution = opt_minResolution !== undefined ? opt_minResolution : 0;\n // during interacting or animating, allow intermediary values\n if (opt_isMoving) {\n var smooth = opt_smooth !== undefined ? opt_smooth : true;\n if (!smooth) {\n return clamp(resolution, minResolution, cappedMaxRes);\n }\n return getSmoothClampedResolution(resolution, cappedMaxRes, minResolution);\n }\n var tolerance = 1e-9;\n var minZoomLevel = Math.ceil(Math.log(maxResolution / cappedMaxRes) / Math.log(power) - tolerance);\n var offset = -direction * (0.5 - tolerance) + 0.5;\n var capped = Math.min(cappedMaxRes, resolution);\n var cappedZoomLevel = Math.floor(Math.log(maxResolution / capped) / Math.log(power) + offset);\n var zoomLevel = Math.max(minZoomLevel, cappedZoomLevel);\n var newResolution = maxResolution / Math.pow(power, zoomLevel);\n return clamp(newResolution, minResolution, cappedMaxRes);\n }\n else {\n return undefined;\n }\n });\n}\n/**\n * @param {number} maxResolution Max resolution.\n * @param {number} minResolution Min resolution.\n * @param {boolean} [opt_smooth] If true, the view will be able to slightly exceed resolution limits. Default: true.\n * @param {import(\"./extent.js\").Extent} [opt_maxExtent] Maximum allowed extent.\n * @param {boolean} [opt_showFullExtent] If true, allows us to show the full extent. Default: false.\n * @return {Type} Zoom function.\n */\nexport function createMinMaxResolution(maxResolution, minResolution, opt_smooth, opt_maxExtent, opt_showFullExtent) {\n return (\n /**\n * @param {number|undefined} resolution Resolution.\n * @param {number} direction Direction.\n * @param {import(\"./size.js\").Size} size Viewport size.\n * @param {boolean} [opt_isMoving] True if an interaction or animation is in progress.\n * @return {number|undefined} Resolution.\n */\n function (resolution, direction, size, opt_isMoving) {\n if (resolution !== undefined) {\n var cappedMaxRes = opt_maxExtent\n ? getViewportClampedResolution(maxResolution, opt_maxExtent, size, opt_showFullExtent)\n : maxResolution;\n var smooth = opt_smooth !== undefined ? opt_smooth : true;\n if (!smooth || !opt_isMoving) {\n return clamp(resolution, minResolution, cappedMaxRes);\n }\n return getSmoothClampedResolution(resolution, cappedMaxRes, minResolution);\n }\n else {\n return undefined;\n }\n });\n}\n//# sourceMappingURL=resolutionconstraint.js.map","/**\n * @module ol/rotationconstraint\n */\nimport { toRadians } from './math.js';\n/**\n * @typedef {function((number|undefined), boolean=): (number|undefined)} Type\n */\n/**\n * @param {number|undefined} rotation Rotation.\n * @return {number|undefined} Rotation.\n */\nexport function disable(rotation) {\n if (rotation !== undefined) {\n return 0;\n }\n else {\n return undefined;\n }\n}\n/**\n * @param {number|undefined} rotation Rotation.\n * @return {number|undefined} Rotation.\n */\nexport function none(rotation) {\n if (rotation !== undefined) {\n return rotation;\n }\n else {\n return undefined;\n }\n}\n/**\n * @param {number} n N.\n * @return {Type} Rotation constraint.\n */\nexport function createSnapToN(n) {\n var theta = (2 * Math.PI) / n;\n return (\n /**\n * @param {number|undefined} rotation Rotation.\n * @param {boolean} [opt_isMoving] True if an interaction or animation is in progress.\n * @return {number|undefined} Rotation.\n */\n function (rotation, opt_isMoving) {\n if (opt_isMoving) {\n return rotation;\n }\n if (rotation !== undefined) {\n rotation = Math.floor(rotation / theta + 0.5) * theta;\n return rotation;\n }\n else {\n return undefined;\n }\n });\n}\n/**\n * @param {number} [opt_tolerance] Tolerance.\n * @return {Type} Rotation constraint.\n */\nexport function createSnapToZero(opt_tolerance) {\n var tolerance = opt_tolerance || toRadians(5);\n return (\n /**\n * @param {number|undefined} rotation Rotation.\n * @param {boolean} [opt_isMoving] True if an interaction or animation is in progress.\n * @return {number|undefined} Rotation.\n */\n function (rotation, opt_isMoving) {\n if (opt_isMoving) {\n return rotation;\n }\n if (rotation !== undefined) {\n if (Math.abs(rotation) <= tolerance) {\n return 0;\n }\n else {\n return rotation;\n }\n }\n else {\n return undefined;\n }\n });\n}\n//# sourceMappingURL=rotationconstraint.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/View\n */\nimport BaseObject from './Object.js';\nimport GeometryType from './geom/GeometryType.js';\nimport Units from './proj/Units.js';\nimport ViewHint from './ViewHint.js';\nimport ViewProperty from './ViewProperty.js';\nimport { DEFAULT_TILE_SIZE } from './tilegrid/common.js';\nimport { METERS_PER_UNIT, createProjection, fromUserCoordinate, fromUserExtent, getUserProjection, toUserCoordinate, toUserExtent, } from './proj.js';\nimport { VOID } from './functions.js';\nimport { add as addCoordinate, equals as coordinatesEqual, rotate as rotateCoordinate, } from './coordinate.js';\nimport { assert } from './asserts.js';\nimport { assign } from './obj.js';\nimport { none as centerNone, createExtent } from './centerconstraint.js';\nimport { clamp, modulo } from './math.js';\nimport { createMinMaxResolution } from './resolutionconstraint.js';\nimport { createSnapToN, createSnapToZero, disable, none as rotationNone, } from './rotationconstraint.js';\nimport { createSnapToPower, createSnapToResolutions, } from './resolutionconstraint.js';\nimport { easeOut } from './easing.js';\nimport { equals } from './coordinate.js';\nimport { getCenter, getForViewAndSize, getHeight, getWidth, isEmpty, } from './extent.js';\nimport { inAndOut } from './easing.js';\nimport { linearFindNearest } from './array.js';\nimport { fromExtent as polygonFromExtent } from './geom/Polygon.js';\n/**\n * An animation configuration\n *\n * @typedef {Object} Animation\n * @property {import(\"./coordinate.js\").Coordinate} [sourceCenter] Source center.\n * @property {import(\"./coordinate.js\").Coordinate} [targetCenter] Target center.\n * @property {number} [sourceResolution] Source resolution.\n * @property {number} [targetResolution] Target resolution.\n * @property {number} [sourceRotation] Source rotation.\n * @property {number} [targetRotation] Target rotation.\n * @property {import(\"./coordinate.js\").Coordinate} [anchor] Anchor.\n * @property {number} start Start.\n * @property {number} duration Duration.\n * @property {boolean} complete Complete.\n * @property {function(number):number} easing Easing.\n * @property {function(boolean):void} callback Callback.\n */\n/**\n * @typedef {Object} Constraints\n * @property {import(\"./centerconstraint.js\").Type} center Center.\n * @property {import(\"./resolutionconstraint.js\").Type} resolution Resolution.\n * @property {import(\"./rotationconstraint.js\").Type} rotation Rotation.\n */\n/**\n * @typedef {Object} FitOptions\n * @property {import(\"./size.js\").Size} [size] The size in pixels of the box to fit\n * the extent into. Default is the current size of the first map in the DOM that\n * uses this view, or `[100, 100]` if no such map is found.\n * @property {!Array<number>} [padding=[0, 0, 0, 0]] Padding (in pixels) to be\n * cleared inside the view. Values in the array are top, right, bottom and left\n * padding.\n * @property {boolean} [nearest=false] If the view `constrainResolution` option is `true`,\n * get the nearest extent instead of the closest that actually fits the view.\n * @property {number} [minResolution=0] Minimum resolution that we zoom to.\n * @property {number} [maxZoom] Maximum zoom level that we zoom to. If\n * `minResolution` is given, this property is ignored.\n * @property {number} [duration] The duration of the animation in milliseconds.\n * By default, there is no animation to the target extent.\n * @property {function(number):number} [easing] The easing function used during\n * the animation (defaults to {@link module:ol/easing.inAndOut}).\n * The function will be called for each frame with a number representing a\n * fraction of the animation's duration. The function should return a number\n * between 0 and 1 representing the progress toward the destination state.\n * @property {function(boolean):void} [callback] Function called when the view is in\n * its final position. The callback will be called with `true` if the animation\n * series completed on its own or `false` if it was cancelled.\n */\n/**\n * @typedef {Object} ViewOptions\n * @property {import(\"./coordinate.js\").Coordinate} [center] The initial center for\n * the view. If a user projection is not set, the coordinate system for the center is\n * specified with the `projection` option. Layer sources will not be fetched if this\n * is not set, but the center can be set later with {@link #setCenter}.\n * @property {boolean|number} [constrainRotation=true] Rotation constraint.\n * `false` means no constraint. `true` means no constraint, but snap to zero\n * near zero. A number constrains the rotation to that number of values. For\n * example, `4` will constrain the rotation to 0, 90, 180, and 270 degrees.\n * @property {boolean} [enableRotation=true] Enable rotation.\n * If `false`, a rotation constraint that always sets the rotation to zero is\n * used. The `constrainRotation` option has no effect if `enableRotation` is\n * `false`.\n * @property {import(\"./extent.js\").Extent} [extent] The extent that constrains the\n * view, in other words, nothing outside of this extent can be visible on the map.\n * @property {boolean} [constrainOnlyCenter=false] If true, the extent\n * constraint will only apply to the view center and not the whole extent.\n * @property {boolean} [smoothExtentConstraint=true] If true, the extent\n * constraint will be applied smoothly, i.e. allow the view to go slightly outside\n * of the given `extent`.\n * @property {number} [maxResolution] The maximum resolution used to determine\n * the resolution constraint. It is used together with `minResolution` (or\n * `maxZoom`) and `zoomFactor`. If unspecified it is calculated in such a way\n * that the projection's validity extent fits in a 256x256 px tile. If the\n * projection is Spherical Mercator (the default) then `maxResolution` defaults\n * to `40075016.68557849 / 256 = 156543.03392804097`.\n * @property {number} [minResolution] The minimum resolution used to determine\n * the resolution constraint. It is used together with `maxResolution` (or\n * `minZoom`) and `zoomFactor`. If unspecified it is calculated assuming 29\n * zoom levels (with a factor of 2). If the projection is Spherical Mercator\n * (the default) then `minResolution` defaults to\n * `40075016.68557849 / 256 / Math.pow(2, 28) = 0.0005831682455839253`.\n * @property {number} [maxZoom=28] The maximum zoom level used to determine the\n * resolution constraint. It is used together with `minZoom` (or\n * `maxResolution`) and `zoomFactor`. Note that if `minResolution` is also\n * provided, it is given precedence over `maxZoom`.\n * @property {number} [minZoom=0] The minimum zoom level used to determine the\n * resolution constraint. It is used together with `maxZoom` (or\n * `minResolution`) and `zoomFactor`. Note that if `maxResolution` is also\n * provided, it is given precedence over `minZoom`.\n * @property {boolean} [multiWorld=false] If `false` the view is constrained so\n * only one world is visible, and you cannot pan off the edge. If `true` the map\n * may show multiple worlds at low zoom levels. Only used if the `projection` is\n * global. Note that if `extent` is also provided it is given precedence.\n * @property {boolean} [constrainResolution=false] If true, the view will always\n * animate to the closest zoom level after an interaction; false means\n * intermediary zoom levels are allowed.\n * @property {boolean} [smoothResolutionConstraint=true] If true, the resolution\n * min/max values will be applied smoothly, i. e. allow the view to exceed slightly\n * the given resolution or zoom bounds.\n * @property {boolean} [showFullExtent=false] Allow the view to be zoomed out to\n * show the full configured extent. By default, when a view is configured with an\n * extent, users will not be able to zoom out so the viewport exceeds the extent in\n * either dimension. This means the full extent may not be visible if the viewport\n * is taller or wider than the aspect ratio of the configured extent. If\n * showFullExtent is true, the user will be able to zoom out so that the viewport\n * exceeds the height or width of the configured extent, but not both, allowing the\n * full extent to be shown.\n * @property {import(\"./proj.js\").ProjectionLike} [projection='EPSG:3857'] The\n * projection. The default is Spherical Mercator.\n * @property {number} [resolution] The initial resolution for the view. The\n * units are `projection` units per pixel (e.g. meters per pixel). An\n * alternative to setting this is to set `zoom`. Layer sources will not be\n * fetched if neither this nor `zoom` are defined, but they can be set later\n * with {@link #setZoom} or {@link #setResolution}.\n * @property {Array<number>} [resolutions] Resolutions that determine the\n * zoom levels if specified. The index in the array corresponds to the zoom level,\n * therefore the resolution values have to be in descending order. It also constrains\n * the resolution by the minimum and maximum value. If set the `maxResolution`,\n * `minResolution`, `minZoom`, `maxZoom`, and `zoomFactor` options are ignored.\n * @property {number} [rotation=0] The initial rotation for the view in radians\n * (positive rotation clockwise, 0 means North).\n * @property {number} [zoom] Only used if `resolution` is not defined. Zoom\n * level used to calculate the initial resolution for the view.\n * @property {number} [zoomFactor=2] The zoom factor used to compute the\n * corresponding resolution.\n * @property {!Array<number>} [padding=[0, 0, 0, 0]] Padding (in css pixels).\n * If the map viewport is partially covered with other content (overlays) along\n * its edges, this setting allows to shift the center of the viewport away from\n * that content. The order of the values is top, right, bottom, left.\n */\n/**\n * @typedef {Object} AnimationOptions\n * @property {import(\"./coordinate.js\").Coordinate} [center] The center of the view at the end of\n * the animation.\n * @property {number} [zoom] The zoom level of the view at the end of the\n * animation. This takes precedence over `resolution`.\n * @property {number} [resolution] The resolution of the view at the end\n * of the animation. If `zoom` is also provided, this option will be ignored.\n * @property {number} [rotation] The rotation of the view at the end of\n * the animation.\n * @property {import(\"./coordinate.js\").Coordinate} [anchor] Optional anchor to remain fixed\n * during a rotation or resolution animation.\n * @property {number} [duration=1000] The duration of the animation in milliseconds.\n * @property {function(number):number} [easing] The easing function used\n * during the animation (defaults to {@link module:ol/easing.inAndOut}).\n * The function will be called for each frame with a number representing a\n * fraction of the animation's duration. The function should return a number\n * between 0 and 1 representing the progress toward the destination state.\n */\n/**\n * @typedef {Object} State\n * @property {import(\"./coordinate.js\").Coordinate} center Center.\n * @property {import(\"./proj/Projection.js\").default} projection Projection.\n * @property {number} resolution Resolution.\n * @property {import(\"./coordinate.js\").Coordinate} [nextCenter] The next center during an animation series.\n * @property {number} [nextResolution] The next resolution during an animation series.\n * @property {number} [nextRotation] The next rotation during an animation series.\n * @property {number} rotation Rotation.\n * @property {number} zoom Zoom.\n */\n/**\n * Default min zoom level for the map view.\n * @type {number}\n */\nvar DEFAULT_MIN_ZOOM = 0;\n/**\n * @typedef {import(\"./ObjectEventType\").Types|'change:center'|'change:resolution'|'change:rotation'} ViewObjectEventTypes\n */\n/***\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature<import(\"./Observable\").EventTypes, import(\"./events/Event.js\").default, Return> &\n * import(\"./Observable\").OnSignature<ViewObjectEventTypes, import(\"./Object\").ObjectEvent, Return> &\n * import(\"./Observable\").CombinedOnSignature<import(\"./Observable\").EventTypes|ViewObjectEventTypes, Return>} ViewOnSignature\n */\n/**\n * @classdesc\n * A View object represents a simple 2D view of the map.\n *\n * This is the object to act upon to change the center, resolution,\n * and rotation of the map.\n *\n * A View has a `projection`. The projection determines the\n * coordinate system of the center, and its units determine the units of the\n * resolution (projection units per pixel). The default projection is\n * Spherical Mercator (EPSG:3857).\n *\n * ### The view states\n *\n * A View is determined by three states: `center`, `resolution`,\n * and `rotation`. Each state has a corresponding getter and setter, e.g.\n * `getCenter` and `setCenter` for the `center` state.\n *\n * The `zoom` state is actually not saved on the view: all computations\n * internally use the `resolution` state. Still, the `setZoom` and `getZoom`\n * methods are available, as well as `getResolutionForZoom` and\n * `getZoomForResolution` to switch from one system to the other.\n *\n * ### The constraints\n *\n * `setCenter`, `setResolution` and `setRotation` can be used to change the\n * states of the view, but any constraint defined in the constructor will\n * be applied along the way.\n *\n * A View object can have a *resolution constraint*, a *rotation constraint*\n * and a *center constraint*.\n *\n * The *resolution constraint* typically restricts min/max values and\n * snaps to specific resolutions. It is determined by the following\n * options: `resolutions`, `maxResolution`, `maxZoom` and `zoomFactor`.\n * If `resolutions` is set, the other three options are ignored. See\n * documentation for each option for more information. By default, the view\n * only has a min/max restriction and allow intermediary zoom levels when\n * pinch-zooming for example.\n *\n * The *rotation constraint* snaps to specific angles. It is determined\n * by the following options: `enableRotation` and `constrainRotation`.\n * By default rotation is allowed and its value is snapped to zero when approaching the\n * horizontal.\n *\n * The *center constraint* is determined by the `extent` option. By\n * default the view center is not constrained at all.\n *\n * ### Changing the view state\n *\n * It is important to note that `setZoom`, `setResolution`, `setCenter` and\n * `setRotation` are subject to the above mentioned constraints. As such, it\n * may sometimes not be possible to know in advance the resulting state of the\n * View. For example, calling `setResolution(10)` does not guarantee that\n * `getResolution()` will return `10`.\n *\n * A consequence of this is that, when applying a delta on the view state, one\n * should use `adjustCenter`, `adjustRotation`, `adjustZoom` and `adjustResolution`\n * rather than the corresponding setters. This will let view do its internal\n * computations. Besides, the `adjust*` methods also take an `opt_anchor`\n * argument which allows specifying an origin for the transformation.\n *\n * ### Interacting with the view\n *\n * View constraints are usually only applied when the view is *at rest*, meaning that\n * no interaction or animation is ongoing. As such, if the user puts the view in a\n * state that is not equivalent to a constrained one (e.g. rotating the view when\n * the snap angle is 0), an animation will be triggered at the interaction end to\n * put back the view to a stable state;\n *\n * @api\n */\nvar View = /** @class */ (function (_super) {\n __extends(View, _super);\n /**\n * @param {ViewOptions} [opt_options] View options.\n */\n function View(opt_options) {\n var _this = _super.call(this) || this;\n /***\n * @type {ViewOnSignature<import(\"./events\").EventsKey>}\n */\n _this.on;\n /***\n * @type {ViewOnSignature<import(\"./events\").EventsKey>}\n */\n _this.once;\n /***\n * @type {ViewOnSignature<void>}\n */\n _this.un;\n var options = assign({}, opt_options);\n /**\n * @private\n * @type {Array<number>}\n */\n _this.hints_ = [0, 0];\n /**\n * @private\n * @type {Array<Array<Animation>>}\n */\n _this.animations_ = [];\n /**\n * @private\n * @type {number|undefined}\n */\n _this.updateAnimationKey_;\n /**\n * @private\n * @const\n * @type {import(\"./proj/Projection.js\").default}\n */\n _this.projection_ = createProjection(options.projection, 'EPSG:3857');\n /**\n * @private\n * @type {import(\"./size.js\").Size}\n */\n _this.viewportSize_ = [100, 100];\n /**\n * @private\n * @type {import(\"./coordinate.js\").Coordinate|undefined}\n */\n _this.targetCenter_ = null;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.targetResolution_;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.targetRotation_;\n /**\n * @private\n * @type {import(\"./coordinate.js\").Coordinate}\n */\n _this.nextCenter_ = null;\n /**\n * @private\n * @type {number}\n */\n _this.nextResolution_;\n /**\n * @private\n * @type {number}\n */\n _this.nextRotation_;\n /**\n * @private\n * @type {import(\"./coordinate.js\").Coordinate|undefined}\n */\n _this.cancelAnchor_ = undefined;\n if (options.center) {\n options.center = fromUserCoordinate(options.center, _this.projection_);\n }\n if (options.extent) {\n options.extent = fromUserExtent(options.extent, _this.projection_);\n }\n _this.applyOptions_(options);\n return _this;\n }\n /**\n * Set up the view with the given options.\n * @param {ViewOptions} options View options.\n */\n View.prototype.applyOptions_ = function (options) {\n /**\n * @type {Object<string, *>}\n */\n var properties = {};\n var resolutionConstraintInfo = createResolutionConstraint(options);\n /**\n * @private\n * @type {number}\n */\n this.maxResolution_ = resolutionConstraintInfo.maxResolution;\n /**\n * @private\n * @type {number}\n */\n this.minResolution_ = resolutionConstraintInfo.minResolution;\n /**\n * @private\n * @type {number}\n */\n this.zoomFactor_ = resolutionConstraintInfo.zoomFactor;\n /**\n * @private\n * @type {Array<number>|undefined}\n */\n this.resolutions_ = options.resolutions;\n /**\n * @type {Array<number>|undefined}\n * @private\n */\n this.padding_ = options.padding;\n /**\n * @private\n * @type {number}\n */\n this.minZoom_ = resolutionConstraintInfo.minZoom;\n var centerConstraint = createCenterConstraint(options);\n var resolutionConstraint = resolutionConstraintInfo.constraint;\n var rotationConstraint = createRotationConstraint(options);\n /**\n * @private\n * @type {Constraints}\n */\n this.constraints_ = {\n center: centerConstraint,\n resolution: resolutionConstraint,\n rotation: rotationConstraint,\n };\n this.setRotation(options.rotation !== undefined ? options.rotation : 0);\n this.setCenterInternal(options.center !== undefined ? options.center : null);\n if (options.resolution !== undefined) {\n this.setResolution(options.resolution);\n }\n else if (options.zoom !== undefined) {\n this.setZoom(options.zoom);\n }\n this.setProperties(properties);\n /**\n * @private\n * @type {ViewOptions}\n */\n this.options_ = options;\n };\n Object.defineProperty(View.prototype, \"padding\", {\n /**\n * Padding (in css pixels).\n * If the map viewport is partially covered with other content (overlays) along\n * its edges, this setting allows to shift the center of the viewport away from that\n * content. The order of the values in the array is top, right, bottom, left.\n * The default is no padding, which is equivalent to `[0, 0, 0, 0]`.\n * @type {Array<number>|undefined}\n * @api\n */\n get: function () {\n return this.padding_;\n },\n set: function (padding) {\n var oldPadding = this.padding_;\n this.padding_ = padding;\n var center = this.getCenter();\n if (center) {\n var newPadding = padding || [0, 0, 0, 0];\n oldPadding = oldPadding || [0, 0, 0, 0];\n var resolution = this.getResolution();\n var offsetX = (resolution / 2) *\n (newPadding[3] - oldPadding[3] + oldPadding[1] - newPadding[1]);\n var offsetY = (resolution / 2) *\n (newPadding[0] - oldPadding[0] + oldPadding[2] - newPadding[2]);\n this.setCenterInternal([center[0] + offsetX, center[1] - offsetY]);\n }\n },\n enumerable: false,\n configurable: true\n });\n /**\n * Get an updated version of the view options used to construct the view. The\n * current resolution (or zoom), center, and rotation are applied to any stored\n * options. The provided options can be used to apply new min/max zoom or\n * resolution limits.\n * @param {ViewOptions} newOptions New options to be applied.\n * @return {ViewOptions} New options updated with the current view state.\n */\n View.prototype.getUpdatedOptions_ = function (newOptions) {\n var options = assign({}, this.options_);\n // preserve resolution (or zoom)\n if (options.resolution !== undefined) {\n options.resolution = this.getResolution();\n }\n else {\n options.zoom = this.getZoom();\n }\n // preserve center\n options.center = this.getCenterInternal();\n // preserve rotation\n options.rotation = this.getRotation();\n return assign({}, options, newOptions);\n };\n /**\n * Animate the view. The view's center, zoom (or resolution), and rotation\n * can be animated for smooth transitions between view states. For example,\n * to animate the view to a new zoom level:\n *\n * view.animate({zoom: view.getZoom() + 1});\n *\n * By default, the animation lasts one second and uses in-and-out easing. You\n * can customize this behavior by including `duration` (in milliseconds) and\n * `easing` options (see {@link module:ol/easing}).\n *\n * To chain together multiple animations, call the method with multiple\n * animation objects. For example, to first zoom and then pan:\n *\n * view.animate({zoom: 10}, {center: [0, 0]});\n *\n * If you provide a function as the last argument to the animate method, it\n * will get called at the end of an animation series. The callback will be\n * called with `true` if the animation series completed on its own or `false`\n * if it was cancelled.\n *\n * Animations are cancelled by user interactions (e.g. dragging the map) or by\n * calling `view.setCenter()`, `view.setResolution()`, or `view.setRotation()`\n * (or another method that calls one of these).\n *\n * @param {...(AnimationOptions|function(boolean): void)} var_args Animation\n * options. Multiple animations can be run in series by passing multiple\n * options objects. To run multiple animations in parallel, call the method\n * multiple times. An optional callback can be provided as a final\n * argument. The callback will be called with a boolean indicating whether\n * the animation completed without being cancelled.\n * @api\n */\n View.prototype.animate = function (var_args) {\n if (this.isDef() && !this.getAnimating()) {\n this.resolveConstraints(0);\n }\n var args = new Array(arguments.length);\n for (var i = 0; i < args.length; ++i) {\n var options = arguments[i];\n if (options.center) {\n options = assign({}, options);\n options.center = fromUserCoordinate(options.center, this.getProjection());\n }\n if (options.anchor) {\n options = assign({}, options);\n options.anchor = fromUserCoordinate(options.anchor, this.getProjection());\n }\n args[i] = options;\n }\n this.animateInternal.apply(this, args);\n };\n /**\n * @param {...(AnimationOptions|function(boolean): void)} var_args Animation options.\n */\n View.prototype.animateInternal = function (var_args) {\n var animationCount = arguments.length;\n var callback;\n if (animationCount > 1 &&\n typeof arguments[animationCount - 1] === 'function') {\n callback = arguments[animationCount - 1];\n --animationCount;\n }\n var i = 0;\n for (; i < animationCount && !this.isDef(); ++i) {\n // if view properties are not yet set, shortcut to the final state\n var state = arguments[i];\n if (state.center) {\n this.setCenterInternal(state.center);\n }\n if (state.zoom !== undefined) {\n this.setZoom(state.zoom);\n }\n else if (state.resolution) {\n this.setResolution(state.resolution);\n }\n if (state.rotation !== undefined) {\n this.setRotation(state.rotation);\n }\n }\n if (i === animationCount) {\n if (callback) {\n animationCallback(callback, true);\n }\n return;\n }\n var start = Date.now();\n var center = this.targetCenter_.slice();\n var resolution = this.targetResolution_;\n var rotation = this.targetRotation_;\n var series = [];\n for (; i < animationCount; ++i) {\n var options = /** @type {AnimationOptions} */ (arguments[i]);\n var animation = {\n start: start,\n complete: false,\n anchor: options.anchor,\n duration: options.duration !== undefined ? options.duration : 1000,\n easing: options.easing || inAndOut,\n callback: callback,\n };\n if (options.center) {\n animation.sourceCenter = center;\n animation.targetCenter = options.center.slice();\n center = animation.targetCenter;\n }\n if (options.zoom !== undefined) {\n animation.sourceResolution = resolution;\n animation.targetResolution = this.getResolutionForZoom(options.zoom);\n resolution = animation.targetResolution;\n }\n else if (options.resolution) {\n animation.sourceResolution = resolution;\n animation.targetResolution = options.resolution;\n resolution = animation.targetResolution;\n }\n if (options.rotation !== undefined) {\n animation.sourceRotation = rotation;\n var delta = modulo(options.rotation - rotation + Math.PI, 2 * Math.PI) - Math.PI;\n animation.targetRotation = rotation + delta;\n rotation = animation.targetRotation;\n }\n // check if animation is a no-op\n if (isNoopAnimation(animation)) {\n animation.complete = true;\n // we still push it onto the series for callback handling\n }\n else {\n start += animation.duration;\n }\n series.push(animation);\n }\n this.animations_.push(series);\n this.setHint(ViewHint.ANIMATING, 1);\n this.updateAnimations_();\n };\n /**\n * Determine if the view is being animated.\n * @return {boolean} The view is being animated.\n * @api\n */\n View.prototype.getAnimating = function () {\n return this.hints_[ViewHint.ANIMATING] > 0;\n };\n /**\n * Determine if the user is interacting with the view, such as panning or zooming.\n * @return {boolean} The view is being interacted with.\n * @api\n */\n View.prototype.getInteracting = function () {\n return this.hints_[ViewHint.INTERACTING] > 0;\n };\n /**\n * Cancel any ongoing animations.\n * @api\n */\n View.prototype.cancelAnimations = function () {\n this.setHint(ViewHint.ANIMATING, -this.hints_[ViewHint.ANIMATING]);\n var anchor;\n for (var i = 0, ii = this.animations_.length; i < ii; ++i) {\n var series = this.animations_[i];\n if (series[0].callback) {\n animationCallback(series[0].callback, false);\n }\n if (!anchor) {\n for (var j = 0, jj = series.length; j < jj; ++j) {\n var animation = series[j];\n if (!animation.complete) {\n anchor = animation.anchor;\n break;\n }\n }\n }\n }\n this.animations_.length = 0;\n this.cancelAnchor_ = anchor;\n this.nextCenter_ = null;\n this.nextResolution_ = NaN;\n this.nextRotation_ = NaN;\n };\n /**\n * Update all animations.\n */\n View.prototype.updateAnimations_ = function () {\n if (this.updateAnimationKey_ !== undefined) {\n cancelAnimationFrame(this.updateAnimationKey_);\n this.updateAnimationKey_ = undefined;\n }\n if (!this.getAnimating()) {\n return;\n }\n var now = Date.now();\n var more = false;\n for (var i = this.animations_.length - 1; i >= 0; --i) {\n var series = this.animations_[i];\n var seriesComplete = true;\n for (var j = 0, jj = series.length; j < jj; ++j) {\n var animation = series[j];\n if (animation.complete) {\n continue;\n }\n var elapsed = now - animation.start;\n var fraction = animation.duration > 0 ? elapsed / animation.duration : 1;\n if (fraction >= 1) {\n animation.complete = true;\n fraction = 1;\n }\n else {\n seriesComplete = false;\n }\n var progress = animation.easing(fraction);\n if (animation.sourceCenter) {\n var x0 = animation.sourceCenter[0];\n var y0 = animation.sourceCenter[1];\n var x1 = animation.targetCenter[0];\n var y1 = animation.targetCenter[1];\n this.nextCenter_ = animation.targetCenter;\n var x = x0 + progress * (x1 - x0);\n var y = y0 + progress * (y1 - y0);\n this.targetCenter_ = [x, y];\n }\n if (animation.sourceResolution && animation.targetResolution) {\n var resolution = progress === 1\n ? animation.targetResolution\n : animation.sourceResolution +\n progress *\n (animation.targetResolution - animation.sourceResolution);\n if (animation.anchor) {\n var size = this.getViewportSize_(this.getRotation());\n var constrainedResolution = this.constraints_.resolution(resolution, 0, size, true);\n this.targetCenter_ = this.calculateCenterZoom(constrainedResolution, animation.anchor);\n }\n this.nextResolution_ = animation.targetResolution;\n this.targetResolution_ = resolution;\n this.applyTargetState_(true);\n }\n if (animation.sourceRotation !== undefined &&\n animation.targetRotation !== undefined) {\n var rotation = progress === 1\n ? modulo(animation.targetRotation + Math.PI, 2 * Math.PI) -\n Math.PI\n : animation.sourceRotation +\n progress *\n (animation.targetRotation - animation.sourceRotation);\n if (animation.anchor) {\n var constrainedRotation = this.constraints_.rotation(rotation, true);\n this.targetCenter_ = this.calculateCenterRotate(constrainedRotation, animation.anchor);\n }\n this.nextRotation_ = animation.targetRotation;\n this.targetRotation_ = rotation;\n }\n this.applyTargetState_(true);\n more = true;\n if (!animation.complete) {\n break;\n }\n }\n if (seriesComplete) {\n this.animations_[i] = null;\n this.setHint(ViewHint.ANIMATING, -1);\n this.nextCenter_ = null;\n this.nextResolution_ = NaN;\n this.nextRotation_ = NaN;\n var callback = series[0].callback;\n if (callback) {\n animationCallback(callback, true);\n }\n }\n }\n // prune completed series\n this.animations_ = this.animations_.filter(Boolean);\n if (more && this.updateAnimationKey_ === undefined) {\n this.updateAnimationKey_ = requestAnimationFrame(this.updateAnimations_.bind(this));\n }\n };\n /**\n * @param {number} rotation Target rotation.\n * @param {import(\"./coordinate.js\").Coordinate} anchor Rotation anchor.\n * @return {import(\"./coordinate.js\").Coordinate|undefined} Center for rotation and anchor.\n */\n View.prototype.calculateCenterRotate = function (rotation, anchor) {\n var center;\n var currentCenter = this.getCenterInternal();\n if (currentCenter !== undefined) {\n center = [currentCenter[0] - anchor[0], currentCenter[1] - anchor[1]];\n rotateCoordinate(center, rotation - this.getRotation());\n addCoordinate(center, anchor);\n }\n return center;\n };\n /**\n * @param {number} resolution Target resolution.\n * @param {import(\"./coordinate.js\").Coordinate} anchor Zoom anchor.\n * @return {import(\"./coordinate.js\").Coordinate|undefined} Center for resolution and anchor.\n */\n View.prototype.calculateCenterZoom = function (resolution, anchor) {\n var center;\n var currentCenter = this.getCenterInternal();\n var currentResolution = this.getResolution();\n if (currentCenter !== undefined && currentResolution !== undefined) {\n var x = anchor[0] -\n (resolution * (anchor[0] - currentCenter[0])) / currentResolution;\n var y = anchor[1] -\n (resolution * (anchor[1] - currentCenter[1])) / currentResolution;\n center = [x, y];\n }\n return center;\n };\n /**\n * Returns the current viewport size.\n * @private\n * @param {number} [opt_rotation] Take into account the rotation of the viewport when giving the size\n * @return {import(\"./size.js\").Size} Viewport size or `[100, 100]` when no viewport is found.\n */\n View.prototype.getViewportSize_ = function (opt_rotation) {\n var size = this.viewportSize_;\n if (opt_rotation) {\n var w = size[0];\n var h = size[1];\n return [\n Math.abs(w * Math.cos(opt_rotation)) +\n Math.abs(h * Math.sin(opt_rotation)),\n Math.abs(w * Math.sin(opt_rotation)) +\n Math.abs(h * Math.cos(opt_rotation)),\n ];\n }\n else {\n return size;\n }\n };\n /**\n * Stores the viewport size on the view. The viewport size is not read every time from the DOM\n * to avoid performance hit and layout reflow.\n * This should be done on map size change.\n * Note: the constraints are not resolved during an animation to avoid stopping it\n * @param {import(\"./size.js\").Size} [opt_size] Viewport size; if undefined, [100, 100] is assumed\n */\n View.prototype.setViewportSize = function (opt_size) {\n this.viewportSize_ = Array.isArray(opt_size)\n ? opt_size.slice()\n : [100, 100];\n if (!this.getAnimating()) {\n this.resolveConstraints(0);\n }\n };\n /**\n * Get the view center.\n * @return {import(\"./coordinate.js\").Coordinate|undefined} The center of the view.\n * @observable\n * @api\n */\n View.prototype.getCenter = function () {\n var center = this.getCenterInternal();\n if (!center) {\n return center;\n }\n return toUserCoordinate(center, this.getProjection());\n };\n /**\n * Get the view center without transforming to user projection.\n * @return {import(\"./coordinate.js\").Coordinate|undefined} The center of the view.\n */\n View.prototype.getCenterInternal = function () {\n return /** @type {import(\"./coordinate.js\").Coordinate|undefined} */ (this.get(ViewProperty.CENTER));\n };\n /**\n * @return {Constraints} Constraints.\n */\n View.prototype.getConstraints = function () {\n return this.constraints_;\n };\n /**\n * @return {boolean} Resolution constraint is set\n */\n View.prototype.getConstrainResolution = function () {\n return this.options_.constrainResolution;\n };\n /**\n * @param {Array<number>} [opt_hints] Destination array.\n * @return {Array<number>} Hint.\n */\n View.prototype.getHints = function (opt_hints) {\n if (opt_hints !== undefined) {\n opt_hints[0] = this.hints_[0];\n opt_hints[1] = this.hints_[1];\n return opt_hints;\n }\n else {\n return this.hints_.slice();\n }\n };\n /**\n * Calculate the extent for the current view state and the passed size.\n * The size is the pixel dimensions of the box into which the calculated extent\n * should fit. In most cases you want to get the extent of the entire map,\n * that is `map.getSize()`.\n * @param {import(\"./size.js\").Size} [opt_size] Box pixel size. If not provided, the size\n * of the map that uses this view will be used.\n * @return {import(\"./extent.js\").Extent} Extent.\n * @api\n */\n View.prototype.calculateExtent = function (opt_size) {\n var extent = this.calculateExtentInternal(opt_size);\n return toUserExtent(extent, this.getProjection());\n };\n /**\n * @param {import(\"./size.js\").Size} [opt_size] Box pixel size. If not provided,\n * the map's last known viewport size will be used.\n * @return {import(\"./extent.js\").Extent} Extent.\n */\n View.prototype.calculateExtentInternal = function (opt_size) {\n var size = opt_size || this.getViewportSizeMinusPadding_();\n var center = /** @type {!import(\"./coordinate.js\").Coordinate} */ (this.getCenterInternal());\n assert(center, 1); // The view center is not defined\n var resolution = /** @type {!number} */ (this.getResolution());\n assert(resolution !== undefined, 2); // The view resolution is not defined\n var rotation = /** @type {!number} */ (this.getRotation());\n assert(rotation !== undefined, 3); // The view rotation is not defined\n return getForViewAndSize(center, resolution, rotation, size);\n };\n /**\n * Get the maximum resolution of the view.\n * @return {number} The maximum resolution of the view.\n * @api\n */\n View.prototype.getMaxResolution = function () {\n return this.maxResolution_;\n };\n /**\n * Get the minimum resolution of the view.\n * @return {number} The minimum resolution of the view.\n * @api\n */\n View.prototype.getMinResolution = function () {\n return this.minResolution_;\n };\n /**\n * Get the maximum zoom level for the view.\n * @return {number} The maximum zoom level.\n * @api\n */\n View.prototype.getMaxZoom = function () {\n return /** @type {number} */ (this.getZoomForResolution(this.minResolution_));\n };\n /**\n * Set a new maximum zoom level for the view.\n * @param {number} zoom The maximum zoom level.\n * @api\n */\n View.prototype.setMaxZoom = function (zoom) {\n this.applyOptions_(this.getUpdatedOptions_({ maxZoom: zoom }));\n };\n /**\n * Get the minimum zoom level for the view.\n * @return {number} The minimum zoom level.\n * @api\n */\n View.prototype.getMinZoom = function () {\n return /** @type {number} */ (this.getZoomForResolution(this.maxResolution_));\n };\n /**\n * Set a new minimum zoom level for the view.\n * @param {number} zoom The minimum zoom level.\n * @api\n */\n View.prototype.setMinZoom = function (zoom) {\n this.applyOptions_(this.getUpdatedOptions_({ minZoom: zoom }));\n };\n /**\n * Set whether the view should allow intermediary zoom levels.\n * @param {boolean} enabled Whether the resolution is constrained.\n * @api\n */\n View.prototype.setConstrainResolution = function (enabled) {\n this.applyOptions_(this.getUpdatedOptions_({ constrainResolution: enabled }));\n };\n /**\n * Get the view projection.\n * @return {import(\"./proj/Projection.js\").default} The projection of the view.\n * @api\n */\n View.prototype.getProjection = function () {\n return this.projection_;\n };\n /**\n * Get the view resolution.\n * @return {number|undefined} The resolution of the view.\n * @observable\n * @api\n */\n View.prototype.getResolution = function () {\n return /** @type {number|undefined} */ (this.get(ViewProperty.RESOLUTION));\n };\n /**\n * Get the resolutions for the view. This returns the array of resolutions\n * passed to the constructor of the View, or undefined if none were given.\n * @return {Array<number>|undefined} The resolutions of the view.\n * @api\n */\n View.prototype.getResolutions = function () {\n return this.resolutions_;\n };\n /**\n * Get the resolution for a provided extent (in map units) and size (in pixels).\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {import(\"./size.js\").Size} [opt_size] Box pixel size.\n * @return {number} The resolution at which the provided extent will render at\n * the given size.\n * @api\n */\n View.prototype.getResolutionForExtent = function (extent, opt_size) {\n return this.getResolutionForExtentInternal(fromUserExtent(extent, this.getProjection()), opt_size);\n };\n /**\n * Get the resolution for a provided extent (in map units) and size (in pixels).\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {import(\"./size.js\").Size} [opt_size] Box pixel size.\n * @return {number} The resolution at which the provided extent will render at\n * the given size.\n */\n View.prototype.getResolutionForExtentInternal = function (extent, opt_size) {\n var size = opt_size || this.getViewportSizeMinusPadding_();\n var xResolution = getWidth(extent) / size[0];\n var yResolution = getHeight(extent) / size[1];\n return Math.max(xResolution, yResolution);\n };\n /**\n * Return a function that returns a value between 0 and 1 for a\n * resolution. Exponential scaling is assumed.\n * @param {number} [opt_power] Power.\n * @return {function(number): number} Resolution for value function.\n */\n View.prototype.getResolutionForValueFunction = function (opt_power) {\n var power = opt_power || 2;\n var maxResolution = this.getConstrainedResolution(this.maxResolution_);\n var minResolution = this.minResolution_;\n var max = Math.log(maxResolution / minResolution) / Math.log(power);\n return (\n /**\n * @param {number} value Value.\n * @return {number} Resolution.\n */\n function (value) {\n var resolution = maxResolution / Math.pow(power, value * max);\n return resolution;\n });\n };\n /**\n * Get the view rotation.\n * @return {number} The rotation of the view in radians.\n * @observable\n * @api\n */\n View.prototype.getRotation = function () {\n return /** @type {number} */ (this.get(ViewProperty.ROTATION));\n };\n /**\n * Return a function that returns a resolution for a value between\n * 0 and 1. Exponential scaling is assumed.\n * @param {number} [opt_power] Power.\n * @return {function(number): number} Value for resolution function.\n */\n View.prototype.getValueForResolutionFunction = function (opt_power) {\n var logPower = Math.log(opt_power || 2);\n var maxResolution = this.getConstrainedResolution(this.maxResolution_);\n var minResolution = this.minResolution_;\n var max = Math.log(maxResolution / minResolution) / logPower;\n return (\n /**\n * @param {number} resolution Resolution.\n * @return {number} Value.\n */\n function (resolution) {\n var value = Math.log(maxResolution / resolution) / logPower / max;\n return value;\n });\n };\n /**\n * Returns the size of the viewport minus padding.\n * @private\n * @param {number} [opt_rotation] Take into account the rotation of the viewport when giving the size\n * @return {import(\"./size.js\").Size} Viewport size reduced by the padding.\n */\n View.prototype.getViewportSizeMinusPadding_ = function (opt_rotation) {\n var size = this.getViewportSize_(opt_rotation);\n var padding = this.padding_;\n if (padding) {\n size = [\n size[0] - padding[1] - padding[3],\n size[1] - padding[0] - padding[2],\n ];\n }\n return size;\n };\n /**\n * @return {State} View state.\n */\n View.prototype.getState = function () {\n var projection = this.getProjection();\n var resolution = this.getResolution();\n var rotation = this.getRotation();\n var center = /** @type {import(\"./coordinate.js\").Coordinate} */ (this.getCenterInternal());\n var padding = this.padding_;\n if (padding) {\n var reducedSize = this.getViewportSizeMinusPadding_();\n center = calculateCenterOn(center, this.getViewportSize_(), [reducedSize[0] / 2 + padding[3], reducedSize[1] / 2 + padding[0]], resolution, rotation);\n }\n return {\n center: center.slice(0),\n projection: projection !== undefined ? projection : null,\n resolution: resolution,\n nextCenter: this.nextCenter_,\n nextResolution: this.nextResolution_,\n nextRotation: this.nextRotation_,\n rotation: rotation,\n zoom: this.getZoom(),\n };\n };\n /**\n * Get the current zoom level. This method may return non-integer zoom levels\n * if the view does not constrain the resolution, or if an interaction or\n * animation is underway.\n * @return {number|undefined} Zoom.\n * @api\n */\n View.prototype.getZoom = function () {\n var zoom;\n var resolution = this.getResolution();\n if (resolution !== undefined) {\n zoom = this.getZoomForResolution(resolution);\n }\n return zoom;\n };\n /**\n * Get the zoom level for a resolution.\n * @param {number} resolution The resolution.\n * @return {number|undefined} The zoom level for the provided resolution.\n * @api\n */\n View.prototype.getZoomForResolution = function (resolution) {\n var offset = this.minZoom_ || 0;\n var max, zoomFactor;\n if (this.resolutions_) {\n var nearest = linearFindNearest(this.resolutions_, resolution, 1);\n offset = nearest;\n max = this.resolutions_[nearest];\n if (nearest == this.resolutions_.length - 1) {\n zoomFactor = 2;\n }\n else {\n zoomFactor = max / this.resolutions_[nearest + 1];\n }\n }\n else {\n max = this.maxResolution_;\n zoomFactor = this.zoomFactor_;\n }\n return offset + Math.log(max / resolution) / Math.log(zoomFactor);\n };\n /**\n * Get the resolution for a zoom level.\n * @param {number} zoom Zoom level.\n * @return {number} The view resolution for the provided zoom level.\n * @api\n */\n View.prototype.getResolutionForZoom = function (zoom) {\n if (this.resolutions_) {\n if (this.resolutions_.length <= 1) {\n return 0;\n }\n var baseLevel = clamp(Math.floor(zoom), 0, this.resolutions_.length - 2);\n var zoomFactor = this.resolutions_[baseLevel] / this.resolutions_[baseLevel + 1];\n return (this.resolutions_[baseLevel] /\n Math.pow(zoomFactor, clamp(zoom - baseLevel, 0, 1)));\n }\n else {\n return (this.maxResolution_ / Math.pow(this.zoomFactor_, zoom - this.minZoom_));\n }\n };\n /**\n * Fit the given geometry or extent based on the given map size and border.\n * The size is pixel dimensions of the box to fit the extent into.\n * In most cases you will want to use the map size, that is `map.getSize()`.\n * Takes care of the map angle.\n * @param {import(\"./geom/SimpleGeometry.js\").default|import(\"./extent.js\").Extent} geometryOrExtent The geometry or\n * extent to fit the view to.\n * @param {FitOptions} [opt_options] Options.\n * @api\n */\n View.prototype.fit = function (geometryOrExtent, opt_options) {\n /** @type {import(\"./geom/SimpleGeometry.js\").default} */\n var geometry;\n assert(Array.isArray(geometryOrExtent) ||\n typeof ( /** @type {?} */(geometryOrExtent).getSimplifiedGeometry) ===\n 'function', 24); // Invalid extent or geometry provided as `geometry`\n if (Array.isArray(geometryOrExtent)) {\n assert(!isEmpty(geometryOrExtent), 25); // Cannot fit empty extent provided as `geometry`\n var extent = fromUserExtent(geometryOrExtent, this.getProjection());\n geometry = polygonFromExtent(extent);\n }\n else if (geometryOrExtent.getType() === GeometryType.CIRCLE) {\n var extent = fromUserExtent(geometryOrExtent.getExtent(), this.getProjection());\n geometry = polygonFromExtent(extent);\n geometry.rotate(this.getRotation(), getCenter(extent));\n }\n else {\n var userProjection = getUserProjection();\n if (userProjection) {\n geometry = /** @type {import(\"./geom/SimpleGeometry.js\").default} */ (geometryOrExtent\n .clone()\n .transform(userProjection, this.getProjection()));\n }\n else {\n geometry = geometryOrExtent;\n }\n }\n this.fitInternal(geometry, opt_options);\n };\n /**\n * Calculate rotated extent\n * @param {import(\"./geom/SimpleGeometry.js\").default} geometry The geometry.\n * @return {import(\"./extent\").Extent} The rotated extent for the geometry.\n */\n View.prototype.rotatedExtentForGeometry = function (geometry) {\n var rotation = this.getRotation();\n var cosAngle = Math.cos(rotation);\n var sinAngle = Math.sin(-rotation);\n var coords = geometry.getFlatCoordinates();\n var stride = geometry.getStride();\n var minRotX = +Infinity;\n var minRotY = +Infinity;\n var maxRotX = -Infinity;\n var maxRotY = -Infinity;\n for (var i = 0, ii = coords.length; i < ii; i += stride) {\n var rotX = coords[i] * cosAngle - coords[i + 1] * sinAngle;\n var rotY = coords[i] * sinAngle + coords[i + 1] * cosAngle;\n minRotX = Math.min(minRotX, rotX);\n minRotY = Math.min(minRotY, rotY);\n maxRotX = Math.max(maxRotX, rotX);\n maxRotY = Math.max(maxRotY, rotY);\n }\n return [minRotX, minRotY, maxRotX, maxRotY];\n };\n /**\n * @param {import(\"./geom/SimpleGeometry.js\").default} geometry The geometry.\n * @param {FitOptions} [opt_options] Options.\n */\n View.prototype.fitInternal = function (geometry, opt_options) {\n var options = opt_options || {};\n var size = options.size;\n if (!size) {\n size = this.getViewportSizeMinusPadding_();\n }\n var padding = options.padding !== undefined ? options.padding : [0, 0, 0, 0];\n var nearest = options.nearest !== undefined ? options.nearest : false;\n var minResolution;\n if (options.minResolution !== undefined) {\n minResolution = options.minResolution;\n }\n else if (options.maxZoom !== undefined) {\n minResolution = this.getResolutionForZoom(options.maxZoom);\n }\n else {\n minResolution = 0;\n }\n var rotatedExtent = this.rotatedExtentForGeometry(geometry);\n // calculate resolution\n var resolution = this.getResolutionForExtentInternal(rotatedExtent, [\n size[0] - padding[1] - padding[3],\n size[1] - padding[0] - padding[2],\n ]);\n resolution = isNaN(resolution)\n ? minResolution\n : Math.max(resolution, minResolution);\n resolution = this.getConstrainedResolution(resolution, nearest ? 0 : 1);\n // calculate center\n var rotation = this.getRotation();\n var sinAngle = Math.sin(rotation);\n var cosAngle = Math.cos(rotation);\n var centerRot = getCenter(rotatedExtent);\n centerRot[0] += ((padding[1] - padding[3]) / 2) * resolution;\n centerRot[1] += ((padding[0] - padding[2]) / 2) * resolution;\n var centerX = centerRot[0] * cosAngle - centerRot[1] * sinAngle;\n var centerY = centerRot[1] * cosAngle + centerRot[0] * sinAngle;\n var center = this.getConstrainedCenter([centerX, centerY], resolution);\n var callback = options.callback ? options.callback : VOID;\n if (options.duration !== undefined) {\n this.animateInternal({\n resolution: resolution,\n center: center,\n duration: options.duration,\n easing: options.easing,\n }, callback);\n }\n else {\n this.targetResolution_ = resolution;\n this.targetCenter_ = center;\n this.applyTargetState_(false, true);\n animationCallback(callback, true);\n }\n };\n /**\n * Center on coordinate and view position.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {import(\"./size.js\").Size} size Box pixel size.\n * @param {import(\"./pixel.js\").Pixel} position Position on the view to center on.\n * @api\n */\n View.prototype.centerOn = function (coordinate, size, position) {\n this.centerOnInternal(fromUserCoordinate(coordinate, this.getProjection()), size, position);\n };\n /**\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {import(\"./size.js\").Size} size Box pixel size.\n * @param {import(\"./pixel.js\").Pixel} position Position on the view to center on.\n */\n View.prototype.centerOnInternal = function (coordinate, size, position) {\n this.setCenterInternal(calculateCenterOn(coordinate, size, position, this.getResolution(), this.getRotation()));\n };\n /**\n * Calculates the shift between map and viewport center.\n * @param {import(\"./coordinate.js\").Coordinate} center Center.\n * @param {number} resolution Resolution.\n * @param {number} rotation Rotation.\n * @param {import(\"./size.js\").Size} size Size.\n * @return {Array<number>|undefined} Center shift.\n */\n View.prototype.calculateCenterShift = function (center, resolution, rotation, size) {\n var centerShift;\n var padding = this.padding_;\n if (padding && center) {\n var reducedSize = this.getViewportSizeMinusPadding_(-rotation);\n var shiftedCenter = calculateCenterOn(center, size, [reducedSize[0] / 2 + padding[3], reducedSize[1] / 2 + padding[0]], resolution, rotation);\n centerShift = [\n center[0] - shiftedCenter[0],\n center[1] - shiftedCenter[1],\n ];\n }\n return centerShift;\n };\n /**\n * @return {boolean} Is defined.\n */\n View.prototype.isDef = function () {\n return !!this.getCenterInternal() && this.getResolution() !== undefined;\n };\n /**\n * Adds relative coordinates to the center of the view. Any extent constraint will apply.\n * @param {import(\"./coordinate.js\").Coordinate} deltaCoordinates Relative value to add.\n * @api\n */\n View.prototype.adjustCenter = function (deltaCoordinates) {\n var center = toUserCoordinate(this.targetCenter_, this.getProjection());\n this.setCenter([\n center[0] + deltaCoordinates[0],\n center[1] + deltaCoordinates[1],\n ]);\n };\n /**\n * Adds relative coordinates to the center of the view. Any extent constraint will apply.\n * @param {import(\"./coordinate.js\").Coordinate} deltaCoordinates Relative value to add.\n */\n View.prototype.adjustCenterInternal = function (deltaCoordinates) {\n var center = this.targetCenter_;\n this.setCenterInternal([\n center[0] + deltaCoordinates[0],\n center[1] + deltaCoordinates[1],\n ]);\n };\n /**\n * Multiply the view resolution by a ratio, optionally using an anchor. Any resolution\n * constraint will apply.\n * @param {number} ratio The ratio to apply on the view resolution.\n * @param {import(\"./coordinate.js\").Coordinate} [opt_anchor] The origin of the transformation.\n * @api\n */\n View.prototype.adjustResolution = function (ratio, opt_anchor) {\n var anchor = opt_anchor && fromUserCoordinate(opt_anchor, this.getProjection());\n this.adjustResolutionInternal(ratio, anchor);\n };\n /**\n * Multiply the view resolution by a ratio, optionally using an anchor. Any resolution\n * constraint will apply.\n * @param {number} ratio The ratio to apply on the view resolution.\n * @param {import(\"./coordinate.js\").Coordinate} [opt_anchor] The origin of the transformation.\n */\n View.prototype.adjustResolutionInternal = function (ratio, opt_anchor) {\n var isMoving = this.getAnimating() || this.getInteracting();\n var size = this.getViewportSize_(this.getRotation());\n var newResolution = this.constraints_.resolution(this.targetResolution_ * ratio, 0, size, isMoving);\n if (opt_anchor) {\n this.targetCenter_ = this.calculateCenterZoom(newResolution, opt_anchor);\n }\n this.targetResolution_ *= ratio;\n this.applyTargetState_();\n };\n /**\n * Adds a value to the view zoom level, optionally using an anchor. Any resolution\n * constraint will apply.\n * @param {number} delta Relative value to add to the zoom level.\n * @param {import(\"./coordinate.js\").Coordinate} [opt_anchor] The origin of the transformation.\n * @api\n */\n View.prototype.adjustZoom = function (delta, opt_anchor) {\n this.adjustResolution(Math.pow(this.zoomFactor_, -delta), opt_anchor);\n };\n /**\n * Adds a value to the view rotation, optionally using an anchor. Any rotation\n * constraint will apply.\n * @param {number} delta Relative value to add to the zoom rotation, in radians.\n * @param {import(\"./coordinate.js\").Coordinate} [opt_anchor] The rotation center.\n * @api\n */\n View.prototype.adjustRotation = function (delta, opt_anchor) {\n if (opt_anchor) {\n opt_anchor = fromUserCoordinate(opt_anchor, this.getProjection());\n }\n this.adjustRotationInternal(delta, opt_anchor);\n };\n /**\n * @param {number} delta Relative value to add to the zoom rotation, in radians.\n * @param {import(\"./coordinate.js\").Coordinate} [opt_anchor] The rotation center.\n */\n View.prototype.adjustRotationInternal = function (delta, opt_anchor) {\n var isMoving = this.getAnimating() || this.getInteracting();\n var newRotation = this.constraints_.rotation(this.targetRotation_ + delta, isMoving);\n if (opt_anchor) {\n this.targetCenter_ = this.calculateCenterRotate(newRotation, opt_anchor);\n }\n this.targetRotation_ += delta;\n this.applyTargetState_();\n };\n /**\n * Set the center of the current view. Any extent constraint will apply.\n * @param {import(\"./coordinate.js\").Coordinate|undefined} center The center of the view.\n * @observable\n * @api\n */\n View.prototype.setCenter = function (center) {\n this.setCenterInternal(fromUserCoordinate(center, this.getProjection()));\n };\n /**\n * Set the center using the view projection (not the user projection).\n * @param {import(\"./coordinate.js\").Coordinate|undefined} center The center of the view.\n */\n View.prototype.setCenterInternal = function (center) {\n this.targetCenter_ = center;\n this.applyTargetState_();\n };\n /**\n * @param {import(\"./ViewHint.js\").default} hint Hint.\n * @param {number} delta Delta.\n * @return {number} New value.\n */\n View.prototype.setHint = function (hint, delta) {\n this.hints_[hint] += delta;\n this.changed();\n return this.hints_[hint];\n };\n /**\n * Set the resolution for this view. Any resolution constraint will apply.\n * @param {number|undefined} resolution The resolution of the view.\n * @observable\n * @api\n */\n View.prototype.setResolution = function (resolution) {\n this.targetResolution_ = resolution;\n this.applyTargetState_();\n };\n /**\n * Set the rotation for this view. Any rotation constraint will apply.\n * @param {number} rotation The rotation of the view in radians.\n * @observable\n * @api\n */\n View.prototype.setRotation = function (rotation) {\n this.targetRotation_ = rotation;\n this.applyTargetState_();\n };\n /**\n * Zoom to a specific zoom level. Any resolution constrain will apply.\n * @param {number} zoom Zoom level.\n * @api\n */\n View.prototype.setZoom = function (zoom) {\n this.setResolution(this.getResolutionForZoom(zoom));\n };\n /**\n * Recompute rotation/resolution/center based on target values.\n * Note: we have to compute rotation first, then resolution and center considering that\n * parameters can influence one another in case a view extent constraint is present.\n * @param {boolean} [opt_doNotCancelAnims] Do not cancel animations.\n * @param {boolean} [opt_forceMoving] Apply constraints as if the view is moving.\n * @private\n */\n View.prototype.applyTargetState_ = function (opt_doNotCancelAnims, opt_forceMoving) {\n var isMoving = this.getAnimating() || this.getInteracting() || opt_forceMoving;\n // compute rotation\n var newRotation = this.constraints_.rotation(this.targetRotation_, isMoving);\n var size = this.getViewportSize_(newRotation);\n var newResolution = this.constraints_.resolution(this.targetResolution_, 0, size, isMoving);\n var newCenter = this.constraints_.center(this.targetCenter_, newResolution, size, isMoving, this.calculateCenterShift(this.targetCenter_, newResolution, newRotation, size));\n if (this.get(ViewProperty.ROTATION) !== newRotation) {\n this.set(ViewProperty.ROTATION, newRotation);\n }\n if (this.get(ViewProperty.RESOLUTION) !== newResolution) {\n this.set(ViewProperty.RESOLUTION, newResolution);\n }\n if (!this.get(ViewProperty.CENTER) ||\n !equals(this.get(ViewProperty.CENTER), newCenter)) {\n this.set(ViewProperty.CENTER, newCenter);\n }\n if (this.getAnimating() && !opt_doNotCancelAnims) {\n this.cancelAnimations();\n }\n this.cancelAnchor_ = undefined;\n };\n /**\n * If any constraints need to be applied, an animation will be triggered.\n * This is typically done on interaction end.\n * Note: calling this with a duration of 0 will apply the constrained values straight away,\n * without animation.\n * @param {number} [opt_duration] The animation duration in ms.\n * @param {number} [opt_resolutionDirection] Which direction to zoom.\n * @param {import(\"./coordinate.js\").Coordinate} [opt_anchor] The origin of the transformation.\n */\n View.prototype.resolveConstraints = function (opt_duration, opt_resolutionDirection, opt_anchor) {\n var duration = opt_duration !== undefined ? opt_duration : 200;\n var direction = opt_resolutionDirection || 0;\n var newRotation = this.constraints_.rotation(this.targetRotation_);\n var size = this.getViewportSize_(newRotation);\n var newResolution = this.constraints_.resolution(this.targetResolution_, direction, size);\n var newCenter = this.constraints_.center(this.targetCenter_, newResolution, size, false, this.calculateCenterShift(this.targetCenter_, newResolution, newRotation, size));\n if (duration === 0 && !this.cancelAnchor_) {\n this.targetResolution_ = newResolution;\n this.targetRotation_ = newRotation;\n this.targetCenter_ = newCenter;\n this.applyTargetState_();\n return;\n }\n var anchor = opt_anchor || (duration === 0 ? this.cancelAnchor_ : undefined);\n this.cancelAnchor_ = undefined;\n if (this.getResolution() !== newResolution ||\n this.getRotation() !== newRotation ||\n !this.getCenterInternal() ||\n !equals(this.getCenterInternal(), newCenter)) {\n if (this.getAnimating()) {\n this.cancelAnimations();\n }\n this.animateInternal({\n rotation: newRotation,\n center: newCenter,\n resolution: newResolution,\n duration: duration,\n easing: easeOut,\n anchor: anchor,\n });\n }\n };\n /**\n * Notify the View that an interaction has started.\n * The view state will be resolved to a stable one if needed\n * (depending on its constraints).\n * @api\n */\n View.prototype.beginInteraction = function () {\n this.resolveConstraints(0);\n this.setHint(ViewHint.INTERACTING, 1);\n };\n /**\n * Notify the View that an interaction has ended. The view state will be resolved\n * to a stable one if needed (depending on its constraints).\n * @param {number} [opt_duration] Animation duration in ms.\n * @param {number} [opt_resolutionDirection] Which direction to zoom.\n * @param {import(\"./coordinate.js\").Coordinate} [opt_anchor] The origin of the transformation.\n * @api\n */\n View.prototype.endInteraction = function (opt_duration, opt_resolutionDirection, opt_anchor) {\n var anchor = opt_anchor && fromUserCoordinate(opt_anchor, this.getProjection());\n this.endInteractionInternal(opt_duration, opt_resolutionDirection, anchor);\n };\n /**\n * Notify the View that an interaction has ended. The view state will be resolved\n * to a stable one if needed (depending on its constraints).\n * @param {number} [opt_duration] Animation duration in ms.\n * @param {number} [opt_resolutionDirection] Which direction to zoom.\n * @param {import(\"./coordinate.js\").Coordinate} [opt_anchor] The origin of the transformation.\n */\n View.prototype.endInteractionInternal = function (opt_duration, opt_resolutionDirection, opt_anchor) {\n this.setHint(ViewHint.INTERACTING, -1);\n this.resolveConstraints(opt_duration, opt_resolutionDirection, opt_anchor);\n };\n /**\n * Get a valid position for the view center according to the current constraints.\n * @param {import(\"./coordinate.js\").Coordinate|undefined} targetCenter Target center position.\n * @param {number} [opt_targetResolution] Target resolution. If not supplied, the current one will be used.\n * This is useful to guess a valid center position at a different zoom level.\n * @return {import(\"./coordinate.js\").Coordinate|undefined} Valid center position.\n */\n View.prototype.getConstrainedCenter = function (targetCenter, opt_targetResolution) {\n var size = this.getViewportSize_(this.getRotation());\n return this.constraints_.center(targetCenter, opt_targetResolution || this.getResolution(), size);\n };\n /**\n * Get a valid zoom level according to the current view constraints.\n * @param {number|undefined} targetZoom Target zoom.\n * @param {number} [opt_direction=0] Indicate which resolution should be used\n * by a renderer if the view resolution does not match any resolution of the tile source.\n * If 0, the nearest resolution will be used. If 1, the nearest lower resolution\n * will be used. If -1, the nearest higher resolution will be used.\n * @return {number|undefined} Valid zoom level.\n */\n View.prototype.getConstrainedZoom = function (targetZoom, opt_direction) {\n var targetRes = this.getResolutionForZoom(targetZoom);\n return this.getZoomForResolution(this.getConstrainedResolution(targetRes, opt_direction));\n };\n /**\n * Get a valid resolution according to the current view constraints.\n * @param {number|undefined} targetResolution Target resolution.\n * @param {number} [opt_direction=0] Indicate which resolution should be used\n * by a renderer if the view resolution does not match any resolution of the tile source.\n * If 0, the nearest resolution will be used. If 1, the nearest lower resolution\n * will be used. If -1, the nearest higher resolution will be used.\n * @return {number|undefined} Valid resolution.\n */\n View.prototype.getConstrainedResolution = function (targetResolution, opt_direction) {\n var direction = opt_direction || 0;\n var size = this.getViewportSize_(this.getRotation());\n return this.constraints_.resolution(targetResolution, direction, size);\n };\n return View;\n}(BaseObject));\n/**\n * @param {Function} callback Callback.\n * @param {*} returnValue Return value.\n */\nfunction animationCallback(callback, returnValue) {\n setTimeout(function () {\n callback(returnValue);\n }, 0);\n}\n/**\n * @param {ViewOptions} options View options.\n * @return {import(\"./centerconstraint.js\").Type} The constraint.\n */\nexport function createCenterConstraint(options) {\n if (options.extent !== undefined) {\n var smooth = options.smoothExtentConstraint !== undefined\n ? options.smoothExtentConstraint\n : true;\n return createExtent(options.extent, options.constrainOnlyCenter, smooth);\n }\n var projection = createProjection(options.projection, 'EPSG:3857');\n if (options.multiWorld !== true && projection.isGlobal()) {\n var extent = projection.getExtent().slice();\n extent[0] = -Infinity;\n extent[2] = Infinity;\n return createExtent(extent, false, false);\n }\n return centerNone;\n}\n/**\n * @param {ViewOptions} options View options.\n * @return {{constraint: import(\"./resolutionconstraint.js\").Type, maxResolution: number,\n * minResolution: number, minZoom: number, zoomFactor: number}} The constraint.\n */\nexport function createResolutionConstraint(options) {\n var resolutionConstraint;\n var maxResolution;\n var minResolution;\n // TODO: move these to be ol constants\n // see https://github.com/openlayers/openlayers/issues/2076\n var defaultMaxZoom = 28;\n var defaultZoomFactor = 2;\n var minZoom = options.minZoom !== undefined ? options.minZoom : DEFAULT_MIN_ZOOM;\n var maxZoom = options.maxZoom !== undefined ? options.maxZoom : defaultMaxZoom;\n var zoomFactor = options.zoomFactor !== undefined ? options.zoomFactor : defaultZoomFactor;\n var multiWorld = options.multiWorld !== undefined ? options.multiWorld : false;\n var smooth = options.smoothResolutionConstraint !== undefined\n ? options.smoothResolutionConstraint\n : true;\n var showFullExtent = options.showFullExtent !== undefined ? options.showFullExtent : false;\n var projection = createProjection(options.projection, 'EPSG:3857');\n var projExtent = projection.getExtent();\n var constrainOnlyCenter = options.constrainOnlyCenter;\n var extent = options.extent;\n if (!multiWorld && !extent && projection.isGlobal()) {\n constrainOnlyCenter = false;\n extent = projExtent;\n }\n if (options.resolutions !== undefined) {\n var resolutions = options.resolutions;\n maxResolution = resolutions[minZoom];\n minResolution =\n resolutions[maxZoom] !== undefined\n ? resolutions[maxZoom]\n : resolutions[resolutions.length - 1];\n if (options.constrainResolution) {\n resolutionConstraint = createSnapToResolutions(resolutions, smooth, !constrainOnlyCenter && extent, showFullExtent);\n }\n else {\n resolutionConstraint = createMinMaxResolution(maxResolution, minResolution, smooth, !constrainOnlyCenter && extent, showFullExtent);\n }\n }\n else {\n // calculate the default min and max resolution\n var size = !projExtent\n ? // use an extent that can fit the whole world if need be\n (360 * METERS_PER_UNIT[Units.DEGREES]) / projection.getMetersPerUnit()\n : Math.max(getWidth(projExtent), getHeight(projExtent));\n var defaultMaxResolution = size / DEFAULT_TILE_SIZE / Math.pow(defaultZoomFactor, DEFAULT_MIN_ZOOM);\n var defaultMinResolution = defaultMaxResolution /\n Math.pow(defaultZoomFactor, defaultMaxZoom - DEFAULT_MIN_ZOOM);\n // user provided maxResolution takes precedence\n maxResolution = options.maxResolution;\n if (maxResolution !== undefined) {\n minZoom = 0;\n }\n else {\n maxResolution = defaultMaxResolution / Math.pow(zoomFactor, minZoom);\n }\n // user provided minResolution takes precedence\n minResolution = options.minResolution;\n if (minResolution === undefined) {\n if (options.maxZoom !== undefined) {\n if (options.maxResolution !== undefined) {\n minResolution = maxResolution / Math.pow(zoomFactor, maxZoom);\n }\n else {\n minResolution = defaultMaxResolution / Math.pow(zoomFactor, maxZoom);\n }\n }\n else {\n minResolution = defaultMinResolution;\n }\n }\n // given discrete zoom levels, minResolution may be different than provided\n maxZoom =\n minZoom +\n Math.floor(Math.log(maxResolution / minResolution) / Math.log(zoomFactor));\n minResolution = maxResolution / Math.pow(zoomFactor, maxZoom - minZoom);\n if (options.constrainResolution) {\n resolutionConstraint = createSnapToPower(zoomFactor, maxResolution, minResolution, smooth, !constrainOnlyCenter && extent, showFullExtent);\n }\n else {\n resolutionConstraint = createMinMaxResolution(maxResolution, minResolution, smooth, !constrainOnlyCenter && extent, showFullExtent);\n }\n }\n return {\n constraint: resolutionConstraint,\n maxResolution: maxResolution,\n minResolution: minResolution,\n minZoom: minZoom,\n zoomFactor: zoomFactor,\n };\n}\n/**\n * @param {ViewOptions} options View options.\n * @return {import(\"./rotationconstraint.js\").Type} Rotation constraint.\n */\nexport function createRotationConstraint(options) {\n var enableRotation = options.enableRotation !== undefined ? options.enableRotation : true;\n if (enableRotation) {\n var constrainRotation = options.constrainRotation;\n if (constrainRotation === undefined || constrainRotation === true) {\n return createSnapToZero();\n }\n else if (constrainRotation === false) {\n return rotationNone;\n }\n else if (typeof constrainRotation === 'number') {\n return createSnapToN(constrainRotation);\n }\n else {\n return rotationNone;\n }\n }\n else {\n return disable;\n }\n}\n/**\n * Determine if an animation involves no view change.\n * @param {Animation} animation The animation.\n * @return {boolean} The animation involves no view change.\n */\nexport function isNoopAnimation(animation) {\n if (animation.sourceCenter && animation.targetCenter) {\n if (!coordinatesEqual(animation.sourceCenter, animation.targetCenter)) {\n return false;\n }\n }\n if (animation.sourceResolution !== animation.targetResolution) {\n return false;\n }\n if (animation.sourceRotation !== animation.targetRotation) {\n return false;\n }\n return true;\n}\n/**\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {import(\"./size.js\").Size} size Box pixel size.\n * @param {import(\"./pixel.js\").Pixel} position Position on the view to center on.\n * @param {number} resolution Resolution.\n * @param {number} rotation Rotation.\n * @return {import(\"./coordinate.js\").Coordinate} Shifted center.\n */\nfunction calculateCenterOn(coordinate, size, position, resolution, rotation) {\n // calculate rotated position\n var cosAngle = Math.cos(-rotation);\n var sinAngle = Math.sin(-rotation);\n var rotX = coordinate[0] * cosAngle - coordinate[1] * sinAngle;\n var rotY = coordinate[1] * cosAngle + coordinate[0] * sinAngle;\n rotX += (size[0] / 2 - position[0]) * resolution;\n rotY += (position[1] - size[1] / 2) * resolution;\n // go back to original angle\n sinAngle = -sinAngle; // go back to original rotation\n var centerX = rotX * cosAngle - rotY * sinAngle;\n var centerY = rotY * cosAngle + rotX * sinAngle;\n return [centerX, centerY];\n}\nexport default View;\n//# sourceMappingURL=View.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/PluggableMap\n */\nimport BaseObject from './Object.js';\nimport Collection from './Collection.js';\nimport CollectionEventType from './CollectionEventType.js';\nimport EventType from './events/EventType.js';\nimport LayerGroup from './layer/Group.js';\nimport MapBrowserEvent from './MapBrowserEvent.js';\nimport MapBrowserEventHandler from './MapBrowserEventHandler.js';\nimport MapBrowserEventType from './MapBrowserEventType.js';\nimport MapEvent from './MapEvent.js';\nimport MapEventType from './MapEventType.js';\nimport MapProperty from './MapProperty.js';\nimport ObjectEventType from './ObjectEventType.js';\nimport PointerEventType from './pointer/EventType.js';\nimport RenderEventType from './render/EventType.js';\nimport TileQueue, { getTilePriority } from './TileQueue.js';\nimport View from './View.js';\nimport ViewHint from './ViewHint.js';\nimport { DEVICE_PIXEL_RATIO, PASSIVE_EVENT_LISTENERS } from './has.js';\nimport { TRUE } from './functions.js';\nimport { apply as applyTransform, create as createTransform, } from './transform.js';\nimport { assert } from './asserts.js';\nimport { clone, createOrUpdateEmpty, equals, getForViewAndSize, isEmpty, } from './extent.js';\nimport { fromUserCoordinate, toUserCoordinate } from './proj.js';\nimport { hasArea } from './size.js';\nimport { listen, unlistenByKey } from './events.js';\nimport { removeNode } from './dom.js';\n/**\n * State of the current frame. Only `pixelRatio`, `time` and `viewState` should\n * be used in applications.\n * @typedef {Object} FrameState\n * @property {number} pixelRatio The pixel ratio of the frame.\n * @property {number} time The time when rendering of the frame was requested.\n * @property {import(\"./View.js\").State} viewState The state of the current view.\n * @property {boolean} animate Animate.\n * @property {import(\"./transform.js\").Transform} coordinateToPixelTransform CoordinateToPixelTransform.\n * @property {import(\"rbush\").default} declutterTree DeclutterTree.\n * @property {null|import(\"./extent.js\").Extent} extent Extent.\n * @property {import(\"./extent.js\").Extent} [nextExtent] Next extent during an animation series.\n * @property {number} index Index.\n * @property {Array<import(\"./layer/Layer.js\").State>} layerStatesArray LayerStatesArray.\n * @property {number} layerIndex LayerIndex.\n * @property {import(\"./transform.js\").Transform} pixelToCoordinateTransform PixelToCoordinateTransform.\n * @property {Array<PostRenderFunction>} postRenderFunctions PostRenderFunctions.\n * @property {import(\"./size.js\").Size} size Size.\n * @property {TileQueue} tileQueue TileQueue.\n * @property {!Object<string, Object<string, boolean>>} usedTiles UsedTiles.\n * @property {Array<number>} viewHints ViewHints.\n * @property {!Object<string, Object<string, boolean>>} wantedTiles WantedTiles.\n */\n/**\n * @typedef {function(PluggableMap, ?FrameState): any} PostRenderFunction\n */\n/**\n * @typedef {Object} AtPixelOptions\n * @property {undefined|function(import(\"./layer/Layer.js\").default<import(\"./source/Source\").default>): boolean} [layerFilter] Layer filter\n * function. The filter function will receive one argument, the\n * {@link module:ol/layer/Layer layer-candidate} and it should return a boolean value.\n * Only layers which are visible and for which this function returns `true`\n * will be tested for features. By default, all visible layers will be tested.\n * @property {number} [hitTolerance=0] Hit-detection tolerance in css pixels. Pixels\n * inside the radius around the given position will be checked for features.\n * @property {boolean} [checkWrapped=true] Check-Wrapped Will check for for wrapped geometries inside the range of\n * +/- 1 world width. Works only if a projection is used that can be wrapped.\n */\n/**\n * @typedef {Object} MapOptionsInternal\n * @property {Collection<import(\"./control/Control.js\").default>} [controls] Controls.\n * @property {Collection<import(\"./interaction/Interaction.js\").default>} [interactions] Interactions.\n * @property {HTMLElement|Document} keyboardEventTarget KeyboardEventTarget.\n * @property {Collection<import(\"./Overlay.js\").default>} overlays Overlays.\n * @property {Object<string, *>} values Values.\n */\n/**\n * @typedef {import(\"./ObjectEventType\").Types|'change:layergroup'|'change:size'|'change:target'|'change:view'} MapObjectEventTypes\n */\n/***\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature<import(\"./Observable\").EventTypes, import(\"./events/Event.js\").default, Return> &\n * import(\"./Observable\").OnSignature<MapObjectEventTypes, import(\"./Object\").ObjectEvent, Return> &\n * import(\"./Observable\").OnSignature<import(\"./MapBrowserEventType\").Types, import(\"./MapBrowserEvent\").default, Return> &\n * import(\"./Observable\").OnSignature<import(\"./MapEventType\").Types, import(\"./MapEvent\").default, Return> &\n * import(\"./Observable\").OnSignature<import(\"./render/EventType\").MapRenderEventTypes, import(\"./render/Event\").default, Return> &\n * import(\"./Observable\").CombinedOnSignature<import(\"./Observable\").EventTypes|MapObjectEventTypes|\n * import(\"./MapBrowserEventType\").Types|import(\"./MapEventType\").Types|\n * import(\"./render/EventType\").MapRenderEventTypes, Return>} PluggableMapOnSignature\n */\n/**\n * Object literal with config options for the map.\n * @typedef {Object} MapOptions\n * @property {Collection<import(\"./control/Control.js\").default>|Array<import(\"./control/Control.js\").default>} [controls]\n * Controls initially added to the map. If not specified,\n * {@link module:ol/control.defaults} is used.\n * @property {number} [pixelRatio=window.devicePixelRatio] The ratio between\n * physical pixels and device-independent pixels (dips) on the device.\n * @property {Collection<import(\"./interaction/Interaction.js\").default>|Array<import(\"./interaction/Interaction.js\").default>} [interactions]\n * Interactions that are initially added to the map. If not specified,\n * {@link module:ol/interaction.defaults} is used.\n * @property {HTMLElement|Document|string} [keyboardEventTarget] The element to\n * listen to keyboard events on. This determines when the `KeyboardPan` and\n * `KeyboardZoom` interactions trigger. For example, if this option is set to\n * `document` the keyboard interactions will always trigger. If this option is\n * not specified, the element the library listens to keyboard events on is the\n * map target (i.e. the user-provided div for the map). If this is not\n * `document`, the target element needs to be focused for key events to be\n * emitted, requiring that the target element has a `tabindex` attribute.\n * @property {Array<import(\"./layer/Base.js\").default>|Collection<import(\"./layer/Base.js\").default>|LayerGroup} [layers]\n * Layers. If this is not defined, a map with no layers will be rendered. Note\n * that layers are rendered in the order supplied, so if you want, for example,\n * a vector layer to appear on top of a tile layer, it must come after the tile\n * layer.\n * @property {number} [maxTilesLoading=16] Maximum number tiles to load\n * simultaneously.\n * @property {number} [moveTolerance=1] The minimum distance in pixels the\n * cursor must move to be detected as a map move event instead of a click.\n * Increasing this value can make it easier to click on the map.\n * @property {Collection<import(\"./Overlay.js\").default>|Array<import(\"./Overlay.js\").default>} [overlays]\n * Overlays initially added to the map. By default, no overlays are added.\n * @property {HTMLElement|string} [target] The container for the map, either the\n * element itself or the `id` of the element. If not specified at construction\n * time, {@link module:ol/Map~Map#setTarget} must be called for the map to be\n * rendered. If passed by element, the container can be in a secondary document.\n * @property {View|Promise<import(\"./View.js\").ViewOptions>} [view] The map's view. No layer sources will be\n * fetched unless this is specified at construction time or through\n * {@link module:ol/Map~Map#setView}.\n */\n/**\n * @fires import(\"./MapBrowserEvent.js\").MapBrowserEvent\n * @fires import(\"./MapEvent.js\").MapEvent\n * @fires import(\"./render/Event.js\").default#precompose\n * @fires import(\"./render/Event.js\").default#postcompose\n * @fires import(\"./render/Event.js\").default#rendercomplete\n * @api\n */\nvar PluggableMap = /** @class */ (function (_super) {\n __extends(PluggableMap, _super);\n /**\n * @param {MapOptions} options Map options.\n */\n function PluggableMap(options) {\n var _this = _super.call(this) || this;\n /***\n * @type {PluggableMapOnSignature<import(\"./events\").EventsKey>}\n */\n _this.on;\n /***\n * @type {PluggableMapOnSignature<import(\"./events\").EventsKey>}\n */\n _this.once;\n /***\n * @type {PluggableMapOnSignature<void>}\n */\n _this.un;\n var optionsInternal = createOptionsInternal(options);\n /** @private */\n _this.boundHandleBrowserEvent_ = _this.handleBrowserEvent.bind(_this);\n /**\n * @type {number}\n * @private\n */\n _this.maxTilesLoading_ =\n options.maxTilesLoading !== undefined ? options.maxTilesLoading : 16;\n /**\n * @private\n * @type {number}\n */\n _this.pixelRatio_ =\n options.pixelRatio !== undefined\n ? options.pixelRatio\n : DEVICE_PIXEL_RATIO;\n /**\n * @private\n * @type {*}\n */\n _this.postRenderTimeoutHandle_;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.animationDelayKey_;\n /**\n * @private\n */\n _this.animationDelay_ = /** @this {PluggableMap} */ function () {\n this.animationDelayKey_ = undefined;\n this.renderFrame_(Date.now());\n }.bind(_this);\n /**\n * @private\n * @type {import(\"./transform.js\").Transform}\n */\n _this.coordinateToPixelTransform_ = createTransform();\n /**\n * @private\n * @type {import(\"./transform.js\").Transform}\n */\n _this.pixelToCoordinateTransform_ = createTransform();\n /**\n * @private\n * @type {number}\n */\n _this.frameIndex_ = 0;\n /**\n * @private\n * @type {?FrameState}\n */\n _this.frameState_ = null;\n /**\n * The extent at the previous 'moveend' event.\n * @private\n * @type {import(\"./extent.js\").Extent}\n */\n _this.previousExtent_ = null;\n /**\n * @private\n * @type {?import(\"./events.js\").EventsKey}\n */\n _this.viewPropertyListenerKey_ = null;\n /**\n * @private\n * @type {?import(\"./events.js\").EventsKey}\n */\n _this.viewChangeListenerKey_ = null;\n /**\n * @private\n * @type {?Array<import(\"./events.js\").EventsKey>}\n */\n _this.layerGroupPropertyListenerKeys_ = null;\n /**\n * @private\n * @type {!HTMLElement}\n */\n _this.viewport_ = document.createElement('div');\n _this.viewport_.className =\n 'ol-viewport' + ('ontouchstart' in window ? ' ol-touch' : '');\n _this.viewport_.style.position = 'relative';\n _this.viewport_.style.overflow = 'hidden';\n _this.viewport_.style.width = '100%';\n _this.viewport_.style.height = '100%';\n /**\n * @private\n * @type {!HTMLElement}\n */\n _this.overlayContainer_ = document.createElement('div');\n _this.overlayContainer_.style.position = 'absolute';\n _this.overlayContainer_.style.zIndex = '0';\n _this.overlayContainer_.style.width = '100%';\n _this.overlayContainer_.style.height = '100%';\n _this.overlayContainer_.style.pointerEvents = 'none';\n _this.overlayContainer_.className = 'ol-overlaycontainer';\n _this.viewport_.appendChild(_this.overlayContainer_);\n /**\n * @private\n * @type {!HTMLElement}\n */\n _this.overlayContainerStopEvent_ = document.createElement('div');\n _this.overlayContainerStopEvent_.style.position = 'absolute';\n _this.overlayContainerStopEvent_.style.zIndex = '0';\n _this.overlayContainerStopEvent_.style.width = '100%';\n _this.overlayContainerStopEvent_.style.height = '100%';\n _this.overlayContainerStopEvent_.style.pointerEvents = 'none';\n _this.overlayContainerStopEvent_.className = 'ol-overlaycontainer-stopevent';\n _this.viewport_.appendChild(_this.overlayContainerStopEvent_);\n /**\n * @private\n * @type {MapBrowserEventHandler}\n */\n _this.mapBrowserEventHandler_ = null;\n /**\n * @private\n * @type {number}\n */\n _this.moveTolerance_ = options.moveTolerance;\n /**\n * @private\n * @type {HTMLElement|Document}\n */\n _this.keyboardEventTarget_ = optionsInternal.keyboardEventTarget;\n /**\n * @private\n * @type {?Array<import(\"./events.js\").EventsKey>}\n */\n _this.keyHandlerKeys_ = null;\n /**\n * @type {Collection<import(\"./control/Control.js\").default>}\n * @protected\n */\n _this.controls = optionsInternal.controls || new Collection();\n /**\n * @type {Collection<import(\"./interaction/Interaction.js\").default>}\n * @protected\n */\n _this.interactions = optionsInternal.interactions || new Collection();\n /**\n * @type {Collection<import(\"./Overlay.js\").default>}\n * @private\n */\n _this.overlays_ = optionsInternal.overlays;\n /**\n * A lookup of overlays by id.\n * @private\n * @type {Object<string, import(\"./Overlay.js\").default>}\n */\n _this.overlayIdIndex_ = {};\n /**\n * @type {import(\"./renderer/Map.js\").default}\n * @private\n */\n _this.renderer_ = null;\n /**\n * @type {undefined|function(Event): void}\n * @private\n */\n _this.handleResize_;\n /**\n * @private\n * @type {!Array<PostRenderFunction>}\n */\n _this.postRenderFunctions_ = [];\n /**\n * @private\n * @type {TileQueue}\n */\n _this.tileQueue_ = new TileQueue(_this.getTilePriority.bind(_this), _this.handleTileChange_.bind(_this));\n _this.addChangeListener(MapProperty.LAYERGROUP, _this.handleLayerGroupChanged_);\n _this.addChangeListener(MapProperty.VIEW, _this.handleViewChanged_);\n _this.addChangeListener(MapProperty.SIZE, _this.handleSizeChanged_);\n _this.addChangeListener(MapProperty.TARGET, _this.handleTargetChanged_);\n // setProperties will trigger the rendering of the map if the map\n // is \"defined\" already.\n _this.setProperties(optionsInternal.values);\n var map = _this;\n if (options.view && !(options.view instanceof View)) {\n options.view.then(function (viewOptions) {\n map.setView(new View(viewOptions));\n });\n }\n _this.controls.addEventListener(CollectionEventType.ADD, \n /**\n * @param {import(\"./Collection.js\").CollectionEvent} event CollectionEvent.\n */\n function (event) {\n event.element.setMap(this);\n }.bind(_this));\n _this.controls.addEventListener(CollectionEventType.REMOVE, \n /**\n * @param {import(\"./Collection.js\").CollectionEvent} event CollectionEvent.\n */\n function (event) {\n event.element.setMap(null);\n }.bind(_this));\n _this.interactions.addEventListener(CollectionEventType.ADD, \n /**\n * @param {import(\"./Collection.js\").CollectionEvent} event CollectionEvent.\n */\n function (event) {\n event.element.setMap(this);\n }.bind(_this));\n _this.interactions.addEventListener(CollectionEventType.REMOVE, \n /**\n * @param {import(\"./Collection.js\").CollectionEvent} event CollectionEvent.\n */\n function (event) {\n event.element.setMap(null);\n }.bind(_this));\n _this.overlays_.addEventListener(CollectionEventType.ADD, \n /**\n * @param {import(\"./Collection.js\").CollectionEvent} event CollectionEvent.\n */\n function (event) {\n this.addOverlayInternal_(\n /** @type {import(\"./Overlay.js\").default} */ (event.element));\n }.bind(_this));\n _this.overlays_.addEventListener(CollectionEventType.REMOVE, \n /**\n * @param {import(\"./Collection.js\").CollectionEvent} event CollectionEvent.\n */\n function (event) {\n var overlay = /** @type {import(\"./Overlay.js\").default} */ (event.element);\n var id = overlay.getId();\n if (id !== undefined) {\n delete this.overlayIdIndex_[id.toString()];\n }\n event.element.setMap(null);\n }.bind(_this));\n _this.controls.forEach(\n /**\n * @param {import(\"./control/Control.js\").default} control Control.\n * @this {PluggableMap}\n */\n function (control) {\n control.setMap(this);\n }.bind(_this));\n _this.interactions.forEach(\n /**\n * @param {import(\"./interaction/Interaction.js\").default} interaction Interaction.\n * @this {PluggableMap}\n */\n function (interaction) {\n interaction.setMap(this);\n }.bind(_this));\n _this.overlays_.forEach(_this.addOverlayInternal_.bind(_this));\n return _this;\n }\n /**\n * @abstract\n * @return {import(\"./renderer/Map.js\").default} The map renderer\n */\n PluggableMap.prototype.createRenderer = function () {\n throw new Error('Use a map type that has a createRenderer method');\n };\n /**\n * Add the given control to the map.\n * @param {import(\"./control/Control.js\").default} control Control.\n * @api\n */\n PluggableMap.prototype.addControl = function (control) {\n this.getControls().push(control);\n };\n /**\n * Add the given interaction to the map. If you want to add an interaction\n * at another point of the collection use `getInteraction()` and the methods\n * available on {@link module:ol/Collection~Collection}. This can be used to\n * stop the event propagation from the handleEvent function. The interactions\n * get to handle the events in the reverse order of this collection.\n * @param {import(\"./interaction/Interaction.js\").default} interaction Interaction to add.\n * @api\n */\n PluggableMap.prototype.addInteraction = function (interaction) {\n this.getInteractions().push(interaction);\n };\n /**\n * Adds the given layer to the top of this map. If you want to add a layer\n * elsewhere in the stack, use `getLayers()` and the methods available on\n * {@link module:ol/Collection~Collection}.\n * @param {import(\"./layer/Base.js\").default} layer Layer.\n * @api\n */\n PluggableMap.prototype.addLayer = function (layer) {\n var layers = this.getLayerGroup().getLayers();\n layers.push(layer);\n };\n /**\n * Add the given overlay to the map.\n * @param {import(\"./Overlay.js\").default} overlay Overlay.\n * @api\n */\n PluggableMap.prototype.addOverlay = function (overlay) {\n this.getOverlays().push(overlay);\n };\n /**\n * This deals with map's overlay collection changes.\n * @param {import(\"./Overlay.js\").default} overlay Overlay.\n * @private\n */\n PluggableMap.prototype.addOverlayInternal_ = function (overlay) {\n var id = overlay.getId();\n if (id !== undefined) {\n this.overlayIdIndex_[id.toString()] = overlay;\n }\n overlay.setMap(this);\n };\n /**\n *\n * Clean up.\n */\n PluggableMap.prototype.disposeInternal = function () {\n this.setTarget(null);\n _super.prototype.disposeInternal.call(this);\n };\n /**\n * Detect features that intersect a pixel on the viewport, and execute a\n * callback with each intersecting feature. Layers included in the detection can\n * be configured through the `layerFilter` option in `opt_options`.\n * @param {import(\"./pixel.js\").Pixel} pixel Pixel.\n * @param {function(import(\"./Feature.js\").FeatureLike, import(\"./layer/Layer.js\").default<import(\"./source/Source\").default>, import(\"./geom/SimpleGeometry.js\").default): T} callback Feature callback. The callback will be\n * called with two arguments. The first argument is one\n * {@link module:ol/Feature feature} or\n * {@link module:ol/render/Feature render feature} at the pixel, the second is\n * the {@link module:ol/layer/Layer layer} of the feature and will be null for\n * unmanaged layers. To stop detection, callback functions can return a\n * truthy value.\n * @param {AtPixelOptions} [opt_options] Optional options.\n * @return {T|undefined} Callback result, i.e. the return value of last\n * callback execution, or the first truthy callback return value.\n * @template T\n * @api\n */\n PluggableMap.prototype.forEachFeatureAtPixel = function (pixel, callback, opt_options) {\n if (!this.frameState_) {\n return;\n }\n var coordinate = this.getCoordinateFromPixelInternal(pixel);\n opt_options = opt_options !== undefined ? opt_options : {};\n var hitTolerance = opt_options.hitTolerance !== undefined ? opt_options.hitTolerance : 0;\n var layerFilter = opt_options.layerFilter !== undefined ? opt_options.layerFilter : TRUE;\n var checkWrapped = opt_options.checkWrapped !== false;\n return this.renderer_.forEachFeatureAtCoordinate(coordinate, this.frameState_, hitTolerance, checkWrapped, callback, null, layerFilter, null);\n };\n /**\n * Get all features that intersect a pixel on the viewport.\n * @param {import(\"./pixel.js\").Pixel} pixel Pixel.\n * @param {AtPixelOptions} [opt_options] Optional options.\n * @return {Array<import(\"./Feature.js\").FeatureLike>} The detected features or\n * an empty array if none were found.\n * @api\n */\n PluggableMap.prototype.getFeaturesAtPixel = function (pixel, opt_options) {\n var features = [];\n this.forEachFeatureAtPixel(pixel, function (feature) {\n features.push(feature);\n }, opt_options);\n return features;\n };\n /**\n * Detect layers that have a color value at a pixel on the viewport, and\n * execute a callback with each matching layer. Layers included in the\n * detection can be configured through `opt_layerFilter`.\n *\n * Note: this may give false positives unless the map layers have had different `className`\n * properties assigned to them.\n *\n * @param {import(\"./pixel.js\").Pixel} pixel Pixel.\n * @param {function(this: S, import(\"./layer/Layer.js\").default, (Uint8ClampedArray|Uint8Array)): T} callback\n * Layer callback. This callback will receive two arguments: first is the\n * {@link module:ol/layer/Layer layer}, second argument is an array representing\n * [R, G, B, A] pixel values (0 - 255) and will be `null` for layer types\n * that do not currently support this argument. To stop detection, callback\n * functions can return a truthy value.\n * @param {AtPixelOptions} [opt_options] Configuration options.\n * @return {T|undefined} Callback result, i.e. the return value of last\n * callback execution, or the first truthy callback return value.\n * @template S,T\n * @api\n */\n PluggableMap.prototype.forEachLayerAtPixel = function (pixel, callback, opt_options) {\n if (!this.frameState_) {\n return;\n }\n var options = opt_options || {};\n var hitTolerance = options.hitTolerance !== undefined ? options.hitTolerance : 0;\n var layerFilter = options.layerFilter || TRUE;\n return this.renderer_.forEachLayerAtPixel(pixel, this.frameState_, hitTolerance, callback, layerFilter);\n };\n /**\n * Detect if features intersect a pixel on the viewport. Layers included in the\n * detection can be configured through `opt_layerFilter`.\n * @param {import(\"./pixel.js\").Pixel} pixel Pixel.\n * @param {AtPixelOptions} [opt_options] Optional options.\n * @return {boolean} Is there a feature at the given pixel?\n * @api\n */\n PluggableMap.prototype.hasFeatureAtPixel = function (pixel, opt_options) {\n if (!this.frameState_) {\n return false;\n }\n var coordinate = this.getCoordinateFromPixelInternal(pixel);\n opt_options = opt_options !== undefined ? opt_options : {};\n var layerFilter = opt_options.layerFilter !== undefined ? opt_options.layerFilter : TRUE;\n var hitTolerance = opt_options.hitTolerance !== undefined ? opt_options.hitTolerance : 0;\n var checkWrapped = opt_options.checkWrapped !== false;\n return this.renderer_.hasFeatureAtCoordinate(coordinate, this.frameState_, hitTolerance, checkWrapped, layerFilter, null);\n };\n /**\n * Returns the coordinate in user projection for a browser event.\n * @param {MouseEvent} event Event.\n * @return {import(\"./coordinate.js\").Coordinate} Coordinate.\n * @api\n */\n PluggableMap.prototype.getEventCoordinate = function (event) {\n return this.getCoordinateFromPixel(this.getEventPixel(event));\n };\n /**\n * Returns the coordinate in view projection for a browser event.\n * @param {MouseEvent} event Event.\n * @return {import(\"./coordinate.js\").Coordinate} Coordinate.\n */\n PluggableMap.prototype.getEventCoordinateInternal = function (event) {\n return this.getCoordinateFromPixelInternal(this.getEventPixel(event));\n };\n /**\n * Returns the map pixel position for a browser event relative to the viewport.\n * @param {UIEvent} event Event.\n * @return {import(\"./pixel.js\").Pixel} Pixel.\n * @api\n */\n PluggableMap.prototype.getEventPixel = function (event) {\n var viewportPosition = this.viewport_.getBoundingClientRect();\n var eventPosition = \n //FIXME Are we really calling this with a TouchEvent anywhere?\n 'changedTouches' in event\n ? /** @type {TouchEvent} */ (event).changedTouches[0]\n : /** @type {MouseEvent} */ (event);\n return [\n eventPosition.clientX - viewportPosition.left,\n eventPosition.clientY - viewportPosition.top,\n ];\n };\n /**\n * Get the target in which this map is rendered.\n * Note that this returns what is entered as an option or in setTarget:\n * if that was an element, it returns an element; if a string, it returns that.\n * @return {HTMLElement|string|undefined} The Element or id of the Element that the\n * map is rendered in.\n * @observable\n * @api\n */\n PluggableMap.prototype.getTarget = function () {\n return /** @type {HTMLElement|string|undefined} */ (this.get(MapProperty.TARGET));\n };\n /**\n * Get the DOM element into which this map is rendered. In contrast to\n * `getTarget` this method always return an `Element`, or `null` if the\n * map has no target.\n * @return {HTMLElement} The element that the map is rendered in.\n * @api\n */\n PluggableMap.prototype.getTargetElement = function () {\n var target = this.getTarget();\n if (target !== undefined) {\n return typeof target === 'string'\n ? document.getElementById(target)\n : target;\n }\n else {\n return null;\n }\n };\n /**\n * Get the coordinate for a given pixel. This returns a coordinate in the\n * user projection.\n * @param {import(\"./pixel.js\").Pixel} pixel Pixel position in the map viewport.\n * @return {import(\"./coordinate.js\").Coordinate} The coordinate for the pixel position.\n * @api\n */\n PluggableMap.prototype.getCoordinateFromPixel = function (pixel) {\n return toUserCoordinate(this.getCoordinateFromPixelInternal(pixel), this.getView().getProjection());\n };\n /**\n * Get the coordinate for a given pixel. This returns a coordinate in the\n * map view projection.\n * @param {import(\"./pixel.js\").Pixel} pixel Pixel position in the map viewport.\n * @return {import(\"./coordinate.js\").Coordinate} The coordinate for the pixel position.\n */\n PluggableMap.prototype.getCoordinateFromPixelInternal = function (pixel) {\n var frameState = this.frameState_;\n if (!frameState) {\n return null;\n }\n else {\n return applyTransform(frameState.pixelToCoordinateTransform, pixel.slice());\n }\n };\n /**\n * Get the map controls. Modifying this collection changes the controls\n * associated with the map.\n * @return {Collection<import(\"./control/Control.js\").default>} Controls.\n * @api\n */\n PluggableMap.prototype.getControls = function () {\n return this.controls;\n };\n /**\n * Get the map overlays. Modifying this collection changes the overlays\n * associated with the map.\n * @return {Collection<import(\"./Overlay.js\").default>} Overlays.\n * @api\n */\n PluggableMap.prototype.getOverlays = function () {\n return this.overlays_;\n };\n /**\n * Get an overlay by its identifier (the value returned by overlay.getId()).\n * Note that the index treats string and numeric identifiers as the same. So\n * `map.getOverlayById(2)` will return an overlay with id `'2'` or `2`.\n * @param {string|number} id Overlay identifier.\n * @return {import(\"./Overlay.js\").default} Overlay.\n * @api\n */\n PluggableMap.prototype.getOverlayById = function (id) {\n var overlay = this.overlayIdIndex_[id.toString()];\n return overlay !== undefined ? overlay : null;\n };\n /**\n * Get the map interactions. Modifying this collection changes the interactions\n * associated with the map.\n *\n * Interactions are used for e.g. pan, zoom and rotate.\n * @return {Collection<import(\"./interaction/Interaction.js\").default>} Interactions.\n * @api\n */\n PluggableMap.prototype.getInteractions = function () {\n return this.interactions;\n };\n /**\n * Get the layergroup associated with this map.\n * @return {LayerGroup} A layer group containing the layers in this map.\n * @observable\n * @api\n */\n PluggableMap.prototype.getLayerGroup = function () {\n return /** @type {LayerGroup} */ (this.get(MapProperty.LAYERGROUP));\n };\n /**\n * Clear any existing layers and add layers to the map.\n * @param {Array<import(\"./layer/Base.js\").default>|Collection<import(\"./layer/Base.js\").default>} layers The layers to be added to the map.\n * @api\n */\n PluggableMap.prototype.setLayers = function (layers) {\n var group = this.getLayerGroup();\n if (layers instanceof Collection) {\n group.setLayers(layers);\n return;\n }\n var collection = group.getLayers();\n collection.clear();\n collection.extend(layers);\n };\n /**\n * Get the collection of layers associated with this map.\n * @return {!Collection<import(\"./layer/Base.js\").default>} Layers.\n * @api\n */\n PluggableMap.prototype.getLayers = function () {\n var layers = this.getLayerGroup().getLayers();\n return layers;\n };\n /**\n * @return {boolean} Layers have sources that are still loading.\n */\n PluggableMap.prototype.getLoading = function () {\n var layerStatesArray = this.getLayerGroup().getLayerStatesArray();\n for (var i = 0, ii = layerStatesArray.length; i < ii; ++i) {\n var layer = layerStatesArray[i].layer;\n var source = /** @type {import(\"./layer/Layer.js\").default} */ (layer).getSource();\n if (source && source.loading) {\n return true;\n }\n }\n return false;\n };\n /**\n * Get the pixel for a coordinate. This takes a coordinate in the user\n * projection and returns the corresponding pixel.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate A map coordinate.\n * @return {import(\"./pixel.js\").Pixel} A pixel position in the map viewport.\n * @api\n */\n PluggableMap.prototype.getPixelFromCoordinate = function (coordinate) {\n var viewCoordinate = fromUserCoordinate(coordinate, this.getView().getProjection());\n return this.getPixelFromCoordinateInternal(viewCoordinate);\n };\n /**\n * Get the pixel for a coordinate. This takes a coordinate in the map view\n * projection and returns the corresponding pixel.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate A map coordinate.\n * @return {import(\"./pixel.js\").Pixel} A pixel position in the map viewport.\n */\n PluggableMap.prototype.getPixelFromCoordinateInternal = function (coordinate) {\n var frameState = this.frameState_;\n if (!frameState) {\n return null;\n }\n else {\n return applyTransform(frameState.coordinateToPixelTransform, coordinate.slice(0, 2));\n }\n };\n /**\n * Get the map renderer.\n * @return {import(\"./renderer/Map.js\").default} Renderer\n */\n PluggableMap.prototype.getRenderer = function () {\n return this.renderer_;\n };\n /**\n * Get the size of this map.\n * @return {import(\"./size.js\").Size|undefined} The size in pixels of the map in the DOM.\n * @observable\n * @api\n */\n PluggableMap.prototype.getSize = function () {\n return /** @type {import(\"./size.js\").Size|undefined} */ (this.get(MapProperty.SIZE));\n };\n /**\n * Get the view associated with this map. A view manages properties such as\n * center and resolution.\n * @return {View} The view that controls this map.\n * @observable\n * @api\n */\n PluggableMap.prototype.getView = function () {\n return /** @type {View} */ (this.get(MapProperty.VIEW));\n };\n /**\n * Get the element that serves as the map viewport.\n * @return {HTMLElement} Viewport.\n * @api\n */\n PluggableMap.prototype.getViewport = function () {\n return this.viewport_;\n };\n /**\n * Get the element that serves as the container for overlays. Elements added to\n * this container will let mousedown and touchstart events through to the map,\n * so clicks and gestures on an overlay will trigger {@link module:ol/MapBrowserEvent~MapBrowserEvent}\n * events.\n * @return {!HTMLElement} The map's overlay container.\n */\n PluggableMap.prototype.getOverlayContainer = function () {\n return this.overlayContainer_;\n };\n /**\n * Get the element that serves as a container for overlays that don't allow\n * event propagation. Elements added to this container won't let mousedown and\n * touchstart events through to the map, so clicks and gestures on an overlay\n * don't trigger any {@link module:ol/MapBrowserEvent~MapBrowserEvent}.\n * @return {!HTMLElement} The map's overlay container that stops events.\n */\n PluggableMap.prototype.getOverlayContainerStopEvent = function () {\n return this.overlayContainerStopEvent_;\n };\n /**\n * @return {!Document} The document where the map is displayed.\n */\n PluggableMap.prototype.getOwnerDocument = function () {\n var targetElement = this.getTargetElement();\n return targetElement ? targetElement.ownerDocument : document;\n };\n /**\n * @param {import(\"./Tile.js\").default} tile Tile.\n * @param {string} tileSourceKey Tile source key.\n * @param {import(\"./coordinate.js\").Coordinate} tileCenter Tile center.\n * @param {number} tileResolution Tile resolution.\n * @return {number} Tile priority.\n */\n PluggableMap.prototype.getTilePriority = function (tile, tileSourceKey, tileCenter, tileResolution) {\n return getTilePriority(this.frameState_, tile, tileSourceKey, tileCenter, tileResolution);\n };\n /**\n * @param {UIEvent} browserEvent Browser event.\n * @param {string} [opt_type] Type.\n */\n PluggableMap.prototype.handleBrowserEvent = function (browserEvent, opt_type) {\n var type = opt_type || browserEvent.type;\n var mapBrowserEvent = new MapBrowserEvent(type, this, browserEvent);\n this.handleMapBrowserEvent(mapBrowserEvent);\n };\n /**\n * @param {MapBrowserEvent} mapBrowserEvent The event to handle.\n */\n PluggableMap.prototype.handleMapBrowserEvent = function (mapBrowserEvent) {\n if (!this.frameState_) {\n // With no view defined, we cannot translate pixels into geographical\n // coordinates so interactions cannot be used.\n return;\n }\n var originalEvent = /** @type {PointerEvent} */ (mapBrowserEvent.originalEvent);\n var eventType = originalEvent.type;\n if (eventType === PointerEventType.POINTERDOWN ||\n eventType === EventType.WHEEL ||\n eventType === EventType.KEYDOWN) {\n var doc = this.getOwnerDocument();\n var rootNode = this.viewport_.getRootNode\n ? this.viewport_.getRootNode()\n : doc;\n var target = /** @type {Node} */ (originalEvent.target);\n if (\n // Abort if the target is a child of the container for elements whose events are not meant\n // to be handled by map interactions.\n this.overlayContainerStopEvent_.contains(target) ||\n // Abort if the event target is a child of the container that is no longer in the page.\n // It's possible for the target to no longer be in the page if it has been removed in an\n // event listener, this might happen in a Control that recreates it's content based on\n // user interaction either manually or via a render in something like https://reactjs.org/\n !(rootNode === doc ? doc.documentElement : rootNode).contains(target)) {\n return;\n }\n }\n mapBrowserEvent.frameState = this.frameState_;\n if (this.dispatchEvent(mapBrowserEvent) !== false) {\n var interactionsArray = this.getInteractions().getArray().slice();\n for (var i = interactionsArray.length - 1; i >= 0; i--) {\n var interaction = interactionsArray[i];\n if (interaction.getMap() !== this ||\n !interaction.getActive() ||\n !this.getTargetElement()) {\n continue;\n }\n var cont = interaction.handleEvent(mapBrowserEvent);\n if (!cont || mapBrowserEvent.propagationStopped) {\n break;\n }\n }\n }\n };\n /**\n * @protected\n */\n PluggableMap.prototype.handlePostRender = function () {\n var frameState = this.frameState_;\n // Manage the tile queue\n // Image loads are expensive and a limited resource, so try to use them\n // efficiently:\n // * When the view is static we allow a large number of parallel tile loads\n // to complete the frame as quickly as possible.\n // * When animating or interacting, image loads can cause janks, so we reduce\n // the maximum number of loads per frame and limit the number of parallel\n // tile loads to remain reactive to view changes and to reduce the chance of\n // loading tiles that will quickly disappear from view.\n var tileQueue = this.tileQueue_;\n if (!tileQueue.isEmpty()) {\n var maxTotalLoading = this.maxTilesLoading_;\n var maxNewLoads = maxTotalLoading;\n if (frameState) {\n var hints = frameState.viewHints;\n if (hints[ViewHint.ANIMATING] || hints[ViewHint.INTERACTING]) {\n var lowOnFrameBudget = Date.now() - frameState.time > 8;\n maxTotalLoading = lowOnFrameBudget ? 0 : 8;\n maxNewLoads = lowOnFrameBudget ? 0 : 2;\n }\n }\n if (tileQueue.getTilesLoading() < maxTotalLoading) {\n tileQueue.reprioritize(); // FIXME only call if view has changed\n tileQueue.loadMoreTiles(maxTotalLoading, maxNewLoads);\n }\n }\n if (frameState &&\n this.hasListener(RenderEventType.RENDERCOMPLETE) &&\n !frameState.animate &&\n !this.tileQueue_.getTilesLoading() &&\n !this.getLoading()) {\n this.renderer_.dispatchRenderEvent(RenderEventType.RENDERCOMPLETE, frameState);\n }\n var postRenderFunctions = this.postRenderFunctions_;\n for (var i = 0, ii = postRenderFunctions.length; i < ii; ++i) {\n postRenderFunctions[i](this, frameState);\n }\n postRenderFunctions.length = 0;\n };\n /**\n * @private\n */\n PluggableMap.prototype.handleSizeChanged_ = function () {\n if (this.getView() && !this.getView().getAnimating()) {\n this.getView().resolveConstraints(0);\n }\n this.render();\n };\n /**\n * @private\n */\n PluggableMap.prototype.handleTargetChanged_ = function () {\n // target may be undefined, null, a string or an Element.\n // If it's a string we convert it to an Element before proceeding.\n // If it's not now an Element we remove the viewport from the DOM.\n // If it's an Element we append the viewport element to it.\n var targetElement;\n if (this.getTarget()) {\n targetElement = this.getTargetElement();\n }\n if (this.mapBrowserEventHandler_) {\n for (var i = 0, ii = this.keyHandlerKeys_.length; i < ii; ++i) {\n unlistenByKey(this.keyHandlerKeys_[i]);\n }\n this.keyHandlerKeys_ = null;\n this.viewport_.removeEventListener(EventType.CONTEXTMENU, this.boundHandleBrowserEvent_);\n this.viewport_.removeEventListener(EventType.WHEEL, this.boundHandleBrowserEvent_);\n if (this.handleResize_ !== undefined) {\n removeEventListener(EventType.RESIZE, this.handleResize_, false);\n this.handleResize_ = undefined;\n }\n this.mapBrowserEventHandler_.dispose();\n this.mapBrowserEventHandler_ = null;\n removeNode(this.viewport_);\n }\n if (!targetElement) {\n if (this.renderer_) {\n clearTimeout(this.postRenderTimeoutHandle_);\n this.postRenderTimeoutHandle_ = undefined;\n this.postRenderFunctions_.length = 0;\n this.renderer_.dispose();\n this.renderer_ = null;\n }\n if (this.animationDelayKey_) {\n cancelAnimationFrame(this.animationDelayKey_);\n this.animationDelayKey_ = undefined;\n }\n }\n else {\n targetElement.appendChild(this.viewport_);\n if (!this.renderer_) {\n this.renderer_ = this.createRenderer();\n }\n this.mapBrowserEventHandler_ = new MapBrowserEventHandler(this, this.moveTolerance_);\n for (var key in MapBrowserEventType) {\n this.mapBrowserEventHandler_.addEventListener(MapBrowserEventType[key], this.handleMapBrowserEvent.bind(this));\n }\n this.viewport_.addEventListener(EventType.CONTEXTMENU, this.boundHandleBrowserEvent_, false);\n this.viewport_.addEventListener(EventType.WHEEL, this.boundHandleBrowserEvent_, PASSIVE_EVENT_LISTENERS ? { passive: false } : false);\n var keyboardEventTarget = !this.keyboardEventTarget_\n ? targetElement\n : this.keyboardEventTarget_;\n this.keyHandlerKeys_ = [\n listen(keyboardEventTarget, EventType.KEYDOWN, this.handleBrowserEvent, this),\n listen(keyboardEventTarget, EventType.KEYPRESS, this.handleBrowserEvent, this),\n ];\n if (!this.handleResize_) {\n this.handleResize_ = this.updateSize.bind(this);\n window.addEventListener(EventType.RESIZE, this.handleResize_, false);\n }\n }\n this.updateSize();\n // updateSize calls setSize, so no need to call this.render\n // ourselves here.\n };\n /**\n * @private\n */\n PluggableMap.prototype.handleTileChange_ = function () {\n this.render();\n };\n /**\n * @private\n */\n PluggableMap.prototype.handleViewPropertyChanged_ = function () {\n this.render();\n };\n /**\n * @private\n */\n PluggableMap.prototype.handleViewChanged_ = function () {\n if (this.viewPropertyListenerKey_) {\n unlistenByKey(this.viewPropertyListenerKey_);\n this.viewPropertyListenerKey_ = null;\n }\n if (this.viewChangeListenerKey_) {\n unlistenByKey(this.viewChangeListenerKey_);\n this.viewChangeListenerKey_ = null;\n }\n var view = this.getView();\n if (view) {\n this.updateViewportSize_();\n this.viewPropertyListenerKey_ = listen(view, ObjectEventType.PROPERTYCHANGE, this.handleViewPropertyChanged_, this);\n this.viewChangeListenerKey_ = listen(view, EventType.CHANGE, this.handleViewPropertyChanged_, this);\n view.resolveConstraints(0);\n }\n this.render();\n };\n /**\n * @private\n */\n PluggableMap.prototype.handleLayerGroupChanged_ = function () {\n if (this.layerGroupPropertyListenerKeys_) {\n this.layerGroupPropertyListenerKeys_.forEach(unlistenByKey);\n this.layerGroupPropertyListenerKeys_ = null;\n }\n var layerGroup = this.getLayerGroup();\n if (layerGroup) {\n this.layerGroupPropertyListenerKeys_ = [\n listen(layerGroup, ObjectEventType.PROPERTYCHANGE, this.render, this),\n listen(layerGroup, EventType.CHANGE, this.render, this),\n ];\n }\n this.render();\n };\n /**\n * @return {boolean} Is rendered.\n */\n PluggableMap.prototype.isRendered = function () {\n return !!this.frameState_;\n };\n /**\n * Requests an immediate render in a synchronous manner.\n * @api\n */\n PluggableMap.prototype.renderSync = function () {\n if (this.animationDelayKey_) {\n cancelAnimationFrame(this.animationDelayKey_);\n }\n this.animationDelay_();\n };\n /**\n * Redraws all text after new fonts have loaded\n */\n PluggableMap.prototype.redrawText = function () {\n var layerStates = this.getLayerGroup().getLayerStatesArray();\n for (var i = 0, ii = layerStates.length; i < ii; ++i) {\n var layer = layerStates[i].layer;\n if (layer.hasRenderer()) {\n layer.getRenderer().handleFontsChanged();\n }\n }\n };\n /**\n * Request a map rendering (at the next animation frame).\n * @api\n */\n PluggableMap.prototype.render = function () {\n if (this.renderer_ && this.animationDelayKey_ === undefined) {\n this.animationDelayKey_ = requestAnimationFrame(this.animationDelay_);\n }\n };\n /**\n * Remove the given control from the map.\n * @param {import(\"./control/Control.js\").default} control Control.\n * @return {import(\"./control/Control.js\").default|undefined} The removed control (or undefined\n * if the control was not found).\n * @api\n */\n PluggableMap.prototype.removeControl = function (control) {\n return this.getControls().remove(control);\n };\n /**\n * Remove the given interaction from the map.\n * @param {import(\"./interaction/Interaction.js\").default} interaction Interaction to remove.\n * @return {import(\"./interaction/Interaction.js\").default|undefined} The removed interaction (or\n * undefined if the interaction was not found).\n * @api\n */\n PluggableMap.prototype.removeInteraction = function (interaction) {\n return this.getInteractions().remove(interaction);\n };\n /**\n * Removes the given layer from the map.\n * @param {import(\"./layer/Base.js\").default} layer Layer.\n * @return {import(\"./layer/Base.js\").default|undefined} The removed layer (or undefined if the\n * layer was not found).\n * @api\n */\n PluggableMap.prototype.removeLayer = function (layer) {\n var layers = this.getLayerGroup().getLayers();\n return layers.remove(layer);\n };\n /**\n * Remove the given overlay from the map.\n * @param {import(\"./Overlay.js\").default} overlay Overlay.\n * @return {import(\"./Overlay.js\").default|undefined} The removed overlay (or undefined\n * if the overlay was not found).\n * @api\n */\n PluggableMap.prototype.removeOverlay = function (overlay) {\n return this.getOverlays().remove(overlay);\n };\n /**\n * @param {number} time Time.\n * @private\n */\n PluggableMap.prototype.renderFrame_ = function (time) {\n var _this = this;\n var size = this.getSize();\n var view = this.getView();\n var previousFrameState = this.frameState_;\n /** @type {?FrameState} */\n var frameState = null;\n if (size !== undefined && hasArea(size) && view && view.isDef()) {\n var viewHints = view.getHints(this.frameState_ ? this.frameState_.viewHints : undefined);\n var viewState = view.getState();\n frameState = {\n animate: false,\n coordinateToPixelTransform: this.coordinateToPixelTransform_,\n declutterTree: null,\n extent: getForViewAndSize(viewState.center, viewState.resolution, viewState.rotation, size),\n index: this.frameIndex_++,\n layerIndex: 0,\n layerStatesArray: this.getLayerGroup().getLayerStatesArray(),\n pixelRatio: this.pixelRatio_,\n pixelToCoordinateTransform: this.pixelToCoordinateTransform_,\n postRenderFunctions: [],\n size: size,\n tileQueue: this.tileQueue_,\n time: time,\n usedTiles: {},\n viewState: viewState,\n viewHints: viewHints,\n wantedTiles: {},\n };\n if (viewState.nextCenter && viewState.nextResolution) {\n var rotation = isNaN(viewState.nextRotation)\n ? viewState.rotation\n : viewState.nextRotation;\n frameState.nextExtent = getForViewAndSize(viewState.nextCenter, viewState.nextResolution, rotation, size);\n }\n }\n this.frameState_ = frameState;\n this.renderer_.renderFrame(frameState);\n if (frameState) {\n if (frameState.animate) {\n this.render();\n }\n Array.prototype.push.apply(this.postRenderFunctions_, frameState.postRenderFunctions);\n if (previousFrameState) {\n var moveStart = !this.previousExtent_ ||\n (!isEmpty(this.previousExtent_) &&\n !equals(frameState.extent, this.previousExtent_));\n if (moveStart) {\n this.dispatchEvent(new MapEvent(MapEventType.MOVESTART, this, previousFrameState));\n this.previousExtent_ = createOrUpdateEmpty(this.previousExtent_);\n }\n }\n var idle = this.previousExtent_ &&\n !frameState.viewHints[ViewHint.ANIMATING] &&\n !frameState.viewHints[ViewHint.INTERACTING] &&\n !equals(frameState.extent, this.previousExtent_);\n if (idle) {\n this.dispatchEvent(new MapEvent(MapEventType.MOVEEND, this, frameState));\n clone(frameState.extent, this.previousExtent_);\n }\n }\n this.dispatchEvent(new MapEvent(MapEventType.POSTRENDER, this, frameState));\n if (!this.postRenderTimeoutHandle_) {\n this.postRenderTimeoutHandle_ = setTimeout(function () {\n _this.postRenderTimeoutHandle_ = undefined;\n _this.handlePostRender();\n }, 0);\n }\n };\n /**\n * Sets the layergroup of this map.\n * @param {LayerGroup} layerGroup A layer group containing the layers in this map.\n * @observable\n * @api\n */\n PluggableMap.prototype.setLayerGroup = function (layerGroup) {\n this.set(MapProperty.LAYERGROUP, layerGroup);\n };\n /**\n * Set the size of this map.\n * @param {import(\"./size.js\").Size|undefined} size The size in pixels of the map in the DOM.\n * @observable\n * @api\n */\n PluggableMap.prototype.setSize = function (size) {\n this.set(MapProperty.SIZE, size);\n };\n /**\n * Set the target element to render this map into.\n * @param {HTMLElement|string} [target] The Element or id of the Element\n * that the map is rendered in.\n * @observable\n * @api\n */\n PluggableMap.prototype.setTarget = function (target) {\n this.set(MapProperty.TARGET, target);\n };\n /**\n * Set the view for this map.\n * @param {View|Promise<import(\"./View.js\").ViewOptions>} view The view that controls this map.\n * It is also possible to pass a promise that resolves to options for constructing a view. This\n * alternative allows view properties to be resolved by sources or other components that load\n * view-related metadata.\n * @observable\n * @api\n */\n PluggableMap.prototype.setView = function (view) {\n if (!view || view instanceof View) {\n this.set(MapProperty.VIEW, view);\n return;\n }\n this.set(MapProperty.VIEW, new View());\n var map = this;\n view.then(function (viewOptions) {\n map.setView(new View(viewOptions));\n });\n };\n /**\n * Force a recalculation of the map viewport size. This should be called when\n * third-party code changes the size of the map viewport.\n * @api\n */\n PluggableMap.prototype.updateSize = function () {\n var targetElement = this.getTargetElement();\n var size = undefined;\n if (targetElement) {\n var computedStyle = getComputedStyle(targetElement);\n var width = targetElement.offsetWidth -\n parseFloat(computedStyle['borderLeftWidth']) -\n parseFloat(computedStyle['paddingLeft']) -\n parseFloat(computedStyle['paddingRight']) -\n parseFloat(computedStyle['borderRightWidth']);\n var height = targetElement.offsetHeight -\n parseFloat(computedStyle['borderTopWidth']) -\n parseFloat(computedStyle['paddingTop']) -\n parseFloat(computedStyle['paddingBottom']) -\n parseFloat(computedStyle['borderBottomWidth']);\n if (!isNaN(width) && !isNaN(height)) {\n size = [width, height];\n if (!hasArea(size) &&\n !!(targetElement.offsetWidth ||\n targetElement.offsetHeight ||\n targetElement.getClientRects().length)) {\n // eslint-disable-next-line\n console.warn(\"No map visible because the map container's width or height are 0.\");\n }\n }\n }\n this.setSize(size);\n this.updateViewportSize_();\n };\n /**\n * Recomputes the viewport size and save it on the view object (if any)\n * @private\n */\n PluggableMap.prototype.updateViewportSize_ = function () {\n var view = this.getView();\n if (view) {\n var size = undefined;\n var computedStyle = getComputedStyle(this.viewport_);\n if (computedStyle.width && computedStyle.height) {\n size = [\n parseInt(computedStyle.width, 10),\n parseInt(computedStyle.height, 10),\n ];\n }\n view.setViewportSize(size);\n }\n };\n return PluggableMap;\n}(BaseObject));\n/**\n * @param {MapOptions} options Map options.\n * @return {MapOptionsInternal} Internal map options.\n */\nfunction createOptionsInternal(options) {\n /**\n * @type {HTMLElement|Document}\n */\n var keyboardEventTarget = null;\n if (options.keyboardEventTarget !== undefined) {\n keyboardEventTarget =\n typeof options.keyboardEventTarget === 'string'\n ? document.getElementById(options.keyboardEventTarget)\n : options.keyboardEventTarget;\n }\n /**\n * @type {Object<string, *>}\n */\n var values = {};\n var layerGroup = options.layers &&\n typeof ( /** @type {?} */(options.layers).getLayers) === 'function'\n ? /** @type {LayerGroup} */ (options.layers)\n : new LayerGroup({ layers: /** @type {Collection} */ (options.layers) });\n values[MapProperty.LAYERGROUP] = layerGroup;\n values[MapProperty.TARGET] = options.target;\n values[MapProperty.VIEW] =\n options.view instanceof View ? options.view : new View();\n var controls;\n if (options.controls !== undefined) {\n if (Array.isArray(options.controls)) {\n controls = new Collection(options.controls.slice());\n }\n else {\n assert(typeof ( /** @type {?} */(options.controls).getArray) === 'function', 47); // Expected `controls` to be an array or an `import(\"./Collection.js\").Collection`\n controls = /** @type {Collection} */ (options.controls);\n }\n }\n var interactions;\n if (options.interactions !== undefined) {\n if (Array.isArray(options.interactions)) {\n interactions = new Collection(options.interactions.slice());\n }\n else {\n assert(typeof ( /** @type {?} */(options.interactions).getArray) ===\n 'function', 48); // Expected `interactions` to be an array or an `import(\"./Collection.js\").Collection`\n interactions = /** @type {Collection} */ (options.interactions);\n }\n }\n var overlays;\n if (options.overlays !== undefined) {\n if (Array.isArray(options.overlays)) {\n overlays = new Collection(options.overlays.slice());\n }\n else {\n assert(typeof ( /** @type {?} */(options.overlays).getArray) === 'function', 49); // Expected `overlays` to be an array or an `import(\"./Collection.js\").Collection`\n overlays = options.overlays;\n }\n }\n else {\n overlays = new Collection();\n }\n return {\n controls: controls,\n interactions: interactions,\n keyboardEventTarget: keyboardEventTarget,\n overlays: overlays,\n values: values,\n };\n}\nexport default PluggableMap;\n//# sourceMappingURL=PluggableMap.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/control/Rotate\n */\nimport Control from './Control.js';\nimport EventType from '../events/EventType.js';\nimport { CLASS_CONTROL, CLASS_HIDDEN, CLASS_UNSELECTABLE } from '../css.js';\nimport { easeOut } from '../easing.js';\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-rotate'] CSS class name.\n * @property {string|HTMLElement} [label='⇧'] Text label to use for the rotate button.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string} [tipLabel='Reset rotation'] Text label to use for the rotate tip.\n * @property {string} [compassClassName='ol-compass'] CSS class name for the compass.\n * @property {number} [duration=250] Animation duration in milliseconds.\n * @property {boolean} [autoHide=true] Hide the control when rotation is 0.\n * @property {function(import(\"../MapEvent.js\").default):void} [render] Function called when the control should\n * be re-rendered. This is called in a `requestAnimationFrame` callback.\n * @property {function():void} [resetNorth] Function called when the control is clicked.\n * This will override the default `resetNorth`.\n * @property {HTMLElement|string} [target] Specify a target if you want the control to be\n * rendered outside of the map's viewport.\n */\n/**\n * @classdesc\n * A button control to reset rotation to 0.\n * To style this control use css selector `.ol-rotate`. A `.ol-hidden` css\n * selector is added to the button when the rotation is 0.\n *\n * @api\n */\nvar Rotate = /** @class */ (function (_super) {\n __extends(Rotate, _super);\n /**\n * @param {Options} [opt_options] Rotate options.\n */\n function Rotate(opt_options) {\n var _this = this;\n var options = opt_options ? opt_options : {};\n _this = _super.call(this, {\n element: document.createElement('div'),\n render: options.render,\n target: options.target,\n }) || this;\n var className = options.className !== undefined ? options.className : 'ol-rotate';\n var label = options.label !== undefined ? options.label : '\\u21E7';\n var compassClassName = options.compassClassName !== undefined\n ? options.compassClassName\n : 'ol-compass';\n /**\n * @type {HTMLElement}\n * @private\n */\n _this.label_ = null;\n if (typeof label === 'string') {\n _this.label_ = document.createElement('span');\n _this.label_.className = compassClassName;\n _this.label_.textContent = label;\n }\n else {\n _this.label_ = label;\n _this.label_.classList.add(compassClassName);\n }\n var tipLabel = options.tipLabel ? options.tipLabel : 'Reset rotation';\n var button = document.createElement('button');\n button.className = className + '-reset';\n button.setAttribute('type', 'button');\n button.title = tipLabel;\n button.appendChild(_this.label_);\n button.addEventListener(EventType.CLICK, _this.handleClick_.bind(_this), false);\n var cssClasses = className + ' ' + CLASS_UNSELECTABLE + ' ' + CLASS_CONTROL;\n var element = _this.element;\n element.className = cssClasses;\n element.appendChild(button);\n _this.callResetNorth_ = options.resetNorth ? options.resetNorth : undefined;\n /**\n * @type {number}\n * @private\n */\n _this.duration_ = options.duration !== undefined ? options.duration : 250;\n /**\n * @type {boolean}\n * @private\n */\n _this.autoHide_ = options.autoHide !== undefined ? options.autoHide : true;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.rotation_ = undefined;\n if (_this.autoHide_) {\n _this.element.classList.add(CLASS_HIDDEN);\n }\n return _this;\n }\n /**\n * @param {MouseEvent} event The event to handle\n * @private\n */\n Rotate.prototype.handleClick_ = function (event) {\n event.preventDefault();\n if (this.callResetNorth_ !== undefined) {\n this.callResetNorth_();\n }\n else {\n this.resetNorth_();\n }\n };\n /**\n * @private\n */\n Rotate.prototype.resetNorth_ = function () {\n var map = this.getMap();\n var view = map.getView();\n if (!view) {\n // the map does not have a view, so we can't act\n // upon it\n return;\n }\n var rotation = view.getRotation();\n if (rotation !== undefined) {\n if (this.duration_ > 0 && rotation % (2 * Math.PI) !== 0) {\n view.animate({\n rotation: 0,\n duration: this.duration_,\n easing: easeOut,\n });\n }\n else {\n view.setRotation(0);\n }\n }\n };\n /**\n * Update the rotate control element.\n * @param {import(\"../MapEvent.js\").default} mapEvent Map event.\n * @override\n */\n Rotate.prototype.render = function (mapEvent) {\n var frameState = mapEvent.frameState;\n if (!frameState) {\n return;\n }\n var rotation = frameState.viewState.rotation;\n if (rotation != this.rotation_) {\n var transform = 'rotate(' + rotation + 'rad)';\n if (this.autoHide_) {\n var contains = this.element.classList.contains(CLASS_HIDDEN);\n if (!contains && rotation === 0) {\n this.element.classList.add(CLASS_HIDDEN);\n }\n else if (contains && rotation !== 0) {\n this.element.classList.remove(CLASS_HIDDEN);\n }\n }\n this.label_.style.transform = transform;\n }\n this.rotation_ = rotation;\n };\n return Rotate;\n}(Control));\nexport default Rotate;\n//# sourceMappingURL=Rotate.js.map","/**\n * @module ol/interaction/Property\n */\n/**\n * @enum {string}\n */\nexport default {\n ACTIVE: 'active',\n};\n//# sourceMappingURL=Property.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/interaction/Interaction\n */\nimport BaseObject from '../Object.js';\nimport InteractionProperty from './Property.js';\nimport { easeOut, linear } from '../easing.js';\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n * import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types|\n * 'change:active', import(\"../Object\").ObjectEvent, Return> &\n * import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").Types|\n * 'change:active', Return>} InteractionOnSignature\n */\n/**\n * Object literal with config options for interactions.\n * @typedef {Object} InteractionOptions\n * @property {function(import(\"../MapBrowserEvent.js\").default):boolean} handleEvent\n * Method called by the map to notify the interaction that a browser event was\n * dispatched to the map. If the function returns a falsy value, propagation of\n * the event to other interactions in the map's interactions chain will be\n * prevented (this includes functions with no explicit return). The interactions\n * are traversed in reverse order of the interactions collection of the map.\n */\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * User actions that change the state of the map. Some are similar to controls,\n * but are not associated with a DOM element.\n * For example, {@link module:ol/interaction/KeyboardZoom~KeyboardZoom} is\n * functionally the same as {@link module:ol/control/Zoom~Zoom}, but triggered\n * by a keyboard event not a button element event.\n * Although interactions do not have a DOM element, some of them do render\n * vectors and so are visible on the screen.\n * @api\n */\nvar Interaction = /** @class */ (function (_super) {\n __extends(Interaction, _super);\n /**\n * @param {InteractionOptions} [opt_options] Options.\n */\n function Interaction(opt_options) {\n var _this = _super.call(this) || this;\n /***\n * @type {InteractionOnSignature<import(\"../events\").EventsKey>}\n */\n _this.on;\n /***\n * @type {InteractionOnSignature<import(\"../events\").EventsKey>}\n */\n _this.once;\n /***\n * @type {InteractionOnSignature<void>}\n */\n _this.un;\n if (opt_options && opt_options.handleEvent) {\n _this.handleEvent = opt_options.handleEvent;\n }\n /**\n * @private\n * @type {import(\"../PluggableMap.js\").default}\n */\n _this.map_ = null;\n _this.setActive(true);\n return _this;\n }\n /**\n * Return whether the interaction is currently active.\n * @return {boolean} `true` if the interaction is active, `false` otherwise.\n * @observable\n * @api\n */\n Interaction.prototype.getActive = function () {\n return /** @type {boolean} */ (this.get(InteractionProperty.ACTIVE));\n };\n /**\n * Get the map associated with this interaction.\n * @return {import(\"../PluggableMap.js\").default} Map.\n * @api\n */\n Interaction.prototype.getMap = function () {\n return this.map_;\n };\n /**\n * Handles the {@link module:ol/MapBrowserEvent map browser event}.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} `false` to stop event propagation.\n * @api\n */\n Interaction.prototype.handleEvent = function (mapBrowserEvent) {\n return true;\n };\n /**\n * Activate or deactivate the interaction.\n * @param {boolean} active Active.\n * @observable\n * @api\n */\n Interaction.prototype.setActive = function (active) {\n this.set(InteractionProperty.ACTIVE, active);\n };\n /**\n * Remove the interaction from its current map and attach it to the new map.\n * Subclasses may set up event handlers to get notified about changes to\n * the map here.\n * @param {import(\"../PluggableMap.js\").default} map Map.\n */\n Interaction.prototype.setMap = function (map) {\n this.map_ = map;\n };\n return Interaction;\n}(BaseObject));\n/**\n * @param {import(\"../View.js\").default} view View.\n * @param {import(\"../coordinate.js\").Coordinate} delta Delta.\n * @param {number} [opt_duration] Duration.\n */\nexport function pan(view, delta, opt_duration) {\n var currentCenter = view.getCenterInternal();\n if (currentCenter) {\n var center = [currentCenter[0] + delta[0], currentCenter[1] + delta[1]];\n view.animateInternal({\n duration: opt_duration !== undefined ? opt_duration : 250,\n easing: linear,\n center: view.getConstrainedCenter(center),\n });\n }\n}\n/**\n * @param {import(\"../View.js\").default} view View.\n * @param {number} delta Delta from previous zoom level.\n * @param {import(\"../coordinate.js\").Coordinate} [opt_anchor] Anchor coordinate in the user projection.\n * @param {number} [opt_duration] Duration.\n */\nexport function zoomByDelta(view, delta, opt_anchor, opt_duration) {\n var currentZoom = view.getZoom();\n if (currentZoom === undefined) {\n return;\n }\n var newZoom = view.getConstrainedZoom(currentZoom + delta);\n var newResolution = view.getResolutionForZoom(newZoom);\n if (view.getAnimating()) {\n view.cancelAnimations();\n }\n view.animate({\n resolution: newResolution,\n anchor: opt_anchor,\n duration: opt_duration !== undefined ? opt_duration : 250,\n easing: easeOut,\n });\n}\nexport default Interaction;\n//# sourceMappingURL=Interaction.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/interaction/DoubleClickZoom\n */\nimport Interaction, { zoomByDelta } from './Interaction.js';\nimport MapBrowserEventType from '../MapBrowserEventType.js';\n/**\n * @typedef {Object} Options\n * @property {number} [duration=250] Animation duration in milliseconds.\n * @property {number} [delta=1] The zoom delta applied on each double click.\n */\n/**\n * @classdesc\n * Allows the user to zoom by double-clicking on the map.\n * @api\n */\nvar DoubleClickZoom = /** @class */ (function (_super) {\n __extends(DoubleClickZoom, _super);\n /**\n * @param {Options} [opt_options] Options.\n */\n function DoubleClickZoom(opt_options) {\n var _this = _super.call(this) || this;\n var options = opt_options ? opt_options : {};\n /**\n * @private\n * @type {number}\n */\n _this.delta_ = options.delta ? options.delta : 1;\n /**\n * @private\n * @type {number}\n */\n _this.duration_ = options.duration !== undefined ? options.duration : 250;\n return _this;\n }\n /**\n * Handles the {@link module:ol/MapBrowserEvent map browser event} (if it was a\n * doubleclick) and eventually zooms the map.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} `false` to stop event propagation.\n */\n DoubleClickZoom.prototype.handleEvent = function (mapBrowserEvent) {\n var stopEvent = false;\n if (mapBrowserEvent.type == MapBrowserEventType.DBLCLICK) {\n var browserEvent = /** @type {MouseEvent} */ (mapBrowserEvent.originalEvent);\n var map = mapBrowserEvent.map;\n var anchor = mapBrowserEvent.coordinate;\n var delta = browserEvent.shiftKey ? -this.delta_ : this.delta_;\n var view = map.getView();\n zoomByDelta(view, delta, anchor, this.duration_);\n browserEvent.preventDefault();\n stopEvent = true;\n }\n return !stopEvent;\n };\n return DoubleClickZoom;\n}(Interaction));\nexport default DoubleClickZoom;\n//# sourceMappingURL=DoubleClickZoom.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/interaction/Pointer\n */\nimport Interaction from './Interaction.js';\nimport MapBrowserEventType from '../MapBrowserEventType.js';\nimport { getValues } from '../obj.js';\n/**\n * @typedef {Object} Options\n * @property {function(import(\"../MapBrowserEvent.js\").default):boolean} [handleDownEvent]\n * Function handling \"down\" events. If the function returns `true` then a drag\n * sequence is started.\n * @property {function(import(\"../MapBrowserEvent.js\").default):void} [handleDragEvent]\n * Function handling \"drag\" events. This function is called on \"move\" events\n * during a drag sequence.\n * @property {function(import(\"../MapBrowserEvent.js\").default):boolean} [handleEvent]\n * Method called by the map to notify the interaction that a browser event was\n * dispatched to the map. The function may return `false` to prevent the\n * propagation of the event to other interactions in the map's interactions\n * chain.\n * @property {function(import(\"../MapBrowserEvent.js\").default):void} [handleMoveEvent]\n * Function handling \"move\" events. This function is called on \"move\" events.\n * This functions is also called during a drag sequence, so during a drag\n * sequence both the `handleDragEvent` function and this function are called.\n * If `handleDownEvent` is defined and it returns true this function will not\n * be called during a drag sequence.\n * @property {function(import(\"../MapBrowserEvent.js\").default):boolean} [handleUpEvent]\n * Function handling \"up\" events. If the function returns `false` then the\n * current drag sequence is stopped.\n * @property {function(boolean):boolean} [stopDown]\n * Should the down event be propagated to other interactions, or should be\n * stopped?\n */\n/**\n * @classdesc\n * Base class that calls user-defined functions on `down`, `move` and `up`\n * events. This class also manages \"drag sequences\".\n *\n * When the `handleDownEvent` user function returns `true` a drag sequence is\n * started. During a drag sequence the `handleDragEvent` user function is\n * called on `move` events. The drag sequence ends when the `handleUpEvent`\n * user function is called and returns `false`.\n * @api\n */\nvar PointerInteraction = /** @class */ (function (_super) {\n __extends(PointerInteraction, _super);\n /**\n * @param {Options} [opt_options] Options.\n */\n function PointerInteraction(opt_options) {\n var _this = this;\n var options = opt_options ? opt_options : {};\n _this = _super.call(this, \n /** @type {import(\"./Interaction.js\").InteractionOptions} */ (options)) || this;\n if (options.handleDownEvent) {\n _this.handleDownEvent = options.handleDownEvent;\n }\n if (options.handleDragEvent) {\n _this.handleDragEvent = options.handleDragEvent;\n }\n if (options.handleMoveEvent) {\n _this.handleMoveEvent = options.handleMoveEvent;\n }\n if (options.handleUpEvent) {\n _this.handleUpEvent = options.handleUpEvent;\n }\n if (options.stopDown) {\n _this.stopDown = options.stopDown;\n }\n /**\n * @type {boolean}\n * @protected\n */\n _this.handlingDownUpSequence = false;\n /**\n * @type {!Object<string, PointerEvent>}\n * @private\n */\n _this.trackedPointers_ = {};\n /**\n * @type {Array<PointerEvent>}\n * @protected\n */\n _this.targetPointers = [];\n return _this;\n }\n /**\n * Returns the current number of pointers involved in the interaction,\n * e.g. `2` when two fingers are used.\n * @return {number} The number of pointers.\n * @api\n */\n PointerInteraction.prototype.getPointerCount = function () {\n return this.targetPointers.length;\n };\n /**\n * Handle pointer down events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n * @protected\n */\n PointerInteraction.prototype.handleDownEvent = function (mapBrowserEvent) {\n return false;\n };\n /**\n * Handle pointer drag events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @protected\n */\n PointerInteraction.prototype.handleDragEvent = function (mapBrowserEvent) { };\n /**\n * Handles the {@link module:ol/MapBrowserEvent map browser event} and may call into\n * other functions, if event sequences like e.g. 'drag' or 'down-up' etc. are\n * detected.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} `false` to stop event propagation.\n * @api\n */\n PointerInteraction.prototype.handleEvent = function (mapBrowserEvent) {\n if (!mapBrowserEvent.originalEvent) {\n return true;\n }\n var stopEvent = false;\n this.updateTrackedPointers_(mapBrowserEvent);\n if (this.handlingDownUpSequence) {\n if (mapBrowserEvent.type == MapBrowserEventType.POINTERDRAG) {\n this.handleDragEvent(mapBrowserEvent);\n // prevent page scrolling during dragging\n mapBrowserEvent.originalEvent.preventDefault();\n }\n else if (mapBrowserEvent.type == MapBrowserEventType.POINTERUP) {\n var handledUp = this.handleUpEvent(mapBrowserEvent);\n this.handlingDownUpSequence =\n handledUp && this.targetPointers.length > 0;\n }\n }\n else {\n if (mapBrowserEvent.type == MapBrowserEventType.POINTERDOWN) {\n var handled = this.handleDownEvent(mapBrowserEvent);\n this.handlingDownUpSequence = handled;\n stopEvent = this.stopDown(handled);\n }\n else if (mapBrowserEvent.type == MapBrowserEventType.POINTERMOVE) {\n this.handleMoveEvent(mapBrowserEvent);\n }\n }\n return !stopEvent;\n };\n /**\n * Handle pointer move events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @protected\n */\n PointerInteraction.prototype.handleMoveEvent = function (mapBrowserEvent) { };\n /**\n * Handle pointer up events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n * @protected\n */\n PointerInteraction.prototype.handleUpEvent = function (mapBrowserEvent) {\n return false;\n };\n /**\n * This function is used to determine if \"down\" events should be propagated\n * to other interactions or should be stopped.\n * @param {boolean} handled Was the event handled by the interaction?\n * @return {boolean} Should the `down` event be stopped?\n */\n PointerInteraction.prototype.stopDown = function (handled) {\n return handled;\n };\n /**\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @private\n */\n PointerInteraction.prototype.updateTrackedPointers_ = function (mapBrowserEvent) {\n if (isPointerDraggingEvent(mapBrowserEvent)) {\n var event_1 = mapBrowserEvent.originalEvent;\n var id = event_1.pointerId.toString();\n if (mapBrowserEvent.type == MapBrowserEventType.POINTERUP) {\n delete this.trackedPointers_[id];\n }\n else if (mapBrowserEvent.type == MapBrowserEventType.POINTERDOWN) {\n this.trackedPointers_[id] = event_1;\n }\n else if (id in this.trackedPointers_) {\n // update only when there was a pointerdown event for this pointer\n this.trackedPointers_[id] = event_1;\n }\n this.targetPointers = getValues(this.trackedPointers_);\n }\n };\n return PointerInteraction;\n}(Interaction));\n/**\n * @param {Array<PointerEvent>} pointerEvents List of events.\n * @return {import(\"../pixel.js\").Pixel} Centroid pixel.\n */\nexport function centroid(pointerEvents) {\n var length = pointerEvents.length;\n var clientX = 0;\n var clientY = 0;\n for (var i = 0; i < length; i++) {\n clientX += pointerEvents[i].clientX;\n clientY += pointerEvents[i].clientY;\n }\n return [clientX / length, clientY / length];\n}\n/**\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} Whether the event is a pointerdown, pointerdrag\n * or pointerup event.\n */\nfunction isPointerDraggingEvent(mapBrowserEvent) {\n var type = mapBrowserEvent.type;\n return (type === MapBrowserEventType.POINTERDOWN ||\n type === MapBrowserEventType.POINTERDRAG ||\n type === MapBrowserEventType.POINTERUP);\n}\nexport default PointerInteraction;\n//# sourceMappingURL=Pointer.js.map","/**\n * @module ol/events/condition\n */\nimport MapBrowserEventType from '../MapBrowserEventType.js';\nimport { FALSE, TRUE } from '../functions.js';\nimport { MAC, WEBKIT } from '../has.js';\nimport { assert } from '../asserts.js';\n/**\n * A function that takes an {@link module:ol/MapBrowserEvent} and returns a\n * `{boolean}`. If the condition is met, true should be returned.\n *\n * @typedef {function(this: ?, import(\"../MapBrowserEvent.js\").default): boolean} Condition\n */\n/**\n * Creates a condition function that passes when all provided conditions pass.\n * @param {...Condition} var_args Conditions to check.\n * @return {Condition} Condition function.\n */\nexport function all(var_args) {\n var conditions = arguments;\n /**\n * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n * @return {boolean} All conditions passed.\n */\n return function (event) {\n var pass = true;\n for (var i = 0, ii = conditions.length; i < ii; ++i) {\n pass = pass && conditions[i](event);\n if (!pass) {\n break;\n }\n }\n return pass;\n };\n}\n/**\n * Return `true` if only the alt-key is pressed, `false` otherwise (e.g. when\n * additionally the shift-key is pressed).\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if only the alt key is pressed.\n * @api\n */\nexport var altKeyOnly = function (mapBrowserEvent) {\n var originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (mapBrowserEvent.originalEvent);\n return (originalEvent.altKey &&\n !(originalEvent.metaKey || originalEvent.ctrlKey) &&\n !originalEvent.shiftKey);\n};\n/**\n * Return `true` if only the alt-key and shift-key is pressed, `false` otherwise\n * (e.g. when additionally the platform-modifier-key is pressed).\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if only the alt and shift keys are pressed.\n * @api\n */\nexport var altShiftKeysOnly = function (mapBrowserEvent) {\n var originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (mapBrowserEvent.originalEvent);\n return (originalEvent.altKey &&\n !(originalEvent.metaKey || originalEvent.ctrlKey) &&\n originalEvent.shiftKey);\n};\n/**\n * Return `true` if the map has the focus. This condition requires a map target\n * element with a `tabindex` attribute, e.g. `<div id=\"map\" tabindex=\"1\">`.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} event Map browser event.\n * @return {boolean} The map has the focus.\n * @api\n */\nexport var focus = function (event) {\n return event.target.getTargetElement().contains(document.activeElement);\n};\n/**\n * Return `true` if the map has the focus or no 'tabindex' attribute set.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} event Map browser event.\n * @return {boolean} The map container has the focus or no 'tabindex' attribute.\n */\nexport var focusWithTabindex = function (event) {\n return event.map.getTargetElement().hasAttribute('tabindex')\n ? focus(event)\n : true;\n};\n/**\n * Return always true.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True.\n * @api\n */\nexport var always = TRUE;\n/**\n * Return `true` if the event is a `click` event, `false` otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event is a map `click` event.\n * @api\n */\nexport var click = function (mapBrowserEvent) {\n return mapBrowserEvent.type == MapBrowserEventType.CLICK;\n};\n/**\n * Return `true` if the event has an \"action\"-producing mouse button.\n *\n * By definition, this includes left-click on windows/linux, and left-click\n * without the ctrl key on Macs.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} The result.\n */\nexport var mouseActionButton = function (mapBrowserEvent) {\n var originalEvent = /** @type {MouseEvent} */ (mapBrowserEvent.originalEvent);\n return originalEvent.button == 0 && !(WEBKIT && MAC && originalEvent.ctrlKey);\n};\n/**\n * Return always false.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} False.\n * @api\n */\nexport var never = FALSE;\n/**\n * Return `true` if the browser event is a `pointermove` event, `false`\n * otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the browser event is a `pointermove` event.\n * @api\n */\nexport var pointerMove = function (mapBrowserEvent) {\n return mapBrowserEvent.type == 'pointermove';\n};\n/**\n * Return `true` if the event is a map `singleclick` event, `false` otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event is a map `singleclick` event.\n * @api\n */\nexport var singleClick = function (mapBrowserEvent) {\n return mapBrowserEvent.type == MapBrowserEventType.SINGLECLICK;\n};\n/**\n * Return `true` if the event is a map `dblclick` event, `false` otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event is a map `dblclick` event.\n * @api\n */\nexport var doubleClick = function (mapBrowserEvent) {\n return mapBrowserEvent.type == MapBrowserEventType.DBLCLICK;\n};\n/**\n * Return `true` if no modifier key (alt-, shift- or platform-modifier-key) is\n * pressed.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True only if there no modifier keys are pressed.\n * @api\n */\nexport var noModifierKeys = function (mapBrowserEvent) {\n var originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (mapBrowserEvent.originalEvent);\n return (!originalEvent.altKey &&\n !(originalEvent.metaKey || originalEvent.ctrlKey) &&\n !originalEvent.shiftKey);\n};\n/**\n * Return `true` if only the platform-modifier-key (the meta-key on Mac,\n * ctrl-key otherwise) is pressed, `false` otherwise (e.g. when additionally\n * the shift-key is pressed).\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if only the platform modifier key is pressed.\n * @api\n */\nexport var platformModifierKeyOnly = function (mapBrowserEvent) {\n var originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (mapBrowserEvent.originalEvent);\n return (!originalEvent.altKey &&\n (MAC ? originalEvent.metaKey : originalEvent.ctrlKey) &&\n !originalEvent.shiftKey);\n};\n/**\n * Return `true` if only the shift-key is pressed, `false` otherwise (e.g. when\n * additionally the alt-key is pressed).\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if only the shift key is pressed.\n * @api\n */\nexport var shiftKeyOnly = function (mapBrowserEvent) {\n var originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (mapBrowserEvent.originalEvent);\n return (!originalEvent.altKey &&\n !(originalEvent.metaKey || originalEvent.ctrlKey) &&\n originalEvent.shiftKey);\n};\n/**\n * Return `true` if the target element is not editable, i.e. not a `<input>`-,\n * `<select>`- or `<textarea>`-element, `false` otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True only if the target element is not editable.\n * @api\n */\nexport var targetNotEditable = function (mapBrowserEvent) {\n var originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (mapBrowserEvent.originalEvent);\n var tagName = /** @type {Element} */ (originalEvent.target).tagName;\n return tagName !== 'INPUT' && tagName !== 'SELECT' && tagName !== 'TEXTAREA';\n};\n/**\n * Return `true` if the event originates from a mouse device.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event originates from a mouse device.\n * @api\n */\nexport var mouseOnly = function (mapBrowserEvent) {\n var pointerEvent = /** @type {import(\"../MapBrowserEvent\").default} */ (mapBrowserEvent).originalEvent;\n assert(pointerEvent !== undefined, 56); // mapBrowserEvent must originate from a pointer event\n // see https://www.w3.org/TR/pointerevents/#widl-PointerEvent-pointerType\n return pointerEvent.pointerType == 'mouse';\n};\n/**\n * Return `true` if the event originates from a touchable device.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event originates from a touchable device.\n * @api\n */\nexport var touchOnly = function (mapBrowserEvent) {\n var pointerEvt = /** @type {import(\"../MapBrowserEvent\").default} */ (mapBrowserEvent).originalEvent;\n assert(pointerEvt !== undefined, 56); // mapBrowserEvent must originate from a pointer event\n // see https://www.w3.org/TR/pointerevents/#widl-PointerEvent-pointerType\n return pointerEvt.pointerType === 'touch';\n};\n/**\n * Return `true` if the event originates from a digital pen.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event originates from a digital pen.\n * @api\n */\nexport var penOnly = function (mapBrowserEvent) {\n var pointerEvt = /** @type {import(\"../MapBrowserEvent\").default} */ (mapBrowserEvent).originalEvent;\n assert(pointerEvt !== undefined, 56); // mapBrowserEvent must originate from a pointer event\n // see https://www.w3.org/TR/pointerevents/#widl-PointerEvent-pointerType\n return pointerEvt.pointerType === 'pen';\n};\n/**\n * Return `true` if the event originates from a primary pointer in\n * contact with the surface or if the left mouse button is pressed.\n * See https://www.w3.org/TR/pointerevents/#button-states.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event originates from a primary pointer.\n * @api\n */\nexport var primaryAction = function (mapBrowserEvent) {\n var pointerEvent = /** @type {import(\"../MapBrowserEvent\").default} */ (mapBrowserEvent).originalEvent;\n assert(pointerEvent !== undefined, 56); // mapBrowserEvent must originate from a pointer event\n return pointerEvent.isPrimary && pointerEvent.button === 0;\n};\n//# sourceMappingURL=condition.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/interaction/DragPan\n */\nimport PointerInteraction, { centroid as centroidFromPointers, } from './Pointer.js';\nimport { FALSE } from '../functions.js';\nimport { all, focusWithTabindex, noModifierKeys, primaryAction, } from '../events/condition.js';\nimport { easeOut } from '../easing.js';\nimport { rotate as rotateCoordinate, scale as scaleCoordinate, } from '../coordinate.js';\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that takes an {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a boolean\n * to indicate whether that event should be handled.\n * Default is {@link module:ol/events/condition.noModifierKeys} and {@link module:ol/events/condition.primaryAction}.\n * @property {boolean} [onFocusOnly=false] When the map's target has a `tabindex` attribute set,\n * the interaction will only handle events when the map has the focus.\n * @property {import(\"../Kinetic.js\").default} [kinetic] Kinetic inertia to apply to the pan.\n */\n/**\n * @classdesc\n * Allows the user to pan the map by dragging the map.\n * @api\n */\nvar DragPan = /** @class */ (function (_super) {\n __extends(DragPan, _super);\n /**\n * @param {Options} [opt_options] Options.\n */\n function DragPan(opt_options) {\n var _this = _super.call(this, {\n stopDown: FALSE,\n }) || this;\n var options = opt_options ? opt_options : {};\n /**\n * @private\n * @type {import(\"../Kinetic.js\").default|undefined}\n */\n _this.kinetic_ = options.kinetic;\n /**\n * @type {import(\"../pixel.js\").Pixel}\n */\n _this.lastCentroid = null;\n /**\n * @type {number}\n */\n _this.lastPointersCount_;\n /**\n * @type {boolean}\n */\n _this.panning_ = false;\n var condition = options.condition\n ? options.condition\n : all(noModifierKeys, primaryAction);\n /**\n * @private\n * @type {import(\"../events/condition.js\").Condition}\n */\n _this.condition_ = options.onFocusOnly\n ? all(focusWithTabindex, condition)\n : condition;\n /**\n * @private\n * @type {boolean}\n */\n _this.noKinetic_ = false;\n return _this;\n }\n /**\n * Handle pointer drag events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n */\n DragPan.prototype.handleDragEvent = function (mapBrowserEvent) {\n if (!this.panning_) {\n this.panning_ = true;\n this.getMap().getView().beginInteraction();\n }\n var targetPointers = this.targetPointers;\n var centroid = centroidFromPointers(targetPointers);\n if (targetPointers.length == this.lastPointersCount_) {\n if (this.kinetic_) {\n this.kinetic_.update(centroid[0], centroid[1]);\n }\n if (this.lastCentroid) {\n var delta = [\n this.lastCentroid[0] - centroid[0],\n centroid[1] - this.lastCentroid[1],\n ];\n var map = mapBrowserEvent.map;\n var view = map.getView();\n scaleCoordinate(delta, view.getResolution());\n rotateCoordinate(delta, view.getRotation());\n view.adjustCenterInternal(delta);\n }\n }\n else if (this.kinetic_) {\n // reset so we don't overestimate the kinetic energy after\n // after one finger down, tiny drag, second finger down\n this.kinetic_.begin();\n }\n this.lastCentroid = centroid;\n this.lastPointersCount_ = targetPointers.length;\n mapBrowserEvent.originalEvent.preventDefault();\n };\n /**\n * Handle pointer up events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n */\n DragPan.prototype.handleUpEvent = function (mapBrowserEvent) {\n var map = mapBrowserEvent.map;\n var view = map.getView();\n if (this.targetPointers.length === 0) {\n if (!this.noKinetic_ && this.kinetic_ && this.kinetic_.end()) {\n var distance = this.kinetic_.getDistance();\n var angle = this.kinetic_.getAngle();\n var center = view.getCenterInternal();\n var centerpx = map.getPixelFromCoordinateInternal(center);\n var dest = map.getCoordinateFromPixelInternal([\n centerpx[0] - distance * Math.cos(angle),\n centerpx[1] - distance * Math.sin(angle),\n ]);\n view.animateInternal({\n center: view.getConstrainedCenter(dest),\n duration: 500,\n easing: easeOut,\n });\n }\n if (this.panning_) {\n this.panning_ = false;\n view.endInteraction();\n }\n return false;\n }\n else {\n if (this.kinetic_) {\n // reset so we don't overestimate the kinetic energy after\n // after one finger up, tiny drag, second finger up\n this.kinetic_.begin();\n }\n this.lastCentroid = null;\n return true;\n }\n };\n /**\n * Handle pointer down events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n */\n DragPan.prototype.handleDownEvent = function (mapBrowserEvent) {\n if (this.targetPointers.length > 0 && this.condition_(mapBrowserEvent)) {\n var map = mapBrowserEvent.map;\n var view = map.getView();\n this.lastCentroid = null;\n // stop any current animation\n if (view.getAnimating()) {\n view.cancelAnimations();\n }\n if (this.kinetic_) {\n this.kinetic_.begin();\n }\n // No kinetic as soon as more than one pointer on the screen is\n // detected. This is to prevent nasty pans after pinch.\n this.noKinetic_ = this.targetPointers.length > 1;\n return true;\n }\n else {\n return false;\n }\n };\n return DragPan;\n}(PointerInteraction));\nexport default DragPan;\n//# sourceMappingURL=DragPan.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/interaction/DragRotate\n */\nimport PointerInteraction from './Pointer.js';\nimport { FALSE } from '../functions.js';\nimport { altShiftKeysOnly, mouseActionButton, mouseOnly, } from '../events/condition.js';\nimport { disable } from '../rotationconstraint.js';\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that takes an\n * {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a boolean\n * to indicate whether that event should be handled.\n * Default is {@link module:ol/events/condition.altShiftKeysOnly}.\n * @property {number} [duration=250] Animation duration in milliseconds.\n */\n/**\n * @classdesc\n * Allows the user to rotate the map by clicking and dragging on the map,\n * normally combined with an {@link module:ol/events/condition} that limits\n * it to when the alt and shift keys are held down.\n *\n * This interaction is only supported for mouse devices.\n * @api\n */\nvar DragRotate = /** @class */ (function (_super) {\n __extends(DragRotate, _super);\n /**\n * @param {Options} [opt_options] Options.\n */\n function DragRotate(opt_options) {\n var _this = this;\n var options = opt_options ? opt_options : {};\n _this = _super.call(this, {\n stopDown: FALSE,\n }) || this;\n /**\n * @private\n * @type {import(\"../events/condition.js\").Condition}\n */\n _this.condition_ = options.condition ? options.condition : altShiftKeysOnly;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.lastAngle_ = undefined;\n /**\n * @private\n * @type {number}\n */\n _this.duration_ = options.duration !== undefined ? options.duration : 250;\n return _this;\n }\n /**\n * Handle pointer drag events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n */\n DragRotate.prototype.handleDragEvent = function (mapBrowserEvent) {\n if (!mouseOnly(mapBrowserEvent)) {\n return;\n }\n var map = mapBrowserEvent.map;\n var view = map.getView();\n if (view.getConstraints().rotation === disable) {\n return;\n }\n var size = map.getSize();\n var offset = mapBrowserEvent.pixel;\n var theta = Math.atan2(size[1] / 2 - offset[1], offset[0] - size[0] / 2);\n if (this.lastAngle_ !== undefined) {\n var delta = theta - this.lastAngle_;\n view.adjustRotationInternal(-delta);\n }\n this.lastAngle_ = theta;\n };\n /**\n * Handle pointer up events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n */\n DragRotate.prototype.handleUpEvent = function (mapBrowserEvent) {\n if (!mouseOnly(mapBrowserEvent)) {\n return true;\n }\n var map = mapBrowserEvent.map;\n var view = map.getView();\n view.endInteraction(this.duration_);\n return false;\n };\n /**\n * Handle pointer down events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n */\n DragRotate.prototype.handleDownEvent = function (mapBrowserEvent) {\n if (!mouseOnly(mapBrowserEvent)) {\n return false;\n }\n if (mouseActionButton(mapBrowserEvent) &&\n this.condition_(mapBrowserEvent)) {\n var map = mapBrowserEvent.map;\n map.getView().beginInteraction();\n this.lastAngle_ = undefined;\n return true;\n }\n else {\n return false;\n }\n };\n return DragRotate;\n}(PointerInteraction));\nexport default DragRotate;\n//# sourceMappingURL=DragRotate.js.map","/**\n * @module ol/render/Box\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport Disposable from '../Disposable.js';\nimport Polygon from '../geom/Polygon.js';\nvar RenderBox = /** @class */ (function (_super) {\n __extends(RenderBox, _super);\n /**\n * @param {string} className CSS class name.\n */\n function RenderBox(className) {\n var _this = _super.call(this) || this;\n /**\n * @type {import(\"../geom/Polygon.js\").default}\n * @private\n */\n _this.geometry_ = null;\n /**\n * @type {HTMLDivElement}\n * @private\n */\n _this.element_ = document.createElement('div');\n _this.element_.style.position = 'absolute';\n _this.element_.style.pointerEvents = 'auto';\n _this.element_.className = 'ol-box ' + className;\n /**\n * @private\n * @type {import(\"../PluggableMap.js\").default}\n */\n _this.map_ = null;\n /**\n * @private\n * @type {import(\"../pixel.js\").Pixel}\n */\n _this.startPixel_ = null;\n /**\n * @private\n * @type {import(\"../pixel.js\").Pixel}\n */\n _this.endPixel_ = null;\n return _this;\n }\n /**\n * Clean up.\n */\n RenderBox.prototype.disposeInternal = function () {\n this.setMap(null);\n };\n /**\n * @private\n */\n RenderBox.prototype.render_ = function () {\n var startPixel = this.startPixel_;\n var endPixel = this.endPixel_;\n var px = 'px';\n var style = this.element_.style;\n style.left = Math.min(startPixel[0], endPixel[0]) + px;\n style.top = Math.min(startPixel[1], endPixel[1]) + px;\n style.width = Math.abs(endPixel[0] - startPixel[0]) + px;\n style.height = Math.abs(endPixel[1] - startPixel[1]) + px;\n };\n /**\n * @param {import(\"../PluggableMap.js\").default} map Map.\n */\n RenderBox.prototype.setMap = function (map) {\n if (this.map_) {\n this.map_.getOverlayContainer().removeChild(this.element_);\n var style = this.element_.style;\n style.left = 'inherit';\n style.top = 'inherit';\n style.width = 'inherit';\n style.height = 'inherit';\n }\n this.map_ = map;\n if (this.map_) {\n this.map_.getOverlayContainer().appendChild(this.element_);\n }\n };\n /**\n * @param {import(\"../pixel.js\").Pixel} startPixel Start pixel.\n * @param {import(\"../pixel.js\").Pixel} endPixel End pixel.\n */\n RenderBox.prototype.setPixels = function (startPixel, endPixel) {\n this.startPixel_ = startPixel;\n this.endPixel_ = endPixel;\n this.createOrUpdateGeometry();\n this.render_();\n };\n /**\n * Creates or updates the cached geometry.\n */\n RenderBox.prototype.createOrUpdateGeometry = function () {\n var startPixel = this.startPixel_;\n var endPixel = this.endPixel_;\n var pixels = [\n startPixel,\n [startPixel[0], endPixel[1]],\n endPixel,\n [endPixel[0], startPixel[1]],\n ];\n var coordinates = pixels.map(this.map_.getCoordinateFromPixelInternal, this.map_);\n // close the polygon\n coordinates[4] = coordinates[0].slice();\n if (!this.geometry_) {\n this.geometry_ = new Polygon([coordinates]);\n }\n else {\n this.geometry_.setCoordinates([coordinates]);\n }\n };\n /**\n * @return {import(\"../geom/Polygon.js\").default} Geometry.\n */\n RenderBox.prototype.getGeometry = function () {\n return this.geometry_;\n };\n return RenderBox;\n}(Disposable));\nexport default RenderBox;\n//# sourceMappingURL=Box.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/interaction/DragBox\n */\n// FIXME draw drag box\nimport Event from '../events/Event.js';\nimport PointerInteraction from './Pointer.js';\nimport RenderBox from '../render/Box.js';\nimport { mouseActionButton } from '../events/condition.js';\n/**\n * A function that takes a {@link module:ol/MapBrowserEvent} and two\n * {@link module:ol/pixel~Pixel}s and returns a `{boolean}`. If the condition is met,\n * true should be returned.\n * @typedef {function(this: ?, import(\"../MapBrowserEvent.js\").default, import(\"../pixel.js\").Pixel, import(\"../pixel.js\").Pixel):boolean} EndCondition\n */\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-dragbox'] CSS class name for styling the box.\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that takes an {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a boolean\n * to indicate whether that event should be handled.\n * Default is {@link ol/events/condition~mouseActionButton}.\n * @property {number} [minArea=64] The minimum area of the box in pixel, this value is used by the default\n * `boxEndCondition` function.\n * @property {EndCondition} [boxEndCondition] A function that takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and two\n * {@link module:ol/pixel~Pixel}s to indicate whether a `boxend` event should be fired.\n * Default is `true` if the area of the box is bigger than the `minArea` option.\n * @property {function(this:DragBox, import(\"../MapBrowserEvent.js\").default):void} [onBoxEnd] Code to execute just\n * before `boxend` is fired.\n */\n/**\n * @enum {string}\n */\nvar DragBoxEventType = {\n /**\n * Triggered upon drag box start.\n * @event DragBoxEvent#boxstart\n * @api\n */\n BOXSTART: 'boxstart',\n /**\n * Triggered on drag when box is active.\n * @event DragBoxEvent#boxdrag\n * @api\n */\n BOXDRAG: 'boxdrag',\n /**\n * Triggered upon drag box end.\n * @event DragBoxEvent#boxend\n * @api\n */\n BOXEND: 'boxend',\n /**\n * Triggered upon drag box canceled.\n * @event DragBoxEvent#boxcancel\n * @api\n */\n BOXCANCEL: 'boxcancel',\n};\n/**\n * @classdesc\n * Events emitted by {@link module:ol/interaction/DragBox~DragBox} instances are instances of\n * this type.\n */\nvar DragBoxEvent = /** @class */ (function (_super) {\n __extends(DragBoxEvent, _super);\n /**\n * @param {string} type The event type.\n * @param {import(\"../coordinate.js\").Coordinate} coordinate The event coordinate.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Originating event.\n */\n function DragBoxEvent(type, coordinate, mapBrowserEvent) {\n var _this = _super.call(this, type) || this;\n /**\n * The coordinate of the drag event.\n * @const\n * @type {import(\"../coordinate.js\").Coordinate}\n * @api\n */\n _this.coordinate = coordinate;\n /**\n * @const\n * @type {import(\"../MapBrowserEvent.js\").default}\n * @api\n */\n _this.mapBrowserEvent = mapBrowserEvent;\n return _this;\n }\n return DragBoxEvent;\n}(Event));\nexport { DragBoxEvent };\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n * import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types|\n * 'change:active', import(\"../Object\").ObjectEvent, Return> &\n * import(\"../Observable\").OnSignature<'boxcancel'|'boxdrag'|'boxend'|'boxstart', DragBoxEvent, Return> &\n * import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").Types|\n * 'change:active'|'boxcancel'|'boxdrag'|'boxend', Return>} DragBoxOnSignature\n */\n/**\n * @classdesc\n * Allows the user to draw a vector box by clicking and dragging on the map,\n * normally combined with an {@link module:ol/events/condition} that limits\n * it to when the shift or other key is held down. This is used, for example,\n * for zooming to a specific area of the map\n * (see {@link module:ol/interaction/DragZoom~DragZoom} and\n * {@link module:ol/interaction/DragRotateAndZoom}).\n *\n * @fires DragBoxEvent\n * @api\n */\nvar DragBox = /** @class */ (function (_super) {\n __extends(DragBox, _super);\n /**\n * @param {Options} [opt_options] Options.\n */\n function DragBox(opt_options) {\n var _this = _super.call(this) || this;\n /***\n * @type {DragBoxOnSignature<import(\"../events\").EventsKey>}\n */\n _this.on;\n /***\n * @type {DragBoxOnSignature<import(\"../events\").EventsKey>}\n */\n _this.once;\n /***\n * @type {DragBoxOnSignature<void>}\n */\n _this.un;\n var options = opt_options ? opt_options : {};\n /**\n * @type {import(\"../render/Box.js\").default}\n * @private\n */\n _this.box_ = new RenderBox(options.className || 'ol-dragbox');\n /**\n * @type {number}\n * @private\n */\n _this.minArea_ = options.minArea !== undefined ? options.minArea : 64;\n if (options.onBoxEnd) {\n _this.onBoxEnd = options.onBoxEnd;\n }\n /**\n * @type {import(\"../pixel.js\").Pixel}\n * @private\n */\n _this.startPixel_ = null;\n /**\n * @private\n * @type {import(\"../events/condition.js\").Condition}\n */\n _this.condition_ = options.condition ? options.condition : mouseActionButton;\n /**\n * @private\n * @type {EndCondition}\n */\n _this.boxEndCondition_ = options.boxEndCondition\n ? options.boxEndCondition\n : _this.defaultBoxEndCondition;\n return _this;\n }\n /**\n * The default condition for determining whether the boxend event\n * should fire.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent The originating MapBrowserEvent\n * leading to the box end.\n * @param {import(\"../pixel.js\").Pixel} startPixel The starting pixel of the box.\n * @param {import(\"../pixel.js\").Pixel} endPixel The end pixel of the box.\n * @return {boolean} Whether or not the boxend condition should be fired.\n */\n DragBox.prototype.defaultBoxEndCondition = function (mapBrowserEvent, startPixel, endPixel) {\n var width = endPixel[0] - startPixel[0];\n var height = endPixel[1] - startPixel[1];\n return width * width + height * height >= this.minArea_;\n };\n /**\n * Returns geometry of last drawn box.\n * @return {import(\"../geom/Polygon.js\").default} Geometry.\n * @api\n */\n DragBox.prototype.getGeometry = function () {\n return this.box_.getGeometry();\n };\n /**\n * Handle pointer drag events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n */\n DragBox.prototype.handleDragEvent = function (mapBrowserEvent) {\n this.box_.setPixels(this.startPixel_, mapBrowserEvent.pixel);\n this.dispatchEvent(new DragBoxEvent(DragBoxEventType.BOXDRAG, mapBrowserEvent.coordinate, mapBrowserEvent));\n };\n /**\n * Handle pointer up events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n */\n DragBox.prototype.handleUpEvent = function (mapBrowserEvent) {\n this.box_.setMap(null);\n var completeBox = this.boxEndCondition_(mapBrowserEvent, this.startPixel_, mapBrowserEvent.pixel);\n if (completeBox) {\n this.onBoxEnd(mapBrowserEvent);\n }\n this.dispatchEvent(new DragBoxEvent(completeBox ? DragBoxEventType.BOXEND : DragBoxEventType.BOXCANCEL, mapBrowserEvent.coordinate, mapBrowserEvent));\n return false;\n };\n /**\n * Handle pointer down events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n */\n DragBox.prototype.handleDownEvent = function (mapBrowserEvent) {\n if (this.condition_(mapBrowserEvent)) {\n this.startPixel_ = mapBrowserEvent.pixel;\n this.box_.setMap(mapBrowserEvent.map);\n this.box_.setPixels(this.startPixel_, this.startPixel_);\n this.dispatchEvent(new DragBoxEvent(DragBoxEventType.BOXSTART, mapBrowserEvent.coordinate, mapBrowserEvent));\n return true;\n }\n else {\n return false;\n }\n };\n /**\n * Function to execute just before `onboxend` is fired\n * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n */\n DragBox.prototype.onBoxEnd = function (event) { };\n return DragBox;\n}(PointerInteraction));\nexport default DragBox;\n//# sourceMappingURL=DragBox.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/interaction/DragZoom\n */\nimport DragBox from './DragBox.js';\nimport { easeOut } from '../easing.js';\nimport { shiftKeyOnly } from '../events/condition.js';\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-dragzoom'] CSS class name for styling the\n * box.\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes an {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether that event should be handled.\n * Default is {@link module:ol/events/condition.shiftKeyOnly}.\n * @property {number} [duration=200] Animation duration in milliseconds.\n * @property {boolean} [out=false] Use interaction for zooming out.\n * @property {number} [minArea=64] The minimum area of the box in pixel, this value is used by the parent default\n * `boxEndCondition` function.\n */\n/**\n * @classdesc\n * Allows the user to zoom the map by clicking and dragging on the map,\n * normally combined with an {@link module:ol/events/condition} that limits\n * it to when a key, shift by default, is held down.\n *\n * To change the style of the box, use CSS and the `.ol-dragzoom` selector, or\n * your custom one configured with `className`.\n * @api\n */\nvar DragZoom = /** @class */ (function (_super) {\n __extends(DragZoom, _super);\n /**\n * @param {Options} [opt_options] Options.\n */\n function DragZoom(opt_options) {\n var _this = this;\n var options = opt_options ? opt_options : {};\n var condition = options.condition ? options.condition : shiftKeyOnly;\n _this = _super.call(this, {\n condition: condition,\n className: options.className || 'ol-dragzoom',\n minArea: options.minArea,\n }) || this;\n /**\n * @private\n * @type {number}\n */\n _this.duration_ = options.duration !== undefined ? options.duration : 200;\n /**\n * @private\n * @type {boolean}\n */\n _this.out_ = options.out !== undefined ? options.out : false;\n return _this;\n }\n /**\n * Function to execute just before `onboxend` is fired\n * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n */\n DragZoom.prototype.onBoxEnd = function (event) {\n var map = this.getMap();\n var view = /** @type {!import(\"../View.js\").default} */ (map.getView());\n var geometry = this.getGeometry();\n if (this.out_) {\n var rotatedExtent = view.rotatedExtentForGeometry(geometry);\n var resolution = view.getResolutionForExtentInternal(rotatedExtent);\n var factor = view.getResolution() / resolution;\n geometry = geometry.clone();\n geometry.scale(factor * factor);\n }\n view.fitInternal(geometry, {\n duration: this.duration_,\n easing: easeOut,\n });\n };\n return DragZoom;\n}(DragBox));\nexport default DragZoom;\n//# sourceMappingURL=DragZoom.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/interaction/KeyboardPan\n */\nimport EventType from '../events/EventType.js';\nimport Interaction, { pan } from './Interaction.js';\nimport KeyCode from '../events/KeyCode.js';\nimport { noModifierKeys, targetNotEditable } from '../events/condition.js';\nimport { rotate as rotateCoordinate } from '../coordinate.js';\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes an {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether that event should be handled. Default is\n * {@link module:ol/events/condition.noModifierKeys} and\n * {@link module:ol/events/condition.targetNotEditable}.\n * @property {number} [duration=100] Animation duration in milliseconds.\n * @property {number} [pixelDelta=128] The amount of pixels to pan on each key\n * press.\n */\n/**\n * @classdesc\n * Allows the user to pan the map using keyboard arrows.\n * Note that, although this interaction is by default included in maps,\n * the keys can only be used when browser focus is on the element to which\n * the keyboard events are attached. By default, this is the map div,\n * though you can change this with the `keyboardEventTarget` in\n * {@link module:ol/Map~Map}. `document` never loses focus but, for any other\n * element, focus will have to be on, and returned to, this element if the keys\n * are to function.\n * See also {@link module:ol/interaction/KeyboardZoom~KeyboardZoom}.\n * @api\n */\nvar KeyboardPan = /** @class */ (function (_super) {\n __extends(KeyboardPan, _super);\n /**\n * @param {Options} [opt_options] Options.\n */\n function KeyboardPan(opt_options) {\n var _this = _super.call(this) || this;\n var options = opt_options || {};\n /**\n * @private\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Browser event.\n * @return {boolean} Combined condition result.\n */\n _this.defaultCondition_ = function (mapBrowserEvent) {\n return (noModifierKeys(mapBrowserEvent) && targetNotEditable(mapBrowserEvent));\n };\n /**\n * @private\n * @type {import(\"../events/condition.js\").Condition}\n */\n _this.condition_ =\n options.condition !== undefined\n ? options.condition\n : _this.defaultCondition_;\n /**\n * @private\n * @type {number}\n */\n _this.duration_ = options.duration !== undefined ? options.duration : 100;\n /**\n * @private\n * @type {number}\n */\n _this.pixelDelta_ =\n options.pixelDelta !== undefined ? options.pixelDelta : 128;\n return _this;\n }\n /**\n * Handles the {@link module:ol/MapBrowserEvent map browser event} if it was a\n * `KeyEvent`, and decides the direction to pan to (if an arrow key was\n * pressed).\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} `false` to stop event propagation.\n * @this {KeyboardPan}\n */\n KeyboardPan.prototype.handleEvent = function (mapBrowserEvent) {\n var stopEvent = false;\n if (mapBrowserEvent.type == EventType.KEYDOWN) {\n var keyEvent = /** @type {KeyboardEvent} */ (mapBrowserEvent.originalEvent);\n var keyCode = keyEvent.keyCode;\n if (this.condition_(mapBrowserEvent) &&\n (keyCode == KeyCode.DOWN ||\n keyCode == KeyCode.LEFT ||\n keyCode == KeyCode.RIGHT ||\n keyCode == KeyCode.UP)) {\n var map = mapBrowserEvent.map;\n var view = map.getView();\n var mapUnitsDelta = view.getResolution() * this.pixelDelta_;\n var deltaX = 0, deltaY = 0;\n if (keyCode == KeyCode.DOWN) {\n deltaY = -mapUnitsDelta;\n }\n else if (keyCode == KeyCode.LEFT) {\n deltaX = -mapUnitsDelta;\n }\n else if (keyCode == KeyCode.RIGHT) {\n deltaX = mapUnitsDelta;\n }\n else {\n deltaY = mapUnitsDelta;\n }\n var delta = [deltaX, deltaY];\n rotateCoordinate(delta, view.getRotation());\n pan(view, delta, this.duration_);\n keyEvent.preventDefault();\n stopEvent = true;\n }\n }\n return !stopEvent;\n };\n return KeyboardPan;\n}(Interaction));\nexport default KeyboardPan;\n//# sourceMappingURL=KeyboardPan.js.map","/**\n * @module ol/events/KeyCode\n */\n/**\n * @enum {number}\n * @const\n */\nexport default {\n LEFT: 37,\n UP: 38,\n RIGHT: 39,\n DOWN: 40,\n};\n//# sourceMappingURL=KeyCode.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/interaction/KeyboardZoom\n */\nimport EventType from '../events/EventType.js';\nimport Interaction, { zoomByDelta } from './Interaction.js';\nimport { targetNotEditable } from '../events/condition.js';\n/**\n * @typedef {Object} Options\n * @property {number} [duration=100] Animation duration in milliseconds.\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes an {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether that event should be handled. Default is\n * {@link module:ol/events/condition.targetNotEditable}.\n * @property {number} [delta=1] The zoom level delta on each key press.\n */\n/**\n * @classdesc\n * Allows the user to zoom the map using keyboard + and -.\n * Note that, although this interaction is by default included in maps,\n * the keys can only be used when browser focus is on the element to which\n * the keyboard events are attached. By default, this is the map div,\n * though you can change this with the `keyboardEventTarget` in\n * {@link module:ol/Map~Map}. `document` never loses focus but, for any other\n * element, focus will have to be on, and returned to, this element if the keys\n * are to function.\n * See also {@link module:ol/interaction/KeyboardPan~KeyboardPan}.\n * @api\n */\nvar KeyboardZoom = /** @class */ (function (_super) {\n __extends(KeyboardZoom, _super);\n /**\n * @param {Options} [opt_options] Options.\n */\n function KeyboardZoom(opt_options) {\n var _this = _super.call(this) || this;\n var options = opt_options ? opt_options : {};\n /**\n * @private\n * @type {import(\"../events/condition.js\").Condition}\n */\n _this.condition_ = options.condition ? options.condition : targetNotEditable;\n /**\n * @private\n * @type {number}\n */\n _this.delta_ = options.delta ? options.delta : 1;\n /**\n * @private\n * @type {number}\n */\n _this.duration_ = options.duration !== undefined ? options.duration : 100;\n return _this;\n }\n /**\n * Handles the {@link module:ol/MapBrowserEvent map browser event} if it was a\n * `KeyEvent`, and decides whether to zoom in or out (depending on whether the\n * key pressed was '+' or '-').\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} `false` to stop event propagation.\n * @this {KeyboardZoom}\n */\n KeyboardZoom.prototype.handleEvent = function (mapBrowserEvent) {\n var stopEvent = false;\n if (mapBrowserEvent.type == EventType.KEYDOWN ||\n mapBrowserEvent.type == EventType.KEYPRESS) {\n var keyEvent = /** @type {KeyboardEvent} */ (mapBrowserEvent.originalEvent);\n var charCode = keyEvent.charCode;\n if (this.condition_(mapBrowserEvent) &&\n (charCode == '+'.charCodeAt(0) || charCode == '-'.charCodeAt(0))) {\n var map = mapBrowserEvent.map;\n var delta = charCode == '+'.charCodeAt(0) ? this.delta_ : -this.delta_;\n var view = map.getView();\n zoomByDelta(view, delta, undefined, this.duration_);\n keyEvent.preventDefault();\n stopEvent = true;\n }\n }\n return !stopEvent;\n };\n return KeyboardZoom;\n}(Interaction));\nexport default KeyboardZoom;\n//# sourceMappingURL=KeyboardZoom.js.map","/**\n * @module ol/Kinetic\n */\n/**\n * @classdesc\n * Implementation of inertial deceleration for map movement.\n *\n * @api\n */\nvar Kinetic = /** @class */ (function () {\n /**\n * @param {number} decay Rate of decay (must be negative).\n * @param {number} minVelocity Minimum velocity (pixels/millisecond).\n * @param {number} delay Delay to consider to calculate the kinetic\n * initial values (milliseconds).\n */\n function Kinetic(decay, minVelocity, delay) {\n /**\n * @private\n * @type {number}\n */\n this.decay_ = decay;\n /**\n * @private\n * @type {number}\n */\n this.minVelocity_ = minVelocity;\n /**\n * @private\n * @type {number}\n */\n this.delay_ = delay;\n /**\n * @private\n * @type {Array<number>}\n */\n this.points_ = [];\n /**\n * @private\n * @type {number}\n */\n this.angle_ = 0;\n /**\n * @private\n * @type {number}\n */\n this.initialVelocity_ = 0;\n }\n /**\n * FIXME empty description for jsdoc\n */\n Kinetic.prototype.begin = function () {\n this.points_.length = 0;\n this.angle_ = 0;\n this.initialVelocity_ = 0;\n };\n /**\n * @param {number} x X.\n * @param {number} y Y.\n */\n Kinetic.prototype.update = function (x, y) {\n this.points_.push(x, y, Date.now());\n };\n /**\n * @return {boolean} Whether we should do kinetic animation.\n */\n Kinetic.prototype.end = function () {\n if (this.points_.length < 6) {\n // at least 2 points are required (i.e. there must be at least 6 elements\n // in the array)\n return false;\n }\n var delay = Date.now() - this.delay_;\n var lastIndex = this.points_.length - 3;\n if (this.points_[lastIndex + 2] < delay) {\n // the last tracked point is too old, which means that the user stopped\n // panning before releasing the map\n return false;\n }\n // get the first point which still falls into the delay time\n var firstIndex = lastIndex - 3;\n while (firstIndex > 0 && this.points_[firstIndex + 2] > delay) {\n firstIndex -= 3;\n }\n var duration = this.points_[lastIndex + 2] - this.points_[firstIndex + 2];\n // we don't want a duration of 0 (divide by zero)\n // we also make sure the user panned for a duration of at least one frame\n // (1/60s) to compute sane displacement values\n if (duration < 1000 / 60) {\n return false;\n }\n var dx = this.points_[lastIndex] - this.points_[firstIndex];\n var dy = this.points_[lastIndex + 1] - this.points_[firstIndex + 1];\n this.angle_ = Math.atan2(dy, dx);\n this.initialVelocity_ = Math.sqrt(dx * dx + dy * dy) / duration;\n return this.initialVelocity_ > this.minVelocity_;\n };\n /**\n * @return {number} Total distance travelled (pixels).\n */\n Kinetic.prototype.getDistance = function () {\n return (this.minVelocity_ - this.initialVelocity_) / this.decay_;\n };\n /**\n * @return {number} Angle of the kinetic panning animation (radians).\n */\n Kinetic.prototype.getAngle = function () {\n return this.angle_;\n };\n return Kinetic;\n}());\nexport default Kinetic;\n//# sourceMappingURL=Kinetic.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/interaction/MouseWheelZoom\n */\nimport EventType from '../events/EventType.js';\nimport Interaction, { zoomByDelta } from './Interaction.js';\nimport { DEVICE_PIXEL_RATIO, FIREFOX } from '../has.js';\nimport { all, always, focusWithTabindex } from '../events/condition.js';\nimport { clamp } from '../math.js';\n/**\n * @enum {string}\n */\nexport var Mode = {\n TRACKPAD: 'trackpad',\n WHEEL: 'wheel',\n};\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes an {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether that event should be handled. Default is\n * {@link module:ol/events/condition.always}.\n * @property {boolean} [onFocusOnly=false] When the map's target has a `tabindex` attribute set,\n * the interaction will only handle events when the map has the focus.\n * @property {number} [maxDelta=1] Maximum mouse wheel delta.\n * @property {number} [duration=250] Animation duration in milliseconds.\n * @property {number} [timeout=80] Mouse wheel timeout duration in milliseconds.\n * @property {boolean} [useAnchor=true] Enable zooming using the mouse's\n * location as the anchor. When set to `false`, zooming in and out will zoom to\n * the center of the screen instead of zooming on the mouse's location.\n * @property {boolean} [constrainResolution=false] If true, the mouse wheel zoom\n * event will always animate to the closest zoom level after an interaction;\n * false means intermediary zoom levels are allowed.\n */\n/**\n * @classdesc\n * Allows the user to zoom the map by scrolling the mouse wheel.\n * @api\n */\nvar MouseWheelZoom = /** @class */ (function (_super) {\n __extends(MouseWheelZoom, _super);\n /**\n * @param {Options} [opt_options] Options.\n */\n function MouseWheelZoom(opt_options) {\n var _this = this;\n var options = opt_options ? opt_options : {};\n _this = _super.call(this, \n /** @type {import(\"./Interaction.js\").InteractionOptions} */ (options)) || this;\n /**\n * @private\n * @type {number}\n */\n _this.totalDelta_ = 0;\n /**\n * @private\n * @type {number}\n */\n _this.lastDelta_ = 0;\n /**\n * @private\n * @type {number}\n */\n _this.maxDelta_ = options.maxDelta !== undefined ? options.maxDelta : 1;\n /**\n * @private\n * @type {number}\n */\n _this.duration_ = options.duration !== undefined ? options.duration : 250;\n /**\n * @private\n * @type {number}\n */\n _this.timeout_ = options.timeout !== undefined ? options.timeout : 80;\n /**\n * @private\n * @type {boolean}\n */\n _this.useAnchor_ =\n options.useAnchor !== undefined ? options.useAnchor : true;\n /**\n * @private\n * @type {boolean}\n */\n _this.constrainResolution_ =\n options.constrainResolution !== undefined\n ? options.constrainResolution\n : false;\n var condition = options.condition ? options.condition : always;\n /**\n * @private\n * @type {import(\"../events/condition.js\").Condition}\n */\n _this.condition_ = options.onFocusOnly\n ? all(focusWithTabindex, condition)\n : condition;\n /**\n * @private\n * @type {?import(\"../coordinate.js\").Coordinate}\n */\n _this.lastAnchor_ = null;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.startTime_ = undefined;\n /**\n * @private\n * @type {?}\n */\n _this.timeoutId_;\n /**\n * @private\n * @type {Mode|undefined}\n */\n _this.mode_ = undefined;\n /**\n * Trackpad events separated by this delay will be considered separate\n * interactions.\n * @type {number}\n */\n _this.trackpadEventGap_ = 400;\n /**\n * @type {?}\n */\n _this.trackpadTimeoutId_;\n /**\n * The number of delta values per zoom level\n * @private\n * @type {number}\n */\n _this.deltaPerZoom_ = 300;\n return _this;\n }\n /**\n * @private\n */\n MouseWheelZoom.prototype.endInteraction_ = function () {\n this.trackpadTimeoutId_ = undefined;\n var view = this.getMap().getView();\n view.endInteraction(undefined, this.lastDelta_ ? (this.lastDelta_ > 0 ? 1 : -1) : 0, this.lastAnchor_);\n };\n /**\n * Handles the {@link module:ol/MapBrowserEvent map browser event} (if it was a mousewheel-event) and eventually\n * zooms the map.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} `false` to stop event propagation.\n */\n MouseWheelZoom.prototype.handleEvent = function (mapBrowserEvent) {\n if (!this.condition_(mapBrowserEvent)) {\n return true;\n }\n var type = mapBrowserEvent.type;\n if (type !== EventType.WHEEL) {\n return true;\n }\n var map = mapBrowserEvent.map;\n var wheelEvent = /** @type {WheelEvent} */ (mapBrowserEvent.originalEvent);\n wheelEvent.preventDefault();\n if (this.useAnchor_) {\n this.lastAnchor_ = mapBrowserEvent.coordinate;\n }\n // Delta normalisation inspired by\n // https://github.com/mapbox/mapbox-gl-js/blob/001c7b9/js/ui/handler/scroll_zoom.js\n var delta;\n if (mapBrowserEvent.type == EventType.WHEEL) {\n delta = wheelEvent.deltaY;\n if (FIREFOX && wheelEvent.deltaMode === WheelEvent.DOM_DELTA_PIXEL) {\n delta /= DEVICE_PIXEL_RATIO;\n }\n if (wheelEvent.deltaMode === WheelEvent.DOM_DELTA_LINE) {\n delta *= 40;\n }\n }\n if (delta === 0) {\n return false;\n }\n else {\n this.lastDelta_ = delta;\n }\n var now = Date.now();\n if (this.startTime_ === undefined) {\n this.startTime_ = now;\n }\n if (!this.mode_ || now - this.startTime_ > this.trackpadEventGap_) {\n this.mode_ = Math.abs(delta) < 4 ? Mode.TRACKPAD : Mode.WHEEL;\n }\n var view = map.getView();\n if (this.mode_ === Mode.TRACKPAD &&\n !(view.getConstrainResolution() || this.constrainResolution_)) {\n if (this.trackpadTimeoutId_) {\n clearTimeout(this.trackpadTimeoutId_);\n }\n else {\n if (view.getAnimating()) {\n view.cancelAnimations();\n }\n view.beginInteraction();\n }\n this.trackpadTimeoutId_ = setTimeout(this.endInteraction_.bind(this), this.timeout_);\n view.adjustZoom(-delta / this.deltaPerZoom_, this.lastAnchor_);\n this.startTime_ = now;\n return false;\n }\n this.totalDelta_ += delta;\n var timeLeft = Math.max(this.timeout_ - (now - this.startTime_), 0);\n clearTimeout(this.timeoutId_);\n this.timeoutId_ = setTimeout(this.handleWheelZoom_.bind(this, map), timeLeft);\n return false;\n };\n /**\n * @private\n * @param {import(\"../PluggableMap.js\").default} map Map.\n */\n MouseWheelZoom.prototype.handleWheelZoom_ = function (map) {\n var view = map.getView();\n if (view.getAnimating()) {\n view.cancelAnimations();\n }\n var delta = -clamp(this.totalDelta_, -this.maxDelta_ * this.deltaPerZoom_, this.maxDelta_ * this.deltaPerZoom_) / this.deltaPerZoom_;\n if (view.getConstrainResolution() || this.constrainResolution_) {\n // view has a zoom constraint, zoom by 1\n delta = delta ? (delta > 0 ? 1 : -1) : 0;\n }\n zoomByDelta(view, delta, this.lastAnchor_, this.duration_);\n this.mode_ = undefined;\n this.totalDelta_ = 0;\n this.lastAnchor_ = null;\n this.startTime_ = undefined;\n this.timeoutId_ = undefined;\n };\n /**\n * Enable or disable using the mouse's location as an anchor when zooming\n * @param {boolean} useAnchor true to zoom to the mouse's location, false\n * to zoom to the center of the map\n * @api\n */\n MouseWheelZoom.prototype.setMouseAnchor = function (useAnchor) {\n this.useAnchor_ = useAnchor;\n if (!useAnchor) {\n this.lastAnchor_ = null;\n }\n };\n return MouseWheelZoom;\n}(Interaction));\nexport default MouseWheelZoom;\n//# sourceMappingURL=MouseWheelZoom.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/interaction/PinchRotate\n */\nimport PointerInteraction, { centroid as centroidFromPointers, } from './Pointer.js';\nimport { FALSE } from '../functions.js';\nimport { disable } from '../rotationconstraint.js';\n/**\n * @typedef {Object} Options\n * @property {number} [duration=250] The duration of the animation in\n * milliseconds.\n * @property {number} [threshold=0.3] Minimal angle in radians to start a rotation.\n */\n/**\n * @classdesc\n * Allows the user to rotate the map by twisting with two fingers\n * on a touch screen.\n * @api\n */\nvar PinchRotate = /** @class */ (function (_super) {\n __extends(PinchRotate, _super);\n /**\n * @param {Options} [opt_options] Options.\n */\n function PinchRotate(opt_options) {\n var _this = this;\n var options = opt_options ? opt_options : {};\n var pointerOptions = /** @type {import(\"./Pointer.js\").Options} */ (options);\n if (!pointerOptions.stopDown) {\n pointerOptions.stopDown = FALSE;\n }\n _this = _super.call(this, pointerOptions) || this;\n /**\n * @private\n * @type {import(\"../coordinate.js\").Coordinate}\n */\n _this.anchor_ = null;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.lastAngle_ = undefined;\n /**\n * @private\n * @type {boolean}\n */\n _this.rotating_ = false;\n /**\n * @private\n * @type {number}\n */\n _this.rotationDelta_ = 0.0;\n /**\n * @private\n * @type {number}\n */\n _this.threshold_ = options.threshold !== undefined ? options.threshold : 0.3;\n /**\n * @private\n * @type {number}\n */\n _this.duration_ = options.duration !== undefined ? options.duration : 250;\n return _this;\n }\n /**\n * Handle pointer drag events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n */\n PinchRotate.prototype.handleDragEvent = function (mapBrowserEvent) {\n var rotationDelta = 0.0;\n var touch0 = this.targetPointers[0];\n var touch1 = this.targetPointers[1];\n // angle between touches\n var angle = Math.atan2(touch1.clientY - touch0.clientY, touch1.clientX - touch0.clientX);\n if (this.lastAngle_ !== undefined) {\n var delta = angle - this.lastAngle_;\n this.rotationDelta_ += delta;\n if (!this.rotating_ && Math.abs(this.rotationDelta_) > this.threshold_) {\n this.rotating_ = true;\n }\n rotationDelta = delta;\n }\n this.lastAngle_ = angle;\n var map = mapBrowserEvent.map;\n var view = map.getView();\n if (view.getConstraints().rotation === disable) {\n return;\n }\n // rotate anchor point.\n // FIXME: should be the intersection point between the lines:\n // touch0,touch1 and previousTouch0,previousTouch1\n var viewportPosition = map.getViewport().getBoundingClientRect();\n var centroid = centroidFromPointers(this.targetPointers);\n centroid[0] -= viewportPosition.left;\n centroid[1] -= viewportPosition.top;\n this.anchor_ = map.getCoordinateFromPixelInternal(centroid);\n // rotate\n if (this.rotating_) {\n map.render();\n view.adjustRotationInternal(rotationDelta, this.anchor_);\n }\n };\n /**\n * Handle pointer up events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n */\n PinchRotate.prototype.handleUpEvent = function (mapBrowserEvent) {\n if (this.targetPointers.length < 2) {\n var map = mapBrowserEvent.map;\n var view = map.getView();\n view.endInteraction(this.duration_);\n return false;\n }\n else {\n return true;\n }\n };\n /**\n * Handle pointer down events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n */\n PinchRotate.prototype.handleDownEvent = function (mapBrowserEvent) {\n if (this.targetPointers.length >= 2) {\n var map = mapBrowserEvent.map;\n this.anchor_ = null;\n this.lastAngle_ = undefined;\n this.rotating_ = false;\n this.rotationDelta_ = 0.0;\n if (!this.handlingDownUpSequence) {\n map.getView().beginInteraction();\n }\n return true;\n }\n else {\n return false;\n }\n };\n return PinchRotate;\n}(PointerInteraction));\nexport default PinchRotate;\n//# sourceMappingURL=PinchRotate.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/interaction/PinchZoom\n */\nimport PointerInteraction, { centroid as centroidFromPointers, } from './Pointer.js';\nimport { FALSE } from '../functions.js';\n/**\n * @typedef {Object} Options\n * @property {number} [duration=400] Animation duration in milliseconds.\n */\n/**\n * @classdesc\n * Allows the user to zoom the map by pinching with two fingers\n * on a touch screen.\n * @api\n */\nvar PinchZoom = /** @class */ (function (_super) {\n __extends(PinchZoom, _super);\n /**\n * @param {Options} [opt_options] Options.\n */\n function PinchZoom(opt_options) {\n var _this = this;\n var options = opt_options ? opt_options : {};\n var pointerOptions = /** @type {import(\"./Pointer.js\").Options} */ (options);\n if (!pointerOptions.stopDown) {\n pointerOptions.stopDown = FALSE;\n }\n _this = _super.call(this, pointerOptions) || this;\n /**\n * @private\n * @type {import(\"../coordinate.js\").Coordinate}\n */\n _this.anchor_ = null;\n /**\n * @private\n * @type {number}\n */\n _this.duration_ = options.duration !== undefined ? options.duration : 400;\n /**\n * @private\n * @type {number|undefined}\n */\n _this.lastDistance_ = undefined;\n /**\n * @private\n * @type {number}\n */\n _this.lastScaleDelta_ = 1;\n return _this;\n }\n /**\n * Handle pointer drag events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n */\n PinchZoom.prototype.handleDragEvent = function (mapBrowserEvent) {\n var scaleDelta = 1.0;\n var touch0 = this.targetPointers[0];\n var touch1 = this.targetPointers[1];\n var dx = touch0.clientX - touch1.clientX;\n var dy = touch0.clientY - touch1.clientY;\n // distance between touches\n var distance = Math.sqrt(dx * dx + dy * dy);\n if (this.lastDistance_ !== undefined) {\n scaleDelta = this.lastDistance_ / distance;\n }\n this.lastDistance_ = distance;\n var map = mapBrowserEvent.map;\n var view = map.getView();\n if (scaleDelta != 1.0) {\n this.lastScaleDelta_ = scaleDelta;\n }\n // scale anchor point.\n var viewportPosition = map.getViewport().getBoundingClientRect();\n var centroid = centroidFromPointers(this.targetPointers);\n centroid[0] -= viewportPosition.left;\n centroid[1] -= viewportPosition.top;\n this.anchor_ = map.getCoordinateFromPixelInternal(centroid);\n // scale, bypass the resolution constraint\n map.render();\n view.adjustResolutionInternal(scaleDelta, this.anchor_);\n };\n /**\n * Handle pointer up events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n */\n PinchZoom.prototype.handleUpEvent = function (mapBrowserEvent) {\n if (this.targetPointers.length < 2) {\n var map = mapBrowserEvent.map;\n var view = map.getView();\n var direction = this.lastScaleDelta_ > 1 ? 1 : -1;\n view.endInteraction(this.duration_, direction);\n return false;\n }\n else {\n return true;\n }\n };\n /**\n * Handle pointer down events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n */\n PinchZoom.prototype.handleDownEvent = function (mapBrowserEvent) {\n if (this.targetPointers.length >= 2) {\n var map = mapBrowserEvent.map;\n this.anchor_ = null;\n this.lastDistance_ = undefined;\n this.lastScaleDelta_ = 1;\n if (!this.handlingDownUpSequence) {\n map.getView().beginInteraction();\n }\n return true;\n }\n else {\n return false;\n }\n };\n return PinchZoom;\n}(PointerInteraction));\nexport default PinchZoom;\n//# sourceMappingURL=PinchZoom.js.map","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\n/**\n * @module ol/Map\n */\nimport CompositeMapRenderer from './renderer/Composite.js';\nimport PluggableMap from './PluggableMap.js';\nimport { assign } from './obj.js';\nimport { defaults as defaultControls } from './control.js';\nimport { defaults as defaultInteractions } from './interaction.js';\n/**\n * @classdesc\n * The map is the core component of OpenLayers. For a map to render, a view,\n * one or more layers, and a target container are needed:\n *\n * import Map from 'ol/Map';\n * import View from 'ol/View';\n * import TileLayer from 'ol/layer/Tile';\n * import OSM from 'ol/source/OSM';\n *\n * var map = new Map({\n * view: new View({\n * center: [0, 0],\n * zoom: 1\n * }),\n * layers: [\n * new TileLayer({\n * source: new OSM()\n * })\n * ],\n * target: 'map'\n * });\n *\n * The above snippet creates a map using a {@link module:ol/layer/Tile} to\n * display {@link module:ol/source/OSM~OSM} OSM data and render it to a DOM\n * element with the id `map`.\n *\n * The constructor places a viewport container (with CSS class name\n * `ol-viewport`) in the target element (see `getViewport()`), and then two\n * further elements within the viewport: one with CSS class name\n * `ol-overlaycontainer-stopevent` for controls and some overlays, and one with\n * CSS class name `ol-overlaycontainer` for other overlays (see the `stopEvent`\n * option of {@link module:ol/Overlay~Overlay} for the difference). The map\n * itself is placed in a further element within the viewport.\n *\n * Layers are stored as a {@link module:ol/Collection~Collection} in\n * layerGroups. A top-level group is provided by the library. This is what is\n * accessed by `getLayerGroup` and `setLayerGroup`. Layers entered in the\n * options are added to this group, and `addLayer` and `removeLayer` change the\n * layer collection in the group. `getLayers` is a convenience function for\n * `getLayerGroup().getLayers()`. Note that {@link module:ol/layer/Group~Group}\n * is a subclass of {@link module:ol/layer/Base}, so layers entered in the\n * options or added with `addLayer` can be groups, which can contain further\n * groups, and so on.\n *\n * @api\n */\nvar Map = /** @class */ (function (_super) {\n __extends(Map, _super);\n /**\n * @param {import(\"./PluggableMap.js\").MapOptions} options Map options.\n */\n function Map(options) {\n var _this = this;\n options = assign({}, options);\n if (!options.controls) {\n options.controls = defaultControls();\n }\n if (!options.interactions) {\n options.interactions = defaultInteractions({\n onFocusOnly: true,\n });\n }\n _this = _super.call(this, options) || this;\n return _this;\n }\n Map.prototype.createRenderer = function () {\n return new CompositeMapRenderer(this);\n };\n return Map;\n}(PluggableMap));\nexport default Map;\n//# sourceMappingURL=Map.js.map","/**\n * @module ol/control\n */\nimport Attribution from './control/Attribution.js';\nimport Collection from './Collection.js';\nimport Rotate from './control/Rotate.js';\nimport Zoom from './control/Zoom.js';\nexport { default as Attribution } from './control/Attribution.js';\nexport { default as Control } from './control/Control.js';\nexport { default as FullScreen } from './control/FullScreen.js';\nexport { default as MousePosition } from './control/MousePosition.js';\nexport { default as OverviewMap } from './control/OverviewMap.js';\nexport { default as Rotate } from './control/Rotate.js';\nexport { default as ScaleLine } from './control/ScaleLine.js';\nexport { default as Zoom } from './control/Zoom.js';\nexport { default as ZoomSlider } from './control/ZoomSlider.js';\nexport { default as ZoomToExtent } from './control/ZoomToExtent.js';\n/**\n * @typedef {Object} DefaultsOptions\n * @property {boolean} [attribution=true] Include\n * {@link module:ol/control/Attribution~Attribution}.\n * @property {import(\"./control/Attribution.js\").Options} [attributionOptions]\n * Options for {@link module:ol/control/Attribution~Attribution}.\n * @property {boolean} [rotate=true] Include\n * {@link module:ol/control/Rotate~Rotate}.\n * @property {import(\"./control/Rotate.js\").Options} [rotateOptions] Options\n * for {@link module:ol/control/Rotate~Rotate}.\n * @property {boolean} [zoom] Include {@link module:ol/control/Zoom~Zoom}.\n * @property {import(\"./control/Zoom.js\").Options} [zoomOptions] Options for\n * {@link module:ol/control/Zoom~Zoom}.\n * @api\n */\n/**\n * Set of controls included in maps by default. Unless configured otherwise,\n * this returns a collection containing an instance of each of the following\n * controls:\n * * {@link module:ol/control/Zoom~Zoom}\n * * {@link module:ol/control/Rotate~Rotate}\n * * {@link module:ol/control/Attribution~Attribution}\n *\n * @param {DefaultsOptions} [opt_options]\n * Defaults options.\n * @return {Collection<import(\"./control/Control.js\").default>}\n * Controls.\n * @api\n */\nexport function defaults(opt_options) {\n var options = opt_options ? opt_options : {};\n var controls = new Collection();\n var zoomControl = options.zoom !== undefined ? options.zoom : true;\n if (zoomControl) {\n controls.push(new Zoom(options.zoomOptions));\n }\n var rotateControl = options.rotate !== undefined ? options.rotate : true;\n if (rotateControl) {\n controls.push(new Rotate(options.rotateOptions));\n }\n var attributionControl = options.attribution !== undefined ? options.attribution : true;\n if (attributionControl) {\n controls.push(new Attribution(options.attributionOptions));\n }\n return controls;\n}\n//# sourceMappingURL=control.js.map","/**\n * @module ol/interaction\n */\nimport Collection from './Collection.js';\nimport DoubleClickZoom from './interaction/DoubleClickZoom.js';\nimport DragPan from './interaction/DragPan.js';\nimport DragRotate from './interaction/DragRotate.js';\nimport DragZoom from './interaction/DragZoom.js';\nimport KeyboardPan from './interaction/KeyboardPan.js';\nimport KeyboardZoom from './interaction/KeyboardZoom.js';\nimport Kinetic from './Kinetic.js';\nimport MouseWheelZoom from './interaction/MouseWheelZoom.js';\nimport PinchRotate from './interaction/PinchRotate.js';\nimport PinchZoom from './interaction/PinchZoom.js';\nexport { default as DoubleClickZoom } from './interaction/DoubleClickZoom.js';\nexport { default as DragAndDrop } from './interaction/DragAndDrop.js';\nexport { default as DragBox } from './interaction/DragBox.js';\nexport { default as DragPan } from './interaction/DragPan.js';\nexport { default as DragRotate } from './interaction/DragRotate.js';\nexport { default as DragRotateAndZoom } from './interaction/DragRotateAndZoom.js';\nexport { default as DragZoom } from './interaction/DragZoom.js';\nexport { default as Draw } from './interaction/Draw.js';\nexport { default as Extent } from './interaction/Extent.js';\nexport { default as Interaction } from './interaction/Interaction.js';\nexport { default as KeyboardPan } from './interaction/KeyboardPan.js';\nexport { default as KeyboardZoom } from './interaction/KeyboardZoom.js';\nexport { default as Modify } from './interaction/Modify.js';\nexport { default as MouseWheelZoom } from './interaction/MouseWheelZoom.js';\nexport { default as PinchRotate } from './interaction/PinchRotate.js';\nexport { default as PinchZoom } from './interaction/PinchZoom.js';\nexport { default as Pointer } from './interaction/Pointer.js';\nexport { default as Select } from './interaction/Select.js';\nexport { default as Snap } from './interaction/Snap.js';\nexport { default as Translate } from './interaction/Translate.js';\n/**\n * @typedef {Object} DefaultsOptions\n * @property {boolean} [altShiftDragRotate=true] Whether Alt-Shift-drag rotate is\n * desired.\n * @property {boolean} [onFocusOnly=false] Interact only when the map has the\n * focus. This affects the `MouseWheelZoom` and `DragPan` interactions and is\n * useful when page scroll is desired for maps that do not have the browser's\n * focus.\n * @property {boolean} [doubleClickZoom=true] Whether double click zoom is\n * desired.\n * @property {boolean} [keyboard=true] Whether keyboard interaction is desired.\n * @property {boolean} [mouseWheelZoom=true] Whether mousewheel zoom is desired.\n * @property {boolean} [shiftDragZoom=true] Whether Shift-drag zoom is desired.\n * @property {boolean} [dragPan=true] Whether drag pan is desired.\n * @property {boolean} [pinchRotate=true] Whether pinch rotate is desired.\n * @property {boolean} [pinchZoom=true] Whether pinch zoom is desired.\n * @property {number} [zoomDelta] Zoom level delta when using keyboard or double click zoom.\n * @property {number} [zoomDuration] Duration of the zoom animation in\n * milliseconds.\n */\n/**\n * Set of interactions included in maps by default. Specific interactions can be\n * excluded by setting the appropriate option to false in the constructor\n * options, but the order of the interactions is fixed. If you want to specify\n * a different order for interactions, you will need to create your own\n * {@link module:ol/interaction/Interaction} instances and insert\n * them into a {@link module:ol/Collection} in the order you want\n * before creating your {@link module:ol/Map~Map} instance. Changing the order can\n * be of interest if the event propagation needs to be stopped at a point.\n * The default set of interactions, in sequence, is:\n * * {@link module:ol/interaction/DragRotate~DragRotate}\n * * {@link module:ol/interaction/DoubleClickZoom~DoubleClickZoom}\n * * {@link module:ol/interaction/DragPan~DragPan}\n * * {@link module:ol/interaction/PinchRotate~PinchRotate}\n * * {@link module:ol/interaction/PinchZoom~PinchZoom}\n * * {@link module:ol/interaction/KeyboardPan~KeyboardPan}\n * * {@link module:ol/interaction/KeyboardZoom~KeyboardZoom}\n * * {@link module:ol/interaction/MouseWheelZoom~MouseWheelZoom}\n * * {@link module:ol/interaction/DragZoom~DragZoom}\n *\n * @param {DefaultsOptions} [opt_options] Defaults options.\n * @return {import(\"./Collection.js\").default<import(\"./interaction/Interaction.js\").default>}\n * A collection of interactions to be used with the {@link module:ol/Map~Map}\n * constructor's `interactions` option.\n * @api\n */\nexport function defaults(opt_options) {\n var options = opt_options ? opt_options : {};\n var interactions = new Collection();\n var kinetic = new Kinetic(-0.005, 0.05, 100);\n var altShiftDragRotate = options.altShiftDragRotate !== undefined\n ? options.altShiftDragRotate\n : true;\n if (altShiftDragRotate) {\n interactions.push(new DragRotate());\n }\n var doubleClickZoom = options.doubleClickZoom !== undefined ? options.doubleClickZoom : true;\n if (doubleClickZoom) {\n interactions.push(new DoubleClickZoom({\n delta: options.zoomDelta,\n duration: options.zoomDuration,\n }));\n }\n var dragPan = options.dragPan !== undefined ? options.dragPan : true;\n if (dragPan) {\n interactions.push(new DragPan({\n onFocusOnly: options.onFocusOnly,\n kinetic: kinetic,\n }));\n }\n var pinchRotate = options.pinchRotate !== undefined ? options.pinchRotate : true;\n if (pinchRotate) {\n interactions.push(new PinchRotate());\n }\n var pinchZoom = options.pinchZoom !== undefined ? options.pinchZoom : true;\n if (pinchZoom) {\n interactions.push(new PinchZoom({\n duration: options.zoomDuration,\n }));\n }\n var keyboard = options.keyboard !== undefined ? options.keyboard : true;\n if (keyboard) {\n interactions.push(new KeyboardPan());\n interactions.push(new KeyboardZoom({\n delta: options.zoomDelta,\n duration: options.zoomDuration,\n }));\n }\n var mouseWheelZoom = options.mouseWheelZoom !== undefined ? options.mouseWheelZoom : true;\n if (mouseWheelZoom) {\n interactions.push(new MouseWheelZoom({\n onFocusOnly: options.onFocusOnly,\n duration: options.zoomDuration,\n }));\n }\n var shiftDragZoom = options.shiftDragZoom !== undefined ? options.shiftDragZoom : true;\n if (shiftDragZoom) {\n interactions.push(new DragZoom({\n duration: options.zoomDuration,\n }));\n }\n return interactions;\n}\n//# sourceMappingURL=interaction.js.map","import { Attribution, MousePosition, Zoom } from 'ol/control.js';\nimport { createStringXY } from 'ol/coordinate.js';\nimport { boundingExtent } from 'ol/extent.js';\nimport { LineString, LinearRing, MultiLineString, MultiPoint, MultiPolygon, Point, Polygon } from 'ol/geom.js';\nimport { Tile, Vector as VectorLayer } from 'ol/layer.js';\nimport { fromLonLat, get, transformExtent } from 'ol/proj.js';\nimport { OSM, Vector as VectorSource } from 'ol/source.js';\nimport { Circle, Fill, Stroke, Style, Text } from 'ol/style.js';\nimport { Feature, Map, View } from 'ol';\n\nconst ol = {\n control: {\n Attribution, MousePosition, Zoom\n },\n coordinate: {\n createStringXY\n },\n extent: {\n boundingExtent\n },\n geom: {\n LineString, LinearRing, MultiLineString, MultiPoint, MultiPolygon, Point, Polygon\n },\n layer: {\n Tile, Vector: VectorLayer\n },\n proj: {\n fromLonLat, get, transformExtent\n },\n source: {\n OSM, Vector: VectorSource\n },\n style: {\n Circle, Fill, Stroke, Style, Text\n },\n Feature, Map, View\n}\n\nexport default ol;"],"names":["root","factory","exports","module","define","amd","self","__webpack_require__","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","BaseEvent","type","this","propagationStopped","defaultPrevented","target","preventDefault","stopPropagation","Disposable","disposed","dispose","disposeInternal","numberSafeCompareFunction","a","b","linearFindNearest","arr","direction","n","length","i","reverseSubArray","begin","end","tmp","data","extension","Array","isArray","equals","arr1","arr2","len1","TRUE","VOID","assign","var_sources","TypeError","output","ii","arguments","source","clear","object","property","getValues","values","push","extendStatics","__extends","d","setPrototypeOf","__proto__","p","String","__","constructor","create","_super","Target","opt_target","_this","eventTarget_","pendingRemovals_","dispatching_","listeners_","addEventListener","listener","listeners","listenersForType","indexOf","dispatchEvent","event","evt","Event","propagate","dispatching","pendingRemovals","handleEvent","pr","removeEventListener","getListeners","undefined","hasListener","opt_type","keys","index","splice","listen","opt_this","opt_once","bind","originalListener_1","apply","eventsKey","listenOnce","unlistenByKey","Observable","on","once","un","revision_","changed","EventType","getRevision","onInternal","len","onceInternal","ol_key","unInternal","unByKey","Error","uidCounter_","getUid","ol_uid","ObjectEvent","oldValue","BaseObject","opt_values","values_","setProperties","value","getKeys","getProperties","hasProperties","notify","eventType","ObjectEventType","addChangeListener","removeChangeListener","set","opt_silent","applyProperties","unset","ua","navigator","userAgent","toLowerCase","FIREFOX","WEBKIT","DEVICE_PIXEL_RATIO","devicePixelRatio","WORKER_OFFSCREEN_CANVAS","WorkerGlobalScope","OffscreenCanvas","IMAGE_DECODE","Image","decode","PASSIVE_EVENT_LISTENERS","passive","options","window","error","createCanvasContext2D","opt_width","opt_height","opt_canvasPool","opt_Context2DSettings","canvas","shift","document","createElement","style","all","width","height","getContext","replaceNode","newNode","oldNode","parent","parentNode","replaceChild","removeNode","node","removeChild","Control","element","pointerEvents","target_","map_","listenerKeys","render","setTarget","getMap","setMap","map","getOverlayContainerStopEvent","appendChild","MapEventType","mapEvent","getElementById","CLASS_HIDDEN","CLASS_UNSELECTABLE","CLASS_CONTROL","CLASS_COLLAPSED","fontRegEx","RegExp","join","fontRegExMatchIndex","getFontParameters","fontSpec","match","lineHeight","size","weight","variant","families","family","split","cssOpacity","opacity","Math","round","AssertionError","code","message","name","assertion","errorCode","min","max","cosh","x","y","exp","log2","log","LOG2E","squaredSegmentDistance","x1","y1","x2","y2","dx","dy","t","angleInDegrees","PI","r","lerp","BaseLayer","properties","visible","zIndex","maxResolution","Infinity","minResolution","minZoom","maxZoom","className_","className","state_","getClassName","getLayerState","opt_managed","state","layer","managed","getZIndex","getOpacity","sourceState","getSourceState","getVisible","extent","getExtent","getMaxResolution","getMinResolution","getMinZoom","getMaxZoom","getLayersArray","opt_array","getLayerStatesArray","opt_states","setExtent","setMaxResolution","setMinResolution","setMaxZoom","setMinZoom","setOpacity","setVisible","setZIndex","zindex","inView","layerState","viewState","resolution","zoom","Layer","baseOptions","mapPrecomposeKey_","mapRenderKey_","sourceChangeKey_","renderer_","handleSourcePropertyChange_","setSource","array","states","getSource","getState","handleSourceChange_","getFeatures","pixel","Promise","resolve","frameState","layerRenderer","getRenderer","prepareFrame","renderFrame","layerStatesArray","some","arrayLayerState","createRenderer","hasRenderer","Base","Attribution","opt_options","ulElement_","collapsed_","collapsed","userCollapsed_","overrideCollapsible_","collapsible","collapsible_","tipLabel","expandClassName","collapseLabel","collapseClassName","collapseLabel_","textContent","label","label_","activeLabel","toggleButton_","setAttribute","title","handleClick_","cssClasses","renderedAttributions_","renderedVisible_","collectSourceAttributions_","lookup","visibleAttributions","attributionGetter","getAttributions","attributions","getAttributionsCollapsible","j","jj","setCollapsible","updateElement_","display","lastChild","removeChildren","innerHTML","handleToggle_","classList","toggle","getCollapsible","setCollapsed","getCollapsed","Units","RADIANS","DEGREES","FEET","METERS","PIXELS","TILE_PIXELS","USFEET","Projection","code_","units_","extent_","worldExtent_","worldExtent","axisOrientation_","axisOrientation","global_","global","canWrapX_","getPointResolutionFunc_","getPointResolution","defaultTileGrid_","metersPerUnit_","metersPerUnit","canWrapX","getCode","getUnits","getMetersPerUnit","getWorldExtent","getAxisOrientation","isGlobal","setGlobal","getDefaultTileGrid","setDefaultTileGrid","tileGrid","setWorldExtent","setGetPointResolution","func","getPointResolutionFunc","RADIUS","HALF_SIZE","EXTENT","WORLD_EXTENT","MAX_SAFE_Y","tan","EPSG3857Projection","units","point","PROJECTIONS","EPSG4326Projection","opt_axisOrientation","cache","transforms","destination","transformFn","sourceCode","destinationCode","BOTTOM_LEFT","BOTTOM_RIGHT","TOP_LEFT","TOP_RIGHT","UNKNOWN","INTERSECTING","ABOVE","RIGHT","BELOW","LEFT","boundingExtent","coordinates","extendCoordinate","buffer","opt_extent","clone","slice","closestSquaredDistanceXY","containsCoordinate","coordinate","containsXY","containsExtent","extent1","extent2","coordinateRelationship","minX","minY","maxX","maxY","relationship","Relationship","createOrUpdate","createOrUpdateEmpty","createOrUpdateFromFlatCoordinates","flatCoordinates","offset","stride","extendFlatCoordinates","extendXY","forEachCorner","callback","val","getBottomLeft","getBottomRight","getTopRight","getTopLeft","getArea","area","getHeight","getCenter","getCorner","corner","Corner","getForViewAndSize","center","rotation","cosRotation","cos","sinRotation","sin","xCos","xSin","yCos","ySin","x0","x3","y0","y3","getIntersection","intersection","intersects","DEFAULT_RADIUS","getDistance","c1","c2","opt_radius","radius","lat1","lat2","deltaLatBy2","deltaLonBy2","atan2","sqrt","cloneTransform","input","opt_output","opt_dimension","identityTransform","addProjection","projection","add","projectionLike","replace","opt_units","pointResolution","getter","toEPSG4326_1","getTransformFromProjections","vertices","addEquivalentProjections","projections","forEach","addProjections","createProjection","defaultCode","equivalent","projection1","projection2","equalUnits","sourceProjection","destinationProjection","transformFunc","transform","getTransform","transformExtent","opt_stops","xs","ys","l","_boundingExtentXYs","applyTransform","projections2","forwardTransform","inverseTransform","userProjection","getUserProjection","toUserCoordinate","fromUserCoordinate","destProjection","toUserResolution","dimension","atan","PROJECTION","COORDINATE_FORMAT","MousePosition","handleProjectionChanged_","coordinateFormat","setCoordinateFormat","setProjection","renderOnMouseOut","placeholder","undefinedHTML","placeholder_","renderOnMouseOut_","renderedHTML_","mapProjection_","transform_","getCoordinateFormat","getProjection","handleMouseMove","updateHTML_","getEventPixel","handleMouseOut","viewport","getViewport","format","html","getCoordinateFromPixelInternal","toString","easeIn","pow","easeOut","inAndOut","linear","Zoom","delta","zoomInClassName","zoomOutClassName","zoomInLabel","zoomOutLabel","zoomInTipLabel","zoomOutTipLabel","inElement","createTextNode","outElement","duration_","duration","zoomByDelta_","view","getView","currentZoom","getZoom","newZoom","getConstrainedZoom","getAnimating","cancelAnimations","animate","easing","setZoom","coordinate1","coordinate2","rotate","angle","cosAngle","sinAngle","worldWidth","worldsAway","opt_sourceExtentWidth","projectionExtent","sourceExtentWidth","floor","transformStringDiv","POINT","LINE_STRING","LINEAR_RING","POLYGON","MULTI_POINT","MULTI_LINE_STRING","MULTI_POLYGON","GEOMETRY_COLLECTION","CIRCLE","compose","dx1","dy1","sx","sy","dx2","dy2","makeInverse","mat","det","c","e","f","transformString","transform2D","opt_dest","dest","anchor","anchorX","anchorY","deltaX","deltaY","k","tmpTransform","Geometry","fn","lastResult","lastArgs","lastThis","called","extentRevision_","simplifiedGeometryMaxMinSquaredTolerance","simplifiedGeometryRevision","simplifyTransformedInternal","revision","squaredTolerance","opt_transform","getSimplifiedGeometry","nextArgs","simplifyTransformed","closestPointXY","closestPoint","minSquaredDistance","coord","getClosestPoint","opt_closestPoint","NaN","intersectsCoordinate","computeExtent","isNaN","returnOrUpdate","scale","opt_sy","opt_anchor","simplify","tolerance","getType","intersectsExtent","translate","sourceProj","inCoordinates","outCoordinates","pixelExtent","projectedExtent","SimpleGeometry","layout","getCoordinates","getFirstCoordinate","getFlatCoordinates","getLastCoordinate","getLayout","simplifiedGeometry","getSimplifiedGeometryInternal","getStride","setFlatCoordinates","getStrideForLayout","setCoordinates","opt_layout","setLayout","nesting","getLayoutForStride","assignClosest","offset1","offset2","maxSquaredDelta","squaredDelta","arrayMaxSquaredDelta","ends","assignClosestPoint","maxDelta","isRing","opt_tmpPoint","squaredDistance","tmpPoint","assignClosestArrayPoint","deflateCoordinates","deflateCoordinatesArray","coordinatess","opt_ends","douglasPeucker","simplifiedFlatCoordinates","simplifiedOffset","markers","stack","last","pop","first","maxSquaredDistance","squaredDistance_1","snap","quantize","quantizeArray","simplifiedEnds","ret","inflateCoordinates","opt_coordinates","inflateCoordinatesArray","opt_coordinatess","inflateMultiCoordinatesArray","endss","opt_coordinatesss","coordinatesss","interpolatePoint","fraction","length_1","cumulativeLengths","haystack","needle","opt_comparator","mid","cmp","comparator","low","high","found","binarySearch","lineStringCoordinateAtM","m","extrapolate","lo","hi","m0","linearRingContainsExtent","linearRingContainsXY","wn","linearRingsContainsXY","intersectsLineString","coordinatesExtent","point1","point2","start","startRel","endRel","startX","startY","endX","endY","slope","intersectsSegment","intersectsLinearRingArray","intersectsLinearRing","lineStringLength","LineString","flatMidpoint_","flatMidpointRevision_","maxDelta_","maxDeltaRevision_","appendCoordinate","lineString","forEachSegment","getCoordinateAtM","opt_extrapolate","getCoordinateAt","getLength","getFlatMidpoint","linearRing","twiceArea","linearRings","LinearRing","MultiLineString","ends_","lineStrings","appendLineString","multiLineString","opt_interpolate","interpolate","lineStringsCoordinateAtM","getEnds","getLineString","getLineStrings","getFlatMidpoints","midpoints","douglasPeuckerArray","intersectsLineStringArray","Point","deflateCoordinate","MultiPoint","appendPoint","multiPoint","getPoint","getPoints","points","getInteriorPointOfArray","flatCenters","flatCentersOffset","intersections","rr","pointX","maxSegmentLength","sort","segmentLength","abs","linearRingIsClockwise","edge","linearRingsAreOriented","opt_right","right","isClockwise","orientLinearRings","orientLinearRingsArray","Polygon","flatInteriorPointRevision_","flatInteriorPoint_","orientedRevision_","orientedFlatCoordinates_","appendLinearRing","polygon","getOrientedFlatCoordinates","getFlatInteriorPoint","flatCenter","getInteriorPoint","getLinearRingCount","getLinearRing","getLinearRings","fromExtent","MultiPolygon","opt_endss","endss_","flatInteriorPointsRevision_","flatInteriorPoints_","polygons","appendPolygon","newEndss","multiPolygon","multiArrayMaxSquaredDelta","assignClosestMultiArrayPoint","linearRingssContainsXY","linearRingss","getEndss","getFlatInteriorPoints","interiorPoints","getInteriorPointsOfMultiArray","getInteriorPoints","linearRingssAreOriented","simplifiedEndss","quantizeMultiArray","getPolygon","prevEnds","getPolygons","intersectsLinearRingMultiArray","deflateMultiCoordinatesArray","lastEnds","BaseTileLayer","preload","useInterimTilesOnError","setPreload","setUseInterimTilesOnError","getPreload","TileProperty","getUseInterimTilesOnError","LayerRenderer","boundHandleImageChange_","handleImageChange_","layer_","declutterExecutorGroup","loadedTileCallback","tiles","tile","tileCoord","createLoadedTileFinder","tileRange","forEachLoadedTile","forEachFeatureAtCoordinate","hitTolerance","matches","getDataAtPixel","getLayer","handleFontsChanged","renderIfReadyAndVisible","loadImage","image","imageState","load","RenderEvent","opt_inversePixelTransform","opt_frameState","opt_context","inversePixelTransform","context","CanvasLayerRenderer","container","renderedResolution","tempTransform","pixelTransform","containerReused","useContainer","layerClassName","firstElementChild","HTMLCanvasElement","position","left","transformOrigin","clipUnrotated","topLeft","topRight","bottomRight","bottomLeft","coordinateToPixelTransform","inverted","save","beginPath","moveTo","lineTo","clip","dispatchRenderEvent_","event_1","preRender","postRender","getRenderTransform","pixelRatio","offsetX","renderPixel","layerExtent","pixelToCoordinateTransform","newCanvas","newContext","clearRect","drawImage","getImageData","err","Uint8Array","TileRange","contains","containsTileRange","extend","getSize","getWidth","CanvasTileLayerRenderer","tileLayer","extentChanged","renderedExtent_","renderedPixelRatio","renderedProjection","renderedRevision","renderedTiles","newTiles_","tmpExtent","tmpTileRange_","isDrawableTile","tileState","getTile","z","setState","getInterimTile","layerIndex","viewResolution","viewCenter","tileSource","sourceRevision","getTileGridForProjection","getZForResolution","zDirection","tileResolution","getResolution","tilePixelRatio","getTilePixelRatio","canvasExtent","getTileRangeForExtentAndZ","tilesToDrawByZ","findLoadedTiles","tmpTileRange","uid","inTransition","getAlpha","time","childTileRange","getTileCoordChildTileRange","covered","forEachTileCoordParentTileRange","canvasScale","canvasTransform","getContextOptions","clips","clipZs","currentClip","zs","Number","getOpaque","reverse","currentZ","currentTilePixelSize","getTilePixelSize","currentScale","dx_1","dy_1","originTileCoord","getTileCoordForCoordAndZ","originTileExtent","getTileCoordExtent","origin_1","tileGutter","getGutterForProjection","tilesToDraw","tileCoordKey","xIndex","nextX","yIndex","nextY","w","h","transition","i_1","drawTileImage","restore","unshift","updateUsedTiles","usedTiles","manageTilePyramid","scheduleExpireCache","gutter","getTileImage","alpha","alphaChanged","globalAlpha","endTransition","getImage","canExpireCache","postRenderFunction","tileSourceKey","expireCache","postRenderFunctions","getKey","opt_tileCallback","wantedTiles","tileQueue","tileCount","isKeyQueued","enqueue","getTileCoordCenter","useTile","updateCacheSize","TileLayer","BaseTile","quickselect","compare","quickselectStep","defaultCompare","s","sd","swap","maxEntries","_maxEntries","_minEntries","ceil","_all","search","bbox","result","toBBox","nodesToSearch","children","child","childBBox","leaf","collides","insert","_build","_splitRoot","tmpNode","_insert","item","createNode","remove","equalsFn","path","indexes","goingUp","findItem","_condense","compareMinX","compareMinY","toJSON","fromJSON","items","N","M","calcBBox","N2","N1","multiSelect","right2","right3","_chooseSubtree","level","targetNode","minArea","minEnlargement","bboxArea","enlargement","isNode","insertPath","_split","_adjustParentBBoxes","_chooseSplitAxis","splitIndex","_chooseSplitIndex","minOverlap","bbox1","distBBox","bbox2","overlap","intersectionArea","compareNodeMinX","compareNodeMinY","_allDistMargin","leftBBox","rightBBox","margin","bboxMargin","siblings","destNode","hasArea","toSize","opt_size","ImageStyle","opacity_","rotateWithView_","rotateWithView","rotation_","scale_","scaleArray_","displacement_","displacement","getScale","getRotation","getRotateWithView","getDisplacement","getScaleArray","getAnchor","getHitDetectionImage","getPixelRatio","getImageState","getImageSize","getOrigin","setRotateWithView","setRotation","setScale","listenImageChange","unlistenImageChange","HEX_COLOR_RE_","NAMED_COLOR_RE_","asString","color","fromString","cacheSize","g","exec","el","body","rgb","getComputedStyle","fromNamed","hasAlpha","parseInt","substr","normalize","fromStringInternal_","asArray","asColorLike","defaultFont","defaultFillStyle","defaultLineCap","defaultLineDash","defaultLineJoin","defaultStrokeStyle","defaultTextAlign","defaultTextBaseline","defaultPadding","checkedFonts","setSize","console","warn","measureFont","measureElement","measureContext","textHeights","registerFont","interval","referenceWidth","referenceFonts","text","isAvailable","fontStyle","fontWeight","fontFamily","available","referenceFont","measureTextWidth","check","done","fonts","font","clearInterval","setInterval","measureText","measureAndCacheTextWidth","RegularShape","canvas_","hitDetectionCanvas_","fill_","fill","origin_","points_","radius_","radius1","radius2_","radius2","angle_","stroke_","stroke","anchor_","size_","renderOptions_","getFill","getRadius","getRadius2","getAngle","getStroke","createHitDetectionCanvas_","renderOptions","draw_","calculateLineJoinSize_","lineJoin","strokeWidth","miterLimit","r1","r2","miterRatio","bevelAdd","aa","dd","innerMiterRatio","innerLength","createRenderOptions","strokeStyle","lineDash","lineDashOffset","getColor","getLineDash","getLineDashOffset","getLineJoin","getMiterLimit","maxRadius","createPath_","fillStyle","lineWidth","setLineDash","drawHitDetectionCanvas_","arc","startAngle","step","angle0","radiusC","closePath","CircleStyle","setRadius","Fill","color_","setColor","Stroke","lineCap_","lineCap","lineDash_","lineDashOffset_","lineJoin_","miterLimit_","width_","getLineCap","setLineCap","setLineDashOffset","setLineJoin","setMiterLimit","setWidth","Style","geometry_","geometryFunction_","defaultGeometryFunction","geometry","setGeometry","image_","renderer","hitDetectionRenderer_","hitDetectionRenderer","text_","zIndex_","getGeometry","getText","setRenderer","setHitDetectionRenderer","getHitDetectionRenderer","getGeometryFunction","setFill","setImage","setStroke","setText","feature","defaultStyles","createDefaultStyle","Circle","BaseVectorLayer","renderBuffer","updateWhileAnimating","updateWhileInteracting","declutter_","declutter","renderBuffer_","style_","styleFunction_","setStyle","updateWhileAnimating_","updateWhileInteracting_","getDeclutter","getRenderBuffer","getRenderOrder","getStyle","getStyleFunction","getUpdateWhileAnimating","getUpdateWhileInteracting","renderDeclutter","declutterTree","setRenderOrder","renderOrder","opt_style","styleFunction","styles_1","Instruction","BEGIN_GEOMETRY","BEGIN_PATH","CLOSE_PATH","CUSTOM","DRAW_CHARS","DRAW_IMAGE","END_GEOMETRY","FILL","MOVE_TO_LINE_TO","SET_FILL_STYLE","SET_STROKE_STYLE","STROKE","fillInstruction","strokeInstruction","beginPathInstruction","closePathInstruction","VectorContext","drawCustom","drawGeometry","drawCircle","circleGeometry","drawFeature","drawGeometryCollection","geometryCollectionGeometry","drawLineString","lineStringGeometry","drawMultiLineString","multiLineStringGeometry","drawMultiPoint","multiPointGeometry","drawMultiPolygon","multiPolygonGeometry","drawPoint","pointGeometry","drawPolygon","polygonGeometry","drawText","setFillStrokeStyle","setImageStyle","imageStyle","opt_declutterImageWithText","setTextStyle","textStyle","CanvasBuilder","maxExtent","maxLineWidth","beginGeometryInstruction1_","beginGeometryInstruction2_","bufferedMaxExtent_","instructions","tmpCoordinate_","hitDetectionInstructions","applyPixelRatio","dashArray","dash","appendFlatPointCoordinates","getBufferedMaxExtent","tmpCoord","myEnd","appendFlatLineCoordinates","closed","skipFirst","lastRel","nextRel","lastXCoord","lastYCoord","nextCoord","skipped","drawCustomCoordinates_","builderEnds","builderEnd","beginGeometry","builderEndss","builderBegin","myEnds","endGeometry","finish","reverseHitDetectionInstructions","instruction","fillStyleColor","strokeStyleColor","strokeStyleLineCap","strokeStyleLineDash","strokeStyleLineDashOffset","strokeStyleLineJoin","strokeStyleWidth","strokeStyleMiterLimit","createFill","applyStroke","createStroke","updateFillStyle","currentFillStyle","updateStrokeStyle","currentStrokeStyle","currentLineCap","currentLineDash","currentLineDashOffset","currentLineJoin","currentLineWidth","currentMiterLimit","endGeometryInstruction","CanvasImageBuilder","hitDetectionImage_","imagePixelRatio_","anchorX_","anchorY_","height_","originX_","originY_","declutterImageWithText_","myBegin","opt_sharedData","hitDetectionImage","origin","CanvasLineStringBuilder","drawFlatCoordinates_","moveToLineToInstruction","lastStroke","CanvasPolygonBuilder","drawFlatCoordinatess_","numEnds","setFillStrokeStyles_","circleInstruction","matchingChunk","maxAngle","m12","m23","x12","y12","x23","y23","chunkStart","chunkEnd","chunkM","acos","TEXT_ALIGN","CanvasTextBuilder","labels_","textOffsetX_","textOffsetY_","textRotateWithView_","textRotation_","textFillState_","fillStates","textStrokeState_","strokeStates","textState_","textStates","textKey_","fillKey_","strokeKey_","fillState","strokeState","textState","geometryType","placement","geometryWidths","overflow","beg_1","filter","keep","saveTextStates_","backgroundFill","backgroundStroke","padding","p0","p1","p2","p3","pixelRatio_1","textAlign","flatOffset","flatEnd","oo","range","drawChars_","strokeKey","textKey","textBaseline","fillKey","baseline","offsetY","textFillStyle","textStrokeStyle","getFont","textScale","getOverflow","getMaxAngle","getPlacement","getTextAlign","getTextBaseline","getBackgroundFill","getBackgroundStroke","getPadding","textOffsetX","getOffsetX","textOffsetY","getOffsetY","textRotateWithView","textRotation","BATCH_CONSTRUCTORS","PolygonBuilder","Builder","ImageBuilder","LineStringBuilder","BuilderGroup","tolerance_","maxExtent_","pixelRatio_","resolution_","buildersByZIndex_","builderInstructions","zKey","builders","builderKey","builderInstruction","getBuilder","builderType","zIndexKey","replays","replay","Constructor","DEFAULT","IMAGE","TEXT","drawTextOnPath","startM","segmentM","advance","beginX","beginY","startOffset","startLength","endM","flat","previousAngle","singleSegment","iStart","charLength","chars","substring","p4","getDeclutterBox","replayImageOrLabelArgs","declutterBox","rtlRegEx","fromCharCode","horizontalTextAlign","align","test","Executor","overlaps","alignFill_","coordinateCache_","renderedTransform_","pixelCoordinates_","viewRotation_","widths_","createLabel","lines","numLines","widths","currentWidth","measureTextWidths","metrics","actualBoundingBoxAscent","actualBoundingBoxDescent","minHeight","maxHeight","border","offsetHeight","measureTextHeight","renderWidth","contextInstructions","OffscreenCanvasRenderingContext2D","CanvasRenderingContext2D","leftRight","replayTextBackground_","setStrokeStyle_","calculateImageOrLabelDimensions_","sheetWidth","sheetHeight","centerX","centerY","originX","originY","snapToPixel","fillStroke","boxW","boxH","boxX","boxY","drawImageX","drawImageY","drawImageW","drawImageH","replayImageOrLabel_","contextScale","imageOrLabel","dimensions","box","strokePadding","labelOrImage","setTransform","executeLabelInstructions","drawImageOrLabel","repeatSize","drawLabelWithPointPlacement_","execute_","opt_featureCallback","opt_hitExtent","opt_declutterTree","pixelCoordinates","transform1","transform2","prevX","prevY","roundX","roundY","currentGeometry","pendingFill","pendingStroke","lastFillInstruction","lastStrokeInstruction","coordinateCache","viewRotation","viewRotationFromTransform","batchSize","coords","declutterImageWithText","labelWithAnchor","widthIndex","args","imageArgs","imageDeclutterBox","measurePixelRatio","pixelRatioScale","cachedWidths","pathLength","textLength","parts","drawChars","cc","part","ii_1","execute","executeHitDetection","ORDER","BuilderType","ExecutorGroup","allInstructions","opt_renderBuffer","overlaps_","executorsByZIndex_","hitDetectionContext_","hitDetectionTransform_","createExecutors_","flatClipCoords","getClipCoords","executors","instructionByZindex","hasExecutors","candidates","declutteredFeatures","contextSize","hitExtent","circlePixelIndexArrayCache","maxDistanceSq","distances","distanceSq","distance","pixelIndex","getPixelIndexArray","featureCallback","imageData","idx","result_1","executor","isEmpty","opt_builderTypes","builderTypes","CanvasImmediateRenderer","opt_squaredTolerance","opt_userTransform","context_","squaredTolerance_","userTransform_","contextFillState_","contextStrokeState_","contextTextState_","fillState_","strokeState_","imageAnchorX_","imageAnchorY_","imageHeight_","imageOpacity_","imageOriginX_","imageOriginY_","imageRotateWithView_","imageRotation_","imageScale_","imageWidth_","textScale_","tmpLocalTransform_","drawImages_","localTransform","drawText_","setContextFillState_","setContextStrokeState_","setContextTextState_","strokeText","fillText","moveToLineTo_","close","drawRings_","simpleGeometry","transformGeom2D","geometries","getGeometriesArray","flatMidpoint","geometryExtent","flatMidpoints","flatInteriorPoint","flatInteriorPoints","contextFillState","contextStrokeState","contextTextState","imageSize","imageAnchor","imageOrigin","textFillStyleColor","textStrokeStyleColor","textStrokeStyleLineCap","textStrokeStyleLineDash","textStrokeStyleLineDashOffset","textStrokeStyleLineJoin","textStrokeStyleWidth","textStrokeStyleMiterLimit","textFont","textText","textTextAlign","textTextBaseline","src","crossOrigin","shared","IconImageCache","cache_","cacheSize_","maxCacheSize_","expire","iconImage","maxCacheSize","ImageBase","listenImage","loadHandler","errorHandler","img","promise","listening_1","then","catch","ImageWrapper","imageLoadFunction","src_","unlisten_","imageLoadFunction_","handleImageError_","unlistenImage_","handleImageLoad_","taintedTestContext","IconImage","imageState_","tainted_","isTainted_","dispatchChangeEvent_","replaceColor_","fillRect","getSrc","ctx","globalCompositeOperation","imgData","putImageData","Icon","normalizedAnchor_","anchorOrigin_","anchorOrigin","IconOrigin","anchorXUnits_","anchorXUnits","IconAnchorUnits","anchorYUnits_","anchorYUnits","crossOrigin_","imgSize","iconImage_","offset_","offsetOrigin_","offsetOrigin","setAnchor","iconImageSize","HIT_DETECT_RESOLUTION","GEOMETRY_RENDERERS","builderGroup","opt_declutterBuilderGroup","imageReplay","textReplay","lineStringReplay","polygonReplay","replayGroup","geometryRenderer","circleReplay","defaultOrder","feature1","feature2","getTolerance","renderFeature","loading","renderGeometry","renderFeatureInternal","getGeometries","brokenDiagonalRendering_","CanvasVectorLayerRenderer","vectorLayer","boundHandleStyleImageChange_","handleStyleImageChange_","animatingOrInteracting_","dirty_","hitDetectionImageData_","renderedFeatures_","renderedRevision_","renderedResolution_","wrappedRenderedExtent_","renderedRotation_","renderedCenter_","renderedProjection_","renderedRenderOrder_","replayGroup_","replayGroupChanged","clipping","renderWorlds","executorGroup","vectorSource","viewHints","multiWorld","getWrapX","endWorld","world","makeScale","clipped","features","imageSmoothingEnabled","featureCount","indexFactor","featuresByZIndex","featureStyleFunction","styles","originalStyle","imgContext","byGeometryType","zIndexKeys","geomAndStyle","kk","createHitDetectionImageData","resultFeatures","hitDetect","lastIndexOf","executorGroups","animating","interacting","frameStateExtent","vectorLayerRevision","vectorLayerRenderBuffer","vectorLayerRenderOrder","renderedExtent","loadExtents","loadExtent","declutterBuilderGroup","userTransform","userExtent_1","loadFeatures","dirty","userExtent","getFeaturesInExtent","replayGroupInstructions","getOverlaps","VectorLayer","BaseVector","Tile","interimTile","transition_","transitionStarts_","release","refreshInterimChain","prev","getTileCoord","id","ImageTile","tileLoadFunction","tileLoadFunction_","naturalWidth","naturalHeight","Triangulation","targetProj","targetExtent","maxSourceExtent","errorThreshold","opt_destinationResolution","sourceProj_","targetProj_","transformInvCache","transformInv","transformInv_","maxSourceExtent_","errorThresholdSquared_","triangles_","wrapsXInSource_","canWrapXInSource_","sourceWorldWidth_","targetWorldWidth_","destinationTopLeft","destinationTopRight","destinationBottomRight","destinationBottomLeft","sourceTopLeft","sourceTopRight","sourceBottomRight","sourceBottomLeft","maxSubdivision","addQuad_","leftBound_1","triangle","newTriangle","addTriangle_","aSrc","bSrc","cSrc","dSrc","sourceQuadExtent","sourceCoverageX","sourceWorldWidth","wrapsX","needsSubdivision","isFinite","isNotFinite","centerSrc","bc","bcSrc","da","daSrc","ab","abSrc","cd","cdSrc","calculateSourceExtent","getTriangles","IMAGE_SMOOTHING_DISABLED","msImageSmoothingEnabled","drawTestTriangle","u1","v1","u2","v2","verifyBrokenDiagonalRendering","calculateSourceResolution","targetCenter","targetResolution","sourceCenter","sourceResolution","targetMetersPerUnit","sourceMetersPerUnit","sourceExtent","compensationFactor","ReprojTile","sourceTileGrid","targetTileGrid","wrappedTileCoord","getTileFunction","opt_errorThreshold","opt_renderEdges","opt_contextOptions","renderEdges_","contextOptions_","gutter_","sourceTileGrid_","targetTileGrid_","wrappedTileCoord_","sourceTiles_","sourcesListenerKeys_","sourceZ_","maxTargetExtent","limitedTargetExtent","sourceProjExtent","calculateSourceExtentResolution","errorThresholdInPixels","triangulation_","sourceRange","srcX","srcY","reproject_","sources","getTileSize","triangulation","pixelRound","sourceDataExtent","canvasWidthInUnits","canvasHeightInUnits","stitchContext","stitchScale","xPos","yPos","srcWidth","srcHeight","targetTopLeft","u0","v0","sourceNumericalShiftX","sourceNumericalShiftY","affineCoefs","maxRow","maxEl","absValue","coef","solveLinearSystem","isBrokenDiagonalRendering","ud","vd","steps","leftToLoad_1","sourceListenKey_1","unlistenSources_","setTimeout","LRUCache","opt_highWaterMark","highWaterMark","count_","entries_","oldest_","newest_","getCount","containsKey","entry","value_","key_","newer","older","peekLast","peekLastKey","peekFirstKey","opt_tileCoord","getKeyZXY","TileCache","pruneExceptNewestZ","adaptAttributions","attributionLike","Source","attributions_","attributionsCollapsible_","attributionsCollapsible","wrapX_","wrapX","viewResolver","viewRejector","viewPromise_","reject","getResolutions","refresh","setAttributions","DEFAULT_MAX_ZOOM","DEFAULT_TILE_SIZE","tmpTileCoord","TileGrid","zoomFactor","resolutions_","resolutions","every","currentVal","res","origins","zoomFactor_","origins_","tileSizes_","tileSizes","tileSize_","tileSize","fullTileRanges_","tmpSize_","tmpExtent_","sizes","restrictedTileRange","calculateTileRanges_","forEachTileCoord","opt_tileRange","tileCoordExtent","getTileRangeForTileCoordAndZ","tileCoordZ","tileCoordX","tileCoordY","factor","getTileRangeExtent","getTileCoordForXYAndZ_","getTileCoordForCoordAndResolution","getTileCoordForXYAndResolution_","reverseIntersectionPolicy","adjustX","adjustY","xFromOrigin","yFromOrigin","getTileCoordResolution","getFullTileRange","opt_direction","fullTileRanges","getForProjection","opt_maxZoom","opt_tileSize","opt_corner","resolutionsFromExtent","createForExtent","extentFromProjection","createForProjection","opt_maxResolution","half","TileSource","opaque_","opaque","tilePixelRatio_","tileCache","tmpSize","tileOptions","getTileCacheForProjection","loaded","setKey","getTileGrid","ratio","getTileCoordForTileUrlFunction","opt_projection","withinExtentAndZ","TileSourceEvent","createFromTemplate","template","zRegEx","xRegEx","yRegEx","dashYRegEx","UrlTile","generateTileUrlFunction_","tileUrlFunction","urls","setUrls","url","setUrl","tileLoadingKeys_","getTileLoadFunction","getTileUrlFunction","getPrototypeOf","getUrls","handleTileChange","setTileLoadFunction","setTileUrlFunction","startCharCode","charCodeAt","stopCharCode","charCode","stop_1","expandUrl","templates","tileUrlFunctions","createFromTileUrlFunctions","createFromTemplates","TileImage","defaultTileLoadFunction","tileClass","tileCacheForProjection","tileGridForProjection","reprojectionErrorThreshold_","reprojectionErrorThreshold","imageSmoothing","renderReprojectionEdges_","usedTileCache","getGutter","JSON","stringify","thisProj","projKey","createTile_","urlTileCoord","tileUrl","newTile","getTileInternal","setRenderReprojectionEdges","setTileGridForProjection","tilegrid","proj","imageTile","XYZ","xyzOptions","gridOptions","createXYZ","OSM","CollectionEvent","opt_element","opt_index","Collection","unique_","unique","array_","assertUnique_","updateLength_","getArray","insertAt","elem","CollectionEventType","removeAt","setAt","opt_except","RBush","opt_maxEntries","rbush_","items_","extents","update","getAll","getInExtent","forEach_","forEachInExtent","concat","rbush","xhr","success","failure","XMLHttpRequest","open","FormatType","responseType","withCredentials","onload","status","responseText","responseXML","DOMParser","parseFromString","readFeatures","featureProjection","readProjection","onerror","send","loadFeaturesXhr","dataProjection","addFeatures","VectorSourceEvent","opt_feature","opt_features","VectorSource","loader_","format_","url_","loader","strategy_","strategy","collection","useSpatialIndex","featuresRtree_","loadedExtentsRtree_","loadingExtentsCount_","nullGeometryFeatures_","idIndex_","uidIndex_","featureChangeKeys_","featuresCollection_","addFeaturesInternal","bindFeaturesCollection_","addFeature","addFeatureInternal","featureKey","addToIndex_","setupChangeEvents_","VectorEventType","handleFeatureChange_","valid","getId","newFeatures","geometryFeatures","length_2","length_3","modifyingCollection","removeFeature","opt_fast","featureId","removeFeatureInternal","clearEvent","forEachFeature","forEachFeatureAtCoordinateDirect","forEachFeatureInExtent","forEachFeatureIntersectingExtent","getFeaturesCollection","getFeaturesAtCoordinate","getClosestFeatureToCoordinate","opt_filter","closestFeature","previousMinSquaredDistance","minDistance","getFeatureById","getFeatureByUid","getFormat","getUrl","sid","removeFromIdIndex_","hasFeature","loadedExtentsRtree","extentsToLoad","_loop_1","extentToLoad","this_1","removeLoadedExtent","removed","setLoader","Text","font_","textAlign_","textBaseline_","maxAngle_","placement_","overflow_","offsetX_","offsetY_","backgroundFill_","backgroundStroke_","padding_","setOverflow","setFont","setMaxAngle","setOffsetX","setOffsetY","setPlacement","setTextAlign","setTextBaseline","setBackgroundFill","setBackgroundStroke","setPadding","Feature","opt_geometryOrProperties","id_","geometryName_","geometryChangeKey_","handleGeometryChanged_","setGeometryName","getGeometryName","handleGeometryChange_","setId","MapRenderer","dispatchRenderEvent","calculateMatrices2D","checkWrapped","thisArg","layerFilter","thisArg2","translatedCoordinate","offsets","layerStates","numLayers","callback_1","order","forEachLayerAtPixel","hasFeatureAtCoordinate","scheduleExpireIconCache","expireIconCache","CompositeMapRenderer","fontChangeListenerKey_","redrawText","element_","insertBefore","firstChild","children_","declutterLayers","previousElement","oldChildren","childNodes","oldChild","newChild","replaceChildren","Map","LayerGroup","layers","layersListenerKeys_","listenerKeys_","handleLayersChanged_","setLayers","handleLayerChange_","getLayers","handleLayersAdd_","handleLayersRemove_","layersArray","collectionEvent","pos","ownLayerState","defaultZIndex","MapEvent","MapBrowserEvent","originalEvent","opt_dragging","pixel_","coordinate_","dragging","configurable","getCoordinateFromPixel","SINGLECLICK","CLICK","DBLCLICK","POINTERDRAG","POINTERMOVE","POINTERDOWN","POINTERUP","POINTEROVER","POINTEROUT","POINTERENTER","POINTERLEAVE","POINTERCANCEL","MapBrowserEventHandler","moveTolerance","clickTimeoutId_","emulateClicks_","dragging_","dragListenerKeys_","moveTolerance_","down_","activePointers_","trackedTouches_","pointerdownListenerKey_","handlePointerDown_","originalPointerMoveEvent_","relayedListenerKey_","relayEvent_","boundHandleTouchMove_","handleTouchMove_","emulateClick_","pointerEvent","newEvent","clearTimeout","updateActivePointers_","pointerId","handlePointerUp_","isMouseActionButton_","button","doc","getOwnerDocument","handlePointerMove_","getRootNode","isMoving_","cancelable","clientX","clientY","DROP","PriorityQueue","priorityFunction","keyFunction","priorityFunction_","keyFunction_","elements_","priorities_","queuedElements_","dequeue","elements","priorities","siftUp_","elementKey","priority","siftDown_","getLeftChildIndex_","getRightChildIndex_","getParentIndex_","heapify_","isQueued","count","startIndex","lIndex","rIndex","smallerChildIndex","parentIndex","reprioritize","TileQueue","tilePriorityFunction","tileChangeCallback","boundHandleTileChange_","tileChangeCallback_","tilesLoading_","tilesLoadingKeys_","added","getTilesLoading","tileKey","loadMoreTiles","maxTotalLoading","maxNewLoads","newLoads","createExtent","onlyCenter","smooth","opt_isMoving","opt_centerShift","viewWidth","viewHeight","shiftX","shiftY","none","getViewportClampedResolution","viewportSize","showFullExtent","xResolution","yResolution","getSmoothClampedResolution","createMinMaxResolution","opt_smooth","opt_maxExtent","opt_showFullExtent","cappedMaxRes","disable","View","hints_","animations_","updateAnimationKey_","projection_","viewportSize_","targetCenter_","targetResolution_","targetRotation_","nextCenter_","nextResolution_","nextRotation_","cancelAnchor_","applyOptions_","resolutionConstraintInfo","resolutionConstraint","smoothResolutionConstraint","projExtent","constrainOnlyCenter","constrainResolution","capped","createSnapToResolutions","defaultMaxResolution","defaultMinResolution","defaultMaxZoom","power","opt_minResolution","minZoomLevel","cappedZoomLevel","zoomLevel","createSnapToPower","constraint","createResolutionConstraint","maxResolution_","minResolution_","minZoom_","centerConstraint","smoothExtentConstraint","createCenterConstraint","rotationConstraint","theta","enableRotation","constrainRotation","createRotationConstraint","constraints_","setCenterInternal","setResolution","options_","oldPadding","newPadding","getUpdatedOptions_","newOptions","getCenterInternal","var_args","isDef","resolveConstraints","animateInternal","animationCount","Date","now","series","animation","complete","getResolutionForZoom","sourceRotation","targetRotation","isNoopAnimation","setHint","updateAnimations_","animationCallback","getInteracting","cancelAnimationFrame","more","seriesComplete","elapsed","progress","getViewportSize_","constrainedResolution","calculateCenterZoom","applyTargetState_","constrainedRotation","calculateCenterRotate","Boolean","requestAnimationFrame","currentCenter","currentResolution","opt_rotation","setViewportSize","ViewProperty","getConstraints","getConstrainResolution","getHints","opt_hints","calculateExtent","calculateExtentInternal","getViewportSizeMinusPadding_","getZoomForResolution","setConstrainResolution","enabled","getResolutionForExtent","getResolutionForExtentInternal","getResolutionForValueFunction","opt_power","getConstrainedResolution","getValueForResolutionFunction","logPower","reducedSize","calculateCenterOn","nextCenter","nextResolution","nextRotation","nearest","baseLevel","fit","geometryOrExtent","fitInternal","rotatedExtentForGeometry","minRotX","minRotY","maxRotX","maxRotY","rotX","rotY","rotatedExtent","centerRot","getConstrainedCenter","centerOn","centerOnInternal","calculateCenterShift","centerShift","shiftedCenter","adjustCenter","deltaCoordinates","setCenter","adjustCenterInternal","adjustResolution","adjustResolutionInternal","isMoving","newResolution","adjustZoom","adjustRotation","adjustRotationInternal","newRotation","hint","opt_doNotCancelAnims","opt_forceMoving","newCenter","opt_duration","opt_resolutionDirection","beginInteraction","endInteraction","endInteractionInternal","opt_targetResolution","targetZoom","targetRes","returnValue","PluggableMap","optionsInternal","keyboardEventTarget","controls","interactions","overlays","layerGroup","MapProperty","createOptionsInternal","boundHandleBrowserEvent_","handleBrowserEvent","maxTilesLoading_","maxTilesLoading","postRenderTimeoutHandle_","animationDelayKey_","animationDelay_","renderFrame_","coordinateToPixelTransform_","pixelToCoordinateTransform_","frameIndex_","frameState_","previousExtent_","viewPropertyListenerKey_","viewChangeListenerKey_","layerGroupPropertyListenerKeys_","viewport_","overlayContainer_","overlayContainerStopEvent_","mapBrowserEventHandler_","keyboardEventTarget_","keyHandlerKeys_","overlays_","overlayIdIndex_","handleResize_","postRenderFunctions_","tileQueue_","getTilePriority","handleTileChange_","handleLayerGroupChanged_","handleViewChanged_","handleSizeChanged_","handleTargetChanged_","viewOptions","setView","addOverlayInternal_","control","interaction","addControl","getControls","addInteraction","getInteractions","addLayer","getLayerGroup","addOverlay","overlay","getOverlays","forEachFeatureAtPixel","getFeaturesAtPixel","hasFeatureAtPixel","getEventCoordinate","getEventCoordinateInternal","viewportPosition","getBoundingClientRect","eventPosition","changedTouches","top","getTarget","getTargetElement","getOverlayById","group","getLoading","getPixelFromCoordinate","viewCoordinate","getPixelFromCoordinateInternal","getOverlayContainer","targetElement","ownerDocument","tileCenter","browserEvent","mapBrowserEvent","handleMapBrowserEvent","rootNode","documentElement","interactionsArray","getActive","handlePostRender","hints","lowOnFrameBudget","updateSize","handleViewPropertyChanged_","updateViewportSize_","isRendered","renderSync","removeControl","removeInteraction","removeLayer","removeOverlay","previousFrameState","nextExtent","setLayerGroup","computedStyle","offsetWidth","parseFloat","getClientRects","Rotate","compassClassName","callResetNorth_","resetNorth","autoHide_","autoHide","resetNorth_","zoomByDelta","Interaction","setActive","active","DoubleClickZoom","delta_","stopEvent","shiftKey","PointerInteraction","handleDownEvent","handleDragEvent","handleMoveEvent","handleUpEvent","stopDown","handlingDownUpSequence","trackedPointers_","targetPointers","getPointerCount","updateTrackedPointers_","handledUp","handled","isPointerDraggingEvent","conditions","pass","altShiftKeysOnly","altKey","metaKey","ctrlKey","focusWithTabindex","hasAttribute","activeElement","always","mouseActionButton","noModifierKeys","shiftKeyOnly","targetNotEditable","tagName","mouseOnly","pointerType","primaryAction","isPrimary","DragPan","kinetic_","kinetic","lastCentroid","lastPointersCount_","panning_","condition","condition_","onFocusOnly","noKinetic_","centroid","centerpx","Pointer","DragRotate","lastAngle_","RenderBox","startPixel_","endPixel_","render_","startPixel","endPixel","px","setPixels","createOrUpdateGeometry","DragBoxEvent","DragBox","box_","minArea_","onBoxEnd","boxEndCondition_","boxEndCondition","defaultBoxEndCondition","completeBox","DragZoom","out_","out","KeyboardPan","defaultCondition_","pixelDelta_","pixelDelta","keyEvent","keyCode","mapUnitsDelta","pan","KeyboardZoom","Kinetic","decay","minVelocity","delay","decay_","minVelocity_","delay_","initialVelocity_","lastIndex","firstIndex","Mode","MouseWheelZoom","totalDelta_","lastDelta_","timeout_","timeout","useAnchor_","useAnchor","constrainResolution_","lastAnchor_","startTime_","timeoutId_","mode_","trackpadEventGap_","trackpadTimeoutId_","deltaPerZoom_","endInteraction_","wheelEvent","deltaMode","WheelEvent","DOM_DELTA_PIXEL","DOM_DELTA_LINE","timeLeft","handleWheelZoom_","setMouseAnchor","PinchRotate","pointerOptions","rotating_","rotationDelta_","threshold_","threshold","rotationDelta","touch0","touch1","PinchZoom","lastDistance_","lastScaleDelta_","scaleDelta","zoomOptions","rotateOptions","attribution","attributionOptions","altShiftDragRotate","doubleClickZoom","zoomDelta","zoomDuration","dragPan","pinchRotate","pinchZoom","keyboard","mouseWheelZoom","shiftDragZoom","Composite","createStringXY","opt_fractionDigits","toFixed","toStringXY","geom","Vector","fromLonLat"],"sourceRoot":""}