/usr/include/Nux-4.0/NuxGraphics/GestureEvent.h is in libnux-4.0-dev 4.0.6+14.04.20140409-0ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | /*
* 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_GESTURE_EVENT_H
#define NUX_GESTURE_EVENT_H
#include "Nux/Features.h"
#ifdef NUX_GESTURES_SUPPORT
#include <geis/geis.h>
#include <vector>
#include "Events.h"
#include "NuxCore/Math/Point2D.h"
namespace nux
{
//! Enumerates all possible gesture classes.
enum GestureClass
{
DRAG_GESTURE = 1, //! A drag gesture
PINCH_GESTURE = 2, //! A pinch gesture
ROTATE_GESTURE = 4, //! A rotation gesture
TAP_GESTURE = 8, //! A tap gesture.
TOUCH_GESTURE = 16 /*! A touch gesture. It merely groups two or more touch
points and send their information, without interpreting
what gestures the touch points are performing. */
};
class TouchPoint
{
public:
TouchPoint() : id(-1), x(0.0f), y(0.0f) {}
TouchPoint(int id, float x, float y) : id(id), x(x), y(y) {}
bool operator ==(const TouchPoint& other) const
{
return id == other.id;
}
int id;
float x;
float y;
};
//! Gesture Event class
class GestureEvent : public Event
{
public:
//! Constructs a GestureEvent
GestureEvent();
//! Accepts the gesture.
void Accept();
//! Rejects the gesture.
void Reject();
//! The gesture classes that this gesture belongs to.
/*!
A bitwise "or" of one or more gesture classes from
GestureClass enumeration.
A single physical gesture can comply/belong to more than
one gesture class, such as a rotating pinch.
*/
int GetGestureClasses() const {return gesture_classes_;}
//! Whether all gestures for the related touch points have been presented.
/*!
This property allows the client to determine if all the possible gestures
from the set of touches in this event have already been presented. When
this value is true, the client will have received all the information needed
to make a gesture accept and reject decision based on potentially
overlapping gestures. An example is when both one and two touch gestures are
subscribed on the same window with the same gesture classes and thresholds.
When this property is true for one touch gesture events, the client can be
sure there are no other touches unless a two touch gesture event has already
been sent.
Another example is when you subscribe for three touches Touch and four
touches Drag. As soon as a third finger is detected a three touches Touch
gesture will begin, but you cannot be sure a fourth finger isn't coming
right after (that can eventually cause a four touches Drag) until this
property is true.
*/
bool IsConstructionFinished() const { return is_construction_finished_;}
int GetGestureId() const {return gesture_id_;}
bool IsDirectTouch() const {return is_direct_touch_;}
int GetTimestamp() const {return timestamp_;}
const Point2D<float> &GetFocus() const {return focus_;}
const Point2D<float> &GetDelta() const {return delta_;}
float GetAngle() const {return angle_;}
float GetAngleDelta() const {return angle_delta_;}
float GetAngularVelocity() const {return angular_velocity_;}
//! Duration of a tap gesture, in milliseconds
int GetTapDuration() const {return tap_duration_;}
const Point2D<float> &GetVelocity() {return velocity_;}
float GetRadius() const {return radius_;}
float GetRadiusDelta() const {return radius_delta_;}
float GetRadialVelocity() const {return radial_velocity_;}
const std::vector<TouchPoint> &GetTouches() const {return touches_;}
virtual void Reset();
private:
int gesture_id_;
int gesture_classes_;
bool is_direct_touch_;
int timestamp_;
Point2D<float> focus_;
Point2D<float> delta_;
float angle_;
float angle_delta_;
float angular_velocity_;
int tap_duration_;
Point2D<float> velocity_;
float radius_;
float radius_delta_;
float radial_velocity_;
std::vector<TouchPoint> touches_;
bool is_construction_finished_;
Geis geis_;
GeisGroup geis_group_;
friend class GeisAdapter;
friend class FakeGestureEvent;
};
//! Enumerates possible requests regarding delivery of gesture events.
enum class GestureDeliveryRequest
{
NONE, /*!< No request. Continue with current delivery policy. */
EXCLUSIVITY /*!< From this moment onwards, deliver events from the related
gesture only to this target. Other targets for this gesture
will receive an event of type EVENT_GESTURE_LOST instead of
this event.
Note that it doesn't affect targets that come before this
one in the order of delivery. */
};
} // namespace nux
#endif // NUX_GESTURES_SUPPORT
#endif // NUX_GESTURE_EVENT_H
|