2013-06-18 11:02:04 -04:00
|
|
|
<!DOCTYPE html>
|
|
|
|
<html>
|
|
|
|
<head>
|
|
|
|
<meta charset="UTF-8">
|
|
|
|
<title>BlendModes</title>
|
|
|
|
<script type="text/javascript" src="../../dist/paper.js"></script>
|
|
|
|
<script type="text/paperscript" canvas="canvas">
|
|
|
|
var stops = [];
|
|
|
|
for (var i = 0; i < 6; i++)
|
|
|
|
stops.push({ hue: (i - 3) * 60, saturation: 1, brightness: 1 });
|
|
|
|
var size = new Size(150, 150)
|
|
|
|
var background = new Path.Rectangle({
|
|
|
|
rectangle: new Rectangle(size),
|
|
|
|
fillColor: {
|
|
|
|
stops: stops,
|
|
|
|
origin: [0, 0],
|
|
|
|
destination: [size.width, 0]
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2013-06-18 20:23:38 -04:00
|
|
|
var image = new Raster('ducky');
|
|
|
|
image.fitBounds(background.bounds);
|
|
|
|
|
|
|
|
background = new Symbol(background);
|
|
|
|
image = new Symbol(image);
|
2013-06-18 11:02:04 -04:00
|
|
|
|
2013-06-18 20:23:38 -04:00
|
|
|
var all = new Group();
|
2013-06-18 11:02:04 -04:00
|
|
|
function makeExample(point, blendMode) {
|
2013-06-18 20:23:38 -04:00
|
|
|
var rect = background.place();
|
|
|
|
// var img = new Raster('ducky');
|
|
|
|
var img = image.place();
|
|
|
|
img.fitBounds(rect.bounds);
|
|
|
|
img.blendMode = blendMode;
|
|
|
|
var text = new PointText({
|
|
|
|
point: [0, size.height / 2 + 15],
|
|
|
|
fontSize: 14,
|
|
|
|
justification: 'center',
|
|
|
|
content: mode
|
|
|
|
})
|
|
|
|
var clip = new Group(rect, img, text);
|
|
|
|
clip.position = point;
|
|
|
|
all.addChild(clip);
|
2013-06-18 11:02:04 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
var modes = [ 'normal', 'multiply', 'screen', 'overlay', 'soft-light',
|
|
|
|
'hard-light', 'color-dodge', 'color-burn', 'darken', 'lighten',
|
|
|
|
'difference', 'exclusion', 'hue', 'saturation', 'luminosity',
|
|
|
|
'color', 'add', 'subtract', 'average', 'pin-light', 'negation'];
|
|
|
|
var columns = 5;
|
|
|
|
var rows = Math.ceil(modes.length / columns);
|
2013-06-18 20:23:38 -04:00
|
|
|
for (var y = 0, i = 0; y < rows; y++) {
|
|
|
|
for (var x = 0; x < columns; x++) {
|
|
|
|
var mode = modes[i];
|
2013-06-18 11:02:04 -04:00
|
|
|
if (!mode)
|
|
|
|
break;
|
2013-06-18 20:23:38 -04:00
|
|
|
var point = (new Point(x, y) + 0.5) * (size + 20);
|
2013-06-18 11:02:04 -04:00
|
|
|
makeExample(point, mode);
|
2013-06-18 20:23:38 -04:00
|
|
|
i++;
|
2013-06-18 11:02:04 -04:00
|
|
|
}
|
|
|
|
}
|
2013-06-18 20:23:38 -04:00
|
|
|
|
|
|
|
// all.opacity = 0.5;
|
|
|
|
all.position = view.center;
|
|
|
|
|
|
|
|
var svg = project.exportSVG();
|
|
|
|
document.getElementById('svg').appendChild(svg);
|
|
|
|
//console.log(svg, new XMLSerializer().serializeToString(svg));
|
2013-06-18 11:02:04 -04:00
|
|
|
</script>
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<canvas id="canvas" resize></canvas>
|
|
|
|
<img id="ducky" style="display:none;" src="
|
2013-06-18 20:23:38 -04:00
|
|
|
<div class id="svg"></div>
|
2013-06-18 11:02:04 -04:00
|
|
|
</body>
|
|
|
|
</html>
|