[iOS开发]一个实例带你搞懂size classes

1. 什么是Size Classes

Size Classes 是多组应用于区分屏幕宽度和高度的一种分类, 当前有2 种Size Classes: Compact和 Regular.

  • 苹果手机竖屏(Portrait)模式下, 高都是regular height, 宽都是compact width.
  • 苹果手机横屏(Landscape)模式下, 高都是compact height, 非plus/Max手机宽都是compact width, plus/max 手机宽都是regular width.

在 Storyboard 中, 一般用简写的 C 表示 Compact, R 表示 Regular.例如wC表示Compact Width, hR表示 Regular Height. 这样的话屏幕的长和就一共可能有 4 种组合.

  1. wC + wR
  2. wC + hR
  3. hC + wR
  4. hC + hR

具体手机的 Size Classes 是如何分类的详见下表:


image.png

注意, 有些手机例如iPhone 11 Pro竖屏下是 compact width + regular height, 但是横屏下width 并不是 regular: 而是compact width + compact height. 注意这里的区别.
那么在实际开发中如何使用这个 Size Classes 呢. 下面我通过一个具体的实例来介绍 Size Classes 的用法

2. Size Classes 实例讲解.

2.1 需求

假设我们需要实现一个很简单的页面. 在竖屏和横屏模式下分别显示如下:


竖屏

横屏
  1. 首先我们创建一个项目, 拖入一个 UIImageView 和 UILabelView.设置好图片.竖屏(Portrait)下的Constraints设置很简单, 不做赘述. 截图如下.


    ImageView设置

    Label设置

运行后可以看到竖屏下,满足要求. 横屏下不满足要求


iphone-landscape-err.PNG

下面看看如何通过Size Classes修改横屏View 的排列.
那么在 Size Classes 中我们要如何区分横屏和竖屏呢? 他们的Size Classes区别是什么呢?
从上面的 Excel 表中可以看出, 横屏和竖屏的区别高度Height, 所有手机在竖屏模式下的高都是Regular Height即hR;所有手机在横屏模式下都是Compact Height即hC. 区别知道了,那么现在开始搞

在 Storyboard 中选中"Orientation", 然后点击"Vary for Traits"


Vary for Traits

注意: 因为我们用 Height 来区分横屏和竖屏,所以选中"Height". 我最开始也很纠结, 这里的Width和 Height 我究竟应该选择哪个呢? 其实这里的Width和 Height 是根据你左侧选择的设备来的, 例如我现在选择的是iPhone 12 Pro Max, 它在横屏模式下就是Regular Width 和Compact Height. 在"Vary canvas edits for"中如果只选择了"Height",那么后面所有的关于 Constraints 的修改都是基于Compact Height 屏幕的手机. 如果只选择了"Width"那么后面的修改都是基于Regular Width的..


image.png

如果你还是不清楚是选择 Width还是 Height, 那么也没有关系, 你可以试着选一个看看, 它会显示你当前选择的是哪种 size class. 例如如果此时你选择了 Height, 下面会显示如下:


image.png

这时候你可以看见那个 Size Classes 栏为蓝色背景, 同时显示"Varing xx Compact Height Devices"表示后面的Constraints操作都是针对当前Compact Height这个Size Class的.
再回头看我上面的那个 excel 表格, Compact Height正好可以区分 iPhone 的横屏和竖屏. 但是不可以用Compact Width区分横屏和竖屏, 原因就是上面我说过的: 有几种型号例如iPhone 11 Pro无论是在横屏还是竖屏下, width都是 compact width.

然后选中图片 UIImageView, 在右边Size Inspector中找到与之相关的约束Constraints, 这些 Constraints 是缺省的约束, 不适合横屏,所以要按Delete 键统统删除.


删除约束Constraints

注意, 这里的删除只是从当前Compact Height这个 Size Class删除了, 并不会影响竖屏模式下的约束.
如此这般, 将 UILabel 中的约束也统统删除, 一个都不要. 所有约束删完后应该显示这样:


约束Constraints删除完成后的样子

Constraints删除后, 在Size Inspector栏中已经看不见约束了, 但是你仍然可以从左边的控件导航栏中看到刚刚删除的Constraints, 并且当前他们显示为灰色, 表示这些Constraints在当前 Size Classe 下不生效.

不要担心上面显示的小红点, 我们现在就修复它.

将 Storyboard 中的 Image和 Label 拖动到理想中的位置, 然后根据需求设置好Constraints, UIImageView的设置如下


image.png

UILabel的Constraints 设置如下


image.png

至此, 全部设置完, 你应该可以看到上面的 红点消失了, 说明我们 Constraints 设置正确. 单击"Done Varying" 完成 Constraints 设置

再次运行项目, 旋转屏幕, 可以看到横屏 Landsca 模式下实际运行效果与需求一致. 完美


iphone-landscape.PNG

zBeYWlSLb5Jfh42RXtEz6kHi9OeoSZ6B.gif

本示例项目可以在 Github 上下载

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

推荐阅读更多精彩内容