From d9c9061a7ce0c75bfa45a0f33b115ad948ddc06d Mon Sep 17 00:00:00 2001 From: Johns Date: Sat, 18 Aug 2012 15:53:14 +0200 Subject: Reset closing only, if trickspeed is set. --- video.c | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/video.c b/video.c index e3dc9f1..55b7c65 100644 --- a/video.c +++ b/video.c @@ -4545,7 +4545,9 @@ static void VaapiSetTrickSpeed(VaapiDecoder * decoder, int speed) { decoder->TrickSpeed = speed; decoder->TrickCounter = speed; - decoder->Closing = 0; + if (speed) { + decoder->Closing = 0; + } } /// @@ -7642,7 +7644,12 @@ static void VdpauMixVideo(VdpauDecoder * decoder) &video_src_rect, VdpauSurfacesRb[VdpauSurfaceIndex], &dst_rect, &dst_video_rect, 0, NULL); } else { - current = decoder->SurfacesRb[decoder->SurfaceRead]; + if (decoder->Interlaced) { + current = decoder->SurfacesRb[(decoder->SurfaceRead + 1) + % VIDEO_SURFACES_MAX]; + } else { + current = decoder->SurfacesRb[decoder->SurfaceRead]; + } status = VdpauVideoMixerRender(decoder->VideoMixer, VDP_INVALID_HANDLE, @@ -7884,7 +7891,9 @@ static void VdpauSetTrickSpeed(VdpauDecoder * decoder, int speed) { decoder->TrickSpeed = speed; decoder->TrickCounter = speed; - decoder->Closing = 0; + if (speed) { + decoder->Closing = 0; + } } /// -- cgit v1.2.3