iOS7适配
状态栏设置
首先,需要在Info.plist
配置文件中,增加键:UIViewControllerBasedStatusBarAppearance
,并设置为YES
;
然后,在UIViewController
子类中实现以下两个方法:
objc
1 | - (UIStatusBarStyle)preferredStatusBarStyle |
swift
1 | override func preferredStatusBarStyle() -> UIStatusBarStyle { |
最后,在需要刷新状态栏样式的时候,调用[self setNeedsStatusBarAppearanceUpdate]
方法即可刷新
注意:
[self setNeedsStatusBarAppearanceUpdate]
在push
或者present
的controller
里面调用才起作用
iOS8适配
SDK 里面的某些API不能在iOS8下使用
如果,你的老项目在iOS8下运行,打开就闪退(iOS8之前没问题),那么“恭喜你”,你中招了,比如下面我遇到的,是因为旧版本的高德地图引用了 iOS8 里面不能用的api,如果你也需要类似的问题,那么是时候升级需要升级的第三方库了。
1 | Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[UIDevice asUniqueDeviceIdentifier]: unrecognized selector sent to instance 0x7c020080' |
iOS8 定位
之前版本的SDk是这样启动系统定位的
1 | // 判断定位操作是否被允许 |
如果在iOS8下用这样的方式,你会发现无法定位,那是因为iOS8下添加了新的方法
1 | //表示使用应用程序期间 开启定位 |
两者区别在于,iOS7 开始,有更强大的后台运行功能,如果 用 requestAlwaysAuthorization
方法,则表示后台运行时也会用到定位
iOS8 下使用系统定位如下:
1 | // 判断定位操作是否被允许 |
同时还需要添加新的方法,其他的都一样
1 | - (void)locationManager:(CLLocationManager *)manager didChangeAuthorizationStatus:(CLAuthorizationStatus)status { |
除了这些,你还需要在 info.plist
里面添加新的键值,否则 也是无法定位的
1 | //表示使用应用程序期间 开启定位 |
其中,NSLocationWhenInUseUsageDescription
(或者NSLocationAlwaysUsageDescription
) 对应的文字会在第一次请求用户同意定位的时候出现,还有 设置 > 隐私 > 定位 > your app 里面也会看到
iOS8 下注册通知的改变
这个不用多说,直接看代码就明白了
1 | //注册消息通知 |
iOS8 cell 层级的改变
如果你像这样取cell 的row 的话,那你又要加个判断方法了,在iOS8下cell的层级又改了,基本上每升级一个版本,苹果都会对cell的结构进行调整,在此建议不要用这样的方式取cell 的row,而是用属性的方式保存 indexPath
1 | NSUInteger curRow = 0; |
UIActionSheet and UIAlertView 的升级
在iOS8里面,官方提供了新的类UIAlertController来替换UIActionSheet and UIAlertView。
示例代码如下:
1 | UIAlertController* alert = [UIAlertController alertControllerWithTitle:@"My Alert" message:@"This is an alert." preferredStyle:UIAlertControllerStyleAlert]; |
至于为什么为加这个类,本人猜测是和iOS8新加的size classes有关,目的是统一屏幕在各个尺寸各个方向上的显示。如果你在iOS 8 里面使用UIActionSheet
and UIAlertView
可能会出现一些很奇怪的问题,建议在iOS 8 里面使用UIAlertController
,iOS 8 之前使用UIActionSheet
and UIAlertView
bounds和contentInset
在iOS 8中,[UIScreen bounds] 、[UIScreen applicationFrame] 、Status bar、Keyboard这些frame都是根据设备真实方向来返回frame的,而在iOS 7中,不过是横屏还是竖屏,iOS总是返回竖屏的frame,如以下输出:
iOS7
1 | 竖屏: |
iOS8
1 | 竖屏: |
这就对某些支持横屏的App造成了困扰,其实也只需要加两个宏或者改造一下就行了:
1 |
1 | CGSize getScreenSize() { |
虽然 contentInset
不属于屏幕适配的内容,但是我还是放在屏幕适配里说一下。
iOS8 和 iOS7 对 automaticallyAdjustsScrollViewInsets
属性的解释不一样:
- iOS8 会把该属性的影响作用到 controller 的 view 的 subviews 上
- iOS7 仅会作用到 self.view 上
另外当你还需要手动调用 contentInset
的时候,iOS7 似乎就不会自动调整了。
解决办法就是将 automaticallyAdjustsScrollViewInsets
设置为 NO
,然后自己控制 contentInset
。
iOS9适配
http无法请求
- 在
Info.plist
中添加NSAppTransportSecurity
类型Dictionary
。 - 在
NSAppTransportSecurity
下添加NSAllowsArbitraryLoads
类型Boolean
,值设为YES
或者直接添加一下配置
1 | <key>NSAppTransportSecurity</key> |
详细介绍 请查看
其他适配
详细介绍 请查看
iOS10适配
设备权限添加提示信息
最近更新版本时无论提交几次 在构建版本
里都不显示
iOS 10 的设备权限需要在plist 文件里面添加字段。
iOS 10 的设备权限 需要添加的字段有:
1 | <!-- 相册 --> |