快速适配先说结论,找设计师要2张启动图:
iPhone XR:828px x 1792px
iPhone XS Max: 1242px x 2688px安全
代码中使用了屏幕size判断是不是iPhone X的须要修改,请翻到最后。app
iPhone全部设备的尺寸和分辨率iphone
XCode GM Bug?ide
项目中使用LaunchImage来作启动图,那么有可能在XCode GM的LaunchImage中会出现只有iPhone X/iPhone XS启动图,而且iOS 8.0 and Later
没有被选中,而且没有iPhone XR/iPhone XS Max,须要手动选择一下iOS 8.0 and Later
,才会出现iPhone XR/iPhone XS Max启动图。 这多是XCode GM中的一个Bug。ui
XCode9 LaunchImagespa
XCode10 GM LaunchImage iOS 8.0 and Later
没有被选中设计
XCode10 GM LaunchImage iOS 8.0 and Later
手动选中才出现 iPhone XR/iPhone XS Maxcode
若是没有设置iPhone XR/iPhone XS Max启动图但设置了iPhone X的启动图,iPhone XR / XS Max默认会走iPhone X 的尺寸375ptx812pt,会对内容近乎于等比拉伸放到iPhone XR / XS Max屏幕内,以下图:cdn
这里为何说是近乎于等比拉伸: iPhone X 高宽比:812/375 = 2.16533333 iPhone XR 和 iPhone XS Max 高宽比:896/414 = 2.16425121blog
型号 | 逻辑尺寸 | 系数 | 分辨率 |
---|---|---|---|
iPhone XR | 414pt x 896pt | @2 | 828px x 1792px |
iPhone XS Max | 414pt x 896pt | @3 | 1242px x 2688px |
当时看发布会以为XR 828px的分辨率有点奇怪,如今看来并非苹果不想作720或1080,而是有照顾开发工程师的目的。 XR 和 XS Max 在逻辑大小上很是统一2x,3x就够了,也不用作其余的切图。
因此如今只是须要设计师给2张效果图:
iPhone XR:828px x 1792px
iPhone XS Max: 1242px x 2688px
若是你之前是使用设备尺寸来判断iPhone X那就须要修改了,判断iPhone X主要是由于刘海的缘由可能要作些特殊处理。鉴于iPhone X/XS/XR/XS Max底部都会有安全距离,因此能够利用safeAreaInsets.bottom > 0.0
来判断是不是iPhone X/XS/XR/XS Max。
safeAreaInsets支持iOS11及之后。
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;
}
复制代码
Detect if the device is iPhone X
《Tech Talks - Session 207》