diff options
author | aa@chromium.org <aa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-30 20:54:26 +0000 |
---|---|---|
committer | aa@chromium.org <aa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-30 20:54:26 +0000 |
commit | aca8afb264cec8bbed3b113178c7475c74af1d01 (patch) | |
tree | a24e91415a71e06a74270f01bff96a53684a48e9 /chrome/browser/views | |
parent | 1f733cf713cdb0a05f24657a278d49c3a4b88a30 (diff) | |
download | chromium_src-aca8afb264cec8bbed3b113178c7475c74af1d01.zip chromium_src-aca8afb264cec8bbed3b113178c7475c74af1d01.tar.gz chromium_src-aca8afb264cec8bbed3b113178c7475c74af1d01.tar.bz2 |
Make browser actions highlight on mouseover using theme colors.
Also, adjust layout a bit to allow for larger icons.
BUG=23363,23377
TEST=Install an extension that has a browser action. It should
highlight on rollover.
Review URL: http://codereview.chromium.org/246051
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@27654 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/views')
-rw-r--r-- | chrome/browser/views/browser_actions_container.cc | 31 | ||||
-rw-r--r-- | chrome/browser/views/browser_actions_container.h | 4 |
2 files changed, 17 insertions, 18 deletions
diff --git a/chrome/browser/views/browser_actions_container.cc b/chrome/browser/views/browser_actions_container.cc index e1d12f5..3e90f7ed 100644 --- a/chrome/browser/views/browser_actions_container.cc +++ b/chrome/browser/views/browser_actions_container.cc @@ -15,21 +15,21 @@ #include "chrome/common/notification_source.h" #include "chrome/common/notification_type.h" #include "third_party/skia/include/core/SkBitmap.h" -#include "views/controls/button/image_button.h" +#include "views/controls/button/text_button.h" // The size of the icon for page actions. -static const int kIconSize = 16; +static const int kIconSize = 30; -// The padding between icons (pixels between each icon). -static const int kIconHorizontalPadding = 10; +// The padding between the browser actions and the omnibox/page menu. +static const int kHorizontalPadding = 4; //////////////////////////////////////////////////////////////////////////////// // BrowserActionImageView -// The BrowserActionImageView is a specialization of the ImageButton class. +// The BrowserActionImageView is a specialization of the TextButton class. // It acts on a ExtensionAction, in this case a BrowserAction and handles // loading the image for the button asynchronously on the file thread to -class BrowserActionImageView : public views::ImageButton, +class BrowserActionImageView : public views::TextButton, public views::ButtonListener, public ImageLoadingTracker::Observer { public: @@ -66,10 +66,12 @@ class BrowserActionImageView : public views::ImageButton, BrowserActionImageView::BrowserActionImageView( ExtensionAction* browser_action, Extension* extension, BrowserActionsContainer* panel) - : ImageButton(this), + : TextButton(this, L""), browser_action_(browser_action), tracker_(NULL), panel_(panel) { + set_alignment(TextButton::ALIGN_CENTER); + // Load the images this view needs asynchronously on the file thread. We'll // get a call back into OnImageLoaded if the image loads successfully. If not, // the ImageView will have no image and will not appear in the browser chrome. @@ -100,9 +102,7 @@ void BrowserActionImageView::OnImageLoaded(SkBitmap* image, size_t index) { DCHECK(index < browser_action_icons_.size()); browser_action_icons_[index] = *image; if (index == 0) { - SetImage(views::CustomButton::BS_NORMAL, image); - SetImage(views::CustomButton::BS_HOT, image); - SetImage(views::CustomButton::BS_PUSHED, image); + SetIcon(*image); SetTooltipText(ASCIIToWide(browser_action_->name())); panel_->OnBrowserActionVisibilityChanged(); } @@ -180,17 +180,16 @@ void BrowserActionsContainer::OnBrowserActionExecuted( gfx::Size BrowserActionsContainer::GetPreferredSize() { if (browser_action_views_.empty()) return gfx::Size(0, 0); - int width = kIconHorizontalPadding + browser_action_views_.size() * - (kIconSize + kIconHorizontalPadding); + int width = kHorizontalPadding * 2 + + browser_action_views_.size() * kIconSize; return gfx::Size(width, kIconSize); } void BrowserActionsContainer::Layout() { for (size_t i = 0; i < browser_action_views_.size(); ++i) { - views::ImageButton* view = browser_action_views_[i]; - gfx::Size sz = view->GetPreferredSize(); - int x = kIconHorizontalPadding + i * (kIconSize + kIconHorizontalPadding); - view->SetBounds(x, (height() - sz.height()) / 2, sz.width(), sz.height()); + views::TextButton* view = browser_action_views_[i]; + int x = kHorizontalPadding + i * kIconSize; + view->SetBounds(x, (height() - kIconSize) / 2, kIconSize, kIconSize); } } diff --git a/chrome/browser/views/browser_actions_container.h b/chrome/browser/views/browser_actions_container.h index 1da8559..fd83437 100644 --- a/chrome/browser/views/browser_actions_container.h +++ b/chrome/browser/views/browser_actions_container.h @@ -15,7 +15,7 @@ class ExtensionAction; class Profile; class ToolbarView; namespace views { -class ImageButton; +class TextButton; } //////////////////////////////////////////////////////////////////////////////// @@ -56,7 +56,7 @@ class BrowserActionsContainer : public views::View, private: // The vector of browser actions (icons/image buttons for each action). - std::vector<views::ImageButton*> browser_action_views_; + std::vector<views::TextButton*> browser_action_views_; NotificationRegistrar registrar_; |