mirror of
https://github.com/brl/mutter.git
synced 2024-11-23 00:20:42 -05:00
display: get button event coordinates with the helper functions
This commit is contained in:
parent
3e3ad71a68
commit
7a3d49b88e
@ -1940,6 +1940,7 @@ event_callback (XEvent *event,
|
||||
{
|
||||
Window xwindow = meta_input_event_get_window (display, event);
|
||||
Time evtime = meta_input_event_get_time (display, event);
|
||||
gdouble ev_root_x, ev_root_y;
|
||||
guint n_button, state;
|
||||
|
||||
if (window && !window->override_redirect &&
|
||||
@ -1981,6 +1982,10 @@ event_callback (XEvent *event,
|
||||
case ButtonPress:
|
||||
meta_input_event_get_button (display, event, &n_button);
|
||||
meta_input_event_get_state (display, event, &state);
|
||||
meta_input_event_get_coordinates (display, event,
|
||||
NULL, NULL,
|
||||
&ev_root_x,
|
||||
&ev_root_y);
|
||||
|
||||
if (display->grab_op == META_GRAB_OP_COMPOSITOR)
|
||||
break;
|
||||
@ -2081,10 +2086,10 @@ event_callback (XEvent *event,
|
||||
|
||||
meta_window_get_position (window, &root_x, &root_y);
|
||||
|
||||
west = event->xbutton.x_root < (root_x + 1 * window->rect.width / 3);
|
||||
east = event->xbutton.x_root > (root_x + 2 * window->rect.width / 3);
|
||||
north = event->xbutton.y_root < (root_y + 1 * window->rect.height / 3);
|
||||
south = event->xbutton.y_root > (root_y + 2 * window->rect.height / 3);
|
||||
west = ev_root_x < (root_x + 1 * window->rect.width / 3);
|
||||
east = ev_root_x > (root_x + 2 * window->rect.width / 3);
|
||||
north = ev_root_y < (root_y + 1 * window->rect.height / 3);
|
||||
south = ev_root_y > (root_y + 2 * window->rect.height / 3);
|
||||
|
||||
if (north && west)
|
||||
op = META_GRAB_OP_RESIZING_NW;
|
||||
@ -2115,8 +2120,8 @@ event_callback (XEvent *event,
|
||||
n_button,
|
||||
0,
|
||||
evtime,
|
||||
event->xbutton.x_root,
|
||||
event->xbutton.y_root);
|
||||
ev_root_x,
|
||||
ev_root_y);
|
||||
}
|
||||
}
|
||||
else if (n_button == meta_prefs_get_mouse_button_menu())
|
||||
@ -2124,8 +2129,8 @@ event_callback (XEvent *event,
|
||||
if (meta_prefs_get_raise_on_click ())
|
||||
meta_window_raise (window);
|
||||
meta_window_show_menu (window,
|
||||
event->xbutton.x_root,
|
||||
event->xbutton.y_root,
|
||||
ev_root_x,
|
||||
ev_root_y,
|
||||
n_button,
|
||||
evtime);
|
||||
}
|
||||
@ -2172,8 +2177,8 @@ event_callback (XEvent *event,
|
||||
n_button,
|
||||
0,
|
||||
evtime,
|
||||
event->xbutton.x_root,
|
||||
event->xbutton.y_root);
|
||||
ev_root_x,
|
||||
ev_root_y);
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
Loading…
Reference in New Issue
Block a user