/** * @module ol/loadingstrategy */ /** * Strategy function for loading all features with a single request. * @param {ol.Extent} extent Extent. * @param {number} resolution Resolution. * @return {Array.} Extents. * @api */ export function all(extent, resolution) { return [[-Infinity, -Infinity, Infinity, Infinity]]; } /** * Strategy function for loading features based on the view's extent and * resolution. * @param {ol.Extent} extent Extent. * @param {number} resolution Resolution. * @return {Array.} Extents. * @api */ export function bbox(extent, resolution) { return [extent]; } /** * Creates a strategy function for loading features based on a tile grid. * @param {ol.tilegrid.TileGrid} tileGrid Tile grid. * @return {function(ol.Extent, number): Array.} Loading strategy. * @api */ export function tile(tileGrid) { return ( /** * @param {ol.Extent} extent Extent. * @param {number} resolution Resolution. * @return {Array.} Extents. */ function(extent, resolution) { const z = tileGrid.getZForResolution(resolution); const tileRange = tileGrid.getTileRangeForExtentAndZ(extent, z); /** @type {Array.} */ const extents = []; /** @type {ol.TileCoord} */ const tileCoord = [z, 0, 0]; for (tileCoord[1] = tileRange.minX; tileCoord[1] <= tileRange.maxX; ++tileCoord[1]) { for (tileCoord[2] = tileRange.minY; tileCoord[2] <= tileRange.maxY; ++tileCoord[2]) { extents.push(tileGrid.getTileCoordExtent(tileCoord)); } } return extents; }); }