Mercurial > code > home > repos > light9
annotate light8/ExtSliderMapper.py @ 99:7910445b81e3
possible fix
author | dmcc |
---|---|
date | Sat, 13 Jul 2002 04:36:49 +0000 |
parents | 57319ec2bfad |
children | f13cf18224f2 |
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' |
99 | 57 elif self.issynced(): |
96 | 58 # stupid hack |
99 | 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' |
99 | 67 elif self.extlevel.get() < self.sublevel.get(): |
68 self.statuslabel['text'] = 'No sync (go up)' | |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
69 else: |
99 | 70 self.statuslabel['text'] = 'No sync (go down)' |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
71 |
92 | 72 # print "color", color, "lastbgcolor", self.lastbgcolor |
87 | 73 if self.lastbgcolor == color: return |
74 for widget in self.widgets: | |
75 widget.configure(bg=color) | |
76 self.lastbgcolor = color | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
77 def set_sublevel_var(self, newvar): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
78 'newvar is one of the variables in scalelevels' |
98 | 79 |
80 if newvar is not self.sublevel: | |
81 try: | |
82 # remove an old trace | |
83 self.sublevel.trace_vdelete('w',self.sublevel.unsync_trace_cbname) | |
84 except AttributeError: | |
85 pass # it didn't have one | |
86 | |
87 self.sublevel = newvar | |
88 self.sublevel.unsync_trace_cbname = self.sublevel.trace('w', self.unsync) | |
89 | |
90 # self.sublevel = newvar | |
91 | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
92 if self.sublabel: |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
93 self.sublabel.configure(textvariable=newvar) |
92 | 94 self.check_synced() |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
95 def get_mapping(self): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
96 'Get name of submaster currently mapped' |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
97 return self.subname.get() |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
98 def get_level_pair(self): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
99 'Returns suitable output for ExtSliderMapper.get_levels()' |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
100 return (self.subname.get(), self.extlevel.get()) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
101 def draw_interface(self, master, subnames): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
102 'Draw interface into master, given a list of submaster names' |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
103 frame = Frame(master) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
104 c = ComboBox(frame, variable=self.subname) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
105 c.slistbox.listbox.insert(END, "disconnected") |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
106 for s in subnames: |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
107 c.slistbox.listbox.insert(END, s) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
108 c.entry.configure(width=12) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
109 statframe = Frame(frame) |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
110 |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
111 ''' |
92 | 112 cb = Checkbutton(statframe, variable=self.synced, |
113 text="Synced") | |
87 | 114 cb.grid(columnspan=2, sticky=W) |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
115 ''' |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
116 self.statuslabel = Label(statframe, text="No sync") |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
117 self.statuslabel.grid(columnspan=2, sticky=W) |
87 | 118 ilabel = Label(statframe, text="Input", fg='blue') |
119 ilabel.grid(row=1, sticky=W) | |
120 extlabel = Label(statframe, textvariable=self.extlevel, width=5) | |
121 extlabel.grid(row=1, column=1) | |
122 rlabel = Label(statframe, text="Real") | |
123 rlabel.grid(row=2, sticky=W) | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
124 self.sublabel = Label(statframe, text="N/A", width=5) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
125 self.sublabel.grid(row=2, column=1) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
126 statframe.pack(side=BOTTOM, expand=1, fill=X) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
127 c.pack() |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
128 frame.pack(side=LEFT, expand=1, fill=BOTH) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
129 |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
130 self.widgets = [frame, c, statframe, self.statuslabel, ilabel, extlabel, |
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
131 rlabel, self.sublabel] |
87 | 132 |
0 | 133 class ExtSliderMapper(Frame): |
80 | 134 def __init__(self, parent, sliderlevels, sliderinput, filename='slidermapping', |
135 numsliders=4): | |
0 | 136 'Slider levels is scalelevels, sliderinput is an ExternalInput object' |
80 | 137 Frame.__init__(self, parent) |
0 | 138 self.parent = parent |
139 self.sliderlevels = sliderlevels | |
140 self.sliderinput = sliderinput | |
141 self.filename = filename | |
142 self.numsliders = numsliders | |
143 self.file = None | |
144 | |
145 # don't call setup, let them do that when scalelevels is created | |
146 def setup(self): | |
147 self.subnames = self.sliderlevels.keys() | |
148 self.subnames.sort() | |
149 self.presets = {} | |
150 self.load_presets() | |
151 | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
152 self.current_preset = StringVar() # name of current preset |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
153 self.current_mappings = [] |
80 | 154 for i in range(self.numsliders): |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
155 self.current_mappings.append(SliderMapping()) |
0 | 156 |
157 self.draw_interface() | |
80 | 158 def load_presets(self): |
0 | 159 self.file = open(self.filename, 'r') |
160 lines = self.file.readlines() | |
161 for l in lines: | |
162 tokens = l[:-1].split('\t') | |
163 name = tokens.pop(0) | |
164 self.presets[name] = tokens | |
165 self.file.close() | |
166 def save_presets(self): | |
167 self.file = open(self.filename, 'w') | |
168 self.file.seek(0) | |
169 preset_names = self.presets.keys() | |
170 preset_names.sort() | |
171 for p in preset_names: | |
172 s = '\t'.join([p] + self.presets[p]) + '\n' | |
173 self.file.write(s) | |
174 self.file.close() | |
175 def load_scalelevels(self): | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
176 for slidermap in self.current_mappings: |
0 | 177 try: |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
178 v = self.sliderlevels[slidermap.get_mapping()] |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
179 slidermap.set_sublevel_var(v) |
0 | 180 except KeyError: |
80 | 181 pass |
0 | 182 |
183 def get_levels(self): | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
184 'Called by changelevels, returns a dict of new values for submasters' |
0 | 185 if not self.sliderinput: return {} |
186 | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
187 self.load_scalelevels() # freshen our input from the physical sliders |
0 | 188 |
189 rawlevels = self.sliderinput.get_levels() | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
190 for rawlev, slidermap in zip(rawlevels, self.current_mappings): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
191 slidermap.changed_extinput(rawlev) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
192 |
94
29a8b23d8db5
ready for better scalelevel variable, checkbutton -> label
dmcc
parents:
92
diff
changeset
|
193 ''' |
80 | 194 outputlevels = {} |
92 | 195 for m in self.current_mappings: |
196 if m.issynced(): | |
197 k, v = m.get_level_pair() | |
198 outputlevels[k] = v | |
199 m.ignorenextunync() | |
200 return outputlevels | |
201 ''' | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
202 return dict([m.get_level_pair() |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
203 for m in self.current_mappings |
92 | 204 if m.issynced()]) |
0 | 205 def draw_interface(self): |
80 | 206 self.reallevellabels = [] |
207 subchoiceframe = Frame(self) | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
208 for m in self.current_mappings: |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
209 m.draw_interface(subchoiceframe, self.subnames) |
0 | 210 subchoiceframe.pack() |
211 | |
80 | 212 presetframe = Frame(self) |
213 Label(presetframe, text="Preset:").pack(side=LEFT) | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
214 self.presetcombo = ComboBox(presetframe, variable=self.current_preset, |
80 | 215 editable=1, command=self.apply_preset) |
0 | 216 self.draw_presets() |
217 self.presetcombo.pack(side=LEFT) | |
80 | 218 Button(presetframe, text="Add", padx=0, pady=0, |
0 | 219 command=self.add_preset).pack(side=LEFT) |
80 | 220 Button(presetframe, text="Delete", padx=0, pady=0, |
0 | 221 command=self.delete_preset).pack(side=LEFT) |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
222 Button(presetframe, text="Disconnect", padx=0, pady=0, |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
223 command=self.disconnect_all).pack(side=LEFT) |
0 | 224 presetframe.pack(side=BOTTOM) |
225 def apply_preset(self, preset): | |
226 if not preset: return | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
227 preset_mapping = self.presets.get(preset) |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
228 if not preset_mapping: return |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
229 for subname, slidermap in zip(preset_mapping, self.current_mappings): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
230 slidermap.set_subname(subname) |
0 | 231 def delete_preset(self, *args): |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
232 del self.presets[self.current_preset.get()] |
0 | 233 self.presetcombo.slistbox.listbox.delete(0, END) |
234 self.draw_presets() | |
235 self.save_presets() | |
236 def add_preset(self, *args): | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
237 self.presets[self.current_preset.get()] = [m.get_mapping() |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
238 for m in self.current_mappings] |
0 | 239 self.presetcombo.slistbox.listbox.delete(0, END) |
240 self.draw_presets() | |
241 self.save_presets() | |
242 def draw_presets(self): | |
243 preset_names = self.presets.keys() | |
244 preset_names.sort() | |
245 for p in preset_names: | |
246 self.presetcombo.slistbox.listbox.insert(END, p) | |
86
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
247 def disconnect_all(self): |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
248 for m in self.current_mappings: |
5a162150b68d
new slidermappings, extslidermapping modularized and slightly smarter
dmcc
parents:
80
diff
changeset
|
249 m.disconnect() |