| Top |  |  |  |  | 
| #define | CLUTTER_CURRENT_TIME | 
| #define | CLUTTER_PRIORITY_EVENTS | 
| #define | CLUTTER_EVENT_PROPAGATE | 
| #define | CLUTTER_EVENT_STOP | 
| enum | ClutterModifierType | 
| enum | ClutterScrollDirection | 
| enum | ClutterScrollFinishFlags | 
| enum | ClutterScrollSource | 
| enum | ClutterStageState | 
| enum | ClutterEventType | 
| ClutterEvent | |
| enum | ClutterEventFlags | 
| struct | ClutterButtonEvent | 
| struct | ClutterKeyEvent | 
| struct | ClutterMotionEvent | 
| struct | ClutterScrollEvent | 
| struct | ClutterStageStateEvent | 
| struct | ClutterCrossingEvent | 
| struct | ClutterTouchEvent | 
| ClutterEventSequence | |
| struct | ClutterTouchpadPinchEvent | 
| struct | ClutterTouchpadSwipeEvent | 
| enum | ClutterTouchpadGesturePhase | 
| #define | CLUTTER_BUTTON_PRIMARY | 
| #define | CLUTTER_BUTTON_MIDDLE | 
| #define | CLUTTER_BUTTON_SECONDARY | 
Windowing events handled by Clutter.
The events usually come from the windowing backend, but can also be synthesized by Clutter itself or by the application code.
ClutterEvent *
clutter_event_new (ClutterEventType type);
Creates a new ClutterEvent of the specified type.
void
clutter_event_free (ClutterEvent *event);
Frees all resources used by event
.
ClutterEventType
clutter_event_type (const ClutterEvent *event);
Retrieves the type of the event.
void clutter_event_set_coords (ClutterEvent *event,gfloat x,gfloat y);
Sets the coordinates of the event
.
Since: 1.8
void clutter_event_get_coords (const ClutterEvent *event,gfloat *x,gfloat *y);
Retrieves the coordinates of event
 and puts them into x
 and y
.
Since: 0.4
void clutter_event_set_state (ClutterEvent *event,ClutterModifierType state);
Sets the modifier state of the event.
Since: 1.8
ClutterModifierType
clutter_event_get_state (const ClutterEvent *event);
Retrieves the modifier state of the event. In case the window system supports reporting latched and locked modifiers, this function returns the effective state.
Since: 0.4
void clutter_event_get_state_full (const ClutterEvent *event,ClutterModifierType *button_state,ClutterModifierType *base_state,ClutterModifierType *latched_state,ClutterModifierType *locked_state,ClutterModifierType *effective_state);
Retrieves the decomposition of the keyboard state into button, base, latched, locked and effective. This can be used to transmit to other applications, for example when implementing a wayland compositor.
| event | ||
| button_state | the pressed buttons as a mask. | [out][allow-none] | 
| base_state | the regular pressed modifier keys. | [out][allow-none] | 
| latched_state | the latched modifier keys (currently released but still valid for one key press/release). | [out][allow-none] | 
| locked_state | the locked modifier keys (valid until the lock key is pressed and released again). | [out][allow-none] | 
| effective_state | the logical OR of all the state bits above. | [out][allow-none] | 
Since: 1.16
void clutter_event_set_time (ClutterEvent *event,guint32 time_);
Sets the time of the event.
Since: 1.8
guint32
clutter_event_get_time (const ClutterEvent *event);
Retrieves the time of the event.
Since: 0.4
void clutter_event_set_source (ClutterEvent *event,ClutterActor *actor);
Sets the source ClutterActor of event
.
Since: 1.8
ClutterActor *
clutter_event_get_source (const ClutterEvent *event);
Retrieves the source ClutterActor the event originated from, or NULL if the event has no source.
Since: 0.6
void clutter_event_set_stage (ClutterEvent *event,ClutterStage *stage);
Sets the source ClutterStage of the event.
Since: 1.8
ClutterStage *
clutter_event_get_stage (const ClutterEvent *event);
Retrieves the source ClutterStage the event originated for, or
NULL if the event has no stage.
Since: 0.8
void clutter_event_set_flags (ClutterEvent *event,ClutterEventFlags flags);
Sets the ClutterEventFlags of event
Since: 1.8
ClutterEventFlags
clutter_event_get_flags (const ClutterEvent *event);
Retrieves the ClutterEventFlags of event
Since: 1.0
gdouble * clutter_event_get_axes (const ClutterEvent *event,guint *n_axes);
Retrieves the array of axes values attached to the event.
Since: 1.6
ClutterEventSequence *
clutter_event_get_event_sequence (const ClutterEvent *event);
Retrieves the ClutterEventSequence of event
.
| event | a ClutterEvent of type  | 
Since: 1.10
double clutter_event_get_angle (const ClutterEvent *source,const ClutterEvent *target);
Retrieves the angle relative from source
 to target
