几句话实现导航栏透明渐变 – iOS

首先我们来看下效果

一开始当我们什么只设置了一张图片作为它的头部视图的时候,它是这样的

  1. 首当其冲的,我们先得把导航栏弄透明

那么我们首先得知道,设置navigationBar的BackgroundColor为Clear是没用的,你可以试着设置它的clear,但是没用,原因一会儿我们就知道了

而对于把导航栏设置为透明,网上大多数的方法是

[self.navigationController.navigationBar setBackgroundImage:[UIImage new]

forBarMetrics:UIBarMetricsDefault];

self.navigationController.navigationBar.shadowImage = [UIImage new];

你可以运行这两句话到你的程序,你会发现这样确实是可以的,那么我们可以从中得到几个信息

  1. 我们设置的是BackgroundImage,说明也许在我们的navigationBar上有一个ImageView的子视图,而我们的看到的导航栏实际上看到的就是这个图片,因此设置它为无图片我们就可以看到透明,而设置backgroundColor却不行
  2. 我们还设置了shadowImage为无图,它其实就是导航栏下面的那根细线,如果你不写第二句话你则会看到一根线

我们来看一下navigationBar的结构图

从图中我们可以很清楚的看到,NavigationBar他背后是有一张类型为_UINavigationBarBackground(UIImageView的子类)的视图,我们平时看到的大部分其实都是它,第二个箭头那里的ImageView就是那根细线,他是加在我们背景的ImageView上面的,我们设置BackgroundImage其实就是设置_UINavigationBarBackground的image

运行效果如图

2.还得让它不仅仅是透明

这,怎么整?我们有几种方案

  1. 设置渐变图片

    根据上面设置为透明的方法,我们最直接能想到的还是setBackgroundImage,根据滑动距离去设置 图片 的alpha,是的,我们是去设置图片,而不是设置UIView,这样的话就需要你不停的去生成新图片赋给BackgroundImage,这样感觉是不是会不太好?

  2. 运行时动态绑定

    我们可以在运行时动态绑定他的背景视图,然后设置他的背景透明度,网上有一个通过类别方式动态绑定实现导航栏颜色渐变的三方框架,感兴趣的朋友可以自行去研究研究LTNavigation

  3. 直接获取那张ImageView,然后设置他的透明度

    其实我们从结构图中可以看出来,他是NavigationBar的子视图,我们可以通过for…in循环遍历navigationBar.subviews,然后获得这个view.

当然,更简单的,它其实就在subviews的第一个,即,我们可以这样

barImageView = self.navigationController.navigationBar.subviews.firstObject

我们可以用一个全局的imageView引用他,以免我们每次都要写一长串

3.其实已经可以了

我们还需要做什么?没错,最后一步,我们仅仅只需要在scrollViewDidScroll里面,根据偏移量来动态改变barImageView的背景颜色(或者透明度)就行了

例如我们需要在-64(默认的最小偏移量)到200之间变化

- (void)scrollViewDidScroll:(UIScrollView *)scrollView {

CGFloat minAlphaOffset = - 64;

CGFloat maxAlphaOffset = 200;

CGFloat offset = scrollView.contentOffset.y;

CGFloat alpha = (offset - minAlphaOffset) / (maxAlphaOffset - minAlphaOffset);

_barImageView.alpha = alpha;

}

就这样你就可以实现我在文章一开始那个图片的效果了(其实并不是,tintColor和satusBarStyle还没变)

Tips

1.你也可以动态的更改的状态栏和标题的颜色以和导航栏更匹配

//状态栏

[[UIApplication sharedApplication] setStatusBarStyle:UIStatusBarStyleLightContent];

//标题颜色

self.navigationController.navigationBar.titleTextAttributes = @{NSForegroundColorAttributeName : [UIColor someColor]}

//导航栏子控件颜色

self.navigationController.navigationBar.tintColor = [UIColor someColor];

2.注意释放tableView 的 delegate(不然你进进出出时候会发现哪里好像不太对)

- (void)viewWillAppear:(BOOL)animated {

[super viewWillAppear:animated];

self.tableView.delegate = self;

}

