mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-10 20:50:12 +00:00
Merge branch 'wip/long-combo-boxes' into 'gtk-3-24'
Fix long combo box positioning See merge request GNOME/gtk!514
This commit is contained in:
commit
e2d9563a55
@ -140,6 +140,7 @@ struct _GdkWindowImplWayland
|
||||
EGLSurface dummy_egl_surface;
|
||||
|
||||
unsigned int initial_configure_received : 1;
|
||||
unsigned int configuring_popup : 1;
|
||||
unsigned int mapped : 1;
|
||||
unsigned int use_custom_surface : 1;
|
||||
unsigned int pending_buffer_attached : 1;
|
||||
@ -1088,12 +1089,18 @@ gdk_wayland_window_maybe_configure (GdkWindow *window,
|
||||
is_xdg_popup = is_realized_popup (window);
|
||||
is_visible = gdk_window_is_visible (window);
|
||||
|
||||
if (is_xdg_popup && is_visible && !impl->initial_configure_received)
|
||||
if (is_xdg_popup &&
|
||||
is_visible &&
|
||||
!impl->initial_configure_received &&
|
||||
!impl->configuring_popup)
|
||||
gdk_window_hide (window);
|
||||
|
||||
gdk_wayland_window_configure (window, width, height, scale);
|
||||
|
||||
if (is_xdg_popup && is_visible && !impl->initial_configure_received)
|
||||
if (is_xdg_popup &&
|
||||
is_visible &&
|
||||
!impl->initial_configure_received &&
|
||||
!impl->configuring_popup)
|
||||
gdk_window_show (window);
|
||||
}
|
||||
|
||||
@ -2413,9 +2420,11 @@ calculate_moved_to_rect_result (GdkWindow *window,
|
||||
window_width = width + window->shadow_left + window->shadow_right;
|
||||
window_height = height + window->shadow_top + window->shadow_bottom;
|
||||
|
||||
impl->configuring_popup = TRUE;
|
||||
gdk_window_move_resize (window,
|
||||
window_x, window_y,
|
||||
window_width, window_height);
|
||||
impl->configuring_popup = FALSE;
|
||||
|
||||
calculate_popup_rect (window,
|
||||
impl->pending_move_to_rect.rect_anchor,
|
||||
|
@ -213,6 +213,12 @@ enum {
|
||||
CHILD_PROP_BOTTOM_ATTACH
|
||||
};
|
||||
|
||||
typedef enum _GtkMenuScrollFlag
|
||||
{
|
||||
GTK_MENU_SCROLL_FLAG_NONE = 0,
|
||||
GTK_MENU_SCROLL_FLAG_ADAPT = 1 << 0,
|
||||
} GtkMenuScrollFlag;
|
||||
|
||||
static void gtk_menu_set_property (GObject *object,
|
||||
guint prop_id,
|
||||
const GValue *value,
|
||||
@ -255,7 +261,8 @@ static gboolean gtk_menu_enter_notify (GtkWidget *widget,
|
||||
static gboolean gtk_menu_leave_notify (GtkWidget *widget,
|
||||
GdkEventCrossing *event);
|
||||
static void gtk_menu_scroll_to (GtkMenu *menu,
|
||||
gint offset);
|
||||
gint offset,
|
||||
GtkMenuScrollFlag flags);
|
||||
static void gtk_menu_grab_notify (GtkWidget *widget,
|
||||
gboolean was_grabbed);
|
||||
static gboolean gtk_menu_captured_event (GtkWidget *widget,
|
||||
@ -1977,7 +1984,7 @@ gtk_menu_popup_internal (GtkMenu *menu,
|
||||
|
||||
associate_menu_grab_transfer_window (menu);
|
||||
|
||||
gtk_menu_scroll_to (menu, priv->scroll_offset);
|
||||
gtk_menu_scroll_to (menu, priv->scroll_offset, GTK_MENU_SCROLL_FLAG_NONE);
|
||||
|
||||
/* if no item is selected, select the first one */
|
||||
if (!menu_shell->priv->active_menu_item &&
|
||||
@ -1985,6 +1992,7 @@ gtk_menu_popup_internal (GtkMenu *menu,
|
||||
gtk_menu_shell_select_first (menu_shell, TRUE);
|
||||
|
||||
/* Once everything is set up correctly, map the toplevel */
|
||||
gtk_window_force_resize (GTK_WINDOW (priv->toplevel));
|
||||
gtk_widget_show (priv->toplevel);
|
||||
|
||||
if (xgrab_shell == widget)
|
||||
@ -2478,7 +2486,8 @@ gtk_menu_update_scroll_offset (GtkMenu *menu,
|
||||
|
||||
get_arrows_border (menu, &arrows_border);
|
||||
menu->priv->scroll_offset = arrows_border.top + (final_rect->y - flipped_rect->y);
|
||||
gtk_menu_scroll_to (menu, menu->priv->scroll_offset);
|
||||
gtk_menu_scroll_to (menu, menu->priv->scroll_offset,
|
||||
GTK_MENU_SCROLL_FLAG_ADAPT);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -2551,7 +2560,8 @@ gtk_menu_popdown (GtkMenu *menu)
|
||||
* non-tearoff menu was popped down.
|
||||
*/
|
||||
if (!priv->tearoff_active)
|
||||
gtk_menu_scroll_to (menu, priv->saved_scroll_offset);
|
||||
gtk_menu_scroll_to (menu, priv->saved_scroll_offset,
|
||||
GTK_MENU_SCROLL_FLAG_NONE);
|
||||
priv->tearoff_active = TRUE;
|
||||
}
|
||||
else
|
||||
@ -2842,7 +2852,7 @@ gtk_menu_scrollbar_changed (GtkAdjustment *adjustment,
|
||||
|
||||
value = gtk_adjustment_get_value (adjustment);
|
||||
if (menu->priv->scroll_offset != value)
|
||||
gtk_menu_scroll_to (menu, value);
|
||||
gtk_menu_scroll_to (menu, value, GTK_MENU_SCROLL_FLAG_NONE);
|
||||
}
|
||||
|
||||
static void
|
||||
@ -3035,7 +3045,7 @@ gtk_menu_set_tearoff_state (GtkMenu *menu,
|
||||
gtk_widget_show (GTK_WIDGET (menu));
|
||||
gtk_widget_show (priv->tearoff_window);
|
||||
|
||||
gtk_menu_scroll_to (menu, 0);
|
||||
gtk_menu_scroll_to (menu, 0, GTK_MENU_SCROLL_FLAG_NONE);
|
||||
|
||||
}
|
||||
else
|
||||
@ -3481,7 +3491,7 @@ gtk_menu_size_allocate (GtkWidget *widget,
|
||||
height = allocation->height - (2 * border_width) - padding.top - padding.bottom;
|
||||
|
||||
if (menu_shell->priv->active)
|
||||
gtk_menu_scroll_to (menu, priv->scroll_offset);
|
||||
gtk_menu_scroll_to (menu, priv->scroll_offset, GTK_MENU_SCROLL_FLAG_NONE);
|
||||
|
||||
get_arrows_border (menu, &arrow_border);
|
||||
|
||||
@ -3589,7 +3599,7 @@ gtk_menu_size_allocate (GtkWidget *widget,
|
||||
gtk_widget_hide (priv->tearoff_scrollbar);
|
||||
gtk_menu_set_tearoff_hints (menu, allocation->width);
|
||||
|
||||
gtk_menu_scroll_to (menu, 0);
|
||||
gtk_menu_scroll_to (menu, 0, GTK_MENU_SCROLL_FLAG_NONE);
|
||||
}
|
||||
}
|
||||
else
|
||||
@ -4167,7 +4177,7 @@ gtk_menu_scroll_by (GtkMenu *menu,
|
||||
offset = priv->requested_height - view_height;
|
||||
|
||||
if (offset != priv->scroll_offset)
|
||||
gtk_menu_scroll_to (menu, offset);
|
||||
gtk_menu_scroll_to (menu, offset, GTK_MENU_SCROLL_FLAG_NONE);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
@ -4677,7 +4687,7 @@ gtk_menu_captured_event (GtkWidget *widget,
|
||||
MIN (priv->scroll_offset, 0),
|
||||
MAX (priv->scroll_offset, priv->requested_height - view_height));
|
||||
|
||||
gtk_menu_scroll_to (menu, offset);
|
||||
gtk_menu_scroll_to (menu, offset, GTK_MENU_SCROLL_FLAG_NONE);
|
||||
|
||||
retval = TRUE;
|
||||
}
|
||||
@ -5243,10 +5253,16 @@ gtk_menu_position (GtkMenu *menu,
|
||||
|
||||
if (!rect_window)
|
||||
{
|
||||
gtk_window_set_unlimited_guessed_size (GTK_WINDOW (priv->toplevel),
|
||||
FALSE, FALSE);
|
||||
gtk_menu_position_legacy (menu, set_scroll_offset);
|
||||
return;
|
||||
}
|
||||
|
||||
gtk_window_set_unlimited_guessed_size (GTK_WINDOW (priv->toplevel),
|
||||
!!(anchor_hints & GDK_ANCHOR_RESIZE_X),
|
||||
!!(anchor_hints & GDK_ANCHOR_RESIZE_Y));
|
||||
|
||||
/* Realize so we have the proper width and height to figure out
|
||||
* the right place to popup the menu.
|
||||
*/
|
||||
@ -5316,11 +5332,26 @@ gtk_menu_stop_scrolling (GtkMenu *menu)
|
||||
}
|
||||
|
||||
static void
|
||||
gtk_menu_scroll_to (GtkMenu *menu,
|
||||
gint offset)
|
||||
sync_arrows_state (GtkMenu *menu)
|
||||
{
|
||||
GtkMenuPrivate *priv = menu->priv;
|
||||
GtkCssNode *top_arrow_node, *bottom_arrow_node;
|
||||
|
||||
top_arrow_node = gtk_css_gadget_get_node (priv->top_arrow_gadget);
|
||||
gtk_css_node_set_visible (top_arrow_node, priv->upper_arrow_visible);
|
||||
gtk_css_node_set_state (top_arrow_node, priv->upper_arrow_state);
|
||||
|
||||
bottom_arrow_node = gtk_css_gadget_get_node (priv->bottom_arrow_gadget);
|
||||
gtk_css_node_set_visible (bottom_arrow_node, priv->lower_arrow_visible);
|
||||
gtk_css_node_set_state (bottom_arrow_node, priv->lower_arrow_state);
|
||||
}
|
||||
|
||||
static void
|
||||
gtk_menu_scroll_to (GtkMenu *menu,
|
||||
gint offset,
|
||||
GtkMenuScrollFlag flags)
|
||||
{
|
||||
GtkMenuPrivate *priv = menu->priv;
|
||||
GtkBorder arrow_border, padding;
|
||||
GtkWidget *widget;
|
||||
gint x, y;
|
||||
@ -5356,13 +5387,25 @@ gtk_menu_scroll_to (GtkMenu *menu,
|
||||
{
|
||||
GtkStateFlags upper_arrow_previous_state = priv->upper_arrow_state;
|
||||
GtkStateFlags lower_arrow_previous_state = priv->lower_arrow_state;
|
||||
gboolean should_offset_by_arrow;
|
||||
|
||||
if (!priv->upper_arrow_visible || !priv->lower_arrow_visible)
|
||||
gtk_widget_queue_draw (GTK_WIDGET (menu));
|
||||
|
||||
if (!priv->upper_arrow_visible &
|
||||
flags & GTK_MENU_SCROLL_FLAG_ADAPT)
|
||||
should_offset_by_arrow = TRUE;
|
||||
else
|
||||
should_offset_by_arrow = FALSE;
|
||||
|
||||
priv->upper_arrow_visible = priv->lower_arrow_visible = TRUE;
|
||||
|
||||
if (flags & GTK_MENU_SCROLL_FLAG_ADAPT)
|
||||
sync_arrows_state (menu);
|
||||
|
||||
get_arrows_border (menu, &arrow_border);
|
||||
if (should_offset_by_arrow)
|
||||
offset += arrow_border.top;
|
||||
y += arrow_border.top;
|
||||
view_height -= arrow_border.top;
|
||||
view_height -= arrow_border.bottom;
|
||||
@ -5429,13 +5472,7 @@ gtk_menu_scroll_to (GtkMenu *menu,
|
||||
}
|
||||
}
|
||||
|
||||
top_arrow_node = gtk_css_gadget_get_node (priv->top_arrow_gadget);
|
||||
gtk_css_node_set_visible (top_arrow_node, priv->upper_arrow_visible);
|
||||
gtk_css_node_set_state (top_arrow_node, priv->upper_arrow_state);
|
||||
|
||||
bottom_arrow_node = gtk_css_gadget_get_node (priv->bottom_arrow_gadget);
|
||||
gtk_css_node_set_visible (bottom_arrow_node, priv->lower_arrow_visible);
|
||||
gtk_css_node_set_state (bottom_arrow_node, priv->lower_arrow_state);
|
||||
sync_arrows_state (menu);
|
||||
|
||||
/* Scroll the menu: */
|
||||
if (gtk_widget_get_realized (widget))
|
||||
@ -5521,7 +5558,7 @@ gtk_menu_scroll_item_visible (GtkMenuShell *menu_shell,
|
||||
* is on the menu
|
||||
*/
|
||||
menu_shell->priv->ignore_enter = TRUE;
|
||||
gtk_menu_scroll_to (menu, child_offset);
|
||||
gtk_menu_scroll_to (menu, child_offset, GTK_MENU_SCROLL_FLAG_NONE);
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -5542,7 +5579,7 @@ gtk_menu_scroll_item_visible (GtkMenuShell *menu_shell,
|
||||
* is on the menu
|
||||
*/
|
||||
menu_shell->priv->ignore_enter = TRUE;
|
||||
gtk_menu_scroll_to (menu, y);
|
||||
gtk_menu_scroll_to (menu, y, GTK_MENU_SCROLL_FLAG_NONE);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -6026,7 +6063,7 @@ gtk_menu_real_move_scroll (GtkMenu *menu,
|
||||
new_offset = priv->scroll_offset + step;
|
||||
new_offset = CLAMP (new_offset, 0, end_position - page_size);
|
||||
|
||||
gtk_menu_scroll_to (menu, new_offset);
|
||||
gtk_menu_scroll_to (menu, new_offset, GTK_MENU_SCROLL_FLAG_NONE);
|
||||
|
||||
if (menu_shell->priv->active_menu_item)
|
||||
{
|
||||
|
@ -262,6 +262,9 @@ struct _GtkWindowPrivate
|
||||
guint maximized : 1;
|
||||
guint fullscreen : 1;
|
||||
guint tiled : 1;
|
||||
guint unlimited_guessed_size_x : 1;
|
||||
guint unlimited_guessed_size_y : 1;
|
||||
guint force_resize : 1;
|
||||
|
||||
guint use_subsurface : 1;
|
||||
|
||||
@ -6455,6 +6458,25 @@ gtk_window_unmap (GtkWidget *widget)
|
||||
gtk_widget_unmap (child);
|
||||
}
|
||||
|
||||
void
|
||||
gtk_window_set_unlimited_guessed_size (GtkWindow *window,
|
||||
gboolean x,
|
||||
gboolean y)
|
||||
{
|
||||
GtkWindowPrivate *priv = window->priv;
|
||||
|
||||
priv->unlimited_guessed_size_x = x;
|
||||
priv->unlimited_guessed_size_y = y;
|
||||
}
|
||||
|
||||
void
|
||||
gtk_window_force_resize (GtkWindow *window)
|
||||
{
|
||||
GtkWindowPrivate *priv = window->priv;
|
||||
|
||||
priv->force_resize = TRUE;
|
||||
}
|
||||
|
||||
/* (Note: Replace "size" with "width" or "height". Also, the request
|
||||
* mode is honoured.)
|
||||
* For selecting the default window size, the following conditions
|
||||
@ -6493,8 +6515,15 @@ gtk_window_guess_default_size (GtkWindow *window,
|
||||
|
||||
gdk_monitor_get_workarea (monitor, &workarea);
|
||||
|
||||
*width = workarea.width;
|
||||
*height = workarea.height;
|
||||
if (window->priv->unlimited_guessed_size_x)
|
||||
*width = INT_MAX;
|
||||
else
|
||||
*width = workarea.width;
|
||||
|
||||
if (window->priv->unlimited_guessed_size_y)
|
||||
*height = INT_MAX;
|
||||
else
|
||||
*height = workarea.height;
|
||||
|
||||
if (gtk_widget_get_request_mode (widget) == GTK_SIZE_REQUEST_WIDTH_FOR_HEIGHT)
|
||||
{
|
||||
@ -9364,7 +9393,8 @@ gtk_window_compute_configure_request_size (GtkWindow *window,
|
||||
|
||||
info = gtk_window_get_geometry_info (window, FALSE);
|
||||
|
||||
if (priv->need_default_size)
|
||||
if (priv->need_default_size ||
|
||||
priv->force_resize)
|
||||
{
|
||||
gtk_window_guess_default_size (window, width, height);
|
||||
gtk_window_get_remembered_size (window, &w, &h);
|
||||
@ -9769,9 +9799,13 @@ gtk_window_move_resize (GtkWindow *window)
|
||||
info->last.configure_request.y != new_request.y)
|
||||
configure_request_pos_changed = TRUE;
|
||||
|
||||
if ((info->last.configure_request.width != new_request.width ||
|
||||
if (priv->force_resize ||
|
||||
(info->last.configure_request.width != new_request.width ||
|
||||
info->last.configure_request.height != new_request.height))
|
||||
configure_request_size_changed = TRUE;
|
||||
{
|
||||
priv->force_resize = FALSE;
|
||||
configure_request_size_changed = TRUE;
|
||||
}
|
||||
|
||||
hints_changed = FALSE;
|
||||
|
||||
|
@ -135,6 +135,11 @@ void gtk_window_set_hardcoded_window (GtkWindow *window,
|
||||
|
||||
GdkScreen *_gtk_window_get_screen (GtkWindow *window);
|
||||
|
||||
void gtk_window_set_unlimited_guessed_size (GtkWindow *window,
|
||||
gboolean x,
|
||||
gboolean y);
|
||||
void gtk_window_force_resize (GtkWindow *window);
|
||||
|
||||
/* Exported handles */
|
||||
|
||||
typedef void (*GtkWindowHandleExported) (GtkWindow *window,
|
||||
|
Loading…
Reference in New Issue
Block a user