写在开头,苹果官方有中文文档了,这对于蹩脚英语的童鞋,简直是莫大的幸福啊。同时也说明了,苹果对于我们天朝开发者的重视。链接iPhone X 适配
与原来的变化
1.高度增加145pt,变成812pt;
2.屏幕圆角显示,至少要留10pt间距;
3.状态栏由原来的20pt变成了44pt,相应的导航栏由64变成88pt;
4.底部工具栏还要为home indicator 留出34pt边距,Tabber高度变为83。
5.物理分辨率1125px*2436px,对应3X图。
6.不要在iPhone X下隐藏状态栏,一是距离足够不需要,而是这样会被齐刘海切掉。
7.homeBar的颜色是会自动适应的,保持着『时刻能找到但是又不那么显眼』的状态,所以不用去为它费心添加背景,强调啊啥的,苹果爸爸会十分感动然后拒绝掉你的……
8.时刻存在的homeBar代替了原来的home键,所以APP内部有上滑手势,尽量去掉吧,与这个homeBar冲突。
具体适配
有一个safeArea的概念,UIViewController 和 UIView 增加了两个属性,safeAeaInsets
和safeAreaLayoutGuide
,通过这两个属性,可以拿到安全区域。我们要做的就是:让那些不能被遮挡的视图在安全区域显示出来
注意:
safeAreaInsets
适用于手动计算
safeAreaLayoutGuide
适用于自动布局
-(void)viewSafeAreaInsetsDidChange;
安全区域一旦发生变化,就会调用这个方法,我们在要进行适配的VC或是View上重写这个方法即可。
注意:
在viewDidLoad
方法中,所有视图safeAreaInsets
的属性都是UIEdgeInsetsZero。-(void)viewSafeAreaInsetsDidChange;
这个方法是在viewWillAppear
之后,viewWillLayoutSubviews
之前调用。
如果你改变一个VC的safeAreaInsets
值,可以通过设置addtionalSafeAreaInsets
属性来实现,一旦改变safeAreaInsets
属性值,-(void)viewSafeAreaInsetsDidChange;
方法也会被调用。
分享一个宏,获取安全区域:
#define VIEWSAFEAREAINSETS(view) ({UIEdgeInsets i; if(@available(ios 11.0, *)){i = view.safeAreaInsets;} else {i = UIEdgeInsetsZero;} i;})
使用:VIEWSAFEAREAINSETS(view).left
VIEWSAFEAREAINSETS(self.view).right
总结:我们要做的就是让那些不能被遮挡的视图在安全区域内显示。
补充:
1.iOS 11中如果不实现-tableView: viewForFooterInSection:
和 -tableView: viewForHeaderInSection:
,那么-tableView: heightForHeaderInSection:
和- tableView: heightForFooterInSection:
不会被调用。
这是因为estimatedRowHeight estimatedSectionHeaderHeight estimatedSectionFooterHeight
三个高度估算属性由默认的0变成了UITableViewAutomaticDimension,导致高度计算不对。
2.直接调取tableView.contentSize 也有异常,解决办法同下:
解决方法:实现对应方法或把这三个属性设为0。
self.tableView.estimatedRowHeight = 0;
self.tableView.estimatedSectionHeaderHeight = 0;
self.tableView.estimatedSectionFooterHeight = 0;
2.撑开控件:
这个控件对应的view实现- intrinsicContentSize方法
- (CGSize)intrinsicContentSize {
return UILayoutFittingExpandedSize;
}
3.iOS 11中ViewController的automaticallyAdjustsScrollViewInsets属性被废弃了.
//笨方法解决:
if (@available(iOS 11.0, *)) {
self.tableView.contentInsetAdjustmentBehavior = UIScrollViewContentInsetAdjustmentNever;
} else {
self.automaticallyAdjustsScrollViewInsets = NO;
}
目前发现所有的Scrollview 及其子类都需要设置 contentInsetAdjustmentBehavior = UIScrollViewContentInsetAdjustmentNever ,工程中大量使用列表的同学不要慌,不要忙,因为UIView及其子类都遵循UIAppearance协议,我们可以进行全局配置:
// AppDelegate 进行全局设置
if (@available(iOS 11.0, *)){ [[UIScrollView appearance] setContentInsetAdjustmentBehavior:UIScrollViewContentInsetAdjustmentNever]; }
这样一来使用UITableview 、UICollectionView、UIScrollview的时候就不需要再单独设置该属性了。
4.安全区域参考文章:iOS 11安全区域
安全区域帮助我们将view放置在整个屏幕的可视的部分。即使把navigationbar设置为透明的,系统也认为安全区域是从navigationbar的bottom开始的。