首页 > 系统 > iOS > 正文

关于iOS屏幕旋转的一些注意事项

2020-07-26 02:58:55
字体:
来源:转载
供稿:网友

前言

最近有个需求,是在App中有一个查看文件的页面,由于查看文件横屏会更方便阅读,所以boss说要让这个页面可以横屏。之前都没有接触过横屏的具体实现方法,一开始走了不少弯路,而且各种bug。在这里把遇到的问题分享一下,希望对大家有点帮助。

要让你的APP支持旋转,你需要进行如下几个步骤

1、 全局配置

在工程->TARGETS->General->Deployment Info中配置


在AppDelegate中配置

- (UIInterfaceOrientationMask)application:(UIApplication *)application supportedInterfaceOrientationsForWindow:(UIWindow *)window { return UIInterfaceOrientationMaskAllButUpsideDown;}

2、 全局配置做好了,你就可以在控制器中实现相应的旋转方法来让你的APP支持旋转了

我们需要在什么地方实现控制器的旋转方法呢?

有以下两种情况

1、当前控制器是window的rootViewController由rootViewController来管理旋转的相关方法

典型的有 UINavigationController、UITableBarController

2、当前控制器是modal模式的时(控制器为modal显示的控制器),由该控制器自己管理旋转的相关方法

即控制器是通过 presentViewController:animated:completion: 方式出来的

控制器的旋转方法介绍

控制器的旋转方法在iOS6之前和之后有了比较大的变化

1、在iOS6 之前只需要实现下面这个方法就可以

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation { return (interfaceOrientation == UIInterfaceOrientationLandscapeLeft || interfaceOrientation == UIInterfaceOrientationLandscapeRight); }

2、在iOS6之后由下面两个方法替代

//是否支持旋转- (BOOL)shouldAutorotate { return YES; }//所支持的方法集合,是一个枚举类- (NSUInteger)supportedInterfaceOrientations { return UIInterfaceOrientationMaskLandscape; }

下面我重点讲一下在iOS6之后旋转方法的使用情况。因为在iOS6+、7、8中和iOS9中这两个方法的调用顺序以及处理逻辑是不一样的(坑)

控制器的旋转方法使用

1、iOS6+、7、8中会先调用shouldAutorotate判断屏幕是否支持旋转

  1. 该方法返回YES,就会去调用supportedInterfaceOrientations检查控制器支持的方向枚举集合,如果存在符合设备所处的方向枚举集合,屏幕会执行相应的旋转,如果不存在设备所处的方向枚举,屏幕就不会旋转,停止检查
  2. 该方法返回NO,屏幕不能够旋转,停止检查

2、iOS9+中会先调用supportedInterfaceOrientations来检查控制器支持的方向枚举集合

  1. 如果方向枚举集合中没有符合设备所处的方向枚举,就不会去调用shouldAutorotate方法,屏幕不会旋转,停止检查
  2. 如果方向枚举集合中有符合设备所处的方向枚举,那么就会去调用shouldAutorotate方法

             如果该返回YES,屏幕执行相应的旋转

             如果该返回NO,屏幕不会旋转,停止检查

3、关于preferredInterfaceOrientationForPresentation方法,该方法的作用是返回最优先显示的屏幕方向。在iOS7之后就不会调用了,但是网上说在iOS7之前需要加上,不加会崩溃(没有亲测)

总结

写这边文章主要是因为之前在网上看了很多资料,但是并有提到旋转方法他们的调用顺序以及处理逻辑的介绍,大部分都是抄来抄去,没有经过自己试验的代码也贴到网上来,坑了我千万遍。

以上就是这篇文章的全部内容了,希望本文的内容对各位Android开发者们能有一定的帮助,亲身试验的东西才是硬道理,如果有疑问大家可以留言交流。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表