iOS preferredstatusbarstyle 不执行
2016-01-29 11:02
489 查看
UINavgationController中覆写preferredStatusBarStyle方法不执行的问题
如果viewController不是在 UINavgationController中,那么以上代码可以把状态栏文本颜色设置为白色,但是如果 viewController是添加到导航上的,你会发现上面代码达不到你想要的效果,状态栏文本颜色是黑色的!
这是为什么?
经过查找资料,才知道原来是这么一回事:
*UINavigationController不会将 preferredStatusBarStyle方法调用转给它的子视图,而是由它自己管理状态,而且它也应该那样做.因为UINavigationController 包含了它自己的状态栏
因此就算 UINavigationController中的viewController 实现了 preferredStatusBarStyle方法 也不会调用
那 UINavigationController是怎么决定 该返回 UIStatusBarStyleLightContent 还是 UIStatusBarStyleDefault的呢? 它是基于它的 UINavigationBar.barStyle属性.默认(UIBarStyleDefault)的是黑色文本的状态栏 而 UIBarStyleBlack是设置为白色文本的状态栏*
也就是说,如果viewController是在导航中的,想要改变状态栏文本颜色,那么需要通过代码:
另外,如果viewController在导航中,还想通过 preferredStatusBarStyle 方法设置状态栏文本颜色,那就只能隐藏导航栏了:
#import "ViewController.h" @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; } -(UIStatusBarStyle)preferredStatusBarStyle { return UIStatusBarStyleDefault; } @end
如果viewController不是在 UINavgationController中,那么以上代码可以把状态栏文本颜色设置为白色,但是如果 viewController是添加到导航上的,你会发现上面代码达不到你想要的效果,状态栏文本颜色是黑色的!
这是为什么?
经过查找资料,才知道原来是这么一回事:
*UINavigationController不会将 preferredStatusBarStyle方法调用转给它的子视图,而是由它自己管理状态,而且它也应该那样做.因为UINavigationController 包含了它自己的状态栏
因此就算 UINavigationController中的viewController 实现了 preferredStatusBarStyle方法 也不会调用
那 UINavigationController是怎么决定 该返回 UIStatusBarStyleLightContent 还是 UIStatusBarStyleDefault的呢? 它是基于它的 UINavigationBar.barStyle属性.默认(UIBarStyleDefault)的是黑色文本的状态栏 而 UIBarStyleBlack是设置为白色文本的状态栏*
也就是说,如果viewController是在导航中的,想要改变状态栏文本颜色,那么需要通过代码:
//将status bar 文本颜色设置为白色 self.navigationController.navigationBar.barStyle = UIBarStyleBlack;
//将status bar 文本颜色设置为黑色 ,默认就是黑色 self.navigationController.navigationBar.barStyle = UIBarStyleDefault;
另外,如果viewController在导航中,还想通过 preferredStatusBarStyle 方法设置状态栏文本颜色,那就只能隐藏导航栏了:
//隐藏导航栏后 系统会调用 preferredStatusBarStyle 方法 self.navigationController.navigationBarHidden = YES;
相关文章推荐
- javaScript 与OC方法的调用
- iPhone6的CSS3媒体查询
- 整理HTML5的一些新特性与Canvas的常用属性
- CSS3动画-表盘
- js倒计时
- 动态创建按钮的JavaScript代码
- JavaScript面向对象初探——原型链、封装和继承
- js数值使用及数组转json,转化后的json传入后台解析
- jquery的each和js原生for循环性能对比
- jquery里的val()给对象重新复制
- 根据iPhone6设计稿动态计算rem值
- JQuery基本选择器
- 所有设备的CSS像素
- 使用js实现tab选项卡效果
- css属性第二版
- node.js
- js动态创建按钮
- ArcGIS api for javascript加载shapefile
- jQuery下的瀑布流效果
- OpenGL学习笔记 transform feedback缓存&粒子系统示例分析