-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsketch.js
120 lines (96 loc) · 2.22 KB
/
sketch.js
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
109
110
111
112
113
114
115
116
117
118
119
120
let stars;
let viewPoint;
function setup() {
createCanvas(windowWidth, windowHeight);
background(0,0,0);
frameRate(30);
setViewPoint(0, 0);
resetStarfield();
}
function resetStarfield() {
stars = [];
}
function setViewPoint(x, y) {
viewPoint = createVector(
map(x, 0, width, 0, 15),
map(y, 0, height, 0, 15)
);
}
function windowResized() {
resizeCanvas(windowWidth, windowHeight);
resetStarfield();
}
function doubleClicked() {
var fs = fullscreen();
fullscreen(!fs);
}
function mousePressed() {
noCursor();
}
function mouseReleased() {
cursor();
}
function draw() {
// Space, the final frontier...
clear();
background(0,0,0);
// Make it so!
if(mouseIsPressed) {
setViewPoint(mouseX - width / 2, mouseY - height / 2);
for(let i = 0; i < 20; i++) {
let star = new Star(createVectorTunnel());
stars.push(star);
}
} else {
setViewPoint(0, 0);
}
// 1/4 impulse.
for(let i = 0; i < 15; i++) {
let star = new Star(createVectorField());
stars.push(star);
}
// On the screen.
for(let i = 0; i < stars.length; i++) {
const star = stars[i];
if(star.isDead()) {
stars.splice(i, 1);
} else {
star.draw();
}
}
}
function createVectorTunnel() {
const radius = 50;
const angle = random(0.0, 180.0);
let x = width/2 + radius * cos(angle);
let y = height/2 + radius * sin(angle);
return createVector(x,y);
}
function createVectorField() {
return createVector(random(0, width), random(0, height));
}
function Star(position) {
this.color = 0;
this.size = 2;
this.position = position;
this.vector = createVector(
this.position.x - width / 2,
this.position.y - height / 2
);
this.direction = this.vector.copy().normalize();
this.draw = function() {
noStroke();
fill(map(this.color,0,100,0,254));
this.direction.mult(random(1.07, 1.10));
this.position.add(this.direction);
this.position.add(viewPoint);
ellipse(this.position.x,this.position.y, this.size);
this.size += 0.05;
if(this.color <= 100) {
this.color += 3;
}
}
this.isDead = function() {
return this.position.x < 0 || this.position.y < 0 || this.position.x > width || this.position.y > height;
}
}