.
The direction of the angle is from the position X axis towards the positive Y axis.
Since: 1.12
float clutter_event_get_distance (const ClutterEvent *source,const ClutterEvent *target);
Retrieves the distance between two events, a source
 and a target
.
Since: 1.12
void clutter_event_get_position (const ClutterEvent *event,ClutterPoint *position);
Retrieves the event coordinates as a ClutterPoint.
Since: 1.12
gboolean
clutter_event_has_control_modifier (const ClutterEvent *event);
Checks whether event
 has the Control modifier mask set.
Since: 1.12
gboolean
clutter_event_has_shift_modifier (const ClutterEvent *event);
Checks whether event
 has the Shift modifier mask set.
Since: 1.12
gboolean
clutter_event_is_pointer_emulated (const ClutterEvent *event);
Checks whether a pointer event
 has been generated by the windowing
system. The returned value can be used to distinguish between events
synthesized by the windowing system itself (as opposed by Clutter).
Since: 1.12
guint
clutter_event_get_gesture_swipe_finger_count
                               (const ClutterEvent *event);
Returns the number of fingers that is triggering the touchpad gesture.
Since: 1.24
gdouble
clutter_event_get_gesture_pinch_angle_delta
                               (const ClutterEvent *event);
Returns the angle delta reported by this specific event.
Since: 1.24
gdouble
clutter_event_get_gesture_pinch_scale (const ClutterEvent *event);
Returns the current scale as reported by event
, 1.0 being the original
distance at the time the corresponding event with phase
CLUTTER_TOUCHPAD_GESTURE_PHASE_BEGIN is received.
is received.
Since: 1.24
ClutterTouchpadGesturePhase
clutter_event_get_gesture_phase (const ClutterEvent *event);
Returns the phase of the event, See ClutterTouchpadGesturePhase.
void clutter_event_get_gesture_motion_delta (const ClutterEvent *event,gdouble *dx,gdouble *dy);
Returns the gesture motion deltas relative to the current pointer position.
Since: 1.24
ClutterScrollSource
clutter_event_get_scroll_source (const ClutterEvent *event);
Returns the ClutterScrollSource that applies to an scroll event.
Since: 1.26
ClutterScrollFinishFlags
clutter_event_get_scroll_finish_flags (const ClutterEvent *event);
Returns the ClutterScrollFinishFlags of an scroll event. Those can be used to determine whether post-scroll effects like kinetic scrolling should be applied.
Since: 1.26
ClutterEvent *
clutter_event_get (void);
Pops an event off the event queue. Applications should not need to call this.
Since: 0.4
ClutterEvent *
clutter_event_peek (void);
Returns a pointer to the first event from the event queue but does not remove it.
Since: 0.4
void
clutter_event_put (const ClutterEvent *event);
Puts a copy of the event on the back of the event queue. The event will
have the CLUTTER_EVENT_FLAG_SYNTHETIC flag set. If the source is set
event signals will be emitted for this source and capture/bubbling for
its ancestors. If the source is not set it will be generated by picking
or use the actor that currently has keyboard focus
Since: 0.6
gboolean
clutter_events_pending (void);
Checks if events are pending in the event queue.
Since: 0.4
gboolean (*ClutterEventFilterFunc) (const ClutterEvent *event,gpointer user_data);
A function pointer type used by event filters that are added with
clutter_event_add_filter().
| event | the event that is going to be emitted | |
| user_data | the data pointer passed to  | 
 CLUTTER_EVENT_STOP to indicate that the event
