Fix compilation against latest GTK+-3 changes

Adjust to GDK/GTK+ API changes:
 - removal of GdkColormap
 - expose-event -> draw transition

https://bugzilla.gnome.org/show_bug.cgi?id=630641
This commit is contained in:
Florian Müllner 2010-09-27 10:45:28 +02:00
parent 1b2a1a3a3d
commit fe5a289460
3 changed files with 50 additions and 83 deletions

View File

@ -218,57 +218,36 @@ shell_tray_manager_manage_stage (ShellTrayManager *manager,
else else
stage_window = gdk_window_foreign_new (stage_xwindow); stage_window = gdk_window_foreign_new (stage_xwindow);
screen = gdk_drawable_get_screen (stage_window); screen = gdk_window_get_screen (stage_window);
g_object_unref (stage_window); g_object_unref (stage_window);
na_tray_manager_manage_screen (manager->priv->na_manager, screen); na_tray_manager_manage_screen (manager->priv->na_manager, screen);
} }
static GdkPixmap *
create_bg_pixmap (GdkColormap *colormap,
ClutterColor *color)
{
GdkScreen *screen = gdk_colormap_get_screen (colormap);
GdkVisual *visual = gdk_colormap_get_visual (colormap);
GdkPixmap *pixmap = gdk_pixmap_new (gdk_screen_get_root_window (screen),
1, 1,
gdk_visual_get_depth (visual));
cairo_t *cr;
gdk_drawable_set_colormap (pixmap, colormap);
cr = gdk_cairo_create (pixmap);
cairo_set_source_rgb (cr,
color->red / 255.,
color->green / 255.,
color->blue / 255.);
cairo_paint (cr);
cairo_destroy (cr);
return pixmap;
}
static void static void
shell_tray_manager_child_on_realize (GtkWidget *widget, shell_tray_manager_child_on_realize (GtkWidget *widget,
ShellTrayManagerChild *child) ShellTrayManagerChild *child)
{ {
GdkPixmap *bg_pixmap;
/* If the tray child is using an RGBA colormap (and so we have real /* If the tray child is using an RGBA colormap (and so we have real
* transparency), we don't need to worry about the background. If * transparency), we don't need to worry about the background. If
* not, we obey the bg-color property by creating a 1x1 pixmap of * not, we obey the bg-color property by creating a cairo pattern of
* that color and setting it as our background. Then "parent-relative" * that color and setting it as our background. Then "parent-relative"
* background on the socket and the plug within that will cause * background on the socket and the plug within that will cause
* the icons contents to appear on top of our background color. * the icons contents to appear on top of our background color.
*/ */
if (!na_tray_child_has_alpha (NA_TRAY_CHILD (child->socket))) if (!na_tray_child_has_alpha (NA_TRAY_CHILD (child->socket)))
{ {
bg_pixmap = create_bg_pixmap (gtk_widget_get_colormap (widget), ClutterColor color = child->manager->priv->bg_color;
&child->manager->priv->bg_color); cairo_pattern_t *bg_pattern;
gdk_window_set_back_pixmap (gtk_widget_get_window (widget),
bg_pixmap, FALSE); bg_pattern = cairo_pattern_create_rgb (color.red / 255.,
g_object_unref (bg_pixmap); color.green / 255.,
color.blue / 255.);
gdk_window_set_background_pattern (gtk_widget_get_window (widget),
bg_pattern);
cairo_pattern_destroy (bg_pattern);
} }
} }
@ -306,9 +285,9 @@ na_tray_icon_added (NaTrayManager *na_manager, GtkWidget *socket,
win = shell_embedded_window_new (manager->priv->stage); win = shell_embedded_window_new (manager->priv->stage);
gtk_container_add (GTK_CONTAINER (win), socket); gtk_container_add (GTK_CONTAINER (win), socket);
/* The colormap of the socket matches that of its contents; make /* The visual of the socket matches that of its contents; make
* the window we put it in match that as well */ * the window we put it in match that as well */
gtk_widget_set_colormap (win, gtk_widget_get_colormap (socket)); gtk_widget_set_visual (win, gtk_widget_get_visual (socket));
child = g_slice_new0 (ShellTrayManagerChild); child = g_slice_new0 (ShellTrayManagerChild);
child->manager = manager; child->manager = manager;

View File

@ -55,17 +55,18 @@ na_tray_child_realize (GtkWidget *widget)
* extension. */ * extension. */
/* Set a transparent background */ /* Set a transparent background */
GdkColor transparent = { 0, 0, 0, 0 }; /* only pixel=0 matters */ cairo_pattern_t *transparent = cairo_pattern_create_rgba (0, 0, 0, 0);
gdk_window_set_background (window, &transparent); gdk_window_set_background_pattern (window, transparent);
gdk_window_set_composited (window, TRUE); gdk_window_set_composited (window, TRUE);
cairo_pattern_destroy (transparent);
child->parent_relative_bg = FALSE; child->parent_relative_bg = FALSE;
} }
else if (visual == gdk_drawable_get_visual (GDK_DRAWABLE (gdk_window_get_parent (window)))) else if (visual == gdk_window_get_visual (gdk_window_get_parent (window)))
{ {
/* Otherwise, if the visual matches the visual of the parent window, we /* Otherwise, if the visual matches the visual of the parent window, we
* can use a parent-relative background and fake transparency. */ * can use a parent-relative background and fake transparency. */
gdk_window_set_back_pixmap (window, NULL, TRUE); gdk_window_set_background_pattern (window, NULL);
child->parent_relative_bg = TRUE; child->parent_relative_bg = TRUE;
} }
@ -174,31 +175,46 @@ na_tray_child_size_allocate (GtkWidget *widget,
/* The plug window should completely occupy the area of the child, so we won't /* The plug window should completely occupy the area of the child, so we won't
* get an expose event. But in case we do (the plug unmaps itself, say), this * get an expose event. But in case we do (the plug unmaps itself, say), this
* expose handler draws with real or fake transparency. * draw handler draws with real or fake transparency.
* Copy-pasted from GtkTrayIcon.
*/ */
static gboolean static gboolean
na_tray_child_expose_event (GtkWidget *widget, na_tray_child_draw (GtkWidget *widget,
GdkEventExpose *event) cairo_t *cr)
{ {
NaTrayChild *child = NA_TRAY_CHILD (widget); NaTrayChild *child = NA_TRAY_CHILD (widget);
GdkWindow *window = gtk_widget_get_window (widget);
if (na_tray_child_has_alpha (child)) if (na_tray_child_has_alpha (child))
{ {
/* Clear to transparent */ /* Clear to transparent */
cairo_t *cr = gdk_cairo_create (window);
cairo_set_source_rgba (cr, 0, 0, 0, 0); cairo_set_source_rgba (cr, 0, 0, 0, 0);
cairo_set_operator (cr, CAIRO_OPERATOR_SOURCE); cairo_set_operator (cr, CAIRO_OPERATOR_SOURCE);
gdk_cairo_region (cr, event->region); cairo_paint (cr);
cairo_fill (cr);
cairo_destroy (cr);
} }
else if (child->parent_relative_bg) else if (child->parent_relative_bg)
{ {
/* Clear to parent-relative pixmap */ GdkWindow *window;
gdk_window_clear_area (window, cairo_surface_t *target;
event->area.x, event->area.y, GdkRectangle clip_rect;
event->area.width, event->area.height);
window = gtk_widget_get_window (widget);
target = cairo_get_group_target (cr);
gdk_cairo_get_clip_rectangle (cr, &clip_rect);
/* Clear to parent-relative pixmap
* We need to use direct X access here because GDK doesn't know about
* the parent relative pixmap. */
cairo_surface_flush (target);
XClearArea (GDK_WINDOW_XDISPLAY (window),
GDK_WINDOW_XID (window),
clip_rect.x, clip_rect.y,
clip_rect.width, clip_rect.height,
False);
cairo_surface_mark_dirty_rectangle (target,
clip_rect.x, clip_rect.y,
clip_rect.width, clip_rect.height);
} }
return FALSE; return FALSE;
@ -222,7 +238,7 @@ na_tray_child_class_init (NaTrayChildClass *klass)
widget_class->style_set = na_tray_child_style_set; widget_class->style_set = na_tray_child_style_set;
widget_class->realize = na_tray_child_realize; widget_class->realize = na_tray_child_realize;
widget_class->size_allocate = na_tray_child_size_allocate; widget_class->size_allocate = na_tray_child_size_allocate;
widget_class->expose_event = na_tray_child_expose_event; widget_class->draw = na_tray_child_draw;
} }
GtkWidget * GtkWidget *
@ -234,8 +250,6 @@ na_tray_child_new (GdkScreen *screen,
NaTrayChild *child; NaTrayChild *child;
GdkVisual *visual; GdkVisual *visual;
gboolean visual_has_alpha; gboolean visual_has_alpha;
GdkColormap *colormap;
gboolean new_colormap;
int red_prec, green_prec, blue_prec, depth; int red_prec, green_prec, blue_prec, depth;
int result; int result;
@ -261,22 +275,10 @@ na_tray_child_new (GdkScreen *screen,
if (!visual) /* Icon window is on another screen? */ if (!visual) /* Icon window is on another screen? */
return NULL; return NULL;
new_colormap = FALSE;
if (visual == gdk_screen_get_rgba_visual (screen))
colormap = gdk_screen_get_rgba_colormap (screen);
else if (visual == gdk_screen_get_system_visual (screen))
colormap = gdk_screen_get_system_colormap (screen);
else
{
colormap = gdk_colormap_new (visual, FALSE);
new_colormap = TRUE;
}
child = g_object_new (NA_TYPE_TRAY_CHILD, NULL); child = g_object_new (NA_TYPE_TRAY_CHILD, NULL);
child->icon_window = icon_window; child->icon_window = icon_window;
gtk_widget_set_colormap (GTK_WIDGET (child), colormap); gtk_widget_set_visual (GTK_WIDGET (child), visual);
/* We have alpha if the visual has something other than red, green, /* We have alpha if the visual has something other than red, green,
* and blue */ * and blue */
@ -291,9 +293,6 @@ na_tray_child_new (GdkScreen *screen,
child->composited = child->has_alpha; child->composited = child->has_alpha;
if (new_colormap)
g_object_unref (colormap);
return GTK_WIDGET (child); return GTK_WIDGET (child);
} }

View File

@ -639,20 +639,9 @@ na_tray_manager_set_visual_property (NaTrayManager *manager)
if (gdk_screen_get_rgba_visual (manager->screen) != NULL && if (gdk_screen_get_rgba_visual (manager->screen) != NULL &&
gdk_display_supports_composite (display)) gdk_display_supports_composite (display))
{
xvisual = GDK_VISUAL_XVISUAL (gdk_screen_get_rgba_visual (manager->screen)); xvisual = GDK_VISUAL_XVISUAL (gdk_screen_get_rgba_visual (manager->screen));
}
else else
{ xvisual = GDK_VISUAL_XVISUAL (gdk_screen_get_system_visual (manager->screen));
/* We actually want the visual of the tray where the icons will
* be embedded. In almost all cases, this will be the same as the visual
* of the screen.
*/
GdkColormap *colormap;
colormap = gdk_screen_get_default_colormap (manager->screen);
xvisual = GDK_VISUAL_XVISUAL (gdk_colormap_get_visual (colormap));
}
data[0] = XVisualIDFromVisual (xvisual); data[0] = XVisualIDFromVisual (xvisual);