iOS状态栏frame计算问题的实现

我们知道除了iPhoneX以外的设备导航栏默认高度都是20,当然苹果也为我们提供了计算状态栏frame的方法:

公司主营业务:成都做网站、成都网站建设、成都外贸网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。成都创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。成都创新互联推出柳城免费做网站回馈大家。

[[UIApplication sharedApplication] statusBarFrame];

这个方法在正常情况下返回的状态栏高度也是20,但当正在通话时,或者后台有APP正在使用定位功能时,顶部会出现两种提示条:

iOS状态栏frame计算问题的实现

正在通话.png

iOS状态栏frame计算问题的实现

后台有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状态栏frame计算问题的实现
文章出自:http://bzwzjz.com/article/pjhgoe.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 四川成都网站制作 成都响应式网站建设 H5网站制作 自适应网站建设 成都品牌网站设计 成都网站建设公司 做网站设计 上市集团网站建设 重庆网站建设 成都网站建设 成都网站建设流程 成都网站建设 成都网站设计公司 公司网站建设 成都网站制作 响应式网站建设 成都网站建设 网站制作 成都网站设计 成都网站建设 成都网站建设 定制网站建设多少钱