Class: WebGLTileLayer

ol/layer/WebGLTile~WebGLTileLayer


import WebGLTileLayer from 'ol/layer/WebGLTile.js';

For layer sources that provide pre-rendered, tiled images in grids that are organized by zoom levels for specific resolutions. Note that any property set in the options is set as a BaseObject property on the layer object; for example, setting title: 'My Title' in the options means that title is observable, and has get/set accessors.

new WebGLTileLayer(options)

Name Type Description
style Style | undefined

Style to apply to the layer.

className string (defaults to 'ol-layer')

A CSS class name to set to the layer element.

opacity number (defaults to 1)

Opacity (0, 1).

visible boolean (defaults to true)

Visibility.

extent Extent | undefined

The bounding extent for layer rendering. The layer will not be rendered outside of this extent.

zIndex number | undefined

The z-index for layer rendering. At rendering time, the layers will be ordered, first by Z-index and then by position. When undefined, a zIndex of 0 is assumed for layers that are added to the map's layers collection, or Infinity when the layer's setMap() method was used.

minResolution number | undefined

The minimum resolution (inclusive) at which this layer will be visible.

maxResolution number | undefined

The maximum resolution (exclusive) below which this layer will be visible.

minZoom number | undefined

The minimum view zoom level (exclusive) above which this layer will be visible.

maxZoom number | undefined

The maximum view zoom level (inclusive) at which this layer will be visible.

preload number (defaults to 0)

Preload. Load low-resolution tiles up to preload levels. 0 means no preloading.

source SourceType | undefined

Source for this layer.

sources Array.<SourceType> | function | undefined

Array of sources for this layer. Takes precedence over source. Can either be an array of sources, or a function that expects an extent and a resolution (in view projection units per pixel) and returns an array of sources. See sourcesFromTileGrid for a helper function to generate sources that are organized in a pyramid following the same pattern as a tile grid. Note: All sources must have the same band count and content.

map Map | undefined

Sets the layer as overlay on a map. The map will not manage this layer in its layers collection, and the layer will be rendered on top. This is useful for temporary layers. The standard way to add a layer to a map and have it managed by the map is to use addLayer.

useInterimTilesOnError boolean (defaults to true)

Deprecated. Use interim tiles on error.

cacheSize number (defaults to 512)

The internal texture cache size. This needs to be large enough to render two zoom levels worth of tiles.

properties Object.<string, *> | undefined

Arbitrary observable properties. Can be accessed with #get() and #set().

Fires:

Extends

Observable Properties

Name Type Settable ObjectEvent type Description
extent Extent | undefined yes change:extent

The layer extent.

maxResolution number yes change:maxresolution

The maximum resolution of the layer.

maxZoom number yes change:maxzoom

The maximum zoom level of the layer.

minResolution number yes change:minresolution

The minimum resolution of the layer.

minZoom number yes change:minzoom

The minimum zoom level of the layer.

opacity number yes change:opacity

The opacity of the layer.

preload number yes change:preload

The level to preload tiles up to.

source SourceType | null yes change:source

The layer source (or null if not yet set).

useInterimTilesOnError boolean yes change:useinterimtilesonerror

Use interim tiles on error.

visible boolean yes change:visible

The value of the visible property of the layer.

zIndex number | undefined yes change:zindex

The Z-index of the layer.

Methods

Increases the revision counter and dispatches a 'change' event.

dispatchEvent(event){boolean | undefined} inherited

Dispatches an event and calls all listeners listening for events of this type. The event parameter can either be a string or an Object with a type property.

Name Type Description
event BaseEvent | string

Event object.

Returns:
false if anyone called preventDefault on the event object or if any of the listeners returned false.

Clean up underlying WebGL resources.

Gets a value.

Name Type Description
key string

Key name.

Returns:
Value.

getAttributions(view){Array.<string>} inherited

Get the attributions of the source of this layer for the given view.

Name Type Description
view View | ViewStateLayerStateExtent | undefined

View or FrameState. Only required when the layer is not added to a map.

Returns:
Attributions for this layer at the given view.

getData(pixel){Uint8ClampedArray | Uint8Array | Float32Array | DataView | null} inherited

Get data for a pixel location. The return type depends on the source data. For image tiles, a four element RGBA array will be returned. For data tiles, the array length will match the number of bands in the dataset. For requests outside the layer extent, null will be returned. Data for a image tiles can only be retrieved if the source's crossOrigin property is set.

// display layer data on every pointer move
map.on('pointermove', (event) => {
  console.log(layer.getData(event.pixel));
});
Name Type Description
pixel Pixel

Pixel.

Returns:
Pixel data.

getExtent(){Extent | undefined} inherited

Return the extent of the layer or undefined if it will be visible regardless of extent.

Returns:
The layer extent.

getKeys(){Array.<string>} inherited

Get a list of object property names.

Returns:
List of property names.

getMaxResolution(){number} inherited

Return the maximum resolution of the layer. Returns Infinity if the layer has no maximum resolution set.

Returns:
The maximum resolution of the layer.

getMaxZoom(){number} inherited

Return the maximum zoom level of the layer. Returns Infinity if the layer has no maximum zoom set.

Returns:
The maximum zoom level of the layer.

getMinResolution(){number} inherited

Return the minimum resolution of the layer. Returns 0 if the layer has no minimum resolution set.

