Support remote requests to drag windows

This commit is contained in:
Kevin Lange 2017-01-08 15:48:26 +09:00
parent 369c6eb09a
commit 0ed855d51d
3 changed files with 23 additions and 8 deletions

View File

@ -1609,9 +1609,13 @@ static void adjust_window_opacity(yutani_globals_t * yg, int direction) {
}
static void mouse_start_drag(yutani_globals_t * yg) {
static void mouse_start_drag(yutani_globals_t * yg, yutani_server_window_t * w) {
set_focused_at(yg, yg->mouse_x / MOUSE_SCALE, yg->mouse_y / MOUSE_SCALE);
if (!w) {
yg->mouse_window = get_focused(yg);
} else {
yg->mouse_window = w;
}
if (yg->mouse_window) {
if (yg->mouse_window->z == YUTANI_ZORDER_BOTTOM || yg->mouse_window->z == YUTANI_ZORDER_TOP
|| yg->mouse_window->server_flags & YUTANI_WINDOW_FLAG_DISALLOW_DRAG) {
@ -1623,6 +1627,7 @@ static void mouse_start_drag(yutani_globals_t * yg) {
yg->mouse_init_y = yg->mouse_y;
yg->mouse_win_x = yg->mouse_window->x;
yg->mouse_win_y = yg->mouse_window->y;
yg->mouse_drag_button = yg->last_mouse_buttons;
mark_screen(yg, yg->mouse_x / MOUSE_SCALE - MOUSE_OFFSET_X, yg->mouse_y / MOUSE_SCALE - MOUSE_OFFSET_Y, MOUSE_WIDTH, MOUSE_HEIGHT);
make_top(yg, yg->mouse_window);
}
@ -1731,7 +1736,7 @@ static void handle_mouse_event(yutani_globals_t * yg, struct yutani_msg_mouse_ev
case YUTANI_MOUSE_STATE_NORMAL:
{
if ((me->event.buttons & YUTANI_MOUSE_BUTTON_LEFT) && (yg->kbd_state.k_alt)) {
mouse_start_drag(yg);
mouse_start_drag(yg, NULL);
} else if ((me->event.buttons & YUTANI_MOUSE_SCROLL_UP) && (yg->kbd_state.k_alt)) {
adjust_window_opacity(yg, 8);
} else if ((me->event.buttons & YUTANI_MOUSE_SCROLL_DOWN) && (yg->kbd_state.k_alt)) {
@ -1791,7 +1796,9 @@ static void handle_mouse_event(yutani_globals_t * yg, struct yutani_msg_mouse_ev
break;
case YUTANI_MOUSE_STATE_MOVING:
{
if (!(me->event.buttons & YUTANI_MOUSE_BUTTON_LEFT)) {
int button_down = (me->event.buttons & YUTANI_MOUSE_BUTTON_LEFT);
int drag_stop = yg->mouse_drag_button != 0 ? (!button_down) : (button_down);
if (drag_stop) {
yg->mouse_window = NULL;
yg->mouse_state = YUTANI_MOUSE_STATE_NORMAL;
mark_screen(yg, yg->mouse_x / MOUSE_SCALE - MOUSE_OFFSET_X, yg->mouse_y / MOUSE_SCALE - MOUSE_OFFSET_Y, MOUSE_WIDTH, MOUSE_HEIGHT);
@ -2067,6 +2074,8 @@ int main(int argc, char * argv[]) {
yg->window_subscribers = list_create();
yg->timer_subscribers = list_create();
yg->last_mouse_buttons = 0;
yutani_cairo_init(yg);
pthread_t render_thread;
@ -2089,7 +2098,6 @@ int main(int argc, char * argv[]) {
mouse_device_packet_t packet;
key_event_t event;
key_event_state_t state = {0};
uint32_t last_mouse_buttons = 0;
fds[0] = fileno(server);
@ -2169,7 +2177,7 @@ int main(int argc, char * argv[]) {
} else if (index == 1) {
int r = read(mfd, (char *)&packet, sizeof(mouse_device_packet_t));
if (r > 0) {
last_mouse_buttons = packet.buttons;
yg->last_mouse_buttons = packet.buttons;
yutani_msg_t * m = yutani_msg_build_mouse_event(0, &packet, YUTANI_MOUSE_EVENT_TYPE_RELATIVE);
handle_mouse_event(yg, (struct yutani_msg_mouse_event *)m->data);
free(m);
@ -2178,7 +2186,7 @@ int main(int argc, char * argv[]) {
} else if (index == 3) {
int r = read(amfd, (char *)&packet, sizeof(mouse_device_packet_t));
if (r > 0) {
packet.buttons = last_mouse_buttons & 0xF;
packet.buttons = yg->last_mouse_buttons & 0xF;
yutani_msg_t * m = yutani_msg_build_mouse_event(0, &packet, YUTANI_MOUSE_EVENT_TYPE_ABSOLUTE);
handle_mouse_event(yg, (struct yutani_msg_mouse_event *)m->data);
free(m);
@ -2432,7 +2440,7 @@ int main(int argc, char * argv[]) {
yutani_server_window_t * w = hashmap_get(yg->wids_to_windows, (void *)wa->wid);
if (w) {
/* Start dragging */
mouse_start_drag(yg);
mouse_start_drag(yg, w);
}
}
break;

View File

@ -172,6 +172,7 @@ typedef struct {
uint32_t timer_precison;
list_t * timer_subscribers;
uint32_t last_mouse_buttons;
} yutani_globals_t;
struct key_bind {

View File

@ -806,6 +806,12 @@ void yutani_window_drag_start(yutani_t * yctx, yutani_window_t * window) {
free(m);
}
void yutani_window_drag_start_wid(yutani_t * yctx, yutani_wid_t wid) {
yutani_msg_t * m = yutani_msg_build_window_drag_start(wid);
int result = yutani_msg_send(yctx, m);
free(m);
}
void yutani_window_update_shape(yutani_t * yctx, yutani_window_t * window, int set_shape) {
yutani_msg_t * m = yutani_msg_build_window_update_shape(window->wid, set_shape);
int result = yutani_msg_send(yctx, m);