blob: 8007f141cb5ddfa4984e4fe2dc3b86cd1d83dcb9 [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
Guido van Rossum3d3a52a1998-05-28 22:52:01 +000019def particle(canvas):
20 r = RADIUS
Guido van Rossum7e0e9551998-06-30 17:01:06 +000021 x = random.gauss(WIDTH/2.0, SIGMA)
22 y = random.gauss(HEIGHT/2.0, SIGMA)
Guido van Rossum3d3a52a1998-05-28 22:52:01 +000023 p = canvas.create_oval(x-r, y-r, x+r, y+r, fill=FILL)
Guido van Rossum7e7912f1998-05-28 23:02:33 +000024 while not stop:
Guido van Rossum7e0e9551998-06-30 17:01:06 +000025 dx = random.gauss(0, BUZZ)
26 dy = random.gauss(0, BUZZ)
27 dt = random.expovariate(LAMBDA)
Guido van Rossum3d3a52a1998-05-28 22:52:01 +000028 try:
29 canvas.move(p, dx, dy)
30 except TclError:
31 break
Guido van Rossum3d3a52a1998-05-28 22:52:01 +000032 time.sleep(dt)
33
34def main():
Guido van Rossum7e7912f1998-05-28 23:02:33 +000035 global stop
Guido van Rossum3d3a52a1998-05-28 22:52:01 +000036 root = Tk()
37 canvas = Canvas(root, width=WIDTH, height=HEIGHT)
38 canvas.pack(fill='both', expand=1)
39 np = 30
40 if sys.argv[1:]:
41 np = int(sys.argv[1])
42 for i in range(np):
43 t = threading.Thread(target=particle, args=(canvas,))
44 t.start()
Guido van Rossum7e7912f1998-05-28 23:02:33 +000045 try:
46 root.mainloop()
47 finally:
48 stop = 1
Guido van Rossum3d3a52a1998-05-28 22:52:01 +000049
50main()