diff options
author | henry <henry@b3059339-0415-0410-9bf9-f77b7e298cf2> | 2005-05-18 10:44:45 +0000 |
---|---|---|
committer | henry <henry@b3059339-0415-0410-9bf9-f77b7e298cf2> | 2005-05-18 10:44:45 +0000 |
commit | 90d49188f8c4a40033846f51579600d5b46c87d8 (patch) | |
tree | de05d15e1499995e155ff426110ed3f4765e240f /libmpcodecs/vd_mpng.c | |
parent | 08e085ad3f76f1b4ea5610516d868ab7e43ae240 (diff) | |
download | mpv-90d49188f8c4a40033846f51579600d5b46c87d8.tar.bz2 mpv-90d49188f8c4a40033846f51579600d5b46c87d8.tar.xz |
8bit palette mode support (and spurious ^M removal)
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@15503 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libmpcodecs/vd_mpng.c')
-rw-r--r-- | libmpcodecs/vd_mpng.c | 21 |
1 files changed, 18 insertions, 3 deletions
diff --git a/libmpcodecs/vd_mpng.c b/libmpcodecs/vd_mpng.c index f64a96ca7d..efc0a49152 100644 --- a/libmpcodecs/vd_mpng.c +++ b/libmpcodecs/vd_mpng.c @@ -76,6 +76,10 @@ static mp_image_t* decode(sh_video_t *sh,void* data,int len,int flags){ png_uint_32 i; mp_image_t* mpi; + int cols; + png_colorp pal; + unsigned char *p; + if(len<=0) return NULL; // skipped frame png=png_create_read_struct( PNG_LIBPNG_VER_STRING,NULL,NULL,NULL ); @@ -88,7 +92,6 @@ static mp_image_t* decode(sh_video_t *sh,void* data,int len,int flags){ png_set_sig_bytes( png,8 ); png_read_info( png,info ); png_get_IHDR( png,info,&png_width,&png_height,&depth,&color,NULL,NULL,NULL ); - png_set_bgr( png ); switch( info->color_type ) { @@ -96,6 +99,8 @@ static mp_image_t* decode(sh_video_t *sh,void* data,int len,int flags){ mp_msg( MSGT_DECVIDEO,MSGL_INFO,"Sorry gray scaled png with alpha channel not supported at moment.\n" ); break; case PNG_COLOR_TYPE_GRAY: + out_fmt=IMGFMT_Y800; + break; case PNG_COLOR_TYPE_PALETTE: out_fmt=IMGFMT_BGR8; break; @@ -137,8 +142,18 @@ static mp_image_t* decode(sh_video_t *sh,void* data,int len,int flags){ for ( i=0; i < png_height; i++ ) row_p[i]=mpi->planes[0] + mpi->stride[0]*i; png_read_image( png,row_p ); free( row_p ); - - //png_get_PLTE( png,info,(png_colorp*)&pal,&cols ); + + if (out_fmt==IMGFMT_BGR8) { + png_get_PLTE( png,info,&pal,&cols ); + mpi->planes[1] = (char*)realloc(mpi->planes[1], 4*cols); + p = mpi->planes[1]; + for (i = 0; i < cols; i++) { + *p++ = pal[i].blue; + *p++ = pal[i].green; + *p++ = pal[i].red; + *p++ = 0; + } + } png_read_end( png,endinfo ); png_destroy_read_struct( &png,&info,&endinfo ); |