[FFmpeg-devel] [PATCH 1/2] ffplay: unify displaymatrix based rotation code
Marton Balint
cus at passwd.hu
Sun May 3 21:16:55 CEST 2015
On Sun, 3 May 2015, Michael Niedermayer wrote:
> Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> ---
> ffplay.c | 45 +++++++++++++++++++++++----------------------
> 1 file changed, 23 insertions(+), 22 deletions(-)
>
> diff --git a/ffplay.c b/ffplay.c
> index 826a473..eea00e6 100644
> --- a/ffplay.c
> +++ b/ffplay.c
> @@ -33,6 +33,7 @@
> #include "libavutil/avstring.h"
> #include "libavutil/colorspace.h"
> #include "libavutil/display.h"
> +#include "libavutil/eval.h"
> #include "libavutil/mathematics.h"
> #include "libavutil/pixdesc.h"
> #include "libavutil/imgutils.h"
> @@ -2020,30 +2021,30 @@ static int configure_video_filters(AVFilterGraph *graph, VideoState *is, const c
> AVDictionaryEntry *rotate_tag = av_dict_get(is->video_st->metadata, "rotate", NULL, 0);
> uint8_t* displaymatrix = av_stream_get_side_data(is->video_st,
> AV_PKT_DATA_DISPLAYMATRIX, NULL);
> + double theta = 0;
>
> if (rotate_tag && *rotate_tag->value && strcmp(rotate_tag->value, "0")) {
> - if (!strcmp(rotate_tag->value, "90")) {
> - INSERT_FILT("transpose", "clock");
> - } else if (!strcmp(rotate_tag->value, "180")) {
> - INSERT_FILT("hflip", NULL);
> - INSERT_FILT("vflip", NULL);
> - } else if (!strcmp(rotate_tag->value, "270")) {
> - INSERT_FILT("transpose", "cclock");
> - } else {
> - char rotate_buf[64];
> - snprintf(rotate_buf, sizeof(rotate_buf), "%s*PI/180", rotate_tag->value);
> - INSERT_FILT("rotate", rotate_buf);
> - }
> - } else if (displaymatrix) {
> - double rot = av_display_rotation_get((int32_t*) displaymatrix);
> - if (rot < -135 || rot > 135) {
> - INSERT_FILT("vflip", NULL);
> - INSERT_FILT("hflip", NULL);
> - } else if (rot < -45) {
> - INSERT_FILT("transpose", "dir=clock");
> - } else if (rot > 45) {
> - INSERT_FILT("transpose", "dir=cclock");
> - }
> + char *tail;
> + theta = av_strtod(rotate_tag->value, &tail);
> + if (*tail)
> + theta = 0;
> + }
> + if (displaymatrix && !theta)
> + theta = av_display_rotation_get((int32_t*) displaymatrix);
> +
> + theta -= 360*floor(theta/360 + 0.9/360);
> +
> + if (fabs(theta - 90) < 1.0) {
> + INSERT_FILT("transpose", "clock");
> + } else if (fabs(theta - 180) < 1.0) {
> + INSERT_FILT("hflip", NULL);
> + INSERT_FILT("vflip", NULL);
> + } else if (fabs(theta - 270) < 1.0) {
> + INSERT_FILT("transpose", "cclock");
> + } else if (fabs(theta) > 1.0) {
> + char rotate_buf[64];
> + snprintf(rotate_buf, sizeof(rotate_buf), "%f*PI/180", theta);
> + INSERT_FILT("rotate", rotate_buf);
> }
> }
LGTM, thanks.
Marton
More information about the ffmpeg-devel
mailing list