mirror of
https://github.com/openseadragon/openseadragon.git
synced 2024-11-25 14:46:10 +03:00
Prevent early tile completion with call order instead of guard flag. Improve getCompletionCallback docs.
This commit is contained in:
parent
55e7d2439a
commit
57486732b1
@ -1656,13 +1656,13 @@ $.extend($.TiledImage.prototype, $.EventSource.prototype, /** @lends OpenSeadrag
|
|||||||
*/
|
*/
|
||||||
_setTileLoaded: function(tile, data, cutoff, tileRequest) {
|
_setTileLoaded: function(tile, data, cutoff, tileRequest) {
|
||||||
var increment = 0,
|
var increment = 0,
|
||||||
completed = false,
|
|
||||||
eventFinished = false,
|
eventFinished = false,
|
||||||
_this = this;
|
_this = this;
|
||||||
|
|
||||||
function getCompletionCallback() {
|
function getCompletionCallback() {
|
||||||
if (eventFinished) {
|
if (eventFinished) {
|
||||||
$.console.error("Event 'tile-loaded' argument getCompletionCallback must not be called asynchronously.");
|
$.console.error("Event 'tile-loaded' argument getCompletionCallback must be called synchronously. " +
|
||||||
|
"Its return value should be called asynchronously.");
|
||||||
}
|
}
|
||||||
increment++;
|
increment++;
|
||||||
return completionCallback;
|
return completionCallback;
|
||||||
@ -1670,8 +1670,7 @@ $.extend($.TiledImage.prototype, $.EventSource.prototype, /** @lends OpenSeadrag
|
|||||||
|
|
||||||
function completionCallback() {
|
function completionCallback() {
|
||||||
increment--;
|
increment--;
|
||||||
if (increment === 0 && !completed) {
|
if (increment === 0) {
|
||||||
completed = true;
|
|
||||||
tile.loading = false;
|
tile.loading = false;
|
||||||
tile.loaded = true;
|
tile.loaded = true;
|
||||||
tile.hasTransparency = _this.source.hasTransparency(
|
tile.hasTransparency = _this.source.hasTransparency(
|
||||||
@ -1705,7 +1704,11 @@ $.extend($.TiledImage.prototype, $.EventSource.prototype, /** @lends OpenSeadrag
|
|||||||
* when the asynchronous processing of the image is done. The image will be
|
* when the asynchronous processing of the image is done. The image will be
|
||||||
* marked as entirely loaded when the callback has been called once for each
|
* marked as entirely loaded when the callback has been called once for each
|
||||||
* call to getCompletionCallback.
|
* call to getCompletionCallback.
|
||||||
|
* Note: if you do not process the tile in asynchronous context
|
||||||
|
* (timeout, Promises, async, callbacks such as image.onload ...), do not use this function.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
var fallbackCompletion = getCompletionCallback();
|
||||||
this.viewer.raiseEvent("tile-loaded", {
|
this.viewer.raiseEvent("tile-loaded", {
|
||||||
tile: tile,
|
tile: tile,
|
||||||
tiledImage: this,
|
tiledImage: this,
|
||||||
@ -1717,9 +1720,9 @@ $.extend($.TiledImage.prototype, $.EventSource.prototype, /** @lends OpenSeadrag
|
|||||||
data: data,
|
data: data,
|
||||||
getCompletionCallback: getCompletionCallback
|
getCompletionCallback: getCompletionCallback
|
||||||
});
|
});
|
||||||
// In case the completion callback is never called, we at least force it once.
|
|
||||||
eventFinished = true;
|
eventFinished = true;
|
||||||
getCompletionCallback()();
|
// In case the completion callback is never called, we at least force it once.
|
||||||
|
fallbackCompletion();
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user