From: Dana Jansens Date: Sun, 10 Jun 2007 03:58:02 +0000 (+0000) Subject: delay re-rendering the frame while it is being iconify-animated until the animation... X-Git-Url: https://git.dogcows.com/gitweb?a=commitdiff_plain;h=ef8bd3947da3816eb365d64042a9c9d49e1b9b98;p=chaz%2Fopenbox delay re-rendering the frame while it is being iconify-animated until the animation finishes (avoid it flashing to unfocused) --- diff --git a/openbox/frame.c b/openbox/frame.c index 8ce2a16d..c30415dd 100644 --- a/openbox/frame.c +++ b/openbox/frame.c @@ -1630,10 +1630,11 @@ void frame_end_iconify_animation(ObFrame *self) if (!self->visible) XUnmapWindow(ob_display, self->window); - else + else { /* Send a ConfigureNotify when the animation is done, this fixes KDE's pager showing the window in the wrong place. */ client_reconfigure(self->client); + } /* we're not animating any more ! */ self->iconify_animation_going = 0; @@ -1641,6 +1642,8 @@ void frame_end_iconify_animation(ObFrame *self) XMoveResizeWindow(ob_display, self->window, self->area.x, self->area.y, self->area.width, self->area.height); + /* we delay re-rendering until after we're done animating */ + framerender_frame(self); XFlush(ob_display); } diff --git a/openbox/framerender.c b/openbox/framerender.c index b5cdf174..a02567bd 100644 --- a/openbox/framerender.c +++ b/openbox/framerender.c @@ -34,6 +34,9 @@ static void framerender_close(ObFrame *self, RrAppearance *a); void framerender_frame(ObFrame *self) { + if (frame_iconify_animating(self)) + return; /* delay redrawing until the animation is done */ + { gulong px;