Merge pull request #7960 from PetroDE/master

Fix memory leak in CanvasImageRenderer
This commit is contained in:
Tim Schaub
2018-03-12 23:04:18 -06:00
committed by GitHub
2 changed files with 74 additions and 0 deletions

View File

@@ -80,6 +80,7 @@ CanvasImageLayerRenderer['create'] = function(mapRenderer, layer) {
const candidate = /** @type {Object.<string, Function>} */ (candidates[i]);
if (candidate !== CanvasImageLayerRenderer && candidate['handles'](RendererType.CANVAS, layer)) {
renderer.setVectorRenderer(candidate['create'](mapRenderer, layer));
break;
}
}
}
@@ -87,6 +88,17 @@ CanvasImageLayerRenderer['create'] = function(mapRenderer, layer) {
};
/**
* @inheritDoc
*/
CanvasImageLayerRenderer.prototype.disposeInternal = function() {
if (this.vectorRenderer_) {
this.vectorRenderer_.dispose();
}
IntermediateCanvasRenderer.prototype.disposeInternal.call(this);
};
/**
* @inheritDoc
*/
@@ -210,6 +222,9 @@ CanvasImageLayerRenderer.prototype.forEachFeatureAtCoordinate = function(coordin
* @param {ol.renderer.canvas.VectorLayer} renderer Vector renderer.
*/
CanvasImageLayerRenderer.prototype.setVectorRenderer = function(renderer) {
if (this.vectorRenderer_) {
this.vectorRenderer_.dispose();
}
this.vectorRenderer_ = renderer;
};
export default CanvasImageLayerRenderer;

View File

@@ -1,12 +1,42 @@
import Map from '../../../../../src/ol/Map.js';
import View from '../../../../../src/ol/View.js';
import ImageLayer from '../../../../../src/ol/layer/Image.js';
import VectorLayer from '../../../../../src/ol/layer/Vector.js';
import Projection from '../../../../../src/ol/proj/Projection.js';
import Static from '../../../../../src/ol/source/ImageStatic.js';
import VectorSource from '../../../../../src/ol/source/Vector.js';
import CanvasImageLayerRenderer from '../../../../../src/ol/renderer/canvas/ImageLayer.js';
import CanvasVectorLayerRenderer from '../../../../../src/ol/renderer/canvas/VectorLayer.js';
describe('ol.renderer.canvas.ImageLayer', function() {
describe('#dispose()', function() {
let layer, imageRenderer, vectorRenderer;
beforeEach(function() {
layer = new VectorLayer({
renderMode: 'image',
source: new VectorSource()
});
imageRenderer = new CanvasImageLayerRenderer(layer);
vectorRenderer = new CanvasVectorLayerRenderer(layer);
});
afterEach(function() {
vectorRenderer.dispose();
imageRenderer.dispose();
layer.dispose();
});
it('cleans up CanvasVectorRenderer', function() {
const spy = sinon.spy(vectorRenderer, 'dispose');
imageRenderer.setVectorRenderer(vectorRenderer);
imageRenderer.dispose();
expect(spy.called).to.be(true);
});
});
describe('#forEachLayerAtCoordinate', function() {
let map, target, source;
@@ -62,4 +92,33 @@ describe('ol.renderer.canvas.ImageLayer', function() {
});
});
describe('#setVectorRenderer()', function() {
let layer, imageRenderer, vectorRenderer1, vectorRenderer2;
beforeEach(function() {
layer = new VectorLayer({
renderMode: 'image',
source: new VectorSource()
});
imageRenderer = new CanvasImageLayerRenderer(layer);
vectorRenderer1 = new CanvasVectorLayerRenderer(layer);
vectorRenderer2 = new CanvasVectorLayerRenderer(layer);
});
afterEach(function() {
vectorRenderer1.dispose();
vectorRenderer2.dispose();
imageRenderer.dispose();
layer.dispose();
});
it('cleans up an existing vectorRenderer', function() {
const spy = sinon.spy(vectorRenderer1, 'dispose');
imageRenderer.setVectorRenderer(vectorRenderer1);
expect(spy.called).to.be(false);
imageRenderer.setVectorRenderer(vectorRenderer2);
expect(spy.called).to.be(true);
});
});
});