[FFmpeg-cvslog] frmdec: tag 5 is AV_PIX_FMT_BGRA with reversed alpha (0=solid/opaque .. 255=transparent)

Peter Ross git at videolan.org
Wed Jan 9 14:16:23 CET 2013


ffmpeg | branch: master | Peter Ross <pross at xvid.org> | Mon Jan  7 22:08:39 2013 +1100| [5b69c07d12b1e505fd7468828ed85d6d8d634621] | committer: Peter Ross

frmdec: tag 5 is AV_PIX_FMT_BGRA with reversed alpha (0=solid/opaque ..  255=transparent)

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=5b69c07d12b1e505fd7468828ed85d6d8d634621
---

 libavformat/frmdec.c |    8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)

diff --git a/libavformat/frmdec.c b/libavformat/frmdec.c
index 914bab5..9c29842 100644
--- a/libavformat/frmdec.c
+++ b/libavformat/frmdec.c
@@ -33,7 +33,7 @@ static const AVCodecTag frm_pix_fmt_tags[] = {
     { AV_PIX_FMT_RGB0,   2 },
     { AV_PIX_FMT_RGB24,  3 },
     { AV_PIX_FMT_BGR0,   4 },
-    { AV_PIX_FMT_BGR0,   5 },
+    { AV_PIX_FMT_BGRA,   5 },
     { AV_PIX_FMT_NONE,   0 },
 };
 
@@ -88,6 +88,12 @@ static int frm_read_packet(AVFormatContext *avctx, AVPacket *pkt)
     if (ret < 0)
         return ret;
 
+    if (stc->pix_fmt == AV_PIX_FMT_BGRA) {
+        int i;
+        for (i = 3; i + 1 <= pkt->size; i += 4)
+            pkt->data[i] = 0xFF - pkt->data[i];
+    }
+
     pkt->stream_index = 0;
     s->count++;
 



More information about the ffmpeg-cvslog mailing list