Convert Figma logo to code with AI

kean logoNuke

Image loading system

8,195
530
8,195
24

Top Related Projects

Asynchronous image downloader with cache support as a UIImageView category

A lightweight, pure-Swift library for downloading and caching images from the web.

AlamofireImage is an image component library for Alamofire

Promises for Swift & ObjC.

24,358

Reactive Programming in Swift

15,122

Network abstraction layer written in Swift.

Quick Overview

Nuke is a powerful image loading and caching system for iOS and macOS applications. It provides an efficient and easy-to-use solution for downloading, processing, and displaying images from various sources, including network URLs and local storage.

Pros

  • High performance and memory efficiency
  • Extensive customization options for image processing and caching
  • Supports progressive image loading and animated GIFs
  • Well-documented and actively maintained

Cons

  • Limited to Apple platforms (iOS, macOS, tvOS, watchOS)
  • Steeper learning curve compared to simpler image loading libraries
  • May be overkill for small projects with basic image loading needs

Code Examples

Loading an image from a URL:

import Nuke

let imageView = UIImageView()
let url = URL(string: "https://example.com/image.jpg")!

Nuke.loadImage(with: url, into: imageView)

Applying image processing:

import Nuke

let processor = ImageProcessors.Resize(width: 320)
let request = ImageRequest(url: url, processors: [processor])

Nuke.loadImage(with: request, into: imageView)

Preheating images:

import Nuke

let urls = [URL(string: "https://example.com/image1.jpg")!,
            URL(string: "https://example.com/image2.jpg")!]

Nuke.ImagePipeline.shared.prefetch(with: urls)

Getting Started

  1. Add Nuke to your project using Swift Package Manager, CocoaPods, or Carthage.

  2. Import Nuke in your Swift file:

import Nuke
  1. Load an image into an image view:
let imageView = UIImageView()
let url = URL(string: "https://example.com/image.jpg")!

Nuke.loadImage(with: url, into: imageView)
  1. Customize the image pipeline (optional):
let pipeline = ImagePipeline {
    $0.dataLoader = DataLoader(configuration: {
        $0.urlCache = URLCache(memoryCapacity: 100_000_000, diskCapacity: 1_000_000_000)
    })
    $0.imageCache = ImageCache.shared
}

ImagePipeline.shared = pipeline

For more advanced usage and configuration options, refer to the official documentation.

Competitor Comparisons

Asynchronous image downloader with cache support as a UIImageView category

Pros of SDWebImage

  • Wider platform support (iOS, tvOS, macOS, watchOS)
  • More comprehensive feature set, including animated image support
  • Larger community and longer history, potentially leading to better stability

Cons of SDWebImage

  • Larger codebase, which may lead to increased app size
  • Potentially more complex API due to its extensive feature set
  • Slower adoption of newer Swift features and patterns

Code Comparison

SDWebImage:

let imageView = UIImageView()
imageView.sd_setImage(with: URL(string: "https://example.com/image.jpg"))

Nuke:

let imageView = UIImageView()
Nuke.loadImage(with: URL(string: "https://example.com/image.jpg")!, into: imageView)

Both libraries offer simple one-line methods for loading images into views. SDWebImage uses a category on UIImageView, while Nuke uses a static method. The syntax is slightly different, but the functionality is similar.

SDWebImage provides a more extensive set of features and wider platform support, making it suitable for complex projects with diverse requirements. Nuke, on the other hand, offers a more focused and lightweight solution, which may be preferable for simpler projects or those prioritizing a smaller codebase and faster adoption of modern Swift practices.

A lightweight, pure-Swift library for downloading and caching images from the web.

Pros of Kingfisher

  • More extensive feature set, including image processing and filters
  • Better support for GIF animations and WebP format
  • More active community and frequent updates

Cons of Kingfisher

  • Slightly larger library size, which may impact app size
  • Can be more complex to set up and use for simple image loading tasks

Code Comparison

Kingfisher:

let url = URL(string: "https://example.com/image.jpg")
imageView.kf.setImage(with: url)

Nuke:

let url = URL(string: "https://example.com/image.jpg")
Nuke.loadImage(with: url, into: imageView)

Both Kingfisher and Nuke are popular image loading libraries for iOS, offering efficient caching and asynchronous image downloading. Kingfisher provides a more comprehensive set of features, including image processing and filters, making it suitable for complex image handling requirements. However, this comes at the cost of a slightly larger library size.

Nuke, on the other hand, focuses on simplicity and performance, making it an excellent choice for projects that prioritize speed and minimal overhead. Its API is straightforward and easy to use, but it may lack some advanced features found in Kingfisher.

Ultimately, the choice between Kingfisher and Nuke depends on the specific needs of your project, balancing feature richness with performance considerations.

AlamofireImage is an image component library for Alamofire

Pros of AlamofireImage

  • Integrated with Alamofire, providing seamless networking and image loading
  • Supports image filters and transformations out of the box
  • Extensive caching options, including memory and disk caching

Cons of AlamofireImage

  • Larger dependency footprint due to Alamofire integration
  • Less flexible for non-Alamofire projects
  • May have a steeper learning curve for developers unfamiliar with Alamofire

Code Comparison

AlamofireImage:

AF.request("https://example.com/image.jpg").responseImage { response in
    if case .success(let image) = response.result {
        imageView.image = image
    }
}

Nuke:

Nuke.loadImage(with: URL(string: "https://example.com/image.jpg")!, into: imageView)

Summary

AlamofireImage is a powerful image loading library tightly integrated with Alamofire, offering robust features for networking and image processing. It's ideal for projects already using Alamofire. Nuke, on the other hand, is a lightweight and flexible image loading solution that can be easily integrated into any project, regardless of the networking stack. Nuke's simplicity and performance make it a great choice for projects that prioritize efficiency and ease of use.

Promises for Swift & ObjC.

Pros of PromiseKit

  • Broader scope: PromiseKit is a general-purpose asynchronous programming framework, useful for various tasks beyond image loading
  • Extensive ecosystem: Offers extensions for many popular libraries and frameworks
  • Powerful chaining and composition: Allows for complex asynchronous operations to be expressed clearly and concisely

Cons of PromiseKit

  • Learning curve: Requires understanding of promises and asynchronous programming concepts
  • Overhead: May introduce additional complexity for simpler tasks compared to Nuke's focused approach
  • Performance: Potentially slower for image loading specific tasks due to its general-purpose nature

Code Comparison

Nuke (Image loading):

Nuke.loadImage(with: url, into: imageView)

PromiseKit (Generic asynchronous operation):

firstly {
    URLSession.shared.dataTask(.promise, with: url)
}.done { data in
    // Process data
}.catch { error in
    // Handle error
}

While Nuke provides a simple, one-line solution for image loading, PromiseKit offers a more verbose but flexible approach for handling various asynchronous operations. PromiseKit's syntax allows for clear chaining of multiple asynchronous tasks, error handling, and transformation of results, making it suitable for complex workflows beyond just image loading.

24,358

Reactive Programming in Swift

Pros of RxSwift

  • Comprehensive reactive programming framework for Swift
  • Supports complex asynchronous operations and event streams
  • Large ecosystem with many extensions and integrations

Cons of RxSwift

  • Steeper learning curve for developers new to reactive programming
  • Can lead to increased code complexity for simple tasks
  • Larger library size and potential performance overhead

Code Comparison

RxSwift:

Observable.from([1, 2, 3, 4, 5])
    .filter { $0 % 2 == 0 }
    .map { $0 * 2 }
    .subscribe(onNext: { print($0) })

Nuke:

let imageView = UIImageView()
Nuke.loadImage(with: URL(string: "https://example.com/image.jpg")!, into: imageView)

Summary

RxSwift is a powerful reactive programming framework, offering extensive capabilities for handling asynchronous operations and event streams. It has a large ecosystem but comes with a steeper learning curve and potential complexity. Nuke, on the other hand, is a focused image loading system, providing a simpler API for image loading tasks. While RxSwift is more versatile for general reactive programming, Nuke excels in its specific domain of efficient image loading and caching.

15,122

Network abstraction layer written in Swift.

Pros of Moya

  • Provides a higher level of abstraction for network requests, making API integration simpler
  • Offers built-in support for testing and stubbing network calls
  • Includes plugins for common tasks like authentication and logging

Cons of Moya

  • May be overkill for simple networking tasks
  • Requires additional setup and configuration compared to more lightweight solutions
  • Learning curve can be steeper for developers new to reactive programming concepts

Code Comparison

Moya example:

let provider = MoyaProvider<MyService>()
provider.request(.userProfile) { result in
    switch result {
    case let .success(response):
        let data = response.data
        // Handle the response
    case let .failure(error):
        // Handle the error
    }
}

Nuke example:

Nuke.loadImage(with: URL(string: "https://example.com/image.jpg")!, into: imageView)

While Moya is focused on general networking and API requests, Nuke is specifically designed for efficient image loading and caching. Moya provides a more comprehensive networking solution, while Nuke excels in its specialized domain of image handling.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README


Image Loading System

Serving Images Since 2015

Load images from different sources and display them in your app using simple and flexible APIs. Take advantage of the powerful image processing capabilities and a robust caching system.

The framework is lean and compiles in under 2 seconds¹. It has an automated test suite 2x the codebase size, ensuring excellent reliability. Nuke is optimized for performance, and its advanced architecture enables virtually unlimited possibilities for customization.

Memory and Disk Cache · Image Processing & Decompression · Request Coalescing & Priority · Prefetching · Resumable Downloads · Progressive JPEG · HEIF, WebP, SVG, GIF · SwiftUI · Async/Await

Sponsors

Lapse: friends not followers.

Lapse Logo

Nuke is also supported by:

Proxyman Logo

Proxyman

Backspace Travel

Backspace Travel

Installation

Nuke supports Swift Package Manager, which is the recommended option. If that doesn't work for you, you can use binary frameworks attached to the releases.

The package ships with four modules that you can install depending on your needs:

ModuleDescription
NukeThe lean core framework with ImagePipeline, ImageRequest, and more
NukeUIThe UI components: LazyImage (SwiftUI) and ImageView (UIKit, AppKit)
NukeExtensionsThe extensions for UIImageView (UIKit, AppKit)
NukeVideoThe components for decoding and playing short videos

Documentation

Nuke is easy to learn and use, thanks to its extensive documentation and a modern API.

You can load images using ImagePipeline from the lean core Nuke module:

func loadImage() async throws {
    let imageTask = ImagePipeline.shared.imageTask(with: url)
    for await progress in imageTask.progress {
        // Update progress
    }
    imageView.image = try await imageTask.image
}

Or you can use the built-in UI components from the NukeUI module:

struct ContentView: View {
    var body: some View {
        LazyImage(url: URL(string: "https://example.com/image.jpeg"))
    }
}

The Getting Started guide is the best place to start learning about these and many other APIs provided by the framework. Check out Nuke Demo for more usage examples.

Nuke Docs

Extensions

The image pipeline is easy to customize and extend. Check out the following first-class extensions and packages built by the community.

NameDescription
Alamofire PluginReplace networking layer with Alamofire
NukeWebPCommunity. WebP support, built by Maxim Kolesnik
WebP PluginCommunity. WebP support, built by Ryo Kosuge
AVIF PluginCommunity. AVIF support, built by Denis
RxNukeRxSwift extensions for Nuke with examples

Looking for a way to log your network requests, including image requests? Check out Pulse.

Minimum Requirements

Upgrading from the previous version? Use a Migration Guide.

NukeDateSwiftXcodePlatforms
Nuke 12.0Mar 4, 2023Swift 5.7Xcode 15.0iOS 13.0, watchOS 6.0, macOS 10.15, tvOS 13.0
Nuke 11.0Jul 20, 2022Swift 5.6Xcode 13.3iOS 13.0, watchOS 6.0, macOS 10.15, tvOS 13.0
Nuke 10.0Jun 1, 2021Swift 5.3Xcode 12.0iOS 11.0, watchOS 4.0, macOS 10.13, tvOS 11.0

Starting with version 12.3, Nuke also ships with visionOS support (in beta)

License

Nuke is available under the MIT license. See the LICENSE file for more info.


¹ Measured on MacBook Pro 14" 2021 (10-core M1 Pro)