paper.js/examples/Scripts/BlendModes.html

65 lines
178 KiB
HTML
Raw Normal View History

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>BlendModes</title>
<link rel="stylesheet" href="../css/style.css">
<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]
}
});
background = new Symbol(background);
// TODO: Make #blendMode on PlacedSymbol work
// var image = new Raster('ducky');
// image.fitBounds(background.bounds);
// image = new Symbol(image);
function makeExample(point, blendMode) {
var rect = background.place(point)
// image.place(point);
var image = new Raster('ducky');
image.fitBounds(rect.bounds);
image.blendMode = blendMode;
}
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);
for (var y = 1, i = 0; y <= rows; y++) {
for (var x = 1; x <= columns; x++) {
var mode = modes[i++];
if (!mode)
break;
var point = (new Point(x, y) - 0.5) * (size + 20);
makeExample(point, mode);
new PointText({
point: point + [0, size.height / 2 + 15],
fontSize: 14,
justification: 'center',
content: mode
})
}
}
// TODO: Debug error in SVG export of result
// alert(new XMLSerializer().serializeToString(project.exportSVG()));
</script>
</head>
<body>
<canvas id="canvas" resize></canvas>
<img id="ducky" style="display:none;" src="
</body>
</html>