mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-03 19:45:44 -05:00
Add Space example.
This commit is contained in:
parent
2c2d636198
commit
531e0bb203
1 changed files with 85 additions and 0 deletions
85
examples/Animated/Space.html
Normal file
85
examples/Animated/Space.html
Normal file
|
@ -0,0 +1,85 @@
|
||||||
|
<!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">
|
||||||
|
<script type="text/javascript" src="../../dist/paper.js"></script>
|
||||||
|
<script type="text/paperscript" canvas="canvas">
|
||||||
|
// The amount of symbol we want to place;
|
||||||
|
var count = 150;
|
||||||
|
|
||||||
|
// Create a symbol, which we will use to place instances of later:
|
||||||
|
var path = new Path.Circle(new Point(0, 0), 5);
|
||||||
|
path.style = {
|
||||||
|
fillColor: 'white',
|
||||||
|
strokeColor: 'black'
|
||||||
|
};
|
||||||
|
|
||||||
|
var symbol = new Symbol(path);
|
||||||
|
|
||||||
|
// Place the instances of the symbol:
|
||||||
|
for (var i = 0; i < count; i++) {
|
||||||
|
// The center position is a random point in the view:
|
||||||
|
var center = Point.random() * view.size;
|
||||||
|
var placed = symbol.place(center);
|
||||||
|
placed.scale(i / count);
|
||||||
|
placed.data = {};
|
||||||
|
placed.data.vector = new Point({
|
||||||
|
angle: Math.random() * 360,
|
||||||
|
length : (i / count) * Math.random() / 5
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
var vector = new Point({
|
||||||
|
angle: 45,
|
||||||
|
length: 0
|
||||||
|
});
|
||||||
|
|
||||||
|
var mouseVector = vector.clone();
|
||||||
|
|
||||||
|
function onMouseMove(event) {
|
||||||
|
mouseVector = view.center - event.point;
|
||||||
|
}
|
||||||
|
|
||||||
|
// The onFrame function is called up to 60 times a second:
|
||||||
|
function onFrame(event) {
|
||||||
|
vector = vector + (mouseVector - vector) / 30;
|
||||||
|
|
||||||
|
// Run through the active layer's children list and change
|
||||||
|
// the position of the placed symbols:
|
||||||
|
for (var i = 0; i < count; i++) {
|
||||||
|
var item = project.activeLayer.children[i];
|
||||||
|
var size = item.bounds.size;
|
||||||
|
var length = vector.length / 10 * size.width / 10;
|
||||||
|
item.position += vector.normalize(length) + item.data.vector;
|
||||||
|
keepInView(item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function keepInView(item) {
|
||||||
|
var position = item.position;
|
||||||
|
var itemBounds = item.bounds;
|
||||||
|
var bounds = view.bounds;
|
||||||
|
if (itemBounds.left > bounds.width) {
|
||||||
|
position.x = -item.bounds.width;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (position.x < -itemBounds.width) {
|
||||||
|
position.x = bounds.width + itemBounds.width;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (itemBounds.top > view.size.height) {
|
||||||
|
position.y = -itemBounds.height;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (position.y < -itemBounds.height) {
|
||||||
|
position.y = bounds.height + itemBounds.height / 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<canvas id="canvas" resize keepalive="true" style='background:black'></canvas>
|
||||||
|
</body>
|
||||||
|
</html>
|
Loading…
Reference in a new issue