diff options
| author | Miguel Freitas <miguelfreitas@users.sourceforge.net> | 2002-05-06 20:32:36 +0000 | 
|---|---|---|
| committer | Miguel Freitas <miguelfreitas@users.sourceforge.net> | 2002-05-06 20:32:36 +0000 | 
| commit | 41f559f4978d78524bd591edb6ab5df62266408d (patch) | |
| tree | 24fcd210d2296a719ff4e601d00595560aba9031 | |
| parent | 003e1ab7e98424f5214be18e1e25d751df07b2f8 (diff) | |
| download | xine-lib-41f559f4978d78524bd591edb6ab5df62266408d.tar.gz xine-lib-41f559f4978d78524bd591edb6ab5df62266408d.tar.bz2 | |
fix cinepak decoding with xshm driver
CVS patchset: 1858
CVS date: 2002/05/06 20:32:36
| -rw-r--r-- | src/libxinevdec/cinepak.c | 20 | 
1 files changed, 19 insertions, 1 deletions
| diff --git a/src/libxinevdec/cinepak.c b/src/libxinevdec/cinepak.c index 05e86facf..b2728e9d6 100644 --- a/src/libxinevdec/cinepak.c +++ b/src/libxinevdec/cinepak.c @@ -22,7 +22,7 @@   * based on overview of Cinepak algorithm and example decoder   * by Tim Ferguson: http://www.csse.monash.edu.au/~timf/   * - * $Id: cinepak.c,v 1.3 2002/05/01 19:42:57 guenter Exp $ + * $Id: cinepak.c,v 1.4 2002/05/06 20:32:36 miguelfreitas Exp $   */  #include <stdlib.h> @@ -376,6 +376,24 @@ static void cvid_decode_data (video_decoder_t *this_gen, buf_element_t *buf) {        xine_fast_memcpy (img->base[1], this->img_buffer + n, (n >> 2));        xine_fast_memcpy (img->base[2], this->img_buffer + n + (n >> 2), (n >> 2)); +      if (img->copy) { +  +        int height = abs(this->biHeight); +        int stride = this->biWidth; +        uint8_t* src[3]; + +        src[0] = img->base[0]; +        src[1] = img->base[1]; +        src[2] = img->base[2]; +        while ((height -= 16) >= 0) { +          img->copy(img, src); +          src[0] += 16 * stride; +          src[1] +=  4 * stride; +          src[2] +=  4 * stride; +        } +      } +       +              img->draw(img);        img->free(img); | 
