Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/daltoniam/skeets
Fetch, cache, and display images via HTTP in Swift.
https://github.com/daltoniam/skeets
Last synced: 14 days ago
JSON representation
Fetch, cache, and display images via HTTP in Swift.
- Host: GitHub
- URL: https://github.com/daltoniam/skeets
- Owner: daltoniam
- License: apache-2.0
- Created: 2014-09-24T16:15:56.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2015-10-14T18:18:25.000Z (about 9 years ago)
- Last Synced: 2024-12-08T02:34:34.730Z (25 days ago)
- Language: Swift
- Size: 426 KB
- Stars: 191
- Watchers: 10
- Forks: 21
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Skeets
=====![skeets](http://img1.wikia.nocookie.net/__cb20110522030251/marvel_dc/images/2/2b/Skeets_JLU_1.jpg)
Skeets is a networking image library that fetches, caches, and displays images via HTTP in Swift. It is built off [SwiftHTTP](https://github.com/daltoniam/SwiftHTTP).
## Features
- Multi level cache. In-memory and disk caching.
- Nonblocking IO. All HTTP and disk IO happen in the background, thanks to GCD.
- Simple one method to load a remote image.
- Robust, fast, and customizable caching.
- Simple concise codebase at just a few hundred LOC.
- handles redundant image requests, so only one request is sent for multiple queriesFull article here: [Vluxe](http://vluxe.io/skeets.html)
## Example
First thing is to import the framework. See the Installation instructions, on how to add the framework to your project.
```swift
import Skeets
```Once imported, you can start requesting images.
```swift
//create a imageView
let imageView = UIImageView(frame: CGRectMake(0, 60, 200, 200))
self.view.addSubview(imageView)//set the cache directory. Only have to do this once since `sharedManager` is a singleton
let paths = NSSearchPathForDirectoriesInDomains(.CachesDirectory, .UserDomainMask, true)
ImageManager.sharedManager.cache.diskDirectory = "\(paths[0])/ImageCache"//for OSX
//let paths = NSSearchPathForDirectoriesInDomains(.CachesDirectory, .UserDomainMask, true)
//ImageManager.sharedManager.cache.diskDirectory = "\(paths[0])/\(NSBundle.mainBundle().bundleIdentifier!)/ImageCache"ImageManager.sharedManager.cache.cleanDisk()
//fetch the image
ImageManager.fetch("http://vluxe.io/assets/images/logo.png",
progress: { (status: Double) in
println("updating some UI for this: \(status)") //useful if you have some kind of progress dialog as the image loads
},success: { (data: NSData) in
println("got an image!")
imageView.image = UIImage(data: data) //set the image data
}, failure: { (error: NSError) in
println("failed to get an image: \(error)")
})
```## Cancel Request
Fetch requests can be cancelled when needed. This simply causes the closures not to be called.
```swift
ImageManager.cancel("http://vluxe.io/assets/images/logo.png")
```## Custom Cache
Skeets also supports customized caching and protocols. It is possible to implement your own custom cache by implementing the `CacheProtocol`. There is also a powerful default cache provided with a few customization options.
```swift
let c = ImageManager.sharedManager.cache as? ImageCache
if let cache = c {
cache.diskAge = 60 * 60 //360 seconds or 1 hour (Default is 1 day).
cache.imageCount = 10 //only 10 images will be stored in memory (Default is 50).
}
```The cache can also be manually purged (e.g. memory warning is received).
```swift
ImageManager.sharedManager.cache.clearCache()
```The disk can also be clean for possibly stale entries as well.
```swift
ImageManager.sharedManager.cache.cleanDisk()
```## Requirements
Skeets requires at least iOS 8/OSX 10.10 or above.
Skeets depends on [SwiftHTTP](https://github.com/daltoniam/SwiftHTTP). Make sure to import that framework as well before using Skeets.
If you encounter an issue with Skeets not building becuase SwiftHTTP can not be found, make sure to manually select SwiftHTTP framework from the build dropdown and build it. Then build your app again. This will cause the issue of SwiftHTTP not being found to be resolved.
## Installation
### Cocoapods
Check out [Get Started](http://cocoapods.org/) tab on [cocoapods.org](http://cocoapods.org/).
To use Skeets in your project add the following 'Podfile' to your project
source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '8.0'
use_frameworks!pod 'Skeets', '~> 0.9.5'
Then run:
pod install
### Carthage
Check out the [Carthage](https://github.com/Carthage/Carthage) docs on how to add a install. The `Skeets` framework is already setup with shared schemes.
[Carthage Install](https://github.com/Carthage/Carthage#adding-frameworks-to-an-application)
### Rogue
First see the [installation docs](https://github.com/acmacalister/Rogue) for how to install Rogue.
To install Skeets run the command below in the directory you created the rogue file.
```
rogue add https://github.com/daltoniam/SwiftHTTP
rogue add https://github.com/daltoniam/Skeets
```Next open the `libs` folder and add the `Skeets.xcodeproj` to your Xcode project. Once that is complete, in your "Build Phases" add the `Skeets.framework` to your "Link Binary with Libraries" phase. Make sure to add the `libs` folder to your `.gitignore` file.
### Other
Simply grab the framework (either via git submodule or another package manager).
Add the `Skeets.xcodeproj` to your Xcode project. Once that is complete, in your "Build Phases" add the `Skeets.framework` to your "Link Binary with Libraries" phase.
### Add Copy Frameworks Phase
If you are running this in an OSX app or on a physical iOS device you will need to make sure you add the `Skeets.framework` or `SkeetsOSX.framework` to be included in your app bundle. To do this, in Xcode, navigate to the target configuration window by clicking on the blue project icon, and selecting the application target under the "Targets" heading in the sidebar. In the tab bar at the top of that window, open the "Build Phases" panel. Expand the "Link Binary with Libraries" group, and add `Skeets.framework` or `SkeetsOSX.framework` depending on if you are building an iOS or OSX app. Click on the + button at the top left of the panel and select "New Copy Files Phase". Rename this new phase to "Copy Frameworks", set the "Destination" to "Frameworks", and add `Skeets.framework` or `SkeetsOSX.framework` respectively.
## TODOs
- [ ] Complete Docs
- [ ] Add Unit Tests## License
Skeets is licensed under the Apache v2 License.
## Contact
### Dalton Cherry
* https://github.com/daltoniam
* http://twitter.com/daltoniam
* http://daltoniam.com