systray: don't crap up on odd-sized windows

Basically, we get the size we want the systray to be drawn at upon drawing
the tray, thus removing the query to the xcb_get_geometry function. As all
windows embedded in the systray are squares, their size is equal to their
height, so we simply force the size to be wibox_height * n x wibox_height,
where n is the number of embedded windows, instead of deriving it from the
largest embedded window (which, for example in the case of wicd, would be
200x200, way too much for one window on a regular wibox).

Signed-off-by: Gregor Best <farhaven@googlemail.com>
Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
Gregor Best 2009-05-29 01:31:57 +02:00 committed by Julien Danjou
parent aa9a7b1fc8
commit 9890561fd5
1 changed files with 17 additions and 16 deletions

View File

@ -32,32 +32,27 @@
#define _NET_SYSTEM_TRAY_ORIENTATION_HORZ 0 #define _NET_SYSTEM_TRAY_ORIENTATION_HORZ 0
#define _NET_SYSTEM_TRAY_ORIENTATION_VERT 1 #define _NET_SYSTEM_TRAY_ORIENTATION_VERT 1
typedef struct
{
/* systray height */
int height;
} systray_data_t;
static area_t static area_t
systray_geometry(widget_t *widget, int screen) systray_geometry(widget_t *widget, int screen)
{ {
area_t geometry; area_t geometry;
int phys_screen = screen_virttophys(screen), n = 0; int phys_screen = screen_virttophys(screen), n = 0;
systray_data_t *d = widget->data;
geometry.height = 0;
int width = 0;
for(int i = 0; i < globalconf.embedded.len; i++) for(int i = 0; i < globalconf.embedded.len; i++)
if(globalconf.embedded.tab[i].phys_screen == phys_screen) if(globalconf.embedded.tab[i].phys_screen == phys_screen)
{
xcb_get_geometry_cookie_t geo = xcb_get_geometry(globalconf.connection, globalconf.embedded.tab[i].win);
xcb_get_geometry_reply_t *g = xcb_get_geometry_reply(globalconf.connection, geo, NULL);
n++; n++;
if(g->height > geometry.height)
geometry.height = g->height;
if(g->width > width)
width = g->width;
}
/** \todo use class hints */ /** \todo use class hints */
geometry.width = width * n; geometry.width = d->height * n;
geometry.height = d->height;
geometry.x = geometry.y = 0; geometry.x = geometry.y = 0;
return geometry; return geometry;
} }
@ -87,6 +82,9 @@ systray_draw(widget_t *widget, draw_context_t *ctx,
break; break;
} }
systray_data_t *d = widget->data;
d->height = p->sw.geometry.height;
/* set wibox orientation */ /* set wibox orientation */
/** \todo stop setting that property on each redraw */ /** \todo stop setting that property on each redraw */
xcb_change_property(globalconf.connection, XCB_PROP_MODE_REPLACE, xcb_change_property(globalconf.connection, XCB_PROP_MODE_REPLACE,
@ -105,6 +103,9 @@ widget_systray(widget_t *w)
w->geometry = systray_geometry; w->geometry = systray_geometry;
w->extents = systray_extents; w->extents = systray_extents;
systray_data_t *d = w->data = p_new(systray_data_t, 1);
d->height = 0;
return w; return w;
} }
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80 // vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80