[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 802, Thu Jan 23 14:22:05 2003 UTC
# Line 386  Line 386 
386          frame.general |= XVID_HALFPEL;          frame.general |= XVID_HALFPEL;
387  //      frame.general |= XVID_ME_EPZS;  //      frame.general |= XVID_ME_EPZS;
388    
   
389          if (codec->config.motion_search > 4)          if (codec->config.motion_search > 4)
390                  frame.general |= XVID_INTER4V;                  frame.general |= XVID_INTER4V;
391    
# Line 405  Line 404 
404                  frame.general |= XVID_GMC;                  frame.general |= XVID_GMC;
405    
406          if (codec->config.chromame)          if (codec->config.chromame)
407                  frame.general |= XVID_ME_COLOUR;                  frame.motion |= PMV_CHROMA16 + PMV_CHROMA8;
408    
409          if (codec->config.reduced_resolution)          if (codec->config.reduced_resolution)
410                  frame.general |= XVID_REDUCED;                  frame.general |= XVID_REDUCED;
# Line 459  Line 458 
458          frame.motion |= pmvfast_presets[codec->config.motion_search];          frame.motion |= pmvfast_presets[codec->config.motion_search];
459    
460          frame.image = icc->lpInput;          frame.image = icc->lpInput;
         // dev-api-3  
461          frame.stride = (((icc->lpbiInput->biWidth * icc->lpbiInput->biBitCount) + 31) & ~31) >> 3;          frame.stride = (((icc->lpbiInput->biWidth * icc->lpbiInput->biBitCount) + 31) & ~31) >> 3;
462    
463          if ((frame.colorspace = get_colorspace(inhdr)) == XVID_CSP_NULL)          if ((frame.colorspace = get_colorspace(inhdr)) == XVID_CSP_NULL)
464                  return ICERR_BADFORMAT;                  return ICERR_BADFORMAT;
465    
466            if (frame.colorspace == XVID_CSP_I420 || frame.colorspace == XVID_CSP_YV12)
467                    frame.stride = (frame.stride*2)/3;
468    
469          frame.bitstream = icc->lpOutput;          frame.bitstream = icc->lpOutput;
470          frame.length = icc->lpbiOutput->biSizeImage;          frame.length = icc->lpbiOutput->biSizeImage;
471    
# Line 736  Line 737 
737                  frame.general |= XVID_DEC_DEBLOCKUV;                  frame.general |= XVID_DEC_DEBLOCKUV;
738    
739          frame.image = icd->lpOutput;          frame.image = icd->lpOutput;
 //      frame.stride = icd->lpbiOutput->biWidth;  
         // dev-api-3:  
740          frame.stride = (((icd->lpbiOutput->biWidth * icd->lpbiOutput->biBitCount) + 31) & ~31) >> 3;          frame.stride = (((icd->lpbiOutput->biWidth * icd->lpbiOutput->biBitCount) + 31) & ~31) >> 3;
741    
742          /* --- yv12 --- */          /* --- yv12 --- */
# Line 751  Line 750 
750                  convert.input.colorspace = get_colorspace(icd->lpbiInput);                  convert.input.colorspace = get_colorspace(icd->lpbiInput);
751                  convert.input.y = icd->lpInput;                  convert.input.y = icd->lpInput;
752                  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;
753                    if (convert.input.colorspace == XVID_CSP_I420 || convert.input.colorspace == XVID_CSP_YV12)
754                            convert.input.y_stride = (convert.input.y_stride*2)/3;
755    
756                  convert.output.colorspace = get_colorspace(icd->lpbiOutput);                  convert.output.colorspace = get_colorspace(icd->lpbiOutput);
757                  convert.output.y = icd->lpOutput;                  convert.output.y = icd->lpOutput;
758                  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;
759                    if (convert.output.colorspace == XVID_CSP_I420 || convert.output.colorspace == XVID_CSP_YV12)
760                            convert.output.y_stride = (convert.output.y_stride*2)/3;
761    
762                  convert.width = icd->lpbiInput->biWidth;                  convert.width = icd->lpbiInput->biWidth;
763                  convert.height = icd->lpbiInput->biHeight;                  convert.height = icd->lpbiInput->biHeight;
764                  convert.interlacing = 0;                  convert.interlacing = 0;
# Line 780  Line 785 
785                  frame.colorspace = XVID_CSP_NULL;                  frame.colorspace = XVID_CSP_NULL;
786          }          }
787    
788            if (frame.colorspace == XVID_CSP_I420 || frame.colorspace == XVID_CSP_YV12)
789                    frame.stride = (frame.stride*2)/3;
790    
791          switch (xvid_decore(codec->dhandle, XVID_DEC_DECODE, &frame, NULL))          switch (xvid_decore(codec->dhandle, XVID_DEC_DECODE, &frame, NULL))
792          {          {
793          case XVID_ERR_FAIL :          case XVID_ERR_FAIL :

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

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