Only support square tiles

This commit is contained in:
Tom Payne
2014-01-15 09:45:49 +01:00
parent 50a322208a
commit d5c1e53e48
13 changed files with 89 additions and 93 deletions

View File

@@ -902,8 +902,8 @@
* @property {ol.Coordinate|undefined} origin Origin. * @property {ol.Coordinate|undefined} origin Origin.
* @property {Array.<ol.Coordinate>|undefined} origins Origins. * @property {Array.<ol.Coordinate>|undefined} origins Origins.
* @property {!Array.<number>} resolutions Resolutions. * @property {!Array.<number>} resolutions Resolutions.
* @property {ol.Size|undefined} tileSize Tile size. * @property {number|undefined} tileSize Tile size.
* @property {Array.<ol.Size>|undefined} tileSizes Tile sizes. * @property {Array.<number>|undefined} tileSizes Tile sizes.
* @todo stability experimental * @todo stability experimental
*/ */
@@ -913,8 +913,8 @@
* @property {Array.<ol.Coordinate>|undefined} origins Origins. * @property {Array.<ol.Coordinate>|undefined} origins Origins.
* @property {!Array.<number>} resolutions Resolutions. * @property {!Array.<number>} resolutions Resolutions.
* @property {!Array.<string>} matrixIds matrix IDs. * @property {!Array.<string>} matrixIds matrix IDs.
* @property {ol.Size|undefined} tileSize Tile size. * @property {number|undefined} tileSize Tile size.
* @property {Array.<ol.Size>|undefined} tileSizes Tile sizes. * @property {Array.<number>|undefined} tileSizes Tile sizes.
* @todo stability experimental * @todo stability experimental
*/ */

View File

