diff options
author | crupest <crupest@outlook.com> | 2018-09-22 00:17:53 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2018-09-22 00:17:53 +0800 |
commit | e01800206050a0ed88cc4f4456fa3590021ab66f (patch) | |
tree | aaa6118d614ead6cd1865e4b2d160cade91d8057 /CruUI/ui/controls/button.h | |
parent | 89f7277d47cd37f25a141ec2ebc13c4f6fceabd5 (diff) | |
download | cru-e01800206050a0ed88cc4f4456fa3590021ab66f.tar.gz cru-e01800206050a0ed88cc4f4456fa3590021ab66f.tar.bz2 cru-e01800206050a0ed88cc4f4456fa3590021ab66f.zip |
Add button.
Diffstat (limited to 'CruUI/ui/controls/button.h')
-rw-r--r-- | CruUI/ui/controls/button.h | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/CruUI/ui/controls/button.h b/CruUI/ui/controls/button.h new file mode 100644 index 00000000..f9ad7726 --- /dev/null +++ b/CruUI/ui/controls/button.h @@ -0,0 +1,36 @@ +#pragma once + +#include "ui/control.h" + +namespace cru::ui::controls +{ + class Button : public Control + { + public: + static Button* Create() + { + return new 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_; + }; +} |