~3v1n0/nux/x11-conffile-on-unity-only

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
/*
 * Copyright 2012 Canonical Ltd.
 *
 * This program is free software: you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License, as
 * published by the  Free Software Foundation; either version 2.1 or 3.0
 * of the License.
 *
 * This program is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranties of
 * MERCHANTABILITY, SATISFACTORY QUALITY or FITNESS FOR A PARTICULAR
 * PURPOSE.  See the applicable version of the GNU Lesser General Public
 * License for more details.
 *
 * You should have received a copy of both the GNU Lesser General Public
 * License along with this program. If not, see <http://www.gnu.org/licenses/>
 *
 * Authored by: Daniel d'Andrada <daniel.dandrada@canonical.com>
 *
 */

#ifndef NUX_GESTURES_SUBSCRIPTION_H
#define NUX_GESTURES_SUBSCRIPTION_H
#include "Nux/Features.h"
#ifdef NUX_GESTURES_SUPPORT

#include <geis/geis.h>
#include <memory>

// For the GestureClass enumeration.
#include "NuxGraphics/GestureEvent.h"

namespace nux
{
  //! Represents a subscription to multitouch gestures
  /*!
    Typical usage:
      GesturesSubscription *subscription = new GesturesSubscription;
      subscription->SetGestureClass(TAP_GESTURE);
      subscription->SetNumTouches(2);
      subscription->Activate();
   */
  /*
    Wraps all the complexity involved in directly manipulating a GeisSubscription
    and exposes a simpler, C++, API.
   */
  class GesturesSubscription
  {
    public:
      //! Creates a new, inactive, gestures subscription
      GesturesSubscription();

      //! Destroys this gestures subscription.
      virtual ~GesturesSubscription();

      //! Activates the subscription
      void Activate();

      //! Deactivates the subscription
      void Deactivate();

      //! Returns whether the subscription is active
      /*!
        Nux only get gesture events that matches active subscriptions.

        Subscriptions are inactive by default.
       */
      bool IsActive() const {return is_active_;}

      //! Sets the classes of gestures this subscription is interested on
      void SetGestureClasses(int gesture_classes);

      //! Returns the gesture class that this subscription is interested on
      /*!
        By default it's set to DRAG_GESTURE|PINCH_GESTURE|ROTATE_GESTURE
       */
      int GetGestureClasses() const {return gesture_classes_;}

      //! The subscription will be interested in gestures with the given number of touches
      void SetNumTouches(unsigned int num_touches);

      //! Returns the number of touches that this subscription is interested on
      /*!
        By default it is set to two touches.
       */
      unsigned int GetNumTouches() const {return num_touches_;}

      //! Specifies the native window from which touch events will be gathered
      /*!
        See also GetWindowId()
       */
      void SetWindowId(int window_id);

      //! Returns the native window id from which touch events are gathered.
      /*!
        By default this is the same native window that Nux uses for rendering.
        But in cases they differ you should speficy the native window that will
        provide the touch events with SetWindowId().
       */
      int GetWindowId() const {return window_id_;}

      //! Sets the recognition threshold for a given gesture class
      /*!
        For the pinch gesture class, the threshold is the current
        radius divided by the initial radius and should be bigger than one.
        Its default value is 1.1.

        For the drag gesture class, the threshold is in meters and represents
        the minimum amount of movement required for a drag to be recognized.
        Its default value is 0.0026

        For the tap gesture class, the threshold is in meters and represents
        the maximum amount of movement allowed for a tap to be recognized.
        Its default value is 0.0026

        For the rotate gesture class, the threshold is in radians and represents
        the mimimum amout of rotation required for a rotation gesture to be
        recognized. Its default value is (2*PI)/50.

        It has no effect or meaning for the touch gesture class.
       */
      void SetRecognitionThreshold(GestureClass gesture_class, float threshold);

      //! Sets the recognition timeout for a given gesture class
      /*!
        The timeout is in milliseconds.
        Setting 0 (zero) means that the recognition never times out.

        The default timeout for drag, pinch and rotate gesture classes is 0 (zero).
        Fot taps it's 300.

        It has no effect or meaning for the touch gesture class.
       */
      void SetRecognitionTimeout(GestureClass gesture_class, int timeout);

      //! Returns whether the gesture from the given event matches this subscription
      bool MatchesGesture(const GestureEvent &event) const;

    private:
      std::vector<const char *> CreateGeisGestureClasses();
      GeisStatus AddGestureClassAndNumTouchesTerm(GeisFilter filter);
      void CreateGeisSubscription();
      void CreateGeisSubscriptionWhenPossible();
      void UpdateGeisSubscription();
      void ConfigureGeisSubscription();

      template<typename T>
      void SetProperty(T& prop, T new_value)
      {
        if (prop == new_value)
          return;

        prop = new_value;

        if (sub_)
          UpdateGeisSubscription();
      }

      int gesture_classes_;
      int unwanted_gesture_classes_;
      unsigned int num_touches_;
      int window_id_;
      GeisSubscription sub_;
      bool is_active_;

      float drag_threshold_;
      int drag_timeout_;
      float pinch_threshold_;
      int pinch_timeout_;
      float rotate_threshold_;
      int rotate_timeout_;
      float tap_threshold_;
      int tap_timeout_;
  };

  typedef std::shared_ptr<GesturesSubscription> ShGesturesSubscription;

} // namespace nux

#endif // NUX_GESTURES_SUPPORT
#endif // NUX_GESTURES_SUBSCRIPTION_H