has been handled or CLUTTER_EVENT_PROPAGATE otherwise.
Returning CLUTTER_EVENT_STOP skips any further filter
functions and prevents the signal emission for the event.
Since: 1.18
guint clutter_event_add_filter (ClutterStage *stage,ClutterEventFilterFunc func,GDestroyNotify notify,gpointer user_data);
Adds a function which will be called for all events that Clutter processes. The function will be called before any signals are emitted for the event and it will take precedence over any grabs.
| stage | The ClutterStage to capture events for. | [allow-none] | 
| func | The callback function which will be passed all events. | |
| notify | ||
| user_data | A data pointer to pass to the function. | 
Since: 1.18
void
clutter_event_remove_filter (guint id);
Removes an event filter that was previously added with
clutter_event_add_filter().
Since: 1.18
void clutter_event_set_button (ClutterEvent *event,guint32 button);
Sets the button number of event
| event | a ClutterEvent or type  | |
| button | the button number | 
Since: 1.8
guint32
clutter_event_get_button (const ClutterEvent *event);
Retrieves the button number of event
Since: 1.0
guint
clutter_event_get_click_count (const ClutterEvent *event);
Retrieves the number of clicks of event
Since: 1.0
void clutter_event_set_key_symbol (ClutterEvent *event,guint key_sym);
Sets the key symbol of event
.
| event | a ClutterEvent of type  | |
| key_sym | the key symbol representing the key | 
Since: 1.8
guint
clutter_event_get_key_symbol (const ClutterEvent *event);
Retrieves the key symbol of event
Since: 1.0
void clutter_event_set_key_code (ClutterEvent *event,guint16 key_code);
Sets the keycode of the event
.
| event | a ClutterEvent of type  | |
| key_code | the keycode representing the key | 
Since: 1.8
guint16
clutter_event_get_key_code (const ClutterEvent *event);
Retrieves the keycode of the key that caused event
Since: 1.0
void clutter_event_set_key_unicode (ClutterEvent *event,gunichar key_unicode);
Sets the Unicode value of event
.
| event | a ClutterEvent of type  | |
| key_unicode | the Unicode value representing the key | 
Since: 1.8
gunichar
clutter_event_get_key_unicode (const ClutterEvent *event);
Retrieves the unicode value for the key that caused keyev
.
guint32
clutter_keysym_to_unicode (guint keyval);
Converts keyval
 from a Clutter key symbol to the corresponding
ISO10646 (Unicode) character.
guint
clutter_unicode_to_keysym (guint32 wc);
Convert from a ISO10646 character to a key symbol.
the corresponding Clutter key symbol, if one exists. or, if there is no corresponding symbol, wc | 0x01000000
Since: 1.10
void clutter_event_set_related (ClutterEvent *event,ClutterActor *actor);
Sets the related actor of a crossing event
| event | a ClutterEvent of type  | |
| actor | a ClutterActor or  | [allow-none] | 
Since: 1.8
ClutterActor *
clutter_event_get_related (const ClutterEvent *event);
Retrieves the related actor of a crossing event.
Since: 1.0
void clutter_event_set_scroll_direction (ClutterEvent *event,ClutterScrollDirection direction);
Sets the direction of the scrolling of event
Since: 1.8
ClutterScrollDirection
clutter_event_get_scroll_direction (const ClutterEvent *event);
Retrieves the direction of the scrolling of event
Since: 1.0
void clutter_event_get_scroll_delta (const ClutterEvent *event,gdouble *dx,gdouble *dy);
Retrieves the precise scrolling information of event
.
The event
 has to have a ClutterScrollEvent.direction value
of CLUTTER_SCROLL_SMOOTH.
| event | a ClutterEvent of type  | |
| dx | return location for the delta on the horizontal axis. | [out] | 
| dy | return location for the delta on the vertical axis. | [out] | 
Since: 1.10
void clutter_event_set_scroll_delta (ClutterEvent *event,gdouble dx,gdouble dy);
Sets the precise scrolling information of event
.
| event | a ClutterEvent of type  | |
| dx | delta on the horizontal axis | |
| dy | delta on the vertical axis | 
Since: 1.10
void clutter_event_set_device (ClutterEvent *event,ClutterInputDevice *device);
Sets the device for event
.
Since: 1.6
ClutterInputDevice *
clutter_event_get_device (const ClutterEvent *event);
Retrieves the ClutterInputDevice for the event.
If you want the physical device the event originated from, use
clutter_event_get_source_device().
The ClutterInputDevice structure is completely opaque and should be cast to the platform-specific implementation.
the ClutterInputDevice or NULL. The
returned device is owned by the ClutterEvent and it should not
be unreferenced. 
[transfer none]
Since: 1.0
void clutter_event_set_source_device (ClutterEvent *event,ClutterInputDevice *device);
Sets the source ClutterInputDevice for event
.
The ClutterEvent must have been created using clutter_event_new().
Since: 1.8
ClutterInputDevice *
clutter_event_get_source_device (const ClutterEvent *event);
Retrieves the hardware device that originated the event.
If you need the virtual device, use clutter_event_get_device().
If no hardware device originated this event, this function will
return the same device as clutter_event_get_device().
Since: 1.6
gint
clutter_event_get_device_id (const ClutterEvent *event);
Retrieves the events device id if set.
ClutterInputDeviceType
clutter_event_get_device_type (const ClutterEvent *event);
Retrieves the type of the device for event
Since: 1.0
guint32
clutter_get_current_event_time (void);
Retrieves the timestamp of the last event, if there is an event or if the event has a timestamp.
Since: 1.0
const ClutterEvent *
clutter_get_current_event (void);
If an event is currently being processed, return that event. This function is intended to be used to access event state that might not be exposed by higher-level widgets. For example, to get the key modifier state from a Button 'clicked' event.
Since: 1.2
#define CLUTTER_PRIORITY_EVENTS (G_PRIORITY_DEFAULT)
Priority for event handling.
Since: 0.4
#define CLUTTER_EVENT_PROPAGATE (FALSE)
Continues the propagation of an event; this macro should be used in event-related signals.
Since: 1.10
#define CLUTTER_EVENT_STOP (TRUE)
Stops the propagation of an event; this macro should be used in event-related signals.
Since: 1.10
Masks applied to a ClutterEvent by modifiers.
Note that Clutter may add internal values to events which include
reserved values such as CLUTTER_MODIFIER_RESERVED_13_MASK.  Your code
should preserve and ignore them.  You can use CLUTTER_MODIFIER_MASK to
remove all reserved values.
| Mask applied by the Shift key | ||
| Mask applied by the Caps Lock key | ||
| Mask applied by the Control key | ||
| Mask applied by the first Mod key | ||
| Mask applied by the second Mod key | ||
| Mask applied by the third Mod key | ||
| Mask applied by the fourth Mod key | ||
| Mask applied by the fifth Mod key | ||
| Mask applied by the first pointer button | ||
| Mask applied by the second pointer button | ||
| Mask applied by the third pointer button | ||
| Mask applied by the fourth pointer button | ||
| Mask applied by the fifth pointer button | ||
| Mask applied by the Super key | ||
| Mask applied by the Hyper key | ||
| Mask applied by the Meta key | ||
| Mask applied during release | ||
| A mask covering all modifier types | 
Since: 0.4
Direction of a pointer scroll event.
The CLUTTER_SCROLL_SMOOTH value implies that the ClutterScrollEvent
has precise scrolling delta information.
Since: 0.4
Flags used to notify the axes that were stopped in a ClutterScrollEvent. These can be used to trigger post-scroll effects like kinetic scrolling.
Since: 1.26
The scroll source determines the source of the scroll event. Keep in mind that the source device ClutterInputDeviceType is not enough to infer the scroll source.
| Source of scroll events is unknown. | ||
| The scroll event is originated by a mouse wheel. | ||
| The scroll event is originated by one or more fingers on the device (eg. touchpads). | ||
| The scroll event is originated by the motion of some device (eg. a scroll button is set). | 
Since: 1.26
Stage state masks, used by the ClutterEvent of type CLUTTER_STAGE_STATE.
Since: 0.4
Types of events.
| Empty event | ||
| Key press event | ||
| Key release event | ||
| Pointer motion event | ||
| Actor enter event | ||
| Actor leave event | ||
| Pointer button press event | ||
| Pointer button release event | ||
| Pointer scroll event | ||
| Stage state change event | ||
| Destroy notification event | ||
| Client message event | ||
| Stage delete event | ||
| A new touch event sequence has started; event added in 1.10 | ||
| A touch event sequence has been updated; event added in 1.10 | ||
| A touch event sequence has finished; event added in 1.10 | ||
| A touch event sequence has been canceled; event added in 1.10 | ||
| A pinch gesture event, the current state is determined by its phase field; event added in 1.24 | ||
| A swipe gesture event, the current state is determined by its phase field; event added in 1.24 | ||
| Marks the end of the ClutterEventType enumeration; added in 1.10 | 
Since: 0.4
struct ClutterButtonEvent {
  ClutterEventType type;
  guint32 time;
  ClutterEventFlags flags;
  ClutterStage *stage;
  ClutterActor *source;
  gfloat x;
  gfloat y;
  ClutterModifierType modifier_state;
  guint32 button;
  guint click_count;
  gdouble *axes; /* Future use */
  ClutterInputDevice *device;
};
Button event.
The event coordinates are relative to the stage that received the
event, and can be transformed into actor-relative coordinates by
using clutter_actor_transform_stage_point().
| ClutterEventType  | event type | |
| guint32  | event time | |
| ClutterEventFlags  | event flags | |
| ClutterStage * | event source stage | |
| ClutterActor * | event source actor | |
| gfloat  | event X coordinate, relative to the stage | |
| gfloat  | event Y coordinate, relative to the stage | |
| ClutterModifierType  | button modifiers | |
| guint32  | event button | |
| guint  | number of button presses within the default time and radius | |
| gdouble * | reserved for future use | |
| ClutterInputDevice * | the device that originated the event. If you want the physical
device the event originated from, use  | 
Since: 0.2
struct ClutterKeyEvent {
  ClutterEventType type;
  guint32 time;
  ClutterEventFlags flags;
  ClutterStage *stage;
  ClutterActor *source;
  ClutterModifierType modifier_state;
  guint keyval;
  guint16 hardware_keycode;
  gunichar unicode_value;
  ClutterInputDevice *device;
};
Key event
| ClutterEventType  | event type | |
| guint32  | event time | |
| ClutterEventFlags  | event flags | |
| ClutterStage * | event source stage | |
| ClutterActor * | event source actor | |
| ClutterModifierType  | key modifiers | |
| guint  | raw key value | |
| guint16  | raw hardware key value | |
| gunichar  | Unicode representation | |
| ClutterInputDevice * | the device that originated the event. If you want the physical
device the event originated from, use  | 
Since: 0.2
struct ClutterMotionEvent {
  ClutterEventType type;
  guint32 time;
  ClutterEventFlags flags;
  ClutterStage *stage;
  ClutterActor *source;
  gfloat x;
  gfloat y;
  ClutterModifierType modifier_state;
  gdouble *axes; /* Future use */
  ClutterInputDevice *device;
};
Event for the pointer motion
| ClutterEventType  | event type | |
| guint32  | event time | |
| ClutterEventFlags  | event flags | |
| ClutterStage * | event source stage | |
| ClutterActor * | event source actor | |
| gfloat  | event X coordinate | |
| gfloat  | event Y coordinate | |
| ClutterModifierType  | button modifiers | |
| gdouble * | reserved for future use | |
| ClutterInputDevice * | the device that originated the event. If you want the physical
device the event originated from, use  | 
Since: 0.2
struct ClutterScrollEvent {
  ClutterEventType type;
  guint32 time;
  ClutterEventFlags flags;
  ClutterStage *stage;
  ClutterActor *source;
  gfloat x;
  gfloat y;
  ClutterScrollDirection direction;
  ClutterModifierType modifier_state;
  gdouble *axes; /* future use */
  ClutterInputDevice *device;
  ClutterScrollSource scroll_source;
  ClutterScrollFinishFlags finish_flags;
};
Scroll wheel (or similar device) event
| ClutterEventType  | event type | |
| guint32  | event time | |
| ClutterEventFlags  | event flags | |
| ClutterStage * | event source stage | |
| ClutterActor * | event source actor | |
| gfloat  | event X coordinate | |
| gfloat  | event Y coordinate | |
| ClutterScrollDirection  | direction of the scrolling | |
| ClutterModifierType  | button modifiers | |
| gdouble * | reserved for future use | |
| ClutterInputDevice * | the device that originated the event. If you want the physical
device the event originated from, use  | |
| ClutterScrollSource  | the source of scroll events. This field is available since 1.26 | |
| ClutterScrollFinishFlags  | the axes that were stopped in this event. This field is available since 1.26 | 
Since: 0.2
struct ClutterStageStateEvent {
  ClutterEventType type;
  guint32 time;
  ClutterEventFlags flags;
  ClutterStage *stage;
  ClutterActor *source; /* XXX: should probably be the stage itself */
  ClutterStageState changed_mask;
  ClutterStageState new_state;
};
Event signalling a change in the ClutterStage state.
| ClutterEventType  | event type | |
| guint32  | event time | |
| ClutterEventFlags  | event flags | |
| ClutterStage * | event source stage | |
| ClutterActor * | event source actor (unused) | |
| ClutterStageState  | bitwise OR of the changed flags | |
| ClutterStageState  | bitwise OR of the current state flags | 
Since: 0.2
struct ClutterCrossingEvent {
  ClutterEventType type;
  guint32 time;
  ClutterEventFlags flags;
  ClutterStage *stage;
  ClutterActor *source;
  gfloat x;
  gfloat y;
  ClutterInputDevice *device;
  ClutterActor *related;
};
Event for the movement of the pointer across different actors
| ClutterEventType  | event type | |
| guint32  | event time | |
| ClutterEventFlags  | event flags | |
| ClutterStage * | event source stage | |
| ClutterActor * | event source actor | |
| gfloat  | event X coordinate | |
| gfloat  | event Y coordinate | |
| ClutterInputDevice * | the device that originated the event. If you want the physical
device the event originated from, use  | |
| ClutterActor * | actor related to the crossing | 
Since: 0.2
struct ClutterTouchEvent {
  ClutterEventType type;
  guint32 time;
  ClutterEventFlags flags;
  ClutterStage *stage;
  ClutterActor *source;
  gfloat x;
  gfloat y;
  ClutterEventSequence *sequence;
  ClutterModifierType modifier_state;
  gdouble *axes; /* reserved */
  ClutterInputDevice *device;
};
Used for touch events.
The type
 field will be one of CLUTTER_TOUCH_BEGIN, CLUTTER_TOUCH_END,
