设置导航栏的一些技巧
2017-04-09 11:52
239 查看
ios上状态栏 就是指的最上面的20像素高的部分
状态栏分前后两部分,要分清这两个概念,后面会用到:
前景部分:就是指的显示电池、时间等部分;
背景部分:就是显示黑色或者图片的背景部分;
(一)设置statusBar的【前景部分】
简单来说,就是设置显示电池电量、时间、网络部分标示的颜色, 这里只能设置两种颜色:
默认的黑色(UIStatusBarStyleDefault)
白色(UIStatusBarStyleLightContent)
可以设置的地方有两个:plist设置里面 和 程序代码里
初始化设置:导航栏设置为不透明并给了"标题"与状态栏文字作对比
![](https://oscdn.geek-share.com/Uploads/Images/Content/202004/08/2ec2949d2ac7be4d34144db53e254f34)
只设置navigationBar不透明和写了一个标题.png
改变状态栏的方法
方法一:
1、plist
View controller-based status bar appearance 设置为 NO
![](https://oscdn.geek-share.com/Uploads/Images/Content/202004/08/583e49b84ec56f5639e33d2494bca02e)
设置为NO.png
2、代码设置
效果如下:
![](https://oscdn.geek-share.com/Uploads/Images/Content/202004/08/f6eb8913d86881e784021041742ce35e)
状态栏白色.png
方法二:
1、plist
View controller-based status bar appearance 设置为 YES 或者默认(不设置)
注意:
如果View controller-based status bar appearance为YES。
则[UIApplication sharedApplication].statusBarStyle 无效。
2、代码设置
![](https://oscdn.geek-share.com/Uploads/Images/Content/202004/08/5948f0399a7e33db251594688614c2bf)
状态栏导航栏文字都白色,背景黑色.png
或者在控制器中重写
(二)设置statusBar的【背景部分】
背景部分,简单来说,就是背景色;改变方法有两种:
1、系统提供的方法
navigationBar的setBarTintColor接口,用此接口可改变statusBar的背景色
![](https://oscdn.geek-share.com/Uploads/Images/Content/202004/08/3d7c821d1bd7d1a0ec4aff13b13efcec)
纯粹的背景色设置,默认字体都是黑色.png
如果想将状态栏和导航栏字体全变为白色,这样就行
![](https://oscdn.geek-share.com/Uploads/Images/Content/202004/08/c9fb9138f10fb88612baf61b1f877d73)
此行代码能将状态栏和导航栏字体颜色全体改变,只能是黑色或白色.png
如果只想改变导航栏的字体颜色,可以这样
![](https://oscdn.geek-share.com/Uploads/Images/Content/202004/08/3bf5c5431a02350790a50bef4aa66b2e)
在默认显示的标题中直接修改文件的大小和颜色也是可以的.png
还可以改变字体大小
![](https://oscdn.geek-share.com/Uploads/Images/Content/202004/08/d40b53dabf815679a4c84a8489809be8)
改变字体颜色大小.png
或者可以设置背景图片
![](https://oscdn.geek-share.com/Uploads/Images/Content/202004/08/cee068fe7e1247ad826c62603b1049d9)
图片背景.png
2、另辟蹊径
创建一个UIView,
设置该UIView的frame.size 和statusBar大小一样,
设置该UIView的frame.origin 为{0,-20},
设置该UIView的背景色为你希望的statusBar的颜色,
在navigationBar上addSubView该UIView即可。
原理:
状态栏区域相对于navigationBar的区域为
除了改变状态栏的前景色(文字颜色,wifi颜色,时间颜色,电池颜色),就是改变背景色.由于状态栏区域上的控件是隐藏的,所以只要在状态栏区域被渲染了颜色,状态栏的背景颜色就跟着一起改变,从而改变了状态栏的背景颜色.
![](https://oscdn.geek-share.com/Uploads/Images/Content/202004/08/9c5b62146acc09747448f89942b4c025)
改变状态栏的背景颜色.png
另外图片透明处理
navigationBar为透明,注释掉self.edgesForExtendedLayout = 0;
![](https://oscdn.geek-share.com/Uploads/Images/Content/202004/08/7be39384da364def215b154a71c290fb)
图片透明设置.png
状态栏分前后两部分,要分清这两个概念,后面会用到:
前景部分:就是指的显示电池、时间等部分;
背景部分:就是显示黑色或者图片的背景部分;
(一)设置statusBar的【前景部分】
简单来说,就是设置显示电池电量、时间、网络部分标示的颜色, 这里只能设置两种颜色:
默认的黑色(UIStatusBarStyleDefault)
白色(UIStatusBarStyleLightContent)
可以设置的地方有两个:plist设置里面 和 程序代码里
初始化设置:导航栏设置为不透明并给了"标题"与状态栏文字作对比
self.edgesForExtendedLayout = 0; self.navigationItem.title = @"标题";
只设置navigationBar不透明和写了一个标题.png
改变状态栏的方法
方法一:
1、plist
View controller-based status bar appearance 设置为 NO
设置为NO.png
2、代码设置
[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;
效果如下:
状态栏白色.png
方法二:
1、plist
View controller-based status bar appearance 设置为 YES 或者默认(不设置)
注意:
如果View controller-based status bar appearance为YES。
则[UIApplication sharedApplication].statusBarStyle 无效。
2、代码设置
self.navigationController.navigationBar.barStyle = UIBarStyleBlack;
状态栏导航栏文字都白色,背景黑色.png
或者在控制器中重写
preferredStatusBarStyle方法,修改状态栏颜色
- (UIStatusBarStyle)preferredStatusBarStyle { // return UIStatusBarStyleLightContent; return UIStatusBarStyleDefault; }
(二)设置statusBar的【背景部分】
背景部分,简单来说,就是背景色;改变方法有两种:
1、系统提供的方法
navigationBar的setBarTintColor接口,用此接口可改变statusBar的背景色
self.navigationController.navigationBar.barTintColor = [UIColor greenColor];
纯粹的背景色设置,默认字体都是黑色.png
如果想将状态栏和导航栏字体全变为白色,这样就行
self.navigationController.navigationBar.barStyle = UIBarStyleBlack;
此行代码能将状态栏和导航栏字体颜色全体改变,只能是黑色或白色.png
如果只想改变导航栏的字体颜色,可以这样
[self.navigationController.navigationBar setTitleTextAttributes:@{NSForegroundColorAttributeName:[UIColor redColor]}];
在默认显示的标题中直接修改文件的大小和颜色也是可以的.png
还可以改变字体大小
[self.navigationController.navigationBar setTitleTextAttributes:@{NSForegroundColorAttributeName:[UIColor redColor],NSFontAttributeName:[UIFont systemFontOfSize:25]}];
改变字体颜色大小.png
或者可以设置背景图片
[self.navigationController.navigationBar setBackgroundImage:[UIImage imageNamed:@"image01"] forBarMetrics:UIBarMetricsDefault];
图片背景.png
2、另辟蹊径
创建一个UIView,
设置该UIView的frame.size 和statusBar大小一样,
设置该UIView的frame.origin 为{0,-20},
设置该UIView的背景色为你希望的statusBar的颜色,
在navigationBar上addSubView该UIView即可。
原理:
状态栏区域相对于navigationBar的区域为
{0,-20,self.view.bounds.size.width,20}
除了改变状态栏的前景色(文字颜色,wifi颜色,时间颜色,电池颜色),就是改变背景色.由于状态栏区域上的控件是隐藏的,所以只要在状态栏区域被渲染了颜色,状态栏的背景颜色就跟着一起改变,从而改变了状态栏的背景颜色.
UIView *statusBarView = [[UIView alloc] initWithFrame:CGRectMake(0, -20, self.view.bounds.size.width, 20)]; statusBarView.backgroundColor = [UIColor greenColor]; [self.navigationController.navigationBar addSubview:statusBarView];
改变状态栏的背景颜色.png
另外图片透明处理
navigationBar为透明,注释掉self.edgesForExtendedLayout = 0;
// self.edgesForExtendedLayout = 0; [self.navigationController.navigationBar setBackgroundImage:[UIImage new] forBarMetrics:UIBarMetricsDefault] self.navigationController.navigationBar.shadowImage = [UIImage new];
图片透明设置.png
相关文章推荐
- Outlook 2003的一些设置技巧
- 防止adsl用户被入侵的一些技巧与设置方法
- windows server 2008下一些设置技巧及优化经验总结
- UIView背景图片设置一些技巧
- iOS应用开发中UITableView的分割线的一些设置技巧
- SourceInSight里面一些小的设置的技巧
- iOS -- 导航栏和标签栏的一些设置
- 关于设置半透明背景的一些技巧
- 关于导航栏和状态栏的一些UI设置
- ubuntu一些设置技巧
- Win2008中的一些设置技巧
- SourceInSight里面一些小的设置的技巧
- windows server 2008下的一些设置技巧及优化
- android studio快捷键中英文对照,一些使用技巧,一些设置
- ubuntu 10.04 下LAMP的一些设置和技巧
- 关于MTU的一些概念与设置技巧
- 关于MTU的一些概念与设置技巧
- windows server 2008下的一些设置技巧及优化
- iOS开发——导航栏的一些小设置
- 设置tabBar、导航栏背景的一些小方法等等