Changeset - 233fe8cefa36
[Not reviewed]
default
0 2 0
dmcc - 22 years ago 2002-07-12 10:38:25

ExtSliderMapping moved to new file
2 files changed with 7 insertions and 150 deletions:
0 comments (0 inline, 0 general)
light8/Lightboard.py
Show inline comments
 
from __future__ import nested_scopes
 

	
 
from Tix import *
 
from signal import signal, SIGINT
 
import sys, cPickle, random
 

	
 
from uihelpers import *
 
from panels import *
 
from Xfader import *
 
from subediting import Subediting
 
from Fader import Fader
 
import io, stage, Subs, Patch, ExternalInput
 
from ExternalInput import ExternalSliders
 
import io, stage, Subs, Patch, ExtSliderMapper
 

	
 
class Pickles:
 
    def __init__(self, scalelevels, subs=None, windowpos=None):
 
        self.scalelevels = dict([(name, lev.get()) 
 
            for name, lev in scalelevels.items()])
 
        self.substate = dict([(name, subobj.get_state())
 
            for name, subobj in subs])
 
        self.windowpos = windowpos
 

	
 
class Lightboard:
 
    def __init__(self, master, parportdmx, DUMMY):
 
        self.master = master
 
        self.parportdmx = parportdmx
 
        self.DUMMY = DUMMY
 
        self.jostle_mode = 0
 

	
 
        self.channel_levels = []
 
        self.scalelevels = {}
 
        # doesn't draw any UI yet-- look for self.xfader.setupwidget()
 
        self.xfader = Xfader(self.scalelevels) 
 
        self.oldlevels = [None] * 68 # never replace this; just clear it
 
        self.subediting = Subediting(currentoutputlevels=self.oldlevels)
 

	
 
        self.windowpos = 0
 
        self.get_data()
 
        self.buildinterface()
 
        self.load()
 
        self.backgroundloop()
 
        self.updatestagelevels()
 
        
 
    def buildinterface(self):
 
        for w in self.master.winfo_children():
 
            w.destroy()
 

	
 
        stage_tl = toplevelat('stage')
 
        s = stage.Stage(stage_tl)
 
        stage.createlights(s)
 
        s.setsubediting(self.subediting)
 
        s.pack()
 
        self.stage = s # save it
 

	
 
        sub_tl = toplevelat('sub')
 
        scene_tl = toplevelat('scenes')
 
        effect_tl = toplevelat('effect')
 

	
 
        mapping_tl = toplevelat('mapping')
 
        self.slidermapper = ExtSliderMapper(mapping_tl, self.scalelevels, 
 
                ExternalInput.ExternalSliders())
 
        self.slidermapper = ExtSliderMapper.ExtSliderMapper(mapping_tl, 
 
                                                            self.scalelevels, 
 
                                                            ExternalSliders())
 
        self.slidermapper.pack()
 

	
 
        self.subpanels = Subpanels(sub_tl, effect_tl, scene_tl, self, self.scalelevels,
 
                                   Subs, self.xfader, self.changelevel,
 
                                   self.subediting, Subs.longestsubname())
 

	
 
        leveldisplay_tl = toplevelat('leveldisplay')
 
        leveldisplay_tl.bind('<Escape>', sys.exit)
 

	
 
        self.leveldisplay = Leveldisplay(leveldisplay_tl, self.channel_levels)
 
        for i in range(0,len(self.channel_levels)):
 
            self.channel_levels[i].config(text=self.oldlevels[i])
 
            colorlabel(self.channel_levels[i])
 

	
 
        Console(self)
 

	
 
        # root frame
 
        controlpanel = Controlpanel(self.master, self.xfader, self.refresh, 
 
            self.quit, self.toggle_jostle)
 
        
 
        xf=Frame(self.master)
 
        xf.pack(side='right')
 

	
 
        self.master.bind('<q>', self.quit)
 
