paper.js/examples/Animated/Extruded.html

73 lines
3 KiB
HTML
Raw Normal View History

2011-04-26 10:04:55 -04:00
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Example</title>
<link rel="stylesheet" href="../css/style.css">
2011-04-26 10:04:55 -04:00
<script type="text/javascript">var root = '../../'</script>
<script type="text/javascript" src="../../src/load.js"></script>
<script type="text/paperscript" canvas="canvas">
var segments = [
2011-05-19 11:16:19 -04:00
[new Point(63.39306640625, 265.7138671875), null, new Point(10.86669921875, 6.96630859375)],
[new Point(106.58203125, 277.97412109375), new Point(-16.71826171875, 0), new Point(24.79931640625, 0)],
[new Point(145.87060546875, 245.9306640625), new Point(0, 18.947265625), new Point(0, -17.27587890625)],
[new Point(110.4833984375, 208.87158203125), new Point(25.35595703125, 9.4736328125), new Point(-30.65087890625, -11.14599609375)],
[new Point(60.88525390625, 155.37255859375), new Point(0, 26.19189453125), new Point(0, -29.25732421875)],
[new Point(121.62890625, 104.380859375), new Point(-36.501953125, 0), new Point(18.947265625, 0)],
[new Point(162.86767578125, 113.576171875), new Point(-8.08056640625, -4.73681640625)],
[new Point(156.18017578125, 133.35986328125), null, new Point(-5.8515625, -3.62255859375)],
[new Point(120.79296875, 124.443359375), new Point(16.9970703125, 0), new Point(-25.63525390625, 0)],
[new Point(85.4052734375, 152.5859375), new Point(0, -12.8173828125), new Point(0, 17.55419921875)],
[new Point(122.7431640625, 188.80908203125), new Point(-25.91357421875, -10.03076171875), new Point(31.76513671875, 12.26025390625)],
[new Point(170.39111328125, 243.97998046875), new Point(0, -27.58544921875), new Point(0, 28.97900390625)],
[new Point(104.91015625, 298.31494140625), new Point(44.30419921875, 0), new Point(-18.111328125, 0)],
[new Point(56.984375, 286.0546875), new Point(10.03076171875, 6.6875)]
2011-04-26 10:04:55 -04:00
];
var lineGroup = new Group();
var lineCount = 100;
2011-05-03 03:54:13 -04:00
for (var i = 0; i < lineCount; i++) {
2011-04-26 10:04:55 -04:00
var linePath = new Path.Line([0, 0], [0, 0]);
linePath.strokeColor = 'red';
lineGroup.appendTop(linePath);
}
var path1 = new Path();
path1.segments = segments;
path1.closed = true;
path1.position = view.center;
2011-04-26 10:04:55 -04:00
path1.scale(1.5);
var path2 = new Path();
path2.segments = segments;
path2.closed = true;
path2.position = view.center;
2011-04-26 10:04:55 -04:00
path2.scale(2);
var length1 = path1.length;
var length2 = path2.length;
function onFrame(event) {
2011-04-26 10:04:55 -04:00
var vector = new Point({
angle: -event.count % 360,
2011-04-26 10:04:55 -04:00
length: 100
});
path1.rotate(-0.5);
path1.position = view.center - vector;
2011-04-26 10:04:55 -04:00
path2.rotate(-0.5);
path2.position = view.center + vector.normalize(50);
2011-04-26 10:04:55 -04:00
for (var i = 0; i < lineCount; i++) {
var path = lineGroup.children[i];
var l1 = (length1 / lineCount * (i + event.count / 10)) % length1;
var l2 = (length2 / lineCount * (i + event.count / 10)) % length2;
path.segments[0].point = path1.getPointAt(l1),
path.segments[1].point = path2.getPointAt(l2);
2011-04-26 10:04:55 -04:00
}
}
</script>
</head>
<body>
<canvas id="canvas" resize keepalive="true"></canvas>
2011-05-30 18:27:39 -04:00
</body>
</html>