diff options
author | crupest <crupest@outlook.com> | 2018-10-02 00:15:52 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2018-10-02 00:15:52 +0800 |
commit | 3b7e3d0ca26b526c8c4e6fc335085ac28d63bbab (patch) | |
tree | 095da7f36e7f4e150080feb753a2995fe2bac8c3 /src/ui/controls/button.cpp | |
parent | c9a423ef94f684ff21e79526f77f8ddc31a2100d (diff) | |
download | cru-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.cpp | 22 |
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(); } } |