mirror of
https://github.com/swaywm/sway.git
synced 2025-01-16 08:05:58 +01:00
Allow resizing tiled views via mod key
This commit is contained in:
parent
f4280e506b
commit
2dceae6224
1 changed files with 42 additions and 18 deletions
|
@ -356,27 +356,35 @@ static void handle_resize_floating_motion(struct sway_seat *seat,
|
||||||
|
|
||||||
static void handle_resize_tiling_motion(struct sway_seat *seat,
|
static void handle_resize_tiling_motion(struct sway_seat *seat,
|
||||||
struct sway_cursor *cursor) {
|
struct sway_cursor *cursor) {
|
||||||
int amount = 0;
|
int amount_x = 0;
|
||||||
|
int amount_y = 0;
|
||||||
int moved_x = cursor->cursor->x - seat->op_ref_lx;
|
int moved_x = cursor->cursor->x - seat->op_ref_lx;
|
||||||
int moved_y = cursor->cursor->y - seat->op_ref_ly;
|
int moved_y = cursor->cursor->y - seat->op_ref_ly;
|
||||||
|
enum wlr_edges edge_x = WLR_EDGE_NONE;
|
||||||
|
enum wlr_edges edge_y = WLR_EDGE_NONE;
|
||||||
struct sway_container *con = seat->op_container;
|
struct sway_container *con = seat->op_container;
|
||||||
switch (seat->op_resize_edge) {
|
|
||||||
case WLR_EDGE_TOP:
|
if (seat->op_resize_edge & WLR_EDGE_TOP) {
|
||||||
amount = (seat->op_ref_height - moved_y) - con->height;
|
amount_y = (seat->op_ref_height - moved_y) - con->height;
|
||||||
break;
|
edge_y = WLR_EDGE_TOP;
|
||||||
case WLR_EDGE_BOTTOM:
|
} else if (seat->op_resize_edge & WLR_EDGE_BOTTOM) {
|
||||||
amount = (seat->op_ref_height + moved_y) - con->height;
|
amount_y = (seat->op_ref_height + moved_y) - con->height;
|
||||||
break;
|
edge_y = WLR_EDGE_BOTTOM;
|
||||||
case WLR_EDGE_LEFT:
|
}
|
||||||
amount = (seat->op_ref_width - moved_x) - con->width;
|
if (seat->op_resize_edge & WLR_EDGE_LEFT) {
|
||||||
break;
|
amount_x = (seat->op_ref_width - moved_x) - con->width;
|
||||||
case WLR_EDGE_RIGHT:
|
edge_x = WLR_EDGE_LEFT;
|
||||||
amount = (seat->op_ref_width + moved_x) - con->width;
|
} else if (seat->op_resize_edge & WLR_EDGE_RIGHT) {
|
||||||
break;
|
amount_x = (seat->op_ref_width + moved_x) - con->width;
|
||||||
case WLR_EDGE_NONE:
|
edge_x = WLR_EDGE_RIGHT;
|
||||||
break;
|
}
|
||||||
|
|
||||||
|
if (amount_x != 0) {
|
||||||
|
container_resize_tiled(seat->op_container, edge_x, amount_x);
|
||||||
|
}
|
||||||
|
if (amount_y != 0) {
|
||||||
|
container_resize_tiled(seat->op_container, edge_y, amount_y);
|
||||||
}
|
}
|
||||||
container_resize_tiled(seat->op_container, seat->op_resize_edge, amount);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void cursor_send_pointer_motion(struct sway_cursor *cursor, uint32_t time_msec,
|
void cursor_send_pointer_motion(struct sway_cursor *cursor, uint32_t time_msec,
|
||||||
|
@ -655,10 +663,25 @@ void dispatch_cursor_button(struct sway_cursor *cursor,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Handle beginning floating move
|
// Handle tiling resize via mod
|
||||||
bool mod_pressed = keyboard &&
|
bool mod_pressed = keyboard &&
|
||||||
(wlr_keyboard_get_modifiers(keyboard) & config->floating_mod);
|
(wlr_keyboard_get_modifiers(keyboard) & config->floating_mod);
|
||||||
|
if (!is_floating) {
|
||||||
|
uint32_t btn_resize = config->floating_mod_inverse ?
|
||||||
|
BTN_LEFT : BTN_RIGHT;
|
||||||
|
if (button == btn_resize) {
|
||||||
|
edge = 0;
|
||||||
|
edge |= cursor->cursor->x > cont->x + cont->width / 2 ?
|
||||||
|
WLR_EDGE_RIGHT : WLR_EDGE_LEFT;
|
||||||
|
edge |= cursor->cursor->y > cont->y + cont->height / 2 ?
|
||||||
|
WLR_EDGE_BOTTOM : WLR_EDGE_TOP;
|
||||||
|
seat_set_focus(seat, cont);
|
||||||
|
seat_begin_resize_tiling(seat, cont, button, edge);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle beginning floating move
|
||||||
if (is_floating_or_child && !is_fullscreen_or_child) {
|
if (is_floating_or_child && !is_fullscreen_or_child) {
|
||||||
uint32_t btn_move = config->floating_mod_inverse ? BTN_RIGHT : BTN_LEFT;
|
uint32_t btn_move = config->floating_mod_inverse ? BTN_RIGHT : BTN_LEFT;
|
||||||
if (button == btn_move && state == WLR_BUTTON_PRESSED &&
|
if (button == btn_move && state == WLR_BUTTON_PRESSED &&
|
||||||
|
@ -688,6 +711,7 @@ void dispatch_cursor_button(struct sway_cursor *cursor,
|
||||||
uint32_t btn_resize = config->floating_mod_inverse ?
|
uint32_t btn_resize = config->floating_mod_inverse ?
|
||||||
BTN_LEFT : BTN_RIGHT;
|
BTN_LEFT : BTN_RIGHT;
|
||||||
if (button == btn_resize) {
|
if (button == btn_resize) {
|
||||||
|
edge = 0;
|
||||||
edge |= cursor->cursor->x > floater->x + floater->width / 2 ?
|
edge |= cursor->cursor->x > floater->x + floater->width / 2 ?
|
||||||
WLR_EDGE_RIGHT : WLR_EDGE_LEFT;
|
WLR_EDGE_RIGHT : WLR_EDGE_LEFT;
|
||||||
edge |= cursor->cursor->y > floater->y + floater->height / 2 ?
|
edge |= cursor->cursor->y > floater->y + floater->height / 2 ?
|
||||||
|
|
Loading…
Reference in a new issue