[FFmpeg-cvslog] Support decoding of Lagarith frame type FRAME_SOLID_COLOR.

Carl Eugen Hoyos git at videolan.org
Tue May 7 14:32:25 CEST 2013


ffmpeg | branch: master | Carl Eugen Hoyos <cehoyos at ag.or.at> | Mon May  6 22:40:38 2013 +0200| [f381dc1d618611f149da32ab865bfc1b49861fd3] | committer: Carl Eugen Hoyos

Support decoding of Lagarith frame type FRAME_SOLID_COLOR.

Fixes bug 459.

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

 libavcodec/lagarith.c |   22 ++++++++++++++++++++++
 1 file changed, 22 insertions(+)

diff --git a/libavcodec/lagarith.c b/libavcodec/lagarith.c
index 8599784..4285644 100644
--- a/libavcodec/lagarith.c
+++ b/libavcodec/lagarith.c
@@ -556,6 +556,28 @@ static int lag_decode_frame(AVCodecContext *avctx,
             }
         }
         break;
+    case FRAME_SOLID_COLOR:
+        if (avctx->bits_per_coded_sample == 24) {
+            avctx->pix_fmt = AV_PIX_FMT_RGB24;
+        } else {
+            avctx->pix_fmt = AV_PIX_FMT_RGB32;
+            offset_gu |= 0xFFU << 24;
+        }
+
+        if ((ret = ff_thread_get_buffer(avctx, &frame,0)) < 0)
+            return ret;
+
+        dst = p->data[0];
+        for (j = 0; j < avctx->height; j++) {
+            for (i = 0; i < avctx->width; i++)
+                if (avctx->bits_per_coded_sample == 24) {
+                    AV_WB24(dst + i * 3, offset_gu);
+                } else {
+                    AV_WN32(dst + i * 4, offset_gu);
+                }
+            dst += p->linesize[0];
+        }
+        break;
     case FRAME_ARITH_RGBA:
         avctx->pix_fmt = AV_PIX_FMT_RGB32;
         planes = 4;



More information about the ffmpeg-cvslog mailing list