/[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 2227 by iliev, Wed Aug 3 17:11:40 2011 UTC revision 2236 by iliev, Thu Aug 11 18:25:45 2011 UTC
# Line 53  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            
# Line 66  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                inline int GetCurveCount();
74                inline ::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                Smoother Smoothers[128];
94            public:
95                SmoothCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): CurveCCUnit(rack, l) { }
96                
97                virtual void AddSmoothCC(uint8_t Controller, float Influence, short int Curve, float Smooth);
98        };
99        
100        
101        class XFInCCUnit: public CCUnit {
102            public:
103                XFInCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): CCUnit(rack, l) { }
104                
105                virtual bool Active() { return Ctrls.size() > 0; }
106                virtual void Calculate();
107                virtual void SetCrossFadeCCs(::sfz::Array<int>& loCCs, ::sfz::Array<int>& hiCCs);
108        };
109        
110        
111        class XFOutCCUnit: public XFInCCUnit {
112            public:
113                XFOutCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): XFInCCUnit(rack, l) { }
114                
115                virtual void Calculate();
116      };      };
117            
118            
# Line 123  namespace LinuxSampler { namespace sfz { Line 170  namespace LinuxSampler { namespace sfz {
170          public:          public:
171              int depth;              int depth;
172              EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack), depth(0) { }              EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack), depth(0) { }
             virtual void Trigger();  
173      };      };
174            
175      class EGv2Unit: public EGUnit< ::LinuxSampler::sfz::EG> {      class EGv2Unit: public EGUnit< ::LinuxSampler::sfz::EG> {
176            protected:
177                ::sfz::EG egInfo;
178          public:          public:
179              EGv2Unit(SfzSignalUnitRack* rack): EGUnit< ::LinuxSampler::sfz::EG>(rack) { }              CCUnit suAmpOnCC;
180                CCUnit suVolOnCC;
181                CCUnit suPitchOnCC;
182                CCUnit suCutoffOnCC;
183                CCUnit suResOnCC;
184                
185                EGv2Unit(SfzSignalUnitRack* rack);
186              virtual void Trigger();              virtual void Trigger();
187      };      };
188            
# Line 144  namespace LinuxSampler { namespace sfz { Line 198  namespace LinuxSampler { namespace sfz {
198              virtual void Trigger();              virtual void Trigger();
199      };      };
200            
201        class AmpEGUnit: public EGv1Unit {
202            public:
203                AmpEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
204                virtual void Trigger();
205        };
206        
207      class AbstractLfo {      class AbstractLfo {
208          public:          public:
209              virtual float Render() = 0;              virtual float Render() = 0;
# Line 192  namespace LinuxSampler { namespace sfz { Line 252  namespace LinuxSampler { namespace sfz {
252              ::sfz::LFO*  pLfoInfo;              ::sfz::LFO*  pLfoInfo;
253              AbstractLfo* pLFO;              AbstractLfo* pLFO;
254              FadeEGUnit   suFadeEG;              FadeEGUnit   suFadeEG;
255              CCUnit       suFreqOnCC;              SmoothCCUnit suDepthOnCC;
256                SmoothCCUnit suFreqOnCC;
257                            
258              LFOUnit(SfzSignalUnitRack* rack);              LFOUnit(SfzSignalUnitRack* rack);
259              LFOUnit(const LFOUnit& Unit);              LFOUnit(const LFOUnit& Unit);
# Line 205  namespace LinuxSampler { namespace sfz { Line 266  namespace LinuxSampler { namespace sfz {
266                  SfzSignalUnit::Copy(Unit);                  SfzSignalUnit::Copy(Unit);
267              }              }
268                            
269              virtual bool  Active() { return true; }              virtual bool  Active() { return pLfoInfo->freq > 0; }
270              virtual void  Trigger();              virtual void  Trigger();
271              virtual void  Increment();              virtual void  Increment();
272              virtual float GetLevel() { return Level; }              virtual float GetLevel() { return Level; }
# Line 238  namespace LinuxSampler { namespace sfz { Line 299  namespace LinuxSampler { namespace sfz {
299                            
300                            
301          public:          public:
302              CCUnit suPitchOnCC;              SmoothCCUnit suVolOnCC;
303                SmoothCCUnit suPitchOnCC;
304                SmoothCCUnit suPanOnCC;
305                SmoothCCUnit suCutoffOnCC;
306                SmoothCCUnit suResOnCC;
307                            
308              LFOv2Unit(SfzSignalUnitRack* rack);              LFOv2Unit(SfzSignalUnitRack* rack);
309                            
# Line 254  namespace LinuxSampler { namespace sfz { Line 319  namespace LinuxSampler { namespace sfz {
319            
320      class PitchLFOUnit: public LFOv1Unit {      class PitchLFOUnit: public LFOv1Unit {
321          public:          public:
322              CCUnit suDepthCC;              PitchLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
               
             PitchLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack), suDepthCC(rack) { }  
323                            
324              virtual void Trigger();              virtual void Trigger();
325      };      };
# Line 269  namespace LinuxSampler { namespace sfz { Line 332  namespace LinuxSampler { namespace sfz {
332      };      };
333            
334            
       
