Mercurial > mplayer.hg
view postproc/swscale.h @ 4291:e889d37f25b2
Add option -last-chapter for DVD playing/encoding
author | kmkaplan |
---|---|
date | Mon, 21 Jan 2002 09:44:31 +0000 |
parents | 1f8ceb12284d |
children | 21dbbbbd5479 |
line wrap: on
line source
/* values for the flags, the stuff on the command line is different */ #define SWS_FAST_BILINEAR 1 #define SWS_BILINEAR 2 #define SWS_BICUBIC 4 #define SWS_X 8 #define SWS_FULL_UV_IPOL 0x100 #define SWS_PRINT_INFO 0x1000 #define SWS_MAX_REDUCE_CUTOFF 0.002 /* this struct should be aligned on at least 32-byte boundary */ typedef struct{ int srcW, srcH, dstW, dstH; int chrDstW, chrDstH; int lumXInc, chrXInc; int lumYInc, chrYInc; int dstFormat, srcFormat; int16_t **lumPixBuf; int16_t **chrPixBuf; int16_t *hLumFilter; int16_t *hLumFilterPos; int16_t *hChrFilter; int16_t *hChrFilterPos; int16_t *vLumFilter; int16_t *vLumFilterPos; int16_t *vChrFilter; int16_t *vChrFilterPos; // Contain simply the values from v(Lum|Chr)Filter just nicely packed for mmx int16_t *lumMmxFilter; int16_t *chrMmxFilter; int hLumFilterSize; int hChrFilterSize; int vLumFilterSize; int vChrFilterSize; int vLumBufSize; int vChrBufSize; uint8_t __attribute__((aligned(32))) funnyYCode[10000]; uint8_t __attribute__((aligned(32))) funnyUVCode[10000]; int canMMX2BeUsed; int lastInLumBuf; int lastInChrBuf; int lumBufIndex; int chrBufIndex; int dstY; int flags; } SwsContext; //FIXME check init (where 0) // when used for filters they must have an odd number of elements // coeffs cannot be shared between vectors typedef struct { double *coeff; int length; } SwsVector; // vectors can be shared typedef struct { SwsVector *lumH; SwsVector *lumV; SwsVector *chrH; SwsVector *chrV; } SwsFilter; // *** bilinear scaling and yuv->rgb & yuv->yuv conversion of yv12 slices: // *** Note: it's called multiple times while decoding a frame, first time y==0 // dstbpp == 12 -> yv12 output // will use sws_flags void SwScale_YV12slice(unsigned char* src[],int srcStride[], int srcSliceY, int srcSliceH, uint8_t* dst[], int dstStride, int dstbpp, int srcW, int srcH, int dstW, int dstH); // Obsolete, will be removed soon void SwScale_Init(); void freeSwsContext(SwsContext *swsContext); SwsContext *getSwsContext(int srcW, int srcH, int srcFormat, int dstW, int dstH, int dstFormat, int flags, SwsFilter *srcFilter, SwsFilter *dstFilter); extern void (*swScale)(SwsContext *context, uint8_t* src[], int srcStride[], int srcSliceY, int srcSliceH, uint8_t* dst[], int dstStride[]); SwsVector *getGaussianVec(double variance, double quality); SwsVector *getIdentityVec(void); void scaleVec(SwsVector *a, double scalar); void normalizeVec(SwsVector *a, double height); SwsVector *convVec(SwsVector *a, SwsVector *b); SwsVector *sumVec(SwsVector *a, SwsVector *b); SwsVector *diffVec(SwsVector *a, SwsVector *b); SwsVector *shiftVec(SwsVector *a, int shift); void printVec(SwsVector *a); void freeVec(SwsVector *a);