diff options
author | pkotwicz@chromium.org <pkotwicz@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-05-11 00:53:32 +0000 |
---|---|---|
committer | pkotwicz@chromium.org <pkotwicz@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-05-11 00:53:32 +0000 |
commit | 546882bd3fae21df702efcaaec50ec168ec6bf86 (patch) | |
tree | 5f5c77beabb57eb7bb3d91c9c423b81998017336 /chrome/browser/themes/theme_service.cc | |
parent | 9bba0e83dd8d8f2b2196a7985cc6fa704fae0cc3 (diff) | |
download | chromium_src-546882bd3fae21df702efcaaec50ec168ec6bf86.zip chromium_src-546882bd3fae21df702efcaaec50ec168ec6bf86.tar.gz chromium_src-546882bd3fae21df702efcaaec50ec168ec6bf86.tar.bz2 |
Add GetImageSkiaNamed to resource_bundle and theme_provider.
This makes converting use of SkBitmap into ImageSkia easier
Bug=124566
Test=Manual
Review URL: https://chromiumcodereview.appspot.com/10388064
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@136470 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/themes/theme_service.cc')
-rw-r--r-- | chrome/browser/themes/theme_service.cc | 22 |
1 files changed, 13 insertions, 9 deletions
diff --git a/chrome/browser/themes/theme_service.cc b/chrome/browser/themes/theme_service.cc index e5628e4..f9be837 100644 --- a/chrome/browser/themes/theme_service.cc +++ b/chrome/browser/themes/theme_service.cc @@ -22,6 +22,7 @@ #include "grit/theme_resources_standard.h" #include "grit/ui_resources.h" #include "ui/base/resource/resource_bundle.h" +#include "ui/gfx/image/image_skia.h" #if defined(OS_WIN) && !defined(USE_AURA) #include "ui/views/widget/native_widget_win.h" @@ -244,17 +245,20 @@ const gfx::Image* ThemeService::GetImageNamed(int id) const { } SkBitmap* ThemeService::GetBitmapNamed(int id) const { - DCHECK(CalledOnValidThread()); - - SkBitmap* bitmap = NULL; - - if (theme_pack_.get()) - bitmap = theme_pack_->GetBitmapNamed(id); + const gfx::Image* image = GetImageNamed(id); + if (!image) + return NULL; - if (!bitmap) - bitmap = rb_.GetBitmapNamed(id); + return const_cast<SkBitmap*>(image->ToSkBitmap()); +} - return bitmap; +gfx::ImageSkia* ThemeService::GetImageSkiaNamed(int id) const { + const gfx::Image* image = GetImageNamed(id); + if (!image) + return NULL; + // TODO(pkotwicz): Remove this const cast. The gfx::Image interface returns + // its images const. GetImageSkiaNamed() also should but has many callsites. + return const_cast<gfx::ImageSkia*>(image->ToImageSkia()); } SkColor ThemeService::GetColor(int id) const { |