diff options
author | crupest <crupest@outlook.com> | 2020-01-01 22:52:01 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2020-01-01 22:52:01 +0800 |
commit | 36708e88596364e81dc9ba2fd3cbddbcaedeedc0 (patch) | |
tree | 0c7990b9e64c6ea1e9df7c01f3521c4fbf7ea2a0 /include/cru/ui/click_detector.hpp | |
parent | ae6f797561cdfa438ebef1fbbf94d784d315e655 (diff) | |
download | cru-36708e88596364e81dc9ba2fd3cbddbcaedeedc0.tar.gz cru-36708e88596364e81dc9ba2fd3cbddbcaedeedc0.tar.bz2 cru-36708e88596364e81dc9ba2fd3cbddbcaedeedc0.zip |
...
Diffstat (limited to 'include/cru/ui/click_detector.hpp')
-rw-r--r-- | include/cru/ui/click_detector.hpp | 35 |
1 files changed, 17 insertions, 18 deletions
diff --git a/include/cru/ui/click_detector.hpp b/include/cru/ui/click_detector.hpp index d5e4ac78..9b59c717 100644 --- a/include/cru/ui/click_detector.hpp +++ b/include/cru/ui/click_detector.hpp @@ -49,7 +49,17 @@ class ClickDetector : public Object { Control* GetControl() const { return control_; } + ClickState GetState() const { return state_; } + + // Default is enable. + bool IsEnabled() const { return enable_; } + // If disable when user is pressing, the pressing is deactivated. + void SetEnabled(bool enable); + + // Default is left and right. MouseButton GetTriggerButton() const { return trigger_button_; } + // If unset the trigger button when user is pressing, the pressing is + // deactivated. void SetTriggerButton(MouseButton trigger_button); IEvent<ClickEventArgs>* ClickEvent() { return &event_; } @@ -57,33 +67,22 @@ class ClickDetector : public Object { IEvent<ClickState>* StateChangeEvent() { return &state_change_event_; } private: - std::optional<Point>& FromButton(MouseButton button) { - switch (button) { - case MouseButton::Left: - return click_map_.left; - case MouseButton::Middle: - return click_map_.middle; - case MouseButton::Right: - return click_map_.right; - default: - UnreachableCode(); - } - } + void SetState(ClickState state); private: Control* control_; - MouseButton trigger_button_ = MouseButton::Left | MouseButton::Right; + ClickState state_; + + bool enable_ = true; + MouseButton trigger_button_ = mouse_buttons::left | mouse_buttons::right; Event<ClickEventArgs> event_; Event<ClickState> state_change_event_; std::vector<EventRevokerGuard> event_rovoker_guards_; - struct { - std::optional<Point> left = std::nullopt; - std::optional<Point> middle = std::nullopt; - std::optional<Point> right = std::nullopt; - } click_map_; + Point down_point_; + MouseButton button_; }; } // namespace cru::ui |