| /** |
| * projectM -- Milkdrop-esque visualisation SDK |
| * Copyright (C)2003-2007 projectM Team |
| * |
| * This library is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU Lesser General Public |
| * License as published by the Free Software Foundation; either |
| * version 2.1 of the License, or (at your option) any later version. |
| * |
| * This library is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| * Lesser General Public License for more details. |
| * |
| * You should have received a copy of the GNU Lesser General Public |
| * License along with this library; if not, write to the Free Software |
| * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
| * See 'LICENSE.txt' included within this release |
| * |
| */ |
| /** |
| * $Id$ |
| * |
| * Encapsulation of raw sound buffer. Used in beat detection |
| * |
| * $Log$ |
| */ |
| |
| #ifndef _PCM_H |
| #define _PCM_H |
| |
| |
| #include "dlldefs.h" |
| |
| |
| class |
| #ifdef WIN32 |
| DLLEXPORT |
| #endif |
| PCM { |
| public: |
| float **PCMd; |
| int start; |
| |
| /** Use wave smoothing */ |
| float waveSmoothing; |
| |
| int *ip; |
| double *w; |
| int newsamples; |
| |
| int numsamples; //size of new PCM info |
| float *pcmdataL; //holder for most recent pcm data |
| float *pcmdataR; //holder for most recent pcm data |
| |
| /** PCM data */ |
| float vdataL[512]; //holders for FFT data (spectrum) |
| float vdataR[512]; |
| |
| static int maxsamples; |
| |
| PCM(); |
| ~PCM(); |
| void initPCM (int maxsamples); |
| void addPCMfloat (const float *PCMdata, int samples); |
| void addPCM16 (short [2][512]); |
| void addPCM16Data (const short* pcm_data, short samples); |
| void addPCM8 (unsigned char [2][1024]); |
| void addPCM8_512 (const unsigned char [2][512]); |
| void getPCM (float *data, int samples, int channel, int freq, float smoothing, int derive); |
| void freePCM (); |
| int getPCMnew (float *PCMdata, int channel, int freq, float smoothing, int derive,int reset); |
| }; |
| |
| #endif /** !_PCM_H */ |