X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=src%2Futil%2Farea.h;h=fc294f3ea7fdd69358f2a12d32da8637b7f536cf;hb=55eb2b64056f1fe6c15cabf1afc3e6d9aba56a11;hp=5ddd0c3a95e773ba72814c2e05d33cb3195ce78b;hpb=2cccd91fa633d9bfefd46073981276cb29fda5e7;p=chaz%2Ftint2 diff --git a/src/util/area.h b/src/util/area.h index 5ddd0c3..fc294f3 100644 --- a/src/util/area.h +++ b/src/util/area.h @@ -5,7 +5,7 @@ * Area is at the begining of each object (&object == &area). * * Area manage the background and border drawing, size and padding. -* Each Area have 2 Pixmap (pix and pix_active). +* Each Area has one Pixmap (pix). * * Area manage the tree of all objects. Parent object drawn before child object. * panel -> taskbars -> tasks @@ -40,22 +40,21 @@ typedef struct double alpha; } Color; - typedef struct { - Pixmap pmap; Color back; Border border; -} Pmap; +} Background; + typedef struct { - // absolute coordinate in panel + // coordinate relative to panel window int posx, posy; // width and height including border int width, height; - Pmap pix; - Pmap pix_active; + Pixmap pix; + Background *bg; // list of child : Area object GSList *list; @@ -65,7 +64,6 @@ typedef struct { int resize; // need redraw Pixmap int redraw; - int use_active, is_active; // paddingxlr = horizontal padding left/right // paddingx = horizontal padding between childs int paddingxlr, paddingx, paddingy; @@ -75,7 +73,7 @@ typedef struct { void *panel; // each object can overwrite following function - void (*_draw_foreground)(void *obj, cairo_t *c, int active); + void (*_draw_foreground)(void *obj, cairo_t *c); void (*_resize)(void *obj); void (*_add_child)(void *obj); int (*_remove_child)(void *obj); @@ -92,9 +90,9 @@ void size (Area *a); // set 'redraw' on an area and childs void set_redraw (Area *a); -// draw pixmap and pixmap_active -void draw (Area *a, int active); -void draw_background (Area *a, cairo_t *c, int active); +// draw pixmap +void draw (Area *a); +void draw_background (Area *a, cairo_t *c); void remove_area (Area *a); void add_area (Area *a); @@ -102,5 +100,8 @@ void free_area (Area *a); // draw rounded rectangle void draw_rect(cairo_t *c, double x, double y, double w, double h, double r); + +// clear pixmap with transparent color +void clear_pixmap(Pixmap p, int x, int y, int w, int h); #endif