Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ainame/swift-webp
A thin libwebp wrapper in Swift that provides both encode/decode APIs
https://github.com/ainame/swift-webp
image-processing libwebp swift swift-wrapper webp
Last synced: 7 days ago
JSON representation
A thin libwebp wrapper in Swift that provides both encode/decode APIs
- Host: GitHub
- URL: https://github.com/ainame/swift-webp
- Owner: ainame
- License: mit
- Created: 2016-10-16T17:59:20.000Z (over 8 years ago)
- Default Branch: main
- Last Pushed: 2024-07-14T19:27:48.000Z (6 months ago)
- Last Synced: 2025-01-18T02:13:05.621Z (7 days ago)
- Topics: image-processing, libwebp, swift, swift-wrapper, webp
- Language: Swift
- Homepage:
- Size: 2.41 MB
- Stars: 166
- Watchers: 4
- Forks: 39
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Swift-WebP
Swift-WebP provides libwebp APIs in Swift manner for both encoding and decoding.
### Support Versions:
* libwebp: v1.2.0
* iOS Deployment Target: 13.0
* macOS Deployment Target: 11.0#### Features
* [x] Support mutiplatform; iOS, macOS, and Linux (swift-docker)
* [x] Support SPM
* [x] [Advanced Encoder API](https://developers.google.com/speed/webp/docs/api#advanced_encoding_api) - WebPEncoder, WebPEncoderConfig
* [x] [Advanced Decoding API](https://developers.google.com/speed/webp/docs/api#advanced_decoding_api) - WebPDecoder, WebPDecoderOptions
* [x] Image inspection for WebP files - WebPImageInspector#### TODO
* [ ] Progressively encoding/decoding option
* [ ] Animated WebP## Usage
#### Encoding
```swift
let image = UIImage(named: "demo")
let encoder = WebPEncoder()
let queue = DispatchQueue(label: "me.ainam.webp")// should encode in background
queue.async {
let data = try! encoder.encode(image, config: .preset(.picture, quality: 95))
// using webp binary data...
}
```#### Decoding
```swift
let data: Data = loadWebPData()
let encoder = WebPDecoder()
let queue = DispatchQueue(label: "me.ainam.webp")// should decode in background
queue.async {
var options = WebPDecoderOptions()
options.scaledWidth = Int(originalWidth / 2)
options.scaledHeight = Int(originalHeight / 2)
let cgImage = try! decoder.decode(data, options: options)
let webpImage = UIImage(cgImage: cgImage)DispatchQueue.main.async {
self.imageView.image = webpImage
}
}
```## Example
Please check example project
## Installation
Swift-WebP supports Swift Package Manager installation.
```
.package(url: "https://github.com/ainame/Swift-WebP.git", from: "0.5.0"),
```## Author
ainame
## License
Swift-WebP is available under the MIT license. See the LICENSE file for more info.