edgemaster for pointing it out. git-svn-id: http://svn.openlayers.org/trunk/openlayers@9247 dc9f47b5-9b13-0410-9fdd-eb0c1a62fdaf
179 lines
5.4 KiB
JavaScript
179 lines
5.4 KiB
JavaScript
/* Copyright (c) 2006-2009 MetaCarta, Inc., published under the Clear BSD
|
|
* license. See http://svn.openlayers.org/trunk/openlayers/license.txt for the
|
|
* full text of the license. */
|
|
|
|
/**
|
|
* @requires OpenLayers/Layer/Grid.js
|
|
*/
|
|
|
|
/**
|
|
* Class: OpenLayers.Layer.XYZ
|
|
* The XYZ class is designed to make it easier for people who have tiles
|
|
* arranged by a standard XYZ grid.
|
|
*/
|
|
OpenLayers.Layer.XYZ = OpenLayers.Class(OpenLayers.Layer.Grid, {
|
|
|
|
/**
|
|
* APIProperty: isBaseLayer
|
|
* Default is true, as this is designed to be a base tile source.
|
|
*/
|
|
isBaseLayer: true,
|
|
|
|
/**
|
|
* APIProperty: sphericalMecator
|
|
* Whether the tile extents should be set to the defaults for
|
|
* spherical mercator. Useful for things like OpenStreetMap.
|
|
* Default is false, except for the OSM subclass.
|
|
*/
|
|
sphericalMercator: false,
|
|
|
|
/**
|
|
* Constructor: OpenLayers.Layer.OSM
|
|
*
|
|
* Parameters:
|
|
* name - {String}
|
|
* url - {String}
|
|
* options - {Object} Hashtable of extra options to tag onto the layer
|
|
*/
|
|
initialize: function(name, url, options) {
|
|
if (options && options.sphericalMercator || this.sphericalMercator) {
|
|
options = OpenLayers.Util.extend({
|
|
maxExtent: new OpenLayers.Bounds(
|
|
-128 * 156543.0339,
|
|
-128 * 156543.0339,
|
|
128 * 156543.0339,
|
|
128 * 156543.0339
|
|
),
|
|
maxResolution: 156543.0339,
|
|
numZoomLevels: 19,
|
|
units: "m",
|
|
projection: "EPSG:900913"
|
|
}, options);
|
|
}
|
|
url = url || this.url;
|
|
name = name || this.name;
|
|
var newArguments = [name, url, {}, options];
|
|
OpenLayers.Layer.Grid.prototype.initialize.apply(this, newArguments);
|
|
},
|
|
|
|
/**
|
|
* APIMethod: clone
|
|
* Create a clone of this layer
|
|
*
|
|
* Parameters:
|
|
* obj - {Object} Is this ever used?
|
|
*
|
|
* Returns:
|
|
* {<OpenLayers.Layer.Grid>} An exact clone of this OpenLayers.Layer.Grid
|
|
*/
|
|
clone: function (obj) {
|
|
|
|
if (obj == null) {
|
|
obj = new OpenLayers.Layer.XYZ(this.name,
|
|
this.url,
|
|
this.options);
|
|
}
|
|
|
|
//get all additions from superclasses
|
|
obj = OpenLayers.Layer.HTTPRequest.prototype.clone.apply(this, [obj]);
|
|
|
|
// copy/set any non-init, non-simple values here
|
|
if (this.tileSize != null) {
|
|
obj.tileSize = this.tileSize.clone();
|
|
}
|
|
|
|
// we do not want to copy reference to grid, so we make a new array
|
|
obj.grid = [];
|
|
|
|
return obj;
|
|
},
|
|
|
|
/**
|
|
* Method: getUrl
|
|
*
|
|
* Parameters:
|
|
* bounds - {<OpenLayers.Bounds>}
|
|
*
|
|
* Returns:
|
|
* {String} A string with the layer's url and parameters and also the
|
|
* passed-in bounds and appropriate tile size specified as
|
|
* parameters
|
|
*/
|
|
getURL: function (bounds) {
|
|
var res = this.map.getResolution();
|
|
var x = Math.round((bounds.left - this.maxExtent.left)
|
|
/ (res * this.tileSize.w));
|
|
var y = Math.round((this.maxExtent.top - bounds.top)
|
|
/ (res * this.tileSize.h));
|
|
var z = this.map.getZoom();
|
|
var limit = Math.pow(2, z);
|
|
|
|
var url = this.url;
|
|
var s = '' + x + y + z;
|
|
if (url instanceof Array)
|
|
{
|
|
url = this.selectUrl(s, url);
|
|
}
|
|
|
|
var path = OpenLayers.String.format(url, {'x': x, 'y': y, 'z': z});
|
|
|
|
return path;
|
|
},
|
|
|
|
/**
|
|
* Method: addTile
|
|
* addTile creates a tile, initializes it, and adds it to the layer div.
|
|
*
|
|
* Parameters:
|
|
* bounds - {<OpenLayers.Bounds>}
|
|
* position - {<OpenLayers.Pixel>}
|
|
*
|
|
* Returns:
|
|
* {<OpenLayers.Tile.Image>} The added OpenLayers.Tile.Image
|
|
*/
|
|
addTile:function(bounds,position) {
|
|
return new OpenLayers.Tile.Image(this, position, bounds,
|
|
null, this.tileSize);
|
|
},
|
|
|
|
/* APIMethod: setMap
|
|
* When the layer is added to a map, then we can fetch our origin
|
|
* (if we don't have one.)
|
|
*
|
|
* Parameters:
|
|
* map - {<OpenLayers.Map>}
|
|
*/
|
|
setMap: function(map) {
|
|
OpenLayers.Layer.Grid.prototype.setMap.apply(this, arguments);
|
|
if (!this.tileOrigin) {
|
|
this.tileOrigin = new OpenLayers.LonLat(this.maxExtent.left,
|
|
this.maxExtent.bottom);
|
|
}
|
|
},
|
|
|
|
CLASS_NAME: "OpenLayers.Layer.XYZ"
|
|
});
|
|
|
|
|
|
/**
|
|
* Class: OpenLayers.Layer.OSM
|
|
* A class to access OpenStreetMap tiles. By default, uses the OpenStreetMap
|
|
* hosted tile.openstreetmap.org 'Mapnik' tileset. If you wish to use
|
|
* tiles@home / osmarender layer instead, you can pass a layer like:
|
|
*
|
|
* (code)
|
|
* new OpenLayers.Layer.OSM("t@h",
|
|
* "http://tah.openstreetmap.org/Tiles/tile/${z}/${x}/${y}.png");
|
|
* (end)
|
|
*
|
|
* This layer defaults to Spherical Mercator.
|
|
*/
|
|
|
|
OpenLayers.Layer.OSM = OpenLayers.Class(OpenLayers.Layer.XYZ, {
|
|
name: "OpenStreetMap",
|
|
attribution: "Data CC-By-SA by <a href='http://openstreetmap.org/'>OpenStreetMap</a>",
|
|
sphericalMercator: true,
|
|
url: 'http://tile.openstreetmap.org/${z}/${x}/${y}.png',
|
|
CLASS_NAME: "OpenLayers.Layer.OSM"
|
|
});
|