Content Compression Resistance和Content Hugging
来源:互联网 发布:击剑器材数据 编辑:程序博客网 时间:2024/05/21 17:22
一 基础知识
1.Intrinsic Content Size:
就是像button,label等文本的size。其中橙色虚线既是label默认的Content Size。(会根据label的text内容的不同,而不同)
2.Content Hugging:抗拉伸 Content Compression Resistance: 抗压缩
下图为 xib中 默认的数值。
注意:仅当视图定义了自己的Intrinsic Content Size,那么它的Content Compression Resistance优先级和Content Hugging优先级属性才有作用。
二 总规则:
Horizontal方向(水平方向):
宽度< Content Size ,并且宽度约束优先级< Content Compression Resistance
- 抗压缩起作用,宽度= Content Size,用户想要设置的宽度无效。
- 例子:
对于Content Compression Resistance默认的优先级下(750),需要把控件的宽度约束优先级设置UILayoutPriorityRequired(1000),宽度才会满足用户的设置要求,否则宽度则为Content Size。
- 例子:
- 抗压缩起作用,宽度= Content Size,用户想要设置的宽度无效。
宽度> Content Size,并且宽度约束优先级< Content Hugging优先级
- 抗拉伸起作用,宽度 = Content Size,用户想要设置的宽度无效。
- 例子:
- 对于Content Hugging默认的优先级下(251),需要把控件的宽度约束优先级设置UILayoutPriorityDefaultHigh(750),宽度才会满足用户的设置要求,否则宽度则为Content Size。
- 例子:
- 抗拉伸起作用,宽度 = Content Size,用户想要设置的宽度无效。
Vertical方向(垂直方向):
同水平方向。只不过比的是高度。
三 详细说明
一.宽度小于intrinsic Content Size的默认大小,Content Compression Resistance起作用
(1) 宽度约束为750时,Content Compression Resistance Priority的Horizontal 大于750时,橙色方框为实际展现的效果。宽度为intrinsic Content Size的默认大小。控件label不会被压缩。
其中宽度约束的约束优先级为750,Content Compression Resistance Priority的Horizontal的优先级为751.
(2)宽度约束为750时,Content Compression Resistance Priority的Horizontal <750时,橙色方框为实际展现的效果。宽度为宽度约束大小。控件label会被压缩
其中宽度约束的约束优先级为750,Content Compression Resistance Priority的Horizontal的优先级为749
二 宽度大于intrinsic Content Size的默认大小,Content Hugging起作用
(1)宽度约束为251时,Content Hugging的Horizontal 大于251时,橙色方框为实际展现的效果。实际宽度为intrinsic Content Size的默认大小。控件label不会被拉伸。
其中宽度约束的约束优先级为251,Content Compression Resistance Priority的Horizontal的优先级为252.
(2)宽度约束为251时,Content Compression Resistance Priority的Horizontal 小于251时,橙色方框为实际展现的效果。宽度为宽度约束大小。控件label会被拉伸
其中宽度约束的约束优先级为251,Content Compression Resistance Priority的Horizontal的优先级为250.
参考:
http://codingobjc.com/blog/2015/01/28/autolayoutzhong-de-content-compression-resistancehe-content-huggingdao-di-shi-shi-yao-yi-si/
- IOS Content Hugging 和 Content Compression Resistance
- Content Compression Resistance和Content Hugging
- Content Compression Resistance和Content Hugging
- Content Compression Resistance和Content Hugging
- Content hugging和Content compression resistance
- Content Compression Resistance和Content Hugging
- AutoLayout中的Content Hugging 和 Content Compression Resistance
- Xcode的Content Hugging 和 Content Compression Resistance
- AutoLayout中的Content Hugging 和 Content Compression Resistance
- AutoLayout之Content Hugging Priority和Content Compression Resistance Priority
- iOS autolayout的Content Hugging 和 Content Compression Resistance
- AutoLayout中的Content Hugging 和 Content Compression Resistance
- AutoLayout中的Content Hugging 和 Content Compression Resistance
- AutoLayout中的Content Hugging 和 Content Compression Resistance
- Xcode之Autolayout -- "Content Hugging"和"Content Compression Resistance"
- Content Hugging Priority & Content Compression Resistance Priority 区别
- 详解intrinsicContentSize 及 约束优先级/content Hugging/content Compression Resistance
- 对Auto Layout中的Content Compression Resistance和Content Hugging的总结
- 一起talk C栗子吧(第六十三回:C语言实例--字符串查找)
- LeetCode---String to Integer (atoi)
- android sqlite cursor 没有返回数据,资源占用问题
- Android之退出应用关闭项目每个Activity的总结
- 佛祖保佑,永不宕机/永无bug
- Content Compression Resistance和Content Hugging
- <2> go -反射-函数map化
- 记一次在Windows上搭建React Native Android环境踩过的坑
- 运行时系统(Runtime System)
- 数据库索引的优点与缺点
- android 把一个Activity窗口化的实现
- vim使用方法
- 栈计算器 Calculator1.0
- 迎接大数据时代