iOS13 Scene Delegate详解

scenedelegate_logo.jpg

iOS13 项目中的SceneDelegate类有什么作用?自从Xcode11发布以来,当你使用新XCode创建一个新的iOS项目时,SceneDelegate会被默认创建,它到底有什么用呢。

在本文中,我们将深入探讨iOS 13和Xcode 11的一些变化。我们将重点关注SceneDelegate和AppDelegate,以及它们如何影响SwiftUI、Storyboard和基于XIB的UI项目。

通过阅读本文你将了解到:

  • SceneDelegate和AppDelegate的新变化
  • 他们是如何合作引导你的app启动的
  • 在纯手写App中使用SceneDelegate
  • 在Storyboards 和 SwiftUI项目中使用SceneDelegate

让我们开始吧。

本篇文章基于 Xcode 11 和 iOS 13.

AppDelegate

你可能对AppDelegate已经熟悉,他是iOS app的入口,application(_:didFinishLaunchingWithOptions:)是你的app启动后系统调用的第一个函数。

AppDelegate类实现了UIKit库中的UIApplicationDelegate 协议。而到了iOS13 AppDelegate的角色将会发生变化,后面我们会详细讨论。

下面是你在iOS12中一般会在AppDelegate中做的事情:

  • 创建app的第一个view controller也就是 rootViewController
  • 配置并启动一些像日志记录和云服务之类的组件
  • 注册推送通知处理程序,并响应发送到app的推送通知
  • 响应应用程序生命周期事件,例如进入后台,恢复应用程序或退出应用程序(终止)

iOS12及以前,使用Storyboards的app,AppDelegate很简单。 像这样:

func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool
{
   
    return true
}

一个使用XIB的简单应用看起来像这样:

func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool
{
      
    let timeline = TimelineViewController()
    let navigation = UINavigationController(rootViewController: timeline)

    let frame = UIScreen.
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`SceneDelegate` 是 iOS 13 引入的新特性,用于管理多场景(multi-scene)应用程序的生命周期和状态。每个场景都代表一个应用程序窗口和相关的视图控制器层次结构。 在使用 `SceneDelegate` 之前,我们需要先创建一个基于 `UIKit` 的应用程序模板。在 Xcode 11 中创建一个新的项目时,默认会自动生成 `SceneDelegate.swift` 文件。如果没有自动生成,可以手动创建。 然后,在 `AppDelegate.swift` 文件中,需要将应用程序的生命周期方法移动到新的 `SceneDelegate.swift` 文件中。例如,将 `application(_:didFinishLaunchingWithOptions:)` 方法移动到 `SceneDelegate.swift` 文件中: ```swift class SceneDelegate: UIResponder, UIWindowSceneDelegate { var window: UIWindow? func scene(_ scene: UIScene, willConnectTo session: UISceneSession, options connectionOptions: UIScene.ConnectionOptions) { // Create a new UIWindow instance guard let windowScene = (scene as? UIWindowScene) else { return } window = UIWindow(windowScene: windowScene) // Set the root view controller of the window let viewController = ViewController() window?.rootViewController = viewController // Make the window visible window?.makeKeyAndVisible() } // other SceneDelegate methods } ``` 在 `scene(_:willConnectTo:options:)` 方法中,我们需要创建一个新的 `UIWindow` 实例,并设置其根视图控制器。最后,通过调用 `makeKeyAndVisible()` 方法,使窗口可见。 最后,在 `Info.plist` 文件中,需要添加一个新的键值对,以启用多场景支持。在 `Application Scene Manifest` 中添加一个 `Session Role` 为 `UIWindowSceneSessionRoleApplication` 的项。 ```xml <key>UIApplicationSceneManifest</key> <dict> <key>UISceneConfigurations</key> <dict> <key>UIWindowSceneSessionRoleApplication</key> <array> <dict> <key>UISceneConfigurationName</key> <string>Default Configuration</string> <key>UISceneDelegateClassName</key> <string>$(PRODUCT_MODULE_NAME).SceneDelegate</string> <key>UISceneStoryboardFile</key> <string>Main</string> </dict> </array> </dict> </dict> ``` 现在,我们已经成功地启用了多场景支持,并将应用程序的生命周期方法移动到了 `SceneDelegate.swift` 文件中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值