paper.js/examples/Paperjs.org/SpiralRaster.html

119 lines
16 KiB
HTML
Raw Normal View History

2011-07-05 12:28:30 -04:00
<!DOCTYPE html>
<html>
<head>
2013-06-02 16:41:10 -04:00
<meta charset="UTF-8">
2011-07-05 12:28:30 -04:00
<title>Spiral Raster</title>
<link rel="stylesheet" href="../css/style.css">
<script type="text/javascript" src="../../dist/paper.js"></script>
<script type="text/paperscript" canvas="canvas">
// Please note: dragging and dropping images only works for
// certain browsers when serving this script online:
var path, position, max;
var count = 0;
var grow = true;
var raster = new Raster('mona');
raster.remove();
2013-03-02 10:42:26 -05:00
var text = new PointText({
justification: 'right',
fontSize: 12,
content: window.FileReader
2011-07-05 12:28:30 -04:00
? 'drag & drop an image from your desktop to rasterize it'
2013-03-02 10:42:26 -05:00
: 'to drag & drop images, please use Webkit, Firefox, Chrome or IE 10'
});
2011-07-05 12:28:30 -04:00
resetSpiral();
function onFrame(event) {
if (grow) {
if (raster && (view.center - position).length < max) {
for (var i = 0, l = count / 36 + 1; i < l; i++) {
growSpiral();
}
path.smooth();
} else {
grow = false;
}
}
}
function growSpiral() {
count++;
var vector = new Point({
angle: count * 5,
length: count / 100
});
var rot = vector.rotate(90);
var color = raster.getAverageColor(position + vector / 2);
var value = color ? (1 - color.gray) * 3.7 : 0;
2011-07-05 12:28:30 -04:00
rot.length = Math.max(value, 0.2);
path.add(position + vector - rot);
path.insert(0, position + vector + rot);
position += vector;
}
function resetSpiral() {
grow = true;
// Transform the raster, so it fills the view:
raster.fitBounds(view.bounds);
if (path)
path.remove();
2011-07-07 10:09:02 -04:00
2011-07-05 12:28:30 -04:00
position = view.center;
count = 0;
2013-03-02 10:42:26 -05:00
path = new Path({
fillColor: 'black',
closed: true
});
2011-07-05 12:28:30 -04:00
position = view.center;
max = Math.min(raster.bounds.width, raster.bounds.height) * 0.5;
}
function onResize() {
2013-03-02 10:42:26 -05:00
resetSpiral();
text.point = view.bounds.bottomRight - [30, 30];
2011-07-05 12:28:30 -04:00
}
function onKeyDown(event) {
if (event.key == 'space') {
path.selected = !path.selected;
}
}
function onDocumentDrag(event) {
event.preventDefault();
}
function onDocumentDrop(event) {
event.preventDefault();
var file = event.dataTransfer.files[0];
var reader = new FileReader();
reader.onload = function ( event ) {
var image = document.createElement('img');
image.onload = function () {
raster = new Raster(image);
raster.remove();
resetSpiral();
};
image.src = event.target.result;
};
reader.readAsDataURL(file);
}
DomEvent.add(document, {
drop: onDocumentDrop,
dragover: onDocumentDrag,
dragleave: onDocumentDrag
});
</script>
</head>
<body>
<canvas id="canvas" resize style="background-color:white"></canvas>
<img width="512" height="512" id="mona" style="display: none;" src="
</body>
</html>