adamwulf/clippingbezier
ClippingBezier
ClippingBezier in Loose Leaf
The ClippingBezier.framework powers the scissors tool in Loose Leaf, and it allows for drawing to be clipped to any imported image scraps.
[clipped-pen-example.png]
Available as a Swift Package!
Install ClippingBezier in your project through Swift Package Manager as of v1.2.0!
Building the framework
This library will generate a proper static framework bundle that can be used in any iOS7+ project.
Including in your project
- Link against the built framework and the included PerformanceBezier framework
- Add "-ObjC++ -lstdc++" to the Other Linker Flags in the project's Settings
- #import <PerformanceBezier/PerformanceBezier.h>
- #import <ClippingBezier/ClippingBezier.h>
Dependencies
This library depends on the UIBezierPath performance improvements in the PerformanceBezier library.
Example
UIBezierPath* aClosedPath = /* some path */;
UIBezierPath* scissorPath = /* some other path */;
NSArray* subshapes = [aClosedPath uniqueShapesCreatedFromSlicingWithUnclosedPath:scissorPath];
for(DKUIBezierPathShape* shape in subshapes){
UIBezierPath* aClosedPathSlice = shape.fullPath;
}Screenshots
Find intersections between two UIBezierPaths:
[intersection-example.png]
Or find the component shapes generated from two path's intersections
[scissor-example.png]
Sample Application
The Xcode workspace includes a ClippingExampleApp project that shows a fully functional integration of the ClippingBezier framework. You can refer to this example for any questions about how to integrate into your app.
License
The ClippingBezier framework and sample code are provided under the MIT License.
Support This Project
- Download Loose Leaf
- Follow @adamwulf on twitter.
- Become a Github Sponsor and buy me a coffee ☕️ 😄
Package Metadata
Repository: adamwulf/clippingbezier
Default branch: main
README: README.md