forked from APCSLowell/Chemotaxis
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathChemotaxis.pde
108 lines (77 loc) · 1.08 KB
/
Chemotaxis.pde
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
//declare bacteria variables here
Bacteria [] bob;
boolean toMove= false;
void setup()
{
size(500,500);
frameRate(10);
bob = new Bacteria[200];
for(int i = 0; i<bob.length; i++)
{
bob[i] = new Bacteria(0,0);
}
}
void draw()
{
background(0);
for(int i = 0; i<bob.length; i++)
{
bob[i].show();
if(toMove == true)
{
bob[i].move();
}
}
blackhole();
}
int a = 250;
int b = 250;
void blackhole()
{
fill(255,255,255,75);
ellipse(a, b,50,50);
}
void mousePressed()
{
if(mouseButton ==LEFT ){
toMove = true;
blackhole();
}
if(mouseButton == RIGHT){
toMove = false;
setup();
}
}
class Bacteria
{
int myX, myY;
Bacteria (int x, int y)
{
myX = (int)(Math.random()*501);
myY = (int)(Math.random()*501);
}
void show()
{
fill((int)(Math.random()*256));
ellipse(myX,myY,10,10);
}
void move()
{
if(myX < a)
{
myX ++;
}
else
{
myX--;
}
if(myY<a)
{
myY++;
}
else
{
myY--;
}
}
}