@@ -135,49 +137,50 @@ class Lightboard:
 
        else:
 
            filename = 'Config.py'
 
        f = open(filename, 'a')
 
        f.write(st)
 
        f.close()
 
        print 'Added sub:', st
 
        if refresh:
 
            self.refresh()
 

	
 
    # this is called on a loop, and ALSO by the Scales
 
    def changelevel(self, *args):
 
        'Amp trims slider'
 

	
 
        levels = [0] * 68
 
        for name, s in Subs.subs.items():
 
            newlevels = s.get_levels(level=self.scalelevels[name].get())
 
            for (ch, fadelev) in newlevels.items():
 
                levels[ch-1] = max(levels[ch-1], fadelev)
 

	
 
        levels = [int(l) for l in levels]
 

	
 
        # load levels from external sliders
 
        extlevels = self.slidermapper.get_levels()
 
        for name, val in extlevels.items():
 
            self.scalelevels[name].set(val)
 
            if name in self.scalelevels:
 
                self.scalelevels[name].set(val)
 
        
 
        for lev,lab,oldlev,numlab in zip(levels, self.channel_levels, 
 
                                         self.oldlevels, 
 
                                         self.leveldisplay.number_labels):
 
            if lev != oldlev:
 
                lab.config(text="%d" % lev) # update labels in lev display
 
                colorlabel(lab)             # recolor labels
 
                if lev < oldlev:
 
                    numlab['bg'] = 'blue'
 
                else:
 
                    numlab['bg'] = 'red'
 
            else:
 
                numlab['bg'] = 'lightPink'
 

	
 
        self.oldlevels[:] = levels[:] # replace the elements in oldlevels - don't make a new list (Subediting is watching it)
 
            
 
        if self.jostle_mode:
 
            delta = random.randrange(-1, 2, 1) # (-1, 0, or 1)
 
            # print "delta", delta
 
            levels = [min(100, max(x + delta, 0)) for x in levels]
 
            # print "jostled", levels
 

	
 
        self.parportdmx.sendlevels(levels)
 

	
light8/panels.py
Show inline comments
 
@@ -58,184 +58,48 @@ class Leveldisplay:
 
            f = Frame(frames[channel > (num_channels/2)])
 
            # channel number -- will turn yellow when being altered
 
            num_lab = Label(f, text=str(channel), width=3, bg='lightPink', 
 
                font=stdfont, padx=0, pady=0, bd=0, height=1)
 
            num_lab.pack(side='left')
 
            self.number_labels.append(num_lab)
 

	
 
            # text description of channel
 
            Label(f, text=Patch.get_channel_name(channel), width=8, 
 
                font=stdfont, anchor='w', padx=0, pady=0, bd=0, 
 
                height=1).pack(side='left')
 

	
 
            # current level of channel, shows intensity with color
 
            l = Label(f, width=3, bg='lightBlue', font=stdfont, anchor='e', 
 
                      padx=1, pady=0, bd=0, height=1)
 
            l.pack(side='left')
 
            colorlabel(l)
 
            channel_levels.append(l)
 
            f.pack(side='top')
 

	
 
        self.channel_levels = channel_levels
 
        # channel_levels is an output - changelevel will use it to access 
 
        # these labels
 

	
 
