Chromium Code Reviews| Index: Source/core/fetch/ResourceLoadPriorityOptimizer.cpp |
| diff --git a/Source/core/fetch/ResourceLoadPriorityOptimizer.cpp b/Source/core/fetch/ResourceLoadPriorityOptimizer.cpp |
| index 40a6f56ab672ae8e99651265e4f1d5084798e74e..2aca6286e99563f679c013736cff4583de506dce 100644 |
| --- a/Source/core/fetch/ResourceLoadPriorityOptimizer.cpp |
| +++ b/Source/core/fetch/ResourceLoadPriorityOptimizer.cpp |
| @@ -42,9 +42,10 @@ ResourceLoadPriorityOptimizer* ResourceLoadPriorityOptimizer::resourceLoadPriori |
| return &s_renderLoadOptimizer; |
| } |
| -ResourceLoadPriorityOptimizer::ResourceAndVisibility::ResourceAndVisibility(ImageResource* image, VisibilityStatus v) |
| +ResourceLoadPriorityOptimizer::ResourceAndVisibility::ResourceAndVisibility(ImageResource* image, VisibilityStatus v, uint32_t s) |
| : imageResource(image) |
| , status(v) |
| + , screenArea(s) |
|
esprehn
2014/02/20 23:05:14
We don't usually abbreviate like this.
|
| { |
| } |
| @@ -99,21 +100,27 @@ void ResourceLoadPriorityOptimizer::updateImageResourcesWithLoadPriority() |
| ResourceLoadPriorityLow : ResourceLoadPriorityVeryLow; |
| if (priority != it->value->imageResource->resourceRequest().priority()) { |
| - it->value->imageResource->resourceRequest().setPriority(priority); |
| - it->value->imageResource->didChangePriority(priority); |
| + it->value->imageResource->resourceRequest().setPriority(priority, it->value->screenArea); |
| + it->value->imageResource->didChangePriority(priority, it->value->screenArea); |
| } |
| } |
| m_imageResources.clear(); |
| } |
| -void ResourceLoadPriorityOptimizer::notifyImageResourceVisibility(ImageResource* img, VisibilityStatus status) |
| +void ResourceLoadPriorityOptimizer::notifyImageResourceVisibility(ImageResource* img, VisibilityStatus status, const LayoutRect& screenRect) |
| { |
| if (!img || img->isLoaded()) |
| return; |
| - ImageResourceMap::AddResult result = m_imageResources.add(img->identifier(), adoptPtr(new ResourceAndVisibility(img, status))); |
| - if (!result.isNewEntry && status == Visible) |
| + int screenArea = 0; |
| + if (!screenRect.isEmpty() && status == Visible) |
| + screenArea += static_cast<uint32_t>(screenRect.width() * screenRect.height()); |
| + |
| + ImageResourceMap::AddResult result = m_imageResources.add(img->identifier(), adoptPtr(new ResourceAndVisibility(img, status, screenArea))); |
| + if (!result.isNewEntry && status == Visible) { |
| result.iterator->value->status = status; |
| + result.iterator->value->screenArea = status; |
| + } |
| } |
| } |