NavigationBar&tabBar调色那些事儿1. 导航栏调色那些事儿2. 标签栏TableBar那些事儿

Paste_Image.png

1. 导航栏调色那些事儿

小规律:

  • 要设置内容,全找item
  • 要修改颜色及文字属性,找bar

1.1 改变 NavigationBar 的背景颜色

[UINavigationBar appearance].barTintColor = [UIColor blueColor];
//如果使用的是backgroundColor,就会自带毛玻璃效果
self.navigationBar.backgroundColor = [UIcolor blueColor];

1.2 改变 NavigationBar 的字体颜色

NavigationBar 上面有两处可以改变字体颜色,一是标题,二是左右按钮的文字。

1.2.1 改变左右按钮的文字颜色:

[UINavigationBar appearance].tintColor = [UIColor whiteColor];

1.2.2 改变标题的文字颜色

  • 字典对应了一个系统自带的KEY,就是
    • 1,NSFontAttributeName:表示要穿一个字体UIFont
    • 2,NSForegroundColorAttributeName:表示要传一个颜色
[[UINavigationBar appearance] setTitleTextAttributes:@{NSForegroundColorAttributeName : [UIColor whiteColor]}];

1.3 去掉 NavigationBar 下方的阴影

iOS 7 NavigationBar的下方默认是有一条阴影的,如果想要 NavigationBar 和下面内容的背景颜色融为一体的话,就要去掉这个阴影。- 这里需要注意的是,如果图片传入的是nil,依然还会添加默认的阴影线。

  • 系统判断是否出现阴影线的标准是:是否传入照片。所以我们用[UIImage new]创建了一个空照片(不是nil)。
[[UINavigationBar appearance] setBackgroundImage:[UIImage new] forBarMetrics:UIBarMetricsDefault];[[UINavigationBar appearance] setShadowImage:[UIImage new]];

1.4 改变 TabBar 的字体颜色

[UITabBarItem.appearance setTitleTextAttributes: @{ NSForegroundColorAttributeName : [UIColor blueColor] } forState:UIControlStateNormal];
[UITabBarItem.appearance setTitleTextAttributes: @{ NSForegroundColorAttributeName : [UIColor whiteColor] } forState:UIControlStateSelected];

1.5 改变 StatusBar 的颜色

iOS7以后,status bar 的背景颜色变成了透明色,而且系统会根据 app的颜色自动改变 status bar 的字体颜色(黑和白)。但是这个自动改变的字体颜色并不一定和所有的 app 都搭配,比如我们 app 的主题色是稍微浅一丢丢的蓝,但是系统匹配的 status bar 的字体颜色就是黑色,看起来就很不爽,所以就要强制将其改为白色。

  • 方法一: 在 Info.plist 中的 Information Property List 中添加一个 Key为View controller-based status bar appearance的 item,其 Type 设为 Boolean,Value 设为 NO
  • 方法二: 然后在AppDelegate.mapplication:didFinishLaunchingWithOptions:中添加突下设置:
[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;

1.6 隐藏 StatusBar

有时候为了实现沉浸式设计,比如 app 首次打开的引导页,需要隐藏整个 StatusBar,方法如下:

  • 状态栏的高度是20
  • 方法一: 和改变 StatusBar 颜色一样,在 Info.plist 中的 Information Property List 中添加一个 Key为View controller-based status bar appearance的 item,其 Type 设为 Boolean,Value 设为 NO
  • 方法二: 在需要隐藏StatusBar 的 ViewController 中的viewDidLoad加入以下代码:
if ([self respondsToSelector:@selector(setNeedsStatusBarAppearanceUpdate)]) { [self prefersStatusBarHidden]; [self setNeedsStatusBarAppearanceUpdate]; }
  • 方法三: 重写prefersStatusBarHidden:
-(BOOL)prefersStatusBarHidden { return YES;}
  • 如果子控制器需要控制状态栏,在全局导航栏控制器下面还需要增加以下方法:
- (UIViewController *)childViewControllerForStatusBarStyle{
   return self.topViewController;
}

1.7 给导航栏设置一张背景图片

  • 这张背景图片系统默认的高度是64
 [self.navigationBar setBackgoundImage:[UIImage imageNamed:@"navBar"] forBarMetrics:UIBarMetricsDefault];

1.8 导航栏的半透明效果

  • 如果设置成NO,tableView就从状态栏下面开始。
  • 如果是YES,就带了毛玻璃效果,tableView就从屏幕的左上角开始了。
  • 导航栏的默认高度是44.
self.navigationBar.translucent = YES;

1.9 自定义头部View

self.navigationItem.titleView = [[UILabel alloc] init]; 

2. 标签栏TableBar那些事儿

2.1 调色

可以完全参考导航栏的,几乎雷同。

2.2 关闭半透明效果

  • 一旦关闭标签栏的半透明效果,控制器的view就不会到达屏幕最底部了,而是到了标签栏的紧上方。
  • 标签栏的默认高度是49.
self.tabBar.translucent = NO;

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏進无尽的文章

实践-腾讯新闻图文详情实现

11520
来自专栏一“技”之长

iOS开发中标签控制器的使用——UITabBarController

        与导航控制器相类似,标签控制器也是用于管理视图控制器的一个UI控件,在其内部封装了一个标签栏,与导航不同的是,导航的管理方式是纵向的,采用pus...

10420
来自专栏滕先生的博客

CALayer 图层概念二、CALayer属性二、方法

31770
来自专栏编程之旅

UINavigationBar的用法

UINavigationBar是一个我们在开发中必定会碰到的控件,用好它能帮助我们自定义导航栏的样式,所以今天讲解一下UINavigationBar的用法。

47220
来自专栏進无尽的文章

UI篇-UINavigationController之易忘补充

[UIApplication sharedApplication].statusBarHidden = YES;

25120
来自专栏猿人谷

UIButton使用方法汇总

//按钮初始化类方法 UIButton *button1 = [UIButton buttonWithType:UIButtonTypeRoundedRect...

21350
来自专栏mukekeheart的iOS之旅

iOS学习——Quartz2D学习之UIKit绘制

  在IOS中绘图技术主要包括:UIKit、Quartz 2D、Core Animation和OpenGL ES。其中Core Animation提供动画实现技...

14020
来自专栏一“技”之长

iOS UITextField 使用与方法解读

UITextField是IOS开发中用户交互中重要的一个控件,常被用来做账号密码框,输入信息框等。

6910
来自专栏程序员叨叨叨

手把手教你打造RecyclerView滚动特效

最近开发中遇到这样的需求,recyclerview的item随滚动改变大小和透明度。这个效果看起来挺有动感的,似乎实现起来有点复杂,其实不然,接下来将带领大家手...

17410
来自专栏糊一笑

移动端效果之IndexList

写在前面 接着前面的移动端效果讲,这次讲解的的是IndexList的实现原理。效果如下: ? 代码请看这里:github 移动端效果之swiper 移动端效果之...

24040

扫码关注云+社区

领取腾讯云代金券