diff options
| author | infirit <[email protected]> | 2015-07-26 01:22:31 +0200 | 
|---|---|---|
| committer | infirit <[email protected]> | 2015-07-28 12:44:04 +0200 | 
| commit | fe992fa646e9ed9aede105261b297204bad74491 (patch) | |
| tree | 02dd38fda29f8f32b9f091910272340d860bcbc5 | |
| parent | e7d2688990388a99baaccb01c61889ca479340a6 (diff) | |
| download | mate-notification-daemon-fe992fa646e9ed9aede105261b297204bad74491.tar.bz2 mate-notification-daemon-fe992fa646e9ed9aede105261b297204bad74491.tar.xz | |
coco: Shape windows without compositing
| -rw-r--r-- | src/themes/coco/coco-theme.c | 109 | 
1 files changed, 109 insertions, 0 deletions
| diff --git a/src/themes/coco/coco-theme.c b/src/themes/coco/coco-theme.c index 5d374ea..1ffbc2f 100644 --- a/src/themes/coco/coco-theme.c +++ b/src/themes/coco/coco-theme.c @@ -49,6 +49,8 @@ typedef struct  	int width;  	int height; +	int last_width; +	int last_height;  	guchar urgency;  	glong timeout; @@ -162,6 +164,98 @@ draw_pie(GtkWidget *pie, WindowData *windata, cairo_t *cr)  	cairo_fill (cr);   } +#if GTK_CHECK_VERSION (3, 0, 0) +static void +update_shape_region (cairo_surface_t *surface, +		     WindowData      *windata) +{ +	cairo_region_t *region; + +	if (windata->width == windata->last_width && windata->height == windata->last_height) +	{ +		return; +	} + +	if (windata->width == 0 || windata->height == 0) +	{ +		GtkAllocation allocation; +		gtk_widget_get_allocation (windata->win, &allocation); + +		windata->width = MAX (allocation.width, 1); +		windata->height = MAX (allocation.height, 1); +	} + +	if (!windata->composited) { +		cairo_region_t *region; + +		region = gdk_cairo_region_create_from_surface (surface); +		gtk_widget_shape_combine_region (windata->win, region); +		cairo_region_destroy (region); +	} else { +		gtk_widget_shape_combine_region (windata->win, NULL); +		return; +	} + +	windata->last_width = windata->width; +	windata->last_height = windata->height; +} +#else +static void +update_shape_mask (WindowData* windata) +{ +	cairo_t *cr; +	GdkBitmap* mask; + +	if (windata->width == windata->last_width && windata->height == windata->last_height) +	{ +		return; +	} + +	if (windata->width == 0 || windata->height == 0) +	{ +		GtkAllocation allocation; + +		gtk_widget_get_allocation (windata->win, &allocation); + +		windata->width = MAX (allocation.width, 1); +		windata->height = MAX (allocation.height, 1); +	} + +	if (windata->composited) +	{ +		gtk_widget_shape_combine_mask (windata->win, NULL, 0, 0); +		return; +	} + +	windata->last_width = windata->width; +	windata->last_height = windata->height; + +	mask = (GdkBitmap*) gdk_pixmap_new (NULL, windata->width, windata->height, 1); + +	if (mask == NULL) +	{ +		return; +	} +	cr = gdk_cairo_create (mask); + +	if (cairo_status (cr) == CAIRO_STATUS_SUCCESS) +	{ +		cairo_set_operator (cr, CAIRO_OPERATOR_CLEAR); +		cairo_paint (cr); + +		cairo_set_operator (cr, CAIRO_OPERATOR_OVER); +		cairo_set_source_rgb (cr, 1.0f, 1.0f, 1.0f); +		nodoka_rounded_rectangle (cr, 0, 0, windata->width , windata->height, 6); +		cairo_fill (cr); + +		gtk_widget_shape_combine_mask (windata->win, mask, 0, 0); +	} + +	cairo_destroy (cr); +	g_object_unref (mask); +} +#endif +  static gboolean  paint_window(GtkWidget *widget,  #if GTK_CHECK_VERSION (3, 0, 0) @@ -208,6 +302,12 @@ paint_window(GtkWidget *widget,  	cairo_paint (cr);  	cairo_restore (cr); +#if GTK_CHECK_VERSION (3, 0, 0) +	update_shape_region (surface, windata); +#else +	update_shape_mask (windata); +#endif +  	cairo_surface_destroy (surface);  #if !GTK_CHECK_VERSION (3, 0, 0)  	cairo_destroy(cr); @@ -286,6 +386,13 @@ static gboolean on_configure_event (GtkWidget* widget, GdkEventConfigure* event,  	return FALSE;  } +static void on_composited_changed (GtkWidget* window, WindowData* windata) +{ +	windata->composited = gdk_screen_is_composited (gtk_widget_get_screen(window)); + +	gtk_widget_queue_draw (window); +} +  static void  action_clicked_cb(GtkWidget *w, GdkEventButton *event,  				  ActionInvokedCb action_cb) @@ -408,6 +515,8 @@ create_notification(UrlClickedCb url_clicked)  	g_signal_connect (G_OBJECT (win), "configure-event", G_CALLBACK (on_configure_event), windata); +	g_signal_connect (G_OBJECT (win), "composited-changed", G_CALLBACK (on_composited_changed), windata); +      padding = gtk_alignment_new(0, 0, 0, 0);  	gtk_widget_show(padding);  	gtk_box_pack_start(GTK_BOX(main_vbox), padding, FALSE, FALSE, 0); | 
