mirror of
https://github.com/openseadragon/openseadragon.git
synced 2025-01-19 17:21:50 +03:00
Quick patch to fix mid-update image loaded callbacks
This commit is contained in:
parent
975828c057
commit
06dcfadf20
102
src/drawer.js
102
src/drawer.js
@ -703,23 +703,10 @@ function loadTile( drawer, tile, time ) {
|
||||
}
|
||||
|
||||
function onTileLoad( drawer, tile, time, image ) {
|
||||
var insertionIndex,
|
||||
cutoff,
|
||||
worstTile,
|
||||
worstTime,
|
||||
worstLevel,
|
||||
worstTileIndex,
|
||||
prevTile,
|
||||
prevTime,
|
||||
prevLevel,
|
||||
i;
|
||||
|
||||
tile.loading = false;
|
||||
|
||||
if ( drawer.midUpdate ) {
|
||||
$.console.warn( "Tile load callback in middle of drawing routine." );
|
||||
return;
|
||||
} else if ( !image && !drawer.viewport.collectionMode ) {
|
||||
if ( !image && !drawer.viewport.collectionMode ) {
|
||||
$.console.log( "Tile %s failed to load: %s", tile, tile.url );
|
||||
if( !drawer.debugMode ){
|
||||
tile.exists = false;
|
||||
@ -733,48 +720,65 @@ function onTileLoad( drawer, tile, time, image ) {
|
||||
tile.loaded = true;
|
||||
tile.image = image;
|
||||
|
||||
|
||||
insertionIndex = drawer.tilesLoaded.length;
|
||||
|
||||
if ( drawer.tilesLoaded.length >= drawer.maxImageCacheCount ) {
|
||||
cutoff = Math.ceil( Math.log( drawer.source.tileSize ) / Math.log( 2 ) );
|
||||
|
||||
worstTile = null;
|
||||
worstTileIndex = -1;
|
||||
|
||||
for ( i = drawer.tilesLoaded.length - 1; i >= 0; i-- ) {
|
||||
prevTile = drawer.tilesLoaded[ i ];
|
||||
|
||||
if ( prevTile.level <= drawer.cutoff || prevTile.beingDrawn ) {
|
||||
continue;
|
||||
} else if ( !worstTile ) {
|
||||
worstTile = prevTile;
|
||||
worstTileIndex = i;
|
||||
continue;
|
||||
}
|
||||
|
||||
prevTime = prevTile.lastTouchTime;
|
||||
worstTime = worstTile.lastTouchTime;
|
||||
prevLevel = prevTile.level;
|
||||
worstLevel = worstTile.level;
|
||||
|
||||
if ( prevTime < worstTime ||
|
||||
( prevTime == worstTime && prevLevel > worstLevel ) ) {
|
||||
worstTile = prevTile;
|
||||
worstTileIndex = i;
|
||||
}
|
||||
if ( drawer.tilesLoaded.length < drawer.maxImageCacheCount ) {
|
||||
// always safe to append things to cache
|
||||
drawer.tilesLoaded[ drawer.tilesLoaded.length ] = tile;
|
||||
}
|
||||
else {
|
||||
// need to remove something from cache,
|
||||
// make sure this doesn't happen mid update
|
||||
if ( !drawer.midUpdate ) {
|
||||
updateTileCache( tile, drawer );
|
||||
}
|
||||
|
||||
if ( worstTile && worstTileIndex >= 0 ) {
|
||||
worstTile.unload();
|
||||
insertionIndex = worstTileIndex;
|
||||
else {
|
||||
window.setTimeout( function() {
|
||||
updateTileCache( tile, drawer );
|
||||
}, 1);
|
||||
}
|
||||
}
|
||||
|
||||
drawer.tilesLoaded[ insertionIndex ] = tile;
|
||||
drawer.updateAgain = true;
|
||||
}
|
||||
|
||||
function updateTileCache( newTile, drawer ) {
|
||||
var i, prevTile, prevTime, worstTime, prevLevel, worstLevel,
|
||||
insertionIndex = drawer.tilesLoaded.length,
|
||||
cutoff = Math.ceil( Math.log( drawer.source.tileSize ) / Math.log( 2 ) ),
|
||||
|
||||
worstTile = null,
|
||||
worstTileIndex = -1;
|
||||
|
||||
for ( i = drawer.tilesLoaded.length - 1; i >= 0; i-- ) {
|
||||
prevTile = drawer.tilesLoaded[ i ];
|
||||
|
||||
if ( prevTile.level <= drawer.cutoff || prevTile.beingDrawn ) {
|
||||
continue;
|
||||
} else if ( !worstTile ) {
|
||||
worstTile = prevTile;
|
||||
worstTileIndex = i;
|
||||
continue;
|
||||
}
|
||||
|
||||
prevTime = prevTile.lastTouchTime;
|
||||
worstTime = worstTile.lastTouchTime;
|
||||
prevLevel = prevTile.level;
|
||||
worstLevel = worstTile.level;
|
||||
|
||||
if ( prevTime < worstTime ||
|
||||
( prevTime == worstTime && prevLevel > worstLevel ) ) {
|
||||
worstTile = prevTile;
|
||||
worstTileIndex = i;
|
||||
}
|
||||
}
|
||||
|
||||
if ( worstTile && worstTileIndex >= 0 ) {
|
||||
worstTile.unload();
|
||||
insertionIndex = worstTileIndex;
|
||||
}
|
||||
|
||||
drawer.tilesLoaded[ insertionIndex ] = newTile;
|
||||
}
|
||||
|
||||
|
||||
function positionTile( tile, overlap, viewport, viewportCenter, levelVisibility ){
|
||||
var boundsTL = tile.bounds.getTopLeft(),
|
||||
|
@ -142,7 +142,14 @@ $.ImageLoader.prototype = {
|
||||
else {
|
||||
this.jobQueue.push( newJob );
|
||||
}
|
||||
},
|
||||
|
||||
/**
|
||||
* Clear any unstarted image loading jobs from the queue.
|
||||
* @method
|
||||
*/
|
||||
clear: function() {
|
||||
this.jobQueue = [];
|
||||
}
|
||||
};
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user