翻译:iOS视图控制器编程指南(十二)——自适应model(The Adaptive Model)

自适应界面能最大的利用可用空间。自适应意味着可以调整内容很好的适配任何iOS设备。iOS中自适应model支持简单动态的方法来重新排列和调整内容以应对变化。当你利用该model,简单app可以使用很少额外代码,以适应截然不同的屏幕尺寸(如图12-1所示)。

图12-1 适应不同设备和方向

建立自适应界面的重要工具是Auto Layout。使用Auto Layout,定义规则(称为约束)管理视图控制器视图的布局。可以在界面构建器中创建可视化的规则或者以编程的方式。当父视图的大小改变,iOS根据指定的约束,自动调整视图的大小和位置。

自适应model的另一个重要组成部分是trait。trait描述视图控制器和视图必须操作的环境。trait帮助你作出界面决定。

trait规则

当约束并不足以管理布局时,视图控制器有机会做出改变。视图控制器、视图和一些其他对象管理trait集合,trait集合指定该对象当前环境。表12-1描述了trait以及如何使用trait来影响用户界面。

Trait 例子 描述
horizontalSizeClass UIUserInterfaceSizeClassCompact 该trait指定界面的总体宽度。使用trait做低级别布局决定,例如视图是否垂直堆放,并排显示,隐藏或以其他方式显示。
verticalSizeClass UIUserInterfaceSizeClassRegular 该traint指定界面的总体高度。如果设计要求所有内容都在屏幕上,且没有滚动,使用trait做布局决定。
displayScale 2.0 该trait指定内容是以Retina或标准分辨率方式显示。使用它(如果需要)进行像素级别布局决定或选择显示哪种版本的图片。
userInterfaceIdiom UIUserInterfaceIdiomPhone 该trait提供向后的兼容性并指定app在哪种类型的设备上运行。尽可能避免使用该trait。对于布局,使用水平、垂直size类代替

表12-1 trait

使用trait来决定如何present用户界面。当在界面构建器中构建你的界面时,使用trait改变显示或用来适应不同约束的视图和图像。许多UIKit类,如 UIImageAsset,调整指定的trait提供的信息。

这里有一些提示帮助你理解何时使用不同类型的trait:

  • 使用size类来更改界面。当size类改变时,添加或删除视图、添加或删除子视图控制器或改变布局约束。也可以什么都不做,使用现有布局约束让界面自适应。
  • 永远不要假设视图的size类为指定高度或宽度。视图控制器的size类会因为很多原因改变。例如,iPhone上的容器视图控制器可以使其子视图控制器以不同的方式显示它的内容。
  • 适当使用界面构建器为每个size类指定不同的布局约束。使用界面构建器指定约束比你自己添加或删除约束简单。视图控制器通过storyboard中的约束,自动处理size类变化。关于为不同size类配置布局约束的更多信息,参见配置storyboard处理不同size类(Configuring Your Storyboard to Handle Different Size Classes)。
  • 避免使用idiom信息来决定界面布局或内容。iPad和iPhone上运行的app通常显示相同的信息,应该使用size类进行布局。

什么时候trait和size发生变化?

trait很少发生变化,但他们确实会发生变化。UIKit基于底层环境,更新视图控制器的trait。size类trait比显示比例trait更容易发生变化。idiomtrait很少发生改变。size类发生变化的原因如下:

  • 视图控制器窗口的垂直或水平size类发生变化,通常是因为设备发生旋转。

  • 容器视图控制器的垂直或水平size类发生变化。

  • 容器视图控制器修改当然视图控制器的垂直或水平size类。

视图控制器层级中size类发生变化会传递到视图控制器。窗口对象作为层级结构的根,为其根视图控制器提供基准size类trait。当设备横竖屏切换时,窗口更新自己的size类信息,并将该信息传递给视图层级结构。容器视图控制器可以将变更传递给未修改的子视图控制器,或者可以覆盖每个子视图控制器的trait。

在iOS8及后续版本,窗口原点总是在左上角,当设备横竖屏切换时,窗口的bound发生变化。窗口的size变更和其他与trait变化相关的变更传递到视图控制器层级结构。对于层级结构中的视图控制器,UIKit调用以下方法来记录这些变化:

  1. willTransitionToTraitCollection:withTransitionCoordinator:方法告诉每个相关视图控制器,trait即将改变。
  2. viewWillTransitionToSize:withTransitionCoordinator:方法告诉每个相关视图控制器,size即将改变。
  3. traitCollectionDidChange:方法告诉每个相关视图控制器,trait已经发生改变。

当遍历视图控制器层级结构,UIKit记录视图控制器的变化。如果一个容器视图控制器覆盖其子视图控制器的size类,当容器视图控制器的size类发生变化时,不通知这些子视图控制器。类似的,如果容器视图控制器的视图有一个固定的宽度和高度,它不接收size变更通知。

图12-2展示了当iPhone6旋转时,视图控制器的trait和视图size如何更新。从竖屏旋转到横屏使屏幕的垂直size类从regular变为compact。size类的改变,相关视图size类的改变传递到视图层级结构。在渲染视图到新size后,UIKit在调用视图控制器的traitCollectionDidChange:方法前适应size类和视图size变更。

图12-2 更新视图控制器的trait和视图大小

不同设备的默认size类

每个iOS设备都有一组默认的size类,当设计界面时,可以作为参考。表12-2列出了设备在竖屏和横屏时的size类。表中未列出的设备的size类与使用相同屏幕尺寸的设备相同。

设备 竖屏 横屏
iPad (all)iPad Mini Vertical size class: RegularHorizontal size class: Regular Vertical size class: RegularHorizontal size class: Regular
iPhone 6 Plus Vertical size class: RegularHorizontal size class: Compact Vertical size class: CompactHorizontal size class: Regular
iPhone 6 Vertical size class: RegularHorizontal size class: Compact Vertical size class: CompactHorizontal size class: Compact
iPhone 5siPhone 5ciPhone 5 Vertical size class: RegularHorizontal size class: Compact Vertical size class: CompactHorizontal size class: Compact
iPhone 4s Vertical size class: RegularHorizontal size class: Compact Vertical size class: CompactHorizontal size class: Compact

表12-2 不同屏幕尺寸设备的size类

重要:永远不要假设app会在特定size类的设备上显示。当决定如何配置对象时,总是要检查该对象trait约束中的size类。

官方原文地址:

https://developer.apple.com/library/prerelease/ios/featuredarticles/ViewControllerPGforiPhoneOS/TheAdaptiveModel.html#//apple_ref/doc/uid/TP40007457-CH19-SW1

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容