Bug 756419 - White standalone image background flashes into view when switching tabs. r=roc,bholley a=lsblakk
☠☠ backed out by c9bdd225388d ☠ ☠
authorJared Wein <jwein@mozilla.com>
Fri, 10 Aug 2012 11:00:35 -0700
changeset 104911 568fd13e400836ca874f10220cc29f9d4563ff21
parent 104910 56e05fc797123b0d4bbaed66b6ee991c58e1bfb7
child 104912 025cea007fcb44493ab8bd7fea4f50aa92c88ccf
push id191
push userlsblakk@mozilla.com
push dateFri, 05 Oct 2012 17:12:53 +0000
treeherdermozilla-release@ddb22ac6c03b [default view] [failures only]
perfherder[talos] [build metrics] [platform microbench] (compared to previous push)
reviewersroc, bholley, lsblakk
bugs756419
milestone16.0a2
Bug 756419 - White standalone image background flashes into view when switching tabs. r=roc,bholley a=lsblakk
content/html/document/src/ImageDocument.cpp
image/src/DiscardTracker.cpp
toolkit/themes/pinstripe/global/TopLevelImageDocument.css
toolkit/themes/winstripe/global/TopLevelImageDocument.css
--- a/content/html/document/src/ImageDocument.cpp
+++ b/content/html/document/src/ImageDocument.cpp
@@ -86,18 +86,20 @@ public:
   virtual void SetScriptGlobalObject(nsIScriptGlobalObject* aScriptGlobalObject);
   virtual void Destroy();
   virtual void OnPageShow(bool aPersisted,
                           nsIDOMEventTarget* aDispatchStartTarget);
 
   NS_DECL_NSIIMAGEDOCUMENT
 
   // imgIDecoderObserver (override nsStubImageDecoderObserver)
+  NS_IMETHOD OnDiscard(imgIRequest* aRequest);
   NS_IMETHOD OnStartContainer(imgIRequest* aRequest, imgIContainer* aImage);
-  NS_IMETHOD OnStopDecode(imgIRequest *aRequest, nsresult aStatus, const PRUnichar *aStatusArg);
+  NS_IMETHOD OnStopContainer(imgIRequest* aRequest, imgIContainer* aContainer);
+  NS_IMETHOD OnStopDecode(imgIRequest* aRequest, nsresult aStatus, const PRUnichar *aStatusArg);
 
   // nsIDOMEventListener
   NS_IMETHOD HandleEvent(nsIDOMEvent* aEvent);
 
   NS_DECL_CYCLE_COLLECTION_CLASS_INHERITED(ImageDocument, MediaDocument)
 
   friend class ImageListener;
 
@@ -500,41 +502,68 @@ ImageDocument::ToggleImageSize()
     ResetZoomLevel();
     ShrinkToFit();
   }
 
   return NS_OK;
 }
 
 NS_IMETHODIMP
+ImageDocument::OnDiscard(imgIRequest *aRequest)
+{
+  printf("\n\n***ImageDocument::OnDiscard***\n\n");
+  // mImageContent can be null if the document is already destroyed
+  if (mImageContent) {
+    // Remove any decoded-related styling when the image is unloaded.
+    mImageContent->UnsetAttr(kNameSpaceID_None, nsGkAtoms::_class,
+                             true);
+  }
+  return NS_OK;
+}
+
+NS_IMETHODIMP
 ImageDocument::OnStartContainer(imgIRequest* aRequest, imgIContainer* aImage)
 {
   aImage->GetWidth(&mImageWidth);
   aImage->GetHeight(&mImageHeight);
   nsCOMPtr<nsIRunnable> runnable =
     NS_NewRunnableMethod(this, &ImageDocument::DefaultCheckOverflowing);
   nsContentUtils::AddScriptRunner(runnable);
   UpdateTitleAndCharset();
 
   return NS_OK;
 }
 
 NS_IMETHODIMP
