aboutsummaryrefslogtreecommitdiff
path: root/src/ui/controls/toggle_button.h
diff options
context:
space:
mode:
authorYuqian Yang <crupest@outlook.com>2018-09-25 05:30:01 +0000
committerYuqian Yang <crupest@outlook.com>2018-09-25 05:30:01 +0000
commitea4b0966d8eb5a8e76dfbe4d833a07a4797a3284 (patch)
treee5918c686f27363bfacf7d47e4b93617872b908d /src/ui/controls/toggle_button.h
parent001e1d955132a02a2f7effc841ab9e5ee425eda1 (diff)
parent03d078796ad31eb55d70ad0aa61254b301e989a6 (diff)
downloadcru-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/toggle_button.h')
-rw-r--r--src/ui/controls/toggle_button.h61
1 files changed, 61 insertions, 0 deletions
diff --git a/src/ui/controls/toggle_button.h b/src/ui/controls/toggle_button.h
new file mode 100644
index 00000000..d496f21a
--- /dev/null
+++ b/src/ui/controls/toggle_button.h
@@ -0,0 +1,61 @@
+#pragma once
+
+#include "ui/control.h"
+
+namespace cru::ui::controls
+{
+ class ToggleButton : public Control
+ {
+ public:
+ static ToggleButton* Create()
+ {
+ return new ToggleButton();
+ }
+
+ protected:
+ ToggleButton();
+
+ public:
+ ToggleButton(const ToggleButton& other) = delete;
+ ToggleButton(ToggleButton&& other) = delete;
+ ToggleButton& operator=(const ToggleButton& other) = delete;
+ ToggleButton& operator=(ToggleButton&& other) = delete;
+ ~ToggleButton() override = default;
+
+ bool IsPointInside(const Point& point) override;
+
+ bool GetState() const
+ {
+ return state_;
+ }
+
+ void SetState(bool state);
+
+ void Toggle();
+
+ public:
+ events::ToggleEvent toggle_event;
+
+ protected:
+ virtual void OnToggle(events::ToggleEventArgs& args);
+
+ protected:
+ void OnDraw(ID2D1DeviceContext* device_context) override;
+
+ void OnMouseClickCore(events::MouseButtonEventArgs& args) override;
+
+ Size OnMeasure(const Size& available_size) override;
+
+ private:
+ void RaiseToggleEvent(bool new_state);
+
+ private:
+ bool state_ = false;
+
+ float current_circle_position_;
+
+ Microsoft::WRL::ComPtr<ID2D1RoundedRectangleGeometry> frame_path_;
+ Microsoft::WRL::ComPtr<ID2D1Brush> on_brush_;
+ Microsoft::WRL::ComPtr<ID2D1Brush> off_brush_;
+ };
+}