extern "C" {
#endif /* __cplusplus */
+#include <X11/Xlib.h>
+#include <X11/Xutil.h>
+#include <X11/Xatom.h>
+
#define IS_ONSCREEN(x,y) ((x >= G_MINSHORT) && (x <= G_MAXSHORT) && \
(y >= G_MINSHORT) && (y <= G_MAXSHORT))
pizza->height = 20;
pizza->bin_window = NULL;
+
+ pizza->xoffset = 0;
+ pizza->yoffset = 0;
pizza->configure_serial = 0;
pizza->scroll_x = 0;
pizza->visibility = GDK_VISIBILITY_PARTIAL;
pizza->clear_on_draw = TRUE;
+ pizza->use_filter = FALSE;
}
GtkWidget*
void
gtk_pizza_set_shadow_type (GtkPizza *pizza,
- GtkMyShadowType type)
+ GtkMyShadowType type)
{
g_return_if_fail (pizza != NULL);
g_return_if_fail (GTK_IS_PIZZA (pizza));
void
gtk_pizza_set_clear (GtkPizza *pizza,
- gboolean clear)
+ gboolean clear)
{
g_return_if_fail (pizza != NULL);
g_return_if_fail (GTK_IS_PIZZA (pizza));
pizza->clear_on_draw = clear;
}
+void
+gtk_pizza_set_filter (GtkPizza *pizza,
+ gboolean use)
+{
+ g_return_if_fail (pizza != NULL);
+ g_return_if_fail (GTK_IS_PIZZA (pizza));
+
+ pizza->use_filter = use;
+}
+
void
gtk_pizza_put (GtkPizza *pizza,
GtkWidget *widget,
if (!IS_ONSCREEN (x, y))
GTK_PRIVATE_SET_FLAG (widget, GTK_IS_OFFSCREEN);
+/*
if (GTK_WIDGET_REALIZED (pizza))
gtk_widget_realize (widget);
+*/
gtk_widget_set_usize (widget, width, height);
+/*
if (GTK_WIDGET_VISIBLE (pizza) && GTK_WIDGET_VISIBLE (widget))
{
if (GTK_WIDGET_MAPPED (pizza))
gtk_widget_queue_resize (widget);
}
+*/
}
void
GDK_VISIBILITY_NOTIFY_MASK;
attributes_mask = GDK_WA_X | GDK_WA_Y | GDK_WA_VISUAL | GDK_WA_COLORMAP;
- widget->window = gdk_window_new (gtk_widget_get_parent_window (widget),
+ widget->window = gdk_window_new(gtk_widget_get_parent_window (widget),
&attributes, attributes_mask);
gdk_window_set_user_data (widget->window, widget);
GDK_LEAVE_NOTIFY_MASK |
GDK_FOCUS_CHANGE_MASK;
- pizza->bin_window = gdk_window_new (widget->window,
+ pizza->bin_window = gdk_window_new(widget->window,
&attributes, attributes_mask);
gdk_window_set_user_data (pizza->bin_window, widget);
pizza = GTK_PIZZA (widget);
-/*
- if (event->window == widget->window)
- {
- gtk_pizza_draw_border( pizza );
- return FALSE;
- }
-*/
-
if (event->window != pizza->bin_window)
return FALSE;
gint dx,
gint dy)
{
- GList *tmp_list;
- GtkPizzaAdjData data;
+ GList *tmp_list;
+ GtkPizzaAdjData data;
- data.dx = dx;
- data.dy = dy;
+ data.dx = dx;
+ data.dy = dy;
- tmp_list = pizza->children;
- while (tmp_list)
+ tmp_list = pizza->children;
+ while (tmp_list)
{
- GtkPizzaChild *child = tmp_list->data;
- tmp_list = tmp_list->next;
+ GtkPizzaChild *child = tmp_list->data;
+ tmp_list = tmp_list->next;
- child->widget->allocation.x += dx;
- child->widget->allocation.y += dy;
+ child->widget->allocation.x += dx;
+ child->widget->allocation.y += dy;
- if (GTK_WIDGET_NO_WINDOW (child->widget) &&
- GTK_IS_CONTAINER (child->widget))
- gtk_container_forall (GTK_CONTAINER (child->widget),
- gtk_pizza_adjust_allocations_recurse,
- &data);
+ if (GTK_WIDGET_NO_WINDOW (child->widget) &&
+ GTK_IS_CONTAINER (child->widget))
+ {
+ gtk_container_forall (GTK_CONTAINER (child->widget),
+ gtk_pizza_adjust_allocations_recurse,
+ &data);
+ }
}
}
gtk_pizza_expose_area (GtkPizza *pizza,
gint x, gint y, gint width, gint height)
{
- if (pizza->visibility == GDK_VISIBILITY_UNOBSCURED)
+ if (pizza->visibility == GDK_VISIBILITY_UNOBSCURED)
{
- GdkEventExpose event;
+ GdkEventExpose event;
- event.type = GDK_EXPOSE;
- event.send_event = TRUE;
- event.window = pizza->bin_window;
- event.count = 0;
+ event.type = GDK_EXPOSE;
+ event.send_event = TRUE;
+ event.window = pizza->bin_window;
+ event.count = 0;
- event.area.x = x;
- event.area.y = y;
- event.area.width = width;
- event.area.height = height;
+ event.area.x = x;
+ event.area.y = y;
+ event.area.width = width;
+ event.area.height = height;
- gdk_window_ref (event.window);
- gtk_widget_event (GTK_WIDGET (pizza), (GdkEvent *)&event);
- gdk_window_unref (event.window);
+ gdk_window_ref (event.window);
+ gtk_widget_event (GTK_WIDGET (pizza), (GdkEvent *)&event);
+ gdk_window_unref (event.window);
}
}
GdkEvent *event,
gpointer data)
{
- XEvent *xevent;
- GtkPizza *pizza;
-
- xevent = (XEvent *)gdk_xevent;
- pizza = GTK_PIZZA (data);
+ XEvent *xevent;
+ GtkPizza *pizza;
+ xevent = (XEvent *)gdk_xevent;
+
+ pizza = GTK_PIZZA (data);
+
switch (xevent->type)
{
case Expose:
break;
}
- return GDK_FILTER_CONTINUE;
+ return GDK_FILTER_CONTINUE;
}
/* Although GDK does have a GDK_VISIBILITY_NOTIFY event,
GdkEvent *event,
gpointer data)
{
- XEvent *xevent;
- GtkPizza *pizza;
+ XEvent *xevent;
+ GtkPizza *pizza;
- xevent = (XEvent *)gdk_xevent;
- pizza = GTK_PIZZA (data);
+ xevent = (XEvent *)gdk_xevent;
+ pizza = GTK_PIZZA (data);
- if (xevent->type == VisibilityNotify)
+ if (xevent->type == VisibilityNotify)
{
- switch (xevent->xvisibility.state)
+ switch (xevent->xvisibility.state)
{
- case VisibilityFullyObscured:
- pizza->visibility = GDK_VISIBILITY_FULLY_OBSCURED;
- break;
+ case VisibilityFullyObscured:
+ pizza->visibility = GDK_VISIBILITY_FULLY_OBSCURED;
+ break;
- case VisibilityPartiallyObscured:
- pizza->visibility = GDK_VISIBILITY_PARTIAL;
- break;
+ case VisibilityPartiallyObscured:
+ pizza->visibility = GDK_VISIBILITY_PARTIAL;
+ break;
- case VisibilityUnobscured:
- pizza->visibility = GDK_VISIBILITY_UNOBSCURED;
- break;
+ case VisibilityUnobscured:
+ pizza->visibility = GDK_VISIBILITY_UNOBSCURED;
+ break;
}
-
- return GDK_FILTER_REMOVE;
+
+ return GDK_FILTER_REMOVE;
}
-
- return GDK_FILTER_CONTINUE;
+ return GDK_FILTER_CONTINUE;
}