Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/favicon/favicon_service.h" | 5 #include "chrome/browser/favicon/favicon_service.h" |
| 6 | 6 |
| 7 #include "chrome/browser/favicon/select_favicon_frames.h" | 7 #include "chrome/browser/favicon/select_favicon_frames.h" |
| 8 #include "chrome/browser/history/history.h" | 8 #include "chrome/browser/history/history.h" |
| 9 #include "chrome/browser/history/history_backend.h" | 9 #include "chrome/browser/history/history_backend.h" |
| 10 #include "chrome/browser/history/history_service_factory.h" | 10 #include "chrome/browser/history/history_service_factory.h" |
| 11 #include "chrome/browser/ui/webui/chrome_web_ui_controller_factory.h" | 11 #include "chrome/browser/ui/webui/chrome_web_ui_controller_factory.h" |
| 12 #include "chrome/common/url_constants.h" | 12 #include "chrome/common/url_constants.h" |
| 13 #include "third_party/skia/include/core/SkBitmap.h" | 13 #include "third_party/skia/include/core/SkBitmap.h" |
| 14 #include "ui/gfx/codec/png_codec.h" | 14 #include "ui/gfx/codec/png_codec.h" |
| 15 #include "ui/gfx/favicon_size.h" | |
| 15 #include "ui/gfx/image/image_skia.h" | 16 #include "ui/gfx/image/image_skia.h" |
| 16 | 17 |
| 17 FaviconService::FaviconService(HistoryService* history_service) | 18 FaviconService::FaviconService(HistoryService* history_service) |
| 18 : history_service_(history_service) { | 19 : history_service_(history_service) { |
| 19 } | 20 } |
| 20 | 21 |
| 21 FaviconService::Handle FaviconService::GetFaviconImage( | 22 FaviconService::Handle FaviconService::GetFaviconImage( |
| 22 const GURL& icon_url, | 23 const GURL& icon_url, |
| 23 history::IconType icon_type, | 24 history::IconType icon_type, |
| 24 int desired_size_in_dip, | 25 int desired_size_in_dip, |
| 25 CancelableRequestConsumerBase* consumer, | 26 CancelableRequestConsumerBase* consumer, |
| 26 const FaviconImageCallback& callback) { | 27 const FaviconImageCallback& callback) { |
| 27 GetFaviconRequest* request = new GetFaviconRequest(base::Bind( | 28 GetFaviconRequest* request = new GetFaviconRequest(base::Bind( |
| 28 &FaviconService::GetFaviconImageCallback, | 29 &FaviconService::GetFaviconImageCallback, |
| 29 base::Unretained(this), | 30 base::Unretained(this), |
| 30 desired_size_in_dip, | 31 desired_size_in_dip, |
| 31 callback)); | 32 callback)); |
| 32 AddRequest(request, consumer); | 33 AddRequest(request, consumer); |
| 33 // TODO(pkotwicz): Pass in desired size and scale factors. | 34 if (history_service_) { |
| 34 if (history_service_) | 35 std::vector<GURL> icon_urls; |
| 35 history_service_->GetFavicon(request, icon_url, icon_type); | 36 icon_urls.push_back(icon_url); |
| 36 else | 37 history_service_->GetFavicons(request, icon_urls, icon_type, |
| 38 desired_size_in_dip, ui::GetSupportedScaleFactors()); | |
| 39 } else { | |
| 37 ForwardEmptyResultAsync(request); | 40 ForwardEmptyResultAsync(request); |
| 41 } | |
| 38 return request->handle(); | 42 return request->handle(); |
| 39 } | 43 } |
| 40 | 44 |
| 41 FaviconService::Handle FaviconService::GetRawFavicon( | 45 FaviconService::Handle FaviconService::GetRawFavicon( |
| 42 const GURL& icon_url, | 46 const GURL& icon_url, |
| 43 history::IconType icon_type, | 47 history::IconType icon_type, |
| 44 int desired_size_in_dip, | 48 int desired_size_in_dip, |
| 45 ui::ScaleFactor desired_scale_factor, | 49 ui::ScaleFactor desired_scale_factor, |
| 46 CancelableRequestConsumerBase* consumer, | 50 CancelableRequestConsumerBase* consumer, |
| 47 const FaviconRawCallback& callback) { | 51 const FaviconRawCallback& callback) { |
| 48 GetFaviconRequest* request = new GetFaviconRequest(base::Bind( | 52 GetFaviconRequest* request = new GetFaviconRequest(base::Bind( |
| 49 &FaviconService::GetRawFaviconCallback, | 53 &FaviconService::GetRawFaviconCallback, |
| 50 base::Unretained(this), | 54 base::Unretained(this), |
| 51 desired_size_in_dip, | 55 desired_size_in_dip, |
| 52 desired_scale_factor, | 56 desired_scale_factor, |
| 53 callback)); | 57 callback)); |
| 54 AddRequest(request, consumer); | 58 AddRequest(request, consumer); |
| 55 // TODO(pkotwicz): Pass in desired size and scale factor. | 59 if (history_service_) { |
| 56 if (history_service_) | 60 std::vector<GURL> icon_urls; |
| 57 history_service_->GetFavicon(request, icon_url, icon_type); | 61 icon_urls.push_back(icon_url); |
| 58 else | 62 std::vector<ui::ScaleFactor> desired_scale_factors; |
| 63 desired_scale_factors.push_back(desired_scale_factor); | |
| 64 history_service_->GetFavicons(request, icon_urls, icon_type, | |
| 65 desired_size_in_dip, desired_scale_factors); | |
| 66 } else { | |
| 59 ForwardEmptyResultAsync(request); | 67 ForwardEmptyResultAsync(request); |
| 68 } | |
| 60 return request->handle(); | 69 return request->handle(); |
| 61 } | 70 } |
| 62 | 71 |
| 63 FaviconService::Handle FaviconService::GetFavicon( | 72 FaviconService::Handle FaviconService::GetFavicon( |
| 64 const GURL& icon_url, | 73 const GURL& icon_url, |
| 65 history::IconType icon_type, | 74 history::IconType icon_type, |
| 66 int desired_size_in_dip, | 75 int desired_size_in_dip, |
| 67 const std::vector<ui::ScaleFactor>& desired_scale_factors, | 76 const std::vector<ui::ScaleFactor>& desired_scale_factors, |
| 68 CancelableRequestConsumerBase* consumer, | 77 CancelableRequestConsumerBase* consumer, |
| 69 const FaviconResultsCallback& callback) { | 78 const FaviconResultsCallback& callback) { |
| 70 GetFaviconRequest* request = new GetFaviconRequest(callback); | 79 GetFaviconRequest* request = new GetFaviconRequest(callback); |
| 71 AddRequest(request, consumer); | 80 AddRequest(request, consumer); |
| 72 if (history_service_) | 81 if (history_service_) { |
| 73 history_service_->GetFavicon(request, icon_url, icon_type); | 82 std::vector<GURL> icon_urls; |
| 74 else | 83 icon_urls.push_back(icon_url); |
| 84 history_service_->GetFavicons(request, icon_urls, icon_type, | |
| 85 desired_size_in_dip, desired_scale_factors); | |
| 86 } else { | |
| 75 ForwardEmptyResultAsync(request); | 87 ForwardEmptyResultAsync(request); |
| 88 } | |
| 76 return request->handle(); | 89 return request->handle(); |
| 77 } | 90 } |
| 78 | 91 |
| 79 FaviconService::Handle FaviconService::UpdateFaviconMappingAndFetch( | 92 FaviconService::Handle FaviconService::UpdateFaviconMappingAndFetch( |
| 80 const GURL& page_url, | 93 const GURL& page_url, |
| 81 const GURL& icon_url, | 94 const GURL& icon_url, |
| 82 history::IconType icon_type, | 95 history::IconType icon_type, |
| 83 CancelableRequestConsumerBase* consumer, | 96 CancelableRequestConsumerBase* consumer, |
| 84 const FaviconResultsCallback& callback) { | 97 const FaviconResultsCallback& callback) { |
| 85 GetFaviconRequest* request = new GetFaviconRequest(callback); | 98 GetFaviconRequest* request = new GetFaviconRequest(callback); |
| 86 AddRequest(request, consumer); | 99 AddRequest(request, consumer); |
| 87 if (history_service_) | 100 if (history_service_) { |
| 88 history_service_->UpdateFaviconMappingAndFetch(request, page_url, | 101 std::vector<GURL> icon_urls; |
| 89 icon_url, icon_type); | 102 icon_urls.push_back(icon_url); |
| 90 else | 103 // TODO(pkotwicz): Pass in |desired_size_in_dip| and |desired_scale_factors| |
| 104 // from FaviconHandler. | |
| 105 history_service_->UpdateFaviconMappingsAndFetch(request, page_url, | |
| 106 icon_urls, icon_type, gfx::kFaviconSize, ui::GetSupportedScaleFactors()) ; | |
|
sky
2012/09/04 20:52:29
> 80
| |
| 107 } else { | |
| 91 ForwardEmptyResultAsync(request); | 108 ForwardEmptyResultAsync(request); |
| 109 } | |
| 92 return request->handle(); | 110 return request->handle(); |
| 93 } | 111 } |
| 94 | 112 |
| 95 FaviconService::Handle FaviconService::GetFaviconImageForURL( | 113 FaviconService::Handle FaviconService::GetFaviconImageForURL( |
| 96 Profile* profile, | 114 Profile* profile, |
| 97 const GURL& page_url, | 115 const GURL& page_url, |
| 98 int icon_types, | 116 int icon_types, |
| 99 int desired_size_in_dip, | 117 int desired_size_in_dip, |
| 100 CancelableRequestConsumerBase* consumer, | 118 CancelableRequestConsumerBase* consumer, |
| 101 const FaviconImageCallback& callback) { | 119 const FaviconImageCallback& callback) { |
| (...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 153 const FaviconRawCallback& callback) { | 171 const FaviconRawCallback& callback) { |
| 154 GetFaviconRequest* request = new GetFaviconRequest(base::Bind( | 172 GetFaviconRequest* request = new GetFaviconRequest(base::Bind( |
| 155 &FaviconService::GetRawFaviconCallback, | 173 &FaviconService::GetRawFaviconCallback, |
| 156 base::Unretained(this), | 174 base::Unretained(this), |
| 157 desired_size_in_dip, | 175 desired_size_in_dip, |
| 158 desired_scale_factor, | 176 desired_scale_factor, |
| 159 callback)); | 177 callback)); |
| 160 | 178 |
| 161 AddRequest(request, consumer); | 179 AddRequest(request, consumer); |
| 162 FaviconService::Handle handle = request->handle(); | 180 FaviconService::Handle handle = request->handle(); |
| 163 // TODO(pkotwicz): Pass in desired size and scale factor. | 181 if (history_service_) { |
| 164 if (history_service_) | 182 history_service_->GetFaviconForID(request, favicon_id, desired_size_in_dip, |
| 165 history_service_->GetFaviconForID(request, favicon_id); | 183 desired_scale_factor); |
| 166 else | 184 } else { |
| 167 ForwardEmptyResultAsync(request); | 185 ForwardEmptyResultAsync(request); |
| 168 | 186 } |
| 169 return handle; | 187 return handle; |
| 170 } | 188 } |
| 171 | 189 |
| 172 | 190 |
| 173 void FaviconService::SetFaviconOutOfDateForPage(const GURL& page_url) { | 191 void FaviconService::SetFaviconOutOfDateForPage(const GURL& page_url) { |
| 174 if (history_service_) | 192 if (history_service_) |
| 175 history_service_->SetFaviconOutOfDateForPage(page_url); | 193 history_service_->SetFaviconsOutOfDateForPage(page_url); |
| 176 } | 194 } |
| 177 | 195 |
| 178 void FaviconService::CloneFavicon(const GURL& old_page_url, | 196 void FaviconService::CloneFavicon(const GURL& old_page_url, |
| 179 const GURL& new_page_url) { | 197 const GURL& new_page_url) { |
| 180 if (history_service_) | 198 if (history_service_) |
| 181 history_service_->CloneFavicon(old_page_url, new_page_url); | 199 history_service_->CloneFavicons(old_page_url, new_page_url); |
| 182 } | 200 } |
| 183 | 201 |
| 184 void FaviconService::SetImportedFavicons( | 202 void FaviconService::SetImportedFavicons( |
| 185 const std::vector<history::ImportedFaviconUsage>& favicon_usage) { | 203 const std::vector<history::ImportedFaviconUsage>& favicon_usage) { |
| 186 if (history_service_) | 204 if (history_service_) |
| 187 history_service_->SetImportedFavicons(favicon_usage); | 205 history_service_->SetImportedFavicons(favicon_usage); |
| 188 } | 206 } |
| 189 | 207 |
| 190 void FaviconService::SetFavicon(const GURL& page_url, | 208 void FaviconService::SetFavicon(const GURL& page_url, |
| 191 const GURL& icon_url, | 209 const GURL& icon_url, |
| 192 const std::vector<unsigned char>& image_data, | 210 const std::vector<unsigned char>& image_data, |
| 193 history::IconType icon_type) { | 211 history::IconType icon_type) { |
| 194 if (history_service_) | 212 if (history_service_) { |
| 195 history_service_->SetFavicon(page_url, icon_url, image_data, icon_type); | 213 // TODO(pkotwicz): Pass in real pixel size to SetFavicons. |
| 214 history::FaviconBitmapData bitmap_data_element; | |
| 215 bitmap_data_element.bitmap_data = scoped_refptr<base::RefCountedMemory>( | |
| 216 new base::RefCountedBytes(image_data)); | |
| 217 bitmap_data_element.pixel_size = gfx::Size(); | |
| 218 bitmap_data_element.icon_url = icon_url; | |
| 219 std::vector<history::FaviconBitmapData> favicon_bitmap_data; | |
| 220 favicon_bitmap_data.push_back(bitmap_data_element); | |
| 221 history::IconURLSizesMap icon_url_sizes; | |
| 222 icon_url_sizes[icon_url] = history::GetDefaultFaviconSizes(); | |
| 223 history_service_->SetFavicons(page_url, icon_type, | |
| 224 favicon_bitmap_data, icon_url_sizes); | |
| 225 } | |
| 196 } | 226 } |
| 197 | 227 |
| 198 FaviconService::~FaviconService() { | 228 FaviconService::~FaviconService() { |
| 199 } | 229 } |
| 200 | 230 |
| 201 FaviconService::Handle FaviconService::GetFaviconForURLImpl( | 231 FaviconService::Handle FaviconService::GetFaviconForURLImpl( |
| 202 Profile* profile, | 232 Profile* profile, |
| 203 const GURL& page_url, | 233 const GURL& page_url, |
| 204 int icon_types, | 234 int icon_types, |
| 205 int desired_size_in_dip, | 235 int desired_size_in_dip, |
| 206 const std::vector<ui::ScaleFactor>& desired_scale_factors, | 236 const std::vector<ui::ScaleFactor>& desired_scale_factors, |
| 207 CancelableRequestConsumerBase* consumer, | 237 CancelableRequestConsumerBase* consumer, |
| 208 GetFaviconRequest* request) { | 238 GetFaviconRequest* request) { |
| 209 AddRequest(request, consumer); | 239 AddRequest(request, consumer); |
| 210 FaviconService::Handle handle = request->handle(); | 240 FaviconService::Handle handle = request->handle(); |
| 211 if (page_url.SchemeIs(chrome::kChromeUIScheme) || | 241 if (page_url.SchemeIs(chrome::kChromeUIScheme) || |
| 212 page_url.SchemeIs(chrome::kExtensionScheme)) { | 242 page_url.SchemeIs(chrome::kExtensionScheme)) { |
| 213 // TODO(pkotwicz): Pass in desired size and desired scale factors. | 243 // TODO(pkotwicz): Pass in desired size and desired scale factors. |
| 214 ChromeWebUIControllerFactory::GetInstance()->GetFaviconForURL( | 244 ChromeWebUIControllerFactory::GetInstance()->GetFaviconForURL( |
| 215 profile, request, page_url); | 245 profile, request, page_url); |
| 216 } else { | 246 } else { |
| 217 // TODO(pkotwicz): Pass in desired size and desired scale factors. | 247 if (history_service_) { |
| 218 if (history_service_) | 248 history_service_->GetFaviconsForURL(request, page_url, icon_types, |
| 219 history_service_->GetFaviconForURL(request, page_url, icon_types); | 249 desired_size_in_dip, desired_scale_factors); |
| 220 else | 250 } else { |
| 221 ForwardEmptyResultAsync(request); | 251 ForwardEmptyResultAsync(request); |
| 252 } | |
| 222 } | 253 } |
| 223 return handle; | 254 return handle; |
| 224 } | 255 } |
| 225 | 256 |
| 226 void FaviconService::GetFaviconImageCallback( | 257 void FaviconService::GetFaviconImageCallback( |
| 227 int desired_size_in_dip, | 258 int desired_size_in_dip, |
| 228 FaviconImageCallback callback, | 259 FaviconImageCallback callback, |
| 229 Handle handle, | 260 Handle handle, |
| 230 std::vector<history::FaviconBitmapResult> favicon_bitmap_results, | 261 std::vector<history::FaviconBitmapResult> favicon_bitmap_results, |
| 231 history::IconURLSizesMap icon_url_sizes_map) { | 262 history::IconURLSizesMap icon_url_sizes_map) { |
| (...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 303 bitmap_result.bitmap_data = base::RefCountedBytes::TakeVector( | 334 bitmap_result.bitmap_data = base::RefCountedBytes::TakeVector( |
| 304 &resized_bitmap_data); | 335 &resized_bitmap_data); |
| 305 callback.Run(handle, bitmap_result); | 336 callback.Run(handle, bitmap_result); |
| 306 } | 337 } |
| 307 | 338 |
| 308 void FaviconService::ForwardEmptyResultAsync(GetFaviconRequest* request) { | 339 void FaviconService::ForwardEmptyResultAsync(GetFaviconRequest* request) { |
| 309 request->ForwardResultAsync(request->handle(), | 340 request->ForwardResultAsync(request->handle(), |
| 310 std::vector<history::FaviconBitmapResult>(), | 341 std::vector<history::FaviconBitmapResult>(), |
| 311 history::IconURLSizesMap()); | 342 history::IconURLSizesMap()); |
| 312 } | 343 } |
| OLD | NEW |