]> git.tdb.fi Git - libs/gui.git/blob - source/input/control.h
Rename ControlSrcType::NONE to NO_SOURCE
[libs/gui.git] / source / input / control.h
1 #ifndef MSP_INPUT_CONTROL_H_
2 #define MSP_INPUT_CONTROL_H_
3
4 #include <string>
5 #include <sigc++/signal.h>
6 #include <sigc++/trackable.h>
7
8 namespace Msp {
9 namespace Input {
10
11 class BinaryControl;
12 class Device;
13
14 enum ControlSrcType
15 {
16         NO_SOURCE,
17         BUTTON,
18         AXIS_POS,
19         AXIS_NEG
20 };
21
22 /**
23 Specifies the source of a control.  This provides a way for setting sources for
24 different types of controls in a uniform way.
25 */
26 struct ControlSource
27 {
28         Device *dev = 0;
29         ControlSrcType type = NO_SOURCE;
30         unsigned index = 0;
31
32         ControlSource() = default;
33         ControlSource(Device &, ControlSrcType, unsigned);
34         std::string str() const;
35 };
36
37 /**
38 Provides further abstraction on top of input devices.  There are two types of
39 controls currently defined: BinaryControl and SmoothControl.
40
41 A control uses either a button or half of an axis (positive or negative) as its
42 source.  How the source values are interpreted depends on the exact type of the
43 control.  Controls also support interactive binding by capturing a button press
44 or axis motion.
45
46 A BinaryControl can be used as an activator, requiring that control to be
47 active for any events to be processed.  This can be used to implement shifted
48 controls (when used on a BinaryControl) or click-and-drag functionality (when
49 used on a SmoothControl).
50 */
51 class Control: public sigc::trackable
52 {
53 public:
54         sigc::signal<void> signal_capture_complete;
55
56 protected:
57         ControlSource src;
58         Device *capture_dev = 0;
59         BinaryControl *activator = 0;
60         float origin = 0.0f;
61         bool rising_edge = false;
62         bool falling_edge = false;
63
64         Control() = default;
65         Control(const ControlSource &);
66         Control(Device &, ControlSrcType, unsigned);
67 public:
68         virtual ~Control();
69
70         void capture(Device &);
71         void cancel_capture();
72         void set_source(Device &, ControlSrcType, unsigned);
73         void set_source(const ControlSource &);
74         const ControlSource &get_source() const { return src; }
75         void set_activator(BinaryControl *);
76         BinaryControl *get_activator() const { return activator; }
77         bool has_rising_edge() const { return rising_edge; }
78         bool has_falling_edge() const { return falling_edge; }
79         void reset_edges();
80 protected:
81         virtual void on_press() = 0;
82         virtual void on_release() = 0;
83         virtual void on_motion(float, float) = 0;
84
85 private:
86         void connect_signals();
87         void button_press(unsigned);
88         void button_release(unsigned);
89         void axis_motion(unsigned, float, float);
90         void deactivate();
91
92         Control(const Control &);
93         Control &operator=(const Control &);
94 };
95
96 } // namespace Input
97 } // namespace Msp
98
99 #endif