DynamicIslandUtilities

0.1.0

A collection of utilities that provides functionality around the Dynamic Island on the iPhone 14 Pro/Max.
theblixguy/DynamicIslandUtilities

What's New

Re-do API

2022-10-08T22:08:14Z
  • Re-do APIs so the progress indicator is available directly from the DynamicIsland namespace.

Now, instead of having to subclass a ViewController, you can just use DynamicIsland.progressIndicator from anywhere to control it. This means you can also use it from SwiftUI!

DynamicIslandUtilities

A collection of utilities that provides functionality around the Dynamic Island on the iPhone 14 Pro/Max.

I will be adding more utilities to this package in the near future.

Utilities

DynamicIsland

A type that provides the size, origin, rect and some other information related to the Dynamic Island. For example, you can do:

let size = DynamicIsland.size

to get the size of the Dynamic Island cutout. This size is the same on both the iPhone 14 Pro and Max.

Warning At the moment, this provides the static size of the island, not the dynamic size (the island will expand if there's a live activity running).

DynamicIslandProgressIndicatorViewController

A UIViewController that provides a progress indicator around the Dynamic Island cutout.

To use it, simply subclass the view controller. You can subclass it even if you're not targetting iOS 16 yet, the minimum requirement is iOS 11.

In order to control the progress indicator, you need to use the configuration object by accessing dynamicIslandProgressIndicatorConfiguration, which will return a view into the progress indicator, allowing you to tweak the color, progress value/visibility or show an indeterminate animation.

dynamicIslandProgressIndicatorConfiguration.progressColor = .green
dynamicIslandProgressIndicatorConfiguration.isProgressIndeterminate = false

// Manual progress

doFixedWork { currentProgress in 
  if currentProgress == 100 {
    dynamicIslandProgressIndicatorConfiguration.hideProgressIndicator()
  } else {
    dynamicIslandProgressIndicatorConfiguration.progress = currentProgress
  }
}

/// Indeterminate progress

dynamicIslandProgressIndicatorConfiguration.showIndeterminateProgressAnimation()
doSomeWorkThatMayFinishLater { result in
 ...
 dynamicIslandProgressIndicatorConfiguration.hideProgressIndicator()
}

In order to access this property, you need to check DynamicIsland.isAvailable (this is enforced at runtime), which also nudges you to provide fallback logic:

if DynamicIsland.isAvailable {
  // Show a cool progress indicator around the Dynamic Island
  dynamicIslandProgressIndicatorConfiguration.showIndeterminateProgressAnimation()
} else {
  // Fallback to a default indicator
  showIndeterminateProgressBar()
}

Example:

Indeterminate

Manual

Note If you're using SwiftUI, I will be providing a native version for that soon. In the meantime, you can wrap the view controller manually.

Requirements

  • Swift Package Manager
  • Xcode 14

Description

  • Swift Tools 5.7.0
View More Packages from this Author

Dependencies

  • None
Last updated: Sat Jan 04 2025 00:53:11 GMT-1000 (Hawaii-Aleutian Standard Time)