Files @ b0342f9ee328
Branch filter:

Location: light9/light8/panels.py - annotation

dmcc
attempts to save params, better loading behavior
45b12307c695
45b12307c695
7adc65771676
45b12307c695
45b12307c695
6284a812da50
45b12307c695
45b12307c695
45b12307c695
45b12307c695
45b12307c695
219d6fcbc28d
7adc65771676
219d6fcbc28d
45b12307c695
45b12307c695
45b12307c695
45b12307c695
45b12307c695
45b12307c695
45b12307c695
7adc65771676
219d6fcbc28d
219d6fcbc28d
45b12307c695
45b12307c695
7adc65771676
7adc65771676
7adc65771676
7adc65771676
7adc65771676
45b12307c695
219d6fcbc28d
219d6fcbc28d
45b12307c695
45b12307c695
7adc65771676
7adc65771676
7adc65771676
45b12307c695
45b12307c695
45b12307c695
7adc65771676
45b12307c695
45b12307c695
219d6fcbc28d
45b12307c695
7dbe8067acea
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
45b12307c695
45b12307c695
45b12307c695
45b12307c695
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
219d6fcbc28d
45b12307c695
45b12307c695
6284a812da50
6284a812da50
45b12307c695
45b12307c695
45b12307c695
45b12307c695
45b12307c695
45b12307c695
45b12307c695
45b12307c695
45b12307c695
45b12307c695
7adc65771676
7adc65771676
45b12307c695
45b12307c695
45b12307c695
45b12307c695
45b12307c695
45b12307c695
7adc65771676
45b12307c695
45b12307c695
6284a812da50
6284a812da50
6284a812da50
6284a812da50
6284a812da50
45b12307c695
7adc65771676
7adc65771676
6284a812da50
6284a812da50
7adc65771676
6284a812da50
7adc65771676
7adc65771676
45b12307c695
768442c7d023
45b12307c695
45b12307c695
45b12307c695
45b12307c695
45b12307c695
"""some of the panels"""

from Tkinter import *
from uihelpers import *
import Patch
from FlyingFader import FlyingFader

stdfont = ('Arial', 8)
monofont = ('Courier', 8)

class Controlpanel(Frame):
    def __init__(self, parent, xfader, refresh_cb, quit_cb):
        Frame.__init__(self,parent)
        controlpanel = self
        for txt,cmd in (
            ('Quit',       quit_cb),
            ('Refresh',    refresh_cb),
            ('Clear all', xfader.clearallbuttons),
            ('On -> X',     lambda: xfader.grab('x')),
            ('Clear X',     lambda: xfader.clearallbuttons('x')),
            ('On -> Y',     lambda: xfader.grab('y')),
            ('Clear Y',     lambda: xfader.clearallbuttons('y'))):
            Button(controlpanel, text=txt, command=cmd).pack(side='top', 
                fill='x')

class Console:
    def __init__(self):
        print "Light 8: Everything's under control"
        t=toplevelat(267,717,w=599,h=19)
        self.frame = Frame(t)
        self.entry=Entry(self.frame)
        self.entry.pack(expand=1, fill='x')
        self.entry.bind('<Return>', lambda evt: self.execute(evt, 
            self.entry.get()))
        self.frame.pack(fill=BOTH, expand=1)
    
    def execute(evt, str):
        if str[0] == '*': # make a new sub
            make_sub(str)
        else:
            print '>>>', str
            print eval(str)
        self.frame.focus()

class Leveldisplay:
    def __init__(self, parent, channel_levels, num_channels=68):
        frames = (make_frame(parent), make_frame(parent))
        channel_levels[:]=[]
        self.number_labels = {}
        for channel in range(1, num_channels+1):

            # frame for this channel
            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[channel] = 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 Subpanels:
    def __init__(self, scenesparent, effectsparent, scalelevels, Subs, xfader,
        changelevel):
        
        sublist = Subs.subs.items()
        sublist.sort()

        for name, sub in sublist:
            if sub.is_effect:
                parent=effectsparent
            else:
                parent=scenesparent

            f=Frame(parent, bd=1, relief='raised')
            f.pack(fill='both',exp=1,side='left')

            if name not in scalelevels:
                scalelevels[name]=DoubleVar()

            sub.set_slider_var(scalelevels[name])

            scaleopts = {}
            if sub.color:
                scaleopts['troughcolor'] = sub.color

            s = FlyingFader(f, label=str(name), variable=scalelevels[name],
                    showvalue=0, length=300-17,
                    width=20, to=0,res=.001,from_=1,bd=1, font=stdfont,
                    **scaleopts)

            for axis in ('y','x'):
                cvar=IntVar()
                cb=Checkbutton(f,text=axis,variable=cvar,font=stdfont, padx=0, 
                               pady=0, bd=1)
                button = ('Alt','Control')[axis=='y'] # unused?
                # s.bind('<Key-%s>'%axis, lambda ev,cb=cb: cb.invoke)
                cb.pack(side='bottom',fill='both', padx=0, pady=0)
                xfader.registerbutton(name,axis,cvar)

            s.pack(side='left', fill=BOTH)

            # effects frame?
            sframe = Frame(f,bd=2,relief='groove')
            sub.draw_tk(sframe)
            sframe.pack(side='left',fill='y')