Updated for Xcode 14.2
If you need to get access to AppDelegate
functionality in SwiftUI, you should create a class that inherits from NSObject
and UIApplicationDelegate
, and give it any functionality you want, such as this:
class AppDelegate: NSObject, UIApplicationDelegate {
// add app delegate methods here
}
For example, if you wanted to implement the old didFinishLaunchingWithOptions
method, you might use this:
class AppDelegate: NSObject, UIApplicationDelegate {
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey : Any]? = nil) -> Bool {
print("Your code here")
return true
}
}
Once you have that, use the UIApplicationDelegateAdaptor
property wrapper in your main App
so that SwiftUI knows to create and manage your app delegate class:
@main
struct NewIn14App: App {
@UIApplicationDelegateAdaptor(AppDelegate.self) var appDelegate
var body: some Scene {
WindowGroup {
ContentView()
}
}
}
SAVE 50% To celebrate WWDC23, all our books and bundles are half price, so you can take your Swift knowledge further without spending big! Get the Swift Power Pack to build your iOS career faster, get the Swift Platform Pack to builds apps for macOS, watchOS, and beyond, or get the Swift Plus Pack to learn advanced design patterns, testing skills, and more.
Link copied to your pasteboard.