Bug 756419 - White standalone image background flashes into view when switching tabs. r=roc,bholley a=lsblakk
--- 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;
}
}