Demonstrate how source.setUrl() works
This commit is contained in:
12
examples/reusable-source.html
Normal file
12
examples/reusable-source.html
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
---
|
||||||
|
layout: example.html
|
||||||
|
title: Reusable Source
|
||||||
|
shortdesc: Updating a tile source by changing the URL.
|
||||||
|
docs: >
|
||||||
|
You can call <code>source.setUrl()</code> to update the URL for a tile source. Note that when you change the URL for a tile source, existing tiles will not be replaced until new tiles are loaded. If you are interested instead in clearing currently rendered tiles, you can call the <code>source.refresh()</code> method. Alternatively, you can use two separate sources if you want to remove rendered tiles and start over loading new tiles.
|
||||||
|
---
|
||||||
|
<div id="map" class="map"></div>
|
||||||
|
<button class="switcher" value="0">January</button>
|
||||||
|
<button class="switcher" value="1">January (with bathymetry)</button>
|
||||||
|
<button class="switcher" value="2">July</button>
|
||||||
|
<button class="switcher" value="3">July (with bathymetry)</button>
|
||||||
39
examples/reusable-source.js
Normal file
39
examples/reusable-source.js
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
goog.require('ol.Map');
|
||||||
|
goog.require('ol.View');
|
||||||
|
goog.require('ol.layer.Tile');
|
||||||
|
goog.require('ol.source.XYZ');
|
||||||
|
|
||||||
|
var urls = [
|
||||||
|
'https://{a-c}.tiles.mapbox.com/v3/mapbox.blue-marble-topo-jan/{z}/{x}/{y}.png',
|
||||||
|
'https://{a-c}.tiles.mapbox.com/v3/mapbox.blue-marble-topo-bathy-jan/{z}/{x}/{y}.png',
|
||||||
|
'https://{a-c}.tiles.mapbox.com/v3/mapbox.blue-marble-topo-jul/{z}/{x}/{y}.png',
|
||||||
|
'https://{a-c}.tiles.mapbox.com/v3/mapbox.blue-marble-topo-bathy-jul/{z}/{x}/{y}.png'
|
||||||
|
];
|
||||||
|
|
||||||
|
var source = new ol.source.XYZ();
|
||||||
|
|
||||||
|
var map = new ol.Map({
|
||||||
|
target: 'map',
|
||||||
|
layers: [
|
||||||
|
new ol.layer.Tile({
|
||||||
|
source: source
|
||||||
|
})
|
||||||
|
],
|
||||||
|
view: new ol.View({
|
||||||
|
center: [0, 0],
|
||||||
|
zoom: 2
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
function updateUrl(index) {
|
||||||
|
source.setUrl(urls[index]);
|
||||||
|
}
|
||||||
|
|
||||||
|
var buttons = document.getElementsByClassName('switcher');
|
||||||
|
for (var i = 0, ii = buttons.length; i < ii; ++i) {
|
||||||
|
var button = buttons[i];
|
||||||
|
button.addEventListener('click', updateUrl.bind(null, Number(button.value)));
|
||||||
|
}
|
||||||
|
|
||||||
|
updateUrl(0);
|
||||||
@@ -22,11 +22,11 @@ goog.require('ol.source.TileImage');
|
|||||||
*
|
*
|
||||||
* @constructor
|
* @constructor
|
||||||
* @extends {ol.source.TileImage}
|
* @extends {ol.source.TileImage}
|
||||||
* @param {olx.source.XYZOptions} options XYZ options.
|
* @param {olx.source.XYZOptions=} opt_options XYZ options.
|
||||||
* @api stable
|
* @api stable
|
||||||
*/
|
*/
|
||||||
ol.source.XYZ = function(options) {
|
ol.source.XYZ = function(opt_options) {
|
||||||
options = options || {};
|
var options = opt_options || {};
|
||||||
var projection = options.projection !== undefined ?
|
var projection = options.projection !== undefined ?
|
||||||
options.projection : 'EPSG:3857';
|
options.projection : 'EPSG:3857';
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user