@@ -191,8 +191,8 @@ ol.renderer.canvas.TileLayer.prototype.prepareFrame =
var tileRange = tileGrid.getTileRangeForExtentAndResolution( var tileRange = tileGrid.getTileRangeForExtentAndResolution(
extent, tileResolution); extent, tileResolution);
var canvasWidth = tileSize[0] * tileRange.getWidth(); var canvasWidth = tileSize * tileRange.getWidth();
var canvasHeight = tileSize[1] * tileRange.getHeight(); var canvasHeight = tileSize * tileRange.getHeight();
var canvas, context; var canvas, context;
if (goog.isNull(this.canvas_)) { if (goog.isNull(this.canvas_)) {
@@ -231,8 +231,8 @@ ol.renderer.canvas.TileLayer.prototype.prepareFrame =
var canvasTileRange, canvasTileRangeWidth, minX, minY; var canvasTileRange, canvasTileRangeWidth, minX, minY;
if (goog.isNull(this.renderedCanvasTileRange_)) { if (goog.isNull(this.renderedCanvasTileRange_)) {
canvasTileRangeWidth = canvasWidth / tileSize[0]; canvasTileRangeWidth = canvasWidth / tileSize;
var canvasTileRangeHeight = canvasHeight / tileSize[1]; var canvasTileRangeHeight = canvasHeight / tileSize;
minX = tileRange.minX - minX = tileRange.minX -
Math.floor((canvasTileRangeWidth - tileRange.getWidth()) / 2); Math.floor((canvasTileRangeWidth - tileRange.getWidth()) / 2);
minY = tileRange.minY - minY = tileRange.minY -
@@ -299,9 +299,9 @@ ol.renderer.canvas.TileLayer.prototype.prepareFrame =
var i, ii; var i, ii;
for (i = 0, ii = tilesToClear.length; i < ii; ++i) { for (i = 0, ii = tilesToClear.length; i < ii; ++i) {
tile = tilesToClear[i]; tile = tilesToClear[i];
x = tileSize[0] * (tile.tileCoord.x - canvasTileRange.minX); x = tileSize * (tile.tileCoord.x - canvasTileRange.minX);
y = tileSize[1] * (canvasTileRange.maxY - tile.tileCoord.y); y = tileSize * (canvasTileRange.maxY - tile.tileCoord.y);
context.clearRect(x, y, tileSize[0], tileSize[1]); context.clearRect(x, y, tileSize, tileSize);
} }
/** @type {Array.<number>} */ /** @type {Array.<number>} */
@@ -325,18 +325,18 @@ ol.renderer.canvas.TileLayer.prototype.prepareFrame =
(tile.tileCoord.y - canvasTileRange.minY) * canvasTileRangeWidth + (tile.tileCoord.y - canvasTileRange.minY) * canvasTileRangeWidth +
(tile.tileCoord.x - canvasTileRange.minX); (tile.tileCoord.x - canvasTileRange.minX);
if (this.renderedTiles_[index] != tile) { if (this.renderedTiles_[index] != tile) {
x = tileSize[0] * (tile.tileCoord.x - canvasTileRange.minX); x = tileSize * (tile.tileCoord.x - canvasTileRange.minX);
y = tileSize[1] * (canvasTileRange.maxY - tile.tileCoord.y); y = tileSize * (canvasTileRange.maxY - tile.tileCoord.y);
tileState = tile.getState(); tileState = tile.getState();
if (tileState == ol.TileState.EMPTY || if (tileState == ol.TileState.EMPTY ||
tileState == ol.TileState.ERROR || tileState == ol.TileState.ERROR ||
!opaque) { !opaque) {
context.clearRect(x, y, tileSize[0], tileSize[1]); context.clearRect(x, y, tileSize, tileSize);
} }
if (tileState == ol.TileState.LOADED) { if (tileState == ol.TileState.LOADED) {
context.drawImage(tile.getImage(), context.drawImage(tile.getImage(),
tileGutter, tileGutter, tileSize[0], tileSize[1], tileGutter, tileGutter, tileSize, tileSize,
x, y, tileSize[0], tileSize[1]); x, y, tileSize, tileSize);
} }
this.renderedTiles_[index] = tile; this.renderedTiles_[index] = tile;
} }
@@ -348,15 +348,15 @@ ol.renderer.canvas.TileLayer.prototype.prepareFrame =
tileExtent = tileGrid.getTileCoordExtent(tile.tileCoord, tmpExtent); tileExtent = tileGrid.getTileCoordExtent(tile.tileCoord, tmpExtent);
x = (tileExtent[0] - origin[0]) / tileResolution; x = (tileExtent[0] - origin[0]) / tileResolution;
y = (origin[1] - tileExtent[3]) / tileResolution; y = (origin[1] - tileExtent[3]) / tileResolution;
width = scale * tileSize[0]; width = scale * tileSize;
height = scale * tileSize[1]; height = scale * tileSize;
tileState = tile.getState(); tileState = tile.getState();
if (tileState == ol.TileState.EMPTY || !opaque) { if (tileState == ol.TileState.EMPTY || !opaque) {
context.clearRect(x, y, width, height); context.clearRect(x, y, width, height);
} }
if (tileState == ol.TileState.LOADED) { if (tileState == ol.TileState.LOADED) {
context.drawImage(tile.getImage(), context.drawImage(tile.getImage(),
tileGutter, tileGutter, tileSize[0], tileSize[1], tileGutter, tileGutter, tileSize, tileSize,
x, y, width, height); x, y, width, height);
} }
interimTileRange = interimTileRange =

View File

@@ -334,8 +334,8 @@ ol.renderer.dom.TileLayerZ_.prototype.addTile = function(tile, tileGutter) {
tileElement = goog.dom.createElement(goog.dom.TagName.DIV); tileElement = goog.dom.createElement(goog.dom.TagName.DIV);
tileElementStyle = tileElement.style; tileElementStyle = tileElement.style;
tileElementStyle.overflow = 'hidden'; tileElementStyle.overflow = 'hidden';
tileElementStyle.width = tileSize[0] + 'px'; tileElementStyle.width = tileSize + 'px';
tileElementStyle.height = tileSize[1] + 'px'; tileElementStyle.height = tileSize + 'px';
imageStyle.position = 'absolute'; imageStyle.position = 'absolute';
imageStyle.left = -tileGutter + 'px'; imageStyle.left = -tileGutter + 'px';
imageStyle.top = -tileGutter + 'px'; imageStyle.top = -tileGutter + 'px';
@@ -346,9 +346,9 @@ ol.renderer.dom.TileLayerZ_.prototype.addTile = function(tile, tileGutter) {
} }
tileElementStyle.position = 'absolute'; tileElementStyle.position = 'absolute';
tileElementStyle.left = tileElementStyle.left =
((tileCoord.x - this.tileCoordOrigin_.x) * tileSize[0]) + 'px'; ((tileCoord.x - this.tileCoordOrigin_.x) * tileSize) + 'px';
tileElementStyle.top = tileElementStyle.top =
((this.tileCoordOrigin_.y - tileCoord.y) * tileSize[1]) + 'px'; ((this.tileCoordOrigin_.y - tileCoord.y) * tileSize) + 'px';
if (goog.isNull(this.documentFragment_)) { if (goog.isNull(this.documentFragment_)) {
this.documentFragment_ = document.createDocumentFragment(); this.documentFragment_ = document.createDocumentFragment();
} }

View File

@@ -76,9 +76,9 @@ ol.renderer.webgl.Map = function(container, map) {
/** /**
* @private * @private
* @type {ol.Size} * @type {number}
*/ */
this.clipTileCanvasSize_ = [0, 0]; this.clipTileCanvasSize_ = 0;
/** /**
* @private * @private
@@ -170,12 +170,10 @@ ol.renderer.webgl.Map = function(container, map) {
this.tileTextureQueue_.reprioritize(); this.tileTextureQueue_.reprioritize();
var element = this.tileTextureQueue_.dequeue(); var element = this.tileTextureQueue_.dequeue();
var tile = /** @type {ol.Tile} */ (element[0]); var tile = /** @type {ol.Tile} */ (element[0]);
var tileWidth = /** @type {number} */ (element[3]); var tileSize = /** @type {number} */ (element[3]);
var tileHeight = /** @type {number} */ (element[4]); var tileGutter = /** @type {number} */ (element[4]);
var tileGutter = /** @type {number} */ (element[5]); this.bindTileTexture(
this.bindTileTexture(tile, tile, tileSize, tileGutter, goog.webgl.LINEAR, goog.webgl.LINEAR);
tileWidth, tileHeight, tileGutter,
goog.webgl.LINEAR, goog.webgl.LINEAR);
} }
}, this); }, this);
@@ -193,14 +191,13 @@ goog.inherits(ol.renderer.webgl.Map, ol.renderer.Map);
/** /**
* @param {ol.Tile} tile Tile. * @param {ol.Tile} tile Tile.
* @param {number} tileWidth Tile width. * @param {number} tileSize Tile size.
* @param {number} tileHeight Tile height.
* @param {number} tileGutter Tile gutter. * @param {number} tileGutter Tile gutter.
* @param {number} magFilter Mag filter. * @param {number} magFilter Mag filter.
* @param {number} minFilter Min filter. * @param {number} minFilter Min filter.
*/ */
ol.renderer.webgl.Map.prototype.bindTileTexture = ol.renderer.webgl.Map.prototype.bindTileTexture =
function(tile, tileWidth, tileHeight, tileGutter, magFilter, minFilter) { function(tile, tileSize, tileGutter, magFilter, minFilter) {
var gl = this.getGL(); var gl = this.getGL();
var tileKey = tile.getKey(); var tileKey = tile.getKey();
if (this.textureCache_.containsKey(tileKey)) { if (this.textureCache_.containsKey(tileKey)) {
@@ -222,19 +219,16 @@ ol.renderer.webgl.Map.prototype.bindTileTexture =
gl.bindTexture(goog.webgl.TEXTURE_2D, texture); gl.bindTexture(goog.webgl.TEXTURE_2D, texture);
if (tileGutter > 0) { if (tileGutter > 0) {
var clipTileCanvas = this.clipTileCanvas_; var clipTileCanvas = this.clipTileCanvas_;
var clipTileCanvasSize = this.clipTileCanvasSize_;
var clipTileContext = this.clipTileContext_; var clipTileContext = this.clipTileContext_;
if (clipTileCanvasSize[0] != tileWidth || if (this.clipTileCanvasSize_ != tileSize) {
clipTileCanvasSize[1] != tileHeight) { clipTileCanvas.width = tileSize;
clipTileCanvas.width = tileWidth; clipTileCanvas.height = tileSize;
clipTileCanvas.height = tileHeight; this.clipTileCanvasSize_ = tileSize;
clipTileCanvasSize[0] = tileWidth;
clipTileCanvasSize[1] = tileHeight;
} else { } else {
clipTileContext.clearRect(0, 0, tileWidth, tileHeight); clipTileContext.clearRect(0, 0, tileSize, tileSize);
} }
clipTileContext.drawImage(tile.getImage(), tileGutter, tileGutter, clipTileContext.drawImage(tile.getImage(), tileGutter, tileGutter,
tileWidth, tileHeight, 0, 0, tileWidth, tileHeight); tileSize, tileSize, 0, 0, tileSize, tileSize);
gl.texImage2D(goog.webgl.TEXTURE_2D, 0, gl.texImage2D(goog.webgl.TEXTURE_2D, 0,
goog.webgl.RGBA, goog.webgl.RGBA, goog.webgl.RGBA, goog.webgl.RGBA,
goog.webgl.UNSIGNED_BYTE, clipTileCanvas); goog.webgl.UNSIGNED_BYTE, clipTileCanvas);

View File

@@ -152,14 +152,13 @@ ol.renderer.webgl.TileLayer.prototype.prepareFrame =
var tileRangeSize = tileRange.getSize(); var tileRangeSize = tileRange.getSize();
var maxDimension = Math.max( var maxDimension =
tileRangeSize[0] * tileSize[0], Math.max(tileRangeSize[0] * tileSize, tileRangeSize[1] * tileSize);
tileRangeSize[1] * tileSize[1]);
var framebufferDimension = ol.math.roundUpToPowerOfTwo(maxDimension); var framebufferDimension = ol.math.roundUpToPowerOfTwo(maxDimension);
var framebufferExtentDimension = tileResolution * framebufferDimension; var framebufferExtentDimension = tileResolution * framebufferDimension;
var origin = tileGrid.getOrigin(z); var origin = tileGrid.getOrigin(z);
var minX = origin[0] + tileRange.minX * tileSize[0] * tileResolution; var minX = origin[0] + tileRange.minX * tileSize * tileResolution;
var minY = origin[1] + tileRange.minY * tileSize[1] * tileResolution; var minY = origin[1] + tileRange.minY * tileSize * tileResolution;
framebufferExtent = [ framebufferExtent = [
minX, minY, minX, minY,
minX + framebufferExtentDimension, minY + framebufferExtentDimension minX + framebufferExtentDimension, minY + framebufferExtentDimension
@@ -255,8 +254,7 @@ ol.renderer.webgl.TileLayer.prototype.prepareFrame =
framebufferExtentDimension - 1; framebufferExtentDimension - 1;
goog.vec.Vec4.setFromValues(u_tileOffset, sx, sy, tx, ty); goog.vec.Vec4.setFromValues(u_tileOffset, sx, sy, tx, ty);
gl.uniform4fv(this.locations_.u_tileOffset, u_tileOffset); gl.uniform4fv(this.locations_.u_tileOffset, u_tileOffset);
mapRenderer.bindTileTexture(tile, mapRenderer.bindTileTexture(tile, tileSize, tileGutter,
tileSize[0], tileSize[1], tileGutter,
goog.webgl.LINEAR, goog.webgl.LINEAR); goog.webgl.LINEAR, goog.webgl.LINEAR);
gl.drawArrays(goog.webgl.TRIANGLE_STRIP, 0, 4); gl.drawArrays(goog.webgl.TRIANGLE_STRIP, 0, 4);
} }
@@ -291,7 +289,7 @@ ol.renderer.webgl.TileLayer.prototype.prepareFrame =
tile, tile,
tileGrid.getTileCoordCenter(tile.tileCoord), tileGrid.getTileCoordCenter(tile.tileCoord),
tileGrid.getResolution(tile.tileCoord.z), tileGrid.getResolution(tile.tileCoord.z),
tileSize[0], tileSize[1], tileGutter tileSize, tileGutter
]); ]);
} }
}, this); }, this);

