| 
							- /*
 -  ==============================================================================
 - 
 -  This file is part of the JUCETICE project - Copyright 2008 by Lucio Asnaghi.
 - 
 -  JUCETICE is based around the JUCE library - "Jules' Utility Class Extensions"
 -  Copyright 2008 by Julian Storer.
 - 
 -  ------------------------------------------------------------------------------
 - 
 -  JUCE and JUCETICE can be redistributed and/or modified under the terms of
 -  the GNU Lesser General Public License, as published by the Free Software
 -  Foundation; either version 2 of the License, or (at your option) any later
 -  version.
 - 
 -  JUCE and JUCETICE are distributed in the hope that they will be useful,
 -  but WITHOUT ANY WARRANTY; without even the implied warranty of
 -  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 -  GNU General Public License for more details.
 - 
 -  You should have received a copy of the GNU Lesser General Public License
 -  along with JUCE and JUCETICE; if not, visit www.gnu.org/licenses or write to
 -  Free Software Foundation, Inc., 59 Temple Place, Suite 330,
 -  Boston, MA 02111-1307 USA
 - 
 -  ==============================================================================
 - 
 -    @author  rockhardbuns
 -    @tweaker Lucio Asnaghi
 -    @tweaker falkTX
 - 
 -  ==============================================================================
 - */
 - 
 - #ifndef DISTRHO_VEX_VOICE_HEADER_INCLUDED
 - #define DISTRHO_VEX_VOICE_HEADER_INCLUDED
 - 
 - #ifndef CARLA_EXPORT
 -  #define CARLA_EXPORT
 - #endif
 - 
 - #ifdef CARLA_EXPORT
 -  #include "juce_audio_basics.h"
 - #else
 -  #include "../StandardHeader.h"
 - #endif
 - 
 - #include "VexADSR.h"
 - #include "VexWaveRenderer.h"
 - 
 - class VexVoice
 - {
 - public:
 -     VexVoice(const float* const p, int poff, WaveRenderer& w, float sr = 44100);
 - 
 -     void updateParameterPtr(const float* const p);
 - 
 -     void doProcess(float* outBufferL, float* outBufferR, int bufferSize);
 -     void start(float f, float v, int n, int preroll, double s, long o);
 -     void release(int p);
 -     void quickRelease();
 - 
 -     void kill();
 -     void update(const int index);
 - 
 -     long getOrdinal() const;
 -     int  getNote() const;
 -     bool getIsOn() const;
 -     bool getIsReleased() const;
 - 
 - private:
 -     OscSet oL;
 -     OscSet oR;
 -     WaveRenderer& wr;
 - 
 -     VexADSR aadsr;
 -     VexADSR fadsr;
 - 
 -     const float* parameters;
 -     const int poff;
 - 
 -     bool isOn, isReleased;
 -     int note;
 - 
 -     long Ordinal;
 - 
 -     float Avelocity;
 -     float Fvelocity;
 -     double SampleRate;
 -     float BaseFrequency;
 -     float lfoC, LFOA, LFOP, LFOF;
 -     float lfoS[2];
 -     float lowL, bandL, highL, lowR, bandR, highR, q, cut;
 - };
 - 
 - #endif // DISTRHO_VEX_VOICE_HEADER_INCLUDED
 
 
  |