screen: compute screen area with wiboxes strut
Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
parent
5e2fbb3684
commit
a7a1ead538
79
screen.c
79
screen.c
|
@ -168,46 +168,55 @@ screen_getbycoord(screen_t *screen, int x, int y)
|
||||||
area_t
|
area_t
|
||||||
screen_area_get(screen_t *screen, bool strut)
|
screen_area_get(screen_t *screen, bool strut)
|
||||||
{
|
{
|
||||||
|
if(!strut)
|
||||||
|
return screen->geometry;
|
||||||
|
|
||||||
area_t area = screen->geometry;
|
area_t area = screen->geometry;
|
||||||
uint16_t top = 0, bottom = 0, left = 0, right = 0;
|
uint16_t top = 0, bottom = 0, left = 0, right = 0;
|
||||||
|
|
||||||
if(strut)
|
#define COMPUTE_STRUT(o) \
|
||||||
foreach(_c, globalconf.clients)
|
{ \
|
||||||
{
|
if((o)->strut.top_start_x || (o)->strut.top_end_x || (o)->strut.top) \
|
||||||
client_t *c = *_c;
|
{ \
|
||||||
if(client_isvisible(c, screen))
|
if((o)->strut.top) \
|
||||||
{
|
top = MAX(top, (o)->strut.top); \
|
||||||
if(c->strut.top_start_x || c->strut.top_end_x)
|
else \
|
||||||
{
|
top = MAX(top, ((o)->geometry.y - area.y) + (o)->geometry.height); \
|
||||||
if(c->strut.top)
|
} \
|
||||||
top = MAX(top, c->strut.top);
|
if((o)->strut.bottom_start_x || (o)->strut.bottom_end_x || (o)->strut.bottom) \
|
||||||
else
|
{ \
|
||||||
top = MAX(top, (c->geometry.y - area.y) + c->geometry.height);
|
if((o)->strut.bottom) \
|
||||||
}
|
bottom = MAX(bottom, (o)->strut.bottom); \
|
||||||
if(c->strut.bottom_start_x || c->strut.bottom_end_x)
|
else \
|
||||||
{
|
bottom = MAX(bottom, (area.y + area.height) - (o)->geometry.y); \
|
||||||
if(c->strut.bottom)
|
} \
|
||||||
bottom = MAX(bottom, c->strut.bottom);
|
if((o)->strut.left_start_y || (o)->strut.left_end_y || (o)->strut.left) \
|
||||||
else
|
{ \
|
||||||
bottom = MAX(bottom, (area.y + area.height) - c->geometry.y);
|
if((o)->strut.left) \
|
||||||
}
|
left = MAX(left, (o)->strut.left); \
|
||||||
if(c->strut.left_start_y || c->strut.left_end_y)
|
else \
|
||||||
{
|
left = MAX(left, ((o)->geometry.x - area.x) + (o)->geometry.width); \
|
||||||
if(c->strut.left)
|
} \
|
||||||
left = MAX(left, c->strut.left);
|
if((o)->strut.right_start_y || (o)->strut.right_end_y || (o)->strut.right) \
|
||||||
else
|
{ \
|
||||||
left = MAX(left, (c->geometry.x - area.x) + c->geometry.width);
|
if((o)->strut.right) \
|
||||||
}
|
right = MAX(right, (o)->strut.right); \
|
||||||
if(c->strut.right_start_y || c->strut.right_end_y)
|
else \
|
||||||
{
|
right = MAX(right, (area.x + area.width) - (o)->geometry.x); \
|
||||||
if(c->strut.right)
|
} \
|
||||||
right = MAX(right, c->strut.right);
|
|
||||||
else
|
|
||||||
right = MAX(right, (area.x + area.width) - c->geometry.x);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
foreach(c, globalconf.clients)
|
||||||
|
if(client_isvisible(*c, screen))
|
||||||
|
COMPUTE_STRUT(*c)
|
||||||
|
|
||||||
|
foreach(wibox, globalconf.wiboxes)
|
||||||
|
if((*wibox)->visible
|
||||||
|
&& (*wibox)->screen == screen)
|
||||||
|
COMPUTE_STRUT(*wibox)
|
||||||
|
|
||||||
|
#undef COMPUTE_STRUT
|
||||||
|
|
||||||
area.x += left;
|
area.x += left;
|
||||||
area.y += top;
|
area.y += top;
|
||||||
area.width -= left + right;
|
area.width -= left + right;
|
||||||
|
|
Loading…
Reference in New Issue