+ImageDocument::OnStopContainer(imgIRequest *aRequest, imgIContainer *aContainer)
+{
+  printf("\n\n***ImageDocument::OnStopContainer***\n\n");
+  // mImageContent can be null if the document is already destroyed.
+  // Only set the attribute if it didn't already exist to prevent unneeded
+  // style resolutions.
+  if (mImageContent &&
+      !mImageContent->HasAttr(kNameSpaceID_None, nsGkAtoms::_class)) {
+    printf("***Didn't have a 'decoded' class, adding one now***\n\n");
+    // Update the background-color of the image only after the
+    // image has been decoded to prevent flashes of just the
+    // background-color.
+    mImageContent->SetAttr(kNameSpaceID_None, nsGkAtoms::_class,
+                           NS_LITERAL_STRING("decoded"), true);
+  }
+
+  return NS_OK;
+}
+
+NS_IMETHODIMP
 ImageDocument::OnStopDecode(imgIRequest *aRequest,
                             nsresult aStatus,
                             const PRUnichar *aStatusArg)
 {
   UpdateTitleAndCharset();
 
-  nsCOMPtr<nsIImageLoadingContent> imageLoader = do_QueryInterface(mImageContent);
-  if (imageLoader) {
-    mObservingImageLoader = false;
-    imageLoader->RemoveObserver(this);
-  }
-
   // mImageContent can be null if the document is already destroyed
   if (NS_FAILED(aStatus) && mStringBundle && mImageContent) {
     nsCAutoString src;
     mDocumentURI->GetSpec(src);
     NS_ConvertUTF8toUTF16 srcString(src);
     const PRUnichar* formatString[] = { srcString.get() };
     nsXPIDLString errorMsg;
     NS_NAMED_LITERAL_STRING(str, "InvalidImage");
--- a/image/src/DiscardTracker.cpp
+++ b/image/src/DiscardTracker.cpp
@@ -247,29 +247,32 @@ void
 DiscardTracker::TimerCallback(nsITimer *aTimer, void *aClosure)
 {
   DiscardNow();
 }
 
 void
 DiscardTracker::DiscardNow()
 {
+  printf("\n\n***DiscardTracker::DiscardNow***\n\n");
+
   // Assuming the list is ordered with oldest discard tracker nodes at the back
   // and newest ones at the front, iterate from back to front discarding nodes
   // until we encounter one which is new enough to keep and until we go under
   // our sMaxDecodedImageKB limit.
 
   TimeStamp now = TimeStamp::Now();
   Node* node;
   while ((node = sDiscardableImages.getLast())) {
     if ((now - node->timestamp).ToMilliseconds() > sMinDiscardTimeoutMs ||
         sCurrentDecodedImageBytes > sMaxDecodedImageKB * 1024) {
 
       // Discarding the image should cause sCurrentDecodedImageBytes to
       // decrease via a call to InformAllocation().
+      printf("***Calling node->img->Discard()***\n\n");
       node->img->Discard();
 
       // Careful: Discarding may have caused the node to have been removed
       // from the list.
       Remove(node);
     }
     else {
       break;
--- a/toolkit/themes/pinstripe/global/TopLevelImageDocument.css
+++ b/toolkit/themes/pinstripe/global/TopLevelImageDocument.css
@@ -2,13 +2,13 @@
  * License, v. 2.0. If a copy of the MPL was not distributed with this file,
  * You can obtain one at http://mozilla.org/MPL/2.0/. */
 
 @media not print {
   body {
     background: #222 url();
   }
 
-  img {
+  .decoded {
     background-color: #fff;
     color: #222;
   }
 }
--- a/toolkit/themes/winstripe/global/TopLevelImageDocument.css
+++ b/toolkit/themes/winstripe/global/TopLevelImageDocument.css
@@ -2,13 +2,13 @@
  * License, v. 2.0. If a copy of the MPL was not distributed with this file,
  * You can obtain one at http://mozilla.org/MPL/2.0/. */
 
 @media not print {
   body {
     background: #222 url();
   }
 
-  img {
+  .decoded {
     background-color: #fff;
     color: #222;
   }
 }