/[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 2219 by iliev, Thu Jul 28 12:35:49 2011 UTC revision 2227 by iliev, Wed Aug 3 17:11:40 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 52  namespace LinuxSampler { namespace sfz { Line 55  namespace LinuxSampler { namespace sfz {
55              double GetSampleRate();              double GetSampleRate();
56      };      };
57            
58        
59        class CCUnit: public CCSignalUnit {
60            public:
61                Voice* pVoice;
62    
63                CCUnit(SfzSignalUnitRack* rack, Listener* l = NULL);
64                
65                virtual void Trigger();
66                
67                void SetCCs(::sfz::Array<int>& pCC);
68                void SetCCs(ArrayList< ::sfz::CC>& cc);
69        };
70        
71        
72      template <class T>      template <class T>
73      class EGUnit: public SfzSignalUnit {      class EGUnit: public SfzSignalUnit {
74          public:          public:
# Line 69  namespace LinuxSampler { namespace sfz { Line 86  namespace LinuxSampler { namespace sfz {
86              }              }
87    
88              virtual bool  Active() { return EG.active(); }              virtual bool  Active() { return EG.active(); }
89              virtual float GetLevel() { return EG.getLevel(); }              virtual float GetLevel() { return DelayStage() ? 0 : EG.getLevel(); }
90                            
91              virtual void EnterReleaseStage() { EG.update(EG::event_release, GetSampleRate()); }              virtual void EnterReleaseStage() { EG.update(EG::event_release, GetSampleRate()); }
92              virtual void CancelRelease() { EG.update(EG::event_cancel_release, GetSampleRate()); }              virtual void CancelRelease() { EG.update(EG::event_cancel_release, GetSampleRate()); }
# Line 104  namespace LinuxSampler { namespace sfz { Line 121  namespace LinuxSampler { namespace sfz {
121            
122      class EGv1Unit: public EGUnit<EGADSR> {      class EGv1Unit: public EGUnit<EGADSR> {
123          public:          public:
124              EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack) { }              int depth;
125                EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack), depth(0) { }
126              virtual void Trigger();              virtual void Trigger();
127      };      };
128            
# Line 114  namespace LinuxSampler { namespace sfz { Line 132  namespace LinuxSampler { namespace sfz {
132              virtual void Trigger();              virtual void Trigger();
133      };      };
134            
135      class LFOUnit: public SfzSignalUnit {      class PitchEGUnit: public EGv1Unit {
136            public:
137                PitchEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
138                virtual void Trigger();
139        };
140        
141        class FilEGUnit: public EGv1Unit {
142          public:          public:
143              ::sfz::LFO* pLfoInfo;              FilEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
144              LFOSigned lfo;              virtual void Trigger();
145        };
146        
147        class AbstractLfo {
148            public:
149                virtual float Render() = 0;
150                virtual void Update(const uint16_t& ExtControlValue) = 0;
151                virtual void Trigger(float Frequency, start_level_t StartLevel, uint16_t InternalDepth, uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate) = 0;
152                virtual void SetPhase(float phase) = 0;
153                virtual void SetFrequency(float Frequency, unsigned int SampleRate) = 0;
154        };
155        
156        template <class T>
157        class LfoBase: public AbstractLfo, public T {
158            public:
159                LfoBase(float Max): T(Max) { }
160                virtual float Render() { return T::render(); }
161                
162                virtual void Update(const uint16_t& ExtControlValue) { T::update(ExtControlValue); }
163                
164                virtual void Trigger (
165                    float Frequency, start_level_t StartLevel, uint16_t InternalDepth,
166                    uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate
167                ) {
168                    T::trigger(Frequency, StartLevel, InternalDepth, ExtControlDepth, FlipPhase, SampleRate);
169                }
170                            
171              LFOUnit(SfzSignalUnitRack* rack): SfzSignalUnit(rack), pLfoInfo(NULL), lfo(1200.0f) { }              virtual void SetPhase(float phase) { T::setPhase(phase); }
172              LFOUnit(const LFOUnit& Unit): SfzSignalUnit(Unit), lfo(1200.0f) { Copy(Unit); }              
173                virtual void SetFrequency(float Frequency, unsigned int SampleRate) {
174                    T::setFrequency(Frequency, SampleRate);
175                }
176        };
177        
178        class LFOUnit;
179        
180        class FadeEGUnit: public EGUnit<EGADSR> {
181            public:
182                FadeEGUnit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack) { }
183                virtual void Trigger() { }
184                virtual void EnterReleaseStage() { }
185                virtual void CancelRelease() { }
186                
187                friend class LFOUnit;
188        };
189        
190        class LFOUnit: public SfzSignalUnit, public CCSignalUnit::Listener {
191            public:
192                ::sfz::LFO*  pLfoInfo;
193                AbstractLfo* pLFO;
194                FadeEGUnit   suFadeEG;
195                CCUnit       suFreqOnCC;
196                
197                LFOUnit(SfzSignalUnitRack* rack);
198                LFOUnit(const LFOUnit& Unit);
199              void operator=(const LFOUnit& Unit) { Copy(Unit); }              void operator=(const LFOUnit& Unit) { Copy(Unit); }
200                            
201              void Copy(const LFOUnit& Unit) {              void Copy(const LFOUnit& Unit) {
202                  pLfoInfo = Unit.pLfoInfo;                  pLfoInfo   = Unit.pLfoInfo;
203                    suFadeEG   = Unit.suFadeEG;
204                                    
205                  SfzSignalUnit::Copy(Unit);                  SfzSignalUnit::Copy(Unit);
206              }              }
# Line 133  namespace LinuxSampler { namespace sfz { Line 209  namespace LinuxSampler { namespace sfz {
209              virtual void  Trigger();              virtual void  Trigger();
210              virtual void  Increment();              virtual void  Increment();
211              virtual float GetLevel() { return Level; }              virtual float GetLevel() { return Level; }
212                virtual void  ValueChanged(CCSignalUnit* pUnit);
213        };
214        
215        class LFOv1Unit: public LFOUnit {
216            public:
217                ::sfz::LFO lfoInfo;
218                LfoBase<LFOSigned> lfo;
219                
220                LFOv1Unit(SfzSignalUnitRack* rack): LFOUnit(rack), lfo(1200.0f) {
221                    pLfoInfo = &lfoInfo; pLFO = &lfo;
222                }
223                
224                virtual void Trigger();
225      };      };
226            
227      class LFOv2Unit: public LFOUnit {      class LFOv2Unit: public LFOUnit {
228            protected:
229                FixedArray<AbstractLfo*> lfos;
230                LfoBase<LFOSigned>                       lfo0; // triangle
231                LfoBase<SineLFO<range_signed> >          lfo1; // sine
232                LfoBase<PulseLFO<range_unsigned, 750> >  lfo2; // pulse 75%
233                LfoBase<SquareLFO<range_signed> >        lfo3; // square
234                LfoBase<PulseLFO<range_unsigned, 250> >  lfo4; // pulse 25%
235                LfoBase<PulseLFO<range_unsigned, 125> >  lfo5; // pulse 12,5%
236                LfoBase<SawLFO<range_unsigned, true> >   lfo6; // saw up
237                LfoBase<SawLFO<range_unsigned, false> >  lfo7; // saw down
238                
239                
240            public:
241                CCUnit suPitchOnCC;
242                
243                LFOv2Unit(SfzSignalUnitRack* rack);
244                
245                virtual void Trigger();
246        };
247        
248        class AmpLFOUnit: public LFOv1Unit {
249            public:
250                AmpLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
251                
252                virtual void Trigger();
253        };
254        
255        class PitchLFOUnit: public LFOv1Unit {
256            public:
257                CCUnit suDepthCC;
258                
259                PitchLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack), suDepthCC(rack) { }
260                
261                virtual void Trigger();
262        };
263        
264        class FilLFOUnit: public LFOv1Unit {
265          public:          public:
266              LFOv2Unit(SfzSignalUnitRack* rack): LFOUnit(rack) { }              FilLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
267                            
268              virtual void Trigger();              virtual void Trigger();
269      };      };
270            
271            
272            
273      class EndpointUnit : public EndpointSignalUnit {      class EndpointUnit: public EndpointSignalUnit {
274          public:          public:
275              Voice* pVoice;              Voice* pVoice;
276    
# Line 173  namespace LinuxSampler { namespace sfz { Line 299  namespace LinuxSampler { namespace sfz {
299          private:          private:
300              EndpointUnit  suEndpoint;              EndpointUnit  suEndpoint;
301              EGv1Unit      suVolEG;              EGv1Unit      suVolEG;
302                FilEGUnit     suFilEG;
303                PitchEGUnit   suPitchEG;
304                
305                AmpLFOUnit   suAmpLFO;
306                PitchLFOUnit suPitchLFO;
307                FilLFOUnit   suFilLFO;
308                            
309              FixedArray<EGv2Unit*> EGs;              FixedArray<EGv2Unit*> EGs;
310                            
# Line 185  namespace LinuxSampler { namespace sfz { Line 317  namespace LinuxSampler { namespace sfz {
317                            
318              FixedArray<LFOv2Unit*> LFOs;              FixedArray<LFOv2Unit*> LFOs;
319                            
320                // used for optimization - contains only the ones that are modulating pitch
321                FixedArray<LFOv2Unit*> pitchLFOs;
322                
323              // used for optimization - contains only the ones that are modulating filter cutoff              // used for optimization - contains only the ones that are modulating filter cutoff
324              FixedArray<LFOv2Unit*> filLFOs;              FixedArray<LFOv2Unit*> filLFOs;
325                            

Legend:
Removed from v.2219  
changed lines
  Added in v.2227

  ViewVC Help
Powered by ViewVC