服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - IOS - iOS轻松实现导航栏透明渐变

iOS轻松实现导航栏透明渐变

2021-03-03 15:40u010850094 IOS

这篇文章主要为大家详细介绍了iOS轻松实现导航栏透明渐变效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

首先我们来看下效果

iOS轻松实现导航栏透明渐变

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

iOS轻松实现导航栏透明渐变

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

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

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

?
1
2
3
[self.navigationcontroller.navigationbar setbackgroundimage:[uiimage new]
forbarmetrics:uibarmetricsdefault];
self.navigationcontroller.navigationbar.shadowimage = [uiimage new];

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

1)我们设置的是backgroundimage,说明也许在我们的navigationbar上有一个imageview的子视图,而我们的看到的导航栏实际上看到的就是这个图片,因此设置它为无图片我们就可以看到透明,而设置backgroundcolor却不行。

2)我们还设置了shadowimage为无图,它其实就是导航栏下面的那根细线,如果你不写第二句话你则会看到一根线。

我们来看一下navigationbar的结构图

iOS轻松实现导航栏透明渐变

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

运行效果如图:

iOS轻松实现导航栏透明渐变

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

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

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

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

直接获取那张imageview,然后设置他的透明度。
其实我们从结构图中可以看出来,它是navigationbar的子视图,我们可以通过for...in循环遍历navigationbar.subviews,然后获得这个view。

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

barimageview = self.navigationcontroller.navigationbar.subviews.firstobject

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

3.其实已经可以了

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

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

?
1
2
3
4
5
6
7
8
- (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)你也可以动态的更改的状态栏和标题的颜色以和导航栏更匹配

?
1
2
3
4
5
6
//状态栏
[[uiapplication sharedapplication] setstatusbarstyle:uistatusbarstylelightcontent];
//标题颜色
self.navigationcontroller.navigationbar.titletextattributes = @{nsforegroundcolorattributename : [uicolor somecolor]}
//导航栏子控件颜色
self.navigationcontroller.navigationbar.tintcolor = [uicolor somecolor];

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

?
1
2
3
4
5
6
7
8
9
- (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

iOS轻松实现导航栏透明渐变

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

延伸 · 阅读

精彩推荐
  • IOSIOS 屏幕适配方案实现缩放window的示例代码

    IOS 屏幕适配方案实现缩放window的示例代码

    这篇文章主要介绍了IOS 屏幕适配方案实现缩放window的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    xiari5772021-06-01
  • IOSiOS布局渲染之UIView方法的调用时机详解

    iOS布局渲染之UIView方法的调用时机详解

    在你刚开始开发 iOS 应用时,最难避免或者是调试的就是和布局相关的问题,下面这篇文章主要给大家介绍了关于iOS布局渲染之UIView方法调用时机的相关资料...

    windtersharp7642021-05-04
  • IOSIOS开发之字典转字符串的实例详解

    IOS开发之字典转字符串的实例详解

    这篇文章主要介绍了IOS开发之字典转字符串的实例详解的相关资料,希望通过本文能帮助到大家,让大家掌握这样的方法,需要的朋友可以参考下...

    苦练内功5832021-04-01
  • IOSiOS通过逆向理解Block的内存模型

    iOS通过逆向理解Block的内存模型

    自从对 iOS 的逆向初窥门径后,我也经常通过它来分析一些比较大的应用,参考一下这些应用中某些功能的实现。这个探索的过程乐趣多多,不仅能满足自...

    Swiftyper12832021-03-03
  • IOS关于iOS自适应cell行高的那些事儿

    关于iOS自适应cell行高的那些事儿

    这篇文章主要给大家介绍了关于iOS自适应cell行高的那些事儿,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    daisy6092021-05-17
  • IOSiOS中tableview 两级cell的展开与收回的示例代码

    iOS中tableview 两级cell的展开与收回的示例代码

    本篇文章主要介绍了iOS中tableview 两级cell的展开与收回的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    J_Kang3862021-04-22
  • IOS解析iOS开发中的FirstResponder第一响应对象

    解析iOS开发中的FirstResponder第一响应对象

    这篇文章主要介绍了解析iOS开发中的FirstResponder第一响应对象,包括View的FirstResponder的释放问题,需要的朋友可以参考下...

    一片枫叶4662020-12-25
  • IOSiOS 雷达效果实例详解

    iOS 雷达效果实例详解

    这篇文章主要介绍了iOS 雷达效果实例详解的相关资料,需要的朋友可以参考下...

    SimpleWorld11022021-01-28