annotate Widgets/FlyingFader.py @ 24:548d3aa2660f

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