/[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 2224 by iliev, Mon Aug 1 19:08:09 2011 UTC revision 2230 by iliev, Fri Aug 5 17:59:10 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 60  namespace LinuxSampler { namespace sfz { Line 61  namespace LinuxSampler { namespace sfz {
61          public:          public:
62              Voice* pVoice;              Voice* pVoice;
63    
64              CCUnit(SfzSignalUnitRack* rack);              CCUnit(SfzSignalUnitRack* rack, Listener* l = NULL);
65                            
66              virtual void Trigger();              virtual void Trigger();
67                            
68              void SetCCs(::sfz::Array<int>& pCC);              void SetCCs(::sfz::Array<int>& pCC);
69                void SetCCs(ArrayList< ::sfz::CC>& cc);
70                
71                inline int GetCurveCount();
72                inline ::sfz::Curve* GetCurve(int idx);
73        };
74        
75        class CurveCCUnit: public CCUnit {
76            public:
77                CurveCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): CCUnit(rack, l) { }
78                
79                virtual void Calculate() {
80                    Level = 0;
81                    for (int i = 0; i < Ctrls.size(); i++) {
82                        if (Ctrls[i].Value == 0) continue;
83                        if (Ctrls[i].Curve == -1) {
84                            Level += (Ctrls[i].Value / 127.0f) * Ctrls[i].Influence;
85                        } else {
86                            Level += GetCurve(Ctrls[i].Curve)->v[Ctrls[i].Value] * Ctrls[i].Influence;
87                        }
88                    }
89                }
90      };      };
91            
92            
# Line 122  namespace LinuxSampler { namespace sfz { Line 144  namespace LinuxSampler { namespace sfz {
144          public:          public:
145              int depth;              int depth;
146              EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack), depth(0) { }              EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack), depth(0) { }
             virtual void Trigger();  
147      };      };
148            
149      class EGv2Unit: public EGUnit< ::LinuxSampler::sfz::EG> {      class EGv2Unit: public EGUnit< ::LinuxSampler::sfz::EG> {
150            protected:
151                ::sfz::EG egInfo;
152          public:          public:
153              EGv2Unit(SfzSignalUnitRack* rack): EGUnit< ::LinuxSampler::sfz::EG>(rack) { }              EGv2Unit(SfzSignalUnitRack* rack): EGUnit< ::LinuxSampler::sfz::EG>(rack) { }
154              virtual void Trigger();              virtual void Trigger();
# Line 143  namespace LinuxSampler { namespace sfz { Line 166  namespace LinuxSampler { namespace sfz {
166              virtual void Trigger();              virtual void Trigger();
167      };      };
168            
169        class AmpEGUnit: public EGv1Unit {
170            public:
171                AmpEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
172                virtual void Trigger();
173        };
174        
175      class AbstractLfo {      class AbstractLfo {
176          public:          public:
177              virtual float Render() = 0;              virtual float Render() = 0;
178              virtual void Update(const uint16_t& ExtControlValue) = 0;              virtual void Update(const uint16_t& ExtControlValue) = 0;
179              virtual void Trigger(float Frequency, start_level_t StartLevel, uint16_t InternalDepth, uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate) = 0;              virtual void Trigger(float Frequency, start_level_t StartLevel, uint16_t InternalDepth, uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate) = 0;
180                virtual void SetPhase(float phase) = 0;
181                virtual void SetFrequency(float Frequency, unsigned int SampleRate) = 0;
182      };      };
183            
184      template <class T>      template <class T>
# Line 164  namespace LinuxSampler { namespace sfz { Line 195  namespace LinuxSampler { namespace sfz {
195              ) {              ) {
196                  T::trigger(Frequency, StartLevel, InternalDepth, ExtControlDepth, FlipPhase, SampleRate);                  T::trigger(Frequency, StartLevel, InternalDepth, ExtControlDepth, FlipPhase, SampleRate);
197              }              }
198                
199                virtual void SetPhase(float phase) { T::setPhase(phase); }
200                
201                virtual void SetFrequency(float Frequency, unsigned int SampleRate) {
202                    T::setFrequency(Frequency, SampleRate);
203                }
204        };
205        
206        class LFOUnit;
207        
208        class FadeEGUnit: public EGUnit<EGADSR> {
209            public:
210                FadeEGUnit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack) { }
211                virtual void Trigger() { }
212                virtual void EnterReleaseStage() { }
213                virtual void CancelRelease() { }
214                
215                friend class LFOUnit;
216      };      };
217            
218      class LFOUnit: public SfzSignalUnit {      class LFOUnit: public SfzSignalUnit, public CCSignalUnit::Listener {
219          public:          public:
220              ::sfz::LFO* pLfoInfo;              ::sfz::LFO*  pLfoInfo;
221              AbstractLfo* pLFO;              AbstractLfo* pLFO;
222                FadeEGUnit   suFadeEG;
223                CCUnit       suFreqOnCC;
224                            
225              LFOUnit(SfzSignalUnitRack* rack): SfzSignalUnit(rack), pLfoInfo(NULL), pLFO(NULL) { }              LFOUnit(SfzSignalUnitRack* rack);
226              LFOUnit(const LFOUnit& Unit): SfzSignalUnit(Unit) { Copy(Unit); }              LFOUnit(const LFOUnit& Unit);
227              void operator=(const LFOUnit& Unit) { Copy(Unit); }              void operator=(const LFOUnit& Unit) { Copy(Unit); }
228                            
229              void Copy(const LFOUnit& Unit) {              void Copy(const LFOUnit& Unit) {
230                  pLfoInfo = Unit.pLfoInfo;                  pLfoInfo   = Unit.pLfoInfo;
231                    suFadeEG   = Unit.suFadeEG;
232                                    
233                  SfzSignalUnit::Copy(Unit);                  SfzSignalUnit::Copy(Unit);
234              }              }
235                            
236              virtual bool  Active() { return true; }              virtual bool  Active() { return pLfoInfo->freq > 0; }
237              virtual void  Trigger();              virtual void  Trigger();
238              virtual void  Increment();              virtual void  Increment();
239              virtual float GetLevel() { return Level; }              virtual float GetLevel() { return Level; }
240                virtual void  ValueChanged(CCSignalUnit* pUnit);
241      };      };
242            
243      class LFOv1Unit: public LFOUnit {      class LFOv1Unit: public LFOUnit {
# Line 213  namespace LinuxSampler { namespace sfz { Line 266  namespace LinuxSampler { namespace sfz {
266                            
267                            
268          public:          public:
269                CCUnit suPitchOnCC;
270                
271              LFOv2Unit(SfzSignalUnitRack* rack);              LFOv2Unit(SfzSignalUnitRack* rack);
272                            
273              virtual void Trigger();              virtual void Trigger();
# Line 242  namespace LinuxSampler { namespace sfz { Line 297  namespace LinuxSampler { namespace sfz {
297      };      };
298            
299            
       
