summaryrefslogtreecommitdiff
path: root/js/2d23d.js
blob: c3ac565f2c68926f7b3f788a431783fe0f4f74a6 (plain)
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
var angle = 0;
var state = 0;
var rotations = 0;
var waiting = false;
var iterations = 0;
var radius = 200;

function checkRotations()
{
	if (rotations > 0)
	{
		rotations = 0;
		angle = 0;
		waiting = true;
	}
}

function setup()
{
	createCanvas(2 * radius + 100, 2 * radius + 100);
	ellipseMode(CENTER);
	rectMode(CENTER);
	noFill();
	frameRate(100);
}

function draw()
{
	if (waiting)
	{
		iterations++;
		
		if (iterations > 150)
		{
			iterations = 0;
			waiting = false;
			background(255, 255, 255);
			state++;
		}
		return;
	}
	var ca = cos(angle) * radius + radius + 50;
	var sa = sin(angle) * radius + radius + 50;
	
	angle += 0.1/6;
	
	if (angle > TWO_PI)
		rotations++;
			
	checkRotations();
	
	angle %= TWO_PI;
	
	if (state == 0)
		ellipse(ca, sa, 50, 50);
	
	else if (state == 1)
		rect(ca, sa, 50, 50);

	else if (state == 2)
		triangle(ca, sa, ca+50, sa, ca, sa+50);

	
	else if (state == 3)
		triangle(ca, sa, ca+25, sa+25, ca, sa+50);

	
	else if (state == 4)
		ellipse(ca, sa, 100, 50);

	
	else if (state == 5)
		line(ca, sa, ca+50, sa);

	
	else if (state == 6)
		line(ca, sa, ca, sa+50);

	else if (state >= 7)
		arc(ca, sa, 50, 50, 0, (HALF_PI + state) % TWO_PI);

	
}