码迷,mamicode.com
首页 > 移动开发 > 详细

iOS之隐藏状态栏

时间:2016-07-02 20:20:53      阅读:183      评论:0      收藏:0      [点我收藏+]

标签:

iOS7中,不仅应用的风格有一定的变化,状态栏变化比较大,我们可以看到UIViewController的状态栏与导航栏基本是一体的。因此UIVIEWCONTROLLER的hide/show状态的方法也跟其他版本的不一样了。 在iOS7以前的版本,hide/show是通过以下代码实现

 

  1. [[UIApplication sharedApplication] setStatusBarHidden:YES(NO) withAnimation:UIStatusBarAnimationSlide];  


在 iOS7中默认情况下,这个方法不成功了。到setStatusBarHidden:withAnimation:声明的头文件去看看,多了一句注释: // Setting statusBarHidden does nothing if your application is using the default UIViewController-based status bar system. 现在在iOS7中,status bar的外观默认依赖UIViewController, 也就是说status bar随UIViewController的不同而不同。在这种默认的方式下,用全局的方法 setStatusBarHidden:withAnimation:是行不通的。

google一下发现现在的解决方法有两种:

如果只是单纯的隐藏状态栏,那么是在默认情况下,只需要重新实现两个新方法

 

  1. - (UIStatusBarStyle)preferredStatusBarStyle  
  2. {  
  3.     return UIStatusBarStyleLightContent;  
  4.     //UIStatusBarStyleDefault = 0 黑色文字,浅色背景时使用  
  5.   //UIStatusBarStyleLightContent = 1 白色文字,深色背景时使用  
  6. }  
  7.   
  8. - (BOOL)prefersStatusBarHidden  
  9. {  
  10.     return NO; //返回NO表示要显示,返回YES将hiden  
  11. }  



上面一个回调方法返回status bar显示时候的样式,下面一个回调控制是否显示status bar.

调用下面的一行代码将会触发上面的回调

 

  1. [self setNeedsStatusBarAppearanceUpdate];  


如果想在hiden/show之间有点动画效果,用下面的代码即可:

 

  1. [UIView animateWithDuration:0.5 animations:^{  
  2.         [self setNeedsStatusBarAppearanceUpdate];  
  3.     }];  

或者调用下面的代码:

 

  1. [[UIApplication sharedApplication] setStatusBarHidden:YES withAnimation:UIStatusBarAnimationSlide];  

在设置好这些,我们还是会发现一些问题,就是状态栏虽然没有了,但取而代之的是黑色的一片区域,所以我们还需要调整UIViewController的视图,具体代码为:

 

    1. -(void)viewDidLayoutSubviews  
    2. {  
    3.     CGRect viewBounds = self.view.bounds;  
    4.     CGFloat topBarOffset = 20.0;  
    5.     viewBounds.origin.y = -topBarOffset;  
    6.     self.view.bounds = viewBounds;  
    7.     [[UIApplication sharedApplication] setStatusBarStyle:UIStatusBarStyleLightContent];//for status bar style  

iOS之隐藏状态栏

标签:

原文地址:http://www.cnblogs.com/zhun/p/5635960.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!