Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/devxoul/swiftyimage
🎨 Generate image resources in Swift
https://github.com/devxoul/swiftyimage
image swift
Last synced: 3 days ago
JSON representation
🎨 Generate image resources in Swift
- Host: GitHub
- URL: https://github.com/devxoul/swiftyimage
- Owner: devxoul
- License: mit
- Created: 2015-07-14T06:23:58.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2022-02-17T03:14:09.000Z (about 3 years ago)
- Last Synced: 2025-02-17T09:45:22.277Z (3 days ago)
- Topics: image, swift
- Language: Swift
- Homepage:
- Size: 82 KB
- Stars: 1,086
- Watchers: 19
- Forks: 65
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
SwiftyImage
===========data:image/s3,"s3://crabby-images/3c1f7/3c1f7bc4b727b99d140f82f9f1552b87ccbb5bc0" alt="Swift"
[data:image/s3,"s3://crabby-images/2383e/2383eb1dffa5e5353ad98b00c778cea35d7449d6" alt="CocoaPods"](https://cocoapods.org/pods/SwiftyImage)
[data:image/s3,"s3://crabby-images/9e104/9e1041ea0c6a6129097d9b9e44b66837b5039c62" alt="CI"](http://github.com/devxoul/SwiftyImage/actions)The most sexy way to use images in Swift.
Features
--------* [x] [Create images with method chaining](#getting-started)
* [x] [Gradient fill and stroke](#methods-available)
* [x] [Create and manipulate images with CGContext](#play-with-cgcontext)
* [x] [Combine images with `+` operator](#image-operator)
* [x] iOS support
* [ ] macOS supportAt a Glance
-----------##### Creating Images
```swift
UIImage.size(width: 100, height: 100)
.color(.white)
.border(color: .red)
.border(width: 10)
.corner(radius: 20)
.image
```data:image/s3,"s3://crabby-images/468a1/468a175b6d1366bb77e6e34e015776c351136dc5" alt="sample1"
```swift
UIImage.resizable()
.color(.white)
.border(color: .blue)
.border(width: 5)
.corner(radius: 10)
.image
```data:image/s3,"s3://crabby-images/5080a/5080a61a3c2f62457dd7e1f3473e7ccef17c86e7" alt="sample2"
##### Creating Color Overlayed Image
```swift
let image = UIImage(named: "myArrow").with(color: UIColor.blueColor())
```Getting Started
---------------SwiftyImage provides a simple way to create images with method chaining.
#### Step 1. Start Chaining
Method chaining starts from `UIImage.size()` or `UIImage.resizable()`.
```swift
UIImage.size(width: CGFloat, height: CGFloat) // ...
UIImage.size(size: CGSize) // ...
UIImage.resizable() // ...
```#### Step 2. Setting Properties
You can set fill color, border attributes, corner radius, etc.
```swift
UIImage.size(width: 100, height: 100) // fixed size
.color(.white) // fill color
.border(color: .red) // border color
.border(width: 10) // border width
.corner(radius: 20) // corner radius
``````swift
UIImage.resizable() // resizable image
.color(.white)
.border(color: .lightGray)
.border(width: 1)
.corner(radius: 5)
```#### Step 3. Generating Image
Use `.image` at the end of method chaining to generate image.
```swift
imageView.image = UIImage.size(width: 100, height: 100)
.color(.white)
.border(color: .red)
.border(width: 10)
.corner(radius: 20)
.image // generate UIImage
```### Methods Available
#### Starting Method Chaining
* **`.size(width: CGFloat, height: CGFloat)`**
Starts chaining for fixed size image
* **`.size(CGSize)`**
Starts chaining for fixed size image
* **`.resizable()`**
Starts chaining for resizable image
#### Setting Properties
* **`.color(UIColor)`**
Sets fill color
* **`.color(gradient: [UIColor], locations: [CGFloat], from: CGPoint, to: CGPoint)`**
Sets gradient fill color
*New in version 1.1.0*
* **`.border(width: CGFloat)`**
Sets border width
* **`.border(color: UIColor)`**
Sets border color
* **`.border(gradient: [UIColor], locations: [CGFloat], from: CGPoint, to: CGPoint)`**
Sets gradient border color
*New in version 1.1.0*
* **`.border(alignment: BorderAlignment)`**
Sets border alignment. Same with Photoshop's
available values: `.inside`, `.center`, `.outside`* **`.corner(radius: CGFloat)`**
Sets all corners radius of image
* **`.corner(topLeft: CGFloat)`**
Sets top left corner radius of image
* **`.corner(topRight: CGFloat)`**
Sets top right corner radius of image
* **`.corner(bottomLeft: CGFloat)`**
Sets bottom left corner radius of image
* **`.corner(bottomRight: CGFloat)`**
Sets bottom right corner radius of image
#### Generating Image
* **`.image`**
Generates and returns image
Play with CGContext
-------------------SwiftyImage also provides a simple method to create or manipulate images with CGContext.
#### Creating Images
```swift
let image = UIImage.with(size: CGSize(width: 100, height: 100)) { context in
UIColor.lightGrayColor().setFill()
CGContextFillEllipseInRect(context, CGRect(x: 0, y: 0, width: 100, height: 100))
}
```#### Manipulating Images
```swift
let newImage = oldImage.with { context in
UIColor.lightGrayColor().setFill()
CGContextFillEllipseInRect(context, CGRect(x: 0, y: 0, width: 100, height: 100))
}
```Image Operator
--------------You can easily combine multiple images with `+` operator.
```swift
let backgroundImage = ...
let iconImage = ...
let combinedImage = backgroundImage + iconImage
```data:image/s3,"s3://crabby-images/044fb/044fb8a2d47d716849e227d7a56d64be100071ee" alt="combine"
Installation
------------```ruby
pod 'SwiftyImage', '~> 1.1'
```Playground
----------Use CocoaPods command `$ pod try SwiftyImage` to try Playground!
data:image/s3,"s3://crabby-images/8e8b8/8e8b8ed5e93a0c3da05b41f29eee37839925cab6" alt="playground"
License
-------SwiftyImage is under MIT license. See the LICENSE file for more info.