335      class EndpointUnit: public EndpointSignalUnit {      class EndpointUnit: public EndpointSignalUnit {
336            private:
337                float xfCoeff; // crossfade coefficient
338                
339          public:          public:
340              Voice* pVoice;              Voice* pVoice;
341                XFInCCUnit  suXFInCC;
342                XFOutCCUnit suXFOutCC;
343    
344              EndpointUnit(SfzSignalUnitRack* rack);              EndpointUnit(SfzSignalUnitRack* rack);
345    
# Line 292  namespace LinuxSampler { namespace sfz { Line 359  namespace LinuxSampler { namespace sfz {
359              virtual float CalculateResonance(float res) {              virtual float CalculateResonance(float res) {
360                  return GetResonance() + res;                  return GetResonance() + res;
361              }              }
362                
363                virtual float CalculateFilterCutoff(float cutoff);
364      };      };
365            
366            
367      class SfzSignalUnitRack : public SignalUnitRack {      class SfzSignalUnitRack : public SignalUnitRack {
368          private:          private:
369              EndpointUnit  suEndpoint;              EndpointUnit  suEndpoint;
370              EGv1Unit      suVolEG;              AmpEGUnit     suVolEG;
371              FilEGUnit     suFilEG;              FilEGUnit     suFilEG;
372              PitchEGUnit   suPitchEG;              PitchEGUnit   suPitchEG;
373                            
# Line 306  namespace LinuxSampler { namespace sfz { Line 375  namespace LinuxSampler { namespace sfz {
375              PitchLFOUnit suPitchLFO;              PitchLFOUnit suPitchLFO;
376              FilLFOUnit   suFilLFO;              FilLFOUnit   suFilLFO;
377                            
378                // SFZ v2
379                
380                SmoothCCUnit suVolOnCC;
381                
382              FixedArray<EGv2Unit*> EGs;              FixedArray<EGv2Unit*> EGs;
383                            
384              // used for optimization - contains only the ones that are modulating volume              // used for optimization - contains only the ones that are modulating volume
# Line 314  namespace LinuxSampler { namespace sfz { Line 387  namespace LinuxSampler { namespace sfz {
387              // used for optimization - contains only the ones that are modulating pitch              // used for optimization - contains only the ones that are modulating pitch
388              FixedArray<EGv2Unit*> pitchEGs;              FixedArray<EGv2Unit*> pitchEGs;
389                            
390                // used for optimization - contains only the ones that are modulating filter cutoff
391                FixedArray<EGv2Unit*> filEGs;
392                
393                // used for optimization - contains only the ones that are modulating filter cutoff
394                FixedArray<EGv2Unit*> resEGs;
395                
396                            
397              FixedArray<LFOv2Unit*> LFOs;              FixedArray<LFOv2Unit*> LFOs;
398                            
399                // used for optimization - contains only the ones that are modulating volume
400                FixedArray<LFOv2Unit*> volLFOs;
401                
402              // used for optimization - contains only the ones that are modulating pitch              // used for optimization - contains only the ones that are modulating pitch
403              FixedArray<LFOv2Unit*> pitchLFOs;              FixedArray<LFOv2Unit*> pitchLFOs;
404                            

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

  ViewVC Help
Powered by ViewVC