paper.js/examples/Animated/Lines.html

53 lines
1.2 KiB
HTML
Raw Normal View History

2011-02-21 08:31:26 -05:00
<!DOCTYPE html>
2011-02-07 13:28:09 -05:00
<html>
<head>
2013-06-02 16:41:10 -04:00
<meta charset="UTF-8">
<title>Lines</title>
<link rel="stylesheet" href="../css/style.css">
<script type="text/javascript" src="../../dist/paper.js"></script>
2011-03-04 06:38:38 -05:00
<script type="text/paperscript" canvas="canvas">
var amount = 45;
2011-05-03 03:54:13 -04:00
for (var i = 0; i < amount; i++) {
var path = new Path({
fillColor: {
hue: 1,
saturation: 1,
brightness: Math.random()
},
closed: true
});
2011-03-12 09:17:08 -05:00
}
var position = view.center;
var mousePos = view.center;
var children = project.activeLayer.children;
2011-05-16 08:42:23 -04:00
function iterate(count) {
var delta = mousePos - position;
2011-03-12 09:17:08 -05:00
position += delta / 10;
for (var i = 1; i < amount; i++) {
2011-03-12 09:28:01 -05:00
var path = children[i];
var length = Math.abs(Math.sin(i + count / 40) * 300);
2011-03-12 09:28:01 -05:00
path.segments = [
2011-03-12 09:17:08 -05:00
position + delta / 1.5,
position + { angle: i / amount * 360, length: length },
position + { angle: (i + 1) / amount * 360, length: length }
2011-03-12 09:17:08 -05:00
];
2011-03-12 09:28:01 -05:00
path.fillColor.hue = count - length;
2011-02-07 13:28:09 -05:00
}
2011-03-12 09:17:08 -05:00
}
2011-05-16 08:42:23 -04:00
function onFrame(event) {
iterate(event.count);
2011-03-12 09:17:08 -05:00
}
2011-05-16 08:42:23 -04:00
2011-03-12 09:17:08 -05:00
function onMouseMove(event) {
iterate();
mousePos = event.point;
2011-02-07 13:28:09 -05:00
}
</script>
</head>
<body style="background:black">
<canvas id="canvas" resize></canvas>
2011-05-30 18:27:39 -04:00
</body>
</html>