X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;ds=sidebyside;f=src%2Futil%2Farea.c;h=acce72550f109e8a847b539aca23f7521fe2ab34;hb=8abd6d423bffc9cd35928e1911c138163f7dbda9;hp=62bb2f212ad720be929d4b0a211929611b298676;hpb=21dcd195642692401f855ef07b239364b5ef0c1b;p=chaz%2Ftint2 diff --git a/src/util/area.c b/src/util/area.c index 62bb2f2..acce725 100644 --- a/src/util/area.c +++ b/src/util/area.c @@ -20,6 +20,7 @@ #include #include #include +#include #include #include #include @@ -110,8 +111,7 @@ void draw (Area *a, int active) // 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); + XCopyArea (server.dsp, ((Panel *)a->panel)->temp_pmap, *pmap, server.gc, a->posx, a->posy, a->width, a->height, 0, 0); cairo_surface_t *cs; cairo_t *c; @@ -253,13 +253,8 @@ 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); - + Picture pict = XRenderCreatePicture(server.dsp, p, XRenderFindVisualFormat(server.dsp, server.visual), 0, 0); + XRenderColor col = { .red=0, .green=0, .blue=0, .alpha=0 }; + XRenderFillRectangle(server.dsp, PictOpSrc, pict, &col, x, y, w, h); + XRenderFreePicture(server.dsp, pict); }