[mouse] Add optionnal argument to specify corner to grab when resizing
Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
parent
8078d45da1
commit
ca81c9a1f1
118
mouse.c
118
mouse.c
|
@ -40,6 +40,34 @@
|
||||||
|
|
||||||
extern awesome_t globalconf;
|
extern awesome_t globalconf;
|
||||||
|
|
||||||
|
/** Define corners. */
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
AutoCorner,
|
||||||
|
TopRightCorner,
|
||||||
|
TopLeftCorner,
|
||||||
|
BottomLeftCorner,
|
||||||
|
BottomRightCorner
|
||||||
|
} corner_t;
|
||||||
|
|
||||||
|
/** Convert a corner name into a corner type.
|
||||||
|
* \param str A string.
|
||||||
|
* \return A corner type.
|
||||||
|
*/
|
||||||
|
static corner_t
|
||||||
|
a_strtocorner(const char *str)
|
||||||
|
{
|
||||||
|
if(!a_strcmp(str, "bottomright"))
|
||||||
|
return BottomRightCorner;
|
||||||
|
else if(!a_strcmp(str, "bottomleft"))
|
||||||
|
return BottomLeftCorner;
|
||||||
|
else if(!a_strcmp(str, "topleft"))
|
||||||
|
return TopLeftCorner;
|
||||||
|
else if(!a_strcmp(str, "topright"))
|
||||||
|
return TopRightCorner;
|
||||||
|
return AutoCorner;
|
||||||
|
}
|
||||||
|
|
||||||
/** Snap an area to the outside of an area.
|
/** Snap an area to the outside of an area.
|
||||||
* \param geometry geometry of the area to snap
|
* \param geometry geometry of the area to snap
|
||||||
* \param snap_geometry geometry of snapping area
|
* \param snap_geometry geometry of snapping area
|
||||||
|
@ -432,9 +460,10 @@ mouse_track_mouse_drag(int *x, int *y)
|
||||||
|
|
||||||
/** Resize a floating client with the mouse.
|
/** Resize a floating client with the mouse.
|
||||||
* \param c The client to resize.
|
* \param c The client to resize.
|
||||||
|
* \param c The corner to resize with.
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
mouse_client_resize_floating(client_t *c)
|
mouse_client_resize_floating(client_t *c, corner_t corner)
|
||||||
{
|
{
|
||||||
xcb_screen_t *screen;
|
xcb_screen_t *screen;
|
||||||
/* one corner of the client has a fixed position */
|
/* one corner of the client has a fixed position */
|
||||||
|
@ -445,57 +474,69 @@ mouse_client_resize_floating(client_t *c)
|
||||||
simple_window_t *sw;
|
simple_window_t *sw;
|
||||||
draw_context_t *ctx;
|
draw_context_t *ctx;
|
||||||
size_t cursor = CurResize;
|
size_t cursor = CurResize;
|
||||||
|
int top, bottom, left, right;
|
||||||
|
|
||||||
screen = xcb_aux_get_screen(globalconf.connection, c->phys_screen);
|
screen = xcb_aux_get_screen(globalconf.connection, c->phys_screen);
|
||||||
|
|
||||||
/* get current mouse poistion */
|
/* get current mouse position */
|
||||||
mouse_query_pointer(screen->root, &mouse_x, &mouse_y);
|
mouse_query_pointer(screen->root, &mouse_x, &mouse_y);
|
||||||
|
|
||||||
|
top = c->geometry.y;
|
||||||
|
bottom = top + c->geometry.height;
|
||||||
|
left = c->geometry.x;
|
||||||
|
right = left + c->geometry.width;
|
||||||
|
|
||||||
/* figure out which corner to move */
|
/* figure out which corner to move */
|
||||||
|
if(corner == AutoCorner)
|
||||||
{
|
{
|
||||||
int top, bottom, left, right;
|
|
||||||
|
|
||||||
top = c->geometry.y;
|
|
||||||
bottom = top + c->geometry.height;
|
|
||||||
left = c->geometry.x;
|
|
||||||
right = left + c->geometry.width;
|
|
||||||
|
|
||||||
if(abs(top - mouse_y) < abs(bottom - mouse_y))
|
if(abs(top - mouse_y) < abs(bottom - mouse_y))
|
||||||
{
|
{
|
||||||
mouse_y = top;
|
|
||||||
fixed_y = bottom;
|
|
||||||
if(abs(left - mouse_x) < abs(right - mouse_x))
|
if(abs(left - mouse_x) < abs(right - mouse_x))
|
||||||
{
|
|
||||||
mouse_x = left;
|
|
||||||
fixed_x = right;
|
|
||||||
cursor = CurTopLeft;
|
cursor = CurTopLeft;
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
corner = TopRightCorner;
|
||||||
mouse_x = right;
|
|
||||||
fixed_x = left;
|
|
||||||
cursor = CurTopRight;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
mouse_y = bottom;
|
|
||||||
fixed_y = top;
|
|
||||||
if(abs(left - mouse_x) < abs(right - mouse_x))
|
if(abs(left - mouse_x) < abs(right - mouse_x))
|
||||||
{
|
corner = BottomLeftCorner;
|
||||||
mouse_x = left;
|
|
||||||
fixed_x = right;
|
|
||||||
cursor = CurBotLeft;
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
corner = BottomRightCorner;
|
||||||
mouse_x = right;
|
|
||||||
fixed_x = left;
|
|
||||||
cursor = CurBotRight;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
switch(corner)
|
||||||
|
{
|
||||||
|
default:
|
||||||
|
mouse_y = top;
|
||||||
|
fixed_y = bottom;
|
||||||
|
mouse_x = left;
|
||||||
|
fixed_x = right;
|
||||||
|
corner = TopLeftCorner;
|
||||||
|
break;
|
||||||
|
case TopRightCorner:
|
||||||
|
mouse_y = top;
|
||||||
|
fixed_y = bottom;
|
||||||
|
mouse_x = right;
|
||||||
|
fixed_x = left;
|
||||||
|
cursor = CurTopRight;
|
||||||
|
break;
|
||||||
|
case BottomLeftCorner:
|
||||||
|
mouse_y = bottom;
|
||||||
|
fixed_y = top;
|
||||||
|
mouse_x = left;
|
||||||
|
fixed_x = right;
|
||||||
|
cursor = CurBotLeft;
|
||||||
|
break;
|
||||||
|
case BottomRightCorner:
|
||||||
|
mouse_y = bottom;
|
||||||
|
fixed_y = top;
|
||||||
|
mouse_x = right;
|
||||||
|
fixed_x = left;
|
||||||
|
cursor = CurBotRight;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
/* grab the pointer */
|
/* grab the pointer */
|
||||||
if(!mouse_grab_pointer(screen->root, cursor))
|
if(!mouse_grab_pointer(screen->root, cursor))
|
||||||
return;
|
return;
|
||||||
|
@ -632,9 +673,10 @@ mouse_client_resize_tiled(client_t *c)
|
||||||
|
|
||||||
/** Resize a client with the mouse.
|
/** Resize a client with the mouse.
|
||||||
* \param c The client to resize.
|
* \param c The client to resize.
|
||||||
|
* \param corner The corner to use.
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
mouse_client_resize(client_t *c)
|
mouse_client_resize(client_t *c, corner_t corner)
|
||||||
{
|
{
|
||||||
int n, screen;
|
int n, screen;
|
||||||
tag_t **curtags;
|
tag_t **curtags;
|
||||||
|
@ -653,7 +695,7 @@ mouse_client_resize(client_t *c)
|
||||||
|
|
||||||
c->ismax = false;
|
c->ismax = false;
|
||||||
|
|
||||||
mouse_client_resize_floating(c);
|
mouse_client_resize_floating(c, corner);
|
||||||
}
|
}
|
||||||
else if (layout == layout_tile || layout == layout_tileleft
|
else if (layout == layout_tile || layout == layout_tileleft
|
||||||
|| layout == layout_tilebottom || layout == layout_tiletop)
|
|| layout == layout_tilebottom || layout == layout_tiletop)
|
||||||
|
@ -691,12 +733,18 @@ luaA_mouse_coords_set(lua_State *L)
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Resize a client with mouse.
|
/** Resize a client with mouse.
|
||||||
|
* \param An optionnal corner, such as bottomleft, topright, etc.
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
luaA_client_mouse_resize(lua_State *L)
|
luaA_client_mouse_resize(lua_State *L)
|
||||||
{
|
{
|
||||||
client_t **c = luaA_checkudata(L, 1, "client");
|
client_t **c = luaA_checkudata(L, 1, "client");
|
||||||
mouse_client_resize(*c);
|
corner_t corner = AutoCorner;
|
||||||
|
|
||||||
|
if(lua_gettop(L) == 2 && lua_isstring(L, 2))
|
||||||
|
corner = a_strtocorner(lua_tostring(L, 2));
|
||||||
|
|
||||||
|
mouse_client_resize(*c, corner);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue