diff options
author | Yuqian Yang <crupest@outlook.com> | 2018-09-25 05:30:01 +0000 |
---|---|---|
committer | Yuqian Yang <crupest@outlook.com> | 2018-09-25 05:30:01 +0000 |
commit | ea4b0966d8eb5a8e76dfbe4d833a07a4797a3284 (patch) | |
tree | e5918c686f27363bfacf7d47e4b93617872b908d /src/ui/controls/button.cpp | |
parent | 001e1d955132a02a2f7effc841ab9e5ee425eda1 (diff) | |
parent | 03d078796ad31eb55d70ad0aa61254b301e989a6 (diff) | |
download | cru-ea4b0966d8eb5a8e76dfbe4d833a07a4797a3284.tar.gz cru-ea4b0966d8eb5a8e76dfbe4d833a07a4797a3284.tar.bz2 cru-ea4b0966d8eb5a8e76dfbe4d833a07a4797a3284.zip |
Merge branch 'testing' into 'master'
Add CI.
See merge request crupest/CruUI!5
Diffstat (limited to 'src/ui/controls/button.cpp')
-rw-r--r-- | src/ui/controls/button.cpp | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/src/ui/controls/button.cpp b/src/ui/controls/button.cpp new file mode 100644 index 00000000..b7614f93 --- /dev/null +++ b/src/ui/controls/button.cpp @@ -0,0 +1,33 @@ +#include "button.h" + +#include "graph/graph.h" + +namespace cru::ui::controls +{ + using graph::CreateSolidBrush; + + 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(); + } + + 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); + } + + void Button::OnMouseClickBegin(MouseButton button) + { + current_border_brush_ = pressed_border_brush_.Get(); + Repaint(); + } + + void Button::OnMouseClickEnd(MouseButton button) + { + current_border_brush_ = normal_border_brush_.Get(); + Repaint(); + } +} |