iOS中的AutoLayout使用实践总结

前言

AutoLayout非常强大也非常易用,可读性也很强,加上各种第三方AutoLayout库,让你布起局来犹如绷掉链子的狗!但在使用中也有各种各样的问题,下面就来给大家详细介绍下。

AutoLayout 问题

  • 布局冲突
  • 固有尺寸冲突
  • 布局和固有尺寸冲突

主要概念

  • 固有尺寸 intrinsicContentSize(意思就是说我知道自己的大小,如果你没有为我指定大小,我就按照这个大小来。)
  • hugging,compress
  • priority
  • constraint:equal,unequal

一个UIView显示,需要有2个元素,position & size。AutoLayout可以确定view 的这两个,so 不用frame。

1、布局遇到的问题

布局绝对冲突:

eg 设置了 view 的左右,然后又有个 width,造成冲突

解决方案:

1.设置优先级(低优先级constraint没有用到的时候的时候系统默认忽略)

2.删除没有的constraint(常用)

2、布局模糊冲突

假设UIView2的宽度不能超过50。当UIView1宽度小于50的时候,二者等宽;

当UIView1宽度大于50的时候,UIView2不受UIView1宽度的影响。

于是给UIView2加上一条约束:宽度<=50。这时候冲突来了:

因为UIView1的宽度是定好的,而UIView2和UIView1等宽。那么UIView2的宽度就是确定的。

so 当宽度 > 50 的时候,就是冲突,<= 50 的时候就不是冲突

解决方案:

equal width priority 设置低一些,这样让 View2 先满足<= 50的 constraint,当他的width <= 50 的时候equal width生效

enum {
 UILayoutPriorityRequired = 1000,
 UILayoutPriorityDefaultHigh = 750,
 UILayoutPriorityDefaultLow = 250,
 UILayoutPriorityFittingSizeLevel = 50,
};

1、intrinsic冲突

content Hugging/content Compression Resistance 设置优先级解决intrinsicContentSize

  • Hugging (不想填充空间)
  • Compression (不想被挤压)
  • 有这两个特性的 view 一定实现了 intrinsicContentSize
  • Hugging 默认 priority = 250
  • Compression 默认 priority = 750
  • 其他 constraint 默认 priority = 1000(最大)

当 constraint.priority > hugging.priority View会被拉伸

当 constraint.priority < hugging.priority View会被抱紧在priority小的那一边

当 constraint.priority > compression.priority View 会被挤压

当 constraint.priority < compression.priority View 不会被挤压

eg UILabel 有intrinsicContentSize 那么UILabel的size 就用它,

如果有constraint 设置了 size 那么使用 constraint的

UILabel1、和UILabel2布局 :

距离上边栏都是50点。 UILabel1与左边栏距离为10,UILabel2左面距离UILabel1为10点。

因为都具有Intrinsic属性,所以不需要指定size,位置应该也明确了。

再给UILabel2加一条约束,右侧距离右边栏为10点。(如果view 没有intrinsicContentSize,那么右边的view 会被拉伸)

因为 UILabel 有intrinsicContentSize 所以2个Labe 必须有一个要被拉伸

* 1个label 使用自己的intrinsic,另一个填充其他空间

使用场景

1、没有 intrinsicContentSize 的view 使用 priority,将模糊冲突改变成条件布局

2、有 intrinsicContentSize 的view

改变hugging or compression 的priority,解决intrinsic 冲突

虽然有intrinsic 只要给出origin 和 size 就可以了,可是使用 unequal constraint 完善布局,避免警告

主要接口 & 属性

UILabel 的preferredMaxLayoutWidth,如果有多行要设置正确的preferredMaxLayoutWidth,来得到 正确的intrinsicContentSize

systemLayoutSizeFittingSize 调用 intrinsicContentSize

layoutIfNeed 如果有布局变化强制刷新

当视图的内在内容改变时,需要调用 invalidateIntrinsicContentSize ,让系统知道在下次布局时重新计算intrinsicContentSize

// 原有的视图尺寸和现在的不相符,
- (void)layoutSubviews {
 [super layoutSubviews];
 _collectionView.frame = self.bounds;
 if (!CGSizeEqualToSize(self.bounds.size, [self intrinsicContentSize])) {
 [self invalidateIntrinsicContentSize];
 }
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。

(0)

相关推荐

  • iOS中的AutoLayout使用实践总结

    前言 AutoLayout非常强大也非常易用,可读性也很强,加上各种第三方AutoLayout库,让你布起局来犹如绷掉链子的狗!但在使用中也有各种各样的问题,下面就来给大家详细介绍下. AutoLayout 问题 布局冲突 固有尺寸冲突 布局和固有尺寸冲突 主要概念 固有尺寸 intrinsicContentSize(意思就是说我知道自己的大小,如果你没有为我指定大小,我就按照这个大小来.) hugging,compress priority constraint:equal,unequal 一

  • 总结iOS开发中的断点续传与实践

    前言 断点续传概述 断点续传就是从文件上次中断的地方开始重新下载或上传数据,而不是从文件开头.(本文的断点续传仅涉及下载,上传不在讨论之内)当下载大文件的时候,如果没有实现断点续传功能,那么每次出现异常或者用户主动的暂停,都会去重头下载,这样很浪费时间.所以项目中要实现大文件下载,断点续传功能就必不可少了.当然,断点续传有一种特殊的情况,就是 iOS 应用被用户 kill 掉或者应用 crash,要实现应用重启之后的断点续传.这种特殊情况是本文要解决的问题. 断点续传原理 要实现断点续传 , 服

  • 详细整理iOS中UITableView的性能优化

    一.介绍 iOS开发中,UITableView可能是平时我们打交道最多的UI控件之一,其重要性不言而喻.Android也是如此,Android中的ListView和UITableView是相同功能的一个控件,但是iOS的UITableView更为强大一点,原因就不说了,如果你学过Android就知道iOS中的UITableView使用起来是非常简单的,这也是峰哥喜欢iOS胜过Android的原因之一.今天研究的内容就是UITableView的优化. 开始之前,你能说出几种UITableView的

  • 30分钟快速带你理解iOS中的谓词NSPredicate

    一.引言 在现代汉语的解释中,谓词是用来描述或判断客体性质.特征或者客体之间关系的词项.通俗的说,它是描述事物属性的.在iOS开发Cocoa框架中,有提供NSPredicate类,这个类通常也被成为谓词类,其主要的作用是在Cocoa中帮助查询和检索,但是需要注意,实质上谓词并不是提供查询和检索的支持,它是一种描述查询检索条件的方式,就像更加标准通用的正则表达式一样. NSPredicate提供的谓词可以分为两类:比较谓词和复合谓词. 比较谓词:比较谓词通过使用比较运算符来描述所符合条件的属性状态

  • ios中Deep Linking实例分析用法

    在 iOS 中,deep linking 实际上包括 URL Scheme.Universal Link.notification 或者 3D Touch 等 URL 跳转方式.应用场景比如常见的通知,社交分享,支付,或者在 webView 中点击特定链接在 app 中打开并跳转到对应的原生页面. 用的最多也是最常用的是通过 Custom URL Scheme 来实现 deep linking.在 application:openURL:sourceApplication:annotation

  • IOS 中CALayer绘制图片的实例详解

    IOS 中CALayer绘制图片的实例详解 CALayer渲染内容图层.与UIImageView相比,不具有事件响应功能,且UIImageView是管理内容. 注意事项:如何使用delegate对象执行代理方法进行绘制,切记需要将delegate设置为nil,否则会导致异常crash. CALayer绘制图片与线条效果图: 代码示例: CGPoint position = CGPointMake(160.0, 200.0); CGRect bounds = CGRectMake(0.0, 0.0

  • IOS 中CATextLayer绘制文本字符串

    IOS 中CATextLayer绘制文本字符串 CATextLayer使用Core Text进行绘制,渲染速度比使用Web Kit的UILable快很多.而且UILable主要是管理内容,而CATextLayer则是绘制内容. CATextLayer的绘制文本字符串的效果如下: 代码示例: // 绘制文本的图层 CATextLayer *layerText = [[CATextLayer alloc] init]; // 背景颜色 layerText.backgroundColor = [UIC

  • iOS中使用schema协议调用APP和使用iframe打开APP的例子

    在iOS中,需要调起一个app可以使用schema协议,这是iOS原生支持的,并且因为iOS系统中都不能使用自己的浏览器内核,所以所有的浏览器都支持,这跟android生态不一样,android是可以自己搞内核的,但是iOS不行. 在iOS中提供了两种在浏览器中打开APP的方法:Smart App Banner和schema协议. Smart App Banner 即通过一个meta 标签,在标签上带上app的信息,和打开后的行为,例如:app-id之类的,代码形如: 复制代码 代码如下: <m

  • iOS 中根据屏幕宽度自适应分布按钮的实例代码

    下载demo链接:https://github.com/MinLee6/buttonShow.git 屏幕摆放的控件有两种方式,一种根据具体内容变化,一种根据屏幕宽度变化. 下面我分别将两个方式,用代码的方式呈现: 1:根据具体内容变化 // // StyleOneViewController.m // buttonShow // // Created by limin on 15/06/15. // Copyright © 2015年 信诺汇通信息科技(北京)有限公司. All rights

  • IOS 中UITextField,UITextView,UILabel 根据内容来计算高度

    IOS 中UITextField,UITextView,UILabel 根据内容来计算高度 在开发的过程中,常常遇到根据内容来决定控件的高度的情况,常见的就是UITextField,UITextView,UILabel这三个控件,下面一UITextView 为例来说明一下: 首先新新建一个textView. 设施text,font UITextView *textView = [[UITextView alloc] init]; textView.text = @"2015-01-19 14:0

随机推荐