Returns:
The minimum resolution of the layer.

getMinZoom(){number} inherited

Return the minimum zoom level of the layer. Returns -Infinity if the layer has no minimum zoom set.

Returns:
The minimum zoom level of the layer.

getOpacity(){number} inherited

Return the opacity of the layer (between 0 and 1).

Returns:
The opacity of the layer.

getPreload(){number} inherited

Return the level as number to which we will preload tiles up to.

Returns:
The level to preload tiles up to.

getProperties(){Object.<string, *>} inherited

Get an object of all property names and values.

Returns:
Object.

getRevision(){number} inherited

Get the version number for this object. Each time the object is modified, its version number will be incremented.

Returns:
Revision.

getSource(){SourceType | null} inherited

Get the layer source.

Returns:
The layer source (or null if not yet set).

getUseInterimTilesOnError(){boolean} inherited

Deprecated. Whether we use interim tiles on error.

Returns:
Use interim tiles on error.

getVisible(){boolean} inherited

Return the value of this layer's visible property. To find out whether the layer is visible on a map, use isVisible() instead.

Returns:
The value of the visible property of the layer.

getZIndex(){number | undefined} inherited

Return the Z-index of the layer, which is used to order layers before rendering. Returns undefined if the layer is unmanaged.

Returns:
The Z-index of the layer.

isVisible(view){boolean} inherited

The layer is visible on the map view, i.e. within its min/max resolution or zoom and extent, not set to visible: false, and not inside a layer group that is set to visible: false.

Name Type Description
view View | ViewStateLayerStateExtent | undefined

View or FrameState. Only required when the layer is not added to a map.

Returns:
The layer is visible in the map view.

on(type, listener){EventsKey | Array<EventsKey>} inherited

Listen for a certain type of event.

Name Type Description
type string | Array.<string>

The event type or array of event types.

listener function

The listener function.

Returns:
Unique key for the listener. If called with an array of event types as the first argument, the return will be an array of keys.

once(type, listener){EventsKey | Array<EventsKey>} inherited

Listen once for a certain type of event.

Name Type Description
type string | Array.<string>

The event type or array of event types.

listener function

The listener function.

Returns:
Unique key for the listener. If called with an array of event types as the first argument, the return will be an array of keys.

set(key, value, silent) inherited

Sets a value.

Name Type Description
key string

Key name.

value *

Value.

silent boolean | undefined

Update without triggering an event.

setExtent(extent) inherited

Set the extent at which the layer is visible. If undefined, the layer will be visible at all extents.

Name Type Description
extent Extent | undefined

The extent of the layer.

Sets the layer to be rendered on top of other layers on a map. The map will not manage this layer in its layers collection. This is useful for temporary layers. To remove an unmanaged layer from the map, use #setMap(null).

To add the layer to a map and have it managed by the map, use addLayer instead.

Name Type Description
map Map | null

Map.

setMaxResolution(maxResolution) inherited

Set the maximum resolution at which the layer is visible.

Name Type Description
maxResolution number

The maximum resolution of the layer.

setMaxZoom(maxZoom) inherited

Set the maximum zoom (exclusive) at which the layer is visible. Note that the zoom levels for layer visibility are based on the view zoom level, which may be different from a tile source zoom level.

Name Type Description
maxZoom number

The maximum zoom of the layer.

setMinResolution(minResolution) inherited

Set the minimum resolution at which the layer is visible.

Name Type Description
minResolution number

The minimum resolution of the layer.

setMinZoom(minZoom) inherited

Set the minimum zoom (inclusive) at which the layer is visible. Note that the zoom levels for layer visibility are based on the view zoom level, which may be different from a tile source zoom level.

Name Type Description
minZoom number

The minimum zoom of the layer.

setOpacity(opacity) inherited

Set the opacity of the layer, allowed values range from 0 to 1.

Name Type Description
opacity number

The opacity of the layer.

setPreload(preload) inherited

Set the level as number to which we will preload tiles up to.

Name Type Description
preload number

The level to preload tiles up to.

setProperties(values, silent) inherited

Sets a collection of key-value pairs. Note that this changes any existing properties and adds new ones (it does not remove any existing properties).

Name Type Description
values Object.<string, *>

Values.

silent boolean | undefined

Update without triggering an event.

setSource(source) inherited

Set the layer source.

Name Type Description
source SourceType | null

The layer source.

setUseInterimTilesOnError(useInterimTilesOnError) inherited

Deprecated. Set whether we use interim tiles on error.

Name Type Description
useInterimTilesOnError boolean

Use interim tiles on error.

setVisible(visible) inherited

Set the visibility of the layer (true or false).

Name Type Description
visible boolean

The visibility of the layer.

setZIndex(zindex) inherited

Set Z-index of the layer, which is used to order layers before rendering. The default Z-index is 0.

Name Type Description
zindex number

The z-index of the layer.

un(type, listener) inherited

Unlisten for a certain type of event.

Name Type Description
type string | Array.<string>

The event type or array of event types.

listener function

The listener function.

unset(key, silent) inherited

Unsets a property.

Name Type Description
key string

Key name.

silent boolean | undefined

Unset without triggering an event.

updateStyleVariables(variables)

Update any variables used by the layer style and trigger a re-render.

Name Type Description
variables Object.<string, number>

Variables to update.