]> Dogcows Code - chaz/tint2/blobdiff - src/util/area.h
*add* more task states (normal, active, iconified, urgent), with each an own backgrou...
[chaz/tint2] / src / util / area.h
index 5ddd0c3a95e773ba72814c2e05d33cb3195ce78b..fc294f3ea7fdd69358f2a12d32da8637b7f536cf 100644 (file)
@@ -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
 
This page took 0.02685 seconds and 4 git commands to generate.