diff options
| author | Carl Hetherington <cth@carlh.net> | 2018-06-08 17:07:24 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2018-06-08 17:07:24 +0100 |
| commit | 383c3b6c81e916c59b08a765540784d3f2350276 (patch) | |
| tree | 8726ada4d0bf1aa5cb8d97901a53b1fcd1966ea7 /src/lib/ffmpeg_examiner.cc | |
| parent | 677344e05e5c8483d39430ab5058f1ff8114fd9e (diff) | |
Auto-rotate videos.
Diffstat (limited to 'src/lib/ffmpeg_examiner.cc')
| -rw-r--r-- | src/lib/ffmpeg_examiner.cc | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/src/lib/ffmpeg_examiner.cc b/src/lib/ffmpeg_examiner.cc index 4223a4bad..4205d3d23 100644 --- a/src/lib/ffmpeg_examiner.cc +++ b/src/lib/ffmpeg_examiner.cc @@ -23,6 +23,8 @@ extern "C" { #include <libavformat/avformat.h> #include <libavutil/pixfmt.h> #include <libavutil/pixdesc.h> +#include <libavutil/eval.h> +#include <libavutil/display.h> } #include "ffmpeg_examiner.h" #include "ffmpeg_content.h" @@ -139,6 +141,31 @@ FFmpegExaminer::FFmpegExaminer (shared_ptr<const FFmpegContent> c, shared_ptr<Jo break; } } + + + if (_video_stream) { + /* This code taken from get_rotation() in ffmpeg:cmdutils.c */ + AVStream* stream = _format_context->streams[*_video_stream]; + AVDictionaryEntry* rotate_tag = av_dict_get (stream->metadata, "rotate", 0, 0); + uint8_t* displaymatrix = av_stream_get_side_data (stream, AV_PKT_DATA_DISPLAYMATRIX, 0); + _rotation = 0; + + if (rotate_tag && *rotate_tag->value && strcmp(rotate_tag->value, "0")) { + char *tail; + _rotation = av_strtod (rotate_tag->value, &tail); + if (*tail) { + _rotation = 0; + } + } + + if (displaymatrix && !_rotation) { + _rotation = - av_display_rotation_get ((int32_t*) displaymatrix); + } + + _rotation = *_rotation - 360 * floor (*_rotation / 360 + 0.9 / 360); + + DCPOMATIC_ASSERT (fabs (*_rotation - 90 * round (*_rotation / 90)) < 2); + } } void |
