Merge pull request #7267 from tschaub/fade
Render tiles with an opacity transition
This commit is contained in:
@@ -199,7 +199,8 @@ describe('ol.renderer.canvas.VectorTileLayer', function() {
|
||||
it('re-renders when layer changed', function() {
|
||||
var layer = new ol.layer.VectorTile({
|
||||
source: new ol.source.VectorTile({
|
||||
tileGrid: ol.tilegrid.createXYZ()
|
||||
tileGrid: ol.tilegrid.createXYZ(),
|
||||
transition: 0
|
||||
})
|
||||
});
|
||||
var sourceTile = new ol.VectorTile([0, 0, 0], 2);
|
||||
@@ -209,6 +210,7 @@ describe('ol.renderer.canvas.VectorTileLayer', function() {
|
||||
return document.createElement('canvas');
|
||||
};
|
||||
var tile = new ol.VectorImageTile([0, 0, 0]);
|
||||
tile.transition_ = 0;
|
||||
tile.wrappedTileCoord = [0, 0, 0];
|
||||
tile.setState(ol.TileState.LOADED);
|
||||
tile.getSourceTile = function() {
|
||||
|
||||
@@ -1,10 +1,59 @@
|
||||
|
||||
|
||||
goog.require('ol');
|
||||
goog.require('ol.ImageTile');
|
||||
goog.require('ol.Tile');
|
||||
goog.require('ol.TileState');
|
||||
|
||||
|
||||
describe('ol.Tile', function() {
|
||||
describe('constructor', function() {
|
||||
it('sets a default transition', function() {
|
||||
var coord = [0, 0, 0];
|
||||
var tile = new ol.Tile(coord, ol.TileState.IDLE);
|
||||
expect(tile.transition_).to.equal(250);
|
||||
});
|
||||
|
||||
it('allows the transition to be set', function() {
|
||||
var coord = [0, 0, 0];
|
||||
var transition = 500;
|
||||
var tile = new ol.Tile(coord, ol.TileState.IDLE, {transition: transition});
|
||||
expect(tile.transition_).to.equal(transition);
|
||||
});
|
||||
});
|
||||
|
||||
describe('#getAlpha()', function() {
|
||||
it('returns the alpha value for a tile in transition', function() {
|
||||
var coord = [0, 0, 0];
|
||||
var tile = new ol.Tile(coord, ol.TileState.IDLE);
|
||||
var id = 'test';
|
||||
var time = Date.now();
|
||||
|
||||
var startAlpha = tile.getAlpha(id, time);
|
||||
expect(startAlpha > 0).to.be(true);
|
||||
expect(startAlpha < 1).to.be(true);
|
||||
|
||||
time += tile.transition_ / 2;
|
||||
var midAlpha = tile.getAlpha(id, time);
|
||||
expect(midAlpha > startAlpha).to.be(true);
|
||||
expect(midAlpha < 1).to.be(true);
|
||||
|
||||
time += tile.transition_ / 2;
|
||||
var endAlpha = tile.getAlpha(id, time);
|
||||
expect(endAlpha).to.be(1);
|
||||
});
|
||||
});
|
||||
|
||||
describe('#inTransition()', function() {
|
||||
it('determines if the tile is in transition', function() {
|
||||
var coord = [0, 0, 0];
|
||||
var tile = new ol.Tile(coord, ol.TileState.IDLE);
|
||||
var id = 'test';
|
||||
|
||||
expect(tile.inTransition(id)).to.be(true);
|
||||
tile.endTransition(id);
|
||||
expect(tile.inTransition(id)).to.be(false);
|
||||
});
|
||||
});
|
||||
|
||||
describe('interimChain', function() {
|
||||
var head, renderTile;
|
||||
beforeEach(function() {
|
||||
|
||||
Reference in New Issue
Block a user