iOS状态栏frame计算问题的实现
更新时间:2018年06月08日 14:36:06 作者:weakTong
这篇文章主要介绍了iOS状态栏frame计算问题的实现,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
我们知道除了iPhoneX以外的设备导航栏默认高度都是20,当然苹果也为我们提供了计算状态栏frame的方法:
[[UIApplication sharedApplication] statusBarFrame];
这个方法在正常情况下返回的状态栏高度也是20,但当正在通话时,或者后台有APP正在使用定位功能时,顶部会出现两种提示条:
正在通话.png
后台有APP使用定位.jpeg
当顶部有这两种提示条出现时,上面的statusBarFrame方法返回的状态栏高度就变成了40,在手动更改顶部约束的时候就会出现问题,最后没找到解决方法,只能手动改回20,感觉是有那么点low。
if (iPhoneX) {//x上不做任何改变 return rectStatus.size.height + rectNav.size.height; } else { if (rectStatus.size.height == 40) {//顶部有导航或者电话条时,状态栏高度系统方法计算错误,手动置为20 CGFloat fStatusBarHeight = 20; return fStatusBarHeight + rectNav.size.height; } else { return rectStatus.size.height + rectNav.size.height; } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章
关于iOS GangSDK的使用 为App快速集成社群公会模块
这篇文章主要介绍了iOS GangSDK的使用为App快速集成社群公会模块功能的实现过程。2017-11-11详解iOS App中UIPickerView滚动选择栏的添加方法
UIPickerView组件在应用中选择地区等方面的运用非常常见,能够提供多列的选择项,下买呢我们就来详解iOS App中UIPickerView滚动选择栏的添加方法2016-05-05
最新评论