View File

@@ -79,10 +79,11 @@ ol.source.BingMaps.prototype.handleImageryMetadataResponse =
//var copyright = response.copyright; // FIXME do we need to display this? //var copyright = response.copyright; // FIXME do we need to display this?
var resource = response.resourceSets[0].resources[0]; var resource = response.resourceSets[0].resources[0];
goog.asserts.assert(resource.imageWidth == resource.imageHeight);
var tileGrid = new ol.tilegrid.XYZ({ var tileGrid = new ol.tilegrid.XYZ({
minZoom: resource.zoomMin, minZoom: resource.zoomMin,
maxZoom: resource.zoomMax, maxZoom: resource.zoomMax,
tileSize: [resource.imageWidth, resource.imageHeight] tileSize: resource.imageWidth
}); });
this.tileGrid = tileGrid; this.tileGrid = tileGrid;

View File

@@ -2,7 +2,6 @@ goog.provide('ol.source.TileDebug');
goog.require('goog.dom'); goog.require('goog.dom');
goog.require('goog.dom.TagName'); goog.require('goog.dom.TagName');
goog.require('ol.Size');
goog.require('ol.Tile'); goog.require('ol.Tile');
goog.require('ol.TileCache'); goog.require('ol.TileCache');
goog.require('ol.TileCoord'); goog.require('ol.TileCoord');
@@ -31,7 +30,7 @@ ol.DebugTile_ = function(tileCoord, tileGrid) {
/** /**
* @private * @private
* @type {ol.Size} * @type {number}
*/ */
this.tileSize_ = tileGrid.getTileSize(tileCoord.z); this.tileSize_ = tileGrid.getTileSize(tileCoord.z);
@@ -58,21 +57,21 @@ ol.DebugTile_.prototype.getImage = function(opt_context) {
var canvas = /** @type {HTMLCanvasElement} */ var canvas = /** @type {HTMLCanvasElement} */
(goog.dom.createElement(goog.dom.TagName.CANVAS)); (goog.dom.createElement(goog.dom.TagName.CANVAS));
canvas.width = tileSize[0]; canvas.width = tileSize;
canvas.height = tileSize[1]; canvas.height = tileSize;
var context = /** @type {CanvasRenderingContext2D} */ var context = /** @type {CanvasRenderingContext2D} */
(canvas.getContext('2d')); (canvas.getContext('2d'));
context.strokeStyle = 'black'; context.strokeStyle = 'black';
context.strokeRect(0.5, 0.5, tileSize[0] + 0.5, tileSize[1] + 0.5); context.strokeRect(0.5, 0.5, tileSize + 0.5, tileSize + 0.5);
context.fillStyle = 'black'; context.fillStyle = 'black';
context.textAlign = 'center'; context.textAlign = 'center';
context.textBaseline = 'middle'; context.textBaseline = 'middle';
context.font = '24px sans-serif'; context.font = '24px sans-serif';
context.fillText( context.fillText(
this.tileCoord_.toString(), tileSize[0] / 2, tileSize[1] / 2); this.tileCoord_.toString(), tileSize / 2, tileSize / 2);
this.canvasByContext_[key] = canvas; this.canvasByContext_[key] = canvas;
return canvas; return canvas;

View File

@@ -167,11 +167,11 @@ ol.source.TileWMS.prototype.tileUrlFunction_ = function(tileCoord, projection) {
var tileSize = tileGrid.getTileSize(tileCoord.z); var tileSize = tileGrid.getTileSize(tileCoord.z);
var gutter = this.gutter_; var gutter = this.gutter_;
if (gutter === 0) { if (gutter === 0) {
goog.object.set(params, 'WIDTH', tileSize[0]); goog.object.set(params, 'WIDTH', tileSize);
goog.object.set(params, 'HEIGHT', tileSize[1]); goog.object.set(params, 'HEIGHT', tileSize);
} else { } else {
goog.object.set(params, 'WIDTH', tileSize[0] + 2 * gutter); goog.object.set(params, 'WIDTH', tileSize + 2 * gutter);
goog.object.set(params, 'HEIGHT', tileSize[1] + 2 * gutter); goog.object.set(params, 'HEIGHT', tileSize + 2 * gutter);
tileExtent = tileExtent =
ol.extent.buffer(tileExtent, tileResolution * gutter, this.tmpExtent_); ol.extent.buffer(tileExtent, tileResolution * gutter, this.tmpExtent_);
} }

View File

@@ -3,7 +3,6 @@ goog.provide('ol.tilegrid.TileGrid');
goog.require('goog.array'); goog.require('goog.array');
goog.require('goog.asserts'); goog.require('goog.asserts');
goog.require('ol.Coordinate'); goog.require('ol.Coordinate');
goog.require('ol.Size');
goog.require('ol.TileCoord'); goog.require('ol.TileCoord');
goog.require('ol.TileRange'); goog.require('ol.TileRange');
goog.require('ol.array'); goog.require('ol.array');
@@ -75,7 +74,7 @@ ol.tilegrid.TileGrid = function(options) {
/** /**
* @private * @private
* @type {Array.<ol.Size>} * @type {Array.<number>}
*/ */
this.tileSizes_ = null; this.tileSizes_ = null;
if (goog.isDef(options.tileSizes)) { if (goog.isDef(options.tileSizes)) {
@@ -85,15 +84,14 @@ ol.tilegrid.TileGrid = function(options) {
/** /**
* @private * @private
* @type {ol.Size} * @type {number|undefined}
*/ */
this.tileSize_ = goog.isDef(options.tileSize) ? this.tileSize_ = goog.isDef(options.tileSize) ?
options.tileSize : options.tileSize :
goog.isNull(this.tileSizes_) ? goog.isNull(this.tileSizes_) ? ol.DEFAULT_TILE_SIZE : undefined;
[ol.DEFAULT_TILE_SIZE, ol.DEFAULT_TILE_SIZE] : null;
goog.asserts.assert( goog.asserts.assert(
(goog.isNull(this.tileSize_) && !goog.isNull(this.tileSizes_)) || (!goog.isDef(this.tileSize_) && !goog.isNull(this.tileSizes_)) ||
(!goog.isNull(this.tileSize_) && goog.isNull(this.tileSizes_))); (goog.isDef(this.tileSize_) && goog.isNull(this.tileSizes_)));
}; };
@@ -220,10 +218,10 @@ ol.tilegrid.TileGrid.prototype.getTileRangeExtent =
var origin = this.getOrigin(z); var origin = this.getOrigin(z);
var resolution = this.getResolution(z); var resolution = this.getResolution(z);
var tileSize = this.getTileSize(z); var tileSize = this.getTileSize(z);
var minX = origin[0] + tileRange.minX * tileSize[0] * resolution; var minX = origin[0] + tileRange.minX * tileSize * resolution;
var maxX = origin[0] + (tileRange.maxX + 1) * tileSize[0] * resolution; var maxX = origin[0] + (tileRange.maxX + 1) * tileSize * resolution;
var minY = origin[1] + tileRange.minY * tileSize[1] * resolution; var minY = origin[1] + tileRange.minY * tileSize * resolution;
var maxY = origin[1] + (tileRange.maxY + 1) * tileSize[1] * resolution; var maxY = origin[1] + (tileRange.maxY + 1) * tileSize * resolution;
return ol.extent.createOrUpdate(minX, minY, maxX, maxY, opt_extent); return ol.extent.createOrUpdate(minX, minY, maxX, maxY, opt_extent);
}; };
@@ -271,8 +269,8 @@ ol.tilegrid.TileGrid.prototype.getTileCoordCenter = function(tileCoord) {
var resolution = this.getResolution(tileCoord.z); var resolution = this.getResolution(tileCoord.z);
var tileSize = this.getTileSize(tileCoord.z); var tileSize = this.getTileSize(tileCoord.z);
return [ return [
origin[0] + (tileCoord.x + 0.5) * tileSize[0] * resolution, origin[0] + (tileCoord.x + 0.5) * tileSize * resolution,
origin[1] + (tileCoord.y + 0.5) * tileSize[1] * resolution origin[1] + (tileCoord.y + 0.5) * tileSize * resolution
]; ];
}; };
@@ -287,10 +285,10 @@ ol.tilegrid.TileGrid.prototype.getTileCoordExtent =
var origin = this.getOrigin(tileCoord.z); var origin = this.getOrigin(tileCoord.z);
var resolution = this.getResolution(tileCoord.z); var resolution = this.getResolution(tileCoord.z);
var tileSize = this.getTileSize(tileCoord.z); var tileSize = this.getTileSize(tileCoord.z);
var minX = origin[0] + tileCoord.x * tileSize[0] * resolution; var minX = origin[0] + tileCoord.x * tileSize * resolution;
var minY = origin[1] + tileCoord.y * tileSize[1] * resolution; var minY = origin[1] + tileCoord.y * tileSize * resolution;
var maxX = minX + tileSize[0] * resolution; var maxX = minX + tileSize * resolution;
var maxY = minY + tileSize[1] * resolution; var maxY = minY + tileSize * resolution;
return ol.extent.createOrUpdate(minX, minY, maxX, maxY, opt_extent); return ol.extent.createOrUpdate(minX, minY, maxX, maxY, opt_extent);
}; };
@@ -330,8 +328,8 @@ ol.tilegrid.TileGrid.prototype.getTileCoordForXYAndResolution_ = function(
var origin = this.getOrigin(z); var origin = this.getOrigin(z);
var tileSize = this.getTileSize(z); var tileSize = this.getTileSize(z);
var tileCoordX = scale * (x - origin[0]) / (resolution * tileSize[0]); var tileCoordX = scale * (x - origin[0]) / (resolution * tileSize);
var tileCoordY = scale * (y - origin[1]) / (resolution * tileSize[1]); var tileCoordY = scale * (y - origin[1]) / (resolution * tileSize);
if (reverseIntersectionPolicy) { if (reverseIntersectionPolicy) {
tileCoordX = Math.ceil(tileCoordX) - 1; tileCoordX = Math.ceil(tileCoordX) - 1;
@@ -372,11 +370,11 @@ ol.tilegrid.TileGrid.prototype.getTileCoordResolution = function(tileCoord) {
/** /**
* @param {number} z Z. * @param {number} z Z.
* @return {ol.Size} Tile size. * @return {number} Tile size.
* @todo stability experimental * @todo stability experimental
*/ */
ol.tilegrid.TileGrid.prototype.getTileSize = function(z) { ol.tilegrid.TileGrid.prototype.getTileSize = function(z) {
if (!goog.isNull(this.tileSize_)) { if (goog.isDef(this.tileSize_)) {
return this.tileSize_; return this.tileSize_;
} else { } else {
goog.asserts.assert(!goog.isNull(this.tileSizes_)); goog.asserts.assert(!goog.isNull(this.tileSizes_));
@@ -412,7 +410,7 @@ ol.tilegrid.getForProjection = function(projection) {
/** /**
* @param {ol.proj.Projection} projection Projection. * @param {ol.proj.Projection} projection Projection.
* @param {number=} opt_maxZoom Maximum zoom level. * @param {number=} opt_maxZoom Maximum zoom level.
* @param {ol.Size=} opt_tileSize Tile size. * @param {number=} opt_tileSize Tile size.
* @return {ol.tilegrid.TileGrid} TileGrid instance. * @return {ol.tilegrid.TileGrid} TileGrid instance.
*/ */
ol.tilegrid.createForProjection = ol.tilegrid.createForProjection =
@@ -425,10 +423,9 @@ ol.tilegrid.createForProjection =
projectionExtent[3] - projectionExtent[1]); projectionExtent[3] - projectionExtent[1]);
var maxZoom = goog.isDef(opt_maxZoom) ? var maxZoom = goog.isDef(opt_maxZoom) ?
opt_maxZoom : ol.DEFAULT_MAX_ZOOM; opt_maxZoom : ol.DEFAULT_MAX_ZOOM;
var tileSize = goog.isDef(opt_tileSize) ? var tileSize = goog.isDef(opt_tileSize) ? opt_tileSize : ol.DEFAULT_TILE_SIZE;
opt_tileSize : [ol.DEFAULT_TILE_SIZE, ol.DEFAULT_TILE_SIZE];
var resolutions = new Array(maxZoom + 1); var resolutions = new Array(maxZoom + 1);
var maxResolution = size / Math.max(tileSize[0], tileSize[1]); var maxResolution = size / tileSize;
for (var z = 0, zz = resolutions.length; z < zz; ++z) { for (var z = 0, zz = resolutions.length; z < zz; ++z) {
resolutions[z] = maxResolution / Math.pow(2, z); resolutions[z] = maxResolution / Math.pow(2, z);
} }

View File

@@ -65,9 +65,13 @@ ol.tilegrid.WMTS.prototype.getMatrixIds = function() {
ol.tilegrid.WMTS.createFromCapabilitiesMatrixSet = ol.tilegrid.WMTS.createFromCapabilitiesMatrixSet =
function(matrixSet) { function(matrixSet) {
/** @type {!Array.<number>} */
var resolutions = []; var resolutions = [];
/** @type {!Array.<string>} */
var matrixIds = []; var matrixIds = [];
/** @type {!Array.<ol.Coordinate>} */
var origins = []; var origins = [];
/** @type {!Array.<number>} */
var tileSizes = []; var tileSizes = [];
var supportedCRSPropName = 'supportedCRS'; var supportedCRSPropName = 'supportedCRS';
@@ -91,7 +95,10 @@ ol.tilegrid.WMTS.createFromCapabilitiesMatrixSet =
origins.push(elt[topLeftCornerPropName]); origins.push(elt[topLeftCornerPropName]);
resolutions.push(elt[scaleDenominatorPropName] * 0.28E-3 / resolutions.push(elt[scaleDenominatorPropName] * 0.28E-3 /
metersPerUnit); metersPerUnit);
tileSizes.push([elt[tileWidthPropName], elt[tileHeightPropName]]); var tileWidth = elt[tileWidthPropName];
var tileHeight = elt[tileHeightPropName];
goog.asserts.assert(tileWidth == tileHeight);
tileSizes.push(tileWidth);
}); });
return new ol.tilegrid.WMTS({ return new ol.tilegrid.WMTS({

View File

@@ -29,7 +29,7 @@ ol.tilegrid.XYZ = function(options) {
minZoom: options.minZoom, minZoom: options.minZoom,
origin: [-ol.proj.EPSG3857.HALF_SIZE, ol.proj.EPSG3857.HALF_SIZE], origin: [-ol.proj.EPSG3857.HALF_SIZE, ol.proj.EPSG3857.HALF_SIZE],
resolutions: resolutions, resolutions: resolutions,
tileSize: [ol.DEFAULT_TILE_SIZE, ol.DEFAULT_TILE_SIZE] tileSize: ol.DEFAULT_TILE_SIZE
}); });
}; };

View File

@@ -197,7 +197,7 @@ ol.test.source.TileMock = function(loaded) {
resolutions: [360 / 256, 180 / 256, 90 / 256, 45 / 256], resolutions: [360 / 256, 180 / 256, 90 / 256, 45 / 256],
extent: extent, extent: extent,
origin: [-180, -180], origin: [-180, -180],
tileSize: [256, 256] tileSize: 256
}); });
goog.base(this, { goog.base(this, {

View File

@@ -12,7 +12,7 @@ describe('ol.tilegrid.TileGrid', function() {
extent = [0, 0, 100000, 100000]; extent = [0, 0, 100000, 100000];
origin = [0, 0]; origin = [0, 0];
origins = []; origins = [];
tileSize = [100, 100]; tileSize = 100;
}); });
describe('create valid', function() { describe('create valid', function() {
@@ -211,7 +211,7 @@ describe('ol.tilegrid.TileGrid', function() {
var resolutions = grid.getResolutions(); var resolutions = grid.getResolutions();
expect(resolutions.length).to.be(ol.DEFAULT_MAX_ZOOM + 1); expect(resolutions.length).to.be(ol.DEFAULT_MAX_ZOOM + 1);
expect(grid.getTileSize()).to.eql([256, 256]); expect(grid.getTileSize()).to.eql(256);
}); });
it('stores the default tile grid on a projection', function() { it('stores the default tile grid on a projection', function() {
@@ -295,7 +295,7 @@ describe('ol.tilegrid.TileGrid', function() {
describe('getTileCoordForCoordAndResolution', function() { describe('getTileCoordForCoordAndResolution', function() {
it('returns the expected TileCoord', function() { it('returns the expected TileCoord', function() {
var tileSize = [256, 256]; var tileSize = 256;
var tileGrid = new ol.tilegrid.TileGrid({ var tileGrid = new ol.tilegrid.TileGrid({
resolutions: [10], resolutions: [10],
extent: extent, extent: extent,