mirror of
https://github.com/swaywm/sway.git
synced 2025-01-25 18:26:45 +00:00
Disable inner gaps when in tabbed/stacked mode
This commit is contained in:
parent
3e1f78ab26
commit
5492277f0c
|
@ -218,6 +218,7 @@ swayc_t *new_container(swayc_t *child, enum swayc_layouts layout) {
|
||||||
cont->y = child->y;
|
cont->y = child->y;
|
||||||
cont->visible = child->visible;
|
cont->visible = child->visible;
|
||||||
cont->cached_geometry = child->cached_geometry;
|
cont->cached_geometry = child->cached_geometry;
|
||||||
|
cont->gaps = child->gaps;
|
||||||
|
|
||||||
/* Container inherits all of workspaces children, layout and whatnot */
|
/* Container inherits all of workspaces children, layout and whatnot */
|
||||||
if (child->type == C_WORKSPACE) {
|
if (child->type == C_WORKSPACE) {
|
||||||
|
@ -680,7 +681,7 @@ bool swayc_is_child_of(swayc_t *child, swayc_t *parent) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int swayc_gap(swayc_t *container) {
|
int swayc_gap(swayc_t *container) {
|
||||||
if (container->type == C_VIEW) {
|
if (container->type == C_VIEW || container->type == C_CONTAINER) {
|
||||||
return container->gaps >= 0 ? container->gaps : config->gaps_inner;
|
return container->gaps >= 0 ? container->gaps : config->gaps_inner;
|
||||||
} else if (container->type == C_WORKSPACE) {
|
} else if (container->type == C_WORKSPACE) {
|
||||||
int base = container->gaps >= 0 ? container->gaps : config->gaps_outer;
|
int base = container->gaps >= 0 ? container->gaps : config->gaps_outer;
|
||||||
|
|
102
sway/layout.c
102
sway/layout.c
|
@ -477,6 +477,45 @@ void update_layout_geometry(swayc_t *parent, enum swayc_layouts prev_layout) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int update_gap_geometry(swayc_t *container, struct wlc_geometry *g) {
|
||||||
|
swayc_t *ws = swayc_parent_by_type(container, C_WORKSPACE);
|
||||||
|
swayc_t *op = ws->parent;
|
||||||
|
int gap = container->is_floating ? 0 : swayc_gap(container);
|
||||||
|
if (gap % 2 != 0) {
|
||||||
|
// because gaps are implemented as "half sized margins" it's currently
|
||||||
|
// not possible to align views properly with odd sized gaps.
|
||||||
|
gap -= 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
g->origin.x = container->x + gap/2 < op->width ? container->x + gap/2 : op->width-1;
|
||||||
|
g->origin.y = container->y + gap/2 < op->height ? container->y + gap/2 : op->height-1;
|
||||||
|
g->size.w = container->width > gap ? container->width - gap : 1;
|
||||||
|
g->size.h = container->height > gap ? container->height - gap : 1;
|
||||||
|
|
||||||
|
if ((!config->edge_gaps && gap > 0) || (config->smart_gaps && ws->children->length == 1)) {
|
||||||
|
// 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) {
|
||||||
|
g->origin.x = ws->x;
|
||||||
|
g->size.w = container->width - gap/2;
|
||||||
|
}
|
||||||
|
if (container->y - gap <= ws->y) {
|
||||||
|
g->origin.y = ws->y;
|
||||||
|
g->size.h = container->height - gap/2;
|
||||||
|
}
|
||||||
|
if (container->x + container->width + gap >= ws->x + ws->width) {
|
||||||
|
g->size.w = ws->x + ws->width - g->origin.x;
|
||||||
|
}
|
||||||
|
if (container->y + container->height + gap >= ws->y + ws->height) {
|
||||||
|
g->size.h = ws->y + ws->height - g->origin.y;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return gap;
|
||||||
|
}
|
||||||
|
|
||||||
void update_geometry(swayc_t *container) {
|
void update_geometry(swayc_t *container) {
|
||||||
if (container->type != C_VIEW && container->type != C_CONTAINER) {
|
if (container->type != C_VIEW && container->type != C_CONTAINER) {
|
||||||
return;
|
return;
|
||||||
|
@ -485,23 +524,26 @@ void update_geometry(swayc_t *container) {
|
||||||
swayc_t *ws = swayc_parent_by_type(container, C_WORKSPACE);
|
swayc_t *ws = swayc_parent_by_type(container, C_WORKSPACE);
|
||||||
swayc_t *op = ws->parent;
|
swayc_t *op = ws->parent;
|
||||||
swayc_t *parent = container->parent;
|
swayc_t *parent = container->parent;
|
||||||
int gap = container->is_floating ? 0 : swayc_gap(container);
|
|
||||||
if (gap % 2 != 0) {
|
|
||||||
// because gaps are implemented as "half sized margins" it's currently
|
|
||||||
// not possible to align views properly with odd sized gaps.
|
|
||||||
gap -= 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
struct wlc_geometry geometry = {
|
struct wlc_geometry geometry = {
|
||||||
.origin = {
|
.origin = {
|
||||||
.x = container->x + gap/2 < op->width ? container->x + gap/2 : op->width-1,
|
.x = container->x < op->width ? container->x : op->width-1,
|
||||||
.y = container->y + gap/2 < op->height ? container->y + gap/2 : op->height-1
|
.y = container->y < op->height ? container->y : op->height-1
|
||||||
},
|
},
|
||||||
.size = {
|
.size = {
|
||||||
.w = container->width > gap ? container->width - gap : 1,
|
.w = container->width,
|
||||||
.h = container->height > gap ? container->height - gap : 1,
|
.h = container->height,
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
int gap = 0;
|
||||||
|
|
||||||
|
// apply inner gaps to non-tabbed/stacked containers
|
||||||
|
swayc_t *p = swayc_tabbed_stacked_parent(container);
|
||||||
|
if (p == NULL) {
|
||||||
|
gap = update_gap_geometry(container, &geometry);
|
||||||
|
}
|
||||||
|
|
||||||
if (swayc_is_fullscreen(container)) {
|
if (swayc_is_fullscreen(container)) {
|
||||||
swayc_t *output = swayc_parent_by_type(container, C_OUTPUT);
|
swayc_t *output = swayc_parent_by_type(container, C_OUTPUT);
|
||||||
const struct wlc_size *size = wlc_output_get_resolution(output->handle);
|
const struct wlc_size *size = wlc_output_get_resolution(output->handle);
|
||||||
|
@ -512,28 +554,7 @@ 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) || (config->smart_gaps && ws->children->length == 1)) {
|
|
||||||
// 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->x + ws->width - geometry.origin.x;
|
|
||||||
}
|
|
||||||
if (container->y + container->height + gap >= ws->y + ws->height) {
|
|
||||||
geometry.size.h = ws->y + ws->height - geometry.origin.y;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (swayc_is_fullscreen(container)) {
|
|
||||||
container->border_geometry = wlc_geometry_zero;
|
container->border_geometry = wlc_geometry_zero;
|
||||||
container->title_bar_geometry = wlc_geometry_zero;
|
container->title_bar_geometry = wlc_geometry_zero;
|
||||||
} else if (container->is_floating) { // allocate border for floating window
|
} else if (container->is_floating) { // allocate border for floating window
|
||||||
|
@ -768,14 +789,23 @@ static void arrange_windows_r(swayc_t *container, double width, double height) {
|
||||||
x = container->x;
|
x = container->x;
|
||||||
y = container->y;
|
y = container->y;
|
||||||
|
|
||||||
|
// add gaps to top level tapped/stacked container
|
||||||
|
if (container->layout == L_TABBED || container->layout == L_STACKED) {
|
||||||
|
update_geometry(container);
|
||||||
|
width = container->border_geometry.size.w;
|
||||||
|
height = container->border_geometry.size.h;
|
||||||
|
x = container->border_geometry.origin.x;
|
||||||
|
y = container->border_geometry.origin.y;
|
||||||
|
}
|
||||||
|
|
||||||
// update container size if it's a child in a tabbed/stacked layout
|
// update container size if it's a child in a tabbed/stacked layout
|
||||||
if (swayc_is_tabbed_stacked(container)) {
|
if (swayc_is_tabbed_stacked(container)) {
|
||||||
// Use parent geometry as a base for calculating
|
// Use parent border_geometry as a base for calculating
|
||||||
// container geometry
|
// container geometry
|
||||||
container->width = container->parent->width;
|
container->width = container->parent->border_geometry.size.w;
|
||||||
container->height = container->parent->height;
|
container->height = container->parent->border_geometry.size.h;
|
||||||
container->x = container->parent->x;
|
container->x = container->parent->border_geometry.origin.x;
|
||||||
container->y = container->parent->y;
|
container->y = container->parent->border_geometry.origin.y;
|
||||||
update_geometry(container);
|
update_geometry(container);
|
||||||
width = container->width = container->actual_geometry.size.w;
|
width = container->width = container->actual_geometry.size.w;
|
||||||
height = container->height = container->actual_geometry.size.h;
|
height = container->height = container->actual_geometry.size.h;
|
||||||
|
|
Loading…
Reference in a new issue