Gnome-shell extension that improves window tiling capabilities of stock gnome-shell.
gTile is used to moves/resize windows on a configurable grid scheme.
It can be used with either the mouse, or keyboard, including customizable keyboard presets for immediate window placement.
This extension is particularly useful for window management on (multiple) large monitors.
Preferred installation is from Gnome Extensions.
Log out and log back in.
You can alternatively manually install the latest version from GitHub master branch:
-
Clone the repository to a folder of your choice.
git clone https://github.com/gTile/gTile.git
Note: It is not recommended to clone the repository directly into
$HOME/.local/share/gnome-shell/extensions/gTile@vibou
. The code gTile installs into the extensions folder is a compiled version of the code in the git repository, and the files may conflict.) -
Build and install
You will need to install Bazel on your system to run the build tool. Then, you can run the installation script to install to
$HOME/.local/share/gnome-shell/extensions/gTile@vibou
.bazel run :install-extension
-
Log out and log back in. (If you don't want to log out, you can restart gnome shell, which keeps all your windows open. Type
Alt
+F2
, then typer
and hit enter.)
If you encounter buggy behavior, it may help to view the log messages gTile writes. These may be viewed with the following shell command:
journalctl --follow /usr/bin/gnome-shell | grep "gTile"
For configuration, please use the built-in preferences dialog (Gnome Tweak Tool -> Extensions -> gTile -> Preferences).
- Keyboard shortcuts:
- Can be assigned from the preferences window (Accelerators tab)
- Both the key combinations and the respective function are configurable
- Can be Global (can be used directly without the main gTile window)
- Can be non-global (can only be used when the gTile window is shown)
- Up to 30 accelerators can be configured, which should be plenty
- Up to 10 accelerators for AutoTiling
- Grid schemes:
- Are defined in the preferences window (Basic tab)
- Written as a comma-separated list of grid sizes like
8x7,3x2,4x6,4x7
(no spaces, columns first, then rows) - Grid lines can be shown when changing the grid size (Basic tab, disabled by default)
Resize presets are defined in the preferences window (Resize presets tab).
- Presets can be cycled. One keyboard shortcut can have several presets attached, which will change on subsequent presses of the hotkey. E.g.
3x3 1:1 1:1, 2:2 2:2
on the first press will put the window on the top left corner, on the second press - in the middle of the screen.
Presets have a format of "[grid size] [top left coordinate]:[bottom right coordinate]".
- Grid size is specified as "XxY", where X represents a number of columns and Y represents a number of rows. E.g. 3x3 divides the screen into 3 columns and 3 rows, the same way as in grid schemes under Basic.
- Grid size can be omitted. In that case preset will use the current grid set by the user in the UI or through the keyboard shortcut.
- If grid size is specified in the first place, it can be omitted in the subsequent places. gTile will use the grid size specified in the first place. E.g.
3x3 1:1 1:1, 2:2 2:2
(when2:2 2:2
is triggered, gTile will use 3x3 grid size). - Grids defined in the presets can differ from the grid sizes defined in the Basic tab.
gTile allows several coordinate types.
- "Tile" represents a tile number and tiles start from 1.
E.g.
3x3 1:1 1:1
is the top left corner of the screen that goes to the third of the width and the third of the height. Tiles are always integer values. - Negative tile works in the same way, but from the other side.
E.g.
3x3 -1:-1 -1:-1
represents a bottom right corner of the screen. - Percentage type is represented by floating point numbers from 0.0 till 1.0. For example, 0.25 represents a quarter of the width or height. When these types are used, grid sizes are ignored.
E.g.
0.0:0.0 0.5:0.5
represents a top left quarter of the screen (window is placed from x:0, y:0 and spans for 25% of the width and height). - Percentage type coordinates can be forced to be approximated to some grid size by adding
~
before the coordinate. E.g.0.0:0.0 ~0.25:~0.25
will make gTile to try to place the window in the top left corner, 25% of the width/height of the screen but gTile will snap it to the nearest grid line. When the grid is set to 3x3, the window will be placed at the top left corner, spanning for a third of the screen size, as it is the closest approximation of~0.25:~0.25
, which respects the grid size.
Coordinates can be mixed and matched freely, e.g. 0.0:2 ~0.5:4
is a perfectly valid syntax.
- Format examples:
2x2 1:2 1:2
or6x4 1:3 4:4, 1:1 4:4, 3x2 1:1 2:2
for multiple cyclable presets
- Make sure the window you want to resize has focus
- Click on the gTile icon on the tool bar, or press
Super
+Enter
(default) - The gTile dialog pop-up will show up in the center of your screen
What these buttons do:
-
<- this one toggles the animation of the changes to the preview drawing.
-
<- this one toggles the auto-closing of the gTile window after applying the changes.
- Use the mouse cursor to click on one of the desired corner coordinates, and then the other corner coordinates
- Window will resize after the second click
- Use the arrow keys to select the coordinate of the first corner and Shift-arrow to select the second coordinate
- a) Hit
Space
to change the grid scheme [optional] - b) Hit
Enter
and the window will resize - c) Hit
Escape
to cancel resize
- Press the accelerator key binding configured for the desired preset
- Window will resize, GUI stays open allowing for additional window resizing. Alternatively, enable Basic setting "Auto close on keyboard shortcut" to automatically exit after a single command.
You can also resize windows using keyboard shortcuts directly.
There are 3 groups of pre-configured shortcuts, representing the following grid schemes:
- Grid 2x2 ->
Super
+Alt
- Grid 2x3 ->
Super
+Control
- Grid 3x3 ->
Super
+Shift
These "grid selectors" are then combined with a keypad number to define the window placement.
Default shortcuts for Super
+Alt
+[KP_1..KP_9]
Shortcut | Description |
---|---|
Super +Alt +KP_1 |
Bottom left quarter of screen |
Super +Alt +KP_2 |
Bottom half |
Super +Alt +KP_3 |
Bottom right quarter |
Super +Alt +KP_4 |
Center left |
Super +Alt +KP_5 |
Center |
Super +Alt +KP_6 |
Center right |
Super +Alt +KP_7 |
Top left quarter |
Super +Alt +KP_8 |
Top half |
Super +Alt +KP_9 |
Top right quarter |
Notes:
- Preconfigured keyboard shortcuts are optimized for horizontal screens.
- For cyclable presets, invoke the corresponding shortcut consecutively on a window to activate format variants.
You can do auto tiling for all windows on screen
- Activate gTile by pressing
Super
+KP_Enter
or clicking on gTile icon - Click on one of 2 autotile buttons, or
- Press one of
[1..9,0]
(total 10 available) for vertical columns autotiling, orM
for "main" autotailing.- Press
M
multiple times to cycle through variants. - Main variables are configurable.
- Press
Screencast.2021-02-25.21.57.34-00.00.00.000-00.00.09.133.mp4
You can expand window - it will fill all available space up to borders with neighbors.
Default keyboard shortcut is <Alt><Ctrl>s
Snap-to-neighbors works only when gTile window is activated
- Focus on window you want to expand to fill space up to neighobrs borders
- Activate gTile window
<Super>Enter
- Press
<Alt><Ctrl>s
. Your windows will snap to neighbors. - Close gTile window
Escape
gTile is intended to supplement existing Gnome-shell keyboard shortcuts.
Here are some useful Gnome built-ins to keep in mind when configuring gTile:
Shortcut | Description |
---|---|
Super +Up |
Maximize |
Super +Down |
Un-Maximize (return to size and position previous to maximizing) |
Super +Left/Right |
left/right half of screen |
Shift +Super +Up/Down/Left/Right |
move window to adjacent monitor/workspace |
This extension is developed at GitHub.
It was originally developed by vibou with help from multiple contributors, and is now community supported.
gTile is licensed under the GPL v2+
For debugging, enable debug in preferences, and in terminal run journalctl /usr/bin/gnome-shell -f