iOS11的适配
2017-09-22 本文已影响314人
找不到好的ID
关于最近的一个项目,升级了11之后遇到的一些问题,记录一下。
1.tabbar 上的红点没有了,因为我用的颜色是图片上取的渐变色,原因还不知道,深挖中,我的解决方案是换了一个颜色相近的。
data:image/s3,"s3://crabby-images/611d6/611d6354566b8721e16cda843b8e73064be863d8" alt=""
之前代码
nav.tabBarItem.badgeColor = [UIColor gradientRedPinkColor];
+ (UIColor *)gradientRedPinkColor
{
return [UIColor colorWithPatternImage:[UIImage imageNamed:@"Gradient"]];
}
之后代码
nav.tabBarItem.badgeColor = [UIColor unt_redPinkColor];
+ (UIColor *)unt_redPinkColor
{
return [UIColor colorWithRed:251.0f / 255.0f green:52.0f / 255.0f blue:112.0f / 255.0f alpha:1.0f];
}
data:image/s3,"s3://crabby-images/f6c06/f6c06a93fdd3f787e069539a0fb27e8133e23e71" alt=""
2.navigationBar上的自定义按钮,边距改变了,原因是iOS11对navigationController上的视图进行调整了。
data:image/s3,"s3://crabby-images/a8f59/a8f598e2c9e52aa1d1b56d0b8a205223a7418a81" alt=""
之前代码中设置的空15距离没有效果了,很无奈。
data:image/s3,"s3://crabby-images/fdfb3/fdfb31d90b1d79641d84bac20dd16f96c493ffea" alt=""
之后代码,我设置了两个一样的按钮,只是第一个按钮是有图案的,有点投机取巧的意思,但是达到了目的,之后我发现更好的办法我会改掉的
data:image/s3,"s3://crabby-images/7030c/7030cf8fcc4437e04d7cc62bbfdeabba64e6b646" alt=""
data:image/s3,"s3://crabby-images/b5067/b5067d95536120a2986bb7c3ed3fd31ce5de7004" alt=""
3.tableview中的一些改动,如果你实现了下面两个分区高度的代理方法
data:image/s3,"s3://crabby-images/e2ab2/e2ab26c5abeae5b61ec55f4439e998e77caa8a4c" alt=""
却没有实现下面这两个分区视图的代理方法
data:image/s3,"s3://crabby-images/a87cd/a87cd56a5bcf5c7e4a2b25397ae5f07c6ec767d8" alt=""
你会发现区与区之间设置的高度是无效的
data:image/s3,"s3://crabby-images/9d54e/9d54e57ea7cc64e8d0af93f8d4f9e29bab9fe6e7" alt=""
之后的代码,修改之后没有问题
设置estimatedSectionHeaderHeight和estimatedSectionFooterHeight
_tableView.estimatedSectionHeaderHeight = 0;
_tableView.estimatedSectionFooterHeight = 0;
data:image/s3,"s3://crabby-images/80cc2/80cc23812caffec89c59ed07c00614fb8762505c" alt=""
4 我觉得UI上比较重要的一个属性取消了,大家在使用滑动控件的时候,遇到下移64的问题,一般都是通过这个解决的。
data:image/s3,"s3://crabby-images/354b0/354b0539e9d61bf56610a4883f7d56fce97c4f27" alt=""
data:image/s3,"s3://crabby-images/1c9bd/1c9bd755a5ed9db93f379a79ea45256dea269c91" alt=""
毫无办法,本来这个属性是写在父类控制器里面的,现在的话可能麻烦很多了。
data:image/s3,"s3://crabby-images/94839/94839fd676b055812548afd0439e2c8f3fe81904" alt=""
5 我目前的适配方式是所有机型(5-7)看到的内容是一样多的,并不是采取大屏看到更多内容的方式,因为5-7的屏幕尺寸都是等比缩放过来的,我写间距的时候乘以了一个比例系数,这样做起来很方便。
data:image/s3,"s3://crabby-images/250eb/250eb6d7e815e9e4c895db9d75fd0585e5379187" alt=""
但是iPhoneX的屏幕并不是等比缩放过来的,只高出一点来,以后的布局方式就变得多样了,这一点也不苹果,向安卓低头。
ps:其他的问题我暂时没有发现,欢迎大家补充。