1
0
mirror of https://github.com/mpv-player/mpv synced 2025-01-15 03:23:23 +00:00

vo_x11: reduce flickering on playlist navigation

The delay between call to .resize, which cleared the buffer, and
actually rendering the first video frame, was significant, resulting in
short flicker on navigation and resizing. This was especially visible
when zooming and navigating between images.

Now the clearing is scheduled to happen just before the rendering, which
looks to be good enough even without double buffering.
This commit is contained in:
rr- 2017-03-23 22:17:59 +01:00 committed by wm4
parent c345680e8c
commit 8de7ba6dfd

View File

@ -77,6 +77,7 @@ struct priv {
XVisualInfo vinfo; XVisualInfo vinfo;
int current_buf; int current_buf;
bool reset_view;
#if HAVE_SHM && HAVE_XEXT #if HAVE_SHM && HAVE_XEXT
int Shmem_Flag; int Shmem_Flag;
@ -268,8 +269,7 @@ static bool resize(struct vo *vo)
if (mp_sws_reinit(p->sws) < 0) if (mp_sws_reinit(p->sws) < 0)
return false; return false;
XFillRectangle(x11->display, x11->window, p->gc, 0, 0, vo->dwidth, vo->dheight); p->reset_view = true;
vo->want_redraw = true; vo->want_redraw = true;
return true; return true;
} }
@ -280,6 +280,11 @@ static void Display_Image(struct priv *p, XImage *myximage)
XImage *x_image = p->myximage[p->current_buf]; XImage *x_image = p->myximage[p->current_buf];
if (p->reset_view) {
XFillRectangle(vo->x11->display, vo->x11->window, p->gc, 0, 0, vo->dwidth, vo->dheight);
p->reset_view = false;
}
#if HAVE_SHM && HAVE_XEXT #if HAVE_SHM && HAVE_XEXT
if (p->Shmem_Flag) { if (p->Shmem_Flag) {
XShmPutImage(vo->x11->display, vo->x11->window, p->gc, x_image, XShmPutImage(vo->x11->display, vo->x11->window, p->gc, x_image,