X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Ftaskbar%2Ftaskbarname.c;h=12866c7aabb46e1c75b6b553bb03d9e49da588a6;hb=9a6f8801012c62445afd308a733aed5fc3bb7716;hp=d1eb34e11dc22010ee09f9222f8b16d90f916c9a;hpb=f451124d52fd1e4afbaee3d11490a4cca8d9ff95;p=chaz%2Ftint2 diff --git a/src/taskbar/taskbarname.c b/src/taskbar/taskbarname.c index d1eb34e..12866c7 100644 --- a/src/taskbar/taskbarname.c +++ b/src/taskbar/taskbarname.c @@ -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; } - - -