diff options
| author | Joar Wandborg <git@wandborg.com> | 2012-01-10 01:54:37 +0100 | 
|---|---|---|
| committer | Joar Wandborg <git@wandborg.com> | 2012-01-25 23:42:04 +0100 | 
| commit | c5ba5b0456a711d157e317f220e9c739226e7f50 (patch) | |
| tree | 2800568ac8e484649a978e0fe7e682a8bcfe20d4 /extlib/leaflet/src/layer/tile | |
| parent | c47a03b909ecd97cab5b144d0cab007b62b92a90 (diff) | |
| download | mediagoblin-c5ba5b0456a711d157e317f220e9c739226e7f50.tar.lz mediagoblin-c5ba5b0456a711d157e317f220e9c739226e7f50.tar.xz mediagoblin-c5ba5b0456a711d157e317f220e9c739226e7f50.zip | |
Installed leaflet in extlib
Diffstat (limited to 'extlib/leaflet/src/layer/tile')
| -rw-r--r-- | extlib/leaflet/src/layer/tile/TileLayer.Canvas.js | 41 | ||||
| -rw-r--r-- | extlib/leaflet/src/layer/tile/TileLayer.WMS.js | 47 | ||||
| -rw-r--r-- | extlib/leaflet/src/layer/tile/TileLayer.js | 262 | 
3 files changed, 350 insertions, 0 deletions
| diff --git a/extlib/leaflet/src/layer/tile/TileLayer.Canvas.js b/extlib/leaflet/src/layer/tile/TileLayer.Canvas.js new file mode 100644 index 00000000..08bbaae2 --- /dev/null +++ b/extlib/leaflet/src/layer/tile/TileLayer.Canvas.js @@ -0,0 +1,41 @@ +L.TileLayer.Canvas = L.TileLayer.extend({
 +	options: {
 +		async: false
 +	},
 +	
 +	initialize: function(options) {
 +		L.Util.setOptions(this, options);
 +	},
 +	
 +	_createTileProto: function() {
 +		this._canvasProto = L.DomUtil.create('canvas', 'leaflet-tile');
 +		
 +		var tileSize = this.options.tileSize;
 +		this._canvasProto.width = tileSize;
 +		this._canvasProto.height = tileSize;
 +	},
 +	
 +	_createTile: function() {
 +		var tile = this._canvasProto.cloneNode(false);
 +		tile.onselectstart = tile.onmousemove = L.Util.falseFn;
 +		return tile;
 +	},
 +	
 +	_loadTile: function(tile, tilePoint, zoom) {
 +		tile._layer = this;
 +		
 +		this.drawTile(tile, tilePoint, zoom);
 +		
 +		if (!this.options.async) {
 +			this.tileDrawn(tile);
 +		}
 +	},
 +	
 +	drawTile: function(tile, tilePoint, zoom) {
 +		// override with rendering code
 +	},
 +	
 +	tileDrawn: function(tile) {
 +		this._tileOnLoad.call(tile);
 +	}
 +});
\ No newline at end of file diff --git a/extlib/leaflet/src/layer/tile/TileLayer.WMS.js b/extlib/leaflet/src/layer/tile/TileLayer.WMS.js new file mode 100644 index 00000000..2f4ad05a --- /dev/null +++ b/extlib/leaflet/src/layer/tile/TileLayer.WMS.js @@ -0,0 +1,47 @@ +L.TileLayer.WMS = L.TileLayer.extend({
 +	defaultWmsParams: {
 +		service: 'WMS',
 +		request: 'GetMap',
 +		version: '1.1.1',
 +		layers: '',
 +		styles: '',
 +		format: 'image/jpeg',
 +		transparent: false
 +	},
 +
 +	initialize: function(/*String*/ url, /*Object*/ options) {
 +		this._url = url;
 +		
 +		this.wmsParams = L.Util.extend({}, this.defaultWmsParams);
 +		this.wmsParams.width = this.wmsParams.height = this.options.tileSize;
 +		
 +		for (var i in options) {
 +			// all keys that are not TileLayer options go to WMS params
 +			if (!this.options.hasOwnProperty(i)) {
 +				this.wmsParams[i] = options[i];
 +			}
 +		}
 +
 +		L.Util.setOptions(this, options);
 +	},
 +	
 +	onAdd: function(map) {
 +		var projectionKey = (parseFloat(this.wmsParams.version) >= 1.3 ? 'crs' : 'srs');
 +		this.wmsParams[projectionKey] = map.options.crs.code;		
 +
 +		L.TileLayer.prototype.onAdd.call(this, map);
 +	},
 +	
 +	getTileUrl: function(/*Point*/ tilePoint, /*Number*/ zoom)/*-> String*/ {
 +		var tileSize = this.options.tileSize,
 +			nwPoint = tilePoint.multiplyBy(tileSize),
 +			sePoint = nwPoint.add(new L.Point(tileSize, tileSize)),
 +			nwMap = this._map.unproject(nwPoint, this._zoom, true),
 +			seMap = this._map.unproject(sePoint, this._zoom, true),
 +			nw = this._map.options.crs.project(nwMap),
 +			se = this._map.options.crs.project(seMap),
 +			bbox = [nw.x, se.y, se.x, nw.y].join(',');
 +		
 +		return this._url + L.Util.getParamString(this.wmsParams) + "&bbox=" + bbox;
 +	}
 +});
