iOS11与iPhoneX适配
iPhone所有机型的尺寸表:
data:image/s3,"s3://crabby-images/32301/323016494be7e31d6e9707d630caa499010b149a" alt=""
iPhone X基本属性
data:image/s3,"s3://crabby-images/0d2a1/0d2a1015fec586ffd03d980026a1ecba0eb6baee" alt=""
- 启动图尺寸:1125px × 2436px(即 375pt × 812pt @3x))
- iphoneX 屏幕高:812.0个点
- 导航栏高度+状态栏高度:88.0个点(导航栏高度仍是44个点,状态栏高度增高为44个点,所以刘海的高度并不是状态栏的高度。状态栏和导航栏平分了头部总的高度)
- tabbar高度:83.0个点(原是固定49个点,增高了34个点).
顶部适配
- iOS11automaticallyAdjustsScrollViewInsets属性废弃了 系统自己计算内边距 会出现ScorllView下沉20的现象
data:image/s3,"s3://crabby-images/27faa/27faa73d6cbe4f9acee38e6ea7be4f61860be0b0" alt=""
可以调用scrollview新的apicontentInsetAdjustmentBehavior
self.automaticallyAdjustsScrollViewInsets = NO;
if (@available(iOS 11.0, *)) {
self.tableView.contentInsetAdjustmentBehavior = UIScrollViewContentInsetAdjustmentNever;
}
但是这么写会导致在iPhoneX下出现,由于在X下安全区域的出现,顶部异形区域不建议覆盖,会造成视觉的差异
data:image/s3,"s3://crabby-images/0b99a/0b99aac8e55d99af5e781c37d392f10eb1073e3e" alt=""
在代码中我们需要来根据设备高度来判断iPhoneX,从而来避免这种情况
[tableview mas_makeConstraints:^(MASConstraintMaker *make) {
make.edges.equalTo(self.view);
if (LL_iPhoneX) {
if (@available(iOS 11.0, *)) {
make.top.equalTo(self.view.mas_safeAreaLayoutGuideTop);
}
}else{
make.top.equalTo(self.view.mas_top).offset(0);
}
make.left.equalTo(self.view).offset(0);
make.right.equalTo(self.view).offset(0);
make.bottom.equalTo(self.view).offset(0);
}];
data:image/s3,"s3://crabby-images/7d786/7d786f741e5a4b3f654a831caabec290c868ff44" alt=""
上面使用的Masonry,并且版本需要在V1.1.0版本
data:image/s3,"s3://crabby-images/c2b9d/c2b9dbc6d3ed51febb91722576698b5dbb2b8572" alt=""
苹果自己的约束代码如下
if (@available(iOS 11.0, *)) {
NSLayoutConstraint *top = [contentView.topAnchor constraintEqualToAnchor:self.view.safeAreaLayoutGuide.top Anchor];
NSLayoutConstraint *bottom = [contentView.bottomAnchor constraintEqualToAnchor:self.view.safeAreaLayoutGuide.bottomAnchor];
NSLayoutConstraint *left = [contentView.leftAnchor constraintEqualToAnchor:self.view.safeAreaLayoutGuide.leftAnchor];
NSLayoutConstraint *right = [contentView.rightAnchor constraintEqualToAnchor:self.view.safeAreaLayoutGuide.rightAnchor];
[NSLayoutConstraint activateConstraints:@[top, bottom, left, right]];
} else {
NSLayoutConstraint *top = [contentView.topAnchor constraintEqualToAnchor:self.topLayoutGuide.bottomAnchor];
NSLayoutConstraint *bottom = [contentView.bottomAnchor constraintEqualToAnchor:self.bottomLayoutGuide.topAnchor];
NSLayoutConstraint *left = [contentView.leftAnchor constraintEqualToAnchor:self.view.leftAnchor];
NSLayoutConstraint *right = [contentView.rightAnchor constraintEqualToAnchor:self.view.rightAnchor];
[NSLayoutConstraint activateConstraints:@[top, bottom, left, right]];
}
我使用的coocaPods导入的Masonry的Podfile.
data:image/s3,"s3://crabby-images/0b90f/0b90fe28ac2ccaf899bc0ff4202c1ed35f991a97" alt=""
适配宏
// UIScreen width.
#define HT_ScreenWidth [UIScreen mainScreen].bounds.size.width
// UIScreen height.
#define HT_ScreenHeight [UIScreen mainScreen].bounds.size.height
// iPhone X
#define HT_iPhoneX (HT_ScreenWidth == 375.f && HT_ScreenHeight == 812.f ? YES : NO)
// Status bar height.
#define HT_StatusBarHeight (HT_iPhoneX ? 44.f : 20.f)
// Navigation bar height.
#define HT_NavigationBarHeight 44.f
// Tabbar height.
#define HT_TabbarHeight (HT_iPhoneX ? (49.f+34.f) : 49.f)
// Tabbar safe bottom margin.
#define HT_TabbarSafeBottomMargin (HT_iPhoneX ? 34.f : 0.f)
// Status bar & navigation bar height.
#define HT_StatusBarAndNavigationBarHeight (HT_iPhoneX ? 88.f : 64.f)
#define HT_ViewSafeAreInsets(view) ({UIEdgeInsets insets; if(@available(iOS 11.0, *)) {insets = view.safeAreaInsets;} else {insets = UIEdgeInsetsZero;} insets;})
网友评论