Commit 47795505 authored by Michael Niedermayer's avatar Michael Niedermayer

avformat/mov: rewrite aspect from matrix code

The original code was intended purely for rotation == 0
In cf70ba37 the condition was
changed to use it only for rotation != 0
which broke the cases for which it was intended to be used
as well as breaking cases for which it was not intended to be
used.
This changes the code so it could work for the more general
case and fixes the regressions
If you have sample files that are not handled correctly
please open tickets or mail me!
Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent 89b6382b
...@@ -2784,7 +2784,6 @@ static int mov_read_tkhd(MOVContext *c, AVIOContext *pb, MOVAtom atom) ...@@ -2784,7 +2784,6 @@ static int mov_read_tkhd(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int i; int i;
int width; int width;
int height; int height;
int64_t disp_transform[2];
int display_matrix[3][3]; int display_matrix[3][3];
AVStream *st; AVStream *st;
MOVStreamContext *sc; MOVStreamContext *sc;
...@@ -2867,20 +2866,18 @@ static int mov_read_tkhd(MOVContext *c, AVIOContext *pb, MOVAtom atom) ...@@ -2867,20 +2866,18 @@ static int mov_read_tkhd(MOVContext *c, AVIOContext *pb, MOVAtom atom)
} }
// transform the display width/height according to the matrix // transform the display width/height according to the matrix
// skip this if the rotation angle is 0 degrees
// to keep the same scale, use [width height 1<<16] // to keep the same scale, use [width height 1<<16]
if (width && height && sc->display_matrix && if (width && height && sc->display_matrix) {
av_display_rotation_get(sc->display_matrix) != 0.0f) { double disp_transform[2];
#define SQR(a) ((a)*(double)(a))
for (i = 0; i < 2; i++) for (i = 0; i < 2; i++)
disp_transform[i] = disp_transform[i] = sqrt(SQR(display_matrix[i][0]) + SQR(display_matrix[i][1]));
(int64_t) width * display_matrix[0][i] +
(int64_t) height * display_matrix[1][i] + if (fabs((disp_transform[0] / disp_transform[1]) - 1.0) > 0.01)
((int64_t) display_matrix[2][i] << 16); st->sample_aspect_ratio = av_d2q(
disp_transform[0] / disp_transform[1],
//sample aspect ratio is new width/height divided by old width/height INT_MAX);
st->sample_aspect_ratio = av_d2q(
((double) disp_transform[0] * height) /
((double) disp_transform[1] * width), INT_MAX);
} }
return 0; return 0;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment