项目作者: robertmogos

项目描述 :
RMImageLoader is a library for background image-loading.
高级语言: Swift
项目地址: git://github.com/robertmogos/RMImageLoader.git
创建时间: 2017-06-16T18:52:43Z
项目社区:https://github.com/robertmogos/RMImageLoader

开源协议:MIT License

下载


RMImageLoader

RMImageLoader is a library for background image-loading.

Features

  • Background image-loading
  • Download cancelation
  • Caching in memory and on disk
  • Extension for UIImageView

Description

RMImageLoader allows you to download asynchronously images. In order to improve and avoid the number of connection, each image that it is being downloaded can have multiple subscribers. A subscriber is an AnyObject that is interested in the image. This way, you avoid downloading the same image several times. The download can’t be canceled unless all the subcribers decided not to download it anymore. Otherwise, any subscriber that cancels it, will just be ignored when the download is ready.

Usage

Add to your Podfile

  1. pod 'RMImageLoader'

In your class

  1. import RMImageLoader

Loading images

Requesting an image for a UIImageView

  1. RMImageLoader.default.loadImage(url: yourUrl, subscriber: imageView, success: { image in
  2. imageView.image = image
  3. }, failure: { _ in
  4. print("ouch")
  5. })

or even faster

  1. imageView.load(url: yourUrl)

Cancel a request

  1. imageView.cancel(url: yourUrl)

or

  1. RMImageLoader.default.cancel(url: yourUrl, forSubscriber: imageView)

Custom usage

RMImageLoader

The default configuration can be used which will use the Retriever to download the images but any can be initialized with any class that implements the Retrieve protocol

Retriever

The default implementation is using an NSCache to store the processed data:

  • 100 MB disk space
  • 20 MB memory space

You can inject your own URLSessionConfiguration