Tiling Shell v15.1 | Smart border radius, more keybindings, bug fixes and more! #218
domferr
announced in
Announcements
Replies: 0 comments
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
-
smart border radius
! In GNOME, different windows may have different border radius. Drawing a border around the focused window is hard because it is not possible to know the window border radius. All the existing extensions just draw a border with a static value, making the UI less polished. Tiling Shell, instead, now dynamically computes the focused window border radius at runtime. Moreover, if you have an extension or anything else who customize the border radius, the focused window border radius adapts as well! This can be enabled/disabled from the extension's preferences. Closes v13: outline doesn't match windows borders #135. Discover more at the end of this release notes!New: the width of the focused window's border now adapts to the monitor scaling factor and differences in DPI scaling or fractional scaling. Tiling Shell now scales focused window border according to monitor scaling factor. Closes Ensure the window border follows the scaling factor #191
New: focused window's border is now above the actual border. Prior this update it was inside.
New: added keybindings to focus next or previous window. Thank you to jessedhillon for contributing and adding this new feature! ❤️
New: added button in the indicator menu to open preferences. Closes Tray menu entry for more settings #208
New: added internal documentation about the format of the exported layouts (in JSON). Thank you to sebastiaanfranken for contributing! ❤️ Closes [Feature request]: add documentation / wiki #177
New: new workspaces now have the same layout as the one used by the last workspace. This is still under testing and might not always work with multiple monitors. We are tracking this here [Feature Request] Remember layouts for different workspaces #182. If you can, please share your feedback! Thank you
Fix: focusing windows using keybinding were stop working after the computer is suspended. Thank you to jessedhillon for contributing and fixing this problem! ❤️ Closes Focus window to the right / left / below / above not working #184
Fix: moving windows across monitors using keybindings were not working. Closes Cannot move window to Tile on other Monitor with Keyboard Shortcuts #197
Fix: increased maximum value of snap assistant's threshold. Closes Snap assistant threshold only works up to 200 or so (with max input value of 512) #205
Fix: to some users with multiple monitors tiles are appearing on the wrong monitor when moving a window. This update contains a bugfix but I haven't a secondary monitor, at the moment, to test extensively. If you can, please share your feedback here Tiles appear on incorrect monitor when moving window with mouse #194. Thank you!
Introducing
smart border radius
!We all know how unpolished GNOME feels when multiple windows are opened and they have different border radius. GNOME traditionally uses static, predefined values for window border radii. Certain applications may request specific border radii through client-side decorations or their toolkit (e.g., GTK vs. Electron apps).
To my knowledge there isn't any solution to this and people end up using extensions to customize (and normalize!) windows border radius. I wanted to provide a solution: now Tiling Shell dynamically computes the focused window border radius at runtime. Moreover, if you have an extension or anything else who customize the border radius, the focused window border radius adapts as well!
How it works?
When a window gets created, after (approximately) 180ms, Tiling Shell captures the pixels of the entire window's left border, excluding any padding or shadow. Then, starting from topmost pixel, Tiling Shell counts the number of progressively transparent pixels until we hit the first fully opaque one. This count determines the top-left border radius. Indeed, the top left border radius is the number of pixels from the top pixel to the first non transparent pixel!
This process is repeated from the bottommost pixel upwards to compute the bottom-left border radius. All of this is done extremely fast, behind the scenes and with the lowest resource consumption possible.
The top-right border radius mirrors the top-left, and the bottom-right mirrors the bottom-left. This approach ensures that border radii dynamically adapt to the window’s actual design.
Tiling Shell v15.0 Release Notes
autotiling.mp4
How to install
⭐ This update of Tiling Shell is landing on GSE too!
Manual installation
There are two builds and you need only one of them, according to your GNOME Shell version:
tilingshell@ferrarodomenico.com.zip
GNOME.42-44.tilingshell@ferrarodomenico.com.zip
To know your GNOME Shell version, run
gnome-shell --version
.Extract the downloaded archive. Copy its content to
~/.local/share/gnome-shell/extensions/tilingshell@ferrarodomenico.com
directory. You need to reload GNOME Shell afterwards (e.g. by logging out). Then you can enable the extension:This discussion was created from the release Tiling Shell v15.1 | Smart border radius, more keybindings, bug fixes and more!.
Beta Was this translation helpful? Give feedback.
All reactions