Mercurial > mplayer.hg
view libaf/af_tools.c @ 25157:cf3b6015735d
Set protocol for the vo proxy used in shared-buffer mode.
NOTE: You have to update your mplayerosx to svn r148 or newer to work with it.
This change will speed up vo proxy and fix all these warnings:
vo_macosx.m: In function 'config':
vo_macosx.m:165: warning: 'NSProxy' may not respond to '-startWithWidth:withHeight:withBytes:withAspect:'
vo_macosx.m:165: warning: (Messages without a matching method signature
vo_macosx.m:165: warning: will be assumed to return 'id' and accept
vo_macosx.m:165: warning: '...' as arguments.)
vo_macosx.m: In function 'flip_page':
vo_macosx.m:183: warning: 'NSProxy' may not respond to '-render'
vo_macosx.m: In function 'uninit':
vo_macosx.m:235: warning: 'NSProxy' may not respond to '-stop'
vo_macosx.m: In function 'control':
vo_macosx.m:334: warning: 'NSProxy' may not respond to '-ontop'
vo_macosx.m:336: warning: 'NSProxy' may not respond to '-toggleFullscreen'
author | ulion |
---|---|
date | Wed, 28 Nov 2007 00:01:35 +0000 |
parents | a54a25221b79 |
children | 327b7955381f |
line wrap: on
line source
#include <math.h> #include <string.h> #include <af.h> /* Convert to gain value from dB. Returns AF_OK if of and AF_ERROR if fail */ int af_from_dB(int n, float* in, float* out, float k, float mi, float ma) { int i = 0; // Sanity check if(!in || !out) return AF_ERROR; for(i=0;i<n;i++){ if(in[i]<=-200) out[i]=0.0; else out[i]=pow(10.0,clamp(in[i],mi,ma)/k); } return AF_OK; } /* Convert from gain value to dB. Returns AF_OK if of and AF_ERROR if fail */ int af_to_dB(int n, float* in, float* out, float k) { int i = 0; // Sanity check if(!in || !out) return AF_ERROR; for(i=0;i<n;i++){ if(in[i] == 0.0) out[i]=-200.0; else out[i]=k*log10(in[i]); } return AF_OK; } /* Convert from ms to sample time */ int af_from_ms(int n, float* in, int* out, int rate, float mi, float ma) { int i = 0; // Sanity check if(!in || !out) return AF_ERROR; for(i=0;i<n;i++) out[i]=(int)((float)rate * clamp(in[i],mi,ma)/1000.0); return AF_OK; } /* Convert from sample time to ms */ int af_to_ms(int n, int* in, float* out, int rate) { int i = 0; // Sanity check if(!in || !out || !rate) return AF_ERROR; for(i=0;i<n;i++) out[i]=1000.0 * (float)in[i]/((float)rate); return AF_OK; } /* Helper function for testing the output format */ int af_test_output(struct af_instance_s* af, af_data_t* out) { if((af->data->format != out->format) || (af->data->bps != out->bps) || (af->data->rate != out->rate) || (af->data->nch != out->nch)){ memcpy(out,af->data,sizeof(af_data_t)); return AF_FALSE; } return AF_OK; } /* Soft clipping, the sound of a dream, thanks to Jon Wattes post to Musicdsp.org */ float af_softclip(float a) { if (a >= M_PI/2) return 1.0; else if (a <= -M_PI/2) return -1.0; else return sin(a); }