Reuse target for image layers

This commit is contained in:
ahocevar
2019-05-19 22:31:49 +02:00
parent a55505b36a
commit d1f1b468b1
4 changed files with 9 additions and 6 deletions
+3 -3
View File
@@ -6,7 +6,7 @@ import ViewHint from '../../ViewHint.js';
import {containsExtent, intersects} from '../../extent.js';
import {getIntersection, isEmpty} from '../../extent.js';
import CanvasLayerRenderer from './Layer.js';
import {compose as composeTransform, makeInverse, toString as transformToString} from '../../transform.js';
import {compose as composeTransform, makeInverse, toString as transformToString, apply as applyTransform} from '../../transform.js';
/**
* @classdesc
@@ -72,7 +72,7 @@ class CanvasImageLayerRenderer extends CanvasLayerRenderer {
/**
* @inheritDoc
*/
renderFrame(frameState, layerState) {
renderFrame(frameState, layerState, target) {
const image = this.image_;
const imageExtent = image.getExtent();
const imageResolution = image.getResolution();
@@ -159,7 +159,7 @@ class CanvasImageLayerRenderer extends CanvasLayerRenderer {
canvas.style.transform = canvasTransform;
}
return canvas;
return this.container;
}
+1
View File
@@ -85,6 +85,7 @@ class CanvasLayerRenderer extends LayerRenderer {
container = target;
reused = true;
} else {
context = null;
container = this.container;
if (!container) {
container = document.createElement('div');
+3 -2
View File
@@ -309,8 +309,9 @@ class CanvasTileLayerRenderer extends CanvasLayerRenderer {
const y = Math.round(floatY);
const w = nextX - x;
const h = nextY - y;
const transition = z === currentZ;
if (clips) {
if (clips && (!transition || tile.getAlpha(getUid(this), frameState.time) === 1)) {
// Clip mask for regions in this tile that already filled by a higher z tile
context.save();
currentClip = [x, y, x + w, y, x + w, y + h, x, y + h];
@@ -334,7 +335,7 @@ class CanvasTileLayerRenderer extends CanvasLayerRenderer {
clips.push(currentClip);
clipZs.push(currentZ);
}
this.drawTileImage(tile, frameState, x, y, w, h, tileGutter, z === currentZ);
this.drawTileImage(tile, frameState, x, y, w, h, tileGutter, transition);
if (clips) {
context.restore();
}