Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix proper floating window support #29

Open
johan-bjareholt opened this issue Jul 10, 2015 · 1 comment
Open

Fix proper floating window support #29

johan-bjareholt opened this issue Jul 10, 2015 · 1 comment

Comments

@johan-bjareholt
Copy link

I was working at fixing floating windows in my wm, and couldn't get the floating windows to always be on top of the tiled ones. Tried a few tricks then decided to look at your velox code, and found this:

static void stack_arrange(struct layout * layout, struct window * window)
{
    /* TODO: Place window on top of stack when swc adds support for this. */
}

https://github.com/michaelforney/velox/blob/master/layout.c#L359

There are a few ways that this could be implemented.

This isn't the most important feature to add currently, but it shouldn't be forgotten either.

@michaelforney
Copy link
Owner

Yep, this is pretty high on my TODO. The biggest problem in terms of implementation is how to do damage tracking in a way that does not cause the entire screen to be repainted, even if the stacking order did not change.

One technique a window manager might want to do is to send all floating windows to the top (in the order that it wants them), every time the windows are arranged. However, from the compositor's perspective, if a window is sent to the top, it would be fully exposed, and so it would have to mark the entire clipped region as damaged. However, the next window may cover up the previous window, and so no repainting was actually necessary.

Maybe what we should do is add functions

swc_begin_restack()
swc_end_restack()

in which you can do all the restacking you want, but the only thing that matters is the ending order. I'll have to think about this.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants