-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpoint-by-point-circle-with-random-lines.js
94 lines (76 loc) · 2.07 KB
/
point-by-point-circle-with-random-lines.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
/* jshint esnext: true */
function setup() {
createCanvas(640, 480);
background(60); // set background canvas color
strokeWeight(3);
stroke(255, 255, 255); // set stroke color
noFill(); // Don't fill shapes
noLoop(); // Don't run the draw loop
// Global config
this.config = {
radius: width / 3,
centX: width / 2,
centY: height / 2,
step: 5 // step value for angle
};
// Global mutable state
this.state = {
angle: 0
};
this.points = [];
this.reportDistanceOfLastPoints = function () {
if (this.points.length < 2) {
return false;
}
let distance = distanceBetweenPoints(
this.points[this.points.length - 1],
this.points[this.points.length - 2]
);
console.log(distance);
};
}
// Main draw loop
function draw() {
strokeWeight(mouseX / 100);
stroke(random(150, 255)); // random whiteness
let rad = radians(this.state.angle);
let radius = this.config.radius * (0.4 + noise(mouseX, mouseY));
let x = this.config.centX + (radius * cos(rad));
let y = this.config.centY + (radius * sin(rad));
// Add point to points and draw it to canvas
this.points.push([x, y]);
point(x, y);
// Draw line connecting points
this.connectRandomPoints = () => {
// ~40% chance for line
if (this.points.length < 2 && random() > 0.4) {
return false;
}
let [x1, y1] = sample(this.points);
let [x2, y2] = sample(this.points);
line(x1, y1, x2, y2);
};
this.connectRandomPoints();
// Increment angle by step with added noise
this.state.angle += this.config.step * (1 + noise(this.config.step));
}
function mousePressed() {
loop(); // starts running the draw loop
}
function mouseReleased() {
noLoop();
}
function keyReleased() {
console.log(`CLEARED with: ${key}`);
background(60);
}
function distanceBetweenPoints(point1, point2) {
let [x1, y1] = point1;
let [x2, y2] = point2;
let dist = Math.sqrt(Math.pow((x1-x2), 2) + Math.pow((y1-y2), 2));
return dist;
}
function sample(collection) {
// TODO add floor.
return collection[Math.floor(random(collection.length))];
}