backend: Don't center the pointers on monitor changes

As a follow up to the patch from a95cbd0a, we need to make sure
that the pointer is out of the way as well when monitors changed,
since that's the event that will prevail in some cases. Besides,
this is also consistent with what the code before a95cbd0a was,
which initialized the pointer position in the same way both in
this case and in the real_post_init() function.

Closes: https://gitlab.gnome.org/GNOME/gnome-shell/issues/157
This commit is contained in:
Mario Sanchez Prada 2018-04-24 21:32:24 +01:00 committed by Jonas Ådahl
parent d0147591b3
commit 59397266ed

View File

@ -170,7 +170,7 @@ meta_backend_sync_screen_size (MetaBackend *backend)
} }
static void static void
center_pointer (MetaBackend *backend) reset_pointer_position (MetaBackend *backend)
{ {
MetaBackendPrivate *priv = meta_backend_get_instance_private (backend); MetaBackendPrivate *priv = meta_backend_get_instance_private (backend);
MetaMonitorManager *monitor_manager = priv->monitor_manager; MetaMonitorManager *monitor_manager = priv->monitor_manager;
@ -179,9 +179,11 @@ center_pointer (MetaBackend *backend)
primary = primary =
meta_monitor_manager_get_primary_logical_monitor (monitor_manager); meta_monitor_manager_get_primary_logical_monitor (monitor_manager);
/* Move the pointer out of the way to avoid hovering over reactive
* elements (e.g. users list at login) causing undesired behaviour. */
meta_backend_warp_pointer (backend, meta_backend_warp_pointer (backend,
primary->rect.x + primary->rect.width / 2, primary->rect.x + primary->rect.width * 0.9,
primary->rect.y + primary->rect.height / 2); primary->rect.y + primary->rect.height * 0.9);
} }
void void
@ -204,7 +206,7 @@ meta_backend_monitors_changed (MetaBackend *backend)
!priv->is_pointer_position_initialized) && !priv->is_pointer_position_initialized) &&
!meta_monitor_manager_is_headless (monitor_manager)) !meta_monitor_manager_is_headless (monitor_manager))
{ {
center_pointer (backend); reset_pointer_position (backend);
priv->is_pointer_position_initialized = TRUE; priv->is_pointer_position_initialized = TRUE;
} }
} }
@ -479,18 +481,7 @@ meta_backend_real_post_init (MetaBackend *backend)
if (!meta_monitor_manager_is_headless (priv->monitor_manager)) if (!meta_monitor_manager_is_headless (priv->monitor_manager))
{ {
MetaMonitorManager *monitor_manager = priv->monitor_manager; reset_pointer_position (backend);
MetaLogicalMonitor *primary;
primary =
meta_monitor_manager_get_primary_logical_monitor (monitor_manager);
/* Move the pointer out of the way to avoid hovering over reactive
* elements (e.g. users list at login) causing undesired behaviour. */
meta_backend_warp_pointer (backend,
primary->rect.x + primary->rect.width * 0.9,
primary->rect.y + primary->rect.height * 0.9);
priv->is_pointer_position_initialized = TRUE; priv->is_pointer_position_initialized = TRUE;
} }
} }