Skip to content

Commit

Permalink
Calculating maxResolution instead of having it in defaults.
Browse files Browse the repository at this point in the history
  • Loading branch information
ahocevar committed Feb 15, 2012
1 parent 2e423df commit 262e2d5
Show file tree
Hide file tree
Showing 6 changed files with 25 additions and 22 deletions.
20 changes: 12 additions & 8 deletions lib/OpenLayers/Layer.js
Original file line number Diff line number Diff line change
Expand Up @@ -255,8 +255,8 @@ OpenLayers.Layer = OpenLayers.Class({
* APIProperty: maxResolution
* {Float} Default max is 360 deg / 256 px, which corresponds to
* zoom level 0 on gmaps. Specify a different value in the layer
* options if you are not using a geographic projection and
* displaying the whole world.
* options if you are not using the default <OpenLayers.Map.tileSize>
* and displaying the whole world.
*/
maxResolution: null,

Expand Down Expand Up @@ -638,12 +638,6 @@ OpenLayers.Layer = OpenLayers.Class({
this.units || this.map.units;

this.initResolutions();
if (!this.resolutions) {
throw(
"Could not calculate resolutions for layer " + this.name +
". Configure maxResolution or resolutions or scales."
);
}

if (!this.isBaseLayer) {
this.inRange = this.calculateInRange();
Expand Down Expand Up @@ -896,6 +890,16 @@ OpenLayers.Layer = OpenLayers.Class({
props.resolutions = this.resolutionsFromScales(props.scales);
}
if(props.resolutions == null) {
var maxExtent = this.maxExtent;
if (!props.maxResolution && maxExtent) {
// maxResolution for default grid sets assumes that at zoom
// level zero, the whole world fits on one tile.
var tileSize = this.tileSize || this.map.getTileSize();
props.maxResolution = Math.max(
maxExtent.getWidth() / tileSize.w,
maxExtent.getHeight() / tileSize.h
);
}
props.resolutions = this.calculateResolutions(props);
}
}
Expand Down
4 changes: 2 additions & 2 deletions lib/OpenLayers/Map.js
Original file line number Diff line number Diff line change
Expand Up @@ -274,8 +274,8 @@ OpenLayers.Map = OpenLayers.Class({

/**
* APIProperty: maxResolution
* {Float} Specify if you are not using a geographic projection or Web
* Mercator and displaying the whole world.
* {Float} Required if you are not displaying the whole world on a tile
* with the size specified in <tileSize>.
*/
maxResolution: null,

Expand Down
12 changes: 4 additions & 8 deletions lib/OpenLayers/Projection.js
Original file line number Diff line number Diff line change
Expand Up @@ -167,26 +167,22 @@ OpenLayers.Projection.transforms = {};
* {Object} Defaults for the SRS codes known to OpenLayers (currently
* EPSG:4326, CRS:84, urn:ogc:def:crs:EPSG:6.6:4326, EPSG:900913, EPSG:3857,
* EPSG:102113 and EPSG:102100). Keys are the SRS code, values are units,
* maxExtent (the validity extent for the SRS), maxResolution (the maximum
* resolution commonly used in grid sets for this SRS) and yx (true if this
* SRS is known to have a reverse axis order).
* maxExtent (the validity extent for the SRS) and yx (true if this SRS is
* known to have a reverse axis order).
*/
OpenLayers.Projection.defaults = {
"EPSG:4326": {
units: "degrees",
maxExtent: [-180, -90, 180, 90],
maxResolution: 1.40625,
yx: true
},
"CRS:84": {
units: "degrees",
maxExtent: [-180, -90, 180, 90],
maxResolution: 1.40625
maxExtent: [-180, -90, 180, 90]
},
"EPSG:900913": {
units: "m",
maxExtent: [-20037508.34, -20037508.34, 20037508.34, 20037508.34],
maxResolution: 156543.03390625
maxExtent: [-20037508.34, -20037508.34, 20037508.34, 20037508.34]
}
};

Expand Down
1 change: 1 addition & 0 deletions tests/Layer/WMS.html
Original file line number Diff line number Diff line change
Expand Up @@ -388,6 +388,7 @@
var map = new OpenLayers.Map({
div: "map",
maxExtent: new OpenLayers.Bounds(-185, -95, 185, 95),
maxResolution: 1.40625,
layers: [dummy, unconstrained, constrained],
center: new OpenLayers.LonLat(0, 0),
zoom: 1
Expand Down
6 changes: 4 additions & 2 deletions tests/Layer/WMTS.html
Original file line number Diff line number Diff line change
Expand Up @@ -136,7 +136,8 @@
layer: "world",
style: "blue_marble",
matrixSet: "arcgis_online",
tileSize: new OpenLayers.Size(512, 512),
tileSize: new OpenLayers.Size(512, 512),
maxResolution: 1.40625,
requestEncoding: "REST"
});
map.addLayer(layer1);
Expand All @@ -156,7 +157,8 @@
layer: "world",
style: "blue_marble",
matrixSet: "arcgis_online",
tileSize: new OpenLayers.Size(512, 512),
tileSize: new OpenLayers.Size(512, 512),
maxResolution: 1.40625,
requestEncoding: "REST"
});
map.addLayer(layer1);
Expand Down
4 changes: 2 additions & 2 deletions tests/Layer/XYZ.html
Original file line number Diff line number Diff line change
Expand Up @@ -195,7 +195,7 @@

var map = new OpenLayers.Map({
div: "map",
maxResolution: OpenLayers.Projection.defaults["EPSG:4326"].maxResolution / Math.pow(2, offset)
maxResolution: 1.40625 / Math.pow(2, offset)
});
var layer = new OpenLayers.Layer.XYZ(name, url, {zoomOffset: offset});
map.addLayer(layer);
Expand All @@ -211,7 +211,7 @@

var map = new OpenLayers.Map({
div: "map",
maxResolution: OpenLayers.Projection.defaults["EPSG:4326"].maxResolution / Math.pow(2, offset)
maxResolution: 1.40625 / Math.pow(2, offset)
});
var layer = new OpenLayers.Layer.XYZ(name, url, {zoomOffset: offset});
map.addLayer(layer);
Expand Down

0 comments on commit 262e2d5

Please sign in to comment.