- server_refresh_root_pixmap ();
-
- draw (&panel.area);
- refresh (&panel.area);
-
- if (panel.clock.time1_format) {
- if (panel.clock.area.redraw)
- panel.refresh = 1;
- if (draw (&panel.clock.area)) {
- panel.clock.area.redraw = 1;
- draw (&panel.clock.area);
- resize_clock();
- resize_taskbar();
- redraw(&panel.area);
- }
- refresh (&panel.clock.area);
- }
-
- // TODO: ne pas afficher les taskbar invisibles
- //if (panel.mode != MULTI_DESKTOP && desktop != server.desktop) continue;
- Task *tsk;
- Taskbar *tskbar;
- GSList *l0;
- for (l0 = panel.area.list; l0 ; l0 = l0->next) {
- tskbar = l0->data;
- draw (&tskbar->area);
- refresh (&tskbar->area);
-
- GSList *l1;
- for (l1 = tskbar->area.list; l1 ; l1 = l1->next) {
- tsk = l1->data;
- draw(&tsk->area);
-
- if (tsk == panel.task_active) refresh (&tsk->area_active);
- else refresh (&tsk->area);
- }
- }
-
- XCopyArea (server.dsp, server.pmap, window.main_win, server.gc, 0, 0, panel.area.width, panel.area.height, 0, 0);
- XFlush(server.dsp);
- panel.refresh = 0;
+ int i;
+ Panel *p;
+
+ // load default icon
+ char *path;
+ const gchar * const *data_dirs;
+ data_dirs = g_get_system_data_dirs ();
+ for (i = 0; data_dirs[i] != NULL; i++) {
+ path = g_build_filename(data_dirs[i], "tint2", "default_icon.png", NULL);
+ if (g_file_test (path, G_FILE_TEST_EXISTS))
+ default_icon = imlib_load_image(path);
+ g_free(path);
+ }
+
+ for (i=0 ; i < nb_panel ; i++) {
+ p = &panel1[i];
+
+ p->area.parent = p;
+ p->area.panel = p;
+ p->area.on_screen = 1;
+ p->area.resize = 1;
+ p->area._resize = resize_panel;
+ p->g_taskbar.parent = p;
+ p->g_taskbar.panel = p;
+ p->g_task.area.panel = p;
+
+ // add childs
+ if (p->clock.area.on_screen)
+ p->area.list = g_slist_append(p->area.list, &p->clock);
+#ifdef ENABLE_BATTERY
+ if (p->battery.area.on_screen)
+ p->area.list = g_slist_append(p->area.list, &p->battery);
+#endif
+ // systray only on first panel
+ if (systray.area.on_screen && i == 0)
+ p->area.list = g_slist_append(p->area.list, &systray);
+
+ // full width mode
+ if (!p->initial_width) {
+ p->initial_width = 100;
+ p->pourcentx = 1;
+ }
+
+ init_panel_size_and_position(p);
+
+ // Catch some events
+ long event_mask = ExposureMask|ButtonPressMask|ButtonReleaseMask;
+ if (g_tooltip.enabled)
+ event_mask |= PointerMotionMask|LeaveWindowMask;
+ XSetWindowAttributes att = { ParentRelative, 0L, 0, 0L, 0, 0, Always, 0L, 0L, False, event_mask, NoEventMask, False, 0, 0 };
+ if (p->main_win) XDestroyWindow(server.dsp, p->main_win);
+ p->main_win = XCreateWindow(server.dsp, server.root_win, p->posx, p->posy, p->area.width, p->area.height, 0, server.depth, InputOutput, CopyFromParent, CWEventMask, &att);
+
+ set_panel_properties(p);
+ set_panel_background(p);
+
+ XMapWindow (server.dsp, p->main_win);
+ }
+ panel_refresh = 1;
+}
+
+
+void init_panel_size_and_position(Panel *panel)
+{
+ // detect panel size
+ if (panel_horizontal) {
+ if (panel->pourcentx)
+ panel->area.width = (float)server.monitor[panel->monitor].width * panel->initial_width / 100;
+ else
+ panel->area.width = panel->initial_width;
+ if (panel->pourcenty)
+ panel->area.height = (float)server.monitor[panel->monitor].height * panel->initial_height / 100;
+ else
+ panel->area.height = panel->initial_height;
+ if (panel->area.pix.border.rounded > panel->area.height/2)
+ panel->area.pix.border.rounded = panel->area.height/2;
+ }
+ else {
+ if (panel->pourcentx)
+ panel->area.height = (float)server.monitor[panel->monitor].height * panel->initial_width / 100;
+ else
+ panel->area.height = panel->initial_width;
+ if (panel->pourcenty)
+ panel->area.width = (float)server.monitor[panel->monitor].width * panel->initial_height / 100;
+ else
+ panel->area.width = panel->initial_height;
+ if (panel->area.pix.border.rounded > panel->area.width/2)
+ panel->area.pix.border.rounded = panel->area.width/2;
+ }
+
+ // panel position determined here
+ if (panel_position & LEFT) {
+ panel->posx = server.monitor[panel->monitor].x + panel->marginx;
+ }
+ else {
+ if (panel_position & RIGHT) {
+ panel->posx = server.monitor[panel->monitor].x + server.monitor[panel->monitor].width - panel->area.width - panel->marginx;
+ }
+ else {
+ if (panel_horizontal)
+ panel->posx = server.monitor[panel->monitor].x + ((server.monitor[panel->monitor].width - panel->area.width) / 2);
+ else
+ panel->posx = server.monitor[panel->monitor].x + panel->marginx;
+ }
+ }
+ if (panel_position & TOP) {
+ panel->posy = server.monitor[panel->monitor].y + panel->marginy;
+ }
+ else {
+ if (panel_position & BOTTOM) {
+ panel->posy = server.monitor[panel->monitor].y + server.monitor[panel->monitor].height - panel->area.height - panel->marginy;
+ }
+ else {
+ panel->posy = server.monitor[panel->monitor].y + ((server.monitor[panel->monitor].height - panel->area.height) / 2);
+ }
+ }
+ // printf("panel : posx %d, posy %d, width %d, height %d\n", panel->posx, panel->posy, panel->area.width, panel->area.height);
+}
+
+
+void cleanup_panel()
+{
+ if (!panel1) return;
+
+ task_active = 0;
+ task_drag = 0;
+ task_urgent = 0;
+ cleanup_systray();
+ cleanup_taskbar();
+
+ if (default_icon) {
+ imlib_context_set_image(default_icon);
+ imlib_free_image();
+ }
+
+ // font allocated once
+ if (panel1[0].g_task.font_desc) {
+ pango_font_description_free(panel1[0].g_task.font_desc);
+ panel1[0].g_task.font_desc = 0;
+ }
+
+ int i;
+ Panel *p;
+ for (i=0 ; i < nb_panel ; i++) {
+ p = &panel1[i];
+
+ free_area(&p->area);
+ free_area(&p->g_task.area);
+ free_area(&p->g_taskbar);
+
+ if (p->temp_pmap) {
+ XFreePixmap(server.dsp, p->temp_pmap);
+ p->temp_pmap = 0;
+ }
+ if (p->main_win) {
+ XDestroyWindow(server.dsp, p->main_win);
+ p->main_win = 0;
+ }
+ }
+
+ if (panel1) free(panel1);
+ panel1 = 0;
+
+ if (g_tooltip.window) {
+ XDestroyWindow(server.dsp, g_tooltip.window);
+ g_tooltip.window = 0;
+ }
+ if (g_tooltip.font_desc) {
+ pango_font_description_free(g_tooltip.font_desc);
+ g_tooltip.font_desc = 0;
+ }