-
Notifications
You must be signed in to change notification settings - Fork 15
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
improvements to tiling windows #10
Comments
This could be a dead-end thought, but one thought i have regarding a hybrid or blended group is to move the concept of tiling type from the group to the frame, and expanding to two major types of frames: window-frames and container-frames. Window-frames can contain either nothing or a window, while container frames contain one or more frames (either window- or container-frames). We could then move the dynamic/auto/tabbed/etc tiling logic from groups to container frames, allowing a blending of the types of tiling used. Ill give an example using dwm-esq dynamic tiling and manual tiling frames: we create a new group with a single manual-tiling-container-frame (MTCF0) containing a single window-frame (WF0) which itself contains nothing. A window (W0) is added to the group, getting placed into WF0. We then call some command which changes MTCF0 into a dynamic-tiling-container-frame (DTCF0). We add a window (W1) to the group and to DTCF0, causing a new window-frame (WF1) to be created and placing W1 into it. WF0 is moved over to the side, giving us our master/stack split. At this point our current frame tree is:
And we wish to create a third window which will always be with W1. So we insert around WF1 MTWF1 and add W2 to it, resulting in the frame tree:
At this point we can manually manage W1 and W2, splitting or unsplitting as we wish, while treating them as a single unit in the context of DTWF0. Now we add a fourth window to the group, adding it to DTWF0, moving W1 and W2 onto the window stack as a single unit, resulting in the frame tree:
And if we wanted to see W1 and W2 side by side we could manually split W1 and W2 into separate frames, resulting in the frame tree:
By moving the manual/dynamic/auto/tabbed/etc tiling logic into the domain of frames we could potentially have a manual frame containing a dynamic frame containing an auto frame containing a dynamic frame containing a manual frame (Im not sure what use this level of nesting would be. Perhaps someone has a 60" monitor?). Each container frame would perhaps require a small indicator in the corner telling what type of frame it is, as well as its depth. Im not sure how the keybindings for moving and cycling between windows/frames would look, but i think there would need to be some different keybindings for navigating in the outermost frame, sub-outermost frame, sub-sub-outermost frame, etc. Perhaps some binding scheme with All in all, i think this system could be useful, but without trying it im unable to say for sure. It could end up being an over engineered and overcomplicated system that fights the user instead of working with them. But as this is a discussion on how tiling would best be implemented i figured it was worth writing this up. |
is it possible to have hybrid, options of dynamic (tiling, stacked, tabbed, etc) and manual tiling,
what are the best ways to switch between frame layouts,
what are the best ways to access a window if multiple are open (cycling, fuzzy search, list/display)
and the best way to search/interact/move frames among workspaces/groups
The text was updated successfully, but these errors were encountered: