mirror of
https://github.com/brl/mutter.git
synced 2024-11-21 23:50:41 -05:00
wayland/pointer-gestures: Implement hold gesture
Update the pointer gestures protocol to version 3 and implement the new hold gesture. Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/1830>
This commit is contained in:
parent
c545ffac43
commit
8d34b50918
@ -584,6 +584,8 @@ if have_wayland
|
|||||||
'wayland/meta-wayland-pointer.c',
|
'wayland/meta-wayland-pointer.c',
|
||||||
'wayland/meta-wayland-pointer-constraints.c',
|
'wayland/meta-wayland-pointer-constraints.c',
|
||||||
'wayland/meta-wayland-pointer-constraints.h',
|
'wayland/meta-wayland-pointer-constraints.h',
|
||||||
|
'wayland/meta-wayland-pointer-gesture-hold.c',
|
||||||
|
'wayland/meta-wayland-pointer-gesture-hold.h',
|
||||||
'wayland/meta-wayland-pointer-gesture-pinch.c',
|
'wayland/meta-wayland-pointer-gesture-pinch.c',
|
||||||
'wayland/meta-wayland-pointer-gesture-pinch.h',
|
'wayland/meta-wayland-pointer-gesture-pinch.h',
|
||||||
'wayland/meta-wayland-pointer-gestures.c',
|
'wayland/meta-wayland-pointer-gestures.c',
|
||||||
|
135
src/wayland/meta-wayland-pointer-gesture-hold.c
Normal file
135
src/wayland/meta-wayland-pointer-gesture-hold.c
Normal file
@ -0,0 +1,135 @@
|
|||||||
|
/*
|
||||||
|
* Wayland Support
|
||||||
|
*
|
||||||
|
* This library 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 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This library is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public
|
||||||
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
* Author: José Expósito <jose.exposito89@gmail.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
#include "wayland/meta-wayland-pointer-gesture-hold.h"
|
||||||
|
|
||||||
|
#include <glib.h>
|
||||||
|
|
||||||
|
#include "wayland/meta-wayland-pointer.h"
|
||||||
|
#include "wayland/meta-wayland-seat.h"
|
||||||
|
#include "wayland/meta-wayland-surface.h"
|
||||||
|
|
||||||
|
#include "pointer-gestures-unstable-v1-server-protocol.h"
|
||||||
|
|
||||||
|
static void
|
||||||
|
handle_hold_begin (MetaWaylandPointer *pointer,
|
||||||
|
const ClutterEvent *event)
|
||||||
|
{
|
||||||
|
MetaWaylandPointerClient *pointer_client;
|
||||||
|
MetaWaylandSeat *seat;
|
||||||
|
struct wl_resource *resource;
|
||||||
|
uint32_t serial, fingers;
|
||||||
|
|
||||||
|
pointer_client = pointer->focus_client;
|
||||||
|
seat = meta_wayland_pointer_get_seat (pointer);
|
||||||
|
serial = wl_display_next_serial (seat->wl_display);
|
||||||
|
fingers = clutter_event_get_touchpad_gesture_finger_count (event);
|
||||||
|
|
||||||
|
wl_resource_for_each (resource, &pointer_client->hold_gesture_resources)
|
||||||
|
{
|
||||||
|
zwp_pointer_gesture_hold_v1_send_begin (resource, serial,
|
||||||
|
clutter_event_get_time (event),
|
||||||
|
pointer->focus_surface->resource,
|
||||||
|
fingers);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
handle_hold_end (MetaWaylandPointer *pointer,
|
||||||
|
const ClutterEvent *event)
|
||||||
|
{
|
||||||
|
MetaWaylandPointerClient *pointer_client;
|
||||||
|
MetaWaylandSeat *seat;
|
||||||
|
struct wl_resource *resource;
|
||||||
|
gboolean cancelled = FALSE;
|
||||||
|
uint32_t serial;
|
||||||
|
|
||||||
|
pointer_client = pointer->focus_client;
|
||||||
|
seat = meta_wayland_pointer_get_seat (pointer);
|
||||||
|
serial = wl_display_next_serial (seat->wl_display);
|
||||||
|
|
||||||
|
if (event->touchpad_hold.phase == CLUTTER_TOUCHPAD_GESTURE_PHASE_CANCEL)
|
||||||
|
cancelled = TRUE;
|
||||||
|
|
||||||
|
wl_resource_for_each (resource, &pointer_client->hold_gesture_resources)
|
||||||
|
{
|
||||||
|
zwp_pointer_gesture_hold_v1_send_end (resource, serial,
|
||||||
|
clutter_event_get_time (event),
|
||||||
|
cancelled);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
meta_wayland_pointer_gesture_hold_handle_event (MetaWaylandPointer *pointer,
|
||||||
|
const ClutterEvent *event)
|
||||||
|
{
|
||||||
|
if (event->type != CLUTTER_TOUCHPAD_HOLD)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
if (!pointer->focus_client)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
switch (event->touchpad_hold.phase)
|
||||||
|
{
|
||||||
|
case CLUTTER_TOUCHPAD_GESTURE_PHASE_BEGIN:
|
||||||
|
handle_hold_begin (pointer, event);
|
||||||
|
break;
|
||||||
|
case CLUTTER_TOUCHPAD_GESTURE_PHASE_END:
|
||||||
|
case CLUTTER_TOUCHPAD_GESTURE_PHASE_CANCEL:
|
||||||
|
handle_hold_end (pointer, event);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
pointer_gesture_hold_release (struct wl_client *client,
|
||||||
|
struct wl_resource *resource)
|
||||||
|
{
|
||||||
|
wl_resource_destroy (resource);
|
||||||
|
}
|
||||||
|
|
||||||
|
static const struct zwp_pointer_gesture_hold_v1_interface pointer_gesture_hold_interface = {
|
||||||
|
pointer_gesture_hold_release
|
||||||
|
};
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_wayland_pointer_gesture_hold_create_new_resource (MetaWaylandPointer *pointer,
|
||||||
|
struct wl_client *client,
|
||||||
|
struct wl_resource *pointer_resource,
|
||||||
|
uint32_t id)
|
||||||
|
{
|
||||||
|
MetaWaylandPointerClient *pointer_client;
|
||||||
|
struct wl_resource *res;
|
||||||
|
|
||||||
|
pointer_client = meta_wayland_pointer_get_pointer_client (pointer, client);
|
||||||
|
g_return_if_fail (pointer_client != NULL);
|
||||||
|
|
||||||
|
res = wl_resource_create (client, &zwp_pointer_gesture_hold_v1_interface,
|
||||||
|
wl_resource_get_version (pointer_resource), id);
|
||||||
|
wl_resource_set_implementation (res, &pointer_gesture_hold_interface, pointer,
|
||||||
|
meta_wayland_pointer_unbind_pointer_client_resource);
|
||||||
|
wl_list_insert (&pointer_client->hold_gesture_resources,
|
||||||
|
wl_resource_get_link (res));
|
||||||
|
}
|
37
src/wayland/meta-wayland-pointer-gesture-hold.h
Normal file
37
src/wayland/meta-wayland-pointer-gesture-hold.h
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
/*
|
||||||
|
* Wayland Support
|
||||||
|
*
|
||||||
|
* This library 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 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This library is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public
|
||||||
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
* Author: José Expósito <jose.exposito89@gmail.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef META_WAYLAND_POINTER_GESTURE_HOLD_H
|
||||||
|
#define META_WAYLAND_POINTER_GESTURE_HOLD_H
|
||||||
|
|
||||||
|
#include <glib.h>
|
||||||
|
#include <wayland-server.h>
|
||||||
|
|
||||||
|
#include "clutter/clutter.h"
|
||||||
|
#include "wayland/meta-wayland-types.h"
|
||||||
|
|
||||||
|
gboolean meta_wayland_pointer_gesture_hold_handle_event (MetaWaylandPointer *pointer,
|
||||||
|
const ClutterEvent *event);
|
||||||
|
|
||||||
|
void meta_wayland_pointer_gesture_hold_create_new_resource (MetaWaylandPointer *pointer,
|
||||||
|
struct wl_client *client,
|
||||||
|
struct wl_resource *gestures_resource,
|
||||||
|
uint32_t id);
|
||||||
|
|
||||||
|
#endif /* META_WAYLAND_POINTER_GESTURE_HOLD_H */
|
@ -54,6 +54,17 @@ gestures_get_pinch (struct wl_client *client,
|
|||||||
meta_wayland_pointer_gesture_pinch_create_new_resource (pointer, client, resource, id);
|
meta_wayland_pointer_gesture_pinch_create_new_resource (pointer, client, resource, id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gestures_get_hold (struct wl_client *client,
|
||||||
|
struct wl_resource *resource,
|
||||||
|
uint32_t id,
|
||||||
|
struct wl_resource *pointer_resource)
|
||||||
|
{
|
||||||
|
MetaWaylandPointer *pointer = wl_resource_get_user_data (pointer_resource);
|
||||||
|
|
||||||
|
meta_wayland_pointer_gesture_hold_create_new_resource (pointer, client, resource, id);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gestures_release (struct wl_client *client,
|
gestures_release (struct wl_client *client,
|
||||||
struct wl_resource *resource)
|
struct wl_resource *resource)
|
||||||
@ -64,7 +75,8 @@ gestures_release (struct wl_client *client,
|
|||||||
static const struct zwp_pointer_gestures_v1_interface pointer_gestures_interface = {
|
static const struct zwp_pointer_gestures_v1_interface pointer_gestures_interface = {
|
||||||
gestures_get_swipe,
|
gestures_get_swipe,
|
||||||
gestures_get_pinch,
|
gestures_get_pinch,
|
||||||
gestures_release
|
gestures_release,
|
||||||
|
gestures_get_hold
|
||||||
};
|
};
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -103,6 +103,7 @@ meta_wayland_pointer_client_new (void)
|
|||||||
wl_list_init (&pointer_client->pointer_resources);
|
wl_list_init (&pointer_client->pointer_resources);
|
||||||
wl_list_init (&pointer_client->swipe_gesture_resources);
|
wl_list_init (&pointer_client->swipe_gesture_resources);
|
||||||
wl_list_init (&pointer_client->pinch_gesture_resources);
|
wl_list_init (&pointer_client->pinch_gesture_resources);
|
||||||
|
wl_list_init (&pointer_client->hold_gesture_resources);
|
||||||
wl_list_init (&pointer_client->relative_pointer_resources);
|
wl_list_init (&pointer_client->relative_pointer_resources);
|
||||||
|
|
||||||
return pointer_client;
|
return pointer_client;
|
||||||
@ -135,6 +136,11 @@ meta_wayland_pointer_make_resources_inert (MetaWaylandPointerClient *pointer_cli
|
|||||||
wl_list_init (wl_resource_get_link (resource));
|
wl_list_init (wl_resource_get_link (resource));
|
||||||
wl_resource_set_user_data (resource, NULL);
|
wl_resource_set_user_data (resource, NULL);
|
||||||
}
|
}
|
||||||
|
wl_resource_for_each_safe (resource, next, &pointer_client->hold_gesture_resources)
|
||||||
|
{
|
||||||
|
wl_list_remove (wl_resource_get_link (resource));
|
||||||
|
wl_list_init (wl_resource_get_link (resource));
|
||||||
|
}
|
||||||
wl_resource_for_each_safe (resource, next, &pointer_client->relative_pointer_resources)
|
wl_resource_for_each_safe (resource, next, &pointer_client->relative_pointer_resources)
|
||||||
{
|
{
|
||||||
wl_list_remove (wl_resource_get_link (resource));
|
wl_list_remove (wl_resource_get_link (resource));
|
||||||
@ -166,6 +172,7 @@ meta_wayland_pointer_client_is_empty (MetaWaylandPointerClient *pointer_client)
|
|||||||
return (wl_list_empty (&pointer_client->pointer_resources) &&
|
return (wl_list_empty (&pointer_client->pointer_resources) &&
|
||||||
wl_list_empty (&pointer_client->swipe_gesture_resources) &&
|
wl_list_empty (&pointer_client->swipe_gesture_resources) &&
|
||||||
wl_list_empty (&pointer_client->pinch_gesture_resources) &&
|
wl_list_empty (&pointer_client->pinch_gesture_resources) &&
|
||||||
|
wl_list_empty (&pointer_client->hold_gesture_resources) &&
|
||||||
wl_list_empty (&pointer_client->relative_pointer_resources));
|
wl_list_empty (&pointer_client->relative_pointer_resources));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -822,6 +829,10 @@ meta_wayland_pointer_handle_event (MetaWaylandPointer *pointer,
|
|||||||
meta_wayland_pointer_gesture_pinch_handle_event (pointer, event);
|
meta_wayland_pointer_gesture_pinch_handle_event (pointer, event);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case CLUTTER_TOUCHPAD_HOLD:
|
||||||
|
meta_wayland_pointer_gesture_hold_handle_event (pointer, event);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
|
|
||||||
#include "meta/meta-cursor-tracker.h"
|
#include "meta/meta-cursor-tracker.h"
|
||||||
#include "wayland/meta-wayland-pointer-constraints.h"
|
#include "wayland/meta-wayland-pointer-constraints.h"
|
||||||
|
#include "wayland/meta-wayland-pointer-gesture-hold.h"
|
||||||
#include "wayland/meta-wayland-pointer-gesture-pinch.h"
|
#include "wayland/meta-wayland-pointer-gesture-pinch.h"
|
||||||
#include "wayland/meta-wayland-pointer-gesture-swipe.h"
|
#include "wayland/meta-wayland-pointer-gesture-swipe.h"
|
||||||
#include "wayland/meta-wayland-seat.h"
|
#include "wayland/meta-wayland-seat.h"
|
||||||
@ -58,6 +59,7 @@ struct _MetaWaylandPointerClient
|
|||||||
struct wl_list pointer_resources;
|
struct wl_list pointer_resources;
|
||||||
struct wl_list swipe_gesture_resources;
|
struct wl_list swipe_gesture_resources;
|
||||||
struct wl_list pinch_gesture_resources;
|
struct wl_list pinch_gesture_resources;
|
||||||
|
struct wl_list hold_gesture_resources;
|
||||||
struct wl_list relative_pointer_resources;
|
struct wl_list relative_pointer_resources;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -400,6 +400,7 @@ meta_wayland_seat_handle_event (MetaWaylandSeat *seat,
|
|||||||
case CLUTTER_SCROLL:
|
case CLUTTER_SCROLL:
|
||||||
case CLUTTER_TOUCHPAD_SWIPE:
|
case CLUTTER_TOUCHPAD_SWIPE:
|
||||||
case CLUTTER_TOUCHPAD_PINCH:
|
case CLUTTER_TOUCHPAD_PINCH:
|
||||||
|
case CLUTTER_TOUCHPAD_HOLD:
|
||||||
if (meta_wayland_seat_has_pointer (seat))
|
if (meta_wayland_seat_has_pointer (seat))
|
||||||
return meta_wayland_pointer_handle_event (seat->pointer, event);
|
return meta_wayland_pointer_handle_event (seat->pointer, event);
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@
|
|||||||
#define META_XSERVER_VERSION 1
|
#define META_XSERVER_VERSION 1
|
||||||
#define META_GTK_SHELL1_VERSION 5
|
#define META_GTK_SHELL1_VERSION 5
|
||||||
#define META_WL_SUBCOMPOSITOR_VERSION 1
|
#define META_WL_SUBCOMPOSITOR_VERSION 1
|
||||||
#define META_ZWP_POINTER_GESTURES_V1_VERSION 2
|
#define META_ZWP_POINTER_GESTURES_V1_VERSION 3
|
||||||
#define META_ZXDG_EXPORTER_V1_VERSION 1
|
#define META_ZXDG_EXPORTER_V1_VERSION 1
|
||||||
#define META_ZXDG_IMPORTER_V1_VERSION 1
|
#define META_ZXDG_IMPORTER_V1_VERSION 1
|
||||||
#define META_ZWP_LINUX_DMABUF_V1_VERSION 3
|
#define META_ZWP_LINUX_DMABUF_V1_VERSION 3
|
||||||
|
Loading…
Reference in New Issue
Block a user