aboutsummaryrefslogtreecommitdiff
path: root/CruUI/ui/controls
diff options
context:
space:
mode:
Diffstat (limited to 'CruUI/ui/controls')
-rw-r--r--CruUI/ui/controls/button.cpp33
-rw-r--r--CruUI/ui/controls/button.h36
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_;
+ };
+}