iOS 9的一个最大变化就是引入了多任务。它允许用户同时打开多个程序。目前有两种打开的形式:侧面覆盖(Slide Over)和分屏(Split View)。
侧面覆盖(Slide Over)
在“Slide Over”下,我们可以在屏幕的右侧滑动看到一个应用列表,选择后在类似与iPhone屏幕的窄小区域打开程序。这个区域在之前已经启动的程序之上,并且左侧区域不能进行交互。
分屏(Split View)
往左拉“Slide Over”情况下的分界线,可以控制两个应用程序所占的尺寸大小,并且进入分屏视图(Split View)。当分屏视图被激活后,这两个应用都处于前台状态。
目前只能在iPad Air 2上使用分屏功能。
启用多任务
Xcode 7创建的新项目默认都支持多任务。如果我们有一个老的项目,则需要手动去打开多任务。当我们使用iOS 9 SDK的情况下,只需要下面两步:
- 让应用支持所有方向
- 使用
Launch Storyboard
取消多任务
如果想要停用多任务功能,我们只要在info.plist
里增加一个条目UIRequiredFullscreen
。
自动布局的重要性
从iOS 6开始引入的Auto Layout,让我们能够使用约束而不是固定位置来进行界面布局。iOS 8引入Adaptive Layout,进一步加强了自动布局的能力,允许基于不同的屏幕尺寸(Size Class)进行布局。Size Class定义了一系列不同的相对窗口大小。
由于多任务的特性,在iOS 9中我们需要考虑下面一些问题。
不要再使用UIInterfaceOrientation
原则上说,一旦支持多任务,这个属性就不再被支持。在一个多任务程序中检查UIInterfaceOrientation
得到的结果与全屏情况下可能不一样。如果该程序处于iPad横屏下的“Split View”中,垂直方向的宽度比水平方向要大,返回UIInterfaceOrientationPortrait
。
如果还是需要根据应用程序窗口尺寸改变UI布局,我们可以使用traitCollection.horizontalSizeClass
。这个属性会提供一些界面相关的信息,可以用来进行判断。
窗口尺寸变化事件
以前,willRotateToInterfaceOrientation
和didRotateToInterfaceOrientation
被用来处理屏幕旋转事件。从iOS 8开始,苹果引入了willTransitionToTraitCollection
和viewWillTransitionToSize
。这些方法在iOS 9的多任务中变得更加重要。我们可以根据窗口宽度和高度决定当前UI应该是垂直还是水平。
响应键盘事件
在过去,应用只会在这个应用的键盘被打开的时候受到影响。多任务情况下,哪怕程序的键盘没有被打开,也有可能收到键盘的影响。
有时键盘覆盖在应用上并不会造成什么影响。但是它也有可能挡住界面上的重要部分,从而影响用户使用。这时我们应该响应键盘通知UIKeyboard
,比如WillShow
、DidShow
、WillHide
、DidHide
、WillChangeFrame
和DidChangeFrame
。当前屏幕上的两个应用都会接收这些通知。
其它考量
项目中所做的改变可能并不是那么直观。过去,应用程序必须唯一地运行在前台,
本文翻译自Chris Grant的《iOS9 Day-by-Day :: Day 6 :: Split Screen Multitasking》(https://www.shinobicontrols.com/blog/ios9-day-by-day-day6-split-screen-multitasking)。感谢Chris Grant的辛苦工作!
然后独占所有的系统资源,比如CPU、GPU以及内存。但是现在这些都发生变化了。如果一个用户使用“Split View”或“Slide Over”甚至用iOS 9的“画中画”功能看电影,多个程序共享系统资源。
操作系统以提供最好的用户体验为依据,而不是平等的分配资源和终止程序——iOS 9多任务文档
我们应该在不同尺寸的iPad上做大量的测试来确保应用程序能够有效工作,并且不会使用它不需要的资源。
更多信息
关于iOS 9多任务的更多信息,请查看“Adopting Multitasking On iPad”。建议观看WWDC session 205,“Continuous Integration and Code Coverage in Xcode”。别忘了我们的代码在GitHub上。
戴维营教育
戴维营教育(Dive In Education),潜心做IT职业教育!紧跟时代潮流,不弄虚作假!不忘初心!