/[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 2220 by iliev, Thu Jul 28 15:47:51 2011 UTC revision 2226 by iliev, Wed Aug 3 09:12:09 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);
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 121  namespace LinuxSampler { namespace sfz { Line 138  namespace LinuxSampler { namespace sfz {
138              virtual void Trigger();              virtual void Trigger();
139      };      };
140            
141        class FilEGUnit: public EGv1Unit {
142            public:
143                FilEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
144                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        };
154        
155        template <class T>
156        class LfoBase: public AbstractLfo, public T {
157            public:
158                LfoBase(float Max): T(Max) { }
159                virtual float Render() { return T::render(); }
160                
161                virtual void Update(const uint16_t& ExtControlValue) { T::update(ExtControlValue); }
162                
163                virtual void Trigger (
164                    float Frequency, start_level_t StartLevel, uint16_t InternalDepth,
165                    uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate
166                ) {
167                    T::trigger(Frequency, StartLevel, InternalDepth, ExtControlDepth, FlipPhase, SampleRate);
168                }
169                
170                virtual void SetPhase(float phase) { T::setPhase(phase); }
171        };
172        
173        class LFOUnit;
174        
175        class FadeEGUnit: public EGUnit<EGADSR> {
176            public:
177                FadeEGUnit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack) { }
178                virtual void Trigger() { }
179                virtual void EnterReleaseStage() { }
180                virtual void CancelRelease() { }
181                
182                friend class LFOUnit;
183        };
184        
185      class LFOUnit: public SfzSignalUnit {      class LFOUnit: public SfzSignalUnit {
186          public:          public:
187              ::sfz::LFO* pLfoInfo;              ::sfz::LFO*  pLfoInfo;
188              LFOSigned lfo;              AbstractLfo* pLFO;
189                FadeEGUnit   suFadeEG;
190                            
191              LFOUnit(SfzSignalUnitRack* rack): SfzSignalUnit(rack), pLfoInfo(NULL), lfo(1200.0f) { }              LFOUnit(SfzSignalUnitRack* rack): SfzSignalUnit(rack), pLfoInfo(NULL), pLFO(NULL), suFadeEG(rack) { }
192              LFOUnit(const LFOUnit& Unit): SfzSignalUnit(Unit), lfo(1200.0f) { Copy(Unit); }              LFOUnit(const LFOUnit& Unit);
193              void operator=(const LFOUnit& Unit) { Copy(Unit); }              void operator=(const LFOUnit& Unit) { Copy(Unit); }
194                            
195              void Copy(const LFOUnit& Unit) {              void Copy(const LFOUnit& Unit) {
196                  pLfoInfo = Unit.pLfoInfo;                  pLfoInfo = Unit.pLfoInfo;
197                    suFadeEG   = Unit.suFadeEG;
198                                    
199                  SfzSignalUnit::Copy(Unit);                  SfzSignalUnit::Copy(Unit);
200              }              }
# Line 142  namespace LinuxSampler { namespace sfz { Line 205  namespace LinuxSampler { namespace sfz {
205              virtual float GetLevel() { return Level; }              virtual float GetLevel() { return Level; }
206      };      };
207            
208        class LFOv1Unit: public LFOUnit {
209            public:
210                ::sfz::LFO lfoInfo;
211                LfoBase<LFOSigned> lfo;
212                
213                LFOv1Unit(SfzSignalUnitRack* rack): LFOUnit(rack), lfo(1200.0f) {
214                    pLfoInfo = &lfoInfo; pLFO = &lfo;
215                }
216                
217                virtual void Trigger();
218        };
219        
220      class LFOv2Unit: public LFOUnit {      class LFOv2Unit: public LFOUnit {
221            protected:
222                FixedArray<AbstractLfo*> lfos;
223                LfoBase<LFOSigned>                       lfo0; // triangle
224                LfoBase<SineLFO<range_signed> >          lfo1; // sine
225                LfoBase<PulseLFO<range_unsigned, 750> >  lfo2; // pulse 75%
226                LfoBase<SquareLFO<range_signed> >        lfo3; // square
227                LfoBase<PulseLFO<range_unsigned, 250> >  lfo4; // pulse 25%
228                LfoBase<PulseLFO<range_unsigned, 125> >  lfo5; // pulse 12,5%
229                LfoBase<SawLFO<range_unsigned, true> >   lfo6; // saw up
230                LfoBase<SawLFO<range_unsigned, false> >  lfo7; // saw down
231                
232                
233          public:          public:
234              LFOv2Unit(SfzSignalUnitRack* rack): LFOUnit(rack) { }              CCUnit suPitchOnCC;
235                
236                LFOv2Unit(SfzSignalUnitRack* rack);
237                
238                virtual void Trigger();
239        };
240        
241        class AmpLFOUnit: public LFOv1Unit {
242            public:
243                AmpLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
244                
245                virtual void Trigger();
246        };
247        
248        class PitchLFOUnit: public LFOv1Unit {
249            public:
250                CCUnit suDepthCC;
251                
252                PitchLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack), suDepthCC(rack) { }
253                
254                virtual void Trigger();
255        };
256        
257        class FilLFOUnit: public LFOv1Unit {
258            public:
259                FilLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
260                            
261              virtual void Trigger();              virtual void Trigger();
262      };      };
263            
264            
265            
266      class EndpointUnit : public EndpointSignalUnit {      class EndpointUnit: public EndpointSignalUnit {
267          public:          public:
268              Voice* pVoice;              Voice* pVoice;
269    
# Line 180  namespace LinuxSampler { namespace sfz { Line 292  namespace LinuxSampler { namespace sfz {
292          private:          private:
293              EndpointUnit  suEndpoint;              EndpointUnit  suEndpoint;
294              EGv1Unit      suVolEG;              EGv1Unit      suVolEG;
295                FilEGUnit     suFilEG;
296              PitchEGUnit   suPitchEG;              PitchEGUnit   suPitchEG;
297                            
298                AmpLFOUnit   suAmpLFO;
299                PitchLFOUnit suPitchLFO;
300                FilLFOUnit   suFilLFO;
301                
302              FixedArray<EGv2Unit*> EGs;              FixedArray<EGv2Unit*> EGs;
303                            
304              // used for optimization - contains only the ones that are modulating volume              // used for optimization - contains only the ones that are modulating volume
# Line 193  namespace LinuxSampler { namespace sfz { Line 310  namespace LinuxSampler { namespace sfz {
310                            
311              FixedArray<LFOv2Unit*> LFOs;              FixedArray<LFOv2Unit*> LFOs;
312                            
313                // used for optimization - contains only the ones that are modulating pitch
314                FixedArray<LFOv2Unit*> pitchLFOs;
315                
316              // used for optimization - contains only the ones that are modulating filter cutoff              // used for optimization - contains only the ones that are modulating filter cutoff
317              FixedArray<LFOv2Unit*> filLFOs;              FixedArray<LFOv2Unit*> filLFOs;
318                            

Legend:
Removed from v.2220  
changed lines
  Added in v.2226

  ViewVC Help
Powered by ViewVC