Bugfix: Don’t draw borders for fullscreen windows
This commit is contained in:
parent
09b5b17830
commit
2d280469af
@ -13,6 +13,6 @@
|
||||
* updated in X11.
|
||||
*
|
||||
*/
|
||||
void render_con(Con *con);
|
||||
void render_con(Con *con, bool render_fullscreen);
|
||||
|
||||
#endif
|
||||
|
@ -503,6 +503,12 @@ Rect con_border_style_rect(Con *con) {
|
||||
*
|
||||
*/
|
||||
int con_border_style(Con *con) {
|
||||
Con *fs = con_get_fullscreen_con(con->parent);
|
||||
if (fs == con) {
|
||||
DLOG("this one is fullscreen! overriding BS_NONE\n");
|
||||
return BS_NONE;
|
||||
}
|
||||
|
||||
if (con->parent->layout == L_STACKED)
|
||||
return BS_NORMAL;
|
||||
|
||||
|
11
src/render.c
11
src/render.c
@ -16,7 +16,7 @@ static bool show_debug_borders = false;
|
||||
* updated in X11.
|
||||
*
|
||||
*/
|
||||
void render_con(Con *con) {
|
||||
void render_con(Con *con, bool render_fullscreen) {
|
||||
printf("currently rendering node %p / %s / layout %d\n",
|
||||
con, con->name, con->layout);
|
||||
int children = con_num_children(con);
|
||||
@ -49,6 +49,7 @@ void render_con(Con *con) {
|
||||
* needs to be smaller */
|
||||
Rect *inset = &(con->window_rect);
|
||||
*inset = (Rect){0, 0, con->rect.width, con->rect.height};
|
||||
if (!render_fullscreen)
|
||||
*inset = rect_add(*inset, con_border_style_rect(con));
|
||||
|
||||
/* Obey x11 border */
|
||||
@ -100,7 +101,7 @@ void render_con(Con *con) {
|
||||
LOG("got fs node: %p\n", fullscreen);
|
||||
fullscreen->rect = rect;
|
||||
x_raise_con(fullscreen);
|
||||
render_con(fullscreen);
|
||||
render_con(fullscreen, true);
|
||||
return;
|
||||
}
|
||||
|
||||
@ -186,7 +187,7 @@ void render_con(Con *con) {
|
||||
child->rect.x, child->rect.y, child->rect.width, child->rect.height);
|
||||
printf("x now %d, y now %d\n", x, y);
|
||||
x_raise_con(child);
|
||||
render_con(child);
|
||||
render_con(child, false);
|
||||
i++;
|
||||
}
|
||||
|
||||
@ -198,7 +199,7 @@ void render_con(Con *con) {
|
||||
x_raise_con(foc);
|
||||
/* by rendering the stacked container again, we handle the case
|
||||
* that we have a non-leaf-container inside the stack. */
|
||||
render_con(foc);
|
||||
render_con(foc, false);
|
||||
}
|
||||
}
|
||||
|
||||
@ -206,7 +207,7 @@ void render_con(Con *con) {
|
||||
LOG("render floating:\n");
|
||||
LOG("floating child at (%d,%d) with %d x %d\n", child->rect.x, child->rect.y, child->rect.width, child->rect.height);
|
||||
x_raise_con(child);
|
||||
render_con(child);
|
||||
render_con(child, false);
|
||||
}
|
||||
|
||||
printf("-- level up\n");
|
||||
|
@ -331,7 +331,7 @@ void tree_render() {
|
||||
Con *output;
|
||||
TAILQ_FOREACH(output, &(croot->nodes_head), nodes) {
|
||||
printf("output %p / %s\n", output, output->name);
|
||||
render_con(output);
|
||||
render_con(output, false);
|
||||
}
|
||||
x_push_changes(croot);
|
||||
printf("-- END RENDERING --\n");
|
||||
|
Loading…
x
Reference in New Issue
Block a user