From 34c1c7d4165586c674e6f52bc6ea3a446f503144 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Abd=C3=B3=20Roig-Maranges?= Date: Fri, 14 Sep 2012 20:14:22 +0200 Subject: [PATCH] Makes awful.screen.focus keep the cursor position on screen When changing focus to an other screen, awful.screen.focus keeps relative position of the cursor, instead of moving to the top left corner. Does not trigger mouse:enter and mouse:leave signals. Signed-off-by: Uli Schlachter --- lib/awful/screen.lua.in | 20 +++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/lib/awful/screen.lua.in b/lib/awful/screen.lua.in index 5088bdc8..00fd16a8 100644 --- a/lib/awful/screen.lua.in +++ b/lib/awful/screen.lua.in @@ -37,14 +37,28 @@ function screen.getbycoord(x, y) end end ---- Give the focus to a screen, and move pointer. +--- Give the focus to a screen, and move pointer. Keeps relative position of the pointer on the screen. -- @param screen Screen number. function screen.focus(_screen) if _screen > capi.screen.count() then _screen = capi.mouse.screen end + + -- screen and pos for current screen + local s = capi.mouse.screen + local pos = capi.mouse.coords() + + -- keep relative mouse position on the new screen + local relx = (pos.x - capi.screen[s].geometry.x) / capi.screen[s].geometry.width + local rely = (pos.y - capi.screen[s].geometry.y) / capi.screen[s].geometry.height + + pos.x = capi.screen[_screen].geometry.x + relx * capi.screen[_screen].geometry.width + pos.y = capi.screen[_screen].geometry.y + rely * capi.screen[_screen].geometry.height + + -- move cursor without triggering signals mouse::enter and mouse::leave + capi.mouse.screen = _screen + capi.mouse.coords(pos, true) + local c = client.focus.history.get(_screen, 0) if c then capi.client.focus = c end - -- Move the mouse on the screen - capi.mouse.screen = _screen end --- Give the focus to a screen, and move pointer, by physical position relative to current screen.