[vlc-devel] [PATCH] swscale: modify output aspect ratio if transformation is not homothetic
Felix Abecassis
felix.abecassis at gmail.com
Wed Apr 30 19:50:47 CEST 2014
Done, thanks!
2014-04-30 19:38 GMT+02:00 Rémi Denis-Courmont <remi at remlab.net>:
> Le mercredi 30 avril 2014, 17:41:25 Felix Abecassis a écrit :
>> Close #10745
>
> Seems OK, but but maybe a XXX EXPLICIT HACK PARENTAL ADVISORY warning is
> missing.
>
>> ---
>> modules/video_chroma/swscale.c | 18 ++++++++++++++++++
>> 1 file changed, 18 insertions(+)
>>
>> diff --git a/modules/video_chroma/swscale.c b/modules/video_chroma/swscale.c
>> index 4b763dd..03cc414 100644
>> --- a/modules/video_chroma/swscale.c
>> +++ b/modules/video_chroma/swscale.c
>> @@ -430,6 +430,24 @@ static int Init( filter_t *p_filter )
>> return VLC_EGENERIC;
>> }
>>
>> + if (p_filter->b_allow_fmt_out_change)
>> + {
>> + /*
>> + * If the transformation is not homothetic we must modify the
>> + * aspect ratio of the output format in order to have the
>> + * output picture displayed correctly and not stretched
>> + * horizontally or vertically.
>> + */
>> + unsigned i_sar_num = p_fmti->i_sar_num * p_fmti->i_visible_width;
>> + unsigned i_sar_den = p_fmti->i_sar_den * p_fmto->i_visible_width;
>> + vlc_ureduce(&i_sar_num, &i_sar_den, i_sar_num, i_sar_den, 65536);
>> + i_sar_num *= p_fmto->i_visible_height;
>> + i_sar_den *= p_fmti->i_visible_height;
>> + vlc_ureduce(&i_sar_num, &i_sar_den, i_sar_num, i_sar_den, 65536);
>> + p_fmto->i_sar_num = i_sar_num;
>> + p_fmto->i_sar_den = i_sar_den;
>> + }
>> +
>> p_sys->b_add_a = cfg.b_add_a;
>> p_sys->b_copy = cfg.b_copy;
>> p_sys->fmt_in = *p_fmti;
>
> --
> Rémi Denis-Courmont
> http://www.remlab.net/
>
> _______________________________________________
> vlc-devel mailing list
> To unsubscribe or modify your subscription options:
> https://mailman.videolan.org/listinfo/vlc-devel
--
Félix Abecassis
http://felix.abecassis.me
More information about the vlc-devel
mailing list