iOS 适配iOS11+ 及 iPhone X系列

官方文档 https://developer.apple.com/ios/human-interface-guidelines

一、一些判断

判断系统版本


方式一、
#ifdef __IPHONE_11_0
    //在这里搞iOS11的事情
#else
    //在这里搞低版本的事情
#endif

方式二、
#if TBC_IS_IPHONE_OS_11_LATER

#else
    
#endif


方式三、
if (@available(iOS 11.0, *))

是否为iPhone X+

方式一、(废弃)
#define IS_IPHONE_X     ([UIScreen instancesRespondToSelector:@selector(currentMode)] ? CGSizeEqualToSize(CGSizeMake(1125, 2436), [[UIScreen mainScreen] currentMode].size) : NO)

方式二、(废弃)
#define IS_IPHONE_X     (( fabs((double)[[UIScreen mainScreen] bounds].size.height - (double)812) < DBL_EPSILON ) || (fabs((double)[[UIScreen mainScreen] bounds].size.width - (double)812) < DBL_EPSILON ))



方式三、
systemInfo.machine

方式四、(推荐)
static inline BOOL isIPhoneXSeries() {
    BOOL iPhoneXSeries = NO;
    if (UIDevice.currentDevice.userInterfaceIdiom != UIUserInterfaceIdiomPhone) {
        return iPhoneXSeries;
    }
    
    if (@available(iOS 11.0, *)) {
        UIWindow *mainWindow = [[[UIApplication sharedApplication] delegate] window];
        if (mainWindow.safeAreaInsets.bottom > 0.0) {
            iPhoneXSeries = YES;
        }
    }
    
    return iPhoneXSeries;
}

二、tableView下移20或64 或 在iPhone X下上划多出一点距离

automaticallyAdjustsScrollViewInsets废弃

打印出来看看是否是安全区域引起的tableView下移问题,主要是safeAreaInsets

如下代码片段,可以看出系统对tableView向下调整了20pt的距离,因为tableView超出了安全区域范围,被statusbar覆盖

tableview.contentInset: {64, 0, 60, 0}
tableview.safeAreaInsets: {20, 0, 0, 0}
tableview.adjustedContentInset: {84, 0, 60, 0}

推荐解决方案

1、2无非就是判断写法
1、
#ifdef __IPHONE_11_0 
if ([tableView respondsToSelector:@selector(setContentInsetAdjustmentBehavior:)]) { 
tableView.contentInsetAdjustmentBehavior = UIScrollViewContentInsetAdjustmentNever; 
} 
#endif

2、
判断为>=11
if (@available(iOS 11.0, *)) { 
      self.tableView.contentInsetAdjustmentBehavior = UIScrollViewContentInsetAdjustmentNever; 
} else { 
      self.automaticallyAdjustsScrollViewInsets = NO; 
}

三、其他下移问题

在iOS 11中默认启用Self-Sizing,,Headers, footers, and cells都默认开启了Self-Sizing
所有estimated 高度默认值从iOS11之前的 0 改变为UITableViewAutomaticDimension

解决方案

1、推荐
self.tableView.estimatedRowHeight = 0;
self.tableView.estimatedSectionHeaderHeight = 0;
self.tableView.estimatedSectionFooterHeight = 0;
2、需同时实现
heightForHeaderInSection
viewForHeaderInSection

四、iOS 11相册写权限

iOS 11 默认开启读权限,但是写权限还要增加
Privacy - Photo Library Additions Usage Description

iOS 11之前需要添加
Privacy - Photo Library Usage Description

在 iOS 11 中必须支持 When In Use 授权模式(NSLocationWhenInUseUsageDescription)
如果不提供When In Use 授权模式,那么 Always 相关授权模式也无法正常使用。

新增
NSLocationAlwaysAndWhenInUseUsageDescription

五、新增

UISearchController *searchController API_AVAILABLE(ios(11.0))

增加API_AVAILABLE(ios(11.0))NS_AVAILABLE_IOS(9_0)

例如
@property (nonatomic, retain, nullable) UISearchController *searchController API_AVAILABLE(ios(11.0));

方法同时适用

废弃的写法

- (void) searchDisplayControllerWillBeginSearch:(UISearchDisplayController *)controller NS_DEPRECATED_IOS(3_0,8_0);

SVP过期方法书写方式

+ (void)showWithMaskType:(SVProgressHUDMaskType)maskType __attribute__((deprecated("Use show and setDefaultMaskType: instead.")));

iPhone X+

如果用到Face ID 那么NSFaceIDUsageDescription权限加一下

开发只关心逻辑分辨率(point),目前有

320 X 480 (3GS、4、4s)
320 X 568 (5、5c、5s)
375 X 667 (6、7、8)
414 X 736 (6p、7p、8p)16:9
375 X 812 (X、XS)13:6
414 X 896 (XR)
414 X 896 (XS Max)

size

首先搞个LaunchImage

iPhone X 、XS
尺寸:1125px × 2436px
iPhone XR
尺寸:828px x 1792px
iPhone XS Max
尺寸:1242px x 2688px

状态栏由20增长到20 + 24 = 44
竖屏Tab Bar高度由49增长到49 + 34 = 83
键盘高度由216增长为216 + 75 = 291(在竖屏下包含Home Indicator)
注:竖屏Home Indicator高度为34,横屏时为21

Safe Area 与 Layout Margins

竖屏
上部留 44pt 給 Status Bar
Layout Margins 通常左右内缩 16pt。

横屏
Safe Area 左右两侧皆内缩 44pt
Layout Margins 通常左右再内缩 16pt

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,219评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,363评论 1 293
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,933评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,020评论 0 206
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,400评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,640评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,896评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,597评论 0 199
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,327评论 1 244
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,581评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,072评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,399评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,054评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,083评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,849评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,672评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,585评论 2 270

推荐阅读更多精彩内容