Commit 5af9a9dd authored by Thomas Lukaszewicz's avatar Thomas Lukaszewicz Committed by Commit Bot

Views: Update button example to use View builders

Bug: 1130078
Change-Id: Ie2011526a9e9e75327895441af629758fa49b715
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/2471879
Commit-Queue: Thomas Lukaszewicz <tluk@chromium.org>
Reviewed-by: default avatarWei Li <weili@chromium.org>
Cr-Commit-Position: refs/heads/master@{#817296}
parent 2d3f037e
...@@ -169,11 +169,16 @@ void MdTextButton::SetEnabledTextColors(base::Optional<SkColor> color) { ...@@ -169,11 +169,16 @@ void MdTextButton::SetEnabledTextColors(base::Optional<SkColor> color) {
UpdateColors(); UpdateColors();
} }
void MdTextButton::SetCustomPadding(const gfx::Insets& padding) { void MdTextButton::SetCustomPadding(
const base::Optional<gfx::Insets>& padding) {
custom_padding_ = padding; custom_padding_ = padding;
UpdatePadding(); UpdatePadding();
} }
base::Optional<gfx::Insets> MdTextButton::GetCustomPadding() const {
return custom_padding_.value_or(CalculateDefaultPadding());
}
void MdTextButton::SetText(const base::string16& text) { void MdTextButton::SetText(const base::string16& text) {
LabelButton::SetText(text); LabelButton::SetText(text);
UpdatePadding(); UpdatePadding();
...@@ -300,6 +305,7 @@ BEGIN_METADATA(MdTextButton, LabelButton) ...@@ -300,6 +305,7 @@ BEGIN_METADATA(MdTextButton, LabelButton)
ADD_PROPERTY_METADATA(bool, Prominent) ADD_PROPERTY_METADATA(bool, Prominent)
ADD_PROPERTY_METADATA(float, CornerRadius) ADD_PROPERTY_METADATA(float, CornerRadius)
ADD_PROPERTY_METADATA(base::Optional<SkColor>, BgColorOverride) ADD_PROPERTY_METADATA(base::Optional<SkColor>, BgColorOverride)
ADD_PROPERTY_METADATA(base::Optional<gfx::Insets>, CustomPadding)
END_METADATA END_METADATA
} // namespace views } // namespace views
...@@ -41,7 +41,8 @@ class VIEWS_EXPORT MdTextButton : public LabelButton { ...@@ -41,7 +41,8 @@ class VIEWS_EXPORT MdTextButton : public LabelButton {
float GetCornerRadius() const; float GetCornerRadius() const;
// See |custom_padding_|. // See |custom_padding_|.
void SetCustomPadding(const gfx::Insets& padding); void SetCustomPadding(const base::Optional<gfx::Insets>& padding);
base::Optional<gfx::Insets> GetCustomPadding() const;
// LabelButton: // LabelButton:
void OnThemeChanged() override; void OnThemeChanged() override;
...@@ -80,6 +81,13 @@ class VIEWS_EXPORT MdTextButton : public LabelButton { ...@@ -80,6 +81,13 @@ class VIEWS_EXPORT MdTextButton : public LabelButton {
DISALLOW_COPY_AND_ASSIGN(MdTextButton); DISALLOW_COPY_AND_ASSIGN(MdTextButton);
}; };
BEGIN_VIEW_BUILDER(VIEWS_EXPORT, MdTextButton, LabelButton)
VIEW_BUILDER_PROPERTY(bool, Prominent)
VIEW_BUILDER_PROPERTY(base::Optional<SkColor>, BgColorOverride)
VIEW_BUILDER_PROPERTY(float, CornerRadius)
VIEW_BUILDER_PROPERTY(base::Optional<gfx::Insets>, CustomPadding)
END_VIEW_BUILDER(VIEWS_EXPORT, MdTextButton)
} // namespace views } // namespace views
#endif // UI_VIEWS_CONTROLS_BUTTON_MD_TEXT_BUTTON_H_ #endif // UI_VIEWS_CONTROLS_BUTTON_MD_TEXT_BUTTON_H_
...@@ -17,6 +17,9 @@ ...@@ -17,6 +17,9 @@
#include "ui/views/controls/button/md_text_button.h" #include "ui/views/controls/button/md_text_button.h"
#include "ui/views/examples/examples_window.h" #include "ui/views/examples/examples_window.h"
#include "ui/views/layout/box_layout.h" #include "ui/views/layout/box_layout.h"
#include "ui/views/layout/box_layout_view.h"
#include "ui/views/layout/fill_layout.h"
#include "ui/views/metadata/view_factory.h"
#include "ui/views/resources/grit/views_resources.h" #include "ui/views/resources/grit/views_resources.h"
#include "ui/views/view.h" #include "ui/views/view.h"
...@@ -41,42 +44,60 @@ ButtonExample::ButtonExample() : ExampleBase("Button") { ...@@ -41,42 +44,60 @@ ButtonExample::ButtonExample() : ExampleBase("Button") {
ButtonExample::~ButtonExample() = default; ButtonExample::~ButtonExample() = default;
void ButtonExample::CreateExampleView(View* container) { void ButtonExample::CreateExampleView(View* container) {
container->SetBackground(CreateSolidBackground(SK_ColorWHITE)); container->SetLayoutManager(std::make_unique<FillLayout>());
auto layout = std::make_unique<BoxLayout>(BoxLayout::Orientation::kVertical,
gfx::Insets(10), 10);
layout->set_cross_axis_alignment(BoxLayout::CrossAxisAlignment::kCenter);
container->SetLayoutManager(std::move(layout));
auto label_button =
std::make_unique<LabelButton>(this, ASCIIToUTF16(kLabelButton));
label_button->SetFocusForPlatform();
label_button->SetRequestFocusOnPress(true);
label_button_ = container->AddChildView(std::move(label_button));
md_button_ = container->AddChildView(std::make_unique<views::MdTextButton>(
this, base::ASCIIToUTF16("Material Design")));
auto md_disabled_button = std::make_unique<views::MdTextButton>(
this, ASCIIToUTF16("Material Design Disabled Button"));
md_disabled_button->SetState(Button::STATE_DISABLED);
md_disabled_button_ = container->AddChildView(std::move(md_disabled_button));
auto md_default_button = std::make_unique<views::MdTextButton>(
this, base::ASCIIToUTF16("Default"));
md_default_button->SetIsDefault(true);
md_default_button_ = container->AddChildView(std::move(md_default_button));
ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance();
auto image_button = std::make_unique<ImageButton>(this);
image_button->SetFocusForPlatform(); auto view =
image_button->SetRequestFocusOnPress(true); Builder<BoxLayoutView>()
image_button->SetImage(ImageButton::STATE_NORMAL, .SetOrientation(BoxLayout::Orientation::kVertical)
rb.GetImageNamed(IDR_CLOSE).ToImageSkia()); .SetInsideBorderInsets(gfx::Insets(10))
image_button->SetImage(ImageButton::STATE_HOVERED, .SetBetweenChildSpacing(10)
rb.GetImageNamed(IDR_CLOSE_H).ToImageSkia()); .SetCrossAxisAlignment(BoxLayout::CrossAxisAlignment::kCenter)
image_button->SetImage(ImageButton::STATE_PRESSED, .SetBackground(CreateSolidBackground(SK_ColorWHITE))
rb.GetImageNamed(IDR_CLOSE_P).ToImageSkia()); .AddChildren(
image_button_ = container->AddChildView(std::move(image_button)); {Builder<LabelButton>()
.CopyAddressTo(&label_button_)
.SetText(ASCIIToUTF16(kLabelButton))
.SetFocusForPlatform()
.SetRequestFocusOnPress(true),
Builder<MdTextButton>()
.CopyAddressTo(&md_button_)
.SetText(base::ASCIIToUTF16("Material Design")),
Builder<MdTextButton>()
.CopyAddressTo(&md_disabled_button_)
.SetText(ASCIIToUTF16("Material Design Disabled Button"))
.SetState(Button::STATE_DISABLED),
Builder<MdTextButton>()
.CopyAddressTo(&md_default_button_)
.SetText(base::ASCIIToUTF16("Default"))
.SetIsDefault(true),
Builder<ImageButton>()
.CopyAddressTo(&image_button_)
.SetFocusForPlatform()
.SetRequestFocusOnPress(true)})
.Build();
auto start_throbber_cb = [](Button* button) { button->StartThrobbing(5); };
label_button_->set_callback(
base::BindRepeating(&ButtonExample::LabelButtonPressed,
base::Unretained(this), label_button_));
md_button_->set_callback(base::BindRepeating(start_throbber_cb, md_button_));
md_disabled_button_->set_callback(
base::BindRepeating(&ButtonExample::LabelButtonPressed,
base::Unretained(this), md_disabled_button_));
md_default_button_->set_callback(
base::BindRepeating(start_throbber_cb, md_default_button_));
image_button_->set_callback(base::BindRepeating(
&ButtonExample::ImageButtonPressed, base::Unretained(this)));
image_button_->SetImage(ImageButton::STATE_NORMAL,
rb.GetImageNamed(IDR_CLOSE).ToImageSkia());
image_button_->SetImage(ImageButton::STATE_HOVERED,
rb.GetImageNamed(IDR_CLOSE_H).ToImageSkia());
image_button_->SetImage(ImageButton::STATE_PRESSED,
rb.GetImageNamed(IDR_CLOSE_P).ToImageSkia());
container->AddChildView(std::move(view));
} }
void ButtonExample::LabelButtonPressed(LabelButton* label_button, void ButtonExample::LabelButtonPressed(LabelButton* label_button,
...@@ -112,15 +133,8 @@ void ButtonExample::LabelButtonPressed(LabelButton* label_button, ...@@ -112,15 +133,8 @@ void ButtonExample::LabelButtonPressed(LabelButton* label_button,
example_view()->GetLayoutManager()->Layout(example_view()); example_view()->GetLayoutManager()->Layout(example_view());
} }
void ButtonExample::ButtonPressed(Button* sender, const ui::Event& event) { void ButtonExample::ImageButtonPressed() {
if (sender == label_button_) PrintStatus("Image Button Pressed! count: %d", ++count_);
LabelButtonPressed(label_button_, event);
else if (sender == md_button_ || sender == md_default_button_)
static_cast<Button*>(sender)->StartThrobbing(5);
else if (sender == md_disabled_button_)
LabelButtonPressed(md_disabled_button_, event);
else
PrintStatus("Image Button Pressed! count: %d", ++count_);
} }
} // namespace examples } // namespace examples
......
...@@ -6,9 +6,16 @@ ...@@ -6,9 +6,16 @@
#define UI_VIEWS_EXAMPLES_BUTTON_EXAMPLE_H_ #define UI_VIEWS_EXAMPLES_BUTTON_EXAMPLE_H_
#include "base/macros.h" #include "base/macros.h"
#include "ui/views/controls/button/button.h"
#include "ui/views/examples/example_base.h" #include "ui/views/examples/example_base.h"
namespace gfx {
class ImageSkia;
} // namespace gfx
namespace ui {
class Event;
} // namespace ui
namespace views { namespace views {
class ImageButton; class ImageButton;
...@@ -18,8 +25,7 @@ class MdTextButton; ...@@ -18,8 +25,7 @@ class MdTextButton;
namespace examples { namespace examples {
// ButtonExample simply counts the number of clicks. // ButtonExample simply counts the number of clicks.
class VIEWS_EXAMPLES_EXPORT ButtonExample : public ExampleBase, class VIEWS_EXAMPLES_EXPORT ButtonExample : public ExampleBase {
public ButtonListener {
public: public:
ButtonExample(); ButtonExample();
~ButtonExample() override; ~ButtonExample() override;
...@@ -29,9 +35,7 @@ class VIEWS_EXAMPLES_EXPORT ButtonExample : public ExampleBase, ...@@ -29,9 +35,7 @@ class VIEWS_EXAMPLES_EXPORT ButtonExample : public ExampleBase,
private: private:
void LabelButtonPressed(LabelButton* label_button, const ui::Event& event); void LabelButtonPressed(LabelButton* label_button, const ui::Event& event);
void ImageButtonPressed();
// ButtonListener:
void ButtonPressed(Button* sender, const ui::Event& event) override;
// Example buttons. // Example buttons.
LabelButton* label_button_ = nullptr; LabelButton* label_button_ = nullptr;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment