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);
|
2013-04-09 23:40:57 -04:00
|
|
|
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>
|
2013-11-06 06:53:50 -05:00
|
|
|
<canvas id="canvas" resize style="background-color:white" hidpi></canvas>
|
2011-07-05 12:28:30 -04:00
|
|
|
<img width="512" height="512" id="mona" style="display: none;" src="
|
|
|
|
</body>
|
|
|
|
</html>
|