ol-cesium
Version:
OpenLayers Cesium integration library
274 lines • 19 kB
JavaScript
import { getSourceProjection } from '../util';
import { Tile as TileSource } from 'ol/source.js';
import { attributionsFunctionToCredits } from '../core';
export function createEmptyCanvas() {
const canvas = document.createElement('canvas');
canvas.width = 1;
canvas.height = 1;
return canvas;
}
const olUseNewCoordinates = (function () {
const tileSource = new TileSource({
projection: 'EPSG:3857',
wrapX: true
});
const tileCoord = tileSource.getTileCoordForTileUrlFunction([6, -31, 22]);
return tileCoord && tileCoord[1] === 33 && tileCoord[2] === 22;
// See b/test/spec/ol/source/tile.test.js
// of e9a30c5cb7e3721d9370025fbe5472c322847b35 in OpenLayers repository
})();
export default class OLImageryProvider {
source_;
projection_;
fallbackProj_;
map_;
shouldRequestNextLevel;
emptyCanvas_ = createEmptyCanvas();
emptyCanvasPromise_ = Promise.resolve(this.emptyCanvas_);
tilingScheme_;
ready_;
rectangle_;
/**
* When <code>true</code>, this model is ready to render, i.e., the external binary, image,
* and shader files were downloaded and the WebGL resources were created.
*/
get ready() {
return this.ready_;
}
/**
* Gets the rectangle, in radians, of the imagery provided by the instance.
*/
get rectangle() {
return this.rectangle_;
}
/**
* Gets the tiling scheme used by the provider.
*/
get tilingScheme() {
return this.tilingScheme_;
}
/**
* Gets an event that is raised when the imagery provider encounters an asynchronous error. By subscribing
* to the event, you will be notified of the error and can potentially recover from it. Event listeners
* are passed an instance of {@link Cesium.TileProviderError}.
*/
errorEvent = new Cesium.Event();
/**
* Gets the credit to display when this imagery provider is active. Typically this is used to credit
* the source of the imagery.
*/
credit;
/**
* Gets the proxy used by this provider.
*/
proxy;
get _ready() {
return this.ready_;
}
/**
* Gets the width of each tile, in pixels.
*/
get tileWidth() {
const tileGrid = this.source_.getTileGrid();
if (tileGrid) {
const tileSizeAtZoom0 = tileGrid.getTileSize(0);
if (Array.isArray(tileSizeAtZoom0)) {
return tileSizeAtZoom0[0];
}
else {
return tileSizeAtZoom0; // same width and height
}
}
return 256;
}
/**
* Gets the height of each tile, in pixels.
*/
get tileHeight() {
const tileGrid = this.source_.getTileGrid();
if (tileGrid) {
const tileSizeAtZoom0 = tileGrid.getTileSize(0);
if (Array.isArray(tileSizeAtZoom0)) {
return tileSizeAtZoom0[1];
}
else {
return tileSizeAtZoom0; // same width and height
}
}
return 256;
}
/**
* Gets the maximum level-of-detail that can be requested.
*/
get maximumLevel() {
const tileGrid = this.source_.getTileGrid();
if (tileGrid) {
return tileGrid.getMaxZoom();
}
else {
return 18; // some arbitrary value
}
}
// FIXME: to implement, we could check the number of tiles at minzoom (for this rectangle) and return 0 if too big
/**
* Gets the minimum level-of-detail that can be requested. Generally,
* a minimum level should only be used when the rectangle of the imagery is small
* enough that the number of tiles at the minimum level is small. An imagery
* provider with more than a few tiles at the minimum level will lead to
* rendering problems.
*/
get minimumLevel() {
// WARNING: Do not use the minimum level (at least until the extent is
// properly set). Cesium assumes the minimumLevel to contain only
// a few tiles and tries to load them all at once -- this can
// freeze and/or crash the browser !
return 0;
//var tg = this.source_.getTileGrid();
//return tg ? tg.getMinZoom() : 0;
}
/**
* Gets the tile discard policy. If not undefined, the discard policy is responsible
* for filtering out "missing" tiles via its shouldDiscardImage function. If this function
* returns undefined, no tiles are filtered.
*/
get tileDiscardPolicy() {
return undefined;
}
// FIXME: this might be exposed
/**
* Gets a value indicating whether or not the images provided by this imagery provider
* include an alpha channel. If this property is false, an alpha channel, if present, will
* be ignored. If this property is true, any images without an alpha channel will be treated
* as if their alpha is 1.0 everywhere. When this property is false, memory usage
* and texture upload time are reduced.
*/
get hasAlphaChannel() {
return true;
}
// FIXME: this could be implemented by proxying to OL
/**
* Asynchronously determines what features, if any, are located at a given longitude and latitude within
* a tile.
* This function is optional, so it may not exist on all ImageryProviders.
* @param x - The tile X coordinate.
* @param y - The tile Y coordinate.
* @param level - The tile level.
* @param longitude - The longitude at which to pick features.
* @param latitude - The latitude at which to pick features.
* @return A promise for the picked features that will resolve when the asynchronous
* picking completes. The resolved value is an array of {@link ImageryLayerFeatureInfo}
* instances. The array may be empty if no features are found at the given location.
* It may also be undefined if picking is not supported.
*/
pickFeatures(x, y, level, longitude, latitude) {
return undefined;
}
/**
* Special class derived from Cesium.ImageryProvider
* that is connected to the given ol.source.TileImage.
* @param olMap OL map
* @param source Tile image source
* @param [opt_fallbackProj] Projection to assume if source has no projection
*/
constructor(olMap, source, opt_fallbackProj) {
this.source_ = source;
this.projection_ = null;
this.ready_ = false;
this.fallbackProj_ = opt_fallbackProj || null;
// cesium v107+ don't wait for ready anymore so we put somehing here while it loads
this.tilingScheme_ = new Cesium.WebMercatorTilingScheme();
this.rectangle_ = null;
this.map_ = olMap;
this.shouldRequestNextLevel = false;
const proxy = this.source_.get('olcs.proxy');
if (proxy) {
if (typeof proxy === 'function') {
// Duck typing a proxy
this.proxy = {
'getURL': proxy
};
}
else if (typeof proxy === 'string') {
this.proxy = new Cesium.DefaultProxy(proxy);
}
}
this.source_.on('change', (e) => {
this.handleSourceChanged_();
});
this.handleSourceChanged_();
}
/**
* Checks if the underlying source is ready and cached required data.
*/
handleSourceChanged_() {
if (!this.ready_ && this.source_.getState() == 'ready') {
this.projection_ = getSourceProjection(this.source_) || this.fallbackProj_;
const options = { numberOfLevelZeroTilesX: 1, numberOfLevelZeroTilesY: 1 };
if (this.source_.tileGrid !== null) {
// Get the number of tiles at level 0 if it is defined
this.source_.tileGrid.forEachTileCoord(this.projection_.getExtent(), 0, ([zoom, xIndex, yIndex]) => {
options.numberOfLevelZeroTilesX = xIndex + 1;
options.numberOfLevelZeroTilesY = yIndex + 1;
});
}
if (this.projection_.getCode() === 'EPSG:4326') {
// Cesium zoom level 0 is OpenLayers zoom level 1 for layer in EPSG:4326 with a single tile on level 0
this.shouldRequestNextLevel = options.numberOfLevelZeroTilesX === 1 && options.numberOfLevelZeroTilesY === 1;
this.tilingScheme_ = new Cesium.GeographicTilingScheme(options);
}
else if (this.projection_.getCode() === 'EPSG:3857') {
this.shouldRequestNextLevel = false;
this.tilingScheme_ = new Cesium.WebMercatorTilingScheme(options);
}
else {
return;
}
this.rectangle_ = this.tilingScheme_.rectangle;
this.ready_ = true;
}
}
/**
* Generates the proper attributions for a given position and zoom
* level.
* @implements
*/
getTileCredits(x, y, level) {
const attributionsFunction = this.source_.getAttributions();
if (!attributionsFunction) {
return [];
}
const extent = this.map_.getView().calculateExtent(this.map_.getSize());
const center = this.map_.getView().getCenter();
const zoom = this.shouldRequestNextLevel ? level + 1 : level;
return attributionsFunctionToCredits(attributionsFunction, zoom, center, extent);
}
/**
* @implements
*/
requestImage(x, y, level, request) {
const tileUrlFunction = this.source_.getTileUrlFunction();
if (tileUrlFunction && this.projection_) {
const z_ = this.shouldRequestNextLevel ? level + 1 : level;
let y_ = y;
if (!olUseNewCoordinates) {
// LEGACY
// OpenLayers version 3 to 5 tile coordinates increase from bottom to top
y_ = -y - 1;
}
let url = tileUrlFunction.call(this.source_, [z_, x, y_], 1, this.projection_);
if (this.proxy) {
url = this.proxy.getURL(url);
}
if (url) {
// It is probably safe to cast here
return Cesium.ImageryProvider.loadImage(this, url);
}
return this.emptyCanvasPromise_;
}
else {
// return empty canvas to stop Cesium from retrying later
return this.emptyCanvasPromise_;
}
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"OLImageryProvider.js","sourceRoot":"","sources":["../../../src/olcs/core/OLImageryProvider.ts"],"names":[],"mappings":"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"}