CLUTTER_TOUCH_UPDATE, or CLUTTER_TOUCH_CANCEL.
Touch events are grouped into sequences; each touch sequence will begin
with a CLUTTER_TOUCH_BEGIN event, progress with CLUTTER_TOUCH_UPDATE
events, and end either with a CLUTTER_TOUCH_END event or with a
CLUTTER_TOUCH_CANCEL event.
With multi-touch capable devices there can be multiple event sequence running at the same time.
| ClutterEventType  | event type | |
| guint32  | event time | |
| ClutterEventFlags  | event flags | |
| ClutterStage * | event source stage | |
| ClutterActor * | event source actor (unused) | |
| gfloat  | the X coordinate of the pointer, relative to the stage | |
| gfloat  | the Y coordinate of the pointer, relative to the stage | |
| ClutterEventSequence * | the event sequence that this event belongs to | |
| ClutterModifierType  | a bit-mask representing the state of modifier keys (e.g. Control, Shift, and Alt) and the pointer buttons. See ClutterModifierType. | [type ClutterModifierType] | 
| gdouble * | reserved | |
| ClutterInputDevice * | the device that originated the event. If you want the physical
device the event originated from, use  | 
Since: 1.10
typedef struct _ClutterEventSequence ClutterEventSequence;
The ClutterEventSequence structure is an opaque type used to denote the event sequence of a touch event.
Since: 1.12
struct ClutterTouchpadPinchEvent {
  ClutterEventType type;
  guint32 time;
  ClutterEventFlags flags;
  ClutterStage *stage;
  ClutterActor *source;
  ClutterTouchpadGesturePhase phase;
  gfloat x;
  gfloat y;
  gfloat dx;
  gfloat dy;
  gfloat angle_delta;
  gfloat scale;
};
Used for touchpad pinch gesture events. The current state of the
gesture will be determined by the phase
 field.
