Only create new atlas after testing all existing
This commit is contained in:
@@ -72,7 +72,7 @@ ol.renderer.webgl.AtlasManager = function(opt_size, opt_maxSize, opt_space) {
|
||||
*/
|
||||
ol.renderer.webgl.AtlasManager.prototype.getInfo = function(hash) {
|
||||
var atlas, info;
|
||||
for (var i = 0, l = this.atlases_.length; i < l; i++) {
|
||||
for (var i = 0, ii = this.atlases_.length; i < ii; i++) {
|
||||
atlas = this.atlases_[i];
|
||||
info = atlas.get(hash);
|
||||
if (info !== null) {
|
||||
@@ -105,18 +105,18 @@ ol.renderer.webgl.AtlasManager.prototype.add =
|
||||
}
|
||||
|
||||
var atlas, info;
|
||||
for (var i = 0, l = this.atlases_.length; i < l; i++) {
|
||||
for (var i = 0, ii = this.atlases_.length; i < ii; i++) {
|
||||
atlas = this.atlases_[i];
|
||||
info = atlas.add(hash, width, height, renderCallback, opt_this);
|
||||
if (info !== null) {
|
||||
return info;
|
||||
} else {
|
||||
} else if (info === null && i === ii - 1) {
|
||||
// the entry could not be added to one of the existing atlases,
|
||||
// create a new atlas that is twice as big and try to add to this one.
|
||||
this.currentSize_ = Math.min(this.currentSize_ * 2, this.maxSize_);
|
||||
atlas = new ol.renderer.webgl.Atlas(this.currentSize_, this.space_);
|
||||
this.atlases_.push(atlas);
|
||||
l++;
|
||||
ii++;
|
||||
}
|
||||
}
|
||||
};
|
||||
@@ -200,7 +200,7 @@ ol.renderer.webgl.Atlas.prototype.get = function(hash) {
|
||||
ol.renderer.webgl.Atlas.prototype.add =
|
||||
function(hash, width, height, renderCallback, opt_this) {
|
||||
var block;
|
||||
for (var i = 0, l = this.emptyBlocks_.length; i < l; i++) {
|
||||
for (var i = 0, ii = this.emptyBlocks_.length; i < ii; i++) {
|
||||
block = this.emptyBlocks_[i];
|
||||
if (block.width >= width + this.space_ &&
|
||||
block.height >= height + this.space_) {
|
||||
|
||||
@@ -207,12 +207,24 @@ describe('ol.renderer.webgl.AtlasManager', function() {
|
||||
it('creates new atlases until one is large enough', function() {
|
||||
var manager = new ol.renderer.webgl.AtlasManager(128);
|
||||
expect(manager.add(1, 100, 100, defaultRender)).to.be.ok();
|
||||
expect(manager.atlases_).to.have.length(1);
|
||||
var info = manager.add(2, 500, 500, defaultRender);
|
||||
expect(info).to.be.ok();
|
||||
expect(info.image.width).to.eql(512);
|
||||
expect(manager.atlases_).to.have.length(3);
|
||||
});
|
||||
|
||||
it('checks all existing atlases and create a new if needed', function() {
|
||||
var manager = new ol.renderer.webgl.AtlasManager(128);
|
||||
expect(manager.add(1, 100, 100, defaultRender)).to.be.ok();
|
||||
expect(manager.add(2, 100, 100, defaultRender)).to.be.ok();
|
||||
expect(manager.atlases_).to.have.length(2);
|
||||
var info = manager.add(3, 500, 500, defaultRender);
|
||||
expect(info).to.be.ok();
|
||||
expect(info.image.width).to.eql(512);
|
||||
expect(manager.atlases_).to.have.length(3);
|
||||
});
|
||||
|
||||
it('returns null if the size exceeds the maximum size', function() {
|
||||
var manager = new ol.renderer.webgl.AtlasManager(128);
|
||||
expect(manager.add(1, 100, 100, defaultRender)).to.be.ok();
|
||||
|
||||
Reference in New Issue
Block a user