 Chromium Code Reviews
 Chromium Code Reviews Issue 1408223008:
  [MD]  Share button code between find bar and download shelf  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@master
    
  
    Issue 1408223008:
  [MD]  Share button code between find bar and download shelf  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@master| Index: chrome/browser/ui/views/bar_control_button.cc | 
| diff --git a/chrome/browser/ui/views/bar_control_button.cc b/chrome/browser/ui/views/bar_control_button.cc | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..0e4336d5533964aabfe476257ce75bcf48ac4f9f | 
| --- /dev/null | 
| +++ b/chrome/browser/ui/views/bar_control_button.cc | 
| @@ -0,0 +1,137 @@ | 
| +// Copyright 2015 The Chromium Authors. All rights reserved. | 
| +// Use of this source code is governed by a BSD-style license that can be | 
| +// found in the LICENSE file. | 
| + | 
| +#include "chrome/browser/ui/views/bar_control_button.h" | 
| + | 
| +#include "ui/gfx/color_utils.h" | 
| +#include "ui/gfx/paint_vector_icon.h" | 
| +#include "ui/gfx/vector_icons_public.h" | 
| +#include "ui/views/animation/ink_drop_animation_controller.h" | 
| +#include "ui/views/animation/ink_drop_animation_controller_factory.h" | 
| +#include "ui/views/border.h" | 
| + | 
| +namespace { | 
| + | 
| +// Extra space around the buttons to increase their event target size. | 
| +const int kButtonExtraTouchSize = 4; | 
| + | 
| +} // namespace | 
| + | 
| +BarControlButton::BarControlButton(views::ButtonListener* listener) | 
| + : views::ImageButton(listener), | 
| + id_(gfx::VectorIconId::VECTOR_ICON_NONE), | 
| + ink_drop_animation_controller_( | 
| + views::InkDropAnimationControllerFactory:: | 
| + CreateInkDropAnimationController(this)) { | 
| + const int kInkDropLargeSize = 32; | 
| + const int kInkDropLargeCornerRadius = 4; | 
| + const int kInkDropSmallSize = 24; | 
| + const int kInkDropSmallCornerRadius = 2; | 
| 
sky
2015/11/03 23:46:43
Are these constants really specific to buttons and
 
Evan Stade
2015/11/03 23:51:17
I don't know, this code is just moved from FindBar
 | 
| + ink_drop_animation_controller_->SetInkDropSize( | 
| + gfx::Size(kInkDropLargeSize, kInkDropLargeSize), | 
| + kInkDropLargeCornerRadius, | 
| + gfx::Size(kInkDropSmallSize, kInkDropSmallSize), | 
| + kInkDropSmallCornerRadius); | 
| +} | 
| + | 
| +BarControlButton::~BarControlButton() {} | 
| + | 
| +void BarControlButton::SetIcon( | 
| + gfx::VectorIconId id, | 
| + const base::Callback<SkColor(void)>& get_text_color_callback) { | 
| + id_ = id; | 
| + get_text_color_callback_ = get_text_color_callback; | 
| + | 
| + SetBorder(views::Border::CreateEmptyBorder( | 
| + kButtonExtraTouchSize, kButtonExtraTouchSize, kButtonExtraTouchSize, | 
| + kButtonExtraTouchSize)); | 
| + SetImageAlignment(views::ImageButton::ALIGN_CENTER, | 
| + views::ImageButton::ALIGN_MIDDLE); | 
| +} | 
| + | 
| +void BarControlButton::OnThemeChanged() { | 
| + SkColor icon_color = | 
| + color_utils::DeriveDefaultIconColor(get_text_color_callback_.Run()); | 
| + gfx::ImageSkia image = gfx::CreateVectorIcon(id_, 16, icon_color); | 
| + SetImage(views::CustomButton::STATE_NORMAL, &image); | 
| + image = gfx::CreateVectorIcon(id_, 16, SkColorSetA(icon_color, 0xff / 2)); | 
| 
sky
2015/11/03 23:46:43
Do we not have 16 defined some where?
 
Evan Stade
2015/11/03 23:51:17
If we landed https://codereview.chromium.org/14066
 | 
| + SetImage(views::CustomButton::STATE_DISABLED, &image); | 
| +} | 
| + | 
| +void BarControlButton::OnNativeThemeChanged(const ui::NativeTheme* theme) { | 
| + OnThemeChanged(); | 
| +} | 
| + | 
| +void BarControlButton::Layout() { | 
| + ImageButton::Layout(); | 
| + | 
| + ink_drop_animation_controller_->SetInkDropCenter( | 
| + GetLocalBounds().CenterPoint()); | 
| +} | 
| + | 
| +void BarControlButton::AddInkDropLayer(ui::Layer* ink_drop_layer) { | 
| + SetPaintToLayer(true); | 
| + SetFillsBoundsOpaquely(false); | 
| + layer()->Add(ink_drop_layer); | 
| + layer()->StackAtBottom(ink_drop_layer); | 
| 
sky
2015/11/03 23:46:43
Is this really necessary?
 
Evan Stade
2015/11/03 23:51:17
I don't know, this code is just moved from FindBar
 | 
| +} | 
| + | 
| +void BarControlButton::RemoveInkDropLayer(ui::Layer* ink_drop_layer) { | 
| 
sky
2015/11/03 23:46:43
I'm not familiar with the ink drop layer. What is
 
Evan Stade
2015/11/03 23:51:17
I don't know, this code is just moved from FindBar
 | 
| + layer()->Remove(ink_drop_layer); | 
| + SetFillsBoundsOpaquely(true); | 
| + SetPaintToLayer(false); | 
| +} | 
| + | 
| +bool BarControlButton::OnMousePressed(const ui::MouseEvent& event) { | 
| + if (IsTriggerableEvent(event)) { | 
| + ink_drop_animation_controller_->AnimateToState( | 
| + views::InkDropState::ACTION_PENDING); | 
| + } | 
| + | 
| + return ImageButton::OnMousePressed(event); | 
| +} | 
| + | 
| +void BarControlButton::OnGestureEvent(ui::GestureEvent* event) { | 
| + views::InkDropState ink_drop_state = views::InkDropState::HIDDEN; | 
| + switch (event->type()) { | 
| + case ui::ET_GESTURE_TAP_DOWN: | 
| + ink_drop_state = views::InkDropState::ACTION_PENDING; | 
| + // The ui::ET_GESTURE_TAP_DOWN event needs to be marked as handled so | 
| + // that subsequent events for the gesture are sent to |this|. | 
| + event->SetHandled(); | 
| + break; | 
| + case ui::ET_GESTURE_LONG_PRESS: | 
| + ink_drop_state = views::InkDropState::SLOW_ACTION_PENDING; | 
| + break; | 
| + case ui::ET_GESTURE_TAP: | 
| + ink_drop_state = views::InkDropState::QUICK_ACTION; | 
| + break; | 
| + case ui::ET_GESTURE_LONG_TAP: | 
| + ink_drop_state = views::InkDropState::SLOW_ACTION; | 
| + break; | 
| + case ui::ET_GESTURE_END: | 
| + case ui::ET_GESTURE_TAP_CANCEL: | 
| + ink_drop_state = views::InkDropState::HIDDEN; | 
| + break; | 
| + default: | 
| + return; | 
| + } | 
| + ink_drop_animation_controller_->AnimateToState(ink_drop_state); | 
| + | 
| + ImageButton::OnGestureEvent(event); | 
| +} | 
| + | 
| +void BarControlButton::OnMouseReleased(const ui::MouseEvent& event) { | 
| + if (!HitTestPoint(event.location())) | 
| + ink_drop_animation_controller_->AnimateToState(views::InkDropState::HIDDEN); | 
| + | 
| + ImageButton::OnMouseReleased(event); | 
| +} | 
| + | 
| +void BarControlButton::NotifyClick(const ui::Event& event) { | 
| + ink_drop_animation_controller_->AnimateToState( | 
| + views::InkDropState::QUICK_ACTION); | 
| + | 
| + ImageButton::NotifyClick(event); | 
| +} |