1
0
mirror of https://github.com/jojo61/vdr-plugin-softhdcuvid.git synced 2023-10-10 13:37:41 +02:00

Fix PIP for cuvid (unstable)

This commit is contained in:
jojo61 2023-08-07 13:12:22 +02:00
parent ddd44e6f62
commit 838dfab45b

View File

@ -3793,6 +3793,7 @@ static void CuvidMixVideo(CuvidDecoder *decoder, __attribute__((unused)) int lev
AVFrameSideData *sd, *sd1 = NULL, *sd2 = NULL; AVFrameSideData *sd, *sd1 = NULL, *sd2 = NULL;
#ifdef PLACEBO #ifdef PLACEBO
if (level) { if (level) {
dst_rect.x0 = decoder->VideoX; // video window output (clip) dst_rect.x0 = decoder->VideoX; // video window output (clip)
dst_rect.y0 = decoder->VideoY; dst_rect.y0 = decoder->VideoY;
@ -4082,6 +4083,9 @@ static void CuvidMixVideo(CuvidDecoder *decoder, __attribute__((unused)) int lev
render_params.upscaler = pl_named_filters[VideoScaling[decoder->Resolution]].filter; render_params.upscaler = pl_named_filters[VideoScaling[decoder->Resolution]].filter;
render_params.downscaler = pl_named_filters[VideoScaling[decoder->Resolution]].filter; render_params.downscaler = pl_named_filters[VideoScaling[decoder->Resolution]].filter;
if (level)
render_params.skip_target_clearing = 1;
render_params.color_adjustment = &colors; render_params.color_adjustment = &colors;
colors.brightness = VideoBrightness; colors.brightness = VideoBrightness;
@ -4175,6 +4179,7 @@ static void CuvidMixVideo(CuvidDecoder *decoder, __attribute__((unused)) int lev
// render_params.lut = NULL; // render_params.lut = NULL;
render_params.num_hooks = 0; render_params.num_hooks = 0;
render_params.skip_target_clearing = 1;
if (!p->renderertest) if (!p->renderertest)
p->renderertest = pl_renderer_create(p->ctx, p->gpu); p->renderertest = pl_renderer_create(p->ctx, p->gpu);
@ -4413,7 +4418,7 @@ static void CuvidDisplayFrame(void) {
if ((VideoShowBlackPicture && !decoder->TrickSpeed) || if ((VideoShowBlackPicture && !decoder->TrickSpeed) ||
(VideoShowBlackPicture && decoder->Closing < -300)) { (VideoShowBlackPicture && decoder->Closing < -300)) {
CuvidBlackSurface(decoder); CuvidBlackSurface(decoder);
CuvidMessage(4, "video/cuvid: black surface displayed\n"); CuvidMessage(4, "video/cuvid: black surface displayed Filled %d\n",filled);
} }
continue; continue;
} }