blob: b08a9561cb42596b28c2e626d3cead63f3ece713 [file] [log] [blame]
Guido van Rossum7e7912f1998-05-28 23:02:33 +00001# Brownian motion -- an example of a multi-threaded Tkinter program.
Guido van Rossum3d3a52a1998-05-28 22:52:01 +00002
3from Tkinter import *
4import random
5import threading
6import time
7import sys
8
9WIDTH = 400
10HEIGHT = 300
11SIGMA = 10
12BUZZ = 2
13RADIUS = 2
14LAMBDA = 10
15FILL = 'red'
16
Guido van Rossum7e7912f1998-05-28 23:02:33 +000017stop = 0 # Set when main loop exits
18
19lock = threading.Lock() # Protects the random generator
20
Guido van Rossum3d3a52a1998-05-28 22:52:01 +000021def particle(canvas):
22 r = RADIUS
Guido van Rossum7e7912f1998-05-28 23:02:33 +000023 lock.acquire()
24 try:
25 x = random.gauss(WIDTH/2.0, SIGMA)
26 y = random.gauss(HEIGHT/2.0, SIGMA)
27 finally:
28 lock.release()
Guido van Rossum3d3a52a1998-05-28 22:52:01 +000029 p = canvas.create_oval(x-r, y-r, x+r, y+r, fill=FILL)
Guido van Rossum7e7912f1998-05-28 23:02:33 +000030 while not stop:
31 lock.acquire()
32 try:
33 dx = random.gauss(0, BUZZ)
34 dy = random.gauss(0, BUZZ)
35 dt = random.expovariate(LAMBDA)
36 finally:
37 lock.release()
Guido van Rossum3d3a52a1998-05-28 22:52:01 +000038 try:
39 canvas.move(p, dx, dy)
40 except TclError:
41 break
Guido van Rossum3d3a52a1998-05-28 22:52:01 +000042 time.sleep(dt)
43
44def main():
Guido van Rossum7e7912f1998-05-28 23:02:33 +000045 global stop
Guido van Rossum3d3a52a1998-05-28 22:52:01 +000046 root = Tk()
47 canvas = Canvas(root, width=WIDTH, height=HEIGHT)
48 canvas.pack(fill='both', expand=1)
49 np = 30
50 if sys.argv[1:]:
51 np = int(sys.argv[1])
52 for i in range(np):
53 t = threading.Thread(target=particle, args=(canvas,))
54 t.start()
Guido van Rossum7e7912f1998-05-28 23:02:33 +000055 try:
56 root.mainloop()
57 finally:
58 stop = 1
Guido van Rossum3d3a52a1998-05-28 22:52:01 +000059
60main()