[FFmpeg-cvslog] cljrenc: 2x2 ordered dither support.
Michael Niedermayer
git at videolan.org
Fri Dec 9 19:06:27 CET 2011
ffmpeg | branch: master | Michael Niedermayer <michaelni at gmx.at> | Fri Dec 9 18:32:29 2011 +0100| [523da37f4c512a5bde37ab30da3d7d4e67e48c94] | committer: Michael Niedermayer
cljrenc: 2x2 ordered dither support.
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=523da37f4c512a5bde37ab30da3d7d4e67e48c94
---
libavcodec/cljr.c | 6 ++++++
1 files changed, 6 insertions(+), 0 deletions(-)
diff --git a/libavcodec/cljr.c b/libavcodec/cljr.c
index 65a077b..ed0eede 100644
--- a/libavcodec/cljr.c
+++ b/libavcodec/cljr.c
@@ -137,6 +137,11 @@ static int encode_frame(AVCodecContext *avctx, unsigned char *buf,
AVFrame *p = data;
int x, y;
uint32_t dither= avctx->frame_number;
+ static const uint32_t ordered_dither[2][2] =
+ {
+ { 0x10400000, 0x104F0000 },
+ { 0xCB2A0000, 0xCB250000 },
+ };
p->pict_type = AV_PICTURE_TYPE_I;
p->key_frame = 1;
@@ -151,6 +156,7 @@ static int encode_frame(AVCodecContext *avctx, unsigned char *buf,
switch (a->dither_type) {
case 0: dither = 0x492A0000; break;
case 1: dither = dither * 1664525 + 1013904223; break;
+ case 2: dither = ordered_dither[ y&1 ][ (x>>2)&1 ];break;
}
put_bits(&pb, 5, (luma[3] + (dither>>29) ) >> 3);
put_bits(&pb, 5, (luma[2] + ((dither>>26)&7)) >> 3);
More information about the ffmpeg-cvslog
mailing list