X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;ds=sidebyside;f=src%2Futil%2Farea.h;h=a45b7b8e031e89c727d46a7535db95bd5f60a880;hb=7eab00cba528e4deb51b2f0eaff6f809c3b1e384;hp=acea08f40873331eb40468c64e9a54a7fa6f63dd;hpb=1ef906db6652330521262656e65873ad697341d4;p=chaz%2Ftint2 diff --git a/src/util/area.h b/src/util/area.h index acea08f..a45b7b8 100644 --- a/src/util/area.h +++ b/src/util/area.h @@ -7,7 +7,7 @@ * Area manage the background and border drawing, size and padding. * Each Area have 2 Pixmap (pix and pix_active). * -* Area also manage the tree of visible objects. Parent object drawn before child object. +* Area manage the tree of all objects. Parent object drawn before child object. * panel -> taskbars -> tasks * -> systray -> icons * -> clock @@ -27,56 +27,59 @@ typedef struct { - double color[3]; - double alpha; - int width; - int rounded; + double color[3]; + double alpha; + int width; + int rounded; } Border; typedef struct { - double color[3]; - double alpha; + double color[3]; + double alpha; } Color; typedef struct { - Pixmap pmap; - Color back; - Border border; + Pixmap pmap; + Color back; + Border border; } Pmap; typedef struct { - // absolute coordinate in panel - int posx, posy; - int width, height; - Pmap pix; - Pmap pix_active; + // coordinate relative to panel window + int posx, posy; + // width and height including border + int width, height; + Pmap pix; + Pmap pix_active; - // list of child : Area object - GSList *list; + // list of child : Area object + GSList *list; + int on_screen; // need compute position and width 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; - // parent Area - void *parent; - // panel - void *panel; - - // each object can overwrite following function - void (*_draw_foreground)(void *obj, cairo_t *c, int active); - void (*_resize)(void *obj); - void (*_add_child)(void *obj); - int (*_remove_child)(void *obj); + // need redraw Pixmap + int redraw; + int use_active, is_active; + // paddingxlr = horizontal padding left/right + // paddingx = horizontal padding between childs + int paddingxlr, paddingx, paddingy; + // parent Area + void *parent; + // panel + void *panel; + + // each object can overwrite following function + void (*_draw_foreground)(void *obj, cairo_t *c, int active); + void (*_resize)(void *obj); + void (*_add_child)(void *obj); + int (*_remove_child)(void *obj); + const char* (*_get_tooltip_text)(void *obj); } Area; @@ -84,6 +87,8 @@ typedef struct { // draw background and foreground void refresh (Area *a); +void size (Area *a); + // set 'redraw' on an area and childs void set_redraw (Area *a); @@ -97,6 +102,5 @@ void free_area (Area *a); // draw rounded rectangle void draw_rect(cairo_t *c, double x, double y, double w, double h, double r); - #endif