aboutsummaryrefslogtreecommitdiff
path: root/src/ui/controls/button.cpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2018-10-02 00:15:52 +0800
committercrupest <crupest@outlook.com>2018-10-02 00:15:52 +0800
commit3b7e3d0ca26b526c8c4e6fc335085ac28d63bbab (patch)
tree095da7f36e7f4e150080feb753a2995fe2bac8c3 /src/ui/controls/button.cpp
parentc9a423ef94f684ff21e79526f77f8ddc31a2100d (diff)
downloadcru-3b7e3d0ca26b526c8c4e6fc335085ac28d63bbab.tar.gz
cru-3b7e3d0ca26b526c8c4e6fc335085ac28d63bbab.tar.bz2
cru-3b7e3d0ca26b526c8c4e6fc335085ac28d63bbab.zip
Make button use border delegate.
Diffstat (limited to 'src/ui/controls/button.cpp')
-rw-r--r--src/ui/controls/button.cpp22
1 files changed, 16 insertions, 6 deletions
diff --git a/src/ui/controls/button.cpp b/src/ui/controls/button.cpp
index b7614f93..630c0c39 100644
--- a/src/ui/controls/button.cpp
+++ b/src/ui/controls/button.cpp
@@ -8,26 +8,36 @@ namespace cru::ui::controls
Button::Button() : Control(true)
{
- normal_border_brush_ = CreateSolidBrush(D2D1::ColorF(D2D1::ColorF::RoyalBlue));
- pressed_border_brush_ = CreateSolidBrush(D2D1::ColorF(D2D1::ColorF::MediumBlue));
- current_border_brush_ = normal_border_brush_.Get();
+ normal_border_border_ = BorderProperty::Create();
+ normal_border_border_->SetBrush(CreateSolidBrush(D2D1::ColorF(D2D1::ColorF::RoyalBlue)));
+ normal_border_border_->SetWidth(2);
+ normal_border_border_->SetRadiusX(6);
+ normal_border_border_->SetRadiusY(6);
+
+ pressed_border_border_ = BorderProperty::Create();
+ pressed_border_border_->SetBrush(CreateSolidBrush(D2D1::ColorF(D2D1::ColorF::Blue)));
+ pressed_border_border_->SetWidth(2);
+ pressed_border_border_->SetRadiusX(6);
+ pressed_border_border_->SetRadiusY(6);
+
+ border_delegate_ = std::make_unique<BorderDelegate>(this, normal_border_border_);
}
void Button::OnDraw(ID2D1DeviceContext* device_context)
{
Control::OnDraw(device_context);
- device_context->DrawRoundedRectangle(D2D1::RoundedRect(D2D1::RectF(0, 0, GetSize().width, GetSize().height), 6, 6), current_border_brush_, 2);
+ border_delegate_->Draw(device_context, GetSize());
}
void Button::OnMouseClickBegin(MouseButton button)
{
- current_border_brush_ = pressed_border_brush_.Get();
+ border_delegate_->SetBorderProperty(pressed_border_border_);
Repaint();
}
void Button::OnMouseClickEnd(MouseButton button)
{
- current_border_brush_ = normal_border_brush_.Get();
+ border_delegate_->SetBorderProperty(normal_border_border_);
Repaint();
}
}