diff options
| author | James Stembridge <jstembridge@users.sourceforge.net> | 2003-02-20 02:13:19 +0000 | 
|---|---|---|
| committer | James Stembridge <jstembridge@users.sourceforge.net> | 2003-02-20 02:13:19 +0000 | 
| commit | 3ff2ddff9fab10226571a14e7a7e2020eadb90ba (patch) | |
| tree | af087663030857aa016e72719f8c28da5bfa9050 /src/libffmpeg/xine_decoder.c | |
| parent | 0d6c42000aa6df65d6775ca74205dbf3f963ff95 (diff) | |
| download | xine-lib-3ff2ddff9fab10226571a14e7a7e2020eadb90ba.tar.gz xine-lib-3ff2ddff9fab10226571a14e7a7e2020eadb90ba.tar.bz2 | |
Support RGBA32 format ffmpeg frames. Allows playback of RGB HuffYUV files
CVS patchset: 4210
CVS date: 2003/02/20 02:13:19
Diffstat (limited to 'src/libffmpeg/xine_decoder.c')
| -rw-r--r-- | src/libffmpeg/xine_decoder.c | 48 | 
1 files changed, 43 insertions, 5 deletions
| diff --git a/src/libffmpeg/xine_decoder.c b/src/libffmpeg/xine_decoder.c index 7cd34aa87..3e43f3452 100644 --- a/src/libffmpeg/xine_decoder.c +++ b/src/libffmpeg/xine_decoder.c @@ -17,7 +17,7 @@   * along with this program; if not, write to the Free Software   * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA   * - * $Id: xine_decoder.c,v 1.94 2003/02/19 22:15:43 jstembridge Exp $ + * $Id: xine_decoder.c,v 1.95 2003/02/20 02:13:19 jstembridge Exp $   *   * xine decoder plugin using ffmpeg   * @@ -85,6 +85,9 @@ typedef struct ff_decoder_s {    float             aspect_ratio;    int               xine_aspect_ratio; +  int               output_format; +  yuv_planes_t      yuv; +     } ff_video_decoder_t;  typedef struct { @@ -162,6 +165,12 @@ static void init_video_codec (ff_video_decoder_t *this, xine_bmiheader *bih) {    this->bufsize = VIDEOBUFSIZE;    this->skipframes = 0; +   +  if(this->context->pix_fmt == PIX_FMT_RGBA32) { +    this->output_format = XINE_IMGFMT_YUY2; +    init_yuv_planes(&this->yuv, this->bih.biWidth, this->bih.biHeight); +  } else +    this->output_format = XINE_IMGFMT_YV12;  }  static void find_sequence_header (ff_video_decoder_t *this, @@ -526,7 +535,7 @@ static void ff_decode_data (video_decoder_t *this_gen, buf_element_t *buf) {  						  this->bih.biWidth,  						  this->bih.biHeight,  						  this->xine_aspect_ratio,  -						  XINE_IMGFMT_YV12, +						  this->output_format,  						  VO_BOTH_FIELDS);  	img->pts      = buf->pts; @@ -590,7 +599,33 @@ static void ff_decode_data (video_decoder_t *this_gen, buf_element_t *buf) {                this->bih.biWidth,                this->bih.biHeight); -          } else +          } else if (this->context->pix_fmt == PIX_FMT_RGBA32) { +           +            int x, plane_ptr = 0; +            uint8_t *src; +             +            for(y = 0; y < this->bih.biHeight; y++) { +              src = sy; +              for(x = 0; x < this->bih.biWidth; x++) { +                uint8_t r, g, b; +               +                /* These probably need to be switched for big endian */ +                b = *src; src++; +                g = *src; src++; +                r = *src; src += 2; + +                this->yuv.y[plane_ptr] = COMPUTE_Y(r, g, b); +                this->yuv.u[plane_ptr] = COMPUTE_U(r, g, b); +                this->yuv.v[plane_ptr] = COMPUTE_V(r, g, b); +                plane_ptr++; +	      } +              sy += this->av_frame->linesize[0]; +            } +             +            yuv444_to_yuy2(&this->yuv, img->base[0], img->pitches[0]); +           +          } else { +            	  for (y=0; y<this->bih.biHeight; y++) {  	    xine_fast_memcpy (dy, sy, this->bih.biWidth); @@ -600,8 +635,6 @@ static void ff_decode_data (video_decoder_t *this_gen, buf_element_t *buf) {  	    sy += this->av_frame->linesize[0];  	  } -          if ((this->context->pix_fmt != PIX_FMT_YUV410P) && -              (this->context->pix_fmt != PIX_FMT_YUV411P))            for (y=0; y<(this->bih.biHeight/2); y++) {  	    if (this->context->pix_fmt != PIX_FMT_YUV444P) { @@ -643,6 +676,8 @@ static void ff_decode_data (video_decoder_t *this_gen, buf_element_t *buf) {  	      sv += this->av_frame->linesize[2];  	    }  	  } + +	  }  	}  	this->skipframes = img->draw(img, this->stream); @@ -739,6 +774,9 @@ static void ff_dispose (video_decoder_t *this_gen) {    if(this->context && this->context->extradata)      free(this->context->extradata); +  if(this->context && this->context->pix_fmt == PIX_FMT_RGBA32) +    free_yuv_planes(&this->yuv); +      if( this->context )      free( this->context ); | 
