Merge pull request #1535 from twpayne/vector-api-square-tiles
[vector-api] Only support square tiles
This commit is contained in:
@@ -191,8 +191,8 @@ ol.renderer.canvas.TileLayer.prototype.prepareFrame =
|
||||
var tileRange = tileGrid.getTileRangeForExtentAndResolution(
|
||||
extent, tileResolution);
|
||||
|
||||
var canvasWidth = tileSize[0] * tileRange.getWidth();
|
||||
var canvasHeight = tileSize[1] * tileRange.getHeight();
|
||||
var canvasWidth = tileSize * tileRange.getWidth();
|
||||
var canvasHeight = tileSize * tileRange.getHeight();
|
||||
|
||||
var canvas, context;
|
||||
if (goog.isNull(this.canvas_)) {
|
||||
@@ -231,8 +231,8 @@ ol.renderer.canvas.TileLayer.prototype.prepareFrame =
|
||||
|
||||
var canvasTileRange, canvasTileRangeWidth, minX, minY;
|
||||
if (goog.isNull(this.renderedCanvasTileRange_)) {
|
||||
canvasTileRangeWidth = canvasWidth / tileSize[0];
|
||||
var canvasTileRangeHeight = canvasHeight / tileSize[1];
|
||||
canvasTileRangeWidth = canvasWidth / tileSize;
|
||||
var canvasTileRangeHeight = canvasHeight / tileSize;
|
||||
minX = tileRange.minX -
|
||||
Math.floor((canvasTileRangeWidth - tileRange.getWidth()) / 2);
|
||||
minY = tileRange.minY -
|
||||
@@ -299,9 +299,9 @@ ol.renderer.canvas.TileLayer.prototype.prepareFrame =
|
||||
var i, ii;
|
||||
for (i = 0, ii = tilesToClear.length; i < ii; ++i) {
|
||||
tile = tilesToClear[i];
|
||||
x = tileSize[0] * (tile.tileCoord.x - canvasTileRange.minX);
|
||||
y = tileSize[1] * (canvasTileRange.maxY - tile.tileCoord.y);
|
||||
context.clearRect(x, y, tileSize[0], tileSize[1]);
|
||||
x = tileSize * (tile.tileCoord.x - canvasTileRange.minX);
|
||||
y = tileSize * (canvasTileRange.maxY - tile.tileCoord.y);
|
||||
context.clearRect(x, y, tileSize, tileSize);
|
||||
}
|
||||
|
||||
/** @type {Array.<number>} */
|
||||
@@ -325,18 +325,18 @@ ol.renderer.canvas.TileLayer.prototype.prepareFrame =
|
||||
(tile.tileCoord.y - canvasTileRange.minY) * canvasTileRangeWidth +
|
||||
(tile.tileCoord.x - canvasTileRange.minX);
|
||||
if (this.renderedTiles_[index] != tile) {
|
||||
x = tileSize[0] * (tile.tileCoord.x - canvasTileRange.minX);
|
||||
y = tileSize[1] * (canvasTileRange.maxY - tile.tileCoord.y);
|
||||
x = tileSize * (tile.tileCoord.x - canvasTileRange.minX);
|
||||
y = tileSize * (canvasTileRange.maxY - tile.tileCoord.y);
|
||||
tileState = tile.getState();
|
||||
if (tileState == ol.TileState.EMPTY ||
|
||||
tileState == ol.TileState.ERROR ||
|
||||
!opaque) {
|
||||
context.clearRect(x, y, tileSize[0], tileSize[1]);
|
||||
context.clearRect(x, y, tileSize, tileSize);
|
||||
}
|
||||
if (tileState == ol.TileState.LOADED) {
|
||||
context.drawImage(tile.getImage(),
|
||||
tileGutter, tileGutter, tileSize[0], tileSize[1],
|
||||
x, y, tileSize[0], tileSize[1]);
|
||||
tileGutter, tileGutter, tileSize, tileSize,
|
||||
x, y, tileSize, tileSize);
|
||||
}
|
||||
this.renderedTiles_[index] = tile;
|
||||
}
|
||||
@@ -348,15 +348,15 @@ ol.renderer.canvas.TileLayer.prototype.prepareFrame =
|
||||
tileExtent = tileGrid.getTileCoordExtent(tile.tileCoord, tmpExtent);
|
||||
x = (tileExtent[0] - origin[0]) / tileResolution;
|
||||
y = (origin[1] - tileExtent[3]) / tileResolution;
|
||||
width = scale * tileSize[0];
|
||||
height = scale * tileSize[1];
|
||||
width = scale * tileSize;
|
||||
height = scale * tileSize;
|
||||
tileState = tile.getState();
|
||||
if (tileState == ol.TileState.EMPTY || !opaque) {
|
||||
context.clearRect(x, y, width, height);
|
||||
}
|
||||
if (tileState == ol.TileState.LOADED) {
|
||||
context.drawImage(tile.getImage(),
|
||||
tileGutter, tileGutter, tileSize[0], tileSize[1],
|
||||
tileGutter, tileGutter, tileSize, tileSize,
|
||||
x, y, width, height);
|
||||
}
|
||||
interimTileRange =
|
||||
|
||||
@@ -334,8 +334,8 @@ ol.renderer.dom.TileLayerZ_.prototype.addTile = function(tile, tileGutter) {
|
||||
tileElement = goog.dom.createElement(goog.dom.TagName.DIV);
|
||||
tileElementStyle = tileElement.style;
|
||||
tileElementStyle.overflow = 'hidden';
|
||||
tileElementStyle.width = tileSize[0] + 'px';
|
||||
tileElementStyle.height = tileSize[1] + 'px';
|
||||
tileElementStyle.width = tileSize + 'px';
|
||||
tileElementStyle.height = tileSize + 'px';
|
||||
imageStyle.position = 'absolute';
|
||||
imageStyle.left = -tileGutter + 'px';
|
||||
imageStyle.top = -tileGutter + 'px';
|
||||
@@ -346,9 +346,9 @@ ol.renderer.dom.TileLayerZ_.prototype.addTile = function(tile, tileGutter) {
|
||||
}
|
||||
tileElementStyle.position = 'absolute';
|
||||
tileElementStyle.left =
|
||||
((tileCoord.x - this.tileCoordOrigin_.x) * tileSize[0]) + 'px';
|
||||
((tileCoord.x - this.tileCoordOrigin_.x) * tileSize) + 'px';
|
||||
tileElementStyle.top =
|
||||
((this.tileCoordOrigin_.y - tileCoord.y) * tileSize[1]) + 'px';
|
||||
((this.tileCoordOrigin_.y - tileCoord.y) * tileSize) + 'px';
|
||||
if (goog.isNull(this.documentFragment_)) {
|
||||
this.documentFragment_ = document.createDocumentFragment();
|
||||
}
|
||||
|
||||
@@ -76,9 +76,9 @@ ol.renderer.webgl.Map = function(container, map) {
|
||||
|
||||
/**
|
||||
* @private
|
||||
* @type {ol.Size}
|
||||
* @type {number}
|
||||
*/
|
||||
this.clipTileCanvasSize_ = [0, 0];
|
||||
this.clipTileCanvasSize_ = 0;
|
||||
|
||||
/**
|
||||
* @private
|
||||
@@ -170,12 +170,10 @@ ol.renderer.webgl.Map = function(container, map) {
|
||||
this.tileTextureQueue_.reprioritize();
|
||||
var element = this.tileTextureQueue_.dequeue();
|
||||
var tile = /** @type {ol.Tile} */ (element[0]);
|
||||
var tileWidth = /** @type {number} */ (element[3]);
|
||||
var tileHeight = /** @type {number} */ (element[4]);
|
||||
var tileGutter = /** @type {number} */ (element[5]);
|
||||
this.bindTileTexture(tile,
|
||||
tileWidth, tileHeight, tileGutter,
|
||||
goog.webgl.LINEAR, goog.webgl.LINEAR);
|
||||
var tileSize = /** @type {number} */ (element[3]);
|
||||
var tileGutter = /** @type {number} */ (element[4]);
|
||||
this.bindTileTexture(
|
||||
tile, tileSize, tileGutter, goog.webgl.LINEAR, goog.webgl.LINEAR);
|
||||
}
|
||||
}, this);
|
||||
|
||||
@@ -193,14 +191,13 @@ goog.inherits(ol.renderer.webgl.Map, ol.renderer.Map);
|
||||
|
||||
/**
|
||||
* @param {ol.Tile} tile Tile.
|
||||
* @param {number} tileWidth Tile width.
|
||||
* @param {number} tileHeight Tile height.
|
||||
* @param {number} tileSize Tile size.
|
||||
* @param {number} tileGutter Tile gutter.
|
||||
* @param {number} magFilter Mag filter.
|
||||
* @param {number} minFilter Min filter.
|
||||
*/
|
||||
ol.renderer.webgl.Map.prototype.bindTileTexture =
|
||||
function(tile, tileWidth, tileHeight, tileGutter, magFilter, minFilter) {
|
||||
function(tile, tileSize, tileGutter, magFilter, minFilter) {
|
||||
var gl = this.getGL();
|
||||
var tileKey = tile.getKey();
|
||||
if (this.textureCache_.containsKey(tileKey)) {
|
||||
@@ -222,19 +219,16 @@ ol.renderer.webgl.Map.prototype.bindTileTexture =
|
||||
gl.bindTexture(goog.webgl.TEXTURE_2D, texture);
|
||||
if (tileGutter > 0) {
|
||||
var clipTileCanvas = this.clipTileCanvas_;
|
||||
var clipTileCanvasSize = this.clipTileCanvasSize_;
|
||||
var clipTileContext = this.clipTileContext_;
|
||||
if (clipTileCanvasSize[0] != tileWidth ||
|
||||
clipTileCanvasSize[1] != tileHeight) {
|
||||
clipTileCanvas.width = tileWidth;
|
||||
clipTileCanvas.height = tileHeight;
|
||||
clipTileCanvasSize[0] = tileWidth;
|
||||
clipTileCanvasSize[1] = tileHeight;
|
||||
if (this.clipTileCanvasSize_ != tileSize) {
|
||||
clipTileCanvas.width = tileSize;
|
||||
clipTileCanvas.height = tileSize;
|
||||
this.clipTileCanvasSize_ = tileSize;
|
||||
} else {
|
||||
clipTileContext.clearRect(0, 0, tileWidth, tileHeight);
|
||||
clipTileContext.clearRect(0, 0, tileSize, tileSize);
|
||||
}
|
||||
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,
|
||||
goog.webgl.RGBA, goog.webgl.RGBA,
|
||||
goog.webgl.UNSIGNED_BYTE, clipTileCanvas);
|
||||
|
||||
@@ -152,14 +152,13 @@ ol.renderer.webgl.TileLayer.prototype.prepareFrame =
|
||||
|
||||
var tileRangeSize = tileRange.getSize();
|
||||
|
||||
var maxDimension = Math.max(
|
||||
tileRangeSize[0] * tileSize[0],
|
||||
tileRangeSize[1] * tileSize[1]);
|
||||
var maxDimension =
|
||||
Math.max(tileRangeSize[0] * tileSize, tileRangeSize[1] * tileSize);
|
||||
var framebufferDimension = ol.math.roundUpToPowerOfTwo(maxDimension);
|
||||
var framebufferExtentDimension = tileResolution * framebufferDimension;
|
||||
var origin = tileGrid.getOrigin(z);
|
||||
var minX = origin[0] + tileRange.minX * tileSize[0] * tileResolution;
|
||||
var minY = origin[1] + tileRange.minY * tileSize[1] * tileResolution;
|
||||
var minX = origin[0] + tileRange.minX * tileSize * tileResolution;
|
||||
var minY = origin[1] + tileRange.minY * tileSize * tileResolution;
|
||||
framebufferExtent = [
|
||||
minX, minY,
|
||||
minX + framebufferExtentDimension, minY + framebufferExtentDimension
|
||||
@@ -255,8 +254,7 @@ ol.renderer.webgl.TileLayer.prototype.prepareFrame =
|
||||
framebufferExtentDimension - 1;
|
||||
goog.vec.Vec4.setFromValues(u_tileOffset, sx, sy, tx, ty);
|
||||
gl.uniform4fv(this.locations_.u_tileOffset, u_tileOffset);
|
||||
mapRenderer.bindTileTexture(tile,
|
||||
tileSize[0], tileSize[1], tileGutter,
|
||||
mapRenderer.bindTileTexture(tile, tileSize, tileGutter,
|
||||
goog.webgl.LINEAR, goog.webgl.LINEAR);
|
||||
gl.drawArrays(goog.webgl.TRIANGLE_STRIP, 0, 4);
|
||||
}
|
||||
@@ -291,7 +289,7 @@ ol.renderer.webgl.TileLayer.prototype.prepareFrame =
|
||||
tile,
|
||||
tileGrid.getTileCoordCenter(tile.tileCoord),
|
||||
tileGrid.getResolution(tile.tileCoord.z),
|
||||
tileSize[0], tileSize[1], tileGutter
|
||||
tileSize, tileGutter
|
||||
]);
|
||||
}
|
||||
}, this);
|
||||
|
||||
Reference in New Issue
Block a user