annotate Widgets/FlyingFader.py @ 39:2443de5df9c5

added subeditor
author drewp
date Sun, 07 Jul 2002 12:16:44 +0000
parents c79d4df9d982
children 5ff08b489693
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
9
342f7d1c7561 The FlyingFader will accept keyboard values and fade to them over 1.5
dmcc
parents: 0
diff changeset
1 from Tkinter import *
24
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
2 from time import time,sleep
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
3 from __future__ import division
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
4
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
5 class Mass:
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
6 def __init__(self):
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
7 self.x=0 # position
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
8 self.xgoal=0 # position goal
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
9
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
10 self.v=0 # velocity
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
11 self.maxspeed = .8 # maximum speed, in position/second
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
12 self.maxaccel = 3 # maximum acceleration, in position/second^2
25
f0e1dde35aec better brakes and numerics (oscillations are still possible if the updates get
drewp
parents: 24
diff changeset
13 self.eps = .03 # epsilon - numbers within this much are considered the same
24
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
14
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
15 self._lastupdate=time()
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
16 self._stopped=1
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
17
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
18 def equal(self,a,b):
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
19 return abs(a-b)<self.eps
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
20
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
21 def stop(self):
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
22 self.v=0
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
23 self.xgoal=self.x
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
24 self._stopped=1
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
25
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
26 def update(self):
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
27 t0 = self._lastupdate
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
28 tnow = time()
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
29 self._lastupdate = tnow
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
30
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
31 dt = tnow-t0
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
32
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
33 self.x += self.v*dt
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
34 # hitting the ends stops the slider
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
35 if self.x>1: self.v=max(self.v,0); self.x=1
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
36 if self.x<0: self.v=min(self.v,0); self.x=0
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
37
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
38 if self.equal(self.x,self.xgoal):
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
39 self.x=self.xgoal # clean up value
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
40 self.stop()
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
41 return
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
42
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
43 self._stopped=0
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
44 dir = (-1.0,1,0)[self.xgoal>self.x]
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
45
25
f0e1dde35aec better brakes and numerics (oscillations are still possible if the updates get
drewp
parents: 24
diff changeset
46 if abs(self.xgoal-self.x) < abs(self.v*5*dt):
f0e1dde35aec better brakes and numerics (oscillations are still possible if the updates get
drewp
parents: 24
diff changeset
47 # apply the brakes on the last 5 steps
f0e1dde35aec better brakes and numerics (oscillations are still possible if the updates get
drewp
parents: 24
diff changeset
48 dir *= -.5
f0e1dde35aec better brakes and numerics (oscillations are still possible if the updates get
drewp
parents: 24
diff changeset
49
24
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
50 self.v += dir*self.maxaccel*dt # velocity changes with acceleration in the right direction
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
51 self.v = min(max(self.v,-self.maxspeed),self.maxspeed) # clamp velocity
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
52
25
f0e1dde35aec better brakes and numerics (oscillations are still possible if the updates get
drewp
parents: 24
diff changeset
53 #print "x=%+.03f v=%+.03f a=%+.03f %f" % (self.x,self.v,self.maxaccel,self.xgoal)
24
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
54
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
55 def goto(self,newx):
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
56 self.xgoal=newx
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
57
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
58 def ismoving(self):
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
59 return not self._stopped
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
60
45b12307c695 Initial revision
drewp
parents:
diff changeset
61 class FlyingFader(Frame):
31
c79d4df9d982 now they're orientable
drewp
parents: 27
diff changeset
62 def __init__(self, master, variable, label, fadedur=1.5, font=('Arial', 8), labelwidth=12,
15
c76b62eccdec put **kw back in, they now go to the scale and can override the defaults.
dmcc
parents: 11
diff changeset
63 **kw):
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
64 Frame.__init__(self, master)
45b12307c695 Initial revision
drewp
parents:
diff changeset
65 self.name = label
45b12307c695 Initial revision
drewp
parents:
diff changeset
66 self.variable = variable
45b12307c695 Initial revision
drewp
parents:
diff changeset
67
24
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
68 self.mass = Mass()
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
69
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
70 self.config({'bd':1, 'relief':'raised'})
22
626aa2179630 some naming and defaults tweaks
drewp
parents: 20
diff changeset
71 scaleopts = {'variable' : variable, 'showvalue' : 0, 'from' : 1.0,
31
c79d4df9d982 now they're orientable
drewp
parents: 27
diff changeset
72 'to' : 0, 'res' : 0.001, 'width' : 20, 'length' : 200, 'orient':'vert'}
15
c76b62eccdec put **kw back in, they now go to the scale and can override the defaults.
dmcc
parents: 11
diff changeset
73 scaleopts.update(kw)
31
c79d4df9d982 now they're orientable
drewp
parents: 27
diff changeset
74 if scaleopts['orient']=='vert':
c79d4df9d982 now they're orientable
drewp
parents: 27
diff changeset
75 side1=TOP
c79d4df9d982 now they're orientable
drewp
parents: 27
diff changeset
76 side2=BOTTOM
c79d4df9d982 now they're orientable
drewp
parents: 27
diff changeset
77 else:
c79d4df9d982 now they're orientable
drewp
parents: 27
diff changeset
78 side1=RIGHT
c79d4df9d982 now they're orientable
drewp
parents: 27
diff changeset
79 side2=LEFT
15
c76b62eccdec put **kw back in, they now go to the scale and can override the defaults.
dmcc
parents: 11
diff changeset
80
c76b62eccdec put **kw back in, they now go to the scale and can override the defaults.
dmcc
parents: 11
diff changeset
81 self.scale = Scale(self, scaleopts)
22
626aa2179630 some naming and defaults tweaks
drewp
parents: 20
diff changeset
82 self.vlabel = Label(self, text="0.0", width=6, font=font)
31
c79d4df9d982 now they're orientable
drewp
parents: 27
diff changeset
83 self.label = Label(self, text=label, font=font, anchor='w',width=labelwidth) #wraplength=40, )
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
84
45b12307c695 Initial revision
drewp
parents:
diff changeset
85 self.oldtrough = self.scale['troughcolor']
45b12307c695 Initial revision
drewp
parents:
diff changeset
86
31
c79d4df9d982 now they're orientable
drewp
parents: 27
diff changeset
87 self.scale.pack(side=side2, expand=1, fill=BOTH, anchor='c')
c79d4df9d982 now they're orientable
drewp
parents: 27
diff changeset
88 self.vlabel.pack(side=side2, expand=0, fill=X)
c79d4df9d982 now they're orientable
drewp
parents: 27
diff changeset
89 self.label.pack(side=side2, expand=0, fill=X)
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
90
45b12307c695 Initial revision
drewp
parents:
diff changeset
91 for k in range(1, 10):
45b12307c695 Initial revision
drewp
parents:
diff changeset
92 self.scale.bind("<Key-%d>" % k,
20
6eafd86930b5 fix precision bug
dmcc
parents: 18
diff changeset
93 lambda evt, k=k: self.newfade(k / 10.0, evt))
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
94
24
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
95 self.scale.bind("<Key-0>", lambda evt: self.newfade(1.0, evt))
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
96 self.scale.bind("<grave>", lambda evt: self.newfade(0, evt))
45b12307c695 Initial revision
drewp
parents:
diff changeset
97
45b12307c695 Initial revision
drewp
parents:
diff changeset
98 self.scale.bind("<1>", self.cancelfade)
11
c65119b66b00 - no more kw args -- they didn't do anything. use configure to change
dmcc
parents: 9
diff changeset
99 self.scale.bind("<2>", self.cancelfade)
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
100 self.scale.bind("<3>", self.mousefade)
45b12307c695 Initial revision
drewp
parents:
diff changeset
101
9
342f7d1c7561 The FlyingFader will accept keyboard values and fade to them over 1.5
dmcc
parents: 0
diff changeset
102 self.variable.trace('w', self.updatelabel)
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
103
45b12307c695 Initial revision
drewp
parents:
diff changeset
104 def cancelfade(self, evt):
24
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
105 self.fadegoal = self.variable.get()
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
106 self.fadevel = self.fadeacc = 0
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
107
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
108 self.scale['troughcolor'] = self.oldtrough
45b12307c695 Initial revision
drewp
parents:
diff changeset
109
45b12307c695 Initial revision
drewp
parents:
diff changeset
110 def mousefade(self, evt):
45b12307c695 Initial revision
drewp
parents:
diff changeset
111 target = float(self.tk.call(self.scale, 'get', evt.x, evt.y))
45b12307c695 Initial revision
drewp
parents:
diff changeset
112 self.newfade(target, evt)
45b12307c695 Initial revision
drewp
parents:
diff changeset
113
24
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
114 def ismoving(self):
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
115 return self.fadevel!=0 or self.fadeacc!=0
22
626aa2179630 some naming and defaults tweaks
drewp
parents: 20
diff changeset
116
9
342f7d1c7561 The FlyingFader will accept keyboard values and fade to them over 1.5
dmcc
parents: 0
diff changeset
117 def newfade(self, newlevel, evt=None, length=None):
24
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
118
25
f0e1dde35aec better brakes and numerics (oscillations are still possible if the updates get
drewp
parents: 24
diff changeset
119 # these are currently unused-- Mass needs to accept a speed input
9
342f7d1c7561 The FlyingFader will accept keyboard values and fade to them over 1.5
dmcc
parents: 0
diff changeset
120 mult = 1
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
121 if evt.state & 8 and evt.state & 4: mult = 0.25 # both
45b12307c695 Initial revision
drewp
parents:
diff changeset
122 elif evt.state & 8: mult = 0.5 # alt
45b12307c695 Initial revision
drewp
parents:
diff changeset
123 elif evt.state & 4: mult = 2 # control
45b12307c695 Initial revision
drewp
parents:
diff changeset
124
25
f0e1dde35aec better brakes and numerics (oscillations are still possible if the updates get
drewp
parents: 24
diff changeset
125
24
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
126 self.mass.x = self.variable.get()
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
127 self.mass.goto(newlevel)
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
128
45b12307c695 Initial revision
drewp
parents:
diff changeset
129 self.gofade()
45b12307c695 Initial revision
drewp
parents:
diff changeset
130
45b12307c695 Initial revision
drewp
parents:
diff changeset
131 def gofade(self):
24
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
132 self.mass.update()
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
133 self.variable.set(self.mass.x)
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
134
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
135 if not self.mass.ismoving():
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
136 self.scale['troughcolor'] = self.oldtrough
45b12307c695 Initial revision
drewp
parents:
diff changeset
137 return
25
f0e1dde35aec better brakes and numerics (oscillations are still possible if the updates get
drewp
parents: 24
diff changeset
138
f0e1dde35aec better brakes and numerics (oscillations are still possible if the updates get
drewp
parents: 24
diff changeset
139 # blink the trough while the thing's moving
f0e1dde35aec better brakes and numerics (oscillations are still possible if the updates get
drewp
parents: 24
diff changeset
140 if time()%.4>.2:
27
bee0862f4436 Construction colors
dmcc
parents: 25
diff changeset
141 # self.scale.config(troughcolor=self.oldtrough)
bee0862f4436 Construction colors
dmcc
parents: 25
diff changeset
142 self.scale.config(troughcolor='orange')
25
f0e1dde35aec better brakes and numerics (oscillations are still possible if the updates get
drewp
parents: 24
diff changeset
143 else:
27
bee0862f4436 Construction colors
dmcc
parents: 25
diff changeset
144 # self.scale.config(troughcolor='white')
bee0862f4436 Construction colors
dmcc
parents: 25
diff changeset
145 self.scale.config(troughcolor='yellow')
24
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
146
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
147 # colorfade(self.scale, percent)
22
626aa2179630 some naming and defaults tweaks
drewp
parents: 20
diff changeset
148 self.after(30, self.gofade)
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
149
45b12307c695 Initial revision
drewp
parents:
diff changeset
150 def updatelabel(self, *args):
18
053889940418 some changes to allow integration into rsn. more needed
dmcc
parents: 15
diff changeset
151 self.vlabel['text'] = "%.3f" % self.variable.get()
24
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
152 # if self.fadetimes[1] == 0: # no fade
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
153 # self.vlabel['fg'] = 'black'
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
154 # elif self.curfade[1] > self.curfade[0]:
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
155 # self.vlabel['fg'] = 'red'
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
156 # else:
548d3aa2660f physics model fader!
drewp
parents: 22
diff changeset
157 # self.vlabel['fg'] = 'blue'
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
158
11
c65119b66b00 - no more kw args -- they didn't do anything. use configure to change
dmcc
parents: 9
diff changeset
159 def get(self):
c65119b66b00 - no more kw args -- they didn't do anything. use configure to change
dmcc
parents: 9
diff changeset
160 return self.scale.get()
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
161
11
c65119b66b00 - no more kw args -- they didn't do anything. use configure to change
dmcc
parents: 9
diff changeset
162 def set(self, val):
c65119b66b00 - no more kw args -- they didn't do anything. use configure to change
dmcc
parents: 9
diff changeset
163 self.scale.set(val)
c65119b66b00 - no more kw args -- they didn't do anything. use configure to change
dmcc
parents: 9
diff changeset
164
c65119b66b00 - no more kw args -- they didn't do anything. use configure to change
dmcc
parents: 9
diff changeset
165
c65119b66b00 - no more kw args -- they didn't do anything. use configure to change
dmcc
parents: 9
diff changeset
166 def colorfade(scale, lev):
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
167 low = (255, 255, 255)
45b12307c695 Initial revision
drewp
parents:
diff changeset
168 high = (0, 0, 0)
11
c65119b66b00 - no more kw args -- they didn't do anything. use configure to change
dmcc
parents: 9
diff changeset
169 out = [int(l+lev*(h-l)) for h, l in zip(high,low)]
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
170 col="#%02X%02X%02X" % tuple(out)
45b12307c695 Initial revision
drewp
parents:
diff changeset
171 scale.config(troughcolor=col)
45b12307c695 Initial revision
drewp
parents:
diff changeset
172
25
f0e1dde35aec better brakes and numerics (oscillations are still possible if the updates get
drewp
parents: 24
diff changeset
173
0
45b12307c695 Initial revision
drewp
parents:
diff changeset
174 if __name__ == '__main__':
45b12307c695 Initial revision
drewp
parents:
diff changeset
175 root = Tk()
45b12307c695 Initial revision
drewp
parents:
diff changeset
176 root.tk_focusFollowsMouse()
45b12307c695 Initial revision
drewp
parents:
diff changeset
177
45b12307c695 Initial revision
drewp
parents:
diff changeset
178 FlyingFader(root, variable=DoubleVar(), label="suck").pack(side=LEFT,
45b12307c695 Initial revision
drewp
parents:
diff changeset
179 expand=1, fill=BOTH)
45b12307c695 Initial revision
drewp
parents:
diff changeset
180 FlyingFader(root, variable=DoubleVar(), label="moof").pack(side=LEFT,
45b12307c695 Initial revision
drewp
parents:
diff changeset
181 expand=1, fill=BOTH)
45b12307c695 Initial revision
drewp
parents:
diff changeset
182 FlyingFader(root, variable=DoubleVar(), label="zarf").pack(side=LEFT,
45b12307c695 Initial revision
drewp
parents:
diff changeset
183 expand=1, fill=BOTH)
45b12307c695 Initial revision
drewp
parents:
diff changeset
184 FlyingFader(root, variable=DoubleVar(),
45b12307c695 Initial revision
drewp
parents:
diff changeset
185 label="long name goes here. got it?").pack(side=LEFT, expand=1,
45b12307c695 Initial revision
drewp
parents:
diff changeset
186 fill=BOTH)
45b12307c695 Initial revision
drewp
parents:
diff changeset
187
45b12307c695 Initial revision
drewp
parents:
diff changeset
188 root.mainloop()