/* * Paper.js * * This file is part of Paper.js, a JavaScript Vector Graphics Library, * based on Scriptographer.org and designed to be largely API compatible. * http://paperjs.org/ * http://scriptographer.org/ * * Distributed under the MIT license. See LICENSE file for details. * * Copyright (c) 2011, Juerg Lehni & Jonathan Puckey * http://lehni.org/ & http://jonathanpuckey.com/ * * All rights reserved. */ var CompoundPath = this.CompoundPath = PathItem.extend({ initialize: function(items) { this.base(); this.children = []; if (items) { for (var i = 0, l = items.length; i < l; i++) this.appendTop(items[i]); } }, /** * If this is a compound path with only one path inside, * the path is moved outside and the compound path is erased. * Otherwise, the compound path is returned unmodified. * * @return the simplified compound path. */ simplify: function() { if (this.children.length == 1) { var child = this.children[0]; child.moveAbove(this); this.remove(); return child; } return this; }, smooth: function() { for (var i = 0, l = this.children.length; i < l; i++) this.children[i].smooth(); }, draw: function(ctx, param) { var firstChild = this.children[0]; ctx.beginPath(); param.compound = true; for (var i = 0, l = this.children.length; i < l; i++) Item.draw(this.children[i], ctx, param); firstChild._setStyles(ctx); var fillColor = firstChild.getFillColor(), strokeColor = firstChild.getStrokeColor(); if (fillColor) { ctx.fillStyle = fillColor.getCanvasStyle(ctx); ctx.fill(); } if (strokeColor) { ctx.strokeStyle = strokeColor.getCanvasStyle(ctx); ctx.stroke(); } } }, new function() { // Injection scope for PostScript-like drawing functions function getCurrentPath(that) { if (that.children.length) { return that.children[that.children.length - 1]; } else { throw new Error('Use a moveTo() command first'); } } var fields = { moveTo: function() { var path = new Path(); this.appendTop(path); path.moveTo.apply(path, arguments); }, moveBy: function() { var point = arguments.length ? Point.read(arguments) : new Point(), path = getCurrentPath(this), current = path.segments[path.segments.length - 1]._point; this.moveTo(current.add(point)); }, closePath: function() { getCurrentPath(this).setClosed(true); } }; // Redirect all other drawing commands to the current path Base.each(['lineTo', 'cubicCurveTo', 'quadraticCurveTo', 'curveTo', 'arcTo', 'lineBy', 'curveBy', 'arcBy'], function(key) { fields[key] = function() { var path = getCurrentPath(this); path[key].apply(path, arguments); }; }); return fields; });