/[svn]/linuxsampler/trunk/src/engines/gig/EngineChannel.h
ViewVC logotype

Contents of /linuxsampler/trunk/src/engines/gig/EngineChannel.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 660 - (show annotations) (download) (as text)
Fri Jun 17 19:49:30 2005 UTC (18 years, 10 months ago) by schoenebeck
File MIME type: text/x-c++hdr
File size: 7334 byte(s)
* LSCP server: fixed LSCP event "CHANNEL_INFO" notification
  (e.g. did not notify on volume changes)

1 /***************************************************************************
2 * *
3 * LinuxSampler - modular, streaming capable sampler *
4 * *
5 * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck *
6 * Copyright (C) 2005 Christian Schoenebeck *
7 * *
8 * This program is free software; you can redistribute it and/or modify *
9 * it under the terms of the GNU General Public License as published by *
10 * the Free Software Foundation; either version 2 of the License, or *
11 * (at your option) any later version. *
12 * *
13 * This program is distributed in the hope that it will be useful, *
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
16 * GNU General Public License for more details. *
17 * *
18 * You should have received a copy of the GNU General Public License *
19 * along with this program; if not, write to the Free Software *
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, *
21 * MA 02111-1307 USA *
22 ***************************************************************************/
23
24 #ifndef __LS_GIG_ENGINECHANNEL_H__
25 #define __LS_GIG_ENGINECHANNEL_H__
26
27 #if DEBUG_HEADERS
28 # warning EngineChannel.h included
29 #endif // DEBUG_HEADERS
30
31 #include "../common/Event.h"
32 #include "../common/EngineChannel.h"
33 #include "EngineGlobals.h"
34 #include "Engine.h"
35 #include "Voice.h"
36 #include "InstrumentResourceManager.h"
37
38 namespace LinuxSampler { namespace gig {
39
40 // just symbol prototyping
41 class midi_key_info_t;
42 class Voice;
43
44 /** @brief Engine Channel of a gig::Engine
45 *
46 * Encapsulates a engine channel for the Gigasampler format capable
47 * sampler engine.
48 */
49 class EngineChannel : public LinuxSampler::EngineChannel, public InstrumentConsumer {
50 public:
51 EngineChannel();
52 virtual ~EngineChannel();
53
54 // implementation of abstract methods derived from interface class 'LinuxSampler::EngineChannel'
55 virtual void PrepareLoadInstrument(const char* FileName, uint Instrument);
56 virtual void LoadInstrument();
57 virtual void SendNoteOn(uint8_t Key, uint8_t Velocity);
58 virtual void SendNoteOff(uint8_t Key, uint8_t Velocity);
59 virtual void SendPitchbend(int Pitch);
60 virtual void SendControlChange(uint8_t Controller, uint8_t Value);
61 virtual bool StatusChanged();
62 virtual float Volume();
63 virtual void Volume(float f);
64 virtual uint Channels();
65 virtual void Connect(AudioOutputDevice* pAudioOut);
66 virtual void DisconnectAudioOutputDevice();
67 virtual void SetOutputChannel(uint EngineAudioChannel, uint AudioDeviceChannel);
68 virtual int OutputChannel(uint EngineAudioChannel);
69 virtual String InstrumentFileName();
70 virtual String InstrumentName();
71 virtual int InstrumentIndex();
72 virtual int InstrumentStatus();
73 virtual LinuxSampler::Engine* GetEngine();
74 virtual String EngineName();
75
76 // implementation of abstract methods derived from interface class 'InstrumentConsumer'
77 virtual void ResourceToBeUpdated(::gig::Instrument* pResource, void*& pUpdateArg);
78 virtual void ResourceUpdated(::gig::Instrument* pOldResource, ::gig::Instrument* pNewResource, void* pUpdateArg);
79 virtual void OnResourceProgress(float fProgress);
80
81 //protected:
82 Engine* pEngine;
83 float* pOutputLeft; ///< Audio output channel buffer (left)
84 float* pOutputRight; ///< Audio output channel buffer (right)
85 int AudioDeviceChannelLeft; ///< audio device channel number to which the left channel is connected to
86 int AudioDeviceChannelRight; ///< audio device channel number to which the right channel is connected to
87 RingBuffer<Event>* pEventQueue; ///< Input event queue.
88 RTList<Event>* pEvents; ///< All engine channel specific events for the current audio fragment.
89 RTList<Event>* pCCEvents; ///< All control change events for the current audio fragment on this engine channel.
90 RTList<Event>* pSynthesisEvents[Event::destination_count]; ///< Events directly affecting synthesis parameters (like pitch, volume and filter).
91 uint8_t ControllerTable[128]; ///< Reflects the current values (0-127) of all MIDI controllers for this engine / sampler channel.
92 midi_key_info_t* pMIDIKeyInfo; ///< Contains all active voices sorted by MIDI key number and other informations to the respective MIDI key
93 Pool<uint>* pActiveKeys; ///< Holds all keys in it's allocation list with active voices.
94 std::map<uint,uint*> ActiveKeyGroups; ///< Contains active keys (in case they belong to a key group) ordered by key group ID.
95 ::gig::Instrument* pInstrument;
96 bool SustainPedal; ///< true if sustain pedal is down
97 double GlobalVolume; ///< overall volume (a value < 1.0 means attenuation, a value > 1.0 means amplification)
98 float GlobalPanLeft;
99 float GlobalPanRight;
100 int Pitch; ///< Current (absolute) MIDI pitch value.
101 int CurrentKeyDimension; ///< Current value (0-127) for the keyboard dimension, altered by pressing a keyswitching key.
102 String InstrumentFile;
103 int InstrumentIdx;
104 String InstrumentIdxName;
105 int InstrumentStat;
106 int iEngineIndexSelf; ///< Reflects the index of this EngineChannel in the Engine's ArrayList.
107 bool bStatusChanged; ///< true in case an engine parameter has changed (e.g. new instrument, another volumet)
108
109 void ResetControllers();
110 void ClearEventLists();
111 void ImportEvents(uint Samples);
112
113 friend class Engine;
114 friend class Voice;
115 friend class InstrumentResourceManager;
116
117 private:
118 void ResetInternal();
119 };
120
121 }} // namespace LinuxSampler::gig
122
123 #endif // __LS_GIG_ENGINECHANNEL_H__

  ViewVC Help
Powered by ViewVC