\ No newline at end of file diff --git a/extlib/leaflet/src/layer/tile/TileLayer.js b/extlib/leaflet/src/layer/tile/TileLayer.js new file mode 100644 index 00000000..68072ee9 --- /dev/null +++ b/extlib/leaflet/src/layer/tile/TileLayer.js @@ -0,0 +1,262 @@ +/*
 + * L.TileLayer is used for standard xyz-numbered tile layers.
 + */
 +
 +L.TileLayer = L.Class.extend({
 +	includes: L.Mixin.Events,
 +	
 +	options: {
 +		minZoom: 0,
 +		maxZoom: 18,
 +		tileSize: 256,
 +		subdomains: 'abc',
 +		errorTileUrl: '',
 +		attribution: '',
 +		opacity: 1,
 +		scheme: 'xyz',
 +    noWrap: false,
 +		
 +		unloadInvisibleTiles: L.Browser.mobileWebkit,
 +		updateWhenIdle: L.Browser.mobileWebkit
 +	},
 +	
 +	initialize: function(url, options) {
 +		L.Util.setOptions(this, options);
 +		
 +		this._url = url;
 +		
 +		if (typeof this.options.subdomains == 'string') {
 +			this.options.subdomains = this.options.subdomains.split('');
 +		}
 +	},
 +	
 +	onAdd: function(map) {
 +		this._map = map;
 +		
 +		// create a container div for tiles
 +		this._initContainer();
 +		
 +		// create an image to clone for tiles
 +		this._createTileProto();
 +		
 +		// set up events
 +		map.on('viewreset', this._reset, this);
 +		
 +		if (this.options.updateWhenIdle) {
 +			map.on('moveend', this._update, this);
 +		} else {
 +			this._limitedUpdate = L.Util.limitExecByInterval(this._update, 100, this);
 +			map.on('move', this._limitedUpdate, this);
 +		}
 +		
 +		this._reset();
 +		this._update();
 +	},
 +	
 +	onRemove: function(map) {
 +		this._map.getPanes().tilePane.removeChild(this._container);
 +		this._container = null;
 +		
 +		this._map.off('viewreset', this._reset, this);
 +		
 +		if (this.options.updateWhenIdle) {
 +			this._map.off('moveend', this._update, this);
 +		} else {
 +			this._map.off('move', this._limitedUpdate, this);
 +		}
 +	},
 +	
 +	getAttribution: function() {
 +		return this.options.attribution;
 +	},
 +	
 +	setOpacity: function(opacity) {
 +		this.options.opacity = opacity;
 +		
 +		this._setOpacity(opacity);
 +		
 +		// stupid webkit hack to force redrawing of tiles
 +		if (L.Browser.webkit) {
 +			for (i in this._tiles) {
 +				this._tiles[i].style.webkitTransform += ' translate(0,0)';
 +			}
 +		}
 +	},
 +	
 +	_setOpacity: function(opacity) {
 +		if (opacity < 1) {
 +			L.DomUtil.setOpacity(this._container, opacity);
 +		}
 +	},
 +	
 +	_initContainer: function() {
 +		var tilePane = this._map.getPanes().tilePane;
 +		
 +		if (!this._container || tilePane.empty) {
 +			this._container = L.DomUtil.create('div', 'leaflet-layer', tilePane);
 +			
 +			this._setOpacity(this.options.opacity);
 +		}
 +	},
 +	
 +	_reset: function() {
 +		this._tiles = {};
 +		this._initContainer();
 +		this._container.innerHTML = '';
 +	},
 +	
 +	_update: function() {
 +		var bounds = this._map.getPixelBounds(),
 +			tileSize = this.options.tileSize;
 +		
 +		var nwTilePoint = new L.Point(
 +				Math.floor(bounds.min.x / tileSize),
 +				Math.floor(bounds.min.y / tileSize)),
 +			seTilePoint = new L.Point(
 +				Math.floor(bounds.max.x / tileSize),
 +				Math.floor(bounds.max.y / tileSize)),
 +			tileBounds = new L.Bounds(nwTilePoint, seTilePoint);
 +		
 +		this._addTilesFromCenterOut(tileBounds);
 +		
 +		if (this.options.unloadInvisibleTiles) {
 +			this._removeOtherTiles(tileBounds);
 +		}
 +	},
 +	
 +	_addTilesFromCenterOut: function(bounds) {
 +		var queue = [],
 +			center = bounds.getCenter();
 +		
 +		for (var j = bounds.min.y; j <= bounds.max.y; j++) {
 +			for (var i = bounds.min.x; i <= bounds.max.x; i++) {				
 +				if ((i + ':' + j) in this._tiles) { continue; }
 +				queue.push(new L.Point(i, j));
 +			}
 +		}
 +		
 +		// load tiles in order of their distance to center
 +		queue.sort(function(a, b) {
 +			return a.distanceTo(center) - b.distanceTo(center);
 +		});
 +		
 +		this._tilesToLoad = queue.length;
 +		for (var k = 0, len = this._tilesToLoad; k < len; k++) {
 +			this._addTile(queue[k]);
 +		}
 +	},
 +	
 +	_removeOtherTiles: function(bounds) {
 +		var kArr, x, y, key;
 +		
 +		for (key in this._tiles) {
 +			if (this._tiles.hasOwnProperty(key)) {
 +				kArr = key.split(':');
 +				x = parseInt(kArr[0], 10);
 +				y = parseInt(kArr[1], 10);
 +				
 +				// remove tile if it's out of bounds
 +				if (x < bounds.min.x || x > bounds.max.x || y < bounds.min.y || y > bounds.max.y) {
 +					this._tiles[key].src = '';
 +					if (this._tiles[key].parentNode == this._container) {
 +						this._container.removeChild(this._tiles[key]);
 +					}
 +					delete this._tiles[key];
 +				}
 +			}
 +		}		
 +	},
 +	
 +	_addTile: function(tilePoint) {
 +		var tilePos = this._getTilePos(tilePoint),
 +			zoom = this._map.getZoom(),
 +			key = tilePoint.x + ':' + tilePoint.y;
 +			
 +		// wrap tile coordinates
 +		var tileLimit = (1 << zoom);
 +		if (!this.options.noWrap) {
 +      tilePoint.x = ((tilePoint.x % tileLimit) + tileLimit) % tileLimit;
 +    }
 +		if (tilePoint.y < 0 || tilePoint.y >= tileLimit) { return; }
 +		
 +		// create tile
 +		var tile = this._createTile();
 +		L.DomUtil.setPosition(tile, tilePos);
 +		
 +		this._tiles[key] = tile;
 +        
 +		if (this.options.scheme == 'tms') {
 +			tilePoint.y = tileLimit - tilePoint.y - 1;
 +		}
 +
 +		this._loadTile(tile, tilePoint, zoom);
 +		
 +		this._container.appendChild(tile);
 +	},
 +	
 +	_getTilePos: function(tilePoint) {
 +		var origin = this._map.getPixelOrigin(),
 +			tileSize = this.options.tileSize;
 +		
 +		return tilePoint.multiplyBy(tileSize).subtract(origin);
 +	},
 +	
 +	// image-specific code (override to implement e.g. Canvas or SVG tile layer)
 +	
 +	getTileUrl: function(tilePoint, zoom) {
 +		var subdomains = this.options.subdomains,
 +			s = this.options.subdomains[(tilePoint.x + tilePoint.y) % subdomains.length];
 +
 +		return this._url
 +				.replace('{s}', s)
 +				.replace('{z}', zoom)
 +				.replace('{x}', tilePoint.x)
 +				.replace('{y}', tilePoint.y);
 +	},
 +	
 +	_createTileProto: function() {
 +		this._tileImg = L.DomUtil.create('img', 'leaflet-tile');
 +		this._tileImg.galleryimg = 'no';
 +		
 +		var tileSize = this.options.tileSize;
 +		this._tileImg.style.width = tileSize + 'px';
 +		this._tileImg.style.height = tileSize + 'px';
 +	},
 +	
 +	_createTile: function() {
 +		var tile = this._tileImg.cloneNode(false);
 +		tile.onselectstart = tile.onmousemove = L.Util.falseFn;
 +		return tile;
 +	},
 +	
 +	_loadTile: function(tile, tilePoint, zoom) {
 +		tile._layer = this;
 +		tile.onload = this._tileOnLoad;
 +		tile.onerror = this._tileOnError;
 +		tile.src = this.getTileUrl(tilePoint, zoom);
 +	},
 +	
 +	_tileOnLoad: function(e) {
 +		var layer = this._layer;
 +		
 +		this.className += ' leaflet-tile-loaded'; 
 +
 +		layer.fire('tileload', {tile: this, url: this.src});
 +		
 +		layer._tilesToLoad--;
 +		if (!layer._tilesToLoad) {
 +			layer.fire('load');
 +		}
 +	},
 +	
 +	_tileOnError: function(e) {
 +		var layer = this._layer;
 +		
 +		layer.fire('tileerror', {tile: this, url: this.src});
 +		
 +		var newUrl = layer.options.errorTileUrl;
 +		if (newUrl) {
 +			this.src = newUrl;
 +		}
 +	}
 +});
 | 
