forked from AuroraMiddleware/gtk
scrolledwindow: Stop using scroll cursors
We used to override cursor to use all-scroll while the content is being scrolled. Unfortunately, there is several problems with this: - It is really only expected certain devices, and we don't have the device information on Wayland - With the way cursor setting works in GTK4, non-NULL cursors of the content (eg the text views ibeam) win, making the scroll cursor not show up - Under X11, we seem to miss scroll end events and then the scroll cursor gets stuck Therefore, just remove this feature.
This commit is contained in:
parent
d0cb76fff4
commit
03176fe23c
@ -401,9 +401,6 @@ static void indicator_start_fade (Indicator *indicator,
|
|||||||
static void indicator_set_over (Indicator *indicator,
|
static void indicator_set_over (Indicator *indicator,
|
||||||
gboolean over);
|
gboolean over);
|
||||||
|
|
||||||
static void install_scroll_cursor (GtkScrolledWindow *scrolled_window);
|
|
||||||
static void uninstall_scroll_cursor (GtkScrolledWindow *scrolled_window);
|
|
||||||
|
|
||||||
static void scrolled_window_scroll (GtkScrolledWindow *scrolled_window,
|
static void scrolled_window_scroll (GtkScrolledWindow *scrolled_window,
|
||||||
double delta_x,
|
double delta_x,
|
||||||
double delta_y,
|
double delta_y,
|
||||||
@ -1335,10 +1332,7 @@ start_scroll_deceleration_cb (gpointer user_data)
|
|||||||
priv->scroll_events_overshoot_id = 0;
|
priv->scroll_events_overshoot_id = 0;
|
||||||
|
|
||||||
if (!priv->deceleration_id)
|
if (!priv->deceleration_id)
|
||||||
{
|
gtk_scrolled_window_start_deceleration (scrolled_window);
|
||||||
uninstall_scroll_cursor (scrolled_window);
|
|
||||||
gtk_scrolled_window_start_deceleration (scrolled_window);
|
|
||||||
}
|
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
@ -1349,7 +1343,6 @@ scroll_controller_scroll_begin (GtkEventControllerScroll *scroll,
|
|||||||
{
|
{
|
||||||
GtkScrolledWindowPrivate *priv = gtk_scrolled_window_get_instance_private (scrolled_window);
|
GtkScrolledWindowPrivate *priv = gtk_scrolled_window_get_instance_private (scrolled_window);
|
||||||
|
|
||||||
install_scroll_cursor (scrolled_window);
|
|
||||||
priv->smooth_scroll = TRUE;
|
priv->smooth_scroll = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1442,7 +1435,6 @@ scroll_controller_scroll_end (GtkEventControllerScroll *scroll,
|
|||||||
GtkScrolledWindowPrivate *priv = gtk_scrolled_window_get_instance_private (scrolled_window);
|
GtkScrolledWindowPrivate *priv = gtk_scrolled_window_get_instance_private (scrolled_window);
|
||||||
|
|
||||||
priv->smooth_scroll = FALSE;
|
priv->smooth_scroll = FALSE;
|
||||||
uninstall_scroll_cursor (scrolled_window);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -3184,18 +3176,6 @@ gtk_scrolled_window_allocate_scrollbar (GtkScrolledWindow *scrolled_window,
|
|||||||
*allocation = child_allocation;
|
*allocation = child_allocation;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
install_scroll_cursor (GtkScrolledWindow *scrolled_window)
|
|
||||||
{
|
|
||||||
gtk_widget_set_cursor_from_name (GTK_WIDGET (scrolled_window), "all-scroll");
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
uninstall_scroll_cursor (GtkScrolledWindow *scrolled_window)
|
|
||||||
{
|
|
||||||
gtk_widget_set_cursor (GTK_WIDGET (scrolled_window), NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_gtk_scrolled_window_set_adjustment_value (GtkScrolledWindow *scrolled_window,
|
_gtk_scrolled_window_set_adjustment_value (GtkScrolledWindow *scrolled_window,
|
||||||
GtkAdjustment *adjustment,
|
GtkAdjustment *adjustment,
|
||||||
|
Loading…
Reference in New Issue
Block a user