/[svn]/linuxsampler/trunk/src/engines/sfz/SfzSignalUnitRack.h
ViewVC logotype

Diff of /linuxsampler/trunk/src/engines/sfz/SfzSignalUnitRack.h

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 2221 by iliev, Thu Jul 28 17:17:42 2011 UTC revision 2229 by iliev, Thu Aug 4 19:02:36 2011 UTC
# Line 27  Line 27 
27  #include "EG.h"  #include "EG.h"
28  #include "EGADSR.h"  #include "EGADSR.h"
29  #include "../common/AbstractVoice.h"  #include "../common/AbstractVoice.h"
30    #include "../common/PulseLFO.h"
31    #include "../common/SawLFO.h"
32    #include "../common/SineLFO.h"
33    
34  namespace LinuxSampler { namespace sfz {  namespace LinuxSampler { namespace sfz {
35      const int MaxUnitCount = 1000;      const int MaxUnitCount = 1000;
# Line 50  namespace LinuxSampler { namespace sfz { Line 53  namespace LinuxSampler { namespace sfz {
53              }              }
54                            
55              double GetSampleRate();              double GetSampleRate();
56                float  GetInfluence(ArrayList< ::sfz::CC>& cc);
57      };      };
58            
59        
60        class CCUnit: public CCSignalUnit {
61            public:
62                Voice* pVoice;
63    
64                CCUnit(SfzSignalUnitRack* rack, Listener* l = NULL);
65                
66                virtual void Trigger();
67                
68                void SetCCs(::sfz::Array<int>& pCC);
69                void SetCCs(ArrayList< ::sfz::CC>& cc);
70        };
71        
72        
73      template <class T>      template <class T>
74      class EGUnit: public SfzSignalUnit {      class EGUnit: public SfzSignalUnit {
75          public:          public:
# Line 106  namespace LinuxSampler { namespace sfz { Line 124  namespace LinuxSampler { namespace sfz {
124          public:          public:
125              int depth;              int depth;
126              EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack), depth(0) { }              EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack), depth(0) { }
             virtual void Trigger();  
127      };      };
128            
129      class EGv2Unit: public EGUnit< ::LinuxSampler::sfz::EG> {      class EGv2Unit: public EGUnit< ::LinuxSampler::sfz::EG> {
130            protected:
131                ::sfz::EG egInfo;
132          public:          public:
133              EGv2Unit(SfzSignalUnitRack* rack): EGUnit< ::LinuxSampler::sfz::EG>(rack) { }              EGv2Unit(SfzSignalUnitRack* rack): EGUnit< ::LinuxSampler::sfz::EG>(rack) { }
134              virtual void Trigger();              virtual void Trigger();
# Line 121  namespace LinuxSampler { namespace sfz { Line 140  namespace LinuxSampler { namespace sfz {
140              virtual void Trigger();              virtual void Trigger();
141      };      };
142            
143      class LFOUnit: public SfzSignalUnit {      class FilEGUnit: public EGv1Unit {
144            public:
145                FilEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
146                virtual void Trigger();
147        };
148        
149        class AmpEGUnit: public EGv1Unit {
150            public:
151                AmpEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
152                virtual void Trigger();
153        };
154        
155        class AbstractLfo {
156            public:
157                virtual float Render() = 0;
158                virtual void Update(const uint16_t& ExtControlValue) = 0;
159                virtual void Trigger(float Frequency, start_level_t StartLevel, uint16_t InternalDepth, uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate) = 0;
160                virtual void SetPhase(float phase) = 0;
161                virtual void SetFrequency(float Frequency, unsigned int SampleRate) = 0;
162        };
163        
164        template <class T>
165        class LfoBase: public AbstractLfo, public T {
166            public:
167                LfoBase(float Max): T(Max) { }
168                virtual float Render() { return T::render(); }
169                
170                virtual void Update(const uint16_t& ExtControlValue) { T::update(ExtControlValue); }
171                
172                virtual void Trigger (
173                    float Frequency, start_level_t StartLevel, uint16_t InternalDepth,
174                    uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate
175                ) {
176                    T::trigger(Frequency, StartLevel, InternalDepth, ExtControlDepth, FlipPhase, SampleRate);
177                }
178                
179                virtual void SetPhase(float phase) { T::setPhase(phase); }
180                
181                virtual void SetFrequency(float Frequency, unsigned int SampleRate) {
182                    T::setFrequency(Frequency, SampleRate);
183                }
184        };
185        
186        class LFOUnit;
187        
188        class FadeEGUnit: public EGUnit<EGADSR> {
189          public:          public:
190              ::sfz::LFO* pLfoInfo;              FadeEGUnit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack) { }
191              LFOSigned lfo;              virtual void Trigger() { }
192                virtual void EnterReleaseStage() { }
193                virtual void CancelRelease() { }
194                            
195              LFOUnit(SfzSignalUnitRack* rack): SfzSignalUnit(rack), pLfoInfo(NULL), lfo(1200.0f) { }              friend class LFOUnit;
196              LFOUnit(const LFOUnit& Unit): SfzSignalUnit(Unit), lfo(1200.0f) { Copy(Unit); }      };
197        
198        class LFOUnit: public SfzSignalUnit, public CCSignalUnit::Listener {
199            public:
200                ::sfz::LFO*  pLfoInfo;
201                AbstractLfo* pLFO;
202                FadeEGUnit   suFadeEG;
203                CCUnit       suFreqOnCC;
204                
205                LFOUnit(SfzSignalUnitRack* rack);
206                LFOUnit(const LFOUnit& Unit);
207              void operator=(const LFOUnit& Unit) { Copy(Unit); }              void operator=(const LFOUnit& Unit) { Copy(Unit); }
208                            
209              void Copy(const LFOUnit& Unit) {              void Copy(const LFOUnit& Unit) {
210                  pLfoInfo = Unit.pLfoInfo;                  pLfoInfo   = Unit.pLfoInfo;
211                    suFadeEG   = Unit.suFadeEG;
212                                    
213                  SfzSignalUnit::Copy(Unit);                  SfzSignalUnit::Copy(Unit);
214              }              }
215                            
216              virtual bool  Active() { return true; }              virtual bool  Active() { return pLfoInfo->freq > 0; }
217              virtual void  Trigger();              virtual void  Trigger();
218              virtual void  Increment();              virtual void  Increment();
219              virtual float GetLevel() { return Level; }              virtual float GetLevel() { return Level; }
220                virtual void  ValueChanged(CCSignalUnit* pUnit);
221      };      };
222            
223      class LFOv1Unit: public LFOUnit {      class LFOv1Unit: public LFOUnit {
224          public:          public:
225              ::sfz::LFO lfoInfo;              ::sfz::LFO lfoInfo;
226                LfoBase<LFOSigned> lfo;
227                            
228              LFOv1Unit(SfzSignalUnitRack* rack): LFOUnit(rack) { pLfoInfo = &lfoInfo; }              LFOv1Unit(SfzSignalUnitRack* rack): LFOUnit(rack), lfo(1200.0f) {
229                    pLfoInfo = &lfoInfo; pLFO = &lfo;
230                }
231                            
232              virtual void Trigger();              virtual void Trigger();
233      };      };
234            
235      class LFOv2Unit: public LFOUnit {      class LFOv2Unit: public LFOUnit {
236            protected:
237                FixedArray<AbstractLfo*> lfos;
238                LfoBase<LFOSigned>                       lfo0; // triangle
239                LfoBase<SineLFO<range_signed> >          lfo1; // sine
240                LfoBase<PulseLFO<range_unsigned, 750> >  lfo2; // pulse 75%
241                LfoBase<SquareLFO<range_signed> >        lfo3; // square
242                LfoBase<PulseLFO<range_unsigned, 250> >  lfo4; // pulse 25%
243                LfoBase<PulseLFO<range_unsigned, 125> >  lfo5; // pulse 12,5%
244                LfoBase<SawLFO<range_unsigned, true> >   lfo6; // saw up
245                LfoBase<SawLFO<range_unsigned, false> >  lfo7; // saw down
246                
247                
248          public:          public:
249              LFOv2Unit(SfzSignalUnitRack* rack): LFOUnit(rack) { }              CCUnit suPitchOnCC;
250                
251                LFOv2Unit(SfzSignalUnitRack* rack);
252                            
253              virtual void Trigger();              virtual void Trigger();
254      };      };
# Line 167  namespace LinuxSampler { namespace sfz { Line 262  namespace LinuxSampler { namespace sfz {
262            
263      class PitchLFOUnit: public LFOv1Unit {      class PitchLFOUnit: public LFOv1Unit {
264          public:          public:
265              PitchLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }              CCUnit suDepthCC;
266                
267                PitchLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack), suDepthCC(rack) { }
268                            
269              virtual void Trigger();              virtual void Trigger();
270      };      };
# Line 181  namespace LinuxSampler { namespace sfz { Line 278  namespace LinuxSampler { namespace sfz {
278            
279            
280            
281      class EndpointUnit : public EndpointSignalUnit {      class EndpointUnit: public EndpointSignalUnit {
282          public:          public:
283              Voice* pVoice;              Voice* pVoice;
284    
# Line 209  namespace LinuxSampler { namespace sfz { Line 306  namespace LinuxSampler { namespace sfz {
306      class SfzSignalUnitRack : public SignalUnitRack {      class SfzSignalUnitRack : public SignalUnitRack {
307          private:          private:
308              EndpointUnit  suEndpoint;              EndpointUnit  suEndpoint;
309              EGv1Unit      suVolEG;              AmpEGUnit     suVolEG;
310                FilEGUnit     suFilEG;
311              PitchEGUnit   suPitchEG;              PitchEGUnit   suPitchEG;
312                            
313              AmpLFOUnit   suAmpLFO;              AmpLFOUnit   suAmpLFO;
# Line 227  namespace LinuxSampler { namespace sfz { Line 325  namespace LinuxSampler { namespace sfz {
325                            
326              FixedArray<LFOv2Unit*> LFOs;              FixedArray<LFOv2Unit*> LFOs;
327                            
328                // used for optimization - contains only the ones that are modulating pitch
329                FixedArray<LFOv2Unit*> pitchLFOs;
330                
331              // used for optimization - contains only the ones that are modulating filter cutoff              // used for optimization - contains only the ones that are modulating filter cutoff
332              FixedArray<LFOv2Unit*> filLFOs;              FixedArray<LFOv2Unit*> filLFOs;
333                            

Legend:
Removed from v.2221  
changed lines
  Added in v.2229

  ViewVC Help
Powered by ViewVC