diff options
Diffstat (limited to 'CruUI/ui/controls')
-rw-r--r-- | CruUI/ui/controls/button.cpp | 33 | ||||
-rw-r--r-- | CruUI/ui/controls/button.h | 36 |
2 files changed, 69 insertions, 0 deletions
diff --git a/CruUI/ui/controls/button.cpp b/CruUI/ui/controls/button.cpp new file mode 100644 index 00000000..b7614f93 --- /dev/null +++ b/CruUI/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(); + } +} 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_; + }; +} |