GtkRequisition *requisition);
static void gtk_pizza_size_allocate (GtkWidget *widget,
GtkAllocation *allocation);
-static gint gtk_pizza_expose (GtkWidget *widget,
- GdkEventExpose *event);
static void gtk_pizza_style_set (GtkWidget *widget,
GtkStyle *previous_style);
static void gtk_pizza_add (GtkContainer *container,
widget_class->unrealize = gtk_pizza_unrealize;
widget_class->size_request = gtk_pizza_size_request;
widget_class->size_allocate = gtk_pizza_size_allocate;
- widget_class->expose_event = gtk_pizza_expose;
widget_class->style_set = gtk_pizza_style_set;
container_class->add = gtk_pizza_add;
gint gtk_pizza_get_rtl_offset (GtkPizza *pizza)
{
- gint width;
gint border;
g_return_val_if_fail ( (pizza != NULL), 0 );
if (!pizza->bin_window) return 0;
- gdk_window_get_geometry( pizza->bin_window, NULL, NULL, &width, NULL, NULL );
-
border = pizza->container.border_width;
- return width-border*2;
+ return GTK_WIDGET(pizza)->allocation.width - border*2;
}
g_return_if_fail (GTK_IS_PIZZA (pizza));
g_return_if_fail (widget != NULL);
- if (gtk_widget_get_direction( GTK_WIDGET(pizza) ) == GTK_TEXT_DIR_RTL)
- {
- /* reverse horizontal placement */
- x = GTK_WIDGET(pizza)->allocation.width - x - width;
- }
-
child_info = g_new (GtkPizzaChild, 1);
child_info->widget = widget;
pizza->children = g_list_append (pizza->children, child_info);
if (GTK_WIDGET_REALIZED (pizza))
- gtk_widget_set_parent_window (widget, pizza->bin_window);
+ gtk_widget_set_parent_window (widget, pizza->bin_window);
gtk_widget_set_parent (widget, GTK_WIDGET (pizza));
- gtk_widget_set_size_request (widget, width, height);
+ gtk_widget_set_size_request( widget, width, height );
+ if (GTK_WIDGET_REALIZED (pizza))
+ gtk_pizza_allocate_child (pizza, child_info);
}
void
widget->allocation = *allocation;
border = pizza->container.border_width;
+
x = allocation->x + border;
y = allocation->y + border;
w = allocation->width - border*2;
}
}
-static gint
-gtk_pizza_expose (GtkWidget *widget,
- GdkEventExpose *event)
-{
- GtkPizza *pizza;
-
- g_return_val_if_fail (widget != NULL, FALSE);
- g_return_val_if_fail (GTK_IS_PIZZA (widget), FALSE);
- g_return_val_if_fail (event != NULL, FALSE);
-
- pizza = (GtkPizza*)widget;
-
- if (event->window != pizza->bin_window)
- return FALSE;
-
- pizza_parent_class->expose_event(widget, event);
-
- return FALSE;
-}
-
static void
gtk_pizza_style_set(GtkWidget *widget, GtkStyle *previous_style)
{
border = pizza->container.border_width;
offset -= border*2;
- allocation.x = offset - child->x - allocation.width - pizza->m_xoffset;
+ allocation.x = offset - child->x - allocation.width + pizza->m_xoffset;
}
gtk_widget_size_allocate (child->widget, &allocation);