Chromium Code Reviews| Index: components/favicon/ios/web_favicon_driver.mm |
| diff --git a/components/favicon/ios/web_favicon_driver.mm b/components/favicon/ios/web_favicon_driver.mm |
| index 03777812d270aaab8087036341b4f3035fc340a0..7040b7aed9dde5f83a5fef2557b5ee1c492e2906 100644 |
| --- a/components/favicon/ios/web_favicon_driver.mm |
| +++ b/components/favicon/ios/web_favicon_driver.mm |
| @@ -5,6 +5,7 @@ |
| #include "components/favicon/ios/web_favicon_driver.h" |
| #include "base/bind.h" |
| +#include "base/memory/ptr_util.h" |
|
sdefresne
2017/02/07 10:18:30
I think this is unused.
gambard
2017/02/08 14:48:12
Done.
|
| #include "components/favicon/core/favicon_url.h" |
| #include "components/favicon/ios/favicon_url_util.h" |
| #include "ios/web/public/browser_state.h" |
| @@ -12,10 +13,21 @@ |
| #include "ios/web/public/navigation_item.h" |
| #include "ios/web/public/navigation_manager.h" |
| #include "ios/web/public/web_state/web_state.h" |
| +#include "ios/web/public/web_thread.h" |
| +#include "skia/ext/skia_utils_ios.h" |
| +#include "third_party/skia/include/core/SkBitmap.h" |
| #include "ui/gfx/image/image.h" |
| DEFINE_WEB_STATE_USER_DATA_KEY(favicon::WebFaviconDriver); |
| +// Callback for the download of favicon. |
| +using ImageDownloadCallback = |
| + base::Callback<void(int image_id, |
| + int http_status_code, |
| + const GURL& image_url, |
| + const std::vector<SkBitmap>& bitmaps, |
| + const std::vector<gfx::Size>& sizes)>; |
| + |
| namespace favicon { |
| // static |
| @@ -55,10 +67,32 @@ int WebFaviconDriver::StartDownload(const GURL& url, int max_image_size) { |
| return 0; |
| } |
| - return web_state()->DownloadImage( |
| - url, true, max_image_size, false, |
| - base::Bind(&FaviconDriverImpl::DidDownloadFavicon, |
| - base::Unretained(this))); |
| + static int downloaded_image_count = 0; |
| + int local_download_id = ++downloaded_image_count; |
| + |
| + ImageDownloadCallback local_image_callback = base::Bind( |
| + &FaviconDriverImpl::DidDownloadFavicon, base::Unretained(this)); |
| + GURL local_url(url); |
| + |
| + image_fetcher::IOSImageDataFetcherCallback local_callback = ^( |
| + NSData* data, const int response_code) { |
| + if (response_code == image_fetcher::ImageDataFetcher::RESPONSE_CODE_INVALID) |
| + return; |
| + |
| + std::vector<SkBitmap> frames; |
| + std::vector<gfx::Size> sizes; |
| + if (data) { |
| + frames = skia::ImageDataToSkBitmaps(data); |
| + for (const auto& frame : frames) { |
| + sizes.push_back(gfx::Size(frame.width(), frame.height())); |
| + } |
| + } |
| + local_image_callback.Run(local_download_id, response_code, local_url, |
| + frames, sizes); |
| + }; |
| + image_fetcher_.FetchImageDataWebpDecoded(url, local_callback); |
| + |
| + return downloaded_image_count; |
| } |
| bool WebFaviconDriver::IsOffTheRecord() { |
| @@ -96,8 +130,9 @@ WebFaviconDriver::WebFaviconDriver(web::WebState* web_state, |
| history::HistoryService* history_service, |
| bookmarks::BookmarkModel* bookmark_model) |
| : web::WebStateObserver(web_state), |
| - FaviconDriverImpl(favicon_service, history_service, bookmark_model) { |
| -} |
| + FaviconDriverImpl(favicon_service, history_service, bookmark_model), |
| + image_fetcher_(web_state->GetBrowserState()->GetRequestContext(), |
| + web::WebThread::GetBlockingPool()) {} |
| WebFaviconDriver::~WebFaviconDriver() { |
| } |