[OpenLayers-Commits] r12247 - in
trunk/openlayers/lib/OpenLayers/Tile: . Image
commits-20090109 at openlayers.org
commits-20090109 at openlayers.org
Sun Aug 14 11:56:35 EDT 2011
Author: ahocevar
Date: 2011-08-14 08:56:33 -0700 (Sun, 14 Aug 2011)
New Revision: 12247
Modified:
trunk/openlayers/lib/OpenLayers/Tile/Image.js
trunk/openlayers/lib/OpenLayers/Tile/Image/IFrame.js
Log:
a bit more code, but this finally fixed the loading image placeholder issue in FF (see #3419)
Modified: trunk/openlayers/lib/OpenLayers/Tile/Image/IFrame.js
===================================================================
--- trunk/openlayers/lib/OpenLayers/Tile/Image/IFrame.js 2011-08-14 15:12:59 UTC (rev 12246)
+++ trunk/openlayers/lib/OpenLayers/Tile/Image/IFrame.js 2011-08-14 15:56:33 UTC (rev 12247)
@@ -29,14 +29,6 @@
useIFrame: null,
/**
- * Property: blankImageUrl
- * {String} This is only used as background image for the eventPane, so we
- * don't care that this doesn't actually result in a blank image on all
- * browsers
- */
- blankImageUrl: "",
-
- /**
* Method: updateBackBuffer
* Update the <backBufferData>, and return a new or reposition the
* backBuffer. When a backbuffer is returned, the tile's markup is not
Modified: trunk/openlayers/lib/OpenLayers/Tile/Image.js
===================================================================
--- trunk/openlayers/lib/OpenLayers/Tile/Image.js 2011-08-14 15:12:59 UTC (rev 12246)
+++ trunk/openlayers/lib/OpenLayers/Tile/Image.js 2011-08-14 15:56:33 UTC (rev 12247)
@@ -59,6 +59,14 @@
asyncRequestId: null,
/**
+ * Property: blankImageUrl
+ * {String} Using a data scheme url is not supported by all browsers, but
+ * we don't care because we either set it as css backgroundImage, or the
+ * image's display style is set to "none" when we use it.
+ */
+ blankImageUrl: "",
+
+ /**
* APIProperty: maxGetUrlLength
* {Number} If set, requests that would result in GET urls with more
* characters than the number provided will be made using form-encoded
@@ -255,14 +263,32 @@
if (this.url && img.getAttribute("src") == this.url) {
this.onImageLoad();
} else {
- OpenLayers.Event.observe(
- img, "load", OpenLayers.Function.bind(this.onImageLoad, this)
- );
- OpenLayers.Event.observe(
- img, "error", OpenLayers.Function.bind(this.onImageError, this)
- );
- this.imageReloadAttempts = 0;
- this.setImgSrc(this.url);
+ // We need to start with a blank image, to make sure that no
+ // loading image placeholder and no old image is displayed when we
+ // set the display style to "" in onImageLoad, which is called
+ // after the image is loaded, but before it is rendered. So we set
+ // a blank image with a data scheme URI, and register for the load
+ // event (for browsers that support data scheme) and the error
+ // event (for browsers that don't). In the event handler, we set
+ // the final src.
+ var load = OpenLayers.Function.bind(function() {
+ OpenLayers.Event.stopObservingElement(img);
+ OpenLayers.Event.observe(img, "load",
+ OpenLayers.Function.bind(this.onImageLoad, this)
+ );
+ OpenLayers.Event.observe(img, "error",
+ OpenLayers.Function.bind(this.onImageError, this)
+ );
+ this.imageReloadAttempts = 0;
+ this.setImgSrc(this.url);
+ }, this);
+ if (img.getAttribute("src") == this.blankImageUrl) {
+ load();
+ } else {
+ OpenLayers.Event.observe(img, "load", load);
+ OpenLayers.Event.observe(img, "error", load);
+ img.src = this.blankImageUrl;
+ }
}
},
@@ -274,9 +300,10 @@
* url - {String} or undefined to hide the image
*/
setImgSrc: function(url) {
- this.imgDiv.style.display = "none";
+ var img = this.imgDiv;
+ img.style.display = "none";
if (url) {
- this.imgDiv.src = url;
+ img.src = url;
}
},
More information about the Commits
mailing list