opt: optimize layer convert in maxmizescreen and fullscreen

This commit is contained in:
DreamMaoMao 2025-08-03 12:37:51 +08:00
parent 077981c67c
commit ba65b03443
2 changed files with 17 additions and 15 deletions

View file

@ -1015,6 +1015,8 @@ void togglemaxmizescreen(const Arg *arg) {
setmaxmizescreen(sel, 0); setmaxmizescreen(sel, 0);
else else
setmaxmizescreen(sel, 1); setmaxmizescreen(sel, 1);
setborder_color(sel);
} }
void toggleoverlay(const Arg *arg) { void toggleoverlay(const Arg *arg) {
if (!selmon->sel || !selmon->sel->mon || selmon->sel->isfullscreen) { if (!selmon->sel || !selmon->sel->mon || selmon->sel->isfullscreen) {

View file

@ -3981,10 +3981,6 @@ void setmaxmizescreen(Client *c, int maxmizescreen) {
c->ismaxmizescreen = maxmizescreen; c->ismaxmizescreen = maxmizescreen;
wlr_scene_node_reparent(&c->scene->node, layers[maxmizescreen ? LyrTile
: c->isfloating ? LyrFloat
: LyrTile]);
if (maxmizescreen) { if (maxmizescreen) {
if (c->isfullscreen) if (c->isfullscreen)
@ -4011,6 +4007,10 @@ void setmaxmizescreen(Client *c, int maxmizescreen) {
setfloating(c, 1); setfloating(c, 1);
arrange(c->mon, false); arrange(c->mon, false);
} }
wlr_scene_node_reparent(&c->scene->node, layers[maxmizescreen ? LyrTile
: c->isfloating ? LyrFloat
: LyrTile]);
} }
void setfakefullscreen(Client *c, int fakefullscreen) { void setfakefullscreen(Client *c, int fakefullscreen) {
@ -4032,17 +4032,6 @@ void setfullscreen(Client *c, int fullscreen) // 用自定义全屏代理自带
client_set_fullscreen(c, fullscreen); client_set_fullscreen(c, fullscreen);
if (c->isoverlay) {
wlr_scene_node_reparent(&c->scene->node, layers[LyrOverlay]);
} else if (client_should_overtop(c) && c->isfloating) {
wlr_scene_node_reparent(&c->scene->node, layers[LyrFSorOverTop]);
} else {
wlr_scene_node_reparent(&c->scene->node,
layers[fullscreen ? LyrFSorOverTop
: c->isfloating ? LyrFloat
: LyrTile]);
}
if (fullscreen) { if (fullscreen) {
if (c->ismaxmizescreen) if (c->ismaxmizescreen)
setmaxmizescreen(c, 0); setmaxmizescreen(c, 0);
@ -4067,6 +4056,17 @@ void setfullscreen(Client *c, int fullscreen) // 用自定义全屏代理自带
setfloating(c, 1); setfloating(c, 1);
arrange(c->mon, false); arrange(c->mon, false);
} }
if (c->isoverlay) {
wlr_scene_node_reparent(&c->scene->node, layers[LyrOverlay]);
} else if (client_should_overtop(c) && c->isfloating) {
wlr_scene_node_reparent(&c->scene->node, layers[LyrFSorOverTop]);
} else {
wlr_scene_node_reparent(&c->scene->node,
layers[fullscreen ? LyrFSorOverTop
: c->isfloating ? LyrFloat
: LyrTile]);
}
} }
void setgaps(int oh, int ov, int ih, int iv) { void setgaps(int oh, int ov, int ih, int iv) {