paper.js/examples/Scripts/BlendModes.html

75 lines
178 KiB
HTML
Raw Normal View History

<!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]
}
});
var image = new Raster('ducky');
image.fitBounds(background.bounds);
background = new Symbol(background);
image = new Symbol(image);
var all = new Group();
function makeExample(point, blendMode) {
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);
}
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 = 0, i = 0; y < rows; y++) {
for (var x = 0; x < columns; x++) {
var mode = modes[i];
if (!mode)
break;
var point = (new Point(x, y) + 0.5) * (size + 20);
makeExample(point, mode);
i++;
}
}
// all.opacity = 0.5;
all.position = view.center;
var svg = project.exportSVG();
document.getElementById('svg').appendChild(svg);
//console.log(svg, new XMLSerializer().serializeToString(svg));
</script>
</head>
<body>
<canvas id="canvas" resize></canvas>
<img id="ducky" style="display:none;" src="
<div class id="svg"></div>
</body>
</html>