Chromium Code Reviews| Index: chrome/browser/ui/views/desktop_capture/desktop_media_list_view.cc |
| diff --git a/chrome/browser/ui/views/desktop_capture/desktop_media_list_view.cc b/chrome/browser/ui/views/desktop_capture/desktop_media_list_view.cc |
| index ef1b7644b09028168643bc7f842db7ecd5d84138..3170da38afbaf1a2448ca8051aab4e136d8af410 100644 |
| --- a/chrome/browser/ui/views/desktop_capture/desktop_media_list_view.cc |
| +++ b/chrome/browser/ui/views/desktop_capture/desktop_media_list_view.cc |
| @@ -7,11 +7,17 @@ |
| #include "base/command_line.h" |
| #include "base/strings/utf_string_conversions.h" |
| #include "chrome/browser/media/desktop_media_list.h" |
| +#include "chrome/browser/media/window_icon_util.h" |
| #include "chrome/browser/ui/views/desktop_capture/desktop_media_picker_views.h" |
| #include "chrome/browser/ui/views/desktop_capture/desktop_media_source_view.h" |
| +#include "chrome/browser/ui/views/frame/browser_view.h" |
| #include "chrome/common/chrome_switches.h" |
| #include "content/public/browser/browser_thread.h" |
| +#include "extensions/grit/extensions_browser_resources.h" |
| +#include "grit/theme_resources.h" |
| #include "ui/accessibility/ax_view_state.h" |
| +#include "ui/aura/window.h" |
| +#include "ui/base/resource/resource_bundle.h" |
| #include "ui/views/focus/focus_manager.h" |
| using content::DesktopMediaID; |
| @@ -20,6 +26,27 @@ namespace { |
| const int kDesktopMediaSourceViewGroupId = 1; |
| +#if defined(OS_CHROMEOS) |
| +// As aura framework uses empty icon to represent default icon, it relies on |
| +// the caller to handle the case. |
| +// Here we are going to display default app icon for app windows without an |
| +// icon, and display product logo for chrome browser windows. |
| +gfx::ImageSkia LoadDefaultIcon(aura::Window* window) { |
| + BrowserView* browser_view = |
| + BrowserView::GetBrowserViewForNativeWindow(window); |
| + Browser* browser = browser_view ? browser_view->browser() : nullptr; |
| + |
| + // Apps could be launched in a view other than BrowserView, so we count those |
| + // windows without Browser association as apps. |
| + // Technically dev tool is actually a special app, but we would like to |
| + // display product logo for it, because intuitively it is internal to browser. |
| + bool is_app = browser ? browser->is_app() && !browser->is_devtools() : true; |
| + int idr = is_app ? IDR_APP_DEFAULT_ICON : IDR_PRODUCT_LOGO_32; |
| + |
| + ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); |
| + return *rb.GetImageSkiaNamed(idr); |
| +} |
| +#endif |
| } // namespace |
| DesktopMediaListView::DesktopMediaListView( |
| @@ -151,6 +178,16 @@ void DesktopMediaListView::OnSourceAdded(DesktopMediaList* list, int index) { |
| source_view->SetName(source.name); |
| source_view->SetGroup(kDesktopMediaSourceViewGroupId); |
| + if (source.id.type == DesktopMediaID::TYPE_WINDOW) { |
| + gfx::ImageSkia icon_image = GetWindowIcon(source.id); |
| +#if defined(OS_CHROMEOS) |
| + if (icon_image.isNull()) { |
| + aura::Window* window = DesktopMediaID::GetAuraWindowById(source.id); |
| + if (window) icon_image = LoadDefaultIcon(window); |
|
Daniel Erat
2016/08/25 23:39:58
please see the style guide. the body should be on
qiangchen
2016/08/25 23:54:19
Done.
|
| + } |
| +#endif |
| + source_view->SetIcon(icon_image); |
| + } |
| AddChildViewAt(source_view, index); |
| if ((child_count() - 1) % active_style_->columns == 0) |