Merge pull request #3107 from elemoine/imagestate

Also listen on loading images
This commit is contained in:
Éric Lemoine
2015-01-21 12:50:31 +01:00
8 changed files with 133 additions and 35 deletions
+2 -9
View File
@@ -3,11 +3,8 @@ goog.provide('ol.renderer.dom.ImageLayer');
goog.require('goog.asserts');
goog.require('goog.dom');
goog.require('goog.dom.TagName');
goog.require('goog.events');
goog.require('goog.events.EventType');
goog.require('goog.vec.Mat4');
goog.require('ol.ImageBase');
goog.require('ol.ImageState');
goog.require('ol.ViewHint');
goog.require('ol.dom');
goog.require('ol.extent');
@@ -113,12 +110,8 @@ ol.renderer.dom.ImageLayer.prototype.prepareFrame =
var image_ = imageSource.getImage(renderedExtent, viewResolution,
frameState.pixelRatio, projection);
if (!goog.isNull(image_)) {
var imageState = image_.getState();
if (imageState == ol.ImageState.IDLE) {
goog.events.listenOnce(image_, goog.events.EventType.CHANGE,
this.handleImageChange, false, this);
image_.load();
} else if (imageState == ol.ImageState.LOADED) {
var loaded = this.loadImage(image_);
if (loaded) {
image = image_;
}
}
@@ -209,7 +209,7 @@ ol.renderer.dom.VectorLayer.prototype.forEachFeatureAtPixel =
* @param {goog.events.Event} event Image style change event.
* @private
*/
ol.renderer.dom.VectorLayer.prototype.handleImageChange_ =
ol.renderer.dom.VectorLayer.prototype.handleStyleImageChange_ =
function(event) {
this.renderIfReadyAndVisible();
};
@@ -334,7 +334,7 @@ ol.renderer.dom.VectorLayer.prototype.renderFeature =
loading = ol.renderer.vector.renderFeature(
replayGroup, feature, styles[i],
ol.renderer.vector.getSquaredTolerance(resolution, pixelRatio),
this.handleImageChange_, this) || loading;
this.handleStyleImageChange_, this) || loading;
}
return loading;
};