Skip to content
Snippets Groups Projects
Commit d210e974 authored by Michael Niedermayer's avatar Michael Niedermayer
Browse files

rv34: fix aspect ratio


Fixes part of Ticket1550

Signed-off-by: default avatarMichael Niedermayer <michaelni@gmx.at>
parent 6c6dc8cc
No related branches found
No related tags found
No related merge requests found
...@@ -1589,6 +1589,16 @@ static int finish_frame(AVCodecContext *avctx, AVFrame *pict) ...@@ -1589,6 +1589,16 @@ static int finish_frame(AVCodecContext *avctx, AVFrame *pict)
return got_picture; return got_picture;
} }
static AVRational update_sar(int old_w, int old_h, AVRational sar, int new_w, int new_h)
{
// attempt to keep aspect during typical resolution switches
if (!sar.num)
sar = (AVRational){1, 1};
sar = av_mul_q(sar, (AVRational){new_h * old_w, new_w * old_h});
return sar;
}
int ff_rv34_decode_frame(AVCodecContext *avctx, int ff_rv34_decode_frame(AVCodecContext *avctx,
void *data, int *got_picture_ptr, void *data, int *got_picture_ptr,
AVPacket *avpkt) AVPacket *avpkt)
...@@ -1664,6 +1674,9 @@ int ff_rv34_decode_frame(AVCodecContext *avctx, ...@@ -1664,6 +1674,9 @@ int ff_rv34_decode_frame(AVCodecContext *avctx,
if (av_image_check_size(si.width, si.height, 0, s->avctx)) if (av_image_check_size(si.width, si.height, 0, s->avctx))
return AVERROR_INVALIDDATA; return AVERROR_INVALIDDATA;
s->avctx->sample_aspect_ratio = update_sar(
s->width, s->height, s->avctx->sample_aspect_ratio,
si.width, si.height);
s->width = si.width; s->width = si.width;
s->height = si.height; s->height = si.height;
avcodec_set_dimensions(s->avctx, s->width, s->height); avcodec_set_dimensions(s->avctx, s->width, s->height);
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment