/[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 2229 by iliev, Thu Aug 4 19:02:36 2011 UTC revision 2252 by iliev, Sat Aug 20 14:01:36 2011 UTC
# Line 32  Line 32 
32  #include "../common/SineLFO.h"  #include "../common/SineLFO.h"
33    
34  namespace LinuxSampler { namespace sfz {  namespace LinuxSampler { namespace sfz {
35      const int MaxUnitCount = 1000;      const int MaxUnitCount = 200;
36      const int maxEgCount = 100; // Maximum number of v2 envelope generators      const int maxEgCount = 30; // Maximum number of v2 envelope generators
37      const int maxLfoCount = 100; // Maximum number of v2 LFOs      const int maxLfoCount = 30; // Maximum number of v2 LFOs
38            
39      class Voice;      class Voice;
40      class SfzSignalUnitRack;      class SfzSignalUnitRack;
# Line 67  namespace LinuxSampler { namespace sfz { Line 67  namespace LinuxSampler { namespace sfz {
67                            
68              void SetCCs(::sfz::Array<int>& pCC);              void SetCCs(::sfz::Array<int>& pCC);
69              void SetCCs(ArrayList< ::sfz::CC>& cc);              void SetCCs(ArrayList< ::sfz::CC>& cc);
70                
71                virtual void AddSmoothCC(uint8_t Controller, float Influence, short int Curve, float Smooth);
72                
73                int GetCurveCount();
74                ::sfz::Curve* GetCurve(int idx);
75                
76                double GetSampleRate();
77        };
78        
79        class CurveCCUnit: public CCUnit {
80            public:
81                CurveCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): CCUnit(rack, l) { }
82                
83                virtual float Normalize(uint8_t val, short int curve = -1) {
84                    if (curve == -1) return val / 127.0f;
85                    return GetCurve(curve)->v[val];
86                }
87        };
88        
89        
90        
91        class SmoothCCUnit: public CurveCCUnit {
92            protected:
93                RTList<Smoother>* pSmoothers;
94            public:
95                SmoothCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): CurveCCUnit(rack, l), pSmoothers(NULL) { }
96                virtual ~SmoothCCUnit();
97                
98                virtual void AddSmoothCC(uint8_t Controller, float Influence, short int Curve, float Smooth);
99                virtual void RemoveAllCCs() { CurveCCUnit::RemoveAllCCs(); pSmoothers->clear(); }
100                virtual void InitCCList(Pool<CC>* pCCPool, Pool<Smoother>* pSmootherPool);
101                
102                void InitSmoothers(Pool<Smoother>* pSmootherPool);
103        };
104        
105        
106        class XFInCCUnit: public CCUnit {
107            public:
108                XFInCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): CCUnit(rack, l) { }
109                
110                virtual bool Active() { return !pCtrls->isEmpty(); }
111                virtual void Calculate();
112                virtual void SetCrossFadeCCs(::sfz::Array<int>& loCCs, ::sfz::Array<int>& hiCCs);
113        };
114        
115        
116        class XFOutCCUnit: public XFInCCUnit {
117            public:
118                XFOutCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): XFInCCUnit(rack, l) { }
119                
120                virtual void Calculate();
121      };      };
122            
123            
# Line 130  namespace LinuxSampler { namespace sfz { Line 181  namespace LinuxSampler { namespace sfz {
181          protected:          protected:
182              ::sfz::EG egInfo;              ::sfz::EG egInfo;
183          public:          public:
184              EGv2Unit(SfzSignalUnitRack* rack): EGUnit< ::LinuxSampler::sfz::EG>(rack) { }              CCUnit suAmpOnCC;
185                CCUnit suVolOnCC;
186                CCUnit suPitchOnCC;
187                CCUnit suCutoffOnCC;
188                CCUnit suResOnCC;
189                CurveCCUnit suPanOnCC;
190                
191                EGv2Unit(SfzSignalUnitRack* rack);
192              virtual void Trigger();              virtual void Trigger();
193      };      };
194            
# Line 200  namespace LinuxSampler { namespace sfz { Line 258  namespace LinuxSampler { namespace sfz {
258              ::sfz::LFO*  pLfoInfo;              ::sfz::LFO*  pLfoInfo;
259              AbstractLfo* pLFO;              AbstractLfo* pLFO;
260              FadeEGUnit   suFadeEG;              FadeEGUnit   suFadeEG;
261              CCUnit       suFreqOnCC;              SmoothCCUnit suDepthOnCC;
262                SmoothCCUnit suFreqOnCC;
263                            
264              LFOUnit(SfzSignalUnitRack* rack);              LFOUnit(SfzSignalUnitRack* rack);
265              LFOUnit(const LFOUnit& Unit);              LFOUnit(const LFOUnit& Unit);
# Line 213  namespace LinuxSampler { namespace sfz { Line 272  namespace LinuxSampler { namespace sfz {
272                  SfzSignalUnit::Copy(Unit);                  SfzSignalUnit::Copy(Unit);
273              }              }
274                            
             virtual bool  Active() { return pLfoInfo->freq > 0; }  
