mirror of
https://github.com/swaywm/sway.git
synced 2025-01-16 16:11:11 +01:00
Learn "gaps edge_gaps <on|off|toggle>".
When yes, the old behaviour of adding half the inner gap around each view is used. When no, don't add any gap when an edge of the view aligns with the workspace. The result is inner gap only between views, not against the workspace edge. The algorithm is not perfect because it means the extra space is distributed amongst edge-aligned views only, but it's simple, looks good and it works.
This commit is contained in:
parent
713c7d6e1e
commit
abc5fbfaec
5 changed files with 42 additions and 2 deletions
|
@ -57,6 +57,7 @@ struct sway_config {
|
||||||
bool auto_back_and_forth;
|
bool auto_back_and_forth;
|
||||||
bool seamless_mouse;
|
bool seamless_mouse;
|
||||||
|
|
||||||
|
bool edge_gaps;
|
||||||
int gaps_inner;
|
int gaps_inner;
|
||||||
int gaps_outer;
|
int gaps_outer;
|
||||||
};
|
};
|
||||||
|
|
|
@ -68,6 +68,11 @@ Commands
|
||||||
**fullscreen**::
|
**fullscreen**::
|
||||||
Toggles fullscreen status for the focused view.
|
Toggles fullscreen status for the focused view.
|
||||||
|
|
||||||
|
**gaps** edge_gaps <on|off|toggle>::
|
||||||
|
Whether or not to add gaps between views and workspace edges if amount of
|
||||||
|
inner gap is not zero. When _no_, no gap is added where the view is aligned to
|
||||||
|
the workspace edge, effectively creating gaps only between views.
|
||||||
|
|
||||||
**gaps** <amount>::
|
**gaps** <amount>::
|
||||||
Sets default _amount_ pixels as the gap between each view, and around each
|
Sets default _amount_ pixels as the gap between each view, and around each
|
||||||
workspace.
|
workspace.
|
||||||
|
|
|
@ -761,7 +761,8 @@ static struct cmd_results *cmd_gaps(int argc, char **argv) {
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
const char* expected_syntax =
|
const char* expected_syntax =
|
||||||
"Expected 'gaps <inner|outer> <current|all|workspace> <set|plus|minus n>'";
|
"Expected 'gaps edge_gaps <on|off|toggle>' or "
|
||||||
|
"'gaps <inner|outer> <current|all|workspace> <set|plus|minus n>'";
|
||||||
const char *amount_str = argv[0];
|
const char *amount_str = argv[0];
|
||||||
// gaps amount
|
// gaps amount
|
||||||
if (argc >= 1 && isdigit(*amount_str)) {
|
if (argc >= 1 && isdigit(*amount_str)) {
|
||||||
|
@ -789,6 +790,20 @@ static struct cmd_results *cmd_gaps(int argc, char **argv) {
|
||||||
}
|
}
|
||||||
arrange_windows(&root_container, -1, -1);
|
arrange_windows(&root_container, -1, -1);
|
||||||
return cmd_results_new(CMD_SUCCESS, NULL, NULL);
|
return cmd_results_new(CMD_SUCCESS, NULL, NULL);
|
||||||
|
} else if (argc == 2 && strcasecmp(argv[0], "edge_gaps") == 0) {
|
||||||
|
// gaps edge_gaps <on|off|toggle>
|
||||||
|
if (strcasecmp(argv[1], "toggle") == 0) {
|
||||||
|
if (config->reading) {
|
||||||
|
return cmd_results_new(CMD_FAILURE, "gaps edge_gaps toggle",
|
||||||
|
"Can't be used in config file.");
|
||||||
|
}
|
||||||
|
config->edge_gaps = !config->edge_gaps;
|
||||||
|
} else {
|
||||||
|
config->edge_gaps =
|
||||||
|
(strcasecmp(argv[1], "yes") == 0 || strcasecmp(argv[1], "on") == 0);
|
||||||
|
}
|
||||||
|
arrange_windows(&root_container, -1, -1);
|
||||||
|
return cmd_results_new(CMD_SUCCESS, NULL, NULL);
|
||||||
}
|
}
|
||||||
// gaps inner|outer current|all set|plus|minus n
|
// gaps inner|outer current|all set|plus|minus n
|
||||||
if (argc < 4 || config->reading) {
|
if (argc < 4 || config->reading) {
|
||||||
|
|
|
@ -105,6 +105,7 @@ static void config_defaults(struct sway_config *config) {
|
||||||
config->seamless_mouse = true;
|
config->seamless_mouse = true;
|
||||||
config->reading = false;
|
config->reading = false;
|
||||||
|
|
||||||
|
config->edge_gaps = false;
|
||||||
config->gaps_inner = 0;
|
config->gaps_inner = 0;
|
||||||
config->gaps_outer = 0;
|
config->gaps_outer = 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -367,9 +367,27 @@ void update_geometry(swayc_t *container) {
|
||||||
if (op->focused == ws) {
|
if (op->focused == ws) {
|
||||||
wlc_view_bring_to_front(container->handle);
|
wlc_view_bring_to_front(container->handle);
|
||||||
}
|
}
|
||||||
|
} else if (!config->edge_gaps && gap > 0) {
|
||||||
|
// Remove gap against the workspace edges. Because a pixel is not
|
||||||
|
// divisable, depending on gap size and the number of siblings our view
|
||||||
|
// might be at the workspace edge without being exactly so (thus test
|
||||||
|
// with gap, and align correctly).
|
||||||
|
if (container->x - gap <= ws->x) {
|
||||||
|
geometry.origin.x = ws->x;
|
||||||
|
geometry.size.w = container->width - gap/2;
|
||||||
|
}
|
||||||
|
if (container->y - gap <= ws->y) {
|
||||||
|
geometry.origin.y = ws->y;
|
||||||
|
geometry.size.h = container->height - gap/2;
|
||||||
|
}
|
||||||
|
if (container->x + container->width + gap >= ws->x + ws->width) {
|
||||||
|
geometry.size.w = ws->width - geometry.origin.x;
|
||||||
|
}
|
||||||
|
if (container->y + container->height + gap >= ws->y + ws->height) {
|
||||||
|
geometry.size.h = ws->height - geometry.origin.y;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
wlc_view_set_geometry(container->handle, 0, &geometry);
|
wlc_view_set_geometry(container->handle, 0, &geometry);
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void arrange_windows_r(swayc_t *container, double width, double height) {
|
static void arrange_windows_r(swayc_t *container, double width, double height) {
|
||||||
|
|
Loading…
Reference in a new issue