annotate light8/Fader.py @ 53:032b2b67bc10

result of July 7th on-site editing
author dmcc
date Mon, 08 Jul 2002 14:31:20 +0000
parents 065896b0913c
children 3011c1028eb7
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
1 from Tix import *
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
2 from time import time # time is on my side
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
3 from util import subsetdict
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
4 from FlyingFader import FlyingFader
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
5
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
6 # statuses are:
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
7 # stopped - no cue is loaded or cue is stopped
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
8 # running - cue is running, not complete
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
9 # finished - cue is finished, next is loaded
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
10
45b12307c695 Initial revision
drewp
parents:
diff changeset
11 stdfont = ('Arial', 10)
45b12307c695 Initial revision
drewp
parents:
diff changeset
12
45b12307c695 Initial revision
drewp
parents:
diff changeset
13 class Fader(Frame):
45b12307c695 Initial revision
drewp
parents:
diff changeset
14 'User interface for cue fader'
45b12307c695 Initial revision
drewp
parents:
diff changeset
15 def __init__(self, master, cues, scalelevels):
45b12307c695 Initial revision
drewp
parents:
diff changeset
16 self.master = master
45b12307c695 Initial revision
drewp
parents:
diff changeset
17 self.cues = cues
45b12307c695 Initial revision
drewp
parents:
diff changeset
18 self.scalelevels = scalelevels
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
19 self.time_start = 0
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
20 self.init_layout()
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
21 self.stop()
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
22 def init_layout(self):
45b12307c695 Initial revision
drewp
parents:
diff changeset
23 Frame.__init__(self, self.master)
45b12307c695 Initial revision
drewp
parents:
diff changeset
24
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
25 # info variables
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
26 self.cuename = StringVar()
45b12307c695 Initial revision
drewp
parents:
diff changeset
27 self.cuelength = DoubleVar()
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
28 self.cuetarget = StringVar()
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
29
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
30 # info about a running cue
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
31 self.cuestatus = StringVar() # text description
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
32 self.cuestatus.set("stopped")
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
33
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
34 self.cuepercent = DoubleVar() # percent complete
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
35 self.cuepercent.set(0)
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
36 self.cuepercent.trace('w', self.update_percent)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
37 self.cuetimeelapse = StringVar() # time elapsed
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
38 self.cuetimeelapse.set('0s')
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
39 self.cuetimeleft = StringVar() # time left
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
40 self.cuetimeleft.set('0s')
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
41
45b12307c695 Initial revision
drewp
parents:
diff changeset
42 buttonframe = Frame(self)
45b12307c695 Initial revision
drewp
parents:
diff changeset
43
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
44 self.listbox = ScrolledListBox(buttonframe,
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
45 command=self.update_selection)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
46 self.listbox.listbox.configure({'exportselection' : 0,
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
47 'selectmode' : EXTENDED})
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
48 for c in self.cues:
45b12307c695 Initial revision
drewp
parents:
diff changeset
49 self.listbox.listbox.insert(END, c.name)
51
71489bb71528 - Meet Fader. He is going to grow up and be a crossfader some day
dmcc
parents: 0
diff changeset
50 self.listbox.pack(side=TOP)
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
51 self.listbox.listbox.bind("<<ListboxSelect>>", self.update_selection,
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
52 add=1)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
53 Button(buttonframe, text="Go", command=self.go, font=stdfont,
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
54 bg='green').pack(side=LEFT)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
55 Button(buttonframe, text="Stop", command=self.stop, font=stdfont,
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
56 bg='red').pack(side=LEFT)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
57 Button(buttonframe, text="Prev", command=self.prev,
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
58 font=stdfont).pack(side=LEFT)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
59 Button(buttonframe, text="Next", command=self.next,
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
60 font=stdfont).pack(side=LEFT)
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
61
51
71489bb71528 - Meet Fader. He is going to grow up and be a crossfader some day
dmcc
parents: 0
diff changeset
62 infoframe = Frame(self)
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
63 Label(infoframe, textvariable=self.cuename,
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
64 font=('Arial', 12), bg='lightBlue').grid(columnspan=4, sticky=NE+SW)
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
65
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
66 Label(infoframe, text="Length", font=stdfont,
45b12307c695 Initial revision
drewp
parents:
diff changeset
67 bg='lightPink').grid(row=1, sticky=NE+SW)
45b12307c695 Initial revision
drewp
parents:
diff changeset
68 Label(infoframe, textvariable=self.cuelength,
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
69 font=stdfont).grid(row=1, column=1, columnspan=3, sticky=NE+SW)
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
70
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
71 Label(infoframe, text="Target", font=stdfont,
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
72 bg='lightPink', wraplength=50).grid(row=2, sticky=NE+SW)
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
73 Label(infoframe, textvariable=self.cuetarget,
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
74 font=stdfont).grid(row=2, column=1, columnspan=3, sticky=NE+SW)
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
75
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
76 Label(infoframe, text="Status", font=stdfont,
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
77 bg='lightPink').grid(row=3, sticky=NE+SW)
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
78 Label(infoframe, textvariable=self.cuestatus,
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
79 font=stdfont).grid(row=3, column=1, columnspan=3, sticky=NE+SW)
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
80
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
81 Label(infoframe, text="Time Elapsed", font=stdfont,
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
82 bg='lightPink').grid(row=4, sticky=NE+SW)
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
83 Label(infoframe, textvariable=self.cuetimeelapse,
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
84 font=stdfont).grid(row=4, column=1, sticky=NE+SW)
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
85
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
86 Label(infoframe, text="Time Remain", font=stdfont,
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
87 bg='lightPink').grid(row=4, column=2, sticky=NE+SW)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
88 Label(infoframe, textvariable=self.cuetimeleft,
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
89 font=stdfont).grid(row=4, column=3, sticky=NE+SW)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
90
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
91 Label(infoframe, text="Percent Complete", font=stdfont,
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
92 bg='lightPink').grid(row=5, column=0, sticky=NE+SW)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
93 self.percentlabel = Label(infoframe,
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
94 font=stdfont)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
95 self.percentlabel.grid(row=5, column=1, columnspan=3, sticky=NE+SW)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
96
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
97 s = Scale(infoframe, variable=self.cuepercent,
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
98 showvalue=0, length=220,
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
99 width=18, sliderlength=30,
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
100 to=100,res=.1,from_=0,bd=1, font=stdfont,
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
101 orient='horiz')
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
102 s.grid(row=6, columnspan=4, sticky='ew')
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
103
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
104 infoframe.pack(side=RIGHT, fill=BOTH, expand=1)
51
71489bb71528 - Meet Fader. He is going to grow up and be a crossfader some day
dmcc
parents: 0
diff changeset
105 buttonframe.pack(side=BOTTOM)
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
106
45b12307c695 Initial revision
drewp
parents:
diff changeset
107 self.listbox.listbox.select_set(0)
45b12307c695 Initial revision
drewp
parents:
diff changeset
108 self.update_selection()
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
109 def update_percent(self, *args):
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
110 if self.cuestatus.get() != 'running':
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
111 self.cuestatus.set("running")
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
112 self.time_start = time()
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
113 startlevels = dict([(k, v.get())
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
114 for k, v in self.scalelevels.items()])
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
115 self.current.start(startlevels, self.time_start)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
116
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
117 percent = self.cuepercent.get()
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
118 self.percentlabel.config(text='%.1f%%' % percent)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
119 percent /= 100
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
120
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
121 elapsed = percent * self.current.dur
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
122 self.cuetimeelapse.set('%.1fs' % elapsed)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
123 self.cuetimeleft.set('%.1fs' % (self.current.dur - elapsed))
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
124 newlevels = self.current.get_levels(self.time_start + elapsed)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
125 for ch, lev in newlevels.items():
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
126 try:
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
127 self.scalelevels[ch].set(lev / 100.0)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
128 except KeyError:
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
129 pass
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
130
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
131 def update_selection(self, *args):
51
71489bb71528 - Meet Fader. He is going to grow up and be a crossfader some day
dmcc
parents: 0
diff changeset
132 selection = int(self.listbox.listbox.curselection()[0]) # blech
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
133 self.current = self.cues[selection]
45b12307c695 Initial revision
drewp
parents:
diff changeset
134 self.cuename.set(self.current.name)
45b12307c695 Initial revision
drewp
parents:
diff changeset
135 self.cuelength.set(self.current.dur)
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
136 target = ', '.join(['%s -> %.1f' % (n, lev)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
137 for n, lev in self.current.get_end_levels().items()])
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
138 self.cuetarget.set(target)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
139 self.cuetimeelapse.set('0s')
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
140 self.cuetimeleft.set('%.1fs' % self.current.dur)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
141 self.cuepercent.set(0)
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
142 def go(self):
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
143 self.update_selection()
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
144 self.cuestatus.set("running")
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
145 self.time_start = time()
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
146 startlevels = dict([(k, v.get()) for k, v in self.scalelevels.items()])
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
147 self.current.start(startlevels, self.time_start)
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
148 self.running_loop()
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
149 def stop(self):
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
150 self.cuestatus.set('stopped')
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
151 def prev(self):
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
152 self.cuestatus.set('stopped')
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
153 selection = int(self.listbox.listbox.curselection()[0]) # blech
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
154 if selection != 0:
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
155 self.listbox.listbox.select_clear(selection)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
156 self.listbox.listbox.select_set(selection - 1)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
157 self.update_selection()
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
158 def next(self):
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
159 self.cuestatus.set('stopped')
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
160 selection = int(self.listbox.listbox.curselection()[0]) # blech
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
161 if selection != self.listbox.listbox.size() - 1:
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
162 self.listbox.listbox.select_clear(selection)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
163 self.listbox.listbox.select_set(selection + 1)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
164 self.update_selection()
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
165 def running_loop(self):
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
166 if self.cuestatus.get() == 'stopped':
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
167 return
53
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
168 curtime = time()
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
169 elapsed = (curtime - self.time_start)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
170 if elapsed > self.current.dur:
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
171 self.cuestatus.set('finished')
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
172 self.cuepercent.set(100)
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
173
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
174 # advance cues if okay
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
175 self.next()
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
176 return
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
177
032b2b67bc10 result of July 7th on-site editing
dmcc
parents: 52
diff changeset
178 self.cuepercent.set(100 * elapsed / self.current.dur)
52
065896b0913c emergency commit
dmcc
parents: 51
diff changeset
179 self.after(30, self.running_loop)