- (void)viewWillDisappear:(BOOL)animated {

[super viewWillDisappear:animated];

self.tableView.delegate = nil;

}

3.导航栏是公有的

所以你可能需要在ViewWillDisappear里面再把导航栏设置为你需要的样子

还有一件事情(This word Learn from Steve jobs)

我自己封装了一些导航栏变化效果,使用简单,欢迎大家尝试MXNavigationBarManager

https://github.com/cwxatlm/MXNavigationBarManager

时间: 2024-10-12 15:39:12

几句话实现导航栏透明渐变 – iOS的相关文章

ios 导航栏透明, 上下滑动 导航栏 颜色渐变

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px "PingFang SC"; color: #008400 } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #3d1d81 } p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #008400 } p.p4 {

Swift 设置导航栏透明

Swift 设置导航栏透明,就是设置一张空的图片,但如果只设置这一句代码,并不起作用,还需要其他设置,直接上代码 // 1.设置导航栏标题属性:设置标题颜色 self.navigationController?.navigationBar.titleTextAttributes = [NSForegroundColorAttributeName:UIColor.white] // 2.设置导航栏前景色:设置item指示色 self.navigationController?.navigation

<iOS 导航栏>第一节:导航栏透明方法实现代码

说下导航栏的透明方法: 很多应用需要导航栏随着向上滑动,逐渐从透明变成不透明,很炫酷,大部分应用都在使用导航栏渐变效果,现附上代码然后直接将实现,一会讲下如何来实现,这一部分直接上代码. 先附上代码: 方法声明: #import <UIKit/UIKit.h> @interface IDSNavBarView : UIView - (instancetype)initWithFrame:(CGRect)frame titleImg:(UIImage *)aTitleImg; - (UILabe

iOS笔记-导航栏透明与不透明的影响

首先设置导航栏透明属性的代码是: self.navigationController.navigationBar.translucent = YES; 默认情况下是YES,就是导航栏是透明的, 于是我设置了约束之后是这样的 看出来不对的地方没 ,就是我的界面上半部分被挡住了 当设置属性为NO时 也就是不让导航栏透明, 一切变迎刃而解 完美~ 补充个笔记:设置导航栏背景色的代码是: self.navigationController.navigationBar.barTintColor = [UI

ios7 ios8导航栏透明

自动调整scrollview的insets为0, 然后scrollview就不会向下偏移64px self.automaticallyAdjustsScrollViewInsets = NO; 导航栏透明: self.navigationController.navigationBar.alpha = 0;

iOS导航栏-导航栏透明

设置一张透明图片:nav_bargound.png //导航栏背景    [self.navigationController.navigationBar setBackgroundImage:[UIImage imageNamed:@"nav_bargound.png"] forBarMetrics:UIBarMetricsDefault];        //导航栏底部线    self.navigationController.navigationBar.shadowImage 

导航栏颜色渐变

1.导航栏开始时是没有导航栏的感觉,往上滚动后又出现导航栏,采用下面的方法 - (void)scrollViewDidScroll:(UIScrollView *)scrollView { CGFloat minAlphaOffset = - 88; CGFloat maxAlphaOffset = 200; CGFloat offset = scrollView.contentOffset.y; CGFloat alpha; if (offset <= 0) { alpha = 0.0; }

iOS 导航栏遮挡问题 --- iOS开发系列 ---项目中成长的知识七

不知大家有没有遇见过自己写的tableview被导航栏遮挡住的问题,反正我是遇见过! 因为在ios7以后所有的UIViewController创建后默认就是full Screen的,因此如果带导航栏的应用界面中的部分控件会被导航栏覆盖掉. 解决方案:可以使用ios7中的UIViewController新增的属性extendLayoutIncludesOpaqueBars和edgesForExtendedLayout来解决. extendLayoutIncludesOpaqueBars指定了当ba

移动端底部导航栏固定——兼容IOS

问题:移动端前端底部导航栏设计 兼容安卓下的各种浏览器和IOS自带的Safari,但是不兼容苹果下的 钉钉. 具体代码格式: <body> <!-- 头部导航栏 --> <div class="header">内容</div> <!-- 内容 --> <div class="content">内容</div> <!-- 底部导航栏 --> <div class=&q