ToB企服应用市场:ToB评测及商务社交产业平台

标题: ios13多窗口(UIWindowScene)学习条记 [打印本页]

作者: 农妇山泉一亩田    时间: 2024-8-11 19:56
标题: ios13多窗口(UIWindowScene)学习条记
ios13引入了UIWindowScene类、UIWindowSceneDelegate协议以便支持多窗口功能,但其适用于ipad,不适用于iphone,因为iphone不支持多窗口功能。留意,这里说的窗口不是UIWindow,而是UIWindowScene。
ios13前后的app的UI架构变革

ios13之前的app的UI架构

ios13及以后的app的UI架构

由上图可知,UIWindowScene和UIWindow是一对多的关系。
下图所示的是UIWindowScene的界说,它用于管理1个或者多个UIWindow。

第一个app demo

如下面两张图所示,当我们在xcode11及以后的xcode版本中创建一个ios app工程时,xcode会自动为我们创建“一个app运行起来所需”的文件。当创建一个新的app工程时,相比于xcode10及其之前的版本,xcode11之后会自动为我们新增3处内容(如下图的红框所示):①SceneDelegate类;②info.plist里面的Application Scene Manifest配置选项;③AppDelegate类里面的

SceneDelegate类

我们先来看看SceneDelegate类里面的内容,如下代码所示。SceneDelegate有个window属性,说明ios13之后的window由SceneDelegate管理。当看到方法里面的“DidBecomeActive”、“WillResignActive”、“WillEnterForeground”、“DidEnterBackground”时,我们便可以猜测出这是app进入和退出前背景时的回调。
  1. #import <UIKit/UIKit.h>
  2. @interface SceneDelegate : UIResponder <UIWindowSceneDelegate>
  3. @property (strong, nonatomic) UIWindow * window;
  4. @end
  5. @interface SceneDelegate ()
  6. @end
  7. @implementation SceneDelegate
  8. - (void)scene:(UIScene *)scene willConnectToSession:(UISceneSession *)session options:(UISceneConnectionOptions *)connectionOptions {
  9.     // Use this method to optionally configure and attach the UIWindow `window` to the provided UIWindowScene `scene`.
  10.     // If using a storyboard, the `window` property will automatically be initialized and attached to the scene.
  11.     // This delegate does not imply the connecting scene or session are new (see `application:configurationForConnectingSceneSession` instead).
  12. }
  13. - (void)sceneDidDisconnect:(UIScene *)scene {
  14.     // Called as the scene is being released by the system.
  15.     // This occurs shortly after the scene enters the background, or when its session is discarded.
  16.     // Release any resources associated with this scene that can be re-created the next time the scene connects.
  17.     // The scene may re-connect later, as its session was not necessarily discarded (see `application:didDiscardSceneSessions` instead).
  18. }
  19. - (void)sceneDidBecomeActive:(UIScene *)scene {
  20.     // Called when the scene has moved from an inactive state to an active state.
  21.     // Use this method to restart any tasks that were paused (or not yet started) when the scene was inactive.
  22. }
  23. - (void)sceneWillResignActive:(UIScene *)scene {
  24.     // Called when the scene will move from an active state to an inactive state.
  25.     // This may occur due to temporary interruptions (ex. an incoming phone call).
  26. }
  27. - (void)sceneWillEnterForeground:(UIScene *)scene {
  28.     // Called as the scene transitions from the background to the foreground.
  29.     // Use this method to undo the changes made on entering the background.
  30. }
  31. - (void)sceneDidEnterBackground:(UIScene *)scene {
  32.     // Called as the scene transitions from the foreground to the background.
  33.     // Use this method to save data, release shared resources, and store enough scene-specific state information
  34.     // to restore the scene back to its current state.
  35. }
  36. @end
复制代码
info.plist里面的Application Scene Manifest配置选项

如下第1张图所示,当我们给SceneDelegate类的方法添加断点,然后运行app时,发现断点生效了。那么,SceneDelegate类是在哪初始化的呢?如下第2张图所示,如果你在工程中搜索“SceneDelegate”关键字,就会发现并没有任何代码来创建SceneDelegate实例,此时你可以看到info.plist文件里面有关于SceneDelegate的配置项。我们便可以猜测出SceneDelegate实例是系统默认帮我们创建的。

   第1张图  

   第2张图  app demo运行

当我们在ipad上运行前面刚刚创建的app时,结果如下图所示,发现屏幕的顶部中心多了个3点按钮(下图的红框所示)。你可以点击3点按钮来使用里面的功能(请看下面的录屏)。

录屏demo链接
UIApplication、UIApplicationDelegate、UIWindowScene、UIWindowSceneDelegate、UISceneSession的职责


xcode11版本之后的xcode创建的ios app如何适配ios13以下的系统

  1. #import <UIKit/UIKit.h>
  2. @interface AppDelegate : UIResponder <UIApplicationDelegate>
  3. @property (strong, nonatomic) UIWindow * window;
  4. @end
复制代码
  1. #import "AppDelegate.h"
  2. #import "ViewController.h"
  3. @implementation AppDelegate
  4. - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
  5.     if (@available(iOS 13.0, *)) {
  6.         
  7.     } else {
  8.         //适配ios13以下的系统
  9.         self.window = [[UIWindow alloc] initWithFrame:UIScreen.mainScreen.bounds];
  10.         ViewController *vc = [ViewController new];
  11.         self.window.rootViewController = vc;
  12.         [self.window makeKeyAndVisible];
  13.     }
  14.     return YES;
  15. }
  16. #pragma mark - UISceneSession lifecycle
  17. - (UISceneConfiguration *)application:(UIApplication *)application configurationForConnectingSceneSession:(UISceneSession *)connectingSceneSession options:(UISceneConnectionOptions *)options {
  18.     return [[UISceneConfiguration alloc] initWithName:@"Default Configuration" sessionRole:connectingSceneSession.role];
  19. }
  20. - (void)application:(UIApplication *)application didDiscardSceneSessions:(NSSet<UISceneSession *> *)sceneSessions {
  21. }
  22. @end
复制代码
  1. #import "SceneDelegate.h"
  2. #import "ViewController.h"
  3. @implementation SceneDelegate
  4. - (void)scene:(UIScene *)scene willConnectToSession:(UISceneSession *)session options:(UISceneConnectionOptions *)connectionOptions {
  5.     if (@available(iOS 13.0, *)) {
  6.         UIWindowScene *windowScene = (UIWindowScene *)scene;
  7.         self.window = [[UIWindow alloc] initWithFrame:UIScreen.mainScreen.bounds];
  8.         [self.window setWindowScene:windowScene];
  9.         ViewController *vc = [ViewController new];
  10.         UINavigationController *nvc = [[UINavigationController alloc] initWithRootViewController:vc];
  11.         self.window.rootViewController = nvc;
  12.         [self.window makeKeyAndVisible];
  13.     }
  14. }
  15. @end
复制代码
ios13后的AppDelegate的职责发生了变革

ios13之前

如下图,ios13之前的Appdelegate职责有:1 进程生命周期干系的回调(比如application:didFinishLaunchingWithOptions:方法); 2 UI的生命周期干系的回调(比如applicationDidBecomeActive:方法)。

ios13之后

如下图,ios13之后,AppDelegate负责进程生命周期干系和UISceneSession生命周期干系的回调。而UI的生命周期干系的回调则由UISceneDelegate来负责。



免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4