summaryrefslogtreecommitdiff
path: root/libavfilter/vf_scale.c
diff options
context:
space:
mode:
authorMaksym Veremeyenko <verem@m1.tv>2017-02-06 17:03:17 +0200
committerMichael Niedermayer <michael@niedermayer.cc>2017-02-07 21:32:26 +0100
commit8efb7f5a26e7300e09ba01239328d1498238c532 (patch)
tree8b9a1f1aa6fa4e934a2f05654e66835a509dfd8d /libavfilter/vf_scale.c
parent8c2ea3030af7b40a3c4275696fb5c76cdb80950a (diff)
downloadffmpeg-8efb7f5a26e7300e09ba01239328d1498238c532.tar.gz
avfilter/vf_scale: Fix chroma positioning for 4:2:0 pixel format
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
Diffstat (limited to 'libavfilter/vf_scale.c')
-rw-r--r--libavfilter/vf_scale.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/libavfilter/vf_scale.c b/libavfilter/vf_scale.c
index 8645da7868..2fe9a1fb52 100644
--- a/libavfilter/vf_scale.c
+++ b/libavfilter/vf_scale.c
@@ -285,6 +285,7 @@ static int config_props(AVFilterLink *outlink)
int i;
for (i = 0; i < 3; i++) {
+ int in_v_chr_pos = scale->in_v_chr_pos, out_v_chr_pos = scale->out_v_chr_pos;
struct SwsContext **s = swscs[i];
*s = sws_alloc_context();
if (!*s)
@@ -317,17 +318,17 @@ static int config_props(AVFilterLink *outlink)
* MPEG-2 chroma positions are used by convention
* XXX: support other 4:2:0 pixel formats */
if (inlink0->format == AV_PIX_FMT_YUV420P && scale->in_v_chr_pos == -513) {
- scale->in_v_chr_pos = (i == 0) ? 128 : (i == 1) ? 64 : 192;
+ in_v_chr_pos = (i == 0) ? 128 : (i == 1) ? 64 : 192;
}
if (outlink->format == AV_PIX_FMT_YUV420P && scale->out_v_chr_pos == -513) {
- scale->out_v_chr_pos = (i == 0) ? 128 : (i == 1) ? 64 : 192;
+ out_v_chr_pos = (i == 0) ? 128 : (i == 1) ? 64 : 192;
}
av_opt_set_int(*s, "src_h_chr_pos", scale->in_h_chr_pos, 0);
- av_opt_set_int(*s, "src_v_chr_pos", scale->in_v_chr_pos, 0);
+ av_opt_set_int(*s, "src_v_chr_pos", in_v_chr_pos, 0);
av_opt_set_int(*s, "dst_h_chr_pos", scale->out_h_chr_pos, 0);
- av_opt_set_int(*s, "dst_v_chr_pos", scale->out_v_chr_pos, 0);
+ av_opt_set_int(*s, "dst_v_chr_pos", out_v_chr_pos, 0);
if ((ret = sws_init_context(*s, NULL, NULL)) < 0)
return ret;