Autolayout之真实内容尺寸(Intrinsic Content Size)

注:本文节选并翻译自Anatomy of a Constraint

真实内容尺寸

到目前为止,所有的示例都是用约束来定义视图的位置和尺寸的。可是,某些视图会根据当前内容生成出一个自然尺寸。这个尺寸即可参考着叫做真实内容尺寸。比如,一个按钮的真实内容尺寸就是它的标题加上一个小边缘。

不是所有的视图都有真实内容尺寸,对于普通视图来说,真实内容尺寸可以定义出视图的宽、高或者二者全部。下面的表格3-1中列出了一些示例。

  • 表格3-1 基本控件的真实内容尺寸
视图 真实内容尺寸
UIView和NSView
Sliders 只定义了宽度(iOS)
Labels、buttons、switches和text fields 同时定义了宽度和高度
Text views和image views 不同情况下差别很大

真实内容尺寸基于视图的当前内容。一个label或button的真实内容尺寸基于显示文字的总量和使用的字体。对于其他视图来说,真实内容尺寸可能会更复杂。例如,一个空的image view没有真实内容尺寸。一旦在上面添加图片之后,它的真实内容尺寸就被设置为图片的尺寸了。

一个text view的真实内容尺寸有多种不同情况,取决于其内容、是否可以滑动或者是给它添加的其他约束。比如,当可以滑动时,text view没有真实内容尺寸。当不可滑动时,默认来说视图的真实内容尺寸基于不换行的文字计算而来。再例,在文字中如果不存在换行,真实内容尺寸会计算出需要的宽和高,并将内容布局为一个单行文字。如果你添加约束指定了text view的宽,真实内容尺寸就会根据此宽度来定义出需要的高度并进行显示。

Autolayout通过对每一个尺寸使用一对约束来表示真实内容尺寸。抗拉伸约束(content hugging,内容包裹)把视图向内部推以保证它可以优雅地环抱着其内容。抗压缩约束(compression resistance)把视图向外推以便它不会轻易裁剪其内容。

img

在列表3-5中展示的这些约束通过使用不等式来进行定义。这里,IntrinsicHeightIntrinsicWidth常量代表了视图真实内容尺寸中的宽和高。

  • 列表3-5 抗压缩和抗拉伸约束方程
// 抗压缩
View.height >= 0.0 * NotAnAttribute + IntrinsicHeight
View.width >= 0.0 * NotAnAttribute + IntrinsicWidth
 
// 抗拉伸
View.height <= 0.0 * NotAnAttribute + IntrinsicHeight
View.width <= 0.0 * NotAnAttribute + IntrinsicWidth

这些约束中的每一个都有自己的优先级。默认来说,视图使用250优先级来定义抗拉伸约束,而使用750优先级来定义抗压缩约束。因此,对于压缩视图来说,拉伸它更加容易。对大多数的控件来说,这都是默认行为。例如,你可以安全地将一个button拉伸到大于它本身的真实内容尺寸;但是,如果你压缩它,则很可能会裁剪其内容。记住,Interface Builder可能会适当修改这些优先级以避免此种情况发生。了解更多信息,请看设置抗拉伸和抗压缩约束的优先级

尽可能地在布局中多使用视图的真实内容尺寸。它可以让你的布局动态适配视图内容的变化。它还可以减少约束的数量来创建出明确的、无冲突的布局,但是你需要管理该视图的抗拉伸和抗压缩约束(统称为CHCR)的优先级。这里是一些处理真实内容尺寸的指导建议:

  • 当拉伸一些列视图来填充空间时,如果所有视图都有相同的抗拉伸优先级,此布局就存在歧义了。Autolayout不知道应该拉伸哪个视图。
    一个普遍的例子就是label和text field的组合。一般来说,你想要让text field来拉伸填充额外空间,而label保持它自身的真实内容尺寸。要确保这种情况,要保证text field的水平抗拉伸优先级要低于label。
    实际上,这个例子如此普遍,Interface Builder已经可以自动处理此情况,自动将label的抗拉伸优先级设置为251。如果手动编码进行布局,你需要自己修改抗拉伸优先级。
  • 当一些带有不可见背景的视图(如buttons或labels)被拉伸超过本身真实内容尺寸时,可能经常会显示出怪异或非预期的布局。导致的实际问题可能并不严重,因为文字直接出现在了错误位置上。要避免这种不必要的拉伸,增加抗拉伸优先级即可。
  • 基准线约束只在那些存在真实内容高度的视图上才有效。如果一个视图被垂直拉伸或压缩,基准线约束便不再正常匹配。
  • 一些视图,如switches,应该总是以真实内容尺寸进行显示。通过提高CHCR优先级来防止被拉伸或压缩。
  • 避免给视图设置“必须级”CHCR优先级。对于视图来说错误的显示尺寸要比偶然出现的约束冲突要更好。如果一个视图需要一直保持真实内容尺寸,考虑将其设置为“非常高”(999)优先级。这个接近“满级”的优先级统称可以保证视图不被拉伸或压缩,而且还可以提供出一个紧急值,以免你的视图在一个与你期望的优先级不同的环境下显示。

真实内容尺寸 VS 合适尺寸

真实内容尺寸在Autolayout中扮演着输入角色。当一个视图存在真实内容尺寸是,系统会生成对应约束来表示尺寸,并且该约束被用于布局的计算。

另一方面,合适尺寸,相当于Autolayout发动机的输出。它是一个视图基于约束计算而得出的尺寸。如果一个视图使用Autolayout来布局子视图,系统便会基于其内容(也就是子视图的布局)计算出该视图的合适尺寸。

UIStackView就是一个好例子。排除任何其他约束,系统会基于其内容和属性计算出stack view的尺寸。从各种角度来看,stack view就好像是存在真实内容尺寸一样:你可以仅仅通过一个单独的垂直约束和一个水平约束就可以定义其位置,进而生成一个完整布局。但是它的尺寸是通过Autolayout进行计算的----所以尺寸并不是作为Autolayout的输入。设置stack view的CHCR优先级也没有作用,因为实际上stack view并不存在真实内容尺寸。

如果你想要让stack view与外部其他视图(不是stack view的子视图)进行自适应尺寸适配,要么就创建明确的约束来捕获那些关系,要么就参照外部其他视图来修改stack view子视图的CHCR优先级。

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

推荐阅读更多精彩内容

  • 翻译自“Auto Layout Guide”。 1 入门 1.1 理解自动布局 自动布局根据视图层级结构中视图上的...
    lakerszhy阅读 3,472评论 3 26
  • 翻译自“Auto Layout Guide”。 2 自动布局细则手册 2.1 堆栈视图 接下来的章节展示了如何使用...
    lakerszhy阅读 1,803评论 3 9
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 11,612评论 4 59
  • 御台所,好奇怪的名字哦…… 是官位职称吗?需要考级证书吗? 不是…… 御台所是古代日本对大臣和将军的称呼。 到了德...
    婉㚥阅读 7,060评论 4 5
  • 林一铭的女朋友秦丽娜是音乐学院的研究生,小提琴天才。秦丽娜总喜欢穿一袭红色的半长裙,露出雪白的半个后背,黑色的长...
    颖七七阅读 909评论 0 2