class ExtSliderMapper(Frame):
 
    def __init__(self, parent, sliderlevels, sliderinput, filename='slidermapping',
 
                 numsliders=4):
 
        'Slider levels is scalelevels, sliderinput is an ExternalInput object'
 
        Frame.__init__(self, parent)
 
        self.parent = parent
 
        self.sliderlevels = sliderlevels
 
        self.sliderinput = sliderinput
 
        self.filename = filename
 
        self.numsliders = numsliders
 
        self.file = None
 

	
 
        # self.setup()
 
    def setup(self):
 
        self.subnames = self.sliderlevels.keys()
 
        self.subnames.sort()
 
        self.presets = {}
 
        self.load_presets()
 

	
 
        self.current_mapping_name = StringVar()
 
        self.current_mapping = []
 
        self.attached = []
 
        self.levels_read = []
 
        for i in range(self.numsliders):
 
            self.current_mapping.append(StringVar())
 
            self.attached.append(BooleanVar())
 
            self.levels_read.append(DoubleVar())
 

	
 
        self.reallevellabels = []
 
        self.draw_interface()
 
    def load_presets(self):
 
        self.file = open(self.filename, 'r')
 
        lines = self.file.readlines()
 
        for l in lines:
 
            tokens = l[:-1].split('\t')
 
            name = tokens.pop(0)
 
            self.presets[name] = tokens
 
        self.file.close()
 
    def save_presets(self):
 
        self.file = open(self.filename, 'w')
 
        self.file.seek(0)
 
        preset_names = self.presets.keys()
 
        preset_names.sort()
 
        for p in preset_names:
 
            s = '\t'.join([p] + self.presets[p]) + '\n'
 
            self.file.write(s)
 
        self.file.close()
 
    def load_scalelevels(self):
 
        for m, rll in zip(self.current_mapping, self.reallevellabels):
 
            try:
 
                v = self.sliderlevels[m.get()]
 
                rll.configure(textvariable=v)
 
            except KeyError:
 
                pass
 
                
 
    def get_levels(self):
 
        'To be called by changelevels, I think'
 
        if not self.current_mapping_name: return {}
 
        if not self.sliderinput: return {}
 

	
 
        self.load_scalelevels()
 

	
 
        rawlevels = self.sliderinput.get_levels()
 
        for rawlev, levlabvar in zip(rawlevels, self.levels_read):
 
            levlabvar.set(rawlev)
 
        outputlevels = {}
 
        return dict([(name.get(), lev) 
 
            for name, lev, att in zip(self.current_mapping, 
 
                                      rawlevels, 
 
                                      self.attached) 
 
            if att.get()])
 

	
 
    def draw_interface(self):
 
        self.reallevellabels = []
 
        subchoiceframe = Frame(self)
 
        for i, mapping, isattached, lev in zip(range(self.numsliders), 
 
                                               self.current_mapping, 
 
                                               self.attached,
 
                                               self.levels_read):
 
            f = Frame(subchoiceframe)
 
            # Label(f, text="Slider %d" % (i+1)).pack(side=LEFT)
 
            c = ComboBox(f, variable=mapping)
 
            for s in self.subnames:
 
                c.slistbox.listbox.insert(END, s)
 
            c.entry.configure(width=12)
 
            statframe = Frame(f)
 
            Checkbutton(statframe, variable=isattached, 
 
                text="Attached").grid(columnspan=2, sticky=W)
 
            Label(statframe, text="Input", fg='red').grid(row=1, sticky=W)
 
            Label(statframe, textvariable=lev, fg='red', width=5).grid(row=1, column=1)
 
            Label(statframe, text="Real").grid(row=2, sticky=W)
 
            l = Label(statframe, text="N/A", width=5)
 
            l.grid(row=2, column=1)
 
            self.reallevellabels.append(l)
 
            statframe.pack(side=BOTTOM, expand=1, fill=X)
 
            c.pack()
 
            f.pack(side=LEFT)
 
        subchoiceframe.pack()
 
        
 
        presetframe = Frame(self)
 
        Label(presetframe, text="Preset:").pack(side=LEFT)
 
        self.presetcombo = ComboBox(presetframe, variable=self.current_mapping_name, 
 
                                    editable=1, command=self.apply_preset)
 
        self.draw_presets()
 
        self.presetcombo.pack(side=LEFT)
 
        Button(presetframe, text="Add", padx=0, pady=0, 
 
                command=self.add_preset).pack(side=LEFT)
 
        Button(presetframe, text="Delete", padx=0, pady=0, 
 
                command=self.delete_preset).pack(side=LEFT)
 
        presetframe.pack(side=BOTTOM)
 
    def apply_preset(self, preset):
 
        if not preset: return
 
        mapping = self.presets.get(preset)
 
        if not mapping: return
 
        for name, var, att in zip(mapping, self.current_mapping, self.attached):
 
            var.set(name)
 
            att.set(0) # detach all sliders
 
    def delete_preset(self, *args):
 
        del self.presets[self.current_mapping_name.get()]
 
        self.presetcombo.slistbox.listbox.delete(0, END)
 
        self.draw_presets()
 
        self.save_presets()
 
    def add_preset(self, *args):
 
        self.presets[self.current_mapping_name.get()] = [m.get() 
 
                for m in self.current_mapping]
 
        self.presetcombo.slistbox.listbox.delete(0, END)
 
        self.draw_presets()
 
        self.save_presets()
 
    def draw_presets(self):
 
        preset_names = self.presets.keys()
 
        preset_names.sort()
 
        for p in preset_names:
 
            self.presetcombo.slistbox.listbox.insert(END, p)
 

	
 
                
 

	
 
