[svn] / branches / dev-api-3 / vfw / src / codec.c Repository:
ViewVC logotype

Diff of /branches/dev-api-3/vfw/src/codec.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 716, Sat Dec 14 06:09:33 2002 UTC revision 726, Tue Dec 17 12:58:10 2002 UTC
# Line 459  Line 459 
459          frame.motion |= pmvfast_presets[codec->config.motion_search];          frame.motion |= pmvfast_presets[codec->config.motion_search];
460    
461          frame.image = icc->lpInput;          frame.image = icc->lpInput;
         // dev-api-3  
462          frame.stride = (((icc->lpbiInput->biWidth * icc->lpbiInput->biBitCount) + 31) & ~31) >> 3;          frame.stride = (((icc->lpbiInput->biWidth * icc->lpbiInput->biBitCount) + 31) & ~31) >> 3;
463    
464          if ((frame.colorspace = get_colorspace(inhdr)) == XVID_CSP_NULL)          if ((frame.colorspace = get_colorspace(inhdr)) == XVID_CSP_NULL)
465                  return ICERR_BADFORMAT;                  return ICERR_BADFORMAT;
466    
467            if (frame.colorspace == XVID_CSP_I420 || frame.colorspace == XVID_CSP_YV12)
468                    frame.stride = (frame.stride*2)/3;
469    
470          frame.bitstream = icc->lpOutput;          frame.bitstream = icc->lpOutput;
471          frame.length = icc->lpbiOutput->biSizeImage;          frame.length = icc->lpbiOutput->biSizeImage;
472    
# Line 736  Line 738 
738                  frame.general |= XVID_DEC_DEBLOCKUV;                  frame.general |= XVID_DEC_DEBLOCKUV;
739    
740          frame.image = icd->lpOutput;          frame.image = icd->lpOutput;
 //      frame.stride = icd->lpbiOutput->biWidth;  
         // dev-api-3:  
741          frame.stride = (((icd->lpbiOutput->biWidth * icd->lpbiOutput->biBitCount) + 31) & ~31) >> 3;          frame.stride = (((icd->lpbiOutput->biWidth * icd->lpbiOutput->biBitCount) + 31) & ~31) >> 3;
742    
743          /* --- yv12 --- */          /* --- yv12 --- */
# Line 751  Line 751 
751                  convert.input.colorspace = get_colorspace(icd->lpbiInput);                  convert.input.colorspace = get_colorspace(icd->lpbiInput);
752                  convert.input.y = icd->lpInput;                  convert.input.y = icd->lpInput;
753                  convert.input.y_stride = (((icd->lpbiInput->biWidth *icd->lpbiInput->biBitCount) + 31) & ~31) >> 3;                  convert.input.y_stride = (((icd->lpbiInput->biWidth *icd->lpbiInput->biBitCount) + 31) & ~31) >> 3;
754                    if (convert.input.colorspace == XVID_CSP_I420 || convert.input.colorspace == XVID_CSP_YV12)
755                            convert.input.y_stride = (convert.input.y_stride*2)/3;
756    
757                  convert.output.colorspace = get_colorspace(icd->lpbiOutput);                  convert.output.colorspace = get_colorspace(icd->lpbiOutput);
758                  convert.output.y = icd->lpOutput;                  convert.output.y = icd->lpOutput;
759                  convert.output.y_stride = (((icd->lpbiOutput->biWidth *icd->lpbiOutput->biBitCount) + 31) & ~31) >> 3;                  convert.output.y_stride = (((icd->lpbiOutput->biWidth *icd->lpbiOutput->biBitCount) + 31) & ~31) >> 3;
760                    if (convert.output.colorspace == XVID_CSP_I420 || convert.output.colorspace == XVID_CSP_YV12)
761                            convert.output.y_stride = (convert.output.y_stride*2)/3;
762    
763                  convert.width = icd->lpbiInput->biWidth;                  convert.width = icd->lpbiInput->biWidth;
764                  convert.height = icd->lpbiInput->biHeight;                  convert.height = icd->lpbiInput->biHeight;
765                  convert.interlacing = 0;                  convert.interlacing = 0;
# Line 780  Line 786 
786                  frame.colorspace = XVID_CSP_NULL;                  frame.colorspace = XVID_CSP_NULL;
787          }          }
788    
789            if (frame.colorspace == XVID_CSP_I420 || frame.colorspace == XVID_CSP_YV12)
790                    frame.stride = (frame.stride*2)/3;
791    
792          switch (xvid_decore(codec->dhandle, XVID_DEC_DECODE, &frame, NULL))          switch (xvid_decore(codec->dhandle, XVID_DEC_DECODE, &frame, NULL))
793          {          {
794          case XVID_ERR_FAIL :          case XVID_ERR_FAIL :

Legend:
Removed from v.716  
changed lines
  Added in v.726

No admin address has been configured
ViewVC Help
Powered by ViewVC 1.0.4