iOS屏幕适配
iOS屏幕适配发展史
1> iPhone4以前(没有iPad)
* 不需要屏幕适配
2> iPad、iPhone5等设备出现
* 需要做横竖屏适配
* autoresizing
a) 解决子控件和父控件的适配问题
b) 子控件跟随父控件的一些行为进行自动调整
3> iOS 6.0开始
* autolayout
a) 解决任何控件的适配问题
b) 一个控件可以跟随其它任意控件的一些行为进行自动调整
autoresizing
-
1、autoresizing适用范围
- 解决子控件和父控件的适配问题
- 子控件跟随父控件的一些行为进行自动调整
-
2、代码实现
UIView *blueView = [[UIView alloc]init];
blueView.backgroundColor = [UIColor blueColor];
blueView.frame = CGRectMake(100, 100, 200, 100);
// 这里是设置blueView的宽、高、右侧与父容器的距离、上边与父容器的距离一定!
blueView.autoresizingMask = UIViewAutoresizingFlexibleLeftMargin | UIViewAutoresizingFlexibleBottomMargin;
[self.view addSubview:blueView];
autolayout
-
1、什么是autolayout
- Autolayout是一种“自动布局”技术,专门用来布局UI界面的
- Autolayout自
iOS 6
开始引入,由于Xcode 4的不给力,当时并没有得到很大推广 - 自iOS 7(Xcode 5)开始,Autolayout的开发效率得到很大的提升
- Autolayout能很轻松地解决屏幕适配的问题
-
2、代码实现autolayout
- 利用
NSLayoutConstraint
类创建具体的约束对象 - 添加约束对象到相应的view上
-(void)addConstraint:(NSLayoutConstraint *)constraint;
-(void)addConstraints:(NSArray *)constraints;
- 利用
-
3、代码实现Autolayout的注意点
- 要先禁止autoresizing功能,设置view的下面属性为NO
view.translatesAutoresizingMaskIntoConstraints = NO;
- 添加约束之前,一定要保证相关控件都已经在各自的父控件上
- 不用再给view设置frame
- 要先禁止autoresizing功能,设置view的下面属性为NO
-
4、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 :常量
- 参数说明:
自动布局核心公式
obj1.property1 =(obj2.property2 * multiplier)+ constant value