Skip to content

Latest commit

 

History

History
97 lines (69 loc) · 4.72 KB

README.md

File metadata and controls

97 lines (69 loc) · 4.72 KB

HKProgressHUD

Build Status codecov CocoaPod Platform CocoaPods compatible Carthage compatible License: MIT

HKProgressHUD is an iOS drop-in class in pure-Swift that displays a translucent HUD with an indicator and/or labels while work is being done in a background thread. The HUD is meant as a replacement for the undocumented, private UIKit UIProgressHUD with some additional features.This project is heavily inspired by the popular MBProgressHUD.

Requirements

HKProgressHUD works on iOS 8+, Swift 4. You will need the latest developer tools in order to build HKProgressHUD. Old Xcode versions might work, but compatibility will not be explicitly maintained.

Adding HKProgressHUD to your project

CocoaPods

CocoaPods is the recommended way to add HKProgressHUD to your project.

  1. Add a pod entry for HKProgressHUD to your Podfile pod 'HKProgressHUD', '~> 1.0'
  2. Update the pod(s) by running pod update.

Carthage

  1. Add HKProgressHUD to your Cartfile. e.g., github "huaweikang/HKProgressHUD" ~> 1.0
  2. Run carthage update
  3. Follow the rest of the standard Carthage installation instructions to add HKProgressHUD to your project.

Source files

Alternatively you can directly add the HKProgressHUD.swift and ProgressView.swift source files to your project.

Usage

The main guideline you need to follow when dealing with HKProgressHUD while running long-running tasks is keeping the main thread work-free, so the UI can be updated promptly. The recommended way of using HKProgressHUD is therefore to set it up on the main thread and then spinning the task, that you want to perform, off onto a new thread.

let hud = HKProgressHUD.show(addedToView: self.view, animated: true)
DispatchQueue.global(qos: .userInitiated).async {
    // Do something...
    DispatchQueue.main.async {
    hud.hide(animated: true)
    }
}

You can add the HUD on any view or window. It is however a good idea to avoid adding the HUD to certain UIKit views with complex view hierarchies - like UITableView or UICollectionView. Those can mutate their subviews in unexpected ways and thereby break HUD display.

If you need to configure the HUD you can do this by using the HKProgressHUD reference that show(addedToView:animated:) returns.

let hud = HKProgressHUD.show(addedToView: (self.navigationController?.view)!, animated: true)
hud.mode = .annularDeterminate
hud.label?.text = "Loading..."
DispatchQueue.global(qos: .userInitiated).async {
    // Do something...
    DispatchQueue.main.async {
    hud.hide(animated: true)
    }
}

You can also use a Progress object and HKProgressHUD will update itself when there is progress reported through that object.

let hud = HKProgressHUD.show(addedToView: (self.navigationController?.view)!, animated: true)
hud.mode = .annularDeterminate
hud.label?.text = "Loading..."
let progress = Progress(totalUnitCount: 100)
hud.progressObject = progress;

UI updates should always be done on the main thread.

If you need to run your long-running task in the main thread, you should perform it with a slight delay, so UIKit will have enough time to update the UI (i.e., draw the HUD) before you block the main thread with your task.

HKProgressHUD.show(addedToView: self.view, animated: true)
DispatchQueue.main.asyncAfter(deadline: DispatchTime.now() + DispatchTimeInterval.seconds(3), execute: {
      // Do something...
      HKProgressHUD.hide(addedToView: self.view, animated: false)
 })

You should be aware that any HUD updates issued inside the above block won't be displayed until the block completes.

For more examples, including how to use HKProgressHUD with asynchronous operations such as NSURLConnection, take a look at the bundled demo project.

License

This code is distributed under the terms and conditions of the MIT license.

Change-log

A brief summary of each HKProgressHUD release can be found in the CHANGELOG.