From: Anselm R. Garbe Date: Fri, 2 Mar 2007 20:50:05 +0000 (+0100) Subject: grab on the slock window instead on the root window X-Git-Url: https://git.danieliu.xyz/?a=commitdiff_plain;h=8322f22871ee1da82546dfcdea484ef9db6d4942;p=slock.git grab on the slock window instead on the root window --- diff --git a/slock.c b/slock.c index ba75493..97a80c5 100644 --- a/slock.c +++ b/slock.c @@ -86,15 +86,16 @@ main(int argc, char **argv) { pmap = XCreateBitmapFromData(dpy, w, curs, 8, 8); invisible = XCreatePixmapCursor(dpy, pmap, pmap, &black, &black, 0, 0); XDefineCursor(dpy, w, invisible); + XMapRaised(dpy, w); for(len = 1000; len; len--) { - if(XGrabPointer(dpy, root, False, ButtonPressMask | ButtonReleaseMask | PointerMotionMask, + if(XGrabPointer(dpy, w, False, ButtonPressMask | ButtonReleaseMask | PointerMotionMask, GrabModeAsync, GrabModeSync, None, invisible, CurrentTime) == GrabSuccess) break; usleep(1000); } if((running = running && (len > 0))) { for(len = 1000; len; len--) { - if(XGrabKeyboard(dpy, root, True, GrabModeAsync, GrabModeAsync, CurrentTime) + if(XGrabKeyboard(dpy, w, True, GrabModeAsync, GrabModeAsync, CurrentTime) == GrabSuccess) break; usleep(1000); @@ -102,7 +103,6 @@ main(int argc, char **argv) { running = (len > 0); } len = 0; - XMapRaised(dpy, w); XSync(dpy, False); /* main event loop */