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.h | |
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.h')
-rw-r--r-- | src/ui/controls/button.h | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/src/ui/controls/button.h b/src/ui/controls/button.h new file mode 100644 index 00000000..bd3f6eb3 --- /dev/null +++ b/src/ui/controls/button.h @@ -0,0 +1,41 @@ +#pragma once + +#include <initializer_list> + +#include "ui/control.h" + +namespace cru::ui::controls +{ + class Button : public Control + { + public: + static Button* Create(const std::initializer_list<Control*>& children = std::initializer_list<Control*>()) + { + const auto button = new Button(); + for (const auto control : children) + button->AddChild(control); + return button; + } + + protected: + Button(); + + public: + Button(const Button& other) = delete; + Button(Button&& other) = delete; + Button& operator=(const Button& other) = delete; + Button& operator=(Button&& other) = delete; + ~Button() override = default; + + protected: + void OnDraw(ID2D1DeviceContext* device_context) override; + + void OnMouseClickBegin(MouseButton button) override final; + void OnMouseClickEnd(MouseButton button) override final; + + private: + Microsoft::WRL::ComPtr<ID2D1Brush> normal_border_brush_; + Microsoft::WRL::ComPtr<ID2D1Brush> pressed_border_brush_; + ID2D1Brush* current_border_brush_; + }; +} |