paperjs-round-corners
A library that provides methods to round the corners of paths in Paper.js.
Last updated
A library that provides methods to round the corners of paths in Paper.js.
Last updated
paperjs-round-corners
is a library that provides methods to round the corners of paths in Paper.js. It offers three different rounding methods: "simple-cubic", "cubic", and "arc", allowing you to achieve smooth and visually appealing rounded corners in your Paper.js projects.
For more information and usage examples, please visit the npm package page.
To install paperjs-round-corners
, use the following command:
Make sure you have Paper.js installed as well.
To use paperjs-round-corners
in your Paper.js project, follow these steps:
Import the library and Paper.js:
Set up your Paper.js project and create a path:
Round the corners of the path using one of the available methods:
Update the Paper.js view to see the rounded path:
.round(segment, roundness, options)
Rounds the corners of a single segment.
segment
(paper.Segment): The segment to be rounded.
roundness
(number): The roundness value. Must be positive.
options
(object): The rounding options.
method
(string): The rounding method. Can be "simple-cubic", "cubic", or "arc".
Returns true
if the rounding was successful, false
otherwise.
.roundMany(segments, roundness, options)
Rounds the corners of multiple segments.
segments
(paper.Segment[]): An array of segments to be rounded.
roundness
(number): The roundness value. Must be positive.
options
(object): The rounding options.
method
(string): The rounding method. Can be "simple-cubic", "cubic", or "arc".
Returns an array of boolean values indicating the success of rounding for each segment.
.roundMap(segments, options)
Rounds the corners of multiple segments using a Map.
segments
(Map<paper.Segment, number>): A Map where the keys are the segments to be rounded and the values are the corresponding roundness values.
options
(object): The rounding options.
method
(string): The rounding method. Can be "simple-cubic", "cubic", or "arc".
Returns a Map<paper.Segment, boolean> indicating the success of rounding for each segment.
Example usage:
simple-cubic
The "simple-cubic" method rounds the corner by dividing the path at a specified distance (roundness) before and after the segment. It creates a smooth curve using a simple cubic Bézier curve.
cubic
The "cubic" method rounds the corner by dividing the path at a specified distance (roundness) before and after the segment. It calculates the tangent lines at the division points and finds their intersection point to create a more precise and smoother curve using a cubic Bézier curve.
arc
The "arc" method rounds the corner using an arc with a specified radius. It creates offset paths (inward and outward) for the curves before and after the segment, finds the intersection point between the offset paths, and creates an arc using that intersection point as the center.