This commit is contained in:
110
node_modules/ol/source/OGCVectorTile.js
generated
vendored
Normal file
110
node_modules/ol/source/OGCVectorTile.js
generated
vendored
Normal file
@@ -0,0 +1,110 @@
|
||||
/**
|
||||
* @module ol/source/OGCVectorTile
|
||||
*/
|
||||
var __extends = (this && this.__extends) || (function () {
|
||||
var extendStatics = function (d, b) {
|
||||
extendStatics = Object.setPrototypeOf ||
|
||||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
||||
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
||||
return extendStatics(d, b);
|
||||
};
|
||||
return function (d, b) {
|
||||
if (typeof b !== "function" && b !== null)
|
||||
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
||||
extendStatics(d, b);
|
||||
function __() { this.constructor = d; }
|
||||
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
||||
};
|
||||
})();
|
||||
import VectorTile from './VectorTile.js';
|
||||
import { getTileSetInfo } from './ogcTileUtil.js';
|
||||
/**
|
||||
* @typedef {Object} Options
|
||||
* @property {string} url URL to the OGC Vector Tileset endpoint.
|
||||
* @property {Object} [context] A lookup of values to use in the tile URL template. The `{tileMatrix}`
|
||||
* (zoom level), `{tileRow}`, and `{tileCol}` variables in the URL will always be provided by the source.
|
||||
* @property {import("../format/Feature.js").default} format Feature parser for tiles.
|
||||
* @property {string} [mediaType] The content type for the tiles (e.g. "application/vnd.mapbox-vector-tile"). If not provided,
|
||||
* the source will try to find a link with rel="item" that uses a vector type supported by the configured format.
|
||||
* @property {import("./Source.js").AttributionLike} [attributions] Attributions.
|
||||
* @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.
|
||||
* @property {number} [cacheSize] Initial tile cache size. Will auto-grow to hold at least twice the number of tiles in the viewport.
|
||||
* @property {boolean} [overlaps=true] This source may have overlapping geometries. Setting this
|
||||
* to `false` (e.g. for sources with polygons that represent administrative
|
||||
* boundaries or TopoJSON sources) allows the renderer to optimise fill and
|
||||
* stroke operations.
|
||||
* @property {import("../proj.js").ProjectionLike} [projection='EPSG:3857'] Projection of the tile grid.
|
||||
* @property {typeof import("../VectorTile.js").default} [tileClass] Class used to instantiate image tiles.
|
||||
* Default is {@link module:ol/VectorTile~VectorTile}.
|
||||
* @property {number} [transition] A duration for tile opacity
|
||||
* transitions in milliseconds. A duration of 0 disables the opacity transition.
|
||||
* @property {boolean} [wrapX=true] Whether to wrap the world horizontally.
|
||||
* When set to `false`, only one world
|
||||
* will be rendered. When set to `true`, tiles will be wrapped horizontally to
|
||||
* render multiple worlds.
|
||||
* @property {number|import("../array.js").NearestDirectionFunction} [zDirection=1]
|
||||
* Choose whether to use tiles with a higher or lower zoom level when between integer
|
||||
* zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.
|
||||
*/
|
||||
/**
|
||||
* @classdesc
|
||||
* Layer source for map tiles from an [OGC API - Tiles](https://ogcapi.ogc.org/tiles/) service that provides "vector" type tiles.
|
||||
* The service must conform to at least the core (http://www.opengis.net/spec/ogcapi-tiles-1/1.0/conf/core)
|
||||
* and tileset (http://www.opengis.net/spec/ogcapi-tiles-1/1.0/conf/tileset) conformance classes.
|
||||
*
|
||||
* Vector tile sets may come in a variety of formats (e.g. GeoJSON, MVT). The `format` option is used to determine
|
||||
* which of the advertised media types is used. If you need to force the use of a particular media type, you can
|
||||
* provide the `mediaType` option.
|
||||
*/
|
||||
var OGCVectorTile = /** @class */ (function (_super) {
|
||||
__extends(OGCVectorTile, _super);
|
||||
/**
|
||||
* @param {Options} options OGC vector tile options.
|
||||
*/
|
||||
function OGCVectorTile(options) {
|
||||
var _this = _super.call(this, {
|
||||
attributions: options.attributions,
|
||||
attributionsCollapsible: options.attributionsCollapsible,
|
||||
cacheSize: options.cacheSize,
|
||||
format: options.format,
|
||||
overlaps: options.overlaps,
|
||||
projection: options.projection,
|
||||
tileClass: options.tileClass,
|
||||
transition: options.transition,
|
||||
wrapX: options.wrapX,
|
||||
zDirection: options.zDirection,
|
||||
state: 'loading',
|
||||
}) || this;
|
||||
var sourceInfo = {
|
||||
url: options.url,
|
||||
projection: _this.getProjection(),
|
||||
mediaType: options.mediaType,
|
||||
supportedMediaTypes: options.format.supportedMediaTypes,
|
||||
context: options.context || null,
|
||||
};
|
||||
getTileSetInfo(sourceInfo)
|
||||
.then(_this.handleTileSetInfo_.bind(_this))
|
||||
.catch(_this.handleError_.bind(_this));
|
||||
return _this;
|
||||
}
|
||||
/**
|
||||
* @param {import("./ogcTileUtil.js").TileSetInfo} tileSetInfo Tile set info.
|
||||
* @private
|
||||
*/
|
||||
OGCVectorTile.prototype.handleTileSetInfo_ = function (tileSetInfo) {
|
||||
this.tileGrid = tileSetInfo.grid;
|
||||
this.setTileUrlFunction(tileSetInfo.urlFunction, tileSetInfo.urlTemplate);
|
||||
this.setState('ready');
|
||||
};
|
||||
/**
|
||||
* @private
|
||||
* @param {Error} error The error.
|
||||
*/
|
||||
OGCVectorTile.prototype.handleError_ = function (error) {
|
||||
console.error(error); // eslint-disable-line no-console
|
||||
this.setState('error');
|
||||
};
|
||||
return OGCVectorTile;
|
||||
}(VectorTile));
|
||||
export default OGCVectorTile;
|
||||
//# sourceMappingURL=OGCVectorTile.js.map
|
||||
Reference in New Issue
Block a user