Raise pane window on resize if it's not sticky

This commit is contained in:
Yevgen Muntyan 2005-09-11 17:50:31 +00:00
parent 800a1114a0
commit 365dc2cf6a

View File

@ -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,