X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Futil%2Farea.c;h=62bb2f212ad720be929d4b0a211929611b298676;hb=21dcd195642692401f855ef07b239364b5ef0c1b;hp=fc80a89d629584c1e6dc2a19a11015adc1fd15ed;hpb=be465e9a323ee71d7a6ab71040a117d3d64db813;p=chaz%2Ftint2 diff --git a/src/util/area.c b/src/util/area.c index fc80a89..62bb2f2 100644 --- a/src/util/area.c +++ b/src/util/area.c @@ -107,17 +107,9 @@ void draw (Area *a, int active) if (*pmap) XFreePixmap (server.dsp, *pmap); *pmap = XCreatePixmap (server.dsp, server.root_win, a->width, a->height, server.depth); - // add layer of root pixmap - if (real_transparency) { - cairo_surface_t *tmp = cairo_xlib_surface_create (server.dsp, *pmap, server.visual, a->width, a->height); - cairo_t *cr = cairo_create(tmp); - cairo_set_operator (cr, CAIRO_OPERATOR_SOURCE); - cairo_rectangle(cr, 0, 0, a->width, a->height); - cairo_set_source_rgba(cr, 1, 1, 1, 0); - cairo_paint (cr); - cairo_destroy (cr); - cairo_surface_destroy (tmp); - } + // add layer of root pixmap (or clear pixmap if real_transparency==true) + if (real_transparency) + clear_pixmap(*pmap, 0 ,0, a->width, a->height); else XCopyArea (server.dsp, ((Panel *)a->panel)->temp_pmap, *pmap, server.gc, a->posx, a->posy, a->width, a->height, 0, 0); @@ -259,3 +251,15 @@ void draw_rect(cairo_t *c, double x, double y, double w, double h, double r) } +void clear_pixmap(Pixmap p, int x, int y, int w, int h) +{ + cairo_surface_t *tmp = cairo_xlib_surface_create (server.dsp, p, server.visual, w, h); + cairo_t *cr = cairo_create(tmp); + cairo_set_operator (cr, CAIRO_OPERATOR_SOURCE); + cairo_rectangle(cr, x, y, w, h); + cairo_set_source_rgba(cr, 1, 1, 1, 0); + cairo_fill(cr); + cairo_destroy(cr); + cairo_surface_destroy (tmp); + +}