using opaque windows on resize/move, this allows to not grab the server

This commit is contained in:
Anselm R. Garbe 2006-05-29 11:04:29 +02:00
parent c6bde2e403
commit f7395c3d73
4 changed files with 38 additions and 46 deletions

View File

@ -23,8 +23,6 @@ static void handle_maprequest(XEvent * e);
static void handle_propertynotify(XEvent * e);
static void handle_unmapnotify(XEvent * e);
void (*handler[LASTEvent]) (XEvent *);
void
init_x_event_handler()
{

View File

@ -158,30 +158,25 @@ snap_move(XRectangle *r, XRectangle *rects,
}
}
static void
draw_pseudo_border(XRectangle * r)
static Window
init_opaque_win(XRectangle r)
{
XRectangle pseudo = *r;
pseudo.x += 2;
pseudo.y += 2;
pseudo.width -= 4;
pseudo.height -= 4;
XSetLineAttributes(dpy, xorgc, 1, LineSolid, CapNotLast, JoinMiter);
XDrawLine(dpy, root, xorgc, pseudo.x + 2, pseudo.y + pseudo.height / 2,
pseudo.x + pseudo.width - 2, pseudo.y + pseudo.height / 2);
XDrawLine(dpy, root, xorgc, pseudo.x + pseudo.width / 2, pseudo.y + 2,
pseudo.x + pseudo.width / 2, pseudo.y + pseudo.height - 2);
XSetLineAttributes(dpy, xorgc, 4, LineSolid, CapNotLast, JoinMiter);
XDrawRectangles(dpy, root, xorgc, &pseudo, 1);
XSync(dpy, False);
XSetWindowAttributes wa;
wa.override_redirect = 1;
wa.border_pixel = def.sel.border;
wa.background_pixel = def.sel.bg;
return XCreateWindow(dpy, root, r.x, r.y,
r.width, r.height, 1,
DefaultDepth(dpy, screen), CopyFromParent,
DefaultVisual(dpy, screen),
CWOverrideRedirect | CWBackPixel | CWBorderPixel, &wa);
}
void
do_mouse_move(Client *c)
{
int px = 0, py = 0, wex, wey, ex, ey, i;
Window dummy;
Window dummy, opaque;
XEvent ev;
unsigned int num = 0;
unsigned int dmask;
@ -202,20 +197,21 @@ do_mouse_move(Client *c)
if(XGrabPointer(dpy, root, False, MouseMask, GrabModeAsync, GrabModeAsync,
None, cursor[CurMove], CurrentTime) != GrabSuccess)
return;
XGrabServer(dpy);
draw_pseudo_border(&frect);
opaque = init_opaque_win(frect);
XClearWindow(dpy, opaque);
XMapRaised(dpy, opaque);
for(;;) {
XMaskEvent(dpy, MouseMask, &ev);
XMaskEvent(dpy, MouseMask | ExposureMask, &ev);
switch (ev.type) {
case ButtonRelease:
draw_pseudo_border(&frect);
XDestroyWindow(dpy, opaque);
if(aidx)
resize_column(c, &frect, &pt);
else
resize_client(c, &frect, False);
free(rects);
XUngrabServer(dpy);
if(rects)
free(rects);
XUngrabPointer(dpy, CurrentTime);
XSync(dpy, False);
return;
@ -225,12 +221,15 @@ do_mouse_move(Client *c)
pt.y = ev.xmotion.y;
XTranslateCoordinates(dpy, c->framewin, root, ev.xmotion.x,
ev.xmotion.y, &px, &py, &dummy);
draw_pseudo_border(&frect);
frect.x = px - ex;
frect.y = py - ey;
if(!aidx)
snap_move(&frect, rects, num, snapw, snaph);
draw_pseudo_border(&frect);
XMoveResizeWindow(dpy, opaque, frect.x, frect.y, frect.width, frect.height);
XClearWindow(dpy, opaque);
break;
case Expose:
(handler[Expose])(&ev);
break;
default: break;
}
@ -417,7 +416,7 @@ void
do_mouse_resize(Client *c, BlitzAlign align)
{
int px = 0, py = 0, i, ox, oy;
Window dummy;
Window dummy, opaque;
XEvent ev;
unsigned int dmask;
unsigned int num = 0;
@ -435,19 +434,21 @@ do_mouse_resize(Client *c, BlitzAlign align)
if(XGrabPointer(dpy, c->framewin, False, MouseMask, GrabModeAsync, GrabModeAsync,
None, cursor[CurResize], CurrentTime) != GrabSuccess)
return;
XGrabServer(dpy);
draw_pseudo_border(&frect);
opaque = init_opaque_win(frect);
XClearWindow(dpy, opaque);
XMapRaised(dpy, opaque);
for(;;) {
XMaskEvent(dpy, MouseMask, &ev);
XMaskEvent(dpy, MouseMask | ExposureMask, &ev);
switch (ev.type) {
case ButtonRelease:
draw_pseudo_border(&frect);
XDestroyWindow(dpy, opaque);
if(aidx)
resize_column(c, &frect, nil);
else
resize_client(c, &frect, False);
XUngrabServer(dpy);
if(rects)
free(rects);
XUngrabPointer(dpy, CurrentTime);
XSync(dpy, False);
return;
@ -455,10 +456,13 @@ do_mouse_resize(Client *c, BlitzAlign align)
case MotionNotify:
XTranslateCoordinates(dpy, c->framewin, root, ev.xmotion.x,
ev.xmotion.y, &px, &py, &dummy);
draw_pseudo_border(&frect);
snap_resize(&frect, &origin, align, rects, num, px,
ox, py, oy, snapw, snaph);
draw_pseudo_border(&frect);
XMoveResizeWindow(dpy, opaque, frect.x, frect.y, frect.width, frect.height);
XClearWindow(dpy, opaque);
break;
case Expose:
(handler[Expose])(&ev);
break;
default: break;
}

View File

@ -139,19 +139,9 @@ init_cursors()
static void
init_screen()
{
XGCValues gcv;
gcv.subwindow_mode = IncludeInferiors;
gcv.function = GXxor;
gcv.foreground = def.sel.bg;
gcv.plane_mask = AllPlanes;
gcv.graphics_exposures = False;
xorgc = XCreateGC(dpy, root, GCForeground | GCGraphicsExposures
| GCFunction | GCSubwindowMode | GCPlaneMask, &gcv);
rect.x = rect.y = 0;
rect.width = DisplayWidth(dpy, screen);
rect.height = DisplayHeight(dpy, screen);
def.snap = rect.height / 63;
}

View File

@ -184,7 +184,6 @@ int screen;
Window root;
XRectangle rect;
BlitzFont blitzfont;
GC xorgc;
IXPServer srv;
Pixmap barpmap;
Window barwin;
@ -197,6 +196,7 @@ Atom net_atom[NetLast];
Cursor cursor[CurLast];
unsigned int valid_mask;
unsigned int num_lock_mask;
void (*handler[LASTEvent]) (XEvent *);
/* area.c */
Area *create_area(View *v, unsigned int pos);