diff options
author | tbarzic@chromium.org <tbarzic@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-09-15 10:50:50 +0000 |
---|---|---|
committer | tbarzic@chromium.org <tbarzic@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-09-15 10:50:50 +0000 |
commit | dd46a4ce7cf1de1f0eff98165c81c218503d1d12 (patch) | |
tree | 810aaff15a9bc0b2cd73ee9221ef69cb29ed7392 /chrome/browser/extensions/extension_install_prompt.cc | |
parent | 932a94767b5b067f2e6845a5f56642e502a2c4ff (diff) | |
download | chromium_src-dd46a4ce7cf1de1f0eff98165c81c218503d1d12.zip chromium_src-dd46a4ce7cf1de1f0eff98165c81c218503d1d12.tar.gz chromium_src-dd46a4ce7cf1de1f0eff98165c81c218503d1d12.tar.bz2 |
Fix for pixelated icons in extension install ui on 2x scale.
We should probably do something like https://chromiumcodereview.appspot.com/10917146/ (and add lazy representation loading for views),
but for M23 timeframe this will also do.
BUG=135268
TEST=manual
TBR=aa@chromium.org
Review URL: https://chromiumcodereview.appspot.com/10915251
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@157000 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/extensions/extension_install_prompt.cc')
-rw-r--r-- | chrome/browser/extensions/extension_install_prompt.cc | 40 |
1 files changed, 37 insertions, 3 deletions
diff --git a/chrome/browser/extensions/extension_install_prompt.cc b/chrome/browser/extensions/extension_install_prompt.cc index 2e5c324..2113b17 100644 --- a/chrome/browser/extensions/extension_install_prompt.cc +++ b/chrome/browser/extensions/extension_install_prompt.cc @@ -95,6 +95,31 @@ namespace { // Size of extension icon in top left of dialog. const int kIconSize = 69; +// Returns pixel size under maximal scale factor for the icon whose device +// independent size is |size_in_dip| +int GetSizeForMaxScaleFactor(int size_in_dip) { + std::vector<ui::ScaleFactor> supported_scale_factors = + ui::GetSupportedScaleFactors(); + // Scale factors are in ascending order, so the last one is the one we need. + ui::ScaleFactor max_scale_factor = supported_scale_factors.back(); + float max_scale_factor_scale = ui::GetScaleFactorScale(max_scale_factor); + + return static_cast<int>(size_in_dip * max_scale_factor_scale); +} + +// Returns bitmap for the default icon with size equal to the default icon's +// pixel size under maximal supported scale factor. +SkBitmap GetDefaultIconBitmapForMaxScaleFactor(bool is_app) { + std::vector<ui::ScaleFactor> supported_scale_factors = + ui::GetSupportedScaleFactors(); + // Scale factors are in ascending order, so the last one is the one we need. + ui::ScaleFactor max_scale_factor = + supported_scale_factors[supported_scale_factors.size() - 1]; + + return Extension::GetDefaultIcon(is_app). + GetRepresentation(max_scale_factor).sk_bitmap(); +} + } // namespace ExtensionInstallPrompt::Prompt::Prompt(Profile* profile, PromptType type) @@ -416,8 +441,12 @@ void ExtensionInstallPrompt::SetIcon(const SkBitmap* image) { icon_ = *image; else icon_ = SkBitmap(); - if (icon_.empty()) - icon_ = Extension::GetDefaultIcon(extension_->is_app()); + if (icon_.empty()) { + // Let's set default icon bitmap whose size is equal to the default icon's + // pixel size under maximal supported scale factor. If the bitmap is larger + // than the one we need, it will be scaled down by the ui code. + icon_ = GetDefaultIconBitmapForMaxScaleFactor(extension_->is_app()); + } } void ExtensionInstallPrompt::OnImageLoaded(const gfx::Image& image, @@ -438,8 +467,13 @@ void ExtensionInstallPrompt::LoadImageIfNeeded() { ExtensionResource image = extension_->GetIconResource(extension_misc::EXTENSION_ICON_LARGE, ExtensionIconSet::MATCH_BIGGER); + // Load the icon whose pixel size is large enough to be displayed under + // maximal supported scale factor. UI code will scale the icon down if needed. + // TODO(tbarzic): We should use IconImage here and load the required bitmap + // lazily. + int pixel_size = GetSizeForMaxScaleFactor(kIconSize); tracker_.LoadImage(extension_, image, - gfx::Size(kIconSize, kIconSize), + gfx::Size(pixel_size, pixel_size), ImageLoadingTracker::DONT_CACHE); } |