Raise pane window on resize if it's not sticky
This commit is contained in:
parent
800a1114a0
commit
365dc2cf6a
@ -61,6 +61,7 @@ struct _MooPanedPrivate {
|
|||||||
|
|
||||||
GdkWindow *handle_window;
|
GdkWindow *handle_window;
|
||||||
GdkWindow *pane_window;
|
GdkWindow *pane_window;
|
||||||
|
gboolean raise_pane; /* need to raise pane window in size_allocate */
|
||||||
|
|
||||||
/* XXX weak pointer */
|
/* XXX weak pointer */
|
||||||
GtkWidget *focus_child; /* focused grandchild of bin->child */
|
GtkWidget *focus_child; /* focused grandchild of bin->child */
|
||||||
@ -424,8 +425,6 @@ static void moo_paned_init (MooPaned *paned)
|
|||||||
paned->priv->handle_prelit = FALSE;
|
paned->priv->handle_prelit = FALSE;
|
||||||
paned->priv->in_drag = FALSE;
|
paned->priv->in_drag = FALSE;
|
||||||
paned->priv->drag_start = -1;
|
paned->priv->drag_start = -1;
|
||||||
|
|
||||||
gtk_widget_set_redraw_on_allocate (GTK_WIDGET (paned), FALSE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -463,8 +462,6 @@ static GObject *moo_paned_constructor (GType type,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
gtk_widget_set_redraw_on_allocate (paned->button_box, FALSE);
|
|
||||||
|
|
||||||
gtk_object_sink (GTK_OBJECT (g_object_ref (paned->button_box)));
|
gtk_object_sink (GTK_OBJECT (g_object_ref (paned->button_box)));
|
||||||
gtk_widget_set_parent (paned->button_box, GTK_WIDGET (paned));
|
gtk_widget_set_parent (paned->button_box, GTK_WIDGET (paned));
|
||||||
gtk_widget_show (paned->button_box);
|
gtk_widget_show (paned->button_box);
|
||||||
@ -1304,32 +1301,12 @@ static void moo_paned_size_allocate (GtkWidget *widget,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (GTK_WIDGET_REALIZED (widget))
|
if (GTK_WIDGET_REALIZED (widget))
|
||||||
{
|
|
||||||
GdkRectangle rect;
|
|
||||||
|
|
||||||
gdk_window_move_resize (widget->window,
|
gdk_window_move_resize (widget->window,
|
||||||
allocation->x,
|
allocation->x,
|
||||||
allocation->y,
|
allocation->y,
|
||||||
allocation->width,
|
allocation->width,
|
||||||
allocation->height);
|
allocation->height);
|
||||||
|
|
||||||
if (paned->priv->pane_widget_visible)
|
|
||||||
{
|
|
||||||
get_pane_window_rect (paned, &rect);
|
|
||||||
gdk_window_move_resize (paned->priv->pane_window,
|
|
||||||
rect.x, rect.y,
|
|
||||||
rect.width, rect.height);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (paned->priv->handle_visible)
|
|
||||||
{
|
|
||||||
get_handle_window_rect (paned, &rect);
|
|
||||||
gdk_window_move_resize (paned->priv->handle_window,
|
|
||||||
rect.x, rect.y,
|
|
||||||
rect.width, rect.height);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (paned->priv->button_box_visible)
|
if (paned->priv->button_box_visible)
|
||||||
{
|
{
|
||||||
get_button_box_allocation (paned, &child_allocation);
|
get_button_box_allocation (paned, &child_allocation);
|
||||||
@ -1342,6 +1319,33 @@ static void moo_paned_size_allocate (GtkWidget *widget,
|
|||||||
gtk_widget_size_allocate (bin->child, &child_allocation);
|
gtk_widget_size_allocate (bin->child, &child_allocation);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (GTK_WIDGET_REALIZED (widget))
|
||||||
|
{
|
||||||
|
GdkRectangle rect;
|
||||||
|
|
||||||
|
if (paned->priv->pane_widget_visible)
|
||||||
|
{
|
||||||
|
get_pane_window_rect (paned, &rect);
|
||||||
|
gdk_window_move_resize (paned->priv->pane_window,
|
||||||
|
rect.x, rect.y,
|
||||||
|
rect.width, rect.height);
|
||||||
|
|
||||||
|
if (paned->priv->raise_pane)
|
||||||
|
{
|
||||||
|
gdk_window_raise (paned->priv->pane_window);
|
||||||
|
paned->priv->raise_pane = FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (paned->priv->handle_visible)
|
||||||
|
{
|
||||||
|
get_handle_window_rect (paned, &rect);
|
||||||
|
gdk_window_move_resize (paned->priv->handle_window,
|
||||||
|
rect.x, rect.y,
|
||||||
|
rect.width, rect.height);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (paned->priv->pane_widget_visible)
|
if (paned->priv->pane_widget_visible)
|
||||||
{
|
{
|
||||||
get_pane_widget_allocation (paned, &child_allocation);
|
get_pane_widget_allocation (paned, &child_allocation);
|
||||||
@ -1667,14 +1671,21 @@ void moo_paned_set_sticky_pane (MooPaned *paned,
|
|||||||
sticky = TRUE;
|
sticky = TRUE;
|
||||||
|
|
||||||
g_return_if_fail (MOO_IS_PANED (paned));
|
g_return_if_fail (MOO_IS_PANED (paned));
|
||||||
|
|
||||||
if (paned->priv->sticky != sticky && GTK_WIDGET_REALIZED (paned))
|
if (paned->priv->sticky != sticky && GTK_WIDGET_REALIZED (paned))
|
||||||
gtk_widget_queue_resize (GTK_WIDGET (paned));
|
gtk_widget_queue_resize (GTK_WIDGET (paned));
|
||||||
|
|
||||||
paned->priv->sticky = sticky;
|
paned->priv->sticky = sticky;
|
||||||
|
|
||||||
for (l = paned->priv->panes; l != NULL; l = l->next)
|
for (l = paned->priv->panes; l != NULL; l = l->next)
|
||||||
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (((Pane*)l->data)->sticky_button),
|
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (((Pane*)l->data)->sticky_button),
|
||||||
sticky);
|
sticky);
|
||||||
|
|
||||||
|
/* this is needed because bin child may
|
||||||
|
move its window on top of the pane window */
|
||||||
|
if (!sticky && paned->priv->current_pane)
|
||||||
|
paned->priv->raise_pane = TRUE;
|
||||||
|
|
||||||
g_object_notify (G_OBJECT (paned), "sticky-pane");
|
g_object_notify (G_OBJECT (paned), "sticky-pane");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2318,7 +2329,6 @@ int moo_paned_insert_pane (MooPaned *paned,
|
|||||||
|
|
||||||
button = gtk_toggle_button_new ();
|
button = gtk_toggle_button_new ();
|
||||||
gtk_widget_show (button);
|
gtk_widget_show (button);
|
||||||
gtk_widget_set_redraw_on_allocate (button, FALSE);
|
|
||||||
gtk_button_set_focus_on_click (GTK_BUTTON (button), FALSE);
|
gtk_button_set_focus_on_click (GTK_BUTTON (button), FALSE);
|
||||||
|
|
||||||
label_widget = moo_pane_label_get_widget (pane_label,
|
label_widget = moo_pane_label_get_widget (pane_label,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user