Each event with phase CLUTTER_TOUCHPAD_GESTURE_PHASE_BEGIN
will report a scale
 of 1.0, all later phases in the gesture
report the current scale relative to the initial 1.0 value
(eg. 0.5 being half the size, 2.0 twice as big).
| ClutterEventType  | event type | |
| guint32  | event time | |
| ClutterEventFlags  | event flags | |
| ClutterStage * | event source stage | |
| ClutterActor * | event source actor (unused) | |
| ClutterTouchpadGesturePhase  | the current phase of the gesture | |
| gfloat  | the X coordinate of the pointer, relative to the stage | |
| gfloat  | the Y coordinate of the pointer, relative to the stage | |
| gfloat  | movement delta of the pinch focal point in the X axis | |
| gfloat  | movement delta of the pinch focal point in the Y axis | |
| gfloat  | angle delta in degrees, clockwise rotations are represented by positive deltas | |
| gfloat  | the current scale | 
Since: 1.24
struct ClutterTouchpadSwipeEvent {
  ClutterEventType type;
  guint32 time;
  ClutterEventFlags flags;
  ClutterStage *stage;
  ClutterActor *source;
  ClutterTouchpadGesturePhase phase;
  guint n_fingers;
  gfloat x;
  gfloat y;
  gfloat dx;
  gfloat dy;
};
Used for touchpad swipe gesture events. The current state of the
gesture will be determined by the phase
 field.
