Skip to content

Commit 8f13409

Browse files
committed
Initial commit, still work to be done...
1 parent 2fe0614 commit 8f13409

14 files changed

+2078
-1
lines changed

LO2ChannelStripComponent.py

Lines changed: 255 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,255 @@
1+
from _Framework.ChannelStripComponent import ChannelStripComponent
2+
from _Framework.SubjectSlot import subject_slot
3+
4+
from LO2DeviceComponent import LO2DeviceComponent
5+
from LO2ParameterComponent import LO2ParameterComponent
6+
from LO2Mixin import LO2Mixin, wrap_init
7+
8+
class LO2ChannelStripComponent(ChannelStripComponent, LO2Mixin):
9+
10+
@wrap_init
11+
def __init__(self, *a, **kw):
12+
self._track_id = None
13+
self._type = None
14+
self._devices = []
15+
self._sends = []
16+
17+
super(LO2ChannelStripComponent, self).__init__(*a, **kw)
18+
19+
self.set_default('_track_id')
20+
21+
for t in [0, 1]:
22+
for p in ['mute', 'solo', 'arm']:
23+
self.add_mixer_callback('/live/'+self._track_types[t]+p, p)
24+
for p in ['volume', 'panning']:
25+
self.add_mixer_callback('/live/'+self._track_types[t]+p, p, 1)
26+
27+
self.add_mixer_callback('/live/master/volume', 'volume', 1)
28+
self.add_mixer_callback('/live/master/pan', 'pan', 1)
29+
30+
self.add_callback('/live/track/stop', self._stop)
31+
32+
for t in self._track_types:
33+
self.add_callback('/live/'+t+'/crossfader', self._crossfader)
34+
35+
for ty in ['track', 'return']:
36+
self.add_simple_callback('/live/'+ty+'/name', '_track', 'name', self._is_track, getattr(self, '_lo2__on_track_name_changed'))
37+
self.add_simple_callback('/live/'+ty+'/color', '_track', 'color', self._is_track, getattr(self, '_on_track_color_changed'))
38+
39+
self.add_callback('/live/track/state', self._track_state)
40+
41+
for ty in self._track_types:
42+
self.add_callback('/live/'+ty+'devices', self._device_list)
43+
self.add_callback('/live/'+ty+'select', self._view)
44+
45+
46+
def with_track(fn):
47+
def decorator(*a, **kw):
48+
if self._track is not None:
49+
fn(*a, **kw)
50+
51+
return decorator
52+
53+
54+
@property
55+
def id(self):
56+
if self._track is not None:
57+
return self._track_id
58+
else:
59+
return -1
60+
61+
62+
def _get_name(self):
63+
if self._track is not None:
64+
return self._track.name
65+
else:
66+
return ''
67+
68+
def _set_name(self, name):
69+
if self._track is not None:
70+
self._track.name = name
71+
72+
track_name = property(_get_name, _set_name)
73+
74+
75+
def disconnect(self):
76+
LO2Mixin.disconnect(self)
77+
super(LO2ChannelStripComponent, self).disconnect()
78+
79+
80+
def _is_track(self, msg):
81+
if 'return' in msg[0]:
82+
ty = 1
83+
elif 'master' in msg[0]:
84+
ty = 2
85+
else:
86+
ty = 0
87+
88+
check_id = msg[2] == self._track_id if ty != 2 else True
89+
90+
self.log_message(str(msg) + ' ' + str(self._track_id) + ' ' + str(self._type))
91+
92+
return ty == self._type and check_id
93+
94+
95+
def add_mixer_callback(self, addr, property, mixer = 0):
96+
def cb(msg, src):
97+
if self._is_track(msg) and self.is_enabled():
98+
self.log_message('moo' + str(msg))
99+
v = msg[2] if len(msg) == 3 else None
100+
101+
if self._track is not None:
102+
obj = getattr(self._track.mixer_device, property) if mixer else self._track
103+
pr = 'value' if mixer else property
104+
ot = float if mixer else int
105+
106+
if v:
107+
setattr(obj, pr, v)
108+
else:
109+
if self._type == 2:
110+
self.send('/live/master/'+property, ot(getattr(obj, pr)))
111+
else:
112+
self.send_default('/live/'+self._track_types[self._type]+property, ot(getattr(obj, pr)))
113+
114+
self.add_callback(addr, cb)
115+
116+
117+
def set_track(self, track):
118+
if self._is_enabled_ovr:
119+
self._track_id, self._type = self.track_id_type(track)
120+
super(LO2ChannelStripComponent, self).set_track(track)
121+
122+
self._on_device_list_changed.subject = track
123+
self._on_track_color_changed.subject = track
124+
self._on_track_state_changed.subject = track
125+
126+
m = track.mixer_device if track else None
127+
self._on_volume_changed.subject = m.volume if track else None
128+
self._on_panning_changed.subject = m.panning if track else None
129+
130+
self._lo2__on_sends_changed()
131+
self._on_device_list_changed()
132+
133+
134+
def _lo2__on_sends_changed(self):
135+
if self._track is not None and self._type != 2:
136+
diff = len(self._track.mixer_device.sends) - len(self._sends)
137+
138+
if diff > 0:
139+
for i in range(diff):
140+
self._sends.append(LO2ParameterComponent(True))
141+
142+
if diff < 0:
143+
for i in range(len(self._sends)-1, len(self._track.mixer_device.sends)-1, -1):
144+
self._sends[i].disconnect()
145+
self._sends.remove(self._sends[i])
146+
147+
for i,s in enumerate(self._sends):
148+
s.set_parameter(self._track.mixer_device.sends[i])
149+
150+
151+
152+
153+
@subject_slot('devices')
154+
def _on_device_list_changed(self):
155+
if self._track is not None:
156+
diff = len(self._track.devices) - len(self._devices)
157+
158+
if diff > 0:
159+
for i in range(diff):
160+
self._devices.append(LO2DeviceComponent())
161+
162+
if diff < 0:
163+
for i in range(len(self._devices)-1, len(self._track.devices)-1, -1):
164+
self._devices[i].disconnect()
165+
self._devices.remove(self._devices[i])
166+
167+
for i,dc in enumerate(self._devices):
168+
dc.set_device(self._track.devices[i])
169+
170+
self._send_device_list()
171+
172+
173+
@subject_slot('value')
174+
def _on_volume_changed(self):
175+
self.log_message(str(self._track_id) + ' ' + str(self._type) + str(self._track) + str(self._track == self.song().master_track))
176+
self.send_default('/live/'+self._track_types[self._type]+'volume', self._track.mixer_device.volume.value)
177+
178+
@subject_slot('value')
179+
def _on_panning_changed(self):
180+
self.send_default('/live/'+self._track_types[self._type]+'panning', self._track.mixer_device.panning.value)
181+
182+
183+
184+
185+
# Callbacks
186+
def _lo2__on_mute_changed(self):
187+
self.log_message('mute track type ' + str(self._type) + ' ' + str(self) + str(self._track))
188+
if self._type < 2 and self._type is not None:
189+
self.send_default('/live/'+self._track_types[self._type]+'mute', self._track.mute)
190+
191+
def _lo2__on_solo_changed(self):
192+
if self._type < 2 and self._type is not None:
193+
self.send_default('/live/'+self._track_types[self._type]+'solo', self._track.solo)
194+
195+
def _lo2__on_arm_changed(self):
196+
if self._type == 0 and self._type is not None:
197+
self.send_default('/live/'+self._track_types[self._type]+'arm', self._track.arm)
198+
199+
def _lo2__on_track_name_changed(self):
200+
self.send_default('/live/'+self._track_types[self._type]+'name', self._track.name)
201+
202+
203+
@subject_slot('color')
204+
def _on_track_color_changed(self):
205+
self.send_default('/live/'+self._track_types[self._type]+'color', self._track.color)
206+
207+
208+
@subject_slot('playing_slot_index')
209+
def _on_track_state_changed(self):
210+
self.send_default('/live/track/state', self._track.playing_slot_index)
211+
212+
213+
214+
#@with_track
215+
def _device_list(self, msg, src):
216+
if self._is_track(msg) and self._track is not None:
217+
self._send_device_list()
218+
219+
220+
def _send_device_list(self):
221+
devices = []
222+
for i,d in enumerate(self._track.devices):
223+
devices.append(i)
224+
devices.append(d.name)
225+
226+
if self._type == 2:
227+
self.send('/live/'+self._track_types[self._type]+'devices', *devices)
228+
else:
229+
self.send_default('/live/'+self._track_types[self._type]+'devices', *devices)
230+
231+
232+
def _stop(self, msg, src):
233+
if self._track is not None and self._is_track(msg):
234+
self._track.stop_all_clips()
235+
236+
237+
def _track_state(self, msg, src):
238+
if self._is_track(msg):
239+
self._on_track_state_changed()
240+
241+
242+
def _view(self, msg, src):
243+
if self._is_track(msg) and self._track is not None:
244+
self.song().view.selected_track = self._track
245+
246+
247+
def _crossfader(self, msg, src):
248+
if self._is_track(msg) and self._track is not None:
249+
# Master
250+
if self._type == 2:
251+
self._track.mixer_device.crossfader.value = msg[1]
252+
253+
# Assign xfader
254+
else:
255+

0 commit comments

Comments
 (0)