From 6a5f0f0c19ad2b96910e18fea9d760817ca9ffe7 Mon Sep 17 00:00:00 2001 From: michael Date: Sun, 16 Jun 2002 13:54:36 +0000 Subject: [PATCH] higher quality mode git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@6449 b3059339-0415-0410-9bf9-f77b7e298cf2 --- libmpcodecs/vf_noise.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/libmpcodecs/vf_noise.c b/libmpcodecs/vf_noise.c index 0de013fc2e..6cf9d00f12 100644 --- a/libmpcodecs/vf_noise.c +++ b/libmpcodecs/vf_noise.c @@ -49,6 +49,7 @@ typedef struct FilterParam{ int strength; int uniform; int temporal; + int quality; int8_t *noise; }FilterParam; @@ -105,7 +106,6 @@ static int8_t *initNoise(FilterParam *fp){ #ifdef HAVE_MMX static inline void lineNoise_MMX(uint8_t *dst, uint8_t *src, int8_t *noise, int len, int shift){ int mmx_len= len&(~7); - shift&= ~7; noise+=shift; asm volatile( @@ -135,7 +135,6 @@ static inline void lineNoise_MMX(uint8_t *dst, uint8_t *src, int8_t *noise, int #ifdef HAVE_MMX2 static inline void lineNoise_MMX2(uint8_t *dst, uint8_t *src, int8_t *noise, int len, int shift){ int mmx_len= len&(~7); - shift&= ~7; noise+=shift; asm volatile( @@ -189,7 +188,7 @@ static void noise(uint8_t *dst, uint8_t *src, int dstStride, int srcStride, int { memcpy(dst, src, width); dst+= dstStride; - src+= srcStride; + src+= srcStride; } } return; @@ -200,6 +199,7 @@ static void noise(uint8_t *dst, uint8_t *src, int dstStride, int srcStride, int if(fp->temporal) shift= rand()&(MAX_SHIFT -1); else shift= nonTempRandShift[y]; + if(fp->quality==0) shift&= ~7; lineNoise(dst, src, noise, width, shift); dst+= dstStride; src+= srcStride; @@ -209,7 +209,7 @@ static void noise(uint8_t *dst, uint8_t *src, int dstStride, int srcStride, int static int config(struct vf_instance_s* vf, int width, int height, int d_width, int d_height, unsigned int flags, unsigned int outfmt){ - + return vf_next_config(vf,width,height,d_width,d_height,flags,outfmt); } @@ -299,6 +299,8 @@ static void parse(FilterParam *fp, char* args){ if(pos && posuniform=1; pos= strchr(args, 't'); if(pos && postemporal=1; + pos= strchr(args, 'h'); + if(pos && posquality=1; if(fp->strength) initNoise(fp); }