ios开发-Autolayout

1. 适配:

1. 可以分为两种适配:
1). 系统适配, 指的是ios不同版本系统的适配
2). 屏幕适配, 指的是根据屏幕大小的不同进行适配
    目前iPhone的尺寸: 3.5inch、4.0inch、4.7inch、5.5inch
    iPad的尺寸: 7.9inch、9.7inch
    屏幕方向: 竖屏  横屏

2. 什么是Autolayout

    Autolayout是一种“自动布局”技术,专门用来布局UI界面的.
    Autolayout自iOS 6开始引入,由于Xcode 4的不给力,当时并没有得到很大推广, 自iOS 7(Xcode 5)开始,Autolayout的开发效率得到很大的提升.
    苹果官方也推荐开发者尽量使用Autolayout来布局UI界面.
    Autolayout能很轻松地解决屏幕适配的问题.

3. Autoresizing

    在Autolayout之前,有Autoresizing可以作屏幕适配,但局限性较大,有些任务根本无法完成.
    相比之下,Autolayout的功能比Autoresizing强大很多.
    Autoresizing是解决子控件和父控件的位置关系的, 通过代码可以实现, 如下:(首先应该将自动布局禁掉)
redView.autoresizingMask = UIViewAutoresizingFlexibleRightMargin | UIViewAutoresizingFlexibleTopMargin | UIViewAutoresizingFlexibleWidth; 
以上代码就表示了最简单的Autoresizing.

4. Autolayout的2个核心概念

    参照
    约束
其中, 参照指的是拿谁做相对控件, 约束指的是针对于相对控件应该有什么样的约束条件.

5. Autolayout的警告和错误

    - 警告
        控件的frame不匹配所添加的约束, 比如
        比如约束控件的宽度为100, 而控件现在的宽度是110
    - 错误
        缺乏必要的约束, 比如
        只约束了宽度和高度, 没有约束具体的位置
    - 两个约束冲突, 比如
        1个约束控件的宽度为100, 1个约束控件的宽度为110

6.代码实现Autolayout

    代码实现Autolayout的步骤
    利用NSLayoutConstraint类创建具体的约束对象
    添加约束对象到相应的view上
    - (void)addConstraint:(NSLayoutConstraint *)constraint;
    - (void)addConstraints:(NSArray *)constraints;

    代码实现Autolayout的注意点
    要先禁止autoresizing功能,设置view的下面属性为NO
    view.translatesAutoresizingMaskIntoConstraints = NO;
    添加约束之前,一定要保证相关控件都已经在各自的父控件上
    不用再给view设置frame

7. NSLayoutConstraint

一个NSLayoutConstraint对象就代表一个约束

    创建约束对象的常用方法
        +(id)constraintWithItem:(id)view1 attribute:(NSLayoutAttribute)attr1 relatedBy:(NSLayoutRelation)relation toItem:(id)view2 attribute:(NSLayoutAttribute)attr2 multiplier:(CGFloat)multiplier constant:(CGFloat)c;
    其中:
    view1 :要约束的控件
    attr1 :约束的类型(做怎样的约束)
    relation :与参照控件之间的关系
    view2 :参照的控件
    attr2 :约束的类型(做怎样的约束)
    multiplier :乘数
    c :常量

8. 自动布局的核心计算公式

obj1.property1 =(obj2.property2 * multiplier)+ constant value

9. 约束规则:

    在创建约束之后,需要将其添加到作用的view上
    在添加时要注意目标view需要遵循以下规则:
    1)对于两个同层级view之间的约束关系,添加到它们的父view上
    2)对于两个不同层级view之间的约束关系,添加到他们最近的共同父view上
    3)对于有层次关系的两个view之间的约束关系,添加到层次较高的父view上

总结:

总而言之, 还是需要实践操作才能感受到自动布局的好吃, 相对于frame来说, 确实有过人之处.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值