ios11+html5偏移20pt,10分钟适配 iOS 11 & iPhone X

适配中的问题及解决办法

1. 滚动条高度跳动、上下拉刷新问题:

self.tableView.estimatedRowHeight = 0;

self.tableView.estimatedSectionHeaderHeight = 0;

self.tableView.estimatedSectionFooterHeight = 0;

2. 列表/页面偏移

设置工程中的UITableView、UICollectionView、UIScrollView的contentInsetAdjustmentBehavior属性,如下:

if (@available(iOS 11.0, *)){

_tableView.contentInsetAdjustmentBehavior = UIScrollViewContentInsetAdjustmentNever;

}

总的来说所有继承与Scrollview 及其子类都需要设置 contentInsetAdjustmentBehavior = UIScrollViewContentInsetAdjustmentNever ,每个设置很麻烦,没关系。由于UIView及其子类都遵循UIAppearance协议,我们可以进行全局配置:

// AppDelegate 进行全局设置

if (@available(iOS 11.0, *)){

[[UIScrollView appearance] setContentInsetAdjustmentBehavior:UIScrollViewContentInsetAdjustmentNever];

}

注意:

3. 导航栏按钮位置问题

iOS 11重新调整了导航栏的元素,强制将leftButtons和rightButtons位置往屏幕中央靠了一些,在这之前通过添加一个UIBarButtonSystemItemFixedSpace 把宽度设为负数以调整按钮的边距

//调整按钮边距

// UIBarButtonItem* spaceItem = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonSystemItemFixedSpace target:nil action:nil];

// //将宽度设为负值

// spaceItem.width= -5;

// [items addObject:spaceItem];

iOS 11如上设置是无效的

如果你无法接受系统给设定的位置,可以试试下面的方法

#pragma mark 导航栏 添加文字按钮

- (NSMutableArray *)addNavigationItemWithTitles:(NSArray *)titles isLeft:(BOOL)isLeft target:(id)target action:(SEL)action tags:(NSArray *)tags

{

NSMutableArray * items = [[NSMutableArray alloc] init];

//调整按钮位置

// UIBarButtonItem* spaceItem = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonSystemItemFixedSpace target:nil action:nil];

// //将宽度设为负值

// spaceItem.width= -5;

// [items addObject:spaceItem];

NSMutableArray * buttonArray = [NSMutableArray array];

NSInteger i = 0;

for (NSString * title in titles) {

UIButton * btn = [UIButton buttonWithType:UIButtonTypeCustom];

btn.frame = CGRectMake(0, 0, 30, 30);

[btn setTitle:title forState:UIControlStateNormal];

[btn addTarget:target action:action forControlEvents:UIControlEventTouchUpInside];

btn.titleLabel.font = SYSTEMFONT(16);

[btn setTitleColor:KWhiteColor forState:UIControlStateNormal];

btn.tag = [tags[i++] integerValue];

[btn sizeToFit];

//设置偏移

if (isLeft) {

[btn setContentEdgeInsets:UIEdgeInsetsMake(0, -10, 0, 10)];

}else{

[btn setContentEdgeInsets:UIEdgeInsetsMake(0, 10, 0, -10)];

}

UIBarButtonItem * item = [[UIBarButtonItem alloc] initWithCustomView:btn];

[items addObject:item];

[buttonArray addObject:btn];

}

if (isLeft) {

self.navigationItem.leftBarButtonItems = items;

} else {

self.navigationItem.rightBarButtonItems = items;

}

return buttonArray;

}

此法实属障眼法,并不完美,通过设置内容偏移,让按钮视觉上看起来位置改变了,实际位置并没有发生变化,这可能导致按钮部分区域响应点击事件。

若追求完美,可以试着自定义UIButton重写hitTest方法尝试改变点击区域。

若有其他完美的办法请联系我更新。

4. 位置权限

在IOS11,原有的NSLocationAlwaysUsageDeion被降级为NSLocationWhenInUseUsageDeion。因此,在原来项目中使用requestAlwaysAuthorization获取定位权限,而未在plist文件中配置NSLocationAlwaysAndWhenInUseUsageDeion,系统框不会弹出。建议新旧key值都在plist里配置,反正我试下来是没有问题,唯一的区别是使用requestAlwaysAuthorization获取权限 IOS11系统弹框会把几种权限级别全部列出,供用户选择,显然更人性化了。

快去更新你的info.plist

NSLocationUsageDescription

获取地理位置,精准推送服务

NSLocationWhenInUseUsageDescription

获取地理位置,精准推送服务

NSLocationAlwaysUsageDescription

App需要您的同意,才能始终访问位置

NSLocationAlwaysAndWhenInUseUsageDeion

App需要您的同意,才能始终访问位置

5. iPhone X 适配

iPhone X 变化最大的是头部 & 底部

非iPhone X :

StatusBar 高20pt,NavigationBar 高44pt,底部TabBar高49pt

iPhone X:

StatusBar 高44pt,NavigationBar 高44pt,底部TabBar高83pt

所以,之前项目里写死的 ±49 ±64 都要出问题,如果你之前抽离出来使用的是宏,那问题不大,如果不是,开始搬砖吧少年。

送你几个宏,来日好好撸,莫偷懒

#define kStatusBarHeight [[UIApplication sharedApplication] statusBarFrame].size.height

#define kNavBarHeight 44.0

//注意:请直接获取系统的tabbar高度,若没有用系统tabbar,建议判断屏幕高度;之前判断状态栏高度的方法不妥,如果正在通话状态栏会变高,导致判断异常,下面只是一个例子,请勿直接使用!

#define kTabBarHeight kAppDelegate.mainTabBar.tabBar.frame.size.height

#define kTopHeight (kStatusBarHeight + kNavBarHeight)

替换 64pt →kTopHeight

替换 49pt →kTabBarHeight

6. iPhone X push的时候TabBar上移

这样可以解决大部分因位置导致的适配问题

请关注点❤️,持续更新……

以上属于臭码农原创,若有雷同属巧合,如有错误望指正,转载请标明来源和作者。

by:臭码农

作者:臭码农

链接:https://www.jianshu.com/p/94d3fdc0f20d

來源:简书

简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值