X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Ftaskbar%2Ftask.h;h=3de591b62ca5858286c0e7bf6ea8dac80199b850;hb=c75069e03de761de15a6d74a4df0d7dbe6672b6e;hp=e67a04513b542f44d07e367b00a8920d55b6f4cf;hpb=22a5d6049eff5cb32e100ccd1a9b24e43e82a2ab;p=chaz%2Ftint2 diff --git a/src/taskbar/task.h b/src/taskbar/task.h index e67a045..3de591b 100644 --- a/src/taskbar/task.h +++ b/src/taskbar/task.h @@ -11,8 +11,13 @@ #include #include #include "common.h" +#include "timer.h" +enum { TASK_NORMAL, TASK_ACTIVE, TASK_ICONIFIED, TASK_URGENT, TASK_STATE_COUNT }; +extern timeout* urgent_timeout; +extern GSList* urgent_list; + // -------------------------------------------------- // global task parameter typedef struct { @@ -26,15 +31,19 @@ typedef struct { int icon_size1; int maximum_width; int maximum_height; - int alpha, saturation, brightness; - int alpha_active, saturation_active, brightness_active; + int alpha[TASK_STATE_COUNT]; + int saturation[TASK_STATE_COUNT]; + int brightness[TASK_STATE_COUNT]; + int config_asb_mask; + Background* background[TASK_STATE_COUNT]; + int config_background_mask; // starting position for text ~ task_padding + task_border + icon_size - double text_posx, text_posy; + double text_posx, text_height; int font_shadow; PangoFontDescription *font_desc; - config_color font; - config_color font_active; + Color font[TASK_STATE_COUNT]; + int config_font_mask; } Global_task; @@ -46,8 +55,9 @@ typedef struct { // TODO: group task with list of windows here Window win; int desktop; - Imlib_Image icon; - Imlib_Image icon_active; + int current_state; + Imlib_Image icon[TASK_STATE_COUNT]; + Pixmap state_pix[TASK_STATE_COUNT]; unsigned int icon_width; unsigned int icon_height; char *title; @@ -58,11 +68,14 @@ typedef struct { Task *add_task (Window win); void remove_task (Task *tsk); -void draw_task (void *obj, cairo_t *c, int active); +void draw_task (void *obj, cairo_t *c); +void on_change_task (void *obj); void get_icon (Task *tsk); void get_title(Task *tsk); void active_task(); +void set_task_state(Task* tsk, int state); +void set_task_redraw(Task* tsk); Task *next_task (Task *tsk); Task *prev_task (Task *tsk);