viewport: Use gdk_window_new_child()

This commit is contained in:
Benjamin Otte 2016-10-17 20:19:32 +02:00
parent d6eedf19dc
commit 3cf7b21256

View File

@ -835,53 +835,35 @@ gtk_viewport_realize (GtkWidget *widget)
GtkAllocation view_allocation; GtkAllocation view_allocation;
GtkWidget *child; GtkWidget *child;
GdkWindow *window; GdkWindow *window;
GdkWindowAttr attributes;
gint attributes_mask;
gint event_mask; gint event_mask;
gtk_widget_set_realized (widget, TRUE); gtk_widget_set_realized (widget, TRUE);
gtk_widget_get_allocation (widget, &allocation); gtk_widget_get_allocation (widget, &allocation);
attributes.x = allocation.x;
attributes.y = allocation.y;
attributes.width = allocation.width;
attributes.height = allocation.height;
attributes.window_type = GDK_WINDOW_CHILD;
attributes.wclass = GDK_INPUT_OUTPUT;
event_mask = gtk_widget_get_events (widget); event_mask = gtk_widget_get_events (widget);
attributes.event_mask = event_mask | GDK_SCROLL_MASK | GDK_TOUCH_MASK | GDK_SMOOTH_SCROLL_MASK; window = gdk_window_new_child (gtk_widget_get_parent_window (widget),
event_mask | GDK_SCROLL_MASK | GDK_TOUCH_MASK | GDK_SMOOTH_SCROLL_MASK,
attributes_mask = GDK_WA_X | GDK_WA_Y; &allocation);
window = gdk_window_new (gtk_widget_get_parent_window (widget),
&attributes, attributes_mask);
gtk_widget_set_window (widget, window); gtk_widget_set_window (widget, window);
gtk_widget_register_window (widget, window); gtk_widget_register_window (widget, window);
gtk_css_gadget_get_content_allocation (priv->gadget, gtk_css_gadget_get_content_allocation (priv->gadget,
&view_allocation, NULL); &view_allocation, NULL);
attributes.x = view_allocation.x; priv->view_window = gdk_window_new_child (window,
attributes.y = view_allocation.y; 0,
attributes.width = view_allocation.width; &view_allocation);
attributes.height = view_allocation.height;
attributes.event_mask = 0;
priv->view_window = gdk_window_new (window,
&attributes, attributes_mask);
gtk_widget_register_window (widget, priv->view_window); gtk_widget_register_window (widget, priv->view_window);
attributes.x = - gtk_adjustment_get_value (hadjustment); priv->bin_window = gdk_window_new_child (priv->view_window,
attributes.y = - gtk_adjustment_get_value (vadjustment); event_mask,
attributes.width = gtk_adjustment_get_upper (hadjustment); &(GdkRectangle) {
attributes.height = gtk_adjustment_get_upper (vadjustment); - gtk_adjustment_get_value (hadjustment),
- gtk_adjustment_get_value (vadjustment),
attributes.event_mask = event_mask; gtk_adjustment_get_upper (hadjustment),
gtk_adjustment_get_upper (vadjustment)});
priv->bin_window = gdk_window_new (priv->view_window, &attributes, attributes_mask);
gtk_widget_register_window (widget, priv->bin_window); gtk_widget_register_window (widget, priv->bin_window);
gdk_window_set_invalidate_handler (priv->bin_window, gdk_window_set_invalidate_handler (priv->bin_window,
gtk_viewport_bin_window_invalidate_handler); gtk_viewport_bin_window_invalidate_handler);