goog.provide('ol.loadingstrategy'); goog.require('ol.TileCoord'); /** * Strategy function for loading all features with a single request. * @param {ol.Extent} extent Extent. * @param {number} resolution Resolution. * @return {Array.} Extents. * @api */ ol.loadingstrategy.all = function(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 */ ol.loadingstrategy.bbox = function(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 */ ol.loadingstrategy.createTile = function(tileGrid) { return ( /** * @param {ol.Extent} extent Extent. * @param {number} resolution Resolution. * @return {Array.} Extents. */ function(extent, resolution) { var z = tileGrid.getZForResolution(resolution); var tileRange = tileGrid.getTileRangeForExtentAndZ(extent, z); /** @type {Array.} */ var extents = []; var tileCoord = new ol.TileCoord(z, 0, 0); for (tileCoord.x = tileRange.minX; tileCoord.x <= tileRange.maxX; ++tileCoord.x) { for (tileCoord.y = tileRange.minY; tileCoord.y <= tileRange.maxY; ++tileCoord.y) { extents.push(tileGrid.getTileCoordExtent(tileCoord)); } } return extents; }); };