📄 taudiofiltereq.h.svn-base
字号:
#ifndef _TAUDIOFILTEREQ_H_#define _TAUDIOFILTEREQ_H_#include "TaudioFilter.h"#include "TeqSettings.h"class TaudioFilterEQsuper;DECLARE_FILTER(TaudioFilterEQ,public,TaudioFilter)private: static const double Q; class Tequalizer { private: static const int AF_NCH=6; static const int KM=10; float wq[AF_NCH][KM][2]; // Circular buffer for W data float g[AF_NCH][KM]; float a[KM][2]; // A weights float b[KM][2]; // B weights int K; static void bp2(float* a, float* b, double fc, double q); template<class sample_t> float equalize(const float *g,sample_t in,unsigned int ci); public: void init(const TeqSettings *cfg,double freq); void reset(void) { memset(wq,0,sizeof(wq)); } template<class sample_t> void process(sample_t *samples,size_t numsamples,unsigned int nchannels); } eq; TeqSettings old; int oldsf;protected: virtual int getSupportedFormats(const TfilterSettingsAudio *cfg,bool *honourPreferred) const {return TsampleFormat::SF_ALL_24;}public: TaudioFilterEQ(IffdshowBase *Ideci,Tfilters *Iparent); virtual HRESULT process(TfilterQueue::iterator it,TsampleFormat &fmt,void *samples,size_t numsamples,const TfilterSettingsAudio *cfg0); virtual void onSeek(void);};#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -