aboutsummaryrefslogtreecommitdiff
path: root/src/ui/controls/button.cpp
diff options
context:
space:
mode:
authorYuqian Yang <crupest@outlook.com>2018-10-04 16:52:11 +0000
committerYuqian Yang <crupest@outlook.com>2018-10-04 16:52:11 +0000
commit7e870dd16e2f5b41fa6c6f687723aaa50c16274d (patch)
treebe2b26a42dc9fde97379f98f035113e08e0bc331 /src/ui/controls/button.cpp
parent30ecda8bb354d5982978af97aa90b5f49d9ea195 (diff)
parentc5384d496e9ed429ca2baa3ca5e586ff255235eb (diff)
downloadcru-7e870dd16e2f5b41fa6c6f687723aaa50c16274d.tar.gz
cru-7e870dd16e2f5b41fa6c6f687723aaa50c16274d.tar.bz2
cru-7e870dd16e2f5b41fa6c6f687723aaa50c16274d.zip
Merge branch '12-layout' into 'master'
Resolve "Add padding, margin, border to Control." Closes #12 See merge request crupest/CruUI!12
Diffstat (limited to 'src/ui/controls/button.cpp')
-rw-r--r--src/ui/controls/button.cpp47
1 files changed, 16 insertions, 31 deletions
diff --git a/src/ui/controls/button.cpp b/src/ui/controls/button.cpp
index 2ecc9f14..db0b71c2 100644
--- a/src/ui/controls/button.cpp
+++ b/src/ui/controls/button.cpp
@@ -8,46 +8,31 @@ namespace cru::ui::controls
Button::Button() : Control(true)
{
- 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);
- border_delegate_->Draw(device_context, GetSize());
- }
-
- Size Button::OnMeasure(const Size& available_size)
- {
- return Control::DefaultMeasureWithPadding(available_size, border_delegate_->GetBorderThickness());
- }
-
- void Button::OnLayout(const Rect& rect)
- {
- Control::DefaultLayoutWithPadding(rect, border_delegate_->GetBorderThickness());
+ normal_border_ = BorderProperty::Create();
+ normal_border_->SetBrush(CreateSolidBrush(D2D1::ColorF(D2D1::ColorF::RoyalBlue)));
+ normal_border_->SetWidth(2);
+ normal_border_->SetRadiusX(6);
+ normal_border_->SetRadiusY(6);
+
+ pressed_border_ = BorderProperty::Create();
+ pressed_border_->SetBrush(CreateSolidBrush(D2D1::ColorF(D2D1::ColorF::Blue)));
+ pressed_border_->SetWidth(2);
+ pressed_border_->SetRadiusX(6);
+ pressed_border_->SetRadiusY(6);
+
+ SetBordered(true);
+ SetBorderProperty(normal_border_);
}
void Button::OnMouseClickBegin(MouseButton button)
{
- border_delegate_->SetBorderProperty(pressed_border_border_);
+ SetBorderProperty(pressed_border_);
Repaint();
}
void Button::OnMouseClickEnd(MouseButton button)
{
- border_delegate_->SetBorderProperty(normal_border_border_);
+ SetBorderProperty(normal_border_);
Repaint();
}
}