| ClutterEventType  | event type | |
| guint32  | event time | |
| ClutterEventFlags  | event flags | |
| ClutterStage * | event source stage | |
| ClutterActor * | event source actor (unused) | |
| ClutterTouchpadGesturePhase  | the current phase of the gesture | |
| guint  | the number of fingers triggering the swipe | |
| gfloat  | the X coordinate of the pointer, relative to the stage | |
| gfloat  | the Y coordinate of the pointer, relative to the stage | |
| gfloat  | movement delta of the pinch focal point in the X axis | |
| gfloat  | movement delta of the pinch focal point in the Y axis | 
Since: 1.24
The phase of a touchpad gesture event. All gestures are guaranteed to
begin with an event of type CLUTTER_TOUCHPAD_GESTURE_PHASE_BEGIN,
followed by a number of CLUTTER_TOUCHPAD_GESTURE_PHASE_UPDATE (possibly 0).
A finished gesture may have 2 possible outcomes, an event with phase
CLUTTER_TOUCHPAD_GESTURE_PHASE_END will be emitted when the gesture is
considered successful, this should be used as the hint to perform any
permanent changes.
Cancelled gestures may be so for a variety of reasons, due to hardware,
or due to the gesture recognition layers hinting the gesture did not
finish resolutely (eg. a 3rd finger being added during a pinch gesture).
In these cases, the last event with report the phase
CLUTTER_TOUCHPAD_GESTURE_PHASE_CANCEL, this should be used as a hint
to undo any visible/permanent changes that were done throughout the
progress of the gesture.
See also ClutterTouchpadPinchEvent and ClutterTouchpadPinchEvent.
| The gesture has begun. | ||
| The gesture has been updated. | ||
| The gesture was finished, changes should be permanently applied. | ||
| The gesture was cancelled, all changes should be undone. | 
Since: 1.24
#define CLUTTER_BUTTON_PRIMARY (1)
The primary button of a pointer device.
This is typically the left mouse button in a right-handed mouse configuration.
Since: 1.10
#define CLUTTER_BUTTON_MIDDLE (2)
The middle button of a pointer device.
Since: 1.10
#define CLUTTER_BUTTON_SECONDARY (3)
The secondary button of a pointer device.
This is typically the right mouse button in a right-handed mouse configuration.
Since: 1.10