-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathradiating_lines.html
87 lines (73 loc) · 1.74 KB
/
radiating_lines.html
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
<!DOCTYPE html>
<html>
<head>
<title>A p5.js sketch</title>
<link rel = "stylesheet" type = "text/css" href = "style/style_sketch.css">
</head>
<body>
<script src = "p5/p5.min.js"></script>
<script src = "javascript/p5utilities.js"></script>
<!-- here is the javascript code using p5.js for the sketch: -->
<script>
/*
RADIATING LINES
- left mouse click: add a line
*/
//GLOBAL VARS
var radius = 500; //default radius is 500 pixels
var lines = 71;
var weight = 3;
var imagePadding = 60; //blank space added on each side of the image (in pixels)
var origin_set = [0, 0];
//SETUP
function setup() {
// initialize the canvas & graphics state:
canvas = createCanvas(windowWidth, windowHeight);
translate(width/2, height/2); //this is what (0,0) is considered to be
background(255);
strokeWeight(weight);
strokeCap(ROUND);
stroke(0);
fill(0);
origin_set = [width/2, height/2];
calculateRadiusSize();
drawImage(0,0);
}
//FUNCTIONS
//(x,y) is for the desired center position of this generated image
function drawImage(x,y){
for(var i=0; i<lines; i++){
//increment the drawing angle
let theta = i * (TWO_PI / lines);
//draw the new line
line(
x,
y,
radius * sin(theta) + x,
radius * cos(theta) + y
);
}
}
function calculateRadiusSize(){
if(windowWidth>windowHeight){
radius = height/2 - imagePadding;
}else{
radius = width/2 - imagePadding;
}
}
function mousePressed(){
//if the mouse is pressed down and then released, re-draw the image
background(255);
lines++;
drawImage(origin_set[0], origin_set[1]);
}
function windowResized() {
resizeCanvas(windowWidth, windowHeight);
origin_set = [width/2, height/2];
calculateRadiusSize();
background(255);
drawImage(origin_set[0], origin_set[1]);
}
</script>
</body>
</html>