class Subpanels:
 
    def __init__(self, scenesparent, effectsparent, scenes, lightboard,
 
                 scalelevels, Subs, xfader,
 
                 changelevel, subediting, longestname):
 
        
 
        sublist = Subs.subs.items()
 
        sublist.sort()
 

	
 
        for p in scenesparent,effectsparent,scenes:
 
            sw = ScrolledWindow(p)
 
            for but,units in ( (4,-4),(5,4) ):
 
                sw.window.bind("<ButtonPress-%s>"%but,lambda ev,s=sw.vsb,u=units: s.tk.call('tkScrollByUnits',s,'hv',u))
 

	
 
            sw.pack(expand=1,fill=BOTH)
 
            if p==scenesparent:
 
                scenesparent = sw.window
 
            elif p==effectsparent:
 
                effectsparent = sw.window
 
            else:
 
                scenes=sw.window
 

	
 
        for name, sub in sublist:
 
            # choose one of the sub panels to add to
 
            if sub.is_effect:
 
@@ -307,34 +171,24 @@ class Subpanels:
 
    def subediting_edit(self,subediting,sub):
 
        subediting.setsub(sub)
 
        
 
    def subediting_save(self,name,sub,lightboard):
 
        lightboard.save_sub(name,sub.getlevels(),refresh=0)
 
        
 
    def subeditingbuttons(self,f,side1,sub,name,lightboard,subediting):
 
        for txt,cmd in (("Edit",lambda subediting=subediting,sub=sub: self.subediting_edit(subediting,sub)),
 
                        ("Save",lambda sub=sub,name=name,lightboard=lightboard: self.subediting_save(name,sub,lightboard)),
 
                        ("SaveStg",lambda l=lightboard,name=name: l.save_sub(name,l.stageassub(),refresh=1)),
 
                        ):
 
            eb = Button(f,text=txt,font=stdfont,padx=0,pady=0,
 
                        bd=1,command=cmd)
 
            eb.pack(side=side1,fill='both',padx=0,pady=0)
 
            
 
    def axisbuttons(self,f,s,xfader,stdfont,side1,name):
 
        for axis in ('y','x'):
 
            cvar=IntVar()
 
            eb_color = ('red', 'green')[axis == 'y']
 
            cb=Togglebutton(f,text=axis.upper(),variable=cvar,font=stdfont, 
 
                            padx=3, pady=0, bd=1, downcolor=eb_color)
 
            cb.pack(side=side1,fill='both', padx=0, pady=0)
 
            s.bind('<Key-%s>'%axis, lambda ev,cb=cb: cb.invoke)
 
            xfader.registerbutton(name,axis,cvar)
 

	
 
                    
 
if __name__ == '__main__':
 
    print "testing external sliders"
 
    root = Tk()
 
    fakesliderlevels = dict([('sub%d' % n, DoubleVar()) for n in range(12)])
 
    esm = ExtSliderMapper(root, fakesliderlevels, None)
 
    esm.pack()
 
    
 
    mainloop()
0 comments (0 inline, 0 general)