Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pocketsvg/PocketSVG
Easily convert your SVG files into CGPaths, CAShapeLayers, and UIBezierPaths
https://github.com/pocketsvg/PocketSVG
cocoapods ios macos objective-c svg svg-files swift
Last synced: 3 months ago
JSON representation
Easily convert your SVG files into CGPaths, CAShapeLayers, and UIBezierPaths
- Host: GitHub
- URL: https://github.com/pocketsvg/PocketSVG
- Owner: pocketsvg
- License: mit
- Created: 2012-08-02T11:27:10.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2024-09-13T11:26:05.000Z (5 months ago)
- Last Synced: 2024-10-29T12:39:35.583Z (4 months ago)
- Topics: cocoapods, ios, macos, objective-c, svg, svg-files, swift
- Language: Objective-C++
- Homepage:
- Size: 743 KB
- Stars: 1,664
- Watchers: 38
- Forks: 239
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# PocketSVG
[data:image/s3,"s3://crabby-images/a5ca1/a5ca13fe313f2c15bbf85c6192f78369723357da" alt="Platforms"](https://img.shields.io/badge/Platforms-macOS_iOS_tvOS_watchOS-green?style=flat-square)
[data:image/s3,"s3://crabby-images/1b633/1b63372ab03cdad09069cdb9fb38ac123c3b54e3" alt="Build Status"](https://github.com/pocketsvg/PocketSVG/actions)
[data:image/s3,"s3://crabby-images/4fa57/4fa571a6d8328c13f6f55d2220ae07b86b9859c3" alt="Swift Package Manager"](https://img.shields.io/badge/Swift_Package_Manager-compatible-orange?style=flat-square)
[data:image/s3,"s3://crabby-images/c108d/c108d7b4affb81d21d5403d829ed3fe1189cc3d9" alt="CocoaPods Compatible"](https://cocoapods.org/pods/PocketSVG)
[data:image/s3,"s3://crabby-images/2d180/2d1801ae7805458b91e18c5ac4d97d63da45be3a" alt="Carthage compatible"](https://github.com/Carthage/Carthage)
[data:image/s3,"s3://crabby-images/0e8bc/0e8bcb16e94fd376254ad717cc8adc67c3275805" alt="Code Coverage"](http://cocoadocs.org/docsets/PocketSVG)
[data:image/s3,"s3://crabby-images/3240c/3240c47e0246dc398c6cc19d466de2de68def232" alt="code size"](#)
[data:image/s3,"s3://crabby-images/b9a4a/b9a4a0d4bb5601dd28c82483b8e733888a5a2d76" alt="license"](https://github.com/pocketsvg/PocketSVG/blob/master/LICENSE)
[data:image/s3,"s3://crabby-images/51be9/51be93769e87217c52d36c719e5d04fb62fb4185" alt="Swift Forums"](https://youtu.be/iik25wqIuFo)A simple toolkit for displaying and manipulating SVGs on iOS and macOS in a performant manner.
The goal of this project is not to be a fully compliant SVG parser/renderer. But rather to use SVG as a format for serializing CG/UIPaths, meaning it only supports SVG features that can be represented by CG/UIPaths.
Thoroughly documented.
## Features
* Support for SVG elements: `path`, `line`, `polyline`, `polygon`, `rect`, `circle`, `ellipse`
* Support for SVG named colors.
* Fully working iOS and macOS demos.
* Straightforward API for typical SVG rendering as a `UIImageView`/`NSImageView` or `CALayer` subclass.
* Access every shape within your SVG as a `CGPath` for more fine-grained manipulation.## Installation
### Swift Package Manager
```swift
dependencies: [
.package(url: "https://github.com/pocketsvg/PocketSVG.git", .upToNextMajor(from: "2.6.0"))
]
```### Cocoapods
Add this to your Podfile:
```ruby
pod 'PocketSVG', '~> 2.6'
```Then run `pod install`
### Carthage
Add this to your Cartfile:
```
github "pocketsvg/PocketSVG" >= 2.7.2
```Then run `carthage update --use-xcframeworks`
## Usage
### Render an SVG file using `SVGImageView`
```swift
let url = Bundle.main.url(forResource: "tiger", withExtension: "svg")!
let svgImageView = SVGImageView.init(contentsOf: url)
svgImageView.frame = view.bounds
svgImageView.contentMode = .scaleAspectFit
view.addSubview(svgImageView)
```**Output**
data:image/s3,"s3://crabby-images/25af8/25af8fed15e684dccb53e13d291b800e3a1fe485" alt="image"Note: By default, SVGLayer has `shouldRasterize` set to `YES` when running on iOS. If you need to animate changes to the layer's transform you might want to reset that to `NO`.
### Manually render each path of an SVG file using `CAShapeLayer`
```swift
view.backgroundColor = .whitelet svgURL = Bundle.main.url(forResource: "tiger", withExtension: "svg")!
let paths = SVGBezierPath.pathsFromSVG(at: svgURL)
let tigerLayer = CALayer()
for (index, path) in paths.enumerated() {
let shapeLayer = CAShapeLayer()
shapeLayer.path = path.cgPath
if index%2 == 0 {
shapeLayer.fillColor = UIColor.black.cgColor
}
else if index%3 == 0 {
shapeLayer.fillColor = UIColor.darkGray.cgColor
}
else {
shapeLayer.fillColor = UIColor.gray.cgColor
}
tigerLayer.addSublayer(shapeLayer)
}var transform = CATransform3DMakeScale(0.4, 0.4, 1.0)
transform = CATransform3DTranslate(transform, 200, 400, 0)
tigerLayer.transform = transform
view.layer.addSublayer(tigerLayer)
```**Output**
data:image/s3,"s3://crabby-images/6e7c6/6e7c69c29e7c82dc8b1f033e38ebee2d45f3c7f1" alt="image"## Contributing
### Bug Reports & Feature Requests
Please use the [issue tracker](https://github.com/arielelkin/pocketsvg/issues) to report any bugs or file feature requests.
### Developing
PRs are welcome.