diff options
author | Clément Bœsch <ubitux@gmail.com> | 2012-12-01 00:35:01 +0100 |
---|---|---|
committer | Clément Bœsch <ubitux@gmail.com> | 2012-12-20 16:13:52 +0100 |
commit | 6c26fc770436d485a261d2088a28fe0148ab90f3 (patch) | |
tree | 1853047f27d4cd2aceeb861ea7d4028e91ec7307 /libavformat/srtenc.c | |
parent | 1dab8d9157f9e52f3c7585cd645ef95947d7f749 (diff) | |
download | ffmpeg-6c26fc770436d485a261d2088a28fe0148ab90f3.tar.gz |
lavf/srtenc: honor subtitle position side data.
Diffstat (limited to 'libavformat/srtenc.c')
-rw-r--r-- | libavformat/srtenc.c | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/libavformat/srtenc.c b/libavformat/srtenc.c index 97b297e489..e02c4ef48d 100644 --- a/libavformat/srtenc.c +++ b/libavformat/srtenc.c @@ -22,6 +22,7 @@ #include "avformat.h" #include "internal.h" #include "libavutil/log.h" +#include "libavutil/intreadwrite.h" /* TODO: add options for: - character encoding; @@ -63,6 +64,16 @@ static int srt_write_packet(AVFormatContext *avf, AVPacket *pkt) if (write_ts) { int64_t s = pkt->pts, e, d = pkt->duration; + int size, x1 = -1, y1 = -1, x2 = -1, y2 = -1; + const uint8_t *p; + + p = av_packet_get_side_data(pkt, AV_PKT_DATA_SUBTITLE_POSITION, &size); + if (p && size == 16) { + x1 = AV_RL32(p ); + y1 = AV_RL32(p + 4); + x2 = AV_RL32(p + 8); + y2 = AV_RL32(p + 12); + } if (d <= 0) /* For backward compatibility, fallback to convergence_duration. */ @@ -73,12 +84,16 @@ static int srt_write_packet(AVFormatContext *avf, AVPacket *pkt) return 0; } e = s + d; - avio_printf(avf->pb, "%d\n%02d:%02d:%02d,%03d --> %02d:%02d:%02d,%03d\n", + avio_printf(avf->pb, "%d\n%02d:%02d:%02d,%03d --> %02d:%02d:%02d,%03d", srt->index, (int)(s / 3600000), (int)(s / 60000) % 60, (int)(s / 1000) % 60, (int)(s % 1000), (int)(e / 3600000), (int)(e / 60000) % 60, (int)(e / 1000) % 60, (int)(e % 1000)); + if (p) + avio_printf(avf->pb, " X1:%03d X2:%03d Y1:%03d Y2:%03d", + x1, x2, y1, y2); + avio_printf(avf->pb, "\n"); } avio_write(avf->pb, pkt->data, pkt->size); if (write_ts) |