]> Dogcows Code - chaz/tint2/blobdiff - src/taskbar/taskbarname.c
desktop name : last step
[chaz/tint2] / src / taskbar / taskbarname.c
index d1eb34e11dc22010ee09f9222f8b16d90f916c9a..12866c7aabb46e1c75b6b553bb03d9e49da588a6 100644 (file)
@@ -35,6 +35,7 @@
 int taskbarname_enabled;
 PangoFontDescription *taskbarname_font_desc;
 Color taskbarname_font;
+Color taskbarname_active_font;
 
 
 void default_taskbarname()
@@ -52,7 +53,8 @@ void init_taskbarname_panel(void *p)
        
        if (!taskbarname_enabled) return;
        
-       for (j=0 ; j < panel->nb_desktop ; j++) {
+       GSList *l, *list = server_get_name_of_desktop();
+       for (j=0, l=list ; j < panel->nb_desktop ; j++) {
                tskbar = &panel->taskbar[j];
                memcpy(&tskbar->bar_name.area, &panel->g_taskbar.area_name, sizeof(Area));
                tskbar->bar_name.area.parent = tskbar;
@@ -60,11 +62,22 @@ void init_taskbarname_panel(void *p)
                        tskbar->bar_name.area.bg = panel->g_taskbar.background_name[TASKBAR_ACTIVE];
                else
                        tskbar->bar_name.area.bg = panel->g_taskbar.background_name[TASKBAR_NORMAL];
-               tskbar->bar_name.name = g_strdup_printf("%d", j+1);
+
+               // use desktop number if name is missing
+               if (l) {
+                       tskbar->bar_name.name = g_strdup(l->data);
+                       l = l->next;
+               }
+               else
+                       tskbar->bar_name.name = g_strdup_printf("%d", j+1);
                
                // append the name at the beginning of taskbar
                tskbar->area.list = g_slist_append(tskbar->area.list, &tskbar->bar_name);
        }
+
+       for (l=list ; l ; l = l->next)
+               g_free(l->data);
+       g_slist_free(list);
 }
 
 
@@ -92,30 +105,34 @@ void cleanup_taskbarname()
 void draw_taskbarname (void *obj, cairo_t *c)
 {
        Taskbarname *taskbar_name = obj;
+       Taskbar *taskbar = taskbar_name->area.parent;
        PangoLayout *layout;
+       Color *config_text = (taskbar->desktop == server.desktop) ? &taskbarname_active_font : &taskbarname_font;
 
+       int state = (taskbar->desktop == server.desktop) ? TASKBAR_ACTIVE : TASKBAR_NORMAL;
+       taskbar_name->state_pix[state] = taskbar_name->area.pix;
+       
+       // draw content
        layout = pango_cairo_create_layout (c);
-
-       // draw layout
        pango_layout_set_font_description (layout, taskbarname_font_desc);
        pango_layout_set_width (layout, taskbar_name->area.width * PANGO_SCALE);
        pango_layout_set_alignment (layout, PANGO_ALIGN_CENTER);
        pango_layout_set_text (layout, taskbar_name->name, strlen(taskbar_name->name));
 
-       cairo_set_source_rgba (c, taskbarname_font.color[0], taskbarname_font.color[1], taskbarname_font.color[2], taskbarname_font.alpha);
+       cairo_set_source_rgba (c, config_text->color[0], config_text->color[1], config_text->color[2], config_text->alpha);
 
        pango_cairo_update_layout (c, layout);
        cairo_move_to (c, 0, taskbar_name->posy);
        pango_cairo_show_layout (c, layout);
 
        g_object_unref (layout);
-       printf("draw_taskbarname %s ******************************\n", taskbar_name->name);
+       //printf("draw_taskbarname %s ******************************\n", taskbar_name->name);
 }
 
 
 int resize_taskbarname(void *obj)
 {
-       Taskbarname *taskbar_name = (Taskbar*)obj;
+       Taskbarname *taskbar_name = obj;
        Panel *panel = taskbar_name->area.panel;
        int name_height, name_width, name_height_ink;
        int ret = 0;
@@ -142,6 +159,3 @@ int resize_taskbarname(void *obj)
        return ret;
 }
 
-
-
-
This page took 0.026976 seconds and 4 git commands to generate.