/* * 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 Group = this.Group = Item.extend({ /** @lends Group# */ // DOCS: document new Group(item, item...); /** * Creates a new Group item and places it at the top of the active layer. * * @param {Item[]} [children] An optional array of children that will be * added to the newly created group. * * @example {@paperscript split=true height=200} * // Create a group containing two paths: * var path = new Path(new Point(100, 100), new Point(100, 200)); * var path2 = new Path(new Point(50, 150), new Point(150, 150)); * * // Create a group from the two paths: * var group = new Group([path, path2]); * * // Set the stroke color of all items in the group: * group.strokeColor = 'black'; * * // Move the group to the center of the view: * group.position = view.center; * * @example {@paperscript split=true height=320} * // Click in the view to add a path to the group, which in turn is rotated * // every frame: * var group = new Group(); * * function onMouseDown(event) { * // Create a new circle shaped path at the position * // of the mouse: * var path = new Path.Circle(event.point, 5); * path.fillColor = 'black'; * * // Add the path to the group's children list: * group.addChild(path); * } * * function onFrame(event) { * // Rotate the group by 1 degree from * // the centerpoint of the view: * group.rotate(1, view.center); * } * * @class A Group is a collection of items. When you transform a Group, its * children are treated as a single unit without changing their relative * positions. * @extends Item * @constructs Group */ initialize: function(items) { this.base(); // Allow Group to have children and named children this._children = []; this._namedChildren = {}; this.setChildren(!items || !Array.isArray(items) || typeof items[0] !== 'object' ? arguments : items); }, _getClipMask: function() { // TODO: Use caching once ChangeFlags.HIERARCHY is implemented for (var i = 0, l = this._children.length; i < l; i++) { var child = this._children[i]; if (child._clipMask) return child; } }, /** * Specifies whether the group item is to be clipped. * When setting to {@code true}, the first child in the group is * automatically defined as the clipping mask. * * @type Boolean * @bean */ isClipped: function() { return !!this._getClipMask(); }, setClipped: function(clipped) { var child = this.getFirstChild(); if (child) child.setClipMask(clipped); return this; }, draw: function(ctx, param) { var clipMask = this._getClipMask(); if (clipMask) Item.draw(clipMask, ctx, param); for (var i = 0, l = this._children.length; i < l; i++) { var item = this._children[i]; if (item != clipMask) Item.draw(item, ctx, param); } } });