#632: fixing the image layer that broke with r2979 - layer now sets its tileSize and imageSize appropriately - this also addesses (dup) ticket 511
git-svn-id: http://svn.openlayers.org/trunk/openlayers@3020 dc9f47b5-9b13-0410-9fdd-eb0c1a62fdaf
This commit is contained in:
@@ -24,17 +24,23 @@ OpenLayers.Layer.Image.prototype =
|
||||
/** @type String */
|
||||
url: null,
|
||||
|
||||
/** @type OpenLayers.Bounds */
|
||||
/**
|
||||
* The image bounds in map units
|
||||
* @type OpenLayers.Bounds
|
||||
*/
|
||||
extent: null,
|
||||
|
||||
/** @type OpenLayers.Size */
|
||||
/**
|
||||
* The image size in pixels
|
||||
* @type OpenLayers.Size
|
||||
*/
|
||||
size: null,
|
||||
|
||||
/** @type OpenLayers.Tile.Image */
|
||||
tile: null,
|
||||
|
||||
/** The ratio of height/width represented by a single pixel in the graphic
|
||||
*
|
||||
/**
|
||||
* The ratio of height/width represented by a single pixel in the graphic
|
||||
* @type Float */
|
||||
aspectRatio: null,
|
||||
|
||||
@@ -94,10 +100,16 @@ OpenLayers.Layer.Image.prototype =
|
||||
* @param {OpenLayers.Map} map
|
||||
*/
|
||||
setMap: function(map) {
|
||||
// If nothing to do with resolutions has been set, assume a single
|
||||
// resolution determined by extent/size
|
||||
/**
|
||||
* If nothing to do with resolutions has been set, assume a single
|
||||
* resolution determined by ratio*extent/size - if an image has a
|
||||
* pixel aspect ratio different than one (as calculated above), the
|
||||
* image will be stretched in one dimension only.
|
||||
*/
|
||||
if( this.options.maxResolution == null ) {
|
||||
this.options.maxResolution = this.extent.getWidth() / this.size.w;
|
||||
this.options.maxResolution = this.aspectRatio *
|
||||
this.extent.getWidth() /
|
||||
this.size.w;
|
||||
}
|
||||
OpenLayers.Layer.prototype.setMap.apply(this, arguments);
|
||||
},
|
||||
@@ -116,11 +128,8 @@ OpenLayers.Layer.Image.prototype =
|
||||
if(zoomChanged || firstRendering) {
|
||||
|
||||
//determine new tile size
|
||||
var tileWidth = this.extent.getWidth() / this.map.getResolution();
|
||||
var tileHeight = this.extent.getHeight() /
|
||||
(this.map.getResolution() * this.aspectRatio);
|
||||
var tileSize = new OpenLayers.Size(tileWidth, tileHeight);
|
||||
|
||||
this.setTileSize();
|
||||
|
||||
//determine new position (upper left corner of new bounds)
|
||||
var ul = new OpenLayers.LonLat(this.extent.left, this.extent.top);
|
||||
var ulPx = this.map.getLayerPxFromLonLat(ul);
|
||||
@@ -128,16 +137,28 @@ OpenLayers.Layer.Image.prototype =
|
||||
if(firstRendering) {
|
||||
//create the new tile
|
||||
this.tile = new OpenLayers.Tile.Image(this, ulPx, this.extent,
|
||||
this.url, tileSize);
|
||||
this.url, this.tileSize);
|
||||
} else {
|
||||
//just resize the tile and set it's new position
|
||||
this.tile.size = tileSize.clone();
|
||||
this.tile.size = this.tileSize.clone();
|
||||
this.tile.position = ulPx.clone();
|
||||
}
|
||||
this.tile.draw();
|
||||
}
|
||||
},
|
||||
|
||||
|
||||
/**
|
||||
* Set the tile size based on the map size. This also sets layer.imageSize
|
||||
* and layer.imageOffset for use by Tile.Image.
|
||||
*/
|
||||
setTileSize: function() {
|
||||
var tileWidth = this.extent.getWidth() / this.map.getResolution();
|
||||
var tileHeight = this.extent.getHeight() / this.map.getResolution();
|
||||
this.tileSize = new OpenLayers.Size(tileWidth, tileHeight);
|
||||
this.imageSize = this.tileSize;
|
||||
this.imageOffset = new OpenLayers.Pixel(0, 0);
|
||||
},
|
||||
|
||||
/**
|
||||
* @param {String} newUrl
|
||||
*/
|
||||
|
||||
Reference in New Issue
Block a user