Constructors
Creates a new path item and places it at the top of the active layer.
- segments: Array of Segment objects — An array of segments (or points to be converted to segments) that will be added to the path — optional
Parameters:
- Path — the newly created path
Returns:
Example:Create an empty path and add segments to it:
var path = new Path();
path.strokeColor = 'black';
path.add(new Point(30, 30));
path.add(new Point(100, 100));
Example:Create a path with two segments:
var segments = [new Point(30, 30), new Point(100, 100)];
var path = new Path(segments);
path.strokeColor = 'black';
Creates a new path item from an object description and places it at the top of the active layer.
- object: Object — an object literal containing properties to be set on the path
Parameters:
- Path — the newly created path
Returns:
Example:
Example:
Creates a new path item from SVG path-data and places it at the top of the active layer.
- :
- pathData: String — the SVG path-data that describes the geometry of this path
Parameters:
- Path — the newly created path
Returns:
Example:
Shaped Paths
Creates a linear path item from the properties described by an object literal.
- object: Object — an object literal containing properties describing the path’s attributes
Parameters:
- Path — the newly created path
Returns:
Example:
Creates a circular path item from the properties described by an object literal.
- object: Object — an object literal containing properties describing the path’s attributes
Parameters:
- Path — the newly created path
Returns:
Example:
Creates a rectangular path item, with optionally rounded corners.
- rectangle: Rectangle — the rectangle object describing the geometry of the rectangular path to be created
- radius: Size — the size of the rounded corners — optional, default: null
Parameters:
- Path — the newly created path
Returns:
Example:
Example:The same, with rounder corners
Creates a rectangular path item from the passed points. These do not necessarily need to be the top left and bottom right corners, the constructor figures out how to fit a rectangle between them.
- from: Point — the first point defining the rectangle
- to: Point — the second point defining the rectangle
Parameters:
- Path — the newly created path
Returns:
Example:
Creates a rectangular path item from the properties described by an object literal.
- object: Object — an object literal containing properties describing the path’s attributes
Parameters:
- Path — the newly created path
Returns:
Example:
Example:
Example:
Example:
Creates an elliptical path item from the properties described by an object literal.
- object: Object — an object literal containing properties describing the path’s attributes
Parameters:
- Path — the newly created path
Returns:
Example:
Example:Placing by center and radius
Creates an circular arc path item from the properties described by an object literal.
- object: Object — an object literal containing properties describing the path’s attributes
Parameters:
- Path — the newly created path
Returns:
Example:
Creates a regular polygon shaped path item from the properties described by an object literal.
- object: Object — an object literal containing properties describing the path’s attributes
Parameters:
- Path — the newly created path
Returns:
Example:
Creates a star shaped path item.
The largest of radius1
and radius2
will be the outer radius of the star. The smallest of radius1 and radius2 will be the inner radius.
- center: Point — the center point of the star
- points: Number — the number of points of the star
- radius1: Number
- radius2: Number
Parameters:
- Path — the newly created path
Returns:
Example:
Creates a star shaped path item from the properties described by an object literal.
- object: Object — an object literal containing properties describing the path’s attributes
Parameters:
- Path — the newly created path
Returns:
Example:
Properties
Specifies whether the path is closed. If it is closed, Paper.js connects the first and last segments.
- Boolean
Type:
Example:
The approximate length of the path.
Read only.
- Number
Type:
The area that the path’s geometry is covering. Self-intersecting paths can contain sub-areas that cancel each other out.
Read only.
- Number
Type:
Specifies whether the path is oriented clock-wise.
- Boolean
Type:
Specifies whether the path and all its segments are selected. Cannot be true
on an empty path.
- Boolean
Type:
Example:A path is fully selected, if all of its segments are selected:
Methods
Adds one or more segments to the end of the segments array of this path.
- Segment — the added segment. This is not necessarily the same object, e.g. if the segment to be added already belongs to another path
Returns:
Example:Adding segments to a path using point objects:
Example:Adding segments to a path using arrays containing number pairs:
Example:Adding segments to a path using objects:
Example:Adding a segment with handles to a path:
Inserts one or more segments at a given index in the list of this path’s segments.
- index: Number — the index at which to insert the segment
- segment: Segment⟋Point — the segment or point to be inserted.
Parameters:
- Segment — the added segment. This is not necessarily the same object, e.g. if the segment to be added already belongs to another path
Returns:
Example:Inserting a segment:
Example:Inserting multiple segments:
Adds an array of segments (or types that can be converted to segments) to the end of the segments array.
- segments: Array of Segment objects
Parameters:
- Array of Segment objects — an array of the added segments. These segments are not necessarily the same objects, e.g. if the segment to be added already belongs to another path
Returns:
Example:Adding an array of Point objects:
Example:Adding an array of [x, y] arrays:
Example:Adding segments from one path to another:
Inserts an array of segments at a given index in the path’s segments array.
- index: Number — the index at which to insert the segments
- segments: Array of Segment objects — the segments to be inserted
Parameters:
- Array of Segment objects — an array of the added segments. These segments are not necessarily the same objects, e.g. if the segment to be added already belongs to another path
Returns:
Removes the segments from the specified from
index to the to
index from the path’s segments array.
- from: Number — the beginning index, inclusive
- to: Number — the ending index, exclusive — optional, default: segments.length
Parameters:
- Array of Segment objects — an array containing the removed segments
Returns:
Example:Removing segments from a path:
Checks if any of the curves in the path have curve handles set.
- Boolean — true if the path has curve handles set, false otherwise
Returns:
- segment.hasHandles()
- curve.hasHandles()
See also:
Clears the path’s handles by setting their coordinates to zero, turning the path into a polygon (or a polyline if it isn’t closed).
Splits the path at the given offset or location. After splitting, the path will be open. If the path was open already, splitting will result in two paths.
- location: Number⟋CurveLocation — the offset or location at which to split the path
Parameters:
- Path — the newly created path after splitting, if any
Returns:
Example:
Example:Splitting an open path Draw a V shaped path:
Example:Splitting a closed path
- index:
- time:
Parameters:
Joins the path with the specified path, which will be removed in the process.
- path: Path — the path to join this path with
Parameters:
- Path — the joined path
Returns:
Example:Joining two paths:
Example:Joining two paths that share a point at the start or end of their segments array:
Example:Joining two paths that connect at two points:
Reduces the path by removing curves that have a length of 0, and unnecessary segments between two collinear flat curves.
- options:
Parameters:
Attempts to create a new shape item with same geometry as this path item, and inherits all settings from it, similar to item.clone().
-
insert:
Boolean
— specifies whether the new shape should be inserted into the scene graph. When set to
true
, it is inserted above the path item — optional, default: true
Parameters:
-
Shape — the newly created shape item with the same geometry as this path item if it can be matched,
null
otherwise
Returns:
- shape.toPath(insert)
See also:
Positions on Paths and Curves
Returns the curve location of the specified point if it lies on the path, null
otherwise.
- point: Point — the point on the path
Parameters:
- CurveLocation — the curve location of the specified point
Returns:
Returns the length of the path from its beginning up to up to the specified point if it lies on the path, null
otherwise.
- point: Point — the point on the path
Parameters:
- Number — the length of the path up to the specified point
Returns:
Returns the curve location of the specified offset on the path.
-
offset:
Number
— the offset on the path, where
0
is at the beginning of the path and path.length at the end
Parameters:
- CurveLocation — the curve location at the specified offset
Returns:
Calculates the point on the path at the given offset.
-
offset:
Number
— the offset on the path, where
0
is at the beginning of the path and path.length at the end
Parameters:
- Point — the point at the given offset
Returns:
Example:Finding the point on a path at a given offset:
Example:Iterating over the length of a path:
Calculates the normalized tangent vector of the path at the given offset.
-
offset:
Number
— the offset on the path, where
0
is at the beginning of the path and path.length at the end
Parameters:
- Point — the normalized tangent vector at the given offset
Returns:
Example:Working with the tangent vector at a given offset:
Example:Iterating over the length of a path:
Calculates the normal vector of the path at the given offset.
-
offset:
Number
— the offset on the path, where
0
is at the beginning of the path and path.length at the end
Parameters:
- Point — the normal vector at the given offset
Returns:
Example:Working with the normal vector at a given offset:
Example:Iterating over the length of a path:
Calculates the weighted tangent vector of the path at the given offset.
-
offset:
Number
— the offset on the path, where
0
is at the beginning of the path and path.length at the end
Parameters:
- Point — the weighted tangent vector at the given offset
Returns:
Calculates the weighted normal vector of the path at the given offset.
-
offset:
Number
— the offset on the path, where
0
is at the beginning of the path and path.length at the end
Parameters:
- Point — the weighted normal vector at the given offset
Returns:
Calculates the curvature of the path at the given offset. Curvatures indicate how sharply a path changes direction. A straight line has zero curvature, where as a circle has a constant curvature. The path’s radius at the given offset is the reciprocal value of its curvature.
-
offset:
Number
— the offset on the path, where
0
is at the beginning of the path and path.length at the end
Parameters:
- Number — the normal vector at the given offset
Returns:
Properties inherited from Item
The unique id of the item.
Read only.
- Number
Type:
The class name of the item as a string.
- 'Group', 'Layer', 'Path', 'CompoundPath', 'Shape', 'Raster', 'SymbolItem', 'PointText'
Values:
- String
Type:
The name of the item. If the item has a name, it can be accessed by name through its parent’s children list.
- String
Type:
Example:
The path style of the item.
- Style
Type:
Example:Applying several styles to an item in one go, by passing an object to its style property:
Example:Copying the style of another item:
Example:Applying the same style object to multiple items:
Specifies whether the item is visible. When set to false
, the item won’t be drawn.
- true
Default:
- Boolean
Type:
Example:Hiding an item:
The blend mode with which the item is composited onto the canvas. Both the standard canvas compositing modes, as well as the new CSS blend modes are supported. If blend-modes cannot be rendered natively, they are emulated. Be aware that emulation can have an impact on performance.
- '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', 'source- over', 'source-in', 'source-out', 'source-atop', 'destination-over', 'destination-in', 'destination-out', 'destination-atop', 'lighter', 'darker', 'copy', 'xor'
Values:
- 'normal'
Default:
- String
Type:
Example:Setting an item's blend mode:
The opacity of the item as a value between 0
and 1
.
- 1
Default:
- Number
Type:
Example:Making an item 50% transparent:
Specifies whether the item is selected. This will also return true
for Group items if they are partially selected, e.g. groups containing selected or partially selected paths.
Paper.js draws the visual outlines of selected items on top of your project. This can be useful for debugging, as it allows you to see the construction of paths, position of path curves, individual segment points and bounding boxes of symbol and raster items.
- Boolean
Type:
Example:Selecting an item:
Specifies whether the item defines a clip mask. This can only be set on paths, compound paths, and text frame objects, and only if the item is already contained within a clipping group.
- Boolean
Type:
A plain javascript object which can be used to store arbitrary data on the item.
- Object
Type:
Example:
var path = new Path();
path.data.remember = 'milk';
Example:
var path = new Path();
path.data.malcolm = new Point(20, 30);
console.log(path.data.malcolm.x); // 20
Example:
var path = new Path();
path.data = {
home: 'Omicron Theta',
found: 2338,
pets: ['Spot']
};
console.log(path.data.pets.length); // 1
Example:
var path = new Path({
data: {
home: 'Omicron Theta',
found: 2338,
pets: ['Spot']
}
});
console.log(path.data.pets.length); // 1
Position and Bounding Boxes
The item’s position within the parent item’s coordinate system. By default, this is the rectangle.center of the item’s bounds rectangle.
- Point
Type:
Example:Changing the position of a path:
Example:Changing the x coordinate of an item's position:
The item’s pivot point specified in the item coordinate system, defining the point around which all transformations are hinging. This is also the reference point for position. By default, it is set to null
, meaning the rectangle.center of the item’s bounds rectangle is used as pivot.
- Point
Type:
The bounding rectangle of the item including stroke width.
- Rectangle
Type:
The bounding rectangle of the item including handles.
- Rectangle
Type:
The item’s transformation matrix, defining position and dimensions in relation to its parent item in which it is contained.
- Matrix
Type:
The item’s global transformation matrix in relation to the global project coordinate space. Note that the view’s transformations resulting from zooming and panning are not factored in.
Read only.
- Matrix
Type:
The item’s global matrix in relation to the view coordinate space. This means that the view’s transformations resulting from zooming and panning are factored in.
Read only.
- Matrix
Type:
Controls whether the transformations applied to the item (e.g. through transform(matrix), rotate(angle), scale(scale), etc.) are stored in its matrix property, or whether they are directly applied to its contents or children (passed on to the segments in Path items, the children of Group items, etc.).
- Boolean
Type:
Project Hierarchy
The item that this item is contained within.
- Item
Type:
Example:
var path = new Path();
// New items are placed in the active layer:
console.log(path.parent == project.activeLayer); // true
var group = new Group();
group.addChild(path);
// Now the parent of the path has become the group:
console.log(path.parent == group); // true
Example:Setting the parent of the item to another item
var path = new Path();
// New items are placed in the active layer:
console.log(path.parent == project.activeLayer); // true
var group = new Group();
group.parent = path;
// Now the parent of the path has become the group:
console.log(path.parent == group); // true
// The path is now contained in the children list of group:
console.log(group.children[0] == path); // true
Example:Setting the parent of an item in the constructor
var group = new Group();
var path = new Path({
parent: group
});
// The parent of the path is the group:
console.log(path.parent == group); // true
// The path is contained in the children list of group:
console.log(group.children[0] == path); // true
The children items contained within this item. Items that define a name can also be accessed by name.
Please note: The children array should not be modified directly using array functions. To remove single items from the children list, use item.remove(), to remove all items from the children list, use item.removeChildren(). To add items to the children list, use item.addChild(item) or item.insertChild(index, item).
- Array of Item objects
Type:
Example:Accessing items in the children array:
Example:Accessing children by name:
Example:Passing an array of items to item.children:
The first item contained within this item. This is a shortcut for accessing item.children[0]
.
Read only.
- Item
Type:
The last item contained within this item.This is a shortcut for accessing item.children[item.children.length - 1]
.
Read only.
- Item
Type:
The index of this item within the list of its parent’s children.
Read only.
- Number
Type:
Stroke Style
The width of the stroke.
- Number
Type:
Example:Setting an item's stroke width:
The shape to be used at the beginning and end of open Path items, when they have a stroke.
- 'round', 'square', 'butt'
Values:
- 'butt'
Default:
- String
Type:
Example:A look at the different stroke caps:
The shape to be used at the segments and corners of Path items when they have a stroke.
- 'miter', 'round', 'bevel'
Values:
- 'miter'
Default:
- String
Type:
Example:A look at the different stroke joins:
The dash offset of the stroke.
- 0
Default:
- Number
Type:
Specifies whether the stroke is to be drawn taking the current affine transformation into account (the default behavior), or whether it should appear as a non-scaling stroke.
- true
Default:
- Boolean
Type:
Specifies an array containing the dash and gap lengths of the stroke.
- []
Default:
- Array
Type:
Example:
The miter limit of the stroke. When two line segments meet at a sharp angle and miter joins have been specified for item.strokeJoin, it is possible for the miter to extend far beyond the item.strokeWidth of the path. The miterLimit imposes a limit on the ratio of the miter length to the item.strokeWidth.
- 10
Default:
- Number
Type:
Fill Style
The fill-rule with which the shape gets filled. Please note that only modern browsers support fill-rules other than 'nonzero'
.
- 'nonzero', 'evenodd'
Values:
- 'nonzero'
Default:
- String
Type:
Shadow Style
The shadow’s blur radius.
- 0
Default:
- Number
Type:
Selection Style
The color the item is highlighted with when selected. If the item does not specify its own color, the color defined by its layer is used instead.
- Color
Type:
Event Handlers
Item level handler function to be called on each frame of an animation. The function receives an event object which contains information about the frame event:
- Function
Type:
- event.count: Number — the number of times the frame event was fired
- event.time: Number — the total amount of time passed since the first frame event in seconds
- event.delta: Number — the time passed in seconds since the last frame event
Options:
- view.onFrame
See also:
Example:Creating an animation:
The function to be called when the mouse button is pushed down on the item. The function receives a MouseEvent object which contains information about the mouse event. Note that such mouse events bubble up the scene graph hierarchy and will reach the view, unless they are stopped with event.stopPropagation() or by returning false
from the handler.
- Function
Type:
- view.onMouseDown
See also:
Example:Press the mouse button down on the circle shaped path, to make it red:
Example:Press the mouse on the circle shaped paths to remove them:
The function to be called when the mouse position changes while the mouse is being dragged over the item. The function receives a MouseEvent object which contains information about the mouse event. Note that such mouse events bubble up the scene graph hierarchy and will reach the view, unless they are stopped with event.stopPropagation() or by returning false
from the handler.
- Function
Type:
- view.onMouseDrag
See also:
Example:Press and drag the mouse on the blue circle to move it:
The function to be called when the mouse button is released over the item. The function receives a MouseEvent object which contains information about the mouse event. Note that such mouse events bubble up the scene graph hierarchy and will reach the view, unless they are stopped with event.stopPropagation() or by returning false
from the handler.
- Function
Type:
- view.onMouseUp
See also:
Example:Release the mouse button over the circle shaped path, to make it red:
The function to be called when the mouse clicks on the item. The function receives a MouseEvent object which contains information about the mouse event. Note that such mouse events bubble up the scene graph hierarchy and will reach the view, unless they are stopped with event.stopPropagation() or by returning false
from the handler.
- Function
Type:
- view.onClick
See also:
Example:Click on the circle shaped path, to make it red:
Example:Click on the circle shaped paths to remove them:
The function to be called when the mouse double clicks on the item. The function receives a MouseEvent object which contains information about the mouse event. Note that such mouse events bubble up the scene graph hierarchy and will reach the view, unless they are stopped with event.stopPropagation() or by returning false
from the handler.
- Function
Type:
- view.onDoubleClick
See also:
Example:Double click on the circle shaped path, to make it red:
Example:Double click on the circle shaped paths to remove them:
The function to be called repeatedly while the mouse moves over the item. The function receives a MouseEvent object which contains information about the mouse event. Note that such mouse events bubble up the scene graph hierarchy and will reach the view, unless they are stopped with event.stopPropagation() or by returning false
from the handler.
- Function
Type:
- view.onMouseMove
See also:
Example:Move over the circle shaped path, to change its opacity:
The function to be called when the mouse moves over the item. This function will only be called again, once the mouse moved outside of the item first. The function receives a MouseEvent object which contains information about the mouse event. Note that such mouse events bubble up the scene graph hierarchy and will reach the view, unless they are stopped with event.stopPropagation() or by returning false
from the handler.
- Function
Type:
- view.onMouseEnter
See also:
Example:When you move the mouse over the item, its fill color is set to red. When you move the mouse outside again, its fill color is set back to black.
Example:When you click the mouse, you create new circle shaped items. When you move the mouse over the item, its fill color is set to red. When you move the mouse outside again, its fill color is set back to black.
The function to be called when the mouse moves out of the item. The function receives a MouseEvent object which contains information about the mouse event. Note that such mouse events bubble up the scene graph hierarchy and will reach the view, unless they are stopped with event.stopPropagation() or by returning false
from the handler.
- Function
Type:
- view.onMouseLeave
See also:
Example:Move the mouse over the circle shaped path and then move it out of it again to set its fill color to red:
Methods inherited from Item
Sets those properties of the passed object literal on this item to the values defined in the object literal, if the item has property of the given name (or a setter defined for it).
- props: Object
Parameters:
- Item — the item itself
Returns:
Example:Setting properties through an object literal
Clones the item within the same project and places the copy above the item.
- insert: undefined — specifies whether the copy should be inserted into the scene graph. When set to
true
, it is inserted above the original — default: true - deep: undefined — specifies whether the item’s children should also be cloned — default: true
Options:
- options: Object — optional, default: { insert: true, deep: true }
Parameters:
- Item — the newly cloned item
Returns:
Example:Cloning items:
Copies the content of the specified item over to this item.
- source: Item — the item to copy the content from
Parameters:
Copies all attributes of the specified item over to this item. This includes its style, visibility, matrix, pivot, blend-mode, opacity, selection state, data, name, etc.
- source: Item — the item to copy the attributes from
- excludeMatrix: Boolean — whether to exclude the transformation matrix when copying all attributes
Parameters:
Rasterizes the item into a newly created Raster object. The item itself is not removed after rasterization.
-
resolution:
Number
— the resolution of the raster in pixels per inch (DPI). If not specified, the value of
view.resolution
is used. — optional, default: view.resolution -
insert:
Boolean
— specifies whether the raster should be inserted into the scene graph. When set to
true
, it is inserted above the original — optional, default: true
Parameters:
- Raster — the newly created raster item
Returns:
Example:Rasterizing an item:
Checks whether the item’s geometry contains the given point.
- point: Point — the point to check for
Parameters:
Example:Click within and outside the star below Create a star shaped path:
- rect: Rectangle — the rectangle to check against
Parameters:
- Boolean
Returns:
- item: Item — the item to check against
Parameters:
- Boolean
Returns:
Perform a hit-test on the item (and its children, if it is a Group or Layer) at the location of the specified point.
The options object allows you to control the specifics of the hit-test and may contain a combination of the following values:
- options.tolerance: Number — the tolerance of the hit-test — default: paperScope.settings.hitTolerance
- options.class: Function — only hit-test again a certain item class and its sub-classes: Group, Layer, Path, CompoundPath, Shape, Raster, SymbolItem, PointText, …
- options.fill: Boolean — hit-test the fill of items — default: true
- options.stroke: Boolean — hit-test the stroke of path items, taking into account the setting of stroke color and width — default: true
- options.segments: Boolean — hit-test for segment.point of Path items — default: true
- options.curves: Boolean — hit-test the curves of path items, without taking the stroke color or width into account
- options.handles: Boolean — hit-test for the handles (segment.handleIn / segment.handleOut) of path segments.
- options.ends: Boolean — only hit-test for the first or last segment points of open path items
- options.bounds: Boolean — hit-test the corners and side-centers of the bounding rectangle of items (item.bounds)
- options.center: Boolean — hit-test the rectangle.center of the bounding rectangle of items (item.bounds)
- options.guides: Boolean — hit-test items that have Item#guide set to
true
- options.selected: Boolean — only hit selected items
Options:
- point: Point — the point where the hit-test should be performed
- options: Object — optional, default: { fill: true, stroke: true, segments: true, tolerance: settings.hitTolerance }
Parameters:
-
HitResult — a hit result object that contains more information about what exactly was hit or
null
if nothing was hit
Returns:
Fetching and matching items
Checks whether the item matches the criteria described by the given object, by iterating over all of its properties and matching against their values through matches(name, compare).
See project.getItems(match) for a selection of illustrated examples.
- match: Object⟋Function — the criteria to match against
Parameters:
- Boolean — true if the item matches all the criteria, false otherwise
Returns:
- getItems(match)
See also:
Checks whether the item matches the given criteria. Extended matching is possible by providing a compare function or a regular expression. Matching points, colors only work as a comparison of the full object, not partial matching (e.g. only providing the x-coordinate to match all points with that x-value). Partial matching does work for item.data.
See project.getItems(match) for a selection of illustrated examples.
- name: String — the name of the state to match against
- compare: Object — the value, function or regular expression to compare against
Parameters:
- Boolean — true if the item matches the state, false otherwise
Returns:
- getItems(match)
See also:
Fetch the descendants (children or children of children) of this item that match the properties in the specified object. Extended matching is possible by providing a compare function or regular expression. Matching points, colors only work as a comparison of the full object, not partial matching (e.g. only providing the x- coordinate to match all points with that x-value). Partial matching does work for item.data.
Matching items against a rectangular area is also possible, by setting either match.inside
or match.overlapping
to a rectangle describing the area in which the items either have to be fully or partly contained.
See project.getItems(match) for a selection of illustrated examples.
- match.recursive: Boolean — whether to loop recursively through all children, or stop at the current level — default: true
- match.match: Function — a match function to be called for each item, allowing the definition of more flexible item checks that are not bound to properties. If no other match properties are defined, this function can also be passed instead of the
match
object - match.class: Function — the constructor function of the item type to match against
- match.inside: Rectangle — the rectangle in which the items need to be fully contained
- match.overlapping: Rectangle — the rectangle with which the items need to at least partly overlap
Options:
- match: Object⟋Function — the criteria to match against
Parameters:
- Array of Item objects — the list of matching descendant items
Returns:
- matches(match)
See also:
Fetch the first descendant (child or child of child) of this item that matches the properties in the specified object. Extended matching is possible by providing a compare function or regular expression. Matching points, colors only work as a comparison of the full object, not partial matching (e.g. only providing the x- coordinate to match all points with that x-value). Partial matching does work for item.data. See project.getItems(match) for a selection of illustrated examples.
- match: Object⟋Function — the criteria to match against
Parameters:
- Item — the first descendant item matching the given criteria
Returns:
- getItems(match)
See also:
Importing / Exporting JSON and SVG
Exports (serializes) the item with its content and child items to a JSON data string.
- options.asString: Boolean — whether the JSON is returned as a
Object
or aString
— default: true - options.precision: Number — the amount of fractional digits in numbers used in JSON data — default: 5
Options:
- options: Object — the serialization options — optional
Parameters:
- String — the exported JSON data
Returns:
Imports (deserializes) the stored JSON data into this item. If the data describes an item of the same class or a parent class of the item, the data is imported into the item itself. If not, the imported item is added to this item’s item.children list. Note that not all type of items can have children.
- json: String — the JSON data to import from
Parameters:
Exports the item with its content and child items as an SVG DOM.
- options.asString: Boolean — whether a SVG node or a
String
is to be returned — default: false - options.precision: Number — the amount of fractional digits in numbers used in SVG data — default: 5
- options.matchShapes: Boolean — whether path items should tried to be converted to SVG shape items (rect, circle, ellipse, line, polyline, polygon), if their geometries match — default: false
- options.embedImages: Boolean — whether raster images should be embedded as base64 data inlined in the xlink:href attribute, or kept as a link to their external URL. — default: true
Options:
- options: Object — the export options — optional
Parameters:
- SVGElement — the item converted to an SVG node
Returns:
Converts the provided SVG content into Paper.js items and adds them to the this item’s children list. Note that the item is not cleared first. You can call item.removeChildren() to do so.
- options.expandShapes: Boolean — whether imported shape items should be expanded to path items — default: false
- options.onLoad: Function — the callback function to call once the SVG content is loaded from the given URL receiving two arguments: the converted
item
and the originalsvg
data as a string. Only required when loading from external files. - options.applyMatrix: Boolean — whether imported items should have their transformation matrices applied to their contents or not — default: paperScope.settings.applyMatrix
Options:
- svg: SVGElement⟋String — the SVG content to import, either as a SVG DOM node, a string containing SVG content, or a string describing the URL of the SVG file to fetch.
- options: Object — the import options — optional
Parameters:
- Item — the newly created Paper.js item containing the converted SVG content
Returns:
Imports the provided external SVG file, converts it into Paper.js items and adds them to the this item’s children list. Note that the item is not cleared first. You can call item.removeChildren() to do so.
- svg: SVGElement⟋String — the URL of the SVG file to fetch.
-
onLoad:
Function
— the callback function to call once the SVG content is loaded from the given URL receiving two arguments: the converted
item
and the originalsvg
data as a string. Only required when loading from external files.
Parameters:
- Item — the newly created Paper.js item containing the converted SVG content
Returns:
Hierarchy Operations
Inserts the specified item as a child of this item at the specified index in its children list. You can use this function for groups, compound paths and layers.
- index: Number — the index at which to insert the item
- item: Item — the item to be inserted as a child
Parameters:
-
Item — the inserted item, or
null
if inserting was not possible
Returns:
Adds the specified items as children of this item at the end of the its children list. You can use this function for groups, compound paths and layers.
- items: Array of Item objects — the items to be added as children
Parameters:
-
Array of Item objects — the added items, or
null
if adding was not possible
Returns:
Inserts the specified items as children of this item at the specified index in its children list. You can use this function for groups, compound paths and layers.
- index: Number
- items: Array of Item objects — the items to be appended as children
Parameters:
-
Array of Item objects — the inserted items, or
null
if inserted was not possible
Returns:
Sends this item to the back of all other items within the same parent.
Brings this item to the front of all other items within the same parent.
Inserts the specified item as a child of this item by appending it to the list of children and moving it above all other children. You can use this function for groups, compound paths and layers.
- item: Item — the item to be appended as a child
Parameters:
Inserts the specified item as a child of this item by appending it to the list of children and moving it below all other children. You can use this function for groups, compound paths and layers.
- item: Item — the item to be appended as a child
Parameters:
Moves this item above the specified item.
- item: Item — the item above which it should be moved
Parameters:
- Boolean — true if it was moved, false otherwise
Returns:
Moves the item below the specified item.
- item: Item — the item below which it should be moved
Parameters:
- Boolean — true if it was moved, false otherwise
Returns:
When passed a project, copies the item to the project, or duplicates it within the same project. When passed an item, copies the item into the specified item.
- owner: Project⟋Layer⟋Group⟋CompoundPath — the item or project to copy the item to
Parameters:
- Item — the new copy of the item
Returns:
Removes the item and all its children from the project. The item is not destroyed and can be inserted again after removal.
- Boolean — true if the item was removed, false otherwise
Returns:
Replaces this item with the provided new item which will takes its place in the project hierarchy instead.
- item:
Parameters:
- Boolean — true if the item was replaced, false otherwise
Returns:
Removes the children from the specified start
index to and excluding the end
index from the parent’s children array.
- start: Number — the beginning index, inclusive
- end: Number — the ending index, exclusive — optional, default: children.length
Parameters:
- Array of Item objects — an array containing the removed items
Returns:
Reverses the order of the item’s children
Tests
Style Tests
Checks whether the item has a fill.
- Boolean — true if the item has a fill, false otherwise
Returns:
Checks whether the item has a stroke.
- Boolean — true if the item has a stroke, false otherwise
Returns:
Checks whether the item has a shadow.
- Boolean — true if the item has a shadow, false otherwise
Returns:
Hierarchy Tests
Checks if the item contains any children items.
- Boolean — true it has one or more children, false otherwise
Returns:
Checks whether the item and all its parents are inserted into scene graph or not.
- Boolean — true if the item is inserted into the scene graph, false otherwise
Returns:
Checks if this item is above the specified item in the stacking order of the project.
- item: Item — the item to check against
Parameters:
- Boolean — true if it is above the specified item, false otherwise
Returns:
Checks if the item is below the specified item in the stacking order of the project.
- item: Item — the item to check against
Parameters:
- Boolean — true if it is below the specified item, false otherwise
Returns:
Checks whether the specified item is the parent of the item.
- item: Item — the item to check against
Parameters:
- Boolean — true if it is the parent of the item, false otherwise
Returns:
Checks whether the specified item is a child of the item.
- item: Item — the item to check against
Parameters:
- Boolean — true it is a child of the item, false otherwise
Returns:
Checks if the item is contained within the specified item.
- item: Item — the item to check against
Parameters:
- Boolean — true if it is inside the specified item, false otherwise
Returns:
Checks if the item is an ancestor of the specified item.
- item: Item — the item to check against
Parameters:
- Boolean — true if the item is an ancestor of the specified item, false otherwise
Returns:
Checks if the item is an a sibling of the specified item.
- item: Item — the item to check against
Parameters:
- Boolean — true if the item is aa sibling of the specified item, false otherwise
Returns:
Checks whether the item is grouped with the specified item.
- item: Item
Parameters:
- Boolean — true if the items are grouped together, false otherwise
Returns:
Transform Functions
Translates (moves) the item by the given offset views.
- delta: Point — the offset to translate the item by
Parameters:
Rotates the item by a given angle around the given center point.
Angles are oriented clockwise and measured in degrees.
- angle: Number — the rotation angle
- center: Point — optional, default: item.position
Parameters:
- matrix.rotate(angle[, center])
See also:
Example:Rotating an item:
Example:Rotating an item around a specific point:
Scales the item by the given value from its center point, or optionally from a supplied point.
- scale: Number — the scale factor
- center: Point — optional, default: item.position
Parameters:
Example:Scaling an item from its center point:
Example:Scaling an item from a specific point:
Scales the item by the given values from its center point, or optionally from a supplied point.
- hor: Number — the horizontal scale factor
- ver: Number — the vertical scale factor
- center: Point — optional, default: item.position
Parameters:
Example:Scaling an item horizontally by 300%:
Shears the item by the given value from its center point, or optionally by a supplied point.
- shear: Point — the horziontal and vertical shear factors as a point
- center: Point — optional, default: item.position
Parameters:
- matrix.shear(shear[, center])
See also:
Shears the item by the given values from its center point, or optionally by a supplied point.
- hor: Number — the horizontal shear factor
- ver: Number — the vertical shear factor
- center: Point — optional, default: item.position
Parameters:
- matrix.shear(hor, ver[, center])
See also:
Skews the item by the given angles from its center point, or optionally by a supplied point.
- skew: Point — the horziontal and vertical skew angles in degrees
- center: Point — optional, default: item.position
Parameters:
- matrix.shear(skew[, center])
See also:
Skews the item by the given angles from its center point, or optionally by a supplied point.
- hor: Number — the horizontal skew angle in degrees
- ver: Number — the vertical sskew angle in degrees
- center: Point — optional, default: item.position
Parameters:
- matrix.shear(hor, ver[, center])
See also:
Transform the item.
- matrix: Matrix — the matrix by which the item shall be transformed
Parameters:
Transform the item so that its bounds fit within the specified rectangle, without changing its aspect ratio.
- rectangle: Rectangle
- fill: Boolean — optional, default: false
Parameters:
Example:Fitting an item to the bounding rectangle of another item's bounding rectangle:
Example:Fitting an item to the bounding rectangle of another item's bounding rectangle with the fill parameter set to true:
Example:Fitting an item to the bounding rectangle of the view
Event Handling
Attaches an event handler to the item.
- type: String — the type of event: ‘frame’, mousedown’, ‘mouseup’, ‘mousedrag’, ‘click’, ‘doubleclick’, ‘mousemove’, ‘mouseenter’, ‘mouseleave’
- function: Function — the function to be called when the event occurs, receiving a MouseEvent or Event object as its sole argument
Parameters:
- Item — this item itself, so calls can be chained
Returns:
Example:Change the fill color of the path to red when the mouse enters its shape and back to black again, when it leaves its shape.
Attaches one or more event handlers to the item.
- object: Object — an object literal containing one or more of the following properties: frame, mousedown, mouseup, mousedrag, click, doubleclick, mousemove, mouseenter, mouseleave
Parameters:
- Item — this item itself, so calls can be chained
Returns:
Example:Change the fill color of the path to red when the mouse enters its shape and back to black again, when it leaves its shape.
Example:When you click the mouse, you create new circle shaped items. When you move the mouse over the item, its fill color is set to red. When you move the mouse outside again, its fill color is set black.
Detach an event handler from the item.
- type: String — the type of event: ‘frame’, mousedown’, ‘mouseup’, ‘mousedrag’, ‘click’, ‘doubleclick’, ‘mousemove’, ‘mouseenter’, ‘mouseleave’
- function: Function — the function to be detached
Parameters:
- Item — this item itself, so calls can be chained
Returns:
Detach one or more event handlers to the item.
- object: Object — an object literal containing one or more of the following properties: frame, mousedown, mouseup, mousedrag, click, doubleclick, mousemove, mouseenter, mouseleave
Parameters:
- Item — this item itself, so calls can be chained
Returns:
Emit an event on the item.
- type: String — the type of event: ‘frame’, mousedown’, ‘mouseup’, ‘mousedrag’, ‘click’, ‘doubleclick’, ‘mousemove’, ‘mouseenter’, ‘mouseleave’
- event: Object — an object literal containing properties describing the event
Parameters:
- Boolean — true if the event had listeners, false otherwise
Returns:
Check if the item has one or more event handlers of the specified type.
- type: String — the type of event: ‘frame’, mousedown’, ‘mouseup’, ‘mousedrag’, ‘click’, ‘doubleclick’, ‘mousemove’, ‘mouseenter’, ‘mouseleave’
Parameters:
- Boolean — true if the item has one or more event handlers of the specified type, false otherwise
Returns:
Remove On Event
Removes the item when the events specified in the passed options object occur.
- options.move: undefined — {Boolean) remove the item when the next tool.onMouseMove event is fired.
- options.drag: undefined — {Boolena) remove the item when the next tool.onMouseDrag event is fired.
- options.down: undefined — {Boolean) remove the item when the next tool.onMouseDown event is fired.
- options.up: undefined — {Boolean) remove the item when the next tool.onMouseUp event is fired.
Options:
- options: Object
Parameters:
Example:Click and drag below:
Removes the item when the next tool.onMouseDown event is fired.
Example:Click a few times below:
Properties inherited from PathItem
The path’s geometry, formatted as SVG style path data.
- String
Type:
Methods inherited from PathItem
Boolean Path Operations
Splits the geometry of this path along the geometry of the specified path returns the result as a new group item. This is equivalent to calling subtract(path) and subtract(path) and putting the results into a new group.
- path: PathItem — the path to divide by
Parameters:
- Group — the resulting group item
Returns:
Path Intersections and Locations
Returns all intersections between two PathItem items as an array of CurveLocation objects. CompoundPath items are also supported.
- path: PathItem — the other item to find the intersections with
- include: Function — a callback function that can be used to filter out undesired locations right while they are collected. When defined, it shall return true to include a location, false otherwise. — optional
Parameters:
- Array of CurveLocation objects — the locations of all intersection between the paths
Returns:
- getCrossings(path)
See also:
Example:Finding the intersections between two paths
Returns all crossings between two PathItem items as an array of CurveLocation objects. CompoundPath items are also supported. Crossings are intersections where the paths actually are crossing each other, as opposed to simply touching.
- path: PathItem — the other item to find the crossings with
Parameters:
- getIntersections(path)
See also:
Returns the nearest location on the path item to the specified point.
- point: Point — the point for which we search the nearest location
Parameters:
- CurveLocation — the location on the path that’s the closest to the specified point
Returns:
Path Manipulation
Reverses the orientation of the path item. When called on CompoundPath items, each of the nested paths is reversed. On Path items, the sequence of path.segments is reversed.
Converts the curves in a path to straight lines with an even distribution of points. The distance between the produced segments is as close as possible to the value specified by the maxDistance
parameter.
- maxDistance: Number — the maximum distance between the points
Parameters:
Example:Flattening a circle shaped path:
Smooths the path item without changing the amount of segments in the path or moving the segments’ locations, by smoothing and adjusting the angle and length of the segments’ handles based on the position and distance of neighboring segments.
Smoothing works both for open paths and closed paths, and can be applied to the full path, as well as a sub-range of it. If a range is defined using the options.from
and options.to
properties, only the curve handles inside that range are touched. If one or both limits of the range are specified in negative indices, the indices are wrapped around the end of the curve. That way, a smoothing range in a close path can even wrap around the connection between the last and the first segment.
Four different smoothing methods are available:
-
'continuous'
smooths the path item by adjusting its curve handles so that the first and second derivatives of all involved curves are continuous across their boundaries.This method tends to result in the smoothest results, but does not allow for further parametrization of the handles.
-
'asymmetric'
is based on the same principle as'continuous'
but uses different factors so that the result is asymmetric. This used to the only method available until v0.10.0, and is currently still the default when no method is specified, for reasons of backward compatibility. It will eventually be removed. -
'catmull-rom'
uses the Catmull-Rom spline to smooth the segment.The optionally passed factor controls the knot parametrization of the algorithm:
0.0
: the standard, uniform Catmull-Rom spline0.5
: the centripetal Catmull-Rom spline, guaranteeing no self-intersections1.0
: the chordal Catmull-Rom spline
-
'geometric'
use a simple heuristic and empiric geometric method to smooth the segment’s handles. The handles were weighted, meaning that big differences in distances between the segments will lead to probably undesired results.The optionally passed factor defines the tension parameter (
0…1
), controlling the amount of smoothing as a factor by which to scale each handle.
- options.type: String — the type of smoothing method: ‘continuous’, ‘asymmetric’, ‘catmull-rom’, ‘geometric’ — default: ‘asymmetric’
- options.factor: Number — the factor parameterizing the smoothing method — default:
0.5
for'catmull-rom'
,0.4
for'geometric'
- options.from: Number⟋Segment⟋Curve — the segment or curve at which to start smoothing, if not the full path shall be smoothed (inclusive). This can either be a segment index, or a segment or curve object that is part of the path. If the passed number is negative, the index is wrapped around the end of the path.
- options.to: Number⟋Segment⟋Curve — the segment or curve to which the handles of the path shall be processed (inclusive). This can either be a segment index, or a segment or curve object that is part of the path. If the passed number is negative, the index is wrapped around the end of the path.
Options:
- options: Object — the smoothing options — optional
Parameters:
- segment.smooth([options])
See also:
Example:Smoothing a closed shape:
Example:
Example:Smoothing ranges of paths, using segments, curves or indices:
Fits a sequence of as few curves as possible through the path’s anchor points, ignoring the path items’s curve-handles, with an allowed maximum error. When called on CompoundPath items, each of the nested paths is simplified. On Path items, the path.segments array is processed and replaced by the resulting sequence of fitted curves.
This method can be used to process and simplify the point data received from a mouse or touch device.
- tolerance: Number — the allowed maximum error when fitting the curves through the segment points — optional, default: 2.5
Parameters:
- Boolean — true if the method was capable of fitting curves through the path’s segment points, false otherwise
Returns:
Example:Click and drag below to draw to draw a line, when you release the mouse, the is made smooth using path.simplify():
Interpolates between the two specified path items and uses the result as the geometry for this path item. The number of children and segments in the two paths involved in the operation should be the same.
Postscript Style Drawing Commands
On a normal empty Path, the point is simply added as the path’s first segment. If called on a CompoundPath, a new Path is created as a child and the point is added as its first segment.
- point: Point — the point in which to start the path
Parameters:
Adds a straight curve to the path, from the the last segment in the path to the specified point.
- point: Point — the destination point of the newly added straight curve
Parameters:
Adds an arc from the position of the last segment in the path, passing through the specified through
point, to the specified to
point, by adding one or more segments to the path.
- through: Point — the point where the arc should pass through
- to: Point — the point where the arc should end
Parameters:
Example:
Example:Interactive example. Click and drag in the view below:
Adds an arc from the position of the last segment in the path to the specified point, by adding one or more segments to the path.
- to: Point — the point where the arc should end
- clockwise: Boolean — specifies whether the arc should be drawn in clockwise direction — optional, default: true
Parameters:
Example:
Example:Interactive example. Click and drag in the view below:
Adds a curve from the last segment in the path through the specified through
point, to the specified destination point by adding one segment to the path.
- through: Point — the point through which the curve should pass
- to: Point — the destination point of the newly added curve
-
time:
Number
— the curve-time parameter at which the
through
point is to be located — optional, default: 0.5
Parameters:
Example:Interactive example. Move your mouse around the view below:
Adds a cubic bezier curve to the path, from the last segment to the specified destination point, with the curve itself defined by two specified handles.
- handle1: Point — the location of the first handle of the newly added curve in absolute coordinates, out of which the relative values for segment.handleOut of its first segment are calculated
- handle2: Point — the location of the second handle of the newly added curve in absolute coordinates, out of which the relative values for segment.handleIn of its second segment are calculated
- to: Point — the destination point of the newly added curve
Parameters:
Adds a quadratic bezier curve to the path, from the last segment to the specified destination point, with the curve itself defined by the specified handle.
Note that Paper.js only stores cubic curves, so the handle is actually converted.
- handle: Point — the location of the handle of the newly added quadratic curve in absolute coordinates, out of which the relative values for segment.handleOut of the resulting cubic curve’s first segment and segment.handleIn of its second segment are calculated
- to: Point — the destination point of the newly added curve
Parameters:
Closes the path. When closed, Paper.js connects the first and last segment of the path with an additional curve.
- join: Boolean — controls whether the method should attempt to merge the first segment with the last if they lie in the same location
Parameters:
- path.closed
See also:
Relative Drawing Commands
If called on a CompoundPath, a new Path is created as a child and a point is added as its first segment relative to the position of the last segment of the current path.
- to: Point
Parameters:
Adds a straight curve to the path, from the the last segment in the path to the to
vector specified relatively to it.
- point: Point — the vector describing the destination of the newly added straight curve
Parameters:
Example:
Example:Drawing a spiral using lineBy:
Adds an arc from the position of the last segment in the path, passing through the specified through
vector, to the specified to
vector, all specified relatively to it by these given vectors, by adding one or more segments to the path.
Adds an arc from the position of the last segment in the path to the to
vector specified relatively to it, by adding one or more segments to the path.
- to: Point — the vector where the arc should end
- clockwise: Boolean — specifies whether the arc should be drawn in clockwise direction — optional, default: true
Parameters:
Adds a curve from the last segment in the path through the specified through
vector, to the specified to
vector, all specified relatively to it by these given vectors, by adding one segment to the path.
Adds a cubic bezier curve to the path, from the last segment to the to the specified to
vector, with the curve itself defined by two specified handles.
Adds a quadratic bezier curve to the path, from the last segment to the specified destination point, with the curve itself defined by the specified handle.
Note that Paper.js only stores cubic curves, so the handle is actually converted.
- handle: Point — the handle of the newly added quadratic curve out of which the values for segment.handleOut of the resulting cubic curve’s first segment and segment.handleIn of its second segment are calculated
- to: Point — the destination point of the newly added curve
Parameters:
Paper.js v0.9.25 (develop)
Copyright © 2011—2016 Jürg Lehni & Jonathan Puckey. All Rights Reserved.