300      class EndpointUnit: public EndpointSignalUnit {      class EndpointUnit: public EndpointSignalUnit {
301          public:          public:
302              Voice* pVoice;              Voice* pVoice;
# Line 271  namespace LinuxSampler { namespace sfz { Line 325  namespace LinuxSampler { namespace sfz {
325      class SfzSignalUnitRack : public SignalUnitRack {      class SfzSignalUnitRack : public SignalUnitRack {
326          private:          private:
327              EndpointUnit  suEndpoint;              EndpointUnit  suEndpoint;
328              EGv1Unit      suVolEG;              AmpEGUnit     suVolEG;
329              FilEGUnit     suFilEG;              FilEGUnit     suFilEG;
330              PitchEGUnit   suPitchEG;              PitchEGUnit   suPitchEG;
331                            
# Line 279  namespace LinuxSampler { namespace sfz { Line 333  namespace LinuxSampler { namespace sfz {
333              PitchLFOUnit suPitchLFO;              PitchLFOUnit suPitchLFO;
334              FilLFOUnit   suFilLFO;              FilLFOUnit   suFilLFO;
335                            
336                // SFZ v2
337                
338                CurveCCUnit suVolOnCC;
339                
340              FixedArray<EGv2Unit*> EGs;              FixedArray<EGv2Unit*> EGs;
341                            
342              // used for optimization - contains only the ones that are modulating volume              // used for optimization - contains only the ones that are modulating volume
# Line 290  namespace LinuxSampler { namespace sfz { Line 348  namespace LinuxSampler { namespace sfz {
348                            
349              FixedArray<LFOv2Unit*> LFOs;              FixedArray<LFOv2Unit*> LFOs;
350                            
351                // used for optimization - contains only the ones that are modulating pitch
352                FixedArray<LFOv2Unit*> pitchLFOs;
353                
354              // used for optimization - contains only the ones that are modulating filter cutoff              // used for optimization - contains only the ones that are modulating filter cutoff
355              FixedArray<LFOv2Unit*> filLFOs;              FixedArray<LFOv2Unit*> filLFOs;
356                            

Legend:
Removed from v.2224  
changed lines
  Added in v.2230

  ViewVC Help
Powered by ViewVC