2021-08-28 11:25:45 +03:00
|
|
|
# Bismuth
|
2018-11-06 09:38:22 +03:00
|
|
|
|
2021-08-28 14:44:30 +03:00
|
|
|
This is a fork of [Krohnkite](https://github.com/esjeon/krohnkite) - a dynamic tiling extension for KWin.
|
2018-11-14 09:23:55 +03:00
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
## Features
|
2018-11-12 11:16:57 +03:00
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
- DWM-like window tiling
|
|
|
|
- Dynamically tile windows, rather than manually placing each.
|
|
|
|
- Floating windows
|
|
|
|
- Fully integrates into KWin features, including:
|
|
|
|
- **Multi-screen**
|
|
|
|
- **Activities & Virtual desktop**
|
|
|
|
- Basic window management (minimize, fullscreen, switching, etc)
|
|
|
|
- Multiple Layout Support
|
|
|
|
- Tiling layout
|
|
|
|
- Monocle layout
|
|
|
|
- Desktop-friendly layouts (Spread, Stair)
|
2018-12-04 02:38:44 +03:00
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
## Development Requirement
|
2018-11-14 11:06:03 +03:00
|
|
|
|
2021-08-28 14:44:30 +03:00
|
|
|
- NPM
|
2021-08-28 11:25:45 +03:00
|
|
|
- p7zip (7z)
|
2018-11-14 11:06:03 +03:00
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
## Installation
|
2018-11-12 11:16:57 +03:00
|
|
|
|
|
|
|
|
2018-12-02 17:15:23 +03:00
|
|
|
make install
|
2019-01-28 10:01:33 +03:00
|
|
|
make uninstall # to uninstall the script
|
|
|
|
|
2021-08-28 14:44:30 +03:00
|
|
|
## Simply Trying Out
|
2018-11-19 10:09:26 +03:00
|
|
|
|
2021-08-28 11:20:19 +03:00
|
|
|
Bismuth can be temporarily loaded without installing the script:
|
2018-11-12 11:16:57 +03:00
|
|
|
|
2018-12-02 17:15:23 +03:00
|
|
|
make run
|
|
|
|
make stop
|
2018-11-12 11:16:57 +03:00
|
|
|
|
2021-08-28 11:20:19 +03:00
|
|
|
Note that Bismuth can destroy itself completely once it is disabled, so no
|
2019-01-28 10:01:33 +03:00
|
|
|
restart is required to deactivated it.
|
2018-11-12 11:16:57 +03:00
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
### Enabling User-Configuration
|
2018-11-19 10:09:26 +03:00
|
|
|
|
2019-01-28 10:01:33 +03:00
|
|
|
[It is reported][kwinconf] that a manual step is required to enable user
|
|
|
|
configuration of KWin scripts. This is a limitation of KWin scripting.
|
2018-11-19 10:09:26 +03:00
|
|
|
|
|
|
|
To enable configuration, you must perform the following in command-line:
|
|
|
|
|
|
|
|
mkdir -p ~/.local/share/kservices5/
|
2021-08-28 11:20:19 +03:00
|
|
|
ln -s ~/.local/share/kwin/scripts/bismuth/metadata.desktop ~/.local/share/kservices5/bismuth.desktop
|
2018-11-19 10:09:26 +03:00
|
|
|
|
|
|
|
A configuration button will appear in `KWin Scripts` in `System Settings`.
|
|
|
|
|
|
|
|
![config button shown](img/conf.png)
|
|
|
|
|
2020-08-30 20:58:26 +03:00
|
|
|
To make changes effective, **the script must be reactivated**:
|
2019-01-28 10:01:33 +03:00
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
1. On `KWin Scripts` dialog, untick Bismuth
|
|
|
|
2. `Apply`
|
|
|
|
3. tick Bismuth
|
|
|
|
4. `Apply`
|
2018-11-19 10:09:26 +03:00
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
[kwinconf]: https://github.com/faho/kwin-tiling/issues/79#issuecomment-311465357
|
2018-11-12 11:16:57 +03:00
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
## Default Key Bindings
|
|
|
|
|
|
|
|
| Key | Action |
|
|
|
|
| ---------------- | ------------------ |
|
|
|
|
| Meta + J | Focus Down/Next |
|
|
|
|
| Meta + K | Focus Up/Previous |
|
|
|
|
| Meta + H | Left |
|
|
|
|
| Meta + L | Right |
|
|
|
|
| | |
|
|
|
|
| Meta + Shift + J | Move Down/Next |
|
|
|
|
| Meta + Shift + K | Move Up/Previous |
|
|
|
|
| Meta + Shift + H | Move Left |
|
|
|
|
| Meta + Shift + L | Move Right |
|
|
|
|
| | |
|
|
|
|
| Meta + I | Increase |
|
|
|
|
| Meta + D | Decrease |
|
|
|
|
| Meta + F | Toggle Floating |
|
|
|
|
| Meta + \ | Cycle Layout |
|
|
|
|
| | |
|
|
|
|
| Meta + Return | Set as Master |
|
|
|
|
| | |
|
|
|
|
| Meta + T | Use Tile Layout |
|
|
|
|
| Meta + M | Use Monocle Layout |
|
|
|
|
| _unbound_ | Use Spread Layout |
|
|
|
|
| _unbound_ | Use Stair Layout |
|
|
|
|
|
|
|
|
## Tips
|
|
|
|
|
|
|
|
### Setting Up for Multi-Screen
|
2019-01-28 10:01:33 +03:00
|
|
|
|
2021-08-28 11:20:19 +03:00
|
|
|
Bismuth supports multi-screen setup, but KWin has to be configured to unlock
|
2019-01-28 10:01:33 +03:00
|
|
|
the full potential of the script.
|
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
1. Enable `Separate Screen Focus` under `Window Management` >
|
2019-01-28 10:01:33 +03:00
|
|
|
`Window Behavior` > `Multiscreen Behaviour`
|
|
|
|
2. Bind keys for global shortcut `Switch to Next/Previous Screen`
|
|
|
|
(Recommend: `Meta + ,` / `Meta + .`)
|
|
|
|
3. Bind keys for global shortcut `Window to Next/Previous Screen`
|
|
|
|
(Recommend: `Meta + <` / `Meta + >`)
|
|
|
|
|
|
|
|
Note: `Separate Screen Focus` appears only when multiple monitors are present.
|
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
### Removing Title Bars
|
2018-11-14 10:28:05 +03:00
|
|
|
|
2019-01-28 10:01:33 +03:00
|
|
|
Breeze window decoration can be configured to completely remove title bars from
|
|
|
|
all windows:
|
|
|
|
|
2018-11-14 10:28:05 +03:00
|
|
|
1. `System Setting` > `Application Style` > `Window Decorations`
|
2019-01-28 10:01:33 +03:00
|
|
|
2. Click `Configure Breeze` inside the decoration preview.
|
2018-11-14 10:28:05 +03:00
|
|
|
3. `Window-Specific Overrides` tab > `Add` button
|
2019-01-28 10:01:33 +03:00
|
|
|
4. Enter the followings, and press `Ok`:
|
2018-11-14 10:28:05 +03:00
|
|
|
- `Regular expression to match`: `.*`
|
2019-01-28 10:01:33 +03:00
|
|
|
- Tick `Hide window title bar`
|
2018-11-14 10:28:05 +03:00
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
### Changing Border Colors
|
2018-11-14 10:28:05 +03:00
|
|
|
|
2019-01-28 10:01:33 +03:00
|
|
|
Changing the border color makes it easier to identify current window. This is
|
2021-08-28 14:44:30 +03:00
|
|
|
convenient if title bars are removed.
|
2018-11-14 10:28:05 +03:00
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
1. Open `~/.config/kdeglobals` with your favorite editor
|
|
|
|
2. Scroll down and find `[WM]` section
|
|
|
|
3. Append the followings to the section:
|
2020-03-03 10:27:34 +03:00
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
- `frame=61,174,233`: set the border color of active window to _RGB(61,174,233)_
|
|
|
|
- `inactiveFrame=239,240,241`: set the border color of inactive window to _RGB(239,240,241)_
|
2020-03-03 10:27:34 +03:00
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
Here's a nice 2-liner that'll do it for you:
|
|
|
|
|
|
|
|
kwriteconfig5 --file ~/.config/kdeglobals --group WM --key frame 61,174,233
|
|
|
|
kwriteconfig5 --file ~/.config/kdeglobals --group WM --key inactiveFrame 239,240,241
|
|
|
|
|
|
|
|
4. You must **restart** your session to see changes. (i.e. re-login, reboot)
|
2018-11-14 10:28:05 +03:00
|
|
|
|
2020-10-28 12:46:54 +03:00
|
|
|
Note: the RGB values presented here are for the default Breeze theme
|
|
|
|
|
|
|
|
Note: You might also need to set the border size larger than the theme's default:
|
|
|
|
`System Settings` > `Application Style` > `Window Decorations`: Untick `Use theme's default window border size` and adjust the size (right from the checkbox).
|
2018-11-16 08:02:04 +03:00
|
|
|
|
2021-08-28 11:25:45 +03:00
|
|
|
### Setting Minimum Geometry Size
|
2020-11-10 12:43:34 +03:00
|
|
|
|
2021-08-28 14:44:30 +03:00
|
|
|
Some applications like discord and KDE settings don't tile nicely as they have a minimum size requirement.
|
2020-11-10 12:43:34 +03:00
|
|
|
This causes the applications to overlap with other applications. To mitigate this we can set minimum size for all windows to be 0.
|
|
|
|
|
|
|
|
1. `System Setting` > `Window Management` > `Window Rules`
|
|
|
|
2. Click on `+ Add New...`
|
|
|
|
3. Set `Window class` to be `Unimportant`
|
|
|
|
4. Set `Window types` to `Normal Window`
|
|
|
|
5. Click `+ Add Properties...`
|
|
|
|
6. Add the `Minimum Size` Property
|
|
|
|
7. Set the fields to `Force` and `0` x `0`
|
|
|
|
8. Apply
|
2018-11-14 10:28:05 +03:00
|
|
|
|