-
Notifications
You must be signed in to change notification settings - Fork 1
/
curve6_generator.py
89 lines (68 loc) · 2.2 KB
/
curve6_generator.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
# Sample Python/Pygame Programs
# Simpson College Computer Science
# http://programarcadegames.com/
# http://simpson.edu/computer-science/
# Import a library of functions called 'pygame'
import pygame
import math
# Initialize the game engine
pygame.init()
# Define the colors we will use in RGB format
black = [ 0, 0, 0]
white = [255,255,255]
blue = [ 0, 0,255]
green = [ 0,255, 0]
red = [255, 0, 0]
PI = 3.141592653
r=30
# Set the height and width of the screen
xscreen=900
yscreen=480
x_shift=xscreen/2.0
y_shift=yscreen/2.0
size = [xscreen,yscreen]
screen = pygame.display.set_mode(size)
pygame.display.set_caption("Sansagraphics World")
#Loop until the user clicks the close button.
done = False
clock = pygame.time.Clock()
colour=red
xorigin=999.9
yorigin=999.9
total_rot=10000
a=1
b=1
while done == False:
# This limits the while loop to a max of 10 times per second.
# Leave this out and we will use all CPU we can.
clock.tick(10)
for event in pygame.event.get(): # User did something
if event.type == pygame.QUIT: # If user clicked close
done = True # Flag that we are done so we exit this loop
# All drawing code happens after the for loop and but
# inside the main while done==False loop.
# Clear the screen and set the screen background
screen.fill(white)
for n in range(total_rot):
phi = n * 2*PI/120
#x_offset = r*math.cos(phi) + x_shift
#y_offset = r*math.sin(phi) + y_shift
x_offset = r*(10*math.cos(phi/a)+math.cos(phi*a))*math.cos(phi/b)+x_shift
y_offset = r*(10*math.cos(phi/a)+math.cos(phi*a))*math.sin(phi/b)+y_shift
if (n>0) and (xorigin!=999.9):
cx=int(120*(math.sin(2*(phi))+1)+10)
cy=int(120*(math.sin(phi)+1)+10)
cz=int(120*(math.sin(phi-PI)+1)+10)
pygame.draw.line(screen,[cx,cy,cz],[xorigin,yorigin],[x_offset,y_offset],2)
xorigin = x_offset
yorigin = y_offset
##pygame.draw.ellipse(screen,black,[y_offset,x_offset,30,30],1/3)
# Go ahead and update the screen with what we've drawn.
# This MUST happen after all the other drawing commands.
a = a+1
b = a*2
pygame.display.flip()
print "Press enter.."
raw = raw_input()
# Be IDLE friendly
pygame.quit()