Skip to content

riodraw

bakkeby edited this page Feb 14, 2021 · 8 revisions

This patch allows the user to "draw" where a window is to be placed in a similar manner to the Plan 9 window system rio.

This solution is based on an external tool slop (Select Operation) that handles the drawing of the selected area where a client window is to be placed.

This can either be used when resizing (and repositioning) a client window or when spawning a new window.

As the riodraw shares a lot of the same code as the swallow patch this comes in a few variants - standalone, on top of swallow, or full patch including both riodraw and swallow.

One room for improvement would be if one could pass the starting point for slop via command line arguments (as in the first click) - that way one could have a more seamless integration for button press bindings in dwm. Something to revisit if such a feature is added to slop.

Note that even if -t 0 is passed to slop it still ends up highlighting the window underneath the cursor for a fraction of a second on the first mouse click before you start dragging.

Configuration options

static const char slopspawnstyle[]  = "-t 0 -c 0.92,0.85,0.69,0.3 -o"; /* do NOT define -f (format) here */
static const char slopresizestyle[] = "-t 0 -c 0.92,0.85,0.69,0.3"; /* do NOT define -f (format) here */
static const int riodraw_borders    = 0; /* 0 or 1, indicates whether the area drawn using slop includes the window borders */
static const int riodraw_matchpid   = 1; /* 0 or 1, indicates whether to match the PID of the client that was spawned with riospawn */

The slopspawnstyle and slopresizestyle options allow you to use a different slop style when spawning and resizing clients. See slop --help for details.

The riodraw_borders option controls whether the drawn area represents the actual window size or the window size including the borders. This may not make much of a difference when the borders are thin, but it gives a different feel if thicker window borders are used.

The riodraw_matchpid option controls whether or not to try to match the PID of the rio spawned window. If this is set to 0 then simply the next window being managed is assumed to be the rio spawned window.

Showcase

Spawning clients:

riospawn.gif

Resizing clients:

rioresize.gif

Download

Clone this wiki locally