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

Side by Side Diff: chrome/browser/extensions/api/extension_action/extension_action_api.cc

Issue 297763004: Fix extension icons showing up with incorrect size on Chrome HiDPI Windows with scales of 150% and … (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 7 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
« no previous file with comments | « no previous file | chrome/browser/extensions/extension_icon_image.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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/extensions/api/extension_action/extension_action_api.h" 5 #include "chrome/browser/extensions/api/extension_action/extension_action_api.h"
6 6
7 #include "base/base64.h" 7 #include "base/base64.h"
8 #include "base/lazy_instance.h" 8 #include "base/lazy_instance.h"
9 #include "base/strings/string_number_conversions.h" 9 #include "base/strings/string_number_conversions.h"
10 #include "base/strings/string_util.h" 10 #include "base/strings/string_util.h"
(...skipping 168 matching lines...) Expand 10 before | Expand all | Expand 10 after
179 } 179 }
180 } 180 }
181 181
182 const base::DictionaryValue* icon_value = NULL; 182 const base::DictionaryValue* icon_value = NULL;
183 if (dict->GetDictionary(kIconStorageKey, &icon_value) && 183 if (dict->GetDictionary(kIconStorageKey, &icon_value) &&
184 !action->HasIcon(kDefaultTabId)) { 184 !action->HasIcon(kDefaultTabId)) {
185 for (size_t i = 0; i < arraysize(kIconSizes); i++) { 185 for (size_t i = 0; i < arraysize(kIconSizes); i++) {
186 if (icon_value->GetString(kIconSizes[i].size_string, &str_value) && 186 if (icon_value->GetString(kIconSizes[i].size_string, &str_value) &&
187 StringToSkBitmap(str_value, &bitmap)) { 187 StringToSkBitmap(str_value, &bitmap)) {
188 CHECK(!bitmap.isNull()); 188 CHECK(!bitmap.isNull());
189 float scale = ui::GetImageScale(kIconSizes[i].scale); 189 float scale = ui::GetScaleForScaleFactor(kIconSizes[i].scale);
190 icon.AddRepresentation(gfx::ImageSkiaRep(bitmap, scale)); 190 icon.AddRepresentation(gfx::ImageSkiaRep(bitmap, scale));
191 } 191 }
192 } 192 }
193 action->SetIcon(kDefaultTabId, gfx::Image(icon)); 193 action->SetIcon(kDefaultTabId, gfx::Image(icon));
194 } 194 }
195 } 195 }
196 196
197 // Store |action|'s default values in a DictionaryValue for use in storing to 197 // Store |action|'s default values in a DictionaryValue for use in storing to
198 // disk. 198 // disk.
199 scoped_ptr<base::DictionaryValue> DefaultsToValue(ExtensionAction* action) { 199 scoped_ptr<base::DictionaryValue> DefaultsToValue(ExtensionAction* action) {
200 const int kDefaultTabId = ExtensionAction::kDefaultTabId; 200 const int kDefaultTabId = ExtensionAction::kDefaultTabId;
201 scoped_ptr<base::DictionaryValue> dict(new base::DictionaryValue()); 201 scoped_ptr<base::DictionaryValue> dict(new base::DictionaryValue());
202 202
203 dict->SetString(kPopupUrlStorageKey, 203 dict->SetString(kPopupUrlStorageKey,
204 action->GetPopupUrl(kDefaultTabId).spec()); 204 action->GetPopupUrl(kDefaultTabId).spec());
205 dict->SetString(kTitleStorageKey, action->GetTitle(kDefaultTabId)); 205 dict->SetString(kTitleStorageKey, action->GetTitle(kDefaultTabId));
206 dict->SetString(kBadgeTextStorageKey, action->GetBadgeText(kDefaultTabId)); 206 dict->SetString(kBadgeTextStorageKey, action->GetBadgeText(kDefaultTabId));
207 dict->SetString( 207 dict->SetString(
208 kBadgeBackgroundColorStorageKey, 208 kBadgeBackgroundColorStorageKey,
209 SkColorToRawString(action->GetBadgeBackgroundColor(kDefaultTabId))); 209 SkColorToRawString(action->GetBadgeBackgroundColor(kDefaultTabId)));
210 dict->SetString(kBadgeTextColorStorageKey, 210 dict->SetString(kBadgeTextColorStorageKey,
211 SkColorToRawString(action->GetBadgeTextColor(kDefaultTabId))); 211 SkColorToRawString(action->GetBadgeTextColor(kDefaultTabId)));
212 dict->SetInteger(kAppearanceStorageKey, 212 dict->SetInteger(kAppearanceStorageKey,
213 action->GetIsVisible(kDefaultTabId) ? ACTIVE : INVISIBLE); 213 action->GetIsVisible(kDefaultTabId) ? ACTIVE : INVISIBLE);
214 214
215 gfx::ImageSkia icon = action->GetExplicitlySetIcon(kDefaultTabId); 215 gfx::ImageSkia icon = action->GetExplicitlySetIcon(kDefaultTabId);
216 if (!icon.isNull()) { 216 if (!icon.isNull()) {
217 base::DictionaryValue* icon_value = new base::DictionaryValue(); 217 base::DictionaryValue* icon_value = new base::DictionaryValue();
218 for (size_t i = 0; i < arraysize(kIconSizes); i++) { 218 for (size_t i = 0; i < arraysize(kIconSizes); i++) {
219 float scale = ui::GetImageScale(kIconSizes[i].scale); 219 float scale = ui::GetScaleForScaleFactor(kIconSizes[i].scale);
220 if (icon.HasRepresentation(scale)) { 220 if (icon.HasRepresentation(scale)) {
221 icon_value->SetString( 221 icon_value->SetString(
222 kIconSizes[i].size_string, 222 kIconSizes[i].size_string,
223 RepresentationToString(icon, scale)); 223 RepresentationToString(icon, scale));
224 } 224 }
225 } 225 }
226 dict->Set(kIconStorageKey, icon_value); 226 dict->Set(kIconStorageKey, icon_value);
227 } 227 }
228 return dict.Pass(); 228 return dict.Pass();
229 } 229 }
(...skipping 444 matching lines...) Expand 10 before | Expand all | Expand 10 after
674 gfx::ImageSkia icon; 674 gfx::ImageSkia icon;
675 // Extract icon representations from the ImageDataSet dictionary. 675 // Extract icon representations from the ImageDataSet dictionary.
676 for (size_t i = 0; i < arraysize(kIconSizes); i++) { 676 for (size_t i = 0; i < arraysize(kIconSizes); i++) {
677 base::BinaryValue* binary; 677 base::BinaryValue* binary;
678 if (canvas_set->GetBinary(kIconSizes[i].size_string, &binary)) { 678 if (canvas_set->GetBinary(kIconSizes[i].size_string, &binary)) {
679 IPC::Message pickle(binary->GetBuffer(), binary->GetSize()); 679 IPC::Message pickle(binary->GetBuffer(), binary->GetSize());
680 PickleIterator iter(pickle); 680 PickleIterator iter(pickle);
681 SkBitmap bitmap; 681 SkBitmap bitmap;
682 EXTENSION_FUNCTION_VALIDATE(IPC::ReadParam(&pickle, &iter, &bitmap)); 682 EXTENSION_FUNCTION_VALIDATE(IPC::ReadParam(&pickle, &iter, &bitmap));
683 CHECK(!bitmap.isNull()); 683 CHECK(!bitmap.isNull());
684 float scale = ui::GetImageScale(kIconSizes[i].scale); 684 float scale = ui::GetScaleForScaleFactor(kIconSizes[i].scale);
685 icon.AddRepresentation(gfx::ImageSkiaRep(bitmap, scale)); 685 icon.AddRepresentation(gfx::ImageSkiaRep(bitmap, scale));
686 } 686 }
687 } 687 }
688 688
689 extension_action_->SetIcon(tab_id_, gfx::Image(icon)); 689 extension_action_->SetIcon(tab_id_, gfx::Image(icon));
690 } else if (details_->GetInteger("iconIndex", &icon_index)) { 690 } else if (details_->GetInteger("iconIndex", &icon_index)) {
691 // Obsolete argument: ignore it. 691 // Obsolete argument: ignore it.
692 return true; 692 return true;
693 } else { 693 } else {
694 EXTENSION_FUNCTION_VALIDATE(false); 694 EXTENSION_FUNCTION_VALIDATE(false);
(...skipping 218 matching lines...) Expand 10 before | Expand all | Expand 10 after
913 return true; 913 return true;
914 } 914 }
915 915
916 bool EnablePageActionsFunction::RunSync() { 916 bool EnablePageActionsFunction::RunSync() {
917 return SetPageActionEnabled(true); 917 return SetPageActionEnabled(true);
918 } 918 }
919 919
920 bool DisablePageActionsFunction::RunSync() { 920 bool DisablePageActionsFunction::RunSync() {
921 return SetPageActionEnabled(false); 921 return SetPageActionEnabled(false);
922 } 922 }
OLDNEW
« no previous file with comments | « no previous file | chrome/browser/extensions/extension_icon_image.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698