Mercurial > code > home > repos > light9
annotate light8/ExtSliderMapper.py @ 98:57319ec2bfad
tracing etc seems to work
author | drewp |
---|---|
date | Sat, 13 Jul 2002 04:26:59 +0000 |
parents | d1a1ded20ec7 |
children | 7910445b81e3 |
rev | line source |
---|---|
80 | 1 """some more of the panels""" |
0 | 2 from Tix import * |
3 | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
4 class SliderMapping: |
92 | 5 def __init__(self, default='disconnected', synced=0, extinputlevel=0, |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
6 sublevel=0): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
7 self.subname = StringVar() # name of submaster we're connected to |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
8 self.subname.set(default) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
9 self.sublevel = DoubleVar() # scalelevel variable of that submaster |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
10 self.sublevel.set(sublevel) |
92 | 11 self.synced = BooleanVar() # currently synced |
12 self.synced.set(synced) | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
13 self.extlevel = DoubleVar() # external slider's input |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
14 self.extlevel.set(extinputlevel) |
87 | 15 self.widgets = [] # list of widgets drawn |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
16 self.sublabel = None # the label which represents a sub level. |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
17 # we hold on to it so we can change its |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
18 # textvariable |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
19 self.statuslabel = None # tells us sync status |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
20 self.lastbgcolor = None # last background color drawn to avoid |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
21 # unnecessary redraws |
92 | 22 def sync(self, *args): |
23 self.synced.set(1) | |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
24 self.color_bg() |
92 | 25 def unsync(self, *args): |
26 self.synced.set(0) | |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
27 self.color_bg() |
92 | 28 def issynced(self): |
29 return self.synced.get() | |
30 def disconnect(self, *args): | |
31 self.set_subname('disconnected') # a bit hack-like | |
32 self.sublabel.configure(text="N/A") | |
33 self.color_bg() | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
34 def isdisconnected(self): |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
35 return self.subname.get() == 'disconnected' # a bit more hack-like |
92 | 36 def check_synced(self, *args): |
37 'If external level is near than the sublevel, it synces' | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
38 if self.isdisconnected(): |
92 | 39 self.unsync() |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
40 return |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
41 |
92 | 42 if abs(self.extlevel.get() - self.sublevel.get()) <= 0.02: |
43 self.sync() | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
44 def changed_extinput(self, newlevel): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
45 'When a new external level is received, this incorporates it' |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
46 self.extlevel.set(newlevel) |
92 | 47 self.check_synced() |
48 self.color_bg() | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
49 def set_subname(self, newname): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
50 self.subname.set(newname) |
92 | 51 self.unsync() |
52 self.color_bg() | |
53 def color_bg(self): | |
87 | 54 if self.widgets: |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
55 if self.isdisconnected(): |
87 | 56 color = 'honeyDew4' |
96 | 57 # elif self.issynced(): |
58 # stupid hack | |
59 elif abs(self.extlevel.get() - self.sublevel.get()) <= 0.02: | |
87 | 60 color = 'honeyDew2' |
92 | 61 else: # unsynced |
87 | 62 color = 'red' |
63 | |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
64 if self.statuslabel: |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
65 if color == 'honeyDew2': # connected |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
66 self.statuslabel['text'] = 'Sync' |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
67 else: |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
68 self.statuslabel['text'] = 'No sync' |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
69 |
92 | 70 # print "color", color, "lastbgcolor", self.lastbgcolor |
87 | 71 if self.lastbgcolor == color: return |
72 for widget in self.widgets: | |
73 widget.configure(bg=color) | |
74 self.lastbgcolor = color | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
75 def set_sublevel_var(self, newvar): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
76 'newvar is one of the variables in scalelevels' |
98 | 77 |
78 if newvar is not self.sublevel: | |
79 try: | |
80 # remove an old trace | |
81 self.sublevel.trace_vdelete('w',self.sublevel.unsync_trace_cbname) | |
82 except AttributeError: | |
83 pass # it didn't have one | |
84 | |
85 self.sublevel = newvar | |
86 self.sublevel.unsync_trace_cbname = self.sublevel.trace('w', self.unsync) | |
87 | |
88 # self.sublevel = newvar | |
89 | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
90 if self.sublabel: |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
91 self.sublabel.configure(textvariable=newvar) |
92 | 92 self.check_synced() |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
93 def get_mapping(self): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
94 'Get name of submaster currently mapped' |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
95 return self.subname.get() |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
96 def get_level_pair(self): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
97 'Returns suitable output for ExtSliderMapper.get_levels()' |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
98 return (self.subname.get(), self.extlevel.get()) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
99 def draw_interface(self, master, subnames): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
100 'Draw interface into master, given a list of submaster names' |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
101 frame = Frame(master) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
102 c = ComboBox(frame, variable=self.subname) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
103 c.slistbox.listbox.insert(END, "disconnected") |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
104 for s in subnames: |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
105 c.slistbox.listbox.insert(END, s) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
106 c.entry.configure(width=12) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
107 statframe = Frame(frame) |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
108 |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
109 ''' |
92 | 110 cb = Checkbutton(statframe, variable=self.synced, |
111 text="Synced") | |
87 | 112 cb.grid(columnspan=2, sticky=W) |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
113 ''' |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
114 self.statuslabel = Label(statframe, text="No sync") |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
115 self.statuslabel.grid(columnspan=2, sticky=W) |
87 | 116 ilabel = Label(statframe, text="Input", fg='blue') |
117 ilabel.grid(row=1, sticky=W) | |
118 extlabel = Label(statframe, textvariable=self.extlevel, width=5) | |
119 extlabel.grid(row=1, column=1) | |
120 rlabel = Label(statframe, text="Real") | |
121 rlabel.grid(row=2, sticky=W) | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
122 self.sublabel = Label(statframe, text="N/A", width=5) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
123 self.sublabel.grid(row=2, column=1) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
124 statframe.pack(side=BOTTOM, expand=1, fill=X) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
125 c.pack() |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
126 frame.pack(side=LEFT, expand=1, fill=BOTH) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
127 |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
128 self.widgets = [frame, c, statframe, self.statuslabel, ilabel, extlabel, |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
129 rlabel, self.sublabel] |
87 | 130 |
0 | 131 class ExtSliderMapper(Frame): |
80 | 132 def __init__(self, parent, sliderlevels, sliderinput, filename='slidermapping', |
133 numsliders=4): | |
0 | 134 'Slider levels is scalelevels, sliderinput is an ExternalInput object' |
80 | 135 Frame.__init__(self, parent) |
0 | 136 self.parent = parent |
137 self.sliderlevels = sliderlevels | |
138 self.sliderinput = sliderinput | |
139 self.filename = filename | |
140 self.numsliders = numsliders | |
141 self.file = None | |
142 | |
143 # don't call setup, let them do that when scalelevels is created | |
144 def setup(self): | |
145 self.subnames = self.sliderlevels.keys() | |
146 self.subnames.sort() | |
147 self.presets = {} | |
148 self.load_presets() | |
149 | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
150 self.current_preset = StringVar() # name of current preset |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
151 self.current_mappings = [] |
80 | 152 for i in range(self.numsliders): |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
153 self.current_mappings.append(SliderMapping()) |
0 | 154 |
155 self.draw_interface() | |
80 | 156 def load_presets(self): |
0 | 157 self.file = open(self.filename, 'r') |
158 lines = self.file.readlines() | |
159 for l in lines: | |
160 tokens = l[:-1].split('\t') | |
161 name = tokens.pop(0) | |
162 self.presets[name] = tokens | |
163 self.file.close() | |
164 def save_presets(self): | |
165 self.file = open(self.filename, 'w') | |
166 self.file.seek(0) | |
167 preset_names = self.presets.keys() | |
168 preset_names.sort() | |
169 for p in preset_names: | |
170 s = '\t'.join([p] + self.presets[p]) + '\n' | |
171 self.file.write(s) | |
172 self.file.close() | |
173 def load_scalelevels(self): | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
174 for slidermap in self.current_mappings: |
0 | 175 try: |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
176 v = self.sliderlevels[slidermap.get_mapping()] |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
177 slidermap.set_sublevel_var(v) |
0 | 178 except KeyError: |
80 | 179 pass |
0 | 180 |
181 def get_levels(self): | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
182 'Called by changelevels, returns a dict of new values for submasters' |
0 | 183 if not self.sliderinput: return {} |
184 | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
185 self.load_scalelevels() # freshen our input from the physical sliders |
0 | 186 |
187 rawlevels = self.sliderinput.get_levels() | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
188 for rawlev, slidermap in zip(rawlevels, self.current_mappings): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
189 slidermap.changed_extinput(rawlev) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
190 |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
191 ''' |
80 | 192 outputlevels = {} |
92 | 193 for m in self.current_mappings: |
194 if m.issynced(): | |
195 k, v = m.get_level_pair() | |
196 outputlevels[k] = v | |
197 m.ignorenextunync() | |
198 return outputlevels | |
199 ''' | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
200 return dict([m.get_level_pair() |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
201 for m in self.current_mappings |
92 | 202 if m.issynced()]) |
0 | 203 def draw_interface(self): |
80 | 204 self.reallevellabels = [] |
205 subchoiceframe = Frame(self) | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
206 for m in self.current_mappings: |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
207 m.draw_interface(subchoiceframe, self.subnames) |
0 | 208 subchoiceframe.pack() |
209 | |
80 | 210 presetframe = Frame(self) |
211 Label(presetframe, text="Preset:").pack(side=LEFT) | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
212 self.presetcombo = ComboBox(presetframe, variable=self.current_preset, |
80 | 213 editable=1, command=self.apply_preset) |
0 | 214 self.draw_presets() |
215 self.presetcombo.pack(side=LEFT) | |
80 | 216 Button(presetframe, text="Add", padx=0, pady=0, |
0 | 217 command=self.add_preset).pack(side=LEFT) |
80 | 218 Button(presetframe, text="Delete", padx=0, pady=0, |
0 | 219 command=self.delete_preset).pack(side=LEFT) |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
220 Button(presetframe, text="Disconnect", padx=0, pady=0, |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
221 command=self.disconnect_all).pack(side=LEFT) |
0 | 222 presetframe.pack(side=BOTTOM) |
223 def apply_preset(self, preset): | |
224 if not preset: return | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
225 preset_mapping = self.presets.get(preset) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
226 if not preset_mapping: return |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
227 for subname, slidermap in zip(preset_mapping, self.current_mappings): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
228 slidermap.set_subname(subname) |
0 | 229 def delete_preset(self, *args): |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
230 del self.presets[self.current_preset.get()] |
0 | 231 self.presetcombo.slistbox.listbox.delete(0, END) |
232 self.draw_presets() | |
233 self.save_presets() | |
234 def add_preset(self, *args): | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
235 self.presets[self.current_preset.get()] = [m.get_mapping() |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
236 for m in self.current_mappings] |
0 | 237 self.presetcombo.slistbox.listbox.delete(0, END) |
238 self.draw_presets() | |
239 self.save_presets() | |
240 def draw_presets(self): | |
241 preset_names = self.presets.keys() | |
242 preset_names.sort() | |
243 for p in preset_names: | |
244 self.presetcombo.slistbox.listbox.insert(END, p) | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
245 def disconnect_all(self): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
246 for m in self.current_mappings: |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
247 m.disconnect() |