275              virtual void  Trigger();              virtual void  Trigger();
276              virtual void  Increment();              virtual void  Increment();
277              virtual float GetLevel() { return Level; }              virtual float GetLevel() { return Level; }
278              virtual void  ValueChanged(CCSignalUnit* pUnit);              
279                // CCSignalUnit::Listener interface implementation
280                virtual void ValueChanged(CCSignalUnit* pUnit);
281      };      };
282            
283      class LFOv1Unit: public LFOUnit {      class LFOv1Unit: public LFOUnit {
# Line 246  namespace LinuxSampler { namespace sfz { Line 306  namespace LinuxSampler { namespace sfz {
306                            
307                            
308          public:          public:
309              CCUnit suPitchOnCC;              SmoothCCUnit suVolOnCC;
310                SmoothCCUnit suPitchOnCC;
311                SmoothCCUnit suPanOnCC;
312                SmoothCCUnit suCutoffOnCC;
313                SmoothCCUnit suResOnCC;
314                            
315              LFOv2Unit(SfzSignalUnitRack* rack);              LFOv2Unit(SfzSignalUnitRack* rack);
316                            
317              virtual void Trigger();              virtual void Trigger();
318                virtual bool  Active() { return true; }
319      };      };
320            
321      class AmpLFOUnit: public LFOv1Unit {      class AmpLFOUnit: public LFOv1Unit {
# Line 262  namespace LinuxSampler { namespace sfz { Line 327  namespace LinuxSampler { namespace sfz {
327            
328      class PitchLFOUnit: public LFOv1Unit {      class PitchLFOUnit: public LFOv1Unit {
329          public:          public:
330              CCUnit suDepthCC;              PitchLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
               
             PitchLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack), suDepthCC(rack) { }  
331                            
332              virtual void Trigger();              virtual void Trigger();
333      };      };
# Line 277  namespace LinuxSampler { namespace sfz { Line 340  namespace LinuxSampler { namespace sfz {
340      };      };
341            
342            
       
343      class EndpointUnit: public EndpointSignalUnit {      class EndpointUnit: public EndpointSignalUnit {
344            private:
345                float xfCoeff; // crossfade coefficient
346                float pitchVeltrackRatio;
347                
348          public:          public:
349              Voice* pVoice;              Voice* pVoice;
350                XFInCCUnit   suXFInCC;
351                XFOutCCUnit  suXFOutCC;
352                SmoothCCUnit suPanOnCC;
353    
354              EndpointUnit(SfzSignalUnitRack* rack);              EndpointUnit(SfzSignalUnitRack* rack);
355    
# Line 300  namespace LinuxSampler { namespace sfz { Line 369  namespace LinuxSampler { namespace sfz {
369              virtual float CalculateResonance(float res) {              virtual float CalculateResonance(float res) {
370                  return GetResonance() + res;                  return GetResonance() + res;
371              }              }
372                
373                virtual float CalculateFilterCutoff(float cutoff);
374      };      };
375            
376            
# Line 314  namespace LinuxSampler { namespace sfz { Line 385  namespace LinuxSampler { namespace sfz {
385              PitchLFOUnit suPitchLFO;              PitchLFOUnit suPitchLFO;
386              FilLFOUnit   suFilLFO;              FilLFOUnit   suFilLFO;
387                            
388                // SFZ v2
389                
390                SmoothCCUnit suVolOnCC;
391                SmoothCCUnit suCutoffOnCC;
392                SmoothCCUnit suResOnCC;
393                
394              FixedArray<EGv2Unit*> EGs;              FixedArray<EGv2Unit*> EGs;
395                            
396              // used for optimization - contains only the ones that are modulating volume              // used for optimization - contains only the ones that are modulating volume
# Line 322  namespace LinuxSampler { namespace sfz { Line 399  namespace LinuxSampler { namespace sfz {
399              // used for optimization - contains only the ones that are modulating pitch              // used for optimization - contains only the ones that are modulating pitch
400              FixedArray<EGv2Unit*> pitchEGs;              FixedArray<EGv2Unit*> pitchEGs;
401                            
402                // used for optimization - contains only the ones that are modulating filter cutoff
403                FixedArray<EGv2Unit*> filEGs;
404                
405                // used for optimization - contains only the ones that are modulating resonance
406                FixedArray<EGv2Unit*> resEGs;
407                
408                // used for optimization - contains only the ones that are modulating pitch
409                FixedArray<EGv2Unit*> panEGs;
410                
411                            
412              FixedArray<LFOv2Unit*> LFOs;              FixedArray<LFOv2Unit*> LFOs;
413                            
414                // used for optimization - contains only the ones that are modulating volume
415                FixedArray<LFOv2Unit*> volLFOs;
416                
417              // used for optimization - contains only the ones that are modulating pitch              // used for optimization - contains only the ones that are modulating pitch
418              FixedArray<LFOv2Unit*> pitchLFOs;              FixedArray<LFOv2Unit*> pitchLFOs;
419                            
# Line 352  namespace LinuxSampler { namespace sfz { Line 441  namespace LinuxSampler { namespace sfz {
441              virtual void Trigger();              virtual void Trigger();
442              virtual void EnterFadeOutStage();              virtual void EnterFadeOutStage();
443                            
444                /** Called when the engine is set and the engine's pools are ready to use. */
445                void InitRTLists();
446                
447                /** Invoked when the voice gone inactive. */
448                void Reset();
449                
450              friend class EndpointUnit;              friend class EndpointUnit;
451      };      };
452  }} // namespace LinuxSampler::sfz  }} // namespace LinuxSampler::sfz

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

  ViewVC Help
Powered by ViewVC