-
Notifications
You must be signed in to change notification settings - Fork 115
Expand file tree
/
Copy pathliveSketch.js
More file actions
69 lines (61 loc) · 1.19 KB
/
liveSketch.js
File metadata and controls
69 lines (61 loc) · 1.19 KB
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
/**
* Mouse Functions.
*
* Click on the box and drag it across the screen.
*/
function runLiveSketch(s) {
var bx;
var by;
var boxSize = 75;
var overBox = false;
var locked = false;
var xOffset = 0.0;
var yOffset = 0.0;
s.setup = () => {
s.createCanvas(640, 360);
bx = s.width / 2.0;
by = s.height / 2.0;
s.rectMode(s.RADIUS);
};
s.draw = () => {
s.background(0);
// Test if the cursor is over the box
if (
s.mouseX > bx - boxSize &&
s.mouseX < bx + boxSize &&
s.mouseY > by - boxSize &&
s.mouseY < by + boxSize
) {
overBox = true;
if (!locked) {
s.stroke(255);
s.fill(153);
}
} else {
s.stroke(153);
s.fill(153);
overBox = false;
}
// Draw the box
s.rect(bx, by, boxSize, boxSize);
};
s.mousePressed = () => {
if (overBox) {
locked = true;
s.fill(255, 255, 255);
} else {
locked = false;
}
xOffset = s.mouseX - bx;
yOffset = s.mouseY - by;
};
s.mouseDragged = () => {
if (locked) {
bx = s.mouseX - xOffset;
by = s.mouseY - yOffset;
}
};
s.mouseReleased = () => {
locked = false;
};
}