paper.js/examples/Animated/Smoothing.html

69 lines
1.8 KiB
HTML
Raw Normal View History

2011-04-23 09:47:28 -04:00
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Smoothing</title>
<link rel="stylesheet" href="../css/style.css">
<script type="text/javascript" src="../../dist/paper.js"></script>
2011-04-23 09:47:28 -04:00
<script type="text/paperscript" canvas="canvas">
2011-05-08 14:14:22 -04:00
var width, height, center;
2011-04-23 09:47:28 -04:00
var points = 10;
var smooth = true;
var path = new Path();
var mousePos = view.center / 2;
2011-05-08 14:14:22 -04:00
var pathHeight = mousePos.y;
2011-04-23 10:23:31 -04:00
path.fillColor = 'black';
initializePath();
2011-05-08 14:14:22 -04:00
function initializePath() {
center = view.center;
width = view.size.width;
height = view.size.height / 2;
path.segments = [];
path.add(view.bounds.bottomLeft);
for (var i = 1; i < points; i++) {
var point = new Point(width / points * i, center.y);
path.add(point);
}
path.add(view.bounds.bottomRight);
2011-06-20 11:40:30 -04:00
path.fullySelected = true;
2011-04-23 09:47:28 -04:00
}
2011-05-08 14:14:22 -04:00
function onFrame(event) {
2011-05-08 14:14:22 -04:00
pathHeight += (center.y - mousePos.y - pathHeight) / 10;
2011-04-23 10:23:31 -04:00
for (var i = 1; i < points; i++) {
var sinSeed = event.count + (i + i % 10) * 100;
2011-04-23 09:47:28 -04:00
var sinHeight = Math.sin(sinSeed / 200) * pathHeight;
var yPos = Math.sin(sinSeed / 100) * sinHeight + height;
path.segments[i].point.y = yPos;
}
if (smooth)
path.smooth();
}
2011-05-08 14:14:22 -04:00
2011-04-23 09:47:28 -04:00
function onMouseMove(event) {
2011-05-08 14:14:22 -04:00
mousePos = event.point;
2011-04-23 09:47:28 -04:00
}
2011-05-08 14:14:22 -04:00
2011-04-23 09:47:28 -04:00
function onMouseDown(event) {
smooth = !smooth;
if (!smooth) {
// If smooth has been turned off, we need to reset
// the handles of the path:
2011-04-23 10:23:31 -04:00
for (var i = 0, l = path.segments.length; i < l; i++) {
2011-04-23 09:47:28 -04:00
var segment = path.segments[i];
segment.handleIn = segment.handleOut = null;
}
}
}
2011-05-08 14:14:22 -04:00
// Reposition the path whenever the window is resized:
function onResize(event) {
initializePath();
}
2011-04-23 09:47:28 -04:00
</script>
</head>
<body>
<canvas id="canvas" resize></canvas>
2011-05-30 18:13:25 -04:00
</body>
</html>