Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(710)

Side by Side Diff: chrome/browser/ui/cocoa/history_menu_bridge.mm

Issue 10870022: Change FaviconData to be able to return data for multiple bitmaps for same icon URL (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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/ui/cocoa/history_menu_bridge.h" 5 #include "chrome/browser/ui/cocoa/history_menu_bridge.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/bind_helpers.h" 8 #include "base/bind_helpers.h"
9 #include "base/stl_util.h" 9 #include "base/stl_util.h"
10 #include "base/string_number_conversions.h" 10 #include "base/string_number_conversions.h"
(...skipping 13 matching lines...) Expand all
24 #include "content/public/browser/notification_registrar.h" 24 #include "content/public/browser/notification_registrar.h"
25 #include "content/public/browser/notification_source.h" 25 #include "content/public/browser/notification_source.h"
26 #include "grit/generated_resources.h" 26 #include "grit/generated_resources.h"
27 #include "grit/theme_resources.h" 27 #include "grit/theme_resources.h"
28 #include "grit/ui_resources.h" 28 #include "grit/ui_resources.h"
29 #include "skia/ext/skia_utils_mac.h" 29 #include "skia/ext/skia_utils_mac.h"
30 #include "third_party/skia/include/core/SkBitmap.h" 30 #include "third_party/skia/include/core/SkBitmap.h"
31 #include "ui/base/l10n/l10n_util.h" 31 #include "ui/base/l10n/l10n_util.h"
32 #include "ui/base/resource/resource_bundle.h" 32 #include "ui/base/resource/resource_bundle.h"
33 #include "ui/gfx/codec/png_codec.h" 33 #include "ui/gfx/codec/png_codec.h"
34 #include "ui/gfx/favicon_size.h"
34 #include "ui/gfx/image/image.h" 35 #include "ui/gfx/image/image.h"
35 #include "ui/gfx/mac/nsimage_cache.h" 36 #include "ui/gfx/mac/nsimage_cache.h"
36 37
37 namespace { 38 namespace {
38 39
39 // Menus more than this many chars long will get trimmed. 40 // Menus more than this many chars long will get trimmed.
40 const NSUInteger kMaximumMenuWidthInChars = 50; 41 const NSUInteger kMaximumMenuWidthInChars = 50;
41 42
42 // When trimming, use this many chars from each side. 43 // When trimming, use this many chars from each side.
43 const NSUInteger kMenuTrimSizeInChars = 25; 44 const NSUInteger kMenuTrimSizeInChars = 25;
(...skipping 403 matching lines...) Expand 10 before | Expand all | Expand 10 after
447 448
448 // Tab navigations don't come with icons, so we always have to request them. 449 // Tab navigations don't come with icons, so we always have to request them.
449 GetFaviconForHistoryItem(item); 450 GetFaviconForHistoryItem(item);
450 451
451 return item; 452 return item;
452 } 453 }
453 454
454 void HistoryMenuBridge::GetFaviconForHistoryItem(HistoryItem* item) { 455 void HistoryMenuBridge::GetFaviconForHistoryItem(HistoryItem* item) {
455 FaviconService* service = 456 FaviconService* service =
456 FaviconServiceFactory::GetForProfile(profile_, Profile::EXPLICIT_ACCESS); 457 FaviconServiceFactory::GetForProfile(profile_, Profile::EXPLICIT_ACCESS);
457 FaviconService::Handle handle = service->GetFaviconForURL( 458 FaviconService::Handle handle = service->GetFaviconImageForURL(
458 profile_, item->url, history::FAVICON, &favicon_consumer_, 459 profile_, item->url, history::FAVICON, gfx::kFaviconSize,
460 &favicon_consumer_,
459 base::Bind(&HistoryMenuBridge::GotFaviconData, base::Unretained(this))); 461 base::Bind(&HistoryMenuBridge::GotFaviconData, base::Unretained(this)));
460 favicon_consumer_.SetClientData(service, handle, item); 462 favicon_consumer_.SetClientData(service, handle, item);
461 item->icon_handle = handle; 463 item->icon_handle = handle;
462 item->icon_requested = true; 464 item->icon_requested = true;
463 } 465 }
464 466
465 void HistoryMenuBridge::GotFaviconData(FaviconService::Handle handle, 467 void HistoryMenuBridge::GotFaviconData(
466 history::FaviconData favicon) { 468 FaviconService::Handle handle,
469 const history::FaviconImageResult& image_result) {
467 // Since we're going to do Cocoa-y things, make sure this is the main thread. 470 // Since we're going to do Cocoa-y things, make sure this is the main thread.
468 DCHECK([NSThread isMainThread]); 471 DCHECK([NSThread isMainThread]);
469 472
470 HistoryItem* item = 473 HistoryItem* item =
471 favicon_consumer_.GetClientData( 474 favicon_consumer_.GetClientData(
472 FaviconServiceFactory::GetForProfile( 475 FaviconServiceFactory::GetForProfile(
473 profile_, Profile::EXPLICIT_ACCESS), handle); 476 profile_, Profile::EXPLICIT_ACCESS), handle);
474 DCHECK(item); 477 DCHECK(item);
475 item->icon_requested = false; 478 item->icon_requested = false;
476 item->icon_handle = 0; 479 item->icon_handle = 0;
477 480
478 // Convert the raw data to Skia and then to a NSImage. 481 NSImage* image = image_result.image.AsNSImage();
479 // TODO(rsesek): Is there an easier way to do this? 482 if (image) {
480 SkBitmap icon; 483 item->icon.reset([image retain]);
481 if (favicon.is_valid() && 484 [item->menu_item setImage:item->icon.get()];
482 gfx::PNGCodec::Decode(favicon.image_data->front(),
483 favicon.image_data->size(), &icon)) {
484 NSImage* image = gfx::SkBitmapToNSImage(icon);
485 if (image) {
486 // The conversion was successful.
487 item->icon.reset([image retain]);
488 [item->menu_item setImage:item->icon.get()];
489 }
490 } 485 }
491 } 486 }
492 487
493 void HistoryMenuBridge::CancelFaviconRequest(HistoryItem* item) { 488 void HistoryMenuBridge::CancelFaviconRequest(HistoryItem* item) {
494 DCHECK(item); 489 DCHECK(item);
495 if (item->icon_requested) { 490 if (item->icon_requested) {
496 FaviconService* service = FaviconServiceFactory::GetForProfile( 491 FaviconService* service = FaviconServiceFactory::GetForProfile(
497 profile_, Profile::EXPLICIT_ACCESS); 492 profile_, Profile::EXPLICIT_ACCESS);
498 service->CancelRequest(item->icon_handle); 493 service->CancelRequest(item->icon_handle);
499 item->icon_requested = false; 494 item->icon_requested = false;
500 item->icon_handle = 0; 495 item->icon_handle = 0;
501 } 496 }
502 } 497 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698