X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Fpanel.h;h=52665cd19f09003eee62639abed69b32e3c4d07d;hb=2e63fd9929fd2c261ad47f4d995dc99722177954;hp=dff0a03bc43b30098190737bf2da002371407936;hpb=8ae318e599f644ca96b09ed2e249ec7881742467;p=chaz%2Ftint2 diff --git a/src/panel.h b/src/panel.h index dff0a03..52665cd 100644 --- a/src/panel.h +++ b/src/panel.h @@ -37,9 +37,11 @@ extern int mouse_tilt_right; //panel mode enum { SINGLE_DESKTOP=0, MULTI_DESKTOP }; +enum { BOTTOM_LAYER, NORMAL_LAYER, TOP_LAYER }; extern int panel_mode; extern int wm_menu; extern int panel_dock; +extern int panel_layer; //panel position enum { LEFT=0x01, RIGHT=0x02, CENTER=0X04, TOP=0X08, BOTTOM=0x10 }; @@ -50,47 +52,45 @@ extern int panel_refresh; extern Task *task_active; extern Task *task_drag; -extern Task *task_urgent; -extern int tick_urgent; extern int max_tick_urgent; extern Imlib_Image default_icon; +// tint2 use one panel per monitor and one taskbar per desktop. typedef struct { - // always start with area - // area.list own all objects of the panel according to config file - Area area; + // always start with area + // area.list own all objects of the panel according to config file + Area area; - // -------------------------------------------------- - // panel - Window main_win; - Pixmap temp_pmap; + // -------------------------------------------------- + // panel + Window main_win; + Pixmap temp_pmap; - // position relative to root window + // position relative to root window int posx, posy; - int marginx, marginy; - float initial_width, initial_height; - int pourcentx, pourcenty; - // location of the panel (monitor number) - int monitor; - - // -------------------------------------------------- - // task and taskbar parameter per panel + int marginx, marginy; + int pourcentx, pourcenty; + // location of the panel (monitor number) + int monitor; + + // -------------------------------------------------- + // task and taskbar parameter per panel Area g_taskbar; Global_task g_task; - // -------------------------------------------------- - // taskbar point to the first taskbar in panel.area.list. - // number of tasbar == nb_desktop + // -------------------------------------------------- + // taskbar point to the first taskbar in panel.area.list. + // number of tasbar == nb_desktop. taskbar[i] is for desktop(i). // taskbar[i] is used to loop over taskbar, // while panel->area.list is used to loop over all panel's objects - Taskbar *taskbar; - int nb_desktop; + Taskbar *taskbar; + int nb_desktop; - // -------------------------------------------------- - // clock - Clock clock; + // -------------------------------------------------- + // clock + Clock clock; // -------------------------------------------------- // battery @@ -100,11 +100,15 @@ typedef struct { } Panel; +extern Panel panel_config; extern Panel *panel1; extern int nb_panel; - +// realloc panels according to number of monitor +// use panel_config as default value void init_panel(); + +void init_panel_size_and_position(Panel *panel); void cleanup_panel(); void resize_panel(void *obj); @@ -117,5 +121,10 @@ void set_panel_background(Panel *p); // detect witch panel Panel *get_panel(Window win); -#endif +Taskbar *click_taskbar (Panel *panel, int x, int y); +Task *click_task (Panel *panel, int x, int y); +int click_padding(Panel *panel, int x, int y); +int click_clock(Panel *panel, int x, int y); +Area* click_area(Panel *panel, int x, int y); +#endif